chainlesschain 0.161.8 → 0.161.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.
Files changed (148) hide show
  1. package/package.json +2 -1
  2. package/src/assets/web-panel/.build-hash +1 -1
  3. package/src/assets/web-panel/assets/{AIOps-Uls1XIO4.js → AIOps-Cbnj25uU.js} +1 -1
  4. package/src/assets/web-panel/assets/{ActionButton-BpVrefl1.js → ActionButton-DY69UkxV.js} +1 -1
  5. package/src/assets/web-panel/assets/{Analytics-Z1Rgg9PA.js → Analytics-DUzoL75H.js} +2 -2
  6. package/src/assets/web-panel/assets/AppLayout-DATUppSv.js +1 -0
  7. package/src/assets/web-panel/assets/{AppLayout-P7jhSfLy.css → AppLayout-qr7ghxW7.css} +1 -1
  8. package/src/assets/web-panel/assets/{Audit-Co6yYgmX.js → Audit-CFJh6huz.js} +1 -1
  9. package/src/assets/web-panel/assets/{Backup-1IZDB3QD.js → Backup-CMTir4tV.js} +1 -1
  10. package/src/assets/web-panel/assets/{BaseInput-LYB_wIZP.js → BaseInput-BaWXBDdp.js} +1 -1
  11. package/src/assets/web-panel/assets/{Chat-D-6LDWGl.js → Chat-DjToexEx.js} +3 -3
  12. package/src/assets/web-panel/assets/{Checkbox-dLnnw7OE.js → Checkbox-DJnhKXhi.js} +1 -1
  13. package/src/assets/web-panel/assets/{Codegen-Wh6xypMx.js → Codegen-CgsgvRJX.js} +1 -1
  14. package/src/assets/web-panel/assets/{Col-BT8lkjSw.js → Col-MvMGDJAB.js} +1 -1
  15. package/src/assets/web-panel/assets/{Community-CdAeMHde.js → Community-q26VGOGu.js} +1 -1
  16. package/src/assets/web-panel/assets/{Compact-VsImrjgV.js → Compact-DyLYzWoX.js} +1 -1
  17. package/src/assets/web-panel/assets/{Compliance-PScuVx8d.js → Compliance-D_TF9eBc.js} +1 -1
  18. package/src/assets/web-panel/assets/{Cowork-qB8hRW0r.js → Cowork-B9bg988c.js} +3 -3
  19. package/src/assets/web-panel/assets/{Cron-CuSjuE-h.js → Cron-6k9vTFfd.js} +2 -2
  20. package/src/assets/web-panel/assets/{Crosschain-BqIRd8bv.js → Crosschain-B7fk2aHi.js} +1 -1
  21. package/src/assets/web-panel/assets/{DID-BT5BJ0DF.js → DID-XhCfTFm2.js} +2 -2
  22. package/src/assets/web-panel/assets/{Dashboard-BX-06zEm.js → Dashboard-Bqk7vtZM.js} +2 -2
  23. package/src/assets/web-panel/assets/{Dropdown-Pjo3G3Vf.js → Dropdown-CDOOZGv7.js} +1 -1
  24. package/src/assets/web-panel/assets/{Federation-BbnYcYhr.js → Federation-NajN4oRO.js} +1 -1
  25. package/src/assets/web-panel/assets/{FormItemContext-C3hf4K1_.js → FormItemContext-DgMHYlMB.js} +1 -1
  26. package/src/assets/web-panel/assets/{Git-Cmw6_HXW.js → Git-CZC5n1Zu.js} +2 -2
  27. package/src/assets/web-panel/assets/{Governance-BFBvB2G6.js → Governance-Br131eUW.js} +1 -1
  28. package/src/assets/web-panel/assets/{Inference-BBdX3YjM.js → Inference-BHlUfcT-.js} +1 -1
  29. package/src/assets/web-panel/assets/{KnowledgeGraph-BC-bcvNY.js → KnowledgeGraph-CByROhg-.js} +1 -1
  30. package/src/assets/web-panel/assets/{Logs-B9DuqFeW.js → Logs-D8Ghzk4B.js} +1 -1
  31. package/src/assets/web-panel/assets/{Marketplace-Bff1ja4R.js → Marketplace-CnjHPFm7.js} +1 -1
  32. package/src/assets/web-panel/assets/{McpTools-DnWqjtkb.js → McpTools-C_vszCBU.js} +1 -1
  33. package/src/assets/web-panel/assets/{Memory-C6YXBuM7.js → Memory-Cl5c_8In.js} +2 -2
  34. package/src/assets/web-panel/assets/MobileBridge-DkkMCDx9.css +1 -0
  35. package/src/assets/web-panel/assets/MobileBridge-K3KwwCKl.js +3 -0
  36. package/src/assets/web-panel/assets/{Mtc-r-J4WRfp.js → Mtc-NfZ8xzyu.js} +4 -4
  37. package/src/assets/web-panel/assets/{MtcAudit-DFqXLHn6.js → MtcAudit-BkktYSXj.js} +1 -1
  38. package/src/assets/web-panel/assets/Multisig-BLRYDn7_.css +1 -0
  39. package/src/assets/web-panel/assets/Multisig-qP51bs1T.js +1 -0
  40. package/src/assets/web-panel/assets/{NLProgramming-s5CrjYto.js → NLProgramming-BhFRuXyi.js} +1 -1
  41. package/src/assets/web-panel/assets/{Notes-TAbnvDCd.js → Notes-BpcAFy8i.js} +3 -3
  42. package/src/assets/web-panel/assets/{NotificationSettings-BZIKI219.js → NotificationSettings-DKNtYYeo.js} +1 -1
  43. package/src/assets/web-panel/assets/{Organization-BXbSljYa.js → Organization-C61VwQEW.js} +4 -4
  44. package/src/assets/web-panel/assets/{Overflow-O2RWHZxH.js → Overflow-WBloac1x.js} +1 -1
  45. package/src/assets/web-panel/assets/{P2P-B8jBZLh6.js → P2P-DGm7EvDg.js} +2 -2
  46. package/src/assets/web-panel/assets/{Permissions-Cexi8Jr6.js → Permissions-KFPtoOV6.js} +2 -2
  47. package/src/assets/web-panel/assets/{Pipeline-BwIBnNzj.js → Pipeline-CFjFtzZT.js} +1 -1
  48. package/src/assets/web-panel/assets/{Privacy-D-LOR9um.js → Privacy-T_Kewe_f.js} +1 -1
  49. package/src/assets/web-panel/assets/{ProjectSettings-DZ_fdRRJ.js → ProjectSettings-BQl8qTPQ.js} +1 -1
  50. package/src/assets/web-panel/assets/{Projects-Bis42Cb6.js → Projects-xGNn4Ov9.js} +2 -2
  51. package/src/assets/web-panel/assets/{Providers-DH6hY4Gx.js → Providers-ByuUztXe.js} +1 -1
  52. package/src/assets/web-panel/assets/{QuickAsk-Ur0bUXHK.js → QuickAsk-BwSXmXvL.js} +1 -1
  53. package/src/assets/web-panel/assets/{Recommend-CLDQjSf6.js → Recommend-Cp433_5Z.js} +1 -1
  54. package/src/assets/web-panel/assets/{Reputation-StG-zGil.js → Reputation-DE_JSjyi.js} +1 -1
  55. package/src/assets/web-panel/assets/{Row-DAWA1cwa.js → Row-DI36Fic1.js} +1 -1
  56. package/src/assets/web-panel/assets/{RssFeed-rb2CP-IS.js → RssFeed-DswpSUiI.js} +3 -3
  57. package/src/assets/web-panel/assets/{Search-Y9qsWaAE.js → Search-Crs2UKhh.js} +1 -1
  58. package/src/assets/web-panel/assets/{Security-BanZDWBe.js → Security-W8ViXXbq.js} +3 -3
  59. package/src/assets/web-panel/assets/{Services-DFOMZwqJ.js → Services-BIQdyLJM.js} +2 -2
  60. package/src/assets/web-panel/assets/{Skeleton-Cy48VmyC.js → Skeleton-DDiOevKX.js} +1 -1
  61. package/src/assets/web-panel/assets/{Skills-BqdkGRyO.js → Skills-v-Vw_jGa.js} +1 -1
  62. package/src/assets/web-panel/assets/{Sla-B8lXq9rJ.js → Sla-B-ULmz5m.js} +1 -1
  63. package/src/assets/web-panel/assets/{SpeechSettings-CmIkYpWT.js → SpeechSettings--8IIPHri.js} +1 -1
  64. package/src/assets/web-panel/assets/{SyncSettings-tZDaJZ0S.js → SyncSettings-D0QiEwJn.js} +1 -1
  65. package/src/assets/web-panel/assets/{Tasks-DxBlrylF.js → Tasks-BNSR9FlM.js} +1 -1
  66. package/src/assets/web-panel/assets/{Templates-ByshgJtu.js → Templates-CFVkaS-d.js} +1 -1
  67. package/src/assets/web-panel/assets/{Tenant-DCpEpRf1.js → Tenant-quU-tldS.js} +1 -1
  68. package/src/assets/web-panel/assets/{Tokens-BIUug_M_.js → Tokens-DTqFjS4k.js} +1 -1
  69. package/src/assets/web-panel/assets/{Trigger-DY4iT_Sv.js → Trigger-ZWVirxhN.js} +1 -1
  70. package/src/assets/web-panel/assets/{Trust-fAtm0ohe.js → Trust-DmaYf5tg.js} +1 -1
  71. package/src/assets/web-panel/assets/{UkeySign-CwbV_ITc.js → UkeySign-BeYyXtZW.js} +1 -1
  72. package/src/assets/web-panel/assets/{VideoEditing-CBJ5dw8E.js → VideoEditing-CRdDwD9C.js} +1 -1
  73. package/src/assets/web-panel/assets/{Wallet-B1fyWeNC.js → Wallet-H-38f7Pv.js} +4 -4
  74. package/src/assets/web-panel/assets/{WebAuthn-by6IZMeB.js → WebAuthn-CCQVzZ0W.js} +4 -4
  75. package/src/assets/web-panel/assets/{WorkflowEditor-DZkBKsSU.js → WorkflowEditor-B1RFE2oN.js} +1 -1
  76. package/src/assets/web-panel/assets/{chat-CKAWhBMH.js → chat-Z4UoBAeF.js} +1 -1
  77. package/src/assets/web-panel/assets/{colors-DgRS7Mb2.js → colors-AecMhEAZ.js} +1 -1
  78. package/src/assets/web-panel/assets/{compact-item-CQUZCSRU.js → compact-item-Dfhm05kA.js} +1 -1
  79. package/src/assets/web-panel/assets/{createContext-DgOciZHM.js → createContext-C7gBVuRm.js} +1 -1
  80. package/src/assets/web-panel/assets/{hasIn-DEXVOypF.js → hasIn-DQarK3iI.js} +1 -1
  81. package/src/assets/web-panel/assets/icons-B2mcO3YM.js +57 -0
  82. package/src/assets/web-panel/assets/{index-DjQzFo-O.js → index-1d6L3YWV.js} +1 -1
  83. package/src/assets/web-panel/assets/{index-jLpDpunJ.js → index-5I_kEh5L.js} +1 -1
  84. package/src/assets/web-panel/assets/{index-BjpS0vcp.js → index-5P_X26-m.js} +1 -1
  85. package/src/assets/web-panel/assets/{index-nMw96bEM.js → index-78eTUfD9.js} +1 -1
  86. package/src/assets/web-panel/assets/{index-BYrBEkTv.js → index-B1XdBIuG.js} +1 -1
  87. package/src/assets/web-panel/assets/{index-BQDGHgXQ.js → index-B52lOAOU.js} +1 -1
  88. package/src/assets/web-panel/assets/{index-Bo43zHIV.js → index-BLYMiBRw.js} +1 -1
  89. package/src/assets/web-panel/assets/{index-D8S-7oDQ.js → index-BxjOmfVA.js} +9 -9
  90. package/src/assets/web-panel/assets/{index-D2PDzVV6.js → index-C-4d1ug2.js} +1 -1
  91. package/src/assets/web-panel/assets/{index-D1dIizuf.js → index-C0kyGID6.js} +1 -1
  92. package/src/assets/web-panel/assets/{index-CS3fI6_d.js → index-C7nHW5ZW.js} +1 -1
  93. package/src/assets/web-panel/assets/{index-Ce57JGJq.js → index-CCUfW7hO.js} +1 -1
  94. package/src/assets/web-panel/assets/{index-nIXYg_tf.js → index-CFR1Scu8.js} +1 -1
  95. package/src/assets/web-panel/assets/{index-hfGZzUzb.js → index-CS7_x1br.js} +1 -1
  96. package/src/assets/web-panel/assets/{index-1EDbawpk.js → index-Ch9ExDNs.js} +1 -1
  97. package/src/assets/web-panel/assets/{index-CEt0RfAY.js → index-CiVezMja.js} +1 -1
  98. package/src/assets/web-panel/assets/index-Cp5G30tN.js +1 -0
  99. package/src/assets/web-panel/assets/index-CuPmKar9.js +1 -0
  100. package/src/assets/web-panel/assets/{index-CCuIY7Ff.js → index-CxDBoEkf.js} +1 -1
  101. package/src/assets/web-panel/assets/{index-B-g1My7q.js → index-Cy_80Fj7.js} +1 -1
  102. package/src/assets/web-panel/assets/{index-CH5YkJC9.js → index-D3Pxfwcc.js} +1 -1
  103. package/src/assets/web-panel/assets/{index-_Oe8Zr99.js → index-D4_1yL1c.js} +1 -1
  104. package/src/assets/web-panel/assets/{index-HE37tYPs.js → index-D841tepe.js} +1 -1
  105. package/src/assets/web-panel/assets/{index-ZOpqRGzA.js → index-DWbRHjgk.js} +1 -1
  106. package/src/assets/web-panel/assets/{index-DkBSIb9k.js → index-DX4CKtlL.js} +1 -1
  107. package/src/assets/web-panel/assets/{index-wPVZuwWm.js → index-DdtxWGjo.js} +2 -2
  108. package/src/assets/web-panel/assets/{index-DW_-28b4.js → index-DfA9S79c.js} +1 -1
  109. package/src/assets/web-panel/assets/{index-CetlLBjh.js → index-DfAZSzZc.js} +1 -1
  110. package/src/assets/web-panel/assets/{index-B1USa9q3.js → index-Dkh_4r1F.js} +1 -1
  111. package/src/assets/web-panel/assets/{index-DBRA1wFF.js → index-DtrMx44i.js} +1 -1
  112. package/src/assets/web-panel/assets/{index-BEnMJ3rw.js → index-Dy2fLm3i.js} +1 -1
  113. package/src/assets/web-panel/assets/index-L6kKxFAO.js +21 -0
  114. package/src/assets/web-panel/assets/{index-DpL-43E_.js → index-OqY41c_z.js} +1 -1
  115. package/src/assets/web-panel/assets/{index-D3tqZAdL.js → index-QgJGoGAK.js} +1 -1
  116. package/src/assets/web-panel/assets/{index-o6vVX9C_.js → index-YJxjR7t9.js} +1 -1
  117. package/src/assets/web-panel/assets/{index-CQepaPId.js → index-aHqD7CZz.js} +1 -1
  118. package/src/assets/web-panel/assets/{index-bRI-SvZ-.js → index-d0Iy6r2J.js} +1 -1
  119. package/src/assets/web-panel/assets/index-eoNKQdFC.js +1 -0
  120. package/src/assets/web-panel/assets/{index-BMx0R9Vw.js → index-nqKLHlmq.js} +1 -1
  121. package/src/assets/web-panel/assets/{initDefaultProps-BSTz5E8D.js → initDefaultProps-CDOGbz6v.js} +1 -1
  122. package/src/assets/web-panel/assets/{markdown-xjUYbPSW.js → markdown-CsiA8-E5.js} +1 -1
  123. package/src/assets/web-panel/assets/{markdown-vYH_ziAO.js → markdown-Yo_c6Krv.js} +1 -1
  124. package/src/assets/web-panel/assets/{motion-B10pjDA-.js → motion-ChIpIzUN.js} +1 -1
  125. package/src/assets/web-panel/assets/{move-B_PFOXXn.js → move-DbH3dyN8.js} +1 -1
  126. package/src/assets/web-panel/assets/{omit-Bf31gUOR.js → omit-BJ1K-IDI.js} +1 -1
  127. package/src/assets/web-panel/assets/{pickAttrs-CTOOvnV9.js → pickAttrs-B0q7EpvV.js} +1 -1
  128. package/src/assets/web-panel/assets/{placementArrow-DfXqIy1B.js → placementArrow-D7XkOUjs.js} +1 -1
  129. package/src/assets/web-panel/assets/{responsiveObserve-BonUzZVT.js → responsiveObserve-efcdE4ju.js} +1 -1
  130. package/src/assets/web-panel/assets/{slide-DtkoQrl3.js → slide-BgAktMzM.js} +1 -1
  131. package/src/assets/web-panel/assets/{statusUtils-BJlmtjwo.js → statusUtils-CV83LVbI.js} +1 -1
  132. package/src/assets/web-panel/assets/{styleChecker-CoQ2DFN_.js → styleChecker-D1npYi6G.js} +1 -1
  133. package/src/assets/web-panel/assets/{useFlexGapSupport-BD9H_ICR.js → useFlexGapSupport-DTH3yXTD.js} +1 -1
  134. package/src/assets/web-panel/assets/{useFs-DNCH6P7V.js → useFs-BEvSw9aX.js} +1 -1
  135. package/src/assets/web-panel/assets/{vnode-CAFNU-3N.js → vnode-Duw65sZ1.js} +1 -1
  136. package/src/assets/web-panel/assets/{zoom-Beg44Pk9.js → zoom-CLMtA8PG.js} +1 -1
  137. package/src/assets/web-panel/index.html +2 -2
  138. package/src/commands/marketplace.js +286 -0
  139. package/src/commands/multisig.js +471 -0
  140. package/src/commands/p2p.js +114 -7
  141. package/src/index.js +2 -0
  142. package/src/lib/multisig-runtime.js +160 -0
  143. package/src/lib/p2p-manager.js +96 -2
  144. package/src/assets/web-panel/assets/AppLayout-GvY1b95g.js +0 -1
  145. package/src/assets/web-panel/assets/icons-B2G69bhT.js +0 -57
  146. package/src/assets/web-panel/assets/index-DLnvncqr.js +0 -1
  147. package/src/assets/web-panel/assets/index-DsmrJv8Y.js +0 -21
  148. package/src/assets/web-panel/assets/index-Rvjbak1o.js +0 -1
