@lssm/lib.design-system 0.0.0-canary-20251120192244 → 0.0.0-canary-20251206181705

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 (546) hide show
  1. package/README.md +21 -0
  2. package/dist/_virtual/rolldown_runtime.js +23 -16
  3. package/dist/components/agent/AgentMonitor.d.ts +28 -0
  4. package/dist/components/agent/AgentMonitor.js +78 -0
  5. package/dist/components/agent/ApprovalQueue.d.ts +25 -0
  6. package/dist/components/agent/ApprovalQueue.js +88 -0
  7. package/dist/components/atoms/ActionButtons.d.ts +11 -12
  8. package/dist/components/atoms/ActionButtons.js +3 -4
  9. package/dist/components/atoms/Button.d.ts +3 -4
  10. package/dist/components/atoms/Button.js +2 -3
  11. package/dist/components/atoms/Button.mobile.d.ts +3 -4
  12. package/dist/components/atoms/Button.mobile.js +2 -3
  13. package/dist/components/atoms/ButtonLink.d.ts +3 -4
  14. package/dist/components/atoms/ButtonLink.js +2 -4
  15. package/dist/components/atoms/ButtonLink.mobile.d.ts +3 -4
  16. package/dist/components/atoms/ButtonLink.mobile.js +2 -3
  17. package/dist/components/atoms/Cta.d.ts +3 -4
  18. package/dist/components/atoms/Cta.js +2 -3
  19. package/dist/components/atoms/Cta.mobile.d.ts +1 -2
  20. package/dist/components/atoms/Cta.mobile.js +2 -4
  21. package/dist/components/atoms/DataChips.d.ts +8 -9
  22. package/dist/components/atoms/DataChips.js +5 -6
  23. package/dist/components/atoms/EmptyState.d.ts +3 -4
  24. package/dist/components/atoms/EmptyState.js +1 -3
  25. package/dist/components/atoms/ErrorState.d.ts +3 -4
  26. package/dist/components/atoms/ErrorState.js +1 -2
  27. package/dist/components/atoms/ErrorState.mobile.d.ts +3 -4
  28. package/dist/components/atoms/ErrorState.mobile.js +1 -2
  29. package/dist/components/atoms/Input.d.ts +3 -4
  30. package/dist/components/atoms/Input.js +2 -3
  31. package/dist/components/atoms/Input.mobile.d.ts +3 -4
  32. package/dist/components/atoms/Input.mobile.js +2 -3
  33. package/dist/components/atoms/Link.d.ts +3 -4
  34. package/dist/components/atoms/Link.js +2 -3
  35. package/dist/components/atoms/Link.web.d.ts +3 -4
  36. package/dist/components/atoms/Link.web.js +2 -3
  37. package/dist/components/atoms/LoaderCircular.d.ts +5 -6
  38. package/dist/components/atoms/LoaderCircular.js +2 -3
  39. package/dist/components/atoms/LoaderCircular.mobile.d.ts +3 -4
  40. package/dist/components/atoms/LoaderCircular.mobile.js +1 -2
  41. package/dist/components/atoms/NavBrand.d.ts +3 -4
  42. package/dist/components/atoms/NavBrand.js +1 -3
  43. package/dist/components/atoms/Stepper.d.ts +3 -4
  44. package/dist/components/atoms/Stepper.js +1 -3
  45. package/dist/components/atoms/Textarea.d.ts +3 -4
  46. package/dist/components/atoms/Textarea.js +2 -3
  47. package/dist/components/atoms/Textarea.mobile.d.ts +3 -4
  48. package/dist/components/atoms/Textarea.mobile.js +2 -3
  49. package/dist/components/data-view/DataViewDetail.d.ts +3 -4
  50. package/dist/components/data-view/DataViewDetail.js +10 -12
  51. package/dist/components/data-view/DataViewList.d.ts +3 -4
  52. package/dist/components/data-view/DataViewList.js +6 -8
  53. package/dist/components/data-view/DataViewRenderer.d.ts +3 -4
  54. package/dist/components/data-view/DataViewRenderer.js +1 -3
  55. package/dist/components/data-view/DataViewTable.d.ts +3 -4
  56. package/dist/components/data-view/DataViewTable.js +10 -12
  57. package/dist/components/data-view/utils.d.ts +1 -2
  58. package/dist/components/data-view/utils.js +1 -3
  59. package/dist/components/forms/FormCardLayout.d.ts +3 -4
  60. package/dist/components/forms/FormCardLayout.js +1 -2
  61. package/dist/components/forms/FormDialog.d.ts +3 -4
  62. package/dist/components/forms/FormDialog.js +1 -3
  63. package/dist/components/forms/FormLayout.d.ts +5 -6
  64. package/dist/components/forms/FormLayout.js +1 -3
  65. package/dist/components/forms/FormOneByOneLayout.d.ts +3 -4
  66. package/dist/components/forms/FormOneByOneLayout.js +1 -2
  67. package/dist/components/forms/FormStepsLayout.d.ts +3 -4
  68. package/dist/components/forms/FormStepsLayout.js +1 -2
  69. package/dist/components/forms/ZodForm.d.ts +3 -4
  70. package/dist/components/forms/ZodForm.js +1 -3
  71. package/dist/components/legal/atoms/DefinitionList.d.ts +3 -4
  72. package/dist/components/legal/atoms/DefinitionList.js +1 -2
  73. package/dist/components/legal/atoms/KeyValueList.d.ts +3 -4
  74. package/dist/components/legal/atoms/KeyValueList.js +1 -2
  75. package/dist/components/legal/atoms/LegalCallout.d.ts +6 -7
  76. package/dist/components/legal/atoms/LegalCallout.js +2 -3
  77. package/dist/components/legal/atoms/LegalHeading.d.ts +5 -6
  78. package/dist/components/legal/atoms/LegalHeading.js +2 -3
  79. package/dist/components/legal/atoms/LegalList.d.ts +5 -6
  80. package/dist/components/legal/atoms/LegalList.js +2 -3
  81. package/dist/components/legal/atoms/LegalSection.d.ts +5 -6
  82. package/dist/components/legal/atoms/LegalSection.js +2 -3
  83. package/dist/components/legal/atoms/LegalText.d.ts +6 -7
  84. package/dist/components/legal/atoms/LegalText.js +2 -3
  85. package/dist/components/legal/molecules/Consent.d.ts +4 -5
  86. package/dist/components/legal/molecules/Consent.js +1 -2
  87. package/dist/components/legal/molecules/ContactFields.d.ts +3 -4
  88. package/dist/components/legal/molecules/ContactFields.js +1 -2
  89. package/dist/components/legal/molecules/LegalMeta.d.ts +3 -4
  90. package/dist/components/legal/molecules/LegalMeta.js +1 -2
  91. package/dist/components/legal/molecules/LegalTOC.d.ts +5 -6
  92. package/dist/components/legal/molecules/LegalTOC.js +2 -3
  93. package/dist/components/legal/organisms/ContactForm.d.ts +3 -4
  94. package/dist/components/legal/organisms/ContactForm.js +1 -2
  95. package/dist/components/legal/organisms/GDPRDataRequest.d.ts +3 -4
  96. package/dist/components/legal/organisms/GDPRDataRequest.js +1 -2
  97. package/dist/components/legal/organisms/GDPRRights.d.ts +3 -4
  98. package/dist/components/legal/organisms/GDPRRights.js +1 -2
  99. package/dist/components/legal/organisms/LegalPageLayout.d.ts +3 -4
  100. package/dist/components/legal/organisms/LegalPageLayout.js +1 -2
  101. package/dist/components/legal/templates/ContactTemplate.d.ts +3 -4
  102. package/dist/components/legal/templates/ContactTemplate.js +1 -2
  103. package/dist/components/legal/templates/CookiesTemplate.d.ts +3 -4
  104. package/dist/components/legal/templates/CookiesTemplate.js +1 -2
  105. package/dist/components/legal/templates/PrivacyTemplate.d.ts +3 -4
  106. package/dist/components/legal/templates/PrivacyTemplate.js +1 -2
  107. package/dist/components/legal/templates/SalesTermsTemplate.d.ts +3 -4
  108. package/dist/components/legal/templates/SalesTermsTemplate.js +1 -2
  109. package/dist/components/legal/templates/TermsTemplate.d.ts +3 -4
  110. package/dist/components/legal/templates/TermsTemplate.js +1 -3
  111. package/dist/components/molecules/AiLinkButton.d.ts +3 -4
  112. package/dist/components/molecules/AiLinkButton.js +1 -2
  113. package/dist/components/molecules/Breadcrumbs.d.ts +3 -4
  114. package/dist/components/molecules/Breadcrumbs.js +1 -3
  115. package/dist/components/molecules/CommandPalette.d.ts +3 -4
  116. package/dist/components/molecules/CommandPalette.js +1 -3
  117. package/dist/components/molecules/CommandSearchTrigger.d.ts +3 -4
  118. package/dist/components/molecules/CommandSearchTrigger.js +1 -3
  119. package/dist/components/molecules/EntityCard.d.ts +5 -6
  120. package/dist/components/molecules/EntityCard.js +2 -4
  121. package/dist/components/molecules/FiltersToolbar.d.ts +3 -4
  122. package/dist/components/molecules/FiltersToolbar.js +1 -2
  123. package/dist/components/molecules/FiltersToolbar.mobile.d.ts +3 -4
  124. package/dist/components/molecules/FiltersToolbar.mobile.js +1 -2
  125. package/dist/components/molecules/HoverPreview.d.ts +3 -4
  126. package/dist/components/molecules/HoverPreview.js +3 -5
  127. package/dist/components/molecules/LangSwitch.d.ts +3 -4
  128. package/dist/components/molecules/LangSwitch.js +1 -3
  129. package/dist/components/molecules/LangSwitchDropdown.d.ts +3 -4
  130. package/dist/components/molecules/LangSwitchDropdown.js +1 -2
  131. package/dist/components/molecules/LoaderBlock.d.ts +3 -4
  132. package/dist/components/molecules/LoaderBlock.js +1 -2
  133. package/dist/components/molecules/LoaderBlock.mobile.d.ts +3 -4
  134. package/dist/components/molecules/LoaderBlock.mobile.js +1 -2
  135. package/dist/components/molecules/MobileNavMenu.d.ts +3 -4
  136. package/dist/components/molecules/MobileNavMenu.js +1 -3
  137. package/dist/components/molecules/NavItemCard.d.ts +3 -4
  138. package/dist/components/molecules/NavItemCard.js +1 -3
  139. package/dist/components/molecules/NavMain.d.ts +3 -4
  140. package/dist/components/molecules/NavMain.js +1 -2
  141. package/dist/components/molecules/NavUser.d.ts +3 -4
  142. package/dist/components/molecules/NavUser.js +1 -2
  143. package/dist/components/molecules/OverviewCard.d.ts +3 -4
  144. package/dist/components/molecules/OverviewCard.js +1 -3
  145. package/dist/components/molecules/SkeletonBlock/index.mobile.d.ts +3 -4
  146. package/dist/components/molecules/SkeletonBlock/index.mobile.js +1 -2
  147. package/dist/components/molecules/SkeletonBlock/index.web.d.ts +3 -4
  148. package/dist/components/molecules/SkeletonBlock/index.web.js +1 -2
  149. package/dist/components/molecules/SkeletonBlock/types.d.ts +1 -2
  150. package/dist/components/molecules/SkeletonCircle/index.mobile.d.ts +3 -4
  151. package/dist/components/molecules/SkeletonCircle/index.mobile.js +1 -2
  152. package/dist/components/molecules/SkeletonCircle/index.web.d.ts +3 -4
  153. package/dist/components/molecules/SkeletonCircle/index.web.js +1 -2
  154. package/dist/components/molecules/SkeletonCircle/types.d.ts +1 -2
  155. package/dist/components/molecules/SkeletonList/index.mobile.d.ts +3 -4
  156. package/dist/components/molecules/SkeletonList/index.mobile.js +1 -2
  157. package/dist/components/molecules/SkeletonList/index.web.d.ts +3 -4
  158. package/dist/components/molecules/SkeletonList/index.web.js +1 -2
  159. package/dist/components/molecules/SkeletonList/types.d.ts +1 -2
  160. package/dist/components/molecules/StatCard.d.ts +6 -7
  161. package/dist/components/molecules/StatCard.js +2 -4
  162. package/dist/components/molecules/StatusChip.d.ts +6 -7
  163. package/dist/components/molecules/StatusChip.js +2 -4
  164. package/dist/components/molecules/hover-previews/Doc.d.ts +3 -4
  165. package/dist/components/molecules/hover-previews/Doc.js +1 -3
  166. package/dist/components/molecules/hover-previews/Media.d.ts +3 -4
  167. package/dist/components/molecules/hover-previews/Media.js +1 -3
  168. package/dist/components/molecules/hover-previews/Simple.d.ts +3 -4
  169. package/dist/components/molecules/hover-previews/Simple.js +1 -3
  170. package/dist/components/molecules/hover-previews/Stats.d.ts +3 -4
  171. package/dist/components/molecules/hover-previews/Stats.js +1 -3
  172. package/dist/components/molecules/hover-previews/User.d.ts +3 -4
  173. package/dist/components/molecules/hover-previews/User.js +1 -3
  174. package/dist/components/native/BottomTabs.mobile.d.ts +3 -4
  175. package/dist/components/native/BottomTabs.mobile.js +1 -3
  176. package/dist/components/native/FlatListScreen.mobile.d.ts +5 -6
  177. package/dist/components/native/FlatListScreen.mobile.js +2 -4
  178. package/dist/components/native/SheetMenu.mobile.d.ts +3 -4
  179. package/dist/components/native/SheetMenu.mobile.js +1 -3
  180. package/dist/components/organisms/AcademyLayout.d.ts +3 -4
  181. package/dist/components/organisms/AcademyLayout.js +1 -3
  182. package/dist/components/organisms/AppHeader.d.ts +3 -4
  183. package/dist/components/organisms/AppHeader.js +2 -4
  184. package/dist/components/organisms/AppHeader.mobile.d.ts +3 -4
  185. package/dist/components/organisms/AppHeader.mobile.js +1 -3
  186. package/dist/components/organisms/AppLayout.d.ts +3 -4
  187. package/dist/components/organisms/AppLayout.js +1 -3
  188. package/dist/components/organisms/AppSidebar.d.ts +3 -4
  189. package/dist/components/organisms/AppSidebar.js +1 -2
  190. package/dist/components/organisms/EmptyDataList.d.ts +3 -4
  191. package/dist/components/organisms/EmptyDataList.js +1 -2
  192. package/dist/components/organisms/EmptyDataList.mobile.d.ts +3 -4
  193. package/dist/components/organisms/EmptyDataList.mobile.js +1 -2
  194. package/dist/components/organisms/EmptyDataList.types.d.ts +1 -2
  195. package/dist/components/organisms/EmptySearchResult.d.ts +3 -4
  196. package/dist/components/organisms/EmptySearchResult.js +1 -2
  197. package/dist/components/organisms/FAQSection.d.ts +3 -4
  198. package/dist/components/organisms/FAQSection.js +1 -2
  199. package/dist/components/organisms/FeatureCarousel.d.ts +3 -4
  200. package/dist/components/organisms/FeatureCarousel.js +2 -3
  201. package/dist/components/organisms/FeaturesSection.d.ts +3 -4
  202. package/dist/components/organisms/FeaturesSection.js +1 -2
  203. package/dist/components/organisms/Footer.d.ts +3 -4
  204. package/dist/components/organisms/Footer.js +1 -2
  205. package/dist/components/organisms/GridLayout.d.ts +5 -6
  206. package/dist/components/organisms/GridLayout.js +1 -2
  207. package/dist/components/organisms/Header.d.ts +5 -6
  208. package/dist/components/organisms/Header.js +1 -3
  209. package/dist/components/organisms/Header.mobile.d.ts +3 -4
  210. package/dist/components/organisms/Header.mobile.js +1 -3
  211. package/dist/components/organisms/HeroResponsive.d.ts +3 -4
  212. package/dist/components/organisms/HeroResponsive.js +1 -3
  213. package/dist/components/organisms/HeroSection.d.ts +3 -4
  214. package/dist/components/organisms/HeroSection.js +1 -2
  215. package/dist/components/organisms/ListCardPage.d.ts +6 -7
  216. package/dist/components/organisms/ListCardPage.js +1 -3
  217. package/dist/components/organisms/ListGridPage.d.ts +6 -7
  218. package/dist/components/organisms/ListGridPage.js +1 -3
  219. package/dist/components/organisms/ListPageResponsive.d.ts +3 -4
  220. package/dist/components/organisms/ListPageResponsive.js +1 -3
  221. package/dist/components/organisms/ListTablePage.d.ts +5 -6
  222. package/dist/components/organisms/ListTablePage.js +1 -3
  223. package/dist/components/organisms/MarketingHeader.d.ts +3 -4
  224. package/dist/components/organisms/MarketingHeader.js +1 -3
  225. package/dist/components/organisms/MarketingHeaderDesktop.d.ts +3 -4
  226. package/dist/components/organisms/MarketingHeaderDesktop.js +1 -3
  227. package/dist/components/organisms/MarketingHeaderMobile.d.ts +3 -4
  228. package/dist/components/organisms/MarketingHeaderMobile.js +1 -3
  229. package/dist/components/organisms/MarketingLayout.d.ts +3 -4
  230. package/dist/components/organisms/MarketingLayout.js +1 -3
  231. package/dist/components/organisms/PageHeaderResponsive.d.ts +3 -4
  232. package/dist/components/organisms/PageHeaderResponsive.js +1 -3
  233. package/dist/components/organisms/PageHeaderResponsive.mobile.d.ts +3 -4
  234. package/dist/components/organisms/PageHeaderResponsive.mobile.js +1 -3
  235. package/dist/components/organisms/PricingCarousel.d.ts +3 -4
  236. package/dist/components/organisms/PricingCarousel.js +2 -3
  237. package/dist/components/organisms/PricingSection.d.ts +3 -4
  238. package/dist/components/organisms/PricingSection.js +1 -2
  239. package/dist/components/organisms/TestimonialCarousel.d.ts +3 -4
  240. package/dist/components/organisms/TestimonialCarousel.js +2 -3
  241. package/dist/components/templates/lists/ListPageTemplate/index.mobile.d.ts +3 -4
  242. package/dist/components/templates/lists/ListPageTemplate/index.mobile.js +1 -2
  243. package/dist/components/templates/lists/ListPageTemplate/index.web.d.ts +3 -4
  244. package/dist/components/templates/lists/ListPageTemplate/index.web.js +1 -2
  245. package/dist/components/templates/lists/ListPageTemplate/types.d.ts +1 -2
  246. package/dist/hooks/useListUrlState.d.ts +1 -2
  247. package/dist/hooks/useListUrlState.js +1 -2
  248. package/dist/index.d.ts +3 -1
  249. package/dist/index.js +3 -2
  250. package/dist/lib/keyboard.d.ts +1 -2
  251. package/dist/lib/keyboard.js +1 -2
  252. package/dist/lib/utils.d.ts +1 -2
  253. package/dist/lib/utils.js +1 -2
  254. package/dist/platform/useColorScheme.d.ts +1 -2
  255. package/dist/platform/useColorScheme.js +1 -3
  256. package/dist/platform/useColorScheme.mobile.d.ts +1 -2
  257. package/dist/platform/useColorScheme.mobile.js +1 -3
  258. package/dist/platform/useReducedMotion.d.ts +1 -2
  259. package/dist/platform/useReducedMotion.js +1 -3
  260. package/dist/platform/useReducedMotion.mobile.d.ts +1 -2
  261. package/dist/platform/useReducedMotion.mobile.js +1 -3
  262. package/dist/platform/useResponsive.d.ts +1 -2
  263. package/dist/platform/useResponsive.js +1 -3
  264. package/dist/platform/useResponsive.mobile.d.ts +1 -2
  265. package/dist/platform/useResponsive.mobile.js +1 -3
  266. package/dist/platform/withPlatformUI.d.ts +1 -2
  267. package/dist/platform/withPlatformUI.js +1 -3
  268. package/dist/renderers/form-contract.d.ts +3 -4
  269. package/dist/renderers/form-contract.js +2 -4
  270. package/dist/theme/tokenBridge.d.ts +1 -2
  271. package/dist/theme/tokenBridge.js +1 -3
  272. package/dist/theme/tokens.d.ts +1 -2
  273. package/dist/theme/tokens.js +1 -3
  274. package/dist/theme/variants.d.ts +4 -5
  275. package/dist/theme/variants.js +1 -3
  276. package/dist/types/navigation.d.ts +1 -2
  277. package/package.json +16 -10
  278. package/dist/components/atoms/ActionButtons.d.ts.map +0 -1
  279. package/dist/components/atoms/ActionButtons.js.map +0 -1
  280. package/dist/components/atoms/Button.d.ts.map +0 -1
  281. package/dist/components/atoms/Button.js.map +0 -1
  282. package/dist/components/atoms/Button.mobile.d.ts.map +0 -1
  283. package/dist/components/atoms/Button.mobile.js.map +0 -1
  284. package/dist/components/atoms/ButtonLink.d.ts.map +0 -1
  285. package/dist/components/atoms/ButtonLink.js.map +0 -1
  286. package/dist/components/atoms/ButtonLink.mobile.d.ts.map +0 -1
  287. package/dist/components/atoms/ButtonLink.mobile.js.map +0 -1
  288. package/dist/components/atoms/Cta.d.ts.map +0 -1
  289. package/dist/components/atoms/Cta.js.map +0 -1
  290. package/dist/components/atoms/Cta.mobile.d.ts.map +0 -1
  291. package/dist/components/atoms/Cta.mobile.js.map +0 -1
  292. package/dist/components/atoms/DataChips.d.ts.map +0 -1
  293. package/dist/components/atoms/DataChips.js.map +0 -1
  294. package/dist/components/atoms/EmptyState.d.ts.map +0 -1
  295. package/dist/components/atoms/EmptyState.js.map +0 -1
  296. package/dist/components/atoms/ErrorState.d.ts.map +0 -1
  297. package/dist/components/atoms/ErrorState.js.map +0 -1
  298. package/dist/components/atoms/ErrorState.mobile.d.ts.map +0 -1
  299. package/dist/components/atoms/ErrorState.mobile.js.map +0 -1
  300. package/dist/components/atoms/Input.d.ts.map +0 -1
  301. package/dist/components/atoms/Input.js.map +0 -1
  302. package/dist/components/atoms/Input.mobile.d.ts.map +0 -1
  303. package/dist/components/atoms/Input.mobile.js.map +0 -1
  304. package/dist/components/atoms/Link.d.ts.map +0 -1
  305. package/dist/components/atoms/Link.js.map +0 -1
  306. package/dist/components/atoms/Link.web.d.ts.map +0 -1
  307. package/dist/components/atoms/Link.web.js.map +0 -1
  308. package/dist/components/atoms/LoaderCircular.d.ts.map +0 -1
  309. package/dist/components/atoms/LoaderCircular.js.map +0 -1
  310. package/dist/components/atoms/LoaderCircular.mobile.d.ts.map +0 -1
  311. package/dist/components/atoms/LoaderCircular.mobile.js.map +0 -1
  312. package/dist/components/atoms/NavBrand.d.ts.map +0 -1
  313. package/dist/components/atoms/NavBrand.js.map +0 -1
  314. package/dist/components/atoms/Stepper.d.ts.map +0 -1
  315. package/dist/components/atoms/Stepper.js.map +0 -1
  316. package/dist/components/atoms/Textarea.d.ts.map +0 -1
  317. package/dist/components/atoms/Textarea.js.map +0 -1
  318. package/dist/components/atoms/Textarea.mobile.d.ts.map +0 -1
  319. package/dist/components/atoms/Textarea.mobile.js.map +0 -1
  320. package/dist/components/data-view/DataViewDetail.d.ts.map +0 -1
  321. package/dist/components/data-view/DataViewDetail.js.map +0 -1
  322. package/dist/components/data-view/DataViewList.d.ts.map +0 -1
  323. package/dist/components/data-view/DataViewList.js.map +0 -1
  324. package/dist/components/data-view/DataViewRenderer.d.ts.map +0 -1
  325. package/dist/components/data-view/DataViewRenderer.js.map +0 -1
  326. package/dist/components/data-view/DataViewTable.d.ts.map +0 -1
  327. package/dist/components/data-view/DataViewTable.js.map +0 -1
  328. package/dist/components/data-view/utils.d.ts.map +0 -1
  329. package/dist/components/data-view/utils.js.map +0 -1
  330. package/dist/components/forms/FormCardLayout.d.ts.map +0 -1
  331. package/dist/components/forms/FormCardLayout.js.map +0 -1
  332. package/dist/components/forms/FormDialog.d.ts.map +0 -1
  333. package/dist/components/forms/FormDialog.js.map +0 -1
  334. package/dist/components/forms/FormLayout.d.ts.map +0 -1
  335. package/dist/components/forms/FormLayout.js.map +0 -1
  336. package/dist/components/forms/FormOneByOneLayout.d.ts.map +0 -1
  337. package/dist/components/forms/FormOneByOneLayout.js.map +0 -1
  338. package/dist/components/forms/FormStepsLayout.d.ts.map +0 -1
  339. package/dist/components/forms/FormStepsLayout.js.map +0 -1
  340. package/dist/components/forms/ZodForm.d.ts.map +0 -1
  341. package/dist/components/forms/ZodForm.js.map +0 -1
  342. package/dist/components/legal/atoms/DefinitionList.d.ts.map +0 -1
  343. package/dist/components/legal/atoms/DefinitionList.js.map +0 -1
  344. package/dist/components/legal/atoms/KeyValueList.d.ts.map +0 -1
  345. package/dist/components/legal/atoms/KeyValueList.js.map +0 -1
  346. package/dist/components/legal/atoms/LegalCallout.d.ts.map +0 -1
  347. package/dist/components/legal/atoms/LegalCallout.js.map +0 -1
  348. package/dist/components/legal/atoms/LegalHeading.d.ts.map +0 -1
  349. package/dist/components/legal/atoms/LegalHeading.js.map +0 -1
  350. package/dist/components/legal/atoms/LegalList.d.ts.map +0 -1
  351. package/dist/components/legal/atoms/LegalList.js.map +0 -1
  352. package/dist/components/legal/atoms/LegalSection.d.ts.map +0 -1
  353. package/dist/components/legal/atoms/LegalSection.js.map +0 -1
  354. package/dist/components/legal/atoms/LegalText.d.ts.map +0 -1
  355. package/dist/components/legal/atoms/LegalText.js.map +0 -1
  356. package/dist/components/legal/molecules/Consent.d.ts.map +0 -1
  357. package/dist/components/legal/molecules/Consent.js.map +0 -1
  358. package/dist/components/legal/molecules/ContactFields.d.ts.map +0 -1
  359. package/dist/components/legal/molecules/ContactFields.js.map +0 -1
  360. package/dist/components/legal/molecules/LegalMeta.d.ts.map +0 -1
  361. package/dist/components/legal/molecules/LegalMeta.js.map +0 -1
  362. package/dist/components/legal/molecules/LegalTOC.d.ts.map +0 -1
  363. package/dist/components/legal/molecules/LegalTOC.js.map +0 -1
  364. package/dist/components/legal/organisms/ContactForm.d.ts.map +0 -1
  365. package/dist/components/legal/organisms/ContactForm.js.map +0 -1
  366. package/dist/components/legal/organisms/GDPRDataRequest.d.ts.map +0 -1
  367. package/dist/components/legal/organisms/GDPRDataRequest.js.map +0 -1
  368. package/dist/components/legal/organisms/GDPRRights.d.ts.map +0 -1
  369. package/dist/components/legal/organisms/GDPRRights.js.map +0 -1
  370. package/dist/components/legal/organisms/LegalPageLayout.d.ts.map +0 -1
  371. package/dist/components/legal/organisms/LegalPageLayout.js.map +0 -1
  372. package/dist/components/legal/templates/ContactTemplate.d.ts.map +0 -1
  373. package/dist/components/legal/templates/ContactTemplate.js.map +0 -1
  374. package/dist/components/legal/templates/CookiesTemplate.d.ts.map +0 -1
  375. package/dist/components/legal/templates/CookiesTemplate.js.map +0 -1
  376. package/dist/components/legal/templates/PrivacyTemplate.d.ts.map +0 -1
  377. package/dist/components/legal/templates/PrivacyTemplate.js.map +0 -1
  378. package/dist/components/legal/templates/SalesTermsTemplate.d.ts.map +0 -1
  379. package/dist/components/legal/templates/SalesTermsTemplate.js.map +0 -1
  380. package/dist/components/legal/templates/TermsTemplate.d.ts.map +0 -1
  381. package/dist/components/legal/templates/TermsTemplate.js.map +0 -1
  382. package/dist/components/molecules/AiLinkButton.d.ts.map +0 -1
  383. package/dist/components/molecules/AiLinkButton.js.map +0 -1
  384. package/dist/components/molecules/Breadcrumbs.d.ts.map +0 -1
  385. package/dist/components/molecules/Breadcrumbs.js.map +0 -1
  386. package/dist/components/molecules/CommandPalette.d.ts.map +0 -1
  387. package/dist/components/molecules/CommandPalette.js.map +0 -1
  388. package/dist/components/molecules/CommandSearchTrigger.d.ts.map +0 -1
  389. package/dist/components/molecules/CommandSearchTrigger.js.map +0 -1
  390. package/dist/components/molecules/EntityCard.d.ts.map +0 -1
  391. package/dist/components/molecules/EntityCard.js.map +0 -1
  392. package/dist/components/molecules/FiltersToolbar.d.ts.map +0 -1
  393. package/dist/components/molecules/FiltersToolbar.js.map +0 -1
  394. package/dist/components/molecules/FiltersToolbar.mobile.d.ts.map +0 -1
  395. package/dist/components/molecules/FiltersToolbar.mobile.js.map +0 -1
  396. package/dist/components/molecules/HoverPreview.d.ts.map +0 -1
  397. package/dist/components/molecules/HoverPreview.js.map +0 -1
  398. package/dist/components/molecules/LangSwitch.d.ts.map +0 -1
  399. package/dist/components/molecules/LangSwitch.js.map +0 -1
  400. package/dist/components/molecules/LangSwitchDropdown.d.ts.map +0 -1
  401. package/dist/components/molecules/LangSwitchDropdown.js.map +0 -1
  402. package/dist/components/molecules/LoaderBlock.d.ts.map +0 -1
  403. package/dist/components/molecules/LoaderBlock.js.map +0 -1
  404. package/dist/components/molecules/LoaderBlock.mobile.d.ts.map +0 -1
  405. package/dist/components/molecules/LoaderBlock.mobile.js.map +0 -1
  406. package/dist/components/molecules/MobileNavMenu.d.ts.map +0 -1
  407. package/dist/components/molecules/MobileNavMenu.js.map +0 -1
  408. package/dist/components/molecules/NavItemCard.d.ts.map +0 -1
  409. package/dist/components/molecules/NavItemCard.js.map +0 -1
  410. package/dist/components/molecules/NavMain.d.ts.map +0 -1
  411. package/dist/components/molecules/NavMain.js.map +0 -1
  412. package/dist/components/molecules/NavUser.d.ts.map +0 -1
  413. package/dist/components/molecules/NavUser.js.map +0 -1
  414. package/dist/components/molecules/OverviewCard.d.ts.map +0 -1
  415. package/dist/components/molecules/OverviewCard.js.map +0 -1
  416. package/dist/components/molecules/SkeletonBlock/index.mobile.d.ts.map +0 -1
  417. package/dist/components/molecules/SkeletonBlock/index.mobile.js.map +0 -1
  418. package/dist/components/molecules/SkeletonBlock/index.web.d.ts.map +0 -1
  419. package/dist/components/molecules/SkeletonBlock/index.web.js.map +0 -1
  420. package/dist/components/molecules/SkeletonBlock/types.d.ts.map +0 -1
  421. package/dist/components/molecules/SkeletonCircle/index.mobile.d.ts.map +0 -1
  422. package/dist/components/molecules/SkeletonCircle/index.mobile.js.map +0 -1
  423. package/dist/components/molecules/SkeletonCircle/index.web.d.ts.map +0 -1
  424. package/dist/components/molecules/SkeletonCircle/index.web.js.map +0 -1
  425. package/dist/components/molecules/SkeletonCircle/types.d.ts.map +0 -1
  426. package/dist/components/molecules/SkeletonList/index.mobile.d.ts.map +0 -1
  427. package/dist/components/molecules/SkeletonList/index.mobile.js.map +0 -1
  428. package/dist/components/molecules/SkeletonList/index.web.d.ts.map +0 -1
  429. package/dist/components/molecules/SkeletonList/index.web.js.map +0 -1
  430. package/dist/components/molecules/SkeletonList/types.d.ts.map +0 -1
  431. package/dist/components/molecules/StatCard.d.ts.map +0 -1
  432. package/dist/components/molecules/StatCard.js.map +0 -1
  433. package/dist/components/molecules/StatusChip.d.ts.map +0 -1
  434. package/dist/components/molecules/StatusChip.js.map +0 -1
  435. package/dist/components/molecules/hover-previews/Doc.d.ts.map +0 -1
  436. package/dist/components/molecules/hover-previews/Doc.js.map +0 -1
  437. package/dist/components/molecules/hover-previews/Media.d.ts.map +0 -1
  438. package/dist/components/molecules/hover-previews/Media.js.map +0 -1
  439. package/dist/components/molecules/hover-previews/Simple.d.ts.map +0 -1
  440. package/dist/components/molecules/hover-previews/Simple.js.map +0 -1
  441. package/dist/components/molecules/hover-previews/Stats.d.ts.map +0 -1
  442. package/dist/components/molecules/hover-previews/Stats.js.map +0 -1
  443. package/dist/components/molecules/hover-previews/User.d.ts.map +0 -1
  444. package/dist/components/molecules/hover-previews/User.js.map +0 -1
  445. package/dist/components/native/BottomTabs.mobile.d.ts.map +0 -1
  446. package/dist/components/native/BottomTabs.mobile.js.map +0 -1
  447. package/dist/components/native/FlatListScreen.mobile.d.ts.map +0 -1
  448. package/dist/components/native/FlatListScreen.mobile.js.map +0 -1
  449. package/dist/components/native/SheetMenu.mobile.d.ts.map +0 -1
  450. package/dist/components/native/SheetMenu.mobile.js.map +0 -1
  451. package/dist/components/organisms/AcademyLayout.d.ts.map +0 -1
  452. package/dist/components/organisms/AcademyLayout.js.map +0 -1
  453. package/dist/components/organisms/AppHeader.d.ts.map +0 -1
  454. package/dist/components/organisms/AppHeader.js.map +0 -1
  455. package/dist/components/organisms/AppHeader.mobile.d.ts.map +0 -1
  456. package/dist/components/organisms/AppHeader.mobile.js.map +0 -1
  457. package/dist/components/organisms/AppLayout.d.ts.map +0 -1
  458. package/dist/components/organisms/AppLayout.js.map +0 -1
  459. package/dist/components/organisms/AppSidebar.d.ts.map +0 -1
  460. package/dist/components/organisms/AppSidebar.js.map +0 -1
  461. package/dist/components/organisms/EmptyDataList.d.ts.map +0 -1
  462. package/dist/components/organisms/EmptyDataList.js.map +0 -1
  463. package/dist/components/organisms/EmptyDataList.mobile.d.ts.map +0 -1
  464. package/dist/components/organisms/EmptyDataList.mobile.js.map +0 -1
  465. package/dist/components/organisms/EmptyDataList.types.d.ts.map +0 -1
  466. package/dist/components/organisms/EmptySearchResult.d.ts.map +0 -1
  467. package/dist/components/organisms/EmptySearchResult.js.map +0 -1
  468. package/dist/components/organisms/FAQSection.d.ts.map +0 -1
  469. package/dist/components/organisms/FAQSection.js.map +0 -1
  470. package/dist/components/organisms/FeatureCarousel.d.ts.map +0 -1
  471. package/dist/components/organisms/FeatureCarousel.js.map +0 -1
  472. package/dist/components/organisms/FeaturesSection.d.ts.map +0 -1
  473. package/dist/components/organisms/FeaturesSection.js.map +0 -1
  474. package/dist/components/organisms/Footer.d.ts.map +0 -1
  475. package/dist/components/organisms/Footer.js.map +0 -1
  476. package/dist/components/organisms/GridLayout.d.ts.map +0 -1
  477. package/dist/components/organisms/GridLayout.js.map +0 -1
  478. package/dist/components/organisms/Header.d.ts.map +0 -1
  479. package/dist/components/organisms/Header.js.map +0 -1
  480. package/dist/components/organisms/Header.mobile.d.ts.map +0 -1
  481. package/dist/components/organisms/Header.mobile.js.map +0 -1
  482. package/dist/components/organisms/HeroResponsive.d.ts.map +0 -1
  483. package/dist/components/organisms/HeroResponsive.js.map +0 -1
  484. package/dist/components/organisms/HeroSection.d.ts.map +0 -1
  485. package/dist/components/organisms/HeroSection.js.map +0 -1
  486. package/dist/components/organisms/ListCardPage.d.ts.map +0 -1
  487. package/dist/components/organisms/ListCardPage.js.map +0 -1
  488. package/dist/components/organisms/ListGridPage.d.ts.map +0 -1
  489. package/dist/components/organisms/ListGridPage.js.map +0 -1
  490. package/dist/components/organisms/ListPageResponsive.d.ts.map +0 -1
  491. package/dist/components/organisms/ListPageResponsive.js.map +0 -1
  492. package/dist/components/organisms/ListTablePage.d.ts.map +0 -1
  493. package/dist/components/organisms/ListTablePage.js.map +0 -1
  494. package/dist/components/organisms/MarketingHeader.d.ts.map +0 -1
  495. package/dist/components/organisms/MarketingHeader.js.map +0 -1
  496. package/dist/components/organisms/MarketingHeaderDesktop.d.ts.map +0 -1
  497. package/dist/components/organisms/MarketingHeaderDesktop.js.map +0 -1
  498. package/dist/components/organisms/MarketingHeaderMobile.d.ts.map +0 -1
  499. package/dist/components/organisms/MarketingHeaderMobile.js.map +0 -1
  500. package/dist/components/organisms/MarketingLayout.d.ts.map +0 -1
  501. package/dist/components/organisms/MarketingLayout.js.map +0 -1
  502. package/dist/components/organisms/PageHeaderResponsive.d.ts.map +0 -1
  503. package/dist/components/organisms/PageHeaderResponsive.js.map +0 -1
  504. package/dist/components/organisms/PageHeaderResponsive.mobile.d.ts.map +0 -1
  505. package/dist/components/organisms/PageHeaderResponsive.mobile.js.map +0 -1
  506. package/dist/components/organisms/PricingCarousel.d.ts.map +0 -1
  507. package/dist/components/organisms/PricingCarousel.js.map +0 -1
  508. package/dist/components/organisms/PricingSection.d.ts.map +0 -1
  509. package/dist/components/organisms/PricingSection.js.map +0 -1
  510. package/dist/components/organisms/TestimonialCarousel.d.ts.map +0 -1
  511. package/dist/components/organisms/TestimonialCarousel.js.map +0 -1
  512. package/dist/components/templates/lists/ListPageTemplate/index.mobile.d.ts.map +0 -1
  513. package/dist/components/templates/lists/ListPageTemplate/index.mobile.js.map +0 -1
  514. package/dist/components/templates/lists/ListPageTemplate/index.web.d.ts.map +0 -1
  515. package/dist/components/templates/lists/ListPageTemplate/index.web.js.map +0 -1
  516. package/dist/components/templates/lists/ListPageTemplate/types.d.ts.map +0 -1
  517. package/dist/hooks/useListUrlState.d.ts.map +0 -1
  518. package/dist/hooks/useListUrlState.js.map +0 -1
  519. package/dist/index.js.map +0 -1
  520. package/dist/lib/keyboard.d.ts.map +0 -1
  521. package/dist/lib/keyboard.js.map +0 -1
  522. package/dist/lib/utils.d.ts.map +0 -1
  523. package/dist/lib/utils.js.map +0 -1
  524. package/dist/platform/useColorScheme.d.ts.map +0 -1
  525. package/dist/platform/useColorScheme.js.map +0 -1
  526. package/dist/platform/useColorScheme.mobile.d.ts.map +0 -1
  527. package/dist/platform/useColorScheme.mobile.js.map +0 -1
  528. package/dist/platform/useReducedMotion.d.ts.map +0 -1
  529. package/dist/platform/useReducedMotion.js.map +0 -1
  530. package/dist/platform/useReducedMotion.mobile.d.ts.map +0 -1
  531. package/dist/platform/useReducedMotion.mobile.js.map +0 -1
  532. package/dist/platform/useResponsive.d.ts.map +0 -1
  533. package/dist/platform/useResponsive.js.map +0 -1
  534. package/dist/platform/useResponsive.mobile.d.ts.map +0 -1
  535. package/dist/platform/useResponsive.mobile.js.map +0 -1
  536. package/dist/platform/withPlatformUI.d.ts.map +0 -1
  537. package/dist/platform/withPlatformUI.js.map +0 -1
  538. package/dist/renderers/form-contract.d.ts.map +0 -1
  539. package/dist/renderers/form-contract.js.map +0 -1
  540. package/dist/theme/tokenBridge.d.ts.map +0 -1
  541. package/dist/theme/tokenBridge.js.map +0 -1
  542. package/dist/theme/tokens.d.ts.map +0 -1
  543. package/dist/theme/tokens.js.map +0 -1
  544. package/dist/theme/variants.d.ts.map +0 -1
  545. package/dist/theme/variants.js.map +0 -1
  546. package/dist/types/navigation.d.ts.map +0 -1
