@frontmcp/ui 0.6.0 → 0.6.2

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 (650) hide show
  1. package/README.md +140 -362
  2. package/bridge/core/bridge-factory.d.ts +1 -0
  3. package/bridge/core/bridge-factory.d.ts.map +1 -1
  4. package/bridge/index.d.ts +1 -1
  5. package/bridge/index.d.ts.map +1 -1
  6. package/bridge/index.js +39 -881
  7. package/bridge/runtime/index.d.ts +2 -1
  8. package/bridge/runtime/index.d.ts.map +1 -1
  9. package/bundler/browser-components.d.ts +42 -0
  10. package/bundler/browser-components.d.ts.map +1 -0
  11. package/bundler/bundler.d.ts +78 -4
  12. package/bundler/bundler.d.ts.map +1 -1
  13. package/bundler/index.d.ts +8 -8
  14. package/bundler/index.d.ts.map +1 -1
  15. package/bundler/index.js +1411 -2997
  16. package/bundler/types.d.ts +188 -7
  17. package/bundler/types.d.ts.map +1 -1
  18. package/components/alert.schema.d.ts +6 -6
  19. package/components/avatar.schema.d.ts +9 -9
  20. package/components/badge.schema.d.ts +9 -9
  21. package/components/button.schema.d.ts +9 -9
  22. package/components/card.schema.d.ts +7 -7
  23. package/components/form.schema.d.ts +24 -24
  24. package/components/index.js +128 -198
  25. package/components/modal.schema.d.ts +8 -8
  26. package/components/table.schema.d.ts +6 -6
  27. package/esm/bridge/{index.js → index.mjs} +40 -877
  28. package/esm/bundler/index.mjs +3136 -0
  29. package/esm/components/{index.js → index.mjs} +136 -196
  30. package/esm/index.mjs +5450 -0
  31. package/esm/layouts/index.mjs +409 -0
  32. package/esm/package.json +15 -32
  33. package/esm/react/{index.js → index.mjs} +71 -260
  34. package/esm/renderers/index.mjs +611 -0
  35. package/esm/universal/index.mjs +1951 -0
  36. package/esm/web-components/{index.js → index.mjs} +232 -287
  37. package/index.d.ts +22 -41
  38. package/index.d.ts.map +1 -1
  39. package/index.js +4286 -19607
  40. package/layouts/base.d.ts +2 -2
  41. package/layouts/base.d.ts.map +1 -1
  42. package/layouts/index.js +46 -539
  43. package/layouts/presets.d.ts.map +1 -1
  44. package/package.json +15 -32
  45. package/react/Alert.d.ts +1 -2
  46. package/react/Alert.d.ts.map +1 -1
  47. package/react/Badge.d.ts +1 -2
  48. package/react/Badge.d.ts.map +1 -1
  49. package/react/Button.d.ts +1 -2
  50. package/react/Button.d.ts.map +1 -1
  51. package/react/Card.d.ts +1 -2
  52. package/react/Card.d.ts.map +1 -1
  53. package/react/hooks/context.d.ts +1 -1
  54. package/react/hooks/context.d.ts.map +1 -1
  55. package/react/index.d.ts +5 -7
  56. package/react/index.d.ts.map +1 -1
  57. package/react/index.js +55 -269
  58. package/react/types.d.ts +1 -2
  59. package/react/types.d.ts.map +1 -1
  60. package/renderers/index.d.ts +15 -25
  61. package/renderers/index.d.ts.map +1 -1
  62. package/renderers/index.js +393 -1619
  63. package/renderers/mdx.renderer.d.ts +13 -34
  64. package/renderers/mdx.renderer.d.ts.map +1 -1
  65. package/{esm/runtime/adapters → renderers}/react.adapter.d.ts +2 -2
  66. package/renderers/react.adapter.d.ts.map +1 -0
  67. package/renderers/react.renderer.d.ts +25 -16
  68. package/renderers/react.renderer.d.ts.map +1 -1
  69. package/renderers/transpiler.d.ts +49 -0
  70. package/renderers/transpiler.d.ts.map +1 -0
  71. package/universal/cached-runtime.d.ts +25 -1
  72. package/universal/cached-runtime.d.ts.map +1 -1
  73. package/universal/index.js +2037 -0
  74. package/universal/runtime-builder.d.ts.map +1 -1
  75. package/universal/types.d.ts.map +1 -1
  76. package/web-components/elements/fmcp-input.d.ts.map +1 -1
  77. package/web-components/elements/fmcp-select.d.ts.map +1 -1
  78. package/web-components/index.d.ts +0 -1
  79. package/web-components/index.d.ts.map +1 -1
  80. package/web-components/index.js +224 -289
  81. package/adapters/index.d.ts +0 -13
  82. package/adapters/index.d.ts.map +0 -1
  83. package/adapters/index.js +0 -462
  84. package/adapters/platform-meta.d.ts +0 -166
  85. package/adapters/platform-meta.d.ts.map +0 -1
  86. package/adapters/response-builder.d.ts +0 -108
  87. package/adapters/response-builder.d.ts.map +0 -1
  88. package/adapters/serving-mode.d.ts +0 -107
  89. package/adapters/serving-mode.d.ts.map +0 -1
  90. package/base-template/bridge.d.ts +0 -90
  91. package/base-template/bridge.d.ts.map +0 -1
  92. package/base-template/default-base-template.d.ts +0 -92
  93. package/base-template/default-base-template.d.ts.map +0 -1
  94. package/base-template/index.d.ts +0 -15
  95. package/base-template/index.d.ts.map +0 -1
  96. package/base-template/index.js +0 -1398
  97. package/base-template/polyfills.d.ts +0 -31
  98. package/base-template/polyfills.d.ts.map +0 -1
  99. package/base-template/theme-styles.d.ts +0 -74
  100. package/base-template/theme-styles.d.ts.map +0 -1
  101. package/build/cdn-resources.d.ts +0 -243
  102. package/build/cdn-resources.d.ts.map +0 -1
  103. package/build/index.d.ts +0 -295
  104. package/build/index.d.ts.map +0 -1
  105. package/build/index.js +0 -7096
  106. package/build/widget-manifest.d.ts +0 -362
  107. package/build/widget-manifest.d.ts.map +0 -1
  108. package/bundler/cache.d.ts +0 -173
  109. package/bundler/cache.d.ts.map +0 -1
  110. package/bundler/file-cache/component-builder.d.ts +0 -167
  111. package/bundler/file-cache/component-builder.d.ts.map +0 -1
  112. package/bundler/file-cache/hash-calculator.d.ts +0 -155
  113. package/bundler/file-cache/hash-calculator.d.ts.map +0 -1
  114. package/bundler/file-cache/index.d.ts +0 -12
  115. package/bundler/file-cache/index.d.ts.map +0 -1
  116. package/bundler/file-cache/storage/filesystem.d.ts +0 -149
  117. package/bundler/file-cache/storage/filesystem.d.ts.map +0 -1
  118. package/bundler/file-cache/storage/index.d.ts +0 -11
  119. package/bundler/file-cache/storage/index.d.ts.map +0 -1
  120. package/bundler/file-cache/storage/interface.d.ts +0 -152
  121. package/bundler/file-cache/storage/interface.d.ts.map +0 -1
  122. package/bundler/file-cache/storage/redis.d.ts +0 -139
  123. package/bundler/file-cache/storage/redis.d.ts.map +0 -1
  124. package/bundler/sandbox/enclave-adapter.d.ts +0 -121
  125. package/bundler/sandbox/enclave-adapter.d.ts.map +0 -1
  126. package/bundler/sandbox/executor.d.ts +0 -14
  127. package/bundler/sandbox/executor.d.ts.map +0 -1
  128. package/bundler/sandbox/policy.d.ts +0 -62
  129. package/bundler/sandbox/policy.d.ts.map +0 -1
  130. package/dependency/cdn-registry.d.ts +0 -98
  131. package/dependency/cdn-registry.d.ts.map +0 -1
  132. package/dependency/import-map.d.ts +0 -186
  133. package/dependency/import-map.d.ts.map +0 -1
  134. package/dependency/import-parser.d.ts +0 -82
  135. package/dependency/import-parser.d.ts.map +0 -1
  136. package/dependency/index.d.ts +0 -17
  137. package/dependency/index.d.ts.map +0 -1
  138. package/dependency/resolver.d.ts +0 -164
  139. package/dependency/resolver.d.ts.map +0 -1
  140. package/dependency/schemas.d.ts +0 -486
  141. package/dependency/schemas.d.ts.map +0 -1
  142. package/dependency/template-loader.d.ts +0 -204
  143. package/dependency/template-loader.d.ts.map +0 -1
  144. package/dependency/template-processor.d.ts +0 -118
  145. package/dependency/template-processor.d.ts.map +0 -1
  146. package/dependency/types.d.ts +0 -739
  147. package/dependency/types.d.ts.map +0 -1
  148. package/esm/adapters/index.d.ts +0 -13
  149. package/esm/adapters/index.d.ts.map +0 -1
  150. package/esm/adapters/index.js +0 -427
  151. package/esm/adapters/platform-meta.d.ts +0 -166
  152. package/esm/adapters/platform-meta.d.ts.map +0 -1
  153. package/esm/adapters/response-builder.d.ts +0 -108
  154. package/esm/adapters/response-builder.d.ts.map +0 -1
  155. package/esm/adapters/serving-mode.d.ts +0 -107
  156. package/esm/adapters/serving-mode.d.ts.map +0 -1
  157. package/esm/base-template/bridge.d.ts +0 -90
  158. package/esm/base-template/bridge.d.ts.map +0 -1
  159. package/esm/base-template/default-base-template.d.ts +0 -92
  160. package/esm/base-template/default-base-template.d.ts.map +0 -1
  161. package/esm/base-template/index.d.ts +0 -15
  162. package/esm/base-template/index.d.ts.map +0 -1
  163. package/esm/base-template/index.js +0 -1364
  164. package/esm/base-template/polyfills.d.ts +0 -31
  165. package/esm/base-template/polyfills.d.ts.map +0 -1
  166. package/esm/base-template/theme-styles.d.ts +0 -74
  167. package/esm/base-template/theme-styles.d.ts.map +0 -1
  168. package/esm/bridge/adapters/base-adapter.d.ts +0 -104
  169. package/esm/bridge/adapters/base-adapter.d.ts.map +0 -1
  170. package/esm/bridge/adapters/claude.adapter.d.ts +0 -67
  171. package/esm/bridge/adapters/claude.adapter.d.ts.map +0 -1
  172. package/esm/bridge/adapters/ext-apps.adapter.d.ts +0 -143
  173. package/esm/bridge/adapters/ext-apps.adapter.d.ts.map +0 -1
  174. package/esm/bridge/adapters/gemini.adapter.d.ts +0 -64
  175. package/esm/bridge/adapters/gemini.adapter.d.ts.map +0 -1
  176. package/esm/bridge/adapters/generic.adapter.d.ts +0 -56
  177. package/esm/bridge/adapters/generic.adapter.d.ts.map +0 -1
  178. package/esm/bridge/adapters/index.d.ts +0 -26
  179. package/esm/bridge/adapters/index.d.ts.map +0 -1
  180. package/esm/bridge/adapters/openai.adapter.d.ts +0 -65
  181. package/esm/bridge/adapters/openai.adapter.d.ts.map +0 -1
  182. package/esm/bridge/core/adapter-registry.d.ts +0 -122
  183. package/esm/bridge/core/adapter-registry.d.ts.map +0 -1
  184. package/esm/bridge/core/bridge-factory.d.ts +0 -199
  185. package/esm/bridge/core/bridge-factory.d.ts.map +0 -1
  186. package/esm/bridge/core/index.d.ts +0 -10
  187. package/esm/bridge/core/index.d.ts.map +0 -1
  188. package/esm/bridge/index.d.ts +0 -62
  189. package/esm/bridge/index.d.ts.map +0 -1
  190. package/esm/bridge/runtime/iife-generator.d.ts +0 -62
  191. package/esm/bridge/runtime/iife-generator.d.ts.map +0 -1
  192. package/esm/bridge/runtime/index.d.ts +0 -9
  193. package/esm/bridge/runtime/index.d.ts.map +0 -1
  194. package/esm/bridge/types.d.ts +0 -386
  195. package/esm/bridge/types.d.ts.map +0 -1
  196. package/esm/build/cdn-resources.d.ts +0 -243
  197. package/esm/build/cdn-resources.d.ts.map +0 -1
  198. package/esm/build/index.d.ts +0 -295
  199. package/esm/build/index.d.ts.map +0 -1
  200. package/esm/build/index.js +0 -7021
  201. package/esm/build/widget-manifest.d.ts +0 -362
  202. package/esm/build/widget-manifest.d.ts.map +0 -1
  203. package/esm/bundler/bundler.d.ts +0 -208
  204. package/esm/bundler/bundler.d.ts.map +0 -1
  205. package/esm/bundler/cache.d.ts +0 -173
  206. package/esm/bundler/cache.d.ts.map +0 -1
  207. package/esm/bundler/file-cache/component-builder.d.ts +0 -167
  208. package/esm/bundler/file-cache/component-builder.d.ts.map +0 -1
  209. package/esm/bundler/file-cache/hash-calculator.d.ts +0 -155
  210. package/esm/bundler/file-cache/hash-calculator.d.ts.map +0 -1
  211. package/esm/bundler/file-cache/index.d.ts +0 -12
  212. package/esm/bundler/file-cache/index.d.ts.map +0 -1
  213. package/esm/bundler/file-cache/storage/filesystem.d.ts +0 -149
  214. package/esm/bundler/file-cache/storage/filesystem.d.ts.map +0 -1
  215. package/esm/bundler/file-cache/storage/index.d.ts +0 -11
  216. package/esm/bundler/file-cache/storage/index.d.ts.map +0 -1
  217. package/esm/bundler/file-cache/storage/interface.d.ts +0 -152
  218. package/esm/bundler/file-cache/storage/interface.d.ts.map +0 -1
  219. package/esm/bundler/file-cache/storage/redis.d.ts +0 -139
  220. package/esm/bundler/file-cache/storage/redis.d.ts.map +0 -1
  221. package/esm/bundler/index.d.ts +0 -43
  222. package/esm/bundler/index.d.ts.map +0 -1
  223. package/esm/bundler/index.js +0 -4687
  224. package/esm/bundler/sandbox/enclave-adapter.d.ts +0 -121
  225. package/esm/bundler/sandbox/enclave-adapter.d.ts.map +0 -1
  226. package/esm/bundler/sandbox/executor.d.ts +0 -14
  227. package/esm/bundler/sandbox/executor.d.ts.map +0 -1
  228. package/esm/bundler/sandbox/policy.d.ts +0 -62
  229. package/esm/bundler/sandbox/policy.d.ts.map +0 -1
  230. package/esm/bundler/types.d.ts +0 -702
  231. package/esm/bundler/types.d.ts.map +0 -1
  232. package/esm/components/alert.d.ts +0 -66
  233. package/esm/components/alert.d.ts.map +0 -1
  234. package/esm/components/alert.schema.d.ts +0 -98
  235. package/esm/components/alert.schema.d.ts.map +0 -1
  236. package/esm/components/avatar.d.ts +0 -77
  237. package/esm/components/avatar.d.ts.map +0 -1
  238. package/esm/components/avatar.schema.d.ts +0 -170
  239. package/esm/components/avatar.schema.d.ts.map +0 -1
  240. package/esm/components/badge.d.ts +0 -64
  241. package/esm/components/badge.d.ts.map +0 -1
  242. package/esm/components/badge.schema.d.ts +0 -91
  243. package/esm/components/badge.schema.d.ts.map +0 -1
  244. package/esm/components/button.d.ts +0 -100
  245. package/esm/components/button.d.ts.map +0 -1
  246. package/esm/components/button.schema.d.ts +0 -120
  247. package/esm/components/button.schema.d.ts.map +0 -1
  248. package/esm/components/card.d.ts +0 -53
  249. package/esm/components/card.d.ts.map +0 -1
  250. package/esm/components/card.schema.d.ts +0 -93
  251. package/esm/components/card.schema.d.ts.map +0 -1
  252. package/esm/components/form.d.ts +0 -212
  253. package/esm/components/form.d.ts.map +0 -1
  254. package/esm/components/form.schema.d.ts +0 -365
  255. package/esm/components/form.schema.d.ts.map +0 -1
  256. package/esm/components/index.d.ts +0 -29
  257. package/esm/components/index.d.ts.map +0 -1
  258. package/esm/components/list.d.ts +0 -121
  259. package/esm/components/list.d.ts.map +0 -1
  260. package/esm/components/list.schema.d.ts +0 -129
  261. package/esm/components/list.schema.d.ts.map +0 -1
  262. package/esm/components/modal.d.ts +0 -100
  263. package/esm/components/modal.d.ts.map +0 -1
  264. package/esm/components/modal.schema.d.ts +0 -151
  265. package/esm/components/modal.schema.d.ts.map +0 -1
  266. package/esm/components/table.d.ts +0 -91
  267. package/esm/components/table.d.ts.map +0 -1
  268. package/esm/components/table.schema.d.ts +0 -123
  269. package/esm/components/table.schema.d.ts.map +0 -1
  270. package/esm/dependency/cdn-registry.d.ts +0 -98
  271. package/esm/dependency/cdn-registry.d.ts.map +0 -1
  272. package/esm/dependency/import-map.d.ts +0 -186
  273. package/esm/dependency/import-map.d.ts.map +0 -1
  274. package/esm/dependency/import-parser.d.ts +0 -82
  275. package/esm/dependency/import-parser.d.ts.map +0 -1
  276. package/esm/dependency/index.d.ts +0 -17
  277. package/esm/dependency/index.d.ts.map +0 -1
  278. package/esm/dependency/resolver.d.ts +0 -164
  279. package/esm/dependency/resolver.d.ts.map +0 -1
  280. package/esm/dependency/schemas.d.ts +0 -486
  281. package/esm/dependency/schemas.d.ts.map +0 -1
  282. package/esm/dependency/template-loader.d.ts +0 -204
  283. package/esm/dependency/template-loader.d.ts.map +0 -1
  284. package/esm/dependency/template-processor.d.ts +0 -118
  285. package/esm/dependency/template-processor.d.ts.map +0 -1
  286. package/esm/dependency/types.d.ts +0 -739
  287. package/esm/dependency/types.d.ts.map +0 -1
  288. package/esm/handlebars/expression-extractor.d.ts +0 -147
  289. package/esm/handlebars/expression-extractor.d.ts.map +0 -1
  290. package/esm/handlebars/helpers.d.ts +0 -339
  291. package/esm/handlebars/helpers.d.ts.map +0 -1
  292. package/esm/handlebars/index.d.ts +0 -195
  293. package/esm/handlebars/index.d.ts.map +0 -1
  294. package/esm/handlebars/index.js +0 -587
  295. package/esm/index.d.ts +0 -56
  296. package/esm/index.d.ts.map +0 -1
  297. package/esm/index.js +0 -20511
  298. package/esm/layouts/base.d.ts +0 -86
  299. package/esm/layouts/base.d.ts.map +0 -1
  300. package/esm/layouts/index.d.ts +0 -8
  301. package/esm/layouts/index.d.ts.map +0 -1
  302. package/esm/layouts/index.js +0 -892
  303. package/esm/layouts/presets.d.ts +0 -134
  304. package/esm/layouts/presets.d.ts.map +0 -1
  305. package/esm/pages/consent.d.ts +0 -117
  306. package/esm/pages/consent.d.ts.map +0 -1
  307. package/esm/pages/error.d.ts +0 -101
  308. package/esm/pages/error.d.ts.map +0 -1
  309. package/esm/pages/index.d.ts +0 -9
  310. package/esm/pages/index.d.ts.map +0 -1
  311. package/esm/pages/index.js +0 -1563
  312. package/esm/react/Alert.d.ts +0 -102
  313. package/esm/react/Alert.d.ts.map +0 -1
  314. package/esm/react/Badge.d.ts +0 -101
  315. package/esm/react/Badge.d.ts.map +0 -1
  316. package/esm/react/Button.d.ts +0 -109
  317. package/esm/react/Button.d.ts.map +0 -1
  318. package/esm/react/Card.d.ts +0 -104
  319. package/esm/react/Card.d.ts.map +0 -1
  320. package/esm/react/hooks/context.d.ts +0 -179
  321. package/esm/react/hooks/context.d.ts.map +0 -1
  322. package/esm/react/hooks/index.d.ts +0 -42
  323. package/esm/react/hooks/index.d.ts.map +0 -1
  324. package/esm/react/hooks/tools.d.ts +0 -284
  325. package/esm/react/hooks/tools.d.ts.map +0 -1
  326. package/esm/react/index.d.ts +0 -81
  327. package/esm/react/index.d.ts.map +0 -1
  328. package/esm/react/types.d.ts +0 -106
  329. package/esm/react/types.d.ts.map +0 -1
  330. package/esm/react/utils.d.ts +0 -43
  331. package/esm/react/utils.d.ts.map +0 -1
  332. package/esm/registry/index.d.ts +0 -46
  333. package/esm/registry/index.d.ts.map +0 -1
  334. package/esm/registry/index.js +0 -6422
  335. package/esm/registry/render-template.d.ts +0 -91
  336. package/esm/registry/render-template.d.ts.map +0 -1
  337. package/esm/registry/tool-ui.registry.d.ts +0 -294
  338. package/esm/registry/tool-ui.registry.d.ts.map +0 -1
  339. package/esm/registry/uri-utils.d.ts +0 -56
  340. package/esm/registry/uri-utils.d.ts.map +0 -1
  341. package/esm/render/index.d.ts +0 -8
  342. package/esm/render/index.d.ts.map +0 -1
  343. package/esm/render/prerender.d.ts +0 -57
  344. package/esm/render/prerender.d.ts.map +0 -1
  345. package/esm/renderers/cache.d.ts +0 -145
  346. package/esm/renderers/cache.d.ts.map +0 -1
  347. package/esm/renderers/html.renderer.d.ts +0 -123
  348. package/esm/renderers/html.renderer.d.ts.map +0 -1
  349. package/esm/renderers/index.d.ts +0 -36
  350. package/esm/renderers/index.d.ts.map +0 -1
  351. package/esm/renderers/index.js +0 -1827
  352. package/esm/renderers/mdx.renderer.d.ts +0 -120
  353. package/esm/renderers/mdx.renderer.d.ts.map +0 -1
  354. package/esm/renderers/react.renderer.d.ts +0 -96
  355. package/esm/renderers/react.renderer.d.ts.map +0 -1
  356. package/esm/renderers/registry.d.ts +0 -134
  357. package/esm/renderers/registry.d.ts.map +0 -1
  358. package/esm/renderers/types.d.ts +0 -342
  359. package/esm/renderers/types.d.ts.map +0 -1
  360. package/esm/renderers/utils/detect.d.ts +0 -107
  361. package/esm/renderers/utils/detect.d.ts.map +0 -1
  362. package/esm/renderers/utils/hash.d.ts +0 -40
  363. package/esm/renderers/utils/hash.d.ts.map +0 -1
  364. package/esm/renderers/utils/index.d.ts +0 -9
  365. package/esm/renderers/utils/index.d.ts.map +0 -1
  366. package/esm/renderers/utils/transpiler.d.ts +0 -89
  367. package/esm/renderers/utils/transpiler.d.ts.map +0 -1
  368. package/esm/runtime/adapters/html.adapter.d.ts +0 -59
  369. package/esm/runtime/adapters/html.adapter.d.ts.map +0 -1
  370. package/esm/runtime/adapters/index.d.ts +0 -26
  371. package/esm/runtime/adapters/index.d.ts.map +0 -1
  372. package/esm/runtime/adapters/mdx.adapter.d.ts +0 -73
  373. package/esm/runtime/adapters/mdx.adapter.d.ts.map +0 -1
  374. package/esm/runtime/adapters/react.adapter.d.ts.map +0 -1
  375. package/esm/runtime/adapters/types.d.ts +0 -95
  376. package/esm/runtime/adapters/types.d.ts.map +0 -1
  377. package/esm/runtime/csp.d.ts +0 -48
  378. package/esm/runtime/csp.d.ts.map +0 -1
  379. package/esm/runtime/index.d.ts +0 -17
  380. package/esm/runtime/index.d.ts.map +0 -1
  381. package/esm/runtime/index.js +0 -5186
  382. package/esm/runtime/mcp-bridge.d.ts +0 -101
  383. package/esm/runtime/mcp-bridge.d.ts.map +0 -1
  384. package/esm/runtime/renderer-runtime.d.ts +0 -133
  385. package/esm/runtime/renderer-runtime.d.ts.map +0 -1
  386. package/esm/runtime/sanitizer.d.ts +0 -172
  387. package/esm/runtime/sanitizer.d.ts.map +0 -1
  388. package/esm/runtime/types.d.ts +0 -415
  389. package/esm/runtime/types.d.ts.map +0 -1
  390. package/esm/runtime/wrapper.d.ts +0 -421
  391. package/esm/runtime/wrapper.d.ts.map +0 -1
  392. package/esm/styles/index.d.ts +0 -8
  393. package/esm/styles/index.d.ts.map +0 -1
  394. package/esm/styles/index.js +0 -171
  395. package/esm/styles/variants.d.ts +0 -51
  396. package/esm/styles/variants.d.ts.map +0 -1
  397. package/esm/theme/cdn.d.ts +0 -195
  398. package/esm/theme/cdn.d.ts.map +0 -1
  399. package/esm/theme/index.d.ts +0 -18
  400. package/esm/theme/index.d.ts.map +0 -1
  401. package/esm/theme/index.js +0 -700
  402. package/esm/theme/platforms.d.ts +0 -107
  403. package/esm/theme/platforms.d.ts.map +0 -1
  404. package/esm/theme/presets/github-openai.d.ts +0 -50
  405. package/esm/theme/presets/github-openai.d.ts.map +0 -1
  406. package/esm/theme/presets/index.d.ts +0 -11
  407. package/esm/theme/presets/index.d.ts.map +0 -1
  408. package/esm/theme/theme.d.ts +0 -396
  409. package/esm/theme/theme.d.ts.map +0 -1
  410. package/esm/tool-template/builder.d.ts +0 -213
  411. package/esm/tool-template/builder.d.ts.map +0 -1
  412. package/esm/tool-template/index.d.ts +0 -16
  413. package/esm/tool-template/index.d.ts.map +0 -1
  414. package/esm/tool-template/index.js +0 -3515
  415. package/esm/types/index.d.ts +0 -14
  416. package/esm/types/index.d.ts.map +0 -1
  417. package/esm/types/index.js +0 -75
  418. package/esm/types/ui-config.d.ts +0 -639
  419. package/esm/types/ui-config.d.ts.map +0 -1
  420. package/esm/types/ui-runtime.d.ts +0 -1007
  421. package/esm/types/ui-runtime.d.ts.map +0 -1
  422. package/esm/typings/cache/cache-adapter.d.ts +0 -125
  423. package/esm/typings/cache/cache-adapter.d.ts.map +0 -1
  424. package/esm/typings/cache/index.d.ts +0 -10
  425. package/esm/typings/cache/index.d.ts.map +0 -1
  426. package/esm/typings/cache/memory-cache.d.ts +0 -92
  427. package/esm/typings/cache/memory-cache.d.ts.map +0 -1
  428. package/esm/typings/dts-parser.d.ts +0 -90
  429. package/esm/typings/dts-parser.d.ts.map +0 -1
  430. package/esm/typings/index.d.ts +0 -48
  431. package/esm/typings/index.d.ts.map +0 -1
  432. package/esm/typings/schemas.d.ts +0 -232
  433. package/esm/typings/schemas.d.ts.map +0 -1
  434. package/esm/typings/type-fetcher.d.ts +0 -89
  435. package/esm/typings/type-fetcher.d.ts.map +0 -1
  436. package/esm/typings/types.d.ts +0 -320
  437. package/esm/typings/types.d.ts.map +0 -1
  438. package/esm/universal/UniversalApp.d.ts +0 -108
  439. package/esm/universal/UniversalApp.d.ts.map +0 -1
  440. package/esm/universal/cached-runtime.d.ts +0 -115
  441. package/esm/universal/cached-runtime.d.ts.map +0 -1
  442. package/esm/universal/context.d.ts +0 -122
  443. package/esm/universal/context.d.ts.map +0 -1
  444. package/esm/universal/index.d.ts +0 -57
  445. package/esm/universal/index.d.ts.map +0 -1
  446. package/esm/universal/renderers/html.renderer.d.ts +0 -37
  447. package/esm/universal/renderers/html.renderer.d.ts.map +0 -1
  448. package/esm/universal/renderers/index.d.ts +0 -112
  449. package/esm/universal/renderers/index.d.ts.map +0 -1
  450. package/esm/universal/renderers/markdown.renderer.d.ts +0 -33
  451. package/esm/universal/renderers/markdown.renderer.d.ts.map +0 -1
  452. package/esm/universal/renderers/mdx.renderer.d.ts +0 -38
  453. package/esm/universal/renderers/mdx.renderer.d.ts.map +0 -1
  454. package/esm/universal/renderers/react.renderer.d.ts +0 -46
  455. package/esm/universal/renderers/react.renderer.d.ts.map +0 -1
  456. package/esm/universal/runtime-builder.d.ts +0 -33
  457. package/esm/universal/runtime-builder.d.ts.map +0 -1
  458. package/esm/universal/store.d.ts +0 -135
  459. package/esm/universal/store.d.ts.map +0 -1
  460. package/esm/universal/types.d.ts +0 -199
  461. package/esm/universal/types.d.ts.map +0 -1
  462. package/esm/utils/escape-html.d.ts +0 -58
  463. package/esm/utils/escape-html.d.ts.map +0 -1
  464. package/esm/utils/index.d.ts +0 -10
  465. package/esm/utils/index.d.ts.map +0 -1
  466. package/esm/utils/index.js +0 -40
  467. package/esm/utils/safe-stringify.d.ts +0 -30
  468. package/esm/utils/safe-stringify.d.ts.map +0 -1
  469. package/esm/validation/error-box.d.ts +0 -56
  470. package/esm/validation/error-box.d.ts.map +0 -1
  471. package/esm/validation/index.d.ts +0 -13
  472. package/esm/validation/index.d.ts.map +0 -1
  473. package/esm/validation/index.js +0 -562
  474. package/esm/validation/schema-paths.d.ts +0 -118
  475. package/esm/validation/schema-paths.d.ts.map +0 -1
  476. package/esm/validation/template-validator.d.ts +0 -143
  477. package/esm/validation/template-validator.d.ts.map +0 -1
  478. package/esm/validation/wrapper.d.ts +0 -97
  479. package/esm/validation/wrapper.d.ts.map +0 -1
  480. package/esm/web-components/core/attribute-parser.d.ts +0 -82
  481. package/esm/web-components/core/attribute-parser.d.ts.map +0 -1
  482. package/esm/web-components/core/base-element.d.ts +0 -197
  483. package/esm/web-components/core/base-element.d.ts.map +0 -1
  484. package/esm/web-components/core/index.d.ts +0 -9
  485. package/esm/web-components/core/index.d.ts.map +0 -1
  486. package/esm/web-components/elements/fmcp-alert.d.ts +0 -46
  487. package/esm/web-components/elements/fmcp-alert.d.ts.map +0 -1
  488. package/esm/web-components/elements/fmcp-badge.d.ts +0 -47
  489. package/esm/web-components/elements/fmcp-badge.d.ts.map +0 -1
  490. package/esm/web-components/elements/fmcp-button.d.ts +0 -117
  491. package/esm/web-components/elements/fmcp-button.d.ts.map +0 -1
  492. package/esm/web-components/elements/fmcp-card.d.ts +0 -53
  493. package/esm/web-components/elements/fmcp-card.d.ts.map +0 -1
  494. package/esm/web-components/elements/fmcp-input.d.ts +0 -96
  495. package/esm/web-components/elements/fmcp-input.d.ts.map +0 -1
  496. package/esm/web-components/elements/fmcp-select.d.ts +0 -100
  497. package/esm/web-components/elements/fmcp-select.d.ts.map +0 -1
  498. package/esm/web-components/elements/index.d.ts +0 -13
  499. package/esm/web-components/elements/index.d.ts.map +0 -1
  500. package/esm/web-components/index.d.ts +0 -50
  501. package/esm/web-components/index.d.ts.map +0 -1
  502. package/esm/web-components/register.d.ts +0 -57
  503. package/esm/web-components/register.d.ts.map +0 -1
  504. package/esm/web-components/types.d.ts +0 -122
  505. package/esm/web-components/types.d.ts.map +0 -1
  506. package/esm/widgets/index.d.ts +0 -8
  507. package/esm/widgets/index.d.ts.map +0 -1
  508. package/esm/widgets/index.js +0 -941
  509. package/esm/widgets/progress.d.ts +0 -133
  510. package/esm/widgets/progress.d.ts.map +0 -1
  511. package/esm/widgets/resource.d.ts +0 -163
  512. package/esm/widgets/resource.d.ts.map +0 -1
  513. package/handlebars/expression-extractor.d.ts +0 -147
  514. package/handlebars/expression-extractor.d.ts.map +0 -1
  515. package/handlebars/helpers.d.ts +0 -339
  516. package/handlebars/helpers.d.ts.map +0 -1
  517. package/handlebars/index.d.ts +0 -195
  518. package/handlebars/index.d.ts.map +0 -1
  519. package/handlebars/index.js +0 -666
  520. package/pages/consent.d.ts +0 -117
  521. package/pages/consent.d.ts.map +0 -1
  522. package/pages/error.d.ts +0 -101
  523. package/pages/error.d.ts.map +0 -1
  524. package/pages/index.d.ts +0 -9
  525. package/pages/index.d.ts.map +0 -1
  526. package/pages/index.js +0 -1602
  527. package/react/utils.d.ts +0 -43
  528. package/react/utils.d.ts.map +0 -1
  529. package/registry/index.d.ts +0 -46
  530. package/registry/index.d.ts.map +0 -1
  531. package/registry/index.js +0 -6465
  532. package/registry/render-template.d.ts +0 -91
  533. package/registry/render-template.d.ts.map +0 -1
  534. package/registry/tool-ui.registry.d.ts +0 -294
  535. package/registry/tool-ui.registry.d.ts.map +0 -1
  536. package/registry/uri-utils.d.ts +0 -56
  537. package/registry/uri-utils.d.ts.map +0 -1
  538. package/renderers/cache.d.ts +0 -145
  539. package/renderers/cache.d.ts.map +0 -1
  540. package/renderers/html.renderer.d.ts +0 -123
  541. package/renderers/html.renderer.d.ts.map +0 -1
  542. package/renderers/registry.d.ts +0 -134
  543. package/renderers/registry.d.ts.map +0 -1
  544. package/renderers/types.d.ts +0 -342
  545. package/renderers/types.d.ts.map +0 -1
  546. package/renderers/utils/detect.d.ts +0 -107
  547. package/renderers/utils/detect.d.ts.map +0 -1
  548. package/renderers/utils/hash.d.ts +0 -40
  549. package/renderers/utils/hash.d.ts.map +0 -1
  550. package/renderers/utils/index.d.ts +0 -9
  551. package/renderers/utils/index.d.ts.map +0 -1
  552. package/renderers/utils/transpiler.d.ts +0 -89
  553. package/renderers/utils/transpiler.d.ts.map +0 -1
  554. package/runtime/adapters/html.adapter.d.ts +0 -59
  555. package/runtime/adapters/html.adapter.d.ts.map +0 -1
  556. package/runtime/adapters/index.d.ts +0 -26
  557. package/runtime/adapters/index.d.ts.map +0 -1
  558. package/runtime/adapters/mdx.adapter.d.ts +0 -73
  559. package/runtime/adapters/mdx.adapter.d.ts.map +0 -1
  560. package/runtime/adapters/react.adapter.d.ts +0 -70
  561. package/runtime/adapters/react.adapter.d.ts.map +0 -1
  562. package/runtime/adapters/types.d.ts +0 -95
  563. package/runtime/adapters/types.d.ts.map +0 -1
  564. package/runtime/csp.d.ts +0 -48
  565. package/runtime/csp.d.ts.map +0 -1
  566. package/runtime/index.d.ts +0 -17
  567. package/runtime/index.d.ts.map +0 -1
  568. package/runtime/index.js +0 -5264
  569. package/runtime/mcp-bridge.d.ts +0 -101
  570. package/runtime/mcp-bridge.d.ts.map +0 -1
  571. package/runtime/renderer-runtime.d.ts +0 -133
  572. package/runtime/renderer-runtime.d.ts.map +0 -1
  573. package/runtime/sanitizer.d.ts +0 -172
  574. package/runtime/sanitizer.d.ts.map +0 -1
  575. package/runtime/types.d.ts +0 -415
  576. package/runtime/types.d.ts.map +0 -1
  577. package/runtime/wrapper.d.ts +0 -421
  578. package/runtime/wrapper.d.ts.map +0 -1
  579. package/styles/index.d.ts +0 -8
  580. package/styles/index.d.ts.map +0 -1
  581. package/styles/index.js +0 -222
  582. package/styles/variants.d.ts +0 -51
  583. package/styles/variants.d.ts.map +0 -1
  584. package/theme/cdn.d.ts +0 -195
  585. package/theme/cdn.d.ts.map +0 -1
  586. package/theme/index.d.ts +0 -18
  587. package/theme/index.d.ts.map +0 -1
  588. package/theme/index.js +0 -757
  589. package/theme/platforms.d.ts +0 -107
  590. package/theme/platforms.d.ts.map +0 -1
  591. package/theme/presets/github-openai.d.ts +0 -50
  592. package/theme/presets/github-openai.d.ts.map +0 -1
  593. package/theme/presets/index.d.ts +0 -11
  594. package/theme/presets/index.d.ts.map +0 -1
  595. package/theme/theme.d.ts +0 -396
  596. package/theme/theme.d.ts.map +0 -1
  597. package/tool-template/builder.d.ts +0 -213
  598. package/tool-template/builder.d.ts.map +0 -1
  599. package/tool-template/index.d.ts +0 -16
  600. package/tool-template/index.d.ts.map +0 -1
  601. package/tool-template/index.js +0 -3559
  602. package/types/index.d.ts +0 -14
  603. package/types/index.d.ts.map +0 -1
  604. package/types/index.js +0 -108
  605. package/types/ui-config.d.ts +0 -639
  606. package/types/ui-config.d.ts.map +0 -1
  607. package/types/ui-runtime.d.ts +0 -1007
  608. package/types/ui-runtime.d.ts.map +0 -1
  609. package/typings/cache/cache-adapter.d.ts +0 -125
  610. package/typings/cache/cache-adapter.d.ts.map +0 -1
  611. package/typings/cache/index.d.ts +0 -10
  612. package/typings/cache/index.d.ts.map +0 -1
  613. package/typings/cache/memory-cache.d.ts +0 -92
  614. package/typings/cache/memory-cache.d.ts.map +0 -1
  615. package/typings/dts-parser.d.ts +0 -90
  616. package/typings/dts-parser.d.ts.map +0 -1
  617. package/typings/index.d.ts +0 -48
  618. package/typings/index.d.ts.map +0 -1
  619. package/typings/schemas.d.ts +0 -232
  620. package/typings/schemas.d.ts.map +0 -1
  621. package/typings/type-fetcher.d.ts +0 -89
  622. package/typings/type-fetcher.d.ts.map +0 -1
  623. package/typings/types.d.ts +0 -320
  624. package/typings/types.d.ts.map +0 -1
  625. package/utils/escape-html.d.ts +0 -58
  626. package/utils/escape-html.d.ts.map +0 -1
  627. package/utils/index.d.ts +0 -10
  628. package/utils/index.d.ts.map +0 -1
  629. package/utils/index.js +0 -70
  630. package/utils/safe-stringify.d.ts +0 -30
  631. package/utils/safe-stringify.d.ts.map +0 -1
  632. package/validation/error-box.d.ts +0 -56
  633. package/validation/error-box.d.ts.map +0 -1
  634. package/validation/index.d.ts +0 -13
  635. package/validation/index.d.ts.map +0 -1
  636. package/validation/index.js +0 -603
  637. package/validation/schema-paths.d.ts +0 -118
  638. package/validation/schema-paths.d.ts.map +0 -1
  639. package/validation/template-validator.d.ts +0 -143
  640. package/validation/template-validator.d.ts.map +0 -1
  641. package/validation/wrapper.d.ts +0 -97
  642. package/validation/wrapper.d.ts.map +0 -1
  643. package/widgets/index.d.ts +0 -8
  644. package/widgets/index.d.ts.map +0 -1
  645. package/widgets/index.js +0 -978
  646. package/widgets/progress.d.ts +0 -133
  647. package/widgets/progress.d.ts.map +0 -1
  648. package/widgets/resource.d.ts +0 -163
  649. package/widgets/resource.d.ts.map +0 -1
  650. /package/esm/render/{index.js → index.mjs} +0 -0
