@frontmcp/ui 0.12.2 → 1.0.0-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (310) hide show
  1. package/README.md +279 -72
  2. package/bridge/adapters/claude.adapter.d.ts.map +1 -1
  3. package/bridge/adapters/gemini.adapter.d.ts.map +1 -1
  4. package/bridge/index.js +2 -36
  5. package/components/Alert/Alert.d.ts +11 -0
  6. package/components/Alert/Alert.d.ts.map +1 -0
  7. package/components/Alert/index.d.ts +4 -0
  8. package/components/Alert/index.d.ts.map +1 -0
  9. package/components/Alert/index.js +61 -0
  10. package/components/Avatar/Avatar.d.ts +10 -0
  11. package/components/Avatar/Avatar.d.ts.map +1 -0
  12. package/components/Avatar/index.d.ts +4 -0
  13. package/components/Avatar/index.d.ts.map +1 -0
  14. package/components/Avatar/index.js +43 -0
  15. package/components/Badge/Badge.d.ts +13 -0
  16. package/components/Badge/Badge.d.ts.map +1 -0
  17. package/components/Badge/index.d.ts +4 -0
  18. package/components/Badge/index.d.ts.map +1 -0
  19. package/{render → components/Badge}/index.js +54 -42
  20. package/components/Button/Button.d.ts +16 -0
  21. package/components/Button/Button.d.ts.map +1 -0
  22. package/components/Button/index.d.ts +4 -0
  23. package/components/Button/index.d.ts.map +1 -0
  24. package/components/Button/index.js +91 -0
  25. package/components/Card/Card.d.ts +25 -0
  26. package/components/Card/Card.d.ts.map +1 -0
  27. package/components/Card/index.d.ts +4 -0
  28. package/components/Card/index.d.ts.map +1 -0
  29. package/components/Card/index.js +110 -0
  30. package/components/List/List.d.ts +15 -0
  31. package/components/List/List.d.ts.map +1 -0
  32. package/components/List/index.d.ts +4 -0
  33. package/components/List/index.d.ts.map +1 -0
  34. package/components/List/index.js +58 -0
  35. package/components/Loader/Loader.d.ts +28 -0
  36. package/components/Loader/Loader.d.ts.map +1 -0
  37. package/components/Loader/LoaderContext.d.ts +20 -0
  38. package/components/Loader/LoaderContext.d.ts.map +1 -0
  39. package/components/Loader/index.d.ts +6 -0
  40. package/components/Loader/index.d.ts.map +1 -0
  41. package/components/Loader/index.js +174 -0
  42. package/components/Modal/Modal.d.ts +22 -0
  43. package/components/Modal/Modal.d.ts.map +1 -0
  44. package/components/Modal/index.d.ts +4 -0
  45. package/components/Modal/index.d.ts.map +1 -0
  46. package/components/Modal/index.js +80 -0
  47. package/components/Select/Select.d.ts +21 -0
  48. package/components/Select/Select.d.ts.map +1 -0
  49. package/components/Select/index.d.ts +4 -0
  50. package/components/Select/index.d.ts.map +1 -0
  51. package/components/Select/index.js +78 -0
  52. package/components/Table/Table.d.ts +15 -0
  53. package/components/Table/Table.d.ts.map +1 -0
  54. package/components/Table/index.d.ts +4 -0
  55. package/components/Table/index.d.ts.map +1 -0
  56. package/components/Table/index.js +70 -0
  57. package/components/TextField/TextField.d.ts +19 -0
  58. package/components/TextField/TextField.d.ts.map +1 -0
  59. package/components/TextField/index.d.ts +4 -0
  60. package/components/TextField/index.d.ts.map +1 -0
  61. package/components/TextField/index.js +77 -0
  62. package/components/index.d.ts +22 -28
  63. package/components/index.d.ts.map +1 -1
  64. package/components/index.js +523 -2521
  65. package/esm/bridge/index.mjs +2 -6
  66. package/esm/components/Alert/index.mjs +28 -0
  67. package/esm/components/Avatar/index.mjs +10 -0
  68. package/esm/components/Badge/index.mjs +56 -0
  69. package/esm/components/Button/index.mjs +58 -0
  70. package/esm/components/Card/index.mjs +77 -0
  71. package/esm/components/List/index.mjs +25 -0
  72. package/esm/components/Loader/index.mjs +141 -0
  73. package/esm/components/Modal/index.mjs +47 -0
  74. package/esm/components/Select/index.mjs +45 -0
  75. package/esm/components/Table/index.mjs +37 -0
  76. package/esm/components/TextField/index.mjs +44 -0
  77. package/esm/components/index.mjs +513 -2415
  78. package/esm/index.mjs +62 -4652
  79. package/esm/package.json +372 -16
  80. package/esm/react/index.mjs +2 -285
  81. package/esm/renderer/charts/index.mjs +336 -0
  82. package/esm/renderer/common/index.mjs +135 -0
  83. package/esm/renderer/csv/index.mjs +193 -0
  84. package/esm/renderer/flow/index.mjs +259 -0
  85. package/esm/renderer/html/index.mjs +99 -0
  86. package/esm/renderer/image/index.mjs +125 -0
  87. package/esm/renderer/index.mjs +2173 -0
  88. package/esm/renderer/maps/index.mjs +217 -0
  89. package/esm/renderer/math/index.mjs +229 -0
  90. package/esm/renderer/mdx/index.mjs +261 -0
  91. package/esm/renderer/media/index.mjs +235 -0
  92. package/esm/renderer/mermaid/index.mjs +220 -0
  93. package/esm/renderer/pdf/index.mjs +229 -0
  94. package/esm/renderer/react/index.mjs +230 -0
  95. package/esm/runtime/index.mjs +194 -0
  96. package/esm/theme/index.mjs +93 -0
  97. package/index.d.ts +10 -18
  98. package/index.d.ts.map +1 -1
  99. package/index.js +63 -4806
  100. package/package.json +372 -16
  101. package/react/index.d.ts +8 -54
  102. package/react/index.d.ts.map +1 -1
  103. package/react/index.js +2 -295
  104. package/renderer/auto-detect.d.ts +39 -0
  105. package/renderer/auto-detect.d.ts.map +1 -0
  106. package/renderer/charts/index.d.ts +22 -0
  107. package/renderer/charts/index.d.ts.map +1 -0
  108. package/renderer/charts/index.js +367 -0
  109. package/renderer/common/index.d.ts +5 -0
  110. package/renderer/common/index.d.ts.map +1 -0
  111. package/renderer/common/index.js +158 -0
  112. package/renderer/common/inject-stylesheet.d.ts +9 -0
  113. package/renderer/common/inject-stylesheet.d.ts.map +1 -0
  114. package/renderer/common/lazy-import.d.ts +85 -0
  115. package/renderer/common/lazy-import.d.ts.map +1 -0
  116. package/renderer/common/use-lazy-module.d.ts +13 -0
  117. package/renderer/common/use-lazy-module.d.ts.map +1 -0
  118. package/renderer/common/use-renderer-theme.d.ts +35 -0
  119. package/renderer/common/use-renderer-theme.d.ts.map +1 -0
  120. package/renderer/csv/index.d.ts +12 -0
  121. package/renderer/csv/index.d.ts.map +1 -0
  122. package/renderer/csv/index.js +224 -0
  123. package/renderer/flow/index.d.ts +40 -0
  124. package/renderer/flow/index.d.ts.map +1 -0
  125. package/renderer/flow/index.js +290 -0
  126. package/renderer/html/index.d.ts +12 -0
  127. package/renderer/html/index.d.ts.map +1 -0
  128. package/renderer/html/index.js +130 -0
  129. package/renderer/image/index.d.ts +11 -0
  130. package/renderer/image/index.d.ts.map +1 -0
  131. package/renderer/image/index.js +156 -0
  132. package/renderer/index.d.ts +32 -0
  133. package/renderer/index.d.ts.map +1 -0
  134. package/renderer/index.js +2206 -0
  135. package/renderer/maps/index.d.ts +27 -0
  136. package/renderer/maps/index.d.ts.map +1 -0
  137. package/renderer/maps/index.js +248 -0
  138. package/renderer/math/index.d.ts +11 -0
  139. package/renderer/math/index.d.ts.map +1 -0
  140. package/renderer/math/index.js +260 -0
  141. package/renderer/mdx/index.d.ts +10 -0
  142. package/renderer/mdx/index.d.ts.map +1 -0
  143. package/renderer/mdx/index.js +292 -0
  144. package/renderer/media/index.d.ts +20 -0
  145. package/renderer/media/index.d.ts.map +1 -0
  146. package/renderer/media/index.js +266 -0
  147. package/renderer/mermaid/index.d.ts +11 -0
  148. package/renderer/mermaid/index.d.ts.map +1 -0
  149. package/renderer/mermaid/index.js +251 -0
  150. package/renderer/pdf/index.d.ts +10 -0
  151. package/renderer/pdf/index.d.ts.map +1 -0
  152. package/renderer/pdf/index.js +260 -0
  153. package/renderer/react/index.d.ts +45 -0
  154. package/renderer/react/index.d.ts.map +1 -0
  155. package/renderer/react/index.js +261 -0
  156. package/renderer/types.d.ts +24 -0
  157. package/renderer/types.d.ts.map +1 -0
  158. package/runtime/babel-runtime.d.ts +70 -0
  159. package/runtime/babel-runtime.d.ts.map +1 -0
  160. package/runtime/content-detector.d.ts +43 -0
  161. package/runtime/content-detector.d.ts.map +1 -0
  162. package/runtime/index.d.ts +10 -0
  163. package/runtime/index.d.ts.map +1 -0
  164. package/runtime/index.js +217 -0
  165. package/theme/FrontMcpThemeProvider.d.ts +4 -0
  166. package/theme/FrontMcpThemeProvider.d.ts.map +1 -0
  167. package/theme/create-theme.d.ts +9 -0
  168. package/theme/create-theme.d.ts.map +1 -0
  169. package/theme/index.d.ts +5 -0
  170. package/theme/index.d.ts.map +1 -0
  171. package/theme/index.js +126 -0
  172. package/theme/types.d.ts +28 -0
  173. package/theme/types.d.ts.map +1 -0
  174. package/theme/use-theme.d.ts +3 -0
  175. package/theme/use-theme.d.ts.map +1 -0
  176. package/bundler/browser-components.d.ts +0 -42
  177. package/bundler/browser-components.d.ts.map +0 -1
  178. package/bundler/bundler.d.ts +0 -282
  179. package/bundler/bundler.d.ts.map +0 -1
  180. package/bundler/index.d.ts +0 -43
  181. package/bundler/index.d.ts.map +0 -1
  182. package/bundler/index.js +0 -3168
  183. package/bundler/types.d.ts +0 -883
  184. package/bundler/types.d.ts.map +0 -1
  185. package/components/alert.d.ts +0 -83
  186. package/components/alert.d.ts.map +0 -1
  187. package/components/alert.schema.d.ts +0 -98
  188. package/components/alert.schema.d.ts.map +0 -1
  189. package/components/avatar.d.ts +0 -77
  190. package/components/avatar.d.ts.map +0 -1
  191. package/components/avatar.schema.d.ts +0 -170
  192. package/components/avatar.schema.d.ts.map +0 -1
  193. package/components/badge.d.ts +0 -78
  194. package/components/badge.d.ts.map +0 -1
  195. package/components/badge.schema.d.ts +0 -91
  196. package/components/badge.schema.d.ts.map +0 -1
  197. package/components/button.d.ts +0 -100
  198. package/components/button.d.ts.map +0 -1
  199. package/components/button.schema.d.ts +0 -120
  200. package/components/button.schema.d.ts.map +0 -1
  201. package/components/card.d.ts +0 -76
  202. package/components/card.d.ts.map +0 -1
  203. package/components/card.schema.d.ts +0 -93
  204. package/components/card.schema.d.ts.map +0 -1
  205. package/components/form.d.ts +0 -227
  206. package/components/form.d.ts.map +0 -1
  207. package/components/form.schema.d.ts +0 -365
  208. package/components/form.schema.d.ts.map +0 -1
  209. package/components/list.d.ts +0 -121
  210. package/components/list.d.ts.map +0 -1
  211. package/components/list.schema.d.ts +0 -129
  212. package/components/list.schema.d.ts.map +0 -1
  213. package/components/modal.d.ts +0 -100
  214. package/components/modal.d.ts.map +0 -1
  215. package/components/modal.schema.d.ts +0 -151
  216. package/components/modal.schema.d.ts.map +0 -1
  217. package/components/table.d.ts +0 -91
  218. package/components/table.d.ts.map +0 -1
  219. package/components/table.schema.d.ts +0 -123
  220. package/components/table.schema.d.ts.map +0 -1
  221. package/esm/bundler/index.mjs +0 -3136
  222. package/esm/layouts/index.mjs +0 -409
  223. package/esm/render/index.mjs +0 -45
  224. package/esm/renderers/index.mjs +0 -621
  225. package/esm/universal/index.mjs +0 -1946
  226. package/esm/web-components/index.mjs +0 -2023
  227. package/layouts/base.d.ts +0 -86
  228. package/layouts/base.d.ts.map +0 -1
  229. package/layouts/index.d.ts +0 -8
  230. package/layouts/index.d.ts.map +0 -1
  231. package/layouts/index.js +0 -437
  232. package/layouts/presets.d.ts +0 -134
  233. package/layouts/presets.d.ts.map +0 -1
  234. package/react/Alert.d.ts +0 -101
  235. package/react/Alert.d.ts.map +0 -1
  236. package/react/Badge.d.ts +0 -100
  237. package/react/Badge.d.ts.map +0 -1
  238. package/react/Button.d.ts +0 -108
  239. package/react/Button.d.ts.map +0 -1
  240. package/react/Card.d.ts +0 -103
  241. package/react/Card.d.ts.map +0 -1
  242. package/react/types.d.ts +0 -105
  243. package/react/types.d.ts.map +0 -1
  244. package/render/index.d.ts +0 -8
  245. package/render/index.d.ts.map +0 -1
  246. package/render/prerender.d.ts +0 -57
  247. package/render/prerender.d.ts.map +0 -1
  248. package/renderers/index.d.ts +0 -26
  249. package/renderers/index.d.ts.map +0 -1
  250. package/renderers/index.js +0 -666
  251. package/renderers/mdx.renderer.d.ts +0 -99
  252. package/renderers/mdx.renderer.d.ts.map +0 -1
  253. package/renderers/react.adapter.d.ts +0 -70
  254. package/renderers/react.adapter.d.ts.map +0 -1
  255. package/renderers/react.renderer.d.ts +0 -105
  256. package/renderers/react.renderer.d.ts.map +0 -1
  257. package/renderers/transpiler.d.ts +0 -49
  258. package/renderers/transpiler.d.ts.map +0 -1
  259. package/universal/UniversalApp.d.ts +0 -108
  260. package/universal/UniversalApp.d.ts.map +0 -1
  261. package/universal/cached-runtime.d.ts +0 -139
  262. package/universal/cached-runtime.d.ts.map +0 -1
  263. package/universal/context.d.ts +0 -122
  264. package/universal/context.d.ts.map +0 -1
  265. package/universal/index.d.ts +0 -57
  266. package/universal/index.d.ts.map +0 -1
  267. package/universal/index.js +0 -2032
  268. package/universal/renderers/html.renderer.d.ts +0 -36
  269. package/universal/renderers/html.renderer.d.ts.map +0 -1
  270. package/universal/renderers/index.d.ts +0 -112
  271. package/universal/renderers/index.d.ts.map +0 -1
  272. package/universal/renderers/markdown.renderer.d.ts +0 -33
  273. package/universal/renderers/markdown.renderer.d.ts.map +0 -1
  274. package/universal/renderers/mdx.renderer.d.ts +0 -38
  275. package/universal/renderers/mdx.renderer.d.ts.map +0 -1
  276. package/universal/renderers/react.renderer.d.ts +0 -46
  277. package/universal/renderers/react.renderer.d.ts.map +0 -1
  278. package/universal/runtime-builder.d.ts +0 -33
  279. package/universal/runtime-builder.d.ts.map +0 -1
  280. package/universal/store.d.ts +0 -135
  281. package/universal/store.d.ts.map +0 -1
  282. package/universal/types.d.ts +0 -199
  283. package/universal/types.d.ts.map +0 -1
  284. package/web-components/core/attribute-parser.d.ts +0 -82
  285. package/web-components/core/attribute-parser.d.ts.map +0 -1
  286. package/web-components/core/base-element.d.ts +0 -197
  287. package/web-components/core/base-element.d.ts.map +0 -1
  288. package/web-components/core/index.d.ts +0 -9
  289. package/web-components/core/index.d.ts.map +0 -1
  290. package/web-components/elements/fmcp-alert.d.ts +0 -46
  291. package/web-components/elements/fmcp-alert.d.ts.map +0 -1
  292. package/web-components/elements/fmcp-badge.d.ts +0 -47
  293. package/web-components/elements/fmcp-badge.d.ts.map +0 -1
  294. package/web-components/elements/fmcp-button.d.ts +0 -117
  295. package/web-components/elements/fmcp-button.d.ts.map +0 -1
  296. package/web-components/elements/fmcp-card.d.ts +0 -53
  297. package/web-components/elements/fmcp-card.d.ts.map +0 -1
  298. package/web-components/elements/fmcp-input.d.ts +0 -96
  299. package/web-components/elements/fmcp-input.d.ts.map +0 -1
  300. package/web-components/elements/fmcp-select.d.ts +0 -100
  301. package/web-components/elements/fmcp-select.d.ts.map +0 -1
  302. package/web-components/elements/index.d.ts +0 -13
  303. package/web-components/elements/index.d.ts.map +0 -1
  304. package/web-components/index.d.ts +0 -49
  305. package/web-components/index.d.ts.map +0 -1
  306. package/web-components/index.js +0 -2058
  307. package/web-components/register.d.ts +0 -57
  308. package/web-components/register.d.ts.map +0 -1
  309. package/web-components/types.d.ts +0 -122
  310. package/web-components/types.d.ts.map +0 -1
