@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.
- package/README.md +117 -3
- package/{src → client}/index.ts +0 -1
- package/{src → client}/store/index.ts +22 -1
- package/client/store/reducers/config.ts +135 -0
- package/{src → client}/store/reducers/index.ts +4 -1
- package/client/websocket/hooks.ts +280 -0
- package/client/websocket/index.ts +48 -0
- package/client/websocket/instance.ts +46 -0
- package/client/websocket/manager.ts +412 -0
- package/client/websocket/messageHandler.ts +166 -0
- package/client/websocket/types.ts +208 -0
- package/dist/index.d.ts +8 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +0 -1
- package/dist/index.js.map +1 -0
- package/dist/router/index.d.ts +25 -0
- package/dist/router/index.d.ts.map +1 -0
- package/dist/router/index.js +49 -0
- package/dist/router/index.js.map +1 -0
- package/dist/store/index.d.ts +19 -0
- package/dist/store/index.d.ts.map +1 -0
- package/dist/store/index.js +67 -0
- package/dist/store/index.js.map +1 -0
- package/dist/store/reducers/config.d.ts +54 -0
- package/dist/store/reducers/config.d.ts.map +1 -0
- package/dist/store/reducers/config.js +78 -0
- package/dist/store/reducers/config.js.map +1 -0
- package/dist/store/reducers/index.d.ts +13 -0
- package/dist/store/reducers/index.d.ts.map +1 -0
- package/dist/store/reducers/index.js +11 -0
- package/dist/store/reducers/index.js.map +1 -0
- package/dist/store/reducers/route.d.ts +37 -0
- package/dist/store/reducers/route.d.ts.map +1 -0
- package/dist/store/reducers/route.js +85 -0
- package/dist/store/reducers/route.js.map +1 -0
- package/dist/store/reducers/script.d.ts +17 -0
- package/dist/store/reducers/script.d.ts.map +1 -0
- package/dist/store/reducers/script.js +74 -0
- package/dist/store/reducers/script.js.map +1 -0
- package/dist/store/reducers/ui.d.ts +14 -0
- package/dist/store/reducers/ui.d.ts.map +1 -0
- package/dist/store/reducers/ui.js +23 -0
- package/dist/store/reducers/ui.js.map +1 -0
- package/dist/types.d.ts +7 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/dist/websocket/hooks.d.ts +55 -0
- package/dist/websocket/hooks.d.ts.map +1 -0
- package/dist/websocket/hooks.js +225 -0
- package/dist/websocket/hooks.js.map +1 -0
- package/dist/websocket/index.d.ts +13 -0
- package/dist/websocket/index.d.ts.map +1 -0
- package/dist/websocket/index.js +31 -0
- package/dist/websocket/index.js.map +1 -0
- package/dist/websocket/instance.d.ts +18 -0
- package/dist/websocket/instance.d.ts.map +1 -0
- package/dist/websocket/instance.js +39 -0
- package/dist/websocket/instance.js.map +1 -0
- package/dist/websocket/manager.d.ts +110 -0
- package/dist/websocket/manager.d.ts.map +1 -0
- package/dist/websocket/manager.js +341 -0
- package/dist/websocket/manager.js.map +1 -0
- package/dist/websocket/messageHandler.d.ts +48 -0
- package/dist/websocket/messageHandler.d.ts.map +1 -0
- package/dist/websocket/messageHandler.js +140 -0
- package/dist/websocket/messageHandler.js.map +1 -0
- package/dist/websocket/types.d.ts +125 -0
- package/dist/websocket/types.d.ts.map +1 -0
- package/dist/websocket/types.js +43 -0
- package/dist/websocket/types.js.map +1 -0
- package/package.json +8 -18
- package/app/index.html +0 -13
- package/app/postcss.config.js +0 -5
- package/app/src/components/ThemeToggle.tsx +0 -21
- package/app/src/hooks/useTheme.ts +0 -17
- package/app/src/layouts/dashboard.tsx +0 -259
- package/app/src/main.tsx +0 -121
- package/app/src/pages/dashboard-bots.tsx +0 -198
- package/app/src/pages/dashboard-home.tsx +0 -301
- package/app/src/pages/dashboard-logs.tsx +0 -298
- package/app/src/pages/dashboard-plugin-detail.tsx +0 -349
- package/app/src/pages/dashboard-plugins.tsx +0 -166
- package/app/src/style.css +0 -1105
- package/app/src/theme/index.ts +0 -92
- package/app/tailwind.config.js +0 -70
- package/app/tsconfig.json +0 -16
- package/src/websocket/index.ts +0 -193
- package/src/websocket/useWebSocket.ts +0 -42
- /package/{src → client}/router/index.tsx +0 -0
- /package/{src → client}/store/reducers/route.ts +0 -0
- /package/{src → client}/store/reducers/script.ts +0 -0
- /package/{src → client}/store/reducers/ui.ts +0 -0
- /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"}
|
package/dist/types.d.ts
ADDED
|
@@ -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 @@
|
|
|
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":"AAAA;;;GAGG;AAEH,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AACjE,OAAO,EACL,WAAW,EACX,WAAW,EACX,YAAY,EACZ,YAAY,EACZ,mBAAmB,EACnB,iBAAiB,EACjB,qBAAqB,EACrB,gBAAgB,EAChB,gBAAgB,EAChB,UAAU,EACV,QAAQ,EACT,MAAM,UAAU,CAAA;AACjB,OAAO,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAA;AAGhD,+EAA+E;AAC/E,oBAAoB;AACpB,+EAA+E;AAE/E;;GAEG;AACH,MAAM,UAAU,YAAY,CAAC,UAA+B,EAAE;IAC5D,MAAM,EAAE,WAAW,GAAG,IAAI,EAAE,GAAG,OAAO,CAAA;IAEtC,MAAM,SAAS,GAAG,mBAAmB,EAAE,CAAA;IAEvC,eAAe;IACf,MAAM,SAAS,GAAG,WAAW,CAAC,qBAAqB,CAAC,CAAA;IACpD,MAAM,OAAO,GAAG,WAAW,CAAC,CAAC,KAAU,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,EAAE,OAAO,IAAI,EAAE,CAAC,CAAA;IACxE,MAAM,aAAa,GAAG,WAAW,CAAC,CAAC,KAAU,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,EAAE,aAAa,IAAI,EAAE,CAAC,CAAA;IAEpF,OAAO;IACP,MAAM,OAAO,GAAG,WAAW,CAAC,GAAG,EAAE;QAC/B,SAAS,CAAC,OAAO,EAAE,CAAA;IACrB,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAA;IAEf,MAAM,UAAU,GAAG,WAAW,CAAC,GAAG,EAAE;QAClC,SAAS,CAAC,UAAU,EAAE,CAAA;IACxB,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAA;IAEf,OAAO;IACP,MAAM,IAAI,GAAG,WAAW,CAAC,CAAC,OAAY,EAAE,EAAE;QACxC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;IACzB,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAA;IAEf,MAAM,WAAW,GAAG,WAAW,CAAC,KAAK,EAAW,OAAY,EAAc,EAAE;QAC1E,eAAe;QACf,OAAQ,SAAiB,CAAC,WAAW,CAAC,OAAO,CAAC,CAAA;IAChD,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAA;IAEf,OAAO;IACP,MAAM,WAAW,GAAG,WAAW,CAAC,GAAG,EAAE;QACnC,OAAO,SAAS,CAAC,WAAW,EAAE,CAAA;IAChC,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAA;IAEf,MAAM,QAAQ,GAAG,WAAW,CAAC,GAAG,EAAE;QAChC,gBAAgB;QAChB,OAAO,SAAS,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,cAAc,CAAA;IAC/D,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAA;IAEf,OAAO;IACP,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,WAAW,IAAI,CAAC,SAAS,EAAE,CAAC;YAC9B,OAAO,EAAE,CAAA;QACX,CAAC;IACH,CAAC,EAAE,CAAC,WAAW,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC,CAAA;IAErC,OAAO;QACL,KAAK;QACL,SAAS;QACT,OAAO;QACP,aAAa;QAEb,KAAK;QACL,OAAO;QACP,UAAU;QACV,IAAI;QACJ,WAAW;QACX,WAAW;QACX,QAAQ;QAER,qBAAqB;QACrB,OAAO,EAAE,SAAS;KACnB,CAAA;AACH,CAAC;AAED,+EAA+E;AAC/E,YAAY;AACZ,+EAA+E;AAE/E;;GAEG;AACH,MAAM,UAAU,SAAS,CAAC,UAAkB,EAAE,UAA4B,EAAE;IAC1E,MAAM,EAAE,QAAQ,GAAG,IAAI,EAAE,cAAc,GAAG,IAAI,EAAE,GAAG,OAAO,CAAA;IAE1D,MAAM,QAAQ,GAAG,WAAW,EAAE,CAAA;IAC9B,MAAM,SAAS,GAAG,mBAAmB,EAAE,CAAA;IAEvC,QAAQ;IACR,MAAM,MAAM,GAAG,WAAW,CAAC,CAAC,KAAU,EAAE,EAAE,CAAC,YAAY,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC,CAAA;IAC3E,MAAM,MAAM,GAAG,WAAW,CAAC,CAAC,KAAU,EAAE,EAAE,CAAC,YAAY,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC,CAAA;IAC3E,MAAM,OAAO,GAAG,WAAW,CAAC,CAAC,KAAU,EAAE,EAAE,CAAC,mBAAmB,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC,CAAA;IACnF,MAAM,KAAK,GAAG,WAAW,CAAC,CAAC,KAAU,EAAE,EAAE,CAAC,iBAAiB,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC,CAAA;IAC/E,MAAM,SAAS,GAAG,WAAW,CAAC,qBAAqB,CAAC,CAAA;IAEpD,OAAO;IACP,MAAM,SAAS,GAAG,WAAW,CAAC,KAAK,IAAI,EAAE;QACvC,QAAQ,CAAC,UAAU,CAAC,EAAE,UAAU,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,CAAA;QACnD,QAAQ,CAAC,QAAQ,CAAC,EAAE,UAAU,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,CAAA;QAE/C,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC,SAAS,CAAC,UAAU,CAAC,CAAA;YACpD,OAAO,MAAM,CAAA;QACf,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACb,OAAO,CAAC,GAAG,CAAC,WAAW,EAAC,KAAK,CAAC,CAAA;YAChC,MAAM,YAAY,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe,CAAA;YAC7E,QAAQ,CAAC,QAAQ,CAAC,EAAE,UAAU,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC,CAAC,CAAA;YACvD,MAAM,KAAK,CAAA;QACb,CAAC;gBAAS,CAAC;YACT,QAAQ,CAAC,UAAU,CAAC,EAAE,UAAU,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC,CAAA;QACtD,CAAC;IACH,CAAC,EAAE,CAAC,UAAU,EAAE,SAAS,EAAE,QAAQ,CAAC,CAAC,CAAA;IAErC,MAAM,SAAS,GAAG,WAAW,CAAC,KAAK,EAAE,SAAc,EAAE,EAAE;QACrD,QAAQ,CAAC,UAAU,CAAC,EAAE,UAAU,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,CAAA;QACnD,QAAQ,CAAC,QAAQ,CAAC,EAAE,UAAU,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,CAAA;QAE/C,IAAI,CAAC;YACH,MAAM,SAAS,CAAC,SAAS,CAAC,UAAU,EAAE,SAAS,CAAC,CAAA;QAClD,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACb,OAAO,CAAC,GAAG,CAAC,WAAW,EAAC,KAAK,CAAC,CAAA;YAChC,MAAM,YAAY,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe,CAAA;YAC7E,QAAQ,CAAC,QAAQ,CAAC,EAAE,UAAU,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC,CAAC,CAAA;YACvD,MAAM,KAAK,CAAA;QACb,CAAC;gBAAS,CAAC;YACT,QAAQ,CAAC,UAAU,CAAC,EAAE,UAAU,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC,CAAA;QACtD,CAAC;IACH,CAAC,EAAE,CAAC,UAAU,EAAE,SAAS,EAAE,QAAQ,CAAC,CAAC,CAAA;IAErC,MAAM,SAAS,GAAG,WAAW,CAAC,KAAK,IAAI,EAAE;QACvC,IAAI,CAAC;YACH,OAAO,MAAM,SAAS,CAAC,SAAS,CAAC,UAAU,CAAC,CAAA;QAC9C,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,mCAAmC,UAAU,GAAG,EAAE,KAAK,CAAC,CAAA;YACtE,MAAM,KAAK,CAAA;QACb,CAAC;IACH,CAAC,EAAE,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC,CAAA;IAE3B,iBAAiB;IACjB,MAAM,MAAM,GAAG,WAAW,CAAC,KAAK,IAAI,EAAE;QACpC,MAAM,QAAQ,GAAG,EAAE,CAAA;QAEnB,IAAI,QAAQ,EAAE,CAAC;YACb,QAAQ,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAA;QAC5B,CAAC;QAED,IAAI,cAAc,EAAE,CAAC;YACnB,QAAQ,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAA;QAC5B,CAAC;QAED,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAA;IAC7B,CAAC,EAAE,CAAC,QAAQ,EAAE,cAAc,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC,CAAA;IAEpD,OAAO;IACP,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,SAAS,IAAI,QAAQ,IAAI,CAAC,MAAM,IAAI,CAAC,OAAO,EAAE,CAAC;YACjD,SAAS,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;QAClC,CAAC;IACH,CAAC,EAAE,CAAC,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,SAAS,CAAC,CAAC,CAAA;IAErD,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,SAAS,IAAI,cAAc,IAAI,CAAC,MAAM,EAAE,CAAC;YAC3C,SAAS,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;QAClC,CAAC;IACH,CAAC,EAAE,CAAC,SAAS,EAAE,cAAc,EAAE,MAAM,EAAE,SAAS,CAAC,CAAC,CAAA;IAElD,OAAO,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC;QACpB,KAAK;QACL,MAAM;QACN,MAAM;QACN,OAAO;QACP,KAAK;QACL,SAAS;QAET,KAAK;QACL,SAAS;QACT,SAAS;QACT,SAAS;QACT,MAAM;KACP,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC,CAAA;AAC3F,CAAC;AAED,+EAA+E;AAC/E,cAAc;AACd,+EAA+E;AAE/E;;GAEG;AACH,MAAM,UAAU,aAAa;IAC3B,MAAM,SAAS,GAAG,mBAAmB,EAAE,CAAA;IAEvC,MAAM,UAAU,GAAG,WAAW,CAAC,gBAAgB,CAAC,CAAA;IAChD,MAAM,UAAU,GAAG,WAAW,CAAC,gBAAgB,CAAC,CAAA;IAChD,MAAM,SAAS,GAAG,WAAW,CAAC,qBAAqB,CAAC,CAAA;IAEpD,MAAM,UAAU,GAAG,WAAW,CAAC,KAAK,IAAI,EAAE;QACxC,IAAI,CAAC;YACH,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;gBAC1C,SAAiB,CAAC,aAAa,EAAE;gBACjC,SAAiB,CAAC,aAAa,EAAE;aACnC,CAAC,CAAA;YAEF,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,CAAA;QAC7B,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,gCAAgC,EAAE,KAAK,CAAC,CAAA;YACtD,MAAM,KAAK,CAAA;QACb,CAAC;IACH,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAA;IAEf,OAAO,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC;QACpB,OAAO,EAAE,UAAU;QACnB,OAAO,EAAE,UAAU;QACnB,SAAS;QACT,UAAU;KACX,CAAC,EAAE,CAAC,UAAU,EAAE,UAAU,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC,CAAA;AACtD,CAAC;AAED,+EAA+E;AAC/E,UAAU;AACV,+EAA+E;AAE/E;;GAEG;AACH,MAAM,UAAU,iBAAiB;IAC/B,MAAM,SAAS,GAAG,mBAAmB,EAAE,CAAA;IACvC,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC,CAAA;IAExD,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,UAAU,GAAG,GAAG,EAAE;YACtB,MAAM,QAAQ,GAAG,SAAS,CAAC,QAAQ,EAAE,CAAA;YACrC,IAAI,QAAQ,KAAK,KAAK,EAAE,CAAC;gBACvB,QAAQ,CAAC,QAAQ,CAAC,CAAA;YACpB,CAAC;QACH,CAAC,CAAA;QAED,MAAM,QAAQ,GAAG,WAAW,CAAC,UAAU,EAAE,IAAI,CAAC,CAAA;QAC9C,OAAO,GAAG,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAA;IACtC,CAAC,EAAE,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC,CAAA;IAEtB,OAAO,KAAK,CAAA;AACd,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,oBAAoB,CAClC,MAAkC,EAClC,OAA8B;IAE9B,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,QAAQ,CAAM,EAAE,CAAC,CAAA;IAEjD,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,SAAS,GAAG,mBAAmB,EAAE,CAAA;QACvC,kCAAkC;QAClC,cAAc;IAChB,CAAC,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAA;IAErB,OAAO,QAAQ,CAAA;AACjB,CAAC"}
|
|
@@ -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"}
|