@lssm/lib.design-system 1.11.0 → 1.11.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 (547) hide show
  1. package/dist/components/agent/AgentMonitor.d.ts +3 -4
  2. package/dist/components/agent/AgentMonitor.js +1 -2
  3. package/dist/components/agent/ApprovalQueue.d.ts +3 -4
  4. package/dist/components/agent/ApprovalQueue.js +1 -2
  5. package/dist/components/atoms/ActionButtons.d.ts +10 -11
  6. package/dist/components/atoms/ActionButtons.js +1 -2
  7. package/dist/components/atoms/Button.d.ts +3 -4
  8. package/dist/components/atoms/Button.js +1 -2
  9. package/dist/components/atoms/Button.mobile.d.ts +3 -4
  10. package/dist/components/atoms/Button.mobile.js +1 -2
  11. package/dist/components/atoms/ButtonLink.d.ts +3 -4
  12. package/dist/components/atoms/ButtonLink.js +1 -2
  13. package/dist/components/atoms/ButtonLink.mobile.d.ts +3 -4
  14. package/dist/components/atoms/ButtonLink.mobile.js +1 -2
  15. package/dist/components/atoms/Cta.d.ts +4 -5
  16. package/dist/components/atoms/Cta.js +1 -2
  17. package/dist/components/atoms/Cta.mobile.d.ts +1 -2
  18. package/dist/components/atoms/Cta.mobile.js +1 -2
  19. package/dist/components/atoms/DataChips.d.ts +8 -9
  20. package/dist/components/atoms/DataChips.js +1 -2
  21. package/dist/components/atoms/EmptyState.d.ts +3 -4
  22. package/dist/components/atoms/EmptyState.js +1 -2
  23. package/dist/components/atoms/ErrorState.d.ts +3 -4
  24. package/dist/components/atoms/ErrorState.js +1 -2
  25. package/dist/components/atoms/ErrorState.mobile.d.ts +3 -4
  26. package/dist/components/atoms/ErrorState.mobile.js +1 -2
  27. package/dist/components/atoms/Input.d.ts +3 -4
  28. package/dist/components/atoms/Input.js +1 -2
  29. package/dist/components/atoms/Input.mobile.d.ts +3 -4
  30. package/dist/components/atoms/Input.mobile.js +1 -2
  31. package/dist/components/atoms/Link.d.ts +3 -4
  32. package/dist/components/atoms/Link.js +1 -2
  33. package/dist/components/atoms/Link.web.d.ts +3 -4
  34. package/dist/components/atoms/Link.web.js +1 -2
  35. package/dist/components/atoms/LoaderCircular.d.ts +5 -6
  36. package/dist/components/atoms/LoaderCircular.js +1 -2
  37. package/dist/components/atoms/LoaderCircular.mobile.d.ts +3 -4
  38. package/dist/components/atoms/LoaderCircular.mobile.js +1 -2
  39. package/dist/components/atoms/NavBrand.d.ts +3 -4
  40. package/dist/components/atoms/NavBrand.js +1 -2
  41. package/dist/components/atoms/Stepper.d.ts +3 -4
  42. package/dist/components/atoms/Stepper.js +1 -2
  43. package/dist/components/atoms/Textarea.d.ts +3 -4
  44. package/dist/components/atoms/Textarea.js +1 -2
  45. package/dist/components/atoms/Textarea.mobile.d.ts +3 -4
  46. package/dist/components/atoms/Textarea.mobile.js +1 -2
  47. package/dist/components/data-view/DataViewDetail.d.ts +3 -4
  48. package/dist/components/data-view/DataViewDetail.js +1 -2
  49. package/dist/components/data-view/DataViewList.d.ts +3 -4
  50. package/dist/components/data-view/DataViewList.js +1 -2
  51. package/dist/components/data-view/DataViewRenderer.d.ts +3 -4
  52. package/dist/components/data-view/DataViewRenderer.js +1 -2
  53. package/dist/components/data-view/DataViewTable.d.ts +3 -4
  54. package/dist/components/data-view/DataViewTable.js +1 -2
  55. package/dist/components/data-view/utils.d.ts +1 -2
  56. package/dist/components/data-view/utils.js +1 -2
  57. package/dist/components/forms/FormCardLayout.d.ts +3 -4
  58. package/dist/components/forms/FormCardLayout.js +1 -2
  59. package/dist/components/forms/FormDialog.d.ts +3 -4
  60. package/dist/components/forms/FormDialog.js +1 -2
  61. package/dist/components/forms/FormLayout.d.ts +5 -6
  62. package/dist/components/forms/FormLayout.js +1 -2
  63. package/dist/components/forms/FormOneByOneLayout.d.ts +3 -4
  64. package/dist/components/forms/FormOneByOneLayout.js +1 -2
  65. package/dist/components/forms/FormStepsLayout.d.ts +3 -4
  66. package/dist/components/forms/FormStepsLayout.js +1 -2
  67. package/dist/components/forms/ZodForm.d.ts +3 -4
  68. package/dist/components/forms/ZodForm.js +1 -2
  69. package/dist/components/legal/atoms/DefinitionList.d.ts +3 -4
  70. package/dist/components/legal/atoms/DefinitionList.js +1 -2
  71. package/dist/components/legal/atoms/KeyValueList.d.ts +3 -4
  72. package/dist/components/legal/atoms/KeyValueList.js +1 -2
  73. package/dist/components/legal/atoms/LegalCallout.d.ts +5 -6
  74. package/dist/components/legal/atoms/LegalCallout.js +1 -2
  75. package/dist/components/legal/atoms/LegalHeading.d.ts +5 -6
  76. package/dist/components/legal/atoms/LegalHeading.js +1 -2
  77. package/dist/components/legal/atoms/LegalList.d.ts +5 -6
  78. package/dist/components/legal/atoms/LegalList.js +1 -2
  79. package/dist/components/legal/atoms/LegalSection.d.ts +5 -6
  80. package/dist/components/legal/atoms/LegalSection.js +1 -2
  81. package/dist/components/legal/atoms/LegalText.d.ts +5 -6
  82. package/dist/components/legal/atoms/LegalText.js +1 -2
  83. package/dist/components/legal/molecules/Consent.d.ts +4 -5
  84. package/dist/components/legal/molecules/Consent.js +1 -2
  85. package/dist/components/legal/molecules/ContactFields.d.ts +3 -4
  86. package/dist/components/legal/molecules/ContactFields.js +1 -2
  87. package/dist/components/legal/molecules/LegalMeta.d.ts +3 -4
  88. package/dist/components/legal/molecules/LegalMeta.js +1 -2
  89. package/dist/components/legal/molecules/LegalTOC.d.ts +5 -6
  90. package/dist/components/legal/molecules/LegalTOC.js +1 -2
  91. package/dist/components/legal/organisms/ContactForm.d.ts +3 -4
  92. package/dist/components/legal/organisms/ContactForm.js +1 -2
  93. package/dist/components/legal/organisms/GDPRDataRequest.d.ts +3 -4
  94. package/dist/components/legal/organisms/GDPRDataRequest.js +1 -2
  95. package/dist/components/legal/organisms/GDPRRights.d.ts +3 -4
  96. package/dist/components/legal/organisms/GDPRRights.js +1 -2
  97. package/dist/components/legal/organisms/LegalPageLayout.d.ts +3 -4
  98. package/dist/components/legal/organisms/LegalPageLayout.js +1 -2
  99. package/dist/components/legal/templates/ContactTemplate.d.ts +3 -4
  100. package/dist/components/legal/templates/ContactTemplate.js +1 -2
  101. package/dist/components/legal/templates/CookiesTemplate.d.ts +3 -4
  102. package/dist/components/legal/templates/CookiesTemplate.js +1 -2
  103. package/dist/components/legal/templates/PrivacyTemplate.d.ts +3 -4
  104. package/dist/components/legal/templates/PrivacyTemplate.js +1 -2
  105. package/dist/components/legal/templates/SalesTermsTemplate.d.ts +3 -4
  106. package/dist/components/legal/templates/SalesTermsTemplate.js +1 -2
  107. package/dist/components/legal/templates/TermsTemplate.d.ts +3 -4
  108. package/dist/components/legal/templates/TermsTemplate.js +1 -2
  109. package/dist/components/molecules/AiLinkButton.d.ts +3 -4
  110. package/dist/components/molecules/AiLinkButton.js +1 -2
  111. package/dist/components/molecules/Breadcrumbs.d.ts +1 -2
  112. package/dist/components/molecules/Breadcrumbs.js +1 -2
  113. package/dist/components/molecules/CommandPalette.d.ts +3 -4
  114. package/dist/components/molecules/CommandPalette.js +1 -2
  115. package/dist/components/molecules/CommandSearchTrigger.d.ts +3 -4
  116. package/dist/components/molecules/CommandSearchTrigger.js +1 -2
  117. package/dist/components/molecules/EntityCard.d.ts +6 -7
  118. package/dist/components/molecules/EntityCard.js +1 -2
  119. package/dist/components/molecules/FiltersToolbar.d.ts +3 -4
  120. package/dist/components/molecules/FiltersToolbar.js +1 -2
  121. package/dist/components/molecules/FiltersToolbar.mobile.d.ts +3 -4
  122. package/dist/components/molecules/FiltersToolbar.mobile.js +1 -2
  123. package/dist/components/molecules/HoverPreview.d.ts +3 -4
  124. package/dist/components/molecules/HoverPreview.js +1 -2
  125. package/dist/components/molecules/LangSwitch.d.ts +3 -4
  126. package/dist/components/molecules/LangSwitch.js +1 -2
  127. package/dist/components/molecules/LangSwitchDropdown.d.ts +3 -4
  128. package/dist/components/molecules/LangSwitchDropdown.js +1 -2
  129. package/dist/components/molecules/LoaderBlock.d.ts +3 -4
  130. package/dist/components/molecules/LoaderBlock.js +1 -2
  131. package/dist/components/molecules/LoaderBlock.mobile.d.ts +3 -4
  132. package/dist/components/molecules/LoaderBlock.mobile.js +1 -2
  133. package/dist/components/molecules/MobileNavMenu.d.ts +3 -4
  134. package/dist/components/molecules/MobileNavMenu.js +1 -2
  135. package/dist/components/molecules/NavItemCard.d.ts +3 -4
  136. package/dist/components/molecules/NavItemCard.js +1 -2
  137. package/dist/components/molecules/NavMain.d.ts +3 -4
  138. package/dist/components/molecules/NavMain.js +1 -2
  139. package/dist/components/molecules/NavUser.d.ts +3 -4
  140. package/dist/components/molecules/NavUser.js +1 -2
  141. package/dist/components/molecules/OverviewCard.d.ts +3 -4
  142. package/dist/components/molecules/OverviewCard.js +1 -2
  143. package/dist/components/molecules/SkeletonBlock/index.mobile.d.ts +3 -4
  144. package/dist/components/molecules/SkeletonBlock/index.mobile.js +1 -2
  145. package/dist/components/molecules/SkeletonBlock/index.web.d.ts +3 -4
  146. package/dist/components/molecules/SkeletonBlock/index.web.js +1 -2
  147. package/dist/components/molecules/SkeletonBlock/types.d.ts +1 -2
  148. package/dist/components/molecules/SkeletonCircle/index.mobile.d.ts +3 -4
  149. package/dist/components/molecules/SkeletonCircle/index.mobile.js +1 -2
  150. package/dist/components/molecules/SkeletonCircle/index.web.d.ts +3 -4
  151. package/dist/components/molecules/SkeletonCircle/index.web.js +1 -2
  152. package/dist/components/molecules/SkeletonCircle/types.d.ts +1 -2
  153. package/dist/components/molecules/SkeletonList/index.mobile.d.ts +3 -4
  154. package/dist/components/molecules/SkeletonList/index.mobile.js +1 -2
  155. package/dist/components/molecules/SkeletonList/index.web.d.ts +3 -4
  156. package/dist/components/molecules/SkeletonList/index.web.js +1 -2
  157. package/dist/components/molecules/SkeletonList/types.d.ts +1 -2
  158. package/dist/components/molecules/StatCard.d.ts +7 -8
  159. package/dist/components/molecules/StatCard.js +1 -2
  160. package/dist/components/molecules/StatusChip.d.ts +5 -6
  161. package/dist/components/molecules/StatusChip.js +1 -2
  162. package/dist/components/molecules/hover-previews/Doc.d.ts +3 -4
  163. package/dist/components/molecules/hover-previews/Doc.js +1 -2
  164. package/dist/components/molecules/hover-previews/Media.d.ts +3 -4
  165. package/dist/components/molecules/hover-previews/Media.js +1 -2
  166. package/dist/components/molecules/hover-previews/Simple.d.ts +3 -4
  167. package/dist/components/molecules/hover-previews/Simple.js +1 -2
  168. package/dist/components/molecules/hover-previews/Stats.d.ts +3 -4
  169. package/dist/components/molecules/hover-previews/Stats.js +1 -2
  170. package/dist/components/molecules/hover-previews/User.d.ts +3 -4
  171. package/dist/components/molecules/hover-previews/User.js +1 -2
  172. package/dist/components/native/BottomTabs.mobile.d.ts +3 -4
  173. package/dist/components/native/BottomTabs.mobile.js +1 -2
  174. package/dist/components/native/FlatListScreen.mobile.d.ts +5 -6
  175. package/dist/components/native/FlatListScreen.mobile.js +1 -2
  176. package/dist/components/native/SheetMenu.mobile.d.ts +3 -4
  177. package/dist/components/native/SheetMenu.mobile.js +1 -2
  178. package/dist/components/organisms/AcademyLayout.d.ts +3 -4
  179. package/dist/components/organisms/AcademyLayout.js +1 -2
  180. package/dist/components/organisms/AppHeader.d.ts +3 -4
  181. package/dist/components/organisms/AppHeader.js +1 -2
  182. package/dist/components/organisms/AppHeader.mobile.d.ts +3 -4
  183. package/dist/components/organisms/AppHeader.mobile.js +1 -2
  184. package/dist/components/organisms/AppLayout.d.ts +3 -4
  185. package/dist/components/organisms/AppLayout.js +1 -2
  186. package/dist/components/organisms/AppSidebar.d.ts +3 -4
  187. package/dist/components/organisms/AppSidebar.js +1 -2
  188. package/dist/components/organisms/EmptyDataList.d.ts +3 -4
  189. package/dist/components/organisms/EmptyDataList.js +1 -2
  190. package/dist/components/organisms/EmptyDataList.mobile.d.ts +3 -4
  191. package/dist/components/organisms/EmptyDataList.mobile.js +1 -2
  192. package/dist/components/organisms/EmptyDataList.types.d.ts +1 -2
  193. package/dist/components/organisms/EmptySearchResult.d.ts +3 -4
  194. package/dist/components/organisms/EmptySearchResult.js +1 -2
  195. package/dist/components/organisms/FAQSection.d.ts +3 -4
  196. package/dist/components/organisms/FAQSection.js +1 -2
  197. package/dist/components/organisms/FeatureCarousel.d.ts +3 -4
  198. package/dist/components/organisms/FeatureCarousel.js +1 -2
  199. package/dist/components/organisms/FeaturesSection.d.ts +3 -4
  200. package/dist/components/organisms/FeaturesSection.js +1 -2
  201. package/dist/components/organisms/Footer.d.ts +3 -4
  202. package/dist/components/organisms/Footer.js +1 -2
  203. package/dist/components/organisms/GridLayout.d.ts +5 -6
  204. package/dist/components/organisms/GridLayout.js +1 -2
  205. package/dist/components/organisms/Header.d.ts +5 -6
  206. package/dist/components/organisms/Header.js +1 -2
  207. package/dist/components/organisms/Header.mobile.d.ts +3 -4
  208. package/dist/components/organisms/Header.mobile.js +1 -2
  209. package/dist/components/organisms/HeroResponsive.d.ts +3 -4
  210. package/dist/components/organisms/HeroResponsive.js +1 -2
  211. package/dist/components/organisms/HeroSection.d.ts +3 -4
  212. package/dist/components/organisms/HeroSection.js +1 -2
  213. package/dist/components/organisms/ListCardPage.d.ts +6 -7
  214. package/dist/components/organisms/ListCardPage.js +1 -2
  215. package/dist/components/organisms/ListGridPage.d.ts +6 -7
  216. package/dist/components/organisms/ListGridPage.js +1 -2
  217. package/dist/components/organisms/ListPageResponsive.d.ts +3 -4
  218. package/dist/components/organisms/ListPageResponsive.js +1 -2
  219. package/dist/components/organisms/ListTablePage.d.ts +5 -6
  220. package/dist/components/organisms/ListTablePage.js +1 -2
  221. package/dist/components/organisms/MarketingHeader.d.ts +3 -4
  222. package/dist/components/organisms/MarketingHeader.js +1 -2
  223. package/dist/components/organisms/MarketingHeaderDesktop.d.ts +3 -4
  224. package/dist/components/organisms/MarketingHeaderDesktop.js +1 -2
  225. package/dist/components/organisms/MarketingHeaderMobile.d.ts +3 -4
  226. package/dist/components/organisms/MarketingHeaderMobile.js +1 -2
  227. package/dist/components/organisms/MarketingLayout.d.ts +3 -4
  228. package/dist/components/organisms/MarketingLayout.js +1 -2
  229. package/dist/components/organisms/PageHeaderResponsive.d.ts +3 -4
  230. package/dist/components/organisms/PageHeaderResponsive.js +1 -2
  231. package/dist/components/organisms/PageHeaderResponsive.mobile.d.ts +3 -4
  232. package/dist/components/organisms/PageHeaderResponsive.mobile.js +1 -2
  233. package/dist/components/organisms/PricingCarousel.d.ts +3 -4
  234. package/dist/components/organisms/PricingCarousel.js +1 -2
  235. package/dist/components/organisms/PricingSection.d.ts +3 -4
  236. package/dist/components/organisms/PricingSection.js +1 -2
  237. package/dist/components/organisms/TestimonialCarousel.d.ts +3 -4
  238. package/dist/components/organisms/TestimonialCarousel.js +1 -2
  239. package/dist/components/templates/lists/ListPageTemplate/index.mobile.d.ts +3 -4
  240. package/dist/components/templates/lists/ListPageTemplate/index.mobile.js +1 -2
  241. package/dist/components/templates/lists/ListPageTemplate/index.web.d.ts +3 -4
  242. package/dist/components/templates/lists/ListPageTemplate/index.web.js +1 -2
  243. package/dist/components/templates/lists/ListPageTemplate/types.d.ts +1 -2
  244. package/dist/hooks/useListUrlState.d.ts +1 -2
  245. package/dist/hooks/useListUrlState.js +1 -2
  246. package/dist/index.js +1 -2
  247. package/dist/lib/keyboard.d.ts +1 -2
  248. package/dist/lib/keyboard.js +1 -2
  249. package/dist/lib/utils.d.ts +1 -2
  250. package/dist/lib/utils.js +1 -2
  251. package/dist/platform/useColorScheme.d.ts +1 -2
  252. package/dist/platform/useColorScheme.js +1 -2
  253. package/dist/platform/useColorScheme.mobile.d.ts +1 -2
  254. package/dist/platform/useColorScheme.mobile.js +1 -2
  255. package/dist/platform/useReducedMotion.d.ts +1 -2
  256. package/dist/platform/useReducedMotion.js +1 -2
  257. package/dist/platform/useReducedMotion.mobile.d.ts +1 -2
  258. package/dist/platform/useReducedMotion.mobile.js +1 -2
  259. package/dist/platform/useResponsive.d.ts +1 -2
  260. package/dist/platform/useResponsive.js +1 -2
  261. package/dist/platform/useResponsive.mobile.d.ts +1 -2
  262. package/dist/platform/useResponsive.mobile.js +1 -2
  263. package/dist/platform/withPlatformUI.d.ts +1 -2
  264. package/dist/platform/withPlatformUI.js +1 -2
  265. package/dist/renderers/form-contract.d.ts +3 -4
  266. package/dist/renderers/form-contract.js +1 -2
  267. package/dist/theme/tokenBridge.d.ts +1 -2
  268. package/dist/theme/tokenBridge.js +1 -2
  269. package/dist/theme/tokens.d.ts +1 -2
  270. package/dist/theme/tokens.js +1 -2
  271. package/dist/theme/variants.d.ts +2 -3
  272. package/dist/theme/variants.js +1 -2
  273. package/dist/types/navigation.d.ts +1 -2
  274. package/package.json +7 -7
  275. package/dist/components/agent/AgentMonitor.d.ts.map +0 -1
  276. package/dist/components/agent/AgentMonitor.js.map +0 -1
  277. package/dist/components/agent/ApprovalQueue.d.ts.map +0 -1
  278. package/dist/components/agent/ApprovalQueue.js.map +0 -1
  279. package/dist/components/atoms/ActionButtons.d.ts.map +0 -1
  280. package/dist/components/atoms/ActionButtons.js.map +0 -1
  281. package/dist/components/atoms/Button.d.ts.map +0 -1
  282. package/dist/components/atoms/Button.js.map +0 -1
  283. package/dist/components/atoms/Button.mobile.d.ts.map +0 -1
  284. package/dist/components/atoms/Button.mobile.js.map +0 -1
  285. package/dist/components/atoms/ButtonLink.d.ts.map +0 -1
  286. package/dist/components/atoms/ButtonLink.js.map +0 -1
  287. package/dist/components/atoms/ButtonLink.mobile.d.ts.map +0 -1
  288. package/dist/components/atoms/ButtonLink.mobile.js.map +0 -1
  289. package/dist/components/atoms/Cta.d.ts.map +0 -1
  290. package/dist/components/atoms/Cta.js.map +0 -1
  291. package/dist/components/atoms/Cta.mobile.d.ts.map +0 -1
  292. package/dist/components/atoms/Cta.mobile.js.map +0 -1
  293. package/dist/components/atoms/DataChips.d.ts.map +0 -1
  294. package/dist/components/atoms/DataChips.js.map +0 -1
  295. package/dist/components/atoms/EmptyState.d.ts.map +0 -1
  296. package/dist/components/atoms/EmptyState.js.map +0 -1
  297. package/dist/components/atoms/ErrorState.d.ts.map +0 -1
  298. package/dist/components/atoms/ErrorState.js.map +0 -1
  299. package/dist/components/atoms/ErrorState.mobile.d.ts.map +0 -1
  300. package/dist/components/atoms/ErrorState.mobile.js.map +0 -1
  301. package/dist/components/atoms/Input.d.ts.map +0 -1
  302. package/dist/components/atoms/Input.js.map +0 -1
  303. package/dist/components/atoms/Input.mobile.d.ts.map +0 -1
  304. package/dist/components/atoms/Input.mobile.js.map +0 -1
  305. package/dist/components/atoms/Link.d.ts.map +0 -1
  306. package/dist/components/atoms/Link.js.map +0 -1
  307. package/dist/components/atoms/Link.web.d.ts.map +0 -1
  308. package/dist/components/atoms/Link.web.js.map +0 -1
  309. package/dist/components/atoms/LoaderCircular.d.ts.map +0 -1
  310. package/dist/components/atoms/LoaderCircular.js.map +0 -1
  311. package/dist/components/atoms/LoaderCircular.mobile.d.ts.map +0 -1
  312. package/dist/components/atoms/LoaderCircular.mobile.js.map +0 -1
  313. package/dist/components/atoms/NavBrand.d.ts.map +0 -1
  314. package/dist/components/atoms/NavBrand.js.map +0 -1
  315. package/dist/components/atoms/Stepper.d.ts.map +0 -1
  316. package/dist/components/atoms/Stepper.js.map +0 -1
  317. package/dist/components/atoms/Textarea.d.ts.map +0 -1
  318. package/dist/components/atoms/Textarea.js.map +0 -1
  319. package/dist/components/atoms/Textarea.mobile.d.ts.map +0 -1
  320. package/dist/components/atoms/Textarea.mobile.js.map +0 -1
  321. package/dist/components/data-view/DataViewDetail.d.ts.map +0 -1
  322. package/dist/components/data-view/DataViewDetail.js.map +0 -1
  323. package/dist/components/data-view/DataViewList.d.ts.map +0 -1
  324. package/dist/components/data-view/DataViewList.js.map +0 -1
  325. package/dist/components/data-view/DataViewRenderer.d.ts.map +0 -1
  326. package/dist/components/data-view/DataViewRenderer.js.map +0 -1
  327. package/dist/components/data-view/DataViewTable.d.ts.map +0 -1
  328. package/dist/components/data-view/DataViewTable.js.map +0 -1
  329. package/dist/components/data-view/utils.d.ts.map +0 -1
  330. package/dist/components/data-view/utils.js.map +0 -1
  331. package/dist/components/forms/FormCardLayout.d.ts.map +0 -1
  332. package/dist/components/forms/FormCardLayout.js.map +0 -1
  333. package/dist/components/forms/FormDialog.d.ts.map +0 -1
  334. package/dist/components/forms/FormDialog.js.map +0 -1
  335. package/dist/components/forms/FormLayout.d.ts.map +0 -1
  336. package/dist/components/forms/FormLayout.js.map +0 -1
  337. package/dist/components/forms/FormOneByOneLayout.d.ts.map +0 -1
  338. package/dist/components/forms/FormOneByOneLayout.js.map +0 -1
  339. package/dist/components/forms/FormStepsLayout.d.ts.map +0 -1
  340. package/dist/components/forms/FormStepsLayout.js.map +0 -1
  341. package/dist/components/forms/ZodForm.d.ts.map +0 -1
  342. package/dist/components/forms/ZodForm.js.map +0 -1
  343. package/dist/components/legal/atoms/DefinitionList.d.ts.map +0 -1
  344. package/dist/components/legal/atoms/DefinitionList.js.map +0 -1
  345. package/dist/components/legal/atoms/KeyValueList.d.ts.map +0 -1
  346. package/dist/components/legal/atoms/KeyValueList.js.map +0 -1
  347. package/dist/components/legal/atoms/LegalCallout.d.ts.map +0 -1
  348. package/dist/components/legal/atoms/LegalCallout.js.map +0 -1
  349. package/dist/components/legal/atoms/LegalHeading.d.ts.map +0 -1
  350. package/dist/components/legal/atoms/LegalHeading.js.map +0 -1
  351. package/dist/components/legal/atoms/LegalList.d.ts.map +0 -1
  352. package/dist/components/legal/atoms/LegalList.js.map +0 -1
  353. package/dist/components/legal/atoms/LegalSection.d.ts.map +0 -1
  354. package/dist/components/legal/atoms/LegalSection.js.map +0 -1
  355. package/dist/components/legal/atoms/LegalText.d.ts.map +0 -1
  356. package/dist/components/legal/atoms/LegalText.js.map +0 -1
  357. package/dist/components/legal/molecules/Consent.d.ts.map +0 -1
  358. package/dist/components/legal/molecules/Consent.js.map +0 -1
  359. package/dist/components/legal/molecules/ContactFields.d.ts.map +0 -1
  360. package/dist/components/legal/molecules/ContactFields.js.map +0 -1
  361. package/dist/components/legal/molecules/LegalMeta.d.ts.map +0 -1
  362. package/dist/components/legal/molecules/LegalMeta.js.map +0 -1
  363. package/dist/components/legal/molecules/LegalTOC.d.ts.map +0 -1
  364. package/dist/components/legal/molecules/LegalTOC.js.map +0 -1
  365. package/dist/components/legal/organisms/ContactForm.d.ts.map +0 -1
  366. package/dist/components/legal/organisms/ContactForm.js.map +0 -1
  367. package/dist/components/legal/organisms/GDPRDataRequest.d.ts.map +0 -1
  368. package/dist/components/legal/organisms/GDPRDataRequest.js.map +0 -1
  369. package/dist/components/legal/organisms/GDPRRights.d.ts.map +0 -1
  370. package/dist/components/legal/organisms/GDPRRights.js.map +0 -1
  371. package/dist/components/legal/organisms/LegalPageLayout.d.ts.map +0 -1
  372. package/dist/components/legal/organisms/LegalPageLayout.js.map +0 -1
  373. package/dist/components/legal/templates/ContactTemplate.d.ts.map +0 -1
  374. package/dist/components/legal/templates/ContactTemplate.js.map +0 -1
  375. package/dist/components/legal/templates/CookiesTemplate.d.ts.map +0 -1
  376. package/dist/components/legal/templates/CookiesTemplate.js.map +0 -1
  377. package/dist/components/legal/templates/PrivacyTemplate.d.ts.map +0 -1
  378. package/dist/components/legal/templates/PrivacyTemplate.js.map +0 -1
  379. package/dist/components/legal/templates/SalesTermsTemplate.d.ts.map +0 -1
  380. package/dist/components/legal/templates/SalesTermsTemplate.js.map +0 -1
  381. package/dist/components/legal/templates/TermsTemplate.d.ts.map +0 -1
  382. package/dist/components/legal/templates/TermsTemplate.js.map +0 -1
  383. package/dist/components/molecules/AiLinkButton.d.ts.map +0 -1
  384. package/dist/components/molecules/AiLinkButton.js.map +0 -1
  385. package/dist/components/molecules/Breadcrumbs.d.ts.map +0 -1
  386. package/dist/components/molecules/Breadcrumbs.js.map +0 -1
  387. package/dist/components/molecules/CommandPalette.d.ts.map +0 -1
  388. package/dist/components/molecules/CommandPalette.js.map +0 -1
  389. package/dist/components/molecules/CommandSearchTrigger.d.ts.map +0 -1
  390. package/dist/components/molecules/CommandSearchTrigger.js.map +0 -1
  391. package/dist/components/molecules/EntityCard.d.ts.map +0 -1
  392. package/dist/components/molecules/EntityCard.js.map +0 -1
  393. package/dist/components/molecules/FiltersToolbar.d.ts.map +0 -1
  394. package/dist/components/molecules/FiltersToolbar.js.map +0 -1
  395. package/dist/components/molecules/FiltersToolbar.mobile.d.ts.map +0 -1
  396. package/dist/components/molecules/FiltersToolbar.mobile.js.map +0 -1
  397. package/dist/components/molecules/HoverPreview.d.ts.map +0 -1
  398. package/dist/components/molecules/HoverPreview.js.map +0 -1
  399. package/dist/components/molecules/LangSwitch.d.ts.map +0 -1
  400. package/dist/components/molecules/LangSwitch.js.map +0 -1
  401. package/dist/components/molecules/LangSwitchDropdown.d.ts.map +0 -1
  402. package/dist/components/molecules/LangSwitchDropdown.js.map +0 -1
  403. package/dist/components/molecules/LoaderBlock.d.ts.map +0 -1
  404. package/dist/components/molecules/LoaderBlock.js.map +0 -1
  405. package/dist/components/molecules/LoaderBlock.mobile.d.ts.map +0 -1
  406. package/dist/components/molecules/LoaderBlock.mobile.js.map +0 -1
  407. package/dist/components/molecules/MobileNavMenu.d.ts.map +0 -1
  408. package/dist/components/molecules/MobileNavMenu.js.map +0 -1
  409. package/dist/components/molecules/NavItemCard.d.ts.map +0 -1
  410. package/dist/components/molecules/NavItemCard.js.map +0 -1
  411. package/dist/components/molecules/NavMain.d.ts.map +0 -1
  412. package/dist/components/molecules/NavMain.js.map +0 -1
  413. package/dist/components/molecules/NavUser.d.ts.map +0 -1
  414. package/dist/components/molecules/NavUser.js.map +0 -1
  415. package/dist/components/molecules/OverviewCard.d.ts.map +0 -1
  416. package/dist/components/molecules/OverviewCard.js.map +0 -1
  417. package/dist/components/molecules/SkeletonBlock/index.mobile.d.ts.map +0 -1
  418. package/dist/components/molecules/SkeletonBlock/index.mobile.js.map +0 -1
  419. package/dist/components/molecules/SkeletonBlock/index.web.d.ts.map +0 -1
  420. package/dist/components/molecules/SkeletonBlock/index.web.js.map +0 -1
  421. package/dist/components/molecules/SkeletonBlock/types.d.ts.map +0 -1
  422. package/dist/components/molecules/SkeletonCircle/index.mobile.d.ts.map +0 -1
  423. package/dist/components/molecules/SkeletonCircle/index.mobile.js.map +0 -1
  424. package/dist/components/molecules/SkeletonCircle/index.web.d.ts.map +0 -1
  425. package/dist/components/molecules/SkeletonCircle/index.web.js.map +0 -1
  426. package/dist/components/molecules/SkeletonCircle/types.d.ts.map +0 -1
  427. package/dist/components/molecules/SkeletonList/index.mobile.d.ts.map +0 -1
  428. package/dist/components/molecules/SkeletonList/index.mobile.js.map +0 -1
  429. package/dist/components/molecules/SkeletonList/index.web.d.ts.map +0 -1
  430. package/dist/components/molecules/SkeletonList/index.web.js.map +0 -1
  431. package/dist/components/molecules/SkeletonList/types.d.ts.map +0 -1
  432. package/dist/components/molecules/StatCard.d.ts.map +0 -1
  433. package/dist/components/molecules/StatCard.js.map +0 -1
  434. package/dist/components/molecules/StatusChip.d.ts.map +0 -1
  435. package/dist/components/molecules/StatusChip.js.map +0 -1
  436. package/dist/components/molecules/hover-previews/Doc.d.ts.map +0 -1
  437. package/dist/components/molecules/hover-previews/Doc.js.map +0 -1
  438. package/dist/components/molecules/hover-previews/Media.d.ts.map +0 -1
  439. package/dist/components/molecules/hover-previews/Media.js.map +0 -1
  440. package/dist/components/molecules/hover-previews/Simple.d.ts.map +0 -1
  441. package/dist/components/molecules/hover-previews/Simple.js.map +0 -1
  442. package/dist/components/molecules/hover-previews/Stats.d.ts.map +0 -1
  443. package/dist/components/molecules/hover-previews/Stats.js.map +0 -1
  444. package/dist/components/molecules/hover-previews/User.d.ts.map +0 -1
  445. package/dist/components/molecules/hover-previews/User.js.map +0 -1
  446. package/dist/components/native/BottomTabs.mobile.d.ts.map +0 -1
  447. package/dist/components/native/BottomTabs.mobile.js.map +0 -1
  448. package/dist/components/native/FlatListScreen.mobile.d.ts.map +0 -1
  449. package/dist/components/native/FlatListScreen.mobile.js.map +0 -1
  450. package/dist/components/native/SheetMenu.mobile.d.ts.map +0 -1
  451. package/dist/components/native/SheetMenu.mobile.js.map +0 -1
  452. package/dist/components/organisms/AcademyLayout.d.ts.map +0 -1
  453. package/dist/components/organisms/AcademyLayout.js.map +0 -1
  454. package/dist/components/organisms/AppHeader.d.ts.map +0 -1
  455. package/dist/components/organisms/AppHeader.js.map +0 -1
  456. package/dist/components/organisms/AppHeader.mobile.d.ts.map +0 -1
  457. package/dist/components/organisms/AppHeader.mobile.js.map +0 -1
  458. package/dist/components/organisms/AppLayout.d.ts.map +0 -1
  459. package/dist/components/organisms/AppLayout.js.map +0 -1
  460. package/dist/components/organisms/AppSidebar.d.ts.map +0 -1
  461. package/dist/components/organisms/AppSidebar.js.map +0 -1
  462. package/dist/components/organisms/EmptyDataList.d.ts.map +0 -1
  463. package/dist/components/organisms/EmptyDataList.js.map +0 -1
  464. package/dist/components/organisms/EmptyDataList.mobile.d.ts.map +0 -1
  465. package/dist/components/organisms/EmptyDataList.mobile.js.map +0 -1
  466. package/dist/components/organisms/EmptyDataList.types.d.ts.map +0 -1
  467. package/dist/components/organisms/EmptySearchResult.d.ts.map +0 -1
  468. package/dist/components/organisms/EmptySearchResult.js.map +0 -1
  469. package/dist/components/organisms/FAQSection.d.ts.map +0 -1
  470. package/dist/components/organisms/FAQSection.js.map +0 -1
  471. package/dist/components/organisms/FeatureCarousel.d.ts.map +0 -1
  472. package/dist/components/organisms/FeatureCarousel.js.map +0 -1
  473. package/dist/components/organisms/FeaturesSection.d.ts.map +0 -1
  474. package/dist/components/organisms/FeaturesSection.js.map +0 -1
  475. package/dist/components/organisms/Footer.d.ts.map +0 -1
  476. package/dist/components/organisms/Footer.js.map +0 -1
  477. package/dist/components/organisms/GridLayout.d.ts.map +0 -1
  478. package/dist/components/organisms/GridLayout.js.map +0 -1
  479. package/dist/components/organisms/Header.d.ts.map +0 -1
  480. package/dist/components/organisms/Header.js.map +0 -1
  481. package/dist/components/organisms/Header.mobile.d.ts.map +0 -1
  482. package/dist/components/organisms/Header.mobile.js.map +0 -1
  483. package/dist/components/organisms/HeroResponsive.d.ts.map +0 -1
  484. package/dist/components/organisms/HeroResponsive.js.map +0 -1
  485. package/dist/components/organisms/HeroSection.d.ts.map +0 -1
  486. package/dist/components/organisms/HeroSection.js.map +0 -1
  487. package/dist/components/organisms/ListCardPage.d.ts.map +0 -1
  488. package/dist/components/organisms/ListCardPage.js.map +0 -1
  489. package/dist/components/organisms/ListGridPage.d.ts.map +0 -1
  490. package/dist/components/organisms/ListGridPage.js.map +0 -1
  491. package/dist/components/organisms/ListPageResponsive.d.ts.map +0 -1
  492. package/dist/components/organisms/ListPageResponsive.js.map +0 -1
  493. package/dist/components/organisms/ListTablePage.d.ts.map +0 -1
  494. package/dist/components/organisms/ListTablePage.js.map +0 -1
  495. package/dist/components/organisms/MarketingHeader.d.ts.map +0 -1
  496. package/dist/components/organisms/MarketingHeader.js.map +0 -1
  497. package/dist/components/organisms/MarketingHeaderDesktop.d.ts.map +0 -1
  498. package/dist/components/organisms/MarketingHeaderDesktop.js.map +0 -1
  499. package/dist/components/organisms/MarketingHeaderMobile.d.ts.map +0 -1
  500. package/dist/components/organisms/MarketingHeaderMobile.js.map +0 -1
  501. package/dist/components/organisms/MarketingLayout.d.ts.map +0 -1
  502. package/dist/components/organisms/MarketingLayout.js.map +0 -1
  503. package/dist/components/organisms/PageHeaderResponsive.d.ts.map +0 -1
  504. package/dist/components/organisms/PageHeaderResponsive.js.map +0 -1
  505. package/dist/components/organisms/PageHeaderResponsive.mobile.d.ts.map +0 -1
  506. package/dist/components/organisms/PageHeaderResponsive.mobile.js.map +0 -1
  507. package/dist/components/organisms/PricingCarousel.d.ts.map +0 -1
  508. package/dist/components/organisms/PricingCarousel.js.map +0 -1
  509. package/dist/components/organisms/PricingSection.d.ts.map +0 -1
  510. package/dist/components/organisms/PricingSection.js.map +0 -1
  511. package/dist/components/organisms/TestimonialCarousel.d.ts.map +0 -1
  512. package/dist/components/organisms/TestimonialCarousel.js.map +0 -1
  513. package/dist/components/templates/lists/ListPageTemplate/index.mobile.d.ts.map +0 -1
  514. package/dist/components/templates/lists/ListPageTemplate/index.mobile.js.map +0 -1
  515. package/dist/components/templates/lists/ListPageTemplate/index.web.d.ts.map +0 -1
  516. package/dist/components/templates/lists/ListPageTemplate/index.web.js.map +0 -1
  517. package/dist/components/templates/lists/ListPageTemplate/types.d.ts.map +0 -1
  518. package/dist/hooks/useListUrlState.d.ts.map +0 -1
  519. package/dist/hooks/useListUrlState.js.map +0 -1
  520. package/dist/index.js.map +0 -1
  521. package/dist/lib/keyboard.d.ts.map +0 -1
  522. package/dist/lib/keyboard.js.map +0 -1
  523. package/dist/lib/utils.d.ts.map +0 -1
  524. package/dist/lib/utils.js.map +0 -1
  525. package/dist/platform/useColorScheme.d.ts.map +0 -1
  526. package/dist/platform/useColorScheme.js.map +0 -1
  527. package/dist/platform/useColorScheme.mobile.d.ts.map +0 -1
  528. package/dist/platform/useColorScheme.mobile.js.map +0 -1
  529. package/dist/platform/useReducedMotion.d.ts.map +0 -1
  530. package/dist/platform/useReducedMotion.js.map +0 -1
  531. package/dist/platform/useReducedMotion.mobile.d.ts.map +0 -1
  532. package/dist/platform/useReducedMotion.mobile.js.map +0 -1
  533. package/dist/platform/useResponsive.d.ts.map +0 -1
  534. package/dist/platform/useResponsive.js.map +0 -1
  535. package/dist/platform/useResponsive.mobile.d.ts.map +0 -1
  536. package/dist/platform/useResponsive.mobile.js.map +0 -1
  537. package/dist/platform/withPlatformUI.d.ts.map +0 -1
  538. package/dist/platform/withPlatformUI.js.map +0 -1
  539. package/dist/renderers/form-contract.d.ts.map +0 -1
  540. package/dist/renderers/form-contract.js.map +0 -1
  541. package/dist/theme/tokenBridge.d.ts.map +0 -1
  542. package/dist/theme/tokenBridge.js.map +0 -1
  543. package/dist/theme/tokens.d.ts.map +0 -1
  544. package/dist/theme/tokens.js.map +0 -1
  545. package/dist/theme/variants.d.ts.map +0 -1
  546. package/dist/theme/variants.js.map +0 -1
  547. package/dist/types/navigation.d.ts.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"Cta.js","names":["React","handleClick: React.MouseEventHandler<\n HTMLButtonElement | HTMLAnchorElement\n >"],"sources":["../../../src/components/atoms/Cta.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Button, type ButtonProps } from './Button';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { ButtonLink } from './ButtonLink';\n\nconst ctaVariants = cva('', {\n variants: {\n size: { sm: 'sm', md: 'md', lg: 'lg', touch: 'touch' },\n emphasis: { default: 'default', subtle: 'secondary', strong: 'default' },\n },\n defaultVariants: { size: 'touch', emphasis: 'default' },\n});\n\nexport type CtaProps = ButtonProps &\n VariantProps<typeof ctaVariants> & {\n capture?: (cta: string) => void;\n ctaName?: string;\n as?: 'button' | 'a';\n href?: string;\n children?: React.ReactNode;\n };\n\nexport const Cta = React.forwardRef<\n HTMLButtonElement | HTMLAnchorElement,\n CtaProps\n>(\n (\n {\n capture,\n ctaName,\n as = 'button',\n href,\n onClick,\n size = 'touch',\n emphasis = 'default',\n children,\n ...props\n },\n ref\n ) => {\n const handleClick: React.MouseEventHandler<\n HTMLButtonElement | HTMLAnchorElement\n > = (e) => {\n if (ctaName) {\n try {\n if (capture) capture(ctaName);\n // Optional PostHog fallback if present globally\n const ph = (globalThis as any).posthog;\n if (ph && typeof ph.capture === 'function') {\n ph.capture('cta_click', { cta: ctaName });\n }\n } catch {}\n }\n onClick?.(e as any);\n };\n\n const uiSize = size as ButtonProps['size'];\n const uiVariant = (\n emphasis === 'subtle' ? 'secondary' : 'default'\n ) as ButtonProps['variant'];\n\n if (as === 'a') {\n return (\n <ButtonLink\n size={uiSize}\n variant={uiVariant}\n {...props}\n href={href}\n ref={ref as any}\n >\n {children}\n </ButtonLink>\n );\n }\n\n return (\n <Button\n size={uiSize}\n variant={uiVariant}\n onPress={handleClick as any}\n ref={ref as any}\n {...props}\n >\n {children}\n </Button>\n );\n }\n);\nCta.displayName = 'Cta';\n"],"mappings":";;;;;;;AAKoB,IAAI,IAAI;CAC1B,UAAU;EACR,MAAM;GAAE,IAAI;GAAM,IAAI;GAAM,IAAI;GAAM,OAAO;GAAS;EACtD,UAAU;GAAE,SAAS;GAAW,QAAQ;GAAa,QAAQ;GAAW;EACzE;CACD,iBAAiB;EAAE,MAAM;EAAS,UAAU;EAAW;CACxD,CAAC;AAWF,MAAa,MAAMA,QAAM,YAKrB,EACE,SACA,SACA,KAAK,UACL,MACA,SACA,OAAO,SACP,WAAW,WACX,UACA,GAAG,SAEL,QACG;CACH,MAAMC,eAED,MAAM;AACT,MAAI,QACF,KAAI;AACF,OAAI,QAAS,SAAQ,QAAQ;GAE7B,MAAM,KAAM,WAAmB;AAC/B,OAAI,MAAM,OAAO,GAAG,YAAY,WAC9B,IAAG,QAAQ,aAAa,EAAE,KAAK,SAAS,CAAC;UAErC;AAEV,YAAU,EAAS;;CAGrB,MAAM,SAAS;CACf,MAAM,YACJ,aAAa,WAAW,cAAc;AAGxC,KAAI,OAAO,IACT,QACE,oBAAC;EACC,MAAM;EACN,SAAS;EACT,GAAI;EACE;EACD;EAEJ;GACU;AAIjB,QACE,oBAAC;EACC,MAAM;EACN,SAAS;EACT,SAAS;EACJ;EACL,GAAI;EAEH;GACM;EAGd;AACD,IAAI,cAAc"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Cta.mobile.d.ts","names":[],"sources":["../../../src/components/atoms/Cta.mobile.tsx"],"sourcesContent":[],"mappings":";;;;KAKY,QAAA,GAAW;;EAAX,OAAA,CAAA,EAAA,MAAQ;EAQP,EAAA,CAAA,EAAA,QA4CZ,GAAA,GAAA;EA5Ce,IAAA,CAAA,EAAA,MAAA;EAAA,QAAA,CAAA,EAHH,OAAA,CAAM,SAGH;CAAA;AAAA,cAAH,GAAG,EAAA,OAAA,CAAA,yBAAA,CAAA,IAAA,CAAA,QAAA,EAAA,KAAA,CAAA,GAAA,OAAA,CAAA,aAAA,CAAA,OAAA,CAAA,CAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Cta.mobile.js","names":["React","ph: any"],"sources":["../../../src/components/atoms/Cta.mobile.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { Button, type ButtonProps } from './Button';\n\nexport type CtaProps = ButtonProps & {\n capture?: (cta: string) => void;\n ctaName?: string;\n as?: 'button' | 'a';\n href?: string;\n children?: React.ReactNode;\n};\n\nexport const Cta = React.forwardRef<unknown, CtaProps>(\n ({ capture, ctaName, size = 'touch', onClick, children, ...props }, ref) => {\n const handlePress = () => {\n try {\n if (ctaName) {\n if (capture) capture(ctaName);\n let ph: any;\n try {\n // Prefer posthog-react-native if present\n\n ph =\n require('posthog-react-native').default ??\n require('posthog-react-native');\n } catch {}\n if (ph && typeof ph.capture === 'function') {\n ph.capture('cta_click', { cta: ctaName });\n } else {\n const globalPh = (globalThis as any).posthog;\n if (globalPh && typeof globalPh.capture === 'function') {\n globalPh.capture('cta_click', { cta: ctaName });\n }\n }\n }\n } catch {}\n // Bridge to any provided web-style onClick for API symmetry\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore cross-platform prop bridge\n onClick?.();\n };\n\n return (\n <Button\n size={size}\n // RN kits generally use onPress\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore cross-platform prop bridge\n onPress={handlePress}\n ref={ref as any}\n {...(props as any)}\n >\n {children}\n </Button>\n );\n }\n);\n\nCta.displayName = 'Cta';\n"],"mappings":";;;;;;;;AAaA,MAAa,MAAMA,QAAM,YACtB,EAAE,SAAS,SAAS,OAAO,SAAS,SAAS,UAAU,GAAG,SAAS,QAAQ;CAC1E,MAAM,oBAAoB;AACxB,MAAI;AACF,OAAI,SAAS;AACX,QAAI,QAAS,SAAQ,QAAQ;IAC7B,IAAIC;AACJ,QAAI;AAGF,oBACU,uBAAuB,CAAC,qBACxB,uBAAuB;YAC3B;AACR,QAAI,MAAM,OAAO,GAAG,YAAY,WAC9B,IAAG,QAAQ,aAAa,EAAE,KAAK,SAAS,CAAC;SACpC;KACL,MAAM,WAAY,WAAmB;AACrC,SAAI,YAAY,OAAO,SAAS,YAAY,WAC1C,UAAS,QAAQ,aAAa,EAAE,KAAK,SAAS,CAAC;;;UAI/C;AAIR,aAAW;;AAGb,QACE,oBAAC;EACO;EAIN,SAAS;EACJ;EACL,GAAK;EAEJ;GACM;EAGd;AAED,IAAI,cAAc"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"DataChips.d.ts","names":[],"sources":["../../../src/components/atoms/DataChips.tsx"],"sourcesContent":[],"mappings":";;;;;;cAIM;;;IASL,+BAAA,CAAA;AATK,KAWM,YAAA,GAAe,YAF1B,CAAA,OAE8C,IAF9C,CAAA;AAEW,iBAEI,QAAA,CAF+B;EAAA,KAApB;EAAA,GAAA;AAGzB,CAHyB,EAAA;EAEX,KAAA,CAAA,EAAA,MAAQ,GAGF,IAHE,GAAA,IAAA;CACtB,GAEoC,YAFpC,CAAA,EAEgD,mBAAA,CAAA,GAAA,CAAA,OAAA,GAFhD,IAAA;AAEoB,iBAgBN,QAAA,CAhBM;EAAA,KAAA;EAAA,GAAA;AAA4B,CAA5B,EAAA;EAAgB,KAAA,CAAA,EAAA,MAAA,GAmBhB,IAnBgB,GAAA,IAAA;CAAY,GAmBZ,YAnBY,CAAA,EAmBA,mBAAA,CAAA,GAAA,CAAA,OAAA,GAnBA,IAAA;AAAA,iBAmClC,SAAA,CAnCkC;EAAA,KAAA;EAAA,GAAA;AAiBhD,CAjBgD,EAAA;EAgBlC,KAAA,CAAA,EAsBH,OAAA,CAAM,SAtBK;CACtB,GAqB+B,YArB/B,CAAA,EAqB2C,mBAAA,CAAA,GAAA,CAAA,OAAA,GArB3C,IAAA;AAEoB,iBA4BN,YAAA,CA5BM;EAAA,OAAA;EAAA,GAAA;AAA4B,CAA5B,EAAA;EAAgB,OAAA,CAAA,EAAA,MAAA,GAAA,IAAA;CAAY,GA+BjB,YA/BiB,CAAA,EA+BL,mBAAA,CAAA,GAAA,CAAA,OAAA,GA/BK,IAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"DataChips.js","names":[],"sources":["../../../src/components/atoms/DataChips.tsx"],"sourcesContent":["import * as React from 'react';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { Calendar, Clock, MapPin } from 'lucide-react';\n\nconst chip = cva(\n 'inline-flex items-center gap-1 text-base text-muted-foreground',\n {\n variants: {\n size: { sm: 'text-sm', md: 'text-base' },\n tone: { default: '', muted: 'opacity-85' },\n },\n defaultVariants: { size: 'md', tone: 'default' },\n }\n);\n\nexport type ChipVariants = VariantProps<typeof chip>;\n\nexport function DateChip({\n value,\n ...v\n}: { value?: string | Date | null } & ChipVariants) {\n if (!value) return null;\n let text = '';\n try {\n const d = typeof value === 'string' ? new Date(value) : value;\n text = d.toLocaleDateString();\n } catch {\n text = String(value);\n }\n return (\n <span className={chip(v)}>\n <Calendar className=\"h-4 w-4\" /> {text}\n </span>\n );\n}\n\nexport function TimeChip({\n value,\n ...v\n}: { value?: string | Date | null } & ChipVariants) {\n if (!value) return null;\n let text = '';\n try {\n const d = typeof value === 'string' ? new Date(value) : value;\n text = d.toLocaleTimeString([], { hour: '2-digit', minute: '2-digit' });\n } catch {\n text = String(value);\n }\n return (\n <span className={chip(v)}>\n <Clock className=\"h-4 w-4\" /> {text}\n </span>\n );\n}\n\nexport function PlaceChip({\n label,\n ...v\n}: { label?: React.ReactNode } & ChipVariants) {\n if (!label) return null;\n return (\n <span className={chip(v)}>\n <MapPin className=\"h-4 w-4\" /> {label}\n </span>\n );\n}\n\nexport function DurationChip({\n minutes,\n ...v\n}: { minutes?: number | null } & ChipVariants) {\n if (minutes == null) return null;\n const hrs = Math.floor(minutes / 60);\n const mins = minutes % 60;\n const text =\n hrs > 0\n ? `${hrs}h${mins > 0 ? String(mins).padStart(2, '0') : ''}`\n : `${mins}min`;\n return (\n <span className={chip(v)}>\n <Clock className=\"h-4 w-4\" /> {text}\n </span>\n );\n}\n"],"mappings":";;;;;;AAIA,MAAM,OAAO,IACX,kEACA;CACE,UAAU;EACR,MAAM;GAAE,IAAI;GAAW,IAAI;GAAa;EACxC,MAAM;GAAE,SAAS;GAAI,OAAO;GAAc;EAC3C;CACD,iBAAiB;EAAE,MAAM;EAAM,MAAM;EAAW;CACjD,CACF;AAID,SAAgB,SAAS,EACvB,OACA,GAAG,KAC+C;AAClD,KAAI,CAAC,MAAO,QAAO;CACnB,IAAI,OAAO;AACX,KAAI;AAEF,UADU,OAAO,UAAU,WAAW,IAAI,KAAK,MAAM,GAAG,OAC/C,oBAAoB;SACvB;AACN,SAAO,OAAO,MAAM;;AAEtB,QACE,qBAAC;EAAK,WAAW,KAAK,EAAE;;GACtB,oBAAC,YAAS,WAAU,YAAY;;GAAE;;GAC7B;;AAIX,SAAgB,SAAS,EACvB,OACA,GAAG,KAC+C;AAClD,KAAI,CAAC,MAAO,QAAO;CACnB,IAAI,OAAO;AACX,KAAI;AAEF,UADU,OAAO,UAAU,WAAW,IAAI,KAAK,MAAM,GAAG,OAC/C,mBAAmB,EAAE,EAAE;GAAE,MAAM;GAAW,QAAQ;GAAW,CAAC;SACjE;AACN,SAAO,OAAO,MAAM;;AAEtB,QACE,qBAAC;EAAK,WAAW,KAAK,EAAE;;GACtB,oBAAC,SAAM,WAAU,YAAY;;GAAE;;GAC1B;;AAIX,SAAgB,UAAU,EACxB,OACA,GAAG,KAC0C;AAC7C,KAAI,CAAC,MAAO,QAAO;AACnB,QACE,qBAAC;EAAK,WAAW,KAAK,EAAE;;GACtB,oBAAC,UAAO,WAAU,YAAY;;GAAE;;GAC3B;;AAIX,SAAgB,aAAa,EAC3B,SACA,GAAG,KAC0C;AAC7C,KAAI,WAAW,KAAM,QAAO;CAC5B,MAAM,MAAM,KAAK,MAAM,UAAU,GAAG;CACpC,MAAM,OAAO,UAAU;CACvB,MAAM,OACJ,MAAM,IACF,GAAG,IAAI,GAAG,OAAO,IAAI,OAAO,KAAK,CAAC,SAAS,GAAG,IAAI,GAAG,OACrD,GAAG,KAAK;AACd,QACE,qBAAC;EAAK,WAAW,KAAK,EAAE;;GACtB,oBAAC,SAAM,WAAU,YAAY;;GAAE;;GAC1B"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"EmptyState.d.ts","names":[],"sources":["../../../src/components/atoms/EmptyState.tsx"],"sourcesContent":[],"mappings":";;;;iBAQgB,UAAA,QAAkB,kBAAe,mBAAA,CAAA,GAAA,CAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"EmptyState.js","names":["WebEmptyState"],"sources":["../../../src/components/atoms/EmptyState.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport {\n EmptyState as WebEmptyState,\n type EmptyStateProps,\n} from '@lssm/lib.ui-kit-web/ui/empty-state';\n\nexport function EmptyState(props: EmptyStateProps) {\n return <WebEmptyState {...props} />;\n}\n"],"mappings":";;;;;;;AAQA,SAAgB,WAAW,OAAwB;AACjD,QAAO,oBAACA,gBAAc,GAAI,QAAS"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"ErrorState.d.ts","names":[],"sources":["../../../src/components/atoms/ErrorState.tsx"],"sourcesContent":[],"mappings":";;;;UAWiB,eAAA;UACP,OAAA,CAAM;gBACA,OAAA,CAAM;EAFL,IAAA,CAAA,EAGR,OAAA,CAAM,SAHiB;EACtB,OAAM,CAAA,EAAA,GAAA,GAAA,IAAA;EACA,UAAM,CAAA,EAGP,OAAA,CAAM,SAHC;EACb,WAAM,CAAA,EAAA,MAAA;EAEA,gBAAM,CAAA,EAAA,GAAA,GAAA,IAAA;EAGJ,YAAM,CAAA,EAAN,OAAA,CAAM,SAAA;EAAS,SAAA,CAAA,EAAA,MAAA;AAIhC;AACE,iBADc,UAAA,CACd;EAAA,KAAA;EAAA,WAAA;EAAA,IAAA;EAAA,OAAA;EAAA,UAAA;EAAA,WAAA;EAAA,gBAAA;EAAA,YAAA;EAAA;AAAA,CAAA,EASC,eATD,CAAA,EASgB,mBAAA,CAAA,GAAA,CAAA,OAThB"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"ErrorState.js","names":[],"sources":["../../../src/components/atoms/ErrorState.tsx"],"sourcesContent":["import * as React from 'react';\nimport {\n Empty,\n EmptyContent,\n EmptyDescription,\n EmptyHeader,\n EmptyTitle,\n} from '@lssm/lib.ui-kit-web/ui/empty';\nimport { Button } from '../atoms/Button';\nimport { ButtonLink } from '../atoms/ButtonLink';\n\nexport interface ErrorStateProps {\n title?: React.ReactNode;\n description?: React.ReactNode;\n icon?: React.ReactNode;\n onRetry?: () => void;\n retryLabel?: React.ReactNode;\n supportHref?: string;\n onContactSupport?: () => void;\n supportLabel?: React.ReactNode;\n className?: string;\n}\n\nexport function ErrorState({\n title = 'Something went wrong',\n description,\n icon,\n onRetry,\n retryLabel = 'Retry',\n supportHref,\n onContactSupport,\n supportLabel = 'Contact support',\n className,\n}: ErrorStateProps) {\n const Support = (() => {\n if (supportHref) {\n return (\n <ButtonLink variant=\"ghost\" href={supportHref}>\n {supportLabel}\n </ButtonLink>\n );\n }\n if (onContactSupport) {\n return (\n <Button variant=\"ghost\" onPress={onContactSupport}>\n {supportLabel}\n </Button>\n );\n }\n return null;\n })();\n\n return (\n <Empty className={className}>\n <EmptyHeader>\n {icon}\n <EmptyTitle>{title}</EmptyTitle>\n {description ? (\n <EmptyDescription>{description}</EmptyDescription>\n ) : null}\n </EmptyHeader>\n <EmptyContent>\n <div className=\"flex flex-wrap items-center gap-2\">\n {onRetry ? <Button onPress={onRetry}>{retryLabel}</Button> : null}\n {Support}\n </div>\n </EmptyContent>\n </Empty>\n );\n}\n\nexport default ErrorState;\n"],"mappings":";;;;;;;AAuBA,SAAgB,WAAW,EACzB,QAAQ,wBACR,aACA,MACA,SACA,aAAa,SACb,aACA,kBACA,eAAe,mBACf,aACkB;CAClB,MAAM,iBAAiB;AACrB,MAAI,YACF,QACE,oBAAC;GAAW,SAAQ;GAAQ,MAAM;aAC/B;IACU;AAGjB,MAAI,iBACF,QACE,oBAAC;GAAO,SAAQ;GAAQ,SAAS;aAC9B;IACM;AAGb,SAAO;KACL;AAEJ,QACE,qBAAC;EAAiB;aAChB,qBAAC;GACE;GACD,oBAAC,wBAAY,QAAmB;GAC/B,cACC,oBAAC,8BAAkB,cAA+B,GAChD;MACQ,EACd,oBAAC,0BACC,qBAAC;GAAI,WAAU;cACZ,UAAU,oBAAC;IAAO,SAAS;cAAU;KAAoB,GAAG,MAC5D;IACG,GACO;GACT;;AAIZ,yBAAe"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"ErrorState.mobile.d.ts","names":[],"sources":["../../../src/components/atoms/ErrorState.mobile.tsx"],"sourcesContent":[],"mappings":";;;;UAKiB,eAAA;UACP,OAAA,CAAM;gBACA,OAAA,CAAM;EAFL,IAAA,CAAA,EAGR,OAAA,CAAM,SAHiB;EACtB,OAAM,CAAA,EAAA,GAAA,GAAA,IAAA;EACA,UAAM,CAAA,EAGP,OAAA,CAAM,SAHC;EACb,WAAM,CAAA,EAAA,MAAA;EAEA,gBAAM,CAAA,EAAA,GAAA,GAAA,IAAA;EAGJ,YAAM,CAAA,EAAN,OAAA,CAAM,SAAA;EAAS,SAAA,CAAA,EAAA,MAAA;AAIhC;AACE,iBADc,UAAA,CACd;EAAA,KAAA;EAAA,WAAA;EAAA,IAAA;EAAA,OAAA;EAAA,UAAA;EAAA,WAAA;EAAA,gBAAA;EAAA,YAAA;EAAA;AAAA,CAAA,EASC,eATD,CAAA,EASgB,mBAAA,CAAA,GAAA,CAAA,OAThB"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"ErrorState.mobile.js","names":["React"],"sources":["../../../src/components/atoms/ErrorState.mobile.tsx"],"sourcesContent":["import * as React from 'react';\nimport { View, Text } from 'react-native';\nimport { Button } from '../atoms/Button.mobile';\nimport { Linking } from 'react-native';\n\nexport interface ErrorStateProps {\n title?: React.ReactNode;\n description?: React.ReactNode;\n icon?: React.ReactNode;\n onRetry?: () => void;\n retryLabel?: React.ReactNode;\n supportHref?: string;\n onContactSupport?: () => void;\n supportLabel?: React.ReactNode;\n className?: string;\n}\n\nexport function ErrorState({\n title = 'Something went wrong',\n description,\n icon,\n onRetry,\n retryLabel = 'Retry',\n supportHref,\n onContactSupport,\n supportLabel = 'Contact support',\n className,\n}: ErrorStateProps) {\n const onSupport = React.useCallback(() => {\n if (supportHref) Linking.openURL(supportHref).catch(() => {});\n else onContactSupport?.();\n }, [supportHref, onContactSupport]);\n\n return (\n <View className={['items-center p-6', className].filter(Boolean).join(' ')}>\n {icon}\n <Text className=\"text-lg font-medium\">{title as any}</Text>\n {description ? (\n <Text className=\"text-muted-foreground mt-1 text-base\">\n {description as any}\n </Text>\n ) : null}\n <View className=\"mt-3 flex-row items-center gap-2\">\n {onRetry ? <Button onPress={onRetry}>{retryLabel}</Button> : null}\n <Button variant=\"ghost\" onPress={onSupport}>\n {supportLabel}\n </Button>\n </View>\n </View>\n );\n}\n\nexport default ErrorState;\n"],"mappings":";;;;;;AAiBA,SAAgB,WAAW,EACzB,QAAQ,wBACR,aACA,MACA,SACA,aAAa,SACb,aACA,kBACA,eAAe,mBACf,aACkB;CAClB,MAAM,YAAYA,QAAM,kBAAkB;AACxC,MAAI,YAAa,SAAQ,QAAQ,YAAY,CAAC,YAAY,GAAG;MACxD,qBAAoB;IACxB,CAAC,aAAa,iBAAiB,CAAC;AAEnC,QACE,qBAAC;EAAK,WAAW,CAAC,oBAAoB,UAAU,CAAC,OAAO,QAAQ,CAAC,KAAK,IAAI;;GACvE;GACD,oBAAC;IAAK,WAAU;cAAuB;KAAoB;GAC1D,cACC,oBAAC;IAAK,WAAU;cACb;KACI,GACL;GACJ,qBAAC;IAAK,WAAU;eACb,UAAU,oBAAC;KAAO,SAAS;eAAU;MAAoB,GAAG,MAC7D,oBAAC;KAAO,SAAQ;KAAQ,SAAS;eAC9B;MACM;KACJ;;GACF;;AAIX,gCAAe"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Input.d.ts","names":[],"sources":["../../../src/components/atoms/Input.tsx"],"sourcesContent":[],"mappings":";;;;;UAOU,cAAA;;;EAAA,QAAA,CAAA,EAAA,CAAA,IAAA,EAAc,MAAA,EAAA,GAAA,IAaX;EAGD,QAAA,CAAA,EAAA,GAAU,GAAA,IAAA;EACpB,OAAA,CAAA,EAAA,GAAA,GAAA,IAAA;EADuB,MAAA,CAAA,EAAA,GAAA,GAAA,IAAA;EAIvB,WAAA,CAAA,EAAA,MAAA;EAAc,QAAA,CAAA,EAAA,OAAA;EAEA,QAAK,CAAA,EAAA,OAAA;EACnB,SAAA,CAAA,EAAA,MAAA;EACA,IAAA,CAAA,EAAA,MAAA;EACA,SAAA,CAAA,EAAA,MAAA;EACA,QAAA,CAAA,EAbW,eAaX;;AAEA,KAZU,UAAA,GAAa,IAYvB,CAXA,YAWA,EAAA,UAAA,GAAA,OAAA,GAAA,cAAA,GAAA,OAAA,CAAA,GARA,cAQA;AACA,iBAPc,KAAA,CAOd;EAAA,KAAA;EAAA,YAAA;EAAA,QAAA;EAAA,QAAA;EAAA,OAAA;EAAA,MAAA;EAAA,WAAA;EAAA,QAAA;EAAA,QAAA;EAAA,SAAA;EAAA,IAAA;EAAA,SAAA;EAAA,QAAA;EAAA,GAAA;AAAA,CAAA,EAQC,UARD,CAAA,EAQW,mBAAA,CAAA,GAAA,CAAA,OARX"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Input.js","names":["WebInput"],"sources":["../../../src/components/atoms/Input.tsx"],"sourcesContent":["import * as React from 'react';\nimport {\n Input as WebInput,\n type InputProps as WebInputProps,\n} from '@lssm/lib.ui-kit-web/ui/input';\nimport { type KeyboardOptions, mapKeyboardToWeb } from '../../lib/keyboard';\n\ninterface BaseFieldProps {\n value?: string | number;\n defaultValue?: string | number;\n onChange?: (text: string) => void;\n onSubmit?: () => void;\n onFocus?: () => void;\n onBlur?: () => void;\n placeholder?: string;\n disabled?: boolean;\n readOnly?: boolean;\n maxLength?: number;\n name?: string;\n className?: string;\n keyboard?: KeyboardOptions;\n}\n\nexport type InputProps = Omit<\n WebInputProps,\n 'onChange' | 'value' | 'defaultValue' | 'input'\n> &\n BaseFieldProps;\n\nexport function Input({\n value,\n defaultValue,\n onChange,\n onSubmit,\n onFocus,\n onBlur,\n placeholder,\n disabled,\n readOnly,\n maxLength,\n name,\n className,\n keyboard,\n ...rest\n}: InputProps) {\n const webKeyboard = mapKeyboardToWeb(keyboard);\n\n return (\n <WebInput\n {...rest}\n className={className}\n value={value}\n defaultValue={defaultValue}\n onChange={onChange ? (e) => onChange?.(e.target.value) : undefined}\n // onKeyDown={onKeyDown}\n onFocus={onFocus}\n onBlur={onBlur}\n placeholder={placeholder}\n disabled={disabled}\n readOnly={readOnly}\n maxLength={maxLength}\n name={name}\n {...webKeyboard}\n />\n );\n}\n\nexport default Input;\n"],"mappings":";;;;;;AA6BA,SAAgB,MAAM,EACpB,OACA,cACA,UACA,UACA,SACA,QACA,aACA,UACA,UACA,WACA,MACA,WACA,UACA,GAAG,QACU;CACb,MAAM,cAAc,iBAAiB,SAAS;AAE9C,QACE,oBAACA;EACC,GAAI;EACO;EACJ;EACO;EACd,UAAU,YAAY,MAAM,WAAW,EAAE,OAAO,MAAM,GAAG;EAEhD;EACD;EACK;EACH;EACA;EACC;EACL;EACN,GAAI;GACJ;;AAIN,oBAAe"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Input.mobile.d.ts","names":[],"sources":["../../../src/components/atoms/Input.mobile.tsx"],"sourcesContent":[],"mappings":";;;;;;UAIU,cAAA;;;EAAA,QAAA,CAAA,EAAA,CAAA,IAAA,EAAc,MAAA,EAAA,GAAA,IAWX;EAGR,QAAA,CAAA,EAAA,GAAA,GAAA,IAAA;EACO,OAAA,CAAA,EAAA,GAAU,GAAA,IAAA;EACpB,MAAA,CAAA,EAAA,GAAA,GAAA,IAAA;EADuB,WAAA,CAAA,EAAA,MAAA;EAIvB,QAAA,CAAA,EAAA,OAAA;EAAc,SAAA,CAAA,EAAA,MAAA;EAEA,SAAK,CAAA,EAAA,MAAA;EACnB,QAAA,CAAA,EAXW,eAWX;;KARG,yBAAA,GAA4B,OAAA,CAAM,cAUrC,CAAA,OAV2D,OAU3D,CAAA;AACA,KAVU,UAAA,GAAa,IAUvB,CATA,yBASA,EAAA,cAAA,GAAA,OAAA,GAAA,cAAA,CAAA,GANA,cAMA;AACA,iBALc,KAAA,CAKd;EAAA,KAAA;EAAA,YAAA;EAAA,QAAA;EAAA,QAAA;EAAA,OAAA;EAAA,MAAA;EAAA,WAAA;EAAA,QAAA;EAAA,SAAA;EAAA,SAAA;EAAA,QAAA;EAAA,GAAA;AAAA,CAAA,EAQC,UARD,CAAA,EAQW,mBAAA,CAAA,GAAA,CAAA,OARX"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Input.mobile.js","names":["NativeInput"],"sources":["../../../src/components/atoms/Input.mobile.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Input as NativeInput } from '@lssm/lib.ui-kit/ui/input';\nimport { mapKeyboardToNative, type KeyboardOptions } from '../../lib/keyboard';\n\ninterface BaseFieldProps {\n value?: string;\n defaultValue?: string;\n onChange?: (text: string) => void;\n onSubmit?: () => void;\n onFocus?: () => void;\n onBlur?: () => void;\n placeholder?: string;\n disabled?: boolean;\n maxLength?: number;\n className?: string;\n keyboard?: KeyboardOptions;\n}\n\ntype NativeInputComponentProps = React.ComponentProps<typeof NativeInput>;\nexport type InputProps = Omit<\n NativeInputComponentProps,\n 'onChangeText' | 'value' | 'defaultValue'\n> &\n BaseFieldProps;\n\nexport function Input({\n value,\n defaultValue,\n onChange,\n onSubmit,\n onFocus,\n onBlur,\n placeholder,\n disabled,\n maxLength,\n className,\n keyboard,\n ...rest\n}: InputProps) {\n const nativeKeyboard = mapKeyboardToNative(keyboard);\n\n return (\n <NativeInput\n {...(rest as any)}\n className={className as any}\n value={value as any}\n defaultValue={defaultValue as any}\n onChangeText={onChange as any}\n onSubmitEditing={onSubmit as any}\n onFocus={onFocus as any}\n onBlur={onBlur as any}\n placeholder={placeholder}\n editable={!disabled}\n maxLength={maxLength}\n {...(nativeKeyboard as any)}\n />\n );\n}\n\nexport default Input;\n"],"mappings":";;;;;;AAyBA,SAAgB,MAAM,EACpB,OACA,cACA,UACA,UACA,SACA,QACA,aACA,UACA,WACA,WACA,UACA,GAAG,QACU;CACb,MAAM,iBAAiB,oBAAoB,SAAS;AAEpD,QACE,oBAACA;EACC,GAAK;EACM;EACJ;EACO;EACd,cAAc;EACd,iBAAiB;EACR;EACD;EACK;EACb,UAAU,CAAC;EACA;EACX,GAAK;GACL;;AAIN,2BAAe"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Link.d.ts","names":[],"sources":["../../../src/components/atoms/Link.tsx"],"sourcesContent":[],"mappings":";;;;KAGY,SAAA,GAAY,qBAAqB;iBAE7B,IAAA;;;GAA6B,YAAS,mBAAA,CAAA,GAAA,CAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Link.js","names":[],"sources":["../../../src/components/atoms/Link.tsx"],"sourcesContent":["import type { AnchorHTMLAttributes } from 'react';\nimport * as React from 'react';\n\nexport type LinkProps = AnchorHTMLAttributes<HTMLAnchorElement>;\n\nexport function Link({ children, ...props }: LinkProps) {\n return <a {...props}>{children}</a>;\n}\n\nexport default Link;\n"],"mappings":";;;;AAKA,SAAgB,KAAK,EAAE,UAAU,GAAG,SAAoB;AACtD,QAAO,oBAAC;EAAE,GAAI;EAAQ;GAAa;;AAGrC,mBAAe"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Link.web.d.ts","names":[],"sources":["../../../src/components/atoms/Link.web.tsx"],"sourcesContent":[],"mappings":";;;;KAGY,SAAA;;aAEC,OAAA,CAAM;EAFP,SAAA,CAAA,EAAS,MAAA;EAER,QAAM,CAAA,EAAA,OAAA;EAQiB,OAAA,CAAA,EAAA,OAAA;EAAxB,MAAM,CAAA,EAAA,OAAA;EACd,OAAA,CAAA,EAAA,OAAA;EAAM,MAAA,CAAA,EAAA,MAAA;EAEM,GAAA,CAAA,EAAA,MAAI;EAAG,OAAA,CAAA,EAHX,OAAA,CAAM,iBAGK,CAHa,iBAGb,CAAA;CAAM,GAFzB,MAEyB,CAAA,MAAA,EAAA,GAAA,CAAA;AAAsB,iBAAnC,IAAA,CAAmC;EAAA,IAAA;EAAA,QAAA;EAAA,GAAA;AAAA,CAAA,EAAA,SAAA,CAAA,EAAS,mBAAA,CAAA,GAAA,CAAA,OAAT"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Link.web.js","names":[],"sources":["../../../src/components/atoms/Link.web.tsx"],"sourcesContent":["import * as React from 'react';\nimport NextLink from 'next/link';\n\nexport type LinkProps = {\n href: any; // keep loose to avoid type coupling with Next.js types\n children?: React.ReactNode;\n className?: string;\n prefetch?: boolean;\n replace?: boolean;\n scroll?: boolean;\n shallow?: boolean;\n target?: string;\n rel?: string;\n onClick?: React.MouseEventHandler<HTMLAnchorElement>;\n} & Record<string, any>;\n\nexport function Link({ href, children, ...props }: LinkProps) {\n return (\n <NextLink href={href} {...props}>\n {children}\n </NextLink>\n );\n}\n"],"mappings":";;;;;AAgBA,SAAgB,KAAK,EAAE,MAAM,UAAU,GAAG,SAAoB;AAC5D,QACE,oBAAC;EAAe;EAAM,GAAI;EACvB;GACQ"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"LoaderCircular.d.ts","names":[],"sources":["../../../src/components/atoms/LoaderCircular.tsx"],"sourcesContent":[],"mappings":";;;;;;cAKM;;;IAaJ,+BAAA,CAAA;AAbI,KAeM,mBAAA,GAAsB,OAAA,CAAM,cAFtC,CAEqD,cAFrD,CAAA,GAGA,YAHA,CAAA,OAGoB,eAHpB,CAAA,GAAA;EAEU,KAAA,CAAA,EAEA,OAAA,CAAM,SAFa;CAAwB;AAArB,iBAKlB,cAAA,CALwB;EAAA,IAAA;EAAA,IAAA;EAAA,KAAA;EAAA,SAAA;EAAA,GAAA;AAAA,CAAA,EAWrC,mBAXqC,CAAA,EAWlB,mBAAA,CAAA,GAAA,CAAA,OAXkB"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"LoaderCircular.js","names":[],"sources":["../../../src/components/atoms/LoaderCircular.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Loader2 } from 'lucide-react';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { cn } from '@lssm/lib.ui-kit-web/ui/utils';\n\nconst spinnerVariants = cva('animate-spin', {\n variants: {\n size: {\n sm: 'h-4 w-4',\n md: 'h-5 w-5',\n lg: 'h-6 w-6',\n },\n tone: {\n default: 'text-foreground',\n muted: 'text-muted-foreground',\n },\n },\n defaultVariants: { size: 'md', tone: 'muted' },\n});\n\nexport type LoaderCircularProps = React.HTMLAttributes<HTMLDivElement> &\n VariantProps<typeof spinnerVariants> & {\n label?: React.ReactNode;\n };\n\nexport function LoaderCircular({\n size,\n tone,\n label,\n className,\n ...props\n}: LoaderCircularProps) {\n return (\n <div\n className={cn('inline-flex items-center gap-2', className)}\n role=\"status\"\n aria-live=\"polite\"\n aria-busy\n {...props}\n >\n <Loader2 className={cn(spinnerVariants({ size, tone }))} />\n {label ? (\n <span className=\"text-muted-foreground text-base\">{label}</span>\n ) : null}\n </div>\n );\n}\n\nexport default LoaderCircular;\n"],"mappings":";;;;;;;AAKA,MAAM,kBAAkB,IAAI,gBAAgB;CAC1C,UAAU;EACR,MAAM;GACJ,IAAI;GACJ,IAAI;GACJ,IAAI;GACL;EACD,MAAM;GACJ,SAAS;GACT,OAAO;GACR;EACF;CACD,iBAAiB;EAAE,MAAM;EAAM,MAAM;EAAS;CAC/C,CAAC;AAOF,SAAgB,eAAe,EAC7B,MACA,MACA,OACA,WACA,GAAG,SACmB;AACtB,QACE,qBAAC;EACC,WAAW,GAAG,kCAAkC,UAAU;EAC1D,MAAK;EACL,aAAU;EACV;EACA,GAAI;aAEJ,oBAAC,WAAQ,WAAW,GAAG,gBAAgB;GAAE;GAAM;GAAM,CAAC,CAAC,GAAI,EAC1D,QACC,oBAAC;GAAK,WAAU;aAAmC;IAAa,GAC9D;GACA;;AAIV,6BAAe"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"LoaderCircular.mobile.d.ts","names":[],"sources":["../../../src/components/atoms/LoaderCircular.mobile.tsx"],"sourcesContent":[],"mappings":";;;;UAGiB,mBAAA;;;EAAA,KAAA,CAAA,EAGP,OAAA,CAAM,SAHoB;EAmBpB,SAAA,CAAA,EAAA,MAAc;;AAE5B,iBAFc,cAAA,CAEd;EAAA,IAAA;EAAA,KAAA;EAAA;AAAA,CAAA,EAEC,mBAFD,CAAA,EAEoB,mBAAA,CAAA,GAAA,CAAA,OAFpB"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"LoaderCircular.mobile.js","names":[],"sources":["../../../src/components/atoms/LoaderCircular.mobile.tsx"],"sourcesContent":["import * as React from 'react';\nimport { ActivityIndicator, View, Text } from 'react-native';\n\nexport interface LoaderCircularProps {\n size?: 'sm' | 'md' | 'lg';\n tone?: 'default' | 'muted';\n label?: React.ReactNode;\n className?: string;\n}\n\nfunction toNativeSize(size?: 'sm' | 'md' | 'lg'): number | 'small' | 'large' {\n switch (size) {\n case 'sm':\n return 'small';\n case 'lg':\n return 'large';\n case 'md':\n default:\n return 'small';\n }\n}\n\nexport function LoaderCircular({\n size = 'md',\n label,\n className,\n}: LoaderCircularProps) {\n return (\n <View\n className={['inline-flex flex-row items-center gap-2', className]\n .filter(Boolean)\n .join(' ')}\n >\n <ActivityIndicator size={toNativeSize(size)} />\n {label ? (\n <Text className=\"text-muted-foreground text-base\">{label as any}</Text>\n ) : null}\n </View>\n );\n}\n\nexport default LoaderCircular;\n"],"mappings":";;;;;AAUA,SAAS,aAAa,MAAuD;AAC3E,SAAQ,MAAR;EACE,KAAK,KACH,QAAO;EACT,KAAK,KACH,QAAO;EACT,KAAK;EACL,QACE,QAAO;;;AAIb,SAAgB,eAAe,EAC7B,OAAO,MACP,OACA,aACsB;AACtB,QACE,qBAAC;EACC,WAAW,CAAC,2CAA2C,UAAU,CAC9D,OAAO,QAAQ,CACf,KAAK,IAAI;aAEZ,oBAAC,qBAAkB,MAAM,aAAa,KAAK,GAAI,EAC9C,QACC,oBAAC;GAAK,WAAU;aAAmC;IAAoB,GACrE;GACC;;AAIX,oCAAe"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"NavBrand.d.ts","names":[],"sources":["../../../src/components/atoms/NavBrand.tsx"],"sourcesContent":[],"mappings":";;;;UAKiB,aAAA;;SAER,OAAA,CAAM;EAFE,KAAA,CAAA,EAGP,OAAA,CAAM,SAHc;EAOd,SAAA,CAAA,EAAQ,MAAA;;AAEtB,iBAFc,QAAA,CAEd;EAAA,IAAA;EAAA,IAAA;EAAA,KAAA;EAAA;AAAA,CAAA,EAGC,aAHD,CAAA,EAGc,mBAAA,CAAA,GAAA,CAAA,OAHd"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"NavBrand.js","names":[],"sources":["../../../src/components/atoms/NavBrand.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { cn } from '@lssm/lib.ui-kit-web/ui/utils';\n\nexport interface NavBrandProps {\n href?: string;\n logo?: React.ReactNode;\n title?: React.ReactNode;\n className?: string;\n}\n\nexport function NavBrand({\n href = '/',\n logo,\n title,\n className,\n}: NavBrandProps) {\n const content = (\n <div\n className={cn(\n 'flex items-center gap-2 truncate font-semibold',\n className\n )}\n >\n {logo}\n {title && <span className=\"truncate text-xl font-bold\">{title}</span>}\n </div>\n );\n return href ? (\n <a href={href} className=\"flex items-center\" aria-label=\"Home\">\n {content}\n </a>\n ) : (\n content\n );\n}\n"],"mappings":";;;;;;;AAYA,SAAgB,SAAS,EACvB,OAAO,KACP,MACA,OACA,aACgB;CAChB,MAAM,UACJ,qBAAC;EACC,WAAW,GACT,kDACA,UACD;aAEA,MACA,SAAS,oBAAC;GAAK,WAAU;aAA8B;IAAa;GACjE;AAER,QAAO,OACL,oBAAC;EAAQ;EAAM,WAAU;EAAoB,cAAW;YACrD;GACC,GAEJ"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Stepper.d.ts","names":[],"sources":["../../../src/components/atoms/Stepper.tsx"],"sourcesContent":[],"mappings":";;;;iBAQgB,OAAA,QAAe,eAAY,mBAAA,CAAA,GAAA,CAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Stepper.js","names":["WebStepper"],"sources":["../../../src/components/atoms/Stepper.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport {\n Stepper as WebStepper,\n type StepperProps,\n} from '@lssm/lib.ui-kit-web/ui/stepper';\n\nexport function Stepper(props: StepperProps) {\n return <WebStepper {...props} />;\n}\n"],"mappings":";;;;;;;AAQA,SAAgB,QAAQ,OAAqB;AAC3C,QAAO,oBAACA,aAAW,GAAI,QAAS"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Textarea.d.ts","names":[],"sources":["../../../src/components/atoms/Textarea.tsx"],"sourcesContent":[],"mappings":";;;;;UAOU,cAAA;;;EAAA,QAAA,CAAA,EAAA,CAAA,IAAA,EAAc,MAAA,EAAA,GAAA,IAcX;EAGD,QAAA,CAAA,EAAA,GAAA,GAAa,IAAA;EACvB,OAAA,CAAA,EAAA,GAAA,GAAA,IAAA;EAD0B,MAAA,CAAA,EAAA,GAAA,GAAA,IAAA;EAI1B,WAAA,CAAA,EAAA,MAAA;EAAc,QAAA,CAAA,EAAA,OAAA;EAEA,QAAA,CAAA,EAAQ,OAAA;EACtB,SAAA,CAAA,EAAA,MAAA;EACA,IAAA,CAAA,EAAA,MAAA;EACA,SAAA,CAAA,EAAA,MAAA;EACA,IAAA,CAAA,EAAA,MAAA;EACA,QAAA,CAAA,EAdW,eAcX;;AAEA,KAbU,aAAA,GAAgB,IAa1B,CAZA,eAYA,EAAA,UAAA,GAAA,OAAA,GAAA,cAAA,CAAA,GATA,cASA;AACA,iBARc,QAAA,CAQd;EAAA,KAAA;EAAA,YAAA;EAAA,QAAA;EAAA,QAAA;EAAA,OAAA;EAAA,MAAA;EAAA,WAAA;EAAA,QAAA;EAAA,QAAA;EAAA,SAAA;EAAA,IAAA;EAAA,SAAA;EAAA,IAAA;EAAA,QAAA;EAAA,GAAA;AAAA,CAAA,EAQC,aARD,CAAA,EAQc,mBAAA,CAAA,GAAA,CAAA,OARd"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Textarea.js","names":["React","WebTextarea"],"sources":["../../../src/components/atoms/Textarea.tsx"],"sourcesContent":["import * as React from 'react';\nimport {\n Textarea as WebTextarea,\n type TextareaProps as WebTextareaProps,\n} from '@lssm/lib.ui-kit-web/ui/textarea';\nimport { type KeyboardOptions, mapKeyboardToWeb } from '../../lib/keyboard';\n\ninterface BaseFieldProps {\n value?: string;\n defaultValue?: string;\n onChange?: (text: string) => void;\n onSubmit?: () => void;\n onFocus?: () => void;\n onBlur?: () => void;\n placeholder?: string;\n disabled?: boolean;\n readOnly?: boolean;\n maxLength?: number;\n name?: string;\n className?: string;\n rows?: number;\n keyboard?: KeyboardOptions;\n}\n\nexport type TextareaProps = Omit<\n WebTextareaProps,\n 'onChange' | 'value' | 'defaultValue'\n> &\n BaseFieldProps;\n\nexport function Textarea({\n value,\n defaultValue,\n onChange,\n onSubmit,\n onFocus,\n onBlur,\n placeholder,\n disabled,\n readOnly,\n maxLength,\n name,\n className,\n rows,\n keyboard,\n ...rest\n}: TextareaProps) {\n const webKeyboard = mapKeyboardToWeb(keyboard);\n\n const handleChange = React.useCallback<\n React.ChangeEventHandler<HTMLTextAreaElement>\n >((e) => onChange?.(e.target.value), [onChange]);\n\n const handleKeyDown = React.useCallback<\n React.KeyboardEventHandler<HTMLTextAreaElement>\n >(\n (e) => {\n if (e.key === 'Enter' && webKeyboard.type !== 'search') {\n // For textarea, Enter inserts newline; onSubmit could be used with modifier\n if (e.metaKey || e.ctrlKey) onSubmit?.();\n }\n },\n [onSubmit, webKeyboard.type]\n );\n\n return (\n <WebTextarea\n {...(rest as any)}\n className={className}\n value={value as any}\n defaultValue={defaultValue as any}\n onChange={handleChange}\n onKeyDown={handleKeyDown}\n onFocus={onFocus as any}\n onBlur={onBlur as any}\n placeholder={placeholder}\n disabled={disabled}\n readOnly={readOnly}\n maxLength={maxLength}\n name={name}\n rows={rows}\n {...webKeyboard}\n />\n );\n}\n\nexport default Textarea;\n"],"mappings":";;;;;;AA8BA,SAAgB,SAAS,EACvB,OACA,cACA,UACA,UACA,SACA,QACA,aACA,UACA,UACA,WACA,MACA,WACA,MACA,UACA,GAAG,QACa;CAChB,MAAM,cAAc,iBAAiB,SAAS;CAE9C,MAAM,eAAeA,QAAM,aAExB,MAAM,WAAW,EAAE,OAAO,MAAM,EAAE,CAAC,SAAS,CAAC;CAEhD,MAAM,gBAAgBA,QAAM,aAGzB,MAAM;AACL,MAAI,EAAE,QAAQ,WAAW,YAAY,SAAS,UAE5C;OAAI,EAAE,WAAW,EAAE,QAAS,aAAY;;IAG5C,CAAC,UAAU,YAAY,KAAK,CAC7B;AAED,QACE,oBAACC;EACC,GAAK;EACM;EACJ;EACO;EACd,UAAU;EACV,WAAW;EACF;EACD;EACK;EACH;EACA;EACC;EACL;EACA;EACN,GAAI;GACJ;;AAIN,uBAAe"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Textarea.mobile.d.ts","names":[],"sources":["../../../src/components/atoms/Textarea.mobile.tsx"],"sourcesContent":[],"mappings":";;;;;;UAIU,cAAA;;;EAAA,QAAA,CAAA,EAAA,CAAA,IAAA,EAAc,MAAA,EAAA,GAAA,IAWX;EAGR,QAAA,CAAA,EAAA,GAAA,GAAA,IAAA;EACO,OAAA,CAAA,EAAA,GAAA,GAAa,IAAA;EACvB,MAAA,CAAA,EAAA,GAAA,GAAA,IAAA;EAD0B,WAAA,CAAA,EAAA,MAAA;EAI1B,QAAA,CAAA,EAAA,OAAA;EAAc,SAAA,CAAA,EAAA,MAAA;EAEA,SAAA,CAAA,EAAQ,MAAA;EACtB,QAAA,CAAA,EAXW,eAWX;;KARG,4BAAA,GAA+B,OAAA,CAAM,cAUxC,CAAA,OAV8D,UAU9D,CAAA;AACA,KAVU,aAAA,GAAgB,IAU1B,CATA,4BASA,EAAA,cAAA,GAAA,OAAA,GAAA,cAAA,CAAA,GANA,cAMA;AACA,iBALc,QAAA,CAKd;EAAA,KAAA;EAAA,YAAA;EAAA,QAAA;EAAA,QAAA;EAAA,OAAA;EAAA,MAAA;EAAA,WAAA;EAAA,QAAA;EAAA,SAAA;EAAA,SAAA;EAAA,QAAA;EAAA,GAAA;AAAA,CAAA,EAQC,aARD,CAAA,EAQc,mBAAA,CAAA,GAAA,CAAA,OARd"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Textarea.mobile.js","names":["NativeTextarea"],"sources":["../../../src/components/atoms/Textarea.mobile.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Textarea as NativeTextarea } from '@lssm/lib.ui-kit/ui/textarea';\nimport { mapKeyboardToNative, type KeyboardOptions } from '../../lib/keyboard';\n\ninterface BaseFieldProps {\n value?: string;\n defaultValue?: string;\n onChange?: (text: string) => void;\n onSubmit?: () => void;\n onFocus?: () => void;\n onBlur?: () => void;\n placeholder?: string;\n disabled?: boolean;\n maxLength?: number;\n className?: string;\n keyboard?: KeyboardOptions;\n}\n\ntype NativeTextareaComponentProps = React.ComponentProps<typeof NativeTextarea>;\nexport type TextareaProps = Omit<\n NativeTextareaComponentProps,\n 'onChangeText' | 'value' | 'defaultValue'\n> &\n BaseFieldProps;\n\nexport function Textarea({\n value,\n defaultValue,\n onChange,\n onSubmit,\n onFocus,\n onBlur,\n placeholder,\n disabled,\n maxLength,\n className,\n keyboard,\n ...rest\n}: TextareaProps) {\n const nativeKeyboard = mapKeyboardToNative(keyboard);\n\n return (\n <NativeTextarea\n {...(rest as any)}\n className={className as any}\n value={value as any}\n defaultValue={defaultValue as any}\n onChangeText={onChange as any}\n onSubmitEditing={onSubmit as any}\n onFocus={onFocus as any}\n onBlur={onBlur as any}\n placeholder={placeholder}\n editable={!disabled}\n maxLength={maxLength}\n {...(nativeKeyboard as any)}\n />\n );\n}\n\nexport default Textarea;\n"],"mappings":";;;;;;AAyBA,SAAgB,SAAS,EACvB,OACA,cACA,UACA,UACA,SACA,QACA,aACA,UACA,WACA,WACA,UACA,GAAG,QACa;CAChB,MAAM,iBAAiB,oBAAoB,SAAS;AAEpD,QACE,oBAACA;EACC,GAAK;EACM;EACJ;EACO;EACd,cAAc;EACd,iBAAiB;EACR;EACD;EACK;EACb,UAAU,CAAC;EACA;EACX,GAAK;GACL;;AAIN,8BAAe"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"DataViewDetail.d.ts","names":[],"sources":["../../../src/components/data-view/DataViewDetail.tsx"],"sourcesContent":[],"mappings":";;;;;UAWiB,mBAAA;QACT;QACA;EAFS,SAAA,CAAA,EAAA,MAAA;EACT,UAAA,CAAA,EAGO,OAAA,CAAM,SAHb;EACA,aAAA,CAAA,EAGU,OAAA,CAAM,SAHhB;;AAGU,iBAGF,cAAA,CAHQ;EAAA,IAAA;EAAA,IAAA;EAAA,SAAA;EAAA,UAAA;EAAA;AAAA,CAAA,EASrB,mBATqB,CAAA,EASF,mBAAA,CAAA,GAAA,CAAA,OATE"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"DataViewDetail.js","names":[],"sources":["../../../src/components/data-view/DataViewDetail.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport type {\n DataViewSpec,\n DataViewDetailConfig,\n DataViewField,\n} from '@lssm/lib.contracts/data-views';\nimport { cn } from '../../lib/utils';\nimport { getAtPath, formatValue } from './utils';\n\nexport interface DataViewDetailProps {\n spec: DataViewSpec;\n item: Record<string, unknown> | null;\n className?: string;\n emptyState?: React.ReactNode;\n headerActions?: React.ReactNode;\n}\n\nexport function DataViewDetail({\n spec,\n item,\n className,\n emptyState,\n headerActions,\n}: DataViewDetailProps) {\n if (spec.view.kind !== 'detail') {\n throw new Error(\n `DataViewDetail received view kind \"${spec.view.kind}\", expected \"detail\".`\n );\n }\n\n const view = spec.view as DataViewDetailConfig;\n const fields = view.fields;\n\n if (!item) {\n return (\n <div className={cn('flex w-full flex-col gap-4', className)}>\n <div className=\"flex items-center justify-between\">\n <h3 className=\"text-foreground text-base font-semibold\">\n {spec.meta.title}\n </h3>\n {headerActions}\n </div>\n {emptyState ?? (\n <div className=\"border-muted-foreground/40 text-muted-foreground rounded-md border border-dashed p-8 text-center text-sm\">\n Select a record to view details.\n </div>\n )}\n </div>\n );\n }\n\n const sections =\n view.sections && view.sections.length > 0\n ? view.sections\n : [{ fields: fields.map((field) => field.key) }];\n\n return (\n <div className={cn('flex w-full flex-col gap-6', className)}>\n <div className=\"flex items-center justify-between\">\n <div>\n <h3 className=\"text-foreground text-xl font-semibold\">\n {spec.meta.title}\n </h3>\n <p className=\"text-muted-foreground text-sm\">\n {spec.meta.description}\n </p>\n </div>\n {headerActions}\n </div>\n <div className=\"flex flex-col gap-6\">\n {sections.map((section, idx) => (\n <div\n key={idx}\n className=\"border-border bg-card rounded-lg border p-4 shadow-sm\"\n >\n {section.title ? (\n <h4 className=\"text-muted-foreground mb-2 text-sm font-semibold tracking-wide uppercase\">\n {section.title}\n </h4>\n ) : null}\n {section.description ? (\n <p className=\"text-muted-foreground mb-4 text-sm\">\n {section.description}\n </p>\n ) : null}\n <dl className=\"grid gap-4 md:grid-cols-2\">\n {section.fields.map((fieldKey) => {\n const field = fieldByKey(fields, fieldKey);\n if (!field) return null;\n const value = getAtPath(item, field.dataPath);\n return (\n <div key={field.key} className=\"flex flex-col gap-1\">\n <dt className=\"text-muted-foreground/80 text-xs font-semibold uppercase\">\n {field.label}\n </dt>\n <dd className=\"text-foreground text-sm\">\n {formatValue(value, field.format)}\n </dd>\n </div>\n );\n })}\n </dl>\n </div>\n ))}\n </div>\n </div>\n );\n}\n\nfunction fieldByKey(fields: DataViewField[], key: string) {\n return fields.find((field) => field.key === key);\n}\n"],"mappings":";;;;;;;;AAmBA,SAAgB,eAAe,EAC7B,MACA,MACA,WACA,YACA,iBACsB;AACtB,KAAI,KAAK,KAAK,SAAS,SACrB,OAAM,IAAI,MACR,sCAAsC,KAAK,KAAK,KAAK,uBACtD;CAGH,MAAM,OAAO,KAAK;CAClB,MAAM,SAAS,KAAK;AAEpB,KAAI,CAAC,KACH,QACE,qBAAC;EAAI,WAAW,GAAG,8BAA8B,UAAU;aACzD,qBAAC;GAAI,WAAU;cACb,oBAAC;IAAG,WAAU;cACX,KAAK,KAAK;KACR,EACJ;IACG,EACL,cACC,oBAAC;GAAI,WAAU;aAA2G;IAEpH;GAEJ;CAIV,MAAM,WACJ,KAAK,YAAY,KAAK,SAAS,SAAS,IACpC,KAAK,WACL,CAAC,EAAE,QAAQ,OAAO,KAAK,UAAU,MAAM,IAAI,EAAE,CAAC;AAEpD,QACE,qBAAC;EAAI,WAAW,GAAG,8BAA8B,UAAU;aACzD,qBAAC;GAAI,WAAU;cACb,qBAAC,oBACC,oBAAC;IAAG,WAAU;cACX,KAAK,KAAK;KACR,EACL,oBAAC;IAAE,WAAU;cACV,KAAK,KAAK;KACT,IACA,EACL;IACG,EACN,oBAAC;GAAI,WAAU;aACZ,SAAS,KAAK,SAAS,QACtB,qBAAC;IAEC,WAAU;;KAET,QAAQ,QACP,oBAAC;MAAG,WAAU;gBACX,QAAQ;OACN,GACH;KACH,QAAQ,cACP,oBAAC;MAAE,WAAU;gBACV,QAAQ;OACP,GACF;KACJ,oBAAC;MAAG,WAAU;gBACX,QAAQ,OAAO,KAAK,aAAa;OAChC,MAAM,QAAQ,WAAW,QAAQ,SAAS;AAC1C,WAAI,CAAC,MAAO,QAAO;OACnB,MAAM,QAAQ,UAAU,MAAM,MAAM,SAAS;AAC7C,cACE,qBAAC;QAAoB,WAAU;mBAC7B,oBAAC;SAAG,WAAU;mBACX,MAAM;UACJ,EACL,oBAAC;SAAG,WAAU;mBACX,YAAY,OAAO,MAAM,OAAO;UAC9B;UANG,MAAM,IAOV;QAER;OACC;;MA7BA,IA8BD,CACN;IACE;GACF;;AAIV,SAAS,WAAW,QAAyB,KAAa;AACxD,QAAO,OAAO,MAAM,UAAU,MAAM,QAAQ,IAAI"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"DataViewList.d.ts","names":[],"sources":["../../../src/components/data-view/DataViewList.tsx"],"sourcesContent":[],"mappings":";;;;;UAWiB,iBAAA;QACT;SACC;EAFQ,SAAA,CAAA,EAAA,MAAA;EACT,aAAA,CAAA,EAAA,CAAA,IAAA,EAGiB,MAHjB,CAAA,MAAA,EAAA,OAAA,CAAA,EAAA,GAG6C,OAAA,CAAM,SAHnD;EACC,QAAA,CAAA,EAAA,CAAA,IAAA,EAGW,MAHX,CAAA,MAAA,EAAA,OAAA,CAAA,EAAA,GAAA,IAAA;EAEgB,UAAA,CAAA,EAEV,OAAA,CAAM,SAFI;;AACL,iBAIJ,YAAA,CAJI;EAAA,IAAA;EAAA,KAAA;EAAA,SAAA;EAAA,aAAA;EAAA,QAAA;EAAA;AAAA,CAAA,EAWjB,iBAXiB,CAAA,EAWA,mBAAA,CAAA,GAAA,CAAA,OAXA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"DataViewList.js","names":[],"sources":["../../../src/components/data-view/DataViewList.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport type {\n DataViewSpec,\n DataViewListConfig,\n DataViewField,\n} from '@lssm/lib.contracts/data-views';\nimport { cn } from '../../lib/utils';\nimport { getAtPath, formatValue } from './utils';\n\nexport interface DataViewListProps {\n spec: DataViewSpec;\n items: Record<string, unknown>[];\n className?: string;\n renderActions?: (item: Record<string, unknown>) => React.ReactNode;\n onSelect?: (item: Record<string, unknown>) => void;\n emptyState?: React.ReactNode;\n}\n\nexport function DataViewList({\n spec,\n items,\n className,\n renderActions,\n onSelect,\n emptyState,\n}: DataViewListProps) {\n if (spec.view.kind !== 'list') {\n throw new Error(\n `DataViewList received view kind \"${spec.view.kind}\", expected \"list\".`\n );\n }\n const view = spec.view as DataViewListConfig;\n const fields = view.fields;\n const primaryField =\n view.primaryField ??\n fields.find((field) => field.key === view.primaryField)?.key ??\n fields[0]?.key;\n\n if (!items.length) {\n return (\n <div className={cn('flex w-full flex-col gap-4', className)}>\n {emptyState ?? (\n <div className=\"border-muted-foreground/40 text-muted-foreground rounded-md border border-dashed p-8 text-center text-sm\">\n No records available.\n </div>\n )}\n </div>\n );\n }\n\n return (\n <div className={cn('flex w-full flex-col gap-4', className)}>\n {items.map((item, idx) => (\n <button\n type=\"button\"\n key={idx}\n className={cn(\n 'border-muted bg-card hover:border-primary/40 focus-visible:border-primary focus-visible:ring-primary/40 flex w-full flex-col gap-2 rounded-lg border p-4 text-left shadow-sm transition hover:shadow-md focus-visible:ring-2 focus-visible:outline-none',\n view.layout === 'compact' && 'md:flex-row md:items-center md:gap-4'\n )}\n onClick={() => onSelect?.(item)}\n >\n <div className=\"flex flex-1 flex-col gap-1\">\n {primaryField ? (\n <span className=\"text-foreground text-base font-medium\">\n {displayValue(item, fields, primaryField)}\n </span>\n ) : null}\n <div className=\"text-muted-foreground flex flex-wrap gap-x-4 gap-y-1 text-sm\">\n {secondaryFieldKeys(view, primaryField).map((fieldKey) => (\n <span key={fieldKey} className=\"flex items-center gap-1.5\">\n <span className=\"text-foreground/80 font-medium\">\n {fieldLabel(fields, fieldKey)}\n </span>\n <span>{displayValue(item, fields, fieldKey)}</span>\n </span>\n ))}\n </div>\n </div>\n {renderActions ? (\n <div className=\"flex shrink-0 items-center gap-2\">\n {renderActions(item)}\n </div>\n ) : null}\n </button>\n ))}\n </div>\n );\n}\n\nfunction fieldLabel(fields: DataViewField[], key: string) {\n return fields.find((field) => field.key === key)?.label ?? key;\n}\n\nfunction fieldByKey(fields: DataViewField[], key?: string) {\n return fields.find((field) => field.key === key);\n}\n\nfunction displayValue(\n item: Record<string, unknown>,\n fields: DataViewField[],\n key: string\n) {\n const field = fieldByKey(fields, key);\n if (!field) return '';\n const value = getAtPath(item, field.dataPath);\n return formatValue(value, field.format);\n}\n\nfunction secondaryFieldKeys(view: DataViewListConfig, primaryField?: string) {\n if (view.secondaryFields?.length) return view.secondaryFields;\n return view.fields\n .map((field) => field.key)\n .filter((key) => key !== primaryField);\n}\n"],"mappings":";;;;;;;;AAoBA,SAAgB,aAAa,EAC3B,MACA,OACA,WACA,eACA,UACA,cACoB;AACpB,KAAI,KAAK,KAAK,SAAS,OACrB,OAAM,IAAI,MACR,oCAAoC,KAAK,KAAK,KAAK,qBACpD;CAEH,MAAM,OAAO,KAAK;CAClB,MAAM,SAAS,KAAK;CACpB,MAAM,eACJ,KAAK,gBACL,OAAO,MAAM,UAAU,MAAM,QAAQ,KAAK,aAAa,EAAE,OACzD,OAAO,IAAI;AAEb,KAAI,CAAC,MAAM,OACT,QACE,oBAAC;EAAI,WAAW,GAAG,8BAA8B,UAAU;YACxD,cACC,oBAAC;GAAI,WAAU;aAA2G;IAEpH;GAEJ;AAIV,QACE,oBAAC;EAAI,WAAW,GAAG,8BAA8B,UAAU;YACxD,MAAM,KAAK,MAAM,QAChB,qBAAC;GACC,MAAK;GAEL,WAAW,GACT,2PACA,KAAK,WAAW,aAAa,uCAC9B;GACD,eAAe,WAAW,KAAK;cAE/B,qBAAC;IAAI,WAAU;eACZ,eACC,oBAAC;KAAK,WAAU;eACb,aAAa,MAAM,QAAQ,aAAa;MACpC,GACL,MACJ,oBAAC;KAAI,WAAU;eACZ,mBAAmB,MAAM,aAAa,CAAC,KAAK,aAC3C,qBAAC;MAAoB,WAAU;iBAC7B,oBAAC;OAAK,WAAU;iBACb,WAAW,QAAQ,SAAS;QACxB,EACP,oBAAC,oBAAM,aAAa,MAAM,QAAQ,SAAS,GAAQ;QAJ1C,SAKJ,CACP;MACE;KACF,EACL,gBACC,oBAAC;IAAI,WAAU;cACZ,cAAc,KAAK;KAChB,GACJ;KA5BC,IA6BE,CACT;GACE;;AAIV,SAAS,WAAW,QAAyB,KAAa;AACxD,QAAO,OAAO,MAAM,UAAU,MAAM,QAAQ,IAAI,EAAE,SAAS;;AAG7D,SAAS,WAAW,QAAyB,KAAc;AACzD,QAAO,OAAO,MAAM,UAAU,MAAM,QAAQ,IAAI;;AAGlD,SAAS,aACP,MACA,QACA,KACA;CACA,MAAM,QAAQ,WAAW,QAAQ,IAAI;AACrC,KAAI,CAAC,MAAO,QAAO;AAEnB,QAAO,YADO,UAAU,MAAM,MAAM,SAAS,EACnB,MAAM,OAAO;;AAGzC,SAAS,mBAAmB,MAA0B,cAAuB;AAC3E,KAAI,KAAK,iBAAiB,OAAQ,QAAO,KAAK;AAC9C,QAAO,KAAK,OACT,KAAK,UAAU,MAAM,IAAI,CACzB,QAAQ,QAAQ,QAAQ,aAAa"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"DataViewRenderer.d.ts","names":[],"sources":["../../../src/components/data-view/DataViewRenderer.tsx"],"sourcesContent":[],"mappings":";;;;;UAsBiB,qBAAA;QACT;UACE;EAFO,IAAA,CAAA,EAGR,MAHQ,CAAA,MAAA,EAAA,OAAqB,CAAA,GAAA,IAAA;EAC9B,SAAA,CAAA,EAAA,MAAA;EACE,aAAA,CAAA,EAAA,CAAA,IAAA,EAGe,MAHf,CAAA,MAAA,EAAA,OAAA,CAAA,EAAA,GAG2C,OAAA,CAAM,SAHjD;EACD,QAAA,CAAA,EAAA,CAAA,IAAA,EAGW,MAHX,CAAA,MAAA,EAAA,OAAA,CAAA,EAAA,GAAA,IAAA;EAEgB,UAAA,CAAA,EAAA,CAAA,IAAA,EAEH,MAFG,CAAA,MAAA,EAAA,OAAA,CAAA,EAAA,GAAA,IAAA;EAA4B,aAAM,CAAA,EAGzC,OAAA,CAAM,SAHmC;EACvC,UAAA,CAAA,EAGL,OAAA,CAAM,SAHD;EACE,MAAA,CAAA,EAGX,OAAA,CAAM,SAHK;EACJ,MAAM,CAAA,EAAA,MAAA;EACT,cAAM,CAAA,EAAA,CAAA,KAAA,EAAA,MAAA,EAAA,GAAA,IAAA;EACV,OAAM,CAAA,EAKL,MALK,CAAA,MAAA,EAAA,GAAA,CAAA;EAKL,cAAA,CAAA,EAAA,CAAA,OAAA,EACiB,MADjB,CAAA,MAAA,EAAA,GAAA,CAAA,EAAA,GAAA,IAAA;EACiB,UAAA,CAAA,EAAA;IAAM,IAAA,EAAA,MAAA;IAWnB,QAAA,EAAA,MAAgB;IAC9B,KAAA,EAAA,MAAA;EACA,CAAA;EACA,YAAA,CAAA,EAAA,CAAA,IAAA,EAAA,MAAA,EAAA,GAAA,IAAA;;AAEA,iBALc,gBAAA,CAKd;EAAA,IAAA;EAAA,KAAA;EAAA,IAAA;EAAA,SAAA;EAAA,aAAA;EAAA,QAAA;EAAA,UAAA;EAAA,aAAA;EAAA,UAAA;EAAA,MAAA;EAAA,MAAA;EAAA,cAAA;EAAA,OAAA;EAAA,cAAA;EAAA,UAAA;EAAA;AAAA,CAAA,EAYC,qBAZD,CAAA,EAYsB,mBAAA,CAAA,GAAA,CAAA,OAZtB"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"DataViewRenderer.js","names":["React","listView: DataViewListConfig"],"sources":["../../../src/components/data-view/DataViewRenderer.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport type {\n DataViewGridConfig,\n DataViewListConfig,\n DataViewSpec,\n} from '@lssm/lib.contracts/data-views';\nimport { DataViewList } from './DataViewList';\nimport { DataViewTable } from './DataViewTable';\nimport { DataViewDetail } from './DataViewDetail';\nimport { FiltersToolbar } from '../molecules/FiltersToolbar';\nimport {\n Pagination,\n PaginationContent,\n PaginationItem,\n PaginationLink,\n PaginationNext,\n PaginationPrevious,\n PaginationEllipsis,\n} from '@lssm/lib.ui-kit-web/ui/pagination';\n\nexport interface DataViewRendererProps {\n spec: DataViewSpec;\n items?: Record<string, unknown>[];\n item?: Record<string, unknown> | null;\n className?: string;\n renderActions?: (item: Record<string, unknown>) => React.ReactNode;\n onSelect?: (item: Record<string, unknown>) => void;\n onRowClick?: (item: Record<string, unknown>) => void;\n headerActions?: React.ReactNode;\n emptyState?: React.ReactNode;\n footer?: React.ReactNode;\n\n // Filters & Search\n search?: string;\n onSearchChange?: (value: string) => void;\n filters?: Record<string, any>;\n onFilterChange?: (filters: Record<string, any>) => void;\n\n // Pagination\n pagination?: {\n page: number;\n pageSize: number;\n total: number;\n };\n onPageChange?: (page: number) => void;\n}\n\nexport function DataViewRenderer({\n spec,\n items = [],\n item = null,\n className,\n renderActions,\n onSelect,\n onRowClick,\n headerActions,\n emptyState,\n footer,\n search,\n onSearchChange,\n filters,\n onFilterChange,\n pagination,\n onPageChange,\n}: DataViewRendererProps) {\n const viewContent = React.useMemo(() => {\n switch (spec.view.kind) {\n case 'list':\n return (\n <DataViewList\n spec={spec}\n items={items}\n className={className}\n renderActions={renderActions}\n onSelect={onSelect}\n emptyState={emptyState}\n />\n );\n case 'table':\n return (\n <DataViewTable\n spec={spec}\n items={items}\n className={className}\n onRowClick={onRowClick}\n emptyState={emptyState}\n headerActions={headerActions}\n footer={footer}\n />\n );\n case 'detail':\n return (\n <DataViewDetail\n spec={spec}\n item={item}\n className={className}\n emptyState={emptyState}\n headerActions={headerActions}\n />\n );\n case 'grid': {\n const grid = spec.view as DataViewGridConfig;\n const listView: DataViewListConfig = {\n kind: 'list',\n layout: 'card',\n fields: grid.fields,\n filters: grid.filters,\n actions: grid.actions,\n primaryField: grid.primaryField,\n secondaryFields: grid.secondaryFields,\n };\n const listSpec = {\n ...spec,\n view: listView,\n } satisfies DataViewSpec;\n return (\n <DataViewList\n spec={listSpec}\n items={items}\n className={className}\n renderActions={renderActions}\n onSelect={onSelect}\n emptyState={emptyState}\n />\n );\n }\n default:\n return <div className={className}>Unsupported data view kind</div>;\n }\n }, [\n spec,\n items,\n item,\n className,\n renderActions,\n onSelect,\n onRowClick,\n headerActions,\n emptyState,\n footer,\n ]);\n\n // Only render toolbar/pagination if it's a collection view\n const isCollection =\n spec.view.kind === 'list' ||\n spec.view.kind === 'table' ||\n spec.view.kind === 'grid';\n\n if (!isCollection) {\n return <>{viewContent}</>;\n }\n\n return (\n <div className=\"space-y-4\">\n {(spec.view.filters?.length || onSearchChange) && (\n <FiltersToolbar\n searchValue={search}\n onSearchChange={onSearchChange}\n searchPlaceholder=\"Search...\"\n activeChips={\n filters\n ? Object.entries(filters).map(([key, value]) => ({\n key,\n label: `${key}: ${value}`,\n onRemove: () => {\n const newFilters = { ...filters };\n delete newFilters[key];\n onFilterChange?.(newFilters);\n },\n }))\n : []\n }\n onClearAll={\n filters && Object.keys(filters).length > 0\n ? () => onFilterChange?.({})\n : undefined\n }\n right={headerActions}\n >\n {/* Render filter dropdowns here if needed */}\n </FiltersToolbar>\n )}\n\n {viewContent}\n\n {pagination && pagination.total > 0 && (\n <div className=\"py-4\">\n <Pagination>\n <PaginationContent>\n <PaginationItem>\n <PaginationPrevious\n href=\"#\"\n onClick={(e) => {\n e.preventDefault();\n if (pagination.page > 1) {\n onPageChange?.(pagination.page - 1);\n }\n }}\n aria-disabled={pagination.page <= 1}\n className={\n pagination.page <= 1 ? 'pointer-events-none opacity-50' : ''\n }\n />\n </PaginationItem>\n\n {/* Simplified pagination: show current page */}\n <PaginationItem>\n <PaginationLink href=\"#\" isActive>\n {pagination.page}\n </PaginationLink>\n </PaginationItem>\n\n <PaginationItem>\n <PaginationNext\n href=\"#\"\n onClick={(e) => {\n e.preventDefault();\n const totalPages = Math.ceil(\n pagination.total / pagination.pageSize\n );\n if (pagination.page < totalPages) {\n onPageChange?.(pagination.page + 1);\n }\n }}\n aria-disabled={\n pagination.page >=\n Math.ceil(pagination.total / pagination.pageSize)\n }\n className={\n pagination.page >=\n Math.ceil(pagination.total / pagination.pageSize)\n ? 'pointer-events-none opacity-50'\n : ''\n }\n />\n </PaginationItem>\n </PaginationContent>\n </Pagination>\n <div className=\"text-muted-foreground mt-2 text-center text-sm\">\n Page {pagination.page} of{' '}\n {Math.ceil(pagination.total / pagination.pageSize)} (\n {pagination.total} items)\n </div>\n </div>\n )}\n </div>\n );\n}\n"],"mappings":";;;;;;;;;;;AAiDA,SAAgB,iBAAiB,EAC/B,MACA,QAAQ,EAAE,EACV,OAAO,MACP,WACA,eACA,UACA,YACA,eACA,YACA,QACA,QACA,gBACA,SACA,gBACA,YACA,gBACwB;CACxB,MAAM,cAAcA,QAAM,cAAc;AACtC,UAAQ,KAAK,KAAK,MAAlB;GACE,KAAK,OACH,QACE,oBAAC;IACO;IACC;IACI;IACI;IACL;IACE;KACZ;GAEN,KAAK,QACH,QACE,oBAAC;IACO;IACC;IACI;IACC;IACA;IACG;IACP;KACR;GAEN,KAAK,SACH,QACE,oBAAC;IACO;IACA;IACK;IACC;IACG;KACf;GAEN,KAAK,QAAQ;IACX,MAAM,OAAO,KAAK;IAClB,MAAMC,WAA+B;KACnC,MAAM;KACN,QAAQ;KACR,QAAQ,KAAK;KACb,SAAS,KAAK;KACd,SAAS,KAAK;KACd,cAAc,KAAK;KACnB,iBAAiB,KAAK;KACvB;AAKD,WACE,oBAAC;KACC,MANa;MACf,GAAG;MACH,MAAM;MACP;KAIU;KACI;KACI;KACL;KACE;MACZ;;GAGN,QACE,QAAO,oBAAC;IAAe;cAAW;KAAgC;;IAErE;EACD;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACD,CAAC;AAQF,KAAI,EAJF,KAAK,KAAK,SAAS,UACnB,KAAK,KAAK,SAAS,WACnB,KAAK,KAAK,SAAS,QAGnB,QAAO,0CAAG,cAAe;AAG3B,QACE,qBAAC;EAAI,WAAU;;IACX,KAAK,KAAK,SAAS,UAAU,mBAC7B,oBAAC;IACC,aAAa;IACG;IAChB,mBAAkB;IAClB,aACE,UACI,OAAO,QAAQ,QAAQ,CAAC,KAAK,CAAC,KAAK,YAAY;KAC7C;KACA,OAAO,GAAG,IAAI,IAAI;KAClB,gBAAgB;MACd,MAAM,aAAa,EAAE,GAAG,SAAS;AACjC,aAAO,WAAW;AAClB,uBAAiB,WAAW;;KAE/B,EAAE,GACH,EAAE;IAER,YACE,WAAW,OAAO,KAAK,QAAQ,CAAC,SAAS,UAC/B,iBAAiB,EAAE,CAAC,GAC1B;IAEN,OAAO;KAGQ;GAGlB;GAEA,cAAc,WAAW,QAAQ,KAChC,qBAAC;IAAI,WAAU;eACb,oBAAC,wBACC,qBAAC;KACC,oBAAC,4BACC,oBAAC;MACC,MAAK;MACL,UAAU,MAAM;AACd,SAAE,gBAAgB;AAClB,WAAI,WAAW,OAAO,EACpB,gBAAe,WAAW,OAAO,EAAE;;MAGvC,iBAAe,WAAW,QAAQ;MAClC,WACE,WAAW,QAAQ,IAAI,mCAAmC;OAE5D,GACa;KAGjB,oBAAC,4BACC,oBAAC;MAAe,MAAK;MAAI;gBACtB,WAAW;OACG,GACF;KAEjB,oBAAC,4BACC,oBAAC;MACC,MAAK;MACL,UAAU,MAAM;AACd,SAAE,gBAAgB;OAClB,MAAM,aAAa,KAAK,KACtB,WAAW,QAAQ,WAAW,SAC/B;AACD,WAAI,WAAW,OAAO,WACpB,gBAAe,WAAW,OAAO,EAAE;;MAGvC,iBACE,WAAW,QACX,KAAK,KAAK,WAAW,QAAQ,WAAW,SAAS;MAEnD,WACE,WAAW,QACX,KAAK,KAAK,WAAW,QAAQ,WAAW,SAAS,GAC7C,mCACA;OAEN,GACa;QACC,GACT,EACb,qBAAC;KAAI,WAAU;;MAAiD;MACxD,WAAW;MAAK;MAAI;MACzB,KAAK,KAAK,WAAW,QAAQ,WAAW,SAAS;MAAC;MAClD,WAAW;MAAM;;MACd;KACF;;GAEJ"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"DataViewTable.d.ts","names":[],"sources":["../../../src/components/data-view/DataViewTable.tsx"],"sourcesContent":[],"mappings":";;;;;UAWiB,kBAAA;QACT;SACC;EAFQ,SAAA,CAAA,EAAA,MAAA;EACT,UAAA,CAAA,EAAA,CAAA,IAAA,EAGc,MAHd,CAAA,MAAA,EAAA,OAAA,CAAA,EAAA,GAAA,IAAA;EACC,UAAA,CAAA,EAGM,OAAA,CAAM,SAHZ;EAEa,aAAA,CAAA,EAEJ,OAAA,CAAM,SAFF;EACP,MAAM,CAAA,EAEV,OAAA,CAAM,SAFI;;AAEV,iBAGK,aAAA,CAHC;EAAA,IAAA;EAAA,KAAA;EAAA,SAAA;EAAA,UAAA;EAAA,UAAA;EAAA,aAAA;EAAA;AAAA,CAAA,EAWd,kBAXc,CAAA,EAWI,mBAAA,CAAA,GAAA,CAAA,OAXJ"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"DataViewTable.js","names":[],"sources":["../../../src/components/data-view/DataViewTable.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport type {\n DataViewSpec,\n DataViewTableConfig,\n DataViewField,\n} from '@lssm/lib.contracts/data-views';\nimport { cn } from '../../lib/utils';\nimport { getAtPath, formatValue } from './utils';\n\nexport interface DataViewTableProps {\n spec: DataViewSpec;\n items: Record<string, unknown>[];\n className?: string;\n onRowClick?: (item: Record<string, unknown>) => void;\n emptyState?: React.ReactNode;\n headerActions?: React.ReactNode;\n footer?: React.ReactNode;\n}\n\nexport function DataViewTable({\n spec,\n items,\n className,\n onRowClick,\n emptyState,\n headerActions,\n footer,\n}: DataViewTableProps) {\n if (spec.view.kind !== 'table') {\n throw new Error(\n `DataViewTable received view kind \"${spec.view.kind}\", expected \"table\".`\n );\n }\n\n const view = spec.view as DataViewTableConfig;\n const fields = view.fields;\n const columns =\n view.columns?.map((column) => ({\n ...column,\n label: column.label ?? fieldLabel(fields, column.field),\n })) ??\n fields.map((field) => ({\n field: field.key,\n label: field.label,\n align: 'left' as const,\n }));\n\n if (!items.length) {\n return (\n <div className={cn('flex w-full flex-col gap-4', className)}>\n <div className=\"flex items-center justify-between\">\n <h3 className=\"text-foreground text-base font-semibold\">\n {spec.meta.title}\n </h3>\n {headerActions}\n </div>\n {emptyState ?? (\n <div className=\"border-muted-foreground/40 text-muted-foreground rounded-md border border-dashed p-8 text-center text-sm\">\n No records available.\n </div>\n )}\n </div>\n );\n }\n\n return (\n <div className={cn('flex w-full flex-col gap-4', className)}>\n <div className=\"flex items-center justify-between\">\n <h3 className=\"text-foreground text-base font-semibold\">\n {spec.meta.title}\n </h3>\n {headerActions}\n </div>\n <div className=\"border-border bg-card overflow-x-auto rounded-lg border shadow-sm\">\n <table\n className={cn(\n 'divide-border min-w-full divide-y text-sm',\n view.density === 'compact' ? 'text-sm' : 'text-base'\n )}\n >\n <thead className=\"bg-muted/50\">\n <tr>\n {columns.map((column, columnIdx) => (\n <th\n key={`${column.field}.${columnIdx}`}\n scope=\"col\"\n className={cn(\n 'text-muted-foreground px-4 py-3 text-left font-semibold',\n alignmentClass(column.align)\n )}\n >\n {column.label}\n </th>\n ))}\n </tr>\n </thead>\n <tbody className=\"divide-border bg-background divide-y\">\n {items.map((item, rowIdx) => (\n <tr\n key={rowIdx}\n className={cn(\n onRowClick &&\n 'hover:bg-muted/30 cursor-pointer transition-colors'\n )}\n onClick={() => onRowClick?.(item)}\n >\n {columns.map((column) => (\n <td\n key={column.field}\n className={cn(\n 'text-foreground px-4 py-3',\n alignmentClass(column.align)\n )}\n >\n {displayValue(item, fields, column.field)}\n </td>\n ))}\n </tr>\n ))}\n </tbody>\n </table>\n </div>\n {footer}\n </div>\n );\n}\n\nfunction fieldLabel(fields: DataViewField[], key: string) {\n return fields.find((field) => field.key === key)?.label ?? key;\n}\n\nfunction fieldByKey(fields: DataViewField[], key: string) {\n return fields.find((field) => field.key === key);\n}\n\nfunction displayValue(\n item: Record<string, unknown>,\n fields: DataViewField[],\n key: string\n) {\n const field = fieldByKey(fields, key);\n if (!field) return '';\n const value = getAtPath(item, field.dataPath);\n return formatValue(value, field.format);\n}\n\nfunction alignmentClass(\n align: 'left' | 'center' | 'right' | undefined\n): string | undefined {\n switch (align) {\n case 'center':\n return 'text-center';\n case 'right':\n return 'text-right';\n default:\n return 'text-left';\n }\n}\n"],"mappings":";;;;;;;;AAqBA,SAAgB,cAAc,EAC5B,MACA,OACA,WACA,YACA,YACA,eACA,UACqB;AACrB,KAAI,KAAK,KAAK,SAAS,QACrB,OAAM,IAAI,MACR,qCAAqC,KAAK,KAAK,KAAK,sBACrD;CAGH,MAAM,OAAO,KAAK;CAClB,MAAM,SAAS,KAAK;CACpB,MAAM,UACJ,KAAK,SAAS,KAAK,YAAY;EAC7B,GAAG;EACH,OAAO,OAAO,SAAS,WAAW,QAAQ,OAAO,MAAM;EACxD,EAAE,IACH,OAAO,KAAK,WAAW;EACrB,OAAO,MAAM;EACb,OAAO,MAAM;EACb,OAAO;EACR,EAAE;AAEL,KAAI,CAAC,MAAM,OACT,QACE,qBAAC;EAAI,WAAW,GAAG,8BAA8B,UAAU;aACzD,qBAAC;GAAI,WAAU;cACb,oBAAC;IAAG,WAAU;cACX,KAAK,KAAK;KACR,EACJ;IACG,EACL,cACC,oBAAC;GAAI,WAAU;aAA2G;IAEpH;GAEJ;AAIV,QACE,qBAAC;EAAI,WAAW,GAAG,8BAA8B,UAAU;;GACzD,qBAAC;IAAI,WAAU;eACb,oBAAC;KAAG,WAAU;eACX,KAAK,KAAK;MACR,EACJ;KACG;GACN,oBAAC;IAAI,WAAU;cACb,qBAAC;KACC,WAAW,GACT,6CACA,KAAK,YAAY,YAAY,YAAY,YAC1C;gBAED,oBAAC;MAAM,WAAU;gBACf,oBAAC,kBACE,QAAQ,KAAK,QAAQ,cACpB,oBAAC;OAEC,OAAM;OACN,WAAW,GACT,2DACA,eAAe,OAAO,MAAM,CAC7B;iBAEA,OAAO;SAPH,GAAG,OAAO,MAAM,GAAG,YAQrB,CACL,GACC;OACC,EACR,oBAAC;MAAM,WAAU;gBACd,MAAM,KAAK,MAAM,WAChB,oBAAC;OAEC,WAAW,GACT,cACE,qDACH;OACD,eAAe,aAAa,KAAK;iBAEhC,QAAQ,KAAK,WACZ,oBAAC;QAEC,WAAW,GACT,6BACA,eAAe,OAAO,MAAM,CAC7B;kBAEA,aAAa,MAAM,QAAQ,OAAO,MAAM;UANpC,OAAO,MAOT,CACL;SAjBG,OAkBF,CACL;OACI;MACF;KACJ;GACL;;GACG;;AAIV,SAAS,WAAW,QAAyB,KAAa;AACxD,QAAO,OAAO,MAAM,UAAU,MAAM,QAAQ,IAAI,EAAE,SAAS;;AAG7D,SAAS,WAAW,QAAyB,KAAa;AACxD,QAAO,OAAO,MAAM,UAAU,MAAM,QAAQ,IAAI;;AAGlD,SAAS,aACP,MACA,QACA,KACA;CACA,MAAM,QAAQ,WAAW,QAAQ,IAAI;AACrC,KAAI,CAAC,MAAO,QAAO;AAEnB,QAAO,YADO,UAAU,MAAM,MAAM,SAAS,EACnB,MAAM,OAAO;;AAGzC,SAAS,eACP,OACoB;AACpB,SAAQ,OAAR;EACE,KAAK,SACH,QAAO;EACT,KAAK,QACH,QAAO;EACT,QACE,QAAO"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"utils.d.ts","names":[],"sources":["../../../src/components/data-view/utils.ts"],"sourcesContent":[],"mappings":";iBAEgB,SAAA,SACN;AADM,iBAuBA,WAAA,CAtBA,KAAA,EAAA,OAAA,EAAA,MAAA,CAAA,EAAA,MAAA,CAAA,EAAA,MAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"utils.js","names":["current: unknown"],"sources":["../../../src/components/data-view/utils.ts"],"sourcesContent":["'use client';\n\nexport function getAtPath(\n source: Record<string, unknown> | undefined,\n path: string\n): unknown {\n if (!source) return undefined;\n if (!path) return source;\n const segments = path\n .replace(/\\[(\\d+)\\]/g, '.$1')\n .split('.')\n .filter(Boolean);\n\n let current: unknown = source;\n for (const segment of segments) {\n if (\n current == null ||\n (typeof current !== 'object' && !Array.isArray(current))\n )\n return undefined;\n current = (current as Record<string, unknown>)[segment];\n }\n return current;\n}\n\nexport function formatValue(value: unknown, format?: string): string {\n if (value == null) return '';\n switch (format) {\n case 'boolean':\n return value ? 'Yes' : 'No';\n case 'currency':\n return typeof value === 'number'\n ? new Intl.NumberFormat(undefined, {\n style: 'currency',\n currency: 'USD',\n }).format(value)\n : String(value);\n case 'percentage':\n return typeof value === 'number'\n ? `${(value * 100).toFixed(1)}%`\n : String(value);\n case 'date':\n return formatDate(value, {\n dateStyle: 'medium',\n });\n case 'dateTime':\n return formatDate(value, {\n dateStyle: 'medium',\n timeStyle: 'short',\n });\n default:\n return String(value);\n }\n}\n\nfunction formatDate(\n value: unknown,\n options: Intl.DateTimeFormatOptions\n): string {\n if (value instanceof Date) {\n return new Intl.DateTimeFormat(undefined, options).format(value);\n }\n if (typeof value === 'string' || typeof value === 'number') {\n const date = new Date(value);\n if (!Number.isNaN(date.getTime())) {\n return new Intl.DateTimeFormat(undefined, options).format(date);\n }\n }\n return String(value ?? '');\n}\n"],"mappings":";;;AAEA,SAAgB,UACd,QACA,MACS;AACT,KAAI,CAAC,OAAQ,QAAO;AACpB,KAAI,CAAC,KAAM,QAAO;CAClB,MAAM,WAAW,KACd,QAAQ,cAAc,MAAM,CAC5B,MAAM,IAAI,CACV,OAAO,QAAQ;CAElB,IAAIA,UAAmB;AACvB,MAAK,MAAM,WAAW,UAAU;AAC9B,MACE,WAAW,QACV,OAAO,YAAY,YAAY,CAAC,MAAM,QAAQ,QAAQ,CAEvD,QAAO;AACT,YAAW,QAAoC;;AAEjD,QAAO;;AAGT,SAAgB,YAAY,OAAgB,QAAyB;AACnE,KAAI,SAAS,KAAM,QAAO;AAC1B,SAAQ,QAAR;EACE,KAAK,UACH,QAAO,QAAQ,QAAQ;EACzB,KAAK,WACH,QAAO,OAAO,UAAU,WACpB,IAAI,KAAK,aAAa,QAAW;GAC/B,OAAO;GACP,UAAU;GACX,CAAC,CAAC,OAAO,MAAM,GAChB,OAAO,MAAM;EACnB,KAAK,aACH,QAAO,OAAO,UAAU,WACpB,IAAI,QAAQ,KAAK,QAAQ,EAAE,CAAC,KAC5B,OAAO,MAAM;EACnB,KAAK,OACH,QAAO,WAAW,OAAO,EACvB,WAAW,UACZ,CAAC;EACJ,KAAK,WACH,QAAO,WAAW,OAAO;GACvB,WAAW;GACX,WAAW;GACZ,CAAC;EACJ,QACE,QAAO,OAAO,MAAM;;;AAI1B,SAAS,WACP,OACA,SACQ;AACR,KAAI,iBAAiB,KACnB,QAAO,IAAI,KAAK,eAAe,QAAW,QAAQ,CAAC,OAAO,MAAM;AAElE,KAAI,OAAO,UAAU,YAAY,OAAO,UAAU,UAAU;EAC1D,MAAM,OAAO,IAAI,KAAK,MAAM;AAC5B,MAAI,CAAC,OAAO,MAAM,KAAK,SAAS,CAAC,CAC/B,QAAO,IAAI,KAAK,eAAe,QAAW,QAAQ,CAAC,OAAO,KAAK;;AAGnE,QAAO,OAAO,SAAS,GAAG"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"FormCardLayout.d.ts","names":[],"sources":["../../../src/components/forms/FormCardLayout.tsx"],"sourcesContent":[],"mappings":";;;;UASiB,mBAAA;UACP,OAAA,CAAM;gBACA,OAAA,CAAM;EAFL,OAAA,CAAA,EAGL,OAAA,CAAM,SAHkB;EAC1B,QAAM,EAGJ,OAAA,CAAM,SAHF;EACA,SAAM,CAAA,EAAA,MAAA;EACV,gBAAM,CAAA,EAAA,MAAA;;AACS,iBAKX,cAAA,CALW;EAAA,KAAA;EAAA,WAAA;EAAA,OAAA;EAAA,QAAA;EAAA,SAAA;EAAA;AAAA,CAAA,EAYxB,mBAZwB,CAAA,EAYL,mBAAA,CAAA,GAAA,CAAA,OAZK"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"FormCardLayout.js","names":[],"sources":["../../../src/components/forms/FormCardLayout.tsx"],"sourcesContent":["import * as React from 'react';\nimport {\n Card,\n CardContent,\n CardHeader,\n CardTitle,\n} from '@lssm/lib.ui-kit-web/ui/card';\nimport { cn } from '@lssm/lib.ui-kit-web/ui/utils';\n\nexport interface FormCardLayoutProps {\n title?: React.ReactNode;\n description?: React.ReactNode;\n actions?: React.ReactNode;\n children: React.ReactNode;\n className?: string;\n contentClassName?: string;\n}\n\nexport function FormCardLayout({\n title,\n description,\n actions,\n children,\n className,\n contentClassName,\n}: FormCardLayoutProps) {\n return (\n <Card className={cn('border-none shadow-2xs', className)}>\n {(title || description) && (\n <CardHeader>\n {title && <CardTitle>{title}</CardTitle>}\n {description && (\n <div className=\"text-muted-foreground text-base\">{description}</div>\n )}\n </CardHeader>\n )}\n <CardContent className={cn('p-4 md:p-5', contentClassName)}>\n <div className=\"space-y-4\">{children}</div>\n {actions && (\n <div className=\"mt-4 flex justify-end gap-2\">{actions}</div>\n )}\n </CardContent>\n </Card>\n );\n}\n"],"mappings":";;;;;;AAkBA,SAAgB,eAAe,EAC7B,OACA,aACA,SACA,UACA,WACA,oBACsB;AACtB,QACE,qBAAC;EAAK,WAAW,GAAG,0BAA0B,UAAU;cACpD,SAAS,gBACT,qBAAC,yBACE,SAAS,oBAAC,uBAAW,QAAkB,EACvC,eACC,oBAAC;GAAI,WAAU;aAAmC;IAAkB,IAE3D,EAEf,qBAAC;GAAY,WAAW,GAAG,cAAc,iBAAiB;cACxD,oBAAC;IAAI,WAAU;IAAa;KAAe,EAC1C,WACC,oBAAC;IAAI,WAAU;cAA+B;KAAc;IAElD;GACT"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"FormDialog.d.ts","names":[],"sources":["../../../src/components/forms/FormDialog.tsx"],"sourcesContent":[],"mappings":";;;;UAYiB,eAAA;;;EAAA,KAAA,EAGR,OAAA,CAAM,SAHiB;EAGvB,WAAM,CAAA,EACC,OAAA,CAAM,SADP;EACC,QAAM,EACV,OAAA,CAAM,SADI;EACV,MAAM,CAAA,EACP,OAAA,CAAM,SADC;EACP,QAAM,CAAA,EAAA,MAAA;;AAID,iBAAA,UAAA,CAAU;EAAA,IAAA;EAAA,YAAA;EAAA,KAAA;EAAA,WAAA;EAAA,QAAA;EAAA,MAAA;EAAA;AAAA,CAAA,EAQvB,eARuB,CAAA,EAQR,mBAAA,CAAA,GAAA,CAAA,OARQ"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"FormDialog.js","names":[],"sources":["../../../src/components/forms/FormDialog.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport {\n Dialog,\n DialogContent,\n DialogDescription,\n DialogFooter,\n DialogHeader,\n DialogTitle,\n} from '@lssm/lib.ui-kit-web/ui/dialog';\n\nexport interface FormDialogProps {\n open: boolean;\n onOpenChange: (open: boolean) => void;\n title: React.ReactNode;\n description?: React.ReactNode;\n children: React.ReactNode; // form body\n footer?: React.ReactNode; // actions\n maxWidth?: string; // e.g., 'sm:max-w-[480px]'\n}\n\nexport function FormDialog({\n open,\n onOpenChange,\n title,\n description,\n children,\n footer,\n maxWidth = 'sm:max-w-[480px]',\n}: FormDialogProps) {\n return (\n <Dialog open={open} onOpenChange={onOpenChange}>\n <DialogContent className={maxWidth}>\n <DialogHeader>\n <DialogTitle>{title}</DialogTitle>\n {description && <DialogDescription>{description}</DialogDescription>}\n </DialogHeader>\n {children}\n {footer && <DialogFooter>{footer}</DialogFooter>}\n </DialogContent>\n </Dialog>\n );\n}\n"],"mappings":";;;;;;;AAsBA,SAAgB,WAAW,EACzB,MACA,cACA,OACA,aACA,UACA,QACA,WAAW,sBACO;AAClB,QACE,oBAAC;EAAa;EAAoB;YAChC,qBAAC;GAAc,WAAW;;IACxB,qBAAC,2BACC,oBAAC,yBAAa,QAAoB,EACjC,eAAe,oBAAC,+BAAmB,cAAgC,IACvD;IACd;IACA,UAAU,oBAAC,0BAAc,SAAsB;;IAClC;GACT"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"FormLayout.d.ts","names":[],"sources":["../../../src/components/forms/FormLayout.tsx"],"sourcesContent":[],"mappings":";;;;iBAKgB,WAAA;;;AAAhB;YAIY,OAAA,CAAM;;AAJlB,CAAA,CAAA,EAMC,mBAAA,CAAA,GAAA,CAAA,OAN0B;AACzB,iBASc,OAAA,CATd;EAAA,QAAA;EAAA;CAAA,EAAA;EACA,QAAA,EAYU,OAAA,CAAM,SAZhB;EAEU,SAAM,CAAA,EAAA,MAAA;CAEjB,CAAA,EAUA,mBAAA,CAAA,GAAA,CAAA,OAVA;AAAA,iBAkBe,QAAA,CAlBf;EAAA,QAAA;EAAA,IAAA;EAAA;CAAA,EAAA;EAIe,QAAA,EAmBJ,OAAA,CAAM,SAnBK;EACrB,IAAA,CAAA,EAAA,CAAA,GAAA,CAAA,GAAA,CAAA,GAAA,CAAA;EACA,SAAA,CAAA,EAAA,MAAA;CAEU,CAAA,EAkBX,mBAAA,CAAA,GAAA,CAAA,OAlBiB"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"FormLayout.js","names":[],"sources":["../../../src/components/forms/FormLayout.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { cn } from '@lssm/lib.ui-kit-web/ui/utils';\n\nexport function FormSection({\n children,\n className,\n}: {\n children: React.ReactNode;\n className?: string;\n}) {\n return <div className={cn('space-y-4', className)}>{children}</div>;\n}\n\nexport function FormRow({\n children,\n className,\n}: {\n children: React.ReactNode;\n className?: string;\n}) {\n return (\n <div className={cn('grid grid-cols-1 gap-4 md:grid-cols-2', className)}>\n {children}\n </div>\n );\n}\n\nexport function FormGrid({\n children,\n cols = 2,\n className,\n}: {\n children: React.ReactNode;\n cols?: 1 | 2 | 3 | 4;\n className?: string;\n}) {\n const preset =\n cols === 1\n ? 'grid-cols-1'\n : cols === 2\n ? 'grid-cols-2'\n : cols === 3\n ? 'grid-cols-3'\n : 'grid-cols-4';\n return <div className={cn('grid gap-4', preset, className)}>{children}</div>;\n}\n"],"mappings":";;;;;;;AAKA,SAAgB,YAAY,EAC1B,UACA,aAIC;AACD,QAAO,oBAAC;EAAI,WAAW,GAAG,aAAa,UAAU;EAAG;GAAe;;AAGrE,SAAgB,QAAQ,EACtB,UACA,aAIC;AACD,QACE,oBAAC;EAAI,WAAW,GAAG,yCAAyC,UAAU;EACnE;GACG;;AAIV,SAAgB,SAAS,EACvB,UACA,OAAO,GACP,aAKC;AASD,QAAO,oBAAC;EAAI,WAAW,GAAG,cAPxB,SAAS,IACL,gBACA,SAAS,IACP,gBACA,SAAS,IACP,gBACA,eACsC,UAAU;EAAG;GAAe"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"FormOneByOneLayout.d.ts","names":[],"sources":["../../../src/components/forms/FormOneByOneLayout.tsx"],"sourcesContent":[],"mappings":";;;;UAIiB,gBAAA;;SAER,OAAA,CAAM;EAFE,WAAA,CAAA,EAGD,OAAA,CAAM,SAHW;EAExB,KAAM,EAEN,OAAA,CAAM,SAFA;EACC,QAAM,CAAA,EAAA,GAAA,GAAA,OAAA;;AACE,UAIP,uBAAA,CAJO;EAIP,MAAA,EACP,gBADO,EAAuB;EAOxB,UAAA,CAAA,EAAA,MAAA;EACd,UAAA,CAAA,EAAA,GAAA,GAAA,IAAA,GAL0B,OAK1B,CAAA,IAAA,CAAA;EACA,SAAA,CAAA,EAAA,MAAA;;AAEA,iBAJc,kBAAA,CAId;EAAA,MAAA;EAAA,UAAA;EAAA,UAAA;EAAA;AAAA,CAAA,EACC,uBADD,CAAA,EACwB,mBAAA,CAAA,GAAA,CAAA,OAAA,GADxB,IAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"FormOneByOneLayout.js","names":["React"],"sources":["../../../src/components/forms/FormOneByOneLayout.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Button } from '../atoms/Button';\nimport { cn } from '@lssm/lib.ui-kit-web/ui/utils';\n\nexport interface OneByOneFieldDef {\n key: string;\n title: React.ReactNode;\n description?: React.ReactNode;\n input: React.ReactNode;\n validate?: () => boolean; // called before advancing\n}\n\nexport interface FormOneByOneLayoutProps {\n fields: OneByOneFieldDef[];\n initialKey?: string;\n onComplete?: () => void | Promise<void>;\n className?: string;\n}\n\nexport function FormOneByOneLayout({\n fields,\n initialKey,\n onComplete,\n className,\n}: FormOneByOneLayoutProps) {\n const indexByKey = React.useMemo(\n () => Object.fromEntries(fields.map((f, i) => [f.key, i])),\n [fields]\n );\n const [idx, setIdx] = React.useState<number>(() => {\n if (initialKey && initialKey in indexByKey) {\n return indexByKey[initialKey] || 0;\n }\n return 0;\n });\n const atLast = idx === fields.length - 1;\n const field = fields[idx];\n\n if (!field) {\n return null;\n }\n\n const next = async () => {\n if (field.validate && !field.validate()) return;\n if (atLast) {\n await onComplete?.();\n } else {\n setIdx((i) => Math.min(i + 1, fields.length - 1));\n }\n };\n const prev = () => setIdx((i) => Math.max(0, i - 1));\n\n return (\n <div\n className={cn(\n 'flex min-h-[320px] flex-col items-stretch justify-between',\n className\n )}\n >\n <div className=\"space-y-2\">\n <div className=\"text-lg font-medium\">{field.title}</div>\n {field.description && (\n <div className=\"text-muted-foreground text-base\">\n {field.description}\n </div>\n )}\n <div className=\"pt-2\">{field.input}</div>\n </div>\n <div className=\"mt-6 flex items-center justify-between\">\n <Button variant=\"ghost\" onPress={prev} disabled={idx === 0}>\n Back\n </Button>\n <Button onPress={next}>{atLast ? 'Done' : 'Continue'}</Button>\n </div>\n </div>\n );\n}\n"],"mappings":";;;;;;AAmBA,SAAgB,mBAAmB,EACjC,QACA,YACA,YACA,aAC0B;CAC1B,MAAM,aAAaA,QAAM,cACjB,OAAO,YAAY,OAAO,KAAK,GAAG,MAAM,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC,EAC1D,CAAC,OAAO,CACT;CACD,MAAM,CAAC,KAAK,UAAUA,QAAM,eAAuB;AACjD,MAAI,cAAc,cAAc,WAC9B,QAAO,WAAW,eAAe;AAEnC,SAAO;GACP;CACF,MAAM,SAAS,QAAQ,OAAO,SAAS;CACvC,MAAM,QAAQ,OAAO;AAErB,KAAI,CAAC,MACH,QAAO;CAGT,MAAM,OAAO,YAAY;AACvB,MAAI,MAAM,YAAY,CAAC,MAAM,UAAU,CAAE;AACzC,MAAI,OACF,OAAM,cAAc;MAEpB,SAAQ,MAAM,KAAK,IAAI,IAAI,GAAG,OAAO,SAAS,EAAE,CAAC;;CAGrD,MAAM,aAAa,QAAQ,MAAM,KAAK,IAAI,GAAG,IAAI,EAAE,CAAC;AAEpD,QACE,qBAAC;EACC,WAAW,GACT,6DACA,UACD;aAED,qBAAC;GAAI,WAAU;;IACb,oBAAC;KAAI,WAAU;eAAuB,MAAM;MAAY;IACvD,MAAM,eACL,oBAAC;KAAI,WAAU;eACZ,MAAM;MACH;IAER,oBAAC;KAAI,WAAU;eAAQ,MAAM;MAAY;;IACrC,EACN,qBAAC;GAAI,WAAU;cACb,oBAAC;IAAO,SAAQ;IAAQ,SAAS;IAAM,UAAU,QAAQ;cAAG;KAEnD,EACT,oBAAC;IAAO,SAAS;cAAO,SAAS,SAAS;KAAoB;IAC1D;GACF"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"FormStepsLayout.d.ts","names":[],"sources":["../../../src/components/forms/FormStepsLayout.tsx"],"sourcesContent":[],"mappings":";;;;UAKiB,OAAA;;SAER,OAAA,CAAM;EAFE,WAAO,CAAA,EAGR,OAAA,CAAM,SAHE;EAEf,OAAM,EAEJ,OAAA,CAAM,SAFF;;AAEJ,UAGM,oBAAA,CAHA;EAAS,KAAA,EAIjB,OAJiB,EAAA;EAGT,cAAA,CAAA,EAAA,MAAoB;EAQrB,QAAA,CAAA,EAAA,GAAA,GAAA,IAAe,GALL,OAKK,CAAA,IAAA,CAAA;EAC7B,OAAA,CAAA,EAAA,CAAA,OAAA,EAAA,MAAA,EAAA,GAAA,OAAA;EACA,SAAA,CAAA,EAAA,MAAA;;AAEA,iBAJc,eAAA,CAId;EAAA,KAAA;EAAA,cAAA;EAAA,QAAA;EAAA,OAAA;EAAA;AAAA,CAAA,EAEC,oBAFD,CAAA,EAEqB,mBAAA,CAAA,GAAA,CAAA,OAAA,GAFrB,IAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"FormStepsLayout.js","names":["React"],"sources":["../../../src/components/forms/FormStepsLayout.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Button } from '../atoms/Button';\nimport { Separator } from '@lssm/lib.ui-kit-web/ui/separator';\nimport { cn } from '@lssm/lib.ui-kit-web/ui/utils';\n\nexport interface StepDef {\n key: string;\n title: React.ReactNode;\n description?: React.ReactNode;\n content: React.ReactNode;\n}\n\nexport interface FormStepsLayoutProps {\n steps: StepDef[];\n initialStepKey?: string;\n onFinish?: () => void | Promise<void>;\n canNext?: (stepKey: string) => boolean;\n className?: string;\n}\n\nexport function FormStepsLayout({\n steps,\n initialStepKey,\n onFinish,\n canNext,\n className,\n}: FormStepsLayoutProps) {\n const indexByKey = React.useMemo(\n () => Object.fromEntries(steps.map((s, i) => [s.key, i])),\n [steps]\n );\n const [idx, setIdx] = React.useState<number>(() => {\n if (initialStepKey && initialStepKey in indexByKey)\n return indexByKey[initialStepKey] || 0;\n return 0;\n });\n const atFirst = idx === 0;\n const atLast = idx === steps.length - 1;\n const step = steps[idx];\n\n if (!step) {\n return null;\n }\n\n const handleNext = async () => {\n if (!atLast) {\n if (canNext && !canNext(step.key)) return;\n setIdx((i) => Math.min(i + 1, steps.length - 1));\n } else if (onFinish) {\n await onFinish();\n }\n };\n const handlePrev = () => setIdx((i) => Math.max(0, i - 1));\n\n return (\n <div className={cn('space-y-4', className)}>\n <div className=\"flex items-center justify-between\">\n <div className=\"truncate text-lg font-medium\">{step.title}</div>\n <div className=\"text-muted-foreground text-base\">\n {idx + 1} / {steps.length}\n </div>\n </div>\n {step.description && (\n <div className=\"text-muted-foreground text-base\">\n {step.description}\n </div>\n )}\n <Separator />\n <div>{step.content}</div>\n <div className=\"flex items-center justify-between\">\n <Button variant=\"ghost\" onPress={handlePrev} disabled={atFirst}>\n Back\n </Button>\n <Button onPress={handleNext}>{atLast ? 'Finish' : 'Next'}</Button>\n </div>\n </div>\n );\n}\n"],"mappings":";;;;;;;AAoBA,SAAgB,gBAAgB,EAC9B,OACA,gBACA,UACA,SACA,aACuB;CACvB,MAAM,aAAaA,QAAM,cACjB,OAAO,YAAY,MAAM,KAAK,GAAG,MAAM,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC,EACzD,CAAC,MAAM,CACR;CACD,MAAM,CAAC,KAAK,UAAUA,QAAM,eAAuB;AACjD,MAAI,kBAAkB,kBAAkB,WACtC,QAAO,WAAW,mBAAmB;AACvC,SAAO;GACP;CACF,MAAM,UAAU,QAAQ;CACxB,MAAM,SAAS,QAAQ,MAAM,SAAS;CACtC,MAAM,OAAO,MAAM;AAEnB,KAAI,CAAC,KACH,QAAO;CAGT,MAAM,aAAa,YAAY;AAC7B,MAAI,CAAC,QAAQ;AACX,OAAI,WAAW,CAAC,QAAQ,KAAK,IAAI,CAAE;AACnC,WAAQ,MAAM,KAAK,IAAI,IAAI,GAAG,MAAM,SAAS,EAAE,CAAC;aACvC,SACT,OAAM,UAAU;;CAGpB,MAAM,mBAAmB,QAAQ,MAAM,KAAK,IAAI,GAAG,IAAI,EAAE,CAAC;AAE1D,QACE,qBAAC;EAAI,WAAW,GAAG,aAAa,UAAU;;GACxC,qBAAC;IAAI,WAAU;eACb,oBAAC;KAAI,WAAU;eAAgC,KAAK;MAAY,EAChE,qBAAC;KAAI,WAAU;;MACZ,MAAM;MAAE;MAAI,MAAM;;MACf;KACF;GACL,KAAK,eACJ,oBAAC;IAAI,WAAU;cACZ,KAAK;KACF;GAER,oBAAC,cAAY;GACb,oBAAC,mBAAK,KAAK,UAAc;GACzB,qBAAC;IAAI,WAAU;eACb,oBAAC;KAAO,SAAQ;KAAQ,SAAS;KAAY,UAAU;eAAS;MAEvD,EACT,oBAAC;KAAO,SAAS;eAAa,SAAS,WAAW;MAAgB;KAC9D;;GACF"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"ZodForm.d.ts","names":[],"sources":["../../../src/components/forms/ZodForm.tsx"],"sourcesContent":[],"mappings":";;;;;;;UAciB,6BACC,CAAA,CAAE,aAAa,mCACV,cAAc,CAAA,CAAE,MAAM,oBACjC,CAAA,CAAE,OAAO;UAEX;kBACQ,QAAQ,gBAAgB,QAAQ,QAAQ;EANzC,QAAA,EAAA,CAAA,IAAY,EAOV,OAPU,EAAA,GAOE,OAPF,CAAA,IAAA,CAAA,GAAA,IAAA;EACI,QAAA,EAAA,CAAA,CAAA,EAOjB,aAPiB,CAOH,YAPG,EAAA,GAAA,EAOgB,OAPhB,CAAA,EAAA,GAO6B,OAAA,CAAM,SAPnC;;AACV,iBASP,OATO,CAAA,gBAUL,CAAA,CAAE,OAVG,CAAA,GAAA,EAUU,WAVV,CAAA,EAAA,qBAWA,WAXA,GAWc,CAAA,CAAE,KAXhB,CAWsB,OAXtB,CAAA,EAAA,UAYX,CAAA,CAAE,MAZS,CAYF,OAZE,CAAA,CAAA,CAAA;EAAA,MAAA;EAAA,aAAA;EAAA,QAAA;EAAA;AAAA,CAAA,EAkBpB,YAlBoB,CAkBP,OAlBO,EAkBE,YAlBF,EAkBgB,OAlBhB,CAAA,CAAA,EAkBwB,mBAAA,CAAA,GAAA,CAAA,OAlBxB"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"ZodForm.js","names":[],"sources":["../../../src/components/forms/ZodForm.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport {\n Form,\n useForm,\n type UseFormReturn,\n zodResolver,\n} from '@lssm/lib.ui-kit-web/ui/form';\nimport type { FieldValues } from 'react-hook-form';\nimport { z } from 'zod';\n\n// import { useForm, type UseFormReturn } from 'react-hook-form';\n\nexport interface ZodFormProps<\n TSchema extends z.ZodType<any, FieldValues>,\n TFieldValues extends FieldValues = z.input<TSchema>,\n TOutput = z.output<TSchema>,\n> {\n schema: TSchema;\n defaultValues?: Partial<TFieldValues> | Promise<Partial<TFieldValues>>;\n onSubmit: (data: TOutput) => Promise<void> | void;\n children: (f: UseFormReturn<TFieldValues, any, TOutput>) => React.ReactNode;\n}\n\nexport function ZodForm<\n TSchema extends z.ZodType<any, FieldValues>,\n TFieldValues extends FieldValues = z.input<TSchema>,\n TOutput = z.output<TSchema>,\n>({\n schema,\n defaultValues,\n onSubmit,\n children,\n}: ZodFormProps<TSchema, TFieldValues, TOutput>) {\n const form = useForm<TFieldValues, any, TOutput>({\n resolver: zodResolver<TFieldValues, any, TOutput>(schema as any),\n defaultValues: defaultValues as any,\n });\n return (\n <Form {...form}>\n <form onSubmit={form.handleSubmit(onSubmit)}>{children(form)}</form>\n </Form>\n );\n}\n"],"mappings":";;;;;;;;AAyBA,SAAgB,QAId,EACA,QACA,eACA,UACA,YAC+C;CAC/C,MAAM,OAAO,QAAoC;EAC/C,UAAU,YAAwC,OAAc;EACjD;EAChB,CAAC;AACF,QACE,oBAAC;EAAK,GAAI;YACR,oBAAC;GAAK,UAAU,KAAK,aAAa,SAAS;aAAG,SAAS,KAAK;IAAQ;GAC/D"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"DefinitionList.d.ts","names":[],"sources":["../../../../src/components/legal/atoms/DefinitionList.tsx"],"sourcesContent":[],"mappings":";;;;iBAGgB,cAAA;;;;;UAIC,OAAA,CAAM;IAJP,WAAA,EAI+B,OAAA,CAAM,SAJvB;EAC5B,CAAA,EAAA;EACA,SAAA,CAAA,EAAA,MAAA;CAEe,CAAA,EAEhB,mBAAA,CAAA,GAAA,CAAA,OAFsB"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"DefinitionList.js","names":[],"sources":["../../../../src/components/legal/atoms/DefinitionList.tsx"],"sourcesContent":["import * as React from 'react';\nimport { cn } from '@lssm/lib.ui-kit-web/ui/utils';\n\nexport function DefinitionList({\n items,\n className,\n}: {\n items: { term: React.ReactNode; description: React.ReactNode }[];\n className?: string;\n}) {\n return (\n <dl className={cn('grid grid-cols-1 gap-3 md:grid-cols-3', className)}>\n {items.map((it, idx) => (\n <div\n key={idx}\n className=\"col-span-1 grid grid-cols-3 gap-3 md:col-span-3\"\n >\n <dt className=\"text-foreground col-span-1 text-base font-medium\">\n {it.term}\n </dt>\n <dd className=\"text-muted-foreground col-span-2 text-base\">\n {it.description}\n </dd>\n </div>\n ))}\n </dl>\n );\n}\n"],"mappings":";;;;;AAGA,SAAgB,eAAe,EAC7B,OACA,aAIC;AACD,QACE,oBAAC;EAAG,WAAW,GAAG,yCAAyC,UAAU;YAClE,MAAM,KAAK,IAAI,QACd,qBAAC;GAEC,WAAU;cAEV,oBAAC;IAAG,WAAU;cACX,GAAG;KACD,EACL,oBAAC;IAAG,WAAU;cACX,GAAG;KACD;KARA,IASD,CACN;GACC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"KeyValueList.d.ts","names":[],"sources":["../../../../src/components/legal/atoms/KeyValueList.tsx"],"sourcesContent":[],"mappings":";;;;iBAGgB,YAAA;;;;;SAIA,OAAA,CAAM;IAJN,KAAA,EAIwB,OAAA,CAAM,SAJlB;EAC1B,CAAA,EAAA;EACA,SAAA,CAAA,EAAA,MAAA;CAEc,CAAA,EAEf,mBAAA,CAAA,GAAA,CAAA,OAFqB"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"KeyValueList.js","names":[],"sources":["../../../../src/components/legal/atoms/KeyValueList.tsx"],"sourcesContent":["import * as React from 'react';\nimport { cn } from '@lssm/lib.ui-kit-web/ui/utils';\n\nexport function KeyValueList({\n items,\n className,\n}: {\n items: { key: React.ReactNode; value: React.ReactNode }[];\n className?: string;\n}) {\n return (\n <div className={cn('grid grid-cols-1 gap-2', className)}>\n {items.map((it, idx) => (\n <div key={idx} className=\"flex items-start gap-3\">\n <div className=\"text-foreground w-40 shrink-0 text-base font-medium\">\n {it.key}\n </div>\n <div className=\"text-muted-foreground flex-1 text-base\">\n {it.value}\n </div>\n </div>\n ))}\n </div>\n );\n}\n"],"mappings":";;;;;AAGA,SAAgB,aAAa,EAC3B,OACA,aAIC;AACD,QACE,oBAAC;EAAI,WAAW,GAAG,0BAA0B,UAAU;YACpD,MAAM,KAAK,IAAI,QACd,qBAAC;GAAc,WAAU;cACvB,oBAAC;IAAI,WAAU;cACZ,GAAG;KACA,EACN,oBAAC;IAAI,WAAU;cACZ,GAAG;KACA;KANE,IAOJ,CACN;GACE"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"LegalCallout.d.ts","names":[],"sources":["../../../../src/components/legal/atoms/LegalCallout.tsx"],"sourcesContent":[],"mappings":";;;;;;cAIM;;IAWJ,gCAAA,CAAA;KAEU,iBAAA,GAAoB,OAAA,CAAM,eAAe,kBACnD,oBAAoB;AAdhB,iBAgBU,YAAA,CALd;EAAA,IAAA;EAAA,SAAA;EAAA,GAAA;AAAA,CAAA,EAK0D,iBAL1D,CAAA,EAK2E,mBAAA,CAAA,GAAA,CAAA,OAL3E"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"LegalCallout.js","names":[],"sources":["../../../../src/components/legal/atoms/LegalCallout.tsx"],"sourcesContent":["import * as React from 'react';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { cn } from '@lssm/lib.ui-kit-web/ui/utils';\n\nconst calloutVariants = cva('rounded-md border p-4', {\n variants: {\n tone: {\n info: 'border-border bg-muted/30',\n warning: 'border-warning/50 bg-warning/10',\n danger: 'border-destructive/50 bg-destructive/10',\n },\n },\n defaultVariants: {\n tone: 'info',\n },\n});\n\nexport type LegalCalloutProps = React.HTMLAttributes<HTMLDivElement> &\n VariantProps<typeof calloutVariants>;\n\nexport function LegalCallout({ tone, className, ...props }: LegalCalloutProps) {\n return (\n <div className={cn(calloutVariants({ tone }), className)} {...props} />\n );\n}\n\nexport { calloutVariants };\n"],"mappings":";;;;;;AAIA,MAAM,kBAAkB,IAAI,yBAAyB;CACnD,UAAU,EACR,MAAM;EACJ,MAAM;EACN,SAAS;EACT,QAAQ;EACT,EACF;CACD,iBAAiB,EACf,MAAM,QACP;CACF,CAAC;AAKF,SAAgB,aAAa,EAAE,MAAM,WAAW,GAAG,SAA4B;AAC7E,QACE,oBAAC;EAAI,WAAW,GAAG,gBAAgB,EAAE,MAAM,CAAC,EAAE,UAAU;EAAE,GAAI;GAAS"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"LegalHeading.d.ts","names":[],"sources":["../../../../src/components/legal/atoms/LegalHeading.tsx"],"sourcesContent":[],"mappings":";;;;;;cAIM,uBAyBJ;;;;AA5BgE,CAAA,GA4BhE,gCAAA,CAAA,SAAA,CAAA,GAAA,SAAA,EAAA,GAAA,MAAA;AAEU,KAAA,iBAAA,GAAoB,OAAA,CAAM,cAAT,CAAwB,kBAAxB,CAAA,GAC3B,YAD2B,CAAA,OACP,eADO,CAAA,GAAA;EAAwB,EAAA,CAAA,EAAA,IAAA,GAAA,IAAA,GAAA,IAAA,GAAA,IAAA;CAArB;AACV,iBAIN,YAAA,CAJM;EAAA,EAAA;EAAA,KAAA;EAAA,IAAA;EAAA,OAAA;EAAA,SAAA;EAAA,GAAA;AAAA,CAAA,EAWnB,iBAXmB,CAAA,EAWF,mBAAA,CAAA,GAAA,CAAA,OAXE"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"LegalHeading.js","names":[],"sources":["../../../../src/components/legal/atoms/LegalHeading.tsx"],"sourcesContent":["import * as React from 'react';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { cn } from '@lssm/lib.ui-kit-web/ui/utils';\n\nconst headingVariants = cva('text-foreground tracking-tight', {\n variants: {\n level: {\n h1: 'text-3xl font-semibold md:text-4xl',\n h2: 'text-2xl font-semibold md:text-3xl',\n h3: 'text-xl font-semibold md:text-2xl',\n h4: 'text-lg font-semibold md:text-xl',\n },\n tone: {\n default: '',\n muted: 'text-muted-foreground',\n accent: 'text-primary',\n },\n spacing: {\n none: '',\n sm: 'mt-4',\n md: 'mt-6',\n lg: 'mt-8',\n },\n },\n defaultVariants: {\n level: 'h2',\n tone: 'default',\n spacing: 'md',\n },\n});\n\nexport type LegalHeadingProps = React.HTMLAttributes<HTMLHeadingElement> &\n VariantProps<typeof headingVariants> & {\n as?: 'h1' | 'h2' | 'h3' | 'h4';\n };\n\nexport function LegalHeading({\n as,\n level,\n tone,\n spacing,\n className,\n ...props\n}: LegalHeadingProps) {\n const Comp = (as ?? level ?? 'h2') as any;\n return (\n <Comp\n className={cn(headingVariants({ level, tone, spacing }), className)}\n {...props}\n />\n );\n}\n\nexport { headingVariants };\n"],"mappings":";;;;;;AAIA,MAAM,kBAAkB,IAAI,kCAAkC;CAC5D,UAAU;EACR,OAAO;GACL,IAAI;GACJ,IAAI;GACJ,IAAI;GACJ,IAAI;GACL;EACD,MAAM;GACJ,SAAS;GACT,OAAO;GACP,QAAQ;GACT;EACD,SAAS;GACP,MAAM;GACN,IAAI;GACJ,IAAI;GACJ,IAAI;GACL;EACF;CACD,iBAAiB;EACf,OAAO;EACP,MAAM;EACN,SAAS;EACV;CACF,CAAC;AAOF,SAAgB,aAAa,EAC3B,IACA,OACA,MACA,SACA,WACA,GAAG,SACiB;AAEpB,QACE,oBAFY,MAAM,SAAS;EAGzB,WAAW,GAAG,gBAAgB;GAAE;GAAO;GAAM;GAAS,CAAC,EAAE,UAAU;EACnE,GAAI;GACJ"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"LegalList.d.ts","names":[],"sources":["../../../../src/components/legal/atoms/LegalList.tsx"],"sourcesContent":[],"mappings":";;;;;;cAIM;;;IAiBJ,gCAAA,CAAA;AAjBI,KAmBM,cAAA,GAAiB,OAAA,CAAM,cAFjC,CAGA,gBAHA,GAGmB,gBAHnB,CAAA,GAKA,YALA,CAAA,OAKoB,YALpB,CAAA;AAEU,iBAKI,SAAA,CALU;EAAA,IAAA;EAAA,OAAA;EAAA,SAAA;EAAA,QAAA;EAAA,GAAA;AAAA,CAAA,EAWvB,cAXuB,CAAA,EAWT,oBAAA,CAAA,GAAA,CAAA,OAXS"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"LegalList.js","names":[],"sources":["../../../../src/components/legal/atoms/LegalList.tsx"],"sourcesContent":["import * as React from 'react';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { cn } from '@lssm/lib.ui-kit-web/ui/utils';\n\nconst listVariants = cva('', {\n variants: {\n type: {\n unordered: 'list-disc pl-6',\n ordered: 'list-decimal pl-6',\n none: 'pl-0',\n },\n spacing: {\n sm: 'space-y-1',\n md: 'space-y-2',\n lg: 'space-y-3',\n },\n },\n defaultVariants: {\n type: 'unordered',\n spacing: 'md',\n },\n});\n\nexport type LegalListProps = React.HTMLAttributes<\n HTMLUListElement | HTMLOListElement\n> &\n VariantProps<typeof listVariants>;\n\nexport function LegalList({\n type,\n spacing,\n className,\n children,\n ...props\n}: LegalListProps) {\n const Comp: any = type === 'ordered' ? 'ol' : 'ul';\n return (\n <Comp className={cn(listVariants({ type, spacing }), className)} {...props}>\n {children}\n </Comp>\n );\n}\n\nexport { listVariants };\n"],"mappings":";;;;;;AAIA,MAAM,eAAe,IAAI,IAAI;CAC3B,UAAU;EACR,MAAM;GACJ,WAAW;GACX,SAAS;GACT,MAAM;GACP;EACD,SAAS;GACP,IAAI;GACJ,IAAI;GACJ,IAAI;GACL;EACF;CACD,iBAAiB;EACf,MAAM;EACN,SAAS;EACV;CACF,CAAC;AAOF,SAAgB,UAAU,EACxB,MACA,SACA,WACA,UACA,GAAG,SACc;AAEjB,QACE,oBAFgB,SAAS,YAAY,OAAO;EAEtC,WAAW,GAAG,aAAa;GAAE;GAAM;GAAS,CAAC,EAAE,UAAU;EAAE,GAAI;EAClE;GACI"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"LegalSection.d.ts","names":[],"sources":["../../../../src/components/legal/atoms/LegalSection.tsx"],"sourcesContent":[],"mappings":";;;;;;cAIM,uBAuBJ;;;;AA1BgE,CAAA,GA0BhE,gCAAA,CAAA,SAAA,CAAA,GAAA,SAAA,EAAA,GAAA,MAAA;AAEU,KAAA,iBAAA,GAAoB,OAAA,CAAM,cAAT,CAAwB,cAAxB,CAAA,GAC3B,YAD2B,CAAA,OACP,eADO,CAAA;AAAwB,iBAGrC,YAAA,CAHqC;EAAA,OAAA;EAAA,MAAA;EAAA,IAAA;EAAA,SAAA;EAAA,GAAA;AAAA,CAAA,EASlD,iBATkD,CAAA,EASjC,mBAAA,CAAA,GAAA,CAAA,OATiC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"LegalSection.js","names":[],"sources":["../../../../src/components/legal/atoms/LegalSection.tsx"],"sourcesContent":["import * as React from 'react';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { cn } from '@lssm/lib.ui-kit-web/ui/utils';\n\nconst sectionVariants = cva('space-y-3', {\n variants: {\n spacing: {\n sm: 'py-3',\n md: 'py-4',\n lg: 'py-6',\n },\n border: {\n none: '',\n top: 'border-t',\n bottom: 'border-b',\n both: 'border-y',\n },\n tone: {\n plain: '',\n subtle: 'bg-muted/30',\n },\n },\n defaultVariants: {\n spacing: 'md',\n border: 'none',\n tone: 'plain',\n },\n});\n\nexport type LegalSectionProps = React.HTMLAttributes<HTMLDivElement> &\n VariantProps<typeof sectionVariants>;\n\nexport function LegalSection({\n spacing,\n border,\n tone,\n className,\n ...props\n}: LegalSectionProps) {\n return (\n <div\n className={cn(sectionVariants({ spacing, border, tone }), className)}\n {...props}\n />\n );\n}\n\nexport { sectionVariants };\n"],"mappings":";;;;;;AAIA,MAAM,kBAAkB,IAAI,aAAa;CACvC,UAAU;EACR,SAAS;GACP,IAAI;GACJ,IAAI;GACJ,IAAI;GACL;EACD,QAAQ;GACN,MAAM;GACN,KAAK;GACL,QAAQ;GACR,MAAM;GACP;EACD,MAAM;GACJ,OAAO;GACP,QAAQ;GACT;EACF;CACD,iBAAiB;EACf,SAAS;EACT,QAAQ;EACR,MAAM;EACP;CACF,CAAC;AAKF,SAAgB,aAAa,EAC3B,SACA,QACA,MACA,WACA,GAAG,SACiB;AACpB,QACE,oBAAC;EACC,WAAW,GAAG,gBAAgB;GAAE;GAAS;GAAQ;GAAM,CAAC,EAAE,UAAU;EACpE,GAAI;GACJ"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"LegalText.d.ts","names":[],"sources":["../../../../src/components/legal/atoms/LegalText.tsx"],"sourcesContent":[],"mappings":";;;;;;cAIM,oBAwBJ;;;;AA3BgE,CAAA,GA2BhE,gCAAA,CAAA,SAAA,CAAA,GAAA,SAAA,EAAA,GAAA,MAAA;AAEU,KAAA,cAAA,GAAiB,OAAA,CAAM,cAAT,CAAwB,oBAAxB,CAAA,GACxB,YADwB,CAAA,OACJ,YADI,CAAA,GAAA;EAAwB,EAAA,CAAA,EAAA,GAAA,GAAA,KAAA,GAAA,MAAA;CAArB;AACP,iBAEN,SAAA,CAFM;EAAA,EAAA;EAAA,IAAA;EAAA,IAAA;EAAA,OAAA;EAAA,SAAA;EAAA,GAAA;AAAA,CAAA,EASnB,cATmB,CAAA,EASL,oBAAA,CAAA,GAAA,CAAA,OATK"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"LegalText.js","names":[],"sources":["../../../../src/components/legal/atoms/LegalText.tsx"],"sourcesContent":["import * as React from 'react';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { cn } from '@lssm/lib.ui-kit-web/ui/utils';\n\nconst textVariants = cva('text-base leading-relaxed', {\n variants: {\n tone: {\n default: 'text-foreground',\n muted: 'text-muted-foreground',\n danger: 'text-destructive',\n },\n size: {\n base: 'text-base',\n sm: 'text-sm',\n lg: 'text-lg',\n },\n spacing: {\n none: '',\n sm: 'mt-2',\n md: 'mt-3',\n lg: 'mt-4',\n },\n },\n defaultVariants: {\n tone: 'default',\n size: 'base',\n spacing: 'sm',\n },\n});\n\nexport type LegalTextProps = React.HTMLAttributes<HTMLParagraphElement> &\n VariantProps<typeof textVariants> & { as?: 'p' | 'div' | 'span' };\n\nexport function LegalText({\n as = 'p',\n tone,\n size,\n spacing,\n className,\n ...props\n}: LegalTextProps) {\n const Comp: any = as;\n return (\n <Comp\n className={cn(textVariants({ tone, size, spacing }), className)}\n {...props}\n />\n );\n}\n\nexport { textVariants };\n"],"mappings":";;;;;;AAIA,MAAM,eAAe,IAAI,6BAA6B;CACpD,UAAU;EACR,MAAM;GACJ,SAAS;GACT,OAAO;GACP,QAAQ;GACT;EACD,MAAM;GACJ,MAAM;GACN,IAAI;GACJ,IAAI;GACL;EACD,SAAS;GACP,MAAM;GACN,IAAI;GACJ,IAAI;GACJ,IAAI;GACL;EACF;CACD,iBAAiB;EACf,MAAM;EACN,MAAM;EACN,SAAS;EACV;CACF,CAAC;AAKF,SAAgB,UAAU,EACxB,KAAK,KACL,MACA,MACA,SACA,WACA,GAAG,SACc;AAEjB,QACE,oBAFgB;EAGd,WAAW,GAAG,aAAa;GAAE;GAAM;GAAM;GAAS,CAAC,EAAE,UAAU;EAC/D,GAAI;GACJ"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Consent.d.ts","names":[],"sources":["../../../../src/components/legal/molecules/Consent.tsx"],"sourcesContent":[],"mappings":";;;;iBAIgB,WAAA;;;;;;;;;SASP,OAAA,CAAM;EATC,WAAA,CAAA,EAUA,OAAA,CAAM,SAVK;EACzB,OAAA,EAAA,OAAA;EACA,QAAA,EAAA,CAAA,OAAA,EAAA,OAAA,EAAA,GAAA,IAAA;EACA,SAAA,CAAA,EAAA,MAAA;CACA,CAAA,EAUD,mBAAA,CAAA,GAAA,CAAA,OAVC;AACA,iBA6Bc,WAAA,CA7Bd;EAAA,KAAA;EAAA,QAAA;EAAA;CAAA,EAAA;EACA,KAAA,EAAA;IAGO,EAAM,EAAA,MAAA;IACC,KAAM,EA+BX,OAAA,CAAM,SA/BK;IAIrB,WAAA,CAAA,EA4BiB,OAAA,CAAM,SA5BvB;IAAA,OAAA,EAAA,OAAA;EAoBe,CAAA,EAAA;EACd,QAAA,EAAA,CAAA,EAAA,EAAA,MAAA,EAAA,OAAA,EAAA,OAAA,EAAA,GAAA,IAAA;EACA,SAAA,CAAA,EAAA,MAAA;CACA,CAAA,EAUD,mBAAA,CAAA,GAAA,CAAA,OAVC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Consent.js","names":[],"sources":["../../../../src/components/legal/molecules/Consent.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Checkbox } from '@lssm/lib.ui-kit-web/ui/checkbox';\nimport { cn } from '@lssm/lib.ui-kit-web/ui/utils';\n\nexport function ConsentItem({\n id,\n label,\n description,\n checked,\n onChange,\n className,\n}: {\n id: string;\n label: React.ReactNode;\n description?: React.ReactNode;\n checked: boolean;\n onChange: (checked: boolean) => void;\n className?: string;\n}) {\n return (\n <div className={cn('flex items-start gap-3', className)}>\n <Checkbox\n id={id}\n checked={checked}\n onCheckedChange={(v: any) => onChange(Boolean(v))}\n />\n <div>\n <label htmlFor={id} className=\"text-base font-medium\">\n {label}\n </label>\n {description && (\n <div className=\"text-muted-foreground text-base\">{description}</div>\n )}\n </div>\n </div>\n );\n}\n\nexport function ConsentList({\n items,\n onChange,\n className,\n}: {\n items: {\n id: string;\n label: React.ReactNode;\n description?: React.ReactNode;\n checked: boolean;\n }[];\n onChange: (id: string, checked: boolean) => void;\n className?: string;\n}) {\n return (\n <div className={cn('space-y-3', className)}>\n {items.map((it) => (\n <ConsentItem key={it.id} {...it} onChange={(c) => onChange(it.id, c)} />\n ))}\n </div>\n );\n}\n"],"mappings":";;;;;;AAIA,SAAgB,YAAY,EAC1B,IACA,OACA,aACA,SACA,UACA,aAQC;AACD,QACE,qBAAC;EAAI,WAAW,GAAG,0BAA0B,UAAU;aACrD,oBAAC;GACK;GACK;GACT,kBAAkB,MAAW,SAAS,QAAQ,EAAE,CAAC;IACjD,EACF,qBAAC,oBACC,oBAAC;GAAM,SAAS;GAAI,WAAU;aAC3B;IACK,EACP,eACC,oBAAC;GAAI,WAAU;aAAmC;IAAkB,IAElE;GACF;;AAIV,SAAgB,YAAY,EAC1B,OACA,UACA,aAUC;AACD,QACE,oBAAC;EAAI,WAAW,GAAG,aAAa,UAAU;YACvC,MAAM,KAAK,OACV,oBAAC;GAAwB,GAAI;GAAI,WAAW,MAAM,SAAS,GAAG,IAAI,EAAE;KAAlD,GAAG,GAAmD,CACxE;GACE"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"ContactFields.d.ts","names":[],"sources":["../../../../src/components/legal/molecules/ContactFields.tsx"],"sourcesContent":[],"mappings":";;;iBAKgB,aAAA;;;;;;;IAAA,KAAA,EAAA,MAAa;IAC3B,OAAA,EAAA,MAAA;IACA,OAAA,EAAA,MAAA;EACA,CAAA;EAUD,QAAA,EAAA,CAAA,IAAA,EAAA;IAAA,IAAA,EAAA,MAAA;;;;;;IAAA,mBAAA,CAAA,GAAA,CAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"ContactFields.js","names":[],"sources":["../../../../src/components/legal/molecules/ContactFields.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Input } from '../../atoms/Input';\nimport { Textarea } from '../../atoms/Textarea';\nimport { Label } from '@lssm/lib.ui-kit-web/ui/label';\n\nexport function ContactFields({\n value,\n onChange,\n disabled,\n}: {\n value: { name: string; email: string; subject: string; message: string };\n onChange: (next: {\n name: string;\n email: string;\n subject: string;\n message: string;\n }) => void;\n disabled?: boolean;\n}) {\n return (\n <div className=\"space-y-4\">\n <div className=\"space-y-2\">\n <Label>Nom</Label>\n <Input\n value={value.name}\n onChange={(v) => onChange({ ...value, name: v })}\n disabled={disabled}\n />\n </div>\n <div className=\"space-y-2\">\n <Label>Email</Label>\n <Input\n type=\"email\"\n value={value.email}\n onChange={(v) => onChange({ ...value, email: v })}\n disabled={disabled}\n />\n </div>\n <div className=\"space-y-2\">\n <Label>Objet</Label>\n <Input\n value={value.subject}\n onChange={(v) =>\n onChange({\n ...value,\n subject: v,\n })\n }\n disabled={disabled}\n />\n </div>\n <div className=\"space-y-2\">\n <Label>Message</Label>\n <Textarea\n value={value.message}\n onChange={(v) =>\n onChange({\n ...value,\n message: v,\n })\n }\n disabled={disabled}\n rows={6}\n />\n </div>\n </div>\n );\n}\n"],"mappings":";;;;;;;AAKA,SAAgB,cAAc,EAC5B,OACA,UACA,YAUC;AACD,QACE,qBAAC;EAAI,WAAU;;GACb,qBAAC;IAAI,WAAU;eACb,oBAAC,mBAAM,QAAW,EAClB,oBAAC;KACC,OAAO,MAAM;KACb,WAAW,MAAM,SAAS;MAAE,GAAG;MAAO,MAAM;MAAG,CAAC;KACtC;MACV;KACE;GACN,qBAAC;IAAI,WAAU;eACb,oBAAC,mBAAM,UAAa,EACpB,oBAAC;KACC,MAAK;KACL,OAAO,MAAM;KACb,WAAW,MAAM,SAAS;MAAE,GAAG;MAAO,OAAO;MAAG,CAAC;KACvC;MACV;KACE;GACN,qBAAC;IAAI,WAAU;eACb,oBAAC,mBAAM,UAAa,EACpB,oBAAC;KACC,OAAO,MAAM;KACb,WAAW,MACT,SAAS;MACP,GAAG;MACH,SAAS;MACV,CAAC;KAEM;MACV;KACE;GACN,qBAAC;IAAI,WAAU;eACb,oBAAC,mBAAM,YAAe,EACtB,oBAAC;KACC,OAAO,MAAM;KACb,WAAW,MACT,SAAS;MACP,GAAG;MACH,SAAS;MACV,CAAC;KAEM;KACV,MAAM;MACN;KACE;;GACF"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"LegalMeta.d.ts","names":[],"sources":["../../../../src/components/legal/molecules/LegalMeta.tsx"],"sourcesContent":[],"mappings":";;;iBAGgB,SAAA;;;;;yBAKS;;EALT,SAAA,CAAA,EAAS,MAAA;CACvB,CAAA,EAOD,mBAAA,CAAA,GAAA,CAAA,OAPC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"LegalMeta.js","names":[],"sources":["../../../../src/components/legal/molecules/LegalMeta.tsx"],"sourcesContent":["import * as React from 'react';\nimport { cn } from '@lssm/lib.ui-kit-web/ui/utils';\n\nexport function LegalMeta({\n lastUpdated,\n version,\n className,\n}: {\n lastUpdated?: string | Date;\n version?: string;\n className?: string;\n}) {\n const fmtDate = (d?: string | Date) => {\n if (!d) return null;\n try {\n const date = typeof d === 'string' ? new Date(d) : d;\n return date.toLocaleDateString();\n } catch {\n return String(d);\n }\n };\n return (\n <div className={cn('text-muted-foreground text-base', className)}>\n {version && <span>Version {version}</span>}\n {version && lastUpdated && <span className=\"mx-2\">•</span>}\n {lastUpdated && <span>Dernière mise à jour: {fmtDate(lastUpdated)}</span>}\n </div>\n );\n}\n"],"mappings":";;;;;AAGA,SAAgB,UAAU,EACxB,aACA,SACA,aAKC;CACD,MAAM,WAAW,MAAsB;AACrC,MAAI,CAAC,EAAG,QAAO;AACf,MAAI;AAEF,WADa,OAAO,MAAM,WAAW,IAAI,KAAK,EAAE,GAAG,GACvC,oBAAoB;UAC1B;AACN,UAAO,OAAO,EAAE;;;AAGpB,QACE,qBAAC;EAAI,WAAW,GAAG,mCAAmC,UAAU;;GAC7D,WAAW,qBAAC,qBAAK,YAAS,WAAe;GACzC,WAAW,eAAe,oBAAC;IAAK,WAAU;cAAO;KAAQ;GACzD,eAAe,qBAAC,qBAAK,0BAAuB,QAAQ,YAAY,IAAQ;;GACrE"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"LegalTOC.d.ts","names":[],"sources":["../../../../src/components/legal/molecules/LegalTOC.tsx"],"sourcesContent":[],"mappings":";;;;;;UAIiB,OAAA;;SAER,OAAA,CAAM;;AAFf,cAKM,WALkB,EAEf,CAAA,KAkBA,CAlBA,EAAM,CAAA;EAGT,OAAA,CAAA,EAAA,SAYJ,GAAA,QAAA,GAAA,IAAA,GAAA,SAAA;EAEU,IAAA,CAAA,EAAA,IAAA,GAAA,IAAa,GAAA,IAAA,GAAA,SAAA;CAChB,GAHP,gCAAA,CAAA,SAGO,CAAA,GAAA,SAAA,EAAA,GAAA,MAAA;AAGe,KAJZ,aAAA,GAIY;EAApB,KAAA,EAHK,OAGL,EAAA;EACmB,UAAA,CAAA,EAAA,MAAA;EAArB,UAAM,CAAA,EAAA,CAAA,IAAA,EAAA,MAAA,EAAA,GAAA,IAAA;CAAc,GADlB,YACkB,CAAA,OADE,WACF,CAAA,GAApB,OAAA,CAAM,cAAc,CAAC,cAAD,CAAA;AAEN,iBAAA,QAAA,CAAQ;EAAA,KAAA;EAAA,UAAA;EAAA,UAAA;EAAA,OAAA;EAAA,IAAA;EAAA,SAAA;EAAA,GAAA;AAAA,CAAA,EAQrB,aARqB,CAAA,EAQR,oBAAA,CAAA,GAAA,CAAA,OARQ"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"LegalTOC.js","names":[],"sources":["../../../../src/components/legal/molecules/LegalTOC.tsx"],"sourcesContent":["import * as React from 'react';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { cn } from '@lssm/lib.ui-kit-web/ui/utils';\n\nexport interface TocItem {\n href: string;\n label: React.ReactNode;\n}\n\nconst tocVariants = cva('text-base', {\n variants: {\n variant: {\n sidebar: 'space-y-2',\n inline: 'flex flex-wrap gap-3',\n },\n size: {\n sm: '',\n md: 'text-base',\n },\n },\n defaultVariants: { variant: 'sidebar', size: 'md' },\n});\n\nexport type LegalTOCProps = {\n items: TocItem[];\n activeHref?: string;\n onNavigate?: (href: string) => void;\n} & VariantProps<typeof tocVariants> &\n React.HTMLAttributes<HTMLDivElement>;\n\nexport function LegalTOC({\n items,\n activeHref,\n onNavigate,\n variant,\n size,\n className,\n ...props\n}: LegalTOCProps) {\n return (\n <nav\n aria-label=\"Table of contents\"\n className={cn(tocVariants({ variant, size }), className)}\n {...props}\n >\n {variant === 'inline' ? (\n items.map((it) => (\n <a\n key={it.href}\n href={it.href}\n onClick={(e) => {\n onNavigate?.(it.href);\n // allow default anchor behaviour too\n }}\n className={cn(\n 'hover:bg-accent hover:text-accent-foreground rounded-xs px-2 py-1',\n activeHref === it.href && 'bg-accent text-accent-foreground'\n )}\n >\n {it.label}\n </a>\n ))\n ) : (\n <ul className=\"list-none space-y-2 pl-0\">\n {items.map((it) => (\n <li key={it.href}>\n <a\n href={it.href}\n onClick={() => onNavigate?.(it.href)}\n className={cn(\n 'hover:bg-accent hover:text-accent-foreground block rounded-xs px-2 py-1',\n activeHref === it.href && 'bg-accent text-accent-foreground'\n )}\n >\n {it.label}\n </a>\n </li>\n ))}\n </ul>\n )}\n </nav>\n );\n}\n\nexport { tocVariants };\n"],"mappings":";;;;;;AASA,MAAM,cAAc,IAAI,aAAa;CACnC,UAAU;EACR,SAAS;GACP,SAAS;GACT,QAAQ;GACT;EACD,MAAM;GACJ,IAAI;GACJ,IAAI;GACL;EACF;CACD,iBAAiB;EAAE,SAAS;EAAW,MAAM;EAAM;CACpD,CAAC;AASF,SAAgB,SAAS,EACvB,OACA,YACA,YACA,SACA,MACA,WACA,GAAG,SACa;AAChB,QACE,oBAAC;EACC,cAAW;EACX,WAAW,GAAG,YAAY;GAAE;GAAS;GAAM,CAAC,EAAE,UAAU;EACxD,GAAI;YAEH,YAAY,WACX,MAAM,KAAK,OACT,oBAAC;GAEC,MAAM,GAAG;GACT,UAAU,MAAM;AACd,iBAAa,GAAG,KAAK;;GAGvB,WAAW,GACT,qEACA,eAAe,GAAG,QAAQ,mCAC3B;aAEA,GAAG;KAXC,GAAG,KAYN,CACJ,GAEF,oBAAC;GAAG,WAAU;aACX,MAAM,KAAK,OACV,oBAAC,kBACC,oBAAC;IACC,MAAM,GAAG;IACT,eAAe,aAAa,GAAG,KAAK;IACpC,WAAW,GACT,2EACA,eAAe,GAAG,QAAQ,mCAC3B;cAEA,GAAG;KACF,IAVG,GAAG,KAWP,CACL;IACC;GAEH"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"ContactForm.d.ts","names":[],"sources":["../../../../src/components/legal/organisms/ContactForm.tsx"],"sourcesContent":[],"mappings":";;;;iBAIgB,WAAA;;;;;;;YAMK,OAAA,CAAM;EANX,CAAA;EACd,YAAA,CAAA,EAAA;IACA,IAAA,EAAA,MAAA;IACA,KAAA,EAAA,MAAA;IACA,OAAA,EAAA,MAAA;IAEmB,OAAM,EAAA,MAAA;EAanB,CAAA;EACP,QAAA,CAAA,EAAA,OAAA;EAAA,QAAA,CAAA,EAAA,CAAA,IAAA,EAAA;;;;;QADO;IACP,oBAAA,CAAA,GAAA,CAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"ContactForm.js","names":["React"],"sources":["../../../../src/components/legal/organisms/ContactForm.tsx"],"sourcesContent":["import * as React from 'react';\nimport { ContactFields } from '../molecules/ContactFields';\nimport { Button } from '../../atoms/Button';\n\nexport function ContactForm({\n labels = { submit: 'Envoyer' },\n initialValue = { name: '', email: '', subject: '', message: '' },\n disabled,\n onSubmit,\n}: {\n labels?: { submit: React.ReactNode };\n initialValue?: {\n name: string;\n email: string;\n subject: string;\n message: string;\n };\n disabled?: boolean;\n onSubmit?: (data: {\n name: string;\n email: string;\n subject: string;\n message: string;\n }) => Promise<void> | void;\n}) {\n const [value, setValue] = React.useState(initialValue);\n const [loading, setLoading] = React.useState(false);\n\n const handleSubmit = async (e: React.FormEvent) => {\n e.preventDefault();\n if (!onSubmit) return;\n setLoading(true);\n try {\n await onSubmit(value);\n } finally {\n setLoading(false);\n }\n };\n\n return (\n <form onSubmit={handleSubmit} className=\"space-y-6\">\n <ContactFields\n value={value}\n onChange={setValue}\n disabled={disabled || loading}\n />\n <Button disabled={disabled || loading} type=\"submit\">\n {loading ? 'Envoi…' : labels.submit}\n </Button>\n </form>\n );\n}\n"],"mappings":";;;;;;AAIA,SAAgB,YAAY,EAC1B,SAAS,EAAE,QAAQ,WAAW,EAC9B,eAAe;CAAE,MAAM;CAAI,OAAO;CAAI,SAAS;CAAI,SAAS;CAAI,EAChE,UACA,YAgBC;CACD,MAAM,CAAC,OAAO,YAAYA,QAAM,SAAS,aAAa;CACtD,MAAM,CAAC,SAAS,cAAcA,QAAM,SAAS,MAAM;CAEnD,MAAM,eAAe,OAAO,MAAuB;AACjD,IAAE,gBAAgB;AAClB,MAAI,CAAC,SAAU;AACf,aAAW,KAAK;AAChB,MAAI;AACF,SAAM,SAAS,MAAM;YACb;AACR,cAAW,MAAM;;;AAIrB,QACE,qBAAC;EAAK,UAAU;EAAc,WAAU;aACtC,oBAAC;GACQ;GACP,UAAU;GACV,UAAU,YAAY;IACtB,EACF,oBAAC;GAAO,UAAU,YAAY;GAAS,MAAK;aACzC,UAAU,WAAW,OAAO;IACtB;GACJ"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"GDPRDataRequest.d.ts","names":[],"sources":["../../../../src/components/legal/organisms/GDPRDataRequest.tsx"],"sourcesContent":[],"mappings":";;;;iBAMgB,eAAA;;;;;mBAKG;mBACA;EANH,MAAA,CAAA,EAAA;IACd,MAAA,EAMmB,OAAA,CAAM,SANzB;IACA,MAAA,EAK4C,OAAA,CAAM,SALlD;EACA,CAAA;CAEiB,CAAA,EAGlB,oBAAA,CAAA,GAAA,CAAA,OAHkB"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"GDPRDataRequest.js","names":["React"],"sources":["../../../../src/components/legal/organisms/GDPRDataRequest.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Button } from '../../atoms/Button';\nimport { LegalSection } from '../atoms/LegalSection';\nimport { LegalHeading } from '../atoms/LegalHeading';\nimport { LegalText } from '../atoms/LegalText';\n\nexport function GDPRDataRequest({\n onExport,\n onDelete,\n labels = { export: 'Demander une copie', delete: 'Demander la suppression' },\n}: {\n onExport?: () => Promise<void> | void;\n onDelete?: () => Promise<void> | void;\n labels?: { export: React.ReactNode; delete: React.ReactNode };\n}) {\n const [loading, setLoading] = React.useState<'export' | 'delete' | null>(\n null\n );\n\n const handle = async (kind: 'export' | 'delete') => {\n const fn = kind === 'export' ? onExport : onDelete;\n if (!fn) return;\n setLoading(kind);\n try {\n await fn();\n } finally {\n setLoading(null);\n }\n };\n\n return (\n <LegalSection border=\"top\" className=\"space-y-3\">\n <LegalHeading as=\"h2\" level=\"h2\">\n Demandes de données\n </LegalHeading>\n <LegalText>\n Vous pouvez demander une copie de vos données ou solliciter leur\n suppression. Ces demandes nécessitent une vérification d’identité et\n sont traitées dans les délais légaux.\n </LegalText>\n <div className=\"flex flex-wrap gap-3\">\n <Button onPress={() => handle('export')} disabled={loading !== null}>\n {loading === 'export' ? 'Envoi…' : labels.export}\n </Button>\n <Button\n variant=\"destructive\"\n onPress={() => handle('delete')}\n disabled={loading !== null}\n >\n {loading === 'delete' ? 'Envoi…' : labels.delete}\n </Button>\n </div>\n </LegalSection>\n );\n}\n"],"mappings":";;;;;;;;AAMA,SAAgB,gBAAgB,EAC9B,UACA,UACA,SAAS;CAAE,QAAQ;CAAsB,QAAQ;CAA2B,IAK3E;CACD,MAAM,CAAC,SAAS,cAAcA,QAAM,SAClC,KACD;CAED,MAAM,SAAS,OAAO,SAA8B;EAClD,MAAM,KAAK,SAAS,WAAW,WAAW;AAC1C,MAAI,CAAC,GAAI;AACT,aAAW,KAAK;AAChB,MAAI;AACF,SAAM,IAAI;YACF;AACR,cAAW,KAAK;;;AAIpB,QACE,qBAAC;EAAa,QAAO;EAAM,WAAU;;GACnC,oBAAC;IAAa,IAAG;IAAK,OAAM;cAAK;KAElB;GACf,oBAAC,uBAAU,gLAIC;GACZ,qBAAC;IAAI,WAAU;eACb,oBAAC;KAAO,eAAe,OAAO,SAAS;KAAE,UAAU,YAAY;eAC5D,YAAY,WAAW,WAAW,OAAO;MACnC,EACT,oBAAC;KACC,SAAQ;KACR,eAAe,OAAO,SAAS;KAC/B,UAAU,YAAY;eAErB,YAAY,WAAW,WAAW,OAAO;MACnC;KACL;;GACO"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"GDPRRights.d.ts","names":[],"sources":["../../../../src/components/legal/organisms/GDPRRights.tsx"],"sourcesContent":[],"mappings":";;;;iBAKgB,UAAA;;;AAAhB;UAUU,OAAA,CAAM;WACL,OAAA,CAAM;AAXjB,CAAA,CAAA,EAYC,oBAAA,CAAA,GAAA,CAAA,OAZyB"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"GDPRRights.js","names":[],"sources":["../../../../src/components/legal/organisms/GDPRRights.tsx"],"sourcesContent":["import * as React from 'react';\nimport { LegalHeading } from '../atoms/LegalHeading';\nimport { LegalList } from '../atoms/LegalList';\nimport { LegalSection } from '../atoms/LegalSection';\n\nexport function GDPRRights({\n title = 'Vos droits RGPD',\n rights = [\n 'Accès à vos données',\n 'Rectification',\n 'Effacement (droit à l’oubli)',\n 'Opposition et limitation',\n 'Portabilité',\n ],\n}: {\n title?: React.ReactNode;\n rights?: React.ReactNode[];\n}) {\n return (\n <LegalSection border=\"top\">\n <LegalHeading as=\"h2\" level=\"h2\">\n {title}\n </LegalHeading>\n <LegalList type=\"unordered\">\n {rights.map((r, i) => (\n <li key={i}>{r}</li>\n ))}\n </LegalList>\n </LegalSection>\n );\n}\n"],"mappings":";;;;;;;AAKA,SAAgB,WAAW,EACzB,QAAQ,mBACR,SAAS;CACP;CACA;CACA;CACA;CACA;CACD,IAIA;AACD,QACE,qBAAC;EAAa,QAAO;aACnB,oBAAC;GAAa,IAAG;GAAK,OAAM;aACzB;IACY,EACf,oBAAC;GAAU,MAAK;aACb,OAAO,KAAK,GAAG,MACd,oBAAC,kBAAY,KAAJ,EAAW,CACpB;IACQ;GACC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"LegalPageLayout.d.ts","names":[],"sources":["../../../../src/components/legal/organisms/LegalPageLayout.tsx"],"sourcesContent":[],"mappings":";;;;;iBAMgB,eAAA;;;;;;;SAOP,OAAA,CAAM;;IAPC,WAAA,CAAA,EAAe,MAAA,GAQG,IARH;IAC7B,OAAA,CAAA,EAAA,MAAA;EACA,CAAA;EACA,GAAA,CAAA,EAMM,OANN,EAAA;EACA,QAAA,EAMU,OAAA,CAAM,SANhB;EACA,SAAA,CAAA,EAAA,MAAA;CAEO,CAAA,EAKR,oBAAA,CAAA,GAAA,CAAA,OALc"}