@powerhousedao/connect 6.1.0-dev.8 → 6.1.0-dev.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{DebugSettingsModal-C4h137r_.js → DebugSettingsModal-D2TozI0o.js} +4 -4
- package/dist/{DebugSettingsModal-C4h137r_.js.map → DebugSettingsModal-D2TozI0o.js.map} +1 -1
- package/dist/{SettingsModal-_I7Ud_Q_.js → SettingsModal-B-uWoxSI.js} +5 -5
- package/dist/{SettingsModal-_I7Ud_Q_.js.map → SettingsModal-B-uWoxSI.js.map} +1 -1
- package/dist/{build-info-D_VQNdd7.js → build-info-BERZooDe.js} +4 -4
- package/dist/{build-info-D_VQNdd7.js.map → build-info-BERZooDe.js.map} +1 -1
- package/dist/{load-DGsqNKew.js → load-DZUI_Umw.js} +4 -4
- package/dist/{load-DGsqNKew.js.map → load-DZUI_Umw.js.map} +1 -1
- package/dist/main.js +1 -1
- package/dist/{package-BrFYj3Kr.js → package-DT0VGtRf.js} +4 -4
- package/dist/package-DT0VGtRf.js.map +1 -0
- package/dist/{sidebar-soAXdN3i.js → sidebar-CZLMU1VL.js} +6 -6
- package/dist/{sidebar-soAXdN3i.js.map → sidebar-CZLMU1VL.js.map} +1 -1
- package/dist/start-connect.js +1 -1
- package/package.json +9 -9
- package/dist/package-BrFYj3Kr.js.map +0 -1
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
|
|
2
|
-
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="
|
|
2
|
+
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="faf59a0b-8d1f-528b-89db-d5308093b760")}catch(e){}}();
|
|
3
3
|
import { t as connectConfig } from "./connect.config-B2xP5Iez.js";
|
|
4
|
-
import { n as getGitUrl, r as shortGitSha, t as getGitSha } from "./build-info-
|
|
4
|
+
import { n as getGitUrl, r as shortGitSha, t as getGitSha } from "./build-info-BERZooDe.js";
|
|
5
5
|
import { t as serviceWorkerManager } from "./registerServiceWorker-5FDz0DvH.js";
|
|
6
6
|
import { closePHModal, usePHModal } from "@powerhousedao/reactor-browser";
|
|
7
7
|
import { useEffect, useState } from "react";
|
|
@@ -168,5 +168,5 @@ const DebugSettingsModal = () => {
|
|
|
168
168
|
//#endregion
|
|
169
169
|
export { DebugSettingsModal };
|
|
170
170
|
|
|
171
|
-
//# sourceMappingURL=DebugSettingsModal-
|
|
172
|
-
//# debugId=
|
|
171
|
+
//# sourceMappingURL=DebugSettingsModal-D2TozI0o.js.map
|
|
172
|
+
//# debugId=faf59a0b-8d1f-528b-89db-d5308093b760
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DebugSettingsModal-
|
|
1
|
+
{"version":3,"file":"DebugSettingsModal-D2TozI0o.js","sources":["../src/components/modal/modals/DebugSettingsModal.tsx"],"sourcesContent":["import { connectConfig } from \"@powerhousedao/connect/config\";\nimport {\n getGitSha,\n getGitUrl,\n serviceWorkerManager,\n shortGitSha,\n} from \"@powerhousedao/connect/utils\";\nimport { Icon, Modal, PowerhouseButton } from \"@powerhousedao/design-system\";\nimport { Combobox, FormInput } from \"@powerhousedao/design-system/connect\";\nimport { closePHModal, usePHModal } from \"@powerhousedao/reactor-browser\";\nimport { useEffect, useState } from \"react\";\n\nexport const DebugSettingsModal: React.FC = () => {\n const phModal = usePHModal();\n const open = phModal?.type === \"debugSettings\";\n\n const [appVersion, setAppVersion] = useState(connectConfig.appVersion);\n const [serviceWorkerDebugMode, setServiceWorkerDebugMode] = useState({\n label: serviceWorkerManager.debug ? \"Enabled\" : \"Disabled\",\n value: serviceWorkerManager.debug,\n });\n\n useEffect(() => {\n serviceWorkerManager.setDebug(serviceWorkerDebugMode.value);\n }, [serviceWorkerDebugMode]);\n\n return (\n <Modal\n open={open}\n onOpenChange={(status) => {\n if (!status) return closePHModal();\n }}\n contentProps={{\n className: \"rounded-2xl\",\n }}\n >\n <div className=\"w-[700px] rounded-2xl bg-white p-6\">\n <div className=\"mb-6 flex justify-between\">\n <div className=\"text-xl font-bold\">Debug Tools</div>\n <button id=\"close-modal\" onClick={() => closePHModal()}>\n <Icon name=\"Xmark\" size={28} />\n </button>\n </div>\n <div className=\"flex text-sm font-bold\">\n <Icon name=\"Ring\" size={22} />\n <span className=\"ml-2\">App Version: {connectConfig.appVersion}</span>\n {(() => {\n const sha = getGitSha();\n if (sha === \"unknown\") return null;\n const url = getGitUrl();\n const label = shortGitSha(sha);\n return url ? (\n <a\n className=\"ml-2 font-mono text-xs font-normal text-blue-600 hover:underline\"\n href={url}\n target=\"_blank\"\n rel=\"noreferrer noopener\"\n title={sha}\n >\n ({label})\n </a>\n ) : (\n <span\n className=\"ml-2 font-mono text-xs font-normal text-gray-500\"\n title={sha}\n >\n ({label})\n </span>\n );\n })()}\n </div>\n <div className=\"mt-4 flex text-sm font-bold\">\n <Icon name=\"Hdd\" size={22} />\n <span className=\"ml-2\">Drive Tools:</span>\n </div>\n\n <div className=\"mt-4 flex text-sm font-bold\">\n <Icon name=\"Gear\" size={22} />\n <span className=\"ml-2\">Service Worker Tools:</span>\n </div>\n <div className=\"mt-2 flex items-end justify-between pl-4\">\n <div className=\"w-[400px]\">\n <label htmlFor=\"serviceWorkerDebugMode\" className=\"text-xs\">\n Service Worker Debug Mode:\n </label>\n <Combobox\n id=\"serviceWorkerDebugMode\"\n onChange={(value) => {\n setServiceWorkerDebugMode(\n value as typeof serviceWorkerDebugMode,\n );\n }}\n value={serviceWorkerDebugMode}\n options={[\n { label: \"Enabled\", value: true },\n { label: \"Disabled\", value: false },\n ]}\n />\n </div>\n </div>\n <div className=\"mt-2 flex items-end justify-between pl-4\">\n <div className=\"w-[400px]\">\n <label htmlFor=\"appVersion\" className=\"text-xs\">\n Set invalid app version:\n </label>\n <FormInput\n containerClassName=\"p-1 bg-white border border-gray-200 rounded-md text-sm\"\n inputClassName=\"text-xs font-normal\"\n id=\"appVersion\"\n icon={\n <div className=\"flex h-full items-center text-xs\">Version:</div>\n }\n value={appVersion}\n onChange={(element) => setAppVersion(element.target.value)}\n />\n </div>\n <div className=\"mb-1 flex items-center justify-center\">\n <PowerhouseButton\n color={appVersion === \"\" ? \"light\" : \"red\"}\n size=\"small\"\n disabled={appVersion === \"\"}\n onClick={() => {\n // @ts-expect-error todo add send message method to service worker manager class\n serviceWorkerManager.sendMessage({\n type: \"SET_APP_VERSION\",\n version: appVersion,\n });\n setAppVersion(\"\");\n }}\n >\n Add Invalid App Version\n </PowerhouseButton>\n </div>\n </div>\n </div>\n </Modal>\n );\n};\n"],"names":[],"mappings":"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","debug_id":"faf59a0b-8d1f-528b-89db-d5308093b760"}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
|
|
2
|
-
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="
|
|
2
|
+
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="0dd4d614-df51-53b1-b58e-bd2c5f55e06a")}catch(e){}}();
|
|
3
3
|
import { t as connectConfig } from "./connect.config-B2xP5Iez.js";
|
|
4
4
|
import { n as toast } from "./toast-DnODOv28.js";
|
|
5
5
|
import { t as useRegistryPackages } from "./useRegistryPackages-PUiMxd73.js";
|
|
6
|
-
import { t as package_default } from "./package-
|
|
7
|
-
import { n as getGitUrl, r as shortGitSha, t as getGitSha } from "./build-info-
|
|
6
|
+
import { t as package_default } from "./package-DT0VGtRf.js";
|
|
7
|
+
import { n as getGitUrl, r as shortGitSha, t as getGitSha } from "./build-info-BERZooDe.js";
|
|
8
8
|
import { closePHModal, deleteDrive, driveCollectionId, setSelectedDrive, showPHModal, useDriveSystemInfo, useDrives, usePHModal, useSyncList, useVetraPackageManager } from "@powerhousedao/reactor-browser";
|
|
9
9
|
import { useCallback, useMemo, useState } from "react";
|
|
10
10
|
import { jsx, jsxs } from "react/jsx-runtime";
|
|
@@ -293,5 +293,5 @@ const SettingsModal = () => {
|
|
|
293
293
|
//#endregion
|
|
294
294
|
export { SettingsModal };
|
|
295
295
|
|
|
296
|
-
//# sourceMappingURL=SettingsModal-
|
|
297
|
-
//# debugId=
|
|
296
|
+
//# sourceMappingURL=SettingsModal-B-uWoxSI.js.map
|
|
297
|
+
//# debugId=0dd4d614-df51-53b1-b58e-bd2c5f55e06a
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SettingsModal-_I7Ud_Q_.js","sources":["../src/components/modal/modals/settings/about.tsx","../src/components/modal/modals/settings/danger-zone.tsx","../src/components/modal/modals/settings/default-editor.tsx","../src/components/modal/modals/settings/package-manager.tsx","../src/components/modal/modals/SettingsModal.tsx"],"sourcesContent":["import { connectConfig } from \"@powerhousedao/connect/config\";\nimport {\n getGitSha,\n getGitUrl,\n packageJson,\n shortGitSha,\n} from \"@powerhousedao/connect/utils\";\nimport { Icon } from \"@powerhousedao/design-system\";\nimport { About as BaseAbout } from \"@powerhousedao/design-system/connect\";\nimport {\n closePHModal,\n driveCollectionId,\n showPHModal,\n useDrives,\n useDriveSystemInfo,\n useSyncList,\n} from \"@powerhousedao/reactor-browser\";\nimport type { DocumentDriveDocument } from \"@powerhousedao/shared/document-drive\";\nimport { useMemo } from \"react\";\n\nexport const About: React.FC = () => {\n const onOpenInspector = () => {\n closePHModal();\n showPHModal({ type: \"inspector\" });\n };\n\n return (\n <div>\n <BaseAbout\n packageJson={packageJson}\n phCliVersion={\n typeof connectConfig.phCliVersion === \"string\"\n ? connectConfig.phCliVersion\n : undefined\n }\n />\n <AppGitHash />\n <ConnectedDrives />\n <div className=\"bg-white p-3\">\n <h2 className=\"mb-2 font-semibold\">Inspector</h2>\n <p className=\"mb-3 text-sm font-normal text-gray-600\">\n Explore the local database and sync state for debugging.\n </p>\n <button\n className=\"flex items-center gap-x-2 rounded-md border border-gray-300 bg-transparent px-3 py-1 text-sm font-medium text-gray-900 transition-colors hover:bg-gray-100\"\n onClick={onOpenInspector}\n type=\"button\"\n >\n Open Inspector <Icon name=\"CircleInfo\" size={16} />\n </button>\n </div>\n </div>\n );\n};\n\nfunction AppGitHash() {\n const sha = getGitSha();\n if (sha === \"unknown\") return null;\n const url = getGitUrl();\n const label = shortGitSha(sha);\n return (\n <div className=\"bg-white p-3 text-sm\">\n <span className=\"font-semibold\">Git hash: </span>\n {url ? (\n <a\n className=\"font-mono underline\"\n href={url}\n target=\"_blank\"\n rel=\"noreferrer noopener\"\n title={sha}\n >\n {label}\n </a>\n ) : (\n <span className=\"font-mono\" title={sha}>\n {label}\n </span>\n )}\n </div>\n );\n}\n\nfunction ConnectedDrives() {\n const drives = useDrives() ?? [];\n const remotes = useSyncList();\n\n const remoteDrives = useMemo(\n () =>\n drives.filter((d) =>\n remotes.some(\n (r) => r.collectionId === driveCollectionId(\"main\", d.header.id),\n ),\n ),\n [drives, remotes],\n );\n\n return (\n <div className=\"my-4 bg-white p-3\">\n <h2 className=\"mb-2 font-semibold\">Connected drives</h2>\n {remoteDrives.length === 0 ? (\n <p className=\"text-sm font-normal text-gray-600\">\n No connected remote drives.\n </p>\n ) : (\n <ul className=\"flex flex-col gap-3\">\n {remoteDrives.map((drive) => (\n <DriveAboutEntry key={drive.header.id} drive={drive} />\n ))}\n </ul>\n )}\n </div>\n );\n}\n\nfunction DriveAboutEntry({ drive }: { drive: DocumentDriveDocument }) {\n const info = useDriveSystemInfo(drive);\n const name = drive.state.global.name || drive.header.name;\n\n return (\n <li className=\"text-sm text-gray-700\">\n <div className=\"flex items-baseline gap-2\">\n <span className=\"font-medium\">{name}</span>\n {info.status === \"ready\" && (\n <span className=\"text-xs text-gray-500\">{info.host}</span>\n )}\n </div>\n {info.status === \"loading\" && (\n <div className=\"mt-1 text-xs text-gray-400\">Loading…</div>\n )}\n {info.status === \"error\" && (\n <div className=\"mt-1 text-xs text-red-600\">\n Could not load system info\n </div>\n )}\n {info.status === \"ready\" && (\n <div className=\"mt-1 text-xs text-gray-600\">\n <div>\n <span className=\"font-medium\">Version:</span> {info.version}\n </div>\n <div>\n <span className=\"font-medium\">Git hash: </span>\n {info.gitUrl ? (\n <a\n className=\"font-mono hover:underline\"\n href={info.gitUrl}\n target=\"_blank\"\n rel=\"noreferrer noopener\"\n title={info.gitHash}\n >\n {shortGitSha(info.gitHash)}\n </a>\n ) : (\n <span className=\"font-mono\" title={info.gitHash}>\n {shortGitSha(info.gitHash)}\n </span>\n )}\n </div>\n </div>\n )}\n {info.status === \"local\" && (\n <div className=\"mt-1 text-xs text-gray-400\">Local drive — N/A</div>\n )}\n </li>\n );\n}\n","import { DangerZone as BaseDangerZone } from \"@powerhousedao/design-system/connect\";\nimport {\n deleteDrive,\n setSelectedDrive,\n showPHModal,\n useDrives,\n} from \"@powerhousedao/reactor-browser\";\nimport type { DocumentDriveDocument } from \"@powerhousedao/shared/document-drive\";\n\nexport const DangerZone: React.FC = () => {\n const drives = useDrives();\n\n const handleDeleteDrive = async (drive: DocumentDriveDocument) => {\n await deleteDrive(drive.header.id);\n setSelectedDrive(undefined);\n };\n\n const handleClearStorage = () => {\n showPHModal({ type: \"clearStorage\" });\n };\n\n return (\n <BaseDangerZone\n drives={drives ?? []}\n onDeleteDrive={handleDeleteDrive}\n onClearStorage={handleClearStorage}\n />\n );\n};\n","import { DefaultEditor as BaseDefaultEditor } from \"@powerhousedao/design-system/connect\";\nimport { useCallback, useState } from \"react\";\n\nconst documentModelEditorOptions = [\n { label: \"V1\", value: \"document-model-editor\" },\n { label: \"V2\", value: \"document-model-editor-v2\" },\n] as const;\n\nexport const DefaultEditor: React.FC = () => {\n const [documentModelEditor, setDocumentModelEditor] = useState<\n (typeof documentModelEditorOptions)[number]\n >(documentModelEditorOptions[1]);\n\n const handleSetDocumentEditor = useCallback((value: string) => {\n const option = documentModelEditorOptions.find((dm) => dm.value == value);\n if (option) {\n setDocumentModelEditor(option);\n }\n }, []);\n\n return (\n <BaseDefaultEditor\n documentModelEditor={documentModelEditor.value}\n setDocumentModelEditor={handleSetDocumentEditor}\n documentModelEditorOptions={\n documentModelEditorOptions as unknown as {\n value: string;\n label: string;\n }[]\n }\n />\n );\n};\n","import { useRegistryPackages } from \"@powerhousedao/connect/hooks\";\nimport { toast } from \"@powerhousedao/connect/services\";\nimport { PackageManager } from \"@powerhousedao/design-system/connect\";\nimport { useVetraPackageManager } from \"@powerhousedao/reactor-browser\";\nimport React from \"react\";\n\n/**\n * Split a `name@tag` spec into its bare package name. Mirrors the design-system's\n * `parsePackageSpec` — duplicated here to avoid reaching into a deep subpath\n * export. Scoped names split on the LAST `@`, unscoped on the first.\n */\nfunction parseBareName(spec: string): string {\n const trimmed = spec.trim();\n const at = trimmed.startsWith(\"@\")\n ? trimmed.lastIndexOf(\"@\")\n : trimmed.indexOf(\"@\");\n return at > 0 ? trimmed.slice(0, at) : trimmed;\n}\n\nexport const ConnectPackageManager: React.FC = () => {\n const packageManager = useVetraPackageManager();\n const {\n registryPackageList,\n updateRegistryPackageStatus,\n registerFallbackRegistryPackage,\n } = useRegistryPackages();\n\n async function handleInstall(packageSpec: string) {\n if (!packageManager) return;\n\n // The spec may include an explicit `@tag` / `@version` suffix from the\n // search input. Pass it through to the package manager as-is (the CDN\n // route already handles `name@tag` specs), but track status under the\n // bare name so the Settings list doesn't fragment.\n const bareName = parseBareName(packageSpec);\n // Packages that were in `/packages` when the user clicked Install go\n // through `updateRegistryPackageStatus` and hit an existing entry.\n // Packages that landed via the npm-uplink fallback weren't in the list,\n // so we register them explicitly rather than silently upserting a\n // placeholder — keeping the \"does not exist\" error as a signal for any\n // other code path that reaches update without a matching entry.\n const wasKnownToRegistry = registryPackageList.some(\n (p) => p.name === bareName,\n );\n const result = await packageManager.addPackage(packageSpec);\n if (result.type === \"success\") {\n if (wasKnownToRegistry) {\n updateRegistryPackageStatus(bareName, \"registry-install\");\n } else {\n registerFallbackRegistryPackage(\n bareName,\n result.package,\n packageManager.getPackageVersion(bareName) ??\n packageManager.getPackageVersion(packageSpec),\n \"registry-install\",\n );\n }\n toast(`Package \"${packageSpec}\" installed successfully`, {\n type: \"connect-success\",\n });\n } else {\n const message = result.error.message;\n // `BrowserPackageManager` raises a generic \"Failed to fetch dynamically\n // imported module\" when the registry CDN returns an error. That covers\n // both \"the name exists nowhere (not on this registry AND not on the\n // npmjs uplink)\" and \"the tarball is there but doesn't look like a\n // Powerhouse package\". Tell the user in plain terms before dumping the\n // raw error so the \"install from npm\" fallback case is self-explanatory.\n const isLikelyNotFound = /failed to fetch|404|not found/i.test(message);\n const userMessage = isLikelyNotFound\n ? `Could not install \"${packageSpec}\". The package isn't available on this registry, and the npmjs.org fallback could not resolve it either.`\n : `Failed to install \"${packageSpec}\": ${message}`;\n toast(userMessage, { type: \"error\" });\n }\n }\n\n function handleUninstall(packageName: string) {\n if (!packageManager) return;\n try {\n packageManager.removePackage(packageName);\n updateRegistryPackageStatus(packageName, \"available\");\n\n toast(`Package \"${packageName}\" uninstalled successfully`, {\n type: \"connect-success\",\n });\n } catch (error) {\n const message = error instanceof Error ? error.message : \"Unknown error\";\n toast(`Failed to uninstall \"${packageName}\": ${message}`, {\n type: \"error\",\n });\n }\n }\n\n return (\n <div className=\"flex h-full flex-1 flex-col\">\n <PackageManager\n mutable={true}\n registryPackageList={registryPackageList}\n onInstall={handleInstall}\n onUninstall={handleUninstall}\n />\n </div>\n );\n};\n","import { Icon } from \"@powerhousedao/design-system\";\nimport { SettingsModal as SettingsModalV2 } from \"@powerhousedao/design-system/connect\";\nimport { closePHModal, usePHModal } from \"@powerhousedao/reactor-browser\";\nimport { t } from \"i18next\";\nimport React, { useMemo } from \"react\";\nimport { About } from \"./settings/about.js\";\nimport { DangerZone } from \"./settings/danger-zone.js\";\nimport { DefaultEditor } from \"./settings/default-editor.js\";\nimport { ConnectPackageManager } from \"./settings/package-manager.js\";\n\nexport const SettingsModal: React.FC = () => {\n const phModal = usePHModal();\n const open = phModal?.type === \"settings\";\n function onRefresh() {\n window.location.reload();\n }\n\n const tabs = useMemo(\n () => [\n {\n id: \"package-manager\",\n icon: <Icon name=\"PackageManager\" size={12} />,\n label: \"Package Manager\",\n content: ConnectPackageManager,\n },\n {\n id: \"default-editors\",\n icon: <Icon name=\"Edit\" size={12} />,\n label: \"Default Editors\",\n content: DefaultEditor,\n },\n {\n id: \"danger-zone\",\n icon: <Icon name=\"Danger\" size={12} className=\"text-red-900\" />,\n label: <span className=\"text-red-900\">Danger Zone</span>,\n content: () => <DangerZone />,\n },\n {\n id: \"about\",\n icon: <Icon name=\"QuestionSquare\" size={12} />,\n label: \"About\",\n content: About,\n },\n ],\n [onRefresh],\n );\n\n return (\n <SettingsModalV2\n open={open}\n title={t(\"modals.connectSettings.title\")}\n onOpenChange={(status: boolean) => {\n if (!status) return closePHModal();\n }}\n tabs={tabs}\n />\n );\n};\n"],"names":["About","BaseAbout","packageJson","DangerZone","BaseDangerZone","DefaultEditor","BaseDefaultEditor","DefaultEditor","DangerZone","About","SettingsModalV2"],"mappings":"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","debug_id":"8107c06c-1d5b-5fb8-83d8-a1f0470cf7c1"}
|
|
1
|
+
{"version":3,"file":"SettingsModal-B-uWoxSI.js","sources":["../src/components/modal/modals/settings/about.tsx","../src/components/modal/modals/settings/danger-zone.tsx","../src/components/modal/modals/settings/default-editor.tsx","../src/components/modal/modals/settings/package-manager.tsx","../src/components/modal/modals/SettingsModal.tsx"],"sourcesContent":["import { connectConfig } from \"@powerhousedao/connect/config\";\nimport {\n getGitSha,\n getGitUrl,\n packageJson,\n shortGitSha,\n} from \"@powerhousedao/connect/utils\";\nimport { Icon } from \"@powerhousedao/design-system\";\nimport { About as BaseAbout } from \"@powerhousedao/design-system/connect\";\nimport {\n closePHModal,\n driveCollectionId,\n showPHModal,\n useDrives,\n useDriveSystemInfo,\n useSyncList,\n} from \"@powerhousedao/reactor-browser\";\nimport type { DocumentDriveDocument } from \"@powerhousedao/shared/document-drive\";\nimport { useMemo } from \"react\";\n\nexport const About: React.FC = () => {\n const onOpenInspector = () => {\n closePHModal();\n showPHModal({ type: \"inspector\" });\n };\n\n return (\n <div>\n <BaseAbout\n packageJson={packageJson}\n phCliVersion={\n typeof connectConfig.phCliVersion === \"string\"\n ? connectConfig.phCliVersion\n : undefined\n }\n />\n <AppGitHash />\n <ConnectedDrives />\n <div className=\"bg-white p-3\">\n <h2 className=\"mb-2 font-semibold\">Inspector</h2>\n <p className=\"mb-3 text-sm font-normal text-gray-600\">\n Explore the local database and sync state for debugging.\n </p>\n <button\n className=\"flex items-center gap-x-2 rounded-md border border-gray-300 bg-transparent px-3 py-1 text-sm font-medium text-gray-900 transition-colors hover:bg-gray-100\"\n onClick={onOpenInspector}\n type=\"button\"\n >\n Open Inspector <Icon name=\"CircleInfo\" size={16} />\n </button>\n </div>\n </div>\n );\n};\n\nfunction AppGitHash() {\n const sha = getGitSha();\n if (sha === \"unknown\") return null;\n const url = getGitUrl();\n const label = shortGitSha(sha);\n return (\n <div className=\"bg-white p-3 text-sm\">\n <span className=\"font-semibold\">Git hash: </span>\n {url ? (\n <a\n className=\"font-mono underline\"\n href={url}\n target=\"_blank\"\n rel=\"noreferrer noopener\"\n title={sha}\n >\n {label}\n </a>\n ) : (\n <span className=\"font-mono\" title={sha}>\n {label}\n </span>\n )}\n </div>\n );\n}\n\nfunction ConnectedDrives() {\n const drives = useDrives() ?? [];\n const remotes = useSyncList();\n\n const remoteDrives = useMemo(\n () =>\n drives.filter((d) =>\n remotes.some(\n (r) => r.collectionId === driveCollectionId(\"main\", d.header.id),\n ),\n ),\n [drives, remotes],\n );\n\n return (\n <div className=\"my-4 bg-white p-3\">\n <h2 className=\"mb-2 font-semibold\">Connected drives</h2>\n {remoteDrives.length === 0 ? (\n <p className=\"text-sm font-normal text-gray-600\">\n No connected remote drives.\n </p>\n ) : (\n <ul className=\"flex flex-col gap-3\">\n {remoteDrives.map((drive) => (\n <DriveAboutEntry key={drive.header.id} drive={drive} />\n ))}\n </ul>\n )}\n </div>\n );\n}\n\nfunction DriveAboutEntry({ drive }: { drive: DocumentDriveDocument }) {\n const info = useDriveSystemInfo(drive);\n const name = drive.state.global.name || drive.header.name;\n\n return (\n <li className=\"text-sm text-gray-700\">\n <div className=\"flex items-baseline gap-2\">\n <span className=\"font-medium\">{name}</span>\n {info.status === \"ready\" && (\n <span className=\"text-xs text-gray-500\">{info.host}</span>\n )}\n </div>\n {info.status === \"loading\" && (\n <div className=\"mt-1 text-xs text-gray-400\">Loading…</div>\n )}\n {info.status === \"error\" && (\n <div className=\"mt-1 text-xs text-red-600\">\n Could not load system info\n </div>\n )}\n {info.status === \"ready\" && (\n <div className=\"mt-1 text-xs text-gray-600\">\n <div>\n <span className=\"font-medium\">Version:</span> {info.version}\n </div>\n <div>\n <span className=\"font-medium\">Git hash: </span>\n {info.gitUrl ? (\n <a\n className=\"font-mono hover:underline\"\n href={info.gitUrl}\n target=\"_blank\"\n rel=\"noreferrer noopener\"\n title={info.gitHash}\n >\n {shortGitSha(info.gitHash)}\n </a>\n ) : (\n <span className=\"font-mono\" title={info.gitHash}>\n {shortGitSha(info.gitHash)}\n </span>\n )}\n </div>\n </div>\n )}\n {info.status === \"local\" && (\n <div className=\"mt-1 text-xs text-gray-400\">Local drive — N/A</div>\n )}\n </li>\n );\n}\n","import { DangerZone as BaseDangerZone } from \"@powerhousedao/design-system/connect\";\nimport {\n deleteDrive,\n setSelectedDrive,\n showPHModal,\n useDrives,\n} from \"@powerhousedao/reactor-browser\";\nimport type { DocumentDriveDocument } from \"@powerhousedao/shared/document-drive\";\n\nexport const DangerZone: React.FC = () => {\n const drives = useDrives();\n\n const handleDeleteDrive = async (drive: DocumentDriveDocument) => {\n await deleteDrive(drive.header.id);\n setSelectedDrive(undefined);\n };\n\n const handleClearStorage = () => {\n showPHModal({ type: \"clearStorage\" });\n };\n\n return (\n <BaseDangerZone\n drives={drives ?? []}\n onDeleteDrive={handleDeleteDrive}\n onClearStorage={handleClearStorage}\n />\n );\n};\n","import { DefaultEditor as BaseDefaultEditor } from \"@powerhousedao/design-system/connect\";\nimport { useCallback, useState } from \"react\";\n\nconst documentModelEditorOptions = [\n { label: \"V1\", value: \"document-model-editor\" },\n { label: \"V2\", value: \"document-model-editor-v2\" },\n] as const;\n\nexport const DefaultEditor: React.FC = () => {\n const [documentModelEditor, setDocumentModelEditor] = useState<\n (typeof documentModelEditorOptions)[number]\n >(documentModelEditorOptions[1]);\n\n const handleSetDocumentEditor = useCallback((value: string) => {\n const option = documentModelEditorOptions.find((dm) => dm.value == value);\n if (option) {\n setDocumentModelEditor(option);\n }\n }, []);\n\n return (\n <BaseDefaultEditor\n documentModelEditor={documentModelEditor.value}\n setDocumentModelEditor={handleSetDocumentEditor}\n documentModelEditorOptions={\n documentModelEditorOptions as unknown as {\n value: string;\n label: string;\n }[]\n }\n />\n );\n};\n","import { useRegistryPackages } from \"@powerhousedao/connect/hooks\";\nimport { toast } from \"@powerhousedao/connect/services\";\nimport { PackageManager } from \"@powerhousedao/design-system/connect\";\nimport { useVetraPackageManager } from \"@powerhousedao/reactor-browser\";\nimport React from \"react\";\n\n/**\n * Split a `name@tag` spec into its bare package name. Mirrors the design-system's\n * `parsePackageSpec` — duplicated here to avoid reaching into a deep subpath\n * export. Scoped names split on the LAST `@`, unscoped on the first.\n */\nfunction parseBareName(spec: string): string {\n const trimmed = spec.trim();\n const at = trimmed.startsWith(\"@\")\n ? trimmed.lastIndexOf(\"@\")\n : trimmed.indexOf(\"@\");\n return at > 0 ? trimmed.slice(0, at) : trimmed;\n}\n\nexport const ConnectPackageManager: React.FC = () => {\n const packageManager = useVetraPackageManager();\n const {\n registryPackageList,\n updateRegistryPackageStatus,\n registerFallbackRegistryPackage,\n } = useRegistryPackages();\n\n async function handleInstall(packageSpec: string) {\n if (!packageManager) return;\n\n // The spec may include an explicit `@tag` / `@version` suffix from the\n // search input. Pass it through to the package manager as-is (the CDN\n // route already handles `name@tag` specs), but track status under the\n // bare name so the Settings list doesn't fragment.\n const bareName = parseBareName(packageSpec);\n // Packages that were in `/packages` when the user clicked Install go\n // through `updateRegistryPackageStatus` and hit an existing entry.\n // Packages that landed via the npm-uplink fallback weren't in the list,\n // so we register them explicitly rather than silently upserting a\n // placeholder — keeping the \"does not exist\" error as a signal for any\n // other code path that reaches update without a matching entry.\n const wasKnownToRegistry = registryPackageList.some(\n (p) => p.name === bareName,\n );\n const result = await packageManager.addPackage(packageSpec);\n if (result.type === \"success\") {\n if (wasKnownToRegistry) {\n updateRegistryPackageStatus(bareName, \"registry-install\");\n } else {\n registerFallbackRegistryPackage(\n bareName,\n result.package,\n packageManager.getPackageVersion(bareName) ??\n packageManager.getPackageVersion(packageSpec),\n \"registry-install\",\n );\n }\n toast(`Package \"${packageSpec}\" installed successfully`, {\n type: \"connect-success\",\n });\n } else {\n const message = result.error.message;\n // `BrowserPackageManager` raises a generic \"Failed to fetch dynamically\n // imported module\" when the registry CDN returns an error. That covers\n // both \"the name exists nowhere (not on this registry AND not on the\n // npmjs uplink)\" and \"the tarball is there but doesn't look like a\n // Powerhouse package\". Tell the user in plain terms before dumping the\n // raw error so the \"install from npm\" fallback case is self-explanatory.\n const isLikelyNotFound = /failed to fetch|404|not found/i.test(message);\n const userMessage = isLikelyNotFound\n ? `Could not install \"${packageSpec}\". The package isn't available on this registry, and the npmjs.org fallback could not resolve it either.`\n : `Failed to install \"${packageSpec}\": ${message}`;\n toast(userMessage, { type: \"error\" });\n }\n }\n\n function handleUninstall(packageName: string) {\n if (!packageManager) return;\n try {\n packageManager.removePackage(packageName);\n updateRegistryPackageStatus(packageName, \"available\");\n\n toast(`Package \"${packageName}\" uninstalled successfully`, {\n type: \"connect-success\",\n });\n } catch (error) {\n const message = error instanceof Error ? error.message : \"Unknown error\";\n toast(`Failed to uninstall \"${packageName}\": ${message}`, {\n type: \"error\",\n });\n }\n }\n\n return (\n <div className=\"flex h-full flex-1 flex-col\">\n <PackageManager\n mutable={true}\n registryPackageList={registryPackageList}\n onInstall={handleInstall}\n onUninstall={handleUninstall}\n />\n </div>\n );\n};\n","import { Icon } from \"@powerhousedao/design-system\";\nimport { SettingsModal as SettingsModalV2 } from \"@powerhousedao/design-system/connect\";\nimport { closePHModal, usePHModal } from \"@powerhousedao/reactor-browser\";\nimport { t } from \"i18next\";\nimport React, { useMemo } from \"react\";\nimport { About } from \"./settings/about.js\";\nimport { DangerZone } from \"./settings/danger-zone.js\";\nimport { DefaultEditor } from \"./settings/default-editor.js\";\nimport { ConnectPackageManager } from \"./settings/package-manager.js\";\n\nexport const SettingsModal: React.FC = () => {\n const phModal = usePHModal();\n const open = phModal?.type === \"settings\";\n function onRefresh() {\n window.location.reload();\n }\n\n const tabs = useMemo(\n () => [\n {\n id: \"package-manager\",\n icon: <Icon name=\"PackageManager\" size={12} />,\n label: \"Package Manager\",\n content: ConnectPackageManager,\n },\n {\n id: \"default-editors\",\n icon: <Icon name=\"Edit\" size={12} />,\n label: \"Default Editors\",\n content: DefaultEditor,\n },\n {\n id: \"danger-zone\",\n icon: <Icon name=\"Danger\" size={12} className=\"text-red-900\" />,\n label: <span className=\"text-red-900\">Danger Zone</span>,\n content: () => <DangerZone />,\n },\n {\n id: \"about\",\n icon: <Icon name=\"QuestionSquare\" size={12} />,\n label: \"About\",\n content: About,\n },\n ],\n [onRefresh],\n );\n\n return (\n <SettingsModalV2\n open={open}\n title={t(\"modals.connectSettings.title\")}\n onOpenChange={(status: boolean) => {\n if (!status) return closePHModal();\n }}\n tabs={tabs}\n />\n );\n};\n"],"names":["About","BaseAbout","packageJson","DangerZone","BaseDangerZone","DefaultEditor","BaseDefaultEditor","DefaultEditor","DangerZone","About","SettingsModalV2"],"mappings":"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","debug_id":"0dd4d614-df51-53b1-b58e-bd2c5f55e06a"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
|
|
2
|
-
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="
|
|
2
|
+
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="44ff3272-9b3b-535c-b3e1-2f41d88f79a8")}catch(e){}}();
|
|
3
3
|
import { buildTreeUrl, shortGitSha } from "@powerhousedao/shared";
|
|
4
4
|
//#region src/utils/build-info.ts
|
|
5
5
|
function getGitSha() {
|
|
6
|
-
return "
|
|
6
|
+
return "2d984b659bf4bca580584fb9840278ae85850682";
|
|
7
7
|
}
|
|
8
8
|
function getGitUrl() {
|
|
9
9
|
return buildTreeUrl(getGitSha());
|
|
@@ -11,5 +11,5 @@ function getGitUrl() {
|
|
|
11
11
|
//#endregion
|
|
12
12
|
export { getGitUrl as n, shortGitSha as r, getGitSha as t };
|
|
13
13
|
|
|
14
|
-
//# sourceMappingURL=build-info-
|
|
15
|
-
//# debugId=
|
|
14
|
+
//# sourceMappingURL=build-info-BERZooDe.js.map
|
|
15
|
+
//# debugId=44ff3272-9b3b-535c-b3e1-2f41d88f79a8
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"build-info-
|
|
1
|
+
{"version":3,"file":"build-info-BERZooDe.js","sources":["../src/utils/build-info.ts"],"sourcesContent":["import { buildTreeUrl, shortGitSha } from \"@powerhousedao/shared\";\nimport { packageJson } from \"./package-json.js\";\n\nexport { shortGitSha };\n\ndeclare const CONNECT_VERSION: string | undefined;\ndeclare const CONNECT_GIT_SHA: string | undefined;\n\nexport function getVersion(): string {\n if (typeof CONNECT_VERSION !== \"undefined\") return CONNECT_VERSION;\n return (\n process.env.WORKSPACE_VERSION ??\n process.env.npm_package_version ??\n packageJson.version\n );\n}\n\nexport function getGitSha(): string {\n if (typeof CONNECT_GIT_SHA !== \"undefined\") return CONNECT_GIT_SHA;\n return process.env.WORKSPACE_GIT_SHA ?? \"unknown\";\n}\n\nexport function getGitUrl(): string | null {\n return buildTreeUrl(getGitSha());\n}\n"],"names":[],"mappings":";;;;AAiBA,SAAgB,YAAoB;AACU,QAAA;;AAI9C,SAAgB,YAA2B;AACzC,QAAO,aAAa,WAAW,CAAC","debug_id":"44ff3272-9b3b-535c-b3e1-2f41d88f79a8"}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
|
|
2
|
-
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="
|
|
2
|
+
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="3ab5b7dc-57a5-5119-886e-9b30998b6be0")}catch(e){}}();
|
|
3
3
|
import { t as connectConfig } from "./connect.config-B2xP5Iez.js";
|
|
4
4
|
import { n as toast } from "./toast-DnODOv28.js";
|
|
5
|
-
import { t as package_default } from "./package-
|
|
5
|
+
import { t as package_default } from "./package-DT0VGtRf.js";
|
|
6
6
|
import { t as detectReactorPgMajor } from "./pglite-runtime-Btp8ZXVH.js";
|
|
7
7
|
import { n as seedPendingPgVersion } from "./pglite-seed-b1mJUaip.js";
|
|
8
8
|
import { n as createReactor } from "./reactor-BqTMQT3A.js";
|
|
@@ -108,5 +108,5 @@ async function loadComponent(localPackage) {
|
|
|
108
108
|
//#endregion
|
|
109
109
|
export { loadComponent };
|
|
110
110
|
|
|
111
|
-
//# sourceMappingURL=load-
|
|
112
|
-
//# debugId=
|
|
111
|
+
//# sourceMappingURL=load-DZUI_Umw.js.map
|
|
112
|
+
//# debugId=3ab5b7dc-57a5-5119-886e-9b30998b6be0
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"load-
|
|
1
|
+
{"version":3,"file":"load-DZUI_Umw.js","sources":["../src/components/reload-connect-toast.tsx","../src/hooks/useCheckLatestVersion.ts","../src/hooks/utils.ts","../src/store/user.ts","../src/components/load.tsx"],"sourcesContent":["import { useTranslation } from \"react-i18next\";\n\nexport const ReloadConnectToast = () => {\n const { t } = useTranslation();\n\n return (\n <div>\n <p className=\"font-medium\">{t(\"notifications.reloadApp\")}</p>\n <button\n onClick={() => location.reload()}\n className=\"underline decoration-solid underline-offset-2\"\n >\n {t(\"common.reloadConnect\")} 🔄\n </button>\n </div>\n );\n};\n","import { connectConfig } from \"@powerhousedao/connect/config\";\nimport { isLatestVersion } from \"@powerhousedao/connect/hooks\";\nimport { toast } from \"@powerhousedao/connect/services\";\nimport { logger } from \"document-model\";\nimport { createElement, useEffect } from \"react\";\nimport { ReloadConnectToast } from \"../components/reload-connect-toast.js\";\n\nexport const useCheckLatestVersion = () => {\n async function checkLatestVersion() {\n const result = await isLatestVersion();\n if (result === null) return;\n // ignore dev/staging versions\n if (result.isLatest || result.currentVersion.includes(\"-\")) {\n return true;\n }\n\n if (\n import.meta.env.MODE === \"development\" ||\n connectConfig.studioMode ||\n !connectConfig.warnOutdatedApp\n ) {\n logger.warn(\n \"Connect is outdated: \\nCurrent: @currentVersion\\nLatest: @latestVersion\",\n result.currentVersion,\n result.latestVersion,\n );\n } else {\n toast(createElement(ReloadConnectToast), {\n type: \"connect-warning\",\n toastId: \"outdated-app\",\n autoClose: false,\n });\n }\n }\n\n useEffect(() => {\n checkLatestVersion().catch(console.error);\n }, []);\n};\n","import { packageJson } from \"../utils/package-json.js\";\n\nexport const isMac = window.navigator.appVersion.includes(\"Mac\");\n\nconst urlBranchMap: Record<string, string> = {\n \"staging/makerdao\": \"deployments/staging/makerdao\",\n \"staging/arbitrum\": \"arb-ltip\",\n \"staging/powerhouse\": \"staging\",\n makerdao: \"deployments/makerdao\",\n arbitrum: \"deployments/arbitrum\",\n arbgrants: \"deployments/arbitrum\",\n localhost: \"develop\",\n};\n\nconst getGithubLinkFromUrl = () => {\n const githubLink = \"https://raw.githubusercontent.com/powerhouse-inc/connect\";\n const url = window.location.href;\n\n const env = Object.keys(urlBranchMap).find((env) => url.includes(env));\n const value = env ? urlBranchMap[env] : undefined;\n if (!value) {\n return undefined;\n } else {\n return `${githubLink}/${value}/package.json`;\n }\n};\n\nconst fetchLatestVersion = async () => {\n const link = getGithubLinkFromUrl();\n if (!link) {\n return undefined;\n }\n const result = await fetch(link);\n const data = (await result.json()) as { version: string };\n const { version } = data;\n return version;\n};\n\nexport const isLatestVersion = async () => {\n const currentVersion = packageJson.version;\n const deployed = await fetchLatestVersion();\n\n if (deployed) {\n return {\n isLatest: deployed === currentVersion,\n currentVersion,\n latestVersion: deployed,\n };\n }\n\n return null;\n};\n","import { useUser } from \"@powerhousedao/reactor-browser\";\nimport type { User as SentryUser } from \"@sentry/react\";\nimport { setUser as setSentryUser } from \"@sentry/react\";\nimport { useEffect } from \"react\";\n\nexport function useSetSentryUser() {\n const user = useUser();\n useEffect(() => {\n let sentryUser: SentryUser | null = null;\n if (user) {\n // saves the user info except the credential\n const { credential, ...rest } = user;\n sentryUser = { id: rest.did, username: rest.ens?.name, ...rest };\n }\n setSentryUser(sentryUser);\n }, [user]);\n}\n","import { useCheckLatestVersion } from \"@powerhousedao/connect/hooks\";\nimport \"@powerhousedao/connect/i18n\";\nimport { createReactor, useSetSentryUser } from \"@powerhousedao/connect/store\";\nimport {\n detectReactorPgMajor,\n seedPendingPgVersion,\n} from \"@powerhousedao/connect/utils\";\nimport type { DocumentModelLib } from \"document-model\";\nimport { type ReactNode } from \"react\";\n\nexport async function loadComponent(localPackage?: DocumentModelLib) {\n await seedPendingPgVersion();\n await detectReactorPgMajor();\n await createReactor(localPackage);\n return {\n default: ({ children }: { children?: ReactNode }) => {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useSetSentryUser();\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useCheckLatestVersion();\n return children;\n },\n };\n}\n"],"names":["packageJson"],"mappings":";;;;;;;;;;;;;;;AAEA,MAAa,2BAA2B;CACtC,MAAM,EAAE,MAAM,gBAAgB;AAE9B,QACE,qBAAC,OAAD,EAAA,UAAA,CACE,oBAAC,KAAD;EAAG,WAAU;YAAe,EAAE,0BAA0B;EAAK,CAAA,EAC7D,qBAAC,UAAD;EACE,eAAe,SAAS,QAAQ;EAChC,WAAU;YAFZ,CAIG,EAAE,uBAAuB,EAAC,MACpB;IACL,EAAA,CAAA;;;;ACPV,MAAa,8BAA8B;CACzC,eAAe,qBAAqB;EAClC,MAAM,SAAS,MAAM,iBAAiB;AACtC,MAAI,WAAW,KAAM;AAErB,MAAI,OAAO,YAAY,OAAO,eAAe,SAAS,IAAI,CACxD,QAAO;AAGT,MACE,OAAO,KAAK,IAAI,SAAS,iBACzB,cAAc,cACd,CAAC,cAAc,gBAEf,QAAO,KACL,2EACA,OAAO,gBACP,OAAO,cACR;MAED,OAAM,cAAc,mBAAmB,EAAE;GACvC,MAAM;GACN,SAAS;GACT,WAAW;GACZ,CAAC;;AAIN,iBAAgB;AACd,sBAAoB,CAAC,MAAM,QAAQ,MAAM;IACxC,EAAE,CAAC;;ACnCa,OAAO,UAAU,WAAW,SAAS,MAAM;AAEhE,MAAM,eAAuC;CAC3C,oBAAoB;CACpB,oBAAoB;CACpB,sBAAsB;CACtB,UAAU;CACV,UAAU;CACV,WAAW;CACX,WAAW;CACZ;AAED,MAAM,6BAA6B;CACjC,MAAM,aAAa;CACnB,MAAM,MAAM,OAAO,SAAS;CAE5B,MAAM,MAAM,OAAO,KAAK,aAAa,CAAC,MAAM,QAAQ,IAAI,SAAS,IAAI,CAAC;CACtE,MAAM,QAAQ,MAAM,aAAa,OAAO,KAAA;AACxC,KAAI,CAAC,MACH;KAEA,QAAO,GAAG,WAAW,GAAG,MAAM;;AAIlC,MAAM,qBAAqB,YAAY;CACrC,MAAM,OAAO,sBAAsB;AACnC,KAAI,CAAC,KACH;CAIF,MAAM,EAAE,YADM,OADC,MAAM,MAAM,KAAK,EACL,MAAM;AAEjC,QAAO;;AAGT,MAAa,kBAAkB,YAAY;CACzC,MAAM,iBAAiBA,gBAAY;CACnC,MAAM,WAAW,MAAM,oBAAoB;AAE3C,KAAI,SACF,QAAO;EACL,UAAU,aAAa;EACvB;EACA,eAAe;EAChB;AAGH,QAAO;;;;AC7CT,SAAgB,mBAAmB;CACjC,MAAM,OAAO,SAAS;AACtB,iBAAgB;EACd,IAAI,aAAgC;AACpC,MAAI,MAAM;GAER,MAAM,EAAE,YAAY,GAAG,SAAS;AAChC,gBAAa;IAAE,IAAI,KAAK;IAAK,UAAU,KAAK,KAAK;IAAM,GAAG;IAAM;;AAElE,UAAc,WAAW;IACxB,CAAC,KAAK,CAAC;;;;ACLZ,eAAsB,cAAc,cAAiC;AACnE,OAAM,sBAAsB;AAC5B,OAAM,sBAAsB;AAC5B,OAAM,cAAc,aAAa;AACjC,QAAO,EACL,UAAU,EAAE,eAAyC;AAEnD,oBAAkB;AAElB,yBAAuB;AACvB,SAAO;IAEV","debug_id":"3ab5b7dc-57a5-5119-886e-9b30998b6be0"}
|
package/dist/main.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
|
|
2
2
|
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="2bbd67e3-aeba-5d1b-90e8-4d1ff3d7e576")}catch(e){}}();
|
|
3
|
-
import { t as AppLoader } from "./sidebar-
|
|
3
|
+
import { t as AppLoader } from "./sidebar-CZLMU1VL.js";
|
|
4
4
|
import { createRoot } from "react-dom/client";
|
|
5
5
|
import { jsx } from "react/jsx-runtime";
|
|
6
6
|
//#region main.tsx
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
//#region package.json
|
|
2
2
|
|
|
3
|
-
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="
|
|
3
|
+
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="70ce2442-b1a8-54a5-ac61-e096f6799cea")}catch(e){}}();
|
|
4
4
|
var package_default = {
|
|
5
5
|
name: "@powerhousedao/connect",
|
|
6
6
|
productName: "Powerhouse-Connect",
|
|
7
|
-
version: "6.1.0-dev.
|
|
7
|
+
version: "6.1.0-dev.9",
|
|
8
8
|
description: "Powerhouse Connect",
|
|
9
9
|
main: "dist/index.html",
|
|
10
10
|
type: "module",
|
|
@@ -119,5 +119,5 @@ var package_default = {
|
|
|
119
119
|
//#endregion
|
|
120
120
|
export { package_default as t };
|
|
121
121
|
|
|
122
|
-
//# sourceMappingURL=package-
|
|
123
|
-
//# debugId=
|
|
122
|
+
//# sourceMappingURL=package-DT0VGtRf.js.map
|
|
123
|
+
//# debugId=70ce2442-b1a8-54a5-ac61-e096f6799cea
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"package-DT0VGtRf.js","sources":["../package.json"],"sourcesContent":[""],"names":[],"mappings":"","debug_id":"70ce2442-b1a8-54a5-ac61-e096f6799cea"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
|
|
2
|
-
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="
|
|
2
|
+
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="9ec07267-610c-5785-aa26-92ef6dc6c948")}catch(e){}}();
|
|
3
3
|
import { n as defaultPHAppConfig, r as defaultPHDocumentEditorConfig, t as connectConfig } from "./connect.config-B2xP5Iez.js";
|
|
4
4
|
import { n as toast, t as ToastContainer } from "./toast-DnODOv28.js";
|
|
5
5
|
import { t as i18n } from "./i18n-BuVT7wFQ.js";
|
|
@@ -1250,13 +1250,13 @@ const AddDriveModal$1 = lazy(() => import("./AddDriveModal-ZK9-BWMB.js").then((m
|
|
|
1250
1250
|
const ClearStorageModal = lazy(() => import("./ClearStorageModal-Dx_kY08P.js").then((m) => ({ default: m.ClearStorageModal })));
|
|
1251
1251
|
const CookiesPolicyModal = lazy(() => import("./CookiesPolicyModal-DiXQV82b.js").then((m) => ({ default: m.CookiesPolicyModal })));
|
|
1252
1252
|
const CreateDocumentModal$1 = lazy(() => import("./CreateDocumentModal-BhJh4nWt.js").then((m) => ({ default: m.CreateDocumentModal })));
|
|
1253
|
-
const DebugSettingsModal = lazy(() => import("./DebugSettingsModal-
|
|
1253
|
+
const DebugSettingsModal = lazy(() => import("./DebugSettingsModal-D2TozI0o.js").then((m) => ({ default: m.DebugSettingsModal })));
|
|
1254
1254
|
const DeleteDriveModal = lazy(() => import("./DeleteDriveModal-CbuIdjKY.js").then((m) => ({ default: m.DeleteDriveModal })));
|
|
1255
1255
|
const DeleteItemModal = lazy(() => import("./DeleteItemModal-9ErYlauT.js").then((m) => ({ default: m.DeleteItemModal })));
|
|
1256
1256
|
const DisclaimerModal = lazy(() => import("./DisclaimerModal-CfDeiBz8.js").then((m) => ({ default: m.DisclaimerModal })));
|
|
1257
1257
|
const DriveSettingsModal$1 = lazy(() => import("./DriveSettingsModal-DEk05PS7.js").then((m) => ({ default: m.DriveSettingsModal })));
|
|
1258
1258
|
const DownloadDocumentWithErrorsModal = lazy(() => import("./DownloadDocumentWithErrorsModal-KZGWQ4J7.js").then((m) => ({ default: m.DownloadDocumentWithErrorsModal })));
|
|
1259
|
-
const SettingsModal$1 = lazy(() => import("./SettingsModal-
|
|
1259
|
+
const SettingsModal$1 = lazy(() => import("./SettingsModal-B-uWoxSI.js").then((m) => ({ default: m.SettingsModal })));
|
|
1260
1260
|
const UpgradeDriveModal = lazy(() => import("./UpgradeDriveModal-BwI5E5k3.js").then((m) => ({ default: m.UpgradeDriveModal })));
|
|
1261
1261
|
const modalComponents = {
|
|
1262
1262
|
addDrive: AddDriveModal$1,
|
|
@@ -1292,7 +1292,7 @@ const ModalsContainer = lazy(async () => {
|
|
|
1292
1292
|
//#endregion
|
|
1293
1293
|
//#region src/components/app-loader.tsx
|
|
1294
1294
|
const AppLoader = (props) => {
|
|
1295
|
-
const Load = lazy(() => import("./load-
|
|
1295
|
+
const Load = lazy(() => import("./load-DZUI_Umw.js").then((m) => m.loadComponent(props.localPackage)));
|
|
1296
1296
|
return /* @__PURE__ */ jsx(StrictMode, { children: /* @__PURE__ */ jsxs(ErrorBoundary$1, {
|
|
1297
1297
|
fallbackRender: (props) => /* @__PURE__ */ jsx(AppSkeleton, { children: /* @__PURE__ */ jsx(DetailedFallback, { ...props }) }),
|
|
1298
1298
|
resetKeys: [props.localPackage],
|
|
@@ -1854,5 +1854,5 @@ function Sidebar() {
|
|
|
1854
1854
|
//#endregion
|
|
1855
1855
|
export { AppLoader as t };
|
|
1856
1856
|
|
|
1857
|
-
//# sourceMappingURL=sidebar-
|
|
1858
|
-
//# debugId=
|
|
1857
|
+
//# sourceMappingURL=sidebar-CZLMU1VL.js.map
|
|
1858
|
+
//# debugId=9ec07267-610c-5785-aa26-92ef6dc6c948
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sidebar-soAXdN3i.js","sources":["../src/hooks/useAcceptedCookies.ts","../src/services/openpanel/buffer.ts","../src/services/openpanel/client.ts","../src/services/openpanel/events.json","../src/services/openpanel/events.ts","../src/services/openpanel/processor.ts","../src/services/openpanel/factory.ts","../src/hooks/useIsEmbedded.ts","../src/hooks/useCookieBanner.ts","../src/hooks/useFailedInstallations.ts","../src/hooks/useInitSentry.ts","../src/hooks/usePendingInstallations.ts","../src/hooks/useUndoRedoShortcuts.ts","../src/components/analytics.tsx","../src/components/openpanel-traits.ts","../src/components/openpanel.tsx","../src/components/document-editor-container.tsx","../src/components/editor-loader.tsx","../src/components/error-boundary.tsx","../src/components/app-container.tsx","../src/utils/browser.ts","../src/utils/document-editor-debug-tools.ts","../src/components/migration-status.ts","../src/utils/pglite-migration.ts","../src/components/app-skeleton.tsx","../src/components/migration-banner.tsx","../src/components/modal/modals-container.tsx","../src/components/app-loader.tsx","../src/context/sentry-provider.tsx","../src/components/missing-model-banner.tsx","../src/components/package-install-prompt.tsx","../src/components/app.tsx","../src/components/cookie-banner.tsx","../src/components/drive-icon.tsx","../src/components/editors.tsx","../src/components/root.tsx","../src/pages/content.tsx","../src/components/router.tsx","../src/components/sidebar.tsx"],"sourcesContent":["import { connectConfig } from \"@powerhousedao/connect/config\";\nimport { useSyncExternalStore } from \"react\";\n\nconst namespace = connectConfig.routerBasename;\n\nconst ACCEPTED_COOKIES_KEY_STORAGE = `${namespace}:acceptedCookies`;\n\nexport interface AcceptedCookies {\n analytics: boolean;\n marketing: boolean;\n functional: boolean;\n}\n\nconst listeners = new Set<() => void>();\n\nlet cookies: AcceptedCookies = getInitial();\n\nfunction getInitial(): AcceptedCookies {\n try {\n const value = localStorage.getItem(ACCEPTED_COOKIES_KEY_STORAGE);\n return value\n ? (JSON.parse(value) as AcceptedCookies)\n : { analytics: false, marketing: false, functional: false };\n } catch {\n return { analytics: false, marketing: false, functional: false };\n }\n}\n\nfunction getCookies(): AcceptedCookies {\n return cookies;\n}\n\nfunction setCookies(setter: (prev: AcceptedCookies) => AcceptedCookies) {\n cookies = setter(cookies);\n localStorage.setItem(ACCEPTED_COOKIES_KEY_STORAGE, JSON.stringify(cookies));\n listeners.forEach((fn) => fn());\n}\n\nfunction subscribe(fn: () => void) {\n listeners.add(fn);\n return () => listeners.delete(fn);\n}\n\nexport const useAcceptedCookies = () => {\n const cookies = useSyncExternalStore(subscribe, getCookies, getCookies);\n return [cookies, setCookies] as const;\n};\n","import type { OpenPanelTracker } from \"./processor.js\";\n\n/**\n * Hard cap on pre-init events held in memory. When full, the oldest entry is\n * evicted (drop-oldest) so the most-recent events survive. Bounded, so an\n * uninitialised client never leaks; `resetOpenPanelClient()` discards it\n * entirely so pre-consent events are never replayed.\n */\nconst BUFFER_CAP = 200;\n\ntype BufferEntry = [name: string, props: Record<string, unknown> | undefined];\n\nconst buffer: BufferEntry[] = [];\nlet activeClient: OpenPanelTracker | undefined;\nlet errorHandler: ((err: unknown) => void) | undefined;\n\nfunction defaultOnError(err: unknown): void {\n console.warn(\"[useOpenPanel] track failed:\", err);\n}\n\n/**\n * Forward a single event to the active client, swallowing any throw.\n *\n * The outer try/catch handles synchronous throws from `client.track`; the\n * inner `.catch()` handles rejected promises. Both are needed because\n * `Promise.resolve(x).catch()` cannot catch a throw from evaluating `x`.\n */\nfunction forward(\n client: OpenPanelTracker,\n name: string,\n props: Record<string, unknown> | undefined,\n): void {\n try {\n Promise.resolve(client.track(name, props)).catch((err) =>\n (errorHandler ?? defaultOnError)(err),\n );\n } catch (err) {\n (errorHandler ?? defaultOnError)(err);\n }\n}\n\n/**\n * Drain the pre-init buffer in FIFO order through `client.track`, then forward\n * subsequent events directly. Called once from `getOpenPanelClient()`.\n */\nexport function drainOpenPanelBuffer(\n client: OpenPanelTracker,\n onError?: (err: unknown) => void,\n): void {\n activeClient = client;\n errorHandler = onError;\n\n // Splice atomically so any track() during the drain is forwarded directly\n // (activeClient is set) rather than re-buffered.\n const pending = buffer.splice(0, buffer.length);\n for (const [name, props] of pending) {\n forward(client, name, props);\n }\n}\n\n/**\n * Clear the buffer and reset the active client. Buffered pre-consent events\n * are discarded so they are not replayed if the user later re-accepts.\n */\nexport function clearOpenPanelBuffer(): void {\n buffer.length = 0;\n activeClient = undefined;\n errorHandler = undefined;\n}\n\n/**\n * Track an analytics event. Sync, never throws. Forwards immediately when the\n * client is initialised, otherwise buffers (FIFO, cap 200, drop-oldest).\n */\nexport function track(name: string, props?: Record<string, unknown>): void {\n if (activeClient) {\n forward(activeClient, name, props);\n return;\n }\n\n if (buffer.length >= BUFFER_CAP) {\n buffer.shift();\n }\n buffer.push([name, props]);\n}\n","import type { OpenPanel } from \"@openpanel/web\";\n\nimport { clearOpenPanelBuffer, drainOpenPanelBuffer } from \"./buffer.js\";\nimport type { OpenPanelConfig } from \"./types.js\";\n\nlet client: OpenPanel | undefined;\n\n/**\n * Returns the cached `OpenPanel` singleton, building it on first call.\n *\n * When `config.clientId` is empty it returns `undefined` without importing\n * `@openpanel/web`, so the bundler can tree-shake the SDK out of production.\n */\nexport async function getOpenPanelClient(\n config: OpenPanelConfig,\n): Promise<OpenPanel | undefined> {\n if (!config.clientId) {\n return undefined;\n }\n\n if (client) {\n return client;\n }\n\n // Dynamic import keeps @openpanel/web out of the initial chunk.\n const { OpenPanel: OpenPanelClass } = await import(\"@openpanel/web\");\n\n client = new OpenPanelClass({\n clientId: config.clientId,\n ...(config.apiUrl ? { apiUrl: config.apiUrl } : {}),\n });\n\n // Runs once (the `if (client)` guard above), so the buffer is never\n // double-drained.\n drainOpenPanelBuffer(client);\n\n return client;\n}\n\n/**\n * Clears the cached singleton and the pre-init buffer. Call on consent\n * revocation or during tests; buffered events are discarded, not replayed.\n */\nexport function resetOpenPanelClient(): void {\n client = undefined;\n clearOpenPanelBuffer();\n}\n","","import type { OperationWithContext } from \"@powerhousedao/shared/document-model\";\nimport { z } from \"zod\";\n\nimport type { OpenPanelEventMapping } from \"./types.js\";\nimport rawEvents from \"./events.json\" with { type: \"json\" };\n\nconst EventMappingSchema = z\n .object({\n documentType: z.string().min(1),\n actionTypes: z.array(z.string().min(1)).min(1),\n alias: z.string().optional(),\n })\n .strict();\n\nconst EventMappingsSchema = z.array(EventMappingSchema).readonly();\n\n/**\n * Parses and validates the event mapping table, returning the validated array\n * and an O(1) lookup map. Accepts a `raw` override for tests. Throws on zod\n * failures and on duplicate `(documentType, actionType)` pairs.\n */\nexport function loadEvents(raw: unknown = rawEvents): {\n mappings: readonly OpenPanelEventMapping[];\n lookupMap: Map<string, Map<string, OpenPanelEventMapping>>;\n} {\n const result = EventMappingsSchema.safeParse(raw);\n if (!result.success) {\n throw new Error(`Invalid OpenPanel events.json: ${result.error.message}`);\n }\n\n const mappings = result.data as readonly OpenPanelEventMapping[];\n const lookupMap = new Map<string, Map<string, OpenPanelEventMapping>>();\n\n for (const mapping of mappings) {\n let inner = lookupMap.get(mapping.documentType);\n if (!inner) {\n inner = new Map<string, OpenPanelEventMapping>();\n lookupMap.set(mapping.documentType, inner);\n }\n\n for (const actionType of mapping.actionTypes) {\n if (inner.has(actionType)) {\n throw new Error(\n `Duplicate OpenPanel event mapping for ${mapping.documentType}/${actionType}`,\n );\n }\n inner.set(actionType, mapping);\n }\n }\n\n return { mappings, lookupMap };\n}\n\nconst { mappings: defaultMappings, lookupMap: defaultLookupMap } = loadEvents();\n\n/** Validated mapping array from the bundled events.json. */\nexport const eventMappings: readonly OpenPanelEventMapping[] = defaultMappings;\n\n/** O(1) lookup map: documentType → actionType → mapping. */\nexport const eventLookupMap: Map<\n string,\n Map<string, OpenPanelEventMapping>\n> = defaultLookupMap;\n\n/**\n * Normalizes a document type into a safe event-name segment: lowercased, `/`\n * replaced with `.`, and any character outside `[a-z0-9._-]` stripped.\n * e.g. `powerhouse/document-drive` → `powerhouse.document-drive`.\n */\nexport function normalize(documentType: string): string {\n return documentType\n .toLowerCase()\n .replace(/\\//g, \".\")\n .replace(/[^a-z0-9._-]/g, \"\");\n}\n\n/**\n * Derives the OpenPanel event name: `mapping.alias` when present, otherwise\n * `${normalize(documentType)}.${actionType.toLowerCase()}`.\n */\nexport function deriveEventName(\n mapping: OpenPanelEventMapping,\n op: OperationWithContext,\n): string {\n if (mapping.alias) {\n return mapping.alias;\n }\n return `${normalize(op.context.documentType)}.${op.operation.action.type.toLowerCase()}`;\n}\n\n/** Builds the default properties attached to every OpenPanel event. */\nexport function buildDefaultProperties(op: OperationWithContext): {\n documentType: string;\n actionType: string;\n documentId: string;\n scope: string;\n branch: string;\n app: string;\n} {\n return {\n documentType: op.context.documentType,\n actionType: op.operation.action.type,\n documentId: op.context.documentId,\n scope: op.context.scope,\n branch: op.context.branch,\n app: \"connect\",\n };\n}\n","import type { OperationWithContext } from \"@powerhousedao/shared/document-model\";\nimport type { IProcessor } from \"@powerhousedao/shared/processors\";\n\nimport { buildDefaultProperties, deriveEventName } from \"./events.js\";\nimport type { OpenPanelEventMapping } from \"./types.js\";\n\n/**\n * Minimal structural type for the injected analytics client. Keeps\n * `@openpanel/web` out of the runtime import graph and makes test fakes\n * trivial; the real `OpenPanel` instance satisfies it structurally.\n */\nexport type OpenPanelTracker = {\n track: (name: string, properties?: Record<string, unknown>) => unknown;\n flush?: () => void;\n};\n\n/**\n * Read-only reactor `IProcessor` that translates matching document operations\n * into OpenPanel analytics events. Operations whose `(documentType, actionType)`\n * pair is absent from the lookup map are skipped; per-operation errors are\n * routed to `onError` and never thrown back to the manager.\n */\nexport class OpenPanelProcessor implements IProcessor {\n constructor(\n private readonly client: OpenPanelTracker,\n private readonly lookupMap: Map<string, Map<string, OpenPanelEventMapping>>,\n private readonly onError: (\n err: unknown,\n op?: OperationWithContext,\n ) => void = (err) =>\n console.warn(\"[OpenPanelProcessor] Error tracking event:\", err),\n ) {}\n\n async onOperations(operations: OperationWithContext[]): Promise<void> {\n for (const op of operations) {\n const inner = this.lookupMap.get(op.context.documentType);\n if (!inner) continue;\n\n const mapping = inner.get(op.operation.action.type);\n if (!mapping) continue;\n\n const name = deriveEventName(mapping, op);\n const payload = buildDefaultProperties(op);\n\n try {\n await this.client.track(name, payload);\n } catch (err) {\n this.onError(err, op);\n }\n }\n }\n\n async onDisconnect(): Promise<void> {\n this.client.flush?.();\n }\n}\n","import type { OperationWithContext } from \"@powerhousedao/shared/document-model\";\nimport type { PHDocumentHeader } from \"@powerhousedao/shared/document-model\";\nimport type {\n ProcessorFactory,\n ProcessorRecord,\n} from \"@powerhousedao/shared/processors\";\n\nimport { OpenPanelProcessor, type OpenPanelTracker } from \"./processor.js\";\nimport type { OpenPanelEventMapping } from \"./types.js\";\n\nexport type OpenPanelProcessorFactoryConfig = {\n /** The initialized analytics client to forward events to. */\n client: OpenPanelTracker;\n\n /** Loaded event mapping data, as returned by `loadEvents()`. */\n events: {\n mappings: readonly OpenPanelEventMapping[];\n lookupMap: Map<string, Map<string, OpenPanelEventMapping>>;\n };\n\n /** Replay window. Defaults to `\"current\"` (no historical replay). */\n startFrom?: \"current\" | \"beginning\";\n\n /** Error handler; defaults to `console.warn`. */\n onError?: (err: unknown, op?: OperationWithContext) => void;\n};\n\n/**\n * Returns a `ProcessorFactory` that, for each drive, creates a single\n * `OpenPanelProcessor` record whose `filter.documentType` is the union of all\n * document types present in the event mapping table.\n */\nexport function createOpenPanelProcessorFactory(\n config: OpenPanelProcessorFactoryConfig,\n): ProcessorFactory {\n return function openPanelProcessorFactory(\n _driveHeader: PHDocumentHeader,\n ): ProcessorRecord[] {\n const documentType = Array.from(config.events.lookupMap.keys());\n\n const processor = new OpenPanelProcessor(\n config.client,\n config.events.lookupMap,\n config.onError,\n );\n\n const record: ProcessorRecord = {\n processor,\n filter: { documentType },\n startFrom: config.startFrom ?? \"current\",\n };\n\n return [record];\n };\n}\n","/**\n * Detects whether Connect is being rendered inside another app (e.g. inside\n * an iframe in the vetra-cli drive editor). When `?embed=1` is present in the\n * URL, chrome that doesn't make sense in the embedded context — the cookie\n * banner, the outer sidebar — is suppressed.\n */\nexport function getIsEmbedded(): boolean {\n if (typeof window === \"undefined\") return false;\n try {\n const params = new URLSearchParams(window.location.search);\n const value = params.get(\"embed\");\n return value !== null && value !== \"0\" && value !== \"false\";\n } catch {\n return false;\n }\n}\n\nexport function useIsEmbedded(): boolean {\n return getIsEmbedded();\n}\n","import { connectConfig } from \"@powerhousedao/connect/config\";\nimport { useSyncExternalStore } from \"react\";\nimport { getIsEmbedded } from \"./useIsEmbedded.js\";\n\nconst namespace = connectConfig.routerBasename;\n\nexport const COOKIE_BANNER_KEY_STORAGE = `${namespace}:display-cookie-banner`;\n\nconst listeners = new Set<() => void>();\n\nlet bannerShown = getInitial();\n\nfunction getInitial(): boolean {\n if (getIsEmbedded()) return false;\n try {\n const value = localStorage.getItem(COOKIE_BANNER_KEY_STORAGE);\n return value !== \"false\";\n } catch (error) {\n console.error(error);\n return true;\n }\n}\n\nfunction getCookieBannerState(): boolean {\n return bannerShown;\n}\n\nfunction setCookieBannerState(state: boolean) {\n bannerShown = state;\n localStorage.setItem(COOKIE_BANNER_KEY_STORAGE, JSON.stringify(state));\n}\n\nfunction subscribe(fn: () => void) {\n listeners.add(fn);\n return () => listeners.delete(fn);\n}\n\nexport const useCookieBanner = () => {\n const cookieBannerShown = useSyncExternalStore(\n subscribe,\n getCookieBannerState,\n getCookieBannerState,\n );\n return [cookieBannerShown, setCookieBannerState] as const;\n};\n","import {\n usePackageDiscoveryService,\n type FailedInstallation,\n} from \"@powerhousedao/reactor-browser\";\nimport { useSyncExternalStore } from \"react\";\n\nconst emptyArray: FailedInstallation[] = [];\n\nexport function useFailedInstallations() {\n const discoveryService = usePackageDiscoveryService();\n return useSyncExternalStore(\n (cb) => discoveryService?.subscribeFailed(cb) ?? (() => {}),\n () => discoveryService?.getFailedInstallations() ?? emptyArray,\n );\n}\n","import { connectConfig } from \"@powerhousedao/connect/config\";\n\nimport type { BrowserOptions } from \"@sentry/react\";\n\nimport { childLogger } from \"document-model\";\nimport React, { useEffect } from \"react\";\nimport {\n createRoutesFromChildren,\n matchRoutes,\n useLocation,\n useNavigationType,\n} from \"react-router-dom\";\nimport { useAcceptedCookies } from \"./useAcceptedCookies.js\";\n\nconst logger = childLogger([\"sentry\"]);\n\nlet clientStarted = false;\n\nasync function getSentry() {\n return await import(\"@sentry/react\");\n}\n\nasync function initSentry() {\n const release = connectConfig.sentry;\n\n const Sentry = await getSentry();\n const integrations: BrowserOptions[\"integrations\"] = [\n Sentry.httpClientIntegration(),\n Sentry.extraErrorDataIntegration({ depth: 5 }),\n Sentry.replayIntegration(),\n Sentry.captureConsoleIntegration({ levels: [\"error\"] }),\n ];\n if (connectConfig.sentry.tracing) {\n integrations.push(\n Sentry.reactRouterV6BrowserTracingIntegration({\n useEffect: React.useEffect,\n useLocation,\n useNavigationType,\n createRoutesFromChildren,\n matchRoutes,\n }),\n );\n }\n\n Sentry.init({\n release: connectConfig.sentry.release,\n dsn: connectConfig.sentry.dsn,\n environment: connectConfig.sentry.env,\n integrations,\n ignoreErrors: [\n \"User is not allowed to create files\",\n \"User is not allowed to move documents\",\n \"The user aborted a request.\",\n ],\n sendDefaultPii: true,\n tracesSampleRate: 1.0,\n replaysSessionSampleRate: 0.1,\n replaysOnErrorSampleRate: 1.0,\n beforeSend(event, hint) {\n const error = hint.originalException;\n if (\n error instanceof TypeError &&\n error.message.includes(\"Failed to fetch\") &&\n !navigator.onLine\n ) {\n // If fetch fails because user is offline then ignores the error\n return null;\n }\n return event;\n },\n });\n\n clientStarted = true;\n}\n\nasync function closeClient() {\n if (!clientStarted) {\n return;\n }\n const sentry = await getSentry();\n const client = sentry.getClient();\n return client?.close();\n}\n\nexport function useInitSentry() {\n const [acceptedCookies] = useAcceptedCookies();\n const { analytics } = acceptedCookies;\n\n useEffect(() => {\n if (!analytics) {\n closeClient().catch((error: unknown) => logger.error(\"@error\", error));\n return;\n }\n\n if (\n clientStarted ||\n !connectConfig.sentry.dsn ||\n connectConfig.sentry.dsn === \"\"\n ) {\n return;\n }\n\n initSentry().catch((error: unknown) => logger.error(\"@error\", error));\n }, [analytics]);\n}\n","import {\n usePackageDiscoveryService,\n type PendingInstallation,\n} from \"@powerhousedao/reactor-browser\";\nimport { useCallback, useRef, useSyncExternalStore } from \"react\";\n\nconst emptyArray: readonly PendingInstallation[] = [];\n\nexport function usePendingInstallations() {\n const discoveryService = usePackageDiscoveryService();\n const cacheRef = useRef<readonly PendingInstallation[]>(emptyArray);\n\n const getSnapshot = useCallback(() => {\n if (!discoveryService) return emptyArray;\n const next = discoveryService.getPendingInstallations() ?? emptyArray;\n const prev = cacheRef.current;\n if (\n next === prev ||\n (next.length === prev.length && next.every((p, i) => p === prev[i]))\n ) {\n return prev;\n }\n cacheRef.current = next;\n return next;\n }, [discoveryService]);\n\n return useSyncExternalStore(\n (cb) => discoveryService?.subscribePending(cb) ?? (() => {}),\n getSnapshot,\n );\n}\n","import { useHotkeys } from \"react-hotkeys-hook\";\n\nexport interface UseUndoRedoShortcutsProps {\n undo: () => void;\n redo: () => void;\n canUndo: boolean;\n canRedo: boolean;\n}\n\nexport const useUndoRedoShortcuts = (props: UseUndoRedoShortcutsProps) => {\n const { undo, redo, canRedo, canUndo } = props;\n const isMac = window.navigator.userAgent.includes(\"Mac\");\n\n let undoShortcut = \"ctrl+z\";\n let redoShortcut = \"ctrl+y\";\n\n if (isMac) {\n undoShortcut = \"mod+z\";\n redoShortcut = \"mod+shift+z\";\n }\n\n // set handler for undo\n useHotkeys(\n undoShortcut,\n (event) => {\n event.preventDefault();\n if (canUndo) {\n undo();\n }\n },\n {},\n [canUndo, undo],\n );\n\n // set handler for redo\n useHotkeys(\n redoShortcut,\n (event) => {\n event.preventDefault();\n if (canRedo) {\n redo();\n }\n },\n {},\n [canRedo, redo],\n );\n};\n","import { connectConfig } from \"@powerhousedao/connect/config\";\nimport { useAcceptedCookies } from \"@powerhousedao/connect/hooks\";\nimport { useEffect } from \"react\";\n\ndeclare global {\n interface Window {\n gtag?: (...args: any[]) => void;\n dataLayer?: any[];\n }\n}\n\nfunction gtag(...args: (string | Date)[]) {\n window.dataLayer?.push(...args);\n}\n\nexport const Analytics = () => {\n const gaTrackingId = connectConfig.gaTrackingId;\n const [{ analytics }] = useAcceptedCookies();\n const useAnalytics = gaTrackingId && analytics;\n\n useEffect(() => {\n if (useAnalytics) {\n // Create the GA script tag\n const script = document.createElement(\"script\");\n script.src = `https://www.googletagmanager.com/gtag/js?id=${gaTrackingId}`;\n script.async = true;\n document.head.appendChild(script);\n\n // Initialize GA\n window.dataLayer = window.dataLayer || [];\n\n gtag(\"js\", new Date());\n gtag(\"config\", gaTrackingId);\n\n // Clean up the script if no longer enabled\n return () => {\n document.head.removeChild(script);\n };\n }\n }, [useAnalytics, gaTrackingId]);\n\n return null;\n};\n","import type { User } from \"@renown/sdk\";\n\n/**\n * Builds the OpenPanel identity traits from a renown User.\n *\n * Rules:\n * - `credential` (contains a JWT) is **never** forwarded.\n * - `did` / `profileId` is sent as the top-level `profileId` key in the\n * `client.identify()` call — it is **not** duplicated inside traits.\n * - Optional fields (`ens`, `profile`) are only included when their value is\n * non-nullish (guards against `null` from `RenownProfile` fields as well\n * as plain `undefined`).\n *\n * Mirror the Sentry pattern in `store/user.ts`: destructure off `credential`\n * first, then assemble the trait payload from the remainder.\n */\nexport function buildTraits(user: User): Record<string, unknown> {\n // Destructure credential off so it can never accidentally make it into the\n // returned object.\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { credential: _credential, ...rest } = user;\n\n const traits: Record<string, unknown> = {\n address: rest.address,\n networkId: rest.networkId,\n chainId: rest.chainId,\n };\n\n // ens fields — optional on the User type\n if (rest.ens?.name != null) {\n traits.ensName = rest.ens.name;\n }\n if (rest.ens?.avatarUrl != null) {\n traits.ensAvatar = rest.ens.avatarUrl;\n }\n\n // profile fields — optional on InternalUser; RenownProfile members can be\n // null, so guard with != null (catches both null and undefined)\n if (rest.profile?.username != null) {\n traits.username = rest.profile.username;\n }\n if (rest.profile?.userImage != null) {\n traits.userImage = rest.profile.userImage;\n }\n if (rest.profile?.documentId != null) {\n traits.profileDocumentId = rest.profile.documentId;\n }\n if (rest.profile?.createdAt != null) {\n traits.profileCreatedAt = rest.profile.createdAt;\n }\n\n return traits;\n}\n","import type { OpenPanel as OpenPanelClient } from \"@openpanel/web\";\nimport { connectConfig } from \"@powerhousedao/connect/config\";\nimport { useAcceptedCookies } from \"@powerhousedao/connect/hooks\";\nimport {\n createOpenPanelProcessorFactory,\n eventLookupMap,\n eventMappings,\n getOpenPanelClient,\n resetOpenPanelClient,\n} from \"@powerhousedao/connect/services\";\nimport {\n useReactorClientModule,\n useUser,\n} from \"@powerhousedao/reactor-browser\";\nimport { useEffect, useRef, useState } from \"react\";\n\nimport { buildTraits } from \"./openpanel-traits.js\";\n\ndeclare global {\n interface Window {\n openPanel?: OpenPanelClient;\n }\n}\n\n/**\n * `OpenPanel` is a `null`-rendering component that manages the full lifecycle\n * of the OpenPanel analytics subsystem.\n *\n * Gates:\n * - `useAcceptedCookies().analytics === true` — the existing analytics cookie.\n * - `connectConfig.openPanel.clientId` non-empty — no client ID → no-op.\n *\n * Behaviour when both gates pass:\n * 1. Lazy-imports `@openpanel/web` and builds the singleton via\n * `getOpenPanelClient(connectConfig.openPanel)`.\n * 2. Exposes the client on `window.openPanel` for the card-6 `useOpenPanel()`\n * hook to consume.\n * 3. If `connectConfig.openPanel.trackOperations`, registers the processor\n * factory against `processorManager` so document operations are forwarded.\n * 4. Calls `client.identify()` when the renown user transitions from\n * `undefined` → defined (login).\n * 5. Calls `client.clear()` when the user transitions from defined →\n * `undefined` (logout).\n *\n * Teardown (unmount **or** consent revocation):\n * - `unregisterFactory(\"openpanel\")` to remove the processor.\n * - `resetOpenPanelClient()` to clear the singleton.\n * - `window.openPanel` is cleared.\n *\n * Mirrors the Sentry pattern in `store/user.ts` for login/logout detection.\n * Analytics failures are caught and forwarded to `console.warn` — they must\n * never throw into the application.\n *\n * Mounted next to `<Analytics />` in `app.tsx`.\n */\nexport function OpenPanel(): null {\n const [{ analytics }] = useAcceptedCookies();\n const user = useUser();\n const reactorClientModule = useReactorClientModule();\n\n const [client, setClient] = useState<OpenPanelClient | undefined>();\n\n /**\n * Tracks the previous `user` value so we can detect the two transitions:\n * undefined → defined (login)\n * defined → undefined (logout)\n */\n const prevUserRef = useRef<ReturnType<typeof useUser>>(undefined);\n\n const enabled = analytics && !!connectConfig.openPanel.clientId;\n const processorManager = reactorClientModule?.reactorModule?.processorManager;\n\n useEffect(() => {\n if (!enabled) return;\n\n let cancelled = false;\n\n void (async () => {\n let builtClient: OpenPanelClient | undefined;\n try {\n builtClient = await getOpenPanelClient(connectConfig.openPanel);\n } catch (err) {\n console.warn(\"[OpenPanel] Failed to build client:\", err);\n return;\n }\n\n if (cancelled || !builtClient) return;\n\n setClient(builtClient);\n window.openPanel = builtClient;\n\n if (connectConfig.openPanel.trackOperations && processorManager) {\n try {\n await processorManager.registerFactory(\n \"openpanel\",\n createOpenPanelProcessorFactory({\n client: builtClient,\n events: { mappings: eventMappings, lookupMap: eventLookupMap },\n startFrom: \"current\",\n }),\n );\n // Guard against teardown happening while registerFactory was in flight.\n if (cancelled) {\n await processorManager\n .unregisterFactory(\"openpanel\")\n .catch((err: unknown) =>\n console.warn(\n \"[OpenPanel] Failed to unregister factory after cancellation:\",\n err,\n ),\n );\n }\n } catch (err) {\n console.warn(\n \"[OpenPanel] Failed to register processor factory:\",\n err,\n );\n }\n }\n })();\n\n return () => {\n cancelled = true;\n\n // Reset the user-tracking ref so that when consent is re-granted (and a\n // new client is built) any currently-logged-in user is re-identified.\n prevUserRef.current = undefined;\n\n if (connectConfig.openPanel.trackOperations && processorManager) {\n void processorManager\n .unregisterFactory(\"openpanel\")\n .catch((err: unknown) =>\n console.warn(\n \"[OpenPanel] Failed to unregister processor factory:\",\n err,\n ),\n );\n }\n\n resetOpenPanelClient();\n window.openPanel = undefined;\n setClient(undefined);\n };\n }, [enabled, processorManager]);\n\n // detect login/logout transitions\n useEffect(() => {\n if (!enabled || !client) return;\n\n const prev = prevUserRef.current;\n prevUserRef.current = user;\n\n if (!prev && user) {\n // Login: undefined → defined (or client became available with user\n // already logged in — prevUserRef is undefined in both cases).\n try {\n void client.identify({\n profileId: user.did,\n properties: buildTraits(user),\n });\n } catch (err) {\n console.warn(\"[OpenPanel] Failed to identify user:\", err);\n }\n } else if (prev && !user) {\n // Logout: defined → undefined\n try {\n void client.clear();\n } catch (err) {\n console.warn(\"[OpenPanel] Failed to clear user:\", err);\n }\n }\n }, [client, user, enabled]);\n\n return null;\n}\n","import { DocumentEditor } from \"@powerhousedao/connect/components\";\nimport {\n setSelectedNode,\n useNodeParentFolderById,\n useSelectedDocument,\n} from \"@powerhousedao/reactor-browser\";\nimport { useCallback, useMemo } from \"react\";\n\nexport function DocumentEditorContainer() {\n const [selectedDocument] = useSelectedDocument();\n const parentFolder = useNodeParentFolderById(selectedDocument.header.id);\n\n // TODO: unused\n const onOpenSwitchboardLink = useMemo(() => {\n return async () => {\n //\n };\n }, []);\n\n const onClose = useCallback(() => {\n setSelectedNode(parentFolder);\n }, [parentFolder, setSelectedNode]);\n\n return (\n <div\n id=\"document-editor-container\"\n className=\"flex-1\"\n data-document-type={selectedDocument.header.documentType}\n >\n <DocumentEditor document={selectedDocument} />\n </div>\n );\n}\n","import { DefaultEditorLoader } from \"@powerhousedao/design-system/connect\";\nimport type { ComponentProps, ReactNode } from \"react\";\nimport { useEffect, useState } from \"react\";\n\ntype Props = ComponentProps<typeof DefaultEditorLoader> & {\n loadingTimeout?: number;\n customEditorLoader?: ReactNode;\n};\nexport function EditorLoader(props: Props) {\n const [showLoading, setShowLoading] = useState(false);\n\n // only shows the loader after some time has passed\n useEffect(() => {\n setTimeout(() => {\n setShowLoading(true);\n }, props.loadingTimeout ?? 200);\n }, [props]);\n\n if (!showLoading) return null;\n\n const { customEditorLoader, ...defaultProps } = props;\n\n if (customEditorLoader) return <>{customEditorLoader}</>;\n\n return <DefaultEditorLoader {...defaultProps} />;\n}\n","import { Icon, PowerhouseButton } from \"@powerhousedao/design-system\";\nimport { childLogger } from \"document-model\";\nimport type { ReactNode } from \"react\";\nimport {\n ErrorBoundary as ReactErrorBoundary,\n type FallbackProps,\n} from \"react-error-boundary\";\n\nconst logger = childLogger([\"Connect\"]);\n\n/**\n * Available fallback UI variants for the ErrorBoundary component.\n *\n * - `\"silent\"` - Renders nothing when an error occurs (useful for modals)\n * - `\"text\"` - Displays a simple centered text message\n * - `\"detailed\"` - Shows full error details including message and JSON representation\n */\ntype ErrorFallbackVariant = \"silent\" | \"text\" | \"detailed\";\n\n/**\n * Base props shared by all ErrorBoundary configurations.\n */\ntype BaseErrorBoundaryProps = {\n /** Content to wrap with error boundary protection */\n children: ReactNode;\n /** Optional callback invoked when an error is caught (in addition to logging) */\n onError?: (error: Error, info: React.ErrorInfo) => void;\n /** When any value in this array changes, the error boundary resets */\n resetKeys?: unknown[];\n /** Logger context path for error logging (e.g., [\"Connect\", \"Editor\"]) */\n loggerContext?: string[];\n};\n\n/**\n * Props for using a predefined fallback variant.\n */\ntype VariantErrorBoundaryProps = BaseErrorBoundaryProps & {\n /** The fallback UI variant to display on error */\n variant: ErrorFallbackVariant;\n /** Custom message for the \"text\" variant (default: \"Something went wrong\") */\n fallbackMessage?: string;\n};\n\n/**\n * Props for using a custom fallback render function.\n */\ntype CustomFallbackErrorBoundaryProps = BaseErrorBoundaryProps & {\n /** Custom render function for the fallback UI */\n fallbackRender: (props: FallbackProps) => ReactNode;\n};\n\n/**\n * Union type for all ErrorBoundary prop configurations.\n * Use either a variant or a custom fallbackRender, but not both.\n */\ntype ErrorBoundaryProps =\n | VariantErrorBoundaryProps\n | CustomFallbackErrorBoundaryProps;\n\nfunction hasCustomFallback(\n props: ErrorBoundaryProps,\n): props is CustomFallbackErrorBoundaryProps {\n return \"fallbackRender\" in props;\n}\n\nfunction SilentFallback() {\n return null;\n}\n\n/**\n * Simple text-based fallback component.\n * Displays a centered message when an error occurs.\n */\nfunction TextFallback({\n message = \"Something went wrong\",\n}: {\n message?: string;\n}) {\n return <div className=\"text-center\">{message}</div>;\n}\n\n/**\n * Detailed fallback component showing full error information.\n * Displays error message with a collapsible details section.\n * Useful for development and debugging purposes.\n */\nfunction DetailedFallback({ error, resetErrorBoundary }: FallbackProps) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n const errorDetails =\n error instanceof Error\n ? (error.stack ?? String(error.cause))\n : JSON.stringify(error, null, 2);\n const hasDetails = errorDetails !== \"{}\";\n\n return (\n <div className=\"z-10 mx-auto flex max-w-[80%] flex-1 items-center justify-center p-6\">\n <div className=\"w-full max-w-lg rounded-lg border border-gray-500 bg-white p-6 shadow-sm\">\n <div className=\"mb-3 flex items-center gap-2\">\n <Icon name=\"Error\" className=\"size-5 shrink-0\" />\n <h1 className=\"text-lg font-semibold\">Something went wrong</h1>\n </div>\n <p className=\"mb-4 text-sm text-gray-700\">{errorMessage}</p>\n {hasDetails && (\n <details className=\"group\">\n <summary className=\"cursor-pointer text-sm font-medium text-gray-700 underline select-none hover:text-gray-700\">\n Show details\n </summary>\n <pre className=\"mt-2 max-h-48 overflow-auto rounded-sm bg-gray-100 p-3 text-xs\">\n {errorDetails}\n </pre>\n </details>\n )}\n <PowerhouseButton\n type=\"button\"\n onClick={resetErrorBoundary}\n className=\"mt-4 px-3 py-1.5 text-base font-medium\"\n >\n Try again\n </PowerhouseButton>\n </div>\n </div>\n );\n}\n\n/**\n * Centered error message fallback component.\n * Displays the error message in a centered, full-size container.\n * Suitable for use as a custom fallbackRender when you need simple error display.\n */\nfunction CenteredErrorMessage({ error }: FallbackProps) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n return (\n <div className=\"flex size-full items-center justify-center\">\n <h3 className=\"text-lg font-semibold\">{errorMessage}</h3>\n </div>\n );\n}\n\nfunction getFallbackComponent(\n variant: ErrorFallbackVariant,\n fallbackMessage?: string,\n): (props: FallbackProps) => ReactNode {\n switch (variant) {\n case \"silent\":\n return SilentFallback;\n case \"text\":\n return () => <TextFallback message={fallbackMessage} />;\n case \"detailed\":\n return DetailedFallback;\n default:\n return CenteredErrorMessage;\n }\n}\n\n/**\n * Unified error boundary component for catching and handling React errors.\n *\n * Built on top of `react-error-boundary`, this component provides:\n * - Automatic error logging with configurable context\n * - Multiple fallback UI variants (silent, text, detailed)\n * - Support for custom fallback render functions\n * - Reset capability via `resetKeys`\n *\n * @example\n * // Using a predefined variant\n * <ErrorBoundary variant=\"detailed\" loggerContext={[\"Connect\", \"Editor\"]}>\n * <EditorComponent />\n * </ErrorBoundary>\n *\n * @example\n * // Using a custom message with the text variant\n * <ErrorBoundary variant=\"text\" fallbackMessage=\"Failed to load drives\">\n * <DrivesList />\n * </ErrorBoundary>\n *\n * @example\n * // Using a custom fallback render\n * <ErrorBoundary\n * fallbackRender={CenteredErrorMessage}\n * onError={(error) => trackError(error)}\n * >\n * <MyComponent />\n * </ErrorBoundary>\n *\n * @example\n * // Silent mode for modals (renders null on error)\n * <ErrorBoundary variant=\"silent\" loggerContext={[\"Connect\", \"Modals\"]}>\n * <ModalContent />\n * </ErrorBoundary>\n */\nexport function ErrorBoundary(props: ErrorBoundaryProps) {\n const { children, onError, resetKeys, loggerContext } = props;\n\n const handleError = (error: Error, info: React.ErrorInfo) => {\n if (\n error.message.includes(\"Failed to fetch dynamically imported module\") &&\n error.message.includes(\"node_modules/.vite\")\n ) {\n console.error(error);\n console.log(\"Outdated chunk detected, reloading page...\");\n window.location.reload();\n return;\n }\n\n const contextLogger = loggerContext ? childLogger(loggerContext) : logger;\n contextLogger.error(\"@error @info\", error, info);\n onError?.(error, info);\n };\n\n const fallbackRender = hasCustomFallback(props)\n ? props.fallbackRender\n : getFallbackComponent(props.variant, props.fallbackMessage);\n\n return (\n <ReactErrorBoundary\n fallbackRender={fallbackRender}\n onError={handleError}\n resetKeys={resetKeys}\n >\n {children}\n </ReactErrorBoundary>\n );\n}\n\nexport { CenteredErrorMessage, DetailedFallback, TextFallback };\nexport type { FallbackProps };\n","import { DropZoneWrapper } from \"@powerhousedao/design-system/connect\";\nimport { GenericDriveExplorer } from \"@powerhousedao/powerhouse-vetra-packages/editors\";\nimport {\n useAppModuleById,\n useDefaultAppModule,\n useSelectedDocumentId,\n useSelectedDriveSafe,\n} from \"@powerhousedao/reactor-browser\";\nimport { Suspense } from \"react\";\nimport { DocumentEditorContainer } from \"./document-editor-container.js\";\nimport { EditorLoader } from \"./editor-loader.js\";\nimport { ErrorBoundary } from \"./error-boundary.js\";\n\nexport function AppContainer() {\n const [selectedDrive] = useSelectedDriveSafe();\n const selectedDocumentId = useSelectedDocumentId();\n\n const app = useAppModuleById(selectedDrive?.header.meta?.preferredEditor);\n const defaultApp = useDefaultAppModule();\n\n if (!selectedDrive) {\n return <EditorLoader />;\n }\n\n const AppComponent =\n app?.Component ?? defaultApp?.Component ?? GenericDriveExplorer.Component;\n\n if (!AppComponent) {\n throw new Error(\"No app component found\");\n }\n return (\n <ErrorBoundary\n variant=\"detailed\"\n resetKeys={[selectedDrive.header.id]}\n loggerContext={[\"Connect\", \"App\"]}\n >\n <Suspense fallback={<EditorLoader />}>\n <DropZoneWrapper className=\"flex h-full flex-col overflow-auto\">\n <AppComponent>\n {selectedDocumentId ? <DocumentEditorContainer /> : null}\n </AppComponent>\n </DropZoneWrapper>\n </Suspense>\n </ErrorBoundary>\n );\n}\n","export function getBasePath() {\n if (typeof document === \"undefined\") {\n return \"/\";\n }\n\n const baseEl = document.querySelector(\"base\");\n const href = baseEl?.getAttribute(\"href\");\n return href || \"/\";\n}\n","import type {\n Operation,\n PHDocument,\n} from \"@powerhousedao/shared/document-model\";\n\nexport class DocumentEditorDebugTools {\n private document: PHDocument | undefined;\n private operations: Operation[] = [];\n\n constructor(document?: PHDocument) {\n if (document) {\n this.document = document;\n }\n }\n\n private operationsToTableObject(operations: Operation[]) {\n return operations.map((op) => ({\n ...op,\n input: JSON.stringify(op.action.input),\n }));\n }\n\n public setDocument(document: PHDocument) {\n this.document = document;\n }\n\n public getDocument() {\n return this.document;\n }\n\n public getOperations() {\n return this.operations;\n }\n\n public pushOperation(operation: Operation) {\n this.operations.push(operation);\n }\n\n public operationsTable() {\n if (!this.document) {\n console.warn(\"No document\");\n }\n const ops = Object.values(this.document?.operations || {})\n .filter((array): array is Operation[] => array !== undefined)\n .flatMap((array) => array)\n .sort((a, b) => a.index - b.index);\n\n console.table(this.operationsToTableObject(ops));\n }\n\n public scopeOperationsTable(scope: string) {\n if (!this.document) {\n console.warn(\"No document\");\n }\n const ops = this.document?.operations[scope] || [];\n console.table(this.operationsToTableObject(ops));\n }\n\n public operationsLog() {\n console.log(this.operations);\n }\n\n public operationsLogTable() {\n console.table(this.operationsToTableObject(this.operations));\n }\n\n public clear() {\n this.operations = [];\n this.document = undefined;\n }\n}\n","export type MigrationPhase = \"clone\" | \"dump\" | \"restore\";\n\nexport type MigrationStatus = {\n idbName: string;\n phase: MigrationPhase;\n};\n\nlet current: MigrationStatus | null = null;\nconst listeners = new Set<() => void>();\n\nexport function setMigrationStatus(status: MigrationStatus | null): void {\n current = status;\n for (const l of listeners) l();\n}\n\nexport function getMigrationStatus(): MigrationStatus | null {\n return current;\n}\n\nexport function subscribeMigrationStatus(cb: () => void): () => void {\n listeners.add(cb);\n return () => {\n listeners.delete(cb);\n };\n}\n","import { PGlite } from \"@electric-sql/pglite\";\nimport {\n setMigrationStatus,\n type MigrationPhase,\n} from \"../components/migration-status.js\";\nimport {\n createFileDataStore,\n IDB_DB_VERSION,\n IDB_STORE_NAME,\n idbError,\n openIdb,\n PRIMARY_IDB_NAMES,\n readPgVersionFile,\n} from \"./pglite-idb.js\";\nimport { CURRENT_PG_MAJOR } from \"./pglite-runtime.js\";\n\nconst BACKUP_PREFIX = \"ph-pglite-backup::\";\nconst BACKUP_INDEX_KEY = \"ph:pglite-backups\";\nconst BACKUP_RETENTION_MS = 30 * 24 * 60 * 60 * 1000;\n\ntype FileDataValue = {\n contents: Uint8Array | number[];\n mode: number;\n timestamp: Date | number;\n};\n\ntype LegacyDumper = (idbName: string) => Promise<string>;\n\nconst LEGACY_DUMPERS: Partial<Record<number, () => Promise<LegacyDumper>>> = {\n 16: async () => {\n const [{ PGlite: LegacyPGlite }, { pgDump }] = await Promise.all([\n import(\"pglite-legacy-02\"),\n import(\"pglite-tools-legacy-02/pg_dump\"),\n ]);\n return async (idbName: string) => {\n const stripped = idbName.replace(/^\\/pglite\\//, \"\");\n const pg = new LegacyPGlite(`idb://${stripped}`);\n try {\n await pg.waitReady;\n const file = await pgDump({ pg });\n return await file.text();\n } finally {\n await pg.close();\n }\n };\n },\n};\n\n// Emscripten IDBFS holds the IDB connection open past pglite's pg.close(),\n// so deleteDatabase can be blocked indefinitely. Callers on the hot path\n// should prefer clearFileData() instead; deleteIdb is only used by the\n// janitor for expired backups, which tolerates the 15s timeout.\nfunction deleteIdb(name: string, timeoutMs = 15_000): Promise<void> {\n return new Promise((resolve, reject) => {\n const req = indexedDB.deleteDatabase(name);\n let settled = false;\n const done = (fn: () => void) => {\n if (settled) return;\n settled = true;\n fn();\n };\n const timer = setTimeout(\n () =>\n done(() =>\n reject(\n new Error(`IDB delete timed out for ${name} after ${timeoutMs}ms`),\n ),\n ),\n timeoutMs,\n );\n req.onsuccess = () =>\n done(() => {\n clearTimeout(timer);\n resolve();\n });\n req.onerror = () =>\n done(() => {\n clearTimeout(timer);\n reject(idbError(req, `IDB delete failed for ${name}`));\n });\n });\n}\n\nasync function clearFileData(name: string): Promise<void> {\n const db = await openIdb(name, IDB_DB_VERSION, createFileDataStore);\n try {\n await new Promise<void>((resolve, reject) => {\n const tx = db.transaction(IDB_STORE_NAME, \"readwrite\");\n tx.oncomplete = () => resolve();\n tx.onerror = () =>\n reject(idbError(tx, `FILE_DATA clear failed for ${name}`));\n tx.onabort = () =>\n reject(idbError(tx, `FILE_DATA clear aborted for ${name}`));\n tx.objectStore(IDB_STORE_NAME).clear();\n });\n } finally {\n db.close();\n }\n}\n\nasync function cloneFileData(\n sourceName: string,\n destName: string,\n): Promise<void> {\n const source = await openIdb(sourceName, IDB_DB_VERSION, createFileDataStore);\n try {\n const dest = await openIdb(destName, IDB_DB_VERSION, createFileDataStore);\n try {\n const readTx = source.transaction(IDB_STORE_NAME, \"readonly\");\n const readStore = readTx.objectStore(IDB_STORE_NAME);\n const entries = await new Promise<\n Array<{ key: IDBValidKey; value: FileDataValue }>\n >((resolve, reject) => {\n const out: Array<{ key: IDBValidKey; value: FileDataValue }> = [];\n const req = readStore.openCursor();\n req.onerror = () =>\n reject(\n idbError(req, `FILE_DATA read cursor failed for ${sourceName}`),\n );\n req.onsuccess = () => {\n const cursor = req.result;\n if (!cursor) return resolve(out);\n out.push({ key: cursor.key, value: cursor.value as FileDataValue });\n cursor.continue();\n };\n });\n\n await new Promise<void>((resolve, reject) => {\n const writeTx = dest.transaction(IDB_STORE_NAME, \"readwrite\");\n writeTx.oncomplete = () => resolve();\n writeTx.onerror = () =>\n reject(idbError(writeTx, `FILE_DATA write failed for ${destName}`));\n writeTx.onabort = () =>\n reject(idbError(writeTx, `FILE_DATA write aborted for ${destName}`));\n const writeStore = writeTx.objectStore(IDB_STORE_NAME);\n writeStore.clear();\n for (const { key, value } of entries) {\n writeStore.put(value, key);\n }\n });\n } finally {\n dest.close();\n }\n } finally {\n source.close();\n }\n}\n\ntype BackupRecord = { name: string; idbName: string; createdAt: number };\n\nfunction readBackupIndex(): BackupRecord[] {\n try {\n const raw = localStorage.getItem(BACKUP_INDEX_KEY);\n if (!raw) return [];\n const parsed: unknown = JSON.parse(raw);\n return Array.isArray(parsed) ? (parsed as BackupRecord[]) : [];\n } catch {\n return [];\n }\n}\n\nfunction writeBackupIndex(records: BackupRecord[]): void {\n try {\n localStorage.setItem(BACKUP_INDEX_KEY, JSON.stringify(records));\n } catch {\n // ignore quota errors — janitor is best-effort\n }\n}\n\nfunction registerBackup(rec: BackupRecord): void {\n writeBackupIndex([...readBackupIndex(), rec]);\n}\n\nfunction forgetBackup(name: string): void {\n writeBackupIndex(readBackupIndex().filter((r) => r.name !== name));\n}\n\nasync function janitor(): Promise<void> {\n const cutoff = Date.now() - BACKUP_RETENTION_MS;\n const keep: BackupRecord[] = [];\n for (const rec of readBackupIndex()) {\n if (rec.createdAt >= cutoff) {\n keep.push(rec);\n continue;\n }\n try {\n await deleteIdb(rec.name);\n } catch (err) {\n console.warn(`Failed to delete expired pglite backup ${rec.name}`, err);\n keep.push(rec);\n }\n }\n writeBackupIndex(keep);\n}\n\nfunction publishPhase(idbName: string, phase: MigrationPhase): void {\n setMigrationStatus({ idbName, phase });\n}\n\nasync function migrateIdbIfNeeded(idbName: string): Promise<void> {\n const major = await readPgVersionFile(idbName);\n if (major === null || major === CURRENT_PG_MAJOR) return;\n\n const loader = LEGACY_DUMPERS[major];\n if (!loader) {\n throw new Error(\n `Unsupported legacy PGlite data dir: PG_VERSION=${major} for ${idbName}`,\n );\n }\n\n const backupName = `${BACKUP_PREFIX}${idbName}::${new Date().toISOString()}`;\n const backupRec: BackupRecord = {\n name: backupName,\n idbName,\n createdAt: Date.now(),\n };\n\n publishPhase(idbName, \"clone\");\n await cloneFileData(idbName, backupName);\n registerBackup(backupRec);\n\n let sql: string;\n try {\n publishPhase(idbName, \"dump\");\n const dump = await loader();\n sql = await dump(idbName);\n } catch (err) {\n await deleteIdb(backupName).catch(() => {});\n forgetBackup(backupName);\n throw err;\n }\n\n try {\n // Can't deleteDatabase here: Emscripten IDBFS from the legacy PGlite\n // keeps its IDB connection open past pg.close(). Clearing the store\n // in-place leaves the IDB handle alone, and the fresh PGlite will\n // initdb into the empty VFS.\n await clearFileData(idbName);\n publishPhase(idbName, \"restore\");\n const stripped = idbName.replace(/^\\/pglite\\//, \"\");\n const pg = new PGlite(`idb://${stripped}`, { relaxedDurability: false });\n try {\n await pg.waitReady;\n // PGlite 0.2.x pg_dump emits SQL literals with doubled backslashes\n // (escape-string form) but does not always emit the matching\n // `SET standard_conforming_strings = off`. PG17 defaults that GUC to on,\n // so '\\\\\"' in the dump is parsed as a literal backslash + end-of-string\n // and JSONB re-parsing fails. Force off at the session level before\n // running the dump so doubled backslashes collapse as intended.\n console.info(\n `[pglite-migration] Dump preamble (first 500 chars):\\n${sql.slice(0, 500)}`,\n );\n try {\n await pg.exec(\"SET standard_conforming_strings = off;\");\n } catch (gucErr) {\n console.warn(\n \"[pglite-migration] Could not force standard_conforming_strings=off\",\n gucErr,\n );\n }\n try {\n await pg.exec(sql);\n } catch (execErr) {\n logRestoreFailure(idbName, sql, execErr);\n throw execErr;\n }\n } finally {\n await pg.close();\n }\n } catch (err) {\n await rollbackFromBackup(idbName, backupName, err);\n throw err;\n }\n}\n\nfunction logRestoreFailure(idbName: string, sql: string, err: unknown): void {\n const errObj = err as {\n message?: string;\n position?: string | number;\n severity?: string;\n code?: string;\n detail?: string;\n where?: string;\n internalQuery?: string;\n };\n const position =\n typeof errObj.position === \"string\"\n ? parseInt(errObj.position, 10)\n : typeof errObj.position === \"number\"\n ? errObj.position\n : NaN;\n\n console.error(`[pglite-migration] Restore failed for ${idbName}`, {\n message: errObj.message,\n code: errObj.code,\n severity: errObj.severity,\n detail: errObj.detail,\n where: errObj.where,\n position: errObj.position,\n sqlLength: sql.length,\n });\n\n if (Number.isFinite(position) && position > 0) {\n const zeroBased = position - 1;\n const start = Math.max(0, zeroBased - 200);\n const end = Math.min(sql.length, zeroBased + 200);\n const before = sql.slice(start, zeroBased);\n const at = sql.slice(zeroBased, zeroBased + 1);\n const after = sql.slice(zeroBased + 1, end);\n console.error(\n `[pglite-migration] SQL context around position ${position}:\\n${before}»${at}«${after}`,\n );\n const lineStart = sql.lastIndexOf(\"\\n\", zeroBased) + 1;\n const lineEnd = sql.indexOf(\"\\n\", zeroBased);\n const line = sql.slice(lineStart, lineEnd === -1 ? sql.length : lineEnd);\n console.error(\n `[pglite-migration] Failing line (truncated to 500 chars):\\n${line.slice(0, 500)}`,\n );\n } else {\n console.error(\n `[pglite-migration] No position info. First 2000 chars of dump:\\n${sql.slice(0, 2000)}`,\n );\n }\n}\n\nasync function rollbackFromBackup(\n idbName: string,\n backupName: string,\n originalError: unknown,\n): Promise<void> {\n try {\n await clearFileData(idbName).catch(() => {});\n await cloneFileData(backupName, idbName);\n } catch (rollbackErr) {\n console.error(\n `PGlite migration failed AND rollback failed for ${idbName}. Primary error:`,\n originalError,\n \"Rollback error:\",\n rollbackErr,\n );\n return;\n }\n await deleteIdb(backupName).catch(() => {});\n forgetBackup(backupName);\n}\n\nasync function migrateAllLocked(): Promise<void> {\n for (const idbName of PRIMARY_IDB_NAMES) {\n await migrateIdbIfNeeded(idbName);\n }\n setMigrationStatus(null);\n}\n\nexport async function migrateAllIfNeeded(): Promise<void> {\n janitor().catch((err) => console.warn(\"PGlite backup janitor failed\", err));\n\n const hasLocks =\n typeof navigator !== \"undefined\" &&\n \"locks\" in navigator &&\n typeof navigator.locks.request === \"function\";\n\n if (!hasLocks) {\n await migrateAllLocked();\n return;\n }\n\n await navigator.locks.request(\n \"ph-pglite-migration\",\n { mode: \"exclusive\" },\n async () => {\n await migrateAllLocked();\n },\n );\n}\n","import { getBasePath } from \"@powerhousedao/connect/utils\";\nimport { getIsEmbedded } from \"@powerhousedao/connect/hooks\";\nimport {\n AnimatedLoader,\n ConnectSidebar,\n HomeScreen,\n} from \"@powerhousedao/design-system/connect\";\nimport {\n useEffect,\n useState,\n useSyncExternalStore,\n type PropsWithChildren,\n} from \"react\";\nimport {\n getMigrationStatus,\n subscribeMigrationStatus,\n type MigrationPhase,\n} from \"./migration-status.js\";\nconst LOADER_DELAY = 250;\n\nconst PHASE_LABEL: Record<MigrationPhase, string> = {\n clone: \"Backing up local database…\",\n dump: \"Exporting data from previous version…\",\n restore: \"Restoring data into the new database…\",\n};\n\nconst MigrationOverlay = () => {\n const status = useSyncExternalStore(\n subscribeMigrationStatus,\n getMigrationStatus,\n () => null,\n );\n if (!status) return null;\n return (\n <div className=\"absolute inset-0 z-20 flex items-center justify-center\">\n <div className=\"rounded-lg bg-white/90 px-6 py-4 text-sm text-gray-900 shadow-lg\">\n <div className=\"font-medium\">Upgrading local database…</div>\n <div className=\"text-gray-600\">{PHASE_LABEL[status.phase]}</div>\n </div>\n </div>\n );\n};\n\nconst Loader = ({ delay = LOADER_DELAY }: { delay?: number }) => {\n const isSSR = typeof window === \"undefined\";\n const showInitialLoader =\n typeof document !== \"undefined\" &&\n document.body.getAttribute(\"data-show-loader\") === \"true\";\n\n const [showLoading, setShowLoading] = useState(!delay || showInitialLoader);\n\n useEffect(() => {\n const id = setTimeout(() => {\n setShowLoading(true);\n }, delay);\n\n return () => clearTimeout(id);\n }, []);\n\n return (\n <div\n className={`skeleton-loader absolute inset-0 z-10 flex items-center justify-center ${showLoading ? \"\" : \"hidden\"}`}\n >\n <div className=\"animate-pulse overflow-hidden rounded-full shadow-lg\">\n <AnimatedLoader />\n </div>\n {isSSR ? (\n <script\n dangerouslySetInnerHTML={{\n __html: `setTimeout(() => {\n document.querySelector('.skeleton-loader')?.classList.remove('hidden');\n document.body.setAttribute('data-show-loader', 'true');\n }, ${delay})`,\n }}\n />\n ) : null}\n </div>\n );\n};\n\nexport const AppSkeleton: React.FC<PropsWithChildren> = (props) => {\n const isSSR = typeof window === \"undefined\";\n const isHomeScreen = !isSSR && window.location.pathname === getBasePath();\n /* Match Root's behavior: when Connect is rendered inside an embed (e.g. the\n * vetra-studio BUILD iframe), suppress the sidebar during the Suspense\n * fallback so the loading state matches the loaded state. */\n const isEmbedded = !isSSR && getIsEmbedded();\n return (\n <div className=\"flex h-screen overflow-hidden\">\n {!isEmbedded && (\n <ConnectSidebar\n className=\"animate-pulse\"\n onLogin={undefined}\n onDisconnect={undefined}\n onClickSettings={undefined}\n address={undefined}\n />\n )}\n <HomeScreen\n containerClassName={\n isSSR || !isHomeScreen ? \"hidden home-screen\" : undefined\n }\n children={props.children ?? null}\n />\n {isSSR ? (\n <script\n dangerouslySetInnerHTML={{\n __html: `\n const baseEl = document.querySelector('base');\n const href = baseEl?.getAttribute('href');\n const basePath = href || '/';\n if (window.location.pathname === basePath) {\n document.querySelector('.home-screen')?.classList.remove('hidden')\n }`,\n }}\n />\n ) : null}\n {!props.children ? <Loader /> : null}\n <MigrationOverlay />\n </div>\n );\n};\n\nexport default AppSkeleton;\n","import {\n CURRENT_PG_MAJOR,\n getCachedReactorPgMajor,\n migrateAllIfNeeded,\n subscribeReactorPgMajor,\n} from \"@powerhousedao/connect/utils\";\nimport { useState, useSyncExternalStore } from \"react\";\n\nlet dismissed = false;\nconst listeners = new Set<() => void>();\n\nfunction notify() {\n for (const l of listeners) l();\n}\n\nfunction dismiss() {\n dismissed = true;\n notify();\n}\n\nfunction subscribeDismissed(cb: () => void): () => void {\n listeners.add(cb);\n return () => {\n listeners.delete(cb);\n };\n}\n\nfunction getDismissed(): boolean {\n return dismissed;\n}\n\nexport const MigrationBanner: React.FC = () => {\n const isDismissed = useSyncExternalStore(\n subscribeDismissed,\n getDismissed,\n () => false,\n );\n const major = useSyncExternalStore(\n subscribeReactorPgMajor,\n getCachedReactorPgMajor,\n () => undefined,\n );\n const [migrating, setMigrating] = useState(false);\n const [error, setError] = useState<string | null>(null);\n\n if (major === undefined || major === null || major === CURRENT_PG_MAJOR) {\n return null;\n }\n if (isDismissed) return null;\n\n const handleMigrate = () => {\n setError(null);\n setMigrating(true);\n migrateAllIfNeeded()\n .then(() => {\n window.location.reload();\n })\n .catch((err: unknown) => {\n setError(err instanceof Error ? err.message : String(err));\n setMigrating(false);\n });\n };\n\n return (\n <div className=\"absolute inset-x-0 top-0 z-30 flex justify-center p-3\">\n <div className=\"flex max-w-3xl items-center gap-3 rounded-lg border border-yellow-500 bg-yellow-400 px-4 py-3 text-sm text-gray-900 shadow-lg\">\n <div className=\"flex-1\">\n <div className=\"font-semibold\">\n Your local database uses Postgres {major}.\n </div>\n <div className=\"text-gray-800\">\n Migrate to Postgres {CURRENT_PG_MAJOR} to pick up the latest\n features. Your data will be backed up first.\n </div>\n {error && (\n <div className=\"mt-2 font-medium text-red-900\">\n Migration failed: {error}\n </div>\n )}\n </div>\n <button\n type=\"button\"\n disabled={migrating}\n onClick={handleMigrate}\n className=\"rounded-sm bg-gray-900 px-3 py-1 text-sm font-medium text-white hover:bg-gray-800 disabled:opacity-50\"\n >\n {migrating ? \"Migrating…\" : \"Migrate now\"}\n </button>\n <button\n type=\"button\"\n disabled={migrating}\n onClick={dismiss}\n className=\"rounded-sm border border-gray-900 bg-transparent px-3 py-1 text-sm font-medium text-gray-900 hover:bg-gray-900/10 disabled:opacity-50\"\n >\n Dismiss\n </button>\n </div>\n </div>\n );\n};\n","import { usePHModal } from \"@powerhousedao/reactor-browser\";\nimport { lazy, Suspense } from \"react\";\nimport { ErrorBoundary } from \"../error-boundary.js\";\n\nconst AddDriveModal = lazy(() =>\n import(\"./modals/AddDriveModal.js\").then((m) => ({\n default: m.AddDriveModal,\n })),\n);\nconst ClearStorageModal = lazy(() =>\n import(\"./modals/ClearStorageModal.js\").then((m) => ({\n default: m.ClearStorageModal,\n })),\n);\nconst CookiesPolicyModal = lazy(() =>\n import(\"./modals/CookiesPolicyModal.js\").then((m) => ({\n default: m.CookiesPolicyModal,\n })),\n);\nconst CreateDocumentModal = lazy(() =>\n import(\"./modals/CreateDocumentModal.js\").then((m) => ({\n default: m.CreateDocumentModal,\n })),\n);\nconst DebugSettingsModal = lazy(() =>\n import(\"./modals/DebugSettingsModal.js\").then((m) => ({\n default: m.DebugSettingsModal,\n })),\n);\nconst DeleteDriveModal = lazy(() =>\n import(\"./modals/DeleteDriveModal.js\").then((m) => ({\n default: m.DeleteDriveModal,\n })),\n);\nconst DeleteItemModal = lazy(() =>\n import(\"./modals/DeleteItemModal.js\").then((m) => ({\n default: m.DeleteItemModal,\n })),\n);\nconst DisclaimerModal = lazy(() =>\n import(\"./modals/DisclaimerModal.js\").then((m) => ({\n default: m.DisclaimerModal,\n })),\n);\nconst DriveSettingsModal = lazy(() =>\n import(\"./modals/DriveSettingsModal.js\").then((m) => ({\n default: m.DriveSettingsModal,\n })),\n);\nconst DownloadDocumentWithErrorsModal = lazy(() =>\n import(\"./modals/DownloadDocumentWithErrorsModal.js\").then((m) => ({\n default: m.DownloadDocumentWithErrorsModal,\n })),\n);\nconst SettingsModal = lazy(() =>\n import(\"./modals/SettingsModal.js\").then((m) => ({\n default: m.SettingsModal,\n })),\n);\nconst UpgradeDriveModal = lazy(() =>\n import(\"./modals/UpgradeDriveModal.js\").then((m) => ({\n default: m.UpgradeDriveModal,\n })),\n);\nconst InspectorModal = lazy(() =>\n import(\"./modals/InspectorModal/index.js\").then((m) => ({\n default: m.InspectorModal,\n })),\n);\nconst MissingPackageModal = lazy(() =>\n import(\"./modals/MissingPackageModal.js\").then((m) => ({\n default: m.ConnectMissingPackageModal,\n })),\n);\nconst modalComponents = {\n addDrive: AddDriveModal,\n clearStorage: ClearStorageModal,\n cookiesPolicy: CookiesPolicyModal,\n createDocument: CreateDocumentModal,\n debugSettings: DebugSettingsModal,\n deleteDrive: DeleteDriveModal,\n deleteItem: DeleteItemModal,\n disclaimer: DisclaimerModal,\n driveSettings: DriveSettingsModal,\n downloadDocumentWithErrors: DownloadDocumentWithErrorsModal,\n inspector: InspectorModal,\n settings: SettingsModal,\n upgradeDrive: UpgradeDriveModal,\n missingPackage: MissingPackageModal,\n} as const;\n\nexport const ModalsContainer = lazy(async () => {\n return {\n default: () => {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n const phModal = usePHModal();\n\n if (!phModal?.type) return null;\n\n const ModalComponent = modalComponents[phModal.type];\n\n return ModalComponent ? (\n <ErrorBoundary variant=\"silent\" loggerContext={[\"Connect\", \"Modals\"]}>\n <Suspense fallback={null}>\n <ModalComponent />\n </Suspense>\n </ErrorBoundary>\n ) : null;\n },\n };\n});\n","import \"@powerhousedao/connect/i18n\";\nimport type { DocumentModelLib } from \"document-model\";\nimport { lazy, StrictMode, Suspense } from \"react\";\nimport AppSkeleton from \"./app-skeleton.js\";\nimport { DetailedFallback, ErrorBoundary } from \"./error-boundary.js\";\nimport { App, CookieBanner } from \"./index.js\";\nimport { MigrationBanner } from \"./migration-banner.js\";\nimport { ModalsContainer } from \"./modal/modals-container.js\";\n\nexport const AppLoader = (props: { localPackage?: DocumentModelLib }) => {\n const Load = lazy(() =>\n import(\"./load.js\").then((m) => m.loadComponent(props.localPackage)),\n );\n return (\n <StrictMode>\n <ErrorBoundary\n fallbackRender={(props) => (\n <AppSkeleton children={<DetailedFallback {...props} />} />\n )}\n resetKeys={[props.localPackage]}\n loggerContext={[\"Connect\"]}\n >\n <Suspense fallback={<AppSkeleton />} name=\"AppLoader\">\n {/* eslint-disable-next-line react-hooks/static-components */}\n <Load {...props}>\n <App />\n </Load>\n </Suspense>\n <Suspense name=\"CookieBanner\">\n <CookieBanner />\n </Suspense>\n <Suspense name=\"ModalsContainer\">\n <ModalsContainer />\n </Suspense>\n <MigrationBanner />\n </ErrorBoundary>\n </StrictMode>\n );\n};\n","import { useInitSentry } from \"@powerhousedao/connect/hooks\";\n\ninterface SentryProviderProps {\n children?: React.ReactNode;\n}\n\nexport const SentryProvider: React.FC<SentryProviderProps> = ({ children }) => {\n useInitSentry();\n\n return children;\n};\n","import { Modal } from \"@powerhousedao/design-system\";\nimport {\n usePackageDiscoveryService,\n type FailedInstallation,\n type FailedInstallationReason,\n} from \"@powerhousedao/reactor-browser\";\nimport { useState } from \"react\";\nimport { twMerge } from \"tailwind-merge\";\nimport { useFailedInstallations } from \"../hooks/useFailedInstallations.js\";\n\nconst reasonLabels: Record<FailedInstallationReason, string> = {\n \"no-registry\": \"No package registry is configured.\",\n \"not-in-registry\": \"No matching package found in the registry.\",\n \"registry-error\": \"Couldn't reach the package registry.\",\n \"install-failed\": \"Package failed to install.\",\n dismissed: \"Installation was dismissed.\",\n};\n\nfunction canRetry(reason: FailedInstallationReason): boolean {\n return reason !== \"no-registry\";\n}\n\nexport function MissingModelBanner() {\n const failed = useFailedInstallations();\n const [open, setOpen] = useState(false);\n\n if (failed.length === 0) return null;\n\n return (\n <>\n <div className=\"flex items-center justify-between gap-3 bg-amber-100 px-4 py-2 text-sm text-amber-900\">\n <span>\n {failed.length === 1\n ? \"1 document type couldn't load (missing model).\"\n : `${failed.length} document types couldn't load (missing models).`}\n </span>\n <button\n type=\"button\"\n onClick={() => setOpen(true)}\n className=\"rounded-md border border-amber-300 bg-white px-3 py-1 text-amber-900 hover:bg-amber-50\"\n >\n View\n </button>\n </div>\n <MissingModelDetailsModal\n open={open}\n failed={failed}\n onClose={() => setOpen(false)}\n />\n </>\n );\n}\n\ntype DetailsProps = {\n readonly open: boolean;\n readonly failed: FailedInstallation[];\n readonly onClose: () => void;\n};\n\nfunction MissingModelDetailsModal(props: DetailsProps) {\n const { open, failed, onClose } = props;\n const discoveryService = usePackageDiscoveryService();\n const [retrying, setRetrying] = useState<Set<string>>(() => new Set());\n\n async function handleRetry(documentType: string) {\n if (!discoveryService) return;\n setRetrying((prev) => new Set(prev).add(documentType));\n try {\n await discoveryService.retryInstallation(documentType);\n } finally {\n setRetrying((prev) => {\n const next = new Set(prev);\n next.delete(documentType);\n return next;\n });\n }\n }\n\n return (\n <Modal\n open={open}\n onOpenChange={(isOpen) => {\n if (!isOpen) onClose();\n }}\n contentProps={{ className: \"rounded-3xl\" }}\n >\n <div className=\"w-[520px] max-w-[90vw] bg-white p-6\">\n <div className=\"border-b border-slate-100 pb-2 text-2xl font-bold text-gray-800\">\n Missing document models\n </div>\n <div className=\"my-4 text-sm text-gray-600\">\n The following document types couldn't be loaded. Documents using them\n won't display until the underlying package is installed.\n </div>\n {failed.length === 0 ? (\n <div className=\"rounded-xl bg-slate-50 p-4 text-sm text-gray-600\">\n No outstanding failures.\n </div>\n ) : (\n <div className=\"flex max-h-[60vh] flex-col gap-3 overflow-y-auto\">\n {failed.map((entry) => {\n const isRetrying = retrying.has(entry.documentType);\n const retryDisabled = !canRetry(entry.reason) || isRetrying;\n return (\n <div\n key={entry.documentType}\n className=\"rounded-xl bg-slate-50 p-4\"\n >\n <div className=\"mb-1 font-mono text-sm font-semibold text-gray-800\">\n {entry.documentType}\n </div>\n <div className=\"mb-2 text-xs text-gray-600\">\n {reasonLabels[entry.reason]}\n </div>\n {entry.packageNames.length > 0 ? (\n <div className=\"mb-2 text-xs text-gray-500\">\n Package{entry.packageNames.length > 1 ? \"s\" : \"\"}:{\" \"}\n {entry.packageNames.join(\", \")}\n </div>\n ) : null}\n {entry.error ? (\n <div className=\"mb-2 font-mono text-xs wrap-break-word text-red-700\">\n {entry.error.message}\n </div>\n ) : null}\n <div className=\"flex justify-end\">\n <button\n type=\"button\"\n onClick={() => void handleRetry(entry.documentType)}\n disabled={retryDisabled}\n title={\n canRetry(entry.reason)\n ? undefined\n : \"No registry is configured; nothing to retry against.\"\n }\n className={twMerge(\n \"min-h-[32px] rounded-xl px-3 py-1 text-sm font-semibold text-white transition-all hover:scale-105\",\n retryDisabled\n ? \"cursor-not-allowed bg-gray-300 hover:scale-100\"\n : \"bg-gray-800 active:opacity-75\",\n )}\n >\n {isRetrying ? \"Retrying...\" : \"Try install again\"}\n </button>\n </div>\n </div>\n );\n })}\n </div>\n )}\n <div className=\"mt-4 flex justify-end\">\n <button\n type=\"button\"\n onClick={onClose}\n className=\"min-h-[36px] rounded-xl border border-slate-200 bg-white px-4 py-2 text-sm font-semibold text-slate-800 hover:bg-slate-50\"\n >\n Close\n </button>\n </div>\n </div>\n </Modal>\n );\n}\n","import {\n PackageInstallModal,\n type PendingPackageInstallation,\n} from \"@powerhousedao/design-system/connect\";\nimport { usePackageDiscoveryService } from \"@powerhousedao/reactor-browser\";\nimport { usePendingInstallations } from \"../hooks/usePendingInstallations.js\";\n\nexport function PackageInstallPrompt() {\n const pendingInstallations = usePendingInstallations();\n const discoveryService = usePackageDiscoveryService();\n\n if (!discoveryService || pendingInstallations.length === 0) return null;\n\n const installations: PendingPackageInstallation[] =\n pendingInstallations.flatMap((p) =>\n p.packageNames.map((packageName) => ({\n documentType: p.documentType,\n packageName,\n })),\n );\n\n return (\n <PackageInstallModal\n pendingInstallations={installations}\n onInstall={(packageName) =>\n discoveryService.approveInstallation(packageName)\n }\n onDismiss={(packageName) =>\n discoveryService.dismissInstallation(packageName)\n }\n />\n );\n}\n","import {\n Analytics,\n OpenPanel,\n Router,\n} from \"@powerhousedao/connect/components\";\n\nimport { SentryProvider } from \"@powerhousedao/connect/context\";\nimport {\n DocumentEditorDebugTools,\n serviceWorkerManager,\n} from \"@powerhousedao/connect/utils\";\nimport { useEffect } from \"react\";\nimport { ToastContainer } from \"../services/toast.js\";\nimport { MissingModelBanner } from \"./missing-model-banner.js\";\nimport { PackageInstallPrompt } from \"./package-install-prompt.js\";\n\nexport const App = () => {\n // refresh page on vite preload error due to outdated chunks — but only when\n // the failing dynamic import is one of Connect's own chunks. External\n // dynamic imports (e.g. the package manager loading a package from the\n // configured CDN) should let the error propagate so the caller can surface\n // it; reloading here drops any open state and hides the real failure.\n useEffect(() => {\n const handlePreloadError = (event: Event) => {\n const payload = (event as Event & { payload?: unknown }).payload;\n const message =\n payload instanceof Error ? payload.message : String(payload ?? \"\");\n const failedUrl = message.match(/https?:\\/\\/[^\\s\"']+/)?.[0];\n\n if (failedUrl && !failedUrl.startsWith(window.location.origin)) {\n console.debug(\n `[Connect] Skipping reload — vite:preloadError for off-origin URL: ${failedUrl}`,\n );\n return;\n }\n\n console.log(\"Outdated chunks detected, reloading page...\");\n window.location.reload();\n };\n\n window.addEventListener(\"vite:preloadError\", handlePreloadError);\n\n return () => {\n window.removeEventListener(\"vite:preloadError\", handlePreloadError);\n };\n }, []);\n\n useEffect(() => {\n if (import.meta.env.MODE === \"development\") {\n window.documentEditorDebugTools = new DocumentEditorDebugTools();\n } else {\n serviceWorkerManager.registerServiceWorker(false);\n }\n }, []);\n\n return (\n <SentryProvider>\n <ToastContainer position=\"bottom-right\" />\n <MissingModelBanner />\n <Router />\n <PackageInstallPrompt />\n <Analytics />\n <OpenPanel />\n </SentryProvider>\n );\n};\n","import {\n useAcceptedCookies,\n useCookieBanner,\n} from \"@powerhousedao/connect/hooks\";\nimport type { CookieInput } from \"@powerhousedao/design-system/connect\";\nimport { CookieBanner as PHCookieBanner } from \"@powerhousedao/design-system/connect\";\nimport { showPHModal } from \"@powerhousedao/reactor-browser\";\nimport { Trans, useTranslation } from \"react-i18next\";\nimport { i18n } from \"@powerhousedao/connect/i18n\";\n\nconst isCookieAccepted = (cookies: CookieInput[], id: string) => {\n return cookies.some((cookie) => cookie.id === id && cookie.value);\n};\n\nexport const CookieBanner = () => {\n const { t } = useTranslation(undefined, {\n useSuspense: true,\n i18n,\n });\n const [showBanner, setShowBanner] = useCookieBanner();\n const [, setAcceptedCookies] = useAcceptedCookies();\n\n const cookiesInput: CookieInput[] = [\n {\n id: \"analytics-cookie\",\n label: t(\"cookieBanner.cookies.analytics\"),\n value: true,\n },\n ];\n\n const handleAccept = (cookies: CookieInput[]) => {\n setShowBanner(false);\n\n if (isCookieAccepted(cookies, \"analytics-cookie\")) {\n setAcceptedCookies((acceptedCookies) => ({\n ...acceptedCookies,\n analytics: true,\n }));\n }\n };\n\n const handleReject = () => {\n setShowBanner(false);\n setAcceptedCookies(() => ({\n analytics: false,\n functional: false,\n marketing: false,\n }));\n };\n\n if (!showBanner) {\n return null;\n }\n\n return (\n <div className=\"absolute inset-0 z-10000 backdrop-blur-sm\">\n <div className=\"absolute inset-0 bg-black opacity-15\" />\n <div className=\"absolute inset-x-0 bottom-0 flex justify-center bg-white px-10 pt-10 pb-16 shadow-lg\">\n <PHCookieBanner\n className=\"max-w-[1024px]\"\n cookies={cookiesInput}\n onSubmit={handleAccept}\n onReject={handleReject}\n submitLabel={t(\"cookieBanner.accept\")}\n rejectLabel={t(\"cookieBanner.reject\")}\n >\n <p className=\"font-semibold text-gray-500\">\n <Trans\n key={\"cookieBanner.message\"}\n i18nKey=\"cookieBanner.message\"\n components={{\n a: (\n <a\n onClick={() => showPHModal({ type: \"cookiesPolicy\" })}\n key={\"cookieBanner.message-link\"}\n className=\"cursor-pointer text-gray-900 hover:underline\"\n />\n ),\n }}\n />\n </p>\n </PHCookieBanner>\n </div>\n </div>\n );\n};\n","import { Icon } from \"@powerhousedao/design-system\";\nimport { driveCollectionId, useSyncList } from \"@powerhousedao/reactor-browser\";\nimport type { DocumentDriveDocument } from \"@powerhousedao/shared/document-drive\";\nimport { useMemo } from \"react\";\n\nexport function DriveIcon({\n drive,\n}: {\n drive: DocumentDriveDocument | undefined;\n}) {\n const remotes = useSyncList();\n const isRemoteDrive = useMemo(() => {\n if (!drive) return false;\n\n return remotes.some(\n (remote) =>\n remote.collectionId === driveCollectionId(\"main\", drive.header.id),\n );\n }, [remotes, drive]);\n\n const driveIconSrc = drive?.state.global.icon;\n\n if (driveIconSrc) {\n return (\n <img src={driveIconSrc} alt={drive.header.name} height={32} width={32} />\n );\n }\n\n if (!isRemoteDrive) {\n return <Icon name=\"Hdd\" size={32} />;\n }\n\n return <Icon name=\"Server\" size={32} />;\n}\n","import { EditorLoader } from \"@powerhousedao/connect/components\";\nimport { useUndoRedoShortcuts } from \"@powerhousedao/connect/hooks\";\nimport { toast } from \"@powerhousedao/connect/services\";\nimport { RevisionHistory } from \"@powerhousedao/design-system/connect\";\nimport {\n getRevisionFromDate,\n setRevisionHistoryVisible,\n showPHModal,\n useDocumentById,\n useDocumentModelModuleById,\n useDocumentOperations,\n useEditorModuleById,\n useFallbackEditorModule,\n useRevisionHistoryVisible,\n useSelectedTimelineItem,\n useVetraPackageManager,\n useVetraPackages,\n} from \"@powerhousedao/reactor-browser\";\nimport type { PHDocument } from \"@powerhousedao/shared/document-model\";\nimport { redo, undo } from \"@powerhousedao/shared/document-model\";\nimport { Suspense, useEffect, useState } from \"react\";\nimport { CenteredErrorMessage, ErrorBoundary } from \"./error-boundary.js\";\n\ntype Props<TDocument extends PHDocument = PHDocument> = {\n document: TDocument;\n};\n\nfunction EditorError({ message }: { message: React.ReactNode }) {\n return (\n <div className=\"flex size-full items-center justify-center\">\n <h3 className=\"text-lg font-semibold\">{message}</h3>\n </div>\n );\n}\n\nexport const DocumentEditor: React.FC<Props> = (props) => {\n const { document: initialDocument } = props;\n const selectedTimelineItem = useSelectedTimelineItem();\n const revisionHistoryVisible = useRevisionHistoryVisible();\n const [document, dispatch] = useDocumentById(initialDocument.header.id);\n const documentId = document?.header.id ?? undefined;\n const documentName = document?.header.name ?? undefined;\n const documentType = document?.header.documentType ?? undefined;\n const preferredEditor = document?.header.meta?.preferredEditor ?? undefined;\n const {\n globalOperations,\n localOperations,\n isLoading: isLoadingOperations,\n refetch: refetchOperations,\n } = useDocumentOperations(documentId);\n\n // Refetch operations when revision history panel opens\n useEffect(() => {\n if (revisionHistoryVisible) {\n void refetchOperations();\n }\n }, [revisionHistoryVisible, refetchOperations]);\n\n const globalRevisionNumber = document?.header.revision.global ?? 0;\n const localRevisionNumber = document?.header.revision.local ?? 0;\n const documentModelModule = useDocumentModelModuleById(documentType);\n const preferredEditorModule = useEditorModuleById(preferredEditor);\n const fallbackEditorModule = useFallbackEditorModule(documentType);\n const editorModule = preferredEditorModule ?? fallbackEditorModule;\n const vetraPackages = useVetraPackages();\n const packageManager = useVetraPackageManager();\n const owningPackageName = editorModule\n ? vetraPackages.find((pkg) => pkg.editors.includes(editorModule))?.manifest\n .name\n : undefined;\n const owningPackageVersion =\n owningPackageName && packageManager\n ? packageManager.getPackageVersion(owningPackageName)\n : undefined;\n const editorBundleKey = owningPackageName\n ? `${owningPackageName}@${owningPackageVersion ?? \"unknown\"}`\n : (editorModule?.config.id ?? \"no-editor\");\n const isLoadingDocument = !document;\n const isLoadingEditor =\n editorModule &&\n documentType &&\n !editorModule.documentTypes.includes(documentType) &&\n !editorModule.documentTypes.includes(\"*\");\n\n const canUndo = globalRevisionNumber > 0 || localRevisionNumber > 0;\n const canRedo = !!document?.clipboard.length;\n const addUndoAction = () => dispatch(undo());\n const addRedoAction = () => dispatch(redo());\n useUndoRedoShortcuts({\n undo: addUndoAction,\n redo: addRedoAction,\n canUndo,\n canRedo,\n });\n\n useEffect(() => {\n return () => {\n window.documentEditorDebugTools?.clear();\n };\n }, []);\n\n const [editorError, setEditorError] = useState<\n | {\n error: any;\n info: React.ErrorInfo;\n documentId?: string;\n // clear: () => void;\n }\n | undefined\n >(undefined);\n\n useEffect(() => {\n if (editorError && editorError.documentId !== documentId) {\n // eslint-disable-next-line react-hooks/set-state-in-effect\n setEditorError(undefined);\n }\n }, [editorError, documentId]);\n\n const handleEditorError = (error: Error, info: React.ErrorInfo) => {\n setEditorError({\n error,\n documentId,\n info,\n });\n };\n\n if (isLoadingEditor) {\n return <EditorLoader message=\"Loading editor\" />;\n }\n\n if (isLoadingDocument) {\n return <EditorLoader message=\"Loading document\" />;\n }\n\n if (!documentModelModule) {\n return (\n <EditorError\n message={\n <div className=\"text-center leading-10\">\n <p>\n Unable to open the document because the document model \"\n {documentType}\" is not supported.\n </p>\n <p>\n Go to the{\" \"}\n <button\n type=\"button\"\n className=\"cursor-pointer underline\"\n onClick={() => {\n showPHModal({ type: \"settings\" });\n }}\n >\n package manager\n </button>{\" \"}\n to install this document model\n </p>\n </div>\n }\n />\n );\n }\n\n if (!editorModule) {\n return (\n <EditorError\n message={\n <div className=\"text-center leading-10\">\n <p>Unable to open the document because no editor has been found</p>\n <p>\n Go to the{\" \"}\n <button\n type=\"button\"\n className=\"cursor-pointer underline\"\n onClick={() => {\n showPHModal({ type: \"settings\" });\n }}\n >\n package manager\n </button>{\" \"}\n an editor for the \"${documentType}\" document type\n </p>\n </div>\n }\n />\n );\n }\n const EditorComponent = editorModule.Component;\n\n return (\n <div\n className=\"relative h-full\"\n id=\"document-editor-context\"\n data-editor={editorModule.config.id}\n data-document-type={documentType}\n >\n {revisionHistoryVisible ? (\n isLoadingOperations ? (\n <EditorLoader message=\"Loading operations\" />\n ) : (\n <RevisionHistory\n key={documentId}\n documentTitle={documentName ?? \"\"}\n documentId={documentId ?? \"\"}\n globalOperations={globalOperations}\n localOperations={localOperations}\n onClose={() => setRevisionHistoryVisible(false)}\n documentState={document.state}\n onCopyState={() => {\n toast(\"Copied document state to clipboard\", { type: \"success\" });\n }}\n onCopyDocId={() => {\n toast(\"Copied document ID to clipboard\", { type: \"success\" });\n }}\n />\n )\n ) : (\n <Suspense\n fallback={<EditorLoader message=\"Loading editor\" />}\n name=\"EditorLoader\"\n >\n <ErrorBoundary\n fallbackRender={CenteredErrorMessage}\n resetKeys={[documentId]}\n onError={handleEditorError}\n loggerContext={[\"Connect\", \"DocumentEditor\"]}\n >\n {!editorError?.error && (\n <EditorComponent\n key={`${editorBundleKey}:${documentId}`}\n context={{\n readMode: !!selectedTimelineItem,\n selectedTimelineRevision: getRevisionFromDate(\n selectedTimelineItem?.startDate,\n selectedTimelineItem?.endDate,\n globalOperations,\n ),\n }}\n documentId={document.header.id}\n />\n )}\n </ErrorBoundary>\n </Suspense>\n )}\n </div>\n );\n};\n","import { Sidebar } from \"@powerhousedao/connect/components\";\nimport { useIsEmbedded } from \"@powerhousedao/connect/hooks\";\nimport { Suspense } from \"react\";\nimport { Outlet } from \"react-router-dom\";\n\nexport function Root() {\n const isEmbedded = useIsEmbedded();\n return (\n <div className=\"h-screen\">\n <div\n className={`flex h-screen items-stretch overflow-auto`}\n role=\"presentation\"\n tabIndex={0}\n >\n <Suspense name=\"Root\">\n {!isEmbedded && <Sidebar />}\n <div className=\"relative flex-1 overflow-auto\">\n <Outlet />\n </div>\n </Suspense>\n </div>\n </div>\n );\n}\n","import { AppContainer, DriveIcon } from \"@powerhousedao/connect/components\";\nimport {\n connectConfig,\n defaultPHAppConfig,\n defaultPHDocumentEditorConfig,\n} from \"@powerhousedao/connect/config\";\nimport {\n HomeScreen,\n HomeScreenAddDriveItem,\n HomeScreenItem,\n} from \"@powerhousedao/design-system/connect\";\nimport {\n setPHAppConfig,\n setPHDocumentEditorConfig,\n setSelectedDrive,\n useAppModuleById,\n useDrives,\n useSelectedDocumentId,\n useSelectedDriveSafe,\n useSelectedFolder,\n} from \"@powerhousedao/reactor-browser\";\nimport type { DocumentDriveDocument } from \"@powerhousedao/shared/document-drive\";\nimport { useEffect } from \"react\";\n\nexport function Content() {\n const [selectedDrive] = useSelectedDriveSafe();\n const selectedFolder = useSelectedFolder();\n const selectedDocumentId = useSelectedDocumentId();\n\n useEffect(() => {\n if (!selectedDocumentId) {\n setPHDocumentEditorConfig(defaultPHDocumentEditorConfig);\n }\n }, [selectedDocumentId]);\n\n useEffect(() => {\n if (!selectedDrive) {\n setPHAppConfig(defaultPHAppConfig);\n }\n }, [selectedDrive]);\n\n const showHomeScreen =\n !selectedDocumentId && !selectedDrive && !selectedFolder;\n return (\n <ContentContainer>\n {showHomeScreen ? <HomeScreenContainer /> : <AppContainer />}\n </ContentContainer>\n );\n}\n\nfunction ContentContainer({ children }: { children: React.ReactNode }) {\n return (\n <div className=\"flex h-full flex-col overflow-auto\" id=\"content-view\">\n {children}\n </div>\n );\n}\n\nfunction DriveItem({ drive }: { drive: DocumentDriveDocument }) {\n const editorModule = useAppModuleById(drive.header.meta?.preferredEditor);\n const description = editorModule?.config.name || \"Drive Explorer App\";\n return (\n <HomeScreenItem\n key={drive.header.id}\n title={drive.state.global.name || drive.header.name}\n description={description}\n icon={<DriveIcon drive={drive} />}\n onClick={() => setSelectedDrive(drive)}\n />\n );\n}\n\nfunction HomeScreenContainer() {\n const drives = useDrives();\n const config = connectConfig;\n return (\n <HomeScreen>\n {drives?.map((drive) => {\n return <DriveItem key={drive.header.id} drive={drive} />;\n })}\n {config.drives.addDriveEnabled && <HomeScreenAddDriveItem />}\n </HomeScreen>\n );\n}\n","import { Root } from \"@powerhousedao/connect/components\";\nimport { connectConfig } from \"@powerhousedao/connect/config\";\nimport { Content } from \"@powerhousedao/connect/pages\";\nimport { Suspense } from \"react\";\nimport type { RouteObject } from \"react-router-dom\";\nimport { RouterProvider, createBrowserRouter } from \"react-router-dom\";\n\nfunction createRouter(routes: RouteObject[]) {\n const routerBasename = connectConfig.routerBasename;\n\n return createBrowserRouter(routes, {\n basename: routerBasename,\n future: {\n v7_fetcherPersist: true,\n v7_relativeSplatPath: true,\n },\n });\n}\n\nfunction createRoutes() {\n const routes: RouteObject[] = [\n {\n index: true,\n path: \"d?/:driveId?/*?\",\n element: (\n <Suspense name=\"Drive\">\n <Content />\n </Suspense>\n ),\n },\n ];\n\n return [\n {\n element: (\n <Suspense name=\"RouteRoot\">\n <Root />\n </Suspense>\n ),\n children: routes,\n },\n ];\n}\n\nconst routes = createRoutes();\nconst router = createRouter(routes);\n\nexport const Router = () => {\n return <RouterProvider router={router} />;\n};\n","import { DriveIcon } from \"@powerhousedao/connect/components\";\nimport { connectConfig } from \"@powerhousedao/connect/config\";\nimport {\n ConnectSidebar,\n ConnectTooltipProvider,\n SidebarAddDriveItem,\n SidebarItem,\n useEns,\n} from \"@powerhousedao/design-system/connect\";\n\nimport {\n logout,\n openRenown,\n setSelectedDrive,\n showPHModal,\n useDrives,\n useSelectedDriveSafe,\n useUser,\n} from \"@powerhousedao/reactor-browser\";\nimport { ErrorBoundary } from \"./error-boundary.js\";\n\nexport function Sidebar() {\n const user = useUser();\n const drives = useDrives();\n const [selectedDrive] = useSelectedDriveSafe();\n const connectDebug = localStorage.getItem(\"CONNECT_DEBUG\") === \"true\";\n\n const ensName = user?.ens?.name || user?.profile?.username || undefined;\n const avatarUrl =\n user?.ens?.avatarUrl || user?.profile?.userImage || undefined;\n\n const ensInfo = useEns(!avatarUrl ? user?.address : undefined);\n\n const onClickSettings = () => {\n showPHModal({ type: \"settings\" });\n };\n\n const onAddDriveClick = () => {\n showPHModal({ type: \"addDrive\" });\n };\n\n const etherscanUrl = user?.address\n ? `https://etherscan.io/address/${user.address}`\n : \"\";\n\n return (\n <ConnectTooltipProvider>\n <ConnectSidebar\n id=\"sidebar\"\n onClick={() => setSelectedDrive(undefined)}\n onClickSettings={onClickSettings}\n address={user?.address}\n onLogin={openRenown}\n onDisconnect={logout}\n ensName={ensName || ensInfo.data?.ens}\n avatarUrl={\n avatarUrl ||\n ensInfo.data?.avatar_small ||\n ensInfo.data?.avatar_url ||\n undefined\n }\n etherscanUrl={etherscanUrl}\n showDebug={connectDebug}\n onDebugClick={() => showPHModal({ type: \"debugSettings\" })}\n >\n <ErrorBoundary\n variant=\"text\"\n fallbackMessage=\"There was an error loading drives\"\n loggerContext={[\"Connect\", \"Sidebar\"]}\n >\n {drives?.map((drive, index) => (\n <SidebarItem\n key={index}\n title={drive.header.name}\n onClick={() => setSelectedDrive(drive)}\n active={selectedDrive?.header.id === drive.header.id}\n icon={<DriveIcon drive={drive} />}\n />\n ))}\n {connectConfig.drives.addDriveEnabled && (\n <SidebarAddDriveItem onClick={onAddDriveClick} />\n )}\n </ErrorBoundary>\n </ConnectSidebar>\n </ConnectTooltipProvider>\n );\n}\n"],"names":["listeners","getInitial","subscribe","rawEvents","listeners","emptyArray","logger","logger","ErrorBoundary","ReactErrorBoundary","ErrorBoundary","listeners","AddDriveModal","CreateDocumentModal","DriveSettingsModal","SettingsModal","ErrorBoundary","ErrorBoundary","CookieBanner","CookieBanner","PHCookieBanner","ErrorBoundary","ErrorBoundary"],"mappings":"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","debug_id":"391b3e27-0b46-5fcb-9eb0-dde34f5f818f"}
|
|
1
|
+
{"version":3,"file":"sidebar-CZLMU1VL.js","sources":["../src/hooks/useAcceptedCookies.ts","../src/services/openpanel/buffer.ts","../src/services/openpanel/client.ts","../src/services/openpanel/events.json","../src/services/openpanel/events.ts","../src/services/openpanel/processor.ts","../src/services/openpanel/factory.ts","../src/hooks/useIsEmbedded.ts","../src/hooks/useCookieBanner.ts","../src/hooks/useFailedInstallations.ts","../src/hooks/useInitSentry.ts","../src/hooks/usePendingInstallations.ts","../src/hooks/useUndoRedoShortcuts.ts","../src/components/analytics.tsx","../src/components/openpanel-traits.ts","../src/components/openpanel.tsx","../src/components/document-editor-container.tsx","../src/components/editor-loader.tsx","../src/components/error-boundary.tsx","../src/components/app-container.tsx","../src/utils/browser.ts","../src/utils/document-editor-debug-tools.ts","../src/components/migration-status.ts","../src/utils/pglite-migration.ts","../src/components/app-skeleton.tsx","../src/components/migration-banner.tsx","../src/components/modal/modals-container.tsx","../src/components/app-loader.tsx","../src/context/sentry-provider.tsx","../src/components/missing-model-banner.tsx","../src/components/package-install-prompt.tsx","../src/components/app.tsx","../src/components/cookie-banner.tsx","../src/components/drive-icon.tsx","../src/components/editors.tsx","../src/components/root.tsx","../src/pages/content.tsx","../src/components/router.tsx","../src/components/sidebar.tsx"],"sourcesContent":["import { connectConfig } from \"@powerhousedao/connect/config\";\nimport { useSyncExternalStore } from \"react\";\n\nconst namespace = connectConfig.routerBasename;\n\nconst ACCEPTED_COOKIES_KEY_STORAGE = `${namespace}:acceptedCookies`;\n\nexport interface AcceptedCookies {\n analytics: boolean;\n marketing: boolean;\n functional: boolean;\n}\n\nconst listeners = new Set<() => void>();\n\nlet cookies: AcceptedCookies = getInitial();\n\nfunction getInitial(): AcceptedCookies {\n try {\n const value = localStorage.getItem(ACCEPTED_COOKIES_KEY_STORAGE);\n return value\n ? (JSON.parse(value) as AcceptedCookies)\n : { analytics: false, marketing: false, functional: false };\n } catch {\n return { analytics: false, marketing: false, functional: false };\n }\n}\n\nfunction getCookies(): AcceptedCookies {\n return cookies;\n}\n\nfunction setCookies(setter: (prev: AcceptedCookies) => AcceptedCookies) {\n cookies = setter(cookies);\n localStorage.setItem(ACCEPTED_COOKIES_KEY_STORAGE, JSON.stringify(cookies));\n listeners.forEach((fn) => fn());\n}\n\nfunction subscribe(fn: () => void) {\n listeners.add(fn);\n return () => listeners.delete(fn);\n}\n\nexport const useAcceptedCookies = () => {\n const cookies = useSyncExternalStore(subscribe, getCookies, getCookies);\n return [cookies, setCookies] as const;\n};\n","import type { OpenPanelTracker } from \"./processor.js\";\n\n/**\n * Hard cap on pre-init events held in memory. When full, the oldest entry is\n * evicted (drop-oldest) so the most-recent events survive. Bounded, so an\n * uninitialised client never leaks; `resetOpenPanelClient()` discards it\n * entirely so pre-consent events are never replayed.\n */\nconst BUFFER_CAP = 200;\n\ntype BufferEntry = [name: string, props: Record<string, unknown> | undefined];\n\nconst buffer: BufferEntry[] = [];\nlet activeClient: OpenPanelTracker | undefined;\nlet errorHandler: ((err: unknown) => void) | undefined;\n\nfunction defaultOnError(err: unknown): void {\n console.warn(\"[useOpenPanel] track failed:\", err);\n}\n\n/**\n * Forward a single event to the active client, swallowing any throw.\n *\n * The outer try/catch handles synchronous throws from `client.track`; the\n * inner `.catch()` handles rejected promises. Both are needed because\n * `Promise.resolve(x).catch()` cannot catch a throw from evaluating `x`.\n */\nfunction forward(\n client: OpenPanelTracker,\n name: string,\n props: Record<string, unknown> | undefined,\n): void {\n try {\n Promise.resolve(client.track(name, props)).catch((err) =>\n (errorHandler ?? defaultOnError)(err),\n );\n } catch (err) {\n (errorHandler ?? defaultOnError)(err);\n }\n}\n\n/**\n * Drain the pre-init buffer in FIFO order through `client.track`, then forward\n * subsequent events directly. Called once from `getOpenPanelClient()`.\n */\nexport function drainOpenPanelBuffer(\n client: OpenPanelTracker,\n onError?: (err: unknown) => void,\n): void {\n activeClient = client;\n errorHandler = onError;\n\n // Splice atomically so any track() during the drain is forwarded directly\n // (activeClient is set) rather than re-buffered.\n const pending = buffer.splice(0, buffer.length);\n for (const [name, props] of pending) {\n forward(client, name, props);\n }\n}\n\n/**\n * Clear the buffer and reset the active client. Buffered pre-consent events\n * are discarded so they are not replayed if the user later re-accepts.\n */\nexport function clearOpenPanelBuffer(): void {\n buffer.length = 0;\n activeClient = undefined;\n errorHandler = undefined;\n}\n\n/**\n * Track an analytics event. Sync, never throws. Forwards immediately when the\n * client is initialised, otherwise buffers (FIFO, cap 200, drop-oldest).\n */\nexport function track(name: string, props?: Record<string, unknown>): void {\n if (activeClient) {\n forward(activeClient, name, props);\n return;\n }\n\n if (buffer.length >= BUFFER_CAP) {\n buffer.shift();\n }\n buffer.push([name, props]);\n}\n","import type { OpenPanel } from \"@openpanel/web\";\n\nimport { clearOpenPanelBuffer, drainOpenPanelBuffer } from \"./buffer.js\";\nimport type { OpenPanelConfig } from \"./types.js\";\n\nlet client: OpenPanel | undefined;\n\n/**\n * Returns the cached `OpenPanel` singleton, building it on first call.\n *\n * When `config.clientId` is empty it returns `undefined` without importing\n * `@openpanel/web`, so the bundler can tree-shake the SDK out of production.\n */\nexport async function getOpenPanelClient(\n config: OpenPanelConfig,\n): Promise<OpenPanel | undefined> {\n if (!config.clientId) {\n return undefined;\n }\n\n if (client) {\n return client;\n }\n\n // Dynamic import keeps @openpanel/web out of the initial chunk.\n const { OpenPanel: OpenPanelClass } = await import(\"@openpanel/web\");\n\n client = new OpenPanelClass({\n clientId: config.clientId,\n ...(config.apiUrl ? { apiUrl: config.apiUrl } : {}),\n });\n\n // Runs once (the `if (client)` guard above), so the buffer is never\n // double-drained.\n drainOpenPanelBuffer(client);\n\n return client;\n}\n\n/**\n * Clears the cached singleton and the pre-init buffer. Call on consent\n * revocation or during tests; buffered events are discarded, not replayed.\n */\nexport function resetOpenPanelClient(): void {\n client = undefined;\n clearOpenPanelBuffer();\n}\n","","import type { OperationWithContext } from \"@powerhousedao/shared/document-model\";\nimport { z } from \"zod\";\n\nimport type { OpenPanelEventMapping } from \"./types.js\";\nimport rawEvents from \"./events.json\" with { type: \"json\" };\n\nconst EventMappingSchema = z\n .object({\n documentType: z.string().min(1),\n actionTypes: z.array(z.string().min(1)).min(1),\n alias: z.string().optional(),\n })\n .strict();\n\nconst EventMappingsSchema = z.array(EventMappingSchema).readonly();\n\n/**\n * Parses and validates the event mapping table, returning the validated array\n * and an O(1) lookup map. Accepts a `raw` override for tests. Throws on zod\n * failures and on duplicate `(documentType, actionType)` pairs.\n */\nexport function loadEvents(raw: unknown = rawEvents): {\n mappings: readonly OpenPanelEventMapping[];\n lookupMap: Map<string, Map<string, OpenPanelEventMapping>>;\n} {\n const result = EventMappingsSchema.safeParse(raw);\n if (!result.success) {\n throw new Error(`Invalid OpenPanel events.json: ${result.error.message}`);\n }\n\n const mappings = result.data as readonly OpenPanelEventMapping[];\n const lookupMap = new Map<string, Map<string, OpenPanelEventMapping>>();\n\n for (const mapping of mappings) {\n let inner = lookupMap.get(mapping.documentType);\n if (!inner) {\n inner = new Map<string, OpenPanelEventMapping>();\n lookupMap.set(mapping.documentType, inner);\n }\n\n for (const actionType of mapping.actionTypes) {\n if (inner.has(actionType)) {\n throw new Error(\n `Duplicate OpenPanel event mapping for ${mapping.documentType}/${actionType}`,\n );\n }\n inner.set(actionType, mapping);\n }\n }\n\n return { mappings, lookupMap };\n}\n\nconst { mappings: defaultMappings, lookupMap: defaultLookupMap } = loadEvents();\n\n/** Validated mapping array from the bundled events.json. */\nexport const eventMappings: readonly OpenPanelEventMapping[] = defaultMappings;\n\n/** O(1) lookup map: documentType → actionType → mapping. */\nexport const eventLookupMap: Map<\n string,\n Map<string, OpenPanelEventMapping>\n> = defaultLookupMap;\n\n/**\n * Normalizes a document type into a safe event-name segment: lowercased, `/`\n * replaced with `.`, and any character outside `[a-z0-9._-]` stripped.\n * e.g. `powerhouse/document-drive` → `powerhouse.document-drive`.\n */\nexport function normalize(documentType: string): string {\n return documentType\n .toLowerCase()\n .replace(/\\//g, \".\")\n .replace(/[^a-z0-9._-]/g, \"\");\n}\n\n/**\n * Derives the OpenPanel event name: `mapping.alias` when present, otherwise\n * `${normalize(documentType)}.${actionType.toLowerCase()}`.\n */\nexport function deriveEventName(\n mapping: OpenPanelEventMapping,\n op: OperationWithContext,\n): string {\n if (mapping.alias) {\n return mapping.alias;\n }\n return `${normalize(op.context.documentType)}.${op.operation.action.type.toLowerCase()}`;\n}\n\n/** Builds the default properties attached to every OpenPanel event. */\nexport function buildDefaultProperties(op: OperationWithContext): {\n documentType: string;\n actionType: string;\n documentId: string;\n scope: string;\n branch: string;\n app: string;\n} {\n return {\n documentType: op.context.documentType,\n actionType: op.operation.action.type,\n documentId: op.context.documentId,\n scope: op.context.scope,\n branch: op.context.branch,\n app: \"connect\",\n };\n}\n","import type { OperationWithContext } from \"@powerhousedao/shared/document-model\";\nimport type { IProcessor } from \"@powerhousedao/shared/processors\";\n\nimport { buildDefaultProperties, deriveEventName } from \"./events.js\";\nimport type { OpenPanelEventMapping } from \"./types.js\";\n\n/**\n * Minimal structural type for the injected analytics client. Keeps\n * `@openpanel/web` out of the runtime import graph and makes test fakes\n * trivial; the real `OpenPanel` instance satisfies it structurally.\n */\nexport type OpenPanelTracker = {\n track: (name: string, properties?: Record<string, unknown>) => unknown;\n flush?: () => void;\n};\n\n/**\n * Read-only reactor `IProcessor` that translates matching document operations\n * into OpenPanel analytics events. Operations whose `(documentType, actionType)`\n * pair is absent from the lookup map are skipped; per-operation errors are\n * routed to `onError` and never thrown back to the manager.\n */\nexport class OpenPanelProcessor implements IProcessor {\n constructor(\n private readonly client: OpenPanelTracker,\n private readonly lookupMap: Map<string, Map<string, OpenPanelEventMapping>>,\n private readonly onError: (\n err: unknown,\n op?: OperationWithContext,\n ) => void = (err) =>\n console.warn(\"[OpenPanelProcessor] Error tracking event:\", err),\n ) {}\n\n async onOperations(operations: OperationWithContext[]): Promise<void> {\n for (const op of operations) {\n const inner = this.lookupMap.get(op.context.documentType);\n if (!inner) continue;\n\n const mapping = inner.get(op.operation.action.type);\n if (!mapping) continue;\n\n const name = deriveEventName(mapping, op);\n const payload = buildDefaultProperties(op);\n\n try {\n await this.client.track(name, payload);\n } catch (err) {\n this.onError(err, op);\n }\n }\n }\n\n async onDisconnect(): Promise<void> {\n this.client.flush?.();\n }\n}\n","import type { OperationWithContext } from \"@powerhousedao/shared/document-model\";\nimport type { PHDocumentHeader } from \"@powerhousedao/shared/document-model\";\nimport type {\n ProcessorFactory,\n ProcessorRecord,\n} from \"@powerhousedao/shared/processors\";\n\nimport { OpenPanelProcessor, type OpenPanelTracker } from \"./processor.js\";\nimport type { OpenPanelEventMapping } from \"./types.js\";\n\nexport type OpenPanelProcessorFactoryConfig = {\n /** The initialized analytics client to forward events to. */\n client: OpenPanelTracker;\n\n /** Loaded event mapping data, as returned by `loadEvents()`. */\n events: {\n mappings: readonly OpenPanelEventMapping[];\n lookupMap: Map<string, Map<string, OpenPanelEventMapping>>;\n };\n\n /** Replay window. Defaults to `\"current\"` (no historical replay). */\n startFrom?: \"current\" | \"beginning\";\n\n /** Error handler; defaults to `console.warn`. */\n onError?: (err: unknown, op?: OperationWithContext) => void;\n};\n\n/**\n * Returns a `ProcessorFactory` that, for each drive, creates a single\n * `OpenPanelProcessor` record whose `filter.documentType` is the union of all\n * document types present in the event mapping table.\n */\nexport function createOpenPanelProcessorFactory(\n config: OpenPanelProcessorFactoryConfig,\n): ProcessorFactory {\n return function openPanelProcessorFactory(\n _driveHeader: PHDocumentHeader,\n ): ProcessorRecord[] {\n const documentType = Array.from(config.events.lookupMap.keys());\n\n const processor = new OpenPanelProcessor(\n config.client,\n config.events.lookupMap,\n config.onError,\n );\n\n const record: ProcessorRecord = {\n processor,\n filter: { documentType },\n startFrom: config.startFrom ?? \"current\",\n };\n\n return [record];\n };\n}\n","/**\n * Detects whether Connect is being rendered inside another app (e.g. inside\n * an iframe in the vetra-cli drive editor). When `?embed=1` is present in the\n * URL, chrome that doesn't make sense in the embedded context — the cookie\n * banner, the outer sidebar — is suppressed.\n */\nexport function getIsEmbedded(): boolean {\n if (typeof window === \"undefined\") return false;\n try {\n const params = new URLSearchParams(window.location.search);\n const value = params.get(\"embed\");\n return value !== null && value !== \"0\" && value !== \"false\";\n } catch {\n return false;\n }\n}\n\nexport function useIsEmbedded(): boolean {\n return getIsEmbedded();\n}\n","import { connectConfig } from \"@powerhousedao/connect/config\";\nimport { useSyncExternalStore } from \"react\";\nimport { getIsEmbedded } from \"./useIsEmbedded.js\";\n\nconst namespace = connectConfig.routerBasename;\n\nexport const COOKIE_BANNER_KEY_STORAGE = `${namespace}:display-cookie-banner`;\n\nconst listeners = new Set<() => void>();\n\nlet bannerShown = getInitial();\n\nfunction getInitial(): boolean {\n if (getIsEmbedded()) return false;\n try {\n const value = localStorage.getItem(COOKIE_BANNER_KEY_STORAGE);\n return value !== \"false\";\n } catch (error) {\n console.error(error);\n return true;\n }\n}\n\nfunction getCookieBannerState(): boolean {\n return bannerShown;\n}\n\nfunction setCookieBannerState(state: boolean) {\n bannerShown = state;\n localStorage.setItem(COOKIE_BANNER_KEY_STORAGE, JSON.stringify(state));\n}\n\nfunction subscribe(fn: () => void) {\n listeners.add(fn);\n return () => listeners.delete(fn);\n}\n\nexport const useCookieBanner = () => {\n const cookieBannerShown = useSyncExternalStore(\n subscribe,\n getCookieBannerState,\n getCookieBannerState,\n );\n return [cookieBannerShown, setCookieBannerState] as const;\n};\n","import {\n usePackageDiscoveryService,\n type FailedInstallation,\n} from \"@powerhousedao/reactor-browser\";\nimport { useSyncExternalStore } from \"react\";\n\nconst emptyArray: FailedInstallation[] = [];\n\nexport function useFailedInstallations() {\n const discoveryService = usePackageDiscoveryService();\n return useSyncExternalStore(\n (cb) => discoveryService?.subscribeFailed(cb) ?? (() => {}),\n () => discoveryService?.getFailedInstallations() ?? emptyArray,\n );\n}\n","import { connectConfig } from \"@powerhousedao/connect/config\";\n\nimport type { BrowserOptions } from \"@sentry/react\";\n\nimport { childLogger } from \"document-model\";\nimport React, { useEffect } from \"react\";\nimport {\n createRoutesFromChildren,\n matchRoutes,\n useLocation,\n useNavigationType,\n} from \"react-router-dom\";\nimport { useAcceptedCookies } from \"./useAcceptedCookies.js\";\n\nconst logger = childLogger([\"sentry\"]);\n\nlet clientStarted = false;\n\nasync function getSentry() {\n return await import(\"@sentry/react\");\n}\n\nasync function initSentry() {\n const release = connectConfig.sentry;\n\n const Sentry = await getSentry();\n const integrations: BrowserOptions[\"integrations\"] = [\n Sentry.httpClientIntegration(),\n Sentry.extraErrorDataIntegration({ depth: 5 }),\n Sentry.replayIntegration(),\n Sentry.captureConsoleIntegration({ levels: [\"error\"] }),\n ];\n if (connectConfig.sentry.tracing) {\n integrations.push(\n Sentry.reactRouterV6BrowserTracingIntegration({\n useEffect: React.useEffect,\n useLocation,\n useNavigationType,\n createRoutesFromChildren,\n matchRoutes,\n }),\n );\n }\n\n Sentry.init({\n release: connectConfig.sentry.release,\n dsn: connectConfig.sentry.dsn,\n environment: connectConfig.sentry.env,\n integrations,\n ignoreErrors: [\n \"User is not allowed to create files\",\n \"User is not allowed to move documents\",\n \"The user aborted a request.\",\n ],\n sendDefaultPii: true,\n tracesSampleRate: 1.0,\n replaysSessionSampleRate: 0.1,\n replaysOnErrorSampleRate: 1.0,\n beforeSend(event, hint) {\n const error = hint.originalException;\n if (\n error instanceof TypeError &&\n error.message.includes(\"Failed to fetch\") &&\n !navigator.onLine\n ) {\n // If fetch fails because user is offline then ignores the error\n return null;\n }\n return event;\n },\n });\n\n clientStarted = true;\n}\n\nasync function closeClient() {\n if (!clientStarted) {\n return;\n }\n const sentry = await getSentry();\n const client = sentry.getClient();\n return client?.close();\n}\n\nexport function useInitSentry() {\n const [acceptedCookies] = useAcceptedCookies();\n const { analytics } = acceptedCookies;\n\n useEffect(() => {\n if (!analytics) {\n closeClient().catch((error: unknown) => logger.error(\"@error\", error));\n return;\n }\n\n if (\n clientStarted ||\n !connectConfig.sentry.dsn ||\n connectConfig.sentry.dsn === \"\"\n ) {\n return;\n }\n\n initSentry().catch((error: unknown) => logger.error(\"@error\", error));\n }, [analytics]);\n}\n","import {\n usePackageDiscoveryService,\n type PendingInstallation,\n} from \"@powerhousedao/reactor-browser\";\nimport { useCallback, useRef, useSyncExternalStore } from \"react\";\n\nconst emptyArray: readonly PendingInstallation[] = [];\n\nexport function usePendingInstallations() {\n const discoveryService = usePackageDiscoveryService();\n const cacheRef = useRef<readonly PendingInstallation[]>(emptyArray);\n\n const getSnapshot = useCallback(() => {\n if (!discoveryService) return emptyArray;\n const next = discoveryService.getPendingInstallations() ?? emptyArray;\n const prev = cacheRef.current;\n if (\n next === prev ||\n (next.length === prev.length && next.every((p, i) => p === prev[i]))\n ) {\n return prev;\n }\n cacheRef.current = next;\n return next;\n }, [discoveryService]);\n\n return useSyncExternalStore(\n (cb) => discoveryService?.subscribePending(cb) ?? (() => {}),\n getSnapshot,\n );\n}\n","import { useHotkeys } from \"react-hotkeys-hook\";\n\nexport interface UseUndoRedoShortcutsProps {\n undo: () => void;\n redo: () => void;\n canUndo: boolean;\n canRedo: boolean;\n}\n\nexport const useUndoRedoShortcuts = (props: UseUndoRedoShortcutsProps) => {\n const { undo, redo, canRedo, canUndo } = props;\n const isMac = window.navigator.userAgent.includes(\"Mac\");\n\n let undoShortcut = \"ctrl+z\";\n let redoShortcut = \"ctrl+y\";\n\n if (isMac) {\n undoShortcut = \"mod+z\";\n redoShortcut = \"mod+shift+z\";\n }\n\n // set handler for undo\n useHotkeys(\n undoShortcut,\n (event) => {\n event.preventDefault();\n if (canUndo) {\n undo();\n }\n },\n {},\n [canUndo, undo],\n );\n\n // set handler for redo\n useHotkeys(\n redoShortcut,\n (event) => {\n event.preventDefault();\n if (canRedo) {\n redo();\n }\n },\n {},\n [canRedo, redo],\n );\n};\n","import { connectConfig } from \"@powerhousedao/connect/config\";\nimport { useAcceptedCookies } from \"@powerhousedao/connect/hooks\";\nimport { useEffect } from \"react\";\n\ndeclare global {\n interface Window {\n gtag?: (...args: any[]) => void;\n dataLayer?: any[];\n }\n}\n\nfunction gtag(...args: (string | Date)[]) {\n window.dataLayer?.push(...args);\n}\n\nexport const Analytics = () => {\n const gaTrackingId = connectConfig.gaTrackingId;\n const [{ analytics }] = useAcceptedCookies();\n const useAnalytics = gaTrackingId && analytics;\n\n useEffect(() => {\n if (useAnalytics) {\n // Create the GA script tag\n const script = document.createElement(\"script\");\n script.src = `https://www.googletagmanager.com/gtag/js?id=${gaTrackingId}`;\n script.async = true;\n document.head.appendChild(script);\n\n // Initialize GA\n window.dataLayer = window.dataLayer || [];\n\n gtag(\"js\", new Date());\n gtag(\"config\", gaTrackingId);\n\n // Clean up the script if no longer enabled\n return () => {\n document.head.removeChild(script);\n };\n }\n }, [useAnalytics, gaTrackingId]);\n\n return null;\n};\n","import type { User } from \"@renown/sdk\";\n\n/**\n * Builds the OpenPanel identity traits from a renown User.\n *\n * Rules:\n * - `credential` (contains a JWT) is **never** forwarded.\n * - `did` / `profileId` is sent as the top-level `profileId` key in the\n * `client.identify()` call — it is **not** duplicated inside traits.\n * - Optional fields (`ens`, `profile`) are only included when their value is\n * non-nullish (guards against `null` from `RenownProfile` fields as well\n * as plain `undefined`).\n *\n * Mirror the Sentry pattern in `store/user.ts`: destructure off `credential`\n * first, then assemble the trait payload from the remainder.\n */\nexport function buildTraits(user: User): Record<string, unknown> {\n // Destructure credential off so it can never accidentally make it into the\n // returned object.\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { credential: _credential, ...rest } = user;\n\n const traits: Record<string, unknown> = {\n address: rest.address,\n networkId: rest.networkId,\n chainId: rest.chainId,\n };\n\n // ens fields — optional on the User type\n if (rest.ens?.name != null) {\n traits.ensName = rest.ens.name;\n }\n if (rest.ens?.avatarUrl != null) {\n traits.ensAvatar = rest.ens.avatarUrl;\n }\n\n // profile fields — optional on InternalUser; RenownProfile members can be\n // null, so guard with != null (catches both null and undefined)\n if (rest.profile?.username != null) {\n traits.username = rest.profile.username;\n }\n if (rest.profile?.userImage != null) {\n traits.userImage = rest.profile.userImage;\n }\n if (rest.profile?.documentId != null) {\n traits.profileDocumentId = rest.profile.documentId;\n }\n if (rest.profile?.createdAt != null) {\n traits.profileCreatedAt = rest.profile.createdAt;\n }\n\n return traits;\n}\n","import type { OpenPanel as OpenPanelClient } from \"@openpanel/web\";\nimport { connectConfig } from \"@powerhousedao/connect/config\";\nimport { useAcceptedCookies } from \"@powerhousedao/connect/hooks\";\nimport {\n createOpenPanelProcessorFactory,\n eventLookupMap,\n eventMappings,\n getOpenPanelClient,\n resetOpenPanelClient,\n} from \"@powerhousedao/connect/services\";\nimport {\n useReactorClientModule,\n useUser,\n} from \"@powerhousedao/reactor-browser\";\nimport { useEffect, useRef, useState } from \"react\";\n\nimport { buildTraits } from \"./openpanel-traits.js\";\n\ndeclare global {\n interface Window {\n openPanel?: OpenPanelClient;\n }\n}\n\n/**\n * `OpenPanel` is a `null`-rendering component that manages the full lifecycle\n * of the OpenPanel analytics subsystem.\n *\n * Gates:\n * - `useAcceptedCookies().analytics === true` — the existing analytics cookie.\n * - `connectConfig.openPanel.clientId` non-empty — no client ID → no-op.\n *\n * Behaviour when both gates pass:\n * 1. Lazy-imports `@openpanel/web` and builds the singleton via\n * `getOpenPanelClient(connectConfig.openPanel)`.\n * 2. Exposes the client on `window.openPanel` for the card-6 `useOpenPanel()`\n * hook to consume.\n * 3. If `connectConfig.openPanel.trackOperations`, registers the processor\n * factory against `processorManager` so document operations are forwarded.\n * 4. Calls `client.identify()` when the renown user transitions from\n * `undefined` → defined (login).\n * 5. Calls `client.clear()` when the user transitions from defined →\n * `undefined` (logout).\n *\n * Teardown (unmount **or** consent revocation):\n * - `unregisterFactory(\"openpanel\")` to remove the processor.\n * - `resetOpenPanelClient()` to clear the singleton.\n * - `window.openPanel` is cleared.\n *\n * Mirrors the Sentry pattern in `store/user.ts` for login/logout detection.\n * Analytics failures are caught and forwarded to `console.warn` — they must\n * never throw into the application.\n *\n * Mounted next to `<Analytics />` in `app.tsx`.\n */\nexport function OpenPanel(): null {\n const [{ analytics }] = useAcceptedCookies();\n const user = useUser();\n const reactorClientModule = useReactorClientModule();\n\n const [client, setClient] = useState<OpenPanelClient | undefined>();\n\n /**\n * Tracks the previous `user` value so we can detect the two transitions:\n * undefined → defined (login)\n * defined → undefined (logout)\n */\n const prevUserRef = useRef<ReturnType<typeof useUser>>(undefined);\n\n const enabled = analytics && !!connectConfig.openPanel.clientId;\n const processorManager = reactorClientModule?.reactorModule?.processorManager;\n\n useEffect(() => {\n if (!enabled) return;\n\n let cancelled = false;\n\n void (async () => {\n let builtClient: OpenPanelClient | undefined;\n try {\n builtClient = await getOpenPanelClient(connectConfig.openPanel);\n } catch (err) {\n console.warn(\"[OpenPanel] Failed to build client:\", err);\n return;\n }\n\n if (cancelled || !builtClient) return;\n\n setClient(builtClient);\n window.openPanel = builtClient;\n\n if (connectConfig.openPanel.trackOperations && processorManager) {\n try {\n await processorManager.registerFactory(\n \"openpanel\",\n createOpenPanelProcessorFactory({\n client: builtClient,\n events: { mappings: eventMappings, lookupMap: eventLookupMap },\n startFrom: \"current\",\n }),\n );\n // Guard against teardown happening while registerFactory was in flight.\n if (cancelled) {\n await processorManager\n .unregisterFactory(\"openpanel\")\n .catch((err: unknown) =>\n console.warn(\n \"[OpenPanel] Failed to unregister factory after cancellation:\",\n err,\n ),\n );\n }\n } catch (err) {\n console.warn(\n \"[OpenPanel] Failed to register processor factory:\",\n err,\n );\n }\n }\n })();\n\n return () => {\n cancelled = true;\n\n // Reset the user-tracking ref so that when consent is re-granted (and a\n // new client is built) any currently-logged-in user is re-identified.\n prevUserRef.current = undefined;\n\n if (connectConfig.openPanel.trackOperations && processorManager) {\n void processorManager\n .unregisterFactory(\"openpanel\")\n .catch((err: unknown) =>\n console.warn(\n \"[OpenPanel] Failed to unregister processor factory:\",\n err,\n ),\n );\n }\n\n resetOpenPanelClient();\n window.openPanel = undefined;\n setClient(undefined);\n };\n }, [enabled, processorManager]);\n\n // detect login/logout transitions\n useEffect(() => {\n if (!enabled || !client) return;\n\n const prev = prevUserRef.current;\n prevUserRef.current = user;\n\n if (!prev && user) {\n // Login: undefined → defined (or client became available with user\n // already logged in — prevUserRef is undefined in both cases).\n try {\n void client.identify({\n profileId: user.did,\n properties: buildTraits(user),\n });\n } catch (err) {\n console.warn(\"[OpenPanel] Failed to identify user:\", err);\n }\n } else if (prev && !user) {\n // Logout: defined → undefined\n try {\n void client.clear();\n } catch (err) {\n console.warn(\"[OpenPanel] Failed to clear user:\", err);\n }\n }\n }, [client, user, enabled]);\n\n return null;\n}\n","import { DocumentEditor } from \"@powerhousedao/connect/components\";\nimport {\n setSelectedNode,\n useNodeParentFolderById,\n useSelectedDocument,\n} from \"@powerhousedao/reactor-browser\";\nimport { useCallback, useMemo } from \"react\";\n\nexport function DocumentEditorContainer() {\n const [selectedDocument] = useSelectedDocument();\n const parentFolder = useNodeParentFolderById(selectedDocument.header.id);\n\n // TODO: unused\n const onOpenSwitchboardLink = useMemo(() => {\n return async () => {\n //\n };\n }, []);\n\n const onClose = useCallback(() => {\n setSelectedNode(parentFolder);\n }, [parentFolder, setSelectedNode]);\n\n return (\n <div\n id=\"document-editor-container\"\n className=\"flex-1\"\n data-document-type={selectedDocument.header.documentType}\n >\n <DocumentEditor document={selectedDocument} />\n </div>\n );\n}\n","import { DefaultEditorLoader } from \"@powerhousedao/design-system/connect\";\nimport type { ComponentProps, ReactNode } from \"react\";\nimport { useEffect, useState } from \"react\";\n\ntype Props = ComponentProps<typeof DefaultEditorLoader> & {\n loadingTimeout?: number;\n customEditorLoader?: ReactNode;\n};\nexport function EditorLoader(props: Props) {\n const [showLoading, setShowLoading] = useState(false);\n\n // only shows the loader after some time has passed\n useEffect(() => {\n setTimeout(() => {\n setShowLoading(true);\n }, props.loadingTimeout ?? 200);\n }, [props]);\n\n if (!showLoading) return null;\n\n const { customEditorLoader, ...defaultProps } = props;\n\n if (customEditorLoader) return <>{customEditorLoader}</>;\n\n return <DefaultEditorLoader {...defaultProps} />;\n}\n","import { Icon, PowerhouseButton } from \"@powerhousedao/design-system\";\nimport { childLogger } from \"document-model\";\nimport type { ReactNode } from \"react\";\nimport {\n ErrorBoundary as ReactErrorBoundary,\n type FallbackProps,\n} from \"react-error-boundary\";\n\nconst logger = childLogger([\"Connect\"]);\n\n/**\n * Available fallback UI variants for the ErrorBoundary component.\n *\n * - `\"silent\"` - Renders nothing when an error occurs (useful for modals)\n * - `\"text\"` - Displays a simple centered text message\n * - `\"detailed\"` - Shows full error details including message and JSON representation\n */\ntype ErrorFallbackVariant = \"silent\" | \"text\" | \"detailed\";\n\n/**\n * Base props shared by all ErrorBoundary configurations.\n */\ntype BaseErrorBoundaryProps = {\n /** Content to wrap with error boundary protection */\n children: ReactNode;\n /** Optional callback invoked when an error is caught (in addition to logging) */\n onError?: (error: Error, info: React.ErrorInfo) => void;\n /** When any value in this array changes, the error boundary resets */\n resetKeys?: unknown[];\n /** Logger context path for error logging (e.g., [\"Connect\", \"Editor\"]) */\n loggerContext?: string[];\n};\n\n/**\n * Props for using a predefined fallback variant.\n */\ntype VariantErrorBoundaryProps = BaseErrorBoundaryProps & {\n /** The fallback UI variant to display on error */\n variant: ErrorFallbackVariant;\n /** Custom message for the \"text\" variant (default: \"Something went wrong\") */\n fallbackMessage?: string;\n};\n\n/**\n * Props for using a custom fallback render function.\n */\ntype CustomFallbackErrorBoundaryProps = BaseErrorBoundaryProps & {\n /** Custom render function for the fallback UI */\n fallbackRender: (props: FallbackProps) => ReactNode;\n};\n\n/**\n * Union type for all ErrorBoundary prop configurations.\n * Use either a variant or a custom fallbackRender, but not both.\n */\ntype ErrorBoundaryProps =\n | VariantErrorBoundaryProps\n | CustomFallbackErrorBoundaryProps;\n\nfunction hasCustomFallback(\n props: ErrorBoundaryProps,\n): props is CustomFallbackErrorBoundaryProps {\n return \"fallbackRender\" in props;\n}\n\nfunction SilentFallback() {\n return null;\n}\n\n/**\n * Simple text-based fallback component.\n * Displays a centered message when an error occurs.\n */\nfunction TextFallback({\n message = \"Something went wrong\",\n}: {\n message?: string;\n}) {\n return <div className=\"text-center\">{message}</div>;\n}\n\n/**\n * Detailed fallback component showing full error information.\n * Displays error message with a collapsible details section.\n * Useful for development and debugging purposes.\n */\nfunction DetailedFallback({ error, resetErrorBoundary }: FallbackProps) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n const errorDetails =\n error instanceof Error\n ? (error.stack ?? String(error.cause))\n : JSON.stringify(error, null, 2);\n const hasDetails = errorDetails !== \"{}\";\n\n return (\n <div className=\"z-10 mx-auto flex max-w-[80%] flex-1 items-center justify-center p-6\">\n <div className=\"w-full max-w-lg rounded-lg border border-gray-500 bg-white p-6 shadow-sm\">\n <div className=\"mb-3 flex items-center gap-2\">\n <Icon name=\"Error\" className=\"size-5 shrink-0\" />\n <h1 className=\"text-lg font-semibold\">Something went wrong</h1>\n </div>\n <p className=\"mb-4 text-sm text-gray-700\">{errorMessage}</p>\n {hasDetails && (\n <details className=\"group\">\n <summary className=\"cursor-pointer text-sm font-medium text-gray-700 underline select-none hover:text-gray-700\">\n Show details\n </summary>\n <pre className=\"mt-2 max-h-48 overflow-auto rounded-sm bg-gray-100 p-3 text-xs\">\n {errorDetails}\n </pre>\n </details>\n )}\n <PowerhouseButton\n type=\"button\"\n onClick={resetErrorBoundary}\n className=\"mt-4 px-3 py-1.5 text-base font-medium\"\n >\n Try again\n </PowerhouseButton>\n </div>\n </div>\n );\n}\n\n/**\n * Centered error message fallback component.\n * Displays the error message in a centered, full-size container.\n * Suitable for use as a custom fallbackRender when you need simple error display.\n */\nfunction CenteredErrorMessage({ error }: FallbackProps) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n return (\n <div className=\"flex size-full items-center justify-center\">\n <h3 className=\"text-lg font-semibold\">{errorMessage}</h3>\n </div>\n );\n}\n\nfunction getFallbackComponent(\n variant: ErrorFallbackVariant,\n fallbackMessage?: string,\n): (props: FallbackProps) => ReactNode {\n switch (variant) {\n case \"silent\":\n return SilentFallback;\n case \"text\":\n return () => <TextFallback message={fallbackMessage} />;\n case \"detailed\":\n return DetailedFallback;\n default:\n return CenteredErrorMessage;\n }\n}\n\n/**\n * Unified error boundary component for catching and handling React errors.\n *\n * Built on top of `react-error-boundary`, this component provides:\n * - Automatic error logging with configurable context\n * - Multiple fallback UI variants (silent, text, detailed)\n * - Support for custom fallback render functions\n * - Reset capability via `resetKeys`\n *\n * @example\n * // Using a predefined variant\n * <ErrorBoundary variant=\"detailed\" loggerContext={[\"Connect\", \"Editor\"]}>\n * <EditorComponent />\n * </ErrorBoundary>\n *\n * @example\n * // Using a custom message with the text variant\n * <ErrorBoundary variant=\"text\" fallbackMessage=\"Failed to load drives\">\n * <DrivesList />\n * </ErrorBoundary>\n *\n * @example\n * // Using a custom fallback render\n * <ErrorBoundary\n * fallbackRender={CenteredErrorMessage}\n * onError={(error) => trackError(error)}\n * >\n * <MyComponent />\n * </ErrorBoundary>\n *\n * @example\n * // Silent mode for modals (renders null on error)\n * <ErrorBoundary variant=\"silent\" loggerContext={[\"Connect\", \"Modals\"]}>\n * <ModalContent />\n * </ErrorBoundary>\n */\nexport function ErrorBoundary(props: ErrorBoundaryProps) {\n const { children, onError, resetKeys, loggerContext } = props;\n\n const handleError = (error: Error, info: React.ErrorInfo) => {\n if (\n error.message.includes(\"Failed to fetch dynamically imported module\") &&\n error.message.includes(\"node_modules/.vite\")\n ) {\n console.error(error);\n console.log(\"Outdated chunk detected, reloading page...\");\n window.location.reload();\n return;\n }\n\n const contextLogger = loggerContext ? childLogger(loggerContext) : logger;\n contextLogger.error(\"@error @info\", error, info);\n onError?.(error, info);\n };\n\n const fallbackRender = hasCustomFallback(props)\n ? props.fallbackRender\n : getFallbackComponent(props.variant, props.fallbackMessage);\n\n return (\n <ReactErrorBoundary\n fallbackRender={fallbackRender}\n onError={handleError}\n resetKeys={resetKeys}\n >\n {children}\n </ReactErrorBoundary>\n );\n}\n\nexport { CenteredErrorMessage, DetailedFallback, TextFallback };\nexport type { FallbackProps };\n","import { DropZoneWrapper } from \"@powerhousedao/design-system/connect\";\nimport { GenericDriveExplorer } from \"@powerhousedao/powerhouse-vetra-packages/editors\";\nimport {\n useAppModuleById,\n useDefaultAppModule,\n useSelectedDocumentId,\n useSelectedDriveSafe,\n} from \"@powerhousedao/reactor-browser\";\nimport { Suspense } from \"react\";\nimport { DocumentEditorContainer } from \"./document-editor-container.js\";\nimport { EditorLoader } from \"./editor-loader.js\";\nimport { ErrorBoundary } from \"./error-boundary.js\";\n\nexport function AppContainer() {\n const [selectedDrive] = useSelectedDriveSafe();\n const selectedDocumentId = useSelectedDocumentId();\n\n const app = useAppModuleById(selectedDrive?.header.meta?.preferredEditor);\n const defaultApp = useDefaultAppModule();\n\n if (!selectedDrive) {\n return <EditorLoader />;\n }\n\n const AppComponent =\n app?.Component ?? defaultApp?.Component ?? GenericDriveExplorer.Component;\n\n if (!AppComponent) {\n throw new Error(\"No app component found\");\n }\n return (\n <ErrorBoundary\n variant=\"detailed\"\n resetKeys={[selectedDrive.header.id]}\n loggerContext={[\"Connect\", \"App\"]}\n >\n <Suspense fallback={<EditorLoader />}>\n <DropZoneWrapper className=\"flex h-full flex-col overflow-auto\">\n <AppComponent>\n {selectedDocumentId ? <DocumentEditorContainer /> : null}\n </AppComponent>\n </DropZoneWrapper>\n </Suspense>\n </ErrorBoundary>\n );\n}\n","export function getBasePath() {\n if (typeof document === \"undefined\") {\n return \"/\";\n }\n\n const baseEl = document.querySelector(\"base\");\n const href = baseEl?.getAttribute(\"href\");\n return href || \"/\";\n}\n","import type {\n Operation,\n PHDocument,\n} from \"@powerhousedao/shared/document-model\";\n\nexport class DocumentEditorDebugTools {\n private document: PHDocument | undefined;\n private operations: Operation[] = [];\n\n constructor(document?: PHDocument) {\n if (document) {\n this.document = document;\n }\n }\n\n private operationsToTableObject(operations: Operation[]) {\n return operations.map((op) => ({\n ...op,\n input: JSON.stringify(op.action.input),\n }));\n }\n\n public setDocument(document: PHDocument) {\n this.document = document;\n }\n\n public getDocument() {\n return this.document;\n }\n\n public getOperations() {\n return this.operations;\n }\n\n public pushOperation(operation: Operation) {\n this.operations.push(operation);\n }\n\n public operationsTable() {\n if (!this.document) {\n console.warn(\"No document\");\n }\n const ops = Object.values(this.document?.operations || {})\n .filter((array): array is Operation[] => array !== undefined)\n .flatMap((array) => array)\n .sort((a, b) => a.index - b.index);\n\n console.table(this.operationsToTableObject(ops));\n }\n\n public scopeOperationsTable(scope: string) {\n if (!this.document) {\n console.warn(\"No document\");\n }\n const ops = this.document?.operations[scope] || [];\n console.table(this.operationsToTableObject(ops));\n }\n\n public operationsLog() {\n console.log(this.operations);\n }\n\n public operationsLogTable() {\n console.table(this.operationsToTableObject(this.operations));\n }\n\n public clear() {\n this.operations = [];\n this.document = undefined;\n }\n}\n","export type MigrationPhase = \"clone\" | \"dump\" | \"restore\";\n\nexport type MigrationStatus = {\n idbName: string;\n phase: MigrationPhase;\n};\n\nlet current: MigrationStatus | null = null;\nconst listeners = new Set<() => void>();\n\nexport function setMigrationStatus(status: MigrationStatus | null): void {\n current = status;\n for (const l of listeners) l();\n}\n\nexport function getMigrationStatus(): MigrationStatus | null {\n return current;\n}\n\nexport function subscribeMigrationStatus(cb: () => void): () => void {\n listeners.add(cb);\n return () => {\n listeners.delete(cb);\n };\n}\n","import { PGlite } from \"@electric-sql/pglite\";\nimport {\n setMigrationStatus,\n type MigrationPhase,\n} from \"../components/migration-status.js\";\nimport {\n createFileDataStore,\n IDB_DB_VERSION,\n IDB_STORE_NAME,\n idbError,\n openIdb,\n PRIMARY_IDB_NAMES,\n readPgVersionFile,\n} from \"./pglite-idb.js\";\nimport { CURRENT_PG_MAJOR } from \"./pglite-runtime.js\";\n\nconst BACKUP_PREFIX = \"ph-pglite-backup::\";\nconst BACKUP_INDEX_KEY = \"ph:pglite-backups\";\nconst BACKUP_RETENTION_MS = 30 * 24 * 60 * 60 * 1000;\n\ntype FileDataValue = {\n contents: Uint8Array | number[];\n mode: number;\n timestamp: Date | number;\n};\n\ntype LegacyDumper = (idbName: string) => Promise<string>;\n\nconst LEGACY_DUMPERS: Partial<Record<number, () => Promise<LegacyDumper>>> = {\n 16: async () => {\n const [{ PGlite: LegacyPGlite }, { pgDump }] = await Promise.all([\n import(\"pglite-legacy-02\"),\n import(\"pglite-tools-legacy-02/pg_dump\"),\n ]);\n return async (idbName: string) => {\n const stripped = idbName.replace(/^\\/pglite\\//, \"\");\n const pg = new LegacyPGlite(`idb://${stripped}`);\n try {\n await pg.waitReady;\n const file = await pgDump({ pg });\n return await file.text();\n } finally {\n await pg.close();\n }\n };\n },\n};\n\n// Emscripten IDBFS holds the IDB connection open past pglite's pg.close(),\n// so deleteDatabase can be blocked indefinitely. Callers on the hot path\n// should prefer clearFileData() instead; deleteIdb is only used by the\n// janitor for expired backups, which tolerates the 15s timeout.\nfunction deleteIdb(name: string, timeoutMs = 15_000): Promise<void> {\n return new Promise((resolve, reject) => {\n const req = indexedDB.deleteDatabase(name);\n let settled = false;\n const done = (fn: () => void) => {\n if (settled) return;\n settled = true;\n fn();\n };\n const timer = setTimeout(\n () =>\n done(() =>\n reject(\n new Error(`IDB delete timed out for ${name} after ${timeoutMs}ms`),\n ),\n ),\n timeoutMs,\n );\n req.onsuccess = () =>\n done(() => {\n clearTimeout(timer);\n resolve();\n });\n req.onerror = () =>\n done(() => {\n clearTimeout(timer);\n reject(idbError(req, `IDB delete failed for ${name}`));\n });\n });\n}\n\nasync function clearFileData(name: string): Promise<void> {\n const db = await openIdb(name, IDB_DB_VERSION, createFileDataStore);\n try {\n await new Promise<void>((resolve, reject) => {\n const tx = db.transaction(IDB_STORE_NAME, \"readwrite\");\n tx.oncomplete = () => resolve();\n tx.onerror = () =>\n reject(idbError(tx, `FILE_DATA clear failed for ${name}`));\n tx.onabort = () =>\n reject(idbError(tx, `FILE_DATA clear aborted for ${name}`));\n tx.objectStore(IDB_STORE_NAME).clear();\n });\n } finally {\n db.close();\n }\n}\n\nasync function cloneFileData(\n sourceName: string,\n destName: string,\n): Promise<void> {\n const source = await openIdb(sourceName, IDB_DB_VERSION, createFileDataStore);\n try {\n const dest = await openIdb(destName, IDB_DB_VERSION, createFileDataStore);\n try {\n const readTx = source.transaction(IDB_STORE_NAME, \"readonly\");\n const readStore = readTx.objectStore(IDB_STORE_NAME);\n const entries = await new Promise<\n Array<{ key: IDBValidKey; value: FileDataValue }>\n >((resolve, reject) => {\n const out: Array<{ key: IDBValidKey; value: FileDataValue }> = [];\n const req = readStore.openCursor();\n req.onerror = () =>\n reject(\n idbError(req, `FILE_DATA read cursor failed for ${sourceName}`),\n );\n req.onsuccess = () => {\n const cursor = req.result;\n if (!cursor) return resolve(out);\n out.push({ key: cursor.key, value: cursor.value as FileDataValue });\n cursor.continue();\n };\n });\n\n await new Promise<void>((resolve, reject) => {\n const writeTx = dest.transaction(IDB_STORE_NAME, \"readwrite\");\n writeTx.oncomplete = () => resolve();\n writeTx.onerror = () =>\n reject(idbError(writeTx, `FILE_DATA write failed for ${destName}`));\n writeTx.onabort = () =>\n reject(idbError(writeTx, `FILE_DATA write aborted for ${destName}`));\n const writeStore = writeTx.objectStore(IDB_STORE_NAME);\n writeStore.clear();\n for (const { key, value } of entries) {\n writeStore.put(value, key);\n }\n });\n } finally {\n dest.close();\n }\n } finally {\n source.close();\n }\n}\n\ntype BackupRecord = { name: string; idbName: string; createdAt: number };\n\nfunction readBackupIndex(): BackupRecord[] {\n try {\n const raw = localStorage.getItem(BACKUP_INDEX_KEY);\n if (!raw) return [];\n const parsed: unknown = JSON.parse(raw);\n return Array.isArray(parsed) ? (parsed as BackupRecord[]) : [];\n } catch {\n return [];\n }\n}\n\nfunction writeBackupIndex(records: BackupRecord[]): void {\n try {\n localStorage.setItem(BACKUP_INDEX_KEY, JSON.stringify(records));\n } catch {\n // ignore quota errors — janitor is best-effort\n }\n}\n\nfunction registerBackup(rec: BackupRecord): void {\n writeBackupIndex([...readBackupIndex(), rec]);\n}\n\nfunction forgetBackup(name: string): void {\n writeBackupIndex(readBackupIndex().filter((r) => r.name !== name));\n}\n\nasync function janitor(): Promise<void> {\n const cutoff = Date.now() - BACKUP_RETENTION_MS;\n const keep: BackupRecord[] = [];\n for (const rec of readBackupIndex()) {\n if (rec.createdAt >= cutoff) {\n keep.push(rec);\n continue;\n }\n try {\n await deleteIdb(rec.name);\n } catch (err) {\n console.warn(`Failed to delete expired pglite backup ${rec.name}`, err);\n keep.push(rec);\n }\n }\n writeBackupIndex(keep);\n}\n\nfunction publishPhase(idbName: string, phase: MigrationPhase): void {\n setMigrationStatus({ idbName, phase });\n}\n\nasync function migrateIdbIfNeeded(idbName: string): Promise<void> {\n const major = await readPgVersionFile(idbName);\n if (major === null || major === CURRENT_PG_MAJOR) return;\n\n const loader = LEGACY_DUMPERS[major];\n if (!loader) {\n throw new Error(\n `Unsupported legacy PGlite data dir: PG_VERSION=${major} for ${idbName}`,\n );\n }\n\n const backupName = `${BACKUP_PREFIX}${idbName}::${new Date().toISOString()}`;\n const backupRec: BackupRecord = {\n name: backupName,\n idbName,\n createdAt: Date.now(),\n };\n\n publishPhase(idbName, \"clone\");\n await cloneFileData(idbName, backupName);\n registerBackup(backupRec);\n\n let sql: string;\n try {\n publishPhase(idbName, \"dump\");\n const dump = await loader();\n sql = await dump(idbName);\n } catch (err) {\n await deleteIdb(backupName).catch(() => {});\n forgetBackup(backupName);\n throw err;\n }\n\n try {\n // Can't deleteDatabase here: Emscripten IDBFS from the legacy PGlite\n // keeps its IDB connection open past pg.close(). Clearing the store\n // in-place leaves the IDB handle alone, and the fresh PGlite will\n // initdb into the empty VFS.\n await clearFileData(idbName);\n publishPhase(idbName, \"restore\");\n const stripped = idbName.replace(/^\\/pglite\\//, \"\");\n const pg = new PGlite(`idb://${stripped}`, { relaxedDurability: false });\n try {\n await pg.waitReady;\n // PGlite 0.2.x pg_dump emits SQL literals with doubled backslashes\n // (escape-string form) but does not always emit the matching\n // `SET standard_conforming_strings = off`. PG17 defaults that GUC to on,\n // so '\\\\\"' in the dump is parsed as a literal backslash + end-of-string\n // and JSONB re-parsing fails. Force off at the session level before\n // running the dump so doubled backslashes collapse as intended.\n console.info(\n `[pglite-migration] Dump preamble (first 500 chars):\\n${sql.slice(0, 500)}`,\n );\n try {\n await pg.exec(\"SET standard_conforming_strings = off;\");\n } catch (gucErr) {\n console.warn(\n \"[pglite-migration] Could not force standard_conforming_strings=off\",\n gucErr,\n );\n }\n try {\n await pg.exec(sql);\n } catch (execErr) {\n logRestoreFailure(idbName, sql, execErr);\n throw execErr;\n }\n } finally {\n await pg.close();\n }\n } catch (err) {\n await rollbackFromBackup(idbName, backupName, err);\n throw err;\n }\n}\n\nfunction logRestoreFailure(idbName: string, sql: string, err: unknown): void {\n const errObj = err as {\n message?: string;\n position?: string | number;\n severity?: string;\n code?: string;\n detail?: string;\n where?: string;\n internalQuery?: string;\n };\n const position =\n typeof errObj.position === \"string\"\n ? parseInt(errObj.position, 10)\n : typeof errObj.position === \"number\"\n ? errObj.position\n : NaN;\n\n console.error(`[pglite-migration] Restore failed for ${idbName}`, {\n message: errObj.message,\n code: errObj.code,\n severity: errObj.severity,\n detail: errObj.detail,\n where: errObj.where,\n position: errObj.position,\n sqlLength: sql.length,\n });\n\n if (Number.isFinite(position) && position > 0) {\n const zeroBased = position - 1;\n const start = Math.max(0, zeroBased - 200);\n const end = Math.min(sql.length, zeroBased + 200);\n const before = sql.slice(start, zeroBased);\n const at = sql.slice(zeroBased, zeroBased + 1);\n const after = sql.slice(zeroBased + 1, end);\n console.error(\n `[pglite-migration] SQL context around position ${position}:\\n${before}»${at}«${after}`,\n );\n const lineStart = sql.lastIndexOf(\"\\n\", zeroBased) + 1;\n const lineEnd = sql.indexOf(\"\\n\", zeroBased);\n const line = sql.slice(lineStart, lineEnd === -1 ? sql.length : lineEnd);\n console.error(\n `[pglite-migration] Failing line (truncated to 500 chars):\\n${line.slice(0, 500)}`,\n );\n } else {\n console.error(\n `[pglite-migration] No position info. First 2000 chars of dump:\\n${sql.slice(0, 2000)}`,\n );\n }\n}\n\nasync function rollbackFromBackup(\n idbName: string,\n backupName: string,\n originalError: unknown,\n): Promise<void> {\n try {\n await clearFileData(idbName).catch(() => {});\n await cloneFileData(backupName, idbName);\n } catch (rollbackErr) {\n console.error(\n `PGlite migration failed AND rollback failed for ${idbName}. Primary error:`,\n originalError,\n \"Rollback error:\",\n rollbackErr,\n );\n return;\n }\n await deleteIdb(backupName).catch(() => {});\n forgetBackup(backupName);\n}\n\nasync function migrateAllLocked(): Promise<void> {\n for (const idbName of PRIMARY_IDB_NAMES) {\n await migrateIdbIfNeeded(idbName);\n }\n setMigrationStatus(null);\n}\n\nexport async function migrateAllIfNeeded(): Promise<void> {\n janitor().catch((err) => console.warn(\"PGlite backup janitor failed\", err));\n\n const hasLocks =\n typeof navigator !== \"undefined\" &&\n \"locks\" in navigator &&\n typeof navigator.locks.request === \"function\";\n\n if (!hasLocks) {\n await migrateAllLocked();\n return;\n }\n\n await navigator.locks.request(\n \"ph-pglite-migration\",\n { mode: \"exclusive\" },\n async () => {\n await migrateAllLocked();\n },\n );\n}\n","import { getBasePath } from \"@powerhousedao/connect/utils\";\nimport { getIsEmbedded } from \"@powerhousedao/connect/hooks\";\nimport {\n AnimatedLoader,\n ConnectSidebar,\n HomeScreen,\n} from \"@powerhousedao/design-system/connect\";\nimport {\n useEffect,\n useState,\n useSyncExternalStore,\n type PropsWithChildren,\n} from \"react\";\nimport {\n getMigrationStatus,\n subscribeMigrationStatus,\n type MigrationPhase,\n} from \"./migration-status.js\";\nconst LOADER_DELAY = 250;\n\nconst PHASE_LABEL: Record<MigrationPhase, string> = {\n clone: \"Backing up local database…\",\n dump: \"Exporting data from previous version…\",\n restore: \"Restoring data into the new database…\",\n};\n\nconst MigrationOverlay = () => {\n const status = useSyncExternalStore(\n subscribeMigrationStatus,\n getMigrationStatus,\n () => null,\n );\n if (!status) return null;\n return (\n <div className=\"absolute inset-0 z-20 flex items-center justify-center\">\n <div className=\"rounded-lg bg-white/90 px-6 py-4 text-sm text-gray-900 shadow-lg\">\n <div className=\"font-medium\">Upgrading local database…</div>\n <div className=\"text-gray-600\">{PHASE_LABEL[status.phase]}</div>\n </div>\n </div>\n );\n};\n\nconst Loader = ({ delay = LOADER_DELAY }: { delay?: number }) => {\n const isSSR = typeof window === \"undefined\";\n const showInitialLoader =\n typeof document !== \"undefined\" &&\n document.body.getAttribute(\"data-show-loader\") === \"true\";\n\n const [showLoading, setShowLoading] = useState(!delay || showInitialLoader);\n\n useEffect(() => {\n const id = setTimeout(() => {\n setShowLoading(true);\n }, delay);\n\n return () => clearTimeout(id);\n }, []);\n\n return (\n <div\n className={`skeleton-loader absolute inset-0 z-10 flex items-center justify-center ${showLoading ? \"\" : \"hidden\"}`}\n >\n <div className=\"animate-pulse overflow-hidden rounded-full shadow-lg\">\n <AnimatedLoader />\n </div>\n {isSSR ? (\n <script\n dangerouslySetInnerHTML={{\n __html: `setTimeout(() => {\n document.querySelector('.skeleton-loader')?.classList.remove('hidden');\n document.body.setAttribute('data-show-loader', 'true');\n }, ${delay})`,\n }}\n />\n ) : null}\n </div>\n );\n};\n\nexport const AppSkeleton: React.FC<PropsWithChildren> = (props) => {\n const isSSR = typeof window === \"undefined\";\n const isHomeScreen = !isSSR && window.location.pathname === getBasePath();\n /* Match Root's behavior: when Connect is rendered inside an embed (e.g. the\n * vetra-studio BUILD iframe), suppress the sidebar during the Suspense\n * fallback so the loading state matches the loaded state. */\n const isEmbedded = !isSSR && getIsEmbedded();\n return (\n <div className=\"flex h-screen overflow-hidden\">\n {!isEmbedded && (\n <ConnectSidebar\n className=\"animate-pulse\"\n onLogin={undefined}\n onDisconnect={undefined}\n onClickSettings={undefined}\n address={undefined}\n />\n )}\n <HomeScreen\n containerClassName={\n isSSR || !isHomeScreen ? \"hidden home-screen\" : undefined\n }\n children={props.children ?? null}\n />\n {isSSR ? (\n <script\n dangerouslySetInnerHTML={{\n __html: `\n const baseEl = document.querySelector('base');\n const href = baseEl?.getAttribute('href');\n const basePath = href || '/';\n if (window.location.pathname === basePath) {\n document.querySelector('.home-screen')?.classList.remove('hidden')\n }`,\n }}\n />\n ) : null}\n {!props.children ? <Loader /> : null}\n <MigrationOverlay />\n </div>\n );\n};\n\nexport default AppSkeleton;\n","import {\n CURRENT_PG_MAJOR,\n getCachedReactorPgMajor,\n migrateAllIfNeeded,\n subscribeReactorPgMajor,\n} from \"@powerhousedao/connect/utils\";\nimport { useState, useSyncExternalStore } from \"react\";\n\nlet dismissed = false;\nconst listeners = new Set<() => void>();\n\nfunction notify() {\n for (const l of listeners) l();\n}\n\nfunction dismiss() {\n dismissed = true;\n notify();\n}\n\nfunction subscribeDismissed(cb: () => void): () => void {\n listeners.add(cb);\n return () => {\n listeners.delete(cb);\n };\n}\n\nfunction getDismissed(): boolean {\n return dismissed;\n}\n\nexport const MigrationBanner: React.FC = () => {\n const isDismissed = useSyncExternalStore(\n subscribeDismissed,\n getDismissed,\n () => false,\n );\n const major = useSyncExternalStore(\n subscribeReactorPgMajor,\n getCachedReactorPgMajor,\n () => undefined,\n );\n const [migrating, setMigrating] = useState(false);\n const [error, setError] = useState<string | null>(null);\n\n if (major === undefined || major === null || major === CURRENT_PG_MAJOR) {\n return null;\n }\n if (isDismissed) return null;\n\n const handleMigrate = () => {\n setError(null);\n setMigrating(true);\n migrateAllIfNeeded()\n .then(() => {\n window.location.reload();\n })\n .catch((err: unknown) => {\n setError(err instanceof Error ? err.message : String(err));\n setMigrating(false);\n });\n };\n\n return (\n <div className=\"absolute inset-x-0 top-0 z-30 flex justify-center p-3\">\n <div className=\"flex max-w-3xl items-center gap-3 rounded-lg border border-yellow-500 bg-yellow-400 px-4 py-3 text-sm text-gray-900 shadow-lg\">\n <div className=\"flex-1\">\n <div className=\"font-semibold\">\n Your local database uses Postgres {major}.\n </div>\n <div className=\"text-gray-800\">\n Migrate to Postgres {CURRENT_PG_MAJOR} to pick up the latest\n features. Your data will be backed up first.\n </div>\n {error && (\n <div className=\"mt-2 font-medium text-red-900\">\n Migration failed: {error}\n </div>\n )}\n </div>\n <button\n type=\"button\"\n disabled={migrating}\n onClick={handleMigrate}\n className=\"rounded-sm bg-gray-900 px-3 py-1 text-sm font-medium text-white hover:bg-gray-800 disabled:opacity-50\"\n >\n {migrating ? \"Migrating…\" : \"Migrate now\"}\n </button>\n <button\n type=\"button\"\n disabled={migrating}\n onClick={dismiss}\n className=\"rounded-sm border border-gray-900 bg-transparent px-3 py-1 text-sm font-medium text-gray-900 hover:bg-gray-900/10 disabled:opacity-50\"\n >\n Dismiss\n </button>\n </div>\n </div>\n );\n};\n","import { usePHModal } from \"@powerhousedao/reactor-browser\";\nimport { lazy, Suspense } from \"react\";\nimport { ErrorBoundary } from \"../error-boundary.js\";\n\nconst AddDriveModal = lazy(() =>\n import(\"./modals/AddDriveModal.js\").then((m) => ({\n default: m.AddDriveModal,\n })),\n);\nconst ClearStorageModal = lazy(() =>\n import(\"./modals/ClearStorageModal.js\").then((m) => ({\n default: m.ClearStorageModal,\n })),\n);\nconst CookiesPolicyModal = lazy(() =>\n import(\"./modals/CookiesPolicyModal.js\").then((m) => ({\n default: m.CookiesPolicyModal,\n })),\n);\nconst CreateDocumentModal = lazy(() =>\n import(\"./modals/CreateDocumentModal.js\").then((m) => ({\n default: m.CreateDocumentModal,\n })),\n);\nconst DebugSettingsModal = lazy(() =>\n import(\"./modals/DebugSettingsModal.js\").then((m) => ({\n default: m.DebugSettingsModal,\n })),\n);\nconst DeleteDriveModal = lazy(() =>\n import(\"./modals/DeleteDriveModal.js\").then((m) => ({\n default: m.DeleteDriveModal,\n })),\n);\nconst DeleteItemModal = lazy(() =>\n import(\"./modals/DeleteItemModal.js\").then((m) => ({\n default: m.DeleteItemModal,\n })),\n);\nconst DisclaimerModal = lazy(() =>\n import(\"./modals/DisclaimerModal.js\").then((m) => ({\n default: m.DisclaimerModal,\n })),\n);\nconst DriveSettingsModal = lazy(() =>\n import(\"./modals/DriveSettingsModal.js\").then((m) => ({\n default: m.DriveSettingsModal,\n })),\n);\nconst DownloadDocumentWithErrorsModal = lazy(() =>\n import(\"./modals/DownloadDocumentWithErrorsModal.js\").then((m) => ({\n default: m.DownloadDocumentWithErrorsModal,\n })),\n);\nconst SettingsModal = lazy(() =>\n import(\"./modals/SettingsModal.js\").then((m) => ({\n default: m.SettingsModal,\n })),\n);\nconst UpgradeDriveModal = lazy(() =>\n import(\"./modals/UpgradeDriveModal.js\").then((m) => ({\n default: m.UpgradeDriveModal,\n })),\n);\nconst InspectorModal = lazy(() =>\n import(\"./modals/InspectorModal/index.js\").then((m) => ({\n default: m.InspectorModal,\n })),\n);\nconst MissingPackageModal = lazy(() =>\n import(\"./modals/MissingPackageModal.js\").then((m) => ({\n default: m.ConnectMissingPackageModal,\n })),\n);\nconst modalComponents = {\n addDrive: AddDriveModal,\n clearStorage: ClearStorageModal,\n cookiesPolicy: CookiesPolicyModal,\n createDocument: CreateDocumentModal,\n debugSettings: DebugSettingsModal,\n deleteDrive: DeleteDriveModal,\n deleteItem: DeleteItemModal,\n disclaimer: DisclaimerModal,\n driveSettings: DriveSettingsModal,\n downloadDocumentWithErrors: DownloadDocumentWithErrorsModal,\n inspector: InspectorModal,\n settings: SettingsModal,\n upgradeDrive: UpgradeDriveModal,\n missingPackage: MissingPackageModal,\n} as const;\n\nexport const ModalsContainer = lazy(async () => {\n return {\n default: () => {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n const phModal = usePHModal();\n\n if (!phModal?.type) return null;\n\n const ModalComponent = modalComponents[phModal.type];\n\n return ModalComponent ? (\n <ErrorBoundary variant=\"silent\" loggerContext={[\"Connect\", \"Modals\"]}>\n <Suspense fallback={null}>\n <ModalComponent />\n </Suspense>\n </ErrorBoundary>\n ) : null;\n },\n };\n});\n","import \"@powerhousedao/connect/i18n\";\nimport type { DocumentModelLib } from \"document-model\";\nimport { lazy, StrictMode, Suspense } from \"react\";\nimport AppSkeleton from \"./app-skeleton.js\";\nimport { DetailedFallback, ErrorBoundary } from \"./error-boundary.js\";\nimport { App, CookieBanner } from \"./index.js\";\nimport { MigrationBanner } from \"./migration-banner.js\";\nimport { ModalsContainer } from \"./modal/modals-container.js\";\n\nexport const AppLoader = (props: { localPackage?: DocumentModelLib }) => {\n const Load = lazy(() =>\n import(\"./load.js\").then((m) => m.loadComponent(props.localPackage)),\n );\n return (\n <StrictMode>\n <ErrorBoundary\n fallbackRender={(props) => (\n <AppSkeleton children={<DetailedFallback {...props} />} />\n )}\n resetKeys={[props.localPackage]}\n loggerContext={[\"Connect\"]}\n >\n <Suspense fallback={<AppSkeleton />} name=\"AppLoader\">\n {/* eslint-disable-next-line react-hooks/static-components */}\n <Load {...props}>\n <App />\n </Load>\n </Suspense>\n <Suspense name=\"CookieBanner\">\n <CookieBanner />\n </Suspense>\n <Suspense name=\"ModalsContainer\">\n <ModalsContainer />\n </Suspense>\n <MigrationBanner />\n </ErrorBoundary>\n </StrictMode>\n );\n};\n","import { useInitSentry } from \"@powerhousedao/connect/hooks\";\n\ninterface SentryProviderProps {\n children?: React.ReactNode;\n}\n\nexport const SentryProvider: React.FC<SentryProviderProps> = ({ children }) => {\n useInitSentry();\n\n return children;\n};\n","import { Modal } from \"@powerhousedao/design-system\";\nimport {\n usePackageDiscoveryService,\n type FailedInstallation,\n type FailedInstallationReason,\n} from \"@powerhousedao/reactor-browser\";\nimport { useState } from \"react\";\nimport { twMerge } from \"tailwind-merge\";\nimport { useFailedInstallations } from \"../hooks/useFailedInstallations.js\";\n\nconst reasonLabels: Record<FailedInstallationReason, string> = {\n \"no-registry\": \"No package registry is configured.\",\n \"not-in-registry\": \"No matching package found in the registry.\",\n \"registry-error\": \"Couldn't reach the package registry.\",\n \"install-failed\": \"Package failed to install.\",\n dismissed: \"Installation was dismissed.\",\n};\n\nfunction canRetry(reason: FailedInstallationReason): boolean {\n return reason !== \"no-registry\";\n}\n\nexport function MissingModelBanner() {\n const failed = useFailedInstallations();\n const [open, setOpen] = useState(false);\n\n if (failed.length === 0) return null;\n\n return (\n <>\n <div className=\"flex items-center justify-between gap-3 bg-amber-100 px-4 py-2 text-sm text-amber-900\">\n <span>\n {failed.length === 1\n ? \"1 document type couldn't load (missing model).\"\n : `${failed.length} document types couldn't load (missing models).`}\n </span>\n <button\n type=\"button\"\n onClick={() => setOpen(true)}\n className=\"rounded-md border border-amber-300 bg-white px-3 py-1 text-amber-900 hover:bg-amber-50\"\n >\n View\n </button>\n </div>\n <MissingModelDetailsModal\n open={open}\n failed={failed}\n onClose={() => setOpen(false)}\n />\n </>\n );\n}\n\ntype DetailsProps = {\n readonly open: boolean;\n readonly failed: FailedInstallation[];\n readonly onClose: () => void;\n};\n\nfunction MissingModelDetailsModal(props: DetailsProps) {\n const { open, failed, onClose } = props;\n const discoveryService = usePackageDiscoveryService();\n const [retrying, setRetrying] = useState<Set<string>>(() => new Set());\n\n async function handleRetry(documentType: string) {\n if (!discoveryService) return;\n setRetrying((prev) => new Set(prev).add(documentType));\n try {\n await discoveryService.retryInstallation(documentType);\n } finally {\n setRetrying((prev) => {\n const next = new Set(prev);\n next.delete(documentType);\n return next;\n });\n }\n }\n\n return (\n <Modal\n open={open}\n onOpenChange={(isOpen) => {\n if (!isOpen) onClose();\n }}\n contentProps={{ className: \"rounded-3xl\" }}\n >\n <div className=\"w-[520px] max-w-[90vw] bg-white p-6\">\n <div className=\"border-b border-slate-100 pb-2 text-2xl font-bold text-gray-800\">\n Missing document models\n </div>\n <div className=\"my-4 text-sm text-gray-600\">\n The following document types couldn't be loaded. Documents using them\n won't display until the underlying package is installed.\n </div>\n {failed.length === 0 ? (\n <div className=\"rounded-xl bg-slate-50 p-4 text-sm text-gray-600\">\n No outstanding failures.\n </div>\n ) : (\n <div className=\"flex max-h-[60vh] flex-col gap-3 overflow-y-auto\">\n {failed.map((entry) => {\n const isRetrying = retrying.has(entry.documentType);\n const retryDisabled = !canRetry(entry.reason) || isRetrying;\n return (\n <div\n key={entry.documentType}\n className=\"rounded-xl bg-slate-50 p-4\"\n >\n <div className=\"mb-1 font-mono text-sm font-semibold text-gray-800\">\n {entry.documentType}\n </div>\n <div className=\"mb-2 text-xs text-gray-600\">\n {reasonLabels[entry.reason]}\n </div>\n {entry.packageNames.length > 0 ? (\n <div className=\"mb-2 text-xs text-gray-500\">\n Package{entry.packageNames.length > 1 ? \"s\" : \"\"}:{\" \"}\n {entry.packageNames.join(\", \")}\n </div>\n ) : null}\n {entry.error ? (\n <div className=\"mb-2 font-mono text-xs wrap-break-word text-red-700\">\n {entry.error.message}\n </div>\n ) : null}\n <div className=\"flex justify-end\">\n <button\n type=\"button\"\n onClick={() => void handleRetry(entry.documentType)}\n disabled={retryDisabled}\n title={\n canRetry(entry.reason)\n ? undefined\n : \"No registry is configured; nothing to retry against.\"\n }\n className={twMerge(\n \"min-h-[32px] rounded-xl px-3 py-1 text-sm font-semibold text-white transition-all hover:scale-105\",\n retryDisabled\n ? \"cursor-not-allowed bg-gray-300 hover:scale-100\"\n : \"bg-gray-800 active:opacity-75\",\n )}\n >\n {isRetrying ? \"Retrying...\" : \"Try install again\"}\n </button>\n </div>\n </div>\n );\n })}\n </div>\n )}\n <div className=\"mt-4 flex justify-end\">\n <button\n type=\"button\"\n onClick={onClose}\n className=\"min-h-[36px] rounded-xl border border-slate-200 bg-white px-4 py-2 text-sm font-semibold text-slate-800 hover:bg-slate-50\"\n >\n Close\n </button>\n </div>\n </div>\n </Modal>\n );\n}\n","import {\n PackageInstallModal,\n type PendingPackageInstallation,\n} from \"@powerhousedao/design-system/connect\";\nimport { usePackageDiscoveryService } from \"@powerhousedao/reactor-browser\";\nimport { usePendingInstallations } from \"../hooks/usePendingInstallations.js\";\n\nexport function PackageInstallPrompt() {\n const pendingInstallations = usePendingInstallations();\n const discoveryService = usePackageDiscoveryService();\n\n if (!discoveryService || pendingInstallations.length === 0) return null;\n\n const installations: PendingPackageInstallation[] =\n pendingInstallations.flatMap((p) =>\n p.packageNames.map((packageName) => ({\n documentType: p.documentType,\n packageName,\n })),\n );\n\n return (\n <PackageInstallModal\n pendingInstallations={installations}\n onInstall={(packageName) =>\n discoveryService.approveInstallation(packageName)\n }\n onDismiss={(packageName) =>\n discoveryService.dismissInstallation(packageName)\n }\n />\n );\n}\n","import {\n Analytics,\n OpenPanel,\n Router,\n} from \"@powerhousedao/connect/components\";\n\nimport { SentryProvider } from \"@powerhousedao/connect/context\";\nimport {\n DocumentEditorDebugTools,\n serviceWorkerManager,\n} from \"@powerhousedao/connect/utils\";\nimport { useEffect } from \"react\";\nimport { ToastContainer } from \"../services/toast.js\";\nimport { MissingModelBanner } from \"./missing-model-banner.js\";\nimport { PackageInstallPrompt } from \"./package-install-prompt.js\";\n\nexport const App = () => {\n // refresh page on vite preload error due to outdated chunks — but only when\n // the failing dynamic import is one of Connect's own chunks. External\n // dynamic imports (e.g. the package manager loading a package from the\n // configured CDN) should let the error propagate so the caller can surface\n // it; reloading here drops any open state and hides the real failure.\n useEffect(() => {\n const handlePreloadError = (event: Event) => {\n const payload = (event as Event & { payload?: unknown }).payload;\n const message =\n payload instanceof Error ? payload.message : String(payload ?? \"\");\n const failedUrl = message.match(/https?:\\/\\/[^\\s\"']+/)?.[0];\n\n if (failedUrl && !failedUrl.startsWith(window.location.origin)) {\n console.debug(\n `[Connect] Skipping reload — vite:preloadError for off-origin URL: ${failedUrl}`,\n );\n return;\n }\n\n console.log(\"Outdated chunks detected, reloading page...\");\n window.location.reload();\n };\n\n window.addEventListener(\"vite:preloadError\", handlePreloadError);\n\n return () => {\n window.removeEventListener(\"vite:preloadError\", handlePreloadError);\n };\n }, []);\n\n useEffect(() => {\n if (import.meta.env.MODE === \"development\") {\n window.documentEditorDebugTools = new DocumentEditorDebugTools();\n } else {\n serviceWorkerManager.registerServiceWorker(false);\n }\n }, []);\n\n return (\n <SentryProvider>\n <ToastContainer position=\"bottom-right\" />\n <MissingModelBanner />\n <Router />\n <PackageInstallPrompt />\n <Analytics />\n <OpenPanel />\n </SentryProvider>\n );\n};\n","import {\n useAcceptedCookies,\n useCookieBanner,\n} from \"@powerhousedao/connect/hooks\";\nimport type { CookieInput } from \"@powerhousedao/design-system/connect\";\nimport { CookieBanner as PHCookieBanner } from \"@powerhousedao/design-system/connect\";\nimport { showPHModal } from \"@powerhousedao/reactor-browser\";\nimport { Trans, useTranslation } from \"react-i18next\";\nimport { i18n } from \"@powerhousedao/connect/i18n\";\n\nconst isCookieAccepted = (cookies: CookieInput[], id: string) => {\n return cookies.some((cookie) => cookie.id === id && cookie.value);\n};\n\nexport const CookieBanner = () => {\n const { t } = useTranslation(undefined, {\n useSuspense: true,\n i18n,\n });\n const [showBanner, setShowBanner] = useCookieBanner();\n const [, setAcceptedCookies] = useAcceptedCookies();\n\n const cookiesInput: CookieInput[] = [\n {\n id: \"analytics-cookie\",\n label: t(\"cookieBanner.cookies.analytics\"),\n value: true,\n },\n ];\n\n const handleAccept = (cookies: CookieInput[]) => {\n setShowBanner(false);\n\n if (isCookieAccepted(cookies, \"analytics-cookie\")) {\n setAcceptedCookies((acceptedCookies) => ({\n ...acceptedCookies,\n analytics: true,\n }));\n }\n };\n\n const handleReject = () => {\n setShowBanner(false);\n setAcceptedCookies(() => ({\n analytics: false,\n functional: false,\n marketing: false,\n }));\n };\n\n if (!showBanner) {\n return null;\n }\n\n return (\n <div className=\"absolute inset-0 z-10000 backdrop-blur-sm\">\n <div className=\"absolute inset-0 bg-black opacity-15\" />\n <div className=\"absolute inset-x-0 bottom-0 flex justify-center bg-white px-10 pt-10 pb-16 shadow-lg\">\n <PHCookieBanner\n className=\"max-w-[1024px]\"\n cookies={cookiesInput}\n onSubmit={handleAccept}\n onReject={handleReject}\n submitLabel={t(\"cookieBanner.accept\")}\n rejectLabel={t(\"cookieBanner.reject\")}\n >\n <p className=\"font-semibold text-gray-500\">\n <Trans\n key={\"cookieBanner.message\"}\n i18nKey=\"cookieBanner.message\"\n components={{\n a: (\n <a\n onClick={() => showPHModal({ type: \"cookiesPolicy\" })}\n key={\"cookieBanner.message-link\"}\n className=\"cursor-pointer text-gray-900 hover:underline\"\n />\n ),\n }}\n />\n </p>\n </PHCookieBanner>\n </div>\n </div>\n );\n};\n","import { Icon } from \"@powerhousedao/design-system\";\nimport { driveCollectionId, useSyncList } from \"@powerhousedao/reactor-browser\";\nimport type { DocumentDriveDocument } from \"@powerhousedao/shared/document-drive\";\nimport { useMemo } from \"react\";\n\nexport function DriveIcon({\n drive,\n}: {\n drive: DocumentDriveDocument | undefined;\n}) {\n const remotes = useSyncList();\n const isRemoteDrive = useMemo(() => {\n if (!drive) return false;\n\n return remotes.some(\n (remote) =>\n remote.collectionId === driveCollectionId(\"main\", drive.header.id),\n );\n }, [remotes, drive]);\n\n const driveIconSrc = drive?.state.global.icon;\n\n if (driveIconSrc) {\n return (\n <img src={driveIconSrc} alt={drive.header.name} height={32} width={32} />\n );\n }\n\n if (!isRemoteDrive) {\n return <Icon name=\"Hdd\" size={32} />;\n }\n\n return <Icon name=\"Server\" size={32} />;\n}\n","import { EditorLoader } from \"@powerhousedao/connect/components\";\nimport { useUndoRedoShortcuts } from \"@powerhousedao/connect/hooks\";\nimport { toast } from \"@powerhousedao/connect/services\";\nimport { RevisionHistory } from \"@powerhousedao/design-system/connect\";\nimport {\n getRevisionFromDate,\n setRevisionHistoryVisible,\n showPHModal,\n useDocumentById,\n useDocumentModelModuleById,\n useDocumentOperations,\n useEditorModuleById,\n useFallbackEditorModule,\n useRevisionHistoryVisible,\n useSelectedTimelineItem,\n useVetraPackageManager,\n useVetraPackages,\n} from \"@powerhousedao/reactor-browser\";\nimport type { PHDocument } from \"@powerhousedao/shared/document-model\";\nimport { redo, undo } from \"@powerhousedao/shared/document-model\";\nimport { Suspense, useEffect, useState } from \"react\";\nimport { CenteredErrorMessage, ErrorBoundary } from \"./error-boundary.js\";\n\ntype Props<TDocument extends PHDocument = PHDocument> = {\n document: TDocument;\n};\n\nfunction EditorError({ message }: { message: React.ReactNode }) {\n return (\n <div className=\"flex size-full items-center justify-center\">\n <h3 className=\"text-lg font-semibold\">{message}</h3>\n </div>\n );\n}\n\nexport const DocumentEditor: React.FC<Props> = (props) => {\n const { document: initialDocument } = props;\n const selectedTimelineItem = useSelectedTimelineItem();\n const revisionHistoryVisible = useRevisionHistoryVisible();\n const [document, dispatch] = useDocumentById(initialDocument.header.id);\n const documentId = document?.header.id ?? undefined;\n const documentName = document?.header.name ?? undefined;\n const documentType = document?.header.documentType ?? undefined;\n const preferredEditor = document?.header.meta?.preferredEditor ?? undefined;\n const {\n globalOperations,\n localOperations,\n isLoading: isLoadingOperations,\n refetch: refetchOperations,\n } = useDocumentOperations(documentId);\n\n // Refetch operations when revision history panel opens\n useEffect(() => {\n if (revisionHistoryVisible) {\n void refetchOperations();\n }\n }, [revisionHistoryVisible, refetchOperations]);\n\n const globalRevisionNumber = document?.header.revision.global ?? 0;\n const localRevisionNumber = document?.header.revision.local ?? 0;\n const documentModelModule = useDocumentModelModuleById(documentType);\n const preferredEditorModule = useEditorModuleById(preferredEditor);\n const fallbackEditorModule = useFallbackEditorModule(documentType);\n const editorModule = preferredEditorModule ?? fallbackEditorModule;\n const vetraPackages = useVetraPackages();\n const packageManager = useVetraPackageManager();\n const owningPackageName = editorModule\n ? vetraPackages.find((pkg) => pkg.editors.includes(editorModule))?.manifest\n .name\n : undefined;\n const owningPackageVersion =\n owningPackageName && packageManager\n ? packageManager.getPackageVersion(owningPackageName)\n : undefined;\n const editorBundleKey = owningPackageName\n ? `${owningPackageName}@${owningPackageVersion ?? \"unknown\"}`\n : (editorModule?.config.id ?? \"no-editor\");\n const isLoadingDocument = !document;\n const isLoadingEditor =\n editorModule &&\n documentType &&\n !editorModule.documentTypes.includes(documentType) &&\n !editorModule.documentTypes.includes(\"*\");\n\n const canUndo = globalRevisionNumber > 0 || localRevisionNumber > 0;\n const canRedo = !!document?.clipboard.length;\n const addUndoAction = () => dispatch(undo());\n const addRedoAction = () => dispatch(redo());\n useUndoRedoShortcuts({\n undo: addUndoAction,\n redo: addRedoAction,\n canUndo,\n canRedo,\n });\n\n useEffect(() => {\n return () => {\n window.documentEditorDebugTools?.clear();\n };\n }, []);\n\n const [editorError, setEditorError] = useState<\n | {\n error: any;\n info: React.ErrorInfo;\n documentId?: string;\n // clear: () => void;\n }\n | undefined\n >(undefined);\n\n useEffect(() => {\n if (editorError && editorError.documentId !== documentId) {\n // eslint-disable-next-line react-hooks/set-state-in-effect\n setEditorError(undefined);\n }\n }, [editorError, documentId]);\n\n const handleEditorError = (error: Error, info: React.ErrorInfo) => {\n setEditorError({\n error,\n documentId,\n info,\n });\n };\n\n if (isLoadingEditor) {\n return <EditorLoader message=\"Loading editor\" />;\n }\n\n if (isLoadingDocument) {\n return <EditorLoader message=\"Loading document\" />;\n }\n\n if (!documentModelModule) {\n return (\n <EditorError\n message={\n <div className=\"text-center leading-10\">\n <p>\n Unable to open the document because the document model \"\n {documentType}\" is not supported.\n </p>\n <p>\n Go to the{\" \"}\n <button\n type=\"button\"\n className=\"cursor-pointer underline\"\n onClick={() => {\n showPHModal({ type: \"settings\" });\n }}\n >\n package manager\n </button>{\" \"}\n to install this document model\n </p>\n </div>\n }\n />\n );\n }\n\n if (!editorModule) {\n return (\n <EditorError\n message={\n <div className=\"text-center leading-10\">\n <p>Unable to open the document because no editor has been found</p>\n <p>\n Go to the{\" \"}\n <button\n type=\"button\"\n className=\"cursor-pointer underline\"\n onClick={() => {\n showPHModal({ type: \"settings\" });\n }}\n >\n package manager\n </button>{\" \"}\n an editor for the \"${documentType}\" document type\n </p>\n </div>\n }\n />\n );\n }\n const EditorComponent = editorModule.Component;\n\n return (\n <div\n className=\"relative h-full\"\n id=\"document-editor-context\"\n data-editor={editorModule.config.id}\n data-document-type={documentType}\n >\n {revisionHistoryVisible ? (\n isLoadingOperations ? (\n <EditorLoader message=\"Loading operations\" />\n ) : (\n <RevisionHistory\n key={documentId}\n documentTitle={documentName ?? \"\"}\n documentId={documentId ?? \"\"}\n globalOperations={globalOperations}\n localOperations={localOperations}\n onClose={() => setRevisionHistoryVisible(false)}\n documentState={document.state}\n onCopyState={() => {\n toast(\"Copied document state to clipboard\", { type: \"success\" });\n }}\n onCopyDocId={() => {\n toast(\"Copied document ID to clipboard\", { type: \"success\" });\n }}\n />\n )\n ) : (\n <Suspense\n fallback={<EditorLoader message=\"Loading editor\" />}\n name=\"EditorLoader\"\n >\n <ErrorBoundary\n fallbackRender={CenteredErrorMessage}\n resetKeys={[documentId]}\n onError={handleEditorError}\n loggerContext={[\"Connect\", \"DocumentEditor\"]}\n >\n {!editorError?.error && (\n <EditorComponent\n key={`${editorBundleKey}:${documentId}`}\n context={{\n readMode: !!selectedTimelineItem,\n selectedTimelineRevision: getRevisionFromDate(\n selectedTimelineItem?.startDate,\n selectedTimelineItem?.endDate,\n globalOperations,\n ),\n }}\n documentId={document.header.id}\n />\n )}\n </ErrorBoundary>\n </Suspense>\n )}\n </div>\n );\n};\n","import { Sidebar } from \"@powerhousedao/connect/components\";\nimport { useIsEmbedded } from \"@powerhousedao/connect/hooks\";\nimport { Suspense } from \"react\";\nimport { Outlet } from \"react-router-dom\";\n\nexport function Root() {\n const isEmbedded = useIsEmbedded();\n return (\n <div className=\"h-screen\">\n <div\n className={`flex h-screen items-stretch overflow-auto`}\n role=\"presentation\"\n tabIndex={0}\n >\n <Suspense name=\"Root\">\n {!isEmbedded && <Sidebar />}\n <div className=\"relative flex-1 overflow-auto\">\n <Outlet />\n </div>\n </Suspense>\n </div>\n </div>\n );\n}\n","import { AppContainer, DriveIcon } from \"@powerhousedao/connect/components\";\nimport {\n connectConfig,\n defaultPHAppConfig,\n defaultPHDocumentEditorConfig,\n} from \"@powerhousedao/connect/config\";\nimport {\n HomeScreen,\n HomeScreenAddDriveItem,\n HomeScreenItem,\n} from \"@powerhousedao/design-system/connect\";\nimport {\n setPHAppConfig,\n setPHDocumentEditorConfig,\n setSelectedDrive,\n useAppModuleById,\n useDrives,\n useSelectedDocumentId,\n useSelectedDriveSafe,\n useSelectedFolder,\n} from \"@powerhousedao/reactor-browser\";\nimport type { DocumentDriveDocument } from \"@powerhousedao/shared/document-drive\";\nimport { useEffect } from \"react\";\n\nexport function Content() {\n const [selectedDrive] = useSelectedDriveSafe();\n const selectedFolder = useSelectedFolder();\n const selectedDocumentId = useSelectedDocumentId();\n\n useEffect(() => {\n if (!selectedDocumentId) {\n setPHDocumentEditorConfig(defaultPHDocumentEditorConfig);\n }\n }, [selectedDocumentId]);\n\n useEffect(() => {\n if (!selectedDrive) {\n setPHAppConfig(defaultPHAppConfig);\n }\n }, [selectedDrive]);\n\n const showHomeScreen =\n !selectedDocumentId && !selectedDrive && !selectedFolder;\n return (\n <ContentContainer>\n {showHomeScreen ? <HomeScreenContainer /> : <AppContainer />}\n </ContentContainer>\n );\n}\n\nfunction ContentContainer({ children }: { children: React.ReactNode }) {\n return (\n <div className=\"flex h-full flex-col overflow-auto\" id=\"content-view\">\n {children}\n </div>\n );\n}\n\nfunction DriveItem({ drive }: { drive: DocumentDriveDocument }) {\n const editorModule = useAppModuleById(drive.header.meta?.preferredEditor);\n const description = editorModule?.config.name || \"Drive Explorer App\";\n return (\n <HomeScreenItem\n key={drive.header.id}\n title={drive.state.global.name || drive.header.name}\n description={description}\n icon={<DriveIcon drive={drive} />}\n onClick={() => setSelectedDrive(drive)}\n />\n );\n}\n\nfunction HomeScreenContainer() {\n const drives = useDrives();\n const config = connectConfig;\n return (\n <HomeScreen>\n {drives?.map((drive) => {\n return <DriveItem key={drive.header.id} drive={drive} />;\n })}\n {config.drives.addDriveEnabled && <HomeScreenAddDriveItem />}\n </HomeScreen>\n );\n}\n","import { Root } from \"@powerhousedao/connect/components\";\nimport { connectConfig } from \"@powerhousedao/connect/config\";\nimport { Content } from \"@powerhousedao/connect/pages\";\nimport { Suspense } from \"react\";\nimport type { RouteObject } from \"react-router-dom\";\nimport { RouterProvider, createBrowserRouter } from \"react-router-dom\";\n\nfunction createRouter(routes: RouteObject[]) {\n const routerBasename = connectConfig.routerBasename;\n\n return createBrowserRouter(routes, {\n basename: routerBasename,\n future: {\n v7_fetcherPersist: true,\n v7_relativeSplatPath: true,\n },\n });\n}\n\nfunction createRoutes() {\n const routes: RouteObject[] = [\n {\n index: true,\n path: \"d?/:driveId?/*?\",\n element: (\n <Suspense name=\"Drive\">\n <Content />\n </Suspense>\n ),\n },\n ];\n\n return [\n {\n element: (\n <Suspense name=\"RouteRoot\">\n <Root />\n </Suspense>\n ),\n children: routes,\n },\n ];\n}\n\nconst routes = createRoutes();\nconst router = createRouter(routes);\n\nexport const Router = () => {\n return <RouterProvider router={router} />;\n};\n","import { DriveIcon } from \"@powerhousedao/connect/components\";\nimport { connectConfig } from \"@powerhousedao/connect/config\";\nimport {\n ConnectSidebar,\n ConnectTooltipProvider,\n SidebarAddDriveItem,\n SidebarItem,\n useEns,\n} from \"@powerhousedao/design-system/connect\";\n\nimport {\n logout,\n openRenown,\n setSelectedDrive,\n showPHModal,\n useDrives,\n useSelectedDriveSafe,\n useUser,\n} from \"@powerhousedao/reactor-browser\";\nimport { ErrorBoundary } from \"./error-boundary.js\";\n\nexport function Sidebar() {\n const user = useUser();\n const drives = useDrives();\n const [selectedDrive] = useSelectedDriveSafe();\n const connectDebug = localStorage.getItem(\"CONNECT_DEBUG\") === \"true\";\n\n const ensName = user?.ens?.name || user?.profile?.username || undefined;\n const avatarUrl =\n user?.ens?.avatarUrl || user?.profile?.userImage || undefined;\n\n const ensInfo = useEns(!avatarUrl ? user?.address : undefined);\n\n const onClickSettings = () => {\n showPHModal({ type: \"settings\" });\n };\n\n const onAddDriveClick = () => {\n showPHModal({ type: \"addDrive\" });\n };\n\n const etherscanUrl = user?.address\n ? `https://etherscan.io/address/${user.address}`\n : \"\";\n\n return (\n <ConnectTooltipProvider>\n <ConnectSidebar\n id=\"sidebar\"\n onClick={() => setSelectedDrive(undefined)}\n onClickSettings={onClickSettings}\n address={user?.address}\n onLogin={openRenown}\n onDisconnect={logout}\n ensName={ensName || ensInfo.data?.ens}\n avatarUrl={\n avatarUrl ||\n ensInfo.data?.avatar_small ||\n ensInfo.data?.avatar_url ||\n undefined\n }\n etherscanUrl={etherscanUrl}\n showDebug={connectDebug}\n onDebugClick={() => showPHModal({ type: \"debugSettings\" })}\n >\n <ErrorBoundary\n variant=\"text\"\n fallbackMessage=\"There was an error loading drives\"\n loggerContext={[\"Connect\", \"Sidebar\"]}\n >\n {drives?.map((drive, index) => (\n <SidebarItem\n key={index}\n title={drive.header.name}\n onClick={() => setSelectedDrive(drive)}\n active={selectedDrive?.header.id === drive.header.id}\n icon={<DriveIcon drive={drive} />}\n />\n ))}\n {connectConfig.drives.addDriveEnabled && (\n <SidebarAddDriveItem onClick={onAddDriveClick} />\n )}\n </ErrorBoundary>\n </ConnectSidebar>\n </ConnectTooltipProvider>\n );\n}\n"],"names":["listeners","getInitial","subscribe","rawEvents","listeners","emptyArray","logger","logger","ErrorBoundary","ReactErrorBoundary","ErrorBoundary","listeners","AddDriveModal","CreateDocumentModal","DriveSettingsModal","SettingsModal","ErrorBoundary","ErrorBoundary","CookieBanner","CookieBanner","PHCookieBanner","ErrorBoundary","ErrorBoundary"],"mappings":"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","debug_id":"9ec07267-610c-5785-aa26-92ef6dc6c948"}
|
package/dist/start-connect.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
|
|
2
2
|
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="90a535c1-da95-5660-8193-15e0e8a0dba6")}catch(e){}}();
|
|
3
|
-
import { t as AppLoader } from "./sidebar-
|
|
3
|
+
import { t as AppLoader } from "./sidebar-CZLMU1VL.js";
|
|
4
4
|
import { createRoot } from "react-dom/client";
|
|
5
5
|
import { jsx } from "react/jsx-runtime";
|
|
6
6
|
//#region start-connect.tsx
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@powerhousedao/connect",
|
|
3
3
|
"productName": "Powerhouse-Connect",
|
|
4
|
-
"version": "6.1.0-dev.
|
|
4
|
+
"version": "6.1.0-dev.9",
|
|
5
5
|
"description": "Powerhouse Connect",
|
|
6
6
|
"main": "dist/index.html",
|
|
7
7
|
"type": "module",
|
|
@@ -68,14 +68,14 @@
|
|
|
68
68
|
"tailwind-merge": "3.4.0",
|
|
69
69
|
"usehooks-ts": "^3.1.1",
|
|
70
70
|
"zod": "4.3.6",
|
|
71
|
-
"@powerhousedao/config": "6.1.0-dev.
|
|
72
|
-
"@powerhousedao/design-system": "6.1.0-dev.
|
|
73
|
-
"@powerhousedao/
|
|
74
|
-
"@powerhousedao/reactor-browser": "6.1.0-dev.
|
|
75
|
-
"@powerhousedao/
|
|
76
|
-
"@powerhousedao/vetra": "6.1.0-dev.
|
|
77
|
-
"@renown/sdk": "6.1.0-dev.
|
|
78
|
-
"document-model": "6.1.0-dev.
|
|
71
|
+
"@powerhousedao/config": "6.1.0-dev.9",
|
|
72
|
+
"@powerhousedao/design-system": "6.1.0-dev.9",
|
|
73
|
+
"@powerhousedao/powerhouse-vetra-packages": "6.1.0-dev.9",
|
|
74
|
+
"@powerhousedao/reactor-browser": "6.1.0-dev.9",
|
|
75
|
+
"@powerhousedao/shared": "6.1.0-dev.9",
|
|
76
|
+
"@powerhousedao/vetra": "6.1.0-dev.9",
|
|
77
|
+
"@renown/sdk": "6.1.0-dev.9",
|
|
78
|
+
"document-model": "6.1.0-dev.9"
|
|
79
79
|
},
|
|
80
80
|
"devDependencies": {
|
|
81
81
|
"@tailwindcss/cli": "4.2.2",
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"package-BrFYj3Kr.js","sources":["../package.json"],"sourcesContent":[""],"names":[],"mappings":"","debug_id":"9b9bb8c0-bf07-5fa3-b396-78034cedff19"}
|