summaryrefslogtreecommitdiffhomepage
path: root/packages/app/src/pages/directory-layout.tsx
blob: 473dcd8e10d415c879b93df84d43d74bf057be72 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
import { createMemo, Show, type ParentProps } from "solid-js"
import { useParams } from "@solidjs/router"
import { SDKProvider, useSDK } from "@/context/sdk"
import { SyncProvider, useSync } from "@/context/sync"
import { LocalProvider } from "@/context/local"
import { PermissionProvider } from "@/context/permission"
import { base64Decode } from "@opencode-ai/util/encode"
import { DataProvider } from "@opencode-ai/ui/context"
import { iife } from "@opencode-ai/util/iife"

export default function Layout(props: ParentProps) {
  const params = useParams()
  const directory = createMemo(() => {
    return base64Decode(params.dir!)
  })
  return (
    <Show when={params.dir} keyed>
      <SDKProvider directory={directory()}>
        <SyncProvider>
          {iife(() => {
            const sync = useSync()
            const sdk = useSDK()
            const respond = (input: {
              sessionID: string
              permissionID: string
              response: "once" | "always" | "reject"
            }) => sdk.client.permission.respond(input)

            return (
              <PermissionProvider permissions={sync.data.permission} onRespond={respond}>
                <DataProvider data={sync.data} directory={directory()} onPermissionRespond={respond}>
                  <LocalProvider>{props.children}</LocalProvider>
                </DataProvider>
              </PermissionProvider>
            )
          })}
        </SyncProvider>
      </SDKProvider>
    </Show>
  )
}