@geminilight/mindos 0.6.39 → 0.6.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.
- package/README.md +31 -15
- package/README_zh.md +31 -15
- package/_standalone/.mindos-build-version +1 -1
- package/_standalone/.next/BUILD_ID +1 -1
- package/_standalone/.next/app-path-routes-manifest.json +19 -18
- package/_standalone/.next/build-manifest.json +3 -3
- package/_standalone/.next/cache/.previewinfo +1 -1
- package/_standalone/.next/cache/.rscinfo +1 -1
- package/_standalone/.next/cache/config.json +3 -3
- package/_standalone/.next/prerender-manifest.json +3 -3
- package/_standalone/.next/react-loadable-manifest.json +68 -2
- package/_standalone/.next/routes-manifest.json +6 -0
- package/_standalone/.next/server/app/.well-known/agent-card.json/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/_global-error.html +2 -2
- package/_standalone/.next/server/app/_global-error.rsc +1 -1
- package/_standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/_standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
- package/_standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
- package/_standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/_standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/_standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/_standalone/.next/server/app/_not-found/page.js +2 -2
- package/_standalone/.next/server/app/_not-found/page.js.nft.json +1 -1
- package/_standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/agents/[agentKey]/page.js +2 -2
- package/_standalone/.next/server/app/agents/[agentKey]/page.js.nft.json +1 -1
- package/_standalone/.next/server/app/agents/[agentKey]/page_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/agents/page.js +3 -3
- package/_standalone/.next/server/app/agents/page.js.nft.json +1 -1
- package/_standalone/.next/server/app/agents/page_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/a2a/agents/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/a2a/delegations/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/a2a/discover/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/a2a/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/acp/config/route.js +1 -1
- package/_standalone/.next/server/app/api/acp/config/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/acp/config/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/acp/detect/route.js +1 -1
- package/_standalone/.next/server/app/api/acp/detect/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/acp/detect/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/acp/install/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/acp/registry/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/acp/session/route.js +1 -1
- package/_standalone/.next/server/app/api/acp/session/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/acp/session/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/agent-activity/route.js +1 -1
- package/_standalone/.next/server/app/api/agent-activity/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/agent-activity/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/ask/route.js +137 -99
- package/_standalone/.next/server/app/api/ask/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/ask/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/ask-sessions/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/auth/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/backlinks/route.js +1 -1
- package/_standalone/.next/server/app/api/backlinks/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/backlinks/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/bootstrap/route.js +1 -1
- package/_standalone/.next/server/app/api/bootstrap/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/bootstrap/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/changes/route.js +1 -1
- package/_standalone/.next/server/app/api/changes/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/changes/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/export/route.js +3 -3
- package/_standalone/.next/server/app/api/export/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/export/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/extract-pdf/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/file/import/route.js +2 -19
- package/_standalone/.next/server/app/api/file/import/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/file/import/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/file/route.js +1 -18
- package/_standalone/.next/server/app/api/file/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/file/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/files/route.js +1 -1
- package/_standalone/.next/server/app/api/files/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/files/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/git/route.js +1 -1
- package/_standalone/.next/server/app/api/git/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/git/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/graph/route.js +1 -1
- package/_standalone/.next/server/app/api/graph/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/graph/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/health/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/inbox/route.js +1 -0
- package/_standalone/.next/server/app/api/inbox/route.js.nft.json +1 -0
- package/_standalone/.next/server/app/api/inbox/route_client-reference-manifest.js +1 -0
- package/_standalone/.next/server/app/api/init/route.js +1 -1
- package/_standalone/.next/server/app/api/init/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/init/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/mcp/agents/route.js +1 -1
- package/_standalone/.next/server/app/api/mcp/agents/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/mcp/agents/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/mcp/install/route.js +1 -1
- package/_standalone/.next/server/app/api/mcp/install/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/mcp/install/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/mcp/install-skill/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/mcp/install-skill/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/mcp/restart/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/mcp/status/route.js +1 -1
- package/_standalone/.next/server/app/api/mcp/status/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/mcp/status/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/monitoring/route.js +1 -1
- package/_standalone/.next/server/app/api/monitoring/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/monitoring/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/recent-files/route.js +1 -1
- package/_standalone/.next/server/app/api/recent-files/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/recent-files/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/restart/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/search/route.js +1 -1
- package/_standalone/.next/server/app/api/search/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/search/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/settings/list-models/route.js +1 -1
- package/_standalone/.next/server/app/api/settings/list-models/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/settings/list-models/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/settings/reset-token/route.js +1 -1
- package/_standalone/.next/server/app/api/settings/reset-token/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/settings/reset-token/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/settings/route.js +1 -1
- package/_standalone/.next/server/app/api/settings/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/settings/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/settings/test-key/route.js +1 -1
- package/_standalone/.next/server/app/api/settings/test-key/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/settings/test-key/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/setup/check-path/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/setup/check-port/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/setup/generate-token/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/setup/ls/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/setup/route.js +1 -1
- package/_standalone/.next/server/app/api/setup/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/setup/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/skills/route.js +2 -2
- package/_standalone/.next/server/app/api/skills/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/skills/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/sync/route.js +1 -1
- package/_standalone/.next/server/app/api/sync/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/tree-version/route.js +1 -1
- package/_standalone/.next/server/app/api/tree-version/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/tree-version/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/uninstall/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/update/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/update-check/route.js +1 -1
- package/_standalone/.next/server/app/api/update-check/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/update-status/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/api/workflows/route.js +2 -2
- package/_standalone/.next/server/app/api/workflows/route.js.nft.json +1 -1
- package/_standalone/.next/server/app/api/workflows/route_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/changes/page.js +2 -2
- package/_standalone/.next/server/app/changes/page.js.nft.json +1 -1
- package/_standalone/.next/server/app/changes/page_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/echo/[segment]/page.js +6 -6
- package/_standalone/.next/server/app/echo/[segment]/page.js.nft.json +1 -1
- package/_standalone/.next/server/app/echo/[segment]/page_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/echo/page.js +2 -2
- package/_standalone/.next/server/app/echo/page.js.nft.json +1 -1
- package/_standalone/.next/server/app/echo/page_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/explore/page.js +3 -3
- package/_standalone/.next/server/app/explore/page.js.nft.json +1 -1
- package/_standalone/.next/server/app/explore/page_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/help/page.js +2 -2
- package/_standalone/.next/server/app/help/page.js.nft.json +1 -1
- package/_standalone/.next/server/app/help/page_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/login/page.js +2 -2
- package/_standalone/.next/server/app/login/page.js.nft.json +1 -1
- package/_standalone/.next/server/app/login/page_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/page.js +3 -3
- package/_standalone/.next/server/app/page.js.nft.json +1 -1
- package/_standalone/.next/server/app/page_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/setup/page.js +2 -2
- package/_standalone/.next/server/app/setup/page.js.nft.json +1 -1
- package/_standalone/.next/server/app/setup/page_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/trash/page.js +3 -3
- package/_standalone/.next/server/app/trash/page.js.nft.json +1 -1
- package/_standalone/.next/server/app/trash/page_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app/view/[...path]/page.js +4 -4
- package/_standalone/.next/server/app/view/[...path]/page.js.nft.json +1 -1
- package/_standalone/.next/server/app/view/[...path]/page_client-reference-manifest.js +1 -1
- package/_standalone/.next/server/app-paths-manifest.json +19 -18
- package/_standalone/.next/server/chunks/1550.js +1 -1
- package/_standalone/.next/server/chunks/1750.js +1 -0
- package/_standalone/.next/server/chunks/{9414.js → 2190.js} +1 -1
- package/_standalone/.next/server/chunks/2536.js +52 -0
- package/_standalone/.next/server/chunks/5648.js +2 -0
- package/_standalone/.next/server/chunks/6539.js +1 -1
- package/_standalone/.next/server/chunks/8388.js +15 -0
- package/_standalone/.next/server/chunks/953.js +42 -2
- package/_standalone/.next/server/chunks/9539.js +219 -0
- package/_standalone/.next/server/functions-config-manifest.json +2 -1
- package/_standalone/.next/server/instrumentation.js +1 -1
- package/_standalone/.next/server/middleware-build-manifest.js +1 -1
- package/_standalone/.next/server/middleware-react-loadable-manifest.js +1 -1
- package/_standalone/.next/server/pages/500.html +2 -2
- package/_standalone/.next/server/server-reference-manifest.js +1 -1
- package/_standalone/.next/server/server-reference-manifest.json +1 -1
- package/_standalone/.next/static/Ij3PFh-a0zi5K_ANoSAW0/_buildManifest.js +1 -0
- package/_standalone/.next/static/chunks/1053-b70535785cc5aaee.js +29 -0
- package/_standalone/.next/static/chunks/1239.10a0710c2772ab34.js +1 -0
- package/_standalone/.next/static/chunks/{1814.e2da5460ded71d71.js → 1814.2ee1d03297c0bccd.js} +1 -1
- package/_standalone/.next/static/chunks/{1384-55276d40a9da4e88.js → 1880-c2a9e76201841c86.js} +2 -2
- package/_standalone/.next/static/chunks/{1a258343-030e4d6735874dd4.js → 1a258343-9803591e4aaee1f6.js} +1 -1
- package/_standalone/.next/static/chunks/2631.dc56e83472bde281.js +1 -0
- package/_standalone/.next/static/chunks/2872.045858d00bd8307f.js +8 -0
- package/_standalone/.next/static/chunks/2968.f10ccee9e7e2324d.js +2 -0
- package/_standalone/.next/static/chunks/3160-83a7e0b94414b3ac.js +1 -0
- package/_standalone/.next/static/chunks/3637.0541ac2d0ea7de1f.js +1 -0
- package/_standalone/.next/static/chunks/4033.6666700547b20141.js +1 -0
- package/_standalone/.next/static/chunks/4563-b2a2ce80aff845af.js +6 -0
- package/_standalone/.next/static/chunks/516.24ee058b1d4b1fed.js +8 -0
- package/_standalone/.next/static/chunks/5627.c4337d7289acb31f.js +1 -0
- package/_standalone/.next/static/chunks/5956.b445072b35915129.js +1 -0
- package/_standalone/.next/static/chunks/6357-c645842834c0d4cd.js +1 -0
- package/_standalone/.next/static/chunks/6826.7b7d94dd0fd83812.js +1 -0
- package/_standalone/.next/static/chunks/{8409-de5726a4a278d28f.js → 6926-4af497b83952fa87.js} +1 -1
- package/_standalone/.next/static/chunks/6981-3d7dcac2d12a5670.js +1 -0
- package/_standalone/.next/static/chunks/7144-5febf62f1a79fe64.js +1 -0
- package/_standalone/.next/static/chunks/7266-bb7be1128eccd48e.js +13 -0
- package/_standalone/.next/static/chunks/7753.63831cfc54a55fbb.js +1 -0
- package/_standalone/.next/static/chunks/862.9f526e964489e2e5.js +1 -0
- package/_standalone/.next/static/chunks/9300.118b8c840634383f.js +28 -0
- package/_standalone/.next/static/chunks/95247769.3b5caae1c1a76ce1.js +4 -0
- package/_standalone/.next/static/chunks/9602-423291fdb36396d1.js +1 -0
- package/_standalone/.next/static/chunks/app/.well-known/agent-card.json/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/_global-error/page-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/agents/[agentKey]/page-773071a99c4daac2.js +1 -0
- package/_standalone/.next/static/chunks/app/agents/page-6102a884b2cb3cfe.js +5 -0
- package/_standalone/.next/static/chunks/app/api/a2a/agents/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/a2a/delegations/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/a2a/discover/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/a2a/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/acp/config/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/acp/detect/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/acp/install/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/acp/registry/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/acp/session/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/agent-activity/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/ask/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/ask-sessions/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/auth/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/backlinks/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/bootstrap/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/changes/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/export/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/extract-pdf/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/file/import/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/file/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/files/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/git/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/graph/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/health/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/inbox/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/init/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/mcp/agents/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/mcp/install/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/mcp/install-skill/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/mcp/restart/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/mcp/status/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/monitoring/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/recent-files/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/restart/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/search/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/settings/list-models/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/settings/reset-token/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/settings/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/settings/test-key/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/setup/check-path/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/setup/check-port/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/setup/generate-token/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/setup/ls/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/setup/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/skills/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/sync/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/tree-version/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/uninstall/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/update/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/update-check/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/update-status/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/api/workflows/route-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/changes/page-350992cf5091bc5b.js +1 -0
- package/_standalone/.next/static/chunks/app/echo/[segment]/page-addf014fcf23fad5.js +11 -0
- package/_standalone/.next/static/chunks/app/echo/page-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/explore/page-5eb2835e9e3ab4bb.js +4 -0
- package/_standalone/.next/static/chunks/app/help/page-2325d25b6846ca07.js +1 -0
- package/_standalone/.next/static/chunks/app/layout-42cdbce19f404567.js +186 -0
- package/_standalone/.next/static/chunks/app/login/page-24236460fa7c11d0.js +1 -0
- package/_standalone/.next/static/chunks/app/page-8c9643b649e01735.js +7 -0
- package/_standalone/.next/static/chunks/app/setup/page-d158b8cb533feb1e.js +1 -0
- package/_standalone/.next/static/chunks/app/trash/page-e9ab74ffeb96af41.js +1 -0
- package/_standalone/.next/static/chunks/app/view/[...path]/loading-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/app/view/[...path]/not-found-61474670d6bb6116.js +1 -0
- package/_standalone/.next/static/chunks/app/view/[...path]/page-764a69a1c8bd4eef.js +12 -0
- package/_standalone/.next/static/chunks/e71f6c19-4df85185bf989b49.js +1 -0
- package/_standalone/.next/static/chunks/next/dist/client/components/builtin/app-error-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/next/dist/client/components/builtin/forbidden-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/next/dist/client/components/builtin/not-found-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/next/dist/client/components/builtin/unauthorized-400c3c09b1540c14.js +1 -0
- package/_standalone/.next/static/chunks/webpack-7b276daaa930d480.js +1 -0
- package/_standalone/.next/static/css/bc9179074eaf65ae.css +1 -0
- package/_standalone/.next/trace +63 -53
- package/_standalone/.next/types/routes.d.ts +2 -1
- package/_standalone/.next/types/validator.ts +9 -0
- package/_standalone/__tests__/agent/chat-mode.test.ts +103 -0
- package/_standalone/__tests__/agents/agents-content-dashboard.test.tsx +4 -3
- package/_standalone/__tests__/api/bootstrap.test.ts +0 -2
- package/_standalone/__tests__/api/file.test.ts +22 -1
- package/_standalone/__tests__/api/install-skill.test.ts +2 -2
- package/_standalone/__tests__/api/mcp-install.test.ts +32 -10
- package/_standalone/__tests__/api/setup.test.ts +2 -2
- package/_standalone/__tests__/api/test-key.test.ts +73 -147
- package/_standalone/__tests__/ask/ask-content-input-during-run.test.tsx +1 -1
- package/_standalone/__tests__/ask/mode-capsule.test.ts +95 -0
- package/_standalone/__tests__/cli/agent-routing.test.ts +232 -0
- package/_standalone/__tests__/cli/file-subcommands.test.ts +379 -0
- package/_standalone/__tests__/core/inbox.test.ts +250 -0
- package/_standalone/__tests__/core/skill-install-logic.test.ts +3 -3
- package/_standalone/__tests__/core/sync-status.test.ts +1 -1
- package/_standalone/__tests__/core/tools.test.ts +8 -6
- package/_standalone/__tests__/lib/echo-pages-visual-i18n.test.ts +2 -2
- package/_standalone/__tests__/lib/i18n-new-keys.test.ts +2 -2
- package/_standalone/__tests__/panels/agents-panel-hub.test.tsx +2 -2
- package/_standalone/__tests__/settings/activity-bar-update-badge.test.tsx +1 -1
- package/_standalone/__tests__/settings/settings-update-badge.test.tsx +1 -1
- package/_standalone/__tests__/settings/update-tab-availability-sync.test.tsx +1 -1
- package/_standalone/__tests__/settings/update-tab-browser.test.tsx +1 -1
- package/_standalone/__tests__/settings/update-tab-desktop.test.tsx +1 -1
- package/_standalone/__tests__/setup.ts +3 -5
- package/_standalone/app/globals.css +11 -1
- package/_standalone/components/ActivityBar.tsx +26 -10
- package/_standalone/components/AskFab.tsx +1 -1
- package/_standalone/components/AskModal.tsx +1 -1
- package/_standalone/components/Backlinks.tsx +1 -1
- package/_standalone/components/CreateSpaceModal.tsx +7 -55
- package/_standalone/components/EchoSpotlight.tsx +1 -1
- package/_standalone/components/ExportModal.tsx +1 -1
- package/_standalone/components/FileTree.tsx +66 -80
- package/_standalone/components/FindInPage.tsx +1 -1
- package/_standalone/components/GuideCard.tsx +1 -1
- package/_standalone/components/ImportModal.tsx +1 -1
- package/_standalone/components/KeyboardShortcuts.tsx +1 -1
- package/_standalone/components/MarkdownView.tsx +41 -16
- package/_standalone/components/OnboardingView.tsx +1 -1
- package/_standalone/components/OrganizeToast.tsx +1 -1
- package/_standalone/components/Panel.tsx +82 -4
- package/_standalone/components/QuickSuggestion.tsx +1 -1
- package/_standalone/components/RightAgentDetailPanel.tsx +2 -2
- package/_standalone/components/RightAskPanel.tsx +88 -22
- package/_standalone/components/SearchModal.tsx +1 -1
- package/_standalone/components/Sidebar.tsx +4 -4
- package/_standalone/components/SidebarLayout.tsx +52 -16
- package/_standalone/components/SpaceInitToast.tsx +1 -1
- package/_standalone/components/SyncStatusBar.tsx +2 -2
- package/_standalone/components/SystemPulse.tsx +12 -6
- package/_standalone/components/TableOfContents.tsx +86 -39
- package/_standalone/components/agents/AgentActivitySection.tsx +225 -0
- package/_standalone/components/agents/AgentsMcpSection.tsx +10 -16
- package/_standalone/components/agents/AgentsOverviewSection.tsx +28 -27
- package/_standalone/components/agents/AgentsPanelA2aTab.tsx +1 -1
- package/_standalone/components/agents/AgentsPanelSessionsTab.tsx +6 -1
- package/_standalone/components/agents/AgentsSkillsSection.tsx +1 -1
- package/_standalone/components/agents/DiscoverAgentModal.tsx +1 -1
- package/_standalone/components/agents/RecentActivityFeed.tsx +49 -88
- package/_standalone/components/agents/agent-activity-shared.tsx +110 -0
- package/_standalone/components/ask/AgentSelectorCapsule.tsx +1 -1
- package/_standalone/components/ask/AskContent.tsx +332 -486
- package/_standalone/components/ask/AskHeader.tsx +61 -0
- package/_standalone/components/ask/FileChip.tsx +9 -5
- package/_standalone/components/ask/MessageList.tsx +88 -21
- package/_standalone/components/ask/ModeCapsule.tsx +180 -0
- package/_standalone/components/ask/ProviderModelCapsule.tsx +284 -0
- package/_standalone/components/ask/SessionHistory.tsx +63 -10
- package/_standalone/components/ask/SessionTabBar.tsx +1 -1
- package/_standalone/components/ask/ThinkingBlock.tsx +1 -1
- package/_standalone/components/ask/ToolCallBlock.tsx +28 -24
- package/_standalone/components/changes/ChangesBanner.tsx +1 -1
- package/_standalone/components/echo/EchoInsightCollapsible.tsx +1 -1
- package/_standalone/components/echo/EchoSegmentNav.tsx +1 -1
- package/_standalone/components/home/InboxSection.tsx +268 -0
- package/_standalone/components/panels/AgentsPanel.tsx +3 -2
- package/_standalone/components/panels/AgentsPanelHubNav.tsx +2 -6
- package/_standalone/components/panels/DiscoverPanel.tsx +1 -1
- package/_standalone/components/panels/EchoPanel.tsx +1 -1
- package/_standalone/components/panels/EchoSidebarStats.tsx +1 -1
- package/_standalone/components/panels/ImportHistoryPanel.tsx +1 -1
- package/_standalone/components/panels/PanelHeader.tsx +1 -1
- package/_standalone/components/panels/PluginsPanel.tsx +1 -1
- package/_standalone/components/panels/SearchPanel.tsx +5 -2
- package/_standalone/components/panels/SyncPopover.tsx +1 -1
- package/_standalone/components/panels/WorkflowsPanel.tsx +1 -1
- package/_standalone/components/renderers/agent-inspector/AgentInspectorRenderer.tsx +18 -0
- package/_standalone/components/renderers/todo/TodoRenderer.tsx +489 -75
- package/_standalone/components/settings/AiTab.tsx +198 -127
- package/_standalone/components/settings/AppearanceTab.tsx +48 -50
- package/_standalone/components/settings/KnowledgeTab.tsx +92 -27
- package/_standalone/components/settings/McpAgentInstall.tsx +95 -28
- package/_standalone/components/settings/McpSkillsSection.tsx +2 -2
- package/_standalone/components/settings/McpTab.tsx +498 -216
- package/_standalone/components/settings/PluginsTab.tsx +1 -1
- package/_standalone/components/settings/SettingsContent.tsx +17 -8
- package/_standalone/components/settings/SyncTab.tsx +615 -230
- package/_standalone/components/settings/UninstallTab.tsx +1 -1
- package/_standalone/components/settings/UpdateTab.tsx +2 -2
- package/_standalone/components/settings/types.ts +7 -5
- package/_standalone/components/setup/StepAI.tsx +70 -49
- package/_standalone/components/setup/StepAgents.tsx +113 -47
- package/_standalone/components/setup/StepDots.tsx +1 -1
- package/_standalone/components/setup/StepReview.tsx +186 -31
- package/_standalone/components/setup/types.ts +17 -8
- package/_standalone/components/shared/ProviderSelect.tsx +134 -0
- package/_standalone/components/walkthrough/WalkthroughOverlay.tsx +2 -2
- package/_standalone/components/walkthrough/WalkthroughTooltip.tsx +2 -2
- package/_standalone/components/walkthrough/index.ts +1 -1
- package/_standalone/data/skills/mindos/SKILL.md +93 -93
- package/_standalone/data/skills/mindos/references/write-supplement.md +119 -0
- package/_standalone/data/skills/mindos-zh/SKILL.md +100 -104
- package/_standalone/data/skills/mindos-zh/references/write-supplement.md +119 -0
- package/_standalone/hooks/useAcpDetection.ts +1 -1
- package/_standalone/hooks/useAskChat.ts +248 -0
- package/_standalone/hooks/useAskPanel.ts +24 -4
- package/_standalone/hooks/useAskSession.ts +15 -0
- package/_standalone/lib/acp/types.ts +1 -1
- package/_standalone/lib/api.ts +3 -1
- package/_standalone/lib/core/types.ts +2 -0
- package/_standalone/lib/i18n/modules/ai-chat.ts +35 -13
- package/_standalone/lib/i18n/modules/features.ts +5 -5
- package/_standalone/lib/i18n/modules/knowledge.ts +86 -2
- package/_standalone/lib/i18n/modules/navigation.ts +6 -2
- package/_standalone/lib/i18n/modules/onboarding.ts +69 -29
- package/_standalone/lib/i18n/modules/panels.ts +78 -29
- package/_standalone/lib/i18n/modules/settings.ts +280 -24
- package/_standalone/lib/inbox-upload.ts +93 -0
- package/_standalone/lib/mcp-snippets.ts +5 -1
- package/_standalone/lib/settings-ai-client.ts +13 -12
- package/_standalone/lib/space-ai-init.ts +66 -0
- package/_standalone/lib/stores/McpStoreInit.tsx +18 -0
- package/_standalone/lib/stores/WalkthroughInit.tsx +20 -0
- package/_standalone/lib/stores/locale-store.ts +55 -0
- package/_standalone/lib/stores/mcp-store.ts +156 -0
- package/_standalone/lib/stores/walkthrough-store.ts +118 -0
- package/_standalone/package-lock.json +40 -8
- package/_standalone/package.json +3 -1
- package/_standalone/tsconfig.json +1 -1
- package/_standalone/tsconfig.tsbuildinfo +1 -1
- package/app/app/api/acp/detect/route.ts +29 -20
- package/app/app/api/agent-activity/route.ts +1 -1
- package/app/app/api/ask/route.ts +105 -30
- package/app/app/api/ask-sessions/route.ts +1 -0
- package/app/app/api/bootstrap/route.ts +1 -3
- package/app/app/api/file/route.ts +34 -4
- package/app/app/api/inbox/route.ts +61 -0
- package/app/app/api/mcp/install/route.ts +2 -1
- package/app/app/api/mcp/status/route.ts +14 -6
- package/app/app/api/settings/list-models/route.ts +73 -53
- package/app/app/api/settings/route.ts +46 -55
- package/app/app/api/settings/test-key/route.ts +57 -114
- package/app/app/api/setup/route.ts +31 -21
- package/app/app/api/sync/route.ts +122 -12
- package/app/app/api/update-check/route.ts +2 -2
- package/app/app/globals.css +11 -1
- package/app/app/layout.tsx +2 -3
- package/app/app/login/page.tsx +1 -1
- package/app/app/view/[...path]/ViewPageClient.tsx +22 -37
- package/app/app/view/[...path]/not-found.tsx +1 -1
- package/app/components/ActivityBar.tsx +26 -10
- package/app/components/AskFab.tsx +1 -1
- package/app/components/AskModal.tsx +1 -1
- package/app/components/Backlinks.tsx +1 -1
- package/app/components/CreateSpaceModal.tsx +7 -55
- package/app/components/DirView.tsx +93 -11
- package/app/components/EchoSpotlight.tsx +1 -1
- package/app/components/ExportModal.tsx +1 -1
- package/app/components/FileTree.tsx +66 -80
- package/app/components/FindInPage.tsx +1 -1
- package/app/components/GuideCard.tsx +1 -1
- package/app/components/HomeContent.tsx +21 -14
- package/app/components/ImportModal.tsx +1 -1
- package/app/components/KeyboardShortcuts.tsx +1 -1
- package/app/components/MarkdownView.tsx +41 -16
- package/app/components/OnboardingView.tsx +1 -1
- package/app/components/OrganizeToast.tsx +1 -1
- package/app/components/Panel.tsx +82 -4
- package/app/components/QuickSuggestion.tsx +1 -1
- package/app/components/RightAgentDetailPanel.tsx +2 -2
- package/app/components/RightAskPanel.tsx +88 -22
- package/app/components/SearchModal.tsx +1 -1
- package/app/components/Sidebar.tsx +4 -4
- package/app/components/SidebarLayout.tsx +52 -16
- package/app/components/SpaceInitToast.tsx +1 -1
- package/app/components/SyncStatusBar.tsx +2 -2
- package/app/components/SystemPulse.tsx +12 -6
- package/app/components/TableOfContents.tsx +86 -39
- package/app/components/TrashPageClient.tsx +1 -1
- package/app/components/UpdateOverlay.tsx +2 -2
- package/app/components/agents/AgentActivitySection.tsx +225 -0
- package/app/components/agents/AgentDetailContent.tsx +234 -3
- package/app/components/agents/AgentsContentPage.tsx +13 -2
- package/app/components/agents/AgentsMcpSection.tsx +10 -16
- package/app/components/agents/AgentsOverviewSection.tsx +28 -27
- package/app/components/agents/AgentsPanelA2aTab.tsx +1 -1
- package/app/components/agents/AgentsPanelSessionsTab.tsx +6 -1
- package/app/components/agents/AgentsSkillsSection.tsx +1 -1
- package/app/components/agents/DiscoverAgentModal.tsx +1 -1
- package/app/components/agents/RecentActivityFeed.tsx +49 -88
- package/app/components/agents/agent-activity-shared.tsx +110 -0
- package/app/components/agents/agents-content-model.ts +2 -2
- package/app/components/ask/AgentSelectorCapsule.tsx +1 -1
- package/app/components/ask/AskContent.tsx +332 -486
- package/app/components/ask/AskHeader.tsx +61 -0
- package/app/components/ask/FileChip.tsx +9 -5
- package/app/components/ask/MessageList.tsx +88 -21
- package/app/components/ask/ModeCapsule.tsx +180 -0
- package/app/components/ask/ProviderModelCapsule.tsx +284 -0
- package/app/components/ask/SessionHistory.tsx +63 -10
- package/app/components/ask/SessionTabBar.tsx +1 -1
- package/app/components/ask/ThinkingBlock.tsx +1 -1
- package/app/components/ask/ToolCallBlock.tsx +28 -24
- package/app/components/changes/ChangesBanner.tsx +1 -1
- package/app/components/changes/ChangesContentPage.tsx +1 -1
- package/app/components/echo/EchoInsightCollapsible.tsx +1 -1
- package/app/components/echo/EchoSegmentNav.tsx +1 -1
- package/app/components/echo/EchoSegmentPageClient.tsx +1 -1
- package/app/components/explore/ExploreContent.tsx +1 -1
- package/app/components/help/HelpContent.tsx +2 -1
- package/app/components/home/InboxSection.tsx +268 -0
- package/app/components/panels/AgentsPanel.tsx +3 -2
- package/app/components/panels/AgentsPanelHubNav.tsx +2 -6
- package/app/components/panels/DiscoverPanel.tsx +1 -1
- package/app/components/panels/EchoPanel.tsx +1 -1
- package/app/components/panels/EchoSidebarStats.tsx +1 -1
- package/app/components/panels/ImportHistoryPanel.tsx +1 -1
- package/app/components/panels/PanelHeader.tsx +1 -1
- package/app/components/panels/PluginsPanel.tsx +1 -1
- package/app/components/panels/SearchPanel.tsx +5 -2
- package/app/components/panels/SyncPopover.tsx +1 -1
- package/app/components/panels/WorkflowsPanel.tsx +1 -1
- package/app/components/renderers/agent-inspector/AgentInspectorRenderer.tsx +18 -0
- package/app/components/renderers/todo/TodoRenderer.tsx +489 -75
- package/app/components/settings/AiTab.tsx +198 -127
- package/app/components/settings/AppearanceTab.tsx +48 -50
- package/app/components/settings/KnowledgeTab.tsx +92 -27
- package/app/components/settings/McpAgentInstall.tsx +95 -28
- package/app/components/settings/McpSkillsSection.tsx +2 -2
- package/app/components/settings/McpTab.tsx +498 -216
- package/app/components/settings/PluginsTab.tsx +1 -1
- package/app/components/settings/SettingsContent.tsx +17 -8
- package/app/components/settings/SyncTab.tsx +615 -230
- package/app/components/settings/UninstallTab.tsx +1 -1
- package/app/components/settings/UpdateTab.tsx +2 -2
- package/app/components/settings/types.ts +7 -5
- package/app/components/setup/StepAI.tsx +70 -49
- package/app/components/setup/StepAgents.tsx +113 -47
- package/app/components/setup/StepDots.tsx +1 -1
- package/app/components/setup/StepReview.tsx +186 -31
- package/app/components/setup/index.tsx +83 -48
- package/app/components/setup/types.ts +17 -8
- package/app/components/shared/ProviderSelect.tsx +134 -0
- package/app/components/walkthrough/WalkthroughOverlay.tsx +2 -2
- package/app/components/walkthrough/WalkthroughTooltip.tsx +2 -2
- package/app/components/walkthrough/index.ts +1 -1
- package/app/data/skills/mindos/SKILL.md +93 -93
- package/app/data/skills/mindos/references/write-supplement.md +119 -0
- package/app/data/skills/mindos-zh/SKILL.md +100 -104
- package/app/data/skills/mindos-zh/references/write-supplement.md +119 -0
- package/app/hooks/useAcpDetection.ts +1 -1
- package/app/hooks/useAskChat.ts +248 -0
- package/app/hooks/useAskPanel.ts +24 -4
- package/app/hooks/useAskSession.ts +15 -0
- package/app/lib/acp/types.ts +1 -1
- package/app/lib/actions.ts +13 -0
- package/app/lib/agent/log.ts +2 -0
- package/app/lib/agent/model.ts +69 -81
- package/app/lib/agent/prompt.ts +27 -0
- package/app/lib/agent/providers.ts +299 -0
- package/app/lib/agent/tools.ts +26 -4
- package/app/lib/api.ts +3 -1
- package/app/lib/core/agent-audit-log.ts +7 -0
- package/app/lib/core/fs-ops.ts +9 -4
- package/app/lib/core/inbox.ts +181 -0
- package/app/lib/core/index.ts +4 -0
- package/app/lib/core/tree.ts +3 -0
- package/app/lib/core/types.ts +2 -0
- package/app/lib/fs.ts +20 -2
- package/app/lib/i18n/modules/ai-chat.ts +35 -13
- package/app/lib/i18n/modules/features.ts +5 -5
- package/app/lib/i18n/modules/knowledge.ts +86 -2
- package/app/lib/i18n/modules/navigation.ts +6 -2
- package/app/lib/i18n/modules/onboarding.ts +69 -29
- package/app/lib/i18n/modules/panels.ts +78 -29
- package/app/lib/i18n/modules/settings.ts +280 -24
- package/app/lib/inbox-upload.ts +93 -0
- package/app/lib/mcp-agents.ts +7 -9
- package/app/lib/mcp-snippets.ts +5 -1
- package/app/lib/settings-ai-client.ts +13 -12
- package/app/lib/settings.ts +48 -33
- package/app/lib/space-ai-init.ts +66 -0
- package/app/lib/stores/LocaleStoreInit.tsx +18 -0
- package/app/lib/stores/McpStoreInit.tsx +18 -0
- package/app/lib/stores/WalkthroughInit.tsx +20 -0
- package/app/lib/stores/locale-store.ts +55 -0
- package/app/lib/stores/mcp-store.ts +156 -0
- package/app/lib/stores/walkthrough-store.ts +118 -0
- package/app/lib/types.ts +20 -0
- package/app/package.json +3 -1
- package/app/tsconfig.json +1 -1
- package/bin/cli.js +168 -1385
- package/bin/commands/agent.js +156 -20
- package/bin/commands/api.js +14 -11
- package/bin/commands/ask.js +79 -68
- package/bin/commands/build.js +26 -0
- package/bin/commands/config.js +170 -0
- package/bin/commands/dev.js +58 -0
- package/bin/commands/doctor.js +205 -0
- package/bin/commands/file.js +558 -40
- package/bin/commands/gateway.js +42 -0
- package/bin/commands/init-skills.js +56 -0
- package/bin/commands/logs.js +32 -0
- package/bin/commands/mcp-cmd.js +57 -0
- package/bin/commands/onboard.js +25 -0
- package/bin/commands/open.js +41 -0
- package/bin/commands/restart.js +48 -0
- package/bin/commands/search.js +16 -14
- package/bin/commands/space.js +100 -25
- package/bin/commands/start.js +262 -0
- package/bin/commands/status.js +2 -2
- package/bin/commands/stop.js +14 -0
- package/bin/commands/sync-cmd.js +134 -0
- package/bin/commands/token.js +98 -0
- package/bin/commands/uninstall.js +154 -0
- package/bin/commands/update.js +286 -0
- package/bin/lib/build.js +1 -1
- package/bin/lib/colors.js +8 -7
- package/bin/lib/command.js +37 -96
- package/bin/lib/config.js +5 -0
- package/bin/lib/csv.js +19 -0
- package/bin/lib/jsonc.js +12 -0
- package/bin/lib/markdown.js +69 -0
- package/bin/lib/mcp-agents.js +27 -8
- package/bin/lib/mcp-build.js +1 -1
- package/bin/lib/mcp-install.js +13 -4
- package/bin/lib/one-shot.js +88 -0
- package/bin/lib/path-expand.js +9 -0
- package/bin/lib/remote.js +65 -0
- package/bin/lib/repl.js +167 -0
- package/bin/lib/{utils.js → shell.js} +10 -26
- package/bin/lib/skill-check.js +1 -1
- package/bin/lib/sse-stream.js +167 -0
- package/bin/lib/sync.js +140 -34
- package/mcp/README.md +2 -2
- package/mcp/dist/index.cjs +43 -43
- package/mcp/package.json +1 -1
- package/mcp/src/index.ts +77 -61
- package/package.json +2 -2
- package/scripts/setup.js +183 -121
- package/skills/mindos/SKILL.md +93 -93
- package/skills/mindos/references/preference-capture.md +4 -4
- package/skills/mindos/references/write-supplement.md +2 -2
- package/skills/mindos-zh/SKILL.md +100 -104
- package/skills/mindos-zh/references/preference-capture.md +4 -4
- package/skills/mindos-zh/references/write-supplement.md +2 -2
- package/templates/empty/INSTRUCTION.md +0 -1
- package/templates/en/INSTRUCTION.md +0 -1
- package/templates/template-generation-skill.md +0 -1
- package/templates/zh/INSTRUCTION.md +0 -1
- package/_standalone/.next/server/chunks/1473.js +0 -52
- package/_standalone/.next/server/chunks/248.js +0 -15
- package/_standalone/.next/server/chunks/359.js +0 -2
- package/_standalone/.next/server/chunks/4931.js +0 -202
- package/_standalone/.next/server/chunks/7670.js +0 -1
- package/_standalone/.next/static/chunks/1038-ed04d6651ec92312.js +0 -1
- package/_standalone/.next/static/chunks/1263-6df1734e4273adb1.js +0 -25
- package/_standalone/.next/static/chunks/275-ebcaaedabe706903.js +0 -1
- package/_standalone/.next/static/chunks/3637.4bcd01a4db78b894.js +0 -1
- package/_standalone/.next/static/chunks/5637-b97c869adf70c82e.js +0 -1
- package/_standalone/.next/static/chunks/5681-a53362a1cd629dc6.js +0 -1
- package/_standalone/.next/static/chunks/9602-35ca17b688f1a4fe.js +0 -1
- package/_standalone/.next/static/chunks/9670-d59e4d45ed705f58.js +0 -6
- package/_standalone/.next/static/chunks/app/.well-known/agent-card.json/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/_global-error/page-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/agents/[agentKey]/page-519d4da1142db5ef.js +0 -1
- package/_standalone/.next/static/chunks/app/agents/page-b709cf3103321609.js +0 -5
- package/_standalone/.next/static/chunks/app/api/a2a/agents/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/a2a/delegations/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/a2a/discover/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/a2a/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/acp/config/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/acp/detect/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/acp/install/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/acp/registry/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/acp/session/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/agent-activity/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/ask/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/ask-sessions/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/auth/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/backlinks/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/bootstrap/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/changes/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/export/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/extract-pdf/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/file/import/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/file/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/files/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/git/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/graph/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/health/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/init/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/mcp/agents/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/mcp/install/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/mcp/install-skill/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/mcp/restart/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/mcp/status/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/monitoring/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/recent-files/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/restart/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/search/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/settings/list-models/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/settings/reset-token/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/settings/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/settings/test-key/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/setup/check-path/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/setup/check-port/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/setup/generate-token/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/setup/ls/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/setup/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/skills/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/sync/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/tree-version/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/uninstall/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/update/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/update-check/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/update-status/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/api/workflows/route-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/changes/page-def5210095f8698d.js +0 -1
- package/_standalone/.next/static/chunks/app/echo/[segment]/page-be28eff31b1a186e.js +0 -11
- package/_standalone/.next/static/chunks/app/echo/page-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/explore/page-e4b8098dca200389.js +0 -4
- package/_standalone/.next/static/chunks/app/help/page-d5e57d73d94bad19.js +0 -1
- package/_standalone/.next/static/chunks/app/layout-d91cdbe2ecf135e1.js +0 -173
- package/_standalone/.next/static/chunks/app/login/page-321875768b70938a.js +0 -1
- package/_standalone/.next/static/chunks/app/page-718fdf170428b43c.js +0 -7
- package/_standalone/.next/static/chunks/app/setup/page-01ab1f549d636057.js +0 -1
- package/_standalone/.next/static/chunks/app/trash/page-89b1430cc8a16f18.js +0 -1
- package/_standalone/.next/static/chunks/app/view/[...path]/loading-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/app/view/[...path]/not-found-f22c513bbc348cc8.js +0 -1
- package/_standalone/.next/static/chunks/app/view/[...path]/page-6e3dc47699a01de1.js +0 -12
- package/_standalone/.next/static/chunks/next/dist/client/components/builtin/app-error-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/next/dist/client/components/builtin/forbidden-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/next/dist/client/components/builtin/not-found-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/next/dist/client/components/builtin/unauthorized-d4762cc48529e566.js +0 -1
- package/_standalone/.next/static/chunks/webpack-3489a2b6c2882b0c.js +0 -1
- package/_standalone/.next/static/css/f16595bc58a16d5d.css +0 -1
- package/_standalone/.next/static/ushZ_NJ8rE3rG5hZfaYOX/_buildManifest.js +0 -1
- package/_standalone/components/walkthrough/WalkthroughProvider.tsx +0 -133
- package/_standalone/hooks/useMcpData.tsx +0 -169
- package/_standalone/lib/i18n-en.ts +0 -2
- package/_standalone/lib/i18n-zh.ts +0 -2
- package/_standalone/lib/types.ts +0 -70
- package/app/components/walkthrough/WalkthroughProvider.tsx +0 -133
- package/app/hooks/useMcpData.tsx +0 -169
- package/app/lib/LocaleContext.tsx +0 -60
- package/app/lib/i18n-en.ts +0 -2
- package/app/lib/i18n-zh.ts +0 -2
- /package/_standalone/.next/static/{ushZ_NJ8rE3rG5hZfaYOX → Ij3PFh-a0zi5K_ANoSAW0}/_ssgManifest.js +0 -0
|
@@ -0,0 +1,379 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tests for new `mindos file` subcommands:
|
|
3
|
+
* write, append, edit-section, insert-heading, append-csv, backlinks, recent, history
|
|
4
|
+
*
|
|
5
|
+
* Tests the pure-logic modules (markdown.js, csv.js) and integration via file.js helpers.
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
import { describe, it, expect, beforeEach, afterEach } from 'vitest';
|
|
9
|
+
import fs from 'fs';
|
|
10
|
+
import os from 'os';
|
|
11
|
+
import path from 'path';
|
|
12
|
+
import { execFileSync } from 'child_process';
|
|
13
|
+
|
|
14
|
+
function mkTmp(): string {
|
|
15
|
+
return fs.mkdtempSync(path.join(os.tmpdir(), 'mindos-cli-file-'));
|
|
16
|
+
}
|
|
17
|
+
function cleanup(dir: string): void {
|
|
18
|
+
fs.rmSync(dir, { recursive: true, force: true });
|
|
19
|
+
}
|
|
20
|
+
function seed(root: string, rel: string, content: string): void {
|
|
21
|
+
const abs = path.join(root, rel);
|
|
22
|
+
fs.mkdirSync(path.dirname(abs), { recursive: true });
|
|
23
|
+
fs.writeFileSync(abs, content, 'utf-8');
|
|
24
|
+
}
|
|
25
|
+
function read(root: string, rel: string): string {
|
|
26
|
+
return fs.readFileSync(path.join(root, rel), 'utf-8');
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
// ── Markdown section logic (ported from app/lib/core/lines.ts) ──
|
|
30
|
+
|
|
31
|
+
function findHeadingIndex(lines: string[], heading: string): number {
|
|
32
|
+
return lines.findIndex(l => {
|
|
33
|
+
const trimmed = l.trim();
|
|
34
|
+
return trimmed === heading || trimmed.replace(/^#+\s*/, '') === heading.replace(/^#+\s*/, '');
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
function replaceSection(content: string, heading: string, newBody: string): string {
|
|
39
|
+
const lines = content.split('\n');
|
|
40
|
+
const idx = findHeadingIndex(lines, heading);
|
|
41
|
+
if (idx === -1) return '';
|
|
42
|
+
|
|
43
|
+
const headingLevel = (lines[idx].match(/^#+/) ?? [''])[0].length;
|
|
44
|
+
let sectionEnd = lines.length - 1;
|
|
45
|
+
for (let i = idx + 1; i < lines.length; i++) {
|
|
46
|
+
const m = lines[i].match(/^(#+)\s/);
|
|
47
|
+
if (m && m[1].length <= headingLevel) {
|
|
48
|
+
sectionEnd = i - 1;
|
|
49
|
+
break;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
while (sectionEnd > idx && lines[sectionEnd].trim() === '') sectionEnd--;
|
|
53
|
+
|
|
54
|
+
const before = lines.slice(0, idx + 1);
|
|
55
|
+
const after = lines.slice(sectionEnd + 1);
|
|
56
|
+
return [...before, '', newBody, ...after].join('\n');
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
function insertAfterHeading(content: string, heading: string, insertion: string): string {
|
|
60
|
+
const lines = content.split('\n');
|
|
61
|
+
const idx = findHeadingIndex(lines, heading);
|
|
62
|
+
if (idx === -1) return '';
|
|
63
|
+
|
|
64
|
+
let insertAt = idx + 1;
|
|
65
|
+
while (insertAt < lines.length && lines[insertAt].trim() === '') insertAt++;
|
|
66
|
+
|
|
67
|
+
const before = lines.slice(0, insertAt);
|
|
68
|
+
const after = lines.slice(insertAt);
|
|
69
|
+
return [...before, '', insertion, ...after].join('\n');
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
function escapeCsvRow(row: string[]): string {
|
|
73
|
+
return row.map(cell => {
|
|
74
|
+
if (cell.includes(',') || cell.includes('"') || cell.includes('\n')) {
|
|
75
|
+
return `"${cell.replace(/"/g, '""')}"`;
|
|
76
|
+
}
|
|
77
|
+
return cell;
|
|
78
|
+
}).join(',');
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
function listHeadings(content: string): string[] {
|
|
82
|
+
return content.split('\n')
|
|
83
|
+
.filter(l => /^#{1,6}\s/.test(l))
|
|
84
|
+
.map(l => l.trim());
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
// ── Markdown replaceSection tests ──
|
|
88
|
+
|
|
89
|
+
describe('replaceSection', () => {
|
|
90
|
+
it('replaces section body between same-level headings', () => {
|
|
91
|
+
const input = '# Title\n\n## A\n\nOld A content\n\n## B\n\nB content';
|
|
92
|
+
const result = replaceSection(input, '## A', 'New A content');
|
|
93
|
+
expect(result).toContain('## A');
|
|
94
|
+
expect(result).toContain('New A content');
|
|
95
|
+
expect(result).not.toContain('Old A content');
|
|
96
|
+
expect(result).toContain('## B');
|
|
97
|
+
expect(result).toContain('B content');
|
|
98
|
+
});
|
|
99
|
+
|
|
100
|
+
it('replaces last section (no following heading)', () => {
|
|
101
|
+
const input = '# Title\n\n## A\n\nA content\n\n## B\n\nOld B';
|
|
102
|
+
const result = replaceSection(input, '## B', 'New B');
|
|
103
|
+
expect(result).toContain('New B');
|
|
104
|
+
expect(result).not.toContain('Old B');
|
|
105
|
+
});
|
|
106
|
+
|
|
107
|
+
it('returns empty string when heading not found', () => {
|
|
108
|
+
const input = '# Title\n\n## A\n\nContent';
|
|
109
|
+
expect(replaceSection(input, '## Missing', 'x')).toBe('');
|
|
110
|
+
});
|
|
111
|
+
|
|
112
|
+
it('handles heading with extra spaces', () => {
|
|
113
|
+
const input = '## Status \n\nOld status';
|
|
114
|
+
const result = replaceSection(input, '## Status', 'New status');
|
|
115
|
+
expect(result).toContain('New status');
|
|
116
|
+
});
|
|
117
|
+
|
|
118
|
+
it('stops at higher-level heading', () => {
|
|
119
|
+
const input = '# Title\n\n## A\n\nA stuff\n\n### Sub\n\nSub stuff\n\n## B\n\nB stuff';
|
|
120
|
+
const result = replaceSection(input, '## A', 'Replaced');
|
|
121
|
+
expect(result).toContain('Replaced');
|
|
122
|
+
expect(result).toContain('## B');
|
|
123
|
+
expect(result).toContain('B stuff');
|
|
124
|
+
expect(result).not.toContain('A stuff');
|
|
125
|
+
expect(result).not.toContain('Sub stuff');
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
it('replaces section with empty content', () => {
|
|
129
|
+
const input = '## A\n\nContent\n\n## B\n\nMore';
|
|
130
|
+
const result = replaceSection(input, '## A', '');
|
|
131
|
+
expect(result).toContain('## A');
|
|
132
|
+
expect(result).not.toContain('Content');
|
|
133
|
+
});
|
|
134
|
+
});
|
|
135
|
+
|
|
136
|
+
// ── insertAfterHeading tests ──
|
|
137
|
+
|
|
138
|
+
describe('insertAfterHeading', () => {
|
|
139
|
+
it('inserts after heading, before existing content', () => {
|
|
140
|
+
const input = '## Notes\n\nExisting note';
|
|
141
|
+
const result = insertAfterHeading(input, '## Notes', 'New note');
|
|
142
|
+
expect(result).toContain('## Notes');
|
|
143
|
+
expect(result).toContain('New note');
|
|
144
|
+
expect(result).toContain('Existing note');
|
|
145
|
+
const lines = result.split('\n');
|
|
146
|
+
const notesIdx = lines.findIndex(l => l.includes('## Notes'));
|
|
147
|
+
const newIdx = lines.findIndex(l => l.includes('New note'));
|
|
148
|
+
const existIdx = lines.findIndex(l => l.includes('Existing note'));
|
|
149
|
+
expect(newIdx).toBeGreaterThan(notesIdx);
|
|
150
|
+
expect(newIdx).toBeLessThan(existIdx);
|
|
151
|
+
});
|
|
152
|
+
|
|
153
|
+
it('returns empty string when heading not found', () => {
|
|
154
|
+
expect(insertAfterHeading('# Title', '## Missing', 'x')).toBe('');
|
|
155
|
+
});
|
|
156
|
+
|
|
157
|
+
it('inserts at end if heading is last thing', () => {
|
|
158
|
+
const input = '## Notes';
|
|
159
|
+
const result = insertAfterHeading(input, '## Notes', 'Added');
|
|
160
|
+
expect(result).toContain('## Notes');
|
|
161
|
+
expect(result).toContain('Added');
|
|
162
|
+
});
|
|
163
|
+
});
|
|
164
|
+
|
|
165
|
+
// ── CSV escaping tests ──
|
|
166
|
+
|
|
167
|
+
describe('escapeCsvRow', () => {
|
|
168
|
+
it('joins simple values', () => {
|
|
169
|
+
expect(escapeCsvRow(['a', 'b', 'c'])).toBe('a,b,c');
|
|
170
|
+
});
|
|
171
|
+
|
|
172
|
+
it('quotes values containing commas', () => {
|
|
173
|
+
expect(escapeCsvRow(['a,b', 'c'])).toBe('"a,b",c');
|
|
174
|
+
});
|
|
175
|
+
|
|
176
|
+
it('escapes double quotes', () => {
|
|
177
|
+
expect(escapeCsvRow(['say "hello"', 'x'])).toBe('"say ""hello""",x');
|
|
178
|
+
});
|
|
179
|
+
|
|
180
|
+
it('quotes values containing newlines', () => {
|
|
181
|
+
expect(escapeCsvRow(['line1\nline2', 'x'])).toBe('"line1\nline2",x');
|
|
182
|
+
});
|
|
183
|
+
|
|
184
|
+
it('handles empty strings', () => {
|
|
185
|
+
expect(escapeCsvRow(['', '', ''])).toBe(',,');
|
|
186
|
+
});
|
|
187
|
+
|
|
188
|
+
it('handles single value', () => {
|
|
189
|
+
expect(escapeCsvRow(['only'])).toBe('only');
|
|
190
|
+
});
|
|
191
|
+
});
|
|
192
|
+
|
|
193
|
+
// ── listHeadings tests ──
|
|
194
|
+
|
|
195
|
+
describe('listHeadings', () => {
|
|
196
|
+
it('extracts all markdown headings', () => {
|
|
197
|
+
const input = '# Title\n\nSome text\n\n## A\n\nContent\n\n### Sub\n\n## B';
|
|
198
|
+
expect(listHeadings(input)).toEqual(['# Title', '## A', '### Sub', '## B']);
|
|
199
|
+
});
|
|
200
|
+
|
|
201
|
+
it('returns empty for no headings', () => {
|
|
202
|
+
expect(listHeadings('Just text\nMore text')).toEqual([]);
|
|
203
|
+
});
|
|
204
|
+
|
|
205
|
+
it('ignores lines that look like headings inside code blocks', () => {
|
|
206
|
+
expect(listHeadings('## Real\n\n```\n## Not a heading\n```')).toContain('## Real');
|
|
207
|
+
});
|
|
208
|
+
});
|
|
209
|
+
|
|
210
|
+
// ── Backlinks logic tests ──
|
|
211
|
+
|
|
212
|
+
describe('findBacklinksLocal', () => {
|
|
213
|
+
let root: string;
|
|
214
|
+
beforeEach(() => { root = mkTmp(); });
|
|
215
|
+
afterEach(() => { cleanup(root); });
|
|
216
|
+
|
|
217
|
+
function findBacklinksLocal(mindRoot: string, targetPath: string): string[] {
|
|
218
|
+
const results: string[] = [];
|
|
219
|
+
const bname = path.basename(targetPath, '.md');
|
|
220
|
+
const escapedTarget = targetPath.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
|
|
221
|
+
const escapedBname = bname.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
|
|
222
|
+
|
|
223
|
+
const patterns = [
|
|
224
|
+
new RegExp(`\\[\\[${escapedBname}(?:[|#][^\\]]*)?\\]\\]`, 'i'),
|
|
225
|
+
new RegExp(`\\[\\[${escapedTarget}(?:[|#][^\\]]*)?\\]\\]`, 'i'),
|
|
226
|
+
new RegExp(`\\[[^\\]]+\\]\\(${escapedTarget}(?:#[^)]*)?\\)`, 'i'),
|
|
227
|
+
];
|
|
228
|
+
|
|
229
|
+
function walk(dir: string): void {
|
|
230
|
+
for (const entry of fs.readdirSync(dir, { withFileTypes: true })) {
|
|
231
|
+
if (entry.name.startsWith('.')) continue;
|
|
232
|
+
const full = path.join(dir, entry.name);
|
|
233
|
+
if (entry.isDirectory()) { walk(full); continue; }
|
|
234
|
+
if (!entry.name.endsWith('.md')) continue;
|
|
235
|
+
const rel = path.relative(mindRoot, full);
|
|
236
|
+
if (rel === targetPath) continue;
|
|
237
|
+
const content = fs.readFileSync(full, 'utf-8');
|
|
238
|
+
if (patterns.some(p => p.test(content))) results.push(rel);
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
walk(mindRoot);
|
|
242
|
+
return results;
|
|
243
|
+
}
|
|
244
|
+
|
|
245
|
+
it('finds wikilink references', () => {
|
|
246
|
+
seed(root, 'target.md', '# Target');
|
|
247
|
+
seed(root, 'linker.md', 'See [[target]] for details');
|
|
248
|
+
expect(findBacklinksLocal(root, 'target.md')).toEqual(['linker.md']);
|
|
249
|
+
});
|
|
250
|
+
|
|
251
|
+
it('finds markdown link references', () => {
|
|
252
|
+
seed(root, 'notes/plan.md', '# Plan');
|
|
253
|
+
seed(root, 'index.md', 'Check [the plan](notes/plan.md) here');
|
|
254
|
+
expect(findBacklinksLocal(root, 'notes/plan.md')).toEqual(['index.md']);
|
|
255
|
+
});
|
|
256
|
+
|
|
257
|
+
it('returns empty when no references', () => {
|
|
258
|
+
seed(root, 'a.md', '# A');
|
|
259
|
+
seed(root, 'b.md', '# B - no links');
|
|
260
|
+
expect(findBacklinksLocal(root, 'a.md')).toEqual([]);
|
|
261
|
+
});
|
|
262
|
+
|
|
263
|
+
it('excludes self-references', () => {
|
|
264
|
+
seed(root, 'self.md', 'Link to [[self]]');
|
|
265
|
+
expect(findBacklinksLocal(root, 'self.md')).toEqual([]);
|
|
266
|
+
});
|
|
267
|
+
});
|
|
268
|
+
|
|
269
|
+
// ── Recent files logic tests ──
|
|
270
|
+
|
|
271
|
+
describe('getRecentFiles', () => {
|
|
272
|
+
let root: string;
|
|
273
|
+
beforeEach(() => { root = mkTmp(); });
|
|
274
|
+
afterEach(() => { cleanup(root); });
|
|
275
|
+
|
|
276
|
+
function getRecentFiles(mindRoot: string, limit: number): Array<{path: string; mtime: number}> {
|
|
277
|
+
const results: Array<{path: string; mtime: number}> = [];
|
|
278
|
+
function walk(dir: string): void {
|
|
279
|
+
for (const entry of fs.readdirSync(dir, { withFileTypes: true })) {
|
|
280
|
+
if (entry.name.startsWith('.')) continue;
|
|
281
|
+
const full = path.join(dir, entry.name);
|
|
282
|
+
if (entry.isDirectory()) { walk(full); continue; }
|
|
283
|
+
if (!entry.name.endsWith('.md') && !entry.name.endsWith('.csv')) continue;
|
|
284
|
+
const stat = fs.statSync(full);
|
|
285
|
+
results.push({ path: path.relative(mindRoot, full), mtime: stat.mtimeMs });
|
|
286
|
+
}
|
|
287
|
+
}
|
|
288
|
+
walk(mindRoot);
|
|
289
|
+
results.sort((a, b) => b.mtime - a.mtime);
|
|
290
|
+
return results.slice(0, limit);
|
|
291
|
+
}
|
|
292
|
+
|
|
293
|
+
it('returns files sorted by modification time', () => {
|
|
294
|
+
seed(root, 'old.md', 'old');
|
|
295
|
+
const oldTime = Date.now() - 10000;
|
|
296
|
+
fs.utimesSync(path.join(root, 'old.md'), new Date(oldTime), new Date(oldTime));
|
|
297
|
+
seed(root, 'new.md', 'new');
|
|
298
|
+
const result = getRecentFiles(root, 10);
|
|
299
|
+
expect(result[0].path).toBe('new.md');
|
|
300
|
+
expect(result[1].path).toBe('old.md');
|
|
301
|
+
});
|
|
302
|
+
|
|
303
|
+
it('respects limit', () => {
|
|
304
|
+
seed(root, 'a.md', 'a');
|
|
305
|
+
seed(root, 'b.md', 'b');
|
|
306
|
+
seed(root, 'c.md', 'c');
|
|
307
|
+
expect(getRecentFiles(root, 2)).toHaveLength(2);
|
|
308
|
+
});
|
|
309
|
+
|
|
310
|
+
it('returns empty for empty directory', () => {
|
|
311
|
+
expect(getRecentFiles(root, 10)).toEqual([]);
|
|
312
|
+
});
|
|
313
|
+
|
|
314
|
+
it('skips hidden files', () => {
|
|
315
|
+
seed(root, '.hidden.md', 'hidden');
|
|
316
|
+
seed(root, 'visible.md', 'visible');
|
|
317
|
+
const result = getRecentFiles(root, 10);
|
|
318
|
+
expect(result).toHaveLength(1);
|
|
319
|
+
expect(result[0].path).toBe('visible.md');
|
|
320
|
+
});
|
|
321
|
+
});
|
|
322
|
+
|
|
323
|
+
// ── Git history tests (integration, requires git) ──
|
|
324
|
+
|
|
325
|
+
describe('gitHistory', () => {
|
|
326
|
+
let root: string;
|
|
327
|
+
let hasGit: boolean;
|
|
328
|
+
|
|
329
|
+
beforeEach(() => {
|
|
330
|
+
root = mkTmp();
|
|
331
|
+
try {
|
|
332
|
+
execFileSync('git', ['--version'], { stdio: 'pipe' });
|
|
333
|
+
hasGit = true;
|
|
334
|
+
} catch { hasGit = false; }
|
|
335
|
+
});
|
|
336
|
+
afterEach(() => { cleanup(root); });
|
|
337
|
+
|
|
338
|
+
it('returns git log entries for a file', () => {
|
|
339
|
+
if (!hasGit) return;
|
|
340
|
+
execFileSync('git', ['init'], { cwd: root, stdio: 'pipe' });
|
|
341
|
+
execFileSync('git', ['config', 'user.email', 'test@test.com'], { cwd: root, stdio: 'pipe' });
|
|
342
|
+
execFileSync('git', ['config', 'user.name', 'Test'], { cwd: root, stdio: 'pipe' });
|
|
343
|
+
seed(root, 'test.md', 'v1');
|
|
344
|
+
execFileSync('git', ['add', '.'], { cwd: root, stdio: 'pipe' });
|
|
345
|
+
execFileSync('git', ['commit', '-m', 'initial'], { cwd: root, stdio: 'pipe' });
|
|
346
|
+
|
|
347
|
+
const output = execFileSync(
|
|
348
|
+
'git',
|
|
349
|
+
['log', '--follow', '--format=%H%x00%aI%x00%s%x00%an', '-n', '10', '--', path.join(root, 'test.md')],
|
|
350
|
+
{ cwd: root, encoding: 'utf-8', stdio: ['pipe', 'pipe', 'pipe'] }
|
|
351
|
+
).trim();
|
|
352
|
+
|
|
353
|
+
const entries = output.split('\n').map(line => {
|
|
354
|
+
const [hash, date, message, author] = line.split('\0');
|
|
355
|
+
return { hash, date, message, author };
|
|
356
|
+
});
|
|
357
|
+
|
|
358
|
+
expect(entries).toHaveLength(1);
|
|
359
|
+
expect(entries[0].message).toBe('initial');
|
|
360
|
+
expect(entries[0].author).toBe('Test');
|
|
361
|
+
});
|
|
362
|
+
|
|
363
|
+
it('returns empty for file with no commits', () => {
|
|
364
|
+
if (!hasGit) return;
|
|
365
|
+
execFileSync('git', ['init'], { cwd: root, stdio: 'pipe' });
|
|
366
|
+
seed(root, 'untracked.md', 'content');
|
|
367
|
+
let output = '';
|
|
368
|
+
try {
|
|
369
|
+
output = execFileSync(
|
|
370
|
+
'git',
|
|
371
|
+
['log', '--follow', '--format=%H%x00%aI%x00%s%x00%an', '-n', '10', '--', path.join(root, 'untracked.md')],
|
|
372
|
+
{ cwd: root, encoding: 'utf-8', stdio: ['pipe', 'pipe', 'pipe'] }
|
|
373
|
+
).trim();
|
|
374
|
+
} catch {
|
|
375
|
+
output = '';
|
|
376
|
+
}
|
|
377
|
+
expect(output).toBe('');
|
|
378
|
+
});
|
|
379
|
+
});
|
|
@@ -0,0 +1,250 @@
|
|
|
1
|
+
import { describe, it, expect, beforeEach, afterEach } from 'vitest';
|
|
2
|
+
import fs from 'fs';
|
|
3
|
+
import path from 'path';
|
|
4
|
+
import { mkTempMindRoot, cleanupMindRoot, seedFile, readSeeded } from './helpers';
|
|
5
|
+
import {
|
|
6
|
+
INBOX_DIR,
|
|
7
|
+
ensureInboxSpace,
|
|
8
|
+
listInboxFiles,
|
|
9
|
+
saveToInbox,
|
|
10
|
+
} from '@/lib/core/inbox';
|
|
11
|
+
|
|
12
|
+
describe('ensureInboxSpace', () => {
|
|
13
|
+
let mindRoot: string;
|
|
14
|
+
|
|
15
|
+
beforeEach(() => { mindRoot = mkTempMindRoot(); });
|
|
16
|
+
afterEach(() => { cleanupMindRoot(mindRoot); });
|
|
17
|
+
|
|
18
|
+
it('creates Inbox directory with INSTRUCTION.md and README.md', () => {
|
|
19
|
+
const result = ensureInboxSpace(mindRoot);
|
|
20
|
+
expect(result).toBe(path.resolve(mindRoot, INBOX_DIR));
|
|
21
|
+
expect(fs.existsSync(path.join(mindRoot, INBOX_DIR, 'INSTRUCTION.md'))).toBe(true);
|
|
22
|
+
expect(fs.existsSync(path.join(mindRoot, INBOX_DIR, 'README.md'))).toBe(true);
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
it('is idempotent — calling twice does not overwrite existing files', () => {
|
|
26
|
+
ensureInboxSpace(mindRoot);
|
|
27
|
+
const original = readSeeded(mindRoot, `${INBOX_DIR}/INSTRUCTION.md`);
|
|
28
|
+
seedFile(mindRoot, `${INBOX_DIR}/custom.md`, 'user content');
|
|
29
|
+
ensureInboxSpace(mindRoot);
|
|
30
|
+
expect(readSeeded(mindRoot, `${INBOX_DIR}/INSTRUCTION.md`)).toBe(original);
|
|
31
|
+
expect(readSeeded(mindRoot, `${INBOX_DIR}/custom.md`)).toBe('user content');
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
it('recreates Inbox after user deletes it', () => {
|
|
35
|
+
ensureInboxSpace(mindRoot);
|
|
36
|
+
fs.rmSync(path.join(mindRoot, INBOX_DIR), { recursive: true, force: true });
|
|
37
|
+
ensureInboxSpace(mindRoot);
|
|
38
|
+
expect(fs.existsSync(path.join(mindRoot, INBOX_DIR, 'INSTRUCTION.md'))).toBe(true);
|
|
39
|
+
});
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
describe('listInboxFiles', () => {
|
|
43
|
+
let mindRoot: string;
|
|
44
|
+
|
|
45
|
+
beforeEach(() => { mindRoot = mkTempMindRoot(); });
|
|
46
|
+
afterEach(() => { cleanupMindRoot(mindRoot); });
|
|
47
|
+
|
|
48
|
+
it('returns empty array when Inbox does not exist', () => {
|
|
49
|
+
expect(listInboxFiles(mindRoot)).toEqual([]);
|
|
50
|
+
});
|
|
51
|
+
|
|
52
|
+
it('returns empty array when Inbox exists but is empty (only system files)', () => {
|
|
53
|
+
ensureInboxSpace(mindRoot);
|
|
54
|
+
expect(listInboxFiles(mindRoot)).toEqual([]);
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
it('lists non-system files with metadata', () => {
|
|
58
|
+
ensureInboxSpace(mindRoot);
|
|
59
|
+
seedFile(mindRoot, `${INBOX_DIR}/notes.md`, '# Notes');
|
|
60
|
+
seedFile(mindRoot, `${INBOX_DIR}/data.csv`, 'a,b,c');
|
|
61
|
+
|
|
62
|
+
const files = listInboxFiles(mindRoot);
|
|
63
|
+
expect(files).toHaveLength(2);
|
|
64
|
+
expect(files.map(f => f.name).sort()).toEqual(['data.csv', 'notes.md']);
|
|
65
|
+
expect(files[0].size).toBeGreaterThan(0);
|
|
66
|
+
expect(files[0].modifiedAt).toBeTruthy();
|
|
67
|
+
expect(typeof files[0].isAging).toBe('boolean');
|
|
68
|
+
});
|
|
69
|
+
|
|
70
|
+
it('excludes system files (INSTRUCTION.md, README.md, dotfiles)', () => {
|
|
71
|
+
ensureInboxSpace(mindRoot);
|
|
72
|
+
seedFile(mindRoot, `${INBOX_DIR}/.hidden`, 'hidden');
|
|
73
|
+
seedFile(mindRoot, `${INBOX_DIR}/visible.md`, 'ok');
|
|
74
|
+
|
|
75
|
+
const files = listInboxFiles(mindRoot);
|
|
76
|
+
expect(files).toHaveLength(1);
|
|
77
|
+
expect(files[0].name).toBe('visible.md');
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
it('sorts by modification time (newest first)', () => {
|
|
81
|
+
ensureInboxSpace(mindRoot);
|
|
82
|
+
seedFile(mindRoot, `${INBOX_DIR}/old.md`, 'old');
|
|
83
|
+
const oldPath = path.join(mindRoot, INBOX_DIR, 'old.md');
|
|
84
|
+
const pastTime = new Date(Date.now() - 86400000);
|
|
85
|
+
fs.utimesSync(oldPath, pastTime, pastTime);
|
|
86
|
+
|
|
87
|
+
seedFile(mindRoot, `${INBOX_DIR}/new.md`, 'new');
|
|
88
|
+
|
|
89
|
+
const files = listInboxFiles(mindRoot);
|
|
90
|
+
expect(files[0].name).toBe('new.md');
|
|
91
|
+
expect(files[1].name).toBe('old.md');
|
|
92
|
+
});
|
|
93
|
+
|
|
94
|
+
it('marks files older than 7 days as aging', () => {
|
|
95
|
+
ensureInboxSpace(mindRoot);
|
|
96
|
+
seedFile(mindRoot, `${INBOX_DIR}/aged.md`, 'old content');
|
|
97
|
+
const filePath = path.join(mindRoot, INBOX_DIR, 'aged.md');
|
|
98
|
+
const eightDaysAgo = new Date(Date.now() - 8 * 24 * 60 * 60 * 1000);
|
|
99
|
+
fs.utimesSync(filePath, eightDaysAgo, eightDaysAgo);
|
|
100
|
+
|
|
101
|
+
seedFile(mindRoot, `${INBOX_DIR}/fresh.md`, 'new content');
|
|
102
|
+
|
|
103
|
+
const files = listInboxFiles(mindRoot);
|
|
104
|
+
const aged = files.find(f => f.name === 'aged.md');
|
|
105
|
+
const fresh = files.find(f => f.name === 'fresh.md');
|
|
106
|
+
expect(aged?.isAging).toBe(true);
|
|
107
|
+
expect(fresh?.isAging).toBe(false);
|
|
108
|
+
});
|
|
109
|
+
|
|
110
|
+
it('skips subdirectories', () => {
|
|
111
|
+
ensureInboxSpace(mindRoot);
|
|
112
|
+
fs.mkdirSync(path.join(mindRoot, INBOX_DIR, 'subdir'), { recursive: true });
|
|
113
|
+
seedFile(mindRoot, `${INBOX_DIR}/subdir/nested.md`, 'nested');
|
|
114
|
+
seedFile(mindRoot, `${INBOX_DIR}/top.md`, 'top');
|
|
115
|
+
|
|
116
|
+
const files = listInboxFiles(mindRoot);
|
|
117
|
+
expect(files).toHaveLength(1);
|
|
118
|
+
expect(files[0].name).toBe('top.md');
|
|
119
|
+
});
|
|
120
|
+
});
|
|
121
|
+
|
|
122
|
+
describe('saveToInbox', () => {
|
|
123
|
+
let mindRoot: string;
|
|
124
|
+
|
|
125
|
+
beforeEach(() => { mindRoot = mkTempMindRoot(); });
|
|
126
|
+
afterEach(() => { cleanupMindRoot(mindRoot); });
|
|
127
|
+
|
|
128
|
+
it('saves a markdown file to Inbox', () => {
|
|
129
|
+
const result = saveToInbox(mindRoot, [
|
|
130
|
+
{ name: 'notes.md', content: '# My Notes\n\nSome content' },
|
|
131
|
+
]);
|
|
132
|
+
|
|
133
|
+
expect(result.saved).toHaveLength(1);
|
|
134
|
+
expect(result.saved[0].original).toBe('notes.md');
|
|
135
|
+
expect(result.saved[0].path).toBe('Inbox/notes.md');
|
|
136
|
+
expect(result.skipped).toHaveLength(0);
|
|
137
|
+
|
|
138
|
+
const content = readSeeded(mindRoot, 'Inbox/notes.md');
|
|
139
|
+
expect(content).toContain('My Notes');
|
|
140
|
+
});
|
|
141
|
+
|
|
142
|
+
it('converts .txt to .md with title heading', () => {
|
|
143
|
+
const result = saveToInbox(mindRoot, [
|
|
144
|
+
{ name: 'todo.txt', content: 'Buy milk\nFix bug' },
|
|
145
|
+
]);
|
|
146
|
+
|
|
147
|
+
expect(result.saved[0].path).toBe('Inbox/todo.md');
|
|
148
|
+
const content = readSeeded(mindRoot, 'Inbox/todo.md');
|
|
149
|
+
expect(content).toContain('# Todo');
|
|
150
|
+
expect(content).toContain('Buy milk');
|
|
151
|
+
});
|
|
152
|
+
|
|
153
|
+
it('handles multiple files at once', () => {
|
|
154
|
+
const result = saveToInbox(mindRoot, [
|
|
155
|
+
{ name: 'a.md', content: 'aaa' },
|
|
156
|
+
{ name: 'b.md', content: 'bbb' },
|
|
157
|
+
{ name: 'c.md', content: 'ccc' },
|
|
158
|
+
]);
|
|
159
|
+
|
|
160
|
+
expect(result.saved).toHaveLength(3);
|
|
161
|
+
expect(fs.readdirSync(path.join(mindRoot, INBOX_DIR))).toContain('a.md');
|
|
162
|
+
expect(fs.readdirSync(path.join(mindRoot, INBOX_DIR))).toContain('b.md');
|
|
163
|
+
expect(fs.readdirSync(path.join(mindRoot, INBOX_DIR))).toContain('c.md');
|
|
164
|
+
});
|
|
165
|
+
|
|
166
|
+
it('deduplicates with -1 suffix on name collision', () => {
|
|
167
|
+
saveToInbox(mindRoot, [{ name: 'notes.md', content: 'first' }]);
|
|
168
|
+
const result = saveToInbox(mindRoot, [{ name: 'notes.md', content: 'second' }]);
|
|
169
|
+
|
|
170
|
+
expect(result.saved[0].path).toBe('Inbox/notes-1.md');
|
|
171
|
+
expect(readSeeded(mindRoot, 'Inbox/notes.md')).toContain('first');
|
|
172
|
+
expect(readSeeded(mindRoot, 'Inbox/notes-1.md')).toContain('second');
|
|
173
|
+
});
|
|
174
|
+
|
|
175
|
+
it('skips unsupported file formats', () => {
|
|
176
|
+
const result = saveToInbox(mindRoot, [
|
|
177
|
+
{ name: 'script.exe', content: 'binary' },
|
|
178
|
+
{ name: 'notes.md', content: 'ok' },
|
|
179
|
+
]);
|
|
180
|
+
|
|
181
|
+
expect(result.saved).toHaveLength(1);
|
|
182
|
+
expect(result.skipped).toHaveLength(1);
|
|
183
|
+
expect(result.skipped[0].name).toBe('script.exe');
|
|
184
|
+
expect(result.skipped[0].reason).toContain('Unsupported');
|
|
185
|
+
});
|
|
186
|
+
|
|
187
|
+
it('skips files with empty or invalid names', () => {
|
|
188
|
+
const result = saveToInbox(mindRoot, [
|
|
189
|
+
{ name: '', content: 'no name' },
|
|
190
|
+
{ name: 'valid.md', content: 'ok' },
|
|
191
|
+
]);
|
|
192
|
+
|
|
193
|
+
expect(result.saved).toHaveLength(1);
|
|
194
|
+
expect(result.skipped).toHaveLength(1);
|
|
195
|
+
});
|
|
196
|
+
|
|
197
|
+
it('skips files with missing or null content', () => {
|
|
198
|
+
const result = saveToInbox(mindRoot, [
|
|
199
|
+
{ name: 'no-content.md', content: undefined as unknown as string },
|
|
200
|
+
{ name: 'null-content.md', content: null as unknown as string },
|
|
201
|
+
{ name: 'valid.md', content: 'ok' },
|
|
202
|
+
]);
|
|
203
|
+
|
|
204
|
+
expect(result.saved).toHaveLength(1);
|
|
205
|
+
expect(result.skipped).toHaveLength(2);
|
|
206
|
+
expect(result.skipped[0].reason).toContain('Missing');
|
|
207
|
+
expect(result.skipped[1].reason).toContain('Missing');
|
|
208
|
+
});
|
|
209
|
+
|
|
210
|
+
it('auto-creates Inbox directory if it was deleted', () => {
|
|
211
|
+
const result = saveToInbox(mindRoot, [
|
|
212
|
+
{ name: 'rescued.md', content: 'saved!' },
|
|
213
|
+
]);
|
|
214
|
+
|
|
215
|
+
expect(result.saved).toHaveLength(1);
|
|
216
|
+
expect(fs.existsSync(path.join(mindRoot, INBOX_DIR, 'INSTRUCTION.md'))).toBe(true);
|
|
217
|
+
expect(readSeeded(mindRoot, 'Inbox/rescued.md')).toContain('saved!');
|
|
218
|
+
});
|
|
219
|
+
|
|
220
|
+
it('preserves CSV and JSON files as-is (no markdown conversion)', () => {
|
|
221
|
+
saveToInbox(mindRoot, [
|
|
222
|
+
{ name: 'data.csv', content: 'a,b,c\n1,2,3' },
|
|
223
|
+
{ name: 'config.json', content: '{"key":"value"}' },
|
|
224
|
+
]);
|
|
225
|
+
|
|
226
|
+
expect(readSeeded(mindRoot, 'Inbox/data.csv')).toBe('a,b,c\n1,2,3');
|
|
227
|
+
expect(readSeeded(mindRoot, 'Inbox/config.json')).toBe('{"key":"value"}');
|
|
228
|
+
});
|
|
229
|
+
|
|
230
|
+
it('sanitizes dangerous file names', () => {
|
|
231
|
+
const result = saveToInbox(mindRoot, [
|
|
232
|
+
{ name: '../../../etc/passwd.md', content: 'hack attempt' },
|
|
233
|
+
]);
|
|
234
|
+
|
|
235
|
+
expect(result.saved).toHaveLength(1);
|
|
236
|
+
expect(result.saved[0].path).toContain('Inbox/');
|
|
237
|
+
expect(result.saved[0].path).not.toContain('..');
|
|
238
|
+
});
|
|
239
|
+
|
|
240
|
+
it('handles base64 encoded content', () => {
|
|
241
|
+
const originalContent = 'Hello from base64!';
|
|
242
|
+
const base64 = Buffer.from(originalContent).toString('base64');
|
|
243
|
+
const result = saveToInbox(mindRoot, [
|
|
244
|
+
{ name: 'encoded.md', content: base64, encoding: 'base64' },
|
|
245
|
+
]);
|
|
246
|
+
|
|
247
|
+
expect(result.saved).toHaveLength(1);
|
|
248
|
+
expect(readSeeded(mindRoot, 'Inbox/encoded.md')).toContain('Hello from base64!');
|
|
249
|
+
});
|
|
250
|
+
});
|
|
@@ -33,7 +33,7 @@ const SKILL_AGENT_REGISTRY: Record<string, { mode: 'universal' | 'additional' |
|
|
|
33
33
|
'qoder': { mode: 'additional', skillAgentName: 'qoder' },
|
|
34
34
|
'trae-cn': { mode: 'additional', skillAgentName: 'trae-cn' },
|
|
35
35
|
'roo': { mode: 'additional', skillAgentName: 'roo' },
|
|
36
|
-
'
|
|
36
|
+
'github-copilot': { mode: 'universal' },
|
|
37
37
|
'codex': { mode: 'universal' },
|
|
38
38
|
};
|
|
39
39
|
|
|
@@ -217,8 +217,8 @@ describe('CLI skill install — end-to-end scenarios', () => {
|
|
|
217
217
|
expect(cmd).toBe('npx skills add "GeminiLight/MindOS" --skill mindos -a qoder -g -y');
|
|
218
218
|
});
|
|
219
219
|
|
|
220
|
-
it('S9c:
|
|
221
|
-
const cmd = simulate('en', ['
|
|
220
|
+
it('S9c: github-copilot should use universal fallback (no explicit -a)', () => {
|
|
221
|
+
const cmd = simulate('en', ['github-copilot']);
|
|
222
222
|
expect(cmd).toBe('npx skills add "GeminiLight/MindOS" --skill mindos -a universal -g -y');
|
|
223
223
|
});
|
|
224
224
|
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { describe, it, expect } from 'vitest';
|
|
2
2
|
import { timeAgo } from '@/components/settings/SyncTab';
|
|
3
3
|
import { getStatusLevel } from '@/components/SyncStatusBar';
|
|
4
|
-
import type { SyncStatus } from '@/components/settings/
|
|
4
|
+
import type { SyncStatus } from '@/components/settings/types';
|
|
5
5
|
|
|
6
6
|
/* ------------------------------------------------------------------ */
|
|
7
7
|
/* timeAgo */
|