@@ -0,0 +1,160 @@
1
+ /**
2
+ * v1.2 m-of-n Phase 2 — shared multisig DB + manager loader.
3
+ *
4
+ * Phase 1 inlined this in commands/multisig.js. Phase 2 marketplace mediator
5
+ * also needs it (cc marketplace purchase / consume), so factor out here.
6
+ *
7
+ * SQLite driver cascade: better-sqlite3-multiple-ciphers → better-sqlite3 →
8
+ * sql.js (WASM) per feedback_sqlite_wasm_fallback memo. sql.js gets a
9
+ * better-sqlite3-style adapter for the subset core-multisig/store.js needs.
10
+ */
11
+
12
+ import fs from "node:fs";
13
+ import path from "node:path";
14
+ import { createRequire } from "node:module";
15
+ import multisig from "@chainlesschain/core-multisig";
16
+ import { getHomeDir } from "./paths.js";
17
+
18
+ const requireCjs = createRequire(import.meta.url);
19
+
20
+ const {
21
+ applySchema,
22
+ createStore,
23
+ createProposalsManager,
24
+ appendGovernanceEvent,
25
+ } = multisig;
26
+
27
+ export function defaultMultisigDbPath() {
28
+ return path.join(getHomeDir(), "multisig.db");
29
+ }
30
+
31
+ export function defaultMultisigLogPath() {
32
+ return path.join(getHomeDir(), "multisig.governance.log");
33
+ }
34
+
35
+ async function _openDatabase(dbPath) {
36
+ for (const pkg of ["better-sqlite3-multiple-ciphers", "better-sqlite3"]) {
37
+ try {
38
+ const Database = requireCjs(pkg);
39
+ const db = new Database(dbPath);
40
+ db.pragma("journal_mode = WAL");
41
+ db.pragma("foreign_keys = ON");
42
+ return { kind: "native", db, close: () => db.close() };
43
+ } catch (_e) {
44
+ /* try next */
45
+ }
46
+ }
47
+ const initSqlJs = requireCjs("sql.js");
48
+ const SQL = await initSqlJs();
49
+ const buf = fs.existsSync(dbPath) ? fs.readFileSync(dbPath) : undefined;
50
+ const sqlDb = new SQL.Database(buf);
51
+ return {
52
+ kind: "wasm",
53
+ db: _adaptSqlJs(sqlDb),
54
+ close: () => {
55
+ const out = sqlDb.export();
56
+ fs.writeFileSync(dbPath, Buffer.from(out));
57
+ sqlDb.close();
58
+ },
59
+ };
60
+ }
61
+
62
+ function _adaptSqlJs(sqlDb) {
63
+ const norm = (params) =>
64
+ params.map((p) => (Buffer.isBuffer(p) ? new Uint8Array(p) : p));
65
+ return {
66
+ prepare(sql) {
67
+ return {
68
+ run(...params) {
69
+ const stmt = sqlDb.prepare(sql);
70
+ try {
71
+ stmt.bind(norm(params));
72
+ stmt.step();
73
+ return { changes: sqlDb.getRowsModified(), lastInsertRowid: 0 };
74
+ } finally {
75
+ stmt.free();
76
+ }
77
+ },
78
+ get(...params) {
79
+ const stmt = sqlDb.prepare(sql);
80
+ try {
81
+ stmt.bind(norm(params));
82
+ return stmt.step() ? stmt.getAsObject() : undefined;
83
+ } finally {
84
+ stmt.free();
85
+ }
86
+ },
87
+ all(...params) {
88
+ const stmt = sqlDb.prepare(sql);
89
+ try {
90
+ stmt.bind(norm(params));
91
+ const rows = [];
92
+ while (stmt.step()) rows.push(stmt.getAsObject());
93
+ return rows;
94
+ } finally {
95
+ stmt.free();
96
+ }
97
+ },
98
+ };
99
+ },
100
+ exec(sql) {
101
+ sqlDb.exec(sql);
102
+ },
103
+ };
104
+ }
105
+
106
+ /**
107
+ * Open a multisig manager backed by SQLite + governance log.
108
+ *
109
+ * @param {string} [dbPath]
110
+ * @param {string} [logPath]
111
+ * @returns {Promise<{ db, store, mgr, close }>}
112
+ */
113
+ export async function openMultisigManager(
114
+ dbPath = defaultMultisigDbPath(),
115
+ logPath = defaultMultisigLogPath(),
116
+ ) {
117
+ fs.mkdirSync(path.dirname(dbPath), { recursive: true });
118
+ const handle = await _openDatabase(dbPath);
119
+ applySchema(handle.db);
120
+ const store = createStore(handle.db);
121
+ const mgr = createProposalsManager(store, {
122
+ logEvent: (event) => appendGovernanceEvent(logPath, event),
123
+ });
124
+ return {
125
+ db: handle.db,
126
+ store,
127
+ mgr,
128
+ close: handle.close,
129
+ };
130
+ }
131
+
132
+ /**
133
+ * Read a secret key from hex string or hex file path.
134
+ *
135
+ * @param {string} arg
136
+ * @returns {Buffer}
137
+ */
138
+ export function readSecretKey(arg) {
139
+ if (!arg) {
140
+ throw new Error("--key required (hex string or path to hex file)");
141
+ }
142
+ if (/^[0-9a-fA-F]+$/.test(arg)) {
143
+ return Buffer.from(arg, "hex");
144
+ }
145
+ if (fs.existsSync(arg)) {
146
+ const raw = fs.readFileSync(arg, "utf-8").trim();
147
+ return Buffer.from(raw, "hex");
148
+ }
149
+ throw new Error(`--key: not hex and not an existing file path: ${arg}`);
150
+ }
151
+
152
+ /**
153
+ * Read JSON from inline string or file path.
154
+ */
155
+ export function readJsonArg(arg) {
156
+ if (fs.existsSync(arg)) {
157
+ return JSON.parse(fs.readFileSync(arg, "utf-8"));
158
+ }
159
+ return JSON.parse(arg);
160
+ }
@@ -223,6 +223,90 @@ export function pairDevice(db, deviceName, deviceType) {
223
223
  return { deviceId, deviceName, deviceType, pairingCode, status: "pending" };
224
224
  }
