@zhin.js/client 1.0.3 → 1.0.5

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.
Files changed (94) hide show
  1. package/README.md +117 -3
  2. package/{src → client}/index.ts +0 -1
  3. package/{src → client}/store/index.ts +22 -1
  4. package/client/store/reducers/config.ts +135 -0
  5. package/{src → client}/store/reducers/index.ts +4 -1
  6. package/client/websocket/hooks.ts +280 -0
  7. package/client/websocket/index.ts +48 -0
  8. package/client/websocket/instance.ts +46 -0
  9. package/client/websocket/manager.ts +412 -0
  10. package/client/websocket/messageHandler.ts +166 -0
  11. package/client/websocket/types.ts +208 -0
  12. package/dist/index.d.ts +8 -0
  13. package/dist/index.d.ts.map +1 -0
  14. package/dist/index.js +0 -1
  15. package/dist/index.js.map +1 -0
  16. package/dist/router/index.d.ts +25 -0
  17. package/dist/router/index.d.ts.map +1 -0
  18. package/dist/router/index.js +49 -0
  19. package/dist/router/index.js.map +1 -0
  20. package/dist/store/index.d.ts +19 -0
  21. package/dist/store/index.d.ts.map +1 -0
  22. package/dist/store/index.js +67 -0
  23. package/dist/store/index.js.map +1 -0
  24. package/dist/store/reducers/config.d.ts +54 -0
  25. package/dist/store/reducers/config.d.ts.map +1 -0
  26. package/dist/store/reducers/config.js +78 -0
  27. package/dist/store/reducers/config.js.map +1 -0
  28. package/dist/store/reducers/index.d.ts +13 -0
  29. package/dist/store/reducers/index.d.ts.map +1 -0
  30. package/dist/store/reducers/index.js +11 -0
  31. package/dist/store/reducers/index.js.map +1 -0
  32. package/dist/store/reducers/route.d.ts +37 -0
  33. package/dist/store/reducers/route.d.ts.map +1 -0
  34. package/dist/store/reducers/route.js +85 -0
  35. package/dist/store/reducers/route.js.map +1 -0
  36. package/dist/store/reducers/script.d.ts +17 -0
  37. package/dist/store/reducers/script.d.ts.map +1 -0
  38. package/dist/store/reducers/script.js +74 -0
  39. package/dist/store/reducers/script.js.map +1 -0
  40. package/dist/store/reducers/ui.d.ts +14 -0
  41. package/dist/store/reducers/ui.d.ts.map +1 -0
  42. package/dist/store/reducers/ui.js +23 -0
  43. package/dist/store/reducers/ui.js.map +1 -0
  44. package/dist/types.d.ts +7 -0
  45. package/dist/types.d.ts.map +1 -0
  46. package/dist/types.js +2 -0
  47. package/dist/types.js.map +1 -0
  48. package/dist/websocket/hooks.d.ts +55 -0
  49. package/dist/websocket/hooks.d.ts.map +1 -0
  50. package/dist/websocket/hooks.js +225 -0
  51. package/dist/websocket/hooks.js.map +1 -0
  52. package/dist/websocket/index.d.ts +13 -0
  53. package/dist/websocket/index.d.ts.map +1 -0
  54. package/dist/websocket/index.js +31 -0
  55. package/dist/websocket/index.js.map +1 -0
  56. package/dist/websocket/instance.d.ts +18 -0
  57. package/dist/websocket/instance.d.ts.map +1 -0
  58. package/dist/websocket/instance.js +39 -0
  59. package/dist/websocket/instance.js.map +1 -0
  60. package/dist/websocket/manager.d.ts +110 -0
  61. package/dist/websocket/manager.d.ts.map +1 -0
  62. package/dist/websocket/manager.js +341 -0
  63. package/dist/websocket/manager.js.map +1 -0
  64. package/dist/websocket/messageHandler.d.ts +48 -0
  65. package/dist/websocket/messageHandler.d.ts.map +1 -0
  66. package/dist/websocket/messageHandler.js +140 -0
  67. package/dist/websocket/messageHandler.js.map +1 -0
  68. package/dist/websocket/types.d.ts +125 -0
  69. package/dist/websocket/types.d.ts.map +1 -0
  70. package/dist/websocket/types.js +43 -0
  71. package/dist/websocket/types.js.map +1 -0
  72. package/package.json +8 -18
  73. package/app/index.html +0 -13
  74. package/app/postcss.config.js +0 -5
  75. package/app/src/components/ThemeToggle.tsx +0 -21
  76. package/app/src/hooks/useTheme.ts +0 -17
  77. package/app/src/layouts/dashboard.tsx +0 -259
  78. package/app/src/main.tsx +0 -121
  79. package/app/src/pages/dashboard-bots.tsx +0 -198
  80. package/app/src/pages/dashboard-home.tsx +0 -301
  81. package/app/src/pages/dashboard-logs.tsx +0 -298
  82. package/app/src/pages/dashboard-plugin-detail.tsx +0 -349
  83. package/app/src/pages/dashboard-plugins.tsx +0 -166
  84. package/app/src/style.css +0 -1105
  85. package/app/src/theme/index.ts +0 -92
  86. package/app/tailwind.config.js +0 -70
  87. package/app/tsconfig.json +0 -16
  88. package/src/websocket/index.ts +0 -193
  89. package/src/websocket/useWebSocket.ts +0 -42
  90. /package/{src → client}/router/index.tsx +0 -0
  91. /package/{src → client}/store/reducers/route.ts +0 -0
  92. /package/{src → client}/store/reducers/script.ts +0 -0
  93. /package/{src → client}/store/reducers/ui.ts +0 -0
  94. /package/{src → client}/types.ts +0 -0