@@ -1,82 +0,0 @@
1
- /**
2
- * @file attribute-parser.ts
3
- * @description Attribute parsing utilities for FrontMCP Web Components.
4
- *
5
- * Converts HTML attributes to typed options for component rendering.
6
- * Handles boolean attributes and kebab-to-camel case conversion.
7
- *
8
- * @example Attribute parsing
9
- * ```typescript
10
- * // variant="primary" -> { variant: 'primary' }
11
- * // disabled -> { disabled: true }
12
- * // disabled="false" -> { disabled: false }
13
- * ```
14
- *
15
- * @module @frontmcp/ui/web-components/core/attribute-parser
16
- */
17
- import type { ZodSchema } from 'zod';
18
- /**
19
- * Result of parsing an attribute value
20
- */
21
- export interface ParsedAttribute {
22
- /** The option key (camelCase) */
23
- key: string | null;
24
- /** The parsed value */
25
- value: unknown;
26
- /** Whether this is a data attribute */
27
- isData?: boolean;
28
- }
29
- /**
30
- * Parse an HTML attribute into a typed option value.
31
- *
32
- * Attribute naming conventions:
33
- * - Simple: `variant="primary"` -> `{ variant: 'primary' }`
34
- * - Boolean: `disabled` -> `{ disabled: true }`
35
- * - Boolean false: `disabled="false"` -> `{ disabled: false }`
36
- * - Data: `data-foo="bar"` -> `{ data: { foo: 'bar' } }`
37
- *
38
- * @param attrName - The attribute name (kebab-case)
39
- * @param value - The attribute value (null for boolean attributes)
40
- * @returns Parsed attribute with key and typed value
41
- */
42
- export declare function parseAttributeValue(attrName: string, value: string | null): ParsedAttribute;
43
- /**
44
- * Convert kebab-case to camelCase.
45
- *
46
- * @param str - Kebab-case string
47
- * @returns camelCase string
48
- *
49
- * @example
50
- * kebabToCamel('full-width') // 'fullWidth'
51
- * kebabToCamel('icon-before') // 'iconBefore'
52
- */
53
- export declare function kebabToCamel(str: string): string;
54
- /**
55
- * Convert camelCase to kebab-case.
56
- *
57
- * @param str - camelCase string
58
- * @returns kebab-case string
59
- *
60
- * @example
61
- * camelToKebab('fullWidth') // 'full-width'
62
- * camelToKebab('iconBefore') // 'icon-before'
63
- */
64
- export declare function camelToKebab(str: string): string;
65
- /**
66
- * Extract observable attribute names from a Zod schema.
67
- *
68
- * @param schema - Zod schema to extract keys from
69
- * @returns Array of kebab-case attribute names
70
- */
71
- export declare function getObservedAttributesFromSchema<T>(schema: ZodSchema<T>): string[];
72
- /**
73
- * Merge a parsed attribute into an options object.
74
- *
75
- * Handles nested objects for data attributes.
76
- *
77
- * @param options - Current options object
78
- * @param parsed - Parsed attribute result
79
- * @returns Updated options object
80
- */
81
- export declare function mergeAttributeIntoOptions<T>(options: Partial<T>, parsed: ParsedAttribute): Partial<T>;
82
- //# sourceMappingURL=attribute-parser.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"attribute-parser.d.ts","sourceRoot":"","sources":["../../../src/web-components/core/attribute-parser.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;GAeG;AAEH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,KAAK,CAAC;AAErC;;GAEG;AACH,MAAM,WAAW,eAAe;IAC9B,iCAAiC;IACjC,GAAG,EAAE,MAAM,GAAG,IAAI,CAAC;IACnB,uBAAuB;IACvB,KAAK,EAAE,OAAO,CAAC;IACf,uCAAuC;IACvC,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB;AAED;;;;;;;;;;;;GAYG;AACH,wBAAgB,mBAAmB,CAAC,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI,GAAG,eAAe,CAiD3F;AAED;;;;;;;;;GASG;AACH,wBAAgB,YAAY,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAEhD;AAED;;;;;;;;;GASG;AACH,wBAAgB,YAAY,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAEhD;AAED;;;;;GAKG;AACH,wBAAgB,+BAA+B,CAAC,CAAC,EAAE,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC,GAAG,MAAM,EAAE,CAkBjF;AAED;;;;;;;;GAQG;AACH,wBAAgB,yBAAyB,CAAC,CAAC,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,eAAe,GAAG,OAAO,CAAC,CAAC,CAAC,CAkBrG"}
@@ -1,197 +0,0 @@
1
- /**
2
- * @file base-element.ts
3
- * @description Base class for all FrontMCP Web Components.
4
- *
5
- * Provides a foundation for creating Custom Elements with:
6
- * - Zod schema validation
7
- * - Attribute-to-option mapping
8
- * - Property setters for React/Vue compatibility
9
- * - Batched rendering via queueMicrotask
10
- * - Light DOM (no Shadow DOM) for Tailwind compatibility
11
- *
12
- * @example Creating a custom element
13
- * ```typescript
14
- * import { FmcpElement } from '@frontmcp/ui/web-components';
15
- * import { ButtonOptionsSchema, type ButtonOptions } from '@frontmcp/ui/components';
16
- * import { button } from '@frontmcp/ui/components';
17
- *
18
- * class FmcpButton extends FmcpElement<ButtonOptions> {
19
- * protected readonly config = {
20
- * name: 'button',
21
- * schema: ButtonOptionsSchema,
22
- * defaults: { variant: 'primary', size: 'md' },
23
- * };
24
- *
25
- * static get observedAttributes() {
26
- * return getObservedAttributesFromSchema(ButtonOptionsSchema);
27
- * }
28
- *
29
- * protected renderHtml(options: ButtonOptions, content: string): string {
30
- * return button(content, options);
31
- * }
32
- * }
33
- *
34
- * customElements.define('fmcp-button', FmcpButton);
35
- * ```
36
- *
37
- * @module @frontmcp/ui/web-components/core/base-element
38
- */
39
- import type { ZodSchema } from 'zod';
40
- declare const HTMLElementBase: {
41
- new (): HTMLElement;
42
- prototype: HTMLElement;
43
- };
44
- /**
45
- * Configuration for FmcpElement subclasses
46
- */
47
- export interface FmcpElementConfig<TOptions> {
48
- /** Component name (used in error messages) */
49
- name: string;
50
- /** Zod schema for validation */
51
- schema: ZodSchema<TOptions>;
52
- /** Default option values */
53
- defaults?: Partial<TOptions>;
54
- }
55
- /**
56
- * Custom event detail for fmcp:render event
57
- */
58
- export interface FmcpRenderEventDetail<TOptions = unknown> {
59
- options: TOptions;
60
- }
61
- /**
62
- * Base class for all FrontMCP Web Components.
63
- *
64
- * Key features:
65
- * - **Light DOM**: Renders directly to innerHTML (no Shadow DOM)
66
- * - **Attribute Parsing**: Converts HTML attributes to typed options
67
- * - **Property Setters**: React/Vue can set properties directly
68
- * - **Zod Validation**: Invalid options render error box
69
- * - **Batched Rendering**: Multiple changes batch via queueMicrotask
70
- *
71
- * @typeParam TOptions - The component's options type (from Zod schema)
72
- *
73
- * @example Usage in HTML
74
- * ```html
75
- * <fmcp-button variant="primary" disabled>
76
- * Click Me
77
- * </fmcp-button>
78
- * ```
79
- *
80
- * @example Usage in React
81
- * ```tsx
82
- * <fmcp-button
83
- * variant="primary"
84
- * onClick={handleClick}
85
- * >
86
- * Click Me
87
- * </fmcp-button>
88
- * ```
89
- */
90
- export declare abstract class FmcpElement<TOptions> extends HTMLElementBase {
91
- /**
92
- * Configuration provided by subclass.
93
- * Must include component name, Zod schema, and optional defaults.
94
- */
95
- protected abstract readonly config: FmcpElementConfig<TOptions>;
96
- /** Internal options state */
97
- protected _options: Partial<TOptions>;
98
- /** Content passed as children (captured on connect) */
99
- protected _content: string;
100
- /** Whether component has been connected to DOM */
101
- private _connected;
102
- /** Whether a render is pending (for batching) */
103
- private _pendingRender;
104
- /** Whether initial render has completed */
105
- private _initialRenderComplete;
106
- /**
107
- * Called when element is added to DOM.
108
- * Captures content, parses attributes, and renders.
109
- *
110
- * Supports SSR hydration via `data-ssr` attribute:
111
- * - If `data-ssr` is present, content was pre-rendered by server
112
- * - Web component adopts existing content without re-rendering
113
- * - This enables progressive enhancement for LLM platforms
114
- */
115
- connectedCallback(): void;
116
- /**
117
- * Called when element is removed from DOM.
118
- */
119
- disconnectedCallback(): void;
120
- /**
121
- * Called when an observed attribute changes.
122
- * Updates options and schedules re-render.
123
- */
124
- attributeChangedCallback(name: string, oldValue: string | null, newValue: string | null): void;
125
- /**
126
- * Set all options at once (React pattern).
127
- *
128
- * @example
129
- * ```typescript
130
- * const el = document.querySelector('fmcp-button');
131
- * el.options = { variant: 'danger', size: 'lg' };
132
- * ```
133
- */
134
- set options(value: Partial<TOptions>);
135
- /**
136
- * Get current options.
137
- */
138
- get options(): Partial<TOptions>;
139
- /**
140
- * Parse all current attributes into options.
141
- */
142
- private _parseAttributes;
143
- /**
144
- * Update a single option from an attribute change.
145
- */
146
- private _updateOptionFromAttribute;
147
- /**
148
- * Schedule a render on next microtask.
149
- * Batches multiple attribute/property changes.
150
- */
151
- protected _scheduleRender(): void;
152
- /**
153
- * Perform the actual render.
154
- * Validates options and updates innerHTML.
155
- */
156
- private _render;
157
- /**
158
- * Generate HTML for the component.
159
- * Subclasses must implement this to render their specific HTML.
160
- *
161
- * @param options - Validated options
162
- * @param content - Original innerHTML content
163
- * @returns HTML string to render
164
- */
165
- protected abstract renderHtml(options: TOptions, content: string): string;
166
- /**
167
- * Force an immediate re-render.
168
- *
169
- * @example
170
- * ```typescript
171
- * el.options = { loading: true };
172
- * el.refresh(); // Force immediate render
173
- * ```
174
- */
175
- refresh(): void;
176
- /**
177
- * Get the first child element (the actual rendered component).
178
- *
179
- * @typeParam T - Expected element type
180
- * @returns The first child element or null
181
- *
182
- * @example
183
- * ```typescript
184
- * const button = el.getInnerElement<HTMLButtonElement>();
185
- * button?.focus();
186
- * ```
187
- */
188
- getInnerElement<T extends Element = Element>(): T | null;
189
- /**
190
- * Update content and re-render.
191
- *
192
- * @param content - New content string
193
- */
194
- setContent(content: string): void;
195
- }
196
- export {};
197
- //# sourceMappingURL=base-element.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"base-element.d.ts","sourceRoot":"","sources":["../../../src/web-components/core/base-element.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqCG;AAEH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,KAAK,CAAC;AAOrC,QAAA,MAAM,eAAe;;;CAWoB,CAAC;AAE1C;;GAEG;AACH,MAAM,WAAW,iBAAiB,CAAC,QAAQ;IACzC,8CAA8C;IAC9C,IAAI,EAAE,MAAM,CAAC;IACb,gCAAgC;IAChC,MAAM,EAAE,SAAS,CAAC,QAAQ,CAAC,CAAC;IAC5B,4BAA4B;IAC5B,QAAQ,CAAC,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAC;CAC9B;AAED;;GAEG;AACH,MAAM,WAAW,qBAAqB,CAAC,QAAQ,GAAG,OAAO;IACvD,OAAO,EAAE,QAAQ,CAAC;CACnB;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4BG;AACH,8BAAsB,WAAW,CAAC,QAAQ,CAAE,SAAQ,eAAe;IACjE;;;OAGG;IACH,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,EAAE,iBAAiB,CAAC,QAAQ,CAAC,CAAC;IAEhE,6BAA6B;IAC7B,SAAS,CAAC,QAAQ,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAM;IAE3C,uDAAuD;IACvD,SAAS,CAAC,QAAQ,SAAM;IAExB,kDAAkD;IAClD,OAAO,CAAC,UAAU,CAAS;IAE3B,iDAAiD;IACjD,OAAO,CAAC,cAAc,CAAS;IAE/B,2CAA2C;IAC3C,OAAO,CAAC,sBAAsB,CAAS;IAMvC;;;;;;;;OAQG;IACH,iBAAiB,IAAI,IAAI;IA8BzB;;OAEG;IACH,oBAAoB,IAAI,IAAI;IAI5B;;;OAGG;IACH,wBAAwB,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,IAAI,EAAE,QAAQ,EAAE,MAAM,GAAG,IAAI,GAAG,IAAI;IAe9F;;;;;;;;OAQG;IACH,IAAI,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,QAAQ,CAAC,EAGnC;IAED;;OAEG;IACH,IAAI,OAAO,IAAI,OAAO,CAAC,QAAQ,CAAC,CAE/B;IAMD;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAMxB;;OAEG;IACH,OAAO,CAAC,0BAA0B;IASlC;;;OAGG;IACH,SAAS,CAAC,eAAe,IAAI,IAAI;IAYjC;;;OAGG;IACH,OAAO,CAAC,OAAO;IAyCf;;;;;;;OAOG;IACH,SAAS,CAAC,QAAQ,CAAC,UAAU,CAAC,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,GAAG,MAAM;IAMzE;;;;;;;;OAQG;IACI,OAAO,IAAI,IAAI;IAMtB;;;;;;;;;;;OAWG;IACI,eAAe,CAAC,CAAC,SAAS,OAAO,GAAG,OAAO,KAAK,CAAC,GAAG,IAAI;IAI/D;;;;OAIG;IACI,UAAU,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;CAIzC"}
@@ -1,9 +0,0 @@
1
- /**
2
- * @file core/index.ts
3
- * @description Core utilities for FrontMCP Web Components.
4
- *
5
- * @module @frontmcp/ui/web-components/core
6
- */
7
- export { FmcpElement, type FmcpElementConfig, type FmcpRenderEventDetail } from './base-element';
8
- export { parseAttributeValue, kebabToCamel, camelToKebab, getObservedAttributesFromSchema, mergeAttributeIntoOptions, type ParsedAttribute, } from './attribute-parser';
9
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/web-components/core/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,WAAW,EAAE,KAAK,iBAAiB,EAAE,KAAK,qBAAqB,EAAE,MAAM,gBAAgB,CAAC;AAEjG,OAAO,EACL,mBAAmB,EACnB,YAAY,EACZ,YAAY,EACZ,+BAA+B,EAC/B,yBAAyB,EACzB,KAAK,eAAe,GACrB,MAAM,oBAAoB,CAAC"}
@@ -1,46 +0,0 @@
1
- /**
2
- * @file fmcp-alert.ts
3
- * @description FrontMCP Alert Web Component.
4
- *
5
- * A custom element wrapper around the alert() HTML function.
6
- *
7
- * @example Basic usage
8
- * ```html
9
- * <fmcp-alert variant="success">Operation completed!</fmcp-alert>
10
- * <fmcp-alert variant="danger" title="Error">Something went wrong</fmcp-alert>
11
- * ```
12
- *
13
- * @example Dismissible alert
14
- * ```html
15
- * <fmcp-alert variant="info" dismissible>
16
- * Click X to dismiss
17
- * </fmcp-alert>
18
- * ```
19
- *
20
- * @module @frontmcp/ui/web-components/elements/fmcp-alert
21
- */
22
- import { FmcpElement, type FmcpElementConfig } from '../core';
23
- import { type AlertOptions } from '../../components/alert';
24
- /**
25
- * FmcpAlert Web Component
26
- */
27
- export declare class FmcpAlert extends FmcpElement<AlertOptions> {
28
- protected readonly config: FmcpElementConfig<AlertOptions>;
29
- static get observedAttributes(): string[];
30
- protected renderHtml(options: AlertOptions, content: string): string;
31
- set variant(value: AlertOptions['variant']);
32
- get variant(): AlertOptions['variant'];
33
- set alertTitle(value: string | undefined);
34
- get alertTitle(): string | undefined;
35
- set showIcon(value: boolean);
36
- get showIcon(): boolean;
37
- set dismissible(value: boolean);
38
- get dismissible(): boolean;
39
- set actions(value: string | undefined);
40
- get actions(): string | undefined;
41
- }
42
- /**
43
- * Register the fmcp-alert custom element.
44
- */
45
- export declare function registerFmcpAlert(): void;
46
- //# sourceMappingURL=fmcp-alert.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"fmcp-alert.d.ts","sourceRoot":"","sources":["../../../src/web-components/elements/fmcp-alert.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;GAoBG;AAEH,OAAO,EAAE,WAAW,EAAE,KAAK,iBAAiB,EAAmC,MAAM,SAAS,CAAC;AAC/F,OAAO,EAAS,KAAK,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAGlE;;GAEG;AACH,qBAAa,SAAU,SAAQ,WAAW,CAAC,YAAY,CAAC;IACtD,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAE,iBAAiB,CAAC,YAAY,CAAC,CAOxD;IAEF,MAAM,KAAK,kBAAkB,IAAI,MAAM,EAAE,CAExC;IAED,SAAS,CAAC,UAAU,CAAC,OAAO,EAAE,YAAY,EAAE,OAAO,EAAE,MAAM,GAAG,MAAM;IAKpE,IAAI,OAAO,CAAC,KAAK,EAAE,YAAY,CAAC,SAAS,CAAC,EAGzC;IACD,IAAI,OAAO,IAAI,YAAY,CAAC,SAAS,CAAC,CAErC;IAED,IAAI,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,EAGvC;IACD,IAAI,UAAU,IAAI,MAAM,GAAG,SAAS,CAEnC;IAED,IAAI,QAAQ,CAAC,KAAK,EAAE,OAAO,EAG1B;IACD,IAAI,QAAQ,IAAI,OAAO,CAEtB;IAED,IAAI,WAAW,CAAC,KAAK,EAAE,OAAO,EAG7B;IACD,IAAI,WAAW,IAAI,OAAO,CAEzB;IAED,IAAI,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,EAGpC;IACD,IAAI,OAAO,IAAI,MAAM,GAAG,SAAS,CAEhC;CACF;AAED;;GAEG;AACH,wBAAgB,iBAAiB,IAAI,IAAI,CAIxC"}
@@ -1,47 +0,0 @@
1
- /**
2
- * @file fmcp-badge.ts
3
- * @description FrontMCP Badge Web Component.
4
- *
5
- * A custom element wrapper around the badge() HTML function.
6
- *
7
- * @example Basic usage
8
- * ```html
9
- * <fmcp-badge>Default</fmcp-badge>
10
- * <fmcp-badge variant="success">Active</fmcp-badge>
11
- * <fmcp-badge variant="danger" pill>Error</fmcp-badge>
12
- * ```
13
- *
14
- * @example Removable badge
15
- * ```html
16
- * <fmcp-badge removable>Tag</fmcp-badge>
17
- * ```
18
- *
19
- * @module @frontmcp/ui/web-components/elements/fmcp-badge
20
- */
21
- import { FmcpElement, type FmcpElementConfig } from '../core';
22
- import { type BadgeOptions } from '../../components/badge';
23
- /**
24
- * FmcpBadge Web Component
25
- */
26
- export declare class FmcpBadge extends FmcpElement<BadgeOptions> {
27
- protected readonly config: FmcpElementConfig<BadgeOptions>;
28
- static get observedAttributes(): string[];
29
- protected renderHtml(options: BadgeOptions, content: string): string;
30
- set variant(value: BadgeOptions['variant']);
31
- get variant(): BadgeOptions['variant'];
32
- set size(value: BadgeOptions['size']);
33
- get size(): BadgeOptions['size'];
34
- set pill(value: boolean);
35
- get pill(): boolean;
36
- set dot(value: boolean);
37
- get dot(): boolean;
38
- set removable(value: boolean);
39
- get removable(): boolean;
40
- set icon(value: string | undefined);
41
- get icon(): string | undefined;
42
- }
43
- /**
44
- * Register the fmcp-badge custom element.
45
- */
46
- export declare function registerFmcpBadge(): void;
47
- //# sourceMappingURL=fmcp-badge.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"fmcp-badge.d.ts","sourceRoot":"","sources":["../../../src/web-components/elements/fmcp-badge.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;GAmBG;AAEH,OAAO,EAAE,WAAW,EAAE,KAAK,iBAAiB,EAAmC,MAAM,SAAS,CAAC;AAC/F,OAAO,EAAS,KAAK,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAGlE;;GAEG;AACH,qBAAa,SAAU,SAAQ,WAAW,CAAC,YAAY,CAAC;IACtD,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAE,iBAAiB,CAAC,YAAY,CAAC,CAOxD;IAEF,MAAM,KAAK,kBAAkB,IAAI,MAAM,EAAE,CAExC;IAED,SAAS,CAAC,UAAU,CAAC,OAAO,EAAE,YAAY,EAAE,OAAO,EAAE,MAAM,GAAG,MAAM;IAKpE,IAAI,OAAO,CAAC,KAAK,EAAE,YAAY,CAAC,SAAS,CAAC,EAGzC;IACD,IAAI,OAAO,IAAI,YAAY,CAAC,SAAS,CAAC,CAErC;IAED,IAAI,IAAI,CAAC,KAAK,EAAE,YAAY,CAAC,MAAM,CAAC,EAGnC;IACD,IAAI,IAAI,IAAI,YAAY,CAAC,MAAM,CAAC,CAE/B;IAED,IAAI,IAAI,CAAC,KAAK,EAAE,OAAO,EAGtB;IACD,IAAI,IAAI,IAAI,OAAO,CAElB;IAED,IAAI,GAAG,CAAC,KAAK,EAAE,OAAO,EAGrB;IACD,IAAI,GAAG,IAAI,OAAO,CAEjB;IAED,IAAI,SAAS,CAAC,KAAK,EAAE,OAAO,EAG3B;IACD,IAAI,SAAS,IAAI,OAAO,CAEvB;IAED,IAAI,IAAI,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,EAGjC;IACD,IAAI,IAAI,IAAI,MAAM,GAAG,SAAS,CAE7B;CACF;AAED;;GAEG;AACH,wBAAgB,iBAAiB,IAAI,IAAI,CAIxC"}
@@ -1,117 +0,0 @@
1
- /**
2
- * @file fmcp-button.ts
3
- * @description FrontMCP Button Web Component.
4
- *
5
- * A custom element wrapper around the button() HTML function.
6
- * Works natively in React, Vue, Angular, and plain HTML.
7
- *
8
- * @example Basic usage
9
- * ```html
10
- * <fmcp-button>Click Me</fmcp-button>
11
- * <fmcp-button variant="danger">Delete</fmcp-button>
12
- * <fmcp-button disabled>Disabled</fmcp-button>
13
- * ```
14
- *
15
- * @example In React
16
- * ```tsx
17
- * import { registerFmcpButton } from '@frontmcp/ui/web-components';
18
- * registerFmcpButton();
19
- *
20
- * function App() {
21
- * return (
22
- * <fmcp-button variant="primary" onClick={handleClick}>
23
- * Click Me
24
- * </fmcp-button>
25
- * );
26
- * }
27
- * ```
28
- *
29
- * @module @frontmcp/ui/web-components/elements/fmcp-button
30
- */
31
- import { FmcpElement, type FmcpElementConfig } from '../core';
32
- import { type ButtonOptions } from '../../components/button';
33
- /**
34
- * FmcpButton Web Component
35
- *
36
- * Attributes:
37
- * - `variant` - 'primary' | 'secondary' | 'outline' | 'ghost' | 'danger' | 'success' | 'link'
38
- * - `size` - 'xs' | 'sm' | 'md' | 'lg' | 'xl'
39
- * - `type` - 'button' | 'submit' | 'reset'
40
- * - `disabled` - boolean (presence = true)
41
- * - `loading` - boolean
42
- * - `full-width` - boolean
43
- * - `icon-only` - boolean
44
- * - `href` - URL for link-style buttons
45
- * - `target` - '_blank' | '_self'
46
- *
47
- * Properties (for React/Vue):
48
- * - All attributes can be set as properties
49
- * - `options` - Set all options at once
50
- *
51
- * Events:
52
- * - `fmcp:render` - Fired after render with { options } detail
53
- * - `fmcp:click` - Fired on button click with { options } detail
54
- */
55
- export declare class FmcpButton extends FmcpElement<ButtonOptions> {
56
- protected readonly config: FmcpElementConfig<ButtonOptions>;
57
- /**
58
- * Attributes to observe for changes.
59
- */
60
- static get observedAttributes(): string[];
61
- /**
62
- * Render the button HTML using the button() function.
63
- */
64
- protected renderHtml(options: ButtonOptions, content: string): string;
65
- set variant(value: ButtonOptions['variant']);
66
- get variant(): ButtonOptions['variant'];
67
- set size(value: ButtonOptions['size']);
68
- get size(): ButtonOptions['size'];
69
- set type(value: ButtonOptions['type']);
70
- get type(): ButtonOptions['type'];
71
- set disabled(value: boolean);
72
- get disabled(): boolean;
73
- set loading(value: boolean);
74
- get loading(): boolean;
75
- set fullWidth(value: boolean);
76
- get fullWidth(): boolean;
77
- set iconOnly(value: boolean);
78
- get iconOnly(): boolean;
79
- set iconBefore(value: string | undefined);
80
- get iconBefore(): string | undefined;
81
- set iconAfter(value: string | undefined);
82
- get iconAfter(): string | undefined;
83
- set href(value: string | undefined);
84
- get href(): string | undefined;
85
- set buttonAriaLabel(value: string | undefined);
86
- get buttonAriaLabel(): string | undefined;
87
- connectedCallback(): void;
88
- private _handleClick;
89
- /**
90
- * Focus the inner button element.
91
- */
92
- focus(): void;
93
- /**
94
- * Blur the inner button element.
95
- */
96
- blur(): void;
97
- /**
98
- * Click the inner button programmatically.
99
- */
100
- click(): void;
101
- }
102
- /**
103
- * Register the fmcp-button custom element.
104
- *
105
- * @example
106
- * ```typescript
107
- * import { registerFmcpButton } from '@frontmcp/ui/web-components';
108
- *
109
- * // Register once on app startup
110
- * registerFmcpButton();
111
- *
112
- * // Then use in HTML
113
- * // <fmcp-button variant="primary">Click</fmcp-button>
114
- * ```
115
- */
116
- export declare function registerFmcpButton(): void;
117
- //# sourceMappingURL=fmcp-button.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"fmcp-button.d.ts","sourceRoot":"","sources":["../../../src/web-components/elements/fmcp-button.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;AAEH,OAAO,EAAE,WAAW,EAAE,KAAK,iBAAiB,EAAmC,MAAM,SAAS,CAAC;AAC/F,OAAO,EAAU,KAAK,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAGrE;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,qBAAa,UAAW,SAAQ,WAAW,CAAC,aAAa,CAAC;IACxD,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAE,iBAAiB,CAAC,aAAa,CAAC,CAQzD;IAEF;;OAEG;IACH,MAAM,KAAK,kBAAkB,IAAI,MAAM,EAAE,CAExC;IAED;;OAEG;IACH,SAAS,CAAC,UAAU,CAAC,OAAO,EAAE,aAAa,EAAE,OAAO,EAAE,MAAM,GAAG,MAAM;IAQrE,IAAI,OAAO,CAAC,KAAK,EAAE,aAAa,CAAC,SAAS,CAAC,EAG1C;IACD,IAAI,OAAO,IAAI,aAAa,CAAC,SAAS,CAAC,CAEtC;IAED,IAAI,IAAI,CAAC,KAAK,EAAE,aAAa,CAAC,MAAM,CAAC,EAGpC;IACD,IAAI,IAAI,IAAI,aAAa,CAAC,MAAM,CAAC,CAEhC;IAED,IAAI,IAAI,CAAC,KAAK,EAAE,aAAa,CAAC,MAAM,CAAC,EAGpC;IACD,IAAI,IAAI,IAAI,aAAa,CAAC,MAAM,CAAC,CAEhC;IAED,IAAI,QAAQ,CAAC,KAAK,EAAE,OAAO,EAG1B;IACD,IAAI,QAAQ,IAAI,OAAO,CAEtB;IAED,IAAI,OAAO,CAAC,KAAK,EAAE,OAAO,EAGzB;IACD,IAAI,OAAO,IAAI,OAAO,CAErB;IAED,IAAI,SAAS,CAAC,KAAK,EAAE,OAAO,EAG3B;IACD,IAAI,SAAS,IAAI,OAAO,CAEvB;IAED,IAAI,QAAQ,CAAC,KAAK,EAAE,OAAO,EAG1B;IACD,IAAI,QAAQ,IAAI,OAAO,CAEtB;IAED,IAAI,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,EAGvC;IACD,IAAI,UAAU,IAAI,MAAM,GAAG,SAAS,CAEnC;IAED,IAAI,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,EAGtC;IACD,IAAI,SAAS,IAAI,MAAM,GAAG,SAAS,CAElC;IAED,IAAI,IAAI,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,EAGjC;IACD,IAAI,IAAI,IAAI,MAAM,GAAG,SAAS,CAE7B;IAED,IAAI,eAAe,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,EAG5C;IACD,IAAI,eAAe,IAAI,MAAM,GAAG,SAAS,CAExC;IAMQ,iBAAiB,IAAI,IAAI;IAOlC,OAAO,CAAC,YAAY;IAiBpB;;OAEG;IACa,KAAK,IAAI,IAAI;IAK7B;;OAEG;IACa,IAAI,IAAI,IAAI;IAK5B;;OAEG;IACa,KAAK,IAAI,IAAI;CAI9B;AAED;;;;;;;;;;;;;GAaG;AACH,wBAAgB,kBAAkB,IAAI,IAAI,CAIzC"}
@@ -1,53 +0,0 @@
1
- /**
2
- * @file fmcp-card.ts
3
- * @description FrontMCP Card Web Component.
4
- *
5
- * A custom element wrapper around the card() HTML function.
6
- *
7
- * @example Basic usage
8
- * ```html
9
- * <fmcp-card title="Welcome" subtitle="Description">
10
- * <p>Card content goes here</p>
11
- * </fmcp-card>
12
- * ```
13
- *
14
- * @example Clickable card
15
- * ```html
16
- * <fmcp-card clickable href="/details" title="Item">
17
- * <p>Click to view details</p>
18
- * </fmcp-card>
19
- * ```
20
- *
21
- * @module @frontmcp/ui/web-components/elements/fmcp-card
22
- */
23
- import { FmcpElement, type FmcpElementConfig } from '../core';
24
- import { type CardOptions } from '../../components/card';
25
- /**
26
- * FmcpCard Web Component
27
- */
28
- export declare class FmcpCard extends FmcpElement<CardOptions> {
29
- protected readonly config: FmcpElementConfig<CardOptions>;
30
- static get observedAttributes(): string[];
31
- protected renderHtml(options: CardOptions, content: string): string;
32
- set variant(value: CardOptions['variant']);
33
- get variant(): CardOptions['variant'];
34
- set size(value: CardOptions['size']);
35
- get size(): CardOptions['size'];
36
- set cardTitle(value: string | undefined);
37
- get cardTitle(): string | undefined;
38
- set subtitle(value: string | undefined);
39
- get subtitle(): string | undefined;
40
- set clickable(value: boolean);
41
- get clickable(): boolean;
42
- set href(value: string | undefined);
43
- get href(): string | undefined;
44
- set footer(value: string | undefined);
45
- get footer(): string | undefined;
46
- set headerActions(value: string | undefined);
47
- get headerActions(): string | undefined;
48
- }
49
- /**
50
- * Register the fmcp-card custom element.
51
- */
52
- export declare function registerFmcpCard(): void;
53
- //# sourceMappingURL=fmcp-card.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"fmcp-card.d.ts","sourceRoot":"","sources":["../../../src/web-components/elements/fmcp-card.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;GAqBG;AAEH,OAAO,EAAE,WAAW,EAAE,KAAK,iBAAiB,EAAmC,MAAM,SAAS,CAAC;AAC/F,OAAO,EAAQ,KAAK,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAG/D;;GAEG;AACH,qBAAa,QAAS,SAAQ,WAAW,CAAC,WAAW,CAAC;IACpD,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAE,iBAAiB,CAAC,WAAW,CAAC,CAOvD;IAEF,MAAM,KAAK,kBAAkB,IAAI,MAAM,EAAE,CAExC;IAED,SAAS,CAAC,UAAU,CAAC,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,GAAG,MAAM;IAKnE,IAAI,OAAO,CAAC,KAAK,EAAE,WAAW,CAAC,SAAS,CAAC,EAGxC;IACD,IAAI,OAAO,IAAI,WAAW,CAAC,SAAS,CAAC,CAEpC;IAED,IAAI,IAAI,CAAC,KAAK,EAAE,WAAW,CAAC,MAAM,CAAC,EAGlC;IACD,IAAI,IAAI,IAAI,WAAW,CAAC,MAAM,CAAC,CAE9B;IAED,IAAI,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,EAGtC;IACD,IAAI,SAAS,IAAI,MAAM,GAAG,SAAS,CAElC;IAED,IAAI,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,EAGrC;IACD,IAAI,QAAQ,IAAI,MAAM,GAAG,SAAS,CAEjC;IAED,IAAI,SAAS,CAAC,KAAK,EAAE,OAAO,EAG3B;IACD,IAAI,SAAS,IAAI,OAAO,CAEvB;IAED,IAAI,IAAI,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,EAGjC;IACD,IAAI,IAAI,IAAI,MAAM,GAAG,SAAS,CAE7B;IAED,IAAI,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,EAGnC;IACD,IAAI,MAAM,IAAI,MAAM,GAAG,SAAS,CAE/B;IAED,IAAI,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,EAG1C;IACD,IAAI,aAAa,IAAI,MAAM,GAAG,SAAS,CAEtC;CACF;AAED;;GAEG;AACH,wBAAgB,gBAAgB,IAAI,IAAI,CAIvC"}