225
225
 
226
+ /**
227
+ * v1.1 W3.5 (issue #19): Pair a device from a scanned QR payload.
228
+ *
229
+ * payload 字段对齐 desktop `device-pairing-handler.js::validatePairingCode`
230
+ * + Android `DesktopPairingViewModel::PairingQrPayload`:
231
+ * {type:"device-pairing", code, did, deviceInfo:{deviceId,name,platform}, timestamp}
232
+ *
233
+ * 与 [pairDevice] 区别:deviceId 来自 QR(移动端的稳定 ID)不是 host 生成,
234
+ * 这样 desktop unpair → 重扫 QR 能复用同 deviceId 而非每次生新条。INSERT OR
235
+ * REPLACE upsert,重复扫同一 QR 是 idempotent。
236
+ *
237
+ * Validate 项与 desktop validatePairingCode 对齐:
238
+ * - payload.type === "device-pairing"
239
+ * - payload.code 匹配 /^\d{6}$/
240
+ * - payload.did 非空
241
+ * - payload.deviceInfo.deviceId 非空
242
+ * - payload.timestamp 不超 5min(与 desktop pairingTimeout 对齐)
243
+ *
244
+ * 返回 {success: true, deviceId, deviceName, did, status:'active'}
245
+ * 或 {success: false, error}
246
+ */
247
+ export function pairDeviceFromQr(db, payload, opts = {}) {
248
+ ensureP2PTables(db);
249
+ const { now = Date.now(), maxAgeMs = 5 * 60 * 1000 } = opts;
250
+
251
+ if (!payload || typeof payload !== "object") {
252
+ return { success: false, error: "payload 不是对象" };
253
+ }
254
+ if (payload.type !== "device-pairing") {
255
+ return { success: false, error: "无效的 QR 类型,期望 device-pairing" };
256
+ }
257
+ if (!/^\d{6}$/.test(String(payload.code || ""))) {
258
+ return { success: false, error: "code 必须是 6 位数字" };
259
+ }
260
+ if (!payload.did || typeof payload.did !== "string") {
261
+ return { success: false, error: "did 必填" };
262
+ }
263
+ const info = payload.deviceInfo || {};
264
+ if (!info.deviceId || typeof info.deviceId !== "string") {
265
+ return { success: false, error: "deviceInfo.deviceId 必填" };
266
+ }
267
+ const ts = Number(payload.timestamp);
268
+ if (!Number.isFinite(ts)) {
269
+ return { success: false, error: "timestamp 必填且为数字" };
270
+ }
271
+ const age = now - ts;
272
+ if (age > maxAgeMs) {
273
+ return {
274
+ success: false,
275
+ error: `QR 已过期(${Math.round(age / 1000)}s > ${maxAgeMs / 1000}s)`,
276
+ };
277
+ }
278
+
279
+ const deviceName = info.name || "(unnamed)";
280
+ const platform = (info.platform || "mobile").toLowerCase();
281
+ // desktop validatePairingCode 接受 platform 为 string 不限值;这里 normalize
282
+ // 进 p2p_paired_devices.device_type 的 desktop/mobile/tablet 三档:
283
+ // - "android"/"ios" → "mobile"
284
+ // - 其它已知值保留
285
+ // - 缺省 "mobile"
286
+ const deviceType = ["mobile", "tablet", "desktop"].includes(platform)
287
+ ? platform
288
+ : ["android", "ios"].includes(platform)
289
+ ? "mobile"
290
+ : "mobile";
291
+
292
+ // INSERT OR REPLACE 让重复扫同 deviceId 是 idempotent;status="active" 因
293
+ // QR 流程的 6 位 code 视作 desktop 已确认,无需 pending 中间态。
294
+ db.prepare(
295
+ `INSERT OR REPLACE INTO p2p_paired_devices
296
+ (device_id, device_name, device_type, pairing_code, paired_at, status)
297
+ VALUES (?, ?, ?, ?, datetime('now'), 'active')`,
298
+ ).run(info.deviceId, deviceName, deviceType, payload.code);
299
+
300
+ return {
301
+ success: true,
302
+ deviceId: info.deviceId,
303
+ deviceName,
304
+ deviceType,
305
+ did: payload.did,
306
+ status: "active",
307
+ };
308
+ }
309
+
226
310
  /**
227
311
  * Confirm device pairing with code.
228
312
  */
