|
1 | | -import { EditorContext } from "@/components/providers/editor-context-provider"; |
2 | | -import { PlatformEnum } from "@/lib/enums"; |
3 | | -import { useCallback, useContext, useEffect, useState } from "react"; |
| 1 | +import { useEffect, useState } from "react"; |
4 | 2 | import { AbstractPlatformAPI } from "../platform-api/abstract-platform-api"; |
5 | | -import { CloudAPI } from "../platform-api/cloud/cloud-api"; |
6 | | -import { ElectronAPI } from "../platform-api/electron/electron-api"; |
7 | | -import { getPlatform } from "../platform-api/platform-checker"; |
| 3 | +import { getAbstractPlatformAPI } from "../platform-api/get-platform-api"; |
8 | 4 | import { useWorkspace } from "./use-workspace"; |
9 | 5 |
|
10 | 6 | export function usePlatformApi() { |
11 | | - const editorContext = useContext(EditorContext); |
12 | | - |
13 | 7 | const { workspace } = useWorkspace(); |
14 | 8 |
|
15 | 9 | const [platformApi, setPlatformApi] = useState< |
16 | 10 | AbstractPlatformAPI | undefined |
17 | 11 | >(undefined); |
18 | 12 |
|
19 | | - const refreshWorkspaceContent = useCallback(async () => { |
20 | | - if (!workspace) { |
21 | | - // Reset all content |
22 | | - editorContext?.setEditorStates((prev) => { |
23 | | - return { |
24 | | - ...prev, |
25 | | - workspaceContent: undefined, |
26 | | - explorerSelectedNodeRefs: [], |
27 | | - }; |
28 | | - }); |
29 | | - return; |
30 | | - } |
31 | | - |
32 | | - const api = getAbstractPlatformAPI(); |
33 | | - |
34 | | - const projectUri = |
35 | | - editorContext?.persistSettings?.projectHomePath + |
36 | | - "/" + |
37 | | - editorContext?.editorStates.project; |
38 | | - const objects = await api?.listPathContent(projectUri, { |
39 | | - include: "all", |
40 | | - isRecursive: true, |
41 | | - }); |
42 | | - |
43 | | - editorContext?.setEditorStates((prev) => { |
44 | | - return { |
45 | | - ...prev, |
46 | | - workspaceContent: objects, |
47 | | - explorerSelectedNodeRefs: [], |
48 | | - }; |
49 | | - }); |
50 | | - |
51 | | - console.log("Found project content:", objects); |
52 | | - }, [ |
53 | | - workspace, |
54 | | - editorContext?.persistSettings?.projectHomePath, |
55 | | - editorContext?.editorStates.project, |
56 | | - ]); |
57 | | - |
58 | 13 | useEffect(() => { |
59 | | - const api = getAbstractPlatformAPI(); |
| 14 | + const api = getAbstractPlatformAPI(workspace); |
60 | 15 | setPlatformApi(api); |
61 | 16 | }, []); |
62 | 17 |
|
63 | | - // When workspace changes, reset platform API if needed |
| 18 | + // When workspace changes, update platform API if needed. |
| 19 | + // So the platform api switch to the latest workspace context. |
64 | 20 | useEffect(() => { |
65 | | - if (platformApi && workspace) { |
66 | | - const api = getAbstractPlatformAPI(); |
| 21 | + if (workspace) { |
| 22 | + const api = getAbstractPlatformAPI(workspace); |
67 | 23 | setPlatformApi(api); |
68 | 24 | } |
69 | 25 | }, [workspace]); |
70 | 26 |
|
71 | | - // When workspace changes, re-fetch content |
72 | | - useEffect(() => { |
73 | | - refreshWorkspaceContent(); |
74 | | - }, [refreshWorkspaceContent]); |
75 | | - |
76 | | - function getAbstractPlatformAPI(): AbstractPlatformAPI { |
77 | | - const platform = getPlatform(); |
78 | | - |
79 | | - if (platform === PlatformEnum.Capacitor) { |
80 | | - // return new CapacitorAPI(); |
81 | | - return new CloudAPI(workspace); |
82 | | - } else if (platform === PlatformEnum.Electron) { |
83 | | - return new ElectronAPI(); |
84 | | - } else if ( |
85 | | - platform === PlatformEnum.Web || |
86 | | - platform === PlatformEnum.WebMobile |
87 | | - ) { |
88 | | - return new CloudAPI(workspace); |
89 | | - } else if (platform === PlatformEnum.VSCode) { |
90 | | - // platformApi.current = new VSCodeAPI(); |
91 | | - throw new Error("VSCode API not implemented"); |
92 | | - } else { |
93 | | - throw new Error("Unknown platform"); |
94 | | - } |
95 | | - } |
96 | | - |
97 | 27 | return { |
98 | 28 | platformApi, |
99 | | - refreshWorkspaceContent, |
100 | 29 | }; |
101 | 30 | } |
0 commit comments