@@ -0,0 +1,85 @@
1
+ import { createSlice } from "@reduxjs/toolkit";
2
+ const initialState = {
3
+ routes: []
4
+ };
5
+ // 辅助函数:查找最佳父路由
6
+ const findBestParent = (routes, fullPath) => {
7
+ const segments = fullPath.split('/').filter(Boolean);
8
+ for (let i = segments.length - 1; i > 0; i--) {
9
+ const parentPath = '/' + segments.slice(0, i).join('/');
10
+ const parent = routes.find(r => r.path === parentPath);
11
+ if (parent)
12
+ return parent;
13
+ }
14
+ return routes.find(r => r.path === '/') || null;
15
+ };
16
+ // 辅助函数:计算相对路径
17
+ const calculateRelativePath = (parentPath, fullPath) => {
18
+ if (parentPath === '/')
19
+ return fullPath;
20
+ return fullPath.replace(parentPath + '/', '');
21
+ };
22
+ export const routeSlice = createSlice({
23
+ name: 'route',
24
+ initialState,
25
+ reducers: {
26
+ addRoute: (state, action) => {
27
+ const route = action.payload;
28
+ const parent = findBestParent(state.routes, route.path);
29
+ if (parent) {
30
+ if (!parent.children)
31
+ parent.children = [];
32
+ const relativePath = calculateRelativePath(parent.path, route.path);
33
+ parent.children.push({ ...route, path: relativePath });
34
+ }
35
+ else {
36
+ state.routes.push(route);
37
+ }
38
+ state.routes.sort((a, b) => (a.meta?.order || 999) - (b.meta?.order || 999));
39
+ },
40
+ removeRoute: (state, action) => {
41
+ const path = action.payload;
42
+ const removeFromArray = (routes) => {
43
+ const index = routes.findIndex(r => r.path === path);
44
+ if (index >= 0) {
45
+ routes.splice(index, 1);
46
+ return true;
47
+ }
48
+ for (const route of routes) {
49
+ if (route.children && removeFromArray(route.children)) {
50
+ return true;
51
+ }
52
+ }
53
+ return false;
54
+ };
55
+ removeFromArray(state.routes);
56
+ },
57
+ updateRoute: (state, action) => {
58
+ const { path, updates } = action.payload;
59
+ const updateInArray = (routes) => {
60
+ const index = routes.findIndex(r => r.path === path);
61
+ if (index >= 0) {
62
+ routes[index] = { ...routes[index], ...updates };
63
+ return true;
64
+ }
65
+ for (const route of routes) {
66
+ if (route.children && updateInArray(route.children)) {
67
+ return true;
68
+ }
69
+ }
70
+ return false;
71
+ };
72
+ updateInArray(state.routes);
73
+ },
74
+ setRoutes: (state, action) => {
75
+ state.routes = action.payload;
76
+ state.routes.sort((a, b) => (a.meta?.order || 999) - (b.meta?.order || 999));
77
+ },
78
+ clearRoutes: (state) => {
79
+ state.routes = [];
80
+ }
81
+ }
82
+ });
83
+ export const { addRoute, removeRoute, updateRoute, setRoutes, clearRoutes } = routeSlice.actions;
84
+ export default routeSlice.reducer;
85
+ //# sourceMappingURL=route.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"route.js","sourceRoot":"","sources":["../../../client/store/reducers/route.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ import { PayloadAction } from "@reduxjs/toolkit";
2
+ export interface ScriptState {
3
+ entries: string[];
4
+ loadedScripts: string[];
5
+ }
6
+ export declare const loadScript: import("@reduxjs/toolkit").AsyncThunk<string, string, import("@reduxjs/toolkit").AsyncThunkConfig>;
7
+ export declare const loadScripts: import("@reduxjs/toolkit").AsyncThunk<string[], string[], import("@reduxjs/toolkit").AsyncThunkConfig>;
8
+ export declare const unloadScript: import("@reduxjs/toolkit").AsyncThunk<string, string, import("@reduxjs/toolkit").AsyncThunkConfig>;
9
+ export declare const scriptSlice: import("@reduxjs/toolkit").Slice<ScriptState, {
10
+ syncEntries: (state: import("@reduxjs/toolkit").WritableDraft<ScriptState>, action: PayloadAction<string[]>) => void;
11
+ addEntry: (state: import("@reduxjs/toolkit").WritableDraft<ScriptState>, action: PayloadAction<string>) => void;
12
+ removeEntry: (state: import("@reduxjs/toolkit").WritableDraft<ScriptState>, action: PayloadAction<string>) => void;
13
+ }, "script", "script", import("@reduxjs/toolkit").SliceSelectors<ScriptState>>;
14
+ export declare const syncEntries: import("@reduxjs/toolkit").ActionCreatorWithPayload<string[], "script/syncEntries">, addEntry: import("@reduxjs/toolkit").ActionCreatorWithPayload<string, "script/addEntry">, removeEntry: import("@reduxjs/toolkit").ActionCreatorWithPayload<string, "script/removeEntry">;
15
+ declare const _default: import("@reduxjs/toolkit").Reducer<ScriptState>;
16
+ export default _default;
17
+ //# sourceMappingURL=script.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"script.d.ts","sourceRoot":"","sources":["../../../client/store/reducers/script.ts"],"names":[],"mappings":"AAAA,OAAO,EAAe,aAAa,EAAoB,MAAM,kBAAkB,CAAA;AAE/E,MAAM,WAAW,WAAW;IACxB,OAAO,EAAE,MAAM,EAAE,CAAA;IACjB,aAAa,EAAE,MAAM,EAAE,CAAA;CAC1B;AAQD,eAAO,MAAM,UAAU,oGAkBtB,CAAA;AAGD,eAAO,MAAM,WAAW,wGAWvB,CAAA;AAGD,eAAO,MAAM,YAAY,oGAOxB,CAAA;AAED,eAAO,MAAM,WAAW;wFAIa,aAAa,CAAC,MAAM,EAAE,CAAC;qFAI1B,aAAa,CAAC,MAAM,CAAC;wFAMlB,aAAa,CAAC,MAAM,CAAC;8EA2BxD,CAAA;AAEF,eAAO,MAAQ,WAAW,uFAAE,QAAQ,kFAAE,WAAW,mFAAwB,CAAA;;AACzE,wBAAkC"}
@@ -0,0 +1,74 @@
1
+ import { createSlice, createAsyncThunk } from "@reduxjs/toolkit";
2
+ const initialState = {
3
+ entries: [],
4
+ loadedScripts: []
5
+ };
6
+ // AsyncThunk: 加载单个脚本
7
+ export const loadScript = createAsyncThunk('script/loadScript', async (src) => {
8
+ return new Promise((resolve, reject) => {
9
+ const script = document.createElement('script');
10
+ script.type = 'module';
11
+ script.src = src;
12
+ script.dataset.dynamicEntry = 'true';
13
+ script.onload = () => resolve(src);
14
+ script.onerror = (error) => {
15
+ console.error('[Script] Load failed:', src);
16
+ reject(error);
17
+ };
18
+ document.body.appendChild(script);
19
+ });
20
+ });
21
+ // AsyncThunk: 批量加载脚本
22
+ export const loadScripts = createAsyncThunk('script/loadScripts', async (entries, { dispatch }) => {
23
+ const results = await Promise.allSettled(entries.map(entry => dispatch(loadScript(entry)).unwrap()));
24
+ return results
25
+ .filter((r) => r.status === 'fulfilled')
26
+ .map(r => r.value);
27
+ });
28
+ // AsyncThunk: 卸载脚本
29
+ export const unloadScript = createAsyncThunk('script/unloadScript', async (src) => {
30
+ const scripts = document.querySelectorAll(`script[src="${src}"][data-dynamic-entry="true"]`);
31
+ scripts.forEach(script => script.remove());
32
+ return src;
33
+ });
34
+ export const scriptSlice = createSlice({
35
+ name: 'script',
36
+ initialState,
37
+ reducers: {
38
+ syncEntries: (state, action) => {
39
+ state.entries = action.payload;
40
+ },
41
+ addEntry: (state, action) => {
42
+ if (!state.entries.includes(action.payload)) {
43
+ state.entries.push(action.payload);
44
+ }
45
+ },
46
+ removeEntry: (state, action) => {
47
+ state.entries = state.entries.filter(e => e !== action.payload);
48
+ state.loadedScripts = state.loadedScripts.filter(s => s !== action.payload);
49
+ }
50
+ },
51
+ extraReducers: (builder) => {
52
+ // loadScript 成功
53
+ builder.addCase(loadScript.fulfilled, (state, action) => {
54
+ if (!state.loadedScripts.includes(action.payload)) {
55
+ state.loadedScripts.push(action.payload);
56
+ }
57
+ });
58
+ // loadScripts 成功
59
+ builder.addCase(loadScripts.fulfilled, (state, action) => {
60
+ action.payload.forEach(src => {
61
+ if (!state.loadedScripts.includes(src)) {
62
+ state.loadedScripts.push(src);
63
+ }
64
+ });
65
+ });
66
+ // unloadScript 成功
67
+ builder.addCase(unloadScript.fulfilled, (state, action) => {
68
+ state.loadedScripts = state.loadedScripts.filter(s => s !== action.payload);
69
+ });
70
+ }
71
+ });
72
+ export const { syncEntries, addEntry, removeEntry } = scriptSlice.actions;
73
+ export default scriptSlice.reducer;
74
+ //# sourceMappingURL=script.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"script.js","sourceRoot":"","sources":["../../../client/store/reducers/script.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,14 @@
1
+ import { PayloadAction } from "@reduxjs/toolkit";
2
+ export interface UIState {
3
+ sidebarOpen: boolean;
4
+ activeMenu: string;
5
+ }
6
+ export declare const uiSlice: import("@reduxjs/toolkit").Slice<UIState, {
7
+ toggleSidebar: (state: import("@reduxjs/toolkit").WritableDraft<UIState>) => void;
8
+ setSidebarOpen: (state: import("@reduxjs/toolkit").WritableDraft<UIState>, action: PayloadAction<boolean>) => void;
9
+ setActiveMenu: (state: import("@reduxjs/toolkit").WritableDraft<UIState>, action: PayloadAction<string>) => void;
10
+ }, "ui", "ui", import("@reduxjs/toolkit").SliceSelectors<UIState>>;
11
+ export declare const toggleSidebar: import("@reduxjs/toolkit").ActionCreatorWithoutPayload<"ui/toggleSidebar">, setSidebarOpen: import("@reduxjs/toolkit").ActionCreatorWithPayload<boolean, "ui/setSidebarOpen">, setActiveMenu: import("@reduxjs/toolkit").ActionCreatorWithPayload<string, "ui/setActiveMenu">;
12
+ declare const _default: import("@reduxjs/toolkit").Reducer<UIState>;
13
+ export default _default;
14
+ //# sourceMappingURL=ui.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ui.d.ts","sourceRoot":"","sources":["../../../client/store/reducers/ui.ts"],"names":[],"mappings":"AAAA,OAAO,EAAe,aAAa,EAAE,MAAM,kBAAkB,CAAA;AAE7D,MAAM,WAAW,OAAO;IACpB,WAAW,EAAE,OAAO,CAAA;IACpB,UAAU,EAAE,MAAM,CAAA;CACrB;AAOD,eAAO,MAAM,OAAO;;uFAOoB,aAAa,CAAC,OAAO,CAAC;sFAGvB,aAAa,CAAC,MAAM,CAAC;kEAI1D,CAAA;AAEF,eAAO,MAAQ,aAAa,8EAAE,cAAc,qFAAE,aAAa,iFAAoB,CAAA;;AAC/E,wBAA8B"}
@@ -0,0 +1,23 @@
1
+ import { createSlice } from "@reduxjs/toolkit";
2
+ const initialState = {
3
+ sidebarOpen: true,
4
+ activeMenu: 'home'
5
+ };
6
+ export const uiSlice = createSlice({
7
+ name: 'ui',
8
+ initialState,
9
+ reducers: {
10
+ toggleSidebar: (state) => {
11
+ state.sidebarOpen = !state.sidebarOpen;
12
+ },
13
+ setSidebarOpen: (state, action) => {
14
+ state.sidebarOpen = action.payload;
15
+ },
16
+ setActiveMenu: (state, action) => {
17
+ state.activeMenu = action.payload;
18
+ }
19
+ }
20
+ });
21
+ export const { toggleSidebar, setSidebarOpen, setActiveMenu } = uiSlice.actions;
22
+ export default uiSlice.reducer;
23
+ //# sourceMappingURL=ui.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ui.js","sourceRoot":"","sources":["../../../client/store/reducers/ui.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAiB,MAAM,kBAAkB,CAAA;AAO7D,MAAM,YAAY,GAAY;IAC1B,WAAW,EAAE,IAAI;IACjB,UAAU,EAAE,MAAM;CACrB,CAAA;AAED,MAAM,CAAC,MAAM,OAAO,GAAG,WAAW,CAAC;IAC/B,IAAI,EAAE,IAAI;IACV,YAAY;IACZ,QAAQ,EAAE;QACN,aAAa,EAAE,CAAC,KAAK,EAAE,EAAE;YACrB,KAAK,CAAC,WAAW,GAAG,CAAC,KAAK,CAAC,WAAW,CAAA;QAC1C,CAAC;QACD,cAAc,EAAE,CAAC,KAAK,EAAE,MAA8B,EAAE,EAAE;YACtD,KAAK,CAAC,WAAW,GAAG,MAAM,CAAC,OAAO,CAAA;QACtC,CAAC;QACD,aAAa,EAAE,CAAC,KAAK,EAAE,MAA6B,EAAE,EAAE;YACpD,KAAK,CAAC,UAAU,GAAG,MAAM,CAAC,OAAO,CAAA;QACrC,CAAC;KACJ;CACJ,CAAC,CAAA;AAEF,MAAM,CAAC,MAAM,EAAE,aAAa,EAAE,cAAc,EAAE,aAAa,EAAE,GAAG,OAAO,CAAC,OAAO,CAAA;AAC/E,eAAe,OAAO,CAAC,OAAO,CAAA"}
@@ -0,0 +1,7 @@
1
+ export interface MessageSegment {
2
+ type: 'text' | 'image' | 'at' | 'face' | 'video' | 'audio' | 'file' | 'reply';
3
+ data: Record<string, any>;
4
+ }
5
+ export type MessageElement = MessageSegment;
6
+ export type SendContent = MessageSegment | MessageSegment[] | string;
7
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../client/types.ts"],"names":[],"mappings":"AACA,MAAM,WAAW,cAAc;IAC7B,IAAI,EAAE,MAAM,GAAG,OAAO,GAAG,IAAI,GAAG,MAAM,GAAG,OAAO,GAAG,OAAO,GAAG,MAAM,GAAG,OAAO,CAAA;IAC7E,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;CAC1B;AAGD,MAAM,MAAM,cAAc,GAAG,cAAc,CAAA;AAG3C,MAAM,MAAM,WAAW,GAAG,cAAc,GAAG,cAAc,EAAE,GAAG,MAAM,CAAA"}
package/dist/types.js ADDED
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../client/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,55 @@
1
+ /**
2
+ * WebSocket React Hooks
3
+ * 提供在 React 组件中使用 WebSocket 功能的便捷接口
4
+ */
5
+ import type { UseConfigOptions, UseWebSocketOptions, ConnectionState } from './types';
6
+ /**
7
+ * WebSocket 连接状态和基础功能 Hook
8
+ */
9
+ export declare function useWebSocket(options?: UseWebSocketOptions): {
10
+ connected: boolean;
11
+ entries: any;
12
+ loadedScripts: any;
13
+ connect: () => void;
14
+ disconnect: () => void;
15
+ send: (message: any) => void;
16
+ sendRequest: <T = any>(message: any) => Promise<T>;
17
+ isConnected: () => boolean;
18
+ getState: () => "disconnected" | "connected";
19
+ manager: import("./manager").WebSocketManager;
20
+ };
21
+ /**
22
+ * 插件配置管理 Hook
23
+ */
24
+ export declare function useConfig(pluginName: string, options?: UseConfigOptions): {
25
+ config: any;
26
+ schema: any;
27
+ loading: boolean;
28
+ error: string | null;
29
+ connected: boolean;
30
+ getConfig: () => Promise<any>;
31
+ setConfig: (newConfig: any) => Promise<void>;
32
+ getSchema: () => Promise<any>;
33
+ reload: () => Promise<void>;
34
+ };
35
+ /**
36
+ * 所有配置管理 Hook
37
+ */
38
+ export declare function useAllConfigs(): {
39
+ configs: Record<string, any>;
40
+ schemas: Record<string, any>;
41
+ connected: boolean;
42
+ refreshAll: () => Promise<{
43
+ configs: any;
44
+ schemas: any;
45
+ }>;
46
+ };
47
+ /**
48
+ * WebSocket 连接状态监听 Hook
49
+ */
50
+ export declare function useWebSocketState(): ConnectionState;
51
+ /**
52
+ * WebSocket 消息监听 Hook
53
+ */
54
+ export declare function useWebSocketMessages<T = any>(filter?: (message: any) => boolean, handler?: (message: T) => void): T[];
55
+ //# sourceMappingURL=hooks.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hooks.d.ts","sourceRoot":"","sources":["../../client/websocket/hooks.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAiBH,OAAO,KAAK,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,eAAe,EAAE,MAAM,SAAS,CAAA;AAMrF;;GAEG;AACH,wBAAgB,YAAY,CAAC,OAAO,GAAE,mBAAwB;;;;;;oBAoBzB,GAAG;kBAIC,CAAC,iBAAiB,GAAG,KAAG,OAAO,CAAC,CAAC,CAAC;;;;EAuC1E;AAMD;;GAEG;AACH,wBAAgB,SAAS,CAAC,UAAU,EAAE,MAAM,EAAE,OAAO,GAAE,gBAAqB;;;;;;;2BA+B1B,GAAG;;;EAmEpD;AAMD;;GAEG;AACH,wBAAgB,aAAa;;;;;;;;EA2B5B;AAMD;;GAEG;AACH,wBAAgB,iBAAiB,oBAiBhC;AAED;;GAEG;AACH,wBAAgB,oBAAoB,CAAC,CAAC,GAAG,GAAG,EAC1C,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,KAAK,OAAO,EAClC,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,KAAK,IAAI,OAW/B"}
@@ -0,0 +1,225 @@
1
+ /**
2
+ * WebSocket React Hooks
3
+ * 提供在 React 组件中使用 WebSocket 功能的便捷接口
4
+ */
5
+ import { useCallback, useEffect, useMemo, useState } from 'react';
6
+ import { useSelector, useDispatch, selectConfig, selectSchema, selectConfigLoading, selectConfigError, selectConfigConnected, selectAllConfigs, selectAllSchemas, setLoading, setError } from '../store';
7
+ import { getWebSocketManager } from './instance';
8
+ // ============================================================================
9
+ // WebSocket 连接 Hook
10
+ // ============================================================================
11
+ /**
12
+ * WebSocket 连接状态和基础功能 Hook
13
+ */
14
+ export function useWebSocket(options = {}) {
15
+ const { autoConnect = true } = options;
16
+ const wsManager = getWebSocketManager();
17
+ // 从 Redux 获取状态
18
+ const connected = useSelector(selectConfigConnected);
19
+ const entries = useSelector((state) => state.script?.entries || []);
20
+ const loadedScripts = useSelector((state) => state.script?.loadedScripts || []);
21
+ // 连接控制
22
+ const connect = useCallback(() => {
23
+ wsManager.connect();
24
+ }, [wsManager]);
25
+ const disconnect = useCallback(() => {
26
+ wsManager.disconnect();
27
+ }, [wsManager]);
28
+ // 消息发送
29
+ const send = useCallback((message) => {
30
+ wsManager.send(message);
31
+ }, [wsManager]);
32
+ const sendRequest = useCallback(async (message) => {
33
+ // 临时使用旧方法,后续完善
34
+ return wsManager.sendRequest(message);
35
+ }, [wsManager]);
36
+ // 状态查询
37
+ const isConnected = useCallback(() => {
38
+ return wsManager.isConnected();
39
+ }, [wsManager]);
40
+ const getState = useCallback(() => {
41
+ // 临时返回连接状态,后续完善
42
+ return wsManager.isConnected() ? 'connected' : 'disconnected';
43
+ }, [wsManager]);
44
+ // 自动连接
45
+ useEffect(() => {
46
+ if (autoConnect && !connected) {
47
+ connect();
48
+ }
49
+ }, [autoConnect, connected, connect]);
50
+ return {
51
+ // 状态
52
+ connected,
53
+ entries,
54
+ loadedScripts,
55
+ // 方法
56
+ connect,
57
+ disconnect,
58
+ send,
59
+ sendRequest,
60
+ isConnected,
61
+ getState,
62
+ // WebSocket 实例(高级用法)
63
+ manager: wsManager
64
+ };
65
+ }
66
+ // ============================================================================
67
+ // 配置管理 Hook
68
+ // ============================================================================
69
+ /**
70
+ * 插件配置管理 Hook
71
+ */
72
+ export function useConfig(pluginName, options = {}) {
73
+ const { autoLoad = true, autoLoadSchema = true } = options;
74
+ const dispatch = useDispatch();
75
+ const wsManager = getWebSocketManager();
76
+ // 状态选择器
77
+ const config = useSelector((state) => selectConfig(state, pluginName));
78
+ const schema = useSelector((state) => selectSchema(state, pluginName));
79
+ const loading = useSelector((state) => selectConfigLoading(state, pluginName));
80
+ const error = useSelector((state) => selectConfigError(state, pluginName));
81
+ const connected = useSelector(selectConfigConnected);
82
+ // 配置操作
83
+ const getConfig = useCallback(async () => {
84
+ dispatch(setLoading({ pluginName, loading: true }));
85
+ dispatch(setError({ pluginName, error: null }));
86
+ try {
87
+ const result = await wsManager.getConfig(pluginName);
88
+ return result;
89
+ }
90
+ catch (error) {
91
+ console.log('getConfig', error);
92
+ const errorMessage = error instanceof Error ? error.message : 'Unknown error';
93
+ dispatch(setError({ pluginName, error: errorMessage }));
94
+ throw error;
95
+ }
96
+ finally {
97
+ dispatch(setLoading({ pluginName, loading: false }));
98
+ }
99
+ }, [pluginName, wsManager, dispatch]);
100
+ const setConfig = useCallback(async (newConfig) => {
101
+ dispatch(setLoading({ pluginName, loading: true }));
102
+ dispatch(setError({ pluginName, error: null }));
103
+ try {
104
+ await wsManager.setConfig(pluginName, newConfig);
105
+ }
106
+ catch (error) {
107
+ console.log('setConfig', error);
108
+ const errorMessage = error instanceof Error ? error.message : 'Unknown error';
109
+ dispatch(setError({ pluginName, error: errorMessage }));
110
+ throw error;
111
+ }
112
+ finally {
113
+ dispatch(setLoading({ pluginName, loading: false }));
114
+ }
115
+ }, [pluginName, wsManager, dispatch]);
116
+ const getSchema = useCallback(async () => {
117
+ try {
118
+ return await wsManager.getSchema(pluginName);
119
+ }
120
+ catch (error) {
121
+ console.error(`Failed to get schema for plugin ${pluginName}:`, error);
122
+ throw error;
123
+ }
124
+ }, [pluginName, wsManager]);
125
+ // 重新加载配置和 Schema
126
+ const reload = useCallback(async () => {
127
+ const promises = [];
128
+ if (autoLoad) {
129
+ promises.push(getConfig());
130
+ }
131
+ if (autoLoadSchema) {
132
+ promises.push(getSchema());
133
+ }
134
+ await Promise.all(promises);
135
+ }, [autoLoad, autoLoadSchema, getConfig, getSchema]);
136
+ // 自动加载
137
+ useEffect(() => {
138
+ if (connected && autoLoad && !config && !loading) {
139
+ getConfig().catch(console.error);
140
+ }
141
+ }, [connected, autoLoad, config, loading, getConfig]);
142
+ useEffect(() => {
143
+ if (connected && autoLoadSchema && !schema) {
144
+ getSchema().catch(console.error);
145
+ }
146
+ }, [connected, autoLoadSchema, schema, getSchema]);
147
+ return useMemo(() => ({
148
+ // 状态
149
+ config,
150
+ schema,
151
+ loading,
152
+ error,
153
+ connected,
154
+ // 方法
155
+ getConfig,
156
+ setConfig,
157
+ getSchema,
158
+ reload
159
+ }), [config, schema, loading, error, connected, getConfig, setConfig, getSchema, reload]);
160
+ }
161
+ // ============================================================================
162
+ // 批量配置管理 Hook
163
+ // ============================================================================
164
+ /**
165
+ * 所有配置管理 Hook
166
+ */
167
+ export function useAllConfigs() {
168
+ const wsManager = getWebSocketManager();
169
+ const allConfigs = useSelector(selectAllConfigs);
170
+ const allSchemas = useSelector(selectAllSchemas);
171
+ const connected = useSelector(selectConfigConnected);
172
+ const refreshAll = useCallback(async () => {
173
+ try {
174
+ const [configs, schemas] = await Promise.all([
175
+ wsManager.getAllConfigs(),
176
+ wsManager.getAllSchemas()
177
+ ]);
178
+ return { configs, schemas };
179
+ }
180
+ catch (error) {
181
+ console.error('Failed to refresh all configs:', error);
182
+ throw error;
183
+ }
184
+ }, [wsManager]);
185
+ return useMemo(() => ({
186
+ configs: allConfigs,
187
+ schemas: allSchemas,
188
+ connected,
189
+ refreshAll
190
+ }), [allConfigs, allSchemas, connected, refreshAll]);
191
+ }
192
+ // ============================================================================
193
+ // 高级 Hook
194
+ // ============================================================================
195
+ /**
196
+ * WebSocket 连接状态监听 Hook
197
+ */
198
+ export function useWebSocketState() {
199
+ const wsManager = getWebSocketManager();
200
+ const [state, setState] = useState(wsManager.getState());
201
+ useEffect(() => {
202
+ const checkState = () => {
203
+ const newState = wsManager.getState();
204
+ if (newState !== state) {
205
+ setState(newState);
206
+ }
207
+ };
208
+ const interval = setInterval(checkState, 1000);
209
+ return () => clearInterval(interval);
210
+ }, [wsManager, state]);
211
+ return state;
212
+ }
213
+ /**
214
+ * WebSocket 消息监听 Hook
215
+ */
216
+ export function useWebSocketMessages(filter, handler) {
217
+ const [messages, setMessages] = useState([]);
218
+ useEffect(() => {
219
+ const wsManager = getWebSocketManager();
220
+ // 这里需要扩展 WebSocketManager 来支持消息监听
221
+ // 暂时留空,后续可以扩展
222
+ }, [filter, handler]);
223
+ return messages;
224
+ }
225
+ //# sourceMappingURL=hooks.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../client/websocket/hooks.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ /**
2
+ * WebSocket 客户端模块
3
+ * 提供统一的 WebSocket 连接管理、消息处理和 React Hook 接口
4
+ */
5
+ export * from './types';
6
+ export { WebSocketManager } from './manager';
7
+ export { MessageHandler } from './messageHandler';
8
+ export { getWebSocketManager, destroyWebSocketManager, resetWebSocketManager } from './instance';
9
+ export { useWebSocket, useConfig, useAllConfigs, useWebSocketState, useWebSocketMessages } from './hooks';
10
+ import { getWebSocketManager } from './instance';
11
+ export { useConfig as useConfigLegacy } from './hooks';
12
+ export default getWebSocketManager;
13
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../client/websocket/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAKH,cAAc,SAAS,CAAA;AAKvB,OAAO,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAA;AAC5C,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AAKjD,OAAO,EACL,mBAAmB,EACnB,uBAAuB,EACvB,qBAAqB,EACtB,MAAM,YAAY,CAAA;AAKnB,OAAO,EACL,YAAY,EACZ,SAAS,EACT,aAAa,EACb,iBAAiB,EACjB,oBAAoB,EACrB,MAAM,SAAS,CAAA;AAOhB,OAAO,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAA;AAGhD,OAAO,EAAE,SAAS,IAAI,eAAe,EAAE,MAAM,SAAS,CAAA;AAGtD,eAAe,mBAAmB,CAAA"}
@@ -0,0 +1,31 @@
1
+ /**
2
+ * WebSocket 客户端模块
3
+ * 提供统一的 WebSocket 连接管理、消息处理和 React Hook 接口
4
+ */
5
+ // ============================================================================
6
+ // 类型定义
7
+ // ============================================================================
8
+ export * from './types';
9
+ // ============================================================================
10
+ // 核心类
11
+ // ============================================================================
12
+ export { WebSocketManager } from './manager';
13
+ export { MessageHandler } from './messageHandler';
14
+ // ============================================================================
15
+ // 实例管理
16
+ // ============================================================================
17
+ export { getWebSocketManager, destroyWebSocketManager, resetWebSocketManager } from './instance';
18
+ // ============================================================================
19
+ // React Hooks
20
+ // ============================================================================
21
+ export { useWebSocket, useConfig, useAllConfigs, useWebSocketState, useWebSocketMessages } from './hooks';
22
+ // ============================================================================
23
+ // 向后兼容的导出(保持与旧代码的兼容性)
24
+ // ============================================================================
25
+ // 为了保持与现有代码的兼容性,重新导出一些常用的接口
26
+ import { getWebSocketManager } from './instance';
27
+ // 兼容旧的 useConfig 导出
28
+ export { useConfig as useConfigLegacy } from './hooks';
29
+ // 兼容旧的 WebSocketManager 默认导出
30
+ export default getWebSocketManager;
31
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../client/websocket/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,+EAA+E;AAC/E,OAAO;AACP,+EAA+E;AAC/E,cAAc,SAAS,CAAA;AAEvB,+EAA+E;AAC/E,MAAM;AACN,+EAA+E;AAC/E,OAAO,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAA;AAC5C,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AAEjD,+EAA+E;AAC/E,OAAO;AACP,+EAA+E;AAC/E,OAAO,EACL,mBAAmB,EACnB,uBAAuB,EACvB,qBAAqB,EACtB,MAAM,YAAY,CAAA;AAEnB,+EAA+E;AAC/E,cAAc;AACd,+EAA+E;AAC/E,OAAO,EACL,YAAY,EACZ,SAAS,EACT,aAAa,EACb,iBAAiB,EACjB,oBAAoB,EACrB,MAAM,SAAS,CAAA;AAEhB,+EAA+E;AAC/E,sBAAsB;AACtB,+EAA+E;AAE/E,4BAA4B;AAC5B,OAAO,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAA;AAEhD,oBAAoB;AACpB,OAAO,EAAE,SAAS,IAAI,eAAe,EAAE,MAAM,SAAS,CAAA;AAEtD,6BAA6B;AAC7B,eAAe,mBAAmB,CAAA"}
@@ -0,0 +1,18 @@
1
+ /**
2
+ * WebSocket 实例管理
3
+ * 提供全局 WebSocket 管理器单例
4
+ */
5
+ import { WebSocketManager } from './manager';
6
+ /**
7
+ * 获取全局 WebSocket 管理器实例
8
+ */
9
+ export declare function getWebSocketManager(): WebSocketManager;
10
+ /**
11
+ * 销毁全局 WebSocket 管理器
12
+ */
13
+ export declare function destroyWebSocketManager(): void;
14
+ /**
15
+ * 重置 WebSocket 管理器(主要用于测试)
16
+ */
17
+ export declare function resetWebSocketManager(): void;
18
+ //# sourceMappingURL=instance.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"instance.d.ts","sourceRoot":"","sources":["../../client/websocket/instance.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAA;AAQ5C;;GAEG;AACH,wBAAgB,mBAAmB,IAAI,gBAAgB,CAWtD;AAED;;GAEG;AACH,wBAAgB,uBAAuB,IAAI,IAAI,CAK9C;AAED;;GAEG;AACH,wBAAgB,qBAAqB,IAAI,IAAI,CAG5C"}