openclaw-multi-auto 1.3.6 → 1.3.8

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 (328) hide show
  1. package/dist/{audio-preflight-5FEeDooz.js → audio-preflight-DDBLZBdb.js} +4 -4
  2. package/dist/{audio-transcription-runner-B-UvoDjZ.js → audio-transcription-runner-DZbSWT9E.js} +1 -1
  3. package/dist/build-info.json +3 -3
  4. package/dist/canvas-host/a2ui/.bundle.hash +1 -1
  5. package/dist/{chrome-D45SyhQL.js → chrome-CMU2WVFh.js} +8 -8
  6. package/dist/{deliver-B9cys0EZ.js → deliver-BXVcFIHL.js} +1 -1
  7. package/dist/{deliver-runtime-DhaQJ0pI.js → deliver-runtime-DTaIS-1i.js} +3 -3
  8. package/dist/{deps-send-whatsapp.runtime-DvTL2tzN.js → deps-send-whatsapp.runtime-CIZqFAqb.js} +7 -7
  9. package/dist/extensionAPI.js +6 -6
  10. package/dist/{image-DAOPwVXi.js → image-BCVLo0qw.js} +1 -1
  11. package/dist/{image-runtime-wlCLVvVv.js → image-runtime-DtCKpMPZ.js} +3 -3
  12. package/dist/{pi-embedded-DYU79yGe.js → pi-embedded-CgQ_W6Xs.js} +24 -24
  13. package/dist/{pi-embedded-helpers-uTRAmQ4n.js → pi-embedded-helpers-CwuBTKza.js} +3 -3
  14. package/dist/plugin-sdk/{accounts-DyFCXtHv.js → accounts-BslAlVYS.js} +2 -2
  15. package/dist/plugin-sdk/{accounts-BJAXxY46.js → accounts-C3m65--E.js} +2 -2
  16. package/dist/plugin-sdk/{accounts-C1j7HSL0.js → accounts-CNCCkdEF.js} +3 -3
  17. package/dist/plugin-sdk/{active-listener-CftX5jLD.js → active-listener-CkPnMUkB.js} +2 -2
  18. package/dist/plugin-sdk/{api-key-rotation-8nyyt1kx.js → api-key-rotation-BXnNsojA.js} +2 -2
  19. package/dist/plugin-sdk/{audio-preflight-C_aSAPR1.js → audio-preflight-CtO4fFvp.js} +26 -26
  20. package/dist/plugin-sdk/{audio-transcription-runner-CB53F7_7.js → audio-transcription-runner-DnxvOS1-.js} +11 -11
  21. package/dist/plugin-sdk/{audit-membership-runtime-BXndI4LG.js → audit-membership-runtime-BpfoSk8M.js} +2 -2
  22. package/dist/plugin-sdk/{channel-activity-C5y8AgAV.js → channel-activity-WJYxcJ3S.js} +3 -3
  23. package/dist/plugin-sdk/{channel-web-DBTRO03V.js → channel-web-dO5k3ubM.js} +18 -18
  24. package/dist/plugin-sdk/{chrome-f00sZkDX.js → chrome-CjNTuJML.js} +6 -6
  25. package/dist/plugin-sdk/{commands-registry-BJ_NxG2F.js → commands-registry-CdYjoI0i.js} +4 -4
  26. package/dist/plugin-sdk/{common-Cf27Jwxu.js → common-oYc5vPFl.js} +2 -2
  27. package/dist/plugin-sdk/{config-CHQrpx-Q.js → config-B1z-UxQ3.js} +7 -7
  28. package/dist/plugin-sdk/{deliver-DNEuetST.js → deliver-D5_6T567.js} +10 -10
  29. package/dist/plugin-sdk/deliver-runtime-C5dgvvga.js +32 -0
  30. package/dist/plugin-sdk/deps-send-discord.runtime-Dg4N7PHJ.js +23 -0
  31. package/dist/plugin-sdk/deps-send-imessage.runtime-0OEwzMQm.js +22 -0
  32. package/dist/plugin-sdk/deps-send-signal.runtime-BM1jRt3G.js +21 -0
  33. package/dist/plugin-sdk/deps-send-slack.runtime-1E3BYRdF.js +19 -0
  34. package/dist/plugin-sdk/deps-send-telegram.runtime-DNCxIflA.js +24 -0
  35. package/dist/plugin-sdk/deps-send-whatsapp.runtime-OLwr-9c8.js +57 -0
  36. package/dist/plugin-sdk/{diagnostic-LYUUmjJ5.js → diagnostic-Bxxu0ig-.js} +2 -2
  37. package/dist/plugin-sdk/{errors-CtMWwS2Z.js → errors-B3cHyZZA.js} +1 -1
  38. package/dist/plugin-sdk/{fetch-guard-CxYB5Kg6.js → fetch-guard-Dcgod0tg.js} +2 -2
  39. package/dist/plugin-sdk/{fs-safe-DtfhxbrI.js → fs-safe-BaKqI3G4.js} +3 -3
  40. package/dist/plugin-sdk/{image-BwjYjRHx.js → image-B2mQW9Rb.js} +6 -6
  41. package/dist/plugin-sdk/{image-ops-BnZKcbd6.js → image-ops-Cbzr4U9l.js} +2 -2
  42. package/dist/plugin-sdk/image-runtime-BFm45j49.js +25 -0
  43. package/dist/plugin-sdk/{ir-Z4hX67TJ.js → ir-ZEmrTr4J.js} +7 -7
  44. package/dist/plugin-sdk/{local-roots-KhjQw04O.js → local-roots-CIPRxA-4.js} +4 -4
  45. package/dist/plugin-sdk/{logger-DHIIvMxj.js → logger-CvPFVOgT.js} +2 -2
  46. package/dist/plugin-sdk/{login-C31642Ld.js → login-CCTew9bt.js} +4 -4
  47. package/dist/plugin-sdk/{login-qr--y2SG_Ue.js → login-qr-BI3Vi_wJ.js} +5 -5
  48. package/dist/plugin-sdk/{manager-2UZBMCc7.js → manager-BEoYPn7R.js} +8 -8
  49. package/dist/plugin-sdk/manager-runtime-DxclHQ4U.js +15 -0
  50. package/dist/plugin-sdk/{outbound-Ba0QUI5h.js → outbound-ByOw1K6W.js} +5 -5
  51. package/dist/plugin-sdk/{outbound-attachment-B1Laso-8.js → outbound-attachment-BzVhxRRw.js} +2 -2
  52. package/dist/plugin-sdk/{path-alias-guards-C7Vm5DZ1.js → path-alias-guards-sWayacde.js} +1 -1
  53. package/dist/plugin-sdk/{paths-DopV9PQG.js → paths-Dpg3qxcl.js} +1 -1
  54. package/dist/plugin-sdk/{pi-embedded-helpers-DnA_OCzP.js → pi-embedded-helpers-DIxXkGJf.js} +16 -16
  55. package/dist/plugin-sdk/{pi-model-discovery-DdPqXk8f.js → pi-model-discovery-DM_2uFtj.js} +1 -1
  56. package/dist/plugin-sdk/pi-model-discovery-runtime-BuzvkvNR.js +8 -0
  57. package/dist/plugin-sdk/{pi-tools.before-tool-call.runtime-DxFHiLUE.js → pi-tools.before-tool-call.runtime-w1dqL_ty.js} +4 -4
  58. package/dist/plugin-sdk/{plugins-CbCt4osF.js → plugins-C4USiH29.js} +4 -4
  59. package/dist/plugin-sdk/{proxy-env-C63mMdas.js → proxy-env-ET-rp8eg.js} +1 -1
  60. package/dist/plugin-sdk/{proxy-fetch-Ch95c_Y2.js → proxy-fetch-uDXGKG3Z.js} +1 -1
  61. package/dist/plugin-sdk/{pw-ai-DpJk62D4.js → pw-ai-CyOt3RDA.js} +9 -9
  62. package/dist/plugin-sdk/{qmd-manager-Ca-iSfEE.js → qmd-manager-BySdoVR7.js} +7 -7
  63. package/dist/plugin-sdk/{query-expansion-B_Xe41Ab.js → query-expansion-C6uS-7lj.js} +4 -4
  64. package/dist/plugin-sdk/{redact-hp9TOulW.js → redact-Bvxt1T_Q.js} +1 -1
  65. package/dist/plugin-sdk/{reply-CovBlFea.js → reply-CTCSeQqW.js} +73 -73
  66. package/dist/plugin-sdk/{resolve-outbound-target-BbrHgyUk.js → resolve-outbound-target-Bw8YNANu.js} +2 -2
  67. package/dist/plugin-sdk/{run-with-concurrency-BR1DXa8T.js → run-with-concurrency-C_KCHwvf.js} +1 -1
  68. package/dist/plugin-sdk/runtime-whatsapp-login.runtime-BxgRDkhc.js +10 -0
  69. package/dist/plugin-sdk/runtime-whatsapp-outbound.runtime-elOqrkfg.js +19 -0
  70. package/dist/plugin-sdk/{send-BvAtLLPl.js → send-BZ6nYFZr.js} +5 -5
  71. package/dist/plugin-sdk/{send-BTztm3D2.js → send-C0w6xP2x.js} +6 -6
  72. package/dist/plugin-sdk/{send-CWJUuG0i.js → send-CFf-1V89.js} +8 -8
  73. package/dist/plugin-sdk/{send-EcglC4cG.js → send-CY-Qfwia.js} +7 -7
  74. package/dist/plugin-sdk/{send-BXpXBwM_.js → send-qPyNGSe4.js} +13 -13
  75. package/dist/plugin-sdk/{session-k256LJZT.js → session-COrvpvUQ.js} +3 -3
  76. package/dist/plugin-sdk/signal.js +2 -2
  77. package/dist/plugin-sdk/{skill-commands-DoRqLzxm.js → skill-commands-DZqhtmiv.js} +4 -4
  78. package/dist/plugin-sdk/{skills-QudILG6e.js → skills-Cw_vXEJb.js} +6 -6
  79. package/dist/plugin-sdk/slash-commands.runtime-D67JLweo.js +13 -0
  80. package/dist/plugin-sdk/slash-dispatch.runtime-DvcpvCJ0.js +52 -0
  81. package/dist/plugin-sdk/slash-skill-commands.runtime-BM1x3azR.js +16 -0
  82. package/dist/plugin-sdk/{store-BbDQw3g6.js → store-CMHj6IIw.js} +2 -2
  83. package/dist/plugin-sdk/subagent-registry-runtime-1lbDyRzz.js +52 -0
  84. package/dist/plugin-sdk/{tables-BhvloMKN.js → tables-CSqrHsKL.js} +1 -1
  85. package/dist/plugin-sdk/{thinking-URzkT-3p.js → thinking-DOnsR_A8.js} +7 -7
  86. package/dist/plugin-sdk/{tokens-B1PW5Ayy.js → tokens-BDr0Z9o3.js} +1 -1
  87. package/dist/plugin-sdk/{tool-images-xpqbP6RR.js → tool-images-eEfOVkzf.js} +2 -2
  88. package/dist/plugin-sdk/web-BLyT64pW.js +56 -0
  89. package/dist/plugin-sdk/{whatsapp-actions-RcZ6vp61.js → whatsapp-actions-xcleMoMv.js} +17 -17
  90. package/dist/plugin-sdk/whatsapp.js +50 -50
  91. package/dist/{pw-ai-GcYO6HPE.js → pw-ai-CmphSzHx.js} +1 -1
  92. package/dist/{slash-dispatch.runtime-Dh053pQK.js → slash-dispatch.runtime-131yup2e.js} +6 -6
  93. package/dist/{subagent-registry-runtime-DSi5mnCQ.js → subagent-registry-runtime-DbSf_Je6.js} +6 -6
  94. package/dist/{web-1hWJDzNA.js → web-MR9d7KyB.js} +6 -6
  95. package/package.json +5 -2
  96. package/scripts/create-instance.sh +44 -19
  97. package/scripts/install-maca.sh +39 -28
  98. package/scripts/npm_publish.sh +8 -6
  99. package/ui/index.html +16 -0
  100. package/ui/node_modules/.bin/jiti +21 -0
  101. package/ui/node_modules/.bin/lessc +21 -0
  102. package/ui/node_modules/.bin/marked +21 -0
  103. package/ui/node_modules/.bin/playwright +21 -0
  104. package/ui/node_modules/.bin/sass +21 -0
  105. package/ui/node_modules/.bin/tsx +21 -0
  106. package/ui/node_modules/.bin/vite +21 -0
  107. package/ui/node_modules/.bin/vitest +21 -0
  108. package/ui/node_modules/.bin/yaml +21 -0
  109. package/ui/package.json +27 -0
  110. package/ui/public/apple-touch-icon.png +0 -0
  111. package/ui/public/favicon-32.png +0 -0
  112. package/ui/public/favicon.ico +0 -0
  113. package/ui/public/favicon.svg +22 -0
  114. package/ui/src/css.d.ts +1 -0
  115. package/ui/src/i18n/index.ts +3 -0
  116. package/ui/src/i18n/lib/lit-controller.ts +22 -0
  117. package/ui/src/i18n/lib/registry.ts +64 -0
  118. package/ui/src/i18n/lib/translate.ts +123 -0
  119. package/ui/src/i18n/lib/types.ts +9 -0
  120. package/ui/src/i18n/locales/de.ts +129 -0
  121. package/ui/src/i18n/locales/en.ts +337 -0
  122. package/ui/src/i18n/locales/pt-BR.ts +128 -0
  123. package/ui/src/i18n/locales/zh-CN.ts +330 -0
  124. package/ui/src/i18n/locales/zh-TW.ts +125 -0
  125. package/ui/src/i18n/test/translate.test.ts +56 -0
  126. package/ui/src/main.ts +2 -0
  127. package/ui/src/styles/base.css +385 -0
  128. package/ui/src/styles/chat/grouped.css +300 -0
  129. package/ui/src/styles/chat/layout.css +481 -0
  130. package/ui/src/styles/chat/sidebar.css +117 -0
  131. package/ui/src/styles/chat/text.css +146 -0
  132. package/ui/src/styles/chat/tool-cards.css +202 -0
  133. package/ui/src/styles/chat.css +5 -0
  134. package/ui/src/styles/components.css +2612 -0
  135. package/ui/src/styles/config.css +1658 -0
  136. package/ui/src/styles/layout.css +621 -0
  137. package/ui/src/styles/layout.mobile.css +374 -0
  138. package/ui/src/styles.css +5 -0
  139. package/ui/src/ui/__screenshots__/config-form.browser.test.ts/config-form-renderer-flags-unsupported-unions-1.png +0 -0
  140. package/ui/src/ui/__screenshots__/config-form.browser.test.ts/config-form-renderer-renders-inputs-and-patches-values-1.png +0 -0
  141. package/ui/src/ui/__screenshots__/config-form.browser.test.ts/config-form-renderer-renders-union-literals-as-select-options-1.png +0 -0
  142. package/ui/src/ui/__screenshots__/navigation.browser.test.ts/control-UI-routing-auto-scrolls-chat-history-to-the-latest-message-1.png +0 -0
  143. package/ui/src/ui/app-channels.ts +279 -0
  144. package/ui/src/ui/app-chat.ts +266 -0
  145. package/ui/src/ui/app-defaults.ts +50 -0
  146. package/ui/src/ui/app-events.ts +5 -0
  147. package/ui/src/ui/app-gateway.node.test.ts +229 -0
  148. package/ui/src/ui/app-gateway.ts +349 -0
  149. package/ui/src/ui/app-lifecycle.node.test.ts +44 -0
  150. package/ui/src/ui/app-lifecycle.ts +109 -0
  151. package/ui/src/ui/app-polling.ts +69 -0
  152. package/ui/src/ui/app-render-usage-tab.ts +273 -0
  153. package/ui/src/ui/app-render.helpers.node.test.ts +286 -0
  154. package/ui/src/ui/app-render.helpers.ts +574 -0
  155. package/ui/src/ui/app-render.ts +1168 -0
  156. package/ui/src/ui/app-scroll.test.ts +275 -0
  157. package/ui/src/ui/app-scroll.ts +179 -0
  158. package/ui/src/ui/app-settings.test.ts +70 -0
  159. package/ui/src/ui/app-settings.ts +440 -0
  160. package/ui/src/ui/app-tool-stream.node.test.ts +139 -0
  161. package/ui/src/ui/app-tool-stream.ts +455 -0
  162. package/ui/src/ui/app-view-state.ts +321 -0
  163. package/ui/src/ui/app.ts +621 -0
  164. package/ui/src/ui/assistant-identity.ts +23 -0
  165. package/ui/src/ui/chat/constants.ts +12 -0
  166. package/ui/src/ui/chat/copy-as-markdown.ts +97 -0
  167. package/ui/src/ui/chat/grouped-render.ts +287 -0
  168. package/ui/src/ui/chat/message-extract.test.ts +64 -0
  169. package/ui/src/ui/chat/message-extract.ts +122 -0
  170. package/ui/src/ui/chat/message-normalizer.test.ts +179 -0
  171. package/ui/src/ui/chat/message-normalizer.ts +101 -0
  172. package/ui/src/ui/chat/tool-cards.ts +156 -0
  173. package/ui/src/ui/chat/tool-helpers.test.ts +141 -0
  174. package/ui/src/ui/chat/tool-helpers.ts +37 -0
  175. package/ui/src/ui/chat-event-reload.test.ts +47 -0
  176. package/ui/src/ui/chat-event-reload.ts +16 -0
  177. package/ui/src/ui/chat-markdown.browser.test.ts +37 -0
  178. package/ui/src/ui/components/resizable-divider.ts +110 -0
  179. package/ui/src/ui/config-form.browser.test.ts +443 -0
  180. package/ui/src/ui/controllers/agent-files.ts +126 -0
  181. package/ui/src/ui/controllers/agent-identity.ts +59 -0
  182. package/ui/src/ui/controllers/agent-skills.ts +33 -0
  183. package/ui/src/ui/controllers/agents.test.ts +61 -0
  184. package/ui/src/ui/controllers/agents.ts +64 -0
  185. package/ui/src/ui/controllers/assistant-identity.ts +34 -0
  186. package/ui/src/ui/controllers/channels.ts +94 -0
  187. package/ui/src/ui/controllers/channels.types.ts +15 -0
  188. package/ui/src/ui/controllers/chat.test.ts +568 -0
  189. package/ui/src/ui/controllers/chat.ts +318 -0
  190. package/ui/src/ui/controllers/config/form-coerce.ts +160 -0
  191. package/ui/src/ui/controllers/config/form-utils.node.test.ts +455 -0
  192. package/ui/src/ui/controllers/config/form-utils.ts +90 -0
  193. package/ui/src/ui/controllers/config.test.ts +289 -0
  194. package/ui/src/ui/controllers/config.ts +219 -0
  195. package/ui/src/ui/controllers/control-ui-bootstrap.test.ts +82 -0
  196. package/ui/src/ui/controllers/control-ui-bootstrap.ts +49 -0
  197. package/ui/src/ui/controllers/cron-filters.test.ts +81 -0
  198. package/ui/src/ui/controllers/cron.test.ts +1070 -0
  199. package/ui/src/ui/controllers/cron.ts +921 -0
  200. package/ui/src/ui/controllers/debug.ts +60 -0
  201. package/ui/src/ui/controllers/devices.ts +159 -0
  202. package/ui/src/ui/controllers/exec-approval.ts +100 -0
  203. package/ui/src/ui/controllers/exec-approvals.ts +170 -0
  204. package/ui/src/ui/controllers/logs.ts +147 -0
  205. package/ui/src/ui/controllers/nodes.ts +32 -0
  206. package/ui/src/ui/controllers/presence.ts +37 -0
  207. package/ui/src/ui/controllers/sessions.test.ts +104 -0
  208. package/ui/src/ui/controllers/sessions.ts +127 -0
  209. package/ui/src/ui/controllers/skills.ts +157 -0
  210. package/ui/src/ui/controllers/usage.node.test.ts +181 -0
  211. package/ui/src/ui/controllers/usage.ts +315 -0
  212. package/ui/src/ui/data/moonshot-kimi-k2.ts +45 -0
  213. package/ui/src/ui/device-auth.ts +73 -0
  214. package/ui/src/ui/device-identity.ts +112 -0
  215. package/ui/src/ui/external-link.test.ts +18 -0
  216. package/ui/src/ui/external-link.ts +19 -0
  217. package/ui/src/ui/focus-mode.browser.test.ts +39 -0
  218. package/ui/src/ui/format.test.ts +101 -0
  219. package/ui/src/ui/format.ts +60 -0
  220. package/ui/src/ui/gateway.ts +360 -0
  221. package/ui/src/ui/icons.ts +256 -0
  222. package/ui/src/ui/markdown.test.ts +85 -0
  223. package/ui/src/ui/markdown.ts +139 -0
  224. package/ui/src/ui/navigation.browser.test.ts +188 -0
  225. package/ui/src/ui/navigation.test.ts +189 -0
  226. package/ui/src/ui/navigation.ts +165 -0
  227. package/ui/src/ui/open-external-url.test.ts +108 -0
  228. package/ui/src/ui/open-external-url.ts +73 -0
  229. package/ui/src/ui/presenter.ts +85 -0
  230. package/ui/src/ui/storage.node.test.ts +63 -0
  231. package/ui/src/ui/storage.ts +99 -0
  232. package/ui/src/ui/test-helpers/app-mount.ts +27 -0
  233. package/ui/src/ui/text-direction.test.ts +24 -0
  234. package/ui/src/ui/text-direction.ts +30 -0
  235. package/ui/src/ui/theme-transition.ts +109 -0
  236. package/ui/src/ui/theme.ts +16 -0
  237. package/ui/src/ui/tool-display.ts +159 -0
  238. package/ui/src/ui/types/chat-types.ts +44 -0
  239. package/ui/src/ui/types.ts +627 -0
  240. package/ui/src/ui/ui-types.ts +54 -0
  241. package/ui/src/ui/usage-helpers.node.test.ts +43 -0
  242. package/ui/src/ui/usage-helpers.ts +321 -0
  243. package/ui/src/ui/usage-types.ts +22 -0
  244. package/ui/src/ui/uuid.test.ts +41 -0
  245. package/ui/src/ui/uuid.ts +57 -0
  246. package/ui/src/ui/views/agents-panels-status-files.ts +461 -0
  247. package/ui/src/ui/views/agents-panels-tools-skills.browser.test.ts +102 -0
  248. package/ui/src/ui/views/agents-panels-tools-skills.ts +537 -0
  249. package/ui/src/ui/views/agents-utils.test.ts +100 -0
  250. package/ui/src/ui/views/agents-utils.ts +502 -0
  251. package/ui/src/ui/views/agents.ts +499 -0
  252. package/ui/src/ui/views/channel-config-extras.ts +49 -0
  253. package/ui/src/ui/views/channels.config.ts +155 -0
  254. package/ui/src/ui/views/channels.discord.ts +65 -0
  255. package/ui/src/ui/views/channels.googlechat.ts +79 -0
  256. package/ui/src/ui/views/channels.imessage.ts +65 -0
  257. package/ui/src/ui/views/channels.nostr-profile-form.ts +321 -0
  258. package/ui/src/ui/views/channels.nostr.ts +237 -0
  259. package/ui/src/ui/views/channels.shared.ts +38 -0
  260. package/ui/src/ui/views/channels.signal.ts +69 -0
  261. package/ui/src/ui/views/channels.slack.ts +65 -0
  262. package/ui/src/ui/views/channels.telegram.ts +120 -0
  263. package/ui/src/ui/views/channels.ts +325 -0
  264. package/ui/src/ui/views/channels.types.ts +62 -0
  265. package/ui/src/ui/views/channels.whatsapp.ts +118 -0
  266. package/ui/src/ui/views/chat-image-open.browser.test.ts +70 -0
  267. package/ui/src/ui/views/chat.test.ts +227 -0
  268. package/ui/src/ui/views/chat.ts +616 -0
  269. package/ui/src/ui/views/config-form.analyze.ts +267 -0
  270. package/ui/src/ui/views/config-form.node.ts +1073 -0
  271. package/ui/src/ui/views/config-form.render.ts +478 -0
  272. package/ui/src/ui/views/config-form.search.node.test.ts +69 -0
  273. package/ui/src/ui/views/config-form.shared.ts +96 -0
  274. package/ui/src/ui/views/config-form.ts +4 -0
  275. package/ui/src/ui/views/config-search.node.test.ts +50 -0
  276. package/ui/src/ui/views/config-search.ts +92 -0
  277. package/ui/src/ui/views/config.browser.test.ts +233 -0
  278. package/ui/src/ui/views/config.ts +820 -0
  279. package/ui/src/ui/views/cron.test.ts +741 -0
  280. package/ui/src/ui/views/cron.ts +1758 -0
  281. package/ui/src/ui/views/debug.ts +151 -0
  282. package/ui/src/ui/views/exec-approval.ts +89 -0
  283. package/ui/src/ui/views/gateway-url-confirmation.ts +40 -0
  284. package/ui/src/ui/views/instances.ts +89 -0
  285. package/ui/src/ui/views/logs.ts +155 -0
  286. package/ui/src/ui/views/markdown-sidebar.ts +40 -0
  287. package/ui/src/ui/views/nodes-exec-approvals.ts +617 -0
  288. package/ui/src/ui/views/nodes-shared.ts +67 -0
  289. package/ui/src/ui/views/nodes.ts +485 -0
  290. package/ui/src/ui/views/overview-hints.ts +16 -0
  291. package/ui/src/ui/views/overview.node.test.ts +39 -0
  292. package/ui/src/ui/views/overview.ts +361 -0
  293. package/ui/src/ui/views/sessions.test.ts +81 -0
  294. package/ui/src/ui/views/sessions.ts +321 -0
  295. package/ui/src/ui/views/skills-grouping.ts +40 -0
  296. package/ui/src/ui/views/skills-shared.ts +52 -0
  297. package/ui/src/ui/views/skills.ts +192 -0
  298. package/ui/src/ui/views/usage-metrics.ts +578 -0
  299. package/ui/src/ui/views/usage-query.ts +277 -0
  300. package/ui/src/ui/views/usage-render-details.test.ts +136 -0
  301. package/ui/src/ui/views/usage-render-details.ts +1083 -0
  302. package/ui/src/ui/views/usage-render-overview.ts +796 -0
  303. package/ui/src/ui/views/usage-styles/usageStyles-part1.ts +701 -0
  304. package/ui/src/ui/views/usage-styles/usageStyles-part2.ts +702 -0
  305. package/ui/src/ui/views/usage-styles/usageStyles-part3.ts +551 -0
  306. package/ui/src/ui/views/usage.ts +836 -0
  307. package/ui/src/ui/views/usageStyles.ts +5 -0
  308. package/ui/src/ui/views/usageTypes.ts +105 -0
  309. package/ui/vite.config.ts +43 -0
  310. package/ui/vitest.config.ts +15 -0
  311. package/ui/vitest.node.config.ts +10 -0
  312. package/dist/plugin-sdk/deliver-runtime-BFdqklJM.js +0 -32
  313. package/dist/plugin-sdk/deps-send-discord.runtime-DuqpYwU0.js +0 -23
  314. package/dist/plugin-sdk/deps-send-imessage.runtime-CZ2rS8Lb.js +0 -22
  315. package/dist/plugin-sdk/deps-send-signal.runtime-BdqiWhIh.js +0 -21
  316. package/dist/plugin-sdk/deps-send-slack.runtime-04s36qiC.js +0 -19
  317. package/dist/plugin-sdk/deps-send-telegram.runtime-LE5tkPvr.js +0 -24
  318. package/dist/plugin-sdk/deps-send-whatsapp.runtime-Bz57lobC.js +0 -57
  319. package/dist/plugin-sdk/image-runtime-B8twoubs.js +0 -25
  320. package/dist/plugin-sdk/manager-runtime-CMeLwose.js +0 -15
  321. package/dist/plugin-sdk/pi-model-discovery-runtime-D8CJhtJY.js +0 -8
  322. package/dist/plugin-sdk/runtime-whatsapp-login.runtime-SkO91TZH.js +0 -10
  323. package/dist/plugin-sdk/runtime-whatsapp-outbound.runtime-B0VWK5hm.js +0 -19
  324. package/dist/plugin-sdk/slash-commands.runtime-DS6vCNSL.js +0 -13
  325. package/dist/plugin-sdk/slash-dispatch.runtime-BXrxb2wd.js +0 -52
  326. package/dist/plugin-sdk/slash-skill-commands.runtime-Bd6qQ2oT.js +0 -16
  327. package/dist/plugin-sdk/subagent-registry-runtime-1uwQbuXj.js +0 -52
  328. package/dist/plugin-sdk/web-B74yhL2N.js +0 -56
