admin-ui-starter-kit 0.1.2 → 0.1.4
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.
- package/.agents/skills/admin-ui-consumer-migration/SKILL.md +135 -0
- package/.agents/skills/component-library-rules/SKILL.md +13 -2
- package/.agents/skills/component-library-rules/references/components/INDEX.json +1 -0
- package/.agents/skills/component-library-rules/references/components/INDEX.md +1 -0
- package/.agents/skills/component-library-rules/references/components/base__buttons.md +18 -6
- package/.agents/skills/component-library-rules/references/components/base__combobox.md +1 -1
- package/.agents/skills/component-library-rules/references/components/base__event-calendar.md +1 -1
- package/.agents/skills/component-library-rules/references/components/base__forms.md +10 -7
- package/.agents/skills/component-library-rules/references/components/base__item.md +1 -1
- package/.agents/skills/component-library-rules/references/components/base__map.md +7 -7
- package/.agents/skills/component-library-rules/references/components/base__navigation.md +8 -8
- package/.agents/skills/component-library-rules/references/components/base__table.md +2 -2
- package/.agents/skills/component-library-rules/references/components/base__typography.md +6 -4
- package/.agents/skills/component-library-rules/references/components/composed__ai-elements.md +4 -4
- package/.agents/skills/component-library-rules/references/components/composed__api-key-list.md +4 -4
- package/.agents/skills/component-library-rules/references/components/composed__commerce-extras.md +107 -113
- package/.agents/skills/component-library-rules/references/components/composed__commerce.md +49 -48
- package/.agents/skills/component-library-rules/references/components/composed__navigation.md +6 -2
- package/.agents/skills/component-library-rules/references/components/composed__timelines.md +21 -7
- package/.agents/skills/component-library-rules/references/components/features__comments.md +12 -4
- package/.agents/skills/component-library-rules/references/components/features__enhanced-activities.md +4 -2
- package/.agents/skills/component-library-rules/references/components/features__event-log.md +6 -2
- package/.agents/skills/component-library-rules/references/components/features__overlays.md +8 -6
- package/.agents/skills/component-library-rules/references/components/layout__layout-app-shell.md +552 -0
- package/.agents/skills/component-library-rules/references/components/layout__layout-header.md +2 -2
- package/.agents/skills/component-library-rules/references/components/layout__layout-sidebar.md +2 -2
- package/.agents/skills/component-library-rules/references/components/layout__layout-users.md +7 -7
- package/.agents/skills/component-library-rules/references/components/ui__toggles-group.md +7 -7
- package/.agents/skills/component-library-rules/references/components/ui__toggles.md +1 -1
- package/AGENTS.md +6 -4
- package/CHANGELOG.md +27 -1
- package/COMPONENT_SELECTION.md +115 -0
- package/INTEGRATION.md +10 -0
- package/MIGRATION.md +239 -0
- package/PUBLISHING.md +6 -1
- package/README.md +31 -8
- package/dist/_shared/accordion-BnxO7Is4.js +130 -0
- package/dist/_shared/accordion-BnxO7Is4.js.map +1 -0
- package/dist/_shared/accordion-RIN0MjPz.cjs +2 -0
- package/dist/_shared/accordion-RIN0MjPz.cjs.map +1 -0
- package/dist/_shared/action-menu-IIO9KtJ2.js +96 -0
- package/dist/_shared/action-menu-IIO9KtJ2.js.map +1 -0
- package/dist/_shared/action-menu-RAyg3cvM.cjs +2 -0
- package/dist/_shared/action-menu-RAyg3cvM.cjs.map +1 -0
- package/dist/_shared/ai-artifact--MqIfP-8.js +1068 -0
- package/dist/_shared/ai-artifact--MqIfP-8.js.map +1 -0
- package/dist/_shared/ai-artifact-D1dBeEz1.cjs +3 -0
- package/dist/_shared/ai-artifact-D1dBeEz1.cjs.map +1 -0
- package/dist/_shared/alert-D3gRd7RK.cjs +2 -0
- package/dist/_shared/alert-D3gRd7RK.cjs.map +1 -0
- package/dist/_shared/alert-DQ-tV8b-.js +48 -0
- package/dist/_shared/alert-DQ-tV8b-.js.map +1 -0
- package/dist/_shared/app-shell-C4d7kCCd.cjs +2 -0
- package/dist/_shared/app-shell-C4d7kCCd.cjs.map +1 -0
- package/dist/_shared/app-shell-CKxcpPTc.js +94 -0
- package/dist/_shared/app-shell-CKxcpPTc.js.map +1 -0
- package/dist/_shared/avatar-0spfQEHG.cjs +2 -0
- package/dist/_shared/avatar-0spfQEHG.cjs.map +1 -0
- package/dist/_shared/avatar-CBi4LGxy.js +52 -0
- package/dist/_shared/avatar-CBi4LGxy.js.map +1 -0
- package/dist/_shared/badge-BK5VvEgg.js +108 -0
- package/dist/_shared/badge-BK5VvEgg.js.map +1 -0
- package/dist/_shared/badge-kS_XtN-z.cjs +2 -0
- package/dist/_shared/badge-kS_XtN-z.cjs.map +1 -0
- package/dist/_shared/breadcrumbs-Dqp2qAmo.cjs +2 -0
- package/dist/_shared/breadcrumbs-Dqp2qAmo.cjs.map +1 -0
- package/dist/_shared/breadcrumbs-bJ-J0oCd.js +111 -0
- package/dist/_shared/breadcrumbs-bJ-J0oCd.js.map +1 -0
- package/dist/_shared/button-683R5quQ.js +46 -0
- package/dist/_shared/button-683R5quQ.js.map +1 -0
- package/dist/_shared/button-CjZrRLzR.cjs +2 -0
- package/dist/_shared/button-CjZrRLzR.cjs.map +1 -0
- package/dist/_shared/button-LZWDn-aU.cjs +2 -0
- package/dist/_shared/button-LZWDn-aU.cjs.map +1 -0
- package/dist/_shared/button-cnkCF8q8.js +177 -0
- package/dist/_shared/button-cnkCF8q8.js.map +1 -0
- package/dist/_shared/buttons-DHV2eZAf.cjs +2 -0
- package/dist/_shared/buttons-DHV2eZAf.cjs.map +1 -0
- package/dist/_shared/buttons-ehfMSkwP.js +143 -0
- package/dist/_shared/buttons-ehfMSkwP.js.map +1 -0
- package/dist/_shared/card-radio-group-Bf03M6c5.js +158 -0
- package/dist/_shared/card-radio-group-Bf03M6c5.js.map +1 -0
- package/dist/_shared/card-radio-group-SqPUL0Je.cjs +2 -0
- package/dist/_shared/card-radio-group-SqPUL0Je.cjs.map +1 -0
- package/dist/_shared/chunk-CMqjfN_6.cjs +1 -0
- package/dist/_shared/combobox-Cvs70ic4.js +808 -0
- package/dist/_shared/combobox-Cvs70ic4.js.map +1 -0
- package/dist/_shared/combobox-Dos9YWjk.cjs +2 -0
- package/dist/_shared/combobox-Dos9YWjk.cjs.map +1 -0
- package/dist/_shared/command-Bxe_FmGD.cjs +2 -0
- package/dist/_shared/command-Bxe_FmGD.cjs.map +1 -0
- package/dist/_shared/command-CAI-BCSR.js +123 -0
- package/dist/_shared/command-CAI-BCSR.js.map +1 -0
- package/dist/_shared/command-DRIySU26.cjs +2 -0
- package/dist/_shared/command-DRIySU26.cjs.map +1 -0
- package/dist/_shared/command-DwRnPIGs.js +39 -0
- package/dist/_shared/command-DwRnPIGs.js.map +1 -0
- package/dist/_shared/comments-DD2aeZVz.js +946 -0
- package/dist/_shared/comments-DD2aeZVz.js.map +1 -0
- package/dist/_shared/comments-DzwU4sNE.cjs +2 -0
- package/dist/_shared/comments-DzwU4sNE.cjs.map +1 -0
- package/dist/_shared/containers-D7oZE4XI.cjs +2 -0
- package/dist/_shared/containers-D7oZE4XI.cjs.map +1 -0
- package/dist/_shared/containers-anBivbL9.js +19 -0
- package/dist/_shared/containers-anBivbL9.js.map +1 -0
- package/dist/_shared/content-container-CVUJCLhn.cjs +2 -0
- package/dist/_shared/content-container-CVUJCLhn.cjs.map +1 -0
- package/dist/_shared/content-container-Dv8XsAw4.js +33 -0
- package/dist/_shared/content-container-Dv8XsAw4.js.map +1 -0
- package/dist/_shared/copyable-D7WhgEzJ.js +38 -0
- package/dist/_shared/copyable-D7WhgEzJ.js.map +1 -0
- package/dist/_shared/copyable-DDjT505-.cjs +2 -0
- package/dist/_shared/copyable-DDjT505-.cjs.map +1 -0
- package/dist/_shared/date-picker-3G3C-sIq.cjs +2 -0
- package/dist/_shared/date-picker-3G3C-sIq.cjs.map +1 -0
- package/dist/_shared/date-picker-7yuMHPYs.js +1362 -0
- package/dist/_shared/date-picker-7yuMHPYs.js.map +1 -0
- package/dist/_shared/date-pickers-B_VUgjvY.cjs +2 -0
- package/dist/_shared/date-pickers-B_VUgjvY.cjs.map +1 -0
- package/dist/_shared/date-pickers-DZXi0di0.js +330 -0
- package/dist/_shared/date-pickers-DZXi0di0.js.map +1 -0
- package/dist/_shared/dialog-A95-614f.js +101 -0
- package/dist/_shared/dialog-A95-614f.js.map +1 -0
- package/dist/_shared/dialog-ivDByBmO.cjs +2 -0
- package/dist/_shared/dialog-ivDByBmO.cjs.map +1 -0
- package/dist/_shared/display-Cuj4td-V.js +1237 -0
- package/dist/_shared/display-Cuj4td-V.js.map +1 -0
- package/dist/_shared/display-D2q93jiS.cjs +8 -0
- package/dist/_shared/display-D2q93jiS.cjs.map +1 -0
- package/dist/_shared/dropdown-menu-CHQzQWUK.cjs +2 -0
- package/dist/_shared/dropdown-menu-CHQzQWUK.cjs.map +1 -0
- package/dist/_shared/dropdown-menu-CoWmrjYX.js +147 -0
- package/dist/_shared/dropdown-menu-CoWmrjYX.js.map +1 -0
- package/dist/_shared/form-field-BNuCBym1.js +319 -0
- package/dist/_shared/form-field-BNuCBym1.js.map +1 -0
- package/dist/_shared/form-field-C4fQYsqv.cjs +2 -0
- package/dist/_shared/form-field-C4fQYsqv.cjs.map +1 -0
- package/dist/_shared/form-sizing-D74IS9KG.js +21 -0
- package/dist/_shared/form-sizing-D74IS9KG.js.map +1 -0
- package/dist/_shared/form-sizing-aVwVuF-w.cjs +2 -0
- package/dist/_shared/form-sizing-aVwVuF-w.cjs.map +1 -0
- package/dist/_shared/format-BTtJC6oz.cjs +2 -0
- package/dist/_shared/format-BTtJC6oz.cjs.map +1 -0
- package/dist/_shared/format-BX3QestD.js +48 -0
- package/dist/_shared/format-BX3QestD.js.map +1 -0
- package/dist/_shared/forms-BV4fHeRx.cjs +2 -0
- package/dist/_shared/forms-BV4fHeRx.cjs.map +1 -0
- package/dist/_shared/forms-DjAdYxme.js +3378 -0
- package/dist/_shared/forms-DjAdYxme.js.map +1 -0
- package/dist/_shared/header-D4Oz-mCv.cjs +2 -0
- package/dist/_shared/header-D4Oz-mCv.cjs.map +1 -0
- package/dist/_shared/header-X5DZ8vmO.js +360 -0
- package/dist/_shared/header-X5DZ8vmO.js.map +1 -0
- package/dist/_shared/heading-C7mNh03X.cjs +2 -0
- package/dist/_shared/heading-C7mNh03X.cjs.map +1 -0
- package/dist/_shared/heading-CrNpYcUr.js +39 -0
- package/dist/_shared/heading-CrNpYcUr.js.map +1 -0
- package/dist/_shared/hooks-CKXPg30g.js +118 -0
- package/dist/_shared/hooks-CKXPg30g.js.map +1 -0
- package/dist/_shared/hooks-CTiEImZp.cjs +2 -0
- package/dist/_shared/hooks-CTiEImZp.cjs.map +1 -0
- package/dist/_shared/icon-badge-BAWl1oOe.cjs +2 -0
- package/dist/_shared/icon-badge-BAWl1oOe.cjs.map +1 -0
- package/dist/_shared/icon-badge-zTBVtgt9.js +52 -0
- package/dist/_shared/icon-badge-zTBVtgt9.js.map +1 -0
- package/dist/_shared/input-Cw2uICc1.cjs +2 -0
- package/dist/_shared/input-Cw2uICc1.cjs.map +1 -0
- package/dist/_shared/input-D43_IMWW.cjs +2 -0
- package/dist/_shared/input-D43_IMWW.cjs.map +1 -0
- package/dist/_shared/input-DJo8d1Rr.js +182 -0
- package/dist/_shared/input-DJo8d1Rr.js.map +1 -0
- package/dist/_shared/input-R8c90tNY.js +17 -0
- package/dist/_shared/input-R8c90tNY.js.map +1 -0
- package/dist/_shared/item-BxlP5TO3.js +224 -0
- package/dist/_shared/item-BxlP5TO3.js.map +1 -0
- package/dist/_shared/item-X18HIqR7.cjs +2 -0
- package/dist/_shared/item-X18HIqR7.cjs.map +1 -0
- package/dist/_shared/mentions-DE9aDOMu.cjs +2 -0
- package/dist/_shared/mentions-DE9aDOMu.cjs.map +1 -0
- package/dist/_shared/mentions-DjjYmMLc.js +493 -0
- package/dist/_shared/mentions-DjjYmMLc.js.map +1 -0
- package/dist/_shared/metadata-C5MSNo7y.js +236 -0
- package/dist/_shared/metadata-C5MSNo7y.js.map +1 -0
- package/dist/_shared/metadata-Cw3Kj2Ug.cjs +2 -0
- package/dist/_shared/metadata-Cw3Kj2Ug.cjs.map +1 -0
- package/dist/_shared/money-display-B7AKxxNt.js +198 -0
- package/dist/_shared/money-display-B7AKxxNt.js.map +1 -0
- package/dist/_shared/money-display-E22wbM21.cjs +2 -0
- package/dist/_shared/money-display-E22wbM21.cjs.map +1 -0
- package/dist/_shared/navigation-B9VAXqLL.cjs +2 -0
- package/dist/_shared/navigation-B9VAXqLL.cjs.map +1 -0
- package/dist/_shared/navigation-CxoJVgfo.js +420 -0
- package/dist/_shared/navigation-CxoJVgfo.js.map +1 -0
- package/dist/_shared/overlays-C-T8RnJz.cjs +2 -0
- package/dist/_shared/overlays-C-T8RnJz.cjs.map +1 -0
- package/dist/_shared/overlays-DfRsQzD3.js +633 -0
- package/dist/_shared/overlays-DfRsQzD3.js.map +1 -0
- package/dist/_shared/page-C4jEULwi.js +263 -0
- package/dist/_shared/page-C4jEULwi.js.map +1 -0
- package/dist/_shared/page-DX3pA_tJ.cjs +2 -0
- package/dist/_shared/page-DX3pA_tJ.cjs.map +1 -0
- package/dist/_shared/popover-CaHvG8Vj.cjs +2 -0
- package/dist/_shared/popover-CaHvG8Vj.cjs.map +1 -0
- package/dist/_shared/popover-L37RqoRO.js +83 -0
- package/dist/_shared/popover-L37RqoRO.js.map +1 -0
- package/dist/_shared/popover-menu-CVAr985u.js +95 -0
- package/dist/_shared/popover-menu-CVAr985u.js.map +1 -0
- package/dist/_shared/popover-menu-Cq-LnAMh.cjs +2 -0
- package/dist/_shared/popover-menu-Cq-LnAMh.cjs.map +1 -0
- package/dist/_shared/rich-text-editor-C3gVBm-v.cjs +2 -0
- package/dist/_shared/rich-text-editor-C3gVBm-v.cjs.map +1 -0
- package/dist/_shared/rich-text-editor-Cylb-lkv.js +616 -0
- package/dist/_shared/rich-text-editor-Cylb-lkv.js.map +1 -0
- package/dist/_shared/scroll-area-BH5CPQh4.js +41 -0
- package/dist/_shared/scroll-area-BH5CPQh4.js.map +1 -0
- package/dist/_shared/scroll-area-u46BOVcC.cjs +2 -0
- package/dist/_shared/scroll-area-u46BOVcC.cjs.map +1 -0
- package/dist/_shared/select-BwUUXpsb.js +85 -0
- package/dist/_shared/select-BwUUXpsb.js.map +1 -0
- package/dist/_shared/select-CG5Yq-6A.cjs +2 -0
- package/dist/_shared/select-CG5Yq-6A.cjs.map +1 -0
- package/dist/_shared/separator-B8FBp-7E.js +16 -0
- package/dist/_shared/separator-B8FBp-7E.js.map +1 -0
- package/dist/_shared/separator-q42IlFFA.cjs +2 -0
- package/dist/_shared/separator-q42IlFFA.cjs.map +1 -0
- package/dist/_shared/sheet-BKEfwhCn.js +100 -0
- package/dist/_shared/sheet-BKEfwhCn.js.map +1 -0
- package/dist/_shared/sheet-D4yWgkwC.cjs +2 -0
- package/dist/_shared/sheet-D4yWgkwC.cjs.map +1 -0
- package/dist/_shared/sidebar-BeWLjIRR.js +537 -0
- package/dist/_shared/sidebar-BeWLjIRR.js.map +1 -0
- package/dist/_shared/sidebar-Bl_KRk-S.cjs +2 -0
- package/dist/_shared/sidebar-Bl_KRk-S.cjs.map +1 -0
- package/dist/_shared/sidebar-DzzdJ2xk.cjs +2 -0
- package/dist/_shared/sidebar-DzzdJ2xk.cjs.map +1 -0
- package/dist/_shared/sidebar-ux-yk-Ph.js +382 -0
- package/dist/_shared/sidebar-ux-yk-Ph.js.map +1 -0
- package/dist/_shared/skeleton-CGQMeno1.js +14 -0
- package/dist/_shared/skeleton-CGQMeno1.js.map +1 -0
- package/dist/_shared/skeleton-D1c5OHXa.cjs +2 -0
- package/dist/_shared/skeleton-D1c5OHXa.cjs.map +1 -0
- package/dist/_shared/slot-C5EJicOc.js +18 -0
- package/dist/_shared/slot-C5EJicOc.js.map +1 -0
- package/dist/_shared/slot-D-Rwlrz2.cjs +2 -0
- package/dist/_shared/slot-D-Rwlrz2.cjs.map +1 -0
- package/dist/_shared/smart-card-DL7esK_y.cjs +2 -0
- package/dist/_shared/smart-card-DL7esK_y.cjs.map +1 -0
- package/dist/_shared/smart-card-eBfUvQ9r.js +360 -0
- package/dist/_shared/smart-card-eBfUvQ9r.js.map +1 -0
- package/dist/_shared/spinner-Bvjs1ybK.cjs +2 -0
- package/dist/_shared/spinner-Bvjs1ybK.cjs.map +1 -0
- package/dist/_shared/spinner-XcfVYbbp.js +67 -0
- package/dist/_shared/spinner-XcfVYbbp.js.map +1 -0
- package/dist/_shared/switch-BBP3u1z5.js +55 -0
- package/dist/_shared/switch-BBP3u1z5.js.map +1 -0
- package/dist/_shared/switch-zFZhhOEP.cjs +2 -0
- package/dist/_shared/switch-zFZhhOEP.cjs.map +1 -0
- package/dist/_shared/text-DzKt9cyb.cjs +2 -0
- package/dist/_shared/text-DzKt9cyb.cjs.map +1 -0
- package/dist/_shared/text-qsEg5GdP.js +74 -0
- package/dist/_shared/text-qsEg5GdP.js.map +1 -0
- package/dist/_shared/textarea-BAKapsLQ.cjs +2 -0
- package/dist/_shared/textarea-BAKapsLQ.cjs.map +1 -0
- package/dist/_shared/textarea-Bfv1KxBm.js +119 -0
- package/dist/_shared/textarea-Bfv1KxBm.js.map +1 -0
- package/dist/_shared/tooltip-CLr_sPX8.js +49 -0
- package/dist/_shared/tooltip-CLr_sPX8.js.map +1 -0
- package/dist/_shared/tooltip-mvxZV_Lu.cjs +2 -0
- package/dist/_shared/tooltip-mvxZV_Lu.cjs.map +1 -0
- package/dist/_shared/typography-4CSyoCj9.js +102 -0
- package/dist/_shared/typography-4CSyoCj9.js.map +1 -0
- package/dist/_shared/typography-DKn7P4wX.cjs +2 -0
- package/dist/_shared/typography-DKn7P4wX.cjs.map +1 -0
- package/dist/_shared/ui-provider-CQJ1glwN.js +85 -0
- package/dist/_shared/ui-provider-CQJ1glwN.js.map +1 -0
- package/dist/_shared/ui-provider-RIYE7O_V.cjs +2 -0
- package/dist/_shared/ui-provider-RIYE7O_V.cjs.map +1 -0
- package/dist/components/base/accordion/index.cjs +1 -1
- package/dist/components/base/accordion/index.js +2 -2
- package/dist/components/base/badge/badge.d.ts +1 -1
- package/dist/components/base/badge/badge.d.ts.map +1 -1
- package/dist/components/base/badge/index.cjs +1 -1
- package/dist/components/base/badge/index.js +1 -1
- package/dist/components/base/buttons/google-button.d.ts +1 -1
- package/dist/components/base/buttons/google-button.d.ts.map +1 -1
- package/dist/components/base/buttons/index.cjs +1 -1
- package/dist/components/base/buttons/index.js +2 -2
- package/dist/components/base/buttons/shopify-button.d.ts +1 -1
- package/dist/components/base/buttons/shopify-button.d.ts.map +1 -1
- package/dist/components/base/buttons/tooltip-button.d.ts.map +1 -1
- package/dist/components/base/cards/index.cjs +1 -1
- package/dist/components/base/cards/index.js +1 -1
- package/dist/components/base/cards/partials/card-primitives.d.ts +6 -6
- package/dist/components/base/cards/partials/card-primitives.d.ts.map +1 -1
- package/dist/components/base/cards/partials/smart-card-actions-menu.d.ts +1 -1
- package/dist/components/base/cards/partials/smart-card-actions-menu.d.ts.map +1 -1
- package/dist/components/base/cards/partials/smart-card-alert.d.ts +1 -1
- package/dist/components/base/cards/partials/smart-card-alert.d.ts.map +1 -1
- package/dist/components/base/cards/partials/smart-card-header-row.d.ts +1 -1
- package/dist/components/base/cards/partials/smart-card-header-row.d.ts.map +1 -1
- package/dist/components/base/cards/partials/smart-card-skeleton.d.ts +1 -1
- package/dist/components/base/cards/partials/smart-card-skeleton.d.ts.map +1 -1
- package/dist/components/base/cards/smart-card.tokens.d.ts +1 -1
- package/dist/components/base/combobox/combobox.strings.d.ts.map +1 -1
- package/dist/components/base/combobox/components/highlighted-text.d.ts.map +1 -1
- package/dist/components/base/combobox/enhanced-combobox.d.ts.map +1 -1
- package/dist/components/base/combobox/index.cjs +1 -1
- package/dist/components/base/combobox/index.js +1 -1
- package/dist/components/base/combobox/types.d.ts +2 -0
- package/dist/components/base/combobox/types.d.ts.map +1 -1
- package/dist/components/base/command/command.d.ts +5 -5
- package/dist/components/base/command/command.d.ts.map +1 -1
- package/dist/components/base/command/index.cjs +1 -1
- package/dist/components/base/command/index.js +2 -2
- package/dist/components/base/copyable/copyable.d.ts +1 -1
- package/dist/components/base/copyable/copyable.d.ts.map +1 -1
- package/dist/components/base/copyable/index.cjs +1 -1
- package/dist/components/base/copyable/index.js +1 -1
- package/dist/components/base/currency/currency-pair-preview.d.ts +1 -1
- package/dist/components/base/currency/currency-pair-preview.d.ts.map +1 -1
- package/dist/components/base/currency/index.cjs +1 -1
- package/dist/components/base/currency/index.js +1 -1
- package/dist/components/base/date-pickers/date-picker-footer.d.ts +2 -1
- package/dist/components/base/date-pickers/date-picker-footer.d.ts.map +1 -1
- package/dist/components/base/date-pickers/date-picker-header.d.ts +1 -1
- package/dist/components/base/date-pickers/date-picker-header.d.ts.map +1 -1
- package/dist/components/base/date-pickers/date-picker-helpers.d.ts +5 -1
- package/dist/components/base/date-pickers/date-picker-helpers.d.ts.map +1 -1
- package/dist/components/base/date-pickers/date-picker.d.ts +2 -1
- package/dist/components/base/date-pickers/date-picker.d.ts.map +1 -1
- package/dist/components/base/date-pickers/date-range-picker.d.ts +2 -1
- package/dist/components/base/date-pickers/date-range-picker.d.ts.map +1 -1
- package/dist/components/base/date-pickers/index.cjs +1 -1
- package/dist/components/base/date-pickers/index.js +3 -3
- package/dist/components/base/date-pickers/month-year-picker.d.ts +2 -1
- package/dist/components/base/date-pickers/month-year-picker.d.ts.map +1 -1
- package/dist/components/base/date-pickers/segmented-time-input.d.ts +2 -1
- package/dist/components/base/date-pickers/segmented-time-input.d.ts.map +1 -1
- package/dist/components/base/display/boolean-indicator.d.ts +1 -1
- package/dist/components/base/display/boolean-indicator.d.ts.map +1 -1
- package/dist/components/base/display/date-block.d.ts +1 -1
- package/dist/components/base/display/date-block.d.ts.map +1 -1
- package/dist/components/base/display/empty-state/partials/illustrations/document-stack.d.ts +1 -1
- package/dist/components/base/display/empty-state/partials/illustrations/document-stack.d.ts.map +1 -1
- package/dist/components/base/display/empty-state/partials/illustrations/inbox-clean.d.ts +1 -1
- package/dist/components/base/display/empty-state/partials/illustrations/inbox-clean.d.ts.map +1 -1
- package/dist/components/base/display/empty-state/partials/illustrations/search-glass.d.ts +1 -1
- package/dist/components/base/display/empty-state/partials/illustrations/search-glass.d.ts.map +1 -1
- package/dist/components/base/display/empty-state/partials/illustrations/stacked-cards.d.ts +1 -1
- package/dist/components/base/display/empty-state/partials/illustrations/stacked-cards.d.ts.map +1 -1
- package/dist/components/base/display/empty-state/partials/illustrations/users-circle.d.ts +1 -1
- package/dist/components/base/display/empty-state/partials/illustrations/users-circle.d.ts.map +1 -1
- package/dist/components/base/display/fields/email-display.d.ts +1 -1
- package/dist/components/base/display/fields/email-display.d.ts.map +1 -1
- package/dist/components/base/display/fields/phone-display.d.ts +1 -1
- package/dist/components/base/display/fields/phone-display.d.ts.map +1 -1
- package/dist/components/base/display/fields/url-display.d.ts +1 -1
- package/dist/components/base/display/fields/url-display.d.ts.map +1 -1
- package/dist/components/base/display/icon-badge/icon-badge.d.ts +1 -1
- package/dist/components/base/display/icon-badge/icon-badge.d.ts.map +1 -1
- package/dist/components/base/display/index.cjs +1 -1
- package/dist/components/base/display/index.js +12 -12
- package/dist/components/base/display/inline-stat/inline-stat.d.ts +1 -1
- package/dist/components/base/display/inline-stat/inline-stat.d.ts.map +1 -1
- package/dist/components/base/display/metadata/index.cjs +1 -1
- package/dist/components/base/display/metadata/index.js +1 -1
- package/dist/components/base/display/metadata/metadata-list.d.ts +1 -1
- package/dist/components/base/display/metadata/metadata-list.d.ts.map +1 -1
- package/dist/components/base/display/money-display.d.ts +1 -1
- package/dist/components/base/display/money-display.d.ts.map +1 -1
- package/dist/components/base/display/money-input.d.ts +1 -1
- package/dist/components/base/display/money-input.d.ts.map +1 -1
- package/dist/components/base/display/notification-banner.d.ts +1 -1
- package/dist/components/base/display/notification-banner.d.ts.map +1 -1
- package/dist/components/base/display/numeric-value/numeric-value.d.ts +1 -1
- package/dist/components/base/display/numeric-value/numeric-value.d.ts.map +1 -1
- package/dist/components/base/display/placeholder-pattern.d.ts +1 -1
- package/dist/components/base/display/placeholder-pattern.d.ts.map +1 -1
- package/dist/components/base/display/qr-code.d.ts +1 -1
- package/dist/components/base/display/qr-code.d.ts.map +1 -1
- package/dist/components/base/display/section-header/section-header.d.ts +1 -1
- package/dist/components/base/display/section-header/section-header.d.ts.map +1 -1
- package/dist/components/base/display/stacked-avatars.d.ts +1 -1
- package/dist/components/base/display/stacked-avatars.d.ts.map +1 -1
- package/dist/components/base/display/throttle-alert.d.ts +1 -1
- package/dist/components/base/display/throttle-alert.d.ts.map +1 -1
- package/dist/components/base/display/user-cell/user-cell.d.ts +1 -1
- package/dist/components/base/display/user-cell/user-cell.d.ts.map +1 -1
- package/dist/components/base/display/visually-hidden.d.ts +1 -1
- package/dist/components/base/display/visually-hidden.d.ts.map +1 -1
- package/dist/components/base/event-calendar/event-calendar-day-cell.d.ts +1 -1
- package/dist/components/base/event-calendar/event-calendar-day-cell.d.ts.map +1 -1
- package/dist/components/base/event-calendar/event-calendar-event-badge.d.ts +1 -1
- package/dist/components/base/event-calendar/event-calendar-event-badge.d.ts.map +1 -1
- package/dist/components/base/event-calendar/event-calendar-event-card.d.ts +1 -1
- package/dist/components/base/event-calendar/event-calendar-event-card.d.ts.map +1 -1
- package/dist/components/base/event-calendar/event-calendar-header.d.ts +1 -1
- package/dist/components/base/event-calendar/event-calendar-header.d.ts.map +1 -1
- package/dist/components/base/event-calendar/event-calendar-legend.d.ts +1 -1
- package/dist/components/base/event-calendar/event-calendar-legend.d.ts.map +1 -1
- package/dist/components/base/event-calendar/event-calendar.d.ts +1 -1
- package/dist/components/base/event-calendar/event-calendar.d.ts.map +1 -1
- package/dist/components/base/event-calendar/index.cjs +1 -1
- package/dist/components/base/event-calendar/index.cjs.map +1 -1
- package/dist/components/base/event-calendar/index.js +12 -12
- package/dist/components/base/event-calendar/index.js.map +1 -1
- package/dist/components/base/forms/fields/avatar-upload.d.ts.map +1 -1
- package/dist/components/base/forms/fields/card-checkbox-group.d.ts +1 -1
- package/dist/components/base/forms/fields/card-checkbox-group.d.ts.map +1 -1
- package/dist/components/base/forms/fields/card-radio-group.d.ts +1 -1
- package/dist/components/base/forms/fields/card-radio-group.d.ts.map +1 -1
- package/dist/components/base/forms/fields/coordinates-input.d.ts +1 -1
- package/dist/components/base/forms/fields/coordinates-input.d.ts.map +1 -1
- package/dist/components/base/forms/fields/date-time-input.d.ts +1 -1
- package/dist/components/base/forms/fields/date-time-input.d.ts.map +1 -1
- package/dist/components/base/forms/fields/dimensions-input.d.ts +1 -1
- package/dist/components/base/forms/fields/dimensions-input.d.ts.map +1 -1
- package/dist/components/base/forms/fields/key-value-editor.d.ts +1 -1
- package/dist/components/base/forms/fields/key-value-editor.d.ts.map +1 -1
- package/dist/components/base/forms/fields/list-radio-group.d.ts +1 -1
- package/dist/components/base/forms/fields/list-radio-group.d.ts.map +1 -1
- package/dist/components/base/forms/fields/list.d.ts +1 -1
- package/dist/components/base/forms/fields/list.d.ts.map +1 -1
- package/dist/components/base/forms/fields/localized-object-field.d.ts +1 -1
- package/dist/components/base/forms/fields/localized-object-field.d.ts.map +1 -1
- package/dist/components/base/forms/fields/localized-string-field.d.ts +1 -1
- package/dist/components/base/forms/fields/localized-string-field.d.ts.map +1 -1
- package/dist/components/base/forms/fields/localized-string-repeater.d.ts +1 -1
- package/dist/components/base/forms/fields/localized-string-repeater.d.ts.map +1 -1
- package/dist/components/base/forms/fields/media-gallery.d.ts +1 -1
- package/dist/components/base/forms/fields/media-gallery.d.ts.map +1 -1
- package/dist/components/base/forms/fields/object-repeater.d.ts +1 -1
- package/dist/components/base/forms/fields/object-repeater.d.ts.map +1 -1
- package/dist/components/base/forms/fields/pill-radio-group.d.ts +11 -1
- package/dist/components/base/forms/fields/pill-radio-group.d.ts.map +1 -1
- package/dist/components/base/forms/fields/repeater.d.ts +1 -1
- package/dist/components/base/forms/fields/repeater.d.ts.map +1 -1
- package/dist/components/base/forms/fields/rounding-mode-select.d.ts +1 -1
- package/dist/components/base/forms/fields/rounding-mode-select.d.ts.map +1 -1
- package/dist/components/base/forms/fields/string-repeater.d.ts +1 -1
- package/dist/components/base/forms/fields/string-repeater.d.ts.map +1 -1
- package/dist/components/base/forms/fields/switch-card.d.ts +2 -1
- package/dist/components/base/forms/fields/switch-card.d.ts.map +1 -1
- package/dist/components/base/forms/fields/switch.d.ts.map +1 -1
- package/dist/components/base/forms/fields/tags-input.d.ts +1 -1
- package/dist/components/base/forms/fields/tags-input.d.ts.map +1 -1
- package/dist/components/base/forms/fields/time-picker.d.ts +2 -1
- package/dist/components/base/forms/fields/time-picker.d.ts.map +1 -1
- package/dist/components/base/forms/fields/toggle-field.d.ts +1 -1
- package/dist/components/base/forms/fields/toggle-field.d.ts.map +1 -1
- package/dist/components/base/forms/fields/upload-progress-list.d.ts +1 -1
- package/dist/components/base/forms/fields/upload-progress-list.d.ts.map +1 -1
- package/dist/components/base/forms/fields/weight-input.d.ts +2 -1
- package/dist/components/base/forms/fields/weight-input.d.ts.map +1 -1
- package/dist/components/base/forms/form-field.d.ts +63 -2
- package/dist/components/base/forms/form-field.d.ts.map +1 -1
- package/dist/components/base/forms/index.cjs +1 -1
- package/dist/components/base/forms/index.js +6 -6
- package/dist/components/base/forms/operation-password-form.d.ts +1 -1
- package/dist/components/base/forms/operation-password-form.d.ts.map +1 -1
- package/dist/components/base/item/index.cjs +1 -1
- package/dist/components/base/item/index.js +1 -1
- package/dist/components/base/map/index.cjs +1 -1
- package/dist/components/base/map/index.cjs.map +1 -1
- package/dist/components/base/map/index.js +104 -85
- package/dist/components/base/map/index.js.map +1 -1
- package/dist/components/base/map/map.d.ts +31 -30
- package/dist/components/base/map/map.d.ts.map +1 -1
- package/dist/components/base/map/place-autocomplete.d.ts +1 -1
- package/dist/components/base/map/place-autocomplete.d.ts.map +1 -1
- package/dist/components/base/navigation/action-menu.d.ts +1 -1
- package/dist/components/base/navigation/aside-navigation-menu.d.ts +1 -1
- package/dist/components/base/navigation/aside-navigation-menu.d.ts.map +1 -1
- package/dist/components/base/navigation/breadcrumbs.d.ts +1 -1
- package/dist/components/base/navigation/breadcrumbs.d.ts.map +1 -1
- package/dist/components/base/navigation/index.cjs +1 -1
- package/dist/components/base/navigation/index.js +4 -4
- package/dist/components/base/navigation/language-switcher.d.ts +1 -1
- package/dist/components/base/navigation/language-switcher.d.ts.map +1 -1
- package/dist/components/base/navigation/navigation-tabs.d.ts +1 -1
- package/dist/components/base/navigation/navigation-tabs.d.ts.map +1 -1
- package/dist/components/base/navigation/overflow-tab-bar.d.ts +1 -1
- package/dist/components/base/navigation/overflow-tab-bar.d.ts.map +1 -1
- package/dist/components/base/navigation/page-header/page-header.d.ts +1 -1
- package/dist/components/base/navigation/page-header/page-header.d.ts.map +1 -1
- package/dist/components/base/navigation/section-nav/section-nav.d.ts +1 -1
- package/dist/components/base/navigation/section-nav/section-nav.d.ts.map +1 -1
- package/dist/components/base/navigation/side-nav.d.ts +1 -1
- package/dist/components/base/navigation/side-nav.d.ts.map +1 -1
- package/dist/components/base/navigation/tab-navigation-menu.d.ts +1 -1
- package/dist/components/base/navigation/tab-navigation-menu.d.ts.map +1 -1
- package/dist/components/base/popover/index.cjs +1 -1
- package/dist/components/base/popover/index.js +1 -1
- package/dist/components/base/popover/popover.d.ts +1 -1
- package/dist/components/base/popover/popover.d.ts.map +1 -1
- package/dist/components/base/popover-menu/index.cjs +1 -1
- package/dist/components/base/popover-menu/index.js +1 -1
- package/dist/components/base/popover-menu/popover-menu.d.ts +1 -1
- package/dist/components/base/popover-menu/popover-menu.d.ts.map +1 -1
- package/dist/components/base/sheet/index.cjs +1 -1
- package/dist/components/base/sheet/index.js +1 -1
- package/dist/components/base/sidebar/index.cjs +1 -1
- package/dist/components/base/sidebar/index.js +2 -2
- package/dist/components/base/sidebar/sidebar.d.ts +10 -9
- package/dist/components/base/sidebar/sidebar.d.ts.map +1 -1
- package/dist/components/base/spinner/index.cjs +1 -1
- package/dist/components/base/spinner/index.js +1 -1
- package/dist/components/base/table/column-visibility-toggle.d.ts +1 -1
- package/dist/components/base/table/column-visibility-toggle.d.ts.map +1 -1
- package/dist/components/base/table/data-table.d.ts +1 -1
- package/dist/components/base/table/data-table.d.ts.map +1 -1
- package/dist/components/base/table/filter-bar.d.ts +1 -1
- package/dist/components/base/table/filter-bar.d.ts.map +1 -1
- package/dist/components/base/table/index.cjs +1 -1
- package/dist/components/base/table/index.cjs.map +1 -1
- package/dist/components/base/table/index.js +23 -23
- package/dist/components/base/table/index.js.map +1 -1
- package/dist/components/base/table/pagination.d.ts +1 -1
- package/dist/components/base/table/pagination.d.ts.map +1 -1
- package/dist/components/base/table/partials/cell-renderers.d.ts +4 -4
- package/dist/components/base/table/partials/cell-renderers.d.ts.map +1 -1
- package/dist/components/base/table/partials/cell-value.d.ts +1 -1
- package/dist/components/base/table/partials/cell-value.d.ts.map +1 -1
- package/dist/components/base/table/partials/density-toggle.d.ts +1 -1
- package/dist/components/base/table/partials/density-toggle.d.ts.map +1 -1
- package/dist/components/base/table/partials/table-link.d.ts +1 -1
- package/dist/components/base/table/partials/table-link.d.ts.map +1 -1
- package/dist/components/base/table/table-actions.d.ts +1 -1
- package/dist/components/base/table/table-actions.d.ts.map +1 -1
- package/dist/components/base/table/table-body.d.ts +1 -1
- package/dist/components/base/table/table-body.d.ts.map +1 -1
- package/dist/components/base/table/table-header.d.ts +2 -1
- package/dist/components/base/table/table-header.d.ts.map +1 -1
- package/dist/components/base/table/table-helpers.d.ts +2 -2
- package/dist/components/base/table/table-helpers.d.ts.map +1 -1
- package/dist/components/base/table/table-pagination.d.ts +1 -1
- package/dist/components/base/table/table-pagination.d.ts.map +1 -1
- package/dist/components/base/table/table-toolbar.d.ts +1 -1
- package/dist/components/base/table/table-toolbar.d.ts.map +1 -1
- package/dist/components/base/toaster/index.cjs +1 -1
- package/dist/components/base/toaster/index.cjs.map +1 -1
- package/dist/components/base/toaster/index.js +1 -1
- package/dist/components/base/toaster/index.js.map +1 -1
- package/dist/components/base/toaster/toaster.d.ts +1 -1
- package/dist/components/base/toaster/toaster.d.ts.map +1 -1
- package/dist/components/composed/admin/conversation-row/conversation-row.d.ts +1 -1
- package/dist/components/composed/admin/conversation-row/conversation-row.d.ts.map +1 -1
- package/dist/components/composed/admin/index.cjs +1 -1
- package/dist/components/composed/admin/index.cjs.map +1 -1
- package/dist/components/composed/admin/index.js +159 -155
- package/dist/components/composed/admin/index.js.map +1 -1
- package/dist/components/composed/admin/inventory-level/inventory-level.d.ts +1 -1
- package/dist/components/composed/admin/inventory-level/inventory-level.d.ts.map +1 -1
- package/dist/components/composed/admin/role-permission/role-permission.d.ts +1 -1
- package/dist/components/composed/admin/role-permission/role-permission.d.ts.map +1 -1
- package/dist/components/composed/admin/settings-toggle/settings-toggle.d.ts +1 -1
- package/dist/components/composed/admin/settings-toggle/settings-toggle.d.ts.map +1 -1
- package/dist/components/composed/admin/team-member/team-member.d.ts +1 -1
- package/dist/components/composed/admin/team-member/team-member.d.ts.map +1 -1
- package/dist/components/composed/ai/ai-agent/ai-agent.d.ts +1 -1
- package/dist/components/composed/ai/ai-agent/ai-agent.d.ts.map +1 -1
- package/dist/components/composed/ai/ai-artifact/ai-artifact.d.ts +1 -1
- package/dist/components/composed/ai/ai-artifact/ai-artifact.d.ts.map +1 -1
- package/dist/components/composed/ai/ai-attachment/ai-attachment.d.ts +1 -1
- package/dist/components/composed/ai/ai-attachment/ai-attachment.d.ts.map +1 -1
- package/dist/components/composed/ai/ai-chain-of-thought/ai-chain-of-thought.d.ts +1 -1
- package/dist/components/composed/ai/ai-chain-of-thought/ai-chain-of-thought.d.ts.map +1 -1
- package/dist/components/composed/ai/ai-citation/ai-citation.d.ts +1 -1
- package/dist/components/composed/ai/ai-citation/ai-citation.d.ts.map +1 -1
- package/dist/components/composed/ai/ai-classification/ai-classification.d.ts +1 -1
- package/dist/components/composed/ai/ai-classification/ai-classification.d.ts.map +1 -1
- package/dist/components/composed/ai/ai-code-block/ai-code-block.d.ts +1 -1
- package/dist/components/composed/ai/ai-code-block/ai-code-block.d.ts.map +1 -1
- package/dist/components/composed/ai/ai-confidence/ai-confidence.d.ts +1 -1
- package/dist/components/composed/ai/ai-confidence/ai-confidence.d.ts.map +1 -1
- package/dist/components/composed/ai/ai-confirmation/ai-confirmation.d.ts +1 -1
- package/dist/components/composed/ai/ai-confirmation/ai-confirmation.d.ts.map +1 -1
- package/dist/components/composed/ai/ai-feedback/ai-feedback.d.ts +1 -1
- package/dist/components/composed/ai/ai-feedback/ai-feedback.d.ts.map +1 -1
- package/dist/components/composed/ai/ai-file-tree/ai-file-tree.d.ts +1 -1
- package/dist/components/composed/ai/ai-file-tree/ai-file-tree.d.ts.map +1 -1
- package/dist/components/composed/ai/ai-inline-citation/ai-inline-citation.d.ts +1 -1
- package/dist/components/composed/ai/ai-inline-citation/ai-inline-citation.d.ts.map +1 -1
- package/dist/components/composed/ai/ai-message-bubble/ai-message-bubble.d.ts +1 -1
- package/dist/components/composed/ai/ai-message-bubble/ai-message-bubble.d.ts.map +1 -1
- package/dist/components/composed/ai/ai-package-info/ai-package-info.d.ts +1 -1
- package/dist/components/composed/ai/ai-package-info/ai-package-info.d.ts.map +1 -1
- package/dist/components/composed/ai/ai-prompt-suggestions/ai-prompt-suggestions.d.ts +1 -1
- package/dist/components/composed/ai/ai-prompt-suggestions/ai-prompt-suggestions.d.ts.map +1 -1
- package/dist/components/composed/ai/ai-reasoning/ai-reasoning.d.ts +1 -1
- package/dist/components/composed/ai/ai-reasoning/ai-reasoning.d.ts.map +1 -1
- package/dist/components/composed/ai/ai-shimmer/ai-shimmer.d.ts +1 -1
- package/dist/components/composed/ai/ai-shimmer/ai-shimmer.d.ts.map +1 -1
- package/dist/components/composed/ai/ai-sources/ai-sources.d.ts +1 -1
- package/dist/components/composed/ai/ai-sources/ai-sources.d.ts.map +1 -1
- package/dist/components/composed/ai/ai-summary/ai-summary.d.ts +1 -1
- package/dist/components/composed/ai/ai-summary/ai-summary.d.ts.map +1 -1
- package/dist/components/composed/ai/ai-task/ai-task.d.ts +1 -1
- package/dist/components/composed/ai/ai-task/ai-task.d.ts.map +1 -1
- package/dist/components/composed/ai/ai-token-usage/ai-token-usage.d.ts +1 -1
- package/dist/components/composed/ai/ai-token-usage/ai-token-usage.d.ts.map +1 -1
- package/dist/components/composed/ai/ai-tool-call/ai-tool-call.d.ts +1 -1
- package/dist/components/composed/ai/ai-tool-call/ai-tool-call.d.ts.map +1 -1
- package/dist/components/composed/ai/index.cjs +1 -1
- package/dist/components/composed/ai/index.cjs.map +1 -1
- package/dist/components/composed/ai/index.js +34 -36
- package/dist/components/composed/ai/index.js.map +1 -1
- package/dist/components/composed/analytics/activity-heatmap/activity-heatmap.d.ts +1 -1
- package/dist/components/composed/analytics/activity-heatmap/activity-heatmap.d.ts.map +1 -1
- package/dist/components/composed/analytics/atoms/metric-skeleton.d.ts +1 -1
- package/dist/components/composed/analytics/atoms/metric-skeleton.d.ts.map +1 -1
- package/dist/components/composed/analytics/atoms/metric-sparkline.d.ts +1 -1
- package/dist/components/composed/analytics/atoms/metric-sparkline.d.ts.map +1 -1
- package/dist/components/composed/analytics/atoms/metric-trend-chip.d.ts +1 -1
- package/dist/components/composed/analytics/atoms/metric-trend-chip.d.ts.map +1 -1
- package/dist/components/composed/analytics/index.cjs +1 -1
- package/dist/components/composed/analytics/index.cjs.map +1 -1
- package/dist/components/composed/analytics/index.js +100 -111
- package/dist/components/composed/analytics/index.js.map +1 -1
- package/dist/components/composed/analytics/metric/metric.d.ts +1 -1
- package/dist/components/composed/analytics/metric/metric.d.ts.map +1 -1
- package/dist/components/composed/analytics/metric-bar/metric-bar.d.ts +1 -1
- package/dist/components/composed/analytics/metric-bar/metric-bar.d.ts.map +1 -1
- package/dist/components/composed/analytics/metric-comparison/metric-comparison.d.ts +1 -1
- package/dist/components/composed/analytics/metric-comparison/metric-comparison.d.ts.map +1 -1
- package/dist/components/composed/analytics/metric-gradient/metric-gradient.d.ts +1 -1
- package/dist/components/composed/analytics/metric-gradient/metric-gradient.d.ts.map +1 -1
- package/dist/components/composed/analytics/metric-grid/metric-grid.d.ts +1 -1
- package/dist/components/composed/analytics/metric-grid/metric-grid.d.ts.map +1 -1
- package/dist/components/composed/analytics/metric-micro-grid/metric-micro-grid.d.ts +1 -1
- package/dist/components/composed/analytics/metric-micro-grid/metric-micro-grid.d.ts.map +1 -1
- package/dist/components/composed/cards/contact-card/contact-card.d.ts +1 -1
- package/dist/components/composed/cards/contact-card/contact-card.d.ts.map +1 -1
- package/dist/components/composed/cards/course-card/course-card.d.ts +1 -1
- package/dist/components/composed/cards/course-card/course-card.d.ts.map +1 -1
- package/dist/components/composed/cards/feature-announcement/feature-announcement.d.ts +1 -1
- package/dist/components/composed/cards/feature-announcement/feature-announcement.d.ts.map +1 -1
- package/dist/components/composed/cards/giftcard-card/partials/giftcard-compact.d.ts +1 -1
- package/dist/components/composed/cards/giftcard-card/partials/giftcard-compact.d.ts.map +1 -1
- package/dist/components/composed/cards/giftcard-card/partials/giftcard-dark.d.ts +1 -1
- package/dist/components/composed/cards/giftcard-card/partials/giftcard-dark.d.ts.map +1 -1
- package/dist/components/composed/cards/giftcard-card/partials/giftcard-full.d.ts +1 -1
- package/dist/components/composed/cards/giftcard-card/partials/giftcard-full.d.ts.map +1 -1
- package/dist/components/composed/cards/giftcard-card/partials/giftcard-illustrated.d.ts +1 -1
- package/dist/components/composed/cards/giftcard-card/partials/giftcard-illustrated.d.ts.map +1 -1
- package/dist/components/composed/cards/giftcard-card/partials/giftcard-minimal.d.ts +1 -1
- package/dist/components/composed/cards/giftcard-card/partials/giftcard-minimal.d.ts.map +1 -1
- package/dist/components/composed/cards/gradient-card/gradient-card.d.ts +2 -2
- package/dist/components/composed/cards/gradient-card/gradient-card.d.ts.map +1 -1
- package/dist/components/composed/cards/index.cjs +1 -1
- package/dist/components/composed/cards/index.cjs.map +1 -1
- package/dist/components/composed/cards/index.js +492 -512
- package/dist/components/composed/cards/index.js.map +1 -1
- package/dist/components/composed/cards/vendor-profile/vendor-profile.d.ts +1 -1
- package/dist/components/composed/cards/vendor-profile/vendor-profile.d.ts.map +1 -1
- package/dist/components/composed/commerce/address-card/address-card.d.ts +1 -1
- package/dist/components/composed/commerce/address-card/address-card.d.ts.map +1 -1
- package/dist/components/composed/commerce/cart-summary/cart-summary.d.ts +1 -1
- package/dist/components/composed/commerce/cart-summary/cart-summary.d.ts.map +1 -1
- package/dist/components/composed/commerce/coupon-input/coupon-input.d.ts +1 -1
- package/dist/components/composed/commerce/coupon-input/coupon-input.d.ts.map +1 -1
- package/dist/components/composed/commerce/discount-stack/discount-stack.d.ts +1 -1
- package/dist/components/composed/commerce/discount-stack/discount-stack.d.ts.map +1 -1
- package/dist/components/composed/commerce/index.cjs +1 -1
- package/dist/components/composed/commerce/index.cjs.map +1 -1
- package/dist/components/composed/commerce/index.js +94 -98
- package/dist/components/composed/commerce/index.js.map +1 -1
- package/dist/components/composed/commerce/loyalty-points/loyalty-points.d.ts +1 -1
- package/dist/components/composed/commerce/loyalty-points/loyalty-points.d.ts.map +1 -1
- package/dist/components/composed/commerce/order-status/order-status.d.ts +1 -1
- package/dist/components/composed/commerce/order-status/order-status.d.ts.map +1 -1
- package/dist/components/composed/commerce/payment-method/payment-method.d.ts +1 -1
- package/dist/components/composed/commerce/payment-method/payment-method.d.ts.map +1 -1
- package/dist/components/composed/commerce/refund-status/refund-status.d.ts +1 -1
- package/dist/components/composed/commerce/refund-status/refund-status.d.ts.map +1 -1
- package/dist/components/composed/commerce/shipment-tracking/shipment-tracking.d.ts +1 -1
- package/dist/components/composed/commerce/shipment-tracking/shipment-tracking.d.ts.map +1 -1
- package/dist/components/composed/commerce/subscription-summary/subscription-summary.d.ts +1 -1
- package/dist/components/composed/commerce/subscription-summary/subscription-summary.d.ts.map +1 -1
- package/dist/components/composed/commerce/tax-breakdown/tax-breakdown.d.ts +1 -1
- package/dist/components/composed/commerce/tax-breakdown/tax-breakdown.d.ts.map +1 -1
- package/dist/components/composed/commerce/upcoming-booking/upcoming-booking.d.ts +1 -1
- package/dist/components/composed/commerce/upcoming-booking/upcoming-booking.d.ts.map +1 -1
- package/dist/components/composed/commerce/voucher-entry/voucher-entry.d.ts +1 -1
- package/dist/components/composed/commerce/voucher-entry/voucher-entry.d.ts.map +1 -1
- package/dist/components/composed/dark-surfaces/booking-receipt/booking-receipt.d.ts +1 -1
- package/dist/components/composed/dark-surfaces/booking-receipt/booking-receipt.d.ts.map +1 -1
- package/dist/components/composed/dark-surfaces/dark-info-panel/dark-info-panel.d.ts +1 -1
- package/dist/components/composed/dark-surfaces/dark-info-panel/dark-info-panel.d.ts.map +1 -1
- package/dist/components/composed/dark-surfaces/dark-payment/dark-payment.d.ts +1 -1
- package/dist/components/composed/dark-surfaces/dark-payment/dark-payment.d.ts.map +1 -1
- package/dist/components/composed/dark-surfaces/index.cjs +1 -1
- package/dist/components/composed/dark-surfaces/index.cjs.map +1 -1
- package/dist/components/composed/dark-surfaces/index.js +30 -27
- package/dist/components/composed/dark-surfaces/index.js.map +1 -1
- package/dist/components/composed/dark-surfaces/order-items/order-items.d.ts +1 -1
- package/dist/components/composed/dark-surfaces/order-items/order-items.d.ts.map +1 -1
- package/dist/components/composed/dark-surfaces/outstanding-balance/outstanding-balance.d.ts +1 -1
- package/dist/components/composed/dark-surfaces/outstanding-balance/outstanding-balance.d.ts.map +1 -1
- package/dist/components/composed/data-display/dense-info-card/helpers.d.ts +2 -2
- package/dist/components/composed/data-display/dense-info-card/helpers.d.ts.map +1 -1
- package/dist/components/composed/data-display/dense-info-card/partials/dense-info-classification.d.ts +1 -1
- package/dist/components/composed/data-display/dense-info-card/partials/dense-info-classification.d.ts.map +1 -1
- package/dist/components/composed/data-display/dense-info-card/partials/dense-info-dashboard.d.ts +1 -1
- package/dist/components/composed/data-display/dense-info-card/partials/dense-info-dashboard.d.ts.map +1 -1
- package/dist/components/composed/data-display/dense-info-card/partials/dense-info-financial.d.ts +1 -1
- package/dist/components/composed/data-display/dense-info-card/partials/dense-info-financial.d.ts.map +1 -1
- package/dist/components/composed/data-display/dense-info-card/partials/dense-info-project.d.ts +1 -1
- package/dist/components/composed/data-display/dense-info-card/partials/dense-info-project.d.ts.map +1 -1
- package/dist/components/composed/data-display/dense-info-card/partials/dense-info-score.d.ts +1 -1
- package/dist/components/composed/data-display/dense-info-card/partials/dense-info-score.d.ts.map +1 -1
- package/dist/components/composed/data-display/index.cjs +1 -1
- package/dist/components/composed/data-display/index.cjs.map +1 -1
- package/dist/components/composed/data-display/index.js +344 -319
- package/dist/components/composed/data-display/index.js.map +1 -1
- package/dist/components/composed/data-display/inline-metric/inline-metric.d.ts +1 -1
- package/dist/components/composed/data-display/inline-metric/inline-metric.d.ts.map +1 -1
- package/dist/components/composed/data-display/invoice-header/invoice-header.d.ts +1 -1
- package/dist/components/composed/data-display/invoice-header/invoice-header.d.ts.map +1 -1
- package/dist/components/composed/data-display/invoice-items/invoice-items.d.ts +3 -3
- package/dist/components/composed/data-display/invoice-items/invoice-items.d.ts.map +1 -1
- package/dist/components/composed/data-display/invoice-mini/invoice-mini.d.ts +1 -1
- package/dist/components/composed/data-display/invoice-mini/invoice-mini.d.ts.map +1 -1
- package/dist/components/composed/data-display/invoice-table/invoice-table.d.ts +1 -1
- package/dist/components/composed/data-display/invoice-table/invoice-table.d.ts.map +1 -1
- package/dist/components/composed/data-display/mini-kpi/mini-kpi.d.ts +1 -1
- package/dist/components/composed/data-display/mini-kpi/mini-kpi.d.ts.map +1 -1
- package/dist/components/composed/navigation/breadcrumb-progress/breadcrumb-progress.d.ts +1 -1
- package/dist/components/composed/navigation/breadcrumb-progress/breadcrumb-progress.d.ts.map +1 -1
- package/dist/components/composed/navigation/category-nav/category-nav.d.ts +1 -1
- package/dist/components/composed/navigation/category-nav/category-nav.d.ts.map +1 -1
- package/dist/components/composed/navigation/experience-activity/experience-activity.d.ts +1 -1
- package/dist/components/composed/navigation/experience-activity/experience-activity.d.ts.map +1 -1
- package/dist/components/composed/navigation/experience-activity/experience-activity.strings.d.ts +8 -0
- package/dist/components/composed/navigation/experience-activity/experience-activity.strings.d.ts.map +1 -0
- package/dist/components/composed/navigation/experience-activity/index.d.ts +1 -0
- package/dist/components/composed/navigation/experience-activity/index.d.ts.map +1 -1
- package/dist/components/composed/navigation/experience-activity/types.d.ts +2 -0
- package/dist/components/composed/navigation/experience-activity/types.d.ts.map +1 -1
- package/dist/components/composed/navigation/index.cjs +1 -1
- package/dist/components/composed/navigation/index.cjs.map +1 -1
- package/dist/components/composed/navigation/index.js +42 -35
- package/dist/components/composed/navigation/index.js.map +1 -1
- package/dist/components/composed/navigation/kanban-board/kanban-board.d.ts +1 -1
- package/dist/components/composed/navigation/kanban-board/kanban-board.d.ts.map +1 -1
- package/dist/components/composed/navigation/tab-switcher/tab-switcher.d.ts +1 -1
- package/dist/components/composed/navigation/tab-switcher/tab-switcher.d.ts.map +1 -1
- package/dist/components/composed/navigation/time-ruler/time-ruler.d.ts +1 -1
- package/dist/components/composed/navigation/time-ruler/time-ruler.d.ts.map +1 -1
- package/dist/components/composed/navigation/vendor-performance/vendor-performance.d.ts +1 -1
- package/dist/components/composed/navigation/vendor-performance/vendor-performance.d.ts.map +1 -1
- package/dist/components/composed/onboarding/checklist/checklist.d.ts.map +1 -1
- package/dist/components/composed/onboarding/checklist/partials/step-status-indicator.d.ts +1 -1
- package/dist/components/composed/onboarding/checklist/partials/step-status-indicator.d.ts.map +1 -1
- package/dist/components/composed/onboarding/index.cjs +1 -1
- package/dist/components/composed/onboarding/index.cjs.map +1 -1
- package/dist/components/composed/onboarding/index.js +60 -60
- package/dist/components/composed/onboarding/index.js.map +1 -1
- package/dist/components/composed/timelines/activity-stream/activity-stream.d.ts +1 -1
- package/dist/components/composed/timelines/activity-stream/activity-stream.d.ts.map +1 -1
- package/dist/components/composed/timelines/changelog/changelog-timeline.d.ts +1 -1
- package/dist/components/composed/timelines/changelog/changelog-timeline.d.ts.map +1 -1
- package/dist/components/composed/timelines/index.cjs +1 -1
- package/dist/components/composed/timelines/index.cjs.map +1 -1
- package/dist/components/composed/timelines/index.js +34 -7
- package/dist/components/composed/timelines/index.js.map +1 -1
- package/dist/components/composed/timelines/milestones/milestones-timeline.d.ts +1 -1
- package/dist/components/composed/timelines/milestones/milestones-timeline.d.ts.map +1 -1
- package/dist/components/composed/timelines/order-timeline/order-timeline.d.ts +1 -1
- package/dist/components/composed/timelines/order-timeline/order-timeline.d.ts.map +1 -1
- package/dist/components/composed/timelines/payment-timeline/payment-timeline.d.ts +1 -1
- package/dist/components/composed/timelines/payment-timeline/payment-timeline.d.ts.map +1 -1
- package/dist/components/composed/timelines/shared/timeline.d.ts +1 -1
- package/dist/components/composed/timelines/shared/timeline.d.ts.map +1 -1
- package/dist/components/composed/timelines/steps-card/steps-card.d.ts +2 -2
- package/dist/components/composed/timelines/steps-card/steps-card.d.ts.map +1 -1
- package/dist/components/features/activities/activities-feed.d.ts +1 -1
- package/dist/components/features/activities/activities-feed.d.ts.map +1 -1
- package/dist/components/features/activities/index.cjs +1 -1
- package/dist/components/features/activities/index.cjs.map +1 -1
- package/dist/components/features/activities/index.js +7 -7
- package/dist/components/features/activities/index.js.map +1 -1
- package/dist/components/features/activities/partials/activities-feed-card.d.ts +1 -1
- package/dist/components/features/activities/partials/activities-feed-card.d.ts.map +1 -1
- package/dist/components/features/activities/partials/activity-actions-menu.d.ts +1 -1
- package/dist/components/features/activities/partials/activity-actions-menu.d.ts.map +1 -1
- package/dist/components/features/activities/partials/activity-changes.d.ts +1 -1
- package/dist/components/features/activities/partials/activity-changes.d.ts.map +1 -1
- package/dist/components/features/activities/partials/activity-date-label.d.ts +1 -1
- package/dist/components/features/activities/partials/activity-date-label.d.ts.map +1 -1
- package/dist/components/features/activities/partials/activity-empty-state.d.ts +1 -1
- package/dist/components/features/activities/partials/activity-empty-state.d.ts.map +1 -1
- package/dist/components/features/activities/partials/activity-headline.d.ts +1 -1
- package/dist/components/features/activities/partials/activity-headline.d.ts.map +1 -1
- package/dist/components/features/activities/partials/activity-marker.d.ts +1 -1
- package/dist/components/features/activities/partials/activity-marker.d.ts.map +1 -1
- package/dist/components/features/activities/partials/activity-resource-tag.d.ts +1 -1
- package/dist/components/features/activities/partials/activity-resource-tag.d.ts.map +1 -1
- package/dist/components/features/activities/partials/activity-row.d.ts +1 -1
- package/dist/components/features/activities/partials/activity-row.d.ts.map +1 -1
- package/dist/components/features/ai-chat/ai-chat.d.ts +1 -1
- package/dist/components/features/ai-chat/ai-chat.d.ts.map +1 -1
- package/dist/components/features/ai-chat/index.cjs +1 -1
- package/dist/components/features/ai-chat/index.cjs.map +1 -1
- package/dist/components/features/ai-chat/index.js +7 -7
- package/dist/components/features/ai-chat/index.js.map +1 -1
- package/dist/components/features/ai-chat/partials/ai-chat-attachments-strip.d.ts +1 -1
- package/dist/components/features/ai-chat/partials/ai-chat-attachments-strip.d.ts.map +1 -1
- package/dist/components/features/ai-chat/partials/ai-chat-conversation.d.ts +1 -1
- package/dist/components/features/ai-chat/partials/ai-chat-conversation.d.ts.map +1 -1
- package/dist/components/features/ai-chat/partials/ai-chat-empty-state.d.ts +1 -1
- package/dist/components/features/ai-chat/partials/ai-chat-empty-state.d.ts.map +1 -1
- package/dist/components/features/ai-chat/partials/ai-chat-message.d.ts +1 -1
- package/dist/components/features/ai-chat/partials/ai-chat-message.d.ts.map +1 -1
- package/dist/components/features/ai-chat/partials/ai-chat-prompt-input.d.ts +1 -1
- package/dist/components/features/ai-chat/partials/ai-chat-prompt-input.d.ts.map +1 -1
- package/dist/components/features/ai-chat/partials/ai-chat-queue.d.ts +1 -1
- package/dist/components/features/ai-chat/partials/ai-chat-queue.d.ts.map +1 -1
- package/dist/components/features/ai-chat/partials/ai-chat-suggestions-row.d.ts +1 -1
- package/dist/components/features/ai-chat/partials/ai-chat-suggestions-row.d.ts.map +1 -1
- package/dist/components/features/card/booking-calendar-event-card.d.ts +1 -1
- package/dist/components/features/card/booking-calendar-event-card.d.ts.map +1 -1
- package/dist/components/features/card/index.cjs +1 -1
- package/dist/components/features/card/index.cjs.map +1 -1
- package/dist/components/features/card/index.js +4 -4
- package/dist/components/features/card/index.js.map +1 -1
- package/dist/components/features/card/partials/default-shared-resource-partials.d.ts +4 -4
- package/dist/components/features/card/partials/default-shared-resource-partials.d.ts.map +1 -1
- package/dist/components/features/card/shared-resource-card.d.ts +1 -1
- package/dist/components/features/card/shared-resource-card.d.ts.map +1 -1
- package/dist/components/features/comments/comments.d.ts +1 -1
- package/dist/components/features/comments/comments.d.ts.map +1 -1
- package/dist/components/features/comments/index.cjs +1 -1
- package/dist/components/features/comments/index.js +2 -2
- package/dist/components/features/comments/partials/comment-composer.d.ts.map +1 -1
- package/dist/components/features/event-log/event-log.d.ts +1 -1
- package/dist/components/features/event-log/event-log.d.ts.map +1 -1
- package/dist/components/features/event-log/index.cjs +1 -1
- package/dist/components/features/event-log/index.cjs.map +1 -1
- package/dist/components/features/event-log/index.js +5 -5
- package/dist/components/features/event-log/index.js.map +1 -1
- package/dist/components/features/filters/facets/async-select-facet.d.ts +1 -1
- package/dist/components/features/filters/facets/async-select-facet.d.ts.map +1 -1
- package/dist/components/features/filters/facets/date-facet.d.ts +1 -1
- package/dist/components/features/filters/facets/date-facet.d.ts.map +1 -1
- package/dist/components/features/filters/facets/range-facet.d.ts +1 -1
- package/dist/components/features/filters/facets/range-facet.d.ts.map +1 -1
- package/dist/components/features/filters/facets/search-facet.d.ts +1 -1
- package/dist/components/features/filters/facets/search-facet.d.ts.map +1 -1
- package/dist/components/features/filters/facets/select-facet.d.ts +1 -1
- package/dist/components/features/filters/facets/select-facet.d.ts.map +1 -1
- package/dist/components/features/filters/facets/tags-facet.d.ts +1 -1
- package/dist/components/features/filters/facets/tags-facet.d.ts.map +1 -1
- package/dist/components/features/filters/filter-context.d.ts +1 -1
- package/dist/components/features/filters/filter-context.d.ts.map +1 -1
- package/dist/components/features/filters/filter-layout.d.ts +1 -1
- package/dist/components/features/filters/filter-layout.d.ts.map +1 -1
- package/dist/components/features/filters/filters.strings.d.ts +1 -0
- package/dist/components/features/filters/filters.strings.d.ts.map +1 -1
- package/dist/components/features/filters/filters.types.d.ts +1 -1
- package/dist/components/features/filters/index.cjs +1 -1
- package/dist/components/features/filters/index.cjs.map +1 -1
- package/dist/components/features/filters/index.js +195 -188
- package/dist/components/features/filters/index.js.map +1 -1
- package/dist/components/features/filters/partials/active-filter-item.d.ts +2 -1
- package/dist/components/features/filters/partials/active-filter-item.d.ts.map +1 -1
- package/dist/components/features/filters/partials/async-filter-content.d.ts +1 -1
- package/dist/components/features/filters/partials/async-filter-content.d.ts.map +1 -1
- package/dist/components/features/filters/partials/date-filter-content.d.ts +1 -1
- package/dist/components/features/filters/partials/date-filter-content.d.ts.map +1 -1
- package/dist/components/features/filters/partials/filter-error-boundary.d.ts +1 -1
- package/dist/components/features/filters/partials/filter-error-boundary.d.ts.map +1 -1
- package/dist/components/features/filters/partials/filter-list-content.d.ts +1 -1
- package/dist/components/features/filters/partials/filter-list-content.d.ts.map +1 -1
- package/dist/components/features/filters/partials/filter-list-item.d.ts +1 -1
- package/dist/components/features/filters/partials/filter-list-item.d.ts.map +1 -1
- package/dist/components/features/filters/partials/filter-operator-select.d.ts +2 -1
- package/dist/components/features/filters/partials/filter-operator-select.d.ts.map +1 -1
- package/dist/components/features/filters/partials/filter-pill.d.ts +1 -1
- package/dist/components/features/filters/partials/filter-pill.d.ts.map +1 -1
- package/dist/components/features/filters/partials/filter-popover-content.d.ts +1 -1
- package/dist/components/features/filters/partials/filter-popover-content.d.ts.map +1 -1
- package/dist/components/features/filters/partials/filter-tabs.d.ts +1 -1
- package/dist/components/features/filters/partials/filter-tabs.d.ts.map +1 -1
- package/dist/components/features/filters/partials/filter-value-display.d.ts +1 -1
- package/dist/components/features/filters/partials/filter-value-display.d.ts.map +1 -1
- package/dist/components/features/filters/partials/filters-button.d.ts +1 -1
- package/dist/components/features/filters/partials/filters-button.d.ts.map +1 -1
- package/dist/components/features/filters/partials/regular-filter-content.d.ts +1 -1
- package/dist/components/features/filters/partials/regular-filter-content.d.ts.map +1 -1
- package/dist/components/features/filters/partials/search-filters-list.d.ts +1 -1
- package/dist/components/features/filters/partials/search-filters-list.d.ts.map +1 -1
- package/dist/components/features/filters/partials/tags-filter-content.d.ts +1 -1
- package/dist/components/features/filters/partials/tags-filter-content.d.ts.map +1 -1
- package/dist/components/features/global-search/global-search.d.ts +22 -1
- package/dist/components/features/global-search/global-search.d.ts.map +1 -1
- package/dist/components/features/global-search/index.cjs +1 -1
- package/dist/components/features/global-search/index.cjs.map +1 -1
- package/dist/components/features/global-search/index.js +3 -3
- package/dist/components/features/global-search/index.js.map +1 -1
- package/dist/components/features/global-search/partials/global-search-empty-state.d.ts +1 -1
- package/dist/components/features/global-search/partials/global-search-empty-state.d.ts.map +1 -1
- package/dist/components/features/global-search/partials/global-search-footer.d.ts +1 -1
- package/dist/components/features/global-search/partials/global-search-footer.d.ts.map +1 -1
- package/dist/components/features/global-search/partials/global-search-idle-state.d.ts +1 -1
- package/dist/components/features/global-search/partials/global-search-idle-state.d.ts.map +1 -1
- package/dist/components/features/global-search/partials/global-search-result-row.d.ts +2 -1
- package/dist/components/features/global-search/partials/global-search-result-row.d.ts.map +1 -1
- package/dist/components/features/global-search/partials/global-search-tabs.d.ts +1 -1
- package/dist/components/features/global-search/partials/global-search-tabs.d.ts.map +1 -1
- package/dist/components/features/kanban/index.cjs +1 -1
- package/dist/components/features/kanban/index.cjs.map +1 -1
- package/dist/components/features/kanban/index.js +2 -2
- package/dist/components/features/kanban/index.js.map +1 -1
- package/dist/components/features/kanban/kanban.d.ts +7 -7
- package/dist/components/features/kanban/kanban.d.ts.map +1 -1
- package/dist/components/features/mentions/index.cjs +1 -1
- package/dist/components/features/mentions/index.js +1 -1
- package/dist/components/features/mentions/partials/mention-inline-suggestions.d.ts +1 -1
- package/dist/components/features/mentions/partials/mention-inline-suggestions.d.ts.map +1 -1
- package/dist/components/features/mentions/partials/mention-picker.d.ts +1 -1
- package/dist/components/features/mentions/partials/mention-picker.d.ts.map +1 -1
- package/dist/components/features/overlays/alert-dialog.d.ts +1 -1
- package/dist/components/features/overlays/alert-dialog.d.ts.map +1 -1
- package/dist/components/features/overlays/dialog.d.ts +1 -1
- package/dist/components/features/overlays/dialog.d.ts.map +1 -1
- package/dist/components/features/overlays/drawer.d.ts +1 -1
- package/dist/components/features/overlays/drawer.d.ts.map +1 -1
- package/dist/components/features/overlays/index.cjs +1 -1
- package/dist/components/features/overlays/index.js +1 -1
- package/dist/components/features/rich-text-editor/form-rich-text-editor.d.ts +1 -1
- package/dist/components/features/rich-text-editor/form-rich-text-editor.d.ts.map +1 -1
- package/dist/components/features/rich-text-editor/index.cjs +1 -1
- package/dist/components/features/rich-text-editor/index.cjs.map +1 -1
- package/dist/components/features/rich-text-editor/index.js +1 -1
- package/dist/components/features/rich-text-editor/index.js.map +1 -1
- package/dist/components/features/rich-text-editor/partials/counts-footer.d.ts +2 -2
- package/dist/components/features/rich-text-editor/partials/counts-footer.d.ts.map +1 -1
- package/dist/components/features/rich-text-editor/partials/rich-text-editor-fallback.d.ts.map +1 -1
- package/dist/components/features/rich-text-editor/partials/rich-text-editor-tiptap.d.ts.map +1 -1
- package/dist/components/features/rich-text-editor/partials/rich-text-editor-toolbar.d.ts +1 -1
- package/dist/components/features/rich-text-editor/partials/rich-text-editor-toolbar.d.ts.map +1 -1
- package/dist/components/features/rich-text-editor/rich-text-editor.strings.d.ts +4 -0
- package/dist/components/features/rich-text-editor/rich-text-editor.strings.d.ts.map +1 -1
- package/dist/components/features/suggestions/index.cjs +1 -1
- package/dist/components/features/suggestions/index.cjs.map +1 -1
- package/dist/components/features/suggestions/index.js +1 -1
- package/dist/components/features/suggestions/index.js.map +1 -1
- package/dist/components/features/suggestions/suggestions.d.ts +1 -1
- package/dist/components/features/suggestions/suggestions.d.ts.map +1 -1
- package/dist/components/features/sync/index.cjs +1 -1
- package/dist/components/features/sync/index.cjs.map +1 -1
- package/dist/components/features/sync/index.js +3 -3
- package/dist/components/features/sync/index.js.map +1 -1
- package/dist/components/features/sync/sync-range-dialog-form.d.ts +1 -1
- package/dist/components/layout/app-shell/app-shell.types.d.ts +65 -0
- package/dist/components/layout/app-shell/app-shell.types.d.ts.map +1 -0
- package/dist/components/layout/app-shell/index.cjs +1 -0
- package/dist/components/layout/app-shell/index.d.ts +3 -0
- package/dist/components/layout/app-shell/index.d.ts.map +1 -0
- package/dist/components/layout/app-shell/index.js +2 -0
- package/dist/components/layout/app-shell/topbar-sidebar-layout.d.ts +3 -0
- package/dist/components/layout/app-shell/topbar-sidebar-layout.d.ts.map +1 -0
- package/dist/components/layout/containers/content-container.d.ts +1 -1
- package/dist/components/layout/containers/content-container.d.ts.map +1 -1
- package/dist/components/layout/containers/index.cjs +1 -1
- package/dist/components/layout/containers/index.js +2 -2
- package/dist/components/layout/containers/section.d.ts +1 -1
- package/dist/components/layout/containers/section.d.ts.map +1 -1
- package/dist/components/layout/header/header.d.ts +1 -1
- package/dist/components/layout/header/header.d.ts.map +1 -1
- package/dist/components/layout/header/index.cjs +1 -1
- package/dist/components/layout/header/index.js +1 -1
- package/dist/components/layout/header/partials/header-breadcrumbs.d.ts +3 -1
- package/dist/components/layout/header/partials/header-breadcrumbs.d.ts.map +1 -1
- package/dist/components/layout/header/partials/header-notifications.d.ts +1 -1
- package/dist/components/layout/header/partials/header-notifications.d.ts.map +1 -1
- package/dist/components/layout/header/partials/header-search.d.ts +1 -1
- package/dist/components/layout/header/partials/header-search.d.ts.map +1 -1
- package/dist/components/layout/header/partials/header-user-menu.d.ts +1 -1
- package/dist/components/layout/header/partials/header-user-menu.d.ts.map +1 -1
- package/dist/components/layout/hooks/index.cjs +1 -1
- package/dist/components/layout/hooks/index.js +1 -1
- package/dist/components/layout/index.cjs +1 -1
- package/dist/components/layout/index.d.ts +1 -0
- package/dist/components/layout/index.d.ts.map +1 -1
- package/dist/components/layout/index.js +8 -7
- package/dist/components/layout/page/index.cjs +1 -1
- package/dist/components/layout/page/index.js +1 -1
- package/dist/components/layout/page/page-content.d.ts +1 -1
- package/dist/components/layout/page/page-content.d.ts.map +1 -1
- package/dist/components/layout/page/page.d.ts +1 -1
- package/dist/components/layout/page/page.d.ts.map +1 -1
- package/dist/components/layout/page/partials/page-actions.d.ts +1 -1
- package/dist/components/layout/page/partials/page-actions.d.ts.map +1 -1
- package/dist/components/layout/page/partials/page-header.d.ts +1 -1
- package/dist/components/layout/page/partials/page-header.d.ts.map +1 -1
- package/dist/components/layout/sidebar/app-sidebar.d.ts +6 -1
- package/dist/components/layout/sidebar/app-sidebar.d.ts.map +1 -1
- package/dist/components/layout/sidebar/components/sidebar-grouped-navigation.d.ts +1 -1
- package/dist/components/layout/sidebar/components/sidebar-grouped-navigation.d.ts.map +1 -1
- package/dist/components/layout/sidebar/components/sidebar-logo.d.ts +1 -1
- package/dist/components/layout/sidebar/components/sidebar-logo.d.ts.map +1 -1
- package/dist/components/layout/sidebar/components/sidebar-navigation-footer.d.ts +1 -1
- package/dist/components/layout/sidebar/components/sidebar-navigation-footer.d.ts.map +1 -1
- package/dist/components/layout/sidebar/components/sidebar-navigation-user.d.ts +1 -1
- package/dist/components/layout/sidebar/components/sidebar-navigation-user.d.ts.map +1 -1
- package/dist/components/layout/sidebar/components/sidebar-navigation.d.ts +3 -1
- package/dist/components/layout/sidebar/components/sidebar-navigation.d.ts.map +1 -1
- package/dist/components/layout/sidebar/components/sidebar-workspace-dropdown.d.ts +1 -1
- package/dist/components/layout/sidebar/components/sidebar-workspace-dropdown.d.ts.map +1 -1
- package/dist/components/layout/sidebar/index.cjs +1 -1
- package/dist/components/layout/sidebar/index.js +2 -2
- package/dist/components/layout/sidebar/sidebar.context.d.ts +1 -1
- package/dist/components/layout/sidebar/sidebar.context.d.ts.map +1 -1
- package/dist/components/layout/sidebar/sidebar.d.ts +1 -1
- package/dist/components/layout/sidebar/sidebar.d.ts.map +1 -1
- package/dist/components/layout/sidebar/sidebar.utils.d.ts +2 -2
- package/dist/components/layout/sidebar/sidebar.utils.d.ts.map +1 -1
- package/dist/components/typography/heading.d.ts +1 -1
- package/dist/components/typography/heading.d.ts.map +1 -1
- package/dist/components/typography/index.cjs +1 -1
- package/dist/components/typography/index.js +3 -3
- package/dist/components/typography/label.d.ts +1 -1
- package/dist/components/typography/label.d.ts.map +1 -1
- package/dist/components/typography/text-link.d.ts +1 -1
- package/dist/components/typography/text-link.d.ts.map +1 -1
- package/dist/components/typography/text.d.ts +1 -1
- package/dist/components/typography/text.d.ts.map +1 -1
- package/dist/components/typography/typography.d.ts +3 -3
- package/dist/components/typography/typography.d.ts.map +1 -1
- package/dist/components/ui/accordion.d.ts +4 -4
- package/dist/components/ui/accordion.d.ts.map +1 -1
- package/dist/components/ui/alert.d.ts +4 -4
- package/dist/components/ui/alert.d.ts.map +1 -1
- package/dist/components/ui/avatar.d.ts +6 -6
- package/dist/components/ui/avatar.d.ts.map +1 -1
- package/dist/components/ui/badge.d.ts +1 -1
- package/dist/components/ui/badge.d.ts.map +1 -1
- package/dist/components/ui/breadcrumb.d.ts +7 -7
- package/dist/components/ui/breadcrumb.d.ts.map +1 -1
- package/dist/components/ui/button-group.d.ts +2 -2
- package/dist/components/ui/button-group.d.ts.map +1 -1
- package/dist/components/ui/button.d.ts +1 -1
- package/dist/components/ui/button.d.ts.map +1 -1
- package/dist/components/ui/calendar.d.ts +2 -2
- package/dist/components/ui/calendar.d.ts.map +1 -1
- package/dist/components/ui/card.d.ts +7 -7
- package/dist/components/ui/card.d.ts.map +1 -1
- package/dist/components/ui/chart.d.ts +4 -4
- package/dist/components/ui/chart.d.ts.map +1 -1
- package/dist/components/ui/checkbox.d.ts +1 -1
- package/dist/components/ui/checkbox.d.ts.map +1 -1
- package/dist/components/ui/collapsible.d.ts +4 -3
- package/dist/components/ui/collapsible.d.ts.map +1 -1
- package/dist/components/ui/combobox.d.ts +20 -20
- package/dist/components/ui/combobox.d.ts.map +1 -1
- package/dist/components/ui/command.d.ts +9 -9
- package/dist/components/ui/command.d.ts.map +1 -1
- package/dist/components/ui/context-menu.d.ts +15 -15
- package/dist/components/ui/context-menu.d.ts.map +1 -1
- package/dist/components/ui/dialog.d.ts +10 -10
- package/dist/components/ui/dialog.d.ts.map +1 -1
- package/dist/components/ui/dropdown-menu.d.ts +16 -16
- package/dist/components/ui/dropdown-menu.d.ts.map +1 -1
- package/dist/components/ui/empty.d.ts +6 -6
- package/dist/components/ui/empty.d.ts.map +1 -1
- package/dist/components/ui/hover-card.d.ts +3 -3
- package/dist/components/ui/hover-card.d.ts.map +1 -1
- package/dist/components/ui/input-group.d.ts +6 -6
- package/dist/components/ui/input-group.d.ts.map +1 -1
- package/dist/components/ui/input.d.ts +1 -1
- package/dist/components/ui/input.d.ts.map +1 -1
- package/dist/components/ui/item.d.ts +9 -9
- package/dist/components/ui/item.d.ts.map +1 -1
- package/dist/components/ui/pagination.d.ts +7 -7
- package/dist/components/ui/pagination.d.ts.map +1 -1
- package/dist/components/ui/popover.d.ts +7 -7
- package/dist/components/ui/popover.d.ts.map +1 -1
- package/dist/components/ui/progress.d.ts +5 -5
- package/dist/components/ui/progress.d.ts.map +1 -1
- package/dist/components/ui/radio-group.d.ts +2 -2
- package/dist/components/ui/radio-group.d.ts.map +1 -1
- package/dist/components/ui/scroll-area.d.ts +2 -2
- package/dist/components/ui/scroll-area.d.ts.map +1 -1
- package/dist/components/ui/select.d.ts +9 -9
- package/dist/components/ui/select.d.ts.map +1 -1
- package/dist/components/ui/separator.d.ts +1 -1
- package/dist/components/ui/separator.d.ts.map +1 -1
- package/dist/components/ui/sheet.d.ts +8 -8
- package/dist/components/ui/sheet.d.ts.map +1 -1
- package/dist/components/ui/sidebar.d.ts +19 -19
- package/dist/components/ui/sidebar.d.ts.map +1 -1
- package/dist/components/ui/skeleton.d.ts +1 -1
- package/dist/components/ui/skeleton.d.ts.map +1 -1
- package/dist/components/ui/slider.d.ts +2 -1
- package/dist/components/ui/slider.d.ts.map +1 -1
- package/dist/components/ui/sonner.d.ts +1 -1
- package/dist/components/ui/sonner.d.ts.map +1 -1
- package/dist/components/ui/spinner.d.ts +1 -1
- package/dist/components/ui/spinner.d.ts.map +1 -1
- package/dist/components/ui/switch.d.ts +1 -1
- package/dist/components/ui/switch.d.ts.map +1 -1
- package/dist/components/ui/table.d.ts +8 -8
- package/dist/components/ui/table.d.ts.map +1 -1
- package/dist/components/ui/tabs.d.ts +4 -4
- package/dist/components/ui/tabs.d.ts.map +1 -1
- package/dist/components/ui/textarea.d.ts +1 -1
- package/dist/components/ui/textarea.d.ts.map +1 -1
- package/dist/components/ui/toggle-group.d.ts +3 -2
- package/dist/components/ui/toggle-group.d.ts.map +1 -1
- package/dist/components/ui/toggle.d.ts +1 -1
- package/dist/components/ui/toggle.d.ts.map +1 -1
- package/dist/components/ui/tooltip.d.ts +4 -4
- package/dist/components/ui/tooltip.d.ts.map +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.js +1 -1
- package/dist/lib/strings.cjs +1 -1
- package/dist/lib/strings.cjs.map +1 -1
- package/dist/lib/strings.js.map +1 -1
- package/dist/lib/ui-provider/index.cjs +1 -1
- package/dist/lib/ui-provider/index.js +1 -1
- package/dist/lib/ui-provider/provider.d.ts +1 -1
- package/dist/lib/ui-provider/provider.d.ts.map +1 -1
- package/dist/lib/utils.cjs +1 -1
- package/dist/lib/utils.cjs.map +1 -1
- package/dist/lib/utils.js.map +1 -1
- package/dist/showcase/assets/AreaChart-CzBEYPbz.js +6 -0
- package/dist/showcase/assets/CSPContext-ImKusJJ_.js +1 -0
- package/dist/showcase/assets/CompositeItem-C-DIOBdJ.js +1 -0
- package/dist/showcase/assets/CompositeRoot-Ce4ORgG2.js +1 -0
- package/dist/showcase/assets/Control.FullScreen-CwLQ1MMK.js +1 -0
- package/dist/showcase/assets/DialogTrigger-DWvMs7dp.js +1 -0
- package/dist/showcase/assets/FormContext-BeC1MJpT.js +1 -0
- package/dist/showcase/assets/PreviewLayout-N1PTTyZK.js +1 -0
- package/dist/showcase/assets/RadioGroup-DAWaa26D.js +1 -0
- package/dist/showcase/assets/Separator-guDkmky0.js +1 -0
- package/dist/showcase/assets/ToolbarRootContext-BJ7hWga8.js +1 -0
- package/dist/showcase/assets/accordion-CiM9WhkT.js +172 -0
- package/dist/showcase/assets/accordion-variants-C_sHrQ7C.js +1 -0
- package/dist/showcase/assets/action-menu-mlWlGE5P.js +1 -0
- package/dist/showcase/assets/activities-YWR4wh4f.js +501 -0
- package/dist/showcase/assets/activities-feed-card-Cglnf5as.js +1 -0
- package/dist/showcase/assets/admin-BtOtzPd4.js +80 -0
- package/dist/showcase/assets/ai-8iNe0R1M.js +41 -0
- package/dist/showcase/assets/ai-artifact-CQL5krnJ.js +2 -0
- package/dist/showcase/assets/ai-chat-BzCdOOc6.js +568 -0
- package/dist/showcase/assets/ai-elements-CBHy2xWU.js +379 -0
- package/dist/showcase/assets/ai-new-CgL5NeVs.js +167 -0
- package/dist/showcase/assets/ai-tool-call-D9AsaWJF.js +1 -0
- package/dist/showcase/assets/alert-B2BuF4vZ.js +59 -0
- package/dist/showcase/assets/alert-BkVaTONJ.js +1 -0
- package/dist/showcase/assets/api-key-list-C-_59dli.js +73 -0
- package/dist/showcase/assets/app-sidebar-BdOu5rVn.js +1 -0
- package/dist/showcase/assets/arrow-down-BpVaq9-H.js +1 -0
- package/dist/showcase/assets/arrow-left-C40rxfqj.js +1 -0
- package/dist/showcase/assets/arrow-right-BclouSfP.js +1 -0
- package/dist/showcase/assets/arrow-up-BpWEnkdX.js +1 -0
- package/dist/showcase/assets/arrow-up-right-Z5sMa1HH.js +1 -0
- package/dist/showcase/assets/avatar-CDNhh3rv.js +57 -0
- package/dist/showcase/assets/avatar-QBwg3fvR.js +1 -0
- package/dist/showcase/assets/badge-check-DXDQ3SaL.js +1 -0
- package/dist/showcase/assets/badge-tAdYt--9.js +28 -0
- package/dist/showcase/assets/bell-CVEeEWw4.js +1 -0
- package/dist/showcase/assets/bot-Bcx5mNAQ.js +1 -0
- package/dist/showcase/assets/box-Dgy2Xc70.js +1 -0
- package/dist/showcase/assets/brain-DsoOsd7m.js +1 -0
- package/dist/showcase/assets/brand-DAyuXNUz.js +40 -0
- package/dist/showcase/assets/breadcrumb-CC4Z8eMY.js +1 -0
- package/dist/showcase/assets/breadcrumb-DCbAzeMs.js +52 -0
- package/dist/showcase/assets/breadcrumbs-DGZMpIoQ.js +1 -0
- package/dist/showcase/assets/briefcase-2uLXCvAZ.js +1 -0
- package/dist/showcase/assets/button-DhQ6rMPU.js +44 -0
- package/dist/showcase/assets/button-group-Ce9vnZ1H.js +1 -0
- package/dist/showcase/assets/buttons-CHja0LUL.js +270 -0
- package/dist/showcase/assets/calendar-BbiK8AMZ.js +16 -0
- package/dist/showcase/assets/calendar-BhZpIjCo.js +1 -0
- package/dist/showcase/assets/calendar-oKaDsUIy.js +1 -0
- package/dist/showcase/assets/card-DoU1VD79.js +1 -0
- package/dist/showcase/assets/cards-3OgH8m3F.js +328 -0
- package/dist/showcase/assets/chart-column-6Tn3WAT9.js +1 -0
- package/dist/showcase/assets/chevron-down-x7TQsvYY.js +1 -0
- package/dist/showcase/assets/chevron-left-CglzJgA2.js +1 -0
- package/dist/showcase/assets/chevron-right-CDDMIkYP.js +1 -0
- package/dist/showcase/assets/chevron-up-Dc3aAaGH.js +1 -0
- package/dist/showcase/assets/chevrons-up-down-DJNnSBAj.js +1 -0
- package/dist/showcase/assets/circle-BBmNFtO8.js +1 -0
- package/dist/showcase/assets/circle-alert-DJevf3tT.js +1 -0
- package/dist/showcase/assets/circle-check-BCxORlAM.js +1 -0
- package/dist/showcase/assets/circle-check-big-tiuK2w0-.js +1 -0
- package/dist/showcase/assets/circle-dot-BEVVQjgN.js +1 -0
- package/dist/showcase/assets/circle-question-mark-BQrUUiKD.js +1 -0
- package/dist/showcase/assets/circle-x-CoV_AUtZ.js +1 -0
- package/dist/showcase/assets/clock-Bn2R4aDX.js +1 -0
- package/dist/showcase/assets/code-xml-BVYp_JDX.js +1 -0
- package/dist/showcase/assets/collapsible-Co2Y739_.js +27 -0
- package/dist/showcase/assets/collapsible-DPbftgrO.js +1 -0
- package/dist/showcase/assets/combobox-Cm4__LnJ.js +622 -0
- package/dist/showcase/assets/command-DQFIxPN9.js +45 -0
- package/dist/showcase/assets/command-KNncGgZW.js +1 -0
- package/dist/showcase/assets/comment-composer-DTJtqYGP.js +1 -0
- package/dist/showcase/assets/comment-item-DIEYMmV_.js +1 -0
- package/dist/showcase/assets/comments-B0BbDp-3.js +357 -0
- package/dist/showcase/assets/commerce-BOWBCLA-.js +79 -0
- package/dist/showcase/assets/commerce-extras-C6CWYfpC.js +173 -0
- package/dist/showcase/assets/composite-YicTVAO0.js +1 -0
- package/dist/showcase/assets/contact-card-DQPRIlnJ.js +65 -0
- package/dist/showcase/assets/content-container-CHXwWViz.js +1 -0
- package/dist/showcase/assets/copyable-CjTwco9O.js +96 -0
- package/dist/showcase/assets/course-card-CTQScd2C.js +113 -0
- package/dist/showcase/assets/cpu-D52NjUWq.js +1 -0
- package/dist/showcase/assets/credit-card-BoDfW0R8.js +1 -0
- package/dist/showcase/assets/currency-BPREbpDA.js +149 -0
- package/dist/showcase/assets/dark-surfaces-BCG45K2m.js +90 -0
- package/dist/showcase/assets/database-DeGR0hed.js +1 -0
- package/dist/showcase/assets/date-block-Bl1kXJrM.js +1 -0
- package/dist/showcase/assets/date-picker-BHbZa4ML.js +1 -0
- package/dist/showcase/assets/date-pickers-DumwUEXE.js +110 -0
- package/dist/showcase/assets/dense-info-DxfgBw9Z.js +106 -0
- package/dist/showcase/assets/dialog-BYHZvlL8.js +1 -0
- package/dist/showcase/assets/display-BXMGOjL3.js +392 -0
- package/dist/showcase/assets/dist-CnonIdcR.js +1 -0
- package/dist/showcase/assets/dollar-sign-BipUTVXC.js +1 -0
- package/dist/showcase/assets/download-CxspQgIc.js +1 -0
- package/dist/showcase/assets/dropdown-menu-Q1BV3wPP.js +1 -0
- package/dist/showcase/assets/dropzone-OivkuTPF.js +1 -0
- package/dist/showcase/assets/ellipsis-Bn-XgoA7.js +1 -0
- package/dist/showcase/assets/ellipsis-vertical-Bcl9HX9k.js +1 -0
- package/dist/showcase/assets/empty-CcafLcw-.js +1 -0
- package/dist/showcase/assets/empty-item-CiJeS8ZV.js +49 -0
- package/dist/showcase/assets/empty-state-B1RYYjUP.js +188 -0
- package/dist/showcase/assets/enhanced-activities-IB811DS6.js +361 -0
- package/dist/showcase/assets/esm-CAF_uoYd.js +2 -0
- package/dist/showcase/assets/event-calendar-C2VCfcUz.js +138 -0
- package/dist/showcase/assets/event-log-ckmsCPmG.js +330 -0
- package/dist/showcase/assets/example-C6-_Sy6B.js +1 -0
- package/dist/showcase/assets/external-link-Bg-_8Uq7.js +1 -0
- package/dist/showcase/assets/eye-JVsUA85G.js +1 -0
- package/dist/showcase/assets/feature-announcement-C4aRXesF.js +34 -0
- package/dist/showcase/assets/fetchers-DHuMQ6PN.js +1 -0
- package/dist/showcase/assets/file-4pOq58jl.js +1 -0
- package/dist/showcase/assets/file-text-BIi71mZ1.js +1 -0
- package/dist/showcase/assets/filters-CxrcnmLU.js +78 -0
- package/dist/showcase/assets/flag-DeiJmomk.js +1 -0
- package/dist/showcase/assets/folder-open-zMXBpVNs.js +1 -0
- package/dist/showcase/assets/form-sizing-B8jbL5tL.js +1 -0
- package/dist/showcase/assets/format-BG4laCmp.js +1 -0
- package/dist/showcase/assets/format-metric-value-B94EDo8X.js +1 -0
- package/dist/showcase/assets/forms-PsN5zTLx.js +793 -0
- package/dist/showcase/assets/generic-BH5YLC_H.js +1 -0
- package/dist/showcase/assets/getPseudoElementBounds-B7wr19E1.js +1 -0
- package/dist/showcase/assets/gift-CKFIh1Wh.js +1 -0
- package/dist/showcase/assets/giftcard-cards-BfOlIHmA.js +85 -0
- package/dist/showcase/assets/git-branch-BO9i8XkJ.js +1 -0
- package/dist/showcase/assets/global-search-CNmUraNa.js +90 -0
- package/dist/showcase/assets/global-search-DkJkQ0Vs.js +1 -0
- package/dist/showcase/assets/globe-47T22W56.js +1 -0
- package/dist/showcase/assets/gradient-card-CXSY29TZ.js +58 -0
- package/dist/showcase/assets/header-eZHN-s6P.js +1 -0
- package/dist/showcase/assets/header-notifications-Caa9i87J.js +1 -0
- package/dist/showcase/assets/heart-DjKkkUsX.js +1 -0
- package/dist/showcase/assets/house-DKxCiHyB.js +1 -0
- package/dist/showcase/assets/icon-badge-Bcm8TlJi.js +1 -0
- package/dist/showcase/assets/image-r-gMI33G.js +1 -0
- package/dist/showcase/assets/inbox-ZxSy1pgX.js +1 -0
- package/dist/showcase/assets/index-B8DVXCmf.js +10 -0
- package/dist/showcase/assets/index-DbLs6mcj.css +2 -0
- package/dist/showcase/assets/inertValue-i0cAMG-0.js +1 -0
- package/dist/showcase/assets/info-B1KV2DkO.js +1 -0
- package/dist/showcase/assets/inline-stat-D0sE-A4C.js +1 -0
- package/dist/showcase/assets/input-25epjsiD.js +1 -0
- package/dist/showcase/assets/input-CnwMt9Sr.js +1 -0
- package/dist/showcase/assets/input-group-DSKyV7we.js +47 -0
- package/dist/showcase/assets/input-group-x5eWeAZg.js +1 -0
- package/dist/showcase/assets/inputs-B2Maxr14.js +49 -0
- package/dist/showcase/assets/invoice-header-Gxl--yFu.js +36 -0
- package/dist/showcase/assets/invoice-items-BtoaGNjE.js +36 -0
- package/dist/showcase/assets/invoice-mini-DHFSZegy.js +14 -0
- package/dist/showcase/assets/invoice-table-6dmU_KrL.js +30 -0
- package/dist/showcase/assets/isSameDay-BrDHfKHm.js +1 -0
- package/dist/showcase/assets/isToday-VtoSc1IH.js +1 -0
- package/dist/showcase/assets/italic-CXkAsf6H.js +1 -0
- package/dist/showcase/assets/item-CGOThKAx.js +1 -0
- package/dist/showcase/assets/item-CMRbW6s-.js +1 -0
- package/dist/showcase/assets/item-sw6fAZcn.js +117 -0
- package/dist/showcase/assets/kanban-CKGYTXji.js +175 -0
- package/dist/showcase/assets/label-BmKD22pm.js +1 -0
- package/dist/showcase/assets/layout-app-shell-CeMHzVNn.js +501 -0
- package/dist/showcase/assets/layout-containers-8Drow5f9.js +96 -0
- package/dist/showcase/assets/layout-header-BlBw4JAV.js +170 -0
- package/dist/showcase/assets/layout-page-BQfgHFau.js +122 -0
- package/dist/showcase/assets/layout-sidebar-DZer5Uuh.js +224 -0
- package/dist/showcase/assets/layout-users-nuioUkeu.js +104 -0
- package/dist/showcase/assets/leaflet-src-S_KZeH2q.js +1 -0
- package/dist/showcase/assets/lib-DMGme4uo.js +1 -0
- package/dist/showcase/assets/lock-DQcZ9cEj.js +1 -0
- package/dist/showcase/assets/mail-yNXDtmNr.js +1 -0
- package/dist/showcase/assets/map-JMM1F9VR.js +124 -0
- package/dist/showcase/assets/map-pin-2WS7oVo3.js +1 -0
- package/dist/showcase/assets/menus-mK-FeNki.js +89 -0
- package/dist/showcase/assets/message-square-DGTAjNJG.js +1 -0
- package/dist/showcase/assets/metadata-list-CBxuQjVO.js +278 -0
- package/dist/showcase/assets/metric-BWGrmyD6.js +1 -0
- package/dist/showcase/assets/metric-grid-CewIJQvo.js +1 -0
- package/dist/showcase/assets/metric-trend-chip-kLBN8u5z.js +1 -0
- package/dist/showcase/assets/metrics-analytics-bar-COnc7VN9.js +44 -0
- package/dist/showcase/assets/metrics-analytics-cards-BR83UVqi.js +77 -0
- package/dist/showcase/assets/metrics-comparison-C0SUjdMg.js +76 -0
- package/dist/showcase/assets/metrics-heatmap-Orq1hLk-.js +27 -0
- package/dist/showcase/assets/metrics-inline-badge-C924q2Xx.js +17 -0
- package/dist/showcase/assets/metrics-kpi-row-Cwi05ruK.js +31 -0
- package/dist/showcase/assets/metrics-micro-grid-D97nkrge.js +42 -0
- package/dist/showcase/assets/metrics-overview-BOc8y3QX.js +192 -0
- package/dist/showcase/assets/metrics-stat-cards-Cilh-A5D.js +54 -0
- package/dist/showcase/assets/minus-DvrDGcTv.js +1 -0
- package/dist/showcase/assets/money-display-0egZ_O76.js +1 -0
- package/dist/showcase/assets/month-year-picker-2cWfwnmP.js +1 -0
- package/dist/showcase/assets/navigation-BnYme-Wj.js +90 -0
- package/dist/showcase/assets/navigation-CLQWl32A.js +230 -0
- package/dist/showcase/assets/navigation-extras-BPDoAdXF.js +43 -0
- package/dist/showcase/assets/onboarding-checklist-26XVWgDF.js +119 -0
- package/dist/showcase/assets/overlays-2sVGhanu.js +88 -0
- package/dist/showcase/assets/overlays-BaR6HDwB.js +394 -0
- package/dist/showcase/assets/package-CUNvdlBi.js +1 -0
- package/dist/showcase/assets/page-action-button-DgvZVtzx.js +1 -0
- package/dist/showcase/assets/page-header-4F_iaFPW.js +1 -0
- package/dist/showcase/assets/pagination-CDjZ6jiZ.js +42 -0
- package/dist/showcase/assets/pagination-g1NQaN42.js +1 -0
- package/dist/showcase/assets/paperclip-CDxdf8Os.js +1 -0
- package/dist/showcase/assets/pencil-Ddc5JwBe.js +1 -0
- package/dist/showcase/assets/phone-NIZ5SwgK.js +1 -0
- package/dist/showcase/assets/plus-C9kwz7rW.js +1 -0
- package/dist/showcase/assets/popover-DtnuOBgr.js +1 -0
- package/dist/showcase/assets/popover-T85aV4zW.js +1 -0
- package/dist/showcase/assets/popover-menu-BRGSZe4f.js +1 -0
- package/dist/showcase/assets/progress-CcZjuzK3.js +1 -0
- package/dist/showcase/assets/progress-DbouniUl.js +18 -0
- package/dist/showcase/assets/props-table-CM_1cocj.js +1 -0
- package/dist/showcase/assets/props.generated-Bg627Jai.json +32829 -0
- package/dist/showcase/assets/quote-vjygm2-7.js +1 -0
- package/dist/showcase/assets/react-dom-Bz4cALsF.js +1 -0
- package/dist/showcase/assets/receipt-CfMgwFPl.js +1 -0
- package/dist/showcase/assets/refresh-cw-Tu5E_cGA.js +1 -0
- package/dist/showcase/assets/resolveValueLabel-CipUZh6i.js +1 -0
- package/dist/showcase/assets/rich-text-editor-BMZUyuQX.js +143 -0
- package/dist/showcase/assets/rich-text-editor-HwYIeWYW.js +124 -0
- package/dist/showcase/assets/rotate-ccw-B4Wi4ws7.js +1 -0
- package/dist/showcase/assets/scroll-area-CuB_woqF.js +1 -0
- package/dist/showcase/assets/scroll-area-I4mSIpRq.js +32 -0
- package/dist/showcase/assets/select-CF3cKjCo.js +1 -0
- package/dist/showcase/assets/send-Blu_n6xl.js +1 -0
- package/dist/showcase/assets/separator-9mrRf_DZ.js +28 -0
- package/dist/showcase/assets/separator-DUKleOvU.js +1 -0
- package/dist/showcase/assets/settings-DlKX-bZT.js +1 -0
- package/dist/showcase/assets/sheet-CwcLVoF3.js +1 -0
- package/dist/showcase/assets/shield-BD0Y8Jj3.js +1 -0
- package/dist/showcase/assets/shield-alert-DNOTmkwG.js +1 -0
- package/dist/showcase/assets/shield-check-Sbul0dUK.js +1 -0
- package/dist/showcase/assets/shopping-bag-EDVpxI9n.js +1 -0
- package/dist/showcase/assets/sidebar-JWZ88xw5.js +1 -0
- package/dist/showcase/assets/sidebar.context-D3P7qppn.js +1 -0
- package/dist/showcase/assets/skeleton-CIS1Kaas.js +1 -0
- package/dist/showcase/assets/skeleton-CJCJDQFt.js +29 -0
- package/dist/showcase/assets/smart-card-7szg_qSt.js +1 -0
- package/dist/showcase/assets/sonner-DMHXr9Ce.js +22 -0
- package/dist/showcase/assets/sortable.esm-DVuzVA1U.js +5 -0
- package/dist/showcase/assets/sparkles-BEa1AgNq.js +1 -0
- package/dist/showcase/assets/spinner-Bi-T9etI.js +30 -0
- package/dist/showcase/assets/spinner-C77XIUVf.js +1 -0
- package/dist/showcase/assets/spinner-DK9BAT6K.js +49 -0
- package/dist/showcase/assets/square-pen-N0mq-vPu.js +1 -0
- package/dist/showcase/assets/stacked-avatars-DORVEni2.js +1 -0
- package/dist/showcase/assets/star-Dbtxr60S.js +1 -0
- package/dist/showcase/assets/startOfDay-BJgxz4yq.js +1 -0
- package/dist/showcase/assets/styles-CwW4IBUg.js +1 -0
- package/dist/showcase/assets/switch-B4iRxZFU.js +1 -0
- package/dist/showcase/assets/switch-B_rnbXwy.js +1 -0
- package/dist/showcase/assets/table-BJ9HSK6H.js +1 -0
- package/dist/showcase/assets/table-IB0MEYf4.js +389 -0
- package/dist/showcase/assets/tabs-D02JL-Fa.js +1 -0
- package/dist/showcase/assets/tabs-XpsVS3ff.js +19 -0
- package/dist/showcase/assets/text-button-BWCgXGnr.js +1 -0
- package/dist/showcase/assets/text-link-TzuDnSCF.js +1 -0
- package/dist/showcase/assets/textarea-B7DUIiH_.js +1 -0
- package/dist/showcase/assets/textarea-CV5gNzXf.js +1 -0
- package/dist/showcase/assets/timelines-CF0UYhwm.js +200 -0
- package/dist/showcase/assets/toggle-group-CK8mBx6E.js +1 -0
- package/dist/showcase/assets/toggles-CqJSApnF.js +71 -0
- package/dist/showcase/assets/toggles-group-v0JijMzG.js +32 -0
- package/dist/showcase/assets/trash-2-_xF5j-Ya.js +1 -0
- package/dist/showcase/assets/trending-up-BCzmjYzm.js +1 -0
- package/dist/showcase/assets/truck-CryH-5dx.js +1 -0
- package/dist/showcase/assets/typography-D3PFbRpb.js +215 -0
- package/dist/showcase/assets/ui-badge-ByyFPLOB.js +28 -0
- package/dist/showcase/assets/ui-card-DYLLiD89.js +30 -0
- package/dist/showcase/assets/ui-table-DW4QIwxK.js +42 -0
- package/dist/showcase/assets/upload-tray-ZdL_dzc0.js +138 -0
- package/dist/showcase/assets/useAnchoredPopupScrollLock-AFPLx3SZ.js +1 -0
- package/dist/showcase/assets/useCollapsiblePanel-CeHRY8U2.js +1 -0
- package/dist/showcase/assets/useCompositeItem-C-1zP8zD.js +1 -0
- package/dist/showcase/assets/useCompositeListItem-D4ugfKLB.js +1 -0
- package/dist/showcase/assets/useControlled-Cpg8gDqb.js +1 -0
- package/dist/showcase/assets/useLabelableId-CSxAHpU-.js +1 -0
- package/dist/showcase/assets/useOpenInteractionType-BLV8Pa2n.js +1 -0
- package/dist/showcase/assets/useRender-DparzvOu.js +1 -0
- package/dist/showcase/assets/useTriggerFocusGuards-CrYLO2g5.js +1 -0
- package/dist/showcase/assets/useValueChanged-DwgbaueK.js +1 -0
- package/dist/showcase/assets/user-CGcV8Ppb.js +1 -0
- package/dist/showcase/assets/user-plus-iOsntM6P.js +1 -0
- package/dist/showcase/assets/users-DzgXeZbf.js +1 -0
- package/dist/showcase/assets/vendor-profile-DbFPkGn9.js +37 -0
- package/dist/showcase/assets/wrench-1Ra9xb3d.js +1 -0
- package/dist/showcase/assets/x-CE8oevyh.js +1 -0
- package/dist/showcase/assets/zap-se3n2YVD.js +1 -0
- package/dist/showcase/index.html +4 -3
- package/dist/style.css +2 -2
- package/package.json +14 -3
- package/scripts/audit-consumer.mjs +337 -0
- package/scripts/install-skill.mjs +50 -36
- package/src/App.css +28 -0
- package/dist/_shared/accordion-CztqyaIN.js +0 -130
- package/dist/_shared/accordion-CztqyaIN.js.map +0 -1
- package/dist/_shared/accordion-D5uTCLCB.cjs +0 -2
- package/dist/_shared/accordion-D5uTCLCB.cjs.map +0 -1
- package/dist/_shared/action-menu-Yrj6VzFS.js +0 -96
- package/dist/_shared/action-menu-Yrj6VzFS.js.map +0 -1
- package/dist/_shared/action-menu-eVP8GGlv.cjs +0 -2
- package/dist/_shared/action-menu-eVP8GGlv.cjs.map +0 -1
- package/dist/_shared/ai-artifact-DaHXJTKg.cjs +0 -3
- package/dist/_shared/ai-artifact-DaHXJTKg.cjs.map +0 -1
- package/dist/_shared/ai-artifact-DyLn3JAs.js +0 -1068
- package/dist/_shared/ai-artifact-DyLn3JAs.js.map +0 -1
- package/dist/_shared/alert-BVw4Mq6H.js +0 -48
- package/dist/_shared/alert-BVw4Mq6H.js.map +0 -1
- package/dist/_shared/alert-DXSlR9ja.cjs +0 -2
- package/dist/_shared/alert-DXSlR9ja.cjs.map +0 -1
- package/dist/_shared/avatar-CpBz9pTv.js +0 -52
- package/dist/_shared/avatar-CpBz9pTv.js.map +0 -1
- package/dist/_shared/avatar-dg20YFFs.cjs +0 -2
- package/dist/_shared/avatar-dg20YFFs.cjs.map +0 -1
- package/dist/_shared/badge-BVCh_hfL.js +0 -108
- package/dist/_shared/badge-BVCh_hfL.js.map +0 -1
- package/dist/_shared/badge-C49SSz-6.cjs +0 -2
- package/dist/_shared/badge-C49SSz-6.cjs.map +0 -1
- package/dist/_shared/breadcrumbs-Bo7j5Rhv.cjs +0 -2
- package/dist/_shared/breadcrumbs-Bo7j5Rhv.cjs.map +0 -1
- package/dist/_shared/breadcrumbs-Dc93fqqE.js +0 -111
- package/dist/_shared/breadcrumbs-Dc93fqqE.js.map +0 -1
- package/dist/_shared/button-2xglT7yf.cjs +0 -2
- package/dist/_shared/button-2xglT7yf.cjs.map +0 -1
- package/dist/_shared/button-ChCkwoOD.js +0 -176
- package/dist/_shared/button-ChCkwoOD.js.map +0 -1
- package/dist/_shared/button-D0nF99a9.cjs +0 -2
- package/dist/_shared/button-D0nF99a9.cjs.map +0 -1
- package/dist/_shared/button-DBR4QI9E.js +0 -46
- package/dist/_shared/button-DBR4QI9E.js.map +0 -1
- package/dist/_shared/buttons-Bcnt1md_.js +0 -143
- package/dist/_shared/buttons-Bcnt1md_.js.map +0 -1
- package/dist/_shared/buttons-km9xqXJv.cjs +0 -2
- package/dist/_shared/buttons-km9xqXJv.cjs.map +0 -1
- package/dist/_shared/card-radio-group-BGH93O5-.js +0 -158
- package/dist/_shared/card-radio-group-BGH93O5-.js.map +0 -1
- package/dist/_shared/card-radio-group-Vq741uhL.cjs +0 -2
- package/dist/_shared/card-radio-group-Vq741uhL.cjs.map +0 -1
- package/dist/_shared/chunk-D3uCBrYO.cjs +0 -1
- package/dist/_shared/combobox-BgXAxjU2.js +0 -746
- package/dist/_shared/combobox-BgXAxjU2.js.map +0 -1
- package/dist/_shared/combobox-DuIyh3xJ.cjs +0 -2
- package/dist/_shared/combobox-DuIyh3xJ.cjs.map +0 -1
- package/dist/_shared/command-BbiijN61.js +0 -39
- package/dist/_shared/command-BbiijN61.js.map +0 -1
- package/dist/_shared/command-D7zTvyBJ.cjs +0 -2
- package/dist/_shared/command-D7zTvyBJ.cjs.map +0 -1
- package/dist/_shared/command-DGNtTI-V.cjs +0 -2
- package/dist/_shared/command-DGNtTI-V.cjs.map +0 -1
- package/dist/_shared/command-jKbwFRtS.js +0 -123
- package/dist/_shared/command-jKbwFRtS.js.map +0 -1
- package/dist/_shared/comments-CNUsdwGW.cjs +0 -2
- package/dist/_shared/comments-CNUsdwGW.cjs.map +0 -1
- package/dist/_shared/comments-CvmS7zG3.js +0 -945
- package/dist/_shared/comments-CvmS7zG3.js.map +0 -1
- package/dist/_shared/containers-BFDv7cCV.cjs +0 -2
- package/dist/_shared/containers-BFDv7cCV.cjs.map +0 -1
- package/dist/_shared/containers-C1-A_2PT.js +0 -19
- package/dist/_shared/containers-C1-A_2PT.js.map +0 -1
- package/dist/_shared/content-container-CwqFnaI0.cjs +0 -2
- package/dist/_shared/content-container-CwqFnaI0.cjs.map +0 -1
- package/dist/_shared/content-container-D_3JGBSc.js +0 -33
- package/dist/_shared/content-container-D_3JGBSc.js.map +0 -1
- package/dist/_shared/copyable-CHhCGMfW.js +0 -38
- package/dist/_shared/copyable-CHhCGMfW.js.map +0 -1
- package/dist/_shared/copyable-ndaiocYq.cjs +0 -2
- package/dist/_shared/copyable-ndaiocYq.cjs.map +0 -1
- package/dist/_shared/date-picker-B8O_qbik.js +0 -1353
- package/dist/_shared/date-picker-B8O_qbik.js.map +0 -1
- package/dist/_shared/date-picker-BnOjyuKS.cjs +0 -2
- package/dist/_shared/date-picker-BnOjyuKS.cjs.map +0 -1
- package/dist/_shared/date-pickers-Cas9cPlj.js +0 -330
- package/dist/_shared/date-pickers-Cas9cPlj.js.map +0 -1
- package/dist/_shared/date-pickers-Dk-G3RMy.cjs +0 -2
- package/dist/_shared/date-pickers-Dk-G3RMy.cjs.map +0 -1
- package/dist/_shared/dialog-67GmkMLC.js +0 -101
- package/dist/_shared/dialog-67GmkMLC.js.map +0 -1
- package/dist/_shared/dialog-BF_4uAhE.cjs +0 -2
- package/dist/_shared/dialog-BF_4uAhE.cjs.map +0 -1
- package/dist/_shared/display-B9xVWboG.cjs +0 -8
- package/dist/_shared/display-B9xVWboG.cjs.map +0 -1
- package/dist/_shared/display-BM_GxDAo.js +0 -1237
- package/dist/_shared/display-BM_GxDAo.js.map +0 -1
- package/dist/_shared/dropdown-menu-4nxEBMnd.js +0 -147
- package/dist/_shared/dropdown-menu-4nxEBMnd.js.map +0 -1
- package/dist/_shared/dropdown-menu-DZlWHqWS.cjs +0 -2
- package/dist/_shared/dropdown-menu-DZlWHqWS.cjs.map +0 -1
- package/dist/_shared/form-field-BQlki-8s.js +0 -319
- package/dist/_shared/form-field-BQlki-8s.js.map +0 -1
- package/dist/_shared/form-field-DzpwVS99.cjs +0 -2
- package/dist/_shared/form-field-DzpwVS99.cjs.map +0 -1
- package/dist/_shared/form-sizing-CcbB-OHF.js +0 -21
- package/dist/_shared/form-sizing-CcbB-OHF.js.map +0 -1
- package/dist/_shared/form-sizing-Cw12UeI6.cjs +0 -2
- package/dist/_shared/form-sizing-Cw12UeI6.cjs.map +0 -1
- package/dist/_shared/format-B2AdSQVn.cjs +0 -2
- package/dist/_shared/format-B2AdSQVn.cjs.map +0 -1
- package/dist/_shared/format-CP65h1vK.js +0 -48
- package/dist/_shared/format-CP65h1vK.js.map +0 -1
- package/dist/_shared/forms-B8aaNG44.cjs +0 -2
- package/dist/_shared/forms-B8aaNG44.cjs.map +0 -1
- package/dist/_shared/forms-BusuTZZ2.js +0 -3374
- package/dist/_shared/forms-BusuTZZ2.js.map +0 -1
- package/dist/_shared/header-DWfOUjFL.cjs +0 -2
- package/dist/_shared/header-DWfOUjFL.cjs.map +0 -1
- package/dist/_shared/header-KpdoLtP9.js +0 -369
- package/dist/_shared/header-KpdoLtP9.js.map +0 -1
- package/dist/_shared/heading-BprqyzDs.js +0 -39
- package/dist/_shared/heading-BprqyzDs.js.map +0 -1
- package/dist/_shared/heading-mZc_jan1.cjs +0 -2
- package/dist/_shared/heading-mZc_jan1.cjs.map +0 -1
- package/dist/_shared/hooks-C-uWoRq5.cjs +0 -2
- package/dist/_shared/hooks-C-uWoRq5.cjs.map +0 -1
- package/dist/_shared/hooks-D5HJtvvP.js +0 -118
- package/dist/_shared/hooks-D5HJtvvP.js.map +0 -1
- package/dist/_shared/icon-badge-BBqDyAUz.cjs +0 -2
- package/dist/_shared/icon-badge-BBqDyAUz.cjs.map +0 -1
- package/dist/_shared/icon-badge-Bi63T-bj.js +0 -52
- package/dist/_shared/icon-badge-Bi63T-bj.js.map +0 -1
- package/dist/_shared/input-B2YXTHqz.cjs +0 -2
- package/dist/_shared/input-B2YXTHqz.cjs.map +0 -1
- package/dist/_shared/input-BJb10xb9.cjs +0 -2
- package/dist/_shared/input-BJb10xb9.cjs.map +0 -1
- package/dist/_shared/input-CZxP5Xgj.js +0 -17
- package/dist/_shared/input-CZxP5Xgj.js.map +0 -1
- package/dist/_shared/input-DQahu2sm.js +0 -182
- package/dist/_shared/input-DQahu2sm.js.map +0 -1
- package/dist/_shared/item-Cu5JbZyZ.js +0 -224
- package/dist/_shared/item-Cu5JbZyZ.js.map +0 -1
- package/dist/_shared/item-Cx_7QZ2o.cjs +0 -2
- package/dist/_shared/item-Cx_7QZ2o.cjs.map +0 -1
- package/dist/_shared/mentions-CS3rIhze.js +0 -493
- package/dist/_shared/mentions-CS3rIhze.js.map +0 -1
- package/dist/_shared/mentions-D7gnP3Nf.cjs +0 -2
- package/dist/_shared/mentions-D7gnP3Nf.cjs.map +0 -1
- package/dist/_shared/metadata-CRsVWE8Y.cjs +0 -2
- package/dist/_shared/metadata-CRsVWE8Y.cjs.map +0 -1
- package/dist/_shared/metadata-CfG0FdFZ.js +0 -236
- package/dist/_shared/metadata-CfG0FdFZ.js.map +0 -1
- package/dist/_shared/money-display-Bd0rkjc9.js +0 -198
- package/dist/_shared/money-display-Bd0rkjc9.js.map +0 -1
- package/dist/_shared/money-display-DSFft9Mi.cjs +0 -2
- package/dist/_shared/money-display-DSFft9Mi.cjs.map +0 -1
- package/dist/_shared/navigation-Do9k5Xh1.js +0 -420
- package/dist/_shared/navigation-Do9k5Xh1.js.map +0 -1
- package/dist/_shared/navigation-QAAD3HJd.cjs +0 -2
- package/dist/_shared/navigation-QAAD3HJd.cjs.map +0 -1
- package/dist/_shared/overlays-B8AH8fNv.js +0 -633
- package/dist/_shared/overlays-B8AH8fNv.js.map +0 -1
- package/dist/_shared/overlays-DOcoRy8k.cjs +0 -2
- package/dist/_shared/overlays-DOcoRy8k.cjs.map +0 -1
- package/dist/_shared/page-BPCeKX9X.js +0 -263
- package/dist/_shared/page-BPCeKX9X.js.map +0 -1
- package/dist/_shared/page-DMM32sxi.cjs +0 -2
- package/dist/_shared/page-DMM32sxi.cjs.map +0 -1
- package/dist/_shared/popover-B1f_EUQS.cjs +0 -2
- package/dist/_shared/popover-B1f_EUQS.cjs.map +0 -1
- package/dist/_shared/popover-CgRGcFk9.js +0 -83
- package/dist/_shared/popover-CgRGcFk9.js.map +0 -1
- package/dist/_shared/popover-menu-BEKIT3LR.cjs +0 -2
- package/dist/_shared/popover-menu-BEKIT3LR.cjs.map +0 -1
- package/dist/_shared/popover-menu-BHdHLEVL.js +0 -95
- package/dist/_shared/popover-menu-BHdHLEVL.js.map +0 -1
- package/dist/_shared/rich-text-editor-0uoIoYXU.js +0 -608
- package/dist/_shared/rich-text-editor-0uoIoYXU.js.map +0 -1
- package/dist/_shared/rich-text-editor-wTiARGuB.cjs +0 -2
- package/dist/_shared/rich-text-editor-wTiARGuB.cjs.map +0 -1
- package/dist/_shared/scroll-area-Bo17wtZD.cjs +0 -2
- package/dist/_shared/scroll-area-Bo17wtZD.cjs.map +0 -1
- package/dist/_shared/scroll-area-Cj-hmB5D.js +0 -41
- package/dist/_shared/scroll-area-Cj-hmB5D.js.map +0 -1
- package/dist/_shared/select-07RRiTWc.js +0 -85
- package/dist/_shared/select-07RRiTWc.js.map +0 -1
- package/dist/_shared/select-BfiU7a4n.cjs +0 -2
- package/dist/_shared/select-BfiU7a4n.cjs.map +0 -1
- package/dist/_shared/separator-CN9zAJfs.cjs +0 -2
- package/dist/_shared/separator-CN9zAJfs.cjs.map +0 -1
- package/dist/_shared/separator-DR0uUMKa.js +0 -16
- package/dist/_shared/separator-DR0uUMKa.js.map +0 -1
- package/dist/_shared/sheet-B5FoGJAZ.cjs +0 -2
- package/dist/_shared/sheet-B5FoGJAZ.cjs.map +0 -1
- package/dist/_shared/sheet-cUI8cypP.js +0 -100
- package/dist/_shared/sheet-cUI8cypP.js.map +0 -1
- package/dist/_shared/sidebar-Bq7yKLrG.cjs +0 -2
- package/dist/_shared/sidebar-Bq7yKLrG.cjs.map +0 -1
- package/dist/_shared/sidebar-Da20tCUc.cjs +0 -2
- package/dist/_shared/sidebar-Da20tCUc.cjs.map +0 -1
- package/dist/_shared/sidebar-Q6TYE8Ux.js +0 -371
- package/dist/_shared/sidebar-Q6TYE8Ux.js.map +0 -1
- package/dist/_shared/sidebar-WmnQ55YY.js +0 -537
- package/dist/_shared/sidebar-WmnQ55YY.js.map +0 -1
- package/dist/_shared/skeleton-B3HWEc6G.js +0 -14
- package/dist/_shared/skeleton-B3HWEc6G.js.map +0 -1
- package/dist/_shared/skeleton-Cz_l8-fc.cjs +0 -2
- package/dist/_shared/skeleton-Cz_l8-fc.cjs.map +0 -1
- package/dist/_shared/slot-BgnZtKR5.js +0 -18
- package/dist/_shared/slot-BgnZtKR5.js.map +0 -1
- package/dist/_shared/slot-Dac1ipUC.cjs +0 -2
- package/dist/_shared/slot-Dac1ipUC.cjs.map +0 -1
- package/dist/_shared/smart-card-Bm_VxYUG.cjs +0 -2
- package/dist/_shared/smart-card-Bm_VxYUG.cjs.map +0 -1
- package/dist/_shared/smart-card-MT6JjkoI.js +0 -360
- package/dist/_shared/smart-card-MT6JjkoI.js.map +0 -1
- package/dist/_shared/spinner-BQjxJ_Kx.js +0 -67
- package/dist/_shared/spinner-BQjxJ_Kx.js.map +0 -1
- package/dist/_shared/spinner-Dvaa6GUm.cjs +0 -2
- package/dist/_shared/spinner-Dvaa6GUm.cjs.map +0 -1
- package/dist/_shared/switch-C0yyhsXZ.js +0 -51
- package/dist/_shared/switch-C0yyhsXZ.js.map +0 -1
- package/dist/_shared/switch-DozkSQNn.cjs +0 -2
- package/dist/_shared/switch-DozkSQNn.cjs.map +0 -1
- package/dist/_shared/text-DBnY6fcL.cjs +0 -2
- package/dist/_shared/text-DBnY6fcL.cjs.map +0 -1
- package/dist/_shared/text-DIxMTECE.js +0 -74
- package/dist/_shared/text-DIxMTECE.js.map +0 -1
- package/dist/_shared/textarea-Cgl-FPwu.js +0 -119
- package/dist/_shared/textarea-Cgl-FPwu.js.map +0 -1
- package/dist/_shared/textarea-D8wC0XlZ.cjs +0 -2
- package/dist/_shared/textarea-D8wC0XlZ.cjs.map +0 -1
- package/dist/_shared/tooltip-Cws4BiPT.js +0 -49
- package/dist/_shared/tooltip-Cws4BiPT.js.map +0 -1
- package/dist/_shared/tooltip-DyUi-Tac.cjs +0 -2
- package/dist/_shared/tooltip-DyUi-Tac.cjs.map +0 -1
- package/dist/_shared/typography-BW7iZBx7.cjs +0 -2
- package/dist/_shared/typography-BW7iZBx7.cjs.map +0 -1
- package/dist/_shared/typography-a3hydyvI.js +0 -102
- package/dist/_shared/typography-a3hydyvI.js.map +0 -1
- package/dist/_shared/ui-provider-4qKSKMPd.js +0 -85
- package/dist/_shared/ui-provider-4qKSKMPd.js.map +0 -1
- package/dist/_shared/ui-provider-uiQgATj1.cjs +0 -2
- package/dist/_shared/ui-provider-uiQgATj1.cjs.map +0 -1
- package/dist/showcase/assets/AreaChart-CJ57G5Ub.js +0 -6
- package/dist/showcase/assets/CSPContext-BA7DfnCI.js +0 -1
- package/dist/showcase/assets/CompositeItem-PwzgE4va.js +0 -1
- package/dist/showcase/assets/CompositeRoot-Du4CMlK7.js +0 -1
- package/dist/showcase/assets/Control.FullScreen-B9vseC57.js +0 -1
- package/dist/showcase/assets/DialogTrigger-FkENgwo6.js +0 -1
- package/dist/showcase/assets/FormContext-ChygLayp.js +0 -1
- package/dist/showcase/assets/PreviewLayout-z6vpJJGt.js +0 -1
- package/dist/showcase/assets/RadioGroup-CcDmbxOw.js +0 -1
- package/dist/showcase/assets/Separator-Dk4eN76U.js +0 -1
- package/dist/showcase/assets/ToolbarRootContext-D_KAA5hZ.js +0 -1
- package/dist/showcase/assets/accordion-dQszzfmw.js +0 -172
- package/dist/showcase/assets/accordion-variants-Dp4wxic-.js +0 -1
- package/dist/showcase/assets/action-menu-CBi2Eiy0.js +0 -1
- package/dist/showcase/assets/activities-DoXsgP4G.js +0 -501
- package/dist/showcase/assets/activities-feed-card-xz5FtkOm.js +0 -1
- package/dist/showcase/assets/admin-CxklUqAG.js +0 -80
- package/dist/showcase/assets/ai-artifact-DkhUdEbM.js +0 -2
- package/dist/showcase/assets/ai-chat-B6PuqkEu.js +0 -568
- package/dist/showcase/assets/ai-elements-D_rpj_ds.js +0 -379
- package/dist/showcase/assets/ai-new-CUPrAbOK.js +0 -167
- package/dist/showcase/assets/ai-tool-call-CEr-dGVx.js +0 -1
- package/dist/showcase/assets/ai-zxF_msJF.js +0 -41
- package/dist/showcase/assets/alert-771BE3Ny.js +0 -59
- package/dist/showcase/assets/alert-CG42DAlX.js +0 -1
- package/dist/showcase/assets/api-key-list-D6jUN7Fq.js +0 -73
- package/dist/showcase/assets/arrow-down-CUoXUyN1.js +0 -1
- package/dist/showcase/assets/arrow-left-Cdq69X6h.js +0 -1
- package/dist/showcase/assets/arrow-right-i25q9L2H.js +0 -1
- package/dist/showcase/assets/arrow-up-pnezegnF.js +0 -1
- package/dist/showcase/assets/arrow-up-right-CK3XnMah.js +0 -1
- package/dist/showcase/assets/avatar-LPmQqZQv.js +0 -1
- package/dist/showcase/assets/avatar-ZVFIQouy.js +0 -57
- package/dist/showcase/assets/badge-DK4bsgZC.js +0 -28
- package/dist/showcase/assets/badge-check-Cw5gkVcG.js +0 -1
- package/dist/showcase/assets/bell-BvJELoaV.js +0 -1
- package/dist/showcase/assets/bot-DRj6sdSR.js +0 -1
- package/dist/showcase/assets/box-BNND3M2m.js +0 -1
- package/dist/showcase/assets/brain-Cy3o-12l.js +0 -1
- package/dist/showcase/assets/brand-DvipEpFn.js +0 -40
- package/dist/showcase/assets/breadcrumb-B-LNuOyv.js +0 -1
- package/dist/showcase/assets/breadcrumb-Lzpc0yo4.js +0 -52
- package/dist/showcase/assets/breadcrumbs-DD6msKFZ.js +0 -1
- package/dist/showcase/assets/briefcase-LcAwoEmu.js +0 -1
- package/dist/showcase/assets/button-CuwcGzk1.js +0 -44
- package/dist/showcase/assets/button-group-CAImjDrl.js +0 -1
- package/dist/showcase/assets/buttons-DTjNHCMl.js +0 -259
- package/dist/showcase/assets/calendar-B1zW0q6I.js +0 -1
- package/dist/showcase/assets/calendar-Dlv72ytt.js +0 -1
- package/dist/showcase/assets/calendar-ls2A08Pn.js +0 -16
- package/dist/showcase/assets/card-BhtkM1BT.js +0 -1
- package/dist/showcase/assets/cards-BRpRXzGk.js +0 -328
- package/dist/showcase/assets/chart-column-BpQkEi1H.js +0 -1
- package/dist/showcase/assets/chevron-down-DyObdfSb.js +0 -1
- package/dist/showcase/assets/chevron-left-T7dHNxYM.js +0 -1
- package/dist/showcase/assets/chevron-right-D_EcqHpT.js +0 -1
- package/dist/showcase/assets/chevron-up-B38ivdGO.js +0 -1
- package/dist/showcase/assets/chevrons-up-down-SdRARzoq.js +0 -1
- package/dist/showcase/assets/circle-BrCPAmDA.js +0 -1
- package/dist/showcase/assets/circle-alert-DdhzLPY_.js +0 -1
- package/dist/showcase/assets/circle-check-DlA6zidQ.js +0 -1
- package/dist/showcase/assets/circle-check-big-DFGJANQF.js +0 -1
- package/dist/showcase/assets/circle-dot-BKmnVUqM.js +0 -1
- package/dist/showcase/assets/circle-question-mark-BNREvgVC.js +0 -1
- package/dist/showcase/assets/circle-x-C45QjHEs.js +0 -1
- package/dist/showcase/assets/clock-D1nKQzQo.js +0 -1
- package/dist/showcase/assets/code-xml-B8N3GRSu.js +0 -1
- package/dist/showcase/assets/collapsible-4TfcWyNs.js +0 -1
- package/dist/showcase/assets/collapsible-CKbZtvTj.js +0 -27
- package/dist/showcase/assets/combobox-DTdGPaU0.js +0 -622
- package/dist/showcase/assets/command-DymTXwL1.js +0 -1
- package/dist/showcase/assets/command-ksVIHQKJ.js +0 -45
- package/dist/showcase/assets/comment-composer-DC9oS1Yy.js +0 -1
- package/dist/showcase/assets/comment-item-CAmKnJa7.js +0 -1
- package/dist/showcase/assets/comments-Benk-2mV.js +0 -349
- package/dist/showcase/assets/commerce-Qz-mq8mQ.js +0 -78
- package/dist/showcase/assets/commerce-extras-CQRc3Bna.js +0 -179
- package/dist/showcase/assets/composite-DBDXLPyz.js +0 -1
- package/dist/showcase/assets/contact-card-DkL2nI3r.js +0 -65
- package/dist/showcase/assets/content-container-mRm6oJEa.js +0 -1
- package/dist/showcase/assets/copyable-DmLlmwzy.js +0 -96
- package/dist/showcase/assets/course-card-CJJoeZj9.js +0 -113
- package/dist/showcase/assets/cpu-BXJnF2Xy.js +0 -1
- package/dist/showcase/assets/credit-card-BQK3KKb2.js +0 -1
- package/dist/showcase/assets/currency-DBPUh8ee.js +0 -149
- package/dist/showcase/assets/dark-surfaces-LpPuIeYy.js +0 -90
- package/dist/showcase/assets/database-BZerpzGE.js +0 -1
- package/dist/showcase/assets/date-block-iiHUpbNX.js +0 -1
- package/dist/showcase/assets/date-picker-BQeBGL7T.js +0 -1
- package/dist/showcase/assets/date-pickers-CKcUEMMF.js +0 -110
- package/dist/showcase/assets/dense-info-DATmxRU8.js +0 -106
- package/dist/showcase/assets/dialog-Bqu5KDYH.js +0 -1
- package/dist/showcase/assets/display-Bj7uPXD4.js +0 -392
- package/dist/showcase/assets/dist-QK7JxeYv.js +0 -1
- package/dist/showcase/assets/dollar-sign-DFZs6vfz.js +0 -1
- package/dist/showcase/assets/download-5oGw_WbW.js +0 -1
- package/dist/showcase/assets/dropdown-menu-1CJgYn0S.js +0 -1
- package/dist/showcase/assets/dropzone-Co1uhsDn.js +0 -1
- package/dist/showcase/assets/ellipsis-cKRcvuyL.js +0 -1
- package/dist/showcase/assets/ellipsis-vertical-B1RErEkj.js +0 -1
- package/dist/showcase/assets/empty-Y2-4nCBr.js +0 -1
- package/dist/showcase/assets/empty-item-USa6xcUv.js +0 -49
- package/dist/showcase/assets/empty-state-DfhZ9AT5.js +0 -188
- package/dist/showcase/assets/enhanced-activities-DmAPVUSu.js +0 -359
- package/dist/showcase/assets/esm-BeGQ_ZTM.js +0 -2
- package/dist/showcase/assets/event-calendar-D-jGrrZS.js +0 -138
- package/dist/showcase/assets/event-log-tA_i4eR9.js +0 -326
- package/dist/showcase/assets/example-6phCHGsN.js +0 -1
- package/dist/showcase/assets/external-link-BuVHkCy0.js +0 -1
- package/dist/showcase/assets/eye-DC5HfGm6.js +0 -1
- package/dist/showcase/assets/feature-announcement-DwvxLytd.js +0 -34
- package/dist/showcase/assets/fetchers-SLCIqgnM.js +0 -1
- package/dist/showcase/assets/file-D-xM4vLy.js +0 -1
- package/dist/showcase/assets/file-text-tmG5vNbr.js +0 -1
- package/dist/showcase/assets/filters-CrGRXmq6.js +0 -78
- package/dist/showcase/assets/flag-CWrEtkY5.js +0 -1
- package/dist/showcase/assets/folder-open-Br-x1pjP.js +0 -1
- package/dist/showcase/assets/form-sizing-Bb5hiM45.js +0 -1
- package/dist/showcase/assets/format-D_ETCyg4.js +0 -1
- package/dist/showcase/assets/format-metric-value-cyOYS377.js +0 -1
- package/dist/showcase/assets/forms-B_MkQ3rm.js +0 -790
- package/dist/showcase/assets/generic-CdmsyXV3.js +0 -1
- package/dist/showcase/assets/getPseudoElementBounds-CZnCbCFP.js +0 -1
- package/dist/showcase/assets/gift-NkuklfU2.js +0 -1
- package/dist/showcase/assets/giftcard-cards-BAvevZ0i.js +0 -85
- package/dist/showcase/assets/git-branch-B_CBqPeO.js +0 -1
- package/dist/showcase/assets/global-search-D9teAbPe.js +0 -90
- package/dist/showcase/assets/globe-gzw45GU2.js +0 -1
- package/dist/showcase/assets/gradient-card-Xk2r7R5H.js +0 -58
- package/dist/showcase/assets/header-notifications-_aZCpE5A.js +0 -1
- package/dist/showcase/assets/heart-CEMKbRaZ.js +0 -1
- package/dist/showcase/assets/house-BlGXAcMH.js +0 -1
- package/dist/showcase/assets/icon-badge-z6N9reH_.js +0 -1
- package/dist/showcase/assets/image-B8mzmVBr.js +0 -1
- package/dist/showcase/assets/inbox-qdSnP4UV.js +0 -1
- package/dist/showcase/assets/index-B4ubXfly.js +0 -10
- package/dist/showcase/assets/index-Cu3Ssz5r.css +0 -2
- package/dist/showcase/assets/inertValue-D5Q8cLku.js +0 -1
- package/dist/showcase/assets/info-DBvvNjc_.js +0 -1
- package/dist/showcase/assets/inline-stat-Bm1zVT8D.js +0 -1
- package/dist/showcase/assets/input-CBQR0aeX.js +0 -1
- package/dist/showcase/assets/input-OrUzpI55.js +0 -1
- package/dist/showcase/assets/input-group-DhqOen2N.js +0 -47
- package/dist/showcase/assets/input-group-l8xa5nUq.js +0 -1
- package/dist/showcase/assets/inputs-DbiJ0qy2.js +0 -49
- package/dist/showcase/assets/invoice-header-C6youIbL.js +0 -36
- package/dist/showcase/assets/invoice-items-g6dgryF-.js +0 -36
- package/dist/showcase/assets/invoice-mini-0iWhufpt.js +0 -14
- package/dist/showcase/assets/invoice-table-Bvdh3rRq.js +0 -30
- package/dist/showcase/assets/isSameDay-BpZEtJe8.js +0 -1
- package/dist/showcase/assets/isToday-F0CS28oK.js +0 -1
- package/dist/showcase/assets/italic-CJOEwjdc.js +0 -1
- package/dist/showcase/assets/item-BiMm1PPB.js +0 -1
- package/dist/showcase/assets/item-CN0cwdj_.js +0 -1
- package/dist/showcase/assets/item-DNqEUYLT.js +0 -117
- package/dist/showcase/assets/kanban-DxePEUiQ.js +0 -175
- package/dist/showcase/assets/label-Dx4WO-fg.js +0 -1
- package/dist/showcase/assets/layout-containers-DDl8rG8S.js +0 -96
- package/dist/showcase/assets/layout-header-Bu6IcDWu.js +0 -170
- package/dist/showcase/assets/layout-page-D-88Qnoy.js +0 -122
- package/dist/showcase/assets/layout-sidebar-Ctft10pk.js +0 -224
- package/dist/showcase/assets/layout-users-DtbZduBG.js +0 -104
- package/dist/showcase/assets/leaflet-src-9EZQ14iG.js +0 -1
- package/dist/showcase/assets/lib-D9BoOYUd.js +0 -1
- package/dist/showcase/assets/lock-CHurDI0n.js +0 -1
- package/dist/showcase/assets/mail-DZ1o1RLW.js +0 -1
- package/dist/showcase/assets/map-C8xiyT9X.js +0 -124
- package/dist/showcase/assets/map-pin-CAKaoYod.js +0 -1
- package/dist/showcase/assets/menus-C6mnp636.js +0 -89
- package/dist/showcase/assets/message-square-Zo5J_zU1.js +0 -1
- package/dist/showcase/assets/metadata-list-W83-UMhc.js +0 -278
- package/dist/showcase/assets/metric-BSvxidIX.js +0 -1
- package/dist/showcase/assets/metric-grid-Dtqx_3Lg.js +0 -1
- package/dist/showcase/assets/metric-trend-chip-mtvcJ_M9.js +0 -1
- package/dist/showcase/assets/metrics-analytics-bar-DQbyss7i.js +0 -44
- package/dist/showcase/assets/metrics-analytics-cards-CEBu5Uw0.js +0 -77
- package/dist/showcase/assets/metrics-comparison-Bs-R6v4y.js +0 -76
- package/dist/showcase/assets/metrics-heatmap-BKHWH8sM.js +0 -27
- package/dist/showcase/assets/metrics-inline-badge-BxVn0Y2p.js +0 -17
- package/dist/showcase/assets/metrics-kpi-row-DtACYEds.js +0 -31
- package/dist/showcase/assets/metrics-micro-grid-BkwUGOUR.js +0 -42
- package/dist/showcase/assets/metrics-overview-BAtrlzsI.js +0 -192
- package/dist/showcase/assets/metrics-stat-cards-iCRCNyHY.js +0 -54
- package/dist/showcase/assets/minus-C6eBW-2t.js +0 -1
- package/dist/showcase/assets/money-display-DjGRJ16l.js +0 -1
- package/dist/showcase/assets/month-year-picker-DTDebPqf.js +0 -1
- package/dist/showcase/assets/navigation-BrG8Chig.js +0 -86
- package/dist/showcase/assets/navigation-CfXQJbyM.js +0 -230
- package/dist/showcase/assets/navigation-extras-D_gzLlZ5.js +0 -43
- package/dist/showcase/assets/onboarding-checklist-1EerUwAo.js +0 -119
- package/dist/showcase/assets/overlays-2AB9-S1Z.js +0 -88
- package/dist/showcase/assets/overlays-CYt9o3Xq.js +0 -393
- package/dist/showcase/assets/package-BJMP-Fcr.js +0 -1
- package/dist/showcase/assets/page-action-button-BZxJ0X1j.js +0 -1
- package/dist/showcase/assets/page-header-B_rqHJhe.js +0 -1
- package/dist/showcase/assets/pagination-BHiQvvka.js +0 -1
- package/dist/showcase/assets/pagination-Dq0GruQd.js +0 -42
- package/dist/showcase/assets/paperclip-BMYKrUQo.js +0 -1
- package/dist/showcase/assets/pencil-BJ3VS_FO.js +0 -1
- package/dist/showcase/assets/phone-CsRIyvep.js +0 -1
- package/dist/showcase/assets/plus-D2JuXYLg.js +0 -1
- package/dist/showcase/assets/popover-DNT9755r.js +0 -1
- package/dist/showcase/assets/popover-KvGgcPNg.js +0 -1
- package/dist/showcase/assets/popover-menu-CJx30R65.js +0 -1
- package/dist/showcase/assets/progress-B7WuXcJR.js +0 -1
- package/dist/showcase/assets/progress-CweCSAUv.js +0 -18
- package/dist/showcase/assets/props-table-uDY4eIzt.js +0 -1
- package/dist/showcase/assets/props.generated-BqPfiNI-.json +0 -32423
- package/dist/showcase/assets/quote-DAyyfzQd.js +0 -1
- package/dist/showcase/assets/receipt-C0mMZGbF.js +0 -1
- package/dist/showcase/assets/refresh-cw-X06JbXb-.js +0 -1
- package/dist/showcase/assets/resolveValueLabel-Bks7UDko.js +0 -1
- package/dist/showcase/assets/rich-text-editor-QJsb-qIe.js +0 -124
- package/dist/showcase/assets/rich-text-editor-h07VBNI9.js +0 -141
- package/dist/showcase/assets/rotate-ccw-D84bdX_x.js +0 -1
- package/dist/showcase/assets/scroll-area-0rT06pXZ.js +0 -1
- package/dist/showcase/assets/scroll-area-YXwdzGpN.js +0 -32
- package/dist/showcase/assets/select-BoWQDtUf.js +0 -1
- package/dist/showcase/assets/send-DJsk3cr1.js +0 -1
- package/dist/showcase/assets/separator-CLSnRcJa.js +0 -28
- package/dist/showcase/assets/separator-DWv-twD-.js +0 -1
- package/dist/showcase/assets/settings-Cb2MsAmN.js +0 -1
- package/dist/showcase/assets/sheet-Dn1-MYus.js +0 -1
- package/dist/showcase/assets/shield-DwLjF5ch.js +0 -1
- package/dist/showcase/assets/shield-alert-D8i6gzMK.js +0 -1
- package/dist/showcase/assets/shield-check-D5YRSBIz.js +0 -1
- package/dist/showcase/assets/shopping-bag-BqlAP4vn.js +0 -1
- package/dist/showcase/assets/sidebar.context-BAp_pBEB.js +0 -1
- package/dist/showcase/assets/skeleton-CeNPp4hr.js +0 -1
- package/dist/showcase/assets/skeleton-QPsnM_NR.js +0 -29
- package/dist/showcase/assets/smart-card-BisUbLPt.js +0 -1
- package/dist/showcase/assets/sonner-B7GzbBK2.js +0 -22
- package/dist/showcase/assets/sortable.esm-BDcEOHT7.js +0 -5
- package/dist/showcase/assets/sparkles-CF9P5Tqh.js +0 -1
- package/dist/showcase/assets/spinner-BeamEyJd.js +0 -49
- package/dist/showcase/assets/spinner-DoYBfalR.js +0 -1
- package/dist/showcase/assets/spinner-UsLsOYzn.js +0 -30
- package/dist/showcase/assets/square-pen-BGTVdnt1.js +0 -1
- package/dist/showcase/assets/stacked-avatars-BWfVX1Ov.js +0 -1
- package/dist/showcase/assets/star-NsPNO9gR.js +0 -1
- package/dist/showcase/assets/startOfDay-zJBpxLuW.js +0 -1
- package/dist/showcase/assets/styles-DA7a7hVy.js +0 -1
- package/dist/showcase/assets/switch-C62S4U2o.js +0 -1
- package/dist/showcase/assets/switch-CYQcinJZ.js +0 -1
- package/dist/showcase/assets/table-w4IABkpa.js +0 -1
- package/dist/showcase/assets/table-xgB63UrY.js +0 -390
- package/dist/showcase/assets/tabs-BFTEaTXj.js +0 -19
- package/dist/showcase/assets/tabs-oMJn9Ujq.js +0 -1
- package/dist/showcase/assets/text-button-BgcutPuu.js +0 -1
- package/dist/showcase/assets/text-link-CS9thOWL.js +0 -1
- package/dist/showcase/assets/textarea-BOBx4EM6.js +0 -1
- package/dist/showcase/assets/textarea-CTzYZZqa.js +0 -1
- package/dist/showcase/assets/timelines-CK07mEBK.js +0 -186
- package/dist/showcase/assets/toggle-group-CSPdPT6G.js +0 -1
- package/dist/showcase/assets/toggles-DDSdl-gA.js +0 -71
- package/dist/showcase/assets/toggles-group-Y2BdKEFB.js +0 -32
- package/dist/showcase/assets/trash-2-C-FAptQP.js +0 -1
- package/dist/showcase/assets/trending-up-BmLhdF_w.js +0 -1
- package/dist/showcase/assets/truck-pZdUS_as.js +0 -1
- package/dist/showcase/assets/typography-CnBH2z7f.js +0 -214
- package/dist/showcase/assets/ui-badge-Cl6INRO5.js +0 -28
- package/dist/showcase/assets/ui-card-B5P-thNu.js +0 -30
- package/dist/showcase/assets/ui-table-B32RILKk.js +0 -42
- package/dist/showcase/assets/upload-tray-mu6bR2ZE.js +0 -138
- package/dist/showcase/assets/useAnchoredPopupScrollLock-CzDaXxmM.js +0 -1
- package/dist/showcase/assets/useCollapsiblePanel-B0DZvDFu.js +0 -1
- package/dist/showcase/assets/useCompositeItem-BVIVLT9X.js +0 -1
- package/dist/showcase/assets/useCompositeListItem-JEMeTFPx.js +0 -1
- package/dist/showcase/assets/useControlled-ZjqBfPCn.js +0 -1
- package/dist/showcase/assets/useLabelableId-D8CZq8Bm.js +0 -1
- package/dist/showcase/assets/useOpenInteractionType-CopGCf3q.js +0 -1
- package/dist/showcase/assets/useRender-zuKv6JQF.js +0 -1
- package/dist/showcase/assets/useRole-08KeyiD3.js +0 -1
- package/dist/showcase/assets/useTriggerFocusGuards-DEuz5CGe.js +0 -1
- package/dist/showcase/assets/useValueChanged-BxFi_qyj.js +0 -1
- package/dist/showcase/assets/user-Bgc2t2_e.js +0 -1
- package/dist/showcase/assets/user-plus-F_TfagnP.js +0 -1
- package/dist/showcase/assets/users-B7G4yTCR.js +0 -1
- package/dist/showcase/assets/vendor-profile-BTQmsKM6.js +0 -37
- package/dist/showcase/assets/wrench-BdzICmjR.js +0 -1
- package/dist/showcase/assets/x-B156Wr-5.js +0 -1
- package/dist/showcase/assets/zap-B3iByjNV.js +0 -1
- /package/dist/showcase/assets/{analytics.strings-BcotPUad.js → analytics.strings-B9262Jmq.js} +0 -0
- /package/dist/showcase/assets/{chunk-CilyBKbf.js → chunk-QTnfLwEv.js} +0 -0
- /package/dist/showcase/assets/{customers-BETQwFRp.js → customers-DvBxRjHv.js} +0 -0
- /package/dist/showcase/assets/{format-DoQ4Wqkq.js → format-C_LjuBUs.js} +0 -0
- /package/dist/showcase/assets/{isElementDisabled-BLmk_uhf.js → isElementDisabled-KSuuBj8D.js} +0 -0
- /package/dist/showcase/assets/{leaflet.draw-CwFqqsDc.js → leaflet.draw-lpeKTWFs.js} +0 -0
- /package/dist/showcase/assets/{orders-DNn7r9k_.js → orders-BFwWtubb.js} +0 -0
- /package/dist/showcase/assets/{resolveAriaLabelledBy-DmY5COAB.js → resolveAriaLabelledBy-B6CR9UP2.js} +0 -0
- /package/dist/showcase/assets/{valueToPercent-CDF3aNnc.js → valueToPercent-B5BHWU68.js} +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.cjs","names":[],"sources":["../../../../src/components/composed/analytics/analytics.strings.ts","../../../../src/components/composed/analytics/format-metric-value.ts","../../../../src/components/composed/analytics/atoms/metric-trend-chip.tsx","../../../../src/components/composed/analytics/atoms/metric-sparkline.tsx","../../../../src/components/composed/analytics/atoms/metric-skeleton.tsx","../../../../src/components/composed/analytics/metric/metric.tsx","../../../../src/components/composed/analytics/metric-bar/metric-bar.tsx","../../../../src/components/composed/analytics/metric-grid/metric-grid.tsx","../../../../src/components/composed/analytics/metric-comparison/metric-comparison.tsx","../../../../src/components/composed/analytics/metric-micro-grid/metric-micro-grid.tsx","../../../../src/components/composed/analytics/metric-gradient/metric-gradient.tsx","../../../../src/components/composed/analytics/activity-heatmap/activity-heatmap.tsx"],"sourcesContent":["/**\n * Shared default strings for `composed/analytics` components.\n *\n * Each component accepts a `strings` prop deep-merged over these defaults\n * so consumers override per-component without touching the rest. Day/month\n * labels live here too because they're localisable in the same way.\n */\nexport interface AnalyticsStrings {\n /** Fallback shown by `<Metric />` when `error` is true. */\n metricErrorLabel: string;\n /** Default title for `<MetricComparison />` when no `title` prop is passed. */\n comparisonTitle: string;\n /** Labels for the activity heatmap weekday rows (Mon–Sun, length 7). */\n heatmapDayLabels: readonly [string, string, string, string, string, string, string];\n /** Short month names for the activity heatmap header (Jan–Dec, length 12). */\n heatmapMonthNames: readonly [\n string, string, string, string, string, string,\n string, string, string, string, string, string,\n ];\n /** Heatmap legend \"less\" label (left edge of intensity legend). */\n heatmapLegendLess: string;\n /** Heatmap legend \"more\" label (right edge of intensity legend). */\n heatmapLegendMore: string;\n}\n\nexport const defaultAnalyticsStrings: AnalyticsStrings = {\n metricErrorLabel: 'Unable to load metric',\n comparisonTitle: 'Comparison',\n heatmapDayLabels: ['Mon', '', 'Wed', '', 'Fri', '', ''],\n heatmapMonthNames: [\n 'Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun',\n 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec',\n ],\n heatmapLegendLess: 'Less',\n heatmapLegendMore: 'More',\n};\n","/**\n * formatMetricValue — single canonical formatter for every metric surface.\n *\n * Keeps formatting logic out of the layout components so the same dataset\n * renders identically regardless of which `Metric*` variant displays it.\n */\nimport {\n\tEMPTY,\n\tformatCurrency,\n\tformatDuration,\n\tformatNumber,\n\tformatPercentage,\n} from '@/lib/format';\nimport type { MetricData } from './types';\n\nexport function formatMetricValue(data: MetricData): string {\n\tif (data.value === null || data.value === undefined) return EMPTY;\n\n\tconst value = data.value;\n\tconst numeric = typeof value === 'number' ? value : null;\n\n\tswitch (data.valueType) {\n\t\tcase 'currency':\n\t\t\treturn numeric !== null\n\t\t\t\t? formatCurrency(numeric, { currency: data.currency })\n\t\t\t\t: String(value);\n\t\tcase 'percentage':\n\t\t\treturn numeric !== null ? formatPercentage(numeric) : String(value);\n\t\tcase 'duration':\n\t\t\treturn numeric !== null ? formatDuration(numeric) : String(value);\n\t\tcase 'number':\n\t\t\treturn numeric !== null ? formatNumber(numeric) : String(value);\n\t\tcase 'text':\n\t\tdefault:\n\t\t\treturn String(value);\n\t}\n}\n\n/**\n * Resolve the effective `MetricTrend` for a metric — explicit `trend` wins,\n * otherwise we infer from `change.direction` (`up` → positive, `down` →\n * negative, `neutral`/missing → neutral).\n */\nexport function resolveTrend(data: MetricData): 'positive' | 'negative' | 'neutral' {\n\tif (data.trend) return data.trend;\n\tif (data.change?.direction === 'up') return 'positive';\n\tif (data.change?.direction === 'down') return 'negative';\n\treturn 'neutral';\n}\n","/**\n * MetricTrendChip — compact ↑/↓/→ delta indicator.\n *\n * Decouples direction (up/down/neutral) from tone (positive/negative/neutral)\n * so consumers can flip the colour for inverted metrics like churn or refund\n * rate. Four variants:\n * - `default` — coloured icon + value, no chrome\n * - `badge` — pill with tinted bg + arrow icon\n * - `compact` — coloured arrow + value, no spacing\n * - `inline` — value only with sign prefix, no icon\n */\nimport { ArrowDown, ArrowUp, Minus } from 'lucide-react';\nimport { Text } from '@/components/typography';\nimport { cn } from '@/lib/utils';\n\nimport type { MetricChange, MetricSize, MetricTrend, MetricTrendVariant } from '../types';\n\ninterface MetricTrendChipProps {\n\tchange: MetricChange;\n\ttrend?: MetricTrend;\n\tsize?: MetricSize;\n\tvariant?: MetricTrendVariant;\n\tclassName?: string;\n}\n\nconst TONE_CLASSES: Record<MetricTrend, { text: string; badge: string; arrow: string }> = {\n\tpositive: { text: 'text-success', badge: 'bg-success/10 text-success', arrow: 'text-success' },\n\tnegative: { text: 'text-destructive', badge: 'bg-destructive/10 text-destructive', arrow: 'text-destructive' },\n\tneutral: { text: 'text-muted-foreground', badge: 'bg-muted text-muted-foreground', arrow: 'text-muted-foreground' },\n};\n\nconst ICON_SIZE: Record<MetricSize, string> = {\n\tsm: 'size-3',\n\tmd: 'size-3.5',\n\tlg: 'size-4',\n};\n\nconst TEXT_SIZE: Record<MetricSize, 'xxs' | 'xs' | 'sm'> = {\n\tsm: 'xxs',\n\tmd: 'xs',\n\tlg: 'sm',\n};\n\nconst BADGE_PADDING: Record<MetricSize, string> = {\n\tsm: 'px-1.5 py-0.5',\n\tmd: 'px-2 py-0.5',\n\tlg: 'px-2.5 py-1',\n};\n\nfunction resolveTone(trend: MetricTrend | undefined, direction: MetricChange['direction']): MetricTrend {\n\tif (trend) return trend;\n\tif (direction === 'up') return 'positive';\n\tif (direction === 'down') return 'negative';\n\treturn 'neutral';\n}\n\nexport function MetricTrendChip({\n\tchange,\n\ttrend,\n\tsize = 'md',\n\tvariant = 'default',\n\tclassName,\n}: MetricTrendChipProps) {\n\tconst tone = resolveTone(trend, change.direction);\n\tconst Icon = change.direction === 'up' ? ArrowUp : change.direction === 'down' ? ArrowDown : Minus;\n\tconst palette = TONE_CLASSES[tone];\n\tconst valueText = String(change.value);\n\tconst sign = change.direction === 'up' ? '+' : change.direction === 'down' ? '' : '';\n\n\tif (variant === 'inline') {\n\t\treturn (\n\t\t\t<Text tag=\"span\" size={TEXT_SIZE[size]} weight=\"medium\" className={cn('metric-trend-chip--component', palette.text, 'tabular-nums', className)}>\n\t\t\t\t{sign}{valueText}\n\t\t\t</Text>\n\t\t);\n\t}\n\n\tif (variant === 'compact') {\n\t\treturn (\n\t\t\t<span className={cn('inline-flex items-center gap-0.5', palette.text, className)}>\n\t\t\t\t<Icon className={ICON_SIZE[size]} strokeWidth={2.5} aria-hidden=\"true\" />\n\t\t\t\t<Text tag=\"span\" size={TEXT_SIZE[size]} weight=\"semibold\" className=\"tabular-nums\">\n\t\t\t\t\t{valueText}\n\t\t\t\t</Text>\n\t\t\t</span>\n\t\t);\n\t}\n\n\tif (variant === 'badge') {\n\t\treturn (\n\t\t\t<span className={cn('inline-flex items-center gap-1 rounded-full font-medium tabular-nums', palette.badge, BADGE_PADDING[size], className)}>\n\t\t\t\t<Icon className={ICON_SIZE[size]} strokeWidth={2.5} aria-hidden=\"true\" />\n\t\t\t\t<Text tag=\"span\" size={TEXT_SIZE[size]} weight=\"semibold\" className=\"tabular-nums\">\n\t\t\t\t\t{valueText}\n\t\t\t\t</Text>\n\t\t\t\t{!!change.label && (\n\t\t\t\t\t<Text tag=\"span\" size={TEXT_SIZE[size]} className=\"opacity-70\">{change.label}</Text>\n\t\t\t\t)}\n\t\t\t</span>\n\t\t);\n\t}\n\n\t// default\n\treturn (\n\t\t<span className={cn('inline-flex items-center gap-1', palette.text, className)}>\n\t\t\t<Icon className={ICON_SIZE[size]} strokeWidth={2.5} aria-hidden=\"true\" />\n\t\t\t<Text tag=\"span\" size={TEXT_SIZE[size]} weight=\"semibold\" className=\"tabular-nums\">\n\t\t\t\t{valueText}\n\t\t\t</Text>\n\t\t\t{!!change.label && (\n\t\t\t\t<Text tag=\"span\" size={TEXT_SIZE[size]} type=\"secondary\">{change.label}</Text>\n\t\t\t)}\n\t\t</span>\n\t);\n}\n\nMetricTrendChip.displayName = 'MetricTrendChip';\n","/**\n * MetricSparkline — recharts-backed mini area chart used inside Metric\n * variants. Auto-stretches to its container; pass a fixed height (e.g.\n * `h-8 w-full`) on the wrapper. `trend` colours the stroke + gradient\n * (positive/negative/neutral); `color` overrides with any CSS colour\n * (semantic var, hex, rgb).\n */\nimport { useId, useMemo } from 'react';\nimport { Area, AreaChart, ResponsiveContainer } from 'recharts';\nimport { cn } from '@/lib/utils';\n\nimport type { MetricTrend } from '../types';\n\ninterface MetricSparklineProps {\n\tdata: readonly number[];\n\ttrend?: MetricTrend;\n\tcolor?: string;\n\tclassName?: string;\n\tanimated?: boolean;\n\t'aria-label'?: string;\n}\n\nconst TREND_COLORS: Record<MetricTrend, string> = {\n\tpositive: 'var(--success)',\n\tnegative: 'var(--destructive)',\n\tneutral: 'var(--muted-foreground)',\n};\n\nexport function MetricSparkline({\n\tdata,\n\ttrend = 'neutral',\n\tcolor,\n\tclassName,\n\tanimated = true,\n\t'aria-label': ariaLabel = 'Trend sparkline',\n}: MetricSparklineProps) {\n\tconst id = useId();\n\tconst gradientId = useMemo(() => `metric-spark-${id.replaceAll(':', '')}`, [id]);\n\tconst stroke = color ?? TREND_COLORS[trend];\n\n\tconst chartData = useMemo(() => {\n\t\tif (!Array.isArray(data) || data.length === 0) return [];\n\t\treturn data.map((value, i) => ({ i, v: value }));\n\t}, [data]);\n\n\tif (chartData.length === 0) {\n\t\treturn <div className={cn('metric-sparkline--component', 'w-full', className)} aria-hidden=\"true\" />;\n\t}\n\n\treturn (\n\t\t<div className={cn('w-full', className)} role=\"img\" aria-label={ariaLabel}>\n\t\t\t<ResponsiveContainer width=\"100%\" height=\"100%\" initialDimension={{ width: 1, height: 1 }}>\n\t\t\t\t<AreaChart data={chartData} margin={{ top: 2, right: 0, bottom: 0, left: 0 }}>\n\t\t\t\t\t<defs>\n\t\t\t\t\t\t<linearGradient id={gradientId} x1=\"0\" y1=\"0\" x2=\"0\" y2=\"1\">\n\t\t\t\t\t\t\t<stop offset=\"0%\" stopColor={stroke} stopOpacity={0.25} />\n\t\t\t\t\t\t\t<stop offset=\"100%\" stopColor={stroke} stopOpacity={0} />\n\t\t\t\t\t\t</linearGradient>\n\t\t\t\t\t</defs>\n\t\t\t\t\t<Area\n\t\t\t\t\t\ttype=\"monotone\"\n\t\t\t\t\t\tdataKey=\"v\"\n\t\t\t\t\t\tstroke={stroke}\n\t\t\t\t\t\tstrokeWidth={1.75}\n\t\t\t\t\t\tfill={`url(#${gradientId})`}\n\t\t\t\t\t\tdot={false}\n\t\t\t\t\t\tactiveDot={false}\n\t\t\t\t\t\tisAnimationActive={animated}\n\t\t\t\t\t\tanimationDuration={600}\n\t\t\t\t\t/>\n\t\t\t\t</AreaChart>\n\t\t\t</ResponsiveContainer>\n\t\t</div>\n\t);\n}\n\nMetricSparkline.displayName = 'MetricSparkline';\n","/**\n * MetricSkeleton — loading placeholder matching the height/spacing of every\n * `Metric` variant so the layout doesn't jump when data resolves.\n */\nimport { cn } from '@/lib/utils';\nimport type { MetricSize, MetricVariant } from '../types';\n\ninterface MetricSkeletonProps {\n\tvariant?: MetricVariant;\n\tsize?: MetricSize;\n\tclassName?: string;\n}\n\nconst Bar = ({ className }: { className?: string }) => (\n\t<div className={cn('animate-pulse rounded bg-muted', className)} />\n);\n\nexport function MetricSkeleton({\n\tvariant = 'default',\n\tsize = 'md',\n\tclassName,\n}: MetricSkeletonProps) {\n\tconst padding = size === 'sm' ? 'p-3' : size === 'lg' ? 'p-5' : 'p-4';\n\n\tif (variant === 'card' || variant === 'bordered' || variant === 'accent' || variant === 'colored') {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tclassName={cn('metric-skeleton--component', \n\t\t\t\t\t'rounded-xl border border-border bg-card shadow-sm',\n\t\t\t\t\tpadding,\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\taria-busy=\"true\"\n\t\t\t\taria-live=\"polite\"\n\t\t\t>\n\t\t\t\t<Bar className=\"h-3 w-24\" />\n\t\t\t\t<Bar className={cn('mt-3', size === 'lg' ? 'h-9 w-40' : 'h-7 w-32')} />\n\t\t\t\t<Bar className=\"mt-2 h-3 w-20\" />\n\t\t\t\t<Bar className=\"mt-3 h-8 w-full\" />\n\t\t\t</div>\n\t\t);\n\t}\n\n\tif (variant === 'compact') {\n\t\treturn (\n\t\t\t<div className={cn('flex items-center gap-3', className)} aria-busy=\"true\">\n\t\t\t\t<Bar className=\"size-9 rounded-lg\" />\n\t\t\t\t<div className=\"flex-1 space-y-1.5\">\n\t\t\t\t\t<Bar className=\"h-3 w-20\" />\n\t\t\t\t\t<Bar className=\"h-4 w-28\" />\n\t\t\t\t</div>\n\t\t\t\t<Bar className=\"h-5 w-12 rounded-full\" />\n\t\t\t</div>\n\t\t);\n\t}\n\n\tif (variant === 'minimal') {\n\t\treturn (\n\t\t\t<div className={cn('inline-flex items-baseline gap-2', className)} aria-busy=\"true\">\n\t\t\t\t<Bar className=\"h-3 w-12\" />\n\t\t\t\t<Bar className=\"h-3 w-16\" />\n\t\t\t</div>\n\t\t);\n\t}\n\n\t// default\n\treturn (\n\t\t<div className={cn('flex flex-col gap-1.5', padding, className)} aria-busy=\"true\">\n\t\t\t<Bar className=\"h-3 w-20\" />\n\t\t\t<Bar className=\"h-5 w-28\" />\n\t\t\t<Bar className=\"mt-1 h-6 w-full\" />\n\t\t</div>\n\t);\n}\n\nMetricSkeleton.displayName = 'MetricSkeleton';\n","/**\n * Metric — canonical single-metric surface. One component, seven variants:\n *\n * default — flat tile (label / value / trend / sparkline) for use inside\n * MetricBar or other composed surfaces.\n * card — wrapped in SmartCard with shadow, padding, optional tooltip.\n * Use as a standalone hero in a row of three.\n * compact — single-row icon + label + value + chip. Sidebar / list use.\n * minimal — inline `Label: value ↑12%` chip for in-flow copy.\n * bordered — soft tinted border keyed off `colorScheme`.\n * accent — dark surface card with bottom-aligned area sparkline.\n * colored — segmented progress bar (driven by `progress` prop).\n *\n * All variants share the same `MetricData` shape; only the layout changes.\n */\nimport { useMemo } from 'react';\nimport { ArrowUpRight } from 'lucide-react';\n\nimport { SmartCard } from '@/components/base/cards';\nimport { Heading, Text } from '@/components/typography';\nimport { cn } from '@/lib/utils';\n\nimport { defaultAnalyticsStrings } from '../analytics.strings';\nimport { MetricSkeleton } from '../atoms/metric-skeleton';\nimport { MetricSparkline } from '../atoms/metric-sparkline';\nimport { MetricTrendChip } from '../atoms/metric-trend-chip';\nimport { formatMetricValue, resolveTrend } from '../format-metric-value';\nimport type {\n\tMetricColorScheme,\n\tMetricData,\n\tMetricSize,\n\tMetricVariant,\n} from '../types';\n\nexport interface MetricProps {\n\tdata: MetricData;\n\tvariant?: MetricVariant;\n\tsize?: MetricSize;\n\tcolorScheme?: MetricColorScheme;\n\tshowSparkline?: boolean;\n\tshowChange?: boolean;\n\tshowIcon?: boolean;\n\tloading?: boolean;\n\terror?: boolean;\n\terrorLabel?: string;\n\t/** `colored` variant only — 0-100 fill percentage. */\n\tprogress?: number;\n\tclassName?: string;\n\t'aria-label'?: string;\n}\n\n// ── colour-scheme palettes (shared between bordered + colored variants) ──\nconst SCHEME_TINT: Record<MetricColorScheme, { border: string; bg: string; bar: string; dot: string; ring: string }> = {\n\tdefault: { border: 'border-border', bg: 'bg-card', bar: 'bg-foreground', dot: 'bg-foreground', ring: 'ring-border' },\n\tprimary: { border: 'border-primary/25', bg: 'bg-primary/5', bar: 'bg-primary', dot: 'bg-primary', ring: 'ring-primary/20' },\n\tsuccess: { border: 'border-success/30', bg: 'bg-success/5', bar: 'bg-success', dot: 'bg-success', ring: 'ring-success/20' },\n\twarning: { border: 'border-warning/40', bg: 'bg-warning/10', bar: 'bg-warning', dot: 'bg-warning', ring: 'ring-warning/30' },\n\tdanger: { border: 'border-destructive/30', bg: 'bg-destructive/5', bar: 'bg-destructive', dot: 'bg-destructive', ring: 'ring-destructive/20' },\n\tinfo: { border: 'border-info/30', bg: 'bg-info/5', bar: 'bg-info', dot: 'bg-info', ring: 'ring-info/20' },\n};\n\n/** Compact value sizes for in-grid / in-bar usage where horizontal space is tight. */\nconst VALUE_FONT_SIZE: Record<MetricSize, string> = {\n\tsm: 'text-sm',\n\tmd: 'text-lg',\n\tlg: 'text-xl',\n};\n\n/** Hero value sizes for standalone card / bordered / accent variants. */\nconst VALUE_FONT_SIZE_HERO: Record<MetricSize, string> = {\n\tsm: 'text-xl',\n\tmd: 'text-3xl',\n\tlg: 'text-4xl',\n};\n\nconst SPARKLINE_HEIGHT: Record<MetricSize, string> = {\n\tsm: 'h-6',\n\tmd: 'h-8',\n\tlg: 'h-10',\n};\n\nconst SEGMENT_COUNT = 16;\n\nexport function Metric(props: MetricProps) {\n\tconst {\n\t\tdata,\n\t\tvariant = 'default',\n\t\tsize = 'md',\n\t\tcolorScheme = 'default',\n\t\tshowSparkline = true,\n\t\tshowChange = true,\n\t\tshowIcon = true,\n\t\tloading = false,\n\t\terror = false,\n\t\terrorLabel,\n\t\tprogress = 0,\n\t\tclassName,\n\t\t'aria-label': ariaLabel,\n\t} = props;\n\n\tconst formattedValue = useMemo(() => formatMetricValue(data), [data]);\n\tconst trend = useMemo(() => resolveTrend(data), [data]);\n\n\tif (loading) return <MetricSkeleton variant={variant} size={size} className={cn('metric--component', className)} />;\n\tif (error) {\n\t\treturn (\n\t\t\t<div className={cn('flex items-center justify-center rounded-lg border border-border bg-card p-4 text-muted-foreground', className)}>\n\t\t\t\t<Text>{errorLabel ?? defaultAnalyticsStrings.metricErrorLabel}</Text>\n\t\t\t</div>\n\t\t);\n\t}\n\n\tconst sharedProps = {\n\t\tdata,\n\t\tformattedValue,\n\t\ttrend,\n\t\tsize,\n\t\tshowSparkline,\n\t\tshowChange,\n\t\tshowIcon,\n\t\tcolorScheme,\n\t\tariaLabel: ariaLabel ?? data.label,\n\t\tclassName,\n\t};\n\n\tswitch (variant) {\n\t\tcase 'card':\n\t\t\treturn <MetricCard {...sharedProps} />;\n\t\tcase 'compact':\n\t\t\treturn <MetricCompact {...sharedProps} />;\n\t\tcase 'minimal':\n\t\t\treturn <MetricMinimal {...sharedProps} />;\n\t\tcase 'bordered':\n\t\t\treturn <MetricBordered {...sharedProps} />;\n\t\tcase 'accent':\n\t\t\treturn <MetricAccent {...sharedProps} />;\n\t\tcase 'colored':\n\t\t\treturn <MetricColored {...sharedProps} progress={progress} />;\n\t\tdefault:\n\t\t\treturn <MetricDefault {...sharedProps} />;\n\t}\n}\n\nMetric.displayName = 'Metric';\n\n// ─────────────────────────────────────────────────────────────────────────\n// Internal sub-components — kept private. Each handles one variant only.\n// ─────────────────────────────────────────────────────────────────────────\n\ninterface SubProps {\n\tdata: MetricData;\n\tformattedValue: string;\n\ttrend: 'positive' | 'negative' | 'neutral';\n\tsize: MetricSize;\n\tshowSparkline: boolean;\n\tshowChange: boolean;\n\tshowIcon: boolean;\n\tcolorScheme: MetricColorScheme;\n\tariaLabel: string;\n\tclassName?: string;\n}\n\nfunction MetricDefault({ data, formattedValue, trend, size, showSparkline, showChange, showIcon, ariaLabel, className }: SubProps) {\n\tconst Icon = data.icon;\n\treturn (\n\t\t<div className={cn('flex min-w-0 flex-col gap-1', className)} aria-label={ariaLabel}>\n\t\t\t<div className=\"flex items-center gap-1.5 min-w-0 text-muted-foreground\">\n\t\t\t\t{!!showIcon && !!Icon && <Icon className=\"size-3.5 shrink-0\" aria-hidden=\"true\" />}\n\t\t\t\t<Text size=\"xs\" type=\"secondary\" weight=\"medium\" className=\"truncate\">{data.label}</Text>\n\t\t\t</div>\n\t\t\t<Heading\n\t\t\t\ttag=\"h5\"\n\t\t\t\tclassName={cn(\n\t\t\t\t\t'font-bold tabular-nums tracking-tight border-none pb-0 leading-tight truncate',\n\t\t\t\t\tVALUE_FONT_SIZE[size],\n\t\t\t\t)}\n\t\t\t\ttitle={formattedValue}\n\t\t\t>\n\t\t\t\t{formattedValue}\n\t\t\t</Heading>\n\t\t\t{!!showChange && !!data.change && (\n\t\t\t\t<div className=\"min-w-0\">\n\t\t\t\t\t<MetricTrendChip change={data.change} trend={data.trend} size={size} variant=\"compact\" />\n\t\t\t\t</div>\n\t\t\t)}\n\t\t\t{!!data.subtitle && <Text size=\"xs\" type=\"secondary\" className=\"truncate\">{data.subtitle}</Text>}\n\t\t\t{!!showSparkline && !!data.sparkline?.length && (\n\t\t\t\t<MetricSparkline data={data.sparkline} trend={trend} className={cn('mt-auto', SPARKLINE_HEIGHT[size])} />\n\t\t\t)}\n\t\t\t{!!data.footer && <Text size=\"xxs\" type=\"discrete\" className=\"truncate\">{data.footer}</Text>}\n\t\t</div>\n\t);\n}\n\nfunction MetricCard({ data, formattedValue, trend, size, showSparkline, showChange, showIcon, ariaLabel, className }: SubProps) {\n\tconst Icon = data.icon;\n\tconst isInteractive = Boolean(data.href || data.onClick);\n\tconst padding: 'sm' | 'base' | 'lg' = size === 'sm' ? 'sm' : size === 'lg' ? 'lg' : 'base';\n\n\tconst card = (\n\t\t<SmartCard\n\t\t\ttitle={data.label}\n\t\t\ticon={!!showIcon && !!Icon ? <Icon className=\"size-4\" aria-hidden=\"true\" /> : null}\n\t\t\ttooltip={data.tooltip}\n\t\t\tpadding={padding}\n\t\t\tclassName={cn(isInteractive && 'cursor-pointer transition-shadow hover:shadow-md', className)}\n\t\t\taria-label={ariaLabel}\n\t\t>\n\t\t\t<div className=\"flex items-baseline justify-between gap-3\">\n\t\t\t\t<Heading\n\t\t\t\t\ttag={size === 'sm' ? 'h5' : size === 'lg' ? 'h3' : 'h4'}\n\t\t\t\t\tclassName={cn('font-bold tabular-nums tracking-tight border-none pb-0 leading-none', VALUE_FONT_SIZE_HERO[size])}\n\t\t\t\t>\n\t\t\t\t\t{formattedValue}\n\t\t\t\t</Heading>\n\t\t\t\t{!!showChange && !!data.change && (\n\t\t\t\t\t<MetricTrendChip change={data.change} trend={data.trend} size={size} variant=\"badge\" />\n\t\t\t\t)}\n\t\t\t</div>\n\t\t\t{!!data.subtitle && <Text type=\"secondary\" className=\"mt-2\">{data.subtitle}</Text>}\n\t\t\t{!!showSparkline && !!data.sparkline?.length && (\n\t\t\t\t<MetricSparkline\n\t\t\t\t\tdata={data.sparkline}\n\t\t\t\t\ttrend={trend}\n\t\t\t\t\tclassName={cn('mt-3', size === 'lg' ? 'h-12' : 'h-10')}\n\t\t\t\t/>\n\t\t\t)}\n\t\t\t{!!data.footer && <Text size=\"xs\" type=\"secondary\" className=\"mt-2\">{data.footer}</Text>}\n\t\t</SmartCard>\n\t);\n\n\tif (isInteractive && data.onClick) {\n\t\treturn (\n\t\t\t<div\n\t\t\t\trole=\"button\"\n\t\t\t\ttabIndex={0}\n\t\t\t\tonClick={data.onClick}\n\t\t\t\tonKeyDown={(e) => (e.key === 'Enter' || e.key === ' ') && data.onClick?.()}\n\t\t\t\tclassName=\"rounded-xl focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring/40\"\n\t\t\t>\n\t\t\t\t{card}\n\t\t\t</div>\n\t\t);\n\t}\n\treturn card;\n}\n\nfunction MetricCompact({ data, formattedValue, size, showChange, showIcon, ariaLabel, className }: SubProps) {\n\tconst Icon = data.icon;\n\treturn (\n\t\t<div className={cn('flex items-center gap-3', className)} aria-label={ariaLabel}>\n\t\t\t{!!showIcon && !!Icon && (\n\t\t\t\t<span className=\"inline-flex size-9 shrink-0 items-center justify-center rounded-lg bg-muted/60 text-muted-foreground\">\n\t\t\t\t\t<Icon className=\"size-4\" aria-hidden=\"true\" />\n\t\t\t\t</span>\n\t\t\t)}\n\t\t\t<div className=\"min-w-0 flex-1\">\n\t\t\t\t<Text size=\"xs\" type=\"secondary\" className=\"truncate\">{data.label}</Text>\n\t\t\t\t<Text tag=\"span\" size={size === 'sm' ? 'sm' : 'lg'} weight=\"bold\" className=\"block truncate tabular-nums\">\n\t\t\t\t\t{formattedValue}\n\t\t\t\t</Text>\n\t\t\t</div>\n\t\t\t{!!showChange && !!data.change && (\n\t\t\t\t<MetricTrendChip change={data.change} trend={data.trend} size={size} variant=\"badge\" className=\"shrink-0\" />\n\t\t\t)}\n\t\t</div>\n\t);\n}\n\nfunction MetricMinimal({ data, formattedValue, size, showChange, ariaLabel, className }: SubProps) {\n\treturn (\n\t\t<span className={cn('inline-flex items-baseline gap-2', className)} aria-label={ariaLabel}>\n\t\t\t<Text tag=\"span\" size={size === 'lg' ? 'sm' : 'xs'} type=\"secondary\">{data.label}:</Text>\n\t\t\t<Text tag=\"span\" size={size === 'lg' ? 'sm' : 'xs'} weight=\"semibold\" className=\"tabular-nums\">{formattedValue}</Text>\n\t\t\t{!!showChange && !!data.change && (\n\t\t\t\t<MetricTrendChip change={data.change} trend={data.trend} size=\"sm\" variant=\"inline\" />\n\t\t\t)}\n\t\t</span>\n\t);\n}\n\nfunction MetricBordered({ data, formattedValue, trend, size, showSparkline, showChange, showIcon, colorScheme, ariaLabel, className }: SubProps) {\n\tconst Icon = data.icon;\n\tconst tint = SCHEME_TINT[colorScheme];\n\treturn (\n\t\t<div\n\t\t\tclassName={cn('flex flex-col gap-3 rounded-xl border p-4 shadow-sm', tint.border, tint.bg, className)}\n\t\t\taria-label={ariaLabel}\n\t\t>\n\t\t\t<div className=\"flex items-center justify-between gap-2\">\n\t\t\t\t<div className=\"flex items-center gap-2 text-muted-foreground\">\n\t\t\t\t\t{!!showIcon && !!Icon && <Icon className=\"size-4 shrink-0\" aria-hidden=\"true\" />}\n\t\t\t\t\t<Text size=\"xs\" type=\"secondary\" weight=\"medium\">{data.label}</Text>\n\t\t\t\t</div>\n\t\t\t\t{!!showChange && !!data.change && (\n\t\t\t\t\t<MetricTrendChip change={data.change} trend={data.trend} size={size} variant=\"badge\" />\n\t\t\t\t)}\n\t\t\t</div>\n\t\t\t<Heading\n\t\t\t\ttag={size === 'lg' ? 'h3' : 'h4'}\n\t\t\t\tclassName={cn('font-bold tabular-nums tracking-tight border-none pb-0 leading-none', VALUE_FONT_SIZE_HERO[size])}\n\t\t\t>\n\t\t\t\t{formattedValue}\n\t\t\t</Heading>\n\t\t\t{!!data.subtitle && <Text size=\"xs\" type=\"secondary\">{data.subtitle}</Text>}\n\t\t\t{!!showSparkline && !!data.sparkline?.length && (\n\t\t\t\t<MetricSparkline data={data.sparkline} trend={trend} className={SPARKLINE_HEIGHT[size]} />\n\t\t\t)}\n\t\t\t{!!data.footer && <Text size=\"xxs\" type=\"discrete\">{data.footer}</Text>}\n\t\t</div>\n\t);\n}\n\nfunction MetricAccent({ data, formattedValue, trend, size, showSparkline, showChange, ariaLabel, className }: SubProps) {\n\tconst Icon = data.icon;\n\treturn (\n\t\t<div\n\t\t\tclassName={cn(\n\t\t\t\t'dark relative flex flex-col rounded-2xl bg-card text-card-foreground shadow-lg ring-1 ring-border overflow-hidden',\n\t\t\t\tclassName,\n\t\t\t)}\n\t\t\taria-label={ariaLabel}\n\t\t>\n\t\t\t<div className=\"flex flex-col gap-2 p-5\">\n\t\t\t\t<div className=\"flex items-center justify-between gap-3\">\n\t\t\t\t\t<Text size=\"xs\" type=\"secondary\" weight=\"medium\" className=\"uppercase tracking-wider\">\n\t\t\t\t\t\t{data.label}\n\t\t\t\t\t</Text>\n\t\t\t\t\t{!!Icon && (\n\t\t\t\t\t\t<span className=\"inline-flex size-7 items-center justify-center rounded-lg bg-foreground/[0.08]\">\n\t\t\t\t\t\t\t<Icon className=\"size-3.5 text-muted-foreground\" aria-hidden=\"true\" />\n\t\t\t\t\t\t</span>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t\t<div className=\"flex items-baseline gap-2.5\">\n\t\t\t\t\t<Heading\n\t\t\t\t\t\ttag=\"h3\"\n\t\t\t\t\t\tclassName={cn('font-bold tabular-nums tracking-tight border-none pb-0 leading-none text-foreground', VALUE_FONT_SIZE_HERO[size])}\n\t\t\t\t\t>\n\t\t\t\t\t\t{formattedValue}\n\t\t\t\t\t</Heading>\n\t\t\t\t\t{!!showChange && !!data.change && (\n\t\t\t\t\t\t<MetricTrendChip change={data.change} trend={data.trend} size={size} variant=\"compact\" />\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t\t{!!data.subtitle && <Text size=\"xs\" type=\"secondary\">{data.subtitle}</Text>}\n\t\t\t</div>\n\t\t\t{!!showSparkline && !!data.sparkline?.length && (\n\t\t\t\t<MetricSparkline data={data.sparkline} trend={trend} className=\"h-12 w-full\" />\n\t\t\t)}\n\t\t</div>\n\t);\n}\n\nfunction MetricColored({ data, formattedValue, size, showChange, colorScheme, ariaLabel, className, progress = 0 }: SubProps & { progress?: number }) {\n\tconst tint = SCHEME_TINT[colorScheme === 'default' ? 'primary' : colorScheme];\n\tconst filledCount = Math.round((Math.min(Math.max(progress, 0), 100) / 100) * SEGMENT_COUNT);\n\treturn (\n\t\t<div\n\t\t\tclassName={cn('rounded-xl bg-card p-5 shadow-sm border border-border/50', className)}\n\t\t\taria-label={ariaLabel}\n\t\t>\n\t\t\t<div className=\"flex items-center gap-2\">\n\t\t\t\t<Text size=\"xs\" type=\"secondary\" weight=\"medium\" className=\"truncate\">{data.label}</Text>\n\t\t\t\t<span className={cn('size-1.5 rounded-full shrink-0', tint.dot)} aria-hidden=\"true\" />\n\t\t\t</div>\n\t\t\t<div className=\"mt-2.5 flex items-baseline gap-2\">\n\t\t\t\t<Heading\n\t\t\t\t\ttag=\"h3\"\n\t\t\t\t\tclassName={cn('font-bold tabular-nums tracking-tight border-none pb-0 leading-none', VALUE_FONT_SIZE_HERO[size])}\n\t\t\t\t>\n\t\t\t\t\t{formattedValue}\n\t\t\t\t</Heading>\n\t\t\t\t{!!data.subtitle && <Text size=\"xs\" type=\"secondary\">{data.subtitle}</Text>}\n\t\t\t</div>\n\t\t\t<div className=\"mt-4 flex items-center gap-0.5\" role=\"progressbar\" aria-valuenow={progress} aria-valuemin={0} aria-valuemax={100}>\n\t\t\t\t{Array.from({ length: SEGMENT_COUNT }, (_, i) => (\n\t\t\t\t\t<div\n\t\t\t\t\t\tkey={`seg-${i}`}\n\t\t\t\t\t\tclassName={cn('h-6 w-1.5 rounded-sm transition-colors', i < filledCount ? tint.bar : 'bg-muted')}\n\t\t\t\t\t/>\n\t\t\t\t))}\n\t\t\t</div>\n\t\t\t{!!showChange && !!data.change && (\n\t\t\t\t<div className=\"mt-3\">\n\t\t\t\t\t<MetricTrendChip change={data.change} trend={data.trend} size={size} variant=\"default\" />\n\t\t\t\t</div>\n\t\t\t)}\n\t\t\t{!!data.footer && (\n\t\t\t\t<div className=\"mt-2 inline-flex items-center gap-1 text-muted-foreground\">\n\t\t\t\t\t<ArrowUpRight className=\"size-3\" aria-hidden=\"true\" />\n\t\t\t\t\t<Text size=\"xxs\" type=\"secondary\">{data.footer}</Text>\n\t\t\t\t</div>\n\t\t\t)}\n\t\t</div>\n\t);\n}\n","/**\n * MetricBar — horizontal strip of metrics with an optional period selector\n * on the leading edge. Cells are divided by hairlines so a row of 4 KPIs\n * reads as a single integrated module rather than disconnected cards.\n *\n * Variants:\n * `default` — flat hairline-divided bar with period chip on the left.\n * Best for tables/dashboards where the bar sits above content.\n * `gradient` — same layout wrapped in a tinted gradient frame for hero\n * placement.\n *\n * Always render `Metric` cells inside; never render layout-specific markup\n * directly. That keeps the formatting / colouring rules in one place.\n */\nimport { Calendar } from 'lucide-react';\nimport { Button } from '@/components/base/buttons';\nimport { Text } from '@/components/typography';\nimport { cn } from '@/lib/utils';\n\nimport { Metric } from '../metric/metric';\nimport type { MetricData, MetricPeriod, MetricSize } from '../types';\n\nexport type MetricBarVariant = 'default' | 'gradient';\n\nexport interface MetricBarProps {\n\tmetrics: MetricData[];\n\tperiod?: MetricPeriod;\n\tonPeriodChange?: (value: string) => void;\n\tvariant?: MetricBarVariant;\n\tsize?: MetricSize;\n\tshowSparklines?: boolean;\n\tshowChanges?: boolean;\n\tfooterText?: string;\n\tclassName?: string;\n}\n\nexport function MetricBar({\n\tmetrics,\n\tperiod,\n\tonPeriodChange,\n\tvariant = 'default',\n\tsize = 'md',\n\tshowSparklines = true,\n\tshowChanges = true,\n\tfooterText,\n\tclassName,\n}: MetricBarProps) {\n\tconst cells = (\n\t\t<div className=\"flex min-w-0 flex-1 items-stretch divide-x divide-border\">\n\t\t\t{metrics.map((metric) => (\n\t\t\t\t<div key={metric.id} className=\"flex-1 min-w-0 px-4 py-3\">\n\t\t\t\t\t<Metric\n\t\t\t\t\t\tdata={metric}\n\t\t\t\t\t\tvariant=\"default\"\n\t\t\t\t\t\tsize={size}\n\t\t\t\t\t\tshowSparkline={showSparklines}\n\t\t\t\t\t\tshowChange={showChanges}\n\t\t\t\t\t/>\n\t\t\t\t</div>\n\t\t\t))}\n\t\t</div>\n\t);\n\n\tconst periodChip = !!period && (\n\t\t<div className=\"flex shrink-0 items-center px-3\">\n\t\t\t<Button\n\t\t\t\tvariant=\"secondary\"\n\t\t\t\tbuttonStyle=\"ghost\"\n\t\t\t\tclassName=\"gap-1.5\"\n\t\t\t\tonClick={onPeriodChange ? () => onPeriodChange(period.value) : undefined}\n\t\t\t>\n\t\t\t\t<Calendar className=\"size-3.5\" aria-hidden=\"true\" />\n\t\t\t\t<Text size=\"xs\" weight=\"medium\">{period.label}</Text>\n\t\t\t</Button>\n\t\t</div>\n\t);\n\n\tif (variant === 'gradient') {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tclassName={cn('metric-bar--component', \n\t\t\t\t\t'rounded-xl bg-gradient-to-r from-primary/8 via-info/5 to-success/8 p-[1px]',\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t>\n\t\t\t\t<div className=\"flex items-stretch overflow-hidden rounded-[11px] bg-card\">\n\t\t\t\t\t{periodChip && (\n\t\t\t\t\t\t<>\n\t\t\t\t\t\t\t{periodChip}\n\t\t\t\t\t\t\t<div className=\"w-px bg-border\" aria-hidden=\"true\" />\n\t\t\t\t\t\t</>\n\t\t\t\t\t)}\n\t\t\t\t\t{cells}\n\t\t\t\t</div>\n\t\t\t\t{!!footerText && (\n\t\t\t\t\t<div className=\"rounded-b-[11px] border-t border-border/50 bg-card px-4 py-2\">\n\t\t\t\t\t\t<Text size=\"xxs\" type=\"discrete\">{footerText}</Text>\n\t\t\t\t\t</div>\n\t\t\t\t)}\n\t\t\t</div>\n\t\t);\n\t}\n\n\treturn (\n\t\t<div\n\t\t\tclassName={cn(\n\t\t\t\t'flex flex-col overflow-hidden rounded-xl border border-border bg-card shadow-sm',\n\t\t\t\tclassName,\n\t\t\t)}\n\t\t>\n\t\t\t<div className=\"flex items-stretch\">\n\t\t\t\t{periodChip && (\n\t\t\t\t\t<>\n\t\t\t\t\t\t{periodChip}\n\t\t\t\t\t\t<div className=\"w-px bg-border\" aria-hidden=\"true\" />\n\t\t\t\t\t</>\n\t\t\t\t)}\n\t\t\t\t{cells}\n\t\t\t</div>\n\t\t\t{!!footerText && (\n\t\t\t\t<div className=\"border-t border-border/50 px-4 py-2\">\n\t\t\t\t\t<Text size=\"xxs\" type=\"discrete\">{footerText}</Text>\n\t\t\t\t</div>\n\t\t\t)}\n\t\t</div>\n\t);\n}\n\nMetricBar.displayName = 'MetricBar';\n","/**\n * MetricGrid — responsive grid of `Metric` cells. The grid is the workhorse\n * for KPI rows on dashboards: pass a list, choose a variant, and the\n * component handles layout / column counts / spacing.\n *\n * Variants are forwarded to `Metric` so a single grid can show either\n * standalone cards, bordered tints, or compact list rows.\n *\n * Column counts default to `auto` — the grid breaks at sm/lg/xl based on\n * the cell count. Override with `columns` to pin a specific layout.\n */\nimport { cn } from '@/lib/utils';\n\nimport { Metric } from '../metric/metric';\nimport type {\n\tMetricColorScheme,\n\tMetricData,\n\tMetricSize,\n\tMetricVariant,\n} from '../types';\n\nexport interface MetricGridProps {\n\tmetrics: MetricData[];\n\t/** Cell variant — restricted to grid-friendly layouts. */\n\tvariant?: Extract<MetricVariant, 'card' | 'compact' | 'bordered' | 'accent' | 'colored'>;\n\tsize?: MetricSize;\n\tcolorScheme?: MetricColorScheme;\n\t/** Force a fixed column count. `auto` picks based on cell count. */\n\tcolumns?: 'auto' | 1 | 2 | 3 | 4 | 6;\n\tgap?: 'sm' | 'md' | 'lg';\n\tshowSparklines?: boolean;\n\tshowChanges?: boolean;\n\tshowIcons?: boolean;\n\tloading?: boolean;\n\tclassName?: string;\n}\n\nconst GAP_CLASS: Record<NonNullable<MetricGridProps['gap']>, string> = {\n\tsm: 'gap-2',\n\tmd: 'gap-3',\n\tlg: 'gap-4',\n};\n\nfunction autoColumnsFor(count: number): string {\n\tif (count <= 1) return 'grid-cols-1';\n\tif (count === 2) return 'grid-cols-1 sm:grid-cols-2';\n\tif (count === 3) return 'grid-cols-1 sm:grid-cols-2 lg:grid-cols-3';\n\tif (count === 4) return 'grid-cols-1 sm:grid-cols-2 lg:grid-cols-4';\n\tif (count === 5 || count === 6) return 'grid-cols-2 sm:grid-cols-3 lg:grid-cols-6';\n\treturn 'grid-cols-1 sm:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4';\n}\n\nconst COLUMN_CLASS: Record<Exclude<NonNullable<MetricGridProps['columns']>, 'auto'>, string> = {\n\t1: 'grid-cols-1',\n\t2: 'grid-cols-1 sm:grid-cols-2',\n\t3: 'grid-cols-1 sm:grid-cols-2 lg:grid-cols-3',\n\t4: 'grid-cols-1 sm:grid-cols-2 lg:grid-cols-4',\n\t6: 'grid-cols-2 sm:grid-cols-3 lg:grid-cols-6',\n};\n\nexport function MetricGrid({\n\tmetrics,\n\tvariant = 'card',\n\tsize = 'md',\n\tcolorScheme = 'default',\n\tcolumns = 'auto',\n\tgap = 'md',\n\tshowSparklines = true,\n\tshowChanges = true,\n\tshowIcons = true,\n\tloading = false,\n\tclassName,\n}: MetricGridProps) {\n\tconst columnsClass = columns === 'auto' ? autoColumnsFor(metrics.length) : COLUMN_CLASS[columns];\n\n\treturn (\n\t\t<div className={cn('metric-grid--component', 'grid', columnsClass, GAP_CLASS[gap], className)}>\n\t\t\t{metrics.map((metric) => (\n\t\t\t\t<Metric\n\t\t\t\t\tkey={metric.id}\n\t\t\t\t\tdata={metric}\n\t\t\t\t\tvariant={variant}\n\t\t\t\t\tsize={size}\n\t\t\t\t\tcolorScheme={colorScheme}\n\t\t\t\t\tshowSparkline={showSparklines}\n\t\t\t\t\tshowChange={showChanges}\n\t\t\t\t\tshowIcon={showIcons}\n\t\t\t\t\tloading={loading}\n\t\t\t\t/>\n\t\t\t))}\n\t\t</div>\n\t);\n}\n\nMetricGrid.displayName = 'MetricGrid';\n","/**\n * MetricComparison — period-over-period comparison surface.\n *\n * Renders two side-by-side `Metric.bordered`-style boxes for current vs\n * previous, with a delta block below showing absolute + percent change in\n * a tone-tinted box. Layout stacks vertically below the `sm` breakpoint.\n *\n * Accepts `MetricData` for both halves so format hints (currency, percent,\n * duration) carry over consistently. Strings overridable for i18n.\n */\nimport { ArrowDown, ArrowRight, ArrowUp, Equal } from 'lucide-react';\n\nimport { SmartCard } from '@/components/base/cards';\nimport { Heading, Text } from '@/components/typography';\nimport { useStrings } from '@/lib/strings';\nimport { cn } from '@/lib/utils';\n\nimport { formatMetricValue } from '../format-metric-value';\nimport type { MetricData } from '../types';\n\nexport interface MetricComparisonStrings {\n\ttitle: string;\n\tcurrentLabel: string;\n\tpreviousLabel: string;\n\tsuffix: string;\n}\n\nexport const defaultMetricComparisonStrings: MetricComparisonStrings = {\n\ttitle: 'Comparison',\n\tcurrentLabel: 'This period',\n\tpreviousLabel: 'Previous period',\n\tsuffix: 'vs previous',\n};\n\nexport interface MetricComparisonProps {\n\tcurrent: MetricData;\n\tprevious: MetricData;\n\ttitle?: string;\n\tcurrentPeriod?: string;\n\tpreviousPeriod?: string;\n\tclassName?: string;\n\tstrings?: Partial<MetricComparisonStrings>;\n}\n\nfunction toNumber(value: MetricData['value']): number | null {\n\tif (value === null || value === undefined) return null;\n\tif (typeof value === 'number') return value;\n\tconst n = Number(value);\n\treturn Number.isFinite(n) ? n : null;\n}\n\nexport function MetricComparison({\n\tcurrent,\n\tprevious,\n\ttitle,\n\tcurrentPeriod,\n\tpreviousPeriod,\n\tclassName,\n\tstrings: stringsProp,\n}: MetricComparisonProps) {\n\tconst strings = useStrings(defaultMetricComparisonStrings, {\n\t\t...(title ? { title } : {}),\n\t\t...stringsProp,\n\t});\n\n\tconst currentNum = toNumber(current.value);\n\tconst previousNum = toNumber(previous.value);\n\tconst canCompute = currentNum !== null && previousNum !== null;\n\tconst delta = canCompute ? (currentNum as number) - (previousNum as number) : 0;\n\tconst deltaPct = canCompute && (previousNum as number) !== 0\n\t\t? Math.round((delta / (previousNum as number)) * 100)\n\t\t: 0;\n\tconst isUp = delta > 0;\n\tconst isFlat = delta === 0;\n\tconst Arrow = isFlat ? Equal : isUp ? ArrowUp : ArrowDown;\n\n\tconst tone = isFlat\n\t\t? { box: 'bg-muted/40', chip: 'bg-card text-muted-foreground border border-border/60' }\n\t\t: isUp\n\t\t\t? { box: 'bg-success/10', chip: 'bg-success/15 text-success' }\n\t\t\t: { box: 'bg-destructive/10', chip: 'bg-destructive/15 text-destructive' };\n\n\tconst formatDelta = (value: number) => {\n\t\tconst abs = Math.abs(value);\n\t\t// reuse the formatter so currency/percent metrics render correctly\n\t\treturn formatMetricValue({ ...current, value: abs });\n\t};\n\n\treturn (\n\t\t<SmartCard title={strings.title} className={cn('metric-comparison--component', className)}>\n\t\t\t{!!(currentPeriod || previousPeriod) && (\n\t\t\t\t<div className=\"flex flex-wrap items-center gap-1.5\">\n\t\t\t\t\t{!!currentPeriod && (\n\t\t\t\t\t\t<Text\n\t\t\t\t\t\t\ttag=\"span\"\n\t\t\t\t\t\t\tsize=\"xxs\"\n\t\t\t\t\t\t\tweight=\"medium\"\n\t\t\t\t\t\t\tclassName=\"rounded-full bg-muted px-2 py-0.5 uppercase tracking-wider text-muted-foreground\"\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{currentPeriod}\n\t\t\t\t\t\t</Text>\n\t\t\t\t\t)}\n\t\t\t\t\t{!!previousPeriod && (\n\t\t\t\t\t\t<Text\n\t\t\t\t\t\t\ttag=\"span\"\n\t\t\t\t\t\t\tsize=\"xxs\"\n\t\t\t\t\t\t\tweight=\"medium\"\n\t\t\t\t\t\t\tclassName=\"rounded-full bg-muted/40 px-2 py-0.5 uppercase tracking-wider text-muted-foreground/70\"\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{previousPeriod}\n\t\t\t\t\t\t</Text>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t)}\n\n\t\t\t<div className=\"mt-3 grid items-stretch gap-2 grid-cols-1 sm:grid-cols-[1fr_auto_1fr]\">\n\t\t\t\t<div className=\"rounded-lg border border-border/60 bg-card px-3 py-2.5\">\n\t\t\t\t\t<Text size=\"xxs\" type=\"secondary\" weight=\"medium\" className=\"uppercase tracking-wider\">\n\t\t\t\t\t\t{strings.currentLabel}\n\t\t\t\t\t</Text>\n\t\t\t\t\t<Heading tag=\"h5\" className=\"text-xl tabular-nums tracking-tight border-none pb-0\">\n\t\t\t\t\t\t{formatMetricValue(current)}\n\t\t\t\t\t</Heading>\n\t\t\t\t</div>\n\t\t\t\t<div className=\"flex items-center justify-center text-muted-foreground/60\">\n\t\t\t\t\t<ArrowRight className=\"hidden size-4 sm:block\" aria-hidden=\"true\" />\n\t\t\t\t\t<ArrowDown className=\"size-4 sm:hidden\" aria-hidden=\"true\" />\n\t\t\t\t</div>\n\t\t\t\t<div className=\"rounded-lg bg-muted/40 px-3 py-2.5\">\n\t\t\t\t\t<Text size=\"xxs\" weight=\"medium\" className=\"uppercase tracking-wider text-muted-foreground/70\">\n\t\t\t\t\t\t{strings.previousLabel}\n\t\t\t\t\t</Text>\n\t\t\t\t\t<Heading tag=\"h5\" className=\"text-xl tabular-nums tracking-tight border-none pb-0 text-muted-foreground\">\n\t\t\t\t\t\t{formatMetricValue(previous)}\n\t\t\t\t\t</Heading>\n\t\t\t\t</div>\n\t\t\t</div>\n\n\t\t\t{!!canCompute && (\n\t\t\t\t<div className={cn('mt-3 flex flex-wrap items-center gap-2 rounded-lg px-3 py-2', tone.box)}>\n\t\t\t\t\t<div className={cn('inline-flex items-center gap-1 rounded-full px-2 py-0.5', tone.chip)}>\n\t\t\t\t\t\t<Arrow className=\"size-3\" strokeWidth={2.5} aria-hidden=\"true\" />\n\t\t\t\t\t\t<Text tag=\"span\" size=\"xs\" weight=\"semibold\" className=\"tabular-nums\">\n\t\t\t\t\t\t\t{isUp ? '+' : isFlat ? '' : '−'}{formatDelta(delta)}\n\t\t\t\t\t\t</Text>\n\t\t\t\t\t</div>\n\t\t\t\t\t<Text size=\"xs\" type=\"secondary\" className=\"tabular-nums\">\n\t\t\t\t\t\t{isUp ? '+' : isFlat ? '' : '−'}{Math.abs(deltaPct)}% {strings.suffix}\n\t\t\t\t\t</Text>\n\t\t\t\t</div>\n\t\t\t)}\n\t\t</SmartCard>\n\t);\n}\n\nMetricComparison.displayName = 'MetricComparison';\n","/**\n * MetricMicroGrid — six-cell dense KPI overview where each cell pairs a\n * label/value with a different lightweight visualization (bars / line /\n * dots / progress / area / pie). Useful as a top-of-page summary widget\n * on a packed dashboard.\n *\n * Cells are positional: index 0 → bars, 1 → line, 2 → dots, 3 → progress,\n * 4 → area, 5 → pie. To pin a specific renderer, pass `chart` per cell.\n */\nimport { useId } from 'react';\nimport { Area, AreaChart, ResponsiveContainer } from 'recharts';\n\nimport { SmartCard } from '@/components/base/cards';\nimport { Text } from '@/components/typography';\nimport { cn } from '@/lib/utils';\n\nexport type MicroChartKind = 'bars' | 'line' | 'dots' | 'progress' | 'area' | 'pie';\n\nexport interface MicroMetricCell {\n\tid?: string;\n\tlabel: string;\n\tvalue: string;\n\tdata: readonly number[];\n\tchart?: MicroChartKind;\n}\n\nexport interface MetricMicroGridProps {\n\ttitle?: string;\n\tcells: readonly MicroMetricCell[];\n\tclassName?: string;\n}\n\nconst DEFAULT_ORDER: MicroChartKind[] = ['bars', 'line', 'dots', 'progress', 'area', 'pie'];\n\nconst CHART_COLORS: Record<MicroChartKind, string> = {\n\tbars: 'var(--primary)',\n\tline: 'var(--info)',\n\tdots: 'var(--warning)',\n\tprogress: 'var(--success)',\n\tarea: 'var(--primary)',\n\tpie: 'var(--success)',\n};\n\nconst PIE_PALETTE = ['var(--success)', 'var(--info)', 'var(--warning)'];\n\nfunction MicroBars({ data, color }: { data: readonly number[]; color: string }) {\n\tconst max = Math.max(...data, 1);\n\treturn (\n\t\t<div className={cn('metric-micro-grid--component', 'flex h-5 items-end gap-[2px]')}>\n\t\t\t{data.slice(0, 6).map((v, i) => (\n\t\t\t\t<div\n\t\t\t\t\tkey={`bar-${i}`}\n\t\t\t\t\tclassName=\"flex-1 rounded-t-sm\"\n\t\t\t\t\tstyle={{ height: `${(v / max) * 100}%`, backgroundColor: color, opacity: 0.8 }}\n\t\t\t\t/>\n\t\t\t))}\n\t\t</div>\n\t);\n}\n\nfunction MicroLine({ data, color }: { data: readonly number[]; color: string }) {\n\tconst max = Math.max(...data, 1);\n\tconst min = Math.min(...data);\n\tconst range = max - min || 1;\n\tconst points = data.slice(0, 6);\n\treturn (\n\t\t<svg viewBox=\"0 0 60 16\" className=\"h-5 w-full\" preserveAspectRatio=\"none\">\n\t\t\t<polyline\n\t\t\t\tfill=\"none\"\n\t\t\t\tstroke={color}\n\t\t\t\tstrokeWidth=\"1.5\"\n\t\t\t\tstrokeLinecap=\"round\"\n\t\t\t\tstrokeLinejoin=\"round\"\n\t\t\t\tpoints={points\n\t\t\t\t\t.map((v, i) => `${(i / Math.max(points.length - 1, 1)) * 60},${16 - ((v - min) / range) * 14}`)\n\t\t\t\t\t.join(' ')}\n\t\t\t/>\n\t\t</svg>\n\t);\n}\n\nfunction MicroDots({ data, color }: { data: readonly number[]; color: string }) {\n\tconst max = Math.max(...data, 1);\n\treturn (\n\t\t<div className=\"flex h-5 items-end justify-around\">\n\t\t\t{data.slice(0, 5).map((v, i) => (\n\t\t\t\t<div\n\t\t\t\t\tkey={`dot-${i}`}\n\t\t\t\t\tclassName=\"h-1.5 w-1.5 rounded-full\"\n\t\t\t\t\tstyle={{ marginBottom: `${(v / max) * 12}px`, backgroundColor: color }}\n\t\t\t\t/>\n\t\t\t))}\n\t\t</div>\n\t);\n}\n\nfunction MicroProgress({ data, color }: { data: readonly number[]; color: string }) {\n\tconst value = data[0] ?? 0;\n\tconst max = data[1] ?? 100;\n\tconst pct = Math.min((value / max) * 100, 100);\n\treturn (\n\t\t<div className=\"h-1.5 w-full overflow-hidden rounded-full bg-muted\">\n\t\t\t<div className=\"h-full rounded-full transition-all\" style={{ width: `${pct}%`, backgroundColor: color }} />\n\t\t</div>\n\t);\n}\n\nfunction MicroAreaChart({ data, color }: { data: readonly number[]; color: string }) {\n\tconst id = useId();\n\tconst gradId = `micro-area-${id.replaceAll(':', '')}`;\n\tconst chartData = data.map((v, i) => ({ i, v }));\n\treturn (\n\t\t<div className=\"h-5 w-full\">\n\t\t\t<ResponsiveContainer width=\"100%\" height=\"100%\" initialDimension={{ width: 1, height: 1 }}>\n\t\t\t\t<AreaChart data={chartData} margin={{ top: 0, right: 0, bottom: 0, left: 0 }}>\n\t\t\t\t\t<defs>\n\t\t\t\t\t\t<linearGradient id={gradId} x1=\"0\" y1=\"0\" x2=\"0\" y2=\"1\">\n\t\t\t\t\t\t\t<stop offset=\"0%\" stopColor={color} stopOpacity={0.3} />\n\t\t\t\t\t\t\t<stop offset=\"100%\" stopColor={color} stopOpacity={0} />\n\t\t\t\t\t\t</linearGradient>\n\t\t\t\t\t</defs>\n\t\t\t\t\t<Area type=\"monotone\" dataKey=\"v\" stroke={color} strokeWidth={1.25} fill={`url(#${gradId})`} />\n\t\t\t\t</AreaChart>\n\t\t\t</ResponsiveContainer>\n\t\t</div>\n\t);\n}\n\nfunction MicroPie({ data }: { data: readonly number[] }) {\n\tconst total = data.reduce((a, b) => a + b, 0) || 1;\n\tlet cumAngle = 0;\n\treturn (\n\t\t<svg viewBox=\"0 0 24 24\" className=\"h-6 w-6\">\n\t\t\t{data.slice(0, 3).map((v, i) => {\n\t\t\t\tconst angle = (v / total) * 360;\n\t\t\t\tconst startAngle = cumAngle;\n\t\t\t\tcumAngle += angle;\n\t\t\t\tconst startRad = ((startAngle - 90) * Math.PI) / 180;\n\t\t\t\tconst endRad = ((startAngle + angle - 90) * Math.PI) / 180;\n\t\t\t\tconst largeArc = angle > 180 ? 1 : 0;\n\t\t\t\tconst x1 = 12 + 10 * Math.cos(startRad);\n\t\t\t\tconst y1 = 12 + 10 * Math.sin(startRad);\n\t\t\t\tconst x2 = 12 + 10 * Math.cos(endRad);\n\t\t\t\tconst y2 = 12 + 10 * Math.sin(endRad);\n\t\t\t\treturn (\n\t\t\t\t\t<path\n\t\t\t\t\t\tkey={`slice-${i}`}\n\t\t\t\t\t\td={`M12,12 L${x1},${y1} A10,10 0 ${largeArc},1 ${x2},${y2} Z`}\n\t\t\t\t\t\tfill={PIE_PALETTE[i % PIE_PALETTE.length]}\n\t\t\t\t\t/>\n\t\t\t\t);\n\t\t\t})}\n\t\t</svg>\n\t);\n}\n\nfunction ChartFor({ kind, data }: { kind: MicroChartKind; data: readonly number[] }) {\n\tconst color = CHART_COLORS[kind];\n\tif (kind === 'bars') return <MicroBars data={data} color={color} />;\n\tif (kind === 'line') return <MicroLine data={data} color={color} />;\n\tif (kind === 'dots') return <MicroDots data={data} color={color} />;\n\tif (kind === 'progress') return <MicroProgress data={data} color={color} />;\n\tif (kind === 'area') return <MicroAreaChart data={data} color={color} />;\n\treturn <MicroPie data={data} />;\n}\n\nexport function MetricMicroGrid({ title = 'Overview', cells, className }: MetricMicroGridProps) {\n\treturn (\n\t\t<SmartCard title={title} className={className} padding=\"sm\">\n\t\t\t<div className=\"grid grid-cols-3 grid-rows-2 -m-2\">\n\t\t\t\t{cells.slice(0, 6).map((cell, i) => (\n\t\t\t\t\t<div\n\t\t\t\t\t\tkey={cell.id ?? cell.label}\n\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t'flex flex-col gap-1.5 px-3 py-2.5',\n\t\t\t\t\t\t\ti % 3 !== 2 && 'border-r border-border/50',\n\t\t\t\t\t\t\ti < 3 && 'border-b border-border/50',\n\t\t\t\t\t\t)}\n\t\t\t\t\t>\n\t\t\t\t\t\t<Text size=\"xxs\" type=\"secondary\" className=\"truncate uppercase tracking-wider\">\n\t\t\t\t\t\t\t{cell.label}\n\t\t\t\t\t\t</Text>\n\t\t\t\t\t\t<Text tag=\"span\" weight=\"bold\" className=\"tabular-nums truncate\">\n\t\t\t\t\t\t\t{cell.value}\n\t\t\t\t\t\t</Text>\n\t\t\t\t\t\t<div className=\"mt-auto\">\n\t\t\t\t\t\t\t<ChartFor kind={cell.chart ?? DEFAULT_ORDER[i]} data={cell.data} />\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t))}\n\t\t\t</div>\n\t\t</SmartCard>\n\t);\n}\n\nMetricMicroGrid.displayName = 'MetricMicroGrid';\n","/**\n * MetricGradient — vivid full-bleed gradient hero card with embedded area\n * chart. Used at the top of marketing dashboards or analytics overview\n * pages where a single metric earns the most visual weight.\n *\n * Themes (`green` / `purple` / `warm` / `ocean`) drive the gradient palette;\n * the data prop accepts a `readonly MetricDataPoint[]` so consumers can pass\n * named time-series points. Renders the active dot in white and the area\n * fill in a soft white-on-tone gradient for legibility.\n */\nimport { useId } from 'react';\nimport { Area, AreaChart, ResponsiveContainer, Tooltip } from 'recharts';\n\nimport { Heading, Text } from '@/components/typography';\nimport { cn } from '@/lib/utils';\n\nimport { MetricTrendChip } from '../atoms/metric-trend-chip';\nimport type { MetricChange, MetricDataPoint } from '../types';\n\nexport type MetricGradientTheme = 'green' | 'purple' | 'warm' | 'ocean';\n\nexport interface MetricGradientProps {\n\ttitle: string;\n\tvalue?: string;\n\tchange?: MetricChange;\n\tdata: readonly MetricDataPoint[];\n\ttheme?: MetricGradientTheme;\n\tsubtitle?: string;\n\tclassName?: string;\n}\n\nconst THEME_BG: Record<MetricGradientTheme, string> = {\n\tgreen: 'bg-gradient-to-br from-emerald-600 via-teal-700 to-emerald-800',\n\tpurple: 'bg-gradient-to-br from-violet-600 via-indigo-700 to-purple-800',\n\twarm: 'bg-gradient-to-br from-orange-500 via-rose-600 to-pink-700',\n\tocean: 'bg-gradient-to-br from-sky-600 via-cyan-700 to-blue-800',\n};\n\ninterface ChartTooltipPayload {\n\tvalue: number;\n\tname: string;\n\tcolor?: string;\n}\n\nfunction ChartTooltip({ active, payload, label }: { active?: boolean; payload?: ChartTooltipPayload[]; label?: string }) {\n\tif (!active || !payload?.length) return null;\n\treturn (\n\t\t<div className={cn('metric-gradient--component', 'rounded-lg bg-foreground/95 px-3 py-2 shadow-lg backdrop-blur-sm')}>\n\t\t\t{!!label && <Text size=\"xxs\" className=\"text-background/60 mb-1\">{label}</Text>}\n\t\t\t{payload.map((entry, idx) => (\n\t\t\t\t<div key={`tt-${idx}`} className=\"flex items-center gap-2\">\n\t\t\t\t\t<div className=\"size-2 rounded-full\" style={{ backgroundColor: entry.color ?? '#fff' }} aria-hidden=\"true\" />\n\t\t\t\t\t<Text size=\"xs\" weight=\"semibold\" className=\"text-background tabular-nums\">\n\t\t\t\t\t\t{typeof entry.value === 'number' ? entry.value.toLocaleString() : entry.value}\n\t\t\t\t\t</Text>\n\t\t\t\t</div>\n\t\t\t))}\n\t\t</div>\n\t);\n}\n\nexport function MetricGradient({\n\ttitle,\n\tvalue,\n\tchange,\n\tdata,\n\ttheme = 'green',\n\tsubtitle,\n\tclassName,\n}: MetricGradientProps) {\n\tconst id = useId();\n\tconst gradientId = `metric-grad-${id.replaceAll(':', '')}`;\n\n\treturn (\n\t\t<div\n\t\t\tclassName={cn(\n\t\t\t\t'relative overflow-hidden rounded-2xl p-5 text-white shadow-lg ring-1 ring-white/10',\n\t\t\t\tTHEME_BG[theme],\n\t\t\t\tclassName,\n\t\t\t)}\n\t\t>\n\t\t\t<div className=\"absolute -right-12 -top-12 size-44 rounded-full bg-white/[0.08] blur-2xl\" aria-hidden=\"true\" />\n\t\t\t<div className=\"absolute -bottom-8 -left-8 size-32 rounded-full bg-white/[0.06] blur-xl\" aria-hidden=\"true\" />\n\n\t\t\t<div className=\"relative flex items-start justify-between gap-3\">\n\t\t\t\t<div className=\"min-w-0\">\n\t\t\t\t\t<Text size=\"xs\" weight=\"medium\" className=\"uppercase tracking-wider text-white/70\">{title}</Text>\n\t\t\t\t\t{!!value && (\n\t\t\t\t\t\t<Heading\n\t\t\t\t\t\t\ttag=\"h3\"\n\t\t\t\t\t\t\tclassName=\"mt-1 text-3xl font-bold tabular-nums tracking-tight border-none pb-0 text-white leading-none\"\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{value}\n\t\t\t\t\t\t</Heading>\n\t\t\t\t\t)}\n\t\t\t\t\t{!!subtitle && <Text size=\"xs\" className=\"mt-1 text-white/70\">{subtitle}</Text>}\n\t\t\t\t</div>\n\t\t\t\t{!!change && (\n\t\t\t\t\t<MetricTrendChip\n\t\t\t\t\t\tchange={change}\n\t\t\t\t\t\ttrend={change.direction === 'up' ? 'positive' : change.direction === 'down' ? 'negative' : 'neutral'}\n\t\t\t\t\t\tsize=\"sm\"\n\t\t\t\t\t\tvariant=\"badge\"\n\t\t\t\t\t\tclassName=\"shrink-0 !bg-white/20 !text-white\"\n\t\t\t\t\t/>\n\t\t\t\t)}\n\t\t\t</div>\n\n\t\t\t<div className=\"relative -mx-1 mt-3 h-24\">\n\t\t\t\t<ResponsiveContainer width=\"100%\" height=\"100%\" initialDimension={{ width: 1, height: 1 }}>\n\t\t\t\t\t<AreaChart data={data as MetricDataPoint[]} margin={{ top: 4, right: 0, bottom: 0, left: 0 }}>\n\t\t\t\t\t\t<defs>\n\t\t\t\t\t\t\t<linearGradient id={gradientId} x1=\"0\" y1=\"0\" x2=\"0\" y2=\"1\">\n\t\t\t\t\t\t\t\t<stop offset=\"0%\" stopColor=\"white\" stopOpacity={0.3} />\n\t\t\t\t\t\t\t\t<stop offset=\"100%\" stopColor=\"white\" stopOpacity={0} />\n\t\t\t\t\t\t\t</linearGradient>\n\t\t\t\t\t\t</defs>\n\t\t\t\t\t\t<Tooltip content={<ChartTooltip />} cursor={{ stroke: 'rgba(255,255,255,0.4)', strokeWidth: 1 }} />\n\t\t\t\t\t\t<Area\n\t\t\t\t\t\t\ttype=\"monotone\"\n\t\t\t\t\t\t\tdataKey=\"value\"\n\t\t\t\t\t\t\tstroke=\"rgba(255,255,255,0.7)\"\n\t\t\t\t\t\t\tstrokeWidth={2}\n\t\t\t\t\t\t\tfill={`url(#${gradientId})`}\n\t\t\t\t\t\t\tdot={false}\n\t\t\t\t\t\t\tactiveDot={{ r: 4, strokeWidth: 2, fill: '#fff', stroke: 'rgba(255,255,255,0.7)' }}\n\t\t\t\t\t\t\tisAnimationActive\n\t\t\t\t\t\t\tanimationDuration={800}\n\t\t\t\t\t\t/>\n\t\t\t\t\t</AreaChart>\n\t\t\t\t</ResponsiveContainer>\n\t\t\t</div>\n\t\t</div>\n\t);\n}\n\nMetricGradient.displayName = 'MetricGradient';\n","/**\n * ActivityHeatmap — GitHub-style daily-activity calendar grid. Renders the\n * provided range as Monday-aligned columns with per-day intensity tinted\n * via the success palette. Month labels float above the grid; the legend\n * sits on the trailing edge.\n *\n * The layout uses absolute month labels with a 3-week minimum gap rule\n * so labels don't collide when a month starts mid-week.\n */\nimport { SmartCard } from '@/components/base/cards';\nimport { Text } from '@/components/typography';\nimport { useStrings } from '@/lib/strings';\nimport { cn } from '@/lib/utils';\n\nimport { defaultAnalyticsStrings } from '../analytics.strings';\nimport type { ActivityHeatmapDay, ActivityHeatmapProps, ActivityLevel } from './types';\n\nconst LEVEL_COLOR: Record<ActivityLevel, string> = {\n\t0: 'bg-muted',\n\t1: 'bg-success/20',\n\t2: 'bg-success/40',\n\t3: 'bg-success/65',\n\t4: 'bg-success',\n};\n\ninterface BuiltCalendar {\n\tweeks: (ActivityHeatmapDay | null)[][];\n\tmonthLabels: { label: string; weekIndex: number }[];\n}\n\nfunction buildCalendar(\n\tdata: readonly ActivityHeatmapDay[],\n\tmonthNames: readonly string[],\n): BuiltCalendar {\n\tif (data.length === 0) return { weeks: [], monthLabels: [] };\n\n\tconst sorted = [...data].sort((a, b) => a.date.localeCompare(b.date));\n\tconst startDate = new Date(sorted[0].date + 'T00:00:00');\n\tconst endDate = new Date(sorted[sorted.length - 1].date + 'T00:00:00');\n\n\tconst dayOfWeek = startDate.getDay();\n\tconst mondayOffset = dayOfWeek === 0 ? -6 : 1 - dayOfWeek;\n\tconst alignedStart = new Date(startDate);\n\talignedStart.setDate(alignedStart.getDate() + mondayOffset);\n\n\tconst dateMap = new Map<string, ActivityLevel>();\n\tfor (const d of sorted) dateMap.set(d.date, d.level);\n\n\tconst weeks: (ActivityHeatmapDay | null)[][] = [];\n\tconst monthLabels: { label: string; weekIndex: number }[] = [];\n\tlet lastMonth = -1;\n\tlet currentWeek: (ActivityHeatmapDay | null)[] = [];\n\n\tconst cursor = new Date(alignedStart);\n\twhile (cursor <= endDate) {\n\t\tconst dateStr = cursor.toISOString().slice(0, 10);\n\t\tconst dayIdx = (cursor.getDay() + 6) % 7;\n\n\t\tif (dayIdx === 0 && currentWeek.length > 0) {\n\t\t\tweeks.push(currentWeek);\n\t\t\tcurrentWeek = [];\n\t\t}\n\n\t\tconst month = cursor.getMonth();\n\t\tif (month !== lastMonth) {\n\t\t\tconst labelWeekIndex = dayIdx === 0 ? weeks.length : weeks.length + 1;\n\t\t\tconst existing = monthLabels.find((m) => m.weekIndex === labelWeekIndex);\n\t\t\tif (!existing) monthLabels.push({ label: monthNames[month], weekIndex: labelWeekIndex });\n\t\t\tlastMonth = month;\n\t\t}\n\n\t\tconst level = dateMap.get(dateStr) ?? 0;\n\t\tcurrentWeek.push({ date: dateStr, level });\n\t\tcursor.setDate(cursor.getDate() + 1);\n\t}\n\n\tif (currentWeek.length > 0) {\n\t\twhile (currentWeek.length < 7) currentWeek.push(null);\n\t\tweeks.push(currentWeek);\n\t}\n\n\treturn { weeks, monthLabels };\n}\n\nexport function ActivityHeatmap({\n\ttitle,\n\tdescription,\n\tdata,\n\tclassName,\n\tstrings: stringsProp,\n}: ActivityHeatmapProps) {\n\tconst strings = useStrings(defaultAnalyticsStrings, stringsProp);\n\tconst { weeks, monthLabels } = buildCalendar(data, strings.heatmapMonthNames);\n\n\treturn (\n\t\t<SmartCard title={title} description={description} className={cn('activity-heatmap--component', className)}>\n\t\t\t<div className=\"overflow-x-auto\">\n\t\t\t\t<div className=\"relative mb-1\" style={{ paddingLeft: '28px', height: '12px' }}>\n\t\t\t\t\t<div className=\"relative flex\" style={{ width: `${weeks.length * 15}px` }}>\n\t\t\t\t\t\t{monthLabels\n\t\t\t\t\t\t\t.filter((m, idx, arr) => idx === 0 || m.weekIndex - arr[idx - 1].weekIndex >= 3)\n\t\t\t\t\t\t\t.map((m) => (\n\t\t\t\t\t\t\t\t<Text\n\t\t\t\t\t\t\t\t\tkey={`${m.label}-${m.weekIndex}`}\n\t\t\t\t\t\t\t\t\tsize=\"xxs\"\n\t\t\t\t\t\t\t\t\ttype=\"secondary\"\n\t\t\t\t\t\t\t\t\tclassName=\"absolute leading-none whitespace-nowrap\"\n\t\t\t\t\t\t\t\t\tstyle={{ left: `${m.weekIndex * 15}px`, top: 0 }}\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t{m.label}\n\t\t\t\t\t\t\t\t</Text>\n\t\t\t\t\t\t\t))}\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\n\t\t\t\t<div className=\"flex gap-0\">\n\t\t\t\t\t<div className=\"mr-1 flex flex-col gap-[3px]\">\n\t\t\t\t\t\t{strings.heatmapDayLabels.map((label, i) => (\n\t\t\t\t\t\t\t<div key={`day-${i}`} className=\"flex h-3 w-6 items-center justify-end\">\n\t\t\t\t\t\t\t\t{!!label && (\n\t\t\t\t\t\t\t\t\t<Text size=\"xxs\" type=\"secondary\" className=\"leading-none\">{label}</Text>\n\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t))}\n\t\t\t\t\t</div>\n\n\t\t\t\t\t<div className=\"flex gap-[3px]\">\n\t\t\t\t\t\t{weeks.map((week, weekIdx) => (\n\t\t\t\t\t\t\t<div key={`w-${weekIdx}`} className=\"flex flex-col gap-[3px]\">\n\t\t\t\t\t\t\t\t{week.map((day, dayIdx) => {\n\t\t\t\t\t\t\t\t\tconst dayTitle = day ? `${day.date}: Level ${day.level}` : undefined;\n\t\t\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\t\t\tkey={`d-${weekIdx}-${dayIdx}`}\n\t\t\t\t\t\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\t\t\t\t\t'size-3 rounded-sm',\n\t\t\t\t\t\t\t\t\t\t\t\tday ? LEVEL_COLOR[day.level] : 'bg-transparent',\n\t\t\t\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t\t\t\t\ttitle={dayTitle}\n\t\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t))}\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</div>\n\n\t\t\t<div className=\"mt-4 flex items-center justify-end gap-1.5\">\n\t\t\t\t<Text size=\"xxs\" type=\"secondary\">{strings.heatmapLegendLess}</Text>\n\t\t\t\t{([0, 1, 2, 3, 4] as ActivityLevel[]).map((level) => (\n\t\t\t\t\t<div key={`legend-${level}`} className={cn('size-3 rounded-sm', LEVEL_COLOR[level])} />\n\t\t\t\t))}\n\t\t\t\t<Text size=\"xxs\" type=\"secondary\">{strings.heatmapLegendMore}</Text>\n\t\t\t</div>\n\t\t</SmartCard>\n\t);\n}\n\nActivityHeatmap.displayName = 'ActivityHeatmap';\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.cjs","names":[],"sources":["../../../../src/components/composed/analytics/analytics.strings.ts","../../../../src/components/composed/analytics/format-metric-value.ts","../../../../src/components/composed/analytics/atoms/metric-trend-chip.tsx","../../../../src/components/composed/analytics/atoms/metric-sparkline.tsx","../../../../src/components/composed/analytics/atoms/metric-skeleton.tsx","../../../../src/components/composed/analytics/metric/metric.tsx","../../../../src/components/composed/analytics/metric-bar/metric-bar.tsx","../../../../src/components/composed/analytics/metric-grid/metric-grid.tsx","../../../../src/components/composed/analytics/metric-comparison/metric-comparison.tsx","../../../../src/components/composed/analytics/metric-micro-grid/metric-micro-grid.tsx","../../../../src/components/composed/analytics/metric-gradient/metric-gradient.tsx","../../../../src/components/composed/analytics/activity-heatmap/activity-heatmap.tsx"],"sourcesContent":["/**\n * Shared default strings for `composed/analytics` components.\n *\n * Each component accepts a `strings` prop deep-merged over these defaults\n * so consumers override per-component without touching the rest. Day/month\n * labels live here too because they're localisable in the same way.\n */\nexport interface AnalyticsStrings {\n /** Fallback shown by `<Metric />` when `error` is true. */\n metricErrorLabel: string;\n /** Default title for `<MetricComparison />` when no `title` prop is passed. */\n comparisonTitle: string;\n /** Labels for the activity heatmap weekday rows (Mon–Sun, length 7). */\n heatmapDayLabels: readonly [string, string, string, string, string, string, string];\n /** Short month names for the activity heatmap header (Jan–Dec, length 12). */\n heatmapMonthNames: readonly [\n string, string, string, string, string, string,\n string, string, string, string, string, string,\n ];\n /** Heatmap legend \"less\" label (left edge of intensity legend). */\n heatmapLegendLess: string;\n /** Heatmap legend \"more\" label (right edge of intensity legend). */\n heatmapLegendMore: string;\n}\n\nexport const defaultAnalyticsStrings: AnalyticsStrings = {\n metricErrorLabel: 'Unable to load metric',\n comparisonTitle: 'Comparison',\n heatmapDayLabels: ['Mon', '', 'Wed', '', 'Fri', '', ''],\n heatmapMonthNames: [\n 'Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun',\n 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec',\n ],\n heatmapLegendLess: 'Less',\n heatmapLegendMore: 'More',\n};\n","/**\n * formatMetricValue — single canonical formatter for every metric surface.\n *\n * Keeps formatting logic out of the layout components so the same dataset\n * renders identically regardless of which `Metric*` variant displays it.\n */\nimport {\n\tEMPTY,\n\tformatCurrency,\n\tformatDuration,\n\tformatNumber,\n\tformatPercentage,\n} from '@/lib/format';\nimport type { MetricData } from './types';\n\nexport function formatMetricValue(data: MetricData): string {\n\tif (data.value === null || data.value === undefined) return EMPTY;\n\n\tconst value = data.value;\n\tconst numeric = typeof value === 'number' ? value : null;\n\n\tswitch (data.valueType) {\n\t\tcase 'currency':\n\t\t\treturn numeric !== null\n\t\t\t\t? formatCurrency(numeric, { currency: data.currency })\n\t\t\t\t: String(value);\n\t\tcase 'percentage':\n\t\t\treturn numeric !== null ? formatPercentage(numeric) : String(value);\n\t\tcase 'duration':\n\t\t\treturn numeric !== null ? formatDuration(numeric) : String(value);\n\t\tcase 'number':\n\t\t\treturn numeric !== null ? formatNumber(numeric) : String(value);\n\t\tcase 'text':\n\t\tdefault:\n\t\t\treturn String(value);\n\t}\n}\n\n/**\n * Resolve the effective `MetricTrend` for a metric — explicit `trend` wins,\n * otherwise we infer from `change.direction` (`up` → positive, `down` →\n * negative, `neutral`/missing → neutral).\n */\nexport function resolveTrend(data: MetricData): 'positive' | 'negative' | 'neutral' {\n\tif (data.trend) return data.trend;\n\tif (data.change?.direction === 'up') return 'positive';\n\tif (data.change?.direction === 'down') return 'negative';\n\treturn 'neutral';\n}\n","/**\n * MetricTrendChip — compact ↑/↓/→ delta indicator.\n *\n * Decouples direction (up/down/neutral) from tone (positive/negative/neutral)\n * so consumers can flip the colour for inverted metrics like churn or refund\n * rate. Four variants:\n * - `default` — coloured icon + value, no chrome\n * - `badge` — pill with tinted bg + arrow icon\n * - `compact` — coloured arrow + value, no spacing\n * - `inline` — value only with sign prefix, no icon\n */\nimport { ArrowDown, ArrowUp, Minus } from 'lucide-react';\nimport { Text } from '@/components/typography';\nimport { cn } from '@/lib/utils';\n\nimport type { MetricChange, MetricSize, MetricTrend, MetricTrendVariant } from '../types';\n\ninterface MetricTrendChipProps {\n\tchange: MetricChange;\n\ttrend?: MetricTrend;\n\tsize?: MetricSize;\n\tvariant?: MetricTrendVariant;\n\tclassName?: string;\n}\n\nconst TONE_CLASSES: Record<MetricTrend, { text: string; badge: string; arrow: string }> = {\n\tpositive: { text: 'text-success', badge: 'bg-success/10 text-success', arrow: 'text-success' },\n\tnegative: { text: 'text-destructive', badge: 'bg-destructive/10 text-destructive', arrow: 'text-destructive' },\n\tneutral: { text: 'text-muted-foreground', badge: 'bg-muted text-muted-foreground', arrow: 'text-muted-foreground' },\n};\n\nconst ICON_SIZE: Record<MetricSize, string> = {\n\tsm: 'size-3',\n\tmd: 'size-3.5',\n\tlg: 'size-4',\n};\n\nconst TEXT_SIZE: Record<MetricSize, 'xxs' | 'xs' | 'sm'> = {\n\tsm: 'xxs',\n\tmd: 'xs',\n\tlg: 'sm',\n};\n\nconst BADGE_PADDING: Record<MetricSize, string> = {\n\tsm: 'px-1.5 py-0.5',\n\tmd: 'px-2 py-0.5',\n\tlg: 'px-2.5 py-1',\n};\n\nfunction resolveTone(trend: MetricTrend | undefined, direction: MetricChange['direction']): MetricTrend {\n\tif (trend) return trend;\n\tif (direction === 'up') return 'positive';\n\tif (direction === 'down') return 'negative';\n\treturn 'neutral';\n}\n\nexport function MetricTrendChip({\n\tchange,\n\ttrend,\n\tsize = 'md',\n\tvariant = 'default',\n\tclassName,\n}: MetricTrendChipProps) {\n\tconst tone = resolveTone(trend, change.direction);\n\tconst Icon = change.direction === 'up' ? ArrowUp : change.direction === 'down' ? ArrowDown : Minus;\n\tconst palette = TONE_CLASSES[tone];\n\tconst valueText = String(change.value);\n\tconst sign = change.direction === 'up' ? '+' : change.direction === 'down' ? '' : '';\n\n\tif (variant === 'inline') {\n\t\treturn (\n\t\t\t<Text tag=\"span\" size={TEXT_SIZE[size]} weight=\"medium\" className={cn('metric-trend-chip--component', palette.text, 'tabular-nums', className)}>\n\t\t\t\t{sign}{valueText}\n\t\t\t</Text>\n\t\t);\n\t}\n\n\tif (variant === 'compact') {\n\t\treturn (\n\t\t\t<span className={cn('inline-flex items-center gap-0.5', palette.text, className)}>\n\t\t\t\t<Icon className={ICON_SIZE[size]} strokeWidth={2.5} aria-hidden=\"true\" />\n\t\t\t\t<Text tag=\"span\" size={TEXT_SIZE[size]} weight=\"semibold\" className=\"tabular-nums\">\n\t\t\t\t\t{valueText}\n\t\t\t\t</Text>\n\t\t\t</span>\n\t\t);\n\t}\n\n\tif (variant === 'badge') {\n\t\treturn (\n\t\t\t<span className={cn('inline-flex items-center gap-1 rounded-full font-medium tabular-nums', palette.badge, BADGE_PADDING[size], className)}>\n\t\t\t\t<Icon className={ICON_SIZE[size]} strokeWidth={2.5} aria-hidden=\"true\" />\n\t\t\t\t<Text tag=\"span\" size={TEXT_SIZE[size]} weight=\"semibold\" className=\"tabular-nums\">\n\t\t\t\t\t{valueText}\n\t\t\t\t</Text>\n\t\t\t\t{!!change.label && (\n\t\t\t\t\t<Text tag=\"span\" size={TEXT_SIZE[size]} className=\"opacity-70\">{change.label}</Text>\n\t\t\t\t)}\n\t\t\t</span>\n\t\t);\n\t}\n\n\t// default\n\treturn (\n\t\t<span className={cn('inline-flex items-center gap-1', palette.text, className)}>\n\t\t\t<Icon className={ICON_SIZE[size]} strokeWidth={2.5} aria-hidden=\"true\" />\n\t\t\t<Text tag=\"span\" size={TEXT_SIZE[size]} weight=\"semibold\" className=\"tabular-nums\">\n\t\t\t\t{valueText}\n\t\t\t</Text>\n\t\t\t{!!change.label && (\n\t\t\t\t<Text tag=\"span\" size={TEXT_SIZE[size]} type=\"secondary\">{change.label}</Text>\n\t\t\t)}\n\t\t</span>\n\t);\n}\n\nMetricTrendChip.displayName = 'MetricTrendChip';\n","/**\n * MetricSparkline — recharts-backed mini area chart used inside Metric\n * variants. Auto-stretches to its container; pass a fixed height (e.g.\n * `h-8 w-full`) on the wrapper. `trend` colours the stroke + gradient\n * (positive/negative/neutral); `color` overrides with any CSS colour\n * (semantic var, hex, rgb).\n */\nimport { useId, useMemo } from 'react';\nimport { Area, AreaChart, ResponsiveContainer } from 'recharts';\nimport { cn } from '@/lib/utils';\n\nimport type { MetricTrend } from '../types';\n\ninterface MetricSparklineProps {\n\tdata: readonly number[];\n\ttrend?: MetricTrend;\n\tcolor?: string;\n\tclassName?: string;\n\tanimated?: boolean;\n\t'aria-label'?: string;\n}\n\nconst TREND_COLORS: Record<MetricTrend, string> = {\n\tpositive: 'var(--success)',\n\tnegative: 'var(--destructive)',\n\tneutral: 'var(--muted-foreground)',\n};\n\nexport function MetricSparkline({\n\tdata,\n\ttrend = 'neutral',\n\tcolor,\n\tclassName,\n\tanimated = true,\n\t'aria-label': ariaLabel = 'Trend sparkline',\n}: MetricSparklineProps) {\n\tconst id = useId();\n\tconst gradientId = useMemo(() => `metric-spark-${id.replaceAll(':', '')}`, [id]);\n\tconst stroke = color ?? TREND_COLORS[trend];\n\n\tconst chartData = useMemo(() => {\n\t\tif (!Array.isArray(data) || data.length === 0) return [];\n\t\treturn data.map((value, i) => ({ i, v: value }));\n\t}, [data]);\n\n\tif (chartData.length === 0) {\n\t\treturn <div className={cn('metric-sparkline--component', 'w-full', className)} aria-hidden=\"true\" />;\n\t}\n\n\treturn (\n\t\t<div className={cn('w-full', className)} role=\"img\" aria-label={ariaLabel}>\n\t\t\t<ResponsiveContainer width=\"100%\" height=\"100%\" initialDimension={{ width: 1, height: 1 }}>\n\t\t\t\t<AreaChart data={chartData} margin={{ top: 2, right: 0, bottom: 0, left: 0 }}>\n\t\t\t\t\t<defs>\n\t\t\t\t\t\t<linearGradient id={gradientId} x1=\"0\" y1=\"0\" x2=\"0\" y2=\"1\">\n\t\t\t\t\t\t\t<stop offset=\"0%\" stopColor={stroke} stopOpacity={0.25} />\n\t\t\t\t\t\t\t<stop offset=\"100%\" stopColor={stroke} stopOpacity={0} />\n\t\t\t\t\t\t</linearGradient>\n\t\t\t\t\t</defs>\n\t\t\t\t\t<Area\n\t\t\t\t\t\ttype=\"monotone\"\n\t\t\t\t\t\tdataKey=\"v\"\n\t\t\t\t\t\tstroke={stroke}\n\t\t\t\t\t\tstrokeWidth={1.75}\n\t\t\t\t\t\tfill={`url(#${gradientId})`}\n\t\t\t\t\t\tdot={false}\n\t\t\t\t\t\tactiveDot={false}\n\t\t\t\t\t\tisAnimationActive={animated}\n\t\t\t\t\t\tanimationDuration={600}\n\t\t\t\t\t/>\n\t\t\t\t</AreaChart>\n\t\t\t</ResponsiveContainer>\n\t\t</div>\n\t);\n}\n\nMetricSparkline.displayName = 'MetricSparkline';\n","/**\n * MetricSkeleton — loading placeholder matching the height/spacing of every\n * `Metric` variant so the layout doesn't jump when data resolves.\n */\nimport { cn } from '@/lib/utils';\nimport type { MetricSize, MetricVariant } from '../types';\n\ninterface MetricSkeletonProps {\n\tvariant?: MetricVariant;\n\tsize?: MetricSize;\n\tclassName?: string;\n}\n\nconst Bar = ({ className }: { className?: string }) => (\n\t<div className={cn('animate-pulse rounded bg-muted', className)} />\n);\n\nexport function MetricSkeleton({\n\tvariant = 'default',\n\tsize = 'md',\n\tclassName,\n}: MetricSkeletonProps) {\n\tconst padding = size === 'sm' ? 'p-3' : size === 'lg' ? 'p-5' : 'p-4';\n\n\tif (variant === 'card' || variant === 'bordered' || variant === 'accent' || variant === 'colored') {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tclassName={cn('metric-skeleton--component', \n\t\t\t\t\t'rounded-xl border border-border bg-card shadow-sm',\n\t\t\t\t\tpadding,\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t\taria-busy=\"true\"\n\t\t\t\taria-live=\"polite\"\n\t\t\t>\n\t\t\t\t<Bar className=\"h-3 w-24\" />\n\t\t\t\t<Bar className={cn('mt-3', size === 'lg' ? 'h-9 w-40' : 'h-7 w-32')} />\n\t\t\t\t<Bar className=\"mt-2 h-3 w-20\" />\n\t\t\t\t<Bar className=\"mt-3 h-8 w-full\" />\n\t\t\t</div>\n\t\t);\n\t}\n\n\tif (variant === 'compact') {\n\t\treturn (\n\t\t\t<div className={cn('flex items-center gap-3', className)} aria-busy=\"true\">\n\t\t\t\t<Bar className=\"size-9 rounded-lg\" />\n\t\t\t\t<div className=\"flex-1 space-y-1.5\">\n\t\t\t\t\t<Bar className=\"h-3 w-20\" />\n\t\t\t\t\t<Bar className=\"h-4 w-28\" />\n\t\t\t\t</div>\n\t\t\t\t<Bar className=\"h-5 w-12 rounded-full\" />\n\t\t\t</div>\n\t\t);\n\t}\n\n\tif (variant === 'minimal') {\n\t\treturn (\n\t\t\t<div className={cn('inline-flex items-baseline gap-2', className)} aria-busy=\"true\">\n\t\t\t\t<Bar className=\"h-3 w-12\" />\n\t\t\t\t<Bar className=\"h-3 w-16\" />\n\t\t\t</div>\n\t\t);\n\t}\n\n\t// default\n\treturn (\n\t\t<div className={cn('flex flex-col gap-1.5', padding, className)} aria-busy=\"true\">\n\t\t\t<Bar className=\"h-3 w-20\" />\n\t\t\t<Bar className=\"h-5 w-28\" />\n\t\t\t<Bar className=\"mt-1 h-6 w-full\" />\n\t\t</div>\n\t);\n}\n\nMetricSkeleton.displayName = 'MetricSkeleton';\n","/**\n * Metric — canonical single-metric surface. One component, seven variants:\n *\n * default — flat tile (label / value / trend / sparkline) for use inside\n * MetricBar or other composed surfaces.\n * card — wrapped in SmartCard with shadow, padding, optional tooltip.\n * Use as a standalone hero in a row of three.\n * compact — single-row icon + label + value + chip. Sidebar / list use.\n * minimal — inline `Label: value ↑12%` chip for in-flow copy.\n * bordered — soft tinted border keyed off `colorScheme`.\n * accent — dark surface card with bottom-aligned area sparkline.\n * colored — segmented progress bar (driven by `progress` prop).\n *\n * All variants share the same `MetricData` shape; only the layout changes.\n */\nimport { useMemo } from 'react';\nimport { ArrowUpRight } from 'lucide-react';\n\nimport { SmartCard } from '@/components/base/cards';\nimport { Heading, Text } from '@/components/typography';\nimport { cn } from '@/lib/utils';\n\nimport { defaultAnalyticsStrings } from '../analytics.strings';\nimport { MetricSkeleton } from '../atoms/metric-skeleton';\nimport { MetricSparkline } from '../atoms/metric-sparkline';\nimport { MetricTrendChip } from '../atoms/metric-trend-chip';\nimport { formatMetricValue, resolveTrend } from '../format-metric-value';\nimport type {\n\tMetricColorScheme,\n\tMetricData,\n\tMetricSize,\n\tMetricVariant,\n} from '../types';\n\nexport interface MetricProps {\n\tdata: MetricData;\n\tvariant?: MetricVariant;\n\tsize?: MetricSize;\n\tcolorScheme?: MetricColorScheme;\n\tshowSparkline?: boolean;\n\tshowChange?: boolean;\n\tshowIcon?: boolean;\n\tloading?: boolean;\n\terror?: boolean;\n\terrorLabel?: string;\n\t/** `colored` variant only — 0-100 fill percentage. */\n\tprogress?: number;\n\tclassName?: string;\n\t'aria-label'?: string;\n}\n\n// ── colour-scheme palettes (shared between bordered + colored variants) ──\nconst SCHEME_TINT: Record<MetricColorScheme, { border: string; bg: string; bar: string; dot: string; ring: string }> = {\n\tdefault: { border: 'border-border', bg: 'bg-card', bar: 'bg-foreground', dot: 'bg-foreground', ring: 'ring-border' },\n\tprimary: { border: 'border-primary/25', bg: 'bg-primary/5', bar: 'bg-primary', dot: 'bg-primary', ring: 'ring-primary/20' },\n\tsuccess: { border: 'border-success/30', bg: 'bg-success/5', bar: 'bg-success', dot: 'bg-success', ring: 'ring-success/20' },\n\twarning: { border: 'border-warning/40', bg: 'bg-warning/10', bar: 'bg-warning', dot: 'bg-warning', ring: 'ring-warning/30' },\n\tdanger: { border: 'border-destructive/30', bg: 'bg-destructive/5', bar: 'bg-destructive', dot: 'bg-destructive', ring: 'ring-destructive/20' },\n\tinfo: { border: 'border-info/30', bg: 'bg-info/5', bar: 'bg-info', dot: 'bg-info', ring: 'ring-info/20' },\n};\n\n/** Compact value sizes for in-grid / in-bar usage where horizontal space is tight. */\nconst VALUE_FONT_SIZE: Record<MetricSize, string> = {\n\tsm: 'text-sm',\n\tmd: 'text-lg',\n\tlg: 'text-xl',\n};\n\n/** Hero value sizes for standalone card / bordered / accent variants. */\nconst VALUE_FONT_SIZE_HERO: Record<MetricSize, string> = {\n\tsm: 'text-xl',\n\tmd: 'text-3xl',\n\tlg: 'text-4xl',\n};\n\nconst SPARKLINE_HEIGHT: Record<MetricSize, string> = {\n\tsm: 'h-6',\n\tmd: 'h-8',\n\tlg: 'h-10',\n};\n\nconst SEGMENT_COUNT = 16;\n\nexport function Metric(props: MetricProps) {\n\tconst {\n\t\tdata,\n\t\tvariant = 'default',\n\t\tsize = 'md',\n\t\tcolorScheme = 'default',\n\t\tshowSparkline = true,\n\t\tshowChange = true,\n\t\tshowIcon = true,\n\t\tloading = false,\n\t\terror = false,\n\t\terrorLabel,\n\t\tprogress = 0,\n\t\tclassName,\n\t\t'aria-label': ariaLabel,\n\t} = props;\n\n\tconst formattedValue = useMemo(() => formatMetricValue(data), [data]);\n\tconst trend = useMemo(() => resolveTrend(data), [data]);\n\n\tif (loading) return <MetricSkeleton variant={variant} size={size} className={cn('metric--component', className)} />;\n\tif (error) {\n\t\treturn (\n\t\t\t<div className={cn('flex items-center justify-center rounded-lg border border-border bg-card p-4 text-muted-foreground', className)}>\n\t\t\t\t<Text>{errorLabel ?? defaultAnalyticsStrings.metricErrorLabel}</Text>\n\t\t\t</div>\n\t\t);\n\t}\n\n\tconst sharedProps = {\n\t\tdata,\n\t\tformattedValue,\n\t\ttrend,\n\t\tsize,\n\t\tshowSparkline,\n\t\tshowChange,\n\t\tshowIcon,\n\t\tcolorScheme,\n\t\tariaLabel: ariaLabel ?? data.label,\n\t\tclassName,\n\t};\n\n\tswitch (variant) {\n\t\tcase 'card':\n\t\t\treturn <MetricCard {...sharedProps} />;\n\t\tcase 'compact':\n\t\t\treturn <MetricCompact {...sharedProps} />;\n\t\tcase 'minimal':\n\t\t\treturn <MetricMinimal {...sharedProps} />;\n\t\tcase 'bordered':\n\t\t\treturn <MetricBordered {...sharedProps} />;\n\t\tcase 'accent':\n\t\t\treturn <MetricAccent {...sharedProps} />;\n\t\tcase 'colored':\n\t\t\treturn <MetricColored {...sharedProps} progress={progress} />;\n\t\tdefault:\n\t\t\treturn <MetricDefault {...sharedProps} />;\n\t}\n}\n\nMetric.displayName = 'Metric';\n\n// ─────────────────────────────────────────────────────────────────────────\n// Internal sub-components — kept private. Each handles one variant only.\n// ─────────────────────────────────────────────────────────────────────────\n\ninterface SubProps {\n\tdata: MetricData;\n\tformattedValue: string;\n\ttrend: 'positive' | 'negative' | 'neutral';\n\tsize: MetricSize;\n\tshowSparkline: boolean;\n\tshowChange: boolean;\n\tshowIcon: boolean;\n\tcolorScheme: MetricColorScheme;\n\tariaLabel: string;\n\tclassName?: string;\n}\n\nfunction MetricDefault({ data, formattedValue, trend, size, showSparkline, showChange, showIcon, ariaLabel, className }: SubProps) {\n\tconst Icon = data.icon;\n\treturn (\n\t\t<div className={cn('flex min-w-0 flex-col gap-1', className)} aria-label={ariaLabel}>\n\t\t\t<div className=\"flex items-center gap-1.5 min-w-0 text-muted-foreground\">\n\t\t\t\t{!!showIcon && !!Icon && <Icon className=\"size-3.5 shrink-0\" aria-hidden=\"true\" />}\n\t\t\t\t<Text size=\"xs\" type=\"secondary\" weight=\"medium\" className=\"truncate\">{data.label}</Text>\n\t\t\t</div>\n\t\t\t<Heading\n\t\t\t\ttag=\"h5\"\n\t\t\t\tclassName={cn(\n\t\t\t\t\t'font-bold tabular-nums tracking-tight border-none pb-0 leading-tight truncate',\n\t\t\t\t\tVALUE_FONT_SIZE[size],\n\t\t\t\t)}\n\t\t\t\ttitle={formattedValue}\n\t\t\t>\n\t\t\t\t{formattedValue}\n\t\t\t</Heading>\n\t\t\t{!!showChange && !!data.change && (\n\t\t\t\t<div className=\"min-w-0\">\n\t\t\t\t\t<MetricTrendChip change={data.change} trend={data.trend} size={size} variant=\"compact\" />\n\t\t\t\t</div>\n\t\t\t)}\n\t\t\t{!!data.subtitle && <Text size=\"xs\" type=\"secondary\" className=\"truncate\">{data.subtitle}</Text>}\n\t\t\t{!!showSparkline && !!data.sparkline?.length && (\n\t\t\t\t<MetricSparkline data={data.sparkline} trend={trend} className={cn('mt-auto', SPARKLINE_HEIGHT[size])} />\n\t\t\t)}\n\t\t\t{!!data.footer && <Text size=\"xxs\" type=\"discrete\" className=\"truncate\">{data.footer}</Text>}\n\t\t</div>\n\t);\n}\n\nfunction MetricCard({ data, formattedValue, trend, size, showSparkline, showChange, showIcon, ariaLabel, className }: SubProps) {\n\tconst Icon = data.icon;\n\tconst isInteractive = Boolean(data.href || data.onClick);\n\tconst padding: 'sm' | 'base' | 'lg' = size === 'sm' ? 'sm' : size === 'lg' ? 'lg' : 'base';\n\n\tconst card = (\n\t\t<SmartCard\n\t\t\ttitle={data.label}\n\t\t\ticon={!!showIcon && !!Icon ? <Icon className=\"size-4\" aria-hidden=\"true\" /> : null}\n\t\t\ttooltip={data.tooltip}\n\t\t\tpadding={padding}\n\t\t\tclassName={cn(isInteractive && 'cursor-pointer transition-shadow hover:shadow-md', className)}\n\t\t\taria-label={ariaLabel}\n\t\t>\n\t\t\t<div className=\"flex items-baseline justify-between gap-3\">\n\t\t\t\t<Heading\n\t\t\t\t\ttag={size === 'sm' ? 'h5' : size === 'lg' ? 'h3' : 'h4'}\n\t\t\t\t\tclassName={cn('font-bold tabular-nums tracking-tight border-none pb-0 leading-none', VALUE_FONT_SIZE_HERO[size])}\n\t\t\t\t>\n\t\t\t\t\t{formattedValue}\n\t\t\t\t</Heading>\n\t\t\t\t{!!showChange && !!data.change && (\n\t\t\t\t\t<MetricTrendChip change={data.change} trend={data.trend} size={size} variant=\"badge\" />\n\t\t\t\t)}\n\t\t\t</div>\n\t\t\t{!!data.subtitle && <Text type=\"secondary\" className=\"mt-2\">{data.subtitle}</Text>}\n\t\t\t{!!showSparkline && !!data.sparkline?.length && (\n\t\t\t\t<MetricSparkline\n\t\t\t\t\tdata={data.sparkline}\n\t\t\t\t\ttrend={trend}\n\t\t\t\t\tclassName={cn('mt-3', size === 'lg' ? 'h-12' : 'h-10')}\n\t\t\t\t/>\n\t\t\t)}\n\t\t\t{!!data.footer && <Text size=\"xs\" type=\"secondary\" className=\"mt-2\">{data.footer}</Text>}\n\t\t</SmartCard>\n\t);\n\n\tif (isInteractive && data.onClick) {\n\t\treturn (\n\t\t\t<div\n\t\t\t\trole=\"button\"\n\t\t\t\ttabIndex={0}\n\t\t\t\tonClick={data.onClick}\n\t\t\t\tonKeyDown={(e) => (e.key === 'Enter' || e.key === ' ') && data.onClick?.()}\n\t\t\t\tclassName=\"rounded-xl focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring/40\"\n\t\t\t>\n\t\t\t\t{card}\n\t\t\t</div>\n\t\t);\n\t}\n\treturn card;\n}\n\nfunction MetricCompact({ data, formattedValue, size, showChange, showIcon, ariaLabel, className }: SubProps) {\n\tconst Icon = data.icon;\n\treturn (\n\t\t<div className={cn('flex items-center gap-3', className)} aria-label={ariaLabel}>\n\t\t\t{!!showIcon && !!Icon && (\n\t\t\t\t<span className=\"inline-flex size-9 shrink-0 items-center justify-center rounded-lg bg-muted/60 text-muted-foreground\">\n\t\t\t\t\t<Icon className=\"size-4\" aria-hidden=\"true\" />\n\t\t\t\t</span>\n\t\t\t)}\n\t\t\t<div className=\"min-w-0 flex-1\">\n\t\t\t\t<Text size=\"xs\" type=\"secondary\" className=\"truncate\">{data.label}</Text>\n\t\t\t\t<Text tag=\"span\" size={size === 'sm' ? 'sm' : 'lg'} weight=\"bold\" className=\"block truncate tabular-nums\">\n\t\t\t\t\t{formattedValue}\n\t\t\t\t</Text>\n\t\t\t</div>\n\t\t\t{!!showChange && !!data.change && (\n\t\t\t\t<MetricTrendChip change={data.change} trend={data.trend} size={size} variant=\"badge\" className=\"shrink-0\" />\n\t\t\t)}\n\t\t</div>\n\t);\n}\n\nfunction MetricMinimal({ data, formattedValue, size, showChange, ariaLabel, className }: SubProps) {\n\treturn (\n\t\t<span className={cn('inline-flex items-baseline gap-2', className)} aria-label={ariaLabel}>\n\t\t\t<Text tag=\"span\" size={size === 'lg' ? 'sm' : 'xs'} type=\"secondary\">{data.label}:</Text>\n\t\t\t<Text tag=\"span\" size={size === 'lg' ? 'sm' : 'xs'} weight=\"semibold\" className=\"tabular-nums\">{formattedValue}</Text>\n\t\t\t{!!showChange && !!data.change && (\n\t\t\t\t<MetricTrendChip change={data.change} trend={data.trend} size=\"sm\" variant=\"inline\" />\n\t\t\t)}\n\t\t</span>\n\t);\n}\n\nfunction MetricBordered({ data, formattedValue, trend, size, showSparkline, showChange, showIcon, colorScheme, ariaLabel, className }: SubProps) {\n\tconst Icon = data.icon;\n\tconst tint = SCHEME_TINT[colorScheme];\n\treturn (\n\t\t<div\n\t\t\tclassName={cn('flex flex-col gap-3 rounded-xl border p-4 shadow-sm', tint.border, tint.bg, className)}\n\t\t\taria-label={ariaLabel}\n\t\t>\n\t\t\t<div className=\"flex items-center justify-between gap-2\">\n\t\t\t\t<div className=\"flex items-center gap-2 text-muted-foreground\">\n\t\t\t\t\t{!!showIcon && !!Icon && <Icon className=\"size-4 shrink-0\" aria-hidden=\"true\" />}\n\t\t\t\t\t<Text size=\"xs\" type=\"secondary\" weight=\"medium\">{data.label}</Text>\n\t\t\t\t</div>\n\t\t\t\t{!!showChange && !!data.change && (\n\t\t\t\t\t<MetricTrendChip change={data.change} trend={data.trend} size={size} variant=\"badge\" />\n\t\t\t\t)}\n\t\t\t</div>\n\t\t\t<Heading\n\t\t\t\ttag={size === 'lg' ? 'h3' : 'h4'}\n\t\t\t\tclassName={cn('font-bold tabular-nums tracking-tight border-none pb-0 leading-none', VALUE_FONT_SIZE_HERO[size])}\n\t\t\t>\n\t\t\t\t{formattedValue}\n\t\t\t</Heading>\n\t\t\t{!!data.subtitle && <Text size=\"xs\" type=\"secondary\">{data.subtitle}</Text>}\n\t\t\t{!!showSparkline && !!data.sparkline?.length && (\n\t\t\t\t<MetricSparkline data={data.sparkline} trend={trend} className={SPARKLINE_HEIGHT[size]} />\n\t\t\t)}\n\t\t\t{!!data.footer && <Text size=\"xxs\" type=\"discrete\">{data.footer}</Text>}\n\t\t</div>\n\t);\n}\n\nfunction MetricAccent({ data, formattedValue, trend, size, showSparkline, showChange, ariaLabel, className }: SubProps) {\n\tconst Icon = data.icon;\n\treturn (\n\t\t<div\n\t\t\tclassName={cn(\n\t\t\t\t'dark relative flex flex-col overflow-hidden rounded-lg bg-card text-card-foreground shadow-sm ring-1 ring-border',\n\t\t\t\tclassName,\n\t\t\t)}\n\t\t\taria-label={ariaLabel}\n\t\t>\n\t\t\t<div className=\"flex flex-col gap-2 p-5\">\n\t\t\t\t<div className=\"flex items-center justify-between gap-3\">\n\t\t\t\t\t<Text size=\"xs\" type=\"secondary\" weight=\"medium\" className=\"uppercase tracking-wider\">\n\t\t\t\t\t\t{data.label}\n\t\t\t\t\t</Text>\n\t\t\t\t\t{!!Icon && (\n\t\t\t\t\t\t<span className=\"inline-flex size-7 items-center justify-center rounded-lg bg-foreground/[0.08]\">\n\t\t\t\t\t\t\t<Icon className=\"size-3.5 text-muted-foreground\" aria-hidden=\"true\" />\n\t\t\t\t\t\t</span>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t\t<div className=\"flex items-baseline gap-2.5\">\n\t\t\t\t\t<Heading\n\t\t\t\t\t\ttag=\"h3\"\n\t\t\t\t\t\tclassName={cn('font-bold tabular-nums tracking-tight border-none pb-0 leading-none text-foreground', VALUE_FONT_SIZE_HERO[size])}\n\t\t\t\t\t>\n\t\t\t\t\t\t{formattedValue}\n\t\t\t\t\t</Heading>\n\t\t\t\t\t{!!showChange && !!data.change && (\n\t\t\t\t\t\t<MetricTrendChip change={data.change} trend={data.trend} size={size} variant=\"compact\" />\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t\t{!!data.subtitle && <Text size=\"xs\" type=\"secondary\">{data.subtitle}</Text>}\n\t\t\t</div>\n\t\t\t{!!showSparkline && !!data.sparkline?.length && (\n\t\t\t\t<MetricSparkline data={data.sparkline} trend={trend} className=\"h-12 w-full\" />\n\t\t\t)}\n\t\t</div>\n\t);\n}\n\nfunction MetricColored({ data, formattedValue, size, showChange, colorScheme, ariaLabel, className, progress = 0 }: SubProps & { progress?: number }) {\n\tconst tint = SCHEME_TINT[colorScheme === 'default' ? 'primary' : colorScheme];\n\tconst filledCount = Math.round((Math.min(Math.max(progress, 0), 100) / 100) * SEGMENT_COUNT);\n\treturn (\n\t\t<div\n\t\t\tclassName={cn('rounded-xl bg-card p-5 shadow-sm border border-border/50', className)}\n\t\t\taria-label={ariaLabel}\n\t\t>\n\t\t\t<div className=\"flex items-center gap-2\">\n\t\t\t\t<Text size=\"xs\" type=\"secondary\" weight=\"medium\" className=\"truncate\">{data.label}</Text>\n\t\t\t\t<span className={cn('size-1.5 rounded-full shrink-0', tint.dot)} aria-hidden=\"true\" />\n\t\t\t</div>\n\t\t\t<div className=\"mt-2.5 flex items-baseline gap-2\">\n\t\t\t\t<Heading\n\t\t\t\t\ttag=\"h3\"\n\t\t\t\t\tclassName={cn('font-bold tabular-nums tracking-tight border-none pb-0 leading-none', VALUE_FONT_SIZE_HERO[size])}\n\t\t\t\t>\n\t\t\t\t\t{formattedValue}\n\t\t\t\t</Heading>\n\t\t\t\t{!!data.subtitle && <Text size=\"xs\" type=\"secondary\">{data.subtitle}</Text>}\n\t\t\t</div>\n\t\t\t<div className=\"mt-4 flex items-center gap-0.5\" role=\"progressbar\" aria-valuenow={progress} aria-valuemin={0} aria-valuemax={100}>\n\t\t\t\t{Array.from({ length: SEGMENT_COUNT }, (_, i) => (\n\t\t\t\t\t<div\n\t\t\t\t\t\tkey={`seg-${i}`}\n\t\t\t\t\t\tclassName={cn('h-6 w-1.5 rounded-sm transition-colors', i < filledCount ? tint.bar : 'bg-muted')}\n\t\t\t\t\t/>\n\t\t\t\t))}\n\t\t\t</div>\n\t\t\t{!!showChange && !!data.change && (\n\t\t\t\t<div className=\"mt-3\">\n\t\t\t\t\t<MetricTrendChip change={data.change} trend={data.trend} size={size} variant=\"default\" />\n\t\t\t\t</div>\n\t\t\t)}\n\t\t\t{!!data.footer && (\n\t\t\t\t<div className=\"mt-2 inline-flex items-center gap-1 text-muted-foreground\">\n\t\t\t\t\t<ArrowUpRight className=\"size-3\" aria-hidden=\"true\" />\n\t\t\t\t\t<Text size=\"xxs\" type=\"secondary\">{data.footer}</Text>\n\t\t\t\t</div>\n\t\t\t)}\n\t\t</div>\n\t);\n}\n","/**\n * MetricBar — horizontal strip of metrics with an optional period selector\n * on the leading edge. Cells are divided by hairlines so a row of 4 KPIs\n * reads as a single integrated module rather than disconnected cards.\n *\n * Variants:\n * `default` — flat hairline-divided bar with period chip on the left.\n * Best for tables/dashboards where the bar sits above content.\n * `gradient` — same layout wrapped in a tinted gradient frame for hero\n * placement.\n *\n * Always render `Metric` cells inside; never render layout-specific markup\n * directly. That keeps the formatting / colouring rules in one place.\n */\nimport { Calendar } from 'lucide-react';\nimport { Button } from '@/components/base/buttons';\nimport { Text } from '@/components/typography';\nimport { cn } from '@/lib/utils';\n\nimport { Metric } from '../metric/metric';\nimport type { MetricData, MetricPeriod, MetricSize } from '../types';\n\nexport type MetricBarVariant = 'default' | 'gradient';\n\nexport interface MetricBarProps {\n\tmetrics: MetricData[];\n\tperiod?: MetricPeriod;\n\tonPeriodChange?: (value: string) => void;\n\tvariant?: MetricBarVariant;\n\tsize?: MetricSize;\n\tshowSparklines?: boolean;\n\tshowChanges?: boolean;\n\tfooterText?: string;\n\tclassName?: string;\n}\n\nexport function MetricBar({\n\tmetrics,\n\tperiod,\n\tonPeriodChange,\n\tvariant = 'default',\n\tsize = 'md',\n\tshowSparklines = true,\n\tshowChanges = true,\n\tfooterText,\n\tclassName,\n}: MetricBarProps) {\n\tconst cells = (\n\t\t<div className=\"grid min-w-0 flex-1 grid-cols-1 divide-y divide-border lg:flex lg:items-stretch lg:divide-x lg:divide-y-0\">\n\t\t\t{metrics.map((metric) => (\n\t\t\t\t<div key={metric.id} className=\"min-w-0 px-4 py-3 lg:min-w-36 lg:flex-1\">\n\t\t\t\t\t<Metric\n\t\t\t\t\t\tdata={metric}\n\t\t\t\t\t\tvariant=\"default\"\n\t\t\t\t\t\tsize={size}\n\t\t\t\t\t\tshowSparkline={showSparklines}\n\t\t\t\t\t\tshowChange={showChanges}\n\t\t\t\t\t/>\n\t\t\t\t</div>\n\t\t\t))}\n\t\t</div>\n\t);\n\n\tconst periodChip = !!period && (\n\t\t<div className=\"flex shrink-0 items-center border-b border-border px-3 py-2 lg:border-b-0 lg:py-0\">\n\t\t\t<Button\n\t\t\t\tvariant=\"secondary\"\n\t\t\t\tbuttonStyle=\"ghost\"\n\t\t\t\tclassName=\"gap-1.5\"\n\t\t\t\tonClick={onPeriodChange ? () => onPeriodChange(period.value) : undefined}\n\t\t\t>\n\t\t\t\t<Calendar className=\"size-3.5\" aria-hidden=\"true\" />\n\t\t\t\t<Text size=\"xs\" weight=\"medium\">{period.label}</Text>\n\t\t\t</Button>\n\t\t</div>\n\t);\n\n\tif (variant === 'gradient') {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tclassName={cn('metric-bar--component',\n\t\t\t\t\t'w-full',\n\t\t\t\t\t'rounded-xl bg-gradient-to-r from-primary/8 via-info/5 to-success/8 p-[1px]',\n\t\t\t\t\tclassName,\n\t\t\t\t)}\n\t\t\t>\n\t\t\t\t<div className=\"flex min-w-0 flex-col overflow-hidden rounded-[11px] bg-card lg:flex-row\">\n\t\t\t\t\t{periodChip && (\n\t\t\t\t\t\t<>\n\t\t\t\t\t\t\t{periodChip}\n\t\t\t\t\t\t\t<div className=\"hidden w-px bg-border lg:block\" aria-hidden=\"true\" />\n\t\t\t\t\t\t</>\n\t\t\t\t\t)}\n\t\t\t\t\t{cells}\n\t\t\t\t</div>\n\t\t\t\t{!!footerText && (\n\t\t\t\t\t<div className=\"rounded-b-[11px] border-t border-border/50 bg-card px-4 py-2\">\n\t\t\t\t\t\t<Text size=\"xxs\" type=\"discrete\">{footerText}</Text>\n\t\t\t\t\t</div>\n\t\t\t\t)}\n\t\t\t</div>\n\t\t);\n\t}\n\n\treturn (\n\t\t<div\n\t\t\tclassName={cn(\n\t\t\t\t'metric-bar--component flex w-full flex-col overflow-hidden rounded-xl border border-border bg-card shadow-sm',\n\t\t\t\tclassName,\n\t\t\t)}\n\t\t>\n\t\t\t<div className=\"flex min-w-0 flex-col overflow-hidden lg:flex-row\">\n\t\t\t\t{periodChip && (\n\t\t\t\t\t<>\n\t\t\t\t\t\t{periodChip}\n\t\t\t\t\t\t<div className=\"hidden w-px bg-border lg:block\" aria-hidden=\"true\" />\n\t\t\t\t\t</>\n\t\t\t\t)}\n\t\t\t\t{cells}\n\t\t\t</div>\n\t\t\t{!!footerText && (\n\t\t\t\t<div className=\"border-t border-border/50 px-4 py-2\">\n\t\t\t\t\t<Text size=\"xxs\" type=\"discrete\">{footerText}</Text>\n\t\t\t\t</div>\n\t\t\t)}\n\t\t</div>\n\t);\n}\n\nMetricBar.displayName = 'MetricBar';\n","/**\n * MetricGrid — responsive grid of `Metric` cells. The grid is the workhorse\n * for KPI rows on dashboards: pass a list, choose a variant, and the\n * component handles layout / column counts / spacing.\n *\n * Variants are forwarded to `Metric` so a single grid can show either\n * standalone cards, bordered tints, or compact list rows.\n *\n * Column counts default to `auto` — the grid breaks at sm/lg/xl based on\n * the cell count. Override with `columns` to pin a specific layout.\n */\nimport { cn } from '@/lib/utils';\n\nimport { Metric } from '../metric/metric';\nimport type {\n\tMetricColorScheme,\n\tMetricData,\n\tMetricSize,\n\tMetricVariant,\n} from '../types';\n\nexport interface MetricGridProps {\n\tmetrics: MetricData[];\n\t/** Cell variant — restricted to grid-friendly layouts. */\n\tvariant?: Extract<MetricVariant, 'card' | 'compact' | 'bordered' | 'accent' | 'colored'>;\n\tsize?: MetricSize;\n\tcolorScheme?: MetricColorScheme;\n\t/** Force a fixed column count. `auto` picks based on cell count. */\n\tcolumns?: 'auto' | 1 | 2 | 3 | 4 | 6;\n\tgap?: 'sm' | 'md' | 'lg';\n\tshowSparklines?: boolean;\n\tshowChanges?: boolean;\n\tshowIcons?: boolean;\n\tloading?: boolean;\n\tclassName?: string;\n}\n\nconst GAP_CLASS: Record<NonNullable<MetricGridProps['gap']>, string> = {\n\tsm: 'gap-2',\n\tmd: 'gap-3',\n\tlg: 'gap-4',\n};\n\nfunction autoColumnsFor(count: number): string {\n\tif (count <= 1) return 'grid-cols-1';\n\tif (count === 2) return 'grid-cols-1 sm:grid-cols-2';\n\tif (count === 3) return 'grid-cols-1 sm:grid-cols-2 lg:grid-cols-3';\n\tif (count === 4) return 'grid-cols-1 sm:grid-cols-2 lg:grid-cols-4';\n\tif (count === 5 || count === 6) return 'grid-cols-2 sm:grid-cols-3 lg:grid-cols-6';\n\treturn 'grid-cols-1 sm:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4';\n}\n\nconst COLUMN_CLASS: Record<Exclude<NonNullable<MetricGridProps['columns']>, 'auto'>, string> = {\n\t1: 'grid-cols-1',\n\t2: 'grid-cols-1 sm:grid-cols-2',\n\t3: 'grid-cols-1 sm:grid-cols-2 lg:grid-cols-3',\n\t4: 'grid-cols-1 sm:grid-cols-2 lg:grid-cols-4',\n\t6: 'grid-cols-2 sm:grid-cols-3 lg:grid-cols-6',\n};\n\nexport function MetricGrid({\n\tmetrics,\n\tvariant = 'card',\n\tsize = 'md',\n\tcolorScheme = 'default',\n\tcolumns = 'auto',\n\tgap = 'md',\n\tshowSparklines = true,\n\tshowChanges = true,\n\tshowIcons = true,\n\tloading = false,\n\tclassName,\n}: MetricGridProps) {\n\tconst columnsClass = columns === 'auto' ? autoColumnsFor(metrics.length) : COLUMN_CLASS[columns];\n\n\treturn (\n\t\t<div className={cn('metric-grid--component', 'grid', columnsClass, GAP_CLASS[gap], className)}>\n\t\t\t{metrics.map((metric) => (\n\t\t\t\t<Metric\n\t\t\t\t\tkey={metric.id}\n\t\t\t\t\tdata={metric}\n\t\t\t\t\tvariant={variant}\n\t\t\t\t\tsize={size}\n\t\t\t\t\tcolorScheme={colorScheme}\n\t\t\t\t\tshowSparkline={showSparklines}\n\t\t\t\t\tshowChange={showChanges}\n\t\t\t\t\tshowIcon={showIcons}\n\t\t\t\t\tloading={loading}\n\t\t\t\t/>\n\t\t\t))}\n\t\t</div>\n\t);\n}\n\nMetricGrid.displayName = 'MetricGrid';\n","/**\n * MetricComparison — period-over-period comparison surface.\n *\n * Renders two side-by-side `Metric.bordered`-style boxes for current vs\n * previous, with a delta block below showing absolute + percent change in\n * a tone-tinted box. Layout stacks vertically below the `sm` breakpoint.\n *\n * Accepts `MetricData` for both halves so format hints (currency, percent,\n * duration) carry over consistently. Strings overridable for i18n.\n */\nimport { ArrowDown, ArrowRight, ArrowUp, Equal } from 'lucide-react';\n\nimport { SmartCard } from '@/components/base/cards';\nimport { Heading, Text } from '@/components/typography';\nimport { useStrings } from '@/lib/strings';\nimport { cn } from '@/lib/utils';\n\nimport { formatMetricValue } from '../format-metric-value';\nimport type { MetricData } from '../types';\n\nexport interface MetricComparisonStrings {\n\ttitle: string;\n\tcurrentLabel: string;\n\tpreviousLabel: string;\n\tsuffix: string;\n}\n\nexport const defaultMetricComparisonStrings: MetricComparisonStrings = {\n\ttitle: 'Comparison',\n\tcurrentLabel: 'This period',\n\tpreviousLabel: 'Previous period',\n\tsuffix: 'vs previous',\n};\n\nexport interface MetricComparisonProps {\n\tcurrent: MetricData;\n\tprevious: MetricData;\n\ttitle?: string;\n\tcurrentPeriod?: string;\n\tpreviousPeriod?: string;\n\tclassName?: string;\n\tstrings?: Partial<MetricComparisonStrings>;\n}\n\nfunction toNumber(value: MetricData['value']): number | null {\n\tif (value === null || value === undefined) return null;\n\tif (typeof value === 'number') return value;\n\tconst n = Number(value);\n\treturn Number.isFinite(n) ? n : null;\n}\n\nexport function MetricComparison({\n\tcurrent,\n\tprevious,\n\ttitle,\n\tcurrentPeriod,\n\tpreviousPeriod,\n\tclassName,\n\tstrings: stringsProp,\n}: MetricComparisonProps) {\n\tconst strings = useStrings(defaultMetricComparisonStrings, {\n\t\t...(title ? { title } : {}),\n\t\t...stringsProp,\n\t});\n\n\tconst currentNum = toNumber(current.value);\n\tconst previousNum = toNumber(previous.value);\n\tconst canCompute = currentNum !== null && previousNum !== null;\n\tconst delta = canCompute ? (currentNum as number) - (previousNum as number) : 0;\n\tconst deltaPct = canCompute && (previousNum as number) !== 0\n\t\t? Math.round((delta / (previousNum as number)) * 100)\n\t\t: 0;\n\tconst isUp = delta > 0;\n\tconst isFlat = delta === 0;\n\tconst Arrow = isFlat ? Equal : isUp ? ArrowUp : ArrowDown;\n\n\tconst tone = isFlat\n\t\t? { box: 'bg-muted/40', chip: 'bg-card text-muted-foreground border border-border/60' }\n\t\t: isUp\n\t\t\t? { box: 'bg-success/10', chip: 'bg-success/15 text-success' }\n\t\t\t: { box: 'bg-destructive/10', chip: 'bg-destructive/15 text-destructive' };\n\n\tconst formatDelta = (value: number) => {\n\t\tconst abs = Math.abs(value);\n\t\t// reuse the formatter so currency/percent metrics render correctly\n\t\treturn formatMetricValue({ ...current, value: abs });\n\t};\n\n\treturn (\n\t\t<SmartCard title={strings.title} className={cn('metric-comparison--component', className)}>\n\t\t\t{!!(currentPeriod || previousPeriod) && (\n\t\t\t\t<div className=\"flex flex-wrap items-center gap-1.5\">\n\t\t\t\t\t{!!currentPeriod && (\n\t\t\t\t\t\t<Text\n\t\t\t\t\t\t\ttag=\"span\"\n\t\t\t\t\t\t\tsize=\"xxs\"\n\t\t\t\t\t\t\tweight=\"medium\"\n\t\t\t\t\t\t\tclassName=\"rounded-full bg-muted px-2 py-0.5 uppercase tracking-wider text-muted-foreground\"\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{currentPeriod}\n\t\t\t\t\t\t</Text>\n\t\t\t\t\t)}\n\t\t\t\t\t{!!previousPeriod && (\n\t\t\t\t\t\t<Text\n\t\t\t\t\t\t\ttag=\"span\"\n\t\t\t\t\t\t\tsize=\"xxs\"\n\t\t\t\t\t\t\tweight=\"medium\"\n\t\t\t\t\t\t\tclassName=\"rounded-full bg-muted/40 px-2 py-0.5 uppercase tracking-wider text-muted-foreground/70\"\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{previousPeriod}\n\t\t\t\t\t\t</Text>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t)}\n\n\t\t\t<div className=\"mt-3 grid items-stretch gap-2 grid-cols-1 sm:grid-cols-[1fr_auto_1fr]\">\n\t\t\t\t<div className=\"rounded-lg border border-border/60 bg-card px-3 py-2.5\">\n\t\t\t\t\t<Text size=\"xxs\" type=\"secondary\" weight=\"medium\" className=\"uppercase tracking-wider\">\n\t\t\t\t\t\t{strings.currentLabel}\n\t\t\t\t\t</Text>\n\t\t\t\t\t<Heading tag=\"h5\" className=\"text-xl tabular-nums tracking-tight border-none pb-0\">\n\t\t\t\t\t\t{formatMetricValue(current)}\n\t\t\t\t\t</Heading>\n\t\t\t\t</div>\n\t\t\t\t<div className=\"flex items-center justify-center text-muted-foreground/60\">\n\t\t\t\t\t<ArrowRight className=\"hidden size-4 sm:block\" aria-hidden=\"true\" />\n\t\t\t\t\t<ArrowDown className=\"size-4 sm:hidden\" aria-hidden=\"true\" />\n\t\t\t\t</div>\n\t\t\t\t<div className=\"rounded-lg bg-muted/40 px-3 py-2.5\">\n\t\t\t\t\t<Text size=\"xxs\" weight=\"medium\" className=\"uppercase tracking-wider text-muted-foreground/70\">\n\t\t\t\t\t\t{strings.previousLabel}\n\t\t\t\t\t</Text>\n\t\t\t\t\t<Heading tag=\"h5\" className=\"text-xl tabular-nums tracking-tight border-none pb-0 text-muted-foreground\">\n\t\t\t\t\t\t{formatMetricValue(previous)}\n\t\t\t\t\t</Heading>\n\t\t\t\t</div>\n\t\t\t</div>\n\n\t\t\t{!!canCompute && (\n\t\t\t\t<div className={cn('mt-3 flex flex-wrap items-center gap-2 rounded-lg px-3 py-2', tone.box)}>\n\t\t\t\t\t<div className={cn('inline-flex items-center gap-1 rounded-full px-2 py-0.5', tone.chip)}>\n\t\t\t\t\t\t<Arrow className=\"size-3\" strokeWidth={2.5} aria-hidden=\"true\" />\n\t\t\t\t\t\t<Text tag=\"span\" size=\"xs\" weight=\"semibold\" className=\"tabular-nums\">\n\t\t\t\t\t\t\t{isUp ? '+' : isFlat ? '' : '−'}{formatDelta(delta)}\n\t\t\t\t\t\t</Text>\n\t\t\t\t\t</div>\n\t\t\t\t\t<Text size=\"xs\" type=\"secondary\" className=\"tabular-nums\">\n\t\t\t\t\t\t{isUp ? '+' : isFlat ? '' : '−'}{Math.abs(deltaPct)}% {strings.suffix}\n\t\t\t\t\t</Text>\n\t\t\t\t</div>\n\t\t\t)}\n\t\t</SmartCard>\n\t);\n}\n\nMetricComparison.displayName = 'MetricComparison';\n","/**\n * MetricMicroGrid — six-cell dense KPI overview where each cell pairs a\n * label/value with a different lightweight visualization (bars / line /\n * dots / progress / area / pie). Useful as a top-of-page summary widget\n * on a packed dashboard.\n *\n * Cells are positional: index 0 → bars, 1 → line, 2 → dots, 3 → progress,\n * 4 → area, 5 → pie. To pin a specific renderer, pass `chart` per cell.\n */\nimport { useId } from 'react';\nimport { Area, AreaChart, ResponsiveContainer } from 'recharts';\n\nimport { SmartCard } from '@/components/base/cards';\nimport { Text } from '@/components/typography';\nimport { cn } from '@/lib/utils';\n\nexport type MicroChartKind = 'bars' | 'line' | 'dots' | 'progress' | 'area' | 'pie';\n\nexport interface MicroMetricCell {\n\tid?: string;\n\tlabel: string;\n\tvalue: string;\n\tdata: readonly number[];\n\tchart?: MicroChartKind;\n}\n\nexport interface MetricMicroGridProps {\n\ttitle?: string;\n\tcells: readonly MicroMetricCell[];\n\tclassName?: string;\n}\n\nconst DEFAULT_ORDER: MicroChartKind[] = ['bars', 'line', 'dots', 'progress', 'area', 'pie'];\n\nconst CHART_COLORS: Record<MicroChartKind, string> = {\n\tbars: 'var(--primary)',\n\tline: 'var(--info)',\n\tdots: 'var(--warning)',\n\tprogress: 'var(--success)',\n\tarea: 'var(--primary)',\n\tpie: 'var(--success)',\n};\n\nconst PIE_PALETTE = ['var(--success)', 'var(--info)', 'var(--warning)'];\n\nfunction MicroBars({ data, color }: { data: readonly number[]; color: string }) {\n\tconst max = Math.max(...data, 1);\n\treturn (\n\t\t<div className={cn('metric-micro-grid--component', 'flex h-5 items-end gap-[2px]')}>\n\t\t\t{data.slice(0, 6).map((v, i) => (\n\t\t\t\t<div\n\t\t\t\t\tkey={`bar-${i}`}\n\t\t\t\t\tclassName=\"flex-1 rounded-t-sm\"\n\t\t\t\t\tstyle={{ height: `${(v / max) * 100}%`, backgroundColor: color, opacity: 0.8 }}\n\t\t\t\t/>\n\t\t\t))}\n\t\t</div>\n\t);\n}\n\nfunction MicroLine({ data, color }: { data: readonly number[]; color: string }) {\n\tconst max = Math.max(...data, 1);\n\tconst min = Math.min(...data);\n\tconst range = max - min || 1;\n\tconst points = data.slice(0, 6);\n\treturn (\n\t\t<svg viewBox=\"0 0 60 16\" className=\"h-5 w-full\" preserveAspectRatio=\"none\">\n\t\t\t<polyline\n\t\t\t\tfill=\"none\"\n\t\t\t\tstroke={color}\n\t\t\t\tstrokeWidth=\"1.5\"\n\t\t\t\tstrokeLinecap=\"round\"\n\t\t\t\tstrokeLinejoin=\"round\"\n\t\t\t\tpoints={points\n\t\t\t\t\t.map((v, i) => `${(i / Math.max(points.length - 1, 1)) * 60},${16 - ((v - min) / range) * 14}`)\n\t\t\t\t\t.join(' ')}\n\t\t\t/>\n\t\t</svg>\n\t);\n}\n\nfunction MicroDots({ data, color }: { data: readonly number[]; color: string }) {\n\tconst max = Math.max(...data, 1);\n\treturn (\n\t\t<div className=\"flex h-5 items-end justify-around\">\n\t\t\t{data.slice(0, 5).map((v, i) => (\n\t\t\t\t<div\n\t\t\t\t\tkey={`dot-${i}`}\n\t\t\t\t\tclassName=\"h-1.5 w-1.5 rounded-full\"\n\t\t\t\t\tstyle={{ marginBottom: `${(v / max) * 12}px`, backgroundColor: color }}\n\t\t\t\t/>\n\t\t\t))}\n\t\t</div>\n\t);\n}\n\nfunction MicroProgress({ data, color }: { data: readonly number[]; color: string }) {\n\tconst value = data[0] ?? 0;\n\tconst max = data[1] ?? 100;\n\tconst pct = Math.min((value / max) * 100, 100);\n\treturn (\n\t\t<div className=\"h-1.5 w-full overflow-hidden rounded-full bg-muted\">\n\t\t\t<div className=\"h-full rounded-full transition-all\" style={{ width: `${pct}%`, backgroundColor: color }} />\n\t\t</div>\n\t);\n}\n\nfunction MicroAreaChart({ data, color }: { data: readonly number[]; color: string }) {\n\tconst id = useId();\n\tconst gradId = `micro-area-${id.replaceAll(':', '')}`;\n\tconst chartData = data.map((v, i) => ({ i, v }));\n\treturn (\n\t\t<div className=\"h-5 w-full\">\n\t\t\t<ResponsiveContainer width=\"100%\" height=\"100%\" initialDimension={{ width: 1, height: 1 }}>\n\t\t\t\t<AreaChart data={chartData} margin={{ top: 0, right: 0, bottom: 0, left: 0 }}>\n\t\t\t\t\t<defs>\n\t\t\t\t\t\t<linearGradient id={gradId} x1=\"0\" y1=\"0\" x2=\"0\" y2=\"1\">\n\t\t\t\t\t\t\t<stop offset=\"0%\" stopColor={color} stopOpacity={0.3} />\n\t\t\t\t\t\t\t<stop offset=\"100%\" stopColor={color} stopOpacity={0} />\n\t\t\t\t\t\t</linearGradient>\n\t\t\t\t\t</defs>\n\t\t\t\t\t<Area type=\"monotone\" dataKey=\"v\" stroke={color} strokeWidth={1.25} fill={`url(#${gradId})`} />\n\t\t\t\t</AreaChart>\n\t\t\t</ResponsiveContainer>\n\t\t</div>\n\t);\n}\n\nfunction MicroPie({ data }: { data: readonly number[] }) {\n\tconst total = data.reduce((a, b) => a + b, 0) || 1;\n\tlet cumAngle = 0;\n\treturn (\n\t\t<svg viewBox=\"0 0 24 24\" className=\"h-6 w-6\">\n\t\t\t{data.slice(0, 3).map((v, i) => {\n\t\t\t\tconst angle = (v / total) * 360;\n\t\t\t\tconst startAngle = cumAngle;\n\t\t\t\tcumAngle += angle;\n\t\t\t\tconst startRad = ((startAngle - 90) * Math.PI) / 180;\n\t\t\t\tconst endRad = ((startAngle + angle - 90) * Math.PI) / 180;\n\t\t\t\tconst largeArc = angle > 180 ? 1 : 0;\n\t\t\t\tconst x1 = 12 + 10 * Math.cos(startRad);\n\t\t\t\tconst y1 = 12 + 10 * Math.sin(startRad);\n\t\t\t\tconst x2 = 12 + 10 * Math.cos(endRad);\n\t\t\t\tconst y2 = 12 + 10 * Math.sin(endRad);\n\t\t\t\treturn (\n\t\t\t\t\t<path\n\t\t\t\t\t\tkey={`slice-${i}`}\n\t\t\t\t\t\td={`M12,12 L${x1},${y1} A10,10 0 ${largeArc},1 ${x2},${y2} Z`}\n\t\t\t\t\t\tfill={PIE_PALETTE[i % PIE_PALETTE.length]}\n\t\t\t\t\t/>\n\t\t\t\t);\n\t\t\t})}\n\t\t</svg>\n\t);\n}\n\nfunction ChartFor({ kind, data }: { kind: MicroChartKind; data: readonly number[] }) {\n\tconst color = CHART_COLORS[kind];\n\tif (kind === 'bars') return <MicroBars data={data} color={color} />;\n\tif (kind === 'line') return <MicroLine data={data} color={color} />;\n\tif (kind === 'dots') return <MicroDots data={data} color={color} />;\n\tif (kind === 'progress') return <MicroProgress data={data} color={color} />;\n\tif (kind === 'area') return <MicroAreaChart data={data} color={color} />;\n\treturn <MicroPie data={data} />;\n}\n\nexport function MetricMicroGrid({ title = 'Overview', cells, className }: MetricMicroGridProps) {\n\treturn (\n\t\t<SmartCard title={title} className={className} padding=\"sm\">\n\t\t\t<div className=\"grid grid-cols-3 grid-rows-2 -m-2\">\n\t\t\t\t{cells.slice(0, 6).map((cell, i) => (\n\t\t\t\t\t<div\n\t\t\t\t\t\tkey={cell.id ?? cell.label}\n\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t'flex flex-col gap-1.5 px-3 py-2.5',\n\t\t\t\t\t\t\ti % 3 !== 2 && 'border-r border-border/50',\n\t\t\t\t\t\t\ti < 3 && 'border-b border-border/50',\n\t\t\t\t\t\t)}\n\t\t\t\t\t>\n\t\t\t\t\t\t<Text size=\"xxs\" type=\"secondary\" className=\"truncate uppercase tracking-wider\">\n\t\t\t\t\t\t\t{cell.label}\n\t\t\t\t\t\t</Text>\n\t\t\t\t\t\t<Text tag=\"span\" weight=\"bold\" className=\"tabular-nums truncate\">\n\t\t\t\t\t\t\t{cell.value}\n\t\t\t\t\t\t</Text>\n\t\t\t\t\t\t<div className=\"mt-auto\">\n\t\t\t\t\t\t\t<ChartFor kind={cell.chart ?? DEFAULT_ORDER[i]} data={cell.data} />\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t))}\n\t\t\t</div>\n\t\t</SmartCard>\n\t);\n}\n\nMetricMicroGrid.displayName = 'MetricMicroGrid';\n","/**\n * MetricGradient — vivid full-bleed gradient hero card with embedded area\n * chart. Used at the top of marketing dashboards or analytics overview\n * pages where a single metric earns the most visual weight.\n *\n * Themes (`green` / `purple` / `warm` / `ocean`) drive the gradient palette;\n * the data prop accepts a `readonly MetricDataPoint[]` so consumers can pass\n * named time-series points. Renders the active dot in white and the area\n * fill in a soft white-on-tone gradient for legibility.\n */\nimport { useId } from 'react';\nimport { Area, AreaChart, ResponsiveContainer, Tooltip } from 'recharts';\n\nimport { Heading, Text } from '@/components/typography';\nimport { cn } from '@/lib/utils';\n\nimport { MetricTrendChip } from '../atoms/metric-trend-chip';\nimport type { MetricChange, MetricDataPoint } from '../types';\n\nexport type MetricGradientTheme = 'green' | 'purple' | 'warm' | 'ocean';\n\nexport interface MetricGradientProps {\n\ttitle: string;\n\tvalue?: string;\n\tchange?: MetricChange;\n\tdata: readonly MetricDataPoint[];\n\ttheme?: MetricGradientTheme;\n\tsubtitle?: string;\n\tclassName?: string;\n}\n\nconst THEME_BG: Record<MetricGradientTheme, string> = {\n\tgreen: 'bg-gradient-to-br from-emerald-600 via-teal-700 to-emerald-800',\n\tpurple: 'bg-gradient-to-br from-violet-600 via-indigo-700 to-purple-800',\n\twarm: 'bg-gradient-to-br from-orange-500 via-rose-600 to-pink-700',\n\tocean: 'bg-gradient-to-br from-sky-600 via-cyan-700 to-blue-800',\n};\n\ninterface ChartTooltipPayload {\n\tvalue: number;\n\tname: string;\n\tcolor?: string;\n}\n\nfunction ChartTooltip({ active, payload, label }: { active?: boolean; payload?: ChartTooltipPayload[]; label?: string }) {\n\tif (!active || !payload?.length) return null;\n\treturn (\n\t\t<div className={cn('metric-gradient--component', 'rounded-lg bg-foreground/95 px-3 py-2 shadow-lg backdrop-blur-sm')}>\n\t\t\t{!!label && <Text size=\"xxs\" className=\"text-background/60 mb-1\">{label}</Text>}\n\t\t\t{payload.map((entry, idx) => (\n\t\t\t\t<div key={`tt-${idx}`} className=\"flex items-center gap-2\">\n\t\t\t\t\t<div className=\"size-2 rounded-full\" style={{ backgroundColor: entry.color ?? '#fff' }} aria-hidden=\"true\" />\n\t\t\t\t\t<Text size=\"xs\" weight=\"semibold\" className=\"text-background tabular-nums\">\n\t\t\t\t\t\t{typeof entry.value === 'number' ? entry.value.toLocaleString() : entry.value}\n\t\t\t\t\t</Text>\n\t\t\t\t</div>\n\t\t\t))}\n\t\t</div>\n\t);\n}\n\nexport function MetricGradient({\n\ttitle,\n\tvalue,\n\tchange,\n\tdata,\n\ttheme = 'green',\n\tsubtitle,\n\tclassName,\n}: MetricGradientProps) {\n\tconst id = useId();\n\tconst gradientId = `metric-grad-${id.replaceAll(':', '')}`;\n\n\treturn (\n\t\t<div\n\t\t\tclassName={cn(\n\t\t\t\t'relative overflow-hidden rounded-lg p-5 text-white shadow-sm ring-1 ring-white/10',\n\t\t\t\tTHEME_BG[theme],\n\t\t\t\tclassName,\n\t\t\t)}\n\t\t>\n\t\t\t<div className=\"relative flex items-start justify-between gap-3\">\n\t\t\t\t<div className=\"min-w-0\">\n\t\t\t\t\t<Text size=\"xs\" weight=\"medium\" className=\"uppercase tracking-wider text-white/70\">{title}</Text>\n\t\t\t\t\t{!!value && (\n\t\t\t\t\t\t<Heading\n\t\t\t\t\t\t\ttag=\"h3\"\n\t\t\t\t\t\t\tclassName=\"mt-1 text-3xl font-bold tabular-nums tracking-tight border-none pb-0 text-white leading-none\"\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{value}\n\t\t\t\t\t\t</Heading>\n\t\t\t\t\t)}\n\t\t\t\t\t{!!subtitle && <Text size=\"xs\" className=\"mt-1 text-white/70\">{subtitle}</Text>}\n\t\t\t\t</div>\n\t\t\t\t{!!change && (\n\t\t\t\t\t<MetricTrendChip\n\t\t\t\t\t\tchange={change}\n\t\t\t\t\t\ttrend={change.direction === 'up' ? 'positive' : change.direction === 'down' ? 'negative' : 'neutral'}\n\t\t\t\t\t\tsize=\"sm\"\n\t\t\t\t\t\tvariant=\"badge\"\n\t\t\t\t\t\tclassName=\"shrink-0 !bg-white/20 !text-white\"\n\t\t\t\t\t/>\n\t\t\t\t)}\n\t\t\t</div>\n\n\t\t\t<div className=\"relative -mx-1 mt-3 h-24\">\n\t\t\t\t<ResponsiveContainer width=\"100%\" height=\"100%\" initialDimension={{ width: 1, height: 1 }}>\n\t\t\t\t\t<AreaChart data={data as MetricDataPoint[]} margin={{ top: 4, right: 0, bottom: 0, left: 0 }}>\n\t\t\t\t\t\t<defs>\n\t\t\t\t\t\t\t<linearGradient id={gradientId} x1=\"0\" y1=\"0\" x2=\"0\" y2=\"1\">\n\t\t\t\t\t\t\t\t<stop offset=\"0%\" stopColor=\"white\" stopOpacity={0.3} />\n\t\t\t\t\t\t\t\t<stop offset=\"100%\" stopColor=\"white\" stopOpacity={0} />\n\t\t\t\t\t\t\t</linearGradient>\n\t\t\t\t\t\t</defs>\n\t\t\t\t\t\t<Tooltip content={<ChartTooltip />} cursor={{ stroke: 'rgba(255,255,255,0.4)', strokeWidth: 1 }} />\n\t\t\t\t\t\t<Area\n\t\t\t\t\t\t\ttype=\"monotone\"\n\t\t\t\t\t\t\tdataKey=\"value\"\n\t\t\t\t\t\t\tstroke=\"rgba(255,255,255,0.7)\"\n\t\t\t\t\t\t\tstrokeWidth={2}\n\t\t\t\t\t\t\tfill={`url(#${gradientId})`}\n\t\t\t\t\t\t\tdot={false}\n\t\t\t\t\t\t\tactiveDot={{ r: 4, strokeWidth: 2, fill: '#fff', stroke: 'rgba(255,255,255,0.7)' }}\n\t\t\t\t\t\t\tisAnimationActive\n\t\t\t\t\t\t\tanimationDuration={800}\n\t\t\t\t\t\t/>\n\t\t\t\t\t</AreaChart>\n\t\t\t\t</ResponsiveContainer>\n\t\t\t</div>\n\t\t</div>\n\t);\n}\n\nMetricGradient.displayName = 'MetricGradient';\n","/**\n * ActivityHeatmap — GitHub-style daily-activity calendar grid. Renders the\n * provided range as Monday-aligned columns with per-day intensity tinted\n * via the success palette. Month labels float above the grid; the legend\n * sits on the trailing edge.\n *\n * The layout uses absolute month labels with a 3-week minimum gap rule\n * so labels don't collide when a month starts mid-week.\n */\nimport { SmartCard } from '@/components/base/cards';\nimport { Text } from '@/components/typography';\nimport { useStrings } from '@/lib/strings';\nimport { cn } from '@/lib/utils';\n\nimport { defaultAnalyticsStrings } from '../analytics.strings';\nimport type { ActivityHeatmapDay, ActivityHeatmapProps, ActivityLevel } from './types';\n\nconst LEVEL_COLOR: Record<ActivityLevel, string> = {\n\t0: 'bg-muted',\n\t1: 'bg-success/20',\n\t2: 'bg-success/40',\n\t3: 'bg-success/65',\n\t4: 'bg-success',\n};\n\ninterface BuiltCalendar {\n\tweeks: (ActivityHeatmapDay | null)[][];\n\tmonthLabels: { label: string; weekIndex: number }[];\n}\n\nfunction buildCalendar(\n\tdata: readonly ActivityHeatmapDay[],\n\tmonthNames: readonly string[],\n): BuiltCalendar {\n\tif (data.length === 0) return { weeks: [], monthLabels: [] };\n\n\tconst sorted = [...data].sort((a, b) => a.date.localeCompare(b.date));\n\tconst startDate = new Date(sorted[0].date + 'T00:00:00');\n\tconst endDate = new Date(sorted[sorted.length - 1].date + 'T00:00:00');\n\n\tconst dayOfWeek = startDate.getDay();\n\tconst mondayOffset = dayOfWeek === 0 ? -6 : 1 - dayOfWeek;\n\tconst alignedStart = new Date(startDate);\n\talignedStart.setDate(alignedStart.getDate() + mondayOffset);\n\n\tconst dateMap = new Map<string, ActivityLevel>();\n\tfor (const d of sorted) dateMap.set(d.date, d.level);\n\n\tconst weeks: (ActivityHeatmapDay | null)[][] = [];\n\tconst monthLabels: { label: string; weekIndex: number }[] = [];\n\tlet lastMonth = -1;\n\tlet currentWeek: (ActivityHeatmapDay | null)[] = [];\n\n\tconst cursor = new Date(alignedStart);\n\twhile (cursor <= endDate) {\n\t\tconst dateStr = cursor.toISOString().slice(0, 10);\n\t\tconst dayIdx = (cursor.getDay() + 6) % 7;\n\n\t\tif (dayIdx === 0 && currentWeek.length > 0) {\n\t\t\tweeks.push(currentWeek);\n\t\t\tcurrentWeek = [];\n\t\t}\n\n\t\tconst month = cursor.getMonth();\n\t\tif (month !== lastMonth) {\n\t\t\tconst labelWeekIndex = dayIdx === 0 ? weeks.length : weeks.length + 1;\n\t\t\tconst existing = monthLabels.find((m) => m.weekIndex === labelWeekIndex);\n\t\t\tif (!existing) monthLabels.push({ label: monthNames[month], weekIndex: labelWeekIndex });\n\t\t\tlastMonth = month;\n\t\t}\n\n\t\tconst level = dateMap.get(dateStr) ?? 0;\n\t\tcurrentWeek.push({ date: dateStr, level });\n\t\tcursor.setDate(cursor.getDate() + 1);\n\t}\n\n\tif (currentWeek.length > 0) {\n\t\twhile (currentWeek.length < 7) currentWeek.push(null);\n\t\tweeks.push(currentWeek);\n\t}\n\n\treturn { weeks, monthLabels };\n}\n\nexport function ActivityHeatmap({\n\ttitle,\n\tdescription,\n\tdata,\n\tclassName,\n\tstrings: stringsProp,\n}: ActivityHeatmapProps) {\n\tconst strings = useStrings(defaultAnalyticsStrings, stringsProp);\n\tconst { weeks, monthLabels } = buildCalendar(data, strings.heatmapMonthNames);\n\n\treturn (\n\t\t<SmartCard title={title} description={description} className={cn('activity-heatmap--component', className)}>\n\t\t\t<div className=\"overflow-x-auto\">\n\t\t\t\t<div className=\"relative mb-1\" style={{ paddingLeft: '28px', height: '12px' }}>\n\t\t\t\t\t<div className=\"relative flex\" style={{ width: `${weeks.length * 15}px` }}>\n\t\t\t\t\t\t{monthLabels\n\t\t\t\t\t\t\t.filter((m, idx, arr) => idx === 0 || m.weekIndex - arr[idx - 1].weekIndex >= 3)\n\t\t\t\t\t\t\t.map((m) => (\n\t\t\t\t\t\t\t\t<Text\n\t\t\t\t\t\t\t\t\tkey={`${m.label}-${m.weekIndex}`}\n\t\t\t\t\t\t\t\t\tsize=\"xxs\"\n\t\t\t\t\t\t\t\t\ttype=\"secondary\"\n\t\t\t\t\t\t\t\t\tclassName=\"absolute leading-none whitespace-nowrap\"\n\t\t\t\t\t\t\t\t\tstyle={{ left: `${m.weekIndex * 15}px`, top: 0 }}\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t{m.label}\n\t\t\t\t\t\t\t\t</Text>\n\t\t\t\t\t\t\t))}\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\n\t\t\t\t<div className=\"flex gap-0\">\n\t\t\t\t\t<div className=\"mr-1 flex flex-col gap-[3px]\">\n\t\t\t\t\t\t{strings.heatmapDayLabels.map((label, i) => (\n\t\t\t\t\t\t\t<div key={`day-${i}`} className=\"flex h-3 w-6 items-center justify-end\">\n\t\t\t\t\t\t\t\t{!!label && (\n\t\t\t\t\t\t\t\t\t<Text size=\"xxs\" type=\"secondary\" className=\"leading-none\">{label}</Text>\n\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t))}\n\t\t\t\t\t</div>\n\n\t\t\t\t\t<div className=\"flex gap-[3px]\">\n\t\t\t\t\t\t{weeks.map((week, weekIdx) => (\n\t\t\t\t\t\t\t<div key={`w-${weekIdx}`} className=\"flex flex-col gap-[3px]\">\n\t\t\t\t\t\t\t\t{week.map((day, dayIdx) => {\n\t\t\t\t\t\t\t\t\tconst dayTitle = day ? `${day.date}: Level ${day.level}` : undefined;\n\t\t\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\t\t\tkey={`d-${weekIdx}-${dayIdx}`}\n\t\t\t\t\t\t\t\t\t\t\tclassName={cn(\n\t\t\t\t\t\t\t\t\t\t\t\t'size-3 rounded-sm',\n\t\t\t\t\t\t\t\t\t\t\t\tday ? LEVEL_COLOR[day.level] : 'bg-transparent',\n\t\t\t\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t\t\t\t\ttitle={dayTitle}\n\t\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t))}\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</div>\n\n\t\t\t<div className=\"mt-4 flex items-center justify-end gap-1.5\">\n\t\t\t\t<Text size=\"xxs\" type=\"secondary\">{strings.heatmapLegendLess}</Text>\n\t\t\t\t{([0, 1, 2, 3, 4] as ActivityLevel[]).map((level) => (\n\t\t\t\t\t<div key={`legend-${level}`} className={cn('size-3 rounded-sm', LEVEL_COLOR[level])} />\n\t\t\t\t))}\n\t\t\t\t<Text size=\"xxs\" type=\"secondary\">{strings.heatmapLegendMore}</Text>\n\t\t\t</div>\n\t\t</SmartCard>\n\t);\n}\n\nActivityHeatmap.displayName = 'ActivityHeatmap';\n"],"mappings":"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"}
|