@frontmcp/ui 0.5.1 → 0.6.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 (805) hide show
  1. package/README.md +140 -362
  2. package/bridge/adapters/base-adapter.d.ts +104 -0
  3. package/bridge/adapters/base-adapter.d.ts.map +1 -0
  4. package/bridge/adapters/claude.adapter.d.ts +67 -0
  5. package/bridge/adapters/claude.adapter.d.ts.map +1 -0
  6. package/bridge/adapters/ext-apps.adapter.d.ts +143 -0
  7. package/bridge/adapters/ext-apps.adapter.d.ts.map +1 -0
  8. package/bridge/adapters/gemini.adapter.d.ts +64 -0
  9. package/bridge/adapters/gemini.adapter.d.ts.map +1 -0
  10. package/bridge/adapters/generic.adapter.d.ts +56 -0
  11. package/bridge/adapters/generic.adapter.d.ts.map +1 -0
  12. package/bridge/adapters/index.d.ts +26 -0
  13. package/bridge/adapters/index.d.ts.map +1 -0
  14. package/bridge/adapters/openai.adapter.d.ts +65 -0
  15. package/bridge/adapters/openai.adapter.d.ts.map +1 -0
  16. package/bridge/core/adapter-registry.d.ts +122 -0
  17. package/bridge/core/adapter-registry.d.ts.map +1 -0
  18. package/bridge/core/bridge-factory.d.ts +199 -0
  19. package/bridge/core/bridge-factory.d.ts.map +1 -0
  20. package/bridge/core/index.d.ts +10 -0
  21. package/bridge/core/index.d.ts.map +1 -0
  22. package/bridge/index.d.ts +62 -0
  23. package/bridge/index.d.ts.map +1 -0
  24. package/bridge/index.js +2540 -0
  25. package/bridge/runtime/iife-generator.d.ts +62 -0
  26. package/bridge/runtime/iife-generator.d.ts.map +1 -0
  27. package/bridge/runtime/index.d.ts +10 -0
  28. package/bridge/runtime/index.d.ts.map +1 -0
  29. package/bridge/types.d.ts +386 -0
  30. package/bridge/types.d.ts.map +1 -0
  31. package/bundler/bundler.d.ts +208 -0
  32. package/bundler/bundler.d.ts.map +1 -0
  33. package/bundler/cache.d.ts +173 -0
  34. package/bundler/cache.d.ts.map +1 -0
  35. package/bundler/file-cache/component-builder.d.ts +167 -0
  36. package/bundler/file-cache/component-builder.d.ts.map +1 -0
  37. package/bundler/file-cache/hash-calculator.d.ts +155 -0
  38. package/bundler/file-cache/hash-calculator.d.ts.map +1 -0
  39. package/bundler/file-cache/index.d.ts +12 -0
  40. package/bundler/file-cache/index.d.ts.map +1 -0
  41. package/bundler/file-cache/storage/filesystem.d.ts +149 -0
  42. package/bundler/file-cache/storage/filesystem.d.ts.map +1 -0
  43. package/bundler/file-cache/storage/index.d.ts +11 -0
  44. package/bundler/file-cache/storage/index.d.ts.map +1 -0
  45. package/bundler/file-cache/storage/interface.d.ts +152 -0
  46. package/bundler/file-cache/storage/interface.d.ts.map +1 -0
  47. package/bundler/file-cache/storage/redis.d.ts +139 -0
  48. package/bundler/file-cache/storage/redis.d.ts.map +1 -0
  49. package/bundler/index.d.ts +43 -0
  50. package/bundler/index.d.ts.map +1 -0
  51. package/bundler/index.js +3707 -0
  52. package/bundler/sandbox/enclave-adapter.d.ts +121 -0
  53. package/bundler/sandbox/enclave-adapter.d.ts.map +1 -0
  54. package/bundler/sandbox/executor.d.ts +14 -0
  55. package/bundler/sandbox/executor.d.ts.map +1 -0
  56. package/bundler/sandbox/policy.d.ts +62 -0
  57. package/bundler/sandbox/policy.d.ts.map +1 -0
  58. package/bundler/types.d.ts +702 -0
  59. package/bundler/types.d.ts.map +1 -0
  60. package/components/alert.d.ts +66 -0
  61. package/components/alert.d.ts.map +1 -0
  62. package/components/alert.schema.d.ts +98 -0
  63. package/components/alert.schema.d.ts.map +1 -0
  64. package/components/avatar.d.ts +77 -0
  65. package/components/avatar.d.ts.map +1 -0
  66. package/components/avatar.schema.d.ts +170 -0
  67. package/components/avatar.schema.d.ts.map +1 -0
  68. package/components/badge.d.ts +64 -0
  69. package/components/badge.d.ts.map +1 -0
  70. package/components/badge.schema.d.ts +91 -0
  71. package/components/badge.schema.d.ts.map +1 -0
  72. package/components/button.d.ts +100 -0
  73. package/components/button.d.ts.map +1 -0
  74. package/components/button.schema.d.ts +120 -0
  75. package/components/button.schema.d.ts.map +1 -0
  76. package/components/card.d.ts +53 -0
  77. package/components/card.d.ts.map +1 -0
  78. package/components/card.schema.d.ts +93 -0
  79. package/components/card.schema.d.ts.map +1 -0
  80. package/components/form.d.ts +212 -0
  81. package/components/form.d.ts.map +1 -0
  82. package/components/form.schema.d.ts +365 -0
  83. package/components/form.schema.d.ts.map +1 -0
  84. package/components/index.d.ts +29 -0
  85. package/components/index.d.ts.map +1 -0
  86. package/components/index.js +2525 -0
  87. package/components/list.d.ts +121 -0
  88. package/components/list.d.ts.map +1 -0
  89. package/components/list.schema.d.ts +129 -0
  90. package/components/list.schema.d.ts.map +1 -0
  91. package/components/modal.d.ts +100 -0
  92. package/components/modal.d.ts.map +1 -0
  93. package/components/modal.schema.d.ts +151 -0
  94. package/components/modal.schema.d.ts.map +1 -0
  95. package/components/table.d.ts +91 -0
  96. package/components/table.d.ts.map +1 -0
  97. package/components/table.schema.d.ts +123 -0
  98. package/components/table.schema.d.ts.map +1 -0
  99. package/esm/bridge/adapters/base-adapter.d.ts +104 -0
  100. package/esm/bridge/adapters/base-adapter.d.ts.map +1 -0
  101. package/esm/bridge/adapters/claude.adapter.d.ts +67 -0
  102. package/esm/bridge/adapters/claude.adapter.d.ts.map +1 -0
  103. package/esm/bridge/adapters/ext-apps.adapter.d.ts +143 -0
  104. package/esm/bridge/adapters/ext-apps.adapter.d.ts.map +1 -0
  105. package/esm/bridge/adapters/gemini.adapter.d.ts +64 -0
  106. package/esm/bridge/adapters/gemini.adapter.d.ts.map +1 -0
  107. package/esm/bridge/adapters/generic.adapter.d.ts +56 -0
  108. package/esm/bridge/adapters/generic.adapter.d.ts.map +1 -0
  109. package/esm/bridge/adapters/index.d.ts +26 -0
  110. package/esm/bridge/adapters/index.d.ts.map +1 -0
  111. package/esm/bridge/adapters/openai.adapter.d.ts +65 -0
  112. package/esm/bridge/adapters/openai.adapter.d.ts.map +1 -0
  113. package/esm/bridge/core/adapter-registry.d.ts +122 -0
  114. package/esm/bridge/core/adapter-registry.d.ts.map +1 -0
  115. package/esm/bridge/core/bridge-factory.d.ts +199 -0
  116. package/esm/bridge/core/bridge-factory.d.ts.map +1 -0
  117. package/esm/bridge/core/index.d.ts +10 -0
  118. package/esm/bridge/core/index.d.ts.map +1 -0
  119. package/esm/bridge/index.d.ts +62 -0
  120. package/esm/bridge/index.d.ts.map +1 -0
  121. package/esm/bridge/index.js +2487 -0
  122. package/esm/bridge/runtime/iife-generator.d.ts +62 -0
  123. package/esm/bridge/runtime/iife-generator.d.ts.map +1 -0
  124. package/esm/bridge/runtime/index.d.ts +10 -0
  125. package/esm/bridge/runtime/index.d.ts.map +1 -0
  126. package/esm/bridge/types.d.ts +386 -0
  127. package/esm/bridge/types.d.ts.map +1 -0
  128. package/esm/bundler/bundler.d.ts +208 -0
  129. package/esm/bundler/bundler.d.ts.map +1 -0
  130. package/esm/bundler/cache.d.ts +173 -0
  131. package/esm/bundler/cache.d.ts.map +1 -0
  132. package/esm/bundler/file-cache/component-builder.d.ts +167 -0
  133. package/esm/bundler/file-cache/component-builder.d.ts.map +1 -0
  134. package/esm/bundler/file-cache/hash-calculator.d.ts +155 -0
  135. package/esm/bundler/file-cache/hash-calculator.d.ts.map +1 -0
  136. package/esm/bundler/file-cache/index.d.ts +12 -0
  137. package/esm/bundler/file-cache/index.d.ts.map +1 -0
  138. package/esm/bundler/file-cache/storage/filesystem.d.ts +149 -0
  139. package/esm/bundler/file-cache/storage/filesystem.d.ts.map +1 -0
  140. package/esm/bundler/file-cache/storage/index.d.ts +11 -0
  141. package/esm/bundler/file-cache/storage/index.d.ts.map +1 -0
  142. package/esm/bundler/file-cache/storage/interface.d.ts +152 -0
  143. package/esm/bundler/file-cache/storage/interface.d.ts.map +1 -0
  144. package/esm/bundler/file-cache/storage/redis.d.ts +139 -0
  145. package/esm/bundler/file-cache/storage/redis.d.ts.map +1 -0
  146. package/esm/bundler/index.d.ts +43 -0
  147. package/esm/bundler/index.d.ts.map +1 -0
  148. package/esm/bundler/index.js +3640 -0
  149. package/esm/bundler/sandbox/enclave-adapter.d.ts +121 -0
  150. package/esm/bundler/sandbox/enclave-adapter.d.ts.map +1 -0
  151. package/esm/bundler/sandbox/executor.d.ts +14 -0
  152. package/esm/bundler/sandbox/executor.d.ts.map +1 -0
  153. package/esm/bundler/sandbox/policy.d.ts +62 -0
  154. package/esm/bundler/sandbox/policy.d.ts.map +1 -0
  155. package/esm/bundler/types.d.ts +702 -0
  156. package/esm/bundler/types.d.ts.map +1 -0
  157. package/esm/components/alert.d.ts +66 -0
  158. package/esm/components/alert.d.ts.map +1 -0
  159. package/esm/components/alert.schema.d.ts +98 -0
  160. package/esm/components/alert.schema.d.ts.map +1 -0
  161. package/esm/components/avatar.d.ts +77 -0
  162. package/esm/components/avatar.d.ts.map +1 -0
  163. package/esm/components/avatar.schema.d.ts +170 -0
  164. package/esm/components/avatar.schema.d.ts.map +1 -0
  165. package/esm/components/badge.d.ts +64 -0
  166. package/esm/components/badge.d.ts.map +1 -0
  167. package/esm/components/badge.schema.d.ts +91 -0
  168. package/esm/components/badge.schema.d.ts.map +1 -0
  169. package/esm/components/button.d.ts +100 -0
  170. package/esm/components/button.d.ts.map +1 -0
  171. package/esm/components/button.schema.d.ts +120 -0
  172. package/esm/components/button.schema.d.ts.map +1 -0
  173. package/esm/components/card.d.ts +53 -0
  174. package/esm/components/card.d.ts.map +1 -0
  175. package/esm/components/card.schema.d.ts +93 -0
  176. package/esm/components/card.schema.d.ts.map +1 -0
  177. package/esm/components/form.d.ts +212 -0
  178. package/esm/components/form.d.ts.map +1 -0
  179. package/esm/components/form.schema.d.ts +365 -0
  180. package/esm/components/form.schema.d.ts.map +1 -0
  181. package/esm/components/index.d.ts +29 -0
  182. package/esm/components/index.d.ts.map +1 -0
  183. package/esm/components/index.js +2396 -0
  184. package/esm/components/list.d.ts +121 -0
  185. package/esm/components/list.d.ts.map +1 -0
  186. package/esm/components/list.schema.d.ts +129 -0
  187. package/esm/components/list.schema.d.ts.map +1 -0
  188. package/esm/components/modal.d.ts +100 -0
  189. package/esm/components/modal.d.ts.map +1 -0
  190. package/esm/components/modal.schema.d.ts +151 -0
  191. package/esm/components/modal.schema.d.ts.map +1 -0
  192. package/esm/components/table.d.ts +91 -0
  193. package/esm/components/table.d.ts.map +1 -0
  194. package/esm/components/table.schema.d.ts +123 -0
  195. package/esm/components/table.schema.d.ts.map +1 -0
  196. package/esm/index.d.ts +40 -0
  197. package/esm/index.d.ts.map +1 -0
  198. package/esm/index.js +8326 -0
  199. package/esm/layouts/base.d.ts +86 -0
  200. package/esm/layouts/base.d.ts.map +1 -0
  201. package/esm/layouts/index.d.ts +8 -0
  202. package/esm/layouts/index.d.ts.map +1 -0
  203. package/esm/layouts/index.js +409 -0
  204. package/esm/layouts/presets.d.ts +134 -0
  205. package/esm/layouts/presets.d.ts.map +1 -0
  206. package/esm/package.json +72 -0
  207. package/esm/pages/consent.d.ts +117 -0
  208. package/esm/pages/consent.d.ts.map +1 -0
  209. package/esm/pages/error.d.ts +101 -0
  210. package/esm/pages/error.d.ts.map +1 -0
  211. package/esm/pages/index.d.ts +9 -0
  212. package/esm/pages/index.d.ts.map +1 -0
  213. package/esm/pages/index.js +1036 -0
  214. package/esm/react/Alert.d.ts +101 -0
  215. package/esm/react/Alert.d.ts.map +1 -0
  216. package/esm/react/Badge.d.ts +100 -0
  217. package/esm/react/Badge.d.ts.map +1 -0
  218. package/esm/react/Button.d.ts +108 -0
  219. package/esm/react/Button.d.ts.map +1 -0
  220. package/esm/react/Card.d.ts +103 -0
  221. package/esm/react/Card.d.ts.map +1 -0
  222. package/esm/react/hooks/context.d.ts +179 -0
  223. package/esm/react/hooks/context.d.ts.map +1 -0
  224. package/esm/react/hooks/index.d.ts +42 -0
  225. package/esm/react/hooks/index.d.ts.map +1 -0
  226. package/esm/react/hooks/tools.d.ts +284 -0
  227. package/esm/react/hooks/tools.d.ts.map +1 -0
  228. package/esm/react/index.d.ts +80 -0
  229. package/esm/react/index.d.ts.map +1 -0
  230. package/esm/react/index.js +3124 -0
  231. package/esm/react/types.d.ts +105 -0
  232. package/esm/react/types.d.ts.map +1 -0
  233. package/esm/react/utils.d.ts +43 -0
  234. package/esm/react/utils.d.ts.map +1 -0
  235. package/esm/render/index.d.ts +8 -0
  236. package/esm/render/index.d.ts.map +1 -0
  237. package/esm/render/index.js +45 -0
  238. package/esm/render/prerender.d.ts +57 -0
  239. package/esm/render/prerender.d.ts.map +1 -0
  240. package/esm/renderers/index.d.ts +21 -0
  241. package/esm/renderers/index.d.ts.map +1 -0
  242. package/esm/renderers/index.js +381 -0
  243. package/esm/renderers/react.adapter.d.ts +70 -0
  244. package/esm/renderers/react.adapter.d.ts.map +1 -0
  245. package/esm/renderers/react.renderer.d.ts +96 -0
  246. package/esm/renderers/react.renderer.d.ts.map +1 -0
  247. package/esm/universal/UniversalApp.d.ts +108 -0
  248. package/esm/universal/UniversalApp.d.ts.map +1 -0
  249. package/esm/universal/cached-runtime.d.ts +115 -0
  250. package/esm/universal/cached-runtime.d.ts.map +1 -0
  251. package/esm/universal/context.d.ts +122 -0
  252. package/esm/universal/context.d.ts.map +1 -0
  253. package/esm/universal/index.d.ts +57 -0
  254. package/esm/universal/index.d.ts.map +1 -0
  255. package/esm/universal/index.js +1755 -0
  256. package/esm/universal/renderers/html.renderer.d.ts +37 -0
  257. package/esm/universal/renderers/html.renderer.d.ts.map +1 -0
  258. package/esm/universal/renderers/index.d.ts +112 -0
  259. package/esm/universal/renderers/index.d.ts.map +1 -0
  260. package/esm/universal/renderers/markdown.renderer.d.ts +33 -0
  261. package/esm/universal/renderers/markdown.renderer.d.ts.map +1 -0
  262. package/esm/universal/renderers/mdx.renderer.d.ts +38 -0
  263. package/esm/universal/renderers/mdx.renderer.d.ts.map +1 -0
  264. package/esm/universal/renderers/react.renderer.d.ts +46 -0
  265. package/esm/universal/renderers/react.renderer.d.ts.map +1 -0
  266. package/esm/universal/runtime-builder.d.ts +33 -0
  267. package/esm/universal/runtime-builder.d.ts.map +1 -0
  268. package/esm/universal/store.d.ts +135 -0
  269. package/esm/universal/store.d.ts.map +1 -0
  270. package/esm/universal/types.d.ts +199 -0
  271. package/esm/universal/types.d.ts.map +1 -0
  272. package/esm/web-components/core/attribute-parser.d.ts +82 -0
  273. package/esm/web-components/core/attribute-parser.d.ts.map +1 -0
  274. package/esm/web-components/core/base-element.d.ts +197 -0
  275. package/esm/web-components/core/base-element.d.ts.map +1 -0
  276. package/esm/web-components/core/index.d.ts +9 -0
  277. package/esm/web-components/core/index.d.ts.map +1 -0
  278. package/esm/web-components/elements/fmcp-alert.d.ts +46 -0
  279. package/esm/web-components/elements/fmcp-alert.d.ts.map +1 -0
  280. package/esm/web-components/elements/fmcp-badge.d.ts +47 -0
  281. package/esm/web-components/elements/fmcp-badge.d.ts.map +1 -0
  282. package/esm/web-components/elements/fmcp-button.d.ts +117 -0
  283. package/esm/web-components/elements/fmcp-button.d.ts.map +1 -0
  284. package/esm/web-components/elements/fmcp-card.d.ts +53 -0
  285. package/esm/web-components/elements/fmcp-card.d.ts.map +1 -0
  286. package/esm/web-components/elements/fmcp-input.d.ts +96 -0
  287. package/esm/web-components/elements/fmcp-input.d.ts.map +1 -0
  288. package/esm/web-components/elements/fmcp-select.d.ts +100 -0
  289. package/esm/web-components/elements/fmcp-select.d.ts.map +1 -0
  290. package/esm/web-components/elements/index.d.ts +13 -0
  291. package/esm/web-components/elements/index.d.ts.map +1 -0
  292. package/esm/web-components/index.d.ts +50 -0
  293. package/esm/web-components/index.d.ts.map +1 -0
  294. package/esm/web-components/index.js +1993 -0
  295. package/esm/web-components/register.d.ts +57 -0
  296. package/esm/web-components/register.d.ts.map +1 -0
  297. package/esm/web-components/types.d.ts +122 -0
  298. package/esm/web-components/types.d.ts.map +1 -0
  299. package/esm/widgets/index.d.ts +8 -0
  300. package/esm/widgets/index.d.ts.map +1 -0
  301. package/esm/widgets/index.js +883 -0
  302. package/esm/widgets/progress.d.ts +133 -0
  303. package/esm/widgets/progress.d.ts.map +1 -0
  304. package/esm/widgets/resource.d.ts +163 -0
  305. package/esm/widgets/resource.d.ts.map +1 -0
  306. package/index.d.ts +40 -0
  307. package/index.d.ts.map +1 -0
  308. package/index.js +8526 -0
  309. package/layouts/base.d.ts +86 -0
  310. package/layouts/base.d.ts.map +1 -0
  311. package/layouts/index.d.ts +8 -0
  312. package/layouts/index.d.ts.map +1 -0
  313. package/layouts/index.js +437 -0
  314. package/layouts/presets.d.ts +134 -0
  315. package/layouts/presets.d.ts.map +1 -0
  316. package/package.json +33 -110
  317. package/pages/consent.d.ts +117 -0
  318. package/pages/consent.d.ts.map +1 -0
  319. package/pages/error.d.ts +101 -0
  320. package/pages/error.d.ts.map +1 -0
  321. package/pages/index.d.ts +9 -0
  322. package/pages/index.d.ts.map +1 -0
  323. package/pages/index.js +1065 -0
  324. package/react/Alert.d.ts +101 -0
  325. package/react/Alert.d.ts.map +1 -0
  326. package/react/Badge.d.ts +100 -0
  327. package/react/Badge.d.ts.map +1 -0
  328. package/react/Button.d.ts +108 -0
  329. package/react/Button.d.ts.map +1 -0
  330. package/react/Card.d.ts +103 -0
  331. package/react/Card.d.ts.map +1 -0
  332. package/react/hooks/context.d.ts +179 -0
  333. package/react/hooks/context.d.ts.map +1 -0
  334. package/react/hooks/index.d.ts +42 -0
  335. package/react/hooks/index.d.ts.map +1 -0
  336. package/react/hooks/tools.d.ts +284 -0
  337. package/react/hooks/tools.d.ts.map +1 -0
  338. package/react/index.d.ts +80 -0
  339. package/react/index.d.ts.map +1 -0
  340. package/react/index.js +3160 -0
  341. package/react/types.d.ts +105 -0
  342. package/react/types.d.ts.map +1 -0
  343. package/react/utils.d.ts +43 -0
  344. package/react/utils.d.ts.map +1 -0
  345. package/render/index.d.ts +8 -0
  346. package/render/index.d.ts.map +1 -0
  347. package/render/index.js +77 -0
  348. package/render/prerender.d.ts +57 -0
  349. package/render/prerender.d.ts.map +1 -0
  350. package/renderers/index.d.ts +21 -0
  351. package/renderers/index.d.ts.map +1 -0
  352. package/renderers/index.js +416 -0
  353. package/renderers/react.adapter.d.ts +70 -0
  354. package/renderers/react.adapter.d.ts.map +1 -0
  355. package/renderers/react.renderer.d.ts +96 -0
  356. package/renderers/react.renderer.d.ts.map +1 -0
  357. package/universal/UniversalApp.d.ts +108 -0
  358. package/universal/UniversalApp.d.ts.map +1 -0
  359. package/universal/cached-runtime.d.ts +115 -0
  360. package/universal/cached-runtime.d.ts.map +1 -0
  361. package/universal/context.d.ts +122 -0
  362. package/universal/context.d.ts.map +1 -0
  363. package/universal/index.d.ts +57 -0
  364. package/universal/index.d.ts.map +1 -0
  365. package/universal/index.js +1841 -0
  366. package/universal/renderers/html.renderer.d.ts +37 -0
  367. package/universal/renderers/html.renderer.d.ts.map +1 -0
  368. package/universal/renderers/index.d.ts +112 -0
  369. package/universal/renderers/index.d.ts.map +1 -0
  370. package/universal/renderers/markdown.renderer.d.ts +33 -0
  371. package/universal/renderers/markdown.renderer.d.ts.map +1 -0
  372. package/universal/renderers/mdx.renderer.d.ts +38 -0
  373. package/universal/renderers/mdx.renderer.d.ts.map +1 -0
  374. package/universal/renderers/react.renderer.d.ts +46 -0
  375. package/universal/renderers/react.renderer.d.ts.map +1 -0
  376. package/universal/runtime-builder.d.ts +33 -0
  377. package/universal/runtime-builder.d.ts.map +1 -0
  378. package/universal/store.d.ts +135 -0
  379. package/universal/store.d.ts.map +1 -0
  380. package/universal/types.d.ts +199 -0
  381. package/universal/types.d.ts.map +1 -0
  382. package/web-components/core/attribute-parser.d.ts +82 -0
  383. package/web-components/core/attribute-parser.d.ts.map +1 -0
  384. package/web-components/core/base-element.d.ts +197 -0
  385. package/web-components/core/base-element.d.ts.map +1 -0
  386. package/web-components/core/index.d.ts +9 -0
  387. package/web-components/core/index.d.ts.map +1 -0
  388. package/web-components/elements/fmcp-alert.d.ts +46 -0
  389. package/web-components/elements/fmcp-alert.d.ts.map +1 -0
  390. package/web-components/elements/fmcp-badge.d.ts +47 -0
  391. package/web-components/elements/fmcp-badge.d.ts.map +1 -0
  392. package/web-components/elements/fmcp-button.d.ts +117 -0
  393. package/web-components/elements/fmcp-button.d.ts.map +1 -0
  394. package/web-components/elements/fmcp-card.d.ts +53 -0
  395. package/web-components/elements/fmcp-card.d.ts.map +1 -0
  396. package/web-components/elements/fmcp-input.d.ts +96 -0
  397. package/web-components/elements/fmcp-input.d.ts.map +1 -0
  398. package/web-components/elements/fmcp-select.d.ts +100 -0
  399. package/web-components/elements/fmcp-select.d.ts.map +1 -0
  400. package/web-components/elements/index.d.ts +13 -0
  401. package/web-components/elements/index.d.ts.map +1 -0
  402. package/web-components/index.d.ts +50 -0
  403. package/web-components/index.d.ts.map +1 -0
  404. package/web-components/index.js +2028 -0
  405. package/web-components/register.d.ts +57 -0
  406. package/web-components/register.d.ts.map +1 -0
  407. package/web-components/types.d.ts +122 -0
  408. package/web-components/types.d.ts.map +1 -0
  409. package/widgets/index.d.ts +8 -0
  410. package/widgets/index.d.ts.map +1 -0
  411. package/widgets/index.js +910 -0
  412. package/widgets/progress.d.ts +133 -0
  413. package/widgets/progress.d.ts.map +1 -0
  414. package/widgets/resource.d.ts +163 -0
  415. package/widgets/resource.d.ts.map +1 -0
  416. package/src/adapters/index.d.ts +0 -10
  417. package/src/adapters/index.js +0 -18
  418. package/src/adapters/index.js.map +0 -1
  419. package/src/adapters/platform-meta.d.ts +0 -165
  420. package/src/adapters/platform-meta.js +0 -310
  421. package/src/adapters/platform-meta.js.map +0 -1
  422. package/src/base-template/bridge.d.ts +0 -89
  423. package/src/base-template/bridge.js +0 -452
  424. package/src/base-template/bridge.js.map +0 -1
  425. package/src/base-template/default-base-template.d.ts +0 -91
  426. package/src/base-template/default-base-template.js +0 -435
  427. package/src/base-template/default-base-template.js.map +0 -1
  428. package/src/base-template/index.d.ts +0 -14
  429. package/src/base-template/index.js +0 -30
  430. package/src/base-template/index.js.map +0 -1
  431. package/src/base-template/polyfills.d.ts +0 -30
  432. package/src/base-template/polyfills.js +0 -190
  433. package/src/base-template/polyfills.js.map +0 -1
  434. package/src/base-template/theme-styles.d.ts +0 -73
  435. package/src/base-template/theme-styles.js +0 -95
  436. package/src/base-template/theme-styles.js.map +0 -1
  437. package/src/bridge/adapters/base-adapter.d.ts +0 -103
  438. package/src/bridge/adapters/base-adapter.js +0 -314
  439. package/src/bridge/adapters/base-adapter.js.map +0 -1
  440. package/src/bridge/adapters/claude.adapter.d.ts +0 -66
  441. package/src/bridge/adapters/claude.adapter.js +0 -145
  442. package/src/bridge/adapters/claude.adapter.js.map +0 -1
  443. package/src/bridge/adapters/ext-apps.adapter.d.ts +0 -142
  444. package/src/bridge/adapters/ext-apps.adapter.js +0 -416
  445. package/src/bridge/adapters/ext-apps.adapter.js.map +0 -1
  446. package/src/bridge/adapters/gemini.adapter.d.ts +0 -63
  447. package/src/bridge/adapters/gemini.adapter.js +0 -160
  448. package/src/bridge/adapters/gemini.adapter.js.map +0 -1
  449. package/src/bridge/adapters/generic.adapter.d.ts +0 -55
  450. package/src/bridge/adapters/generic.adapter.js +0 -108
  451. package/src/bridge/adapters/generic.adapter.js.map +0 -1
  452. package/src/bridge/adapters/index.d.ts +0 -25
  453. package/src/bridge/adapters/index.js +0 -65
  454. package/src/bridge/adapters/index.js.map +0 -1
  455. package/src/bridge/adapters/openai.adapter.d.ts +0 -64
  456. package/src/bridge/adapters/openai.adapter.js +0 -194
  457. package/src/bridge/adapters/openai.adapter.js.map +0 -1
  458. package/src/bridge/core/adapter-registry.d.ts +0 -121
  459. package/src/bridge/core/adapter-registry.js +0 -271
  460. package/src/bridge/core/adapter-registry.js.map +0 -1
  461. package/src/bridge/core/bridge-factory.d.ts +0 -198
  462. package/src/bridge/core/bridge-factory.js +0 -428
  463. package/src/bridge/core/bridge-factory.js.map +0 -1
  464. package/src/bridge/core/index.d.ts +0 -9
  465. package/src/bridge/core/index.js +0 -22
  466. package/src/bridge/core/index.js.map +0 -1
  467. package/src/bridge/index.d.ts +0 -61
  468. package/src/bridge/index.js +0 -94
  469. package/src/bridge/index.js.map +0 -1
  470. package/src/bridge/runtime/iife-generator.d.ts +0 -61
  471. package/src/bridge/runtime/iife-generator.js +0 -940
  472. package/src/bridge/runtime/iife-generator.js.map +0 -1
  473. package/src/bridge/runtime/index.d.ts +0 -8
  474. package/src/bridge/runtime/index.js +0 -16
  475. package/src/bridge/runtime/index.js.map +0 -1
  476. package/src/bridge/types.d.ts +0 -385
  477. package/src/bridge/types.js +0 -11
  478. package/src/bridge/types.js.map +0 -1
  479. package/src/build/cdn-resources.d.ts +0 -140
  480. package/src/build/cdn-resources.js +0 -314
  481. package/src/build/cdn-resources.js.map +0 -1
  482. package/src/build/index.d.ts +0 -294
  483. package/src/build/index.js +0 -325
  484. package/src/build/index.js.map +0 -1
  485. package/src/build/widget-manifest.d.ts +0 -212
  486. package/src/build/widget-manifest.js +0 -652
  487. package/src/build/widget-manifest.js.map +0 -1
  488. package/src/bundler/bundler.d.ts +0 -110
  489. package/src/bundler/bundler.js +0 -432
  490. package/src/bundler/bundler.js.map +0 -1
  491. package/src/bundler/cache.d.ts +0 -172
  492. package/src/bundler/cache.js +0 -250
  493. package/src/bundler/cache.js.map +0 -1
  494. package/src/bundler/index.d.ts +0 -41
  495. package/src/bundler/index.js +0 -73
  496. package/src/bundler/index.js.map +0 -1
  497. package/src/bundler/sandbox/enclave-adapter.d.ts +0 -120
  498. package/src/bundler/sandbox/enclave-adapter.js +0 -339
  499. package/src/bundler/sandbox/enclave-adapter.js.map +0 -1
  500. package/src/bundler/sandbox/executor.d.ts +0 -13
  501. package/src/bundler/sandbox/executor.js +0 -22
  502. package/src/bundler/sandbox/executor.js.map +0 -1
  503. package/src/bundler/sandbox/policy.d.ts +0 -61
  504. package/src/bundler/sandbox/policy.js +0 -238
  505. package/src/bundler/sandbox/policy.js.map +0 -1
  506. package/src/bundler/types.d.ts +0 -347
  507. package/src/bundler/types.js +0 -132
  508. package/src/bundler/types.js.map +0 -1
  509. package/src/components/alert.d.ts +0 -71
  510. package/src/components/alert.js +0 -189
  511. package/src/components/alert.js.map +0 -1
  512. package/src/components/alert.schema.d.ts +0 -114
  513. package/src/components/alert.schema.js +0 -105
  514. package/src/components/alert.schema.js.map +0 -1
  515. package/src/components/avatar.d.ts +0 -76
  516. package/src/components/avatar.js +0 -176
  517. package/src/components/avatar.js.map +0 -1
  518. package/src/components/avatar.schema.d.ts +0 -169
  519. package/src/components/avatar.schema.js +0 -103
  520. package/src/components/avatar.schema.js.map +0 -1
  521. package/src/components/badge.d.ts +0 -70
  522. package/src/components/badge.js +0 -149
  523. package/src/components/badge.js.map +0 -1
  524. package/src/components/badge.schema.d.ts +0 -109
  525. package/src/components/badge.schema.js +0 -96
  526. package/src/components/badge.schema.js.map +0 -1
  527. package/src/components/button.d.ts +0 -111
  528. package/src/components/button.js +0 -336
  529. package/src/components/button.js.map +0 -1
  530. package/src/components/button.schema.d.ts +0 -148
  531. package/src/components/button.schema.js +0 -121
  532. package/src/components/button.schema.js.map +0 -1
  533. package/src/components/card.d.ts +0 -60
  534. package/src/components/card.js +0 -117
  535. package/src/components/card.js.map +0 -1
  536. package/src/components/card.schema.d.ts +0 -113
  537. package/src/components/card.schema.js +0 -98
  538. package/src/components/card.schema.js.map +0 -1
  539. package/src/components/form.d.ts +0 -239
  540. package/src/components/form.js +0 -420
  541. package/src/components/form.js.map +0 -1
  542. package/src/components/form.schema.d.ts +0 -441
  543. package/src/components/form.schema.js +0 -406
  544. package/src/components/form.schema.js.map +0 -1
  545. package/src/components/index.d.ts +0 -29
  546. package/src/components/index.js +0 -98
  547. package/src/components/index.js.map +0 -1
  548. package/src/components/list.d.ts +0 -127
  549. package/src/components/list.js +0 -279
  550. package/src/components/list.js.map +0 -1
  551. package/src/components/list.schema.d.ts +0 -134
  552. package/src/components/list.schema.js +0 -168
  553. package/src/components/list.schema.js.map +0 -1
  554. package/src/components/modal.d.ts +0 -111
  555. package/src/components/modal.js +0 -260
  556. package/src/components/modal.js.map +0 -1
  557. package/src/components/modal.schema.d.ts +0 -186
  558. package/src/components/modal.schema.js +0 -167
  559. package/src/components/modal.schema.js.map +0 -1
  560. package/src/components/table.d.ts +0 -105
  561. package/src/components/table.js +0 -283
  562. package/src/components/table.js.map +0 -1
  563. package/src/components/table.schema.d.ts +0 -159
  564. package/src/components/table.schema.js +0 -173
  565. package/src/components/table.schema.js.map +0 -1
  566. package/src/handlebars/helpers.d.ts +0 -348
  567. package/src/handlebars/helpers.js +0 -605
  568. package/src/handlebars/helpers.js.map +0 -1
  569. package/src/handlebars/index.d.ts +0 -193
  570. package/src/handlebars/index.js +0 -350
  571. package/src/handlebars/index.js.map +0 -1
  572. package/src/index.d.ts +0 -50
  573. package/src/index.js +0 -192
  574. package/src/index.js.map +0 -1
  575. package/src/layouts/base.d.ts +0 -88
  576. package/src/layouts/base.js +0 -227
  577. package/src/layouts/base.js.map +0 -1
  578. package/src/layouts/index.d.ts +0 -7
  579. package/src/layouts/index.js +0 -25
  580. package/src/layouts/index.js.map +0 -1
  581. package/src/layouts/presets.d.ts +0 -133
  582. package/src/layouts/presets.js +0 -277
  583. package/src/layouts/presets.js.map +0 -1
  584. package/src/pages/consent.d.ts +0 -116
  585. package/src/pages/consent.js +0 -218
  586. package/src/pages/consent.js.map +0 -1
  587. package/src/pages/error.d.ts +0 -100
  588. package/src/pages/error.js +0 -263
  589. package/src/pages/error.js.map +0 -1
  590. package/src/pages/index.d.ts +0 -8
  591. package/src/pages/index.js +0 -27
  592. package/src/pages/index.js.map +0 -1
  593. package/src/react/Alert.d.ts +0 -101
  594. package/src/react/Alert.js +0 -51
  595. package/src/react/Alert.js.map +0 -1
  596. package/src/react/Badge.d.ts +0 -100
  597. package/src/react/Badge.js +0 -55
  598. package/src/react/Badge.js.map +0 -1
  599. package/src/react/Button.d.ts +0 -108
  600. package/src/react/Button.js +0 -52
  601. package/src/react/Button.js.map +0 -1
  602. package/src/react/Card.d.ts +0 -103
  603. package/src/react/Card.js +0 -55
  604. package/src/react/Card.js.map +0 -1
  605. package/src/react/hooks/context.d.ts +0 -178
  606. package/src/react/hooks/context.js +0 -287
  607. package/src/react/hooks/context.js.map +0 -1
  608. package/src/react/hooks/index.d.ts +0 -41
  609. package/src/react/hooks/index.js +0 -61
  610. package/src/react/hooks/index.js.map +0 -1
  611. package/src/react/hooks/tools.d.ts +0 -283
  612. package/src/react/hooks/tools.js +0 -465
  613. package/src/react/hooks/tools.js.map +0 -1
  614. package/src/react/index.d.ts +0 -80
  615. package/src/react/index.js +0 -113
  616. package/src/react/index.js.map +0 -1
  617. package/src/react/types.d.ts +0 -105
  618. package/src/react/types.js +0 -12
  619. package/src/react/types.js.map +0 -1
  620. package/src/react/utils.d.ts +0 -42
  621. package/src/react/utils.js +0 -99
  622. package/src/react/utils.js.map +0 -1
  623. package/src/registry/index.d.ts +0 -45
  624. package/src/registry/index.js +0 -67
  625. package/src/registry/index.js.map +0 -1
  626. package/src/registry/render-template.d.ts +0 -86
  627. package/src/registry/render-template.js +0 -239
  628. package/src/registry/render-template.js.map +0 -1
  629. package/src/registry/tool-ui.registry.d.ts +0 -260
  630. package/src/registry/tool-ui.registry.js +0 -438
  631. package/src/registry/tool-ui.registry.js.map +0 -1
  632. package/src/registry/uri-utils.d.ts +0 -55
  633. package/src/registry/uri-utils.js +0 -97
  634. package/src/registry/uri-utils.js.map +0 -1
  635. package/src/render/index.d.ts +0 -7
  636. package/src/render/index.js +0 -14
  637. package/src/render/index.js.map +0 -1
  638. package/src/render/prerender.d.ts +0 -56
  639. package/src/render/prerender.js +0 -98
  640. package/src/render/prerender.js.map +0 -1
  641. package/src/renderers/cache.d.ts +0 -144
  642. package/src/renderers/cache.js +0 -240
  643. package/src/renderers/cache.js.map +0 -1
  644. package/src/renderers/html.renderer.d.ts +0 -122
  645. package/src/renderers/html.renderer.js +0 -204
  646. package/src/renderers/html.renderer.js.map +0 -1
  647. package/src/renderers/index.d.ts +0 -35
  648. package/src/renderers/index.js +0 -70
  649. package/src/renderers/index.js.map +0 -1
  650. package/src/renderers/mdx.renderer.d.ts +0 -119
  651. package/src/renderers/mdx.renderer.js +0 -305
  652. package/src/renderers/mdx.renderer.js.map +0 -1
  653. package/src/renderers/react.renderer.d.ts +0 -95
  654. package/src/renderers/react.renderer.js +0 -260
  655. package/src/renderers/react.renderer.js.map +0 -1
  656. package/src/renderers/registry.d.ts +0 -133
  657. package/src/renderers/registry.js +0 -232
  658. package/src/renderers/registry.js.map +0 -1
  659. package/src/renderers/types.d.ts +0 -341
  660. package/src/renderers/types.js +0 -9
  661. package/src/renderers/types.js.map +0 -1
  662. package/src/renderers/utils/detect.d.ts +0 -106
  663. package/src/renderers/utils/detect.js +0 -267
  664. package/src/renderers/utils/detect.js.map +0 -1
  665. package/src/renderers/utils/hash.d.ts +0 -39
  666. package/src/renderers/utils/hash.js +0 -75
  667. package/src/renderers/utils/hash.js.map +0 -1
  668. package/src/renderers/utils/index.d.ts +0 -8
  669. package/src/renderers/utils/index.js +0 -28
  670. package/src/renderers/utils/index.js.map +0 -1
  671. package/src/renderers/utils/transpiler.d.ts +0 -88
  672. package/src/renderers/utils/transpiler.js +0 -215
  673. package/src/renderers/utils/transpiler.js.map +0 -1
  674. package/src/runtime/adapters/html.adapter.d.ts +0 -58
  675. package/src/runtime/adapters/html.adapter.js +0 -131
  676. package/src/runtime/adapters/html.adapter.js.map +0 -1
  677. package/src/runtime/adapters/index.d.ts +0 -25
  678. package/src/runtime/adapters/index.js +0 -54
  679. package/src/runtime/adapters/index.js.map +0 -1
  680. package/src/runtime/adapters/mdx.adapter.d.ts +0 -72
  681. package/src/runtime/adapters/mdx.adapter.js +0 -241
  682. package/src/runtime/adapters/mdx.adapter.js.map +0 -1
  683. package/src/runtime/adapters/react.adapter.d.ts +0 -69
  684. package/src/runtime/adapters/react.adapter.js +0 -245
  685. package/src/runtime/adapters/react.adapter.js.map +0 -1
  686. package/src/runtime/adapters/types.d.ts +0 -94
  687. package/src/runtime/adapters/types.js +0 -11
  688. package/src/runtime/adapters/types.js.map +0 -1
  689. package/src/runtime/csp.d.ts +0 -37
  690. package/src/runtime/csp.js +0 -140
  691. package/src/runtime/csp.js.map +0 -1
  692. package/src/runtime/index.d.ts +0 -16
  693. package/src/runtime/index.js +0 -72
  694. package/src/runtime/index.js.map +0 -1
  695. package/src/runtime/mcp-bridge.d.ts +0 -100
  696. package/src/runtime/mcp-bridge.js +0 -581
  697. package/src/runtime/mcp-bridge.js.map +0 -1
  698. package/src/runtime/renderer-runtime.d.ts +0 -132
  699. package/src/runtime/renderer-runtime.js +0 -389
  700. package/src/runtime/renderer-runtime.js.map +0 -1
  701. package/src/runtime/sanitizer.d.ts +0 -171
  702. package/src/runtime/sanitizer.js +0 -318
  703. package/src/runtime/sanitizer.js.map +0 -1
  704. package/src/runtime/types.d.ts +0 -414
  705. package/src/runtime/types.js +0 -12
  706. package/src/runtime/types.js.map +0 -1
  707. package/src/runtime/wrapper.d.ts +0 -375
  708. package/src/runtime/wrapper.js +0 -1793
  709. package/src/runtime/wrapper.js.map +0 -1
  710. package/src/styles/index.d.ts +0 -7
  711. package/src/styles/index.js +0 -11
  712. package/src/styles/index.js.map +0 -1
  713. package/src/styles/variants.d.ts +0 -50
  714. package/src/styles/variants.js +0 -175
  715. package/src/styles/variants.js.map +0 -1
  716. package/src/theme/cdn.d.ts +0 -194
  717. package/src/theme/cdn.js +0 -375
  718. package/src/theme/cdn.js.map +0 -1
  719. package/src/theme/index.d.ts +0 -17
  720. package/src/theme/index.js +0 -57
  721. package/src/theme/index.js.map +0 -1
  722. package/src/theme/platforms.d.ts +0 -106
  723. package/src/theme/platforms.js +0 -161
  724. package/src/theme/platforms.js.map +0 -1
  725. package/src/theme/presets/github-openai.d.ts +0 -49
  726. package/src/theme/presets/github-openai.js +0 -189
  727. package/src/theme/presets/github-openai.js.map +0 -1
  728. package/src/theme/presets/index.d.ts +0 -10
  729. package/src/theme/presets/index.js +0 -17
  730. package/src/theme/presets/index.js.map +0 -1
  731. package/src/theme/theme.d.ts +0 -395
  732. package/src/theme/theme.js +0 -332
  733. package/src/theme/theme.js.map +0 -1
  734. package/src/tool-template/builder.d.ts +0 -212
  735. package/src/tool-template/builder.js +0 -397
  736. package/src/tool-template/builder.js.map +0 -1
  737. package/src/tool-template/index.d.ts +0 -15
  738. package/src/tool-template/index.js +0 -38
  739. package/src/tool-template/index.js.map +0 -1
  740. package/src/types/index.d.ts +0 -13
  741. package/src/types/index.js +0 -26
  742. package/src/types/index.js.map +0 -1
  743. package/src/types/ui-config.d.ts +0 -357
  744. package/src/types/ui-config.js +0 -12
  745. package/src/types/ui-config.js.map +0 -1
  746. package/src/types/ui-runtime.d.ts +0 -965
  747. package/src/types/ui-runtime.js +0 -117
  748. package/src/types/ui-runtime.js.map +0 -1
  749. package/src/validation/error-box.d.ts +0 -55
  750. package/src/validation/error-box.js +0 -75
  751. package/src/validation/error-box.js.map +0 -1
  752. package/src/validation/index.d.ts +0 -12
  753. package/src/validation/index.js +0 -21
  754. package/src/validation/index.js.map +0 -1
  755. package/src/validation/wrapper.d.ts +0 -96
  756. package/src/validation/wrapper.js +0 -117
  757. package/src/validation/wrapper.js.map +0 -1
  758. package/src/web-components/core/attribute-parser.d.ts +0 -85
  759. package/src/web-components/core/attribute-parser.js +0 -189
  760. package/src/web-components/core/attribute-parser.js.map +0 -1
  761. package/src/web-components/core/base-element.d.ts +0 -197
  762. package/src/web-components/core/base-element.js +0 -289
  763. package/src/web-components/core/base-element.js.map +0 -1
  764. package/src/web-components/core/index.d.ts +0 -8
  765. package/src/web-components/core/index.js +0 -18
  766. package/src/web-components/core/index.js.map +0 -1
  767. package/src/web-components/elements/fmcp-alert.d.ts +0 -45
  768. package/src/web-components/elements/fmcp-alert.js +0 -93
  769. package/src/web-components/elements/fmcp-alert.js.map +0 -1
  770. package/src/web-components/elements/fmcp-badge.d.ts +0 -46
  771. package/src/web-components/elements/fmcp-badge.js +0 -99
  772. package/src/web-components/elements/fmcp-badge.js.map +0 -1
  773. package/src/web-components/elements/fmcp-button.d.ts +0 -124
  774. package/src/web-components/elements/fmcp-button.js +0 -233
  775. package/src/web-components/elements/fmcp-button.js.map +0 -1
  776. package/src/web-components/elements/fmcp-card.d.ts +0 -52
  777. package/src/web-components/elements/fmcp-card.js +0 -115
  778. package/src/web-components/elements/fmcp-card.js.map +0 -1
  779. package/src/web-components/elements/fmcp-input.d.ts +0 -95
  780. package/src/web-components/elements/fmcp-input.js +0 -248
  781. package/src/web-components/elements/fmcp-input.js.map +0 -1
  782. package/src/web-components/elements/fmcp-select.d.ts +0 -99
  783. package/src/web-components/elements/fmcp-select.js +0 -243
  784. package/src/web-components/elements/fmcp-select.js.map +0 -1
  785. package/src/web-components/elements/index.d.ts +0 -12
  786. package/src/web-components/elements/index.js +0 -34
  787. package/src/web-components/elements/index.js.map +0 -1
  788. package/src/web-components/index.d.ts +0 -49
  789. package/src/web-components/index.js +0 -75
  790. package/src/web-components/index.js.map +0 -1
  791. package/src/web-components/register.d.ts +0 -56
  792. package/src/web-components/register.js +0 -80
  793. package/src/web-components/register.js.map +0 -1
  794. package/src/web-components/types.d.ts +0 -121
  795. package/src/web-components/types.js +0 -25
  796. package/src/web-components/types.js.map +0 -1
  797. package/src/widgets/index.d.ts +0 -7
  798. package/src/widgets/index.js +0 -24
  799. package/src/widgets/index.js.map +0 -1
  800. package/src/widgets/progress.d.ts +0 -132
  801. package/src/widgets/progress.js +0 -303
  802. package/src/widgets/progress.js.map +0 -1
  803. package/src/widgets/resource.d.ts +0 -162
  804. package/src/widgets/resource.js +0 -340
  805. package/src/widgets/resource.js.map +0 -1