@@ -242,10 +326,20 @@ export function confirmPairing(db, deviceId, code) {
242
326
  }
243
327
 
244
328
  /**
245
- * Get all paired devices.
329
+ * Get all paired devices, optionally filtered by device_type.
330
+ *
331
+ * v1.1 W3.4a (issue #19):`type` filter 让 web-panel MobileBridge.vue
332
+ * 只拉 mobile 子集。`type` 必须 ∈ {'desktop','mobile','tablet'} 或不传。
246
333
  */
247
- export function getPairedDevices(db) {
334
+ export function getPairedDevices(db, type = null) {
248
335
  ensureP2PTables(db);
336
+ if (type) {
337
+ return db
338
+ .prepare(
339
+ "SELECT * FROM p2p_paired_devices WHERE device_type = ? ORDER BY paired_at DESC",
340
+ )
341
+ .all(type);
342
+ }
249
343
  return db
250
344
  .prepare("SELECT * FROM p2p_paired_devices ORDER BY paired_at DESC")
251
345
  .all();
@@ -1 +0,0 @@
1
- import{f as b,r as M,o as Xe,x as rt,K as d,L as c,M as g,c as e,N as t,u as a,R as l,O as i,P as s,Q as $,F as U,Y as xe,Z as W,S as j,w as ut,I as dt,H as pt,_ as yt}from"./vendor-Ci2pTZ_t.js";import{u as et,_ as tt,E as mt,a as ft,b as kt,T as _t,c as gt,d as V}from"./index-D8S-7oDQ.js";import{u as K}from"./useShellMode-CgR0wCYM.js";import{B as pe,R as ht,F as z,G as x,D as ee,M as me,h as te,i as fe,j as ae,A as ke,N as _e,k as ge,l as he,m as ve,n as we,S as Le,o as $e,p as be,q as oe,r as Oe,s as Ce,t as Se,u as Ee,v as Re,w as Ae,x as Ne,P as Te,y as ne,K as se,z as T,H as je,J as Be,O as Pe,W as De,Q as ie,U as Ue,V as Ke,X as le,Y as Me,Z as Ie,_ as Fe,$ as Ve,a0 as ze,a1 as qe,a2 as We,a3 as Ge,a4 as Ye,a5 as He,a6 as Je,a7 as vt,a8 as Qe,e as wt,a9 as Lt}from"./icons-B2G69bhT.js";import $t from"./index-ZOpqRGzA.js";import"./KeyCode-D63Tfrq7.js";import"./omit-Bf31gUOR.js";import"./pickAttrs-CTOOvnV9.js";import"./initDefaultProps-BSTz5E8D.js";import"./motion-B10pjDA-.js";import"./raf-Deuc0E8-.js";import"./index-D3tqZAdL.js";import"./index-_Oe8Zr99.js";import"./isVisible-C7tPsqfj.js";import"./useState-4T1Ntfpx.js";import"./devWarning-CNIS3FrJ.js";import"./warning-Pq00owYb.js";import"./compact-item-CQUZCSRU.js";import"./createContext-DgOciZHM.js";import"./Compact-VsImrjgV.js";import"./_getTag-BVc6NQ_K.js";import"./styleChecker-CoQ2DFN_.js";import"./zoom-Beg44Pk9.js";import"./ActionButton-BpVrefl1.js";import"./vnode-CAFNU-3N.js";const bt=""+new URL("logo-DBCYUiWP.png",import.meta.url).href,w={notifications:M([]),unreadCount:M(0)};function q(v){if(v&&v.ok===!1)throw new Error(v.error||"notification handler failed");return v?.result??v}function Ot(){const v=et();async function B({limit:p=50,offset:r=0,isRead:f}={}){if(!K().isEmbedded)return w.notifications.value=[],w.unreadCount.value=0,w.notifications.value;const y=await v.sendRaw({type:"notification.list",limit:p,offset:r,isRead:f},15e3),L=q(y);if(L?.success===!1)throw new Error(L.error||"notification.list failed");return w.notifications.value=Array.isArray(L?.notifications)?L.notifications:[],await O(),w.notifications.value}async function O(){if(!K().isEmbedded)return w.unreadCount.value=0,0;const p=await v.sendRaw({type:"notification.unread-count"},1e4),r=q(p);return w.unreadCount.value=Number(r?.count)||0,w.unreadCount.value}async function h(p){if(p==null||p==="")throw new Error("id is required");if(!K().isEmbedded)return;const r=await v.sendRaw({type:"notification.mark-read",id:p},1e4),f=q(r);if(f?.success===!1)throw new Error(f.error||"notification.mark-read failed");const y=w.notifications.value.find(L=>L.id===p);y&&(y.is_read=1),await O()}async function C(){if(!K().isEmbedded)return;const p=await v.sendRaw({type:"notification.mark-all-read"},1e4),r=q(p);if(r?.success===!1)throw new Error(r.error||"notification.mark-all-read failed");for(const f of w.notifications.value)f.is_read=1;w.unreadCount.value=0}async function R(p,r=""){if(!K().isEmbedded)throw new Error("桌面通知仅在嵌入式 web-shell 中可用");const f=await v.sendRaw({type:"notification.send-desktop",title:p,body:r},1e4),y=q(f);if(y?.success===!1)throw new Error(y.error||"notification.send-desktop failed")}return{notifications:b(()=>w.notifications.value),unreadCount:b(()=>w.unreadCount.value),refresh:B,refreshUnreadCount:O,markRead:h,markAllRead:C,sendDesktop:R}}const Ct={class:"notif-toolbar"},St={class:"notif-body"},Et={key:2,class:"notif-list"},Rt=["onClick"],At={class:"notif-row"},Nt={class:"notif-title"},Tt={class:"notif-time"},jt={key:0,class:"notif-message"},Bt={__name:"NotificationBell",setup(v){const B=M(!1),O=M("all"),h=M(!1),{notifications:C,unreadCount:R,refresh:p,markRead:r,markAllRead:f}=Ot();function y(){Y()}Xe(()=>{window.addEventListener("cc:open-notification-drawer",y)}),rt(()=>{window.removeEventListener("cc:open-notification-drawer",y)});const L=b(()=>O.value==="unread"?C.value.filter(m=>!m.is_read):C.value);async function G(){if(K().isEmbedded){h.value=!0;try{await p({limit:100})}catch{}finally{h.value=!1}}}async function Y(){B.value=!0,await G()}async function H(m){if(!m.is_read)try{await r(m.id)}catch{}}async function J(){try{await f()}catch(m){console.warn("[NotificationBell] markAllRead failed:",m?.message||m)}}function ce(m){if(!m)return"";const k=typeof m=="string"?Date.parse(m):Number(m);if(!Number.isFinite(k))return String(m);const S=Date.now()-k,P=6e4,A=60*P,I=24*A;return S<P?"刚刚":S<A?`${Math.floor(S/P)} 分钟前`:S<I?`${Math.floor(S/A)} 小时前`:new Date(k).toLocaleDateString()}return(m,k)=>{const S=d("a-badge"),P=d("a-tooltip"),A=d("a-radio-button"),I=d("a-radio-group"),F=d("a-space"),Q=d("a-button"),re=d("a-empty"),ue=d("a-spin"),de=d("a-drawer");return c(),g(U,null,[e(P,{title:"通知"},{default:t(()=>[e(S,{count:a(R),"overflow-count":99,offset:[-4,4]},{default:t(()=>[l("button",{type:"button",class:"notif-bell-btn","aria-label":"通知",onClick:Y},[e(a(pe))])]),_:1},8,["count"])]),_:1}),e(de,{open:B.value,"onUpdate:open":k[1]||(k[1]=_=>B.value=_),title:"通知中心",placement:"right",width:400,"body-style":{padding:0}},{default:t(()=>[l("div",Ct,[e(F,null,{default:t(()=>[e(I,{value:O.value,"onUpdate:value":k[0]||(k[0]=_=>O.value=_),size:"small","button-style":"solid"},{default:t(()=>[e(A,{value:"all"},{default:t(()=>[i("全部 ("+s(a(C).length)+")",1)]),_:1}),e(A,{value:"unread"},{default:t(()=>[i("未读 ("+s(a(R))+")",1)]),_:1})]),_:1},8,["value"])]),_:1}),e(F,null,{default:t(()=>[e(Q,{size:"small",loading:h.value,onClick:G},{icon:t(()=>[e(a(ht))]),_:1},8,["loading"]),e(Q,{size:"small",disabled:a(R)===0,onClick:J},{default:t(()=>[...k[2]||(k[2]=[i(" 全部已读 ",-1)])]),_:1},8,["disabled"])]),_:1})]),l("div",St,[!h.value&&L.value.length===0?(c(),$(re,{key:0,description:"暂无通知",image:a(mt).PRESENTED_IMAGE_SIMPLE,style:{padding:"60px 0"}},null,8,["image"])):h.value?(c(),$(ue,{key:1,style:{display:"block",padding:"60px"}})):(c(),g("ul",Et,[(c(!0),g(U,null,xe(L.value,_=>(c(),g("li",{key:_.id,class:W(["notif-item",{unread:!_.is_read}]),onClick:n=>H(_)},[l("div",At,[l("div",Nt,s(_.title||_.message||"(无标题)"),1),l("span",Tt,s(ce(_.created_at)),1)]),_.message&&_.title?(c(),g("div",jt,s(_.message),1)):j("",!0)],10,Rt))),128))]))])]),_:1},8,["open"])],64)}}},Pt=tt(Bt,[["__scopeId","data-v-af539070"]]),Dt=["src"],Ut={key:0,class:"logo-text"},Kt={key:0,class:"mode-banner project"},Mt={class:"banner-info"},It={class:"banner-name"},Ft={class:"banner-sub"},Vt={key:1,class:"mode-banner global"},zt={class:"banner-name"},qt=["title"],Wt={class:"group-label"},Gt={class:"group-label"},Yt={class:"group-label"},Ht={class:"group-label"},Jt={class:"group-label"},Qt={class:"group-label"},Zt={class:"group-label"},Xt={class:"group-label"},xt={class:"group-label"},ea={key:0,class:"footer-text"},ta={class:"header-left"},aa={class:"header-right"},oa={class:"theme-switcher"},na=["data-theme-key","onClick"],sa=["data-locale"],ia={class:"lang-switch-label"},la={class:"version-tag"},Ze="cc.web-panel.sidebar.openKeys",ca={__name:"AppLayout",setup(v){const B=dt(),O=pt(),h=et(),C=ft(),{t:R}=kt(),p=K(),r=M(!1),f=window.__CC_CONFIG__||{},y=b(()=>f.mode==="project"),L="v5.0.3.48",G=b(()=>C.current),Y=b(()=>C.config.vars["--menu-mode"]),H=b(()=>{const n=O.name?.toLowerCase()||"dashboard";return[{mcptools:"mcp",quickask:"quick-ask",ukeysign:"ukey-sign"}[n]||n]}),J=["g-overview","g-config","g-data","g-advanced","g-enterprise","g-social","g-media","g-extension"];function ce(){try{const n=localStorage.getItem(Ze);if(n){const u=JSON.parse(n);if(Array.isArray(u))return u.filter(o=>J.includes(o))}}catch{}return[...J]}const m=M(ce());ut(m,n=>{try{localStorage.setItem(Ze,JSON.stringify(n))}catch{}},{deep:!0});const k=b(()=>h.status),S=b(()=>({connected:"success",connecting:"processing",error:"error",disconnected:"default"})[h.status]||"default"),P=b(()=>{const n=`appLayout.footerStatus.${h.status}`,u=R(n);return u===n?R("appLayout.footerStatus.unknown"):u});function A(n){C.setTheme(n)}const{current:I,supported:F,setLocale:Q}=gt();function re(){const n=F[(F.indexOf(I.value)+1)%F.length];Q(n)}async function ue(n){try{const u=await h.sendRaw({type:"window.open",role:n},1e4);if(u?.ok===!1){V.error(`打开失败:${u.error||"未知"}`);return}const o=u?.result??u;o?.reason==="role_reserved"?V.warning("该窗口角色被保留"):o?.reason}catch(u){V.error(`打开桌面窗口失败:${u.message||u}`)}}async function de(){$t.confirm({title:"切换到桌面壳?",content:"回到 V5/V6 桌面壳。完整 electronAPI 表面(UKey 硬件 / 原生对话框 / 系统设置等)会重新可用,但失去 web-panel 的 SPA 体验。保存后需要重启应用才生效。",okText:"切换并重启",cancelText:"取消",centered:!0,async onOk(){try{const n=await h.sendRaw({type:"shell.switch",target:"desktop"},5e3);if(n?.ok===!1)throw new Error(n.error||"shell.switch returned failure");V.loading({content:"正在重启…",duration:0})}catch(n){const u=n instanceof Error?n.message:String(n);V.error("切换失败:"+u)}}})}function _({key:n}){if(typeof n=="string"&&n.startsWith("desktop:")){ue(n);return}B.push({mcp:"/mcp"}[n]||`/${n}`)}return Xe(()=>h.connect()),(n,u)=>{const o=d("a-menu-item"),E=d("a-sub-menu"),D=d("a-menu-divider"),at=d("a-menu"),ot=d("a-badge"),nt=d("a-layout-sider"),Z=d("a-tooltip"),st=d("a-tag"),it=d("a-layout-header"),lt=d("router-view"),ct=d("a-layout-content"),ye=d("a-layout");return c(),$(ye,{class:"app-root"},{default:t(()=>[e(nt,{collapsed:r.value,"onUpdate:collapsed":u[2]||(u[2]=N=>r.value=N),collapsible:"","collapsed-width":56,width:216,class:"sidebar"},{default:t(()=>[l("div",{class:W(["logo",{collapsed:r.value}])},[l("img",{src:a(bt),alt:"ChainlessChain",class:"logo-icon"},null,8,Dt),r.value?j("",!0):(c(),g("span",Ut,"ChainlessChain"))],2),r.value?(c(),g("div",{key:1,class:"mode-icon-sm",title:y.value?a(f).projectName:n.$t("appLayout.scope.global")},[y.value?(c(),$(a(z),{key:0,style:{color:"#1677ff"}})):(c(),$(a(x),{key:1,style:{color:"#722ed1"}}))],8,qt)):(c(),g(U,{key:0},[y.value?(c(),g("div",Kt,[e(a(z),{class:"banner-icon"}),l("div",Mt,[l("div",It,s(a(f).projectName||n.$t("appLayout.scope.fallbackProject")),1),l("div",Ft,s(n.$t("appLayout.scope.projectPanel")),1)])])):(c(),g("div",Vt,[e(a(x),{class:"banner-icon"}),l("span",zt,s(n.$t("appLayout.scope.global")),1)]))],64)),e(at,{selectedKeys:H.value,"onUpdate:selectedKeys":u[0]||(u[0]=N=>H.value=N),openKeys:m.value,"onUpdate:openKeys":u[1]||(u[1]=N=>m.value=N),theme:Y.value,mode:"inline","inline-collapsed":r.value,class:"side-menu",onClick:_},{default:t(()=>[r.value?(c(),g(U,{key:1},[e(o,{key:"dashboard"},{icon:t(()=>[e(a(ee))]),_:1}),e(o,{key:"chat"},{icon:t(()=>[e(a(me))]),_:1}),e(o,{key:"quick-ask"},{icon:t(()=>[e(a(te))]),_:1}),e(o,{key:"cowork"},{icon:t(()=>[e(a(fe))]),_:1}),e(o,{key:"services"},{icon:t(()=>[e(a(ae))]),_:1}),e(o,{key:"aiops"},{icon:t(()=>[e(a(ke))]),_:1}),e(o,{key:"tokens"},{icon:t(()=>[e(a(_e))]),_:1}),e(o,{key:"logs"},{icon:t(()=>[e(a(ge))]),_:1}),e(D,{class:"divider-sm"}),e(o,{key:"skills"},{icon:t(()=>[e(a(he))]),_:1}),e(o,{key:"providers"},{icon:t(()=>[e(a(ve))]),_:1}),e(o,{key:"mcp"},{icon:t(()=>[e(a(we))]),_:1}),e(o,{key:"project-settings"},{icon:t(()=>[e(a(z))]),_:1}),e(o,{key:"speech-settings"},{icon:t(()=>[e(a(Le))]),_:1}),e(o,{key:"notification-settings"},{icon:t(()=>[e(a(pe))]),_:1}),e(o,{key:"sync-settings"},{icon:t(()=>[e(a($e))]),_:1}),e(o,{key:"nlprog"},{icon:t(()=>[e(a(be))]),_:1}),e(o,{key:"codegen"},{icon:t(()=>[e(a(oe))]),_:1}),e(D,{class:"divider-sm"}),e(o,{key:"notes"},{icon:t(()=>[e(a(Oe))]),_:1}),e(o,{key:"search"},{icon:t(()=>[e(a(Ce))]),_:1}),e(o,{key:"memory"},{icon:t(()=>[e(a(Se))]),_:1}),e(o,{key:"knowledge"},{icon:t(()=>[e(a(Ee))]),_:1}),e(o,{key:"marketplace"},{icon:t(()=>[e(a(Re))]),_:1}),e(o,{key:"cron"},{icon:t(()=>[e(a(Ae))]),_:1}),e(o,{key:"workflow"},{icon:t(()=>[e(a(Ne))]),_:1}),e(o,{key:"pipeline"},{icon:t(()=>[e(a(Te))]),_:1}),e(o,{key:"tasks"},{icon:t(()=>[e(a(te))]),_:1}),e(D,{class:"divider-sm"}),e(o,{key:"security"},{icon:t(()=>[e(a(ne))]),_:1}),e(o,{key:"ukey-sign"},{icon:t(()=>[e(a(se))]),_:1}),e(o,{key:"trust"},{icon:t(()=>[e(a(T))]),_:1}),e(o,{key:"audit"},{icon:t(()=>[e(a(je))]),_:1}),e(o,{key:"mtc"},{icon:t(()=>[e(a(T))]),_:1}),e(o,{key:"mtc-audit"},{icon:t(()=>[e(a(T))]),_:1}),e(o,{key:"did"},{icon:t(()=>[e(a(Be))]),_:1}),e(o,{key:"permissions"},{icon:t(()=>[e(a(Pe))]),_:1}),e(o,{key:"p2p"},{icon:t(()=>[e(a(De))]),_:1}),e(o,{key:"backup"},{icon:t(()=>[e(a(ie))]),_:1}),e(o,{key:"git"},{icon:t(()=>[e(a(oe))]),_:1}),e(o,{key:"projects"},{icon:t(()=>[e(a(Ue))]),_:1}),e(o,{key:"crosschain"},{icon:t(()=>[e(a(Ke))]),_:1}),e(o,{key:"compliance"},{icon:t(()=>[e(a(T))]),_:1}),e(o,{key:"privacy"},{icon:t(()=>[e(a(le))]),_:1}),e(o,{key:"inference"},{icon:t(()=>[e(a(Me))]),_:1}),e(o,{key:"federation"},{icon:t(()=>[e(a(Ie))]),_:1}),e(D,{class:"divider-sm"}),e(o,{key:"wallet"},{icon:t(()=>[e(a(Fe))]),_:1}),e(o,{key:"organization"},{icon:t(()=>[e(a(Ve))]),_:1}),e(o,{key:"tenant"},{icon:t(()=>[e(a(ze))]),_:1}),e(o,{key:"sla"},{icon:t(()=>[e(a(ee))]),_:1}),e(o,{key:"analytics"},{icon:t(()=>[e(a(qe))]),_:1}),e(o,{key:"templates"},{icon:t(()=>[e(a(We))]),_:1}),e(D,{class:"divider-sm"}),e(o,{key:"community"},{icon:t(()=>[e(a(Ge))]),_:1}),e(o,{key:"governance"},{icon:t(()=>[e(a(Ye))]),_:1}),e(o,{key:"reputation"},{icon:t(()=>[e(a(He))]),_:1}),e(o,{key:"recommend"},{icon:t(()=>[e(a(Je))]),_:1}),e(D,{class:"divider-sm"}),e(o,{key:"rssfeed"},{icon:t(()=>[e(a(Qe))]),_:1}),e(o,{key:"webauthn"},{icon:t(()=>[e(a(se))]),_:1}),a(p).isEmbedded?(c(),g(U,{key:0},[e(D,{class:"divider-sm"}),e(o,{key:"desktop:hardware-wallet"},{icon:t(()=>[e(a(ne))]),_:1}),e(o,{key:"desktop:backup-dashboard"},{icon:t(()=>[e(a(ie))]),_:1}),e(o,{key:"desktop:llm-test-chat"},{icon:t(()=>[e(a(le))]),_:1}),e(o,{key:"desktop:settings"},{icon:t(()=>[e(a(ae))]),_:1})],64)):j("",!0)],64)):(c(),g(U,{key:0},[e(E,{key:"g-overview"},{title:t(()=>[l("span",Wt,s(n.$t("appLayout.groups.overview")),1)]),default:t(()=>[e(o,{key:"dashboard"},{icon:t(()=>[e(a(ee))]),default:t(()=>[i(s(n.$t("appLayout.items.dashboard")),1)]),_:1}),e(o,{key:"chat"},{icon:t(()=>[e(a(me))]),default:t(()=>[i(s(n.$t("appLayout.items.chat")),1)]),_:1}),e(o,{key:"quick-ask"},{icon:t(()=>[e(a(te))]),default:t(()=>[i(s(n.$t("appLayout.items.quickAsk")),1)]),_:1}),e(o,{key:"cowork"},{icon:t(()=>[e(a(fe))]),default:t(()=>[i(s(n.$t("appLayout.items.cowork")),1)]),_:1}),e(o,{key:"services"},{icon:t(()=>[e(a(ae))]),default:t(()=>[i(s(n.$t("appLayout.items.services")),1)]),_:1}),e(o,{key:"aiops"},{icon:t(()=>[e(a(ke))]),default:t(()=>[i(s(n.$t("appLayout.items.aiops")),1)]),_:1}),e(o,{key:"tokens"},{icon:t(()=>[e(a(_e))]),default:t(()=>[i(s(n.$t("appLayout.items.tokens")),1)]),_:1}),e(o,{key:"logs"},{icon:t(()=>[e(a(ge))]),default:t(()=>[i(s(n.$t("appLayout.items.logs")),1)]),_:1})]),_:1}),e(E,{key:"g-config"},{title:t(()=>[l("span",Gt,s(n.$t("appLayout.groups.config")),1)]),default:t(()=>[e(o,{key:"skills"},{icon:t(()=>[e(a(he))]),default:t(()=>[i(s(n.$t("appLayout.items.skills")),1)]),_:1}),e(o,{key:"providers"},{icon:t(()=>[e(a(ve))]),default:t(()=>[i(s(n.$t("appLayout.items.providers")),1)]),_:1}),e(o,{key:"mcp"},{icon:t(()=>[e(a(we))]),default:t(()=>[i(s(n.$t("appLayout.items.mcp")),1)]),_:1}),e(o,{key:"project-settings"},{icon:t(()=>[e(a(z))]),default:t(()=>[i(s(n.$t("appLayout.items.projectSettings")),1)]),_:1}),e(o,{key:"speech-settings"},{icon:t(()=>[e(a(Le))]),default:t(()=>[i(s(n.$t("appLayout.items.speechSettings")),1)]),_:1}),e(o,{key:"notification-settings"},{icon:t(()=>[e(a(pe))]),default:t(()=>[i(s(n.$t("appLayout.items.notificationSettings")),1)]),_:1}),e(o,{key:"sync-settings"},{icon:t(()=>[e(a($e))]),default:t(()=>[i(s(n.$t("appLayout.items.syncSettings")),1)]),_:1}),e(o,{key:"nlprog"},{icon:t(()=>[e(a(be))]),default:t(()=>[i(s(n.$t("appLayout.items.nlprog")),1)]),_:1}),e(o,{key:"codegen"},{icon:t(()=>[e(a(oe))]),default:t(()=>[i(s(n.$t("appLayout.items.codegen")),1)]),_:1})]),_:1}),e(E,{key:"g-data"},{title:t(()=>[l("span",Yt,s(n.$t("appLayout.groups.data")),1)]),default:t(()=>[e(o,{key:"notes"},{icon:t(()=>[e(a(Oe))]),default:t(()=>[i(s(n.$t("appLayout.items.notes")),1)]),_:1}),e(o,{key:"search"},{icon:t(()=>[e(a(Ce))]),default:t(()=>[i(s(n.$t("appLayout.items.search")),1)]),_:1}),e(o,{key:"memory"},{icon:t(()=>[e(a(Se))]),default:t(()=>[i(s(n.$t("appLayout.items.memory")),1)]),_:1}),e(o,{key:"knowledge"},{icon:t(()=>[e(a(Ee))]),default:t(()=>[i(s(n.$t("appLayout.items.knowledge")),1)]),_:1}),e(o,{key:"marketplace"},{icon:t(()=>[e(a(Re))]),default:t(()=>[i(s(n.$t("appLayout.items.marketplace")),1)]),_:1}),e(o,{key:"cron"},{icon:t(()=>[e(a(Ae))]),default:t(()=>[i(s(n.$t("appLayout.items.cron")),1)]),_:1}),e(o,{key:"workflow"},{icon:t(()=>[e(a(Ne))]),default:t(()=>[i(s(n.$t("appLayout.items.workflow")),1)]),_:1}),e(o,{key:"pipeline"},{icon:t(()=>[e(a(Te))]),default:t(()=>[i(s(n.$t("appLayout.items.pipeline")),1)]),_:1}),e(o,{key:"tasks"},{icon:t(()=>[e(a(te))]),default:t(()=>[i(s(n.$t("appLayout.items.tasks")),1)]),_:1})]),_:1}),e(E,{key:"g-advanced"},{title:t(()=>[l("span",Ht,s(n.$t("appLayout.groups.advanced")),1)]),default:t(()=>[e(o,{key:"security"},{icon:t(()=>[e(a(ne))]),default:t(()=>[i(s(n.$t("appLayout.items.security")),1)]),_:1}),e(o,{key:"ukey-sign"},{icon:t(()=>[e(a(se))]),default:t(()=>[i(s(n.$t("appLayout.items.ukeySign")),1)]),_:1}),e(o,{key:"trust"},{icon:t(()=>[e(a(T))]),default:t(()=>[i(s(n.$t("appLayout.items.trust")),1)]),_:1}),e(o,{key:"audit"},{icon:t(()=>[e(a(je))]),default:t(()=>[i(s(n.$t("appLayout.items.audit")),1)]),_:1}),e(o,{key:"mtc"},{icon:t(()=>[e(a(T))]),default:t(()=>[i(s(n.$t("appLayout.items.mtc")),1)]),_:1}),e(o,{key:"mtc-audit"},{icon:t(()=>[e(a(T))]),default:t(()=>[i(s(n.$t("appLayout.items.mtcAudit","MTC 审计")),1)]),_:1}),e(o,{key:"did"},{icon:t(()=>[e(a(Be))]),default:t(()=>[i(s(n.$t("appLayout.items.did")),1)]),_:1}),e(o,{key:"permissions"},{icon:t(()=>[e(a(Pe))]),default:t(()=>[i(s(n.$t("appLayout.items.permissions")),1)]),_:1}),e(o,{key:"p2p"},{icon:t(()=>[e(a(De))]),default:t(()=>[i(s(n.$t("appLayout.items.p2p")),1)]),_:1}),e(o,{key:"backup"},{icon:t(()=>[e(a(ie))]),default:t(()=>[i(s(n.$t("appLayout.items.backup")),1)]),_:1}),e(o,{key:"git"},{icon:t(()=>[e(a(oe))]),default:t(()=>[i(s(n.$t("appLayout.items.git")),1)]),_:1}),e(o,{key:"projects"},{icon:t(()=>[e(a(Ue))]),default:t(()=>[i(s(n.$t("appLayout.items.projects")),1)]),_:1}),e(o,{key:"crosschain"},{icon:t(()=>[e(a(Ke))]),default:t(()=>[i(s(n.$t("appLayout.items.crosschain")),1)]),_:1}),e(o,{key:"compliance"},{icon:t(()=>[e(a(T))]),default:t(()=>[i(s(n.$t("appLayout.items.compliance")),1)]),_:1}),e(o,{key:"privacy"},{icon:t(()=>[e(a(le))]),default:t(()=>[i(s(n.$t("appLayout.items.privacy")),1)]),_:1}),e(o,{key:"inference"},{icon:t(()=>[e(a(Me))]),default:t(()=>[i(s(n.$t("appLayout.items.inference")),1)]),_:1}),e(o,{key:"federation"},{icon:t(()=>[e(a(Ie))]),default:t(()=>[i(s(n.$t("appLayout.items.federation")),1)]),_:1})]),_:1}),e(E,{key:"g-enterprise"},{title:t(()=>[l("span",Jt,s(n.$t("appLayout.groups.enterprise")),1)]),default:t(()=>[e(o,{key:"wallet"},{icon:t(()=>[e(a(Fe))]),default:t(()=>[i(s(n.$t("appLayout.items.wallet")),1)]),_:1}),e(o,{key:"organization"},{icon:t(()=>[e(a(Ve))]),default:t(()=>[i(s(n.$t("appLayout.items.organization")),1)]),_:1}),e(o,{key:"tenant"},{icon:t(()=>[e(a(ze))]),default:t(()=>[i(s(n.$t("appLayout.items.tenant")),1)]),_:1}),e(o,{key:"sla"},{icon:t(()=>[e(a(ee))]),default:t(()=>[i(s(n.$t("appLayout.items.sla")),1)]),_:1}),e(o,{key:"analytics"},{icon:t(()=>[e(a(qe))]),default:t(()=>[i(s(n.$t("appLayout.items.analytics")),1)]),_:1}),e(o,{key:"templates"},{icon:t(()=>[e(a(We))]),default:t(()=>[i(s(n.$t("appLayout.items.templates")),1)]),_:1})]),_:1}),e(E,{key:"g-social"},{title:t(()=>[l("span",Qt,s(n.$t("appLayout.groups.social")),1)]),default:t(()=>[e(o,{key:"community"},{icon:t(()=>[e(a(Ge))]),default:t(()=>[i(s(n.$t("appLayout.items.community")),1)]),_:1}),e(o,{key:"governance"},{icon:t(()=>[e(a(Ye))]),default:t(()=>[i(s(n.$t("appLayout.items.governance")),1)]),_:1}),e(o,{key:"reputation"},{icon:t(()=>[e(a(He))]),default:t(()=>[i(s(n.$t("appLayout.items.reputation")),1)]),_:1}),e(o,{key:"recommend"},{icon:t(()=>[e(a(Je))]),default:t(()=>[i(s(n.$t("appLayout.items.recommend")),1)]),_:1})]),_:1}),e(E,{key:"g-media"},{title:t(()=>[l("span",Zt,s(n.$t("appLayout.groups.media")),1)]),default:t(()=>[e(o,{key:"video"},{icon:t(()=>[e(a(vt))]),default:t(()=>[i(s(n.$t("appLayout.items.video")),1)]),_:1})]),_:1}),e(E,{key:"g-extension"},{title:t(()=>[l("span",Xt,s(n.$t("appLayout.groups.extension")),1)]),default:t(()=>[e(o,{key:"rssfeed"},{icon:t(()=>[e(a(Qe))]),default:t(()=>[i(s(n.$t("appLayout.items.rssfeed")),1)]),_:1}),e(o,{key:"webauthn"},{icon:t(()=>[e(a(se))]),default:t(()=>[i(s(n.$t("appLayout.items.webauthn")),1)]),_:1})]),_:1}),a(p).isEmbedded?(c(),$(E,{key:"g-desktop"},{title:t(()=>[l("span",xt,s(n.$t("appLayout.groups.desktop")),1)]),default:t(()=>[e(o,{key:"desktop:hardware-wallet"},{icon:t(()=>[e(a(ne))]),default:t(()=>[i(s(n.$t("appLayout.items.desktopHardware")),1)]),_:1}),e(o,{key:"desktop:backup-dashboard"},{icon:t(()=>[e(a(ie))]),default:t(()=>[i(s(n.$t("appLayout.items.desktopBackup")),1)]),_:1}),e(o,{key:"desktop:llm-test-chat"},{icon:t(()=>[e(a(le))]),default:t(()=>[i(s(n.$t("appLayout.items.desktopLlmTest")),1)]),_:1}),e(o,{key:"desktop:settings"},{icon:t(()=>[e(a(ae))]),default:t(()=>[i(s(n.$t("appLayout.items.desktopSettings")),1)]),_:1})]),_:1})):j("",!0)],64))]),_:1},8,["selectedKeys","openKeys","theme","inline-collapsed"]),l("div",{class:W(["sidebar-footer",{collapsed:r.value}])},[e(ot,{status:S.value},null,8,["status"]),r.value?j("",!0):(c(),g("span",ea,s(P.value),1))],2)]),_:1},8,["collapsed"]),e(ye,{class:"main-area"},{default:t(()=>[e(it,{class:"app-header"},{default:t(()=>[l("div",ta,[l("div",{class:W(["scope-tag",y.value?"project":"global"])},[(c(),$(yt(y.value?a(z):a(x)))),l("span",null,s(y.value?a(f).projectName||n.$t("appLayout.scope.fallbackProject"):n.$t("appLayout.scope.global")),1),y.value&&a(f).projectRoot?(c(),$(Z,{key:0,title:a(f).projectRoot},{default:t(()=>[e(a(wt),{class:"info-icon"})]),_:1},8,["title"])):j("",!0)],2)]),l("div",aa,[l("div",oa,[(c(!0),g(U,null,xe(a(_t),(N,X)=>(c(),$(Z,{key:X,title:N.label},{default:t(()=>[l("button",{class:W(["theme-btn",{active:G.value===X}]),"data-theme-key":X,onClick:ra=>A(X)},s(N.icon),11,na)]),_:2},1032,["title"]))),128))]),e(Z,{title:n.$t("language.label")},{default:t(()=>[l("button",{class:"lang-switch-btn","data-locale":a(I),onClick:re},[e(a(x),{class:"lang-switch-icon"}),l("span",ia,s(n.$t("language.switch")),1)],8,sa)]),_:1},8,["title"]),a(p).isEmbedded?(c(),$(Pt,{key:0})):j("",!0),l("span",la,s(a(L)),1),a(p).isEmbedded?(c(),$(Z,{key:1,title:n.$t("appLayout.shellSwitch")},{default:t(()=>[l("button",{type:"button",class:"shell-switch-btn",onClick:de},[e(a(Lt))])]),_:1},8,["title"])):j("",!0),e(st,{color:k.value==="connected"?"green":k.value==="connecting"?"orange":"red",class:"ws-tag"},{default:t(()=>[i(s(k.value==="connected"?n.$t("appLayout.wsStatus.connected"):k.value==="connecting"?n.$t("appLayout.wsStatus.connecting"):n.$t("appLayout.wsStatus.disconnected")),1)]),_:1},8,["color"])])]),_:1}),e(ct,{class:"page-content"},{default:t(()=>[e(lt)]),_:1})]),_:1})]),_:1})}}},Pa=tt(ca,[["__scopeId","data-v-6636ff75"]]);export{Pa as default};