@gguf/pigbot 0.0.1 → 0.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1302) hide show
  1. package/CHANGELOG.md +6 -1054
  2. package/README-header.png +0 -0
  3. package/README.md +1 -1
  4. package/assets/chrome-extension/README.md +5 -5
  5. package/assets/chrome-extension/background.js +5 -5
  6. package/assets/chrome-extension/manifest.json +3 -3
  7. package/assets/chrome-extension/options.html +5 -6
  8. package/assets/chrome-extension/options.js +1 -1
  9. package/dist/acp/client.js +5 -5
  10. package/dist/acp/server.js +3 -3
  11. package/dist/acp/types.js +2 -2
  12. package/dist/agents/agent-paths.js +6 -6
  13. package/dist/agents/anthropic-payload-log.js +2 -2
  14. package/dist/agents/auth-health.js +2 -6
  15. package/dist/agents/auth-profiles/doctor.js +1 -1
  16. package/dist/agents/auth-profiles/external-cli-sync.js +5 -150
  17. package/dist/agents/auth-profiles/oauth.js +26 -7
  18. package/dist/agents/auth-profiles/paths.js +3 -3
  19. package/dist/agents/auth-profiles/store.js +5 -13
  20. package/dist/agents/bash-tools.exec.js +77 -26
  21. package/dist/agents/bash-tools.shared.js +8 -1
  22. package/dist/agents/cache-trace.js +5 -5
  23. package/dist/agents/cli-backends.js +8 -0
  24. package/dist/agents/cli-runner/helpers.js +3 -3
  25. package/dist/agents/cli-runner.js +3 -3
  26. package/dist/agents/compaction.js +3 -0
  27. package/dist/agents/context.js +4 -4
  28. package/dist/agents/docs-path.js +3 -3
  29. package/dist/agents/identity.js +1 -1
  30. package/dist/agents/live-auth-keys.js +2 -2
  31. package/dist/agents/memory-search.js +7 -2
  32. package/dist/agents/minimax-vlm.js +1 -1
  33. package/dist/agents/model-auth.js +1 -1
  34. package/dist/agents/model-catalog.js +23 -5
  35. package/dist/agents/model-fallback.js +22 -0
  36. package/dist/agents/model-selection.js +9 -2
  37. package/dist/agents/models-config.js +3 -3
  38. package/dist/agents/models-config.providers.js +4 -4
  39. package/dist/agents/{pigbot-tools.js → moltbot-tools.js} +7 -6
  40. package/dist/agents/pi-embedded-helpers/errors.js +23 -1
  41. package/dist/agents/pi-embedded-helpers/openai.js +1 -1
  42. package/dist/agents/pi-embedded-runner/cache-ttl.js +1 -1
  43. package/dist/agents/pi-embedded-runner/compact.js +8 -8
  44. package/dist/agents/pi-embedded-runner/extensions.js +5 -0
  45. package/dist/agents/pi-embedded-runner/model.js +9 -3
  46. package/dist/agents/pi-embedded-runner/run/attempt.js +10 -6
  47. package/dist/agents/pi-embedded-runner/run.js +5 -5
  48. package/dist/agents/pi-embedded-runner/sandbox-info.js +1 -4
  49. package/dist/agents/pi-embedded-runner/session-manager-cache.js +1 -1
  50. package/dist/agents/pi-embedded-runner/utils.js +1 -1
  51. package/dist/agents/pi-embedded-subscribe.raw-stream.js +2 -2
  52. package/dist/agents/pi-embedded-utils.js +7 -1
  53. package/dist/agents/pi-extensions/compaction-safeguard-runtime.js +20 -0
  54. package/dist/agents/pi-extensions/compaction-safeguard.js +32 -3
  55. package/dist/agents/pi-tools.js +26 -15
  56. package/dist/agents/pi-tools.policy.js +34 -1
  57. package/dist/agents/pi-tools.read.js +2 -2
  58. package/dist/agents/sandbox/browser.js +10 -12
  59. package/dist/agents/sandbox/config.js +0 -12
  60. package/dist/agents/sandbox/constants.js +8 -8
  61. package/dist/agents/sandbox/context.js +3 -3
  62. package/dist/agents/sandbox/docker.js +8 -8
  63. package/dist/agents/sandbox/runtime-status.js +1 -1
  64. package/dist/agents/session-transcript-repair.js +1 -1
  65. package/dist/agents/session-write-lock.js +68 -0
  66. package/dist/agents/skills/bundled-dir.js +1 -1
  67. package/dist/agents/skills/config.js +9 -8
  68. package/dist/agents/skills/env-overrides.js +1 -1
  69. package/dist/agents/skills/frontmatter.js +15 -14
  70. package/dist/agents/skills/workspace.js +7 -7
  71. package/dist/agents/skills-install.js +1 -1
  72. package/dist/agents/skills-status.js +12 -12
  73. package/dist/agents/subagent-registry.store.js +2 -2
  74. package/dist/agents/system-prompt.js +21 -32
  75. package/dist/agents/tool-images.js +1 -1
  76. package/dist/agents/tool-policy.js +8 -2
  77. package/dist/agents/tools/agents-list-tool.js +3 -1
  78. package/dist/agents/tools/browser-tool.js +19 -79
  79. package/dist/agents/tools/browser-tool.schema.js +1 -2
  80. package/dist/agents/tools/cron-tool.js +44 -1
  81. package/dist/agents/tools/discord-actions-guild.js +5 -1
  82. package/dist/agents/tools/image-tool.js +2 -2
  83. package/dist/agents/tools/message-tool.js +13 -1
  84. package/dist/agents/tools/sessions-send-helpers.js +17 -2
  85. package/dist/agents/tools/sessions-spawn-tool.js +1 -1
  86. package/dist/agents/tools/telegram-actions.js +95 -1
  87. package/dist/agents/tools/web-fetch.js +123 -103
  88. package/dist/agents/tools/web-search.js +7 -7
  89. package/dist/agents/workspace.js +37 -1
  90. package/dist/auto-reply/chunk.js +71 -26
  91. package/dist/auto-reply/commands-registry.data.js +73 -22
  92. package/dist/auto-reply/commands-registry.js +14 -11
  93. package/dist/auto-reply/heartbeat.js +3 -0
  94. package/dist/auto-reply/model.js +1 -1
  95. package/dist/auto-reply/reply/agent-runner-execution.js +21 -3
  96. package/dist/auto-reply/reply/agent-runner-memory.js +5 -0
  97. package/dist/auto-reply/reply/bash-command.js +2 -2
  98. package/dist/auto-reply/reply/block-streaming.js +8 -15
  99. package/dist/auto-reply/reply/commands-context-report.js +2 -2
  100. package/dist/auto-reply/reply/commands-info.js +50 -5
  101. package/dist/auto-reply/reply/commands-plugin.js +4 -2
  102. package/dist/auto-reply/reply/commands-session.js +4 -4
  103. package/dist/auto-reply/reply/commands-tts.js +61 -63
  104. package/dist/auto-reply/reply/directive-handling.shared.js +1 -1
  105. package/dist/auto-reply/reply/directives.js +12 -1
  106. package/dist/auto-reply/reply/dispatch-from-config.js +68 -22
  107. package/dist/auto-reply/reply/followup-runner.js +5 -0
  108. package/dist/auto-reply/reply/get-reply-inline-actions.js +2 -2
  109. package/dist/auto-reply/reply/get-reply-run.js +4 -0
  110. package/dist/auto-reply/reply/get-reply.js +1 -1
  111. package/dist/auto-reply/reply/groups.js +1 -1
  112. package/dist/auto-reply/reply/history.js +23 -0
  113. package/dist/auto-reply/reply/line-directives.js +294 -0
  114. package/dist/auto-reply/reply/normalize-reply.js +13 -5
  115. package/dist/auto-reply/reply/reply-elevated.js +1 -1
  116. package/dist/auto-reply/reply/reply-payloads.js +2 -1
  117. package/dist/auto-reply/reply/route-reply.js +1 -1
  118. package/dist/auto-reply/reply/session-updates.js +6 -1
  119. package/dist/auto-reply/reply/stage-sandbox-media.js +1 -1
  120. package/dist/auto-reply/status.js +144 -42
  121. package/dist/auto-reply/thinking.js +13 -0
  122. package/dist/browser/bridge-server.js +1 -3
  123. package/dist/browser/client-actions-core.js +13 -7
  124. package/dist/browser/client-actions-observe.js +14 -8
  125. package/dist/browser/client-actions-state.js +21 -15
  126. package/dist/browser/client-fetch.js +74 -61
  127. package/dist/browser/client.js +19 -21
  128. package/dist/browser/config.js +13 -26
  129. package/dist/browser/constants.js +1 -1
  130. package/dist/browser/control-service.js +72 -0
  131. package/dist/browser/extension-relay.js +3 -3
  132. package/dist/browser/pw-session.js +41 -4
  133. package/dist/browser/pw-tools-core.downloads.js +1 -1
  134. package/dist/browser/pw-tools-core.interactions.js +5 -5
  135. package/dist/browser/pw-tools-core.responses.js +1 -1
  136. package/dist/browser/routes/agent.act.js +13 -0
  137. package/dist/browser/routes/agent.debug.js +1 -1
  138. package/dist/browser/routes/basic.js +0 -1
  139. package/dist/browser/routes/dispatcher.js +86 -0
  140. package/dist/browser/server-context.js +3 -3
  141. package/dist/browser/server.js +7 -9
  142. package/dist/build-info.json +2 -2
  143. package/dist/canvas-host/a2ui/.bundle.hash +1 -0
  144. package/dist/canvas-host/a2ui/a2ui.bundle.js +1620 -1618
  145. package/dist/canvas-host/a2ui/index.html +28 -28
  146. package/dist/canvas-host/a2ui.js +27 -21
  147. package/dist/canvas-host/server.js +67 -33
  148. package/dist/channels/plugins/actions/discord/handle-action.guild-admin.js +5 -1
  149. package/dist/channels/plugins/actions/telegram.js +62 -7
  150. package/dist/channels/plugins/catalog.js +7 -5
  151. package/dist/channels/plugins/group-mentions.js +48 -1
  152. package/dist/channels/plugins/helpers.js +2 -2
  153. package/dist/channels/plugins/message-action-names.js +1 -0
  154. package/dist/channels/plugins/normalize/imessage.js +36 -0
  155. package/dist/channels/plugins/onboarding/imessage.js +1 -1
  156. package/dist/channels/plugins/onboarding/signal.js +2 -2
  157. package/dist/channels/plugins/onboarding/slack.js +4 -4
  158. package/dist/channels/plugins/onboarding/telegram.js +17 -9
  159. package/dist/channels/plugins/onboarding/whatsapp.js +4 -4
  160. package/dist/channels/plugins/outbound/telegram.js +40 -0
  161. package/dist/channels/plugins/pairing-message.js +1 -1
  162. package/dist/channels/plugins/status-issues/bluebubbles.js +1 -1
  163. package/dist/channels/plugins/status-issues/whatsapp.js +2 -2
  164. package/dist/channels/registry.js +1 -1
  165. package/dist/cli/acp-cli.js +2 -2
  166. package/dist/cli/argv.js +14 -7
  167. package/dist/cli/banner.js +3 -1
  168. package/dist/cli/browser-cli-actions-input/register.element.js +72 -44
  169. package/dist/cli/browser-cli-actions-input/register.files-downloads.js +55 -35
  170. package/dist/cli/browser-cli-actions-input/register.form-wait-eval.js +41 -28
  171. package/dist/cli/browser-cli-actions-input/register.navigation.js +23 -14
  172. package/dist/cli/browser-cli-actions-input/shared.js +10 -3
  173. package/dist/cli/browser-cli-actions-observe.js +29 -21
  174. package/dist/cli/browser-cli-debug.js +49 -35
  175. package/dist/cli/browser-cli-examples.js +29 -29
  176. package/dist/cli/browser-cli-extension.js +8 -8
  177. package/dist/cli/browser-cli-inspect.js +23 -17
  178. package/dist/cli/browser-cli-manage.js +106 -56
  179. package/dist/cli/browser-cli-shared.js +34 -1
  180. package/dist/cli/browser-cli-state.cookies-storage.js +53 -39
  181. package/dist/cli/browser-cli-state.js +90 -64
  182. package/dist/cli/browser-cli.js +4 -5
  183. package/dist/cli/channel-options.js +1 -1
  184. package/dist/cli/channels-cli.js +1 -1
  185. package/dist/cli/cli-name.js +26 -0
  186. package/dist/cli/command-format.js +12 -8
  187. package/dist/cli/config-cli.js +2 -2
  188. package/dist/cli/cron-cli/register.js +1 -1
  189. package/dist/cli/daemon-cli/install.js +3 -2
  190. package/dist/cli/daemon-cli/register.js +1 -1
  191. package/dist/cli/daemon-cli/shared.js +13 -11
  192. package/dist/cli/daemon-cli/status.gather.js +2 -2
  193. package/dist/cli/daemon-cli/status.print.js +8 -8
  194. package/dist/cli/directory-cli.js +1 -1
  195. package/dist/cli/dns-cli.js +7 -7
  196. package/dist/cli/docs-cli.js +2 -2
  197. package/dist/cli/exec-approvals-cli.js +2 -2
  198. package/dist/cli/gateway-cli/dev.js +5 -5
  199. package/dist/cli/gateway-cli/register.js +1 -1
  200. package/dist/cli/gateway-cli/run.js +19 -16
  201. package/dist/cli/gateway-cli/shared.js +5 -5
  202. package/dist/cli/hooks-cli.js +3 -3
  203. package/dist/cli/logs-cli.js +3 -3
  204. package/dist/cli/memory-cli.js +1 -1
  205. package/dist/cli/models-cli.js +2 -2
  206. package/dist/cli/node-cli/daemon.js +3 -3
  207. package/dist/cli/node-cli/register.js +1 -1
  208. package/dist/cli/nodes-camera.js +3 -1
  209. package/dist/cli/nodes-canvas.js +3 -1
  210. package/dist/cli/nodes-cli/register.canvas.js +1 -1
  211. package/dist/cli/nodes-cli/register.js +1 -1
  212. package/dist/cli/nodes-screen.js +1 -1
  213. package/dist/cli/pairing-cli.js +3 -3
  214. package/dist/cli/plugin-registry.js +2 -2
  215. package/dist/cli/plugins-cli.js +3 -3
  216. package/dist/cli/profile.js +9 -9
  217. package/dist/cli/program/config-guard.js +1 -1
  218. package/dist/cli/program/help.js +15 -16
  219. package/dist/cli/program/message/register.send.js +2 -1
  220. package/dist/cli/program/preaction.js +5 -3
  221. package/dist/cli/program/register.agent.js +12 -12
  222. package/dist/cli/program/register.configure.js +1 -1
  223. package/dist/cli/program/register.maintenance.js +4 -4
  224. package/dist/cli/program/register.message.js +5 -5
  225. package/dist/cli/program/register.onboard.js +5 -3
  226. package/dist/cli/program/register.setup.js +2 -2
  227. package/dist/cli/program/register.status-health-sessions.js +13 -13
  228. package/dist/cli/program/register.subclis.js +2 -2
  229. package/dist/cli/route.js +1 -1
  230. package/dist/cli/run-main.js +11 -4
  231. package/dist/cli/sandbox-cli.js +19 -19
  232. package/dist/cli/security-cli.js +18 -8
  233. package/dist/cli/skills-cli.js +3 -3
  234. package/dist/cli/system-cli.js +1 -1
  235. package/dist/cli/tagline.js +2 -2
  236. package/dist/cli/tui-cli.js +1 -1
  237. package/dist/cli/update-cli.js +64 -48
  238. package/dist/cli/webhooks-cli.js +6 -6
  239. package/dist/commands/agent-via-gateway.js +1 -1
  240. package/dist/commands/agent.js +2 -1
  241. package/dist/commands/agents.command-shared.js +1 -1
  242. package/dist/commands/agents.commands.add.js +2 -3
  243. package/dist/commands/agents.commands.list.js +1 -1
  244. package/dist/commands/auth-choice-options.js +4 -54
  245. package/dist/commands/auth-choice.apply.anthropic.js +6 -109
  246. package/dist/commands/auth-choice.apply.openai.js +1 -33
  247. package/dist/commands/auth-choice.apply.plugin-provider.js +2 -2
  248. package/dist/commands/channels/list.js +2 -2
  249. package/dist/commands/channels/shared.js +1 -1
  250. package/dist/commands/channels/status.js +1 -1
  251. package/dist/commands/chutes-oauth.js +1 -1
  252. package/dist/commands/configure.channels.js +4 -4
  253. package/dist/commands/configure.daemon.js +10 -2
  254. package/dist/commands/configure.gateway-auth.js +1 -8
  255. package/dist/commands/configure.gateway.js +1 -10
  256. package/dist/commands/configure.wizard.js +21 -21
  257. package/dist/commands/daemon-install-helpers.js +10 -3
  258. package/dist/commands/dashboard.js +2 -2
  259. package/dist/commands/docs.js +5 -5
  260. package/dist/commands/doctor-auth.js +122 -3
  261. package/dist/commands/doctor-config-flow.js +7 -7
  262. package/dist/commands/doctor-format.js +5 -5
  263. package/dist/commands/doctor-gateway-daemon-flow.js +5 -4
  264. package/dist/commands/doctor-gateway-services.js +7 -5
  265. package/dist/commands/doctor-platform-notes.js +7 -7
  266. package/dist/commands/doctor-security.js +48 -1
  267. package/dist/commands/doctor-state-integrity.js +3 -3
  268. package/dist/commands/doctor-ui.js +2 -2
  269. package/dist/commands/doctor-update.js +5 -5
  270. package/dist/commands/doctor-workspace-status.js +2 -2
  271. package/dist/commands/doctor-workspace.js +4 -4
  272. package/dist/commands/doctor.js +13 -12
  273. package/dist/commands/gateway-status/helpers.js +2 -2
  274. package/dist/commands/gateway-status.js +2 -2
  275. package/dist/commands/health.js +2 -2
  276. package/dist/commands/models/auth.js +23 -22
  277. package/dist/commands/models/list.probe.js +2 -2
  278. package/dist/commands/models/list.registry.js +4 -4
  279. package/dist/commands/models/list.status-command.js +8 -9
  280. package/dist/commands/node-daemon-install-helpers.js +1 -1
  281. package/dist/commands/onboard-auth.credentials.js +2 -2
  282. package/dist/commands/onboard-channels.js +3 -3
  283. package/dist/commands/onboard-helpers.js +4 -4
  284. package/dist/commands/onboard-hooks.js +4 -4
  285. package/dist/commands/onboard-non-interactive/local/auth-choice.js +38 -34
  286. package/dist/commands/onboard-non-interactive/local/daemon-install.js +1 -0
  287. package/dist/commands/onboard-non-interactive/local/gateway-config.js +7 -4
  288. package/dist/commands/onboard-non-interactive/local.js +1 -1
  289. package/dist/commands/onboard-non-interactive/remote.js +1 -1
  290. package/dist/commands/onboard-non-interactive.js +1 -1
  291. package/dist/commands/onboard-remote.js +2 -2
  292. package/dist/commands/onboard-skills.js +2 -2
  293. package/dist/commands/onboard.js +25 -4
  294. package/dist/commands/onboarding/plugin-install.js +2 -2
  295. package/dist/commands/reset.js +3 -3
  296. package/dist/commands/sandbox-display.js +1 -1
  297. package/dist/commands/sandbox-explain.js +2 -2
  298. package/dist/commands/setup.js +2 -2
  299. package/dist/commands/signal-install.js +2 -2
  300. package/dist/commands/status-all/diagnosis.js +1 -1
  301. package/dist/commands/status-all/report-lines.js +1 -1
  302. package/dist/commands/status-all.js +5 -5
  303. package/dist/commands/status.command.js +9 -9
  304. package/dist/commands/status.gateway-probe.js +2 -2
  305. package/dist/commands/status.scan.js +2 -2
  306. package/dist/commands/status.update.js +3 -3
  307. package/dist/commands/uninstall.js +4 -4
  308. package/dist/compat/legacy-names.js +6 -0
  309. package/dist/config/config.js +1 -1
  310. package/dist/config/env-vars.js +21 -0
  311. package/dist/config/group-policy.js +69 -0
  312. package/dist/config/io.js +24 -28
  313. package/dist/config/legacy.migrations.part-3.js +3 -0
  314. package/dist/config/logging.js +3 -3
  315. package/dist/config/paths.js +57 -17
  316. package/dist/config/schema.js +26 -12
  317. package/dist/config/sessions/store.js +1 -1
  318. package/dist/config/sessions/transcript.js +1 -1
  319. package/dist/config/types.clawdbot.js +1 -0
  320. package/dist/config/types.js +1 -1
  321. package/dist/config/validation.js +2 -2
  322. package/dist/config/version.js +4 -4
  323. package/dist/config/zod-schema.agent-defaults.js +1 -0
  324. package/dist/config/zod-schema.agent-runtime.js +39 -7
  325. package/dist/config/zod-schema.hooks.js +2 -0
  326. package/dist/config/zod-schema.js +10 -3
  327. package/dist/config/zod-schema.providers-core.js +24 -0
  328. package/dist/config/zod-schema.providers-whatsapp.js +3 -0
  329. package/dist/control-ui/assets/index-BAFzd9IE.css +1 -0
  330. package/dist/control-ui/assets/index-CxUFDXFX.js +3162 -0
  331. package/dist/control-ui/assets/index-CxUFDXFX.js.map +1 -0
  332. package/dist/control-ui/index.html +4 -4
  333. package/dist/cron/isolated-agent/run.js +38 -3
  334. package/dist/daemon/constants.js +26 -16
  335. package/dist/daemon/inspect.js +16 -15
  336. package/dist/daemon/launchd.js +8 -8
  337. package/dist/daemon/node-service.js +14 -14
  338. package/dist/daemon/paths.js +3 -3
  339. package/dist/daemon/program-args.js +1 -1
  340. package/dist/daemon/schtasks.js +6 -6
  341. package/dist/daemon/service-env.js +21 -21
  342. package/dist/daemon/systemd-hints.js +1 -1
  343. package/dist/daemon/systemd-unit.js +1 -1
  344. package/dist/daemon/systemd.js +6 -6
  345. package/dist/discord/monitor/listeners.js +25 -1
  346. package/dist/discord/monitor/native-command.js +7 -5
  347. package/dist/discord/monitor/presence-cache.js +38 -0
  348. package/dist/discord/monitor/provider.js +21 -7
  349. package/dist/entry.js +7 -7
  350. package/dist/gateway/auth.js +55 -22
  351. package/dist/gateway/call.js +2 -2
  352. package/dist/gateway/control-ui.js +4 -4
  353. package/dist/gateway/hooks-mapping.js +18 -4
  354. package/dist/gateway/hooks.js +5 -7
  355. package/dist/gateway/http-utils.js +3 -5
  356. package/dist/gateway/net.js +1 -1
  357. package/dist/gateway/openai-http.js +3 -3
  358. package/dist/gateway/openresponses-http.js +4 -4
  359. package/dist/gateway/protocol/client-info.js +5 -5
  360. package/dist/gateway/protocol/schema/logs-chat.js +1 -1
  361. package/dist/gateway/server/__tests__/test-utils.js +2 -0
  362. package/dist/gateway/server/health-state.js +3 -3
  363. package/dist/gateway/server/hooks.js +1 -0
  364. package/dist/gateway/server/plugins-http.js +23 -2
  365. package/dist/gateway/server/ws-connection/message-handler.js +66 -19
  366. package/dist/gateway/server-browser.js +16 -5
  367. package/dist/gateway/server-chat.js +28 -2
  368. package/dist/gateway/server-constants.js +2 -2
  369. package/dist/gateway/server-cron.js +1 -1
  370. package/dist/gateway/server-discovery-runtime.js +25 -17
  371. package/dist/gateway/server-discovery.js +7 -7
  372. package/dist/gateway/server-http.js +13 -7
  373. package/dist/gateway/server-methods/agent.js +2 -0
  374. package/dist/gateway/server-methods/browser.js +204 -0
  375. package/dist/gateway/server-methods/chat.js +5 -0
  376. package/dist/gateway/server-methods/config.js +8 -8
  377. package/dist/gateway/server-methods/logs.js +1 -1
  378. package/dist/gateway/server-methods/skills.js +3 -3
  379. package/dist/gateway/server-methods/update.js +2 -2
  380. package/dist/gateway/server-methods-list.js +1 -0
  381. package/dist/gateway/server-methods.js +3 -0
  382. package/dist/gateway/server-plugins.js +2 -2
  383. package/dist/gateway/server-reload-handlers.js +5 -5
  384. package/dist/gateway/server-restart-sentinel.js +10 -5
  385. package/dist/gateway/server-runtime-config.js +7 -4
  386. package/dist/gateway/server-startup.js +5 -5
  387. package/dist/gateway/server.impl.js +17 -7
  388. package/dist/gateway/session-utils.fs.js +1 -1
  389. package/dist/gateway/session-utils.js +31 -11
  390. package/dist/gateway/test-helpers.mocks.js +8 -7
  391. package/dist/gateway/test-helpers.server.js +51 -32
  392. package/dist/gateway/tools-invoke-http.js +15 -8
  393. package/dist/hooks/bundled/boot-md/HOOK.md +3 -3
  394. package/dist/hooks/bundled/command-logger/HOOK.md +12 -12
  395. package/dist/hooks/bundled/command-logger/handler.js +1 -1
  396. package/dist/hooks/bundled/session-memory/HOOK.md +4 -4
  397. package/dist/hooks/bundled/session-memory/handler.js +2 -2
  398. package/dist/hooks/bundled/soul-evil/HOOK.md +5 -5
  399. package/dist/hooks/bundled-dir.js +2 -2
  400. package/dist/hooks/config.js +8 -7
  401. package/dist/hooks/frontmatter.js +16 -15
  402. package/dist/hooks/gmail-ops.js +4 -4
  403. package/dist/hooks/gmail-watcher.js +1 -1
  404. package/dist/hooks/hooks-status.js +13 -13
  405. package/dist/hooks/install.js +8 -7
  406. package/dist/hooks/internal-hooks.js +1 -1
  407. package/dist/hooks/llm-slug-generator.js +1 -1
  408. package/dist/hooks/loader.js +3 -3
  409. package/dist/hooks/plugin-hooks.js +8 -8
  410. package/dist/hooks/workspace.js +10 -9
  411. package/dist/imessage/monitor/monitor-provider.js +2 -2
  412. package/dist/imessage/targets.js +19 -0
  413. package/dist/index.js +4 -4
  414. package/dist/infra/agent-events.js +3 -0
  415. package/dist/infra/bonjour-discovery.js +9 -9
  416. package/dist/infra/bonjour.js +20 -13
  417. package/dist/infra/device-identity.js +1 -1
  418. package/dist/infra/diagnostic-flags.js +66 -0
  419. package/dist/infra/dotenv.js +1 -1
  420. package/dist/infra/env.js +22 -0
  421. package/dist/infra/exec-approvals.js +2 -2
  422. package/dist/infra/fs-safe.js +76 -0
  423. package/dist/infra/gateway-lock.js +5 -4
  424. package/dist/infra/heartbeat-visibility.js +14 -0
  425. package/dist/infra/heartbeat-wake.js +2 -2
  426. package/dist/infra/machine-name.js +1 -1
  427. package/dist/infra/{pigbot-root.js → moltbot-root.js} +3 -2
  428. package/dist/infra/net/ssrf.js +77 -1
  429. package/dist/infra/node-shell.js +1 -1
  430. package/dist/infra/outbound/deliver.js +41 -18
  431. package/dist/infra/outbound/message-action-runner.js +24 -3
  432. package/dist/infra/outbound/message-action-spec.js +1 -0
  433. package/dist/infra/outbound/message.js +1 -0
  434. package/dist/infra/outbound/outbound-policy.js +4 -1
  435. package/dist/infra/outbound/outbound-send-service.js +10 -0
  436. package/dist/infra/outbound/payloads.js +15 -5
  437. package/dist/infra/outbound/target-resolver.js +53 -14
  438. package/dist/infra/outbound/targets.js +1 -1
  439. package/dist/infra/path-env.js +9 -9
  440. package/dist/infra/ports-format.js +2 -2
  441. package/dist/infra/ports.js +2 -2
  442. package/dist/infra/provider-usage.auth.js +2 -4
  443. package/dist/infra/provider-usage.fetch.claude.js +1 -1
  444. package/dist/infra/provider-usage.fetch.minimax.js +1 -1
  445. package/dist/infra/restart-sentinel.js +1 -1
  446. package/dist/infra/restart.js +4 -4
  447. package/dist/infra/retry-policy.js +4 -1
  448. package/dist/infra/runtime-guard.js +2 -2
  449. package/dist/infra/shell-env.js +4 -4
  450. package/dist/infra/skills-remote.js +3 -3
  451. package/dist/infra/state-migrations.js +1 -1
  452. package/dist/infra/system-presence.js +1 -1
  453. package/dist/infra/tailscale.js +63 -1
  454. package/dist/infra/tls/gateway.js +1 -1
  455. package/dist/infra/unhandled-rejections.js +89 -2
  456. package/dist/infra/update-check.js +2 -4
  457. package/dist/infra/update-global.js +5 -5
  458. package/dist/infra/update-runner.js +32 -8
  459. package/dist/infra/update-startup.js +3 -3
  460. package/dist/infra/warnings.js +1 -1
  461. package/dist/infra/widearea-dns.js +10 -10
  462. package/dist/line/accounts.js +130 -0
  463. package/dist/line/auto-reply-delivery.js +102 -0
  464. package/dist/line/bot-access.js +38 -0
  465. package/dist/line/bot-handlers.js +258 -0
  466. package/dist/line/bot-message-context.js +374 -0
  467. package/dist/line/bot.js +48 -0
  468. package/dist/line/config-schema.js +47 -0
  469. package/dist/line/download.js +95 -0
  470. package/dist/line/flex-templates.js +1264 -0
  471. package/dist/line/http-registry.js +27 -0
  472. package/dist/line/index.js +19 -0
  473. package/dist/line/markdown-to-line.js +346 -0
  474. package/dist/line/monitor.js +266 -0
  475. package/dist/line/probe.js +37 -0
  476. package/dist/line/reply-chunks.js +53 -0
  477. package/dist/line/rich-menu.js +320 -0
  478. package/dist/line/send.js +451 -0
  479. package/dist/line/signature.js +11 -0
  480. package/dist/line/template-messages.js +258 -0
  481. package/dist/line/types.js +1 -0
  482. package/dist/line/webhook.js +71 -0
  483. package/dist/link-understanding/apply.js +22 -0
  484. package/dist/link-understanding/defaults.js +2 -0
  485. package/dist/link-understanding/detect.js +49 -0
  486. package/dist/link-understanding/format.js +10 -0
  487. package/dist/link-understanding/index.js +4 -0
  488. package/dist/link-understanding/runner.js +99 -0
  489. package/dist/logging/logger.js +4 -4
  490. package/dist/macos/gateway-daemon.js +7 -7
  491. package/dist/macos/relay-smoke.js +1 -1
  492. package/dist/macos/relay.js +6 -6
  493. package/dist/media/host.js +1 -1
  494. package/dist/media/image-ops.js +3 -3
  495. package/dist/media/input-files.js +40 -32
  496. package/dist/media/server.js +39 -15
  497. package/dist/media/store.js +72 -52
  498. package/dist/media-understanding/attachments.js +1 -1
  499. package/dist/media-understanding/providers/image.js +2 -2
  500. package/dist/media-understanding/runner.js +69 -1
  501. package/dist/memory/batch-gemini.js +2 -2
  502. package/dist/memory/batch-openai.js +1 -1
  503. package/dist/memory/embeddings-gemini.js +1 -1
  504. package/dist/memory/embeddings.js +1 -1
  505. package/dist/node-host/runner.js +64 -60
  506. package/dist/pairing/pairing-messages.js +2 -2
  507. package/dist/plugin-sdk/index.js +12 -2
  508. package/dist/plugins/bundled-dir.js +1 -1
  509. package/dist/plugins/cli.js +2 -2
  510. package/dist/plugins/commands.js +1 -1
  511. package/dist/plugins/discovery.js +6 -5
  512. package/dist/plugins/http-path.js +10 -0
  513. package/dist/plugins/http-registry.js +31 -0
  514. package/dist/plugins/install.js +8 -7
  515. package/dist/plugins/loader.js +11 -4
  516. package/dist/plugins/manifest-registry.js +4 -4
  517. package/dist/plugins/manifest.js +16 -1
  518. package/dist/plugins/providers.js +2 -2
  519. package/dist/plugins/registry.js +36 -5
  520. package/dist/plugins/runtime/index.js +26 -0
  521. package/dist/plugins/runtime.js +2 -1
  522. package/dist/plugins/services.js +3 -3
  523. package/dist/plugins/status.js +2 -2
  524. package/dist/plugins/tools.js +2 -2
  525. package/dist/plugins/update.js +3 -3
  526. package/dist/process/exec.js +11 -7
  527. package/dist/process/spawn-utils.js +95 -0
  528. package/dist/providers/qwen-portal-oauth.js +1 -1
  529. package/dist/routing/session-key.js +17 -12
  530. package/dist/security/audit-extra.js +120 -70
  531. package/dist/security/audit-fs.js +78 -0
  532. package/dist/security/audit.js +145 -87
  533. package/dist/security/external-content.js +143 -0
  534. package/dist/security/fix.js +93 -8
  535. package/dist/security/windows-acl.js +162 -0
  536. package/dist/shared/text/reasoning-tags.js +48 -0
  537. package/dist/slack/monitor/media.js +32 -4
  538. package/dist/slack/monitor/message-handler/dispatch.js +2 -1
  539. package/dist/slack/monitor/slash.js +3 -3
  540. package/dist/slack/monitor.test-helpers.js +1 -1
  541. package/dist/telegram/accounts.js +1 -1
  542. package/dist/telegram/api-logging.js +24 -0
  543. package/dist/telegram/bot/delivery.js +218 -28
  544. package/dist/telegram/bot/helpers.js +29 -19
  545. package/dist/telegram/bot-handlers.js +70 -8
  546. package/dist/telegram/bot-message-context.js +83 -22
  547. package/dist/telegram/bot-message-dispatch.js +69 -0
  548. package/dist/telegram/bot-native-commands.js +245 -94
  549. package/dist/telegram/bot.js +18 -2
  550. package/dist/telegram/fetch.js +25 -1
  551. package/dist/telegram/monitor.js +11 -3
  552. package/dist/telegram/network-config.js +23 -0
  553. package/dist/telegram/network-errors.js +103 -0
  554. package/dist/telegram/send.js +229 -41
  555. package/dist/telegram/sticker-cache.js +202 -0
  556. package/dist/telegram/webhook-set.js +13 -6
  557. package/dist/telegram/webhook.js +8 -3
  558. package/dist/terminal/links.js +1 -1
  559. package/dist/tts/tts.js +128 -25
  560. package/dist/tui/components/filterable-select-list.js +1 -1
  561. package/dist/tui/components/searchable-select-list.js +2 -1
  562. package/dist/tui/gateway-chat.js +3 -3
  563. package/dist/tui/tui.js +1 -1
  564. package/dist/utils.js +3 -3
  565. package/dist/version.js +3 -3
  566. package/dist/web/active-listener.js +1 -1
  567. package/dist/web/auth-store.js +1 -1
  568. package/dist/web/auto-reply/monitor/process-message.js +1 -1
  569. package/dist/web/auto-reply/monitor.js +1 -1
  570. package/dist/web/login.js +1 -1
  571. package/dist/web/session.js +2 -2
  572. package/dist/wizard/onboarding.finalize.js +22 -21
  573. package/dist/wizard/onboarding.gateway-config.js +1 -11
  574. package/dist/wizard/onboarding.js +24 -13
  575. package/docs/CNAME +1 -1
  576. package/docs/_config.yml +2 -2
  577. package/docs/_layouts/default.html +9 -9
  578. package/docs/assets/terminal.css +3 -0
  579. package/docs/assets/theme.js +1 -1
  580. package/docs/automation/auth-monitoring.md +7 -7
  581. package/docs/automation/cron-jobs.md +19 -19
  582. package/docs/automation/cron-vs-heartbeat.md +8 -8
  583. package/docs/automation/gmail-pubsub.md +27 -25
  584. package/docs/automation/poll.md +7 -7
  585. package/docs/automation/webhook.md +13 -8
  586. package/docs/bedrock.md +10 -10
  587. package/docs/brave-search.md +1 -1
  588. package/docs/broadcast-groups.md +4 -4
  589. package/docs/channels/bluebubbles.md +14 -12
  590. package/docs/channels/discord.md +23 -18
  591. package/docs/channels/googlechat.md +16 -16
  592. package/docs/channels/grammy.md +1 -1
  593. package/docs/channels/imessage.md +14 -14
  594. package/docs/channels/index.md +6 -4
  595. package/docs/channels/line.md +183 -0
  596. package/docs/channels/location.md +1 -1
  597. package/docs/channels/matrix.md +16 -16
  598. package/docs/channels/mattermost.md +8 -8
  599. package/docs/channels/msteams.md +31 -27
  600. package/docs/channels/nextcloud-talk.md +8 -8
  601. package/docs/channels/nostr.md +9 -9
  602. package/docs/channels/signal.md +11 -11
  603. package/docs/channels/slack.md +31 -29
  604. package/docs/channels/telegram.md +152 -22
  605. package/docs/channels/tlon.md +5 -5
  606. package/docs/channels/troubleshooting.md +2 -2
  607. package/docs/channels/twitch.md +366 -0
  608. package/docs/channels/whatsapp.md +26 -26
  609. package/docs/channels/zalo.md +8 -8
  610. package/docs/channels/zalouser.md +12 -12
  611. package/docs/cli/acp.md +24 -24
  612. package/docs/cli/agent.md +6 -6
  613. package/docs/cli/agents.md +9 -9
  614. package/docs/cli/approvals.md +14 -14
  615. package/docs/cli/browser.md +33 -35
  616. package/docs/cli/channels.md +21 -21
  617. package/docs/cli/config.md +15 -15
  618. package/docs/cli/configure.md +6 -6
  619. package/docs/cli/cron.md +5 -5
  620. package/docs/cli/dashboard.md +4 -4
  621. package/docs/cli/devices.md +13 -13
  622. package/docs/cli/directory.md +12 -12
  623. package/docs/cli/dns.md +5 -5
  624. package/docs/cli/docs.md +5 -5
  625. package/docs/cli/doctor.md +11 -11
  626. package/docs/cli/gateway.md +26 -26
  627. package/docs/cli/health.md +5 -5
  628. package/docs/cli/hooks.md +34 -34
  629. package/docs/cli/index.md +46 -52
  630. package/docs/cli/logs.md +6 -6
  631. package/docs/cli/memory.md +11 -11
  632. package/docs/cli/message.md +11 -11
  633. package/docs/cli/models.md +17 -17
  634. package/docs/cli/node.md +14 -14
  635. package/docs/cli/nodes.md +14 -14
  636. package/docs/cli/onboard.md +7 -6
  637. package/docs/cli/pairing.md +4 -4
  638. package/docs/cli/plugins.md +16 -16
  639. package/docs/cli/reset.md +5 -5
  640. package/docs/cli/sandbox.md +28 -28
  641. package/docs/cli/security.md +5 -5
  642. package/docs/cli/sessions.md +5 -5
  643. package/docs/cli/setup.md +6 -6
  644. package/docs/cli/skills.md +6 -6
  645. package/docs/cli/status.md +7 -7
  646. package/docs/cli/system.md +6 -6
  647. package/docs/cli/tui.md +5 -5
  648. package/docs/cli/uninstall.md +5 -5
  649. package/docs/cli/update.md +20 -20
  650. package/docs/cli/voicecall.md +9 -9
  651. package/docs/cli/webhooks.md +5 -5
  652. package/docs/concepts/agent-loop.md +5 -5
  653. package/docs/concepts/agent-workspace.md +21 -21
  654. package/docs/concepts/agent.md +12 -12
  655. package/docs/concepts/architecture.md +2 -2
  656. package/docs/concepts/channel-routing.md +4 -4
  657. package/docs/concepts/compaction.md +5 -5
  658. package/docs/concepts/context.md +6 -6
  659. package/docs/concepts/group-messages.md +6 -6
  660. package/docs/concepts/groups.md +41 -5
  661. package/docs/concepts/markdown-formatting.md +3 -3
  662. package/docs/concepts/memory.md +14 -14
  663. package/docs/concepts/messages.md +4 -4
  664. package/docs/concepts/model-failover.md +14 -14
  665. package/docs/concepts/model-providers.md +22 -22
  666. package/docs/concepts/models.md +27 -27
  667. package/docs/concepts/multi-agent.md +19 -19
  668. package/docs/concepts/oauth.md +32 -59
  669. package/docs/concepts/presence.md +2 -2
  670. package/docs/concepts/retry.md +1 -1
  671. package/docs/concepts/session-pruning.md +1 -1
  672. package/docs/concepts/session-tool.md +4 -4
  673. package/docs/concepts/session.md +14 -14
  674. package/docs/concepts/streaming.md +4 -4
  675. package/docs/concepts/system-prompt.md +11 -11
  676. package/docs/concepts/timezone.md +2 -2
  677. package/docs/concepts/typebox.md +3 -3
  678. package/docs/concepts/typing-indicators.md +2 -2
  679. package/docs/concepts/usage-tracking.md +3 -3
  680. package/docs/date-time.md +2 -2
  681. package/docs/debug/node-issue.md +4 -4
  682. package/docs/debugging.md +18 -18
  683. package/docs/diagnostics/flags.md +89 -0
  684. package/docs/docs.json +37 -7
  685. package/docs/environment.md +7 -7
  686. package/docs/experiments/plans/cron-add-hardening.md +1 -1
  687. package/docs/experiments/plans/openresponses-gateway.md +2 -2
  688. package/docs/experiments/research/memory.md +6 -6
  689. package/docs/gateway/authentication.md +33 -57
  690. package/docs/gateway/background-process.md +2 -2
  691. package/docs/gateway/bonjour.md +25 -25
  692. package/docs/gateway/bridge-protocol.md +2 -2
  693. package/docs/gateway/cli-backends.md +13 -12
  694. package/docs/gateway/configuration-examples.md +14 -14
  695. package/docs/gateway/configuration.md +160 -145
  696. package/docs/gateway/discovery.md +10 -10
  697. package/docs/gateway/doctor.md +27 -27
  698. package/docs/gateway/gateway-lock.md +1 -1
  699. package/docs/gateway/health.md +11 -11
  700. package/docs/gateway/heartbeat.md +5 -5
  701. package/docs/gateway/index.md +65 -65
  702. package/docs/gateway/local-models.md +2 -2
  703. package/docs/gateway/logging.md +8 -8
  704. package/docs/gateway/multiple-gateways.md +27 -27
  705. package/docs/gateway/openai-http-api.md +12 -12
  706. package/docs/gateway/openresponses-http-api.md +12 -12
  707. package/docs/gateway/pairing.md +9 -9
  708. package/docs/gateway/protocol.md +6 -5
  709. package/docs/gateway/remote-gateway-readme.md +16 -14
  710. package/docs/gateway/remote.md +5 -5
  711. package/docs/gateway/sandbox-vs-tool-policy-vs-elevated.md +10 -7
  712. package/docs/gateway/sandboxing.md +8 -6
  713. package/docs/gateway/security/formal-verification.md +107 -0
  714. package/docs/gateway/{security.md → security/index.md} +172 -75
  715. package/docs/gateway/tailscale.md +19 -38
  716. package/docs/gateway/tools-invoke-http-api.md +5 -5
  717. package/docs/gateway/troubleshooting.md +114 -119
  718. package/docs/help/faq.md +369 -355
  719. package/docs/help/troubleshooting.md +16 -16
  720. package/docs/hooks/soul-evil.md +2 -2
  721. package/docs/hooks.md +60 -60
  722. package/docs/index.md +35 -35
  723. package/docs/install/ansible.md +35 -35
  724. package/docs/install/development-channels.md +10 -10
  725. package/docs/install/docker.md +44 -44
  726. package/docs/install/index.md +34 -33
  727. package/docs/install/installer.md +24 -24
  728. package/docs/install/migrating.md +190 -0
  729. package/docs/install/nix.md +18 -18
  730. package/docs/install/node.md +7 -6
  731. package/docs/install/uninstall.md +30 -30
  732. package/docs/install/updating.md +50 -49
  733. package/docs/logging.md +82 -58
  734. package/docs/multi-agent-sandbox-tools.md +7 -7
  735. package/docs/network.md +1 -1
  736. package/docs/nodes/audio.md +2 -2
  737. package/docs/nodes/camera.md +18 -18
  738. package/docs/nodes/images.md +4 -4
  739. package/docs/nodes/index.md +57 -57
  740. package/docs/nodes/location-command.md +2 -2
  741. package/docs/nodes/media-understanding.md +5 -5
  742. package/docs/nodes/talk.md +1 -1
  743. package/docs/nodes/voicewake.md +2 -2
  744. package/docs/northflank.mdx +53 -0
  745. package/docs/perplexity.md +2 -2
  746. package/docs/platforms/android.md +13 -13
  747. package/docs/platforms/digitalocean.md +243 -0
  748. package/docs/platforms/exe-dev.md +25 -25
  749. package/docs/platforms/fly.md +149 -24
  750. package/docs/platforms/gcp.md +498 -0
  751. package/docs/platforms/hetzner.md +42 -42
  752. package/docs/platforms/index.md +9 -9
  753. package/docs/platforms/ios.md +13 -13
  754. package/docs/platforms/linux.md +11 -11
  755. package/docs/platforms/mac/bundled-gateway.md +16 -16
  756. package/docs/platforms/mac/canvas.md +14 -14
  757. package/docs/platforms/mac/child-process.md +9 -9
  758. package/docs/platforms/mac/dev-setup.md +11 -11
  759. package/docs/platforms/mac/health.md +2 -2
  760. package/docs/platforms/mac/icon.md +1 -1
  761. package/docs/platforms/mac/logging.md +7 -7
  762. package/docs/platforms/mac/menu-bar.md +1 -1
  763. package/docs/platforms/mac/peekaboo.md +9 -9
  764. package/docs/platforms/mac/permissions.md +3 -3
  765. package/docs/platforms/mac/release.md +20 -20
  766. package/docs/platforms/mac/remote.md +14 -14
  767. package/docs/platforms/mac/signing.md +7 -7
  768. package/docs/platforms/mac/skills.md +4 -4
  769. package/docs/platforms/mac/voice-overlay.md +2 -2
  770. package/docs/platforms/mac/webchat.md +2 -2
  771. package/docs/platforms/mac/xpc.md +4 -4
  772. package/docs/platforms/macos-vm.md +27 -27
  773. package/docs/platforms/macos.md +20 -20
  774. package/docs/platforms/oracle.md +291 -0
  775. package/docs/platforms/raspberry-pi.md +354 -0
  776. package/docs/platforms/windows.md +11 -11
  777. package/docs/plugin.md +80 -64
  778. package/docs/plugins/agent-tools.md +1 -1
  779. package/docs/plugins/manifest.md +4 -4
  780. package/docs/plugins/voice-call.md +96 -12
  781. package/docs/plugins/zalouser.md +9 -9
  782. package/docs/prose.md +9 -9
  783. package/docs/providers/anthropic.md +23 -27
  784. package/docs/providers/claude-max-api-proxy.md +145 -0
  785. package/docs/providers/deepgram.md +2 -2
  786. package/docs/providers/github-copilot.md +11 -11
  787. package/docs/providers/glm.md +4 -4
  788. package/docs/providers/index.md +7 -3
  789. package/docs/providers/minimax.md +9 -9
  790. package/docs/providers/models.md +3 -3
  791. package/docs/providers/moonshot.md +2 -2
  792. package/docs/providers/ollama.md +11 -11
  793. package/docs/providers/openai.md +9 -13
  794. package/docs/providers/opencode.md +3 -3
  795. package/docs/providers/openrouter.md +3 -3
  796. package/docs/providers/qwen.md +6 -6
  797. package/docs/providers/synthetic.md +4 -4
  798. package/docs/providers/venice.md +21 -21
  799. package/docs/providers/vercel-ai-gateway.md +5 -4
  800. package/docs/providers/zai.md +5 -5
  801. package/docs/railway.mdx +9 -7
  802. package/docs/refactor/exec-host.md +5 -5
  803. package/docs/refactor/plugin-sdk.md +12 -12
  804. package/docs/refactor/strict-config.md +11 -11
  805. package/docs/reference/AGENTS.default.md +10 -10
  806. package/docs/reference/RELEASING.md +29 -29
  807. package/docs/reference/api-usage-costs.md +6 -6
  808. package/docs/reference/device-models.md +7 -7
  809. package/docs/reference/rpc.md +3 -3
  810. package/docs/reference/session-management-compaction.md +19 -19
  811. package/docs/reference/templates/AGENTS.dev.md +1 -1
  812. package/docs/reference/templates/BOOT.md +1 -1
  813. package/docs/reference/templates/IDENTITY.md +27 -0
  814. package/docs/reference/templates/TOOLS.dev.md +1 -1
  815. package/docs/reference/templates/USER.dev.md +2 -2
  816. package/docs/reference/templates/USER.md +22 -0
  817. package/docs/reference/test.md +2 -2
  818. package/docs/reference/transcript-hygiene.md +1 -1
  819. package/docs/render.mdx +158 -0
  820. package/docs/scripts.md +1 -1
  821. package/docs/security/formal-verification.md +107 -0
  822. package/docs/start/clawd.md +29 -29
  823. package/docs/start/getting-started.md +31 -25
  824. package/docs/start/hubs.md +2 -2
  825. package/docs/start/lore.md +74 -38
  826. package/docs/start/onboarding.md +7 -7
  827. package/docs/start/pairing.md +10 -10
  828. package/docs/start/setup.md +30 -17
  829. package/docs/start/showcase.md +32 -32
  830. package/docs/start/wizard.md +29 -26
  831. package/docs/testing.md +56 -56
  832. package/docs/token-use.md +7 -7
  833. package/docs/tools/agent-send.md +10 -10
  834. package/docs/tools/browser-linux-troubleshooting.md +10 -10
  835. package/docs/tools/browser-login.md +4 -4
  836. package/docs/tools/browser.md +136 -242
  837. package/docs/tools/chrome-extension.md +31 -48
  838. package/docs/tools/clawdhub.md +7 -7
  839. package/docs/tools/creating-skills.md +41 -0
  840. package/docs/tools/elevated.md +1 -0
  841. package/docs/tools/exec-approvals.md +8 -5
  842. package/docs/tools/exec.md +15 -4
  843. package/docs/tools/firecrawl.md +2 -2
  844. package/docs/tools/index.md +18 -15
  845. package/docs/tools/llm-task.md +1 -1
  846. package/docs/tools/lobster.md +23 -11
  847. package/docs/tools/skills-config.md +2 -2
  848. package/docs/tools/skills.md +39 -31
  849. package/docs/tools/slash-commands.md +10 -8
  850. package/docs/tools/web.md +8 -8
  851. package/docs/tts.md +11 -11
  852. package/docs/tui.md +7 -7
  853. package/docs/vps.md +6 -1
  854. package/docs/web/control-ui.md +15 -14
  855. package/docs/web/dashboard.md +10 -6
  856. package/docs/web/index.md +7 -6
  857. package/docs/web/webchat.md +1 -1
  858. package/extensions/bluebubbles/index.ts +3 -3
  859. package/extensions/bluebubbles/package.json +5 -5
  860. package/extensions/bluebubbles/src/accounts.ts +9 -9
  861. package/extensions/bluebubbles/src/actions.test.ts +22 -22
  862. package/extensions/bluebubbles/src/actions.ts +6 -6
  863. package/extensions/bluebubbles/src/attachments.ts +2 -2
  864. package/extensions/bluebubbles/src/channel.ts +71 -17
  865. package/extensions/bluebubbles/src/chat.ts +2 -2
  866. package/extensions/bluebubbles/src/config-schema.ts +1 -1
  867. package/extensions/bluebubbles/src/media-send.ts +2 -2
  868. package/extensions/bluebubbles/src/monitor.test.ts +56 -50
  869. package/extensions/bluebubbles/src/monitor.ts +181 -6
  870. package/extensions/bluebubbles/src/onboarding.ts +9 -9
  871. package/extensions/bluebubbles/src/reactions.ts +2 -2
  872. package/extensions/bluebubbles/src/runtime.ts +1 -1
  873. package/extensions/bluebubbles/src/send.test.ts +94 -2
  874. package/extensions/bluebubbles/src/send.ts +73 -7
  875. package/extensions/copilot-proxy/README.md +3 -3
  876. package/extensions/copilot-proxy/index.ts +1 -1
  877. package/extensions/copilot-proxy/package.json +4 -4
  878. package/extensions/diagnostics-otel/index.ts +3 -3
  879. package/extensions/diagnostics-otel/package.json +4 -4
  880. package/extensions/diagnostics-otel/src/service.test.ts +15 -15
  881. package/extensions/diagnostics-otel/src/service.ts +85 -85
  882. package/extensions/discord/index.ts +3 -3
  883. package/extensions/discord/package.json +4 -4
  884. package/extensions/discord/src/channel.ts +1 -1
  885. package/extensions/discord/src/runtime.ts +1 -1
  886. package/extensions/google-antigravity-auth/README.md +3 -3
  887. package/extensions/google-antigravity-auth/index.ts +9 -2
  888. package/extensions/google-antigravity-auth/package.json +4 -4
  889. package/extensions/google-gemini-cli-auth/README.md +17 -6
  890. package/extensions/google-gemini-cli-auth/index.ts +3 -3
  891. package/extensions/google-gemini-cli-auth/oauth.test.ts +228 -0
  892. package/extensions/google-gemini-cli-auth/oauth.ts +96 -12
  893. package/extensions/google-gemini-cli-auth/package.json +4 -4
  894. package/extensions/googlechat/index.ts +4 -4
  895. package/extensions/googlechat/package.json +7 -7
  896. package/extensions/googlechat/src/accounts.ts +9 -9
  897. package/extensions/googlechat/src/actions.ts +8 -8
  898. package/extensions/googlechat/src/api.ts +1 -1
  899. package/extensions/googlechat/src/channel.ts +23 -23
  900. package/extensions/googlechat/src/monitor.ts +9 -9
  901. package/extensions/googlechat/src/onboarding.ts +11 -11
  902. package/extensions/googlechat/src/runtime.ts +1 -1
  903. package/extensions/googlechat/src/types.config.ts +1 -1
  904. package/extensions/imessage/index.ts +3 -3
  905. package/extensions/imessage/package.json +4 -4
  906. package/extensions/imessage/src/channel.ts +5 -8
  907. package/extensions/imessage/src/runtime.ts +1 -1
  908. package/extensions/line/clawdbot.plugin.json +11 -0
  909. package/extensions/line/index.ts +20 -0
  910. package/extensions/line/package.json +29 -0
  911. package/extensions/line/src/card-command.ts +338 -0
  912. package/extensions/line/src/channel.logout.test.ts +96 -0
  913. package/extensions/line/src/channel.sendPayload.test.ts +308 -0
  914. package/extensions/line/src/channel.ts +773 -0
  915. package/extensions/line/src/runtime.ts +14 -0
  916. package/extensions/llm-task/README.md +4 -4
  917. package/extensions/llm-task/index.ts +2 -2
  918. package/extensions/llm-task/package.json +4 -4
  919. package/extensions/llm-task/src/llm-task-tool.ts +5 -5
  920. package/extensions/lobster/README.md +6 -6
  921. package/extensions/lobster/index.ts +2 -2
  922. package/extensions/lobster/package.json +3 -3
  923. package/extensions/lobster/src/lobster-tool.test.ts +26 -6
  924. package/extensions/lobster/src/lobster-tool.ts +24 -6
  925. package/extensions/matrix/CHANGELOG.md +9 -9
  926. package/extensions/matrix/index.ts +3 -3
  927. package/extensions/matrix/node_modules/.bin/markdown-it +2 -2
  928. package/extensions/matrix/node_modules/.bin/markdown-it.CMD +2 -2
  929. package/extensions/matrix/node_modules/.bin/markdown-it.ps1 +2 -2
  930. package/extensions/matrix/package.json +7 -7
  931. package/extensions/matrix/src/actions.ts +1 -1
  932. package/extensions/matrix/src/channel.directory.test.ts +1 -1
  933. package/extensions/matrix/src/channel.ts +1 -1
  934. package/extensions/matrix/src/config-schema.ts +1 -1
  935. package/extensions/matrix/src/directory-live.ts +1 -1
  936. package/extensions/matrix/src/group-mentions.ts +1 -1
  937. package/extensions/matrix/src/matrix/accounts.ts +1 -1
  938. package/extensions/matrix/src/matrix/actions/client.ts +1 -1
  939. package/extensions/matrix/src/matrix/actions/messages.ts +1 -1
  940. package/extensions/matrix/src/matrix/actions/reactions.ts +1 -1
  941. package/extensions/matrix/src/matrix/actions/room.ts +3 -3
  942. package/extensions/matrix/src/matrix/actions/summary.ts +1 -1
  943. package/extensions/matrix/src/matrix/actions/types.ts +1 -1
  944. package/extensions/matrix/src/matrix/active-client.ts +1 -1
  945. package/extensions/matrix/src/matrix/client/config.ts +2 -2
  946. package/extensions/matrix/src/matrix/client/create-client.ts +2 -2
  947. package/extensions/matrix/src/matrix/client/logging.ts +1 -1
  948. package/extensions/matrix/src/matrix/client/shared.ts +3 -3
  949. package/extensions/matrix/src/matrix/deps.ts +5 -5
  950. package/extensions/matrix/src/matrix/monitor/allowlist.ts +1 -1
  951. package/extensions/matrix/src/matrix/monitor/auto-join.ts +4 -4
  952. package/extensions/matrix/src/matrix/monitor/direct.ts +1 -1
  953. package/extensions/matrix/src/matrix/monitor/events.ts +2 -2
  954. package/extensions/matrix/src/matrix/monitor/handler.ts +15 -11
  955. package/extensions/matrix/src/matrix/monitor/index.ts +2 -2
  956. package/extensions/matrix/src/matrix/monitor/location.ts +2 -2
  957. package/extensions/matrix/src/matrix/monitor/media.test.ts +41 -5
  958. package/extensions/matrix/src/matrix/monitor/media.ts +17 -14
  959. package/extensions/matrix/src/matrix/monitor/replies.ts +2 -2
  960. package/extensions/matrix/src/matrix/monitor/room-info.ts +1 -1
  961. package/extensions/matrix/src/matrix/monitor/rooms.ts +1 -1
  962. package/extensions/matrix/src/matrix/monitor/threads.ts +1 -1
  963. package/extensions/matrix/src/matrix/monitor/types.ts +2 -1
  964. package/extensions/matrix/src/matrix/poll-types.ts +1 -1
  965. package/extensions/matrix/src/matrix/probe.ts +1 -1
  966. package/extensions/matrix/src/matrix/send/client.ts +3 -3
  967. package/extensions/matrix/src/matrix/send/media.ts +1 -1
  968. package/extensions/matrix/src/matrix/send/targets.test.ts +1 -1
  969. package/extensions/matrix/src/matrix/send/targets.ts +1 -1
  970. package/extensions/matrix/src/matrix/send/types.ts +2 -2
  971. package/extensions/matrix/src/matrix/send.test.ts +3 -3
  972. package/extensions/matrix/src/matrix/send.ts +4 -4
  973. package/extensions/matrix/src/onboarding.ts +3 -3
  974. package/extensions/matrix/src/outbound.ts +1 -1
  975. package/extensions/matrix/src/resolve-targets.ts +1 -1
  976. package/extensions/matrix/src/runtime.ts +1 -1
  977. package/extensions/matrix/src/tool-actions.ts +1 -1
  978. package/extensions/matrix/src/types.ts +1 -1
  979. package/extensions/mattermost/index.ts +3 -3
  980. package/extensions/mattermost/package.json +5 -5
  981. package/extensions/mattermost/src/channel.ts +1 -1
  982. package/extensions/mattermost/src/config-schema.ts +1 -1
  983. package/extensions/mattermost/src/group-mentions.ts +2 -2
  984. package/extensions/mattermost/src/mattermost/accounts.ts +10 -10
  985. package/extensions/mattermost/src/mattermost/client.ts +1 -1
  986. package/extensions/mattermost/src/mattermost/monitor-helpers.ts +6 -6
  987. package/extensions/mattermost/src/mattermost/monitor.ts +4 -4
  988. package/extensions/mattermost/src/mattermost/probe.ts +1 -1
  989. package/extensions/mattermost/src/onboarding-helpers.ts +5 -5
  990. package/extensions/mattermost/src/onboarding.ts +5 -5
  991. package/extensions/mattermost/src/runtime.ts +1 -1
  992. package/extensions/mattermost/src/types.ts +1 -1
  993. package/extensions/memory-core/index.ts +3 -3
  994. package/extensions/memory-core/package.json +9 -6
  995. package/extensions/memory-lancedb/{pigbot.plugin.json → clawdbot.plugin.json} +1 -1
  996. package/extensions/memory-lancedb/config.ts +2 -2
  997. package/extensions/memory-lancedb/index.test.ts +3 -3
  998. package/extensions/memory-lancedb/index.ts +4 -4
  999. package/extensions/memory-lancedb/node_modules/.bin/openai +2 -2
  1000. package/extensions/memory-lancedb/node_modules/.bin/openai.CMD +2 -2
  1001. package/extensions/memory-lancedb/node_modules/.bin/openai.ps1 +2 -2
  1002. package/extensions/memory-lancedb/package.json +4 -4
  1003. package/extensions/msteams/CHANGELOG.md +7 -7
  1004. package/extensions/msteams/index.ts +3 -3
  1005. package/extensions/msteams/package.json +6 -6
  1006. package/extensions/msteams/src/attachments.test.ts +1 -1
  1007. package/extensions/msteams/src/channel.directory.test.ts +2 -2
  1008. package/extensions/msteams/src/channel.ts +3 -3
  1009. package/extensions/msteams/src/conversation-store-fs.test.ts +5 -5
  1010. package/extensions/msteams/src/directory-live.ts +1 -1
  1011. package/extensions/msteams/src/graph-upload.ts +4 -4
  1012. package/extensions/msteams/src/media-helpers.ts +1 -1
  1013. package/extensions/msteams/src/messenger.test.ts +1 -1
  1014. package/extensions/msteams/src/messenger.ts +1 -1
  1015. package/extensions/msteams/src/monitor-handler/message-handler.ts +1 -1
  1016. package/extensions/msteams/src/monitor-handler.ts +2 -2
  1017. package/extensions/msteams/src/monitor.ts +3 -3
  1018. package/extensions/msteams/src/onboarding.ts +11 -11
  1019. package/extensions/msteams/src/outbound.ts +1 -1
  1020. package/extensions/msteams/src/policy.test.ts +1 -1
  1021. package/extensions/msteams/src/policy.ts +50 -5
  1022. package/extensions/msteams/src/polls-store.test.ts +1 -1
  1023. package/extensions/msteams/src/polls.test.ts +5 -5
  1024. package/extensions/msteams/src/polls.ts +8 -8
  1025. package/extensions/msteams/src/probe.test.ts +1 -1
  1026. package/extensions/msteams/src/probe.ts +1 -1
  1027. package/extensions/msteams/src/reply-dispatcher.ts +36 -36
  1028. package/extensions/msteams/src/runtime.ts +1 -1
  1029. package/extensions/msteams/src/send-context.ts +2 -2
  1030. package/extensions/msteams/src/send.ts +5 -5
  1031. package/extensions/msteams/src/token.ts +1 -1
  1032. package/extensions/nextcloud-talk/index.ts +3 -3
  1033. package/extensions/nextcloud-talk/package.json +5 -5
  1034. package/extensions/nextcloud-talk/src/accounts.ts +2 -2
  1035. package/extensions/nextcloud-talk/src/channel.ts +8 -8
  1036. package/extensions/nextcloud-talk/src/config-schema.ts +1 -1
  1037. package/extensions/nextcloud-talk/src/inbound.ts +8 -8
  1038. package/extensions/nextcloud-talk/src/monitor.ts +1 -1
  1039. package/extensions/nextcloud-talk/src/onboarding.ts +2 -2
  1040. package/extensions/nextcloud-talk/src/policy.ts +2 -2
  1041. package/extensions/nextcloud-talk/src/room-info.ts +1 -1
  1042. package/extensions/nextcloud-talk/src/runtime.ts +1 -1
  1043. package/extensions/nextcloud-talk/src/types.ts +1 -1
  1044. package/extensions/nostr/CHANGELOG.md +4 -4
  1045. package/extensions/nostr/README.md +5 -5
  1046. package/extensions/nostr/index.ts +6 -6
  1047. package/extensions/nostr/package.json +6 -6
  1048. package/extensions/nostr/src/channel.ts +2 -2
  1049. package/extensions/nostr/src/config-schema.ts +1 -1
  1050. package/extensions/nostr/src/nostr-state-store.test.ts +8 -8
  1051. package/extensions/nostr/src/runtime.ts +1 -1
  1052. package/extensions/nostr/src/types.ts +4 -4
  1053. package/extensions/open-prose/index.ts +2 -2
  1054. package/extensions/open-prose/package.json +3 -3
  1055. package/extensions/open-prose/skills/prose/SKILL.md +5 -5
  1056. package/extensions/open-prose/skills/prose/examples/28-automated-pr-review.prose +2 -2
  1057. package/extensions/open-prose/skills/prose/prose.md +4 -4
  1058. package/extensions/qwen-portal-auth/README.md +3 -3
  1059. package/extensions/qwen-portal-auth/index.ts +1 -1
  1060. package/extensions/signal/index.ts +3 -3
  1061. package/extensions/signal/package.json +4 -4
  1062. package/extensions/signal/src/channel.ts +1 -1
  1063. package/extensions/signal/src/runtime.ts +1 -1
  1064. package/extensions/slack/index.ts +3 -3
  1065. package/extensions/slack/package.json +4 -4
  1066. package/extensions/slack/src/channel.ts +1 -1
  1067. package/extensions/slack/src/runtime.ts +1 -1
  1068. package/extensions/telegram/index.ts +3 -3
  1069. package/extensions/telegram/package.json +4 -4
  1070. package/extensions/telegram/src/channel.ts +3 -3
  1071. package/extensions/telegram/src/runtime.ts +1 -1
  1072. package/extensions/tlon/README.md +3 -3
  1073. package/extensions/tlon/index.ts +3 -3
  1074. package/extensions/tlon/package.json +5 -5
  1075. package/extensions/tlon/src/channel.ts +15 -15
  1076. package/extensions/tlon/src/config-schema.ts +1 -1
  1077. package/extensions/tlon/src/monitor/discovery.ts +1 -1
  1078. package/extensions/tlon/src/monitor/history.ts +1 -1
  1079. package/extensions/tlon/src/monitor/index.ts +3 -3
  1080. package/extensions/tlon/src/onboarding.ts +4 -4
  1081. package/extensions/tlon/src/runtime.ts +1 -1
  1082. package/extensions/tlon/src/types.ts +3 -3
  1083. package/extensions/tlon/src/urbit/send.ts +19 -6
  1084. package/extensions/twitch/CHANGELOG.md +21 -0
  1085. package/extensions/twitch/README.md +89 -0
  1086. package/extensions/twitch/clawdbot.plugin.json +9 -0
  1087. package/extensions/twitch/index.ts +20 -0
  1088. package/extensions/twitch/package.json +20 -0
  1089. package/extensions/twitch/src/access-control.test.ts +489 -0
  1090. package/extensions/twitch/src/access-control.ts +154 -0
  1091. package/extensions/twitch/src/actions.ts +173 -0
  1092. package/extensions/twitch/src/client-manager-registry.ts +115 -0
  1093. package/extensions/twitch/src/config-schema.ts +82 -0
  1094. package/extensions/twitch/src/config.test.ts +88 -0
  1095. package/extensions/twitch/src/config.ts +116 -0
  1096. package/extensions/twitch/src/monitor.ts +257 -0
  1097. package/extensions/twitch/src/onboarding.test.ts +311 -0
  1098. package/extensions/twitch/src/onboarding.ts +411 -0
  1099. package/extensions/twitch/src/outbound.test.ts +373 -0
  1100. package/extensions/twitch/src/outbound.ts +186 -0
  1101. package/extensions/twitch/src/plugin.test.ts +39 -0
  1102. package/extensions/twitch/src/plugin.ts +274 -0
  1103. package/extensions/twitch/src/probe.test.ts +198 -0
  1104. package/extensions/twitch/src/probe.ts +118 -0
  1105. package/extensions/twitch/src/resolver.ts +137 -0
  1106. package/extensions/twitch/src/runtime.ts +14 -0
  1107. package/extensions/twitch/src/send.test.ts +289 -0
  1108. package/extensions/twitch/src/send.ts +136 -0
  1109. package/extensions/twitch/src/status.test.ts +270 -0
  1110. package/extensions/twitch/src/status.ts +176 -0
  1111. package/extensions/twitch/src/token.test.ts +171 -0
  1112. package/extensions/twitch/src/token.ts +87 -0
  1113. package/extensions/twitch/src/twitch-client.test.ts +574 -0
  1114. package/extensions/twitch/src/twitch-client.ts +277 -0
  1115. package/extensions/twitch/src/types.ts +141 -0
  1116. package/extensions/twitch/src/utils/markdown.ts +92 -0
  1117. package/extensions/twitch/src/utils/twitch.ts +78 -0
  1118. package/extensions/twitch/test/setup.ts +7 -0
  1119. package/extensions/voice-call/CHANGELOG.md +19 -11
  1120. package/extensions/voice-call/README.md +38 -16
  1121. package/extensions/voice-call/{pigbot.plugin.json → clawdbot.plugin.json} +210 -14
  1122. package/extensions/voice-call/index.ts +32 -12
  1123. package/extensions/voice-call/package.json +4 -4
  1124. package/extensions/voice-call/src/cli.ts +1 -1
  1125. package/extensions/voice-call/src/config.test.ts +204 -0
  1126. package/extensions/voice-call/src/config.ts +134 -26
  1127. package/extensions/voice-call/src/core-bridge.ts +16 -8
  1128. package/extensions/voice-call/src/manager/context.ts +0 -1
  1129. package/extensions/voice-call/src/manager/events.ts +0 -1
  1130. package/extensions/voice-call/src/manager/lookup.ts +0 -1
  1131. package/extensions/voice-call/src/manager/outbound.ts +4 -3
  1132. package/extensions/voice-call/src/manager/state.ts +0 -1
  1133. package/extensions/voice-call/src/manager/store.ts +0 -1
  1134. package/extensions/voice-call/src/manager/timers.ts +0 -1
  1135. package/extensions/voice-call/src/manager/twiml.ts +0 -1
  1136. package/extensions/voice-call/src/manager.test.ts +2 -2
  1137. package/extensions/voice-call/src/manager.ts +4 -2
  1138. package/extensions/voice-call/src/media-stream.test.ts +97 -0
  1139. package/extensions/voice-call/src/media-stream.ts +114 -0
  1140. package/extensions/voice-call/src/providers/plivo.test.ts +0 -1
  1141. package/extensions/voice-call/src/providers/stt-openai-realtime.ts +8 -0
  1142. package/extensions/voice-call/src/providers/twilio/webhook.ts +2 -2
  1143. package/extensions/voice-call/src/providers/twilio.ts +44 -26
  1144. package/extensions/voice-call/src/response-generator.ts +1 -1
  1145. package/extensions/voice-call/src/runtime.ts +37 -27
  1146. package/extensions/voice-call/src/telephony-audio.ts +88 -0
  1147. package/extensions/voice-call/src/telephony-tts.ts +95 -0
  1148. package/extensions/voice-call/src/types.ts +1 -0
  1149. package/extensions/voice-call/src/webhook-security.test.ts +52 -0
  1150. package/extensions/voice-call/src/webhook-security.ts +16 -5
  1151. package/extensions/voice-call/src/webhook.ts +11 -0
  1152. package/extensions/whatsapp/index.ts +3 -3
  1153. package/extensions/whatsapp/package.json +4 -4
  1154. package/extensions/whatsapp/src/channel.ts +1 -1
  1155. package/extensions/whatsapp/src/runtime.ts +1 -1
  1156. package/extensions/zalo/CHANGELOG.md +9 -9
  1157. package/extensions/zalo/README.md +4 -4
  1158. package/extensions/zalo/index.ts +3 -3
  1159. package/extensions/zalo/package.json +6 -6
  1160. package/extensions/zalo/src/accounts.ts +9 -9
  1161. package/extensions/zalo/src/actions.ts +6 -6
  1162. package/extensions/zalo/src/channel.directory.test.ts +2 -2
  1163. package/extensions/zalo/src/channel.ts +20 -20
  1164. package/extensions/zalo/src/config-schema.ts +1 -1
  1165. package/extensions/zalo/src/monitor.ts +9 -9
  1166. package/extensions/zalo/src/monitor.webhook.test.ts +2 -2
  1167. package/extensions/zalo/src/onboarding.ts +27 -27
  1168. package/extensions/zalo/src/runtime.ts +1 -1
  1169. package/extensions/zalo/src/send.ts +2 -2
  1170. package/extensions/zalo/src/status-issues.ts +1 -1
  1171. package/extensions/zalo/src/token.ts +1 -1
  1172. package/extensions/zalouser/CHANGELOG.md +4 -4
  1173. package/extensions/zalouser/README.md +18 -18
  1174. package/extensions/zalouser/index.ts +3 -3
  1175. package/extensions/zalouser/package.json +6 -6
  1176. package/extensions/zalouser/src/accounts.ts +10 -10
  1177. package/extensions/zalouser/src/channel.test.ts +0 -1
  1178. package/extensions/zalouser/src/channel.ts +27 -27
  1179. package/extensions/zalouser/src/config-schema.ts +1 -1
  1180. package/extensions/zalouser/src/monitor.ts +5 -5
  1181. package/extensions/zalouser/src/onboarding.ts +32 -32
  1182. package/extensions/zalouser/src/runtime.ts +1 -1
  1183. package/extensions/zalouser/src/status-issues.ts +2 -2
  1184. package/package.json +39 -23
  1185. package/scripts/postinstall.js +1 -1
  1186. package/skills/1password/SKILL.md +3 -3
  1187. package/skills/apple-notes/SKILL.md +2 -2
  1188. package/skills/apple-reminders/SKILL.md +1 -1
  1189. package/skills/bear-notes/SKILL.md +1 -1
  1190. package/skills/bird/SKILL.md +1 -1
  1191. package/skills/blogwatcher/SKILL.md +1 -1
  1192. package/skills/blucli/SKILL.md +1 -1
  1193. package/skills/bluebubbles/SKILL.md +2 -2
  1194. package/skills/camsnap/SKILL.md +1 -1
  1195. package/skills/canvas/SKILL.md +15 -15
  1196. package/skills/clawdhub/SKILL.md +2 -2
  1197. package/skills/coding-agent/SKILL.md +6 -6
  1198. package/skills/discord/SKILL.md +6 -5
  1199. package/skills/eightctl/SKILL.md +1 -1
  1200. package/skills/food-order/SKILL.md +1 -1
  1201. package/skills/gemini/SKILL.md +1 -1
  1202. package/skills/gifgrep/SKILL.md +1 -1
  1203. package/skills/github/SKILL.md +1 -0
  1204. package/skills/gog/SKILL.md +1 -1
  1205. package/skills/goplaces/SKILL.md +1 -1
  1206. package/skills/himalaya/SKILL.md +1 -1
  1207. package/skills/imsg/SKILL.md +1 -1
  1208. package/skills/local-places/SKILL.md +2 -2
  1209. package/skills/mcporter/SKILL.md +1 -1
  1210. package/skills/model-usage/SKILL.md +1 -1
  1211. package/skills/nano-banana-pro/SKILL.md +10 -5
  1212. package/skills/nano-banana-pro/scripts/generate_image.py +42 -27
  1213. package/skills/nano-pdf/SKILL.md +1 -1
  1214. package/skills/notion/SKILL.md +1 -1
  1215. package/skills/obsidian/SKILL.md +1 -1
  1216. package/skills/openai-image-gen/SKILL.md +1 -1
  1217. package/skills/openai-whisper/SKILL.md +1 -1
  1218. package/skills/openai-whisper-api/SKILL.md +2 -2
  1219. package/skills/openhue/SKILL.md +1 -1
  1220. package/skills/oracle/SKILL.md +1 -1
  1221. package/skills/ordercli/SKILL.md +1 -1
  1222. package/skills/peekaboo/SKILL.md +1 -1
  1223. package/skills/sag/SKILL.md +1 -1
  1224. package/skills/session-logs/SKILL.md +7 -7
  1225. package/skills/sherpa-onnx-tts/SKILL.md +6 -6
  1226. package/skills/sherpa-onnx-tts/bin/sherpa-onnx-tts +178 -0
  1227. package/skills/slack/SKILL.md +4 -3
  1228. package/skills/songsee/SKILL.md +1 -1
  1229. package/skills/sonoscli/SKILL.md +1 -1
  1230. package/skills/spotify-player/SKILL.md +1 -1
  1231. package/skills/summarize/SKILL.md +1 -1
  1232. package/skills/things-mac/SKILL.md +3 -3
  1233. package/skills/tmux/SKILL.md +8 -8
  1234. package/skills/tmux/scripts/find-sessions.sh +2 -2
  1235. package/skills/trello/SKILL.md +2 -2
  1236. package/skills/video-frames/SKILL.md +1 -1
  1237. package/skills/voice-call/SKILL.md +4 -4
  1238. package/skills/wacli/SKILL.md +2 -2
  1239. package/skills/weather/SKILL.md +1 -1
  1240. package/dist/cli/browser-cli-serve.js +0 -91
  1241. package/dist/control-ui/assets/index--6ilUi7V.css +0 -1
  1242. package/dist/control-ui/assets/index-DrGg77je.js +0 -3111
  1243. package/dist/control-ui/assets/index-DrGg77je.js.map +0 -1
  1244. package/extensions/diagnostics-otel/node_modules/.bin/acorn +0 -21
  1245. package/extensions/diagnostics-otel/node_modules/.bin/acorn.CMD +0 -12
  1246. package/extensions/diagnostics-otel/node_modules/.bin/acorn.ps1 +0 -41
  1247. package/extensions/googlechat/node_modules/.bin/pigbot +0 -21
  1248. package/extensions/googlechat/node_modules/.bin/pigbot.CMD +0 -12
  1249. package/extensions/googlechat/node_modules/.bin/pigbot.ps1 +0 -41
  1250. package/extensions/matrix/node_modules/.bin/pigbot +0 -21
  1251. package/extensions/matrix/node_modules/.bin/pigbot.CMD +0 -12
  1252. package/extensions/matrix/node_modules/.bin/pigbot.ps1 +0 -41
  1253. package/extensions/memory-core/node_modules/.bin/pigbot +0 -21
  1254. package/extensions/memory-core/node_modules/.bin/pigbot.CMD +0 -12
  1255. package/extensions/memory-core/node_modules/.bin/pigbot.ps1 +0 -41
  1256. package/extensions/memory-lancedb/node_modules/.bin/arrow2csv +0 -21
  1257. package/extensions/memory-lancedb/node_modules/.bin/arrow2csv.CMD +0 -12
  1258. package/extensions/memory-lancedb/node_modules/.bin/arrow2csv.ps1 +0 -41
  1259. package/extensions/msteams/node_modules/.bin/pigbot +0 -21
  1260. package/extensions/msteams/node_modules/.bin/pigbot.CMD +0 -12
  1261. package/extensions/msteams/node_modules/.bin/pigbot.ps1 +0 -41
  1262. package/extensions/nostr/node_modules/.bin/pigbot +0 -21
  1263. package/extensions/nostr/node_modules/.bin/pigbot.CMD +0 -12
  1264. package/extensions/nostr/node_modules/.bin/pigbot.ps1 +0 -41
  1265. package/extensions/nostr/node_modules/.bin/tsc +0 -21
  1266. package/extensions/nostr/node_modules/.bin/tsc.CMD +0 -12
  1267. package/extensions/nostr/node_modules/.bin/tsc.ps1 +0 -41
  1268. package/extensions/nostr/node_modules/.bin/tsserver +0 -21
  1269. package/extensions/nostr/node_modules/.bin/tsserver.CMD +0 -12
  1270. package/extensions/nostr/node_modules/.bin/tsserver.ps1 +0 -41
  1271. package/extensions/zalo/node_modules/.bin/pigbot +0 -21
  1272. package/extensions/zalo/node_modules/.bin/pigbot.CMD +0 -12
  1273. package/extensions/zalo/node_modules/.bin/pigbot.ps1 +0 -41
  1274. package/extensions/zalouser/node_modules/.bin/pigbot +0 -21
  1275. package/extensions/zalouser/node_modules/.bin/pigbot.CMD +0 -12
  1276. package/extensions/zalouser/node_modules/.bin/pigbot.ps1 +0 -41
  1277. /package/dist/{config/types.pigbot.js → browser/routes/types.js} +0 -0
  1278. /package/extensions/bluebubbles/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1279. /package/extensions/copilot-proxy/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1280. /package/extensions/diagnostics-otel/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1281. /package/extensions/discord/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1282. /package/extensions/google-antigravity-auth/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1283. /package/extensions/google-gemini-cli-auth/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1284. /package/extensions/googlechat/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1285. /package/extensions/imessage/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1286. /package/extensions/llm-task/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1287. /package/extensions/lobster/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1288. /package/extensions/matrix/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1289. /package/extensions/mattermost/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1290. /package/extensions/memory-core/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1291. /package/extensions/msteams/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1292. /package/extensions/nextcloud-talk/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1293. /package/extensions/nostr/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1294. /package/extensions/open-prose/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1295. /package/extensions/qwen-portal-auth/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1296. /package/extensions/signal/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1297. /package/extensions/slack/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1298. /package/extensions/telegram/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1299. /package/extensions/tlon/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1300. /package/extensions/whatsapp/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1301. /package/extensions/zalo/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1302. /package/extensions/zalouser/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
@@ -1,3111 +0,0 @@
1
- (function(){const t=document.createElement("link").relList;if(t&&t.supports&&t.supports("modulepreload"))return;for(const i of document.querySelectorAll('link[rel="modulepreload"]'))s(i);new MutationObserver(i=>{for(const o of i)if(o.type==="childList")for(const a of o.addedNodes)a.tagName==="LINK"&&a.rel==="modulepreload"&&s(a)}).observe(document,{childList:!0,subtree:!0});function n(i){const o={};return i.integrity&&(o.integrity=i.integrity),i.referrerPolicy&&(o.referrerPolicy=i.referrerPolicy),i.crossOrigin==="use-credentials"?o.credentials="include":i.crossOrigin==="anonymous"?o.credentials="omit":o.credentials="same-origin",o}function s(i){if(i.ep)return;i.ep=!0;const o=n(i);fetch(i.href,o)}})();const qt=globalThis,Cs=qt.ShadowRoot&&(qt.ShadyCSS===void 0||qt.ShadyCSS.nativeShadow)&&"adoptedStyleSheets"in Document.prototype&&"replace"in CSSStyleSheet.prototype,Es=Symbol(),Ni=new WeakMap;let Go=class{constructor(t,n,s){if(this._$cssResult$=!0,s!==Es)throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");this.cssText=t,this.t=n}get styleSheet(){let t=this.o;const n=this.t;if(Cs&&t===void 0){const s=n!==void 0&&n.length===1;s&&(t=Ni.get(n)),t===void 0&&((this.o=t=new CSSStyleSheet).replaceSync(this.cssText),s&&Ni.set(n,t))}return t}toString(){return this.cssText}};const Dr=e=>new Go(typeof e=="string"?e:e+"",void 0,Es),Br=(e,...t)=>{const n=e.length===1?e[0]:t.reduce((s,i,o)=>s+(a=>{if(a._$cssResult$===!0)return a.cssText;if(typeof a=="number")return a;throw Error("Value passed to 'css' function must be a 'css' function result: "+a+". Use 'unsafeCSS' to pass non-literal values, but take care to ensure page security.")})(i)+e[o+1],e[0]);return new Go(n,e,Es)},Fr=(e,t)=>{if(Cs)e.adoptedStyleSheets=t.map(n=>n instanceof CSSStyleSheet?n:n.styleSheet);else for(const n of t){const s=document.createElement("style"),i=qt.litNonce;i!==void 0&&s.setAttribute("nonce",i),s.textContent=n.cssText,e.appendChild(s)}},Oi=Cs?e=>e:e=>e instanceof CSSStyleSheet?(t=>{let n="";for(const s of t.cssRules)n+=s.cssText;return Dr(n)})(e):e;const{is:Ur,defineProperty:Kr,getOwnPropertyDescriptor:Hr,getOwnPropertyNames:zr,getOwnPropertySymbols:jr,getPrototypeOf:qr}=Object,nn=globalThis,Di=nn.trustedTypes,Wr=Di?Di.emptyScript:"",Gr=nn.reactiveElementPolyfillSupport,mt=(e,t)=>e,Vt={toAttribute(e,t){switch(t){case Boolean:e=e?Wr:null;break;case Object:case Array:e=e==null?e:JSON.stringify(e)}return e},fromAttribute(e,t){let n=e;switch(t){case Boolean:n=e!==null;break;case Number:n=e===null?null:Number(e);break;case Object:case Array:try{n=JSON.parse(e)}catch{n=null}}return n}},Is=(e,t)=>!Ur(e,t),Bi={attribute:!0,type:String,converter:Vt,reflect:!1,useDefault:!1,hasChanged:Is};Symbol.metadata??=Symbol("metadata"),nn.litPropertyMetadata??=new WeakMap;let Ve=class extends HTMLElement{static addInitializer(t){this._$Ei(),(this.l??=[]).push(t)}static get observedAttributes(){return this.finalize(),this._$Eh&&[...this._$Eh.keys()]}static createProperty(t,n=Bi){if(n.state&&(n.attribute=!1),this._$Ei(),this.prototype.hasOwnProperty(t)&&((n=Object.create(n)).wrapped=!0),this.elementProperties.set(t,n),!n.noAccessor){const s=Symbol(),i=this.getPropertyDescriptor(t,s,n);i!==void 0&&Kr(this.prototype,t,i)}}static getPropertyDescriptor(t,n,s){const{get:i,set:o}=Hr(this.prototype,t)??{get(){return this[n]},set(a){this[n]=a}};return{get:i,set(a){const l=i?.call(this);o?.call(this,a),this.requestUpdate(t,l,s)},configurable:!0,enumerable:!0}}static getPropertyOptions(t){return this.elementProperties.get(t)??Bi}static _$Ei(){if(this.hasOwnProperty(mt("elementProperties")))return;const t=qr(this);t.finalize(),t.l!==void 0&&(this.l=[...t.l]),this.elementProperties=new Map(t.elementProperties)}static finalize(){if(this.hasOwnProperty(mt("finalized")))return;if(this.finalized=!0,this._$Ei(),this.hasOwnProperty(mt("properties"))){const n=this.properties,s=[...zr(n),...jr(n)];for(const i of s)this.createProperty(i,n[i])}const t=this[Symbol.metadata];if(t!==null){const n=litPropertyMetadata.get(t);if(n!==void 0)for(const[s,i]of n)this.elementProperties.set(s,i)}this._$Eh=new Map;for(const[n,s]of this.elementProperties){const i=this._$Eu(n,s);i!==void 0&&this._$Eh.set(i,n)}this.elementStyles=this.finalizeStyles(this.styles)}static finalizeStyles(t){const n=[];if(Array.isArray(t)){const s=new Set(t.flat(1/0).reverse());for(const i of s)n.unshift(Oi(i))}else t!==void 0&&n.push(Oi(t));return n}static _$Eu(t,n){const s=n.attribute;return s===!1?void 0:typeof s=="string"?s:typeof t=="string"?t.toLowerCase():void 0}constructor(){super(),this._$Ep=void 0,this.isUpdatePending=!1,this.hasUpdated=!1,this._$Em=null,this._$Ev()}_$Ev(){this._$ES=new Promise(t=>this.enableUpdating=t),this._$AL=new Map,this._$E_(),this.requestUpdate(),this.constructor.l?.forEach(t=>t(this))}addController(t){(this._$EO??=new Set).add(t),this.renderRoot!==void 0&&this.isConnected&&t.hostConnected?.()}removeController(t){this._$EO?.delete(t)}_$E_(){const t=new Map,n=this.constructor.elementProperties;for(const s of n.keys())this.hasOwnProperty(s)&&(t.set(s,this[s]),delete this[s]);t.size>0&&(this._$Ep=t)}createRenderRoot(){const t=this.shadowRoot??this.attachShadow(this.constructor.shadowRootOptions);return Fr(t,this.constructor.elementStyles),t}connectedCallback(){this.renderRoot??=this.createRenderRoot(),this.enableUpdating(!0),this._$EO?.forEach(t=>t.hostConnected?.())}enableUpdating(t){}disconnectedCallback(){this._$EO?.forEach(t=>t.hostDisconnected?.())}attributeChangedCallback(t,n,s){this._$AK(t,s)}_$ET(t,n){const s=this.constructor.elementProperties.get(t),i=this.constructor._$Eu(t,s);if(i!==void 0&&s.reflect===!0){const o=(s.converter?.toAttribute!==void 0?s.converter:Vt).toAttribute(n,s.type);this._$Em=t,o==null?this.removeAttribute(i):this.setAttribute(i,o),this._$Em=null}}_$AK(t,n){const s=this.constructor,i=s._$Eh.get(t);if(i!==void 0&&this._$Em!==i){const o=s.getPropertyOptions(i),a=typeof o.converter=="function"?{fromAttribute:o.converter}:o.converter?.fromAttribute!==void 0?o.converter:Vt;this._$Em=i;const l=a.fromAttribute(n,o.type);this[i]=l??this._$Ej?.get(i)??l,this._$Em=null}}requestUpdate(t,n,s,i=!1,o){if(t!==void 0){const a=this.constructor;if(i===!1&&(o=this[t]),s??=a.getPropertyOptions(t),!((s.hasChanged??Is)(o,n)||s.useDefault&&s.reflect&&o===this._$Ej?.get(t)&&!this.hasAttribute(a._$Eu(t,s))))return;this.C(t,n,s)}this.isUpdatePending===!1&&(this._$ES=this._$EP())}C(t,n,{useDefault:s,reflect:i,wrapped:o},a){s&&!(this._$Ej??=new Map).has(t)&&(this._$Ej.set(t,a??n??this[t]),o!==!0||a!==void 0)||(this._$AL.has(t)||(this.hasUpdated||s||(n=void 0),this._$AL.set(t,n)),i===!0&&this._$Em!==t&&(this._$Eq??=new Set).add(t))}async _$EP(){this.isUpdatePending=!0;try{await this._$ES}catch(n){Promise.reject(n)}const t=this.scheduleUpdate();return t!=null&&await t,!this.isUpdatePending}scheduleUpdate(){return this.performUpdate()}performUpdate(){if(!this.isUpdatePending)return;if(!this.hasUpdated){if(this.renderRoot??=this.createRenderRoot(),this._$Ep){for(const[i,o]of this._$Ep)this[i]=o;this._$Ep=void 0}const s=this.constructor.elementProperties;if(s.size>0)for(const[i,o]of s){const{wrapped:a}=o,l=this[i];a!==!0||this._$AL.has(i)||l===void 0||this.C(i,void 0,o,l)}}let t=!1;const n=this._$AL;try{t=this.shouldUpdate(n),t?(this.willUpdate(n),this._$EO?.forEach(s=>s.hostUpdate?.()),this.update(n)):this._$EM()}catch(s){throw t=!1,this._$EM(),s}t&&this._$AE(n)}willUpdate(t){}_$AE(t){this._$EO?.forEach(n=>n.hostUpdated?.()),this.hasUpdated||(this.hasUpdated=!0,this.firstUpdated(t)),this.updated(t)}_$EM(){this._$AL=new Map,this.isUpdatePending=!1}get updateComplete(){return this.getUpdateComplete()}getUpdateComplete(){return this._$ES}shouldUpdate(t){return!0}update(t){this._$Eq&&=this._$Eq.forEach(n=>this._$ET(n,this[n])),this._$EM()}updated(t){}firstUpdated(t){}};Ve.elementStyles=[],Ve.shadowRootOptions={mode:"open"},Ve[mt("elementProperties")]=new Map,Ve[mt("finalized")]=new Map,Gr?.({ReactiveElement:Ve}),(nn.reactiveElementVersions??=[]).push("2.1.2");const Rs=globalThis,Fi=e=>e,Yt=Rs.trustedTypes,Ui=Yt?Yt.createPolicy("lit-html",{createHTML:e=>e}):void 0,Vo="$lit$",$e=`lit$${Math.random().toFixed(9).slice(2)}$`,Yo="?"+$e,Vr=`<${Yo}>`,Ne=document,wt=()=>Ne.createComment(""),$t=e=>e===null||typeof e!="object"&&typeof e!="function",Ls=Array.isArray,Yr=e=>Ls(e)||typeof e?.[Symbol.iterator]=="function",On=`[
2
- \f\r]`,at=/<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g,Ki=/-->/g,Hi=/>/g,Ee=RegExp(`>|${On}(?:([^\\s"'>=/]+)(${On}*=${On}*(?:[^
3
- \f\r"'\`<>=]|("|')|))|$)`,"g"),zi=/'/g,ji=/"/g,Qo=/^(?:script|style|textarea|title)$/i,Qr=e=>(t,...n)=>({_$litType$:e,strings:t,values:n}),c=Qr(1),Ae=Symbol.for("lit-noChange"),g=Symbol.for("lit-nothing"),qi=new WeakMap,Me=Ne.createTreeWalker(Ne,129);function Jo(e,t){if(!Ls(e)||!e.hasOwnProperty("raw"))throw Error("invalid template strings array");return Ui!==void 0?Ui.createHTML(t):t}const Jr=(e,t)=>{const n=e.length-1,s=[];let i,o=t===2?"<svg>":t===3?"<math>":"",a=at;for(let l=0;l<n;l++){const r=e[l];let p,d,u=-1,h=0;for(;h<r.length&&(a.lastIndex=h,d=a.exec(r),d!==null);)h=a.lastIndex,a===at?d[1]==="!--"?a=Ki:d[1]!==void 0?a=Hi:d[2]!==void 0?(Qo.test(d[2])&&(i=RegExp("</"+d[2],"g")),a=Ee):d[3]!==void 0&&(a=Ee):a===Ee?d[0]===">"?(a=i??at,u=-1):d[1]===void 0?u=-2:(u=a.lastIndex-d[2].length,p=d[1],a=d[3]===void 0?Ee:d[3]==='"'?ji:zi):a===ji||a===zi?a=Ee:a===Ki||a===Hi?a=at:(a=Ee,i=void 0);const v=a===Ee&&e[l+1].startsWith("/>")?" ":"";o+=a===at?r+Vr:u>=0?(s.push(p),r.slice(0,u)+Vo+r.slice(u)+$e+v):r+$e+(u===-2?l:v)}return[Jo(e,o+(e[n]||"<?>")+(t===2?"</svg>":t===3?"</math>":"")),s]};let ns=class Zo{constructor({strings:t,_$litType$:n},s){let i;this.parts=[];let o=0,a=0;const l=t.length-1,r=this.parts,[p,d]=Jr(t,n);if(this.el=Zo.createElement(p,s),Me.currentNode=this.el.content,n===2||n===3){const u=this.el.content.firstChild;u.replaceWith(...u.childNodes)}for(;(i=Me.nextNode())!==null&&r.length<l;){if(i.nodeType===1){if(i.hasAttributes())for(const u of i.getAttributeNames())if(u.endsWith(Vo)){const h=d[a++],v=i.getAttribute(u).split($e),w=/([.?@])?(.*)/.exec(h);r.push({type:1,index:o,name:w[2],strings:v,ctor:w[1]==="."?Xr:w[1]==="?"?el:w[1]==="@"?tl:on}),i.removeAttribute(u)}else u.startsWith($e)&&(r.push({type:6,index:o}),i.removeAttribute(u));if(Qo.test(i.tagName)){const u=i.textContent.split($e),h=u.length-1;if(h>0){i.textContent=Yt?Yt.emptyScript:"";for(let v=0;v<h;v++)i.append(u[v],wt()),Me.nextNode(),r.push({type:2,index:++o});i.append(u[h],wt())}}}else if(i.nodeType===8)if(i.data===Yo)r.push({type:2,index:o});else{let u=-1;for(;(u=i.data.indexOf($e,u+1))!==-1;)r.push({type:7,index:o}),u+=$e.length-1}o++}}static createElement(t,n){const s=Ne.createElement("template");return s.innerHTML=t,s}};function Je(e,t,n=e,s){if(t===Ae)return t;let i=s!==void 0?n._$Co?.[s]:n._$Cl;const o=$t(t)?void 0:t._$litDirective$;return i?.constructor!==o&&(i?._$AO?.(!1),o===void 0?i=void 0:(i=new o(e),i._$AT(e,n,s)),s!==void 0?(n._$Co??=[])[s]=i:n._$Cl=i),i!==void 0&&(t=Je(e,i._$AS(e,t.values),i,s)),t}class Zr{constructor(t,n){this._$AV=[],this._$AN=void 0,this._$AD=t,this._$AM=n}get parentNode(){return this._$AM.parentNode}get _$AU(){return this._$AM._$AU}u(t){const{el:{content:n},parts:s}=this._$AD,i=(t?.creationScope??Ne).importNode(n,!0);Me.currentNode=i;let o=Me.nextNode(),a=0,l=0,r=s[0];for(;r!==void 0;){if(a===r.index){let p;r.type===2?p=new sn(o,o.nextSibling,this,t):r.type===1?p=new r.ctor(o,r.name,r.strings,this,t):r.type===6&&(p=new nl(o,this,t)),this._$AV.push(p),r=s[++l]}a!==r?.index&&(o=Me.nextNode(),a++)}return Me.currentNode=Ne,i}p(t){let n=0;for(const s of this._$AV)s!==void 0&&(s.strings!==void 0?(s._$AI(t,s,n),n+=s.strings.length-2):s._$AI(t[n])),n++}}let sn=class Xo{get _$AU(){return this._$AM?._$AU??this._$Cv}constructor(t,n,s,i){this.type=2,this._$AH=g,this._$AN=void 0,this._$AA=t,this._$AB=n,this._$AM=s,this.options=i,this._$Cv=i?.isConnected??!0}get parentNode(){let t=this._$AA.parentNode;const n=this._$AM;return n!==void 0&&t?.nodeType===11&&(t=n.parentNode),t}get startNode(){return this._$AA}get endNode(){return this._$AB}_$AI(t,n=this){t=Je(this,t,n),$t(t)?t===g||t==null||t===""?(this._$AH!==g&&this._$AR(),this._$AH=g):t!==this._$AH&&t!==Ae&&this._(t):t._$litType$!==void 0?this.$(t):t.nodeType!==void 0?this.T(t):Yr(t)?this.k(t):this._(t)}O(t){return this._$AA.parentNode.insertBefore(t,this._$AB)}T(t){this._$AH!==t&&(this._$AR(),this._$AH=this.O(t))}_(t){this._$AH!==g&&$t(this._$AH)?this._$AA.nextSibling.data=t:this.T(Ne.createTextNode(t)),this._$AH=t}$(t){const{values:n,_$litType$:s}=t,i=typeof s=="number"?this._$AC(t):(s.el===void 0&&(s.el=ns.createElement(Jo(s.h,s.h[0]),this.options)),s);if(this._$AH?._$AD===i)this._$AH.p(n);else{const o=new Zr(i,this),a=o.u(this.options);o.p(n),this.T(a),this._$AH=o}}_$AC(t){let n=qi.get(t.strings);return n===void 0&&qi.set(t.strings,n=new ns(t)),n}k(t){Ls(this._$AH)||(this._$AH=[],this._$AR());const n=this._$AH;let s,i=0;for(const o of t)i===n.length?n.push(s=new Xo(this.O(wt()),this.O(wt()),this,this.options)):s=n[i],s._$AI(o),i++;i<n.length&&(this._$AR(s&&s._$AB.nextSibling,i),n.length=i)}_$AR(t=this._$AA.nextSibling,n){for(this._$AP?.(!1,!0,n);t!==this._$AB;){const s=Fi(t).nextSibling;Fi(t).remove(),t=s}}setConnected(t){this._$AM===void 0&&(this._$Cv=t,this._$AP?.(t))}};class on{get tagName(){return this.element.tagName}get _$AU(){return this._$AM._$AU}constructor(t,n,s,i,o){this.type=1,this._$AH=g,this._$AN=void 0,this.element=t,this.name=n,this._$AM=i,this.options=o,s.length>2||s[0]!==""||s[1]!==""?(this._$AH=Array(s.length-1).fill(new String),this.strings=s):this._$AH=g}_$AI(t,n=this,s,i){const o=this.strings;let a=!1;if(o===void 0)t=Je(this,t,n,0),a=!$t(t)||t!==this._$AH&&t!==Ae,a&&(this._$AH=t);else{const l=t;let r,p;for(t=o[0],r=0;r<o.length-1;r++)p=Je(this,l[s+r],n,r),p===Ae&&(p=this._$AH[r]),a||=!$t(p)||p!==this._$AH[r],p===g?t=g:t!==g&&(t+=(p??"")+o[r+1]),this._$AH[r]=p}a&&!i&&this.j(t)}j(t){t===g?this.element.removeAttribute(this.name):this.element.setAttribute(this.name,t??"")}}let Xr=class extends on{constructor(){super(...arguments),this.type=3}j(t){this.element[this.name]=t===g?void 0:t}},el=class extends on{constructor(){super(...arguments),this.type=4}j(t){this.element.toggleAttribute(this.name,!!t&&t!==g)}},tl=class extends on{constructor(t,n,s,i,o){super(t,n,s,i,o),this.type=5}_$AI(t,n=this){if((t=Je(this,t,n,0)??g)===Ae)return;const s=this._$AH,i=t===g&&s!==g||t.capture!==s.capture||t.once!==s.once||t.passive!==s.passive,o=t!==g&&(s===g||i);i&&this.element.removeEventListener(this.name,this,s),o&&this.element.addEventListener(this.name,this,t),this._$AH=t}handleEvent(t){typeof this._$AH=="function"?this._$AH.call(this.options?.host??this.element,t):this._$AH.handleEvent(t)}},nl=class{constructor(t,n,s){this.element=t,this.type=6,this._$AN=void 0,this._$AM=n,this.options=s}get _$AU(){return this._$AM._$AU}_$AI(t){Je(this,t)}};const sl={I:sn},il=Rs.litHtmlPolyfillSupport;il?.(ns,sn),(Rs.litHtmlVersions??=[]).push("3.3.2");const ol=(e,t,n)=>{const s=n?.renderBefore??t;let i=s._$litPart$;if(i===void 0){const o=n?.renderBefore??null;s._$litPart$=i=new sn(t.insertBefore(wt(),o),o,void 0,n??{})}return i._$AI(e),i};const Ms=globalThis;let Qe=class extends Ve{constructor(){super(...arguments),this.renderOptions={host:this},this._$Do=void 0}createRenderRoot(){const t=super.createRenderRoot();return this.renderOptions.renderBefore??=t.firstChild,t}update(t){const n=this.render();this.hasUpdated||(this.renderOptions.isConnected=this.isConnected),super.update(t),this._$Do=ol(n,this.renderRoot,this.renderOptions)}connectedCallback(){super.connectedCallback(),this._$Do?.setConnected(!0)}disconnectedCallback(){super.disconnectedCallback(),this._$Do?.setConnected(!1)}render(){return Ae}};Qe._$litElement$=!0,Qe.finalized=!0,Ms.litElementHydrateSupport?.({LitElement:Qe});const al=Ms.litElementPolyfillSupport;al?.({LitElement:Qe});(Ms.litElementVersions??=[]).push("4.2.2");const ea=e=>(t,n)=>{n!==void 0?n.addInitializer(()=>{customElements.define(e,t)}):customElements.define(e,t)};const rl={attribute:!0,type:String,converter:Vt,reflect:!1,hasChanged:Is},ll=(e=rl,t,n)=>{const{kind:s,metadata:i}=n;let o=globalThis.litPropertyMetadata.get(i);if(o===void 0&&globalThis.litPropertyMetadata.set(i,o=new Map),s==="setter"&&((e=Object.create(e)).wrapped=!0),o.set(n.name,e),s==="accessor"){const{name:a}=n;return{set(l){const r=t.get.call(this);t.set.call(this,l),this.requestUpdate(a,r,e,!0,l)},init(l){return l!==void 0&&this.C(a,void 0,e,l),l}}}if(s==="setter"){const{name:a}=n;return function(l){const r=this[a];t.call(this,l),this.requestUpdate(a,r,e,!0,l)}}throw Error("Unsupported decorator location: "+s)};function an(e){return(t,n)=>typeof n=="object"?ll(e,t,n):((s,i,o)=>{const a=i.hasOwnProperty(o);return i.constructor.createProperty(o,s),a?Object.getOwnPropertyDescriptor(i,o):void 0})(e,t,n)}function y(e){return an({...e,state:!0,attribute:!1})}const cl=50,dl=200,ul="Assistant";function Wi(e,t){if(typeof e!="string")return;const n=e.trim();if(n)return n.length<=t?n:n.slice(0,t)}function ss(e){const t=Wi(e?.name,cl)??ul,n=Wi(e?.avatar??void 0,dl)??null;return{agentId:typeof e?.agentId=="string"&&e.agentId.trim()?e.agentId.trim():null,name:t,avatar:n}}function pl(){return ss(typeof window>"u"?{}:{name:window.__PIGBOT_ASSISTANT_NAME__,avatar:window.__PIGBOT_ASSISTANT_AVATAR__})}const ta="pigbot.control.settings.v1";function fl(){const t={gatewayUrl:`${location.protocol==="https:"?"wss":"ws"}://${location.host}`,token:"",sessionKey:"main",lastActiveSessionKey:"main",theme:"system",chatFocusMode:!1,chatShowThinking:!0,splitRatio:.6,navCollapsed:!1,navGroupsCollapsed:{}};try{const n=localStorage.getItem(ta);if(!n)return t;const s=JSON.parse(n);return{gatewayUrl:typeof s.gatewayUrl=="string"&&s.gatewayUrl.trim()?s.gatewayUrl.trim():t.gatewayUrl,token:typeof s.token=="string"?s.token:t.token,sessionKey:typeof s.sessionKey=="string"&&s.sessionKey.trim()?s.sessionKey.trim():t.sessionKey,lastActiveSessionKey:typeof s.lastActiveSessionKey=="string"&&s.lastActiveSessionKey.trim()?s.lastActiveSessionKey.trim():typeof s.sessionKey=="string"&&s.sessionKey.trim()||t.lastActiveSessionKey,theme:s.theme==="light"||s.theme==="dark"||s.theme==="system"?s.theme:t.theme,chatFocusMode:typeof s.chatFocusMode=="boolean"?s.chatFocusMode:t.chatFocusMode,chatShowThinking:typeof s.chatShowThinking=="boolean"?s.chatShowThinking:t.chatShowThinking,splitRatio:typeof s.splitRatio=="number"&&s.splitRatio>=.4&&s.splitRatio<=.7?s.splitRatio:t.splitRatio,navCollapsed:typeof s.navCollapsed=="boolean"?s.navCollapsed:t.navCollapsed,navGroupsCollapsed:typeof s.navGroupsCollapsed=="object"&&s.navGroupsCollapsed!==null?s.navGroupsCollapsed:t.navGroupsCollapsed}}catch{return t}}function hl(e){localStorage.setItem(ta,JSON.stringify(e))}function na(e){const t=(e??"").trim();if(!t)return null;const n=t.split(":").filter(Boolean);if(n.length<3||n[0]!=="agent")return null;const s=n[1]?.trim(),i=n.slice(2).join(":");return!s||!i?null:{agentId:s,rest:i}}const gl=[{label:"Chat",tabs:["chat"]},{label:"Control",tabs:["overview","channels","instances","sessions","cron"]},{label:"Agent",tabs:["skills","nodes"]},{label:"Settings",tabs:["config","debug","logs"]}],sa={overview:"/overview",channels:"/channels",instances:"/instances",sessions:"/sessions",cron:"/cron",skills:"/skills",nodes:"/nodes",chat:"/chat",config:"/config",debug:"/debug",logs:"/logs"},ia=new Map(Object.entries(sa).map(([e,t])=>[t,e]));function rn(e){if(!e)return"";let t=e.trim();return t.startsWith("/")||(t=`/${t}`),t==="/"?"":(t.endsWith("/")&&(t=t.slice(0,-1)),t)}function kt(e){if(!e)return"/";let t=e.trim();return t.startsWith("/")||(t=`/${t}`),t.length>1&&t.endsWith("/")&&(t=t.slice(0,-1)),t}function Ps(e,t=""){const n=rn(t),s=sa[e];return n?`${n}${s}`:s}function oa(e,t=""){const n=rn(t);let s=e||"/";n&&(s===n?s="/":s.startsWith(`${n}/`)&&(s=s.slice(n.length)));let i=kt(s).toLowerCase();return i.endsWith("/index.html")&&(i="/"),i==="/"?"chat":ia.get(i)??null}function vl(e){let t=kt(e);if(t.endsWith("/index.html")&&(t=kt(t.slice(0,-11))),t==="/")return"";const n=t.split("/").filter(Boolean);if(n.length===0)return"";for(let s=0;s<n.length;s++){const i=`/${n.slice(s).join("/")}`.toLowerCase();if(ia.has(i)){const o=n.slice(0,s);return o.length?`/${o.join("/")}`:""}}return`/${n.join("/")}`}function ml(e){switch(e){case"chat":return"💬";case"overview":return"📊";case"channels":return"🔗";case"instances":return"📡";case"sessions":return"📄";case"cron":return"⏰";case"skills":return"⚡️";case"nodes":return"🖥️";case"config":return"⚙️";case"debug":return"🐞";case"logs":return"🧾";default:return"📁"}}function is(e){switch(e){case"overview":return"Overview";case"channels":return"Channels";case"instances":return"Instances";case"sessions":return"Sessions";case"cron":return"Cron Jobs";case"skills":return"Skills";case"nodes":return"Nodes";case"chat":return"Chat";case"config":return"Config";case"debug":return"Debug";case"logs":return"Logs";default:return"Control"}}function bl(e){switch(e){case"overview":return"Gateway status, entry points, and a fast health read.";case"channels":return"Manage channels and settings.";case"instances":return"Presence beacons from connected clients and nodes.";case"sessions":return"Inspect active sessions and adjust per-session defaults.";case"cron":return"Schedule wakeups and recurring agent runs.";case"skills":return"Manage skill availability and API key injection.";case"nodes":return"Paired devices, capabilities, and command exposure.";case"chat":return"Direct gateway chat session for quick interventions.";case"config":return"Edit ~/.pigbot/pigbot.json safely.";case"debug":return"Gateway snapshots, events, and manual RPC calls.";case"logs":return"Live tail of the gateway file logs.";default:return""}}const yl=/<\s*\/?\s*(?:think(?:ing)?|thought|antthinking|final)\b/i,Ot=/<\s*\/?\s*final\b[^>]*>/gi,Gi=/<\s*(\/?)\s*(?:think(?:ing)?|thought|antthinking)\b[^>]*>/gi;function wl(e,t){return e.trimStart()}function $l(e,t){if(!e||!yl.test(e))return e;let n=e;Ot.test(n)?(Ot.lastIndex=0,n=n.replace(Ot,"")):Ot.lastIndex=0,Gi.lastIndex=0;let s="",i=0,o=!1;for(const a of n.matchAll(Gi)){const l=a.index??0,r=a[1]==="/";o?r&&(o=!1):(s+=n.slice(i,l),r||(o=!0)),i=l+a[0].length}return s+=n.slice(i),wl(s)}function xt(e){return!e&&e!==0?"n/a":new Date(e).toLocaleString()}function O(e){if(!e&&e!==0)return"n/a";const t=Date.now()-e;if(t<0)return"just now";const n=Math.round(t/1e3);if(n<60)return`${n}s ago`;const s=Math.round(n/60);if(s<60)return`${s}m ago`;const i=Math.round(s/60);return i<48?`${i}h ago`:`${Math.round(i/24)}d ago`}function aa(e){if(!e&&e!==0)return"n/a";if(e<1e3)return`${e}ms`;const t=Math.round(e/1e3);if(t<60)return`${t}s`;const n=Math.round(t/60);if(n<60)return`${n}m`;const s=Math.round(n/60);return s<48?`${s}h`:`${Math.round(s/24)}d`}function os(e){return!e||e.length===0?"none":e.filter(t=>!!(t&&t.trim())).join(", ")}function as(e,t=120){return e.length<=t?e:`${e.slice(0,Math.max(0,t-1))}…`}function ra(e,t){return e.length<=t?{text:e,truncated:!1,total:e.length}:{text:e.slice(0,Math.max(0,t)),truncated:!0,total:e.length}}function Qt(e,t){const n=Number(e);return Number.isFinite(n)?n:t}function Dn(e){return $l(e)}const kl=/^\[([^\]]+)\]\s*/,xl=["WebChat","WhatsApp","Telegram","Signal","Slack","Discord","iMessage","Teams","Matrix","Zalo","Zalo Personal","BlueBubbles"],Bn=new WeakMap,Fn=new WeakMap;function Al(e){return/\d{4}-\d{2}-\d{2}T\d{2}:\d{2}Z\b/.test(e)||/\d{4}-\d{2}-\d{2} \d{2}:\d{2}\b/.test(e)?!0:xl.some(t=>e.startsWith(`${t} `))}function Un(e){const t=e.match(kl);if(!t)return e;const n=t[1]??"";return Al(n)?e.slice(t[0].length):e}function rs(e){const t=e,n=typeof t.role=="string"?t.role:"",s=t.content;if(typeof s=="string")return n==="assistant"?Dn(s):Un(s);if(Array.isArray(s)){const i=s.map(o=>{const a=o;return a.type==="text"&&typeof a.text=="string"?a.text:null}).filter(o=>typeof o=="string");if(i.length>0){const o=i.join(`
4
- `);return n==="assistant"?Dn(o):Un(o)}}return typeof t.text=="string"?n==="assistant"?Dn(t.text):Un(t.text):null}function la(e){if(!e||typeof e!="object")return rs(e);const t=e;if(Bn.has(t))return Bn.get(t)??null;const n=rs(e);return Bn.set(t,n),n}function Vi(e){const n=e.content,s=[];if(Array.isArray(n))for(const l of n){const r=l;if(r.type==="thinking"&&typeof r.thinking=="string"){const p=r.thinking.trim();p&&s.push(p)}}if(s.length>0)return s.join(`
5
- `);const i=_l(e);if(!i)return null;const a=[...i.matchAll(/<\s*think(?:ing)?\s*>([\s\S]*?)<\s*\/\s*think(?:ing)?\s*>/gi)].map(l=>(l[1]??"").trim()).filter(Boolean);return a.length>0?a.join(`
6
- `):null}function Sl(e){if(!e||typeof e!="object")return Vi(e);const t=e;if(Fn.has(t))return Fn.get(t)??null;const n=Vi(e);return Fn.set(t,n),n}function _l(e){const t=e,n=t.content;if(typeof n=="string")return n;if(Array.isArray(n)){const s=n.map(i=>{const o=i;return o.type==="text"&&typeof o.text=="string"?o.text:null}).filter(i=>typeof i=="string");if(s.length>0)return s.join(`
7
- `)}return typeof t.text=="string"?t.text:null}function Tl(e){const t=e.trim();if(!t)return"";const n=t.split(/\r?\n/).map(s=>s.trim()).filter(Boolean).map(s=>`_${s}_`);return n.length?["_Reasoning:_",...n].join(`
8
- `):""}function Yi(e){e[6]=e[6]&15|64,e[8]=e[8]&63|128;let t="";for(let n=0;n<e.length;n++)t+=e[n].toString(16).padStart(2,"0");return`${t.slice(0,8)}-${t.slice(8,12)}-${t.slice(12,16)}-${t.slice(16,20)}-${t.slice(20)}`}function Cl(){const e=new Uint8Array(16),t=Date.now();for(let n=0;n<e.length;n++)e[n]=Math.floor(Math.random()*256);return e[0]^=t&255,e[1]^=t>>>8&255,e[2]^=t>>>16&255,e[3]^=t>>>24&255,e}function Ns(e=globalThis.crypto){if(e&&typeof e.randomUUID=="function")return e.randomUUID();if(e&&typeof e.getRandomValues=="function"){const t=new Uint8Array(16);return e.getRandomValues(t),Yi(t)}return Yi(Cl())}async function Ze(e){if(!(!e.client||!e.connected)){e.chatLoading=!0,e.lastError=null;try{const t=await e.client.request("chat.history",{sessionKey:e.sessionKey,limit:200});e.chatMessages=Array.isArray(t.messages)?t.messages:[],e.chatThinkingLevel=t.thinkingLevel??null}catch(t){e.lastError=String(t)}finally{e.chatLoading=!1}}}async function El(e,t){if(!e.client||!e.connected)return!1;const n=t.trim();if(!n)return!1;const s=Date.now();e.chatMessages=[...e.chatMessages,{role:"user",content:[{type:"text",text:n}],timestamp:s}],e.chatSending=!0,e.lastError=null;const i=Ns();e.chatRunId=i,e.chatStream="",e.chatStreamStartedAt=s;try{return await e.client.request("chat.send",{sessionKey:e.sessionKey,message:n,deliver:!1,idempotencyKey:i}),!0}catch(o){const a=String(o);return e.chatRunId=null,e.chatStream=null,e.chatStreamStartedAt=null,e.lastError=a,e.chatMessages=[...e.chatMessages,{role:"assistant",content:[{type:"text",text:"Error: "+a}],timestamp:Date.now()}],!1}finally{e.chatSending=!1}}async function Il(e){if(!e.client||!e.connected)return!1;const t=e.chatRunId;try{return await e.client.request("chat.abort",t?{sessionKey:e.sessionKey,runId:t}:{sessionKey:e.sessionKey}),!0}catch(n){return e.lastError=String(n),!1}}function Rl(e,t){if(!t||t.sessionKey!==e.sessionKey||t.runId&&e.chatRunId&&t.runId!==e.chatRunId)return null;if(t.state==="delta"){const n=rs(t.message);if(typeof n=="string"){const s=e.chatStream??"";(!s||n.length>=s.length)&&(e.chatStream=n)}}else t.state==="final"||t.state==="aborted"?(e.chatStream=null,e.chatRunId=null,e.chatStreamStartedAt=null):t.state==="error"&&(e.chatStream=null,e.chatRunId=null,e.chatStreamStartedAt=null,e.lastError=t.errorMessage??"chat error");return t.state}async function nt(e){if(!(!e.client||!e.connected)&&!e.sessionsLoading){e.sessionsLoading=!0,e.sessionsError=null;try{const t={includeGlobal:e.sessionsIncludeGlobal,includeUnknown:e.sessionsIncludeUnknown},n=Qt(e.sessionsFilterActive,0),s=Qt(e.sessionsFilterLimit,0);n>0&&(t.activeMinutes=n),s>0&&(t.limit=s);const i=await e.client.request("sessions.list",t);i&&(e.sessionsResult=i)}catch(t){e.sessionsError=String(t)}finally{e.sessionsLoading=!1}}}async function Ll(e,t,n){if(!e.client||!e.connected)return;const s={key:t};"label"in n&&(s.label=n.label),"thinkingLevel"in n&&(s.thinkingLevel=n.thinkingLevel),"verboseLevel"in n&&(s.verboseLevel=n.verboseLevel),"reasoningLevel"in n&&(s.reasoningLevel=n.reasoningLevel);try{await e.client.request("sessions.patch",s),await nt(e)}catch(i){e.sessionsError=String(i)}}async function Ml(e,t){if(!(!e.client||!e.connected||e.sessionsLoading||!window.confirm(`Delete session "${t}"?
9
-
10
- Deletes the session entry and archives its transcript.`))){e.sessionsLoading=!0,e.sessionsError=null;try{await e.client.request("sessions.delete",{key:t,deleteTranscript:!0}),await nt(e)}catch(s){e.sessionsError=String(s)}finally{e.sessionsLoading=!1}}}const Qi=50,Pl=80,Nl=12e4;function Ol(e){if(!e||typeof e!="object")return null;const t=e;if(typeof t.text=="string")return t.text;const n=t.content;if(!Array.isArray(n))return null;const s=n.map(i=>{if(!i||typeof i!="object")return null;const o=i;return o.type==="text"&&typeof o.text=="string"?o.text:null}).filter(i=>!!i);return s.length===0?null:s.join(`
11
- `)}function Ji(e){if(e==null)return null;if(typeof e=="number"||typeof e=="boolean")return String(e);const t=Ol(e);let n;if(typeof e=="string")n=e;else if(t)n=t;else try{n=JSON.stringify(e,null,2)}catch{n=String(e)}const s=ra(n,Nl);return s.truncated?`${s.text}
12
-
13
- … truncated (${s.total} chars, showing first ${s.text.length}).`:s.text}function Dl(e){const t=[];return t.push({type:"toolcall",name:e.name,arguments:e.args??{}}),e.output&&t.push({type:"toolresult",name:e.name,text:e.output}),{role:"assistant",toolCallId:e.toolCallId,runId:e.runId,content:t,timestamp:e.startedAt}}function Bl(e){if(e.toolStreamOrder.length<=Qi)return;const t=e.toolStreamOrder.length-Qi,n=e.toolStreamOrder.splice(0,t);for(const s of n)e.toolStreamById.delete(s)}function Fl(e){e.chatToolMessages=e.toolStreamOrder.map(t=>e.toolStreamById.get(t)?.message).filter(t=>!!t)}function ls(e){e.toolStreamSyncTimer!=null&&(clearTimeout(e.toolStreamSyncTimer),e.toolStreamSyncTimer=null),Fl(e)}function Ul(e,t=!1){if(t){ls(e);return}e.toolStreamSyncTimer==null&&(e.toolStreamSyncTimer=window.setTimeout(()=>ls(e),Pl))}function Os(e){e.toolStreamById.clear(),e.toolStreamOrder=[],e.chatToolMessages=[],ls(e)}const Kl=5e3;function Hl(e,t){const n=t.data??{},s=typeof n.phase=="string"?n.phase:"";e.compactionClearTimer!=null&&(window.clearTimeout(e.compactionClearTimer),e.compactionClearTimer=null),s==="start"?e.compactionStatus={active:!0,startedAt:Date.now(),completedAt:null}:s==="end"&&(e.compactionStatus={active:!1,startedAt:e.compactionStatus?.startedAt??null,completedAt:Date.now()},e.compactionClearTimer=window.setTimeout(()=>{e.compactionStatus=null,e.compactionClearTimer=null},Kl))}function zl(e,t){if(!t)return;if(t.stream==="compaction"){Hl(e,t);return}if(t.stream!=="tool")return;const n=typeof t.sessionKey=="string"?t.sessionKey:void 0;if(n&&n!==e.sessionKey||!n&&e.chatRunId&&t.runId!==e.chatRunId||e.chatRunId&&t.runId!==e.chatRunId||!e.chatRunId)return;const s=t.data??{},i=typeof s.toolCallId=="string"?s.toolCallId:"";if(!i)return;const o=typeof s.name=="string"?s.name:"tool",a=typeof s.phase=="string"?s.phase:"",l=a==="start"?s.args:void 0,r=a==="update"?Ji(s.partialResult):a==="result"?Ji(s.result):void 0,p=Date.now();let d=e.toolStreamById.get(i);d?(d.name=o,l!==void 0&&(d.args=l),r!==void 0&&(d.output=r),d.updatedAt=p):(d={toolCallId:i,runId:t.runId,sessionKey:n,name:o,args:l,output:r,startedAt:typeof t.ts=="number"?t.ts:p,updatedAt:p,message:{}},e.toolStreamById.set(i,d),e.toolStreamOrder.push(i)),d.message=Dl(d),Bl(e),Ul(e,a==="result")}function ln(e,t=!1){e.chatScrollFrame&&cancelAnimationFrame(e.chatScrollFrame),e.chatScrollTimeout!=null&&(clearTimeout(e.chatScrollTimeout),e.chatScrollTimeout=null);const n=()=>{const s=e.querySelector(".chat-thread");if(s){const i=getComputedStyle(s).overflowY;if(i==="auto"||i==="scroll"||s.scrollHeight-s.clientHeight>1)return s}return document.scrollingElement??document.documentElement};e.updateComplete.then(()=>{e.chatScrollFrame=requestAnimationFrame(()=>{e.chatScrollFrame=null;const s=n();if(!s)return;const i=s.scrollHeight-s.scrollTop-s.clientHeight;if(!(t||e.chatUserNearBottom||i<200))return;t&&(e.chatHasAutoScrolled=!0),s.scrollTop=s.scrollHeight,e.chatUserNearBottom=!0;const a=t?150:120;e.chatScrollTimeout=window.setTimeout(()=>{e.chatScrollTimeout=null;const l=n();if(!l)return;const r=l.scrollHeight-l.scrollTop-l.clientHeight;(t||e.chatUserNearBottom||r<200)&&(l.scrollTop=l.scrollHeight,e.chatUserNearBottom=!0)},a)})})}function ca(e,t=!1){e.logsScrollFrame&&cancelAnimationFrame(e.logsScrollFrame),e.updateComplete.then(()=>{e.logsScrollFrame=requestAnimationFrame(()=>{e.logsScrollFrame=null;const n=e.querySelector(".log-stream");if(!n)return;const s=n.scrollHeight-n.scrollTop-n.clientHeight;(t||s<80)&&(n.scrollTop=n.scrollHeight)})})}function jl(e,t){const n=t.currentTarget;if(!n)return;const s=n.scrollHeight-n.scrollTop-n.clientHeight;e.chatUserNearBottom=s<200}function ql(e,t){const n=t.currentTarget;if(!n)return;const s=n.scrollHeight-n.scrollTop-n.clientHeight;e.logsAtBottom=s<80}function Wl(e){e.chatHasAutoScrolled=!1,e.chatUserNearBottom=!0}function Gl(e,t){if(e.length===0)return;const n=new Blob([`${e.join(`
14
- `)}
15
- `],{type:"text/plain"}),s=URL.createObjectURL(n),i=document.createElement("a"),o=new Date().toISOString().slice(0,19).replace(/[:T]/g,"-");i.href=s,i.download=`pigbot-logs-${t}-${o}.log`,i.click(),URL.revokeObjectURL(s)}function Vl(e){if(typeof ResizeObserver>"u")return;const t=e.querySelector(".topbar");if(!t)return;const n=()=>{const{height:s}=t.getBoundingClientRect();e.style.setProperty("--topbar-height",`${s}px`)};n(),e.topbarObserver=new ResizeObserver(()=>n()),e.topbarObserver.observe(t)}function Oe(e){return typeof structuredClone=="function"?structuredClone(e):JSON.parse(JSON.stringify(e))}function Xe(e){return`${JSON.stringify(e,null,2).trimEnd()}
16
- `}function da(e,t,n){if(t.length===0)return;let s=e;for(let o=0;o<t.length-1;o+=1){const a=t[o],l=t[o+1];if(typeof a=="number"){if(!Array.isArray(s))return;s[a]==null&&(s[a]=typeof l=="number"?[]:{}),s=s[a]}else{if(typeof s!="object"||s==null)return;const r=s;r[a]==null&&(r[a]=typeof l=="number"?[]:{}),s=r[a]}}const i=t[t.length-1];if(typeof i=="number"){Array.isArray(s)&&(s[i]=n);return}typeof s=="object"&&s!=null&&(s[i]=n)}function ua(e,t){if(t.length===0)return;let n=e;for(let i=0;i<t.length-1;i+=1){const o=t[i];if(typeof o=="number"){if(!Array.isArray(n))return;n=n[o]}else{if(typeof n!="object"||n==null)return;n=n[o]}if(n==null)return}const s=t[t.length-1];if(typeof s=="number"){Array.isArray(n)&&n.splice(s,1);return}typeof n=="object"&&n!=null&&delete n[s]}async function me(e){if(!(!e.client||!e.connected)){e.configLoading=!0,e.lastError=null;try{const t=await e.client.request("config.get",{});Ql(e,t)}catch(t){e.lastError=String(t)}finally{e.configLoading=!1}}}async function pa(e){if(!(!e.client||!e.connected)&&!e.configSchemaLoading){e.configSchemaLoading=!0;try{const t=await e.client.request("config.schema",{});Yl(e,t)}catch(t){e.lastError=String(t)}finally{e.configSchemaLoading=!1}}}function Yl(e,t){e.configSchema=t.schema??null,e.configUiHints=t.uiHints??{},e.configSchemaVersion=t.version??null}function Ql(e,t){e.configSnapshot=t;const n=typeof t.raw=="string"?t.raw:t.config&&typeof t.config=="object"?Xe(t.config):e.configRaw;!e.configFormDirty||e.configFormMode==="raw"?e.configRaw=n:e.configForm?e.configRaw=Xe(e.configForm):e.configRaw=n,e.configValid=typeof t.valid=="boolean"?t.valid:null,e.configIssues=Array.isArray(t.issues)?t.issues:[],e.configFormDirty||(e.configForm=Oe(t.config??{}),e.configFormOriginal=Oe(t.config??{}),e.configRawOriginal=n)}async function cs(e){if(!(!e.client||!e.connected)){e.configSaving=!0,e.lastError=null;try{const t=e.configFormMode==="form"&&e.configForm?Xe(e.configForm):e.configRaw,n=e.configSnapshot?.hash;if(!n){e.lastError="Config hash missing; reload and retry.";return}await e.client.request("config.set",{raw:t,baseHash:n}),e.configFormDirty=!1,await me(e)}catch(t){e.lastError=String(t)}finally{e.configSaving=!1}}}async function Jl(e){if(!(!e.client||!e.connected)){e.configApplying=!0,e.lastError=null;try{const t=e.configFormMode==="form"&&e.configForm?Xe(e.configForm):e.configRaw,n=e.configSnapshot?.hash;if(!n){e.lastError="Config hash missing; reload and retry.";return}await e.client.request("config.apply",{raw:t,baseHash:n,sessionKey:e.applySessionKey}),e.configFormDirty=!1,await me(e)}catch(t){e.lastError=String(t)}finally{e.configApplying=!1}}}async function Zl(e){if(!(!e.client||!e.connected)){e.updateRunning=!0,e.lastError=null;try{await e.client.request("update.run",{sessionKey:e.applySessionKey})}catch(t){e.lastError=String(t)}finally{e.updateRunning=!1}}}function Dt(e,t,n){const s=Oe(e.configForm??e.configSnapshot?.config??{});da(s,t,n),e.configForm=s,e.configFormDirty=!0,e.configFormMode==="form"&&(e.configRaw=Xe(s))}function Zi(e,t){const n=Oe(e.configForm??e.configSnapshot?.config??{});ua(n,t),e.configForm=n,e.configFormDirty=!0,e.configFormMode==="form"&&(e.configRaw=Xe(n))}async function _t(e){if(!(!e.client||!e.connected))try{const t=await e.client.request("cron.status",{});e.cronStatus=t}catch(t){e.cronError=String(t)}}async function cn(e){if(!(!e.client||!e.connected)&&!e.cronLoading){e.cronLoading=!0,e.cronError=null;try{const t=await e.client.request("cron.list",{includeDisabled:!0});e.cronJobs=Array.isArray(t.jobs)?t.jobs:[]}catch(t){e.cronError=String(t)}finally{e.cronLoading=!1}}}function Xl(e){if(e.scheduleKind==="at"){const n=Date.parse(e.scheduleAt);if(!Number.isFinite(n))throw new Error("Invalid run time.");return{kind:"at",atMs:n}}if(e.scheduleKind==="every"){const n=Qt(e.everyAmount,0);if(n<=0)throw new Error("Invalid interval amount.");const s=e.everyUnit;return{kind:"every",everyMs:n*(s==="minutes"?6e4:s==="hours"?36e5:864e5)}}const t=e.cronExpr.trim();if(!t)throw new Error("Cron expression required.");return{kind:"cron",expr:t,tz:e.cronTz.trim()||void 0}}function ec(e){if(e.payloadKind==="systemEvent"){const i=e.payloadText.trim();if(!i)throw new Error("System event text required.");return{kind:"systemEvent",text:i}}const t=e.payloadText.trim();if(!t)throw new Error("Agent message required.");const n={kind:"agentTurn",message:t};e.deliver&&(n.deliver=!0),e.channel&&(n.channel=e.channel),e.to.trim()&&(n.to=e.to.trim());const s=Qt(e.timeoutSeconds,0);return s>0&&(n.timeoutSeconds=s),n}async function tc(e){if(!(!e.client||!e.connected||e.cronBusy)){e.cronBusy=!0,e.cronError=null;try{const t=Xl(e.cronForm),n=ec(e.cronForm),s=e.cronForm.agentId.trim(),i={name:e.cronForm.name.trim(),description:e.cronForm.description.trim()||void 0,agentId:s||void 0,enabled:e.cronForm.enabled,schedule:t,sessionTarget:e.cronForm.sessionTarget,wakeMode:e.cronForm.wakeMode,payload:n,isolation:e.cronForm.postToMainPrefix.trim()&&e.cronForm.sessionTarget==="isolated"?{postToMainPrefix:e.cronForm.postToMainPrefix.trim()}:void 0};if(!i.name)throw new Error("Name required.");await e.client.request("cron.add",i),e.cronForm={...e.cronForm,name:"",description:"",payloadText:""},await cn(e),await _t(e)}catch(t){e.cronError=String(t)}finally{e.cronBusy=!1}}}async function nc(e,t,n){if(!(!e.client||!e.connected||e.cronBusy)){e.cronBusy=!0,e.cronError=null;try{await e.client.request("cron.update",{id:t.id,patch:{enabled:n}}),await cn(e),await _t(e)}catch(s){e.cronError=String(s)}finally{e.cronBusy=!1}}}async function sc(e,t){if(!(!e.client||!e.connected||e.cronBusy)){e.cronBusy=!0,e.cronError=null;try{await e.client.request("cron.run",{id:t.id,mode:"force"}),await fa(e,t.id)}catch(n){e.cronError=String(n)}finally{e.cronBusy=!1}}}async function ic(e,t){if(!(!e.client||!e.connected||e.cronBusy)){e.cronBusy=!0,e.cronError=null;try{await e.client.request("cron.remove",{id:t.id}),e.cronRunsJobId===t.id&&(e.cronRunsJobId=null,e.cronRuns=[]),await cn(e),await _t(e)}catch(n){e.cronError=String(n)}finally{e.cronBusy=!1}}}async function fa(e,t){if(!(!e.client||!e.connected))try{const n=await e.client.request("cron.runs",{id:t,limit:50});e.cronRunsJobId=t,e.cronRuns=Array.isArray(n.entries)?n.entries:[]}catch(n){e.cronError=String(n)}}async function oe(e,t){if(!(!e.client||!e.connected)&&!e.channelsLoading){e.channelsLoading=!0,e.channelsError=null;try{const n=await e.client.request("channels.status",{probe:t,timeoutMs:8e3});e.channelsSnapshot=n,e.channelsLastSuccess=Date.now()}catch(n){e.channelsError=String(n)}finally{e.channelsLoading=!1}}}async function oc(e,t){if(!(!e.client||!e.connected||e.whatsappBusy)){e.whatsappBusy=!0;try{const n=await e.client.request("web.login.start",{force:t,timeoutMs:3e4});e.whatsappLoginMessage=n.message??null,e.whatsappLoginQrDataUrl=n.qrDataUrl??null,e.whatsappLoginConnected=null}catch(n){e.whatsappLoginMessage=String(n),e.whatsappLoginQrDataUrl=null,e.whatsappLoginConnected=null}finally{e.whatsappBusy=!1}}}async function ac(e){if(!(!e.client||!e.connected||e.whatsappBusy)){e.whatsappBusy=!0;try{const t=await e.client.request("web.login.wait",{timeoutMs:12e4});e.whatsappLoginMessage=t.message??null,e.whatsappLoginConnected=t.connected??null,t.connected&&(e.whatsappLoginQrDataUrl=null)}catch(t){e.whatsappLoginMessage=String(t),e.whatsappLoginConnected=null}finally{e.whatsappBusy=!1}}}async function rc(e){if(!(!e.client||!e.connected||e.whatsappBusy)){e.whatsappBusy=!0;try{await e.client.request("channels.logout",{channel:"whatsapp"}),e.whatsappLoginMessage="Logged out.",e.whatsappLoginQrDataUrl=null,e.whatsappLoginConnected=null}catch(t){e.whatsappLoginMessage=String(t)}finally{e.whatsappBusy=!1}}}async function dn(e){if(!(!e.client||!e.connected)&&!e.debugLoading){e.debugLoading=!0;try{const[t,n,s,i]=await Promise.all([e.client.request("status",{}),e.client.request("health",{}),e.client.request("models.list",{}),e.client.request("last-heartbeat",{})]);e.debugStatus=t,e.debugHealth=n;const o=s;e.debugModels=Array.isArray(o?.models)?o?.models:[],e.debugHeartbeat=i}catch(t){e.debugCallError=String(t)}finally{e.debugLoading=!1}}}async function lc(e){if(!(!e.client||!e.connected)){e.debugCallError=null,e.debugCallResult=null;try{const t=e.debugCallParams.trim()?JSON.parse(e.debugCallParams):{},n=await e.client.request(e.debugCallMethod.trim(),t);e.debugCallResult=JSON.stringify(n,null,2)}catch(t){e.debugCallError=String(t)}}}const cc=2e3,dc=new Set(["trace","debug","info","warn","error","fatal"]);function uc(e){if(typeof e!="string")return null;const t=e.trim();if(!t.startsWith("{")||!t.endsWith("}"))return null;try{const n=JSON.parse(t);return!n||typeof n!="object"?null:n}catch{return null}}function pc(e){if(typeof e!="string")return null;const t=e.toLowerCase();return dc.has(t)?t:null}function fc(e){if(!e.trim())return{raw:e,message:e};try{const t=JSON.parse(e),n=t&&typeof t._meta=="object"&&t._meta!==null?t._meta:null,s=typeof t.time=="string"?t.time:typeof n?.date=="string"?n?.date:null,i=pc(n?.logLevelName??n?.level),o=typeof t[0]=="string"?t[0]:typeof n?.name=="string"?n?.name:null,a=uc(o);let l=null;a&&(typeof a.subsystem=="string"?l=a.subsystem:typeof a.module=="string"&&(l=a.module)),!l&&o&&o.length<120&&(l=o);let r=null;return typeof t[1]=="string"?r=t[1]:!a&&typeof t[0]=="string"?r=t[0]:typeof t.message=="string"&&(r=t.message),{raw:e,time:s,level:i,subsystem:l,message:r??e,meta:n??void 0}}catch{return{raw:e,message:e}}}async function Ds(e,t){if(!(!e.client||!e.connected)&&!(e.logsLoading&&!t?.quiet)){t?.quiet||(e.logsLoading=!0),e.logsError=null;try{const s=await e.client.request("logs.tail",{cursor:t?.reset?void 0:e.logsCursor??void 0,limit:e.logsLimit,maxBytes:e.logsMaxBytes}),o=(Array.isArray(s.lines)?s.lines.filter(l=>typeof l=="string"):[]).map(fc),a=!!(t?.reset||s.reset||e.logsCursor==null);e.logsEntries=a?o:[...e.logsEntries,...o].slice(-cc),typeof s.cursor=="number"&&(e.logsCursor=s.cursor),typeof s.file=="string"&&(e.logsFile=s.file),e.logsTruncated=!!s.truncated,e.logsLastFetchAt=Date.now()}catch(n){e.logsError=String(n)}finally{t?.quiet||(e.logsLoading=!1)}}}const ha={p:0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffedn,n:0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3edn,h:8n,a:0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffecn,d:0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3n,Gx:0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51an,Gy:0x6666666666666666666666666666666666666666666666666666666666666658n},{p:W,n:Wt,Gx:Xi,Gy:eo,a:Kn,d:Hn,h:hc}=ha,De=32,Bs=64,gc=(...e)=>{"captureStackTrace"in Error&&typeof Error.captureStackTrace=="function"&&Error.captureStackTrace(...e)},H=(e="")=>{const t=new Error(e);throw gc(t,H),t},vc=e=>typeof e=="bigint",mc=e=>typeof e=="string",bc=e=>e instanceof Uint8Array||ArrayBuffer.isView(e)&&e.constructor.name==="Uint8Array",Se=(e,t,n="")=>{const s=bc(e),i=e?.length,o=t!==void 0;if(!s||o&&i!==t){const a=n&&`"${n}" `,l=o?` of length ${t}`:"",r=s?`length=${i}`:`type=${typeof e}`;H(a+"expected Uint8Array"+l+", got "+r)}return e},un=e=>new Uint8Array(e),ga=e=>Uint8Array.from(e),va=(e,t)=>e.toString(16).padStart(t,"0"),ma=e=>Array.from(Se(e)).map(t=>va(t,2)).join(""),ge={_0:48,_9:57,A:65,F:70,a:97,f:102},to=e=>{if(e>=ge._0&&e<=ge._9)return e-ge._0;if(e>=ge.A&&e<=ge.F)return e-(ge.A-10);if(e>=ge.a&&e<=ge.f)return e-(ge.a-10)},ba=e=>{const t="hex invalid";if(!mc(e))return H(t);const n=e.length,s=n/2;if(n%2)return H(t);const i=un(s);for(let o=0,a=0;o<s;o++,a+=2){const l=to(e.charCodeAt(a)),r=to(e.charCodeAt(a+1));if(l===void 0||r===void 0)return H(t);i[o]=l*16+r}return i},ya=()=>globalThis?.crypto,yc=()=>ya()?.subtle??H("crypto.subtle must be defined, consider polyfill"),At=(...e)=>{const t=un(e.reduce((s,i)=>s+Se(i).length,0));let n=0;return e.forEach(s=>{t.set(s,n),n+=s.length}),t},wc=(e=De)=>ya().getRandomValues(un(e)),Jt=BigInt,Le=(e,t,n,s="bad number: out of range")=>vc(e)&&t<=e&&e<n?e:H(s),A=(e,t=W)=>{const n=e%t;return n>=0n?n:t+n},wa=e=>A(e,Wt),$c=(e,t)=>{(e===0n||t<=0n)&&H("no inverse n="+e+" mod="+t);let n=A(e,t),s=t,i=0n,o=1n;for(;n!==0n;){const a=s/n,l=s%n,r=i-o*a;s=n,n=l,i=o,o=r}return s===1n?A(i,t):H("no inverse")},kc=e=>{const t=Aa[e];return typeof t!="function"&&H("hashes."+e+" not set"),t},zn=e=>e instanceof X?e:H("Point expected"),ds=2n**256n;class X{static BASE;static ZERO;X;Y;Z;T;constructor(t,n,s,i){const o=ds;this.X=Le(t,0n,o),this.Y=Le(n,0n,o),this.Z=Le(s,1n,o),this.T=Le(i,0n,o),Object.freeze(this)}static CURVE(){return ha}static fromAffine(t){return new X(t.x,t.y,1n,A(t.x*t.y))}static fromBytes(t,n=!1){const s=Hn,i=ga(Se(t,De)),o=t[31];i[31]=o&-129;const a=ka(i);Le(a,0n,n?ds:W);const r=A(a*a),p=A(r-1n),d=A(s*r+1n);let{isValid:u,value:h}=Ac(p,d);u||H("bad point: y not sqrt");const v=(h&1n)===1n,w=(o&128)!==0;return!n&&h===0n&&w&&H("bad point: x==0, isLastByteOdd"),w!==v&&(h=A(-h)),new X(h,a,1n,A(h*a))}static fromHex(t,n){return X.fromBytes(ba(t),n)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}assertValidity(){const t=Kn,n=Hn,s=this;if(s.is0())return H("bad point: ZERO");const{X:i,Y:o,Z:a,T:l}=s,r=A(i*i),p=A(o*o),d=A(a*a),u=A(d*d),h=A(r*t),v=A(d*A(h+p)),w=A(u+A(n*A(r*p)));if(v!==w)return H("bad point: equation left != right (1)");const $=A(i*o),x=A(a*l);return $!==x?H("bad point: equation left != right (2)"):this}equals(t){const{X:n,Y:s,Z:i}=this,{X:o,Y:a,Z:l}=zn(t),r=A(n*l),p=A(o*i),d=A(s*l),u=A(a*i);return r===p&&d===u}is0(){return this.equals(Ye)}negate(){return new X(A(-this.X),this.Y,this.Z,A(-this.T))}double(){const{X:t,Y:n,Z:s}=this,i=Kn,o=A(t*t),a=A(n*n),l=A(2n*A(s*s)),r=A(i*o),p=t+n,d=A(A(p*p)-o-a),u=r+a,h=u-l,v=r-a,w=A(d*h),$=A(u*v),x=A(d*v),T=A(h*u);return new X(w,$,T,x)}add(t){const{X:n,Y:s,Z:i,T:o}=this,{X:a,Y:l,Z:r,T:p}=zn(t),d=Kn,u=Hn,h=A(n*a),v=A(s*l),w=A(o*u*p),$=A(i*r),x=A((n+s)*(a+l)-h-v),T=A($-w),R=A($+w),P=A(v-d*h),I=A(x*T),C=A(R*P),E=A(x*P),ue=A(T*R);return new X(I,C,ue,E)}subtract(t){return this.add(zn(t).negate())}multiply(t,n=!0){if(!n&&(t===0n||this.is0()))return Ye;if(Le(t,1n,Wt),t===1n)return this;if(this.equals(Be))return Nc(t).p;let s=Ye,i=Be;for(let o=this;t>0n;o=o.double(),t>>=1n)t&1n?s=s.add(o):n&&(i=i.add(o));return s}multiplyUnsafe(t){return this.multiply(t,!1)}toAffine(){const{X:t,Y:n,Z:s}=this;if(this.equals(Ye))return{x:0n,y:1n};const i=$c(s,W);A(s*i)!==1n&&H("invalid inverse");const o=A(t*i),a=A(n*i);return{x:o,y:a}}toBytes(){const{x:t,y:n}=this.assertValidity().toAffine(),s=$a(n);return s[31]|=t&1n?128:0,s}toHex(){return ma(this.toBytes())}clearCofactor(){return this.multiply(Jt(hc),!1)}isSmallOrder(){return this.clearCofactor().is0()}isTorsionFree(){let t=this.multiply(Wt/2n,!1).double();return Wt%2n&&(t=t.add(this)),t.is0()}}const Be=new X(Xi,eo,1n,A(Xi*eo)),Ye=new X(0n,1n,1n,0n);X.BASE=Be;X.ZERO=Ye;const $a=e=>ba(va(Le(e,0n,ds),Bs)).reverse(),ka=e=>Jt("0x"+ma(ga(Se(e)).reverse())),le=(e,t)=>{let n=e;for(;t-- >0n;)n*=n,n%=W;return n},xc=e=>{const n=e*e%W*e%W,s=le(n,2n)*n%W,i=le(s,1n)*e%W,o=le(i,5n)*i%W,a=le(o,10n)*o%W,l=le(a,20n)*a%W,r=le(l,40n)*l%W,p=le(r,80n)*r%W,d=le(p,80n)*r%W,u=le(d,10n)*o%W;return{pow_p_5_8:le(u,2n)*e%W,b2:n}},no=0x2b8324804fc1df0b2b4d00993dfbd7a72f431806ad2fe478c4ee1b274a0ea0b0n,Ac=(e,t)=>{const n=A(t*t*t),s=A(n*n*t),i=xc(e*s).pow_p_5_8;let o=A(e*n*i);const a=A(t*o*o),l=o,r=A(o*no),p=a===e,d=a===A(-e),u=a===A(-e*no);return p&&(o=l),(d||u)&&(o=r),(A(o)&1n)===1n&&(o=A(-o)),{isValid:p||d,value:o}},us=e=>wa(ka(e)),Fs=(...e)=>Aa.sha512Async(At(...e)),Sc=(...e)=>kc("sha512")(At(...e)),xa=e=>{const t=e.slice(0,De);t[0]&=248,t[31]&=127,t[31]|=64;const n=e.slice(De,Bs),s=us(t),i=Be.multiply(s),o=i.toBytes();return{head:t,prefix:n,scalar:s,point:i,pointBytes:o}},Us=e=>Fs(Se(e,De)).then(xa),_c=e=>xa(Sc(Se(e,De))),Tc=e=>Us(e).then(t=>t.pointBytes),Cc=e=>Fs(e.hashable).then(e.finish),Ec=(e,t,n)=>{const{pointBytes:s,scalar:i}=e,o=us(t),a=Be.multiply(o).toBytes();return{hashable:At(a,s,n),finish:p=>{const d=wa(o+us(p)*i);return Se(At(a,$a(d)),Bs)}}},Ic=async(e,t)=>{const n=Se(e),s=await Us(t),i=await Fs(s.prefix,n);return Cc(Ec(s,i,n))},Aa={sha512Async:async e=>{const t=yc(),n=At(e);return un(await t.digest("SHA-512",n.buffer))},sha512:void 0},Rc=(e=wc(De))=>e,Lc={getExtendedPublicKeyAsync:Us,getExtendedPublicKey:_c,randomSecretKey:Rc},Zt=8,Mc=256,Sa=Math.ceil(Mc/Zt)+1,ps=2**(Zt-1),Pc=()=>{const e=[];let t=Be,n=t;for(let s=0;s<Sa;s++){n=t,e.push(n);for(let i=1;i<ps;i++)n=n.add(t),e.push(n);t=n.double()}return e};let so;const io=(e,t)=>{const n=t.negate();return e?n:t},Nc=e=>{const t=so||(so=Pc());let n=Ye,s=Be;const i=2**Zt,o=i,a=Jt(i-1),l=Jt(Zt);for(let r=0;r<Sa;r++){let p=Number(e&a);e>>=l,p>ps&&(p-=o,e+=1n);const d=r*ps,u=d,h=d+Math.abs(p)-1,v=r%2!==0,w=p<0;p===0?s=s.add(io(v,t[u])):n=n.add(io(w,t[h]))}return e!==0n&&H("invalid wnaf"),{p:n,f:s}},jn="pigbot-device-identity-v1";function fs(e){let t="";for(const n of e)t+=String.fromCharCode(n);return btoa(t).replaceAll("+","-").replaceAll("/","_").replace(/=+$/g,"")}function _a(e){const t=e.replaceAll("-","+").replaceAll("_","/"),n=t+"=".repeat((4-t.length%4)%4),s=atob(n),i=new Uint8Array(s.length);for(let o=0;o<s.length;o+=1)i[o]=s.charCodeAt(o);return i}function Oc(e){return Array.from(e).map(t=>t.toString(16).padStart(2,"0")).join("")}async function Ta(e){const t=await crypto.subtle.digest("SHA-256",e);return Oc(new Uint8Array(t))}async function Dc(){const e=Lc.randomSecretKey(),t=await Tc(e);return{deviceId:await Ta(t),publicKey:fs(t),privateKey:fs(e)}}async function Ks(){try{const n=localStorage.getItem(jn);if(n){const s=JSON.parse(n);if(s?.version===1&&typeof s.deviceId=="string"&&typeof s.publicKey=="string"&&typeof s.privateKey=="string"){const i=await Ta(_a(s.publicKey));if(i!==s.deviceId){const o={...s,deviceId:i};return localStorage.setItem(jn,JSON.stringify(o)),{deviceId:i,publicKey:s.publicKey,privateKey:s.privateKey}}return{deviceId:s.deviceId,publicKey:s.publicKey,privateKey:s.privateKey}}}}catch{}const e=await Dc(),t={version:1,deviceId:e.deviceId,publicKey:e.publicKey,privateKey:e.privateKey,createdAtMs:Date.now()};return localStorage.setItem(jn,JSON.stringify(t)),e}async function Bc(e,t){const n=_a(e),s=new TextEncoder().encode(t),i=await Ic(s,n);return fs(i)}const Ca="pigbot.device.auth.v1";function Hs(e){return e.trim()}function Fc(e){if(!Array.isArray(e))return[];const t=new Set;for(const n of e){const s=n.trim();s&&t.add(s)}return[...t].sort()}function zs(){try{const e=window.localStorage.getItem(Ca);if(!e)return null;const t=JSON.parse(e);return!t||t.version!==1||!t.deviceId||typeof t.deviceId!="string"||!t.tokens||typeof t.tokens!="object"?null:t}catch{return null}}function Ea(e){try{window.localStorage.setItem(Ca,JSON.stringify(e))}catch{}}function Uc(e){const t=zs();if(!t||t.deviceId!==e.deviceId)return null;const n=Hs(e.role),s=t.tokens[n];return!s||typeof s.token!="string"?null:s}function Ia(e){const t=Hs(e.role),n={version:1,deviceId:e.deviceId,tokens:{}},s=zs();s&&s.deviceId===e.deviceId&&(n.tokens={...s.tokens});const i={token:e.token,role:t,scopes:Fc(e.scopes),updatedAtMs:Date.now()};return n.tokens[t]=i,Ea(n),i}function Ra(e){const t=zs();if(!t||t.deviceId!==e.deviceId)return;const n=Hs(e.role);if(!t.tokens[n])return;const s={...t,tokens:{...t.tokens}};delete s.tokens[n],Ea(s)}async function _e(e,t){if(!(!e.client||!e.connected)&&!e.devicesLoading){e.devicesLoading=!0,t?.quiet||(e.devicesError=null);try{const n=await e.client.request("device.pair.list",{});e.devicesList={pending:Array.isArray(n?.pending)?n.pending:[],paired:Array.isArray(n?.paired)?n.paired:[]}}catch(n){t?.quiet||(e.devicesError=String(n))}finally{e.devicesLoading=!1}}}async function Kc(e,t){if(!(!e.client||!e.connected))try{await e.client.request("device.pair.approve",{requestId:t}),await _e(e)}catch(n){e.devicesError=String(n)}}async function Hc(e,t){if(!(!e.client||!e.connected||!window.confirm("Reject this device pairing request?")))try{await e.client.request("device.pair.reject",{requestId:t}),await _e(e)}catch(s){e.devicesError=String(s)}}async function zc(e,t){if(!(!e.client||!e.connected))try{const n=await e.client.request("device.token.rotate",t);if(n?.token){const s=await Ks(),i=n.role??t.role;(n.deviceId===s.deviceId||t.deviceId===s.deviceId)&&Ia({deviceId:s.deviceId,role:i,token:n.token,scopes:n.scopes??t.scopes??[]}),window.prompt("New device token (copy and store securely):",n.token)}await _e(e)}catch(n){e.devicesError=String(n)}}async function jc(e,t){if(!(!e.client||!e.connected||!window.confirm(`Revoke token for ${t.deviceId} (${t.role})?`)))try{await e.client.request("device.token.revoke",t);const s=await Ks();t.deviceId===s.deviceId&&Ra({deviceId:s.deviceId,role:t.role}),await _e(e)}catch(s){e.devicesError=String(s)}}async function pn(e,t){if(!(!e.client||!e.connected)&&!e.nodesLoading){e.nodesLoading=!0,t?.quiet||(e.lastError=null);try{const n=await e.client.request("node.list",{});e.nodes=Array.isArray(n.nodes)?n.nodes:[]}catch(n){t?.quiet||(e.lastError=String(n))}finally{e.nodesLoading=!1}}}function qc(e){if(!e||e.kind==="gateway")return{method:"exec.approvals.get",params:{}};const t=e.nodeId.trim();return t?{method:"exec.approvals.node.get",params:{nodeId:t}}:null}function Wc(e,t){if(!e||e.kind==="gateway")return{method:"exec.approvals.set",params:t};const n=e.nodeId.trim();return n?{method:"exec.approvals.node.set",params:{...t,nodeId:n}}:null}async function js(e,t){if(!(!e.client||!e.connected)&&!e.execApprovalsLoading){e.execApprovalsLoading=!0,e.lastError=null;try{const n=qc(t);if(!n){e.lastError="Select a node before loading exec approvals.";return}const s=await e.client.request(n.method,n.params);Gc(e,s)}catch(n){e.lastError=String(n)}finally{e.execApprovalsLoading=!1}}}function Gc(e,t){e.execApprovalsSnapshot=t,e.execApprovalsDirty||(e.execApprovalsForm=Oe(t.file??{}))}async function Vc(e,t){if(!(!e.client||!e.connected)){e.execApprovalsSaving=!0,e.lastError=null;try{const n=e.execApprovalsSnapshot?.hash;if(!n){e.lastError="Exec approvals hash missing; reload and retry.";return}const s=e.execApprovalsForm??e.execApprovalsSnapshot?.file??{},i=Wc(t,{file:s,baseHash:n});if(!i){e.lastError="Select a node before saving exec approvals.";return}await e.client.request(i.method,i.params),e.execApprovalsDirty=!1,await js(e,t)}catch(n){e.lastError=String(n)}finally{e.execApprovalsSaving=!1}}}function Yc(e,t,n){const s=Oe(e.execApprovalsForm??e.execApprovalsSnapshot?.file??{});da(s,t,n),e.execApprovalsForm=s,e.execApprovalsDirty=!0}function Qc(e,t){const n=Oe(e.execApprovalsForm??e.execApprovalsSnapshot?.file??{});ua(n,t),e.execApprovalsForm=n,e.execApprovalsDirty=!0}async function qs(e){if(!(!e.client||!e.connected)&&!e.presenceLoading){e.presenceLoading=!0,e.presenceError=null,e.presenceStatus=null;try{const t=await e.client.request("system-presence",{});Array.isArray(t)?(e.presenceEntries=t,e.presenceStatus=t.length===0?"No instances yet.":null):(e.presenceEntries=[],e.presenceStatus="No presence payload.")}catch(t){e.presenceError=String(t)}finally{e.presenceLoading=!1}}}function et(e,t,n){if(!t.trim())return;const s={...e.skillMessages};n?s[t]=n:delete s[t],e.skillMessages=s}function fn(e){return e instanceof Error?e.message:String(e)}async function Tt(e,t){if(t?.clearMessages&&Object.keys(e.skillMessages).length>0&&(e.skillMessages={}),!(!e.client||!e.connected)&&!e.skillsLoading){e.skillsLoading=!0,e.skillsError=null;try{const n=await e.client.request("skills.status",{});n&&(e.skillsReport=n)}catch(n){e.skillsError=fn(n)}finally{e.skillsLoading=!1}}}function Jc(e,t,n){e.skillEdits={...e.skillEdits,[t]:n}}async function Zc(e,t,n){if(!(!e.client||!e.connected)){e.skillsBusyKey=t,e.skillsError=null;try{await e.client.request("skills.update",{skillKey:t,enabled:n}),await Tt(e),et(e,t,{kind:"success",message:n?"Skill enabled":"Skill disabled"})}catch(s){const i=fn(s);e.skillsError=i,et(e,t,{kind:"error",message:i})}finally{e.skillsBusyKey=null}}}async function Xc(e,t){if(!(!e.client||!e.connected)){e.skillsBusyKey=t,e.skillsError=null;try{const n=e.skillEdits[t]??"";await e.client.request("skills.update",{skillKey:t,apiKey:n}),await Tt(e),et(e,t,{kind:"success",message:"API key saved"})}catch(n){const s=fn(n);e.skillsError=s,et(e,t,{kind:"error",message:s})}finally{e.skillsBusyKey=null}}}async function ed(e,t,n,s){if(!(!e.client||!e.connected)){e.skillsBusyKey=t,e.skillsError=null;try{const i=await e.client.request("skills.install",{name:n,installId:s,timeoutMs:12e4});await Tt(e),et(e,t,{kind:"success",message:i?.message??"Installed"})}catch(i){const o=fn(i);e.skillsError=o,et(e,t,{kind:"error",message:o})}finally{e.skillsBusyKey=null}}}function td(){return typeof window>"u"||typeof window.matchMedia!="function"||window.matchMedia("(prefers-color-scheme: dark)").matches?"dark":"light"}function Ws(e){return e==="system"?td():e}const Bt=e=>Number.isNaN(e)?.5:e<=0?0:e>=1?1:e,nd=()=>typeof window>"u"||typeof window.matchMedia!="function"?!1:window.matchMedia("(prefers-reduced-motion: reduce)").matches??!1,Ft=e=>{e.classList.remove("theme-transition"),e.style.removeProperty("--theme-switch-x"),e.style.removeProperty("--theme-switch-y")},sd=({nextTheme:e,applyTheme:t,context:n,currentTheme:s})=>{if(s===e)return;const i=globalThis.document??null;if(!i){t();return}const o=i.documentElement,a=i,l=nd();if(!!a.startViewTransition&&!l){let p=.5,d=.5;if(n?.pointerClientX!==void 0&&n?.pointerClientY!==void 0&&typeof window<"u")p=Bt(n.pointerClientX/window.innerWidth),d=Bt(n.pointerClientY/window.innerHeight);else if(n?.element){const u=n.element.getBoundingClientRect();u.width>0&&u.height>0&&typeof window<"u"&&(p=Bt((u.left+u.width/2)/window.innerWidth),d=Bt((u.top+u.height/2)/window.innerHeight))}o.style.setProperty("--theme-switch-x",`${p*100}%`),o.style.setProperty("--theme-switch-y",`${d*100}%`),o.classList.add("theme-transition");try{const u=a.startViewTransition?.(()=>{t()});u?.finished?u.finished.finally(()=>Ft(o)):Ft(o)}catch{Ft(o),t()}return}t(),Ft(o)};function id(e){e.nodesPollInterval==null&&(e.nodesPollInterval=window.setInterval(()=>{pn(e,{quiet:!0})},5e3))}function od(e){e.nodesPollInterval!=null&&(clearInterval(e.nodesPollInterval),e.nodesPollInterval=null)}function Gs(e){e.logsPollInterval==null&&(e.logsPollInterval=window.setInterval(()=>{e.tab==="logs"&&Ds(e,{quiet:!0})},2e3))}function Vs(e){e.logsPollInterval!=null&&(clearInterval(e.logsPollInterval),e.logsPollInterval=null)}function Ys(e){e.debugPollInterval==null&&(e.debugPollInterval=window.setInterval(()=>{e.tab==="debug"&&dn(e)},3e3))}function Qs(e){e.debugPollInterval!=null&&(clearInterval(e.debugPollInterval),e.debugPollInterval=null)}function ke(e,t){const n={...t,lastActiveSessionKey:t.lastActiveSessionKey?.trim()||t.sessionKey.trim()||"main"};e.settings=n,hl(n),t.theme!==e.theme&&(e.theme=t.theme,hn(e,Ws(t.theme))),e.applySessionKey=e.settings.lastActiveSessionKey}function La(e,t){const n=t.trim();n&&e.settings.lastActiveSessionKey!==n&&ke(e,{...e.settings,lastActiveSessionKey:n})}function ad(e){if(!window.location.search)return;const t=new URLSearchParams(window.location.search),n=t.get("token"),s=t.get("password"),i=t.get("session"),o=t.get("gatewayUrl");let a=!1;if(n!=null){const r=n.trim();r&&r!==e.settings.token&&ke(e,{...e.settings,token:r}),t.delete("token"),a=!0}if(s!=null){const r=s.trim();r&&(e.password=r),t.delete("password"),a=!0}if(i!=null){const r=i.trim();r&&(e.sessionKey=r,ke(e,{...e.settings,sessionKey:r,lastActiveSessionKey:r}))}if(o!=null){const r=o.trim();r&&r!==e.settings.gatewayUrl&&ke(e,{...e.settings,gatewayUrl:r}),t.delete("gatewayUrl"),a=!0}if(!a)return;const l=new URL(window.location.href);l.search=t.toString(),window.history.replaceState({},"",l.toString())}function rd(e,t){e.tab!==t&&(e.tab=t),t==="chat"&&(e.chatHasAutoScrolled=!1),t==="logs"?Gs(e):Vs(e),t==="debug"?Ys(e):Qs(e),Js(e),Pa(e,t,!1)}function ld(e,t,n){sd({nextTheme:t,applyTheme:()=>{e.theme=t,ke(e,{...e.settings,theme:t}),hn(e,Ws(t))},context:n,currentTheme:e.theme})}async function Js(e){e.tab==="overview"&&await Na(e),e.tab==="channels"&&await vd(e),e.tab==="instances"&&await qs(e),e.tab==="sessions"&&await nt(e),e.tab==="cron"&&await Zs(e),e.tab==="skills"&&await Tt(e),e.tab==="nodes"&&(await pn(e),await _e(e),await me(e),await js(e)),e.tab==="chat"&&(await $d(e),ln(e,!e.chatHasAutoScrolled)),e.tab==="config"&&(await pa(e),await me(e)),e.tab==="debug"&&(await dn(e),e.eventLog=e.eventLogBuffer),e.tab==="logs"&&(e.logsAtBottom=!0,await Ds(e,{reset:!0}),ca(e,!0))}function cd(){if(typeof window>"u")return"";const e=window.__PIGBOT_CONTROL_UI_BASE_PATH__;return typeof e=="string"&&e.trim()?rn(e):vl(window.location.pathname)}function dd(e){e.theme=e.settings.theme??"system",hn(e,Ws(e.theme))}function hn(e,t){if(e.themeResolved=t,typeof document>"u")return;const n=document.documentElement;n.dataset.theme=t,n.style.colorScheme=t}function ud(e){if(typeof window>"u"||typeof window.matchMedia!="function")return;if(e.themeMedia=window.matchMedia("(prefers-color-scheme: dark)"),e.themeMediaHandler=n=>{e.theme==="system"&&hn(e,n.matches?"dark":"light")},typeof e.themeMedia.addEventListener=="function"){e.themeMedia.addEventListener("change",e.themeMediaHandler);return}e.themeMedia.addListener(e.themeMediaHandler)}function pd(e){if(!e.themeMedia||!e.themeMediaHandler)return;if(typeof e.themeMedia.removeEventListener=="function"){e.themeMedia.removeEventListener("change",e.themeMediaHandler);return}e.themeMedia.removeListener(e.themeMediaHandler),e.themeMedia=null,e.themeMediaHandler=null}function fd(e,t){if(typeof window>"u")return;const n=oa(window.location.pathname,e.basePath)??"chat";Ma(e,n),Pa(e,n,t)}function hd(e){if(typeof window>"u")return;const t=oa(window.location.pathname,e.basePath);if(!t)return;const s=new URL(window.location.href).searchParams.get("session")?.trim();s&&(e.sessionKey=s,ke(e,{...e.settings,sessionKey:s,lastActiveSessionKey:s})),Ma(e,t)}function Ma(e,t){e.tab!==t&&(e.tab=t),t==="chat"&&(e.chatHasAutoScrolled=!1),t==="logs"?Gs(e):Vs(e),t==="debug"?Ys(e):Qs(e),e.connected&&Js(e)}function Pa(e,t,n){if(typeof window>"u")return;const s=kt(Ps(t,e.basePath)),i=kt(window.location.pathname),o=new URL(window.location.href);t==="chat"&&e.sessionKey?o.searchParams.set("session",e.sessionKey):o.searchParams.delete("session"),i!==s&&(o.pathname=s),n?window.history.replaceState({},"",o.toString()):window.history.pushState({},"",o.toString())}function gd(e,t,n){if(typeof window>"u")return;const s=new URL(window.location.href);s.searchParams.set("session",t),window.history.replaceState({},"",s.toString())}async function Na(e){await Promise.all([oe(e,!1),qs(e),nt(e),_t(e),dn(e)])}async function vd(e){await Promise.all([oe(e,!0),pa(e),me(e)])}async function Zs(e){await Promise.all([oe(e,!1),_t(e),cn(e)])}function Oa(e){return e.chatSending||!!e.chatRunId}function md(e){const t=e.trim();if(!t)return!1;const n=t.toLowerCase();return n==="/stop"?!0:n==="stop"||n==="esc"||n==="abort"||n==="wait"||n==="exit"}async function Da(e){e.connected&&(e.chatMessage="",await Il(e))}function bd(e,t){const n=t.trim();n&&(e.chatQueue=[...e.chatQueue,{id:Ns(),text:n,createdAt:Date.now()}])}async function Ba(e,t,n){Os(e);const s=await El(e,t);return!s&&n?.previousDraft!=null&&(e.chatMessage=n.previousDraft),s&&La(e,e.sessionKey),s&&n?.restoreDraft&&n.previousDraft?.trim()&&(e.chatMessage=n.previousDraft),ln(e),s&&!e.chatRunId&&Fa(e),s}async function Fa(e){if(!e.connected||Oa(e))return;const[t,...n]=e.chatQueue;if(!t)return;e.chatQueue=n,await Ba(e,t.text)||(e.chatQueue=[t,...e.chatQueue])}function yd(e,t){e.chatQueue=e.chatQueue.filter(n=>n.id!==t)}async function wd(e,t,n){if(!e.connected)return;const s=e.chatMessage,i=(t??e.chatMessage).trim();if(i){if(md(i)){await Da(e);return}if(t==null&&(e.chatMessage=""),Oa(e)){bd(e,i);return}await Ba(e,i,{previousDraft:t==null?s:void 0,restoreDraft:!!(t&&n?.restoreDraft)})}}async function $d(e){await Promise.all([Ze(e),nt(e),hs(e)]),ln(e,!0)}const kd=Fa;function xd(e){const t=na(e.sessionKey);return t?.agentId?t.agentId:e.hello?.snapshot?.sessionDefaults?.defaultAgentId?.trim()||"main"}function Ad(e,t){const n=rn(e),s=encodeURIComponent(t);return n?`${n}/avatar/${s}?meta=1`:`/avatar/${s}?meta=1`}async function hs(e){if(!e.connected){e.chatAvatarUrl=null;return}const t=xd(e);if(!t){e.chatAvatarUrl=null;return}e.chatAvatarUrl=null;const n=Ad(e.basePath,t);try{const s=await fetch(n,{method:"GET"});if(!s.ok){e.chatAvatarUrl=null;return}const i=await s.json(),o=typeof i.avatarUrl=="string"?i.avatarUrl.trim():"";e.chatAvatarUrl=o||null}catch{e.chatAvatarUrl=null}}const Ua={CHILD:2},Ka=e=>(...t)=>({_$litDirective$:e,values:t});let Ha=class{constructor(t){}get _$AU(){return this._$AM._$AU}_$AT(t,n,s){this._$Ct=t,this._$AM=n,this._$Ci=s}_$AS(t,n){return this.update(t,n)}update(t,n){return this.render(...n)}};const{I:Sd}=sl,oo=e=>e,ao=()=>document.createComment(""),rt=(e,t,n)=>{const s=e._$AA.parentNode,i=t===void 0?e._$AB:t._$AA;if(n===void 0){const o=s.insertBefore(ao(),i),a=s.insertBefore(ao(),i);n=new Sd(o,a,e,e.options)}else{const o=n._$AB.nextSibling,a=n._$AM,l=a!==e;if(l){let r;n._$AQ?.(e),n._$AM=e,n._$AP!==void 0&&(r=e._$AU)!==a._$AU&&n._$AP(r)}if(o!==i||l){let r=n._$AA;for(;r!==o;){const p=oo(r).nextSibling;oo(s).insertBefore(r,i),r=p}}}return n},Ie=(e,t,n=e)=>(e._$AI(t,n),e),_d={},Td=(e,t=_d)=>e._$AH=t,Cd=e=>e._$AH,qn=e=>{e._$AR(),e._$AA.remove()};const ro=(e,t,n)=>{const s=new Map;for(let i=t;i<=n;i++)s.set(e[i],i);return s},za=Ka(class extends Ha{constructor(e){if(super(e),e.type!==Ua.CHILD)throw Error("repeat() can only be used in text expressions")}dt(e,t,n){let s;n===void 0?n=t:t!==void 0&&(s=t);const i=[],o=[];let a=0;for(const l of e)i[a]=s?s(l,a):a,o[a]=n(l,a),a++;return{values:o,keys:i}}render(e,t,n){return this.dt(e,t,n).values}update(e,[t,n,s]){const i=Cd(e),{values:o,keys:a}=this.dt(t,n,s);if(!Array.isArray(i))return this.ut=a,o;const l=this.ut??=[],r=[];let p,d,u=0,h=i.length-1,v=0,w=o.length-1;for(;u<=h&&v<=w;)if(i[u]===null)u++;else if(i[h]===null)h--;else if(l[u]===a[v])r[v]=Ie(i[u],o[v]),u++,v++;else if(l[h]===a[w])r[w]=Ie(i[h],o[w]),h--,w--;else if(l[u]===a[w])r[w]=Ie(i[u],o[w]),rt(e,r[w+1],i[u]),u++,w--;else if(l[h]===a[v])r[v]=Ie(i[h],o[v]),rt(e,i[u],i[h]),h--,v++;else if(p===void 0&&(p=ro(a,v,w),d=ro(l,u,h)),p.has(l[u]))if(p.has(l[h])){const $=d.get(a[v]),x=$!==void 0?i[$]:null;if(x===null){const T=rt(e,i[u]);Ie(T,o[v]),r[v]=T}else r[v]=Ie(x,o[v]),rt(e,i[u],x),i[$]=null;v++}else qn(i[h]),h--;else qn(i[u]),u++;for(;v<=w;){const $=rt(e,r[w+1]);Ie($,o[v]),r[v++]=$}for(;u<=h;){const $=i[u++];$!==null&&qn($)}return this.ut=a,Td(e,r),Ae}});function ja(e){const t=e;let n=typeof t.role=="string"?t.role:"unknown";const s=typeof t.toolCallId=="string"||typeof t.tool_call_id=="string",i=t.content,o=Array.isArray(i)?i:null,a=Array.isArray(o)&&o.some(u=>{const v=String(u.type??"").toLowerCase();return v==="toolresult"||v==="tool_result"}),l=typeof t.toolName=="string"||typeof t.tool_name=="string";(s||a||l)&&(n="toolResult");let r=[];typeof t.content=="string"?r=[{type:"text",text:t.content}]:Array.isArray(t.content)?r=t.content.map(u=>({type:u.type||"text",text:u.text,name:u.name,args:u.args||u.arguments})):typeof t.text=="string"&&(r=[{type:"text",text:t.text}]);const p=typeof t.timestamp=="number"?t.timestamp:Date.now(),d=typeof t.id=="string"?t.id:void 0;return{role:n,content:r,timestamp:p,id:d}}function Xs(e){const t=e.toLowerCase();return e==="user"||e==="User"?e:e==="assistant"?"assistant":e==="system"?"system":t==="toolresult"||t==="tool_result"||t==="tool"||t==="function"?"tool":e}function qa(e){const t=e,n=typeof t.role=="string"?t.role.toLowerCase():"";return n==="toolresult"||n==="tool_result"}class gs extends Ha{constructor(t){if(super(t),this.it=g,t.type!==Ua.CHILD)throw Error(this.constructor.directiveName+"() can only be used in child bindings")}render(t){if(t===g||t==null)return this._t=void 0,this.it=t;if(t===Ae)return t;if(typeof t!="string")throw Error(this.constructor.directiveName+"() called with a non-string value");if(t===this.it)return this._t;this.it=t;const n=[t];return n.raw=n,this._t={_$litType$:this.constructor.resultType,strings:n,values:[]}}}gs.directiveName="unsafeHTML",gs.resultType=1;const vs=Ka(gs);const{entries:Wa,setPrototypeOf:lo,isFrozen:Ed,getPrototypeOf:Id,getOwnPropertyDescriptor:Rd}=Object;let{freeze:Q,seal:te,create:ms}=Object,{apply:bs,construct:ys}=typeof Reflect<"u"&&Reflect;Q||(Q=function(t){return t});te||(te=function(t){return t});bs||(bs=function(t,n){for(var s=arguments.length,i=new Array(s>2?s-2:0),o=2;o<s;o++)i[o-2]=arguments[o];return t.apply(n,i)});ys||(ys=function(t){for(var n=arguments.length,s=new Array(n>1?n-1:0),i=1;i<n;i++)s[i-1]=arguments[i];return new t(...s)});const Ut=J(Array.prototype.forEach),Ld=J(Array.prototype.lastIndexOf),co=J(Array.prototype.pop),lt=J(Array.prototype.push),Md=J(Array.prototype.splice),Gt=J(String.prototype.toLowerCase),Wn=J(String.prototype.toString),Gn=J(String.prototype.match),ct=J(String.prototype.replace),Pd=J(String.prototype.indexOf),Nd=J(String.prototype.trim),ne=J(Object.prototype.hasOwnProperty),V=J(RegExp.prototype.test),dt=Od(TypeError);function J(e){return function(t){t instanceof RegExp&&(t.lastIndex=0);for(var n=arguments.length,s=new Array(n>1?n-1:0),i=1;i<n;i++)s[i-1]=arguments[i];return bs(e,t,s)}}function Od(e){return function(){for(var t=arguments.length,n=new Array(t),s=0;s<t;s++)n[s]=arguments[s];return ys(e,n)}}function L(e,t){let n=arguments.length>2&&arguments[2]!==void 0?arguments[2]:Gt;lo&&lo(e,null);let s=t.length;for(;s--;){let i=t[s];if(typeof i=="string"){const o=n(i);o!==i&&(Ed(t)||(t[s]=o),i=o)}e[i]=!0}return e}function Dd(e){for(let t=0;t<e.length;t++)ne(e,t)||(e[t]=null);return e}function ce(e){const t=ms(null);for(const[n,s]of Wa(e))ne(e,n)&&(Array.isArray(s)?t[n]=Dd(s):s&&typeof s=="object"&&s.constructor===Object?t[n]=ce(s):t[n]=s);return t}function ut(e,t){for(;e!==null;){const s=Rd(e,t);if(s){if(s.get)return J(s.get);if(typeof s.value=="function")return J(s.value)}e=Id(e)}function n(){return null}return n}const uo=Q(["a","abbr","acronym","address","area","article","aside","audio","b","bdi","bdo","big","blink","blockquote","body","br","button","canvas","caption","center","cite","code","col","colgroup","content","data","datalist","dd","decorator","del","details","dfn","dialog","dir","div","dl","dt","element","em","fieldset","figcaption","figure","font","footer","form","h1","h2","h3","h4","h5","h6","head","header","hgroup","hr","html","i","img","input","ins","kbd","label","legend","li","main","map","mark","marquee","menu","menuitem","meter","nav","nobr","ol","optgroup","option","output","p","picture","pre","progress","q","rp","rt","ruby","s","samp","search","section","select","shadow","slot","small","source","spacer","span","strike","strong","style","sub","summary","sup","table","tbody","td","template","textarea","tfoot","th","thead","time","tr","track","tt","u","ul","var","video","wbr"]),Vn=Q(["svg","a","altglyph","altglyphdef","altglyphitem","animatecolor","animatemotion","animatetransform","circle","clippath","defs","desc","ellipse","enterkeyhint","exportparts","filter","font","g","glyph","glyphref","hkern","image","inputmode","line","lineargradient","marker","mask","metadata","mpath","part","path","pattern","polygon","polyline","radialgradient","rect","stop","style","switch","symbol","text","textpath","title","tref","tspan","view","vkern"]),Yn=Q(["feBlend","feColorMatrix","feComponentTransfer","feComposite","feConvolveMatrix","feDiffuseLighting","feDisplacementMap","feDistantLight","feDropShadow","feFlood","feFuncA","feFuncB","feFuncG","feFuncR","feGaussianBlur","feImage","feMerge","feMergeNode","feMorphology","feOffset","fePointLight","feSpecularLighting","feSpotLight","feTile","feTurbulence"]),Bd=Q(["animate","color-profile","cursor","discard","font-face","font-face-format","font-face-name","font-face-src","font-face-uri","foreignobject","hatch","hatchpath","mesh","meshgradient","meshpatch","meshrow","missing-glyph","script","set","solidcolor","unknown","use"]),Qn=Q(["math","menclose","merror","mfenced","mfrac","mglyph","mi","mlabeledtr","mmultiscripts","mn","mo","mover","mpadded","mphantom","mroot","mrow","ms","mspace","msqrt","mstyle","msub","msup","msubsup","mtable","mtd","mtext","mtr","munder","munderover","mprescripts"]),Fd=Q(["maction","maligngroup","malignmark","mlongdiv","mscarries","mscarry","msgroup","mstack","msline","msrow","semantics","annotation","annotation-xml","mprescripts","none"]),po=Q(["#text"]),fo=Q(["accept","action","align","alt","autocapitalize","autocomplete","autopictureinpicture","autoplay","background","bgcolor","border","capture","cellpadding","cellspacing","checked","cite","class","clear","color","cols","colspan","controls","controlslist","coords","crossorigin","datetime","decoding","default","dir","disabled","disablepictureinpicture","disableremoteplayback","download","draggable","enctype","enterkeyhint","exportparts","face","for","headers","height","hidden","high","href","hreflang","id","inert","inputmode","integrity","ismap","kind","label","lang","list","loading","loop","low","max","maxlength","media","method","min","minlength","multiple","muted","name","nonce","noshade","novalidate","nowrap","open","optimum","part","pattern","placeholder","playsinline","popover","popovertarget","popovertargetaction","poster","preload","pubdate","radiogroup","readonly","rel","required","rev","reversed","role","rows","rowspan","spellcheck","scope","selected","shape","size","sizes","slot","span","srclang","start","src","srcset","step","style","summary","tabindex","title","translate","type","usemap","valign","value","width","wrap","xmlns","slot"]),Jn=Q(["accent-height","accumulate","additive","alignment-baseline","amplitude","ascent","attributename","attributetype","azimuth","basefrequency","baseline-shift","begin","bias","by","class","clip","clippathunits","clip-path","clip-rule","color","color-interpolation","color-interpolation-filters","color-profile","color-rendering","cx","cy","d","dx","dy","diffuseconstant","direction","display","divisor","dur","edgemode","elevation","end","exponent","fill","fill-opacity","fill-rule","filter","filterunits","flood-color","flood-opacity","font-family","font-size","font-size-adjust","font-stretch","font-style","font-variant","font-weight","fx","fy","g1","g2","glyph-name","glyphref","gradientunits","gradienttransform","height","href","id","image-rendering","in","in2","intercept","k","k1","k2","k3","k4","kerning","keypoints","keysplines","keytimes","lang","lengthadjust","letter-spacing","kernelmatrix","kernelunitlength","lighting-color","local","marker-end","marker-mid","marker-start","markerheight","markerunits","markerwidth","maskcontentunits","maskunits","max","mask","mask-type","media","method","mode","min","name","numoctaves","offset","operator","opacity","order","orient","orientation","origin","overflow","paint-order","path","pathlength","patterncontentunits","patterntransform","patternunits","points","preservealpha","preserveaspectratio","primitiveunits","r","rx","ry","radius","refx","refy","repeatcount","repeatdur","restart","result","rotate","scale","seed","shape-rendering","slope","specularconstant","specularexponent","spreadmethod","startoffset","stddeviation","stitchtiles","stop-color","stop-opacity","stroke-dasharray","stroke-dashoffset","stroke-linecap","stroke-linejoin","stroke-miterlimit","stroke-opacity","stroke","stroke-width","style","surfacescale","systemlanguage","tabindex","tablevalues","targetx","targety","transform","transform-origin","text-anchor","text-decoration","text-rendering","textlength","type","u1","u2","unicode","values","viewbox","visibility","version","vert-adv-y","vert-origin-x","vert-origin-y","width","word-spacing","wrap","writing-mode","xchannelselector","ychannelselector","x","x1","x2","xmlns","y","y1","y2","z","zoomandpan"]),ho=Q(["accent","accentunder","align","bevelled","close","columnsalign","columnlines","columnspan","denomalign","depth","dir","display","displaystyle","encoding","fence","frame","height","href","id","largeop","length","linethickness","lspace","lquote","mathbackground","mathcolor","mathsize","mathvariant","maxsize","minsize","movablelimits","notation","numalign","open","rowalign","rowlines","rowspacing","rowspan","rspace","rquote","scriptlevel","scriptminsize","scriptsizemultiplier","selection","separator","separators","stretchy","subscriptshift","supscriptshift","symmetric","voffset","width","xmlns"]),Kt=Q(["xlink:href","xml:id","xlink:title","xml:space","xmlns:xlink"]),Ud=te(/\{\{[\w\W]*|[\w\W]*\}\}/gm),Kd=te(/<%[\w\W]*|[\w\W]*%>/gm),Hd=te(/\$\{[\w\W]*/gm),zd=te(/^data-[\-\w.\u00B7-\uFFFF]+$/),jd=te(/^aria-[\-\w]+$/),Ga=te(/^(?:(?:(?:f|ht)tps?|mailto|tel|callto|sms|cid|xmpp|matrix):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i),qd=te(/^(?:\w+script|data):/i),Wd=te(/[\u0000-\u0020\u00A0\u1680\u180E\u2000-\u2029\u205F\u3000]/g),Va=te(/^html$/i),Gd=te(/^[a-z][.\w]*(-[.\w]+)+$/i);var go=Object.freeze({__proto__:null,ARIA_ATTR:jd,ATTR_WHITESPACE:Wd,CUSTOM_ELEMENT:Gd,DATA_ATTR:zd,DOCTYPE_NAME:Va,ERB_EXPR:Kd,IS_ALLOWED_URI:Ga,IS_SCRIPT_OR_DATA:qd,MUSTACHE_EXPR:Ud,TMPLIT_EXPR:Hd});const pt={element:1,text:3,progressingInstruction:7,comment:8,document:9},Vd=function(){return typeof window>"u"?null:window},Yd=function(t,n){if(typeof t!="object"||typeof t.createPolicy!="function")return null;let s=null;const i="data-tt-policy-suffix";n&&n.hasAttribute(i)&&(s=n.getAttribute(i));const o="dompurify"+(s?"#"+s:"");try{return t.createPolicy(o,{createHTML(a){return a},createScriptURL(a){return a}})}catch{return console.warn("TrustedTypes policy "+o+" could not be created."),null}},vo=function(){return{afterSanitizeAttributes:[],afterSanitizeElements:[],afterSanitizeShadowDOM:[],beforeSanitizeAttributes:[],beforeSanitizeElements:[],beforeSanitizeShadowDOM:[],uponSanitizeAttribute:[],uponSanitizeElement:[],uponSanitizeShadowNode:[]}};function Ya(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:Vd();const t=_=>Ya(_);if(t.version="3.3.1",t.removed=[],!e||!e.document||e.document.nodeType!==pt.document||!e.Element)return t.isSupported=!1,t;let{document:n}=e;const s=n,i=s.currentScript,{DocumentFragment:o,HTMLTemplateElement:a,Node:l,Element:r,NodeFilter:p,NamedNodeMap:d=e.NamedNodeMap||e.MozNamedAttrMap,HTMLFormElement:u,DOMParser:h,trustedTypes:v}=e,w=r.prototype,$=ut(w,"cloneNode"),x=ut(w,"remove"),T=ut(w,"nextSibling"),R=ut(w,"childNodes"),P=ut(w,"parentNode");if(typeof a=="function"){const _=n.createElement("template");_.content&&_.content.ownerDocument&&(n=_.content.ownerDocument)}let I,C="";const{implementation:E,createNodeIterator:ue,createDocumentFragment:yn,getElementsByTagName:wn}=n,{importNode:Ar}=s;let G=vo();t.isSupported=typeof Wa=="function"&&typeof P=="function"&&E&&E.createHTMLDocument!==void 0;const{MUSTACHE_EXPR:$n,ERB_EXPR:kn,TMPLIT_EXPR:xn,DATA_ATTR:Sr,ARIA_ATTR:_r,IS_SCRIPT_OR_DATA:Tr,ATTR_WHITESPACE:ui,CUSTOM_ELEMENT:Cr}=go;let{IS_ALLOWED_URI:pi}=go,K=null;const fi=L({},[...uo,...Vn,...Yn,...Qn,...po]);let z=null;const hi=L({},[...fo,...Jn,...ho,...Kt]);let B=Object.seal(ms(null,{tagNameCheck:{writable:!0,configurable:!1,enumerable:!0,value:null},attributeNameCheck:{writable:!0,configurable:!1,enumerable:!0,value:null},allowCustomizedBuiltInElements:{writable:!0,configurable:!1,enumerable:!0,value:!1}})),st=null,An=null;const Ke=Object.seal(ms(null,{tagCheck:{writable:!0,configurable:!1,enumerable:!0,value:null},attributeCheck:{writable:!0,configurable:!1,enumerable:!0,value:null}}));let gi=!0,Sn=!0,vi=!1,mi=!0,He=!1,Et=!0,Te=!1,_n=!1,Tn=!1,ze=!1,It=!1,Rt=!1,bi=!0,yi=!1;const Er="user-content-";let Cn=!0,it=!1,je={},ae=null;const En=L({},["annotation-xml","audio","colgroup","desc","foreignobject","head","iframe","math","mi","mn","mo","ms","mtext","noembed","noframes","noscript","plaintext","script","style","svg","template","thead","title","video","xmp"]);let wi=null;const $i=L({},["audio","video","img","source","image","track"]);let In=null;const ki=L({},["alt","class","for","id","label","name","pattern","placeholder","role","summary","title","value","style","xmlns"]),Lt="http://www.w3.org/1998/Math/MathML",Mt="http://www.w3.org/2000/svg",pe="http://www.w3.org/1999/xhtml";let qe=pe,Rn=!1,Ln=null;const Ir=L({},[Lt,Mt,pe],Wn);let Pt=L({},["mi","mo","mn","ms","mtext"]),Nt=L({},["annotation-xml"]);const Rr=L({},["title","style","font","a","script"]);let ot=null;const Lr=["application/xhtml+xml","text/html"],Mr="text/html";let U=null,We=null;const Pr=n.createElement("form"),xi=function(f){return f instanceof RegExp||f instanceof Function},Mn=function(){let f=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};if(!(We&&We===f)){if((!f||typeof f!="object")&&(f={}),f=ce(f),ot=Lr.indexOf(f.PARSER_MEDIA_TYPE)===-1?Mr:f.PARSER_MEDIA_TYPE,U=ot==="application/xhtml+xml"?Wn:Gt,K=ne(f,"ALLOWED_TAGS")?L({},f.ALLOWED_TAGS,U):fi,z=ne(f,"ALLOWED_ATTR")?L({},f.ALLOWED_ATTR,U):hi,Ln=ne(f,"ALLOWED_NAMESPACES")?L({},f.ALLOWED_NAMESPACES,Wn):Ir,In=ne(f,"ADD_URI_SAFE_ATTR")?L(ce(ki),f.ADD_URI_SAFE_ATTR,U):ki,wi=ne(f,"ADD_DATA_URI_TAGS")?L(ce($i),f.ADD_DATA_URI_TAGS,U):$i,ae=ne(f,"FORBID_CONTENTS")?L({},f.FORBID_CONTENTS,U):En,st=ne(f,"FORBID_TAGS")?L({},f.FORBID_TAGS,U):ce({}),An=ne(f,"FORBID_ATTR")?L({},f.FORBID_ATTR,U):ce({}),je=ne(f,"USE_PROFILES")?f.USE_PROFILES:!1,gi=f.ALLOW_ARIA_ATTR!==!1,Sn=f.ALLOW_DATA_ATTR!==!1,vi=f.ALLOW_UNKNOWN_PROTOCOLS||!1,mi=f.ALLOW_SELF_CLOSE_IN_ATTR!==!1,He=f.SAFE_FOR_TEMPLATES||!1,Et=f.SAFE_FOR_XML!==!1,Te=f.WHOLE_DOCUMENT||!1,ze=f.RETURN_DOM||!1,It=f.RETURN_DOM_FRAGMENT||!1,Rt=f.RETURN_TRUSTED_TYPE||!1,Tn=f.FORCE_BODY||!1,bi=f.SANITIZE_DOM!==!1,yi=f.SANITIZE_NAMED_PROPS||!1,Cn=f.KEEP_CONTENT!==!1,it=f.IN_PLACE||!1,pi=f.ALLOWED_URI_REGEXP||Ga,qe=f.NAMESPACE||pe,Pt=f.MATHML_TEXT_INTEGRATION_POINTS||Pt,Nt=f.HTML_INTEGRATION_POINTS||Nt,B=f.CUSTOM_ELEMENT_HANDLING||{},f.CUSTOM_ELEMENT_HANDLING&&xi(f.CUSTOM_ELEMENT_HANDLING.tagNameCheck)&&(B.tagNameCheck=f.CUSTOM_ELEMENT_HANDLING.tagNameCheck),f.CUSTOM_ELEMENT_HANDLING&&xi(f.CUSTOM_ELEMENT_HANDLING.attributeNameCheck)&&(B.attributeNameCheck=f.CUSTOM_ELEMENT_HANDLING.attributeNameCheck),f.CUSTOM_ELEMENT_HANDLING&&typeof f.CUSTOM_ELEMENT_HANDLING.allowCustomizedBuiltInElements=="boolean"&&(B.allowCustomizedBuiltInElements=f.CUSTOM_ELEMENT_HANDLING.allowCustomizedBuiltInElements),He&&(Sn=!1),It&&(ze=!0),je&&(K=L({},po),z=[],je.html===!0&&(L(K,uo),L(z,fo)),je.svg===!0&&(L(K,Vn),L(z,Jn),L(z,Kt)),je.svgFilters===!0&&(L(K,Yn),L(z,Jn),L(z,Kt)),je.mathMl===!0&&(L(K,Qn),L(z,ho),L(z,Kt))),f.ADD_TAGS&&(typeof f.ADD_TAGS=="function"?Ke.tagCheck=f.ADD_TAGS:(K===fi&&(K=ce(K)),L(K,f.ADD_TAGS,U))),f.ADD_ATTR&&(typeof f.ADD_ATTR=="function"?Ke.attributeCheck=f.ADD_ATTR:(z===hi&&(z=ce(z)),L(z,f.ADD_ATTR,U))),f.ADD_URI_SAFE_ATTR&&L(In,f.ADD_URI_SAFE_ATTR,U),f.FORBID_CONTENTS&&(ae===En&&(ae=ce(ae)),L(ae,f.FORBID_CONTENTS,U)),f.ADD_FORBID_CONTENTS&&(ae===En&&(ae=ce(ae)),L(ae,f.ADD_FORBID_CONTENTS,U)),Cn&&(K["#text"]=!0),Te&&L(K,["html","head","body"]),K.table&&(L(K,["tbody"]),delete st.tbody),f.TRUSTED_TYPES_POLICY){if(typeof f.TRUSTED_TYPES_POLICY.createHTML!="function")throw dt('TRUSTED_TYPES_POLICY configuration option must provide a "createHTML" hook.');if(typeof f.TRUSTED_TYPES_POLICY.createScriptURL!="function")throw dt('TRUSTED_TYPES_POLICY configuration option must provide a "createScriptURL" hook.');I=f.TRUSTED_TYPES_POLICY,C=I.createHTML("")}else I===void 0&&(I=Yd(v,i)),I!==null&&typeof C=="string"&&(C=I.createHTML(""));Q&&Q(f),We=f}},Ai=L({},[...Vn,...Yn,...Bd]),Si=L({},[...Qn,...Fd]),Nr=function(f){let k=P(f);(!k||!k.tagName)&&(k={namespaceURI:qe,tagName:"template"});const S=Gt(f.tagName),D=Gt(k.tagName);return Ln[f.namespaceURI]?f.namespaceURI===Mt?k.namespaceURI===pe?S==="svg":k.namespaceURI===Lt?S==="svg"&&(D==="annotation-xml"||Pt[D]):!!Ai[S]:f.namespaceURI===Lt?k.namespaceURI===pe?S==="math":k.namespaceURI===Mt?S==="math"&&Nt[D]:!!Si[S]:f.namespaceURI===pe?k.namespaceURI===Mt&&!Nt[D]||k.namespaceURI===Lt&&!Pt[D]?!1:!Si[S]&&(Rr[S]||!Ai[S]):!!(ot==="application/xhtml+xml"&&Ln[f.namespaceURI]):!1},re=function(f){lt(t.removed,{element:f});try{P(f).removeChild(f)}catch{x(f)}},Ce=function(f,k){try{lt(t.removed,{attribute:k.getAttributeNode(f),from:k})}catch{lt(t.removed,{attribute:null,from:k})}if(k.removeAttribute(f),f==="is")if(ze||It)try{re(k)}catch{}else try{k.setAttribute(f,"")}catch{}},_i=function(f){let k=null,S=null;if(Tn)f="<remove></remove>"+f;else{const F=Gn(f,/^[\r\n\t ]+/);S=F&&F[0]}ot==="application/xhtml+xml"&&qe===pe&&(f='<html xmlns="http://www.w3.org/1999/xhtml"><head></head><body>'+f+"</body></html>");const D=I?I.createHTML(f):f;if(qe===pe)try{k=new h().parseFromString(D,ot)}catch{}if(!k||!k.documentElement){k=E.createDocument(qe,"template",null);try{k.documentElement.innerHTML=Rn?C:D}catch{}}const q=k.body||k.documentElement;return f&&S&&q.insertBefore(n.createTextNode(S),q.childNodes[0]||null),qe===pe?wn.call(k,Te?"html":"body")[0]:Te?k.documentElement:q},Ti=function(f){return ue.call(f.ownerDocument||f,f,p.SHOW_ELEMENT|p.SHOW_COMMENT|p.SHOW_TEXT|p.SHOW_PROCESSING_INSTRUCTION|p.SHOW_CDATA_SECTION,null)},Pn=function(f){return f instanceof u&&(typeof f.nodeName!="string"||typeof f.textContent!="string"||typeof f.removeChild!="function"||!(f.attributes instanceof d)||typeof f.removeAttribute!="function"||typeof f.setAttribute!="function"||typeof f.namespaceURI!="string"||typeof f.insertBefore!="function"||typeof f.hasChildNodes!="function")},Ci=function(f){return typeof l=="function"&&f instanceof l};function fe(_,f,k){Ut(_,S=>{S.call(t,f,k,We)})}const Ei=function(f){let k=null;if(fe(G.beforeSanitizeElements,f,null),Pn(f))return re(f),!0;const S=U(f.nodeName);if(fe(G.uponSanitizeElement,f,{tagName:S,allowedTags:K}),Et&&f.hasChildNodes()&&!Ci(f.firstElementChild)&&V(/<[/\w!]/g,f.innerHTML)&&V(/<[/\w!]/g,f.textContent)||f.nodeType===pt.progressingInstruction||Et&&f.nodeType===pt.comment&&V(/<[/\w]/g,f.data))return re(f),!0;if(!(Ke.tagCheck instanceof Function&&Ke.tagCheck(S))&&(!K[S]||st[S])){if(!st[S]&&Ri(S)&&(B.tagNameCheck instanceof RegExp&&V(B.tagNameCheck,S)||B.tagNameCheck instanceof Function&&B.tagNameCheck(S)))return!1;if(Cn&&!ae[S]){const D=P(f)||f.parentNode,q=R(f)||f.childNodes;if(q&&D){const F=q.length;for(let Z=F-1;Z>=0;--Z){const he=$(q[Z],!0);he.__removalCount=(f.__removalCount||0)+1,D.insertBefore(he,T(f))}}}return re(f),!0}return f instanceof r&&!Nr(f)||(S==="noscript"||S==="noembed"||S==="noframes")&&V(/<\/no(script|embed|frames)/i,f.innerHTML)?(re(f),!0):(He&&f.nodeType===pt.text&&(k=f.textContent,Ut([$n,kn,xn],D=>{k=ct(k,D," ")}),f.textContent!==k&&(lt(t.removed,{element:f.cloneNode()}),f.textContent=k)),fe(G.afterSanitizeElements,f,null),!1)},Ii=function(f,k,S){if(bi&&(k==="id"||k==="name")&&(S in n||S in Pr))return!1;if(!(Sn&&!An[k]&&V(Sr,k))){if(!(gi&&V(_r,k))){if(!(Ke.attributeCheck instanceof Function&&Ke.attributeCheck(k,f))){if(!z[k]||An[k]){if(!(Ri(f)&&(B.tagNameCheck instanceof RegExp&&V(B.tagNameCheck,f)||B.tagNameCheck instanceof Function&&B.tagNameCheck(f))&&(B.attributeNameCheck instanceof RegExp&&V(B.attributeNameCheck,k)||B.attributeNameCheck instanceof Function&&B.attributeNameCheck(k,f))||k==="is"&&B.allowCustomizedBuiltInElements&&(B.tagNameCheck instanceof RegExp&&V(B.tagNameCheck,S)||B.tagNameCheck instanceof Function&&B.tagNameCheck(S))))return!1}else if(!In[k]){if(!V(pi,ct(S,ui,""))){if(!((k==="src"||k==="xlink:href"||k==="href")&&f!=="script"&&Pd(S,"data:")===0&&wi[f])){if(!(vi&&!V(Tr,ct(S,ui,"")))){if(S)return!1}}}}}}}return!0},Ri=function(f){return f!=="annotation-xml"&&Gn(f,Cr)},Li=function(f){fe(G.beforeSanitizeAttributes,f,null);const{attributes:k}=f;if(!k||Pn(f))return;const S={attrName:"",attrValue:"",keepAttr:!0,allowedAttributes:z,forceKeepAttr:void 0};let D=k.length;for(;D--;){const q=k[D],{name:F,namespaceURI:Z,value:he}=q,Ge=U(F),Nn=he;let j=F==="value"?Nn:Nd(Nn);if(S.attrName=Ge,S.attrValue=j,S.keepAttr=!0,S.forceKeepAttr=void 0,fe(G.uponSanitizeAttribute,f,S),j=S.attrValue,yi&&(Ge==="id"||Ge==="name")&&(Ce(F,f),j=Er+j),Et&&V(/((--!?|])>)|<\/(style|title|textarea)/i,j)){Ce(F,f);continue}if(Ge==="attributename"&&Gn(j,"href")){Ce(F,f);continue}if(S.forceKeepAttr)continue;if(!S.keepAttr){Ce(F,f);continue}if(!mi&&V(/\/>/i,j)){Ce(F,f);continue}He&&Ut([$n,kn,xn],Pi=>{j=ct(j,Pi," ")});const Mi=U(f.nodeName);if(!Ii(Mi,Ge,j)){Ce(F,f);continue}if(I&&typeof v=="object"&&typeof v.getAttributeType=="function"&&!Z)switch(v.getAttributeType(Mi,Ge)){case"TrustedHTML":{j=I.createHTML(j);break}case"TrustedScriptURL":{j=I.createScriptURL(j);break}}if(j!==Nn)try{Z?f.setAttributeNS(Z,F,j):f.setAttribute(F,j),Pn(f)?re(f):co(t.removed)}catch{Ce(F,f)}}fe(G.afterSanitizeAttributes,f,null)},Or=function _(f){let k=null;const S=Ti(f);for(fe(G.beforeSanitizeShadowDOM,f,null);k=S.nextNode();)fe(G.uponSanitizeShadowNode,k,null),Ei(k),Li(k),k.content instanceof o&&_(k.content);fe(G.afterSanitizeShadowDOM,f,null)};return t.sanitize=function(_){let f=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},k=null,S=null,D=null,q=null;if(Rn=!_,Rn&&(_="<!-->"),typeof _!="string"&&!Ci(_))if(typeof _.toString=="function"){if(_=_.toString(),typeof _!="string")throw dt("dirty is not a string, aborting")}else throw dt("toString is not a function");if(!t.isSupported)return _;if(_n||Mn(f),t.removed=[],typeof _=="string"&&(it=!1),it){if(_.nodeName){const he=U(_.nodeName);if(!K[he]||st[he])throw dt("root node is forbidden and cannot be sanitized in-place")}}else if(_ instanceof l)k=_i("<!---->"),S=k.ownerDocument.importNode(_,!0),S.nodeType===pt.element&&S.nodeName==="BODY"||S.nodeName==="HTML"?k=S:k.appendChild(S);else{if(!ze&&!He&&!Te&&_.indexOf("<")===-1)return I&&Rt?I.createHTML(_):_;if(k=_i(_),!k)return ze?null:Rt?C:""}k&&Tn&&re(k.firstChild);const F=Ti(it?_:k);for(;D=F.nextNode();)Ei(D),Li(D),D.content instanceof o&&Or(D.content);if(it)return _;if(ze){if(It)for(q=yn.call(k.ownerDocument);k.firstChild;)q.appendChild(k.firstChild);else q=k;return(z.shadowroot||z.shadowrootmode)&&(q=Ar.call(s,q,!0)),q}let Z=Te?k.outerHTML:k.innerHTML;return Te&&K["!doctype"]&&k.ownerDocument&&k.ownerDocument.doctype&&k.ownerDocument.doctype.name&&V(Va,k.ownerDocument.doctype.name)&&(Z="<!DOCTYPE "+k.ownerDocument.doctype.name+`>
17
- `+Z),He&&Ut([$n,kn,xn],he=>{Z=ct(Z,he," ")}),I&&Rt?I.createHTML(Z):Z},t.setConfig=function(){let _=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};Mn(_),_n=!0},t.clearConfig=function(){We=null,_n=!1},t.isValidAttribute=function(_,f,k){We||Mn({});const S=U(_),D=U(f);return Ii(S,D,k)},t.addHook=function(_,f){typeof f=="function"&&lt(G[_],f)},t.removeHook=function(_,f){if(f!==void 0){const k=Ld(G[_],f);return k===-1?void 0:Md(G[_],k,1)[0]}return co(G[_])},t.removeHooks=function(_){G[_]=[]},t.removeAllHooks=function(){G=vo()},t}var ws=Ya();function ei(){return{async:!1,breaks:!1,extensions:null,gfm:!0,hooks:null,pedantic:!1,renderer:null,silent:!1,tokenizer:null,walkTokens:null}}var Ue=ei();function Qa(e){Ue=e}var bt={exec:()=>null};function M(e,t=""){let n=typeof e=="string"?e:e.source,s={replace:(i,o)=>{let a=typeof o=="string"?o:o.source;return a=a.replace(Y.caret,"$1"),n=n.replace(i,a),s},getRegex:()=>new RegExp(n,t)};return s}var Qd=(()=>{try{return!!new RegExp("(?<=1)(?<!1)")}catch{return!1}})(),Y={codeRemoveIndent:/^(?: {1,4}| {0,3}\t)/gm,outputLinkReplace:/\\([\[\]])/g,indentCodeCompensation:/^(\s+)(?:```)/,beginningSpace:/^\s+/,endingHash:/#$/,startingSpaceChar:/^ /,endingSpaceChar:/ $/,nonSpaceChar:/[^ ]/,newLineCharGlobal:/\n/g,tabCharGlobal:/\t/g,multipleSpaceGlobal:/\s+/g,blankLine:/^[ \t]*$/,doubleBlankLine:/\n[ \t]*\n[ \t]*$/,blockquoteStart:/^ {0,3}>/,blockquoteSetextReplace:/\n {0,3}((?:=+|-+) *)(?=\n|$)/g,blockquoteSetextReplace2:/^ {0,3}>[ \t]?/gm,listReplaceTabs:/^\t+/,listReplaceNesting:/^ {1,4}(?=( {4})*[^ ])/g,listIsTask:/^\[[ xX]\] +\S/,listReplaceTask:/^\[[ xX]\] +/,listTaskCheckbox:/\[[ xX]\]/,anyLine:/\n.*\n/,hrefBrackets:/^<(.*)>$/,tableDelimiter:/[:|]/,tableAlignChars:/^\||\| *$/g,tableRowBlankLine:/\n[ \t]*$/,tableAlignRight:/^ *-+: *$/,tableAlignCenter:/^ *:-+: *$/,tableAlignLeft:/^ *:-+ *$/,startATag:/^<a /i,endATag:/^<\/a>/i,startPreScriptTag:/^<(pre|code|kbd|script)(\s|>)/i,endPreScriptTag:/^<\/(pre|code|kbd|script)(\s|>)/i,startAngleBracket:/^</,endAngleBracket:/>$/,pedanticHrefTitle:/^([^'"]*[^\s])\s+(['"])(.*)\2/,unicodeAlphaNumeric:/[\p{L}\p{N}]/u,escapeTest:/[&<>"']/,escapeReplace:/[&<>"']/g,escapeTestNoEncode:/[<>"']|&(?!(#\d{1,7}|#[Xx][a-fA-F0-9]{1,6}|\w+);)/,escapeReplaceNoEncode:/[<>"']|&(?!(#\d{1,7}|#[Xx][a-fA-F0-9]{1,6}|\w+);)/g,unescapeTest:/&(#(?:\d+)|(?:#x[0-9A-Fa-f]+)|(?:\w+));?/ig,caret:/(^|[^\[])\^/g,percentDecode:/%25/g,findPipe:/\|/g,splitPipe:/ \|/,slashPipe:/\\\|/g,carriageReturn:/\r\n|\r/g,spaceLine:/^ +$/gm,notSpaceStart:/^\S*/,endingNewline:/\n$/,listItemRegex:e=>new RegExp(`^( {0,3}${e})((?:[ ][^\\n]*)?(?:\\n|$))`),nextBulletRegex:e=>new RegExp(`^ {0,${Math.min(3,e-1)}}(?:[*+-]|\\d{1,9}[.)])((?:[ ][^\\n]*)?(?:\\n|$))`),hrRegex:e=>new RegExp(`^ {0,${Math.min(3,e-1)}}((?:- *){3,}|(?:_ *){3,}|(?:\\* *){3,})(?:\\n+|$)`),fencesBeginRegex:e=>new RegExp(`^ {0,${Math.min(3,e-1)}}(?:\`\`\`|~~~)`),headingBeginRegex:e=>new RegExp(`^ {0,${Math.min(3,e-1)}}#`),htmlBeginRegex:e=>new RegExp(`^ {0,${Math.min(3,e-1)}}<(?:[a-z].*>|!--)`,"i")},Jd=/^(?:[ \t]*(?:\n|$))+/,Zd=/^((?: {4}| {0,3}\t)[^\n]+(?:\n(?:[ \t]*(?:\n|$))*)?)+/,Xd=/^ {0,3}(`{3,}(?=[^`\n]*(?:\n|$))|~{3,})([^\n]*)(?:\n|$)(?:|([\s\S]*?)(?:\n|$))(?: {0,3}\1[~`]* *(?=\n|$)|$)/,Ct=/^ {0,3}((?:-[\t ]*){3,}|(?:_[ \t]*){3,}|(?:\*[ \t]*){3,})(?:\n+|$)/,eu=/^ {0,3}(#{1,6})(?=\s|$)(.*)(?:\n+|$)/,ti=/(?:[*+-]|\d{1,9}[.)])/,Ja=/^(?!bull |blockCode|fences|blockquote|heading|html|table)((?:.|\n(?!\s*?\n|bull |blockCode|fences|blockquote|heading|html|table))+?)\n {0,3}(=+|-+) *(?:\n+|$)/,Za=M(Ja).replace(/bull/g,ti).replace(/blockCode/g,/(?: {4}| {0,3}\t)/).replace(/fences/g,/ {0,3}(?:`{3,}|~{3,})/).replace(/blockquote/g,/ {0,3}>/).replace(/heading/g,/ {0,3}#{1,6}/).replace(/html/g,/ {0,3}<[^\n>]+>\n/).replace(/\|table/g,"").getRegex(),tu=M(Ja).replace(/bull/g,ti).replace(/blockCode/g,/(?: {4}| {0,3}\t)/).replace(/fences/g,/ {0,3}(?:`{3,}|~{3,})/).replace(/blockquote/g,/ {0,3}>/).replace(/heading/g,/ {0,3}#{1,6}/).replace(/html/g,/ {0,3}<[^\n>]+>\n/).replace(/table/g,/ {0,3}\|?(?:[:\- ]*\|)+[\:\- ]*\n/).getRegex(),ni=/^([^\n]+(?:\n(?!hr|heading|lheading|blockquote|fences|list|html|table| +\n)[^\n]+)*)/,nu=/^[^\n]+/,si=/(?!\s*\])(?:\\[\s\S]|[^\[\]\\])+/,su=M(/^ {0,3}\[(label)\]: *(?:\n[ \t]*)?([^<\s][^\s]*|<.*?>)(?:(?: +(?:\n[ \t]*)?| *\n[ \t]*)(title))? *(?:\n+|$)/).replace("label",si).replace("title",/(?:"(?:\\"?|[^"\\])*"|'[^'\n]*(?:\n[^'\n]+)*\n?'|\([^()]*\))/).getRegex(),iu=M(/^( {0,3}bull)([ \t][^\n]+?)?(?:\n|$)/).replace(/bull/g,ti).getRegex(),gn="address|article|aside|base|basefont|blockquote|body|caption|center|col|colgroup|dd|details|dialog|dir|div|dl|dt|fieldset|figcaption|figure|footer|form|frame|frameset|h[1-6]|head|header|hr|html|iframe|legend|li|link|main|menu|menuitem|meta|nav|noframes|ol|optgroup|option|p|param|search|section|summary|table|tbody|td|tfoot|th|thead|title|tr|track|ul",ii=/<!--(?:-?>|[\s\S]*?(?:-->|$))/,ou=M("^ {0,3}(?:<(script|pre|style|textarea)[\\s>][\\s\\S]*?(?:</\\1>[^\\n]*\\n+|$)|comment[^\\n]*(\\n+|$)|<\\?[\\s\\S]*?(?:\\?>\\n*|$)|<![A-Z][\\s\\S]*?(?:>\\n*|$)|<!\\[CDATA\\[[\\s\\S]*?(?:\\]\\]>\\n*|$)|</?(tag)(?: +|\\n|/?>)[\\s\\S]*?(?:(?:\\n[ ]*)+\\n|$)|<(?!script|pre|style|textarea)([a-z][\\w-]*)(?:attribute)*? */?>(?=[ \\t]*(?:\\n|$))[\\s\\S]*?(?:(?:\\n[ ]*)+\\n|$)|</(?!script|pre|style|textarea)[a-z][\\w-]*\\s*>(?=[ \\t]*(?:\\n|$))[\\s\\S]*?(?:(?:\\n[ ]*)+\\n|$))","i").replace("comment",ii).replace("tag",gn).replace("attribute",/ +[a-zA-Z:_][\w.:-]*(?: *= *"[^"\n]*"| *= *'[^'\n]*'| *= *[^\s"'=<>`]+)?/).getRegex(),Xa=M(ni).replace("hr",Ct).replace("heading"," {0,3}#{1,6}(?:\\s|$)").replace("|lheading","").replace("|table","").replace("blockquote"," {0,3}>").replace("fences"," {0,3}(?:`{3,}(?=[^`\\n]*\\n)|~{3,})[^\\n]*\\n").replace("list"," {0,3}(?:[*+-]|1[.)]) ").replace("html","</?(?:tag)(?: +|\\n|/?>)|<(?:script|pre|style|textarea|!--)").replace("tag",gn).getRegex(),au=M(/^( {0,3}> ?(paragraph|[^\n]*)(?:\n|$))+/).replace("paragraph",Xa).getRegex(),oi={blockquote:au,code:Zd,def:su,fences:Xd,heading:eu,hr:Ct,html:ou,lheading:Za,list:iu,newline:Jd,paragraph:Xa,table:bt,text:nu},mo=M("^ *([^\\n ].*)\\n {0,3}((?:\\| *)?:?-+:? *(?:\\| *:?-+:? *)*(?:\\| *)?)(?:\\n((?:(?! *\\n|hr|heading|blockquote|code|fences|list|html).*(?:\\n|$))*)\\n*|$)").replace("hr",Ct).replace("heading"," {0,3}#{1,6}(?:\\s|$)").replace("blockquote"," {0,3}>").replace("code","(?: {4}| {0,3} )[^\\n]").replace("fences"," {0,3}(?:`{3,}(?=[^`\\n]*\\n)|~{3,})[^\\n]*\\n").replace("list"," {0,3}(?:[*+-]|1[.)]) ").replace("html","</?(?:tag)(?: +|\\n|/?>)|<(?:script|pre|style|textarea|!--)").replace("tag",gn).getRegex(),ru={...oi,lheading:tu,table:mo,paragraph:M(ni).replace("hr",Ct).replace("heading"," {0,3}#{1,6}(?:\\s|$)").replace("|lheading","").replace("table",mo).replace("blockquote"," {0,3}>").replace("fences"," {0,3}(?:`{3,}(?=[^`\\n]*\\n)|~{3,})[^\\n]*\\n").replace("list"," {0,3}(?:[*+-]|1[.)]) ").replace("html","</?(?:tag)(?: +|\\n|/?>)|<(?:script|pre|style|textarea|!--)").replace("tag",gn).getRegex()},lu={...oi,html:M(`^ *(?:comment *(?:\\n|\\s*$)|<(tag)[\\s\\S]+?</\\1> *(?:\\n{2,}|\\s*$)|<tag(?:"[^"]*"|'[^']*'|\\s[^'"/>\\s]*)*?/?> *(?:\\n{2,}|\\s*$))`).replace("comment",ii).replace(/tag/g,"(?!(?:a|em|strong|small|s|cite|q|dfn|abbr|data|time|code|var|samp|kbd|sub|sup|i|b|u|mark|ruby|rt|rp|bdi|bdo|span|br|wbr|ins|del|img)\\b)\\w+(?!:|[^\\w\\s@]*@)\\b").getRegex(),def:/^ *\[([^\]]+)\]: *<?([^\s>]+)>?(?: +(["(][^\n]+[")]))? *(?:\n+|$)/,heading:/^(#{1,6})(.*)(?:\n+|$)/,fences:bt,lheading:/^(.+?)\n {0,3}(=+|-+) *(?:\n+|$)/,paragraph:M(ni).replace("hr",Ct).replace("heading",` *#{1,6} *[^
18
- ]`).replace("lheading",Za).replace("|table","").replace("blockquote"," {0,3}>").replace("|fences","").replace("|list","").replace("|html","").replace("|tag","").getRegex()},cu=/^\\([!"#$%&'()*+,\-./:;<=>?@\[\]\\^_`{|}~])/,du=/^(`+)([^`]|[^`][\s\S]*?[^`])\1(?!`)/,er=/^( {2,}|\\)\n(?!\s*$)/,uu=/^(`+|[^`])(?:(?= {2,}\n)|[\s\S]*?(?:(?=[\\<!\[`*_]|\b_|$)|[^ ](?= {2,}\n)))/,vn=/[\p{P}\p{S}]/u,ai=/[\s\p{P}\p{S}]/u,tr=/[^\s\p{P}\p{S}]/u,pu=M(/^((?![*_])punctSpace)/,"u").replace(/punctSpace/g,ai).getRegex(),nr=/(?!~)[\p{P}\p{S}]/u,fu=/(?!~)[\s\p{P}\p{S}]/u,hu=/(?:[^\s\p{P}\p{S}]|~)/u,gu=M(/link|precode-code|html/,"g").replace("link",/\[(?:[^\[\]`]|(?<a>`+)[^`]+\k<a>(?!`))*?\]\((?:\\[\s\S]|[^\\\(\)]|\((?:\\[\s\S]|[^\\\(\)])*\))*\)/).replace("precode-",Qd?"(?<!`)()":"(^^|[^`])").replace("code",/(?<b>`+)[^`]+\k<b>(?!`)/).replace("html",/<(?! )[^<>]*?>/).getRegex(),sr=/^(?:\*+(?:((?!\*)punct)|[^\s*]))|^_+(?:((?!_)punct)|([^\s_]))/,vu=M(sr,"u").replace(/punct/g,vn).getRegex(),mu=M(sr,"u").replace(/punct/g,nr).getRegex(),ir="^[^_*]*?__[^_*]*?\\*[^_*]*?(?=__)|[^*]+(?=[^*])|(?!\\*)punct(\\*+)(?=[\\s]|$)|notPunctSpace(\\*+)(?!\\*)(?=punctSpace|$)|(?!\\*)punctSpace(\\*+)(?=notPunctSpace)|[\\s](\\*+)(?!\\*)(?=punct)|(?!\\*)punct(\\*+)(?!\\*)(?=punct)|notPunctSpace(\\*+)(?=notPunctSpace)",bu=M(ir,"gu").replace(/notPunctSpace/g,tr).replace(/punctSpace/g,ai).replace(/punct/g,vn).getRegex(),yu=M(ir,"gu").replace(/notPunctSpace/g,hu).replace(/punctSpace/g,fu).replace(/punct/g,nr).getRegex(),wu=M("^[^_*]*?\\*\\*[^_*]*?_[^_*]*?(?=\\*\\*)|[^_]+(?=[^_])|(?!_)punct(_+)(?=[\\s]|$)|notPunctSpace(_+)(?!_)(?=punctSpace|$)|(?!_)punctSpace(_+)(?=notPunctSpace)|[\\s](_+)(?!_)(?=punct)|(?!_)punct(_+)(?!_)(?=punct)","gu").replace(/notPunctSpace/g,tr).replace(/punctSpace/g,ai).replace(/punct/g,vn).getRegex(),$u=M(/\\(punct)/,"gu").replace(/punct/g,vn).getRegex(),ku=M(/^<(scheme:[^\s\x00-\x1f<>]*|email)>/).replace("scheme",/[a-zA-Z][a-zA-Z0-9+.-]{1,31}/).replace("email",/[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+(@)[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+(?![-_])/).getRegex(),xu=M(ii).replace("(?:-->|$)","-->").getRegex(),Au=M("^comment|^</[a-zA-Z][\\w:-]*\\s*>|^<[a-zA-Z][\\w-]*(?:attribute)*?\\s*/?>|^<\\?[\\s\\S]*?\\?>|^<![a-zA-Z]+\\s[\\s\\S]*?>|^<!\\[CDATA\\[[\\s\\S]*?\\]\\]>").replace("comment",xu).replace("attribute",/\s+[a-zA-Z:_][\w.:-]*(?:\s*=\s*"[^"]*"|\s*=\s*'[^']*'|\s*=\s*[^\s"'=<>`]+)?/).getRegex(),Xt=/(?:\[(?:\\[\s\S]|[^\[\]\\])*\]|\\[\s\S]|`+[^`]*?`+(?!`)|[^\[\]\\`])*?/,Su=M(/^!?\[(label)\]\(\s*(href)(?:(?:[ \t]*(?:\n[ \t]*)?)(title))?\s*\)/).replace("label",Xt).replace("href",/<(?:\\.|[^\n<>\\])+>|[^ \t\n\x00-\x1f]*/).replace("title",/"(?:\\"?|[^"\\])*"|'(?:\\'?|[^'\\])*'|\((?:\\\)?|[^)\\])*\)/).getRegex(),or=M(/^!?\[(label)\]\[(ref)\]/).replace("label",Xt).replace("ref",si).getRegex(),ar=M(/^!?\[(ref)\](?:\[\])?/).replace("ref",si).getRegex(),_u=M("reflink|nolink(?!\\()","g").replace("reflink",or).replace("nolink",ar).getRegex(),bo=/[hH][tT][tT][pP][sS]?|[fF][tT][pP]/,ri={_backpedal:bt,anyPunctuation:$u,autolink:ku,blockSkip:gu,br:er,code:du,del:bt,emStrongLDelim:vu,emStrongRDelimAst:bu,emStrongRDelimUnd:wu,escape:cu,link:Su,nolink:ar,punctuation:pu,reflink:or,reflinkSearch:_u,tag:Au,text:uu,url:bt},Tu={...ri,link:M(/^!?\[(label)\]\((.*?)\)/).replace("label",Xt).getRegex(),reflink:M(/^!?\[(label)\]\s*\[([^\]]*)\]/).replace("label",Xt).getRegex()},$s={...ri,emStrongRDelimAst:yu,emStrongLDelim:mu,url:M(/^((?:protocol):\/\/|www\.)(?:[a-zA-Z0-9\-]+\.?)+[^\s<]*|^email/).replace("protocol",bo).replace("email",/[A-Za-z0-9._+-]+(@)[a-zA-Z0-9-_]+(?:\.[a-zA-Z0-9-_]*[a-zA-Z0-9])+(?![-_])/).getRegex(),_backpedal:/(?:[^?!.,:;*_'"~()&]+|\([^)]*\)|&(?![a-zA-Z0-9]+;$)|[?!.,:;*_'"~)]+(?!$))+/,del:/^(~~?)(?=[^\s~])((?:\\[\s\S]|[^\\])*?(?:\\[\s\S]|[^\s~\\]))\1(?=[^~]|$)/,text:M(/^([`~]+|[^`~])(?:(?= {2,}\n)|(?=[a-zA-Z0-9.!#$%&'*+\/=?_`{\|}~-]+@)|[\s\S]*?(?:(?=[\\<!\[`*~_]|\b_|protocol:\/\/|www\.|$)|[^ ](?= {2,}\n)|[^a-zA-Z0-9.!#$%&'*+\/=?_`{\|}~-](?=[a-zA-Z0-9.!#$%&'*+\/=?_`{\|}~-]+@)))/).replace("protocol",bo).getRegex()},Cu={...$s,br:M(er).replace("{2,}","*").getRegex(),text:M($s.text).replace("\\b_","\\b_| {2,}\\n").replace(/\{2,\}/g,"*").getRegex()},Ht={normal:oi,gfm:ru,pedantic:lu},ft={normal:ri,gfm:$s,breaks:Cu,pedantic:Tu},Eu={"&":"&amp;","<":"&lt;",">":"&gt;",'"':"&quot;","'":"&#39;"},yo=e=>Eu[e];function ve(e,t){if(t){if(Y.escapeTest.test(e))return e.replace(Y.escapeReplace,yo)}else if(Y.escapeTestNoEncode.test(e))return e.replace(Y.escapeReplaceNoEncode,yo);return e}function wo(e){try{e=encodeURI(e).replace(Y.percentDecode,"%")}catch{return null}return e}function $o(e,t){let n=e.replace(Y.findPipe,(o,a,l)=>{let r=!1,p=a;for(;--p>=0&&l[p]==="\\";)r=!r;return r?"|":" |"}),s=n.split(Y.splitPipe),i=0;if(s[0].trim()||s.shift(),s.length>0&&!s.at(-1)?.trim()&&s.pop(),t)if(s.length>t)s.splice(t);else for(;s.length<t;)s.push("");for(;i<s.length;i++)s[i]=s[i].trim().replace(Y.slashPipe,"|");return s}function ht(e,t,n){let s=e.length;if(s===0)return"";let i=0;for(;i<s&&e.charAt(s-i-1)===t;)i++;return e.slice(0,s-i)}function Iu(e,t){if(e.indexOf(t[1])===-1)return-1;let n=0;for(let s=0;s<e.length;s++)if(e[s]==="\\")s++;else if(e[s]===t[0])n++;else if(e[s]===t[1]&&(n--,n<0))return s;return n>0?-2:-1}function ko(e,t,n,s,i){let o=t.href,a=t.title||null,l=e[1].replace(i.other.outputLinkReplace,"$1");s.state.inLink=!0;let r={type:e[0].charAt(0)==="!"?"image":"link",raw:n,href:o,title:a,text:l,tokens:s.inlineTokens(l)};return s.state.inLink=!1,r}function Ru(e,t,n){let s=e.match(n.other.indentCodeCompensation);if(s===null)return t;let i=s[1];return t.split(`
19
- `).map(o=>{let a=o.match(n.other.beginningSpace);if(a===null)return o;let[l]=a;return l.length>=i.length?o.slice(i.length):o}).join(`
20
- `)}var en=class{options;rules;lexer;constructor(e){this.options=e||Ue}space(e){let t=this.rules.block.newline.exec(e);if(t&&t[0].length>0)return{type:"space",raw:t[0]}}code(e){let t=this.rules.block.code.exec(e);if(t){let n=t[0].replace(this.rules.other.codeRemoveIndent,"");return{type:"code",raw:t[0],codeBlockStyle:"indented",text:this.options.pedantic?n:ht(n,`
21
- `)}}}fences(e){let t=this.rules.block.fences.exec(e);if(t){let n=t[0],s=Ru(n,t[3]||"",this.rules);return{type:"code",raw:n,lang:t[2]?t[2].trim().replace(this.rules.inline.anyPunctuation,"$1"):t[2],text:s}}}heading(e){let t=this.rules.block.heading.exec(e);if(t){let n=t[2].trim();if(this.rules.other.endingHash.test(n)){let s=ht(n,"#");(this.options.pedantic||!s||this.rules.other.endingSpaceChar.test(s))&&(n=s.trim())}return{type:"heading",raw:t[0],depth:t[1].length,text:n,tokens:this.lexer.inline(n)}}}hr(e){let t=this.rules.block.hr.exec(e);if(t)return{type:"hr",raw:ht(t[0],`
22
- `)}}blockquote(e){let t=this.rules.block.blockquote.exec(e);if(t){let n=ht(t[0],`
23
- `).split(`
24
- `),s="",i="",o=[];for(;n.length>0;){let a=!1,l=[],r;for(r=0;r<n.length;r++)if(this.rules.other.blockquoteStart.test(n[r]))l.push(n[r]),a=!0;else if(!a)l.push(n[r]);else break;n=n.slice(r);let p=l.join(`
25
- `),d=p.replace(this.rules.other.blockquoteSetextReplace,`
26
- $1`).replace(this.rules.other.blockquoteSetextReplace2,"");s=s?`${s}
27
- ${p}`:p,i=i?`${i}
28
- ${d}`:d;let u=this.lexer.state.top;if(this.lexer.state.top=!0,this.lexer.blockTokens(d,o,!0),this.lexer.state.top=u,n.length===0)break;let h=o.at(-1);if(h?.type==="code")break;if(h?.type==="blockquote"){let v=h,w=v.raw+`
29
- `+n.join(`
30
- `),$=this.blockquote(w);o[o.length-1]=$,s=s.substring(0,s.length-v.raw.length)+$.raw,i=i.substring(0,i.length-v.text.length)+$.text;break}else if(h?.type==="list"){let v=h,w=v.raw+`
31
- `+n.join(`
32
- `),$=this.list(w);o[o.length-1]=$,s=s.substring(0,s.length-h.raw.length)+$.raw,i=i.substring(0,i.length-v.raw.length)+$.raw,n=w.substring(o.at(-1).raw.length).split(`
33
- `);continue}}return{type:"blockquote",raw:s,tokens:o,text:i}}}list(e){let t=this.rules.block.list.exec(e);if(t){let n=t[1].trim(),s=n.length>1,i={type:"list",raw:"",ordered:s,start:s?+n.slice(0,-1):"",loose:!1,items:[]};n=s?`\\d{1,9}\\${n.slice(-1)}`:`\\${n}`,this.options.pedantic&&(n=s?n:"[*+-]");let o=this.rules.other.listItemRegex(n),a=!1;for(;e;){let r=!1,p="",d="";if(!(t=o.exec(e))||this.rules.block.hr.test(e))break;p=t[0],e=e.substring(p.length);let u=t[2].split(`
34
- `,1)[0].replace(this.rules.other.listReplaceTabs,$=>" ".repeat(3*$.length)),h=e.split(`
35
- `,1)[0],v=!u.trim(),w=0;if(this.options.pedantic?(w=2,d=u.trimStart()):v?w=t[1].length+1:(w=t[2].search(this.rules.other.nonSpaceChar),w=w>4?1:w,d=u.slice(w),w+=t[1].length),v&&this.rules.other.blankLine.test(h)&&(p+=h+`
36
- `,e=e.substring(h.length+1),r=!0),!r){let $=this.rules.other.nextBulletRegex(w),x=this.rules.other.hrRegex(w),T=this.rules.other.fencesBeginRegex(w),R=this.rules.other.headingBeginRegex(w),P=this.rules.other.htmlBeginRegex(w);for(;e;){let I=e.split(`
37
- `,1)[0],C;if(h=I,this.options.pedantic?(h=h.replace(this.rules.other.listReplaceNesting," "),C=h):C=h.replace(this.rules.other.tabCharGlobal," "),T.test(h)||R.test(h)||P.test(h)||$.test(h)||x.test(h))break;if(C.search(this.rules.other.nonSpaceChar)>=w||!h.trim())d+=`
38
- `+C.slice(w);else{if(v||u.replace(this.rules.other.tabCharGlobal," ").search(this.rules.other.nonSpaceChar)>=4||T.test(u)||R.test(u)||x.test(u))break;d+=`
39
- `+h}!v&&!h.trim()&&(v=!0),p+=I+`
40
- `,e=e.substring(I.length+1),u=C.slice(w)}}i.loose||(a?i.loose=!0:this.rules.other.doubleBlankLine.test(p)&&(a=!0)),i.items.push({type:"list_item",raw:p,task:!!this.options.gfm&&this.rules.other.listIsTask.test(d),loose:!1,text:d,tokens:[]}),i.raw+=p}let l=i.items.at(-1);if(l)l.raw=l.raw.trimEnd(),l.text=l.text.trimEnd();else return;i.raw=i.raw.trimEnd();for(let r of i.items){if(this.lexer.state.top=!1,r.tokens=this.lexer.blockTokens(r.text,[]),r.task){if(r.text=r.text.replace(this.rules.other.listReplaceTask,""),r.tokens[0]?.type==="text"||r.tokens[0]?.type==="paragraph"){r.tokens[0].raw=r.tokens[0].raw.replace(this.rules.other.listReplaceTask,""),r.tokens[0].text=r.tokens[0].text.replace(this.rules.other.listReplaceTask,"");for(let d=this.lexer.inlineQueue.length-1;d>=0;d--)if(this.rules.other.listIsTask.test(this.lexer.inlineQueue[d].src)){this.lexer.inlineQueue[d].src=this.lexer.inlineQueue[d].src.replace(this.rules.other.listReplaceTask,"");break}}let p=this.rules.other.listTaskCheckbox.exec(r.raw);if(p){let d={type:"checkbox",raw:p[0]+" ",checked:p[0]!=="[ ]"};r.checked=d.checked,i.loose?r.tokens[0]&&["paragraph","text"].includes(r.tokens[0].type)&&"tokens"in r.tokens[0]&&r.tokens[0].tokens?(r.tokens[0].raw=d.raw+r.tokens[0].raw,r.tokens[0].text=d.raw+r.tokens[0].text,r.tokens[0].tokens.unshift(d)):r.tokens.unshift({type:"paragraph",raw:d.raw,text:d.raw,tokens:[d]}):r.tokens.unshift(d)}}if(!i.loose){let p=r.tokens.filter(u=>u.type==="space"),d=p.length>0&&p.some(u=>this.rules.other.anyLine.test(u.raw));i.loose=d}}if(i.loose)for(let r of i.items){r.loose=!0;for(let p of r.tokens)p.type==="text"&&(p.type="paragraph")}return i}}html(e){let t=this.rules.block.html.exec(e);if(t)return{type:"html",block:!0,raw:t[0],pre:t[1]==="pre"||t[1]==="script"||t[1]==="style",text:t[0]}}def(e){let t=this.rules.block.def.exec(e);if(t){let n=t[1].toLowerCase().replace(this.rules.other.multipleSpaceGlobal," "),s=t[2]?t[2].replace(this.rules.other.hrefBrackets,"$1").replace(this.rules.inline.anyPunctuation,"$1"):"",i=t[3]?t[3].substring(1,t[3].length-1).replace(this.rules.inline.anyPunctuation,"$1"):t[3];return{type:"def",tag:n,raw:t[0],href:s,title:i}}}table(e){let t=this.rules.block.table.exec(e);if(!t||!this.rules.other.tableDelimiter.test(t[2]))return;let n=$o(t[1]),s=t[2].replace(this.rules.other.tableAlignChars,"").split("|"),i=t[3]?.trim()?t[3].replace(this.rules.other.tableRowBlankLine,"").split(`
41
- `):[],o={type:"table",raw:t[0],header:[],align:[],rows:[]};if(n.length===s.length){for(let a of s)this.rules.other.tableAlignRight.test(a)?o.align.push("right"):this.rules.other.tableAlignCenter.test(a)?o.align.push("center"):this.rules.other.tableAlignLeft.test(a)?o.align.push("left"):o.align.push(null);for(let a=0;a<n.length;a++)o.header.push({text:n[a],tokens:this.lexer.inline(n[a]),header:!0,align:o.align[a]});for(let a of i)o.rows.push($o(a,o.header.length).map((l,r)=>({text:l,tokens:this.lexer.inline(l),header:!1,align:o.align[r]})));return o}}lheading(e){let t=this.rules.block.lheading.exec(e);if(t)return{type:"heading",raw:t[0],depth:t[2].charAt(0)==="="?1:2,text:t[1],tokens:this.lexer.inline(t[1])}}paragraph(e){let t=this.rules.block.paragraph.exec(e);if(t){let n=t[1].charAt(t[1].length-1)===`
42
- `?t[1].slice(0,-1):t[1];return{type:"paragraph",raw:t[0],text:n,tokens:this.lexer.inline(n)}}}text(e){let t=this.rules.block.text.exec(e);if(t)return{type:"text",raw:t[0],text:t[0],tokens:this.lexer.inline(t[0])}}escape(e){let t=this.rules.inline.escape.exec(e);if(t)return{type:"escape",raw:t[0],text:t[1]}}tag(e){let t=this.rules.inline.tag.exec(e);if(t)return!this.lexer.state.inLink&&this.rules.other.startATag.test(t[0])?this.lexer.state.inLink=!0:this.lexer.state.inLink&&this.rules.other.endATag.test(t[0])&&(this.lexer.state.inLink=!1),!this.lexer.state.inRawBlock&&this.rules.other.startPreScriptTag.test(t[0])?this.lexer.state.inRawBlock=!0:this.lexer.state.inRawBlock&&this.rules.other.endPreScriptTag.test(t[0])&&(this.lexer.state.inRawBlock=!1),{type:"html",raw:t[0],inLink:this.lexer.state.inLink,inRawBlock:this.lexer.state.inRawBlock,block:!1,text:t[0]}}link(e){let t=this.rules.inline.link.exec(e);if(t){let n=t[2].trim();if(!this.options.pedantic&&this.rules.other.startAngleBracket.test(n)){if(!this.rules.other.endAngleBracket.test(n))return;let o=ht(n.slice(0,-1),"\\");if((n.length-o.length)%2===0)return}else{let o=Iu(t[2],"()");if(o===-2)return;if(o>-1){let a=(t[0].indexOf("!")===0?5:4)+t[1].length+o;t[2]=t[2].substring(0,o),t[0]=t[0].substring(0,a).trim(),t[3]=""}}let s=t[2],i="";if(this.options.pedantic){let o=this.rules.other.pedanticHrefTitle.exec(s);o&&(s=o[1],i=o[3])}else i=t[3]?t[3].slice(1,-1):"";return s=s.trim(),this.rules.other.startAngleBracket.test(s)&&(this.options.pedantic&&!this.rules.other.endAngleBracket.test(n)?s=s.slice(1):s=s.slice(1,-1)),ko(t,{href:s&&s.replace(this.rules.inline.anyPunctuation,"$1"),title:i&&i.replace(this.rules.inline.anyPunctuation,"$1")},t[0],this.lexer,this.rules)}}reflink(e,t){let n;if((n=this.rules.inline.reflink.exec(e))||(n=this.rules.inline.nolink.exec(e))){let s=(n[2]||n[1]).replace(this.rules.other.multipleSpaceGlobal," "),i=t[s.toLowerCase()];if(!i){let o=n[0].charAt(0);return{type:"text",raw:o,text:o}}return ko(n,i,n[0],this.lexer,this.rules)}}emStrong(e,t,n=""){let s=this.rules.inline.emStrongLDelim.exec(e);if(!(!s||s[3]&&n.match(this.rules.other.unicodeAlphaNumeric))&&(!(s[1]||s[2])||!n||this.rules.inline.punctuation.exec(n))){let i=[...s[0]].length-1,o,a,l=i,r=0,p=s[0][0]==="*"?this.rules.inline.emStrongRDelimAst:this.rules.inline.emStrongRDelimUnd;for(p.lastIndex=0,t=t.slice(-1*e.length+i);(s=p.exec(t))!=null;){if(o=s[1]||s[2]||s[3]||s[4]||s[5]||s[6],!o)continue;if(a=[...o].length,s[3]||s[4]){l+=a;continue}else if((s[5]||s[6])&&i%3&&!((i+a)%3)){r+=a;continue}if(l-=a,l>0)continue;a=Math.min(a,a+l+r);let d=[...s[0]][0].length,u=e.slice(0,i+s.index+d+a);if(Math.min(i,a)%2){let v=u.slice(1,-1);return{type:"em",raw:u,text:v,tokens:this.lexer.inlineTokens(v)}}let h=u.slice(2,-2);return{type:"strong",raw:u,text:h,tokens:this.lexer.inlineTokens(h)}}}}codespan(e){let t=this.rules.inline.code.exec(e);if(t){let n=t[2].replace(this.rules.other.newLineCharGlobal," "),s=this.rules.other.nonSpaceChar.test(n),i=this.rules.other.startingSpaceChar.test(n)&&this.rules.other.endingSpaceChar.test(n);return s&&i&&(n=n.substring(1,n.length-1)),{type:"codespan",raw:t[0],text:n}}}br(e){let t=this.rules.inline.br.exec(e);if(t)return{type:"br",raw:t[0]}}del(e){let t=this.rules.inline.del.exec(e);if(t)return{type:"del",raw:t[0],text:t[2],tokens:this.lexer.inlineTokens(t[2])}}autolink(e){let t=this.rules.inline.autolink.exec(e);if(t){let n,s;return t[2]==="@"?(n=t[1],s="mailto:"+n):(n=t[1],s=n),{type:"link",raw:t[0],text:n,href:s,tokens:[{type:"text",raw:n,text:n}]}}}url(e){let t;if(t=this.rules.inline.url.exec(e)){let n,s;if(t[2]==="@")n=t[0],s="mailto:"+n;else{let i;do i=t[0],t[0]=this.rules.inline._backpedal.exec(t[0])?.[0]??"";while(i!==t[0]);n=t[0],t[1]==="www."?s="http://"+t[0]:s=t[0]}return{type:"link",raw:t[0],text:n,href:s,tokens:[{type:"text",raw:n,text:n}]}}}inlineText(e){let t=this.rules.inline.text.exec(e);if(t){let n=this.lexer.state.inRawBlock;return{type:"text",raw:t[0],text:t[0],escaped:n}}}},se=class ks{tokens;options;state;inlineQueue;tokenizer;constructor(t){this.tokens=[],this.tokens.links=Object.create(null),this.options=t||Ue,this.options.tokenizer=this.options.tokenizer||new en,this.tokenizer=this.options.tokenizer,this.tokenizer.options=this.options,this.tokenizer.lexer=this,this.inlineQueue=[],this.state={inLink:!1,inRawBlock:!1,top:!0};let n={other:Y,block:Ht.normal,inline:ft.normal};this.options.pedantic?(n.block=Ht.pedantic,n.inline=ft.pedantic):this.options.gfm&&(n.block=Ht.gfm,this.options.breaks?n.inline=ft.breaks:n.inline=ft.gfm),this.tokenizer.rules=n}static get rules(){return{block:Ht,inline:ft}}static lex(t,n){return new ks(n).lex(t)}static lexInline(t,n){return new ks(n).inlineTokens(t)}lex(t){t=t.replace(Y.carriageReturn,`
43
- `),this.blockTokens(t,this.tokens);for(let n=0;n<this.inlineQueue.length;n++){let s=this.inlineQueue[n];this.inlineTokens(s.src,s.tokens)}return this.inlineQueue=[],this.tokens}blockTokens(t,n=[],s=!1){for(this.options.pedantic&&(t=t.replace(Y.tabCharGlobal," ").replace(Y.spaceLine,""));t;){let i;if(this.options.extensions?.block?.some(a=>(i=a.call({lexer:this},t,n))?(t=t.substring(i.raw.length),n.push(i),!0):!1))continue;if(i=this.tokenizer.space(t)){t=t.substring(i.raw.length);let a=n.at(-1);i.raw.length===1&&a!==void 0?a.raw+=`
44
- `:n.push(i);continue}if(i=this.tokenizer.code(t)){t=t.substring(i.raw.length);let a=n.at(-1);a?.type==="paragraph"||a?.type==="text"?(a.raw+=(a.raw.endsWith(`
45
- `)?"":`
46
- `)+i.raw,a.text+=`
47
- `+i.text,this.inlineQueue.at(-1).src=a.text):n.push(i);continue}if(i=this.tokenizer.fences(t)){t=t.substring(i.raw.length),n.push(i);continue}if(i=this.tokenizer.heading(t)){t=t.substring(i.raw.length),n.push(i);continue}if(i=this.tokenizer.hr(t)){t=t.substring(i.raw.length),n.push(i);continue}if(i=this.tokenizer.blockquote(t)){t=t.substring(i.raw.length),n.push(i);continue}if(i=this.tokenizer.list(t)){t=t.substring(i.raw.length),n.push(i);continue}if(i=this.tokenizer.html(t)){t=t.substring(i.raw.length),n.push(i);continue}if(i=this.tokenizer.def(t)){t=t.substring(i.raw.length);let a=n.at(-1);a?.type==="paragraph"||a?.type==="text"?(a.raw+=(a.raw.endsWith(`
48
- `)?"":`
49
- `)+i.raw,a.text+=`
50
- `+i.raw,this.inlineQueue.at(-1).src=a.text):this.tokens.links[i.tag]||(this.tokens.links[i.tag]={href:i.href,title:i.title},n.push(i));continue}if(i=this.tokenizer.table(t)){t=t.substring(i.raw.length),n.push(i);continue}if(i=this.tokenizer.lheading(t)){t=t.substring(i.raw.length),n.push(i);continue}let o=t;if(this.options.extensions?.startBlock){let a=1/0,l=t.slice(1),r;this.options.extensions.startBlock.forEach(p=>{r=p.call({lexer:this},l),typeof r=="number"&&r>=0&&(a=Math.min(a,r))}),a<1/0&&a>=0&&(o=t.substring(0,a+1))}if(this.state.top&&(i=this.tokenizer.paragraph(o))){let a=n.at(-1);s&&a?.type==="paragraph"?(a.raw+=(a.raw.endsWith(`
51
- `)?"":`
52
- `)+i.raw,a.text+=`
53
- `+i.text,this.inlineQueue.pop(),this.inlineQueue.at(-1).src=a.text):n.push(i),s=o.length!==t.length,t=t.substring(i.raw.length);continue}if(i=this.tokenizer.text(t)){t=t.substring(i.raw.length);let a=n.at(-1);a?.type==="text"?(a.raw+=(a.raw.endsWith(`
54
- `)?"":`
55
- `)+i.raw,a.text+=`
56
- `+i.text,this.inlineQueue.pop(),this.inlineQueue.at(-1).src=a.text):n.push(i);continue}if(t){let a="Infinite loop on byte: "+t.charCodeAt(0);if(this.options.silent){console.error(a);break}else throw new Error(a)}}return this.state.top=!0,n}inline(t,n=[]){return this.inlineQueue.push({src:t,tokens:n}),n}inlineTokens(t,n=[]){let s=t,i=null;if(this.tokens.links){let r=Object.keys(this.tokens.links);if(r.length>0)for(;(i=this.tokenizer.rules.inline.reflinkSearch.exec(s))!=null;)r.includes(i[0].slice(i[0].lastIndexOf("[")+1,-1))&&(s=s.slice(0,i.index)+"["+"a".repeat(i[0].length-2)+"]"+s.slice(this.tokenizer.rules.inline.reflinkSearch.lastIndex))}for(;(i=this.tokenizer.rules.inline.anyPunctuation.exec(s))!=null;)s=s.slice(0,i.index)+"++"+s.slice(this.tokenizer.rules.inline.anyPunctuation.lastIndex);let o;for(;(i=this.tokenizer.rules.inline.blockSkip.exec(s))!=null;)o=i[2]?i[2].length:0,s=s.slice(0,i.index+o)+"["+"a".repeat(i[0].length-o-2)+"]"+s.slice(this.tokenizer.rules.inline.blockSkip.lastIndex);s=this.options.hooks?.emStrongMask?.call({lexer:this},s)??s;let a=!1,l="";for(;t;){a||(l=""),a=!1;let r;if(this.options.extensions?.inline?.some(d=>(r=d.call({lexer:this},t,n))?(t=t.substring(r.raw.length),n.push(r),!0):!1))continue;if(r=this.tokenizer.escape(t)){t=t.substring(r.raw.length),n.push(r);continue}if(r=this.tokenizer.tag(t)){t=t.substring(r.raw.length),n.push(r);continue}if(r=this.tokenizer.link(t)){t=t.substring(r.raw.length),n.push(r);continue}if(r=this.tokenizer.reflink(t,this.tokens.links)){t=t.substring(r.raw.length);let d=n.at(-1);r.type==="text"&&d?.type==="text"?(d.raw+=r.raw,d.text+=r.text):n.push(r);continue}if(r=this.tokenizer.emStrong(t,s,l)){t=t.substring(r.raw.length),n.push(r);continue}if(r=this.tokenizer.codespan(t)){t=t.substring(r.raw.length),n.push(r);continue}if(r=this.tokenizer.br(t)){t=t.substring(r.raw.length),n.push(r);continue}if(r=this.tokenizer.del(t)){t=t.substring(r.raw.length),n.push(r);continue}if(r=this.tokenizer.autolink(t)){t=t.substring(r.raw.length),n.push(r);continue}if(!this.state.inLink&&(r=this.tokenizer.url(t))){t=t.substring(r.raw.length),n.push(r);continue}let p=t;if(this.options.extensions?.startInline){let d=1/0,u=t.slice(1),h;this.options.extensions.startInline.forEach(v=>{h=v.call({lexer:this},u),typeof h=="number"&&h>=0&&(d=Math.min(d,h))}),d<1/0&&d>=0&&(p=t.substring(0,d+1))}if(r=this.tokenizer.inlineText(p)){t=t.substring(r.raw.length),r.raw.slice(-1)!=="_"&&(l=r.raw.slice(-1)),a=!0;let d=n.at(-1);d?.type==="text"?(d.raw+=r.raw,d.text+=r.text):n.push(r);continue}if(t){let d="Infinite loop on byte: "+t.charCodeAt(0);if(this.options.silent){console.error(d);break}else throw new Error(d)}}return n}},tn=class{options;parser;constructor(e){this.options=e||Ue}space(e){return""}code({text:e,lang:t,escaped:n}){let s=(t||"").match(Y.notSpaceStart)?.[0],i=e.replace(Y.endingNewline,"")+`
57
- `;return s?'<pre><code class="language-'+ve(s)+'">'+(n?i:ve(i,!0))+`</code></pre>
58
- `:"<pre><code>"+(n?i:ve(i,!0))+`</code></pre>
59
- `}blockquote({tokens:e}){return`<blockquote>
60
- ${this.parser.parse(e)}</blockquote>
61
- `}html({text:e}){return e}def(e){return""}heading({tokens:e,depth:t}){return`<h${t}>${this.parser.parseInline(e)}</h${t}>
62
- `}hr(e){return`<hr>
63
- `}list(e){let t=e.ordered,n=e.start,s="";for(let a=0;a<e.items.length;a++){let l=e.items[a];s+=this.listitem(l)}let i=t?"ol":"ul",o=t&&n!==1?' start="'+n+'"':"";return"<"+i+o+`>
64
- `+s+"</"+i+`>
65
- `}listitem(e){return`<li>${this.parser.parse(e.tokens)}</li>
66
- `}checkbox({checked:e}){return"<input "+(e?'checked="" ':"")+'disabled="" type="checkbox"> '}paragraph({tokens:e}){return`<p>${this.parser.parseInline(e)}</p>
67
- `}table(e){let t="",n="";for(let i=0;i<e.header.length;i++)n+=this.tablecell(e.header[i]);t+=this.tablerow({text:n});let s="";for(let i=0;i<e.rows.length;i++){let o=e.rows[i];n="";for(let a=0;a<o.length;a++)n+=this.tablecell(o[a]);s+=this.tablerow({text:n})}return s&&(s=`<tbody>${s}</tbody>`),`<table>
68
- <thead>
69
- `+t+`</thead>
70
- `+s+`</table>
71
- `}tablerow({text:e}){return`<tr>
72
- ${e}</tr>
73
- `}tablecell(e){let t=this.parser.parseInline(e.tokens),n=e.header?"th":"td";return(e.align?`<${n} align="${e.align}">`:`<${n}>`)+t+`</${n}>
74
- `}strong({tokens:e}){return`<strong>${this.parser.parseInline(e)}</strong>`}em({tokens:e}){return`<em>${this.parser.parseInline(e)}</em>`}codespan({text:e}){return`<code>${ve(e,!0)}</code>`}br(e){return"<br>"}del({tokens:e}){return`<del>${this.parser.parseInline(e)}</del>`}link({href:e,title:t,tokens:n}){let s=this.parser.parseInline(n),i=wo(e);if(i===null)return s;e=i;let o='<a href="'+e+'"';return t&&(o+=' title="'+ve(t)+'"'),o+=">"+s+"</a>",o}image({href:e,title:t,text:n,tokens:s}){s&&(n=this.parser.parseInline(s,this.parser.textRenderer));let i=wo(e);if(i===null)return ve(n);e=i;let o=`<img src="${e}" alt="${n}"`;return t&&(o+=` title="${ve(t)}"`),o+=">",o}text(e){return"tokens"in e&&e.tokens?this.parser.parseInline(e.tokens):"escaped"in e&&e.escaped?e.text:ve(e.text)}},li=class{strong({text:e}){return e}em({text:e}){return e}codespan({text:e}){return e}del({text:e}){return e}html({text:e}){return e}text({text:e}){return e}link({text:e}){return""+e}image({text:e}){return""+e}br(){return""}checkbox({raw:e}){return e}},ie=class xs{options;renderer;textRenderer;constructor(t){this.options=t||Ue,this.options.renderer=this.options.renderer||new tn,this.renderer=this.options.renderer,this.renderer.options=this.options,this.renderer.parser=this,this.textRenderer=new li}static parse(t,n){return new xs(n).parse(t)}static parseInline(t,n){return new xs(n).parseInline(t)}parse(t){let n="";for(let s=0;s<t.length;s++){let i=t[s];if(this.options.extensions?.renderers?.[i.type]){let a=i,l=this.options.extensions.renderers[a.type].call({parser:this},a);if(l!==!1||!["space","hr","heading","code","table","blockquote","list","html","def","paragraph","text"].includes(a.type)){n+=l||"";continue}}let o=i;switch(o.type){case"space":{n+=this.renderer.space(o);break}case"hr":{n+=this.renderer.hr(o);break}case"heading":{n+=this.renderer.heading(o);break}case"code":{n+=this.renderer.code(o);break}case"table":{n+=this.renderer.table(o);break}case"blockquote":{n+=this.renderer.blockquote(o);break}case"list":{n+=this.renderer.list(o);break}case"checkbox":{n+=this.renderer.checkbox(o);break}case"html":{n+=this.renderer.html(o);break}case"def":{n+=this.renderer.def(o);break}case"paragraph":{n+=this.renderer.paragraph(o);break}case"text":{n+=this.renderer.text(o);break}default:{let a='Token with "'+o.type+'" type was not found.';if(this.options.silent)return console.error(a),"";throw new Error(a)}}}return n}parseInline(t,n=this.renderer){let s="";for(let i=0;i<t.length;i++){let o=t[i];if(this.options.extensions?.renderers?.[o.type]){let l=this.options.extensions.renderers[o.type].call({parser:this},o);if(l!==!1||!["escape","html","link","image","strong","em","codespan","br","del","text"].includes(o.type)){s+=l||"";continue}}let a=o;switch(a.type){case"escape":{s+=n.text(a);break}case"html":{s+=n.html(a);break}case"link":{s+=n.link(a);break}case"image":{s+=n.image(a);break}case"checkbox":{s+=n.checkbox(a);break}case"strong":{s+=n.strong(a);break}case"em":{s+=n.em(a);break}case"codespan":{s+=n.codespan(a);break}case"br":{s+=n.br(a);break}case"del":{s+=n.del(a);break}case"text":{s+=n.text(a);break}default:{let l='Token with "'+a.type+'" type was not found.';if(this.options.silent)return console.error(l),"";throw new Error(l)}}}return s}},gt=class{options;block;constructor(e){this.options=e||Ue}static passThroughHooks=new Set(["preprocess","postprocess","processAllTokens","emStrongMask"]);static passThroughHooksRespectAsync=new Set(["preprocess","postprocess","processAllTokens"]);preprocess(e){return e}postprocess(e){return e}processAllTokens(e){return e}emStrongMask(e){return e}provideLexer(){return this.block?se.lex:se.lexInline}provideParser(){return this.block?ie.parse:ie.parseInline}},Lu=class{defaults=ei();options=this.setOptions;parse=this.parseMarkdown(!0);parseInline=this.parseMarkdown(!1);Parser=ie;Renderer=tn;TextRenderer=li;Lexer=se;Tokenizer=en;Hooks=gt;constructor(...e){this.use(...e)}walkTokens(e,t){let n=[];for(let s of e)switch(n=n.concat(t.call(this,s)),s.type){case"table":{let i=s;for(let o of i.header)n=n.concat(this.walkTokens(o.tokens,t));for(let o of i.rows)for(let a of o)n=n.concat(this.walkTokens(a.tokens,t));break}case"list":{let i=s;n=n.concat(this.walkTokens(i.items,t));break}default:{let i=s;this.defaults.extensions?.childTokens?.[i.type]?this.defaults.extensions.childTokens[i.type].forEach(o=>{let a=i[o].flat(1/0);n=n.concat(this.walkTokens(a,t))}):i.tokens&&(n=n.concat(this.walkTokens(i.tokens,t)))}}return n}use(...e){let t=this.defaults.extensions||{renderers:{},childTokens:{}};return e.forEach(n=>{let s={...n};if(s.async=this.defaults.async||s.async||!1,n.extensions&&(n.extensions.forEach(i=>{if(!i.name)throw new Error("extension name required");if("renderer"in i){let o=t.renderers[i.name];o?t.renderers[i.name]=function(...a){let l=i.renderer.apply(this,a);return l===!1&&(l=o.apply(this,a)),l}:t.renderers[i.name]=i.renderer}if("tokenizer"in i){if(!i.level||i.level!=="block"&&i.level!=="inline")throw new Error("extension level must be 'block' or 'inline'");let o=t[i.level];o?o.unshift(i.tokenizer):t[i.level]=[i.tokenizer],i.start&&(i.level==="block"?t.startBlock?t.startBlock.push(i.start):t.startBlock=[i.start]:i.level==="inline"&&(t.startInline?t.startInline.push(i.start):t.startInline=[i.start]))}"childTokens"in i&&i.childTokens&&(t.childTokens[i.name]=i.childTokens)}),s.extensions=t),n.renderer){let i=this.defaults.renderer||new tn(this.defaults);for(let o in n.renderer){if(!(o in i))throw new Error(`renderer '${o}' does not exist`);if(["options","parser"].includes(o))continue;let a=o,l=n.renderer[a],r=i[a];i[a]=(...p)=>{let d=l.apply(i,p);return d===!1&&(d=r.apply(i,p)),d||""}}s.renderer=i}if(n.tokenizer){let i=this.defaults.tokenizer||new en(this.defaults);for(let o in n.tokenizer){if(!(o in i))throw new Error(`tokenizer '${o}' does not exist`);if(["options","rules","lexer"].includes(o))continue;let a=o,l=n.tokenizer[a],r=i[a];i[a]=(...p)=>{let d=l.apply(i,p);return d===!1&&(d=r.apply(i,p)),d}}s.tokenizer=i}if(n.hooks){let i=this.defaults.hooks||new gt;for(let o in n.hooks){if(!(o in i))throw new Error(`hook '${o}' does not exist`);if(["options","block"].includes(o))continue;let a=o,l=n.hooks[a],r=i[a];gt.passThroughHooks.has(o)?i[a]=p=>{if(this.defaults.async&&gt.passThroughHooksRespectAsync.has(o))return(async()=>{let u=await l.call(i,p);return r.call(i,u)})();let d=l.call(i,p);return r.call(i,d)}:i[a]=(...p)=>{if(this.defaults.async)return(async()=>{let u=await l.apply(i,p);return u===!1&&(u=await r.apply(i,p)),u})();let d=l.apply(i,p);return d===!1&&(d=r.apply(i,p)),d}}s.hooks=i}if(n.walkTokens){let i=this.defaults.walkTokens,o=n.walkTokens;s.walkTokens=function(a){let l=[];return l.push(o.call(this,a)),i&&(l=l.concat(i.call(this,a))),l}}this.defaults={...this.defaults,...s}}),this}setOptions(e){return this.defaults={...this.defaults,...e},this}lexer(e,t){return se.lex(e,t??this.defaults)}parser(e,t){return ie.parse(e,t??this.defaults)}parseMarkdown(e){return(t,n)=>{let s={...n},i={...this.defaults,...s},o=this.onError(!!i.silent,!!i.async);if(this.defaults.async===!0&&s.async===!1)return o(new Error("marked(): The async option was set to true by an extension. Remove async: false from the parse options object to return a Promise."));if(typeof t>"u"||t===null)return o(new Error("marked(): input parameter is undefined or null"));if(typeof t!="string")return o(new Error("marked(): input parameter is of type "+Object.prototype.toString.call(t)+", string expected"));if(i.hooks&&(i.hooks.options=i,i.hooks.block=e),i.async)return(async()=>{let a=i.hooks?await i.hooks.preprocess(t):t,l=await(i.hooks?await i.hooks.provideLexer():e?se.lex:se.lexInline)(a,i),r=i.hooks?await i.hooks.processAllTokens(l):l;i.walkTokens&&await Promise.all(this.walkTokens(r,i.walkTokens));let p=await(i.hooks?await i.hooks.provideParser():e?ie.parse:ie.parseInline)(r,i);return i.hooks?await i.hooks.postprocess(p):p})().catch(o);try{i.hooks&&(t=i.hooks.preprocess(t));let a=(i.hooks?i.hooks.provideLexer():e?se.lex:se.lexInline)(t,i);i.hooks&&(a=i.hooks.processAllTokens(a)),i.walkTokens&&this.walkTokens(a,i.walkTokens);let l=(i.hooks?i.hooks.provideParser():e?ie.parse:ie.parseInline)(a,i);return i.hooks&&(l=i.hooks.postprocess(l)),l}catch(a){return o(a)}}}onError(e,t){return n=>{if(n.message+=`
75
- Please report this to https://github.com/markedjs/marked.`,e){let s="<p>An error occurred:</p><pre>"+ve(n.message+"",!0)+"</pre>";return t?Promise.resolve(s):s}if(t)return Promise.reject(n);throw n}}},Fe=new Lu;function N(e,t){return Fe.parse(e,t)}N.options=N.setOptions=function(e){return Fe.setOptions(e),N.defaults=Fe.defaults,Qa(N.defaults),N};N.getDefaults=ei;N.defaults=Ue;N.use=function(...e){return Fe.use(...e),N.defaults=Fe.defaults,Qa(N.defaults),N};N.walkTokens=function(e,t){return Fe.walkTokens(e,t)};N.parseInline=Fe.parseInline;N.Parser=ie;N.parser=ie.parse;N.Renderer=tn;N.TextRenderer=li;N.Lexer=se;N.lexer=se.lex;N.Tokenizer=en;N.Hooks=gt;N.parse=N;N.options;N.setOptions;N.use;N.walkTokens;N.parseInline;ie.parse;se.lex;N.setOptions({gfm:!0,breaks:!0,mangle:!1});const xo=["a","b","blockquote","br","code","del","em","h1","h2","h3","h4","hr","i","li","ol","p","pre","strong","table","tbody","td","th","thead","tr","ul"],Ao=["class","href","rel","target","title","start"];let So=!1;const Mu=14e4,Pu=4e4,Nu=200,Zn=5e4,Pe=new Map;function Ou(e){const t=Pe.get(e);return t===void 0?null:(Pe.delete(e),Pe.set(e,t),t)}function _o(e,t){if(Pe.set(e,t),Pe.size<=Nu)return;const n=Pe.keys().next().value;n&&Pe.delete(n)}function Du(){So||(So=!0,ws.addHook("afterSanitizeAttributes",e=>{!(e instanceof HTMLAnchorElement)||!e.getAttribute("href")||(e.setAttribute("rel","noreferrer noopener"),e.setAttribute("target","_blank"))}))}function As(e){const t=e.trim();if(!t)return"";if(Du(),t.length<=Zn){const a=Ou(t);if(a!==null)return a}const n=ra(t,Mu),s=n.truncated?`
76
-
77
- … truncated (${n.total} chars, showing first ${n.text.length}).`:"";if(n.text.length>Pu){const l=`<pre class="code-block">${Bu(`${n.text}${s}`)}</pre>`,r=ws.sanitize(l,{ALLOWED_TAGS:xo,ALLOWED_ATTR:Ao});return t.length<=Zn&&_o(t,r),r}const i=N.parse(`${n.text}${s}`),o=ws.sanitize(i,{ALLOWED_TAGS:xo,ALLOWED_ATTR:Ao});return t.length<=Zn&&_o(t,o),o}function Bu(e){return e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;").replace(/'/g,"&#39;")}function Fu(e,t){return c`<span class=${t} aria-hidden="true">${e}</span>`}function zt(e,t){e&&(e.textContent=t)}const Uu=1500,Ku=2e3,rr="Copy as markdown",Hu="Copied",zu="Copy failed",Xn="📋",ju="✓",qu="!";async function Wu(e){if(!e)return!1;try{return await navigator.clipboard.writeText(e),!0}catch{return!1}}function jt(e,t){e.title=t,e.setAttribute("aria-label",t)}function Gu(e){const t=e.label??rr;return c`
78
- <button
79
- class="chat-copy-btn"
80
- type="button"
81
- title=${t}
82
- aria-label=${t}
83
- @click=${async n=>{const s=n.currentTarget,i=s?.querySelector(".chat-copy-btn__icon");if(!s||s.dataset.copying==="1")return;s.dataset.copying="1",s.setAttribute("aria-busy","true"),s.disabled=!0;const o=await Wu(e.text());if(s.isConnected){if(delete s.dataset.copying,s.removeAttribute("aria-busy"),s.disabled=!1,!o){s.dataset.error="1",jt(s,zu),zt(i,qu),window.setTimeout(()=>{s.isConnected&&(delete s.dataset.error,jt(s,t),zt(i,Xn))},Ku);return}s.dataset.copied="1",jt(s,Hu),zt(i,ju),window.setTimeout(()=>{s.isConnected&&(delete s.dataset.copied,jt(s,t),zt(i,Xn))},Uu)}}}
84
- >
85
- ${Fu(Xn,"chat-copy-btn__icon")}
86
- </button>
87
- `}function Vu(e){return Gu({text:()=>e,label:rr})}const Yu={emoji:"🧩",detailKeys:["command","path","url","targetUrl","targetId","ref","element","node","nodeId","id","requestId","to","channelId","guildId","userId","name","query","pattern","messageId"]},Qu={bash:{emoji:"🛠️",title:"Bash",detailKeys:["command"]},process:{emoji:"🧰",title:"Process",detailKeys:["sessionId"]},read:{emoji:"📖",title:"Read",detailKeys:["path"]},write:{emoji:"✍️",title:"Write",detailKeys:["path"]},edit:{emoji:"📝",title:"Edit",detailKeys:["path"]},attach:{emoji:"📎",title:"Attach",detailKeys:["path","url","fileName"]},browser:{emoji:"🌐",title:"Browser",actions:{status:{label:"status"},start:{label:"start"},stop:{label:"stop"},tabs:{label:"tabs"},open:{label:"open",detailKeys:["targetUrl"]},focus:{label:"focus",detailKeys:["targetId"]},close:{label:"close",detailKeys:["targetId"]},snapshot:{label:"snapshot",detailKeys:["targetUrl","targetId","ref","element","format"]},screenshot:{label:"screenshot",detailKeys:["targetUrl","targetId","ref","element"]},navigate:{label:"navigate",detailKeys:["targetUrl","targetId"]},console:{label:"console",detailKeys:["level","targetId"]},pdf:{label:"pdf",detailKeys:["targetId"]},upload:{label:"upload",detailKeys:["paths","ref","inputRef","element","targetId"]},dialog:{label:"dialog",detailKeys:["accept","promptText","targetId"]},act:{label:"act",detailKeys:["request.kind","request.ref","request.selector","request.text","request.value"]}}},canvas:{emoji:"🖼️",title:"Canvas",actions:{present:{label:"present",detailKeys:["target","node","nodeId"]},hide:{label:"hide",detailKeys:["node","nodeId"]},navigate:{label:"navigate",detailKeys:["url","node","nodeId"]},eval:{label:"eval",detailKeys:["javaScript","node","nodeId"]},snapshot:{label:"snapshot",detailKeys:["format","node","nodeId"]},a2ui_push:{label:"A2UI push",detailKeys:["jsonlPath","node","nodeId"]},a2ui_reset:{label:"A2UI reset",detailKeys:["node","nodeId"]}}},nodes:{emoji:"📱",title:"Nodes",actions:{status:{label:"status"},describe:{label:"describe",detailKeys:["node","nodeId"]},pending:{label:"pending"},approve:{label:"approve",detailKeys:["requestId"]},reject:{label:"reject",detailKeys:["requestId"]},notify:{label:"notify",detailKeys:["node","nodeId","title","body"]},camera_snap:{label:"camera snap",detailKeys:["node","nodeId","facing","deviceId"]},camera_list:{label:"camera list",detailKeys:["node","nodeId"]},camera_clip:{label:"camera clip",detailKeys:["node","nodeId","facing","duration","durationMs"]},screen_record:{label:"screen record",detailKeys:["node","nodeId","duration","durationMs","fps","screenIndex"]}}},cron:{emoji:"⏰",title:"Cron",actions:{status:{label:"status"},list:{label:"list"},add:{label:"add",detailKeys:["job.name","job.id","job.schedule","job.cron"]},update:{label:"update",detailKeys:["id"]},remove:{label:"remove",detailKeys:["id"]},run:{label:"run",detailKeys:["id"]},runs:{label:"runs",detailKeys:["id"]},wake:{label:"wake",detailKeys:["text","mode"]}}},gateway:{emoji:"🔌",title:"Gateway",actions:{restart:{label:"restart",detailKeys:["reason","delayMs"]},"config.get":{label:"config get"},"config.schema":{label:"config schema"},"config.apply":{label:"config apply",detailKeys:["restartDelayMs"]},"update.run":{label:"update run",detailKeys:["restartDelayMs"]}}},whatsapp_login:{emoji:"🟢",title:"WhatsApp Login",actions:{start:{label:"start"},wait:{label:"wait"}}},discord:{emoji:"💬",title:"Discord",actions:{react:{label:"react",detailKeys:["channelId","messageId","emoji"]},reactions:{label:"reactions",detailKeys:["channelId","messageId"]},sticker:{label:"sticker",detailKeys:["to","stickerIds"]},poll:{label:"poll",detailKeys:["question","to"]},permissions:{label:"permissions",detailKeys:["channelId"]},readMessages:{label:"read messages",detailKeys:["channelId","limit"]},sendMessage:{label:"send",detailKeys:["to","content"]},editMessage:{label:"edit",detailKeys:["channelId","messageId"]},deleteMessage:{label:"delete",detailKeys:["channelId","messageId"]},threadCreate:{label:"thread create",detailKeys:["channelId","name"]},threadList:{label:"thread list",detailKeys:["guildId","channelId"]},threadReply:{label:"thread reply",detailKeys:["channelId","content"]},pinMessage:{label:"pin",detailKeys:["channelId","messageId"]},unpinMessage:{label:"unpin",detailKeys:["channelId","messageId"]},listPins:{label:"list pins",detailKeys:["channelId"]},searchMessages:{label:"search",detailKeys:["guildId","content"]},memberInfo:{label:"member",detailKeys:["guildId","userId"]},roleInfo:{label:"roles",detailKeys:["guildId"]},emojiList:{label:"emoji list",detailKeys:["guildId"]},roleAdd:{label:"role add",detailKeys:["guildId","userId","roleId"]},roleRemove:{label:"role remove",detailKeys:["guildId","userId","roleId"]},channelInfo:{label:"channel",detailKeys:["channelId"]},channelList:{label:"channels",detailKeys:["guildId"]},voiceStatus:{label:"voice",detailKeys:["guildId","userId"]},eventList:{label:"events",detailKeys:["guildId"]},eventCreate:{label:"event create",detailKeys:["guildId","name"]},timeout:{label:"timeout",detailKeys:["guildId","userId"]},kick:{label:"kick",detailKeys:["guildId","userId"]},ban:{label:"ban",detailKeys:["guildId","userId"]}}},slack:{emoji:"💬",title:"Slack",actions:{react:{label:"react",detailKeys:["channelId","messageId","emoji"]},reactions:{label:"reactions",detailKeys:["channelId","messageId"]},sendMessage:{label:"send",detailKeys:["to","content"]},editMessage:{label:"edit",detailKeys:["channelId","messageId"]},deleteMessage:{label:"delete",detailKeys:["channelId","messageId"]},readMessages:{label:"read messages",detailKeys:["channelId","limit"]},pinMessage:{label:"pin",detailKeys:["channelId","messageId"]},unpinMessage:{label:"unpin",detailKeys:["channelId","messageId"]},listPins:{label:"list pins",detailKeys:["channelId"]},memberInfo:{label:"member",detailKeys:["userId"]},emojiList:{label:"emoji list"}}}},Ju={fallback:Yu,tools:Qu},lr=Ju,To=lr.fallback??{emoji:"🧩"},Zu=lr.tools??{};function Xu(e){return(e??"tool").trim()}function ep(e){const t=e.replace(/_/g," ").trim();return t?t.split(/\s+/).map(n=>n.length<=2&&n.toUpperCase()===n?n:`${n.at(0)?.toUpperCase()??""}${n.slice(1)}`).join(" "):"Tool"}function tp(e){const t=e?.trim();if(t)return t.replace(/_/g," ")}function cr(e){if(e!=null){if(typeof e=="string"){const t=e.trim();if(!t)return;const n=t.split(/\r?\n/)[0]?.trim()??"";return n?n.length>160?`${n.slice(0,157)}…`:n:void 0}if(typeof e=="number"||typeof e=="boolean")return String(e);if(Array.isArray(e)){const t=e.map(s=>cr(s)).filter(s=>!!s);if(t.length===0)return;const n=t.slice(0,3).join(", ");return t.length>3?`${n}…`:n}}}function np(e,t){if(!e||typeof e!="object")return;let n=e;for(const s of t.split(".")){if(!s||!n||typeof n!="object")return;n=n[s]}return n}function sp(e,t){for(const n of t){const s=np(e,n),i=cr(s);if(i)return i}}function ip(e){if(!e||typeof e!="object")return;const t=e,n=typeof t.path=="string"?t.path:void 0;if(!n)return;const s=typeof t.offset=="number"?t.offset:void 0,i=typeof t.limit=="number"?t.limit:void 0;return s!==void 0&&i!==void 0?`${n}:${s}-${s+i}`:n}function op(e){if(!e||typeof e!="object")return;const t=e;return typeof t.path=="string"?t.path:void 0}function ap(e,t){if(!(!e||!t))return e.actions?.[t]??void 0}function rp(e){const t=Xu(e.name),n=t.toLowerCase(),s=Zu[n],i=s?.emoji??To.emoji??"🧩",o=s?.title??ep(t),a=s?.label??t,l=e.args&&typeof e.args=="object"?e.args.action:void 0,r=typeof l=="string"?l.trim():void 0,p=ap(s,r),d=tp(p?.label??r);let u;n==="read"&&(u=ip(e.args)),!u&&(n==="write"||n==="edit"||n==="attach")&&(u=op(e.args));const h=p?.detailKeys??s?.detailKeys??To.detailKeys??[];return!u&&h.length>0&&(u=sp(e.args,h)),!u&&e.meta&&(u=e.meta),u&&(u=cp(u)),{name:t,emoji:i,title:o,label:a,verb:d,detail:u}}function lp(e){const t=[];if(e.verb&&t.push(e.verb),e.detail&&t.push(e.detail),t.length!==0)return t.join(" · ")}function cp(e){return e&&e.replace(/\/Users\/[^/]+/g,"~").replace(/\/home\/[^/]+/g,"~")}const dp=80,up=2,Co=100;function pp(e){const t=e.trim();if(t.startsWith("{")||t.startsWith("["))try{const n=JSON.parse(t);return"```json\n"+JSON.stringify(n,null,2)+"\n```"}catch{}return e}function fp(e){const t=e.split(`
88
- `),n=t.slice(0,up),s=n.join(`
89
- `);return s.length>Co?s.slice(0,Co)+"…":n.length<t.length?s+"…":s}function hp(e){const t=e,n=gp(t.content),s=[];for(const i of n){const o=String(i.type??"").toLowerCase();(["toolcall","tool_call","tooluse","tool_use"].includes(o)||typeof i.name=="string"&&i.arguments!=null)&&s.push({kind:"call",name:i.name??"tool",args:vp(i.arguments??i.args)})}for(const i of n){const o=String(i.type??"").toLowerCase();if(o!=="toolresult"&&o!=="tool_result")continue;const a=mp(i),l=typeof i.name=="string"?i.name:"tool";s.push({kind:"result",name:l,text:a})}if(qa(e)&&!s.some(i=>i.kind==="result")){const i=typeof t.toolName=="string"&&t.toolName||typeof t.tool_name=="string"&&t.tool_name||"tool",o=la(e)??void 0;s.push({kind:"result",name:i,text:o})}return s}function Eo(e,t){const n=rp({name:e.name,args:e.args}),s=lp(n),i=!!e.text?.trim(),o=!!t,a=o?()=>{if(i){t(pp(e.text));return}const u=`## ${n.label}
90
-
91
- ${s?`**Command:** \`${s}\`
92
-
93
- `:""}*No output — tool completed successfully.*`;t(u)}:void 0,l=i&&(e.text?.length??0)<=dp,r=i&&!l,p=i&&l,d=!i;return c`
94
- <div
95
- class="chat-tool-card ${o?"chat-tool-card--clickable":""}"
96
- @click=${a}
97
- role=${o?"button":g}
98
- tabindex=${o?"0":g}
99
- @keydown=${o?u=>{u.key!=="Enter"&&u.key!==" "||(u.preventDefault(),a?.())}:g}
100
- >
101
- <div class="chat-tool-card__header">
102
- <div class="chat-tool-card__title">
103
- <span class="chat-tool-card__icon">${n.emoji}</span>
104
- <span>${n.label}</span>
105
- </div>
106
- ${o?c`<span class="chat-tool-card__action">${i?"View ›":"›"}</span>`:g}
107
- ${d&&!o?c`<span class="chat-tool-card__status">✓</span>`:g}
108
- </div>
109
- ${s?c`<div class="chat-tool-card__detail">${s}</div>`:g}
110
- ${d?c`<div class="chat-tool-card__status-text muted">Completed</div>`:g}
111
- ${r?c`<div class="chat-tool-card__preview mono">${fp(e.text)}</div>`:g}
112
- ${p?c`<div class="chat-tool-card__inline mono">${e.text}</div>`:g}
113
- </div>
114
- `}function gp(e){return Array.isArray(e)?e.filter(Boolean):[]}function vp(e){if(typeof e!="string")return e;const t=e.trim();if(!t||!t.startsWith("{")&&!t.startsWith("["))return e;try{return JSON.parse(t)}catch{return e}}function mp(e){if(typeof e.text=="string")return e.text;if(typeof e.content=="string")return e.content}function bp(e){return c`
115
- <div class="chat-group assistant">
116
- ${ci("assistant",e)}
117
- <div class="chat-group-messages">
118
- <div class="chat-bubble chat-reading-indicator" aria-hidden="true">
119
- <span class="chat-reading-indicator__dots">
120
- <span></span><span></span><span></span>
121
- </span>
122
- </div>
123
- </div>
124
- </div>
125
- `}function yp(e,t,n,s){const i=new Date(t).toLocaleTimeString([],{hour:"numeric",minute:"2-digit"}),o=s?.name??"Assistant";return c`
126
- <div class="chat-group assistant">
127
- ${ci("assistant",s)}
128
- <div class="chat-group-messages">
129
- ${dr({role:"assistant",content:[{type:"text",text:e}],timestamp:t},{isStreaming:!0,showReasoning:!1},n)}
130
- <div class="chat-group-footer">
131
- <span class="chat-sender-name">${o}</span>
132
- <span class="chat-group-timestamp">${i}</span>
133
- </div>
134
- </div>
135
- </div>
136
- `}function wp(e,t){const n=Xs(e.role),s=t.assistantName??"Assistant",i=n==="user"?"You":n==="assistant"?s:n,o=n==="user"?"user":n==="assistant"?"assistant":"other",a=new Date(e.timestamp).toLocaleTimeString([],{hour:"numeric",minute:"2-digit"});return c`
137
- <div class="chat-group ${o}">
138
- ${ci(e.role,{name:s,avatar:t.assistantAvatar??null})}
139
- <div class="chat-group-messages">
140
- ${e.messages.map((l,r)=>dr(l.message,{isStreaming:e.isStreaming&&r===e.messages.length-1,showReasoning:t.showReasoning},t.onOpenSidebar))}
141
- <div class="chat-group-footer">
142
- <span class="chat-sender-name">${i}</span>
143
- <span class="chat-group-timestamp">${a}</span>
144
- </div>
145
- </div>
146
- </div>
147
- `}function ci(e,t){const n=Xs(e),s=t?.name?.trim()||"Assistant",i=t?.avatar?.trim()||"",o=n==="user"?"U":n==="assistant"?s.charAt(0).toUpperCase()||"A":n==="tool"?"⚙":"?",a=n==="user"?"user":n==="assistant"?"assistant":n==="tool"?"tool":"other";return i&&n==="assistant"?$p(i)?c`<img
148
- class="chat-avatar ${a}"
149
- src="${i}"
150
- alt="${s}"
151
- />`:c`<div class="chat-avatar ${a}">${i}</div>`:c`<div class="chat-avatar ${a}">${o}</div>`}function $p(e){return/^https?:\/\//i.test(e)||/^data:image\//i.test(e)||/^\//.test(e)}function dr(e,t,n){const s=e,i=typeof s.role=="string"?s.role:"unknown",o=qa(e)||i.toLowerCase()==="toolresult"||i.toLowerCase()==="tool_result"||typeof s.toolCallId=="string"||typeof s.tool_call_id=="string",a=hp(e),l=a.length>0,r=la(e),p=t.showReasoning&&i==="assistant"?Sl(e):null,d=r?.trim()?r:null,u=p?Tl(p):null,h=d,v=i==="assistant"&&!!h?.trim(),w=["chat-bubble",v?"has-copy":"",t.isStreaming?"streaming":"","fade-in"].filter(Boolean).join(" ");return!h&&l&&o?c`${a.map($=>Eo($,n))}`:!h&&!l?g:c`
152
- <div class="${w}">
153
- ${v?Vu(h):g}
154
- ${u?c`<div class="chat-thinking">${vs(As(u))}</div>`:g}
155
- ${h?c`<div class="chat-text">${vs(As(h))}</div>`:g}
156
- ${a.map($=>Eo($,n))}
157
- </div>
158
- `}function kp(e){return c`
159
- <div class="sidebar-panel">
160
- <div class="sidebar-header">
161
- <div class="sidebar-title">Tool Output</div>
162
- <button @click=${e.onClose} class="btn" title="Close sidebar">
163
-
164
- </button>
165
- </div>
166
- <div class="sidebar-content">
167
- ${e.error?c`
168
- <div class="callout danger">${e.error}</div>
169
- <button @click=${e.onViewRawText} class="btn" style="margin-top: 12px;">
170
- View Raw Text
171
- </button>
172
- `:e.content?c`<div class="sidebar-markdown">${vs(As(e.content))}</div>`:c`<div class="muted">No content available</div>`}
173
- </div>
174
- </div>
175
- `}var xp=Object.defineProperty,Ap=Object.getOwnPropertyDescriptor,mn=(e,t,n,s)=>{for(var i=s>1?void 0:s?Ap(t,n):t,o=e.length-1,a;o>=0;o--)(a=e[o])&&(i=(s?a(t,n,i):a(i))||i);return s&&i&&xp(t,n,i),i};let tt=class extends Qe{constructor(){super(...arguments),this.splitRatio=.6,this.minRatio=.4,this.maxRatio=.7,this.isDragging=!1,this.startX=0,this.startRatio=0,this.handleMouseDown=e=>{this.isDragging=!0,this.startX=e.clientX,this.startRatio=this.splitRatio,this.classList.add("dragging"),document.addEventListener("mousemove",this.handleMouseMove),document.addEventListener("mouseup",this.handleMouseUp),e.preventDefault()},this.handleMouseMove=e=>{if(!this.isDragging)return;const t=this.parentElement;if(!t)return;const n=t.getBoundingClientRect().width,i=(e.clientX-this.startX)/n;let o=this.startRatio+i;o=Math.max(this.minRatio,Math.min(this.maxRatio,o)),this.dispatchEvent(new CustomEvent("resize",{detail:{splitRatio:o},bubbles:!0,composed:!0}))},this.handleMouseUp=()=>{this.isDragging=!1,this.classList.remove("dragging"),document.removeEventListener("mousemove",this.handleMouseMove),document.removeEventListener("mouseup",this.handleMouseUp)}}render(){return c``}connectedCallback(){super.connectedCallback(),this.addEventListener("mousedown",this.handleMouseDown)}disconnectedCallback(){super.disconnectedCallback(),this.removeEventListener("mousedown",this.handleMouseDown),document.removeEventListener("mousemove",this.handleMouseMove),document.removeEventListener("mouseup",this.handleMouseUp)}};tt.styles=Br`
176
- :host {
177
- width: 4px;
178
- cursor: col-resize;
179
- background: var(--border, #333);
180
- transition: background 150ms ease-out;
181
- flex-shrink: 0;
182
- position: relative;
183
- }
184
-
185
- :host::before {
186
- content: "";
187
- position: absolute;
188
- top: 0;
189
- left: -4px;
190
- right: -4px;
191
- bottom: 0;
192
- }
193
-
194
- :host(:hover) {
195
- background: var(--accent, #007bff);
196
- }
197
-
198
- :host(.dragging) {
199
- background: var(--accent, #007bff);
200
- }
201
- `;mn([an({type:Number})],tt.prototype,"splitRatio",2);mn([an({type:Number})],tt.prototype,"minRatio",2);mn([an({type:Number})],tt.prototype,"maxRatio",2);tt=mn([ea("resizable-divider")],tt);const Sp=5e3;function _p(e){return e?e.active?c`
202
- <div class="callout info compaction-indicator compaction-indicator--active">
203
- 🧹 Compacting context...
204
- </div>
205
- `:e.completedAt&&Date.now()-e.completedAt<Sp?c`
206
- <div class="callout success compaction-indicator compaction-indicator--complete">
207
- 🧹 Context compacted
208
- </div>
209
- `:g:g}function Tp(e){const t=e.connected,n=e.sending||e.stream!==null,s=!!(e.canAbort&&e.onAbort),o=e.sessions?.sessions?.find(h=>h.key===e.sessionKey)?.reasoningLevel??"off",a=e.showThinking&&o!=="off",l={name:e.assistantName,avatar:e.assistantAvatar??e.assistantAvatarUrl??null},r=e.connected?"Message (↩ to send, Shift+↩ for line breaks)":"Connect to the gateway to start chatting…",p=e.splitRatio??.6,d=!!(e.sidebarOpen&&e.onCloseSidebar),u=c`
210
- <div
211
- class="chat-thread"
212
- role="log"
213
- aria-live="polite"
214
- @scroll=${e.onChatScroll}
215
- >
216
- ${e.loading?c`<div class="muted">Loading chat…</div>`:g}
217
- ${za(Ep(e),h=>h.key,h=>h.kind==="reading-indicator"?bp(l):h.kind==="stream"?yp(h.text,h.startedAt,e.onOpenSidebar,l):h.kind==="group"?wp(h,{onOpenSidebar:e.onOpenSidebar,showReasoning:a,assistantName:e.assistantName,assistantAvatar:l.avatar}):g)}
218
- </div>
219
- `;return c`
220
- <section class="card chat">
221
- ${e.disabledReason?c`<div class="callout">${e.disabledReason}</div>`:g}
222
-
223
- ${e.error?c`<div class="callout danger">${e.error}</div>`:g}
224
-
225
- ${_p(e.compactionStatus)}
226
-
227
- ${e.focusMode?c`
228
- <button
229
- class="chat-focus-exit"
230
- type="button"
231
- @click=${e.onToggleFocusMode}
232
- aria-label="Exit focus mode"
233
- title="Exit focus mode"
234
- >
235
-
236
- </button>
237
- `:g}
238
-
239
- <div
240
- class="chat-split-container ${d?"chat-split-container--open":""}"
241
- >
242
- <div
243
- class="chat-main"
244
- style="flex: ${d?`0 0 ${p*100}%`:"1 1 100%"}"
245
- >
246
- ${u}
247
- </div>
248
-
249
- ${d?c`
250
- <resizable-divider
251
- .splitRatio=${p}
252
- @resize=${h=>e.onSplitRatioChange?.(h.detail.splitRatio)}
253
- ></resizable-divider>
254
- <div class="chat-sidebar">
255
- ${kp({content:e.sidebarContent??null,error:e.sidebarError??null,onClose:e.onCloseSidebar,onViewRawText:()=>{!e.sidebarContent||!e.onOpenSidebar||e.onOpenSidebar(`\`\`\`
256
- ${e.sidebarContent}
257
- \`\`\``)}})}
258
- </div>
259
- `:g}
260
- </div>
261
-
262
- ${e.queue.length?c`
263
- <div class="chat-queue" role="status" aria-live="polite">
264
- <div class="chat-queue__title">Queued (${e.queue.length})</div>
265
- <div class="chat-queue__list">
266
- ${e.queue.map(h=>c`
267
- <div class="chat-queue__item">
268
- <div class="chat-queue__text">${h.text}</div>
269
- <button
270
- class="btn chat-queue__remove"
271
- type="button"
272
- aria-label="Remove queued message"
273
- @click=${()=>e.onQueueRemove(h.id)}
274
- >
275
-
276
- </button>
277
- </div>
278
- `)}
279
- </div>
280
- </div>
281
- `:g}
282
-
283
- <div class="chat-compose">
284
- <label class="field chat-compose__field">
285
- <span>Message</span>
286
- <textarea
287
- .value=${e.draft}
288
- ?disabled=${!e.connected}
289
- @keydown=${h=>{h.key==="Enter"&&(h.isComposing||h.keyCode===229||h.shiftKey||e.connected&&(h.preventDefault(),t&&e.onSend()))}}
290
- @input=${h=>e.onDraftChange(h.target.value)}
291
- placeholder=${r}
292
- ></textarea>
293
- </label>
294
- <div class="chat-compose__actions">
295
- <button
296
- class="btn"
297
- ?disabled=${!e.connected||!s&&e.sending}
298
- @click=${s?e.onAbort:e.onNewSession}
299
- >
300
- ${s?"Stop":"New session"}
301
- </button>
302
- <button
303
- class="btn primary"
304
- ?disabled=${!e.connected}
305
- @click=${e.onSend}
306
- >
307
- ${n?"Queue":"Send"}
308
- </button>
309
- </div>
310
- </div>
311
- </section>
312
- `}const Io=200;function Cp(e){const t=[];let n=null;for(const s of e){if(s.kind!=="message"){n&&(t.push(n),n=null),t.push(s);continue}const i=ja(s.message),o=Xs(i.role),a=i.timestamp||Date.now();!n||n.role!==o?(n&&t.push(n),n={kind:"group",key:`group:${o}:${s.key}`,role:o,messages:[{message:s.message,key:s.key}],timestamp:a,isStreaming:!1}):n.messages.push({message:s.message,key:s.key})}return n&&t.push(n),t}function Ep(e){const t=[],n=Array.isArray(e.messages)?e.messages:[],s=Array.isArray(e.toolMessages)?e.toolMessages:[],i=Math.max(0,n.length-Io);i>0&&t.push({kind:"message",key:"chat:history:notice",message:{role:"system",content:`Showing last ${Io} messages (${i} hidden).`,timestamp:Date.now()}});for(let o=i;o<n.length;o++){const a=n[o],l=ja(a);!e.showThinking&&l.role.toLowerCase()==="toolresult"||t.push({kind:"message",key:Ro(a,o),message:a})}if(e.showThinking)for(let o=0;o<s.length;o++)t.push({kind:"message",key:Ro(s[o],o+n.length),message:s[o]});if(e.stream!==null){const o=`stream:${e.sessionKey}:${e.streamStartedAt??"live"}`;e.stream.trim().length>0?t.push({kind:"stream",key:o,text:e.stream,startedAt:e.streamStartedAt??Date.now()}):t.push({kind:"reading-indicator",key:o})}return Cp(t)}function Ro(e,t){const n=e,s=typeof n.toolCallId=="string"?n.toolCallId:"";if(s)return`tool:${s}`;const i=typeof n.id=="string"?n.id:"";if(i)return`msg:${i}`;const o=typeof n.messageId=="string"?n.messageId:"";if(o)return`msg:${o}`;const a=typeof n.timestamp=="number"?n.timestamp:null,l=typeof n.role=="string"?n.role:"unknown";return a!=null?`msg:${l}:${a}:${t}`:`msg:${l}:${t}`}function de(e){if(e)return Array.isArray(e.type)?e.type.filter(n=>n!=="null")[0]??e.type[0]:e.type}function ur(e){if(!e)return"";if(e.default!==void 0)return e.default;switch(de(e)){case"object":return{};case"array":return[];case"boolean":return!1;case"number":case"integer":return 0;case"string":return"";default:return""}}function bn(e){return e.filter(t=>typeof t=="string").join(".")}function ee(e,t){const n=bn(e),s=t[n];if(s)return s;const i=n.split(".");for(const[o,a]of Object.entries(t)){if(!o.includes("*"))continue;const l=o.split(".");if(l.length!==i.length)continue;let r=!0;for(let p=0;p<i.length;p+=1)if(l[p]!=="*"&&l[p]!==i[p]){r=!1;break}if(r)return a}}function ye(e){return e.replace(/_/g," ").replace(/([a-z0-9])([A-Z])/g,"$1 $2").replace(/\s+/g," ").replace(/^./,t=>t.toUpperCase())}function Ip(e){const t=bn(e).toLowerCase();return t.includes("token")||t.includes("password")||t.includes("secret")||t.includes("apikey")||t.endsWith("key")}const Rp=new Set(["title","description","default","nullable"]);function Lp(e){return Object.keys(e??{}).filter(n=>!Rp.has(n)).length===0}function Mp(e){if(e===void 0)return"";try{return JSON.stringify(e,null,2)??""}catch{return""}}const St={chevronDown:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><polyline points="6 9 12 15 18 9"></polyline></svg>`,plus:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><line x1="12" y1="5" x2="12" y2="19"></line><line x1="5" y1="12" x2="19" y2="12"></line></svg>`,minus:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><line x1="5" y1="12" x2="19" y2="12"></line></svg>`,trash:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><polyline points="3 6 5 6 21 6"></polyline><path d="M19 6v14a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2V6m3 0V4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v2"></path></svg>`,edit:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M11 4H4a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2v-7"></path><path d="M18.5 2.5a2.121 2.121 0 0 1 3 3L12 15l-4 1 1-4 9.5-9.5z"></path></svg>`};function be(e){const{schema:t,value:n,path:s,hints:i,unsupported:o,disabled:a,onPatch:l}=e,r=e.showLabel??!0,p=de(t),d=ee(s,i),u=d?.label??t.title??ye(String(s.at(-1))),h=d?.help??t.description,v=bn(s);if(o.has(v))return c`<div class="cfg-field cfg-field--error">
313
- <div class="cfg-field__label">${u}</div>
314
- <div class="cfg-field__error">Unsupported schema node. Use Raw mode.</div>
315
- </div>`;if(t.anyOf||t.oneOf){const $=(t.anyOf??t.oneOf??[]).filter(C=>!(C.type==="null"||Array.isArray(C.type)&&C.type.includes("null")));if($.length===1)return be({...e,schema:$[0]});const x=C=>{if(C.const!==void 0)return C.const;if(C.enum&&C.enum.length===1)return C.enum[0]},T=$.map(x),R=T.every(C=>C!==void 0);if(R&&T.length>0&&T.length<=5){const C=n??t.default;return c`
316
- <div class="cfg-field">
317
- ${r?c`<label class="cfg-field__label">${u}</label>`:g}
318
- ${h?c`<div class="cfg-field__help">${h}</div>`:g}
319
- <div class="cfg-segmented">
320
- ${T.map((E,ue)=>c`
321
- <button
322
- type="button"
323
- class="cfg-segmented__btn ${E===C||String(E)===String(C)?"active":""}"
324
- ?disabled=${a}
325
- @click=${()=>l(s,E)}
326
- >
327
- ${String(E)}
328
- </button>
329
- `)}
330
- </div>
331
- </div>
332
- `}if(R&&T.length>5)return Mo({...e,options:T,value:n??t.default});const P=new Set($.map(C=>de(C)).filter(Boolean)),I=new Set([...P].map(C=>C==="integer"?"number":C));if([...I].every(C=>["string","number","boolean"].includes(C))){const C=I.has("string"),E=I.has("number");if(I.has("boolean")&&I.size===1)return be({...e,schema:{...t,type:"boolean",anyOf:void 0,oneOf:void 0}});if(C||E)return Lo({...e,inputType:E&&!C?"number":"text"})}}if(t.enum){const w=t.enum;if(w.length<=5){const $=n??t.default;return c`
333
- <div class="cfg-field">
334
- ${r?c`<label class="cfg-field__label">${u}</label>`:g}
335
- ${h?c`<div class="cfg-field__help">${h}</div>`:g}
336
- <div class="cfg-segmented">
337
- ${w.map(x=>c`
338
- <button
339
- type="button"
340
- class="cfg-segmented__btn ${x===$||String(x)===String($)?"active":""}"
341
- ?disabled=${a}
342
- @click=${()=>l(s,x)}
343
- >
344
- ${String(x)}
345
- </button>
346
- `)}
347
- </div>
348
- </div>
349
- `}return Mo({...e,options:w,value:n??t.default})}if(p==="object")return Np(e);if(p==="array")return Op(e);if(p==="boolean"){const w=typeof n=="boolean"?n:typeof t.default=="boolean"?t.default:!1;return c`
350
- <label class="cfg-toggle-row ${a?"disabled":""}">
351
- <div class="cfg-toggle-row__content">
352
- <span class="cfg-toggle-row__label">${u}</span>
353
- ${h?c`<span class="cfg-toggle-row__help">${h}</span>`:g}
354
- </div>
355
- <div class="cfg-toggle">
356
- <input
357
- type="checkbox"
358
- .checked=${w}
359
- ?disabled=${a}
360
- @change=${$=>l(s,$.target.checked)}
361
- />
362
- <span class="cfg-toggle__track"></span>
363
- </div>
364
- </label>
365
- `}return p==="number"||p==="integer"?Pp(e):p==="string"?Lo({...e,inputType:"text"}):c`
366
- <div class="cfg-field cfg-field--error">
367
- <div class="cfg-field__label">${u}</div>
368
- <div class="cfg-field__error">Unsupported type: ${p}. Use Raw mode.</div>
369
- </div>
370
- `}function Lo(e){const{schema:t,value:n,path:s,hints:i,disabled:o,onPatch:a,inputType:l}=e,r=e.showLabel??!0,p=ee(s,i),d=p?.label??t.title??ye(String(s.at(-1))),u=p?.help??t.description,h=p?.sensitive??Ip(s),v=p?.placeholder??(h?"••••":t.default!==void 0?`Default: ${t.default}`:""),w=n??"";return c`
371
- <div class="cfg-field">
372
- ${r?c`<label class="cfg-field__label">${d}</label>`:g}
373
- ${u?c`<div class="cfg-field__help">${u}</div>`:g}
374
- <div class="cfg-input-wrap">
375
- <input
376
- type=${h?"password":l}
377
- class="cfg-input"
378
- placeholder=${v}
379
- .value=${w==null?"":String(w)}
380
- ?disabled=${o}
381
- @input=${$=>{const x=$.target.value;if(l==="number"){if(x.trim()===""){a(s,void 0);return}const T=Number(x);a(s,Number.isNaN(T)?x:T);return}a(s,x)}}
382
- />
383
- ${t.default!==void 0?c`
384
- <button
385
- type="button"
386
- class="cfg-input__reset"
387
- title="Reset to default"
388
- ?disabled=${o}
389
- @click=${()=>a(s,t.default)}
390
- >↺</button>
391
- `:g}
392
- </div>
393
- </div>
394
- `}function Pp(e){const{schema:t,value:n,path:s,hints:i,disabled:o,onPatch:a}=e,l=e.showLabel??!0,r=ee(s,i),p=r?.label??t.title??ye(String(s.at(-1))),d=r?.help??t.description,u=n??t.default??"",h=typeof u=="number"?u:0;return c`
395
- <div class="cfg-field">
396
- ${l?c`<label class="cfg-field__label">${p}</label>`:g}
397
- ${d?c`<div class="cfg-field__help">${d}</div>`:g}
398
- <div class="cfg-number">
399
- <button
400
- type="button"
401
- class="cfg-number__btn"
402
- ?disabled=${o}
403
- @click=${()=>a(s,h-1)}
404
- >−</button>
405
- <input
406
- type="number"
407
- class="cfg-number__input"
408
- .value=${u==null?"":String(u)}
409
- ?disabled=${o}
410
- @input=${v=>{const w=v.target.value,$=w===""?void 0:Number(w);a(s,$)}}
411
- />
412
- <button
413
- type="button"
414
- class="cfg-number__btn"
415
- ?disabled=${o}
416
- @click=${()=>a(s,h+1)}
417
- >+</button>
418
- </div>
419
- </div>
420
- `}function Mo(e){const{schema:t,value:n,path:s,hints:i,disabled:o,options:a,onPatch:l}=e,r=e.showLabel??!0,p=ee(s,i),d=p?.label??t.title??ye(String(s.at(-1))),u=p?.help??t.description,h=n??t.default,v=a.findIndex($=>$===h||String($)===String(h)),w="__unset__";return c`
421
- <div class="cfg-field">
422
- ${r?c`<label class="cfg-field__label">${d}</label>`:g}
423
- ${u?c`<div class="cfg-field__help">${u}</div>`:g}
424
- <select
425
- class="cfg-select"
426
- ?disabled=${o}
427
- .value=${v>=0?String(v):w}
428
- @change=${$=>{const x=$.target.value;l(s,x===w?void 0:a[Number(x)])}}
429
- >
430
- <option value=${w}>Select...</option>
431
- ${a.map(($,x)=>c`
432
- <option value=${String(x)}>${String($)}</option>
433
- `)}
434
- </select>
435
- </div>
436
- `}function Np(e){const{schema:t,value:n,path:s,hints:i,unsupported:o,disabled:a,onPatch:l}=e;e.showLabel;const r=ee(s,i),p=r?.label??t.title??ye(String(s.at(-1))),d=r?.help??t.description,u=n??t.default,h=u&&typeof u=="object"&&!Array.isArray(u)?u:{},v=t.properties??{},$=Object.entries(v).sort((P,I)=>{const C=ee([...s,P[0]],i)?.order??0,E=ee([...s,I[0]],i)?.order??0;return C!==E?C-E:P[0].localeCompare(I[0])}),x=new Set(Object.keys(v)),T=t.additionalProperties,R=!!T&&typeof T=="object";return s.length===1?c`
437
- <div class="cfg-fields">
438
- ${$.map(([P,I])=>be({schema:I,value:h[P],path:[...s,P],hints:i,unsupported:o,disabled:a,onPatch:l}))}
439
- ${R?Po({schema:T,value:h,path:s,hints:i,unsupported:o,disabled:a,reservedKeys:x,onPatch:l}):g}
440
- </div>
441
- `:c`
442
- <details class="cfg-object" open>
443
- <summary class="cfg-object__header">
444
- <span class="cfg-object__title">${p}</span>
445
- <span class="cfg-object__chevron">${St.chevronDown}</span>
446
- </summary>
447
- ${d?c`<div class="cfg-object__help">${d}</div>`:g}
448
- <div class="cfg-object__content">
449
- ${$.map(([P,I])=>be({schema:I,value:h[P],path:[...s,P],hints:i,unsupported:o,disabled:a,onPatch:l}))}
450
- ${R?Po({schema:T,value:h,path:s,hints:i,unsupported:o,disabled:a,reservedKeys:x,onPatch:l}):g}
451
- </div>
452
- </details>
453
- `}function Op(e){const{schema:t,value:n,path:s,hints:i,unsupported:o,disabled:a,onPatch:l}=e,r=e.showLabel??!0,p=ee(s,i),d=p?.label??t.title??ye(String(s.at(-1))),u=p?.help??t.description,h=Array.isArray(t.items)?t.items[0]:t.items;if(!h)return c`
454
- <div class="cfg-field cfg-field--error">
455
- <div class="cfg-field__label">${d}</div>
456
- <div class="cfg-field__error">Unsupported array schema. Use Raw mode.</div>
457
- </div>
458
- `;const v=Array.isArray(n)?n:Array.isArray(t.default)?t.default:[];return c`
459
- <div class="cfg-array">
460
- <div class="cfg-array__header">
461
- ${r?c`<span class="cfg-array__label">${d}</span>`:g}
462
- <span class="cfg-array__count">${v.length} item${v.length!==1?"s":""}</span>
463
- <button
464
- type="button"
465
- class="cfg-array__add"
466
- ?disabled=${a}
467
- @click=${()=>{const w=[...v,ur(h)];l(s,w)}}
468
- >
469
- <span class="cfg-array__add-icon">${St.plus}</span>
470
- Add
471
- </button>
472
- </div>
473
- ${u?c`<div class="cfg-array__help">${u}</div>`:g}
474
-
475
- ${v.length===0?c`
476
- <div class="cfg-array__empty">
477
- No items yet. Click "Add" to create one.
478
- </div>
479
- `:c`
480
- <div class="cfg-array__items">
481
- ${v.map((w,$)=>c`
482
- <div class="cfg-array__item">
483
- <div class="cfg-array__item-header">
484
- <span class="cfg-array__item-index">#${$+1}</span>
485
- <button
486
- type="button"
487
- class="cfg-array__item-remove"
488
- title="Remove item"
489
- ?disabled=${a}
490
- @click=${()=>{const x=[...v];x.splice($,1),l(s,x)}}
491
- >
492
- ${St.trash}
493
- </button>
494
- </div>
495
- <div class="cfg-array__item-content">
496
- ${be({schema:h,value:w,path:[...s,$],hints:i,unsupported:o,disabled:a,showLabel:!1,onPatch:l})}
497
- </div>
498
- </div>
499
- `)}
500
- </div>
501
- `}
502
- </div>
503
- `}function Po(e){const{schema:t,value:n,path:s,hints:i,unsupported:o,disabled:a,reservedKeys:l,onPatch:r}=e,p=Lp(t),d=Object.entries(n??{}).filter(([u])=>!l.has(u));return c`
504
- <div class="cfg-map">
505
- <div class="cfg-map__header">
506
- <span class="cfg-map__label">Custom entries</span>
507
- <button
508
- type="button"
509
- class="cfg-map__add"
510
- ?disabled=${a}
511
- @click=${()=>{const u={...n??{}};let h=1,v=`custom-${h}`;for(;v in u;)h+=1,v=`custom-${h}`;u[v]=p?{}:ur(t),r(s,u)}}
512
- >
513
- <span class="cfg-map__add-icon">${St.plus}</span>
514
- Add Entry
515
- </button>
516
- </div>
517
-
518
- ${d.length===0?c`
519
- <div class="cfg-map__empty">No custom entries.</div>
520
- `:c`
521
- <div class="cfg-map__items">
522
- ${d.map(([u,h])=>{const v=[...s,u],w=Mp(h);return c`
523
- <div class="cfg-map__item">
524
- <div class="cfg-map__item-key">
525
- <input
526
- type="text"
527
- class="cfg-input cfg-input--sm"
528
- placeholder="Key"
529
- .value=${u}
530
- ?disabled=${a}
531
- @change=${$=>{const x=$.target.value.trim();if(!x||x===u)return;const T={...n??{}};x in T||(T[x]=T[u],delete T[u],r(s,T))}}
532
- />
533
- </div>
534
- <div class="cfg-map__item-value">
535
- ${p?c`
536
- <textarea
537
- class="cfg-textarea cfg-textarea--sm"
538
- placeholder="JSON value"
539
- rows="2"
540
- .value=${w}
541
- ?disabled=${a}
542
- @change=${$=>{const x=$.target,T=x.value.trim();if(!T){r(v,void 0);return}try{r(v,JSON.parse(T))}catch{x.value=w}}}
543
- ></textarea>
544
- `:be({schema:t,value:h,path:v,hints:i,unsupported:o,disabled:a,showLabel:!1,onPatch:r})}
545
- </div>
546
- <button
547
- type="button"
548
- class="cfg-map__item-remove"
549
- title="Remove entry"
550
- ?disabled=${a}
551
- @click=${()=>{const $={...n??{}};delete $[u],r(s,$)}}
552
- >
553
- ${St.trash}
554
- </button>
555
- </div>
556
- `})}
557
- </div>
558
- `}
559
- </div>
560
- `}const No={env:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><circle cx="12" cy="12" r="3"></circle><path d="M19.4 15a1.65 1.65 0 0 0 .33 1.82l.06.06a2 2 0 0 1 0 2.83 2 2 0 0 1-2.83 0l-.06-.06a1.65 1.65 0 0 0-1.82-.33 1.65 1.65 0 0 0-1 1.51V21a2 2 0 0 1-2 2 2 2 0 0 1-2-2v-.09A1.65 1.65 0 0 0 9 19.4a1.65 1.65 0 0 0-1.82.33l-.06.06a2 2 0 0 1-2.83 0 2 2 0 0 1 0-2.83l.06-.06a1.65 1.65 0 0 0 .33-1.82 1.65 1.65 0 0 0-1.51-1H3a2 2 0 0 1-2-2 2 2 0 0 1 2-2h.09A1.65 1.65 0 0 0 4.6 9a1.65 1.65 0 0 0-.33-1.82l-.06-.06a2 2 0 0 1 0-2.83 2 2 0 0 1 2.83 0l.06.06a1.65 1.65 0 0 0 1.82.33H9a1.65 1.65 0 0 0 1-1.51V3a2 2 0 0 1 2-2 2 2 0 0 1 2 2v.09a1.65 1.65 0 0 0 1 1.51 1.65 1.65 0 0 0 1.82-.33l.06-.06a2 2 0 0 1 2.83 0 2 2 0 0 1 0 2.83l-.06.06a1.65 1.65 0 0 0-.33 1.82V9a1.65 1.65 0 0 0 1.51 1H21a2 2 0 0 1 2 2 2 2 0 0 1-2 2h-.09a1.65 1.65 0 0 0-1.51 1z"></path></svg>`,update:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><path d="M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4"></path><polyline points="7 10 12 15 17 10"></polyline><line x1="12" y1="15" x2="12" y2="3"></line></svg>`,agents:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><path d="M12 2a2 2 0 0 1 2 2c0 .74-.4 1.39-1 1.73V7h1a7 7 0 0 1 7 7h1a1 1 0 0 1 1 1v3a1 1 0 0 1-1 1h-1v1a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-1H2a1 1 0 0 1-1-1v-3a1 1 0 0 1 1-1h1a7 7 0 0 1 7-7h1V5.73c-.6-.34-1-.99-1-1.73a2 2 0 0 1 2-2z"></path><circle cx="8" cy="14" r="1"></circle><circle cx="16" cy="14" r="1"></circle></svg>`,auth:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><rect x="3" y="11" width="18" height="11" rx="2" ry="2"></rect><path d="M7 11V7a5 5 0 0 1 10 0v4"></path></svg>`,channels:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><path d="M21 15a2 2 0 0 1-2 2H7l-4 4V5a2 2 0 0 1 2-2h14a2 2 0 0 1 2 2z"></path></svg>`,messages:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><path d="M4 4h16c1.1 0 2 .9 2 2v12c0 1.1-.9 2-2 2H4c-1.1 0-2-.9-2-2V6c0-1.1.9-2 2-2z"></path><polyline points="22,6 12,13 2,6"></polyline></svg>`,commands:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><polyline points="4 17 10 11 4 5"></polyline><line x1="12" y1="19" x2="20" y2="19"></line></svg>`,hooks:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg>`,skills:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><polygon points="12 2 15.09 8.26 22 9.27 17 14.14 18.18 21.02 12 17.77 5.82 21.02 7 14.14 2 9.27 8.91 8.26 12 2"></polygon></svg>`,tools:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><path d="M14.7 6.3a1 1 0 0 0 0 1.4l1.6 1.6a1 1 0 0 0 1.4 0l3.77-3.77a6 6 0 0 1-7.94 7.94l-6.91 6.91a2.12 2.12 0 0 1-3-3l6.91-6.91a6 6 0 0 1 7.94-7.94l-3.76 3.76z"></path></svg>`,gateway:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><circle cx="12" cy="12" r="10"></circle><line x1="2" y1="12" x2="22" y2="12"></line><path d="M12 2a15.3 15.3 0 0 1 4 10 15.3 15.3 0 0 1-4 10 15.3 15.3 0 0 1-4-10 15.3 15.3 0 0 1 4-10z"></path></svg>`,wizard:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><path d="M15 4V2"></path><path d="M15 16v-2"></path><path d="M8 9h2"></path><path d="M20 9h2"></path><path d="M17.8 11.8 19 13"></path><path d="M15 9h0"></path><path d="M17.8 6.2 19 5"></path><path d="m3 21 9-9"></path><path d="M12.2 6.2 11 5"></path></svg>`,meta:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><path d="M12 20h9"></path><path d="M16.5 3.5a2.12 2.12 0 0 1 3 3L7 19l-4 1 1-4Z"></path></svg>`,logging:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><path d="M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z"></path><polyline points="14 2 14 8 20 8"></polyline><line x1="16" y1="13" x2="8" y2="13"></line><line x1="16" y1="17" x2="8" y2="17"></line><polyline points="10 9 9 9 8 9"></polyline></svg>`,browser:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><circle cx="12" cy="12" r="10"></circle><circle cx="12" cy="12" r="4"></circle><line x1="21.17" y1="8" x2="12" y2="8"></line><line x1="3.95" y1="6.06" x2="8.54" y2="14"></line><line x1="10.88" y1="21.94" x2="15.46" y2="14"></line></svg>`,ui:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><rect x="3" y="3" width="18" height="18" rx="2" ry="2"></rect><line x1="3" y1="9" x2="21" y2="9"></line><line x1="9" y1="21" x2="9" y2="9"></line></svg>`,models:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><path d="M21 16V8a2 2 0 0 0-1-1.73l-7-4a2 2 0 0 0-2 0l-7 4A2 2 0 0 0 3 8v8a2 2 0 0 0 1 1.73l7 4a2 2 0 0 0 2 0l7-4A2 2 0 0 0 21 16z"></path><polyline points="3.27 6.96 12 12.01 20.73 6.96"></polyline><line x1="12" y1="22.08" x2="12" y2="12"></line></svg>`,bindings:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><rect x="2" y="2" width="20" height="8" rx="2" ry="2"></rect><rect x="2" y="14" width="20" height="8" rx="2" ry="2"></rect><line x1="6" y1="6" x2="6.01" y2="6"></line><line x1="6" y1="18" x2="6.01" y2="18"></line></svg>`,broadcast:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><path d="M4.9 19.1C1 15.2 1 8.8 4.9 4.9"></path><path d="M7.8 16.2c-2.3-2.3-2.3-6.1 0-8.5"></path><circle cx="12" cy="12" r="2"></circle><path d="M16.2 7.8c2.3 2.3 2.3 6.1 0 8.5"></path><path d="M19.1 4.9C23 8.8 23 15.1 19.1 19"></path></svg>`,audio:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><path d="M9 18V5l12-2v13"></path><circle cx="6" cy="18" r="3"></circle><circle cx="18" cy="16" r="3"></circle></svg>`,session:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><path d="M17 21v-2a4 4 0 0 0-4-4H5a4 4 0 0 0-4 4v2"></path><circle cx="9" cy="7" r="4"></circle><path d="M23 21v-2a4 4 0 0 0-3-3.87"></path><path d="M16 3.13a4 4 0 0 1 0 7.75"></path></svg>`,cron:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><circle cx="12" cy="12" r="10"></circle><polyline points="12 6 12 12 16 14"></polyline></svg>`,web:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><circle cx="12" cy="12" r="10"></circle><line x1="2" y1="12" x2="22" y2="12"></line><path d="M12 2a15.3 15.3 0 0 1 4 10 15.3 15.3 0 0 1-4 10 15.3 15.3 0 0 1-4-10 15.3 15.3 0 0 1 4-10z"></path></svg>`,discovery:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><circle cx="11" cy="11" r="8"></circle><line x1="21" y1="21" x2="16.65" y2="16.65"></line></svg>`,canvasHost:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><rect x="3" y="3" width="18" height="18" rx="2" ry="2"></rect><circle cx="8.5" cy="8.5" r="1.5"></circle><polyline points="21 15 16 10 5 21"></polyline></svg>`,talk:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><path d="M12 1a3 3 0 0 0-3 3v8a3 3 0 0 0 6 0V4a3 3 0 0 0-3-3z"></path><path d="M19 10v2a7 7 0 0 1-14 0v-2"></path><line x1="12" y1="19" x2="12" y2="23"></line><line x1="8" y1="23" x2="16" y2="23"></line></svg>`,plugins:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><path d="M12 2v6"></path><path d="m4.93 10.93 4.24 4.24"></path><path d="M2 12h6"></path><path d="m4.93 13.07 4.24-4.24"></path><path d="M12 22v-6"></path><path d="m19.07 13.07-4.24-4.24"></path><path d="M22 12h-6"></path><path d="m19.07 10.93-4.24 4.24"></path></svg>`,default:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><path d="M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z"></path><polyline points="14 2 14 8 20 8"></polyline></svg>`},di={env:{label:"Environment Variables",description:"Environment variables passed to the gateway process"},update:{label:"Updates",description:"Auto-update settings and release channel"},agents:{label:"Agents",description:"Agent configurations, models, and identities"},auth:{label:"Authentication",description:"API keys and authentication profiles"},channels:{label:"Channels",description:"Messaging channels (Telegram, Discord, Slack, etc.)"},messages:{label:"Messages",description:"Message handling and routing settings"},commands:{label:"Commands",description:"Custom slash commands"},hooks:{label:"Hooks",description:"Webhooks and event hooks"},skills:{label:"Skills",description:"Skill packs and capabilities"},tools:{label:"Tools",description:"Tool configurations (browser, search, etc.)"},gateway:{label:"Gateway",description:"Gateway server settings (port, auth, binding)"},wizard:{label:"Setup Wizard",description:"Setup wizard state and history"},meta:{label:"Metadata",description:"Gateway metadata and version information"},logging:{label:"Logging",description:"Log levels and output configuration"},browser:{label:"Browser",description:"Browser automation settings"},ui:{label:"UI",description:"User interface preferences"},models:{label:"Models",description:"AI model configurations and providers"},bindings:{label:"Bindings",description:"Key bindings and shortcuts"},broadcast:{label:"Broadcast",description:"Broadcast and notification settings"},audio:{label:"Audio",description:"Audio input/output settings"},session:{label:"Session",description:"Session management and persistence"},cron:{label:"Cron",description:"Scheduled tasks and automation"},web:{label:"Web",description:"Web server and API settings"},discovery:{label:"Discovery",description:"Service discovery and networking"},canvasHost:{label:"Canvas Host",description:"Canvas rendering and display"},talk:{label:"Talk",description:"Voice and speech settings"},plugins:{label:"Plugins",description:"Plugin management and extensions"}};function Oo(e){return No[e]??No.default}function Dp(e,t,n){if(!n)return!0;const s=n.toLowerCase(),i=di[e];return e.toLowerCase().includes(s)||i&&(i.label.toLowerCase().includes(s)||i.description.toLowerCase().includes(s))?!0:vt(t,s)}function vt(e,t){if(e.title?.toLowerCase().includes(t)||e.description?.toLowerCase().includes(t)||e.enum?.some(s=>String(s).toLowerCase().includes(t)))return!0;if(e.properties){for(const[s,i]of Object.entries(e.properties))if(s.toLowerCase().includes(t)||vt(i,t))return!0}if(e.items){const s=Array.isArray(e.items)?e.items:[e.items];for(const i of s)if(i&&vt(i,t))return!0}if(e.additionalProperties&&typeof e.additionalProperties=="object"&&vt(e.additionalProperties,t))return!0;const n=e.anyOf??e.oneOf??e.allOf;if(n){for(const s of n)if(s&&vt(s,t))return!0}return!1}function Bp(e){if(!e.schema)return c`<div class="muted">Schema unavailable.</div>`;const t=e.schema,n=e.value??{};if(de(t)!=="object"||!t.properties)return c`<div class="callout danger">Unsupported schema. Use Raw.</div>`;const s=new Set(e.unsupportedPaths??[]),i=t.properties,o=e.searchQuery??"",a=e.activeSection,l=e.activeSubsection??null,p=Object.entries(i).sort((u,h)=>{const v=ee([u[0]],e.uiHints)?.order??50,w=ee([h[0]],e.uiHints)?.order??50;return v!==w?v-w:u[0].localeCompare(h[0])}).filter(([u,h])=>!(a&&u!==a||o&&!Dp(u,h,o)));let d=null;if(a&&l&&p.length===1){const u=p[0]?.[1];u&&de(u)==="object"&&u.properties&&u.properties[l]&&(d={sectionKey:a,subsectionKey:l,schema:u.properties[l]})}return p.length===0?c`
561
- <div class="config-empty">
562
- <div class="config-empty__icon">🔍</div>
563
- <div class="config-empty__text">
564
- ${o?`No settings match "${o}"`:"No settings in this section"}
565
- </div>
566
- </div>
567
- `:c`
568
- <div class="config-form config-form--modern">
569
- ${d?(()=>{const{sectionKey:u,subsectionKey:h,schema:v}=d,w=ee([u,h],e.uiHints),$=w?.label??v.title??ye(h),x=w?.help??v.description??"",T=n[u],R=T&&typeof T=="object"?T[h]:void 0,P=`config-section-${u}-${h}`;return c`
570
- <section class="config-section-card" id=${P}>
571
- <div class="config-section-card__header">
572
- <span class="config-section-card__icon">${Oo(u)}</span>
573
- <div class="config-section-card__titles">
574
- <h3 class="config-section-card__title">${$}</h3>
575
- ${x?c`<p class="config-section-card__desc">${x}</p>`:g}
576
- </div>
577
- </div>
578
- <div class="config-section-card__content">
579
- ${be({schema:v,value:R,path:[u,h],hints:e.uiHints,unsupported:s,disabled:e.disabled??!1,showLabel:!1,onPatch:e.onPatch})}
580
- </div>
581
- </section>
582
- `})():p.map(([u,h])=>{const v=di[u]??{label:u.charAt(0).toUpperCase()+u.slice(1),description:h.description??""};return c`
583
- <section class="config-section-card" id="config-section-${u}">
584
- <div class="config-section-card__header">
585
- <span class="config-section-card__icon">${Oo(u)}</span>
586
- <div class="config-section-card__titles">
587
- <h3 class="config-section-card__title">${v.label}</h3>
588
- ${v.description?c`<p class="config-section-card__desc">${v.description}</p>`:g}
589
- </div>
590
- </div>
591
- <div class="config-section-card__content">
592
- ${be({schema:h,value:n[u],path:[u],hints:e.uiHints,unsupported:s,disabled:e.disabled??!1,showLabel:!1,onPatch:e.onPatch})}
593
- </div>
594
- </section>
595
- `})}
596
- </div>
597
- `}const Fp=new Set(["title","description","default","nullable"]);function Up(e){return Object.keys(e??{}).filter(n=>!Fp.has(n)).length===0}function pr(e){const t=e.filter(i=>i!=null),n=t.length!==e.length,s=[];for(const i of t)s.some(o=>Object.is(o,i))||s.push(i);return{enumValues:s,nullable:n}}function fr(e){return!e||typeof e!="object"?{schema:null,unsupportedPaths:["<root>"]}:yt(e,[])}function yt(e,t){const n=new Set,s={...e},i=bn(t)||"<root>";if(e.anyOf||e.oneOf||e.allOf){const l=Kp(e,t);return l||{schema:e,unsupportedPaths:[i]}}const o=Array.isArray(e.type)&&e.type.includes("null"),a=de(e)??(e.properties||e.additionalProperties?"object":void 0);if(s.type=a??e.type,s.nullable=o||e.nullable,s.enum){const{enumValues:l,nullable:r}=pr(s.enum);s.enum=l,r&&(s.nullable=!0),l.length===0&&n.add(i)}if(a==="object"){const l=e.properties??{},r={};for(const[p,d]of Object.entries(l)){const u=yt(d,[...t,p]);u.schema&&(r[p]=u.schema);for(const h of u.unsupportedPaths)n.add(h)}if(s.properties=r,e.additionalProperties===!0)n.add(i);else if(e.additionalProperties===!1)s.additionalProperties=!1;else if(e.additionalProperties&&typeof e.additionalProperties=="object"&&!Up(e.additionalProperties)){const p=yt(e.additionalProperties,[...t,"*"]);s.additionalProperties=p.schema??e.additionalProperties,p.unsupportedPaths.length>0&&n.add(i)}}else if(a==="array"){const l=Array.isArray(e.items)?e.items[0]:e.items;if(!l)n.add(i);else{const r=yt(l,[...t,"*"]);s.items=r.schema??l,r.unsupportedPaths.length>0&&n.add(i)}}else a!=="string"&&a!=="number"&&a!=="integer"&&a!=="boolean"&&!s.enum&&n.add(i);return{schema:s,unsupportedPaths:Array.from(n)}}function Kp(e,t){if(e.allOf)return null;const n=e.anyOf??e.oneOf;if(!n)return null;const s=[],i=[];let o=!1;for(const l of n){if(!l||typeof l!="object")return null;if(Array.isArray(l.enum)){const{enumValues:r,nullable:p}=pr(l.enum);s.push(...r),p&&(o=!0);continue}if("const"in l){if(l.const==null){o=!0;continue}s.push(l.const);continue}if(de(l)==="null"){o=!0;continue}i.push(l)}if(s.length>0&&i.length===0){const l=[];for(const r of s)l.some(p=>Object.is(p,r))||l.push(r);return{schema:{...e,enum:l,nullable:o,anyOf:void 0,oneOf:void 0,allOf:void 0},unsupportedPaths:[]}}if(i.length===1){const l=yt(i[0],t);return l.schema&&(l.schema.nullable=o||l.schema.nullable),l}const a=["string","number","integer","boolean"];return i.length>0&&s.length===0&&i.every(l=>l.type&&a.includes(String(l.type)))?{schema:{...e,nullable:o},unsupportedPaths:[]}:null}const Ss={all:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><rect x="3" y="3" width="7" height="7"></rect><rect x="14" y="3" width="7" height="7"></rect><rect x="14" y="14" width="7" height="7"></rect><rect x="3" y="14" width="7" height="7"></rect></svg>`,env:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><circle cx="12" cy="12" r="3"></circle><path d="M19.4 15a1.65 1.65 0 0 0 .33 1.82l.06.06a2 2 0 0 1 0 2.83 2 2 0 0 1-2.83 0l-.06-.06a1.65 1.65 0 0 0-1.82-.33 1.65 1.65 0 0 0-1 1.51V21a2 2 0 0 1-2 2 2 2 0 0 1-2-2v-.09A1.65 1.65 0 0 0 9 19.4a1.65 1.65 0 0 0-1.82.33l-.06.06a2 2 0 0 1-2.83 0 2 2 0 0 1 0-2.83l.06-.06a1.65 1.65 0 0 0 .33-1.82 1.65 1.65 0 0 0-1.51-1H3a2 2 0 0 1-2-2 2 2 0 0 1 2-2h.09A1.65 1.65 0 0 0 4.6 9a1.65 1.65 0 0 0-.33-1.82l-.06-.06a2 2 0 0 1 0-2.83 2 2 0 0 1 2.83 0l.06.06a1.65 1.65 0 0 0 1.82.33H9a1.65 1.65 0 0 0 1-1.51V3a2 2 0 0 1 2-2 2 2 0 0 1 2 2v.09a1.65 1.65 0 0 0 1 1.51 1.65 1.65 0 0 0 1.82-.33l.06-.06a2 2 0 0 1 2.83 0 2 2 0 0 1 0 2.83l-.06.06a1.65 1.65 0 0 0-.33 1.82V9a1.65 1.65 0 0 0 1.51 1H21a2 2 0 0 1 2 2 2 2 0 0 1-2 2h-.09a1.65 1.65 0 0 0-1.51 1z"></path></svg>`,update:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4"></path><polyline points="7 10 12 15 17 10"></polyline><line x1="12" y1="15" x2="12" y2="3"></line></svg>`,agents:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M12 2a2 2 0 0 1 2 2c0 .74-.4 1.39-1 1.73V7h1a7 7 0 0 1 7 7h1a1 1 0 0 1 1 1v3a1 1 0 0 1-1 1h-1v1a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-1H2a1 1 0 0 1-1-1v-3a1 1 0 0 1 1-1h1a7 7 0 0 1 7-7h1V5.73c-.6-.34-1-.99-1-1.73a2 2 0 0 1 2-2z"></path><circle cx="8" cy="14" r="1"></circle><circle cx="16" cy="14" r="1"></circle></svg>`,auth:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><rect x="3" y="11" width="18" height="11" rx="2" ry="2"></rect><path d="M7 11V7a5 5 0 0 1 10 0v4"></path></svg>`,channels:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M21 15a2 2 0 0 1-2 2H7l-4 4V5a2 2 0 0 1 2-2h14a2 2 0 0 1 2 2z"></path></svg>`,messages:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M4 4h16c1.1 0 2 .9 2 2v12c0 1.1-.9 2-2 2H4c-1.1 0-2-.9-2-2V6c0-1.1.9-2 2-2z"></path><polyline points="22,6 12,13 2,6"></polyline></svg>`,commands:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><polyline points="4 17 10 11 4 5"></polyline><line x1="12" y1="19" x2="20" y2="19"></line></svg>`,hooks:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg>`,skills:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><polygon points="12 2 15.09 8.26 22 9.27 17 14.14 18.18 21.02 12 17.77 5.82 21.02 7 14.14 2 9.27 8.91 8.26 12 2"></polygon></svg>`,tools:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M14.7 6.3a1 1 0 0 0 0 1.4l1.6 1.6a1 1 0 0 0 1.4 0l3.77-3.77a6 6 0 0 1-7.94 7.94l-6.91 6.91a2.12 2.12 0 0 1-3-3l6.91-6.91a6 6 0 0 1 7.94-7.94l-3.76 3.76z"></path></svg>`,gateway:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><circle cx="12" cy="12" r="10"></circle><line x1="2" y1="12" x2="22" y2="12"></line><path d="M12 2a15.3 15.3 0 0 1 4 10 15.3 15.3 0 0 1-4 10 15.3 15.3 0 0 1-4-10 15.3 15.3 0 0 1 4-10z"></path></svg>`,wizard:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M15 4V2"></path><path d="M15 16v-2"></path><path d="M8 9h2"></path><path d="M20 9h2"></path><path d="M17.8 11.8 19 13"></path><path d="M15 9h0"></path><path d="M17.8 6.2 19 5"></path><path d="m3 21 9-9"></path><path d="M12.2 6.2 11 5"></path></svg>`,meta:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M12 20h9"></path><path d="M16.5 3.5a2.12 2.12 0 0 1 3 3L7 19l-4 1 1-4Z"></path></svg>`,logging:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z"></path><polyline points="14 2 14 8 20 8"></polyline><line x1="16" y1="13" x2="8" y2="13"></line><line x1="16" y1="17" x2="8" y2="17"></line><polyline points="10 9 9 9 8 9"></polyline></svg>`,browser:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><circle cx="12" cy="12" r="10"></circle><circle cx="12" cy="12" r="4"></circle><line x1="21.17" y1="8" x2="12" y2="8"></line><line x1="3.95" y1="6.06" x2="8.54" y2="14"></line><line x1="10.88" y1="21.94" x2="15.46" y2="14"></line></svg>`,ui:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><rect x="3" y="3" width="18" height="18" rx="2" ry="2"></rect><line x1="3" y1="9" x2="21" y2="9"></line><line x1="9" y1="21" x2="9" y2="9"></line></svg>`,models:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M21 16V8a2 2 0 0 0-1-1.73l-7-4a2 2 0 0 0-2 0l-7 4A2 2 0 0 0 3 8v8a2 2 0 0 0 1 1.73l7 4a2 2 0 0 0 2 0l7-4A2 2 0 0 0 21 16z"></path><polyline points="3.27 6.96 12 12.01 20.73 6.96"></polyline><line x1="12" y1="22.08" x2="12" y2="12"></line></svg>`,bindings:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><rect x="2" y="2" width="20" height="8" rx="2" ry="2"></rect><rect x="2" y="14" width="20" height="8" rx="2" ry="2"></rect><line x1="6" y1="6" x2="6.01" y2="6"></line><line x1="6" y1="18" x2="6.01" y2="18"></line></svg>`,broadcast:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M4.9 19.1C1 15.2 1 8.8 4.9 4.9"></path><path d="M7.8 16.2c-2.3-2.3-2.3-6.1 0-8.5"></path><circle cx="12" cy="12" r="2"></circle><path d="M16.2 7.8c2.3 2.3 2.3 6.1 0 8.5"></path><path d="M19.1 4.9C23 8.8 23 15.1 19.1 19"></path></svg>`,audio:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M9 18V5l12-2v13"></path><circle cx="6" cy="18" r="3"></circle><circle cx="18" cy="16" r="3"></circle></svg>`,session:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M17 21v-2a4 4 0 0 0-4-4H5a4 4 0 0 0-4 4v2"></path><circle cx="9" cy="7" r="4"></circle><path d="M23 21v-2a4 4 0 0 0-3-3.87"></path><path d="M16 3.13a4 4 0 0 1 0 7.75"></path></svg>`,cron:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><circle cx="12" cy="12" r="10"></circle><polyline points="12 6 12 12 16 14"></polyline></svg>`,web:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><circle cx="12" cy="12" r="10"></circle><line x1="2" y1="12" x2="22" y2="12"></line><path d="M12 2a15.3 15.3 0 0 1 4 10 15.3 15.3 0 0 1-4 10 15.3 15.3 0 0 1-4-10 15.3 15.3 0 0 1 4-10z"></path></svg>`,discovery:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><circle cx="11" cy="11" r="8"></circle><line x1="21" y1="21" x2="16.65" y2="16.65"></line></svg>`,canvasHost:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><rect x="3" y="3" width="18" height="18" rx="2" ry="2"></rect><circle cx="8.5" cy="8.5" r="1.5"></circle><polyline points="21 15 16 10 5 21"></polyline></svg>`,talk:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M12 1a3 3 0 0 0-3 3v8a3 3 0 0 0 6 0V4a3 3 0 0 0-3-3z"></path><path d="M19 10v2a7 7 0 0 1-14 0v-2"></path><line x1="12" y1="19" x2="12" y2="23"></line><line x1="8" y1="23" x2="16" y2="23"></line></svg>`,plugins:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M12 2v6"></path><path d="m4.93 10.93 4.24 4.24"></path><path d="M2 12h6"></path><path d="m4.93 13.07 4.24-4.24"></path><path d="M12 22v-6"></path><path d="m19.07 13.07-4.24-4.24"></path><path d="M22 12h-6"></path><path d="m19.07 10.93-4.24 4.24"></path></svg>`,default:c`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z"></path><polyline points="14 2 14 8 20 8"></polyline></svg>`},Do=[{key:"env",label:"Environment"},{key:"update",label:"Updates"},{key:"agents",label:"Agents"},{key:"auth",label:"Authentication"},{key:"channels",label:"Channels"},{key:"messages",label:"Messages"},{key:"commands",label:"Commands"},{key:"hooks",label:"Hooks"},{key:"skills",label:"Skills"},{key:"tools",label:"Tools"},{key:"gateway",label:"Gateway"},{key:"wizard",label:"Setup Wizard"}],Bo="__all__";function Fo(e){return Ss[e]??Ss.default}function Hp(e,t){const n=di[e];return n||{label:t?.title??ye(e),description:t?.description??""}}function zp(e){const{key:t,schema:n,uiHints:s}=e;if(!n||de(n)!=="object"||!n.properties)return[];const i=Object.entries(n.properties).map(([o,a])=>{const l=ee([t,o],s),r=l?.label??a.title??ye(o),p=l?.help??a.description??"",d=l?.order??50;return{key:o,label:r,description:p,order:d}});return i.sort((o,a)=>o.order!==a.order?o.order-a.order:o.key.localeCompare(a.key)),i}function jp(e,t){if(!e||!t)return[];const n=[];function s(i,o,a){if(i===o)return;if(typeof i!=typeof o){n.push({path:a,from:i,to:o});return}if(typeof i!="object"||i===null||o===null){i!==o&&n.push({path:a,from:i,to:o});return}if(Array.isArray(i)&&Array.isArray(o)){JSON.stringify(i)!==JSON.stringify(o)&&n.push({path:a,from:i,to:o});return}const l=i,r=o,p=new Set([...Object.keys(l),...Object.keys(r)]);for(const d of p)s(l[d],r[d],a?`${a}.${d}`:d)}return s(e,t,""),n}function Uo(e,t=40){let n;try{n=JSON.stringify(e)??String(e)}catch{n=String(e)}return n.length<=t?n:n.slice(0,t-3)+"..."}function qp(e){const t=e.valid==null?"unknown":e.valid?"valid":"invalid",n=fr(e.schema),s=n.schema?n.unsupportedPaths.length>0:!1,i=n.schema?.properties??{},o=Do.filter(E=>E.key in i),a=new Set(Do.map(E=>E.key)),l=Object.keys(i).filter(E=>!a.has(E)).map(E=>({key:E,label:E.charAt(0).toUpperCase()+E.slice(1)})),r=[...o,...l],p=e.activeSection&&n.schema&&de(n.schema)==="object"?n.schema.properties?.[e.activeSection]:void 0,d=e.activeSection?Hp(e.activeSection,p):null,u=e.activeSection?zp({key:e.activeSection,schema:p,uiHints:e.uiHints}):[],h=e.formMode==="form"&&!!e.activeSection&&u.length>0,v=e.activeSubsection===Bo,w=e.searchQuery||v?null:e.activeSubsection??u[0]?.key??null,$=e.formMode==="form"?jp(e.originalValue,e.formValue):[],x=e.formMode==="raw"&&e.raw!==e.originalRaw,T=e.formMode==="form"?$.length>0:x,R=!!e.formValue&&!e.loading&&!!n.schema,P=e.connected&&!e.saving&&T&&(e.formMode==="raw"?!0:R),I=e.connected&&!e.applying&&!e.updating&&T&&(e.formMode==="raw"?!0:R),C=e.connected&&!e.applying&&!e.updating;return c`
598
- <div class="config-layout">
599
- <!-- Sidebar -->
600
- <aside class="config-sidebar">
601
- <div class="config-sidebar__header">
602
- <div class="config-sidebar__title">Settings</div>
603
- <span class="pill pill--sm ${t==="valid"?"pill--ok":t==="invalid"?"pill--danger":""}">${t}</span>
604
- </div>
605
-
606
- <!-- Search -->
607
- <div class="config-search">
608
- <svg class="config-search__icon" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">
609
- <circle cx="11" cy="11" r="8"></circle>
610
- <path d="M21 21l-4.35-4.35"></path>
611
- </svg>
612
- <input
613
- type="text"
614
- class="config-search__input"
615
- placeholder="Search settings..."
616
- .value=${e.searchQuery}
617
- @input=${E=>e.onSearchChange(E.target.value)}
618
- />
619
- ${e.searchQuery?c`
620
- <button
621
- class="config-search__clear"
622
- @click=${()=>e.onSearchChange("")}
623
- >×</button>
624
- `:g}
625
- </div>
626
-
627
- <!-- Section nav -->
628
- <nav class="config-nav">
629
- <button
630
- class="config-nav__item ${e.activeSection===null?"active":""}"
631
- @click=${()=>e.onSectionChange(null)}
632
- >
633
- <span class="config-nav__icon">${Ss.all}</span>
634
- <span class="config-nav__label">All Settings</span>
635
- </button>
636
- ${r.map(E=>c`
637
- <button
638
- class="config-nav__item ${e.activeSection===E.key?"active":""}"
639
- @click=${()=>e.onSectionChange(E.key)}
640
- >
641
- <span class="config-nav__icon">${Fo(E.key)}</span>
642
- <span class="config-nav__label">${E.label}</span>
643
- </button>
644
- `)}
645
- </nav>
646
-
647
- <!-- Mode toggle at bottom -->
648
- <div class="config-sidebar__footer">
649
- <div class="config-mode-toggle">
650
- <button
651
- class="config-mode-toggle__btn ${e.formMode==="form"?"active":""}"
652
- ?disabled=${e.schemaLoading||!e.schema}
653
- @click=${()=>e.onFormModeChange("form")}
654
- >
655
- Form
656
- </button>
657
- <button
658
- class="config-mode-toggle__btn ${e.formMode==="raw"?"active":""}"
659
- @click=${()=>e.onFormModeChange("raw")}
660
- >
661
- Raw
662
- </button>
663
- </div>
664
- </div>
665
- </aside>
666
-
667
- <!-- Main content -->
668
- <main class="config-main">
669
- <!-- Action bar -->
670
- <div class="config-actions">
671
- <div class="config-actions__left">
672
- ${T?c`
673
- <span class="config-changes-badge">${e.formMode==="raw"?"Unsaved changes":`${$.length} unsaved change${$.length!==1?"s":""}`}</span>
674
- `:c`
675
- <span class="config-status muted">No changes</span>
676
- `}
677
- </div>
678
- <div class="config-actions__right">
679
- <button class="btn btn--sm" ?disabled=${e.loading} @click=${e.onReload}>
680
- ${e.loading?"Loading…":"Reload"}
681
- </button>
682
- <button
683
- class="btn btn--sm primary"
684
- ?disabled=${!P}
685
- @click=${e.onSave}
686
- >
687
- ${e.saving?"Saving…":"Save"}
688
- </button>
689
- <button
690
- class="btn btn--sm"
691
- ?disabled=${!I}
692
- @click=${e.onApply}
693
- >
694
- ${e.applying?"Applying…":"Apply"}
695
- </button>
696
- <button
697
- class="btn btn--sm"
698
- ?disabled=${!C}
699
- @click=${e.onUpdate}
700
- >
701
- ${e.updating?"Updating…":"Update"}
702
- </button>
703
- </div>
704
- </div>
705
-
706
- <!-- Diff panel (form mode only - raw mode doesn't have granular diff) -->
707
- ${T&&e.formMode==="form"?c`
708
- <details class="config-diff">
709
- <summary class="config-diff__summary">
710
- <span>View ${$.length} pending change${$.length!==1?"s":""}</span>
711
- <svg class="config-diff__chevron" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">
712
- <polyline points="6 9 12 15 18 9"></polyline>
713
- </svg>
714
- </summary>
715
- <div class="config-diff__content">
716
- ${$.map(E=>c`
717
- <div class="config-diff__item">
718
- <div class="config-diff__path">${E.path}</div>
719
- <div class="config-diff__values">
720
- <span class="config-diff__from">${Uo(E.from)}</span>
721
- <span class="config-diff__arrow">→</span>
722
- <span class="config-diff__to">${Uo(E.to)}</span>
723
- </div>
724
- </div>
725
- `)}
726
- </div>
727
- </details>
728
- `:g}
729
-
730
- ${d&&e.formMode==="form"?c`
731
- <div class="config-section-hero">
732
- <div class="config-section-hero__icon">${Fo(e.activeSection??"")}</div>
733
- <div class="config-section-hero__text">
734
- <div class="config-section-hero__title">${d.label}</div>
735
- ${d.description?c`<div class="config-section-hero__desc">${d.description}</div>`:g}
736
- </div>
737
- </div>
738
- `:g}
739
-
740
- ${h?c`
741
- <div class="config-subnav">
742
- <button
743
- class="config-subnav__item ${w===null?"active":""}"
744
- @click=${()=>e.onSubsectionChange(Bo)}
745
- >
746
- All
747
- </button>
748
- ${u.map(E=>c`
749
- <button
750
- class="config-subnav__item ${w===E.key?"active":""}"
751
- title=${E.description||E.label}
752
- @click=${()=>e.onSubsectionChange(E.key)}
753
- >
754
- ${E.label}
755
- </button>
756
- `)}
757
- </div>
758
- `:g}
759
-
760
- <!-- Form content -->
761
- <div class="config-content">
762
- ${e.formMode==="form"?c`
763
- ${e.schemaLoading?c`<div class="config-loading">
764
- <div class="config-loading__spinner"></div>
765
- <span>Loading schema…</span>
766
- </div>`:Bp({schema:n.schema,uiHints:e.uiHints,value:e.formValue,disabled:e.loading||!e.formValue,unsupportedPaths:n.unsupportedPaths,onPatch:e.onFormPatch,searchQuery:e.searchQuery,activeSection:e.activeSection,activeSubsection:w})}
767
- ${s?c`<div class="callout danger" style="margin-top: 12px;">
768
- Form view can't safely edit some fields.
769
- Use Raw to avoid losing config entries.
770
- </div>`:g}
771
- `:c`
772
- <label class="field config-raw-field">
773
- <span>Raw JSON5</span>
774
- <textarea
775
- .value=${e.raw}
776
- @input=${E=>e.onRawChange(E.target.value)}
777
- ></textarea>
778
- </label>
779
- `}
780
- </div>
781
-
782
- ${e.issues.length>0?c`<div class="callout danger" style="margin-top: 12px;">
783
- <pre class="code-block">${JSON.stringify(e.issues,null,2)}</pre>
784
- </div>`:g}
785
- </main>
786
- </div>
787
- `}function Wp(e){if(!e&&e!==0)return"n/a";const t=Math.round(e/1e3);if(t<60)return`${t}s`;const n=Math.round(t/60);return n<60?`${n}m`:`${Math.round(n/60)}h`}function Gp(e,t){const n=t.snapshot,s=n?.channels;if(!n||!s)return!1;const i=s[e],o=typeof i?.configured=="boolean"&&i.configured,a=typeof i?.running=="boolean"&&i.running,l=typeof i?.connected=="boolean"&&i.connected,p=(n.channelAccounts?.[e]??[]).some(d=>d.configured||d.running||d.connected);return o||a||l||p}function Vp(e,t){return t?.[e]?.length??0}function hr(e,t){const n=Vp(e,t);return n<2?g:c`<div class="account-count">Accounts (${n})</div>`}function Yp(e,t){let n=e;for(const s of t){if(!n)return null;const i=de(n);if(i==="object"){const o=n.properties??{};if(typeof s=="string"&&o[s]){n=o[s];continue}const a=n.additionalProperties;if(typeof s=="string"&&a&&typeof a=="object"){n=a;continue}return null}if(i==="array"){if(typeof s!="number")return null;n=(Array.isArray(n.items)?n.items[0]:n.items)??null;continue}return null}return n}function Qp(e,t){const s=(e.channels??{})[t],i=e[t];return(s&&typeof s=="object"?s:null)??(i&&typeof i=="object"?i:null)??{}}function Jp(e){const t=fr(e.schema),n=t.schema;if(!n)return c`<div class="callout danger">Schema unavailable. Use Raw.</div>`;const s=Yp(n,["channels",e.channelId]);if(!s)return c`<div class="callout danger">Channel config schema unavailable.</div>`;const i=e.configValue??{},o=Qp(i,e.channelId);return c`
788
- <div class="config-form">
789
- ${be({schema:s,value:o,path:["channels",e.channelId],hints:e.uiHints,unsupported:new Set(t.unsupportedPaths),disabled:e.disabled,showLabel:!1,onPatch:e.onPatch})}
790
- </div>
791
- `}function we(e){const{channelId:t,props:n}=e,s=n.configSaving||n.configSchemaLoading;return c`
792
- <div style="margin-top: 16px;">
793
- ${n.configSchemaLoading?c`<div class="muted">Loading config schema…</div>`:Jp({channelId:t,configValue:n.configForm,schema:n.configSchema,uiHints:n.configUiHints,disabled:s,onPatch:n.onConfigPatch})}
794
- <div class="row" style="margin-top: 12px;">
795
- <button
796
- class="btn primary"
797
- ?disabled=${s||!n.configFormDirty}
798
- @click=${()=>n.onConfigSave()}
799
- >
800
- ${n.configSaving?"Saving…":"Save"}
801
- </button>
802
- <button
803
- class="btn"
804
- ?disabled=${s}
805
- @click=${()=>n.onConfigReload()}
806
- >
807
- Reload
808
- </button>
809
- </div>
810
- </div>
811
- `}function Zp(e){const{props:t,discord:n,accountCountLabel:s}=e;return c`
812
- <div class="card">
813
- <div class="card-title">Discord</div>
814
- <div class="card-sub">Bot status and channel configuration.</div>
815
- ${s}
816
-
817
- <div class="status-list" style="margin-top: 16px;">
818
- <div>
819
- <span class="label">Configured</span>
820
- <span>${n?.configured?"Yes":"No"}</span>
821
- </div>
822
- <div>
823
- <span class="label">Running</span>
824
- <span>${n?.running?"Yes":"No"}</span>
825
- </div>
826
- <div>
827
- <span class="label">Last start</span>
828
- <span>${n?.lastStartAt?O(n.lastStartAt):"n/a"}</span>
829
- </div>
830
- <div>
831
- <span class="label">Last probe</span>
832
- <span>${n?.lastProbeAt?O(n.lastProbeAt):"n/a"}</span>
833
- </div>
834
- </div>
835
-
836
- ${n?.lastError?c`<div class="callout danger" style="margin-top: 12px;">
837
- ${n.lastError}
838
- </div>`:g}
839
-
840
- ${n?.probe?c`<div class="callout" style="margin-top: 12px;">
841
- Probe ${n.probe.ok?"ok":"failed"} ·
842
- ${n.probe.status??""} ${n.probe.error??""}
843
- </div>`:g}
844
-
845
- ${we({channelId:"discord",props:t})}
846
-
847
- <div class="row" style="margin-top: 12px;">
848
- <button class="btn" @click=${()=>t.onRefresh(!0)}>
849
- Probe
850
- </button>
851
- </div>
852
- </div>
853
- `}function Xp(e){const{props:t,googleChat:n,accountCountLabel:s}=e;return c`
854
- <div class="card">
855
- <div class="card-title">Google Chat</div>
856
- <div class="card-sub">Chat API webhook status and channel configuration.</div>
857
- ${s}
858
-
859
- <div class="status-list" style="margin-top: 16px;">
860
- <div>
861
- <span class="label">Configured</span>
862
- <span>${n?n.configured?"Yes":"No":"n/a"}</span>
863
- </div>
864
- <div>
865
- <span class="label">Running</span>
866
- <span>${n?n.running?"Yes":"No":"n/a"}</span>
867
- </div>
868
- <div>
869
- <span class="label">Credential</span>
870
- <span>${n?.credentialSource??"n/a"}</span>
871
- </div>
872
- <div>
873
- <span class="label">Audience</span>
874
- <span>
875
- ${n?.audienceType?`${n.audienceType}${n.audience?` · ${n.audience}`:""}`:"n/a"}
876
- </span>
877
- </div>
878
- <div>
879
- <span class="label">Last start</span>
880
- <span>${n?.lastStartAt?O(n.lastStartAt):"n/a"}</span>
881
- </div>
882
- <div>
883
- <span class="label">Last probe</span>
884
- <span>${n?.lastProbeAt?O(n.lastProbeAt):"n/a"}</span>
885
- </div>
886
- </div>
887
-
888
- ${n?.lastError?c`<div class="callout danger" style="margin-top: 12px;">
889
- ${n.lastError}
890
- </div>`:g}
891
-
892
- ${n?.probe?c`<div class="callout" style="margin-top: 12px;">
893
- Probe ${n.probe.ok?"ok":"failed"} ·
894
- ${n.probe.status??""} ${n.probe.error??""}
895
- </div>`:g}
896
-
897
- ${we({channelId:"googlechat",props:t})}
898
-
899
- <div class="row" style="margin-top: 12px;">
900
- <button class="btn" @click=${()=>t.onRefresh(!0)}>
901
- Probe
902
- </button>
903
- </div>
904
- </div>
905
- `}function ef(e){const{props:t,imessage:n,accountCountLabel:s}=e;return c`
906
- <div class="card">
907
- <div class="card-title">iMessage</div>
908
- <div class="card-sub">macOS bridge status and channel configuration.</div>
909
- ${s}
910
-
911
- <div class="status-list" style="margin-top: 16px;">
912
- <div>
913
- <span class="label">Configured</span>
914
- <span>${n?.configured?"Yes":"No"}</span>
915
- </div>
916
- <div>
917
- <span class="label">Running</span>
918
- <span>${n?.running?"Yes":"No"}</span>
919
- </div>
920
- <div>
921
- <span class="label">Last start</span>
922
- <span>${n?.lastStartAt?O(n.lastStartAt):"n/a"}</span>
923
- </div>
924
- <div>
925
- <span class="label">Last probe</span>
926
- <span>${n?.lastProbeAt?O(n.lastProbeAt):"n/a"}</span>
927
- </div>
928
- </div>
929
-
930
- ${n?.lastError?c`<div class="callout danger" style="margin-top: 12px;">
931
- ${n.lastError}
932
- </div>`:g}
933
-
934
- ${n?.probe?c`<div class="callout" style="margin-top: 12px;">
935
- Probe ${n.probe.ok?"ok":"failed"} ·
936
- ${n.probe.error??""}
937
- </div>`:g}
938
-
939
- ${we({channelId:"imessage",props:t})}
940
-
941
- <div class="row" style="margin-top: 12px;">
942
- <button class="btn" @click=${()=>t.onRefresh(!0)}>
943
- Probe
944
- </button>
945
- </div>
946
- </div>
947
- `}function tf(e){const{values:t,original:n}=e;return t.name!==n.name||t.displayName!==n.displayName||t.about!==n.about||t.picture!==n.picture||t.banner!==n.banner||t.website!==n.website||t.nip05!==n.nip05||t.lud16!==n.lud16}function nf(e){const{state:t,callbacks:n,accountId:s}=e,i=tf(t),o=(l,r,p={})=>{const{type:d="text",placeholder:u,maxLength:h,help:v}=p,w=t.values[l]??"",$=t.fieldErrors[l],x=`nostr-profile-${l}`;return d==="textarea"?c`
948
- <div class="form-field" style="margin-bottom: 12px;">
949
- <label for="${x}" style="display: block; margin-bottom: 4px; font-weight: 500;">
950
- ${r}
951
- </label>
952
- <textarea
953
- id="${x}"
954
- .value=${w}
955
- placeholder=${u??""}
956
- maxlength=${h??2e3}
957
- rows="3"
958
- style="width: 100%; padding: 8px; border: 1px solid var(--border-color); border-radius: 4px; resize: vertical; font-family: inherit;"
959
- @input=${T=>{const R=T.target;n.onFieldChange(l,R.value)}}
960
- ?disabled=${t.saving}
961
- ></textarea>
962
- ${v?c`<div style="font-size: 12px; color: var(--text-muted); margin-top: 2px;">${v}</div>`:g}
963
- ${$?c`<div style="font-size: 12px; color: var(--danger-color); margin-top: 2px;">${$}</div>`:g}
964
- </div>
965
- `:c`
966
- <div class="form-field" style="margin-bottom: 12px;">
967
- <label for="${x}" style="display: block; margin-bottom: 4px; font-weight: 500;">
968
- ${r}
969
- </label>
970
- <input
971
- id="${x}"
972
- type=${d}
973
- .value=${w}
974
- placeholder=${u??""}
975
- maxlength=${h??256}
976
- style="width: 100%; padding: 8px; border: 1px solid var(--border-color); border-radius: 4px;"
977
- @input=${T=>{const R=T.target;n.onFieldChange(l,R.value)}}
978
- ?disabled=${t.saving}
979
- />
980
- ${v?c`<div style="font-size: 12px; color: var(--text-muted); margin-top: 2px;">${v}</div>`:g}
981
- ${$?c`<div style="font-size: 12px; color: var(--danger-color); margin-top: 2px;">${$}</div>`:g}
982
- </div>
983
- `},a=()=>{const l=t.values.picture;return l?c`
984
- <div style="margin-bottom: 12px;">
985
- <img
986
- src=${l}
987
- alt="Profile picture preview"
988
- style="max-width: 80px; max-height: 80px; border-radius: 50%; object-fit: cover; border: 2px solid var(--border-color);"
989
- @error=${r=>{const p=r.target;p.style.display="none"}}
990
- @load=${r=>{const p=r.target;p.style.display="block"}}
991
- />
992
- </div>
993
- `:g};return c`
994
- <div class="nostr-profile-form" style="padding: 16px; background: var(--bg-secondary); border-radius: 8px; margin-top: 12px;">
995
- <div style="display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px;">
996
- <div style="font-weight: 600; font-size: 16px;">Edit Profile</div>
997
- <div style="font-size: 12px; color: var(--text-muted);">Account: ${s}</div>
998
- </div>
999
-
1000
- ${t.error?c`<div class="callout danger" style="margin-bottom: 12px;">${t.error}</div>`:g}
1001
-
1002
- ${t.success?c`<div class="callout success" style="margin-bottom: 12px;">${t.success}</div>`:g}
1003
-
1004
- ${a()}
1005
-
1006
- ${o("name","Username",{placeholder:"satoshi",maxLength:256,help:"Short username (e.g., satoshi)"})}
1007
-
1008
- ${o("displayName","Display Name",{placeholder:"Satoshi Nakamoto",maxLength:256,help:"Your full display name"})}
1009
-
1010
- ${o("about","Bio",{type:"textarea",placeholder:"Tell people about yourself...",maxLength:2e3,help:"A brief bio or description"})}
1011
-
1012
- ${o("picture","Avatar URL",{type:"url",placeholder:"https://example.com/avatar.jpg",help:"HTTPS URL to your profile picture"})}
1013
-
1014
- ${t.showAdvanced?c`
1015
- <div style="border-top: 1px solid var(--border-color); padding-top: 12px; margin-top: 12px;">
1016
- <div style="font-weight: 500; margin-bottom: 12px; color: var(--text-muted);">Advanced</div>
1017
-
1018
- ${o("banner","Banner URL",{type:"url",placeholder:"https://example.com/banner.jpg",help:"HTTPS URL to a banner image"})}
1019
-
1020
- ${o("website","Website",{type:"url",placeholder:"https://example.com",help:"Your personal website"})}
1021
-
1022
- ${o("nip05","NIP-05 Identifier",{placeholder:"you@example.com",help:"Verifiable identifier (e.g., you@domain.com)"})}
1023
-
1024
- ${o("lud16","Lightning Address",{placeholder:"you@getalby.com",help:"Lightning address for tips (LUD-16)"})}
1025
- </div>
1026
- `:g}
1027
-
1028
- <div style="display: flex; gap: 8px; margin-top: 16px; flex-wrap: wrap;">
1029
- <button
1030
- class="btn primary"
1031
- @click=${n.onSave}
1032
- ?disabled=${t.saving||!i}
1033
- >
1034
- ${t.saving?"Saving...":"Save & Publish"}
1035
- </button>
1036
-
1037
- <button
1038
- class="btn"
1039
- @click=${n.onImport}
1040
- ?disabled=${t.importing||t.saving}
1041
- >
1042
- ${t.importing?"Importing...":"Import from Relays"}
1043
- </button>
1044
-
1045
- <button
1046
- class="btn"
1047
- @click=${n.onToggleAdvanced}
1048
- >
1049
- ${t.showAdvanced?"Hide Advanced":"Show Advanced"}
1050
- </button>
1051
-
1052
- <button
1053
- class="btn"
1054
- @click=${n.onCancel}
1055
- ?disabled=${t.saving}
1056
- >
1057
- Cancel
1058
- </button>
1059
- </div>
1060
-
1061
- ${i?c`<div style="font-size: 12px; color: var(--warning-color); margin-top: 8px;">
1062
- You have unsaved changes
1063
- </div>`:g}
1064
- </div>
1065
- `}function sf(e){const t={name:e?.name??"",displayName:e?.displayName??"",about:e?.about??"",picture:e?.picture??"",banner:e?.banner??"",website:e?.website??"",nip05:e?.nip05??"",lud16:e?.lud16??""};return{values:t,original:{...t},saving:!1,importing:!1,error:null,success:null,fieldErrors:{},showAdvanced:!!(e?.banner||e?.website||e?.nip05||e?.lud16)}}function Ko(e){return e?e.length<=20?e:`${e.slice(0,8)}...${e.slice(-8)}`:"n/a"}function of(e){const{props:t,nostr:n,nostrAccounts:s,accountCountLabel:i,profileFormState:o,profileFormCallbacks:a,onEditProfile:l}=e,r=s[0],p=n?.configured??r?.configured??!1,d=n?.running??r?.running??!1,u=n?.publicKey??r?.publicKey,h=n?.lastStartAt??r?.lastStartAt??null,v=n?.lastError??r?.lastError??null,w=s.length>1,$=o!=null,x=R=>{const P=R.publicKey,I=R.profile,C=I?.displayName??I?.name??R.name??R.accountId;return c`
1066
- <div class="account-card">
1067
- <div class="account-card-header">
1068
- <div class="account-card-title">${C}</div>
1069
- <div class="account-card-id">${R.accountId}</div>
1070
- </div>
1071
- <div class="status-list account-card-status">
1072
- <div>
1073
- <span class="label">Running</span>
1074
- <span>${R.running?"Yes":"No"}</span>
1075
- </div>
1076
- <div>
1077
- <span class="label">Configured</span>
1078
- <span>${R.configured?"Yes":"No"}</span>
1079
- </div>
1080
- <div>
1081
- <span class="label">Public Key</span>
1082
- <span class="monospace" title="${P??""}">${Ko(P)}</span>
1083
- </div>
1084
- <div>
1085
- <span class="label">Last inbound</span>
1086
- <span>${R.lastInboundAt?O(R.lastInboundAt):"n/a"}</span>
1087
- </div>
1088
- ${R.lastError?c`
1089
- <div class="account-card-error">${R.lastError}</div>
1090
- `:g}
1091
- </div>
1092
- </div>
1093
- `},T=()=>{if($&&a)return nf({state:o,callbacks:a,accountId:s[0]?.accountId??"default"});const R=r?.profile??n?.profile,{name:P,displayName:I,about:C,picture:E,nip05:ue}=R??{},yn=P||I||C||E||ue;return c`
1094
- <div style="margin-top: 16px; padding: 12px; background: var(--bg-secondary); border-radius: 8px;">
1095
- <div style="display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px;">
1096
- <div style="font-weight: 500;">Profile</div>
1097
- ${p?c`
1098
- <button
1099
- class="btn btn-sm"
1100
- @click=${l}
1101
- style="font-size: 12px; padding: 4px 8px;"
1102
- >
1103
- Edit Profile
1104
- </button>
1105
- `:g}
1106
- </div>
1107
- ${yn?c`
1108
- <div class="status-list">
1109
- ${E?c`
1110
- <div style="margin-bottom: 8px;">
1111
- <img
1112
- src=${E}
1113
- alt="Profile picture"
1114
- style="width: 48px; height: 48px; border-radius: 50%; object-fit: cover; border: 2px solid var(--border-color);"
1115
- @error=${wn=>{wn.target.style.display="none"}}
1116
- />
1117
- </div>
1118
- `:g}
1119
- ${P?c`<div><span class="label">Name</span><span>${P}</span></div>`:g}
1120
- ${I?c`<div><span class="label">Display Name</span><span>${I}</span></div>`:g}
1121
- ${C?c`<div><span class="label">About</span><span style="max-width: 300px; overflow: hidden; text-overflow: ellipsis;">${C}</span></div>`:g}
1122
- ${ue?c`<div><span class="label">NIP-05</span><span>${ue}</span></div>`:g}
1123
- </div>
1124
- `:c`
1125
- <div style="color: var(--text-muted); font-size: 13px;">
1126
- No profile set. Click "Edit Profile" to add your name, bio, and avatar.
1127
- </div>
1128
- `}
1129
- </div>
1130
- `};return c`
1131
- <div class="card">
1132
- <div class="card-title">Nostr</div>
1133
- <div class="card-sub">Decentralized DMs via Nostr relays (NIP-04).</div>
1134
- ${i}
1135
-
1136
- ${w?c`
1137
- <div class="account-card-list">
1138
- ${s.map(R=>x(R))}
1139
- </div>
1140
- `:c`
1141
- <div class="status-list" style="margin-top: 16px;">
1142
- <div>
1143
- <span class="label">Configured</span>
1144
- <span>${p?"Yes":"No"}</span>
1145
- </div>
1146
- <div>
1147
- <span class="label">Running</span>
1148
- <span>${d?"Yes":"No"}</span>
1149
- </div>
1150
- <div>
1151
- <span class="label">Public Key</span>
1152
- <span class="monospace" title="${u??""}"
1153
- >${Ko(u)}</span
1154
- >
1155
- </div>
1156
- <div>
1157
- <span class="label">Last start</span>
1158
- <span>${h?O(h):"n/a"}</span>
1159
- </div>
1160
- </div>
1161
- `}
1162
-
1163
- ${v?c`<div class="callout danger" style="margin-top: 12px;">${v}</div>`:g}
1164
-
1165
- ${T()}
1166
-
1167
- ${we({channelId:"nostr",props:t})}
1168
-
1169
- <div class="row" style="margin-top: 12px;">
1170
- <button class="btn" @click=${()=>t.onRefresh(!1)}>Refresh</button>
1171
- </div>
1172
- </div>
1173
- `}function af(e){const{props:t,signal:n,accountCountLabel:s}=e;return c`
1174
- <div class="card">
1175
- <div class="card-title">Signal</div>
1176
- <div class="card-sub">signal-cli status and channel configuration.</div>
1177
- ${s}
1178
-
1179
- <div class="status-list" style="margin-top: 16px;">
1180
- <div>
1181
- <span class="label">Configured</span>
1182
- <span>${n?.configured?"Yes":"No"}</span>
1183
- </div>
1184
- <div>
1185
- <span class="label">Running</span>
1186
- <span>${n?.running?"Yes":"No"}</span>
1187
- </div>
1188
- <div>
1189
- <span class="label">Base URL</span>
1190
- <span>${n?.baseUrl??"n/a"}</span>
1191
- </div>
1192
- <div>
1193
- <span class="label">Last start</span>
1194
- <span>${n?.lastStartAt?O(n.lastStartAt):"n/a"}</span>
1195
- </div>
1196
- <div>
1197
- <span class="label">Last probe</span>
1198
- <span>${n?.lastProbeAt?O(n.lastProbeAt):"n/a"}</span>
1199
- </div>
1200
- </div>
1201
-
1202
- ${n?.lastError?c`<div class="callout danger" style="margin-top: 12px;">
1203
- ${n.lastError}
1204
- </div>`:g}
1205
-
1206
- ${n?.probe?c`<div class="callout" style="margin-top: 12px;">
1207
- Probe ${n.probe.ok?"ok":"failed"} ·
1208
- ${n.probe.status??""} ${n.probe.error??""}
1209
- </div>`:g}
1210
-
1211
- ${we({channelId:"signal",props:t})}
1212
-
1213
- <div class="row" style="margin-top: 12px;">
1214
- <button class="btn" @click=${()=>t.onRefresh(!0)}>
1215
- Probe
1216
- </button>
1217
- </div>
1218
- </div>
1219
- `}function rf(e){const{props:t,slack:n,accountCountLabel:s}=e;return c`
1220
- <div class="card">
1221
- <div class="card-title">Slack</div>
1222
- <div class="card-sub">Socket mode status and channel configuration.</div>
1223
- ${s}
1224
-
1225
- <div class="status-list" style="margin-top: 16px;">
1226
- <div>
1227
- <span class="label">Configured</span>
1228
- <span>${n?.configured?"Yes":"No"}</span>
1229
- </div>
1230
- <div>
1231
- <span class="label">Running</span>
1232
- <span>${n?.running?"Yes":"No"}</span>
1233
- </div>
1234
- <div>
1235
- <span class="label">Last start</span>
1236
- <span>${n?.lastStartAt?O(n.lastStartAt):"n/a"}</span>
1237
- </div>
1238
- <div>
1239
- <span class="label">Last probe</span>
1240
- <span>${n?.lastProbeAt?O(n.lastProbeAt):"n/a"}</span>
1241
- </div>
1242
- </div>
1243
-
1244
- ${n?.lastError?c`<div class="callout danger" style="margin-top: 12px;">
1245
- ${n.lastError}
1246
- </div>`:g}
1247
-
1248
- ${n?.probe?c`<div class="callout" style="margin-top: 12px;">
1249
- Probe ${n.probe.ok?"ok":"failed"} ·
1250
- ${n.probe.status??""} ${n.probe.error??""}
1251
- </div>`:g}
1252
-
1253
- ${we({channelId:"slack",props:t})}
1254
-
1255
- <div class="row" style="margin-top: 12px;">
1256
- <button class="btn" @click=${()=>t.onRefresh(!0)}>
1257
- Probe
1258
- </button>
1259
- </div>
1260
- </div>
1261
- `}function lf(e){const{props:t,telegram:n,telegramAccounts:s,accountCountLabel:i}=e,o=s.length>1,a=l=>{const p=l.probe?.bot?.username,d=l.name||l.accountId;return c`
1262
- <div class="account-card">
1263
- <div class="account-card-header">
1264
- <div class="account-card-title">
1265
- ${p?`@${p}`:d}
1266
- </div>
1267
- <div class="account-card-id">${l.accountId}</div>
1268
- </div>
1269
- <div class="status-list account-card-status">
1270
- <div>
1271
- <span class="label">Running</span>
1272
- <span>${l.running?"Yes":"No"}</span>
1273
- </div>
1274
- <div>
1275
- <span class="label">Configured</span>
1276
- <span>${l.configured?"Yes":"No"}</span>
1277
- </div>
1278
- <div>
1279
- <span class="label">Last inbound</span>
1280
- <span>${l.lastInboundAt?O(l.lastInboundAt):"n/a"}</span>
1281
- </div>
1282
- ${l.lastError?c`
1283
- <div class="account-card-error">
1284
- ${l.lastError}
1285
- </div>
1286
- `:g}
1287
- </div>
1288
- </div>
1289
- `};return c`
1290
- <div class="card">
1291
- <div class="card-title">Telegram</div>
1292
- <div class="card-sub">Bot status and channel configuration.</div>
1293
- ${i}
1294
-
1295
- ${o?c`
1296
- <div class="account-card-list">
1297
- ${s.map(l=>a(l))}
1298
- </div>
1299
- `:c`
1300
- <div class="status-list" style="margin-top: 16px;">
1301
- <div>
1302
- <span class="label">Configured</span>
1303
- <span>${n?.configured?"Yes":"No"}</span>
1304
- </div>
1305
- <div>
1306
- <span class="label">Running</span>
1307
- <span>${n?.running?"Yes":"No"}</span>
1308
- </div>
1309
- <div>
1310
- <span class="label">Mode</span>
1311
- <span>${n?.mode??"n/a"}</span>
1312
- </div>
1313
- <div>
1314
- <span class="label">Last start</span>
1315
- <span>${n?.lastStartAt?O(n.lastStartAt):"n/a"}</span>
1316
- </div>
1317
- <div>
1318
- <span class="label">Last probe</span>
1319
- <span>${n?.lastProbeAt?O(n.lastProbeAt):"n/a"}</span>
1320
- </div>
1321
- </div>
1322
- `}
1323
-
1324
- ${n?.lastError?c`<div class="callout danger" style="margin-top: 12px;">
1325
- ${n.lastError}
1326
- </div>`:g}
1327
-
1328
- ${n?.probe?c`<div class="callout" style="margin-top: 12px;">
1329
- Probe ${n.probe.ok?"ok":"failed"} ·
1330
- ${n.probe.status??""} ${n.probe.error??""}
1331
- </div>`:g}
1332
-
1333
- ${we({channelId:"telegram",props:t})}
1334
-
1335
- <div class="row" style="margin-top: 12px;">
1336
- <button class="btn" @click=${()=>t.onRefresh(!0)}>
1337
- Probe
1338
- </button>
1339
- </div>
1340
- </div>
1341
- `}function cf(e){const{props:t,whatsapp:n,accountCountLabel:s}=e;return c`
1342
- <div class="card">
1343
- <div class="card-title">WhatsApp</div>
1344
- <div class="card-sub">Link WhatsApp Web and monitor connection health.</div>
1345
- ${s}
1346
-
1347
- <div class="status-list" style="margin-top: 16px;">
1348
- <div>
1349
- <span class="label">Configured</span>
1350
- <span>${n?.configured?"Yes":"No"}</span>
1351
- </div>
1352
- <div>
1353
- <span class="label">Linked</span>
1354
- <span>${n?.linked?"Yes":"No"}</span>
1355
- </div>
1356
- <div>
1357
- <span class="label">Running</span>
1358
- <span>${n?.running?"Yes":"No"}</span>
1359
- </div>
1360
- <div>
1361
- <span class="label">Connected</span>
1362
- <span>${n?.connected?"Yes":"No"}</span>
1363
- </div>
1364
- <div>
1365
- <span class="label">Last connect</span>
1366
- <span>
1367
- ${n?.lastConnectedAt?O(n.lastConnectedAt):"n/a"}
1368
- </span>
1369
- </div>
1370
- <div>
1371
- <span class="label">Last message</span>
1372
- <span>
1373
- ${n?.lastMessageAt?O(n.lastMessageAt):"n/a"}
1374
- </span>
1375
- </div>
1376
- <div>
1377
- <span class="label">Auth age</span>
1378
- <span>
1379
- ${n?.authAgeMs!=null?Wp(n.authAgeMs):"n/a"}
1380
- </span>
1381
- </div>
1382
- </div>
1383
-
1384
- ${n?.lastError?c`<div class="callout danger" style="margin-top: 12px;">
1385
- ${n.lastError}
1386
- </div>`:g}
1387
-
1388
- ${t.whatsappMessage?c`<div class="callout" style="margin-top: 12px;">
1389
- ${t.whatsappMessage}
1390
- </div>`:g}
1391
-
1392
- ${t.whatsappQrDataUrl?c`<div class="qr-wrap">
1393
- <img src=${t.whatsappQrDataUrl} alt="WhatsApp QR" />
1394
- </div>`:g}
1395
-
1396
- <div class="row" style="margin-top: 14px; flex-wrap: wrap;">
1397
- <button
1398
- class="btn primary"
1399
- ?disabled=${t.whatsappBusy}
1400
- @click=${()=>t.onWhatsAppStart(!1)}
1401
- >
1402
- ${t.whatsappBusy?"Working…":"Show QR"}
1403
- </button>
1404
- <button
1405
- class="btn"
1406
- ?disabled=${t.whatsappBusy}
1407
- @click=${()=>t.onWhatsAppStart(!0)}
1408
- >
1409
- Relink
1410
- </button>
1411
- <button
1412
- class="btn"
1413
- ?disabled=${t.whatsappBusy}
1414
- @click=${()=>t.onWhatsAppWait()}
1415
- >
1416
- Wait for scan
1417
- </button>
1418
- <button
1419
- class="btn danger"
1420
- ?disabled=${t.whatsappBusy}
1421
- @click=${()=>t.onWhatsAppLogout()}
1422
- >
1423
- Logout
1424
- </button>
1425
- <button class="btn" @click=${()=>t.onRefresh(!0)}>
1426
- Refresh
1427
- </button>
1428
- </div>
1429
-
1430
- ${we({channelId:"whatsapp",props:t})}
1431
- </div>
1432
- `}function df(e){const t=e.snapshot?.channels,n=t?.whatsapp??void 0,s=t?.telegram??void 0,i=t?.discord??null;t?.googlechat;const o=t?.slack??null,a=t?.signal??null,l=t?.imessage??null,r=t?.nostr??null,d=uf(e.snapshot).map((u,h)=>({key:u,enabled:Gp(u,e),order:h})).sort((u,h)=>u.enabled!==h.enabled?u.enabled?-1:1:u.order-h.order);return c`
1433
- <section class="grid grid-cols-2">
1434
- ${d.map(u=>pf(u.key,e,{whatsapp:n,telegram:s,discord:i,slack:o,signal:a,imessage:l,nostr:r,channelAccounts:e.snapshot?.channelAccounts??null}))}
1435
- </section>
1436
-
1437
- <section class="card" style="margin-top: 18px;">
1438
- <div class="row" style="justify-content: space-between;">
1439
- <div>
1440
- <div class="card-title">Channel health</div>
1441
- <div class="card-sub">Channel status snapshots from the gateway.</div>
1442
- </div>
1443
- <div class="muted">${e.lastSuccessAt?O(e.lastSuccessAt):"n/a"}</div>
1444
- </div>
1445
- ${e.lastError?c`<div class="callout danger" style="margin-top: 12px;">
1446
- ${e.lastError}
1447
- </div>`:g}
1448
- <pre class="code-block" style="margin-top: 12px;">
1449
- ${e.snapshot?JSON.stringify(e.snapshot,null,2):"No snapshot yet."}
1450
- </pre>
1451
- </section>
1452
- `}function uf(e){return e?.channelMeta?.length?e.channelMeta.map(t=>t.id):e?.channelOrder?.length?e.channelOrder:["whatsapp","telegram","discord","googlechat","slack","signal","imessage","nostr"]}function pf(e,t,n){const s=hr(e,n.channelAccounts);switch(e){case"whatsapp":return cf({props:t,whatsapp:n.whatsapp,accountCountLabel:s});case"telegram":return lf({props:t,telegram:n.telegram,telegramAccounts:n.channelAccounts?.telegram??[],accountCountLabel:s});case"discord":return Zp({props:t,discord:n.discord,accountCountLabel:s});case"googlechat":return Xp({props:t,accountCountLabel:s});case"slack":return rf({props:t,slack:n.slack,accountCountLabel:s});case"signal":return af({props:t,signal:n.signal,accountCountLabel:s});case"imessage":return ef({props:t,imessage:n.imessage,accountCountLabel:s});case"nostr":{const i=n.channelAccounts?.nostr??[],o=i[0],a=o?.accountId??"default",l=o?.profile??null,r=t.nostrProfileAccountId===a?t.nostrProfileFormState:null,p=r?{onFieldChange:t.onNostrProfileFieldChange,onSave:t.onNostrProfileSave,onImport:t.onNostrProfileImport,onCancel:t.onNostrProfileCancel,onToggleAdvanced:t.onNostrProfileToggleAdvanced}:null;return of({props:t,nostr:n.nostr,nostrAccounts:i,accountCountLabel:s,profileFormState:r,profileFormCallbacks:p,onEditProfile:()=>t.onNostrProfileEdit(a,l)})}default:return ff(e,t,n.channelAccounts??{})}}function ff(e,t,n){const s=gf(t.snapshot,e),i=t.snapshot?.channels?.[e],o=typeof i?.configured=="boolean"?i.configured:void 0,a=typeof i?.running=="boolean"?i.running:void 0,l=typeof i?.connected=="boolean"?i.connected:void 0,r=typeof i?.lastError=="string"?i.lastError:void 0,p=n[e]??[],d=hr(e,n);return c`
1453
- <div class="card">
1454
- <div class="card-title">${s}</div>
1455
- <div class="card-sub">Channel status and configuration.</div>
1456
- ${d}
1457
-
1458
- ${p.length>0?c`
1459
- <div class="account-card-list">
1460
- ${p.map(u=>yf(u))}
1461
- </div>
1462
- `:c`
1463
- <div class="status-list" style="margin-top: 16px;">
1464
- <div>
1465
- <span class="label">Configured</span>
1466
- <span>${o==null?"n/a":o?"Yes":"No"}</span>
1467
- </div>
1468
- <div>
1469
- <span class="label">Running</span>
1470
- <span>${a==null?"n/a":a?"Yes":"No"}</span>
1471
- </div>
1472
- <div>
1473
- <span class="label">Connected</span>
1474
- <span>${l==null?"n/a":l?"Yes":"No"}</span>
1475
- </div>
1476
- </div>
1477
- `}
1478
-
1479
- ${r?c`<div class="callout danger" style="margin-top: 12px;">
1480
- ${r}
1481
- </div>`:g}
1482
-
1483
- ${we({channelId:e,props:t})}
1484
- </div>
1485
- `}function hf(e){return e?.channelMeta?.length?Object.fromEntries(e.channelMeta.map(t=>[t.id,t])):{}}function gf(e,t){return hf(e)[t]?.label??e?.channelLabels?.[t]??t}const vf=600*1e3;function gr(e){return e.lastInboundAt?Date.now()-e.lastInboundAt<vf:!1}function mf(e){return e.running?"Yes":gr(e)?"Active":"No"}function bf(e){return e.connected===!0?"Yes":e.connected===!1?"No":gr(e)?"Active":"n/a"}function yf(e){const t=mf(e),n=bf(e);return c`
1486
- <div class="account-card">
1487
- <div class="account-card-header">
1488
- <div class="account-card-title">${e.name||e.accountId}</div>
1489
- <div class="account-card-id">${e.accountId}</div>
1490
- </div>
1491
- <div class="status-list account-card-status">
1492
- <div>
1493
- <span class="label">Running</span>
1494
- <span>${t}</span>
1495
- </div>
1496
- <div>
1497
- <span class="label">Configured</span>
1498
- <span>${e.configured?"Yes":"No"}</span>
1499
- </div>
1500
- <div>
1501
- <span class="label">Connected</span>
1502
- <span>${n}</span>
1503
- </div>
1504
- <div>
1505
- <span class="label">Last inbound</span>
1506
- <span>${e.lastInboundAt?O(e.lastInboundAt):"n/a"}</span>
1507
- </div>
1508
- ${e.lastError?c`
1509
- <div class="account-card-error">
1510
- ${e.lastError}
1511
- </div>
1512
- `:g}
1513
- </div>
1514
- </div>
1515
- `}function wf(e){const t=e.host??"unknown",n=e.ip?`(${e.ip})`:"",s=e.mode??"",i=e.version??"";return`${t} ${n} ${s} ${i}`.trim()}function $f(e){const t=e.ts??null;return t?O(t):"n/a"}function vr(e){return e?`${xt(e)} (${O(e)})`:"n/a"}function kf(e){if(e.totalTokens==null)return"n/a";const t=e.totalTokens??0,n=e.contextTokens??0;return n?`${t} / ${n}`:String(t)}function xf(e){if(e==null)return"";try{return JSON.stringify(e,null,2)}catch{return String(e)}}function Af(e){const t=e.state??{},n=t.nextRunAtMs?xt(t.nextRunAtMs):"n/a",s=t.lastRunAtMs?xt(t.lastRunAtMs):"n/a";return`${t.lastStatus??"n/a"} · next ${n} · last ${s}`}function Sf(e){const t=e.schedule;return t.kind==="at"?`At ${xt(t.atMs)}`:t.kind==="every"?`Every ${aa(t.everyMs)}`:`Cron ${t.expr}${t.tz?` (${t.tz})`:""}`}function _f(e){const t=e.payload;return t.kind==="systemEvent"?`System: ${t.text}`:`Agent: ${t.message}`}function Tf(e){const t=["last",...e.channels.filter(Boolean)],n=e.form.channel?.trim();n&&!t.includes(n)&&t.push(n);const s=new Set;return t.filter(i=>s.has(i)?!1:(s.add(i),!0))}function Cf(e,t){if(t==="last")return"last";const n=e.channelMeta?.find(s=>s.id===t);return n?.label?n.label:e.channelLabels?.[t]??t}function Ef(e){const t=Tf(e);return c`
1516
- <section class="grid grid-cols-2">
1517
- <div class="card">
1518
- <div class="card-title">Scheduler</div>
1519
- <div class="card-sub">Gateway-owned cron scheduler status.</div>
1520
- <div class="stat-grid" style="margin-top: 16px;">
1521
- <div class="stat">
1522
- <div class="stat-label">Enabled</div>
1523
- <div class="stat-value">
1524
- ${e.status?e.status.enabled?"Yes":"No":"n/a"}
1525
- </div>
1526
- </div>
1527
- <div class="stat">
1528
- <div class="stat-label">Jobs</div>
1529
- <div class="stat-value">${e.status?.jobs??"n/a"}</div>
1530
- </div>
1531
- <div class="stat">
1532
- <div class="stat-label">Next wake</div>
1533
- <div class="stat-value">${vr(e.status?.nextWakeAtMs??null)}</div>
1534
- </div>
1535
- </div>
1536
- <div class="row" style="margin-top: 12px;">
1537
- <button class="btn" ?disabled=${e.loading} @click=${e.onRefresh}>
1538
- ${e.loading?"Refreshing…":"Refresh"}
1539
- </button>
1540
- ${e.error?c`<span class="muted">${e.error}</span>`:g}
1541
- </div>
1542
- </div>
1543
-
1544
- <div class="card">
1545
- <div class="card-title">New Job</div>
1546
- <div class="card-sub">Create a scheduled wakeup or agent run.</div>
1547
- <div class="form-grid" style="margin-top: 16px;">
1548
- <label class="field">
1549
- <span>Name</span>
1550
- <input
1551
- .value=${e.form.name}
1552
- @input=${n=>e.onFormChange({name:n.target.value})}
1553
- />
1554
- </label>
1555
- <label class="field">
1556
- <span>Description</span>
1557
- <input
1558
- .value=${e.form.description}
1559
- @input=${n=>e.onFormChange({description:n.target.value})}
1560
- />
1561
- </label>
1562
- <label class="field">
1563
- <span>Agent ID</span>
1564
- <input
1565
- .value=${e.form.agentId}
1566
- @input=${n=>e.onFormChange({agentId:n.target.value})}
1567
- placeholder="default"
1568
- />
1569
- </label>
1570
- <label class="field checkbox">
1571
- <span>Enabled</span>
1572
- <input
1573
- type="checkbox"
1574
- .checked=${e.form.enabled}
1575
- @change=${n=>e.onFormChange({enabled:n.target.checked})}
1576
- />
1577
- </label>
1578
- <label class="field">
1579
- <span>Schedule</span>
1580
- <select
1581
- .value=${e.form.scheduleKind}
1582
- @change=${n=>e.onFormChange({scheduleKind:n.target.value})}
1583
- >
1584
- <option value="every">Every</option>
1585
- <option value="at">At</option>
1586
- <option value="cron">Cron</option>
1587
- </select>
1588
- </label>
1589
- </div>
1590
- ${If(e)}
1591
- <div class="form-grid" style="margin-top: 12px;">
1592
- <label class="field">
1593
- <span>Session</span>
1594
- <select
1595
- .value=${e.form.sessionTarget}
1596
- @change=${n=>e.onFormChange({sessionTarget:n.target.value})}
1597
- >
1598
- <option value="main">Main</option>
1599
- <option value="isolated">Isolated</option>
1600
- </select>
1601
- </label>
1602
- <label class="field">
1603
- <span>Wake mode</span>
1604
- <select
1605
- .value=${e.form.wakeMode}
1606
- @change=${n=>e.onFormChange({wakeMode:n.target.value})}
1607
- >
1608
- <option value="next-heartbeat">Next heartbeat</option>
1609
- <option value="now">Now</option>
1610
- </select>
1611
- </label>
1612
- <label class="field">
1613
- <span>Payload</span>
1614
- <select
1615
- .value=${e.form.payloadKind}
1616
- @change=${n=>e.onFormChange({payloadKind:n.target.value})}
1617
- >
1618
- <option value="systemEvent">System event</option>
1619
- <option value="agentTurn">Agent turn</option>
1620
- </select>
1621
- </label>
1622
- </div>
1623
- <label class="field" style="margin-top: 12px;">
1624
- <span>${e.form.payloadKind==="systemEvent"?"System text":"Agent message"}</span>
1625
- <textarea
1626
- .value=${e.form.payloadText}
1627
- @input=${n=>e.onFormChange({payloadText:n.target.value})}
1628
- rows="4"
1629
- ></textarea>
1630
- </label>
1631
- ${e.form.payloadKind==="agentTurn"?c`
1632
- <div class="form-grid" style="margin-top: 12px;">
1633
- <label class="field checkbox">
1634
- <span>Deliver</span>
1635
- <input
1636
- type="checkbox"
1637
- .checked=${e.form.deliver}
1638
- @change=${n=>e.onFormChange({deliver:n.target.checked})}
1639
- />
1640
- </label>
1641
- <label class="field">
1642
- <span>Channel</span>
1643
- <select
1644
- .value=${e.form.channel||"last"}
1645
- @change=${n=>e.onFormChange({channel:n.target.value})}
1646
- >
1647
- ${t.map(n=>c`<option value=${n}>
1648
- ${Cf(e,n)}
1649
- </option>`)}
1650
- </select>
1651
- </label>
1652
- <label class="field">
1653
- <span>To</span>
1654
- <input
1655
- .value=${e.form.to}
1656
- @input=${n=>e.onFormChange({to:n.target.value})}
1657
- placeholder="+1555… or chat id"
1658
- />
1659
- </label>
1660
- <label class="field">
1661
- <span>Timeout (seconds)</span>
1662
- <input
1663
- .value=${e.form.timeoutSeconds}
1664
- @input=${n=>e.onFormChange({timeoutSeconds:n.target.value})}
1665
- />
1666
- </label>
1667
- ${e.form.sessionTarget==="isolated"?c`
1668
- <label class="field">
1669
- <span>Post to main prefix</span>
1670
- <input
1671
- .value=${e.form.postToMainPrefix}
1672
- @input=${n=>e.onFormChange({postToMainPrefix:n.target.value})}
1673
- />
1674
- </label>
1675
- `:g}
1676
- </div>
1677
- `:g}
1678
- <div class="row" style="margin-top: 14px;">
1679
- <button class="btn primary" ?disabled=${e.busy} @click=${e.onAdd}>
1680
- ${e.busy?"Saving…":"Add job"}
1681
- </button>
1682
- </div>
1683
- </div>
1684
- </section>
1685
-
1686
- <section class="card" style="margin-top: 18px;">
1687
- <div class="card-title">Jobs</div>
1688
- <div class="card-sub">All scheduled jobs stored in the gateway.</div>
1689
- ${e.jobs.length===0?c`<div class="muted" style="margin-top: 12px;">No jobs yet.</div>`:c`
1690
- <div class="list" style="margin-top: 12px;">
1691
- ${e.jobs.map(n=>Rf(n,e))}
1692
- </div>
1693
- `}
1694
- </section>
1695
-
1696
- <section class="card" style="margin-top: 18px;">
1697
- <div class="card-title">Run history</div>
1698
- <div class="card-sub">Latest runs for ${e.runsJobId??"(select a job)"}.</div>
1699
- ${e.runsJobId==null?c`
1700
- <div class="muted" style="margin-top: 12px;">
1701
- Select a job to inspect run history.
1702
- </div>
1703
- `:e.runs.length===0?c`<div class="muted" style="margin-top: 12px;">No runs yet.</div>`:c`
1704
- <div class="list" style="margin-top: 12px;">
1705
- ${e.runs.map(n=>Lf(n))}
1706
- </div>
1707
- `}
1708
- </section>
1709
- `}function If(e){const t=e.form;return t.scheduleKind==="at"?c`
1710
- <label class="field" style="margin-top: 12px;">
1711
- <span>Run at</span>
1712
- <input
1713
- type="datetime-local"
1714
- .value=${t.scheduleAt}
1715
- @input=${n=>e.onFormChange({scheduleAt:n.target.value})}
1716
- />
1717
- </label>
1718
- `:t.scheduleKind==="every"?c`
1719
- <div class="form-grid" style="margin-top: 12px;">
1720
- <label class="field">
1721
- <span>Every</span>
1722
- <input
1723
- .value=${t.everyAmount}
1724
- @input=${n=>e.onFormChange({everyAmount:n.target.value})}
1725
- />
1726
- </label>
1727
- <label class="field">
1728
- <span>Unit</span>
1729
- <select
1730
- .value=${t.everyUnit}
1731
- @change=${n=>e.onFormChange({everyUnit:n.target.value})}
1732
- >
1733
- <option value="minutes">Minutes</option>
1734
- <option value="hours">Hours</option>
1735
- <option value="days">Days</option>
1736
- </select>
1737
- </label>
1738
- </div>
1739
- `:c`
1740
- <div class="form-grid" style="margin-top: 12px;">
1741
- <label class="field">
1742
- <span>Expression</span>
1743
- <input
1744
- .value=${t.cronExpr}
1745
- @input=${n=>e.onFormChange({cronExpr:n.target.value})}
1746
- />
1747
- </label>
1748
- <label class="field">
1749
- <span>Timezone (optional)</span>
1750
- <input
1751
- .value=${t.cronTz}
1752
- @input=${n=>e.onFormChange({cronTz:n.target.value})}
1753
- />
1754
- </label>
1755
- </div>
1756
- `}function Rf(e,t){const s=`list-item list-item-clickable${t.runsJobId===e.id?" list-item-selected":""}`;return c`
1757
- <div class=${s} @click=${()=>t.onLoadRuns(e.id)}>
1758
- <div class="list-main">
1759
- <div class="list-title">${e.name}</div>
1760
- <div class="list-sub">${Sf(e)}</div>
1761
- <div class="muted">${_f(e)}</div>
1762
- ${e.agentId?c`<div class="muted">Agent: ${e.agentId}</div>`:g}
1763
- <div class="chip-row" style="margin-top: 6px;">
1764
- <span class="chip">${e.enabled?"enabled":"disabled"}</span>
1765
- <span class="chip">${e.sessionTarget}</span>
1766
- <span class="chip">${e.wakeMode}</span>
1767
- </div>
1768
- </div>
1769
- <div class="list-meta">
1770
- <div>${Af(e)}</div>
1771
- <div class="row" style="justify-content: flex-end; margin-top: 8px;">
1772
- <button
1773
- class="btn"
1774
- ?disabled=${t.busy}
1775
- @click=${i=>{i.stopPropagation(),t.onToggle(e,!e.enabled)}}
1776
- >
1777
- ${e.enabled?"Disable":"Enable"}
1778
- </button>
1779
- <button
1780
- class="btn"
1781
- ?disabled=${t.busy}
1782
- @click=${i=>{i.stopPropagation(),t.onRun(e)}}
1783
- >
1784
- Run
1785
- </button>
1786
- <button
1787
- class="btn"
1788
- ?disabled=${t.busy}
1789
- @click=${i=>{i.stopPropagation(),t.onLoadRuns(e.id)}}
1790
- >
1791
- Runs
1792
- </button>
1793
- <button
1794
- class="btn danger"
1795
- ?disabled=${t.busy}
1796
- @click=${i=>{i.stopPropagation(),t.onRemove(e)}}
1797
- >
1798
- Remove
1799
- </button>
1800
- </div>
1801
- </div>
1802
- </div>
1803
- `}function Lf(e){return c`
1804
- <div class="list-item">
1805
- <div class="list-main">
1806
- <div class="list-title">${e.status}</div>
1807
- <div class="list-sub">${e.summary??""}</div>
1808
- </div>
1809
- <div class="list-meta">
1810
- <div>${xt(e.ts)}</div>
1811
- <div class="muted">${e.durationMs??0}ms</div>
1812
- ${e.error?c`<div class="muted">${e.error}</div>`:g}
1813
- </div>
1814
- </div>
1815
- `}function Mf(e){return c`
1816
- <section class="grid grid-cols-2">
1817
- <div class="card">
1818
- <div class="row" style="justify-content: space-between;">
1819
- <div>
1820
- <div class="card-title">Snapshots</div>
1821
- <div class="card-sub">Status, health, and heartbeat data.</div>
1822
- </div>
1823
- <button class="btn" ?disabled=${e.loading} @click=${e.onRefresh}>
1824
- ${e.loading?"Refreshing…":"Refresh"}
1825
- </button>
1826
- </div>
1827
- <div class="stack" style="margin-top: 12px;">
1828
- <div>
1829
- <div class="muted">Status</div>
1830
- <pre class="code-block">${JSON.stringify(e.status??{},null,2)}</pre>
1831
- </div>
1832
- <div>
1833
- <div class="muted">Health</div>
1834
- <pre class="code-block">${JSON.stringify(e.health??{},null,2)}</pre>
1835
- </div>
1836
- <div>
1837
- <div class="muted">Last heartbeat</div>
1838
- <pre class="code-block">${JSON.stringify(e.heartbeat??{},null,2)}</pre>
1839
- </div>
1840
- </div>
1841
- </div>
1842
-
1843
- <div class="card">
1844
- <div class="card-title">Manual RPC</div>
1845
- <div class="card-sub">Send a raw gateway method with JSON params.</div>
1846
- <div class="form-grid" style="margin-top: 16px;">
1847
- <label class="field">
1848
- <span>Method</span>
1849
- <input
1850
- .value=${e.callMethod}
1851
- @input=${t=>e.onCallMethodChange(t.target.value)}
1852
- placeholder="system-presence"
1853
- />
1854
- </label>
1855
- <label class="field">
1856
- <span>Params (JSON)</span>
1857
- <textarea
1858
- .value=${e.callParams}
1859
- @input=${t=>e.onCallParamsChange(t.target.value)}
1860
- rows="6"
1861
- ></textarea>
1862
- </label>
1863
- </div>
1864
- <div class="row" style="margin-top: 12px;">
1865
- <button class="btn primary" @click=${e.onCall}>Call</button>
1866
- </div>
1867
- ${e.callError?c`<div class="callout danger" style="margin-top: 12px;">
1868
- ${e.callError}
1869
- </div>`:g}
1870
- ${e.callResult?c`<pre class="code-block" style="margin-top: 12px;">${e.callResult}</pre>`:g}
1871
- </div>
1872
- </section>
1873
-
1874
- <section class="card" style="margin-top: 18px;">
1875
- <div class="card-title">Models</div>
1876
- <div class="card-sub">Catalog from models.list.</div>
1877
- <pre class="code-block" style="margin-top: 12px;">${JSON.stringify(e.models??[],null,2)}</pre>
1878
- </section>
1879
-
1880
- <section class="card" style="margin-top: 18px;">
1881
- <div class="card-title">Event Log</div>
1882
- <div class="card-sub">Latest gateway events.</div>
1883
- ${e.eventLog.length===0?c`<div class="muted" style="margin-top: 12px;">No events yet.</div>`:c`
1884
- <div class="list" style="margin-top: 12px;">
1885
- ${e.eventLog.map(t=>c`
1886
- <div class="list-item">
1887
- <div class="list-main">
1888
- <div class="list-title">${t.event}</div>
1889
- <div class="list-sub">${new Date(t.ts).toLocaleTimeString()}</div>
1890
- </div>
1891
- <div class="list-meta">
1892
- <pre class="code-block">${xf(t.payload)}</pre>
1893
- </div>
1894
- </div>
1895
- `)}
1896
- </div>
1897
- `}
1898
- </section>
1899
- `}function Pf(e){return c`
1900
- <section class="card">
1901
- <div class="row" style="justify-content: space-between;">
1902
- <div>
1903
- <div class="card-title">Connected Instances</div>
1904
- <div class="card-sub">Presence beacons from the gateway and clients.</div>
1905
- </div>
1906
- <button class="btn" ?disabled=${e.loading} @click=${e.onRefresh}>
1907
- ${e.loading?"Loading…":"Refresh"}
1908
- </button>
1909
- </div>
1910
- ${e.lastError?c`<div class="callout danger" style="margin-top: 12px;">
1911
- ${e.lastError}
1912
- </div>`:g}
1913
- ${e.statusMessage?c`<div class="callout" style="margin-top: 12px;">
1914
- ${e.statusMessage}
1915
- </div>`:g}
1916
- <div class="list" style="margin-top: 16px;">
1917
- ${e.entries.length===0?c`<div class="muted">No instances reported yet.</div>`:e.entries.map(t=>Nf(t))}
1918
- </div>
1919
- </section>
1920
- `}function Nf(e){const t=e.lastInputSeconds!=null?`${e.lastInputSeconds}s ago`:"n/a",n=e.mode??"unknown",s=Array.isArray(e.roles)?e.roles.filter(Boolean):[],i=Array.isArray(e.scopes)?e.scopes.filter(Boolean):[],o=i.length>0?i.length>3?`${i.length} scopes`:`scopes: ${i.join(", ")}`:null;return c`
1921
- <div class="list-item">
1922
- <div class="list-main">
1923
- <div class="list-title">${e.host??"unknown host"}</div>
1924
- <div class="list-sub">${wf(e)}</div>
1925
- <div class="chip-row">
1926
- <span class="chip">${n}</span>
1927
- ${s.map(a=>c`<span class="chip">${a}</span>`)}
1928
- ${o?c`<span class="chip">${o}</span>`:g}
1929
- ${e.platform?c`<span class="chip">${e.platform}</span>`:g}
1930
- ${e.deviceFamily?c`<span class="chip">${e.deviceFamily}</span>`:g}
1931
- ${e.modelIdentifier?c`<span class="chip">${e.modelIdentifier}</span>`:g}
1932
- ${e.version?c`<span class="chip">${e.version}</span>`:g}
1933
- </div>
1934
- </div>
1935
- <div class="list-meta">
1936
- <div>${$f(e)}</div>
1937
- <div class="muted">Last input ${t}</div>
1938
- <div class="muted">Reason ${e.reason??""}</div>
1939
- </div>
1940
- </div>
1941
- `}const Ho=["trace","debug","info","warn","error","fatal"];function Of(e){if(!e)return"";const t=new Date(e);return Number.isNaN(t.getTime())?e:t.toLocaleTimeString()}function Df(e,t){return t?[e.message,e.subsystem,e.raw].filter(Boolean).join(" ").toLowerCase().includes(t):!0}function Bf(e){const t=e.filterText.trim().toLowerCase(),n=Ho.some(o=>!e.levelFilters[o]),s=e.entries.filter(o=>o.level&&!e.levelFilters[o.level]?!1:Df(o,t)),i=t||n?"filtered":"visible";return c`
1942
- <section class="card">
1943
- <div class="row" style="justify-content: space-between;">
1944
- <div>
1945
- <div class="card-title">Logs</div>
1946
- <div class="card-sub">Gateway file logs (JSONL).</div>
1947
- </div>
1948
- <div class="row" style="gap: 8px;">
1949
- <button class="btn" ?disabled=${e.loading} @click=${e.onRefresh}>
1950
- ${e.loading?"Loading…":"Refresh"}
1951
- </button>
1952
- <button
1953
- class="btn"
1954
- ?disabled=${s.length===0}
1955
- @click=${()=>e.onExport(s.map(o=>o.raw),i)}
1956
- >
1957
- Export ${i}
1958
- </button>
1959
- </div>
1960
- </div>
1961
-
1962
- <div class="filters" style="margin-top: 14px;">
1963
- <label class="field" style="min-width: 220px;">
1964
- <span>Filter</span>
1965
- <input
1966
- .value=${e.filterText}
1967
- @input=${o=>e.onFilterTextChange(o.target.value)}
1968
- placeholder="Search logs"
1969
- />
1970
- </label>
1971
- <label class="field checkbox">
1972
- <span>Auto-follow</span>
1973
- <input
1974
- type="checkbox"
1975
- .checked=${e.autoFollow}
1976
- @change=${o=>e.onToggleAutoFollow(o.target.checked)}
1977
- />
1978
- </label>
1979
- </div>
1980
-
1981
- <div class="chip-row" style="margin-top: 12px;">
1982
- ${Ho.map(o=>c`
1983
- <label class="chip log-chip ${o}">
1984
- <input
1985
- type="checkbox"
1986
- .checked=${e.levelFilters[o]}
1987
- @change=${a=>e.onLevelToggle(o,a.target.checked)}
1988
- />
1989
- <span>${o}</span>
1990
- </label>
1991
- `)}
1992
- </div>
1993
-
1994
- ${e.file?c`<div class="muted" style="margin-top: 10px;">File: ${e.file}</div>`:g}
1995
- ${e.truncated?c`<div class="callout" style="margin-top: 10px;">
1996
- Log output truncated; showing latest chunk.
1997
- </div>`:g}
1998
- ${e.error?c`<div class="callout danger" style="margin-top: 10px;">${e.error}</div>`:g}
1999
-
2000
- <div class="log-stream" style="margin-top: 12px;" @scroll=${e.onScroll}>
2001
- ${s.length===0?c`<div class="muted" style="padding: 12px;">No log entries.</div>`:s.map(o=>c`
2002
- <div class="log-row">
2003
- <div class="log-time mono">${Of(o.time)}</div>
2004
- <div class="log-level ${o.level??""}">${o.level??""}</div>
2005
- <div class="log-subsystem mono">${o.subsystem??""}</div>
2006
- <div class="log-message mono">${o.message??o.raw}</div>
2007
- </div>
2008
- `)}
2009
- </div>
2010
- </section>
2011
- `}function Ff(e){const t=qf(e),n=Jf(e);return c`
2012
- ${Xf(n)}
2013
- ${Zf(t)}
2014
- ${Uf(e)}
2015
- <section class="card">
2016
- <div class="row" style="justify-content: space-between;">
2017
- <div>
2018
- <div class="card-title">Nodes</div>
2019
- <div class="card-sub">Paired devices and live links.</div>
2020
- </div>
2021
- <button class="btn" ?disabled=${e.loading} @click=${e.onRefresh}>
2022
- ${e.loading?"Loading…":"Refresh"}
2023
- </button>
2024
- </div>
2025
- <div class="list" style="margin-top: 16px;">
2026
- ${e.nodes.length===0?c`<div class="muted">No nodes found.</div>`:e.nodes.map(s=>ch(s))}
2027
- </div>
2028
- </section>
2029
- `}function Uf(e){const t=e.devicesList??{pending:[],paired:[]},n=Array.isArray(t.pending)?t.pending:[],s=Array.isArray(t.paired)?t.paired:[];return c`
2030
- <section class="card">
2031
- <div class="row" style="justify-content: space-between;">
2032
- <div>
2033
- <div class="card-title">Devices</div>
2034
- <div class="card-sub">Pairing requests + role tokens.</div>
2035
- </div>
2036
- <button class="btn" ?disabled=${e.devicesLoading} @click=${e.onDevicesRefresh}>
2037
- ${e.devicesLoading?"Loading…":"Refresh"}
2038
- </button>
2039
- </div>
2040
- ${e.devicesError?c`<div class="callout danger" style="margin-top: 12px;">${e.devicesError}</div>`:g}
2041
- <div class="list" style="margin-top: 16px;">
2042
- ${n.length>0?c`
2043
- <div class="muted" style="margin-bottom: 8px;">Pending</div>
2044
- ${n.map(i=>Kf(i,e))}
2045
- `:g}
2046
- ${s.length>0?c`
2047
- <div class="muted" style="margin-top: 12px; margin-bottom: 8px;">Paired</div>
2048
- ${s.map(i=>Hf(i,e))}
2049
- `:g}
2050
- ${n.length===0&&s.length===0?c`<div class="muted">No paired devices.</div>`:g}
2051
- </div>
2052
- </section>
2053
- `}function Kf(e,t){const n=e.displayName?.trim()||e.deviceId,s=typeof e.ts=="number"?O(e.ts):"n/a",i=e.role?.trim()?`role: ${e.role}`:"role: -",o=e.isRepair?" · repair":"",a=e.remoteIp?` · ${e.remoteIp}`:"";return c`
2054
- <div class="list-item">
2055
- <div class="list-main">
2056
- <div class="list-title">${n}</div>
2057
- <div class="list-sub">${e.deviceId}${a}</div>
2058
- <div class="muted" style="margin-top: 6px;">
2059
- ${i} · requested ${s}${o}
2060
- </div>
2061
- </div>
2062
- <div class="list-meta">
2063
- <div class="row" style="justify-content: flex-end; gap: 8px; flex-wrap: wrap;">
2064
- <button class="btn btn--sm primary" @click=${()=>t.onDeviceApprove(e.requestId)}>
2065
- Approve
2066
- </button>
2067
- <button class="btn btn--sm" @click=${()=>t.onDeviceReject(e.requestId)}>
2068
- Reject
2069
- </button>
2070
- </div>
2071
- </div>
2072
- </div>
2073
- `}function Hf(e,t){const n=e.displayName?.trim()||e.deviceId,s=e.remoteIp?` · ${e.remoteIp}`:"",i=`roles: ${os(e.roles)}`,o=`scopes: ${os(e.scopes)}`,a=Array.isArray(e.tokens)?e.tokens:[];return c`
2074
- <div class="list-item">
2075
- <div class="list-main">
2076
- <div class="list-title">${n}</div>
2077
- <div class="list-sub">${e.deviceId}${s}</div>
2078
- <div class="muted" style="margin-top: 6px;">${i} · ${o}</div>
2079
- ${a.length===0?c`<div class="muted" style="margin-top: 6px;">Tokens: none</div>`:c`
2080
- <div class="muted" style="margin-top: 10px;">Tokens</div>
2081
- <div style="display: flex; flex-direction: column; gap: 8px; margin-top: 6px;">
2082
- ${a.map(l=>zf(e.deviceId,l,t))}
2083
- </div>
2084
- `}
2085
- </div>
2086
- </div>
2087
- `}function zf(e,t,n){const s=t.revokedAtMs?"revoked":"active",i=`scopes: ${os(t.scopes)}`,o=O(t.rotatedAtMs??t.createdAtMs??t.lastUsedAtMs??null);return c`
2088
- <div class="row" style="justify-content: space-between; gap: 8px;">
2089
- <div class="list-sub">${t.role} · ${s} · ${i} · ${o}</div>
2090
- <div class="row" style="justify-content: flex-end; gap: 6px; flex-wrap: wrap;">
2091
- <button
2092
- class="btn btn--sm"
2093
- @click=${()=>n.onDeviceRotate(e,t.role,t.scopes)}
2094
- >
2095
- Rotate
2096
- </button>
2097
- ${t.revokedAtMs?g:c`
2098
- <button
2099
- class="btn btn--sm danger"
2100
- @click=${()=>n.onDeviceRevoke(e,t.role)}
2101
- >
2102
- Revoke
2103
- </button>
2104
- `}
2105
- </div>
2106
- </div>
2107
- `}const xe="__defaults__",zo=[{value:"deny",label:"Deny"},{value:"allowlist",label:"Allowlist"},{value:"full",label:"Full"}],jf=[{value:"off",label:"Off"},{value:"on-miss",label:"On miss"},{value:"always",label:"Always"}];function qf(e){const t=e.configForm,n=ah(e.nodes),{defaultBinding:s,agents:i}=lh(t),o=!!t,a=e.configSaving||e.configFormMode==="raw";return{ready:o,disabled:a,configDirty:e.configDirty,configLoading:e.configLoading,configSaving:e.configSaving,defaultBinding:s,agents:i,nodes:n,onBindDefault:e.onBindDefault,onBindAgent:e.onBindAgent,onSave:e.onSaveBindings,onLoadConfig:e.onLoadConfig,formMode:e.configFormMode}}function jo(e){return e==="allowlist"||e==="full"||e==="deny"?e:"deny"}function Wf(e){return e==="always"||e==="off"||e==="on-miss"?e:"on-miss"}function Gf(e){const t=e?.defaults??{};return{security:jo(t.security),ask:Wf(t.ask),askFallback:jo(t.askFallback??"deny"),autoAllowSkills:!!(t.autoAllowSkills??!1)}}function Vf(e){const t=e?.agents??{},n=Array.isArray(t.list)?t.list:[],s=[];return n.forEach(i=>{if(!i||typeof i!="object")return;const o=i,a=typeof o.id=="string"?o.id.trim():"";if(!a)return;const l=typeof o.name=="string"?o.name.trim():void 0,r=o.default===!0;s.push({id:a,name:l||void 0,isDefault:r})}),s}function Yf(e,t){const n=Vf(e),s=Object.keys(t?.agents??{}),i=new Map;n.forEach(a=>i.set(a.id,a)),s.forEach(a=>{i.has(a)||i.set(a,{id:a})});const o=Array.from(i.values());return o.length===0&&o.push({id:"main",isDefault:!0}),o.sort((a,l)=>{if(a.isDefault&&!l.isDefault)return-1;if(!a.isDefault&&l.isDefault)return 1;const r=a.name?.trim()?a.name:a.id,p=l.name?.trim()?l.name:l.id;return r.localeCompare(p)}),o}function Qf(e,t){return e===xe?xe:e&&t.some(n=>n.id===e)?e:xe}function Jf(e){const t=e.execApprovalsForm??e.execApprovalsSnapshot?.file??null,n=!!t,s=Gf(t),i=Yf(e.configForm,t),o=rh(e.nodes),a=e.execApprovalsTarget;let l=a==="node"&&e.execApprovalsTargetNodeId?e.execApprovalsTargetNodeId:null;a==="node"&&l&&!o.some(u=>u.id===l)&&(l=null);const r=Qf(e.execApprovalsSelectedAgent,i),p=r!==xe?(t?.agents??{})[r]??null:null,d=Array.isArray(p?.allowlist)?p.allowlist??[]:[];return{ready:n,disabled:e.execApprovalsSaving||e.execApprovalsLoading,dirty:e.execApprovalsDirty,loading:e.execApprovalsLoading,saving:e.execApprovalsSaving,form:t,defaults:s,selectedScope:r,selectedAgent:p,agents:i,allowlist:d,target:a,targetNodeId:l,targetNodes:o,onSelectScope:e.onExecApprovalsSelectAgent,onSelectTarget:e.onExecApprovalsTargetChange,onPatch:e.onExecApprovalsPatch,onRemove:e.onExecApprovalsRemove,onLoad:e.onLoadExecApprovals,onSave:e.onSaveExecApprovals}}function Zf(e){const t=e.nodes.length>0,n=e.defaultBinding??"";return c`
2108
- <section class="card">
2109
- <div class="row" style="justify-content: space-between; align-items: center;">
2110
- <div>
2111
- <div class="card-title">Exec node binding</div>
2112
- <div class="card-sub">
2113
- Pin agents to a specific node when using <span class="mono">exec host=node</span>.
2114
- </div>
2115
- </div>
2116
- <button
2117
- class="btn"
2118
- ?disabled=${e.disabled||!e.configDirty}
2119
- @click=${e.onSave}
2120
- >
2121
- ${e.configSaving?"Saving…":"Save"}
2122
- </button>
2123
- </div>
2124
-
2125
- ${e.formMode==="raw"?c`<div class="callout warn" style="margin-top: 12px;">
2126
- Switch the Config tab to <strong>Form</strong> mode to edit bindings here.
2127
- </div>`:g}
2128
-
2129
- ${e.ready?c`
2130
- <div class="list" style="margin-top: 16px;">
2131
- <div class="list-item">
2132
- <div class="list-main">
2133
- <div class="list-title">Default binding</div>
2134
- <div class="list-sub">Used when agents do not override a node binding.</div>
2135
- </div>
2136
- <div class="list-meta">
2137
- <label class="field">
2138
- <span>Node</span>
2139
- <select
2140
- ?disabled=${e.disabled||!t}
2141
- @change=${s=>{const o=s.target.value.trim();e.onBindDefault(o||null)}}
2142
- >
2143
- <option value="" ?selected=${n===""}>Any node</option>
2144
- ${e.nodes.map(s=>c`<option
2145
- value=${s.id}
2146
- ?selected=${n===s.id}
2147
- >
2148
- ${s.label}
2149
- </option>`)}
2150
- </select>
2151
- </label>
2152
- ${t?g:c`<div class="muted">No nodes with system.run available.</div>`}
2153
- </div>
2154
- </div>
2155
-
2156
- ${e.agents.length===0?c`<div class="muted">No agents found.</div>`:e.agents.map(s=>oh(s,e))}
2157
- </div>
2158
- `:c`<div class="row" style="margin-top: 12px; gap: 12px;">
2159
- <div class="muted">Load config to edit bindings.</div>
2160
- <button class="btn" ?disabled=${e.configLoading} @click=${e.onLoadConfig}>
2161
- ${e.configLoading?"Loading…":"Load config"}
2162
- </button>
2163
- </div>`}
2164
- </section>
2165
- `}function Xf(e){const t=e.ready,n=e.target!=="node"||!!e.targetNodeId;return c`
2166
- <section class="card">
2167
- <div class="row" style="justify-content: space-between; align-items: center;">
2168
- <div>
2169
- <div class="card-title">Exec approvals</div>
2170
- <div class="card-sub">
2171
- Allowlist and approval policy for <span class="mono">exec host=gateway/node</span>.
2172
- </div>
2173
- </div>
2174
- <button
2175
- class="btn"
2176
- ?disabled=${e.disabled||!e.dirty||!n}
2177
- @click=${e.onSave}
2178
- >
2179
- ${e.saving?"Saving…":"Save"}
2180
- </button>
2181
- </div>
2182
-
2183
- ${eh(e)}
2184
-
2185
- ${t?c`
2186
- ${th(e)}
2187
- ${nh(e)}
2188
- ${e.selectedScope===xe?g:sh(e)}
2189
- `:c`<div class="row" style="margin-top: 12px; gap: 12px;">
2190
- <div class="muted">Load exec approvals to edit allowlists.</div>
2191
- <button class="btn" ?disabled=${e.loading||!n} @click=${e.onLoad}>
2192
- ${e.loading?"Loading…":"Load approvals"}
2193
- </button>
2194
- </div>`}
2195
- </section>
2196
- `}function eh(e){const t=e.targetNodes.length>0,n=e.targetNodeId??"";return c`
2197
- <div class="list" style="margin-top: 12px;">
2198
- <div class="list-item">
2199
- <div class="list-main">
2200
- <div class="list-title">Target</div>
2201
- <div class="list-sub">
2202
- Gateway edits local approvals; node edits the selected node.
2203
- </div>
2204
- </div>
2205
- <div class="list-meta">
2206
- <label class="field">
2207
- <span>Host</span>
2208
- <select
2209
- ?disabled=${e.disabled}
2210
- @change=${s=>{if(s.target.value==="node"){const a=e.targetNodes[0]?.id??null;e.onSelectTarget("node",n||a)}else e.onSelectTarget("gateway",null)}}
2211
- >
2212
- <option value="gateway" ?selected=${e.target==="gateway"}>Gateway</option>
2213
- <option value="node" ?selected=${e.target==="node"}>Node</option>
2214
- </select>
2215
- </label>
2216
- ${e.target==="node"?c`
2217
- <label class="field">
2218
- <span>Node</span>
2219
- <select
2220
- ?disabled=${e.disabled||!t}
2221
- @change=${s=>{const o=s.target.value.trim();e.onSelectTarget("node",o||null)}}
2222
- >
2223
- <option value="" ?selected=${n===""}>Select node</option>
2224
- ${e.targetNodes.map(s=>c`<option
2225
- value=${s.id}
2226
- ?selected=${n===s.id}
2227
- >
2228
- ${s.label}
2229
- </option>`)}
2230
- </select>
2231
- </label>
2232
- `:g}
2233
- </div>
2234
- </div>
2235
- ${e.target==="node"&&!t?c`<div class="muted">No nodes advertise exec approvals yet.</div>`:g}
2236
- </div>
2237
- `}function th(e){return c`
2238
- <div class="row" style="margin-top: 12px; gap: 8px; flex-wrap: wrap;">
2239
- <span class="label">Scope</span>
2240
- <div class="row" style="gap: 8px; flex-wrap: wrap;">
2241
- <button
2242
- class="btn btn--sm ${e.selectedScope===xe?"active":""}"
2243
- @click=${()=>e.onSelectScope(xe)}
2244
- >
2245
- Defaults
2246
- </button>
2247
- ${e.agents.map(t=>{const n=t.name?.trim()?`${t.name} (${t.id})`:t.id;return c`
2248
- <button
2249
- class="btn btn--sm ${e.selectedScope===t.id?"active":""}"
2250
- @click=${()=>e.onSelectScope(t.id)}
2251
- >
2252
- ${n}
2253
- </button>
2254
- `})}
2255
- </div>
2256
- </div>
2257
- `}function nh(e){const t=e.selectedScope===xe,n=e.defaults,s=e.selectedAgent??{},i=t?["defaults"]:["agents",e.selectedScope],o=typeof s.security=="string"?s.security:void 0,a=typeof s.ask=="string"?s.ask:void 0,l=typeof s.askFallback=="string"?s.askFallback:void 0,r=t?n.security:o??"__default__",p=t?n.ask:a??"__default__",d=t?n.askFallback:l??"__default__",u=typeof s.autoAllowSkills=="boolean"?s.autoAllowSkills:void 0,h=u??n.autoAllowSkills,v=u==null;return c`
2258
- <div class="list" style="margin-top: 16px;">
2259
- <div class="list-item">
2260
- <div class="list-main">
2261
- <div class="list-title">Security</div>
2262
- <div class="list-sub">
2263
- ${t?"Default security mode.":`Default: ${n.security}.`}
2264
- </div>
2265
- </div>
2266
- <div class="list-meta">
2267
- <label class="field">
2268
- <span>Mode</span>
2269
- <select
2270
- ?disabled=${e.disabled}
2271
- @change=${w=>{const x=w.target.value;!t&&x==="__default__"?e.onRemove([...i,"security"]):e.onPatch([...i,"security"],x)}}
2272
- >
2273
- ${t?g:c`<option value="__default__" ?selected=${r==="__default__"}>
2274
- Use default (${n.security})
2275
- </option>`}
2276
- ${zo.map(w=>c`<option
2277
- value=${w.value}
2278
- ?selected=${r===w.value}
2279
- >
2280
- ${w.label}
2281
- </option>`)}
2282
- </select>
2283
- </label>
2284
- </div>
2285
- </div>
2286
-
2287
- <div class="list-item">
2288
- <div class="list-main">
2289
- <div class="list-title">Ask</div>
2290
- <div class="list-sub">
2291
- ${t?"Default prompt policy.":`Default: ${n.ask}.`}
2292
- </div>
2293
- </div>
2294
- <div class="list-meta">
2295
- <label class="field">
2296
- <span>Mode</span>
2297
- <select
2298
- ?disabled=${e.disabled}
2299
- @change=${w=>{const x=w.target.value;!t&&x==="__default__"?e.onRemove([...i,"ask"]):e.onPatch([...i,"ask"],x)}}
2300
- >
2301
- ${t?g:c`<option value="__default__" ?selected=${p==="__default__"}>
2302
- Use default (${n.ask})
2303
- </option>`}
2304
- ${jf.map(w=>c`<option
2305
- value=${w.value}
2306
- ?selected=${p===w.value}
2307
- >
2308
- ${w.label}
2309
- </option>`)}
2310
- </select>
2311
- </label>
2312
- </div>
2313
- </div>
2314
-
2315
- <div class="list-item">
2316
- <div class="list-main">
2317
- <div class="list-title">Ask fallback</div>
2318
- <div class="list-sub">
2319
- ${t?"Applied when the UI prompt is unavailable.":`Default: ${n.askFallback}.`}
2320
- </div>
2321
- </div>
2322
- <div class="list-meta">
2323
- <label class="field">
2324
- <span>Fallback</span>
2325
- <select
2326
- ?disabled=${e.disabled}
2327
- @change=${w=>{const x=w.target.value;!t&&x==="__default__"?e.onRemove([...i,"askFallback"]):e.onPatch([...i,"askFallback"],x)}}
2328
- >
2329
- ${t?g:c`<option value="__default__" ?selected=${d==="__default__"}>
2330
- Use default (${n.askFallback})
2331
- </option>`}
2332
- ${zo.map(w=>c`<option
2333
- value=${w.value}
2334
- ?selected=${d===w.value}
2335
- >
2336
- ${w.label}
2337
- </option>`)}
2338
- </select>
2339
- </label>
2340
- </div>
2341
- </div>
2342
-
2343
- <div class="list-item">
2344
- <div class="list-main">
2345
- <div class="list-title">Auto-allow skill CLIs</div>
2346
- <div class="list-sub">
2347
- ${t?"Allow skill executables listed by the Gateway.":v?`Using default (${n.autoAllowSkills?"on":"off"}).`:`Override (${h?"on":"off"}).`}
2348
- </div>
2349
- </div>
2350
- <div class="list-meta">
2351
- <label class="field">
2352
- <span>Enabled</span>
2353
- <input
2354
- type="checkbox"
2355
- ?disabled=${e.disabled}
2356
- .checked=${h}
2357
- @change=${w=>{const $=w.target;e.onPatch([...i,"autoAllowSkills"],$.checked)}}
2358
- />
2359
- </label>
2360
- ${!t&&!v?c`<button
2361
- class="btn btn--sm"
2362
- ?disabled=${e.disabled}
2363
- @click=${()=>e.onRemove([...i,"autoAllowSkills"])}
2364
- >
2365
- Use default
2366
- </button>`:g}
2367
- </div>
2368
- </div>
2369
- </div>
2370
- `}function sh(e){const t=["agents",e.selectedScope,"allowlist"],n=e.allowlist;return c`
2371
- <div class="row" style="margin-top: 18px; justify-content: space-between;">
2372
- <div>
2373
- <div class="card-title">Allowlist</div>
2374
- <div class="card-sub">Case-insensitive glob patterns.</div>
2375
- </div>
2376
- <button
2377
- class="btn btn--sm"
2378
- ?disabled=${e.disabled}
2379
- @click=${()=>{const s=[...n,{pattern:""}];e.onPatch(t,s)}}
2380
- >
2381
- Add pattern
2382
- </button>
2383
- </div>
2384
- <div class="list" style="margin-top: 12px;">
2385
- ${n.length===0?c`<div class="muted">No allowlist entries yet.</div>`:n.map((s,i)=>ih(e,s,i))}
2386
- </div>
2387
- `}function ih(e,t,n){const s=t.lastUsedAt?O(t.lastUsedAt):"never",i=t.lastUsedCommand?as(t.lastUsedCommand,120):null,o=t.lastResolvedPath?as(t.lastResolvedPath,120):null;return c`
2388
- <div class="list-item">
2389
- <div class="list-main">
2390
- <div class="list-title">${t.pattern?.trim()?t.pattern:"New pattern"}</div>
2391
- <div class="list-sub">Last used: ${s}</div>
2392
- ${i?c`<div class="list-sub mono">${i}</div>`:g}
2393
- ${o?c`<div class="list-sub mono">${o}</div>`:g}
2394
- </div>
2395
- <div class="list-meta">
2396
- <label class="field">
2397
- <span>Pattern</span>
2398
- <input
2399
- type="text"
2400
- .value=${t.pattern??""}
2401
- ?disabled=${e.disabled}
2402
- @input=${a=>{const l=a.target;e.onPatch(["agents",e.selectedScope,"allowlist",n,"pattern"],l.value)}}
2403
- />
2404
- </label>
2405
- <button
2406
- class="btn btn--sm danger"
2407
- ?disabled=${e.disabled}
2408
- @click=${()=>{if(e.allowlist.length<=1){e.onRemove(["agents",e.selectedScope,"allowlist"]);return}e.onRemove(["agents",e.selectedScope,"allowlist",n])}}
2409
- >
2410
- Remove
2411
- </button>
2412
- </div>
2413
- </div>
2414
- `}function oh(e,t){const n=e.binding??"__default__",s=e.name?.trim()?`${e.name} (${e.id})`:e.id,i=t.nodes.length>0;return c`
2415
- <div class="list-item">
2416
- <div class="list-main">
2417
- <div class="list-title">${s}</div>
2418
- <div class="list-sub">
2419
- ${e.isDefault?"default agent":"agent"} ·
2420
- ${n==="__default__"?`uses default (${t.defaultBinding??"any"})`:`override: ${e.binding}`}
2421
- </div>
2422
- </div>
2423
- <div class="list-meta">
2424
- <label class="field">
2425
- <span>Binding</span>
2426
- <select
2427
- ?disabled=${t.disabled||!i}
2428
- @change=${o=>{const l=o.target.value.trim();t.onBindAgent(e.index,l==="__default__"?null:l)}}
2429
- >
2430
- <option value="__default__" ?selected=${n==="__default__"}>
2431
- Use default
2432
- </option>
2433
- ${t.nodes.map(o=>c`<option
2434
- value=${o.id}
2435
- ?selected=${n===o.id}
2436
- >
2437
- ${o.label}
2438
- </option>`)}
2439
- </select>
2440
- </label>
2441
- </div>
2442
- </div>
2443
- `}function ah(e){const t=[];for(const n of e){if(!(Array.isArray(n.commands)?n.commands:[]).some(l=>String(l)==="system.run"))continue;const o=typeof n.nodeId=="string"?n.nodeId.trim():"";if(!o)continue;const a=typeof n.displayName=="string"&&n.displayName.trim()?n.displayName.trim():o;t.push({id:o,label:a===o?o:`${a} · ${o}`})}return t.sort((n,s)=>n.label.localeCompare(s.label)),t}function rh(e){const t=[];for(const n of e){if(!(Array.isArray(n.commands)?n.commands:[]).some(l=>String(l)==="system.execApprovals.get"||String(l)==="system.execApprovals.set"))continue;const o=typeof n.nodeId=="string"?n.nodeId.trim():"";if(!o)continue;const a=typeof n.displayName=="string"&&n.displayName.trim()?n.displayName.trim():o;t.push({id:o,label:a===o?o:`${a} · ${o}`})}return t.sort((n,s)=>n.label.localeCompare(s.label)),t}function lh(e){const t={id:"main",name:void 0,index:0,isDefault:!0,binding:null};if(!e||typeof e!="object")return{defaultBinding:null,agents:[t]};const s=(e.tools??{}).exec??{},i=typeof s.node=="string"&&s.node.trim()?s.node.trim():null,o=e.agents??{},a=Array.isArray(o.list)?o.list:[];if(a.length===0)return{defaultBinding:i,agents:[t]};const l=[];return a.forEach((r,p)=>{if(!r||typeof r!="object")return;const d=r,u=typeof d.id=="string"?d.id.trim():"";if(!u)return;const h=typeof d.name=="string"?d.name.trim():void 0,v=d.default===!0,$=(d.tools??{}).exec??{},x=typeof $.node=="string"&&$.node.trim()?$.node.trim():null;l.push({id:u,name:h||void 0,index:p,isDefault:v,binding:x})}),l.length===0&&l.push(t),{defaultBinding:i,agents:l}}function ch(e){const t=!!e.connected,n=!!e.paired,s=typeof e.displayName=="string"&&e.displayName.trim()||(typeof e.nodeId=="string"?e.nodeId:"unknown"),i=Array.isArray(e.caps)?e.caps:[],o=Array.isArray(e.commands)?e.commands:[];return c`
2444
- <div class="list-item">
2445
- <div class="list-main">
2446
- <div class="list-title">${s}</div>
2447
- <div class="list-sub">
2448
- ${typeof e.nodeId=="string"?e.nodeId:""}
2449
- ${typeof e.remoteIp=="string"?` · ${e.remoteIp}`:""}
2450
- ${typeof e.version=="string"?` · ${e.version}`:""}
2451
- </div>
2452
- <div class="chip-row" style="margin-top: 6px;">
2453
- <span class="chip">${n?"paired":"unpaired"}</span>
2454
- <span class="chip ${t?"chip-ok":"chip-warn"}">
2455
- ${t?"connected":"offline"}
2456
- </span>
2457
- ${i.slice(0,12).map(a=>c`<span class="chip">${String(a)}</span>`)}
2458
- ${o.slice(0,8).map(a=>c`<span class="chip">${String(a)}</span>`)}
2459
- </div>
2460
- </div>
2461
- </div>
2462
- `}function dh(e){const t=e.hello?.snapshot,n=t?.uptimeMs?aa(t.uptimeMs):"n/a",s=t?.policy?.tickIntervalMs?`${t.policy.tickIntervalMs}ms`:"n/a",i=(()=>{if(e.connected||!e.lastError)return null;const a=e.lastError.toLowerCase();if(!(a.includes("unauthorized")||a.includes("connect failed")))return null;const r=!!e.settings.token.trim(),p=!!e.password.trim();return!r&&!p?c`
2463
- <div class="muted" style="margin-top: 8px;">
2464
- This gateway requires auth. Add a token or password, then click Connect.
2465
- <div style="margin-top: 6px;">
2466
- <span class="mono">pigbot dashboard --no-open</span> → tokenized URL<br />
2467
- <span class="mono">pigbot doctor --generate-gateway-token</span> → set token
2468
- </div>
2469
- <div style="margin-top: 6px;">
2470
- <a
2471
- class="session-link"
2472
- href="https://docs.clawd.bot/web/dashboard"
2473
- target="_blank"
2474
- rel="noreferrer"
2475
- title="Control UI auth docs (opens in new tab)"
2476
- >Docs: Control UI auth</a
2477
- >
2478
- </div>
2479
- </div>
2480
- `:c`
2481
- <div class="muted" style="margin-top: 8px;">
2482
- Auth failed. Re-copy a tokenized URL with
2483
- <span class="mono">pigbot dashboard --no-open</span>, or update the token,
2484
- then click Connect.
2485
- <div style="margin-top: 6px;">
2486
- <a
2487
- class="session-link"
2488
- href="https://docs.clawd.bot/web/dashboard"
2489
- target="_blank"
2490
- rel="noreferrer"
2491
- title="Control UI auth docs (opens in new tab)"
2492
- >Docs: Control UI auth</a
2493
- >
2494
- </div>
2495
- </div>
2496
- `})(),o=(()=>{if(e.connected||!e.lastError||(typeof window<"u"?window.isSecureContext:!0)!==!1)return null;const l=e.lastError.toLowerCase();return!l.includes("secure context")&&!l.includes("device identity required")?null:c`
2497
- <div class="muted" style="margin-top: 8px;">
2498
- This page is HTTP, so the browser blocks device identity. Use HTTPS (Tailscale Serve) or
2499
- open <span class="mono">http://127.0.0.1:18789</span> on the gateway host.
2500
- <div style="margin-top: 6px;">
2501
- If you must stay on HTTP, set
2502
- <span class="mono">gateway.controlUi.allowInsecureAuth: true</span> (token-only).
2503
- </div>
2504
- <div style="margin-top: 6px;">
2505
- <a
2506
- class="session-link"
2507
- href="https://docs.clawd.bot/gateway/tailscale"
2508
- target="_blank"
2509
- rel="noreferrer"
2510
- title="Tailscale Serve docs (opens in new tab)"
2511
- >Docs: Tailscale Serve</a
2512
- >
2513
- <span class="muted"> · </span>
2514
- <a
2515
- class="session-link"
2516
- href="https://docs.clawd.bot/web/control-ui#insecure-http"
2517
- target="_blank"
2518
- rel="noreferrer"
2519
- title="Insecure HTTP docs (opens in new tab)"
2520
- >Docs: Insecure HTTP</a
2521
- >
2522
- </div>
2523
- </div>
2524
- `})();return c`
2525
- <section class="grid grid-cols-2">
2526
- <div class="card">
2527
- <div class="card-title">Gateway Access</div>
2528
- <div class="card-sub">Where the dashboard connects and how it authenticates.</div>
2529
- <div class="form-grid" style="margin-top: 16px;">
2530
- <label class="field">
2531
- <span>WebSocket URL</span>
2532
- <input
2533
- .value=${e.settings.gatewayUrl}
2534
- @input=${a=>{const l=a.target.value;e.onSettingsChange({...e.settings,gatewayUrl:l})}}
2535
- placeholder="ws://100.x.y.z:18789"
2536
- />
2537
- </label>
2538
- <label class="field">
2539
- <span>Gateway Token</span>
2540
- <input
2541
- .value=${e.settings.token}
2542
- @input=${a=>{const l=a.target.value;e.onSettingsChange({...e.settings,token:l})}}
2543
- placeholder="PIGBOT_GATEWAY_TOKEN"
2544
- />
2545
- </label>
2546
- <label class="field">
2547
- <span>Password (not stored)</span>
2548
- <input
2549
- type="password"
2550
- .value=${e.password}
2551
- @input=${a=>{const l=a.target.value;e.onPasswordChange(l)}}
2552
- placeholder="system or shared password"
2553
- />
2554
- </label>
2555
- <label class="field">
2556
- <span>Default Session Key</span>
2557
- <input
2558
- .value=${e.settings.sessionKey}
2559
- @input=${a=>{const l=a.target.value;e.onSessionKeyChange(l)}}
2560
- />
2561
- </label>
2562
- </div>
2563
- <div class="row" style="margin-top: 14px;">
2564
- <button class="btn" @click=${()=>e.onConnect()}>Connect</button>
2565
- <button class="btn" @click=${()=>e.onRefresh()}>Refresh</button>
2566
- <span class="muted">Click Connect to apply connection changes.</span>
2567
- </div>
2568
- </div>
2569
-
2570
- <div class="card">
2571
- <div class="card-title">Snapshot</div>
2572
- <div class="card-sub">Latest gateway handshake information.</div>
2573
- <div class="stat-grid" style="margin-top: 16px;">
2574
- <div class="stat">
2575
- <div class="stat-label">Status</div>
2576
- <div class="stat-value ${e.connected?"ok":"warn"}">
2577
- ${e.connected?"Connected":"Disconnected"}
2578
- </div>
2579
- </div>
2580
- <div class="stat">
2581
- <div class="stat-label">Uptime</div>
2582
- <div class="stat-value">${n}</div>
2583
- </div>
2584
- <div class="stat">
2585
- <div class="stat-label">Tick Interval</div>
2586
- <div class="stat-value">${s}</div>
2587
- </div>
2588
- <div class="stat">
2589
- <div class="stat-label">Last Channels Refresh</div>
2590
- <div class="stat-value">
2591
- ${e.lastChannelsRefresh?O(e.lastChannelsRefresh):"n/a"}
2592
- </div>
2593
- </div>
2594
- </div>
2595
- ${e.lastError?c`<div class="callout danger" style="margin-top: 14px;">
2596
- <div>${e.lastError}</div>
2597
- ${i??""}
2598
- ${o??""}
2599
- </div>`:c`<div class="callout" style="margin-top: 14px;">
2600
- Use Channels to link WhatsApp, Telegram, Discord, Signal, or iMessage.
2601
- </div>`}
2602
- </div>
2603
- </section>
2604
-
2605
- <section class="grid grid-cols-3" style="margin-top: 18px;">
2606
- <div class="card stat-card">
2607
- <div class="stat-label">Instances</div>
2608
- <div class="stat-value">${e.presenceCount}</div>
2609
- <div class="muted">Presence beacons in the last 5 minutes.</div>
2610
- </div>
2611
- <div class="card stat-card">
2612
- <div class="stat-label">Sessions</div>
2613
- <div class="stat-value">${e.sessionsCount??"n/a"}</div>
2614
- <div class="muted">Recent session keys tracked by the gateway.</div>
2615
- </div>
2616
- <div class="card stat-card">
2617
- <div class="stat-label">Cron</div>
2618
- <div class="stat-value">
2619
- ${e.cronEnabled==null?"n/a":e.cronEnabled?"Enabled":"Disabled"}
2620
- </div>
2621
- <div class="muted">Next wake ${vr(e.cronNext)}</div>
2622
- </div>
2623
- </section>
2624
-
2625
- <section class="card" style="margin-top: 18px;">
2626
- <div class="card-title">Notes</div>
2627
- <div class="card-sub">Quick reminders for remote control setups.</div>
2628
- <div class="note-grid" style="margin-top: 14px;">
2629
- <div>
2630
- <div class="note-title">Tailscale serve</div>
2631
- <div class="muted">
2632
- Prefer serve mode to keep the gateway on loopback with tailnet auth.
2633
- </div>
2634
- </div>
2635
- <div>
2636
- <div class="note-title">Session hygiene</div>
2637
- <div class="muted">Use /new or sessions.patch to reset context.</div>
2638
- </div>
2639
- <div>
2640
- <div class="note-title">Cron reminders</div>
2641
- <div class="muted">Use isolated sessions for recurring runs.</div>
2642
- </div>
2643
- </div>
2644
- </section>
2645
- `}const uh=["","off","minimal","low","medium","high"],ph=["","off","on"],fh=[{value:"",label:"inherit"},{value:"off",label:"off (explicit)"},{value:"on",label:"on"}],hh=["","off","on","stream"];function gh(e){if(!e)return"";const t=e.trim().toLowerCase();return t==="z.ai"||t==="z-ai"?"zai":t}function mr(e){return gh(e)==="zai"}function vh(e){return mr(e)?ph:uh}function mh(e,t){return!t||!e||e==="off"?e:"on"}function bh(e,t){return e?t&&e==="on"?"low":e:null}function yh(e){const t=e.result?.sessions??[];return c`
2646
- <section class="card">
2647
- <div class="row" style="justify-content: space-between;">
2648
- <div>
2649
- <div class="card-title">Sessions</div>
2650
- <div class="card-sub">Active session keys and per-session overrides.</div>
2651
- </div>
2652
- <button class="btn" ?disabled=${e.loading} @click=${e.onRefresh}>
2653
- ${e.loading?"Loading…":"Refresh"}
2654
- </button>
2655
- </div>
2656
-
2657
- <div class="filters" style="margin-top: 14px;">
2658
- <label class="field">
2659
- <span>Active within (minutes)</span>
2660
- <input
2661
- .value=${e.activeMinutes}
2662
- @input=${n=>e.onFiltersChange({activeMinutes:n.target.value,limit:e.limit,includeGlobal:e.includeGlobal,includeUnknown:e.includeUnknown})}
2663
- />
2664
- </label>
2665
- <label class="field">
2666
- <span>Limit</span>
2667
- <input
2668
- .value=${e.limit}
2669
- @input=${n=>e.onFiltersChange({activeMinutes:e.activeMinutes,limit:n.target.value,includeGlobal:e.includeGlobal,includeUnknown:e.includeUnknown})}
2670
- />
2671
- </label>
2672
- <label class="field checkbox">
2673
- <span>Include global</span>
2674
- <input
2675
- type="checkbox"
2676
- .checked=${e.includeGlobal}
2677
- @change=${n=>e.onFiltersChange({activeMinutes:e.activeMinutes,limit:e.limit,includeGlobal:n.target.checked,includeUnknown:e.includeUnknown})}
2678
- />
2679
- </label>
2680
- <label class="field checkbox">
2681
- <span>Include unknown</span>
2682
- <input
2683
- type="checkbox"
2684
- .checked=${e.includeUnknown}
2685
- @change=${n=>e.onFiltersChange({activeMinutes:e.activeMinutes,limit:e.limit,includeGlobal:e.includeGlobal,includeUnknown:n.target.checked})}
2686
- />
2687
- </label>
2688
- </div>
2689
-
2690
- ${e.error?c`<div class="callout danger" style="margin-top: 12px;">${e.error}</div>`:g}
2691
-
2692
- <div class="muted" style="margin-top: 12px;">
2693
- ${e.result?`Store: ${e.result.path}`:""}
2694
- </div>
2695
-
2696
- <div class="table" style="margin-top: 16px;">
2697
- <div class="table-head">
2698
- <div>Key</div>
2699
- <div>Label</div>
2700
- <div>Kind</div>
2701
- <div>Updated</div>
2702
- <div>Tokens</div>
2703
- <div>Thinking</div>
2704
- <div>Verbose</div>
2705
- <div>Reasoning</div>
2706
- <div>Actions</div>
2707
- </div>
2708
- ${t.length===0?c`<div class="muted">No sessions found.</div>`:t.map(n=>wh(n,e.basePath,e.onPatch,e.onDelete,e.loading))}
2709
- </div>
2710
- </section>
2711
- `}function wh(e,t,n,s,i){const o=e.updatedAt?O(e.updatedAt):"n/a",a=e.thinkingLevel??"",l=mr(e.modelProvider),r=mh(a,l),p=vh(e.modelProvider),d=e.verboseLevel??"",u=e.reasoningLevel??"",h=e.displayName??e.key,v=e.kind!=="global",w=v?`${Ps("chat",t)}?session=${encodeURIComponent(e.key)}`:null;return c`
2712
- <div class="table-row">
2713
- <div class="mono">${v?c`<a href=${w} class="session-link">${h}</a>`:h}</div>
2714
- <div>
2715
- <input
2716
- .value=${e.label??""}
2717
- ?disabled=${i}
2718
- placeholder="(optional)"
2719
- @change=${$=>{const x=$.target.value.trim();n(e.key,{label:x||null})}}
2720
- />
2721
- </div>
2722
- <div>${e.kind}</div>
2723
- <div>${o}</div>
2724
- <div>${kf(e)}</div>
2725
- <div>
2726
- <select
2727
- .value=${r}
2728
- ?disabled=${i}
2729
- @change=${$=>{const x=$.target.value;n(e.key,{thinkingLevel:bh(x,l)})}}
2730
- >
2731
- ${p.map($=>c`<option value=${$}>${$||"inherit"}</option>`)}
2732
- </select>
2733
- </div>
2734
- <div>
2735
- <select
2736
- .value=${d}
2737
- ?disabled=${i}
2738
- @change=${$=>{const x=$.target.value;n(e.key,{verboseLevel:x||null})}}
2739
- >
2740
- ${fh.map($=>c`<option value=${$.value}>${$.label}</option>`)}
2741
- </select>
2742
- </div>
2743
- <div>
2744
- <select
2745
- .value=${u}
2746
- ?disabled=${i}
2747
- @change=${$=>{const x=$.target.value;n(e.key,{reasoningLevel:x||null})}}
2748
- >
2749
- ${hh.map($=>c`<option value=${$}>${$||"inherit"}</option>`)}
2750
- </select>
2751
- </div>
2752
- <div>
2753
- <button class="btn danger" ?disabled=${i} @click=${()=>s(e.key)}>
2754
- Delete
2755
- </button>
2756
- </div>
2757
- </div>
2758
- `}function $h(e){const t=Math.max(0,e),n=Math.floor(t/1e3);if(n<60)return`${n}s`;const s=Math.floor(n/60);return s<60?`${s}m`:`${Math.floor(s/60)}h`}function Re(e,t){return t?c`<div class="exec-approval-meta-row"><span>${e}</span><span>${t}</span></div>`:g}function kh(e){const t=e.execApprovalQueue[0];if(!t)return g;const n=t.request,s=t.expiresAtMs-Date.now(),i=s>0?`expires in ${$h(s)}`:"expired",o=e.execApprovalQueue.length;return c`
2759
- <div class="exec-approval-overlay" role="dialog" aria-live="polite">
2760
- <div class="exec-approval-card">
2761
- <div class="exec-approval-header">
2762
- <div>
2763
- <div class="exec-approval-title">Exec approval needed</div>
2764
- <div class="exec-approval-sub">${i}</div>
2765
- </div>
2766
- ${o>1?c`<div class="exec-approval-queue">${o} pending</div>`:g}
2767
- </div>
2768
- <div class="exec-approval-command mono">${n.command}</div>
2769
- <div class="exec-approval-meta">
2770
- ${Re("Host",n.host)}
2771
- ${Re("Agent",n.agentId)}
2772
- ${Re("Session",n.sessionKey)}
2773
- ${Re("CWD",n.cwd)}
2774
- ${Re("Resolved",n.resolvedPath)}
2775
- ${Re("Security",n.security)}
2776
- ${Re("Ask",n.ask)}
2777
- </div>
2778
- ${e.execApprovalError?c`<div class="exec-approval-error">${e.execApprovalError}</div>`:g}
2779
- <div class="exec-approval-actions">
2780
- <button
2781
- class="btn primary"
2782
- ?disabled=${e.execApprovalBusy}
2783
- @click=${()=>e.handleExecApprovalDecision("allow-once")}
2784
- >
2785
- Allow once
2786
- </button>
2787
- <button
2788
- class="btn"
2789
- ?disabled=${e.execApprovalBusy}
2790
- @click=${()=>e.handleExecApprovalDecision("allow-always")}
2791
- >
2792
- Always allow
2793
- </button>
2794
- <button
2795
- class="btn danger"
2796
- ?disabled=${e.execApprovalBusy}
2797
- @click=${()=>e.handleExecApprovalDecision("deny")}
2798
- >
2799
- Deny
2800
- </button>
2801
- </div>
2802
- </div>
2803
- </div>
2804
- `}function xh(e){const t=e.report?.skills??[],n=e.filter.trim().toLowerCase(),s=n?t.filter(i=>[i.name,i.description,i.source].join(" ").toLowerCase().includes(n)):t;return c`
2805
- <section class="card">
2806
- <div class="row" style="justify-content: space-between;">
2807
- <div>
2808
- <div class="card-title">Skills</div>
2809
- <div class="card-sub">Bundled, managed, and workspace skills.</div>
2810
- </div>
2811
- <button class="btn" ?disabled=${e.loading} @click=${e.onRefresh}>
2812
- ${e.loading?"Loading…":"Refresh"}
2813
- </button>
2814
- </div>
2815
-
2816
- <div class="filters" style="margin-top: 14px;">
2817
- <label class="field" style="flex: 1;">
2818
- <span>Filter</span>
2819
- <input
2820
- .value=${e.filter}
2821
- @input=${i=>e.onFilterChange(i.target.value)}
2822
- placeholder="Search skills"
2823
- />
2824
- </label>
2825
- <div class="muted">${s.length} shown</div>
2826
- </div>
2827
-
2828
- ${e.error?c`<div class="callout danger" style="margin-top: 12px;">${e.error}</div>`:g}
2829
-
2830
- ${s.length===0?c`<div class="muted" style="margin-top: 16px;">No skills found.</div>`:c`
2831
- <div class="list" style="margin-top: 16px;">
2832
- ${s.map(i=>Ah(i,e))}
2833
- </div>
2834
- `}
2835
- </section>
2836
- `}function Ah(e,t){const n=t.busyKey===e.skillKey,s=t.edits[e.skillKey]??"",i=t.messages[e.skillKey]??null,o=e.install.length>0&&e.missing.bins.length>0,a=[...e.missing.bins.map(r=>`bin:${r}`),...e.missing.env.map(r=>`env:${r}`),...e.missing.config.map(r=>`config:${r}`),...e.missing.os.map(r=>`os:${r}`)],l=[];return e.disabled&&l.push("disabled"),e.blockedByAllowlist&&l.push("blocked by allowlist"),c`
2837
- <div class="list-item">
2838
- <div class="list-main">
2839
- <div class="list-title">
2840
- ${e.emoji?`${e.emoji} `:""}${e.name}
2841
- </div>
2842
- <div class="list-sub">${as(e.description,140)}</div>
2843
- <div class="chip-row" style="margin-top: 6px;">
2844
- <span class="chip">${e.source}</span>
2845
- <span class="chip ${e.eligible?"chip-ok":"chip-warn"}">
2846
- ${e.eligible?"eligible":"blocked"}
2847
- </span>
2848
- ${e.disabled?c`<span class="chip chip-warn">disabled</span>`:g}
2849
- </div>
2850
- ${a.length>0?c`
2851
- <div class="muted" style="margin-top: 6px;">
2852
- Missing: ${a.join(", ")}
2853
- </div>
2854
- `:g}
2855
- ${l.length>0?c`
2856
- <div class="muted" style="margin-top: 6px;">
2857
- Reason: ${l.join(", ")}
2858
- </div>
2859
- `:g}
2860
- </div>
2861
- <div class="list-meta">
2862
- <div class="row" style="justify-content: flex-end; flex-wrap: wrap;">
2863
- <button
2864
- class="btn"
2865
- ?disabled=${n}
2866
- @click=${()=>t.onToggle(e.skillKey,e.disabled)}
2867
- >
2868
- ${e.disabled?"Enable":"Disable"}
2869
- </button>
2870
- ${o?c`<button
2871
- class="btn"
2872
- ?disabled=${n}
2873
- @click=${()=>t.onInstall(e.skillKey,e.name,e.install[0].id)}
2874
- >
2875
- ${n?"Installing…":e.install[0].label}
2876
- </button>`:g}
2877
- </div>
2878
- ${i?c`<div
2879
- class="muted"
2880
- style="margin-top: 8px; color: ${i.kind==="error"?"var(--danger-color, #d14343)":"var(--success-color, #0a7f5a)"};"
2881
- >
2882
- ${i.message}
2883
- </div>`:g}
2884
- ${e.primaryEnv?c`
2885
- <div class="field" style="margin-top: 10px;">
2886
- <span>API key</span>
2887
- <input
2888
- type="password"
2889
- .value=${s}
2890
- @input=${r=>t.onEdit(e.skillKey,r.target.value)}
2891
- />
2892
- </div>
2893
- <button
2894
- class="btn primary"
2895
- style="margin-top: 8px;"
2896
- ?disabled=${n}
2897
- @click=${()=>t.onSaveKey(e.skillKey)}
2898
- >
2899
- Save key
2900
- </button>
2901
- `:g}
2902
- </div>
2903
- </div>
2904
- `}function Sh(e,t){const n=Ps(t,e.basePath);return c`
2905
- <a
2906
- href=${n}
2907
- class="nav-item ${e.tab===t?"active":""}"
2908
- @click=${s=>{s.defaultPrevented||s.button!==0||s.metaKey||s.ctrlKey||s.shiftKey||s.altKey||(s.preventDefault(),e.setTab(t))}}
2909
- title=${is(t)}
2910
- >
2911
- <span class="nav-item__icon" aria-hidden="true">${ml(t)}</span>
2912
- <span class="nav-item__text">${is(t)}</span>
2913
- </a>
2914
- `}function _h(e){const t=Th(e.sessionKey,e.sessionsResult),n=e.onboarding,s=e.onboarding,i=e.onboarding?!1:e.settings.chatShowThinking,o=e.onboarding?!0:e.settings.chatFocusMode,a=c`<svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M21 12a9 9 0 1 1-9-9c2.52 0 4.93 1 6.74 2.74L21 8"></path><path d="M21 3v5h-5"></path></svg>`,l=c`<svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M4 7V4h3"></path><path d="M20 7V4h-3"></path><path d="M4 17v3h3"></path><path d="M20 17v3h-3"></path><circle cx="12" cy="12" r="3"></circle></svg>`;return c`
2915
- <div class="chat-controls">
2916
- <label class="field chat-controls__session">
2917
- <select
2918
- .value=${e.sessionKey}
2919
- ?disabled=${!e.connected}
2920
- @change=${r=>{const p=r.target.value;e.sessionKey=p,e.chatMessage="",e.chatStream=null,e.chatStreamStartedAt=null,e.chatRunId=null,e.resetToolStream(),e.resetChatScroll(),e.applySettings({...e.settings,sessionKey:p,lastActiveSessionKey:p}),e.loadAssistantIdentity(),gd(e,p),Ze(e)}}
2921
- >
2922
- ${za(t,r=>r.key,r=>c`<option value=${r.key}>
2923
- ${r.displayName??r.key}
2924
- </option>`)}
2925
- </select>
2926
- </label>
2927
- <button
2928
- class="btn btn--sm btn--icon"
2929
- ?disabled=${e.chatLoading||!e.connected}
2930
- @click=${()=>{e.resetToolStream(),Ze(e)}}
2931
- title="Refresh chat history"
2932
- >
2933
- ${a}
2934
- </button>
2935
- <span class="chat-controls__separator">|</span>
2936
- <button
2937
- class="btn btn--sm btn--icon ${i?"active":""}"
2938
- ?disabled=${n}
2939
- @click=${()=>{n||e.applySettings({...e.settings,chatShowThinking:!e.settings.chatShowThinking})}}
2940
- aria-pressed=${i}
2941
- title=${n?"Disabled during onboarding":"Toggle assistant thinking/working output"}
2942
- >
2943
- 🧠
2944
- </button>
2945
- <button
2946
- class="btn btn--sm btn--icon ${o?"active":""}"
2947
- ?disabled=${s}
2948
- @click=${()=>{s||e.applySettings({...e.settings,chatFocusMode:!e.settings.chatFocusMode})}}
2949
- aria-pressed=${o}
2950
- title=${s?"Disabled during onboarding":"Toggle focus mode (hide sidebar + page header)"}
2951
- >
2952
- ${l}
2953
- </button>
2954
- </div>
2955
- `}function Th(e,t){const n=new Set,s=[],i=t?.sessions?.find(o=>o.key===e);if(n.add(e),s.push({key:e,displayName:i?.displayName}),t?.sessions)for(const o of t.sessions)n.has(o.key)||(n.add(o.key),s.push({key:o.key,displayName:o.displayName}));return s}const Ch=["system","light","dark"];function Eh(e){const t=Math.max(0,Ch.indexOf(e.theme)),n=s=>i=>{const a={element:i.currentTarget};(i.clientX||i.clientY)&&(a.pointerClientX=i.clientX,a.pointerClientY=i.clientY),e.setTheme(s,a)};return c`
2956
- <div class="theme-toggle" style="--theme-index: ${t};">
2957
- <div class="theme-toggle__track" role="group" aria-label="Theme">
2958
- <span class="theme-toggle__indicator"></span>
2959
- <button
2960
- class="theme-toggle__button ${e.theme==="system"?"active":""}"
2961
- @click=${n("system")}
2962
- aria-pressed=${e.theme==="system"}
2963
- aria-label="System theme"
2964
- title="System"
2965
- >
2966
- ${Lh()}
2967
- </button>
2968
- <button
2969
- class="theme-toggle__button ${e.theme==="light"?"active":""}"
2970
- @click=${n("light")}
2971
- aria-pressed=${e.theme==="light"}
2972
- aria-label="Light theme"
2973
- title="Light"
2974
- >
2975
- ${Ih()}
2976
- </button>
2977
- <button
2978
- class="theme-toggle__button ${e.theme==="dark"?"active":""}"
2979
- @click=${n("dark")}
2980
- aria-pressed=${e.theme==="dark"}
2981
- aria-label="Dark theme"
2982
- title="Dark"
2983
- >
2984
- ${Rh()}
2985
- </button>
2986
- </div>
2987
- </div>
2988
- `}function Ih(){return c`
2989
- <svg class="theme-icon" viewBox="0 0 24 24" aria-hidden="true">
2990
- <circle cx="12" cy="12" r="4"></circle>
2991
- <path d="M12 2v2"></path>
2992
- <path d="M12 20v2"></path>
2993
- <path d="m4.93 4.93 1.41 1.41"></path>
2994
- <path d="m17.66 17.66 1.41 1.41"></path>
2995
- <path d="M2 12h2"></path>
2996
- <path d="M20 12h2"></path>
2997
- <path d="m6.34 17.66-1.41 1.41"></path>
2998
- <path d="m19.07 4.93-1.41 1.41"></path>
2999
- </svg>
3000
- `}function Rh(){return c`
3001
- <svg class="theme-icon" viewBox="0 0 24 24" aria-hidden="true">
3002
- <path
3003
- d="M20.985 12.486a9 9 0 1 1-9.473-9.472c.405-.022.617.46.402.803a6 6 0 0 0 8.268 8.268c.344-.215.825-.004.803.401"
3004
- ></path>
3005
- </svg>
3006
- `}function Lh(){return c`
3007
- <svg class="theme-icon" viewBox="0 0 24 24" aria-hidden="true">
3008
- <rect width="20" height="14" x="2" y="3" rx="2"></rect>
3009
- <line x1="8" x2="16" y1="21" y2="21"></line>
3010
- <line x1="12" x2="12" y1="17" y2="21"></line>
3011
- </svg>
3012
- `}const Mh=/^data:/i,Ph=/^https?:\/\//i;function Nh(e){const t=e.agentsList?.agents??[],s=na(e.sessionKey)?.agentId??e.agentsList?.defaultId??"main",o=t.find(l=>l.id===s)?.identity,a=o?.avatarUrl??o?.avatar;if(a)return Mh.test(a)||Ph.test(a)?a:o?.avatarUrl}function Oh(e){const t=e.presenceEntries.length,n=e.sessionsResult?.count??null,s=e.cronStatus?.nextWakeAtMs??null,i=e.connected?null:"Disconnected from gateway.",o=e.tab==="chat",a=o&&(e.settings.chatFocusMode||e.onboarding),l=e.onboarding?!1:e.settings.chatShowThinking,r=Nh(e),p=e.chatAvatarUrl??r??null;return c`
3013
- <div class="shell ${o?"shell--chat":""} ${a?"shell--chat-focus":""} ${e.settings.navCollapsed?"shell--nav-collapsed":""} ${e.onboarding?"shell--onboarding":""}">
3014
- <header class="topbar">
3015
- <div class="topbar-left">
3016
- <button
3017
- class="nav-collapse-toggle"
3018
- @click=${()=>e.applySettings({...e.settings,navCollapsed:!e.settings.navCollapsed})}
3019
- title="${e.settings.navCollapsed?"Expand sidebar":"Collapse sidebar"}"
3020
- aria-label="${e.settings.navCollapsed?"Expand sidebar":"Collapse sidebar"}"
3021
- >
3022
- <span class="nav-collapse-toggle__icon">☰</span>
3023
- </button>
3024
- <div class="brand">
3025
- <div class="brand-title">PIGBOT</div>
3026
- <div class="brand-sub">Gateway Dashboard</div>
3027
- </div>
3028
- </div>
3029
- <div class="topbar-status">
3030
- <div class="pill">
3031
- <span class="statusDot ${e.connected?"ok":""}"></span>
3032
- <span>Health</span>
3033
- <span class="mono">${e.connected?"OK":"Offline"}</span>
3034
- </div>
3035
- ${Eh(e)}
3036
- </div>
3037
- </header>
3038
- <aside class="nav ${e.settings.navCollapsed?"nav--collapsed":""}">
3039
- ${gl.map(d=>{const u=e.settings.navGroupsCollapsed[d.label]??!1,h=d.tabs.some(v=>v===e.tab);return c`
3040
- <div class="nav-group ${u&&!h?"nav-group--collapsed":""}">
3041
- <button
3042
- class="nav-label"
3043
- @click=${()=>{const v={...e.settings.navGroupsCollapsed};v[d.label]=!u,e.applySettings({...e.settings,navGroupsCollapsed:v})}}
3044
- aria-expanded=${!u}
3045
- >
3046
- <span class="nav-label__text">${d.label}</span>
3047
- <span class="nav-label__chevron">${u?"+":"−"}</span>
3048
- </button>
3049
- <div class="nav-group__items">
3050
- ${d.tabs.map(v=>Sh(e,v))}
3051
- </div>
3052
- </div>
3053
- `})}
3054
- <div class="nav-group nav-group--links">
3055
- <div class="nav-label nav-label--static">
3056
- <span class="nav-label__text">Resources</span>
3057
- </div>
3058
- <div class="nav-group__items">
3059
- <a
3060
- class="nav-item nav-item--external"
3061
- href="https://docs.clawd.bot"
3062
- target="_blank"
3063
- rel="noreferrer"
3064
- title="Docs (opens in new tab)"
3065
- >
3066
- <span class="nav-item__icon" aria-hidden="true">📚</span>
3067
- <span class="nav-item__text">Docs</span>
3068
- </a>
3069
- </div>
3070
- </div>
3071
- </aside>
3072
- <main class="content ${o?"content--chat":""}">
3073
- <section class="content-header">
3074
- <div>
3075
- <div class="page-title">${is(e.tab)}</div>
3076
- <div class="page-sub">${bl(e.tab)}</div>
3077
- </div>
3078
- <div class="page-meta">
3079
- ${e.lastError?c`<div class="pill danger">${e.lastError}</div>`:g}
3080
- ${o?_h(e):g}
3081
- </div>
3082
- </section>
3083
-
3084
- ${e.tab==="overview"?dh({connected:e.connected,hello:e.hello,settings:e.settings,password:e.password,lastError:e.lastError,presenceCount:t,sessionsCount:n,cronEnabled:e.cronStatus?.enabled??null,cronNext:s,lastChannelsRefresh:e.channelsLastSuccess,onSettingsChange:d=>e.applySettings(d),onPasswordChange:d=>e.password=d,onSessionKeyChange:d=>{e.sessionKey=d,e.chatMessage="",e.resetToolStream(),e.applySettings({...e.settings,sessionKey:d,lastActiveSessionKey:d}),e.loadAssistantIdentity()},onConnect:()=>e.connect(),onRefresh:()=>e.loadOverview()}):g}
3085
-
3086
- ${e.tab==="channels"?df({connected:e.connected,loading:e.channelsLoading,snapshot:e.channelsSnapshot,lastError:e.channelsError,lastSuccessAt:e.channelsLastSuccess,whatsappMessage:e.whatsappLoginMessage,whatsappQrDataUrl:e.whatsappLoginQrDataUrl,whatsappConnected:e.whatsappLoginConnected,whatsappBusy:e.whatsappBusy,configSchema:e.configSchema,configSchemaLoading:e.configSchemaLoading,configForm:e.configForm,configUiHints:e.configUiHints,configSaving:e.configSaving,configFormDirty:e.configFormDirty,nostrProfileFormState:e.nostrProfileFormState,nostrProfileAccountId:e.nostrProfileAccountId,onRefresh:d=>oe(e,d),onWhatsAppStart:d=>e.handleWhatsAppStart(d),onWhatsAppWait:()=>e.handleWhatsAppWait(),onWhatsAppLogout:()=>e.handleWhatsAppLogout(),onConfigPatch:(d,u)=>Dt(e,d,u),onConfigSave:()=>e.handleChannelConfigSave(),onConfigReload:()=>e.handleChannelConfigReload(),onNostrProfileEdit:(d,u)=>e.handleNostrProfileEdit(d,u),onNostrProfileCancel:()=>e.handleNostrProfileCancel(),onNostrProfileFieldChange:(d,u)=>e.handleNostrProfileFieldChange(d,u),onNostrProfileSave:()=>e.handleNostrProfileSave(),onNostrProfileImport:()=>e.handleNostrProfileImport(),onNostrProfileToggleAdvanced:()=>e.handleNostrProfileToggleAdvanced()}):g}
3087
-
3088
- ${e.tab==="instances"?Pf({loading:e.presenceLoading,entries:e.presenceEntries,lastError:e.presenceError,statusMessage:e.presenceStatus,onRefresh:()=>qs(e)}):g}
3089
-
3090
- ${e.tab==="sessions"?yh({loading:e.sessionsLoading,result:e.sessionsResult,error:e.sessionsError,activeMinutes:e.sessionsFilterActive,limit:e.sessionsFilterLimit,includeGlobal:e.sessionsIncludeGlobal,includeUnknown:e.sessionsIncludeUnknown,basePath:e.basePath,onFiltersChange:d=>{e.sessionsFilterActive=d.activeMinutes,e.sessionsFilterLimit=d.limit,e.sessionsIncludeGlobal=d.includeGlobal,e.sessionsIncludeUnknown=d.includeUnknown},onRefresh:()=>nt(e),onPatch:(d,u)=>Ll(e,d,u),onDelete:d=>Ml(e,d)}):g}
3091
-
3092
- ${e.tab==="cron"?Ef({loading:e.cronLoading,status:e.cronStatus,jobs:e.cronJobs,error:e.cronError,busy:e.cronBusy,form:e.cronForm,channels:e.channelsSnapshot?.channelMeta?.length?e.channelsSnapshot.channelMeta.map(d=>d.id):e.channelsSnapshot?.channelOrder??[],channelLabels:e.channelsSnapshot?.channelLabels??{},channelMeta:e.channelsSnapshot?.channelMeta??[],runsJobId:e.cronRunsJobId,runs:e.cronRuns,onFormChange:d=>e.cronForm={...e.cronForm,...d},onRefresh:()=>e.loadCron(),onAdd:()=>tc(e),onToggle:(d,u)=>nc(e,d,u),onRun:d=>sc(e,d),onRemove:d=>ic(e,d),onLoadRuns:d=>fa(e,d)}):g}
3093
-
3094
- ${e.tab==="skills"?xh({loading:e.skillsLoading,report:e.skillsReport,error:e.skillsError,filter:e.skillsFilter,edits:e.skillEdits,messages:e.skillMessages,busyKey:e.skillsBusyKey,onFilterChange:d=>e.skillsFilter=d,onRefresh:()=>Tt(e,{clearMessages:!0}),onToggle:(d,u)=>Zc(e,d,u),onEdit:(d,u)=>Jc(e,d,u),onSaveKey:d=>Xc(e,d),onInstall:(d,u,h)=>ed(e,d,u,h)}):g}
3095
-
3096
- ${e.tab==="nodes"?Ff({loading:e.nodesLoading,nodes:e.nodes,devicesLoading:e.devicesLoading,devicesError:e.devicesError,devicesList:e.devicesList,configForm:e.configForm??e.configSnapshot?.config,configLoading:e.configLoading,configSaving:e.configSaving,configDirty:e.configFormDirty,configFormMode:e.configFormMode,execApprovalsLoading:e.execApprovalsLoading,execApprovalsSaving:e.execApprovalsSaving,execApprovalsDirty:e.execApprovalsDirty,execApprovalsSnapshot:e.execApprovalsSnapshot,execApprovalsForm:e.execApprovalsForm,execApprovalsSelectedAgent:e.execApprovalsSelectedAgent,execApprovalsTarget:e.execApprovalsTarget,execApprovalsTargetNodeId:e.execApprovalsTargetNodeId,onRefresh:()=>pn(e),onDevicesRefresh:()=>_e(e),onDeviceApprove:d=>Kc(e,d),onDeviceReject:d=>Hc(e,d),onDeviceRotate:(d,u,h)=>zc(e,{deviceId:d,role:u,scopes:h}),onDeviceRevoke:(d,u)=>jc(e,{deviceId:d,role:u}),onLoadConfig:()=>me(e),onLoadExecApprovals:()=>{const d=e.execApprovalsTarget==="node"&&e.execApprovalsTargetNodeId?{kind:"node",nodeId:e.execApprovalsTargetNodeId}:{kind:"gateway"};return js(e,d)},onBindDefault:d=>{d?Dt(e,["tools","exec","node"],d):Zi(e,["tools","exec","node"])},onBindAgent:(d,u)=>{const h=["agents","list",d,"tools","exec","node"];u?Dt(e,h,u):Zi(e,h)},onSaveBindings:()=>cs(e),onExecApprovalsTargetChange:(d,u)=>{e.execApprovalsTarget=d,e.execApprovalsTargetNodeId=u,e.execApprovalsSnapshot=null,e.execApprovalsForm=null,e.execApprovalsDirty=!1,e.execApprovalsSelectedAgent=null},onExecApprovalsSelectAgent:d=>{e.execApprovalsSelectedAgent=d},onExecApprovalsPatch:(d,u)=>Yc(e,d,u),onExecApprovalsRemove:d=>Qc(e,d),onSaveExecApprovals:()=>{const d=e.execApprovalsTarget==="node"&&e.execApprovalsTargetNodeId?{kind:"node",nodeId:e.execApprovalsTargetNodeId}:{kind:"gateway"};return Vc(e,d)}}):g}
3097
-
3098
- ${e.tab==="chat"?Tp({sessionKey:e.sessionKey,onSessionKeyChange:d=>{e.sessionKey=d,e.chatMessage="",e.chatStream=null,e.chatStreamStartedAt=null,e.chatRunId=null,e.chatQueue=[],e.resetToolStream(),e.resetChatScroll(),e.applySettings({...e.settings,sessionKey:d,lastActiveSessionKey:d}),e.loadAssistantIdentity(),Ze(e),hs(e)},thinkingLevel:e.chatThinkingLevel,showThinking:l,loading:e.chatLoading,sending:e.chatSending,compactionStatus:e.compactionStatus,assistantAvatarUrl:p,messages:e.chatMessages,toolMessages:e.chatToolMessages,stream:e.chatStream,streamStartedAt:e.chatStreamStartedAt,draft:e.chatMessage,queue:e.chatQueue,connected:e.connected,canSend:e.connected,disabledReason:i,error:e.lastError,sessions:e.sessionsResult,focusMode:a,onRefresh:()=>(e.resetToolStream(),Promise.all([Ze(e),hs(e)])),onToggleFocusMode:()=>{e.onboarding||e.applySettings({...e.settings,chatFocusMode:!e.settings.chatFocusMode})},onChatScroll:d=>e.handleChatScroll(d),onDraftChange:d=>e.chatMessage=d,onSend:()=>e.handleSendChat(),canAbort:!!e.chatRunId,onAbort:()=>{e.handleAbortChat()},onQueueRemove:d=>e.removeQueuedMessage(d),onNewSession:()=>e.handleSendChat("/new",{restoreDraft:!0}),sidebarOpen:e.sidebarOpen,sidebarContent:e.sidebarContent,sidebarError:e.sidebarError,splitRatio:e.splitRatio,onOpenSidebar:d=>e.handleOpenSidebar(d),onCloseSidebar:()=>e.handleCloseSidebar(),onSplitRatioChange:d=>e.handleSplitRatioChange(d),assistantName:e.assistantName,assistantAvatar:e.assistantAvatar}):g}
3099
-
3100
- ${e.tab==="config"?qp({raw:e.configRaw,originalRaw:e.configRawOriginal,valid:e.configValid,issues:e.configIssues,loading:e.configLoading,saving:e.configSaving,applying:e.configApplying,updating:e.updateRunning,connected:e.connected,schema:e.configSchema,schemaLoading:e.configSchemaLoading,uiHints:e.configUiHints,formMode:e.configFormMode,formValue:e.configForm,originalValue:e.configFormOriginal,searchQuery:e.configSearchQuery,activeSection:e.configActiveSection,activeSubsection:e.configActiveSubsection,onRawChange:d=>{e.configRaw=d},onFormModeChange:d=>e.configFormMode=d,onFormPatch:(d,u)=>Dt(e,d,u),onSearchChange:d=>e.configSearchQuery=d,onSectionChange:d=>{e.configActiveSection=d,e.configActiveSubsection=null},onSubsectionChange:d=>e.configActiveSubsection=d,onReload:()=>me(e),onSave:()=>cs(e),onApply:()=>Jl(e),onUpdate:()=>Zl(e)}):g}
3101
-
3102
- ${e.tab==="debug"?Mf({loading:e.debugLoading,status:e.debugStatus,health:e.debugHealth,models:e.debugModels,heartbeat:e.debugHeartbeat,eventLog:e.eventLog,callMethod:e.debugCallMethod,callParams:e.debugCallParams,callResult:e.debugCallResult,callError:e.debugCallError,onCallMethodChange:d=>e.debugCallMethod=d,onCallParamsChange:d=>e.debugCallParams=d,onRefresh:()=>dn(e),onCall:()=>lc(e)}):g}
3103
-
3104
- ${e.tab==="logs"?Bf({loading:e.logsLoading,error:e.logsError,file:e.logsFile,entries:e.logsEntries,filterText:e.logsFilterText,levelFilters:e.logsLevelFilters,autoFollow:e.logsAutoFollow,truncated:e.logsTruncated,onFilterTextChange:d=>e.logsFilterText=d,onLevelToggle:(d,u)=>{e.logsLevelFilters={...e.logsLevelFilters,[d]:u}},onToggleAutoFollow:d=>e.logsAutoFollow=d,onRefresh:()=>Ds(e,{reset:!0}),onExport:(d,u)=>e.exportLogs(d,u),onScroll:d=>e.handleLogsScroll(d)}):g}
3105
- </main>
3106
- ${kh(e)}
3107
- </div>
3108
- `}const Dh={trace:!0,debug:!0,info:!0,warn:!0,error:!0,fatal:!0},Bh={name:"",description:"",agentId:"",enabled:!0,scheduleKind:"every",scheduleAt:"",everyAmount:"30",everyUnit:"minutes",cronExpr:"0 7 * * *",cronTz:"",sessionTarget:"main",wakeMode:"next-heartbeat",payloadKind:"systemEvent",payloadText:"",deliver:!1,channel:"last",to:"",timeoutSeconds:"",postToMainPrefix:""};async function Fh(e){if(!(!e.client||!e.connected)&&!e.agentsLoading){e.agentsLoading=!0,e.agentsError=null;try{const t=await e.client.request("agents.list",{});t&&(e.agentsList=t)}catch(t){e.agentsError=String(t)}finally{e.agentsLoading=!1}}}const br={WEBCHAT_UI:"webchat-ui",CONTROL_UI:"pigbot-control-ui",WEBCHAT:"webchat",CLI:"cli",GATEWAY_CLIENT:"gateway-client",MACOS_APP:"pigbot-macos",IOS_APP:"pigbot-ios",ANDROID_APP:"pigbot-android",NODE_HOST:"node-host",TEST:"test",FINGERPRINT:"fingerprint",PROBE:"pigbot-probe"},qo=br,_s={WEBCHAT:"webchat",CLI:"cli",UI:"ui",BACKEND:"backend",NODE:"node",PROBE:"probe",TEST:"test"};new Set(Object.values(br));new Set(Object.values(_s));function Uh(e){const t=e.version??(e.nonce?"v2":"v1"),n=e.scopes.join(","),s=e.token??"",i=[t,e.deviceId,e.clientId,e.clientMode,e.role,n,String(e.signedAtMs),s];return t==="v2"&&i.push(e.nonce??""),i.join("|")}const Kh=4008;class Hh{constructor(t){this.opts=t,this.ws=null,this.pending=new Map,this.closed=!1,this.lastSeq=null,this.connectNonce=null,this.connectSent=!1,this.connectTimer=null,this.backoffMs=800}start(){this.closed=!1,this.connect()}stop(){this.closed=!0,this.ws?.close(),this.ws=null,this.flushPending(new Error("gateway client stopped"))}get connected(){return this.ws?.readyState===WebSocket.OPEN}connect(){this.closed||(this.ws=new WebSocket(this.opts.url),this.ws.onopen=()=>this.queueConnect(),this.ws.onmessage=t=>this.handleMessage(String(t.data??"")),this.ws.onclose=t=>{const n=String(t.reason??"");this.ws=null,this.flushPending(new Error(`gateway closed (${t.code}): ${n}`)),this.opts.onClose?.({code:t.code,reason:n}),this.scheduleReconnect()},this.ws.onerror=()=>{})}scheduleReconnect(){if(this.closed)return;const t=this.backoffMs;this.backoffMs=Math.min(this.backoffMs*1.7,15e3),window.setTimeout(()=>this.connect(),t)}flushPending(t){for(const[,n]of this.pending)n.reject(t);this.pending.clear()}async sendConnect(){if(this.connectSent)return;this.connectSent=!0,this.connectTimer!==null&&(window.clearTimeout(this.connectTimer),this.connectTimer=null);const t=typeof crypto<"u"&&!!crypto.subtle,n=["operator.admin","operator.approvals","operator.pairing"],s="operator";let i=null,o=!1,a=this.opts.token;if(t){i=await Ks();const d=Uc({deviceId:i.deviceId,role:s})?.token;a=d??this.opts.token,o=!!(d&&this.opts.token)}const l=a||this.opts.password?{token:a,password:this.opts.password}:void 0;let r;if(t&&i){const d=Date.now(),u=this.connectNonce??void 0,h=Uh({deviceId:i.deviceId,clientId:this.opts.clientName??qo.CONTROL_UI,clientMode:this.opts.mode??_s.WEBCHAT,role:s,scopes:n,signedAtMs:d,token:a??null,nonce:u}),v=await Bc(i.privateKey,h);r={id:i.deviceId,publicKey:i.publicKey,signature:v,signedAt:d,nonce:u}}const p={minProtocol:3,maxProtocol:3,client:{id:this.opts.clientName??qo.CONTROL_UI,version:this.opts.clientVersion??"dev",platform:this.opts.platform??navigator.platform??"web",mode:this.opts.mode??_s.WEBCHAT,instanceId:this.opts.instanceId},role:s,scopes:n,device:r,caps:[],auth:l,userAgent:navigator.userAgent,locale:navigator.language};this.request("connect",p).then(d=>{d?.auth?.deviceToken&&i&&Ia({deviceId:i.deviceId,role:d.auth.role??s,token:d.auth.deviceToken,scopes:d.auth.scopes??[]}),this.backoffMs=800,this.opts.onHello?.(d)}).catch(()=>{o&&i&&Ra({deviceId:i.deviceId,role:s}),this.ws?.close(Kh,"connect failed")})}handleMessage(t){let n;try{n=JSON.parse(t)}catch{return}const s=n;if(s.type==="event"){const i=n;if(i.event==="connect.challenge"){const a=i.payload,l=a&&typeof a.nonce=="string"?a.nonce:null;l&&(this.connectNonce=l,this.sendConnect());return}const o=typeof i.seq=="number"?i.seq:null;o!==null&&(this.lastSeq!==null&&o>this.lastSeq+1&&this.opts.onGap?.({expected:this.lastSeq+1,received:o}),this.lastSeq=o);try{this.opts.onEvent?.(i)}catch(a){console.error("[gateway] event handler error:",a)}return}if(s.type==="res"){const i=n,o=this.pending.get(i.id);if(!o)return;this.pending.delete(i.id),i.ok?o.resolve(i.payload):o.reject(new Error(i.error?.message??"request failed"));return}}request(t,n){if(!this.ws||this.ws.readyState!==WebSocket.OPEN)return Promise.reject(new Error("gateway not connected"));const s=Ns(),i={type:"req",id:s,method:t,params:n},o=new Promise((a,l)=>{this.pending.set(s,{resolve:r=>a(r),reject:l})});return this.ws.send(JSON.stringify(i)),o}queueConnect(){this.connectNonce=null,this.connectSent=!1,this.connectTimer!==null&&window.clearTimeout(this.connectTimer),this.connectTimer=window.setTimeout(()=>{this.sendConnect()},750)}}function Ts(e){return typeof e=="object"&&e!==null}function zh(e){if(!Ts(e))return null;const t=typeof e.id=="string"?e.id.trim():"",n=e.request;if(!t||!Ts(n))return null;const s=typeof n.command=="string"?n.command.trim():"";if(!s)return null;const i=typeof e.createdAtMs=="number"?e.createdAtMs:0,o=typeof e.expiresAtMs=="number"?e.expiresAtMs:0;return!i||!o?null:{id:t,request:{command:s,cwd:typeof n.cwd=="string"?n.cwd:null,host:typeof n.host=="string"?n.host:null,security:typeof n.security=="string"?n.security:null,ask:typeof n.ask=="string"?n.ask:null,agentId:typeof n.agentId=="string"?n.agentId:null,resolvedPath:typeof n.resolvedPath=="string"?n.resolvedPath:null,sessionKey:typeof n.sessionKey=="string"?n.sessionKey:null},createdAtMs:i,expiresAtMs:o}}function jh(e){if(!Ts(e))return null;const t=typeof e.id=="string"?e.id.trim():"";return t?{id:t,decision:typeof e.decision=="string"?e.decision:null,resolvedBy:typeof e.resolvedBy=="string"?e.resolvedBy:null,ts:typeof e.ts=="number"?e.ts:null}:null}function yr(e){const t=Date.now();return e.filter(n=>n.expiresAtMs>t)}function qh(e,t){const n=yr(e).filter(s=>s.id!==t.id);return n.push(t),n}function Wo(e,t){return yr(e).filter(n=>n.id!==t)}async function wr(e,t){if(!e.client||!e.connected)return;const n=e.sessionKey.trim(),s=n?{sessionKey:n}:{};try{const i=await e.client.request("agent.identity.get",s);if(!i)return;const o=ss(i);e.assistantName=o.name,e.assistantAvatar=o.avatar,e.assistantAgentId=o.agentId??null}catch{}}function es(e,t){const n=(e??"").trim(),s=t.mainSessionKey?.trim();if(!s)return n;if(!n)return s;const i=t.mainKey?.trim()||"main",o=t.defaultAgentId?.trim();return n==="main"||n===i||o&&(n===`agent:${o}:main`||n===`agent:${o}:${i}`)?s:n}function Wh(e,t){if(!t?.mainSessionKey)return;const n=es(e.sessionKey,t),s=es(e.settings.sessionKey,t),i=es(e.settings.lastActiveSessionKey,t),o=n||s||e.sessionKey,a={...e.settings,sessionKey:s||o,lastActiveSessionKey:i||o},l=a.sessionKey!==e.settings.sessionKey||a.lastActiveSessionKey!==e.settings.lastActiveSessionKey;o!==e.sessionKey&&(e.sessionKey=o),l&&ke(e,a)}function $r(e){e.lastError=null,e.hello=null,e.connected=!1,e.execApprovalQueue=[],e.execApprovalError=null,e.client?.stop(),e.client=new Hh({url:e.settings.gatewayUrl,token:e.settings.token.trim()?e.settings.token:void 0,password:e.password.trim()?e.password:void 0,clientName:"pigbot-control-ui",mode:"webchat",onHello:t=>{e.connected=!0,e.lastError=null,e.hello=t,Yh(e,t),wr(e),Fh(e),pn(e,{quiet:!0}),_e(e,{quiet:!0}),Js(e)},onClose:({code:t,reason:n})=>{e.connected=!1,t!==1012&&(e.lastError=`disconnected (${t}): ${n||"no reason"}`)},onEvent:t=>Gh(e,t),onGap:({expected:t,received:n})=>{e.lastError=`event gap detected (expected seq ${t}, got ${n}); refresh recommended`}}),e.client.start()}function Gh(e,t){try{Vh(e,t)}catch(n){console.error("[gateway] handleGatewayEvent error:",t.event,n)}}function Vh(e,t){if(e.eventLogBuffer=[{ts:Date.now(),event:t.event,payload:t.payload},...e.eventLogBuffer].slice(0,250),e.tab==="debug"&&(e.eventLog=e.eventLogBuffer),t.event==="agent"){if(e.onboarding)return;zl(e,t.payload);return}if(t.event==="chat"){const n=t.payload;n?.sessionKey&&La(e,n.sessionKey);const s=Rl(e,n);(s==="final"||s==="error"||s==="aborted")&&(Os(e),kd(e)),s==="final"&&Ze(e);return}if(t.event==="presence"){const n=t.payload;n?.presence&&Array.isArray(n.presence)&&(e.presenceEntries=n.presence,e.presenceError=null,e.presenceStatus=null);return}if(t.event==="cron"&&e.tab==="cron"&&Zs(e),(t.event==="device.pair.requested"||t.event==="device.pair.resolved")&&_e(e,{quiet:!0}),t.event==="exec.approval.requested"){const n=zh(t.payload);if(n){e.execApprovalQueue=qh(e.execApprovalQueue,n),e.execApprovalError=null;const s=Math.max(0,n.expiresAtMs-Date.now()+500);window.setTimeout(()=>{e.execApprovalQueue=Wo(e.execApprovalQueue,n.id)},s)}return}if(t.event==="exec.approval.resolved"){const n=jh(t.payload);n&&(e.execApprovalQueue=Wo(e.execApprovalQueue,n.id))}}function Yh(e,t){const n=t.snapshot;n?.presence&&Array.isArray(n.presence)&&(e.presenceEntries=n.presence),n?.health&&(e.debugHealth=n.health),n?.sessionDefaults&&Wh(e,n.sessionDefaults)}function Qh(e){e.basePath=cd(),fd(e,!0),dd(e),ud(e),window.addEventListener("popstate",e.popStateHandler),ad(e),$r(e),id(e),e.tab==="logs"&&Gs(e),e.tab==="debug"&&Ys(e)}function Jh(e){Vl(e)}function Zh(e){window.removeEventListener("popstate",e.popStateHandler),od(e),Vs(e),Qs(e),pd(e),e.topbarObserver?.disconnect(),e.topbarObserver=null}function Xh(e,t){if(e.tab==="chat"&&(t.has("chatMessages")||t.has("chatToolMessages")||t.has("chatStream")||t.has("chatLoading")||t.has("tab"))){const n=t.has("tab"),s=t.has("chatLoading")&&t.get("chatLoading")===!0&&e.chatLoading===!1;ln(e,n||s||!e.chatHasAutoScrolled)}e.tab==="logs"&&(t.has("logsEntries")||t.has("logsAutoFollow")||t.has("tab"))&&e.logsAutoFollow&&e.logsAtBottom&&ca(e,t.has("tab")||t.has("logsAutoFollow"))}async function eg(e,t){await oc(e,t),await oe(e,!0)}async function tg(e){await ac(e),await oe(e,!0)}async function ng(e){await rc(e),await oe(e,!0)}async function sg(e){await cs(e),await me(e),await oe(e,!0)}async function ig(e){await me(e),await oe(e,!0)}function og(e){if(!Array.isArray(e))return{};const t={};for(const n of e){if(typeof n!="string")continue;const[s,...i]=n.split(":");if(!s||i.length===0)continue;const o=s.trim(),a=i.join(":").trim();o&&a&&(t[o]=a)}return t}function kr(e){return(e.channelsSnapshot?.channelAccounts?.nostr??[])[0]?.accountId??e.nostrProfileAccountId??"default"}function xr(e,t=""){return`/api/channels/nostr/${encodeURIComponent(e)}/profile${t}`}function ag(e,t,n){e.nostrProfileAccountId=t,e.nostrProfileFormState=sf(n??void 0)}function rg(e){e.nostrProfileFormState=null,e.nostrProfileAccountId=null}function lg(e,t,n){const s=e.nostrProfileFormState;s&&(e.nostrProfileFormState={...s,values:{...s.values,[t]:n},fieldErrors:{...s.fieldErrors,[t]:""}})}function cg(e){const t=e.nostrProfileFormState;t&&(e.nostrProfileFormState={...t,showAdvanced:!t.showAdvanced})}async function dg(e){const t=e.nostrProfileFormState;if(!t||t.saving)return;const n=kr(e);e.nostrProfileFormState={...t,saving:!0,error:null,success:null,fieldErrors:{}};try{const s=await fetch(xr(n),{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify(t.values)}),i=await s.json().catch(()=>null);if(!s.ok||i?.ok===!1||!i){const o=i?.error??`Profile update failed (${s.status})`;e.nostrProfileFormState={...t,saving:!1,error:o,success:null,fieldErrors:og(i?.details)};return}if(!i.persisted){e.nostrProfileFormState={...t,saving:!1,error:"Profile publish failed on all relays.",success:null};return}e.nostrProfileFormState={...t,saving:!1,error:null,success:"Profile published to relays.",fieldErrors:{},original:{...t.values}},await oe(e,!0)}catch(s){e.nostrProfileFormState={...t,saving:!1,error:`Profile update failed: ${String(s)}`,success:null}}}async function ug(e){const t=e.nostrProfileFormState;if(!t||t.importing)return;const n=kr(e);e.nostrProfileFormState={...t,importing:!0,error:null,success:null};try{const s=await fetch(xr(n,"/import"),{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({autoMerge:!0})}),i=await s.json().catch(()=>null);if(!s.ok||i?.ok===!1||!i){const r=i?.error??`Profile import failed (${s.status})`;e.nostrProfileFormState={...t,importing:!1,error:r,success:null};return}const o=i.merged??i.imported??null,a=o?{...t.values,...o}:t.values,l=!!(a.banner||a.website||a.nip05||a.lud16);e.nostrProfileFormState={...t,importing:!1,values:a,error:null,success:i.saved?"Profile imported from relays. Review and publish.":"Profile imported. Review and publish.",showAdvanced:l},i.saved&&await oe(e,!0)}catch(s){e.nostrProfileFormState={...t,importing:!1,error:`Profile import failed: ${String(s)}`,success:null}}}var pg=Object.defineProperty,fg=Object.getOwnPropertyDescriptor,b=(e,t,n,s)=>{for(var i=s>1?void 0:s?fg(t,n):t,o=e.length-1,a;o>=0;o--)(a=e[o])&&(i=(s?a(t,n,i):a(i))||i);return s&&i&&pg(t,n,i),i};const ts=pl();function hg(){if(!window.location.search)return!1;const t=new URLSearchParams(window.location.search).get("onboarding");if(!t)return!1;const n=t.trim().toLowerCase();return n==="1"||n==="true"||n==="yes"||n==="on"}let m=class extends Qe{constructor(){super(...arguments),this.settings=fl(),this.password="",this.tab="chat",this.onboarding=hg(),this.connected=!1,this.theme=this.settings.theme??"system",this.themeResolved="dark",this.hello=null,this.lastError=null,this.eventLog=[],this.eventLogBuffer=[],this.toolStreamSyncTimer=null,this.sidebarCloseTimer=null,this.assistantName=ts.name,this.assistantAvatar=ts.avatar,this.assistantAgentId=ts.agentId??null,this.sessionKey=this.settings.sessionKey,this.chatLoading=!1,this.chatSending=!1,this.chatMessage="",this.chatMessages=[],this.chatToolMessages=[],this.chatStream=null,this.chatStreamStartedAt=null,this.chatRunId=null,this.compactionStatus=null,this.chatAvatarUrl=null,this.chatThinkingLevel=null,this.chatQueue=[],this.sidebarOpen=!1,this.sidebarContent=null,this.sidebarError=null,this.splitRatio=this.settings.splitRatio,this.nodesLoading=!1,this.nodes=[],this.devicesLoading=!1,this.devicesError=null,this.devicesList=null,this.execApprovalsLoading=!1,this.execApprovalsSaving=!1,this.execApprovalsDirty=!1,this.execApprovalsSnapshot=null,this.execApprovalsForm=null,this.execApprovalsSelectedAgent=null,this.execApprovalsTarget="gateway",this.execApprovalsTargetNodeId=null,this.execApprovalQueue=[],this.execApprovalBusy=!1,this.execApprovalError=null,this.configLoading=!1,this.configRaw=`{
3109
- }
3110
- `,this.configRawOriginal="",this.configValid=null,this.configIssues=[],this.configSaving=!1,this.configApplying=!1,this.updateRunning=!1,this.applySessionKey=this.settings.lastActiveSessionKey,this.configSnapshot=null,this.configSchema=null,this.configSchemaVersion=null,this.configSchemaLoading=!1,this.configUiHints={},this.configForm=null,this.configFormOriginal=null,this.configFormDirty=!1,this.configFormMode="form",this.configSearchQuery="",this.configActiveSection=null,this.configActiveSubsection=null,this.channelsLoading=!1,this.channelsSnapshot=null,this.channelsError=null,this.channelsLastSuccess=null,this.whatsappLoginMessage=null,this.whatsappLoginQrDataUrl=null,this.whatsappLoginConnected=null,this.whatsappBusy=!1,this.nostrProfileFormState=null,this.nostrProfileAccountId=null,this.presenceLoading=!1,this.presenceEntries=[],this.presenceError=null,this.presenceStatus=null,this.agentsLoading=!1,this.agentsList=null,this.agentsError=null,this.sessionsLoading=!1,this.sessionsResult=null,this.sessionsError=null,this.sessionsFilterActive="",this.sessionsFilterLimit="120",this.sessionsIncludeGlobal=!0,this.sessionsIncludeUnknown=!1,this.cronLoading=!1,this.cronJobs=[],this.cronStatus=null,this.cronError=null,this.cronForm={...Bh},this.cronRunsJobId=null,this.cronRuns=[],this.cronBusy=!1,this.skillsLoading=!1,this.skillsReport=null,this.skillsError=null,this.skillsFilter="",this.skillEdits={},this.skillsBusyKey=null,this.skillMessages={},this.debugLoading=!1,this.debugStatus=null,this.debugHealth=null,this.debugModels=[],this.debugHeartbeat=null,this.debugCallMethod="",this.debugCallParams="{}",this.debugCallResult=null,this.debugCallError=null,this.logsLoading=!1,this.logsError=null,this.logsFile=null,this.logsEntries=[],this.logsFilterText="",this.logsLevelFilters={...Dh},this.logsAutoFollow=!0,this.logsTruncated=!1,this.logsCursor=null,this.logsLastFetchAt=null,this.logsLimit=500,this.logsMaxBytes=25e4,this.logsAtBottom=!0,this.client=null,this.chatScrollFrame=null,this.chatScrollTimeout=null,this.chatHasAutoScrolled=!1,this.chatUserNearBottom=!0,this.nodesPollInterval=null,this.logsPollInterval=null,this.debugPollInterval=null,this.logsScrollFrame=null,this.toolStreamById=new Map,this.toolStreamOrder=[],this.basePath="",this.popStateHandler=()=>hd(this),this.themeMedia=null,this.themeMediaHandler=null,this.topbarObserver=null}createRenderRoot(){return this}connectedCallback(){super.connectedCallback(),Qh(this)}firstUpdated(){Jh(this)}disconnectedCallback(){Zh(this),super.disconnectedCallback()}updated(e){Xh(this,e)}connect(){$r(this)}handleChatScroll(e){jl(this,e)}handleLogsScroll(e){ql(this,e)}exportLogs(e,t){Gl(e,t)}resetToolStream(){Os(this)}resetChatScroll(){Wl(this)}async loadAssistantIdentity(){await wr(this)}applySettings(e){ke(this,e)}setTab(e){rd(this,e)}setTheme(e,t){ld(this,e,t)}async loadOverview(){await Na(this)}async loadCron(){await Zs(this)}async handleAbortChat(){await Da(this)}removeQueuedMessage(e){yd(this,e)}async handleSendChat(e,t){await wd(this,e,t)}async handleWhatsAppStart(e){await eg(this,e)}async handleWhatsAppWait(){await tg(this)}async handleWhatsAppLogout(){await ng(this)}async handleChannelConfigSave(){await sg(this)}async handleChannelConfigReload(){await ig(this)}handleNostrProfileEdit(e,t){ag(this,e,t)}handleNostrProfileCancel(){rg(this)}handleNostrProfileFieldChange(e,t){lg(this,e,t)}async handleNostrProfileSave(){await dg(this)}async handleNostrProfileImport(){await ug(this)}handleNostrProfileToggleAdvanced(){cg(this)}async handleExecApprovalDecision(e){const t=this.execApprovalQueue[0];if(!(!t||!this.client||this.execApprovalBusy)){this.execApprovalBusy=!0,this.execApprovalError=null;try{await this.client.request("exec.approval.resolve",{id:t.id,decision:e}),this.execApprovalQueue=this.execApprovalQueue.filter(n=>n.id!==t.id)}catch(n){this.execApprovalError=`Exec approval failed: ${String(n)}`}finally{this.execApprovalBusy=!1}}}handleOpenSidebar(e){this.sidebarCloseTimer!=null&&(window.clearTimeout(this.sidebarCloseTimer),this.sidebarCloseTimer=null),this.sidebarContent=e,this.sidebarError=null,this.sidebarOpen=!0}handleCloseSidebar(){this.sidebarOpen=!1,this.sidebarCloseTimer!=null&&window.clearTimeout(this.sidebarCloseTimer),this.sidebarCloseTimer=window.setTimeout(()=>{this.sidebarOpen||(this.sidebarContent=null,this.sidebarError=null,this.sidebarCloseTimer=null)},200)}handleSplitRatioChange(e){const t=Math.max(.4,Math.min(.7,e));this.splitRatio=t,this.applySettings({...this.settings,splitRatio:t})}render(){return Oh(this)}};b([y()],m.prototype,"settings",2);b([y()],m.prototype,"password",2);b([y()],m.prototype,"tab",2);b([y()],m.prototype,"onboarding",2);b([y()],m.prototype,"connected",2);b([y()],m.prototype,"theme",2);b([y()],m.prototype,"themeResolved",2);b([y()],m.prototype,"hello",2);b([y()],m.prototype,"lastError",2);b([y()],m.prototype,"eventLog",2);b([y()],m.prototype,"assistantName",2);b([y()],m.prototype,"assistantAvatar",2);b([y()],m.prototype,"assistantAgentId",2);b([y()],m.prototype,"sessionKey",2);b([y()],m.prototype,"chatLoading",2);b([y()],m.prototype,"chatSending",2);b([y()],m.prototype,"chatMessage",2);b([y()],m.prototype,"chatMessages",2);b([y()],m.prototype,"chatToolMessages",2);b([y()],m.prototype,"chatStream",2);b([y()],m.prototype,"chatStreamStartedAt",2);b([y()],m.prototype,"chatRunId",2);b([y()],m.prototype,"compactionStatus",2);b([y()],m.prototype,"chatAvatarUrl",2);b([y()],m.prototype,"chatThinkingLevel",2);b([y()],m.prototype,"chatQueue",2);b([y()],m.prototype,"sidebarOpen",2);b([y()],m.prototype,"sidebarContent",2);b([y()],m.prototype,"sidebarError",2);b([y()],m.prototype,"splitRatio",2);b([y()],m.prototype,"nodesLoading",2);b([y()],m.prototype,"nodes",2);b([y()],m.prototype,"devicesLoading",2);b([y()],m.prototype,"devicesError",2);b([y()],m.prototype,"devicesList",2);b([y()],m.prototype,"execApprovalsLoading",2);b([y()],m.prototype,"execApprovalsSaving",2);b([y()],m.prototype,"execApprovalsDirty",2);b([y()],m.prototype,"execApprovalsSnapshot",2);b([y()],m.prototype,"execApprovalsForm",2);b([y()],m.prototype,"execApprovalsSelectedAgent",2);b([y()],m.prototype,"execApprovalsTarget",2);b([y()],m.prototype,"execApprovalsTargetNodeId",2);b([y()],m.prototype,"execApprovalQueue",2);b([y()],m.prototype,"execApprovalBusy",2);b([y()],m.prototype,"execApprovalError",2);b([y()],m.prototype,"configLoading",2);b([y()],m.prototype,"configRaw",2);b([y()],m.prototype,"configRawOriginal",2);b([y()],m.prototype,"configValid",2);b([y()],m.prototype,"configIssues",2);b([y()],m.prototype,"configSaving",2);b([y()],m.prototype,"configApplying",2);b([y()],m.prototype,"updateRunning",2);b([y()],m.prototype,"applySessionKey",2);b([y()],m.prototype,"configSnapshot",2);b([y()],m.prototype,"configSchema",2);b([y()],m.prototype,"configSchemaVersion",2);b([y()],m.prototype,"configSchemaLoading",2);b([y()],m.prototype,"configUiHints",2);b([y()],m.prototype,"configForm",2);b([y()],m.prototype,"configFormOriginal",2);b([y()],m.prototype,"configFormDirty",2);b([y()],m.prototype,"configFormMode",2);b([y()],m.prototype,"configSearchQuery",2);b([y()],m.prototype,"configActiveSection",2);b([y()],m.prototype,"configActiveSubsection",2);b([y()],m.prototype,"channelsLoading",2);b([y()],m.prototype,"channelsSnapshot",2);b([y()],m.prototype,"channelsError",2);b([y()],m.prototype,"channelsLastSuccess",2);b([y()],m.prototype,"whatsappLoginMessage",2);b([y()],m.prototype,"whatsappLoginQrDataUrl",2);b([y()],m.prototype,"whatsappLoginConnected",2);b([y()],m.prototype,"whatsappBusy",2);b([y()],m.prototype,"nostrProfileFormState",2);b([y()],m.prototype,"nostrProfileAccountId",2);b([y()],m.prototype,"presenceLoading",2);b([y()],m.prototype,"presenceEntries",2);b([y()],m.prototype,"presenceError",2);b([y()],m.prototype,"presenceStatus",2);b([y()],m.prototype,"agentsLoading",2);b([y()],m.prototype,"agentsList",2);b([y()],m.prototype,"agentsError",2);b([y()],m.prototype,"sessionsLoading",2);b([y()],m.prototype,"sessionsResult",2);b([y()],m.prototype,"sessionsError",2);b([y()],m.prototype,"sessionsFilterActive",2);b([y()],m.prototype,"sessionsFilterLimit",2);b([y()],m.prototype,"sessionsIncludeGlobal",2);b([y()],m.prototype,"sessionsIncludeUnknown",2);b([y()],m.prototype,"cronLoading",2);b([y()],m.prototype,"cronJobs",2);b([y()],m.prototype,"cronStatus",2);b([y()],m.prototype,"cronError",2);b([y()],m.prototype,"cronForm",2);b([y()],m.prototype,"cronRunsJobId",2);b([y()],m.prototype,"cronRuns",2);b([y()],m.prototype,"cronBusy",2);b([y()],m.prototype,"skillsLoading",2);b([y()],m.prototype,"skillsReport",2);b([y()],m.prototype,"skillsError",2);b([y()],m.prototype,"skillsFilter",2);b([y()],m.prototype,"skillEdits",2);b([y()],m.prototype,"skillsBusyKey",2);b([y()],m.prototype,"skillMessages",2);b([y()],m.prototype,"debugLoading",2);b([y()],m.prototype,"debugStatus",2);b([y()],m.prototype,"debugHealth",2);b([y()],m.prototype,"debugModels",2);b([y()],m.prototype,"debugHeartbeat",2);b([y()],m.prototype,"debugCallMethod",2);b([y()],m.prototype,"debugCallParams",2);b([y()],m.prototype,"debugCallResult",2);b([y()],m.prototype,"debugCallError",2);b([y()],m.prototype,"logsLoading",2);b([y()],m.prototype,"logsError",2);b([y()],m.prototype,"logsFile",2);b([y()],m.prototype,"logsEntries",2);b([y()],m.prototype,"logsFilterText",2);b([y()],m.prototype,"logsLevelFilters",2);b([y()],m.prototype,"logsAutoFollow",2);b([y()],m.prototype,"logsTruncated",2);b([y()],m.prototype,"logsCursor",2);b([y()],m.prototype,"logsLastFetchAt",2);b([y()],m.prototype,"logsLimit",2);b([y()],m.prototype,"logsMaxBytes",2);b([y()],m.prototype,"logsAtBottom",2);m=b([ea("pigbot-app")],m);
3111
- //# sourceMappingURL=index-DrGg77je.js.map