chainlesschain 0.162.40 → 0.162.41

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 (162) hide show
  1. package/package.json +1 -1
  2. package/src/assets/web-panel/assets/{AIOps-CPmKv82o.js → AIOps-Ut7EevnG.js} +1 -1
  3. package/src/assets/web-panel/assets/{ActionButton-BNDYY7Qd.js → ActionButton-Dv6BlfJg.js} +1 -1
  4. package/src/assets/web-panel/assets/{Analytics-BgCMCOsk.js → Analytics-TQVQuJ7u.js} +3 -3
  5. package/src/assets/web-panel/assets/{AppLayout-Dv4oJcqS.js → AppLayout-MSqLm2WK.js} +5 -5
  6. package/src/assets/web-panel/assets/{Audit-5iV3yrGa.js → Audit-mw81HwVy.js} +1 -1
  7. package/src/assets/web-panel/assets/{Backup-CHDhnbzF.js → Backup-BQcPWDb1.js} +1 -1
  8. package/src/assets/web-panel/assets/{BaseInput-B6reFkra.js → BaseInput-BYo_pwBH.js} +1 -1
  9. package/src/assets/web-panel/assets/{Chat-DwS5YyE2.js → Chat-zi3YUKx2.js} +6 -6
  10. package/src/assets/web-panel/assets/{ChatBubbleRenderer-CqXa87Hw.js → ChatBubbleRenderer-DWSm1XJJ.js} +1 -1
  11. package/src/assets/web-panel/assets/{Checkbox-yiW0M4RE.js → Checkbox-BvC8Erjt.js} +1 -1
  12. package/src/assets/web-panel/assets/{Codegen-DoiVuD_g.js → Codegen-C32vx0OP.js} +1 -1
  13. package/src/assets/web-panel/assets/{Col-BVASLexk.js → Col-DMBwmqyZ.js} +1 -1
  14. package/src/assets/web-panel/assets/{Community-D6KQ7JoU.js → Community-nDWncmKV.js} +1 -1
  15. package/src/assets/web-panel/assets/{Compact-Bl9Uhb6v.js → Compact-lIc1HFn8.js} +1 -1
  16. package/src/assets/web-panel/assets/{Compliance-MM31-dba.js → Compliance-D14I_gd2.js} +1 -1
  17. package/src/assets/web-panel/assets/{Cowork-PjU_1ieD.js → Cowork-BiNI-_ZL.js} +3 -3
  18. package/src/assets/web-panel/assets/{Cron-DorNtPZL.js → Cron-N13sFzHb.js} +2 -2
  19. package/src/assets/web-panel/assets/{Crosschain-Bm5ts2Kw.js → Crosschain-Dlnl0-v6.js} +1 -1
  20. package/src/assets/web-panel/assets/{DID-7Y3jlFdY.js → DID-CxtYS31I.js} +2 -2
  21. package/src/assets/web-panel/assets/{Dashboard-1oE532bG.js → Dashboard-G4UnHlTR.js} +2 -2
  22. package/src/assets/web-panel/assets/{Dropdown-hJlOPs0s.js → Dropdown-BazlxFGY.js} +1 -1
  23. package/src/assets/web-panel/assets/{EmailListRenderer-BEqJxKaO.js → EmailListRenderer-BrpNdihm.js} +1 -1
  24. package/src/assets/web-panel/assets/{FamilyGuardDashboard-BvCGwB6X.js → FamilyGuardDashboard-HD7jbOOR.js} +1 -1
  25. package/src/assets/web-panel/assets/{Federation-CsXI72e5.js → Federation-Bz8lzAGI.js} +1 -1
  26. package/src/assets/web-panel/assets/{FormItemContext-Dh9SMul-.js → FormItemContext-CcyzGS00.js} +1 -1
  27. package/src/assets/web-panel/assets/{GenericCardRenderer-9edWzrtG.js → GenericCardRenderer-DRo9cwmp.js} +1 -1
  28. package/src/assets/web-panel/assets/{Git-ZYhNL8Xk.js → Git-B7bn333J.js} +2 -2
  29. package/src/assets/web-panel/assets/{Governance-BwAdp8QA.js → Governance-DZX9CWAM.js} +1 -1
  30. package/src/assets/web-panel/assets/{Inference-5C-M1XsH.js → Inference-B3XhsL6W.js} +1 -1
  31. package/src/assets/web-panel/assets/{KnowledgeGraph-zFAi-zCi.js → KnowledgeGraph-CxFRTlQe.js} +1 -1
  32. package/src/assets/web-panel/assets/{Logs-BZsEdbgE.js → Logs-xuys6mKH.js} +2 -2
  33. package/src/assets/web-panel/assets/{Marketplace-BP6gErRK.js → Marketplace-CXyxv4WU.js} +1 -1
  34. package/src/assets/web-panel/assets/{McpTools-CXVzoLrd.js → McpTools-BzZLQVI3.js} +5 -5
  35. package/src/assets/web-panel/assets/{Memory-BIpChb4-.js → Memory-BANtaBa7.js} +2 -2
  36. package/src/assets/web-panel/assets/{MobileBridge-B4O7wDT8.js → MobileBridge-BJIwjmxr.js} +2 -2
  37. package/src/assets/web-panel/assets/MobileProjects-B857uSAZ.js +1 -0
  38. package/src/assets/web-panel/assets/{Mtc-BTmEyTM5.js → Mtc-Cn7ceFEz.js} +6 -6
  39. package/src/assets/web-panel/assets/{MtcAudit-CsbG9LlV.js → MtcAudit-B0zE978G.js} +2 -2
  40. package/src/assets/web-panel/assets/{Multisig-CL8yoGon.js → Multisig-CQFT0wXW.js} +3 -3
  41. package/src/assets/web-panel/assets/{NLProgramming-C2cIlIp_.js → NLProgramming-DSxKdVY-.js} +1 -1
  42. package/src/assets/web-panel/assets/{Notes-7aBk_n_M.js → Notes-DtlTfam8.js} +3 -3
  43. package/src/assets/web-panel/assets/{NotificationSettings-BuhQk4rJ.js → NotificationSettings-CHQwayAg.js} +1 -1
  44. package/src/assets/web-panel/assets/{OrderTableRenderer-mqMFZu0x.js → OrderTableRenderer-Brpmzh9n.js} +1 -1
  45. package/src/assets/web-panel/assets/{Organization-CAdq-170.js → Organization-nF_tzZDT.js} +4 -4
  46. package/src/assets/web-panel/assets/{Overflow--Xn0E787.js → Overflow-CgCSf_PH.js} +1 -1
  47. package/src/assets/web-panel/assets/{P2P-DYt3YAXI.js → P2P-Bvn46bLY.js} +2 -2
  48. package/src/assets/web-panel/assets/{PdhVaultBrowser-Bgb_v8WN.js → PdhVaultBrowser-Bzl9k7Gj.js} +5 -5
  49. package/src/assets/web-panel/assets/{Permissions-DoFlmoaW.js → Permissions-Dmezbuo8.js} +4 -4
  50. package/src/assets/web-panel/assets/{PersonalDataHub-C-FJB3a0.js → PersonalDataHub-lCKRxwZr.js} +2 -2
  51. package/src/assets/web-panel/assets/{Pipeline-3bL2RzzL.js → Pipeline-DDCGm9PA.js} +1 -1
  52. package/src/assets/web-panel/assets/{Privacy-c4igYUCF.js → Privacy-Cgu18Kjl.js} +1 -1
  53. package/src/assets/web-panel/assets/{ProjectInit-C0QS1UPR.js → ProjectInit-CkF1AeRY.js} +2 -2
  54. package/src/assets/web-panel/assets/{ProjectSettings-CkYC0xkE.js → ProjectSettings-D0Q-orz1.js} +2 -2
  55. package/src/assets/web-panel/assets/Projects-KfGELrSY.js +1 -0
  56. package/src/assets/web-panel/assets/{Providers-41NySsLt.js → Providers-BACLV0z8.js} +1 -1
  57. package/src/assets/web-panel/assets/{QuickAsk-DHq9pD7z.js → QuickAsk-CPsZUqDl.js} +1 -1
  58. package/src/assets/web-panel/assets/{Recommend-CLjgFPLv.js → Recommend-5jX0OI1-.js} +1 -1
  59. package/src/assets/web-panel/assets/{Reputation-EIrgErm3.js → Reputation-5JKv54z0.js} +1 -1
  60. package/src/assets/web-panel/assets/{Row-GAvKzKH7.js → Row-DLiTF5LY.js} +1 -1
  61. package/src/assets/web-panel/assets/{RssFeed-CYCNsVmD.js → RssFeed-CFdGmCKW.js} +3 -3
  62. package/src/assets/web-panel/assets/{Search-DWOE32k8.js → Search-BjIOnmA7.js} +1 -1
  63. package/src/assets/web-panel/assets/{Security-Dgh8Jevn.js → Security-BujPqQSo.js} +4 -4
  64. package/src/assets/web-panel/assets/{Services-BxdgP67N.js → Services-ChciPnMu.js} +2 -2
  65. package/src/assets/web-panel/assets/{Skeleton-D-xT4ZkA.js → Skeleton-Cwswp1Jv.js} +1 -1
  66. package/src/assets/web-panel/assets/{Skills-BKN4lfSa.js → Skills-CtwR4vJV.js} +1 -1
  67. package/src/assets/web-panel/assets/{Sla--N1TudpS.js → Sla-pRIevich.js} +1 -1
  68. package/src/assets/web-panel/assets/{SpeechSettings-B0vfJpEh.js → SpeechSettings-BRqB28Ai.js} +1 -1
  69. package/src/assets/web-panel/assets/{SyncSettings-BuBAbPAh.js → SyncSettings-BYyj58_h.js} +2 -2
  70. package/src/assets/web-panel/assets/Tasks-DTLpT48U.js +1 -0
  71. package/src/assets/web-panel/assets/{Templates-DI2giLgc.js → Templates-Bbz_h7oW.js} +1 -1
  72. package/src/assets/web-panel/assets/{Tenant-BiTWvm0g.js → Tenant-D-H4E3cu.js} +1 -1
  73. package/src/assets/web-panel/assets/{Terminal-vV6AWGDi.js → Terminal-CLLi0-lV.js} +2 -2
  74. package/src/assets/web-panel/assets/{TimelineRenderer-BmgzKdAp.js → TimelineRenderer-BKI6eG0k.js} +1 -1
  75. package/src/assets/web-panel/assets/{Tokens-Nvupdm6p.js → Tokens-rsE_yDjM.js} +1 -1
  76. package/src/assets/web-panel/assets/{Trigger-DRfR77WJ.js → Trigger-8TpwuTGk.js} +1 -1
  77. package/src/assets/web-panel/assets/{Trust-De0Jal_6.js → Trust-sMtZkHPs.js} +1 -1
  78. package/src/assets/web-panel/assets/{UkeySign-Dzo4-VAM.js → UkeySign-BAy2bAdG.js} +1 -1
  79. package/src/assets/web-panel/assets/{VideoEditing-hg2ytiJB.js → VideoEditing-CBeR_DYK.js} +1 -1
  80. package/src/assets/web-panel/assets/{Wallet--bU5-gRh.js → Wallet-BymDnBcq.js} +4 -4
  81. package/src/assets/web-panel/assets/{WebAuthn-DZptt-PV.js → WebAuthn-DQIjmqNz.js} +5 -5
  82. package/src/assets/web-panel/assets/{WorkflowEditor-Dy9223bY.js → WorkflowEditor-Cj7PB73f.js} +1 -1
  83. package/src/assets/web-panel/assets/{chat-DaxGeI9w.js → chat-DYnGj4vi.js} +1 -1
  84. package/src/assets/web-panel/assets/{colors-Cu2VEci3.js → colors-qOLKZNvN.js} +1 -1
  85. package/src/assets/web-panel/assets/{compact-item-CGolhyJq.js → compact-item-BpjCLPcW.js} +1 -1
  86. package/src/assets/web-panel/assets/{createContext-DY7EFhkD.js → createContext-CfakUZVQ.js} +1 -1
  87. package/src/assets/web-panel/assets/devWarning-DgtRXlrj.js +1 -0
  88. package/src/assets/web-panel/assets/{hasIn-Bpc-NoFN.js → hasIn-C9RW1s7t.js} +1 -1
  89. package/src/assets/web-panel/assets/{index-DxXkr-NS.js → index-8Ia91vNV.js} +1 -1
  90. package/src/assets/web-panel/assets/{index-DldaToUA.js → index-B4kS312z.js} +1 -1
  91. package/src/assets/web-panel/assets/{index-CBSk_VrT.js → index-BE67I0SW.js} +1 -1
  92. package/src/assets/web-panel/assets/{index-Bz83ngs0.js → index-BFOSDeeo.js} +1 -1
  93. package/src/assets/web-panel/assets/{index-1D4sfByw.js → index-BIz-pX0k.js} +1 -1
  94. package/src/assets/web-panel/assets/{index-DNX81oSR.js → index-BJoWi1aR.js} +1 -1
  95. package/src/assets/web-panel/assets/{index-D63ObMdQ.js → index-B_K0YtG2.js} +1 -1
  96. package/src/assets/web-panel/assets/{index-DpRSzAFl.js → index-BdR8XRyF.js} +1 -1
  97. package/src/assets/web-panel/assets/{index-eF9RV_4c.js → index-BfyRXPyV.js} +1 -1
  98. package/src/assets/web-panel/assets/{index-CJFYF8F9.js → index-Bl5LBZJM.js} +1 -1
  99. package/src/assets/web-panel/assets/{index-CFAnEzRW.js → index-BlxRICmz.js} +1 -1
  100. package/src/assets/web-panel/assets/{index-BTvwiqJE.js → index-BxiHBsfU.js} +1 -1
  101. package/src/assets/web-panel/assets/{index-Ciw5-X1B.js → index-C2S1hUWG.js} +1 -1
  102. package/src/assets/web-panel/assets/{index-C0_zeYnx.js → index-CEHyZ77C.js} +1 -1
  103. package/src/assets/web-panel/assets/{index-DfKmAEtE.js → index-CJZ2noI2.js} +1 -1
  104. package/src/assets/web-panel/assets/{index-lfP8sdzB.js → index-COYEuArt.js} +1 -1
  105. package/src/assets/web-panel/assets/{index-C-Hkl_2G.js → index-CVZTLSL1.js} +1 -1
  106. package/src/assets/web-panel/assets/{index-DAov-rJR.js → index-CbnJ6FsO.js} +1 -1
  107. package/src/assets/web-panel/assets/{index-CaKXhpEu.js → index-CvWFTG56.js} +1 -1
  108. package/src/assets/web-panel/assets/{index-rkm7dHwG.js → index-D-RzTqlR.js} +1 -1
  109. package/src/assets/web-panel/assets/{index-CGqeHu_F.js → index-DA80prWe.js} +1 -1
  110. package/src/assets/web-panel/assets/{index-BjfxHEmX.js → index-DAjszh8P.js} +1 -1
  111. package/src/assets/web-panel/assets/index-DIGTMmnW.js +1 -0
  112. package/src/assets/web-panel/assets/{index-BRAgl2J_.js → index-DQvVYNoJ.js} +1 -1
  113. package/src/assets/web-panel/assets/{index-D0GN5tdM.js → index-DSWdpR3c.js} +1 -1
  114. package/src/assets/web-panel/assets/{index-DexYD87j.js → index-DadPmrxI.js} +1 -1
  115. package/src/assets/web-panel/assets/{index-BP9P6chP.js → index-DgMJagCq.js} +1 -1
  116. package/src/assets/web-panel/assets/{index-Bn5gM9Oy.js → index-DkmLJFE_.js} +1 -1
  117. package/src/assets/web-panel/assets/{index-C2RpsAiO.js → index-DzXYG5YJ.js} +1 -1
  118. package/src/assets/web-panel/assets/index-Ef5jERRW.js +1 -0
  119. package/src/assets/web-panel/assets/{index-DElatOQ0.js → index-JkOMWGMX.js} +1 -1
  120. package/src/assets/web-panel/assets/{index-oJQgRCrR.js → index-T3bIqK_p.js} +3 -3
  121. package/src/assets/web-panel/assets/{index-RumxOD0S.js → index-UiiqS5k2.js} +1 -1
  122. package/src/assets/web-panel/assets/{index-BQ2z6Ky5.js → index-VYIJmPvJ.js} +1 -1
  123. package/src/assets/web-panel/assets/{index-DZ4Vm8dQ.js → index-ZCtDWP2C.js} +1 -1
  124. package/src/assets/web-panel/assets/{index-BlHq81Ow.js → index-f9yoj84i.js} +1 -1
  125. package/src/assets/web-panel/assets/{index-8h9y5S6X.js → index-lPc7EzUi.js} +1 -1
  126. package/src/assets/web-panel/assets/{index-VBRPxZeE.js → index-m9JeDv6B.js} +1 -1
  127. package/src/assets/web-panel/assets/{index-CLNqZF55.js → index-qf0fAus7.js} +1 -1
  128. package/src/assets/web-panel/assets/{initDefaultProps-CkJZfCo8.js → initDefaultProps-DgsgQr1H.js} +1 -1
  129. package/src/assets/web-panel/assets/{motion-BerbusV1.js → motion-TeUH7wzx.js} +1 -1
  130. package/src/assets/web-panel/assets/{move-DyRzKPD4.js → move-DdkIeWQx.js} +1 -1
  131. package/src/assets/web-panel/assets/{omit-CCdrTUAs.js → omit-BH_PH6HT.js} +1 -1
  132. package/src/assets/web-panel/assets/{pickAttrs-mVDeZx2m.js → pickAttrs-CllCh-Nl.js} +1 -1
  133. package/src/assets/web-panel/assets/{placementArrow-Bb_-Fs_o.js → placementArrow-BCjE2AzM.js} +1 -1
  134. package/src/assets/web-panel/assets/{responsiveObserve-C6TMj1R_.js → responsiveObserve-BAVGAvRQ.js} +1 -1
  135. package/src/assets/web-panel/assets/{slide-CdCNsy1J.js → slide-D4ZW-Inn.js} +1 -1
  136. package/src/assets/web-panel/assets/{statusUtils-Ccxd1rFd.js → statusUtils-j4pxhmKV.js} +1 -1
  137. package/src/assets/web-panel/assets/{styleChecker-3IL-yw1V.js → styleChecker-DH2SLtPg.js} +1 -1
  138. package/src/assets/web-panel/assets/{useFlexGapSupport-CH8DjUHl.js → useFlexGapSupport-CYMMs-_Q.js} +1 -1
  139. package/src/assets/web-panel/assets/{useFs-Cn9nE2sp.js → useFs-BOX2ddKh.js} +1 -1
  140. package/src/assets/web-panel/assets/{usePersonalDataHub-BPyT0HO7.js → usePersonalDataHub-BwcnN5z_.js} +1 -1
  141. package/src/assets/web-panel/assets/{vnode-Mfm7vy07.js → vnode-Cwalh7Hj.js} +1 -1
  142. package/src/assets/web-panel/assets/{zoom-CTpAiAE9.js → zoom-B2_q_nbu.js} +1 -1
  143. package/src/assets/web-panel/index.html +1 -1
  144. package/src/commands/agent.js +38 -4
  145. package/src/commands/init.js +31 -0
  146. package/src/commands/mcp.js +57 -0
  147. package/src/commands/memory.js +62 -0
  148. package/src/commands/session.js +70 -0
  149. package/src/lib/agent-core.js +1 -0
  150. package/src/lib/init-ai-refine.js +66 -0
  151. package/src/lib/json-schema-output.js +181 -0
  152. package/src/lib/mcp-serve.js +259 -0
  153. package/src/lib/project-instructions.js +89 -0
  154. package/src/lib/repl-completer.js +9 -3
  155. package/src/lib/repl-rewind.js +107 -0
  156. package/src/repl/agent-repl.js +145 -1
  157. package/src/assets/web-panel/assets/MobileProjects-7VPMoHus.js +0 -1
  158. package/src/assets/web-panel/assets/Projects-Di17SYft.js +0 -1
  159. package/src/assets/web-panel/assets/Tasks-4XugjJ87.js +0 -1
  160. package/src/assets/web-panel/assets/devWarning-DV2BNd59.js +0 -1
  161. package/src/assets/web-panel/assets/index-BZqtTmyG.js +0 -1
  162. package/src/assets/web-panel/assets/index-DUpwdJt9.js +0 -1
