@portel/photon 1.4.0 → 1.5.1

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 (379) hide show
  1. package/README.md +287 -1160
  2. package/dist/auto-ui/beam.d.ts +9 -0
  3. package/dist/auto-ui/beam.d.ts.map +1 -0
  4. package/dist/auto-ui/beam.js +2381 -0
  5. package/dist/auto-ui/beam.js.map +1 -0
  6. package/dist/auto-ui/components/card.d.ts +13 -0
  7. package/dist/auto-ui/components/card.d.ts.map +1 -0
  8. package/dist/auto-ui/components/card.js +64 -0
  9. package/dist/auto-ui/components/card.js.map +1 -0
  10. package/dist/auto-ui/components/form.d.ts +15 -0
  11. package/dist/auto-ui/components/form.d.ts.map +1 -0
  12. package/dist/auto-ui/components/form.js +72 -0
  13. package/dist/auto-ui/components/form.js.map +1 -0
  14. package/dist/auto-ui/components/list.d.ts +13 -0
  15. package/dist/auto-ui/components/list.d.ts.map +1 -0
  16. package/dist/auto-ui/components/list.js +58 -0
  17. package/dist/auto-ui/components/list.js.map +1 -0
  18. package/dist/auto-ui/components/progress.d.ts +18 -0
  19. package/dist/auto-ui/components/progress.d.ts.map +1 -0
  20. package/dist/auto-ui/components/progress.js +125 -0
  21. package/dist/auto-ui/components/progress.js.map +1 -0
  22. package/dist/auto-ui/components/table.d.ts +13 -0
  23. package/dist/auto-ui/components/table.d.ts.map +1 -0
  24. package/dist/auto-ui/components/table.js +82 -0
  25. package/dist/auto-ui/components/table.js.map +1 -0
  26. package/dist/auto-ui/components/tree.d.ts +13 -0
  27. package/dist/auto-ui/components/tree.d.ts.map +1 -0
  28. package/dist/auto-ui/components/tree.js +61 -0
  29. package/dist/auto-ui/components/tree.js.map +1 -0
  30. package/dist/auto-ui/daemon-tools.d.ts +45 -0
  31. package/dist/auto-ui/daemon-tools.d.ts.map +1 -0
  32. package/dist/auto-ui/daemon-tools.js +580 -0
  33. package/dist/auto-ui/daemon-tools.js.map +1 -0
  34. package/dist/auto-ui/design-system/index.d.ts +21 -0
  35. package/dist/auto-ui/design-system/index.d.ts.map +1 -0
  36. package/dist/auto-ui/design-system/index.js +27 -0
  37. package/dist/auto-ui/design-system/index.js.map +1 -0
  38. package/dist/auto-ui/design-system/tokens.d.ts +9 -0
  39. package/dist/auto-ui/design-system/tokens.d.ts.map +1 -0
  40. package/dist/auto-ui/design-system/tokens.js +27 -0
  41. package/dist/auto-ui/design-system/tokens.js.map +1 -0
  42. package/dist/auto-ui/design-system/transaction-ui.d.ts +70 -0
  43. package/dist/auto-ui/design-system/transaction-ui.d.ts.map +1 -0
  44. package/dist/auto-ui/design-system/transaction-ui.js +982 -0
  45. package/dist/auto-ui/design-system/transaction-ui.js.map +1 -0
  46. package/dist/auto-ui/frontend/index.html +84 -0
  47. package/dist/auto-ui/index.d.ts +21 -0
  48. package/dist/auto-ui/index.d.ts.map +1 -0
  49. package/dist/auto-ui/index.js +25 -0
  50. package/dist/auto-ui/index.js.map +1 -0
  51. package/dist/auto-ui/openapi-generator.d.ts +71 -0
  52. package/dist/auto-ui/openapi-generator.d.ts.map +1 -0
  53. package/dist/auto-ui/openapi-generator.js +223 -0
  54. package/dist/auto-ui/openapi-generator.js.map +1 -0
  55. package/dist/auto-ui/photon-bridge.d.ts +159 -0
  56. package/dist/auto-ui/photon-bridge.d.ts.map +1 -0
  57. package/dist/auto-ui/photon-bridge.js +262 -0
  58. package/dist/auto-ui/photon-bridge.js.map +1 -0
  59. package/dist/auto-ui/photon-host.d.ts +113 -0
  60. package/dist/auto-ui/photon-host.d.ts.map +1 -0
  61. package/dist/auto-ui/photon-host.js +284 -0
  62. package/dist/auto-ui/photon-host.js.map +1 -0
  63. package/dist/auto-ui/platform-compat.d.ts +71 -0
  64. package/dist/auto-ui/platform-compat.d.ts.map +1 -0
  65. package/dist/auto-ui/platform-compat.js +574 -0
  66. package/dist/auto-ui/platform-compat.js.map +1 -0
  67. package/dist/auto-ui/playground-html.d.ts +15 -0
  68. package/dist/auto-ui/playground-html.d.ts.map +1 -0
  69. package/dist/auto-ui/playground-html.js +1113 -0
  70. package/dist/auto-ui/playground-html.js.map +1 -0
  71. package/dist/auto-ui/playground-server.d.ts +7 -0
  72. package/dist/auto-ui/playground-server.d.ts.map +1 -0
  73. package/dist/auto-ui/playground-server.js +840 -0
  74. package/dist/auto-ui/playground-server.js.map +1 -0
  75. package/dist/auto-ui/registry.d.ts +13 -0
  76. package/dist/auto-ui/registry.d.ts.map +1 -0
  77. package/dist/auto-ui/registry.js +62 -0
  78. package/dist/auto-ui/registry.js.map +1 -0
  79. package/dist/auto-ui/renderer.d.ts +14 -0
  80. package/dist/auto-ui/renderer.d.ts.map +1 -0
  81. package/dist/auto-ui/renderer.js +88 -0
  82. package/dist/auto-ui/renderer.js.map +1 -0
  83. package/dist/auto-ui/rendering/components.d.ts +29 -0
  84. package/dist/auto-ui/rendering/components.d.ts.map +1 -0
  85. package/dist/auto-ui/rendering/components.js +773 -0
  86. package/dist/auto-ui/rendering/components.js.map +1 -0
  87. package/dist/auto-ui/rendering/field-analyzer.d.ts +48 -0
  88. package/dist/auto-ui/rendering/field-analyzer.d.ts.map +1 -0
  89. package/dist/auto-ui/rendering/field-analyzer.js +270 -0
  90. package/dist/auto-ui/rendering/field-analyzer.js.map +1 -0
  91. package/dist/auto-ui/rendering/field-renderers.d.ts +64 -0
  92. package/dist/auto-ui/rendering/field-renderers.d.ts.map +1 -0
  93. package/dist/auto-ui/rendering/field-renderers.js +317 -0
  94. package/dist/auto-ui/rendering/field-renderers.js.map +1 -0
  95. package/dist/auto-ui/rendering/index.d.ts +28 -0
  96. package/dist/auto-ui/rendering/index.d.ts.map +1 -0
  97. package/dist/auto-ui/rendering/index.js +60 -0
  98. package/dist/auto-ui/rendering/index.js.map +1 -0
  99. package/dist/auto-ui/rendering/layout-selector.d.ts +48 -0
  100. package/dist/auto-ui/rendering/layout-selector.d.ts.map +1 -0
  101. package/dist/auto-ui/rendering/layout-selector.js +352 -0
  102. package/dist/auto-ui/rendering/layout-selector.js.map +1 -0
  103. package/dist/auto-ui/rendering/template-engine.d.ts +41 -0
  104. package/dist/auto-ui/rendering/template-engine.d.ts.map +1 -0
  105. package/dist/auto-ui/rendering/template-engine.js +238 -0
  106. package/dist/auto-ui/rendering/template-engine.js.map +1 -0
  107. package/dist/auto-ui/streamable-http-transport.d.ts +79 -0
  108. package/dist/auto-ui/streamable-http-transport.d.ts.map +1 -0
  109. package/dist/auto-ui/streamable-http-transport.js +1314 -0
  110. package/dist/auto-ui/streamable-http-transport.js.map +1 -0
  111. package/dist/auto-ui/types.d.ts +310 -0
  112. package/dist/auto-ui/types.d.ts.map +1 -0
  113. package/dist/auto-ui/types.js +71 -0
  114. package/dist/auto-ui/types.js.map +1 -0
  115. package/dist/beam.bundle.js +13506 -0
  116. package/dist/beam.bundle.js.map +7 -0
  117. package/dist/claude-code-plugin.d.ts.map +1 -1
  118. package/dist/claude-code-plugin.js +30 -30
  119. package/dist/claude-code-plugin.js.map +1 -1
  120. package/dist/cli/commands/info.d.ts +11 -0
  121. package/dist/cli/commands/info.d.ts.map +1 -0
  122. package/dist/cli/commands/info.js +313 -0
  123. package/dist/cli/commands/info.js.map +1 -0
  124. package/dist/cli/commands/marketplace.d.ts +11 -0
  125. package/dist/cli/commands/marketplace.d.ts.map +1 -0
  126. package/dist/cli/commands/marketplace.js +198 -0
  127. package/dist/cli/commands/marketplace.js.map +1 -0
  128. package/dist/cli/commands/package-app.d.ts +9 -0
  129. package/dist/cli/commands/package-app.d.ts.map +1 -0
  130. package/dist/cli/commands/package-app.js +191 -0
  131. package/dist/cli/commands/package-app.js.map +1 -0
  132. package/dist/cli/commands/package.d.ts +11 -0
  133. package/dist/cli/commands/package.d.ts.map +1 -0
  134. package/dist/cli/commands/package.js +573 -0
  135. package/dist/cli/commands/package.js.map +1 -0
  136. package/dist/cli-alias.d.ts.map +1 -1
  137. package/dist/cli-alias.js +30 -28
  138. package/dist/cli-alias.js.map +1 -1
  139. package/dist/cli-formatter.d.ts +8 -24
  140. package/dist/cli-formatter.d.ts.map +1 -1
  141. package/dist/cli-formatter.js +8 -325
  142. package/dist/cli-formatter.js.map +1 -1
  143. package/dist/cli.d.ts +15 -1
  144. package/dist/cli.d.ts.map +1 -1
  145. package/dist/cli.js +1157 -1132
  146. package/dist/cli.js.map +1 -1
  147. package/dist/daemon/client.d.ts +81 -0
  148. package/dist/daemon/client.d.ts.map +1 -1
  149. package/dist/daemon/client.js +583 -13
  150. package/dist/daemon/client.js.map +1 -1
  151. package/dist/daemon/manager.d.ts +46 -12
  152. package/dist/daemon/manager.d.ts.map +1 -1
  153. package/dist/daemon/manager.js +102 -61
  154. package/dist/daemon/manager.js.map +1 -1
  155. package/dist/daemon/protocol.d.ts +74 -6
  156. package/dist/daemon/protocol.d.ts.map +1 -1
  157. package/dist/daemon/protocol.js +76 -1
  158. package/dist/daemon/protocol.js.map +1 -1
  159. package/dist/daemon/server.d.ts +6 -6
  160. package/dist/daemon/server.js +778 -117
  161. package/dist/daemon/server.js.map +1 -1
  162. package/dist/daemon/session-manager.d.ts +8 -1
  163. package/dist/daemon/session-manager.d.ts.map +1 -1
  164. package/dist/daemon/session-manager.js +32 -9
  165. package/dist/daemon/session-manager.js.map +1 -1
  166. package/dist/deploy/cloudflare.d.ts +12 -0
  167. package/dist/deploy/cloudflare.d.ts.map +1 -0
  168. package/dist/deploy/cloudflare.js +216 -0
  169. package/dist/deploy/cloudflare.js.map +1 -0
  170. package/dist/index.d.ts +1 -0
  171. package/dist/index.d.ts.map +1 -1
  172. package/dist/index.js +3 -0
  173. package/dist/index.js.map +1 -1
  174. package/dist/loader.d.ts +172 -15
  175. package/dist/loader.d.ts.map +1 -1
  176. package/dist/loader.js +1132 -267
  177. package/dist/loader.js.map +1 -1
  178. package/dist/markdown-utils.d.ts +8 -0
  179. package/dist/markdown-utils.d.ts.map +1 -0
  180. package/dist/markdown-utils.js +63 -0
  181. package/dist/markdown-utils.js.map +1 -0
  182. package/dist/marketplace-manager.d.ts +10 -0
  183. package/dist/marketplace-manager.d.ts.map +1 -1
  184. package/dist/marketplace-manager.js +112 -28
  185. package/dist/marketplace-manager.js.map +1 -1
  186. package/dist/mcp-client.d.ts +9 -0
  187. package/dist/mcp-client.d.ts.map +1 -0
  188. package/dist/mcp-client.js +11 -0
  189. package/dist/mcp-client.js.map +1 -0
  190. package/dist/mcp-elicitation.d.ts +32 -0
  191. package/dist/mcp-elicitation.d.ts.map +1 -0
  192. package/dist/mcp-elicitation.js +26 -0
  193. package/dist/mcp-elicitation.js.map +1 -0
  194. package/dist/path-resolver.d.ts +9 -12
  195. package/dist/path-resolver.d.ts.map +1 -1
  196. package/dist/path-resolver.js +13 -43
  197. package/dist/path-resolver.js.map +1 -1
  198. package/dist/photon-cli-runner.d.ts.map +1 -1
  199. package/dist/photon-cli-runner.js +216 -73
  200. package/dist/photon-cli-runner.js.map +1 -1
  201. package/dist/photon-doc-extractor.d.ts +88 -0
  202. package/dist/photon-doc-extractor.d.ts.map +1 -1
  203. package/dist/photon-doc-extractor.js +536 -27
  204. package/dist/photon-doc-extractor.js.map +1 -1
  205. package/dist/photons/maker.photon.d.ts +182 -0
  206. package/dist/photons/maker.photon.d.ts.map +1 -0
  207. package/dist/photons/maker.photon.js +504 -0
  208. package/dist/photons/maker.photon.js.map +1 -0
  209. package/dist/photons/maker.photon.ts +626 -0
  210. package/dist/photons/marketplace.photon.d.ts +110 -0
  211. package/dist/photons/marketplace.photon.d.ts.map +1 -0
  212. package/dist/photons/marketplace.photon.js +260 -0
  213. package/dist/photons/marketplace.photon.js.map +1 -0
  214. package/dist/photons/marketplace.photon.ts +378 -0
  215. package/dist/photons/tunnel.photon.d.ts +80 -0
  216. package/dist/photons/tunnel.photon.d.ts.map +1 -0
  217. package/dist/photons/tunnel.photon.js +269 -0
  218. package/dist/photons/tunnel.photon.js.map +1 -0
  219. package/dist/photons/tunnel.photon.ts +345 -0
  220. package/dist/security-scanner.d.ts.map +1 -1
  221. package/dist/security-scanner.js +18 -15
  222. package/dist/security-scanner.js.map +1 -1
  223. package/dist/serv/auth/jwt.d.ts +89 -0
  224. package/dist/serv/auth/jwt.d.ts.map +1 -0
  225. package/dist/serv/auth/jwt.js +239 -0
  226. package/dist/serv/auth/jwt.js.map +1 -0
  227. package/dist/serv/auth/oauth.d.ts +117 -0
  228. package/dist/serv/auth/oauth.d.ts.map +1 -0
  229. package/dist/serv/auth/oauth.js +395 -0
  230. package/dist/serv/auth/oauth.js.map +1 -0
  231. package/dist/serv/auth/well-known.d.ts +60 -0
  232. package/dist/serv/auth/well-known.d.ts.map +1 -0
  233. package/dist/serv/auth/well-known.js +154 -0
  234. package/dist/serv/auth/well-known.js.map +1 -0
  235. package/dist/serv/db/d1-client.d.ts +65 -0
  236. package/dist/serv/db/d1-client.d.ts.map +1 -0
  237. package/dist/serv/db/d1-client.js +137 -0
  238. package/dist/serv/db/d1-client.js.map +1 -0
  239. package/dist/serv/db/d1-stores.d.ts +62 -0
  240. package/dist/serv/db/d1-stores.d.ts.map +1 -0
  241. package/dist/serv/db/d1-stores.js +307 -0
  242. package/dist/serv/db/d1-stores.js.map +1 -0
  243. package/dist/serv/index.d.ts +114 -0
  244. package/dist/serv/index.d.ts.map +1 -0
  245. package/dist/serv/index.js +172 -0
  246. package/dist/serv/index.js.map +1 -0
  247. package/dist/serv/local.d.ts +118 -0
  248. package/dist/serv/local.d.ts.map +1 -0
  249. package/dist/serv/local.js +392 -0
  250. package/dist/serv/local.js.map +1 -0
  251. package/dist/serv/middleware/auth.d.ts +66 -0
  252. package/dist/serv/middleware/auth.d.ts.map +1 -0
  253. package/dist/serv/middleware/auth.js +178 -0
  254. package/dist/serv/middleware/auth.js.map +1 -0
  255. package/dist/serv/middleware/tenant.d.ts +94 -0
  256. package/dist/serv/middleware/tenant.d.ts.map +1 -0
  257. package/dist/serv/middleware/tenant.js +152 -0
  258. package/dist/serv/middleware/tenant.js.map +1 -0
  259. package/dist/serv/runtime/executor.d.ts +76 -0
  260. package/dist/serv/runtime/executor.d.ts.map +1 -0
  261. package/dist/serv/runtime/executor.js +105 -0
  262. package/dist/serv/runtime/executor.js.map +1 -0
  263. package/dist/serv/runtime/index.d.ts +8 -0
  264. package/dist/serv/runtime/index.d.ts.map +1 -0
  265. package/dist/serv/runtime/index.js +10 -0
  266. package/dist/serv/runtime/index.js.map +1 -0
  267. package/dist/serv/runtime/oauth-context.d.ts +121 -0
  268. package/dist/serv/runtime/oauth-context.d.ts.map +1 -0
  269. package/dist/serv/runtime/oauth-context.js +153 -0
  270. package/dist/serv/runtime/oauth-context.js.map +1 -0
  271. package/dist/serv/session/kv-store.d.ts +54 -0
  272. package/dist/serv/session/kv-store.d.ts.map +1 -0
  273. package/dist/serv/session/kv-store.js +149 -0
  274. package/dist/serv/session/kv-store.js.map +1 -0
  275. package/dist/serv/session/store.d.ts +113 -0
  276. package/dist/serv/session/store.d.ts.map +1 -0
  277. package/dist/serv/session/store.js +284 -0
  278. package/dist/serv/session/store.js.map +1 -0
  279. package/dist/serv/types/index.d.ts +147 -0
  280. package/dist/serv/types/index.d.ts.map +1 -0
  281. package/dist/serv/types/index.js +8 -0
  282. package/dist/serv/types/index.js.map +1 -0
  283. package/dist/serv/vault/token-vault.d.ts +102 -0
  284. package/dist/serv/vault/token-vault.d.ts.map +1 -0
  285. package/dist/serv/vault/token-vault.js +177 -0
  286. package/dist/serv/vault/token-vault.js.map +1 -0
  287. package/dist/server.d.ts +173 -0
  288. package/dist/server.d.ts.map +1 -1
  289. package/dist/server.js +1622 -86
  290. package/dist/server.js.map +1 -1
  291. package/dist/shared/cli-sections.d.ts +6 -0
  292. package/dist/shared/cli-sections.d.ts.map +1 -0
  293. package/dist/shared/cli-sections.js +16 -0
  294. package/dist/shared/cli-sections.js.map +1 -0
  295. package/dist/shared/cli-utils.d.ts +81 -0
  296. package/dist/shared/cli-utils.d.ts.map +1 -0
  297. package/dist/shared/cli-utils.js +174 -0
  298. package/dist/shared/cli-utils.js.map +1 -0
  299. package/dist/shared/config-docs.d.ts +6 -0
  300. package/dist/shared/config-docs.d.ts.map +1 -0
  301. package/dist/shared/config-docs.js +6 -0
  302. package/dist/shared/config-docs.js.map +1 -0
  303. package/dist/shared/error-handler.d.ts +128 -0
  304. package/dist/shared/error-handler.d.ts.map +1 -0
  305. package/dist/shared/error-handler.js +342 -0
  306. package/dist/shared/error-handler.js.map +1 -0
  307. package/dist/shared/logger.d.ts +42 -0
  308. package/dist/shared/logger.d.ts.map +1 -0
  309. package/dist/shared/logger.js +123 -0
  310. package/dist/shared/logger.js.map +1 -0
  311. package/dist/shared/performance.d.ts +65 -0
  312. package/dist/shared/performance.d.ts.map +1 -0
  313. package/dist/shared/performance.js +136 -0
  314. package/dist/shared/performance.js.map +1 -0
  315. package/dist/shared/task-runner.d.ts +2 -0
  316. package/dist/shared/task-runner.d.ts.map +1 -0
  317. package/dist/shared/task-runner.js +16 -0
  318. package/dist/shared/task-runner.js.map +1 -0
  319. package/dist/shared/validation.d.ts +6 -0
  320. package/dist/shared/validation.d.ts.map +1 -0
  321. package/dist/shared/validation.js +6 -0
  322. package/dist/shared/validation.js.map +1 -0
  323. package/dist/shared-utils.d.ts +63 -0
  324. package/dist/shared-utils.d.ts.map +1 -0
  325. package/dist/shared-utils.js +123 -0
  326. package/dist/shared-utils.js.map +1 -0
  327. package/dist/template-manager.d.ts +23 -2
  328. package/dist/template-manager.d.ts.map +1 -1
  329. package/dist/template-manager.js +177 -88
  330. package/dist/template-manager.js.map +1 -1
  331. package/dist/test-client.d.ts.map +1 -1
  332. package/dist/test-client.js +10 -8
  333. package/dist/test-client.js.map +1 -1
  334. package/dist/test-runner.d.ts +52 -0
  335. package/dist/test-runner.d.ts.map +1 -0
  336. package/dist/test-runner.js +785 -0
  337. package/dist/test-runner.js.map +1 -0
  338. package/dist/testing.d.ts +103 -0
  339. package/dist/testing.d.ts.map +1 -0
  340. package/dist/testing.js +163 -0
  341. package/dist/testing.js.map +1 -0
  342. package/dist/version-checker.d.ts.map +1 -1
  343. package/dist/version-checker.js +2 -2
  344. package/dist/version-checker.js.map +1 -1
  345. package/dist/version.d.ts +2 -0
  346. package/dist/version.d.ts.map +1 -0
  347. package/dist/version.js +5 -0
  348. package/dist/version.js.map +1 -0
  349. package/dist/watcher.d.ts +6 -3
  350. package/dist/watcher.d.ts.map +1 -1
  351. package/dist/watcher.js +49 -10
  352. package/dist/watcher.js.map +1 -1
  353. package/package.json +47 -7
  354. package/templates/cloudflare/worker.ts.template +381 -0
  355. package/templates/cloudflare/wrangler.toml.template +9 -0
  356. package/dist/base.d.ts +0 -58
  357. package/dist/base.d.ts.map +0 -1
  358. package/dist/base.js +0 -92
  359. package/dist/base.js.map +0 -1
  360. package/dist/dependency-manager.d.ts +0 -49
  361. package/dist/dependency-manager.d.ts.map +0 -1
  362. package/dist/dependency-manager.js +0 -165
  363. package/dist/dependency-manager.js.map +0 -1
  364. package/dist/registry-manager.d.ts +0 -76
  365. package/dist/registry-manager.d.ts.map +0 -1
  366. package/dist/registry-manager.js +0 -220
  367. package/dist/registry-manager.js.map +0 -1
  368. package/dist/schema-extractor.d.ts +0 -110
  369. package/dist/schema-extractor.d.ts.map +0 -1
  370. package/dist/schema-extractor.js +0 -727
  371. package/dist/schema-extractor.js.map +0 -1
  372. package/dist/test-marketplace-sources.d.ts +0 -5
  373. package/dist/test-marketplace-sources.d.ts.map +0 -1
  374. package/dist/test-marketplace-sources.js +0 -53
  375. package/dist/test-marketplace-sources.js.map +0 -1
  376. package/dist/types.d.ts +0 -109
  377. package/dist/types.d.ts.map +0 -1
  378. package/dist/types.js +0 -12
  379. package/dist/types.js.map +0 -1
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../node_modules/@lit/reactive-element/src/css-tag.ts", "../node_modules/@lit/reactive-element/src/reactive-element.ts", "../node_modules/lit-html/src/lit-html.ts", "../node_modules/lit-element/src/lit-element.ts", "../node_modules/lit-html/src/directive.ts", "../node_modules/lit-html/src/directives/unsafe-html.ts", "../node_modules/@lit/reactive-element/src/decorators/custom-element.ts", "../node_modules/@lit/reactive-element/src/decorators/property.ts", "../node_modules/@lit/reactive-element/src/decorators/state.ts", "../node_modules/@lit/reactive-element/src/decorators/base.ts", "../node_modules/@lit/reactive-element/src/decorators/query.ts", "../src/auto-ui/frontend/styles/theme.ts", "../src/auto-ui/frontend/components/toast-manager.ts", "../../photon-core/src/design-system/tokens.ts", "../src/auto-ui/frontend/services/mcp-client.ts", "../src/auto-ui/frontend/components/beam-app.ts", "../src/auto-ui/frontend/components/beam-sidebar.ts", "../src/auto-ui/frontend/components/method-card.ts", "../src/auto-ui/frontend/components/invoke-form.ts", "../src/auto-ui/frontend/components/activity-log.ts", "../src/auto-ui/frontend/components/result-viewer.ts", "../src/auto-ui/frontend/components/file-picker.ts", "../src/auto-ui/frontend/components/marketplace-view.ts", "../src/auto-ui/frontend/components/custom-ui-renderer.ts", "../src/auto-ui/frontend/components/photon-config.ts", "../src/auto-ui/frontend/components/elicitation-modal.ts", "../src/auto-ui/frontend/main.ts"],
4
+ "sourcesContent": ["/**\n * @license\n * Copyright 2019 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\n\nconst NODE_MODE = false;\n\n// Allows minifiers to rename references to globalThis\nconst global = globalThis;\n\n/**\n * Whether the current browser supports `adoptedStyleSheets`.\n */\nexport const supportsAdoptingStyleSheets: boolean =\n global.ShadowRoot &&\n (global.ShadyCSS === undefined || global.ShadyCSS.nativeShadow) &&\n 'adoptedStyleSheets' in Document.prototype &&\n 'replace' in CSSStyleSheet.prototype;\n\n/**\n * A CSSResult or native CSSStyleSheet.\n *\n * In browsers that support constructible CSS style sheets, CSSStyleSheet\n * object can be used for styling along side CSSResult from the `css`\n * template tag.\n */\nexport type CSSResultOrNative = CSSResult | CSSStyleSheet;\n\nexport type CSSResultArray = Array<CSSResultOrNative | CSSResultArray>;\n\n/**\n * A single CSSResult, CSSStyleSheet, or an array or nested arrays of those.\n */\nexport type CSSResultGroup = CSSResultOrNative | CSSResultArray;\n\nconst constructionToken = Symbol();\n\nconst cssTagCache = new WeakMap<TemplateStringsArray, CSSStyleSheet>();\n\n/**\n * A container for a string of CSS text, that may be used to create a CSSStyleSheet.\n *\n * CSSResult is the return value of `css`-tagged template literals and\n * `unsafeCSS()`. In order to ensure that CSSResults are only created via the\n * `css` tag and `unsafeCSS()`, CSSResult cannot be constructed directly.\n */\nexport class CSSResult {\n // This property needs to remain unminified.\n ['_$cssResult$'] = true;\n readonly cssText: string;\n private _styleSheet?: CSSStyleSheet;\n private _strings: TemplateStringsArray | undefined;\n\n private constructor(\n cssText: string,\n strings: TemplateStringsArray | undefined,\n safeToken: symbol\n ) {\n if (safeToken !== constructionToken) {\n throw new Error(\n 'CSSResult is not constructable. Use `unsafeCSS` or `css` instead.'\n );\n }\n this.cssText = cssText;\n this._strings = strings;\n }\n\n // This is a getter so that it's lazy. In practice, this means stylesheets\n // are not created until the first element instance is made.\n get styleSheet(): CSSStyleSheet | undefined {\n // If `supportsAdoptingStyleSheets` is true then we assume CSSStyleSheet is\n // constructable.\n let styleSheet = this._styleSheet;\n const strings = this._strings;\n if (supportsAdoptingStyleSheets && styleSheet === undefined) {\n const cacheable = strings !== undefined && strings.length === 1;\n if (cacheable) {\n styleSheet = cssTagCache.get(strings);\n }\n if (styleSheet === undefined) {\n (this._styleSheet = styleSheet = new CSSStyleSheet()).replaceSync(\n this.cssText\n );\n if (cacheable) {\n cssTagCache.set(strings, styleSheet);\n }\n }\n }\n return styleSheet;\n }\n\n toString(): string {\n return this.cssText;\n }\n}\n\ntype ConstructableCSSResult = CSSResult & {\n new (\n cssText: string,\n strings: TemplateStringsArray | undefined,\n safeToken: symbol\n ): CSSResult;\n};\n\nconst textFromCSSResult = (value: CSSResultGroup | number) => {\n // This property needs to remain unminified.\n if ((value as CSSResult)['_$cssResult$'] === true) {\n return (value as CSSResult).cssText;\n } else if (typeof value === 'number') {\n return value;\n } else {\n throw new Error(\n `Value passed to 'css' function must be a 'css' function result: ` +\n `${value}. Use 'unsafeCSS' to pass non-literal values, but take care ` +\n `to ensure page security.`\n );\n }\n};\n\n/**\n * Wrap a value for interpolation in a {@linkcode css} tagged template literal.\n *\n * This is unsafe because untrusted CSS text can be used to phone home\n * or exfiltrate data to an attacker controlled site. Take care to only use\n * this with trusted input.\n */\nexport const unsafeCSS = (value: unknown) =>\n new (CSSResult as ConstructableCSSResult)(\n typeof value === 'string' ? value : String(value),\n undefined,\n constructionToken\n );\n\n/**\n * A template literal tag which can be used with LitElement's\n * {@linkcode LitElement.styles} property to set element styles.\n *\n * For security reasons, only literal string values and number may be used in\n * embedded expressions. To incorporate non-literal values {@linkcode unsafeCSS}\n * may be used inside an expression.\n */\nexport const css = (\n strings: TemplateStringsArray,\n ...values: (CSSResultGroup | number)[]\n): CSSResult => {\n const cssText =\n strings.length === 1\n ? strings[0]\n : values.reduce(\n (acc, v, idx) => acc + textFromCSSResult(v) + strings[idx + 1],\n strings[0]\n );\n return new (CSSResult as ConstructableCSSResult)(\n cssText,\n strings,\n constructionToken\n );\n};\n\n/**\n * Applies the given styles to a `shadowRoot`. When Shadow DOM is\n * available but `adoptedStyleSheets` is not, styles are appended to the\n * `shadowRoot` to [mimic the native feature](https://developer.mozilla.org/en-US/docs/Web/API/ShadowRoot/adoptedStyleSheets).\n * Note, when shimming is used, any styles that are subsequently placed into\n * the shadowRoot should be placed *before* any shimmed adopted styles. This\n * will match spec behavior that gives adopted sheets precedence over styles in\n * shadowRoot.\n */\nexport const adoptStyles = (\n renderRoot: ShadowRoot,\n styles: Array<CSSResultOrNative>\n) => {\n if (supportsAdoptingStyleSheets) {\n (renderRoot as ShadowRoot).adoptedStyleSheets = styles.map((s) =>\n s instanceof CSSStyleSheet ? s : s.styleSheet!\n );\n } else {\n for (const s of styles) {\n const style = document.createElement('style');\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const nonce = (global as any)['litNonce'];\n if (nonce !== undefined) {\n style.setAttribute('nonce', nonce);\n }\n style.textContent = (s as CSSResult).cssText;\n renderRoot.appendChild(style);\n }\n }\n};\n\nconst cssResultFromStyleSheet = (sheet: CSSStyleSheet) => {\n let cssText = '';\n for (const rule of sheet.cssRules) {\n cssText += rule.cssText;\n }\n return unsafeCSS(cssText);\n};\n\nexport const getCompatibleStyle =\n supportsAdoptingStyleSheets ||\n (NODE_MODE && global.CSSStyleSheet === undefined)\n ? (s: CSSResultOrNative) => s\n : (s: CSSResultOrNative) =>\n s instanceof CSSStyleSheet ? cssResultFromStyleSheet(s) : s;\n", "/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\n\n/**\n * Use this module if you want to create your own base class extending\n * {@link ReactiveElement}.\n * @packageDocumentation\n */\n\nimport {\n getCompatibleStyle,\n adoptStyles,\n CSSResultGroup,\n CSSResultOrNative,\n} from './css-tag.js';\nimport type {\n ReactiveController,\n ReactiveControllerHost,\n} from './reactive-controller.js';\n\n// In the Node build, this import will be injected by Rollup:\n// import {HTMLElement, customElements} from '@lit-labs/ssr-dom-shim';\n\nexport * from './css-tag.js';\nexport type {\n ReactiveController,\n ReactiveControllerHost,\n} from './reactive-controller.js';\n\n/**\n * Removes the `readonly` modifier from properties in the union K.\n *\n * This is a safer way to cast a value to a type with a mutable version of a\n * readonly field, than casting to an interface with the field re-declared\n * because it preserves the type of all the fields and warns on typos.\n */\ntype Mutable<T, K extends keyof T> = Omit<T, K> & {\n -readonly [P in keyof Pick<T, K>]: P extends K ? T[P] : never;\n};\n\n// TODO (justinfagnani): Add `hasOwn` here when we ship ES2022\nconst {\n is,\n defineProperty,\n getOwnPropertyDescriptor,\n getOwnPropertyNames,\n getOwnPropertySymbols,\n getPrototypeOf,\n} = Object;\n\nconst NODE_MODE = false;\n\n// Lets a minifier replace globalThis references with a minified name\nconst global = globalThis;\n\nif (NODE_MODE) {\n global.customElements ??= customElements;\n}\n\nconst DEV_MODE = true;\n\nlet issueWarning: (code: string, warning: string) => void;\n\nconst trustedTypes = (global as unknown as {trustedTypes?: {emptyScript: ''}})\n .trustedTypes;\n\n// Temporary workaround for https://crbug.com/993268\n// Currently, any attribute starting with \"on\" is considered to be a\n// TrustedScript source. Such boolean attributes must be set to the equivalent\n// trusted emptyScript value.\nconst emptyStringForBooleanAttribute = trustedTypes\n ? (trustedTypes.emptyScript as unknown as '')\n : '';\n\nconst polyfillSupport = DEV_MODE\n ? global.reactiveElementPolyfillSupportDevMode\n : global.reactiveElementPolyfillSupport;\n\nif (DEV_MODE) {\n // Ensure warnings are issued only 1x, even if multiple versions of Lit\n // are loaded.\n global.litIssuedWarnings ??= new Set();\n\n /**\n * Issue a warning if we haven't already, based either on `code` or `warning`.\n * Warnings are disabled automatically only by `warning`; disabling via `code`\n * can be done by users.\n */\n issueWarning = (code: string, warning: string) => {\n warning += ` See https://lit.dev/msg/${code} for more information.`;\n if (\n !global.litIssuedWarnings!.has(warning) &&\n !global.litIssuedWarnings!.has(code)\n ) {\n console.warn(warning);\n global.litIssuedWarnings!.add(warning);\n }\n };\n\n queueMicrotask(() => {\n issueWarning(\n 'dev-mode',\n `Lit is in dev mode. Not recommended for production!`\n );\n\n // Issue polyfill support warning.\n if (global.ShadyDOM?.inUse && polyfillSupport === undefined) {\n issueWarning(\n 'polyfill-support-missing',\n `Shadow DOM is being polyfilled via \\`ShadyDOM\\` but ` +\n `the \\`polyfill-support\\` module has not been loaded.`\n );\n }\n });\n}\n\n/**\n * Contains types that are part of the unstable debug API.\n *\n * Everything in this API is not stable and may change or be removed in the future,\n * even on patch releases.\n */\n// eslint-disable-next-line @typescript-eslint/no-namespace\nexport namespace ReactiveUnstable {\n /**\n * When Lit is running in dev mode and `window.emitLitDebugLogEvents` is true,\n * we will emit 'lit-debug' events to window, with live details about the update and render\n * lifecycle. These can be useful for writing debug tooling and visualizations.\n *\n * Please be aware that running with window.emitLitDebugLogEvents has performance overhead,\n * making certain operations that are normally very cheap (like a no-op render) much slower,\n * because we must copy data and dispatch events.\n */\n // eslint-disable-next-line @typescript-eslint/no-namespace\n export namespace DebugLog {\n export type Entry = Update;\n export interface Update {\n kind: 'update';\n }\n }\n}\n\ninterface DebugLoggingWindow {\n // Even in dev mode, we generally don't want to emit these events, as that's\n // another level of cost, so only emit them when DEV_MODE is true _and_ when\n // window.emitLitDebugEvents is true.\n emitLitDebugLogEvents?: boolean;\n}\n\n/**\n * Useful for visualizing and logging insights into what the Lit template system is doing.\n *\n * Compiled out of prod mode builds.\n */\nconst debugLogEvent = DEV_MODE\n ? (event: ReactiveUnstable.DebugLog.Entry) => {\n const shouldEmit = (global as unknown as DebugLoggingWindow)\n .emitLitDebugLogEvents;\n if (!shouldEmit) {\n return;\n }\n global.dispatchEvent(\n new CustomEvent<ReactiveUnstable.DebugLog.Entry>('lit-debug', {\n detail: event,\n })\n );\n }\n : undefined;\n\n/*\n * When using Closure Compiler, JSCompiler_renameProperty(property, object) is\n * replaced at compile time by the munged name for object[property]. We cannot\n * alias this function, so we have to use a small shim that has the same\n * behavior when not compiling.\n */\n/*@__INLINE__*/\nconst JSCompiler_renameProperty = <P extends PropertyKey>(\n prop: P,\n _obj: unknown\n): P => prop;\n\n/**\n * Converts property values to and from attribute values.\n */\nexport interface ComplexAttributeConverter<Type = unknown, TypeHint = unknown> {\n /**\n * Called to convert an attribute value to a property\n * value.\n */\n fromAttribute?(value: string | null, type?: TypeHint): Type;\n\n /**\n * Called to convert a property value to an attribute\n * value.\n *\n * It returns unknown instead of string, to be compatible with\n * https://github.com/WICG/trusted-types (and similar efforts).\n */\n toAttribute?(value: Type, type?: TypeHint): unknown;\n}\n\ntype AttributeConverter<Type = unknown, TypeHint = unknown> =\n | ComplexAttributeConverter<Type>\n | ((value: string | null, type?: TypeHint) => Type);\n\n/**\n * Defines options for a property accessor.\n */\nexport interface PropertyDeclaration<Type = unknown, TypeHint = unknown> {\n /**\n * When set to `true`, indicates the property is internal private state. The\n * property should not be set by users. When using TypeScript, this property\n * should be marked as `private` or `protected`, and it is also a common\n * practice to use a leading `_` in the name. The property is not added to\n * `observedAttributes`.\n */\n readonly state?: boolean;\n\n /**\n * Indicates how and whether the property becomes an observed attribute.\n * If the value is `false`, the property is not added to `observedAttributes`.\n * If true or absent, the lowercased property name is observed (e.g. `fooBar`\n * becomes `foobar`). If a string, the string value is observed (e.g\n * `attribute: 'foo-bar'`).\n */\n readonly attribute?: boolean | string;\n\n /**\n * Indicates the type of the property. This is used only as a hint for the\n * `converter` to determine how to convert the attribute\n * to/from a property.\n */\n readonly type?: TypeHint;\n\n /**\n * Indicates how to convert the attribute to/from a property. If this value\n * is a function, it is used to convert the attribute value a the property\n * value. If it's an object, it can have keys for `fromAttribute` and\n * `toAttribute`. If no `toAttribute` function is provided and\n * `reflect` is set to `true`, the property value is set directly to the\n * attribute. A default `converter` is used if none is provided; it supports\n * `Boolean`, `String`, `Number`, `Object`, and `Array`. Note,\n * when a property changes and the converter is used to update the attribute,\n * the property is never updated again as a result of the attribute changing,\n * and vice versa.\n */\n readonly converter?: AttributeConverter<Type, TypeHint>;\n\n /**\n * Indicates if the property should reflect to an attribute.\n * If `true`, when the property is set, the attribute is set using the\n * attribute name determined according to the rules for the `attribute`\n * property option and the value of the property converted using the rules\n * from the `converter` property option.\n */\n readonly reflect?: boolean;\n\n /**\n * A function that indicates if a property should be considered changed when\n * it is set. The function should take the `newValue` and `oldValue` and\n * return `true` if an update should be requested.\n */\n hasChanged?(value: Type, oldValue: Type): boolean;\n\n /**\n * Indicates whether an accessor will be created for this property. By\n * default, an accessor will be generated for this property that requests an\n * update when set. If this flag is `true`, no accessor will be created, and\n * it will be the user's responsibility to call\n * `this.requestUpdate(propertyName, oldValue)` to request an update when\n * the property changes.\n */\n readonly noAccessor?: boolean;\n\n /**\n * Whether this property is wrapping accessors. This is set by `@property`\n * to control the initial value change and reflection logic.\n *\n * @internal\n */\n wrapped?: boolean;\n\n /**\n * When `true`, uses the initial value of the property as the default value,\n * which changes how attributes are handled:\n * - The initial value does *not* reflect, even if the `reflect` option is `true`.\n * Subsequent changes to the property will reflect, even if they are equal to the\n * default value.\n * - When the attribute is removed, the property is set to the default value\n * - The initial value will not trigger an old value in the `changedProperties` map\n * argument to update lifecycle methods.\n *\n * When set, properties must be initialized, either with a field initializer, or an\n * assignment in the constructor. Not initializing the property may lead to\n * improper handling of subsequent property assignments.\n *\n * While this behavior is opt-in, most properties that reflect to attributes should\n * use `useDefault: true` so that their initial values do not reflect.\n */\n useDefault?: boolean;\n}\n\n/**\n * Map of properties to PropertyDeclaration options. For each property an\n * accessor is made, and the property is processed according to the\n * PropertyDeclaration options.\n */\nexport interface PropertyDeclarations {\n readonly [key: string]: PropertyDeclaration;\n}\n\ntype PropertyDeclarationMap = Map<PropertyKey, PropertyDeclaration>;\n\ntype AttributeMap = Map<string, PropertyKey>;\n\n/**\n * A Map of property keys to values.\n *\n * Takes an optional type parameter T, which when specified as a non-any,\n * non-unknown type, will make the Map more strongly-typed, associating the map\n * keys with their corresponding value type on T.\n *\n * Use `PropertyValues<this>` when overriding ReactiveElement.update() and\n * other lifecycle methods in order to get stronger type-checking on keys\n * and values.\n */\n// This type is conditional so that if the parameter T is not specified, or\n// is `any`, the type will include `Map<PropertyKey, unknown>`. Since T is not\n// given in the uses of PropertyValues in this file, all uses here fallback to\n// meaning `Map<PropertyKey, unknown>`, but if a developer uses\n// `PropertyValues<this>` (or any other value for T) they will get a\n// strongly-typed Map type.\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport type PropertyValues<T = any> = T extends object\n ? PropertyValueMap<T>\n : Map<PropertyKey, unknown>;\n\n/**\n * Do not use, instead prefer {@linkcode PropertyValues}.\n */\n// This type must be exported such that JavaScript generated by the Google\n// Closure Compiler can import a type reference.\nexport interface PropertyValueMap<T> extends Map<PropertyKey, unknown> {\n get<K extends keyof T>(k: K): T[K] | undefined;\n set<K extends keyof T>(key: K, value: T[K]): this;\n has<K extends keyof T>(k: K): boolean;\n delete<K extends keyof T>(k: K): boolean;\n}\n\nexport const defaultConverter: ComplexAttributeConverter = {\n toAttribute(value: unknown, type?: unknown): unknown {\n switch (type) {\n case Boolean:\n value = value ? emptyStringForBooleanAttribute : null;\n break;\n case Object:\n case Array:\n // if the value is `null` or `undefined` pass this through\n // to allow removing/no change behavior.\n value = value == null ? value : JSON.stringify(value);\n break;\n }\n return value;\n },\n\n fromAttribute(value: string | null, type?: unknown) {\n let fromValue: unknown = value;\n switch (type) {\n case Boolean:\n fromValue = value !== null;\n break;\n case Number:\n fromValue = value === null ? null : Number(value);\n break;\n case Object:\n case Array:\n // Do *not* generate exception when invalid JSON is set as elements\n // don't normally complain on being mis-configured.\n // TODO(sorvell): Do generate exception in *dev mode*.\n try {\n // Assert to adhere to Bazel's \"must type assert JSON parse\" rule.\n fromValue = JSON.parse(value!) as unknown;\n } catch (e) {\n fromValue = null;\n }\n break;\n }\n return fromValue;\n },\n};\n\nexport interface HasChanged {\n (value: unknown, old: unknown): boolean;\n}\n\n/**\n * Change function that returns true if `value` is different from `oldValue`.\n * This method is used as the default for a property's `hasChanged` function.\n */\nexport const notEqual: HasChanged = (value: unknown, old: unknown): boolean =>\n !is(value, old);\n\nconst defaultPropertyDeclaration: PropertyDeclaration = {\n attribute: true,\n type: String,\n converter: defaultConverter,\n reflect: false,\n useDefault: false,\n hasChanged: notEqual,\n};\n\n/**\n * A string representing one of the supported dev mode warning categories.\n */\nexport type WarningKind =\n | 'change-in-update'\n | 'migration'\n | 'async-perform-update';\n\nexport type Initializer = (element: ReactiveElement) => void;\n\n// Temporary, until google3 is on TypeScript 5.2\ndeclare global {\n interface SymbolConstructor {\n readonly metadata: unique symbol;\n }\n}\n\n// Ensure metadata is enabled. TypeScript does not polyfill\n// Symbol.metadata, so we must ensure that it exists.\n(Symbol as {metadata: symbol}).metadata ??= Symbol('metadata');\n\ndeclare global {\n // This is public global API, do not change!\n // eslint-disable-next-line no-var\n var litPropertyMetadata: WeakMap<\n object,\n Map<PropertyKey, PropertyDeclaration>\n >;\n}\n\n// Map from a class's metadata object to property options\n// Note that we must use nullish-coalescing assignment so that we only use one\n// map even if we load multiple version of this module.\nglobal.litPropertyMetadata ??= new WeakMap<\n object,\n Map<PropertyKey, PropertyDeclaration>\n>();\n\n/**\n * Base element class which manages element properties and attributes. When\n * properties change, the `update` method is asynchronously called. This method\n * should be supplied by subclasses to render updates as desired.\n * @noInheritDoc\n */\nexport abstract class ReactiveElement\n // In the Node build, this `extends` clause will be substituted with\n // `(globalThis.HTMLElement ?? HTMLElement)`.\n //\n // This way, we will first prefer any global `HTMLElement` polyfill that the\n // user has assigned, and then fall back to the `HTMLElement` shim which has\n // been imported (see note at the top of this file about how this import is\n // generated by Rollup). Note that the `HTMLElement` variable has been\n // shadowed by this import, so it no longer refers to the global.\n extends HTMLElement\n implements ReactiveControllerHost\n{\n // Note: these are patched in only in DEV_MODE.\n /**\n * Read or set all the enabled warning categories for this class.\n *\n * This property is only used in development builds.\n *\n * @nocollapse\n * @category dev-mode\n */\n static enabledWarnings?: WarningKind[];\n\n /**\n * Enable the given warning category for this class.\n *\n * This method only exists in development builds, so it should be accessed\n * with a guard like:\n *\n * ```ts\n * // Enable for all ReactiveElement subclasses\n * ReactiveElement.enableWarning?.('migration');\n *\n * // Enable for only MyElement and subclasses\n * MyElement.enableWarning?.('migration');\n * ```\n *\n * @nocollapse\n * @category dev-mode\n */\n static enableWarning?: (warningKind: WarningKind) => void;\n\n /**\n * Disable the given warning category for this class.\n *\n * This method only exists in development builds, so it should be accessed\n * with a guard like:\n *\n * ```ts\n * // Disable for all ReactiveElement subclasses\n * ReactiveElement.disableWarning?.('migration');\n *\n * // Disable for only MyElement and subclasses\n * MyElement.disableWarning?.('migration');\n * ```\n *\n * @nocollapse\n * @category dev-mode\n */\n static disableWarning?: (warningKind: WarningKind) => void;\n\n /**\n * Adds an initializer function to the class that is called during instance\n * construction.\n *\n * This is useful for code that runs against a `ReactiveElement`\n * subclass, such as a decorator, that needs to do work for each\n * instance, such as setting up a `ReactiveController`.\n *\n * ```ts\n * const myDecorator = (target: typeof ReactiveElement, key: string) => {\n * target.addInitializer((instance: ReactiveElement) => {\n * // This is run during construction of the element\n * new MyController(instance);\n * });\n * }\n * ```\n *\n * Decorating a field will then cause each instance to run an initializer\n * that adds a controller:\n *\n * ```ts\n * class MyElement extends LitElement {\n * @myDecorator foo;\n * }\n * ```\n *\n * Initializers are stored per-constructor. Adding an initializer to a\n * subclass does not add it to a superclass. Since initializers are run in\n * constructors, initializers will run in order of the class hierarchy,\n * starting with superclasses and progressing to the instance's class.\n *\n * @nocollapse\n */\n static addInitializer(initializer: Initializer) {\n this.__prepare();\n (this._initializers ??= []).push(initializer);\n }\n\n static _initializers?: Initializer[];\n\n /*\n * Due to closure compiler ES6 compilation bugs, @nocollapse is required on\n * all static methods and properties with initializers. Reference:\n * - https://github.com/google/closure-compiler/issues/1776\n */\n\n /**\n * Maps attribute names to properties; for example `foobar` attribute to\n * `fooBar` property. Created lazily on user subclasses when finalizing the\n * class.\n * @nocollapse\n */\n private static __attributeToPropertyMap: AttributeMap;\n\n /**\n * Marks class as having been finalized, which includes creating properties\n * from `static properties`, but does *not* include all properties created\n * from decorators.\n * @nocollapse\n */\n protected static finalized: true | undefined;\n\n /**\n * Memoized list of all element properties, including any superclass\n * properties. Created lazily on user subclasses when finalizing the class.\n *\n * @nocollapse\n * @category properties\n */\n static elementProperties: PropertyDeclarationMap;\n\n /**\n * User-supplied object that maps property names to `PropertyDeclaration`\n * objects containing options for configuring reactive properties. When\n * a reactive property is set the element will update and render.\n *\n * By default properties are public fields, and as such, they should be\n * considered as primarily settable by element users, either via attribute or\n * the property itself.\n *\n * Generally, properties that are changed by the element should be private or\n * protected fields and should use the `state: true` option. Properties\n * marked as `state` do not reflect from the corresponding attribute\n *\n * However, sometimes element code does need to set a public property. This\n * should typically only be done in response to user interaction, and an event\n * should be fired informing the user; for example, a checkbox sets its\n * `checked` property when clicked and fires a `changed` event. Mutating\n * public properties should typically not be done for non-primitive (object or\n * array) properties. In other cases when an element needs to manage state, a\n * private property set with the `state: true` option should be used. When\n * needed, state properties can be initialized via public properties to\n * facilitate complex interactions.\n * @nocollapse\n * @category properties\n */\n static properties: PropertyDeclarations;\n\n /**\n * Memoized list of all element styles.\n * Created lazily on user subclasses when finalizing the class.\n * @nocollapse\n * @category styles\n */\n static elementStyles: Array<CSSResultOrNative> = [];\n\n /**\n * Array of styles to apply to the element. The styles should be defined\n * using the {@linkcode css} tag function, via constructible stylesheets, or\n * imported from native CSS module scripts.\n *\n * Note on Content Security Policy:\n *\n * Element styles are implemented with `<style>` tags when the browser doesn't\n * support adopted StyleSheets. To use such `<style>` tags with the style-src\n * CSP directive, the style-src value must either include 'unsafe-inline' or\n * `nonce-<base64-value>` with `<base64-value>` replaced be a server-generated\n * nonce.\n *\n * To provide a nonce to use on generated `<style>` elements, set\n * `window.litNonce` to a server-generated nonce in your page's HTML, before\n * loading application code:\n *\n * ```html\n * <script>\n * // Generated and unique per request:\n * window.litNonce = 'a1b2c3d4';\n * </script>\n * ```\n * @nocollapse\n * @category styles\n */\n static styles?: CSSResultGroup;\n\n /**\n * Returns a list of attributes corresponding to the registered properties.\n * @nocollapse\n * @category attributes\n */\n static get observedAttributes() {\n // Ensure we've created all properties\n this.finalize();\n // this.__attributeToPropertyMap is only undefined after finalize() in\n // ReactiveElement itself. ReactiveElement.observedAttributes is only\n // accessed with ReactiveElement as the receiver when a subclass or mixin\n // calls super.observedAttributes\n return (\n this.__attributeToPropertyMap && [...this.__attributeToPropertyMap.keys()]\n );\n }\n\n private __instanceProperties?: PropertyValues = undefined;\n\n /**\n * Creates a property accessor on the element prototype if one does not exist\n * and stores a {@linkcode PropertyDeclaration} for the property with the\n * given options. The property setter calls the property's `hasChanged`\n * property option or uses a strict identity check to determine whether or not\n * to request an update.\n *\n * This method may be overridden to customize properties; however,\n * when doing so, it's important to call `super.createProperty` to ensure\n * the property is setup correctly. This method calls\n * `getPropertyDescriptor` internally to get a descriptor to install.\n * To customize what properties do when they are get or set, override\n * `getPropertyDescriptor`. To customize the options for a property,\n * implement `createProperty` like this:\n *\n * ```ts\n * static createProperty(name, options) {\n * options = Object.assign(options, {myOption: true});\n * super.createProperty(name, options);\n * }\n * ```\n *\n * @nocollapse\n * @category properties\n */\n static createProperty(\n name: PropertyKey,\n options: PropertyDeclaration = defaultPropertyDeclaration\n ) {\n // If this is a state property, force the attribute to false.\n if (options.state) {\n (options as Mutable<PropertyDeclaration, 'attribute'>).attribute = false;\n }\n this.__prepare();\n // Whether this property is wrapping accessors.\n // Helps control the initial value change and reflection logic.\n if (this.prototype.hasOwnProperty(name)) {\n options = Object.create(options);\n options.wrapped = true;\n }\n this.elementProperties.set(name, options);\n if (!options.noAccessor) {\n const key = DEV_MODE\n ? // Use Symbol.for in dev mode to make it easier to maintain state\n // when doing HMR.\n Symbol.for(`${String(name)} (@property() cache)`)\n : Symbol();\n const descriptor = this.getPropertyDescriptor(name, key, options);\n if (descriptor !== undefined) {\n defineProperty(this.prototype, name, descriptor);\n }\n }\n }\n\n /**\n * Returns a property descriptor to be defined on the given named property.\n * If no descriptor is returned, the property will not become an accessor.\n * For example,\n *\n * ```ts\n * class MyElement extends LitElement {\n * static getPropertyDescriptor(name, key, options) {\n * const defaultDescriptor =\n * super.getPropertyDescriptor(name, key, options);\n * const setter = defaultDescriptor.set;\n * return {\n * get: defaultDescriptor.get,\n * set(value) {\n * setter.call(this, value);\n * // custom action.\n * },\n * configurable: true,\n * enumerable: true\n * }\n * }\n * }\n * ```\n *\n * @nocollapse\n * @category properties\n */\n protected static getPropertyDescriptor(\n name: PropertyKey,\n key: string | symbol,\n options: PropertyDeclaration\n ): PropertyDescriptor | undefined {\n const {get, set} = getOwnPropertyDescriptor(this.prototype, name) ?? {\n get(this: ReactiveElement) {\n return this[key as keyof typeof this];\n },\n set(this: ReactiveElement, v: unknown) {\n (this as unknown as Record<string | symbol, unknown>)[key] = v;\n },\n };\n if (DEV_MODE && get == null) {\n if ('value' in (getOwnPropertyDescriptor(this.prototype, name) ?? {})) {\n throw new Error(\n `Field ${JSON.stringify(String(name))} on ` +\n `${this.name} was declared as a reactive property ` +\n `but it's actually declared as a value on the prototype. ` +\n `Usually this is due to using @property or @state on a method.`\n );\n }\n issueWarning(\n 'reactive-property-without-getter',\n `Field ${JSON.stringify(String(name))} on ` +\n `${this.name} was declared as a reactive property ` +\n `but it does not have a getter. This will be an error in a ` +\n `future version of Lit.`\n );\n }\n return {\n get,\n set(this: ReactiveElement, value: unknown) {\n const oldValue = get?.call(this);\n set?.call(this, value);\n this.requestUpdate(name, oldValue, options);\n },\n configurable: true,\n enumerable: true,\n };\n }\n\n /**\n * Returns the property options associated with the given property.\n * These options are defined with a `PropertyDeclaration` via the `properties`\n * object or the `@property` decorator and are registered in\n * `createProperty(...)`.\n *\n * Note, this method should be considered \"final\" and not overridden. To\n * customize the options for a given property, override\n * {@linkcode createProperty}.\n *\n * @nocollapse\n * @final\n * @category properties\n */\n static getPropertyOptions(name: PropertyKey) {\n return this.elementProperties.get(name) ?? defaultPropertyDeclaration;\n }\n\n // Temporary, until google3 is on TypeScript 5.2\n declare static [Symbol.metadata]: object & Record<PropertyKey, unknown>;\n\n /**\n * Initializes static own properties of the class used in bookkeeping\n * for element properties, initializers, etc.\n *\n * Can be called multiple times by code that needs to ensure these\n * properties exist before using them.\n *\n * This method ensures the superclass is finalized so that inherited\n * property metadata can be copied down.\n * @nocollapse\n */\n private static __prepare() {\n if (\n this.hasOwnProperty(JSCompiler_renameProperty('elementProperties', this))\n ) {\n // Already prepared\n return;\n }\n // Finalize any superclasses\n const superCtor = getPrototypeOf(this) as typeof ReactiveElement;\n superCtor.finalize();\n\n // Create own set of initializers for this class if any exist on the\n // superclass and copy them down. Note, for a small perf boost, avoid\n // creating initializers unless needed.\n if (superCtor._initializers !== undefined) {\n this._initializers = [...superCtor._initializers];\n }\n // Initialize elementProperties from the superclass\n this.elementProperties = new Map(superCtor.elementProperties);\n }\n\n /**\n * Finishes setting up the class so that it's ready to be registered\n * as a custom element and instantiated.\n *\n * This method is called by the ReactiveElement.observedAttributes getter.\n * If you override the observedAttributes getter, you must either call\n * super.observedAttributes to trigger finalization, or call finalize()\n * yourself.\n *\n * @nocollapse\n */\n protected static finalize() {\n if (this.hasOwnProperty(JSCompiler_renameProperty('finalized', this))) {\n return;\n }\n this.finalized = true;\n this.__prepare();\n\n // Create properties from the static properties block:\n if (this.hasOwnProperty(JSCompiler_renameProperty('properties', this))) {\n const props = this.properties;\n const propKeys = [\n ...getOwnPropertyNames(props),\n ...getOwnPropertySymbols(props),\n ] as Array<keyof typeof props>;\n for (const p of propKeys) {\n this.createProperty(p, props[p]);\n }\n }\n\n // Create properties from standard decorator metadata:\n const metadata = this[Symbol.metadata];\n if (metadata !== null) {\n const properties = litPropertyMetadata.get(metadata);\n if (properties !== undefined) {\n for (const [p, options] of properties) {\n this.elementProperties.set(p, options);\n }\n }\n }\n\n // Create the attribute-to-property map\n this.__attributeToPropertyMap = new Map();\n for (const [p, options] of this.elementProperties) {\n const attr = this.__attributeNameForProperty(p, options);\n if (attr !== undefined) {\n this.__attributeToPropertyMap.set(attr, p);\n }\n }\n\n this.elementStyles = this.finalizeStyles(this.styles);\n\n if (DEV_MODE) {\n if (this.hasOwnProperty('createProperty')) {\n issueWarning(\n 'no-override-create-property',\n 'Overriding ReactiveElement.createProperty() is deprecated. ' +\n 'The override will not be called with standard decorators'\n );\n }\n if (this.hasOwnProperty('getPropertyDescriptor')) {\n issueWarning(\n 'no-override-get-property-descriptor',\n 'Overriding ReactiveElement.getPropertyDescriptor() is deprecated. ' +\n 'The override will not be called with standard decorators'\n );\n }\n }\n }\n\n /**\n * Options used when calling `attachShadow`. Set this property to customize\n * the options for the shadowRoot; for example, to create a closed\n * shadowRoot: `{mode: 'closed'}`.\n *\n * Note, these options are used in `createRenderRoot`. If this method\n * is customized, options should be respected if possible.\n * @nocollapse\n * @category rendering\n */\n static shadowRootOptions: ShadowRootInit = {mode: 'open'};\n\n /**\n * Takes the styles the user supplied via the `static styles` property and\n * returns the array of styles to apply to the element.\n * Override this method to integrate into a style management system.\n *\n * Styles are deduplicated preserving the _last_ instance in the list. This\n * is a performance optimization to avoid duplicated styles that can occur\n * especially when composing via subclassing. The last item is kept to try\n * to preserve the cascade order with the assumption that it's most important\n * that last added styles override previous styles.\n *\n * @nocollapse\n * @category styles\n */\n protected static finalizeStyles(\n styles?: CSSResultGroup\n ): Array<CSSResultOrNative> {\n const elementStyles = [];\n if (Array.isArray(styles)) {\n // Dedupe the flattened array in reverse order to preserve the last items.\n // Casting to Array<unknown> works around TS error that\n // appears to come from trying to flatten a type CSSResultArray.\n const set = new Set((styles as Array<unknown>).flat(Infinity).reverse());\n // Then preserve original order by adding the set items in reverse order.\n for (const s of set) {\n elementStyles.unshift(getCompatibleStyle(s as CSSResultOrNative));\n }\n } else if (styles !== undefined) {\n elementStyles.push(getCompatibleStyle(styles));\n }\n return elementStyles;\n }\n\n /**\n * Node or ShadowRoot into which element DOM should be rendered. Defaults\n * to an open shadowRoot.\n * @category rendering\n */\n readonly renderRoot!: HTMLElement | DocumentFragment;\n\n /**\n * Returns the property name for the given attribute `name`.\n * @nocollapse\n */\n private static __attributeNameForProperty(\n name: PropertyKey,\n options: PropertyDeclaration\n ) {\n const attribute = options.attribute;\n return attribute === false\n ? undefined\n : typeof attribute === 'string'\n ? attribute\n : typeof name === 'string'\n ? name.toLowerCase()\n : undefined;\n }\n\n // Initialize to an unresolved Promise so we can make sure the element has\n // connected before first update.\n private __updatePromise!: Promise<boolean>;\n\n /**\n * True if there is a pending update as a result of calling `requestUpdate()`.\n * Should only be read.\n * @category updates\n */\n isUpdatePending = false;\n\n /**\n * Is set to `true` after the first update. The element code cannot assume\n * that `renderRoot` exists before the element `hasUpdated`.\n * @category updates\n */\n hasUpdated = false;\n\n /**\n * Map with keys for any properties that have changed since the last\n * update cycle with previous values.\n *\n * @internal\n */\n _$changedProperties!: PropertyValues;\n\n /**\n * Records property default values when the\n * `useDefault` option is used.\n */\n private __defaultValues?: Map<PropertyKey, unknown>;\n\n /**\n * Properties that should be reflected when updated.\n */\n private __reflectingProperties?: Set<PropertyKey>;\n\n /**\n * Name of currently reflecting property\n */\n private __reflectingProperty: PropertyKey | null = null;\n\n /**\n * Set of controllers.\n */\n private __controllers?: Set<ReactiveController>;\n\n constructor() {\n super();\n this.__initialize();\n }\n\n /**\n * Internal only override point for customizing work done when elements\n * are constructed.\n */\n private __initialize() {\n this.__updatePromise = new Promise<boolean>(\n (res) => (this.enableUpdating = res)\n );\n this._$changedProperties = new Map();\n // This enqueues a microtask that must run before the first update, so it\n // must be called before requestUpdate()\n this.__saveInstanceProperties();\n // ensures first update will be caught by an early access of\n // `updateComplete`\n this.requestUpdate();\n (this.constructor as typeof ReactiveElement)._initializers?.forEach((i) =>\n i(this)\n );\n }\n\n /**\n * Registers a `ReactiveController` to participate in the element's reactive\n * update cycle. The element automatically calls into any registered\n * controllers during its lifecycle callbacks.\n *\n * If the element is connected when `addController()` is called, the\n * controller's `hostConnected()` callback will be immediately called.\n * @category controllers\n */\n addController(controller: ReactiveController) {\n (this.__controllers ??= new Set()).add(controller);\n // If a controller is added after the element has been connected,\n // call hostConnected. Note, re-using existence of `renderRoot` here\n // (which is set in connectedCallback) to avoid the need to track a\n // first connected state.\n if (this.renderRoot !== undefined && this.isConnected) {\n controller.hostConnected?.();\n }\n }\n\n /**\n * Removes a `ReactiveController` from the element.\n * @category controllers\n */\n removeController(controller: ReactiveController) {\n this.__controllers?.delete(controller);\n }\n\n /**\n * Fixes any properties set on the instance before upgrade time.\n * Otherwise these would shadow the accessor and break these properties.\n * The properties are stored in a Map which is played back after the\n * constructor runs.\n */\n private __saveInstanceProperties() {\n const instanceProperties = new Map<PropertyKey, unknown>();\n const elementProperties = (this.constructor as typeof ReactiveElement)\n .elementProperties;\n for (const p of elementProperties.keys() as IterableIterator<keyof this>) {\n if (this.hasOwnProperty(p)) {\n instanceProperties.set(p, this[p]);\n delete this[p];\n }\n }\n if (instanceProperties.size > 0) {\n this.__instanceProperties = instanceProperties;\n }\n }\n\n /**\n * Returns the node into which the element should render and by default\n * creates and returns an open shadowRoot. Implement to customize where the\n * element's DOM is rendered. For example, to render into the element's\n * childNodes, return `this`.\n *\n * @return Returns a node into which to render.\n * @category rendering\n */\n protected createRenderRoot(): HTMLElement | DocumentFragment {\n const renderRoot =\n this.shadowRoot ??\n this.attachShadow(\n (this.constructor as typeof ReactiveElement).shadowRootOptions\n );\n adoptStyles(\n renderRoot,\n (this.constructor as typeof ReactiveElement).elementStyles\n );\n return renderRoot;\n }\n\n /**\n * On first connection, creates the element's renderRoot, sets up\n * element styling, and enables updating.\n * @category lifecycle\n */\n connectedCallback() {\n // Create renderRoot before controllers `hostConnected`\n (this as Mutable<typeof this, 'renderRoot'>).renderRoot ??=\n this.createRenderRoot();\n this.enableUpdating(true);\n this.__controllers?.forEach((c) => c.hostConnected?.());\n }\n\n /**\n * Note, this method should be considered final and not overridden. It is\n * overridden on the element instance with a function that triggers the first\n * update.\n * @category updates\n */\n protected enableUpdating(_requestedUpdate: boolean) {}\n\n /**\n * Allows for `super.disconnectedCallback()` in extensions while\n * reserving the possibility of making non-breaking feature additions\n * when disconnecting at some point in the future.\n * @category lifecycle\n */\n disconnectedCallback() {\n this.__controllers?.forEach((c) => c.hostDisconnected?.());\n }\n\n /**\n * Synchronizes property values when attributes change.\n *\n * Specifically, when an attribute is set, the corresponding property is set.\n * You should rarely need to implement this callback. If this method is\n * overridden, `super.attributeChangedCallback(name, _old, value)` must be\n * called.\n *\n * See [responding to attribute changes](https://developer.mozilla.org/en-US/docs/Web/API/Web_components/Using_custom_elements#responding_to_attribute_changes)\n * on MDN for more information about the `attributeChangedCallback`.\n * @category attributes\n */\n attributeChangedCallback(\n name: string,\n _old: string | null,\n value: string | null\n ) {\n this._$attributeToProperty(name, value);\n }\n\n private __propertyToAttribute(name: PropertyKey, value: unknown) {\n const elemProperties: PropertyDeclarationMap = (\n this.constructor as typeof ReactiveElement\n ).elementProperties;\n const options = elemProperties.get(name)!;\n const attr = (\n this.constructor as typeof ReactiveElement\n ).__attributeNameForProperty(name, options);\n if (attr !== undefined && options.reflect === true) {\n const converter =\n (options.converter as ComplexAttributeConverter)?.toAttribute !==\n undefined\n ? (options.converter as ComplexAttributeConverter)\n : defaultConverter;\n const attrValue = converter.toAttribute!(value, options.type);\n if (\n DEV_MODE &&\n (this.constructor as typeof ReactiveElement).enabledWarnings!.includes(\n 'migration'\n ) &&\n attrValue === undefined\n ) {\n issueWarning(\n 'undefined-attribute-value',\n `The attribute value for the ${name as string} property is ` +\n `undefined on element ${this.localName}. The attribute will be ` +\n `removed, but in the previous version of \\`ReactiveElement\\`, ` +\n `the attribute would not have changed.`\n );\n }\n // Track if the property is being reflected to avoid\n // setting the property again via `attributeChangedCallback`. Note:\n // 1. this takes advantage of the fact that the callback is synchronous.\n // 2. will behave incorrectly if multiple attributes are in the reaction\n // stack at time of calling. However, since we process attributes\n // in `update` this should not be possible (or an extreme corner case\n // that we'd like to discover).\n // mark state reflecting\n this.__reflectingProperty = name;\n if (attrValue == null) {\n this.removeAttribute(attr);\n } else {\n this.setAttribute(attr, attrValue as string);\n }\n // mark state not reflecting\n this.__reflectingProperty = null;\n }\n }\n\n /** @internal */\n _$attributeToProperty(name: string, value: string | null) {\n const ctor = this.constructor as typeof ReactiveElement;\n // Note, hint this as an `AttributeMap` so closure clearly understands\n // the type; it has issues with tracking types through statics\n const propName = (ctor.__attributeToPropertyMap as AttributeMap).get(name);\n // Use tracking info to avoid reflecting a property value to an attribute\n // if it was just set because the attribute changed.\n if (propName !== undefined && this.__reflectingProperty !== propName) {\n const options = ctor.getPropertyOptions(propName);\n const converter =\n typeof options.converter === 'function'\n ? {fromAttribute: options.converter}\n : options.converter?.fromAttribute !== undefined\n ? options.converter\n : defaultConverter;\n // mark state reflecting\n this.__reflectingProperty = propName;\n const convertedValue = converter.fromAttribute!(value, options.type);\n this[propName as keyof this] =\n convertedValue ??\n this.__defaultValues?.get(propName) ??\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n (convertedValue as any);\n // mark state not reflecting\n this.__reflectingProperty = null;\n }\n }\n\n /**\n * Requests an update which is processed asynchronously. This should be called\n * when an element should update based on some state not triggered by setting\n * a reactive property. In this case, pass no arguments. It should also be\n * called when manually implementing a property setter. In this case, pass the\n * property `name` and `oldValue` to ensure that any configured property\n * options are honored.\n *\n * @param name name of requesting property\n * @param oldValue old value of requesting property\n * @param options property options to use instead of the previously\n * configured options\n * @param useNewValue if true, the newValue argument is used instead of\n * reading the property value. This is important to use if the reactive\n * property is a standard private accessor, as opposed to a plain\n * property, since private members can't be dynamically read by name.\n * @param newValue the new value of the property. This is only used if\n * `useNewValue` is true.\n * @category updates\n */\n requestUpdate(\n name?: PropertyKey,\n oldValue?: unknown,\n options?: PropertyDeclaration,\n useNewValue = false,\n newValue?: unknown\n ): void {\n // If we have a property key, perform property update steps.\n if (name !== undefined) {\n if (DEV_MODE && (name as unknown) instanceof Event) {\n issueWarning(\n ``,\n `The requestUpdate() method was called with an Event as the property name. This is probably a mistake caused by binding this.requestUpdate as an event listener. Instead bind a function that will call it with no arguments: () => this.requestUpdate()`\n );\n }\n const ctor = this.constructor as typeof ReactiveElement;\n if (useNewValue === false) {\n newValue = this[name as keyof this];\n }\n options ??= ctor.getPropertyOptions(name);\n const changed =\n (options.hasChanged ?? notEqual)(newValue, oldValue) ||\n // When there is no change, check a corner case that can occur when\n // 1. there's a initial value which was not reflected\n // 2. the property is subsequently set to this value.\n // For example, `prop: {useDefault: true, reflect: true}`\n // and el.prop = 'foo'. This should be considered a change if the\n // attribute is not set because we will now reflect the property to the attribute.\n (options.useDefault &&\n options.reflect &&\n newValue === this.__defaultValues?.get(name) &&\n !this.hasAttribute(ctor.__attributeNameForProperty(name, options)!));\n if (changed) {\n this._$changeProperty(name, oldValue, options);\n } else {\n // Abort the request if the property should not be considered changed.\n return;\n }\n }\n if (this.isUpdatePending === false) {\n this.__updatePromise = this.__enqueueUpdate();\n }\n }\n\n /**\n * @internal\n */\n _$changeProperty(\n name: PropertyKey,\n oldValue: unknown,\n {useDefault, reflect, wrapped}: PropertyDeclaration,\n initializeValue?: unknown\n ) {\n // Record default value when useDefault is used. This allows us to\n // restore this value when the attribute is removed.\n if (useDefault && !(this.__defaultValues ??= new Map()).has(name)) {\n this.__defaultValues.set(\n name,\n initializeValue ?? oldValue ?? this[name as keyof this]\n );\n // if this is not wrapping an accessor, it must be an initial setting\n // and in this case we do not want to record the change or reflect.\n if (wrapped !== true || initializeValue !== undefined) {\n return;\n }\n }\n // TODO (justinfagnani): Create a benchmark of Map.has() + Map.set(\n // vs just Map.set()\n if (!this._$changedProperties.has(name)) {\n // On the initial change, the old value should be `undefined`, except\n // with `useDefault`\n if (!this.hasUpdated && !useDefault) {\n oldValue = undefined;\n }\n this._$changedProperties.set(name, oldValue);\n }\n // Add to reflecting properties set.\n // Note, it's important that every change has a chance to add the\n // property to `__reflectingProperties`. This ensures setting\n // attribute + property reflects correctly.\n if (reflect === true && this.__reflectingProperty !== name) {\n (this.__reflectingProperties ??= new Set<PropertyKey>()).add(name);\n }\n }\n\n /**\n * Sets up the element to asynchronously update.\n */\n private async __enqueueUpdate() {\n this.isUpdatePending = true;\n try {\n // Ensure any previous update has resolved before updating.\n // This `await` also ensures that property changes are batched.\n await this.__updatePromise;\n } catch (e) {\n // Refire any previous errors async so they do not disrupt the update\n // cycle. Errors are refired so developers have a chance to observe\n // them, and this can be done by implementing\n // `window.onunhandledrejection`.\n Promise.reject(e);\n }\n const result = this.scheduleUpdate();\n // If `scheduleUpdate` returns a Promise, we await it. This is done to\n // enable coordinating updates with a scheduler. Note, the result is\n // checked to avoid delaying an additional microtask unless we need to.\n if (result != null) {\n await result;\n }\n return !this.isUpdatePending;\n }\n\n /**\n * Schedules an element update. You can override this method to change the\n * timing of updates by returning a Promise. The update will await the\n * returned Promise, and you should resolve the Promise to allow the update\n * to proceed. If this method is overridden, `super.scheduleUpdate()`\n * must be called.\n *\n * For instance, to schedule updates to occur just before the next frame:\n *\n * ```ts\n * override protected async scheduleUpdate(): Promise<unknown> {\n * await new Promise((resolve) => requestAnimationFrame(() => resolve()));\n * super.scheduleUpdate();\n * }\n * ```\n * @category updates\n */\n protected scheduleUpdate(): void | Promise<unknown> {\n const result = this.performUpdate();\n if (\n DEV_MODE &&\n (this.constructor as typeof ReactiveElement).enabledWarnings!.includes(\n 'async-perform-update'\n ) &&\n typeof (result as unknown as Promise<unknown> | undefined)?.then ===\n 'function'\n ) {\n issueWarning(\n 'async-perform-update',\n `Element ${this.localName} returned a Promise from performUpdate(). ` +\n `This behavior is deprecated and will be removed in a future ` +\n `version of ReactiveElement.`\n );\n }\n return result;\n }\n\n /**\n * Performs an element update. Note, if an exception is thrown during the\n * update, `firstUpdated` and `updated` will not be called.\n *\n * Call `performUpdate()` to immediately process a pending update. This should\n * generally not be needed, but it can be done in rare cases when you need to\n * update synchronously.\n *\n * @category updates\n */\n protected performUpdate(): void {\n // Abort any update if one is not pending when this is called.\n // This can happen if `performUpdate` is called early to \"flush\"\n // the update.\n if (!this.isUpdatePending) {\n return;\n }\n debugLogEvent?.({kind: 'update'});\n if (!this.hasUpdated) {\n // Create renderRoot before first update. This occurs in `connectedCallback`\n // but is done here to support out of tree calls to `enableUpdating`/`performUpdate`.\n (this as Mutable<typeof this, 'renderRoot'>).renderRoot ??=\n this.createRenderRoot();\n if (DEV_MODE) {\n // Produce warning if any reactive properties on the prototype are\n // shadowed by class fields. Instance fields set before upgrade are\n // deleted by this point, so any own property is caused by class field\n // initialization in the constructor.\n const ctor = this.constructor as typeof ReactiveElement;\n const shadowedProperties = [...ctor.elementProperties.keys()].filter(\n (p) => this.hasOwnProperty(p) && p in getPrototypeOf(this)\n );\n if (shadowedProperties.length) {\n throw new Error(\n `The following properties on element ${this.localName} will not ` +\n `trigger updates as expected because they are set using class ` +\n `fields: ${shadowedProperties.join(', ')}. ` +\n `Native class fields and some compiled output will overwrite ` +\n `accessors used for detecting changes. See ` +\n `https://lit.dev/msg/class-field-shadowing ` +\n `for more information.`\n );\n }\n }\n // Mixin instance properties once, if they exist.\n if (this.__instanceProperties) {\n // TODO (justinfagnani): should we use the stored value? Could a new value\n // have been set since we stored the own property value?\n for (const [p, value] of this.__instanceProperties) {\n this[p as keyof this] = value as this[keyof this];\n }\n this.__instanceProperties = undefined;\n }\n // Trigger initial value reflection and populate the initial\n // `changedProperties` map, but only for the case of properties created\n // via `createProperty` on accessors, which will not have already\n // populated the `changedProperties` map since they are not set.\n // We can't know if these accessors had initializers, so we just set\n // them anyway - a difference from experimental decorators on fields and\n // standard decorators on auto-accessors.\n // For context see:\n // https://github.com/lit/lit/pull/4183#issuecomment-1711959635\n const elementProperties = (this.constructor as typeof ReactiveElement)\n .elementProperties;\n if (elementProperties.size > 0) {\n for (const [p, options] of elementProperties) {\n const {wrapped} = options;\n const value = this[p as keyof this];\n if (\n wrapped === true &&\n !this._$changedProperties.has(p) &&\n value !== undefined\n ) {\n this._$changeProperty(p, undefined, options, value);\n }\n }\n }\n }\n let shouldUpdate = false;\n const changedProperties = this._$changedProperties;\n try {\n shouldUpdate = this.shouldUpdate(changedProperties);\n if (shouldUpdate) {\n this.willUpdate(changedProperties);\n this.__controllers?.forEach((c) => c.hostUpdate?.());\n this.update(changedProperties);\n } else {\n this.__markUpdated();\n }\n } catch (e) {\n // Prevent `firstUpdated` and `updated` from running when there's an\n // update exception.\n shouldUpdate = false;\n // Ensure element can accept additional updates after an exception.\n this.__markUpdated();\n throw e;\n }\n // The update is no longer considered pending and further updates are now allowed.\n if (shouldUpdate) {\n this._$didUpdate(changedProperties);\n }\n }\n\n /**\n * Invoked before `update()` to compute values needed during the update.\n *\n * Implement `willUpdate` to compute property values that depend on other\n * properties and are used in the rest of the update process.\n *\n * ```ts\n * willUpdate(changedProperties) {\n * // only need to check changed properties for an expensive computation.\n * if (changedProperties.has('firstName') || changedProperties.has('lastName')) {\n * this.sha = computeSHA(`${this.firstName} ${this.lastName}`);\n * }\n * }\n *\n * render() {\n * return html`SHA: ${this.sha}`;\n * }\n * ```\n *\n * @category updates\n */\n protected willUpdate(_changedProperties: PropertyValues): void {}\n\n // Note, this is an override point for polyfill-support.\n // @internal\n _$didUpdate(changedProperties: PropertyValues) {\n this.__controllers?.forEach((c) => c.hostUpdated?.());\n if (!this.hasUpdated) {\n this.hasUpdated = true;\n this.firstUpdated(changedProperties);\n }\n this.updated(changedProperties);\n if (\n DEV_MODE &&\n this.isUpdatePending &&\n (this.constructor as typeof ReactiveElement).enabledWarnings!.includes(\n 'change-in-update'\n )\n ) {\n issueWarning(\n 'change-in-update',\n `Element ${this.localName} scheduled an update ` +\n `(generally because a property was set) ` +\n `after an update completed, causing a new update to be scheduled. ` +\n `This is inefficient and should be avoided unless the next update ` +\n `can only be scheduled as a side effect of the previous update.`\n );\n }\n }\n\n private __markUpdated() {\n this._$changedProperties = new Map();\n this.isUpdatePending = false;\n }\n\n /**\n * Returns a Promise that resolves when the element has completed updating.\n * The Promise value is a boolean that is `true` if the element completed the\n * update without triggering another update. The Promise result is `false` if\n * a property was set inside `updated()`. If the Promise is rejected, an\n * exception was thrown during the update.\n *\n * To await additional asynchronous work, override the `getUpdateComplete`\n * method. For example, it is sometimes useful to await a rendered element\n * before fulfilling this Promise. To do this, first await\n * `super.getUpdateComplete()`, then any subsequent state.\n *\n * @return A promise of a boolean that resolves to true if the update completed\n * without triggering another update.\n * @category updates\n */\n get updateComplete(): Promise<boolean> {\n return this.getUpdateComplete();\n }\n\n /**\n * Override point for the `updateComplete` promise.\n *\n * It is not safe to override the `updateComplete` getter directly due to a\n * limitation in TypeScript which means it is not possible to call a\n * superclass getter (e.g. `super.updateComplete.then(...)`) when the target\n * language is ES5 (https://github.com/microsoft/TypeScript/issues/338).\n * This method should be overridden instead. For example:\n *\n * ```ts\n * class MyElement extends LitElement {\n * override async getUpdateComplete() {\n * const result = await super.getUpdateComplete();\n * await this._myChild.updateComplete;\n * return result;\n * }\n * }\n * ```\n *\n * @return A promise of a boolean that resolves to true if the update completed\n * without triggering another update.\n * @category updates\n */\n protected getUpdateComplete(): Promise<boolean> {\n return this.__updatePromise;\n }\n\n /**\n * Controls whether or not `update()` should be called when the element requests\n * an update. By default, this method always returns `true`, but this can be\n * customized to control when to update.\n *\n * @param _changedProperties Map of changed properties with old values\n * @category updates\n */\n protected shouldUpdate(_changedProperties: PropertyValues): boolean {\n return true;\n }\n\n /**\n * Updates the element. This method reflects property values to attributes.\n * It can be overridden to render and keep updated element DOM.\n * Setting properties inside this method will *not* trigger\n * another update.\n *\n * @param _changedProperties Map of changed properties with old values\n * @category updates\n */\n protected update(_changedProperties: PropertyValues) {\n // The forEach() expression will only run when __reflectingProperties is\n // defined, and it returns undefined, setting __reflectingProperties to\n // undefined\n this.__reflectingProperties &&= this.__reflectingProperties.forEach((p) =>\n this.__propertyToAttribute(p, this[p as keyof this])\n ) as undefined;\n this.__markUpdated();\n }\n\n /**\n * Invoked whenever the element is updated. Implement to perform\n * post-updating tasks via DOM APIs, for example, focusing an element.\n *\n * Setting properties inside this method will trigger the element to update\n * again after this update cycle completes.\n *\n * @param _changedProperties Map of changed properties with old values\n * @category updates\n */\n protected updated(_changedProperties: PropertyValues) {}\n\n /**\n * Invoked when the element is first updated. Implement to perform one time\n * work on the element after update.\n *\n * ```ts\n * firstUpdated() {\n * this.renderRoot.getElementById('my-text-area').focus();\n * }\n * ```\n *\n * Setting properties inside this method will trigger the element to update\n * again after this update cycle completes.\n *\n * @param _changedProperties Map of changed properties with old values\n * @category updates\n */\n protected firstUpdated(_changedProperties: PropertyValues) {}\n}\n// Assigned here to work around a jscompiler bug with static fields\n// when compiling to ES5.\n// https://github.com/google/closure-compiler/issues/3177\n(ReactiveElement as unknown as Record<string, unknown>)[\n JSCompiler_renameProperty('elementProperties', ReactiveElement)\n] = new Map();\n(ReactiveElement as unknown as Record<string, unknown>)[\n JSCompiler_renameProperty('finalized', ReactiveElement)\n] = new Map();\n\n// Apply polyfills if available\npolyfillSupport?.({ReactiveElement});\n\n// Dev mode warnings...\nif (DEV_MODE) {\n // Default warning set.\n ReactiveElement.enabledWarnings = [\n 'change-in-update',\n 'async-perform-update',\n ];\n const ensureOwnWarnings = function (ctor: typeof ReactiveElement) {\n if (\n !ctor.hasOwnProperty(JSCompiler_renameProperty('enabledWarnings', ctor))\n ) {\n ctor.enabledWarnings = ctor.enabledWarnings!.slice();\n }\n };\n ReactiveElement.enableWarning = function (\n this: typeof ReactiveElement,\n warning: WarningKind\n ) {\n ensureOwnWarnings(this);\n if (!this.enabledWarnings!.includes(warning)) {\n this.enabledWarnings!.push(warning);\n }\n };\n ReactiveElement.disableWarning = function (\n this: typeof ReactiveElement,\n warning: WarningKind\n ) {\n ensureOwnWarnings(this);\n const i = this.enabledWarnings!.indexOf(warning);\n if (i >= 0) {\n this.enabledWarnings!.splice(i, 1);\n }\n };\n}\n\n// IMPORTANT: do not change the property name or the assignment expression.\n// This line will be used in regexes to search for ReactiveElement usage.\n(global.reactiveElementVersions ??= []).push('2.1.2');\nif (DEV_MODE && global.reactiveElementVersions.length > 1) {\n queueMicrotask(() => {\n issueWarning!(\n 'multiple-versions',\n `Multiple versions of Lit loaded. Loading multiple versions ` +\n `is not recommended.`\n );\n });\n}\n", "/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\n\n// IMPORTANT: these imports must be type-only\nimport type {Directive, DirectiveResult, PartInfo} from './directive.js';\nimport type {TrustedHTML, TrustedTypesWindow} from 'trusted-types/lib/index.js';\n\nconst DEV_MODE = true;\nconst ENABLE_EXTRA_SECURITY_HOOKS = true;\nconst ENABLE_SHADYDOM_NOPATCH = true;\nconst NODE_MODE = false;\n\n// Allows minifiers to rename references to globalThis\nconst global = globalThis;\n\n/**\n * Contains types that are part of the unstable debug API.\n *\n * Everything in this API is not stable and may change or be removed in the future,\n * even on patch releases.\n */\n// eslint-disable-next-line @typescript-eslint/no-namespace\nexport namespace LitUnstable {\n /**\n * When Lit is running in dev mode and `window.emitLitDebugLogEvents` is true,\n * we will emit 'lit-debug' events to window, with live details about the update and render\n * lifecycle. These can be useful for writing debug tooling and visualizations.\n *\n * Please be aware that running with window.emitLitDebugLogEvents has performance overhead,\n * making certain operations that are normally very cheap (like a no-op render) much slower,\n * because we must copy data and dispatch events.\n */\n // eslint-disable-next-line @typescript-eslint/no-namespace\n export namespace DebugLog {\n export type Entry =\n | TemplatePrep\n | TemplateInstantiated\n | TemplateInstantiatedAndUpdated\n | TemplateUpdating\n | BeginRender\n | EndRender\n | CommitPartEntry\n | SetPartValue;\n export interface TemplatePrep {\n kind: 'template prep';\n template: Template;\n strings: TemplateStringsArray;\n clonableTemplate: HTMLTemplateElement;\n parts: TemplatePart[];\n }\n export interface BeginRender {\n kind: 'begin render';\n id: number;\n value: unknown;\n container: RenderRootNode;\n options: RenderOptions | undefined;\n part: ChildPart | undefined;\n }\n export interface EndRender {\n kind: 'end render';\n id: number;\n value: unknown;\n container: RenderRootNode;\n options: RenderOptions | undefined;\n part: ChildPart;\n }\n export interface TemplateInstantiated {\n kind: 'template instantiated';\n template: Template | CompiledTemplate;\n instance: TemplateInstance;\n options: RenderOptions | undefined;\n fragment: Node;\n parts: Array<Part | undefined>;\n values: unknown[];\n }\n export interface TemplateInstantiatedAndUpdated {\n kind: 'template instantiated and updated';\n template: Template | CompiledTemplate;\n instance: TemplateInstance;\n options: RenderOptions | undefined;\n fragment: Node;\n parts: Array<Part | undefined>;\n values: unknown[];\n }\n export interface TemplateUpdating {\n kind: 'template updating';\n template: Template | CompiledTemplate;\n instance: TemplateInstance;\n options: RenderOptions | undefined;\n parts: Array<Part | undefined>;\n values: unknown[];\n }\n export interface SetPartValue {\n kind: 'set part';\n part: Part;\n value: unknown;\n valueIndex: number;\n values: unknown[];\n templateInstance: TemplateInstance;\n }\n\n export type CommitPartEntry =\n | CommitNothingToChildEntry\n | CommitText\n | CommitNode\n | CommitAttribute\n | CommitProperty\n | CommitBooleanAttribute\n | CommitEventListener\n | CommitToElementBinding;\n\n export interface CommitNothingToChildEntry {\n kind: 'commit nothing to child';\n start: ChildNode;\n end: ChildNode | null;\n parent: Disconnectable | undefined;\n options: RenderOptions | undefined;\n }\n\n export interface CommitText {\n kind: 'commit text';\n node: Text;\n value: unknown;\n options: RenderOptions | undefined;\n }\n\n export interface CommitNode {\n kind: 'commit node';\n start: Node;\n parent: Disconnectable | undefined;\n value: Node;\n options: RenderOptions | undefined;\n }\n\n export interface CommitAttribute {\n kind: 'commit attribute';\n element: Element;\n name: string;\n value: unknown;\n options: RenderOptions | undefined;\n }\n\n export interface CommitProperty {\n kind: 'commit property';\n element: Element;\n name: string;\n value: unknown;\n options: RenderOptions | undefined;\n }\n\n export interface CommitBooleanAttribute {\n kind: 'commit boolean attribute';\n element: Element;\n name: string;\n value: boolean;\n options: RenderOptions | undefined;\n }\n\n export interface CommitEventListener {\n kind: 'commit event listener';\n element: Element;\n name: string;\n value: unknown;\n oldListener: unknown;\n options: RenderOptions | undefined;\n // True if we're removing the old event listener (e.g. because settings changed, or value is nothing)\n removeListener: boolean;\n // True if we're adding a new event listener (e.g. because first render, or settings changed)\n addListener: boolean;\n }\n\n export interface CommitToElementBinding {\n kind: 'commit to element binding';\n element: Element;\n value: unknown;\n options: RenderOptions | undefined;\n }\n }\n}\n\ninterface DebugLoggingWindow {\n // Even in dev mode, we generally don't want to emit these events, as that's\n // another level of cost, so only emit them when DEV_MODE is true _and_ when\n // window.emitLitDebugEvents is true.\n emitLitDebugLogEvents?: boolean;\n}\n\n/**\n * Useful for visualizing and logging insights into what the Lit template system is doing.\n *\n * Compiled out of prod mode builds.\n */\nconst debugLogEvent = DEV_MODE\n ? (event: LitUnstable.DebugLog.Entry) => {\n const shouldEmit = (global as unknown as DebugLoggingWindow)\n .emitLitDebugLogEvents;\n if (!shouldEmit) {\n return;\n }\n global.dispatchEvent(\n new CustomEvent<LitUnstable.DebugLog.Entry>('lit-debug', {\n detail: event,\n })\n );\n }\n : undefined;\n// Used for connecting beginRender and endRender events when there are nested\n// renders when errors are thrown preventing an endRender event from being\n// called.\nlet debugLogRenderId = 0;\n\nlet issueWarning: (code: string, warning: string) => void;\n\nif (DEV_MODE) {\n global.litIssuedWarnings ??= new Set();\n\n /**\n * Issue a warning if we haven't already, based either on `code` or `warning`.\n * Warnings are disabled automatically only by `warning`; disabling via `code`\n * can be done by users.\n */\n issueWarning = (code: string, warning: string) => {\n warning += code\n ? ` See https://lit.dev/msg/${code} for more information.`\n : '';\n if (\n !global.litIssuedWarnings!.has(warning) &&\n !global.litIssuedWarnings!.has(code)\n ) {\n console.warn(warning);\n global.litIssuedWarnings!.add(warning);\n }\n };\n\n queueMicrotask(() => {\n issueWarning(\n 'dev-mode',\n `Lit is in dev mode. Not recommended for production!`\n );\n });\n}\n\nconst wrap =\n ENABLE_SHADYDOM_NOPATCH &&\n global.ShadyDOM?.inUse &&\n global.ShadyDOM?.noPatch === true\n ? (global.ShadyDOM!.wrap as <T extends Node>(node: T) => T)\n : <T extends Node>(node: T) => node;\n\nconst trustedTypes = (global as unknown as TrustedTypesWindow).trustedTypes;\n\n/**\n * Our TrustedTypePolicy for HTML which is declared using the html template\n * tag function.\n *\n * That HTML is a developer-authored constant, and is parsed with innerHTML\n * before any untrusted expressions have been mixed in. Therefor it is\n * considered safe by construction.\n */\nconst policy = trustedTypes\n ? trustedTypes.createPolicy('lit-html', {\n createHTML: (s) => s,\n })\n : undefined;\n\n/**\n * Used to sanitize any value before it is written into the DOM. This can be\n * used to implement a security policy of allowed and disallowed values in\n * order to prevent XSS attacks.\n *\n * One way of using this callback would be to check attributes and properties\n * against a list of high risk fields, and require that values written to such\n * fields be instances of a class which is safe by construction. Closure's Safe\n * HTML Types is one implementation of this technique (\n * https://github.com/google/safe-html-types/blob/master/doc/safehtml-types.md).\n * The TrustedTypes polyfill in API-only mode could also be used as a basis\n * for this technique (https://github.com/WICG/trusted-types).\n *\n * @param node The HTML node (usually either a #text node or an Element) that\n * is being written to. Note that this is just an exemplar node, the write\n * may take place against another instance of the same class of node.\n * @param name The name of an attribute or property (for example, 'href').\n * @param type Indicates whether the write that's about to be performed will\n * be to a property or a node.\n * @return A function that will sanitize this class of writes.\n */\nexport type SanitizerFactory = (\n node: Node,\n name: string,\n type: 'property' | 'attribute'\n) => ValueSanitizer;\n\n/**\n * A function which can sanitize values that will be written to a specific kind\n * of DOM sink.\n *\n * See SanitizerFactory.\n *\n * @param value The value to sanitize. Will be the actual value passed into\n * the lit-html template literal, so this could be of any type.\n * @return The value to write to the DOM. Usually the same as the input value,\n * unless sanitization is needed.\n */\nexport type ValueSanitizer = (value: unknown) => unknown;\n\nconst identityFunction: ValueSanitizer = (value: unknown) => value;\nconst noopSanitizer: SanitizerFactory = (\n _node: Node,\n _name: string,\n _type: 'property' | 'attribute'\n) => identityFunction;\n\n/** Sets the global sanitizer factory. */\nconst setSanitizer = (newSanitizer: SanitizerFactory) => {\n if (!ENABLE_EXTRA_SECURITY_HOOKS) {\n return;\n }\n if (sanitizerFactoryInternal !== noopSanitizer) {\n throw new Error(\n `Attempted to overwrite existing lit-html security policy.` +\n ` setSanitizeDOMValueFactory should be called at most once.`\n );\n }\n sanitizerFactoryInternal = newSanitizer;\n};\n\n/**\n * Only used in internal tests, not a part of the public API.\n */\nconst _testOnlyClearSanitizerFactoryDoNotCallOrElse = () => {\n sanitizerFactoryInternal = noopSanitizer;\n};\n\nconst createSanitizer: SanitizerFactory = (node, name, type) => {\n return sanitizerFactoryInternal(node, name, type);\n};\n\n// Added to an attribute name to mark the attribute as bound so we can find\n// it easily.\nconst boundAttributeSuffix = '$lit$';\n\n// This marker is used in many syntactic positions in HTML, so it must be\n// a valid element name and attribute name. We don't support dynamic names (yet)\n// but this at least ensures that the parse tree is closer to the template\n// intention.\nconst marker = `lit$${Math.random().toFixed(9).slice(2)}$`;\n\n// String used to tell if a comment is a marker comment\nconst markerMatch = '?' + marker;\n\n// Text used to insert a comment marker node. We use processing instruction\n// syntax because it's slightly smaller, but parses as a comment node.\nconst nodeMarker = `<${markerMatch}>`;\n\nconst d =\n NODE_MODE && global.document === undefined\n ? ({\n createTreeWalker() {\n return {};\n },\n } as unknown as Document)\n : document;\n\n// Creates a dynamic marker. We never have to search for these in the DOM.\nconst createMarker = () => d.createComment('');\n\n// https://tc39.github.io/ecma262/#sec-typeof-operator\ntype Primitive = null | undefined | boolean | number | string | symbol | bigint;\nconst isPrimitive = (value: unknown): value is Primitive =>\n value === null || (typeof value != 'object' && typeof value != 'function');\nconst isArray = Array.isArray;\nconst isIterable = (value: unknown): value is Iterable<unknown> =>\n isArray(value) ||\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n typeof (value as any)?.[Symbol.iterator] === 'function';\n\nconst SPACE_CHAR = `[ \\t\\n\\f\\r]`;\nconst ATTR_VALUE_CHAR = `[^ \\t\\n\\f\\r\"'\\`<>=]`;\nconst NAME_CHAR = `[^\\\\s\"'>=/]`;\n\n// These regexes represent the five parsing states that we care about in the\n// Template's HTML scanner. They match the *end* of the state they're named\n// after.\n// Depending on the match, we transition to a new state. If there's no match,\n// we stay in the same state.\n// Note that the regexes are stateful. We utilize lastIndex and sync it\n// across the multiple regexes used. In addition to the five regexes below\n// we also dynamically create a regex to find the matching end tags for raw\n// text elements.\n\n/**\n * End of text is: `<` followed by:\n * (comment start) or (tag) or (dynamic tag binding)\n */\nconst textEndRegex = /<(?:(!--|\\/[^a-zA-Z])|(\\/?[a-zA-Z][^>\\s]*)|(\\/?$))/g;\nconst COMMENT_START = 1;\nconst TAG_NAME = 2;\nconst DYNAMIC_TAG_NAME = 3;\n\nconst commentEndRegex = /-->/g;\n/**\n * Comments not started with <!--, like </{, can be ended by a single `>`\n */\nconst comment2EndRegex = />/g;\n\n/**\n * The tagEnd regex matches the end of the \"inside an opening\" tag syntax\n * position. It either matches a `>`, an attribute-like sequence, or the end\n * of the string after a space (attribute-name position ending).\n *\n * See attributes in the HTML spec:\n * https://www.w3.org/TR/html5/syntax.html#elements-attributes\n *\n * \" \\t\\n\\f\\r\" are HTML space characters:\n * https://infra.spec.whatwg.org/#ascii-whitespace\n *\n * So an attribute is:\n * * The name: any character except a whitespace character, (\"), ('), \">\",\n * \"=\", or \"/\". Note: this is different from the HTML spec which also excludes control characters.\n * * Followed by zero or more space characters\n * * Followed by \"=\"\n * * Followed by zero or more space characters\n * * Followed by:\n * * Any character except space, ('), (\"), \"<\", \">\", \"=\", (`), or\n * * (\") then any non-(\"), or\n * * (') then any non-(')\n */\nconst tagEndRegex = new RegExp(\n `>|${SPACE_CHAR}(?:(${NAME_CHAR}+)(${SPACE_CHAR}*=${SPACE_CHAR}*(?:${ATTR_VALUE_CHAR}|(\"|')|))|$)`,\n 'g'\n);\nconst ENTIRE_MATCH = 0;\nconst ATTRIBUTE_NAME = 1;\nconst SPACES_AND_EQUALS = 2;\nconst QUOTE_CHAR = 3;\n\nconst singleQuoteAttrEndRegex = /'/g;\nconst doubleQuoteAttrEndRegex = /\"/g;\n/**\n * Matches the raw text elements.\n *\n * Comments are not parsed within raw text elements, so we need to search their\n * text content for marker strings.\n */\nconst rawTextElement = /^(?:script|style|textarea|title)$/i;\n\n/** TemplateResult types */\nconst HTML_RESULT = 1;\nconst SVG_RESULT = 2;\nconst MATHML_RESULT = 3;\n\ntype ResultType = typeof HTML_RESULT | typeof SVG_RESULT | typeof MATHML_RESULT;\n\n// TemplatePart types\n// IMPORTANT: these must match the values in PartType\nconst ATTRIBUTE_PART = 1;\nconst CHILD_PART = 2;\nconst PROPERTY_PART = 3;\nconst BOOLEAN_ATTRIBUTE_PART = 4;\nconst EVENT_PART = 5;\nconst ELEMENT_PART = 6;\nconst COMMENT_PART = 7;\n\n/**\n * The return type of the template tag functions, {@linkcode html} and\n * {@linkcode svg} when it hasn't been compiled by @lit-labs/compiler.\n *\n * A `TemplateResult` object holds all the information about a template\n * expression required to render it: the template strings, expression values,\n * and type of template (html or svg).\n *\n * `TemplateResult` objects do not create any DOM on their own. To create or\n * update DOM you need to render the `TemplateResult`. See\n * [Rendering](https://lit.dev/docs/components/rendering) for more information.\n *\n */\nexport type UncompiledTemplateResult<T extends ResultType = ResultType> = {\n // This property needs to remain unminified.\n ['_$litType$']: T;\n strings: TemplateStringsArray;\n values: unknown[];\n};\n\n/**\n * This is a template result that may be either uncompiled or compiled.\n *\n * In the future, TemplateResult will be this type. If you want to explicitly\n * note that a template result is potentially compiled, you can reference this\n * type and it will continue to behave the same through the next major version\n * of Lit. This can be useful for code that wants to prepare for the next\n * major version of Lit.\n */\nexport type MaybeCompiledTemplateResult<T extends ResultType = ResultType> =\n | UncompiledTemplateResult<T>\n | CompiledTemplateResult;\n\n/**\n * The return type of the template tag functions, {@linkcode html} and\n * {@linkcode svg}.\n *\n * A `TemplateResult` object holds all the information about a template\n * expression required to render it: the template strings, expression values,\n * and type of template (html or svg).\n *\n * `TemplateResult` objects do not create any DOM on their own. To create or\n * update DOM you need to render the `TemplateResult`. See\n * [Rendering](https://lit.dev/docs/components/rendering) for more information.\n *\n * In Lit 4, this type will be an alias of\n * MaybeCompiledTemplateResult, so that code will get type errors if it assumes\n * that Lit templates are not compiled. When deliberately working with only\n * one, use either {@linkcode CompiledTemplateResult} or\n * {@linkcode UncompiledTemplateResult} explicitly.\n */\nexport type TemplateResult<T extends ResultType = ResultType> =\n UncompiledTemplateResult<T>;\n\nexport type HTMLTemplateResult = TemplateResult<typeof HTML_RESULT>;\n\nexport type SVGTemplateResult = TemplateResult<typeof SVG_RESULT>;\n\nexport type MathMLTemplateResult = TemplateResult<typeof MATHML_RESULT>;\n\n/**\n * A TemplateResult that has been compiled by @lit-labs/compiler, skipping the\n * prepare step.\n */\nexport interface CompiledTemplateResult {\n // This is a factory in order to make template initialization lazy\n // and allow ShadyRenderOptions scope to be passed in.\n // This property needs to remain unminified.\n ['_$litType$']: CompiledTemplate;\n values: unknown[];\n}\n\nexport interface CompiledTemplate extends Omit<Template, 'el'> {\n // el is overridden to be optional. We initialize it on first render\n el?: HTMLTemplateElement;\n\n // The prepared HTML string to create a template element from.\n // The type is a TemplateStringsArray to guarantee that the value came from\n // source code, preventing a JSON injection attack.\n h: TemplateStringsArray;\n}\n\n/**\n * Generates a template literal tag function that returns a TemplateResult with\n * the given result type.\n */\nconst tag =\n <T extends ResultType>(type: T) =>\n (strings: TemplateStringsArray, ...values: unknown[]): TemplateResult<T> => {\n // Warn against templates octal escape sequences\n // We do this here rather than in render so that the warning is closer to the\n // template definition.\n if (DEV_MODE && strings.some((s) => s === undefined)) {\n console.warn(\n 'Some template strings are undefined.\\n' +\n 'This is probably caused by illegal octal escape sequences.'\n );\n }\n if (DEV_MODE) {\n // Import static-html.js results in a circular dependency which g3 doesn't\n // handle. Instead we know that static values must have the field\n // `_$litStatic$`.\n if (\n values.some((val) => (val as {_$litStatic$: unknown})?.['_$litStatic$'])\n ) {\n issueWarning(\n '',\n `Static values 'literal' or 'unsafeStatic' cannot be used as values to non-static templates.\\n` +\n `Please use the static 'html' tag function. See https://lit.dev/docs/templates/expressions/#static-expressions`\n );\n }\n }\n return {\n // This property needs to remain unminified.\n ['_$litType$']: type,\n strings,\n values,\n };\n };\n\n/**\n * Interprets a template literal as an HTML template that can efficiently\n * render to and update a container.\n *\n * ```ts\n * const header = (title: string) => html`<h1>${title}</h1>`;\n * ```\n *\n * The `html` tag returns a description of the DOM to render as a value. It is\n * lazy, meaning no work is done until the template is rendered. When rendering,\n * if a template comes from the same expression as a previously rendered result,\n * it's efficiently updated instead of replaced.\n */\nexport const html = tag(HTML_RESULT);\n\n/**\n * Interprets a template literal as an SVG fragment that can efficiently render\n * to and update a container.\n *\n * ```ts\n * const rect = svg`<rect width=\"10\" height=\"10\"></rect>`;\n *\n * const myImage = html`\n * <svg viewBox=\"0 0 10 10\" xmlns=\"http://www.w3.org/2000/svg\">\n * ${rect}\n * </svg>`;\n * ```\n *\n * The `svg` *tag function* should only be used for SVG fragments, or elements\n * that would be contained **inside** an `<svg>` HTML element. A common error is\n * placing an `<svg>` *element* in a template tagged with the `svg` tag\n * function. The `<svg>` element is an HTML element and should be used within a\n * template tagged with the {@linkcode html} tag function.\n *\n * In LitElement usage, it's invalid to return an SVG fragment from the\n * `render()` method, as the SVG fragment will be contained within the element's\n * shadow root and thus not be properly contained within an `<svg>` HTML\n * element.\n */\nexport const svg = tag(SVG_RESULT);\n\n/**\n * Interprets a template literal as MathML fragment that can efficiently render\n * to and update a container.\n *\n * ```ts\n * const num = mathml`<mn>1</mn>`;\n *\n * const eq = html`\n * <math>\n * ${num}\n * </math>`;\n * ```\n *\n * The `mathml` *tag function* should only be used for MathML fragments, or\n * elements that would be contained **inside** a `<math>` HTML element. A common\n * error is placing a `<math>` *element* in a template tagged with the `mathml`\n * tag function. The `<math>` element is an HTML element and should be used\n * within a template tagged with the {@linkcode html} tag function.\n *\n * In LitElement usage, it's invalid to return an MathML fragment from the\n * `render()` method, as the MathML fragment will be contained within the\n * element's shadow root and thus not be properly contained within a `<math>`\n * HTML element.\n */\nexport const mathml = tag(MATHML_RESULT);\n\n/**\n * A sentinel value that signals that a value was handled by a directive and\n * should not be written to the DOM.\n */\nexport const noChange = Symbol.for('lit-noChange');\n\n/**\n * A sentinel value that signals a ChildPart to fully clear its content.\n *\n * ```ts\n * const button = html`${\n * user.isAdmin\n * ? html`<button>DELETE</button>`\n * : nothing\n * }`;\n * ```\n *\n * Prefer using `nothing` over other falsy values as it provides a consistent\n * behavior between various expression binding contexts.\n *\n * In child expressions, `undefined`, `null`, `''`, and `nothing` all behave the\n * same and render no nodes. In attribute expressions, `nothing` _removes_ the\n * attribute, while `undefined` and `null` will render an empty string. In\n * property expressions `nothing` becomes `undefined`.\n */\nexport const nothing = Symbol.for('lit-nothing');\n\n/**\n * The cache of prepared templates, keyed by the tagged TemplateStringsArray\n * and _not_ accounting for the specific template tag used. This means that\n * template tags cannot be dynamic - they must statically be one of html, svg,\n * or attr. This restriction simplifies the cache lookup, which is on the hot\n * path for rendering.\n */\nconst templateCache = new WeakMap<TemplateStringsArray, Template>();\n\n/**\n * Object specifying options for controlling lit-html rendering. Note that\n * while `render` may be called multiple times on the same `container` (and\n * `renderBefore` reference node) to efficiently update the rendered content,\n * only the options passed in during the first render are respected during\n * the lifetime of renders to that unique `container` + `renderBefore`\n * combination.\n */\nexport interface RenderOptions {\n /**\n * An object to use as the `this` value for event listeners. It's often\n * useful to set this to the host component rendering a template.\n */\n host?: object;\n /**\n * A DOM node before which to render content in the container.\n */\n renderBefore?: ChildNode | null;\n /**\n * Node used for cloning the template (`importNode` will be called on this\n * node). This controls the `ownerDocument` of the rendered DOM, along with\n * any inherited context. Defaults to the global `document`.\n */\n creationScope?: {importNode(node: Node, deep?: boolean): Node};\n /**\n * The initial connected state for the top-level part being rendered. If no\n * `isConnected` option is set, `AsyncDirective`s will be connected by\n * default. Set to `false` if the initial render occurs in a disconnected tree\n * and `AsyncDirective`s should see `isConnected === false` for their initial\n * render. The `part.setConnected()` method must be used subsequent to initial\n * render to change the connected state of the part.\n */\n isConnected?: boolean;\n}\n\n/**\n * The root DOM node for rendering.\n */\nexport type RenderRootNode = HTMLElement | SVGElement | DocumentFragment;\n\nconst walker = d.createTreeWalker(\n d,\n 129 /* NodeFilter.SHOW_{ELEMENT|COMMENT} */\n);\n\nlet sanitizerFactoryInternal: SanitizerFactory = noopSanitizer;\n\n//\n// Classes only below here, const variable declarations only above here...\n//\n// Keeping variable declarations and classes together improves minification.\n// Interfaces and type aliases can be interleaved freely.\n//\n\n// Type for classes that have a `_directive` or `_directives[]` field, used by\n// `resolveDirective`\nexport interface DirectiveParent {\n _$parent?: DirectiveParent;\n _$isConnected: boolean;\n __directive?: Directive;\n __directives?: Array<Directive | undefined>;\n}\n\nfunction trustFromTemplateString(\n tsa: TemplateStringsArray,\n stringFromTSA: string\n): TrustedHTML {\n // A security check to prevent spoofing of Lit template results.\n // In the future, we may be able to replace this with Array.isTemplateObject,\n // though we might need to make that check inside of the html and svg\n // functions, because precompiled templates don't come in as\n // TemplateStringArray objects.\n if (!isArray(tsa) || !tsa.hasOwnProperty('raw')) {\n let message = 'invalid template strings array';\n if (DEV_MODE) {\n message = `\n Internal Error: expected template strings to be an array\n with a 'raw' field. Faking a template strings array by\n calling html or svg like an ordinary function is effectively\n the same as calling unsafeHtml and can lead to major security\n issues, e.g. opening your code up to XSS attacks.\n If you're using the html or svg tagged template functions normally\n and still seeing this error, please file a bug at\n https://github.com/lit/lit/issues/new?template=bug_report.md\n and include information about your build tooling, if any.\n `\n .trim()\n .replace(/\\n */g, '\\n');\n }\n throw new Error(message);\n }\n return policy !== undefined\n ? policy.createHTML(stringFromTSA)\n : (stringFromTSA as unknown as TrustedHTML);\n}\n\n/**\n * Returns an HTML string for the given TemplateStringsArray and result type\n * (HTML or SVG), along with the case-sensitive bound attribute names in\n * template order. The HTML contains comment markers denoting the `ChildPart`s\n * and suffixes on bound attributes denoting the `AttributeParts`.\n *\n * @param strings template strings array\n * @param type HTML or SVG\n * @return Array containing `[html, attrNames]` (array returned for terseness,\n * to avoid object fields since this code is shared with non-minified SSR\n * code)\n */\nconst getTemplateHtml = (\n strings: TemplateStringsArray,\n type: ResultType\n): [TrustedHTML, Array<string>] => {\n // Insert makers into the template HTML to represent the position of\n // bindings. The following code scans the template strings to determine the\n // syntactic position of the bindings. They can be in text position, where\n // we insert an HTML comment, attribute value position, where we insert a\n // sentinel string and re-write the attribute name, or inside a tag where\n // we insert the sentinel string.\n const l = strings.length - 1;\n // Stores the case-sensitive bound attribute names in the order of their\n // parts. ElementParts are also reflected in this array as undefined\n // rather than a string, to disambiguate from attribute bindings.\n const attrNames: Array<string> = [];\n let html =\n type === SVG_RESULT ? '<svg>' : type === MATHML_RESULT ? '<math>' : '';\n\n // When we're inside a raw text tag (not it's text content), the regex\n // will still be tagRegex so we can find attributes, but will switch to\n // this regex when the tag ends.\n let rawTextEndRegex: RegExp | undefined;\n\n // The current parsing state, represented as a reference to one of the\n // regexes\n let regex = textEndRegex;\n\n for (let i = 0; i < l; i++) {\n const s = strings[i];\n // The index of the end of the last attribute name. When this is\n // positive at end of a string, it means we're in an attribute value\n // position and need to rewrite the attribute name.\n // We also use a special value of -2 to indicate that we encountered\n // the end of a string in attribute name position.\n let attrNameEndIndex = -1;\n let attrName: string | undefined;\n let lastIndex = 0;\n let match!: RegExpExecArray | null;\n\n // The conditions in this loop handle the current parse state, and the\n // assignments to the `regex` variable are the state transitions.\n while (lastIndex < s.length) {\n // Make sure we start searching from where we previously left off\n regex.lastIndex = lastIndex;\n match = regex.exec(s);\n if (match === null) {\n break;\n }\n lastIndex = regex.lastIndex;\n if (regex === textEndRegex) {\n if (match[COMMENT_START] === '!--') {\n regex = commentEndRegex;\n } else if (match[COMMENT_START] !== undefined) {\n // We started a weird comment, like </{\n regex = comment2EndRegex;\n } else if (match[TAG_NAME] !== undefined) {\n if (rawTextElement.test(match[TAG_NAME])) {\n // Record if we encounter a raw-text element. We'll switch to\n // this regex at the end of the tag.\n rawTextEndRegex = new RegExp(`</${match[TAG_NAME]}`, 'g');\n }\n regex = tagEndRegex;\n } else if (match[DYNAMIC_TAG_NAME] !== undefined) {\n if (DEV_MODE) {\n throw new Error(\n 'Bindings in tag names are not supported. Please use static templates instead. ' +\n 'See https://lit.dev/docs/templates/expressions/#static-expressions'\n );\n }\n regex = tagEndRegex;\n }\n } else if (regex === tagEndRegex) {\n if (match[ENTIRE_MATCH] === '>') {\n // End of a tag. If we had started a raw-text element, use that\n // regex\n regex = rawTextEndRegex ?? textEndRegex;\n // We may be ending an unquoted attribute value, so make sure we\n // clear any pending attrNameEndIndex\n attrNameEndIndex = -1;\n } else if (match[ATTRIBUTE_NAME] === undefined) {\n // Attribute name position\n attrNameEndIndex = -2;\n } else {\n attrNameEndIndex = regex.lastIndex - match[SPACES_AND_EQUALS].length;\n attrName = match[ATTRIBUTE_NAME];\n regex =\n match[QUOTE_CHAR] === undefined\n ? tagEndRegex\n : match[QUOTE_CHAR] === '\"'\n ? doubleQuoteAttrEndRegex\n : singleQuoteAttrEndRegex;\n }\n } else if (\n regex === doubleQuoteAttrEndRegex ||\n regex === singleQuoteAttrEndRegex\n ) {\n regex = tagEndRegex;\n } else if (regex === commentEndRegex || regex === comment2EndRegex) {\n regex = textEndRegex;\n } else {\n // Not one of the five state regexes, so it must be the dynamically\n // created raw text regex and we're at the close of that element.\n regex = tagEndRegex;\n rawTextEndRegex = undefined;\n }\n }\n\n if (DEV_MODE) {\n // If we have a attrNameEndIndex, which indicates that we should\n // rewrite the attribute name, assert that we're in a valid attribute\n // position - either in a tag, or a quoted attribute value.\n console.assert(\n attrNameEndIndex === -1 ||\n regex === tagEndRegex ||\n regex === singleQuoteAttrEndRegex ||\n regex === doubleQuoteAttrEndRegex,\n 'unexpected parse state B'\n );\n }\n\n // We have four cases:\n // 1. We're in text position, and not in a raw text element\n // (regex === textEndRegex): insert a comment marker.\n // 2. We have a non-negative attrNameEndIndex which means we need to\n // rewrite the attribute name to add a bound attribute suffix.\n // 3. We're at the non-first binding in a multi-binding attribute, use a\n // plain marker.\n // 4. We're somewhere else inside the tag. If we're in attribute name\n // position (attrNameEndIndex === -2), add a sequential suffix to\n // generate a unique attribute name.\n\n // Detect a binding next to self-closing tag end and insert a space to\n // separate the marker from the tag end:\n const end =\n regex === tagEndRegex && strings[i + 1].startsWith('/>') ? ' ' : '';\n html +=\n regex === textEndRegex\n ? s + nodeMarker\n : attrNameEndIndex >= 0\n ? (attrNames.push(attrName!),\n s.slice(0, attrNameEndIndex) +\n boundAttributeSuffix +\n s.slice(attrNameEndIndex)) +\n marker +\n end\n : s + marker + (attrNameEndIndex === -2 ? i : end);\n }\n\n const htmlResult: string | TrustedHTML =\n html +\n (strings[l] || '<?>') +\n (type === SVG_RESULT ? '</svg>' : type === MATHML_RESULT ? '</math>' : '');\n\n // Returned as an array for terseness\n return [trustFromTemplateString(strings, htmlResult), attrNames];\n};\n\n/** @internal */\nexport type {Template};\nclass Template {\n /** @internal */\n el!: HTMLTemplateElement;\n\n parts: Array<TemplatePart> = [];\n\n constructor(\n // This property needs to remain unminified.\n {strings, ['_$litType$']: type}: UncompiledTemplateResult,\n options?: RenderOptions\n ) {\n let node: Node | null;\n let nodeIndex = 0;\n let attrNameIndex = 0;\n const partCount = strings.length - 1;\n const parts = this.parts;\n\n // Create template element\n const [html, attrNames] = getTemplateHtml(strings, type);\n this.el = Template.createElement(html, options);\n walker.currentNode = this.el.content;\n\n // Re-parent SVG or MathML nodes into template root\n if (type === SVG_RESULT || type === MATHML_RESULT) {\n const wrapper = this.el.content.firstChild!;\n wrapper.replaceWith(...wrapper.childNodes);\n }\n\n // Walk the template to find binding markers and create TemplateParts\n while ((node = walker.nextNode()) !== null && parts.length < partCount) {\n if (node.nodeType === 1) {\n if (DEV_MODE) {\n const tag = (node as Element).localName;\n // Warn if `textarea` includes an expression and throw if `template`\n // does since these are not supported. We do this by checking\n // innerHTML for anything that looks like a marker. This catches\n // cases like bindings in textarea there markers turn into text nodes.\n if (\n /^(?:textarea|template)$/i!.test(tag) &&\n (node as Element).innerHTML.includes(marker)\n ) {\n const m =\n `Expressions are not supported inside \\`${tag}\\` ` +\n `elements. See https://lit.dev/msg/expression-in-${tag} for more ` +\n `information.`;\n if (tag === 'template') {\n throw new Error(m);\n } else issueWarning('', m);\n }\n }\n // TODO (justinfagnani): for attempted dynamic tag names, we don't\n // increment the bindingIndex, and it'll be off by 1 in the element\n // and off by two after it.\n if ((node as Element).hasAttributes()) {\n for (const name of (node as Element).getAttributeNames()) {\n if (name.endsWith(boundAttributeSuffix)) {\n const realName = attrNames[attrNameIndex++];\n const value = (node as Element).getAttribute(name)!;\n const statics = value.split(marker);\n const m = /([.?@])?(.*)/.exec(realName)!;\n parts.push({\n type: ATTRIBUTE_PART,\n index: nodeIndex,\n name: m[2],\n strings: statics,\n ctor:\n m[1] === '.'\n ? PropertyPart\n : m[1] === '?'\n ? BooleanAttributePart\n : m[1] === '@'\n ? EventPart\n : AttributePart,\n });\n (node as Element).removeAttribute(name);\n } else if (name.startsWith(marker)) {\n parts.push({\n type: ELEMENT_PART,\n index: nodeIndex,\n });\n (node as Element).removeAttribute(name);\n }\n }\n }\n // TODO (justinfagnani): benchmark the regex against testing for each\n // of the 3 raw text element names.\n if (rawTextElement.test((node as Element).tagName)) {\n // For raw text elements we need to split the text content on\n // markers, create a Text node for each segment, and create\n // a TemplatePart for each marker.\n const strings = (node as Element).textContent!.split(marker);\n const lastIndex = strings.length - 1;\n if (lastIndex > 0) {\n (node as Element).textContent = trustedTypes\n ? (trustedTypes.emptyScript as unknown as '')\n : '';\n // Generate a new text node for each literal section\n // These nodes are also used as the markers for child parts\n for (let i = 0; i < lastIndex; i++) {\n (node as Element).append(strings[i], createMarker());\n // Walk past the marker node we just added\n walker.nextNode();\n parts.push({type: CHILD_PART, index: ++nodeIndex});\n }\n // Note because this marker is added after the walker's current\n // node, it will be walked to in the outer loop (and ignored), so\n // we don't need to adjust nodeIndex here\n (node as Element).append(strings[lastIndex], createMarker());\n }\n }\n } else if (node.nodeType === 8) {\n const data = (node as Comment).data;\n if (data === markerMatch) {\n parts.push({type: CHILD_PART, index: nodeIndex});\n } else {\n let i = -1;\n while ((i = (node as Comment).data.indexOf(marker, i + 1)) !== -1) {\n // Comment node has a binding marker inside, make an inactive part\n // The binding won't work, but subsequent bindings will\n parts.push({type: COMMENT_PART, index: nodeIndex});\n // Move to the end of the match\n i += marker.length - 1;\n }\n }\n }\n nodeIndex++;\n }\n\n if (DEV_MODE) {\n // If there was a duplicate attribute on a tag, then when the tag is\n // parsed into an element the attribute gets de-duplicated. We can detect\n // this mismatch if we haven't precisely consumed every attribute name\n // when preparing the template. This works because `attrNames` is built\n // from the template string and `attrNameIndex` comes from processing the\n // resulting DOM.\n if (attrNames.length !== attrNameIndex) {\n throw new Error(\n `Detected duplicate attribute bindings. This occurs if your template ` +\n `has duplicate attributes on an element tag. For example ` +\n `\"<input ?disabled=\\${true} ?disabled=\\${false}>\" contains a ` +\n `duplicate \"disabled\" attribute. The error was detected in ` +\n `the following template: \\n` +\n '`' +\n strings.join('${...}') +\n '`'\n );\n }\n }\n\n // We could set walker.currentNode to another node here to prevent a memory\n // leak, but every time we prepare a template, we immediately render it\n // and re-use the walker in new TemplateInstance._clone().\n debugLogEvent &&\n debugLogEvent({\n kind: 'template prep',\n template: this,\n clonableTemplate: this.el,\n parts: this.parts,\n strings,\n });\n }\n\n // Overridden via `litHtmlPolyfillSupport` to provide platform support.\n /** @nocollapse */\n static createElement(html: TrustedHTML, _options?: RenderOptions) {\n const el = d.createElement('template');\n el.innerHTML = html as unknown as string;\n return el;\n }\n}\n\nexport interface Disconnectable {\n _$parent?: Disconnectable;\n _$disconnectableChildren?: Set<Disconnectable>;\n // Rather than hold connection state on instances, Disconnectables recursively\n // fetch the connection state from the RootPart they are connected in via\n // getters up the Disconnectable tree via _$parent references. This pushes the\n // cost of tracking the isConnected state to `AsyncDirectives`, and avoids\n // needing to pass all Disconnectables (parts, template instances, and\n // directives) their connection state each time it changes, which would be\n // costly for trees that have no AsyncDirectives.\n _$isConnected: boolean;\n}\n\nfunction resolveDirective(\n part: ChildPart | AttributePart | ElementPart,\n value: unknown,\n parent: DirectiveParent = part,\n attributeIndex?: number\n): unknown {\n // Bail early if the value is explicitly noChange. Note, this means any\n // nested directive is still attached and is not run.\n if (value === noChange) {\n return value;\n }\n let currentDirective =\n attributeIndex !== undefined\n ? (parent as AttributePart).__directives?.[attributeIndex]\n : (parent as ChildPart | ElementPart | Directive).__directive;\n const nextDirectiveConstructor = isPrimitive(value)\n ? undefined\n : // This property needs to remain unminified.\n (value as DirectiveResult)['_$litDirective$'];\n if (currentDirective?.constructor !== nextDirectiveConstructor) {\n // This property needs to remain unminified.\n currentDirective?.['_$notifyDirectiveConnectionChanged']?.(false);\n if (nextDirectiveConstructor === undefined) {\n currentDirective = undefined;\n } else {\n currentDirective = new nextDirectiveConstructor(part as PartInfo);\n currentDirective._$initialize(part, parent, attributeIndex);\n }\n if (attributeIndex !== undefined) {\n ((parent as AttributePart).__directives ??= [])[attributeIndex] =\n currentDirective;\n } else {\n (parent as ChildPart | Directive).__directive = currentDirective;\n }\n }\n if (currentDirective !== undefined) {\n value = resolveDirective(\n part,\n currentDirective._$resolve(part, (value as DirectiveResult).values),\n currentDirective,\n attributeIndex\n );\n }\n return value;\n}\n\nexport type {TemplateInstance};\n/**\n * An updateable instance of a Template. Holds references to the Parts used to\n * update the template instance.\n */\nclass TemplateInstance implements Disconnectable {\n _$template: Template;\n _$parts: Array<Part | undefined> = [];\n\n /** @internal */\n _$parent: ChildPart;\n /** @internal */\n _$disconnectableChildren?: Set<Disconnectable> = undefined;\n\n constructor(template: Template, parent: ChildPart) {\n this._$template = template;\n this._$parent = parent;\n }\n\n // Called by ChildPart parentNode getter\n get parentNode() {\n return this._$parent.parentNode;\n }\n\n // See comment in Disconnectable interface for why this is a getter\n get _$isConnected() {\n return this._$parent._$isConnected;\n }\n\n // This method is separate from the constructor because we need to return a\n // DocumentFragment and we don't want to hold onto it with an instance field.\n _clone(options: RenderOptions | undefined) {\n const {\n el: {content},\n parts: parts,\n } = this._$template;\n const fragment = (options?.creationScope ?? d).importNode(content, true);\n walker.currentNode = fragment;\n\n let node = walker.nextNode()!;\n let nodeIndex = 0;\n let partIndex = 0;\n let templatePart = parts[0];\n\n while (templatePart !== undefined) {\n if (nodeIndex === templatePart.index) {\n let part: Part | undefined;\n if (templatePart.type === CHILD_PART) {\n part = new ChildPart(\n node as HTMLElement,\n node.nextSibling,\n this,\n options\n );\n } else if (templatePart.type === ATTRIBUTE_PART) {\n part = new templatePart.ctor(\n node as HTMLElement,\n templatePart.name,\n templatePart.strings,\n this,\n options\n );\n } else if (templatePart.type === ELEMENT_PART) {\n part = new ElementPart(node as HTMLElement, this, options);\n }\n this._$parts.push(part);\n templatePart = parts[++partIndex];\n }\n if (nodeIndex !== templatePart?.index) {\n node = walker.nextNode()!;\n nodeIndex++;\n }\n }\n // We need to set the currentNode away from the cloned tree so that we\n // don't hold onto the tree even if the tree is detached and should be\n // freed.\n walker.currentNode = d;\n return fragment;\n }\n\n _update(values: Array<unknown>) {\n let i = 0;\n for (const part of this._$parts) {\n if (part !== undefined) {\n debugLogEvent &&\n debugLogEvent({\n kind: 'set part',\n part,\n value: values[i],\n valueIndex: i,\n values,\n templateInstance: this,\n });\n if ((part as AttributePart).strings !== undefined) {\n (part as AttributePart)._$setValue(values, part as AttributePart, i);\n // The number of values the part consumes is part.strings.length - 1\n // since values are in between template spans. We increment i by 1\n // later in the loop, so increment it by part.strings.length - 2 here\n i += (part as AttributePart).strings!.length - 2;\n } else {\n part._$setValue(values[i]);\n }\n }\n i++;\n }\n }\n}\n\n/*\n * Parts\n */\ntype AttributeTemplatePart = {\n readonly type: typeof ATTRIBUTE_PART;\n readonly index: number;\n readonly name: string;\n readonly ctor: typeof AttributePart;\n readonly strings: ReadonlyArray<string>;\n};\ntype ChildTemplatePart = {\n readonly type: typeof CHILD_PART;\n readonly index: number;\n};\ntype ElementTemplatePart = {\n readonly type: typeof ELEMENT_PART;\n readonly index: number;\n};\ntype CommentTemplatePart = {\n readonly type: typeof COMMENT_PART;\n readonly index: number;\n};\n\n/**\n * A TemplatePart represents a dynamic part in a template, before the template\n * is instantiated. When a template is instantiated Parts are created from\n * TemplateParts.\n */\ntype TemplatePart =\n | ChildTemplatePart\n | AttributeTemplatePart\n | ElementTemplatePart\n | CommentTemplatePart;\n\nexport type Part =\n | ChildPart\n | AttributePart\n | PropertyPart\n | BooleanAttributePart\n | ElementPart\n | EventPart;\n\nexport type {ChildPart};\nclass ChildPart implements Disconnectable {\n readonly type = CHILD_PART;\n readonly options: RenderOptions | undefined;\n _$committedValue: unknown = nothing;\n /** @internal */\n __directive?: Directive;\n /** @internal */\n _$startNode: ChildNode;\n /** @internal */\n _$endNode: ChildNode | null;\n private _textSanitizer: ValueSanitizer | undefined;\n /** @internal */\n _$parent: Disconnectable | undefined;\n /**\n * Connection state for RootParts only (i.e. ChildPart without _$parent\n * returned from top-level `render`). This field is unused otherwise. The\n * intention would be clearer if we made `RootPart` a subclass of `ChildPart`\n * with this field (and a different _$isConnected getter), but the subclass\n * caused a perf regression, possibly due to making call sites polymorphic.\n * @internal\n */\n __isConnected: boolean;\n\n // See comment in Disconnectable interface for why this is a getter\n get _$isConnected() {\n // ChildParts that are not at the root should always be created with a\n // parent; only RootChildNode's won't, so they return the local isConnected\n // state\n return this._$parent?._$isConnected ?? this.__isConnected;\n }\n\n // The following fields will be patched onto ChildParts when required by\n // AsyncDirective\n /** @internal */\n _$disconnectableChildren?: Set<Disconnectable> = undefined;\n /** @internal */\n _$notifyConnectionChanged?(\n isConnected: boolean,\n removeFromParent?: boolean,\n from?: number\n ): void;\n /** @internal */\n _$reparentDisconnectables?(parent: Disconnectable): void;\n\n constructor(\n startNode: ChildNode,\n endNode: ChildNode | null,\n parent: TemplateInstance | ChildPart | undefined,\n options: RenderOptions | undefined\n ) {\n this._$startNode = startNode;\n this._$endNode = endNode;\n this._$parent = parent;\n this.options = options;\n // Note __isConnected is only ever accessed on RootParts (i.e. when there is\n // no _$parent); the value on a non-root-part is \"don't care\", but checking\n // for parent would be more code\n this.__isConnected = options?.isConnected ?? true;\n if (ENABLE_EXTRA_SECURITY_HOOKS) {\n // Explicitly initialize for consistent class shape.\n this._textSanitizer = undefined;\n }\n }\n\n /**\n * The parent node into which the part renders its content.\n *\n * A ChildPart's content consists of a range of adjacent child nodes of\n * `.parentNode`, possibly bordered by 'marker nodes' (`.startNode` and\n * `.endNode`).\n *\n * - If both `.startNode` and `.endNode` are non-null, then the part's content\n * consists of all siblings between `.startNode` and `.endNode`, exclusively.\n *\n * - If `.startNode` is non-null but `.endNode` is null, then the part's\n * content consists of all siblings following `.startNode`, up to and\n * including the last child of `.parentNode`. If `.endNode` is non-null, then\n * `.startNode` will always be non-null.\n *\n * - If both `.endNode` and `.startNode` are null, then the part's content\n * consists of all child nodes of `.parentNode`.\n */\n get parentNode(): Node {\n let parentNode: Node = wrap(this._$startNode).parentNode!;\n const parent = this._$parent;\n if (\n parent !== undefined &&\n parentNode?.nodeType === 11 /* Node.DOCUMENT_FRAGMENT */\n ) {\n // If the parentNode is a DocumentFragment, it may be because the DOM is\n // still in the cloned fragment during initial render; if so, get the real\n // parentNode the part will be committed into by asking the parent.\n parentNode = (parent as ChildPart | TemplateInstance).parentNode;\n }\n return parentNode;\n }\n\n /**\n * The part's leading marker node, if any. See `.parentNode` for more\n * information.\n */\n get startNode(): Node | null {\n return this._$startNode;\n }\n\n /**\n * The part's trailing marker node, if any. See `.parentNode` for more\n * information.\n */\n get endNode(): Node | null {\n return this._$endNode;\n }\n\n _$setValue(value: unknown, directiveParent: DirectiveParent = this): void {\n if (DEV_MODE && this.parentNode === null) {\n throw new Error(\n `This \\`ChildPart\\` has no \\`parentNode\\` and therefore cannot accept a value. This likely means the element containing the part was manipulated in an unsupported way outside of Lit's control such that the part's marker nodes were ejected from DOM. For example, setting the element's \\`innerHTML\\` or \\`textContent\\` can do this.`\n );\n }\n value = resolveDirective(this, value, directiveParent);\n if (isPrimitive(value)) {\n // Non-rendering child values. It's important that these do not render\n // empty text nodes to avoid issues with preventing default <slot>\n // fallback content.\n if (value === nothing || value == null || value === '') {\n if (this._$committedValue !== nothing) {\n debugLogEvent &&\n debugLogEvent({\n kind: 'commit nothing to child',\n start: this._$startNode,\n end: this._$endNode,\n parent: this._$parent,\n options: this.options,\n });\n this._$clear();\n }\n this._$committedValue = nothing;\n } else if (value !== this._$committedValue && value !== noChange) {\n this._commitText(value);\n }\n // This property needs to remain unminified.\n } else if ((value as TemplateResult)['_$litType$'] !== undefined) {\n this._commitTemplateResult(value as TemplateResult);\n } else if ((value as Node).nodeType !== undefined) {\n if (DEV_MODE && this.options?.host === value) {\n this._commitText(\n `[probable mistake: rendered a template's host in itself ` +\n `(commonly caused by writing \\${this} in a template]`\n );\n console.warn(\n `Attempted to render the template host`,\n value,\n `inside itself. This is almost always a mistake, and in dev mode `,\n `we render some warning text. In production however, we'll `,\n `render it, which will usually result in an error, and sometimes `,\n `in the element disappearing from the DOM.`\n );\n return;\n }\n this._commitNode(value as Node);\n } else if (isIterable(value)) {\n this._commitIterable(value);\n } else {\n // Fallback, will render the string representation\n this._commitText(value);\n }\n }\n\n private _insert<T extends Node>(node: T) {\n return wrap(wrap(this._$startNode).parentNode!).insertBefore(\n node,\n this._$endNode\n );\n }\n\n private _commitNode(value: Node): void {\n if (this._$committedValue !== value) {\n this._$clear();\n if (\n ENABLE_EXTRA_SECURITY_HOOKS &&\n sanitizerFactoryInternal !== noopSanitizer\n ) {\n const parentNodeName = this._$startNode.parentNode?.nodeName;\n if (parentNodeName === 'STYLE' || parentNodeName === 'SCRIPT') {\n let message = 'Forbidden';\n if (DEV_MODE) {\n if (parentNodeName === 'STYLE') {\n message =\n `Lit does not support binding inside style nodes. ` +\n `This is a security risk, as style injection attacks can ` +\n `exfiltrate data and spoof UIs. ` +\n `Consider instead using css\\`...\\` literals ` +\n `to compose styles, and do dynamic styling with ` +\n `css custom properties, ::parts, <slot>s, ` +\n `and by mutating the DOM rather than stylesheets.`;\n } else {\n message =\n `Lit does not support binding inside script nodes. ` +\n `This is a security risk, as it could allow arbitrary ` +\n `code execution.`;\n }\n }\n throw new Error(message);\n }\n }\n debugLogEvent &&\n debugLogEvent({\n kind: 'commit node',\n start: this._$startNode,\n parent: this._$parent,\n value: value,\n options: this.options,\n });\n this._$committedValue = this._insert(value);\n }\n }\n\n private _commitText(value: unknown): void {\n // If the committed value is a primitive it means we called _commitText on\n // the previous render, and we know that this._$startNode.nextSibling is a\n // Text node. We can now just replace the text content (.data) of the node.\n if (\n this._$committedValue !== nothing &&\n isPrimitive(this._$committedValue)\n ) {\n const node = wrap(this._$startNode).nextSibling as Text;\n if (ENABLE_EXTRA_SECURITY_HOOKS) {\n if (this._textSanitizer === undefined) {\n this._textSanitizer = createSanitizer(node, 'data', 'property');\n }\n value = this._textSanitizer(value);\n }\n debugLogEvent &&\n debugLogEvent({\n kind: 'commit text',\n node,\n value,\n options: this.options,\n });\n (node as Text).data = value as string;\n } else {\n if (ENABLE_EXTRA_SECURITY_HOOKS) {\n const textNode = d.createTextNode('');\n this._commitNode(textNode);\n // When setting text content, for security purposes it matters a lot\n // what the parent is. For example, <style> and <script> need to be\n // handled with care, while <span> does not. So first we need to put a\n // text node into the document, then we can sanitize its content.\n if (this._textSanitizer === undefined) {\n this._textSanitizer = createSanitizer(textNode, 'data', 'property');\n }\n value = this._textSanitizer(value);\n debugLogEvent &&\n debugLogEvent({\n kind: 'commit text',\n node: textNode,\n value,\n options: this.options,\n });\n textNode.data = value as string;\n } else {\n this._commitNode(d.createTextNode(value as string));\n debugLogEvent &&\n debugLogEvent({\n kind: 'commit text',\n node: wrap(this._$startNode).nextSibling as Text,\n value,\n options: this.options,\n });\n }\n }\n this._$committedValue = value;\n }\n\n private _commitTemplateResult(\n result: TemplateResult | CompiledTemplateResult\n ): void {\n // This property needs to remain unminified.\n const {values, ['_$litType$']: type} = result;\n // If $litType$ is a number, result is a plain TemplateResult and we get\n // the template from the template cache. If not, result is a\n // CompiledTemplateResult and _$litType$ is a CompiledTemplate and we need\n // to create the <template> element the first time we see it.\n const template: Template | CompiledTemplate =\n typeof type === 'number'\n ? this._$getTemplate(result as UncompiledTemplateResult)\n : (type.el === undefined &&\n (type.el = Template.createElement(\n trustFromTemplateString(type.h, type.h[0]),\n this.options\n )),\n type);\n\n if ((this._$committedValue as TemplateInstance)?._$template === template) {\n debugLogEvent &&\n debugLogEvent({\n kind: 'template updating',\n template,\n instance: this._$committedValue as TemplateInstance,\n parts: (this._$committedValue as TemplateInstance)._$parts,\n options: this.options,\n values,\n });\n (this._$committedValue as TemplateInstance)._update(values);\n } else {\n const instance = new TemplateInstance(template as Template, this);\n const fragment = instance._clone(this.options);\n debugLogEvent &&\n debugLogEvent({\n kind: 'template instantiated',\n template,\n instance,\n parts: instance._$parts,\n options: this.options,\n fragment,\n values,\n });\n instance._update(values);\n debugLogEvent &&\n debugLogEvent({\n kind: 'template instantiated and updated',\n template,\n instance,\n parts: instance._$parts,\n options: this.options,\n fragment,\n values,\n });\n this._commitNode(fragment);\n this._$committedValue = instance;\n }\n }\n\n // Overridden via `litHtmlPolyfillSupport` to provide platform support.\n /** @internal */\n _$getTemplate(result: UncompiledTemplateResult) {\n let template = templateCache.get(result.strings);\n if (template === undefined) {\n templateCache.set(result.strings, (template = new Template(result)));\n }\n return template;\n }\n\n private _commitIterable(value: Iterable<unknown>): void {\n // For an Iterable, we create a new InstancePart per item, then set its\n // value to the item. This is a little bit of overhead for every item in\n // an Iterable, but it lets us recurse easily and efficiently update Arrays\n // of TemplateResults that will be commonly returned from expressions like:\n // array.map((i) => html`${i}`), by reusing existing TemplateInstances.\n\n // If value is an array, then the previous render was of an\n // iterable and value will contain the ChildParts from the previous\n // render. If value is not an array, clear this part and make a new\n // array for ChildParts.\n if (!isArray(this._$committedValue)) {\n this._$committedValue = [];\n this._$clear();\n }\n\n // Lets us keep track of how many items we stamped so we can clear leftover\n // items from a previous render\n const itemParts = this._$committedValue as ChildPart[];\n let partIndex = 0;\n let itemPart: ChildPart | undefined;\n\n for (const item of value) {\n if (partIndex === itemParts.length) {\n // If no existing part, create a new one\n // TODO (justinfagnani): test perf impact of always creating two parts\n // instead of sharing parts between nodes\n // https://github.com/lit/lit/issues/1266\n itemParts.push(\n (itemPart = new ChildPart(\n this._insert(createMarker()),\n this._insert(createMarker()),\n this,\n this.options\n ))\n );\n } else {\n // Reuse an existing part\n itemPart = itemParts[partIndex];\n }\n itemPart._$setValue(item);\n partIndex++;\n }\n\n if (partIndex < itemParts.length) {\n // itemParts always have end nodes\n this._$clear(\n itemPart && wrap(itemPart._$endNode!).nextSibling,\n partIndex\n );\n // Truncate the parts array so _value reflects the current state\n itemParts.length = partIndex;\n }\n }\n\n /**\n * Removes the nodes contained within this Part from the DOM.\n *\n * @param start Start node to clear from, for clearing a subset of the part's\n * DOM (used when truncating iterables)\n * @param from When `start` is specified, the index within the iterable from\n * which ChildParts are being removed, used for disconnecting directives\n * in those Parts.\n *\n * @internal\n */\n _$clear(\n start: ChildNode | null = wrap(this._$startNode).nextSibling,\n from?: number\n ) {\n this._$notifyConnectionChanged?.(false, true, from);\n while (start !== this._$endNode) {\n // The non-null assertion is safe because if _$startNode.nextSibling is\n // null, then _$endNode is also null, and we would not have entered this\n // loop.\n const n = wrap(start!).nextSibling;\n wrap(start!).remove();\n start = n;\n }\n }\n\n /**\n * Implementation of RootPart's `isConnected`. Note that this method\n * should only be called on `RootPart`s (the `ChildPart` returned from a\n * top-level `render()` call). It has no effect on non-root ChildParts.\n * @param isConnected Whether to set\n * @internal\n */\n setConnected(isConnected: boolean) {\n if (this._$parent === undefined) {\n this.__isConnected = isConnected;\n this._$notifyConnectionChanged?.(isConnected);\n } else if (DEV_MODE) {\n throw new Error(\n 'part.setConnected() may only be called on a ' +\n 'RootPart returned from render().'\n );\n }\n }\n}\n\n/**\n * A top-level `ChildPart` returned from `render` that manages the connected\n * state of `AsyncDirective`s created throughout the tree below it.\n */\nexport interface RootPart extends ChildPart {\n /**\n * Sets the connection state for `AsyncDirective`s contained within this root\n * ChildPart.\n *\n * lit-html does not automatically monitor the connectedness of DOM rendered;\n * as such, it is the responsibility of the caller to `render` to ensure that\n * `part.setConnected(false)` is called before the part object is potentially\n * discarded, to ensure that `AsyncDirective`s have a chance to dispose of\n * any resources being held. If a `RootPart` that was previously\n * disconnected is subsequently re-connected (and its `AsyncDirective`s should\n * re-connect), `setConnected(true)` should be called.\n *\n * @param isConnected Whether directives within this tree should be connected\n * or not\n */\n setConnected(isConnected: boolean): void;\n}\n\nexport type {AttributePart};\nclass AttributePart implements Disconnectable {\n readonly type:\n | typeof ATTRIBUTE_PART\n | typeof PROPERTY_PART\n | typeof BOOLEAN_ATTRIBUTE_PART\n | typeof EVENT_PART = ATTRIBUTE_PART;\n readonly element: HTMLElement;\n readonly name: string;\n readonly options: RenderOptions | undefined;\n\n /**\n * If this attribute part represents an interpolation, this contains the\n * static strings of the interpolation. For single-value, complete bindings,\n * this is undefined.\n */\n readonly strings?: ReadonlyArray<string>;\n /** @internal */\n _$committedValue: unknown | Array<unknown> = nothing;\n /** @internal */\n __directives?: Array<Directive | undefined>;\n /** @internal */\n _$parent: Disconnectable;\n /** @internal */\n _$disconnectableChildren?: Set<Disconnectable> = undefined;\n\n protected _sanitizer: ValueSanitizer | undefined;\n\n get tagName() {\n return this.element.tagName;\n }\n\n // See comment in Disconnectable interface for why this is a getter\n get _$isConnected() {\n return this._$parent._$isConnected;\n }\n\n constructor(\n element: HTMLElement,\n name: string,\n strings: ReadonlyArray<string>,\n parent: Disconnectable,\n options: RenderOptions | undefined\n ) {\n this.element = element;\n this.name = name;\n this._$parent = parent;\n this.options = options;\n if (strings.length > 2 || strings[0] !== '' || strings[1] !== '') {\n this._$committedValue = new Array(strings.length - 1).fill(new String());\n this.strings = strings;\n } else {\n this._$committedValue = nothing;\n }\n if (ENABLE_EXTRA_SECURITY_HOOKS) {\n this._sanitizer = undefined;\n }\n }\n\n /**\n * Sets the value of this part by resolving the value from possibly multiple\n * values and static strings and committing it to the DOM.\n * If this part is single-valued, `this._strings` will be undefined, and the\n * method will be called with a single value argument. If this part is\n * multi-value, `this._strings` will be defined, and the method is called\n * with the value array of the part's owning TemplateInstance, and an offset\n * into the value array from which the values should be read.\n * This method is overloaded this way to eliminate short-lived array slices\n * of the template instance values, and allow a fast-path for single-valued\n * parts.\n *\n * @param value The part value, or an array of values for multi-valued parts\n * @param valueIndex the index to start reading values from. `undefined` for\n * single-valued parts\n * @param noCommit causes the part to not commit its value to the DOM. Used\n * in hydration to prime attribute parts with their first-rendered value,\n * but not set the attribute, and in SSR to no-op the DOM operation and\n * capture the value for serialization.\n *\n * @internal\n */\n _$setValue(\n value: unknown | Array<unknown>,\n directiveParent: DirectiveParent = this,\n valueIndex?: number,\n noCommit?: boolean\n ) {\n const strings = this.strings;\n\n // Whether any of the values has changed, for dirty-checking\n let change = false;\n\n if (strings === undefined) {\n // Single-value binding case\n value = resolveDirective(this, value, directiveParent, 0);\n change =\n !isPrimitive(value) ||\n (value !== this._$committedValue && value !== noChange);\n if (change) {\n this._$committedValue = value;\n }\n } else {\n // Interpolation case\n const values = value as Array<unknown>;\n value = strings[0];\n\n let i, v;\n for (i = 0; i < strings.length - 1; i++) {\n v = resolveDirective(this, values[valueIndex! + i], directiveParent, i);\n\n if (v === noChange) {\n // If the user-provided value is `noChange`, use the previous value\n v = (this._$committedValue as Array<unknown>)[i];\n }\n change ||=\n !isPrimitive(v) || v !== (this._$committedValue as Array<unknown>)[i];\n if (v === nothing) {\n value = nothing;\n } else if (value !== nothing) {\n value += (v ?? '') + strings[i + 1];\n }\n // We always record each value, even if one is `nothing`, for future\n // change detection.\n (this._$committedValue as Array<unknown>)[i] = v;\n }\n }\n if (change && !noCommit) {\n this._commitValue(value);\n }\n }\n\n /** @internal */\n _commitValue(value: unknown) {\n if (value === nothing) {\n (wrap(this.element) as Element).removeAttribute(this.name);\n } else {\n if (ENABLE_EXTRA_SECURITY_HOOKS) {\n if (this._sanitizer === undefined) {\n this._sanitizer = sanitizerFactoryInternal(\n this.element,\n this.name,\n 'attribute'\n );\n }\n value = this._sanitizer(value ?? '');\n }\n debugLogEvent &&\n debugLogEvent({\n kind: 'commit attribute',\n element: this.element,\n name: this.name,\n value,\n options: this.options,\n });\n (wrap(this.element) as Element).setAttribute(\n this.name,\n (value ?? '') as string\n );\n }\n }\n}\n\nexport type {PropertyPart};\nclass PropertyPart extends AttributePart {\n override readonly type = PROPERTY_PART;\n\n /** @internal */\n override _commitValue(value: unknown) {\n if (ENABLE_EXTRA_SECURITY_HOOKS) {\n if (this._sanitizer === undefined) {\n this._sanitizer = sanitizerFactoryInternal(\n this.element,\n this.name,\n 'property'\n );\n }\n value = this._sanitizer(value);\n }\n debugLogEvent &&\n debugLogEvent({\n kind: 'commit property',\n element: this.element,\n name: this.name,\n value,\n options: this.options,\n });\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n (this.element as any)[this.name] = value === nothing ? undefined : value;\n }\n}\n\nexport type {BooleanAttributePart};\nclass BooleanAttributePart extends AttributePart {\n override readonly type = BOOLEAN_ATTRIBUTE_PART;\n\n /** @internal */\n override _commitValue(value: unknown) {\n debugLogEvent &&\n debugLogEvent({\n kind: 'commit boolean attribute',\n element: this.element,\n name: this.name,\n value: !!(value && value !== nothing),\n options: this.options,\n });\n (wrap(this.element) as Element).toggleAttribute(\n this.name,\n !!value && value !== nothing\n );\n }\n}\n\ntype EventListenerWithOptions = EventListenerOrEventListenerObject &\n Partial<AddEventListenerOptions>;\n\n/**\n * An AttributePart that manages an event listener via add/removeEventListener.\n *\n * This part works by adding itself as the event listener on an element, then\n * delegating to the value passed to it. This reduces the number of calls to\n * add/removeEventListener if the listener changes frequently, such as when an\n * inline function is used as a listener.\n *\n * Because event options are passed when adding listeners, we must take case\n * to add and remove the part as a listener when the event options change.\n */\nexport type {EventPart};\nclass EventPart extends AttributePart {\n override readonly type = EVENT_PART;\n\n constructor(\n element: HTMLElement,\n name: string,\n strings: ReadonlyArray<string>,\n parent: Disconnectable,\n options: RenderOptions | undefined\n ) {\n super(element, name, strings, parent, options);\n\n if (DEV_MODE && this.strings !== undefined) {\n throw new Error(\n `A \\`<${element.localName}>\\` has a \\`@${name}=...\\` listener with ` +\n 'invalid content. Event listeners in templates must have exactly ' +\n 'one expression and no surrounding text.'\n );\n }\n }\n\n // EventPart does not use the base _$setValue/_resolveValue implementation\n // since the dirty checking is more complex\n /** @internal */\n override _$setValue(\n newListener: unknown,\n directiveParent: DirectiveParent = this\n ) {\n newListener =\n resolveDirective(this, newListener, directiveParent, 0) ?? nothing;\n if (newListener === noChange) {\n return;\n }\n const oldListener = this._$committedValue;\n\n // If the new value is nothing or any options change we have to remove the\n // part as a listener.\n const shouldRemoveListener =\n (newListener === nothing && oldListener !== nothing) ||\n (newListener as EventListenerWithOptions).capture !==\n (oldListener as EventListenerWithOptions).capture ||\n (newListener as EventListenerWithOptions).once !==\n (oldListener as EventListenerWithOptions).once ||\n (newListener as EventListenerWithOptions).passive !==\n (oldListener as EventListenerWithOptions).passive;\n\n // If the new value is not nothing and we removed the listener, we have\n // to add the part as a listener.\n const shouldAddListener =\n newListener !== nothing &&\n (oldListener === nothing || shouldRemoveListener);\n\n debugLogEvent &&\n debugLogEvent({\n kind: 'commit event listener',\n element: this.element,\n name: this.name,\n value: newListener,\n options: this.options,\n removeListener: shouldRemoveListener,\n addListener: shouldAddListener,\n oldListener,\n });\n if (shouldRemoveListener) {\n this.element.removeEventListener(\n this.name,\n this,\n oldListener as EventListenerWithOptions\n );\n }\n if (shouldAddListener) {\n this.element.addEventListener(\n this.name,\n this,\n newListener as EventListenerWithOptions\n );\n }\n this._$committedValue = newListener;\n }\n\n handleEvent(event: Event) {\n if (typeof this._$committedValue === 'function') {\n this._$committedValue.call(this.options?.host ?? this.element, event);\n } else {\n (this._$committedValue as EventListenerObject).handleEvent(event);\n }\n }\n}\n\nexport type {ElementPart};\nclass ElementPart implements Disconnectable {\n readonly type = ELEMENT_PART;\n\n /** @internal */\n __directive?: Directive;\n\n // This is to ensure that every Part has a _$committedValue\n _$committedValue: undefined;\n\n /** @internal */\n _$parent!: Disconnectable;\n\n /** @internal */\n _$disconnectableChildren?: Set<Disconnectable> = undefined;\n\n options: RenderOptions | undefined;\n\n constructor(\n public element: Element,\n parent: Disconnectable,\n options: RenderOptions | undefined\n ) {\n this._$parent = parent;\n this.options = options;\n }\n\n // See comment in Disconnectable interface for why this is a getter\n get _$isConnected() {\n return this._$parent._$isConnected;\n }\n\n _$setValue(value: unknown): void {\n debugLogEvent &&\n debugLogEvent({\n kind: 'commit to element binding',\n element: this.element,\n value,\n options: this.options,\n });\n resolveDirective(this, value);\n }\n}\n\n/**\n * END USERS SHOULD NOT RELY ON THIS OBJECT.\n *\n * Private exports for use by other Lit packages, not intended for use by\n * external users.\n *\n * We currently do not make a mangled rollup build of the lit-ssr code. In order\n * to keep a number of (otherwise private) top-level exports mangled in the\n * client side code, we export a _$LH object containing those members (or\n * helper methods for accessing private fields of those members), and then\n * re-export them for use in lit-ssr. This keeps lit-ssr agnostic to whether the\n * client-side code is being used in `dev` mode or `prod` mode.\n *\n * This has a unique name, to disambiguate it from private exports in\n * lit-element, which re-exports all of lit-html.\n *\n * @private\n */\nexport const _$LH = {\n // Used in lit-ssr\n _boundAttributeSuffix: boundAttributeSuffix,\n _marker: marker,\n _markerMatch: markerMatch,\n _HTML_RESULT: HTML_RESULT,\n _getTemplateHtml: getTemplateHtml,\n // Used in tests and private-ssr-support\n _TemplateInstance: TemplateInstance,\n _isIterable: isIterable,\n _resolveDirective: resolveDirective,\n _ChildPart: ChildPart,\n _AttributePart: AttributePart,\n _BooleanAttributePart: BooleanAttributePart,\n _EventPart: EventPart,\n _PropertyPart: PropertyPart,\n _ElementPart: ElementPart,\n};\n\n// Apply polyfills if available\nconst polyfillSupport = DEV_MODE\n ? global.litHtmlPolyfillSupportDevMode\n : global.litHtmlPolyfillSupport;\npolyfillSupport?.(Template, ChildPart);\n\n// IMPORTANT: do not change the property name or the assignment expression.\n// This line will be used in regexes to search for lit-html usage.\n(global.litHtmlVersions ??= []).push('3.3.2');\nif (DEV_MODE && global.litHtmlVersions.length > 1) {\n queueMicrotask(() => {\n issueWarning!(\n 'multiple-versions',\n `Multiple versions of Lit loaded. ` +\n `Loading multiple versions is not recommended.`\n );\n });\n}\n\n/**\n * Renders a value, usually a lit-html TemplateResult, to the container.\n *\n * This example renders the text \"Hello, Zoe!\" inside a paragraph tag, appending\n * it to the container `document.body`.\n *\n * ```js\n * import {html, render} from 'lit';\n *\n * const name = \"Zoe\";\n * render(html`<p>Hello, ${name}!</p>`, document.body);\n * ```\n *\n * @param value Any [renderable\n * value](https://lit.dev/docs/templates/expressions/#child-expressions),\n * typically a {@linkcode TemplateResult} created by evaluating a template tag\n * like {@linkcode html} or {@linkcode svg}.\n * @param container A DOM container to render to. The first render will append\n * the rendered value to the container, and subsequent renders will\n * efficiently update the rendered value if the same result type was\n * previously rendered there.\n * @param options See {@linkcode RenderOptions} for options documentation.\n * @see\n * {@link https://lit.dev/docs/libraries/standalone-templates/#rendering-lit-html-templates| Rendering Lit HTML Templates}\n */\nexport const render = (\n value: unknown,\n container: RenderRootNode,\n options?: RenderOptions\n): RootPart => {\n if (DEV_MODE && container == null) {\n // Give a clearer error message than\n // Uncaught TypeError: Cannot read properties of null (reading\n // '_$litPart$')\n // which reads like an internal Lit error.\n throw new TypeError(`The container to render into may not be ${container}`);\n }\n const renderId = DEV_MODE ? debugLogRenderId++ : 0;\n const partOwnerNode = options?.renderBefore ?? container;\n // This property needs to remain unminified.\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let part: ChildPart = (partOwnerNode as any)['_$litPart$'];\n debugLogEvent &&\n debugLogEvent({\n kind: 'begin render',\n id: renderId,\n value,\n container,\n options,\n part,\n });\n if (part === undefined) {\n const endNode = options?.renderBefore ?? null;\n // This property needs to remain unminified.\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n (partOwnerNode as any)['_$litPart$'] = part = new ChildPart(\n container.insertBefore(createMarker(), endNode),\n endNode,\n undefined,\n options ?? {}\n );\n }\n part._$setValue(value);\n debugLogEvent &&\n debugLogEvent({\n kind: 'end render',\n id: renderId,\n value,\n container,\n options,\n part,\n });\n return part as RootPart;\n};\n\nif (ENABLE_EXTRA_SECURITY_HOOKS) {\n render.setSanitizer = setSanitizer;\n render.createSanitizer = createSanitizer;\n if (DEV_MODE) {\n render._testOnlyClearSanitizerFactoryDoNotCallOrElse =\n _testOnlyClearSanitizerFactoryDoNotCallOrElse;\n }\n}\n", "/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\n\n/**\n * The main LitElement module, which defines the {@linkcode LitElement} base\n * class and related APIs.\n *\n * LitElement components can define a template and a set of observed\n * properties. Changing an observed property triggers a re-render of the\n * element.\n *\n * Import {@linkcode LitElement} and {@linkcode html} from this module to\n * create a component:\n *\n * ```js\n * import {LitElement, html} from 'lit-element';\n *\n * class MyElement extends LitElement {\n *\n * // Declare observed properties\n * static get properties() {\n * return {\n * adjective: {}\n * }\n * }\n *\n * constructor() {\n * this.adjective = 'awesome';\n * }\n *\n * // Define the element's template\n * render() {\n * return html`<p>your ${adjective} template here</p>`;\n * }\n * }\n *\n * customElements.define('my-element', MyElement);\n * ```\n *\n * `LitElement` extends {@linkcode ReactiveElement} and adds lit-html\n * templating. The `ReactiveElement` class is provided for users that want to\n * build their own custom element base classes that don't use lit-html.\n *\n * @packageDocumentation\n */\nimport {PropertyValues, ReactiveElement} from '@lit/reactive-element';\nimport {render, RenderOptions, noChange, RootPart} from 'lit-html';\nexport * from '@lit/reactive-element';\nexport * from 'lit-html';\n\nimport {LitUnstable} from 'lit-html';\nimport {ReactiveUnstable} from '@lit/reactive-element';\n\n/**\n * Contains types that are part of the unstable debug API.\n *\n * Everything in this API is not stable and may change or be removed in the future,\n * even on patch releases.\n */\n// eslint-disable-next-line @typescript-eslint/no-namespace\nexport namespace Unstable {\n /**\n * When Lit is running in dev mode and `window.emitLitDebugLogEvents` is true,\n * we will emit 'lit-debug' events to window, with live details about the update and render\n * lifecycle. These can be useful for writing debug tooling and visualizations.\n *\n * Please be aware that running with window.emitLitDebugLogEvents has performance overhead,\n * making certain operations that are normally very cheap (like a no-op render) much slower,\n * because we must copy data and dispatch events.\n */\n // eslint-disable-next-line @typescript-eslint/no-namespace\n export namespace DebugLog {\n export type Entry =\n | LitUnstable.DebugLog.Entry\n | ReactiveUnstable.DebugLog.Entry;\n }\n}\n/*\n * When using Closure Compiler, JSCompiler_renameProperty(property, object) is\n * replaced at compile time by the munged name for object[property]. We cannot\n * alias this function, so we have to use a small shim that has the same\n * behavior when not compiling.\n */\n/*@__INLINE__*/\nconst JSCompiler_renameProperty = <P extends PropertyKey>(\n prop: P,\n _obj: unknown\n): P => prop;\n\nconst DEV_MODE = true;\n// Allows minifiers to rename references to globalThis\nconst global = globalThis;\n\nlet issueWarning: (code: string, warning: string) => void;\n\nif (DEV_MODE) {\n // Ensure warnings are issued only 1x, even if multiple versions of Lit\n // are loaded.\n global.litIssuedWarnings ??= new Set();\n\n /**\n * Issue a warning if we haven't already, based either on `code` or `warning`.\n * Warnings are disabled automatically only by `warning`; disabling via `code`\n * can be done by users.\n */\n issueWarning = (code: string, warning: string) => {\n warning += ` See https://lit.dev/msg/${code} for more information.`;\n if (\n !global.litIssuedWarnings!.has(warning) &&\n !global.litIssuedWarnings!.has(code)\n ) {\n console.warn(warning);\n global.litIssuedWarnings!.add(warning);\n }\n };\n}\n\n/**\n * Base element class that manages element properties and attributes, and\n * renders a lit-html template.\n *\n * To define a component, subclass `LitElement` and implement a\n * `render` method to provide the component's template. Define properties\n * using the {@linkcode LitElement.properties properties} property or the\n * {@linkcode property} decorator.\n */\nexport class LitElement extends ReactiveElement {\n // This property needs to remain unminified.\n static ['_$litElement$'] = true;\n\n /**\n * @category rendering\n */\n readonly renderOptions: RenderOptions = {host: this};\n\n private __childPart: RootPart | undefined = undefined;\n\n /**\n * @category rendering\n */\n protected override createRenderRoot() {\n const renderRoot = super.createRenderRoot();\n // When adoptedStyleSheets are shimmed, they are inserted into the\n // shadowRoot by createRenderRoot. Adjust the renderBefore node so that\n // any styles in Lit content render before adoptedStyleSheets. This is\n // important so that adoptedStyleSheets have precedence over styles in\n // the shadowRoot.\n this.renderOptions.renderBefore ??= renderRoot!.firstChild as ChildNode;\n return renderRoot;\n }\n\n /**\n * Updates the element. This method reflects property values to attributes\n * and calls `render` to render DOM via lit-html. Setting properties inside\n * this method will *not* trigger another update.\n * @param changedProperties Map of changed properties with old values\n * @category updates\n */\n protected override update(changedProperties: PropertyValues) {\n // Setting properties in `render` should not trigger an update. Since\n // updates are allowed after super.update, it's important to call `render`\n // before that.\n const value = this.render();\n if (!this.hasUpdated) {\n this.renderOptions.isConnected = this.isConnected;\n }\n super.update(changedProperties);\n this.__childPart = render(value, this.renderRoot, this.renderOptions);\n }\n\n /**\n * Invoked when the component is added to the document's DOM.\n *\n * In `connectedCallback()` you should setup tasks that should only occur when\n * the element is connected to the document. The most common of these is\n * adding event listeners to nodes external to the element, like a keydown\n * event handler added to the window.\n *\n * ```ts\n * connectedCallback() {\n * super.connectedCallback();\n * addEventListener('keydown', this._handleKeydown);\n * }\n * ```\n *\n * Typically, anything done in `connectedCallback()` should be undone when the\n * element is disconnected, in `disconnectedCallback()`.\n *\n * @category lifecycle\n */\n override connectedCallback() {\n super.connectedCallback();\n this.__childPart?.setConnected(true);\n }\n\n /**\n * Invoked when the component is removed from the document's DOM.\n *\n * This callback is the main signal to the element that it may no longer be\n * used. `disconnectedCallback()` should ensure that nothing is holding a\n * reference to the element (such as event listeners added to nodes external\n * to the element), so that it is free to be garbage collected.\n *\n * ```ts\n * disconnectedCallback() {\n * super.disconnectedCallback();\n * window.removeEventListener('keydown', this._handleKeydown);\n * }\n * ```\n *\n * An element may be re-connected after being disconnected.\n *\n * @category lifecycle\n */\n override disconnectedCallback() {\n super.disconnectedCallback();\n this.__childPart?.setConnected(false);\n }\n\n /**\n * Invoked on each update to perform rendering tasks. This method may return\n * any value renderable by lit-html's `ChildPart` - typically a\n * `TemplateResult`. Setting properties inside this method will *not* trigger\n * the element to update.\n * @category rendering\n */\n protected render(): unknown {\n return noChange;\n }\n}\n\n/**\n * Ensure this class is marked as `finalized` as an optimization ensuring\n * it will not needlessly try to `finalize`.\n *\n * Note this property name is a string to prevent breaking Closure JS Compiler\n * optimizations. See @lit/reactive-element for more information.\n */\n(LitElement as unknown as Record<string, unknown>)[\n JSCompiler_renameProperty('finalized', LitElement)\n] = true;\n\n// Install hydration if available\nglobal.litElementHydrateSupport?.({LitElement});\n\n// Apply polyfills if available\nconst polyfillSupport = DEV_MODE\n ? global.litElementPolyfillSupportDevMode\n : global.litElementPolyfillSupport;\npolyfillSupport?.({LitElement});\n\n/**\n * END USERS SHOULD NOT RELY ON THIS OBJECT.\n *\n * Private exports for use by other Lit packages, not intended for use by\n * external users.\n *\n * We currently do not make a mangled rollup build of the lit-ssr code. In order\n * to keep a number of (otherwise private) top-level exports mangled in the\n * client side code, we export a _$LE object containing those members (or\n * helper methods for accessing private fields of those members), and then\n * re-export them for use in lit-ssr. This keeps lit-ssr agnostic to whether the\n * client-side code is being used in `dev` mode or `prod` mode.\n *\n * This has a unique name, to disambiguate it from private exports in\n * lit-html, since this module re-exports all of lit-html.\n *\n * @private\n */\nexport const _$LE = {\n _$attributeToProperty: (\n el: LitElement,\n name: string,\n value: string | null\n ) => {\n // eslint-disable-next-line\n (el as any)._$attributeToProperty(name, value);\n },\n // eslint-disable-next-line\n _$changedProperties: (el: LitElement) => (el as any)._$changedProperties,\n};\n\n// IMPORTANT: do not change the property name or the assignment expression.\n// This line will be used in regexes to search for LitElement usage.\n(global.litElementVersions ??= []).push('4.2.2');\nif (DEV_MODE && global.litElementVersions.length > 1) {\n queueMicrotask(() => {\n issueWarning!(\n 'multiple-versions',\n `Multiple versions of Lit loaded. Loading multiple versions ` +\n `is not recommended.`\n );\n });\n}\n", "/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\n\nimport {Disconnectable, Part} from './lit-html.js';\n\nexport {\n AttributePart,\n BooleanAttributePart,\n ChildPart,\n ElementPart,\n EventPart,\n Part,\n PropertyPart,\n} from './lit-html.js';\n\nexport interface DirectiveClass {\n new (part: PartInfo): Directive;\n}\n\n/**\n * This utility type extracts the signature of a directive class's render()\n * method so we can use it for the type of the generated directive function.\n */\nexport type DirectiveParameters<C extends Directive> = Parameters<C['render']>;\n\n/**\n * A generated directive function doesn't evaluate the directive, but just\n * returns a DirectiveResult object that captures the arguments.\n */\nexport interface DirectiveResult<C extends DirectiveClass = DirectiveClass> {\n /**\n * This property needs to remain unminified.\n * @internal\n */\n ['_$litDirective$']: C;\n /** @internal */\n values: DirectiveParameters<InstanceType<C>>;\n}\n\nexport const PartType = {\n ATTRIBUTE: 1,\n CHILD: 2,\n PROPERTY: 3,\n BOOLEAN_ATTRIBUTE: 4,\n EVENT: 5,\n ELEMENT: 6,\n} as const;\n\nexport type PartType = (typeof PartType)[keyof typeof PartType];\n\nexport interface ChildPartInfo {\n readonly type: typeof PartType.CHILD;\n}\n\nexport interface AttributePartInfo {\n readonly type:\n | typeof PartType.ATTRIBUTE\n | typeof PartType.PROPERTY\n | typeof PartType.BOOLEAN_ATTRIBUTE\n | typeof PartType.EVENT;\n readonly strings?: ReadonlyArray<string>;\n readonly name: string;\n readonly tagName: string;\n}\n\nexport interface ElementPartInfo {\n readonly type: typeof PartType.ELEMENT;\n}\n\n/**\n * Information about the part a directive is bound to.\n *\n * This is useful for checking that a directive is attached to a valid part,\n * such as with directive that can only be used on attribute bindings.\n */\nexport type PartInfo = ChildPartInfo | AttributePartInfo | ElementPartInfo;\n\n/**\n * Creates a user-facing directive function from a Directive class. This\n * function has the same parameters as the directive's render() method.\n */\nexport const directive =\n <C extends DirectiveClass>(c: C) =>\n (...values: DirectiveParameters<InstanceType<C>>): DirectiveResult<C> => ({\n // This property needs to remain unminified.\n ['_$litDirective$']: c,\n values,\n });\n\n/**\n * Base class for creating custom directives. Users should extend this class,\n * implement `render` and/or `update`, and then pass their subclass to\n * `directive`.\n */\nexport abstract class Directive implements Disconnectable {\n //@internal\n __part!: Part;\n //@internal\n __attributeIndex: number | undefined;\n //@internal\n __directive?: Directive;\n\n //@internal\n _$parent!: Disconnectable;\n\n // These will only exist on the AsyncDirective subclass\n //@internal\n _$disconnectableChildren?: Set<Disconnectable>;\n // This property needs to remain unminified.\n //@internal\n ['_$notifyDirectiveConnectionChanged']?(isConnected: boolean): void;\n\n constructor(_partInfo: PartInfo) {}\n\n // See comment in Disconnectable interface for why this is a getter\n get _$isConnected() {\n return this._$parent._$isConnected;\n }\n\n /** @internal */\n _$initialize(\n part: Part,\n parent: Disconnectable,\n attributeIndex: number | undefined\n ) {\n this.__part = part;\n this._$parent = parent;\n this.__attributeIndex = attributeIndex;\n }\n /** @internal */\n _$resolve(part: Part, props: Array<unknown>): unknown {\n return this.update(part, props);\n }\n\n abstract render(...props: Array<unknown>): unknown;\n\n update(_part: Part, props: Array<unknown>): unknown {\n return this.render(...props);\n }\n}\n", "/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\n\nimport {nothing, TemplateResult, noChange} from '../lit-html.js';\nimport {directive, Directive, PartInfo, PartType} from '../directive.js';\n\nconst HTML_RESULT = 1;\n\nexport class UnsafeHTMLDirective extends Directive {\n static directiveName = 'unsafeHTML';\n static resultType = HTML_RESULT;\n\n private _value: unknown = nothing;\n private _templateResult?: TemplateResult;\n\n constructor(partInfo: PartInfo) {\n super(partInfo);\n if (partInfo.type !== PartType.CHILD) {\n throw new Error(\n `${\n (this.constructor as typeof UnsafeHTMLDirective).directiveName\n }() can only be used in child bindings`\n );\n }\n }\n\n render(value: string | typeof nothing | typeof noChange | undefined | null) {\n if (value === nothing || value == null) {\n this._templateResult = undefined;\n return (this._value = value);\n }\n if (value === noChange) {\n return value;\n }\n if (typeof value != 'string') {\n throw new Error(\n `${\n (this.constructor as typeof UnsafeHTMLDirective).directiveName\n }() called with a non-string value`\n );\n }\n if (value === this._value) {\n return this._templateResult;\n }\n this._value = value;\n const strings = [value] as unknown as TemplateStringsArray;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n (strings as any).raw = strings;\n // WARNING: impersonating a TemplateResult like this is extremely\n // dangerous. Third-party directives should not do this.\n return (this._templateResult = {\n // Cast to a known set of integers that satisfy ResultType so that we\n // don't have to export ResultType and possibly encourage this pattern.\n // This property needs to remain unminified.\n ['_$litType$']: (this.constructor as typeof UnsafeHTMLDirective)\n .resultType as 1 | 2,\n strings,\n values: [],\n });\n }\n}\n\n/**\n * Renders the result as HTML, rather than text.\n *\n * The values `undefined`, `null`, and `nothing`, will all result in no content\n * (empty string) being rendered.\n *\n * Note, this is unsafe to use with any user-provided input that hasn't been\n * sanitized or escaped, as it may lead to cross-site-scripting\n * vulnerabilities.\n */\nexport const unsafeHTML = directive(UnsafeHTMLDirective);\n", "/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\n\n/*\n * IMPORTANT: For compatibility with tsickle and the Closure JS compiler, all\n * property decorators (but not class decorators) in this file that have\n * an @ExportDecoratedItems annotation must be defined as a regular function,\n * not an arrow function.\n */\n\nimport type {Constructor} from './base.js';\n\n/**\n * Allow for custom element classes with private constructors\n */\ntype CustomElementClass = Omit<typeof HTMLElement, 'new'>;\n\nexport type CustomElementDecorator = {\n // legacy\n (cls: CustomElementClass): void;\n\n // standard\n (\n target: CustomElementClass,\n context: ClassDecoratorContext<Constructor<HTMLElement>>\n ): void;\n};\n\n/**\n * Class decorator factory that defines the decorated class as a custom element.\n *\n * ```js\n * @customElement('my-element')\n * class MyElement extends LitElement {\n * render() {\n * return html``;\n * }\n * }\n * ```\n * @category Decorator\n * @param tagName The tag name of the custom element to define.\n */\nexport const customElement =\n (tagName: string): CustomElementDecorator =>\n (\n classOrTarget: CustomElementClass | Constructor<HTMLElement>,\n context?: ClassDecoratorContext<Constructor<HTMLElement>>\n ) => {\n if (context !== undefined) {\n context.addInitializer(() => {\n customElements.define(\n tagName,\n classOrTarget as CustomElementConstructor\n );\n });\n } else {\n customElements.define(tagName, classOrTarget as CustomElementConstructor);\n }\n };\n", "/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\n\n/*\n * IMPORTANT: For compatibility with tsickle and the Closure JS compiler, all\n * property decorators (but not class decorators) in this file that have\n * an @ExportDecoratedItems annotation must be defined as a regular function,\n * not an arrow function.\n */\n\nimport {\n type PropertyDeclaration,\n type ReactiveElement,\n defaultConverter,\n notEqual,\n} from '../reactive-element.js';\nimport type {Interface} from './base.js';\n\nconst DEV_MODE = true;\n\nlet issueWarning: (code: string, warning: string) => void;\n\nif (DEV_MODE) {\n // Ensure warnings are issued only 1x, even if multiple versions of Lit\n // are loaded.\n globalThis.litIssuedWarnings ??= new Set();\n\n /**\n * Issue a warning if we haven't already, based either on `code` or `warning`.\n * Warnings are disabled automatically only by `warning`; disabling via `code`\n * can be done by users.\n */\n issueWarning = (code: string, warning: string) => {\n warning += ` See https://lit.dev/msg/${code} for more information.`;\n if (\n !globalThis.litIssuedWarnings!.has(warning) &&\n !globalThis.litIssuedWarnings!.has(code)\n ) {\n console.warn(warning);\n globalThis.litIssuedWarnings!.add(warning);\n }\n };\n}\n\n// Overloads for property decorator so that TypeScript can infer the correct\n// return type when a decorator is used as an accessor decorator or a setter\n// decorator.\nexport type PropertyDecorator = {\n // accessor decorator signature\n <C extends Interface<ReactiveElement>, V>(\n target: ClassAccessorDecoratorTarget<C, V>,\n context: ClassAccessorDecoratorContext<C, V>\n ): ClassAccessorDecoratorResult<C, V>;\n\n // setter decorator signature\n <C extends Interface<ReactiveElement>, V>(\n target: (value: V) => void,\n context: ClassSetterDecoratorContext<C, V>\n ): (this: C, value: V) => void;\n\n // legacy decorator signature\n (\n protoOrDescriptor: Object,\n name: PropertyKey,\n descriptor?: PropertyDescriptor\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): any;\n};\n\nconst legacyProperty = (\n options: PropertyDeclaration | undefined,\n proto: Object,\n name: PropertyKey\n) => {\n const hasOwnProperty = proto.hasOwnProperty(name);\n (proto.constructor as typeof ReactiveElement).createProperty(name, options);\n // For accessors (which have a descriptor on the prototype) we need to\n // return a descriptor, otherwise TypeScript overwrites the descriptor we\n // define in createProperty() with the original descriptor. We don't do this\n // for fields, which don't have a descriptor, because this could overwrite\n // descriptor defined by other decorators.\n return hasOwnProperty\n ? Object.getOwnPropertyDescriptor(proto, name)\n : undefined;\n};\n\n// This is duplicated from a similar variable in reactive-element.ts, but\n// actually makes sense to have this default defined with the decorator, so\n// that different decorators could have different defaults.\nconst defaultPropertyDeclaration: PropertyDeclaration = {\n attribute: true,\n type: String,\n converter: defaultConverter,\n reflect: false,\n hasChanged: notEqual,\n};\n\n// Temporary type, until google3 is on TypeScript 5.2\ntype StandardPropertyContext<C, V> = (\n | ClassAccessorDecoratorContext<C, V>\n | ClassSetterDecoratorContext<C, V>\n) & {metadata: object};\n\n/**\n * Wraps a class accessor or setter so that `requestUpdate()` is called with the\n * property name and old value when the accessor is set.\n */\nexport const standardProperty = <C extends Interface<ReactiveElement>, V>(\n options: PropertyDeclaration = defaultPropertyDeclaration,\n target: ClassAccessorDecoratorTarget<C, V> | ((value: V) => void),\n context: StandardPropertyContext<C, V>\n): ClassAccessorDecoratorResult<C, V> | ((this: C, value: V) => void) => {\n const {kind, metadata} = context;\n\n if (DEV_MODE && metadata == null) {\n issueWarning(\n 'missing-class-metadata',\n `The class ${target} is missing decorator metadata. This ` +\n `could mean that you're using a compiler that supports decorators ` +\n `but doesn't support decorator metadata, such as TypeScript 5.1. ` +\n `Please update your compiler.`\n );\n }\n\n // Store the property options\n let properties = globalThis.litPropertyMetadata.get(metadata);\n if (properties === undefined) {\n globalThis.litPropertyMetadata.set(metadata, (properties = new Map()));\n }\n if (kind === 'setter') {\n options = Object.create(options);\n options.wrapped = true;\n }\n properties.set(context.name, options);\n\n if (kind === 'accessor') {\n // Standard decorators cannot dynamically modify the class, so we can't\n // replace a field with accessors. The user must use the new `accessor`\n // keyword instead.\n const {name} = context;\n return {\n set(this: ReactiveElement, v: V) {\n const oldValue = (\n target as ClassAccessorDecoratorTarget<C, V>\n ).get.call(this as unknown as C);\n (target as ClassAccessorDecoratorTarget<C, V>).set.call(\n this as unknown as C,\n v\n );\n this.requestUpdate(name, oldValue, options, true, v);\n },\n init(this: ReactiveElement, v: V): V {\n if (v !== undefined) {\n this._$changeProperty(name, undefined, options, v);\n }\n return v;\n },\n } as unknown as ClassAccessorDecoratorResult<C, V>;\n } else if (kind === 'setter') {\n const {name} = context;\n return function (this: ReactiveElement, value: V) {\n const oldValue = this[name as keyof ReactiveElement];\n (target as (value: V) => void).call(this, value);\n this.requestUpdate(name, oldValue, options, true, value);\n } as unknown as (this: C, value: V) => void;\n }\n throw new Error(`Unsupported decorator location: ${kind}`);\n};\n\n/**\n * A class field or accessor decorator which creates a reactive property that\n * reflects a corresponding attribute value. When a decorated property is set\n * the element will update and render. A {@linkcode PropertyDeclaration} may\n * optionally be supplied to configure property features.\n *\n * This decorator should only be used for public fields. As public fields,\n * properties should be considered as primarily settable by element users,\n * either via attribute or the property itself.\n *\n * Generally, properties that are changed by the element should be private or\n * protected fields and should use the {@linkcode state} decorator.\n *\n * However, sometimes element code does need to set a public property. This\n * should typically only be done in response to user interaction, and an event\n * should be fired informing the user; for example, a checkbox sets its\n * `checked` property when clicked and fires a `changed` event. Mutating public\n * properties should typically not be done for non-primitive (object or array)\n * properties. In other cases when an element needs to manage state, a private\n * property decorated via the {@linkcode state} decorator should be used. When\n * needed, state properties can be initialized via public properties to\n * facilitate complex interactions.\n *\n * ```ts\n * class MyElement {\n * @property({ type: Boolean })\n * clicked = false;\n * }\n * ```\n * @category Decorator\n * @ExportDecoratedItems\n */\nexport function property(options?: PropertyDeclaration): PropertyDecorator {\n return <C extends Interface<ReactiveElement>, V>(\n protoOrTarget:\n | object\n | ClassAccessorDecoratorTarget<C, V>\n | ((value: V) => void),\n nameOrContext:\n | PropertyKey\n | ClassAccessorDecoratorContext<C, V>\n | ClassSetterDecoratorContext<C, V>\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): any => {\n return (\n typeof nameOrContext === 'object'\n ? standardProperty<C, V>(\n options,\n protoOrTarget as\n | ClassAccessorDecoratorTarget<C, V>\n | ((value: V) => void),\n nameOrContext as StandardPropertyContext<C, V>\n )\n : legacyProperty(\n options,\n protoOrTarget as Object,\n nameOrContext as PropertyKey\n )\n ) as PropertyDecorator;\n };\n}\n", "/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\n\n/*\n * IMPORTANT: For compatibility with tsickle and the Closure JS compiler, all\n * property decorators (but not class decorators) in this file that have\n * an @ExportDecoratedItems annotation must be defined as a regular function,\n * not an arrow function.\n */\n\nimport {property} from './property.js';\n\nexport interface StateDeclaration<Type = unknown> {\n /**\n * A function that indicates if a property should be considered changed when\n * it is set. The function should take the `newValue` and `oldValue` and\n * return `true` if an update should be requested.\n */\n hasChanged?(value: Type, oldValue: Type): boolean;\n}\n\n/**\n * @deprecated use StateDeclaration\n */\nexport type InternalPropertyDeclaration<Type = unknown> =\n StateDeclaration<Type>;\n\n/**\n * Declares a private or protected reactive property that still triggers\n * updates to the element when it changes. It does not reflect from the\n * corresponding attribute.\n *\n * Properties declared this way must not be used from HTML or HTML templating\n * systems, they're solely for properties internal to the element. These\n * properties may be renamed by optimization tools like closure compiler.\n * @category Decorator\n */\nexport function state(options?: StateDeclaration) {\n return property({\n ...options,\n // Add both `state` and `attribute` because we found a third party\n // controller that is keying off of PropertyOptions.state to determine\n // whether a field is a private internal property or not.\n state: true,\n attribute: false,\n });\n}\n", "/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\n\n/**\n * Generates a public interface type that removes private and protected fields.\n * This allows accepting otherwise incompatible versions of the type (e.g. from\n * multiple copies of the same package in `node_modules`).\n */\nexport type Interface<T> = {\n [K in keyof T]: T[K];\n};\n\nexport type Constructor<T> = {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n new (...args: any[]): T;\n};\n\n/**\n * Wraps up a few best practices when returning a property descriptor from a\n * decorator.\n *\n * Marks the defined property as configurable, and enumerable, and handles\n * the case where we have a busted Reflect.decorate zombiefill (e.g. in Angular\n * apps).\n *\n * @internal\n */\nexport const desc = (\n obj: object,\n name: PropertyKey | ClassAccessorDecoratorContext<unknown, unknown>,\n descriptor: PropertyDescriptor\n) => {\n // For backwards compatibility, we keep them configurable and enumerable.\n descriptor.configurable = true;\n descriptor.enumerable = true;\n if (\n // We check for Reflect.decorate each time, in case the zombiefill\n // is applied via lazy loading some Angular code.\n (Reflect as typeof Reflect & {decorate?: unknown}).decorate &&\n typeof name !== 'object'\n ) {\n // If we're called as a legacy decorator, and Reflect.decorate is present\n // then we have no guarantees that the returned descriptor will be\n // defined on the class, so we must apply it directly ourselves.\n\n Object.defineProperty(obj, name, descriptor);\n }\n return descriptor;\n};\n", "/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\n\n/*\n * IMPORTANT: For compatibility with tsickle and the Closure JS compiler, all\n * property decorators (but not class decorators) in this file that have\n * an @ExportDecoratedItems annotation must be defined as a regular function,\n * not an arrow function.\n */\nimport type {ReactiveElement} from '../reactive-element.js';\nimport {desc, type Interface} from './base.js';\n\nconst DEV_MODE = true;\n\nlet issueWarning: (code: string, warning: string) => void;\n\nif (DEV_MODE) {\n // Ensure warnings are issued only 1x, even if multiple versions of Lit\n // are loaded.\n globalThis.litIssuedWarnings ??= new Set();\n\n /**\n * Issue a warning if we haven't already, based either on `code` or `warning`.\n * Warnings are disabled automatically only by `warning`; disabling via `code`\n * can be done by users.\n */\n issueWarning = (code: string, warning: string) => {\n warning += code\n ? ` See https://lit.dev/msg/${code} for more information.`\n : '';\n if (\n !globalThis.litIssuedWarnings!.has(warning) &&\n !globalThis.litIssuedWarnings!.has(code)\n ) {\n console.warn(warning);\n globalThis.litIssuedWarnings!.add(warning);\n }\n };\n}\n\nexport type QueryDecorator = {\n // legacy\n (\n proto: Interface<ReactiveElement>,\n name: PropertyKey,\n descriptor?: PropertyDescriptor\n // Note TypeScript requires the return type to be `void|any`\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): void | any;\n\n // standard\n <C extends Interface<ReactiveElement>, V extends Element | null>(\n value: ClassAccessorDecoratorTarget<C, V>,\n context: ClassAccessorDecoratorContext<C, V>\n ): ClassAccessorDecoratorResult<C, V>;\n};\n\n/**\n * A property decorator that converts a class property into a getter that\n * executes a querySelector on the element's renderRoot.\n *\n * @param selector A DOMString containing one or more selectors to match.\n * @param cache An optional boolean which when true performs the DOM query only\n * once and caches the result.\n *\n * See: https://developer.mozilla.org/en-US/docs/Web/API/Document/querySelector\n *\n * ```ts\n * class MyElement {\n * @query('#first')\n * first: HTMLDivElement;\n *\n * render() {\n * return html`\n * <div id=\"first\"></div>\n * <div id=\"second\"></div>\n * `;\n * }\n * }\n * ```\n * @category Decorator\n */\nexport function query(selector: string, cache?: boolean): QueryDecorator {\n return (<C extends Interface<ReactiveElement>, V extends Element | null>(\n protoOrTarget: ClassAccessorDecoratorTarget<C, V>,\n nameOrContext: PropertyKey | ClassAccessorDecoratorContext<C, V>,\n descriptor?: PropertyDescriptor\n ) => {\n const doQuery = (el: Interface<ReactiveElement>): V => {\n const result = (el.renderRoot?.querySelector(selector) ?? null) as V;\n if (DEV_MODE && result === null && cache && !el.hasUpdated) {\n const name =\n typeof nameOrContext === 'object'\n ? nameOrContext.name\n : nameOrContext;\n issueWarning(\n '',\n `@query'd field ${JSON.stringify(String(name))} with the 'cache' ` +\n `flag set for selector '${selector}' has been accessed before ` +\n `the first update and returned null. This is expected if the ` +\n `renderRoot tree has not been provided beforehand (e.g. via ` +\n `Declarative Shadow DOM). Therefore the value hasn't been cached.`\n );\n }\n // TODO: if we want to allow users to assert that the query will never\n // return null, we need a new option and to throw here if the result\n // is null.\n return result;\n };\n if (cache) {\n // Accessors to wrap from either:\n // 1. The decorator target, in the case of standard decorators\n // 2. The property descriptor, in the case of experimental decorators\n // on auto-accessors.\n // 3. Functions that access our own cache-key property on the instance,\n // in the case of experimental decorators on fields.\n const {get, set} =\n typeof nameOrContext === 'object'\n ? protoOrTarget\n : (descriptor ??\n (() => {\n const key = DEV_MODE\n ? Symbol(`${String(nameOrContext)} (@query() cache)`)\n : Symbol();\n type WithCache = ReactiveElement & {\n [key: symbol]: Element | null;\n };\n return {\n get() {\n return (this as WithCache)[key];\n },\n set(v) {\n (this as WithCache)[key] = v;\n },\n };\n })());\n return desc(protoOrTarget, nameOrContext, {\n get(this: ReactiveElement): V {\n let result: V = get!.call(this);\n if (result === undefined) {\n result = doQuery(this);\n if (result !== null || this.hasUpdated) {\n set!.call(this, result);\n }\n }\n return result;\n },\n });\n } else {\n // This object works as the return type for both standard and\n // experimental decorators.\n return desc(protoOrTarget, nameOrContext, {\n get(this: ReactiveElement) {\n return doQuery(this);\n },\n });\n }\n }) as QueryDecorator;\n}\n", "import { css } from 'lit';\n\nexport type Theme = 'dark' | 'light';\n\n/**\n * Base theme - only defines spacing, radius, typography\n * Color variables are inherited from beam-app root\n */\nexport const theme = css`\n :host {\n /* Spacing - same for all themes */\n --space-xs: 4px;\n --space-sm: 8px;\n --space-md: 16px;\n --space-lg: 24px;\n --space-xl: 32px;\n\n /* Radius - same for all themes */\n --radius-sm: 6px;\n --radius-md: 12px;\n --radius-lg: 18px;\n\n /* Typography - same for all themes */\n --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;\n --font-mono: 'JetBrains Mono', monospace;\n }\n\n /* Shared Utility Classes */\n .glass {\n background: var(--bg-glass);\n backdrop-filter: blur(16px);\n -webkit-backdrop-filter: blur(16px);\n border: 1px solid var(--border-glass);\n box-shadow: 0 4px 24px -1px rgba(0, 0, 0, 0.2);\n }\n\n .glass-panel {\n background: var(--bg-glass-strong);\n backdrop-filter: blur(24px);\n -webkit-backdrop-filter: blur(24px);\n border: 1px solid var(--border-glass);\n border-radius: var(--radius-md);\n }\n\n .text-gradient {\n background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));\n -webkit-background-clip: text;\n -webkit-text-fill-color: transparent;\n }\n\n /* Scrollbar */\n ::-webkit-scrollbar {\n width: 8px;\n height: 8px;\n }\n ::-webkit-scrollbar-track {\n background: transparent;\n }\n ::-webkit-scrollbar-thumb {\n background: var(--border-glass);\n border-radius: 4px;\n }\n ::-webkit-scrollbar-thumb:hover {\n background: var(--t-muted);\n opacity: 0.5;\n }\n /* Toggle Switch */\n .switch {\n position: relative;\n display: inline-block;\n width: 44px;\n height: 24px;\n }\n\n .switch input {\n opacity: 0;\n width: 0;\n height: 0;\n }\n\n .slider {\n position: absolute;\n cursor: pointer;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background-color: var(--bg-glass);\n border: 1px solid var(--border-glass);\n transition: 0.4s;\n border-radius: 24px;\n }\n\n .slider:before {\n position: absolute;\n content: '';\n height: 18px;\n width: 18px;\n left: 2px;\n bottom: 2px;\n background-color: var(--t-muted);\n transition: 0.4s;\n border-radius: 50%;\n }\n\n input:checked + .slider {\n background-color: var(--accent-primary);\n border-color: var(--accent-primary);\n }\n\n input:checked + .slider:before {\n transform: translateX(20px);\n background-color: white;\n }\n\n input:focus + .slider {\n box-shadow: 0 0 1px var(--accent-primary);\n }\n`;\n", "import { LitElement, html, css } from 'lit';\nimport { customElement, state } from 'lit/decorators.js';\nimport { theme } from '../styles/theme.js';\n\ninterface ToastAction {\n label: string;\n callback: () => void;\n}\n\ninterface Toast {\n id: string;\n message: string;\n type: 'success' | 'error' | 'info' | 'warning';\n duration: number;\n action?: ToastAction;\n}\n\n@customElement('toast-manager')\nexport class ToastManager extends LitElement {\n static styles = [\n theme,\n css`\n :host {\n position: fixed;\n bottom: var(--space-lg);\n right: var(--space-lg);\n z-index: 9999;\n display: flex;\n flex-direction: column-reverse;\n gap: var(--space-sm);\n pointer-events: none;\n }\n\n .toast {\n display: flex;\n align-items: center;\n gap: var(--space-sm);\n padding: var(--space-sm) var(--space-md);\n border-radius: var(--radius-sm);\n background: var(--bg-glass-strong);\n backdrop-filter: blur(16px);\n -webkit-backdrop-filter: blur(16px);\n border: 1px solid var(--border-glass);\n color: var(--t-primary);\n font-size: 0.9rem;\n pointer-events: auto;\n animation: slideIn 0.3s ease-out;\n max-width: 350px;\n box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);\n }\n\n .toast.exiting {\n animation: slideOut 0.3s ease-in forwards;\n }\n\n @keyframes slideIn {\n from {\n transform: translateX(100%);\n opacity: 0;\n }\n to {\n transform: translateX(0);\n opacity: 1;\n }\n }\n\n @keyframes slideOut {\n from {\n transform: translateX(0);\n opacity: 1;\n }\n to {\n transform: translateX(100%);\n opacity: 0;\n }\n }\n\n .icon {\n flex-shrink: 0;\n width: 18px;\n height: 18px;\n }\n\n .toast.success .icon {\n color: #4ade80;\n }\n .toast.error .icon {\n color: #f87171;\n }\n .toast.info .icon {\n color: var(--accent-secondary);\n }\n .toast.warning .icon {\n color: #fbbf24;\n }\n\n .toast.success {\n border-left: 3px solid #4ade80;\n }\n .toast.error {\n border-left: 3px solid #f87171;\n }\n .toast.info {\n border-left: 3px solid var(--accent-secondary);\n }\n .toast.warning {\n border-left: 3px solid #fbbf24;\n }\n\n .message {\n flex: 1;\n line-height: 1.4;\n }\n\n .close {\n background: none;\n border: none;\n color: var(--t-muted);\n cursor: pointer;\n padding: 4px;\n border-radius: var(--radius-sm);\n transition: all 0.2s;\n }\n\n .close:hover {\n color: var(--t-primary);\n background: hsla(220, 10%, 80%, 0.1);\n }\n\n .toast-action {\n background: none;\n border: 1px solid var(--border-glass);\n color: var(--accent-secondary);\n cursor: pointer;\n padding: 3px 10px;\n border-radius: 6px;\n font-size: 0.8rem;\n font-weight: 500;\n transition: all 0.2s;\n white-space: nowrap;\n flex-shrink: 0;\n }\n\n .toast-action:hover {\n background: var(--bg-glass);\n border-color: var(--accent-secondary);\n }\n `,\n ];\n\n @state() private _toasts: Toast[] = [];\n private _exitingToasts = new Set<string>();\n\n static instance: ToastManager | null = null;\n\n connectedCallback() {\n super.connectedCallback();\n ToastManager.instance = this;\n }\n\n disconnectedCallback() {\n super.disconnectedCallback();\n if (ToastManager.instance === this) {\n ToastManager.instance = null;\n }\n }\n\n static show(\n message: string,\n type: Toast['type'] = 'info',\n duration = 3000,\n action?: ToastAction\n ) {\n if (ToastManager.instance) {\n ToastManager.instance.addToast(message, type, duration, action);\n }\n }\n\n addToast(message: string, type: Toast['type'] = 'info', duration = 3000, action?: ToastAction) {\n const id = `toast-${Date.now()}-${Math.random().toString(36).substr(2, 9)}`;\n const toast: Toast = { id, message, type, duration, action };\n\n this._toasts = [...this._toasts, toast];\n\n if (duration > 0) {\n setTimeout(() => this._dismissToast(id), duration);\n }\n }\n\n private _dismissToast(id: string) {\n this._exitingToasts.add(id);\n this.requestUpdate();\n\n setTimeout(() => {\n this._exitingToasts.delete(id);\n this._toasts = this._toasts.filter((t) => t.id !== id);\n }, 300);\n }\n\n render() {\n return html`\n <div role=\"status\" aria-live=\"polite\" aria-atomic=\"false\">\n ${this._toasts.map(\n (toast) => html`\n <div\n class=\"toast ${toast.type} ${this._exitingToasts.has(toast.id) ? 'exiting' : ''}\"\n role=\"alert\"\n aria-live=\"${toast.type === 'error' ? 'assertive' : 'polite'}\"\n >\n ${this._renderIcon(toast.type)}\n <span class=\"message\">${toast.message}</span>\n ${toast.action\n ? html`<button\n class=\"toast-action\"\n @click=${() => {\n toast.action!.callback();\n this._dismissToast(toast.id);\n }}\n >\n ${toast.action.label}\n </button>`\n : ''}\n <button\n class=\"close\"\n @click=${() => this._dismissToast(toast.id)}\n aria-label=\"Dismiss notification\"\n >\n <svg\n width=\"14\"\n height=\"14\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n aria-hidden=\"true\"\n >\n <path d=\"M18 6L6 18M6 6l12 12\" />\n </svg>\n </button>\n </div>\n `\n )}\n </div>\n `;\n }\n\n private _renderIcon(type: Toast['type']) {\n const icons: Record<Toast['type'], string> = {\n success: '<path d=\"M20 6L9 17l-5-5\"/>',\n error: '<circle cx=\"12\" cy=\"12\" r=\"10\"/><path d=\"M15 9l-6 6M9 9l6 6\"/>',\n info: '<circle cx=\"12\" cy=\"12\" r=\"10\"/><path d=\"M12 16v-4M12 8h.01\"/>',\n warning:\n '<path d=\"M10.29 3.86L1.82 18a2 2 0 001.71 3h16.94a2 2 0 001.71-3L13.71 3.86a2 2 0 00-3.42 0zM12 9v4M12 17h.01\"/>',\n };\n\n return html`\n <svg\n class=\"icon\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n >\n ${this._unsafeSvg(icons[type])}\n </svg>\n `;\n }\n\n private _unsafeSvg(svg: string) {\n const template = document.createElement('template');\n template.innerHTML = svg;\n return html`${template.content}`;\n }\n}\n\nexport function showToast(\n message: string,\n type: Toast['type'] = 'info',\n duration = 3000,\n action?: { label: string; callback: () => void }\n) {\n ToastManager.show(message, type, duration, action);\n}\n", "/**\n * Photon Design System - Design Tokens\n *\n * Based on:\n * - Material Design 3 token structure (https://m3.material.io/foundations/design-tokens)\n * - Apple HIG 8pt grid system (https://developer.apple.com/design/human-interface-guidelines/layout)\n *\n * This is the foundation for all Photon UI - both BEAM interface and auto-generated UIs.\n */\n\n// =============================================================================\n// SPACING - 8pt Grid System (Apple HIG)\n// =============================================================================\n\nexport const spacing = {\n // Base unit: 4px (for fine adjustments)\n '0': '0',\n '1': '4px', // xs - minimal spacing\n '2': '8px', // sm - tight spacing\n '3': '12px', // md - default spacing\n '4': '16px', // lg - comfortable spacing\n '5': '20px', // xl - generous spacing\n '6': '24px', // 2xl - section spacing\n '8': '32px', // 3xl - large section spacing\n '10': '40px', // 4xl - hero spacing\n '12': '48px', // 5xl - page spacing\n} as const;\n\n// Semantic spacing aliases\nexport const spacingAliases = {\n none: spacing['0'],\n tight: spacing['1'],\n compact: spacing['2'],\n default: spacing['3'],\n comfortable: spacing['4'],\n spacious: spacing['6'],\n section: spacing['8'],\n} as const;\n\n// =============================================================================\n// TYPOGRAPHY - Material Design 3 Type Scale\n// =============================================================================\n\nexport const fontFamily = {\n sans: '-apple-system, BlinkMacSystemFont, \"SF Pro Display\", \"Segoe UI\", Roboto, Oxygen, Ubuntu, sans-serif',\n mono: '\"SF Mono\", \"Fira Code\", \"Fira Mono\", Menlo, Monaco, Consolas, monospace',\n} as const;\n\nexport const fontSize = {\n // Display - for hero/large numbers\n 'display-lg': '57px',\n 'display-md': '45px',\n 'display-sm': '36px',\n\n // Headline - for section headers\n 'headline-lg': '32px',\n 'headline-md': '28px',\n 'headline-sm': '24px',\n\n // Title - for card titles, list item titles\n 'title-lg': '22px',\n 'title-md': '16px',\n 'title-sm': '14px',\n\n // Body - for content\n 'body-lg': '16px',\n 'body-md': '14px',\n 'body-sm': '12px',\n\n // Label - for UI labels, buttons, badges\n 'label-lg': '14px',\n 'label-md': '12px',\n 'label-sm': '11px',\n} as const;\n\nexport const lineHeight = {\n 'display-lg': '64px',\n 'display-md': '52px',\n 'display-sm': '44px',\n 'headline-lg': '40px',\n 'headline-md': '36px',\n 'headline-sm': '32px',\n 'title-lg': '28px',\n 'title-md': '24px',\n 'title-sm': '20px',\n 'body-lg': '24px',\n 'body-md': '20px',\n 'body-sm': '16px',\n 'label-lg': '20px',\n 'label-md': '16px',\n 'label-sm': '16px',\n} as const;\n\nexport const fontWeight = {\n regular: '400',\n medium: '500',\n semibold: '600',\n bold: '700',\n} as const;\n\n// =============================================================================\n// COLORS - Semantic Color System\n// =============================================================================\n\n// Reference colors (raw values)\nconst colorPalette = {\n // Neutrals (dark theme optimized)\n neutral: {\n 0: '#000000',\n 5: '#0d0d0d',\n 10: '#1a1a1a',\n 15: '#262626',\n 20: '#333333',\n 30: '#4d4d4d',\n 40: '#666666',\n 50: '#808080',\n 60: '#999999',\n 70: '#b3b3b3',\n 80: '#cccccc',\n 90: '#e6e6e6',\n 95: '#f2f2f2',\n 100: '#ffffff',\n },\n\n // Primary (blue - trust, action)\n primary: {\n 10: '#001d36',\n 20: '#003258',\n 30: '#00497d',\n 40: '#0061a4',\n 50: '#2c7bc9',\n 60: '#5094e0',\n 70: '#79aef0',\n 80: '#a4c9ff',\n 90: '#d1e4ff',\n 95: '#e9f1ff',\n },\n\n // Success (green)\n success: {\n 10: '#002106',\n 20: '#003910',\n 30: '#00531a',\n 40: '#006e25',\n 50: '#008a30',\n 60: '#1fa940',\n 70: '#4cc760',\n 80: '#73e380',\n 90: '#98ffa0',\n 95: '#c8ffc8',\n },\n\n // Warning (amber)\n warning: {\n 10: '#261900',\n 20: '#402d00',\n 30: '#5c4300',\n 40: '#7a5900',\n 50: '#996f00',\n 60: '#b88600',\n 70: '#d89e00',\n 80: '#f9b800',\n 90: '#ffdf9e',\n 95: '#fff0d6',\n },\n\n // Error (red)\n error: {\n 10: '#410002',\n 20: '#690005',\n 30: '#93000a',\n 40: '#ba1a1a',\n 50: '#de3730',\n 60: '#ff5449',\n 70: '#ff897d',\n 80: '#ffb4ab',\n 90: '#ffdad6',\n 95: '#ffedea',\n },\n} as const;\n\n// System colors - Dark Theme (default)\nexport const colorsDark = {\n // Surfaces\n surface: colorPalette.neutral[5],\n surfaceContainer: colorPalette.neutral[10],\n surfaceContainerHigh: colorPalette.neutral[15],\n surfaceContainerHighest: colorPalette.neutral[20],\n surfaceBright: colorPalette.neutral[95],\n\n // Text on surfaces\n onSurface: colorPalette.neutral[90],\n onSurfaceVariant: colorPalette.neutral[70],\n onSurfaceMuted: colorPalette.neutral[50],\n\n // Primary\n primary: colorPalette.primary[70],\n primaryContainer: colorPalette.primary[30],\n onPrimary: colorPalette.primary[10],\n onPrimaryContainer: colorPalette.primary[90],\n\n // Success\n success: colorPalette.success[70],\n successContainer: colorPalette.success[20],\n onSuccess: colorPalette.success[10],\n onSuccessContainer: colorPalette.success[90],\n\n // Warning\n warning: colorPalette.warning[70],\n warningContainer: colorPalette.warning[20],\n onWarning: colorPalette.warning[10],\n onWarningContainer: colorPalette.warning[90],\n\n // Error\n error: colorPalette.error[70],\n errorContainer: colorPalette.error[20],\n onError: colorPalette.error[10],\n onErrorContainer: colorPalette.error[90],\n\n // Outline\n outline: colorPalette.neutral[30],\n outlineVariant: colorPalette.neutral[20],\n\n // Scrim (overlay)\n scrim: 'rgba(0, 0, 0, 0.5)',\n} as const;\n\n// System colors - Light Theme\nexport const colorsLight = {\n // Surfaces (inverted - light backgrounds)\n surface: colorPalette.neutral[100], // white\n surfaceContainer: colorPalette.neutral[95],\n surfaceContainerHigh: colorPalette.neutral[90],\n surfaceContainerHighest: colorPalette.neutral[80],\n surfaceBright: colorPalette.neutral[100],\n\n // Text on surfaces (dark text on light)\n onSurface: colorPalette.neutral[10],\n onSurfaceVariant: colorPalette.neutral[30],\n onSurfaceMuted: colorPalette.neutral[50],\n\n // Primary (darker for light theme)\n primary: colorPalette.primary[40],\n primaryContainer: colorPalette.primary[90],\n onPrimary: colorPalette.neutral[100], // white text on primary\n onPrimaryContainer: colorPalette.primary[10],\n\n // Success\n success: colorPalette.success[40],\n successContainer: colorPalette.success[90],\n onSuccess: colorPalette.neutral[100], // white text\n onSuccessContainer: colorPalette.success[10],\n\n // Warning\n warning: colorPalette.warning[40],\n warningContainer: colorPalette.warning[90],\n onWarning: colorPalette.neutral[100], // white text\n onWarningContainer: colorPalette.warning[10],\n\n // Error\n error: colorPalette.error[40],\n errorContainer: colorPalette.error[90],\n onError: colorPalette.neutral[100], // white text\n onErrorContainer: colorPalette.error[10],\n\n // Outline (darker for light theme)\n outline: colorPalette.neutral[50],\n outlineVariant: colorPalette.neutral[80],\n\n // Scrim (overlay)\n scrim: 'rgba(0, 0, 0, 0.3)' as const,\n};\n\n// Default export (dark theme for backwards compatibility)\nexport const colors = colorsDark;\n\n// Theme type\nexport type ThemeMode = 'light' | 'dark' | 'system';\n\n// Theme colors type (union of both)\nexport type ThemeColors = typeof colorsDark | typeof colorsLight;\n\n// Get colors for a specific theme\nexport function getThemeColors(theme: 'light' | 'dark'): ThemeColors {\n return theme === 'light' ? colorsLight : colorsDark;\n}\n\n// =============================================================================\n// ELEVATION - Material Design 3 Shadows\n// =============================================================================\n\nexport const elevation = {\n '0': 'none',\n '1': '0px 1px 2px 0px rgba(0, 0, 0, 0.30), 0px 1px 3px 1px rgba(0, 0, 0, 0.15)',\n '2': '0px 1px 2px 0px rgba(0, 0, 0, 0.30), 0px 2px 6px 2px rgba(0, 0, 0, 0.15)',\n '3': '0px 1px 3px 0px rgba(0, 0, 0, 0.30), 0px 4px 8px 3px rgba(0, 0, 0, 0.15)',\n '4': '0px 2px 3px 0px rgba(0, 0, 0, 0.30), 0px 6px 10px 4px rgba(0, 0, 0, 0.15)',\n '5': '0px 4px 4px 0px rgba(0, 0, 0, 0.30), 0px 8px 12px 6px rgba(0, 0, 0, 0.15)',\n} as const;\n\n// =============================================================================\n// BORDER RADIUS - Apple HIG inspired\n// =============================================================================\n\nexport const radius = {\n none: '0',\n sm: '6px', // Small elements (chips, badges)\n md: '10px', // Cards, inputs (iOS default)\n lg: '14px', // Large cards\n xl: '20px', // Modal, sheet\n full: '9999px', // Pills, circles\n} as const;\n\n// =============================================================================\n// MOTION - Transitions\n// =============================================================================\n\nexport const duration = {\n instant: '0ms',\n fast: '100ms',\n normal: '200ms',\n slow: '300ms',\n slower: '500ms',\n} as const;\n\nexport const easing = {\n standard: 'cubic-bezier(0.2, 0, 0, 1)',\n standardDecelerate: 'cubic-bezier(0, 0, 0, 1)',\n standardAccelerate: 'cubic-bezier(0.3, 0, 1, 1)',\n emphasized: 'cubic-bezier(0.2, 0, 0, 1)',\n emphasizedDecelerate: 'cubic-bezier(0.05, 0.7, 0.1, 1)',\n emphasizedAccelerate: 'cubic-bezier(0.3, 0, 0.8, 0.15)',\n} as const;\n\n// =============================================================================\n// INTERACTION - Touch targets (Apple HIG: 44pt minimum)\n// =============================================================================\n\nexport const touchTarget = {\n min: '44px',\n comfortable: '48px',\n spacious: '56px',\n} as const;\n\n// =============================================================================\n// Z-INDEX - Layering system\n// =============================================================================\n\nexport const zIndex = {\n base: '0',\n dropdown: '100',\n sticky: '200',\n modal: '300',\n popover: '400',\n toast: '500',\n} as const;\n\n// =============================================================================\n// CSS CUSTOM PROPERTIES GENERATOR\n// =============================================================================\n\n/**\n * Generate color CSS variables for a specific theme\n */\nfunction generateColorVars(themeColors: ThemeColors): string {\n return `\n /* Colors - Surfaces */\n --color-surface: ${themeColors.surface};\n --color-surface-container: ${themeColors.surfaceContainer};\n --color-surface-container-high: ${themeColors.surfaceContainerHigh};\n --color-surface-container-highest: ${themeColors.surfaceContainerHighest};\n --color-surface-bright: ${themeColors.surfaceBright};\n\n /* Colors - Text */\n --color-on-surface: ${themeColors.onSurface};\n --color-on-surface-variant: ${themeColors.onSurfaceVariant};\n --color-on-surface-muted: ${themeColors.onSurfaceMuted};\n\n /* Colors - Primary */\n --color-primary: ${themeColors.primary};\n --color-primary-container: ${themeColors.primaryContainer};\n --color-on-primary: ${themeColors.onPrimary};\n --color-on-primary-container: ${themeColors.onPrimaryContainer};\n\n /* Colors - Success */\n --color-success: ${themeColors.success};\n --color-success-container: ${themeColors.successContainer};\n --color-on-success: ${themeColors.onSuccess};\n --color-on-success-container: ${themeColors.onSuccessContainer};\n\n /* Colors - Warning */\n --color-warning: ${themeColors.warning};\n --color-warning-container: ${themeColors.warningContainer};\n --color-on-warning: ${themeColors.onWarning};\n --color-on-warning-container: ${themeColors.onWarningContainer};\n\n /* Colors - Error */\n --color-error: ${themeColors.error};\n --color-error-container: ${themeColors.errorContainer};\n --color-on-error: ${themeColors.onError};\n --color-on-error-container: ${themeColors.onErrorContainer};\n\n /* Colors - Outline */\n --color-outline: ${themeColors.outline};\n --color-outline-variant: ${themeColors.outlineVariant};\n\n /* Colors - Scrim */\n --color-scrim: ${themeColors.scrim};`;\n}\n\nexport function generateTokensCSS(): string {\n return `\n/* ==========================================================================\n Photon Design System - Design Tokens\n Based on Material Design 3 + Apple HIG\n Supports: dark (default), light, system preference\n ========================================================================== */\n\n:root {\n /* Spacing (8pt grid) */\n --space-0: ${spacing['0']};\n --space-1: ${spacing['1']};\n --space-2: ${spacing['2']};\n --space-3: ${spacing['3']};\n --space-4: ${spacing['4']};\n --space-5: ${spacing['5']};\n --space-6: ${spacing['6']};\n --space-8: ${spacing['8']};\n --space-10: ${spacing['10']};\n --space-12: ${spacing['12']};\n\n /* Typography - Font Family */\n --font-sans: ${fontFamily.sans};\n --font-mono: ${fontFamily.mono};\n\n /* Typography - Font Size */\n --text-display-lg: ${fontSize['display-lg']};\n --text-display-md: ${fontSize['display-md']};\n --text-display-sm: ${fontSize['display-sm']};\n --text-headline-lg: ${fontSize['headline-lg']};\n --text-headline-md: ${fontSize['headline-md']};\n --text-headline-sm: ${fontSize['headline-sm']};\n --text-title-lg: ${fontSize['title-lg']};\n --text-title-md: ${fontSize['title-md']};\n --text-title-sm: ${fontSize['title-sm']};\n --text-body-lg: ${fontSize['body-lg']};\n --text-body-md: ${fontSize['body-md']};\n --text-body-sm: ${fontSize['body-sm']};\n --text-label-lg: ${fontSize['label-lg']};\n --text-label-md: ${fontSize['label-md']};\n --text-label-sm: ${fontSize['label-sm']};\n\n /* Typography - Line Height */\n --leading-display-lg: ${lineHeight['display-lg']};\n --leading-display-md: ${lineHeight['display-md']};\n --leading-display-sm: ${lineHeight['display-sm']};\n --leading-headline-lg: ${lineHeight['headline-lg']};\n --leading-headline-md: ${lineHeight['headline-md']};\n --leading-headline-sm: ${lineHeight['headline-sm']};\n --leading-title-lg: ${lineHeight['title-lg']};\n --leading-title-md: ${lineHeight['title-md']};\n --leading-title-sm: ${lineHeight['title-sm']};\n --leading-body-lg: ${lineHeight['body-lg']};\n --leading-body-md: ${lineHeight['body-md']};\n --leading-body-sm: ${lineHeight['body-sm']};\n --leading-label-lg: ${lineHeight['label-lg']};\n --leading-label-md: ${lineHeight['label-md']};\n --leading-label-sm: ${lineHeight['label-sm']};\n\n /* Typography - Font Weight */\n --weight-regular: ${fontWeight.regular};\n --weight-medium: ${fontWeight.medium};\n --weight-semibold: ${fontWeight.semibold};\n --weight-bold: ${fontWeight.bold};\n\n /* Default: Dark Theme Colors */\n ${generateColorVars(colorsDark)}\n\n /* Elevation */\n --elevation-0: ${elevation['0']};\n --elevation-1: ${elevation['1']};\n --elevation-2: ${elevation['2']};\n --elevation-3: ${elevation['3']};\n --elevation-4: ${elevation['4']};\n --elevation-5: ${elevation['5']};\n\n /* Border Radius */\n --radius-none: ${radius.none};\n --radius-sm: ${radius.sm};\n --radius-md: ${radius.md};\n --radius-lg: ${radius.lg};\n --radius-xl: ${radius.xl};\n --radius-full: ${radius.full};\n\n /* Motion */\n --duration-instant: ${duration.instant};\n --duration-fast: ${duration.fast};\n --duration-normal: ${duration.normal};\n --duration-slow: ${duration.slow};\n --duration-slower: ${duration.slower};\n\n --ease-standard: ${easing.standard};\n --ease-decelerate: ${easing.standardDecelerate};\n --ease-accelerate: ${easing.standardAccelerate};\n --ease-emphasized: ${easing.emphasized};\n\n /* Touch Targets */\n --touch-min: ${touchTarget.min};\n --touch-comfortable: ${touchTarget.comfortable};\n --touch-spacious: ${touchTarget.spacious};\n\n /* Z-Index */\n --z-base: ${zIndex.base};\n --z-dropdown: ${zIndex.dropdown};\n --z-sticky: ${zIndex.sticky};\n --z-modal: ${zIndex.modal};\n --z-popover: ${zIndex.popover};\n --z-toast: ${zIndex.toast};\n}\n\n/* Light Theme Override */\n[data-theme=\"light\"],\n.light {\n ${generateColorVars(colorsLight)}\n}\n\n/* System Preference: Light Mode */\n@media (prefers-color-scheme: light) {\n [data-theme=\"system\"] {\n ${generateColorVars(colorsLight)}\n }\n}\n`;\n}\n\n// =============================================================================\n// THEME TOKENS FOR MCP APPS / PLATFORM BRIDGES\n// =============================================================================\n\n/**\n * Get theme tokens as a flat object for MCP Apps ui/initialize\n * Compatible with OpenAI Apps SDK and MCP Apps Extension (SEP-1865)\n */\nexport function getThemeTokens(theme: 'light' | 'dark'): Record<string, string> {\n const themeColors = theme === 'light' ? colorsLight : colorsDark;\n\n return {\n // \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n // DESIGN SYSTEM TOKENS (Material Design 3 naming)\n // \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\n // Colors\n '--color-surface': themeColors.surface,\n '--color-surface-container': themeColors.surfaceContainer,\n '--color-surface-container-high': themeColors.surfaceContainerHigh,\n '--color-surface-container-highest': themeColors.surfaceContainerHighest,\n '--color-surface-bright': themeColors.surfaceBright,\n '--color-on-surface': themeColors.onSurface,\n '--color-on-surface-variant': themeColors.onSurfaceVariant,\n '--color-on-surface-muted': themeColors.onSurfaceMuted,\n '--color-primary': themeColors.primary,\n '--color-primary-container': themeColors.primaryContainer,\n '--color-on-primary': themeColors.onPrimary,\n '--color-on-primary-container': themeColors.onPrimaryContainer,\n '--color-success': themeColors.success,\n '--color-success-container': themeColors.successContainer,\n '--color-on-success': themeColors.onSuccess,\n '--color-on-success-container': themeColors.onSuccessContainer,\n '--color-warning': themeColors.warning,\n '--color-warning-container': themeColors.warningContainer,\n '--color-on-warning': themeColors.onWarning,\n '--color-on-warning-container': themeColors.onWarningContainer,\n '--color-error': themeColors.error,\n '--color-error-container': themeColors.errorContainer,\n '--color-on-error': themeColors.onError,\n '--color-on-error-container': themeColors.onErrorContainer,\n '--color-outline': themeColors.outline,\n '--color-outline-variant': themeColors.outlineVariant,\n '--color-scrim': themeColors.scrim,\n\n // Spacing\n '--space-0': spacing['0'],\n '--space-1': spacing['1'],\n '--space-2': spacing['2'],\n '--space-3': spacing['3'],\n '--space-4': spacing['4'],\n '--space-6': spacing['6'],\n '--space-8': spacing['8'],\n\n // Typography\n '--font-sans': fontFamily.sans,\n '--font-mono': fontFamily.mono,\n '--text-body-md': fontSize['body-md'],\n '--text-body-sm': fontSize['body-sm'],\n '--text-title-md': fontSize['title-md'],\n '--text-label-md': fontSize['label-md'],\n\n // Border Radius\n '--radius-sm': radius.sm,\n '--radius-md': radius.md,\n '--radius-lg': radius.lg,\n '--radius-full': radius.full,\n\n // \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n // COMMON ALIASES - For compatibility with various app conventions\n // Apps use different naming conventions; these aliases ensure apps work\n // regardless of whether they use --bg, --background, --bg-primary, etc.\n // \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\n // Background aliases (apps use: --bg, --background, --bg-primary, --bg-secondary)\n '--bg': themeColors.surface,\n '--background': themeColors.surface,\n '--bg-primary': themeColors.surface,\n '--bg-secondary': themeColors.surfaceContainer,\n '--bg-tertiary': themeColors.surfaceContainerHigh,\n '--bg-card': themeColors.surfaceContainer,\n '--card': themeColors.surfaceContainer,\n '--card-background': themeColors.surfaceContainer,\n\n // Text/foreground aliases (apps use: --text, --foreground, --text-primary, --text-muted)\n '--text': themeColors.onSurface,\n '--foreground': themeColors.onSurface,\n '--text-primary': themeColors.onSurface,\n '--text-secondary': themeColors.onSurfaceVariant,\n '--text-muted': themeColors.onSurfaceMuted,\n '--muted': themeColors.onSurfaceMuted,\n '--muted-foreground': themeColors.onSurfaceMuted,\n\n // Border aliases (apps use: --border, --border-color)\n '--border': themeColors.outline,\n '--border-color': themeColors.outline,\n '--border-muted': themeColors.outlineVariant,\n\n // Accent/primary aliases (apps use: --accent, --primary, --accent-color)\n '--accent': themeColors.primary,\n '--primary': themeColors.primary,\n '--accent-color': themeColors.primary,\n '--accent-foreground': themeColors.onPrimary,\n '--accent-hover': themeColors.primaryContainer,\n\n // Status colors (common naming)\n '--success': themeColors.success,\n '--warning': themeColors.warning,\n '--error': themeColors.error,\n '--danger': themeColors.error,\n\n // Input/form aliases\n '--input': themeColors.surfaceContainerHigh,\n '--input-border': themeColors.outline,\n '--ring': themeColors.primary,\n\n // \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n // MCP APPS STANDARD CSS VARIABLES (2026-01-26 spec)\n // Maps standard names to closest Photon semantic tokens.\n // Both Photon-native and standard MCP Apps names are emitted.\n // \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\n // --- Background Colors ---\n '--color-background-primary': themeColors.surface,\n '--color-background-secondary': themeColors.surfaceContainer,\n '--color-background-tertiary': themeColors.surfaceContainerHigh,\n '--color-background-inverse': themeColors.surfaceBright,\n '--color-background-brand': themeColors.primary,\n '--color-background-info': themeColors.primaryContainer,\n '--color-background-danger': themeColors.errorContainer,\n '--color-background-success': themeColors.successContainer,\n '--color-background-warning': themeColors.warningContainer,\n '--color-background-ghost': 'transparent',\n '--color-background-disabled': themeColors.surfaceContainerHigh,\n\n // --- Text Colors ---\n '--color-text-primary': themeColors.onSurface,\n '--color-text-secondary': themeColors.onSurfaceVariant,\n '--color-text-tertiary': themeColors.onSurfaceMuted,\n '--color-text-inverse': themeColors.onPrimary,\n '--color-text-brand': themeColors.primary,\n '--color-text-info': themeColors.primary,\n '--color-text-danger': themeColors.error,\n '--color-text-success': themeColors.success,\n '--color-text-warning': themeColors.warning,\n '--color-text-ghost': themeColors.onSurfaceVariant,\n '--color-text-disabled': themeColors.onSurfaceMuted,\n '--color-text-link': themeColors.primary,\n '--color-text-on-brand': themeColors.onPrimary,\n '--color-text-on-info': themeColors.onPrimaryContainer,\n '--color-text-on-danger': themeColors.onErrorContainer,\n '--color-text-on-success': themeColors.onSuccessContainer,\n '--color-text-on-warning': themeColors.onWarningContainer,\n\n // --- Border Colors ---\n '--color-border-primary': themeColors.outline,\n '--color-border-secondary': themeColors.outlineVariant,\n '--color-border-brand': themeColors.primary,\n '--color-border-info': themeColors.primary,\n '--color-border-danger': themeColors.error,\n '--color-border-success': themeColors.success,\n '--color-border-warning': themeColors.warning,\n '--color-border-disabled': themeColors.outlineVariant,\n '--color-border-focus': themeColors.primary,\n\n // --- Border Colors (additional spec variants) ---\n '--color-border-tertiary': themeColors.outlineVariant,\n '--color-border-inverse': themeColors.onSurface,\n '--color-border-ghost': themeColors.outlineVariant,\n\n // --- Ring (focus) ---\n '--color-ring-primary': themeColors.primary,\n '--color-ring-secondary': themeColors.outlineVariant,\n '--color-ring-inverse': themeColors.onSurface,\n '--color-ring-brand': themeColors.primary,\n '--color-ring-info': themeColors.primary,\n '--color-ring-danger': themeColors.error,\n '--color-ring-success': themeColors.success,\n '--color-ring-warning': themeColors.warning,\n\n // --- Icon Colors ---\n '--color-icon-primary': themeColors.onSurface,\n '--color-icon-secondary': themeColors.onSurfaceVariant,\n '--color-icon-brand': themeColors.primary,\n '--color-icon-info': themeColors.primary,\n '--color-icon-danger': themeColors.error,\n '--color-icon-success': themeColors.success,\n '--color-icon-warning': themeColors.warning,\n\n // --- Font Weights ---\n '--font-weight-normal': fontWeight.regular,\n '--font-weight-medium': fontWeight.medium,\n '--font-weight-semibold': fontWeight.semibold,\n '--font-weight-bold': fontWeight.bold,\n\n // --- Font Text Sizes ---\n '--font-text-xs-size': fontSize['label-sm'],\n '--font-text-xs-line-height': lineHeight['label-sm'],\n '--font-text-sm-size': fontSize['body-sm'],\n '--font-text-sm-line-height': lineHeight['body-sm'],\n '--font-text-md-size': fontSize['body-md'],\n '--font-text-md-line-height': lineHeight['body-md'],\n '--font-text-lg-size': fontSize['body-lg'],\n '--font-text-lg-line-height': lineHeight['body-lg'],\n\n // --- Font Heading Sizes ---\n '--font-heading-xs-size': fontSize['title-sm'],\n '--font-heading-xs-line-height': lineHeight['title-sm'],\n '--font-heading-sm-size': fontSize['title-md'],\n '--font-heading-sm-line-height': lineHeight['title-md'],\n '--font-heading-md-size': fontSize['title-lg'],\n '--font-heading-md-line-height': lineHeight['title-lg'],\n '--font-heading-lg-size': fontSize['headline-sm'],\n '--font-heading-lg-line-height': lineHeight['headline-sm'],\n '--font-heading-xl-size': fontSize['headline-md'],\n '--font-heading-xl-line-height': lineHeight['headline-md'],\n '--font-heading-2xl-size': fontSize['headline-lg'],\n '--font-heading-2xl-line-height': lineHeight['headline-lg'],\n '--font-heading-3xl-size': fontSize['display-sm'],\n '--font-heading-3xl-line-height': lineHeight['display-sm'],\n\n // --- Border Radius ---\n '--border-radius-xs': '4px',\n '--border-radius-sm': radius.sm,\n '--border-radius-md': radius.md,\n '--border-radius-lg': radius.lg,\n '--border-radius-xl': radius.xl,\n '--border-radius-full': radius.full,\n\n // --- Shadows ---\n '--shadow-hairline': `0 0 0 1px ${themeColors.outlineVariant}`,\n '--shadow-sm': elevation['1'],\n '--shadow-md': elevation['2'],\n '--shadow-lg': elevation['3'],\n\n // --- Border Width ---\n '--border-width-regular': '1px',\n '--border-width-thick': '2px',\n };\n}\n", "/**\n * MCP Client Service for Beam UI\n *\n * Pure Streamable HTTP transport implementation (2025-03-26 spec).\n * Uses POST for requests and SSE for server notifications.\n * No WebSocket - acts like a standard external MCP client.\n */\n\ntype JSONRPCMessage = {\n jsonrpc: '2.0';\n id?: string | number;\n method?: string;\n params?: Record<string, unknown>;\n result?: unknown;\n error?: { code: number; message: string; data?: unknown };\n};\n\ninterface ProgressNotification {\n progressToken: string | number;\n progress: number;\n total?: number;\n message?: string;\n}\n\ninterface MCPTool {\n name: string;\n description?: string;\n inputSchema: Record<string, unknown>;\n 'x-photon-id'?: string;\n 'x-icon'?: string;\n 'x-autorun'?: boolean;\n 'x-output-format'?: string;\n 'x-layout-hints'?: Record<string, string>;\n 'x-button-label'?: string;\n _meta?: { ui?: { resourceUri?: string; visibility?: string[] } };\n}\n\ninterface MCPResource {\n uri: string;\n name: string;\n mimeType?: string;\n description?: string;\n}\n\ninterface MCPResourceContent {\n uri: string;\n mimeType?: string;\n text?: string;\n blob?: string; // base64 encoded\n}\n\n/**\n * Configuration schema for unconfigured photons (SEP-1596 inspired)\n * Uses OpenAPI-compliant format values where possible\n */\ninterface ConfigurationSchema {\n [photonName: string]: {\n title?: string;\n description?: string;\n type: 'object';\n properties: Record<\n string,\n {\n type: string;\n description?: string;\n default?: any;\n format?: string; // 'password', 'path', 'email', 'uri', etc.\n writeOnly?: boolean; // OpenAPI standard for sensitive fields\n 'x-env-var'?: string; // Custom: maps to environment variable\n }\n >;\n required?: string[];\n 'x-error-message'?: string;\n };\n}\n\ntype MCPEventType =\n | 'connect'\n | 'disconnect'\n | 'error'\n | 'tools-changed'\n | 'progress'\n | 'configuration-available'\n | 'photons' // Photon list changed\n | 'hot-reload' // File changed, photon reloaded\n | 'elicitation' // User input needed\n | 'board-update' // Kanban board update (legacy, triggers refresh)\n | 'channel-event' // Specific event with delta (task-moved, task-updated, etc.)\n | 'refresh-needed' // Server signals lastEventId too old, full refresh required\n | 'result' // Tool execution result\n | 'configured' // Photon configuration complete\n | 'notification' // Generic notification\n | 'operation-queued' // Operation queued for retry\n | 'queue-processed' // Queued operations processed\n | 'ui-tool-result' // MCP Apps: tool result notification\n | 'ui-tool-input' // MCP Apps: tool input notification\n | 'ui-tool-input-partial'; // MCP Apps: partial tool input (streaming)\n\n// Pending operation for offline queue\ninterface PendingOperation {\n id: number;\n method: string;\n params: Record<string, unknown>;\n resolve: (value: unknown) => void;\n reject: (error: Error) => void;\n timestamp: number;\n}\n\nclass MCPClientService {\n private sessionId: string | null = null;\n private requestId = 0;\n private connected = false;\n private eventSource: EventSource | null = null;\n private reconnectAttempts = 0;\n private maxReconnectAttempts = 5;\n private reconnectDelay = 1000;\n private eventListeners = new Map<MCPEventType, Set<(data?: unknown) => void>>();\n private baseUrl: string;\n private _configurationSchema: ConfigurationSchema | null = null;\n private lastMessageTime = 0;\n private heartbeatInterval: number | null = null;\n private visibilityHandler: (() => void) | null = null;\n private readonly HEARTBEAT_TIMEOUT_MS = 60000; // 60s - server sends keepalive every 30s\n private pendingOperations: PendingOperation[] = [];\n private isProcessingQueue = false;\n private readonly MAX_QUEUE_AGE_MS = 30000; // Discard operations older than 30s\n\n constructor() {\n this.baseUrl = `${window.location.protocol}//${window.location.host}/mcp`;\n }\n\n /**\n * Connect to the MCP endpoint via Streamable HTTP\n */\n async connect(): Promise<void> {\n try {\n // Initialize session via POST\n await this.initialize();\n\n // Open SSE stream for server notifications\n this.openSSEStream();\n\n this.connected = true;\n this.reconnectAttempts = 0;\n this.emit('connect');\n } catch (error) {\n this.emit('error', error);\n throw error;\n }\n }\n\n /**\n * Disconnect from the MCP endpoint\n */\n disconnect(): void {\n this.maxReconnectAttempts = 0;\n this.stopHeartbeatCheck();\n if (this.eventSource) {\n this.eventSource.close();\n this.eventSource = null;\n }\n this.connected = false;\n this.sessionId = null;\n this.emit('disconnect');\n }\n\n /**\n * Initialize MCP session\n */\n private async initialize(): Promise<void> {\n const result = (await this.sendRequest('initialize', {\n protocolVersion: '2025-03-26',\n capabilities: {\n roots: { listChanged: false },\n sampling: {},\n },\n clientInfo: {\n name: 'beam', // Identifies as Beam client for server-side notifications\n version: '1.0.0',\n },\n })) as {\n protocolVersion: string;\n serverInfo: { name: string; version: string };\n capabilities: Record<string, unknown>;\n configurationSchema?: ConfigurationSchema;\n };\n\n // Capture configuration schema for unconfigured photons\n if (result.configurationSchema) {\n this._configurationSchema = result.configurationSchema;\n this.emit('configuration-available', this._configurationSchema);\n }\n\n // Send initialized notification\n await this.sendNotification('notifications/initialized', {});\n }\n\n /**\n * Open SSE stream for server-to-client notifications\n */\n private openSSEStream(): void {\n // Build URL with session ID if available\n let sseUrl = this.baseUrl;\n if (this.sessionId) {\n sseUrl += `?sessionId=${encodeURIComponent(this.sessionId)}`;\n }\n\n this.eventSource = new EventSource(sseUrl);\n\n this.eventSource.onopen = () => {\n // SSE connected - reset reconnect counter and start heartbeat monitoring\n this.reconnectAttempts = 0;\n this.lastMessageTime = Date.now();\n this.startHeartbeatCheck();\n // Process any queued operations\n this.processQueue();\n };\n\n this.eventSource.onmessage = (event) => {\n this.lastMessageTime = Date.now();\n this.handleSSEMessage(event.data);\n };\n\n this.eventSource.onerror = () => {\n if (this.eventSource?.readyState === EventSource.CLOSED) {\n this.handleSSEDisconnect();\n }\n };\n }\n\n /**\n * Start heartbeat check to detect stale connections\n * Only polls when tab is visible - stops when hidden to save resources\n */\n private startHeartbeatCheck(): void {\n this.stopHeartbeatCheck();\n\n // Check for stale connection\n const checkStale = () => {\n const elapsed = Date.now() - this.lastMessageTime;\n if (elapsed > this.HEARTBEAT_TIMEOUT_MS && this.connected) {\n console.warn('[MCP] Connection stale, reconnecting...');\n this.handleSSEDisconnect();\n }\n };\n\n // Start/stop polling based on visibility\n const handleVisibility = () => {\n if (document.visibilityState === 'visible') {\n // Tab became visible - check immediately and start polling\n checkStale();\n if (!this.heartbeatInterval) {\n this.heartbeatInterval = window.setInterval(checkStale, 15000);\n }\n } else {\n // Tab hidden - stop polling to save resources\n if (this.heartbeatInterval) {\n clearInterval(this.heartbeatInterval);\n this.heartbeatInterval = null;\n }\n }\n };\n\n this.visibilityHandler = handleVisibility;\n document.addEventListener('visibilitychange', handleVisibility);\n\n // Start polling if currently visible\n if (document.visibilityState === 'visible') {\n this.heartbeatInterval = window.setInterval(checkStale, 15000);\n }\n }\n\n /**\n * Stop heartbeat check\n */\n private stopHeartbeatCheck(): void {\n if (this.heartbeatInterval) {\n clearInterval(this.heartbeatInterval);\n this.heartbeatInterval = null;\n }\n if (this.visibilityHandler) {\n document.removeEventListener('visibilitychange', this.visibilityHandler);\n this.visibilityHandler = null;\n }\n }\n\n /**\n * Handle SSE disconnect with reconnection\n */\n private handleSSEDisconnect(): void {\n this.stopHeartbeatCheck();\n if (this.eventSource) {\n this.eventSource.close();\n this.eventSource = null;\n }\n\n if (this.reconnectAttempts < this.maxReconnectAttempts) {\n this.reconnectAttempts++;\n setTimeout(() => {\n if (this.connected) {\n this.openSSEStream();\n }\n }, this.reconnectDelay * this.reconnectAttempts);\n } else {\n this.connected = false;\n this.emit('disconnect');\n }\n }\n\n /**\n * Handle incoming SSE message\n */\n private handleSSEMessage(data: string): void {\n try {\n const message = JSON.parse(data) as JSONRPCMessage;\n\n // Server notifications come through SSE\n if (message.method && message.id === undefined) {\n this.handleNotification(message);\n }\n } catch (error) {\n this.emit('error', error);\n }\n }\n\n /**\n * List available tools\n */\n async listTools(): Promise<MCPTool[]> {\n const result = (await this.sendRequest('tools/list', {})) as { tools: MCPTool[] };\n return result.tools || [];\n }\n\n /**\n * Call a tool - queues operation if connection fails\n */\n async callTool(\n name: string,\n args: Record<string, unknown>,\n progressToken?: string | number\n ): Promise<{ content: Array<{ type: string; text?: string }>; isError?: boolean }> {\n const params: Record<string, unknown> = { name, arguments: args };\n\n if (progressToken !== undefined) {\n params._meta = { progressToken };\n }\n\n try {\n const result = (await this.sendRequest('tools/call', params)) as {\n content: Array<{ type: string; text?: string }>;\n isError?: boolean;\n };\n return result;\n } catch (error) {\n // Queue the operation for retry if it's a connection error\n if (this.isConnectionError(error)) {\n return this.queueOperation('tools/call', params);\n }\n throw error;\n }\n }\n\n /**\n * Check if error is a connection-related error\n */\n private isConnectionError(error: unknown): boolean {\n if (error instanceof Error) {\n const msg = error.message.toLowerCase();\n return (\n msg.includes('network') ||\n msg.includes('fetch') ||\n msg.includes('connection') ||\n msg.includes('timeout') ||\n msg.includes('http error: 0') ||\n msg.includes('failed to fetch')\n );\n }\n return false;\n }\n\n /**\n * Queue an operation for retry when connection is restored\n */\n private queueOperation(\n method: string,\n params: Record<string, unknown>\n ): Promise<{ content: Array<{ type: string; text?: string }>; isError?: boolean }> {\n return new Promise((resolve, reject) => {\n const operation: PendingOperation = {\n id: ++this.requestId,\n method,\n params,\n resolve,\n reject,\n timestamp: Date.now(),\n };\n this.pendingOperations.push(operation);\n console.log(`[MCP] Operation queued (${this.pendingOperations.length} pending)`);\n this.emit('operation-queued', { count: this.pendingOperations.length, method, params });\n });\n }\n\n /**\n * Process queued operations after reconnection\n */\n private async processQueue(): Promise<void> {\n if (this.isProcessingQueue || this.pendingOperations.length === 0) return;\n\n this.isProcessingQueue = true;\n const now = Date.now();\n\n // Filter out stale operations\n this.pendingOperations = this.pendingOperations.filter((op) => {\n if (now - op.timestamp > this.MAX_QUEUE_AGE_MS) {\n op.reject(new Error('Operation expired'));\n return false;\n }\n return true;\n });\n\n console.log(`[MCP] Processing ${this.pendingOperations.length} queued operations`);\n\n while (this.pendingOperations.length > 0) {\n const operation = this.pendingOperations.shift()!;\n try {\n const result = await this.sendRequest(operation.method, operation.params);\n operation.resolve(result);\n } catch (error) {\n // If still failing, re-queue if not too old\n if (this.isConnectionError(error) && now - operation.timestamp < this.MAX_QUEUE_AGE_MS) {\n this.pendingOperations.unshift(operation);\n break; // Stop processing, wait for next reconnect\n }\n operation.reject(error instanceof Error ? error : new Error(String(error)));\n }\n }\n\n this.isProcessingQueue = false;\n this.emit('queue-processed', { remaining: this.pendingOperations.length });\n }\n\n /**\n * List available resources (MCP Apps Extension - ui:// scheme)\n */\n async listResources(): Promise<MCPResource[]> {\n const result = (await this.sendRequest('resources/list', {})) as { resources: MCPResource[] };\n return result.resources || [];\n }\n\n /**\n * Read a resource by URI (MCP Apps Extension - ui:// scheme)\n */\n async readResource(uri: string): Promise<MCPResourceContent | null> {\n const result = (await this.sendRequest('resources/read', { uri })) as {\n contents: MCPResourceContent[];\n };\n return result.contents?.[0] || null;\n }\n\n /**\n * Get configuration schema for unconfigured photons\n */\n getConfigurationSchema(): ConfigurationSchema | null {\n return this._configurationSchema;\n }\n\n /**\n * Check if a photon needs configuration\n */\n needsConfiguration(photonName: string): boolean {\n return !!this._configurationSchema?.[photonName];\n }\n\n /**\n * Configure a photon via beam/configure tool\n */\n async configurePhoton(\n photonName: string,\n config: Record<string, string>\n ): Promise<{ success: boolean; error?: string }> {\n try {\n const result = await this.callTool('beam/configure', {\n photon: photonName,\n config,\n });\n\n if (result.isError) {\n const errorText =\n result.content.find((c) => c.type === 'text')?.text || 'Configuration failed';\n return { success: false, error: errorText };\n }\n\n // Clear configuration schema for this photon on success\n if (this._configurationSchema) {\n delete this._configurationSchema[photonName];\n }\n\n return { success: true };\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n return { success: false, error: message };\n }\n }\n\n /**\n * Browse server filesystem via beam/browse tool\n */\n async browseFilesystem(\n path?: string,\n filter?: string\n ): Promise<{\n path: string;\n parent: string;\n items: Array<{ name: string; path: string; isDirectory: boolean }>;\n } | null> {\n try {\n const result = await this.callTool('beam/browse', { path, filter });\n\n if (result.isError) {\n return null;\n }\n\n const data = this.parseToolResult(result);\n return data as any;\n } catch {\n return null;\n }\n }\n\n /**\n * Reload a photon via beam/reload tool\n */\n async reloadPhoton(photonName: string): Promise<{ success: boolean; error?: string }> {\n try {\n const result = await this.callTool('beam/reload', { photon: photonName });\n\n if (result.isError) {\n const errorText = result.content.find((c) => c.type === 'text')?.text || 'Reload failed';\n return { success: false, error: errorText };\n }\n\n return { success: true };\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n return { success: false, error: message };\n }\n }\n\n /**\n * Remove a photon via beam/remove tool\n */\n async removePhoton(photonName: string): Promise<{ success: boolean; error?: string }> {\n try {\n const result = await this.callTool('beam/remove', { photon: photonName });\n\n if (result.isError) {\n const errorText = result.content.find((c) => c.type === 'text')?.text || 'Remove failed';\n return { success: false, error: errorText };\n }\n\n return { success: true };\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n return { success: false, error: message };\n }\n }\n\n /**\n * Send elicitation response back to server\n */\n async sendElicitationResponse(\n elicitationId: string,\n value: any,\n cancelled = false\n ): Promise<{ success: boolean }> {\n try {\n await this.sendRequest('beam/elicitation-response', {\n elicitationId,\n value,\n cancelled,\n });\n return { success: true };\n } catch {\n return { success: false };\n }\n }\n\n /**\n * Get rich help documentation for a photon via beam/photon-help tool\n */\n async getPhotonHelp(photonName: string): Promise<string | null> {\n try {\n const result = await this.callTool('beam/photon-help', { photon: photonName });\n\n if (result.isError) {\n return null;\n }\n\n const textContent = result.content.find((c) => c.type === 'text');\n return textContent?.text || null;\n } catch {\n return null;\n }\n }\n\n /**\n * Update photon or method metadata via beam/update-metadata tool\n */\n async updateMetadata(\n photonName: string,\n methodName: string | null,\n metadata: Record<string, any>\n ): Promise<{ success: boolean; error?: string }> {\n try {\n const args: Record<string, unknown> = { photon: photonName, metadata };\n if (methodName) {\n args.method = methodName;\n }\n\n const result = await this.callTool('beam/update-metadata', args);\n\n if (result.isError) {\n const errorText = result.content.find((c) => c.type === 'text')?.text || 'Update failed';\n return { success: false, error: errorText };\n }\n\n return { success: true };\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n return { success: false, error: message };\n }\n }\n\n /**\n * Parse tool result content to data\n */\n parseToolResult(result: { content: Array<{ type: string; text?: string }> }): unknown {\n if (result.content && result.content.length > 0) {\n const textContent = result.content.find((c) => c.type === 'text');\n if (textContent?.text) {\n try {\n return JSON.parse(textContent.text);\n } catch {\n return textContent.text;\n }\n }\n }\n return null;\n }\n\n /**\n * Convert MCP tools to photons format\n */\n toolsToPhotons(tools: MCPTool[]): Array<{\n id: string;\n name: string;\n configured: boolean;\n isApp?: boolean;\n appEntry?: any;\n methods: Array<{\n name: string;\n description: string;\n params: Record<string, unknown>;\n icon?: string;\n autorun?: boolean;\n outputFormat?: string;\n layoutHints?: Record<string, string>;\n buttonLabel?: string;\n linkedUi?: string;\n }>;\n }> {\n const photonMap = new Map<string, any>();\n\n for (const tool of tools) {\n const slashIndex = tool.name.indexOf('/');\n if (slashIndex === -1) continue;\n\n const photonName = tool.name.slice(0, slashIndex);\n const methodName = tool.name.slice(slashIndex + 1);\n\n if (!photonMap.has(photonName)) {\n photonMap.set(photonName, {\n id: tool['x-photon-id'] || photonName, // Use hash ID, fallback to name\n name: photonName,\n path: tool['x-photon-path'], // File path for View Source\n description: tool['x-photon-description'],\n icon: tool['x-photon-icon'],\n internal: tool['x-photon-internal'],\n promptCount: tool['x-photon-prompt-count'] || 0,\n resourceCount: tool['x-photon-resource-count'] || 0,\n configured: true,\n methods: [],\n });\n }\n\n photonMap.get(photonName).methods.push({\n name: methodName,\n description: tool.description || '',\n params: tool.inputSchema || { type: 'object', properties: {} },\n icon: tool['x-icon'],\n autorun: tool['x-autorun'],\n outputFormat: tool['x-output-format'],\n layoutHints: tool['x-layout-hints'],\n buttonLabel: tool['x-button-label'],\n linkedUi: tool._meta?.ui?.resourceUri?.match(/^ui:\\/\\/[^/]+\\/(.+)$/)?.[1],\n visibility: tool._meta?.ui?.visibility,\n });\n }\n\n // Post-process: set isApp and appEntry for photons with main() + linkedUi\n for (const photon of photonMap.values()) {\n const mainMethod = photon.methods.find((m: any) => m.name === 'main' && m.linkedUi);\n if (mainMethod) {\n photon.isApp = true;\n photon.appEntry = mainMethod;\n }\n }\n\n return Array.from(photonMap.values());\n }\n\n /**\n * Add event listener\n */\n on(event: MCPEventType, callback: (data?: unknown) => void): void {\n if (!this.eventListeners.has(event)) {\n this.eventListeners.set(event, new Set());\n }\n this.eventListeners.get(event)!.add(callback);\n }\n\n /**\n * Remove event listener\n */\n off(event: MCPEventType, callback: (data?: unknown) => void): void {\n this.eventListeners.get(event)?.delete(callback);\n }\n\n /**\n * Emit event\n */\n private emit(event: MCPEventType, data?: unknown): void {\n this.eventListeners.get(event)?.forEach((callback) => callback(data));\n }\n\n /**\n * Send JSON-RPC request via HTTP POST\n */\n private async sendRequest(method: string, params: Record<string, unknown>): Promise<unknown> {\n const id = ++this.requestId;\n const request: JSONRPCMessage = {\n jsonrpc: '2.0',\n id,\n method,\n params,\n };\n\n const headers: Record<string, string> = {\n 'Content-Type': 'application/json',\n Accept: 'application/json',\n };\n\n // Include session ID if we have one\n if (this.sessionId) {\n headers['Mcp-Session-Id'] = this.sessionId;\n }\n\n const response = await fetch(this.baseUrl, {\n method: 'POST',\n headers,\n body: JSON.stringify(request),\n signal: AbortSignal.timeout(60000), // 60s for MCP method calls\n });\n\n // Capture session ID from response\n const newSessionId = response.headers.get('Mcp-Session-Id');\n if (newSessionId) {\n this.sessionId = newSessionId;\n }\n\n if (!response.ok) {\n throw new Error(`HTTP error: ${response.status} ${response.statusText}`);\n }\n\n const result = (await response.json()) as JSONRPCMessage;\n\n if (result.error) {\n throw new Error(result.error.message);\n }\n\n return result.result;\n }\n\n /**\n * Notify server that client is viewing a resource (for on-demand subscriptions)\n * @param photonId - Hash of photon path (unique across servers)\n * @param itemId - Whatever the photon uses to identify the item (e.g., board name)\n */\n async notifyViewing(photonId: string, itemId: string): Promise<void> {\n if (!this.connected) return;\n await this.sendNotification('beam/viewing', { photonId, itemId });\n }\n\n /**\n * Send JSON-RPC notification via HTTP POST\n */\n private async sendNotification(method: string, params: Record<string, unknown>): Promise<void> {\n const notification: JSONRPCMessage = {\n jsonrpc: '2.0',\n method,\n params,\n };\n\n const headers: Record<string, string> = {\n 'Content-Type': 'application/json',\n };\n\n if (this.sessionId) {\n headers['Mcp-Session-Id'] = this.sessionId;\n }\n\n await fetch(this.baseUrl, {\n method: 'POST',\n headers,\n body: JSON.stringify(notification),\n signal: AbortSignal.timeout(10000), // 10s for notifications\n });\n }\n\n /**\n * Handle notification\n */\n private handleNotification(notification: JSONRPCMessage): void {\n switch (notification.method) {\n case 'notifications/tools/list_changed':\n this.emit('tools-changed');\n break;\n\n case 'notifications/progress':\n if (notification.params) {\n this.emit('progress', notification.params as ProgressNotification);\n }\n break;\n\n // Beam-specific notifications\n case 'beam/photons':\n this.emit('photons', notification.params);\n break;\n\n case 'beam/hot-reload':\n this.emit('hot-reload', notification.params);\n break;\n\n case 'beam/elicitation':\n this.emit('elicitation', notification.params);\n break;\n\n case 'beam/result':\n this.emit('result', notification.params);\n break;\n\n case 'beam/configured':\n this.emit('configured', notification.params);\n break;\n\n case 'beam/error':\n this.emit('error', notification.params);\n break;\n\n case 'beam/toast':\n this.emit('toast', notification.params);\n break;\n\n case 'beam/thinking':\n this.emit('thinking', notification.params);\n break;\n\n case 'beam/log':\n this.emit('log', notification.params);\n break;\n\n case 'photon/board-update':\n this.emit('board-update', notification.params);\n break;\n\n case 'photon/channel-event':\n this.emit('channel-event', notification.params);\n break;\n\n case 'photon/refresh-needed':\n this.emit('refresh-needed', notification.params);\n break;\n\n // MCP Apps standard notifications\n case 'ui/notifications/tool-result':\n this.emit('ui-tool-result', notification.params);\n break;\n\n case 'ui/notifications/tool-input':\n this.emit('ui-tool-input', notification.params);\n break;\n\n case 'ui/notifications/tool-input-partial':\n this.emit('ui-tool-input-partial', notification.params);\n break;\n\n default:\n // Emit generic notification for unknown methods\n this.emit('notification', notification);\n break;\n }\n }\n\n /**\n * Check if connected\n */\n isConnected(): boolean {\n return this.connected;\n }\n}\n\n// Singleton instance\nexport const mcpClient = new MCPClientService();\n", "import { LitElement, html, css } from 'lit';\nimport { unsafeHTML } from 'lit/directives/unsafe-html.js';\nimport { customElement, property, state, query } from 'lit/decorators.js';\nimport { theme, Theme } from '../styles/theme.js';\nimport { showToast } from './toast-manager.js';\nimport type { BeamSidebar } from './beam-sidebar.js';\nimport { getThemeTokens } from '../../design-system/tokens.js';\nimport type { ElicitationData } from './elicitation-modal.js';\nimport { mcpClient } from '../services/mcp-client.js';\n\nconst THEME_STORAGE_KEY = 'beam-theme';\nconst PROTOCOL_STORAGE_KEY = 'beam-protocol';\nconst FETCH_TIMEOUT_MS = 10_000;\nconst MCP_RECONNECT_DELAY_MS = 3_000;\nconst SCROLL_RENDER_DELAY_MS = 100;\n\n@customElement('beam-app')\nexport class BeamApp extends LitElement {\n static styles = [\n theme,\n css`\n :host {\n /* ===== Dark Theme (Default) ===== */\n --bg-app: hsl(220, 15%, 10%);\n --bg-glass: hsla(220, 15%, 14%, 0.6);\n --bg-glass-strong: hsla(220, 15%, 14%, 0.85);\n --bg-panel: hsl(220, 15%, 12%);\n --t-primary: hsl(220, 10%, 95%);\n --t-muted: hsl(220, 10%, 65%);\n --border-glass: hsla(220, 10%, 80%, 0.1);\n --accent-primary: hsl(260, 100%, 65%);\n --accent-secondary: hsl(190, 100%, 50%);\n --glow-primary: hsla(260, 100%, 65%, 0.3);\n\n display: flex;\n height: 100vh;\n width: 100vw;\n background: var(--bg-app);\n color: var(--t-primary);\n font-family: var(--font-sans);\n overflow: hidden;\n }\n\n /* ===== Light Theme - \"Warm Editorial\" ===== */\n :host([data-theme='light']) {\n --bg-app: hsl(40, 20%, 94%);\n --bg-glass: hsla(45, 40%, 99%, 0.92);\n --bg-glass-strong: hsla(45, 50%, 100%, 0.97);\n --bg-panel: hsl(42, 35%, 97%);\n --t-primary: hsl(220, 30%, 15%);\n --t-muted: hsl(220, 10%, 45%);\n --border-glass: hsla(30, 20%, 50%, 0.15);\n --accent-primary: hsl(215, 70%, 48%);\n --accent-secondary: hsl(165, 60%, 38%);\n --glow-primary: hsla(215, 70%, 48%, 0.15);\n }\n\n .sidebar-area {\n width: 300px;\n flex-shrink: 0;\n z-index: 10;\n display: flex;\n flex-direction: column;\n }\n\n .main-area {\n flex: 1;\n position: relative;\n overflow-y: auto;\n overflow-x: hidden;\n padding: var(--space-lg);\n }\n\n .cards-grid {\n display: grid;\n grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));\n gap: var(--space-md);\n margin-bottom: var(--space-xl);\n align-items: stretch; /* Make cards same height per row */\n }\n\n /* Photon Header */\n .photon-header {\n display: flex;\n align-items: flex-start;\n gap: var(--space-lg);\n margin-bottom: var(--space-xl);\n }\n\n .photon-icon-large {\n width: 64px;\n height: 64px;\n border-radius: 16px;\n background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));\n display: flex;\n align-items: center;\n justify-content: center;\n font-size: 28px;\n color: white;\n flex-shrink: 0;\n box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);\n }\n\n .photon-icon-large.mcp-icon {\n background: var(--bg-glass);\n color: var(--accent-secondary);\n font-size: 20px;\n font-weight: 600;\n }\n\n .photon-icon-large img {\n width: 40px;\n height: 40px;\n object-fit: contain;\n }\n\n .photon-header-info {\n flex: 1;\n min-width: 0;\n }\n\n .photon-header-name {\n font-size: 2rem;\n font-weight: 700;\n margin: 0 0 var(--space-sm) 0;\n background: linear-gradient(135deg, var(--t-primary), var(--accent-secondary));\n -webkit-background-clip: text;\n -webkit-text-fill-color: transparent;\n background-clip: text;\n }\n\n .photon-header-desc {\n color: var(--t-muted);\n font-size: 1rem;\n line-height: 1.5;\n margin: 0;\n }\n\n .photon-header-meta {\n display: flex;\n gap: var(--space-md);\n margin-top: var(--space-sm);\n }\n\n .photon-badge {\n font-size: 0.75rem;\n padding: 4px 10px;\n border-radius: 12px;\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n color: var(--t-muted);\n }\n\n .photon-badge.app {\n background: hsla(260, 100%, 65%, 0.15);\n border-color: hsla(260, 100%, 65%, 0.3);\n color: hsl(260, 100%, 75%);\n }\n\n .photon-badge.update {\n background: hsla(30, 100%, 55%, 0.15);\n border-color: hsla(30, 100%, 55%, 0.3);\n color: hsl(30, 100%, 65%);\n cursor: pointer;\n }\n\n .photon-badge.source {\n background: hsla(200, 60%, 50%, 0.1);\n border-color: hsla(200, 60%, 50%, 0.2);\n color: hsl(200, 60%, 65%);\n }\n\n .photon-header-actions {\n display: flex;\n gap: var(--space-sm);\n margin-top: var(--space-sm);\n }\n\n .btn-sm {\n font-size: 0.75rem;\n padding: 4px 12px;\n border-radius: 8px;\n border: 1px solid var(--border-glass);\n background: var(--bg-glass);\n color: var(--t-primary);\n cursor: pointer;\n transition: all 0.2s;\n }\n\n .btn-sm:hover {\n background: var(--bg-glass-strong);\n border-color: var(--accent-secondary);\n }\n\n .btn-sm.primary {\n background: var(--accent-primary);\n border-color: var(--accent-primary);\n color: white;\n }\n\n .btn-sm.primary:hover {\n opacity: 0.9;\n }\n\n /* Inline Editable Elements */\n .editable {\n cursor: pointer;\n border-radius: var(--radius-sm);\n padding: 2px 6px;\n margin: -2px -6px;\n transition:\n background 0.15s ease,\n box-shadow 0.15s ease;\n position: relative;\n }\n\n .editable:hover {\n background: var(--bg-glass);\n }\n\n .editable:hover::after {\n content: '\u270F\uFE0F';\n position: absolute;\n right: -24px;\n top: 50%;\n transform: translateY(-50%);\n font-size: 0.8rem;\n opacity: 0.6;\n }\n\n .editable.editing {\n background: var(--bg-glass-strong);\n box-shadow: 0 0 0 2px var(--accent-primary);\n }\n\n .editable-input {\n background: transparent;\n border: none;\n color: inherit;\n font: inherit;\n width: 100%;\n outline: none;\n padding: 0;\n margin: 0;\n }\n\n .editable-input::placeholder {\n color: var(--t-muted);\n font-style: italic;\n }\n\n .photon-header-desc.editable {\n min-width: 200px;\n display: inline-block;\n }\n\n .photon-header-desc.placeholder {\n color: var(--t-muted);\n font-style: italic;\n }\n\n /* Editable Icon */\n .photon-icon-large.editable {\n cursor: pointer;\n transition:\n transform 0.2s ease,\n box-shadow 0.2s ease;\n }\n\n .photon-icon-large.editable:hover {\n transform: scale(1.05);\n box-shadow:\n 0 8px 32px rgba(0, 0, 0, 0.3),\n 0 0 0 3px var(--accent-primary);\n }\n\n /* Emoji Picker */\n .emoji-picker {\n position: absolute;\n top: calc(100% + 8px);\n left: 0;\n background: var(--bg-panel);\n border: 1px solid var(--border-glass);\n border-radius: var(--radius-md);\n padding: var(--space-sm);\n box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);\n z-index: 100;\n display: grid;\n grid-template-columns: repeat(8, 1fr);\n gap: 4px;\n max-width: 280px;\n }\n\n .emoji-picker button {\n background: none;\n border: none;\n font-size: 1.5rem;\n padding: 4px;\n cursor: pointer;\n border-radius: var(--radius-sm);\n transition:\n background 0.15s ease,\n transform 0.1s ease;\n }\n\n .emoji-picker button:hover {\n background: var(--bg-glass);\n transform: scale(1.1);\n }\n\n /* Prompts & Resources Section */\n .section-header {\n color: var(--t-muted);\n text-transform: uppercase;\n font-size: 0.8rem;\n letter-spacing: 0.1em;\n margin-top: var(--space-xl);\n margin-bottom: var(--space-md);\n display: flex;\n align-items: center;\n gap: var(--space-sm);\n }\n\n .section-header .count {\n background: var(--bg-glass);\n padding: 2px 8px;\n border-radius: 10px;\n font-size: 0.7rem;\n }\n\n .asset-card {\n padding: var(--space-md);\n display: flex;\n flex-direction: column;\n gap: var(--space-sm);\n cursor: pointer;\n transition:\n transform 0.2s ease,\n box-shadow 0.2s ease;\n height: 100%;\n box-sizing: border-box;\n }\n\n .asset-card:hover {\n transform: translateY(-2px);\n box-shadow: 0 8px 32px -4px rgba(0, 0, 0, 0.3);\n border-color: var(--accent-secondary);\n }\n\n .asset-card .asset-icon {\n width: 32px;\n height: 32px;\n border-radius: 8px;\n background: var(--bg-glass);\n display: flex;\n align-items: center;\n justify-content: center;\n font-size: 16px;\n flex-shrink: 0;\n }\n\n .asset-card .asset-icon.prompt {\n background: hsla(45, 80%, 50%, 0.15);\n color: hsl(45, 80%, 50%);\n }\n\n .asset-card .asset-icon.resource {\n background: hsla(190, 80%, 50%, 0.15);\n color: hsl(190, 80%, 50%);\n }\n\n .asset-card .asset-header {\n display: flex;\n align-items: center;\n gap: var(--space-sm);\n }\n\n .asset-card .asset-name {\n font-weight: 600;\n font-size: 1rem;\n color: var(--t-primary);\n }\n\n .asset-card .asset-desc {\n font-size: 0.85rem;\n color: var(--t-muted);\n flex: 1;\n }\n\n .asset-card .asset-meta {\n font-size: 0.75rem;\n color: var(--t-muted);\n opacity: 0.7;\n }\n\n /* Prompt/Resource Viewer */\n .asset-viewer {\n padding: var(--space-lg);\n }\n\n .asset-viewer-header {\n display: flex;\n align-items: center;\n gap: var(--space-md);\n margin-bottom: var(--space-lg);\n }\n\n .asset-viewer-icon {\n width: 48px;\n height: 48px;\n border-radius: 12px;\n display: flex;\n align-items: center;\n justify-content: center;\n font-size: 24px;\n }\n\n .asset-viewer-icon.prompt {\n background: hsla(45, 80%, 50%, 0.15);\n color: hsl(45, 80%, 50%);\n }\n\n .asset-viewer-icon.resource {\n background: hsla(190, 80%, 50%, 0.15);\n color: hsl(190, 80%, 50%);\n }\n\n .asset-viewer-title {\n font-size: 1.5rem;\n font-weight: 600;\n margin: 0;\n }\n\n .asset-viewer-desc {\n color: var(--t-muted);\n margin: 4px 0 0 0;\n }\n\n .prompt-preview {\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n border-radius: var(--radius-md);\n padding: var(--space-md);\n font-family: var(--font-mono);\n font-size: 0.9rem;\n white-space: pre-wrap;\n line-height: 1.6;\n max-height: 400px;\n overflow-y: auto;\n }\n\n .prompt-preview .variable {\n background: hsla(45, 80%, 50%, 0.2);\n color: hsl(45, 80%, 60%);\n padding: 2px 6px;\n border-radius: 4px;\n font-weight: 500;\n }\n\n .background-glow {\n position: absolute;\n top: -20%;\n left: -10%;\n width: 50%;\n height: 50%;\n background: radial-gradient(circle, var(--glow-primary) 0%, transparent 70%);\n pointer-events: none;\n z-index: 0;\n }\n\n .connection-banner {\n position: fixed;\n top: 0;\n left: 0;\n right: 0;\n background: #f87171;\n color: white;\n padding: var(--space-sm) var(--space-md);\n display: flex;\n align-items: center;\n justify-content: center;\n gap: var(--space-md);\n z-index: 9998;\n font-size: 0.9rem;\n }\n\n .connection-banner button {\n background: rgba(255, 255, 255, 0.2);\n border: 1px solid rgba(255, 255, 255, 0.3);\n color: white;\n padding: 4px 12px;\n border-radius: var(--radius-sm);\n cursor: pointer;\n font-size: 0.8rem;\n }\n\n .connection-banner button:hover {\n background: rgba(255, 255, 255, 0.3);\n }\n\n .reconnecting {\n background: #fbbf24;\n }\n\n .modal-overlay {\n position: fixed;\n inset: 0;\n background: rgba(0, 0, 0, 0.6);\n backdrop-filter: blur(4px);\n z-index: 9999;\n display: flex;\n align-items: center;\n justify-content: center;\n }\n\n .help-modal {\n background: var(--bg-panel);\n border: 1px solid var(--border-glass);\n border-radius: var(--radius-md);\n padding: var(--space-xl);\n max-width: 500px;\n width: 90%;\n max-height: 80vh;\n overflow-y: auto;\n }\n\n .help-modal h2 {\n margin: 0 0 var(--space-lg) 0;\n font-size: 1.5rem;\n }\n\n .help-modal-close {\n position: absolute;\n top: var(--space-md);\n right: var(--space-md);\n background: none;\n border: none;\n color: var(--t-muted);\n font-size: 1.5rem;\n cursor: pointer;\n }\n\n .shortcut-section {\n margin-bottom: var(--space-lg);\n }\n\n .shortcut-section h3 {\n font-size: 0.8rem;\n text-transform: uppercase;\n letter-spacing: 0.1em;\n color: var(--t-muted);\n margin: 0 0 var(--space-sm) 0;\n }\n\n .shortcut-list {\n display: flex;\n flex-direction: column;\n gap: var(--space-xs);\n }\n\n .shortcut-item {\n display: flex;\n justify-content: space-between;\n align-items: center;\n padding: var(--space-xs) 0;\n }\n\n .shortcut-key {\n display: inline-flex;\n gap: 4px;\n }\n\n .shortcut-key kbd {\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n border-radius: 4px;\n padding: 2px 8px;\n font-family: var(--font-mono);\n font-size: 0.85rem;\n }\n\n .shortcut-desc {\n color: var(--t-muted);\n font-size: 0.9rem;\n }\n\n /* Header Toolbar */\n .header-toolbar {\n display: flex;\n align-items: center;\n justify-content: space-between;\n margin-bottom: var(--space-md);\n }\n\n .header-left {\n display: flex;\n align-items: center;\n gap: var(--space-md);\n }\n\n /* Desktop Action Toolbar */\n .action-toolbar {\n display: flex;\n align-items: center;\n gap: var(--space-xs);\n }\n\n .toolbar-btn {\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n color: var(--t-muted);\n padding: 6px 10px;\n border-radius: var(--radius-sm);\n cursor: pointer;\n display: flex;\n align-items: center;\n gap: 6px;\n font-size: 0.8rem;\n transition: all 0.2s ease;\n white-space: nowrap;\n }\n\n .toolbar-btn:hover {\n color: var(--t-primary);\n background: var(--bg-glass-strong);\n border-color: var(--accent-primary);\n }\n\n .toolbar-btn.icon-only {\n padding: 6px 8px;\n }\n\n .toolbar-btn.icon-only span.label {\n display: none;\n }\n\n .toolbar-btn.danger:hover {\n border-color: #f87171;\n color: #f87171;\n }\n\n .toolbar-btn.active {\n background: var(--accent-primary);\n border-color: var(--accent-primary);\n color: white;\n }\n\n .toolbar-divider {\n width: 1px;\n height: 24px;\n background: var(--border-glass);\n margin: 0 var(--space-xs);\n }\n\n .toolbar-toggle {\n display: flex;\n align-items: center;\n gap: 6px;\n }\n\n .toolbar-toggle .toggle-indicator {\n width: 8px;\n height: 8px;\n border-radius: 50%;\n background: var(--bg-glass-strong);\n transition: background 0.2s ease;\n }\n\n .toolbar-toggle .toggle-indicator.active {\n background: var(--accent-primary);\n }\n\n /* Mobile dropdown toggle */\n .settings-container {\n position: relative;\n display: none;\n }\n\n .settings-btn {\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n color: var(--t-muted);\n padding: 8px 12px;\n border-radius: var(--radius-sm);\n cursor: pointer;\n display: flex;\n align-items: center;\n gap: 6px;\n font-size: 0.85rem;\n transition: all 0.2s ease;\n }\n\n .settings-btn:hover {\n color: var(--t-primary);\n background: var(--bg-glass-strong);\n border-color: var(--accent-primary);\n }\n\n .settings-dropdown {\n position: absolute;\n top: calc(100% + 8px);\n right: 0;\n background: var(--bg-panel);\n border: 1px solid var(--border-glass);\n border-radius: var(--radius-md);\n min-width: 200px;\n box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);\n z-index: 100;\n overflow: hidden;\n }\n\n .settings-dropdown-item {\n display: flex;\n align-items: center;\n gap: 10px;\n padding: 12px 16px;\n cursor: pointer;\n color: var(--t-primary);\n font-size: 0.9rem;\n transition: background 0.15s ease;\n border: none;\n background: none;\n width: 100%;\n text-align: left;\n }\n\n .settings-dropdown-item:hover {\n background: var(--bg-glass);\n }\n\n .settings-dropdown-item .icon {\n font-size: 1rem;\n width: 20px;\n text-align: center;\n }\n\n .settings-dropdown-divider {\n height: 1px;\n background: var(--border-glass);\n margin: 4px 0;\n }\n\n .settings-dropdown-item.toggle {\n justify-content: space-between;\n }\n\n .toggle-switch {\n width: 36px;\n height: 20px;\n background: var(--bg-glass);\n border-radius: 10px;\n position: relative;\n transition: background 0.2s ease;\n }\n\n .toggle-switch.active {\n background: var(--accent-primary);\n }\n\n .toggle-switch::after {\n content: '';\n position: absolute;\n top: 2px;\n left: 2px;\n width: 16px;\n height: 16px;\n background: white;\n border-radius: 50%;\n transition: transform 0.2s ease;\n }\n\n .toggle-switch.active::after {\n transform: translateX(16px);\n }\n\n /* Prism.js Syntax Highlighting (One Dark theme) */\n code[class*='language-'],\n pre[class*='language-'] {\n color: #abb2bf;\n text-shadow: none;\n }\n .token.comment,\n .token.prolog,\n .token.doctype,\n .token.cdata {\n color: #5c6370;\n font-style: italic;\n }\n .token.punctuation {\n color: #abb2bf;\n }\n .token.property,\n .token.tag,\n .token.boolean,\n .token.number,\n .token.constant,\n .token.symbol,\n .token.deleted {\n color: #e06c75;\n }\n .token.selector,\n .token.attr-name,\n .token.string,\n .token.char,\n .token.builtin,\n .token.inserted {\n color: #98c379;\n }\n .token.operator,\n .token.entity,\n .token.url,\n .language-css .token.string,\n .style .token.string {\n color: #56b6c2;\n }\n .token.atrule,\n .token.attr-value,\n .token.keyword {\n color: #c678dd;\n }\n .token.function,\n .token.class-name {\n color: #61afef;\n }\n .token.regex,\n .token.important,\n .token.variable {\n color: #d19a66;\n }\n\n /* Asset Viewer Modal */\n .asset-viewer-modal {\n background: var(--bg-panel);\n border: 1px solid var(--border-glass);\n border-radius: var(--radius-md);\n padding: var(--space-xl);\n max-width: 800px;\n width: 90%;\n max-height: 85vh;\n overflow-y: auto;\n position: relative;\n }\n\n .asset-viewer-modal .close-btn {\n position: absolute;\n top: var(--space-md);\n right: var(--space-md);\n background: none;\n border: none;\n color: var(--t-muted);\n font-size: 1.5rem;\n cursor: pointer;\n padding: 4px 8px;\n border-radius: var(--radius-sm);\n transition: all 0.15s ease;\n }\n\n .asset-viewer-modal .close-btn:hover {\n background: var(--bg-glass);\n color: var(--t-primary);\n }\n\n .asset-viewer-modal h2 {\n margin: 0 0 var(--space-md) 0;\n display: flex;\n align-items: center;\n gap: var(--space-sm);\n }\n\n .asset-viewer-modal h2 .icon {\n font-size: 1.5rem;\n }\n\n .asset-viewer-modal .description {\n color: var(--t-muted);\n margin-bottom: var(--space-lg);\n }\n\n /* Variables Form */\n .variables-form {\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n border-radius: var(--radius-md);\n padding: var(--space-md);\n margin-bottom: var(--space-lg);\n }\n\n .variables-form h4 {\n margin: 0 0 var(--space-md) 0;\n font-size: 0.85rem;\n text-transform: uppercase;\n letter-spacing: 0.05em;\n color: var(--t-muted);\n }\n\n .variable-input {\n display: flex;\n align-items: center;\n gap: var(--space-md);\n margin-bottom: var(--space-sm);\n }\n\n .variable-input label {\n min-width: 120px;\n font-family: var(--font-mono);\n font-size: 0.9rem;\n color: hsl(45, 80%, 60%);\n }\n\n .variable-input input {\n flex: 1;\n background: var(--bg-panel);\n border: 1px solid var(--border-glass);\n border-radius: var(--radius-sm);\n padding: var(--space-sm) var(--space-md);\n color: var(--t-primary);\n font-size: 0.9rem;\n }\n\n .variable-input input:focus {\n outline: none;\n border-color: var(--accent-primary);\n }\n\n /* Content Preview */\n .content-section {\n margin-top: var(--space-lg);\n }\n\n .content-section h4 {\n margin: 0 0 var(--space-sm) 0;\n font-size: 0.85rem;\n text-transform: uppercase;\n letter-spacing: 0.05em;\n color: var(--t-muted);\n }\n\n .content-preview {\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n border-radius: var(--radius-md);\n padding: var(--space-md);\n font-family: var(--font-mono);\n font-size: 0.85rem;\n white-space: pre-wrap;\n line-height: 1.6;\n max-height: 300px;\n overflow-y: auto;\n }\n\n .content-preview .var-highlight {\n background: hsla(45, 80%, 50%, 0.2);\n color: hsl(45, 80%, 60%);\n padding: 2px 6px;\n border-radius: 4px;\n }\n\n .content-preview .var-filled {\n background: hsla(150, 80%, 50%, 0.2);\n color: hsl(150, 80%, 60%);\n padding: 2px 6px;\n border-radius: 4px;\n }\n\n /* Copy Button */\n .copy-btn {\n display: flex;\n align-items: center;\n gap: 6px;\n background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));\n border: none;\n padding: var(--space-sm) var(--space-lg);\n border-radius: var(--radius-sm);\n color: white;\n font-weight: 500;\n cursor: pointer;\n margin-top: var(--space-md);\n transition:\n transform 0.15s ease,\n box-shadow 0.15s ease;\n }\n\n .copy-btn:hover {\n transform: translateY(-1px);\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);\n }\n\n .resource-image {\n max-width: 100%;\n border-radius: var(--radius-md);\n border: 1px solid var(--border-glass);\n }\n\n /* ===== Mobile Menu Button ===== */\n .mobile-menu-btn {\n display: none;\n position: fixed;\n top: var(--space-md);\n left: var(--space-md);\n z-index: 1001;\n width: 44px;\n height: 44px;\n border-radius: var(--radius-sm);\n background: var(--bg-panel);\n border: 1px solid var(--border-glass);\n color: var(--t-primary);\n cursor: pointer;\n align-items: center;\n justify-content: center;\n font-size: 1.5rem;\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);\n transition: all 0.2s;\n }\n\n .mobile-menu-btn:hover {\n background: var(--bg-glass-strong);\n transform: scale(1.05);\n }\n\n .mobile-menu-btn.open {\n background: var(--accent-primary);\n color: white;\n }\n\n /* ===== Sidebar Overlay (mobile) ===== */\n .sidebar-overlay {\n display: none;\n position: fixed;\n inset: 0;\n background: rgba(0, 0, 0, 0.5);\n backdrop-filter: blur(4px);\n z-index: 999;\n opacity: 0;\n transition: opacity 0.3s ease;\n }\n\n .sidebar-overlay.visible {\n opacity: 1;\n }\n\n /* ===== HTML UI Panel ===== */\n .html-ui-panel {\n min-height: 500px;\n display: flex;\n flex-direction: column;\n }\n\n .html-ui-panel result-viewer {\n flex: 1;\n margin: 0;\n }\n\n /* ===== Progress Bar ===== */\n .progress-container {\n margin: var(--space-md) 0;\n padding: var(--space-md);\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n border-radius: var(--radius-md);\n }\n\n .progress-bar-wrapper {\n height: 8px;\n background: rgba(0, 0, 0, 0.2);\n border-radius: 4px;\n overflow: hidden;\n }\n\n .progress-bar {\n height: 100%;\n background: linear-gradient(90deg, var(--accent-primary), var(--accent-secondary));\n border-radius: 4px;\n transition: width 0.3s ease;\n }\n\n .progress-bar.indeterminate {\n animation: indeterminate 1.5s infinite ease-in-out;\n }\n\n @keyframes indeterminate {\n 0% {\n transform: translateX(-100%);\n }\n 50% {\n transform: translateX(200%);\n }\n 100% {\n transform: translateX(-100%);\n }\n }\n\n .progress-text {\n display: flex;\n justify-content: space-between;\n align-items: center;\n margin-top: var(--space-sm);\n font-size: 0.85rem;\n color: var(--t-muted);\n }\n\n .progress-percentage {\n font-weight: 600;\n color: var(--accent-secondary);\n }\n\n /* ===== Responsive Design ===== */\n @media (max-width: 768px) {\n .mobile-menu-btn {\n display: flex;\n }\n\n .sidebar-overlay {\n display: block;\n pointer-events: none;\n }\n\n .sidebar-overlay.visible {\n pointer-events: auto;\n }\n\n .sidebar-area {\n position: fixed;\n top: 0;\n left: 0;\n bottom: 0;\n width: 85%;\n max-width: 320px;\n margin: 0 !important;\n border-radius: 0 var(--radius-md) var(--radius-md) 0 !important;\n transform: translateX(-100%);\n transition: transform 0.3s ease;\n z-index: 1000;\n }\n\n .sidebar-area.visible {\n transform: translateX(0);\n }\n\n .main-area {\n padding: var(--space-md);\n padding-top: calc(var(--space-md) + 60px); /* Space for mobile menu button */\n }\n\n .photon-header {\n flex-direction: column;\n align-items: flex-start;\n gap: var(--space-md);\n }\n\n .photon-header-name {\n font-size: 1.5rem;\n }\n\n .cards-grid {\n grid-template-columns: 1fr;\n }\n\n /* Touch-friendly targets - min 44px */\n .asset-card,\n .method-card,\n button,\n .filter-btn {\n min-height: 44px;\n }\n\n .photon-header-meta {\n flex-wrap: wrap;\n }\n\n /* Responsive toolbar: hide desktop, show mobile dropdown */\n .action-toolbar {\n display: none;\n }\n\n .settings-container {\n display: block;\n }\n\n /* Settings dropdown positioning */\n .settings-dropdown {\n right: 0;\n left: auto;\n }\n\n /* Emoji picker positioning for mobile */\n .emoji-picker {\n position: fixed;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n max-width: 90vw;\n z-index: 1000;\n }\n\n /* Help modal adjustments */\n .help-modal {\n padding: var(--space-lg);\n max-height: 85vh;\n }\n }\n\n @media (max-width: 480px) {\n .main-area {\n padding: var(--space-sm);\n padding-top: calc(var(--space-sm) + 60px);\n }\n\n .cards-grid {\n gap: var(--space-sm);\n }\n\n .photon-icon-large {\n width: 48px;\n height: 48px;\n font-size: 20px;\n }\n\n .photon-header-name {\n font-size: 1.25rem;\n }\n\n .modal-content,\n .glass-panel {\n max-width: 100%;\n border-radius: var(--radius-sm);\n }\n\n .help-modal {\n padding: var(--space-md);\n max-height: 90vh;\n }\n\n /* Section headers more compact */\n .section-header {\n margin-top: var(--space-lg);\n margin-bottom: var(--space-sm);\n }\n }\n\n /* ===== Animation & Performance Optimization ===== */\n /* Use transform and opacity for GPU-accelerated animations */\n .sidebar-area,\n .mobile-menu-btn,\n .modal-overlay,\n .asset-card,\n .photon-icon-large {\n will-change: transform, opacity;\n }\n\n /* Remove will-change after animation completes to free GPU memory */\n .sidebar-area:not(.visible),\n .modal-overlay:not(:hover) {\n will-change: auto;\n }\n\n /* Reduce motion for users who prefer it */\n @media (prefers-reduced-motion: reduce) {\n *,\n *::before,\n *::after {\n animation-duration: 0.01ms !important;\n animation-iteration-count: 1 !important;\n transition-duration: 0.01ms !important;\n }\n\n .sidebar-area {\n transition: none;\n }\n }\n `,\n ];\n\n @state() private _connected = false;\n @state() private _reconnecting = false;\n @state() private _reconnectAttempt = 0;\n @state() private _sidebarVisible = false;\n @state() private _photons: any[] = [];\n @state() private _selectedPhoton: any = null;\n @state() private _view: 'list' | 'form' | 'marketplace' | 'config' | 'diagnostics' = 'list';\n @state() private _welcomePhase: 'welcome' | 'marketplace' = 'welcome';\n @state() private _configMode: 'initial' | 'edit' = 'initial';\n\n // ... (existing code)\n\n private _handleInstall(e: CustomEvent) {\n // Just log for now, the socket update 'photon_added' will handle the actual refresh\n this._log('info', `Installed ${e.detail.name}`);\n }\n\n private _handleMakerAction(e: CustomEvent) {\n const action = e.detail.action;\n // Try maker first, then marketplace for sync/init\n let target = this._photons.find((p) => p.name === 'maker');\n let targetName = 'maker';\n\n // sync and init moved to marketplace photon\n if (\n (action === 'sync' || action === 'init') &&\n !target?.methods?.find((m: any) => m.name === action)\n ) {\n target = this._photons.find((p) => p.name === 'marketplace');\n targetName = 'marketplace';\n }\n\n if (!target) {\n this._showError('Photon not found', `${targetName} photon not found`);\n return;\n }\n\n // Navigate to target photon and select the method\n this._selectedPhoton = target;\n const method = target.methods?.find((m: any) => m.name === action);\n if (method) {\n this._selectedMethod = method;\n this._view = 'form';\n this._updateHash();\n this._log('info', `Starting ${targetName}/${action}...`);\n showToast(`Starting ${action}...`, 'info');\n } else {\n this._showError('Photon not found', `Method '${action}' not found on ${targetName}`);\n }\n }\n\n /**\n * Collect static methods from all internal photons for global display\n */\n private get _globalStaticMethods(): Array<{ photon: any; method: any }> {\n const results: Array<{ photon: any; method: any }> = [];\n for (const photon of this._photons) {\n if (!photon.internal || !photon.methods) continue;\n for (const method of photon.methods) {\n if (method.isStatic) {\n results.push({ photon, method });\n }\n }\n }\n return results;\n }\n\n /**\n * Handle clicking a global static method card\n */\n private _handleGlobalMethodSelect(photon: any, method: any) {\n this._teardownActiveCustomUI();\n this._selectedPhoton = photon;\n this._selectedMethod = method;\n this._view = 'form';\n this._updateHash();\n this._maybeAutoInvoke(method);\n }\n\n @state() private _diagnosticsData: any = null;\n @state() private _testResults: Array<{\n method: string;\n passed: boolean;\n error?: string;\n duration?: number;\n }> = [];\n @state() private _runningTests = false;\n @state() private _selectedMethod: any = null;\n @state() private _lastResult: any = null;\n @state() private _lastFormParams: Record<string, any> = {};\n @state() private _sharedFormParams: Record<string, any> | null = null;\n @state() private _activityLog: any[] = [];\n @state() private _isExecuting = false;\n @state() private _progress: { value: number; message: string } | null = null;\n @state() private _theme: Theme = 'dark';\n @state() private _showHelp = false;\n @state() private _showPhotonHelp = false;\n @state() private _photonHelpMarkdown = '';\n @state() private _photonHelpLoading = false;\n @state() private _elicitationData: ElicitationData | null = null;\n @state() private _showElicitation = false;\n @state() private _protocolMode: 'legacy' | 'mcp' = 'legacy';\n @state() private _mcpReady = false;\n @state() private _showSettingsMenu = false;\n @state() private _rememberFormValues = false;\n @state() private _verboseLogging = false;\n @state() private _showSourceModal = false;\n @state() private _sourceData: { path: string; code: string } | null = null;\n @state() private _editingDescription = false;\n @state() private _editingIcon = false;\n @state() private _editedDescription = '';\n @state() private _updatesAvailable: Array<{\n name: string;\n currentVersion: string;\n latestVersion: string;\n marketplace: string;\n }> = [];\n @state() private _selectedPrompt: any = null;\n @state() private _selectedResource: any = null;\n @state() private _promptArguments: Record<string, string> = {};\n @state() private _renderedPrompt: string = '';\n @state() private _resourceContent: string = '';\n\n @query('beam-sidebar')\n private _sidebar!: BeamSidebar;\n\n private _pendingBridgeCalls = new Map<string, Window>();\n\n // File storage for ChatGPT Apps SDK uploadFile/getFileDownloadUrl\n private _uploadedFiles = new Map<string, { data: string; fileName: string; fileType: string }>();\n private _modelContext: any = null;\n private _fileIdCounter = 0;\n\n // Deep link URL for setOpenInAppUrl\n private _openInAppUrl: string | null = null;\n\n connectedCallback() {\n super.connectedCallback();\n\n // Load saved theme preference\n const savedTheme = localStorage.getItem(THEME_STORAGE_KEY) as Theme;\n if (savedTheme === 'light' || savedTheme === 'dark') {\n this._theme = savedTheme;\n }\n this._applyTheme();\n\n // Load saved protocol preference\n const savedProtocol = localStorage.getItem(PROTOCOL_STORAGE_KEY) as 'legacy' | 'mcp';\n if (savedProtocol === 'mcp') {\n this._protocolMode = 'mcp';\n }\n\n // Load saved remember values preference\n const savedRemember = localStorage.getItem('beam-remember-values');\n if (savedRemember === 'true') {\n this._rememberFormValues = true;\n }\n\n // Load saved verbose logging preference\n const savedVerbose = localStorage.getItem('beam-verbose-logging');\n if (savedVerbose === 'true') {\n this._verboseLogging = true;\n }\n\n // Click outside to close settings menu\n document.addEventListener('click', this._handleDocumentClick);\n\n // Connect via MCP Streamable HTTP (SSE for notifications)\n this._connectMCP();\n\n window.addEventListener('hashchange', this._handleHashChange);\n window.addEventListener('message', this._handleBridgeMessage);\n window.addEventListener('keydown', this._handleKeydown);\n }\n\n disconnectedCallback() {\n super.disconnectedCallback();\n window.removeEventListener('hashchange', this._handleHashChange);\n window.removeEventListener('message', this._handleBridgeMessage);\n window.removeEventListener('keydown', this._handleKeydown);\n document.removeEventListener('click', this._handleDocumentClick);\n }\n\n private _handleDocumentClick = (e: MouseEvent) => {\n const path = e.composedPath();\n\n if (this._showSettingsMenu) {\n const settingsContainer = this.shadowRoot?.querySelector('.settings-container');\n if (settingsContainer && !path.includes(settingsContainer)) {\n this._showSettingsMenu = false;\n }\n }\n\n // Close emoji picker when clicking outside\n if (this._editingIcon) {\n const emojiPicker = this.shadowRoot?.querySelector('.emoji-picker');\n const iconElement = this.shadowRoot?.querySelector('.photon-icon-large');\n if (emojiPicker && !path.includes(emojiPicker) && !path.includes(iconElement!)) {\n this._editingIcon = false;\n }\n }\n };\n\n private async _connectMCP() {\n try {\n mcpClient.on('connect', async () => {\n this._mcpReady = true;\n this._connected = true;\n this._reconnecting = false;\n this._reconnectAttempt = 0;\n console.log('MCP client connected');\n\n // Load initial photon list\n const tools = await mcpClient.listTools();\n this._photons = mcpClient.toolsToPhotons(tools);\n\n // Add unconfigured photons from configuration schema\n this._addUnconfiguredPhotons();\n\n // Check for available updates in background\n this._checkForUpdates();\n\n // Restore state from hash or select first photon\n if (window.location.hash) {\n this._handleHashChange();\n } else if (!this._selectedPhoton && this._photons.length > 0) {\n const firstUserPhoton = this._photons.find((p) => !p.internal);\n if (firstUserPhoton) this._selectedPhoton = firstUserPhoton;\n this._updateHash();\n }\n });\n\n mcpClient.on('disconnect', () => {\n this._mcpReady = false;\n this._connected = false;\n this._reconnecting = true;\n this._reconnectAttempt++;\n // Connection status shown via banner, not log\n showToast('Connection lost. Reconnecting...', 'warning');\n });\n\n mcpClient.on('tools-changed', async () => {\n const prevNames = new Set(this._photons.filter((p) => !p.internal).map((p) => p.name));\n const tools = await mcpClient.listTools();\n this._photons = mcpClient.toolsToPhotons(tools);\n // Re-add unconfigured photons from configuration schema\n this._addUnconfiguredPhotons();\n // Auto-select newly added user photon (welcome wizard flow)\n if (!this._selectedPhoton) {\n const newUserPhoton = this._photons.find(\n (p) => !p.internal && p.configured && !prevNames.has(p.name)\n );\n if (newUserPhoton) {\n this._selectedPhoton = newUserPhoton;\n this._welcomePhase = 'welcome';\n this._view = 'list';\n this._updateHash();\n }\n }\n });\n\n // Handle configuration schema for unconfigured photons\n mcpClient.on('configuration-available', () => {\n this._addUnconfiguredPhotons();\n });\n\n mcpClient.on('progress', (data: any) => {\n this._log('info', data.message || 'Processing...');\n // Update progress bar state\n if (typeof data.progress === 'number') {\n // For status events (progress=0 with message), only update if we don't have progress yet\n // or if it's an actual progress update (progress > 0)\n if (data.progress > 0 || !this._progress) {\n this._progress = {\n value: data.total ? data.progress / data.total : data.progress,\n message: data.message || 'Processing...',\n };\n } else if (this._progress && data.message) {\n // Status event - just update message, keep current progress value\n this._progress = {\n ...this._progress,\n message: data.message,\n };\n }\n }\n });\n\n // Handle toast notifications\n mcpClient.on('toast', (data: any) => {\n if (data?.message) {\n const type = data.type || 'info';\n const duration = data.duration || 3000;\n showToast(data.message, type, duration);\n }\n });\n\n // Handle thinking indicator\n mcpClient.on('thinking', (data: any) => {\n if (data?.active) {\n // Show thinking state - use progress bar with indeterminate state\n this._progress = {\n value: -1, // -1 indicates indeterminate\n message: 'Processing...',\n };\n } else if (this._progress?.value === -1) {\n // Only clear if we're in thinking state\n this._progress = null;\n }\n });\n\n // Handle log messages\n mcpClient.on('log', (data: any) => {\n if (data?.message) {\n const level = data.level || 'info';\n this._log(level, data.message);\n }\n });\n\n // Handle photons list update from SSE\n mcpClient.on('photons', (data: any) => {\n if (data?.photons) {\n const prevNames = new Set(this._photons.filter((p) => !p.internal).map((p) => p.name));\n this._photons = data.photons;\n // Update selected photon if it was in the list\n if (this._selectedPhoton) {\n const updated = this._photons.find((p) => p.name === this._selectedPhoton?.name);\n if (updated) {\n this._selectedPhoton = updated;\n }\n } else {\n // Auto-select newly added user photon (welcome wizard flow)\n const newUserPhoton = this._photons.find(\n (p) => !p.internal && p.configured && !prevNames.has(p.name)\n );\n if (newUserPhoton) {\n this._selectedPhoton = newUserPhoton;\n this._welcomePhase = 'welcome';\n this._view = 'list';\n this._updateHash();\n }\n }\n }\n });\n\n // Handle hot-reload notifications\n mcpClient.on('hot-reload', (data: any) => {\n if (data?.photon) {\n const reloadedPhoton = data.photon;\n const index = this._photons.findIndex((p) => p.name === reloadedPhoton.name);\n if (index !== -1) {\n this._photons = [\n ...this._photons.slice(0, index),\n reloadedPhoton,\n ...this._photons.slice(index + 1),\n ];\n }\n\n // Update selected photon if it was reloaded\n if (this._selectedPhoton?.name === reloadedPhoton.name) {\n this._selectedPhoton = reloadedPhoton;\n\n // Reselect method if it still exists\n if (this._selectedMethod) {\n const updatedMethod = reloadedPhoton.methods?.find(\n (m: any) => m.name === this._selectedMethod.name\n );\n if (updatedMethod) {\n this._selectedMethod = updatedMethod;\n }\n }\n }\n\n this._log('success', `${reloadedPhoton.name} reloaded`);\n showToast(`${reloadedPhoton.name} reloaded successfully`, 'success');\n }\n });\n\n // Handle configuration complete notifications\n mcpClient.on('configured', (data: any) => {\n if (data?.photon) {\n const configuredPhoton = data.photon;\n this._log('success', `${configuredPhoton.name} configured successfully`);\n showToast(`${configuredPhoton.name} configured successfully!`, 'success');\n\n // Update photon in list\n const index = this._photons.findIndex((p) => p.name === configuredPhoton.name);\n if (index !== -1) {\n this._photons = [\n ...this._photons.slice(0, index),\n configuredPhoton,\n ...this._photons.slice(index + 1),\n ];\n }\n\n // Update selected photon and switch to methods view\n if (this._selectedPhoton?.name === configuredPhoton.name) {\n this._selectedPhoton = configuredPhoton;\n if (configuredPhoton.isApp && configuredPhoton.appEntry) {\n this._selectedMethod = configuredPhoton.appEntry;\n this._view = 'form';\n } else {\n this._view = 'list';\n }\n this._updateHash();\n }\n }\n });\n\n // Handle elicitation requests\n mcpClient.on('elicitation', (data: any) => {\n if (data) {\n this._elicitationData = data;\n this._showElicitation = true;\n this._log('info', `Input required: ${data.message || data.ask}`);\n }\n });\n\n // Handle channel events (task-moved, task-updated, etc.) - forward with delta\n mcpClient.on('channel-event', (data: any) => {\n this._forwardToIframes({ type: 'photon:channel-event', ...data });\n });\n\n // Handle board updates (legacy) - forward to custom UI iframes\n mcpClient.on('board-update', (data: any) => {\n this._forwardToIframes({ type: 'photon:board-update', ...data });\n });\n\n // Handle refresh-needed (lastEventId too old) - forward to custom UI iframes\n mcpClient.on('refresh-needed', (data: any) => {\n this._forwardToIframes({ type: 'photon:refresh-needed', ...data });\n });\n\n // MCP Apps standard: forward ui/notifications/tool-result to iframes as JSON-RPC\n mcpClient.on('ui-tool-result', (params: any) => {\n this._forwardToIframes({\n jsonrpc: '2.0',\n method: 'ui/notifications/tool-result',\n params,\n });\n });\n\n // MCP Apps standard: forward ui/notifications/tool-input-partial to iframes as JSON-RPC\n mcpClient.on('ui-tool-input-partial', (params: any) => {\n this._forwardToIframes({\n jsonrpc: '2.0',\n method: 'ui/notifications/tool-input-partial',\n params,\n });\n });\n\n // MCP Apps standard: forward ui/notifications/tool-input to iframes as JSON-RPC\n mcpClient.on('ui-tool-input', (params: any) => {\n this._forwardToIframes({\n jsonrpc: '2.0',\n method: 'ui/notifications/tool-input',\n params,\n });\n });\n\n // Handle errors\n mcpClient.on('error', (data: any) => {\n if (data?.message) {\n this._isExecuting = false;\n this._log('error', data.message);\n showToast(data.message, 'error', 5000);\n }\n });\n\n await mcpClient.connect();\n } catch (error) {\n console.error('MCP connection failed:', error);\n this._mcpReady = false;\n this._connected = false;\n this._reconnecting = true;\n // Connection status shown via indicator, not log\n this._showError('Connection lost');\n // Retry connection after a delay\n setTimeout(() => this._connectMCP(), MCP_RECONNECT_DELAY_MS);\n }\n }\n\n private _handleHashChange = () => {\n const fullHash = window.location.hash.slice(1);\n // Parse hash format: photon/method?param1=value1&param2=value2\n const [pathPart, queryPart] = fullHash.split('?');\n const [photonName, methodName] = pathPart.split('/');\n\n // Parse query parameters for shared links\n let sharedParams: Record<string, any> = {};\n if (queryPart) {\n const params = new URLSearchParams(queryPart);\n for (const [key, value] of params) {\n // Try to parse JSON values (objects, arrays, numbers, booleans)\n try {\n sharedParams[key] = JSON.parse(value);\n } catch {\n sharedParams[key] = value;\n }\n }\n }\n\n if (photonName) {\n const photon = this._photons.find((p) => p.name === photonName);\n if (photon) {\n this._selectedPhoton = photon;\n\n if (methodName && photon.methods) {\n const method = photon.methods.find((m: any) => m.name === methodName);\n if (method) {\n this._selectedMethod = method;\n this._view = 'form';\n // Store shared params to pre-populate form\n if (Object.keys(sharedParams).length > 0) {\n this._sharedFormParams = sharedParams;\n } else {\n // Auto-invoke if no shared params provided\n this._maybeAutoInvoke(method);\n }\n }\n } else if (photon.isApp && photon.appEntry) {\n // For Apps without method specified, auto-select main\n this._selectedMethod = photon.appEntry;\n this._view = 'form';\n // Auto-invoke app entry if it has no required params\n this._maybeAutoInvoke(photon.appEntry);\n } else {\n this._selectedMethod = null;\n this._view = 'list';\n }\n }\n }\n };\n\n private _updateHash() {\n if (!this._selectedPhoton) return;\n let hash = this._selectedPhoton.name;\n if (this._selectedMethod) {\n hash += `/${this._selectedMethod.name}`;\n }\n // Update URL without scrolling\n history.replaceState(null, '', `#${hash}`);\n }\n\n /**\n * Add unconfigured photons from configurationSchema to the photons list\n */\n private _addUnconfiguredPhotons() {\n const schema = mcpClient.getConfigurationSchema();\n if (!schema) return;\n\n // Get names of photons already in list\n const existingNames = new Set(this._photons.map((p) => p.name));\n\n // Add unconfigured photons that aren't already in the list\n const unconfigured = Object.entries(schema)\n .filter(([name]) => !existingNames.has(name))\n .map(([name, config]) => ({\n id: name,\n name,\n configured: false,\n internal: config['x-internal'],\n methods: [], // Empty methods signals needs setup\n requiredParams: Object.entries(config.properties || {}).map(\n ([key, prop]: [string, any]) => ({\n name: key,\n type: prop.type || 'string',\n format: prop.format,\n default: prop.default,\n required: config.required?.includes(key),\n })\n ),\n errorMessage: config['x-error-message'],\n }));\n\n if (unconfigured.length > 0) {\n this._photons = [...this._photons, ...unconfigured];\n }\n }\n\n private _getTestMethods(): string[] {\n if (!this._selectedPhoton?.methods) return [];\n return this._selectedPhoton.methods\n .filter((m: any) => m.name.startsWith('test_') || m.name.startsWith('test'))\n .map((m: any) => m.name);\n }\n\n private _getAllTestMethods(): Array<{ photon: string; method: string }> {\n const results: Array<{ photon: string; method: string }> = [];\n for (const p of this._photons) {\n if (!p.methods) continue;\n for (const m of p.methods) {\n if (m.name.startsWith('test_') || m.name.startsWith('test')) {\n results.push({ photon: p.name, method: m.name });\n }\n }\n }\n return results;\n }\n\n private _runTests = async () => {\n if (!this._selectedPhoton || this._runningTests) return;\n const testMethods = this._getTestMethods();\n if (testMethods.length === 0) return;\n\n this._runningTests = true;\n this._testResults = [];\n this._log('info', `Running ${testMethods.length} test(s) for ${this._selectedPhoton.name}...`);\n\n for (const testName of testMethods) {\n try {\n const res = await fetch('/api/test/run', {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ photon: this._selectedPhoton.name, test: testName }),\n signal: AbortSignal.timeout(FETCH_TIMEOUT_MS),\n });\n const result = await res.json();\n this._testResults = [\n ...this._testResults,\n {\n method: testName,\n passed: result.passed,\n error: result.error,\n duration: result.duration,\n },\n ];\n } catch (error) {\n console.warn('Test fetch failed:', error);\n this._testResults = [\n ...this._testResults,\n {\n method: testName,\n passed: false,\n error: 'Request failed',\n },\n ];\n }\n }\n\n this._runningTests = false;\n const passed = this._testResults.filter((r) => r.passed).length;\n const total = this._testResults.length;\n showToast(`Tests: ${passed}/${total} passed`, passed === total ? 'success' : 'warning');\n this._log(passed === total ? 'success' : 'error', `Tests: ${passed}/${total} passed`);\n };\n\n private _runAllTests = async () => {\n const allTests = this._getAllTestMethods();\n if (allTests.length === 0 || this._runningTests) return;\n\n this._runningTests = true;\n this._testResults = [];\n this._log('info', `Running ${allTests.length} test(s) across all photons...`);\n\n for (const { photon, method } of allTests) {\n try {\n const res = await fetch('/api/test/run', {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ photon, test: method }),\n signal: AbortSignal.timeout(FETCH_TIMEOUT_MS),\n });\n const result = await res.json();\n this._testResults = [\n ...this._testResults,\n {\n method: `${photon}/${method}`,\n passed: result.passed,\n error: result.error,\n duration: result.duration,\n },\n ];\n } catch (error) {\n console.warn('Test fetch failed:', error);\n this._testResults = [\n ...this._testResults,\n {\n method: `${photon}/${method}`,\n passed: false,\n error: 'Request failed',\n },\n ];\n }\n }\n\n this._runningTests = false;\n const passed = this._testResults.filter((r) => r.passed).length;\n const total = this._testResults.length;\n showToast(`Tests: ${passed}/${total} passed`, passed === total ? 'success' : 'warning');\n this._log(\n passed === total ? 'success' : 'error',\n `All photon tests: ${passed}/${total} passed`\n );\n };\n\n private _renderDiagnostics() {\n if (!this._diagnosticsData) {\n this._fetchDiagnostics();\n return html`<div style=\"color: var(--t-muted);\">Loading diagnostics...</div>`;\n }\n\n const d = this._diagnosticsData;\n return html`\n <div\n style=\"display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--space-md); margin-bottom: var(--space-lg);\"\n >\n <div class=\"glass-panel\" style=\"padding: var(--space-md);\">\n <div style=\"font-size: 0.75rem; color: var(--t-muted); text-transform: uppercase;\">\n Node\n </div>\n <div style=\"font-size: 1.1rem; font-weight: 600;\">${d.nodeVersion}</div>\n </div>\n <div class=\"glass-panel\" style=\"padding: var(--space-md);\">\n <div style=\"font-size: 0.75rem; color: var(--t-muted); text-transform: uppercase;\">\n Photon\n </div>\n <div style=\"font-size: 1.1rem; font-weight: 600;\">${d.photonVersion}</div>\n </div>\n <div class=\"glass-panel\" style=\"padding: var(--space-md);\">\n <div style=\"font-size: 0.75rem; color: var(--t-muted); text-transform: uppercase;\">\n Uptime\n </div>\n <div style=\"font-size: 1.1rem; font-weight: 600;\">\n ${Math.floor(d.uptime / 60)}m ${Math.floor(d.uptime % 60)}s\n </div>\n </div>\n <div class=\"glass-panel\" style=\"padding: var(--space-md);\">\n <div style=\"font-size: 0.75rem; color: var(--t-muted); text-transform: uppercase;\">\n Sources\n </div>\n <div style=\"font-size: 1.1rem; font-weight: 600;\">${d.marketplaceSources}</div>\n </div>\n </div>\n\n <h3\n style=\"color: var(--t-muted); text-transform: uppercase; font-size: 0.8rem; letter-spacing: 0.1em; margin-bottom: var(--space-sm);\"\n >\n Photons (${d.configuredCount} loaded, ${d.unconfiguredCount} unconfigured)\n </h3>\n <div class=\"glass-panel\" style=\"padding: var(--space-md);\">\n ${(d.photons || []).map(\n (p: any) => html`\n <div style=\"display: flex; align-items: center; gap: var(--space-sm); padding: 4px 0;\">\n <span\n style=\"width: 10px; height: 10px; border-radius: 50; background: ${p.status ===\n 'loaded'\n ? '#4ade80'\n : p.status === 'unconfigured'\n ? '#fbbf24'\n : '#f87171'}; flex-shrink: 0;\"\n ></span>\n <span style=\"flex: 1;\">${p.name}</span>\n <span style=\"color: var(--t-muted); font-size: 0.8rem;\">${p.methods} methods</span>\n ${p.error\n ? html`<span style=\"color: #f87171; font-size: 0.75rem;\">${p.error}</span>`\n : ''}\n </div>\n `\n )}\n </div>\n\n <h3\n style=\"color: var(--t-muted); text-transform: uppercase; font-size: 0.8rem; letter-spacing: 0.1em; margin-top: var(--space-lg); margin-bottom: var(--space-sm);\"\n >\n Test Runner\n </h3>\n ${this._getAllTestMethods().length > 0\n ? html`\n <div class=\"glass-panel\" style=\"padding: var(--space-md);\">\n <div\n style=\"display: flex; align-items: center; justify-content: space-between; margin-bottom: ${this\n ._testResults.length > 0\n ? 'var(--space-md)'\n : '0'};\"\n >\n <span style=\"color: var(--t-muted); font-size: 0.85rem;\">\n ${this._getAllTestMethods().length} test(s) across\n ${new Set(this._getAllTestMethods().map((t) => t.photon)).size} photon(s)\n </span>\n <button class=\"btn-sm\" @click=${this._runAllTests} ?disabled=${this._runningTests}>\n ${this._runningTests ? '\u23F3 Running...' : '\u25B6 Run All Tests'}\n </button>\n </div>\n ${this._testResults.length > 0\n ? html`\n ${this._testResults.map(\n (r) => html`\n <div\n style=\"display: flex; align-items: center; gap: var(--space-sm); padding: 4px 0; font-size: 0.85rem;\"\n >\n <span>${r.passed ? '\u2705' : '\u274C'}</span>\n <span style=\"flex: 1; font-family: monospace;\">${r.method}</span>\n ${r.duration != null\n ? html`<span style=\"color: var(--t-muted); font-size: 0.75rem;\"\n >${r.duration}ms</span\n >`\n : ''}\n ${r.error\n ? html`<span style=\"color: #f87171; font-size: 0.75rem;\"\n >${r.error}</span\n >`\n : ''}\n </div>\n `\n )}\n <div\n style=\"margin-top: var(--space-sm); color: var(--t-muted); font-size: 0.8rem;\"\n >\n ${this._testResults.filter((r) => r.passed).length}/${this._testResults\n .length}\n passed\n </div>\n `\n : ''}\n </div>\n `\n : html`\n <div\n class=\"glass-panel\"\n style=\"padding: var(--space-md); color: var(--t-muted); font-size: 0.85rem;\"\n >\n No test methods found. Add methods prefixed with\n <code style=\"background: var(--bg-panel); padding: 2px 6px; border-radius: 4px;\"\n >test</code\n >\n to any photon.\n </div>\n `}\n\n <div style=\"margin-top: var(--space-md);\">\n <button\n class=\"btn-sm\"\n @click=${() => {\n this._diagnosticsData = null;\n this._fetchDiagnostics();\n }}\n >\n \uD83D\uDD04 Refresh\n </button>\n </div>\n `;\n }\n\n private async _fetchDiagnostics() {\n try {\n const res = await fetch('/api/diagnostics', {\n signal: AbortSignal.timeout(FETCH_TIMEOUT_MS),\n });\n if (res.ok) {\n this._diagnosticsData = await res.json();\n }\n } catch (error) {\n console.debug('Diagnostics fetch failed:', error);\n }\n }\n\n private _showError(error: string, context?: string) {\n let message = error;\n let action: { label: string; callback: () => void } | undefined;\n\n if (error.includes('Not connected') || error.includes('Connection lost')) {\n message = 'Connection lost. Beam will auto-reconnect, or restart with `photon beam`.';\n } else if (error.includes('not found') || error.includes('Not found')) {\n message = context || 'Photon may have been removed. Try refreshing.';\n action = { label: 'Refresh', callback: () => window.location.reload() };\n } else if (error.includes('Configuration') || error.includes('config')) {\n message = context || error;\n action = { label: 'Reconfigure', callback: () => this._handleReconfigure() };\n } else if (error.includes('Install') || error.includes('install')) {\n message = 'Check marketplace connectivity and try again.';\n } else {\n message = context ? `${error}: ${context}` : error;\n }\n\n showToast(message, 'error', 5000, action);\n }\n\n private async _checkForUpdates() {\n try {\n const res = await fetch('/api/marketplace/updates', {\n signal: AbortSignal.timeout(FETCH_TIMEOUT_MS),\n });\n if (!res.ok) return;\n const data = await res.json();\n this._updatesAvailable = data.updates || [];\n\n // Mark photons with available updates\n if (this._updatesAvailable.length > 0) {\n this._photons = this._photons.map((p) => {\n const update = this._updatesAvailable.find((u) => u.name === p.name);\n return update ? { ...p, hasUpdate: true } : p;\n });\n }\n } catch (error) {\n console.debug('Update check failed:', error);\n }\n }\n\n private _log(type: string, message: string, verbose = false) {\n // Skip verbose messages if verbose logging is disabled\n if (verbose && !this._verboseLogging) {\n return;\n }\n\n // Check if this is a duplicate of the most recent message\n const lastItem = this._activityLog[0];\n if (lastItem && lastItem.message === message && lastItem.type === type) {\n // Increment count on existing item\n this._activityLog = [\n { ...lastItem, count: (lastItem.count || 1) + 1, timestamp: new Date().toISOString() },\n ...this._activityLog.slice(1),\n ];\n return;\n }\n\n this._activityLog = [\n {\n id: Date.now().toString(),\n type,\n message,\n timestamp: new Date().toISOString(),\n count: 1,\n },\n ...this._activityLog,\n ];\n }\n\n render() {\n return html`\n ${!this._connected\n ? html`\n <div class=\"connection-banner ${this._reconnecting ? 'reconnecting' : ''}\">\n <div>\n <span\n >${this._reconnecting\n ? `Reconnecting to server...${this._reconnectAttempt > 1 ? ` (attempt ${this._reconnectAttempt})` : ''}`\n : 'Disconnected from server'}</span\n >\n ${this._reconnectAttempt >= 2\n ? html`<div style=\"font-size: 0.75rem; opacity: 0.8; margin-top: 2px;\">\n Server may have stopped. Restart:\n <code\n style=\"background: rgba(255,255,255,0.2); padding: 1px 4px; border-radius: 3px;\"\n >photon beam</code\n >\n </div>`\n : ''}\n </div>\n <button @click=${() => this._connect()}>Retry Now</button>\n </div>\n `\n : ''}\n\n <div class=\"background-glow\"></div>\n\n <!-- Mobile Menu Button -->\n <button\n class=\"mobile-menu-btn ${this._sidebarVisible ? 'open' : ''}\"\n @click=${this._toggleSidebar}\n aria-label=\"${this._sidebarVisible ? 'Close menu' : 'Open menu'}\"\n >\n ${this._sidebarVisible ? '\u2715' : '\u2630'}\n </button>\n\n <!-- Sidebar Overlay (mobile) -->\n <div\n class=\"sidebar-overlay ${this._sidebarVisible ? 'visible' : ''}\"\n @click=${this._closeSidebar}\n ></div>\n\n <div\n class=\"sidebar-area glass-panel ${this._sidebarVisible ? 'visible' : ''}\"\n style=\"margin: var(--space-sm); border-radius: var(--radius-md);\"\n >\n <beam-sidebar\n .photons=${this._photons}\n .selectedPhoton=${this._selectedPhoton?.name}\n .theme=${this._theme}\n .connected=${this._connected}\n .reconnecting=${this._reconnecting}\n .updatesAvailable=${this._updatesAvailable.length}\n @select=${this._handlePhotonSelectMobile}\n @marketplace=${this._handleMarketplaceMobile}\n @theme-change=${this._handleThemeChange}\n @show-shortcuts=${this._showHelpModal}\n @diagnostics=${() => {\n this._view = 'diagnostics';\n this._updateHash();\n }}\n ></beam-sidebar>\n </div>\n\n <main class=\"main-area\" role=\"main\" aria-label=\"Main content\">\n ${this._renderContent()}\n <activity-log\n .items=${this._activityLog}\n @clear=${() => (this._activityLog = [])}\n ></activity-log>\n </main>\n\n <toast-manager></toast-manager>\n\n ${this._showHelp ? this._renderHelpModal() : ''}\n ${this._showPhotonHelp ? this._renderPhotonHelpModal() : ''}\n ${this._showSourceModal ? this._renderSourceModal() : ''}\n ${this._selectedPrompt?.content ? this._renderPromptModal() : ''}\n ${this._selectedResource?.content ? this._renderResourceModal() : ''}\n\n <elicitation-modal\n ?open=${this._showElicitation}\n .data=${this._elicitationData}\n @submit=${this._handleElicitationSubmit}\n @cancel=${this._handleElicitationCancel}\n @oauth-complete=${this._handleOAuthComplete}\n ></elicitation-modal>\n `;\n }\n\n private _renderContent() {\n if (this._view === 'diagnostics') {\n return html`\n <div style=\"margin-bottom: var(--space-md);\">\n <button\n style=\"background:none; border:none; color:var(--accent-secondary); cursor:pointer;\"\n @click=${() => (this._view = 'list')}\n >\n \u2190 Back to Dashboard\n </button>\n </div>\n <h1 class=\"text-gradient\">Diagnostics</h1>\n <p style=\"color: var(--t-muted); margin-bottom: var(--space-lg);\">\n Server health and photon status.\n </p>\n ${this._renderDiagnostics()}\n `;\n }\n\n if (this._view === 'marketplace') {\n const globalMethods = this._globalStaticMethods;\n\n return html`\n <div style=\"margin-bottom: var(--space-md);\">\n <button\n style=\"background:none; border:none; color:var(--accent-secondary); cursor:pointer;\"\n @click=${() => (this._view = 'list')}\n >\n \u2190 Back to Dashboard\n </button>\n </div>\n <h1 class=\"text-gradient\">Marketplace</h1>\n <p style=\"color: var(--t-muted); margin-bottom: var(--space-lg);\">\n Discover and install new Photons.\n </p>\n\n ${globalMethods.length > 0\n ? html`\n <h3\n style=\"color: var(--t-muted); text-transform: uppercase; font-size: 0.8rem; letter-spacing: 0.1em; margin-bottom: var(--space-md);\"\n >\n Actions\n </h3>\n <div class=\"cards-grid\" style=\"margin-bottom: var(--space-xl);\">\n ${globalMethods.map(\n ({ photon, method }) => html`\n <method-card\n .method=${method}\n .photonName=${photon.name}\n @select=${() => this._handleGlobalMethodSelect(photon, method)}\n ></method-card>\n `\n )}\n </div>\n `\n : ''}\n\n <marketplace-view\n @install=${this._handleInstall}\n @maker-action=${this._handleMakerAction}\n ></marketplace-view>\n `;\n }\n\n if (!this._selectedPhoton) {\n const userPhotons = this._photons.filter((p) => !p.internal);\n const configuredPhotons = userPhotons.filter((p) => p.configured);\n const unconfiguredPhotons = userPhotons.filter((p) => !p.configured);\n\n // No user photons at all \u2014 show welcome wizard\n if (userPhotons.length === 0) {\n if (this._welcomePhase === 'marketplace') {\n return html`\n <div style=\"margin-bottom: var(--space-md);\">\n <button\n style=\"background:none; border:none; color:var(--accent-secondary); cursor:pointer;\"\n @click=${() => (this._welcomePhase = 'welcome')}\n >\n \u2190 Back to Welcome\n </button>\n </div>\n <h1 class=\"text-gradient\">Marketplace</h1>\n <p style=\"color: var(--t-muted); margin-bottom: var(--space-lg);\">\n Discover and install a photon to get started.\n </p>\n <marketplace-view\n @install=${this._handleInstall}\n @maker-action=${this._handleMakerAction}\n ></marketplace-view>\n `;\n }\n\n // Phase 1: Welcome screen with two paths\n return html`\n <div style=\"display:flex; flex-direction:column; align-items:center; justify-content:center; min-height:60vh; text-align:center;\">\n <h1 class=\"text-gradient\" style=\"font-size:2rem; margin-bottom: var(--space-sm);\">\n Welcome to Photon Beam\n </h1>\n <p style=\"color: var(--t-muted); font-size: 1.05rem; max-width: 520px; margin: 0 auto var(--space-xl) auto; line-height: 1.6;\">\n Photon lets you build and run MCP tools \u2014 callable from\n Claude, Cursor, or any AI assistant.\n </p>\n <div style=\"display:grid; grid-template-columns: 1fr 1fr; gap: var(--space-lg); max-width: 520px; width:100%;\">\n <button\n class=\"glass-panel\"\n style=\"padding: var(--space-lg); border:1px solid var(--border-glass); cursor:pointer; text-align:center; transition: border-color 0.2s, box-shadow 0.2s;\"\n @mouseenter=${(e: Event) => (e.currentTarget as HTMLElement).style.borderColor = 'var(--accent-primary)'}\n @mouseleave=${(e: Event) => (e.currentTarget as HTMLElement).style.borderColor = 'var(--border-glass)'}\n @click=${() => (this._welcomePhase = 'marketplace')}\n >\n <div style=\"font-size: 2rem; margin-bottom: var(--space-sm);\">\uD83D\uDCE6</div>\n <div style=\"font-weight:600; font-size:1.05rem; margin-bottom: var(--space-xs); color: var(--t-primary);\">Browse & Install</div>\n <div style=\"color: var(--t-muted); font-size: 0.85rem; line-height:1.5;\">\n Install a ready-made photon from the marketplace\n </div>\n </button>\n <button\n class=\"glass-panel\"\n style=\"padding: var(--space-lg); border:1px solid var(--border-glass); cursor:pointer; text-align:center; transition: border-color 0.2s, box-shadow 0.2s;\"\n @mouseenter=${(e: Event) => (e.currentTarget as HTMLElement).style.borderColor = 'var(--accent-primary)'}\n @mouseleave=${(e: Event) => (e.currentTarget as HTMLElement).style.borderColor = 'var(--border-glass)'}\n @click=${() => this._handleMakerAction(new CustomEvent('maker-action', { detail: { action: 'wizard' } }))}\n >\n <div style=\"font-size: 2rem; margin-bottom: var(--space-sm);\">\uD83D\uDEE0\uFE0F</div>\n <div style=\"font-weight:600; font-size:1.05rem; margin-bottom: var(--space-xs); color: var(--t-primary);\">Create Your Own</div>\n <div style=\"color: var(--t-muted); font-size: 0.85rem; line-height:1.5;\">\n Build a custom photon from scratch with the guided wizard\n </div>\n </button>\n </div>\n </div>\n `;\n }\n\n // Has user photons but none selected \u2014 show dashboard overview\n return html`\n <h1 class=\"text-gradient\" style=\"margin-bottom: var(--space-lg);\">\n Welcome to Photon Beam\n </h1>\n\n <div\n style=\"display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--space-md); margin-bottom: var(--space-lg);\"\n >\n <div class=\"glass-panel\" style=\"padding: var(--space-lg);\">\n <h3 style=\"margin-bottom: var(--space-sm);\">Your Photons</h3>\n <p style=\"color: var(--t-muted); font-size: 0.9rem; margin-bottom: var(--space-sm);\">\n ${configuredPhotons.length} configured\n photon${configuredPhotons.length !== 1 ? 's' : ''}\n </p>\n ${configuredPhotons.length > 0\n ? html`<div style=\"font-size: 0.85rem; color: var(--t-secondary);\">\n ${configuredPhotons\n .slice(0, 5)\n .map(\n (p) => html`<div style=\"padding: 2px 0;\">${p.icon || '\u26A1'} ${p.name}</div>`\n )}\n ${configuredPhotons.length > 5\n ? html`<div style=\"color: var(--t-muted);\">\n +${configuredPhotons.length - 5} more\n </div>`\n : ''}\n </div>`\n : html`<p style=\"color: var(--t-muted); font-size: 0.85rem;\">\n No photons configured yet.\n </p>`}\n </div>\n\n <div class=\"glass-panel\" style=\"padding: var(--space-lg);\">\n <h3 style=\"margin-bottom: var(--space-sm);\">Browse Marketplace</h3>\n <p style=\"color: var(--t-muted); font-size: 0.9rem; margin-bottom: var(--space-md);\">\n Discover and install new photons.\n </p>\n <button class=\"btn-primary\" @click=${() => (this._view = 'marketplace')}>\n Explore\n </button>\n </div>\n\n <div class=\"glass-panel\" style=\"padding: var(--space-lg);\">\n <h3 style=\"margin-bottom: var(--space-sm);\">Keyboard Shortcuts</h3>\n <p style=\"color: var(--t-muted); font-size: 0.9rem; margin-bottom: var(--space-sm);\">\n Press\n <kbd\n style=\"padding: 2px 6px; background: var(--bg-glass); border: 1px solid var(--border-glass); border-radius: 4px; font-size: 0.85rem;\"\n >?</kbd\n >\n to see all shortcuts.\n </p>\n </div>\n </div>\n\n ${unconfiguredPhotons.length > 0\n ? html`\n <div\n class=\"glass-panel\"\n style=\"padding: var(--space-lg); border-left: 3px solid hsl(45, 80%, 50%);\"\n >\n <h3 style=\"margin-bottom: var(--space-sm);\">Setup Required</h3>\n <p\n style=\"color: var(--t-muted); font-size: 0.9rem; margin-bottom: var(--space-sm);\"\n >\n ${unconfiguredPhotons.length}\n photon${unconfiguredPhotons.length !== 1 ? 's need' : ' needs'} configuration.\n </p>\n <div style=\"font-size: 0.85rem; color: var(--t-secondary);\">\n ${unconfiguredPhotons.map(\n (p) =>\n html`<div\n style=\"padding: 2px 0; cursor: pointer;\"\n @click=${() => {\n this._selectedPhoton = p;\n this._view = 'config';\n }}\n >\n \u26A0\uFE0F ${p.name}\n </div>`\n )}\n </div>\n </div>\n `\n : ''}\n `;\n }\n\n // Show configuration view for unconfigured photons or edit mode\n if (this._view === 'config' || this._selectedPhoton.configured === false) {\n return html`\n <div class=\"glass-panel\" style=\"padding: var(--space-lg); max-width: 600px;\">\n <photon-config\n .photon=${this._selectedPhoton}\n .mode=${this._selectedPhoton.configured === false ? 'initial' : this._configMode}\n @configure=${this._handleConfigure}\n ></photon-config>\n </div>\n `;\n }\n\n if (this._view === 'form' && this._selectedMethod) {\n // Check for Linked UI (Custom Interface)\n if (this._selectedMethod.linkedUi) {\n const isAppMain = this._selectedPhoton.isApp && this._selectedMethod.name === 'main';\n const otherMethods = isAppMain\n ? (this._selectedPhoton.methods || []).filter((m: any) => m.name !== 'main')\n : [];\n\n return html`\n ${!isAppMain\n ? html`\n <div style=\"margin-bottom: var(--space-md);\">\n <button\n style=\"background:none; border:none; color:var(--accent-secondary); cursor:pointer;\"\n @click=${() => this._handleBackFromMethod()}\n >\n \u2190 Back to ${this._selectedPhoton.internal ? 'Marketplace' : this._selectedPhoton.isApp ? this._selectedPhoton.name : 'Methods'}\n </button>\n </div>\n `\n : ''}\n <div\n class=\"glass-panel\"\n style=\"padding: 0; overflow: hidden; min-height: calc(100vh - 80px);\"\n >\n <custom-ui-renderer\n .photon=${this._selectedPhoton.name}\n .method=${this._selectedMethod.name}\n .uiId=${this._selectedMethod.linkedUi}\n .theme=${this._theme}\n style=\"height: calc(100vh - 80px);\"\n ></custom-ui-renderer>\n </div>\n\n ${isAppMain && otherMethods.length > 0\n ? html`\n <div\n style=\"margin-top: var(--space-xl); padding-top: var(--space-xl); border-top: 1px solid var(--border-glass);\"\n >\n <div\n style=\"display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-lg);\"\n >\n <div style=\"display: flex; align-items: center; gap: var(--space-sm);\">\n <span style=\"font-size: 1.5rem;\"\n >${this._selectedPhoton.appEntry?.icon || '\uD83D\uDCF1'}</span\n >\n <h3 style=\"margin: 0; font-size: 1.2rem; color: var(--t-primary);\">\n ${this._selectedPhoton.name}\n </h3>\n </div>\n ${this._renderActionToolbar({\n showLaunchApp: true,\n showReconfigure: false,\n showRememberValues: false,\n showRename: false,\n showViewSource: false,\n showDelete: false,\n showRemove: true,\n showHelp: false,\n showRunTests: false,\n })}\n </div>\n <h4\n style=\"color: var(--t-muted); text-transform: uppercase; font-size: 0.75rem; letter-spacing: 0.1em; margin-bottom: var(--space-md);\"\n >\n Methods\n </h4>\n <div class=\"cards-grid\">\n ${otherMethods.map(\n (method: any) => html`\n <method-card\n .method=${method}\n .photonName=${this._selectedPhoton.name}\n @select=${this._handleMethodSelect}\n @update-metadata=${this._handleMethodMetadataUpdate}\n ></method-card>\n `\n )}\n </div>\n </div>\n `\n : ''}\n `;\n }\n\n // Default Form Interface\n const isAppMethod = this._selectedPhoton.isApp && this._selectedPhoton.appEntry;\n const isInternalPhoton = this._selectedPhoton.internal;\n const backLabel = isInternalPhoton\n ? '\u2190 Back'\n : isAppMethod\n ? `\u2190 Back to ${this._selectedPhoton.name}`\n : '\u2190 Back to Methods';\n\n return html`\n <div class=\"header-toolbar\">\n <div class=\"header-left\">\n <button\n style=\"background:none; border:none; color:var(--accent-secondary); cursor:pointer;\"\n @click=${() => this._handleBackFromMethod()}\n >\n ${backLabel}\n </button>\n </div>\n ${this._renderActionToolbar({\n showRename: false,\n showViewSource: false,\n showDelete: false,\n })}\n </div>\n ${this._renderMethodContent()}\n `;\n }\n\n return html`\n <div class=\"header-toolbar\">\n <div class=\"header-left\"></div>\n ${this._renderActionToolbar()}\n </div>\n\n ${this._renderPhotonHeader()}\n\n <h3\n style=\"color: var(--t-muted); text-transform: uppercase; font-size: 0.8rem; letter-spacing: 0.1em;\"\n >\n Methods\n </h3>\n <div class=\"cards-grid\">\n ${(this._selectedPhoton.methods || []).map(\n (method: any) => html`\n <method-card\n .method=${method}\n .photonName=${this._selectedPhoton.name}\n @select=${this._handleMethodSelect}\n @update-metadata=${this._handleMethodMetadataUpdate}\n ></method-card>\n `\n )}\n </div>\n\n ${this._testResults.length > 0\n ? html`\n <div class=\"glass-panel\" style=\"padding: var(--space-md); margin-top: var(--space-md);\">\n <h4 style=\"margin-bottom: var(--space-sm);\">Test Results</h4>\n ${this._testResults.map(\n (r) => html`\n <div\n style=\"display: flex; align-items: center; gap: var(--space-sm); padding: 4px 0; font-size: 0.85rem;\"\n >\n <span>${r.passed ? '\u2705' : '\u274C'}</span>\n <span style=\"flex: 1;\">${r.method}</span>\n ${r.duration != null\n ? html`<span style=\"color: var(--t-muted); font-size: 0.75rem;\"\n >${r.duration}ms</span\n >`\n : ''}\n ${r.error\n ? html`<span style=\"color: #f87171; font-size: 0.75rem;\">${r.error}</span>`\n : ''}\n </div>\n `\n )}\n <div style=\"margin-top: var(--space-sm); color: var(--t-muted); font-size: 0.8rem;\">\n ${this._testResults.filter((r) => r.passed).length}/${this._testResults.length}\n passed\n </div>\n </div>\n `\n : ''}\n ${this._renderPromptsSection()} ${this._renderResourcesSection()}\n `;\n }\n\n // ===== Mobile Sidebar Methods =====\n private _toggleSidebar() {\n this._sidebarVisible = !this._sidebarVisible;\n }\n\n private _closeSidebar() {\n this._sidebarVisible = false;\n }\n\n private _handlePhotonSelectMobile(e: CustomEvent) {\n this._closeSidebar();\n this._handlePhotonSelect(e);\n }\n\n private _handleMarketplaceMobile() {\n this._closeSidebar();\n this._view = 'marketplace';\n }\n\n private _handlePhotonSelect(e: CustomEvent) {\n this._selectedPhoton = e.detail.photon;\n this._selectedMethod = null;\n this._lastResult = null;\n\n // For unconfigured photons, show configuration view\n if (this._selectedPhoton.configured === false) {\n this._view = 'config';\n this._updateHash();\n return;\n }\n\n // For Apps, automatically select the main method to show Custom UI\n if (this._selectedPhoton.isApp && this._selectedPhoton.appEntry) {\n this._selectedMethod = this._selectedPhoton.appEntry;\n this._view = 'form';\n } else {\n this._view = 'list';\n }\n this._updateHash();\n }\n\n private _handleMethodSelect(e: CustomEvent) {\n // Teardown any active custom-ui-renderer before switching methods\n this._teardownActiveCustomUI();\n this._selectedMethod = e.detail.method;\n this._lastResult = null;\n this._view = 'form';\n this._updateHash();\n\n // Auto-invoke if method has autorun or has no required parameters\n this._maybeAutoInvoke(e.detail.method);\n }\n\n /**\n * Check if method is an HTML UI that should show in minimal \"UI mode\"\n * (no form controls, just the rendered HTML)\n */\n /**\n * Trigger teardown on any active custom-ui-renderer before switching methods\n */\n private _teardownActiveCustomUI(): void {\n const renderer = this.shadowRoot?.querySelector('custom-ui-renderer') as any;\n if (renderer?.teardown) {\n renderer.teardown().catch(() => {});\n }\n }\n\n private _isHtmlUiMode(): boolean {\n if (!this._selectedMethod) return false;\n\n const isHtmlFormat = this._selectedMethod.outputFormat === 'html';\n const hasResult = this._lastResult !== null;\n\n // Check if method has no required parameters\n const params = this._selectedMethod.params || {};\n const required = params.required || [];\n const properties = params.properties || {};\n const hasNoRequiredParams = required.length === 0 && Object.keys(properties).length === 0;\n\n return isHtmlFormat && hasResult && hasNoRequiredParams;\n }\n\n /**\n * Render the method content - either as a minimal HTML UI or full form\n */\n private _renderMethodContent() {\n // HTML UI mode: minimal chrome, just show the interactive content\n if (this._isHtmlUiMode()) {\n return html`\n <div class=\"glass-panel html-ui-panel\" style=\"padding: 0; overflow: hidden;\">\n <result-viewer\n .result=${this._lastResult}\n .outputFormat=${this._selectedMethod?.outputFormat}\n .layoutHints=${this._selectedMethod?.layoutHints}\n .theme=${this._theme}\n @share=${this._handleShareResult}\n ></result-viewer>\n </div>\n `;\n }\n\n // Standard form mode\n return html`\n <div class=\"glass-panel\" style=\"padding: var(--space-lg);\">\n <h2 style=\"margin-top:0;\">${this._selectedMethod.name}</h2>\n <p style=\"color: var(--t-muted);\">${this._selectedMethod.description}</p>\n <invoke-form\n .params=${this._selectedMethod.params}\n .loading=${this._isExecuting}\n .photonName=${this._selectedPhoton.name}\n .methodName=${this._selectedMethod.name}\n .rememberValues=${this._rememberFormValues}\n .sharedValues=${this._sharedFormParams}\n @submit=${this._handleExecute}\n @cancel=${() => this._handleBackFromMethod()}\n ></invoke-form>\n\n ${this._progress\n ? html`\n <div class=\"progress-container\">\n <div class=\"progress-bar-wrapper\">\n <div\n class=\"progress-bar ${this._progress.value < 0 ? 'indeterminate' : ''}\"\n style=\"width: ${this._progress.value < 0\n ? '30%'\n : Math.round(this._progress.value * 100) + '%'}\"\n ></div>\n </div>\n <div class=\"progress-text\">\n <span>${this._progress.message}</span>\n ${this._progress.value >= 0\n ? html`\n <span class=\"progress-percentage\"\n >${Math.round(this._progress.value * 100)}%</span\n >\n `\n : ''}\n </div>\n </div>\n `\n : ''}\n ${this._lastResult !== null\n ? html`\n <result-viewer\n .result=${this._lastResult}\n .outputFormat=${this._selectedMethod?.outputFormat}\n .layoutHints=${this._selectedMethod?.layoutHints}\n .theme=${this._theme}\n @share=${this._handleShareResult}\n ></result-viewer>\n `\n : ''}\n </div>\n `;\n }\n\n /**\n * Check if a method should auto-invoke and invoke it if so.\n * Auto-invokes when: method.autorun === true OR method has no required parameters\n */\n private _maybeAutoInvoke(method: any) {\n if (!method || !this._mcpReady) return;\n\n // Check if method should autorun\n const shouldAutorun = method.autorun === true;\n\n // Check if method has no required parameters\n const params = method.params || {};\n const required = params.required || [];\n const properties = params.properties || {};\n const hasNoRequiredParams = required.length === 0 && Object.keys(properties).length === 0;\n\n if (shouldAutorun || hasNoRequiredParams) {\n // Auto-invoke with empty args\n this._handleExecute(new CustomEvent('execute', { detail: { args: {} } }));\n }\n }\n\n private _handleBackFromMethod() {\n if (this._selectedPhoton.isApp && this._selectedPhoton.appEntry) {\n // For Apps, go back to the main Custom UI and scroll to methods\n this._selectedMethod = this._selectedPhoton.appEntry;\n this._view = 'form';\n this._updateHash();\n\n // Scroll to methods section after render\n this.updateComplete.then(() => {\n setTimeout(() => {\n const mainArea = this.shadowRoot?.querySelector('.main-area');\n if (mainArea) {\n // Scroll past the Custom UI to show methods\n mainArea.scrollTo({ top: mainArea.scrollHeight, behavior: 'smooth' });\n }\n }, SCROLL_RENDER_DELAY_MS);\n });\n } else if (this._selectedPhoton.internal) {\n // For internal photons, go back to welcome screen\n this._selectedMethod = null;\n this._selectedPhoton = null;\n this._welcomePhase = 'welcome';\n this._view = 'list';\n this._updateHash();\n } else {\n // For regular photons, go back to methods list\n this._view = 'list';\n this._selectedMethod = null;\n this._updateHash();\n }\n }\n\n private _toggleSettingsMenu = () => {\n this._showSettingsMenu = !this._showSettingsMenu;\n };\n\n private _closeSettingsMenu = () => {\n this._showSettingsMenu = false;\n };\n\n private _handleRefresh = async () => {\n this._closeSettingsMenu();\n // Reload the current photon via MCP\n if (this._selectedPhoton && this._mcpReady) {\n showToast(`Reloading ${this._selectedPhoton.name}...`, 'info');\n const result = await mcpClient.reloadPhoton(this._selectedPhoton.name);\n if (!result.success) {\n showToast(result.error || 'Reload failed', 'error');\n }\n }\n };\n\n private _launchAsApp = () => {\n this._closeSettingsMenu();\n if (this._selectedPhoton) {\n window.open(`/api/pwa/app?photon=${encodeURIComponent(this._selectedPhoton.name)}`, '_blank');\n }\n };\n\n private _handleRemove = async () => {\n this._closeSettingsMenu();\n if (this._selectedPhoton && this._mcpReady) {\n if (confirm(`Remove ${this._selectedPhoton.name} from this workspace?`)) {\n const result = await mcpClient.removePhoton(this._selectedPhoton.name);\n if (!result.success) {\n showToast(result.error || 'Remove failed', 'error');\n }\n }\n }\n };\n\n private _handleCopyMCPConfig = async () => {\n if (!this._selectedPhoton) return;\n try {\n const res = await fetch(\n `/api/export/mcp-config?photon=${encodeURIComponent(this._selectedPhoton.name)}`,\n {\n signal: AbortSignal.timeout(FETCH_TIMEOUT_MS),\n }\n );\n if (!res.ok) throw new Error('Failed to fetch config');\n const config = await res.json();\n await navigator.clipboard.writeText(JSON.stringify(config, null, 2));\n showToast('MCP config copied \u2014 paste into Claude Desktop settings', 'success');\n } catch (error) {\n console.warn('Copy MCP config failed:', error);\n showToast('Failed to copy MCP config', 'error');\n }\n };\n\n private _handleUpgrade = async () => {\n if (!this._selectedPhoton) return;\n const name = this._selectedPhoton.name;\n showToast(`Upgrading ${name}...`, 'info');\n\n try {\n const res = await fetch('/api/marketplace/add', {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ name }),\n signal: AbortSignal.timeout(FETCH_TIMEOUT_MS),\n });\n\n if (!res.ok) throw new Error('Upgrade failed');\n const result = await res.json();\n\n showToast(`${name} upgraded${result.version ? ` to ${result.version}` : ''}`, 'success');\n\n // Clear hasUpdate flag\n this._photons = this._photons.map((p) => (p.name === name ? { ...p, hasUpdate: false } : p));\n this._updatesAvailable = this._updatesAvailable.filter((u) => u.name !== name);\n if (this._selectedPhoton?.name === name) {\n this._selectedPhoton = { ...this._selectedPhoton, hasUpdate: false };\n }\n } catch (error) {\n console.warn('Upgrade failed:', error);\n showToast(\n `Failed to upgrade ${name}. Check marketplace connectivity and try again.`,\n 'error'\n );\n }\n };\n\n private _handleReconfigure = () => {\n this._closeSettingsMenu();\n this._configMode = this._selectedPhoton?.configured ? 'edit' : 'initial';\n this._view = 'config';\n this._updateHash();\n };\n\n private _toggleRememberValues = () => {\n this._rememberFormValues = !this._rememberFormValues;\n localStorage.setItem('beam-remember-values', String(this._rememberFormValues));\n showToast(\n this._rememberFormValues\n ? 'Form values will be remembered'\n : 'Form values will not be remembered',\n 'info'\n );\n };\n\n private _toggleVerboseLogging = () => {\n this._verboseLogging = !this._verboseLogging;\n localStorage.setItem('beam-verbose-logging', String(this._verboseLogging));\n showToast(\n this._verboseLogging ? 'Verbose logging enabled' : 'Verbose logging disabled',\n 'info'\n );\n };\n\n // Maker instance method handlers - operate on the current photon\n private _handleRenamePhoton = () => {\n this._closeSettingsMenu();\n const currentName = this._selectedPhoton?.name || '';\n const newName = prompt(`Enter new name for \"${currentName}\":`, currentName);\n if (newName && newName !== currentName) {\n this._invokeMakerMethod('rename', { name: newName });\n }\n };\n\n private _handleViewSource = async () => {\n this._closeSettingsMenu();\n\n const maker = this._photons.find((p) => p.name === 'maker');\n if (!maker) {\n this._showError('Photon not found', 'Maker photon not available');\n return;\n }\n\n const photonPath = this._selectedPhoton?.path;\n if (!photonPath) {\n showToast('Photon path not available', 'error');\n return;\n }\n\n if (this._mcpReady) {\n try {\n const result = await mcpClient.callTool('maker/source', { photonPath });\n if (result.isError) {\n const errorText =\n result.content.find((c: any) => c.type === 'text')?.text || 'Failed to load source';\n showToast(errorText, 'error');\n } else {\n const data = mcpClient.parseToolResult(result);\n if (data && data.code) {\n this._sourceData = data;\n this._showSourceModal = true;\n } else {\n showToast('No source code returned', 'error');\n }\n }\n } catch (error) {\n showToast(error instanceof Error ? error.message : 'Failed to load source', 'error');\n }\n }\n };\n\n private _handleDeletePhoton = () => {\n this._closeSettingsMenu();\n if (\n confirm(\n `Are you sure you want to delete \"${this._selectedPhoton?.name}\"? This cannot be undone.`\n )\n ) {\n this._invokeMakerMethod('delete');\n }\n };\n\n private async _invokeMakerMethod(methodName: string, additionalArgs: Record<string, any> = {}) {\n // Find maker photon\n const maker = this._photons.find((p) => p.name === 'maker');\n if (!maker) {\n this._showError('Photon not found', 'Maker photon not available');\n return;\n }\n\n // Invoke the maker method with the current photon's path\n const photonPath = this._selectedPhoton?.path;\n if (!photonPath) {\n showToast('Photon path not available', 'error');\n return;\n }\n\n this._log('info', `Invoking maker.${methodName} on ${this._selectedPhoton?.name}...`, true);\n\n // Use MCP to invoke the maker method\n if (this._mcpReady) {\n try {\n const toolName = `maker/${methodName}`;\n const result = await mcpClient.callTool(toolName, { photonPath, ...additionalArgs });\n\n if (result.isError) {\n const errorText = result.content.find((c) => c.type === 'text')?.text || 'Unknown error';\n this._log('error', errorText);\n showToast(errorText, 'error', 5000);\n } else {\n const data = mcpClient.parseToolResult(result);\n this._log('success', `maker.${methodName} completed`);\n // Handle result if needed\n if (methodName === 'source' && data) {\n // Show source in a new window or modal\n console.log('Source:', data);\n }\n }\n } catch (error) {\n const message = error instanceof Error ? error.message : 'Unknown error';\n this._log('error', message);\n showToast(message, 'error', 5000);\n }\n }\n }\n\n private async _handleExecute(e: CustomEvent) {\n const args = e.detail.args;\n this._lastFormParams = args; // Store for sharing\n this._sharedFormParams = null; // Clear shared params after use\n this._log('info', `Invoking ${this._selectedMethod.name}...`, true);\n this._lastResult = null;\n this._isExecuting = true;\n this._progress = null;\n\n // Use MCP for all tool invocations\n if (this._mcpReady) {\n try {\n const toolName = `${this._selectedPhoton.name}/${this._selectedMethod.name}`;\n const result = await mcpClient.callTool(toolName, args);\n\n if (result.isError) {\n const errorText = result.content.find((c) => c.type === 'text')?.text || 'Unknown error';\n this._log('error', errorText);\n showToast(errorText, 'error', 5000);\n } else {\n this._lastResult = mcpClient.parseToolResult(result);\n this._log('success', 'Execution completed');\n }\n } catch (error) {\n const message = error instanceof Error ? error.message : 'Unknown error';\n this._log('error', message);\n showToast(message, 'error', 5000);\n } finally {\n this._isExecuting = false;\n this._progress = null;\n }\n } else {\n this._log('error', 'Not connected to server');\n this._showError('Not connected');\n this._isExecuting = false;\n this._progress = null;\n }\n }\n\n private async _handleConfigure(e: CustomEvent) {\n const { photon, config } = e.detail;\n this._log('info', `Configuring ${photon}...`);\n\n if (this._mcpReady) {\n const result = await mcpClient.configurePhoton(photon, config);\n if (!result.success) {\n this._log('error', result.error || 'Configuration failed');\n this._showError('Configuration failed', result.error);\n }\n // Success notification will come via SSE beam/configured\n } else {\n this._log('error', 'Not connected to server');\n this._showError('Not connected');\n }\n }\n /**\n * Forward a message to all custom-ui-renderer iframes\n */\n private _forwardToIframes(message: any): void {\n const iframes: HTMLIFrameElement[] = [];\n this.shadowRoot?.querySelectorAll('custom-ui-renderer').forEach((renderer) => {\n const iframe = renderer.shadowRoot?.querySelector('iframe');\n if (iframe) iframes.push(iframe);\n });\n this.shadowRoot?.querySelectorAll('iframe').forEach((iframe) => iframes.push(iframe));\n iframes.forEach((iframe) => {\n iframe.contentWindow?.postMessage(message, '*');\n });\n }\n\n private _handleBridgeMessage = async (event: MessageEvent) => {\n const msg = event.data;\n if (!msg || typeof msg !== 'object') return;\n\n // MCP Apps standard: JSON-RPC tools/call from iframes\n if (msg.jsonrpc === '2.0' && msg.method === 'tools/call' && msg.id != null) {\n if (this._selectedPhoton && this._mcpReady) {\n const toolName = `${this._selectedPhoton.name}/${msg.params?.name}`;\n try {\n const mcpResult = await mcpClient.callTool(toolName, msg.params?.arguments || {});\n if (mcpResult.isError) {\n const errorText =\n mcpResult.content?.find((c) => c.type === 'text')?.text || 'Tool call failed';\n if (event.source) {\n (event.source as Window).postMessage(\n { jsonrpc: '2.0', id: msg.id, error: { code: -32000, message: errorText } },\n '*'\n );\n }\n } else {\n // Parse MCP content envelope into actual data for the iframe\n const parsed = mcpClient.parseToolResult(mcpResult);\n if (event.source) {\n (event.source as Window).postMessage(\n { jsonrpc: '2.0', id: msg.id, result: parsed },\n '*'\n );\n }\n }\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : 'Unknown error';\n if (event.source) {\n (event.source as Window).postMessage(\n {\n jsonrpc: '2.0',\n id: msg.id,\n error: { code: -32000, message: errorMessage },\n },\n '*'\n );\n }\n }\n }\n }\n\n // MCP Apps standard: JSON-RPC ui/update-model-context from iframes\n if (msg.jsonrpc === '2.0' && msg.method === 'ui/update-model-context' && msg.id != null) {\n // Store model context for future conversation turns\n this._modelContext = msg.params || null;\n if (event.source) {\n (event.source as Window).postMessage({ jsonrpc: '2.0', id: msg.id, result: {} }, '*');\n }\n }\n\n // MCP Apps standard: JSON-RPC ui/ready from iframes (acknowledgement)\n if (msg.jsonrpc === '2.0' && msg.method === 'ui/ready') {\n // iframe bridge is ready \u2014 no action needed\n }\n\n // Handle app state persistence\n if (msg.type === 'photon:set-state') {\n if (this._selectedPhoton && this._selectedMethod) {\n const stateKey = `beam-app-state:${this._selectedPhoton.name}:${this._selectedMethod.name}`;\n try {\n localStorage.setItem(stateKey, JSON.stringify(msg.state));\n } catch (e) {\n console.warn('Failed to persist app state:', e);\n }\n }\n }\n\n // Handle request for persisted state\n if (msg.type === 'photon:get-state') {\n if (this._selectedPhoton && this._selectedMethod && event.source) {\n const stateKey = `beam-app-state:${this._selectedPhoton.name}:${this._selectedMethod.name}`;\n try {\n const savedState = localStorage.getItem(stateKey);\n const state = savedState ? JSON.parse(savedState) : null;\n (event.source as Window).postMessage(\n {\n type: 'photon:init-state',\n state,\n },\n '*'\n );\n } catch (e) {\n console.warn('Failed to load app state:', e);\n }\n }\n }\n\n // Handle custom UI notifying what resource it's viewing\n // This enables on-demand channel subscriptions\n // photonId: hash of photon path (from selected photon)\n // itemId: whatever the photon uses to identify the item (e.g., board name)\n if (msg.type === 'photon:viewing') {\n const photonId = this._selectedPhoton?.id;\n const itemId = msg.itemId || msg.board; // Support both new and legacy field names\n if (photonId && itemId) {\n mcpClient.notifyViewing(photonId, itemId);\n }\n }\n\n // ChatGPT Apps SDK: uploadFile\n if (msg.type === 'photon:upload-file' && event.source) {\n const callId = msg.callId;\n const fileId = `file_${++this._fileIdCounter}_${Date.now()}`;\n\n // Store the file data\n this._uploadedFiles.set(fileId, {\n data: msg.data,\n fileName: msg.fileName,\n fileType: msg.fileType,\n });\n\n // Send response\n (event.source as Window).postMessage(\n { type: 'photon:upload-file-response', callId, fileId },\n '*'\n );\n }\n\n // ChatGPT Apps SDK: getFileDownloadUrl\n if (msg.type === 'photon:get-file-url' && event.source) {\n const callId = msg.callId;\n const file = this._uploadedFiles.get(msg.fileId);\n\n if (file) {\n // The file.data is already a data URL from FileReader.readAsDataURL\n (event.source as Window).postMessage(\n { type: 'photon:get-file-url-response', callId, url: file.data },\n '*'\n );\n } else {\n (event.source as Window).postMessage(\n { type: 'photon:get-file-url-response', callId, error: 'File not found' },\n '*'\n );\n }\n }\n\n // ChatGPT Apps SDK: requestModal\n if (msg.type === 'photon:request-modal' && event.source) {\n const callId = msg.callId;\n\n // For now, show a simple elicitation modal with the template as message\n // In the future, this could render custom modal templates\n this._elicitationData = {\n type: 'confirm',\n message: msg.template || 'Modal Request',\n elicitationId: callId,\n ...msg.params,\n } as ElicitationData;\n this._showElicitation = true;\n\n // Store the source window to respond later\n this._pendingBridgeCalls.set(callId, event.source as Window);\n }\n\n // ChatGPT Apps SDK: setOpenInAppUrl\n if (msg.type === 'photon:set-open-in-app-url') {\n this._openInAppUrl = msg.href;\n this._log('info', `Open-in-app URL set: ${msg.href}`);\n }\n\n // Handle display mode request\n if (msg.type === 'photon:request-display-mode') {\n // For now, just log it - could implement fullscreen/pip in future\n this._log('info', `Display mode requested: ${msg.mode}`);\n }\n\n // Handle height notification\n if (msg.type === 'photon:notify-height') {\n // Could be used to adjust iframe height dynamically\n this._log('debug', `Custom UI height notification: ${msg.height}px`);\n }\n };\n\n // ===== Share Result Link =====\n private _handleShareResult() {\n if (!this._selectedPhoton || !this._selectedMethod) {\n showToast('No method selected to share', 'error');\n return;\n }\n\n // Build shareable URL with hash and query params\n const baseUrl = window.location.origin + window.location.pathname;\n const hash = `${this._selectedPhoton.name}/${this._selectedMethod.name}`;\n\n // Encode form parameters as query string\n const params = new URLSearchParams();\n for (const [key, value] of Object.entries(this._lastFormParams)) {\n if (value !== undefined && value !== null && value !== '') {\n // Handle objects/arrays by JSON encoding\n if (typeof value === 'object') {\n params.set(key, JSON.stringify(value));\n } else {\n params.set(key, String(value));\n }\n }\n }\n\n let shareUrl = `${baseUrl}#${hash}`;\n if (params.toString()) {\n shareUrl += `?${params.toString()}`;\n }\n\n // Copy to clipboard\n navigator.clipboard\n .writeText(shareUrl)\n .then(() => {\n showToast('Share link copied to clipboard', 'success');\n })\n .catch(() => {\n // Fallback: show URL in prompt\n prompt('Copy this link to share:', shareUrl);\n });\n }\n\n private _handleThemeChange = (e: CustomEvent) => {\n const newTheme = e.detail.theme as Theme;\n this._theme = newTheme;\n localStorage.setItem(THEME_STORAGE_KEY, newTheme);\n this._applyTheme();\n this._broadcastThemeToIframes();\n };\n\n private _handleElicitationSubmit = async (e: CustomEvent) => {\n const { value } = e.detail;\n const elicitationId = (this._elicitationData as any)?.elicitationId;\n\n this._showElicitation = false;\n this._elicitationData = null;\n\n // Check if this is a ChatGPT SDK modal request\n const pendingWindow = elicitationId ? this._pendingBridgeCalls.get(elicitationId) : null;\n if (pendingWindow) {\n this._pendingBridgeCalls.delete(elicitationId);\n pendingWindow.postMessage(\n { type: 'photon:request-modal-response', callId: elicitationId, result: value },\n '*'\n );\n return;\n }\n\n if (elicitationId && this._mcpReady) {\n const result = await mcpClient.sendElicitationResponse(elicitationId, value);\n if (result.success) {\n this._log('info', 'Input submitted');\n } else {\n this._log('error', 'Failed to submit input');\n showToast('Failed to submit input', 'error');\n }\n } else {\n this._log('info', 'Input submitted');\n }\n };\n\n private _handleElicitationCancel = async () => {\n const elicitationId = (this._elicitationData as any)?.elicitationId;\n\n this._showElicitation = false;\n this._elicitationData = null;\n this._isExecuting = false;\n\n // Check if this is a ChatGPT SDK modal request\n const pendingWindow = elicitationId ? this._pendingBridgeCalls.get(elicitationId) : null;\n if (pendingWindow) {\n this._pendingBridgeCalls.delete(elicitationId);\n pendingWindow.postMessage(\n { type: 'photon:request-modal-response', callId: elicitationId, error: 'User cancelled' },\n '*'\n );\n return;\n }\n\n if (elicitationId && this._mcpReady) {\n await mcpClient.sendElicitationResponse(elicitationId, null, true);\n }\n\n this._log('info', 'Input cancelled');\n showToast('Input cancelled', 'info');\n };\n\n private _handleOAuthComplete = async (e: CustomEvent) => {\n const { elicitationId, success } = e.detail;\n // OAuth completion is handled by the auth service callback\n // The elicitation UI just needs to close and show status\n this._showElicitation = false;\n this._elicitationData = null;\n if (success) {\n this._log('success', 'Authorization completed');\n showToast('Authorization completed', 'success');\n }\n };\n\n private _applyTheme() {\n this.setAttribute('data-theme', this._theme);\n }\n\n private _broadcastThemeToIframes() {\n const themeTokens = getThemeTokens(this._theme);\n\n // Find custom-ui-renderer components and notify their iframes\n const renderers = this.shadowRoot?.querySelectorAll('custom-ui-renderer');\n renderers?.forEach((renderer) => {\n const shadowRoot = (renderer as any).shadowRoot;\n const iframe = shadowRoot?.querySelector('iframe');\n if (iframe?.contentWindow) {\n iframe.contentWindow.postMessage(\n {\n type: 'photon:theme-change',\n theme: this._theme,\n themeTokens: themeTokens,\n },\n '*'\n );\n }\n });\n\n // Also check for any direct iframes (fallback)\n const iframes = this.shadowRoot?.querySelectorAll('iframe');\n iframes?.forEach((iframe) => {\n iframe.contentWindow?.postMessage(\n {\n type: 'photon:theme-change',\n theme: this._theme,\n themeTokens: themeTokens,\n },\n '*'\n );\n });\n }\n\n private _handleKeydown = (e: KeyboardEvent) => {\n // Skip if typing in an input field (unless it's a special key combo)\n // Use composedPath() to check through shadow DOM boundaries\n const path = e.composedPath();\n const isInput = path.some((el) => {\n if (el instanceof HTMLElement) {\n return el.tagName === 'INPUT' || el.tagName === 'TEXTAREA' || el.isContentEditable;\n }\n return false;\n });\n\n // Ctrl/Cmd+K or / to focus search\n if ((e.key === 'k' && (e.metaKey || e.ctrlKey)) || (e.key === '/' && !isInput)) {\n e.preventDefault();\n this._sidebar?.focusSearch();\n return;\n }\n\n // Escape to close modals or clear\n if (e.key === 'Escape') {\n if (this._sidebarVisible) {\n this._closeSidebar();\n return;\n }\n if (this._showHelp) {\n this._showHelp = false;\n return;\n }\n if (this._showPhotonHelp) {\n this._showPhotonHelp = false;\n return;\n }\n if (this._showSourceModal) {\n this._closeSourceModal();\n return;\n }\n if (this._view === 'form' && this._selectedMethod) {\n this._handleBackFromMethod();\n return;\n }\n if (this._view === 'marketplace') {\n this._view = 'list';\n return;\n }\n }\n\n // Skip other shortcuts if in input\n if (isInput) return;\n\n // ? to show help\n if (e.key === '?' && e.shiftKey) {\n this._showHelp = !this._showHelp;\n return;\n }\n\n // t to toggle theme\n if (e.key === 't') {\n const newTheme = this._theme === 'dark' ? 'light' : 'dark';\n this._theme = newTheme;\n localStorage.setItem(THEME_STORAGE_KEY, newTheme);\n this._applyTheme();\n this._broadcastThemeToIframes();\n showToast(`Theme: ${newTheme}`, 'info');\n return;\n }\n\n // p to show marketplace\n if (e.key === 'p') {\n this._view = 'marketplace';\n return;\n }\n\n // f to toggle favorites filter\n if (e.key === 'f') {\n this._sidebar?.toggleFavoritesFilter();\n const isActive = this._sidebar?.isFavoritesFilterActive();\n showToast(isActive ? 'Showing favorites only' : 'Showing all photons', 'info');\n return;\n }\n\n // h to go back\n if (e.key === 'h') {\n if (this._view === 'form') {\n this._handleBackFromMethod();\n } else if (this._view === 'marketplace') {\n this._view = 'list';\n }\n return;\n }\n\n // [ and ] to navigate photons\n if (e.key === '[' || e.key === ']') {\n const photons = this._sidebar?.getAllPhotons() || this._photons;\n if (photons.length === 0) return;\n\n const currentIndex = this._selectedPhoton\n ? photons.findIndex((p) => p.name === this._selectedPhoton.name)\n : -1;\n\n let newIndex: number;\n if (e.key === '[') {\n newIndex = currentIndex <= 0 ? photons.length - 1 : currentIndex - 1;\n } else {\n newIndex = currentIndex >= photons.length - 1 ? 0 : currentIndex + 1;\n }\n\n const newPhoton = photons[newIndex];\n if (newPhoton) {\n this._handlePhotonSelect(new CustomEvent('select', { detail: { photon: newPhoton } }));\n }\n return;\n }\n\n // j/k or arrows to navigate methods\n if (\n (e.key === 'j' || e.key === 'ArrowDown' || e.key === 'k' || e.key === 'ArrowUp') &&\n this._view === 'list'\n ) {\n const methods = this._selectedPhoton?.methods || [];\n if (methods.length === 0) return;\n\n const currentIndex = this._selectedMethod\n ? methods.findIndex((m: any) => m.name === this._selectedMethod.name)\n : -1;\n\n let newIndex: number;\n if (e.key === 'j' || e.key === 'ArrowDown') {\n newIndex = currentIndex >= methods.length - 1 ? 0 : currentIndex + 1;\n } else {\n newIndex = currentIndex <= 0 ? methods.length - 1 : currentIndex - 1;\n }\n\n this._selectedMethod = methods[newIndex];\n // Highlight but don't navigate to form\n return;\n }\n\n // Enter to select highlighted method\n if (e.key === 'Enter' && this._selectedMethod && this._view === 'list') {\n this._view = 'form';\n this._updateHash();\n return;\n }\n\n // r to reload/re-execute\n if (e.key === 'r') {\n if (this._view === 'form' && this._selectedMethod && this._lastResult !== null) {\n // Re-execute last method (would need form data - skip for now)\n showToast('Press Ctrl+Enter in form to re-execute', 'info');\n }\n return;\n }\n };\n\n private _closeHelp() {\n this._showHelp = false;\n }\n\n private _showHelpModal = () => {\n this._closeSettingsMenu();\n this._showHelp = true;\n };\n\n private _showPhotonHelpModal = async () => {\n this._closeSettingsMenu();\n this._photonHelpMarkdown = '';\n this._photonHelpLoading = true;\n this._showPhotonHelp = true;\n\n if (this._selectedPhoton) {\n const markdown = await mcpClient.getPhotonHelp(this._selectedPhoton.name);\n if (markdown) {\n this._photonHelpMarkdown = markdown;\n } else {\n // Fallback to client-side generation\n this._photonHelpMarkdown = this._generatePhotonHelpMarkdown();\n }\n this._photonHelpLoading = false;\n }\n };\n\n private _closePhotonHelp() {\n this._showPhotonHelp = false;\n }\n\n private _generatePhotonHelpMarkdown(): string {\n if (!this._selectedPhoton) return '';\n\n const photon = this._selectedPhoton;\n const lines: string[] = [];\n\n // Header with icon\n const icon = photon.icon ? `${photon.icon} ` : '';\n lines.push(`# ${icon}${photon.name}`);\n lines.push('');\n\n // Badges\n const badges: string[] = [];\n if (photon.internal) badges.push('`System`');\n if (photon.isApp) badges.push('`App`');\n if (badges.length > 0) {\n lines.push(badges.join(' '));\n lines.push('');\n }\n\n if (photon.description) {\n lines.push(photon.description);\n lines.push('');\n }\n\n // Methods (Tools)\n if (photon.methods && photon.methods.length > 0) {\n lines.push('## Methods');\n lines.push('');\n\n for (const method of photon.methods) {\n lines.push(`### ${method.name}`);\n lines.push('');\n if (method.description) {\n lines.push(method.description);\n lines.push('');\n }\n\n // Parameters\n if (method.params && method.params.length > 0) {\n lines.push('**Parameters:**');\n lines.push('');\n lines.push('| Name | Type | Required | Description |');\n lines.push('|------|------|----------|-------------|');\n for (const param of method.params) {\n const required = param.required ? '\u2713' : '';\n const desc = param.description || '-';\n lines.push(`| \\`${param.name}\\` | ${param.type || 'any'} | ${required} | ${desc} |`);\n }\n lines.push('');\n }\n\n // Return type\n if (method.returnType) {\n lines.push(`**Returns:** \\`${method.returnType}\\``);\n lines.push('');\n }\n }\n }\n\n // Prompts\n if (photon.prompts && photon.prompts.length > 0) {\n lines.push('## Prompts');\n lines.push('');\n for (const prompt of photon.prompts) {\n lines.push(`- **${prompt.name}**: ${prompt.description || 'No description'}`);\n }\n lines.push('');\n }\n\n // Resources\n if (photon.resources && photon.resources.length > 0) {\n lines.push('## Resources');\n lines.push('');\n for (const resource of photon.resources) {\n lines.push(\n `- **${resource.name}** (\\`${resource.uri || '-'}\\`): ${resource.description || 'No description'}`\n );\n }\n lines.push('');\n }\n\n return lines.join('\\n');\n }\n\n /**\n * Renders the action toolbar for both desktop (inline buttons) and mobile (dropdown)\n * @param options Configuration for which buttons to show\n */\n private _renderActionToolbar(\n options: {\n showRefresh?: boolean;\n showReconfigure?: boolean;\n showRememberValues?: boolean;\n showRename?: boolean;\n showViewSource?: boolean;\n showDelete?: boolean;\n showHelp?: boolean;\n showLaunchApp?: boolean;\n showRemove?: boolean;\n showRunTests?: boolean;\n } = {}\n ) {\n const {\n showRefresh = true,\n showReconfigure = this._selectedPhoton?.configured !== false,\n showRememberValues = true,\n showRename = this._selectedPhoton?.name !== 'maker',\n showViewSource = this._selectedPhoton?.name !== 'maker',\n showDelete = this._selectedPhoton?.name !== 'maker',\n showHelp = true,\n showLaunchApp = false,\n showRemove = false,\n showRunTests = this._getTestMethods().length > 0,\n } = options;\n\n return html`\n <!-- Desktop Action Toolbar -->\n <div class=\"action-toolbar\">\n ${showRefresh\n ? html`\n <button class=\"toolbar-btn\" @click=${this._handleRefresh} title=\"Refresh photon\">\n <span>\uD83D\uDD04</span>\n <span class=\"label\">Refresh</span>\n </button>\n `\n : ''}\n ${showReconfigure\n ? html`\n <button\n class=\"toolbar-btn\"\n @click=${this._handleReconfigure}\n title=\"Reconfigure photon\"\n >\n <span>\uD83D\uDD27</span>\n <span class=\"label\">Configure</span>\n </button>\n `\n : ''}\n ${showRememberValues\n ? html`\n <button\n class=\"toolbar-btn toolbar-toggle\"\n @click=${this._toggleRememberValues}\n title=\"Remember form values between invocations\"\n >\n <span>\uD83D\uDCDD</span>\n <span class=\"label\">Remember</span>\n <span class=\"toggle-indicator ${this._rememberFormValues ? 'active' : ''}\"></span>\n </button>\n `\n : ''}\n ${showLaunchApp\n ? html`\n <button\n class=\"toolbar-btn\"\n @click=${() => this._launchAsApp()}\n title=\"Launch in separate window\"\n >\n <span>\uD83D\uDDA5\uFE0F</span>\n <span class=\"label\">Launch</span>\n </button>\n `\n : ''}\n ${showRunTests\n ? html`\n <button\n class=\"toolbar-btn\"\n @click=${this._runTests}\n ?disabled=${this._runningTests}\n title=\"Run test methods for this photon\"\n >\n <span>\uD83E\uDDEA</span>\n <span class=\"label\">${this._runningTests ? 'Running...' : 'Run Tests'}</span>\n </button>\n `\n : ''}\n ${showRename || showViewSource || showDelete\n ? html` <span class=\"toolbar-divider\"></span> `\n : ''}\n ${showRename\n ? html`\n <button\n class=\"toolbar-btn icon-only\"\n @click=${this._handleRenamePhoton}\n title=\"Rename photon\"\n >\n <span>\u270F\uFE0F</span>\n </button>\n `\n : ''}\n ${showViewSource\n ? html`\n <button\n class=\"toolbar-btn icon-only\"\n @click=${this._handleViewSource}\n title=\"View source code\"\n >\n <span>\uD83D\uDCC4</span>\n </button>\n `\n : ''}\n ${showDelete\n ? html`\n <button\n class=\"toolbar-btn icon-only danger\"\n @click=${this._handleDeletePhoton}\n title=\"Delete photon\"\n >\n <span>\uD83D\uDDD1\uFE0F</span>\n </button>\n `\n : ''}\n ${showRemove\n ? html`\n <button\n class=\"toolbar-btn icon-only danger\"\n @click=${this._handleRemove}\n title=\"Remove from list\"\n >\n <span>\uD83D\uDDD1\uFE0F</span>\n </button>\n `\n : ''}\n ${showHelp\n ? html`\n <span class=\"toolbar-divider\"></span>\n <button\n class=\"toolbar-btn icon-only\"\n @click=${this._showPhotonHelpModal}\n title=\"Photon documentation\"\n >\n <span>\u2753</span>\n </button>\n `\n : ''}\n </div>\n\n <!-- Mobile Dropdown Menu -->\n <div class=\"settings-container\">\n <button class=\"settings-btn\" @click=${this._toggleSettingsMenu}>\n <span>\u2699\uFE0F</span>\n <span>Menu</span>\n </button>\n ${this._showSettingsMenu\n ? html`\n <div class=\"settings-dropdown\">\n ${showLaunchApp\n ? html`\n <button class=\"settings-dropdown-item\" @click=${() => this._launchAsApp()}>\n <span class=\"icon\">\uD83D\uDDA5\uFE0F</span>\n <span>Launch as App</span>\n </button>\n `\n : ''}\n ${showRunTests\n ? html`\n <button\n class=\"settings-dropdown-item\"\n @click=${this._runTests}\n ?disabled=${this._runningTests}\n >\n <span class=\"icon\">\uD83E\uDDEA</span>\n <span>${this._runningTests ? 'Running Tests...' : 'Run Tests'}</span>\n </button>\n `\n : ''}\n ${showRefresh\n ? html`\n <button class=\"settings-dropdown-item\" @click=${this._handleRefresh}>\n <span class=\"icon\">\uD83D\uDD04</span>\n <span>Refresh</span>\n </button>\n `\n : ''}\n ${showReconfigure\n ? html`\n <button class=\"settings-dropdown-item\" @click=${this._handleReconfigure}>\n <span class=\"icon\">\uD83D\uDD27</span>\n <span>Reconfigure</span>\n </button>\n `\n : ''}\n ${showRememberValues\n ? html`\n <div class=\"settings-dropdown-divider\"></div>\n <button\n class=\"settings-dropdown-item toggle\"\n @click=${this._toggleRememberValues}\n >\n <span style=\"display:flex;align-items:center;gap:10px;\">\n <span class=\"icon\">\uD83D\uDCDD</span>\n <span>Remember Values</span>\n </span>\n <span\n class=\"toggle-switch ${this._rememberFormValues ? 'active' : ''}\"\n ></span>\n </button>\n `\n : ''}\n <button class=\"settings-dropdown-item toggle\" @click=${this._toggleVerboseLogging}>\n <span style=\"display:flex;align-items:center;gap:10px;\">\n <span class=\"icon\">\uD83D\uDCCB</span>\n <span>Verbose Logging</span>\n </span>\n <span class=\"toggle-switch ${this._verboseLogging ? 'active' : ''}\"></span>\n </button>\n ${showRename || showViewSource || showDelete\n ? html` <div class=\"settings-dropdown-divider\"></div> `\n : ''}\n ${showRename\n ? html`\n <button class=\"settings-dropdown-item\" @click=${this._handleRenamePhoton}>\n <span class=\"icon\">\u270F\uFE0F</span>\n <span>Rename</span>\n </button>\n `\n : ''}\n ${showViewSource\n ? html`\n <button class=\"settings-dropdown-item\" @click=${this._handleViewSource}>\n <span class=\"icon\">\uD83D\uDCC4</span>\n <span>View Source</span>\n </button>\n `\n : ''}\n ${showDelete\n ? html`\n <button\n class=\"settings-dropdown-item\"\n style=\"color: #f87171;\"\n @click=${this._handleDeletePhoton}\n >\n <span class=\"icon\">\uD83D\uDDD1\uFE0F</span>\n <span>Delete</span>\n </button>\n `\n : ''}\n ${showRemove\n ? html`\n <button\n class=\"settings-dropdown-item\"\n style=\"color: #f87171;\"\n @click=${this._handleRemove}\n >\n <span class=\"icon\">\uD83D\uDDD1\uFE0F</span>\n <span>Remove</span>\n </button>\n `\n : ''}\n ${showHelp\n ? html`\n <div class=\"settings-dropdown-divider\"></div>\n <button class=\"settings-dropdown-item\" @click=${this._showPhotonHelpModal}>\n <span class=\"icon\">\uD83D\uDCD6</span>\n <span>Photon Help</span>\n </button>\n `\n : ''}\n </div>\n `\n : ''}\n </div>\n `;\n }\n\n private _renderPhotonHeader() {\n if (!this._selectedPhoton) return '';\n\n const isApp = this._selectedPhoton.isApp;\n const methodCount = this._selectedPhoton.methods?.length || 0;\n const description = this._selectedPhoton.description || `${this._selectedPhoton.name} MCP`;\n const isGenericDesc = description.endsWith(' MCP') || description === 'Photon tool';\n\n // Get icon - check for custom icon first, then app icon, then initials\n const customIcon = this._selectedPhoton.icon;\n const photonInitials = this._selectedPhoton.name.substring(0, 2).toUpperCase();\n const defaultIcon = isApp ? '\uD83D\uDCF1' : photonInitials;\n const displayIcon = customIcon || defaultIcon;\n\n return html`\n <div class=\"photon-header\">\n <div\n class=\"photon-icon-large editable ${isApp ? '' : 'mcp-icon'}\"\n @click=${this._startEditingIcon}\n title=\"Click to change icon\"\n >\n ${displayIcon}\n </div>\n ${this._editingIcon ? this._renderEmojiPicker() : ''}\n <div class=\"photon-header-info\">\n <h1 class=\"photon-header-name\">${this._selectedPhoton.name}</h1>\n ${this._editingDescription\n ? html`\n <p class=\"photon-header-desc editable editing\">\n <input\n class=\"editable-input\"\n type=\"text\"\n .value=${this._editedDescription}\n placeholder=\"Add a description...\"\n @input=${(e: Event) =>\n (this._editedDescription = (e.target as HTMLInputElement).value)}\n @blur=${this._saveDescription}\n @keydown=${this._handleDescriptionKeydown}\n autofocus\n />\n </p>\n `\n : html`\n <p\n class=\"photon-header-desc editable ${isGenericDesc ? 'placeholder' : ''}\"\n @click=${this._startEditingDescription}\n title=\"Click to edit description\"\n >\n ${isGenericDesc ? 'Click to add a description...' : description}\n </p>\n `}\n <div class=\"photon-header-meta\">\n ${isApp\n ? html`<span class=\"photon-badge app\">App</span>`\n : html`<span class=\"photon-badge\">MCP</span>`}\n <span class=\"photon-badge\">${methodCount} method${methodCount !== 1 ? 's' : ''}</span>\n ${this._selectedPhoton.version\n ? html`<span class=\"photon-badge\">${this._selectedPhoton.version}</span>`\n : ''}\n ${this._selectedPhoton.hasUpdate\n ? html`<span class=\"photon-badge update\" @click=${this._handleUpgrade}\n >Update available</span\n >`\n : ''}\n ${this._selectedPhoton.author\n ? html`<span class=\"photon-badge\">${this._selectedPhoton.author}</span>`\n : ''}\n ${this._selectedPhoton.installSource\n ? html`<span class=\"photon-badge source\"\n >from ${this._selectedPhoton.installSource.marketplace}</span\n >`\n : ''}\n </div>\n <div class=\"photon-header-actions\">\n <button\n class=\"btn-sm\"\n @click=${this._handleCopyMCPConfig}\n title=\"Copy MCP config for Claude Desktop\"\n >\n \uD83D\uDCCB Copy MCP Config\n </button>\n ${this._selectedPhoton.hasUpdate\n ? html`<button class=\"btn-sm primary\" @click=${this._handleUpgrade}>\n \u2B06 Upgrade\n </button>`\n : ''}\n </div>\n </div>\n </div>\n `;\n }\n\n private _startEditingDescription = () => {\n const desc = this._selectedPhoton?.description || '';\n const isGeneric = desc.endsWith(' MCP') || desc === 'Photon tool';\n this._editedDescription = isGeneric ? '' : desc;\n this._editingDescription = true;\n };\n\n private _handleDescriptionKeydown = (e: KeyboardEvent) => {\n if (e.key === 'Enter') {\n e.preventDefault();\n this._saveDescription();\n } else if (e.key === 'Escape') {\n this._editingDescription = false;\n }\n };\n\n private _saveDescription = async () => {\n this._editingDescription = false;\n const newDesc = this._editedDescription.trim();\n\n if (newDesc && this._selectedPhoton && this._mcpReady) {\n // Update local state optimistically\n this._selectedPhoton = { ...this._selectedPhoton, description: newDesc };\n\n // Send to server to persist via MCP\n const result = await mcpClient.updateMetadata(this._selectedPhoton.name, null, {\n description: newDesc,\n });\n if (result.success) {\n showToast('Description updated', 'success');\n } else {\n showToast(result.error || 'Failed to update description', 'error');\n }\n }\n };\n\n private _startEditingIcon = () => {\n this._editingIcon = !this._editingIcon;\n };\n\n private _selectIcon = async (icon: string) => {\n this._editingIcon = false;\n\n if (this._selectedPhoton && this._mcpReady) {\n // Update local state optimistically\n this._selectedPhoton = { ...this._selectedPhoton, icon };\n\n // Send to server to persist via MCP\n const result = await mcpClient.updateMetadata(this._selectedPhoton.name, null, { icon });\n if (result.success) {\n showToast('Icon updated', 'success');\n } else {\n showToast(result.error || 'Failed to update icon', 'error');\n }\n }\n };\n\n private _handleMethodMetadataUpdate = async (e: CustomEvent) => {\n const { photonName, methodName, metadata } = e.detail;\n\n if (this._selectedPhoton && this._selectedPhoton.name === photonName && this._mcpReady) {\n // Update local state optimistically\n const methods = this._selectedPhoton.methods?.map((m: any) => {\n if (m.name === methodName) {\n return {\n ...m,\n ...(metadata.description !== undefined\n ? { description: metadata.description || '' }\n : {}),\n ...(metadata.icon !== undefined ? { icon: metadata.icon || undefined } : {}),\n };\n }\n return m;\n });\n\n this._selectedPhoton = { ...this._selectedPhoton, methods };\n\n // Send to server to persist via MCP\n const result = await mcpClient.updateMetadata(photonName, methodName, metadata);\n if (result.success) {\n showToast(\n `Method ${metadata.description !== undefined ? 'description' : 'icon'} updated`,\n 'success'\n );\n } else {\n showToast(result.error || 'Failed to update method metadata', 'error');\n }\n }\n };\n\n private _renderEmojiPicker() {\n const emojis = [\n '\uD83D\uDD27',\n '\u2699\uFE0F',\n '\uD83D\uDEE0\uFE0F',\n '\uD83D\uDD28',\n '\uD83D\uDD29',\n '\u26A1',\n '\uD83D\uDCA1',\n '\uD83C\uDFAF',\n '\uD83D\uDCCA',\n '\uD83D\uDCC8',\n '\uD83D\uDCC9',\n '\uD83D\uDCCB',\n '\uD83D\uDCDD',\n '\uD83D\uDCC1',\n '\uD83D\uDCC2',\n '\uD83D\uDDC2\uFE0F',\n '\uD83C\uDF10',\n '\uD83D\uDD17',\n '\uD83D\uDD12',\n '\uD83D\uDD13',\n '\uD83D\uDD11',\n '\uD83D\uDEE1\uFE0F',\n '\uD83D\uDD0D',\n '\uD83D\uDD0E',\n '\uD83D\uDCBE',\n '\uD83D\uDCBF',\n '\uD83D\uDCC0',\n '\uD83D\uDDA5\uFE0F',\n '\uD83D\uDCBB',\n '\uD83D\uDCF1',\n '\u2328\uFE0F',\n '\uD83D\uDDB1\uFE0F',\n '\uD83E\uDD16',\n '\uD83E\uDDE0',\n '\uD83C\uDFA8',\n '\uD83C\uDFAD',\n '\uD83C\uDFAC',\n '\uD83C\uDFAE',\n '\uD83C\uDFB2',\n '\uD83E\uDDE9',\n '\uD83D\uDCE7',\n '\uD83D\uDCAC',\n '\uD83D\uDCAD',\n '\uD83D\uDDE8\uFE0F',\n '\uD83D\uDCE3',\n '\uD83D\uDCE2',\n '\uD83D\uDD14',\n '\uD83D\uDD15',\n '\u2705',\n '\u274C',\n '\u2B50',\n '\uD83C\uDF1F',\n '\uD83D\uDCAB',\n '\u2728',\n '\uD83D\uDD25',\n '\uD83D\uDCA5',\n ];\n\n return html`\n <div class=\"emoji-picker\" @click=${(e: Event) => e.stopPropagation()}>\n ${emojis.map(\n (emoji) => html` <button @click=${() => this._selectIcon(emoji)}>${emoji}</button> `\n )}\n </div>\n `;\n }\n\n private _renderPromptsSection() {\n const prompts = this._selectedPhoton?.assets?.prompts || [];\n if (prompts.length === 0) return '';\n\n return html`\n <h3 class=\"section-header\">\n \uD83D\uDCDD Prompts\n <span class=\"count\">${prompts.length}</span>\n </h3>\n <div class=\"cards-grid\">\n ${prompts.map(\n (prompt: any) => html`\n <div class=\"asset-card glass-panel\" @click=${() => this._handlePromptSelect(prompt)}>\n <div class=\"asset-header\">\n <div class=\"asset-icon prompt\">\uD83D\uDCDD</div>\n <span class=\"asset-name\">${prompt.id}</span>\n </div>\n <div class=\"asset-desc\">\n ${prompt.description || 'Click to view and customize this prompt'}\n </div>\n <div class=\"asset-meta\">${prompt.path}</div>\n </div>\n `\n )}\n </div>\n `;\n }\n\n private _renderResourcesSection() {\n const resources = this._selectedPhoton?.assets?.resources || [];\n if (resources.length === 0) return '';\n\n return html`\n <h3 class=\"section-header\">\n \uD83D\uDCE6 Resources\n <span class=\"count\">${resources.length}</span>\n </h3>\n <div class=\"cards-grid\">\n ${resources.map(\n (resource: any) => html`\n <div\n class=\"asset-card glass-panel\"\n @click=${() => this._handleResourceSelect(resource)}\n >\n <div class=\"asset-header\">\n <div class=\"asset-icon resource\">\uD83D\uDCE6</div>\n <span class=\"asset-name\">${resource.id}</span>\n </div>\n <div class=\"asset-desc\">${resource.description || 'Click to view this resource'}</div>\n <div class=\"asset-meta\">${resource.mimeType || resource.path}</div>\n </div>\n `\n )}\n </div>\n `;\n }\n\n private _handlePromptSelect = async (prompt: any) => {\n this._selectedPrompt = prompt;\n this._promptArguments = {};\n this._renderedPrompt = '';\n\n // Load the prompt content via MCP\n if (this._mcpReady && this._selectedPhoton) {\n try {\n const uri = `prompt://${this._selectedPhoton.name}/${prompt.id}`;\n const content = await mcpClient.readResource(uri);\n if (content?.text) {\n this._selectedPrompt = {\n ...this._selectedPrompt,\n content: content.text,\n renderedContent: content.text,\n variables: this._extractVariables(content.text),\n description: prompt.description,\n };\n for (const v of this._selectedPrompt.variables) {\n this._promptArguments[v] = '';\n }\n this._renderedPrompt = content.text;\n }\n } catch (error) {\n console.error('Failed to load prompt:', error);\n }\n }\n };\n\n private _extractVariables(content: string): string[] {\n const matches = content.match(/\\{\\{(\\w+)\\}\\}/g) || [];\n return [...new Set(matches.map((m) => m.slice(2, -2)))];\n }\n\n private _handleResourceSelect = async (resource: any) => {\n this._selectedResource = resource;\n this._resourceContent = '';\n\n // Load the resource content via MCP\n if (this._mcpReady && this._selectedPhoton) {\n try {\n const uri = `ui://${this._selectedPhoton.name}/${resource.id}`;\n const content = await mcpClient.readResource(uri);\n if (content) {\n this._selectedResource = {\n ...this._selectedResource,\n content: content.text,\n mimeType: content.mimeType,\n description: resource.description,\n };\n this._resourceContent = content.text || '';\n }\n } catch (error) {\n console.error('Failed to load resource:', error);\n }\n }\n };\n\n private _renderPromptWithVariables(content: string): string {\n // Highlight {{variables}} in the prompt\n return content.replace(/\\{\\{(\\w+)\\}\\}/g, '<span class=\"variable\">{{$1}}</span>');\n }\n\n private _renderPromptModal() {\n if (!this._selectedPrompt || !this._selectedPrompt.content) return '';\n\n const variables = this._selectedPrompt.variables || [];\n const hasVariables = variables.length > 0;\n\n // Render the prompt with filled values highlighted\n let renderedContent = this._selectedPrompt.content;\n for (const [key, value] of Object.entries(this._promptArguments)) {\n if (value) {\n renderedContent = renderedContent.replace(\n new RegExp(`\\\\{\\\\{${key}\\\\}\\\\}`, 'g'),\n `<span class=\"var-filled\">${value}</span>`\n );\n } else {\n renderedContent = renderedContent.replace(\n new RegExp(`\\\\{\\\\{${key}\\\\}\\\\}`, 'g'),\n `<span class=\"var-highlight\">{{${key}}}</span>`\n );\n }\n }\n\n return html`\n <div\n class=\"modal-overlay\"\n @click=${(e: Event) => {\n if (e.target === e.currentTarget) this._closePromptModal();\n }}\n >\n <div class=\"asset-viewer-modal glass-panel\">\n <button class=\"close-btn\" @click=${this._closePromptModal}>&times;</button>\n\n <h2>\n <span class=\"icon\">\uD83D\uDCDD</span>\n ${this._selectedPrompt.id}\n </h2>\n\n ${this._selectedPrompt.description\n ? html` <p class=\"description\">${this._selectedPrompt.description}</p> `\n : ''}\n ${hasVariables\n ? html`\n <div class=\"variables-form\">\n <h4>Variables</h4>\n ${variables.map(\n (v: string) => html`\n <div class=\"variable-input\">\n <label>{{${v}}}</label>\n <input\n type=\"text\"\n placeholder=\"Enter value...\"\n .value=${this._promptArguments[v] || ''}\n @input=${(e: Event) =>\n this._updatePromptArgument(v, (e.target as HTMLInputElement).value)}\n />\n </div>\n `\n )}\n </div>\n `\n : ''}\n\n <div class=\"content-section\">\n <h4>${hasVariables ? 'Rendered Prompt' : 'Content'}</h4>\n <div class=\"content-preview\" .innerHTML=${renderedContent}></div>\n </div>\n\n <button class=\"copy-btn\" @click=${this._copyPromptContent}>\uD83D\uDCCB Copy to Clipboard</button>\n </div>\n </div>\n `;\n }\n\n private _renderResourceModal() {\n if (!this._selectedResource || !this._selectedResource.content) return '';\n\n const mimeType = this._selectedResource.mimeType || 'text/plain';\n const isImage = mimeType.startsWith('image/');\n const isJson = mimeType === 'application/json';\n\n let displayContent = this._selectedResource.content;\n if (isJson) {\n try {\n displayContent = JSON.stringify(JSON.parse(displayContent), null, 2);\n } catch {\n // Keep as-is\n }\n }\n\n return html`\n <div\n class=\"modal-overlay\"\n @click=${(e: Event) => {\n if (e.target === e.currentTarget) this._closeResourceModal();\n }}\n >\n <div class=\"asset-viewer-modal glass-panel\">\n <button class=\"close-btn\" @click=${this._closeResourceModal}>&times;</button>\n\n <h2>\n <span class=\"icon\">\uD83D\uDCE6</span>\n ${this._selectedResource.id}\n </h2>\n\n ${this._selectedResource.description\n ? html` <p class=\"description\">${this._selectedResource.description}</p> `\n : ''}\n\n <div class=\"content-section\">\n <h4>Content <span style=\"opacity:0.5\">(${mimeType})</span></h4>\n ${isImage\n ? html`\n <img\n class=\"resource-image\"\n src=\"data:${mimeType};base64,${this._selectedResource.content}\"\n alt=\"${this._selectedResource.id}\"\n />\n `\n : html` <div class=\"content-preview\">${displayContent}</div> `}\n </div>\n\n ${!isImage\n ? html`\n <button class=\"copy-btn\" @click=${this._copyResourceContent}>\n \uD83D\uDCCB Copy to Clipboard\n </button>\n `\n : ''}\n </div>\n </div>\n `;\n }\n\n private _closePromptModal = () => {\n this._selectedPrompt = null;\n this._promptArguments = {};\n this._renderedPrompt = '';\n };\n\n private _closeResourceModal = () => {\n this._selectedResource = null;\n this._resourceContent = '';\n };\n\n private _updatePromptArgument = (key: string, value: string) => {\n this._promptArguments = {\n ...this._promptArguments,\n [key]: value,\n };\n };\n\n private _copyPromptContent = async () => {\n // Build the rendered content\n let content = this._selectedPrompt?.content || '';\n for (const [key, value] of Object.entries(this._promptArguments)) {\n if (value) {\n content = content.replace(new RegExp(`\\\\{\\\\{${key}\\\\}\\\\}`, 'g'), value);\n }\n }\n\n try {\n await navigator.clipboard.writeText(content);\n showToast('Prompt copied to clipboard', 'success');\n } catch {\n showToast('Failed to copy', 'error');\n }\n };\n\n private _copyResourceContent = async () => {\n try {\n await navigator.clipboard.writeText(this._resourceContent);\n showToast('Resource copied to clipboard', 'success');\n } catch {\n showToast('Failed to copy', 'error');\n }\n };\n\n private _renderHelpModal() {\n return html`\n <div\n class=\"modal-overlay\"\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby=\"help-modal-title\"\n @click=${(e: Event) => {\n if (e.target === e.currentTarget) this._closeHelp();\n }}\n >\n <div class=\"help-modal glass-panel\">\n <h2 id=\"help-modal-title\" class=\"text-gradient\">Keyboard Shortcuts</h2>\n\n <div class=\"shortcut-section\">\n <h3>Navigation</h3>\n <div class=\"shortcut-list\">\n <div class=\"shortcut-item\">\n <span class=\"shortcut-key\"><kbd>\u2318</kbd><kbd>K</kbd></span>\n <span class=\"shortcut-desc\">Focus search</span>\n </div>\n <div class=\"shortcut-item\">\n <span class=\"shortcut-key\"><kbd>/</kbd></span>\n <span class=\"shortcut-desc\">Focus search</span>\n </div>\n <div class=\"shortcut-item\">\n <span class=\"shortcut-key\"><kbd>[</kbd> <kbd>]</kbd></span>\n <span class=\"shortcut-desc\">Previous / Next photon</span>\n </div>\n <div class=\"shortcut-item\">\n <span class=\"shortcut-key\"><kbd>j</kbd> <kbd>k</kbd></span>\n <span class=\"shortcut-desc\">Navigate methods</span>\n </div>\n <div class=\"shortcut-item\">\n <span class=\"shortcut-key\"><kbd>Enter</kbd></span>\n <span class=\"shortcut-desc\">Select method</span>\n </div>\n <div class=\"shortcut-item\">\n <span class=\"shortcut-key\"><kbd>h</kbd></span>\n <span class=\"shortcut-desc\">Go back</span>\n </div>\n </div>\n </div>\n\n <div class=\"shortcut-section\">\n <h3>Actions</h3>\n <div class=\"shortcut-list\">\n <div class=\"shortcut-item\">\n <span class=\"shortcut-key\"><kbd>\u2318</kbd><kbd>Enter</kbd></span>\n <span class=\"shortcut-desc\">Submit form</span>\n </div>\n <div class=\"shortcut-item\">\n <span class=\"shortcut-key\"><kbd>Esc</kbd></span>\n <span class=\"shortcut-desc\">Close / Cancel</span>\n </div>\n <div class=\"shortcut-item\">\n <span class=\"shortcut-key\"><kbd>t</kbd></span>\n <span class=\"shortcut-desc\">Toggle theme</span>\n </div>\n <div class=\"shortcut-item\">\n <span class=\"shortcut-key\"><kbd>p</kbd></span>\n <span class=\"shortcut-desc\">Open marketplace</span>\n </div>\n <div class=\"shortcut-item\">\n <span class=\"shortcut-key\"><kbd>f</kbd></span>\n <span class=\"shortcut-desc\">Toggle favorites filter</span>\n </div>\n <div class=\"shortcut-item\">\n <span class=\"shortcut-key\"><kbd>?</kbd></span>\n <span class=\"shortcut-desc\">Show this help</span>\n </div>\n </div>\n </div>\n\n <button\n class=\"btn-primary\"\n style=\"width: 100%; margin-top: var(--space-md);\"\n @click=${this._closeHelp}\n >\n Close\n </button>\n </div>\n </div>\n `;\n }\n\n private _renderPhotonHelpModal() {\n const markdown = this._photonHelpLoading\n ? this._generatePhotonHelpMarkdown()\n : this._photonHelpMarkdown || this._generatePhotonHelpMarkdown();\n let htmlContent = markdown;\n\n // Parse markdown if marked is available\n if ((window as any).marked) {\n htmlContent = (window as any).marked.parse(markdown);\n }\n\n return html`\n <div\n class=\"modal-overlay\"\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby=\"photon-help-title\"\n @click=${(e: Event) => {\n if (e.target === e.currentTarget) this._closePhotonHelp();\n }}\n >\n <div\n class=\"help-modal glass-panel\"\n style=\"max-width: 700px; max-height: 80vh; overflow: auto;\"\n >\n <div\n style=\"display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-md);\"\n >\n <h2 id=\"photon-help-title\" class=\"text-gradient\" style=\"margin: 0;\">\n ${this._selectedPhoton?.name || 'Photon'} Help\n ${this._photonHelpLoading\n ? html`<span style=\"font-size: 0.7em; opacity: 0.6; margin-left: 8px;\">Loading...</span>`\n : ''}\n </h2>\n <button\n class=\"btn-secondary\"\n style=\"padding: 6px 12px; font-size: 0.85rem;\"\n @click=${this._closePhotonHelp}\n aria-label=\"Close help\"\n >\n \u2715\n </button>\n </div>\n <div class=\"markdown-body\" style=\"color: var(--t-default);\">\n ${(window as any).marked\n ? html`${unsafeHTML(htmlContent)}`\n : html`<pre style=\"white-space: pre-wrap;\">${markdown}</pre>`}\n </div>\n </div>\n </div>\n `;\n }\n\n private _closeSourceModal = () => {\n this._showSourceModal = false;\n this._sourceData = null;\n };\n\n private _copySourceCode = async () => {\n if (this._sourceData?.code) {\n try {\n await navigator.clipboard.writeText(this._sourceData.code);\n showToast('Source code copied', 'success');\n } catch {\n showToast('Failed to copy', 'error');\n }\n }\n };\n\n private _renderSourceModal() {\n if (!this._sourceData) return '';\n\n const filename = this._sourceData.path.split('/').pop() || 'source.ts';\n const ext = filename.split('.').pop()?.toLowerCase() || 'ts';\n\n // Map file extensions to Prism language\n const langMap: Record<string, string> = {\n ts: 'typescript',\n tsx: 'typescript',\n js: 'javascript',\n jsx: 'javascript',\n py: 'python',\n json: 'json',\n css: 'css',\n sql: 'sql',\n yaml: 'yaml',\n yml: 'yaml',\n md: 'markdown',\n rs: 'rust',\n go: 'go',\n sh: 'bash',\n bash: 'bash',\n };\n const language = langMap[ext] || 'typescript';\n\n // Apply syntax highlighting if Prism is available\n let highlightedCode = this._sourceData.code;\n const Prism = (window as any).Prism;\n if (Prism && Prism.languages[language]) {\n highlightedCode = Prism.highlight(this._sourceData.code, Prism.languages[language], language);\n }\n\n return html`\n <div\n class=\"modal-overlay\"\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby=\"source-modal-title\"\n @click=${(e: Event) => {\n if (e.target === e.currentTarget) this._closeSourceModal();\n }}\n >\n <div\n class=\"help-modal glass-panel\"\n style=\"max-width: 900px; max-height: 85vh; display: flex; flex-direction: column;\"\n >\n <div\n style=\"display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-md); flex-shrink: 0;\"\n >\n <div>\n <h2 id=\"source-modal-title\" class=\"text-gradient\" style=\"margin: 0;\">Source Code</h2>\n <div\n style=\"font-size: 0.85rem; color: var(--t-muted); margin-top: 4px; font-family: var(--font-mono);\"\n >\n ${filename}\n </div>\n </div>\n <div style=\"display: flex; gap: var(--space-sm);\">\n <button\n class=\"toolbar-btn\"\n style=\"padding: 6px 12px; font-size: 0.85rem;\"\n @click=${this._copySourceCode}\n title=\"Copy source code\"\n >\n \uD83D\uDCCB Copy\n </button>\n <button\n class=\"toolbar-btn\"\n style=\"padding: 6px 12px; font-size: 0.85rem;\"\n @click=${this._closeSourceModal}\n aria-label=\"Close\"\n >\n \u2715\n </button>\n </div>\n </div>\n <pre\n class=\"language-${language}\"\n style=\"\n flex: 1;\n overflow: auto;\n white-space: pre;\n background: #1e1e2e;\n border: 1px solid var(--border-glass);\n border-radius: var(--radius-sm);\n padding: var(--space-md);\n margin: 0;\n font-family: var(--font-mono);\n font-size: 0.85rem;\n line-height: 1.6;\n tab-size: 2;\n \"\n ><code class=\"language-${language}\" style=\"display: block; overflow-x: visible;\">${Prism\n ? unsafeHTML(highlightedCode)\n : this._sourceData.code}</code></pre>\n </div>\n </div>\n `;\n }\n}\n", "import { LitElement, html, css } from 'lit';\nimport { customElement, property, state, query } from 'lit/decorators.js';\nimport { theme, Theme } from '../styles/theme.js';\n\ninterface PhotonItem {\n name: string;\n description: string;\n isApp?: boolean;\n appEntry?: any;\n methods?: any[];\n icon?: string;\n internal?: boolean;\n version?: string;\n resourceCount?: number;\n promptCount?: number;\n hasUpdate?: boolean;\n}\n\n@customElement('beam-sidebar')\nexport class BeamSidebar extends LitElement {\n static styles = [\n theme,\n css`\n :host {\n display: flex;\n flex-direction: column;\n height: 100%;\n color: var(--t-primary);\n }\n\n .sidebar-content {\n flex: 1;\n overflow-y: auto;\n }\n\n .sidebar-footer {\n padding: var(--space-sm) var(--space-md);\n border-top: 1px solid var(--border-glass);\n display: flex;\n justify-content: center;\n gap: var(--space-md);\n }\n\n .footer-link {\n color: var(--t-muted);\n font-size: 0.75rem;\n cursor: pointer;\n display: flex;\n align-items: center;\n gap: 4px;\n transition: color 0.2s;\n background: none;\n border: none;\n padding: var(--space-xs) var(--space-sm);\n border-radius: var(--radius-sm);\n }\n\n .footer-link:hover {\n color: var(--t-primary);\n background: var(--bg-glass);\n }\n\n .footer-link kbd {\n font-size: 0.65rem;\n padding: 1px 4px;\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n border-radius: 3px;\n font-family: var(--font-mono);\n }\n\n .header {\n padding: var(--space-md);\n border-bottom: 1px solid var(--border-glass);\n }\n\n .header-row {\n display: flex;\n justify-content: space-between;\n align-items: center;\n }\n\n .logo {\n font-size: 1.2rem;\n font-weight: 600;\n margin: 0;\n display: flex;\n align-items: center;\n gap: 8px;\n }\n\n .status-indicator {\n width: 8px;\n height: 8px;\n border-radius: 50%;\n flex-shrink: 0;\n }\n\n .status-indicator.connected {\n background: #4ade80;\n box-shadow: 0 0 6px #4ade80;\n }\n\n .status-indicator.reconnecting {\n background: #fbbf24;\n box-shadow: 0 0 6px #fbbf24;\n animation: pulse 1s ease-in-out infinite;\n }\n\n .status-indicator.disconnected {\n background: #f87171;\n box-shadow: 0 0 6px #f87171;\n }\n\n @keyframes pulse {\n 0%,\n 100% {\n opacity: 1;\n }\n 50% {\n opacity: 0.4;\n }\n }\n\n .theme-toggle {\n display: flex;\n align-items: center;\n gap: var(--space-xs);\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n border-radius: 20px;\n padding: 4px;\n cursor: pointer;\n }\n\n .theme-btn {\n width: 28px;\n height: 28px;\n border-radius: 50%;\n border: none;\n background: transparent;\n cursor: pointer;\n display: flex;\n align-items: center;\n justify-content: center;\n font-size: 14px;\n transition: all 0.2s;\n }\n\n .theme-btn.active {\n background: var(--accent-primary);\n color: white;\n }\n\n .theme-btn:not(.active) {\n color: var(--t-muted);\n }\n\n .theme-btn:hover:not(.active) {\n background: var(--bg-glass-strong);\n }\n\n .search-box {\n margin-top: var(--space-md);\n position: relative;\n }\n\n input {\n width: 100%;\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n color: var(--t-primary);\n padding: var(--space-sm) var(--space-md);\n border-radius: var(--radius-sm);\n font-family: var(--font-sans);\n box-sizing: border-box;\n }\n\n input:focus {\n outline: none;\n border-color: var(--accent-primary);\n box-shadow: 0 0 0 2px var(--glow-primary);\n }\n\n .section-header {\n padding: var(--space-sm) var(--space-md);\n font-size: 0.7rem;\n font-weight: 600;\n text-transform: uppercase;\n letter-spacing: 0.1em;\n color: var(--t-muted);\n margin-top: var(--space-sm);\n }\n\n .photon-list {\n list-style: none;\n padding: 0 var(--space-sm);\n margin: 0;\n }\n\n .photon-item {\n padding: var(--space-sm) var(--space-md);\n margin-bottom: var(--space-xs);\n border-radius: var(--radius-sm);\n cursor: pointer;\n transition: all 0.2s ease;\n display: flex;\n align-items: center;\n gap: var(--space-sm);\n }\n\n .photon-item:hover {\n background: hsla(220, 10%, 80%, 0.1);\n }\n\n .photon-item.active {\n background: linear-gradient(90deg, var(--glow-primary), transparent);\n border-left: 2px solid var(--accent-primary);\n }\n\n .photon-icon {\n width: 28px;\n height: 28px;\n border-radius: 6px;\n background: var(--bg-glass);\n display: flex;\n align-items: center;\n justify-content: center;\n font-size: 12px;\n color: var(--accent-secondary);\n flex-shrink: 0;\n }\n\n .photon-icon.app-icon,\n .photon-icon.emoji-icon {\n background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));\n color: white;\n border-radius: 8px;\n font-size: 16px;\n }\n\n .photon-item.internal {\n opacity: 0.85;\n }\n\n .internal-badge {\n font-size: 0.6rem;\n padding: 1px 4px;\n background: linear-gradient(135deg, hsl(280, 60%, 50%), hsl(320, 60%, 50%));\n color: white;\n border-radius: 3px;\n text-transform: uppercase;\n font-weight: 600;\n letter-spacing: 0.03em;\n }\n\n .photon-info {\n min-width: 0;\n flex: 1;\n }\n\n .photon-name {\n font-weight: 500;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n .photon-desc {\n font-size: 0.8em;\n color: var(--t-muted);\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n .method-count {\n font-size: 0.65rem;\n padding: 2px 6px;\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n color: var(--t-muted);\n border-radius: 10px;\n font-weight: 500;\n flex-shrink: 0;\n }\n\n .method-count.unconfigured {\n background: hsla(45, 80%, 50%, 0.15);\n border-color: hsla(45, 80%, 50%, 0.3);\n color: hsl(45, 80%, 50%);\n }\n\n .counts-pill {\n display: flex;\n align-items: center;\n gap: 6px;\n font-size: 0.65rem;\n padding: 2px 6px;\n background: rgba(255, 255, 255, 0.05);\n border: 1px solid var(--border-glass);\n border-radius: 10px;\n font-weight: 500;\n flex-shrink: 0;\n }\n\n .count-tools {\n color: hsl(210, 80%, 65%);\n }\n .count-prompts {\n color: hsl(140, 60%, 55%);\n }\n .count-resources {\n color: hsl(30, 80%, 60%);\n }\n\n .version-badge {\n font-size: 0.6rem;\n color: var(--t-muted);\n opacity: 0.7;\n }\n\n .update-dot {\n display: inline-block;\n width: 6px;\n height: 6px;\n border-radius: 50%;\n background: hsl(0, 80%, 55%);\n margin-left: 2px;\n flex-shrink: 0;\n }\n\n .update-badge {\n font-size: 0.6rem;\n padding: 1px 5px;\n background: hsl(0, 80%, 55%);\n color: white;\n border-radius: 8px;\n font-weight: 600;\n flex-shrink: 0;\n }\n\n .marketplace-btn {\n width: 100%;\n margin-top: var(--space-md);\n padding: var(--space-sm);\n background: var(--bg-glass-strong);\n border: 1px solid var(--border-glass);\n color: var(--t-primary);\n cursor: pointer;\n border-radius: var(--radius-sm);\n display: flex;\n align-items: center;\n justify-content: center;\n gap: var(--space-sm);\n font-weight: 500;\n transition: all 0.2s ease;\n }\n\n .marketplace-btn:hover {\n background: var(--bg-panel);\n border-color: var(--accent-secondary);\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);\n transform: translateY(-1px);\n }\n\n .empty-section {\n padding: var(--space-sm) var(--space-md);\n color: var(--t-muted);\n font-size: 0.85rem;\n font-style: italic;\n }\n\n /* Favorites */\n .filter-row {\n display: flex;\n gap: var(--space-sm);\n margin-top: var(--space-sm);\n }\n\n .filter-btn {\n flex: 1;\n padding: var(--space-xs) var(--space-sm);\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n color: var(--t-muted);\n cursor: pointer;\n border-radius: var(--radius-sm);\n display: flex;\n align-items: center;\n justify-content: center;\n gap: 4px;\n font-size: 0.8rem;\n transition: all 0.2s;\n }\n\n .filter-btn:hover {\n background: var(--bg-glass-strong);\n }\n\n .filter-btn.active {\n background: var(--accent-primary);\n border-color: var(--accent-primary);\n color: white;\n }\n\n .star-btn {\n background: none;\n border: none;\n cursor: pointer;\n padding: 2px;\n font-size: 0.9rem;\n opacity: 0.3;\n transition: all 0.2s;\n flex-shrink: 0;\n }\n\n .star-btn:hover {\n opacity: 0.7;\n transform: scale(1.1);\n }\n\n .star-btn.favorited {\n opacity: 1;\n }\n\n .photon-item .star-btn {\n visibility: hidden;\n }\n\n .photon-item:hover .star-btn,\n .photon-item .star-btn.favorited {\n visibility: visible;\n }\n\n /* ===== Responsive Design ===== */\n @media (max-width: 768px) {\n .header {\n padding: var(--space-lg) var(--space-md);\n padding-top: calc(var(--space-lg) + 8px);\n }\n\n .photon-item {\n padding: var(--space-md);\n min-height: 44px;\n }\n\n .photon-item .star-btn {\n visibility: visible;\n padding: var(--space-sm);\n }\n\n .filter-btn {\n min-height: 44px;\n font-size: 0.85rem;\n }\n\n input {\n min-height: 44px;\n font-size: 16px; /* Prevent iOS zoom on focus */\n }\n\n .theme-btn {\n width: 36px;\n height: 36px;\n }\n\n .footer-link {\n min-height: 44px;\n padding: var(--space-sm) var(--space-md);\n }\n }\n `,\n ];\n\n @property({ type: Array })\n photons: PhotonItem[] = [];\n\n @property({ type: String })\n selectedPhoton: string | null = null;\n\n @property({ type: String })\n theme: Theme = 'dark';\n\n @property({ type: Boolean })\n connected = false;\n\n @property({ type: Boolean })\n reconnecting = false;\n\n @property({ type: Number })\n updatesAvailable = 0;\n\n @state()\n private _searchQuery = '';\n\n @state()\n private _showFavoritesOnly = false;\n\n @state()\n private _favorites: Set<string> = new Set();\n\n @query('input')\n private _searchInput!: HTMLInputElement;\n\n private static FAVORITES_KEY = 'beam-favorites';\n\n connectedCallback() {\n super.connectedCallback();\n this._loadFavorites();\n }\n\n private _loadFavorites() {\n try {\n const stored = localStorage.getItem(BeamSidebar.FAVORITES_KEY);\n if (stored) {\n this._favorites = new Set(JSON.parse(stored));\n }\n } catch (e) {\n console.warn('Failed to load favorites:', e);\n }\n }\n\n private _saveFavorites() {\n try {\n localStorage.setItem(BeamSidebar.FAVORITES_KEY, JSON.stringify([...this._favorites]));\n } catch (e) {\n console.warn('Failed to save favorites:', e);\n }\n }\n\n private get _filteredPhotons() {\n // Exclude internal photons \u2014 their static methods appear in the marketplace/global area\n let filtered = this.photons.filter((p) => !p.internal);\n\n // Filter by favorites if enabled\n if (this._showFavoritesOnly) {\n filtered = filtered.filter((p) => this._favorites.has(p.name));\n }\n\n // Filter by search query\n if (this._searchQuery.trim()) {\n const query = this._searchQuery.toLowerCase();\n filtered = filtered.filter(\n (p) =>\n p.name.toLowerCase().includes(query) ||\n (p.description && p.description.toLowerCase().includes(query))\n );\n }\n\n return filtered;\n }\n\n private get _apps() {\n return this._filteredPhotons.filter((p) => p.isApp);\n }\n\n private get _configured() {\n return this._filteredPhotons.filter((p) => !p.isApp && p.methods && p.methods.length > 0);\n }\n\n private get _needsSetup() {\n return this._filteredPhotons.filter((p) => !p.isApp && (!p.methods || p.methods.length === 0));\n }\n\n render() {\n return html`\n <nav class=\"sidebar-content\" role=\"navigation\" aria-label=\"Photon navigation\">\n <div class=\"header\">\n <div class=\"header-row\">\n <h2 class=\"text-gradient logo\">\n Photon Beam\n <span\n class=\"status-indicator ${this.connected\n ? 'connected'\n : this.reconnecting\n ? 'reconnecting'\n : 'disconnected'}\"\n title=\"${this.connected\n ? 'Connected'\n : this.reconnecting\n ? 'Reconnecting...'\n : 'Disconnected'}\"\n ></span>\n </h2>\n <div class=\"theme-toggle\" role=\"group\" aria-label=\"Theme selection\">\n <button\n class=\"theme-btn ${this.theme === 'light' ? 'active' : ''}\"\n @click=${() => this._setTheme('light')}\n title=\"Light theme\"\n aria-label=\"Switch to light theme\"\n aria-pressed=\"${this.theme === 'light'}\"\n >\n \u2600\uFE0F\n </button>\n <button\n class=\"theme-btn ${this.theme === 'dark' ? 'active' : ''}\"\n @click=${() => this._setTheme('dark')}\n title=\"Dark theme\"\n aria-label=\"Switch to dark theme\"\n aria-pressed=\"${this.theme === 'dark'}\"\n >\n \uD83C\uDF19\n </button>\n </div>\n </div>\n <div class=\"search-box\" role=\"search\">\n <input\n type=\"search\"\n placeholder=\"Search photons... (\u2318K)\"\n .value=${this._searchQuery}\n @input=${this._handleSearch}\n @keydown=${this._handleSearchKeydown}\n aria-label=\"Search photons\"\n />\n </div>\n <div class=\"filter-row\" role=\"group\" aria-label=\"Filter options\">\n <button\n class=\"filter-btn ${this._showFavoritesOnly ? 'active' : ''}\"\n @click=${this._toggleFavoritesFilter}\n title=\"Show favorites only (f)\"\n aria-pressed=\"${this._showFavoritesOnly}\"\n aria-label=\"Filter by favorites\"\n >\n \u2B50 Favorites ${this._favorites.size > 0 ? `(${this._favorites.size})` : ''}\n </button>\n <button\n class=\"filter-btn\"\n @click=${() => this.dispatchEvent(new CustomEvent('marketplace'))}\n aria-label=\"Open marketplace\"\n >\n \uD83D\uDECD\uFE0F Marketplace\n ${this.updatesAvailable > 0\n ? html`<span class=\"update-badge\">${this.updatesAvailable}</span>`\n : ''}\n </button>\n </div>\n </div>\n\n ${this._apps.length > 0\n ? html`\n <div class=\"section-header\" id=\"apps-header\">Apps</div>\n <ul class=\"photon-list\" role=\"listbox\" aria-labelledby=\"apps-header\">\n ${this._apps.map((photon) => this._renderPhotonItem(photon, 'app'))}\n </ul>\n `\n : ''}\n ${this._configured.length > 0\n ? html`\n <div class=\"section-header\" id=\"mcps-header\">MCPs</div>\n <ul class=\"photon-list\" role=\"listbox\" aria-labelledby=\"mcps-header\">\n ${this._configured.map((photon) => this._renderPhotonItem(photon, 'configured'))}\n </ul>\n `\n : ''}\n ${this._needsSetup.length > 0\n ? html`\n <div class=\"section-header\" id=\"setup-header\">Setup</div>\n <ul class=\"photon-list\" role=\"listbox\" aria-labelledby=\"setup-header\">\n ${this._needsSetup.map((photon) => this._renderPhotonItem(photon, 'unconfigured'))}\n </ul>\n `\n : ''}\n </nav>\n\n <div class=\"sidebar-footer\">\n <button\n class=\"footer-link\"\n @click=${() =>\n this.dispatchEvent(new CustomEvent('diagnostics', { bubbles: true, composed: true }))}\n title=\"Server diagnostics\"\n aria-label=\"Show diagnostics\"\n >\n \uD83D\uDD0D Status\n </button>\n <button\n class=\"footer-link\"\n @click=${this._showShortcuts}\n title=\"Keyboard shortcuts\"\n aria-label=\"Show keyboard shortcuts\"\n >\n \u2328\uFE0F Shortcuts <kbd>?</kbd>\n </button>\n </div>\n `;\n }\n\n private _showShortcuts() {\n this.dispatchEvent(new CustomEvent('show-shortcuts', { bubbles: true, composed: true }));\n }\n\n private _renderPhotonItem(photon: PhotonItem, type: 'app' | 'configured' | 'unconfigured') {\n const methodCount = photon.methods?.length || 0;\n const isApp = type === 'app';\n const isUnconfigured = type === 'unconfigured';\n const isFavorited = this._favorites.has(photon.name);\n\n // Determine icon: use photon's icon if available, otherwise default\n const displayIcon = photon.icon || (isApp ? '\uD83D\uDCF1' : photon.name.substring(0, 2).toUpperCase());\n const hasCustomIcon = !!photon.icon;\n\n return html`\n <li\n class=\"photon-item ${this.selectedPhoton === photon.name ? 'active' : ''} ${photon.internal\n ? 'internal'\n : ''}\"\n role=\"option\"\n aria-selected=\"${this.selectedPhoton === photon.name}\"\n tabindex=\"0\"\n @click=${() => this._selectPhoton(photon)}\n @keydown=${(e: KeyboardEvent) => e.key === 'Enter' && this._selectPhoton(photon)}\n title=\"${photon.description || photon.name}\"\n >\n <div class=\"photon-icon ${isApp || hasCustomIcon ? 'emoji-icon' : ''}\" aria-hidden=\"true\">\n ${displayIcon}\n </div>\n <div class=\"photon-info\">\n <div class=\"photon-name\">${photon.name}</div>\n ${photon.internal ? html`<span class=\"internal-badge\">System</span>` : ''}\n </div>\n <button\n class=\"star-btn ${isFavorited ? 'favorited' : ''}\"\n @click=${(e: Event) => this._toggleFavorite(e, photon.name)}\n title=\"${isFavorited ? 'Remove from favorites' : 'Add to favorites'}\"\n aria-label=\"${isFavorited\n ? `Remove ${photon.name} from favorites`\n : `Add ${photon.name} to favorites`}\"\n aria-pressed=\"${isFavorited}\"\n >\n ${isFavorited ? '\u2B50' : '\u2606'}\n </button>\n ${photon.hasUpdate ? html`<span class=\"update-dot\" title=\"Update available\"></span>` : ''}\n ${isUnconfigured\n ? html`<span class=\"method-count unconfigured\" aria-label=\"Needs configuration\">?</span>`\n : this._renderCountsPill(photon, methodCount)}\n </li>\n `;\n }\n\n private _renderCountsPill(photon: PhotonItem, toolCount: number) {\n const promptCount = photon.promptCount || 0;\n const resourceCount = photon.resourceCount || 0;\n // Prompt templates are added as methods, so subtract to avoid double counting\n const actualToolCount = Math.max(0, toolCount - promptCount);\n const hasAnyCounts = actualToolCount > 0 || promptCount > 0 || resourceCount > 0;\n\n if (!hasAnyCounts) return '';\n\n return html`<span\n class=\"counts-pill\"\n aria-label=\"${actualToolCount} tools, ${promptCount} prompts, ${resourceCount} resources\"\n >\n ${actualToolCount > 0\n ? html`<span class=\"count-tools\" title=\"${actualToolCount} tools\">${actualToolCount}</span>`\n : ''}\n ${promptCount > 0\n ? html`<span class=\"count-prompts\" title=\"${promptCount} prompts\">${promptCount}</span>`\n : ''}\n ${resourceCount > 0\n ? html`<span class=\"count-resources\" title=\"${resourceCount} resources\"\n >${resourceCount}</span\n >`\n : ''}\n </span>`;\n }\n\n private _setTheme(theme: Theme) {\n this.dispatchEvent(\n new CustomEvent('theme-change', {\n detail: { theme },\n bubbles: true,\n composed: true,\n })\n );\n }\n\n private _handleSearch(e: Event) {\n this._searchQuery = (e.target as HTMLInputElement).value;\n }\n\n private _handleSearchKeydown(e: KeyboardEvent) {\n if (e.key === 'Escape') {\n this._searchQuery = '';\n this._searchInput.value = '';\n this._searchInput.blur();\n }\n }\n\n private _selectPhoton(photon: PhotonItem) {\n this.dispatchEvent(new CustomEvent('select', { detail: { photon } }));\n }\n\n private _toggleFavorite(e: Event, photonName: string) {\n e.stopPropagation(); // Don't select the photon\n const newFavorites = new Set(this._favorites);\n if (newFavorites.has(photonName)) {\n newFavorites.delete(photonName);\n } else {\n newFavorites.add(photonName);\n }\n this._favorites = newFavorites;\n this._saveFavorites();\n }\n\n private _toggleFavoritesFilter() {\n this._showFavoritesOnly = !this._showFavoritesOnly;\n }\n\n // Public methods for keyboard navigation from parent\n focusSearch() {\n this._searchInput?.focus();\n }\n\n clearSearch() {\n this._searchQuery = '';\n if (this._searchInput) {\n this._searchInput.value = '';\n }\n }\n\n getAllPhotons(): PhotonItem[] {\n return this._filteredPhotons;\n }\n\n toggleFavoritesFilter() {\n this._toggleFavoritesFilter();\n }\n\n isFavoritesFilterActive(): boolean {\n return this._showFavoritesOnly;\n }\n}\n", "import { LitElement, html, css } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { theme } from '../styles/theme.js';\n\ninterface MethodInfo {\n name: string;\n description: string;\n params: Record<string, any>;\n icon?: string;\n isTemplate?: boolean;\n}\n\n@customElement('method-card')\nexport class MethodCard extends LitElement {\n static styles = [\n theme,\n css`\n :host {\n display: block;\n height: 100%;\n }\n\n .card {\n padding: var(--space-md);\n display: flex;\n flex-direction: column;\n gap: var(--space-sm);\n cursor: pointer;\n transition:\n transform 0.2s ease,\n box-shadow 0.2s ease;\n height: 100%;\n box-sizing: border-box;\n position: relative;\n }\n\n .card:hover {\n transform: translateY(-2px);\n box-shadow: 0 8px 32px -4px rgba(0, 0, 0, 0.3);\n border-color: var(--accent-secondary);\n }\n\n .header {\n display: flex;\n justify-content: space-between;\n align-items: flex-start;\n gap: var(--space-sm);\n }\n\n .title-row {\n display: flex;\n align-items: center;\n gap: var(--space-sm);\n flex: 1;\n min-width: 0;\n }\n\n .method-icon {\n width: 32px;\n height: 32px;\n border-radius: 8px;\n background: var(--bg-glass);\n display: flex;\n align-items: center;\n justify-content: center;\n font-size: 16px;\n flex-shrink: 0;\n cursor: pointer;\n transition: all 0.15s ease;\n border: 1px solid transparent;\n }\n\n .method-icon:hover {\n background: var(--bg-glass-strong);\n border-color: var(--accent-primary);\n transform: scale(1.1);\n }\n\n .method-icon.placeholder {\n color: var(--t-muted);\n font-size: 12px;\n }\n\n .title {\n font-weight: 600;\n font-size: 1.1rem;\n margin: 0;\n color: var(--t-primary);\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n .description {\n font-size: 0.9rem;\n color: var(--t-muted);\n line-height: 1.5;\n margin-bottom: var(--space-md);\n flex: 1;\n display: -webkit-box;\n -webkit-line-clamp: 3;\n -webkit-box-orient: vertical;\n overflow: hidden;\n cursor: text;\n padding: 4px 6px;\n margin: -4px -6px;\n margin-bottom: calc(var(--space-md) - 4px);\n border-radius: var(--radius-sm);\n transition: background 0.15s ease;\n }\n\n .description:hover {\n background: var(--bg-glass);\n }\n\n .description.placeholder {\n font-style: italic;\n opacity: 0.7;\n }\n\n .description.editing {\n background: var(--bg-glass-strong);\n box-shadow: 0 0 0 2px var(--accent-primary);\n -webkit-line-clamp: unset;\n overflow: visible;\n }\n\n .description-input {\n background: transparent;\n border: none;\n color: inherit;\n font: inherit;\n width: 100%;\n outline: none;\n padding: 0;\n margin: 0;\n resize: none;\n line-height: 1.5;\n }\n\n .description-input::placeholder {\n color: var(--t-muted);\n font-style: italic;\n }\n\n .badge {\n font-size: 0.75rem;\n padding: 2px 8px;\n border-radius: 12px;\n background: hsla(220, 10%, 80%, 0.1);\n color: var(--t-muted);\n flex-shrink: 0;\n }\n\n .badge.prompt {\n background: hsla(45, 80%, 50%, 0.15);\n color: hsl(45, 80%, 60%);\n }\n\n .run-btn {\n align-self: flex-start;\n background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));\n border: none;\n padding: var(--space-sm) var(--space-lg);\n border-radius: var(--radius-sm);\n color: white;\n font-weight: 500;\n cursor: pointer;\n opacity: 0;\n transform: translateY(10px);\n transition: all 0.2s ease;\n }\n\n .card:hover .run-btn {\n opacity: 1;\n transform: translateY(0);\n }\n\n /* Emoji Picker */\n .emoji-picker {\n position: absolute;\n top: 50px;\n left: var(--space-md);\n background: var(--bg-panel);\n border: 1px solid var(--border-glass);\n border-radius: var(--radius-md);\n padding: var(--space-sm);\n box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);\n z-index: 100;\n display: grid;\n grid-template-columns: repeat(6, 1fr);\n gap: 2px;\n max-width: 200px;\n }\n\n .emoji-picker button {\n background: none;\n border: none;\n font-size: 1.2rem;\n padding: 4px;\n cursor: pointer;\n border-radius: var(--radius-sm);\n transition:\n background 0.15s ease,\n transform 0.1s ease;\n }\n\n .emoji-picker button:hover {\n background: var(--bg-glass);\n transform: scale(1.15);\n }\n\n .emoji-picker .remove-btn {\n font-size: 0.7rem;\n color: var(--t-muted);\n grid-column: span 6;\n padding: 6px;\n margin-top: 4px;\n border-top: 1px solid var(--border-glass);\n }\n\n .emoji-picker .remove-btn:hover {\n color: #f87171;\n background: hsla(0, 80%, 60%, 0.1);\n }\n\n /* ===== Responsive Design ===== */\n @media (max-width: 768px) {\n .card {\n padding: var(--space-md);\n min-height: 44px;\n }\n\n /* Make run button always visible on touch devices */\n .run-btn {\n opacity: 1;\n transform: none;\n width: 100%;\n }\n\n .emoji-picker {\n position: fixed;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n max-width: 90vw;\n z-index: 1000;\n }\n }\n\n @media (max-width: 480px) {\n .title {\n font-size: 1rem;\n }\n\n .description {\n font-size: 0.85rem;\n -webkit-line-clamp: 2;\n }\n\n .method-icon {\n width: 28px;\n height: 28px;\n font-size: 14px;\n }\n }\n `,\n ];\n\n @property({ type: Object })\n method!: MethodInfo;\n\n @property({ type: String })\n photonName = '';\n\n @state() private _editingDescription = false;\n @state() private _editingIcon = false;\n @state() private _editedDescription = '';\n\n connectedCallback() {\n super.connectedCallback();\n document.addEventListener('click', this._handleDocumentClick);\n }\n\n disconnectedCallback() {\n super.disconnectedCallback();\n document.removeEventListener('click', this._handleDocumentClick);\n }\n\n private _handleDocumentClick = (e: MouseEvent) => {\n if (this._editingIcon) {\n const path = e.composedPath();\n const picker = this.shadowRoot?.querySelector('.emoji-picker');\n const icon = this.shadowRoot?.querySelector('.method-icon');\n if (picker && !path.includes(picker) && !path.includes(icon!)) {\n this._editingIcon = false;\n }\n }\n };\n\n render() {\n const hasIcon = !!this.method.icon;\n const hasDescription =\n this.method.description && this.method.description !== 'No description provided.';\n const initials = this.method.name.substring(0, 2).toUpperCase();\n\n return html`\n <div class=\"card glass-panel\" @click=${this._handleCardClick}>\n <div>\n <div class=\"header\">\n <div class=\"title-row\">\n <div\n class=\"method-icon ${hasIcon ? '' : 'placeholder'}\"\n @click=${this._handleIconClick}\n title=\"Click to set icon\"\n >\n ${hasIcon ? this.method.icon : initials}\n </div>\n <h3 class=\"title\">${this.method.name}</h3>\n </div>\n ${this.method.isTemplate\n ? html`<span class=\"badge prompt\">Prompt</span>`\n : Object.keys(this.method.params || {}).length > 0\n ? html`<span class=\"badge\">Params</span>`\n : html`<span\n class=\"badge\"\n style=\"background: hsla(150, 50%, 40%, 0.2); color: #4ade80;\"\n >Ready</span\n >`}\n </div>\n ${this._editingDescription\n ? html`\n <div class=\"description editing\" @click=${(e: Event) => e.stopPropagation()}>\n <textarea\n class=\"description-input\"\n .value=${this._editedDescription}\n placeholder=\"Add a description...\"\n rows=\"3\"\n @input=${(e: Event) =>\n (this._editedDescription = (e.target as HTMLTextAreaElement).value)}\n @blur=${this._saveDescription}\n @keydown=${this._handleDescriptionKeydown}\n @click=${(e: Event) => e.stopPropagation()}\n ></textarea>\n </div>\n `\n : html`\n <p\n class=\"description ${hasDescription ? '' : 'placeholder'}\"\n @click=${this._handleDescriptionClick}\n title=\"Click to edit description\"\n >\n ${hasDescription ? this.method.description : 'Click to add description...'}\n </p>\n `}\n </div>\n <button class=\"run-btn\" @click=${this._handleRunClick}>Run Method</button>\n ${this._editingIcon ? this._renderEmojiPicker() : ''}\n </div>\n `;\n }\n\n private _renderEmojiPicker() {\n const emojis = [\n '\uD83D\uDCE5',\n '\uD83D\uDCE4',\n '\uD83D\uDD0D',\n '\uD83D\uDD0E',\n '\uD83D\uDCCA',\n '\uD83D\uDCC8',\n '\uD83D\uDCBE',\n '\uD83D\uDCC1',\n '\uD83D\uDCDD',\n '\u270F\uFE0F',\n '\uD83D\uDDD1\uFE0F',\n '\u2795',\n '\uD83D\uDD04',\n '\u26A1',\n '\uD83D\uDD27',\n '\u2699\uFE0F',\n '\uD83D\uDEE0\uFE0F',\n '\uD83D\uDD28',\n '\uD83D\uDD12',\n '\uD83D\uDD13',\n '\uD83D\uDD11',\n '\uD83D\uDEE1\uFE0F',\n '\uD83D\uDC64',\n '\uD83D\uDC65',\n '\uD83D\uDCE7',\n '\uD83D\uDCAC',\n '\uD83D\uDD14',\n '\uD83D\uDCE3',\n '\uD83C\uDF10',\n '\uD83D\uDD17',\n '\u2705',\n '\u274C',\n '\u2B50',\n '\uD83C\uDFAF',\n '\uD83D\uDCA1',\n '\uD83D\uDE80',\n ];\n\n return html`\n <div class=\"emoji-picker\" @click=${(e: Event) => e.stopPropagation()}>\n ${emojis.map(\n (emoji) => html` <button @click=${() => this._selectIcon(emoji)}>${emoji}</button> `\n )}\n ${this.method.icon\n ? html`\n <button class=\"remove-btn\" @click=${() => this._selectIcon('')}>Remove icon</button>\n `\n : ''}\n </div>\n `;\n }\n\n private _handleCardClick(e: Event) {\n // Don't trigger card click if editing\n if (this._editingDescription || this._editingIcon) {\n return;\n }\n this.dispatchEvent(new CustomEvent('select', { detail: { method: this.method } }));\n }\n\n private _handleRunClick(e: Event) {\n e.stopPropagation();\n this.dispatchEvent(new CustomEvent('select', { detail: { method: this.method } }));\n }\n\n private _handleIconClick(e: Event) {\n e.stopPropagation();\n this._editingIcon = !this._editingIcon;\n }\n\n private _selectIcon(icon: string) {\n this._editingIcon = false;\n\n // Dispatch event to parent for persistence\n this.dispatchEvent(\n new CustomEvent('update-metadata', {\n bubbles: true,\n composed: true,\n detail: {\n photonName: this.photonName,\n methodName: this.method.name,\n metadata: { icon: icon || null },\n },\n })\n );\n }\n\n private _handleDescriptionClick(e: Event) {\n e.stopPropagation();\n this._editedDescription = this.method.description || '';\n this._editingDescription = true;\n\n // Focus the textarea after render\n this.updateComplete.then(() => {\n const textarea = this.shadowRoot?.querySelector('.description-input') as HTMLTextAreaElement;\n textarea?.focus();\n textarea?.select();\n });\n }\n\n private _handleDescriptionKeydown(e: KeyboardEvent) {\n if (e.key === 'Enter' && !e.shiftKey) {\n e.preventDefault();\n this._saveDescription();\n } else if (e.key === 'Escape') {\n this._editingDescription = false;\n }\n }\n\n private _saveDescription() {\n this._editingDescription = false;\n const newDesc = this._editedDescription.trim();\n\n // Dispatch event to parent for persistence\n this.dispatchEvent(\n new CustomEvent('update-metadata', {\n bubbles: true,\n composed: true,\n detail: {\n photonName: this.photonName,\n methodName: this.method.name,\n metadata: { description: newDesc || null },\n },\n })\n );\n }\n}\n", "import { LitElement, html, css } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { theme } from '../styles/theme.js';\nimport { showToast } from './toast-manager.js';\n\ninterface MethodParam {\n type: string;\n description?: string;\n required?: boolean;\n}\n\n@customElement('invoke-form')\nexport class InvokeForm extends LitElement {\n static styles = [\n theme,\n css`\n :host {\n display: block;\n }\n\n .form-container {\n padding: var(--space-lg);\n }\n\n .form-group {\n margin-bottom: var(--space-md);\n }\n\n label {\n display: block;\n margin-bottom: var(--space-xs);\n font-weight: 500;\n font-size: 0.9rem;\n }\n\n .hint {\n font-size: 0.8rem;\n color: var(--t-muted);\n margin-left: var(--space-xs);\n }\n\n input,\n textarea,\n select {\n width: 100%;\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n color: var(--t-primary);\n padding: var(--space-sm);\n border-radius: var(--radius-sm);\n font-family: var(--font-sans);\n box-sizing: border-box;\n }\n\n input:focus,\n textarea:focus {\n outline: none;\n border-color: var(--accent-primary);\n box-shadow: 0 0 0 2px var(--glow-primary);\n }\n\n .actions {\n display: flex;\n justify-content: flex-end;\n gap: var(--space-md);\n margin-top: var(--space-lg);\n padding-top: var(--space-md);\n border-top: 1px solid var(--border-glass);\n }\n\n button {\n padding: var(--space-sm) var(--space-lg);\n border-radius: var(--radius-sm);\n font-weight: 500;\n cursor: pointer;\n border: none;\n font-family: var(--font-sans);\n transition: all 0.2s;\n }\n\n .btn-primary {\n background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));\n color: white;\n }\n\n .btn-primary:hover {\n opacity: 0.9;\n transform: translateY(-1px);\n box-shadow: 0 4px 12px var(--glow-primary);\n }\n\n .btn-secondary {\n background: transparent;\n color: var(--t-muted);\n border: 1px solid var(--border-glass);\n }\n\n .btn-secondary:hover {\n background: hsla(220, 10%, 80%, 0.1);\n color: var(--t-primary);\n }\n\n .btn-primary:disabled {\n opacity: 0.6;\n cursor: not-allowed;\n transform: none;\n }\n\n .btn-loading {\n display: inline-flex;\n align-items: center;\n gap: var(--space-sm);\n }\n\n .spinner {\n width: 16px;\n height: 16px;\n border: 2px solid rgba(255, 255, 255, 0.3);\n border-top-color: white;\n border-radius: 50%;\n animation: spin 0.8s linear infinite;\n }\n\n @keyframes spin {\n to {\n transform: rotate(360deg);\n }\n }\n\n .error-text {\n color: #f87171;\n font-size: 0.75rem;\n margin-top: var(--space-xs);\n }\n\n input.error,\n textarea.error,\n select.error {\n border-color: #f87171;\n }\n\n input.error:focus,\n textarea.error:focus {\n box-shadow: 0 0 0 2px rgba(248, 113, 113, 0.3);\n }\n\n /* Multiselect Styles */\n .multiselect-container {\n display: flex;\n flex-wrap: wrap;\n gap: var(--space-sm);\n }\n\n .multiselect-option {\n display: flex;\n align-items: center;\n gap: 6px;\n padding: 6px 12px;\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n border-radius: var(--radius-sm);\n cursor: pointer;\n transition: all 0.2s;\n user-select: none;\n }\n\n .multiselect-option:hover {\n border-color: var(--accent-secondary);\n }\n\n .multiselect-option.selected {\n background: var(--accent-primary);\n border-color: var(--accent-primary);\n color: white;\n }\n\n .multiselect-option input {\n width: auto;\n margin: 0;\n cursor: pointer;\n }\n\n /* Number Input with Range Slider */\n .number-with-range {\n display: flex;\n flex-direction: column;\n gap: var(--space-xs);\n }\n\n .number-with-range input[type='range'] {\n width: 100%;\n height: 6px;\n background: var(--bg-glass);\n border-radius: 3px;\n border: none;\n -webkit-appearance: none;\n }\n\n .number-with-range input[type='range']::-webkit-slider-thumb {\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background: var(--accent-primary);\n border-radius: 50%;\n cursor: pointer;\n }\n\n .number-input-row {\n display: flex;\n align-items: center;\n gap: var(--space-sm);\n }\n\n .number-input-row input[type='number'] {\n width: 100px;\n }\n\n .range-labels {\n display: flex;\n justify-content: space-between;\n font-size: 0.75rem;\n color: var(--t-muted);\n }\n\n /* ===== Responsive Design ===== */\n @media (max-width: 768px) {\n .form-container {\n padding: var(--space-md);\n }\n\n input,\n textarea,\n select {\n min-height: 44px;\n font-size: 16px; /* Prevent iOS zoom */\n }\n\n button {\n min-height: 44px;\n padding: var(--space-sm) var(--space-md);\n }\n\n .actions {\n flex-direction: column;\n }\n\n .actions button {\n width: 100%;\n }\n }\n\n @media (max-width: 480px) {\n .form-container {\n padding: var(--space-sm);\n }\n\n .number-input-row {\n flex-direction: column;\n align-items: stretch;\n }\n\n .number-input-row input[type='number'] {\n width: 100%;\n }\n\n .multiselect-container {\n flex-direction: column;\n }\n\n .multiselect-option {\n width: 100%;\n justify-content: center;\n }\n }\n `,\n ];\n\n @property({ type: Object })\n params: Record<string, MethodParam> = {};\n\n @property({ type: Boolean })\n loading = false;\n\n /** Photon name for localStorage key */\n @property({ type: String })\n photonName = '';\n\n /** Method name for localStorage key */\n @property({ type: String })\n methodName = '';\n\n /** Whether to remember form values (controlled by parent settings menu) */\n @property({ type: Boolean })\n rememberValues = false;\n\n /** Pre-populated values from shared link */\n @property({ type: Object })\n sharedValues: Record<string, any> | null = null;\n\n @state()\n private _values: Record<string, any> = {};\n\n @state()\n private _errors: Record<string, string> = {};\n\n private get _storageKey(): string {\n return `beam-form:${this.photonName}:${this.methodName}`;\n }\n\n connectedCallback() {\n super.connectedCallback();\n this._loadPersistedValues();\n }\n\n updated(changedProps: Map<string, unknown>) {\n // Reload persisted values when photon/method or remember setting changes\n if (\n changedProps.has('photonName') ||\n changedProps.has('methodName') ||\n changedProps.has('rememberValues')\n ) {\n this._loadPersistedValues();\n }\n // Apply shared values from URL (takes priority over persisted values)\n if (changedProps.has('sharedValues') && this.sharedValues) {\n this._values = { ...this._values, ...this.sharedValues };\n showToast('Form pre-filled from shared link', 'info');\n }\n }\n\n private _loadPersistedValues() {\n if (!this.photonName || !this.methodName) return;\n\n // Only load persisted values if remember is enabled\n if (!this.rememberValues) {\n this._values = {};\n return;\n }\n\n try {\n const stored = localStorage.getItem(this._storageKey);\n if (stored) {\n const data = JSON.parse(stored);\n this._values = data.values || {};\n }\n } catch (e) {\n console.warn('Failed to load persisted form values:', e);\n }\n }\n\n private _savePersistedValues() {\n if (!this.photonName || !this.methodName) return;\n\n try {\n if (this.rememberValues) {\n localStorage.setItem(\n this._storageKey,\n JSON.stringify({\n values: this._values,\n })\n );\n }\n } catch (e) {\n console.warn('Failed to save form values:', e);\n }\n }\n\n private _clearPersistedValues() {\n if (!this.photonName || !this.methodName) return;\n\n localStorage.removeItem(this._storageKey);\n this._values = {};\n showToast('Form values cleared', 'info');\n this.requestUpdate();\n }\n\n render() {\n return html`\n <div class=\"form-container\">\n ${this._renderFields()}\n\n <div class=\"actions\">\n <button class=\"btn-secondary\" @click=${this._handleCancel} ?disabled=${this.loading}>\n Cancel\n </button>\n <button class=\"btn-primary\" @click=${this._handleSubmit} ?disabled=${this.loading}>\n ${this.loading\n ? html`<span class=\"btn-loading\"><span class=\"spinner\"></span>Executing...</span>`\n : 'Execute'}\n </button>\n </div>\n </div>\n `;\n }\n\n private _renderFields() {\n // Handle standard JSON Schema 'properties'\n const properties = (this.params as any).properties || this.params;\n const requiredList = (this.params as any).required || [];\n\n // Check if properties is actual object to avoid crash\n if (!properties || typeof properties !== 'object') {\n return html`<p>No parameters required.</p>`;\n }\n\n return Object.entries(properties).map(([key, schema]: [string, any]) => {\n const isRequired = Array.isArray(requiredList)\n ? requiredList.includes(key)\n : !!schema.required;\n const error = this._errors[key];\n\n return html`\n <div class=\"form-group\">\n <label>\n ${key} ${isRequired ? html`<span style=\"color: var(--accent-secondary)\">*</span>` : ''}\n ${schema.description ? html`<span class=\"hint\">${schema.description}</span>` : ''}\n </label>\n ${this._renderInput(key, schema, !!error)}\n ${error ? html`<div class=\"error-text\">${error}</div>` : ''}\n </div>\n `;\n });\n }\n\n private _renderInput(key: string, schema: MethodParam, hasError = false) {\n const isBoolean = schema.type === 'boolean' || (schema as any).type === '\"boolean\"';\n const errorClass = hasError ? 'error' : '';\n\n // Handle Boolean -> Toggle Switch\n if (isBoolean) {\n return html`\n <label class=\"switch\">\n <input\n type=\"checkbox\"\n .checked=${!!this._values[key]}\n @change=${(e: Event) => this._handleChange(key, (e.target as HTMLInputElement).checked)}\n />\n <span class=\"slider\"></span>\n </label>\n `;\n }\n\n // Handle Array of Enums -> Multiselect\n if (schema.type === 'array' && (schema as any).items?.enum) {\n const enumValues = (schema as any).items.enum as string[];\n const selectedValues = (this._values[key] as string[]) || [];\n\n return html`\n <div class=\"multiselect-container\">\n ${enumValues.map(\n (val) => html`\n <label\n class=\"multiselect-option ${selectedValues.includes(val) ? 'selected' : ''}\"\n @click=${() => this._toggleMultiselect(key, val)}\n >\n <input\n type=\"checkbox\"\n .checked=${selectedValues.includes(val)}\n @click=${(e: Event) => e.stopPropagation()}\n @change=${() => this._toggleMultiselect(key, val)}\n />\n ${val}\n </label>\n `\n )}\n </div>\n `;\n }\n\n // Handle Enums -> Select Dropdown\n if ((schema as any).enum) {\n const currentValue = this._values[key] || '';\n return html`\n <select\n class=\"${errorClass}\"\n .value=${currentValue}\n @change=${(e: Event) => this._handleChange(key, (e.target as HTMLSelectElement).value)}\n >\n <option value=\"\">Select...</option>\n ${(schema as any).enum.map(\n (val: string) => html`\n <option value=${val} ?selected=${val === currentValue}>${val}</option>\n `\n )}\n </select>\n `;\n }\n\n // Handle Number with min/max -> Number Input with Range Slider\n if (schema.type === 'number' || schema.type === 'integer') {\n const hasRange =\n (schema as any).minimum !== undefined && (schema as any).maximum !== undefined;\n const min = (schema as any).minimum ?? 0;\n const max = (schema as any).maximum ?? 100;\n const step = schema.type === 'integer' ? 1 : 0.1;\n const currentValue = this._values[key] ?? (schema as any).default ?? min;\n\n if (hasRange) {\n return html`\n <div class=\"number-with-range\">\n <div class=\"number-input-row\">\n <input\n type=\"number\"\n class=\"${errorClass}\"\n min=\"${min}\"\n max=\"${max}\"\n step=\"${step}\"\n .value=${String(currentValue)}\n @input=${(e: Event) =>\n this._handleChange(key, Number((e.target as HTMLInputElement).value))}\n />\n <input\n type=\"range\"\n min=\"${min}\"\n max=\"${max}\"\n step=\"${step}\"\n .value=${String(currentValue)}\n @input=${(e: Event) =>\n this._handleChange(key, Number((e.target as HTMLInputElement).value))}\n />\n </div>\n <div class=\"range-labels\">\n <span>${min}</span>\n <span>${max}</span>\n </div>\n </div>\n `;\n }\n\n return html`\n <input\n type=\"number\"\n class=\"${errorClass}\"\n .value=${this._values[key] !== undefined ? String(this._values[key]) : ''}\n @input=${(e: Event) =>\n this._handleChange(key, Number((e.target as HTMLInputElement).value))}\n />\n `;\n }\n\n // Handle File Paths -> File Picker\n // Heuristic: Key contains \"path\", \"file\", \"dir\" or schema.format matches\n const isFile =\n key.toLowerCase().includes('path') ||\n key.toLowerCase().includes('file') ||\n (schema as any).format === 'path' ||\n (schema as any).format === 'file';\n\n if (isFile) {\n // Support @accept filter from schema (e.g., \".ts,.js\" or \"*.photon.ts\")\n const acceptFilter = (schema as any).accept || '';\n return html`\n <file-picker\n .value=${this._values[key] || ''}\n .hasError=${hasError}\n .accept=${acceptFilter}\n @change=${(e: CustomEvent) => this._handleChange(key, e.detail.value)}\n ></file-picker>\n `;\n }\n\n // Default -> Text Input\n return html`\n <input\n type=\"text\"\n class=\"${errorClass}\"\n .value=${this._values[key] || ''}\n @input=${(e: Event) => this._handleChange(key, (e.target as HTMLInputElement).value)}\n />\n `;\n }\n\n private _toggleMultiselect(key: string, value: string) {\n const currentValues = (this._values[key] as string[]) || [];\n let newValues: string[];\n\n if (currentValues.includes(value)) {\n newValues = currentValues.filter((v) => v !== value);\n } else {\n newValues = [...currentValues, value];\n }\n\n this._values = { ...this._values, [key]: newValues };\n if (this.rememberValues) {\n this._savePersistedValues();\n }\n }\n\n private _handleChange(key: string, value: any) {\n this._values = { ...this._values, [key]: value };\n if (this.rememberValues) {\n this._savePersistedValues();\n }\n }\n\n private _handleSubmit() {\n // Validate required fields\n const properties = (this.params as any).properties || this.params;\n const requiredList = (this.params as any).required || [];\n const errors: Record<string, string> = {};\n\n if (properties && typeof properties === 'object') {\n for (const [key, schema] of Object.entries(properties)) {\n const isRequired = Array.isArray(requiredList)\n ? requiredList.includes(key)\n : !!(schema as any).required;\n\n if (isRequired) {\n const value = this._values[key];\n if (value === undefined || value === null || value === '') {\n errors[key] = 'This field is required';\n }\n }\n }\n }\n\n if (Object.keys(errors).length > 0) {\n this._errors = errors;\n showToast('Please fill in all required fields', 'warning');\n return;\n }\n\n this._errors = {};\n this.dispatchEvent(new CustomEvent('submit', { detail: { args: this._values } }));\n }\n\n private _handleCancel() {\n this.dispatchEvent(new CustomEvent('cancel'));\n }\n}\n", "import { LitElement, html, css } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { theme } from '../styles/theme.js';\n\ninterface ActivityItem {\n id: string;\n type: 'info' | 'success' | 'error' | 'warning';\n message: string;\n timestamp: string;\n count?: number; // For collapsed repeated messages\n}\n\n@customElement('activity-log')\nexport class ActivityLog extends LitElement {\n static styles = [\n theme,\n css`\n :host {\n display: block;\n margin-top: var(--space-xl);\n padding-top: var(--space-lg);\n border-top: 1px solid var(--border-glass);\n }\n\n .log-header {\n display: flex;\n justify-content: space-between;\n align-items: center;\n margin-bottom: var(--space-md);\n padding: 0 var(--space-xs);\n }\n\n h3 {\n margin: 0;\n font-size: 0.8rem;\n text-transform: uppercase;\n letter-spacing: 0.1em;\n color: var(--t-secondary); /* Brighter */\n font-weight: 600;\n }\n\n .clear-btn {\n background: none;\n border: none;\n color: var(--t-muted);\n font-size: 0.8rem;\n cursor: pointer;\n padding: 4px 8px;\n border-radius: 4px;\n }\n\n .clear-btn:hover {\n background: hsla(220, 10%, 80%, 0.1);\n color: var(--t-primary);\n }\n\n .log-list {\n display: flex;\n flex-direction: column;\n gap: var(--space-xs);\n }\n\n .log-item {\n padding: var(--space-sm) var(--space-md);\n border-radius: var(--radius-sm);\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n border-left-width: 3px;\n border-left-style: solid;\n font-family: var(--font-mono);\n font-size: 0.85rem;\n display: flex;\n gap: var(--space-md);\n }\n\n .meta {\n color: var(--t-muted);\n flex-shrink: 0;\n min-width: 95px;\n }\n\n .count {\n color: var(--t-muted);\n font-size: 0.75rem;\n opacity: 0.8;\n margin-left: var(--space-xs);\n }\n\n .content {\n color: var(--t-primary);\n flex: 1;\n word-break: break-all;\n }\n\n .type-info {\n border-left-color: var(--accent-secondary);\n }\n .type-success {\n border-left-color: #4ade80;\n }\n .type-error {\n border-left-color: #f87171;\n }\n .type-warning {\n border-left-color: #fbbf24;\n }\n\n /* ===== Responsive Design ===== */\n @media (max-width: 768px) {\n .log-item {\n flex-direction: column;\n gap: var(--space-xs);\n }\n\n .meta {\n width: auto;\n font-size: 0.75rem;\n }\n\n .clear-btn {\n min-height: 44px;\n padding: var(--space-sm) var(--space-md);\n }\n }\n\n @media (max-width: 480px) {\n :host {\n margin-top: var(--space-lg);\n padding-top: var(--space-md);\n }\n\n .content {\n font-size: 0.8rem;\n }\n }\n `,\n ];\n\n @property({ type: Array })\n items: ActivityItem[] = [];\n\n render() {\n if (this.items.length === 0) return html``;\n\n return html`\n <div class=\"log-header\">\n <h3>Activity Log</h3>\n <button class=\"clear-btn\" @click=${this._clear}>Clear</button>\n </div>\n\n <div class=\"log-list\">\n ${this.items.map(\n (item) => html`\n <div class=\"log-item type-${item.type}\">\n <span class=\"meta\">${new Date(item.timestamp).toLocaleTimeString()}</span>\n <span class=\"content\"\n >${item.message}${item.count && item.count > 1\n ? html`<span class=\"count\">(\u00D7${item.count})</span>`\n : ''}</span\n >\n </div>\n `\n )}\n </div>\n `;\n }\n\n private _clear() {\n this.dispatchEvent(new CustomEvent('clear'));\n }\n}\n", "import { LitElement, html, css, TemplateResult } from 'lit';\nimport { unsafeHTML } from 'lit/directives/unsafe-html.js';\nimport { customElement, property, state, query } from 'lit/decorators.js';\nimport { theme, Theme } from '../styles/theme.js';\nimport { showToast } from './toast-manager.js';\n\ntype LayoutType =\n | 'table'\n | 'list'\n | 'card'\n | 'tree'\n | 'json'\n | 'markdown'\n | 'mermaid'\n | 'code'\n | 'text'\n | 'chips'\n | 'html';\n\ninterface LayoutHints {\n title?: string;\n subtitle?: string;\n icon?: string;\n badge?: string;\n detail?: string;\n style?: string;\n columns?: string;\n filter?: string;\n}\n\n@customElement('result-viewer')\nexport class ResultViewer extends LitElement {\n static styles = [\n theme,\n css`\n :host {\n display: block;\n margin-top: var(--space-md);\n }\n\n .container {\n padding: var(--space-md);\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n border-radius: var(--radius-md);\n position: relative;\n overflow: hidden;\n }\n\n .header {\n display: flex;\n justify-content: space-between;\n align-items: center;\n margin-bottom: var(--space-sm);\n padding-bottom: var(--space-sm);\n border-bottom: 1px solid var(--border-glass);\n }\n\n .title {\n font-size: 0.8rem;\n text-transform: uppercase;\n letter-spacing: 0.05em;\n color: var(--t-muted);\n font-weight: 600;\n }\n\n .format-badge {\n font-size: 0.7rem;\n padding: 2px 8px;\n background: var(--bg-glass-strong);\n border: 1px solid var(--border-glass);\n border-radius: 10px;\n color: var(--accent-secondary);\n }\n\n .actions {\n display: flex;\n gap: var(--space-sm);\n }\n\n button {\n background: transparent;\n border: 1px solid var(--border-glass);\n color: var(--t-muted);\n border-radius: var(--radius-sm);\n cursor: pointer;\n padding: 4px 8px;\n font-size: 0.75rem;\n transition: all 0.2s;\n }\n\n button:hover {\n background: hsla(220, 10%, 80%, 0.1);\n color: var(--t-primary);\n }\n\n .content {\n font-family: var(--font-mono);\n font-size: 0.9rem;\n color: var(--t-primary);\n white-space: pre-wrap;\n overflow-x: auto;\n max-height: 500px;\n line-height: 1.5;\n }\n\n /* JSON Syntax Highlighting - Theme Aware */\n .json-key {\n color: var(--syntax-key, var(--accent-secondary));\n }\n .json-string {\n color: var(--syntax-string, #a5d6ff);\n }\n .json-number {\n color: var(--syntax-number, #ff9e64);\n }\n .json-boolean {\n color: var(--syntax-boolean, #ff007c);\n }\n .json-null {\n color: var(--syntax-null, #79c0ff);\n }\n\n /* Syntax Highlighting Colors - Dark Theme (default) */\n :host {\n --syntax-key: var(--accent-secondary);\n --syntax-string: #a5d6ff;\n --syntax-number: #ff9e64;\n --syntax-boolean: #ff007c;\n --syntax-null: #79c0ff;\n --syntax-comment: #6a737d;\n --syntax-keyword: #ff7b72;\n --syntax-function: #d2a8ff;\n --syntax-operator: #79c0ff;\n --syntax-punctuation: #8b949e;\n --code-bg: rgba(0, 0, 0, 0.3);\n }\n\n /* Syntax Highlighting Colors - Light Theme */\n :host([data-theme='light']) {\n --syntax-key: #0550ae;\n --syntax-string: #0a3069;\n --syntax-number: #953800;\n --syntax-boolean: #cf222e;\n --syntax-null: #0550ae;\n --syntax-comment: #57606a;\n --syntax-keyword: #cf222e;\n --syntax-function: #8250df;\n --syntax-operator: #0550ae;\n --syntax-punctuation: #24292f;\n --code-bg: rgba(0, 0, 0, 0.05);\n }\n\n /* Prism.js Code Highlighting Overrides */\n .token.comment,\n .token.prolog,\n .token.doctype,\n .token.cdata {\n color: var(--syntax-comment);\n }\n .token.punctuation {\n color: var(--syntax-punctuation);\n }\n .token.property,\n .token.tag,\n .token.constant,\n .token.symbol,\n .token.deleted {\n color: var(--syntax-key);\n }\n .token.boolean,\n .token.number {\n color: var(--syntax-number);\n }\n .token.selector,\n .token.attr-name,\n .token.string,\n .token.char,\n .token.builtin,\n .token.inserted {\n color: var(--syntax-string);\n }\n .token.operator,\n .token.entity,\n .token.url,\n .language-css .token.string,\n .style .token.string {\n color: var(--syntax-operator);\n }\n .token.atrule,\n .token.attr-value,\n .token.keyword {\n color: var(--syntax-keyword);\n }\n .token.function,\n .token.class-name {\n color: var(--syntax-function);\n }\n .token.regex,\n .token.important,\n .token.variable {\n color: var(--syntax-boolean);\n }\n\n /* Table Styles */\n .smart-table {\n width: 100%;\n border-collapse: collapse;\n font-family: var(--font-sans);\n font-size: 0.9rem;\n }\n\n .smart-table th {\n text-align: left;\n padding: var(--space-sm) var(--space-md);\n background: var(--bg-glass-strong);\n border-bottom: 1px solid var(--border-glass);\n color: var(--t-muted);\n font-weight: 600;\n text-transform: capitalize;\n }\n\n .smart-table td {\n padding: var(--space-sm) var(--space-md);\n border-bottom: 1px solid var(--border-glass);\n color: var(--t-primary);\n }\n\n .smart-table tr:hover td {\n background: hsla(220, 10%, 80%, 0.05);\n }\n\n /* Key-Value Table (single object) */\n .kv-table {\n max-width: 600px;\n }\n\n .kv-table th:first-child,\n .kv-table .kv-key {\n width: 140px;\n font-weight: 600;\n color: var(--t-muted);\n text-transform: uppercase;\n font-size: 0.75rem;\n letter-spacing: 0.05em;\n }\n\n /* List Styles */\n .smart-list {\n list-style: none;\n padding: 0;\n margin: 0;\n display: flex;\n flex-direction: column;\n gap: 1px;\n background: var(--border-glass);\n border-radius: var(--radius-sm);\n overflow: hidden;\n }\n\n .list-item {\n display: flex;\n align-items: center;\n gap: var(--space-md);\n padding: var(--space-sm) var(--space-md);\n background: var(--bg-panel);\n font-family: var(--font-sans);\n }\n\n .list-item-leading {\n width: 36px;\n height: 36px;\n display: flex;\n align-items: center;\n justify-content: center;\n background: var(--bg-glass);\n border-radius: var(--radius-sm);\n font-size: 1rem;\n flex-shrink: 0;\n }\n\n .list-item-leading img {\n width: 100%;\n height: 100%;\n object-fit: cover;\n border-radius: var(--radius-sm);\n }\n\n .list-item-content {\n flex: 1;\n min-width: 0;\n }\n\n .list-item-title {\n font-weight: 500;\n color: var(--t-primary);\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n .list-item-subtitle {\n font-size: 0.85rem;\n color: var(--t-muted);\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n .list-item-trailing {\n display: flex;\n align-items: center;\n gap: var(--space-sm);\n flex-shrink: 0;\n }\n\n .status-badge {\n padding: 2px 8px;\n border-radius: 10px;\n font-size: 0.75rem;\n font-weight: 500;\n }\n\n .status-success,\n .status-active,\n .status-completed,\n .status-online {\n background: hsla(120, 60%, 50%, 0.15);\n color: hsl(120, 60%, 50%);\n }\n\n .status-error,\n .status-failed,\n .status-offline,\n .status-inactive {\n background: hsla(0, 60%, 50%, 0.15);\n color: hsl(0, 60%, 50%);\n }\n\n .status-warning,\n .status-pending,\n .status-processing {\n background: hsla(45, 80%, 50%, 0.15);\n color: hsl(45, 80%, 50%);\n }\n\n /* Link Styles */\n .result-link {\n display: inline-flex;\n align-items: center;\n gap: 4px;\n padding: 6px 12px;\n background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));\n color: white;\n text-decoration: none;\n border-radius: var(--radius-sm);\n font-weight: 500;\n font-size: 0.9rem;\n word-break: break-all;\n transition:\n opacity 0.2s,\n transform 0.2s;\n }\n\n .result-link:hover {\n opacity: 0.9;\n transform: translateY(-1px);\n }\n\n .result-link .link-icon {\n font-size: 0.8em;\n opacity: 0.8;\n }\n\n /* Card Styles */\n .smart-card {\n padding: var(--space-md);\n font-family: var(--font-sans);\n }\n\n .card-header {\n display: flex;\n align-items: center;\n gap: var(--space-md);\n margin-bottom: var(--space-md);\n padding-bottom: var(--space-md);\n border-bottom: 1px solid var(--border-glass);\n }\n\n .card-icon {\n width: 48px;\n height: 48px;\n display: flex;\n align-items: center;\n justify-content: center;\n background: var(--bg-glass);\n border-radius: var(--radius-md);\n font-size: 1.5rem;\n }\n\n .card-title {\n font-size: 1.2rem;\n font-weight: 600;\n color: var(--t-primary);\n }\n\n .card-subtitle {\n color: var(--t-muted);\n font-size: 0.9rem;\n }\n\n .card-fields {\n display: grid;\n grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));\n gap: var(--space-md);\n }\n\n .card-field {\n display: flex;\n flex-direction: column;\n gap: 2px;\n }\n\n .card-field-label {\n font-size: 0.75rem;\n color: var(--t-muted);\n text-transform: uppercase;\n letter-spacing: 0.05em;\n }\n\n .card-field-value {\n color: var(--t-primary);\n }\n\n /* Chips Styles */\n .smart-chips {\n display: flex;\n flex-wrap: wrap;\n gap: var(--space-sm);\n font-family: var(--font-sans);\n }\n\n .chip {\n padding: var(--space-xs) var(--space-md);\n background: var(--bg-glass-strong);\n border: 1px solid var(--border-glass);\n border-radius: 20px;\n font-size: 0.85rem;\n color: var(--t-primary);\n }\n\n /* Markdown Styles */\n .markdown-body {\n font-family: var(--font-sans);\n line-height: 1.6;\n }\n\n .markdown-body p {\n margin-bottom: 0.5em;\n }\n .markdown-body code {\n background: var(--code-bg);\n padding: 2px 6px;\n border-radius: 4px;\n font-family: var(--font-mono);\n font-size: 0.9em;\n }\n .markdown-body pre {\n background: var(--code-bg);\n padding: 1em;\n border-radius: 8px;\n overflow-x: auto;\n border: 1px solid var(--border-glass);\n }\n .markdown-body pre code {\n background: transparent;\n padding: 0;\n font-size: 0.85em;\n line-height: 1.5;\n }\n .markdown-body ul,\n .markdown-body ol {\n margin-left: 1.5em;\n margin-bottom: 0.5em;\n }\n .markdown-body h1,\n .markdown-body h2,\n .markdown-body h3 {\n margin-top: 1em;\n margin-bottom: 0.5em;\n color: var(--t-primary);\n }\n .markdown-body a {\n color: var(--accent-primary);\n text-decoration: none;\n }\n .markdown-body a:hover {\n text-decoration: underline;\n }\n .markdown-body table {\n border-collapse: collapse;\n width: 100%;\n margin: 1em 0;\n }\n .markdown-body th,\n .markdown-body td {\n border: 1px solid var(--border-glass);\n padding: 8px;\n text-align: left;\n }\n .markdown-body th {\n background: var(--code-bg);\n }\n\n /* Code block language label */\n .code-block-wrapper {\n position: relative;\n margin: 1em 0;\n }\n .code-block-wrapper .language-label {\n position: absolute;\n top: 0;\n right: 0;\n padding: 2px 8px;\n font-size: 0.7rem;\n text-transform: uppercase;\n color: var(--t-muted);\n background: var(--bg-glass-strong);\n border-radius: 0 8px 0 4px;\n font-family: var(--font-mono);\n }\n\n /* Empty State */\n .empty-state {\n text-align: center;\n padding: var(--space-lg);\n color: var(--t-muted);\n font-style: italic;\n }\n\n /* Filter Input */\n .filter-container {\n display: flex;\n align-items: center;\n gap: var(--space-sm);\n flex: 1;\n max-width: 300px;\n }\n\n .filter-input {\n flex: 1;\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n border-radius: var(--radius-sm);\n padding: 4px 10px;\n color: var(--t-primary);\n font-size: 0.8rem;\n font-family: var(--font-sans);\n }\n\n .filter-input:focus {\n outline: none;\n border-color: var(--accent-primary);\n box-shadow: 0 0 0 2px var(--glow-primary);\n }\n\n .filter-input::placeholder {\n color: var(--t-muted);\n opacity: 0.6;\n }\n\n .filter-count {\n font-size: 0.75rem;\n color: var(--t-muted);\n white-space: nowrap;\n }\n\n .filter-count.filtered {\n color: var(--accent-secondary);\n }\n\n /* Highlight matching text */\n .highlight {\n background: hsla(45, 80%, 50%, 0.3);\n border-radius: 2px;\n padding: 0 1px;\n }\n\n /* Sortable Table Headers */\n .smart-table th.sortable {\n cursor: pointer;\n user-select: none;\n transition: background 0.2s;\n }\n\n .smart-table th.sortable:hover {\n background: var(--bg-glass);\n }\n\n .sort-indicator {\n margin-left: 4px;\n opacity: 0.5;\n font-size: 0.8em;\n }\n\n .smart-table th.sorted .sort-indicator {\n opacity: 1;\n color: var(--accent-secondary);\n }\n\n /* Pagination */\n .pagination {\n display: flex;\n align-items: center;\n justify-content: space-between;\n padding: var(--space-sm) 0;\n margin-top: var(--space-sm);\n border-top: 1px solid var(--border-glass);\n font-family: var(--font-sans);\n font-size: 0.85rem;\n }\n\n .pagination-info {\n color: var(--t-muted);\n }\n\n .pagination-controls {\n display: flex;\n gap: var(--space-xs);\n }\n\n .pagination-btn {\n padding: 4px 10px;\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n border-radius: var(--radius-sm);\n color: var(--t-primary);\n cursor: pointer;\n font-size: 0.8rem;\n }\n\n .pagination-btn:hover:not(:disabled) {\n background: var(--bg-glass-strong);\n border-color: var(--accent-secondary);\n }\n\n .pagination-btn:disabled {\n opacity: 0.4;\n cursor: not-allowed;\n }\n\n .pagination-btn.active {\n background: var(--accent-primary);\n border-color: var(--accent-primary);\n color: white;\n }\n\n /* Tree Component */\n .tree-container {\n font-family: var(--font-sans);\n font-size: 0.9rem;\n }\n\n .tree-node {\n margin-left: var(--space-md);\n position: relative;\n }\n\n .tree-node::before {\n content: '';\n position: absolute;\n left: -12px;\n top: 0;\n height: 100%;\n border-left: 1px dashed var(--border-glass);\n }\n\n .tree-node:last-child::before {\n height: 12px;\n }\n\n .tree-node::after {\n content: '';\n position: absolute;\n left: -12px;\n top: 12px;\n width: 12px;\n border-bottom: 1px dashed var(--border-glass);\n }\n\n .tree-item {\n display: flex;\n align-items: center;\n gap: var(--space-sm);\n padding: var(--space-xs) var(--space-sm);\n margin: 2px 0;\n border-radius: var(--radius-sm);\n cursor: default;\n }\n\n .tree-item:hover {\n background: hsla(220, 10%, 80%, 0.1);\n }\n\n .tree-toggle {\n width: 16px;\n height: 16px;\n display: flex;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n color: var(--t-muted);\n font-size: 0.7rem;\n flex-shrink: 0;\n }\n\n .tree-toggle:hover {\n color: var(--accent-secondary);\n }\n\n .tree-key {\n color: var(--accent-secondary);\n font-weight: 500;\n }\n\n .tree-value {\n color: var(--t-primary);\n }\n\n .tree-value.string {\n color: #a5d6ff;\n }\n .tree-value.number {\n color: #ff9e64;\n }\n .tree-value.boolean {\n color: #ff007c;\n }\n .tree-value.null {\n color: #79c0ff;\n }\n\n .tree-type {\n color: var(--t-muted);\n font-size: 0.75rem;\n opacity: 0.7;\n }\n\n .tree-root {\n margin-left: 0;\n }\n\n .tree-root::before,\n .tree-root::after {\n display: none;\n }\n\n /* Fullscreen Modal */\n .fullscreen-overlay {\n position: fixed;\n inset: 0;\n background: rgba(0, 0, 0, 0.95);\n backdrop-filter: blur(8px);\n z-index: 10000;\n display: flex;\n flex-direction: column;\n }\n\n .fullscreen-toolbar {\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n display: flex;\n justify-content: space-between;\n align-items: center;\n padding: 12px 20px;\n background: linear-gradient(to bottom, rgba(0, 0, 0, 0.8), transparent);\n z-index: 10;\n }\n\n .fullscreen-toolbar-left {\n display: flex;\n align-items: center;\n gap: 8px;\n }\n\n .fullscreen-toolbar-center {\n display: flex;\n align-items: center;\n gap: 4px;\n background: rgba(255, 255, 255, 0.1);\n border-radius: 8px;\n padding: 4px;\n }\n\n .fullscreen-toolbar-right {\n display: flex;\n align-items: center;\n gap: 8px;\n }\n\n .fullscreen-btn {\n background: rgba(255, 255, 255, 0.1);\n border: 1px solid rgba(255, 255, 255, 0.2);\n color: white;\n width: 36px;\n height: 36px;\n border-radius: 8px;\n cursor: pointer;\n font-size: 1.1rem;\n display: flex;\n align-items: center;\n justify-content: center;\n transition: all 0.2s;\n }\n\n .fullscreen-btn:hover {\n background: rgba(255, 255, 255, 0.2);\n }\n\n .fullscreen-btn:active {\n transform: scale(0.95);\n }\n\n .fullscreen-btn.close-btn {\n background: rgba(239, 68, 68, 0.2);\n border-color: rgba(239, 68, 68, 0.3);\n }\n\n .fullscreen-btn.close-btn:hover {\n background: rgba(239, 68, 68, 0.4);\n }\n\n .zoom-level {\n color: rgba(255, 255, 255, 0.7);\n font-size: 0.8rem;\n min-width: 50px;\n text-align: center;\n font-variant-numeric: tabular-nums;\n }\n\n .fullscreen-hint {\n color: rgba(255, 255, 255, 0.5);\n font-size: 0.75rem;\n }\n\n .fullscreen-viewport {\n flex: 1;\n overflow: hidden;\n display: flex;\n align-items: center;\n justify-content: center;\n cursor: grab;\n position: relative;\n }\n\n .fullscreen-viewport.dragging {\n cursor: grabbing;\n }\n\n .fullscreen-viewport.zoom-1 {\n cursor: default;\n }\n\n .fullscreen-content {\n transform-origin: center center;\n transition: transform 0.1s ease-out;\n will-change: transform;\n }\n\n .fullscreen-content.no-transition {\n transition: none;\n }\n\n .fullscreen-content img {\n max-width: 90vw;\n max-height: 85vh;\n object-fit: contain;\n border-radius: var(--radius-md);\n box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);\n user-select: none;\n -webkit-user-drag: none;\n }\n\n .fullscreen-content .mermaid-container {\n background: #1e293b;\n padding: var(--space-xl);\n border-radius: var(--radius-md);\n min-width: 300px;\n min-height: 200px;\n max-width: 95vw;\n max-height: 85vh;\n overflow: visible;\n display: flex;\n align-items: center;\n justify-content: center;\n }\n\n :host([data-theme='light']) .fullscreen-content .mermaid-container {\n background: #f8fafc;\n }\n\n .fullscreen-content .mermaid-container svg {\n max-width: 100%;\n max-height: 100%;\n width: auto;\n height: auto;\n }\n\n .fullscreen-content .markdown-container {\n background: var(--bg-glass);\n padding: var(--space-xl);\n border-radius: var(--radius-md);\n width: 90vw;\n max-width: 900px;\n max-height: 85vh;\n overflow: auto;\n color: var(--t-default);\n }\n\n :host([data-theme='light']) .fullscreen-content .markdown-container {\n background: #ffffff;\n }\n\n .fullscreen-close {\n position: absolute;\n top: -40px;\n right: 0;\n background: rgba(255, 255, 255, 0.1);\n border: 1px solid rgba(255, 255, 255, 0.2);\n color: white;\n width: 36px;\n height: 36px;\n border-radius: 50%;\n cursor: pointer;\n font-size: 1.2rem;\n display: flex;\n align-items: center;\n justify-content: center;\n transition: all 0.2s;\n }\n\n .fullscreen-close:hover {\n background: rgba(255, 255, 255, 0.2);\n }\n\n /* Clickable image in results */\n .clickable-image {\n cursor: pointer;\n transition:\n transform 0.2s,\n box-shadow 0.2s;\n max-width: 100%;\n border-radius: var(--radius-sm);\n }\n\n .clickable-image:hover {\n transform: scale(1.02);\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);\n }\n\n .expand-hint {\n font-size: 0.75rem;\n color: var(--t-muted);\n margin-top: 4px;\n opacity: 0.7;\n }\n\n /* Expand button for markdown/mermaid */\n .markdown-body-wrapper,\n .mermaid-wrapper {\n position: relative;\n }\n\n .expand-btn {\n position: absolute;\n top: 8px;\n right: 8px;\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n color: var(--t-muted);\n width: 28px;\n height: 28px;\n border-radius: 6px;\n cursor: pointer;\n font-size: 1rem;\n display: flex;\n align-items: center;\n justify-content: center;\n transition: all 0.2s;\n opacity: 0;\n z-index: 5;\n }\n\n .markdown-body-wrapper:hover .expand-btn,\n .mermaid-wrapper:hover .expand-btn {\n opacity: 1;\n }\n\n .expand-btn:hover {\n background: var(--primary);\n color: white;\n border-color: var(--primary);\n }\n\n /* ===== Responsive Design ===== */\n @media (max-width: 768px) {\n .container {\n max-height: 400px;\n }\n\n .header {\n flex-wrap: wrap;\n gap: var(--space-sm);\n }\n\n .filter-container {\n order: 3;\n flex-basis: 100%;\n max-width: 100%;\n }\n\n .actions {\n flex-wrap: wrap;\n }\n\n .kv-table {\n display: block;\n max-width: 100%;\n }\n\n .kv-table tr {\n display: flex;\n flex-direction: column;\n border-bottom: 1px solid var(--border-glass);\n padding: var(--space-sm) 0;\n }\n\n .kv-table td:first-child,\n .kv-table .kv-key {\n width: 100%;\n font-weight: 600;\n margin-bottom: var(--space-xs);\n }\n\n .kv-table td:last-child {\n width: 100%;\n }\n\n .card-fields {\n grid-template-columns: 1fr;\n }\n\n button {\n min-height: 44px;\n }\n }\n\n @media (max-width: 480px) {\n .container {\n padding: var(--space-sm);\n }\n\n pre {\n font-size: 12px;\n padding: var(--space-sm);\n }\n\n .smart-table th,\n .smart-table td {\n padding: var(--space-xs) var(--space-sm);\n font-size: 0.85rem;\n }\n\n .pagination {\n flex-direction: column;\n gap: var(--space-sm);\n align-items: center;\n }\n\n .pagination-controls {\n flex-wrap: wrap;\n justify-content: center;\n }\n\n .fullscreen-toolbar {\n flex-direction: column;\n gap: var(--space-sm);\n padding: var(--space-sm);\n }\n\n .fullscreen-toolbar-left,\n .fullscreen-toolbar-center,\n .fullscreen-toolbar-right {\n width: 100%;\n justify-content: center;\n }\n }\n\n /* ===== HTML UI Mode ===== */\n .html-ui-container {\n display: flex;\n flex-direction: column;\n flex: 1;\n min-height: 400px;\n }\n\n .html-content {\n flex: 1;\n display: flex;\n flex-direction: column;\n border-radius: var(--radius-md);\n /* Theme-aware: transparent bg lets the HTML content define its own styling */\n background: transparent;\n }\n\n /* Ensure iframe/custom-ui fills the container */\n .html-content custom-ui-renderer {\n flex: 1;\n min-height: 400px;\n }\n `,\n ];\n\n @property({ type: Object })\n result: any = null;\n\n @property({ type: String })\n outputFormat?: string;\n\n @property({ type: Object })\n layoutHints?: LayoutHints;\n\n @property({ type: String, reflect: true, attribute: 'data-theme' })\n theme: Theme = 'dark';\n\n @state()\n private _filterQuery = '';\n\n @state()\n private _sortColumn: string | null = null;\n\n @state()\n private _sortDirection: 'asc' | 'desc' = 'asc';\n\n @state()\n private _currentPage = 0;\n\n @state()\n private _expandedNodes = new Set<string>();\n\n @state()\n private _fullscreenImage: string | null = null;\n\n @state()\n private _fullscreenMermaid: string | null = null;\n\n @state()\n private _fullscreenMarkdown: string | null = null;\n\n @state()\n private _zoomLevel = 1;\n\n @state()\n private _panX = 0;\n\n @state()\n private _panY = 0;\n\n private _isPanning = false;\n private _panStartX = 0;\n private _panStartY = 0;\n private _lastPanX = 0;\n private _lastPanY = 0;\n\n private _pageSize = 20;\n\n @query('.filter-input')\n private _filterInput!: HTMLInputElement;\n\n connectedCallback() {\n super.connectedCallback();\n window.addEventListener('keydown', this._handleGlobalKeydown);\n }\n\n disconnectedCallback() {\n super.disconnectedCallback();\n window.removeEventListener('keydown', this._handleGlobalKeydown);\n }\n\n private _handleGlobalKeydown = (e: KeyboardEvent) => {\n if (e.key === 'Escape') {\n this._closeFullscreen();\n }\n // Zoom with + and - keys when fullscreen is open\n if (this._fullscreenImage || this._fullscreenMermaid) {\n if (e.key === '+' || e.key === '=') {\n e.preventDefault();\n this._zoomIn();\n } else if (e.key === '-') {\n e.preventDefault();\n this._zoomOut();\n } else if (e.key === '0') {\n e.preventDefault();\n this._resetZoom();\n }\n }\n };\n\n private _closeFullscreen() {\n this._fullscreenImage = null;\n this._fullscreenMermaid = null;\n this._fullscreenMarkdown = null;\n this._resetZoom();\n }\n\n private _resetZoom() {\n this._zoomLevel = 1;\n this._panX = 0;\n this._panY = 0;\n }\n\n private _zoomIn() {\n this._zoomLevel = Math.min(10, this._zoomLevel * 1.25);\n }\n\n private _zoomOut() {\n this._zoomLevel = Math.max(0.1, this._zoomLevel / 1.25);\n }\n\n private _handleWheel = (e: WheelEvent) => {\n if (!this._fullscreenImage && !this._fullscreenMermaid) return;\n e.preventDefault();\n\n const factor = e.deltaY > 0 ? 0.9 : 1.1;\n const newZoom = Math.max(0.1, Math.min(10, this._zoomLevel * factor));\n\n if (newZoom !== this._zoomLevel) {\n this._zoomLevel = newZoom;\n if (this._zoomLevel === 1) {\n this._panX = 0;\n this._panY = 0;\n }\n }\n };\n\n private _handlePanStart = (e: MouseEvent) => {\n if (this._zoomLevel <= 1) return;\n e.preventDefault();\n this._isPanning = true;\n this._panStartX = e.clientX;\n this._panStartY = e.clientY;\n this._lastPanX = this._panX;\n this._lastPanY = this._panY;\n };\n\n private _handlePanMove = (e: MouseEvent) => {\n if (!this._isPanning) return;\n e.preventDefault();\n const dx = e.clientX - this._panStartX;\n const dy = e.clientY - this._panStartY;\n this._panX = this._lastPanX + dx;\n this._panY = this._lastPanY + dy;\n };\n\n private _handlePanEnd = () => {\n this._isPanning = false;\n };\n\n private _autoFitFullscreen() {\n // Wait for SVG to be in DOM\n requestAnimationFrame(() => {\n const viewport = this.shadowRoot?.querySelector('.fullscreen-viewport');\n const content = this.shadowRoot?.querySelector('.fullscreen-content');\n const svg = content?.querySelector('svg');\n const mermaidContainer = content?.querySelector('.mermaid-container');\n\n if (!viewport || !content) return;\n\n const viewportRect = viewport.getBoundingClientRect();\n const viewportWidth = viewportRect.width * 0.9; // 90% of viewport\n const viewportHeight = viewportRect.height * 0.85; // 85% of viewport (account for toolbar)\n\n let contentWidth: number;\n let contentHeight: number;\n\n if (svg) {\n // Get SVG dimensions\n const svgRect = svg.getBoundingClientRect();\n contentWidth = svgRect.width || parseFloat(svg.getAttribute('width') || '400');\n contentHeight = svgRect.height || parseFloat(svg.getAttribute('height') || '300');\n } else if (mermaidContainer) {\n const containerRect = mermaidContainer.getBoundingClientRect();\n contentWidth = containerRect.width;\n contentHeight = containerRect.height;\n } else {\n return; // No content to fit\n }\n\n if (contentWidth > 0 && contentHeight > 0) {\n // Calculate zoom to fit\n const scaleX = viewportWidth / contentWidth;\n const scaleY = viewportHeight / contentHeight;\n const fitZoom = Math.min(scaleX, scaleY);\n\n // Use fit zoom, but ensure it's at least 1x if content is small\n this._zoomLevel = Math.max(1, fitZoom);\n this._panX = 0;\n this._panY = 0;\n }\n });\n }\n\n render() {\n if (this.result === null || this.result === undefined) return html``;\n\n const layout = this._selectLayout();\n const filteredData = this._getFilteredData();\n const totalCount = this._getTotalCount();\n const filteredCount = this._getFilteredCount(filteredData);\n const isFiltered = this._filterQuery.trim() !== '';\n const isHtmlUiMode = layout === 'html';\n\n // HTML UI mode: minimal chrome, full-height interactive content\n if (isHtmlUiMode) {\n return html`\n <div class=\"html-ui-container\">${this._renderContent(layout, filteredData)}</div>\n `;\n }\n\n return html`\n <div class=\"container glass-panel\">\n <div class=\"header\">\n <span class=\"title\">Result</span>\n <div class=\"filter-container\">\n <input\n type=\"text\"\n class=\"filter-input\"\n placeholder=\"Filter results...\"\n .value=${this._filterQuery}\n @input=${this._handleFilterInput}\n @keydown=${this._handleFilterKeydown}\n />\n ${isFiltered\n ? html` <span class=\"filter-count filtered\">${filteredCount} / ${totalCount}</span> `\n : ''}\n </div>\n <div class=\"actions\">\n ${layout !== 'json' ? html`<span class=\"format-badge\">${layout}</span>` : ''}\n <button @click=${this._copy}>Copy</button>\n <button @click=${() => this._downloadSmart(layout)}>\n \u2193 ${this._getDownloadLabel(layout)}\n </button>\n ${this._isTabularData()\n ? html`<button @click=${() => this._download('csv')}>\u2193 CSV</button>`\n : ''}\n <button @click=${this._share} title=\"Share link to this result\">\uD83D\uDD17 Share</button>\n </div>\n </div>\n <div class=\"content\">${this._renderContent(layout, filteredData)}</div>\n </div>\n\n ${this._fullscreenImage\n ? html`\n <div class=\"fullscreen-overlay\">\n <div class=\"fullscreen-toolbar\">\n <div class=\"fullscreen-toolbar-left\">\n <span class=\"fullscreen-hint\">Scroll to zoom \u2022 Drag to pan \u2022 Esc to close</span>\n </div>\n <div class=\"fullscreen-toolbar-center\">\n <button class=\"fullscreen-btn\" @click=${this._zoomOut} title=\"Zoom out (-)\">\n \u2212\n </button>\n <span class=\"zoom-level\">${Math.round(this._zoomLevel * 100)}%</span>\n <button class=\"fullscreen-btn\" @click=${this._zoomIn} title=\"Zoom in (+)\">\n +\n </button>\n <button class=\"fullscreen-btn\" @click=${this._resetZoom} title=\"Reset zoom (0)\">\n \u27F2\n </button>\n </div>\n <div class=\"fullscreen-toolbar-right\">\n <button\n class=\"fullscreen-btn close-btn\"\n @click=${this._closeFullscreen}\n title=\"Close (Esc)\"\n >\n \u2715\n </button>\n </div>\n </div>\n <div\n class=\"fullscreen-viewport ${this._isPanning ? 'dragging' : ''} ${this._zoomLevel <=\n 1\n ? 'zoom-1'\n : ''}\"\n @wheel=${this._handleWheel}\n @mousedown=${this._handlePanStart}\n @mousemove=${this._handlePanMove}\n @mouseup=${this._handlePanEnd}\n @mouseleave=${this._handlePanEnd}\n >\n <div\n class=\"fullscreen-content ${this._isPanning ? 'no-transition' : ''}\"\n style=\"transform: scale(${this._zoomLevel}) translate(${this._panX /\n this._zoomLevel}px, ${this._panY / this._zoomLevel}px)\"\n >\n <img src=\"${this._fullscreenImage}\" alt=\"Fullscreen image\" draggable=\"false\" />\n </div>\n </div>\n </div>\n `\n : ''}\n ${this._fullscreenMermaid\n ? html`\n <div class=\"fullscreen-overlay\">\n <div class=\"fullscreen-toolbar\">\n <div class=\"fullscreen-toolbar-left\">\n <span class=\"fullscreen-hint\">Scroll to zoom \u2022 Drag to pan \u2022 Esc to close</span>\n </div>\n <div class=\"fullscreen-toolbar-center\">\n <button class=\"fullscreen-btn\" @click=${this._zoomOut} title=\"Zoom out (-)\">\n \u2212\n </button>\n <span class=\"zoom-level\">${Math.round(this._zoomLevel * 100)}%</span>\n <button class=\"fullscreen-btn\" @click=${this._zoomIn} title=\"Zoom in (+)\">\n +\n </button>\n <button class=\"fullscreen-btn\" @click=${this._resetZoom} title=\"Reset zoom (0)\">\n \u27F2\n </button>\n </div>\n <div class=\"fullscreen-toolbar-right\">\n <button\n class=\"fullscreen-btn close-btn\"\n @click=${this._closeFullscreen}\n title=\"Close (Esc)\"\n >\n \u2715\n </button>\n </div>\n </div>\n <div\n class=\"fullscreen-viewport ${this._isPanning ? 'dragging' : ''} ${this._zoomLevel <=\n 1\n ? 'zoom-1'\n : ''}\"\n @wheel=${this._handleWheel}\n @mousedown=${this._handlePanStart}\n @mousemove=${this._handlePanMove}\n @mouseup=${this._handlePanEnd}\n @mouseleave=${this._handlePanEnd}\n >\n <div\n class=\"fullscreen-content ${this._isPanning ? 'no-transition' : ''}\"\n style=\"transform: scale(${this._zoomLevel}) translate(${this._panX /\n this._zoomLevel}px, ${this._panY / this._zoomLevel}px)\"\n >\n <div class=\"mermaid-container\" id=\"fullscreen-mermaid\"></div>\n </div>\n </div>\n </div>\n `\n : ''}\n ${this._fullscreenMarkdown\n ? html`\n <div class=\"fullscreen-overlay\">\n <div class=\"fullscreen-toolbar\">\n <div class=\"fullscreen-toolbar-left\">\n <span class=\"fullscreen-hint\">Esc to close</span>\n </div>\n <div class=\"fullscreen-toolbar-center\"></div>\n <div class=\"fullscreen-toolbar-right\">\n <button\n class=\"fullscreen-btn close-btn\"\n @click=${this._closeFullscreen}\n title=\"Close (Esc)\"\n >\n \u2715\n </button>\n </div>\n </div>\n <div class=\"fullscreen-viewport zoom-1\" style=\"padding-top: 60px;\">\n <div class=\"fullscreen-content\">\n <div class=\"markdown-container markdown-content\">\n ${unsafeHTML(this._fullscreenMarkdown)}\n </div>\n </div>\n </div>\n </div>\n `\n : ''}\n `;\n }\n\n private _handleFilterInput(e: Event) {\n this._filterQuery = (e.target as HTMLInputElement).value;\n }\n\n private _handleFilterKeydown(e: KeyboardEvent) {\n if (e.key === 'Escape') {\n this._filterQuery = '';\n this._filterInput.blur();\n }\n }\n\n private _getTotalCount(): number {\n if (Array.isArray(this.result)) return this.result.length;\n if (typeof this.result === 'object' && this.result !== null)\n return Object.keys(this.result).length;\n return 1;\n }\n\n private _getFilteredCount(data: any): number {\n if (Array.isArray(data)) return data.length;\n if (typeof data === 'object' && data !== null) return Object.keys(data).length;\n return data !== null ? 1 : 0;\n }\n\n private _getFilteredData(): any {\n if (!this._filterQuery.trim()) return this.result;\n\n const query = this._filterQuery.toLowerCase();\n const data = this.result;\n\n // Array filtering\n if (Array.isArray(data)) {\n return data.filter((item) => this._itemMatchesFilter(item, query));\n }\n\n // Object filtering (card view)\n if (typeof data === 'object' && data !== null) {\n const filtered: Record<string, any> = {};\n for (const [key, value] of Object.entries(data)) {\n if (key.toLowerCase().includes(query) || this._valueMatchesFilter(value, query)) {\n filtered[key] = value;\n }\n }\n return Object.keys(filtered).length > 0 ? filtered : null;\n }\n\n // String/primitive filtering\n if (typeof data === 'string' && data.toLowerCase().includes(query)) {\n return data;\n }\n\n return String(data).toLowerCase().includes(query) ? data : null;\n }\n\n private _itemMatchesFilter(item: any, query: string): boolean {\n if (typeof item === 'string') return item.toLowerCase().includes(query);\n if (typeof item === 'object' && item !== null) {\n return Object.values(item).some((v) => this._valueMatchesFilter(v, query));\n }\n return String(item).toLowerCase().includes(query);\n }\n\n private _valueMatchesFilter(value: any, query: string): boolean {\n if (value === null || value === undefined) return false;\n if (typeof value === 'string') return value.toLowerCase().includes(query);\n if (typeof value === 'object') {\n return JSON.stringify(value).toLowerCase().includes(query);\n }\n return String(value).toLowerCase().includes(query);\n }\n\n private _highlightText(text: string): TemplateResult | string {\n if (!this._filterQuery.trim() || typeof text !== 'string') return text;\n\n const query = this._filterQuery.toLowerCase();\n const lower = text.toLowerCase();\n const index = lower.indexOf(query);\n\n if (index === -1) return text;\n\n const before = text.slice(0, index);\n const match = text.slice(index, index + query.length);\n const after = text.slice(index + query.length);\n\n return html`${before}<span class=\"highlight\">${match}</span>${this._highlightText(after)}`;\n }\n\n private _selectLayout(): LayoutType {\n // 1. Explicit format from docblock\n if (this.outputFormat) {\n const format = this.outputFormat.toLowerCase();\n if (\n [\n 'table',\n 'list',\n 'card',\n 'tree',\n 'json',\n 'markdown',\n 'mermaid',\n 'code',\n 'text',\n 'chips',\n 'grid',\n 'html',\n ].includes(format)\n ) {\n return format as LayoutType;\n }\n // Content formats\n if (format === 'md') return 'markdown';\n }\n\n // 2. Detect from data shape\n const data = this.result;\n\n // String detection\n if (typeof data === 'string') {\n // Check for markdown indicators\n if (data.includes('```') || data.includes('##') || data.includes('**')) {\n return 'markdown';\n }\n return 'text';\n }\n\n // Primitives\n if (typeof data !== 'object' || data === null) {\n return 'text';\n }\n\n // Arrays\n if (Array.isArray(data)) {\n if (data.length === 0) return 'json';\n\n // Array of strings \u2192 chips\n if (data.every((item) => typeof item === 'string')) {\n return 'chips';\n }\n\n // Array of objects \u2192 table or list\n if (data.every((item) => typeof item === 'object' && item !== null)) {\n // Check if we have semantic fields for list\n const hasListFields = this._hasSemanticFields(data[0], [\n 'name',\n 'title',\n 'status',\n 'state',\n 'description',\n ]);\n return hasListFields ? 'list' : 'table';\n }\n }\n\n // Single object \u2192 card\n if (typeof data === 'object') {\n return 'card';\n }\n\n return 'json';\n }\n\n private _hasSemanticFields(obj: any, fields: string[]): boolean {\n if (!obj || typeof obj !== 'object') return false;\n const keys = Object.keys(obj).map((k) => k.toLowerCase());\n return fields.some((f) => keys.includes(f.toLowerCase()));\n }\n\n private _renderContent(layout: LayoutType, filteredData: any): TemplateResult | string {\n if (filteredData === null) {\n return html`<div class=\"empty-state\">No matches found</div>`;\n }\n\n switch (layout) {\n case 'table':\n return this._renderTable(filteredData);\n case 'list':\n return this._renderList(filteredData);\n case 'card':\n return this._renderCard(filteredData);\n case 'chips':\n return this._renderChips(filteredData);\n case 'tree':\n return this._renderTree(filteredData);\n case 'markdown':\n return this._renderMarkdown();\n case 'html':\n return this._renderHtml();\n case 'text':\n return this._renderText(filteredData);\n case 'json':\n default:\n return this._renderJson(filteredData);\n }\n }\n\n private _renderTable(data: any[]): TemplateResult {\n if (!Array.isArray(data) || data.length === 0) {\n return html`<div class=\"empty-state\">No data</div>`;\n }\n\n // Get columns from first item of original result for consistency\n const originalData = Array.isArray(this.result) && this.result.length > 0 ? this.result : data;\n const columns = Object.keys(originalData[0]);\n\n // Apply sorting\n let sortedData = [...data];\n if (this._sortColumn) {\n sortedData.sort((a, b) => {\n const aVal = a[this._sortColumn!];\n const bVal = b[this._sortColumn!];\n\n // Handle null/undefined\n if (aVal == null && bVal == null) return 0;\n if (aVal == null) return 1;\n if (bVal == null) return -1;\n\n // Compare based on type\n let comparison = 0;\n if (typeof aVal === 'number' && typeof bVal === 'number') {\n comparison = aVal - bVal;\n } else {\n comparison = String(aVal).localeCompare(String(bVal));\n }\n\n return this._sortDirection === 'asc' ? comparison : -comparison;\n });\n }\n\n // Apply pagination\n const totalItems = sortedData.length;\n const totalPages = Math.ceil(totalItems / this._pageSize);\n const startIndex = this._currentPage * this._pageSize;\n const endIndex = Math.min(startIndex + this._pageSize, totalItems);\n const pageData = sortedData.slice(startIndex, endIndex);\n\n return html`\n <table class=\"smart-table\">\n <thead>\n <tr>\n ${columns.map(\n (col) => html`\n <th\n class=\"sortable ${this._sortColumn === col ? 'sorted' : ''}\"\n @click=${() => this._toggleSort(col)}\n >\n ${this._formatColumnName(col)}\n <span class=\"sort-indicator\">\n ${this._sortColumn === col ? (this._sortDirection === 'asc' ? '\u2191' : '\u2193') : '\u2195'}\n </span>\n </th>\n `\n )}\n </tr>\n </thead>\n <tbody>\n ${pageData.map(\n (row) => html`\n <tr>\n ${columns.map(\n (col) => html`<td>${this._formatCellValue(row[col], col, true)}</td>`\n )}\n </tr>\n `\n )}\n </tbody>\n </table>\n ${totalItems > this._pageSize ? this._renderPagination(totalItems, totalPages) : ''}\n `;\n }\n\n private _toggleSort(column: string) {\n if (this._sortColumn === column) {\n this._sortDirection = this._sortDirection === 'asc' ? 'desc' : 'asc';\n } else {\n this._sortColumn = column;\n this._sortDirection = 'asc';\n }\n this._currentPage = 0; // Reset to first page when sorting\n }\n\n private _renderPagination(totalItems: number, totalPages: number): TemplateResult {\n const startItem = this._currentPage * this._pageSize + 1;\n const endItem = Math.min((this._currentPage + 1) * this._pageSize, totalItems);\n\n // Calculate visible page buttons (max 5)\n let startPage = Math.max(0, this._currentPage - 2);\n const endPage = Math.min(totalPages, startPage + 5);\n if (endPage - startPage < 5) {\n startPage = Math.max(0, endPage - 5);\n }\n\n return html`\n <div class=\"pagination\">\n <span class=\"pagination-info\"> Showing ${startItem}-${endItem} of ${totalItems} </span>\n <div class=\"pagination-controls\">\n <button\n class=\"pagination-btn\"\n ?disabled=${this._currentPage === 0}\n @click=${() => (this._currentPage = 0)}\n >\n \u00AB\n </button>\n <button\n class=\"pagination-btn\"\n ?disabled=${this._currentPage === 0}\n @click=${() => this._currentPage--}\n >\n \u2039\n </button>\n ${Array.from({ length: endPage - startPage }, (_, i) => startPage + i).map(\n (page) => html`\n <button\n class=\"pagination-btn ${this._currentPage === page ? 'active' : ''}\"\n @click=${() => (this._currentPage = page)}\n >\n ${page + 1}\n </button>\n `\n )}\n <button\n class=\"pagination-btn\"\n ?disabled=${this._currentPage >= totalPages - 1}\n @click=${() => this._currentPage++}\n >\n \u203A\n </button>\n <button\n class=\"pagination-btn\"\n ?disabled=${this._currentPage >= totalPages - 1}\n @click=${() => (this._currentPage = totalPages - 1)}\n >\n \u00BB\n </button>\n </div>\n </div>\n `;\n }\n\n private _renderList(data: any[]): TemplateResult {\n if (!Array.isArray(data) || data.length === 0) {\n return html`<div class=\"empty-state\">No items</div>`;\n }\n\n return html`\n <ul class=\"smart-list\">\n ${data.map((item) => this._renderListItem(item))}\n </ul>\n `;\n }\n\n private _renderListItem(item: any): TemplateResult {\n if (typeof item !== 'object' || item === null) {\n return html`<li class=\"list-item\">\n <span class=\"list-item-title\">${this._highlightText(String(item))}</span>\n </li>`;\n }\n\n const mapping = this._analyzeFields(item);\n\n return html`\n <li class=\"list-item\">\n ${mapping.icon\n ? html`\n <div class=\"list-item-leading\">\n ${this._isImageUrl(item[mapping.icon])\n ? html`<img src=\"${item[mapping.icon]}\" alt=\"\" />`\n : item[mapping.icon]}\n </div>\n `\n : ''}\n <div class=\"list-item-content\">\n ${mapping.title\n ? html`<div class=\"list-item-title\">\n ${this._highlightText(String(item[mapping.title]))}\n </div>`\n : ''}\n ${mapping.subtitle\n ? html`<div class=\"list-item-subtitle\">\n ${this._highlightText(String(item[mapping.subtitle]))}\n </div>`\n : ''}\n </div>\n <div class=\"list-item-trailing\">\n ${mapping.detail\n ? html`<span>${this._highlightText(String(item[mapping.detail]))}</span>`\n : ''}\n ${mapping.badge\n ? html`\n <span class=\"status-badge ${this._getStatusClass(item[mapping.badge])}\"\n >${item[mapping.badge]}</span\n >\n `\n : ''}\n </div>\n </li>\n `;\n }\n\n private _renderCard(data: any): TemplateResult {\n if (!data || typeof data !== 'object') {\n const text = this._renderText(data);\n return html`${text}`;\n }\n\n // Render single object as vertical key-value table\n const keys = Object.keys(data).filter((k) => data[k] !== undefined);\n\n return html`\n <table class=\"smart-table kv-table\">\n <thead>\n <tr>\n <th>Property</th>\n <th>Value</th>\n </tr>\n </thead>\n <tbody>\n ${keys.map(\n (key) => html`\n <tr>\n <td class=\"kv-key\">${this._formatColumnName(key)}</td>\n <td>${this._formatCellValue(data[key], key, true)}</td>\n </tr>\n `\n )}\n </tbody>\n </table>\n `;\n }\n\n private _renderChips(data: any): TemplateResult {\n if (!Array.isArray(data)) {\n return html`<div class=\"chip\">${this._highlightText(String(data))}</div>`;\n }\n\n return html`\n <div class=\"smart-chips\">\n ${data.map((item) => html`<span class=\"chip\">${this._highlightText(String(item))}</span>`)}\n </div>\n `;\n }\n\n private _renderTree(data: any, path = 'root', isRoot = true): TemplateResult {\n if (data === null || data === undefined) {\n return html`<span class=\"tree-value null\">null</span>`;\n }\n\n if (typeof data !== 'object') {\n return this._renderTreeValue(data);\n }\n\n const isArray = Array.isArray(data);\n const entries = isArray ? data.map((v, i) => [i, v] as [number, any]) : Object.entries(data);\n\n const isExpanded = this._expandedNodes.has(path);\n const hasChildren = entries.length > 0;\n\n return html`\n <div class=\"tree-node ${isRoot ? 'tree-root' : ''}\">\n <div class=\"tree-item\">\n ${hasChildren\n ? html`\n <span class=\"tree-toggle\" @click=${() => this._toggleNode(path)}>\n ${isExpanded ? '\u25BC' : '\u25B6'}\n </span>\n `\n : html`<span class=\"tree-toggle\"></span>`}\n ${!isRoot ? html`<span class=\"tree-key\">${path.split('.').pop()}</span>` : ''}\n <span class=\"tree-type\"\n >${isArray ? `Array[${entries.length}]` : `Object{${entries.length}}`}</span\n >\n </div>\n ${isExpanded || isRoot\n ? html`\n <div class=\"tree-container\">\n ${entries.map(([key, value]) => {\n const childPath = `${path}.${key}`;\n const isChildObject = value !== null && typeof value === 'object';\n\n if (isChildObject) {\n return this._renderTree(value, childPath, false);\n }\n\n return html`\n <div class=\"tree-node\">\n <div class=\"tree-item\">\n <span class=\"tree-toggle\"></span>\n <span class=\"tree-key\">${key}:</span>\n ${this._renderTreeValue(value)}\n </div>\n </div>\n `;\n })}\n </div>\n `\n : ''}\n </div>\n `;\n }\n\n private _renderTreeValue(value: any): TemplateResult {\n if (value === null) {\n return html`<span class=\"tree-value null\">null</span>`;\n }\n if (value === undefined) {\n return html`<span class=\"tree-value null\">undefined</span>`;\n }\n if (typeof value === 'string') {\n const display = value.length > 50 ? value.slice(0, 50) + '...' : value;\n return html`<span class=\"tree-value string\">\"${this._highlightText(display)}\"</span>`;\n }\n if (typeof value === 'number') {\n return html`<span class=\"tree-value number\">${value}</span>`;\n }\n if (typeof value === 'boolean') {\n return html`<span class=\"tree-value boolean\">${value}</span>`;\n }\n return html`<span class=\"tree-value\">${String(value)}</span>`;\n }\n\n private _toggleNode(path: string) {\n const newExpanded = new Set(this._expandedNodes);\n if (newExpanded.has(path)) {\n newExpanded.delete(path);\n } else {\n newExpanded.add(path);\n }\n this._expandedNodes = newExpanded;\n }\n\n // Non-reactive property to avoid infinite update loops\n private _pendingMermaidBlocks: { id: string; code: string }[] = [];\n\n // Store code blocks for Prism highlighting after DOM update\n private _pendingCodeBlocks: { id: string; code: string; language: string }[] = [];\n\n private _renderMarkdown(): TemplateResult {\n const str = String(this.result);\n\n if ((window as any).marked) {\n // Extract mermaid blocks before parsing to handle them separately\n const mermaidBlocks: { id: string; code: string }[] = [];\n const codeBlocks: { id: string; code: string; language: string }[] = [];\n\n // First extract mermaid blocks\n let processedStr = str.replace(/```mermaid\\s*\\n([\\s\\S]*?)```/g, (_match, code) => {\n const id = `mermaid-${Math.random().toString(36).substr(2, 9)}`;\n mermaidBlocks.push({ id, code: code.trim() });\n return `<div class=\"mermaid-placeholder\" data-mermaid-id=\"${id}\" style=\"min-height: 100px; display: flex; align-items: center; justify-content: center; color: var(--t-muted);\">Loading diagram...</div>`;\n });\n\n // Extract other code blocks for Prism highlighting\n processedStr = processedStr.replace(/```(\\w+)?\\s*\\n([\\s\\S]*?)```/g, (_match, lang, code) => {\n const id = `code-${Math.random().toString(36).substr(2, 9)}`;\n const language = lang || 'text';\n codeBlocks.push({ id, code: code.trimEnd(), language });\n return `<div class=\"code-block-wrapper\"><span class=\"language-label\">${language}</span><pre data-code-id=\"${id}\" class=\"language-${language}\"><code class=\"language-${language}\">Loading...</code></pre></div>`;\n });\n\n // Store blocks for rendering after DOM update (non-reactive)\n this._pendingMermaidBlocks = mermaidBlocks;\n this._pendingCodeBlocks = codeBlocks;\n\n const htmlContent = (window as any).marked.parse(processedStr);\n\n return html`\n <div class=\"markdown-body-wrapper\">\n <button class=\"expand-btn\" @click=${this._openMarkdownFullscreen} title=\"View fullscreen\">\n \u2922\n </button>\n <div class=\"markdown-body\">${unsafeHTML(htmlContent)}</div>\n </div>\n `;\n }\n\n return html`<pre>${str}</pre>`;\n }\n\n private _renderHtml(): TemplateResult {\n const htmlContent = String(this.result);\n return html` <div class=\"html-content\">${unsafeHTML(htmlContent)}</div> `;\n }\n\n private _openMarkdownFullscreen = () => {\n // Capture the rendered markdown (including mermaid SVGs) from the DOM\n const markdownBody = this.shadowRoot?.querySelector('.markdown-body');\n if (markdownBody) {\n this._fullscreenMarkdown = markdownBody.innerHTML;\n }\n };\n\n private _openImageFullscreen(src: string) {\n this._resetZoom();\n this._fullscreenImage = src;\n // Auto-fit image after it loads\n setTimeout(() => {\n const img = this.shadowRoot?.querySelector('.fullscreen-content img') as HTMLImageElement;\n if (img && img.complete) {\n this._autoFitImage(img);\n } else if (img) {\n img.onload = () => this._autoFitImage(img);\n }\n }, 50);\n }\n\n private _autoFitImage(img: HTMLImageElement) {\n const viewport = this.shadowRoot?.querySelector('.fullscreen-viewport');\n if (!viewport) return;\n\n const viewportRect = viewport.getBoundingClientRect();\n const viewportWidth = viewportRect.width * 0.9;\n const viewportHeight = viewportRect.height * 0.85;\n\n const imgWidth = img.naturalWidth || img.width;\n const imgHeight = img.naturalHeight || img.height;\n\n if (imgWidth > 0 && imgHeight > 0) {\n const scaleX = viewportWidth / imgWidth;\n const scaleY = viewportHeight / imgHeight;\n const fitZoom = Math.min(scaleX, scaleY);\n // Use fit zoom, ensure at least 1x for small images\n this._zoomLevel = Math.max(1, fitZoom);\n }\n }\n\n updated(changedProperties: Map<string, any>) {\n super.updated(changedProperties);\n\n // Render mermaid blocks after DOM update (only if there are pending blocks)\n if (this._pendingMermaidBlocks.length > 0 && (window as any).mermaid) {\n const blocks = this._pendingMermaidBlocks;\n this._pendingMermaidBlocks = []; // Clear before async render to prevent re-entry\n this._renderMermaidBlocks(blocks);\n }\n\n // Highlight code blocks with Prism after DOM update\n if (this._pendingCodeBlocks.length > 0 && (window as any).Prism) {\n const codeBlocks = this._pendingCodeBlocks;\n this._pendingCodeBlocks = []; // Clear before render to prevent re-entry\n this._highlightCodeBlocks(codeBlocks);\n }\n\n // Re-render mermaid if theme changed\n if (changedProperties.has('theme') && changedProperties.get('theme') !== undefined) {\n this._reRenderMermaidOnThemeChange();\n }\n }\n\n private _highlightCodeBlocks(blocks: { id: string; code: string; language: string }[]) {\n const Prism = (window as any).Prism;\n if (!Prism) return;\n\n for (const { id, code, language } of blocks) {\n const preElement = this.shadowRoot?.querySelector(`[data-code-id=\"${id}\"]`);\n if (!preElement) continue;\n\n const codeElement = preElement.querySelector('code');\n if (!codeElement) continue;\n\n // Map common language aliases\n const langMap: Record<string, string> = {\n ts: 'typescript',\n js: 'javascript',\n py: 'python',\n sh: 'bash',\n shell: 'bash',\n yml: 'yaml',\n md: 'markdown',\n };\n const prismLang = langMap[language] || language;\n\n // Check if Prism has the language, fall back to text\n const grammar = Prism.languages[prismLang] || Prism.languages['text'];\n\n try {\n const highlighted = Prism.highlight(code, grammar, prismLang);\n codeElement.innerHTML = highlighted;\n } catch (e) {\n // Fall back to plain text\n codeElement.textContent = code;\n }\n }\n }\n\n private _reRenderMermaidOnThemeChange() {\n // Find all existing mermaid wrappers and re-render them\n const wrappers = this.shadowRoot?.querySelectorAll('.mermaid-wrapper');\n if (!wrappers || wrappers.length === 0) return;\n\n const mermaid = (window as any).mermaid;\n if (!mermaid) return;\n\n // Update background color for existing wrappers\n const bgColor = this.theme === 'light' ? '#f8fafc' : '#1e293b';\n wrappers.forEach((wrapper) => {\n (wrapper as HTMLElement).style.background = bgColor;\n });\n\n // Note: Full re-render of mermaid diagrams would require storing the original code\n // For now, we just update the background color. Full re-render happens on next result.\n }\n\n private async _renderMermaidBlocks(blocks: { id: string; code: string }[]) {\n const mermaid = (window as any).mermaid;\n if (!mermaid) return;\n\n // Configure mermaid theme based on current theme\n const mermaidTheme = this.theme === 'light' ? 'default' : 'dark';\n mermaid.initialize({\n startOnLoad: false,\n theme: mermaidTheme,\n themeVariables:\n this.theme === 'light'\n ? {\n primaryColor: '#e0e7ff',\n primaryTextColor: '#1e293b',\n primaryBorderColor: '#6366f1',\n lineColor: '#64748b',\n secondaryColor: '#f1f5f9',\n tertiaryColor: '#f8fafc',\n background: '#ffffff',\n mainBkg: '#f8fafc',\n textColor: '#1e293b',\n nodeBorder: '#cbd5e1',\n }\n : {\n primaryColor: '#3730a3',\n primaryTextColor: '#e2e8f0',\n primaryBorderColor: '#6366f1',\n lineColor: '#64748b',\n secondaryColor: '#1e293b',\n tertiaryColor: '#0f172a',\n background: '#0f172a',\n mainBkg: '#1e293b',\n textColor: '#e2e8f0',\n nodeBorder: '#334155',\n },\n });\n\n for (const { id, code } of blocks) {\n const placeholder = this.shadowRoot?.querySelector(`[data-mermaid-id=\"${id}\"]`);\n if (!placeholder) {\n console.warn('Mermaid placeholder not found:', id);\n continue;\n }\n\n try {\n // Create mermaid container with theme-aware background\n const wrapper = document.createElement('div');\n wrapper.className = 'mermaid-wrapper';\n const bgColor = this.theme === 'light' ? '#f8fafc' : '#1e293b';\n wrapper.style.cssText = `position: relative; background: ${bgColor}; border-radius: 8px; padding: 16px; margin: 16px 0;`;\n\n const diagramDiv = document.createElement('div');\n diagramDiv.id = id;\n\n // Render mermaid\n const { svg } = await mermaid.render(id + '-svg', code);\n diagramDiv.innerHTML = svg;\n\n // Add expand button\n const expandBtn = document.createElement('button');\n expandBtn.innerHTML = '\u2922';\n expandBtn.title = 'View fullscreen';\n expandBtn.className = 'expand-btn';\n expandBtn.style.opacity = '0'; // Start hidden, show on hover via CSS\n expandBtn.onclick = () => {\n this._resetZoom();\n this._fullscreenMermaid = code;\n setTimeout(async () => {\n const fullscreenContainer = this.shadowRoot?.querySelector('#fullscreen-mermaid');\n if (fullscreenContainer && mermaid) {\n const fsId = 'fullscreen-' + id;\n const { svg: fsSvg } = await mermaid.render(fsId + '-svg', code);\n fullscreenContainer.innerHTML = fsSvg;\n // Auto-fit: calculate zoom to fill viewport\n this._autoFitFullscreen();\n }\n }, 50);\n };\n\n wrapper.appendChild(diagramDiv);\n wrapper.appendChild(expandBtn);\n placeholder.replaceWith(wrapper);\n } catch (e) {\n console.error('Mermaid render error:', e);\n (placeholder as HTMLElement).innerHTML =\n `<pre style=\"color: #ff6b6b; background: rgba(255,0,0,0.1); padding: 8px; border-radius: 4px;\">Mermaid Error: ${e}\\n\\n${code}</pre>`;\n }\n }\n }\n\n private _renderText(data: any): TemplateResult | string {\n const text = String(data);\n return this._highlightText(text);\n }\n\n private _renderJson(data: any): TemplateResult {\n const jsonStr = JSON.stringify(data, null, 2);\n\n const highlighted = jsonStr.replace(\n /(\"(\\\\u[a-zA-Z0-9]{4}|\\\\[^u]|[^\\\\\"])*\"(\\s*:)?|\\b(true|false|null)\\b|-?\\d+(?:\\.\\d*)?(?:[eE][+\\-]?\\d+)?)/g,\n (match) => {\n let cls = 'json-number';\n if (/^\"/.test(match)) {\n if (/:$/.test(match)) {\n cls = 'json-key';\n } else {\n cls = 'json-string';\n }\n } else if (/true|false/.test(match)) {\n cls = 'json-boolean';\n } else if (/null/.test(match)) {\n cls = 'json-null';\n }\n return `<span class=\"${cls}\">${match}</span>`;\n }\n );\n\n const parser = new DOMParser();\n const doc = parser.parseFromString(`<pre>${highlighted}</pre>`, 'text/html');\n return html`${doc.body.children[0]}`;\n }\n\n private _analyzeFields(obj: any): {\n title?: string;\n subtitle?: string;\n icon?: string;\n badge?: string;\n detail?: string;\n } {\n const keys = Object.keys(obj);\n const result: any = {};\n\n // Use layout hints if provided\n if (this.layoutHints) {\n if (this.layoutHints.title && keys.includes(this.layoutHints.title))\n result.title = this.layoutHints.title;\n if (this.layoutHints.subtitle && keys.includes(this.layoutHints.subtitle))\n result.subtitle = this.layoutHints.subtitle;\n if (this.layoutHints.icon && keys.includes(this.layoutHints.icon))\n result.icon = this.layoutHints.icon;\n if (this.layoutHints.badge && keys.includes(this.layoutHints.badge))\n result.badge = this.layoutHints.badge;\n if (this.layoutHints.detail && keys.includes(this.layoutHints.detail))\n result.detail = this.layoutHints.detail;\n }\n\n // Auto-detect from field names\n const titleFields = ['name', 'title', 'label', 'displayName', 'heading', 'subject'];\n const subtitleFields = ['description', 'email', 'summary', 'bio', 'address', 'subtitle'];\n const iconFields = ['icon', 'avatar', 'image', 'photo', 'thumbnail', 'picture'];\n const badgeFields = ['status', 'state', 'type', 'role', 'category', 'priority'];\n const detailFields = ['count', 'total', 'amount', 'price', 'value', 'size'];\n\n if (!result.title) result.title = keys.find((k) => titleFields.includes(k.toLowerCase()));\n if (!result.subtitle)\n result.subtitle = keys.find((k) => subtitleFields.includes(k.toLowerCase()));\n if (!result.icon) result.icon = keys.find((k) => iconFields.includes(k.toLowerCase()));\n if (!result.badge) result.badge = keys.find((k) => badgeFields.includes(k.toLowerCase()));\n if (!result.detail) result.detail = keys.find((k) => detailFields.includes(k.toLowerCase()));\n\n return result;\n }\n\n private _formatColumnName(name: string): string {\n // Convert camelCase/snake_case to Title Case\n return name\n .replace(/([A-Z])/g, ' $1')\n .replace(/_/g, ' ')\n .replace(/^\\s/, '')\n .split(' ')\n .map((w) => w.charAt(0).toUpperCase() + w.slice(1).toLowerCase())\n .join(' ');\n }\n\n private _formatCellValue(value: any, key: string, highlight = false): TemplateResult | string {\n if (value === null || value === undefined) return '\u2014';\n if (typeof value === 'boolean') return value ? '\u2713' : '\u2717';\n\n // Check for image URLs - make them clickable for fullscreen\n if (this._isImageUrl(value)) {\n return html`\n <div>\n <img\n src=\"${value}\"\n alt=\"${key}\"\n class=\"clickable-image\"\n style=\"max-height: 80px; max-width: 150px;\"\n @click=${() => this._openImageFullscreen(value)}\n />\n <div class=\"expand-hint\">Click to expand</div>\n </div>\n `;\n }\n\n // Check for date fields\n if (this._isDateField(key) && (typeof value === 'string' || typeof value === 'number')) {\n const date = new Date(value);\n if (!isNaN(date.getTime())) {\n const dateStr = date.toLocaleString();\n return highlight ? this._highlightText(dateStr) : dateStr;\n }\n }\n\n // Check for URL fields - render as clickable link with full URL visible\n if (this._isUrlField(key) && typeof value === 'string' && value.startsWith('http')) {\n return html`\n <a href=\"${value}\" target=\"_blank\" rel=\"noopener\" class=\"result-link\">\n ${value} <span class=\"link-icon\">\u2197</span>\n </a>\n `;\n }\n\n // Check for status fields\n if (this._isStatusField(key) && typeof value === 'string') {\n return html`<span class=\"status-badge ${this._getStatusClass(value)}\">${value}</span>`;\n }\n\n if (typeof value === 'object') {\n const str = JSON.stringify(value);\n return highlight ? this._highlightText(str) : str;\n }\n\n const str = String(value);\n return highlight ? this._highlightText(str) : str;\n }\n\n private _isDateField(key: string): boolean {\n const lower = key.toLowerCase();\n return (\n lower.endsWith('at') ||\n lower.endsWith('date') ||\n lower.endsWith('time') ||\n lower === 'created' ||\n lower === 'updated' ||\n lower === 'timestamp'\n );\n }\n\n private _isUrlField(key: string): boolean {\n const lower = key.toLowerCase();\n return lower === 'url' || lower === 'link' || lower === 'href' || lower === 'website';\n }\n\n private _isStatusField(key: string): boolean {\n const lower = key.toLowerCase();\n return lower === 'status' || lower === 'state' || lower === 'priority';\n }\n\n private _isImageUrl(value: any): boolean {\n if (typeof value !== 'string') return false;\n return /\\.(jpg|jpeg|png|gif|webp|svg)$/i.test(value) || value.startsWith('data:image/');\n }\n\n private _getStatusClass(status: any): string {\n const lower = String(status).toLowerCase();\n if (\n ['success', 'active', 'completed', 'online', 'done', 'enabled', 'yes', 'true'].includes(lower)\n ) {\n return 'status-success';\n }\n if (\n ['error', 'failed', 'offline', 'inactive', 'disabled', 'no', 'false', 'blocked'].includes(\n lower\n )\n ) {\n return 'status-error';\n }\n if (['warning', 'pending', 'processing', 'in_progress', 'todo', 'waiting'].includes(lower)) {\n return 'status-warning';\n }\n return '';\n }\n\n private _copy() {\n const text =\n typeof this.result === 'object' ? JSON.stringify(this.result, null, 2) : String(this.result);\n\n navigator.clipboard.writeText(text);\n showToast('Copied to clipboard', 'success');\n }\n\n private _share() {\n this.dispatchEvent(\n new CustomEvent('share', {\n bubbles: true,\n composed: true,\n })\n );\n }\n\n private _isTabularData(): boolean {\n return (\n Array.isArray(this.result) &&\n this.result.length > 0 &&\n typeof this.result[0] === 'object' &&\n this.result[0] !== null\n );\n }\n\n private _getDownloadLabel(layout: LayoutType): string {\n switch (layout) {\n case 'markdown':\n return 'MD';\n case 'mermaid':\n return 'MMD';\n case 'text':\n return 'TXT';\n case 'code':\n return 'TXT';\n default:\n return 'JSON';\n }\n }\n\n private _downloadSmart(layout: LayoutType) {\n let content: string;\n let mimeType: string;\n let extension: string;\n const timestamp = new Date().toISOString().slice(0, 10);\n\n switch (layout) {\n case 'markdown':\n content = String(this.result);\n mimeType = 'text/markdown';\n extension = 'md';\n break;\n case 'mermaid':\n // Extract mermaid code from result\n content = String(this.result);\n mimeType = 'text/plain';\n extension = 'mmd';\n break;\n case 'text':\n case 'code':\n content = String(this.result);\n mimeType = 'text/plain';\n extension = 'txt';\n break;\n case 'chips':\n // Array of strings - save as newline-separated\n content = Array.isArray(this.result) ? this.result.join('\\n') : String(this.result);\n mimeType = 'text/plain';\n extension = 'txt';\n break;\n default:\n // JSON for table, list, card, tree, json\n content = JSON.stringify(this.result, null, 2);\n mimeType = 'application/json';\n extension = 'json';\n }\n\n const filename = `result-${timestamp}.${extension}`;\n const blob = new Blob([content], { type: mimeType });\n const url = URL.createObjectURL(blob);\n const a = document.createElement('a');\n a.href = url;\n a.download = filename;\n document.body.appendChild(a);\n a.click();\n document.body.removeChild(a);\n URL.revokeObjectURL(url);\n showToast(`Downloaded as ${filename}`, 'success');\n }\n\n private _download(format: 'json' | 'csv') {\n let content: string;\n let mimeType: string;\n let filename: string;\n const timestamp = new Date().toISOString().slice(0, 10);\n\n if (format === 'csv' && this._isTabularData()) {\n content = this._convertToCsv(this.result);\n mimeType = 'text/csv';\n filename = `result-${timestamp}.csv`;\n } else {\n content = JSON.stringify(this.result, null, 2);\n mimeType = 'application/json';\n filename = `result-${timestamp}.json`;\n }\n\n const blob = new Blob([content], { type: mimeType });\n const url = URL.createObjectURL(blob);\n const a = document.createElement('a');\n a.href = url;\n a.download = filename;\n document.body.appendChild(a);\n a.click();\n document.body.removeChild(a);\n URL.revokeObjectURL(url);\n showToast(`Downloaded as ${filename}`, 'success');\n }\n\n private _convertToCsv(data: any[]): string {\n if (!data || data.length === 0) return '';\n\n const headers = Object.keys(data[0]);\n const rows = data.map((row) =>\n headers\n .map((header) => {\n const value = row[header];\n if (value === null || value === undefined) return '';\n const str = typeof value === 'object' ? JSON.stringify(value) : String(value);\n // Escape quotes and wrap in quotes if contains comma/newline/quote\n if (str.includes(',') || str.includes('\\n') || str.includes('\"')) {\n return `\"${str.replace(/\"/g, '\"\"')}\"`;\n }\n return str;\n })\n .join(',')\n );\n\n return [headers.join(','), ...rows].join('\\n');\n }\n}\n", "import { LitElement, html, css } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { theme } from '../styles/theme.js';\n\ninterface FileEntry {\n name: string;\n path: string;\n isDirectory: boolean;\n}\n\ninterface BrowseResponse {\n path: string;\n parent: string | null;\n items: FileEntry[];\n}\n\n@customElement('file-picker')\nexport class FilePicker extends LitElement {\n static styles = [\n theme,\n css`\n :host {\n display: block;\n }\n\n .picker-container {\n display: flex;\n flex-direction: column;\n gap: var(--space-sm);\n border: 1px solid var(--border-glass);\n background: var(--bg-glass);\n border-radius: var(--radius-sm);\n overflow: hidden;\n }\n\n .current-path {\n padding: var(--space-sm);\n background: rgba(0, 0, 0, 0.2);\n font-family: var(--font-mono);\n font-size: 0.8rem;\n color: var(--t-muted);\n display: flex;\n align-items: center;\n gap: var(--space-sm);\n }\n\n .path-text {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n flex: 1;\n }\n\n .file-list {\n max-height: 200px;\n overflow-y: auto;\n display: flex;\n flex-direction: column;\n }\n\n .file-item {\n padding: 6px 12px;\n cursor: pointer;\n display: flex;\n align-items: center;\n gap: 8px;\n font-size: 0.9rem;\n transition: background 0.1s;\n border-bottom: 1px solid rgba(255, 255, 255, 0.02);\n }\n\n .file-item:hover {\n background: rgba(255, 255, 255, 0.05);\n }\n\n .file-item.selected {\n background: var(--accent-primary);\n color: white;\n }\n\n .icon {\n opacity: 0.7;\n }\n\n /* Input Base Styles */\n input {\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n color: var(--t-primary);\n padding: var(--space-sm);\n border-radius: var(--radius-sm);\n font-family: var(--font-sans);\n box-sizing: border-box;\n width: 100%;\n transition: all 0.2s;\n }\n\n input:focus {\n outline: none;\n border-color: var(--accent-primary);\n box-shadow: 0 0 0 2px var(--glow-primary);\n }\n\n input.error {\n border-color: #f87171;\n }\n\n input.error:focus {\n box-shadow: 0 0 0 2px rgba(248, 113, 113, 0.3);\n }\n\n .input-wrapper {\n display: flex;\n gap: 0; /* Merged look */\n }\n\n .input-wrapper input {\n flex: 1;\n border-top-right-radius: 0;\n border-bottom-right-radius: 0;\n border-right: none;\n }\n\n .input-wrapper button {\n border-top-left-radius: 0;\n border-bottom-left-radius: 0;\n border-left: 1px solid var(--border-glass);\n }\n\n /* Modal styling if we want it to be a popover later, \n for now it's inline */\n .browser-area {\n border-top: 1px solid var(--border-glass);\n }\n\n /* Button Styles */\n button {\n font-family: var(--font-sans);\n font-size: 0.9rem;\n cursor: pointer;\n transition: all 0.2s;\n }\n\n .btn-secondary {\n background: transparent;\n color: var(--t-muted);\n border: 1px solid var(--border-glass);\n padding: var(--space-sm) var(--space-md);\n border-radius: var(--radius-sm);\n }\n\n .btn-secondary:hover {\n background: hsla(220, 10%, 80%, 0.1);\n color: var(--t-primary);\n }\n\n /* ===== Responsive Design ===== */\n @media (max-width: 768px) {\n input {\n min-height: 44px;\n font-size: 16px; /* Prevent iOS zoom */\n }\n\n .btn-secondary {\n min-height: 44px;\n }\n\n .file-item {\n padding: var(--space-sm) var(--space-md);\n min-height: 44px;\n }\n\n .file-list {\n max-height: 300px;\n }\n }\n\n @media (max-width: 480px) {\n .input-wrapper {\n flex-direction: column;\n gap: var(--space-xs);\n }\n\n .input-wrapper input {\n border-radius: var(--radius-sm);\n border-right: 1px solid var(--border-glass);\n }\n\n .input-wrapper button {\n border-radius: var(--radius-sm);\n border-left: 1px solid var(--border-glass);\n width: 100%;\n }\n\n .current-path {\n flex-wrap: wrap;\n }\n\n .path-text {\n width: 100%;\n margin-top: var(--space-xs);\n }\n }\n `,\n ];\n\n @property({ type: String })\n value = '';\n\n @property({ type: Boolean })\n hasError = false;\n\n /** File extension filter (e.g., \".ts,.js,.tsx\" or \"*.photon.ts\") */\n @property({ type: String })\n accept = '';\n\n @state()\n private _isOpen = false;\n\n @state()\n private _currentPath = '';\n\n @state()\n private _items: FileEntry[] = [];\n\n @state()\n private _loading = false;\n\n firstUpdated() {\n // Determine initial path (use current value if absolute path, or default)\n if (this.value && this.value.startsWith('/')) {\n this._currentPath = this.value.substring(0, this.value.lastIndexOf('/'));\n }\n }\n\n render() {\n return html`\n <div class=\"input-wrapper\" style=\"align-items: center;\">\n <input\n type=\"text\"\n class=\"${this.hasError ? 'error' : ''}\"\n .value=${this.value}\n @input=${this._handleInput}\n placeholder=\"/path/to/file\"\n />\n <button\n class=\"btn-secondary\"\n style=\"height: auto; white-space: nowrap;\"\n @click=${this._toggleBrowser}\n >\n ${this._isOpen ? 'Close' : 'Browse'}\n </button>\n </div>\n\n ${this._isOpen\n ? html`\n <div class=\"picker-container\" style=\"margin-top: var(--space-sm);\">\n <div class=\"current-path\">\n <button\n class=\"btn-secondary\"\n style=\"padding: 2px 6px; font-size: 0.7rem;\"\n @click=${this._goUp}\n >\n \u2191\n </button>\n <span class=\"path-text\" title=${this._currentPath}\n >${this._currentPath || 'Loading...'}</span\n >\n </div>\n\n <div class=\"file-list\">\n ${this._loading\n ? html`<div style=\"padding: var(--space-md); color: var(--t-muted);\">\n Loading...\n </div>`\n : this._items\n .filter((item) => this._matchesFilter(item))\n .map((item) => this._renderItem(item))}\n ${!this._loading &&\n this._items.filter((item) => this._matchesFilter(item)).length === 0\n ? html`\n <div style=\"padding: var(--space-md); color: var(--t-muted);\">\n Empty directory\n </div>\n `\n : ''}\n </div>\n </div>\n `\n : ''}\n `;\n }\n\n private _renderItem(item: FileEntry) {\n const isSelected = this.value === item.path;\n return html`\n <div\n class=\"file-item ${isSelected ? 'selected' : ''}\"\n @click=${() => this._handleItemClick(item)}\n >\n <span class=\"icon\">${item.isDirectory ? '\uD83D\uDCC1' : '\uD83D\uDCC4'}</span>\n <span style=\"flex:1; overflow:hidden; text-overflow:ellipsis;\">${item.name}</span>\n </div>\n `;\n }\n\n private _handleInput(e: Event) {\n const newVal = (e.target as HTMLInputElement).value;\n this.value = newVal;\n this._dispatchChange();\n }\n\n private _toggleBrowser() {\n this._isOpen = !this._isOpen;\n if (this._isOpen) {\n this._loadPath(this._currentPath || '');\n }\n }\n\n private async _loadPath(path: string) {\n this._loading = true;\n try {\n const url = new URL('/api/browse', window.location.origin);\n if (path) url.searchParams.set('path', path);\n\n const res = await fetch(url.toString(), {\n signal: AbortSignal.timeout(10000),\n });\n if (!res.ok) throw new Error('Failed to load');\n\n const data: BrowseResponse = await res.json();\n this._currentPath = data.path;\n this._items = data.items;\n } catch (err) {\n console.error(err);\n } finally {\n this._loading = false;\n }\n }\n\n private _handleItemClick(item: FileEntry) {\n if (item.isDirectory) {\n this._loadPath(item.path);\n } else {\n this.value = item.path;\n this._dispatchChange();\n // Auto-close on file selection\n this._isOpen = false;\n }\n }\n\n private _goUp() {\n this._loadPath(this._currentPath + '/..');\n }\n\n /** Check if a file matches the accept filter */\n private _matchesFilter(item: FileEntry): boolean {\n // Always show directories\n if (item.isDirectory) return true;\n\n // No filter = show all\n if (!this.accept) return true;\n\n const filters = this.accept.split(',').map((f) => f.trim().toLowerCase());\n const fileName = item.name.toLowerCase();\n\n return filters.some((filter) => {\n // Handle glob patterns like \"*.photon.ts\"\n if (filter.startsWith('*.')) {\n const suffix = filter.slice(1); // Remove leading *\n return fileName.endsWith(suffix);\n }\n // Handle extension patterns like \".ts\" or \"ts\"\n const ext = filter.startsWith('.') ? filter : `.${filter}`;\n return fileName.endsWith(ext);\n });\n }\n\n private _dispatchChange() {\n this.dispatchEvent(\n new CustomEvent('change', {\n detail: { value: this.value },\n bubbles: true,\n composed: true,\n })\n );\n }\n}\n", "import { LitElement, html, css } from 'lit';\nimport { customElement, state } from 'lit/decorators.js';\nimport { theme } from '../styles/theme.js';\nimport { showToast } from './toast-manager.js';\n\ninterface MarketplaceItem {\n name: string;\n description: string;\n author: string;\n tags: string[];\n marketplace: string;\n version: string;\n icon?: string;\n internal?: boolean;\n installed?: boolean;\n}\n\ninterface MarketplaceSource {\n name: string;\n source: string;\n sourceType: string;\n enabled: boolean;\n photonCount: number;\n}\n\n@customElement('marketplace-view')\nexport class MarketplaceView extends LitElement {\n static styles = [\n theme,\n css`\n :host {\n display: block;\n height: 100%;\n display: flex;\n flex-direction: column;\n }\n\n .toolbar {\n display: flex;\n gap: var(--space-md);\n margin-bottom: var(--space-lg);\n }\n\n .search-box {\n flex: 1;\n position: relative;\n }\n\n .search-box input {\n width: 100%;\n padding: var(--space-sm) var(--space-lg);\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n color: var(--t-primary);\n border-radius: var(--radius-md);\n font-size: 1rem;\n transition: all 0.2s;\n }\n\n .search-box input:focus {\n outline: none;\n border-color: var(--accent-primary);\n box-shadow: 0 0 0 2px var(--glow-primary);\n }\n\n .grid {\n display: grid;\n grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));\n gap: var(--space-md);\n overflow-y: auto;\n padding-bottom: var(--space-xl);\n }\n\n .card {\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n border-radius: var(--radius-md);\n padding: var(--space-md);\n display: flex;\n flex-direction: column;\n transition:\n transform 0.2s,\n box-shadow 0.2s;\n }\n\n .card:hover {\n transform: translateY(-2px);\n box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);\n border-color: var(--accent-secondary);\n }\n\n .card-header {\n display: flex;\n justify-content: space-between;\n align-items: flex-start;\n margin-bottom: var(--space-sm);\n }\n\n .card-title {\n font-weight: 600;\n font-size: 1.1rem;\n color: var(--t-primary);\n }\n\n .card-author {\n font-size: 0.8rem;\n color: var(--t-muted);\n }\n\n .card-desc {\n flex: 1;\n font-size: 0.9rem;\n color: var(--t-muted);\n line-height: 1.4;\n margin-bottom: var(--space-md);\n }\n\n .tags {\n display: flex;\n gap: 4px;\n flex-wrap: wrap;\n margin-bottom: var(--space-md);\n }\n\n .tag {\n font-size: 0.7rem;\n padding: 2px 8px;\n background: rgba(255, 255, 255, 0.05);\n border-radius: 10px;\n color: var(--t-muted);\n }\n\n .source-pill {\n font-size: 0.65rem;\n padding: 2px 8px;\n border-radius: 10px;\n font-weight: 600;\n text-transform: uppercase;\n letter-spacing: 0.05em;\n }\n\n .source-official {\n background: linear-gradient(135deg, hsl(210, 100%, 50%), hsl(240, 100%, 60%));\n color: white;\n }\n\n .source-community {\n background: linear-gradient(135deg, hsl(150, 60%, 45%), hsl(180, 60%, 45%));\n color: white;\n }\n\n .source-local {\n background: rgba(255, 255, 255, 0.1);\n color: var(--t-muted);\n border: 1px solid var(--border-glass);\n }\n\n .source-internal {\n background: linear-gradient(135deg, hsl(280, 60%, 50%), hsl(320, 60%, 50%));\n color: white;\n }\n\n .card.internal {\n border-color: hsl(280, 40%, 40%);\n }\n\n .photon-icon {\n margin-right: 6px;\n font-size: 1.1em;\n }\n\n /* Marketplace filter pills */\n .source-filters {\n display: flex;\n gap: 8px;\n flex-wrap: wrap;\n margin-bottom: var(--space-lg);\n }\n\n .filter-pill {\n padding: 6px 12px;\n border-radius: 16px;\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n font-size: 0.85rem;\n color: var(--t-secondary);\n cursor: pointer;\n transition: all 0.2s;\n display: flex;\n align-items: center;\n gap: 6px;\n }\n\n .filter-pill:hover {\n border-color: var(--accent-primary);\n color: var(--t-primary);\n }\n\n .filter-pill.active {\n background: var(--accent-primary);\n border-color: var(--accent-primary);\n color: white;\n }\n\n .filter-pill .count {\n background: rgba(255, 255, 255, 0.2);\n padding: 2px 6px;\n border-radius: 10px;\n font-size: 0.75rem;\n font-weight: 500;\n }\n\n .filter-pill.active .count {\n background: rgba(255, 255, 255, 0.3);\n }\n\n .filter-pill .remove-btn {\n opacity: 0;\n margin-left: 4px;\n padding: 0;\n background: none;\n border: none;\n color: inherit;\n cursor: pointer;\n font-size: 14px;\n line-height: 1;\n }\n\n .filter-pill:hover .remove-btn {\n opacity: 0.6;\n }\n\n .filter-pill .remove-btn:hover {\n opacity: 1;\n }\n\n .card-meta {\n display: flex;\n align-items: center;\n gap: var(--space-sm);\n flex-wrap: wrap;\n }\n\n .actions {\n display: flex;\n justify-content: flex-end;\n }\n\n .btn-install {\n background: var(--accent-primary);\n color: white;\n border: none;\n padding: 6px 12px;\n border-radius: var(--radius-sm);\n cursor: pointer;\n font-weight: 500;\n transition: opacity 0.2s;\n }\n\n .btn-install:hover {\n opacity: 0.9;\n }\n\n .btn-install:disabled {\n opacity: 0.5;\n cursor: not-allowed;\n background: var(--t-muted);\n }\n\n .btn-installed {\n background: transparent;\n color: var(--t-muted);\n border: 1px solid var(--border-glass);\n padding: 6px 12px;\n border-radius: var(--radius-sm);\n font-weight: 500;\n cursor: default;\n font-size: 0.85rem;\n }\n\n .card.installed {\n border-color: var(--accent-secondary);\n opacity: 0.85;\n }\n\n /* Actions Toolbar */\n .actions-toolbar {\n display: flex;\n gap: var(--space-sm);\n margin-bottom: var(--space-lg);\n padding: var(--space-md);\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n border-radius: var(--radius-md);\n flex-wrap: wrap;\n align-items: center;\n }\n\n .toolbar-section {\n display: flex;\n gap: var(--space-sm);\n align-items: center;\n }\n\n .toolbar-section-title {\n font-size: 0.7rem;\n text-transform: uppercase;\n letter-spacing: 0.05em;\n color: var(--t-muted);\n margin-right: var(--space-sm);\n }\n\n .toolbar-divider {\n width: 1px;\n height: 24px;\n background: var(--border-glass);\n margin: 0 var(--space-sm);\n }\n\n /* Unified button style for all toolbar buttons */\n .toolbar-btn {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n gap: 6px;\n height: 36px;\n padding: 0 14px;\n background: var(--bg-glass-strong);\n border: 1px solid var(--border-glass);\n color: var(--t-primary);\n border-radius: var(--radius-sm);\n cursor: pointer;\n font-size: 0.85rem;\n font-weight: 500;\n transition: all 0.2s;\n white-space: nowrap;\n }\n\n .toolbar-btn:hover {\n background: var(--accent-primary);\n border-color: var(--accent-primary);\n color: white;\n }\n\n .toolbar-btn:disabled {\n opacity: 0.5;\n cursor: not-allowed;\n }\n\n .toolbar-btn .icon {\n font-size: 1rem;\n line-height: 1;\n }\n\n .toolbar-btn.primary {\n background: var(--accent-primary);\n border-color: var(--accent-primary);\n color: white;\n }\n\n .toolbar-btn.primary:hover {\n opacity: 0.9;\n }\n\n /* Legacy alias for backwards compatibility */\n .maker-btn {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n gap: 6px;\n height: 36px;\n padding: 0 14px;\n background: var(--bg-glass-strong);\n border: 1px solid var(--border-glass);\n color: var(--t-primary);\n border-radius: var(--radius-sm);\n cursor: pointer;\n font-size: 0.85rem;\n font-weight: 500;\n transition: all 0.2s;\n white-space: nowrap;\n }\n\n .maker-btn:hover {\n background: var(--accent-primary);\n border-color: var(--accent-primary);\n color: white;\n }\n\n .maker-btn:disabled {\n opacity: 0.5;\n cursor: not-allowed;\n }\n\n .maker-btn .icon {\n font-size: 1rem;\n line-height: 1;\n }\n\n /* Add Marketplace Modal */\n .modal-overlay {\n position: fixed;\n inset: 0;\n background: rgba(0, 0, 0, 0.6);\n display: flex;\n align-items: center;\n justify-content: center;\n z-index: 1000;\n backdrop-filter: blur(4px);\n }\n\n .modal {\n background: var(--bg-panel);\n border: 1px solid var(--border-glass);\n border-radius: var(--radius-md);\n width: 90%;\n max-width: 450px;\n box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4);\n }\n\n .modal-header {\n display: flex;\n justify-content: space-between;\n align-items: center;\n padding: var(--space-md);\n border-bottom: 1px solid var(--border-glass);\n }\n\n .modal-header h3 {\n margin: 0;\n font-size: 1.1rem;\n }\n\n .modal-close {\n background: none;\n border: none;\n color: var(--t-muted);\n cursor: pointer;\n padding: 4px;\n border-radius: var(--radius-sm);\n }\n\n .modal-close:hover {\n color: var(--t-primary);\n background: var(--bg-glass);\n }\n\n .modal-body {\n padding: var(--space-md);\n }\n\n .modal-body input {\n width: 100%;\n padding: var(--space-sm) var(--space-md);\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n color: var(--t-primary);\n border-radius: var(--radius-sm);\n font-size: 0.95rem;\n margin-bottom: var(--space-sm);\n box-sizing: border-box;\n }\n\n .modal-body input:focus {\n outline: none;\n border-color: var(--accent-primary);\n }\n\n .modal-hint {\n font-size: 0.8rem;\n color: var(--t-muted);\n line-height: 1.5;\n }\n\n .modal-hint code {\n background: var(--bg-glass);\n padding: 1px 4px;\n border-radius: 3px;\n font-size: 0.75rem;\n }\n\n .formats-table {\n width: 100%;\n font-size: 0.8rem;\n border-collapse: collapse;\n margin-top: var(--space-md);\n }\n\n .formats-table td {\n padding: 6px 0;\n vertical-align: middle;\n }\n\n .formats-table .type-label {\n color: var(--t-muted);\n font-size: 0.75rem;\n width: 80px;\n font-weight: 500;\n }\n\n .formats-table td code {\n background: var(--bg-glass);\n padding: 2px 6px;\n border-radius: 3px;\n font-size: 0.75rem;\n color: var(--t-secondary);\n }\n\n .modal-footer {\n display: flex;\n justify-content: flex-end;\n gap: var(--space-sm);\n padding: var(--space-md);\n border-top: 1px solid var(--border-glass);\n }\n\n /* ===== Responsive Design ===== */\n @media (max-width: 768px) {\n .grid {\n grid-template-columns: 1fr;\n gap: var(--space-md);\n }\n\n .toolbar {\n flex-direction: column;\n gap: var(--space-sm);\n }\n\n .search-box input {\n min-height: 44px;\n font-size: 16px; /* Prevent iOS zoom */\n }\n\n .filter-pill {\n min-height: 44px;\n }\n\n .card {\n min-height: 44px;\n }\n\n .btn-install {\n min-height: 44px;\n width: 100%;\n }\n\n .actions-toolbar {\n flex-direction: column;\n align-items: stretch;\n }\n\n .toolbar-section {\n flex-wrap: wrap;\n justify-content: center;\n }\n\n .toolbar-divider {\n width: 100%;\n height: 1px;\n margin: var(--space-sm) 0;\n }\n\n .toolbar-btn,\n .maker-btn {\n min-height: 44px;\n flex: 1;\n }\n\n .modal {\n margin: var(--space-md);\n width: calc(100% - var(--space-lg));\n }\n\n .modal-footer {\n flex-direction: column;\n }\n\n .modal-footer button {\n width: 100%;\n }\n }\n\n @media (max-width: 480px) {\n :host {\n padding: var(--space-sm);\n }\n\n .source-filters {\n flex-wrap: nowrap;\n overflow-x: auto;\n padding-bottom: var(--space-sm);\n -webkit-overflow-scrolling: touch;\n }\n\n .filter-pill {\n flex-shrink: 0;\n }\n\n .card-header {\n flex-direction: column;\n align-items: flex-start;\n gap: var(--space-sm);\n }\n\n .card-meta {\n width: 100%;\n justify-content: flex-start;\n }\n\n .card-title {\n font-size: 1rem;\n }\n\n .card-desc {\n font-size: 0.85rem;\n }\n\n .toolbar-section-title {\n width: 100%;\n text-align: center;\n margin-bottom: var(--space-xs);\n }\n\n .formats-table {\n font-size: 0.75rem;\n }\n }\n `,\n ];\n\n @state()\n private _items: MarketplaceItem[] = [];\n\n @state()\n private _allItems: MarketplaceItem[] = [];\n\n @state()\n private _sources: MarketplaceSource[] = [];\n\n @state()\n private _activeFilter: string | null = null;\n\n @state()\n private _loading = false;\n\n @state()\n private _installing: string | null = null;\n\n @state()\n private _showAddRepoModal = false;\n\n @state()\n private _repoInput = '';\n\n async connectedCallback() {\n super.connectedCallback();\n await this._fetchSources();\n await this._fetchItems();\n }\n\n render() {\n return html`\n <!-- Actions Toolbar -->\n <div class=\"actions-toolbar\">\n <div class=\"toolbar-section\">\n <span class=\"toolbar-section-title\">Create</span>\n <button class=\"toolbar-btn\" @click=${this._createNew} title=\"Create a new photon\">\n <span class=\"icon\">\u2728</span>\n <span>New Photon</span>\n </button>\n </div>\n\n <div class=\"toolbar-divider\"></div>\n\n <div class=\"toolbar-section\">\n <span class=\"toolbar-section-title\">Marketplaces</span>\n <button\n class=\"toolbar-btn primary\"\n @click=${() => (this._showAddRepoModal = true)}\n title=\"Add a new marketplace\"\n >\n <span class=\"icon\">+</span>\n <span>Add Marketplace</span>\n </button>\n <button class=\"toolbar-btn\" @click=${this._syncPhotons} title=\"Sync marketplace cache\">\n <span class=\"icon\">\uD83D\uDD04</span>\n <span>Sync</span>\n </button>\n </div>\n\n <div class=\"toolbar-divider\"></div>\n\n <div class=\"toolbar-section\">\n <span class=\"toolbar-section-title\">Tools</span>\n <button class=\"toolbar-btn\" @click=${this._validatePhotons} title=\"Validate all photons\">\n <span class=\"icon\">\u2713</span>\n <span>Validate</span>\n </button>\n </div>\n </div>\n\n <div class=\"toolbar\">\n <div class=\"search-box\">\n <input type=\"text\" placeholder=\"Search photons...\" @input=${this._handleSearch} />\n </div>\n </div>\n\n <!-- Marketplace filters -->\n <div class=\"source-filters\">\n <button\n class=\"filter-pill ${this._activeFilter === null ? 'active' : ''}\"\n @click=${() => this._filterBySource(null)}\n >\n All\n <span class=\"count\">${this._allItems.length}</span>\n </button>\n ${this._sources\n .filter((s) => s.enabled)\n .map(\n (source) => html`\n <button\n class=\"filter-pill ${this._activeFilter === source.name ? 'active' : ''}\"\n @click=${() => this._filterBySource(source.name)}\n title=${source.source}\n >\n ${source.name}\n <span class=\"count\">${source.photonCount}</span>\n <span\n class=\"remove-btn\"\n @click=${(e: Event) => {\n e.stopPropagation();\n this._removeSource(source.name);\n }}\n title=\"Remove marketplace\"\n >\u2715</span\n >\n </button>\n `\n )}\n </div>\n\n ${this._loading\n ? html`<div style=\"text-align: center; color: var(--t-muted); padding: 40px;\">\n Loading marketplace...\n </div>`\n : html` <div class=\"grid\">${this._items.map((item) => this._renderItem(item))}</div> `}\n ${this._showAddRepoModal ? this._renderAddRepoModal() : ''}\n `;\n }\n\n private _renderAddRepoModal() {\n return html`\n <div\n class=\"modal-overlay\"\n @click=${(e: Event) => {\n if (e.target === e.currentTarget) this._showAddRepoModal = false;\n }}\n >\n <div class=\"modal\">\n <div class=\"modal-header\">\n <h3>Add Marketplace</h3>\n <button class=\"modal-close\" @click=${() => (this._showAddRepoModal = false)}>\u2715</button>\n </div>\n <div class=\"modal-body\">\n <input\n type=\"text\"\n placeholder=\"Enter GitHub repo, local path, or URL\"\n .value=${this._repoInput}\n @input=${(e: Event) => (this._repoInput = (e.target as HTMLInputElement).value)}\n @keydown=${(e: KeyboardEvent) => {\n if (e.key === 'Enter') this._addRepository();\n }}\n autofocus\n />\n <table class=\"formats-table\">\n <tbody>\n <tr>\n <td class=\"type-label\">GitHub</td>\n <td><code>username/repo</code></td>\n </tr>\n <tr>\n <td class=\"type-label\">GitHub URL</td>\n <td><code>https://github.com/user/repo</code></td>\n </tr>\n <tr>\n <td class=\"type-label\">SSH</td>\n <td><code>git@github.com:user/repo.git</code></td>\n </tr>\n <tr>\n <td class=\"type-label\">Local</td>\n <td><code>~/path/to/folder</code></td>\n </tr>\n <tr>\n <td class=\"type-label\">URL</td>\n <td><code>https://example.com/photons.json</code></td>\n </tr>\n </tbody>\n </table>\n </div>\n <div class=\"modal-footer\">\n <button class=\"toolbar-btn\" @click=${() => (this._showAddRepoModal = false)}>\n Cancel\n </button>\n <button class=\"toolbar-btn primary\" @click=${this._addRepository}>Add</button>\n </div>\n </div>\n </div>\n `;\n }\n\n private _renderItem(item: MarketplaceItem) {\n const isInstalling = this._installing === item.name;\n const sourceClass = this._getSourceClass(item.marketplace);\n const cardClasses = `card glass ${item.internal ? 'internal' : ''} ${item.installed ? 'installed' : ''}`;\n\n return html`\n <div class=\"${cardClasses}\">\n <div class=\"card-header\">\n <div>\n <div class=\"card-title\">\n ${item.icon ? html`<span class=\"photon-icon\">${item.icon}</span>` : ''} ${item.name}\n </div>\n <div class=\"card-author\">by ${item.author}</div>\n </div>\n <div class=\"card-meta\">\n ${item.internal ? html`<span class=\"source-pill source-internal\">System</span>` : ''}\n <span class=\"source-pill ${sourceClass}\">${item.marketplace || 'Local'}</span>\n <div class=\"tag\" style=\"background: var(--accent-secondary); color: black;\">\n ${item.version}\n </div>\n </div>\n </div>\n\n <div class=\"card-desc\">${item.description}</div>\n\n <div class=\"tags\">${item.tags.map((tag) => html`<span class=\"tag\">${tag}</span>`)}</div>\n\n <div class=\"actions\">\n ${item.installed\n ? html`<span class=\"btn-installed\">\u2713 Installed</span>`\n : html`<button\n class=\"btn-install\"\n ?disabled=${isInstalling}\n @click=${() => this._install(item)}\n >\n ${isInstalling ? 'Installing...' : 'Install'}\n </button>`}\n </div>\n </div>\n `;\n }\n\n private _getSourceClass(marketplace: string): string {\n const lower = marketplace?.toLowerCase() || '';\n if (lower.includes('official') || lower === 'photon' || lower === 'portel') {\n return 'source-official';\n }\n if (lower.includes('community') || lower.includes('github')) {\n return 'source-community';\n }\n return 'source-local';\n }\n\n private _getSourceLabel(marketplace: string): string {\n const lower = marketplace?.toLowerCase() || '';\n if (lower.includes('official') || lower === 'photon' || lower === 'portel') {\n return 'Official';\n }\n if (lower.includes('community')) {\n return 'Community';\n }\n if (lower.includes('github')) {\n return 'GitHub';\n }\n return marketplace || 'Local';\n }\n\n private async _fetchSources() {\n try {\n const res = await fetch('/api/marketplace/sources', {\n signal: AbortSignal.timeout(10000),\n });\n const data = await res.json();\n this._sources = data.sources || [];\n } catch (e) {\n console.error('Failed to fetch marketplace sources', e);\n }\n }\n\n private async _fetchItems(query = '') {\n this._loading = true;\n try {\n const endpoint = query\n ? `/api/marketplace/search?q=${encodeURIComponent(query)}`\n : '/api/marketplace/list';\n\n const res = await fetch(endpoint, {\n signal: AbortSignal.timeout(30000), // marketplace fetch can be slow\n });\n const data = await res.json();\n this._allItems = data.photons || [];\n this._applyFilter();\n } catch (e) {\n console.error('Failed to fetch marketplace', e);\n } finally {\n this._loading = false;\n }\n }\n\n private _filterBySource(sourceName: string | null) {\n this._activeFilter = sourceName;\n this._applyFilter();\n }\n\n private _applyFilter() {\n if (this._activeFilter === null) {\n this._items = this._allItems;\n } else {\n this._items = this._allItems.filter((item) => item.marketplace === this._activeFilter);\n }\n }\n\n private async _removeSource(name: string) {\n if (!confirm(`Remove marketplace \"${name}\"? This will not uninstall any photons.`)) {\n return;\n }\n\n try {\n const res = await fetch('/api/marketplace/sources/remove', {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ name }),\n signal: AbortSignal.timeout(10000),\n });\n\n if (res.ok) {\n showToast(`Removed marketplace: ${name}`, 'success');\n if (this._activeFilter === name) {\n this._activeFilter = null;\n }\n await this._fetchSources();\n await this._fetchItems();\n } else {\n const data = await res.json();\n throw new Error(data.error || 'Failed to remove marketplace');\n }\n } catch (e: any) {\n showToast(e.message, 'error');\n }\n }\n\n // Debounce search\n private _searchTimeout: any;\n private _handleSearch(e: Event) {\n const query = (e.target as HTMLInputElement).value;\n clearTimeout(this._searchTimeout);\n this._searchTimeout = setTimeout(() => {\n this._fetchItems(query);\n }, 300);\n }\n\n private async _install(item: MarketplaceItem) {\n this._installing = item.name;\n try {\n const res = await fetch('/api/marketplace/add', {\n method: 'POST',\n body: JSON.stringify({ name: item.name }),\n signal: AbortSignal.timeout(30000), // 30s for installation\n });\n\n if (res.ok) {\n // Mark item as installed in the local list\n item.installed = true;\n this.requestUpdate();\n this.dispatchEvent(\n new CustomEvent('install', {\n detail: { name: item.name },\n bubbles: true,\n composed: true,\n })\n );\n showToast(`Successfully installed ${item.name}`, 'success');\n } else {\n const err = await res.json();\n showToast(`Failed to install: ${err.error}`, 'error', 5000);\n }\n } catch (e) {\n showToast('Installation failed', 'error', 5000);\n } finally {\n this._installing = null;\n }\n }\n\n // Maker static method actions\n private _createNew() {\n this.dispatchEvent(\n new CustomEvent('maker-action', {\n detail: { action: 'new' },\n bubbles: true,\n composed: true,\n })\n );\n }\n\n private _syncPhotons() {\n this.dispatchEvent(\n new CustomEvent('maker-action', {\n detail: { action: 'sync' },\n bubbles: true,\n composed: true,\n })\n );\n }\n\n private _validatePhotons() {\n this.dispatchEvent(\n new CustomEvent('maker-action', {\n detail: { action: 'validate' },\n bubbles: true,\n composed: true,\n })\n );\n }\n\n private async _addRepository() {\n const source = this._repoInput.trim();\n if (!source) {\n showToast('Please enter a marketplace location', 'error');\n return;\n }\n\n try {\n const res = await fetch('/api/marketplace/sources/add', {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ source }),\n signal: AbortSignal.timeout(30000), // 30s for adding repo\n });\n\n const data = await res.json();\n\n if (!res.ok) {\n throw new Error(data.error || 'Failed to add repository');\n }\n\n this._showAddRepoModal = false;\n this._repoInput = '';\n showToast(\n data.added ? `Added marketplace: ${data.name}` : `Already exists: ${data.name}`,\n 'success'\n );\n\n // Refresh sources and photons\n await this._fetchSources();\n await this._fetchItems();\n } catch (e: any) {\n showToast(e.message || 'Failed to add repository', 'error', 5000);\n }\n }\n}\n", "import { LitElement, html, css, PropertyValueMap } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { theme, Theme } from '../styles/theme.js';\nimport { getThemeTokens } from '../../design-system/tokens.js';\nimport { mcpClient } from '../services/mcp-client.js';\n\n@customElement('custom-ui-renderer')\nexport class CustomUiRenderer extends LitElement {\n static styles = [\n theme,\n css`\n :host {\n display: block;\n width: 100%;\n height: 100%;\n min-height: 500px;\n background: var(--bg-panel, #0d0d0d);\n border-radius: var(--radius-md);\n overflow: hidden;\n }\n\n iframe {\n width: 100%;\n height: 100%;\n border: none;\n display: block;\n opacity: 0;\n transition: opacity 0.15s ease-in;\n }\n\n iframe.ready {\n opacity: 1;\n }\n\n .loading {\n display: flex;\n align-items: center;\n justify-content: center;\n height: 100%;\n color: var(--t-muted);\n background: var(--bg-panel);\n }\n\n .error-container {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n gap: var(--space-md);\n height: 100%;\n background: var(--bg-glass);\n color: var(--t-primary);\n padding: var(--space-lg);\n text-align: center;\n }\n\n .error-icon {\n font-size: 3rem;\n opacity: 0.5;\n }\n\n .error-message {\n color: #f87171;\n font-size: 0.9rem;\n max-width: 400px;\n }\n\n .retry-btn {\n background: var(--accent-primary);\n color: white;\n border: none;\n padding: var(--space-sm) var(--space-lg);\n border-radius: var(--radius-sm);\n cursor: pointer;\n font-weight: 500;\n transition: opacity 0.2s;\n }\n\n .retry-btn:hover {\n opacity: 0.9;\n }\n\n /* ===== Responsive Design ===== */\n @media (max-width: 768px) {\n :host {\n min-height: 400px;\n border-radius: var(--radius-sm);\n }\n\n .retry-btn {\n min-height: 44px;\n width: 100%;\n }\n\n .error-container {\n padding: var(--space-md);\n }\n\n .error-message {\n max-width: 100%;\n }\n }\n\n @media (max-width: 480px) {\n :host {\n min-height: 300px;\n }\n\n .error-icon {\n font-size: 2.5rem;\n }\n\n .error-message {\n font-size: 0.85rem;\n }\n }\n `,\n ];\n\n @property({ type: String }) photon = '';\n @property({ type: String }) method = '';\n @property({ type: String }) theme: Theme = 'dark';\n @property({ type: Object }) csp?: {\n connectDomains?: string[];\n resourceDomains?: string[];\n frameDomains?: string[];\n baseUriDomains?: string[];\n };\n\n // One of these will be set (in order of preference)\n @property({ type: String }) uiUri = ''; // MCP Apps: ui://photon/id\n @property({ type: String }) templatePath = '';\n @property({ type: String }) uiId = '';\n\n @state() private _srcDoc = '';\n @state() private _loading = true;\n @state() private _error = '';\n private _iframeRef: HTMLIFrameElement | null = null;\n\n protected updated(changedProperties: PropertyValueMap<any> | Map<PropertyKey, unknown>) {\n if (\n changedProperties.has('photon') ||\n changedProperties.has('method') ||\n changedProperties.has('templatePath') ||\n changedProperties.has('uiId') ||\n changedProperties.has('uiUri')\n ) {\n this._loadContent();\n }\n\n // Notify iframe of theme change without reloading\n if (changedProperties.has('theme')) {\n if (this._iframeRef?.contentWindow) {\n const themeTokens = getThemeTokens(this.theme);\n // Standard MCP Apps notification\n this._iframeRef.contentWindow.postMessage(\n {\n jsonrpc: '2.0',\n method: 'ui/notifications/host-context-changed',\n params: {\n theme: this.theme,\n styles: { variables: themeTokens },\n },\n },\n '*'\n );\n // Photon bridge notification (backward compat)\n this._iframeRef.contentWindow.postMessage(\n {\n type: 'photon:theme-change',\n theme: this.theme,\n themeTokens: themeTokens,\n },\n '*'\n );\n }\n }\n }\n\n private async _loadContent() {\n if (!this.photon && !this.uiUri) return;\n\n this._loading = true;\n this._error = '';\n this._srcDoc = '';\n\n try {\n // 1. Fetch Template via MCP resources/read (ui:// scheme)\n let templateHtml: string;\n\n // Determine the ui:// URI\n let uri = this.uiUri;\n if (!uri && this.uiId) {\n uri = `ui://${this.photon}/${this.uiId}`;\n }\n\n if (uri) {\n // Use MCP resources/read for ui:// URIs\n templateHtml = await this._fetchViaMCP(uri);\n } else if (this.templatePath) {\n // Fall back to HTTP for templatePath (legacy)\n const url = `/api/template?photon=${encodeURIComponent(this.photon)}&path=${encodeURIComponent(this.templatePath)}`;\n const templateRes = await fetch(url, { signal: AbortSignal.timeout(10000) });\n if (!templateRes.ok) throw new Error(`Failed to load template: ${templateRes.statusText}`);\n templateHtml = await templateRes.text();\n } else {\n throw new Error('No template source specified');\n }\n\n // 2. Fetch Bridge Script (still via HTTP - it's dynamically generated)\n const bridgeRes = await fetch(\n `/api/platform-bridge?photon=${encodeURIComponent(this.photon)}&method=${encodeURIComponent(this.method)}&theme=${encodeURIComponent(this.theme)}`,\n {\n signal: AbortSignal.timeout(10000),\n }\n );\n if (!bridgeRes.ok) throw new Error('Failed to load platform bridge');\n const bridgeScript = await bridgeRes.text();\n\n // 3. Build CSP meta tag if CSP metadata is provided\n let cspTag = '';\n if (this.csp) {\n const directives: string[] = [\n \"default-src 'self'\",\n \"script-src 'self' 'unsafe-inline'\",\n \"style-src 'self' 'unsafe-inline'\",\n ];\n if (this.csp.connectDomains?.length) {\n directives.push(`connect-src 'self' ${this.csp.connectDomains.join(' ')}`);\n }\n if (this.csp.resourceDomains?.length) {\n directives.push(`img-src 'self' ${this.csp.resourceDomains.join(' ')}`);\n directives.push(`media-src 'self' ${this.csp.resourceDomains.join(' ')}`);\n directives.push(`font-src 'self' ${this.csp.resourceDomains.join(' ')}`);\n }\n if (this.csp.frameDomains?.length) {\n directives.push(`frame-src 'self' ${this.csp.frameDomains.join(' ')}`);\n }\n if (this.csp.baseUriDomains?.length) {\n directives.push(`base-uri ${this.csp.baseUriDomains.join(' ')}`);\n }\n cspTag = `<meta http-equiv=\"Content-Security-Policy\" content=\"${directives.join('; ')}\">`;\n }\n\n // 4. Inject Bridge (and CSP if present)\n const injected = cspTag + bridgeScript;\n let finalHtml = templateHtml;\n if (finalHtml.includes('</head>')) {\n finalHtml = finalHtml.replace('</head>', `${injected}</head>`);\n } else {\n finalHtml = `<html><head>${injected}</head><body>${finalHtml}</body></html>`;\n }\n\n this._srcDoc = finalHtml;\n // Note: Custom UIs should send 'photon:viewing' message with actual board name\n // to enable on-demand channel subscriptions\n } catch (e: any) {\n this._error = e.message;\n } finally {\n this._loading = false;\n }\n }\n\n /**\n * Fetch UI template via MCP resources/read with HTTP fallback\n */\n private async _fetchViaMCP(uri: string): Promise<string> {\n // Try MCP first\n if (mcpClient.isConnected()) {\n try {\n const resource = await mcpClient.readResource(uri);\n if (resource?.text) {\n return resource.text;\n }\n } catch (e) {\n console.warn('MCP resources/read failed, falling back to HTTP:', e);\n }\n }\n\n // Fallback to HTTP /api/ui endpoint\n const match = uri.match(/^ui:\\/\\/([^/]+)\\/(.+)$/);\n if (!match) {\n throw new Error(`Invalid ui:// URI: ${uri}`);\n }\n\n const [, photonName, uiId] = match;\n const url = `/api/ui?photon=${encodeURIComponent(photonName)}&id=${encodeURIComponent(uiId)}`;\n const res = await fetch(url, { signal: AbortSignal.timeout(10000) });\n if (!res.ok) throw new Error(`Failed to load UI: ${res.statusText}`);\n return res.text();\n }\n\n render() {\n if (this._error) {\n return html`\n <div class=\"error-container\">\n <div class=\"error-icon\">\u26A0\uFE0F</div>\n <div class=\"error-message\">${this._error}</div>\n <button class=\"retry-btn\" @click=${this._loadContent}>Retry</button>\n </div>\n `;\n }\n\n if (this._loading) {\n return html`<div class=\"loading\">Loading interface...</div>`;\n }\n\n return html`\n <iframe\n srcdoc=${this._srcDoc}\n sandbox=\"allow-scripts allow-forms allow-same-origin allow-popups allow-modals\"\n @load=${this._handleIframeLoad}\n ></iframe>\n `;\n }\n\n /**\n * Send ui/resource-teardown to iframe and wait for response (max 3s).\n * Returns a promise that resolves when teardown completes or times out.\n */\n async teardown(): Promise<void> {\n if (!this._iframeRef?.contentWindow) return;\n\n const callId = `teardown_${Date.now()}`;\n return new Promise<void>((resolve) => {\n const timeout = setTimeout(resolve, 3000);\n const handler = (e: MessageEvent) => {\n const msg = e.data;\n if (msg?.jsonrpc === '2.0' && msg?.id === callId && !msg.method) {\n clearTimeout(timeout);\n window.removeEventListener('message', handler);\n resolve();\n }\n };\n window.addEventListener('message', handler);\n\n this._iframeRef!.contentWindow!.postMessage(\n { jsonrpc: '2.0', id: callId, method: 'ui/resource-teardown', params: {} },\n '*'\n );\n });\n }\n\n disconnectedCallback() {\n super.disconnectedCallback();\n // Fire-and-forget teardown on unmount\n this.teardown().catch(() => {});\n }\n\n private _handleIframeLoad(e: Event) {\n this._iframeRef = e.target as HTMLIFrameElement;\n // Send initial theme to iframe after load (with tokens for immediate styling)\n const themeTokens = getThemeTokens(this.theme);\n // Standard MCP Apps notification\n this._iframeRef?.contentWindow?.postMessage(\n {\n jsonrpc: '2.0',\n method: 'ui/notifications/host-context-changed',\n params: {\n theme: this.theme,\n styles: { variables: themeTokens },\n },\n },\n '*'\n );\n // Photon bridge notification (backward compat)\n this._iframeRef?.contentWindow?.postMessage(\n {\n type: 'photon:theme-change',\n theme: this.theme,\n themeTokens: themeTokens,\n },\n '*'\n );\n // Reveal iframe after theme is applied (next frame lets bridge script run)\n requestAnimationFrame(() => {\n this._iframeRef?.classList.add('ready');\n });\n }\n}\n", "import { LitElement, html, css } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { theme } from '../styles/theme.js';\nimport { showToast } from './toast-manager.js';\n\ninterface ConfigParam {\n name: string;\n envVar: string;\n type: string;\n isOptional: boolean;\n hasDefault: boolean;\n defaultValue?: any;\n}\n\ninterface UnconfiguredPhoton {\n name: string;\n configured: false;\n requiredParams: ConfigParam[];\n errorMessage?: string;\n}\n\n@customElement('photon-config')\nexport class PhotonConfig extends LitElement {\n static styles = [\n theme,\n css`\n :host {\n display: block;\n }\n\n .config-header {\n margin-bottom: var(--space-lg);\n }\n\n .config-title {\n font-size: 1.5rem;\n font-weight: 600;\n margin: 0 0 var(--space-sm) 0;\n }\n\n .config-description {\n color: var(--t-muted);\n font-size: 0.9rem;\n }\n\n .config-form {\n display: flex;\n flex-direction: column;\n gap: var(--space-md);\n }\n\n .form-group {\n display: flex;\n flex-direction: column;\n gap: var(--space-xs);\n }\n\n .form-group label {\n font-weight: 500;\n display: flex;\n align-items: center;\n gap: var(--space-sm);\n }\n\n .form-group label .required {\n color: #f87171;\n }\n\n .form-group label .hint {\n font-size: 0.75rem;\n color: var(--t-muted);\n font-family: var(--font-mono);\n background: var(--bg-glass);\n padding: 2px 6px;\n border-radius: 4px;\n }\n\n .form-group input {\n width: 100%;\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n color: var(--t-primary);\n padding: var(--space-sm) var(--space-md);\n border-radius: var(--radius-sm);\n font-family: var(--font-sans);\n font-size: 0.95rem;\n box-sizing: border-box;\n }\n\n .form-group input:focus {\n outline: none;\n border-color: var(--accent-primary);\n box-shadow: 0 0 0 2px var(--glow-primary);\n }\n\n .form-group input::placeholder {\n color: var(--t-muted);\n opacity: 0.6;\n }\n\n .toggle-switch {\n display: flex;\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n border-radius: var(--radius-sm);\n overflow: hidden;\n width: fit-content;\n }\n\n .toggle-btn {\n padding: var(--space-sm) var(--space-md);\n background: transparent;\n border: none;\n color: var(--t-muted);\n cursor: pointer;\n font-size: 0.9rem;\n transition: all 0.2s;\n }\n\n .toggle-btn.active {\n background: var(--accent-primary);\n color: white;\n }\n\n .toggle-btn:hover:not(.active) {\n background: var(--bg-glass-strong);\n }\n\n .submit-btn {\n display: flex;\n align-items: center;\n justify-content: center;\n gap: var(--space-sm);\n padding: var(--space-md);\n background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));\n border: none;\n color: white;\n font-weight: 600;\n font-size: 1rem;\n border-radius: var(--radius-sm);\n cursor: pointer;\n margin-top: var(--space-md);\n transition: all 0.2s;\n }\n\n .submit-btn:hover {\n opacity: 0.9;\n transform: translateY(-1px);\n }\n\n .submit-btn:disabled {\n opacity: 0.5;\n cursor: not-allowed;\n transform: none;\n }\n\n .submit-btn svg {\n width: 18px;\n height: 18px;\n }\n\n .error-banner {\n background: hsla(0, 70%, 50%, 0.15);\n border: 1px solid hsla(0, 70%, 50%, 0.3);\n color: #f87171;\n padding: var(--space-sm) var(--space-md);\n border-radius: var(--radius-sm);\n font-size: 0.85rem;\n margin-bottom: var(--space-md);\n }\n\n /* ===== Responsive Design ===== */\n @media (max-width: 768px) {\n .form-group input {\n min-height: 44px;\n font-size: 16px; /* Prevent iOS zoom */\n }\n\n .submit-btn {\n min-height: 44px;\n width: 100%;\n }\n\n .toggle-switch {\n width: 100%;\n }\n\n .toggle-btn {\n flex: 1;\n min-height: 44px;\n }\n }\n\n @media (max-width: 480px) {\n .config-title {\n font-size: 1.25rem;\n }\n\n .form-group label {\n flex-direction: column;\n align-items: flex-start;\n gap: var(--space-xs);\n }\n\n .form-group label .hint {\n font-size: 0.7rem;\n }\n }\n `,\n ];\n\n @property({ type: Object })\n photon: UnconfiguredPhoton | null = null;\n\n @property({ type: String })\n mode: 'initial' | 'edit' = 'initial';\n\n @state()\n private _loading = false;\n\n @state()\n private _formData: Record<string, string> = {};\n\n render() {\n if (!this.photon) return html``;\n\n const params = this.photon.requiredParams || [];\n\n return html`\n <div class=\"config-header\">\n <h2 class=\"config-title text-gradient\">${this.photon.name}</h2>\n <p class=\"config-description\">\n ${this.mode === 'edit'\n ? 'Edit configuration values. Only changed fields will be updated.'\n : this.photon.errorMessage || 'Configure this photon to enable its features'}\n </p>\n </div>\n\n ${this.mode === 'initial' && this.photon.errorMessage\n ? html` <div class=\"error-banner\">${this.photon.errorMessage}</div> `\n : ''}\n\n <form class=\"config-form\" @submit=${this._handleSubmit}>\n ${params.map((param) => this._renderField(param))}\n\n <button type=\"submit\" class=\"submit-btn\" ?disabled=${this._loading}>\n <svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\">\n <path\n d=\"M12 2v4m0 12v4M4.93 4.93l2.83 2.83m8.48 8.48l2.83 2.83M2 12h4m12 0h4M4.93 19.07l2.83-2.83m8.48-8.48l2.83-2.83\"\n />\n </svg>\n ${this._loading\n ? 'Saving...'\n : this.mode === 'edit'\n ? 'Save Changes'\n : 'Configure & Enable'}\n </button>\n </form>\n `;\n }\n\n private _renderField(param: ConfigParam) {\n const isRequired = !param.isOptional && !param.hasDefault;\n const isSecret = this._isSecretField(param.name);\n const isBoolean = param.type === 'boolean';\n const isNumber = param.type === 'number';\n const defaultValue = param.hasDefault ? String(param.defaultValue ?? '') : '';\n\n return html`\n <div class=\"form-group\">\n <label>\n ${param.name}${isRequired ? html`<span class=\"required\">*</span>` : ''}\n <span class=\"hint\">${param.envVar}</span>\n </label>\n\n ${isBoolean\n ? this._renderToggle(param, defaultValue)\n : isNumber\n ? this._renderNumberInput(param, defaultValue, isRequired)\n : this._renderTextInput(param, defaultValue, isRequired, isSecret)}\n </div>\n `;\n }\n\n private _renderToggle(param: ConfigParam, defaultValue: string) {\n const isOn = defaultValue === 'true';\n return html`\n <div class=\"toggle-switch\">\n <button\n type=\"button\"\n class=\"toggle-btn ${!isOn ? 'active' : ''}\"\n @click=${() => this._setToggle(param.envVar, false)}\n >\n Off\n </button>\n <button\n type=\"button\"\n class=\"toggle-btn ${isOn ? 'active' : ''}\"\n @click=${() => this._setToggle(param.envVar, true)}\n >\n On\n </button>\n </div>\n `;\n }\n\n private _renderNumberInput(param: ConfigParam, defaultValue: string, isRequired: boolean) {\n return html`\n <input\n type=\"number\"\n name=\"${param.envVar}\"\n .value=${this._formData[param.envVar] ?? defaultValue}\n placeholder=\"Enter ${param.name}...\"\n ?required=${isRequired}\n @input=${(e: Event) =>\n this._updateField(param.envVar, (e.target as HTMLInputElement).value)}\n />\n `;\n }\n\n private _renderTextInput(\n param: ConfigParam,\n defaultValue: string,\n isRequired: boolean,\n isSecret: boolean\n ) {\n return html`\n <input\n type=\"${isSecret ? 'password' : 'text'}\"\n name=\"${param.envVar}\"\n .value=${this._formData[param.envVar] ?? defaultValue}\n placeholder=\"Enter ${param.name}...\"\n ?required=${isRequired}\n @input=${(e: Event) =>\n this._updateField(param.envVar, (e.target as HTMLInputElement).value)}\n />\n `;\n }\n\n private _isSecretField(name: string): boolean {\n const lower = name.toLowerCase();\n return (\n lower.includes('password') ||\n lower.includes('secret') ||\n lower.includes('key') ||\n lower.includes('token')\n );\n }\n\n private _setToggle(envVar: string, value: boolean) {\n this._formData = { ...this._formData, [envVar]: String(value) };\n }\n\n private _updateField(envVar: string, value: string) {\n this._formData = { ...this._formData, [envVar]: value };\n }\n\n private _handleSubmit(e: Event) {\n e.preventDefault();\n\n if (!this.photon) return;\n\n // Collect form data\n const config: Record<string, string> = {};\n const params = this.photon.requiredParams || [];\n\n for (const param of params) {\n const value = this._formData[param.envVar];\n if (value) {\n config[param.envVar] = value;\n } else if (param.hasDefault) {\n config[param.envVar] = String(param.defaultValue ?? '');\n }\n }\n\n this._loading = true;\n showToast(`Configuring ${this.photon.name}...`, 'info');\n\n this.dispatchEvent(\n new CustomEvent('configure', {\n detail: {\n photon: this.photon.name,\n config,\n },\n bubbles: true,\n composed: true,\n })\n );\n }\n\n // Called from parent when configuration completes\n configurationComplete(success: boolean, message?: string) {\n this._loading = false;\n if (success) {\n showToast(`${this.photon?.name} configured successfully!`, 'success');\n } else {\n showToast(message || 'Configuration failed', 'error');\n }\n }\n}\n", "import { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { theme } from '../styles/theme.js';\n\nexport interface ElicitationData {\n ask: 'text' | 'password' | 'select' | 'confirm' | 'number' | 'oauth' | 'form';\n message?: string;\n placeholder?: string;\n default?: any;\n options?: ElicitationOption[];\n multi?: boolean;\n min?: number;\n max?: number;\n step?: number;\n // OAuth specific\n provider?: string;\n scopes?: string[];\n url?: string;\n elicitationUrl?: string;\n elicitationId?: string;\n // Form specific\n schema?: any;\n fields?: FormField[];\n}\n\nexport interface ElicitationOption {\n value: string;\n label: string;\n description?: string;\n image?: string;\n disabled?: boolean;\n selected?: boolean;\n}\n\nexport interface FormField {\n name: string;\n label?: string;\n type?: string;\n required?: boolean;\n default?: any;\n placeholder?: string;\n}\n\n@customElement('elicitation-modal')\nexport class ElicitationModal extends LitElement {\n static styles = [\n theme,\n css`\n :host {\n display: none;\n }\n\n :host([open]) {\n display: flex;\n position: fixed;\n inset: 0;\n background: rgba(0, 0, 0, 0.6);\n backdrop-filter: blur(4px);\n z-index: 10000;\n align-items: center;\n justify-content: center;\n }\n\n .modal-content {\n background: var(--bg-panel);\n border: 1px solid var(--border-glass);\n border-radius: var(--radius-md);\n padding: var(--space-xl);\n max-width: 500px;\n width: 90%;\n max-height: 80vh;\n overflow-y: auto;\n box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);\n }\n\n h3 {\n margin: 0 0 var(--space-lg) 0;\n font-size: 1.25rem;\n font-weight: 600;\n color: var(--t-primary);\n }\n\n .form-group {\n margin-bottom: var(--space-md);\n }\n\n label {\n display: block;\n margin-bottom: var(--space-xs);\n font-size: 0.875rem;\n color: var(--t-muted);\n }\n\n input[type='text'],\n input[type='password'],\n input[type='number'],\n textarea,\n select {\n width: 100%;\n padding: var(--space-sm) var(--space-md);\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n border-radius: var(--radius-sm);\n color: var(--t-primary);\n font-size: 1rem;\n font-family: var(--font-sans);\n box-sizing: border-box;\n }\n\n input:focus,\n textarea:focus,\n select:focus {\n outline: none;\n border-color: var(--accent-primary);\n box-shadow: 0 0 0 2px var(--glow-primary);\n }\n\n .actions {\n display: flex;\n gap: var(--space-sm);\n justify-content: flex-end;\n margin-top: var(--space-lg);\n }\n\n button {\n padding: var(--space-sm) var(--space-lg);\n border-radius: var(--radius-sm);\n font-size: 0.9rem;\n font-weight: 500;\n cursor: pointer;\n transition: all 0.2s;\n border: none;\n }\n\n .btn-primary {\n background: var(--accent-primary);\n color: white;\n }\n\n .btn-primary:hover {\n opacity: 0.9;\n }\n\n .btn-secondary {\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n color: var(--t-primary);\n }\n\n .btn-secondary:hover {\n background: var(--bg-glass-strong);\n }\n\n .btn-success {\n background: #22c55e;\n color: white;\n }\n\n .btn-danger {\n background: #ef4444;\n color: white;\n }\n\n /* Confirm buttons */\n .confirm-actions {\n display: flex;\n gap: var(--space-md);\n }\n\n .confirm-actions button {\n flex: 1;\n }\n\n /* Select options */\n .select-options {\n display: flex;\n flex-direction: column;\n gap: var(--space-sm);\n max-height: 300px;\n overflow-y: auto;\n }\n\n .select-option {\n display: flex;\n align-items: center;\n gap: var(--space-md);\n padding: var(--space-md);\n background: var(--bg-glass);\n border: 1px solid var(--border-glass);\n border-radius: var(--radius-sm);\n cursor: pointer;\n transition: all 0.2s;\n }\n\n .select-option:hover {\n background: var(--bg-glass-strong);\n border-color: var(--accent-primary);\n }\n\n .select-option.selected {\n border-color: var(--accent-primary);\n background: var(--glow-primary);\n }\n\n .select-option.disabled {\n opacity: 0.5;\n cursor: not-allowed;\n }\n\n .select-option input[type='radio'],\n .select-option input[type='checkbox'] {\n width: 18px;\n height: 18px;\n flex-shrink: 0;\n }\n\n .option-content {\n flex: 1;\n min-width: 0;\n }\n\n .option-label {\n font-weight: 500;\n color: var(--t-primary);\n }\n\n .option-description {\n font-size: 0.85rem;\n color: var(--t-muted);\n margin-top: 2px;\n }\n\n .option-image {\n width: 48px;\n height: 48px;\n object-fit: cover;\n border-radius: var(--radius-sm);\n flex-shrink: 0;\n }\n\n /* OAuth */\n .oauth-content {\n text-align: center;\n }\n\n .oauth-icon {\n font-size: 3rem;\n margin-bottom: var(--space-md);\n }\n\n .oauth-message {\n color: var(--t-muted);\n margin-bottom: var(--space-lg);\n }\n\n .oauth-scopes {\n font-size: 0.85rem;\n color: var(--t-muted);\n margin-bottom: var(--space-lg);\n }\n\n /* Form fields */\n .form-fields {\n display: flex;\n flex-direction: column;\n gap: var(--space-md);\n }\n\n /* ===== Responsive Design ===== */\n @media (max-width: 768px) {\n .modal-content {\n padding: var(--space-lg);\n margin: var(--space-md);\n }\n\n input[type='text'],\n input[type='password'],\n input[type='number'],\n textarea,\n select {\n min-height: 44px;\n font-size: 16px; /* Prevent iOS zoom */\n }\n\n button {\n min-height: 44px;\n }\n\n .actions {\n flex-direction: column;\n }\n\n .actions button {\n width: 100%;\n }\n\n .confirm-actions {\n flex-direction: column;\n }\n\n .confirm-actions button {\n flex: none;\n width: 100%;\n }\n\n .select-options {\n max-height: 250px;\n }\n\n .select-option {\n padding: var(--space-md);\n }\n }\n\n @media (max-width: 480px) {\n .modal-content {\n padding: var(--space-md);\n border-radius: var(--radius-sm);\n max-height: 95vh;\n }\n\n h3 {\n font-size: 1.1rem;\n }\n\n .oauth-icon {\n font-size: 2.5rem;\n }\n\n .option-image {\n width: 40px;\n height: 40px;\n }\n }\n `,\n ];\n\n @property({ type: Boolean, reflect: true }) open = false;\n @property({ type: Object }) data: ElicitationData | null = null;\n\n @state() private _inputValue: any = '';\n @state() private _selectedValues: string[] = [];\n @state() private _formValues: Record<string, any> = {};\n\n private _oauthPopup: Window | null = null;\n\n updated(changedProperties: Map<string, any>) {\n if (changedProperties.has('data') && this.data) {\n this._resetState();\n }\n }\n\n private _resetState() {\n if (!this.data) return;\n\n this._inputValue = this.data.default ?? '';\n this._selectedValues = [];\n this._formValues = {};\n\n // Pre-select options if specified\n if (this.data.options) {\n this._selectedValues = this.data.options\n .filter((opt) => opt.selected)\n .map((opt) => opt.value);\n }\n\n // Initialize form values\n if (this.data.fields) {\n this.data.fields.forEach((field) => {\n this._formValues[field.name] = field.default ?? '';\n });\n }\n }\n\n render() {\n if (!this.data) return nothing;\n\n return html`\n <div class=\"modal-content\" @click=${(e: Event) => e.stopPropagation()}>\n <h3>${this.data.message || 'Input Required'}</h3>\n ${this._renderContent()}\n </div>\n `;\n }\n\n private _renderContent() {\n if (!this.data) return nothing;\n\n switch (this.data.ask) {\n case 'text':\n case 'password':\n return this._renderTextInput();\n case 'number':\n return this._renderNumberInput();\n case 'select':\n return this._renderSelect();\n case 'confirm':\n return this._renderConfirm();\n case 'oauth':\n return this._renderOAuth();\n case 'form':\n return this._renderForm();\n default:\n return html`<p>Unknown elicitation type: ${this.data.ask}</p>`;\n }\n }\n\n private _renderTextInput() {\n const type = this.data?.ask === 'password' ? 'password' : 'text';\n return html`\n <div class=\"form-group\">\n <input\n type=${type}\n .value=${this._inputValue}\n placeholder=${this.data?.placeholder || ''}\n @input=${(e: Event) => (this._inputValue = (e.target as HTMLInputElement).value)}\n @keydown=${this._handleKeydown}\n autofocus\n />\n </div>\n <div class=\"actions\">\n <button class=\"btn-secondary\" @click=${this._cancel}>Cancel</button>\n <button class=\"btn-primary\" @click=${this._submit}>Submit</button>\n </div>\n `;\n }\n\n private _renderNumberInput() {\n return html`\n <div class=\"form-group\">\n <input\n type=\"number\"\n .value=${String(this._inputValue)}\n min=${this.data?.min ?? nothing}\n max=${this.data?.max ?? nothing}\n step=${this.data?.step ?? nothing}\n @input=${(e: Event) => (this._inputValue = Number((e.target as HTMLInputElement).value))}\n @keydown=${this._handleKeydown}\n autofocus\n />\n </div>\n <div class=\"actions\">\n <button class=\"btn-secondary\" @click=${this._cancel}>Cancel</button>\n <button class=\"btn-primary\" @click=${this._submit}>Submit</button>\n </div>\n `;\n }\n\n private _renderSelect() {\n const options = this.data?.options || [];\n const isMulti = this.data?.multi === true;\n\n if (options.length <= 5 && !options.some((o) => o.image || o.description)) {\n // Simple dropdown for small option sets\n return html`\n <div class=\"form-group\">\n <select\n @change=${(e: Event) => (this._inputValue = (e.target as HTMLSelectElement).value)}\n >\n ${options.map(\n (opt) => html`\n <option value=${opt.value} ?selected=${opt.selected}>${opt.label}</option>\n `\n )}\n </select>\n </div>\n <div class=\"actions\">\n <button class=\"btn-secondary\" @click=${this._cancel}>Cancel</button>\n <button class=\"btn-primary\" @click=${this._submit}>Submit</button>\n </div>\n `;\n }\n\n // Rich select with cards\n return html`\n <div class=\"select-options\">\n ${options.map(\n (opt) => html`\n <label\n class=\"select-option ${opt.disabled ? 'disabled' : ''} ${this._isSelected(opt.value)\n ? 'selected'\n : ''}\"\n >\n <input\n type=${isMulti ? 'checkbox' : 'radio'}\n name=\"select-option\"\n .value=${opt.value}\n .checked=${this._isSelected(opt.value)}\n ?disabled=${opt.disabled}\n @change=${() => this._toggleOption(opt.value, isMulti)}\n />\n ${opt.image\n ? html`<img class=\"option-image\" src=${opt.image} alt=${opt.label} />`\n : nothing}\n <div class=\"option-content\">\n <div class=\"option-label\">${opt.label}</div>\n ${opt.description\n ? html`<div class=\"option-description\">${opt.description}</div>`\n : nothing}\n </div>\n </label>\n `\n )}\n </div>\n <div class=\"actions\">\n <button class=\"btn-secondary\" @click=${this._cancel}>Cancel</button>\n <button class=\"btn-primary\" @click=${this._submitSelect}>Submit</button>\n </div>\n `;\n }\n\n private _isSelected(value: string): boolean {\n return this._selectedValues.includes(value);\n }\n\n private _toggleOption(value: string, isMulti: boolean) {\n if (isMulti) {\n if (this._selectedValues.includes(value)) {\n this._selectedValues = this._selectedValues.filter((v) => v !== value);\n } else {\n this._selectedValues = [...this._selectedValues, value];\n }\n } else {\n this._selectedValues = [value];\n }\n this.requestUpdate();\n }\n\n private _renderConfirm() {\n return html`\n <div class=\"confirm-actions\">\n <button class=\"btn-danger\" @click=${() => this._submitValue(false)}>No</button>\n <button class=\"btn-success\" @click=${() => this._submitValue(true)}>Yes</button>\n </div>\n `;\n }\n\n private _renderOAuth() {\n const providerIcons: Record<string, string> = {\n google: '\uD83D\uDD35',\n github: '\u26AB',\n microsoft: '\uD83D\uDFE6',\n slack: '\uD83D\uDC9C',\n notion: '\u2B1B',\n default: '\uD83D\uDD10',\n };\n const provider = this.data?.provider || 'OAuth';\n const icon = providerIcons[provider.toLowerCase()] || providerIcons.default;\n const scopes = (this.data?.scopes || []).join(', ') || 'basic access';\n\n return html`\n <div class=\"oauth-content\">\n <div class=\"oauth-icon\">${icon}</div>\n <p class=\"oauth-message\">Authorization is required to access ${provider}.</p>\n <p class=\"oauth-scopes\">Requested permissions: ${scopes}</p>\n <div class=\"actions\" style=\"justify-content: center;\">\n <button class=\"btn-secondary\" @click=${this._cancel}>Cancel</button>\n <button class=\"btn-primary\" @click=${this._startOAuth}>Authorize ${provider}</button>\n </div>\n </div>\n `;\n }\n\n private _renderForm() {\n const fields = this.data?.fields || [];\n\n return html`\n <div class=\"form-fields\">\n ${fields.map(\n (field) => html`\n <div class=\"form-group\">\n <label>${field.label || field.name}${field.required ? ' *' : ''}</label>\n ${this._renderFormField(field)}\n </div>\n `\n )}\n </div>\n <div class=\"actions\">\n <button class=\"btn-secondary\" @click=${this._cancel}>Cancel</button>\n <button class=\"btn-primary\" @click=${this._submitForm}>Submit</button>\n </div>\n `;\n }\n\n private _renderFormField(field: FormField) {\n const type = field.type || 'text';\n const value = this._formValues[field.name] ?? '';\n\n if (type === 'textarea') {\n return html`\n <textarea\n rows=\"3\"\n .value=${value}\n placeholder=${field.placeholder || ''}\n @input=${(e: Event) =>\n this._updateFormValue(field.name, (e.target as HTMLTextAreaElement).value)}\n ></textarea>\n `;\n }\n\n return html`\n <input\n type=${type}\n .value=${value}\n placeholder=${field.placeholder || ''}\n ?required=${field.required}\n @input=${(e: Event) =>\n this._updateFormValue(field.name, (e.target as HTMLInputElement).value)}\n />\n `;\n }\n\n private _updateFormValue(name: string, value: any) {\n this._formValues = { ...this._formValues, [name]: value };\n }\n\n private _handleKeydown(e: KeyboardEvent) {\n if (e.key === 'Enter') {\n this._submit();\n } else if (e.key === 'Escape') {\n this._cancel();\n }\n }\n\n private _submit() {\n this._submitValue(this._inputValue);\n }\n\n private _submitSelect() {\n const value = this.data?.multi ? this._selectedValues : this._selectedValues[0];\n this._submitValue(value);\n }\n\n private _submitForm() {\n this._submitValue(this._formValues);\n }\n\n private _submitValue(value: any) {\n this.dispatchEvent(\n new CustomEvent('submit', {\n detail: { value },\n bubbles: true,\n composed: true,\n })\n );\n this.open = false;\n }\n\n private _cancel() {\n this.dispatchEvent(\n new CustomEvent('cancel', {\n bubbles: true,\n composed: true,\n })\n );\n this.open = false;\n }\n\n private _startOAuth() {\n const url = this.data?.url || this.data?.elicitationUrl;\n if (!url) {\n console.error('No OAuth URL provided');\n return;\n }\n\n // Open OAuth popup\n const width = 600;\n const height = 700;\n const left = window.screenX + (window.outerWidth - width) / 2;\n const top = window.screenY + (window.outerHeight - height) / 2;\n\n this._oauthPopup = window.open(\n url,\n 'oauth_popup',\n `width=${width},height=${height},left=${left},top=${top},toolbar=no,menubar=no`\n );\n\n // Listen for OAuth completion\n const checkClosed = setInterval(() => {\n if (this._oauthPopup?.closed) {\n clearInterval(checkClosed);\n // Assume success when popup closes\n this.dispatchEvent(\n new CustomEvent('oauth-complete', {\n detail: {\n elicitationId: this.data?.elicitationId,\n success: true,\n },\n bubbles: true,\n composed: true,\n })\n );\n this.open = false;\n }\n }, 500);\n }\n}\n", "import './components/beam-app.js';\nimport './components/beam-sidebar.js';\nimport './components/method-card.js';\nimport './components/invoke-form.js';\nimport './components/activity-log.js';\nimport './components/result-viewer.js';\nimport './components/file-picker.js';\nimport './components/marketplace-view.js';\nimport './components/custom-ui-renderer.js';\nimport './components/toast-manager.js';\nimport './components/photon-config.js';\nimport './components/elicitation-modal.js';\n\nconsole.log('\u2728 Beam UI Initialized');\n"],
5
+ "mappings": "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AAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;A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A;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAA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A;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAA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AAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;A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",
6
+ "names": ["global", "globalThis", "supportsAdoptingStyleSheets", "ShadowRoot", "ShadyCSS", "nativeShadow", "Document", "prototype", "CSSStyleSheet", "constructionToken", "Symbol", "cssTagCache", "WeakMap", "CSSResult", "cssText", "strings", "safeToken", "this", "Error", "_strings", "styleSheet", "_styleSheet", "cacheable", "length", "get", "replaceSync", "set", "toString", "unsafeCSS", "value", "String", "css", "values", "reduce", "acc", "v", "idx", "adoptStyles", "renderRoot", "styles", "adoptedStyleSheets", "map", "s", "style", "document", "createElement", "nonce", "setAttribute", "textContent", "appendChild", "getCompatibleStyle", "sheet", "rule", "cssRules", "is", "defineProperty", "getOwnPropertyDescriptor", "getOwnPropertyNames", "getOwnPropertySymbols", "getPrototypeOf", "Object", "global", "globalThis", "trustedTypes", "emptyStringForBooleanAttribute", "emptyScript", "polyfillSupport", "reactiveElementPolyfillSupport", "JSCompiler_renameProperty", "prop", "_obj", "defaultConverter", "value", "type", "Boolean", "Array", "JSON", "stringify", "fromValue", "Number", "parse", "e", "notEqual", "old", "defaultPropertyDeclaration", "attribute", "String", "converter", "reflect", "useDefault", "hasChanged", "Symbol", "metadata", "litPropertyMetadata", "WeakMap", "ReactiveElement", "HTMLElement", "initializer", "this", "__prepare", "_initializers", "push", "observedAttributes", "finalize", "__attributeToPropertyMap", "keys", "name", "options", "state", "prototype", "hasOwnProperty", "create", "wrapped", "elementProperties", "set", "noAccessor", "key", "descriptor", "getPropertyDescriptor", "get", "v", "oldValue", "call", "requestUpdate", "configurable", "enumerable", "superCtor", "Map", "finalized", "props", "properties", "propKeys", "p", "createProperty", "attr", "__attributeNameForProperty", "elementStyles", "finalizeStyles", "styles", "isArray", "Set", "flat", "Infinity", "reverse", "s", "unshift", "getCompatibleStyle", "toLowerCase", "constructor", "super", "__instanceProperties", "isUpdatePending", "hasUpdated", "__reflectingProperty", "__initialize", "__updatePromise", "Promise", "res", "enableUpdating", "_$changedProperties", "__saveInstanceProperties", "forEach", "i", "controller", "__controllers", "add", "renderRoot", "isConnected", "hostConnected", "delete", "instanceProperties", "size", "createRenderRoot", "shadowRoot", "attachShadow", "shadowRootOptions", "adoptStyles", "connectedCallback", "c", "_requestedUpdate", "disconnectedCallback", "hostDisconnected", "_old", "_$attributeToProperty", "attrValue", "toAttribute", "removeAttribute", "setAttribute", "ctor", "propName", "getPropertyOptions", "fromAttribute", "convertedValue", "__defaultValues", "useNewValue", "newValue", "hasAttribute", "_$changeProperty", "__enqueueUpdate", "initializeValue", "has", "__reflectingProperties", "reject", "result", "scheduleUpdate", "performUpdate", "shouldUpdate", "changedProperties", "willUpdate", "hostUpdate", "update", "__markUpdated", "_$didUpdate", "_changedProperties", "hostUpdated", "firstUpdated", "updated", "updateComplete", "getUpdateComplete", "__propertyToAttribute", "mode", "reactiveElementVersions", "global", "globalThis", "wrap", "node", "trustedTypes", "policy", "createPolicy", "createHTML", "s", "boundAttributeSuffix", "marker", "Math", "random", "toFixed", "slice", "markerMatch", "nodeMarker", "d", "document", "createMarker", "createComment", "isPrimitive", "value", "isArray", "Array", "isIterable", "Symbol", "iterator", "SPACE_CHAR", "textEndRegex", "commentEndRegex", "comment2EndRegex", "tagEndRegex", "RegExp", "singleQuoteAttrEndRegex", "doubleQuoteAttrEndRegex", "rawTextElement", "tag", "type", "strings", "values", "_$litType$", "html", "svg", "mathml", "noChange", "for", "nothing", "templateCache", "WeakMap", "walker", "createTreeWalker", "trustFromTemplateString", "tsa", "stringFromTSA", "hasOwnProperty", "Error", "getTemplateHtml", "l", "length", "attrNames", "rawTextEndRegex", "regex", "i", "attrName", "match", "attrNameEndIndex", "lastIndex", "exec", "test", "end", "startsWith", "push", "Template", "constructor", "options", "this", "parts", "nodeIndex", "attrNameIndex", "partCount", "el", "createElement", "currentNode", "content", "wrapper", "firstChild", "replaceWith", "childNodes", "nextNode", "nodeType", "hasAttributes", "name", "getAttributeNames", "endsWith", "realName", "statics", "getAttribute", "split", "m", "index", "ctor", "PropertyPart", "BooleanAttributePart", "EventPart", "AttributePart", "removeAttribute", "tagName", "textContent", "emptyScript", "append", "data", "indexOf", "_options", "innerHTML", "resolveDirective", "part", "parent", "attributeIndex", "currentDirective", "__directives", "__directive", "nextDirectiveConstructor", "_$initialize", "_$resolve", "TemplateInstance", "template", "_$parts", "_$disconnectableChildren", "_$template", "_$parent", "parentNode", "_$isConnected", "fragment", "creationScope", "importNode", "partIndex", "templatePart", "ChildPart", "nextSibling", "ElementPart", "_$setValue", "__isConnected", "startNode", "endNode", "_$committedValue", "_$startNode", "_$endNode", "isConnected", "directiveParent", "_$clear", "_commitText", "_commitTemplateResult", "_commitNode", "_commitIterable", "insertBefore", "_insert", "createTextNode", "result", "_$getTemplate", "h", "_update", "instance", "_clone", "get", "set", "itemParts", "itemPart", "item", "start", "from", "_$notifyConnectionChanged", "n", "remove", "element", "fill", "String", "valueIndex", "noCommit", "change", "v", "_commitValue", "setAttribute", "toggleAttribute", "super", "newListener", "oldListener", "shouldRemoveListener", "capture", "once", "passive", "shouldAddListener", "removeEventListener", "addEventListener", "event", "call", "host", "handleEvent", "polyfillSupport", "global", "litHtmlPolyfillSupport", "Template", "ChildPart", "litHtmlVersions", "push", "render", "value", "container", "options", "partOwnerNode", "renderBefore", "part", "endNode", "insertBefore", "createMarker", "_$setValue", "global", "globalThis", "LitElement", "ReactiveElement", "constructor", "this", "renderOptions", "host", "__childPart", "createRenderRoot", "renderRoot", "super", "renderBefore", "firstChild", "changedProperties", "value", "render", "hasUpdated", "isConnected", "update", "connectedCallback", "setConnected", "disconnectedCallback", "noChange", "litElementHydrateSupport", "polyfillSupport", "litElementPolyfillSupport", "global", "litElementVersions", "push", "PartType", "ATTRIBUTE", "CHILD", "PROPERTY", "BOOLEAN_ATTRIBUTE", "EVENT", "ELEMENT", "directive", "c", "values", "_$litDirective$", "Directive", "_partInfo", "_$isConnected", "this", "_$parent", "part", "parent", "attributeIndex", "__part", "__attributeIndex", "props", "update", "_part", "render", "UnsafeHTMLDirective", "Directive", "partInfo", "super", "this", "_value", "nothing", "type", "PartType", "CHILD", "Error", "constructor", "directiveName", "value", "_templateResult", "noChange", "strings", "raw", "_$litType$", "resultType", "values", "unsafeHTML", "directive", "customElement", "tagName", "classOrTarget", "context", "addInitializer", "customElements", "define", "defaultPropertyDeclaration", "attribute", "type", "String", "converter", "defaultConverter", "reflect", "hasChanged", "notEqual", "standardProperty", "options", "target", "context", "kind", "metadata", "properties", "globalThis", "litPropertyMetadata", "get", "set", "Map", "Object", "create", "wrapped", "name", "v", "oldValue", "call", "this", "requestUpdate", "_$changeProperty", "value", "Error", "property", "protoOrTarget", "nameOrContext", "proto", "hasOwnProperty", "constructor", "createProperty", "getOwnPropertyDescriptor", "undefined", "state", "options", "property", "attribute", "desc", "obj", "name", "descriptor", "configurable", "enumerable", "Reflect", "decorate", "Object", "defineProperty", "query", "selector", "cache", "protoOrTarget", "nameOrContext", "descriptor", "doQuery", "el", "renderRoot", "querySelector", "get", "set", "key", "Symbol", "this", "v", "desc", "result", "call", "hasUpdated", "i", "duration", "t", "b", "r", "theme", "c", "m", "i", "e", "p", "m", "r", "u", "c", "prompt", "v", "duration", "b", "d", "t", "o", "i", "e", "p", "b", "theme", "n", "r", "t", "i", "e", "b", "n", "r", "t", "i", "e", "b", "v", "n", "r", "t", "i", "b", "n", "t", "i", "e", "b", "o", "v", "k", "f", "a", "_", "w", "str", "n", "r", "t", "i", "b", "e", "f", "n", "r", "t", "i", "b", "s", "e", "r", "t", "i", "e", "b", "n", "r", "t", "i", "b", "e", "n", "r", "t", "i", "b", "e", "o", "v", "n", "r", "t"]
7
+ }