@@ -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-base font-semibold text-foreground\">\n {spec.meta.title}\n </h3>\n {headerActions}\n </div>\n {emptyState ?? (\n <div className=\"rounded-md border border-dashed border-muted-foreground/40 p-8 text-center text-sm text-muted-foreground\">\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-xl font-semibold text-foreground\">\n {spec.meta.title}\n </h3>\n <p className=\"text-sm text-muted-foreground\">{spec.meta.description}</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=\"rounded-lg border border-border bg-card p-4 shadow-sm\"\n >\n {section.title ? (\n <h4 className=\"mb-2 text-sm font-semibold uppercase tracking-wide text-muted-foreground\">\n {section.title}\n </h4>\n ) : null}\n {section.description ? (\n <p className=\"mb-4 text-sm text-muted-foreground\">\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-xs font-semibold uppercase text-muted-foreground/80\">\n {field.label}\n </dt>\n <dd className=\"text-sm text-foreground\">\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\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;cAAiC,KAAK,KAAK;KAAgB,IACpE,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=\"rounded-md border border-dashed border-muted-foreground/40 p-8 text-center text-sm text-muted-foreground\">\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 'flex w-full flex-col gap-2 rounded-lg border border-muted bg-card p-4 text-left shadow-sm transition hover:border-primary/40 hover:shadow-md focus-visible:border-primary focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-primary/40',\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-base font-medium text-foreground\">\n {displayValue(item, fields, primaryField)}\n </span>\n ) : null}\n <div className=\"flex flex-wrap gap-x-4 gap-y-1 text-sm text-muted-foreground\">\n {secondaryFieldKeys(view, primaryField).map((fieldKey) => (\n <span key={fieldKey} className=\"flex items-center gap-1.5\">\n <span className=\"font-medium text-foreground/80\">\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\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-base font-semibold text-foreground\">\n {spec.meta.title}\n </h3>\n {headerActions}\n </div>\n {emptyState ?? (\n <div className=\"rounded-md border border-dashed border-muted-foreground/40 p-8 text-center text-sm text-muted-foreground\">\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-base font-semibold text-foreground\">\n {spec.meta.title}\n </h3>\n {headerActions}\n </div>\n <div className=\"overflow-x-auto rounded-lg border border-border bg-card shadow-sm\">\n <table\n className={cn(\n 'min-w-full divide-y divide-border 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 'px-4 py-3 text-left font-semibold text-muted-foreground',\n alignmentClass(column.align)\n )}\n >\n {column.label}\n </th>\n ))}\n </tr>\n </thead>\n <tbody className=\"divide-y divide-border bg-background\">\n {items.map((item, rowIdx) => (\n <tr\n key={rowIdx}\n className={cn(\n onRowClick &&\n 'cursor-pointer hover:bg-muted/30 transition-colors'\n )}\n onClick={() => onRowClick?.(item)}\n >\n {columns.map((column) => (\n <td\n key={column.field}\n className={cn(\n 'px-4 py-3 text-foreground',\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\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\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,+BAAA,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,kBAAA,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,UAAW,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,UACA,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,mBAAA,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,SACA,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,oBAAA,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,UACA,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,+BAAA,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,mBAAA,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,UACA,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,oBAAA,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,oBAAA,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,oBAAA,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,oBAAA,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,UACA,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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"LegalPageLayout.js","names":[],"sources":["../../../../src/components/legal/organisms/LegalPageLayout.tsx"],"sourcesContent":["import * as React from 'react';\nimport { cn } from '@lssm/lib.ui-kit-web/ui/utils';\nimport { LegalHeading } from '../atoms/LegalHeading';\nimport { LegalMeta } from '../molecules/LegalMeta';\nimport { LegalTOC, type TocItem } from '../molecules/LegalTOC';\n\nexport function LegalPageLayout({\n title,\n meta,\n toc,\n children,\n className,\n}: {\n title: React.ReactNode;\n meta?: { lastUpdated?: string | Date; version?: string };\n toc?: TocItem[];\n children: React.ReactNode;\n className?: string;\n}) {\n return (\n <div\n className={cn('mx-auto w-full max-w-6xl px-4 py-8 md:py-12', className)}\n >\n <div className=\"mb-6 space-y-2\">\n <LegalHeading as=\"h1\" level=\"h1\" spacing=\"sm\">\n {title}\n </LegalHeading>\n {meta && (\n <LegalMeta lastUpdated={meta.lastUpdated} version={meta.version} />\n )}\n </div>\n {toc && toc.length > 0 && (\n <div className=\"mb-6 md:hidden\">\n <LegalTOC items={toc} variant=\"inline\" />\n </div>\n )}\n <div className=\"grid grid-cols-1 gap-8 md:grid-cols-[220px_minmax(0,1fr)]\">\n {toc && toc.length > 0 ? (\n <aside className=\"sticky top-24 hidden self-start md:block\">\n <LegalTOC items={toc} variant=\"sidebar\" />\n </aside>\n ) : (\n <div className=\"hidden md:block\" />\n )}\n <article className=\"prose text-foreground max-w-none\">\n {children}\n </article>\n </div>\n </div>\n );\n}\n"],"mappings":";;;;;;;;AAMA,SAAgB,gBAAgB,EAC9B,OACA,MACA,KACA,UACA,aAOC;AACD,QACE,qBAAC;EACC,WAAW,GAAG,+CAA+C,UAAU;;GAEvE,qBAAC;IAAI,WAAU;eACb,oBAAC;KAAa,IAAG;KAAK,OAAM;KAAK,SAAQ;eACtC;MACY,EACd,QACC,oBAAC;KAAU,aAAa,KAAK;KAAa,SAAS,KAAK;MAAW;KAEjE;GACL,OAAO,IAAI,SAAS,KACnB,oBAAC;IAAI,WAAU;cACb,oBAAC;KAAS,OAAO;KAAK,SAAQ;MAAW;KACrC;GAER,qBAAC;IAAI,WAAU;eACZ,OAAO,IAAI,SAAS,IACnB,oBAAC;KAAM,WAAU;eACf,oBAAC;MAAS,OAAO;MAAK,SAAQ;OAAY;MACpC,GAER,oBAAC,SAAI,WAAU,oBAAoB,EAErC,oBAAC;KAAQ,WAAU;KAChB;MACO;KACN;;GACF"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"ContactTemplate.d.ts","names":[],"sources":["../../../../src/components/legal/templates/ContactTemplate.tsx"],"sourcesContent":[],"mappings":";;;;iBAKgB,eAAA;;;;;UAKN,OAAA,CAAM;;IALA,WAAA,CAAA,EAAe,MAAA,GAMG,IANH;IAC7B,OAAA,CAAA,EAAA,MAAA;EACA,CAAA;EACA,QAAA,CAAA,EAAA,CAAA,IAAA,EAAA;IAEQ,IAAM,EAAA,MAAA;IACkB,KAAA,EAAA,MAAA;IAM1B,OAAA,EAAA,MAAA;IACP,OAAA,EAAA,MAAA;EAAA,CAAA,EAAA,GADO,OACP,CAAA,IAAA,CAAA,GAAA,IAAA;IAAA,oBAAA,CAAA,GAAA,CAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"ContactTemplate.js","names":["React"],"sources":["../../../../src/components/legal/templates/ContactTemplate.tsx"],"sourcesContent":["import * as React from 'react';\nimport { LegalPageLayout } from '../organisms/LegalPageLayout';\nimport { ContactFields } from '../molecules/ContactFields';\nimport { Button } from '../../../index';\n\nexport function ContactTemplate({\n title = 'Contact',\n meta,\n onSubmit,\n}: {\n title?: React.ReactNode;\n meta?: { lastUpdated?: string | Date; version?: string };\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({\n name: '',\n email: '',\n subject: '',\n message: '',\n });\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 <LegalPageLayout title={title} meta={meta}>\n <form onSubmit={handleSubmit} className=\"space-y-6\">\n <ContactFields value={value} onChange={setValue} disabled={loading} />\n <Button disabled={loading} type=\"submit\">\n {loading ? 'Envoi…' : 'Envoyer'}\n </Button>\n </form>\n </LegalPageLayout>\n );\n}\n"],"mappings":";;;;;;;AAKA,SAAgB,gBAAgB,EAC9B,QAAQ,WACR,MACA,YAUC;CACD,MAAM,CAAC,OAAO,YAAYA,QAAM,SAAS;EACvC,MAAM;EACN,OAAO;EACP,SAAS;EACT,SAAS;EACV,CAAC;CACF,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,oBAAC;EAAuB;EAAa;YACnC,qBAAC;GAAK,UAAU;GAAc,WAAU;cACtC,oBAAC;IAAqB;IAAO,UAAU;IAAU,UAAU;KAAW,EACtE,oBAAC;IAAO,UAAU;IAAS,MAAK;cAC7B,UAAU,WAAW;KACf;IACJ;GACS"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"CookiesTemplate.d.ts","names":[],"sources":["../../../../src/components/legal/templates/CookiesTemplate.tsx"],"sourcesContent":[],"mappings":";;;;iBAOgB,eAAA;;;;;;;UAON,OAAA,CAAM;;IAPA,WAAA,CAAA,EAAe,MAAA,GAQG,IARH;IAC7B,OAAA,CAAA,EAAA,MAAA;EACA,CAAA;EACA,GAAA,CAAA,EAAA;IACA,IAAA,EAAA,MAAA;IACA,KAAA,EAI6B,OAAA,CAAM,SAJnC;EAEQ,CAAA,EAAA;EACwB,SAAA,CAAA,EAAA;IACH,GAAM,EAChB,OAAA,CAAM,SADU;IAChB,KAAM,EAAkB,OAAA,CAAM,SAAxB;EAAkB,CAAA,EAAA;EACZ,QAAM,EAAA;IAAoB,EAAM,EAAA,MAAA;IAChE,KAAA,EADgC,OAAA,CAAM,SACtC;IAAA,OAAA,EAD0D,OAAA,CAAM,SAChE;;IAAA,oBAAA,CAAA,GAAA,CAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"CookiesTemplate.js","names":[],"sources":["../../../../src/components/legal/templates/CookiesTemplate.tsx"],"sourcesContent":["import * as React from 'react';\nimport { LegalPageLayout } from '../organisms/LegalPageLayout';\nimport { LegalSection } from '../atoms/LegalSection';\nimport { LegalHeading } from '../atoms/LegalHeading';\nimport { LegalText } from '../atoms/LegalText';\nimport { KeyValueList } from '../atoms/KeyValueList';\n\nexport function CookiesTemplate({\n title = 'Politique Cookies',\n meta,\n toc,\n keyValues,\n sections,\n}: {\n title?: React.ReactNode;\n meta?: { lastUpdated?: string | Date; version?: string };\n toc?: { href: string; label: React.ReactNode }[];\n keyValues?: { key: React.ReactNode; value: React.ReactNode }[];\n sections: { id: string; title: React.ReactNode; content: React.ReactNode }[];\n}) {\n return (\n <LegalPageLayout title={title} meta={meta} toc={toc}>\n {keyValues && keyValues.length > 0 && (\n <LegalSection border=\"bottom\">\n <KeyValueList items={keyValues} />\n </LegalSection>\n )}\n\n {sections.map((s) => (\n <LegalSection\n key={s.id}\n id={s.id}\n border=\"top\"\n className=\"scroll-mt-24\"\n >\n <LegalHeading as=\"h2\" level=\"h2\">\n {s.title}\n </LegalHeading>\n <LegalText as=\"div\">{s.content}</LegalText>\n </LegalSection>\n ))}\n </LegalPageLayout>\n );\n}\n"],"mappings":";;;;;;;;;AAOA,SAAgB,gBAAgB,EAC9B,QAAQ,qBACR,MACA,KACA,WACA,YAOC;AACD,QACE,qBAAC;EAAuB;EAAa;EAAW;aAC7C,aAAa,UAAU,SAAS,KAC/B,oBAAC;GAAa,QAAO;aACnB,oBAAC,gBAAa,OAAO,YAAa;IACrB,EAGhB,SAAS,KAAK,MACb,qBAAC;GAEC,IAAI,EAAE;GACN,QAAO;GACP,WAAU;cAEV,oBAAC;IAAa,IAAG;IAAK,OAAM;cACzB,EAAE;KACU,EACf,oBAAC;IAAU,IAAG;cAAO,EAAE;KAAoB;KARtC,EAAE,GASM,CACf;GACc"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"PrivacyTemplate.d.ts","names":[],"sources":["../../../../src/components/legal/templates/PrivacyTemplate.tsx"],"sourcesContent":[],"mappings":";;;;iBAOgB,eAAA;;;;;;;UAON,OAAA,CAAM;;IAPA,WAAA,CAAA,EAAe,MAAA,GAQG,IARH;IAC7B,OAAA,CAAA,EAAA,MAAA;EACA,CAAA;EACA,GAAA,CAAA,EAAA;IACA,IAAA,EAAA,MAAA;IACA,KAAA,EAI6B,OAAA,CAAM,SAJnC;EAEQ,CAAA,EAAA;EACwB,QAAA,EAAA;IACH,EAAM,EAAA,MAAA;IACJ,KAAM,EAAN,OAAA,CAAM,SAAA;IAAoB,OAAM,EAAN,OAAA,CAAM,SAAA;EACzC,CAAA,EAAA;EAA8B,WAAM,CAAA,EAAA;IAC3D,IAAA,EADuB,OAAA,CAAM,SAC7B;IAAA,WAAA,EADqD,OAAA,CAAM,SAC3D;;IAAA,oBAAA,CAAA,GAAA,CAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"PrivacyTemplate.js","names":[],"sources":["../../../../src/components/legal/templates/PrivacyTemplate.tsx"],"sourcesContent":["import * as React from 'react';\nimport { LegalPageLayout } from '../organisms/LegalPageLayout';\nimport { LegalSection } from '../atoms/LegalSection';\nimport { LegalHeading } from '../atoms/LegalHeading';\nimport { LegalText } from '../atoms/LegalText';\nimport { DefinitionList } from '../atoms/DefinitionList';\n\nexport function PrivacyTemplate({\n title = 'Politique de Confidentialité',\n meta,\n toc,\n sections,\n definitions,\n}: {\n title?: React.ReactNode;\n meta?: { lastUpdated?: string | Date; version?: string };\n toc?: { href: string; label: React.ReactNode }[];\n sections: { id: string; title: React.ReactNode; content: React.ReactNode }[];\n definitions?: { term: React.ReactNode; description: React.ReactNode }[];\n}) {\n return (\n <LegalPageLayout title={title} meta={meta} toc={toc}>\n {definitions && definitions.length > 0 && (\n <LegalSection border=\"bottom\">\n <LegalHeading as=\"h2\" level=\"h3\">\n Définitions\n </LegalHeading>\n <DefinitionList items={definitions} />\n </LegalSection>\n )}\n\n {sections.map((s) => (\n <LegalSection\n key={s.id}\n id={s.id}\n border=\"top\"\n className=\"scroll-mt-24\"\n >\n <LegalHeading as=\"h2\" level=\"h2\">\n {s.title}\n </LegalHeading>\n <LegalText as=\"div\">{s.content}</LegalText>\n </LegalSection>\n ))}\n </LegalPageLayout>\n );\n}\n"],"mappings":";;;;;;;;;AAOA,SAAgB,gBAAgB,EAC9B,QAAQ,gCACR,MACA,KACA,UACA,eAOC;AACD,QACE,qBAAC;EAAuB;EAAa;EAAW;aAC7C,eAAe,YAAY,SAAS,KACnC,qBAAC;GAAa,QAAO;cACnB,oBAAC;IAAa,IAAG;IAAK,OAAM;cAAK;KAElB,EACf,oBAAC,kBAAe,OAAO,cAAe;IACzB,EAGhB,SAAS,KAAK,MACb,qBAAC;GAEC,IAAI,EAAE;GACN,QAAO;GACP,WAAU;cAEV,oBAAC;IAAa,IAAG;IAAK,OAAM;cACzB,EAAE;KACU,EACf,oBAAC;IAAU,IAAG;cAAO,EAAE;KAAoB;KARtC,EAAE,GASM,CACf;GACc"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"SalesTermsTemplate.d.ts","names":[],"sources":["../../../../src/components/legal/templates/SalesTermsTemplate.tsx"],"sourcesContent":[],"mappings":";;;;iBAMgB,kBAAA;;;;;;UAMN,OAAA,CAAM;;IANA,WAAA,CAAA,EAAA,MAAkB,GAOA,IAPA;IAChC,OAAA,CAAA,EAAA,MAAA;EACA,CAAA;EACA,GAAA,CAAA,EAAA;IACA,IAAA,EAAA,MAAA;IAEQ,KAAM,EAEe,OAAA,CAAM,SAFrB;EACkB,CAAA,EAAA;EACH,QAAM,EAAA;IACJ,EAAM,EAAA,MAAA;IAAoB,KAAM,EAAhC,OAAA,CAAM,SAA0B;IAChE,OAAA,EAD0D,OAAA,CAAM,SAChE;EAAA,CAAA,EAAA;IAAA,oBAAA,CAAA,GAAA,CAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"SalesTermsTemplate.js","names":[],"sources":["../../../../src/components/legal/templates/SalesTermsTemplate.tsx"],"sourcesContent":["import * as React from 'react';\nimport { LegalPageLayout } from '../organisms/LegalPageLayout';\nimport { LegalSection } from '../atoms/LegalSection';\nimport { LegalHeading } from '../atoms/LegalHeading';\nimport { LegalText } from '../atoms/LegalText';\n\nexport function SalesTermsTemplate({\n title = 'Conditions Générales de Vente',\n meta,\n toc,\n sections,\n}: {\n title?: React.ReactNode;\n meta?: { lastUpdated?: string | Date; version?: string };\n toc?: { href: string; label: React.ReactNode }[];\n sections: { id: string; title: React.ReactNode; content: React.ReactNode }[];\n}) {\n return (\n <LegalPageLayout title={title} meta={meta} toc={toc}>\n {sections.map((s) => (\n <LegalSection\n key={s.id}\n id={s.id}\n border=\"top\"\n className=\"scroll-mt-24\"\n >\n <LegalHeading as=\"h2\" level=\"h2\">\n {s.title}\n </LegalHeading>\n <LegalText as=\"div\">{s.content}</LegalText>\n </LegalSection>\n ))}\n </LegalPageLayout>\n );\n}\n"],"mappings":";;;;;;;;AAMA,SAAgB,mBAAmB,EACjC,QAAQ,iCACR,MACA,KACA,YAMC;AACD,QACE,oBAAC;EAAuB;EAAa;EAAW;YAC7C,SAAS,KAAK,MACb,qBAAC;GAEC,IAAI,EAAE;GACN,QAAO;GACP,WAAU;cAEV,oBAAC;IAAa,IAAG;IAAK,OAAM;cACzB,EAAE;KACU,EACf,oBAAC;IAAU,IAAG;cAAO,EAAE;KAAoB;KARtC,EAAE,GASM,CACf;GACc"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"TermsTemplate.d.ts","names":[],"sources":["../../../../src/components/legal/templates/TermsTemplate.tsx"],"sourcesContent":[],"mappings":";;;;iBAQgB,aAAA;;;;;;UAMN,OAAA,CAAM;;IANA,WAAA,CAAa,EAAA,MAAA,GAOK,IAPL;IAC3B,OAAA,CAAA,EAAA,MAAA;EACA,CAAA;EACA,GAAA,CAAA,EAAA;IACA,IAAA,EAAA,MAAA;IAEQ,KAAM,EAEe,OAAA,CAAM,SAFrB;EACkB,CAAA,EAAA;EACH,QAAM,EAAA;IACJ,EAAM,EAAA,MAAA;IAAoB,KAAM,EAAhC,OAAA,CAAM,SAA0B;IAChE,OAAA,EAD0D,OAAA,CAAM,SAChE;EAAA,CAAA,EAAA;IAAA,oBAAA,CAAA,GAAA,CAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"TermsTemplate.js","names":[],"sources":["../../../../src/components/legal/templates/TermsTemplate.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { LegalPageLayout } from '../organisms/LegalPageLayout';\nimport { LegalSection } from '../atoms/LegalSection';\nimport { LegalHeading } from '../atoms/LegalHeading';\nimport { LegalText } from '../atoms/LegalText';\n\nexport function TermsTemplate({\n title = 'Conditions Générales d’Utilisation',\n meta,\n toc,\n sections,\n}: {\n title?: React.ReactNode;\n meta?: { lastUpdated?: string | Date; version?: string };\n toc?: { href: string; label: React.ReactNode }[];\n sections: { id: string; title: React.ReactNode; content: React.ReactNode }[];\n}) {\n return (\n <LegalPageLayout title={title} meta={meta} toc={toc}>\n {sections.map((s) => (\n <LegalSection\n key={s.id}\n id={s.id}\n border=\"top\"\n className=\"scroll-mt-24\"\n >\n <LegalHeading as=\"h2\" level=\"h2\">\n {s.title}\n </LegalHeading>\n <LegalText as=\"div\">{s.content}</LegalText>\n </LegalSection>\n ))}\n </LegalPageLayout>\n );\n}\n"],"mappings":";;;;;;;;;;;AAQA,SAAgB,cAAc,EAC5B,QAAQ,sCACR,MACA,KACA,YAMC;AACD,QACE,oBAAC;EAAuB;EAAa;EAAW;YAC7C,SAAS,KAAK,MACb,qBAAC;GAEC,IAAI,EAAE;GACN,QAAO;GACP,WAAU;cAEV,oBAAC;IAAa,IAAG;IAAK,OAAM;cACzB,EAAE;KACU,EACf,oBAAC;IAAU,IAAG;cAAO,EAAE;KAAoB;KARtC,EAAE,GASM,CACf;GACc"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"AiLinkButton.d.ts","names":[],"sources":["../../../src/components/molecules/AiLinkButton.tsx"],"sourcesContent":[],"mappings":";;;KAUK,QAAA;UAEY,iBAAA;;EAFZ,QAAA,CAAA,EAIQ,QAJA;EAEI,SAAA,CAAA,EAAA,MAAA;AAqBjB;AAA+B,iBAAf,YAAA,CAAe;EAAA,IAAA;EAAA;AAAA,CAAA,EAAmB,iBAAnB,CAAA,EAAoC,mBAAA,CAAA,GAAA,CAAA,OAApC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"AiLinkButton.js","names":["React"],"sources":["../../../src/components/molecules/AiLinkButton.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Button } from '../atoms/Button';\nimport {\n DropdownMenu,\n DropdownMenuContent,\n DropdownMenuItem,\n DropdownMenuTrigger,\n} from '@lssm/lib.ui-kit-web/ui/dropdown-menu';\n// } from './DropdownMenu';\n\ntype Provider = 'chatgpt' | 'claude';\n\nexport interface AiLinkButtonProps {\n href: string; // canonical or .md URL\n provider?: Provider;\n className?: string;\n}\n\nfunction buildPrompt(href: string) {\n return `Please load and use this markdown context when answering: ${href}`;\n}\n\nfunction buildProviderUrl(provider: Provider, href: string) {\n const prompt = encodeURIComponent(buildPrompt(href));\n switch (provider) {\n case 'claude':\n return `https://claude.ai/new?prompt=${prompt}`;\n case 'chatgpt':\n default:\n return `https://chatgpt.com/?q=${prompt}`;\n }\n}\n\nexport function AiLinkButton({ href, className }: AiLinkButtonProps) {\n const copyLink = React.useCallback(() => {\n try {\n navigator.clipboard?.writeText(href).catch(() => {});\n } catch {}\n }, [href]);\n\n const openChatGPT = React.useCallback(() => {\n const url = buildProviderUrl('chatgpt', href);\n try {\n navigator.clipboard?.writeText(href).catch(() => {});\n } catch {}\n window.open(url, '_blank', 'noopener,noreferrer');\n }, [href]);\n\n const openClaude = React.useCallback(() => {\n const url = buildProviderUrl('claude', href);\n try {\n navigator.clipboard?.writeText(href).catch(() => {});\n } catch {}\n window.open(url, '_blank', 'noopener,noreferrer');\n }, [href]);\n\n return (\n <DropdownMenu>\n <DropdownMenuTrigger asChild>\n <Button\n className={className}\n variant=\"secondary\"\n aria-label=\"AI actions\"\n >\n AI\n </Button>\n </DropdownMenuTrigger>\n <DropdownMenuContent align=\"end\">\n <DropdownMenuItem onClick={copyLink}>Get link for AI</DropdownMenuItem>\n <DropdownMenuItem onClick={openChatGPT}>\n Open in ChatGPT\n </DropdownMenuItem>\n <DropdownMenuItem onClick={openClaude}>Open in Claude</DropdownMenuItem>\n </DropdownMenuContent>\n </DropdownMenu>\n );\n}\n"],"mappings":";;;;;;AAkBA,SAAS,YAAY,MAAc;AACjC,QAAO,6DAA6D;;AAGtE,SAAS,iBAAiB,UAAoB,MAAc;CAC1D,MAAM,SAAS,mBAAmB,YAAY,KAAK,CAAC;AACpD,SAAQ,UAAR;EACE,KAAK,SACH,QAAO,gCAAgC;EACzC,KAAK;EACL,QACE,QAAO,0BAA0B;;;AAIvC,SAAgB,aAAa,EAAE,MAAM,aAAgC;CACnE,MAAM,WAAWA,QAAM,kBAAkB;AACvC,MAAI;AACF,aAAU,WAAW,UAAU,KAAK,CAAC,YAAY,GAAG;UAC9C;IACP,CAAC,KAAK,CAAC;CAEV,MAAM,cAAcA,QAAM,kBAAkB;EAC1C,MAAM,MAAM,iBAAiB,WAAW,KAAK;AAC7C,MAAI;AACF,aAAU,WAAW,UAAU,KAAK,CAAC,YAAY,GAAG;UAC9C;AACR,SAAO,KAAK,KAAK,UAAU,sBAAsB;IAChD,CAAC,KAAK,CAAC;CAEV,MAAM,aAAaA,QAAM,kBAAkB;EACzC,MAAM,MAAM,iBAAiB,UAAU,KAAK;AAC5C,MAAI;AACF,aAAU,WAAW,UAAU,KAAK,CAAC,YAAY,GAAG;UAC9C;AACR,SAAO,KAAK,KAAK,UAAU,sBAAsB;IAChD,CAAC,KAAK,CAAC;AAEV,QACE,qBAAC,2BACC,oBAAC;EAAoB;YACnB,oBAAC;GACY;GACX,SAAQ;GACR,cAAW;aACZ;IAEQ;GACW,EACtB,qBAAC;EAAoB,OAAM;;GACzB,oBAAC;IAAiB,SAAS;cAAU;KAAkC;GACvE,oBAAC;IAAiB,SAAS;cAAa;KAErB;GACnB,oBAAC;IAAiB,SAAS;cAAY;KAAiC;;GACpD,IACT"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Breadcrumbs.d.ts","names":[],"sources":["../../../src/components/molecules/Breadcrumbs.tsx"],"sourcesContent":[],"mappings":";;;;UAYiB,iBAAA;;SAER,OAAA,CAAM;AAFf;AAKgB,iBAAA,WAAA,CAAW;EAAA;CAAA,EAAA;EAAG,KAAA,EAAkB,iBAAlB,EAAA;CAAkB,CAAA,EAAqB,mBAAA,CAAA,GAAA,CAAA,OAAA,GAArB,IAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Breadcrumbs.js","names":["Root","React"],"sources":["../../../src/components/molecules/Breadcrumbs.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport {\n Breadcrumb as Root,\n BreadcrumbItem,\n BreadcrumbLink,\n BreadcrumbList,\n BreadcrumbPage,\n BreadcrumbSeparator,\n} from '@lssm/lib.ui-kit-web/ui/breadcrumb';\n\nexport interface BreadcrumbItemDef {\n href?: string;\n label: React.ReactNode;\n}\n\nexport function Breadcrumbs({ items }: { items: BreadcrumbItemDef[] }) {\n if (!items?.length) return null;\n return (\n <Root>\n <BreadcrumbList>\n {items.map((it, idx) => (\n <React.Fragment key={idx}>\n <BreadcrumbItem>\n {it.href ? (\n <BreadcrumbLink href={it.href}>{it.label}</BreadcrumbLink>\n ) : (\n <BreadcrumbPage>{it.label}</BreadcrumbPage>\n )}\n </BreadcrumbItem>\n {idx < items.length - 1 && <BreadcrumbSeparator />}\n </React.Fragment>\n ))}\n </BreadcrumbList>\n </Root>\n );\n}\n"],"mappings":";;;;;;;;AAiBA,SAAgB,YAAY,EAAE,SAAyC;AACrE,KAAI,CAAC,OAAO,OAAQ,QAAO;AAC3B,QACE,oBAACA,wBACC,oBAAC,4BACE,MAAM,KAAK,IAAI,QACd,qBAACC,QAAM,uBACL,oBAAC,4BACE,GAAG,OACF,oBAAC;EAAe,MAAM,GAAG;YAAO,GAAG;GAAuB,GAE1D,oBAAC,4BAAgB,GAAG,QAAuB,GAE9B,EAChB,MAAM,MAAM,SAAS,KAAK,oBAAC,wBAAsB,KAR/B,IASJ,CACjB,GACa,GACZ"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"CommandPalette.d.ts","names":[],"sources":["../../../src/components/molecules/CommandPalette.tsx"],"sourcesContent":[],"mappings":";;;UAciB,mBAAA;;;EAAA,MAAA,EAAA;IAgBD,OAAA,CAAA,EAAA,MAAc;IAC5B,KAAA,EAAA;MACA,EAAA,EAAA,MAAA;MACA,KAAA,EAAA,MAAA;MACA,QAAA,CAAA,EAAA,MAAA;MACC,QAAA,CAAA,EAAA,GAAA,GAAA,IAAA;IAAmB,CAAA,EAAA;EAAA,CAAA,EAAA;;;;iBALN,cAAA;;;;;GAKb,sBAAmB,mBAAA,CAAA,GAAA,CAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"CommandPalette.js","names":["React"],"sources":["../../../src/components/molecules/CommandPalette.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport {\n CommandDialog,\n CommandEmpty,\n CommandGroup,\n CommandInput,\n CommandItem,\n CommandList,\n CommandSeparator,\n CommandShortcut,\n} from '@lssm/lib.ui-kit-web/ui/command';\n\nexport interface CommandPaletteProps {\n open?: boolean;\n onOpenChange?: (open: boolean) => void;\n groups: {\n heading?: string;\n items: {\n id: string;\n label: string;\n shortcut?: string;\n onSelect?: () => void;\n }[];\n }[];\n placeholder?: string;\n kbd?: string; // e.g., ⌘K shown in UI copy\n}\n\nexport function CommandPalette({\n open,\n onOpenChange,\n groups,\n placeholder = 'Type a command or search…',\n}: CommandPaletteProps) {\n const [internalOpen, setInternalOpen] = React.useState(false);\n const isControlled = typeof open === 'boolean';\n const visible = isControlled ? open : internalOpen;\n const setVisible = isControlled ? onOpenChange! : setInternalOpen;\n\n React.useEffect(() => {\n const handler = (e: KeyboardEvent) => {\n if ((e.metaKey || e.ctrlKey) && e.key.toLowerCase() === 'k') {\n e.preventDefault();\n setVisible(!visible);\n }\n };\n document.addEventListener('keydown', handler);\n return () => document.removeEventListener('keydown', handler);\n }, [visible, setVisible]);\n\n return (\n <CommandDialog open={visible} onOpenChange={setVisible}>\n <CommandInput placeholder={placeholder} />\n <CommandList>\n <CommandEmpty>No results found.</CommandEmpty>\n {groups.map((g, gi) => (\n <CommandGroup key={gi} heading={g.heading}>\n {g.items.map((it) => (\n <CommandItem key={it.id} onSelect={it.onSelect}>\n <span>{it.label}</span>\n {it.shortcut && (\n <CommandShortcut>{it.shortcut}</CommandShortcut>\n )}\n </CommandItem>\n ))}\n </CommandGroup>\n ))}\n <CommandSeparator />\n </CommandList>\n </CommandDialog>\n );\n}\n"],"mappings":";;;;;;;;AA8BA,SAAgB,eAAe,EAC7B,MACA,cACA,QACA,cAAc,+BACQ;CACtB,MAAM,CAAC,cAAc,mBAAmBA,QAAM,SAAS,MAAM;CAC7D,MAAM,eAAe,OAAO,SAAS;CACrC,MAAM,UAAU,eAAe,OAAO;CACtC,MAAM,aAAa,eAAe,eAAgB;AAElD,SAAM,gBAAgB;EACpB,MAAM,WAAW,MAAqB;AACpC,QAAK,EAAE,WAAW,EAAE,YAAY,EAAE,IAAI,aAAa,KAAK,KAAK;AAC3D,MAAE,gBAAgB;AAClB,eAAW,CAAC,QAAQ;;;AAGxB,WAAS,iBAAiB,WAAW,QAAQ;AAC7C,eAAa,SAAS,oBAAoB,WAAW,QAAQ;IAC5D,CAAC,SAAS,WAAW,CAAC;AAEzB,QACE,qBAAC;EAAc,MAAM;EAAS,cAAc;aAC1C,oBAAC,gBAA0B,cAAe,EAC1C,qBAAC;GACC,oBAAC,0BAAa,sBAAgC;GAC7C,OAAO,KAAK,GAAG,OACd,oBAAC;IAAsB,SAAS,EAAE;cAC/B,EAAE,MAAM,KAAK,OACZ,qBAAC;KAAwB,UAAU,GAAG;gBACpC,oBAAC,oBAAM,GAAG,QAAa,EACtB,GAAG,YACF,oBAAC,6BAAiB,GAAG,WAA2B;OAHlC,GAAG,GAKP,CACd;MARe,GASJ,CACf;GACF,oBAAC,qBAAmB;MACR;GACA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"CommandSearchTrigger.d.ts","names":[],"sources":["../../../src/components/molecules/CommandSearchTrigger.tsx"],"sourcesContent":[],"mappings":";;;;;iBAQgB,oBAAA;;;;;;UAMN,OAAA,CAAM,sBAAsB;;EANtB,WAAA,CAAA,EAAA,MAAA;EACd,OAAA,CAAA,EAAA,OAAA;CACA,CAAA,EAQD,kBAAA,CAAA,GAAA,CAAA,OARC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"CommandSearchTrigger.js","names":["React"],"sources":["../../../src/components/molecules/CommandSearchTrigger.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { SearchIcon } from 'lucide-react';\nimport { cn } from '@lssm/lib.ui-kit-web/ui/utils';\nimport { CommandPalette } from './CommandPalette';\nimport { Button } from '../atoms/Button';\n\nexport function CommandSearchTrigger({\n groups,\n className,\n placeholder = 'Search…',\n compact = false,\n}: {\n groups: React.ComponentProps<typeof CommandPalette>['groups'];\n className?: string;\n placeholder?: string;\n compact?: boolean; // if true, render as icon button only\n}) {\n const [open, setOpen] = React.useState(false);\n\n React.useEffect(() => {\n const handler = (e: KeyboardEvent) => {\n if ((e.metaKey || e.ctrlKey) && e.key.toLowerCase() === 'k') {\n e.preventDefault();\n setOpen((p) => !p);\n }\n };\n document.addEventListener('keydown', handler);\n return () => document.removeEventListener('keydown', handler);\n }, []);\n\n return (\n <>\n <Button\n variant=\"ghost\"\n type=\"button\"\n onPress={() => setOpen(true)}\n className={cn(\n 'group text-muted-foreground hover:bg-muted/40 inline-flex items-center gap-2 rounded-xs border px-3 text-sm',\n compact ? 'h-9 w-9 justify-center p-0' : 'h-9',\n className\n )}\n aria-label=\"Open search\"\n >\n <SearchIcon className=\"h-4 w-4 opacity-70\" />\n\n {!compact && (\n <span className=\"whitespace-nowrap\">\n {placeholder}\n <span className=\"bg-muted ml-2 hidden items-center gap-1 rounded-xs border px-1.5 font-mono text-[10px] md:inline-flex\">\n ⌘K\n </span>\n </span>\n )}\n </Button>\n <CommandPalette open={open} onOpenChange={setOpen} groups={groups} />\n </>\n );\n}\n"],"mappings":";;;;;;;;;;;AAQA,SAAgB,qBAAqB,EACnC,QACA,WACA,cAAc,WACd,UAAU,SAMT;CACD,MAAM,CAAC,MAAM,WAAWA,QAAM,SAAS,MAAM;AAE7C,SAAM,gBAAgB;EACpB,MAAM,WAAW,MAAqB;AACpC,QAAK,EAAE,WAAW,EAAE,YAAY,EAAE,IAAI,aAAa,KAAK,KAAK;AAC3D,MAAE,gBAAgB;AAClB,aAAS,MAAM,CAAC,EAAE;;;AAGtB,WAAS,iBAAiB,WAAW,QAAQ;AAC7C,eAAa,SAAS,oBAAoB,WAAW,QAAQ;IAC5D,EAAE,CAAC;AAEN,QACE,4CACE,qBAAC;EACC,SAAQ;EACR,MAAK;EACL,eAAe,QAAQ,KAAK;EAC5B,WAAW,GACT,+GACA,UAAU,+BAA+B,OACzC,UACD;EACD,cAAW;aAEX,oBAAC,cAAW,WAAU,uBAAuB,EAE5C,CAAC,WACA,qBAAC;GAAK,WAAU;cACb,aACD,oBAAC;IAAK,WAAU;cAAwG;KAEjH;IACF;GAEF,EACT,oBAAC;EAAqB;EAAM,cAAc;EAAiB;GAAU,IACpE"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"EntityCard.d.ts","names":[],"sources":["../../../src/components/molecules/EntityCard.tsx"],"sourcesContent":[],"mappings":";;;;;;;cAOM;;;IAaJ,+BAAA,CAAA;AAbI,KAeM,eAAA,GAAkB,OAAA,CAAM,cAFlC,CAAA,OAEwD,IAFxD,CAAA,GAGA,YAHA,CAAA,OAGoB,kBAHpB,CAAA,GAAA;EAEU,SAAA,EAEG,OAAA,CAAM,SAFM;EAA+B,YAAA,CAAA,EAGvC,OAAA,CAAM,SAHiC;EAA5B,KAAM,CAAA,EAIxB,OAAA,CAAM,SAJkB;EACd,IAAA,CAAA,EAIX,OAAA,CAAM,SAJK;EAApB,MAAA,CAAA,EAKW,OAAA,CAAM,SALjB;EACa,IAAA,CAAM,EAAA,MAAA;EACF,gBAAM,CAAA,EAAA,MAAA;EACb,OAAM,CAAA,EAKJ,OAAA,CAAM,SALF;CACP;AACE,iBAMG,UAAA,CANG;EAAA,SAAA;EAAA,YAAA;EAAA,KAAA;EAAA,IAAA;EAAA,MAAA;EAAA,QAAA;EAAA,OAAA;EAAA,SAAA;EAAA,gBAAA;EAAA,IAAA;EAAA,OAAA;EAAA,GAAA;AAAA,CAAA,EAmBhB,eAnBgB,CAAA,EAmBD,kBAAA,CAAA,GAAA,CAAA,OAnBC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"EntityCard.js","names":["Wrapper: React.ElementType"],"sources":["../../../src/components/molecules/EntityCard.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { Card, CardContent } from '@lssm/lib.ui-kit-web/ui/card';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { cn } from '@lssm/lib.ui-kit-web/ui/utils';\n\nconst entityCardVariants = cva('transition-all hover:shadow-2xs', {\n variants: {\n emphasis: {\n default: '',\n subtle: 'border-muted/60 bg-muted/20',\n strong: 'border-primary/50 bg-primary/5',\n },\n density: {\n compact: 'p-3',\n comfortable: 'p-4 md:p-5',\n },\n },\n defaultVariants: { emphasis: 'default', density: 'comfortable' },\n});\n\nexport type EntityCardProps = React.ComponentProps<typeof Card> &\n VariantProps<typeof entityCardVariants> & {\n cardTitle: React.ReactNode;\n cardSubtitle?: React.ReactNode;\n chips?: React.ReactNode; // right-aligned small chips\n meta?: React.ReactNode; // rows of icon+text data\n footer?: React.ReactNode; // actions area\n href?: string; // optional link wrapper\n contentClassName?: string;\n preview?: React.ReactNode; // hover preview content\n };\n\nexport function EntityCard({\n cardTitle,\n cardSubtitle,\n chips,\n meta,\n footer,\n emphasis,\n density,\n className,\n contentClassName,\n href,\n preview,\n ...cardProps\n}: EntityCardProps) {\n const Wrapper: React.ElementType = href ? 'a' : 'div';\n const cardContent = (\n <Card\n className={cn(entityCardVariants({ emphasis }), className)}\n {...cardProps}\n >\n <CardContent\n className={cn(entityCardVariants({ density }), contentClassName)}\n >\n <div className=\"space-y-3\">\n <div className=\"flex items-start justify-between gap-2\">\n <div className=\"min-w-0\">\n <div className=\"truncate text-lg font-medium\">{cardTitle}</div>\n {cardSubtitle && (\n <div className=\"text-muted-foreground text-base\">\n {cardSubtitle}\n </div>\n )}\n </div>\n {chips && (\n <div className=\"inline-flex shrink-0 items-center gap-1\">\n {chips}\n </div>\n )}\n </div>\n {meta && <div className=\"space-y-1\">{meta}</div>}\n {footer && (\n <div className=\"flex items-center justify-between\">{footer}</div>\n )}\n </div>\n </CardContent>\n </Card>\n );\n\n const maybePreview = (() => {\n if (!preview) return cardContent;\n try {\n const { HoverPreview } =\n require('./HoverPreview') as typeof import('./HoverPreview');\n return <HoverPreview trigger={cardContent} content={preview} />;\n } catch {\n return cardContent;\n }\n })();\n\n return (\n <Wrapper href={href} className={href ? 'block' : undefined}>\n {maybePreview}\n </Wrapper>\n );\n}\n"],"mappings":";;;;;;;;;;;;AAOA,MAAM,qBAAqB,IAAI,mCAAmC;CAChE,UAAU;EACR,UAAU;GACR,SAAS;GACT,QAAQ;GACR,QAAQ;GACT;EACD,SAAS;GACP,SAAS;GACT,aAAa;GACd;EACF;CACD,iBAAiB;EAAE,UAAU;EAAW,SAAS;EAAe;CACjE,CAAC;AAcF,SAAgB,WAAW,EACzB,WACA,cACA,OACA,MACA,QACA,UACA,SACA,WACA,kBACA,MACA,QACA,GAAG,aACe;CAClB,MAAMA,UAA6B,OAAO,MAAM;CAChD,MAAM,cACJ,oBAAC;EACC,WAAW,GAAG,mBAAmB,EAAE,UAAU,CAAC,EAAE,UAAU;EAC1D,GAAI;YAEJ,oBAAC;GACC,WAAW,GAAG,mBAAmB,EAAE,SAAS,CAAC,EAAE,iBAAiB;aAEhE,qBAAC;IAAI,WAAU;;KACb,qBAAC;MAAI,WAAU;iBACb,qBAAC;OAAI,WAAU;kBACb,oBAAC;QAAI,WAAU;kBAAgC;SAAgB,EAC9D,gBACC,oBAAC;QAAI,WAAU;kBACZ;SACG;QAEJ,EACL,SACC,oBAAC;OAAI,WAAU;iBACZ;QACG;OAEJ;KACL,QAAQ,oBAAC;MAAI,WAAU;gBAAa;OAAW;KAC/C,UACC,oBAAC;MAAI,WAAU;gBAAqC;OAAa;;KAE/D;IACM;GACT;CAGT,MAAM,sBAAsB;AAC1B,MAAI,CAAC,QAAS,QAAO;AACrB,MAAI;GACF,MAAM,EAAE;AAER,UAAO,oBAAC;IAAa,SAAS;IAAa,SAAS;KAAW;UACzD;AACN,UAAO;;KAEP;AAEJ,QACE,oBAAC;EAAc;EAAM,WAAW,OAAO,UAAU;YAC9C;GACO"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"FiltersToolbar.d.ts","names":[],"sources":["../../../src/components/molecules/FiltersToolbar.tsx"],"sourcesContent":[],"mappings":";;;;UAKiB,gBAAA;;SAER,OAAA,CAAM;EAFE,QAAA,CAAA,EAAA,GAAA,GAAA,IAAgB;AAMjC;AAEa,UAFI,mBAAA,CAEE;EACT,SAAM,CAAA,EAAA,MAAA;EAMA,QAAA,CAAA,EAPH,OAAA,CAAM,SAOH;EAAgB,KAAA,CAAA,EANtB,OAAA,CAAM,SAMgB;EAIhB,iBAAc,CAAA,EAAA,MAAA;EAC5B,WAAA,CAAA,EAAA,MAAA;EACA,cAAA,CAAA,EAAA,CAAA,KAAA,EAAA,MAAA,EAAA,GAAA,IAAA;EACA,cAAA,CAAA,EAAA,GAAA,GAAA,IAAA;EACA,UAAA,CAAA,EAAA,MAAA;EACA,WAAA,CAAA,EATc,gBASd,EAAA;EACA,UAAA,CAAA,EAAA,GAAA,GAAA,IAAA;;AAEA,iBARc,cAAA,CAQd;EAAA,SAAA;EAAA,QAAA;EAAA,KAAA;EAAA,iBAAA;EAAA,WAAA;EAAA,cAAA;EAAA,cAAA;EAAA,UAAA;EAAA,WAAA;EAAA;AAAA,CAAA,EAGC,mBAHD,CAAA,EAGoB,kBAAA,CAAA,GAAA,CAAA,OAHpB"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"FiltersToolbar.js","names":["React"],"sources":["../../../src/components/molecules/FiltersToolbar.tsx"],"sourcesContent":["import * as React from 'react';\nimport { cn } from '@lssm/lib.ui-kit-web/ui/utils';\nimport { Button, Input } from '../../index';\nimport { Badge } from '@lssm/lib.ui-kit-web/ui/badge';\n\nexport interface ActiveFilterChip {\n key: string;\n label: React.ReactNode;\n onRemove?: () => void;\n}\n\nexport interface FiltersToolbarProps {\n className?: string;\n children?: React.ReactNode;\n right?: React.ReactNode;\n searchPlaceholder?: string;\n searchValue?: string;\n onSearchChange?: (value: string) => void;\n onSearchSubmit?: () => void;\n debounceMs?: number;\n activeChips?: ActiveFilterChip[];\n onClearAll?: () => void;\n}\n\nexport function FiltersToolbar({\n className,\n children,\n right,\n searchPlaceholder,\n searchValue,\n onSearchChange,\n onSearchSubmit,\n debounceMs = 250,\n activeChips = [],\n onClearAll,\n}: FiltersToolbarProps) {\n const [q, setQ] = React.useState<string>(searchValue ?? '');\n\n React.useEffect(() => {\n setQ(searchValue ?? '');\n }, [searchValue]);\n\n React.useEffect(() => {\n if (!onSearchChange) return;\n const id = setTimeout(() => onSearchChange(q), debounceMs);\n return () => clearTimeout(id);\n }, [q, debounceMs, onSearchChange]);\n\n return (\n <div className={cn('space-y-2', className)}>\n <div className=\"flex flex-col items-stretch gap-2 md:flex-row md:items-center md:justify-between\">\n <div className=\"flex flex-1 items-center gap-2\">\n {onSearchChange ? (\n <div className=\"flex flex-1 items-center gap-2\">\n <Input\n value={q}\n onChange={setQ}\n onKeyDown={(e) => {\n if (e.key === 'Enter') onSearchSubmit?.();\n }}\n placeholder={searchPlaceholder}\n keyboard={{ kind: 'search' }}\n />\n <Button\n variant=\"outline\"\n onPress={() => onSearchSubmit?.()}\n className=\"shrink-0\"\n >\n Rechercher\n </Button>\n </div>\n ) : null}\n {children}\n </div>\n {right}\n </div>\n\n {(activeChips.length > 0 || onClearAll) && (\n <div className=\"flex flex-wrap items-center gap-2\">\n {activeChips.map((c) => (\n <Badge\n key={c.key}\n variant=\"secondary\"\n className=\"inline-flex items-center gap-2\"\n >\n <span>{c.label}</span>\n {c.onRemove && (\n <button\n type=\"button\"\n aria-label=\"Supprimer le filtre\"\n onClick={c.onRemove}\n className=\"hover:bg-muted rounded-xs px-1 text-base\"\n >\n ×\n </button>\n )}\n </Badge>\n ))}\n {onClearAll && (\n <Button size=\"sm\" variant=\"ghost\" onPress={onClearAll}>\n Effacer les filtres\n </Button>\n )}\n </div>\n )}\n </div>\n );\n}\n"],"mappings":";;;;;;;;AAwBA,SAAgB,eAAe,EAC7B,WACA,UACA,OACA,mBACA,aACA,gBACA,gBACA,aAAa,KACb,cAAc,EAAE,EAChB,cACsB;CACtB,MAAM,CAAC,GAAG,QAAQA,QAAM,SAAiB,eAAe,GAAG;AAE3D,SAAM,gBAAgB;AACpB,OAAK,eAAe,GAAG;IACtB,CAAC,YAAY,CAAC;AAEjB,SAAM,gBAAgB;AACpB,MAAI,CAAC,eAAgB;EACrB,MAAM,KAAK,iBAAiB,eAAe,EAAE,EAAE,WAAW;AAC1D,eAAa,aAAa,GAAG;IAC5B;EAAC;EAAG;EAAY;EAAe,CAAC;AAEnC,QACE,qBAAC;EAAI,WAAW,GAAG,aAAa,UAAU;aACxC,qBAAC;GAAI,WAAU;cACb,qBAAC;IAAI,WAAU;eACZ,iBACC,qBAAC;KAAI,WAAU;gBACb,oBAAC;MACC,OAAO;MACP,UAAU;MACV,YAAY,MAAM;AAChB,WAAI,EAAE,QAAQ,QAAS,mBAAkB;;MAE3C,aAAa;MACb,UAAU,EAAE,MAAM,UAAU;OAC5B,EACF,oBAAC;MACC,SAAQ;MACR,eAAe,kBAAkB;MACjC,WAAU;gBACX;OAEQ;MACL,GACJ,MACH;KACG,EACL;IACG,GAEJ,YAAY,SAAS,KAAK,eAC1B,qBAAC;GAAI,WAAU;cACZ,YAAY,KAAK,MAChB,qBAAC;IAEC,SAAQ;IACR,WAAU;eAEV,oBAAC,oBAAM,EAAE,QAAa,EACrB,EAAE,YACD,oBAAC;KACC,MAAK;KACL,cAAW;KACX,SAAS,EAAE;KACX,WAAU;eACX;MAEQ;MAbN,EAAE,IAeD,CACR,EACD,cACC,oBAAC;IAAO,MAAK;IAAK,SAAQ;IAAQ,SAAS;cAAY;KAE9C;IAEP;GAEJ"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"FiltersToolbar.mobile.d.ts","names":[],"sources":["../../../src/components/molecules/FiltersToolbar.mobile.tsx"],"sourcesContent":[],"mappings":";;;;iBAKgB,cAAA;;;;;;;;;;;GAWb,sBAAmB,kBAAA,CAAA,GAAA,CAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"FiltersToolbar.mobile.js","names":["React"],"sources":["../../../src/components/molecules/FiltersToolbar.mobile.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Button, Input } from '../../index';\nimport { VStack, HStack } from '@lssm/lib.ui-kit/ui/stack';\nimport type { FiltersToolbarProps } from './FiltersToolbar';\n\nexport function FiltersToolbar({\n className,\n children,\n right,\n searchPlaceholder,\n searchValue,\n onSearchChange,\n onSearchSubmit,\n debounceMs = 250,\n activeChips = [],\n onClearAll,\n}: FiltersToolbarProps) {\n const [q, setQ] = React.useState<string>(searchValue ?? '');\n\n React.useEffect(() => {\n setQ(searchValue ?? '');\n }, [searchValue]);\n\n React.useEffect(() => {\n if (!onSearchChange) return;\n const id = setTimeout(() => onSearchChange(q), debounceMs);\n return () => clearTimeout(id);\n }, [q, debounceMs, onSearchChange]);\n\n return (\n <VStack className={className}>\n <HStack className=\"items-center gap-2\">\n {onSearchChange ? (\n <HStack className=\"flex-1 items-center gap-2\">\n <Input\n value={q}\n onChange={setQ}\n placeholder={searchPlaceholder}\n keyboard={{ kind: 'search' }}\n />\n <Button variant=\"outline\" onPress={() => onSearchSubmit?.()}>\n Rechercher\n </Button>\n </HStack>\n ) : null}\n {children}\n {right}\n </HStack>\n {/* For now chips are omitted on mobile; can add a compact chip row later with Pressable rows */}\n </VStack>\n );\n}\n"],"mappings":";;;;;;;AAKA,SAAgB,eAAe,EAC7B,WACA,UACA,OACA,mBACA,aACA,gBACA,gBACA,aAAa,KACb,cAAc,EAAE,EAChB,cACsB;CACtB,MAAM,CAAC,GAAG,QAAQA,QAAM,SAAiB,eAAe,GAAG;AAE3D,SAAM,gBAAgB;AACpB,OAAK,eAAe,GAAG;IACtB,CAAC,YAAY,CAAC;AAEjB,SAAM,gBAAgB;AACpB,MAAI,CAAC,eAAgB;EACrB,MAAM,KAAK,iBAAiB,eAAe,EAAE,EAAE,WAAW;AAC1D,eAAa,aAAa,GAAG;IAC5B;EAAC;EAAG;EAAY;EAAe,CAAC;AAEnC,QACE,oBAAC;EAAkB;YACjB,qBAAC;GAAO,WAAU;;IACf,iBACC,qBAAC;KAAO,WAAU;gBAChB,oBAAC;MACC,OAAO;MACP,UAAU;MACV,aAAa;MACb,UAAU,EAAE,MAAM,UAAU;OAC5B,EACF,oBAAC;MAAO,SAAQ;MAAU,eAAe,kBAAkB;gBAAE;OAEpD;MACF,GACP;IACH;IACA;;IACM;GAEF"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"HoverPreview.d.ts","names":[],"sources":["../../../src/components/molecules/HoverPreview.tsx"],"sourcesContent":[],"mappings":";;;;UASiB,iBAAA;WACN,OAAA,CAAM;WACN,OAAA,CAAM;EAFA,KAAA,CAAA,EAAA,OAAA,GAAA,QAAiB,GAAA,KACvB;EAOK,UAAA,CAAA,EAAA,MAAY;EAC1B,SAAA,CAAA,EAAA,MAAA;;AAEA,iBAHc,YAAA,CAGd;EAAA,OAAA;EAAA,OAAA;EAAA,KAAA;EAAA,UAAA;EAAA;AAAA,CAAA,EAGC,iBAHD,CAAA,EAGkB,kBAAA,CAAA,GAAA,CAAA,OAHlB"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"HoverPreview.js","names":[],"sources":["../../../src/components/molecules/HoverPreview.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport {\n HoverCard,\n HoverCardTrigger,\n HoverCardContent,\n} from '@lssm/lib.ui-kit-web/ui/hover-card';\n\nexport interface HoverPreviewProps {\n trigger: React.ReactNode; // usually a link or chip\n content: React.ReactNode; // preview panel\n align?: 'start' | 'center' | 'end';\n sideOffset?: number;\n className?: string;\n}\n\nexport function HoverPreview({\n trigger,\n content,\n align = 'center',\n sideOffset = 8,\n className,\n}: HoverPreviewProps) {\n return (\n <HoverCard>\n <HoverCardTrigger asChild>{trigger}</HoverCardTrigger>\n <HoverCardContent\n align={align}\n sideOffset={sideOffset}\n className={className}\n >\n {content}\n </HoverCardContent>\n </HoverCard>\n );\n}\n"],"mappings":";;;;;;;;;;AAiBA,SAAgB,aAAa,EAC3B,SACA,SACA,QAAQ,UACR,aAAa,GACb,aACoB;AACpB,QACE,qBAAC,wBACC,oBAAC;EAAiB;YAAS;GAA2B,EACtD,oBAAC;EACQ;EACK;EACD;YAEV;GACgB,IACT"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"LangSwitch.d.ts","names":[],"sources":["../../../src/components/molecules/LangSwitch.tsx"],"sourcesContent":[],"mappings":";;;;UAKiB,UAAA;;SAER,OAAA,CAAM;AAFf;AAKiB,UAAA,eAAA,CAAe;EAOhB,KAAA,EAAA,MAAU;EACxB,OAAA,EANS,UAMT,EAAA;EACA,QAAA,EAAA,CAAA,IAAA,EAAA,MAAA,EAAA,GAAA,IAAA;EACA,IAAA,CAAA,EAAA,IAAA,GAAA,SAAA;;AAEC,iBALa,UAAA,CAKb;EAAA,KAAA;EAAA,OAAA;EAAA,QAAA;EAAA;AAAA,CAAA,EAAA,eAAA,CAAA,EAAe,mBAAA,CAAA,GAAA,CAAA,OAAf"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"LangSwitch.js","names":[],"sources":["../../../src/components/molecules/LangSwitch.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { Button } from '../atoms/Button';\n\nexport interface LangOption {\n code: string; // e.g. 'en', 'fr'\n label: React.ReactNode;\n}\n\nexport interface LangSwitchProps {\n value: string;\n options: LangOption[];\n onChange: (code: string) => void;\n size?: 'sm' | 'default';\n}\n\nexport function LangSwitch({\n value,\n options,\n onChange,\n size = 'sm',\n}: LangSwitchProps) {\n return (\n <div className=\"flex items-center gap-1\">\n {options.map((opt) => (\n <Button\n key={opt.code}\n variant={value === opt.code ? 'default' : 'ghost'}\n size={size}\n onPress={() => onChange(opt.code)}\n >\n {opt.label}\n </Button>\n ))}\n </div>\n );\n}\n"],"mappings":";;;;;;;;AAiBA,SAAgB,WAAW,EACzB,OACA,SACA,UACA,OAAO,QACW;AAClB,QACE,oBAAC;EAAI,WAAU;YACZ,QAAQ,KAAK,QACZ,oBAAC;GAEC,SAAS,UAAU,IAAI,OAAO,YAAY;GACpC;GACN,eAAe,SAAS,IAAI,KAAK;aAEhC,IAAI;KALA,IAAI,KAMF,CACT;GACE"}