@@ -0,0 +1,702 @@
1
+ export const usageStylesPart2 = `
2
+ .usage-list-item .muted {
3
+ font-size: 11px;
4
+ }
5
+ .usage-error-list {
6
+ display: flex;
7
+ flex-direction: column;
8
+ gap: 10px;
9
+ }
10
+ .usage-error-row {
11
+ display: grid;
12
+ grid-template-columns: 1fr auto;
13
+ gap: 8px;
14
+ align-items: center;
15
+ font-size: 12px;
16
+ }
17
+ .usage-error-date {
18
+ font-weight: 600;
19
+ }
20
+ .usage-error-rate {
21
+ font-variant-numeric: tabular-nums;
22
+ }
23
+ .usage-error-sub {
24
+ grid-column: 1 / -1;
25
+ font-size: 11px;
26
+ color: var(--muted);
27
+ }
28
+ .usage-badges {
29
+ display: flex;
30
+ flex-wrap: wrap;
31
+ gap: 6px;
32
+ margin-bottom: 8px;
33
+ }
34
+ .usage-badge {
35
+ display: inline-flex;
36
+ align-items: center;
37
+ gap: 6px;
38
+ padding: 2px 8px;
39
+ border: 1px solid var(--border);
40
+ border-radius: 999px;
41
+ font-size: 11px;
42
+ background: var(--bg);
43
+ color: var(--text);
44
+ }
45
+ .usage-meta-grid {
46
+ display: grid;
47
+ grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
48
+ gap: 12px;
49
+ }
50
+ .usage-meta-item {
51
+ display: flex;
52
+ flex-direction: column;
53
+ gap: 4px;
54
+ font-size: 12px;
55
+ }
56
+ .usage-meta-item span {
57
+ color: var(--muted);
58
+ font-size: 11px;
59
+ }
60
+ .usage-insights-grid {
61
+ display: grid;
62
+ grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
63
+ gap: 16px;
64
+ margin-top: 12px;
65
+ }
66
+ .usage-insight-card {
67
+ padding: 14px;
68
+ border-radius: 10px;
69
+ border: 1px solid var(--border);
70
+ background: var(--bg-secondary);
71
+ }
72
+ .usage-insight-title {
73
+ font-size: 12px;
74
+ font-weight: 600;
75
+ margin-bottom: 10px;
76
+ }
77
+ .usage-insight-subtitle {
78
+ font-size: 11px;
79
+ color: var(--muted);
80
+ margin-top: 6px;
81
+ }
82
+ /* ===== CHART TOGGLE ===== */
83
+ .chart-toggle {
84
+ display: flex;
85
+ background: var(--bg);
86
+ border-radius: 6px;
87
+ overflow: hidden;
88
+ border: 1px solid var(--border);
89
+ }
90
+ .chart-toggle .toggle-btn {
91
+ padding: 6px 14px;
92
+ font-size: 13px;
93
+ background: transparent;
94
+ border: none;
95
+ color: var(--muted);
96
+ cursor: pointer;
97
+ transition: all 0.15s;
98
+ }
99
+ .chart-toggle .toggle-btn:hover {
100
+ color: var(--text);
101
+ }
102
+ .chart-toggle .toggle-btn.active {
103
+ background: #ff4d4d;
104
+ color: white;
105
+ }
106
+ .chart-toggle.small .toggle-btn {
107
+ padding: 4px 8px;
108
+ font-size: 11px;
109
+ }
110
+ .sessions-toggle {
111
+ border-radius: 4px;
112
+ }
113
+ .sessions-toggle .toggle-btn {
114
+ border-radius: 4px;
115
+ }
116
+ .daily-chart-header {
117
+ display: flex;
118
+ align-items: center;
119
+ justify-content: flex-start;
120
+ gap: 8px;
121
+ margin-bottom: 6px;
122
+ }
123
+
124
+ /* ===== DAILY BAR CHART ===== */
125
+ .daily-chart {
126
+ margin-top: 12px;
127
+ }
128
+ .daily-chart-bars {
129
+ display: flex;
130
+ align-items: flex-end;
131
+ height: 200px;
132
+ gap: 4px;
133
+ padding: 8px 4px 36px;
134
+ }
135
+ .daily-bar-wrapper {
136
+ flex: 1;
137
+ display: flex;
138
+ flex-direction: column;
139
+ align-items: center;
140
+ height: 100%;
141
+ justify-content: flex-end;
142
+ cursor: pointer;
143
+ position: relative;
144
+ border-radius: 4px 4px 0 0;
145
+ transition: background 0.15s;
146
+ min-width: 0;
147
+ }
148
+ .daily-bar-wrapper:hover {
149
+ background: var(--bg-hover);
150
+ }
151
+ .daily-bar-wrapper.selected {
152
+ background: var(--accent-subtle);
153
+ }
154
+ .daily-bar-wrapper.selected .daily-bar {
155
+ background: var(--accent);
156
+ }
157
+ .daily-bar {
158
+ width: 100%;
159
+ max-width: var(--bar-max-width, 32px);
160
+ background: #ff4d4d;
161
+ border-radius: 3px 3px 0 0;
162
+ min-height: 2px;
163
+ transition: all 0.15s;
164
+ overflow: hidden;
165
+ }
166
+ .daily-bar-wrapper:hover .daily-bar {
167
+ background: #cc3d3d;
168
+ }
169
+ .daily-bar-label {
170
+ position: absolute;
171
+ bottom: -28px;
172
+ font-size: 10px;
173
+ color: var(--muted);
174
+ white-space: nowrap;
175
+ text-align: center;
176
+ transform: rotate(-35deg);
177
+ transform-origin: top center;
178
+ }
179
+ .daily-bar-total {
180
+ position: absolute;
181
+ top: -16px;
182
+ left: 50%;
183
+ transform: translateX(-50%);
184
+ font-size: 10px;
185
+ color: var(--muted);
186
+ white-space: nowrap;
187
+ }
188
+ .daily-bar-tooltip {
189
+ position: absolute;
190
+ bottom: calc(100% + 8px);
191
+ left: 50%;
192
+ transform: translateX(-50%);
193
+ background: var(--bg);
194
+ border: 1px solid var(--border);
195
+ border-radius: 6px;
196
+ padding: 8px 12px;
197
+ font-size: 12px;
198
+ white-space: nowrap;
199
+ z-index: 100;
200
+ box-shadow: 0 4px 12px rgba(0,0,0,0.15);
201
+ pointer-events: none;
202
+ opacity: 0;
203
+ transition: opacity 0.15s;
204
+ }
205
+ .daily-bar-wrapper:hover .daily-bar-tooltip {
206
+ opacity: 1;
207
+ }
208
+
209
+ /* ===== COST/TOKEN BREAKDOWN BAR ===== */
210
+ .cost-breakdown {
211
+ margin-top: 18px;
212
+ padding: 16px;
213
+ background: var(--bg-secondary);
214
+ border-radius: 8px;
215
+ }
216
+ .cost-breakdown-header {
217
+ font-weight: 600;
218
+ font-size: 15px;
219
+ letter-spacing: -0.02em;
220
+ margin-bottom: 12px;
221
+ color: var(--text-strong);
222
+ }
223
+ .cost-breakdown-bar {
224
+ height: 28px;
225
+ background: var(--bg);
226
+ border-radius: 6px;
227
+ overflow: hidden;
228
+ display: flex;
229
+ }
230
+ .cost-segment {
231
+ height: 100%;
232
+ transition: width 0.3s ease;
233
+ position: relative;
234
+ }
235
+ .cost-segment.output {
236
+ background: #ef4444;
237
+ }
238
+ .cost-segment.input {
239
+ background: #f59e0b;
240
+ }
241
+ .cost-segment.cache-write {
242
+ background: #10b981;
243
+ }
244
+ .cost-segment.cache-read {
245
+ background: #06b6d4;
246
+ }
247
+ .cost-breakdown-legend {
248
+ display: flex;
249
+ flex-wrap: wrap;
250
+ gap: 16px;
251
+ margin-top: 12px;
252
+ }
253
+ .cost-breakdown-total {
254
+ margin-top: 10px;
255
+ font-size: 12px;
256
+ color: var(--muted);
257
+ }
258
+ .legend-item {
259
+ display: flex;
260
+ align-items: center;
261
+ gap: 6px;
262
+ font-size: 12px;
263
+ color: var(--text);
264
+ cursor: help;
265
+ }
266
+ .legend-dot {
267
+ width: 10px;
268
+ height: 10px;
269
+ border-radius: 2px;
270
+ flex-shrink: 0;
271
+ }
272
+ .legend-dot.output {
273
+ background: #ef4444;
274
+ }
275
+ .legend-dot.input {
276
+ background: #f59e0b;
277
+ }
278
+ .legend-dot.cache-write {
279
+ background: #10b981;
280
+ }
281
+ .legend-dot.cache-read {
282
+ background: #06b6d4;
283
+ }
284
+ .legend-dot.system {
285
+ background: #ff4d4d;
286
+ }
287
+ .legend-dot.skills {
288
+ background: #8b5cf6;
289
+ }
290
+ .legend-dot.tools {
291
+ background: #ec4899;
292
+ }
293
+ .legend-dot.files {
294
+ background: #f59e0b;
295
+ }
296
+ .cost-breakdown-note {
297
+ margin-top: 10px;
298
+ font-size: 11px;
299
+ color: var(--muted);
300
+ line-height: 1.4;
301
+ }
302
+
303
+ /* ===== SESSION BARS (scrollable list) ===== */
304
+ .session-bars {
305
+ margin-top: 16px;
306
+ max-height: 400px;
307
+ overflow-y: auto;
308
+ border: 1px solid var(--border);
309
+ border-radius: 8px;
310
+ background: var(--bg);
311
+ }
312
+ .session-bar-row {
313
+ display: flex;
314
+ align-items: center;
315
+ gap: 12px;
316
+ padding: 10px 14px;
317
+ border-bottom: 1px solid var(--border);
318
+ cursor: pointer;
319
+ transition: background 0.15s;
320
+ }
321
+ .session-bar-row:last-child {
322
+ border-bottom: none;
323
+ }
324
+ .session-bar-row:hover {
325
+ background: var(--bg-hover);
326
+ }
327
+ .session-bar-row.selected {
328
+ background: var(--accent-subtle);
329
+ }
330
+ .session-bar-label {
331
+ flex: 1 1 auto;
332
+ min-width: 0;
333
+ font-size: 13px;
334
+ color: var(--text);
335
+ display: flex;
336
+ flex-direction: column;
337
+ gap: 2px;
338
+ }
339
+ .session-bar-title {
340
+ /* Prefer showing the full name; wrap instead of truncating. */
341
+ white-space: normal;
342
+ overflow-wrap: anywhere;
343
+ word-break: break-word;
344
+ }
345
+ .session-bar-meta {
346
+ font-size: 10px;
347
+ color: var(--muted);
348
+ font-weight: 400;
349
+ overflow: hidden;
350
+ text-overflow: ellipsis;
351
+ white-space: nowrap;
352
+ }
353
+ .session-bar-track {
354
+ flex: 0 0 90px;
355
+ height: 6px;
356
+ background: var(--bg-secondary);
357
+ border-radius: 4px;
358
+ overflow: hidden;
359
+ opacity: 0.6;
360
+ }
361
+ .session-bar-fill {
362
+ height: 100%;
363
+ background: rgba(255, 77, 77, 0.7);
364
+ border-radius: 4px;
365
+ transition: width 0.3s ease;
366
+ }
367
+ .session-bar-value {
368
+ flex: 0 0 70px;
369
+ text-align: right;
370
+ font-size: 12px;
371
+ font-family: var(--font-mono);
372
+ color: var(--muted);
373
+ }
374
+ .session-bar-actions {
375
+ display: inline-flex;
376
+ align-items: center;
377
+ gap: 8px;
378
+ flex: 0 0 auto;
379
+ }
380
+ .session-copy-btn {
381
+ height: 26px;
382
+ padding: 0 10px;
383
+ border-radius: 999px;
384
+ border: 1px solid var(--border);
385
+ background: var(--bg-secondary);
386
+ font-size: 11px;
387
+ font-weight: 600;
388
+ color: var(--muted);
389
+ cursor: pointer;
390
+ transition: background 0.15s, border-color 0.15s, color 0.15s;
391
+ }
392
+ .session-copy-btn:hover {
393
+ background: var(--bg);
394
+ border-color: var(--border-strong);
395
+ color: var(--text);
396
+ }
397
+
398
+ /* ===== TIME SERIES CHART ===== */
399
+ .session-timeseries {
400
+ margin-top: 24px;
401
+ padding: 16px;
402
+ background: var(--bg-secondary);
403
+ border-radius: 8px;
404
+ }
405
+ .timeseries-header-row {
406
+ display: flex;
407
+ justify-content: space-between;
408
+ align-items: center;
409
+ margin-bottom: 12px;
410
+ }
411
+ .timeseries-controls {
412
+ display: flex;
413
+ gap: 6px;
414
+ align-items: center;
415
+ }
416
+ .timeseries-header {
417
+ font-weight: 600;
418
+ color: var(--text);
419
+ }
420
+ .timeseries-chart {
421
+ width: 100%;
422
+ overflow: hidden;
423
+ }
424
+ .timeseries-svg {
425
+ width: 100%;
426
+ height: auto;
427
+ display: block;
428
+ }
429
+ .timeseries-svg .axis-label {
430
+ font-size: 10px;
431
+ fill: var(--muted);
432
+ }
433
+ .timeseries-svg .ts-area {
434
+ fill: #ff4d4d;
435
+ fill-opacity: 0.1;
436
+ }
437
+ .timeseries-svg .ts-line {
438
+ fill: none;
439
+ stroke: #ff4d4d;
440
+ stroke-width: 2;
441
+ }
442
+ .timeseries-svg .ts-dot {
443
+ fill: #ff4d4d;
444
+ transition: r 0.15s, fill 0.15s;
445
+ }
446
+ .timeseries-svg .ts-dot:hover {
447
+ r: 5;
448
+ }
449
+ .timeseries-svg .ts-bar {
450
+ fill: #ff4d4d;
451
+ transition: fill 0.15s;
452
+ }
453
+ .timeseries-svg .ts-bar:hover {
454
+ fill: #cc3d3d;
455
+ }
456
+ .timeseries-svg .ts-bar.output { fill: #ef4444; }
457
+ .timeseries-svg .ts-bar.input { fill: #f59e0b; }
458
+ .timeseries-svg .ts-bar.cache-write { fill: #10b981; }
459
+ .timeseries-svg .ts-bar.cache-read { fill: #06b6d4; }
460
+ .timeseries-summary {
461
+ margin-top: 12px;
462
+ font-size: 13px;
463
+ color: var(--muted);
464
+ display: flex;
465
+ flex-wrap: wrap;
466
+ gap: 8px;
467
+ }
468
+ .timeseries-loading {
469
+ padding: 24px;
470
+ text-align: center;
471
+ color: var(--muted);
472
+ }
473
+
474
+ /* ===== SESSION LOGS ===== */
475
+ .session-logs {
476
+ margin-top: 24px;
477
+ background: var(--bg-secondary);
478
+ border-radius: 8px;
479
+ overflow: hidden;
480
+ }
481
+ .session-logs-header {
482
+ padding: 10px 14px;
483
+ font-weight: 600;
484
+ border-bottom: 1px solid var(--border);
485
+ display: flex;
486
+ justify-content: space-between;
487
+ align-items: center;
488
+ font-size: 13px;
489
+ background: var(--bg-secondary);
490
+ }
491
+ .session-logs-loading {
492
+ padding: 24px;
493
+ text-align: center;
494
+ color: var(--muted);
495
+ }
496
+ .session-logs-list {
497
+ max-height: 400px;
498
+ overflow-y: auto;
499
+ }
500
+ .session-log-entry {
501
+ padding: 10px 14px;
502
+ border-bottom: 1px solid var(--border);
503
+ display: flex;
504
+ flex-direction: column;
505
+ gap: 6px;
506
+ background: var(--bg);
507
+ }
508
+ .session-log-entry:last-child {
509
+ border-bottom: none;
510
+ }
511
+ .session-log-entry.user {
512
+ border-left: 3px solid var(--accent);
513
+ }
514
+ .session-log-entry.assistant {
515
+ border-left: 3px solid var(--border-strong);
516
+ }
517
+ .session-log-meta {
518
+ display: flex;
519
+ gap: 8px;
520
+ align-items: center;
521
+ font-size: 11px;
522
+ color: var(--muted);
523
+ flex-wrap: wrap;
524
+ }
525
+ .session-log-role {
526
+ font-weight: 600;
527
+ text-transform: uppercase;
528
+ letter-spacing: 0.04em;
529
+ font-size: 10px;
530
+ padding: 2px 6px;
531
+ border-radius: 999px;
532
+ background: var(--bg-secondary);
533
+ border: 1px solid var(--border);
534
+ }
535
+ .session-log-entry.user .session-log-role {
536
+ color: var(--accent);
537
+ }
538
+ .session-log-entry.assistant .session-log-role {
539
+ color: var(--muted);
540
+ }
541
+ .session-log-content {
542
+ font-size: 13px;
543
+ line-height: 1.5;
544
+ color: var(--text);
545
+ white-space: pre-wrap;
546
+ word-break: break-word;
547
+ background: var(--bg-secondary);
548
+ border-radius: 8px;
549
+ padding: 8px 10px;
550
+ border: 1px solid var(--border);
551
+ max-height: 220px;
552
+ overflow-y: auto;
553
+ }
554
+
555
+ /* ===== CONTEXT WEIGHT BREAKDOWN ===== */
556
+ .context-weight-breakdown {
557
+ margin-top: 24px;
558
+ padding: 16px;
559
+ background: var(--bg-secondary);
560
+ border-radius: 8px;
561
+ }
562
+ .context-weight-breakdown .context-weight-header {
563
+ font-weight: 600;
564
+ font-size: 13px;
565
+ margin-bottom: 4px;
566
+ color: var(--text);
567
+ }
568
+ .context-weight-desc {
569
+ font-size: 12px;
570
+ color: var(--muted);
571
+ margin: 0 0 12px 0;
572
+ }
573
+ .context-stacked-bar {
574
+ height: 24px;
575
+ background: var(--bg);
576
+ border-radius: 6px;
577
+ overflow: hidden;
578
+ display: flex;
579
+ }
580
+ .context-segment {
581
+ height: 100%;
582
+ transition: width 0.3s ease;
583
+ }
584
+ .context-segment.system {
585
+ background: #ff4d4d;
586
+ }
587
+ .context-segment.skills {
588
+ background: #8b5cf6;
589
+ }
590
+ .context-segment.tools {
591
+ background: #ec4899;
592
+ }
593
+ .context-segment.files {
594
+ background: #f59e0b;
595
+ }
596
+ .context-legend {
597
+ display: flex;
598
+ flex-wrap: wrap;
599
+ gap: 16px;
600
+ margin-top: 12px;
601
+ }
602
+ .context-total {
603
+ margin-top: 10px;
604
+ font-size: 12px;
605
+ font-weight: 600;
606
+ color: var(--muted);
607
+ }
608
+ .context-details {
609
+ margin-top: 12px;
610
+ border: 1px solid var(--border);
611
+ border-radius: 6px;
612
+ overflow: hidden;
613
+ }
614
+ .context-details summary {
615
+ padding: 10px 14px;
616
+ font-size: 13px;
617
+ font-weight: 500;
618
+ cursor: pointer;
619
+ background: var(--bg);
620
+ border-bottom: 1px solid var(--border);
621
+ }
622
+ .context-details[open] summary {
623
+ border-bottom: 1px solid var(--border);
624
+ }
625
+ .context-list {
626
+ max-height: 200px;
627
+ overflow-y: auto;
628
+ }
629
+ .context-list-header {
630
+ display: flex;
631
+ justify-content: space-between;
632
+ padding: 8px 14px;
633
+ font-size: 11px;
634
+ text-transform: uppercase;
635
+ color: var(--muted);
636
+ background: var(--bg-secondary);
637
+ border-bottom: 1px solid var(--border);
638
+ }
639
+ .context-list-item {
640
+ display: flex;
641
+ justify-content: space-between;
642
+ padding: 8px 14px;
643
+ font-size: 12px;
644
+ border-bottom: 1px solid var(--border);
645
+ }
646
+ .context-list-item:last-child {
647
+ border-bottom: none;
648
+ }
649
+ .context-list-item .mono {
650
+ font-family: var(--font-mono);
651
+ color: var(--text);
652
+ }
653
+ .context-list-item .muted {
654
+ color: var(--muted);
655
+ font-family: var(--font-mono);
656
+ }
657
+
658
+ /* ===== NO CONTEXT NOTE ===== */
659
+ .no-context-note {
660
+ margin-top: 24px;
661
+ padding: 16px;
662
+ background: var(--bg-secondary);
663
+ border-radius: 8px;
664
+ font-size: 13px;
665
+ color: var(--muted);
666
+ line-height: 1.5;
667
+ }
668
+
669
+ /* ===== TWO COLUMN LAYOUT ===== */
670
+ .usage-grid {
671
+ display: grid;
672
+ grid-template-columns: 1fr 1fr;
673
+ gap: 18px;
674
+ margin-top: 18px;
675
+ align-items: stretch;
676
+ }
677
+ .usage-grid-left {
678
+ display: flex;
679
+ flex-direction: column;
680
+ }
681
+ .usage-grid-right {
682
+ display: flex;
683
+ flex-direction: column;
684
+ }
685
+
686
+ /* ===== LEFT CARD (Daily + Breakdown) ===== */
687
+ .usage-left-card {
688
+ /* inherits background, border, shadow from .card */
689
+ flex: 1;
690
+ display: flex;
691
+ flex-direction: column;
692
+ }
693
+ .usage-left-card .daily-chart-bars {
694
+ flex: 1;
695
+ min-height: 200px;
696
+ }
697
+ .usage-left-card .sessions-panel-title {
698
+ font-weight: 600;
699
+ font-size: 14px;
700
+ margin-bottom: 12px;
701
+ }
702
+ `;