@frontmcp/ui 0.5.0 → 0.6.0

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 (1134) hide show
  1. package/adapters/index.d.ts +13 -0
  2. package/adapters/index.d.ts.map +1 -0
  3. package/adapters/index.js +462 -0
  4. package/adapters/platform-meta.d.ts +166 -0
  5. package/adapters/platform-meta.d.ts.map +1 -0
  6. package/adapters/response-builder.d.ts +108 -0
  7. package/adapters/response-builder.d.ts.map +1 -0
  8. package/adapters/serving-mode.d.ts +107 -0
  9. package/adapters/serving-mode.d.ts.map +1 -0
  10. package/base-template/bridge.d.ts +90 -0
  11. package/base-template/bridge.d.ts.map +1 -0
  12. package/base-template/default-base-template.d.ts +92 -0
  13. package/base-template/default-base-template.d.ts.map +1 -0
  14. package/base-template/index.d.ts +15 -0
  15. package/base-template/index.d.ts.map +1 -0
  16. package/base-template/index.js +1398 -0
  17. package/base-template/polyfills.d.ts +31 -0
  18. package/base-template/polyfills.d.ts.map +1 -0
  19. package/base-template/theme-styles.d.ts +74 -0
  20. package/base-template/theme-styles.d.ts.map +1 -0
  21. package/bridge/adapters/base-adapter.d.ts +104 -0
  22. package/bridge/adapters/base-adapter.d.ts.map +1 -0
  23. package/bridge/adapters/claude.adapter.d.ts +67 -0
  24. package/bridge/adapters/claude.adapter.d.ts.map +1 -0
  25. package/bridge/adapters/ext-apps.adapter.d.ts +143 -0
  26. package/bridge/adapters/ext-apps.adapter.d.ts.map +1 -0
  27. package/bridge/adapters/gemini.adapter.d.ts +64 -0
  28. package/bridge/adapters/gemini.adapter.d.ts.map +1 -0
  29. package/bridge/adapters/generic.adapter.d.ts +56 -0
  30. package/bridge/adapters/generic.adapter.d.ts.map +1 -0
  31. package/bridge/adapters/index.d.ts +26 -0
  32. package/bridge/adapters/index.d.ts.map +1 -0
  33. package/bridge/adapters/openai.adapter.d.ts +65 -0
  34. package/bridge/adapters/openai.adapter.d.ts.map +1 -0
  35. package/bridge/core/adapter-registry.d.ts +122 -0
  36. package/bridge/core/adapter-registry.d.ts.map +1 -0
  37. package/bridge/core/bridge-factory.d.ts +199 -0
  38. package/bridge/core/bridge-factory.d.ts.map +1 -0
  39. package/bridge/core/index.d.ts +10 -0
  40. package/bridge/core/index.d.ts.map +1 -0
  41. package/bridge/index.d.ts +62 -0
  42. package/bridge/index.d.ts.map +1 -0
  43. package/bridge/index.js +2540 -0
  44. package/bridge/runtime/iife-generator.d.ts +62 -0
  45. package/bridge/runtime/iife-generator.d.ts.map +1 -0
  46. package/bridge/runtime/index.d.ts +9 -0
  47. package/bridge/runtime/index.d.ts.map +1 -0
  48. package/bridge/types.d.ts +386 -0
  49. package/bridge/types.d.ts.map +1 -0
  50. package/build/cdn-resources.d.ts +243 -0
  51. package/build/cdn-resources.d.ts.map +1 -0
  52. package/build/index.d.ts +295 -0
  53. package/build/index.d.ts.map +1 -0
  54. package/build/index.js +7096 -0
  55. package/build/widget-manifest.d.ts +362 -0
  56. package/build/widget-manifest.d.ts.map +1 -0
  57. package/bundler/bundler.d.ts +208 -0
  58. package/bundler/bundler.d.ts.map +1 -0
  59. package/bundler/cache.d.ts +173 -0
  60. package/bundler/cache.d.ts.map +1 -0
  61. package/bundler/file-cache/component-builder.d.ts +167 -0
  62. package/bundler/file-cache/component-builder.d.ts.map +1 -0
  63. package/bundler/file-cache/hash-calculator.d.ts +155 -0
  64. package/bundler/file-cache/hash-calculator.d.ts.map +1 -0
  65. package/bundler/file-cache/index.d.ts +12 -0
  66. package/bundler/file-cache/index.d.ts.map +1 -0
  67. package/bundler/file-cache/storage/filesystem.d.ts +149 -0
  68. package/bundler/file-cache/storage/filesystem.d.ts.map +1 -0
  69. package/bundler/file-cache/storage/index.d.ts +11 -0
  70. package/bundler/file-cache/storage/index.d.ts.map +1 -0
  71. package/bundler/file-cache/storage/interface.d.ts +152 -0
  72. package/bundler/file-cache/storage/interface.d.ts.map +1 -0
  73. package/bundler/file-cache/storage/redis.d.ts +139 -0
  74. package/bundler/file-cache/storage/redis.d.ts.map +1 -0
  75. package/bundler/index.d.ts +43 -0
  76. package/bundler/index.d.ts.map +1 -0
  77. package/bundler/index.js +4754 -0
  78. package/bundler/sandbox/enclave-adapter.d.ts +121 -0
  79. package/bundler/sandbox/enclave-adapter.d.ts.map +1 -0
  80. package/bundler/sandbox/executor.d.ts +14 -0
  81. package/bundler/sandbox/executor.d.ts.map +1 -0
  82. package/bundler/sandbox/policy.d.ts +62 -0
  83. package/bundler/sandbox/policy.d.ts.map +1 -0
  84. package/bundler/types.d.ts +702 -0
  85. package/bundler/types.d.ts.map +1 -0
  86. package/components/alert.d.ts +66 -0
  87. package/components/alert.d.ts.map +1 -0
  88. package/components/alert.schema.d.ts +98 -0
  89. package/components/alert.schema.d.ts.map +1 -0
  90. package/components/avatar.d.ts +77 -0
  91. package/components/avatar.d.ts.map +1 -0
  92. package/components/avatar.schema.d.ts +170 -0
  93. package/components/avatar.schema.d.ts.map +1 -0
  94. package/components/badge.d.ts +64 -0
  95. package/components/badge.d.ts.map +1 -0
  96. package/components/badge.schema.d.ts +91 -0
  97. package/components/badge.schema.d.ts.map +1 -0
  98. package/components/button.d.ts +100 -0
  99. package/components/button.d.ts.map +1 -0
  100. package/components/button.schema.d.ts +120 -0
  101. package/components/button.schema.d.ts.map +1 -0
  102. package/components/card.d.ts +53 -0
  103. package/components/card.d.ts.map +1 -0
  104. package/components/card.schema.d.ts +93 -0
  105. package/components/card.schema.d.ts.map +1 -0
  106. package/components/form.d.ts +212 -0
  107. package/components/form.d.ts.map +1 -0
  108. package/components/form.schema.d.ts +365 -0
  109. package/components/form.schema.d.ts.map +1 -0
  110. package/components/index.d.ts +29 -0
  111. package/components/index.d.ts.map +1 -0
  112. package/components/index.js +2595 -0
  113. package/components/list.d.ts +121 -0
  114. package/components/list.d.ts.map +1 -0
  115. package/components/list.schema.d.ts +129 -0
  116. package/components/list.schema.d.ts.map +1 -0
  117. package/components/modal.d.ts +100 -0
  118. package/components/modal.d.ts.map +1 -0
  119. package/components/modal.schema.d.ts +151 -0
  120. package/components/modal.schema.d.ts.map +1 -0
  121. package/components/table.d.ts +91 -0
  122. package/components/table.d.ts.map +1 -0
  123. package/components/table.schema.d.ts +123 -0
  124. package/components/table.schema.d.ts.map +1 -0
  125. package/dependency/cdn-registry.d.ts +98 -0
  126. package/dependency/cdn-registry.d.ts.map +1 -0
  127. package/dependency/import-map.d.ts +186 -0
  128. package/dependency/import-map.d.ts.map +1 -0
  129. package/dependency/import-parser.d.ts +82 -0
  130. package/dependency/import-parser.d.ts.map +1 -0
  131. package/dependency/index.d.ts +17 -0
  132. package/dependency/index.d.ts.map +1 -0
  133. package/dependency/resolver.d.ts +164 -0
  134. package/dependency/resolver.d.ts.map +1 -0
  135. package/dependency/schemas.d.ts +486 -0
  136. package/dependency/schemas.d.ts.map +1 -0
  137. package/dependency/template-loader.d.ts +204 -0
  138. package/dependency/template-loader.d.ts.map +1 -0
  139. package/dependency/template-processor.d.ts +118 -0
  140. package/dependency/template-processor.d.ts.map +1 -0
  141. package/dependency/types.d.ts +739 -0
  142. package/dependency/types.d.ts.map +1 -0
  143. package/esm/adapters/index.d.ts +13 -0
  144. package/esm/adapters/index.d.ts.map +1 -0
  145. package/esm/adapters/index.js +427 -0
  146. package/esm/adapters/platform-meta.d.ts +166 -0
  147. package/esm/adapters/platform-meta.d.ts.map +1 -0
  148. package/esm/adapters/response-builder.d.ts +108 -0
  149. package/esm/adapters/response-builder.d.ts.map +1 -0
  150. package/esm/adapters/serving-mode.d.ts +107 -0
  151. package/esm/adapters/serving-mode.d.ts.map +1 -0
  152. package/esm/base-template/bridge.d.ts +90 -0
  153. package/esm/base-template/bridge.d.ts.map +1 -0
  154. package/esm/base-template/default-base-template.d.ts +92 -0
  155. package/esm/base-template/default-base-template.d.ts.map +1 -0
  156. package/esm/base-template/index.d.ts +15 -0
  157. package/esm/base-template/index.d.ts.map +1 -0
  158. package/esm/base-template/index.js +1364 -0
  159. package/esm/base-template/polyfills.d.ts +31 -0
  160. package/esm/base-template/polyfills.d.ts.map +1 -0
  161. package/esm/base-template/theme-styles.d.ts +74 -0
  162. package/esm/base-template/theme-styles.d.ts.map +1 -0
  163. package/esm/bridge/adapters/base-adapter.d.ts +104 -0
  164. package/esm/bridge/adapters/base-adapter.d.ts.map +1 -0
  165. package/esm/bridge/adapters/claude.adapter.d.ts +67 -0
  166. package/esm/bridge/adapters/claude.adapter.d.ts.map +1 -0
  167. package/esm/bridge/adapters/ext-apps.adapter.d.ts +143 -0
  168. package/esm/bridge/adapters/ext-apps.adapter.d.ts.map +1 -0
  169. package/esm/bridge/adapters/gemini.adapter.d.ts +64 -0
  170. package/esm/bridge/adapters/gemini.adapter.d.ts.map +1 -0
  171. package/esm/bridge/adapters/generic.adapter.d.ts +56 -0
  172. package/esm/bridge/adapters/generic.adapter.d.ts.map +1 -0
  173. package/esm/bridge/adapters/index.d.ts +26 -0
  174. package/esm/bridge/adapters/index.d.ts.map +1 -0
  175. package/esm/bridge/adapters/openai.adapter.d.ts +65 -0
  176. package/esm/bridge/adapters/openai.adapter.d.ts.map +1 -0
  177. package/esm/bridge/core/adapter-registry.d.ts +122 -0
  178. package/esm/bridge/core/adapter-registry.d.ts.map +1 -0
  179. package/esm/bridge/core/bridge-factory.d.ts +199 -0
  180. package/esm/bridge/core/bridge-factory.d.ts.map +1 -0
  181. package/esm/bridge/core/index.d.ts +10 -0
  182. package/esm/bridge/core/index.d.ts.map +1 -0
  183. package/esm/bridge/index.d.ts +62 -0
  184. package/esm/bridge/index.d.ts.map +1 -0
  185. package/esm/bridge/index.js +2487 -0
  186. package/esm/bridge/runtime/iife-generator.d.ts +62 -0
  187. package/esm/bridge/runtime/iife-generator.d.ts.map +1 -0
  188. package/esm/bridge/runtime/index.d.ts +9 -0
  189. package/esm/bridge/runtime/index.d.ts.map +1 -0
  190. package/esm/bridge/types.d.ts +386 -0
  191. package/esm/bridge/types.d.ts.map +1 -0
  192. package/esm/build/cdn-resources.d.ts +243 -0
  193. package/esm/build/cdn-resources.d.ts.map +1 -0
  194. package/esm/build/index.d.ts +295 -0
  195. package/esm/build/index.d.ts.map +1 -0
  196. package/esm/build/index.js +7021 -0
  197. package/esm/build/widget-manifest.d.ts +362 -0
  198. package/esm/build/widget-manifest.d.ts.map +1 -0
  199. package/esm/bundler/bundler.d.ts +208 -0
  200. package/esm/bundler/bundler.d.ts.map +1 -0
  201. package/esm/bundler/cache.d.ts +173 -0
  202. package/esm/bundler/cache.d.ts.map +1 -0
  203. package/esm/bundler/file-cache/component-builder.d.ts +167 -0
  204. package/esm/bundler/file-cache/component-builder.d.ts.map +1 -0
  205. package/esm/bundler/file-cache/hash-calculator.d.ts +155 -0
  206. package/esm/bundler/file-cache/hash-calculator.d.ts.map +1 -0
  207. package/esm/bundler/file-cache/index.d.ts +12 -0
  208. package/esm/bundler/file-cache/index.d.ts.map +1 -0
  209. package/esm/bundler/file-cache/storage/filesystem.d.ts +149 -0
  210. package/esm/bundler/file-cache/storage/filesystem.d.ts.map +1 -0
  211. package/esm/bundler/file-cache/storage/index.d.ts +11 -0
  212. package/esm/bundler/file-cache/storage/index.d.ts.map +1 -0
  213. package/esm/bundler/file-cache/storage/interface.d.ts +152 -0
  214. package/esm/bundler/file-cache/storage/interface.d.ts.map +1 -0
  215. package/esm/bundler/file-cache/storage/redis.d.ts +139 -0
  216. package/esm/bundler/file-cache/storage/redis.d.ts.map +1 -0
  217. package/esm/bundler/index.d.ts +43 -0
  218. package/esm/bundler/index.d.ts.map +1 -0
  219. package/esm/bundler/index.js +4687 -0
  220. package/esm/bundler/sandbox/enclave-adapter.d.ts +121 -0
  221. package/esm/bundler/sandbox/enclave-adapter.d.ts.map +1 -0
  222. package/esm/bundler/sandbox/executor.d.ts +14 -0
  223. package/esm/bundler/sandbox/executor.d.ts.map +1 -0
  224. package/esm/bundler/sandbox/policy.d.ts +62 -0
  225. package/esm/bundler/sandbox/policy.d.ts.map +1 -0
  226. package/esm/bundler/types.d.ts +702 -0
  227. package/esm/bundler/types.d.ts.map +1 -0
  228. package/esm/components/alert.d.ts +66 -0
  229. package/esm/components/alert.d.ts.map +1 -0
  230. package/esm/components/alert.schema.d.ts +98 -0
  231. package/esm/components/alert.schema.d.ts.map +1 -0
  232. package/esm/components/avatar.d.ts +77 -0
  233. package/esm/components/avatar.d.ts.map +1 -0
  234. package/esm/components/avatar.schema.d.ts +170 -0
  235. package/esm/components/avatar.schema.d.ts.map +1 -0
  236. package/esm/components/badge.d.ts +64 -0
  237. package/esm/components/badge.d.ts.map +1 -0
  238. package/esm/components/badge.schema.d.ts +91 -0
  239. package/esm/components/badge.schema.d.ts.map +1 -0
  240. package/esm/components/button.d.ts +100 -0
  241. package/esm/components/button.d.ts.map +1 -0
  242. package/esm/components/button.schema.d.ts +120 -0
  243. package/esm/components/button.schema.d.ts.map +1 -0
  244. package/esm/components/card.d.ts +53 -0
  245. package/esm/components/card.d.ts.map +1 -0
  246. package/esm/components/card.schema.d.ts +93 -0
  247. package/esm/components/card.schema.d.ts.map +1 -0
  248. package/esm/components/form.d.ts +212 -0
  249. package/esm/components/form.d.ts.map +1 -0
  250. package/esm/components/form.schema.d.ts +365 -0
  251. package/esm/components/form.schema.d.ts.map +1 -0
  252. package/esm/components/index.d.ts +29 -0
  253. package/esm/components/index.d.ts.map +1 -0
  254. package/esm/components/index.js +2456 -0
  255. package/esm/components/list.d.ts +121 -0
  256. package/esm/components/list.d.ts.map +1 -0
  257. package/esm/components/list.schema.d.ts +129 -0
  258. package/esm/components/list.schema.d.ts.map +1 -0
  259. package/esm/components/modal.d.ts +100 -0
  260. package/esm/components/modal.d.ts.map +1 -0
  261. package/esm/components/modal.schema.d.ts +151 -0
  262. package/esm/components/modal.schema.d.ts.map +1 -0
  263. package/esm/components/table.d.ts +91 -0
  264. package/esm/components/table.d.ts.map +1 -0
  265. package/esm/components/table.schema.d.ts +123 -0
  266. package/esm/components/table.schema.d.ts.map +1 -0
  267. package/esm/dependency/cdn-registry.d.ts +98 -0
  268. package/esm/dependency/cdn-registry.d.ts.map +1 -0
  269. package/esm/dependency/import-map.d.ts +186 -0
  270. package/esm/dependency/import-map.d.ts.map +1 -0
  271. package/esm/dependency/import-parser.d.ts +82 -0
  272. package/esm/dependency/import-parser.d.ts.map +1 -0
  273. package/esm/dependency/index.d.ts +17 -0
  274. package/esm/dependency/index.d.ts.map +1 -0
  275. package/esm/dependency/resolver.d.ts +164 -0
  276. package/esm/dependency/resolver.d.ts.map +1 -0
  277. package/esm/dependency/schemas.d.ts +486 -0
  278. package/esm/dependency/schemas.d.ts.map +1 -0
  279. package/esm/dependency/template-loader.d.ts +204 -0
  280. package/esm/dependency/template-loader.d.ts.map +1 -0
  281. package/esm/dependency/template-processor.d.ts +118 -0
  282. package/esm/dependency/template-processor.d.ts.map +1 -0
  283. package/esm/dependency/types.d.ts +739 -0
  284. package/esm/dependency/types.d.ts.map +1 -0
  285. package/esm/handlebars/expression-extractor.d.ts +147 -0
  286. package/esm/handlebars/expression-extractor.d.ts.map +1 -0
  287. package/esm/handlebars/helpers.d.ts +339 -0
  288. package/esm/handlebars/helpers.d.ts.map +1 -0
  289. package/esm/handlebars/index.d.ts +195 -0
  290. package/esm/handlebars/index.d.ts.map +1 -0
  291. package/esm/handlebars/index.js +587 -0
  292. package/esm/index.d.ts +56 -0
  293. package/esm/index.d.ts.map +1 -0
  294. package/esm/index.js +20511 -0
  295. package/esm/layouts/base.d.ts +86 -0
  296. package/esm/layouts/base.d.ts.map +1 -0
  297. package/esm/layouts/index.d.ts +8 -0
  298. package/esm/layouts/index.d.ts.map +1 -0
  299. package/esm/layouts/index.js +892 -0
  300. package/esm/layouts/presets.d.ts +134 -0
  301. package/esm/layouts/presets.d.ts.map +1 -0
  302. package/esm/package.json +90 -0
  303. package/esm/pages/consent.d.ts +117 -0
  304. package/esm/pages/consent.d.ts.map +1 -0
  305. package/esm/pages/error.d.ts +101 -0
  306. package/esm/pages/error.d.ts.map +1 -0
  307. package/esm/pages/index.d.ts +9 -0
  308. package/esm/pages/index.d.ts.map +1 -0
  309. package/esm/pages/index.js +1563 -0
  310. package/esm/react/Alert.d.ts +102 -0
  311. package/esm/react/Alert.d.ts.map +1 -0
  312. package/esm/react/Badge.d.ts +101 -0
  313. package/esm/react/Badge.d.ts.map +1 -0
  314. package/esm/react/Button.d.ts +109 -0
  315. package/esm/react/Button.d.ts.map +1 -0
  316. package/esm/react/Card.d.ts +104 -0
  317. package/esm/react/Card.d.ts.map +1 -0
  318. package/esm/react/hooks/context.d.ts +179 -0
  319. package/esm/react/hooks/context.d.ts.map +1 -0
  320. package/esm/react/hooks/index.d.ts +42 -0
  321. package/esm/react/hooks/index.d.ts.map +1 -0
  322. package/esm/react/hooks/tools.d.ts +284 -0
  323. package/esm/react/hooks/tools.d.ts.map +1 -0
  324. package/esm/react/index.d.ts +81 -0
  325. package/esm/react/index.d.ts.map +1 -0
  326. package/esm/react/index.js +1372 -0
  327. package/esm/react/types.d.ts +106 -0
  328. package/esm/react/types.d.ts.map +1 -0
  329. package/esm/react/utils.d.ts +43 -0
  330. package/esm/react/utils.d.ts.map +1 -0
  331. package/esm/registry/index.d.ts +46 -0
  332. package/esm/registry/index.d.ts.map +1 -0
  333. package/esm/registry/index.js +6422 -0
  334. package/esm/registry/render-template.d.ts +91 -0
  335. package/esm/registry/render-template.d.ts.map +1 -0
  336. package/esm/registry/tool-ui.registry.d.ts +294 -0
  337. package/esm/registry/tool-ui.registry.d.ts.map +1 -0
  338. package/esm/registry/uri-utils.d.ts +56 -0
  339. package/esm/registry/uri-utils.d.ts.map +1 -0
  340. package/esm/render/index.d.ts +8 -0
  341. package/esm/render/index.d.ts.map +1 -0
  342. package/esm/render/index.js +45 -0
  343. package/esm/render/prerender.d.ts +57 -0
  344. package/esm/render/prerender.d.ts.map +1 -0
  345. package/esm/renderers/cache.d.ts +145 -0
  346. package/esm/renderers/cache.d.ts.map +1 -0
  347. package/esm/renderers/html.renderer.d.ts +123 -0
  348. package/esm/renderers/html.renderer.d.ts.map +1 -0
  349. package/esm/renderers/index.d.ts +36 -0
  350. package/esm/renderers/index.d.ts.map +1 -0
  351. package/esm/renderers/index.js +1827 -0
  352. package/esm/renderers/mdx.renderer.d.ts +120 -0
  353. package/esm/renderers/mdx.renderer.d.ts.map +1 -0
  354. package/esm/renderers/react.renderer.d.ts +96 -0
  355. package/esm/renderers/react.renderer.d.ts.map +1 -0
  356. package/esm/renderers/registry.d.ts +134 -0
  357. package/esm/renderers/registry.d.ts.map +1 -0
  358. package/esm/renderers/types.d.ts +342 -0
  359. package/esm/renderers/types.d.ts.map +1 -0
  360. package/esm/renderers/utils/detect.d.ts +107 -0
  361. package/esm/renderers/utils/detect.d.ts.map +1 -0
  362. package/esm/renderers/utils/hash.d.ts +40 -0
  363. package/esm/renderers/utils/hash.d.ts.map +1 -0
  364. package/esm/renderers/utils/index.d.ts +9 -0
  365. package/esm/renderers/utils/index.d.ts.map +1 -0
  366. package/esm/renderers/utils/transpiler.d.ts +89 -0
  367. package/esm/renderers/utils/transpiler.d.ts.map +1 -0
  368. package/esm/runtime/adapters/html.adapter.d.ts +59 -0
  369. package/esm/runtime/adapters/html.adapter.d.ts.map +1 -0
  370. package/esm/runtime/adapters/index.d.ts +26 -0
  371. package/esm/runtime/adapters/index.d.ts.map +1 -0
  372. package/esm/runtime/adapters/mdx.adapter.d.ts +73 -0
  373. package/esm/runtime/adapters/mdx.adapter.d.ts.map +1 -0
  374. package/esm/runtime/adapters/react.adapter.d.ts +70 -0
  375. package/esm/runtime/adapters/react.adapter.d.ts.map +1 -0
  376. package/esm/runtime/adapters/types.d.ts +95 -0
  377. package/esm/runtime/adapters/types.d.ts.map +1 -0
  378. package/esm/runtime/csp.d.ts +48 -0
  379. package/esm/runtime/csp.d.ts.map +1 -0
  380. package/esm/runtime/index.d.ts +17 -0
  381. package/esm/runtime/index.d.ts.map +1 -0
  382. package/esm/runtime/index.js +5186 -0
  383. package/esm/runtime/mcp-bridge.d.ts +101 -0
  384. package/esm/runtime/mcp-bridge.d.ts.map +1 -0
  385. package/esm/runtime/renderer-runtime.d.ts +133 -0
  386. package/esm/runtime/renderer-runtime.d.ts.map +1 -0
  387. package/esm/runtime/sanitizer.d.ts +172 -0
  388. package/esm/runtime/sanitizer.d.ts.map +1 -0
  389. package/esm/runtime/types.d.ts +415 -0
  390. package/esm/runtime/types.d.ts.map +1 -0
  391. package/esm/runtime/wrapper.d.ts +421 -0
  392. package/esm/runtime/wrapper.d.ts.map +1 -0
  393. package/esm/styles/index.d.ts +8 -0
  394. package/esm/styles/index.d.ts.map +1 -0
  395. package/esm/styles/index.js +171 -0
  396. package/esm/styles/variants.d.ts +51 -0
  397. package/esm/styles/variants.d.ts.map +1 -0
  398. package/esm/theme/cdn.d.ts +195 -0
  399. package/esm/theme/cdn.d.ts.map +1 -0
  400. package/esm/theme/index.d.ts +18 -0
  401. package/esm/theme/index.d.ts.map +1 -0
  402. package/esm/theme/index.js +700 -0
  403. package/esm/theme/platforms.d.ts +107 -0
  404. package/esm/theme/platforms.d.ts.map +1 -0
  405. package/esm/theme/presets/github-openai.d.ts +50 -0
  406. package/esm/theme/presets/github-openai.d.ts.map +1 -0
  407. package/esm/theme/presets/index.d.ts +11 -0
  408. package/esm/theme/presets/index.d.ts.map +1 -0
  409. package/esm/theme/theme.d.ts +396 -0
  410. package/esm/theme/theme.d.ts.map +1 -0
  411. package/esm/tool-template/builder.d.ts +213 -0
  412. package/esm/tool-template/builder.d.ts.map +1 -0
  413. package/esm/tool-template/index.d.ts +16 -0
  414. package/esm/tool-template/index.d.ts.map +1 -0
  415. package/esm/tool-template/index.js +3515 -0
  416. package/esm/types/index.d.ts +14 -0
  417. package/esm/types/index.d.ts.map +1 -0
  418. package/esm/types/index.js +75 -0
  419. package/esm/types/ui-config.d.ts +639 -0
  420. package/esm/types/ui-config.d.ts.map +1 -0
  421. package/esm/types/ui-runtime.d.ts +1007 -0
  422. package/esm/types/ui-runtime.d.ts.map +1 -0
  423. package/esm/typings/cache/cache-adapter.d.ts +125 -0
  424. package/esm/typings/cache/cache-adapter.d.ts.map +1 -0
  425. package/esm/typings/cache/index.d.ts +10 -0
  426. package/esm/typings/cache/index.d.ts.map +1 -0
  427. package/esm/typings/cache/memory-cache.d.ts +92 -0
  428. package/esm/typings/cache/memory-cache.d.ts.map +1 -0
  429. package/esm/typings/dts-parser.d.ts +90 -0
  430. package/esm/typings/dts-parser.d.ts.map +1 -0
  431. package/esm/typings/index.d.ts +48 -0
  432. package/esm/typings/index.d.ts.map +1 -0
  433. package/esm/typings/schemas.d.ts +232 -0
  434. package/esm/typings/schemas.d.ts.map +1 -0
  435. package/esm/typings/type-fetcher.d.ts +89 -0
  436. package/esm/typings/type-fetcher.d.ts.map +1 -0
  437. package/esm/typings/types.d.ts +320 -0
  438. package/esm/typings/types.d.ts.map +1 -0
  439. package/esm/universal/UniversalApp.d.ts +108 -0
  440. package/esm/universal/UniversalApp.d.ts.map +1 -0
  441. package/esm/universal/cached-runtime.d.ts +115 -0
  442. package/esm/universal/cached-runtime.d.ts.map +1 -0
  443. package/esm/universal/context.d.ts +122 -0
  444. package/esm/universal/context.d.ts.map +1 -0
  445. package/esm/universal/index.d.ts +57 -0
  446. package/esm/universal/index.d.ts.map +1 -0
  447. package/esm/universal/renderers/html.renderer.d.ts +37 -0
  448. package/esm/universal/renderers/html.renderer.d.ts.map +1 -0
  449. package/esm/universal/renderers/index.d.ts +112 -0
  450. package/esm/universal/renderers/index.d.ts.map +1 -0
  451. package/esm/universal/renderers/markdown.renderer.d.ts +33 -0
  452. package/esm/universal/renderers/markdown.renderer.d.ts.map +1 -0
  453. package/esm/universal/renderers/mdx.renderer.d.ts +38 -0
  454. package/esm/universal/renderers/mdx.renderer.d.ts.map +1 -0
  455. package/esm/universal/renderers/react.renderer.d.ts +46 -0
  456. package/esm/universal/renderers/react.renderer.d.ts.map +1 -0
  457. package/esm/universal/runtime-builder.d.ts +33 -0
  458. package/esm/universal/runtime-builder.d.ts.map +1 -0
  459. package/esm/universal/store.d.ts +135 -0
  460. package/esm/universal/store.d.ts.map +1 -0
  461. package/esm/universal/types.d.ts +199 -0
  462. package/esm/universal/types.d.ts.map +1 -0
  463. package/esm/utils/escape-html.d.ts +58 -0
  464. package/esm/utils/escape-html.d.ts.map +1 -0
  465. package/esm/utils/index.d.ts +10 -0
  466. package/esm/utils/index.d.ts.map +1 -0
  467. package/esm/utils/index.js +40 -0
  468. package/esm/utils/safe-stringify.d.ts +30 -0
  469. package/esm/utils/safe-stringify.d.ts.map +1 -0
  470. package/esm/validation/error-box.d.ts +56 -0
  471. package/esm/validation/error-box.d.ts.map +1 -0
  472. package/esm/validation/index.d.ts +13 -0
  473. package/esm/validation/index.d.ts.map +1 -0
  474. package/esm/validation/index.js +562 -0
  475. package/esm/validation/schema-paths.d.ts +118 -0
  476. package/esm/validation/schema-paths.d.ts.map +1 -0
  477. package/esm/validation/template-validator.d.ts +143 -0
  478. package/esm/validation/template-validator.d.ts.map +1 -0
  479. package/esm/validation/wrapper.d.ts +97 -0
  480. package/esm/validation/wrapper.d.ts.map +1 -0
  481. package/esm/web-components/core/attribute-parser.d.ts +82 -0
  482. package/esm/web-components/core/attribute-parser.d.ts.map +1 -0
  483. package/esm/web-components/core/base-element.d.ts +197 -0
  484. package/esm/web-components/core/base-element.d.ts.map +1 -0
  485. package/esm/web-components/core/index.d.ts +9 -0
  486. package/esm/web-components/core/index.d.ts.map +1 -0
  487. package/esm/web-components/elements/fmcp-alert.d.ts +46 -0
  488. package/esm/web-components/elements/fmcp-alert.d.ts.map +1 -0
  489. package/esm/web-components/elements/fmcp-badge.d.ts +47 -0
  490. package/esm/web-components/elements/fmcp-badge.d.ts.map +1 -0
  491. package/esm/web-components/elements/fmcp-button.d.ts +117 -0
  492. package/esm/web-components/elements/fmcp-button.d.ts.map +1 -0
  493. package/esm/web-components/elements/fmcp-card.d.ts +53 -0
  494. package/esm/web-components/elements/fmcp-card.d.ts.map +1 -0
  495. package/esm/web-components/elements/fmcp-input.d.ts +96 -0
  496. package/esm/web-components/elements/fmcp-input.d.ts.map +1 -0
  497. package/esm/web-components/elements/fmcp-select.d.ts +100 -0
  498. package/esm/web-components/elements/fmcp-select.d.ts.map +1 -0
  499. package/esm/web-components/elements/index.d.ts +13 -0
  500. package/esm/web-components/elements/index.d.ts.map +1 -0
  501. package/esm/web-components/index.d.ts +50 -0
  502. package/esm/web-components/index.d.ts.map +1 -0
  503. package/esm/web-components/index.js +2048 -0
  504. package/esm/web-components/register.d.ts +57 -0
  505. package/esm/web-components/register.d.ts.map +1 -0
  506. package/esm/web-components/types.d.ts +122 -0
  507. package/esm/web-components/types.d.ts.map +1 -0
  508. package/esm/widgets/index.d.ts +8 -0
  509. package/esm/widgets/index.d.ts.map +1 -0
  510. package/esm/widgets/index.js +941 -0
  511. package/esm/widgets/progress.d.ts +133 -0
  512. package/esm/widgets/progress.d.ts.map +1 -0
  513. package/esm/widgets/resource.d.ts +163 -0
  514. package/esm/widgets/resource.d.ts.map +1 -0
  515. package/handlebars/expression-extractor.d.ts +147 -0
  516. package/handlebars/expression-extractor.d.ts.map +1 -0
  517. package/handlebars/helpers.d.ts +339 -0
  518. package/handlebars/helpers.d.ts.map +1 -0
  519. package/handlebars/index.d.ts +195 -0
  520. package/handlebars/index.d.ts.map +1 -0
  521. package/handlebars/index.js +666 -0
  522. package/index.d.ts +56 -0
  523. package/index.d.ts.map +1 -0
  524. package/index.js +20942 -0
  525. package/layouts/base.d.ts +86 -0
  526. package/layouts/base.d.ts.map +1 -0
  527. package/layouts/index.d.ts +8 -0
  528. package/layouts/index.d.ts.map +1 -0
  529. package/layouts/index.js +930 -0
  530. package/layouts/presets.d.ts +134 -0
  531. package/layouts/presets.d.ts.map +1 -0
  532. package/package.json +28 -87
  533. package/pages/consent.d.ts +117 -0
  534. package/pages/consent.d.ts.map +1 -0
  535. package/pages/error.d.ts +101 -0
  536. package/pages/error.d.ts.map +1 -0
  537. package/pages/index.d.ts +9 -0
  538. package/pages/index.d.ts.map +1 -0
  539. package/pages/index.js +1602 -0
  540. package/react/Alert.d.ts +102 -0
  541. package/react/Alert.d.ts.map +1 -0
  542. package/react/Badge.d.ts +101 -0
  543. package/react/Badge.d.ts.map +1 -0
  544. package/react/Button.d.ts +109 -0
  545. package/react/Button.d.ts.map +1 -0
  546. package/react/Card.d.ts +104 -0
  547. package/react/Card.d.ts.map +1 -0
  548. package/react/hooks/context.d.ts +179 -0
  549. package/react/hooks/context.d.ts.map +1 -0
  550. package/react/hooks/index.d.ts +42 -0
  551. package/react/hooks/index.d.ts.map +1 -0
  552. package/react/hooks/tools.d.ts +284 -0
  553. package/react/hooks/tools.d.ts.map +1 -0
  554. package/react/index.d.ts +81 -0
  555. package/react/index.d.ts.map +1 -0
  556. package/react/index.js +1430 -0
  557. package/react/types.d.ts +106 -0
  558. package/react/types.d.ts.map +1 -0
  559. package/react/utils.d.ts +43 -0
  560. package/react/utils.d.ts.map +1 -0
  561. package/registry/index.d.ts +46 -0
  562. package/registry/index.d.ts.map +1 -0
  563. package/registry/index.js +6465 -0
  564. package/registry/render-template.d.ts +91 -0
  565. package/registry/render-template.d.ts.map +1 -0
  566. package/registry/tool-ui.registry.d.ts +294 -0
  567. package/registry/tool-ui.registry.d.ts.map +1 -0
  568. package/registry/uri-utils.d.ts +56 -0
  569. package/registry/uri-utils.d.ts.map +1 -0
  570. package/render/index.d.ts +8 -0
  571. package/render/index.d.ts.map +1 -0
  572. package/render/index.js +77 -0
  573. package/render/prerender.d.ts +57 -0
  574. package/render/prerender.d.ts.map +1 -0
  575. package/renderers/cache.d.ts +145 -0
  576. package/renderers/cache.d.ts.map +1 -0
  577. package/renderers/html.renderer.d.ts +123 -0
  578. package/renderers/html.renderer.d.ts.map +1 -0
  579. package/renderers/index.d.ts +36 -0
  580. package/renderers/index.d.ts.map +1 -0
  581. package/renderers/index.js +1882 -0
  582. package/renderers/mdx.renderer.d.ts +120 -0
  583. package/renderers/mdx.renderer.d.ts.map +1 -0
  584. package/renderers/react.renderer.d.ts +96 -0
  585. package/renderers/react.renderer.d.ts.map +1 -0
  586. package/renderers/registry.d.ts +134 -0
  587. package/renderers/registry.d.ts.map +1 -0
  588. package/renderers/types.d.ts +342 -0
  589. package/renderers/types.d.ts.map +1 -0
  590. package/renderers/utils/detect.d.ts +107 -0
  591. package/renderers/utils/detect.d.ts.map +1 -0
  592. package/renderers/utils/hash.d.ts +40 -0
  593. package/renderers/utils/hash.d.ts.map +1 -0
  594. package/renderers/utils/index.d.ts +9 -0
  595. package/renderers/utils/index.d.ts.map +1 -0
  596. package/renderers/utils/transpiler.d.ts +89 -0
  597. package/renderers/utils/transpiler.d.ts.map +1 -0
  598. package/runtime/adapters/html.adapter.d.ts +59 -0
  599. package/runtime/adapters/html.adapter.d.ts.map +1 -0
  600. package/runtime/adapters/index.d.ts +26 -0
  601. package/runtime/adapters/index.d.ts.map +1 -0
  602. package/runtime/adapters/mdx.adapter.d.ts +73 -0
  603. package/runtime/adapters/mdx.adapter.d.ts.map +1 -0
  604. package/runtime/adapters/react.adapter.d.ts +70 -0
  605. package/runtime/adapters/react.adapter.d.ts.map +1 -0
  606. package/runtime/adapters/types.d.ts +95 -0
  607. package/runtime/adapters/types.d.ts.map +1 -0
  608. package/runtime/csp.d.ts +48 -0
  609. package/runtime/csp.d.ts.map +1 -0
  610. package/runtime/index.d.ts +17 -0
  611. package/runtime/index.d.ts.map +1 -0
  612. package/runtime/index.js +5264 -0
  613. package/runtime/mcp-bridge.d.ts +101 -0
  614. package/runtime/mcp-bridge.d.ts.map +1 -0
  615. package/runtime/renderer-runtime.d.ts +133 -0
  616. package/runtime/renderer-runtime.d.ts.map +1 -0
  617. package/runtime/sanitizer.d.ts +172 -0
  618. package/runtime/sanitizer.d.ts.map +1 -0
  619. package/runtime/types.d.ts +415 -0
  620. package/runtime/types.d.ts.map +1 -0
  621. package/runtime/wrapper.d.ts +421 -0
  622. package/runtime/wrapper.d.ts.map +1 -0
  623. package/styles/index.d.ts +8 -0
  624. package/styles/index.d.ts.map +1 -0
  625. package/styles/index.js +222 -0
  626. package/styles/variants.d.ts +51 -0
  627. package/styles/variants.d.ts.map +1 -0
  628. package/theme/cdn.d.ts +195 -0
  629. package/theme/cdn.d.ts.map +1 -0
  630. package/theme/index.d.ts +18 -0
  631. package/theme/index.d.ts.map +1 -0
  632. package/theme/index.js +757 -0
  633. package/theme/platforms.d.ts +107 -0
  634. package/theme/platforms.d.ts.map +1 -0
  635. package/theme/presets/github-openai.d.ts +50 -0
  636. package/theme/presets/github-openai.d.ts.map +1 -0
  637. package/theme/presets/index.d.ts +11 -0
  638. package/theme/presets/index.d.ts.map +1 -0
  639. package/theme/theme.d.ts +396 -0
  640. package/theme/theme.d.ts.map +1 -0
  641. package/tool-template/builder.d.ts +213 -0
  642. package/tool-template/builder.d.ts.map +1 -0
  643. package/tool-template/index.d.ts +16 -0
  644. package/tool-template/index.d.ts.map +1 -0
  645. package/tool-template/index.js +3559 -0
  646. package/types/index.d.ts +14 -0
  647. package/types/index.d.ts.map +1 -0
  648. package/types/index.js +108 -0
  649. package/types/ui-config.d.ts +639 -0
  650. package/types/ui-config.d.ts.map +1 -0
  651. package/types/ui-runtime.d.ts +1007 -0
  652. package/types/ui-runtime.d.ts.map +1 -0
  653. package/typings/cache/cache-adapter.d.ts +125 -0
  654. package/typings/cache/cache-adapter.d.ts.map +1 -0
  655. package/typings/cache/index.d.ts +10 -0
  656. package/typings/cache/index.d.ts.map +1 -0
  657. package/typings/cache/memory-cache.d.ts +92 -0
  658. package/typings/cache/memory-cache.d.ts.map +1 -0
  659. package/typings/dts-parser.d.ts +90 -0
  660. package/typings/dts-parser.d.ts.map +1 -0
  661. package/typings/index.d.ts +48 -0
  662. package/typings/index.d.ts.map +1 -0
  663. package/typings/schemas.d.ts +232 -0
  664. package/typings/schemas.d.ts.map +1 -0
  665. package/typings/type-fetcher.d.ts +89 -0
  666. package/typings/type-fetcher.d.ts.map +1 -0
  667. package/typings/types.d.ts +320 -0
  668. package/typings/types.d.ts.map +1 -0
  669. package/universal/UniversalApp.d.ts +108 -0
  670. package/universal/UniversalApp.d.ts.map +1 -0
  671. package/universal/cached-runtime.d.ts +115 -0
  672. package/universal/cached-runtime.d.ts.map +1 -0
  673. package/universal/context.d.ts +122 -0
  674. package/universal/context.d.ts.map +1 -0
  675. package/universal/index.d.ts +57 -0
  676. package/universal/index.d.ts.map +1 -0
  677. package/universal/renderers/html.renderer.d.ts +37 -0
  678. package/universal/renderers/html.renderer.d.ts.map +1 -0
  679. package/universal/renderers/index.d.ts +112 -0
  680. package/universal/renderers/index.d.ts.map +1 -0
  681. package/universal/renderers/markdown.renderer.d.ts +33 -0
  682. package/universal/renderers/markdown.renderer.d.ts.map +1 -0
  683. package/universal/renderers/mdx.renderer.d.ts +38 -0
  684. package/universal/renderers/mdx.renderer.d.ts.map +1 -0
  685. package/universal/renderers/react.renderer.d.ts +46 -0
  686. package/universal/renderers/react.renderer.d.ts.map +1 -0
  687. package/universal/runtime-builder.d.ts +33 -0
  688. package/universal/runtime-builder.d.ts.map +1 -0
  689. package/universal/store.d.ts +135 -0
  690. package/universal/store.d.ts.map +1 -0
  691. package/universal/types.d.ts +199 -0
  692. package/universal/types.d.ts.map +1 -0
  693. package/utils/escape-html.d.ts +58 -0
  694. package/utils/escape-html.d.ts.map +1 -0
  695. package/utils/index.d.ts +10 -0
  696. package/utils/index.d.ts.map +1 -0
  697. package/utils/index.js +70 -0
  698. package/utils/safe-stringify.d.ts +30 -0
  699. package/utils/safe-stringify.d.ts.map +1 -0
  700. package/validation/error-box.d.ts +56 -0
  701. package/validation/error-box.d.ts.map +1 -0
  702. package/validation/index.d.ts +13 -0
  703. package/validation/index.d.ts.map +1 -0
  704. package/validation/index.js +603 -0
  705. package/validation/schema-paths.d.ts +118 -0
  706. package/validation/schema-paths.d.ts.map +1 -0
  707. package/validation/template-validator.d.ts +143 -0
  708. package/validation/template-validator.d.ts.map +1 -0
  709. package/validation/wrapper.d.ts +97 -0
  710. package/validation/wrapper.d.ts.map +1 -0
  711. package/web-components/core/attribute-parser.d.ts +82 -0
  712. package/web-components/core/attribute-parser.d.ts.map +1 -0
  713. package/web-components/core/base-element.d.ts +197 -0
  714. package/web-components/core/base-element.d.ts.map +1 -0
  715. package/web-components/core/index.d.ts +9 -0
  716. package/web-components/core/index.d.ts.map +1 -0
  717. package/web-components/elements/fmcp-alert.d.ts +46 -0
  718. package/web-components/elements/fmcp-alert.d.ts.map +1 -0
  719. package/web-components/elements/fmcp-badge.d.ts +47 -0
  720. package/web-components/elements/fmcp-badge.d.ts.map +1 -0
  721. package/web-components/elements/fmcp-button.d.ts +117 -0
  722. package/web-components/elements/fmcp-button.d.ts.map +1 -0
  723. package/web-components/elements/fmcp-card.d.ts +53 -0
  724. package/web-components/elements/fmcp-card.d.ts.map +1 -0
  725. package/web-components/elements/fmcp-input.d.ts +96 -0
  726. package/web-components/elements/fmcp-input.d.ts.map +1 -0
  727. package/web-components/elements/fmcp-select.d.ts +100 -0
  728. package/web-components/elements/fmcp-select.d.ts.map +1 -0
  729. package/web-components/elements/index.d.ts +13 -0
  730. package/web-components/elements/index.d.ts.map +1 -0
  731. package/web-components/index.d.ts +50 -0
  732. package/web-components/index.d.ts.map +1 -0
  733. package/web-components/index.js +2093 -0
  734. package/web-components/register.d.ts +57 -0
  735. package/web-components/register.d.ts.map +1 -0
  736. package/web-components/types.d.ts +122 -0
  737. package/web-components/types.d.ts.map +1 -0
  738. package/widgets/index.d.ts +8 -0
  739. package/widgets/index.d.ts.map +1 -0
  740. package/widgets/index.js +978 -0
  741. package/widgets/progress.d.ts +133 -0
  742. package/widgets/progress.d.ts.map +1 -0
  743. package/widgets/resource.d.ts +163 -0
  744. package/widgets/resource.d.ts.map +1 -0
  745. package/src/adapters/index.d.ts +0 -10
  746. package/src/adapters/index.js +0 -18
  747. package/src/adapters/index.js.map +0 -1
  748. package/src/adapters/platform-meta.d.ts +0 -165
  749. package/src/adapters/platform-meta.js +0 -310
  750. package/src/adapters/platform-meta.js.map +0 -1
  751. package/src/base-template/bridge.d.ts +0 -89
  752. package/src/base-template/bridge.js +0 -452
  753. package/src/base-template/bridge.js.map +0 -1
  754. package/src/base-template/default-base-template.d.ts +0 -91
  755. package/src/base-template/default-base-template.js +0 -435
  756. package/src/base-template/default-base-template.js.map +0 -1
  757. package/src/base-template/index.d.ts +0 -14
  758. package/src/base-template/index.js +0 -30
  759. package/src/base-template/index.js.map +0 -1
  760. package/src/base-template/polyfills.d.ts +0 -30
  761. package/src/base-template/polyfills.js +0 -190
  762. package/src/base-template/polyfills.js.map +0 -1
  763. package/src/base-template/theme-styles.d.ts +0 -73
  764. package/src/base-template/theme-styles.js +0 -95
  765. package/src/base-template/theme-styles.js.map +0 -1
  766. package/src/bridge/adapters/base-adapter.d.ts +0 -103
  767. package/src/bridge/adapters/base-adapter.js +0 -314
  768. package/src/bridge/adapters/base-adapter.js.map +0 -1
  769. package/src/bridge/adapters/claude.adapter.d.ts +0 -66
  770. package/src/bridge/adapters/claude.adapter.js +0 -145
  771. package/src/bridge/adapters/claude.adapter.js.map +0 -1
  772. package/src/bridge/adapters/ext-apps.adapter.d.ts +0 -142
  773. package/src/bridge/adapters/ext-apps.adapter.js +0 -416
  774. package/src/bridge/adapters/ext-apps.adapter.js.map +0 -1
  775. package/src/bridge/adapters/gemini.adapter.d.ts +0 -63
  776. package/src/bridge/adapters/gemini.adapter.js +0 -160
  777. package/src/bridge/adapters/gemini.adapter.js.map +0 -1
  778. package/src/bridge/adapters/generic.adapter.d.ts +0 -55
  779. package/src/bridge/adapters/generic.adapter.js +0 -108
  780. package/src/bridge/adapters/generic.adapter.js.map +0 -1
  781. package/src/bridge/adapters/index.d.ts +0 -25
  782. package/src/bridge/adapters/index.js +0 -65
  783. package/src/bridge/adapters/index.js.map +0 -1
  784. package/src/bridge/adapters/openai.adapter.d.ts +0 -64
  785. package/src/bridge/adapters/openai.adapter.js +0 -194
  786. package/src/bridge/adapters/openai.adapter.js.map +0 -1
  787. package/src/bridge/core/adapter-registry.d.ts +0 -121
  788. package/src/bridge/core/adapter-registry.js +0 -271
  789. package/src/bridge/core/adapter-registry.js.map +0 -1
  790. package/src/bridge/core/bridge-factory.d.ts +0 -198
  791. package/src/bridge/core/bridge-factory.js +0 -428
  792. package/src/bridge/core/bridge-factory.js.map +0 -1
  793. package/src/bridge/core/index.d.ts +0 -9
  794. package/src/bridge/core/index.js +0 -22
  795. package/src/bridge/core/index.js.map +0 -1
  796. package/src/bridge/index.d.ts +0 -61
  797. package/src/bridge/index.js +0 -94
  798. package/src/bridge/index.js.map +0 -1
  799. package/src/bridge/runtime/iife-generator.d.ts +0 -61
  800. package/src/bridge/runtime/iife-generator.js +0 -940
  801. package/src/bridge/runtime/iife-generator.js.map +0 -1
  802. package/src/bridge/runtime/index.d.ts +0 -8
  803. package/src/bridge/runtime/index.js +0 -16
  804. package/src/bridge/runtime/index.js.map +0 -1
  805. package/src/bridge/types.d.ts +0 -385
  806. package/src/bridge/types.js +0 -11
  807. package/src/bridge/types.js.map +0 -1
  808. package/src/build/cdn-resources.d.ts +0 -140
  809. package/src/build/cdn-resources.js +0 -314
  810. package/src/build/cdn-resources.js.map +0 -1
  811. package/src/build/index.d.ts +0 -294
  812. package/src/build/index.js +0 -325
  813. package/src/build/index.js.map +0 -1
  814. package/src/build/widget-manifest.d.ts +0 -212
  815. package/src/build/widget-manifest.js +0 -652
  816. package/src/build/widget-manifest.js.map +0 -1
  817. package/src/bundler/bundler.d.ts +0 -110
  818. package/src/bundler/bundler.js +0 -432
  819. package/src/bundler/bundler.js.map +0 -1
  820. package/src/bundler/cache.d.ts +0 -172
  821. package/src/bundler/cache.js +0 -250
  822. package/src/bundler/cache.js.map +0 -1
  823. package/src/bundler/index.d.ts +0 -41
  824. package/src/bundler/index.js +0 -73
  825. package/src/bundler/index.js.map +0 -1
  826. package/src/bundler/sandbox/enclave-adapter.d.ts +0 -120
  827. package/src/bundler/sandbox/enclave-adapter.js +0 -339
  828. package/src/bundler/sandbox/enclave-adapter.js.map +0 -1
  829. package/src/bundler/sandbox/executor.d.ts +0 -13
  830. package/src/bundler/sandbox/executor.js +0 -22
  831. package/src/bundler/sandbox/executor.js.map +0 -1
  832. package/src/bundler/sandbox/policy.d.ts +0 -61
  833. package/src/bundler/sandbox/policy.js +0 -238
  834. package/src/bundler/sandbox/policy.js.map +0 -1
  835. package/src/bundler/types.d.ts +0 -347
  836. package/src/bundler/types.js +0 -132
  837. package/src/bundler/types.js.map +0 -1
  838. package/src/components/alert.d.ts +0 -71
  839. package/src/components/alert.js +0 -189
  840. package/src/components/alert.js.map +0 -1
  841. package/src/components/alert.schema.d.ts +0 -114
  842. package/src/components/alert.schema.js +0 -105
  843. package/src/components/alert.schema.js.map +0 -1
  844. package/src/components/avatar.d.ts +0 -76
  845. package/src/components/avatar.js +0 -176
  846. package/src/components/avatar.js.map +0 -1
  847. package/src/components/avatar.schema.d.ts +0 -169
  848. package/src/components/avatar.schema.js +0 -103
  849. package/src/components/avatar.schema.js.map +0 -1
  850. package/src/components/badge.d.ts +0 -70
  851. package/src/components/badge.js +0 -149
  852. package/src/components/badge.js.map +0 -1
  853. package/src/components/badge.schema.d.ts +0 -109
  854. package/src/components/badge.schema.js +0 -96
  855. package/src/components/badge.schema.js.map +0 -1
  856. package/src/components/button.d.ts +0 -111
  857. package/src/components/button.js +0 -336
  858. package/src/components/button.js.map +0 -1
  859. package/src/components/button.schema.d.ts +0 -148
  860. package/src/components/button.schema.js +0 -121
  861. package/src/components/button.schema.js.map +0 -1
  862. package/src/components/card.d.ts +0 -60
  863. package/src/components/card.js +0 -117
  864. package/src/components/card.js.map +0 -1
  865. package/src/components/card.schema.d.ts +0 -113
  866. package/src/components/card.schema.js +0 -98
  867. package/src/components/card.schema.js.map +0 -1
  868. package/src/components/form.d.ts +0 -239
  869. package/src/components/form.js +0 -420
  870. package/src/components/form.js.map +0 -1
  871. package/src/components/form.schema.d.ts +0 -441
  872. package/src/components/form.schema.js +0 -406
  873. package/src/components/form.schema.js.map +0 -1
  874. package/src/components/index.d.ts +0 -29
  875. package/src/components/index.js +0 -98
  876. package/src/components/index.js.map +0 -1
  877. package/src/components/list.d.ts +0 -127
  878. package/src/components/list.js +0 -279
  879. package/src/components/list.js.map +0 -1
  880. package/src/components/list.schema.d.ts +0 -134
  881. package/src/components/list.schema.js +0 -168
  882. package/src/components/list.schema.js.map +0 -1
  883. package/src/components/modal.d.ts +0 -111
  884. package/src/components/modal.js +0 -260
  885. package/src/components/modal.js.map +0 -1
  886. package/src/components/modal.schema.d.ts +0 -186
  887. package/src/components/modal.schema.js +0 -167
  888. package/src/components/modal.schema.js.map +0 -1
  889. package/src/components/table.d.ts +0 -105
  890. package/src/components/table.js +0 -283
  891. package/src/components/table.js.map +0 -1
  892. package/src/components/table.schema.d.ts +0 -159
  893. package/src/components/table.schema.js +0 -173
  894. package/src/components/table.schema.js.map +0 -1
  895. package/src/handlebars/helpers.d.ts +0 -348
  896. package/src/handlebars/helpers.js +0 -605
  897. package/src/handlebars/helpers.js.map +0 -1
  898. package/src/handlebars/index.d.ts +0 -193
  899. package/src/handlebars/index.js +0 -350
  900. package/src/handlebars/index.js.map +0 -1
  901. package/src/index.d.ts +0 -50
  902. package/src/index.js +0 -192
  903. package/src/index.js.map +0 -1
  904. package/src/layouts/base.d.ts +0 -88
  905. package/src/layouts/base.js +0 -227
  906. package/src/layouts/base.js.map +0 -1
  907. package/src/layouts/index.d.ts +0 -7
  908. package/src/layouts/index.js +0 -25
  909. package/src/layouts/index.js.map +0 -1
  910. package/src/layouts/presets.d.ts +0 -133
  911. package/src/layouts/presets.js +0 -277
  912. package/src/layouts/presets.js.map +0 -1
  913. package/src/pages/consent.d.ts +0 -116
  914. package/src/pages/consent.js +0 -218
  915. package/src/pages/consent.js.map +0 -1
  916. package/src/pages/error.d.ts +0 -100
  917. package/src/pages/error.js +0 -263
  918. package/src/pages/error.js.map +0 -1
  919. package/src/pages/index.d.ts +0 -8
  920. package/src/pages/index.js +0 -27
  921. package/src/pages/index.js.map +0 -1
  922. package/src/react/Alert.d.ts +0 -101
  923. package/src/react/Alert.js +0 -51
  924. package/src/react/Alert.js.map +0 -1
  925. package/src/react/Badge.d.ts +0 -100
  926. package/src/react/Badge.js +0 -55
  927. package/src/react/Badge.js.map +0 -1
  928. package/src/react/Button.d.ts +0 -108
  929. package/src/react/Button.js +0 -52
  930. package/src/react/Button.js.map +0 -1
  931. package/src/react/Card.d.ts +0 -103
  932. package/src/react/Card.js +0 -55
  933. package/src/react/Card.js.map +0 -1
  934. package/src/react/hooks/context.d.ts +0 -178
  935. package/src/react/hooks/context.js +0 -287
  936. package/src/react/hooks/context.js.map +0 -1
  937. package/src/react/hooks/index.d.ts +0 -41
  938. package/src/react/hooks/index.js +0 -61
  939. package/src/react/hooks/index.js.map +0 -1
  940. package/src/react/hooks/tools.d.ts +0 -283
  941. package/src/react/hooks/tools.js +0 -465
  942. package/src/react/hooks/tools.js.map +0 -1
  943. package/src/react/index.d.ts +0 -80
  944. package/src/react/index.js +0 -113
  945. package/src/react/index.js.map +0 -1
  946. package/src/react/types.d.ts +0 -105
  947. package/src/react/types.js +0 -12
  948. package/src/react/types.js.map +0 -1
  949. package/src/react/utils.d.ts +0 -42
  950. package/src/react/utils.js +0 -99
  951. package/src/react/utils.js.map +0 -1
  952. package/src/registry/index.d.ts +0 -45
  953. package/src/registry/index.js +0 -67
  954. package/src/registry/index.js.map +0 -1
  955. package/src/registry/render-template.d.ts +0 -86
  956. package/src/registry/render-template.js +0 -239
  957. package/src/registry/render-template.js.map +0 -1
  958. package/src/registry/tool-ui.registry.d.ts +0 -260
  959. package/src/registry/tool-ui.registry.js +0 -438
  960. package/src/registry/tool-ui.registry.js.map +0 -1
  961. package/src/registry/uri-utils.d.ts +0 -55
  962. package/src/registry/uri-utils.js +0 -97
  963. package/src/registry/uri-utils.js.map +0 -1
  964. package/src/render/index.d.ts +0 -7
  965. package/src/render/index.js +0 -14
  966. package/src/render/index.js.map +0 -1
  967. package/src/render/prerender.d.ts +0 -56
  968. package/src/render/prerender.js +0 -98
  969. package/src/render/prerender.js.map +0 -1
  970. package/src/renderers/cache.d.ts +0 -144
  971. package/src/renderers/cache.js +0 -240
  972. package/src/renderers/cache.js.map +0 -1
  973. package/src/renderers/html.renderer.d.ts +0 -122
  974. package/src/renderers/html.renderer.js +0 -204
  975. package/src/renderers/html.renderer.js.map +0 -1
  976. package/src/renderers/index.d.ts +0 -35
  977. package/src/renderers/index.js +0 -70
  978. package/src/renderers/index.js.map +0 -1
  979. package/src/renderers/mdx.renderer.d.ts +0 -119
  980. package/src/renderers/mdx.renderer.js +0 -305
  981. package/src/renderers/mdx.renderer.js.map +0 -1
  982. package/src/renderers/react.renderer.d.ts +0 -95
  983. package/src/renderers/react.renderer.js +0 -260
  984. package/src/renderers/react.renderer.js.map +0 -1
  985. package/src/renderers/registry.d.ts +0 -133
  986. package/src/renderers/registry.js +0 -232
  987. package/src/renderers/registry.js.map +0 -1
  988. package/src/renderers/types.d.ts +0 -341
  989. package/src/renderers/types.js +0 -9
  990. package/src/renderers/types.js.map +0 -1
  991. package/src/renderers/utils/detect.d.ts +0 -106
  992. package/src/renderers/utils/detect.js +0 -267
  993. package/src/renderers/utils/detect.js.map +0 -1
  994. package/src/renderers/utils/hash.d.ts +0 -39
  995. package/src/renderers/utils/hash.js +0 -75
  996. package/src/renderers/utils/hash.js.map +0 -1
  997. package/src/renderers/utils/index.d.ts +0 -8
  998. package/src/renderers/utils/index.js +0 -28
  999. package/src/renderers/utils/index.js.map +0 -1
  1000. package/src/renderers/utils/transpiler.d.ts +0 -88
  1001. package/src/renderers/utils/transpiler.js +0 -215
  1002. package/src/renderers/utils/transpiler.js.map +0 -1
  1003. package/src/runtime/adapters/html.adapter.d.ts +0 -58
  1004. package/src/runtime/adapters/html.adapter.js +0 -131
  1005. package/src/runtime/adapters/html.adapter.js.map +0 -1
  1006. package/src/runtime/adapters/index.d.ts +0 -25
  1007. package/src/runtime/adapters/index.js +0 -54
  1008. package/src/runtime/adapters/index.js.map +0 -1
  1009. package/src/runtime/adapters/mdx.adapter.d.ts +0 -72
  1010. package/src/runtime/adapters/mdx.adapter.js +0 -241
  1011. package/src/runtime/adapters/mdx.adapter.js.map +0 -1
  1012. package/src/runtime/adapters/react.adapter.d.ts +0 -69
  1013. package/src/runtime/adapters/react.adapter.js +0 -245
  1014. package/src/runtime/adapters/react.adapter.js.map +0 -1
  1015. package/src/runtime/adapters/types.d.ts +0 -94
  1016. package/src/runtime/adapters/types.js +0 -11
  1017. package/src/runtime/adapters/types.js.map +0 -1
  1018. package/src/runtime/csp.d.ts +0 -37
  1019. package/src/runtime/csp.js +0 -140
  1020. package/src/runtime/csp.js.map +0 -1
  1021. package/src/runtime/index.d.ts +0 -16
  1022. package/src/runtime/index.js +0 -72
  1023. package/src/runtime/index.js.map +0 -1
  1024. package/src/runtime/mcp-bridge.d.ts +0 -100
  1025. package/src/runtime/mcp-bridge.js +0 -581
  1026. package/src/runtime/mcp-bridge.js.map +0 -1
  1027. package/src/runtime/renderer-runtime.d.ts +0 -132
  1028. package/src/runtime/renderer-runtime.js +0 -389
  1029. package/src/runtime/renderer-runtime.js.map +0 -1
  1030. package/src/runtime/sanitizer.d.ts +0 -171
  1031. package/src/runtime/sanitizer.js +0 -318
  1032. package/src/runtime/sanitizer.js.map +0 -1
  1033. package/src/runtime/types.d.ts +0 -414
  1034. package/src/runtime/types.js +0 -12
  1035. package/src/runtime/types.js.map +0 -1
  1036. package/src/runtime/wrapper.d.ts +0 -375
  1037. package/src/runtime/wrapper.js +0 -1793
  1038. package/src/runtime/wrapper.js.map +0 -1
  1039. package/src/styles/index.d.ts +0 -7
  1040. package/src/styles/index.js +0 -11
  1041. package/src/styles/index.js.map +0 -1
  1042. package/src/styles/variants.d.ts +0 -50
  1043. package/src/styles/variants.js +0 -175
  1044. package/src/styles/variants.js.map +0 -1
  1045. package/src/theme/cdn.d.ts +0 -194
  1046. package/src/theme/cdn.js +0 -375
  1047. package/src/theme/cdn.js.map +0 -1
  1048. package/src/theme/index.d.ts +0 -17
  1049. package/src/theme/index.js +0 -57
  1050. package/src/theme/index.js.map +0 -1
  1051. package/src/theme/platforms.d.ts +0 -106
  1052. package/src/theme/platforms.js +0 -161
  1053. package/src/theme/platforms.js.map +0 -1
  1054. package/src/theme/presets/github-openai.d.ts +0 -49
  1055. package/src/theme/presets/github-openai.js +0 -189
  1056. package/src/theme/presets/github-openai.js.map +0 -1
  1057. package/src/theme/presets/index.d.ts +0 -10
  1058. package/src/theme/presets/index.js +0 -17
  1059. package/src/theme/presets/index.js.map +0 -1
  1060. package/src/theme/theme.d.ts +0 -395
  1061. package/src/theme/theme.js +0 -332
  1062. package/src/theme/theme.js.map +0 -1
  1063. package/src/tool-template/builder.d.ts +0 -212
  1064. package/src/tool-template/builder.js +0 -397
  1065. package/src/tool-template/builder.js.map +0 -1
  1066. package/src/tool-template/index.d.ts +0 -15
  1067. package/src/tool-template/index.js +0 -38
  1068. package/src/tool-template/index.js.map +0 -1
  1069. package/src/types/index.d.ts +0 -13
  1070. package/src/types/index.js +0 -26
  1071. package/src/types/index.js.map +0 -1
  1072. package/src/types/ui-config.d.ts +0 -357
  1073. package/src/types/ui-config.js +0 -12
  1074. package/src/types/ui-config.js.map +0 -1
  1075. package/src/types/ui-runtime.d.ts +0 -965
  1076. package/src/types/ui-runtime.js +0 -117
  1077. package/src/types/ui-runtime.js.map +0 -1
  1078. package/src/validation/error-box.d.ts +0 -55
  1079. package/src/validation/error-box.js +0 -75
  1080. package/src/validation/error-box.js.map +0 -1
  1081. package/src/validation/index.d.ts +0 -12
  1082. package/src/validation/index.js +0 -21
  1083. package/src/validation/index.js.map +0 -1
  1084. package/src/validation/wrapper.d.ts +0 -96
  1085. package/src/validation/wrapper.js +0 -117
  1086. package/src/validation/wrapper.js.map +0 -1
  1087. package/src/web-components/core/attribute-parser.d.ts +0 -85
  1088. package/src/web-components/core/attribute-parser.js +0 -189
  1089. package/src/web-components/core/attribute-parser.js.map +0 -1
  1090. package/src/web-components/core/base-element.d.ts +0 -197
  1091. package/src/web-components/core/base-element.js +0 -289
  1092. package/src/web-components/core/base-element.js.map +0 -1
  1093. package/src/web-components/core/index.d.ts +0 -8
  1094. package/src/web-components/core/index.js +0 -18
  1095. package/src/web-components/core/index.js.map +0 -1
  1096. package/src/web-components/elements/fmcp-alert.d.ts +0 -45
  1097. package/src/web-components/elements/fmcp-alert.js +0 -93
  1098. package/src/web-components/elements/fmcp-alert.js.map +0 -1
  1099. package/src/web-components/elements/fmcp-badge.d.ts +0 -46
  1100. package/src/web-components/elements/fmcp-badge.js +0 -99
  1101. package/src/web-components/elements/fmcp-badge.js.map +0 -1
  1102. package/src/web-components/elements/fmcp-button.d.ts +0 -124
  1103. package/src/web-components/elements/fmcp-button.js +0 -233
  1104. package/src/web-components/elements/fmcp-button.js.map +0 -1
  1105. package/src/web-components/elements/fmcp-card.d.ts +0 -52
  1106. package/src/web-components/elements/fmcp-card.js +0 -115
  1107. package/src/web-components/elements/fmcp-card.js.map +0 -1
  1108. package/src/web-components/elements/fmcp-input.d.ts +0 -95
  1109. package/src/web-components/elements/fmcp-input.js +0 -248
  1110. package/src/web-components/elements/fmcp-input.js.map +0 -1
  1111. package/src/web-components/elements/fmcp-select.d.ts +0 -99
  1112. package/src/web-components/elements/fmcp-select.js +0 -243
  1113. package/src/web-components/elements/fmcp-select.js.map +0 -1
  1114. package/src/web-components/elements/index.d.ts +0 -12
  1115. package/src/web-components/elements/index.js +0 -34
  1116. package/src/web-components/elements/index.js.map +0 -1
  1117. package/src/web-components/index.d.ts +0 -49
  1118. package/src/web-components/index.js +0 -75
  1119. package/src/web-components/index.js.map +0 -1
  1120. package/src/web-components/register.d.ts +0 -56
  1121. package/src/web-components/register.js +0 -80
  1122. package/src/web-components/register.js.map +0 -1
  1123. package/src/web-components/types.d.ts +0 -121
  1124. package/src/web-components/types.js +0 -25
  1125. package/src/web-components/types.js.map +0 -1
  1126. package/src/widgets/index.d.ts +0 -7
  1127. package/src/widgets/index.js +0 -24
  1128. package/src/widgets/index.js.map +0 -1
  1129. package/src/widgets/progress.d.ts +0 -132
  1130. package/src/widgets/progress.js +0 -303
  1131. package/src/widgets/progress.js.map +0 -1
  1132. package/src/widgets/resource.d.ts +0 -162
  1133. package/src/widgets/resource.js +0 -340
  1134. package/src/widgets/resource.js.map +0 -1