@@ -1,8 +0,0 @@
1
- /**
2
- * Page Templates Module
3
- *
4
- * Minimal page templates that complement SDK auth flows.
5
- * Login/Register flows are handled by @frontmcp/sdk auth system.
6
- */
7
- export { type ClientInfo, type UserInfo, type ConsentPageOptions, type ConsentSuccessOptions, type ConsentDeniedOptions, consentPage, consentSuccessPage, consentDeniedPage, } from './consent';
8
- export { type ErrorPageOptions, type OAuthErrorPageOptions, errorPage, notFoundPage, forbiddenPage, unauthorizedPage, serverErrorPage, maintenancePage, rateLimitPage, offlinePage, sessionExpiredPage, oauthErrorPage, } from './error';
@@ -1,27 +0,0 @@
1
- "use strict";
2
- /**
3
- * Page Templates Module
4
- *
5
- * Minimal page templates that complement SDK auth flows.
6
- * Login/Register flows are handled by @frontmcp/sdk auth system.
7
- */
8
- Object.defineProperty(exports, "__esModule", { value: true });
9
- exports.oauthErrorPage = exports.sessionExpiredPage = exports.offlinePage = exports.rateLimitPage = exports.maintenancePage = exports.serverErrorPage = exports.unauthorizedPage = exports.forbiddenPage = exports.notFoundPage = exports.errorPage = exports.consentDeniedPage = exports.consentSuccessPage = exports.consentPage = void 0;
10
- // Consent pages (OAuth/OpenID consent flows)
11
- var consent_1 = require("./consent");
12
- Object.defineProperty(exports, "consentPage", { enumerable: true, get: function () { return consent_1.consentPage; } });
13
- Object.defineProperty(exports, "consentSuccessPage", { enumerable: true, get: function () { return consent_1.consentSuccessPage; } });
14
- Object.defineProperty(exports, "consentDeniedPage", { enumerable: true, get: function () { return consent_1.consentDeniedPage; } });
15
- // Error pages (generic error display)
16
- var error_1 = require("./error");
17
- Object.defineProperty(exports, "errorPage", { enumerable: true, get: function () { return error_1.errorPage; } });
18
- Object.defineProperty(exports, "notFoundPage", { enumerable: true, get: function () { return error_1.notFoundPage; } });
19
- Object.defineProperty(exports, "forbiddenPage", { enumerable: true, get: function () { return error_1.forbiddenPage; } });
20
- Object.defineProperty(exports, "unauthorizedPage", { enumerable: true, get: function () { return error_1.unauthorizedPage; } });
21
- Object.defineProperty(exports, "serverErrorPage", { enumerable: true, get: function () { return error_1.serverErrorPage; } });
22
- Object.defineProperty(exports, "maintenancePage", { enumerable: true, get: function () { return error_1.maintenancePage; } });
23
- Object.defineProperty(exports, "rateLimitPage", { enumerable: true, get: function () { return error_1.rateLimitPage; } });
24
- Object.defineProperty(exports, "offlinePage", { enumerable: true, get: function () { return error_1.offlinePage; } });
25
- Object.defineProperty(exports, "sessionExpiredPage", { enumerable: true, get: function () { return error_1.sessionExpiredPage; } });
26
- Object.defineProperty(exports, "oauthErrorPage", { enumerable: true, get: function () { return error_1.oauthErrorPage; } });
27
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/pages/index.ts"],"names":[],"mappings":";AAAA;;;;;GAKG;;;AAEH,6CAA6C;AAC7C,qCASmB;AAHjB,sGAAA,WAAW,OAAA;AACX,6GAAA,kBAAkB,OAAA;AAClB,4GAAA,iBAAiB,OAAA;AAGnB,sCAAsC;AACtC,iCAaiB;AAVf,kGAAA,SAAS,OAAA;AACT,qGAAA,YAAY,OAAA;AACZ,sGAAA,aAAa,OAAA;AACb,yGAAA,gBAAgB,OAAA;AAChB,wGAAA,eAAe,OAAA;AACf,wGAAA,eAAe,OAAA;AACf,sGAAA,aAAa,OAAA;AACb,oGAAA,WAAW,OAAA;AACX,2GAAA,kBAAkB,OAAA;AAClB,uGAAA,cAAc,OAAA","sourcesContent":["/**\n * Page Templates Module\n *\n * Minimal page templates that complement SDK auth flows.\n * Login/Register flows are handled by @frontmcp/sdk auth system.\n */\n\n// Consent pages (OAuth/OpenID consent flows)\nexport {\n type ClientInfo,\n type UserInfo,\n type ConsentPageOptions,\n type ConsentSuccessOptions,\n type ConsentDeniedOptions,\n consentPage,\n consentSuccessPage,\n consentDeniedPage,\n} from './consent';\n\n// Error pages (generic error display)\nexport {\n type ErrorPageOptions,\n type OAuthErrorPageOptions,\n errorPage,\n notFoundPage,\n forbiddenPage,\n unauthorizedPage,\n serverErrorPage,\n maintenancePage,\n rateLimitPage,\n offlinePage,\n sessionExpiredPage,\n oauthErrorPage,\n} from './error';\n"]}
@@ -1,101 +0,0 @@
1
- /**
2
- * @file Alert.tsx
3
- * @description React Alert component with static HTML rendering support.
4
- *
5
- * This is the single source of truth for the Alert component. It can be used:
6
- * 1. As a React component: `<Alert variant="success" title="Success!">Message</Alert>`
7
- * 2. As a static HTML generator: `await renderAlert({ variant: 'success', children: 'Message' })`
8
- *
9
- * @example React usage
10
- * ```tsx
11
- * import { Alert } from '@frontmcp/ui/react';
12
- *
13
- * function App() {
14
- * return (
15
- * <Alert variant="success" title="Success!">
16
- * Your changes have been saved.
17
- * </Alert>
18
- * );
19
- * }
20
- * ```
21
- *
22
- * @example Dismissible alert
23
- * ```tsx
24
- * <Alert variant="warning" dismissible onDismiss={() => setShow(false)}>
25
- * This action cannot be undone.
26
- * </Alert>
27
- * ```
28
- *
29
- * @example Static HTML generation
30
- * ```typescript
31
- * import { renderAlert } from '@frontmcp/ui/react';
32
- *
33
- * const html = await renderAlert({
34
- * variant: 'info',
35
- * title: 'Note',
36
- * children: 'Please review before submitting.',
37
- * });
38
- * ```
39
- *
40
- * @module @frontmcp/ui/react/Alert
41
- */
42
- import type { ReactNode, ReactElement } from 'react';
43
- import { type AlertVariant } from '../styles/variants';
44
- /**
45
- * Alert component props
46
- */
47
- export interface AlertProps {
48
- /** Alert variant */
49
- variant?: AlertVariant;
50
- /** Alert title */
51
- title?: string;
52
- /** Custom icon (React element) */
53
- icon?: ReactNode;
54
- /** Show default icon based on variant */
55
- showIcon?: boolean;
56
- /** Dismissible alert */
57
- dismissible?: boolean;
58
- /** Dismiss callback */
59
- onDismiss?: () => void;
60
- /** Additional CSS classes */
61
- className?: string;
62
- /** Alert content */
63
- children?: ReactNode;
64
- }
65
- /**
66
- * Alert component.
67
- *
68
- * A notification component for displaying important messages.
69
- * Uses Tailwind CSS classes for styling.
70
- */
71
- export declare function Alert({ variant, title, icon, showIcon, dismissible, onDismiss, className, children, }: AlertProps): ReactElement;
72
- /**
73
- * Props for static render functions (children is always a string)
74
- */
75
- export interface AlertRenderProps extends Omit<AlertProps, 'children' | 'icon' | 'onDismiss'> {
76
- /** Alert content as string */
77
- children?: string;
78
- /** Icon as HTML string */
79
- icon?: string;
80
- }
81
- /**
82
- * Render Alert component to static HTML string (async).
83
- *
84
- * Uses React 19's prerender API for optimal static HTML generation.
85
- *
86
- * @param props - Alert props (with string children)
87
- * @returns Promise resolving to HTML string
88
- */
89
- export declare function renderAlert(props: AlertRenderProps): Promise<string>;
90
- /**
91
- * Render Alert component to static HTML string (sync).
92
- *
93
- * Uses React's renderToStaticMarkup for synchronous rendering.
94
- * Does NOT wait for Suspense boundaries.
95
- *
96
- * @param props - Alert props (with string children)
97
- * @returns HTML string
98
- */
99
- export declare function renderAlertSync(props: AlertRenderProps): string;
100
- export type { AlertVariant };
101
- export default Alert;
@@ -1,51 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Alert = Alert;
4
- exports.renderAlert = renderAlert;
5
- exports.renderAlertSync = renderAlertSync;
6
- const jsx_runtime_1 = require("react/jsx-runtime");
7
- const variants_1 = require("../styles/variants");
8
- const prerender_1 = require("../render/prerender");
9
- /**
10
- * Alert component.
11
- *
12
- * A notification component for displaying important messages.
13
- * Uses Tailwind CSS classes for styling.
14
- */
15
- function Alert({ variant = 'info', title, icon, showIcon = true, dismissible = false, onDismiss, className, children, }) {
16
- const variantStyles = (0, variants_1.getAlertVariantClasses)(variant);
17
- const allClasses = (0, variants_1.cn)(variants_1.ALERT_BASE_CLASSES, variantStyles.container, className);
18
- // Use custom icon or default variant icon
19
- const iconContent = icon ||
20
- (showIcon ? ((0, jsx_runtime_1.jsx)("span", { className: (0, variants_1.cn)('flex-shrink-0', variantStyles.icon), dangerouslySetInnerHTML: { __html: variants_1.ALERT_ICONS[variant] } })) : null);
21
- return ((0, jsx_runtime_1.jsx)("div", { className: allClasses, role: "alert", children: (0, jsx_runtime_1.jsxs)("div", { className: "flex", children: [iconContent && (0, jsx_runtime_1.jsx)("div", { className: "flex-shrink-0 mr-3", children: iconContent }), (0, jsx_runtime_1.jsxs)("div", { className: "flex-1", children: [title && (0, jsx_runtime_1.jsx)("h4", { className: "font-semibold mb-1", children: title }), (0, jsx_runtime_1.jsx)("div", { className: "text-sm", children: children })] }), dismissible && ((0, jsx_runtime_1.jsx)("button", { type: "button", className: "flex-shrink-0 ml-3 hover:opacity-70 transition-opacity", "aria-label": "Dismiss", onClick: onDismiss, children: (0, jsx_runtime_1.jsx)("span", { dangerouslySetInnerHTML: { __html: variants_1.CLOSE_ICON } }) }))] }) }));
22
- }
23
- /**
24
- * Render Alert component to static HTML string (async).
25
- *
26
- * Uses React 19's prerender API for optimal static HTML generation.
27
- *
28
- * @param props - Alert props (with string children)
29
- * @returns Promise resolving to HTML string
30
- */
31
- async function renderAlert(props) {
32
- const { children, icon, ...rest } = props;
33
- const element = ((0, jsx_runtime_1.jsx)(Alert, { ...rest, icon: icon ? (0, jsx_runtime_1.jsx)("span", { dangerouslySetInnerHTML: { __html: icon } }) : undefined, children: children }));
34
- return (0, prerender_1.renderToString)(element);
35
- }
36
- /**
37
- * Render Alert component to static HTML string (sync).
38
- *
39
- * Uses React's renderToStaticMarkup for synchronous rendering.
40
- * Does NOT wait for Suspense boundaries.
41
- *
42
- * @param props - Alert props (with string children)
43
- * @returns HTML string
44
- */
45
- function renderAlertSync(props) {
46
- const { children, icon, ...rest } = props;
47
- const element = ((0, jsx_runtime_1.jsx)(Alert, { ...rest, icon: icon ? (0, jsx_runtime_1.jsx)("span", { dangerouslySetInnerHTML: { __html: icon } }) : undefined, children: children }));
48
- return (0, prerender_1.renderToStringSync)(element);
49
- }
50
- exports.default = Alert;
51
- //# sourceMappingURL=Alert.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Alert.js","sourceRoot":"","sources":["../../../src/react/Alert.tsx"],"names":[],"mappings":";;AAkFA,sBA6CC;AAoBD,kCAQC;AAWD,0CAQC;;AAlID,iDAO4B;AAC5B,mDAAyE;AAwBzE;;;;;GAKG;AACH,SAAgB,KAAK,CAAC,EACpB,OAAO,GAAG,MAAM,EAChB,KAAK,EACL,IAAI,EACJ,QAAQ,GAAG,IAAI,EACf,WAAW,GAAG,KAAK,EACnB,SAAS,EACT,SAAS,EACT,QAAQ,GACG;IACX,MAAM,aAAa,GAAG,IAAA,iCAAsB,EAAC,OAAO,CAAC,CAAC;IAEtD,MAAM,UAAU,GAAG,IAAA,aAAE,EAAC,6BAAkB,EAAE,aAAa,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;IAE9E,0CAA0C;IAC1C,MAAM,WAAW,GACf,IAAI;QACJ,CAAC,QAAQ,CAAC,CAAC,CAAC,CACV,iCACE,SAAS,EAAE,IAAA,aAAE,EAAC,eAAe,EAAE,aAAa,CAAC,IAAI,CAAC,EAClD,uBAAuB,EAAE,EAAE,MAAM,EAAE,sBAAW,CAAC,OAAO,CAAC,EAAE,GACzD,CACH,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IAEZ,OAAO,CACL,gCAAK,SAAS,EAAE,UAAU,EAAE,IAAI,EAAC,OAAO,YACtC,iCAAK,SAAS,EAAC,MAAM,aAClB,WAAW,IAAI,gCAAK,SAAS,EAAC,oBAAoB,YAAE,WAAW,GAAO,EACvE,iCAAK,SAAS,EAAC,QAAQ,aACpB,KAAK,IAAI,+BAAI,SAAS,EAAC,oBAAoB,YAAE,KAAK,GAAM,EACzD,gCAAK,SAAS,EAAC,SAAS,YAAE,QAAQ,GAAO,IACrC,EACL,WAAW,IAAI,CACd,mCACE,IAAI,EAAC,QAAQ,EACb,SAAS,EAAC,wDAAwD,gBACvD,SAAS,EACpB,OAAO,EAAE,SAAS,YAElB,iCAAM,uBAAuB,EAAE,EAAE,MAAM,EAAE,qBAAU,EAAE,GAAI,GAClD,CACV,IACG,GACF,CACP,CAAC;AACJ,CAAC;AAYD;;;;;;;GAOG;AACI,KAAK,UAAU,WAAW,CAAC,KAAuB;IACvD,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,KAAK,CAAC;IAC1C,MAAM,OAAO,GAAG,CACd,uBAAC,KAAK,OAAK,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,iCAAM,uBAAuB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,GAAI,CAAC,CAAC,CAAC,SAAS,YAC1F,QAAQ,GACH,CACT,CAAC;IACF,OAAO,IAAA,0BAAc,EAAC,OAAO,CAAC,CAAC;AACjC,CAAC;AAED;;;;;;;;GAQG;AACH,SAAgB,eAAe,CAAC,KAAuB;IACrD,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,KAAK,CAAC;IAC1C,MAAM,OAAO,GAAG,CACd,uBAAC,KAAK,OAAK,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,iCAAM,uBAAuB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,GAAI,CAAC,CAAC,CAAC,SAAS,YAC1F,QAAQ,GACH,CACT,CAAC;IACF,OAAO,IAAA,8BAAkB,EAAC,OAAO,CAAC,CAAC;AACrC,CAAC;AAKD,kBAAe,KAAK,CAAC","sourcesContent":["/**\n * @file Alert.tsx\n * @description React Alert component with static HTML rendering support.\n *\n * This is the single source of truth for the Alert component. It can be used:\n * 1. As a React component: `<Alert variant=\"success\" title=\"Success!\">Message</Alert>`\n * 2. As a static HTML generator: `await renderAlert({ variant: 'success', children: 'Message' })`\n *\n * @example React usage\n * ```tsx\n * import { Alert } from '@frontmcp/ui/react';\n *\n * function App() {\n * return (\n * <Alert variant=\"success\" title=\"Success!\">\n * Your changes have been saved.\n * </Alert>\n * );\n * }\n * ```\n *\n * @example Dismissible alert\n * ```tsx\n * <Alert variant=\"warning\" dismissible onDismiss={() => setShow(false)}>\n * This action cannot be undone.\n * </Alert>\n * ```\n *\n * @example Static HTML generation\n * ```typescript\n * import { renderAlert } from '@frontmcp/ui/react';\n *\n * const html = await renderAlert({\n * variant: 'info',\n * title: 'Note',\n * children: 'Please review before submitting.',\n * });\n * ```\n *\n * @module @frontmcp/ui/react/Alert\n */\n\nimport React from 'react';\nimport type { ReactNode, ReactElement } from 'react';\nimport {\n type AlertVariant,\n getAlertVariantClasses,\n ALERT_BASE_CLASSES,\n ALERT_ICONS,\n CLOSE_ICON,\n cn,\n} from '../styles/variants';\nimport { renderToString, renderToStringSync } from '../render/prerender';\n\n/**\n * Alert component props\n */\nexport interface AlertProps {\n /** Alert variant */\n variant?: AlertVariant;\n /** Alert title */\n title?: string;\n /** Custom icon (React element) */\n icon?: ReactNode;\n /** Show default icon based on variant */\n showIcon?: boolean;\n /** Dismissible alert */\n dismissible?: boolean;\n /** Dismiss callback */\n onDismiss?: () => void;\n /** Additional CSS classes */\n className?: string;\n /** Alert content */\n children?: ReactNode;\n}\n\n/**\n * Alert component.\n *\n * A notification component for displaying important messages.\n * Uses Tailwind CSS classes for styling.\n */\nexport function Alert({\n variant = 'info',\n title,\n icon,\n showIcon = true,\n dismissible = false,\n onDismiss,\n className,\n children,\n}: AlertProps): ReactElement {\n const variantStyles = getAlertVariantClasses(variant);\n\n const allClasses = cn(ALERT_BASE_CLASSES, variantStyles.container, className);\n\n // Use custom icon or default variant icon\n const iconContent =\n icon ||\n (showIcon ? (\n <span\n className={cn('flex-shrink-0', variantStyles.icon)}\n dangerouslySetInnerHTML={{ __html: ALERT_ICONS[variant] }}\n />\n ) : null);\n\n return (\n <div className={allClasses} role=\"alert\">\n <div className=\"flex\">\n {iconContent && <div className=\"flex-shrink-0 mr-3\">{iconContent}</div>}\n <div className=\"flex-1\">\n {title && <h4 className=\"font-semibold mb-1\">{title}</h4>}\n <div className=\"text-sm\">{children}</div>\n </div>\n {dismissible && (\n <button\n type=\"button\"\n className=\"flex-shrink-0 ml-3 hover:opacity-70 transition-opacity\"\n aria-label=\"Dismiss\"\n onClick={onDismiss}\n >\n <span dangerouslySetInnerHTML={{ __html: CLOSE_ICON }} />\n </button>\n )}\n </div>\n </div>\n );\n}\n\n/**\n * Props for static render functions (children is always a string)\n */\nexport interface AlertRenderProps extends Omit<AlertProps, 'children' | 'icon' | 'onDismiss'> {\n /** Alert content as string */\n children?: string;\n /** Icon as HTML string */\n icon?: string;\n}\n\n/**\n * Render Alert component to static HTML string (async).\n *\n * Uses React 19's prerender API for optimal static HTML generation.\n *\n * @param props - Alert props (with string children)\n * @returns Promise resolving to HTML string\n */\nexport async function renderAlert(props: AlertRenderProps): Promise<string> {\n const { children, icon, ...rest } = props;\n const element = (\n <Alert {...rest} icon={icon ? <span dangerouslySetInnerHTML={{ __html: icon }} /> : undefined}>\n {children}\n </Alert>\n );\n return renderToString(element);\n}\n\n/**\n * Render Alert component to static HTML string (sync).\n *\n * Uses React's renderToStaticMarkup for synchronous rendering.\n * Does NOT wait for Suspense boundaries.\n *\n * @param props - Alert props (with string children)\n * @returns HTML string\n */\nexport function renderAlertSync(props: AlertRenderProps): string {\n const { children, icon, ...rest } = props;\n const element = (\n <Alert {...rest} icon={icon ? <span dangerouslySetInnerHTML={{ __html: icon }} /> : undefined}>\n {children}\n </Alert>\n );\n return renderToStringSync(element);\n}\n\n// Re-export types\nexport type { AlertVariant };\n\nexport default Alert;\n"]}
@@ -1,100 +0,0 @@
1
- /**
2
- * @file Badge.tsx
3
- * @description React Badge component with static HTML rendering support.
4
- *
5
- * This is the single source of truth for the Badge component. It can be used:
6
- * 1. As a React component: `<Badge variant="success">Active</Badge>`
7
- * 2. As a static HTML generator: `await renderBadge({ variant: 'success', children: 'Active' })`
8
- *
9
- * @example React usage
10
- * ```tsx
11
- * import { Badge } from '@frontmcp/ui/react';
12
- *
13
- * function App() {
14
- * return (
15
- * <Badge variant="success">Active</Badge>
16
- * );
17
- * }
18
- * ```
19
- *
20
- * @example Pill badge
21
- * ```tsx
22
- * <Badge variant="info" pill>
23
- * New Feature
24
- * </Badge>
25
- * ```
26
- *
27
- * @example Static HTML generation
28
- * ```typescript
29
- * import { renderBadge } from '@frontmcp/ui/react';
30
- *
31
- * const html = await renderBadge({
32
- * variant: 'success',
33
- * children: 'Active',
34
- * });
35
- * ```
36
- *
37
- * @module @frontmcp/ui/react/Badge
38
- */
39
- import type { ReactNode, ReactElement } from 'react';
40
- import { type BadgeVariant, type BadgeSize } from '../styles/variants';
41
- /**
42
- * Badge component props
43
- */
44
- export interface BadgeProps {
45
- /** Badge variant */
46
- variant?: BadgeVariant;
47
- /** Badge size */
48
- size?: BadgeSize;
49
- /** Rounded pill style */
50
- pill?: boolean;
51
- /** Icon before text (React element) */
52
- icon?: ReactNode;
53
- /** Dot indicator (no text) */
54
- dot?: boolean;
55
- /** Additional CSS classes */
56
- className?: string;
57
- /** Removable badge */
58
- removable?: boolean;
59
- /** Remove callback */
60
- onRemove?: () => void;
61
- /** Badge content */
62
- children?: ReactNode;
63
- }
64
- /**
65
- * Badge component.
66
- *
67
- * A small status indicator or label component.
68
- * Uses Tailwind CSS classes for styling.
69
- */
70
- export declare function Badge({ variant, size, pill, icon, dot, className, removable, onRemove, children, }: BadgeProps): ReactElement;
71
- /**
72
- * Props for static render functions (children is always a string)
73
- */
74
- export interface BadgeRenderProps extends Omit<BadgeProps, 'children' | 'icon' | 'onRemove'> {
75
- /** Badge content as string */
76
- children?: string;
77
- /** Icon as HTML string */
78
- icon?: string;
79
- }
80
- /**
81
- * Render Badge component to static HTML string (async).
82
- *
83
- * Uses React 19's prerender API for optimal static HTML generation.
84
- *
85
- * @param props - Badge props (with string children)
86
- * @returns Promise resolving to HTML string
87
- */
88
- export declare function renderBadge(props: BadgeRenderProps): Promise<string>;
89
- /**
90
- * Render Badge component to static HTML string (sync).
91
- *
92
- * Uses React's renderToStaticMarkup for synchronous rendering.
93
- * Does NOT wait for Suspense boundaries.
94
- *
95
- * @param props - Badge props (with string children)
96
- * @returns HTML string
97
- */
98
- export declare function renderBadgeSync(props: BadgeRenderProps): string;
99
- export type { BadgeVariant, BadgeSize };
100
- export default Badge;
@@ -1,55 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Badge = Badge;
4
- exports.renderBadge = renderBadge;
5
- exports.renderBadgeSync = renderBadgeSync;
6
- const jsx_runtime_1 = require("react/jsx-runtime");
7
- const variants_1 = require("../styles/variants");
8
- const prerender_1 = require("../render/prerender");
9
- /**
10
- * Badge component.
11
- *
12
- * A small status indicator or label component.
13
- * Uses Tailwind CSS classes for styling.
14
- */
15
- function Badge({ variant = 'default', size = 'md', pill = false, icon, dot = false, className, removable = false, onRemove, children, }) {
16
- // Handle dot badge (status indicator)
17
- if (dot) {
18
- const dotClasses = (0, variants_1.cn)('inline-block rounded-full', (0, variants_1.getBadgeDotSizeClasses)(size), (0, variants_1.getBadgeDotVariantClasses)(variant), className);
19
- const label = typeof children === 'string' ? children : undefined;
20
- return (0, jsx_runtime_1.jsx)("span", { className: dotClasses, "aria-label": label, title: label });
21
- }
22
- const variantClasses = (0, variants_1.getBadgeVariantClasses)(variant);
23
- const sizeClasses = (0, variants_1.getBadgeSizeClasses)(size);
24
- const baseClasses = (0, variants_1.cn)('inline-flex items-center font-medium', pill ? 'rounded-full' : 'rounded-md', variantClasses, sizeClasses, className);
25
- return ((0, jsx_runtime_1.jsxs)("span", { className: baseClasses, children: [icon && (0, jsx_runtime_1.jsx)("span", { className: "mr-1", children: icon }), children, removable && ((0, jsx_runtime_1.jsx)("button", { type: "button", className: "ml-1.5 -mr-1 hover:opacity-70 transition-opacity", "aria-label": "Remove", onClick: onRemove, children: (0, jsx_runtime_1.jsx)("svg", { className: "w-3 h-3", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: (0, jsx_runtime_1.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: "2", d: "M6 18L18 6M6 6l12 12" }) }) }))] }));
26
- }
27
- /**
28
- * Render Badge component to static HTML string (async).
29
- *
30
- * Uses React 19's prerender API for optimal static HTML generation.
31
- *
32
- * @param props - Badge props (with string children)
33
- * @returns Promise resolving to HTML string
34
- */
35
- async function renderBadge(props) {
36
- const { children, icon, ...rest } = props;
37
- const element = ((0, jsx_runtime_1.jsx)(Badge, { ...rest, icon: icon ? (0, jsx_runtime_1.jsx)("span", { dangerouslySetInnerHTML: { __html: icon } }) : undefined, children: children }));
38
- return (0, prerender_1.renderToString)(element);
39
- }
40
- /**
41
- * Render Badge component to static HTML string (sync).
42
- *
43
- * Uses React's renderToStaticMarkup for synchronous rendering.
44
- * Does NOT wait for Suspense boundaries.
45
- *
46
- * @param props - Badge props (with string children)
47
- * @returns HTML string
48
- */
49
- function renderBadgeSync(props) {
50
- const { children, icon, ...rest } = props;
51
- const element = ((0, jsx_runtime_1.jsx)(Badge, { ...rest, icon: icon ? (0, jsx_runtime_1.jsx)("span", { dangerouslySetInnerHTML: { __html: icon } }) : undefined, children: children }));
52
- return (0, prerender_1.renderToStringSync)(element);
53
- }
54
- exports.default = Badge;
55
- //# sourceMappingURL=Badge.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Badge.js","sourceRoot":"","sources":["../../../src/react/Badge.tsx"],"names":[],"mappings":";;AAmFA,sBAsDC;AAoBD,kCAQC;AAWD,0CAQC;;AA/ID,iDAS4B;AAC5B,mDAAyE;AA0BzE;;;;;GAKG;AACH,SAAgB,KAAK,CAAC,EACpB,OAAO,GAAG,SAAS,EACnB,IAAI,GAAG,IAAI,EACX,IAAI,GAAG,KAAK,EACZ,IAAI,EACJ,GAAG,GAAG,KAAK,EACX,SAAS,EACT,SAAS,GAAG,KAAK,EACjB,QAAQ,EACR,QAAQ,GACG;IACX,sCAAsC;IACtC,IAAI,GAAG,EAAE,CAAC;QACR,MAAM,UAAU,GAAG,IAAA,aAAE,EACnB,2BAA2B,EAC3B,IAAA,iCAAsB,EAAC,IAAI,CAAC,EAC5B,IAAA,oCAAyB,EAAC,OAAO,CAAC,EAClC,SAAS,CACV,CAAC;QAEF,MAAM,KAAK,GAAG,OAAO,QAAQ,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC;QAElE,OAAO,iCAAM,SAAS,EAAE,UAAU,gBAAc,KAAK,EAAE,KAAK,EAAE,KAAK,GAAI,CAAC;IAC1E,CAAC;IAED,MAAM,cAAc,GAAG,IAAA,iCAAsB,EAAC,OAAO,CAAC,CAAC;IACvD,MAAM,WAAW,GAAG,IAAA,8BAAmB,EAAC,IAAI,CAAC,CAAC;IAE9C,MAAM,WAAW,GAAG,IAAA,aAAE,EACpB,sCAAsC,EACtC,IAAI,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,YAAY,EACpC,cAAc,EACd,WAAW,EACX,SAAS,CACV,CAAC;IAEF,OAAO,CACL,kCAAM,SAAS,EAAE,WAAW,aACzB,IAAI,IAAI,iCAAM,SAAS,EAAC,MAAM,YAAE,IAAI,GAAQ,EAC5C,QAAQ,EACR,SAAS,IAAI,CACZ,mCACE,IAAI,EAAC,QAAQ,EACb,SAAS,EAAC,kDAAkD,gBACjD,QAAQ,EACnB,OAAO,EAAE,QAAQ,YAEjB,gCAAK,SAAS,EAAC,SAAS,EAAC,IAAI,EAAC,MAAM,EAAC,MAAM,EAAC,cAAc,EAAC,OAAO,EAAC,WAAW,YAC5E,iCAAM,aAAa,EAAC,OAAO,EAAC,cAAc,EAAC,OAAO,EAAC,WAAW,EAAC,GAAG,EAAC,CAAC,EAAC,sBAAsB,GAAG,GAC1F,GACC,CACV,IACI,CACR,CAAC;AACJ,CAAC;AAYD;;;;;;;GAOG;AACI,KAAK,UAAU,WAAW,CAAC,KAAuB;IACvD,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,KAAK,CAAC;IAC1C,MAAM,OAAO,GAAG,CACd,uBAAC,KAAK,OAAK,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,iCAAM,uBAAuB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,GAAI,CAAC,CAAC,CAAC,SAAS,YAC1F,QAAQ,GACH,CACT,CAAC;IACF,OAAO,IAAA,0BAAc,EAAC,OAAO,CAAC,CAAC;AACjC,CAAC;AAED;;;;;;;;GAQG;AACH,SAAgB,eAAe,CAAC,KAAuB;IACrD,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,KAAK,CAAC;IAC1C,MAAM,OAAO,GAAG,CACd,uBAAC,KAAK,OAAK,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,iCAAM,uBAAuB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,GAAI,CAAC,CAAC,CAAC,SAAS,YAC1F,QAAQ,GACH,CACT,CAAC;IACF,OAAO,IAAA,8BAAkB,EAAC,OAAO,CAAC,CAAC;AACrC,CAAC;AAKD,kBAAe,KAAK,CAAC","sourcesContent":["/**\n * @file Badge.tsx\n * @description React Badge component with static HTML rendering support.\n *\n * This is the single source of truth for the Badge component. It can be used:\n * 1. As a React component: `<Badge variant=\"success\">Active</Badge>`\n * 2. As a static HTML generator: `await renderBadge({ variant: 'success', children: 'Active' })`\n *\n * @example React usage\n * ```tsx\n * import { Badge } from '@frontmcp/ui/react';\n *\n * function App() {\n * return (\n * <Badge variant=\"success\">Active</Badge>\n * );\n * }\n * ```\n *\n * @example Pill badge\n * ```tsx\n * <Badge variant=\"info\" pill>\n * New Feature\n * </Badge>\n * ```\n *\n * @example Static HTML generation\n * ```typescript\n * import { renderBadge } from '@frontmcp/ui/react';\n *\n * const html = await renderBadge({\n * variant: 'success',\n * children: 'Active',\n * });\n * ```\n *\n * @module @frontmcp/ui/react/Badge\n */\n\nimport React from 'react';\nimport type { ReactNode, ReactElement } from 'react';\nimport {\n type BadgeVariant,\n type BadgeSize,\n getBadgeVariantClasses,\n getBadgeSizeClasses,\n getBadgeDotSizeClasses,\n getBadgeDotVariantClasses,\n CLOSE_ICON,\n cn,\n} from '../styles/variants';\nimport { renderToString, renderToStringSync } from '../render/prerender';\n\n/**\n * Badge component props\n */\nexport interface BadgeProps {\n /** Badge variant */\n variant?: BadgeVariant;\n /** Badge size */\n size?: BadgeSize;\n /** Rounded pill style */\n pill?: boolean;\n /** Icon before text (React element) */\n icon?: ReactNode;\n /** Dot indicator (no text) */\n dot?: boolean;\n /** Additional CSS classes */\n className?: string;\n /** Removable badge */\n removable?: boolean;\n /** Remove callback */\n onRemove?: () => void;\n /** Badge content */\n children?: ReactNode;\n}\n\n/**\n * Badge component.\n *\n * A small status indicator or label component.\n * Uses Tailwind CSS classes for styling.\n */\nexport function Badge({\n variant = 'default',\n size = 'md',\n pill = false,\n icon,\n dot = false,\n className,\n removable = false,\n onRemove,\n children,\n}: BadgeProps): ReactElement {\n // Handle dot badge (status indicator)\n if (dot) {\n const dotClasses = cn(\n 'inline-block rounded-full',\n getBadgeDotSizeClasses(size),\n getBadgeDotVariantClasses(variant),\n className,\n );\n\n const label = typeof children === 'string' ? children : undefined;\n\n return <span className={dotClasses} aria-label={label} title={label} />;\n }\n\n const variantClasses = getBadgeVariantClasses(variant);\n const sizeClasses = getBadgeSizeClasses(size);\n\n const baseClasses = cn(\n 'inline-flex items-center font-medium',\n pill ? 'rounded-full' : 'rounded-md',\n variantClasses,\n sizeClasses,\n className,\n );\n\n return (\n <span className={baseClasses}>\n {icon && <span className=\"mr-1\">{icon}</span>}\n {children}\n {removable && (\n <button\n type=\"button\"\n className=\"ml-1.5 -mr-1 hover:opacity-70 transition-opacity\"\n aria-label=\"Remove\"\n onClick={onRemove}\n >\n <svg className=\"w-3 h-3\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth=\"2\" d=\"M6 18L18 6M6 6l12 12\" />\n </svg>\n </button>\n )}\n </span>\n );\n}\n\n/**\n * Props for static render functions (children is always a string)\n */\nexport interface BadgeRenderProps extends Omit<BadgeProps, 'children' | 'icon' | 'onRemove'> {\n /** Badge content as string */\n children?: string;\n /** Icon as HTML string */\n icon?: string;\n}\n\n/**\n * Render Badge component to static HTML string (async).\n *\n * Uses React 19's prerender API for optimal static HTML generation.\n *\n * @param props - Badge props (with string children)\n * @returns Promise resolving to HTML string\n */\nexport async function renderBadge(props: BadgeRenderProps): Promise<string> {\n const { children, icon, ...rest } = props;\n const element = (\n <Badge {...rest} icon={icon ? <span dangerouslySetInnerHTML={{ __html: icon }} /> : undefined}>\n {children}\n </Badge>\n );\n return renderToString(element);\n}\n\n/**\n * Render Badge component to static HTML string (sync).\n *\n * Uses React's renderToStaticMarkup for synchronous rendering.\n * Does NOT wait for Suspense boundaries.\n *\n * @param props - Badge props (with string children)\n * @returns HTML string\n */\nexport function renderBadgeSync(props: BadgeRenderProps): string {\n const { children, icon, ...rest } = props;\n const element = (\n <Badge {...rest} icon={icon ? <span dangerouslySetInnerHTML={{ __html: icon }} /> : undefined}>\n {children}\n </Badge>\n );\n return renderToStringSync(element);\n}\n\n// Re-export types\nexport type { BadgeVariant, BadgeSize };\n\nexport default Badge;\n"]}
@@ -1,108 +0,0 @@
1
- /**
2
- * @file Button.tsx
3
- * @description React Button component with static HTML rendering support.
4
- *
5
- * This is the single source of truth for the Button component. It can be used:
6
- * 1. As a React component: `<Button variant="primary">Click Me</Button>`
7
- * 2. As a static HTML generator: `await renderButton({ variant: 'primary', children: 'Click Me' })`
8
- *
9
- * @example React usage
10
- * ```tsx
11
- * import { Button } from '@frontmcp/ui/react';
12
- *
13
- * function App() {
14
- * return (
15
- * <Button variant="primary" onClick={() => alert('Clicked!')}>
16
- * Click Me
17
- * </Button>
18
- * );
19
- * }
20
- * ```
21
- *
22
- * @example With loading state
23
- * ```tsx
24
- * <Button variant="primary" loading>
25
- * Saving...
26
- * </Button>
27
- * ```
28
- *
29
- * @example Static HTML generation
30
- * ```typescript
31
- * import { renderButton } from '@frontmcp/ui/react';
32
- *
33
- * const html = await renderButton({
34
- * variant: 'primary',
35
- * children: 'Submit',
36
- * });
37
- * ```
38
- *
39
- * @module @frontmcp/ui/react/Button
40
- */
41
- import type { ReactNode, ReactElement } from 'react';
42
- import { type ButtonVariant, type ButtonSize } from '../styles/variants';
43
- /**
44
- * Button component props
45
- */
46
- export interface ButtonProps {
47
- /** Button variant */
48
- variant?: ButtonVariant;
49
- /** Button size */
50
- size?: ButtonSize;
51
- /** Disabled state */
52
- disabled?: boolean;
53
- /** Loading state */
54
- loading?: boolean;
55
- /** Full width */
56
- fullWidth?: boolean;
57
- /** Icon position */
58
- iconPosition?: 'left' | 'right';
59
- /** Icon content (React element) */
60
- icon?: ReactNode;
61
- /** Icon only (no text) */
62
- iconOnly?: boolean;
63
- /** Button type */
64
- type?: 'button' | 'submit' | 'reset';
65
- /** Additional CSS classes */
66
- className?: string;
67
- /** Click handler */
68
- onClick?: () => void;
69
- /** Button content */
70
- children?: ReactNode;
71
- }
72
- /**
73
- * Button component.
74
- *
75
- * A versatile button component with multiple variants, sizes, and states.
76
- * Uses Tailwind CSS classes for styling.
77
- */
78
- export declare function Button({ variant, size, disabled, loading, fullWidth, iconPosition, icon, iconOnly, type, className, onClick, children, }: ButtonProps): ReactElement;
79
- /**
80
- * Props for static render functions (children is always a string)
81
- */
82
- export interface ButtonRenderProps extends Omit<ButtonProps, 'children' | 'icon' | 'onClick'> {
83
- /** Button content as string */
84
- children?: string;
85
- /** Icon as HTML string */
86
- icon?: string;
87
- }
88
- /**
89
- * Render Button component to static HTML string (async).
90
- *
91
- * Uses React 19's prerender API for optimal static HTML generation.
92
- *
93
- * @param props - Button props (with string children)
94
- * @returns Promise resolving to HTML string
95
- */
96
- export declare function renderButton(props: ButtonRenderProps): Promise<string>;
97
- /**
98
- * Render Button component to static HTML string (sync).
99
- *
100
- * Uses React's renderToStaticMarkup for synchronous rendering.
101
- * Does NOT wait for Suspense boundaries.
102
- *
103
- * @param props - Button props (with string children)
104
- * @returns HTML string
105
- */
106
- export declare function renderButtonSync(props: ButtonRenderProps): string;
107
- export type { ButtonVariant, ButtonSize };
108
- export default Button;
@@ -1,52 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Button = Button;
4
- exports.renderButton = renderButton;
5
- exports.renderButtonSync = renderButtonSync;
6
- const jsx_runtime_1 = require("react/jsx-runtime");
7
- const variants_1 = require("../styles/variants");
8
- const prerender_1 = require("../render/prerender");
9
- /**
10
- * Button component.
11
- *
12
- * A versatile button component with multiple variants, sizes, and states.
13
- * Uses Tailwind CSS classes for styling.
14
- */
15
- function Button({ variant = 'primary', size = 'md', disabled = false, loading = false, fullWidth = false, iconPosition = 'left', icon, iconOnly = false, type = 'button', className, onClick, children, }) {
16
- const variantClasses = (0, variants_1.getButtonVariantClasses)(variant);
17
- const sizeClasses = (0, variants_1.getButtonSizeClasses)(size, iconOnly);
18
- const disabledClasses = disabled || loading ? 'opacity-50 cursor-not-allowed' : '';
19
- const widthClasses = fullWidth ? 'w-full' : '';
20
- const allClasses = (0, variants_1.cn)(variants_1.BUTTON_BASE_CLASSES, variantClasses, sizeClasses, disabledClasses, widthClasses, className);
21
- const iconElement = icon && (0, jsx_runtime_1.jsx)("span", { className: iconPosition === 'left' ? 'mr-2' : 'ml-2', children: icon });
22
- return ((0, jsx_runtime_1.jsxs)("button", { type: type, className: allClasses, disabled: disabled || loading, onClick: onClick, children: [loading && (0, jsx_runtime_1.jsx)("span", { className: "mr-2", dangerouslySetInnerHTML: { __html: variants_1.LOADING_SPINNER } }), !loading && icon && iconPosition === 'left' && iconElement, !iconOnly && children, !loading && icon && iconPosition === 'right' && iconElement] }));
23
- }
24
- /**
25
- * Render Button component to static HTML string (async).
26
- *
27
- * Uses React 19's prerender API for optimal static HTML generation.
28
- *
29
- * @param props - Button props (with string children)
30
- * @returns Promise resolving to HTML string
31
- */
32
- async function renderButton(props) {
33
- const { children, icon, ...rest } = props;
34
- const element = ((0, jsx_runtime_1.jsx)(Button, { ...rest, icon: icon ? (0, jsx_runtime_1.jsx)("span", { dangerouslySetInnerHTML: { __html: icon } }) : undefined, children: children }));
35
- return (0, prerender_1.renderToString)(element);
36
- }
37
- /**
38
- * Render Button component to static HTML string (sync).
39
- *
40
- * Uses React's renderToStaticMarkup for synchronous rendering.
41
- * Does NOT wait for Suspense boundaries.
42
- *
43
- * @param props - Button props (with string children)
44
- * @returns HTML string
45
- */
46
- function renderButtonSync(props) {
47
- const { children, icon, ...rest } = props;
48
- const element = ((0, jsx_runtime_1.jsx)(Button, { ...rest, icon: icon ? (0, jsx_runtime_1.jsx)("span", { dangerouslySetInnerHTML: { __html: icon } }) : undefined, children: children }));
49
- return (0, prerender_1.renderToStringSync)(element);
50
- }
51
- exports.default = Button;
52
- //# sourceMappingURL=Button.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Button.js","sourceRoot":"","sources":["../../../src/react/Button.tsx"],"names":[],"mappings":";;AA0FA,wBAgCC;AAoBD,oCAQC;AAWD,4CAQC;;AA9HD,iDAQ4B;AAC5B,mDAAyE;AAgCzE;;;;;GAKG;AACH,SAAgB,MAAM,CAAC,EACrB,OAAO,GAAG,SAAS,EACnB,IAAI,GAAG,IAAI,EACX,QAAQ,GAAG,KAAK,EAChB,OAAO,GAAG,KAAK,EACf,SAAS,GAAG,KAAK,EACjB,YAAY,GAAG,MAAM,EACrB,IAAI,EACJ,QAAQ,GAAG,KAAK,EAChB,IAAI,GAAG,QAAQ,EACf,SAAS,EACT,OAAO,EACP,QAAQ,GACI;IACZ,MAAM,cAAc,GAAG,IAAA,kCAAuB,EAAC,OAAO,CAAC,CAAC;IACxD,MAAM,WAAW,GAAG,IAAA,+BAAoB,EAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;IAEzD,MAAM,eAAe,GAAG,QAAQ,IAAI,OAAO,CAAC,CAAC,CAAC,+BAA+B,CAAC,CAAC,CAAC,EAAE,CAAC;IACnF,MAAM,YAAY,GAAG,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC;IAE/C,MAAM,UAAU,GAAG,IAAA,aAAE,EAAC,8BAAmB,EAAE,cAAc,EAAE,WAAW,EAAE,eAAe,EAAE,YAAY,EAAE,SAAS,CAAC,CAAC;IAElH,MAAM,WAAW,GAAG,IAAI,IAAI,iCAAM,SAAS,EAAE,YAAY,KAAK,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,YAAG,IAAI,GAAQ,CAAC;IAEtG,OAAO,CACL,oCAAQ,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE,QAAQ,IAAI,OAAO,EAAE,OAAO,EAAE,OAAO,aACvF,OAAO,IAAI,iCAAM,SAAS,EAAC,MAAM,EAAC,uBAAuB,EAAE,EAAE,MAAM,EAAE,0BAAe,EAAE,GAAI,EAC1F,CAAC,OAAO,IAAI,IAAI,IAAI,YAAY,KAAK,MAAM,IAAI,WAAW,EAC1D,CAAC,QAAQ,IAAI,QAAQ,EACrB,CAAC,OAAO,IAAI,IAAI,IAAI,YAAY,KAAK,OAAO,IAAI,WAAW,IACrD,CACV,CAAC;AACJ,CAAC;AAYD;;;;;;;GAOG;AACI,KAAK,UAAU,YAAY,CAAC,KAAwB;IACzD,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,KAAK,CAAC;IAC1C,MAAM,OAAO,GAAG,CACd,uBAAC,MAAM,OAAK,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,iCAAM,uBAAuB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,GAAI,CAAC,CAAC,CAAC,SAAS,YAC3F,QAAQ,GACF,CACV,CAAC;IACF,OAAO,IAAA,0BAAc,EAAC,OAAO,CAAC,CAAC;AACjC,CAAC;AAED;;;;;;;;GAQG;AACH,SAAgB,gBAAgB,CAAC,KAAwB;IACvD,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,KAAK,CAAC;IAC1C,MAAM,OAAO,GAAG,CACd,uBAAC,MAAM,OAAK,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,iCAAM,uBAAuB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,GAAI,CAAC,CAAC,CAAC,SAAS,YAC3F,QAAQ,GACF,CACV,CAAC;IACF,OAAO,IAAA,8BAAkB,EAAC,OAAO,CAAC,CAAC;AACrC,CAAC;AAKD,kBAAe,MAAM,CAAC","sourcesContent":["/**\n * @file Button.tsx\n * @description React Button component with static HTML rendering support.\n *\n * This is the single source of truth for the Button component. It can be used:\n * 1. As a React component: `<Button variant=\"primary\">Click Me</Button>`\n * 2. As a static HTML generator: `await renderButton({ variant: 'primary', children: 'Click Me' })`\n *\n * @example React usage\n * ```tsx\n * import { Button } from '@frontmcp/ui/react';\n *\n * function App() {\n * return (\n * <Button variant=\"primary\" onClick={() => alert('Clicked!')}>\n * Click Me\n * </Button>\n * );\n * }\n * ```\n *\n * @example With loading state\n * ```tsx\n * <Button variant=\"primary\" loading>\n * Saving...\n * </Button>\n * ```\n *\n * @example Static HTML generation\n * ```typescript\n * import { renderButton } from '@frontmcp/ui/react';\n *\n * const html = await renderButton({\n * variant: 'primary',\n * children: 'Submit',\n * });\n * ```\n *\n * @module @frontmcp/ui/react/Button\n */\n\nimport React from 'react';\nimport type { ReactNode, ReactElement } from 'react';\nimport {\n type ButtonVariant,\n type ButtonSize,\n getButtonVariantClasses,\n getButtonSizeClasses,\n BUTTON_BASE_CLASSES,\n LOADING_SPINNER,\n cn,\n} from '../styles/variants';\nimport { renderToString, renderToStringSync } from '../render/prerender';\n\n/**\n * Button component props\n */\nexport interface ButtonProps {\n /** Button variant */\n variant?: ButtonVariant;\n /** Button size */\n size?: ButtonSize;\n /** Disabled state */\n disabled?: boolean;\n /** Loading state */\n loading?: boolean;\n /** Full width */\n fullWidth?: boolean;\n /** Icon position */\n iconPosition?: 'left' | 'right';\n /** Icon content (React element) */\n icon?: ReactNode;\n /** Icon only (no text) */\n iconOnly?: boolean;\n /** Button type */\n type?: 'button' | 'submit' | 'reset';\n /** Additional CSS classes */\n className?: string;\n /** Click handler */\n onClick?: () => void;\n /** Button content */\n children?: ReactNode;\n}\n\n/**\n * Button component.\n *\n * A versatile button component with multiple variants, sizes, and states.\n * Uses Tailwind CSS classes for styling.\n */\nexport function Button({\n variant = 'primary',\n size = 'md',\n disabled = false,\n loading = false,\n fullWidth = false,\n iconPosition = 'left',\n icon,\n iconOnly = false,\n type = 'button',\n className,\n onClick,\n children,\n}: ButtonProps): ReactElement {\n const variantClasses = getButtonVariantClasses(variant);\n const sizeClasses = getButtonSizeClasses(size, iconOnly);\n\n const disabledClasses = disabled || loading ? 'opacity-50 cursor-not-allowed' : '';\n const widthClasses = fullWidth ? 'w-full' : '';\n\n const allClasses = cn(BUTTON_BASE_CLASSES, variantClasses, sizeClasses, disabledClasses, widthClasses, className);\n\n const iconElement = icon && <span className={iconPosition === 'left' ? 'mr-2' : 'ml-2'}>{icon}</span>;\n\n return (\n <button type={type} className={allClasses} disabled={disabled || loading} onClick={onClick}>\n {loading && <span className=\"mr-2\" dangerouslySetInnerHTML={{ __html: LOADING_SPINNER }} />}\n {!loading && icon && iconPosition === 'left' && iconElement}\n {!iconOnly && children}\n {!loading && icon && iconPosition === 'right' && iconElement}\n </button>\n );\n}\n\n/**\n * Props for static render functions (children is always a string)\n */\nexport interface ButtonRenderProps extends Omit<ButtonProps, 'children' | 'icon' | 'onClick'> {\n /** Button content as string */\n children?: string;\n /** Icon as HTML string */\n icon?: string;\n}\n\n/**\n * Render Button component to static HTML string (async).\n *\n * Uses React 19's prerender API for optimal static HTML generation.\n *\n * @param props - Button props (with string children)\n * @returns Promise resolving to HTML string\n */\nexport async function renderButton(props: ButtonRenderProps): Promise<string> {\n const { children, icon, ...rest } = props;\n const element = (\n <Button {...rest} icon={icon ? <span dangerouslySetInnerHTML={{ __html: icon }} /> : undefined}>\n {children}\n </Button>\n );\n return renderToString(element);\n}\n\n/**\n * Render Button component to static HTML string (sync).\n *\n * Uses React's renderToStaticMarkup for synchronous rendering.\n * Does NOT wait for Suspense boundaries.\n *\n * @param props - Button props (with string children)\n * @returns HTML string\n */\nexport function renderButtonSync(props: ButtonRenderProps): string {\n const { children, icon, ...rest } = props;\n const element = (\n <Button {...rest} icon={icon ? <span dangerouslySetInnerHTML={{ __html: icon }} /> : undefined}>\n {children}\n </Button>\n );\n return renderToStringSync(element);\n}\n\n// Re-export types\nexport type { ButtonVariant, ButtonSize };\n\nexport default Button;\n"]}