import { DataProvider } from "@opencode-ai/ui/context" import { showToast } from "@opencode-ai/ui/toast" import { base64Encode } from "@opencode-ai/core/util/encode" import { useLocation, useNavigate, useParams } from "@solidjs/router" import { createEffect, createMemo, createResource, type ParentProps, Show } from "solid-js" import { useLanguage } from "@/context/language" import { LocalProvider } from "@/context/local" import { SDKProvider } from "@/context/sdk" import { SyncProvider, useSync } from "@/context/sync" import { decode64 } from "@/utils/base64" function DirectoryDataProvider(props: ParentProps<{ directory: string }>) { const location = useLocation() const navigate = useNavigate() const params = useParams() const sync = useSync() const slug = createMemo(() => base64Encode(props.directory)) createEffect(() => { const next = sync.data.path.directory if (!next || next === props.directory) return const path = location.pathname.slice(slug().length + 1) navigate(`/${base64Encode(next)}${path}${location.search}${location.hash}`, { replace: true }) }) createResource( () => params.id, (id) => sync.session.sync(id), ) return ( navigate(`/${slug()}/session/${sessionID}`)} onSessionHref={(sessionID: string) => `/${slug()}/session/${sessionID}`} > {props.children} ) } export default function Layout(props: ParentProps) { const params = useParams() const language = useLanguage() const navigate = useNavigate() let invalid = "" const resolved = createMemo(() => { if (!params.dir) return "" return decode64(params.dir) ?? "" }) createEffect(() => { const dir = params.dir if (!dir) return if (resolved()) { invalid = "" return } if (invalid === dir) return invalid = dir showToast({ variant: "error", title: language.t("common.requestFailed"), description: language.t("directory.error.invalidUrl"), }) navigate("/", { replace: true }) }) return ( {(resolved) => ( resolved}> {props.children} )} ) }