clawmini 0.0.3 → 0.0.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +19 -0
- package/dist/adapter-discord/index.d.mts.map +1 -1
- package/dist/adapter-discord/index.mjs +398 -193
- package/dist/adapter-discord/index.mjs.map +1 -1
- package/dist/adapter-google-chat/index.d.mts +5 -0
- package/dist/adapter-google-chat/index.d.mts.map +1 -0
- package/dist/adapter-google-chat/index.mjs +1077 -0
- package/dist/adapter-google-chat/index.mjs.map +1 -0
- package/dist/cli/index.mjs +107 -14
- package/dist/cli/index.mjs.map +1 -1
- package/dist/cli/lite.mjs +175 -16
- package/dist/cli/lite.mjs.map +1 -1
- package/dist/cli/propose-policy.d.mts +1 -0
- package/dist/cli/propose-policy.mjs +7159 -0
- package/dist/cli/propose-policy.mjs.map +1 -0
- package/dist/daemon/index.d.mts.map +1 -1
- package/dist/daemon/index.mjs +1427 -513
- package/dist/daemon/index.mjs.map +1 -1
- package/dist/{lite-oSYSvaOr.mjs → lite-CBxOT1y5.mjs} +101 -24
- package/dist/lite-CBxOT1y5.mjs.map +1 -0
- package/dist/routing-D8rTxtaV.mjs +245 -0
- package/dist/routing-D8rTxtaV.mjs.map +1 -0
- package/dist/web/_app/immutable/assets/0.C-4eziNy.css +1 -0
- package/dist/web/_app/immutable/assets/4.Cc_xwLNl.css +1 -0
- package/dist/web/_app/immutable/chunks/B6YN0Nuq.js +1 -0
- package/dist/web/_app/immutable/chunks/{Dc-UOHw9.js → BmRlVmv6.js} +1 -1
- package/{web/.svelte-kit/output/client/_app/immutable/chunks/8YNcRyEk.js → dist/web/_app/immutable/chunks/C20lZMGz.js} +1 -1
- package/dist/web/_app/immutable/chunks/C9lbZ-kT.js +1 -0
- package/dist/web/_app/immutable/chunks/CK9JZLaG.js +2 -0
- package/dist/web/_app/immutable/chunks/CME08kGM.js +1 -0
- package/dist/web/_app/immutable/chunks/{BPy8HLo7.js → Ck-be5J2.js} +1 -1
- package/dist/web/_app/immutable/chunks/Ck3rYNON.js +1 -0
- package/dist/web/_app/immutable/chunks/DMtIqaiV.js +2 -0
- package/dist/web/_app/immutable/chunks/{B8yYFADm.js → DhD271EB.js} +1 -1
- package/dist/web/_app/immutable/chunks/{DcrmIfTj.js → DpuLqk8d.js} +1 -1
- package/dist/web/_app/immutable/chunks/{ZkLyk0mE.js → Drm9vgeP.js} +1 -1
- package/dist/web/_app/immutable/chunks/DsIToJCP.js +1 -0
- package/dist/web/_app/immutable/chunks/{CyNaE55B.js → Zeh-C-mx.js} +1 -1
- package/{web/.svelte-kit/output/client/_app/immutable/entry/app.DO5eYwVz.js → dist/web/_app/immutable/entry/app.BgB5VkRU.js} +2 -2
- package/dist/web/_app/immutable/entry/start.DuxJo6av.js +1 -0
- package/dist/web/_app/immutable/nodes/0.C9oFZP9h.js +1 -0
- package/dist/web/_app/immutable/nodes/1.BON2Wk6k.js +1 -0
- package/dist/web/_app/immutable/nodes/{2.CK3CLC0f.js → 2.BnwnD1Ki.js} +1 -1
- package/dist/web/_app/immutable/nodes/{3.ncP0xLO6.js → 3.CIs4tjjw.js} +1 -1
- package/dist/web/_app/immutable/nodes/4.DLarELN4.js +60 -0
- package/dist/web/_app/immutable/nodes/{5.BpJUN6QH.js → 5.CE_QKy_3.js} +1 -1
- package/dist/web/_app/version.json +1 -1
- package/dist/web/index.html +12 -12
- package/dist/{workspace-DjoNjhW0.mjs → workspace-BJmJBfKi.mjs} +103 -11
- package/dist/workspace-BJmJBfKi.mjs.map +1 -0
- package/docs/14_google_chat_adapter/development_log.md +40 -0
- package/docs/14_google_chat_adapter/notes.md +28 -0
- package/docs/14_google_chat_adapter/prd.md +35 -0
- package/docs/14_google_chat_adapter/questions.md +9 -0
- package/docs/14_google_chat_adapter/tickets.md +117 -0
- package/docs/15_sandbox_policies/tickets.md +33 -0
- package/docs/16_session_timeout/development_log.md +20 -0
- package/docs/16_session_timeout/notes.md +44 -0
- package/docs/16_session_timeout/prd.md +106 -0
- package/docs/16_session_timeout/questions.md +10 -0
- package/docs/16_session_timeout/tickets.md +64 -0
- package/docs/17_auto_approve_policy/development_log.md +29 -0
- package/docs/17_auto_approve_policy/notes.md +25 -0
- package/docs/17_auto_approve_policy/prd.md +34 -0
- package/docs/17_auto_approve_policy/questions.md +10 -0
- package/docs/17_auto_approve_policy/tickets.md +11 -0
- package/docs/18_clawmini_skills/development_log.md +36 -0
- package/docs/18_clawmini_skills/notes.md +8 -0
- package/docs/18_clawmini_skills/prd.md +45 -0
- package/docs/18_clawmini_skills/questions.md +10 -0
- package/docs/18_clawmini_skills/tickets.md +55 -0
- package/docs/19_subagents/development_log.md +69 -0
- package/docs/19_subagents/notes.md +18 -0
- package/docs/19_subagents/prd.md +156 -0
- package/docs/19_subagents/questions.md +13 -0
- package/docs/19_subagents/tickets.md +113 -0
- package/docs/20_chat_logs_cleanup/development_log.md +50 -0
- package/docs/20_chat_logs_cleanup/notes.md +43 -0
- package/docs/20_chat_logs_cleanup/prd.md +232 -0
- package/docs/20_chat_logs_cleanup/questions.md +2 -0
- package/docs/20_chat_logs_cleanup/tickets.md +98 -0
- package/docs/20_webui_markdown/development_log.md +36 -0
- package/docs/20_webui_markdown/notes.md +23 -0
- package/docs/20_webui_markdown/prd.md +49 -0
- package/docs/20_webui_markdown/questions.md +10 -0
- package/docs/20_webui_markdown/tickets.md +55 -0
- package/docs/21_adapter_filtering/development_log.md +29 -0
- package/docs/21_adapter_filtering/notes.md +25 -0
- package/docs/21_adapter_filtering/prd.md +44 -0
- package/docs/21_adapter_filtering/questions.md +12 -0
- package/docs/21_adapter_filtering/tickets.md +38 -0
- package/docs/21_built_in_routers/development_log.md +17 -0
- package/docs/21_built_in_routers/notes.md +27 -0
- package/docs/21_built_in_routers/prd.md +34 -0
- package/docs/21_built_in_routers/questions.md +4 -0
- package/docs/21_built_in_routers/tickets.md +25 -0
- package/docs/21_fancy_policies/development_log.md +38 -0
- package/docs/21_fancy_policies/notes.md +27 -0
- package/docs/21_fancy_policies/prd.md +58 -0
- package/docs/21_fancy_policies/questions.md +6 -0
- package/docs/21_fancy_policies/tickets.md +48 -0
- package/docs/22_adapter_multi_chat/development_log.md +76 -0
- package/docs/22_adapter_multi_chat/notes.md +42 -0
- package/docs/22_adapter_multi_chat/prd.md +76 -0
- package/docs/22_adapter_multi_chat/questions.md +16 -0
- package/docs/22_adapter_multi_chat/tickets.md +164 -0
- package/docs/23_custom_token_env/development_log.md +31 -0
- package/docs/23_custom_token_env/notes.md +16 -0
- package/docs/23_custom_token_env/prd.md +42 -0
- package/docs/23_custom_token_env/questions.md +8 -0
- package/docs/23_custom_token_env/tickets.md +54 -0
- package/docs/guides/discord_adapter_setup.md +15 -2
- package/docs/guides/google_chat_adapter_setup.md +145 -0
- package/napkin.md +5 -0
- package/package.json +7 -2
- package/src/adapter-discord/config.test.ts +27 -8
- package/src/adapter-discord/config.ts +6 -8
- package/src/adapter-discord/forwarder.test.ts +307 -114
- package/src/adapter-discord/forwarder.ts +260 -75
- package/src/adapter-discord/index.test.ts +278 -0
- package/src/adapter-discord/index.ts +160 -30
- package/src/adapter-discord/interactions.test.ts +96 -0
- package/src/adapter-discord/interactions.ts +156 -0
- package/src/adapter-discord/state.test.ts +9 -8
- package/src/adapter-discord/state.ts +51 -8
- package/src/adapter-google-chat/auth.test.ts +87 -0
- package/src/adapter-google-chat/auth.ts +132 -0
- package/src/adapter-google-chat/cards.ts +71 -0
- package/src/adapter-google-chat/client.test.ts +561 -0
- package/src/adapter-google-chat/client.ts +430 -0
- package/src/adapter-google-chat/config.test.ts +187 -0
- package/src/adapter-google-chat/config.ts +82 -0
- package/src/adapter-google-chat/cron.test.ts +143 -0
- package/src/adapter-google-chat/cron.ts +81 -0
- package/src/adapter-google-chat/forwarder.test.ts +537 -0
- package/src/adapter-google-chat/forwarder.ts +349 -0
- package/src/adapter-google-chat/index.test.ts +62 -0
- package/src/adapter-google-chat/index.ts +61 -0
- package/src/adapter-google-chat/state.test.ts +96 -0
- package/src/adapter-google-chat/state.ts +85 -0
- package/src/adapter-google-chat/subscriptions.ts +124 -0
- package/src/adapter-google-chat/upload.ts +88 -0
- package/src/adapter-google-chat/utils.test.ts +111 -0
- package/src/adapter-google-chat/utils.ts +133 -0
- package/src/cli/commands/init.ts +0 -7
- package/src/cli/commands/messages.ts +18 -3
- package/src/cli/commands/policies.ts +70 -0
- package/src/cli/commands/skills.ts +71 -0
- package/src/cli/commands/web-api/chats.ts +5 -1
- package/src/cli/e2e/basic.test.ts +1 -1
- package/src/cli/e2e/cron.test.ts +1 -1
- package/src/cli/e2e/daemon.test.ts +132 -4
- package/src/cli/e2e/export-lite-func.test.ts +54 -31
- package/src/cli/e2e/fallbacks.test.ts +8 -6
- package/src/cli/e2e/init.test.ts +7 -0
- package/src/cli/e2e/messages.test.ts +90 -55
- package/src/cli/e2e/propose-policy.test.ts +203 -0
- package/src/cli/e2e/requests.test.ts +15 -0
- package/src/cli/e2e/session-timeout.test.ts +192 -0
- package/src/cli/e2e/skills.test.ts +55 -0
- package/src/cli/e2e/slash-new.test.ts +93 -0
- package/src/cli/e2e/subagents.test.ts +106 -0
- package/src/cli/index.ts +4 -0
- package/src/cli/lite.ts +51 -11
- package/src/cli/propose-policy.ts +91 -0
- package/src/cli/subagent-commands.ts +215 -0
- package/src/daemon/agent/agent-context.ts +89 -0
- package/src/daemon/agent/agent-extractors.ts +68 -0
- package/src/daemon/agent/agent-runner.ts +153 -0
- package/src/daemon/agent/agent-session.ts +261 -0
- package/src/daemon/agent/chat-logger.test.ts +158 -0
- package/src/daemon/agent/chat-logger.ts +188 -0
- package/src/daemon/agent/task-scheduler.test.ts +202 -0
- package/src/daemon/agent/task-scheduler.ts +276 -0
- package/src/daemon/agent/types.ts +84 -0
- package/src/daemon/agent/utils.ts +7 -0
- package/src/daemon/api/agent-router.ts +166 -18
- package/src/daemon/api/index.test.ts +50 -18
- package/src/daemon/api/policy-request.test.ts +39 -2
- package/src/daemon/api/subagent-router.test.ts +108 -0
- package/src/daemon/api/subagent-router.ts +296 -0
- package/src/daemon/api/subagent-utils.test.ts +56 -0
- package/src/daemon/api/subagent-utils.ts +130 -0
- package/src/daemon/api/user-router.ts +30 -13
- package/src/daemon/auth.ts +1 -0
- package/src/daemon/chats.ts +6 -0
- package/src/daemon/cron.test.ts +66 -1
- package/src/daemon/cron.ts +35 -8
- package/src/daemon/index.ts +23 -0
- package/src/daemon/message-agent.test.ts +11 -25
- package/src/daemon/message-extraction.test.ts +10 -27
- package/src/daemon/message-fallbacks.test.ts +13 -35
- package/src/daemon/message-interruption.test.ts +70 -53
- package/src/daemon/message-jobs.test.ts +138 -0
- package/src/daemon/message-queue.test.ts +30 -43
- package/src/daemon/message-router.test.ts +12 -11
- package/src/daemon/message-session.test.ts +41 -28
- package/src/daemon/message-typing.test.ts +19 -6
- package/src/daemon/message.ts +103 -515
- package/src/daemon/policy-request-service.ts +8 -3
- package/src/daemon/policy-utils.ts +19 -1
- package/src/daemon/queue.ts +16 -0
- package/src/daemon/request-store.test.ts +4 -0
- package/src/daemon/routers/session-timeout.test.ts +122 -0
- package/src/daemon/routers/session-timeout.ts +71 -0
- package/src/daemon/routers/slash-new.ts +3 -1
- package/src/daemon/routers/slash-policies.test.ts +26 -13
- package/src/daemon/routers/slash-policies.ts +39 -29
- package/src/daemon/routers/types.ts +8 -0
- package/src/daemon/routers.ts +64 -2
- package/src/daemon/utils/spawn.ts +6 -8
- package/src/shared/adapters/commands.test.ts +155 -0
- package/src/shared/adapters/commands.ts +125 -0
- package/src/shared/adapters/filtering.test.ts +111 -0
- package/src/shared/adapters/filtering.ts +57 -0
- package/src/shared/adapters/routing.test.ts +144 -0
- package/src/shared/adapters/routing.ts +109 -0
- package/src/shared/agent-utils.ts +10 -0
- package/src/shared/chats.test.ts +145 -3
- package/src/shared/chats.ts +215 -18
- package/src/shared/config.ts +67 -15
- package/src/shared/lite.ts +22 -18
- package/src/shared/policies.ts +7 -0
- package/src/shared/workspace.test.ts +45 -1
- package/src/shared/workspace.ts +119 -6
- package/templates/debug/settings.json +5 -2
- package/templates/environments/cladding/env.json +2 -2
- package/templates/gemini/.gemini/hooks/check-subagents.mjs +23 -0
- package/templates/gemini/.gemini/hooks/clawmini-logging.sh +17 -0
- package/templates/gemini/.gemini/hooks/insert-pending.sh +9 -0
- package/templates/gemini/.gemini/settings.json +50 -0
- package/templates/gemini/settings.json +22 -8
- package/templates/gemini-claw/.gemini/base-system.md +100 -0
- package/templates/gemini-claw/.gemini/hooks/check-subagents.mjs +23 -0
- package/templates/gemini-claw/.gemini/hooks/clawmini-logging.sh +1 -1
- package/templates/gemini-claw/.gemini/settings.json +13 -0
- package/templates/gemini-claw/.gemini/subagent-system.md +7 -0
- package/templates/gemini-claw/.gemini/system.md +3 -99
- package/templates/gemini-claw/settings.json +27 -22
- package/templates/skills/clawmini-requests/SKILL.md +92 -0
- package/templates/skills/clawmini-subagents/SKILL.md +79 -0
- package/templates/skills/skill-creator/SKILL.md +60 -0
- package/tsdown.config.ts +10 -1
- package/web/.svelte-kit/generated/server/internal.js +2 -1
- package/web/.svelte-kit/non-ambient.d.ts +2 -0
- package/web/.svelte-kit/output/client/.vite/manifest.json +141 -138
- package/web/.svelte-kit/output/client/_app/immutable/assets/0.C-4eziNy.css +1 -0
- package/web/.svelte-kit/output/client/_app/immutable/assets/4.Cc_xwLNl.css +1 -0
- package/web/.svelte-kit/output/client/_app/immutable/chunks/B6YN0Nuq.js +1 -0
- package/web/.svelte-kit/output/client/_app/immutable/chunks/{Dc-UOHw9.js → BmRlVmv6.js} +1 -1
- package/{dist/web/_app/immutable/chunks/8YNcRyEk.js → web/.svelte-kit/output/client/_app/immutable/chunks/C20lZMGz.js} +1 -1
- package/web/.svelte-kit/output/client/_app/immutable/chunks/C9lbZ-kT.js +1 -0
- package/web/.svelte-kit/output/client/_app/immutable/chunks/CK9JZLaG.js +2 -0
- package/web/.svelte-kit/output/client/_app/immutable/chunks/CME08kGM.js +1 -0
- package/web/.svelte-kit/output/client/_app/immutable/chunks/{BPy8HLo7.js → Ck-be5J2.js} +1 -1
- package/web/.svelte-kit/output/client/_app/immutable/chunks/Ck3rYNON.js +1 -0
- package/web/.svelte-kit/output/client/_app/immutable/chunks/DMtIqaiV.js +2 -0
- package/web/.svelte-kit/output/client/_app/immutable/chunks/{B8yYFADm.js → DhD271EB.js} +1 -1
- package/web/.svelte-kit/output/client/_app/immutable/chunks/{DcrmIfTj.js → DpuLqk8d.js} +1 -1
- package/web/.svelte-kit/output/client/_app/immutable/chunks/{ZkLyk0mE.js → Drm9vgeP.js} +1 -1
- package/web/.svelte-kit/output/client/_app/immutable/chunks/DsIToJCP.js +1 -0
- package/web/.svelte-kit/output/client/_app/immutable/chunks/{CyNaE55B.js → Zeh-C-mx.js} +1 -1
- package/{dist/web/_app/immutable/entry/app.DO5eYwVz.js → web/.svelte-kit/output/client/_app/immutable/entry/app.BgB5VkRU.js} +2 -2
- package/web/.svelte-kit/output/client/_app/immutable/entry/start.DuxJo6av.js +1 -0
- package/web/.svelte-kit/output/client/_app/immutable/nodes/0.C9oFZP9h.js +1 -0
- package/web/.svelte-kit/output/client/_app/immutable/nodes/1.BON2Wk6k.js +1 -0
- package/web/.svelte-kit/output/client/_app/immutable/nodes/{2.CK3CLC0f.js → 2.BnwnD1Ki.js} +1 -1
- package/web/.svelte-kit/output/client/_app/immutable/nodes/{3.ncP0xLO6.js → 3.CIs4tjjw.js} +1 -1
- package/web/.svelte-kit/output/client/_app/immutable/nodes/4.DLarELN4.js +60 -0
- package/web/.svelte-kit/output/client/_app/immutable/nodes/{5.BpJUN6QH.js → 5.CE_QKy_3.js} +1 -1
- package/web/.svelte-kit/output/client/_app/version.json +1 -1
- package/web/.svelte-kit/output/server/.vite/manifest.json +12 -3
- package/web/.svelte-kit/output/server/_app/immutable/assets/_layout.C-4eziNy.css +1 -0
- package/web/.svelte-kit/output/server/_app/immutable/assets/_page.Cc_xwLNl.css +1 -0
- package/web/.svelte-kit/output/server/chunks/app-state.svelte.js +5 -0
- package/web/.svelte-kit/output/server/chunks/bot.js +4 -4
- package/web/.svelte-kit/output/server/chunks/client.js +2 -1
- package/web/.svelte-kit/output/server/chunks/exports.js +0 -1
- package/web/.svelte-kit/output/server/chunks/internal.js +2 -1
- package/web/.svelte-kit/output/server/chunks/root.js +482 -392
- package/web/.svelte-kit/output/server/entries/pages/_layout.svelte.js +57 -7
- package/web/.svelte-kit/output/server/entries/pages/chats/_id_/_page.svelte.js +234 -9
- package/web/.svelte-kit/output/server/index.js +82 -10
- package/web/.svelte-kit/output/server/manifest-full.js +1 -1
- package/web/.svelte-kit/output/server/manifest.js +1 -1
- package/web/.svelte-kit/output/server/nodes/0.js +2 -2
- package/web/.svelte-kit/output/server/nodes/1.js +1 -1
- package/web/.svelte-kit/output/server/nodes/2.js +1 -1
- package/web/.svelte-kit/output/server/nodes/3.js +1 -1
- package/web/.svelte-kit/output/server/nodes/4.js +2 -2
- package/web/.svelte-kit/output/server/nodes/5.js +1 -1
- package/web/.svelte-kit/types/src/routes/$types.d.ts +1 -2
- package/web/.svelte-kit/types/src/routes/agents/$types.d.ts +1 -2
- package/web/.svelte-kit/types/src/routes/chats/[id]/$types.d.ts +1 -2
- package/web/.svelte-kit/types/src/routes/chats/[id]/settings/$types.d.ts +1 -2
- package/web/package.json +8 -0
- package/web/src/lib/app-state.svelte.ts +5 -1
- package/web/src/lib/components/app/markdown-renderer.svelte +56 -0
- package/web/src/lib/components/app/markdown-renderer.svelte.spec.ts +44 -0
- package/web/src/lib/components/app/message-content.svelte +16 -0
- package/web/src/lib/types.ts +67 -3
- package/web/src/routes/+layout.svelte +31 -1
- package/web/src/routes/chats/[id]/+page.svelte +167 -18
- package/web/src/routes/chats/[id]/page.svelte.spec.ts +58 -7
- package/dist/lite-oSYSvaOr.mjs.map +0 -1
- package/dist/web/_app/immutable/assets/0.GI4C4dpV.css +0 -1
- package/dist/web/_app/immutable/chunks/B5abRDXp.js +0 -1
- package/dist/web/_app/immutable/chunks/Bi0jeV7Q.js +0 -1
- package/dist/web/_app/immutable/chunks/BmUXQ3wy.js +0 -2
- package/dist/web/_app/immutable/chunks/C3k55nDF.js +0 -1
- package/dist/web/_app/immutable/chunks/CpaGRn9L.js +0 -1
- package/dist/web/_app/immutable/chunks/DG5RZBw-.js +0 -2
- package/dist/web/_app/immutable/chunks/DQoygso7.js +0 -1
- package/dist/web/_app/immutable/entry/start.D48mVn1m.js +0 -1
- package/dist/web/_app/immutable/nodes/0.B-0CcADM.js +0 -1
- package/dist/web/_app/immutable/nodes/1.FixKgvRO.js +0 -1
- package/dist/web/_app/immutable/nodes/4.CQYJEgv8.js +0 -1
- package/dist/workspace-DjoNjhW0.mjs.map +0 -1
- package/src/daemon/message-verbosity.test.ts +0 -127
- package/web/.svelte-kit/output/client/_app/immutable/assets/0.GI4C4dpV.css +0 -1
- package/web/.svelte-kit/output/client/_app/immutable/chunks/B5abRDXp.js +0 -1
- package/web/.svelte-kit/output/client/_app/immutable/chunks/Bi0jeV7Q.js +0 -1
- package/web/.svelte-kit/output/client/_app/immutable/chunks/BmUXQ3wy.js +0 -2
- package/web/.svelte-kit/output/client/_app/immutable/chunks/C3k55nDF.js +0 -1
- package/web/.svelte-kit/output/client/_app/immutable/chunks/CpaGRn9L.js +0 -1
- package/web/.svelte-kit/output/client/_app/immutable/chunks/DG5RZBw-.js +0 -2
- package/web/.svelte-kit/output/client/_app/immutable/chunks/DQoygso7.js +0 -1
- package/web/.svelte-kit/output/client/_app/immutable/entry/start.D48mVn1m.js +0 -1
- package/web/.svelte-kit/output/client/_app/immutable/nodes/0.B-0CcADM.js +0 -1
- package/web/.svelte-kit/output/client/_app/immutable/nodes/1.FixKgvRO.js +0 -1
- package/web/.svelte-kit/output/client/_app/immutable/nodes/4.CQYJEgv8.js +0 -1
- package/web/.svelte-kit/output/server/_app/immutable/assets/_layout.GI4C4dpV.css +0 -1
- /package/templates/{gemini-claw/.gemini/skills → skills}/clawmini-jobs/SKILL.md +0 -0
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { D as pathIsInsideDir, _ as readEnvironment, c as getClawminiDir, f as getWorkspaceRoot, u as getSettingsPath, y as readSettings } from "./workspace-BJmJBfKi.mjs";
|
|
2
2
|
import { existsSync } from "node:fs";
|
|
3
3
|
import path from "node:path";
|
|
4
4
|
import fs$1 from "node:fs/promises";
|
|
@@ -52,14 +52,78 @@ async function appendMessage(id, message, startDir = process.cwd()) {
|
|
|
52
52
|
const chatFile = path.join(chatDir, "chat.jsonl");
|
|
53
53
|
await fs$1.appendFile(chatFile, JSON.stringify(message) + "\n");
|
|
54
54
|
}
|
|
55
|
-
async function
|
|
55
|
+
async function* readLinesBackwards(filePath) {
|
|
56
|
+
const fd = await fs$1.open(filePath, "r");
|
|
57
|
+
try {
|
|
58
|
+
const stats = await fd.stat();
|
|
59
|
+
if (stats.size === 0) return;
|
|
60
|
+
const chunkSize = 64 * 1024;
|
|
61
|
+
let position = stats.size;
|
|
62
|
+
const buffer = Buffer.alloc(chunkSize);
|
|
63
|
+
let leftoverBuffer = Buffer.alloc(0);
|
|
64
|
+
while (position > 0) {
|
|
65
|
+
const readSize = Math.min(chunkSize, position);
|
|
66
|
+
position -= readSize;
|
|
67
|
+
const { bytesRead } = await fd.read(buffer, 0, readSize, position);
|
|
68
|
+
const currentChunk = buffer.subarray(0, bytesRead);
|
|
69
|
+
let combinedBuffer = Buffer.concat([currentChunk, leftoverBuffer]);
|
|
70
|
+
let lastNewlineIdx = combinedBuffer.lastIndexOf(10);
|
|
71
|
+
while (lastNewlineIdx !== -1) {
|
|
72
|
+
const line = combinedBuffer.subarray(lastNewlineIdx + 1).toString("utf8").trim();
|
|
73
|
+
if (line) yield line;
|
|
74
|
+
combinedBuffer = combinedBuffer.subarray(0, lastNewlineIdx);
|
|
75
|
+
lastNewlineIdx = combinedBuffer.lastIndexOf(10);
|
|
76
|
+
}
|
|
77
|
+
leftoverBuffer = combinedBuffer;
|
|
78
|
+
}
|
|
79
|
+
if (leftoverBuffer.length > 0) {
|
|
80
|
+
const line = leftoverBuffer.toString("utf8").trim();
|
|
81
|
+
if (line) yield line;
|
|
82
|
+
}
|
|
83
|
+
} finally {
|
|
84
|
+
await fd.close();
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
function parseChatMessage(line) {
|
|
88
|
+
try {
|
|
89
|
+
const msg = JSON.parse(line);
|
|
90
|
+
if (msg && msg.role === "log") msg.role = "legacy_log";
|
|
91
|
+
return msg;
|
|
92
|
+
} catch {
|
|
93
|
+
return null;
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
async function getMessages(id, limit, startDir = process.cwd(), predicate, before) {
|
|
56
97
|
assertValidChatId(id);
|
|
57
98
|
const chatsDir = await getChatsDir(startDir);
|
|
58
99
|
const chatFile = path.join(chatsDir, id, "chat.jsonl");
|
|
59
100
|
if (!existsSync(chatFile)) throw new Error(`Chat directory or file for '${id}' not found.`);
|
|
60
|
-
|
|
61
|
-
if (limit
|
|
62
|
-
|
|
101
|
+
limit = limit ?? 100;
|
|
102
|
+
if (limit <= 0) {
|
|
103
|
+
let messages = (await fs$1.readFile(chatFile, "utf8")).split("\n").filter((line) => line.trim() !== "").map((line) => parseChatMessage(line)).filter((msg) => msg !== null);
|
|
104
|
+
if (before) {
|
|
105
|
+
const beforeIndex = messages.findIndex((m) => m.id === before);
|
|
106
|
+
if (beforeIndex !== -1) messages = messages.slice(0, beforeIndex);
|
|
107
|
+
else messages = [];
|
|
108
|
+
}
|
|
109
|
+
if (predicate) messages = messages.filter(predicate);
|
|
110
|
+
return messages;
|
|
111
|
+
}
|
|
112
|
+
const messages = [];
|
|
113
|
+
let skipping = before !== void 0;
|
|
114
|
+
for await (const line of readLinesBackwards(chatFile)) try {
|
|
115
|
+
const msg = parseChatMessage(line);
|
|
116
|
+
if (!msg) continue;
|
|
117
|
+
if (skipping) {
|
|
118
|
+
if (msg.id === before) skipping = false;
|
|
119
|
+
continue;
|
|
120
|
+
}
|
|
121
|
+
if (!predicate || predicate(msg)) {
|
|
122
|
+
messages.push(msg);
|
|
123
|
+
if (messages.length >= limit) break;
|
|
124
|
+
}
|
|
125
|
+
} catch {}
|
|
126
|
+
return messages.reverse();
|
|
63
127
|
}
|
|
64
128
|
async function getDefaultChatId(startDir = process.cwd()) {
|
|
65
129
|
const settingsPath = getSettingsPath(startDir);
|
|
@@ -85,28 +149,41 @@ async function setDefaultChatId(id, startDir = process.cwd()) {
|
|
|
85
149
|
if (!existsSync(clawminiDir)) await fs$1.mkdir(clawminiDir, { recursive: true });
|
|
86
150
|
await fs$1.writeFile(settingsPath, JSON.stringify(settings, null, 2));
|
|
87
151
|
}
|
|
152
|
+
async function findLastMessage(id, predicate, startDir = process.cwd()) {
|
|
153
|
+
assertValidChatId(id);
|
|
154
|
+
const chatsDir = await getChatsDir(startDir);
|
|
155
|
+
const chatFile = path.join(chatsDir, id, "chat.jsonl");
|
|
156
|
+
if (!existsSync(chatFile)) return null;
|
|
157
|
+
for await (const line of readLinesBackwards(chatFile)) try {
|
|
158
|
+
const msg = parseChatMessage(line);
|
|
159
|
+
if (!msg) continue;
|
|
160
|
+
if (predicate(msg)) return msg;
|
|
161
|
+
} catch {}
|
|
162
|
+
return null;
|
|
163
|
+
}
|
|
88
164
|
|
|
89
165
|
//#endregion
|
|
90
166
|
//#region src/shared/lite.ts
|
|
167
|
+
async function resolveCompiledScript(scriptName, metaUrl) {
|
|
168
|
+
const __dirname = path.dirname(fileURLToPath(metaUrl));
|
|
169
|
+
const filename = scriptName.endsWith(".mjs") ? scriptName : `${scriptName}.mjs`;
|
|
170
|
+
const searchPaths = [
|
|
171
|
+
path.resolve(__dirname, `cli/${filename}`),
|
|
172
|
+
path.resolve(__dirname, filename),
|
|
173
|
+
path.resolve(__dirname, `../cli/${filename}`),
|
|
174
|
+
path.resolve(__dirname, `../../dist/cli/${filename}`),
|
|
175
|
+
path.resolve(__dirname, `../${filename}`),
|
|
176
|
+
path.resolve(__dirname, `../../${filename}`)
|
|
177
|
+
];
|
|
178
|
+
for (const scriptPath of searchPaths) try {
|
|
179
|
+
await fs$1.access(scriptPath);
|
|
180
|
+
return scriptPath;
|
|
181
|
+
} catch {}
|
|
182
|
+
throw new Error(`Could not find compiled script: ${filename}`);
|
|
183
|
+
}
|
|
91
184
|
async function getLiteScriptContent() {
|
|
92
185
|
let liteScriptContent;
|
|
93
|
-
const
|
|
94
|
-
let liteScriptPath = path.resolve(__dirname, "cli/lite.mjs");
|
|
95
|
-
try {
|
|
96
|
-
await fs$1.access(liteScriptPath);
|
|
97
|
-
} catch {
|
|
98
|
-
try {
|
|
99
|
-
liteScriptPath = path.resolve(__dirname, "lite.mjs");
|
|
100
|
-
await fs$1.access(liteScriptPath);
|
|
101
|
-
} catch {
|
|
102
|
-
try {
|
|
103
|
-
liteScriptPath = path.resolve(__dirname, "../cli/lite.mjs");
|
|
104
|
-
await fs$1.access(liteScriptPath);
|
|
105
|
-
} catch {
|
|
106
|
-
liteScriptPath = path.resolve(__dirname, "../../dist/cli/lite.mjs");
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
}
|
|
186
|
+
const liteScriptPath = await resolveCompiledScript("lite", import.meta.url);
|
|
110
187
|
liteScriptContent = await fs$1.readFile(liteScriptPath, "utf8");
|
|
111
188
|
if (!liteScriptContent.startsWith("#!")) liteScriptContent = "#!/usr/bin/env node\n" + liteScriptContent;
|
|
112
189
|
return liteScriptContent;
|
|
@@ -160,5 +237,5 @@ async function exportLiteToAllEnvironments(startDir = process.cwd()) {
|
|
|
160
237
|
}
|
|
161
238
|
|
|
162
239
|
//#endregion
|
|
163
|
-
export {
|
|
164
|
-
//# sourceMappingURL=lite-
|
|
240
|
+
export { writeLiteScript as a, createChat as c, getChatsDir as d, getDefaultChatId as f, setDefaultChatId as g, listChats as h, resolveCompiledScript as i, deleteChat as l, isValidChatId as m, exportLiteToEnvironment as n, DEFAULT_CHAT_ID as o, getMessages as p, getLiteScriptContent as r, appendMessage as s, exportLiteToAllEnvironments as t, findLastMessage as u };
|
|
241
|
+
//# sourceMappingURL=lite-CBxOT1y5.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lite-CBxOT1y5.mjs","names":["fs","fs"],"sources":["../src/shared/chats.ts","../src/shared/lite.ts"],"sourcesContent":["/* eslint-disable max-lines */\nimport fs from 'node:fs/promises';\nimport { existsSync } from 'node:fs';\nimport path from 'node:path';\nimport { getClawminiDir, getSettingsPath } from './workspace.js';\nimport { pathIsInsideDir } from './utils/fs.js';\n\nexport const DEFAULT_CHAT_ID = 'default';\n\nexport interface BaseMessage {\n id: string;\n role: string;\n displayRole?: 'user' | 'agent';\n content: string;\n timestamp: string;\n subagentId?: string;\n}\n\nexport interface UserMessage extends BaseMessage {\n role: 'user';\n agentContent?: string;\n files?: string[];\n}\n\nexport interface AgentReplyMessage extends BaseMessage {\n role: 'agent';\n files?: string[];\n}\n\nexport interface LogMessage extends BaseMessage {\n role: 'log';\n messageId: string;\n type?: 'tool' | 'unknown';\n}\n\nexport interface CommandLogMessage extends BaseMessage {\n role: 'command';\n messageId: string;\n command: string;\n cwd: string;\n stdout: string;\n stderr: string;\n exitCode: number;\n retryAttemptIndex?: number;\n}\n\nexport interface SystemMessage extends BaseMessage {\n role: 'system';\n event: 'cron' | 'policy_approved' | 'policy_rejected' | 'subagent_update' | 'router' | 'other';\n messageId?: string;\n}\n\nexport interface ToolMessage extends BaseMessage {\n role: 'tool';\n messageId: string;\n name: string;\n payload: unknown;\n}\n\nexport interface PolicyRequestMessage extends BaseMessage {\n role: 'policy';\n messageId: string;\n requestId: string;\n commandName: string;\n args: string[];\n status: 'pending' | 'approved' | 'rejected';\n}\n\nexport interface SubagentStatusMessage extends BaseMessage {\n role: 'subagent_status';\n subagentId: string;\n status: 'completed' | 'failed';\n}\n\nexport interface LegacyLogMessage extends BaseMessage {\n role: 'legacy_log';\n messageId?: string;\n source?: string;\n files?: string[];\n level?: 'default' | 'debug' | 'verbose';\n command?: string;\n cwd?: string;\n stdout?: string;\n stderr?: string;\n exitCode?: number;\n}\n\nexport type ChatMessage =\n | UserMessage\n | AgentReplyMessage\n | CommandLogMessage\n | SystemMessage\n | ToolMessage\n | PolicyRequestMessage\n | SubagentStatusMessage\n | LegacyLogMessage;\n\nexport async function getChatsDir(startDir = process.cwd()): Promise<string> {\n const dir = path.join(getClawminiDir(startDir), 'chats');\n if (!existsSync(dir)) {\n await fs.mkdir(dir, { recursive: true });\n }\n return dir;\n}\n\nexport function isValidChatId(chatId: string): boolean {\n if (!chatId || chatId.length === 0) return false;\n return /^[a-zA-Z0-9_-]+$/.test(chatId);\n}\n\nfunction assertValidChatId(id: string): void {\n if (!isValidChatId(id)) {\n throw new Error(`Invalid chat ID: ${id}`);\n }\n}\n\nexport async function createChat(id: string, startDir = process.cwd()): Promise<void> {\n assertValidChatId(id);\n const chatsDir = await getChatsDir(startDir);\n const chatDir = path.join(chatsDir, id);\n if (!existsSync(chatDir)) {\n await fs.mkdir(chatDir, { recursive: true });\n }\n const chatFile = path.join(chatDir, 'chat.jsonl');\n if (!existsSync(chatFile)) {\n await fs.writeFile(chatFile, '');\n }\n}\n\nexport async function listChats(startDir = process.cwd()): Promise<string[]> {\n const chatsDir = await getChatsDir(startDir);\n try {\n const entries = await fs.readdir(chatsDir, { withFileTypes: true });\n return entries.filter((e) => e.isDirectory()).map((e) => e.name);\n } catch {\n return [];\n }\n}\n\nexport async function deleteChat(id: string, startDir = process.cwd()): Promise<void> {\n assertValidChatId(id);\n const chatsDir = await getChatsDir(startDir);\n const chatDir = path.join(chatsDir, id);\n\n if (!pathIsInsideDir(chatDir, chatsDir)) {\n throw new Error(`Security Error: Cannot delete chat directory outside of ${chatsDir}`);\n }\n\n if (existsSync(chatDir)) {\n await fs.rm(chatDir, { recursive: true, force: true });\n }\n}\n\nexport async function appendMessage(\n id: string,\n message: ChatMessage,\n startDir = process.cwd()\n): Promise<void> {\n assertValidChatId(id);\n const chatsDir = await getChatsDir(startDir);\n const chatDir = path.join(chatsDir, id);\n if (!existsSync(chatDir)) {\n await createChat(id, startDir);\n }\n const chatFile = path.join(chatDir, 'chat.jsonl');\n await fs.appendFile(chatFile, JSON.stringify(message) + '\\n');\n}\n\nasync function* readLinesBackwards(filePath: string): AsyncGenerator<string, void, unknown> {\n const fd = await fs.open(filePath, 'r');\n try {\n const stats = await fd.stat();\n if (stats.size === 0) return;\n\n const chunkSize = 64 * 1024;\n let position = stats.size;\n const buffer = Buffer.alloc(chunkSize);\n let leftoverBuffer = Buffer.alloc(0);\n\n while (position > 0) {\n const readSize = Math.min(chunkSize, position);\n position -= readSize;\n\n const { bytesRead } = await fd.read(buffer, 0, readSize, position);\n\n const currentChunk = buffer.subarray(0, bytesRead);\n let combinedBuffer = Buffer.concat([currentChunk, leftoverBuffer]);\n\n let lastNewlineIdx = combinedBuffer.lastIndexOf(0x0a);\n\n while (lastNewlineIdx !== -1) {\n const lineBuffer = combinedBuffer.subarray(lastNewlineIdx + 1);\n const line = lineBuffer.toString('utf8').trim();\n\n if (line) {\n yield line;\n }\n\n combinedBuffer = combinedBuffer.subarray(0, lastNewlineIdx);\n lastNewlineIdx = combinedBuffer.lastIndexOf(0x0a);\n }\n leftoverBuffer = combinedBuffer;\n }\n\n if (leftoverBuffer.length > 0) {\n const line = leftoverBuffer.toString('utf8').trim();\n if (line) {\n yield line;\n }\n }\n } finally {\n await fd.close();\n }\n}\n\nexport function parseChatMessage(line: string): ChatMessage | null {\n try {\n const msg = JSON.parse(line);\n if (msg && msg.role === 'log') {\n msg.role = 'legacy_log';\n }\n return msg as ChatMessage;\n } catch {\n return null;\n }\n}\n\nexport async function getMessages(\n id: string,\n limit?: number,\n startDir = process.cwd(),\n predicate?: (msg: ChatMessage) => boolean,\n before?: string\n): Promise<ChatMessage[]> {\n assertValidChatId(id);\n const chatsDir = await getChatsDir(startDir);\n const chatFile = path.join(chatsDir, id, 'chat.jsonl');\n if (!existsSync(chatFile)) {\n throw new Error(`Chat directory or file for '${id}' not found.`);\n }\n\n limit = limit ?? 100;\n\n if (limit <= 0) {\n const content = await fs.readFile(chatFile, 'utf8');\n const lines = content.split('\\n').filter((line) => line.trim() !== '');\n\n let messages = lines\n .map((line) => parseChatMessage(line))\n .filter((msg): msg is ChatMessage => msg !== null);\n\n if (before) {\n const beforeIndex = messages.findIndex((m) => m.id === before);\n if (beforeIndex !== -1) {\n messages = messages.slice(0, beforeIndex);\n } else {\n messages = [];\n }\n }\n\n if (predicate) {\n messages = messages.filter(predicate);\n }\n\n return messages;\n }\n\n // We have a limit > 0, read backwards to avoid parsing the whole file\n const messages: ChatMessage[] = [];\n let skipping = before !== undefined;\n\n for await (const line of readLinesBackwards(chatFile)) {\n try {\n const msg = parseChatMessage(line);\n if (!msg) continue;\n\n if (skipping) {\n if (msg.id === before) {\n skipping = false;\n }\n continue;\n }\n\n if (!predicate || predicate(msg)) {\n messages.push(msg);\n if (messages.length >= limit) {\n break;\n }\n }\n } catch {\n // Ignore invalid JSON lines\n }\n }\n\n return messages.reverse();\n}\n\nexport async function getDefaultChatId(startDir = process.cwd()): Promise<string> {\n const settingsPath = getSettingsPath(startDir);\n if (!existsSync(settingsPath)) return DEFAULT_CHAT_ID;\n\n try {\n const content = await fs.readFile(settingsPath, 'utf8');\n const settings = JSON.parse(content);\n return settings.chats?.defaultId || DEFAULT_CHAT_ID;\n } catch {\n return DEFAULT_CHAT_ID;\n }\n}\n\nexport async function setDefaultChatId(id: string, startDir = process.cwd()): Promise<void> {\n assertValidChatId(id);\n const settingsPath = getSettingsPath(startDir);\n let settings: { chats?: { defaultId?: string; [key: string]: unknown }; [key: string]: unknown } =\n {};\n if (existsSync(settingsPath)) {\n try {\n const content = await fs.readFile(settingsPath, 'utf8');\n settings = JSON.parse(content);\n } catch {\n // Ignore invalid JSON\n }\n }\n\n if (!settings.chats) {\n settings.chats = {};\n }\n settings.chats.defaultId = id;\n\n const clawminiDir = getClawminiDir(startDir);\n if (!existsSync(clawminiDir)) {\n await fs.mkdir(clawminiDir, { recursive: true });\n }\n\n await fs.writeFile(settingsPath, JSON.stringify(settings, null, 2));\n}\n\nexport async function findLastMessage(\n id: string,\n predicate: (msg: ChatMessage) => boolean,\n startDir = process.cwd()\n): Promise<ChatMessage | null> {\n assertValidChatId(id);\n const chatsDir = await getChatsDir(startDir);\n const chatFile = path.join(chatsDir, id, 'chat.jsonl');\n if (!existsSync(chatFile)) {\n return null;\n }\n\n for await (const line of readLinesBackwards(chatFile)) {\n try {\n const msg = parseChatMessage(line);\n if (!msg) continue;\n if (predicate(msg)) return msg;\n } catch {\n // Ignore invalid JSON lines\n }\n }\n\n return null;\n}\n","import fs from 'node:fs/promises';\nimport path from 'node:path';\nimport { fileURLToPath } from 'node:url';\nimport { readSettings, readEnvironment, getWorkspaceRoot } from './workspace.js';\nimport type { Environment } from './config.js';\n\nexport async function resolveCompiledScript(scriptName: string, metaUrl: string): Promise<string> {\n const __dirname = path.dirname(fileURLToPath(metaUrl));\n const filename = scriptName.endsWith('.mjs') ? scriptName : `${scriptName}.mjs`;\n\n const searchPaths = [\n path.resolve(__dirname, `cli/${filename}`), // If bundled in a shared chunk at dist/\n path.resolve(__dirname, filename), // If bundled in dist/cli or dist/daemon and lite is next to it\n path.resolve(__dirname, `../cli/${filename}`), // If bundled in dist/daemon, it might be in ../cli/\n path.resolve(__dirname, `../../dist/cli/${filename}`), // Fallback for development/testing when running from src/shared\n path.resolve(__dirname, `../${filename}`), // Used from src/cli/commands (1 level deep) -> dist/cli\n path.resolve(__dirname, `../../${filename}`), // Used from src/cli/commands -> dist/cli (2 levels deep)\n ];\n\n for (const scriptPath of searchPaths) {\n try {\n await fs.access(scriptPath);\n return scriptPath;\n } catch {\n // Continue searching\n }\n }\n\n throw new Error(`Could not find compiled script: ${filename}`);\n}\n\nexport async function getLiteScriptContent(): Promise<string> {\n let liteScriptContent: string;\n const liteScriptPath = await resolveCompiledScript('lite', import.meta.url);\n\n liteScriptContent = await fs.readFile(liteScriptPath, 'utf8');\n\n // Ensure it has the hashbang (if tsdown stripped it or if missing)\n if (!liteScriptContent.startsWith('#!')) {\n liteScriptContent = '#!/usr/bin/env node\\n' + liteScriptContent;\n }\n return liteScriptContent;\n}\n\nexport async function writeLiteScript(outPath: string): Promise<string> {\n const content = await getLiteScriptContent();\n\n let finalPath = outPath;\n const isDir =\n finalPath.endsWith(path.sep) ||\n !(\n path.extname(finalPath) === '.js' ||\n path.extname(finalPath) === '.mjs' ||\n path.basename(finalPath) === 'clawmini-lite'\n );\n\n try {\n const stat = await fs.stat(finalPath);\n if (stat.isDirectory()) {\n finalPath = path.join(finalPath, 'clawmini-lite.js');\n }\n } catch {\n if (\n isDir &&\n !path.extname(finalPath) &&\n !finalPath.endsWith('clawmini-lite') &&\n !finalPath.endsWith('clawmini-lite.js')\n ) {\n await fs.mkdir(finalPath, { recursive: true });\n finalPath = path.join(finalPath, 'clawmini-lite.js');\n }\n }\n\n const dir = path.dirname(finalPath);\n await fs.mkdir(dir, { recursive: true });\n await fs.writeFile(finalPath, content, { mode: 0o755 });\n return finalPath;\n}\n\nexport async function exportLiteToEnvironment(\n envName: string,\n envConfig: Environment,\n affectedDir: string\n): Promise<boolean> {\n if (!envConfig?.exportLiteTo) return false;\n\n const finalExportPath = path.resolve(affectedDir, envConfig.exportLiteTo);\n\n if (\n !finalExportPath.startsWith(affectedDir + path.sep) &&\n finalExportPath !== affectedDir &&\n !finalExportPath.startsWith(affectedDir + '/')\n ) {\n console.warn(\n `Skipping export for environment '${envName}': exportLiteTo path '${envConfig.exportLiteTo}' escapes the environment target directory '${affectedDir}'`\n );\n return false;\n }\n\n try {\n const writtenPath = await writeLiteScript(finalExportPath);\n console.log(`Successfully exported clawmini-lite to ${writtenPath} (Environment: ${envName})`);\n return true;\n } catch (err) {\n console.error(\n `Failed to export clawmini-lite to ${finalExportPath} (Environment: ${envName}): ${err instanceof Error ? err.message : String(err)}`\n );\n return false;\n }\n}\n\nexport async function exportLiteToAllEnvironments(startDir = process.cwd()): Promise<boolean> {\n let exportedToEnvironments = false;\n try {\n const workspaceRoot = getWorkspaceRoot(startDir);\n const settings = await readSettings(workspaceRoot);\n if (settings?.environments) {\n for (const [envPath, envName] of Object.entries(settings.environments)) {\n const envConfig = await readEnvironment(envName, workspaceRoot);\n if (envConfig) {\n const affectedDir = path.resolve(workspaceRoot, envPath);\n const exported = await exportLiteToEnvironment(envName, envConfig, affectedDir);\n if (exported) {\n exportedToEnvironments = true;\n }\n }\n }\n }\n } catch {\n // Ignore settings read errors\n }\n return exportedToEnvironments;\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,245 @@
|
|
|
1
|
+
import http from "node:http";
|
|
2
|
+
|
|
3
|
+
//#region src/shared/event-source.ts
|
|
4
|
+
function createUnixSocketEventSource(socketPath) {
|
|
5
|
+
return class UnixSocketEventSource {
|
|
6
|
+
readyState = 0;
|
|
7
|
+
CONNECTING = 0;
|
|
8
|
+
OPEN = 1;
|
|
9
|
+
CLOSED = 2;
|
|
10
|
+
req = null;
|
|
11
|
+
listeners = {};
|
|
12
|
+
constructor(url, init) {
|
|
13
|
+
const parsedUrl = new URL(url);
|
|
14
|
+
const options = {
|
|
15
|
+
socketPath,
|
|
16
|
+
path: parsedUrl.pathname + parsedUrl.search,
|
|
17
|
+
method: "GET",
|
|
18
|
+
headers: {
|
|
19
|
+
Accept: "text/event-stream",
|
|
20
|
+
"Cache-Control": "no-cache",
|
|
21
|
+
...init?.headers
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
this.req = http.request(options, (res) => {
|
|
25
|
+
if (res.statusCode === 200) {
|
|
26
|
+
this.readyState = this.OPEN;
|
|
27
|
+
this.dispatchEvent({ type: "open" });
|
|
28
|
+
} else {
|
|
29
|
+
this.readyState = this.CLOSED;
|
|
30
|
+
this.dispatchEvent({
|
|
31
|
+
type: "error",
|
|
32
|
+
message: `Unexpected status code: ${res.statusCode}`
|
|
33
|
+
});
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
let buffer = "";
|
|
37
|
+
res.on("data", (chunk) => {
|
|
38
|
+
buffer += chunk.toString("utf-8");
|
|
39
|
+
const lines = buffer.split(/\r?\n\r?\n/);
|
|
40
|
+
buffer = lines.pop() || "";
|
|
41
|
+
for (const block of lines) this.parseBlock(block);
|
|
42
|
+
});
|
|
43
|
+
res.on("end", () => {
|
|
44
|
+
if (buffer) this.parseBlock(buffer);
|
|
45
|
+
this.readyState = this.CLOSED;
|
|
46
|
+
this.dispatchEvent({ type: "close" });
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
this.req.on("error", (err) => {
|
|
50
|
+
this.readyState = this.CLOSED;
|
|
51
|
+
this.dispatchEvent({
|
|
52
|
+
type: "error",
|
|
53
|
+
error: err
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
this.req.end();
|
|
57
|
+
}
|
|
58
|
+
parseBlock(block) {
|
|
59
|
+
if (!block.trim()) return;
|
|
60
|
+
const lines = block.split(/\r?\n/);
|
|
61
|
+
let eventType = "message";
|
|
62
|
+
let data = "";
|
|
63
|
+
let id = "";
|
|
64
|
+
for (const line of lines) if (line.startsWith("event: ")) eventType = line.slice(7).trim();
|
|
65
|
+
else if (line.startsWith("data: ")) data += (data ? "\n" : "") + line.slice(6);
|
|
66
|
+
else if (line.startsWith("id: ")) id = line.slice(4).trim();
|
|
67
|
+
if (data) this.dispatchEvent({
|
|
68
|
+
type: eventType,
|
|
69
|
+
data,
|
|
70
|
+
lastEventId: id
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
addEventListener(type, listener) {
|
|
74
|
+
if (!this.listeners[type]) this.listeners[type] = [];
|
|
75
|
+
this.listeners[type].push(listener);
|
|
76
|
+
}
|
|
77
|
+
removeEventListener(type, listener) {
|
|
78
|
+
if (!this.listeners[type]) return;
|
|
79
|
+
this.listeners[type] = this.listeners[type].filter((l) => l !== listener);
|
|
80
|
+
}
|
|
81
|
+
dispatchEvent(event) {
|
|
82
|
+
const type = event.type;
|
|
83
|
+
if (this.listeners[type]) for (const listener of this.listeners[type]) listener(event);
|
|
84
|
+
}
|
|
85
|
+
close() {
|
|
86
|
+
this.readyState = this.CLOSED;
|
|
87
|
+
if (this.req) this.req.destroy();
|
|
88
|
+
}
|
|
89
|
+
};
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
//#endregion
|
|
93
|
+
//#region src/shared/adapters/filtering.ts
|
|
94
|
+
function shouldDisplayMessage(message, config) {
|
|
95
|
+
const overrides = config.filters || {};
|
|
96
|
+
if (message.subagentId && overrides["subagent"] !== true) return false;
|
|
97
|
+
if (message.displayRole === "agent" || message.role === "agent" || message.role === "legacy_log" || message.role === "policy" && message.status === "pending") return true;
|
|
98
|
+
if (message.subagentId && overrides["subagent"] === true && (message.role === "user" || message.displayRole === "user")) return true;
|
|
99
|
+
if (overrides[message.role] === true || message.displayRole && overrides[message.displayRole] === true) return true;
|
|
100
|
+
return false;
|
|
101
|
+
}
|
|
102
|
+
function formatMessage(message) {
|
|
103
|
+
if (!message.subagentId) return message.content;
|
|
104
|
+
if (message.role === "user" || message.displayRole === "user") return `[To:${message.subagentId}]\n${message.content}`;
|
|
105
|
+
return `[From:${message.subagentId}]\n${message.content}`;
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
//#endregion
|
|
109
|
+
//#region src/shared/adapters/commands.ts
|
|
110
|
+
const VALID_ROLES = new Set([
|
|
111
|
+
"subagent",
|
|
112
|
+
"command",
|
|
113
|
+
"system",
|
|
114
|
+
"tool",
|
|
115
|
+
"policy",
|
|
116
|
+
"subagent_status",
|
|
117
|
+
"legacy_log"
|
|
118
|
+
]);
|
|
119
|
+
async function handleAdapterCommand(content, config, trpcClient, chatId) {
|
|
120
|
+
const trimmed = content.trim();
|
|
121
|
+
if (trimmed === "/show all") {
|
|
122
|
+
const newConfig = { filters: { ...config.filters } };
|
|
123
|
+
for (const role of VALID_ROLES) newConfig.filters[role] = true;
|
|
124
|
+
return {
|
|
125
|
+
type: "text",
|
|
126
|
+
text: "Configuration updated: Showing all messages.",
|
|
127
|
+
newConfig
|
|
128
|
+
};
|
|
129
|
+
}
|
|
130
|
+
if (trimmed === "/hide all") return {
|
|
131
|
+
type: "text",
|
|
132
|
+
text: "Configuration updated: Hidden all overrides (using defaults).",
|
|
133
|
+
newConfig: { filters: {} }
|
|
134
|
+
};
|
|
135
|
+
if (trimmed === "/show" || trimmed === "/hide") return {
|
|
136
|
+
type: "text",
|
|
137
|
+
text: `Valid options for ${trimmed}: ${Array.from(VALID_ROLES).join(", ")}`
|
|
138
|
+
};
|
|
139
|
+
if (trimmed.startsWith("/show ")) {
|
|
140
|
+
const role = trimmed.slice(6).trim();
|
|
141
|
+
if (!VALID_ROLES.has(role)) return {
|
|
142
|
+
type: "text",
|
|
143
|
+
text: `Error: '${role}' is not a valid message role or special value. Valid options: ${Array.from(VALID_ROLES).join(", ")}`
|
|
144
|
+
};
|
|
145
|
+
return {
|
|
146
|
+
type: "text",
|
|
147
|
+
text: `Configuration updated: Showing messages for '${role}'.`,
|
|
148
|
+
newConfig: { filters: {
|
|
149
|
+
...config.filters,
|
|
150
|
+
[role]: true
|
|
151
|
+
} }
|
|
152
|
+
};
|
|
153
|
+
}
|
|
154
|
+
if (trimmed.startsWith("/hide ")) {
|
|
155
|
+
const role = trimmed.slice(6).trim();
|
|
156
|
+
if (!VALID_ROLES.has(role)) return {
|
|
157
|
+
type: "text",
|
|
158
|
+
text: `Error: '${role}' is not a valid message role or special value. Valid options: ${Array.from(VALID_ROLES).join(", ")}`
|
|
159
|
+
};
|
|
160
|
+
return {
|
|
161
|
+
type: "text",
|
|
162
|
+
text: `Configuration updated: Hiding messages for '${role}'.`,
|
|
163
|
+
newConfig: { filters: {
|
|
164
|
+
...config.filters,
|
|
165
|
+
[role]: false
|
|
166
|
+
} }
|
|
167
|
+
};
|
|
168
|
+
}
|
|
169
|
+
if (trimmed === "/debug" || trimmed.startsWith("/debug ")) {
|
|
170
|
+
const match = trimmed.match(/^\/debug\s+(\d+)$/);
|
|
171
|
+
const limit = match ? parseInt(match[1], 10) : 5;
|
|
172
|
+
const messages = await trpcClient.getMessages.query({
|
|
173
|
+
chatId,
|
|
174
|
+
limit: limit * 10
|
|
175
|
+
});
|
|
176
|
+
const ignoredMessages = [];
|
|
177
|
+
for (let i = messages.length - 1; i >= 0; i--) {
|
|
178
|
+
const msg = messages[i];
|
|
179
|
+
if (!msg) continue;
|
|
180
|
+
if ((msg.role === "user" || msg.displayRole === "user") && !msg.subagentId) continue;
|
|
181
|
+
if (!shouldDisplayMessage(msg, config)) {
|
|
182
|
+
ignoredMessages.push(msg);
|
|
183
|
+
if (ignoredMessages.length >= limit) break;
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
ignoredMessages.reverse();
|
|
187
|
+
return {
|
|
188
|
+
type: "debug",
|
|
189
|
+
messages: ignoredMessages
|
|
190
|
+
};
|
|
191
|
+
}
|
|
192
|
+
return null;
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
//#endregion
|
|
196
|
+
//#region src/shared/adapters/routing.ts
|
|
197
|
+
async function handleRoutingCommand(content, externalContextId, currentChannelChatMap, adapterName, trpcClient) {
|
|
198
|
+
const trimmed = content.trim();
|
|
199
|
+
if (trimmed.startsWith("/chat")) {
|
|
200
|
+
const chatId = trimmed.split(/\s+/).slice(1)[0];
|
|
201
|
+
const availableChats = await trpcClient.getChats.query();
|
|
202
|
+
if (!chatId || !availableChats.includes(chatId)) return {
|
|
203
|
+
type: "reply",
|
|
204
|
+
text: `Available chats:\n${availableChats.length > 0 ? availableChats.map((c) => `- ${c}`).join("\n") : "No chats available."}\n\nPlease specify a valid chat ID: \`/chat [chat-id]\``
|
|
205
|
+
};
|
|
206
|
+
for (const [channelId, mappedId] of Object.entries(currentChannelChatMap)) if (mappedId === chatId && channelId !== externalContextId) return {
|
|
207
|
+
type: "reply",
|
|
208
|
+
text: `Error: Chat \`${chatId}\` is already mapped to another channel/space. Strict 1:1 mapping is required.`
|
|
209
|
+
};
|
|
210
|
+
return {
|
|
211
|
+
type: "mapped",
|
|
212
|
+
text: `Successfully mapped this channel/space to chat \`${chatId}\`.`,
|
|
213
|
+
newChatId: chatId
|
|
214
|
+
};
|
|
215
|
+
}
|
|
216
|
+
if (trimmed.startsWith("/agent")) {
|
|
217
|
+
const agentId = trimmed.split(/\s+/).slice(1)[0];
|
|
218
|
+
const availableAgents = await trpcClient.getAgents.query();
|
|
219
|
+
if (!agentId || !availableAgents.includes(agentId)) return {
|
|
220
|
+
type: "reply",
|
|
221
|
+
text: `Available agents:\n${availableAgents.length > 0 ? availableAgents.map((a) => `- ${a}`).join("\n") : "No agents available."}\n\nPlease specify a valid agent ID: \`/agent [agent-id]\``
|
|
222
|
+
};
|
|
223
|
+
const availableChats = await trpcClient.getChats.query();
|
|
224
|
+
let newChatId = `${agentId}-${adapterName}`;
|
|
225
|
+
let counter = 1;
|
|
226
|
+
while (availableChats.includes(newChatId)) {
|
|
227
|
+
newChatId = `${agentId}-${adapterName}-${counter}`;
|
|
228
|
+
counter++;
|
|
229
|
+
}
|
|
230
|
+
await trpcClient.createChat.mutate({
|
|
231
|
+
chatId: newChatId,
|
|
232
|
+
agent: agentId
|
|
233
|
+
});
|
|
234
|
+
return {
|
|
235
|
+
type: "mapped",
|
|
236
|
+
text: `Successfully created new chat \`${newChatId}\` with agent \`${agentId}\` and mapped it to this channel/space.`,
|
|
237
|
+
newChatId
|
|
238
|
+
};
|
|
239
|
+
}
|
|
240
|
+
return null;
|
|
241
|
+
}
|
|
242
|
+
|
|
243
|
+
//#endregion
|
|
244
|
+
export { createUnixSocketEventSource as a, shouldDisplayMessage as i, handleAdapterCommand as n, formatMessage as r, handleRoutingCommand as t };
|
|
245
|
+
//# sourceMappingURL=routing-D8rTxtaV.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"routing-D8rTxtaV.mjs","names":[],"sources":["../src/shared/event-source.ts","../src/shared/adapters/filtering.ts","../src/shared/adapters/commands.ts","../src/shared/adapters/routing.ts"],"sourcesContent":["import http from 'node:http';\n\nexport function createUnixSocketEventSource(socketPath: string) {\n return class UnixSocketEventSource {\n public readyState: number = 0; // CONNECTING\n public readonly CONNECTING = 0;\n public readonly OPEN = 1;\n public readonly CLOSED = 2;\n\n req: http.ClientRequest | null = null;\n listeners: Record<string, ((event: Record<string, unknown>) => void)[]> = {};\n\n constructor(url: string, init?: Record<string, unknown>) {\n const parsedUrl = new URL(url);\n\n const options: http.RequestOptions = {\n socketPath,\n path: parsedUrl.pathname + parsedUrl.search,\n method: 'GET',\n headers: {\n Accept: 'text/event-stream',\n 'Cache-Control': 'no-cache',\n ...(init?.headers as Record<string, string> | undefined),\n },\n };\n\n this.req = http.request(options, (res) => {\n if (res.statusCode === 200) {\n this.readyState = this.OPEN;\n this.dispatchEvent({ type: 'open' });\n } else {\n this.readyState = this.CLOSED;\n this.dispatchEvent({\n type: 'error',\n message: `Unexpected status code: ${res.statusCode}`,\n });\n return;\n }\n\n let buffer = '';\n res.on('data', (chunk) => {\n buffer += chunk.toString('utf-8');\n const lines = buffer.split(/\\r?\\n\\r?\\n/);\n buffer = lines.pop() || '';\n\n for (const block of lines) {\n this.parseBlock(block);\n }\n });\n\n res.on('end', () => {\n if (buffer) this.parseBlock(buffer);\n this.readyState = this.CLOSED;\n this.dispatchEvent({ type: 'close' });\n });\n });\n\n this.req.on('error', (err) => {\n this.readyState = this.CLOSED;\n this.dispatchEvent({ type: 'error', error: err });\n });\n\n this.req.end();\n }\n\n parseBlock(block: string) {\n if (!block.trim()) return;\n\n const lines = block.split(/\\r?\\n/);\n let eventType = 'message';\n let data = '';\n let id = '';\n\n for (const line of lines) {\n if (line.startsWith('event: ')) {\n eventType = line.slice(7).trim();\n } else if (line.startsWith('data: ')) {\n data += (data ? '\\n' : '') + line.slice(6);\n } else if (line.startsWith('id: ')) {\n id = line.slice(4).trim();\n }\n }\n\n if (data) {\n this.dispatchEvent({\n type: eventType,\n data,\n lastEventId: id,\n });\n }\n }\n\n public addEventListener(type: string, listener: (event: Record<string, unknown>) => void) {\n if (!this.listeners[type]) {\n this.listeners[type] = [];\n }\n this.listeners[type].push(listener);\n }\n\n public removeEventListener(type: string, listener: (event: Record<string, unknown>) => void) {\n if (!this.listeners[type]) return;\n this.listeners[type] = this.listeners[type].filter((l) => l !== listener);\n }\n\n dispatchEvent(event: Record<string, unknown>) {\n const type = event.type as string;\n if (this.listeners[type]) {\n for (const listener of this.listeners[type]) {\n listener(event);\n }\n }\n }\n\n public close() {\n this.readyState = this.CLOSED;\n if (this.req) {\n this.req.destroy();\n }\n }\n };\n}\n","import type { ChatMessage } from '../chats.js';\n\nexport interface FilteringConfig {\n filters?: Record<string, boolean> | undefined;\n}\n\nexport function shouldDisplayMessage(message: ChatMessage, config: FilteringConfig): boolean {\n const overrides = config.filters || {};\n\n // If the message has a subagentId, return false immediately unless subagent messages are allowed.\n if (message.subagentId && overrides['subagent'] !== true) {\n return false;\n }\n\n // Then check if it's a standard agent message (via role/displayRole) and always return true if so.\n const isStandardAgent =\n message.displayRole === 'agent' ||\n message.role === 'agent' ||\n message.role === 'legacy_log' ||\n (message.role === 'policy' && message.status === 'pending');\n\n if (isStandardAgent) {\n return true;\n }\n\n // Then check if it's a user message directed to a subagent, if subagent messages are allowed\n if (\n message.subagentId &&\n overrides['subagent'] === true &&\n (message.role === 'user' || message.displayRole === 'user')\n ) {\n return true;\n }\n\n // Finally, check if the role is allowed and forward it if so.\n if (\n overrides[message.role] === true ||\n (message.displayRole && overrides[message.displayRole] === true)\n ) {\n return true;\n }\n\n return false;\n}\n\nexport function formatMessage(message: ChatMessage): string {\n if (!message.subagentId) {\n return message.content;\n }\n\n const isToSubagent = message.role === 'user' || message.displayRole === 'user';\n if (isToSubagent) {\n return `[To:${message.subagentId}]\\n${message.content}`;\n }\n\n return `[From:${message.subagentId}]\\n${message.content}`;\n}\n","import { shouldDisplayMessage, type FilteringConfig } from './filtering.js';\nimport type { ChatMessage } from '../chats.js';\n\nexport interface CommandTrpcClient {\n getMessages: {\n query: (args: { chatId: string; limit: number }) => Promise<ChatMessage[]>;\n };\n}\n\nconst VALID_ROLES = new Set([\n 'subagent',\n 'command',\n 'system',\n 'tool',\n 'policy',\n 'subagent_status',\n 'legacy_log',\n]);\n\nexport type AdapterCommandResult =\n | { type: 'text'; text: string; newConfig?: FilteringConfig }\n | { type: 'debug'; messages: ChatMessage[] }\n | null;\n\nexport async function handleAdapterCommand(\n content: string,\n config: FilteringConfig,\n trpcClient: CommandTrpcClient,\n chatId: string\n): Promise<AdapterCommandResult> {\n const trimmed = content.trim();\n\n if (trimmed === '/show all') {\n const newConfig: FilteringConfig = { filters: { ...config.filters } };\n for (const role of VALID_ROLES) {\n newConfig.filters![role] = true;\n }\n return { type: 'text', text: 'Configuration updated: Showing all messages.', newConfig };\n }\n\n if (trimmed === '/hide all') {\n return {\n type: 'text',\n text: 'Configuration updated: Hidden all overrides (using defaults).',\n newConfig: { filters: {} },\n };\n }\n\n if (trimmed === '/show' || trimmed === '/hide') {\n return {\n type: 'text',\n text: `Valid options for ${trimmed}: ${Array.from(VALID_ROLES).join(', ')}`,\n };\n }\n\n if (trimmed.startsWith('/show ')) {\n const role = trimmed.slice(6).trim();\n if (!VALID_ROLES.has(role)) {\n return {\n type: 'text',\n text: `Error: '${role}' is not a valid message role or special value. Valid options: ${Array.from(VALID_ROLES).join(', ')}`,\n };\n }\n return {\n type: 'text',\n text: `Configuration updated: Showing messages for '${role}'.`,\n newConfig: { filters: { ...config.filters, [role]: true } },\n };\n }\n\n if (trimmed.startsWith('/hide ')) {\n const role = trimmed.slice(6).trim();\n if (!VALID_ROLES.has(role)) {\n return {\n type: 'text',\n text: `Error: '${role}' is not a valid message role or special value. Valid options: ${Array.from(VALID_ROLES).join(', ')}`,\n };\n }\n return {\n type: 'text',\n text: `Configuration updated: Hiding messages for '${role}'.`,\n newConfig: { filters: { ...config.filters, [role]: false } },\n };\n }\n\n if (trimmed === '/debug' || trimmed.startsWith('/debug ')) {\n const match = trimmed.match(/^\\/debug\\s+(\\d+)$/);\n const limit = match ? parseInt(match[1] as string, 10) : 5;\n\n // Fetch recent messages\n // Fetch a larger batch since we need to filter them down\n const messages: ChatMessage[] = await trpcClient.getMessages.query({\n chatId,\n limit: limit * 10,\n });\n\n const ignoredMessages: ChatMessage[] = [];\n\n // Iterating backwards (newest to oldest)\n for (let i = messages.length - 1; i >= 0; i--) {\n const msg = messages[i];\n if (!msg) continue;\n\n // Exclude user messages without subagentIds\n const isUserWithoutSubagent =\n (msg.role === 'user' || msg.displayRole === 'user') && !msg.subagentId;\n if (isUserWithoutSubagent) continue;\n\n const isDisplayed = shouldDisplayMessage(msg, config);\n if (!isDisplayed) {\n ignoredMessages.push(msg);\n if (ignoredMessages.length >= limit) {\n break;\n }\n }\n }\n\n // Reverse back to chronological order\n ignoredMessages.reverse();\n\n return { type: 'debug', messages: ignoredMessages };\n }\n\n return null;\n}\n","export type RoutingTrpcClient = {\n getChats: { query: () => Promise<string[]> };\n getAgents: { query: () => Promise<string[]> };\n createChat: {\n mutate: (args: {\n chatId: string;\n agent?: string;\n }) => Promise<{ success: boolean; chatId: string }>;\n };\n sendMessage: {\n mutate: (args: {\n type: 'send-message';\n client: 'cli';\n data: {\n message: string;\n chatId?: string;\n agentId?: string;\n adapter?: string;\n noWait?: boolean;\n };\n }) => Promise<{ success: boolean }>;\n };\n};\n\nexport type RoutingCommandResult =\n | { type: 'reply'; text: string }\n | { type: 'mapped'; text: string; newChatId: string }\n | null;\n\nexport async function handleRoutingCommand(\n content: string,\n externalContextId: string,\n currentChannelChatMap: Record<string, string>,\n adapterName: string,\n trpcClient: RoutingTrpcClient\n): Promise<RoutingCommandResult> {\n const trimmed = content.trim();\n\n if (trimmed.startsWith('/chat')) {\n const args = trimmed.split(/\\s+/).slice(1);\n const chatId = args[0];\n\n const availableChats = await trpcClient.getChats.query();\n\n if (!chatId || !availableChats.includes(chatId)) {\n const formattedList =\n availableChats.length > 0\n ? availableChats.map((c) => `- ${c}`).join('\\n')\n : 'No chats available.';\n return {\n type: 'reply',\n text: `Available chats:\\n${formattedList}\\n\\nPlease specify a valid chat ID: \\`/chat [chat-id]\\``,\n };\n }\n\n // Strict 1:1 Mapping Constraint\n for (const [channelId, mappedId] of Object.entries(currentChannelChatMap)) {\n if (mappedId === chatId && channelId !== externalContextId) {\n return {\n type: 'reply',\n text: `Error: Chat \\`${chatId}\\` is already mapped to another channel/space. Strict 1:1 mapping is required.`,\n };\n }\n }\n\n return {\n type: 'mapped',\n text: `Successfully mapped this channel/space to chat \\`${chatId}\\`.`,\n newChatId: chatId,\n };\n }\n\n if (trimmed.startsWith('/agent')) {\n const args = trimmed.split(/\\s+/).slice(1);\n const agentId = args[0];\n\n const availableAgents = await trpcClient.getAgents.query();\n\n if (!agentId || !availableAgents.includes(agentId)) {\n const formattedList =\n availableAgents.length > 0\n ? availableAgents.map((a) => `- ${a}`).join('\\n')\n : 'No agents available.';\n return {\n type: 'reply',\n text: `Available agents:\\n${formattedList}\\n\\nPlease specify a valid agent ID: \\`/agent [agent-id]\\``,\n };\n }\n\n const availableChats = await trpcClient.getChats.query();\n let newChatId = `${agentId}-${adapterName}`;\n let counter = 1;\n\n while (availableChats.includes(newChatId)) {\n newChatId = `${agentId}-${adapterName}-${counter}`;\n counter++;\n }\n\n await trpcClient.createChat.mutate({ chatId: newChatId, agent: agentId });\n\n return {\n type: 'mapped',\n text: `Successfully created new chat \\`${newChatId}\\` with agent \\`${agentId}\\` and mapped it to this channel/space.`,\n newChatId,\n };\n }\n\n return null;\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-ease:initial;--tw-content:"";--tw-animation-delay:0s;--tw-animation-direction:normal;--tw-animation-duration:initial;--tw-animation-fill-mode:none;--tw-animation-iteration-count:1;--tw-enter-blur:0;--tw-enter-opacity:1;--tw-enter-rotate:0;--tw-enter-scale:1;--tw-enter-translate-x:0;--tw-enter-translate-y:0;--tw-exit-blur:0;--tw-exit-opacity:1;--tw-exit-rotate:0;--tw-exit-scale:1;--tw-exit-translate-x:0;--tw-exit-translate-y:0}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-red-500:oklch(63.7% .237 25.331);--color-amber-500:oklch(76.9% .188 70.08);--color-yellow-400:oklch(85.2% .199 91.936);--color-yellow-500:oklch(79.5% .184 86.047);--color-yellow-600:oklch(68.1% .162 75.834);--color-green-500:oklch(72.3% .219 149.579);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-sm:24rem;--container-lg:32rem;--container-4xl:56rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height: 1.5 ;--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--tracking-wider:.05em;--radius-xs:.125rem;--radius-2xl:1rem;--ease-in-out:cubic-bezier(.4, 0, .2, 1);--animate-spin:spin 1s linear infinite;--animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--blur-sm:8px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}*{border-color:var(--border);outline-color:var(--ring)}@supports (color:color-mix(in lab,red,red)){*{outline-color:color-mix(in oklab,var(--ring) 50%,transparent)}}body{background-color:var(--background);color:var(--foreground)}}@layer components;@layer utilities{.pointer-events-none{pointer-events:none}.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.inset-0{inset:calc(var(--spacing) * 0)}.inset-x-0{inset-inline:calc(var(--spacing) * 0)}.inset-y-0{inset-block:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.start-0{inset-inline-start:calc(var(--spacing) * 0)}.end-0{inset-inline-end:calc(var(--spacing) * 0)}.end-1{inset-inline-end:calc(var(--spacing) * 1)}.end-3{inset-inline-end:calc(var(--spacing) * 3)}.end-4{inset-inline-end:calc(var(--spacing) * 4)}.top-0{top:calc(var(--spacing) * 0)}.top-1\.5{top:calc(var(--spacing) * 1.5)}.top-3\.5{top:calc(var(--spacing) * 3.5)}.top-4{top:calc(var(--spacing) * 4)}.top-\[50\%\]{top:50%}.bottom-0{bottom:calc(var(--spacing) * 0)}.left-1\/2,.left-\[50\%\]{left:50%}.z-10{z-index:10}.z-20{z-index:20}.z-50{z-index:50}.col-span-2{grid-column:span 2/span 2}.col-span-3{grid-column:span 3/span 3}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.mx-3\.5{margin-inline:calc(var(--spacing) * 3.5)}.mx-auto{margin-inline:auto}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-auto{margin-top:auto}.mr-2{margin-right:calc(var(--spacing) * 2)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.-ml-2{margin-left:calc(var(--spacing) * -2)}.ml-1{margin-left:calc(var(--spacing) * 1)}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.field-sizing-content{field-sizing:content}.aspect-square{aspect-ratio:1}.size-2\.5{width:calc(var(--spacing) * 2.5);height:calc(var(--spacing) * 2.5)}.size-4{width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.size-7{width:calc(var(--spacing) * 7);height:calc(var(--spacing) * 7)}.size-8{width:calc(var(--spacing) * 8);height:calc(var(--spacing) * 8)}.size-9{width:calc(var(--spacing) * 9);height:calc(var(--spacing) * 9)}.size-10{width:calc(var(--spacing) * 10);height:calc(var(--spacing) * 10)}.h-2{height:calc(var(--spacing) * 2)}.h-3{height:calc(var(--spacing) * 3)}.h-4{height:calc(var(--spacing) * 4)}.h-5{height:calc(var(--spacing) * 5)}.h-7{height:calc(var(--spacing) * 7)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-10{height:calc(var(--spacing) * 10)}.h-12{height:calc(var(--spacing) * 12)}.h-14{height:calc(var(--spacing) * 14)}.h-\[1\.15rem\]{height:1.15rem}.h-\[100dvh\]{height:100dvh}.h-auto{height:auto}.h-full{height:100%}.h-svh{height:100svh}.min-h-0{min-height:calc(var(--spacing) * 0)}.min-h-16{min-height:calc(var(--spacing) * 16)}.min-h-\[0px\]{min-height:0}.min-h-\[80px\]{min-height:80px}.min-h-full{min-height:100%}.min-h-svh{min-height:100svh}.w-\(--sidebar-width\){width:var(--sidebar-width)}.w-2{width:calc(var(--spacing) * 2)}.w-3{width:calc(var(--spacing) * 3)}.w-3\/4{width:75%}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.w-8{width:calc(var(--spacing) * 8)}.w-12{width:calc(var(--spacing) * 12)}.w-fit{width:fit-content}.w-full{width:100%}.w-px{width:1px}.max-w-\(--skeleton-width\){max-width:var(--skeleton-width)}.max-w-4xl{max-width:var(--container-4xl)}.max-w-\[80\%\]{max-width:80%}.max-w-\[calc\(100\%-2rem\)\]{max-width:calc(100% - 2rem)}.max-w-none{max-width:none}.min-w-0{min-width:calc(var(--spacing) * 0)}.min-w-5{min-width:calc(var(--spacing) * 5)}.flex-1{flex:1}.shrink-0{flex-shrink:0}.origin-\(--bits-tooltip-content-transform-origin\){transform-origin:var(--bits-tooltip-content-transform-origin)}.-translate-x-1\/2{--tw-translate-x: -50% ;translate:var(--tw-translate-x) var(--tw-translate-y)}.-translate-x-px{--tw-translate-x:-1px;translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-x-\[-50\%\]{--tw-translate-x:-50%;translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-x-px{--tw-translate-x:1px;translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-y-\[-50\%\]{--tw-translate-y:-50%;translate:var(--tw-translate-x) var(--tw-translate-y)}.rotate-45{rotate:45deg}.animate-in{animation:enter var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none)}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.resize{resize:both}.resize-none{resize:none}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.flex-row{flex-direction:row}.flex-row-reverse{flex-direction:row-reverse}.items-baseline{align-items:baseline}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}:where(.space-y-1\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 1.5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 1.5) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-8>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 8) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 8) * calc(1 - var(--tw-space-y-reverse)))}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-\[2px\]{border-radius:2px}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-xs{border-radius:var(--radius-xs)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-s{border-inline-start-style:var(--tw-border-style);border-inline-start-width:1px}.border-e{border-inline-end-style:var(--tw-border-style);border-inline-end-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-dashed{--tw-border-style:dashed;border-style:dashed}.border-current{border-color:currentColor}.border-destructive\/20{border-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.border-destructive\/20{border-color:color-mix(in oklab,var(--destructive) 20%,transparent)}}.border-input{border-color:var(--input)}.border-primary\/50{border-color:var(--primary)}@supports (color:color-mix(in lab,red,red)){.border-primary\/50{border-color:color-mix(in oklab,var(--primary) 50%,transparent)}}.border-sidebar-border{border-color:var(--sidebar-border)}.border-transparent{border-color:#0000}.border-yellow-500\/20{border-color:#edb20033}@supports (color:color-mix(in lab,red,red)){.border-yellow-500\/20{border-color:color-mix(in oklab,var(--color-yellow-500) 20%,transparent)}}.border-t-transparent{border-top-color:#0000}.bg-accent{background-color:var(--accent)}.bg-background,.bg-background\/80{background-color:var(--background)}@supports (color:color-mix(in lab,red,red)){.bg-background\/80{background-color:color-mix(in oklab,var(--background) 80%,transparent)}}.bg-black\/50{background-color:#00000080}@supports (color:color-mix(in lab,red,red)){.bg-black\/50{background-color:color-mix(in oklab,var(--color-black) 50%,transparent)}}.bg-border{background-color:var(--border)}.bg-card{background-color:var(--card)}.bg-destructive,.bg-destructive\/5{background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.bg-destructive\/5{background-color:color-mix(in oklab,var(--destructive) 5%,transparent)}}.bg-destructive\/10{background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.bg-destructive\/10{background-color:color-mix(in oklab,var(--destructive) 10%,transparent)}}.bg-destructive\/15{background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.bg-destructive\/15{background-color:color-mix(in oklab,var(--destructive) 15%,transparent)}}.bg-destructive\/90{background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.bg-destructive\/90{background-color:color-mix(in oklab,var(--destructive) 90%,transparent)}}.bg-foreground{background-color:var(--foreground)}.bg-muted,.bg-muted\/20{background-color:var(--muted)}@supports (color:color-mix(in lab,red,red)){.bg-muted\/20{background-color:color-mix(in oklab,var(--muted) 20%,transparent)}}.bg-muted\/50{background-color:var(--muted)}@supports (color:color-mix(in lab,red,red)){.bg-muted\/50{background-color:color-mix(in oklab,var(--muted) 50%,transparent)}}.bg-primary,.bg-primary\/5{background-color:var(--primary)}@supports (color:color-mix(in lab,red,red)){.bg-primary\/5{background-color:color-mix(in oklab,var(--primary) 5%,transparent)}}.bg-secondary{background-color:var(--secondary)}.bg-sidebar{background-color:var(--sidebar)}.bg-sidebar-border{background-color:var(--sidebar-border)}.bg-transparent{background-color:#0000}.bg-yellow-500\/10{background-color:#edb2001a}@supports (color:color-mix(in lab,red,red)){.bg-yellow-500\/10{background-color:color-mix(in oklab,var(--color-yellow-500) 10%,transparent)}}.p-0{padding:calc(var(--spacing) * 0)}.p-1{padding:calc(var(--spacing) * 1)}.p-1\.5{padding:calc(var(--spacing) * 1.5)}.p-2{padding:calc(var(--spacing) * 2)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-6{padding:calc(var(--spacing) * 6)}.p-8{padding:calc(var(--spacing) * 8)}.p-12{padding:calc(var(--spacing) * 12)}.px-1{padding-inline:calc(var(--spacing) * 1)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-6{padding-inline:calc(var(--spacing) * 6)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-4{padding-block:calc(var(--spacing) * 4)}.pt-1\.5{padding-top:calc(var(--spacing) * 1.5)}.pt-2{padding-top:calc(var(--spacing) * 2)}.text-center{text-align:center}.text-left{text-align:left}.text-start{text-align:start}.font-mono{font-family:var(--font-mono)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[10px\]{font-size:10px}.leading-none{--tw-leading:1;line-height:1}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.text-balance{text-wrap:balance}.break-words{overflow-wrap:break-word}.whitespace-normal{white-space:normal}.whitespace-nowrap{white-space:nowrap}.whitespace-pre{white-space:pre}.whitespace-pre-wrap{white-space:pre-wrap}.text-amber-500{color:var(--color-amber-500)}.text-background{color:var(--background)}.text-card-foreground{color:var(--card-foreground)}.text-destructive{color:var(--destructive)}.text-foreground{color:var(--foreground)}.text-green-500{color:var(--color-green-500)}.text-muted-foreground,.text-muted-foreground\/50{color:var(--muted-foreground)}@supports (color:color-mix(in lab,red,red)){.text-muted-foreground\/50{color:color-mix(in oklab,var(--muted-foreground) 50%,transparent)}}.text-primary{color:var(--primary)}.text-primary-foreground{color:var(--primary-foreground)}.text-red-500{color:var(--color-red-500)}.text-secondary-foreground{color:var(--secondary-foreground)}.text-sidebar-foreground,.text-sidebar-foreground\/70{color:var(--sidebar-foreground)}@supports (color:color-mix(in lab,red,red)){.text-sidebar-foreground\/70{color:color-mix(in oklab,var(--sidebar-foreground) 70%,transparent)}}.text-white{color:var(--color-white)}.text-yellow-600{color:var(--color-yellow-600)}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.underline-offset-4{text-underline-offset:4px}.opacity-50{opacity:.5}.opacity-70{opacity:.7}.shadow-\[0_0_0_1px_var\(--sidebar-border\)\]{--tw-shadow:0 0 0 1px var(--tw-shadow-color,var(--sidebar-border));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-none{--tw-shadow:0 0 #0000;box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-xs{--tw-shadow:0 1px 2px 0 var(--tw-shadow-color,#0000000d);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-0{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-sidebar-ring{--tw-ring-color:var(--sidebar-ring)}.ring-offset-background{--tw-ring-offset-color:var(--background)}.outline-hidden{--tw-outline-style:none;outline-style:none}@media(forced-colors:active){.outline-hidden{outline-offset:2px;outline:2px solid #0000}}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.backdrop-blur-sm{--tw-backdrop-blur:blur(var(--blur-sm));-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[color\,box-shadow\]{transition-property:color,box-shadow;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[left\,right\,width\]{transition-property:left,right,width;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[margin\,opacity\]{transition-property:margin,opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[width\,height\,padding\]{transition-property:width,height,padding;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[width\]{transition-property:width;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-200{--tw-duration:.2s;transition-duration:.2s}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.ease-linear{--tw-ease:linear;transition-timing-function:linear}.fade-in-0{--tw-enter-opacity:0}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.zoom-in-95{--tw-enter-scale:.95}.group-focus-within\/menu-item\:opacity-100:is(:where(.group\/menu-item):focus-within *){opacity:1}@media(hover:hover){.group-hover\/menu-item\:opacity-100:is(:where(.group\/menu-item):hover *){opacity:1}}.group-has-data-\[sidebar\=menu-action\]\/menu-item\:pe-8:is(:where(.group\/menu-item):has([data-sidebar=menu-action]) *){padding-inline-end:calc(var(--spacing) * 8)}.group-data-\[collapsible\=icon\]\:-mt-8:is(:where(.group)[data-collapsible=icon] *){margin-top:calc(var(--spacing) * -8)}.group-data-\[collapsible\=icon\]\:hidden:is(:where(.group)[data-collapsible=icon] *){display:none}.group-data-\[collapsible\=icon\]\:size-8\!:is(:where(.group)[data-collapsible=icon] *){width:calc(var(--spacing) * 8)!important;height:calc(var(--spacing) * 8)!important}.group-data-\[collapsible\=icon\]\:w-\(--sidebar-width-icon\):is(:where(.group)[data-collapsible=icon] *){width:var(--sidebar-width-icon)}.group-data-\[collapsible\=icon\]\:w-\[calc\(var\(--sidebar-width-icon\)\+\(--spacing\(4\)\)\+2px\)\]:is(:where(.group)[data-collapsible=icon] *){width:calc(var(--sidebar-width-icon) + (calc(var(--spacing) * 4)) + 2px)}.group-data-\[collapsible\=icon\]\:overflow-hidden:is(:where(.group)[data-collapsible=icon] *){overflow:hidden}.group-data-\[collapsible\=icon\]\:p-0\!:is(:where(.group)[data-collapsible=icon] *){padding:calc(var(--spacing) * 0)!important}.group-data-\[collapsible\=icon\]\:p-2\!:is(:where(.group)[data-collapsible=icon] *){padding:calc(var(--spacing) * 2)!important}.group-data-\[collapsible\=icon\]\:opacity-0:is(:where(.group)[data-collapsible=icon] *){opacity:0}.group-data-\[collapsible\=offcanvas\]\:start-\[calc\(var\(--sidebar-width\)\*-1\)\]:is(:where(.group)[data-collapsible=offcanvas] *){inset-inline-start:calc(var(--sidebar-width) * -1)}.group-data-\[collapsible\=offcanvas\]\:end-\[calc\(var\(--sidebar-width\)\*-1\)\]:is(:where(.group)[data-collapsible=offcanvas] *){inset-inline-end:calc(var(--sidebar-width) * -1)}.group-data-\[collapsible\=offcanvas\]\:w-0:is(:where(.group)[data-collapsible=offcanvas] *){width:calc(var(--spacing) * 0)}.group-data-\[collapsible\=offcanvas\]\:translate-x-0:is(:where(.group)[data-collapsible=offcanvas] *){--tw-translate-x:calc(var(--spacing) * 0);translate:var(--tw-translate-x) var(--tw-translate-y)}.group-data-\[side\=left\]\:-end-4:is(:where(.group)[data-side=left] *){inset-inline-end:calc(var(--spacing) * -4)}.group-data-\[side\=left\]\:border-e:is(:where(.group)[data-side=left] *){border-inline-end-style:var(--tw-border-style);border-inline-end-width:1px}.group-data-\[side\=right\]\:start-0:is(:where(.group)[data-side=right] *){inset-inline-start:calc(var(--spacing) * 0)}.group-data-\[side\=right\]\:rotate-180:is(:where(.group)[data-side=right] *){rotate:180deg}.group-data-\[side\=right\]\:border-s:is(:where(.group)[data-side=right] *){border-inline-start-style:var(--tw-border-style);border-inline-start-width:1px}.group-data-\[variant\=floating\]\:rounded-lg:is(:where(.group)[data-variant=floating] *){border-radius:var(--radius)}.group-data-\[variant\=floating\]\:border:is(:where(.group)[data-variant=floating] *){border-style:var(--tw-border-style);border-width:1px}.group-data-\[variant\=floating\]\:border-sidebar-border:is(:where(.group)[data-variant=floating] *){border-color:var(--sidebar-border)}.group-data-\[variant\=floating\]\:shadow-sm:is(:where(.group)[data-variant=floating] *){--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}@media(hover:hover){.peer-hover\/menu-button\:text-sidebar-accent-foreground:is(:where(.peer\/menu-button):hover~*){color:var(--sidebar-accent-foreground)}}.peer-disabled\:cursor-not-allowed:is(:where(.peer):disabled~*){cursor:not-allowed}.peer-disabled\:opacity-70:is(:where(.peer):disabled~*){opacity:.7}.peer-data-\[active\=true\]\/menu-button\:text-sidebar-accent-foreground:is(:where(.peer\/menu-button)[data-active=true]~*){color:var(--sidebar-accent-foreground)}.peer-data-\[size\=default\]\/menu-button\:top-1\.5:is(:where(.peer\/menu-button)[data-size=default]~*){top:calc(var(--spacing) * 1.5)}.peer-data-\[size\=lg\]\/menu-button\:top-2\.5:is(:where(.peer\/menu-button)[data-size=lg]~*){top:calc(var(--spacing) * 2.5)}.peer-data-\[size\=sm\]\/menu-button\:top-1:is(:where(.peer\/menu-button)[data-size=sm]~*){top:calc(var(--spacing) * 1)}.selection\:bg-primary ::selection{background-color:var(--primary)}.selection\:bg-primary::selection{background-color:var(--primary)}.selection\:text-primary-foreground ::selection{color:var(--primary-foreground)}.selection\:text-primary-foreground::selection{color:var(--primary-foreground)}.file\:border-0::file-selector-button{border-style:var(--tw-border-style);border-width:0}.file\:bg-transparent::file-selector-button{background-color:#0000}.file\:text-sm::file-selector-button{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.file\:font-medium::file-selector-button{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.placeholder\:text-muted-foreground::placeholder{color:var(--muted-foreground)}.after\:absolute:after{content:var(--tw-content);position:absolute}.after\:-inset-2:after{content:var(--tw-content);inset:calc(var(--spacing) * -2)}.after\:inset-y-0:after{content:var(--tw-content);inset-block:calc(var(--spacing) * 0)}.after\:start-\[calc\(1\/2\*100\%-1px\)\]:after{content:var(--tw-content);inset-inline-start:calc(50% - 1px)}.after\:w-\[2px\]:after{content:var(--tw-content);width:2px}.group-data-\[collapsible\=offcanvas\]\:after\:start-full:is(:where(.group)[data-collapsible=offcanvas] *):after{content:var(--tw-content);inset-inline-start:100%}@media(hover:hover){.hover\:bg-accent:hover{background-color:var(--accent)}.hover\:bg-destructive\/10:hover{background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-destructive\/10:hover{background-color:color-mix(in oklab,var(--destructive) 10%,transparent)}}.hover\:bg-destructive\/90:hover{background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-destructive\/90:hover{background-color:color-mix(in oklab,var(--destructive) 90%,transparent)}}.hover\:bg-muted:hover{background-color:var(--muted)}.hover\:bg-primary\/90:hover{background-color:var(--primary)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-primary\/90:hover{background-color:color-mix(in oklab,var(--primary) 90%,transparent)}}.hover\:bg-secondary\/80:hover{background-color:var(--secondary)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-secondary\/80:hover{background-color:color-mix(in oklab,var(--secondary) 80%,transparent)}}.hover\:bg-sidebar-accent:hover{background-color:var(--sidebar-accent)}.hover\:text-accent-foreground:hover{color:var(--accent-foreground)}.hover\:text-destructive:hover{color:var(--destructive)}.hover\:text-foreground:hover{color:var(--foreground)}.hover\:text-sidebar-accent-foreground:hover{color:var(--sidebar-accent-foreground)}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}.hover\:shadow-\[0_0_0_1px_var\(--sidebar-accent\)\]:hover{--tw-shadow:0 0 0 1px var(--tw-shadow-color,var(--sidebar-accent));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.hover\:group-data-\[collapsible\=offcanvas\]\:bg-sidebar:hover:is(:where(.group)[data-collapsible=offcanvas] *){background-color:var(--sidebar)}.hover\:after\:bg-sidebar-border:hover:after{content:var(--tw-content);background-color:var(--sidebar-border)}}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-ring:focus{--tw-ring-color:var(--ring)}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.focus\:outline-hidden:focus{--tw-outline-style:none;outline-style:none}@media(forced-colors:active){.focus\:outline-hidden:focus{outline-offset:2px;outline:2px solid #0000}}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.focus-visible\:border-ring:focus-visible{border-color:var(--ring)}.focus-visible\:ring-2:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus-visible\:ring-\[3px\]:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus-visible\:ring-destructive\/20:focus-visible{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.focus-visible\:ring-destructive\/20:focus-visible{--tw-ring-color:color-mix(in oklab, var(--destructive) 20%, transparent)}}.focus-visible\:ring-ring:focus-visible,.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color:var(--ring)}@supports (color:color-mix(in lab,red,red)){.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color:color-mix(in oklab, var(--ring) 50%, transparent)}}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.focus-visible\:outline-hidden:focus-visible{--tw-outline-style:none;outline-style:none}@media(forced-colors:active){.focus-visible\:outline-hidden:focus-visible{outline-offset:2px;outline:2px solid #0000}}.focus-visible\:outline-none:focus-visible{--tw-outline-style:none;outline-style:none}.active\:bg-sidebar-accent:active{background-color:var(--sidebar-accent)}.active\:text-sidebar-accent-foreground:active{color:var(--sidebar-accent-foreground)}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}:where([data-side=left]) .in-data-\[side\=left\]\:cursor-w-resize{cursor:w-resize}:where([data-side=right]) .in-data-\[side\=right\]\:cursor-e-resize{cursor:e-resize}.has-data-\[variant\=inset\]\:bg-sidebar:has([data-variant=inset]){background-color:var(--sidebar)}.has-\[\>svg\]\:px-2\.5:has(>svg){padding-inline:calc(var(--spacing) * 2.5)}.has-\[\>svg\]\:px-3:has(>svg){padding-inline:calc(var(--spacing) * 3)}.has-\[\>svg\]\:px-4:has(>svg){padding-inline:calc(var(--spacing) * 4)}.aria-disabled\:pointer-events-none[aria-disabled=true]{pointer-events:none}.aria-disabled\:opacity-50[aria-disabled=true]{opacity:.5}.aria-invalid\:border-destructive[aria-invalid=true]{border-color:var(--destructive)}.aria-invalid\:ring-destructive\/20[aria-invalid=true]{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.aria-invalid\:ring-destructive\/20[aria-invalid=true]{--tw-ring-color:color-mix(in oklab, var(--destructive) 20%, transparent)}}.data-\[active\=true\]\:bg-sidebar-accent[data-active=true]{background-color:var(--sidebar-accent)}.data-\[active\=true\]\:font-medium[data-active=true]{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.data-\[active\=true\]\:text-sidebar-accent-foreground[data-active=true]{color:var(--sidebar-accent-foreground)}.data-\[orientation\=horizontal\]\:h-px[data-orientation=horizontal]{height:1px}.data-\[orientation\=horizontal\]\:w-full[data-orientation=horizontal]{width:100%}.data-\[orientation\=vertical\]\:min-h-full[data-orientation=vertical]{min-height:100%}.data-\[orientation\=vertical\]\:w-px[data-orientation=vertical]{width:1px}.data-\[side\=bottom\]\:-translate-x-1\/2[data-side=bottom]{--tw-translate-x: -50% ;translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=bottom\]\:-translate-y-\[calc\(-50\%_\+_1px\)\][data-side=bottom]{--tw-translate-y: calc((-50% + 1px)*-1) ;translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=bottom\]\:slide-in-from-top-2[data-side=bottom]{--tw-enter-translate-y:calc(2*var(--spacing)*-1)}.data-\[side\=left\]\:-translate-y-\[calc\(50\%_-_3px\)\][data-side=left]{--tw-translate-y: calc((50% - 3px)*-1) ;translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=left\]\:slide-in-from-end-2[data-side=left]:where(:dir(ltr),[dir=ltr]){--tw-enter-translate-x:calc(2*var(--spacing))}.data-\[side\=left\]\:slide-in-from-end-2[data-side=left]:where(:dir(rtl),[dir=rtl]){--tw-enter-translate-x:calc(2*var(--spacing)*-1)}.data-\[side\=right\]\:translate-x-\[calc\(50\%_\+_2px\)\][data-side=right]{--tw-translate-x: calc(50% + 2px) ;translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=right\]\:translate-y-1\/2[data-side=right]{--tw-translate-y: 50% ;translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=right\]\:slide-in-from-start-2[data-side=right]:where(:dir(ltr),[dir=ltr]){--tw-enter-translate-x:calc(2*var(--spacing)*-1)}.data-\[side\=right\]\:slide-in-from-start-2[data-side=right]:where(:dir(rtl),[dir=rtl]){--tw-enter-translate-x:calc(2*var(--spacing))}.data-\[side\=top\]\:translate-x-1\/2[data-side=top]{--tw-translate-x: 50% ;translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=top\]\:translate-y-\[calc\(-50\%_\+_2px\)\][data-side=top]{--tw-translate-y: calc(-50% + 2px) ;translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=top\]\:slide-in-from-bottom-2[data-side=top]{--tw-enter-translate-y:calc(2*var(--spacing))}.data-\[state\=checked\]\:translate-x-\[calc\(100\%-2px\)\][data-state=checked]{--tw-translate-x: calc(100% - 2px) ;translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[state\=checked\]\:bg-primary[data-state=checked]{background-color:var(--primary)}.data-\[state\=closed\]\:animate-out[data-state=closed]{animation:exit var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none)}.data-\[state\=closed\]\:duration-300[data-state=closed]{--tw-duration:.3s;transition-duration:.3s}.data-\[state\=closed\]\:fade-out-0[data-state=closed]{--tw-exit-opacity:0}.data-\[state\=closed\]\:slide-out-to-end[data-state=closed]:dir(ltr){--tw-exit-translate-x:100%}.data-\[state\=closed\]\:slide-out-to-end[data-state=closed]:dir(rtl){--tw-exit-translate-x:-100%}.data-\[state\=closed\]\:slide-out-to-start[data-state=closed]:dir(ltr){--tw-exit-translate-x:-100%}.data-\[state\=closed\]\:slide-out-to-start[data-state=closed]:dir(rtl){--tw-exit-translate-x:100%}.data-\[state\=closed\]\:zoom-out-95[data-state=closed]{--tw-exit-scale:.95}.data-\[state\=closed\]\:slide-out-to-bottom[data-state=closed]{--tw-exit-translate-y:100%}.data-\[state\=closed\]\:slide-out-to-top[data-state=closed]{--tw-exit-translate-y:-100%}.data-\[state\=open\]\:animate-in[data-state=open]{animation:enter var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none)}.data-\[state\=open\]\:opacity-100[data-state=open]{opacity:1}.data-\[state\=open\]\:duration-500[data-state=open]{--tw-duration:.5s;transition-duration:.5s}.data-\[state\=open\]\:fade-in-0[data-state=open]{--tw-enter-opacity:0}.data-\[state\=open\]\:slide-in-from-end[data-state=open]:dir(ltr){--tw-enter-translate-x:100%}.data-\[state\=open\]\:slide-in-from-end[data-state=open]:dir(rtl){--tw-enter-translate-x:-100%}.data-\[state\=open\]\:slide-in-from-start[data-state=open]:dir(ltr){--tw-enter-translate-x:-100%}.data-\[state\=open\]\:slide-in-from-start[data-state=open]:dir(rtl){--tw-enter-translate-x:100%}.data-\[state\=open\]\:zoom-in-95[data-state=open]{--tw-enter-scale:.95}.data-\[state\=open\]\:slide-in-from-bottom[data-state=open]{--tw-enter-translate-y:100%}.data-\[state\=open\]\:slide-in-from-top[data-state=open]{--tw-enter-translate-y:-100%}@media(hover:hover){.data-\[state\=open\]\:hover\:bg-sidebar-accent[data-state=open]:hover{background-color:var(--sidebar-accent)}.data-\[state\=open\]\:hover\:text-sidebar-accent-foreground[data-state=open]:hover{color:var(--sidebar-accent-foreground)}}.data-\[state\=unchecked\]\:translate-x-0[data-state=unchecked]{--tw-translate-x:calc(var(--spacing) * 0);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[state\=unchecked\]\:bg-input[data-state=unchecked]{background-color:var(--input)}@media(min-width:40rem){.sm\:flex{display:flex}.sm\:max-w-\[425px\]{max-width:425px}.sm\:max-w-lg{max-width:var(--container-lg)}.sm\:max-w-sm{max-width:var(--container-sm)}.sm\:flex-row{flex-direction:row}.sm\:justify-end{justify-content:flex-end}.sm\:text-start{text-align:start}}@media(min-width:48rem){.md\:block{display:block}.md\:flex{display:flex}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.md\:opacity-0{opacity:0}.md\:peer-data-\[variant\=inset\]\:m-2:is(:where(.peer)[data-variant=inset]~*){margin:calc(var(--spacing) * 2)}.md\:peer-data-\[variant\=inset\]\:ms-0:is(:where(.peer)[data-variant=inset]~*){margin-inline-start:calc(var(--spacing) * 0)}.md\:peer-data-\[variant\=inset\]\:rounded-xl:is(:where(.peer)[data-variant=inset]~*){border-radius:calc(var(--radius) + 4px)}.md\:peer-data-\[variant\=inset\]\:shadow-sm:is(:where(.peer)[data-variant=inset]~*){--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.md\:peer-data-\[variant\=inset\]\:peer-data-\[state\=collapsed\]\:ms-2:is(:where(.peer)[data-variant=inset]~*):is(:where(.peer)[data-state=collapsed]~*){margin-inline-start:calc(var(--spacing) * 2)}.md\:after\:hidden:after{content:var(--tw-content);display:none}}.dark\:border-input:is(.dark *){border-color:var(--input)}.dark\:bg-destructive\/60:is(.dark *){background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.dark\:bg-destructive\/60:is(.dark *){background-color:color-mix(in oklab,var(--destructive) 60%,transparent)}}.dark\:bg-input\/30:is(.dark *){background-color:var(--input)}@supports (color:color-mix(in lab,red,red)){.dark\:bg-input\/30:is(.dark *){background-color:color-mix(in oklab,var(--input) 30%,transparent)}}.dark\:text-yellow-400:is(.dark *){color:var(--color-yellow-400)}@media(hover:hover){.dark\:hover\:bg-accent\/50:is(.dark *):hover{background-color:var(--accent)}@supports (color:color-mix(in lab,red,red)){.dark\:hover\:bg-accent\/50:is(.dark *):hover{background-color:color-mix(in oklab,var(--accent) 50%,transparent)}}.dark\:hover\:bg-input\/50:is(.dark *):hover{background-color:var(--input)}@supports (color:color-mix(in lab,red,red)){.dark\:hover\:bg-input\/50:is(.dark *):hover{background-color:color-mix(in oklab,var(--input) 50%,transparent)}}}.dark\:focus-visible\:ring-destructive\/40:is(.dark *):focus-visible{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.dark\:focus-visible\:ring-destructive\/40:is(.dark *):focus-visible{--tw-ring-color:color-mix(in oklab, var(--destructive) 40%, transparent)}}.dark\:aria-invalid\:ring-destructive\/40:is(.dark *)[aria-invalid=true]{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.dark\:aria-invalid\:ring-destructive\/40:is(.dark *)[aria-invalid=true]{--tw-ring-color:color-mix(in oklab, var(--destructive) 40%, transparent)}}.dark\:data-\[state\=checked\]\:bg-primary-foreground:is(.dark *)[data-state=checked]{background-color:var(--primary-foreground)}.dark\:data-\[state\=unchecked\]\:bg-foreground:is(.dark *)[data-state=unchecked]{background-color:var(--foreground)}.dark\:data-\[state\=unchecked\]\:bg-input\/80:is(.dark *)[data-state=unchecked]{background-color:var(--input)}@supports (color:color-mix(in lab,red,red)){.dark\:data-\[state\=unchecked\]\:bg-input\/80:is(.dark *)[data-state=unchecked]{background-color:color-mix(in oklab,var(--input) 80%,transparent)}}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-4 svg:not([class*=size-]){width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.\[\&\>button\]\:hidden>button{display:none}.\[\&\>span\:last-child\]\:truncate>span:last-child{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.\[\&\>svg\]\:size-4>svg{width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.\[\&\>svg\]\:shrink-0>svg{flex-shrink:0}.\[\&\>svg\]\:text-sidebar-accent-foreground>svg{color:var(--sidebar-accent-foreground)}[data-side=left][data-collapsible=offcanvas] .\[\[data-side\=left\]\[data-collapsible\=offcanvas\]_\&\]\:-end-2{inset-inline-end:calc(var(--spacing) * -2)}[data-side=left][data-state=collapsed] .\[\[data-side\=left\]\[data-state\=collapsed\]_\&\]\:cursor-e-resize{cursor:e-resize}[data-side=right][data-collapsible=offcanvas] .\[\[data-side\=right\]\[data-collapsible\=offcanvas\]_\&\]\:-start-2{inset-inline-start:calc(var(--spacing) * -2)}[data-side=right][data-state=collapsed] .\[\[data-side\=right\]\[data-state\=collapsed\]_\&\]\:cursor-w-resize{cursor:w-resize}}@property --tw-animation-delay{syntax:"*";inherits:false;initial-value:0s}@property --tw-animation-direction{syntax:"*";inherits:false;initial-value:normal}@property --tw-animation-duration{syntax:"*";inherits:false}@property --tw-animation-fill-mode{syntax:"*";inherits:false;initial-value:none}@property --tw-animation-iteration-count{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-translate-y{syntax:"*";inherits:false;initial-value:0}:root{--radius:.625rem;--background:oklch(100% 0 0);--foreground:oklch(12.9% .042 264.695);--card:oklch(100% 0 0);--card-foreground:oklch(12.9% .042 264.695);--popover:oklch(100% 0 0);--popover-foreground:oklch(12.9% .042 264.695);--primary:oklch(20.8% .042 265.755);--primary-foreground:oklch(98.4% .003 247.858);--secondary:oklch(96.8% .007 247.896);--secondary-foreground:oklch(20.8% .042 265.755);--muted:oklch(96.8% .007 247.896);--muted-foreground:oklch(55.4% .046 257.417);--accent:oklch(96.8% .007 247.896);--accent-foreground:oklch(20.8% .042 265.755);--destructive:oklch(57.7% .245 27.325);--border:oklch(92.9% .013 255.508);--input:oklch(92.9% .013 255.508);--ring:oklch(70.4% .04 256.788);--chart-1:oklch(64.6% .222 41.116);--chart-2:oklch(60% .118 184.704);--chart-3:oklch(39.8% .07 227.392);--chart-4:oklch(82.8% .189 84.429);--chart-5:oklch(76.9% .188 70.08);--sidebar:oklch(98.4% .003 247.858);--sidebar-foreground:oklch(12.9% .042 264.695);--sidebar-primary:oklch(20.8% .042 265.755);--sidebar-primary-foreground:oklch(98.4% .003 247.858);--sidebar-accent:oklch(96.8% .007 247.896);--sidebar-accent-foreground:oklch(20.8% .042 265.755);--sidebar-border:oklch(92.9% .013 255.508);--sidebar-ring:oklch(70.4% .04 256.788)}.dark{--background:oklch(12.9% .042 264.695);--foreground:oklch(98.4% .003 247.858);--card:oklch(20.8% .042 265.755);--card-foreground:oklch(98.4% .003 247.858);--popover:oklch(20.8% .042 265.755);--popover-foreground:oklch(98.4% .003 247.858);--primary:oklch(92.9% .013 255.508);--primary-foreground:oklch(20.8% .042 265.755);--secondary:oklch(27.9% .041 260.031);--secondary-foreground:oklch(98.4% .003 247.858);--muted:oklch(27.9% .041 260.031);--muted-foreground:oklch(70.4% .04 256.788);--accent:oklch(27.9% .041 260.031);--accent-foreground:oklch(98.4% .003 247.858);--destructive:oklch(70.4% .191 22.216);--border:oklch(100% 0 0/.1);--input:oklch(100% 0 0/.15);--ring:oklch(55.1% .027 264.364);--chart-1:oklch(48.8% .243 264.376);--chart-2:oklch(69.6% .17 162.48);--chart-3:oklch(76.9% .188 70.08);--chart-4:oklch(62.7% .265 303.9);--chart-5:oklch(64.5% .246 16.439);--sidebar:oklch(20.8% .042 265.755);--sidebar-foreground:oklch(98.4% .003 247.858);--sidebar-primary:oklch(48.8% .243 264.376);--sidebar-primary-foreground:oklch(98.4% .003 247.858);--sidebar-accent:oklch(27.9% .041 260.031);--sidebar-accent-foreground:oklch(98.4% .003 247.858);--sidebar-border:oklch(100% 0 0/.1);--sidebar-ring:oklch(55.1% .027 264.364)}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@property --tw-content{syntax:"*";inherits:false;initial-value:""}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{50%{opacity:.5}}@keyframes enter{0%{opacity:var(--tw-enter-opacity,1);transform:translate3d(var(--tw-enter-translate-x,0),var(--tw-enter-translate-y,0),0)scale3d(var(--tw-enter-scale,1),var(--tw-enter-scale,1),var(--tw-enter-scale,1))rotate(var(--tw-enter-rotate,0));filter:blur(var(--tw-enter-blur,0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity,1);transform:translate3d(var(--tw-exit-translate-x,0),var(--tw-exit-translate-y,0),0)scale3d(var(--tw-exit-scale,1),var(--tw-exit-scale,1),var(--tw-exit-scale,1))rotate(var(--tw-exit-rotate,0));filter:blur(var(--tw-exit-blur,0))}}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.markdown-content p{margin-top:.5em;margin-bottom:.5em}.markdown-content pre{background-color:#1e1e1e;color:#d4d4d4;padding:1em;border-radius:.5rem;overflow-x:auto}.markdown-content code{background-color:#78787833;padding:.2em .4em;border-radius:.25rem;font-size:.875em}.markdown-content pre code{background-color:transparent;padding:0}.markdown-content ul{list-style-type:disc;padding-left:1.5em;margin-top:.5em;margin-bottom:.5em}.markdown-content ol{list-style-type:decimal;padding-left:1.5em;margin-top:.5em;margin-bottom:.5em}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{U,V as g,W as C,K as R,X as A,Y as $,h as x,k as M,Z as G,_ as Z,b as q,d as z,E as V,e as W,g as X,i as H,j as D,m as J,$ as Q,a0 as k,o as B,L as P,a1 as ee,a2 as O,a3 as m,a4 as re,a5 as K,w,l as se,D as te,a6 as ne,a7 as ie,a8 as ae,a9 as fe,A as ue,aa as ce,ab as oe,y as le,ac as de,ad as I,ae as T,af as _,ag as N,ah as pe}from"./CME08kGM.js";let b=!1;function he(r){var e=b;try{return b=!1,[r(),b]}finally{b=e}}class _e{anchor;#r=new Map;#s=new Map;#e=new Map;#t=new Set;#n=!0;constructor(e,t=!0){this.anchor=e,this.#n=t}#i=e=>{if(this.#r.has(e)){var t=this.#r.get(e),s=this.#s.get(t);if(s)U(s),this.#t.delete(t);else{var n=this.#e.get(t);n&&(this.#s.set(t,n.effect),this.#e.delete(t),n.fragment.lastChild.remove(),this.anchor.before(n.fragment),s=n.effect)}for(const[a,u]of this.#r){if(this.#r.delete(a),a===e)break;const i=this.#e.get(u);i&&(g(i.effect),this.#e.delete(u))}for(const[a,u]of this.#s){if(a===t||this.#t.has(a))continue;const i=()=>{if(Array.from(this.#r.values()).includes(a)){var o=document.createDocumentFragment();G(u,o),o.append(R()),this.#e.set(a,{effect:u,fragment:o})}else g(u);this.#t.delete(a),this.#s.delete(a)};this.#n||!s?(this.#t.add(a),C(u,i,!1)):i()}}};#a=e=>{this.#r.delete(e);const t=Array.from(this.#r.values());for(const[s,n]of this.#e)t.includes(s)||(g(n.effect),this.#e.delete(s))};ensure(e,t){var s=$,n=Z();if(t&&!this.#s.has(e)&&!this.#e.has(e))if(n){var a=document.createDocumentFragment(),u=R();a.append(u),this.#e.set(e,{effect:A(()=>t(u)),fragment:a})}else this.#s.set(e,A(()=>t(this.anchor)));if(this.#r.set(s,e),n){for(const[i,f]of this.#s)i===e?s.unskip_effect(f):s.skip_effect(f);for(const[i,f]of this.#e)i===e?s.unskip_effect(f.effect):s.skip_effect(f.effect);s.oncommit(this.#i),s.ondiscard(this.#a)}else x&&(this.anchor=M),this.#i(s)}}function ge(r,e,t=!1){var s;x&&(s=M,z());var n=new _e(r),a=t?V:0;function u(i,f){if(x){var o=W(s);if(i!==parseInt(o.substring(1))){var l=X();H(l),n.anchor=l,D(!1),n.ensure(i,f),D(!0);return}}n.ensure(i,f)}q(()=>{var i=!1;e((f,o=0)=>{i=!0,u(o,f)}),i||u(-1,null)},a)}function L(r,e){return r===e||r?.[O]===e}function xe(r={},e,t,s){var n=J.r,a=P;return Q(()=>{var u,i;return k(()=>{u=i,i=[],B(()=>{r!==t(...i)&&(e(r,...i),u&&L(t(...u),r)&&e(null,...u))})}),()=>{let f=a;for(;f!==n&&f.parent!==null&&f.parent.fⅇ)f=f.parent;const o=()=>{i&&L(t(...i),r)&&e(null,...i)},l=f.teardown;f.teardown=()=>{o(),l?.()}}}),r}const ve={get(r,e){if(!r.exclude.includes(e))return r.props[e]},set(r,e){return!1},getOwnPropertyDescriptor(r,e){if(!r.exclude.includes(e)&&e in r.props)return{enumerable:!0,configurable:!0,value:r.props[e]}},has(r,e){return r.exclude.includes(e)?!1:e in r.props},ownKeys(r){return Reflect.ownKeys(r.props).filter(e=>!r.exclude.includes(e))}};function me(r,e,t){return new Proxy({props:r,exclude:e},ve)}const be={get(r,e){if(!r.exclude.includes(e))return w(r.version),e in r.special?r.special[e]():r.props[e]},set(r,e,t){if(!(e in r.special)){var s=P;try{T(r.parent_effect),r.special[e]=Pe({get[e](){return r.props[e]}},e,K)}finally{T(s)}}return r.special[e](t),I(r.version),!0},getOwnPropertyDescriptor(r,e){if(!r.exclude.includes(e)&&e in r.props)return{enumerable:!0,configurable:!0,value:r.props[e]}},deleteProperty(r,e){return r.exclude.includes(e)||(r.exclude.push(e),I(r.version)),!0},has(r,e){return r.exclude.includes(e)?!1:e in r.props},ownKeys(r){return Reflect.ownKeys(r.props).filter(e=>!r.exclude.includes(e))}};function Oe(r,e){return new Proxy({props:r,exclude:e,special:{},version:ae(0),parent_effect:P},be)}const we={get(r,e){let t=r.props.length;for(;t--;){let s=r.props[t];if(_(s)&&(s=s()),typeof s=="object"&&s!==null&&e in s)return s[e]}},set(r,e,t){let s=r.props.length;for(;s--;){let n=r.props[s];_(n)&&(n=n());const a=m(n,e);if(a&&a.set)return a.set(t),!0}return!1},getOwnPropertyDescriptor(r,e){let t=r.props.length;for(;t--;){let s=r.props[t];if(_(s)&&(s=s()),typeof s=="object"&&s!==null&&e in s){const n=m(s,e);return n&&!n.configurable&&(n.configurable=!0),n}}},has(r,e){if(e===O||e===N)return!1;for(let t of r.props)if(_(t)&&(t=t()),t!=null&&e in t)return!0;return!1},ownKeys(r){const e=[];for(let t of r.props)if(_(t)&&(t=t()),!!t){for(const s in t)e.includes(s)||e.push(s);for(const s of Object.getOwnPropertySymbols(t))e.includes(s)||e.push(s)}return e}};function ye(...r){return new Proxy({props:r},we)}function Pe(r,e,t,s){var n=!ue||(t&ce)!==0,a=(t&fe)!==0,u=(t&pe)!==0,i=s,f=!0,o=()=>(f&&(f=!1,i=u?B(s):s),i);let l;if(a){var Y=O in r||N in r;l=m(r,e)?.set??(Y&&e in r?c=>r[e]=c:void 0)}var p,y=!1;a?[p,y]=he(()=>r[e]):p=r[e],p===void 0&&s!==void 0&&(p=o(),l&&(n&&re(),l(p)));var d;if(n?d=()=>{var c=r[e];return c===void 0?o():(f=!0,c)}:d=()=>{var c=r[e];return c!==void 0&&(i=void 0),c===void 0?i:c},n&&(t&K)===0)return d;if(l){var j=r.$$legacy;return(function(c,v){return arguments.length>0?((!n||!v||j||y)&&l(v?d():c),c):d()})}var S=!1,h=((t&oe)!==0?le:de)(()=>(S=!1,d()));a&&w(h);var F=P;return(function(c,v){if(arguments.length>0){const E=v?w(h):n&&a?se(c):c;return te(h,E),S=!0,i!==void 0&&(i=E),c}return ne&&S||(F.f&ie)!==0?h.v:w(h)})}export{_e as B,xe as b,ge as i,Oe as l,Pe as p,me as r,ye as s};
|