package/widgets/index.js DELETED
@@ -1,978 +0,0 @@
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/widgets/index.ts
21
- var widgets_exports = {};
22
- __export(widgets_exports, {
23
- circularProgress: () => circularProgress,
24
- codePreview: () => codePreview,
25
- contentSkeleton: () => contentSkeleton,
26
- imagePreview: () => imagePreview,
27
- progressBar: () => progressBar,
28
- resourceItem: () => resourceItem,
29
- resourceList: () => resourceList,
30
- resourceWidget: () => resourceWidget,
31
- skeleton: () => skeleton,
32
- statusIndicator: () => statusIndicator,
33
- stepProgress: () => stepProgress
34
- });
35
- module.exports = __toCommonJS(widgets_exports);
36
-
37
- // libs/ui/src/theme/platforms.ts
38
- var CLAUDE_PLATFORM = {
39
- id: "claude",
40
- name: "Claude (Artifacts)",
41
- supportsWidgets: true,
42
- supportsTailwind: true,
43
- supportsHtmx: false,
44
- // Network blocked, HTMX won't work for API calls
45
- networkMode: "blocked",
46
- scriptStrategy: "inline",
47
- maxInlineSize: 100 * 1024,
48
- // 100KB limit for artifacts
49
- cspRestrictions: ["script-src 'unsafe-inline'", "connect-src 'none'"],
50
- options: {
51
- mode: "artifacts",
52
- framework: "react"
53
- // Claude artifacts prefer React
54
- }
55
- };
56
-
57
- // libs/ui/src/utils/escape-html.ts
58
- function escapeHtml(str) {
59
- if (str === null || str === void 0) {
60
- return "";
61
- }
62
- const s = String(str);
63
- 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");
64
- }
65
-
66
- // libs/ui/src/components/card.ts
67
- function getVariantClasses(variant) {
68
- const variants = {
69
- default: "bg-white border border-border rounded-xl shadow-sm",
70
- outlined: "bg-transparent border-2 border-border rounded-xl",
71
- elevated: "bg-white rounded-xl shadow-lg",
72
- filled: "bg-gray-50 rounded-xl",
73
- ghost: "bg-transparent"
74
- };
75
- return variants[variant];
76
- }
77
- function getSizeClasses(size) {
78
- const sizes = {
79
- sm: "p-4",
80
- md: "p-6",
81
- lg: "p-8"
82
- };
83
- return sizes[size];
84
- }
85
- function buildDataAttrs(data) {
86
- if (!data) return "";
87
- return Object.entries(data).map(([key, value]) => `data-${key}="${escapeHtml(value)}"`).join(" ");
88
- }
89
- function card(content, options = {}) {
90
- const {
91
- variant = "default",
92
- size = "md",
93
- title,
94
- subtitle,
95
- headerActions,
96
- footer,
97
- className = "",
98
- id,
99
- data,
100
- clickable = false,
101
- href
102
- } = options;
103
- const variantClasses = getVariantClasses(variant);
104
- const sizeClasses = getSizeClasses(size);
105
- const clickableClasses = clickable ? "cursor-pointer hover:shadow-md transition-shadow" : "";
106
- const allClasses = [variantClasses, sizeClasses, clickableClasses, className].filter(Boolean).join(" ");
107
- const dataAttrs = buildDataAttrs(data);
108
- const idAttr = id ? `id="${escapeHtml(id)}"` : "";
109
- const hasHeader = title || subtitle || headerActions;
110
- const headerHtml = hasHeader ? `<div class="flex items-start justify-between mb-4">
111
- <div>
112
- ${title ? `<h3 class="text-lg font-semibold text-text-primary">${escapeHtml(title)}</h3>` : ""}
113
- ${subtitle ? `<p class="text-sm text-text-secondary mt-1">${escapeHtml(subtitle)}</p>` : ""}
114
- </div>
115
- ${headerActions ? `<div class="flex items-center gap-2">${headerActions}</div>` : ""}
116
- </div>` : "";
117
- const footerHtml = footer ? `<div class="mt-4 pt-4 border-t border-divider">${footer}</div>` : "";
118
- if (href) {
119
- return `<a href="${escapeHtml(href)}" class="${allClasses}" ${idAttr} ${dataAttrs}>
120
- ${headerHtml}
121
- ${content}
122
- ${footerHtml}
123
- </a>`;
124
- }
125
- return `<div class="${allClasses}" ${idAttr} ${dataAttrs}>
126
- ${headerHtml}
127
- ${content}
128
- ${footerHtml}
129
- </div>`;
130
- }
131
-
132
- // libs/ui/src/components/badge.ts
133
- function getVariantClasses2(variant) {
134
- const variants = {
135
- default: "bg-gray-100 text-gray-800",
136
- primary: "bg-primary/10 text-primary",
137
- secondary: "bg-secondary/10 text-secondary",
138
- success: "bg-success/10 text-success",
139
- warning: "bg-warning/10 text-warning",
140
- danger: "bg-danger/10 text-danger",
141
- info: "bg-blue-100 text-blue-800",
142
- outline: "border border-border text-text-primary bg-transparent"
143
- };
144
- return variants[variant];
145
- }
146
- function getSizeClasses2(size, dot) {
147
- if (dot) {
148
- const dotSizes = {
149
- sm: "w-2 h-2",
150
- md: "w-2.5 h-2.5",
151
- lg: "w-3 h-3"
152
- };
153
- return dotSizes[size];
154
- }
155
- const sizes = {
156
- sm: "px-2 py-0.5 text-xs",
157
- md: "px-2.5 py-1 text-xs",
158
- lg: "px-3 py-1.5 text-sm"
159
- };
160
- return sizes[size];
161
- }
162
- function badge(text, options = {}) {
163
- const {
164
- variant = "default",
165
- size = "md",
166
- pill = false,
167
- icon,
168
- dot = false,
169
- className = "",
170
- removable = false
171
- } = options;
172
- if (dot) {
173
- const dotVariants = {
174
- default: "bg-gray-400",
175
- primary: "bg-primary",
176
- secondary: "bg-secondary",
177
- success: "bg-success",
178
- warning: "bg-warning",
179
- danger: "bg-danger",
180
- info: "bg-blue-500",
181
- outline: "border border-current"
182
- };
183
- const dotClasses = ["inline-block rounded-full", getSizeClasses2(size, true), dotVariants[variant], className].filter(Boolean).join(" ");
184
- return `<span class="${dotClasses}" aria-label="${escapeHtml(text)}" title="${escapeHtml(text)}"></span>`;
185
- }
186
- const variantClasses = getVariantClasses2(variant);
187
- const sizeClasses = getSizeClasses2(size, false);
188
- const baseClasses = [
189
- "inline-flex items-center font-medium",
190
- pill ? "rounded-full" : "rounded-md",
191
- variantClasses,
192
- sizeClasses,
193
- className
194
- ].filter(Boolean).join(" ");
195
- const iconHtml = icon ? `<span class="mr-1">${icon}</span>` : "";
196
- const removeHtml = removable ? `<button
197
- type="button"
198
- class="ml-1.5 -mr-1 hover:opacity-70 transition-opacity"
199
- onclick="this.parentElement.remove()"
200
- aria-label="Remove"
201
- >
202
- <svg class="w-3 h-3" fill="none" stroke="currentColor" viewBox="0 0 24 24">
203
- <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M6 18L18 6M6 6l12 12"/>
204
- </svg>
205
- </button>` : "";
206
- return `<span class="${baseClasses}">
207
- ${iconHtml}${escapeHtml(text)}${removeHtml}
208
- </span>`;
209
- }
210
-
211
- // libs/ui/src/validation/error-box.ts
212
- var errorIcon = `<svg class="w-5 h-5 flex-shrink-0" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
213
- <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"/>
214
- </svg>`;
215
- function validationErrorBox(options) {
216
- const { componentName, invalidParam } = options;
217
- return `<div
218
- class="validation-error flex items-start gap-3 p-4 bg-red-50 border border-red-200 text-red-800 rounded-lg"
219
- role="alert"
220
- data-testid="validation-error"
221
- data-component="${escapeHtml(componentName)}"
222
- data-param="${escapeHtml(invalidParam)}"
223
- >
224
- ${errorIcon}
225
- <div class="min-w-0">
226
- <p class="font-semibold text-sm">${escapeHtml(componentName)}: Invalid Configuration</p>
227
- <p class="text-sm opacity-90 mt-0.5">The "${escapeHtml(invalidParam)}" parameter is invalid.</p>
228
- </div>
229
- </div>`;
230
- }
231
-
232
- // libs/ui/src/validation/wrapper.ts
233
- function getFirstInvalidPath(error) {
234
- const firstError = error.issues[0];
235
- if (!firstError || firstError.path.length === 0) {
236
- return "options";
237
- }
238
- return firstError.path.map(String).join(".");
239
- }
240
- function validateOptions(options, config) {
241
- const result = config.schema.safeParse(options);
242
- if (result.success) {
243
- return { success: true, data: result.data };
244
- }
245
- const invalidParam = getFirstInvalidPath(result.error);
246
- return {
247
- success: false,
248
- error: validationErrorBox({
249
- componentName: config.componentName,
250
- invalidParam
251
- })
252
- };
253
- }
254
-
255
- // libs/ui/src/validation/schema-paths.ts
256
- var import_zod = require("zod");
257
-
258
- // libs/ui/src/components/button.schema.ts
259
- var import_zod2 = require("zod");
260
- var ButtonVariantSchema = import_zod2.z.enum(["primary", "secondary", "outline", "ghost", "danger", "success", "link"]);
261
- var ButtonSizeSchema = import_zod2.z.enum(["xs", "sm", "md", "lg", "xl"]);
262
- var ButtonOptionsSchema = import_zod2.z.object({
263
- /** Button variant */
264
- variant: ButtonVariantSchema.optional(),
265
- /** Button size */
266
- size: ButtonSizeSchema.optional(),
267
- /** Button type attribute */
268
- type: import_zod2.z.enum(["button", "submit", "reset"]).optional(),
269
- /** Disabled state */
270
- disabled: import_zod2.z.boolean().optional(),
271
- /** Loading state */
272
- loading: import_zod2.z.boolean().optional(),
273
- /** Full width */
274
- fullWidth: import_zod2.z.boolean().optional(),
275
- /** Icon before text (HTML string) */
276
- iconBefore: import_zod2.z.string().optional(),
277
- /** Icon after text (HTML string) */
278
- iconAfter: import_zod2.z.string().optional(),
279
- /** Icon only (no text) */
280
- iconOnly: import_zod2.z.boolean().optional(),
281
- /** Additional CSS classes */
282
- className: import_zod2.z.string().optional(),
283
- /** Button ID */
284
- id: import_zod2.z.string().optional(),
285
- /** Name attribute */
286
- name: import_zod2.z.string().optional(),
287
- /** Value attribute */
288
- value: import_zod2.z.string().optional(),
289
- /** Click handler (URL for links) */
290
- href: import_zod2.z.string().optional(),
291
- /** Open in new tab */
292
- target: import_zod2.z.enum(["_blank", "_self"]).optional(),
293
- /** Data attributes */
294
- data: import_zod2.z.record(import_zod2.z.string(), import_zod2.z.string()).optional(),
295
- /** ARIA label */
296
- ariaLabel: import_zod2.z.string().optional()
297
- }).strict();
298
- var ButtonGroupOptionsSchema = import_zod2.z.object({
299
- /** Attach buttons visually */
300
- attached: import_zod2.z.boolean().optional(),
301
- /** Direction */
302
- direction: import_zod2.z.enum(["horizontal", "vertical"]).optional(),
303
- /** Gap between buttons */
304
- gap: import_zod2.z.enum(["sm", "md", "lg"]).optional(),
305
- /** Additional CSS classes */
306
- className: import_zod2.z.string().optional()
307
- }).strict();
308
-
309
- // libs/ui/src/components/button.ts
310
- function getVariantClasses3(variant) {
311
- const variants = {
312
- primary: "bg-primary hover:bg-primary/90 text-white shadow-sm",
313
- secondary: "bg-secondary hover:bg-secondary/90 text-white shadow-sm",
314
- outline: "border-2 border-primary text-primary hover:bg-primary/10",
315
- ghost: "text-text-primary hover:bg-gray-100",
316
- danger: "bg-danger hover:bg-danger/90 text-white shadow-sm",
317
- success: "bg-success hover:bg-success/90 text-white shadow-sm",
318
- link: "text-primary hover:text-primary/80 hover:underline"
319
- };
320
- return variants[variant];
321
- }
322
- function getSizeClasses3(size, iconOnly) {
323
- if (iconOnly) {
324
- const iconSizes = {
325
- xs: "p-1.5",
326
- sm: "p-2",
327
- md: "p-2.5",
328
- lg: "p-3",
329
- xl: "p-4"
330
- };
331
- return iconSizes[size];
332
- }
333
- const sizes = {
334
- xs: "px-2.5 py-1.5 text-xs",
335
- sm: "px-3 py-2 text-sm",
336
- md: "px-4 py-2.5 text-sm",
337
- lg: "px-5 py-3 text-base",
338
- xl: "px-6 py-3.5 text-lg"
339
- };
340
- return sizes[size];
341
- }
342
- function sanitizeDataKey(key) {
343
- const sanitized = key.toLowerCase().replace(/[^a-z0-9_-]/g, "-").replace(/-+/g, "-").replace(/^-|-$/g, "");
344
- if (!sanitized) {
345
- console.warn(`[frontmcp/ui] Dropping invalid data-* key: "${key}"`);
346
- return null;
347
- }
348
- return sanitized;
349
- }
350
- var loadingSpinner = `<svg class="animate-spin -ml-1 mr-2 h-4 w-4" fill="none" viewBox="0 0 24 24">
351
- <circle class="opacity-25" cx="12" cy="12" r="10" stroke="currentColor" stroke-width="4"></circle>
352
- <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>
353
- </svg>`;
354
- function isValidHrefProtocol(href) {
355
- const trimmed = href.trim().toLowerCase();
356
- return trimmed.startsWith("http://") || trimmed.startsWith("https://") || trimmed.startsWith("/") || trimmed.startsWith("#") || trimmed.startsWith("mailto:") || trimmed.startsWith("tel:");
357
- }
358
- function button(text, options = {}) {
359
- const validation = validateOptions(options, {
360
- schema: ButtonOptionsSchema,
361
- componentName: "button"
362
- });
363
- if (!validation.success) {
364
- return validation.error;
365
- }
366
- const validatedOptions = validation.data;
367
- const {
368
- variant = "primary",
369
- size = "md",
370
- type = "button",
371
- disabled = false,
372
- loading = false,
373
- fullWidth = false,
374
- iconBefore,
375
- iconAfter,
376
- iconOnly = false,
377
- className = "",
378
- id,
379
- name,
380
- value,
381
- href,
382
- target,
383
- data,
384
- ariaLabel
385
- } = validatedOptions;
386
- if (!iconOnly && !text.trim()) {
387
- console.warn("[frontmcp/ui] Button has empty text. Consider providing text or using iconOnly with ariaLabel.");
388
- }
389
- if (iconOnly && !ariaLabel && !text.trim()) {
390
- console.warn(
391
- "[frontmcp/ui] iconOnly button requires non-empty text or ariaLabel for accessibility; control will have no label."
392
- );
393
- }
394
- if (href && !isValidHrefProtocol(href)) {
395
- console.warn(`[frontmcp/ui] Button href contains potentially dangerous protocol: "${href.slice(0, 20)}..."`);
396
- }
397
- const variantClasses = getVariantClasses3(variant);
398
- const sizeClasses = getSizeClasses3(size, iconOnly);
399
- const safeClassName = className ? escapeHtml(className) : "";
400
- const baseClasses = [
401
- "inline-flex items-center justify-center",
402
- "font-medium",
403
- "rounded-lg",
404
- "transition-colors duration-200",
405
- "focus:outline-none focus:ring-2 focus:ring-primary/50 focus:ring-offset-2",
406
- disabled || loading ? "opacity-50 cursor-not-allowed" : "cursor-pointer",
407
- fullWidth ? "w-full" : "",
408
- variantClasses,
409
- sizeClasses,
410
- safeClassName
411
- ].filter(Boolean).join(" ");
412
- const dataAttrs = data ? Object.entries(data).map(([key, val]) => {
413
- const safeKey = sanitizeDataKey(key);
414
- return safeKey ? `data-${safeKey}="${escapeHtml(val)}"` : "";
415
- }).filter(Boolean).join(" ") : "";
416
- const idAttr = id ? `id="${escapeHtml(id)}"` : "";
417
- const nameAttr = name ? `name="${escapeHtml(name)}"` : "";
418
- const valueAttr = value ? `value="${escapeHtml(value)}"` : "";
419
- const disabledAttr = disabled || loading ? "disabled" : "";
420
- const targetAttr = target ? `target="${escapeHtml(target)}"` : "";
421
- const relAttr = target === "_blank" ? 'rel="noopener noreferrer"' : "";
422
- const trimmedText = text.trim();
423
- const effectiveAriaLabel = ariaLabel ?? (iconOnly && trimmedText ? trimmedText : void 0);
424
- const ariaLabelAttr = effectiveAriaLabel ? `aria-label="${escapeHtml(effectiveAriaLabel)}"` : "";
425
- const iconBeforeHtml = iconBefore && !loading ? `<span class="${iconOnly ? "" : "mr-2"}">${iconBefore}</span>` : "";
426
- const iconAfterHtml = iconAfter && !loading ? `<span class="${iconOnly ? "" : "ml-2"}">${iconAfter}</span>` : "";
427
- const loadingHtml = loading ? loadingSpinner : "";
428
- const textHtml = iconOnly ? "" : escapeHtml(text);
429
- const contentHtml = `${loadingHtml}${iconBeforeHtml}${textHtml}${iconAfterHtml}`;
430
- if (href && !disabled && !loading && isValidHrefProtocol(href)) {
431
- return `<a href="${escapeHtml(
432
- href
433
- )}" class="${baseClasses}" ${idAttr} ${dataAttrs} ${ariaLabelAttr} ${targetAttr} ${relAttr}>
434
- ${contentHtml}
435
- </a>`;
436
- }
437
- return `<button type="${type}" class="${baseClasses}" ${idAttr} ${nameAttr} ${valueAttr} ${disabledAttr} ${dataAttrs} ${ariaLabelAttr}>
438
- ${contentHtml}
439
- </button>`;
440
- }
441
-
442
- // libs/ui/src/widgets/resource.ts
443
- var resourceIcons = {
444
- document: `<svg class="w-8 h-8" fill="none" stroke="currentColor" viewBox="0 0 24 24">
445
- <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M9 12h6m-6 4h6m2 5H7a2 2 0 01-2-2V5a2 2 0 012-2h5.586a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V19a2 2 0 01-2 2z"/>
446
- </svg>`,
447
- image: `<svg class="w-8 h-8" fill="none" stroke="currentColor" viewBox="0 0 24 24">
448
- <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M4 16l4.586-4.586a2 2 0 012.828 0L16 16m-2-2l1.586-1.586a2 2 0 012.828 0L20 14m-6-6h.01M6 20h12a2 2 0 002-2V6a2 2 0 00-2-2H6a2 2 0 00-2 2v12a2 2 0 002 2z"/>
449
- </svg>`,
450
- code: `<svg class="w-8 h-8" fill="none" stroke="currentColor" viewBox="0 0 24 24">
451
- <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M10 20l4-16m4 4l4 4-4 4M6 16l-4-4 4-4"/>
452
- </svg>`,
453
- data: `<svg class="w-8 h-8" fill="none" stroke="currentColor" viewBox="0 0 24 24">
454
- <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M4 7v10c0 2.21 3.582 4 8 4s8-1.79 8-4V7M4 7c0 2.21 3.582 4 8 4s8-1.79 8-4M4 7c0-2.21 3.582-4 8-4s8 1.79 8 4"/>
455
- </svg>`,
456
- file: `<svg class="w-8 h-8" fill="none" stroke="currentColor" viewBox="0 0 24 24">
457
- <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M7 21h10a2 2 0 002-2V9.414a1 1 0 00-.293-.707l-5.414-5.414A1 1 0 0012.586 3H7a2 2 0 00-2 2v14a2 2 0 002 2z"/>
458
- </svg>`,
459
- link: `<svg class="w-8 h-8" fill="none" stroke="currentColor" viewBox="0 0 24 24">
460
- <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M13.828 10.172a4 4 0 00-5.656 0l-4 4a4 4 0 105.656 5.656l1.102-1.101m-.758-4.899a4 4 0 005.656 0l4-4a4 4 0 00-5.656-5.656l-1.1 1.1"/>
461
- </svg>`,
462
- user: `<svg class="w-8 h-8" fill="none" stroke="currentColor" viewBox="0 0 24 24">
463
- <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"/>
464
- </svg>`,
465
- event: `<svg class="w-8 h-8" fill="none" stroke="currentColor" viewBox="0 0 24 24">
466
- <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M8 7V3m8 4V3m-9 8h10M5 21h14a2 2 0 002-2V7a2 2 0 00-2-2H5a2 2 0 00-2 2v12a2 2 0 002 2z"/>
467
- </svg>`,
468
- message: `<svg class="w-8 h-8" fill="none" stroke="currentColor" viewBox="0 0 24 24">
469
- <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M8 10h.01M12 10h.01M16 10h.01M9 16H5a2 2 0 01-2-2V6a2 2 0 012-2h14a2 2 0 012 2v8a2 2 0 01-2 2h-5l-5 5v-5z"/>
470
- </svg>`,
471
- task: `<svg class="w-8 h-8" fill="none" stroke="currentColor" viewBox="0 0 24 24">
472
- <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2m-6 9l2 2 4-4"/>
473
- </svg>`,
474
- custom: `<svg class="w-8 h-8" fill="none" stroke="currentColor" viewBox="0 0 24 24">
475
- <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M19 11H5m14 0a2 2 0 012 2v6a2 2 0 01-2 2H5a2 2 0 01-2-2v-6a2 2 0 012-2m14 0V9a2 2 0 00-2-2M5 11V9a2 2 0 012-2m0 0V5a2 2 0 012-2h6a2 2 0 012 2v2M7 7h10"/>
476
- </svg>`
477
- };
478
- function formatFileSize(bytes) {
479
- if (bytes === 0) return "0 B";
480
- const k = 1024;
481
- const sizes = ["B", "KB", "MB", "GB", "TB"];
482
- const i = Math.floor(Math.log(bytes) / Math.log(k));
483
- return `${parseFloat((bytes / Math.pow(k, i)).toFixed(1))} ${sizes[i]}`;
484
- }
485
- function formatDate(date) {
486
- const d = typeof date === "string" ? new Date(date) : date;
487
- return d.toLocaleDateString("en-US", {
488
- year: "numeric",
489
- month: "short",
490
- day: "numeric"
491
- });
492
- }
493
- function resourceWidget(options) {
494
- const {
495
- type,
496
- title,
497
- description,
498
- icon,
499
- thumbnail,
500
- url,
501
- meta,
502
- status,
503
- actions = [],
504
- className = "",
505
- cardOptions = {}
506
- } = options;
507
- const iconHtml = thumbnail ? `<div class="w-16 h-16 rounded-lg overflow-hidden bg-gray-100 flex-shrink-0">
508
- <img src="${escapeHtml(thumbnail)}" alt="${escapeHtml(title)}" class="w-full h-full object-cover">
509
- </div>` : `<div class="w-16 h-16 rounded-lg bg-gray-100 flex items-center justify-center flex-shrink-0 text-gray-400">
510
- ${icon || resourceIcons[type]}
511
- </div>`;
512
- const statusHtml = status ? badge(status.label, { variant: status.variant, size: "sm" }) : "";
513
- const metaItems = [];
514
- if (meta?.size) {
515
- metaItems.push(formatFileSize(meta.size));
516
- }
517
- if (meta?.mimeType) {
518
- metaItems.push(meta.mimeType);
519
- }
520
- if (meta?.updatedAt) {
521
- metaItems.push(`Updated ${formatDate(meta.updatedAt)}`);
522
- } else if (meta?.createdAt) {
523
- metaItems.push(`Created ${formatDate(meta.createdAt)}`);
524
- }
525
- if (meta?.author) {
526
- metaItems.push(`by ${meta.author}`);
527
- }
528
- const metaHtml = metaItems.length > 0 ? `<div class="text-xs text-text-secondary mt-1">${metaItems.join(" \u2022 ")}</div>` : "";
529
- const tagsHtml = meta?.tags && meta.tags.length > 0 ? `<div class="flex flex-wrap gap-1 mt-2">
530
- ${meta.tags.map((tag) => badge(tag, { variant: "default", size: "sm" })).join("")}
531
- </div>` : "";
532
- const actionsHtml = actions.length > 0 ? `<div class="flex gap-2 mt-4">
533
- ${actions.map((action) => {
534
- const variantMap = {
535
- primary: "primary",
536
- secondary: "secondary",
537
- danger: "danger",
538
- ghost: "ghost"
539
- };
540
- const variant = action.variant ? variantMap[action.variant] : "ghost";
541
- const htmxAttrs = [];
542
- if (action.htmx) {
543
- if (action.htmx.get) htmxAttrs.push(`hx-get="${escapeHtml(action.htmx.get)}"`);
544
- if (action.htmx.post) htmxAttrs.push(`hx-post="${escapeHtml(action.htmx.post)}"`);
545
- if (action.htmx.delete) htmxAttrs.push(`hx-delete="${escapeHtml(action.htmx.delete)}"`);
546
- if (action.htmx.target) htmxAttrs.push(`hx-target="${escapeHtml(action.htmx.target)}"`);
547
- if (action.htmx.swap) htmxAttrs.push(`hx-swap="${escapeHtml(action.htmx.swap)}"`);
548
- if (action.htmx.confirm) htmxAttrs.push(`hx-confirm="${escapeHtml(action.htmx.confirm)}"`);
549
- }
550
- return button(action.label, {
551
- variant,
552
- size: "sm",
553
- href: action.href,
554
- disabled: action.disabled,
555
- iconBefore: action.icon
556
- });
557
- }).join("")}
558
- </div>` : "";
559
- const content = `
560
- <div class="flex gap-4">
561
- ${iconHtml}
562
- <div class="flex-1 min-w-0">
563
- <div class="flex items-start justify-between gap-2">
564
- <div class="min-w-0">
565
- ${url ? `<a href="${escapeHtml(
566
- url
567
- )}" class="font-semibold text-text-primary hover:text-primary truncate block">${escapeHtml(
568
- title
569
- )}</a>` : `<h3 class="font-semibold text-text-primary truncate">${escapeHtml(title)}</h3>`}
570
- ${description ? `<p class="text-sm text-text-secondary mt-0.5 line-clamp-2">${escapeHtml(description)}</p>` : ""}
571
- ${metaHtml}
572
- ${tagsHtml}
573
- </div>
574
- ${statusHtml}
575
- </div>
576
- ${actionsHtml}
577
- </div>
578
- </div>
579
- `;
580
- return card(content, {
581
- variant: "default",
582
- size: "md",
583
- className: `resource-widget resource-${type} ${className}`,
584
- ...cardOptions
585
- });
586
- }
587
- function resourceList(options) {
588
- const {
589
- resources,
590
- title,
591
- emptyMessage = "No resources found",
592
- layout = "list",
593
- columns = 2,
594
- className = "",
595
- showLoadMore = false,
596
- loadMoreUrl
597
- } = options;
598
- const titleHtml = title ? `<h2 class="text-lg font-semibold text-text-primary mb-4">${escapeHtml(title)}</h2>` : "";
599
- if (resources.length === 0) {
600
- return `<div class="${className}">
601
- ${titleHtml}
602
- <div class="text-center py-12 text-text-secondary">
603
- <svg class="w-12 h-12 mx-auto mb-4 text-gray-300" fill="none" stroke="currentColor" viewBox="0 0 24 24">
604
- <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"/>
605
- </svg>
606
- <p>${escapeHtml(emptyMessage)}</p>
607
- </div>
608
- </div>`;
609
- }
610
- const layoutClasses = layout === "grid" ? `grid grid-cols-1 md:grid-cols-${columns} gap-4` : "space-y-4";
611
- const resourcesHtml = resources.map((r) => resourceWidget(r)).join("\n");
612
- const loadMoreHtml = showLoadMore && loadMoreUrl ? `<div class="text-center mt-6">
613
- ${button("Load More", {
614
- variant: "outline",
615
- href: loadMoreUrl
616
- })}
617
- </div>` : "";
618
- return `<div class="resource-list ${className}">
619
- ${titleHtml}
620
- <div class="${layoutClasses}">
621
- ${resourcesHtml}
622
- </div>
623
- ${loadMoreHtml}
624
- </div>`;
625
- }
626
- function resourceItem(options) {
627
- const { type, title, description, icon, url, meta, status } = options;
628
- const iconHtml = `<div class="w-10 h-10 rounded-lg bg-gray-100 flex items-center justify-center flex-shrink-0 text-gray-400">
629
- ${icon || resourceIcons[type]}
630
- </div>`;
631
- const statusHtml = status ? badge(status.label, { variant: status.variant, size: "sm" }) : "";
632
- const metaText = meta?.size ? formatFileSize(meta.size) : "";
633
- const titleElement = url ? `<a href="${escapeHtml(url)}" class="font-medium text-text-primary hover:text-primary">${escapeHtml(title)}</a>` : `<span class="font-medium text-text-primary">${escapeHtml(title)}</span>`;
634
- return `<div class="flex items-center gap-3 p-3 rounded-lg hover:bg-gray-50 transition-colors">
635
- ${iconHtml}
636
- <div class="flex-1 min-w-0">
637
- <div class="flex items-center gap-2">
638
- ${titleElement}
639
- ${statusHtml}
640
- </div>
641
- ${description || metaText ? `<p class="text-sm text-text-secondary truncate">${escapeHtml(description || metaText)}</p>` : ""}
642
- </div>
643
- </div>`;
644
- }
645
- function codePreview(options) {
646
- const {
647
- code,
648
- language = "text",
649
- filename,
650
- lineNumbers = true,
651
- maxHeight = "400px",
652
- showCopy = true,
653
- className = ""
654
- } = options;
655
- const lines = code.split("\n");
656
- const lineNumbersHtml = lineNumbers ? `<div class="text-right select-none pr-4 text-gray-500">
657
- ${lines.map((_, i) => `<div>${i + 1}</div>`).join("")}
658
- </div>` : "";
659
- const copyScript = showCopy ? `<script>
660
- function copyCode(btn, code) {
661
- navigator.clipboard.writeText(code).then(() => {
662
- const original = btn.innerHTML;
663
- 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>';
664
- setTimeout(() => btn.innerHTML = original, 2000);
665
- });
666
- }
667
- </script>` : "";
668
- const copyButton = showCopy ? `<button
669
- type="button"
670
- onclick="copyCode(this, ${escapeHtml(JSON.stringify(code))})"
671
- class="p-1.5 rounded hover:bg-gray-700 transition-colors"
672
- title="Copy code"
673
- >
674
- <svg class="w-4 h-4" fill="none" stroke="currentColor" viewBox="0 0 24 24">
675
- <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"/>
676
- </svg>
677
- </button>` : "";
678
- return `<div class="code-preview rounded-lg overflow-hidden ${className}">
679
- ${filename || showCopy ? `
680
- <div class="flex items-center justify-between px-4 py-2 bg-gray-800 border-b border-gray-700">
681
- ${filename ? `<span class="text-sm text-gray-300">${escapeHtml(filename)}</span>` : "<span></span>"}
682
- <div class="flex items-center gap-2">
683
- ${language ? `<span class="text-xs text-gray-500">${escapeHtml(language)}</span>` : ""}
684
- ${copyButton}
685
- </div>
686
- </div>
687
- ` : ""}
688
- <div class="bg-gray-900 p-4 overflow-auto" style="max-height: ${maxHeight}">
689
- <div class="flex text-sm font-mono">
690
- ${lineNumbersHtml}
691
- <pre class="flex-1 text-gray-100"><code>${escapeHtml(code)}</code></pre>
692
- </div>
693
- </div>
694
- ${copyScript}
695
- </div>`;
696
- }
697
- function imagePreview(options) {
698
- const { src, alt, caption, maxHeight = "400px", clickable = true, className = "" } = options;
699
- const imageHtml = `<img
700
- src="${escapeHtml(src)}"
701
- alt="${escapeHtml(alt)}"
702
- class="max-w-full h-auto rounded-lg"
703
- style="max-height: ${maxHeight}"
704
- >`;
705
- const captionHtml = caption ? `<p class="text-sm text-text-secondary mt-2 text-center">${escapeHtml(caption)}</p>` : "";
706
- const content = clickable ? `<a href="${escapeHtml(src)}" target="_blank" rel="noopener" class="block">${imageHtml}</a>` : imageHtml;
707
- return `<div class="image-preview ${className}">
708
- ${content}
709
- ${captionHtml}
710
- </div>`;
711
- }
712
-
713
- // libs/ui/src/widgets/progress.ts
714
- function progressBar(options) {
715
- const {
716
- value,
717
- showLabel = true,
718
- labelPosition = "outside",
719
- size = "md",
720
- variant = "primary",
721
- animated = false,
722
- className = "",
723
- label
724
- } = options;
725
- const clampedValue = Math.min(100, Math.max(0, value));
726
- const sizeClasses = {
727
- sm: "h-1.5",
728
- md: "h-2.5",
729
- lg: "h-4"
730
- };
731
- const variantClasses = {
732
- primary: "bg-primary",
733
- success: "bg-success",
734
- warning: "bg-warning",
735
- danger: "bg-danger",
736
- info: "bg-blue-500"
737
- };
738
- const animatedClass = animated ? "bg-stripes animate-stripes" : "";
739
- const displayLabel = label || `${Math.round(clampedValue)}%`;
740
- const insideLabel = labelPosition === "inside" && size === "lg" && clampedValue > 10 ? `<span class="absolute inset-0 flex items-center justify-center text-xs font-medium text-white">${escapeHtml(
741
- displayLabel
742
- )}</span>` : "";
743
- const outsideLabel = showLabel && labelPosition === "outside" ? `<div class="flex justify-between mb-1">
744
- <span class="text-sm font-medium text-text-primary">${label ? escapeHtml(label) : "Progress"}</span>
745
- <span class="text-sm text-text-secondary">${Math.round(clampedValue)}%</span>
746
- </div>` : "";
747
- return `<div class="progress-bar ${className}">
748
- ${outsideLabel}
749
- <div class="relative w-full ${sizeClasses[size]} bg-gray-200 rounded-full overflow-hidden">
750
- <div
751
- class="${variantClasses[variant]} ${sizeClasses[size]} ${animatedClass} rounded-full transition-all duration-300"
752
- style="width: ${clampedValue}%"
753
- role="progressbar"
754
- aria-valuenow="${clampedValue}"
755
- aria-valuemin="0"
756
- aria-valuemax="100"
757
- ></div>
758
- ${insideLabel}
759
- </div>
760
- </div>
761
- ${animated ? `<style>
762
- .bg-stripes {
763
- background-image: linear-gradient(
764
- 45deg,
765
- rgba(255,255,255,0.15) 25%,
766
- transparent 25%,
767
- transparent 50%,
768
- rgba(255,255,255,0.15) 50%,
769
- rgba(255,255,255,0.15) 75%,
770
- transparent 75%,
771
- transparent
772
- );
773
- background-size: 1rem 1rem;
774
- }
775
- @keyframes stripes {
776
- from { background-position: 1rem 0; }
777
- to { background-position: 0 0; }
778
- }
779
- .animate-stripes {
780
- animation: stripes 1s linear infinite;
781
- }
782
- </style>` : ""}`;
783
- }
784
- function stepProgress(options) {
785
- const { steps, orientation = "horizontal", connector = "line", className = "" } = options;
786
- const getStepIcon = (step, index) => {
787
- if (step.icon) return step.icon;
788
- if (step.status === "completed") {
789
- return `<svg class="w-5 h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24">
790
- <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M5 13l4 4L19 7"/>
791
- </svg>`;
792
- }
793
- return `<span class="font-medium">${index + 1}</span>`;
794
- };
795
- const getStepClasses = (status) => {
796
- switch (status) {
797
- case "completed":
798
- return {
799
- circle: "bg-success text-white",
800
- text: "text-text-primary"
801
- };
802
- case "current":
803
- return {
804
- circle: "bg-primary text-white ring-4 ring-primary/20",
805
- text: "text-primary font-medium"
806
- };
807
- case "upcoming":
808
- default:
809
- return {
810
- circle: "bg-gray-200 text-gray-500",
811
- text: "text-text-secondary"
812
- };
813
- }
814
- };
815
- if (orientation === "vertical") {
816
- const stepsHtml2 = steps.map((step, index) => {
817
- const classes = getStepClasses(step.status);
818
- const isLast = index === steps.length - 1;
819
- const connectorHtml = !isLast && connector !== "none" ? `<div class="ml-5 w-0.5 h-8 ${connector === "dashed" ? "border-l-2 border-dashed border-gray-300" : "bg-gray-200"} ${step.status === "completed" ? "bg-success" : ""}"></div>` : "";
820
- const stepContent = `
821
- <div class="flex items-start gap-4">
822
- <div class="w-10 h-10 rounded-full ${classes.circle} flex items-center justify-center flex-shrink-0">
823
- ${getStepIcon(step, index)}
824
- </div>
825
- <div class="pt-2">
826
- <div class="${classes.text}">${escapeHtml(step.label)}</div>
827
- ${step.description ? `<p class="text-sm text-text-secondary mt-0.5">${escapeHtml(step.description)}</p>` : ""}
828
- </div>
829
- </div>
830
- ${connectorHtml}
831
- `;
832
- return step.href && step.status === "completed" ? `<a href="${escapeHtml(step.href)}" class="block hover:opacity-80">${stepContent}</a>` : `<div>${stepContent}</div>`;
833
- }).join("\n");
834
- return `<div class="step-progress ${className}">${stepsHtml2}</div>`;
835
- }
836
- const stepsHtml = steps.map((step, index) => {
837
- const classes = getStepClasses(step.status);
838
- const isLast = index === steps.length - 1;
839
- const connectorHtml = !isLast && connector !== "none" ? `<div class="flex-1 h-0.5 mx-2 ${connector === "dashed" ? "border-t-2 border-dashed border-gray-300" : "bg-gray-200"} ${step.status === "completed" ? "bg-success" : ""}"></div>` : "";
840
- const stepHtml = `
841
- <div class="flex flex-col items-center">
842
- <div class="w-10 h-10 rounded-full ${classes.circle} flex items-center justify-center">
843
- ${getStepIcon(step, index)}
844
- </div>
845
- <div class="mt-2 text-center">
846
- <div class="${classes.text} text-sm">${escapeHtml(step.label)}</div>
847
- ${step.description ? `<p class="text-xs text-text-secondary mt-0.5 max-w-[120px]">${escapeHtml(step.description)}</p>` : ""}
848
- </div>
849
- </div>
850
- `;
851
- const clickableStep = step.href && step.status === "completed" ? `<a href="${escapeHtml(step.href)}" class="hover:opacity-80">${stepHtml}</a>` : stepHtml;
852
- return `${clickableStep}${connectorHtml}`;
853
- }).join("\n");
854
- return `<div class="step-progress flex items-start ${className}">${stepsHtml}</div>`;
855
- }
856
- function circularProgress(options) {
857
- const { value, size = 80, strokeWidth = 8, variant = "primary", showLabel = true, label, className = "" } = options;
858
- const clampedValue = Math.min(100, Math.max(0, value));
859
- const radius = (size - strokeWidth) / 2;
860
- const circumference = radius * 2 * Math.PI;
861
- const offset = circumference - clampedValue / 100 * circumference;
862
- const variantColors = {
863
- primary: "text-primary",
864
- success: "text-success",
865
- warning: "text-warning",
866
- danger: "text-danger"
867
- };
868
- const displayLabel = label || `${Math.round(clampedValue)}%`;
869
- return `<div class="circular-progress inline-flex items-center justify-center ${className}" style="width: ${size}px; height: ${size}px;">
870
- <svg class="transform -rotate-90" width="${size}" height="${size}">
871
- <!-- Background circle -->
872
- <circle
873
- cx="${size / 2}"
874
- cy="${size / 2}"
875
- r="${radius}"
876
- fill="none"
877
- stroke="currentColor"
878
- stroke-width="${strokeWidth}"
879
- class="text-gray-200"
880
- />
881
- <!-- Progress circle -->
882
- <circle
883
- cx="${size / 2}"
884
- cy="${size / 2}"
885
- r="${radius}"
886
- fill="none"
887
- stroke="currentColor"
888
- stroke-width="${strokeWidth}"
889
- stroke-linecap="round"
890
- class="${variantColors[variant]}"
891
- style="stroke-dasharray: ${circumference}; stroke-dashoffset: ${offset}; transition: stroke-dashoffset 0.3s ease;"
892
- />
893
- </svg>
894
- ${showLabel ? `<span class="absolute text-sm font-semibold text-text-primary">${escapeHtml(displayLabel)}</span>` : ""}
895
- </div>`;
896
- }
897
- function statusIndicator(options) {
898
- const { status, label, size = "md", pulse = false, className = "" } = options;
899
- const sizeClasses = {
900
- sm: { dot: "w-2 h-2", text: "text-xs" },
901
- md: { dot: "w-2.5 h-2.5", text: "text-sm" },
902
- lg: { dot: "w-3 h-3", text: "text-base" }
903
- };
904
- const statusClasses = {
905
- online: { color: "bg-success", label: "Online" },
906
- offline: { color: "bg-gray-400", label: "Offline" },
907
- busy: { color: "bg-danger", label: "Busy" },
908
- away: { color: "bg-warning", label: "Away" },
909
- loading: { color: "bg-blue-500", label: "Loading" },
910
- error: { color: "bg-danger", label: "Error" },
911
- success: { color: "bg-success", label: "Success" }
912
- };
913
- const statusInfo = statusClasses[status];
914
- const sizeInfo = sizeClasses[size];
915
- const displayLabel = label || statusInfo.label;
916
- const pulseHtml = pulse || status === "loading" ? `<span class="absolute ${sizeInfo.dot} ${statusInfo.color} rounded-full animate-ping opacity-75"></span>` : "";
917
- return `<div class="status-indicator inline-flex items-center gap-2 ${className}">
918
- <span class="relative flex">
919
- ${pulseHtml}
920
- <span class="relative ${sizeInfo.dot} ${statusInfo.color} rounded-full"></span>
921
- </span>
922
- ${displayLabel ? `<span class="${sizeInfo.text} text-text-secondary">${escapeHtml(displayLabel)}</span>` : ""}
923
- </div>`;
924
- }
925
- function skeleton(options = {}) {
926
- const { type = "text", width, height, lines = 3, animated = true, className = "" } = options;
927
- const animateClass = animated ? "animate-pulse" : "";
928
- const baseClass = `bg-gray-200 ${animateClass}`;
929
- switch (type) {
930
- case "circle":
931
- return `<div class="${baseClass} rounded-full ${className}" style="width: ${width || "40px"}; height: ${height || "40px"}"></div>`;
932
- case "rect":
933
- return `<div class="${baseClass} rounded ${className}" style="width: ${width || "100%"}; height: ${height || "100px"}"></div>`;
934
- case "card":
935
- return `<div class="${animateClass} space-y-4 ${className}">
936
- <div class="bg-gray-200 rounded h-40"></div>
937
- <div class="space-y-2">
938
- <div class="bg-gray-200 h-4 rounded w-3/4"></div>
939
- <div class="bg-gray-200 h-4 rounded w-1/2"></div>
940
- </div>
941
- </div>`;
942
- case "text":
943
- default: {
944
- const linesHtml = Array(lines).fill(0).map((_, i) => {
945
- const lineWidth = i === lines - 1 ? "60%" : i === 0 ? "90%" : "80%";
946
- return `<div class="bg-gray-200 h-4 rounded" style="width: ${lineWidth}"></div>`;
947
- }).join("\n");
948
- return `<div class="${animateClass} space-y-2 ${className}" style="width: ${width || "100%"}">
949
- ${linesHtml}
950
- </div>`;
951
- }
952
- }
953
- }
954
- function contentSkeleton(options = {}) {
955
- const { animated = true, className = "" } = options;
956
- const animateClass = animated ? "animate-pulse" : "";
957
- return `<div class="${animateClass} flex gap-4 ${className}">
958
- <div class="bg-gray-200 rounded-full w-12 h-12 flex-shrink-0"></div>
959
- <div class="flex-1 space-y-2 py-1">
960
- <div class="bg-gray-200 h-4 rounded w-3/4"></div>
961
- <div class="bg-gray-200 h-4 rounded w-1/2"></div>
962
- </div>
963
- </div>`;
964
- }
965
- // Annotate the CommonJS export names for ESM import in node:
966
- 0 && (module.exports = {
967
- circularProgress,
968
- codePreview,
969
- contentSkeleton,
970
- imagePreview,
971
- progressBar,
972
- resourceItem,
973
- resourceList,
974
- resourceWidget,
975
- skeleton,
976
- statusIndicator,
977
- stepProgress
978
- });