@@ -718,6 +718,18 @@ export async function startAgentRepl(options = {}) {
718
718
  } catch (_err) {
719
719
  // Non-critical
720
720
  }
721
+ // Resume recap (offline, extractive — no LLM): a quick "where were we"
722
+ // so the user doesn't have to scroll the old transcript.
723
+ try {
724
+ const { buildResumeRecap } = await import("../lib/repl-rewind.js");
725
+ const recap = buildResumeRecap(messages);
726
+ if (recap) {
727
+ logger.log(chalk.bold("Recap:"));
728
+ for (const line of recap) logger.log(chalk.gray(` ${line}`));
729
+ }
730
+ } catch (_err) {
731
+ /* non-critical */
732
+ }
721
733
  }
722
734
 
723
735
  const getPrompt = () => {
@@ -754,6 +766,7 @@ export async function startAgentRepl(options = {}) {
754
766
  "/provider",
755
767
  "/quit",
756
768
  "/reindex",
769
+ "/rewind",
757
770
  "/search",
758
771
  "/session",
759
772
  "/stats",
@@ -787,6 +800,53 @@ export async function startAgentRepl(options = {}) {
787
800
  completer: atCompleter,
788
801
  });
789
802
 
803
+ // Esc interrupt (Claude-Code parity): pressing Esc while a turn is in
804
+ // flight aborts the in-flight agentLoop through its existing AbortSignal
805
+ // seam (throwIfAborted at each iteration); partial conversation is kept.
806
+ // Idle Esc presses (no active turn) are ignored, and escape-prefixed key
807
+ // sequences (arrows etc.) never reach here as bare "escape".
808
+ let _turnAbort = null;
809
+ let _lastIdleEscAt = 0;
810
+ if (process.stdin.isTTY) {
811
+ process.stdin.on("keypress", (_str, key) => {
812
+ if (!key || key.name !== "escape" || key.meta) return;
813
+ if (_turnAbort) {
814
+ process.stdout.write(chalk.yellow("\n⎋ interrupting…\n"));
815
+ try {
816
+ _turnAbort.abort();
817
+ } catch {
818
+ /* already aborted */
819
+ }
820
+ _turnAbort = null;
821
+ return;
822
+ }
823
+ // Double-Esc while idle → rewind picker shortcut (Claude-Code parity);
824
+ // the actual rewind is `/rewind <n>` so stdin stays readline-owned.
825
+ const nowTs = Date.now();
826
+ if (nowTs - _lastIdleEscAt < 600) {
827
+ _lastIdleEscAt = 0;
828
+ import("../lib/repl-rewind.js")
829
+ .then(({ listUserTurns, renderTurnList }) => {
830
+ process.stdout.write(
831
+ chalk.bold("\nRewind — pick a user turn (newest first):\n"),
832
+ );
833
+ process.stdout.write(
834
+ `${renderTurnList(listUserTurns(messages))}\n`,
835
+ );
836
+ process.stdout.write(
837
+ chalk.gray(
838
+ "Run /rewind <n> to rewind the conversation (files: cc checkpoint restore).\n",
839
+ ),
840
+ );
841
+ prompt();
842
+ })
843
+ .catch(() => {});
844
+ } else {
845
+ _lastIdleEscAt = nowTs;
846
+ }
847
+ });
848
+ }
849
+
790
850
  logger.log(chalk.bold("\nChainlessChain Agent"));
791
851
  logger.log(
792
852
  chalk.gray(`Model: ${model} Provider: ${provider} CWD: ${process.cwd()}`),
@@ -871,7 +931,12 @@ export async function startAgentRepl(options = {}) {
871
931
 
872
932
  prompt();
873
933
 
874
- rl.on("line", async (input) => {
934
+ // Steering (Claude-Code parity): typing while a turn is running QUEUES the
935
+ // line instead of racing a second concurrent turn; the queue drains FIFO
936
+ // when the current turn finishes.
937
+ let _processingLine = false;
938
+ const _pendingLines = [];
939
+ const handleLine = async (input) => {
875
940
  const trimmed = input.trim();
876
941
  if (!trimmed) {
877
942
  prompt();
@@ -944,6 +1009,9 @@ export async function startAgentRepl(options = {}) {
944
1009
  logger.log(
945
1010
  ` ${chalk.cyan("/context")} Live context-window usage by role`,
946
1011
  );
1012
+ logger.log(
1013
+ ` ${chalk.cyan("/rewind")} Rewind conversation to an earlier turn (double-Esc lists)`,
1014
+ );
947
1015
  logger.log(
948
1016
  ` ${chalk.cyan("/compact")} Smart compact (importance-based)`,
949
1017
  );
@@ -1182,6 +1250,44 @@ export async function startAgentRepl(options = {}) {
1182
1250
  return;
1183
1251
  }
1184
1252
 
1253
+ if (trimmed === "/rewind" || trimmed.startsWith("/rewind ")) {
1254
+ try {
1255
+ const { listUserTurns, rewindToTurn, renderTurnList } = await import(
1256
+ "../lib/repl-rewind.js"
1257
+ );
1258
+ const arg = trimmed.slice("/rewind".length).trim();
1259
+ if (!arg) {
1260
+ logger.log(
1261
+ chalk.bold("\nRewind — pick a user turn (newest first):"),
1262
+ );
1263
+ logger.log(renderTurnList(listUserTurns(messages)));
1264
+ logger.log(
1265
+ chalk.gray(
1266
+ "Usage: /rewind <n> (conversation only — restore files with `cc checkpoint restore`)",
1267
+ ),
1268
+ );
1269
+ } else {
1270
+ const res = rewindToTurn(messages, arg);
1271
+ if (!res) {
1272
+ logger.error(`No such turn: ${arg} — run /rewind to list.`);
1273
+ } else {
1274
+ logger.log(
1275
+ chalk.yellow(
1276
+ `⎌ rewound — dropped ${res.removed} message(s); edit and resend below`,
1277
+ ),
1278
+ );
1279
+ prompt();
1280
+ if (res.text) rl.write(res.text);
1281
+ return;
1282
+ }
1283
+ }
1284
+ } catch (err) {
1285
+ logger.error(`/rewind failed: ${err.message}`);
1286
+ }
1287
+ prompt();
1288
+ return;
1289
+ }
1290
+
1185
1291
  if (trimmed === "/context") {
1186
1292
  // Live-session twin of `cc context` (Claude-Code /context parity):
1187
1293
  // bucket the CURRENT in-memory conversation by role against the model
@@ -2142,7 +2248,9 @@ export async function startAgentRepl(options = {}) {
2142
2248
  } catch (_e) {
2143
2249
  /* goal binding is best-effort — fall back to defaultPrepareCall */
2144
2250
  }
2251
+ _turnAbort = new AbortController();
2145
2252
  const { content: response, usageEvents } = await agentLoop(messages, {
2253
+ signal: _turnAbort.signal,
2146
2254
  provider,
2147
2255
  model: activeModel,
2148
2256
  thinking,
@@ -2169,6 +2277,7 @@ export async function startAgentRepl(options = {}) {
2169
2277
  externalToolDescriptors: _adhocMcp?.externalToolDescriptors,
2170
2278
  chatFn: _fallbackChatFn,
2171
2279
  });
2280
+ _turnAbort = null;
2172
2281
 
2173
2282
  if (sessionId && usageEvents?.length) {
2174
2283
  for (const ue of usageEvents) {
@@ -2294,6 +2403,16 @@ export async function startAgentRepl(options = {}) {
2294
2403
  }
2295
2404
  }
2296
2405
  } catch (err) {
2406
+ _turnAbort = null;
2407
+ // Esc interrupt: an aborted turn is normal flow, not an error — the
2408
+ // partial conversation stays usable and queued lines still drain.
2409
+ if (err?.name === "AbortError" || /abort/i.test(err?.message || "")) {
2410
+ logger.log(
2411
+ chalk.yellow("⎋ turn interrupted — partial progress kept"),
2412
+ );
2413
+ prompt();
2414
+ return;
2415
+ }
2297
2416
  logger.error(`Error: ${err.message}`);
2298
2417
 
2299
2418
  // Record error for context injection
@@ -2317,6 +2436,31 @@ export async function startAgentRepl(options = {}) {
2317
2436
  }
2318
2437
 
2319
2438
  prompt();
2439
+ };
2440
+
2441
+ rl.on("line", async (input) => {
2442
+ if (_processingLine) {
2443
+ if (input.trim()) {
2444
+ _pendingLines.push(input);
2445
+ logger.log(
2446
+ chalk.gray(
2447
+ `⏸ queued (${_pendingLines.length}) — runs after the current turn`,
2448
+ ),
2449
+ );
2450
+ }
2451
+ return;
2452
+ }
2453
+ _processingLine = true;
2454
+ try {
2455
+ await handleLine(input);
2456
+ while (_pendingLines.length) {
2457
+ const next = _pendingLines.shift();
2458
+ logger.log(chalk.cyan(`▶ running queued input: ${next}`));
2459
+ await handleLine(next);
2460
+ }
2461
+ } finally {
2462
+ _processingLine = false;
2463
+ }
2320
2464
  });
2321
2465
 
2322
2466
  rl.on("close", async () => {
@@ -1 +0,0 @@
1
- import{I as n,J as g,c as l,K as r,N as u,P as h,U as o,R as t,Q as b}from"./vendor-BvqAck49.js";import{_ as v,b as m}from"./index-oJQgRCrR.js";import{a7 as y,M as B}from"./icons-DP3uiYxy.js";const M={__name:"MobileProjects",setup(p,{expose:i}){i();const c=u(),{t:e}=m();function a(){c.push("/projects")}function _(){c.push("/mobile-bridge")}const s={router:c,t:e,goToProjects:a,goToMobileBridge:_,get useRouter(){return u},get useI18n(){return m},get MobileOutlined(){return B},get FolderOutlined(){return y}};return Object.defineProperty(s,"__isScriptSetup",{enumerable:!1,value:!0}),s}},x={class:"mobile-projects-placeholder"},O={class:"title"},T={class:"subtitle"},k={class:"explainer"};function w(p,i,c,e,a,_){const s=n("a-alert"),d=n("a-button"),f=n("a-space"),P=n("a-empty"),j=n("a-card");return h(),g("div",x,[l(j,null,{default:r(()=>[l(P,{description:!1},{image:r(()=>[l(e.MobileOutlined,{style:{fontSize:"64px",color:"#bfbfbf"}})]),default:r(()=>[o("h2",O,t(e.t("mobileProjects.title")),1),o("p",T,t(e.t("mobileProjects.subtitle")),1),l(s,{message:e.t("mobileProjects.v02Banner"),type:"info","show-icon":"",class:"banner"},null,8,["message"]),o("div",k,[o("h3",null,t(e.t("mobileProjects.currentDirection")),1),o("p",null,t(e.t("mobileProjects.currentDirectionBody")),1),o("ul",null,[o("li",null,t(e.t("mobileProjects.stepPhone")),1),o("li",null,t(e.t("mobileProjects.stepTap")),1),o("li",null,t(e.t("mobileProjects.stepPull")),1)]),o("h3",null,t(e.t("mobileProjects.reverseDirection")),1),o("p",null,t(e.t("mobileProjects.reverseDirectionBody")),1)]),l(f,{class:"actions"},{default:r(()=>[l(d,{type:"primary",onClick:e.goToProjects},{default:r(()=>[l(e.FolderOutlined),b(" "+t(e.t("mobileProjects.viewLocalProjects")),1)]),_:1}),l(d,{onClick:e.goToMobileBridge},{default:r(()=>[l(e.MobileOutlined),b(" "+t(e.t("mobileProjects.checkBridge")),1)]),_:1})]),_:1})]),_:1})]),_:1})])}const N=v(M,[["render",w],["__scopeId","data-v-9262cc45"],["__file","/tmp/cc-web-panel-RrTzBJ/repo/packages/web-panel/src/views/MobileProjects.vue"]]);export{N as default};
@@ -1 +0,0 @@
1
- import{I as i,J as I,U,R as s,Q as r,c as t,K as a,V as _,S as x,o as oe,b as ee,r as u,P as p,F as ne,a2 as ge}from"./vendor-BvqAck49.js";import{_ as we,b as re,u as ie,d}from"./index-oJQgRCrR.js";import{u as de}from"./useShellMode-CgR0wCYM.js";import{aM as ke,aN as Fe,aO as be,f as je,a4 as Ce,a7 as xe,as as Oe,R as Se}from"./icons-DP3uiYxy.js";const Pe={__name:"Projects",setup(se,{expose:l}){l();const{t:te}=re(),e=ie(),{isEmbedded:J}=de();async function w(o,f,ye,ae=8e3){if(J){const Z=await e.sendRaw({...f,type:o},ae);if(!Z?.ok){const $=Z?.error;throw new Error(typeof $=="string"?$:$?.message||`${o} failed`)}return Z.result}return e.executeJson(ye,ae)}const B=u(!1),y=u([]),O=u(""),S=u(""),P=u(!1),v=u(null),h=u([]),k=u(!1),E=u(!1),L=u(!1),F=u({name:"",description:"",type:"document",rootPath:""}),z=[{title:"ID",key:"id",width:110},{title:"名称",key:"name"},{title:"类型",key:"project_type",width:120},{title:"状态",key:"status",width:100},{title:"同步",key:"sync_status",width:100},{title:"更新",key:"updated_at",width:160},{title:"操作",key:"actions",width:180,fixed:"right"}],M=ee(()=>{const o={active:0,draft:0,completed:0,archived:0};for(const f of y.value)o[f.status]!==void 0&&(o[f.status]+=1);return o}),W=ee(()=>y.value.filter(o=>!(O.value&&o.status!==O.value||S.value&&!o.name.toLowerCase().includes(S.value.toLowerCase()))));function g(o){switch(o){case"active":return"green";case"draft":return"default";case"completed":return"cyan";case"archived":return"gold";default:return"default"}}function K(o){switch(o){case"synced":return"green";case"pending":return"orange";case"conflict":return"red";case"error":return"red";default:return"default"}}function Q(o){return!o&&o!==0?"-":new Date(typeof o=="number"?o:parseInt(o,10)).toLocaleString("zh-CN",{hour12:!1})}async function C(){B.value=!0;try{const o=await w("project.list",{limit:500},"project list --limit 500 --json",1e4);y.value=Array.isArray(o?.projects)?o.projects:Array.isArray(o)?o:[]}catch(o){d.error("加载失败: "+(o.message||o)),y.value=[]}finally{B.value=!1}}function G(o){return{onClick:()=>V(o)}}async function V(o){v.value=o,P.value=!0,k.value=!0,h.value=[];try{const f=await w("project.listFiles",{projectId:o.id,limit:200},`project list-files ${o.id} --json`,8e3);h.value=Array.isArray(f?.files)?f.files:[]}catch{h.value=[]}finally{k.value=!1}}async function H(o){try{(await w("project.delete",{id:o.id},`project delete ${o.id} --json`,8e3))?.ok?(d.success(`已删除项目 '${o.name}'`),P.value=!1,await C()):d.error("删除失败")}catch(f){d.error(f.message||String(f))}}function X(){F.value={name:"",description:"",type:"document",rootPath:""},E.value=!0}async function T(){if(!F.value.name.trim()){d.warning("请输入项目名称");return}L.value=!0;try{const o=await w("project.init",{name:F.value.name.trim(),description:F.value.description||null,projectType:F.value.type,rootPath:F.value.rootPath||null},`project init "${F.value.name.trim()}" --type ${F.value.type} --json`,8e3);o?.id?(d.success(`已创建项目 '${o.name}'`),E.value=!1,await C()):d.error("创建失败")}catch(o){d.error(o.message||String(o))}finally{L.value=!1}}const b=u(!1),D=u(!1),j=u({path:"",content:""}),A=u(!1),m=u(!1),R=u({path:""}),n=u(!1),c=u(null),q=u(""),Y=u(!1);function ue(){j.value={path:"",content:""},b.value=!0}function ce(){R.value={path:""},A.value=!0}async function N(){if(v.value){k.value=!0;try{const o=await w("project.listFiles",{projectId:v.value.id,limit:200},`project list-files ${v.value.id} --json`,8e3);h.value=Array.isArray(o?.files)?o.files:[]}catch(o){d.error("刷新文件失败: "+(o.message||o))}finally{k.value=!1}}}async function fe(){if(!j.value.path.trim()){d.warning("请输入文件路径");return}if(v.value){D.value=!0;try{const o=await w("project.createFile",{projectId:v.value.id,filePath:j.value.path.trim(),content:j.value.content||""},`project create-file ${v.value.id} "${j.value.path.trim()}" --json`,8e3);o?.id?(d.success(`已创建文件 '${o.file_name}'`),b.value=!1,await N(),await C()):d.error("创建文件失败")}catch(o){d.error(o.message||String(o))}finally{D.value=!1}}}async function pe(){if(!R.value.path.trim()){d.warning("请输入文件夹路径");return}if(v.value){m.value=!0;try{const o=await w("project.createFolder",{projectId:v.value.id,folderPath:R.value.path.trim()},`project create-folder ${v.value.id} "${R.value.path.trim()}" --json`,8e3);o?.id?(d.success(`已创建文件夹 '${o.file_name}'`),A.value=!1,await N(),await C()):d.error("创建文件夹失败")}catch(o){d.error(o.message||String(o))}finally{m.value=!1}}}async function ve(o){try{(await w("project.deleteFile",{fileId:o.id},`project delete-file ${o.id} --json`,8e3))?.deleted?(d.success(`已删除 '${o.file_name}'`),await N(),await C()):d.error("删除失败")}catch(f){d.error(f.message||String(f))}}async function me(o){if(o.is_folder){d.info("文件夹无内容可编辑");return}try{const f=await w("project.getFile",{fileId:o.id},`project get-file ${o.id} --json`,8e3);c.value=o,q.value=f?.content||"",n.value=!0}catch(f){d.error("读取文件失败: "+(f.message||f))}}async function _e(){if(c.value){Y.value=!0;try{(await w("project.writeFile",{fileId:c.value.id,content:q.value},`project write-file ${c.value.id} --json`,8e3))?.id?(d.success("已保存"),n.value=!1,await N()):d.error("保存失败")}catch(o){d.error(o.message||String(o))}finally{Y.value=!1}}}oe(()=>{C()});const le={t:te,ws:e,isEmbedded:J,callProjectTopic:w,loading:B,projects:y,statusFilter:O,nameFilter:S,detailOpen:P,detail:v,files:h,filesLoading:k,createOpen:E,creating:L,newProject:F,columns:z,countByStatus:M,filteredProjects:W,statusColor:g,syncColor:K,formatTime:Q,loadAll:C,onRowClick:G,openDetail:V,onDelete:H,onShowCreate:X,onCreate:T,createFileOpen:b,creatingFile:D,newFile:j,createFolderOpen:A,creatingFolder:m,newFolder:R,editFileOpen:n,editingFile:c,editFileContent:q,savingFile:Y,openCreateFile:ue,openCreateFolder:ce,refreshFiles:N,onCreateFile:fe,onCreateFolder:pe,onDeleteFile:ve,openEditFile:me,onSaveFile:_e,ref:u,computed:ee,onMounted:oe,get ReloadOutlined(){return Se},get PlusOutlined(){return Oe},get FolderOutlined(){return xe},get FileTextOutlined(){return Ce},get CheckCircleOutlined(){return je},get CheckSquareOutlined(){return be},get FileAddOutlined(){return Fe},get FolderAddOutlined(){return ke},get message(){return d},get useI18n(){return re},get useWsStore(){return ie},get useShellMode(){return de}};return Object.defineProperty(le,"__isScriptSetup",{enumerable:!1,value:!0}),le}},ze={style:{display:"flex","align-items":"center","justify-content":"space-between","margin-bottom":"24px"}},Ae={class:"page-title"},Ie={class:"page-sub"},Ue={class:"filter-bar",style:{"margin-bottom":"12px",display:"flex",gap:"12px","align-items":"center"}},he={key:0,style:{"font-size":"12px",color:"#888"}},De={key:0,style:{color:"#888","font-size":"12px"}},Re={key:0},Te={key:1,style:{color:"#888"}},Be=["onClick"],Ee={key:0,style:{color:"#888","font-size":"12px"}};function Le(se,l,te,e,J,w){const B=i("router-link"),y=i("a-button"),O=i("a-space"),S=i("a-statistic"),P=i("a-card"),v=i("a-col"),h=i("a-row"),k=i("a-radio-button"),E=i("a-radio-group"),L=i("a-input-search"),F=i("a-alert"),z=i("a-tag"),M=i("a-popconfirm"),W=i("a-table"),g=i("a-descriptions-item"),K=i("a-descriptions"),Q=i("a-divider"),C=i("a-empty"),G=i("a-list-item"),V=i("a-list"),H=i("a-spin"),X=i("a-drawer"),T=i("a-input"),b=i("a-form-item"),D=i("a-textarea"),j=i("a-form"),A=i("a-modal"),m=i("a-select-option"),R=i("a-select");return p(),I("div",null,[U("div",ze,[U("div",null,[U("h2",Ae,s(e.t("projects.title")),1),U("p",Ie,[l[17]||(l[17]=r("桌面 / CLI / 手机 三端共享同一份项目数据,Phase 3d sync 自动同步 (",-1)),t(B,{to:"/project-init"},{default:a(()=>[...l[16]||(l[16]=[r("项目初始化 / 环境设置",-1)])]),_:1}),l[18]||(l[18]=r(")",-1))])]),t(O,null,{default:a(()=>[t(y,{loading:e.loading,onClick:e.loadAll},{icon:a(()=>[t(e.ReloadOutlined)]),default:a(()=>[l[19]||(l[19]=r(" 刷新 ",-1))]),_:1},8,["loading"]),t(y,{type:"primary",onClick:e.onShowCreate},{icon:a(()=>[t(e.PlusOutlined)]),default:a(()=>[l[20]||(l[20]=r(" 新建项目 ",-1))]),_:1})]),_:1})]),_(" Stats "),t(h,{gutter:[16,16],style:{"margin-bottom":"20px"}},{default:a(()=>[t(v,{xs:12,sm:8,lg:6},{default:a(()=>[t(P,{style:{background:"var(--bg-card)","border-color":"var(--border-color)"}},{default:a(()=>[t(S,{title:"总项目",value:e.projects.length,"value-style":{color:"#1677ff",fontSize:"20px"}},{prefix:a(()=>[t(e.FolderOutlined)]),_:1},8,["value"])]),_:1})]),_:1}),t(v,{xs:12,sm:8,lg:6},{default:a(()=>[t(P,{style:{background:"var(--bg-card)","border-color":"var(--border-color)"}},{default:a(()=>[t(S,{title:"活跃",value:e.countByStatus.active,"value-style":{color:"#52c41a",fontSize:"20px"}},{prefix:a(()=>[t(e.CheckCircleOutlined)]),_:1},8,["value"])]),_:1})]),_:1}),t(v,{xs:12,sm:8,lg:6},{default:a(()=>[t(P,{style:{background:"var(--bg-card)","border-color":"var(--border-color)"}},{default:a(()=>[t(S,{title:"草稿",value:e.countByStatus.draft,"value-style":{color:"#8c8c8c",fontSize:"20px"}},{prefix:a(()=>[t(e.FileTextOutlined)]),_:1},8,["value"])]),_:1})]),_:1}),t(v,{xs:12,sm:8,lg:6},{default:a(()=>[t(P,{style:{background:"var(--bg-card)","border-color":"var(--border-color)"}},{default:a(()=>[t(S,{title:"已完成",value:e.countByStatus.completed,"value-style":{color:"#13c2c2",fontSize:"20px"}},{prefix:a(()=>[t(e.CheckSquareOutlined)]),_:1},8,["value"])]),_:1})]),_:1})]),_:1}),_(" Filter "),U("div",Ue,[t(E,{value:e.statusFilter,"onUpdate:value":l[0]||(l[0]=n=>e.statusFilter=n),size:"small","button-style":"solid"},{default:a(()=>[t(k,{value:""},{default:a(()=>[...l[21]||(l[21]=[r("全部",-1)])]),_:1}),t(k,{value:"active"},{default:a(()=>[...l[22]||(l[22]=[r("活跃",-1)])]),_:1}),t(k,{value:"draft"},{default:a(()=>[...l[23]||(l[23]=[r("草稿",-1)])]),_:1}),t(k,{value:"completed"},{default:a(()=>[...l[24]||(l[24]=[r("已完成",-1)])]),_:1}),t(k,{value:"archived"},{default:a(()=>[...l[25]||(l[25]=[r("已归档",-1)])]),_:1})]),_:1},8,["value"]),t(L,{value:e.nameFilter,"onUpdate:value":l[1]||(l[1]=n=>e.nameFilter=n),placeholder:"按名称过滤",style:{"max-width":"260px"},"allow-clear":""},null,8,["value"])]),!e.projects.length&&!e.loading?(p(),x(F,{key:0,type:"info",message:"还没有项目",description:'运行 `cc project init <name>` 或点击右上角"新建项目"按钮创建。桌面 / CLI / 手机三端共享同一份数据。',"show-icon":"",style:{"margin-bottom":"16px"}})):_("v-if",!0),e.projects.length||e.loading?(p(),x(W,{key:1,columns:e.columns,"data-source":e.filteredProjects,loading:e.loading,pagination:{pageSize:20,showSizeChanger:!0},"row-key":"id","custom-row":e.onRowClick},{bodyCell:a(({column:n,record:c})=>[n.key==="id"?(p(),I("code",he,s(c.id.slice(0,8))+"…",1)):n.key==="name"?(p(),I(ne,{key:1},[U("strong",null,s(c.name),1),c.description?(p(),I("div",De,s(c.description),1)):_("v-if",!0)],64)):n.key==="project_type"?(p(),x(z,{key:2},{default:a(()=>[r(s(c.project_type),1)]),_:2},1024)):n.key==="status"?(p(),x(z,{key:3,color:e.statusColor(c.status)},{default:a(()=>[r(s(c.status),1)]),_:2},1032,["color"])):n.key==="sync_status"?(p(),x(z,{key:4,color:e.syncColor(c.sync_status)},{default:a(()=>[r(s(c.sync_status||"unknown"),1)]),_:2},1032,["color"])):n.key==="updated_at"?(p(),I(ne,{key:5},[r(s(e.formatTime(c.updated_at)),1)],64)):n.key==="actions"?(p(),x(O,{key:6,onClick:l[2]||(l[2]=ge(()=>{},["stop"]))},{default:a(()=>[t(y,{size:"small",onClick:q=>e.openDetail(c)},{default:a(()=>[...l[26]||(l[26]=[r("详情",-1)])]),_:1},8,["onClick"]),t(M,{title:`删除项目 '${c.name}' ?`,"ok-text":"删除","ok-type":"danger","cancel-text":"取消",onConfirm:q=>e.onDelete(c)},{default:a(()=>[t(y,{size:"small",danger:""},{default:a(()=>[...l[27]||(l[27]=[r("删除",-1)])]),_:1})]),_:1},8,["title","onConfirm"])]),_:2},1024)):_("v-if",!0)]),_:1},8,["data-source","loading"])):_("v-if",!0),_(" Detail drawer "),t(X,{open:e.detailOpen,"onUpdate:open":l[3]||(l[3]=n=>e.detailOpen=n),title:e.detail?.name||"项目详情",width:"640",placement:"right"},{default:a(()=>[e.detail?(p(),x(K,{key:0,column:1,bordered:"",size:"small"},{default:a(()=>[t(g,{label:"ID"},{default:a(()=>[U("code",null,s(e.detail.id),1)]),_:1}),t(g,{label:"名称"},{default:a(()=>[r(s(e.detail.name),1)]),_:1}),t(g,{label:"描述"},{default:a(()=>[r(s(e.detail.description||"-"),1)]),_:1}),t(g,{label:"类型"},{default:a(()=>[t(z,null,{default:a(()=>[r(s(e.detail.project_type),1)]),_:1})]),_:1}),t(g,{label:"状态"},{default:a(()=>[t(z,{color:e.statusColor(e.detail.status)},{default:a(()=>[r(s(e.detail.status),1)]),_:1},8,["color"])]),_:1}),t(g,{label:"同步状态"},{default:a(()=>[t(z,{color:e.syncColor(e.detail.sync_status)},{default:a(()=>[r(s(e.detail.sync_status||"unknown"),1)]),_:1},8,["color"])]),_:1}),t(g,{label:"用户"},{default:a(()=>[r(s(e.detail.user_id),1)]),_:1}),t(g,{label:"根路径"},{default:a(()=>[e.detail.root_path?(p(),I("code",Re,s(e.detail.root_path),1)):(p(),I("span",Te,"(无)"))]),_:1}),t(g,{label:"文件数"},{default:a(()=>[r(s(e.detail.file_count||0),1)]),_:1}),t(g,{label:"创建"},{default:a(()=>[r(s(e.formatTime(e.detail.created_at)),1)]),_:1}),t(g,{label:"更新"},{default:a(()=>[r(s(e.formatTime(e.detail.updated_at)),1)]),_:1})]),_:1})):_("v-if",!0),t(Q,null,{default:a(()=>[...l[28]||(l[28]=[r("文件",-1)])]),_:1}),_(" Sub-phase 7.3 (2026-05-17): 文件 CRUD toolbar "),t(O,{style:{"margin-bottom":"12px"}},{default:a(()=>[t(y,{size:"small",type:"primary",disabled:!e.detail,onClick:e.openCreateFile},{default:a(()=>[t(e.FileAddOutlined),l[29]||(l[29]=r(" 新建文件 ",-1))]),_:1},8,["disabled"]),t(y,{size:"small",disabled:!e.detail,onClick:e.openCreateFolder},{default:a(()=>[t(e.FolderAddOutlined),l[30]||(l[30]=r(" 新建文件夹 ",-1))]),_:1},8,["disabled"])]),_:1}),t(H,{spinning:e.filesLoading},{default:a(()=>[!e.files.length&&!e.filesLoading?(p(),x(C,{key:0,description:"无文件 (点上方按钮新建)"})):(p(),x(V,{key:1,size:"small","data-source":e.files},{renderItem:a(({item:n})=>[t(G,null,{extra:a(()=>[t(O,null,{default:a(()=>[n.file_size?(p(),I("span",Ee,s(n.file_size)+" B",1)):_("v-if",!0),t(M,{title:`删除 ${n.is_folder?"文件夹":"文件"} '${n.file_name}' ?`,"ok-text":"删除","ok-type":"danger","cancel-text":"取消",onConfirm:c=>e.onDeleteFile(n)},{default:a(()=>[t(y,{size:"small",danger:""},{default:a(()=>[...l[31]||(l[31]=[r("×",-1)])]),_:1})]),_:1},8,["title","onConfirm"])]),_:2},1024)]),default:a(()=>[U("span",{style:{cursor:"pointer"},onClick:c=>e.openEditFile(n)},s(n.is_folder?"📁":"📄")+" "+s(n.file_path),9,Be)]),_:2},1024)]),_:1},8,["data-source"]))]),_:1},8,["spinning"])]),_:1},8,["open","title"]),_(" Sub-phase 7.3: Create file modal "),t(A,{open:e.createFileOpen,"onUpdate:open":l[6]||(l[6]=n=>e.createFileOpen=n),title:"新建文件","confirm-loading":e.creatingFile,"ok-text":"创建","cancel-text":"取消",onOk:e.onCreateFile},{default:a(()=>[t(j,{layout:"vertical"},{default:a(()=>[t(b,{label:"文件路径(项目内)",required:""},{default:a(()=>[t(T,{value:e.newFile.path,"onUpdate:value":l[4]||(l[4]=n=>e.newFile.path=n),placeholder:"例如 README.md 或 src/main.kt"},null,8,["value"])]),_:1}),t(b,{label:"初始内容(可选)"},{default:a(()=>[t(D,{value:e.newFile.content,"onUpdate:value":l[5]||(l[5]=n=>e.newFile.content=n),rows:6,placeholder:"留空创建空文件"},null,8,["value"])]),_:1})]),_:1})]),_:1},8,["open","confirm-loading"]),_(" Sub-phase 7.3: Create folder modal "),t(A,{open:e.createFolderOpen,"onUpdate:open":l[8]||(l[8]=n=>e.createFolderOpen=n),title:"新建文件夹","confirm-loading":e.creatingFolder,"ok-text":"创建","cancel-text":"取消",onOk:e.onCreateFolder},{default:a(()=>[t(j,{layout:"vertical"},{default:a(()=>[t(b,{label:"文件夹路径(项目内)",required:""},{default:a(()=>[t(T,{value:e.newFolder.path,"onUpdate:value":l[7]||(l[7]=n=>e.newFolder.path=n),placeholder:"例如 src/utils"},null,8,["value"])]),_:1})]),_:1})]),_:1},8,["open","confirm-loading"]),_(" Sub-phase 7.3: Edit file content modal "),t(A,{open:e.editFileOpen,"onUpdate:open":l[10]||(l[10]=n=>e.editFileOpen=n),title:`编辑 ${e.editingFile?.file_name||""}`,"confirm-loading":e.savingFile,"ok-text":"保存","cancel-text":"取消",onOk:e.onSaveFile,width:"720"},{default:a(()=>[t(D,{value:e.editFileContent,"onUpdate:value":l[9]||(l[9]=n=>e.editFileContent=n),rows:18,"auto-size":{minRows:12,maxRows:24},style:{"font-family":"monospace"}},null,8,["value"])]),_:1},8,["open","title","confirm-loading"]),_(" Create modal "),t(A,{open:e.createOpen,"onUpdate:open":l[15]||(l[15]=n=>e.createOpen=n),title:"新建项目","confirm-loading":e.creating,"ok-text":"创建","cancel-text":"取消",onOk:e.onCreate},{default:a(()=>[t(j,{layout:"vertical"},{default:a(()=>[t(b,{label:"项目名称",required:""},{default:a(()=>[t(T,{value:e.newProject.name,"onUpdate:value":l[11]||(l[11]=n=>e.newProject.name=n),placeholder:"例如:旅行计划-上海"},null,8,["value"])]),_:1}),t(b,{label:"描述"},{default:a(()=>[t(D,{value:e.newProject.description,"onUpdate:value":l[12]||(l[12]=n=>e.newProject.description=n),rows:2},null,8,["value"])]),_:1}),t(b,{label:"类型"},{default:a(()=>[t(R,{value:e.newProject.type,"onUpdate:value":l[13]||(l[13]=n=>e.newProject.type=n)},{default:a(()=>[t(m,{value:"document"},{default:a(()=>[...l[32]||(l[32]=[r("文档 (document)",-1)])]),_:1}),t(m,{value:"data"},{default:a(()=>[...l[33]||(l[33]=[r("数据 (data)",-1)])]),_:1}),t(m,{value:"web"},{default:a(()=>[...l[34]||(l[34]=[r("Web",-1)])]),_:1}),t(m,{value:"app"},{default:a(()=>[...l[35]||(l[35]=[r("应用 (app)",-1)])]),_:1}),t(m,{value:"presentation"},{default:a(()=>[...l[36]||(l[36]=[r("演示文稿",-1)])]),_:1}),t(m,{value:"spreadsheet"},{default:a(()=>[...l[37]||(l[37]=[r("表格",-1)])]),_:1}),t(m,{value:"design"},{default:a(()=>[...l[38]||(l[38]=[r("设计",-1)])]),_:1}),t(m,{value:"code"},{default:a(()=>[...l[39]||(l[39]=[r("代码",-1)])]),_:1}),t(m,{value:"workflow"},{default:a(()=>[...l[40]||(l[40]=[r("工作流",-1)])]),_:1}),t(m,{value:"knowledge"},{default:a(()=>[...l[41]||(l[41]=[r("知识库",-1)])]),_:1})]),_:1},8,["value"])]),_:1}),t(b,{label:"根路径 (可选)"},{default:a(()=>[t(T,{value:e.newProject.rootPath,"onUpdate:value":l[14]||(l[14]=n=>e.newProject.rootPath=n),placeholder:"留空则仅元数据"},null,8,["value"])]),_:1})]),_:1})]),_:1},8,["open","confirm-loading"])])}const Je=we(Pe,[["render",Le],["__scopeId","data-v-019ac5aa"],["__file","/tmp/cc-web-panel-RrTzBJ/repo/packages/web-panel/src/views/Projects.vue"]]);export{Je as default};
@@ -1 +0,0 @@
1
- import{E as V,b as z,r as D,I as p,J as c,U as _,c as n,K as a,S,V as w,o as P,x as B,P as i,Q as g,R as r,F as h,Z as F}from"./vendor-BvqAck49.js";import{u as R,_ as O}from"./index-oJQgRCrR.js";import{R as E}from"./icons-DP3uiYxy.js";const I=V("tasks",()=>{const k=D([]),l=D(!1);let u=null,e=null;const x=z(()=>k.value.filter(t=>t.status==="running")),b=z(()=>k.value.filter(t=>t.status==="pending")),y=z(()=>k.value.filter(t=>t.status==="completed"||t.status==="failed"||t.status==="timeout"));async function f(){const t=R();l.value=!0;try{const s=await t.sendRaw({type:"tasks-list"});s&&Array.isArray(s.tasks)&&(k.value=s.tasks)}catch{}finally{l.value=!1}}async function o(t){const s=R();try{await s.sendRaw({type:"tasks-stop",taskId:t})}catch{}finally{await f()}}const d=D(null);function m(t=5e3){v(),f(),u=setInterval(f,t),C()}function v(){u&&(clearInterval(u),u=null),e&&(e(),e=null)}function C(){const t=R();if(e)return;const s=T=>{T.type==="task:notification"&&T.payload?.task&&(d.value=T.payload.task,f(),setTimeout(()=>{d.value=null},8e3))};e=t.onRuntimeEvent(s)}function N(t){return!t||t<0?"-":t<1e3?`${t}ms`:t<6e4?`${(t/1e3).toFixed(1)}s`:`${(t/6e4).toFixed(1)}m`}function A(t){switch(t){case"running":return"processing";case"pending":return"default";case"completed":return"success";case"failed":return"error";case"timeout":return"warning";default:return"default"}}return{tasks:k,loading:l,running:x,pending:b,completed:y,lastNotification:d,fetchTasks:f,stopTask:o,startPolling:m,stopPolling:v,formatDuration:N,getStatusColor:A}}),U={__name:"Tasks",setup(k,{expose:l}){l();const u=I(),e=[{title:"状态",key:"status",width:90},{title:"描述",key:"description",ellipsis:!0},{title:"类型",dataIndex:"type",width:100},{title:"耗时",key:"duration",width:90},{title:"创建时间",key:"createdAt",width:180},{title:"结果",key:"result",ellipsis:!0},{title:"操作",key:"action",width:80}];function x(o){return o.status==="running"&&o.startedAt?u.formatDuration(Date.now()-o.startedAt):o.completedAt&&o.startedAt?u.formatDuration(o.completedAt-o.startedAt):"-"}function b(o){return o?new Date(o).toLocaleString():"-"}function y(o,d){return o?o.length>d?`${o.slice(0,d)}...`:o:""}P(()=>u.startPolling(5e3)),B(()=>u.stopPolling());const f={store:u,columns:e,getDuration:x,formatTime:b,truncate:y,onMounted:P,onUnmounted:B,get ReloadOutlined(){return E},get useTasksStore(){return I}};return Object.defineProperty(f,"__isScriptSetup",{enumerable:!1,value:!0}),f}},J={class:"page-header"},L={key:0,class:"error-text"},j={key:1},K={class:"task-header"},M={class:"task-desc"},Q={class:"task-id"},W={class:"task-meta"},Z=["title"],q={key:0,class:"error-text"},G={key:1,class:"success-text"},H={key:2,class:"muted-text"};function X(k,l,u,e,x,b){const y=p("a-button"),f=p("a-space"),o=p("a-alert"),d=p("a-statistic"),m=p("a-card"),v=p("a-col"),C=p("a-row"),N=p("a-tag"),A=p("a-table");return i(),c("div",null,[_("div",J,[l[3]||(l[3]=_("div",null,[_("h2",{class:"page-title"},"后台任务"),_("p",{class:"page-sub"},"查看后台任务队列、实时通知和任务执行结果。")],-1)),n(f,null,{default:a(()=>[n(y,{ghost:"",loading:e.store.loading,onClick:l[0]||(l[0]=t=>e.store.fetchTasks())},{icon:a(()=>[n(e.ReloadOutlined)]),default:a(()=>[l[2]||(l[2]=g(" 刷新 ",-1))]),_:1},8,["loading"])]),_:1})]),e.store.lastNotification?(i(),S(o,{key:0,type:e.store.lastNotification.status==="completed"?"success":"error","show-icon":"",closable:"",class:"banner",onClose:l[1]||(l[1]=t=>e.store.lastNotification=null)},{message:a(()=>[g(" 任务"+r(e.store.lastNotification.status==="completed"?"完成":"结束")+": "+r(e.store.lastNotification.description||e.store.lastNotification.id.slice(0,16)),1)]),description:a(()=>[e.store.lastNotification.error?(i(),c("span",L,r(e.store.lastNotification.error),1)):e.store.lastNotification.result?(i(),c("span",j,r(e.truncate(String(e.store.lastNotification.result),120)),1)):w("v-if",!0)]),_:1},8,["type"])):w("v-if",!0),n(C,{gutter:[16,16],class:"stats-row"},{default:a(()=>[n(v,{xs:12,sm:6},{default:a(()=>[n(m,{class:"stat-card",size:"small"},{default:a(()=>[n(d,{title:"全部任务",value:e.store.tasks.length},null,8,["value"])]),_:1})]),_:1}),n(v,{xs:12,sm:6},{default:a(()=>[n(m,{class:"stat-card",size:"small"},{default:a(()=>[n(d,{title:"运行中",value:e.store.running.length},null,8,["value"])]),_:1})]),_:1}),n(v,{xs:12,sm:6},{default:a(()=>[n(m,{class:"stat-card",size:"small"},{default:a(()=>[n(d,{title:"等待中",value:e.store.pending.length},null,8,["value"])]),_:1})]),_:1}),n(v,{xs:12,sm:6},{default:a(()=>[n(m,{class:"stat-card",size:"small"},{default:a(()=>[n(d,{title:"已完成",value:e.store.completed.length},null,8,["value"])]),_:1})]),_:1})]),_:1}),e.store.running.length>0?(i(),S(m,{key:1,title:"运行中的任务",class:"panel-card",size:"small"},{default:a(()=>[(i(!0),c(h,null,F(e.store.running,t=>(i(),c("div",{key:t.id,class:"task-item running"},[_("div",K,[n(N,{color:e.store.getStatusColor(t.status)},{default:a(()=>[g(r(t.status.toUpperCase()),1)]),_:2},1032,["color"]),_("span",M,r(t.description),1),_("span",Q,r(t.id.slice(0,16)),1)]),_("div",W,[_("span",null,"类型: "+r(t.type||"-"),1),_("span",null,"已运行: "+r(e.store.formatDuration(Date.now()-t.startedAt)),1),n(y,{size:"small",danger:"",onClick:s=>e.store.stopTask(t.id)},{default:a(()=>[...l[4]||(l[4]=[g("停止",-1)])]),_:1},8,["onClick"])])]))),128))]),_:1})):w("v-if",!0),n(m,{class:"panel-card"},{default:a(()=>[n(A,{columns:e.columns,"data-source":e.store.tasks,pagination:{pageSize:15,size:"small"},loading:e.store.loading,"row-key":"id",size:"small"},{bodyCell:a(({column:t,record:s})=>[t.key==="status"?(i(),S(N,{key:0,color:e.store.getStatusColor(s.status)},{default:a(()=>[g(r(s.status),1)]),_:2},1032,["color"])):t.key==="description"?(i(),c("span",{key:1,title:s.command},r(s.description),9,Z)):t.key==="duration"?(i(),c(h,{key:2},[g(r(e.getDuration(s)),1)],64)):t.key==="createdAt"?(i(),c(h,{key:3},[g(r(e.formatTime(s.createdAt)),1)],64)):t.key==="result"?(i(),c(h,{key:4},[s.error?(i(),c("span",q,r(e.truncate(s.error,60)),1)):s.result?(i(),c("span",G,r(e.truncate(String(s.result),60)),1)):(i(),c("span",H,"-"))],64)):t.key==="action"?(i(),c(h,{key:5},[s.status==="running"?(i(),S(y,{key:0,size:"small",danger:"",onClick:T=>e.store.stopTask(s.id)},{default:a(()=>[...l[5]||(l[5]=[g(" 停止 ",-1)])]),_:1},8,["onClick"])):w("v-if",!0)],64)):w("v-if",!0)]),_:1},8,["data-source","loading"])]),_:1})])}const et=O(U,[["render",X],["__scopeId","data-v-da5ff6a2"],["__file","/tmp/cc-web-panel-RrTzBJ/repo/packages/web-panel/src/views/Tasks.vue"]]);export{et as default};
@@ -1 +0,0 @@
1
- import{O as r}from"./index-oJQgRCrR.js";const o=((n,a,e)=>{r(n,`[ant-design-vue: ${a}] ${e}`)});export{o as d};
@@ -1 +0,0 @@
1
- import{A as o}from"./Row-GAvKzKH7.js";import{U as t}from"./index-oJQgRCrR.js";import"./vendor-BvqAck49.js";import"./responsiveObserve-C6TMj1R_.js";import"./useFlexGapSupport-CH8DjUHl.js";import"./styleChecker-3IL-yw1V.js";import"./index-DexYD87j.js";import"./icons-DP3uiYxy.js";const l=t(o);export{l as default};
@@ -1 +0,0 @@
1
- import{C as o}from"./Col-BVASLexk.js";import{U as t}from"./index-oJQgRCrR.js";import"./vendor-BvqAck49.js";import"./index-DexYD87j.js";import"./icons-DP3uiYxy.js";const s=t(o);export{s as default};