@@ -0,0 +1,2595 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // libs/ui/src/components/index.ts
21
+ var components_exports = {};
22
+ __export(components_exports, {
23
+ ActionItemSchema: () => ActionItemSchema,
24
+ ActionListOptionsSchema: () => ActionListOptionsSchema,
25
+ AlertOptionsSchema: () => AlertOptionsSchema,
26
+ AlertVariantSchema: () => AlertVariantSchema,
27
+ AvatarGroupOptionsSchema: () => AvatarGroupOptionsSchema,
28
+ AvatarOptionsSchema: () => AvatarOptionsSchema,
29
+ AvatarShapeSchema: () => AvatarShapeSchema,
30
+ AvatarSizeSchema: () => AvatarSizeSchema,
31
+ AvatarSpacingSchema: () => AvatarSpacingSchema,
32
+ AvatarStatusSchema: () => AvatarStatusSchema,
33
+ AvatarWithTextOptionsSchema: () => AvatarWithTextOptionsSchema,
34
+ BadgeGroupOptionsSchema: () => BadgeGroupOptionsSchema,
35
+ BadgeOptionsSchema: () => BadgeOptionsSchema,
36
+ BadgeSizeSchema: () => BadgeSizeSchema,
37
+ BadgeVariantSchema: () => BadgeVariantSchema,
38
+ ButtonGroupOptionsSchema: () => ButtonGroupOptionsSchema,
39
+ ButtonOptionsSchema: () => ButtonOptionsSchema,
40
+ ButtonSizeSchema: () => ButtonSizeSchema,
41
+ ButtonVariantSchema: () => ButtonVariantSchema,
42
+ CardGroupOptionsSchema: () => CardGroupOptionsSchema,
43
+ CardOptionsSchema: () => CardOptionsSchema,
44
+ CardSizeSchema: () => CardSizeSchema,
45
+ CardVariantSchema: () => CardVariantSchema,
46
+ CheckboxOptionsSchema: () => CheckboxOptionsSchema,
47
+ ConfirmModalOptionsSchema: () => ConfirmModalOptionsSchema,
48
+ ConfirmModalVariantSchema: () => ConfirmModalVariantSchema,
49
+ DescriptionItemSchema: () => DescriptionItemSchema,
50
+ DescriptionListOptionsSchema: () => DescriptionListOptionsSchema,
51
+ DrawerOptionsSchema: () => DrawerOptionsSchema,
52
+ DrawerPositionSchema: () => DrawerPositionSchema,
53
+ FeatureItemSchema: () => FeatureItemSchema,
54
+ FeatureListOptionsSchema: () => FeatureListOptionsSchema,
55
+ FormActionsOptionsSchema: () => FormActionsOptionsSchema,
56
+ FormEnctypeSchema: () => FormEnctypeSchema,
57
+ FormMethodSchema: () => FormMethodSchema,
58
+ FormOptionsSchema: () => FormOptionsSchema,
59
+ FormRowOptionsSchema: () => FormRowOptionsSchema,
60
+ FormSectionOptionsSchema: () => FormSectionOptionsSchema,
61
+ InputOptionsSchema: () => InputOptionsSchema,
62
+ InputSizeSchema: () => InputSizeSchema,
63
+ InputStateSchema: () => InputStateSchema,
64
+ InputTypeSchema: () => InputTypeSchema,
65
+ ModalOptionsSchema: () => ModalOptionsSchema,
66
+ ModalSizeSchema: () => ModalSizeSchema,
67
+ ModalTriggerOptionsSchema: () => ModalTriggerOptionsSchema,
68
+ PaginationOptionsSchema: () => PaginationOptionsSchema,
69
+ PermissionItemSchema: () => PermissionItemSchema,
70
+ PermissionListOptionsSchema: () => PermissionListOptionsSchema,
71
+ RadioGroupOptionsSchema: () => RadioGroupOptionsSchema,
72
+ RadioOptionItemSchema: () => RadioOptionItemSchema,
73
+ SelectOptionItemSchema: () => SelectOptionItemSchema,
74
+ SelectOptionsSchema: () => SelectOptionsSchema,
75
+ TableAlignSchema: () => TableAlignSchema,
76
+ TableColumnSchema: () => TableColumnSchema,
77
+ TableOptionsSchema: () => TableOptionsSchema,
78
+ TableSortDirectionSchema: () => TableSortDirectionSchema,
79
+ TextareaOptionsSchema: () => TextareaOptionsSchema,
80
+ TextareaResizeSchema: () => TextareaResizeSchema,
81
+ ToastOptionsSchema: () => ToastOptionsSchema,
82
+ ToastPositionSchema: () => ToastPositionSchema,
83
+ actionList: () => actionList,
84
+ activeBadge: () => activeBadge,
85
+ alert: () => alert,
86
+ avatar: () => avatar,
87
+ avatarGroup: () => avatarGroup,
88
+ avatarWithText: () => avatarWithText,
89
+ awayDot: () => awayDot,
90
+ badge: () => badge,
91
+ badgeGroup: () => badgeGroup,
92
+ betaBadge: () => betaBadge,
93
+ busyDot: () => busyDot,
94
+ button: () => button,
95
+ buttonGroup: () => buttonGroup,
96
+ card: () => card,
97
+ cardGroup: () => cardGroup,
98
+ checkbox: () => checkbox,
99
+ confirmModal: () => confirmModal,
100
+ csrfInput: () => csrfInput,
101
+ dangerAlert: () => dangerAlert,
102
+ dangerButton: () => dangerButton,
103
+ descriptionList: () => descriptionList,
104
+ drawer: () => drawer,
105
+ errorBadge: () => errorBadge,
106
+ featureList: () => featureList,
107
+ form: () => form,
108
+ formActions: () => formActions,
109
+ formRow: () => formRow,
110
+ formSection: () => formSection,
111
+ ghostButton: () => ghostButton,
112
+ hiddenInput: () => hiddenInput,
113
+ inactiveBadge: () => inactiveBadge,
114
+ infoAlert: () => infoAlert,
115
+ input: () => input,
116
+ linkButton: () => linkButton,
117
+ modal: () => modal,
118
+ modalTrigger: () => modalTrigger,
119
+ newBadge: () => newBadge,
120
+ offlineDot: () => offlineDot,
121
+ onlineDot: () => onlineDot,
122
+ outlineButton: () => outlineButton,
123
+ pagination: () => pagination,
124
+ pendingBadge: () => pendingBadge,
125
+ permissionList: () => permissionList,
126
+ primaryButton: () => primaryButton,
127
+ radioGroup: () => radioGroup,
128
+ secondaryButton: () => secondaryButton,
129
+ select: () => select,
130
+ successAlert: () => successAlert,
131
+ table: () => table,
132
+ textarea: () => textarea,
133
+ toast: () => toast,
134
+ toastContainer: () => toastContainer,
135
+ warningAlert: () => warningAlert
136
+ });
137
+ module.exports = __toCommonJS(components_exports);
138
+
139
+ // libs/ui/src/components/button.schema.ts
140
+ var import_zod = require("zod");
141
+ var ButtonVariantSchema = import_zod.z.enum(["primary", "secondary", "outline", "ghost", "danger", "success", "link"]);
142
+ var ButtonSizeSchema = import_zod.z.enum(["xs", "sm", "md", "lg", "xl"]);
143
+ var ButtonOptionsSchema = import_zod.z.object({
144
+ /** Button variant */
145
+ variant: ButtonVariantSchema.optional(),
146
+ /** Button size */
147
+ size: ButtonSizeSchema.optional(),
148
+ /** Button type attribute */
149
+ type: import_zod.z.enum(["button", "submit", "reset"]).optional(),
150
+ /** Disabled state */
151
+ disabled: import_zod.z.boolean().optional(),
152
+ /** Loading state */
153
+ loading: import_zod.z.boolean().optional(),
154
+ /** Full width */
155
+ fullWidth: import_zod.z.boolean().optional(),
156
+ /** Icon before text (HTML string) */
157
+ iconBefore: import_zod.z.string().optional(),
158
+ /** Icon after text (HTML string) */
159
+ iconAfter: import_zod.z.string().optional(),
160
+ /** Icon only (no text) */
161
+ iconOnly: import_zod.z.boolean().optional(),
162
+ /** Additional CSS classes */
163
+ className: import_zod.z.string().optional(),
164
+ /** Button ID */
165
+ id: import_zod.z.string().optional(),
166
+ /** Name attribute */
167
+ name: import_zod.z.string().optional(),
168
+ /** Value attribute */
169
+ value: import_zod.z.string().optional(),
170
+ /** Click handler (URL for links) */
171
+ href: import_zod.z.string().optional(),
172
+ /** Open in new tab */
173
+ target: import_zod.z.enum(["_blank", "_self"]).optional(),
174
+ /** Data attributes */
175
+ data: import_zod.z.record(import_zod.z.string(), import_zod.z.string()).optional(),
176
+ /** ARIA label */
177
+ ariaLabel: import_zod.z.string().optional()
178
+ }).strict();
179
+ var ButtonGroupOptionsSchema = import_zod.z.object({
180
+ /** Attach buttons visually */
181
+ attached: import_zod.z.boolean().optional(),
182
+ /** Direction */
183
+ direction: import_zod.z.enum(["horizontal", "vertical"]).optional(),
184
+ /** Gap between buttons */
185
+ gap: import_zod.z.enum(["sm", "md", "lg"]).optional(),
186
+ /** Additional CSS classes */
187
+ className: import_zod.z.string().optional()
188
+ }).strict();
189
+
190
+ // libs/ui/src/components/card.schema.ts
191
+ var import_zod2 = require("zod");
192
+ var CardVariantSchema = import_zod2.z.enum(["default", "outlined", "elevated", "filled", "ghost"]);
193
+ var CardSizeSchema = import_zod2.z.enum(["sm", "md", "lg"]);
194
+ var CardOptionsSchema = import_zod2.z.object({
195
+ /** Card variant */
196
+ variant: CardVariantSchema.optional(),
197
+ /** Card size (padding) */
198
+ size: CardSizeSchema.optional(),
199
+ /** Card title */
200
+ title: import_zod2.z.string().optional(),
201
+ /** Card subtitle/description */
202
+ subtitle: import_zod2.z.string().optional(),
203
+ /** Header actions (HTML string) */
204
+ headerActions: import_zod2.z.string().optional(),
205
+ /** Footer content (HTML string) */
206
+ footer: import_zod2.z.string().optional(),
207
+ /** Additional CSS classes */
208
+ className: import_zod2.z.string().optional(),
209
+ /** Card ID */
210
+ id: import_zod2.z.string().optional(),
211
+ /** Data attributes */
212
+ data: import_zod2.z.record(import_zod2.z.string(), import_zod2.z.string()).optional(),
213
+ /** Clickable card (adds hover effects) */
214
+ clickable: import_zod2.z.boolean().optional(),
215
+ /** Click handler URL */
216
+ href: import_zod2.z.string().optional()
217
+ }).strict();
218
+ var CardGroupOptionsSchema = import_zod2.z.object({
219
+ /** Direction */
220
+ direction: import_zod2.z.enum(["horizontal", "vertical"]).optional(),
221
+ /** Gap between cards */
222
+ gap: import_zod2.z.enum(["sm", "md", "lg"]).optional(),
223
+ /** Additional CSS classes */
224
+ className: import_zod2.z.string().optional()
225
+ }).strict();
226
+
227
+ // libs/ui/src/components/badge.schema.ts
228
+ var import_zod3 = require("zod");
229
+ var BadgeVariantSchema = import_zod3.z.enum([
230
+ "default",
231
+ "primary",
232
+ "secondary",
233
+ "success",
234
+ "warning",
235
+ "danger",
236
+ "info",
237
+ "outline"
238
+ ]);
239
+ var BadgeSizeSchema = import_zod3.z.enum(["sm", "md", "lg"]);
240
+ var BadgeOptionsSchema = import_zod3.z.object({
241
+ /** Badge variant */
242
+ variant: BadgeVariantSchema.optional(),
243
+ /** Badge size */
244
+ size: BadgeSizeSchema.optional(),
245
+ /** Rounded pill style */
246
+ pill: import_zod3.z.boolean().optional(),
247
+ /** Icon before text (HTML string) */
248
+ icon: import_zod3.z.string().optional(),
249
+ /** Dot indicator (no text) */
250
+ dot: import_zod3.z.boolean().optional(),
251
+ /** Additional CSS classes */
252
+ className: import_zod3.z.string().optional(),
253
+ /** Removable badge */
254
+ removable: import_zod3.z.boolean().optional()
255
+ }).strict();
256
+ var BadgeGroupOptionsSchema = import_zod3.z.object({
257
+ /** Gap between badges */
258
+ gap: import_zod3.z.enum(["sm", "md", "lg"]).optional(),
259
+ /** Additional CSS classes */
260
+ className: import_zod3.z.string().optional()
261
+ }).strict();
262
+
263
+ // libs/ui/src/components/alert.schema.ts
264
+ var import_zod4 = require("zod");
265
+ var AlertVariantSchema = import_zod4.z.enum(["info", "success", "warning", "danger", "neutral"]);
266
+ var AlertOptionsSchema = import_zod4.z.object({
267
+ /** Alert variant */
268
+ variant: AlertVariantSchema.optional(),
269
+ /** Alert title */
270
+ title: import_zod4.z.string().optional(),
271
+ /** Show icon */
272
+ showIcon: import_zod4.z.boolean().optional(),
273
+ /** Custom icon (HTML string, overrides default) */
274
+ icon: import_zod4.z.string().optional(),
275
+ /** Dismissible alert */
276
+ dismissible: import_zod4.z.boolean().optional(),
277
+ /** Additional CSS classes */
278
+ className: import_zod4.z.string().optional(),
279
+ /** Alert ID */
280
+ id: import_zod4.z.string().optional(),
281
+ /** Actions (HTML string for buttons) */
282
+ actions: import_zod4.z.string().optional()
283
+ }).strict();
284
+ var ToastPositionSchema = import_zod4.z.enum([
285
+ "top-right",
286
+ "top-left",
287
+ "bottom-right",
288
+ "bottom-left",
289
+ "top-center",
290
+ "bottom-center"
291
+ ]);
292
+ var ToastOptionsSchema = import_zod4.z.object({
293
+ /** Toast variant */
294
+ variant: AlertVariantSchema.optional(),
295
+ /** Toast title */
296
+ title: import_zod4.z.string().optional(),
297
+ /** Duration in ms (0 = no auto-dismiss) */
298
+ duration: import_zod4.z.number().min(0).optional(),
299
+ /** Position */
300
+ position: ToastPositionSchema.optional(),
301
+ /** Toast ID */
302
+ id: import_zod4.z.string().optional()
303
+ }).strict();
304
+
305
+ // libs/ui/src/components/avatar.schema.ts
306
+ var import_zod5 = require("zod");
307
+ var AvatarSizeSchema = import_zod5.z.enum(["xs", "sm", "md", "lg", "xl", "2xl"]);
308
+ var AvatarShapeSchema = import_zod5.z.enum(["circle", "square", "rounded"]);
309
+ var AvatarStatusSchema = import_zod5.z.enum(["online", "offline", "busy", "away", "none"]);
310
+ var AvatarOptionsSchema = import_zod5.z.object({
311
+ /** Image source URL */
312
+ src: import_zod5.z.string().optional(),
313
+ /** Alt text / name (required) */
314
+ alt: import_zod5.z.string(),
315
+ /** Avatar size */
316
+ size: AvatarSizeSchema.optional(),
317
+ /** Avatar shape */
318
+ shape: AvatarShapeSchema.optional(),
319
+ /** Status indicator */
320
+ status: AvatarStatusSchema.optional(),
321
+ /** Additional CSS classes */
322
+ className: import_zod5.z.string().optional(),
323
+ /** Click handler URL */
324
+ href: import_zod5.z.string().optional(),
325
+ /** Custom initials (overrides auto-generation) */
326
+ initials: import_zod5.z.string().optional(),
327
+ /** Background color for initials (CSS color) */
328
+ bgColor: import_zod5.z.string().optional()
329
+ }).strict();
330
+ var AvatarSpacingSchema = import_zod5.z.enum(["tight", "normal", "loose"]);
331
+ var AvatarGroupOptionsSchema = import_zod5.z.object({
332
+ /** Maximum visible avatars */
333
+ max: import_zod5.z.number().min(1).optional(),
334
+ /** Avatar size */
335
+ size: AvatarSizeSchema.optional(),
336
+ /** Overlap amount */
337
+ spacing: AvatarSpacingSchema.optional(),
338
+ /** Additional CSS classes */
339
+ className: import_zod5.z.string().optional()
340
+ }).strict();
341
+ var AvatarWithTextOptionsSchema = AvatarOptionsSchema.extend({
342
+ /** Primary text (name) */
343
+ name: import_zod5.z.string(),
344
+ /** Secondary text (email, role, etc.) */
345
+ subtitle: import_zod5.z.string().optional(),
346
+ /** Text alignment */
347
+ align: import_zod5.z.enum(["left", "right"]).optional()
348
+ }).strict();
349
+
350
+ // libs/ui/src/components/modal.schema.ts
351
+ var import_zod6 = require("zod");
352
+ var ModalSizeSchema = import_zod6.z.enum(["sm", "md", "lg", "xl", "full"]);
353
+ var ModalOptionsSchema = import_zod6.z.object({
354
+ /** Modal ID (required) */
355
+ id: import_zod6.z.string(),
356
+ /** Modal title */
357
+ title: import_zod6.z.string().optional(),
358
+ /** Modal size */
359
+ size: ModalSizeSchema.optional(),
360
+ /** Show close button */
361
+ showClose: import_zod6.z.boolean().optional(),
362
+ /** Close on backdrop click */
363
+ closeOnBackdrop: import_zod6.z.boolean().optional(),
364
+ /** Close on escape key */
365
+ closeOnEscape: import_zod6.z.boolean().optional(),
366
+ /** Footer content (HTML string) */
367
+ footer: import_zod6.z.string().optional(),
368
+ /** Additional CSS classes for modal */
369
+ className: import_zod6.z.string().optional(),
370
+ /** Initially visible */
371
+ open: import_zod6.z.boolean().optional()
372
+ }).strict();
373
+ var ConfirmModalVariantSchema = import_zod6.z.enum(["info", "warning", "danger"]);
374
+ var ConfirmModalOptionsSchema = import_zod6.z.object({
375
+ /** Modal ID (required) */
376
+ id: import_zod6.z.string(),
377
+ /** Confirm message */
378
+ message: import_zod6.z.string(),
379
+ /** Title */
380
+ title: import_zod6.z.string().optional(),
381
+ /** Variant/severity */
382
+ variant: ConfirmModalVariantSchema.optional(),
383
+ /** Confirm button text */
384
+ confirmText: import_zod6.z.string().optional(),
385
+ /** Cancel button text */
386
+ cancelText: import_zod6.z.string().optional(),
387
+ /** Initially visible */
388
+ open: import_zod6.z.boolean().optional(),
389
+ /** Confirm action URL */
390
+ confirmHref: import_zod6.z.string().optional()
391
+ }).strict();
392
+ var DrawerPositionSchema = import_zod6.z.enum(["left", "right", "top", "bottom"]);
393
+ var DrawerOptionsSchema = import_zod6.z.object({
394
+ /** Drawer ID (required) */
395
+ id: import_zod6.z.string(),
396
+ /** Position */
397
+ position: DrawerPositionSchema.optional(),
398
+ /** Size (width for left/right, height for top/bottom) */
399
+ size: ModalSizeSchema.optional(),
400
+ /** Drawer title */
401
+ title: import_zod6.z.string().optional(),
402
+ /** Show close button */
403
+ showClose: import_zod6.z.boolean().optional(),
404
+ /** Footer content (HTML string) */
405
+ footer: import_zod6.z.string().optional(),
406
+ /** Additional CSS classes */
407
+ className: import_zod6.z.string().optional(),
408
+ /** Initially visible */
409
+ open: import_zod6.z.boolean().optional()
410
+ }).strict();
411
+ var ModalTriggerOptionsSchema = import_zod6.z.object({
412
+ /** Target modal ID (required) */
413
+ targetId: import_zod6.z.string(),
414
+ /** Trigger text */
415
+ text: import_zod6.z.string().optional(),
416
+ /** HTML tag to use */
417
+ tag: import_zod6.z.enum(["button", "a", "span", "div"]).optional(),
418
+ /** Additional CSS classes */
419
+ className: import_zod6.z.string().optional()
420
+ }).strict();
421
+
422
+ // libs/ui/src/components/table.schema.ts
423
+ var import_zod7 = require("zod");
424
+ var TableAlignSchema = import_zod7.z.enum(["left", "center", "right"]);
425
+ var TableSortDirectionSchema = import_zod7.z.enum(["asc", "desc"]).nullable();
426
+ var TableColumnSchema = import_zod7.z.object({
427
+ /** Column key (property name) */
428
+ key: import_zod7.z.string(),
429
+ /** Column header text */
430
+ header: import_zod7.z.string(),
431
+ /** Column width (CSS value) */
432
+ width: import_zod7.z.string().optional(),
433
+ /** Text alignment */
434
+ align: TableAlignSchema.optional(),
435
+ /** Sortable column */
436
+ sortable: import_zod7.z.boolean().optional(),
437
+ /** Current sort direction */
438
+ sortDirection: TableSortDirectionSchema.optional(),
439
+ /** Custom cell renderer (function - cannot validate at runtime) */
440
+ render: import_zod7.z.any().optional(),
441
+ /** Additional header CSS classes */
442
+ headerClass: import_zod7.z.string().optional(),
443
+ /** Additional cell CSS classes */
444
+ cellClass: import_zod7.z.string().optional()
445
+ }).strict();
446
+ var TableOptionsSchema = import_zod7.z.object({
447
+ /** Column definitions */
448
+ columns: import_zod7.z.array(TableColumnSchema),
449
+ /** Table ID */
450
+ id: import_zod7.z.string().optional(),
451
+ /** Show row selection checkboxes */
452
+ selectable: import_zod7.z.boolean().optional(),
453
+ /** Row hover effect */
454
+ hoverable: import_zod7.z.boolean().optional(),
455
+ /** Striped rows */
456
+ striped: import_zod7.z.boolean().optional(),
457
+ /** Bordered cells */
458
+ bordered: import_zod7.z.boolean().optional(),
459
+ /** Compact size */
460
+ compact: import_zod7.z.boolean().optional(),
461
+ /** Fixed header (sticky) */
462
+ stickyHeader: import_zod7.z.boolean().optional(),
463
+ /** Additional CSS classes */
464
+ className: import_zod7.z.string().optional(),
465
+ /** Empty state message */
466
+ emptyMessage: import_zod7.z.string().optional(),
467
+ /** Empty state HTML */
468
+ emptyContent: import_zod7.z.string().optional(),
469
+ /** Loading state */
470
+ loading: import_zod7.z.boolean().optional(),
471
+ /** Row key property for selection */
472
+ rowKey: import_zod7.z.string().optional(),
473
+ /** Row click handler (URL template with {key}) */
474
+ onRowClick: import_zod7.z.string().optional()
475
+ }).strict();
476
+ var PaginationOptionsSchema = import_zod7.z.object({
477
+ /** Current page (1-indexed) */
478
+ page: import_zod7.z.number().min(1),
479
+ /** Total pages */
480
+ totalPages: import_zod7.z.number().min(0),
481
+ /** Total items count */
482
+ totalItems: import_zod7.z.number().min(0).optional(),
483
+ /** Items per page */
484
+ pageSize: import_zod7.z.number().min(1).optional(),
485
+ /** Page size options */
486
+ pageSizeOptions: import_zod7.z.array(import_zod7.z.number()).optional(),
487
+ /** Show first/last buttons */
488
+ showFirstLast: import_zod7.z.boolean().optional(),
489
+ /** Show page count */
490
+ showPageCount: import_zod7.z.boolean().optional(),
491
+ /** Show item count */
492
+ showItemCount: import_zod7.z.boolean().optional(),
493
+ /** Show page size selector */
494
+ showPageSize: import_zod7.z.boolean().optional(),
495
+ /** Max visible page buttons */
496
+ maxVisiblePages: import_zod7.z.number().min(1).optional(),
497
+ /** Additional CSS classes */
498
+ className: import_zod7.z.string().optional()
499
+ }).strict();
500
+
501
+ // libs/ui/src/components/form.schema.ts
502
+ var import_zod8 = require("zod");
503
+ var InputTypeSchema = import_zod8.z.enum([
504
+ "text",
505
+ "email",
506
+ "password",
507
+ "number",
508
+ "tel",
509
+ "url",
510
+ "search",
511
+ "date",
512
+ "time",
513
+ "datetime-local",
514
+ "hidden"
515
+ ]);
516
+ var InputSizeSchema = import_zod8.z.enum(["sm", "md", "lg"]);
517
+ var InputStateSchema = import_zod8.z.enum(["default", "error", "success", "warning"]);
518
+ var InputOptionsSchema = import_zod8.z.object({
519
+ /** Input type */
520
+ type: InputTypeSchema.optional(),
521
+ /** Input name (required) */
522
+ name: import_zod8.z.string(),
523
+ /** Input ID (defaults to name) */
524
+ id: import_zod8.z.string().optional(),
525
+ /** Input value */
526
+ value: import_zod8.z.string().optional(),
527
+ /** Placeholder text */
528
+ placeholder: import_zod8.z.string().optional(),
529
+ /** Label text */
530
+ label: import_zod8.z.string().optional(),
531
+ /** Helper text */
532
+ helper: import_zod8.z.string().optional(),
533
+ /** Error message */
534
+ error: import_zod8.z.string().optional(),
535
+ /** Input size */
536
+ size: InputSizeSchema.optional(),
537
+ /** Input state */
538
+ state: InputStateSchema.optional(),
539
+ /** Required field */
540
+ required: import_zod8.z.boolean().optional(),
541
+ /** Disabled state */
542
+ disabled: import_zod8.z.boolean().optional(),
543
+ /** Readonly state */
544
+ readonly: import_zod8.z.boolean().optional(),
545
+ /** Autocomplete attribute */
546
+ autocomplete: import_zod8.z.string().optional(),
547
+ /** Pattern for validation */
548
+ pattern: import_zod8.z.string().optional(),
549
+ /** Min value (for number/date) */
550
+ min: import_zod8.z.union([import_zod8.z.string(), import_zod8.z.number()]).optional(),
551
+ /** Max value (for number/date) */
552
+ max: import_zod8.z.union([import_zod8.z.string(), import_zod8.z.number()]).optional(),
553
+ /** Step value (for number) */
554
+ step: import_zod8.z.union([import_zod8.z.string(), import_zod8.z.number()]).optional(),
555
+ /** Additional CSS classes */
556
+ className: import_zod8.z.string().optional(),
557
+ /** Data attributes */
558
+ data: import_zod8.z.record(import_zod8.z.string(), import_zod8.z.string()).optional(),
559
+ /** Icon before input (HTML string) */
560
+ iconBefore: import_zod8.z.string().optional(),
561
+ /** Icon after input (HTML string) */
562
+ iconAfter: import_zod8.z.string().optional()
563
+ }).strict();
564
+ var SelectOptionItemSchema = import_zod8.z.object({
565
+ value: import_zod8.z.string(),
566
+ label: import_zod8.z.string(),
567
+ disabled: import_zod8.z.boolean().optional(),
568
+ selected: import_zod8.z.boolean().optional()
569
+ }).strict();
570
+ var SelectOptionsSchema = import_zod8.z.object({
571
+ /** Input name (required) */
572
+ name: import_zod8.z.string(),
573
+ /** Input ID (defaults to name) */
574
+ id: import_zod8.z.string().optional(),
575
+ /** Input value */
576
+ value: import_zod8.z.string().optional(),
577
+ /** Placeholder text */
578
+ placeholder: import_zod8.z.string().optional(),
579
+ /** Label text */
580
+ label: import_zod8.z.string().optional(),
581
+ /** Helper text */
582
+ helper: import_zod8.z.string().optional(),
583
+ /** Error message */
584
+ error: import_zod8.z.string().optional(),
585
+ /** Input size */
586
+ size: InputSizeSchema.optional(),
587
+ /** Input state */
588
+ state: InputStateSchema.optional(),
589
+ /** Required field */
590
+ required: import_zod8.z.boolean().optional(),
591
+ /** Disabled state */
592
+ disabled: import_zod8.z.boolean().optional(),
593
+ /** Readonly state */
594
+ readonly: import_zod8.z.boolean().optional(),
595
+ /** Additional CSS classes */
596
+ className: import_zod8.z.string().optional(),
597
+ /** Data attributes */
598
+ data: import_zod8.z.record(import_zod8.z.string(), import_zod8.z.string()).optional(),
599
+ /** Icon before input (HTML string) */
600
+ iconBefore: import_zod8.z.string().optional(),
601
+ /** Icon after input (HTML string) */
602
+ iconAfter: import_zod8.z.string().optional(),
603
+ /** Select options (required) */
604
+ options: import_zod8.z.array(SelectOptionItemSchema),
605
+ /** Multiple selection */
606
+ multiple: import_zod8.z.boolean().optional()
607
+ }).strict();
608
+ var TextareaResizeSchema = import_zod8.z.enum(["none", "vertical", "horizontal", "both"]);
609
+ var TextareaOptionsSchema = import_zod8.z.object({
610
+ /** Input name (required) */
611
+ name: import_zod8.z.string(),
612
+ /** Input ID (defaults to name) */
613
+ id: import_zod8.z.string().optional(),
614
+ /** Input value */
615
+ value: import_zod8.z.string().optional(),
616
+ /** Placeholder text */
617
+ placeholder: import_zod8.z.string().optional(),
618
+ /** Label text */
619
+ label: import_zod8.z.string().optional(),
620
+ /** Helper text */
621
+ helper: import_zod8.z.string().optional(),
622
+ /** Error message */
623
+ error: import_zod8.z.string().optional(),
624
+ /** Input size */
625
+ size: InputSizeSchema.optional(),
626
+ /** Input state */
627
+ state: InputStateSchema.optional(),
628
+ /** Required field */
629
+ required: import_zod8.z.boolean().optional(),
630
+ /** Disabled state */
631
+ disabled: import_zod8.z.boolean().optional(),
632
+ /** Readonly state */
633
+ readonly: import_zod8.z.boolean().optional(),
634
+ /** Autocomplete attribute */
635
+ autocomplete: import_zod8.z.string().optional(),
636
+ /** Additional CSS classes */
637
+ className: import_zod8.z.string().optional(),
638
+ /** Data attributes */
639
+ data: import_zod8.z.record(import_zod8.z.string(), import_zod8.z.string()).optional(),
640
+ /** Icon before input (HTML string) */
641
+ iconBefore: import_zod8.z.string().optional(),
642
+ /** Icon after input (HTML string) */
643
+ iconAfter: import_zod8.z.string().optional(),
644
+ /** Number of rows */
645
+ rows: import_zod8.z.number().min(1).optional(),
646
+ /** Resize behavior */
647
+ resize: TextareaResizeSchema.optional()
648
+ }).strict();
649
+ var CheckboxOptionsSchema = import_zod8.z.object({
650
+ /** Input name (required) */
651
+ name: import_zod8.z.string(),
652
+ /** Input ID */
653
+ id: import_zod8.z.string().optional(),
654
+ /** Input value */
655
+ value: import_zod8.z.string().optional(),
656
+ /** Label text (required) */
657
+ label: import_zod8.z.string(),
658
+ /** Checked state */
659
+ checked: import_zod8.z.boolean().optional(),
660
+ /** Disabled state */
661
+ disabled: import_zod8.z.boolean().optional(),
662
+ /** Helper text */
663
+ helper: import_zod8.z.string().optional(),
664
+ /** Error message */
665
+ error: import_zod8.z.string().optional(),
666
+ /** Additional CSS classes */
667
+ className: import_zod8.z.string().optional()
668
+ }).strict();
669
+ var RadioOptionItemSchema = import_zod8.z.object({
670
+ value: import_zod8.z.string(),
671
+ label: import_zod8.z.string(),
672
+ disabled: import_zod8.z.boolean().optional()
673
+ }).strict();
674
+ var RadioGroupOptionsSchema = import_zod8.z.object({
675
+ /** Group name (required) */
676
+ name: import_zod8.z.string(),
677
+ /** Radio options (required) */
678
+ options: import_zod8.z.array(RadioOptionItemSchema),
679
+ /** Selected value */
680
+ value: import_zod8.z.string().optional(),
681
+ /** Label for the group */
682
+ label: import_zod8.z.string().optional(),
683
+ /** Helper text */
684
+ helper: import_zod8.z.string().optional(),
685
+ /** Error message */
686
+ error: import_zod8.z.string().optional(),
687
+ /** Layout direction */
688
+ direction: import_zod8.z.enum(["horizontal", "vertical"]).optional(),
689
+ /** Additional CSS classes */
690
+ className: import_zod8.z.string().optional()
691
+ }).strict();
692
+ var FormMethodSchema = import_zod8.z.enum(["get", "post", "dialog"]);
693
+ var FormEnctypeSchema = import_zod8.z.enum(["application/x-www-form-urlencoded", "multipart/form-data", "text/plain"]);
694
+ var FormOptionsSchema = import_zod8.z.object({
695
+ /** Form action URL */
696
+ action: import_zod8.z.string().optional(),
697
+ /** Form method */
698
+ method: FormMethodSchema.optional(),
699
+ /** Form ID */
700
+ id: import_zod8.z.string().optional(),
701
+ /** Form enctype */
702
+ enctype: FormEnctypeSchema.optional(),
703
+ /** Disable browser validation */
704
+ novalidate: import_zod8.z.boolean().optional(),
705
+ /** Autocomplete behavior */
706
+ autocomplete: import_zod8.z.enum(["on", "off"]).optional(),
707
+ /** Additional CSS classes */
708
+ className: import_zod8.z.string().optional()
709
+ }).strict();
710
+ var FormRowOptionsSchema = import_zod8.z.object({
711
+ /** Number of columns */
712
+ cols: import_zod8.z.number().min(1).max(12).optional(),
713
+ /** Gap between columns */
714
+ gap: import_zod8.z.enum(["sm", "md", "lg"]).optional(),
715
+ /** Additional CSS classes */
716
+ className: import_zod8.z.string().optional()
717
+ }).strict();
718
+ var FormSectionOptionsSchema = import_zod8.z.object({
719
+ /** Section title */
720
+ title: import_zod8.z.string().optional(),
721
+ /** Section description */
722
+ description: import_zod8.z.string().optional(),
723
+ /** Additional CSS classes */
724
+ className: import_zod8.z.string().optional()
725
+ }).strict();
726
+ var FormActionsOptionsSchema = import_zod8.z.object({
727
+ /** Alignment */
728
+ align: import_zod8.z.enum(["left", "center", "right", "between"]).optional(),
729
+ /** Additional CSS classes */
730
+ className: import_zod8.z.string().optional()
731
+ }).strict();
732
+
733
+ // libs/ui/src/components/list.schema.ts
734
+ var import_zod9 = require("zod");
735
+ var PermissionItemSchema = import_zod9.z.object({
736
+ /** Scope identifier */
737
+ scope: import_zod9.z.string(),
738
+ /** Display name */
739
+ name: import_zod9.z.string(),
740
+ /** Description */
741
+ description: import_zod9.z.string().optional(),
742
+ /** Icon HTML */
743
+ icon: import_zod9.z.string().optional(),
744
+ /** Required permission (cannot be unchecked) */
745
+ required: import_zod9.z.boolean().optional(),
746
+ /** Checked by default */
747
+ checked: import_zod9.z.boolean().optional(),
748
+ /** Sensitive/dangerous permission */
749
+ sensitive: import_zod9.z.boolean().optional()
750
+ }).strict();
751
+ var PermissionListOptionsSchema = import_zod9.z.object({
752
+ /** List ID */
753
+ id: import_zod9.z.string().optional(),
754
+ /** Checkable permissions */
755
+ checkable: import_zod9.z.boolean().optional(),
756
+ /** Input name for checkable */
757
+ inputName: import_zod9.z.string().optional(),
758
+ /** Group title */
759
+ title: import_zod9.z.string().optional(),
760
+ /** Additional CSS classes */
761
+ className: import_zod9.z.string().optional()
762
+ }).strict();
763
+ var FeatureItemSchema = import_zod9.z.object({
764
+ /** Feature name */
765
+ name: import_zod9.z.string(),
766
+ /** Feature description */
767
+ description: import_zod9.z.string().optional(),
768
+ /** Icon HTML */
769
+ icon: import_zod9.z.string().optional(),
770
+ /** Included in plan */
771
+ included: import_zod9.z.boolean().optional()
772
+ }).strict();
773
+ var FeatureListOptionsSchema = import_zod9.z.object({
774
+ /** Group title */
775
+ title: import_zod9.z.string().optional(),
776
+ /** Show included/excluded styling */
777
+ showStatus: import_zod9.z.boolean().optional(),
778
+ /** Additional CSS classes */
779
+ className: import_zod9.z.string().optional()
780
+ }).strict();
781
+ var DescriptionItemSchema = import_zod9.z.object({
782
+ /** Term/label */
783
+ term: import_zod9.z.string(),
784
+ /** Description/value */
785
+ description: import_zod9.z.string(),
786
+ /** Copy button */
787
+ copyable: import_zod9.z.boolean().optional()
788
+ }).strict();
789
+ var DescriptionListOptionsSchema = import_zod9.z.object({
790
+ /** Layout direction */
791
+ direction: import_zod9.z.enum(["horizontal", "vertical"]).optional(),
792
+ /** Striped rows */
793
+ striped: import_zod9.z.boolean().optional(),
794
+ /** Additional CSS classes */
795
+ className: import_zod9.z.string().optional()
796
+ }).strict();
797
+ var ActionItemSchema = import_zod9.z.object({
798
+ /** Action label */
799
+ label: import_zod9.z.string(),
800
+ /** Action description */
801
+ description: import_zod9.z.string().optional(),
802
+ /** Icon HTML */
803
+ icon: import_zod9.z.string().optional(),
804
+ /** Click URL */
805
+ href: import_zod9.z.string().optional(),
806
+ /** Destructive action styling */
807
+ destructive: import_zod9.z.boolean().optional(),
808
+ /** Disabled state */
809
+ disabled: import_zod9.z.boolean().optional()
810
+ }).strict();
811
+ var ActionListOptionsSchema = import_zod9.z.object({
812
+ /** Divided items */
813
+ divided: import_zod9.z.boolean().optional(),
814
+ /** Additional CSS classes */
815
+ className: import_zod9.z.string().optional()
816
+ }).strict();
817
+
818
+ // libs/ui/src/theme/platforms.ts
819
+ var CLAUDE_PLATFORM = {
820
+ id: "claude",
821
+ name: "Claude (Artifacts)",
822
+ supportsWidgets: true,
823
+ supportsTailwind: true,
824
+ supportsHtmx: false,
825
+ // Network blocked, HTMX won't work for API calls
826
+ networkMode: "blocked",
827
+ scriptStrategy: "inline",
828
+ maxInlineSize: 100 * 1024,
829
+ // 100KB limit for artifacts
830
+ cspRestrictions: ["script-src 'unsafe-inline'", "connect-src 'none'"],
831
+ options: {
832
+ mode: "artifacts",
833
+ framework: "react"
834
+ // Claude artifacts prefer React
835
+ }
836
+ };
837
+
838
+ // libs/ui/src/utils/escape-html.ts
839
+ function escapeHtml(str) {
840
+ if (str === null || str === void 0) {
841
+ return "";
842
+ }
843
+ const s = String(str);
844
+ return s.replace(/&/g, "&amp;").replace(/</g, "&lt;").replace(/>/g, "&gt;").replace(/"/g, "&quot;").replace(/'/g, "&#39;").replace(/\u2028/g, "\\u2028").replace(/\u2029/g, "\\u2029");
845
+ }
846
+
847
+ // libs/ui/src/validation/error-box.ts
848
+ var errorIcon = `<svg class="w-5 h-5 flex-shrink-0" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
849
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-3L13.732 4c-.77-1.333-2.694-1.333-3.464 0L3.34 16c-.77 1.333.192 3 1.732 3z"/>
850
+ </svg>`;
851
+ function validationErrorBox(options) {
852
+ const { componentName, invalidParam } = options;
853
+ return `<div
854
+ class="validation-error flex items-start gap-3 p-4 bg-red-50 border border-red-200 text-red-800 rounded-lg"
855
+ role="alert"
856
+ data-testid="validation-error"
857
+ data-component="${escapeHtml(componentName)}"
858
+ data-param="${escapeHtml(invalidParam)}"
859
+ >
860
+ ${errorIcon}
861
+ <div class="min-w-0">
862
+ <p class="font-semibold text-sm">${escapeHtml(componentName)}: Invalid Configuration</p>
863
+ <p class="text-sm opacity-90 mt-0.5">The "${escapeHtml(invalidParam)}" parameter is invalid.</p>
864
+ </div>
865
+ </div>`;
866
+ }
867
+
868
+ // libs/ui/src/validation/wrapper.ts
869
+ function getFirstInvalidPath(error) {
870
+ const firstError = error.issues[0];
871
+ if (!firstError || firstError.path.length === 0) {
872
+ return "options";
873
+ }
874
+ return firstError.path.map(String).join(".");
875
+ }
876
+ function validateOptions(options, config) {
877
+ const result = config.schema.safeParse(options);
878
+ if (result.success) {
879
+ return { success: true, data: result.data };
880
+ }
881
+ const invalidParam = getFirstInvalidPath(result.error);
882
+ return {
883
+ success: false,
884
+ error: validationErrorBox({
885
+ componentName: config.componentName,
886
+ invalidParam
887
+ })
888
+ };
889
+ }
890
+
891
+ // libs/ui/src/validation/schema-paths.ts
892
+ var import_zod10 = require("zod");
893
+
894
+ // libs/ui/src/components/button.ts
895
+ function getVariantClasses(variant) {
896
+ const variants = {
897
+ primary: "bg-primary hover:bg-primary/90 text-white shadow-sm",
898
+ secondary: "bg-secondary hover:bg-secondary/90 text-white shadow-sm",
899
+ outline: "border-2 border-primary text-primary hover:bg-primary/10",
900
+ ghost: "text-text-primary hover:bg-gray-100",
901
+ danger: "bg-danger hover:bg-danger/90 text-white shadow-sm",
902
+ success: "bg-success hover:bg-success/90 text-white shadow-sm",
903
+ link: "text-primary hover:text-primary/80 hover:underline"
904
+ };
905
+ return variants[variant];
906
+ }
907
+ function getSizeClasses(size, iconOnly) {
908
+ if (iconOnly) {
909
+ const iconSizes = {
910
+ xs: "p-1.5",
911
+ sm: "p-2",
912
+ md: "p-2.5",
913
+ lg: "p-3",
914
+ xl: "p-4"
915
+ };
916
+ return iconSizes[size];
917
+ }
918
+ const sizes = {
919
+ xs: "px-2.5 py-1.5 text-xs",
920
+ sm: "px-3 py-2 text-sm",
921
+ md: "px-4 py-2.5 text-sm",
922
+ lg: "px-5 py-3 text-base",
923
+ xl: "px-6 py-3.5 text-lg"
924
+ };
925
+ return sizes[size];
926
+ }
927
+ function sanitizeDataKey(key) {
928
+ const sanitized = key.toLowerCase().replace(/[^a-z0-9_-]/g, "-").replace(/-+/g, "-").replace(/^-|-$/g, "");
929
+ if (!sanitized) {
930
+ console.warn(`[frontmcp/ui] Dropping invalid data-* key: "${key}"`);
931
+ return null;
932
+ }
933
+ return sanitized;
934
+ }
935
+ var loadingSpinner = `<svg class="animate-spin -ml-1 mr-2 h-4 w-4" fill="none" viewBox="0 0 24 24">
936
+ <circle class="opacity-25" cx="12" cy="12" r="10" stroke="currentColor" stroke-width="4"></circle>
937
+ <path class="opacity-75" fill="currentColor" d="M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"></path>
938
+ </svg>`;
939
+ function isValidHrefProtocol(href) {
940
+ const trimmed = href.trim().toLowerCase();
941
+ return trimmed.startsWith("http://") || trimmed.startsWith("https://") || trimmed.startsWith("/") || trimmed.startsWith("#") || trimmed.startsWith("mailto:") || trimmed.startsWith("tel:");
942
+ }
943
+ function button(text, options = {}) {
944
+ const validation = validateOptions(options, {
945
+ schema: ButtonOptionsSchema,
946
+ componentName: "button"
947
+ });
948
+ if (!validation.success) {
949
+ return validation.error;
950
+ }
951
+ const validatedOptions = validation.data;
952
+ const {
953
+ variant = "primary",
954
+ size = "md",
955
+ type = "button",
956
+ disabled = false,
957
+ loading = false,
958
+ fullWidth = false,
959
+ iconBefore,
960
+ iconAfter,
961
+ iconOnly = false,
962
+ className = "",
963
+ id,
964
+ name,
965
+ value,
966
+ href,
967
+ target,
968
+ data,
969
+ ariaLabel
970
+ } = validatedOptions;
971
+ if (!iconOnly && !text.trim()) {
972
+ console.warn("[frontmcp/ui] Button has empty text. Consider providing text or using iconOnly with ariaLabel.");
973
+ }
974
+ if (iconOnly && !ariaLabel && !text.trim()) {
975
+ console.warn(
976
+ "[frontmcp/ui] iconOnly button requires non-empty text or ariaLabel for accessibility; control will have no label."
977
+ );
978
+ }
979
+ if (href && !isValidHrefProtocol(href)) {
980
+ console.warn(`[frontmcp/ui] Button href contains potentially dangerous protocol: "${href.slice(0, 20)}..."`);
981
+ }
982
+ const variantClasses = getVariantClasses(variant);
983
+ const sizeClasses = getSizeClasses(size, iconOnly);
984
+ const safeClassName = className ? escapeHtml(className) : "";
985
+ const baseClasses = [
986
+ "inline-flex items-center justify-center",
987
+ "font-medium",
988
+ "rounded-lg",
989
+ "transition-colors duration-200",
990
+ "focus:outline-none focus:ring-2 focus:ring-primary/50 focus:ring-offset-2",
991
+ disabled || loading ? "opacity-50 cursor-not-allowed" : "cursor-pointer",
992
+ fullWidth ? "w-full" : "",
993
+ variantClasses,
994
+ sizeClasses,
995
+ safeClassName
996
+ ].filter(Boolean).join(" ");
997
+ const dataAttrs = data ? Object.entries(data).map(([key, val]) => {
998
+ const safeKey = sanitizeDataKey(key);
999
+ return safeKey ? `data-${safeKey}="${escapeHtml(val)}"` : "";
1000
+ }).filter(Boolean).join(" ") : "";
1001
+ const idAttr = id ? `id="${escapeHtml(id)}"` : "";
1002
+ const nameAttr = name ? `name="${escapeHtml(name)}"` : "";
1003
+ const valueAttr = value ? `value="${escapeHtml(value)}"` : "";
1004
+ const disabledAttr = disabled || loading ? "disabled" : "";
1005
+ const targetAttr = target ? `target="${escapeHtml(target)}"` : "";
1006
+ const relAttr = target === "_blank" ? 'rel="noopener noreferrer"' : "";
1007
+ const trimmedText = text.trim();
1008
+ const effectiveAriaLabel = ariaLabel ?? (iconOnly && trimmedText ? trimmedText : void 0);
1009
+ const ariaLabelAttr = effectiveAriaLabel ? `aria-label="${escapeHtml(effectiveAriaLabel)}"` : "";
1010
+ const iconBeforeHtml = iconBefore && !loading ? `<span class="${iconOnly ? "" : "mr-2"}">${iconBefore}</span>` : "";
1011
+ const iconAfterHtml = iconAfter && !loading ? `<span class="${iconOnly ? "" : "ml-2"}">${iconAfter}</span>` : "";
1012
+ const loadingHtml = loading ? loadingSpinner : "";
1013
+ const textHtml = iconOnly ? "" : escapeHtml(text);
1014
+ const contentHtml = `${loadingHtml}${iconBeforeHtml}${textHtml}${iconAfterHtml}`;
1015
+ if (href && !disabled && !loading && isValidHrefProtocol(href)) {
1016
+ return `<a href="${escapeHtml(
1017
+ href
1018
+ )}" class="${baseClasses}" ${idAttr} ${dataAttrs} ${ariaLabelAttr} ${targetAttr} ${relAttr}>
1019
+ ${contentHtml}
1020
+ </a>`;
1021
+ }
1022
+ return `<button type="${type}" class="${baseClasses}" ${idAttr} ${nameAttr} ${valueAttr} ${disabledAttr} ${dataAttrs} ${ariaLabelAttr}>
1023
+ ${contentHtml}
1024
+ </button>`;
1025
+ }
1026
+ function buttonGroup(buttons, options = {}) {
1027
+ if (buttons.length === 0) {
1028
+ console.warn("[frontmcp/ui] buttonGroup called with empty buttons array");
1029
+ return "";
1030
+ }
1031
+ const validation = validateOptions(options, {
1032
+ schema: ButtonGroupOptionsSchema,
1033
+ componentName: "buttonGroup"
1034
+ });
1035
+ if (!validation.success) {
1036
+ return validation.error;
1037
+ }
1038
+ const validatedOptions = validation.data;
1039
+ const { attached = false, direction = "horizontal", gap = "md", className = "" } = validatedOptions;
1040
+ const safeClassName = className ? escapeHtml(className) : "";
1041
+ if (attached) {
1042
+ const classes = direction === "horizontal" ? "inline-flex rounded-lg shadow-sm [&>*:first-child]:rounded-r-none [&>*:last-child]:rounded-l-none [&>*:not(:first-child):not(:last-child)]:rounded-none [&>*:not(:first-child)]:-ml-px" : "inline-flex flex-col rounded-lg shadow-sm [&>*:first-child]:rounded-b-none [&>*:last-child]:rounded-t-none [&>*:not(:first-child):not(:last-child)]:rounded-none [&>*:not(:first-child)]:-mt-px";
1043
+ return `<div class="${classes} ${safeClassName}">${buttons.join("")}</div>`;
1044
+ }
1045
+ const gapClasses = { sm: "gap-2", md: "gap-3", lg: "gap-4" };
1046
+ const directionClasses = direction === "horizontal" ? "flex flex-row" : "flex flex-col";
1047
+ return `<div class="${directionClasses} ${gapClasses[gap]} ${safeClassName}">${buttons.join("")}</div>`;
1048
+ }
1049
+ var primaryButton = (text, opts) => button(text, { ...opts, variant: "primary" });
1050
+ var secondaryButton = (text, opts) => button(text, { ...opts, variant: "secondary" });
1051
+ var outlineButton = (text, opts) => button(text, { ...opts, variant: "outline" });
1052
+ var ghostButton = (text, opts) => button(text, { ...opts, variant: "ghost" });
1053
+ var dangerButton = (text, opts) => button(text, { ...opts, variant: "danger" });
1054
+ var linkButton = (text, opts) => button(text, { ...opts, variant: "link" });
1055
+
1056
+ // libs/ui/src/components/card.ts
1057
+ function getVariantClasses2(variant) {
1058
+ const variants = {
1059
+ default: "bg-white border border-border rounded-xl shadow-sm",
1060
+ outlined: "bg-transparent border-2 border-border rounded-xl",
1061
+ elevated: "bg-white rounded-xl shadow-lg",
1062
+ filled: "bg-gray-50 rounded-xl",
1063
+ ghost: "bg-transparent"
1064
+ };
1065
+ return variants[variant];
1066
+ }
1067
+ function getSizeClasses2(size) {
1068
+ const sizes = {
1069
+ sm: "p-4",
1070
+ md: "p-6",
1071
+ lg: "p-8"
1072
+ };
1073
+ return sizes[size];
1074
+ }
1075
+ function buildDataAttrs(data) {
1076
+ if (!data) return "";
1077
+ return Object.entries(data).map(([key, value]) => `data-${key}="${escapeHtml(value)}"`).join(" ");
1078
+ }
1079
+ function card(content, options = {}) {
1080
+ const {
1081
+ variant = "default",
1082
+ size = "md",
1083
+ title,
1084
+ subtitle,
1085
+ headerActions,
1086
+ footer,
1087
+ className = "",
1088
+ id,
1089
+ data,
1090
+ clickable = false,
1091
+ href
1092
+ } = options;
1093
+ const variantClasses = getVariantClasses2(variant);
1094
+ const sizeClasses = getSizeClasses2(size);
1095
+ const clickableClasses = clickable ? "cursor-pointer hover:shadow-md transition-shadow" : "";
1096
+ const allClasses = [variantClasses, sizeClasses, clickableClasses, className].filter(Boolean).join(" ");
1097
+ const dataAttrs = buildDataAttrs(data);
1098
+ const idAttr = id ? `id="${escapeHtml(id)}"` : "";
1099
+ const hasHeader = title || subtitle || headerActions;
1100
+ const headerHtml = hasHeader ? `<div class="flex items-start justify-between mb-4">
1101
+ <div>
1102
+ ${title ? `<h3 class="text-lg font-semibold text-text-primary">${escapeHtml(title)}</h3>` : ""}
1103
+ ${subtitle ? `<p class="text-sm text-text-secondary mt-1">${escapeHtml(subtitle)}</p>` : ""}
1104
+ </div>
1105
+ ${headerActions ? `<div class="flex items-center gap-2">${headerActions}</div>` : ""}
1106
+ </div>` : "";
1107
+ const footerHtml = footer ? `<div class="mt-4 pt-4 border-t border-divider">${footer}</div>` : "";
1108
+ if (href) {
1109
+ return `<a href="${escapeHtml(href)}" class="${allClasses}" ${idAttr} ${dataAttrs}>
1110
+ ${headerHtml}
1111
+ ${content}
1112
+ ${footerHtml}
1113
+ </a>`;
1114
+ }
1115
+ return `<div class="${allClasses}" ${idAttr} ${dataAttrs}>
1116
+ ${headerHtml}
1117
+ ${content}
1118
+ ${footerHtml}
1119
+ </div>`;
1120
+ }
1121
+ function cardGroup(cards, options = {}) {
1122
+ const { direction = "vertical", gap = "md", className = "" } = options;
1123
+ const gapClasses = { sm: "gap-2", md: "gap-4", lg: "gap-6" };
1124
+ const directionClasses = direction === "horizontal" ? "flex flex-row flex-wrap" : "flex flex-col";
1125
+ return `<div class="${directionClasses} ${gapClasses[gap]} ${className}">
1126
+ ${cards.join("\n")}
1127
+ </div>`;
1128
+ }
1129
+
1130
+ // libs/ui/src/components/form.ts
1131
+ function getInputSizeClasses(size) {
1132
+ const sizes = {
1133
+ sm: "px-3 py-1.5 text-sm",
1134
+ md: "px-4 py-2.5 text-sm",
1135
+ lg: "px-5 py-3 text-base"
1136
+ };
1137
+ return sizes[size];
1138
+ }
1139
+ function getInputStateClasses(state) {
1140
+ const states = {
1141
+ default: "border-border focus:border-primary focus:ring-primary/20",
1142
+ error: "border-danger focus:border-danger focus:ring-danger/20",
1143
+ success: "border-success focus:border-success focus:ring-success/20",
1144
+ warning: "border-warning focus:border-warning focus:ring-warning/20"
1145
+ };
1146
+ return states[state];
1147
+ }
1148
+ function buildDataAttrs2(data) {
1149
+ if (!data) return "";
1150
+ return Object.entries(data).map(([key, value]) => `data-${key}="${escapeHtml(value)}"`).join(" ");
1151
+ }
1152
+ function input(options) {
1153
+ const {
1154
+ type = "text",
1155
+ name,
1156
+ id = name,
1157
+ value = "",
1158
+ placeholder = "",
1159
+ label,
1160
+ helper,
1161
+ error,
1162
+ size = "md",
1163
+ state = error ? "error" : "default",
1164
+ required = false,
1165
+ disabled = false,
1166
+ readonly = false,
1167
+ autocomplete,
1168
+ pattern,
1169
+ min,
1170
+ max,
1171
+ step,
1172
+ className = "",
1173
+ data,
1174
+ iconBefore,
1175
+ iconAfter
1176
+ } = options;
1177
+ const sizeClasses = getInputSizeClasses(size);
1178
+ const stateClasses = getInputStateClasses(state);
1179
+ const hasIcon = iconBefore || iconAfter;
1180
+ const baseClasses = [
1181
+ "w-full rounded-lg border bg-white",
1182
+ "transition-colors duration-200",
1183
+ "focus:outline-none focus:ring-2",
1184
+ disabled ? "opacity-50 cursor-not-allowed bg-gray-50" : "",
1185
+ sizeClasses,
1186
+ stateClasses,
1187
+ hasIcon ? (iconBefore ? "pl-10" : "") + (iconAfter ? " pr-10" : "") : "",
1188
+ className
1189
+ ].filter(Boolean).join(" ");
1190
+ const dataAttrs = buildDataAttrs2(data);
1191
+ const inputAttrs = [
1192
+ `type="${type}"`,
1193
+ `name="${escapeHtml(name)}"`,
1194
+ `id="${escapeHtml(id)}"`,
1195
+ value ? `value="${escapeHtml(value)}"` : "",
1196
+ placeholder ? `placeholder="${escapeHtml(placeholder)}"` : "",
1197
+ required ? "required" : "",
1198
+ disabled ? "disabled" : "",
1199
+ readonly ? "readonly" : "",
1200
+ autocomplete ? `autocomplete="${escapeHtml(autocomplete)}"` : "",
1201
+ pattern ? `pattern="${escapeHtml(pattern)}"` : "",
1202
+ min !== void 0 ? `min="${escapeHtml(String(min))}"` : "",
1203
+ max !== void 0 ? `max="${escapeHtml(String(max))}"` : "",
1204
+ step !== void 0 ? `step="${escapeHtml(String(step))}"` : "",
1205
+ `class="${baseClasses}"`,
1206
+ dataAttrs
1207
+ ].filter(Boolean).join(" ");
1208
+ const labelHtml = label ? `<label for="${escapeHtml(id)}" class="block text-sm font-medium text-text-primary mb-1.5">
1209
+ ${escapeHtml(label)}${required ? '<span class="text-danger ml-1">*</span>' : ""}
1210
+ </label>` : "";
1211
+ const helperHtml = helper && !error ? `<p class="mt-1.5 text-sm text-text-secondary">${escapeHtml(helper)}</p>` : "";
1212
+ const errorHtml = error ? `<p class="mt-1.5 text-sm text-danger">${escapeHtml(error)}</p>` : "";
1213
+ const iconBeforeHtml = iconBefore ? `<span class="absolute left-3 top-1/2 -translate-y-1/2 text-text-secondary">${iconBefore}</span>` : "";
1214
+ const iconAfterHtml = iconAfter ? `<span class="absolute right-3 top-1/2 -translate-y-1/2 text-text-secondary">${iconAfter}</span>` : "";
1215
+ const inputHtml = hasIcon ? `<div class="relative">
1216
+ ${iconBeforeHtml}
1217
+ <input ${inputAttrs}>
1218
+ ${iconAfterHtml}
1219
+ </div>` : `<input ${inputAttrs}>`;
1220
+ return `<div class="form-field">
1221
+ ${labelHtml}
1222
+ ${inputHtml}
1223
+ ${helperHtml}
1224
+ ${errorHtml}
1225
+ </div>`;
1226
+ }
1227
+ function select(options) {
1228
+ const {
1229
+ name,
1230
+ id = name,
1231
+ options: selectOptions,
1232
+ value,
1233
+ label,
1234
+ helper,
1235
+ error,
1236
+ size = "md",
1237
+ state = error ? "error" : "default",
1238
+ required = false,
1239
+ disabled = false,
1240
+ multiple = false,
1241
+ className = "",
1242
+ data
1243
+ } = options;
1244
+ const sizeClasses = getInputSizeClasses(size);
1245
+ const stateClasses = getInputStateClasses(state);
1246
+ const baseClasses = [
1247
+ "w-full rounded-lg border bg-white",
1248
+ "transition-colors duration-200",
1249
+ "focus:outline-none focus:ring-2",
1250
+ disabled ? "opacity-50 cursor-not-allowed bg-gray-50" : "",
1251
+ sizeClasses,
1252
+ stateClasses,
1253
+ className
1254
+ ].filter(Boolean).join(" ");
1255
+ const dataAttrs = buildDataAttrs2(data);
1256
+ const optionsHtml = selectOptions.map((opt) => {
1257
+ const selected = opt.selected || opt.value === value ? "selected" : "";
1258
+ const optDisabled = opt.disabled ? "disabled" : "";
1259
+ return `<option value="${escapeHtml(opt.value)}" ${selected} ${optDisabled}>${escapeHtml(opt.label)}</option>`;
1260
+ }).join("\n");
1261
+ const labelHtml = label ? `<label for="${escapeHtml(id)}" class="block text-sm font-medium text-text-primary mb-1.5">
1262
+ ${escapeHtml(label)}${required ? '<span class="text-danger ml-1">*</span>' : ""}
1263
+ </label>` : "";
1264
+ const helperHtml = helper && !error ? `<p class="mt-1.5 text-sm text-text-secondary">${escapeHtml(helper)}</p>` : "";
1265
+ const errorHtml = error ? `<p class="mt-1.5 text-sm text-danger">${escapeHtml(error)}</p>` : "";
1266
+ return `<div class="form-field">
1267
+ ${labelHtml}
1268
+ <select
1269
+ name="${escapeHtml(name)}"
1270
+ id="${escapeHtml(id)}"
1271
+ class="${baseClasses}"
1272
+ ${required ? "required" : ""}
1273
+ ${disabled ? "disabled" : ""}
1274
+ ${multiple ? "multiple" : ""}
1275
+ ${dataAttrs}
1276
+ >
1277
+ ${optionsHtml}
1278
+ </select>
1279
+ ${helperHtml}
1280
+ ${errorHtml}
1281
+ </div>`;
1282
+ }
1283
+ function textarea(options) {
1284
+ const {
1285
+ name,
1286
+ id = name,
1287
+ value = "",
1288
+ placeholder = "",
1289
+ label,
1290
+ helper,
1291
+ error,
1292
+ size = "md",
1293
+ state = error ? "error" : "default",
1294
+ required = false,
1295
+ disabled = false,
1296
+ readonly = false,
1297
+ rows = 4,
1298
+ resize = "vertical",
1299
+ className = "",
1300
+ data
1301
+ } = options;
1302
+ const sizeClasses = getInputSizeClasses(size);
1303
+ const stateClasses = getInputStateClasses(state);
1304
+ const resizeClasses = {
1305
+ none: "resize-none",
1306
+ vertical: "resize-y",
1307
+ horizontal: "resize-x",
1308
+ both: "resize"
1309
+ };
1310
+ const baseClasses = [
1311
+ "w-full rounded-lg border bg-white",
1312
+ "transition-colors duration-200",
1313
+ "focus:outline-none focus:ring-2",
1314
+ disabled ? "opacity-50 cursor-not-allowed bg-gray-50" : "",
1315
+ sizeClasses,
1316
+ stateClasses,
1317
+ resizeClasses[resize],
1318
+ className
1319
+ ].filter(Boolean).join(" ");
1320
+ const dataAttrs = buildDataAttrs2(data);
1321
+ const labelHtml = label ? `<label for="${escapeHtml(id)}" class="block text-sm font-medium text-text-primary mb-1.5">
1322
+ ${escapeHtml(label)}${required ? '<span class="text-danger ml-1">*</span>' : ""}
1323
+ </label>` : "";
1324
+ const helperHtml = helper && !error ? `<p class="mt-1.5 text-sm text-text-secondary">${escapeHtml(helper)}</p>` : "";
1325
+ const errorHtml = error ? `<p class="mt-1.5 text-sm text-danger">${escapeHtml(error)}</p>` : "";
1326
+ return `<div class="form-field">
1327
+ ${labelHtml}
1328
+ <textarea
1329
+ name="${escapeHtml(name)}"
1330
+ id="${escapeHtml(id)}"
1331
+ rows="${rows}"
1332
+ class="${baseClasses}"
1333
+ ${placeholder ? `placeholder="${escapeHtml(placeholder)}"` : ""}
1334
+ ${required ? "required" : ""}
1335
+ ${disabled ? "disabled" : ""}
1336
+ ${readonly ? "readonly" : ""}
1337
+ ${dataAttrs}
1338
+ >${escapeHtml(value)}</textarea>
1339
+ ${helperHtml}
1340
+ ${errorHtml}
1341
+ </div>`;
1342
+ }
1343
+ function checkbox(options) {
1344
+ const {
1345
+ name,
1346
+ id = name,
1347
+ value = "true",
1348
+ label,
1349
+ checked = false,
1350
+ disabled = false,
1351
+ helper,
1352
+ error,
1353
+ className = ""
1354
+ } = options;
1355
+ const checkboxClasses = [
1356
+ "h-4 w-4 rounded border-border text-primary",
1357
+ "focus:ring-2 focus:ring-primary/20 focus:ring-offset-0",
1358
+ disabled ? "opacity-50 cursor-not-allowed" : "cursor-pointer"
1359
+ ].join(" ");
1360
+ const helperHtml = helper && !error ? `<p class="text-sm text-text-secondary">${escapeHtml(helper)}</p>` : "";
1361
+ const errorHtml = error ? `<p class="text-sm text-danger">${escapeHtml(error)}</p>` : "";
1362
+ return `<div class="form-field ${className}">
1363
+ <label class="flex items-start gap-3 ${disabled ? "cursor-not-allowed" : "cursor-pointer"}">
1364
+ <input
1365
+ type="checkbox"
1366
+ name="${escapeHtml(name)}"
1367
+ id="${escapeHtml(id)}"
1368
+ value="${escapeHtml(value)}"
1369
+ class="${checkboxClasses}"
1370
+ ${checked ? "checked" : ""}
1371
+ ${disabled ? "disabled" : ""}
1372
+ >
1373
+ <div>
1374
+ <span class="text-sm font-medium text-text-primary">${escapeHtml(label)}</span>
1375
+ ${helperHtml}
1376
+ ${errorHtml}
1377
+ </div>
1378
+ </label>
1379
+ </div>`;
1380
+ }
1381
+ function radioGroup(options) {
1382
+ const { name, options: radioOptions, value, label, helper, error, direction = "vertical", className = "" } = options;
1383
+ const directionClasses = direction === "horizontal" ? "flex flex-row flex-wrap gap-4" : "flex flex-col gap-2";
1384
+ const radioClasses = "h-4 w-4 border-border text-primary focus:ring-2 focus:ring-primary/20 focus:ring-offset-0";
1385
+ const radiosHtml = radioOptions.map((opt, index) => {
1386
+ const radioId = `${name}-${index}`;
1387
+ const checked = opt.value === value ? "checked" : "";
1388
+ const disabled = opt.disabled ? "disabled" : "";
1389
+ const cursorClass = opt.disabled ? "cursor-not-allowed opacity-50" : "cursor-pointer";
1390
+ return `<label class="flex items-center gap-2 ${cursorClass}">
1391
+ <input
1392
+ type="radio"
1393
+ name="${escapeHtml(name)}"
1394
+ id="${escapeHtml(radioId)}"
1395
+ value="${escapeHtml(opt.value)}"
1396
+ class="${radioClasses}"
1397
+ ${checked}
1398
+ ${disabled}
1399
+ >
1400
+ <span class="text-sm text-text-primary">${escapeHtml(opt.label)}</span>
1401
+ </label>`;
1402
+ }).join("\n");
1403
+ const labelHtml = label ? `<label class="block text-sm font-medium text-text-primary mb-2">${escapeHtml(label)}</label>` : "";
1404
+ const helperHtml = helper && !error ? `<p class="mt-1.5 text-sm text-text-secondary">${escapeHtml(helper)}</p>` : "";
1405
+ const errorHtml = error ? `<p class="mt-1.5 text-sm text-danger">${escapeHtml(error)}</p>` : "";
1406
+ return `<div class="form-field ${className}" role="radiogroup">
1407
+ ${labelHtml}
1408
+ <div class="${directionClasses}">
1409
+ ${radiosHtml}
1410
+ </div>
1411
+ ${helperHtml}
1412
+ ${errorHtml}
1413
+ </div>`;
1414
+ }
1415
+ function form(content, options = {}) {
1416
+ const { action, method = "post", id, className = "", preventDefault = false, autocomplete, enctype } = options;
1417
+ const attrs = [
1418
+ action ? `action="${escapeHtml(action)}"` : "",
1419
+ `method="${method}"`,
1420
+ id ? `id="${escapeHtml(id)}"` : "",
1421
+ className ? `class="${escapeHtml(className)}"` : "",
1422
+ autocomplete ? `autocomplete="${autocomplete}"` : "",
1423
+ enctype ? `enctype="${enctype}"` : "",
1424
+ preventDefault ? 'onsubmit="return false;"' : ""
1425
+ ].filter(Boolean).join(" ");
1426
+ return `<form ${attrs}>${content}</form>`;
1427
+ }
1428
+ function formRow(fields, options = {}) {
1429
+ const { gap = "md", className = "" } = options;
1430
+ const gapClasses = { sm: "gap-2", md: "gap-4", lg: "gap-6" };
1431
+ return `<div class="grid grid-cols-${fields.length} ${gapClasses[gap]} ${className}">
1432
+ ${fields.join("\n")}
1433
+ </div>`;
1434
+ }
1435
+ function formSection(content, options = {}) {
1436
+ const { title, description, className = "" } = options;
1437
+ const headerHtml = title ? `<div class="mb-4">
1438
+ <h3 class="text-lg font-semibold text-text-primary">${escapeHtml(title)}</h3>
1439
+ ${description ? `<p class="text-sm text-text-secondary mt-1">${escapeHtml(description)}</p>` : ""}
1440
+ </div>` : "";
1441
+ return `<div class="form-section ${className}">
1442
+ ${headerHtml}
1443
+ <div class="space-y-4">
1444
+ ${content}
1445
+ </div>
1446
+ </div>`;
1447
+ }
1448
+ function formActions(buttons, options = {}) {
1449
+ const { align = "right", className = "" } = options;
1450
+ const alignClasses = {
1451
+ left: "justify-start",
1452
+ center: "justify-center",
1453
+ right: "justify-end",
1454
+ between: "justify-between"
1455
+ };
1456
+ return `<div class="flex items-center gap-3 pt-4 ${alignClasses[align]} ${className}">
1457
+ ${buttons.join("\n")}
1458
+ </div>`;
1459
+ }
1460
+ function hiddenInput(name, value) {
1461
+ return `<input type="hidden" name="${escapeHtml(name)}" value="${escapeHtml(value)}">`;
1462
+ }
1463
+ function csrfInput(token) {
1464
+ return hiddenInput("_csrf", token);
1465
+ }
1466
+
1467
+ // libs/ui/src/components/badge.ts
1468
+ function getVariantClasses3(variant) {
1469
+ const variants = {
1470
+ default: "bg-gray-100 text-gray-800",
1471
+ primary: "bg-primary/10 text-primary",
1472
+ secondary: "bg-secondary/10 text-secondary",
1473
+ success: "bg-success/10 text-success",
1474
+ warning: "bg-warning/10 text-warning",
1475
+ danger: "bg-danger/10 text-danger",
1476
+ info: "bg-blue-100 text-blue-800",
1477
+ outline: "border border-border text-text-primary bg-transparent"
1478
+ };
1479
+ return variants[variant];
1480
+ }
1481
+ function getSizeClasses3(size, dot) {
1482
+ if (dot) {
1483
+ const dotSizes = {
1484
+ sm: "w-2 h-2",
1485
+ md: "w-2.5 h-2.5",
1486
+ lg: "w-3 h-3"
1487
+ };
1488
+ return dotSizes[size];
1489
+ }
1490
+ const sizes = {
1491
+ sm: "px-2 py-0.5 text-xs",
1492
+ md: "px-2.5 py-1 text-xs",
1493
+ lg: "px-3 py-1.5 text-sm"
1494
+ };
1495
+ return sizes[size];
1496
+ }
1497
+ function badge(text, options = {}) {
1498
+ const {
1499
+ variant = "default",
1500
+ size = "md",
1501
+ pill = false,
1502
+ icon,
1503
+ dot = false,
1504
+ className = "",
1505
+ removable = false
1506
+ } = options;
1507
+ if (dot) {
1508
+ const dotVariants = {
1509
+ default: "bg-gray-400",
1510
+ primary: "bg-primary",
1511
+ secondary: "bg-secondary",
1512
+ success: "bg-success",
1513
+ warning: "bg-warning",
1514
+ danger: "bg-danger",
1515
+ info: "bg-blue-500",
1516
+ outline: "border border-current"
1517
+ };
1518
+ const dotClasses = ["inline-block rounded-full", getSizeClasses3(size, true), dotVariants[variant], className].filter(Boolean).join(" ");
1519
+ return `<span class="${dotClasses}" aria-label="${escapeHtml(text)}" title="${escapeHtml(text)}"></span>`;
1520
+ }
1521
+ const variantClasses = getVariantClasses3(variant);
1522
+ const sizeClasses = getSizeClasses3(size, false);
1523
+ const baseClasses = [
1524
+ "inline-flex items-center font-medium",
1525
+ pill ? "rounded-full" : "rounded-md",
1526
+ variantClasses,
1527
+ sizeClasses,
1528
+ className
1529
+ ].filter(Boolean).join(" ");
1530
+ const iconHtml = icon ? `<span class="mr-1">${icon}</span>` : "";
1531
+ const removeHtml = removable ? `<button
1532
+ type="button"
1533
+ class="ml-1.5 -mr-1 hover:opacity-70 transition-opacity"
1534
+ onclick="this.parentElement.remove()"
1535
+ aria-label="Remove"
1536
+ >
1537
+ <svg class="w-3 h-3" fill="none" stroke="currentColor" viewBox="0 0 24 24">
1538
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M6 18L18 6M6 6l12 12"/>
1539
+ </svg>
1540
+ </button>` : "";
1541
+ return `<span class="${baseClasses}">
1542
+ ${iconHtml}${escapeHtml(text)}${removeHtml}
1543
+ </span>`;
1544
+ }
1545
+ function badgeGroup(badges, options = {}) {
1546
+ const { gap = "sm", className = "" } = options;
1547
+ const gapClasses = { sm: "gap-1", md: "gap-2", lg: "gap-3" };
1548
+ return `<div class="inline-flex flex-wrap ${gapClasses[gap]} ${className}">
1549
+ ${badges.join("\n")}
1550
+ </div>`;
1551
+ }
1552
+ var activeBadge = (text = "Active") => badge(text, { variant: "success", dot: false });
1553
+ var inactiveBadge = (text = "Inactive") => badge(text, { variant: "default", dot: false });
1554
+ var pendingBadge = (text = "Pending") => badge(text, { variant: "warning", dot: false });
1555
+ var errorBadge = (text = "Error") => badge(text, { variant: "danger", dot: false });
1556
+ var newBadge = (text = "New") => badge(text, { variant: "primary", size: "sm", pill: true });
1557
+ var betaBadge = (text = "Beta") => badge(text, { variant: "secondary", size: "sm", pill: true });
1558
+ var onlineDot = (label = "Online") => badge(label, { variant: "success", dot: true });
1559
+ var offlineDot = (label = "Offline") => badge(label, { variant: "default", dot: true });
1560
+ var busyDot = (label = "Busy") => badge(label, { variant: "danger", dot: true });
1561
+ var awayDot = (label = "Away") => badge(label, { variant: "warning", dot: true });
1562
+
1563
+ // libs/ui/src/components/alert.ts
1564
+ var alertIcons = {
1565
+ info: `<svg class="w-5 h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24">
1566
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M13 16h-1v-4h-1m1-4h.01M21 12a9 9 0 11-18 0 9 9 0 0118 0z"/>
1567
+ </svg>`,
1568
+ success: `<svg class="w-5 h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24">
1569
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M9 12l2 2 4-4m6 2a9 9 0 11-18 0 9 9 0 0118 0z"/>
1570
+ </svg>`,
1571
+ warning: `<svg class="w-5 h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24">
1572
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-3L13.732 4c-.77-1.333-2.694-1.333-3.464 0L3.34 16c-.77 1.333.192 3 1.732 3z"/>
1573
+ </svg>`,
1574
+ danger: `<svg class="w-5 h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24">
1575
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M10 14l2-2m0 0l2-2m-2 2l-2-2m2 2l2 2m7-2a9 9 0 11-18 0 9 9 0 0118 0z"/>
1576
+ </svg>`,
1577
+ neutral: `<svg class="w-5 h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24">
1578
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M13 16h-1v-4h-1m1-4h.01M21 12a9 9 0 11-18 0 9 9 0 0118 0z"/>
1579
+ </svg>`
1580
+ };
1581
+ function getVariantClasses4(variant) {
1582
+ const variants = {
1583
+ info: {
1584
+ container: "bg-blue-50 border-blue-200 text-blue-800",
1585
+ icon: "text-blue-500"
1586
+ },
1587
+ success: {
1588
+ container: "bg-success/10 border-success/30 text-success",
1589
+ icon: "text-success"
1590
+ },
1591
+ warning: {
1592
+ container: "bg-warning/10 border-warning/30 text-warning",
1593
+ icon: "text-warning"
1594
+ },
1595
+ danger: {
1596
+ container: "bg-danger/10 border-danger/30 text-danger",
1597
+ icon: "text-danger"
1598
+ },
1599
+ neutral: {
1600
+ container: "bg-gray-50 border-gray-200 text-gray-800",
1601
+ icon: "text-gray-500"
1602
+ }
1603
+ };
1604
+ return variants[variant];
1605
+ }
1606
+ function alert(message, options = {}) {
1607
+ const { variant = "info", title, showIcon = true, icon, dismissible = false, className = "", id, actions } = options;
1608
+ const variantClasses = getVariantClasses4(variant);
1609
+ const baseClasses = ["rounded-lg border p-4", variantClasses.container, className].filter(Boolean).join(" ");
1610
+ const iconHtml = showIcon ? `<div class="flex-shrink-0 ${variantClasses.icon}">
1611
+ ${icon || alertIcons[variant]}
1612
+ </div>` : "";
1613
+ const titleHtml = title ? `<h3 class="font-semibold">${escapeHtml(title)}</h3>` : "";
1614
+ const dismissHtml = dismissible ? `<button
1615
+ type="button"
1616
+ class="flex-shrink-0 ml-auto -mr-1 -mt-1 p-1 rounded hover:bg-black/5 transition-colors"
1617
+ onclick="this.closest('.alert').remove()"
1618
+ aria-label="Dismiss"
1619
+ >
1620
+ <svg class="w-4 h-4" fill="none" stroke="currentColor" viewBox="0 0 24 24">
1621
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M6 18L18 6M6 6l12 12"/>
1622
+ </svg>
1623
+ </button>` : "";
1624
+ const actionsHtml = actions ? `<div class="mt-3">${actions}</div>` : "";
1625
+ const idAttr = id ? `id="${escapeHtml(id)}"` : "";
1626
+ return `<div class="alert ${baseClasses}" role="alert" ${idAttr}>
1627
+ <div class="flex gap-3">
1628
+ ${iconHtml}
1629
+ <div class="flex-1">
1630
+ ${titleHtml}
1631
+ <div class="${title ? "mt-1" : ""}">${escapeHtml(message)}</div>
1632
+ ${actionsHtml}
1633
+ </div>
1634
+ ${dismissHtml}
1635
+ </div>
1636
+ </div>`;
1637
+ }
1638
+ var infoAlert = (message, opts) => alert(message, { ...opts, variant: "info" });
1639
+ var successAlert = (message, opts) => alert(message, { ...opts, variant: "success" });
1640
+ var warningAlert = (message, opts) => alert(message, { ...opts, variant: "warning" });
1641
+ var dangerAlert = (message, opts) => alert(message, { ...opts, variant: "danger" });
1642
+ function toast(message, options = {}) {
1643
+ const { variant = "info", title, duration = 5e3, position = "top-right", id = `toast-${Date.now()}` } = options;
1644
+ const variantClasses = getVariantClasses4(variant);
1645
+ const positionClasses = {
1646
+ "top-right": "top-4 right-4",
1647
+ "top-left": "top-4 left-4",
1648
+ "bottom-right": "bottom-4 right-4",
1649
+ "bottom-left": "bottom-4 left-4",
1650
+ "top-center": "top-4 left-1/2 -translate-x-1/2",
1651
+ "bottom-center": "bottom-4 left-1/2 -translate-x-1/2"
1652
+ };
1653
+ const titleHtml = title ? `<h4 class="font-semibold">${escapeHtml(title)}</h4>` : "";
1654
+ const autoDismissScript = duration > 0 ? `<script>
1655
+ setTimeout(() => {
1656
+ const toast = document.getElementById('${id}');
1657
+ if (toast) {
1658
+ toast.classList.add('opacity-0', 'translate-x-2');
1659
+ setTimeout(() => toast.remove(), 300);
1660
+ }
1661
+ }, ${duration});
1662
+ </script>` : "";
1663
+ return `<div
1664
+ id="${escapeHtml(id)}"
1665
+ class="fixed ${positionClasses[position]} z-50 min-w-[300px] max-w-md rounded-lg border shadow-lg ${variantClasses.container} transition-all duration-300 transform"
1666
+ role="alert"
1667
+ >
1668
+ <div class="flex gap-3 p-4">
1669
+ <div class="flex-shrink-0 ${variantClasses.icon}">
1670
+ ${alertIcons[variant]}
1671
+ </div>
1672
+ <div class="flex-1">
1673
+ ${titleHtml}
1674
+ <p class="${title ? "mt-1 text-sm opacity-90" : ""}">${escapeHtml(message)}</p>
1675
+ </div>
1676
+ <button
1677
+ type="button"
1678
+ class="flex-shrink-0 p-1 rounded hover:bg-black/5 transition-colors"
1679
+ onclick="this.closest('#${id}').remove()"
1680
+ aria-label="Close"
1681
+ >
1682
+ <svg class="w-4 h-4" fill="none" stroke="currentColor" viewBox="0 0 24 24">
1683
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M6 18L18 6M6 6l12 12"/>
1684
+ </svg>
1685
+ </button>
1686
+ </div>
1687
+ </div>
1688
+ ${autoDismissScript}`;
1689
+ }
1690
+ function toastContainer(position = "top-right", id = "toast-container") {
1691
+ const positionClasses = {
1692
+ "top-right": "top-4 right-4",
1693
+ "top-left": "top-4 left-4",
1694
+ "bottom-right": "bottom-4 right-4",
1695
+ "bottom-left": "bottom-4 left-4",
1696
+ "top-center": "top-4 left-1/2 -translate-x-1/2",
1697
+ "bottom-center": "bottom-4 left-1/2 -translate-x-1/2"
1698
+ };
1699
+ return `<div id="${escapeHtml(id)}" class="fixed ${positionClasses[position]} z-50 flex flex-col gap-2"></div>`;
1700
+ }
1701
+
1702
+ // libs/ui/src/components/avatar.ts
1703
+ function getSizeClasses4(size) {
1704
+ const sizes = {
1705
+ xs: { container: "w-6 h-6", text: "text-xs", status: "w-2 h-2 border" },
1706
+ sm: { container: "w-8 h-8", text: "text-xs", status: "w-2.5 h-2.5 border" },
1707
+ md: { container: "w-10 h-10", text: "text-sm", status: "w-3 h-3 border-2" },
1708
+ lg: { container: "w-12 h-12", text: "text-base", status: "w-3.5 h-3.5 border-2" },
1709
+ xl: { container: "w-16 h-16", text: "text-lg", status: "w-4 h-4 border-2" },
1710
+ "2xl": { container: "w-24 h-24", text: "text-2xl", status: "w-5 h-5 border-2" }
1711
+ };
1712
+ return sizes[size];
1713
+ }
1714
+ function getShapeClasses(shape) {
1715
+ const shapes = {
1716
+ circle: "rounded-full",
1717
+ square: "rounded-none",
1718
+ rounded: "rounded-lg"
1719
+ };
1720
+ return shapes[shape];
1721
+ }
1722
+ function getStatusClasses(status) {
1723
+ const statuses = {
1724
+ online: "bg-success",
1725
+ offline: "bg-gray-400",
1726
+ busy: "bg-danger",
1727
+ away: "bg-warning",
1728
+ none: ""
1729
+ };
1730
+ return statuses[status];
1731
+ }
1732
+ function generateInitials(name) {
1733
+ const parts = name.trim().split(/\s+/);
1734
+ if (parts.length === 1) {
1735
+ return parts[0].charAt(0).toUpperCase();
1736
+ }
1737
+ return (parts[0].charAt(0) + parts[parts.length - 1].charAt(0)).toUpperCase();
1738
+ }
1739
+ function generateBgColor(name) {
1740
+ const colors = [
1741
+ "bg-blue-500",
1742
+ "bg-green-500",
1743
+ "bg-yellow-500",
1744
+ "bg-purple-500",
1745
+ "bg-pink-500",
1746
+ "bg-indigo-500",
1747
+ "bg-red-500",
1748
+ "bg-orange-500",
1749
+ "bg-teal-500",
1750
+ "bg-cyan-500"
1751
+ ];
1752
+ let hash = 0;
1753
+ for (let i = 0; i < name.length; i++) {
1754
+ hash = name.charCodeAt(i) + ((hash << 5) - hash);
1755
+ }
1756
+ return colors[Math.abs(hash) % colors.length];
1757
+ }
1758
+ function avatar(options) {
1759
+ const { src, alt, size = "md", shape = "circle", status = "none", className = "", href, initials, bgColor } = options;
1760
+ const sizeClasses = getSizeClasses4(size);
1761
+ const shapeClasses = getShapeClasses(shape);
1762
+ const statusColor = getStatusClasses(status);
1763
+ const displayInitials = initials || generateInitials(alt);
1764
+ const displayBgColor = bgColor || generateBgColor(alt);
1765
+ const containerClasses = [
1766
+ "relative inline-flex items-center justify-center",
1767
+ "overflow-hidden",
1768
+ sizeClasses.container,
1769
+ shapeClasses,
1770
+ className
1771
+ ].filter(Boolean).join(" ");
1772
+ const contentHtml = src ? `<img src="${escapeHtml(src)}" alt="${escapeHtml(alt)}" class="w-full h-full object-cover">` : `<span class="font-medium text-white ${sizeClasses.text}">${escapeHtml(displayInitials)}</span>`;
1773
+ const bgClasses = src ? "bg-gray-200" : displayBgColor;
1774
+ const statusHtml = status !== "none" ? `<span class="absolute bottom-0 right-0 block ${sizeClasses.status} ${shapeClasses} ${statusColor} border-white"></span>` : "";
1775
+ const innerHtml = `
1776
+ <div class="${containerClasses} ${bgClasses}">
1777
+ ${contentHtml}
1778
+ ${statusHtml}
1779
+ </div>
1780
+ `;
1781
+ if (href) {
1782
+ return `<a href="${escapeHtml(href)}" class="inline-block">${innerHtml}</a>`;
1783
+ }
1784
+ return innerHtml;
1785
+ }
1786
+ function avatarGroup(avatars, options = {}) {
1787
+ const { max = 5, size = "md", spacing = "normal", className = "" } = options;
1788
+ const spacingClasses = {
1789
+ tight: "-space-x-3",
1790
+ normal: "-space-x-2",
1791
+ loose: "-space-x-1"
1792
+ };
1793
+ const visibleAvatars = avatars.slice(0, max);
1794
+ const remainingCount = avatars.length - max;
1795
+ const avatarsHtml = visibleAvatars.map((opts, index) => {
1796
+ const avatarHtml = avatar({ ...opts, size });
1797
+ return `<div class="relative ring-2 ring-white rounded-full" style="z-index: ${visibleAvatars.length - index}">
1798
+ ${avatarHtml}
1799
+ </div>`;
1800
+ }).join("\n");
1801
+ const sizeClasses = getSizeClasses4(size);
1802
+ const overflowHtml = remainingCount > 0 ? `<div class="relative ring-2 ring-white rounded-full" style="z-index: 0">
1803
+ <div class="${sizeClasses.container} rounded-full bg-gray-200 flex items-center justify-center">
1804
+ <span class="${sizeClasses.text} font-medium text-gray-600">+${remainingCount}</span>
1805
+ </div>
1806
+ </div>` : "";
1807
+ return `<div class="flex ${spacingClasses[spacing]} ${className}">
1808
+ ${avatarsHtml}
1809
+ ${overflowHtml}
1810
+ </div>`;
1811
+ }
1812
+ function avatarWithText(options) {
1813
+ const { name, subtitle, align = "left", ...avatarOptions } = options;
1814
+ const avatarHtml = avatar({ ...avatarOptions, alt: avatarOptions.alt || name });
1815
+ const textHtml = `
1816
+ <div class="${align === "right" ? "text-right" : ""}">
1817
+ <div class="font-medium text-text-primary">${escapeHtml(name)}</div>
1818
+ ${subtitle ? `<div class="text-sm text-text-secondary">${escapeHtml(subtitle)}</div>` : ""}
1819
+ </div>
1820
+ `;
1821
+ const flexDirection = align === "right" ? "flex-row-reverse" : "flex-row";
1822
+ return `<div class="flex items-center gap-3 ${flexDirection}">
1823
+ ${avatarHtml}
1824
+ ${textHtml}
1825
+ </div>`;
1826
+ }
1827
+
1828
+ // libs/ui/src/components/modal.ts
1829
+ function isSafeUrl(url) {
1830
+ if (!url) return false;
1831
+ const lower = url.toLowerCase().trim();
1832
+ const isSafe = lower.startsWith("http://") || lower.startsWith("https://") || lower.startsWith("/") || lower.startsWith("#") || lower.startsWith("mailto:") || lower.startsWith("tel:");
1833
+ if (!isSafe) {
1834
+ console.warn(`[FrontMCP] Blocked unsafe URL scheme in modal confirmHref: "${url.substring(0, 50)}..."`);
1835
+ }
1836
+ return isSafe;
1837
+ }
1838
+ function getSizeClasses5(size) {
1839
+ const sizes = {
1840
+ sm: "max-w-sm",
1841
+ md: "max-w-md",
1842
+ lg: "max-w-lg",
1843
+ xl: "max-w-2xl",
1844
+ full: "max-w-full mx-4"
1845
+ };
1846
+ return sizes[size];
1847
+ }
1848
+ function modal(content, options) {
1849
+ const {
1850
+ id,
1851
+ title,
1852
+ size = "md",
1853
+ showClose = true,
1854
+ closeOnBackdrop = true,
1855
+ closeOnEscape = true,
1856
+ footer,
1857
+ className = "",
1858
+ open = false
1859
+ } = options;
1860
+ const sizeClasses = getSizeClasses5(size);
1861
+ const visibilityClasses = open ? "" : "hidden";
1862
+ const headerHtml = title || showClose ? `<div class="flex items-center justify-between p-4 border-b border-divider">
1863
+ ${title ? `<h3 class="text-lg font-semibold text-text-primary">${escapeHtml(title)}</h3>` : "<div></div>"}
1864
+ ${showClose ? `
1865
+ <button
1866
+ type="button"
1867
+ class="p-1 rounded-lg text-text-secondary hover:text-text-primary hover:bg-gray-100 transition-colors"
1868
+ onclick="document.getElementById('${escapeHtml(id)}').classList.add('hidden')"
1869
+ aria-label="Close"
1870
+ >
1871
+ <svg class="w-5 h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24">
1872
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M6 18L18 6M6 6l12 12"/>
1873
+ </svg>
1874
+ </button>
1875
+ ` : ""}
1876
+ </div>` : "";
1877
+ const footerHtml = footer ? `<div class="flex items-center justify-end gap-3 p-4 border-t border-divider">
1878
+ ${footer}
1879
+ </div>` : "";
1880
+ const backdropClickHandler = closeOnBackdrop ? `onclick="if (event.target === this) this.classList.add('hidden')"` : "";
1881
+ const escapeHandler = closeOnEscape ? `<script>
1882
+ document.addEventListener('keydown', function(e) {
1883
+ if (e.key === 'Escape') {
1884
+ document.getElementById('${escapeHtml(id)}')?.classList.add('hidden');
1885
+ }
1886
+ });
1887
+ </script>` : "";
1888
+ return `
1889
+ <div
1890
+ id="${escapeHtml(id)}"
1891
+ class="fixed inset-0 z-50 overflow-y-auto ${visibilityClasses}"
1892
+ ${backdropClickHandler}
1893
+ role="dialog"
1894
+ aria-modal="true"
1895
+ aria-labelledby="${escapeHtml(id)}-title"
1896
+ >
1897
+ <!-- Backdrop -->
1898
+ <div class="fixed inset-0 bg-black/50 transition-opacity"></div>
1899
+
1900
+ <!-- Modal container -->
1901
+ <div class="flex min-h-full items-center justify-center p-4">
1902
+ <div class="relative w-full ${sizeClasses} bg-white rounded-xl shadow-xl ${className}">
1903
+ ${headerHtml}
1904
+ <div class="p-4">
1905
+ ${content}
1906
+ </div>
1907
+ ${footerHtml}
1908
+ </div>
1909
+ </div>
1910
+ </div>
1911
+ ${escapeHandler}
1912
+ `;
1913
+ }
1914
+ function modalTrigger(triggerContent, modalId, options = {}) {
1915
+ const { className = "", tag = "button" } = options;
1916
+ const attrs = `
1917
+ class="${className}"
1918
+ onclick="document.getElementById('${escapeHtml(modalId)}').classList.remove('hidden')"
1919
+ `;
1920
+ if (tag === "button") {
1921
+ return `<button type="button" ${attrs}>${triggerContent}</button>`;
1922
+ }
1923
+ return `<${tag} ${attrs}>${triggerContent}</${tag}>`;
1924
+ }
1925
+ function confirmModal(options) {
1926
+ const {
1927
+ id,
1928
+ title = "Confirm Action",
1929
+ message,
1930
+ confirmText = "Confirm",
1931
+ cancelText = "Cancel",
1932
+ variant = "primary",
1933
+ icon,
1934
+ confirmHref
1935
+ } = options;
1936
+ const variantClasses = {
1937
+ primary: "bg-primary hover:bg-primary/90 text-white",
1938
+ danger: "bg-danger hover:bg-danger/90 text-white",
1939
+ warning: "bg-warning hover:bg-warning/90 text-white"
1940
+ };
1941
+ const iconColors = {
1942
+ primary: "text-primary bg-primary/10",
1943
+ danger: "text-danger bg-danger/10",
1944
+ warning: "text-warning bg-warning/10"
1945
+ };
1946
+ const defaultIcons = {
1947
+ primary: `<svg class="w-6 h-6" fill="none" stroke="currentColor" viewBox="0 0 24 24">
1948
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M8.228 9c.549-1.165 2.03-2 3.772-2 2.21 0 4 1.343 4 3 0 1.4-1.278 2.575-3.006 2.907-.542.104-.994.54-.994 1.093m0 3h.01M21 12a9 9 0 11-18 0 9 9 0 0118 0z"/>
1949
+ </svg>`,
1950
+ danger: `<svg class="w-6 h-6" fill="none" stroke="currentColor" viewBox="0 0 24 24">
1951
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-3L13.732 4c-.77-1.333-2.694-1.333-3.464 0L3.34 16c-.77 1.333.192 3 1.732 3z"/>
1952
+ </svg>`,
1953
+ warning: `<svg class="w-6 h-6" fill="none" stroke="currentColor" viewBox="0 0 24 24">
1954
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-3L13.732 4c-.77-1.333-2.694-1.333-3.464 0L3.34 16c-.77 1.333.192 3 1.732 3z"/>
1955
+ </svg>`
1956
+ };
1957
+ const displayIcon = icon || defaultIcons[variant];
1958
+ const content = `
1959
+ <div class="text-center">
1960
+ <div class="mx-auto w-12 h-12 rounded-full ${iconColors[variant]} flex items-center justify-center mb-4">
1961
+ ${displayIcon}
1962
+ </div>
1963
+ <h3 class="text-lg font-semibold text-text-primary mb-2">${escapeHtml(title)}</h3>
1964
+ <p class="text-text-secondary">${escapeHtml(message)}</p>
1965
+ </div>
1966
+ `;
1967
+ const confirmButton = confirmHref && isSafeUrl(confirmHref) ? `<a
1968
+ href="${escapeHtml(confirmHref)}"
1969
+ class="px-4 py-2 rounded-lg ${variantClasses[variant]} transition-colors"
1970
+ >
1971
+ ${escapeHtml(confirmText)}
1972
+ </a>` : `<button
1973
+ type="button"
1974
+ class="px-4 py-2 rounded-lg ${variantClasses[variant]} transition-colors"
1975
+ onclick="document.getElementById('${escapeHtml(id)}').classList.add('hidden')"
1976
+ >
1977
+ ${escapeHtml(confirmText)}
1978
+ </button>`;
1979
+ const footer = `
1980
+ <button
1981
+ type="button"
1982
+ class="px-4 py-2 rounded-lg border border-border text-text-primary hover:bg-gray-50 transition-colors"
1983
+ onclick="document.getElementById('${escapeHtml(id)}').classList.add('hidden')"
1984
+ >
1985
+ ${escapeHtml(cancelText)}
1986
+ </button>
1987
+ ${confirmButton}
1988
+ `;
1989
+ return modal(content, {
1990
+ id,
1991
+ size: "sm",
1992
+ showClose: false,
1993
+ footer
1994
+ });
1995
+ }
1996
+ function drawer(content, options) {
1997
+ const {
1998
+ id,
1999
+ title,
2000
+ position = "right",
2001
+ size = "md",
2002
+ showClose = true,
2003
+ closeOnBackdrop = true,
2004
+ footer,
2005
+ className = "",
2006
+ open = false
2007
+ } = options;
2008
+ const sizeClasses = {
2009
+ left: { sm: "w-64", md: "w-80", lg: "w-96", xl: "w-[32rem]" },
2010
+ right: { sm: "w-64", md: "w-80", lg: "w-96", xl: "w-[32rem]" },
2011
+ top: { sm: "h-32", md: "h-48", lg: "h-64", xl: "h-96" },
2012
+ bottom: { sm: "h-32", md: "h-48", lg: "h-64", xl: "h-96" }
2013
+ };
2014
+ const positionClasses = {
2015
+ left: "inset-y-0 left-0",
2016
+ right: "inset-y-0 right-0",
2017
+ top: "inset-x-0 top-0",
2018
+ bottom: "inset-x-0 bottom-0"
2019
+ };
2020
+ const fullSizeClasses = {
2021
+ left: "h-full",
2022
+ right: "h-full",
2023
+ top: "w-full",
2024
+ bottom: "w-full"
2025
+ };
2026
+ const visibilityClasses = open ? "" : "hidden";
2027
+ const headerHtml = title || showClose ? `<div class="flex items-center justify-between p-4 border-b border-divider">
2028
+ ${title ? `<h3 class="text-lg font-semibold text-text-primary">${escapeHtml(title)}</h3>` : "<div></div>"}
2029
+ ${showClose ? `
2030
+ <button
2031
+ type="button"
2032
+ class="p-1 rounded-lg text-text-secondary hover:text-text-primary hover:bg-gray-100 transition-colors"
2033
+ onclick="document.getElementById('${escapeHtml(id)}').classList.add('hidden')"
2034
+ aria-label="Close"
2035
+ >
2036
+ <svg class="w-5 h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24">
2037
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M6 18L18 6M6 6l12 12"/>
2038
+ </svg>
2039
+ </button>
2040
+ ` : ""}
2041
+ </div>` : "";
2042
+ const footerHtml = footer ? `<div class="p-4 border-t border-divider">${footer}</div>` : "";
2043
+ const backdropClickHandler = closeOnBackdrop ? `onclick="if (event.target === this) this.classList.add('hidden')"` : "";
2044
+ return `
2045
+ <div
2046
+ id="${escapeHtml(id)}"
2047
+ class="fixed inset-0 z-50 ${visibilityClasses}"
2048
+ ${backdropClickHandler}
2049
+ role="dialog"
2050
+ aria-modal="true"
2051
+ >
2052
+ <!-- Backdrop -->
2053
+ <div class="fixed inset-0 bg-black/50 transition-opacity"></div>
2054
+
2055
+ <!-- Drawer -->
2056
+ <div class="fixed ${positionClasses[position]} ${sizeClasses[position][size]} ${fullSizeClasses[position]} bg-white shadow-xl flex flex-col ${className}">
2057
+ ${headerHtml}
2058
+ <div class="flex-1 overflow-y-auto p-4">
2059
+ ${content}
2060
+ </div>
2061
+ ${footerHtml}
2062
+ </div>
2063
+ </div>
2064
+ `;
2065
+ }
2066
+
2067
+ // libs/ui/src/components/table.ts
2068
+ function getAlignClasses(align = "left") {
2069
+ const alignments = {
2070
+ left: "text-left",
2071
+ center: "text-center",
2072
+ right: "text-right"
2073
+ };
2074
+ return alignments[align];
2075
+ }
2076
+ function buildSortIndicator(direction) {
2077
+ if (direction === "asc") {
2078
+ return `<svg class="w-4 h-4 ml-1 inline-block" fill="none" stroke="currentColor" viewBox="0 0 24 24">
2079
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M5 15l7-7 7 7"/>
2080
+ </svg>`;
2081
+ }
2082
+ if (direction === "desc") {
2083
+ return `<svg class="w-4 h-4 ml-1 inline-block" fill="none" stroke="currentColor" viewBox="0 0 24 24">
2084
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M19 9l-7 7-7-7"/>
2085
+ </svg>`;
2086
+ }
2087
+ return `<svg class="w-4 h-4 ml-1 inline-block opacity-30" fill="none" stroke="currentColor" viewBox="0 0 24 24">
2088
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M7 16V4m0 0L3 8m4-4l4 4m6 0v12m0 0l4-4m-4 4l-4-4"/>
2089
+ </svg>`;
2090
+ }
2091
+ function buildTableHeader(columns, options) {
2092
+ const { selectable, compact } = options;
2093
+ const paddingClass = compact ? "px-3 py-2" : "px-4 py-3";
2094
+ const selectAllCell = selectable ? `<th class="${paddingClass} w-12">
2095
+ <input
2096
+ type="checkbox"
2097
+ class="w-4 h-4 rounded border-border text-primary focus:ring-primary/20"
2098
+ aria-label="Select all"
2099
+ >
2100
+ </th>` : "";
2101
+ const headerCells = columns.map((col) => {
2102
+ const alignClass = getAlignClasses(col.align);
2103
+ const widthStyle = col.width ? `style="width: ${col.width}"` : "";
2104
+ const sortableClasses = col.sortable ? "cursor-pointer hover:bg-gray-50" : "";
2105
+ return `<th
2106
+ class="${paddingClass} ${alignClass} font-semibold text-text-primary ${sortableClasses} ${col.headerClass || ""}"
2107
+ ${widthStyle}
2108
+ >
2109
+ ${col.sortable ? `<span class="inline-flex items-center">${escapeHtml(col.header)}${buildSortIndicator(
2110
+ col.sortDirection || null
2111
+ )}</span>` : escapeHtml(col.header)}
2112
+ </th>`;
2113
+ }).join("\n");
2114
+ return `<thead class="bg-gray-50 border-b border-border">
2115
+ <tr>
2116
+ ${selectAllCell}
2117
+ ${headerCells}
2118
+ </tr>
2119
+ </thead>`;
2120
+ }
2121
+ function buildTableBody(data, columns, options) {
2122
+ const { selectable, hoverable, striped, bordered, compact, rowKey = "id", onRowClick } = options;
2123
+ const paddingClass = compact ? "px-3 py-2" : "px-4 py-3";
2124
+ if (data.length === 0) {
2125
+ const colspan = columns.length + (selectable ? 1 : 0);
2126
+ const emptyContent = options.emptyContent || `
2127
+ <div class="text-center py-8">
2128
+ <svg class="w-12 h-12 mx-auto text-gray-300 mb-4" fill="none" stroke="currentColor" viewBox="0 0 24 24">
2129
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M20 13V6a2 2 0 00-2-2H6a2 2 0 00-2 2v7m16 0v5a2 2 0 01-2 2H6a2 2 0 01-2-2v-5m16 0h-2.586a1 1 0 00-.707.293l-2.414 2.414a1 1 0 01-.707.293h-3.172a1 1 0 01-.707-.293l-2.414-2.414A1 1 0 006.586 13H4"/>
2130
+ </svg>
2131
+ <p class="text-text-secondary">${options.emptyMessage || "No data available"}</p>
2132
+ </div>
2133
+ `;
2134
+ return `<tbody>
2135
+ <tr>
2136
+ <td colspan="${colspan}">${emptyContent}</td>
2137
+ </tr>
2138
+ </tbody>`;
2139
+ }
2140
+ const rows = data.map((row, rowIndex) => {
2141
+ const rowId = String(row[rowKey] || rowIndex);
2142
+ const rowClasses = [
2143
+ hoverable ? "hover:bg-gray-50" : "",
2144
+ striped && rowIndex % 2 === 1 ? "bg-gray-50/50" : "",
2145
+ bordered ? "border-b border-border" : "",
2146
+ onRowClick ? "cursor-pointer" : ""
2147
+ ].filter(Boolean).join(" ");
2148
+ const clickHandler = onRowClick ? `onclick="window.location.href='${escapeHtml(onRowClick.replace("{key}", rowId))}'"` : "";
2149
+ const selectCell = selectable ? `<td class="${paddingClass}" onclick="event.stopPropagation()">
2150
+ <input
2151
+ type="checkbox"
2152
+ class="w-4 h-4 rounded border-border text-primary focus:ring-primary/20"
2153
+ name="selected[]"
2154
+ value="${escapeHtml(rowId)}"
2155
+ aria-label="Select row"
2156
+ >
2157
+ </td>` : "";
2158
+ const cells = columns.map((col) => {
2159
+ const value = row[col.key];
2160
+ const alignClass = getAlignClasses(col.align);
2161
+ const cellContent = col.render ? col.render(value, row, rowIndex) : escapeHtml(String(value ?? ""));
2162
+ return `<td class="${paddingClass} ${alignClass} ${col.cellClass || ""}">${cellContent}</td>`;
2163
+ }).join("\n");
2164
+ return `<tr class="${rowClasses}" ${clickHandler}>
2165
+ ${selectCell}
2166
+ ${cells}
2167
+ </tr>`;
2168
+ }).join("\n");
2169
+ return `<tbody class="divide-y divide-border">${rows}</tbody>`;
2170
+ }
2171
+ function buildLoadingOverlay() {
2172
+ return `<div class="absolute inset-0 bg-white/70 flex items-center justify-center">
2173
+ <svg class="animate-spin w-8 h-8 text-primary" fill="none" viewBox="0 0 24 24">
2174
+ <circle class="opacity-25" cx="12" cy="12" r="10" stroke="currentColor" stroke-width="4"></circle>
2175
+ <path class="opacity-75" fill="currentColor" d="M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"></path>
2176
+ </svg>
2177
+ </div>`;
2178
+ }
2179
+ function table(data, options) {
2180
+ const { id, bordered, stickyHeader, className = "", loading = false } = options;
2181
+ const tableClasses = ["w-full", bordered ? "border border-border" : "", "text-sm"].filter(Boolean).join(" ");
2182
+ const wrapperClasses = ["relative overflow-x-auto", stickyHeader ? "max-h-96 overflow-y-auto" : "", className].filter(Boolean).join(" ");
2183
+ const idAttr = id ? `id="${escapeHtml(id)}"` : "";
2184
+ const header = buildTableHeader(options.columns, options);
2185
+ const body = buildTableBody(data, options.columns, options);
2186
+ const loadingOverlay = loading ? buildLoadingOverlay() : "";
2187
+ return `<div class="${wrapperClasses}" ${idAttr}>
2188
+ <table class="${tableClasses}">
2189
+ ${header}
2190
+ ${body}
2191
+ </table>
2192
+ ${loadingOverlay}
2193
+ </div>`;
2194
+ }
2195
+ function pagination(options) {
2196
+ const {
2197
+ page,
2198
+ totalPages,
2199
+ totalItems,
2200
+ pageSize = 10,
2201
+ showPageSize = false,
2202
+ pageSizeOptions = [10, 25, 50, 100],
2203
+ className = "",
2204
+ baseUrl = ""
2205
+ } = options;
2206
+ const buildPageLink = (pageNum, label, disabled, active) => {
2207
+ const baseClasses = "px-3 py-2 text-sm rounded-lg transition-colors";
2208
+ const stateClasses = disabled ? "text-gray-300 cursor-not-allowed" : active ? "bg-primary text-white" : "text-text-primary hover:bg-gray-100";
2209
+ if (disabled) {
2210
+ return `<span class="${baseClasses} ${stateClasses}">${label}</span>`;
2211
+ }
2212
+ const pageUrl = baseUrl ? `${baseUrl}${baseUrl.includes("?") ? "&" : "?"}page=${pageNum}` : `?page=${pageNum}`;
2213
+ return `<a href="${escapeHtml(pageUrl)}" class="${baseClasses} ${stateClasses}">${label}</a>`;
2214
+ };
2215
+ const pageNumbers = [];
2216
+ const maxVisible = 5;
2217
+ if (totalPages <= maxVisible) {
2218
+ for (let i = 1; i <= totalPages; i++) {
2219
+ pageNumbers.push(i);
2220
+ }
2221
+ } else {
2222
+ pageNumbers.push(1);
2223
+ let start = Math.max(2, page - 1);
2224
+ let end = Math.min(totalPages - 1, page + 1);
2225
+ if (page <= 2) {
2226
+ end = 4;
2227
+ } else if (page >= totalPages - 1) {
2228
+ start = totalPages - 3;
2229
+ }
2230
+ if (start > 2) {
2231
+ pageNumbers.push(-1);
2232
+ }
2233
+ for (let i = start; i <= end; i++) {
2234
+ pageNumbers.push(i);
2235
+ }
2236
+ if (end < totalPages - 1) {
2237
+ pageNumbers.push(-1);
2238
+ }
2239
+ pageNumbers.push(totalPages);
2240
+ }
2241
+ const pagesHtml = pageNumbers.map((num) => {
2242
+ if (num === -1) {
2243
+ return '<span class="px-2 py-2 text-text-secondary">...</span>';
2244
+ }
2245
+ return buildPageLink(num, String(num), false, num === page);
2246
+ }).join("\n");
2247
+ const prevLink = buildPageLink(page - 1, "&larr; Previous", page <= 1, false);
2248
+ const nextLink = buildPageLink(page + 1, "Next &rarr;", page >= totalPages, false);
2249
+ const infoHtml = totalItems !== void 0 ? `<span class="text-sm text-text-secondary">
2250
+ Showing ${(page - 1) * pageSize + 1} to ${Math.min(page * pageSize, totalItems)} of ${totalItems} results
2251
+ </span>` : "";
2252
+ const pageSizeHtml = showPageSize ? `<select
2253
+ class="ml-4 px-2 py-1 text-sm border border-border rounded-lg bg-white"
2254
+ onchange="window.location.href = '${baseUrl}${baseUrl.includes("?") ? "&" : "?"}page=1&pageSize=' + this.value"
2255
+ >
2256
+ ${pageSizeOptions.map((size) => `<option value="${size}" ${size === pageSize ? "selected" : ""}>${size} per page</option>`).join("")}
2257
+ </select>` : "";
2258
+ return `<div class="flex items-center justify-between ${className}">
2259
+ <div class="flex items-center">
2260
+ ${infoHtml}
2261
+ ${pageSizeHtml}
2262
+ </div>
2263
+ <div class="flex items-center gap-1">
2264
+ ${prevLink}
2265
+ ${pagesHtml}
2266
+ ${nextLink}
2267
+ </div>
2268
+ </div>`;
2269
+ }
2270
+
2271
+ // libs/ui/src/components/list.ts
2272
+ var permissionIcons = {
2273
+ read: `<svg class="w-5 h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24">
2274
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M15 12a3 3 0 11-6 0 3 3 0 016 0z"/>
2275
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M2.458 12C3.732 7.943 7.523 5 12 5c4.478 0 8.268 2.943 9.542 7-1.274 4.057-5.064 7-9.542 7-4.477 0-8.268-2.943-9.542-7z"/>
2276
+ </svg>`,
2277
+ write: `<svg class="w-5 h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24">
2278
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M11 5H6a2 2 0 00-2 2v11a2 2 0 002 2h11a2 2 0 002-2v-5m-1.414-9.414a2 2 0 112.828 2.828L11.828 15H9v-2.828l8.586-8.586z"/>
2279
+ </svg>`,
2280
+ delete: `<svg class="w-5 h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24">
2281
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M19 7l-.867 12.142A2 2 0 0116.138 21H7.862a2 2 0 01-1.995-1.858L5 7m5 4v6m4-6v6m1-10V4a1 1 0 00-1-1h-4a1 1 0 00-1 1v3M4 7h16"/>
2282
+ </svg>`,
2283
+ profile: `<svg class="w-5 h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24">
2284
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M16 7a4 4 0 11-8 0 4 4 0 018 0zM12 14a7 7 0 00-7 7h14a7 7 0 00-7-7z"/>
2285
+ </svg>`,
2286
+ email: `<svg class="w-5 h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24">
2287
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M3 8l7.89 5.26a2 2 0 002.22 0L21 8M5 19h14a2 2 0 002-2V7a2 2 0 00-2-2H5a2 2 0 00-2 2v10a2 2 0 002 2z"/>
2288
+ </svg>`,
2289
+ settings: `<svg class="w-5 h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24">
2290
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M10.325 4.317c.426-1.756 2.924-1.756 3.35 0a1.724 1.724 0 002.573 1.066c1.543-.94 3.31.826 2.37 2.37a1.724 1.724 0 001.065 2.572c1.756.426 1.756 2.924 0 3.35a1.724 1.724 0 00-1.066 2.573c.94 1.543-.826 3.31-2.37 2.37a1.724 1.724 0 00-2.572 1.065c-.426 1.756-2.924 1.756-3.35 0a1.724 1.724 0 00-2.573-1.066c-1.543.94-3.31-.826-2.37-2.37a1.724 1.724 0 00-1.065-2.572c-1.756-.426-1.756-2.924 0-3.35a1.724 1.724 0 001.066-2.573c-.94-1.543.826-3.31 2.37-2.37.996.608 2.296.07 2.572-1.065z"/>
2291
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M15 12a3 3 0 11-6 0 3 3 0 016 0z"/>
2292
+ </svg>`,
2293
+ default: `<svg class="w-5 h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24">
2294
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M9 12l2 2 4-4m5.618-4.016A11.955 11.955 0 0112 2.944a11.955 11.955 0 01-8.618 3.04A12.02 12.02 0 003 9c0 5.591 3.824 10.29 9 11.622 5.176-1.332 9-6.03 9-11.622 0-1.042-.133-2.052-.382-3.016z"/>
2295
+ </svg>`
2296
+ };
2297
+ function getPermissionIcon(scope, customIcon) {
2298
+ if (customIcon) return customIcon;
2299
+ const scopeLower = scope.toLowerCase();
2300
+ if (scopeLower.includes("read")) return permissionIcons["read"];
2301
+ if (scopeLower.includes("write") || scopeLower.includes("create") || scopeLower.includes("update"))
2302
+ return permissionIcons["write"];
2303
+ if (scopeLower.includes("delete")) return permissionIcons["delete"];
2304
+ if (scopeLower.includes("profile")) return permissionIcons["profile"];
2305
+ if (scopeLower.includes("email")) return permissionIcons["email"];
2306
+ if (scopeLower.includes("settings") || scopeLower.includes("config")) return permissionIcons["settings"];
2307
+ return permissionIcons["default"];
2308
+ }
2309
+ function permissionList(permissions, options = {}) {
2310
+ const { id, checkable = false, inputName = "scopes", title, className = "" } = options;
2311
+ const titleHtml = title ? `<h4 class="font-medium text-text-primary mb-3">${escapeHtml(title)}</h4>` : "";
2312
+ const itemsHtml = permissions.map((perm, index) => {
2313
+ const icon = getPermissionIcon(perm.scope, perm.icon);
2314
+ const sensitiveClasses = perm.sensitive ? "border-warning/30 bg-warning/5" : "border-border";
2315
+ const sensitiveLabel = perm.sensitive ? '<span class="text-xs text-warning font-medium ml-2">Sensitive</span>' : "";
2316
+ const checkboxHtml = checkable ? `<input
2317
+ type="checkbox"
2318
+ name="${escapeHtml(inputName)}[]"
2319
+ value="${escapeHtml(perm.scope)}"
2320
+ class="w-4 h-4 rounded border-border text-primary focus:ring-primary/20"
2321
+ ${perm.checked || perm.required ? "checked" : ""}
2322
+ ${perm.required ? "disabled" : ""}
2323
+ id="${id ? escapeHtml(id) : "perm"}-${index}"
2324
+ >` : `<div class="w-5 h-5 rounded-full bg-success/10 text-success flex items-center justify-center">
2325
+ <svg class="w-3 h-3" fill="none" stroke="currentColor" viewBox="0 0 24 24">
2326
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="3" d="M5 13l4 4L19 7"/>
2327
+ </svg>
2328
+ </div>`;
2329
+ return `<div class="flex items-start gap-3 p-3 border ${sensitiveClasses} rounded-lg">
2330
+ <div class="flex-shrink-0 mt-0.5 text-text-secondary">
2331
+ ${icon}
2332
+ </div>
2333
+ <div class="flex-1 min-w-0">
2334
+ <div class="flex items-center">
2335
+ <span class="font-medium text-text-primary">${escapeHtml(perm.name)}</span>
2336
+ ${perm.required ? '<span class="text-xs text-text-secondary ml-2">(Required)</span>' : ""}
2337
+ ${sensitiveLabel}
2338
+ </div>
2339
+ ${perm.description ? `<p class="text-sm text-text-secondary mt-0.5">${escapeHtml(perm.description)}</p>` : ""}
2340
+ </div>
2341
+ <div class="flex-shrink-0">
2342
+ ${checkboxHtml}
2343
+ </div>
2344
+ </div>`;
2345
+ }).join("\n");
2346
+ const idAttr = id ? `id="${escapeHtml(id)}"` : "";
2347
+ return `<div class="permission-list ${className}" ${idAttr}>
2348
+ ${titleHtml}
2349
+ <div class="space-y-2">
2350
+ ${itemsHtml}
2351
+ </div>
2352
+ </div>`;
2353
+ }
2354
+ function featureList(features, options = {}) {
2355
+ const { style = "check", includedIcon, excludedIcon, className = "" } = options;
2356
+ const defaultIncludedIcon = `<svg class="w-5 h-5 text-success" fill="none" stroke="currentColor" viewBox="0 0 24 24">
2357
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M5 13l4 4L19 7"/>
2358
+ </svg>`;
2359
+ const defaultExcludedIcon = `<svg class="w-5 h-5 text-gray-300" fill="none" stroke="currentColor" viewBox="0 0 24 24">
2360
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M6 18L18 6M6 6l12 12"/>
2361
+ </svg>`;
2362
+ const itemsHtml = features.map((feature, index) => {
2363
+ const included = feature.included !== false;
2364
+ let iconHtml;
2365
+ if (style === "check") {
2366
+ iconHtml = included ? includedIcon || defaultIncludedIcon : excludedIcon || defaultExcludedIcon;
2367
+ } else if (style === "bullet") {
2368
+ iconHtml = `<span class="w-2 h-2 rounded-full ${included ? "bg-primary" : "bg-gray-300"}"></span>`;
2369
+ } else {
2370
+ iconHtml = `<span class="text-sm font-medium ${included ? "text-primary" : "text-gray-400"}">${index + 1}.</span>`;
2371
+ }
2372
+ const textClasses = included ? "text-text-primary" : "text-text-secondary line-through";
2373
+ return `<li class="flex items-start gap-3">
2374
+ <div class="flex-shrink-0 mt-0.5">${iconHtml}</div>
2375
+ <div class="flex-1">
2376
+ <span class="${textClasses}">${escapeHtml(feature.name)}</span>
2377
+ ${feature.description ? `<p class="text-sm text-text-secondary">${escapeHtml(feature.description)}</p>` : ""}
2378
+ </div>
2379
+ </li>`;
2380
+ }).join("\n");
2381
+ return `<ul class="space-y-3 ${className}">${itemsHtml}</ul>`;
2382
+ }
2383
+ function descriptionList(items, options = {}) {
2384
+ const { layout = "stacked", dividers = false, className = "" } = options;
2385
+ const copyScript = `
2386
+ <script>
2387
+ function copyToClipboard(text, btn) {
2388
+ navigator.clipboard.writeText(text).then(() => {
2389
+ const originalText = btn.innerHTML;
2390
+ btn.innerHTML = '<svg class="w-4 h-4 text-success" fill="none" stroke="currentColor" viewBox="0 0 24 24"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M5 13l4 4L19 7"/></svg>';
2391
+ setTimeout(() => btn.innerHTML = originalText, 2000);
2392
+ });
2393
+ }
2394
+ </script>
2395
+ `;
2396
+ const hasCopyable = items.some((item) => item.copyable);
2397
+ if (layout === "horizontal") {
2398
+ const itemsHtml2 = items.map((item) => {
2399
+ const copyBtn = item.copyable ? `<button type="button" onclick="copyToClipboard('${escapeHtml(
2400
+ item.description
2401
+ )}', this)" class="ml-2 p-1 rounded hover:bg-gray-100 transition-colors">
2402
+ <svg class="w-4 h-4 text-text-secondary" fill="none" stroke="currentColor" viewBox="0 0 24 24">
2403
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M8 16H6a2 2 0 01-2-2V6a2 2 0 012-2h8a2 2 0 012 2v2m-6 12h8a2 2 0 002-2v-8a2 2 0 00-2-2h-8a2 2 0 00-2 2v8a2 2 0 002 2z"/>
2404
+ </svg>
2405
+ </button>` : "";
2406
+ return `<div class="py-3 sm:grid sm:grid-cols-3 sm:gap-4 ${dividers ? "border-b border-divider" : ""}">
2407
+ <dt class="text-sm font-medium text-text-secondary">${escapeHtml(item.term)}</dt>
2408
+ <dd class="mt-1 sm:mt-0 sm:col-span-2 text-sm text-text-primary flex items-center">
2409
+ ${escapeHtml(item.description)}
2410
+ ${copyBtn}
2411
+ </dd>
2412
+ </div>`;
2413
+ }).join("\n");
2414
+ return `<dl class="${className}">${itemsHtml2}</dl>${hasCopyable ? copyScript : ""}`;
2415
+ }
2416
+ if (layout === "grid") {
2417
+ const itemsHtml2 = items.map((item) => {
2418
+ const copyBtn = item.copyable ? `<button type="button" onclick="copyToClipboard('${escapeHtml(
2419
+ item.description
2420
+ )}', this)" class="absolute top-2 right-2 p-1 rounded hover:bg-gray-100 transition-colors">
2421
+ <svg class="w-4 h-4 text-text-secondary" fill="none" stroke="currentColor" viewBox="0 0 24 24">
2422
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M8 16H6a2 2 0 01-2-2V6a2 2 0 012-2h8a2 2 0 012 2v2m-6 12h8a2 2 0 002-2v-8a2 2 0 00-2-2h-8a2 2 0 00-2 2v8a2 2 0 002 2z"/>
2423
+ </svg>
2424
+ </button>` : "";
2425
+ return `<div class="relative p-4 bg-gray-50 rounded-lg">
2426
+ <dt class="text-sm font-medium text-text-secondary">${escapeHtml(item.term)}</dt>
2427
+ <dd class="mt-1 text-sm text-text-primary font-medium">${escapeHtml(item.description)}</dd>
2428
+ ${copyBtn}
2429
+ </div>`;
2430
+ }).join("\n");
2431
+ return `<dl class="grid grid-cols-2 gap-4 ${className}">${itemsHtml2}</dl>${hasCopyable ? copyScript : ""}`;
2432
+ }
2433
+ const itemsHtml = items.map((item) => {
2434
+ const copyBtn = item.copyable ? `<button type="button" onclick="copyToClipboard('${escapeHtml(
2435
+ item.description
2436
+ )}', this)" class="ml-2 p-1 rounded hover:bg-gray-100 transition-colors">
2437
+ <svg class="w-4 h-4 text-text-secondary" fill="none" stroke="currentColor" viewBox="0 0 24 24">
2438
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M8 16H6a2 2 0 01-2-2V6a2 2 0 012-2h8a2 2 0 012 2v2m-6 12h8a2 2 0 002-2v-8a2 2 0 00-2-2h-8a2 2 0 00-2 2v8a2 2 0 002 2z"/>
2439
+ </svg>
2440
+ </button>` : "";
2441
+ return `<div class="${dividers ? "py-3 border-b border-divider last:border-0" : "py-2"}">
2442
+ <dt class="text-sm text-text-secondary">${escapeHtml(item.term)}</dt>
2443
+ <dd class="mt-1 text-sm text-text-primary font-medium flex items-center">
2444
+ ${escapeHtml(item.description)}
2445
+ ${copyBtn}
2446
+ </dd>
2447
+ </div>`;
2448
+ }).join("\n");
2449
+ return `<dl class="${className}">${itemsHtml}</dl>${hasCopyable ? copyScript : ""}`;
2450
+ }
2451
+ function actionList(items, className = "") {
2452
+ const itemsHtml = items.map((item) => {
2453
+ const baseClasses = [
2454
+ "flex items-center gap-3 px-4 py-3 transition-colors",
2455
+ item.disabled ? "opacity-50 cursor-not-allowed" : item.destructive ? "hover:bg-danger/5 text-danger cursor-pointer" : "hover:bg-gray-50 cursor-pointer"
2456
+ ].join(" ");
2457
+ const iconHtml = item.icon ? `<span class="flex-shrink-0 ${item.destructive ? "text-danger" : "text-text-secondary"}">${item.icon}</span>` : "";
2458
+ const contentHtml = `
2459
+ ${iconHtml}
2460
+ <div class="flex-1 min-w-0">
2461
+ <div class="font-medium ${item.destructive ? "text-danger" : "text-text-primary"}">${escapeHtml(
2462
+ item.label
2463
+ )}</div>
2464
+ ${item.description ? `<p class="text-sm text-text-secondary">${escapeHtml(item.description)}</p>` : ""}
2465
+ </div>
2466
+ <svg class="w-5 h-5 text-text-secondary" fill="none" stroke="currentColor" viewBox="0 0 24 24">
2467
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M9 5l7 7-7 7"/>
2468
+ </svg>
2469
+ `;
2470
+ if (item.disabled) {
2471
+ return `<div class="${baseClasses}">${contentHtml}</div>`;
2472
+ }
2473
+ if (item.href) {
2474
+ return `<a href="${escapeHtml(item.href)}" class="${baseClasses}">${contentHtml}</a>`;
2475
+ }
2476
+ return `<div class="${baseClasses}">${contentHtml}</div>`;
2477
+ }).join("\n");
2478
+ return `<div class="divide-y divide-divider ${className}">${itemsHtml}</div>`;
2479
+ }
2480
+ // Annotate the CommonJS export names for ESM import in node:
2481
+ 0 && (module.exports = {
2482
+ ActionItemSchema,
2483
+ ActionListOptionsSchema,
2484
+ AlertOptionsSchema,
2485
+ AlertVariantSchema,
2486
+ AvatarGroupOptionsSchema,
2487
+ AvatarOptionsSchema,
2488
+ AvatarShapeSchema,
2489
+ AvatarSizeSchema,
2490
+ AvatarSpacingSchema,
2491
+ AvatarStatusSchema,
2492
+ AvatarWithTextOptionsSchema,
2493
+ BadgeGroupOptionsSchema,
2494
+ BadgeOptionsSchema,
2495
+ BadgeSizeSchema,
2496
+ BadgeVariantSchema,
2497
+ ButtonGroupOptionsSchema,
2498
+ ButtonOptionsSchema,
2499
+ ButtonSizeSchema,
2500
+ ButtonVariantSchema,
2501
+ CardGroupOptionsSchema,
2502
+ CardOptionsSchema,
2503
+ CardSizeSchema,
2504
+ CardVariantSchema,
2505
+ CheckboxOptionsSchema,
2506
+ ConfirmModalOptionsSchema,
2507
+ ConfirmModalVariantSchema,
2508
+ DescriptionItemSchema,
2509
+ DescriptionListOptionsSchema,
2510
+ DrawerOptionsSchema,
2511
+ DrawerPositionSchema,
2512
+ FeatureItemSchema,
2513
+ FeatureListOptionsSchema,
2514
+ FormActionsOptionsSchema,
2515
+ FormEnctypeSchema,
2516
+ FormMethodSchema,
2517
+ FormOptionsSchema,
2518
+ FormRowOptionsSchema,
2519
+ FormSectionOptionsSchema,
2520
+ InputOptionsSchema,
2521
+ InputSizeSchema,
2522
+ InputStateSchema,
2523
+ InputTypeSchema,
2524
+ ModalOptionsSchema,
2525
+ ModalSizeSchema,
2526
+ ModalTriggerOptionsSchema,
2527
+ PaginationOptionsSchema,
2528
+ PermissionItemSchema,
2529
+ PermissionListOptionsSchema,
2530
+ RadioGroupOptionsSchema,
2531
+ RadioOptionItemSchema,
2532
+ SelectOptionItemSchema,
2533
+ SelectOptionsSchema,
2534
+ TableAlignSchema,
2535
+ TableColumnSchema,
2536
+ TableOptionsSchema,
2537
+ TableSortDirectionSchema,
2538
+ TextareaOptionsSchema,
2539
+ TextareaResizeSchema,
2540
+ ToastOptionsSchema,
2541
+ ToastPositionSchema,
2542
+ actionList,
2543
+ activeBadge,
2544
+ alert,
2545
+ avatar,
2546
+ avatarGroup,
2547
+ avatarWithText,
2548
+ awayDot,
2549
+ badge,
2550
+ badgeGroup,
2551
+ betaBadge,
2552
+ busyDot,
2553
+ button,
2554
+ buttonGroup,
2555
+ card,
2556
+ cardGroup,
2557
+ checkbox,
2558
+ confirmModal,
2559
+ csrfInput,
2560
+ dangerAlert,
2561
+ dangerButton,
2562
+ descriptionList,
2563
+ drawer,
2564
+ errorBadge,
2565
+ featureList,
2566
+ form,
2567
+ formActions,
2568
+ formRow,
2569
+ formSection,
2570
+ ghostButton,
2571
+ hiddenInput,
2572
+ inactiveBadge,
2573
+ infoAlert,
2574
+ input,
2575
+ linkButton,
2576
+ modal,
2577
+ modalTrigger,
2578
+ newBadge,
2579
+ offlineDot,
2580
+ onlineDot,
2581
+ outlineButton,
2582
+ pagination,
2583
+ pendingBadge,
2584
+ permissionList,
2585
+ primaryButton,
2586
+ radioGroup,
2587
+ secondaryButton,
2588
+ select,
2589
+ successAlert,
2590
+ table,
2591
+ textarea,
2592
+ toast,
2593
+ toastContainer,
2594
+ warningAlert
2595
+ });