@mastra/playground-ui 33.0.0-alpha.3 → 33.0.0
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/CHANGELOG.md +344 -0
- package/dist/Avatar-Dcmi3-pN.js +42 -0
- package/dist/Avatar-Dcmi3-pN.js.map +1 -0
- package/dist/Avatar-Y-1fas25.cjs +44 -0
- package/dist/Avatar-Y-1fas25.cjs.map +1 -0
- package/dist/Badge-C5MzMyCa.js +34 -0
- package/dist/Badge-C5MzMyCa.js.map +1 -0
- package/dist/Badge-CQD9T1Yd.cjs +36 -0
- package/dist/Badge-CQD9T1Yd.cjs.map +1 -0
- package/dist/Breadcrumb-BT_nzL3M.cjs +39 -0
- package/dist/Breadcrumb-BT_nzL3M.cjs.map +1 -0
- package/dist/Breadcrumb-CxbCgAij.js +35 -0
- package/dist/Breadcrumb-CxbCgAij.js.map +1 -0
- package/dist/Button-DoOEJwa_.js +105 -0
- package/dist/Button-DoOEJwa_.js.map +1 -0
- package/dist/Button-DpIX8JMz.cjs +108 -0
- package/dist/Button-DpIX8JMz.cjs.map +1 -0
- package/dist/Card-Xx0_PeuI.cjs +90 -0
- package/dist/Card-Xx0_PeuI.cjs.map +1 -0
- package/dist/Card-cFJPRQ9O.js +64 -0
- package/dist/Card-cFJPRQ9O.js.map +1 -0
- package/dist/EmptyState-DfXdX6I8.js +31 -0
- package/dist/EmptyState-DfXdX6I8.js.map +1 -0
- package/dist/EmptyState-vw7dhSKP.cjs +33 -0
- package/dist/EmptyState-vw7dhSKP.cjs.map +1 -0
- package/dist/Entity-CVzaJDXu.js +42 -0
- package/dist/Entity-CVzaJDXu.js.map +1 -0
- package/dist/Entity-DALpbsRa.cjs +48 -0
- package/dist/Entity-DALpbsRa.cjs.map +1 -0
- package/dist/ErrorBoundary-6_BD8AkH.js +154 -0
- package/dist/ErrorBoundary-6_BD8AkH.js.map +1 -0
- package/dist/ErrorBoundary-BqiUSXyJ.cjs +175 -0
- package/dist/ErrorBoundary-BqiUSXyJ.cjs.map +1 -0
- package/dist/ErrorState-DH5KsoFs.js +14 -0
- package/dist/ErrorState-DH5KsoFs.js.map +1 -0
- package/dist/ErrorState-Dq9BVWmR.cjs +16 -0
- package/dist/ErrorState-Dq9BVWmR.cjs.map +1 -0
- package/dist/Header-Cfc5fIp6.js +31 -0
- package/dist/Header-Cfc5fIp6.js.map +1 -0
- package/dist/Header-wkLHG26m.cjs +36 -0
- package/dist/Header-wkLHG26m.cjs.map +1 -0
- package/dist/Icon-CJEjdbjB.js +14 -0
- package/dist/Icon-CJEjdbjB.js.map +1 -0
- package/dist/Icon-C_Ooy-cP.cjs +16 -0
- package/dist/Icon-C_Ooy-cP.cjs.map +1 -0
- package/dist/Notice-D5nzvm08.js +89 -0
- package/dist/Notice-D5nzvm08.js.map +1 -0
- package/dist/Notice-Mjo3MJi2.cjs +91 -0
- package/dist/Notice-Mjo3MJi2.cjs.map +1 -0
- package/dist/PermissionDenied-DFCUFnNH.js +22 -0
- package/dist/PermissionDenied-DFCUFnNH.js.map +1 -0
- package/dist/PermissionDenied-DjZjq-3E.cjs +24 -0
- package/dist/PermissionDenied-DjZjq-3E.cjs.map +1 -0
- package/dist/SessionExpired-DGk3CXNp.cjs +47 -0
- package/dist/SessionExpired-DGk3CXNp.cjs.map +1 -0
- package/dist/SessionExpired-Dhmm8eLq.js +45 -0
- package/dist/SessionExpired-Dhmm8eLq.js.map +1 -0
- package/dist/StatusBadge-Bow-zeGQ.cjs +74 -0
- package/dist/StatusBadge-Bow-zeGQ.cjs.map +1 -0
- package/dist/StatusBadge-CBbwykMh.js +72 -0
- package/dist/StatusBadge-CBbwykMh.js.map +1 -0
- package/dist/Txt-AhytBlTj.js +26 -0
- package/dist/Txt-AhytBlTj.js.map +1 -0
- package/dist/Txt-Cmn4ug68.cjs +28 -0
- package/dist/Txt-Cmn4ug68.cjs.map +1 -0
- package/dist/alert-dialog-DfQhrc2F.cjs +120 -0
- package/dist/alert-dialog-DfQhrc2F.cjs.map +1 -0
- package/dist/alert-dialog-bKOBpddM.js +99 -0
- package/dist/alert-dialog-bKOBpddM.js.map +1 -0
- package/dist/as-child-Dgr1RHLO.cjs +29 -0
- package/dist/as-child-Dgr1RHLO.cjs.map +1 -0
- package/dist/as-child-N1qMDCr8.js +8 -0
- package/dist/as-child-N1qMDCr8.js.map +1 -0
- package/dist/brand-loader-Bxz0bWdp.js +52 -0
- package/dist/brand-loader-Bxz0bWdp.js.map +1 -0
- package/dist/brand-loader-DNMY5ZK7.cjs +54 -0
- package/dist/brand-loader-DNMY5ZK7.cjs.map +1 -0
- package/dist/brand-loader.css +68 -0
- package/dist/buttons-group-BAU7uXE9.js +161 -0
- package/dist/buttons-group-BAU7uXE9.js.map +1 -0
- package/dist/buttons-group-BvLg2kpv.cjs +185 -0
- package/dist/buttons-group-BvLg2kpv.cjs.map +1 -0
- package/dist/checkbox-Bda6srNY.cjs +109 -0
- package/dist/checkbox-Bda6srNY.cjs.map +1 -0
- package/dist/checkbox-DmKlRClz.js +88 -0
- package/dist/checkbox-DmKlRClz.js.map +1 -0
- package/dist/chip-Cx5D5DkA.cjs +68 -0
- package/dist/chip-Cx5D5DkA.cjs.map +1 -0
- package/dist/chip-Dgrpa03p.js +66 -0
- package/dist/chip-Dgrpa03p.js.map +1 -0
- package/dist/chips-group-CaxAKuxv.cjs +23 -0
- package/dist/chips-group-CaxAKuxv.cjs.map +1 -0
- package/dist/chips-group-DgaAmiHe.js +21 -0
- package/dist/chips-group-DgaAmiHe.js.map +1 -0
- package/dist/code-B3WONxnA.cjs +68 -0
- package/dist/code-B3WONxnA.cjs.map +1 -0
- package/dist/code-C5KVVzOZ.js +47 -0
- package/dist/code-C5KVVzOZ.js.map +1 -0
- package/dist/code-block-53x4kvYO.js +73 -0
- package/dist/code-block-53x4kvYO.js.map +1 -0
- package/dist/code-block-UyWLLMZ0.cjs +75 -0
- package/dist/code-block-UyWLLMZ0.cjs.map +1 -0
- package/dist/code-diff-C2vuR6Ti.cjs +136 -0
- package/dist/code-diff-C2vuR6Ti.cjs.map +1 -0
- package/dist/code-diff-lktH1err.js +134 -0
- package/dist/code-diff-lktH1err.js.map +1 -0
- package/dist/code-editor-BuzhLm2a.cjs +446 -0
- package/dist/code-editor-BuzhLm2a.cjs.map +1 -0
- package/dist/code-editor-XAfFI9V8.js +438 -0
- package/dist/code-editor-XAfFI9V8.js.map +1 -0
- package/dist/collapsible-CDSgJ39O.cjs +61 -0
- package/dist/collapsible-CDSgJ39O.cjs.map +1 -0
- package/dist/collapsible-PODbdTuV.js +57 -0
- package/dist/collapsible-PODbdTuV.js.map +1 -0
- package/dist/combobox-B2TriE9Z.cjs +77 -0
- package/dist/combobox-B2TriE9Z.cjs.map +1 -0
- package/dist/combobox-q2xPfCZc.js +75 -0
- package/dist/combobox-q2xPfCZc.js.map +1 -0
- package/dist/command-D0tQ1Lpz.cjs +151 -0
- package/dist/command-D0tQ1Lpz.cjs.map +1 -0
- package/dist/command-DPEUOKZw.js +122 -0
- package/dist/command-DPEUOKZw.js.map +1 -0
- package/dist/components/AlertDialog.cjs.js +10 -0
- package/dist/components/AlertDialog.cjs.js.map +1 -0
- package/dist/components/AlertDialog.d.ts +2 -0
- package/dist/components/AlertDialog.es.js +2 -0
- package/dist/components/AlertDialog.es.js.map +1 -0
- package/dist/components/Avatar.cjs.js +10 -0
- package/dist/components/Avatar.cjs.js.map +1 -0
- package/dist/components/Avatar.d.ts +2 -0
- package/dist/components/Avatar.es.js +2 -0
- package/dist/components/Avatar.es.js.map +1 -0
- package/dist/components/Badge.cjs.js +10 -0
- package/dist/components/Badge.cjs.js.map +1 -0
- package/dist/components/Badge.d.ts +2 -0
- package/dist/components/Badge.es.js +2 -0
- package/dist/components/Badge.es.js.map +1 -0
- package/dist/components/BrandLoader.cjs.js +10 -0
- package/dist/components/BrandLoader.cjs.js.map +1 -0
- package/dist/components/BrandLoader.d.ts +2 -0
- package/dist/components/BrandLoader.es.js +2 -0
- package/dist/components/BrandLoader.es.js.map +1 -0
- package/dist/components/Breadcrumb.cjs.js +11 -0
- package/dist/components/Breadcrumb.cjs.js.map +1 -0
- package/dist/components/Breadcrumb.d.ts +2 -0
- package/dist/components/Breadcrumb.es.js +2 -0
- package/dist/components/Breadcrumb.es.js.map +1 -0
- package/dist/components/Button.cjs.js +11 -0
- package/dist/components/Button.cjs.js.map +1 -0
- package/dist/components/Button.d.ts +2 -0
- package/dist/components/Button.es.js +2 -0
- package/dist/components/Button.es.js.map +1 -0
- package/dist/components/ButtonsGroup.cjs.js +13 -0
- package/dist/components/ButtonsGroup.cjs.js.map +1 -0
- package/dist/components/ButtonsGroup.d.ts +2 -0
- package/dist/components/ButtonsGroup.es.js +2 -0
- package/dist/components/ButtonsGroup.es.js.map +1 -0
- package/dist/components/Card.cjs.js +15 -0
- package/dist/components/Card.cjs.js.map +1 -0
- package/dist/components/Card.d.ts +2 -0
- package/dist/components/Card.es.js +2 -0
- package/dist/components/Card.es.js.map +1 -0
- package/dist/components/Checkbox.cjs.js +10 -0
- package/dist/components/Checkbox.cjs.js.map +1 -0
- package/dist/components/Checkbox.d.ts +2 -0
- package/dist/components/Checkbox.es.js +2 -0
- package/dist/components/Checkbox.es.js.map +1 -0
- package/dist/components/Chip.cjs.js +12 -0
- package/dist/components/Chip.cjs.js.map +1 -0
- package/dist/components/Chip.d.ts +2 -0
- package/dist/components/Chip.es.js +3 -0
- package/dist/components/Chip.es.js.map +1 -0
- package/dist/components/Code.cjs.js +10 -0
- package/dist/components/Code.cjs.js.map +1 -0
- package/dist/components/Code.d.ts +2 -0
- package/dist/components/Code.es.js +2 -0
- package/dist/components/Code.es.js.map +1 -0
- package/dist/components/CodeBlock.cjs.js +10 -0
- package/dist/components/CodeBlock.cjs.js.map +1 -0
- package/dist/components/CodeBlock.d.ts +2 -0
- package/dist/components/CodeBlock.es.js +2 -0
- package/dist/components/CodeBlock.es.js.map +1 -0
- package/dist/components/CodeDiff.cjs.js +10 -0
- package/dist/components/CodeDiff.cjs.js.map +1 -0
- package/dist/components/CodeDiff.d.ts +2 -0
- package/dist/components/CodeDiff.es.js +2 -0
- package/dist/components/CodeDiff.es.js.map +1 -0
- package/dist/components/CodeEditor.cjs.js +18 -0
- package/dist/components/CodeEditor.cjs.js.map +1 -0
- package/dist/components/CodeEditor.d.ts +2 -0
- package/dist/components/CodeEditor.es.js +3 -0
- package/dist/components/CodeEditor.es.js.map +1 -0
- package/dist/components/Collapsible.cjs.js +12 -0
- package/dist/components/Collapsible.cjs.js.map +1 -0
- package/dist/components/Collapsible.d.ts +2 -0
- package/dist/components/Collapsible.es.js +2 -0
- package/dist/components/Collapsible.es.js.map +1 -0
- package/dist/components/Columns.cjs.js +12 -0
- package/dist/components/Columns.cjs.js.map +1 -0
- package/dist/components/Columns.d.ts +2 -0
- package/dist/components/Columns.es.js +2 -0
- package/dist/components/Columns.es.js.map +1 -0
- package/dist/components/Combobox.cjs.js +18 -0
- package/dist/components/Combobox.cjs.js.map +1 -0
- package/dist/components/Combobox.d.ts +2 -0
- package/dist/components/Combobox.es.js +4 -0
- package/dist/components/Combobox.es.js.map +1 -0
- package/dist/components/Command.cjs.js +18 -0
- package/dist/components/Command.cjs.js.map +1 -0
- package/dist/components/Command.d.ts +2 -0
- package/dist/components/Command.es.js +2 -0
- package/dist/components/Command.es.js.map +1 -0
- package/dist/components/ContentBlocks.cjs.js +11 -0
- package/dist/components/ContentBlocks.cjs.js.map +1 -0
- package/dist/components/ContentBlocks.d.ts +2 -0
- package/dist/components/ContentBlocks.es.js +2 -0
- package/dist/components/ContentBlocks.es.js.map +1 -0
- package/dist/components/ContextMenu.cjs.js +212 -0
- package/dist/components/ContextMenu.cjs.js.map +1 -0
- package/dist/components/ContextMenu.d.ts +2 -0
- package/dist/components/ContextMenu.es.js +189 -0
- package/dist/components/ContextMenu.es.js.map +1 -0
- package/dist/components/CopyButton.cjs.js +10 -0
- package/dist/components/CopyButton.cjs.js.map +1 -0
- package/dist/components/CopyButton.d.ts +2 -0
- package/dist/components/CopyButton.es.js +2 -0
- package/dist/components/CopyButton.es.js.map +1 -0
- package/dist/components/DashboardCard.cjs.js +10 -0
- package/dist/components/DashboardCard.cjs.js.map +1 -0
- package/dist/components/DashboardCard.d.ts +2 -0
- package/dist/components/DashboardCard.es.js +2 -0
- package/dist/components/DashboardCard.es.js.map +1 -0
- package/dist/components/DataCodeSection.cjs.js +10 -0
- package/dist/components/DataCodeSection.cjs.js.map +1 -0
- package/dist/components/DataCodeSection.d.ts +2 -0
- package/dist/components/DataCodeSection.es.js +2 -0
- package/dist/components/DataCodeSection.es.js.map +1 -0
- package/dist/components/DataDetailsPanel.cjs.js +228 -0
- package/dist/components/DataDetailsPanel.cjs.js.map +1 -0
- package/dist/components/DataDetailsPanel.d.ts +2 -0
- package/dist/components/DataDetailsPanel.es.js +224 -0
- package/dist/components/DataDetailsPanel.es.js.map +1 -0
- package/dist/components/DataFilter.cjs.js +10 -0
- package/dist/components/DataFilter.cjs.js.map +1 -0
- package/dist/components/DataFilter.d.ts +2 -0
- package/dist/components/DataFilter.es.js +2 -0
- package/dist/components/DataFilter.es.js.map +1 -0
- package/dist/components/DataKeysAndValues.cjs.js +10 -0
- package/dist/components/DataKeysAndValues.cjs.js.map +1 -0
- package/dist/components/DataKeysAndValues.d.ts +2 -0
- package/dist/components/DataKeysAndValues.es.js +2 -0
- package/dist/components/DataKeysAndValues.es.js.map +1 -0
- package/dist/components/DataList.cjs.js +14 -0
- package/dist/components/DataList.cjs.js.map +1 -0
- package/dist/components/DataList.d.ts +2 -0
- package/dist/components/DataList.es.js +3 -0
- package/dist/components/DataList.es.js.map +1 -0
- package/dist/components/DataPanel.cjs.js +10 -0
- package/dist/components/DataPanel.cjs.js.map +1 -0
- package/dist/components/DataPanel.d.ts +2 -0
- package/dist/components/DataPanel.es.js +2 -0
- package/dist/components/DataPanel.es.js.map +1 -0
- package/dist/components/DateTimePicker.cjs.js +15 -0
- package/dist/components/DateTimePicker.cjs.js.map +1 -0
- package/dist/components/DateTimePicker.d.ts +2 -0
- package/dist/components/DateTimePicker.es.js +3 -0
- package/dist/components/DateTimePicker.es.js.map +1 -0
- package/dist/components/DateTimeRangePicker.cjs.js +10 -0
- package/dist/components/DateTimeRangePicker.cjs.js.map +1 -0
- package/dist/components/DateTimeRangePicker.d.ts +2 -0
- package/dist/components/DateTimeRangePicker.es.js +2 -0
- package/dist/components/DateTimeRangePicker.es.js.map +1 -0
- package/dist/components/Dialog.cjs.js +20 -0
- package/dist/components/Dialog.cjs.js.map +1 -0
- package/dist/components/Dialog.d.ts +2 -0
- package/dist/components/Dialog.es.js +2 -0
- package/dist/components/Dialog.es.js.map +1 -0
- package/dist/components/Drawer.cjs.js +29 -0
- package/dist/components/Drawer.cjs.js.map +1 -0
- package/dist/components/Drawer.d.ts +2 -0
- package/dist/components/Drawer.es.js +2 -0
- package/dist/components/Drawer.es.js.map +1 -0
- package/dist/components/DropdownMenu.cjs.js +10 -0
- package/dist/components/DropdownMenu.cjs.js.map +1 -0
- package/dist/components/DropdownMenu.d.ts +2 -0
- package/dist/components/DropdownMenu.es.js +2 -0
- package/dist/components/DropdownMenu.es.js.map +1 -0
- package/dist/components/EmptyState.cjs.js +10 -0
- package/dist/components/EmptyState.cjs.js.map +1 -0
- package/dist/components/EmptyState.d.ts +2 -0
- package/dist/components/EmptyState.es.js +2 -0
- package/dist/components/EmptyState.es.js.map +1 -0
- package/dist/components/Entity.cjs.js +14 -0
- package/dist/components/Entity.cjs.js.map +1 -0
- package/dist/components/Entity.d.ts +2 -0
- package/dist/components/Entity.es.js +2 -0
- package/dist/components/Entity.es.js.map +1 -0
- package/dist/components/EntityHeader.cjs.js +10 -0
- package/dist/components/EntityHeader.cjs.js.map +1 -0
- package/dist/components/EntityHeader.d.ts +2 -0
- package/dist/components/EntityHeader.es.js +2 -0
- package/dist/components/EntityHeader.es.js.map +1 -0
- package/dist/components/Entry.cjs.js +10 -0
- package/dist/components/Entry.cjs.js.map +1 -0
- package/dist/components/Entry.d.ts +2 -0
- package/dist/components/Entry.es.js +2 -0
- package/dist/components/Entry.es.js.map +1 -0
- package/dist/components/ErrorBoundary.cjs.js +10 -0
- package/dist/components/ErrorBoundary.cjs.js.map +1 -0
- package/dist/components/ErrorBoundary.d.ts +2 -0
- package/dist/components/ErrorBoundary.es.js +2 -0
- package/dist/components/ErrorBoundary.es.js.map +1 -0
- package/dist/components/ErrorState.cjs.js +10 -0
- package/dist/components/ErrorState.cjs.js.map +1 -0
- package/dist/components/ErrorState.d.ts +2 -0
- package/dist/components/ErrorState.es.js +2 -0
- package/dist/components/ErrorState.es.js.map +1 -0
- package/dist/components/FormFieldBlocks.cjs.js +18 -0
- package/dist/components/FormFieldBlocks.cjs.js.map +1 -0
- package/dist/components/FormFieldBlocks.d.ts +2 -0
- package/dist/components/FormFieldBlocks.es.js +6 -0
- package/dist/components/FormFieldBlocks.es.js.map +1 -0
- package/dist/components/Header.cjs.js +13 -0
- package/dist/components/Header.cjs.js.map +1 -0
- package/dist/components/Header.d.ts +2 -0
- package/dist/components/Header.es.js +2 -0
- package/dist/components/Header.es.js.map +1 -0
- package/dist/components/HorizontalBars.cjs.js +10 -0
- package/dist/components/HorizontalBars.cjs.js.map +1 -0
- package/dist/components/HorizontalBars.d.ts +2 -0
- package/dist/components/HorizontalBars.es.js +2 -0
- package/dist/components/HorizontalBars.es.js.map +1 -0
- package/dist/components/HoverCard.cjs.js +12 -0
- package/dist/components/HoverCard.cjs.js.map +1 -0
- package/dist/components/HoverCard.d.ts +2 -0
- package/dist/components/HoverCard.es.js +2 -0
- package/dist/components/HoverCard.es.js.map +1 -0
- package/dist/components/Input.cjs.js +10 -0
- package/dist/components/Input.cjs.js.map +1 -0
- package/dist/components/Input.d.ts +2 -0
- package/dist/components/Input.es.js +2 -0
- package/dist/components/Input.es.js.map +1 -0
- package/dist/components/InputGroup.cjs.js +15 -0
- package/dist/components/InputGroup.cjs.js.map +1 -0
- package/dist/components/InputGroup.d.ts +2 -0
- package/dist/components/InputGroup.es.js +2 -0
- package/dist/components/InputGroup.es.js.map +1 -0
- package/dist/components/ItemList.cjs.js +14 -0
- package/dist/components/ItemList.cjs.js.map +1 -0
- package/dist/components/ItemList.d.ts +2 -0
- package/dist/components/ItemList.es.js +2 -0
- package/dist/components/ItemList.es.js.map +1 -0
- package/dist/components/JSONSchemaForm.cjs.js +547 -0
- package/dist/components/JSONSchemaForm.cjs.js.map +1 -0
- package/dist/components/JSONSchemaForm.d.ts +2 -0
- package/dist/components/JSONSchemaForm.es.js +507 -0
- package/dist/components/JSONSchemaForm.es.js.map +1 -0
- package/dist/components/Kbd.cjs.js +10 -0
- package/dist/components/Kbd.cjs.js.map +1 -0
- package/dist/components/Kbd.d.ts +2 -0
- package/dist/components/Kbd.es.js +2 -0
- package/dist/components/Kbd.es.js.map +1 -0
- package/dist/components/KeyValueList.cjs.js +10 -0
- package/dist/components/KeyValueList.cjs.js.map +1 -0
- package/dist/components/KeyValueList.d.ts +2 -0
- package/dist/components/KeyValueList.es.js +2 -0
- package/dist/components/KeyValueList.es.js.map +1 -0
- package/dist/components/Label.cjs.js +10 -0
- package/dist/components/Label.cjs.js.map +1 -0
- package/dist/components/Label.d.ts +2 -0
- package/dist/components/Label.es.js +2 -0
- package/dist/components/Label.es.js.map +1 -0
- package/dist/components/ListSearch.cjs.js +10 -0
- package/dist/components/ListSearch.cjs.js.map +1 -0
- package/dist/components/ListSearch.d.ts +2 -0
- package/dist/components/ListSearch.es.js +2 -0
- package/dist/components/ListSearch.es.js.map +1 -0
- package/dist/components/Logo.cjs.js +11 -0
- package/dist/components/Logo.cjs.js.map +1 -0
- package/dist/components/Logo.d.ts +2 -0
- package/dist/components/Logo.es.js +2 -0
- package/dist/components/Logo.es.js.map +1 -0
- package/dist/components/LogsDataList.cjs.js +12 -0
- package/dist/components/LogsDataList.cjs.js.map +1 -0
- package/dist/components/LogsDataList.d.ts +2 -0
- package/dist/components/LogsDataList.es.js +3 -0
- package/dist/components/LogsDataList.es.js.map +1 -0
- package/dist/components/MainContent.cjs.js +12 -0
- package/dist/components/MainContent.cjs.js.map +1 -0
- package/dist/components/MainContent.d.ts +2 -0
- package/dist/components/MainContent.es.js +2 -0
- package/dist/components/MainContent.es.js.map +1 -0
- package/dist/components/MainHeader.cjs.js +10 -0
- package/dist/components/MainHeader.cjs.js.map +1 -0
- package/dist/components/MainHeader.d.ts +2 -0
- package/dist/components/MainHeader.es.js +2 -0
- package/dist/components/MainHeader.es.js.map +1 -0
- package/dist/components/MainSidebar.cjs.js +17 -0
- package/dist/components/MainSidebar.cjs.js.map +1 -0
- package/dist/components/MainSidebar.d.ts +2 -0
- package/dist/components/MainSidebar.es.js +2 -0
- package/dist/components/MainSidebar.es.js.map +1 -0
- package/dist/components/MarkdownRenderer.cjs.js +10 -0
- package/dist/components/MarkdownRenderer.cjs.js.map +1 -0
- package/dist/components/MarkdownRenderer.d.ts +2 -0
- package/dist/components/MarkdownRenderer.es.js +2 -0
- package/dist/components/MarkdownRenderer.es.js.map +1 -0
- package/dist/components/MetricsCard.cjs.js +10 -0
- package/dist/components/MetricsCard.cjs.js.map +1 -0
- package/dist/components/MetricsCard.d.ts +2 -0
- package/dist/components/MetricsCard.es.js +2 -0
- package/dist/components/MetricsCard.es.js.map +1 -0
- package/dist/components/MetricsDataTable.cjs.js +10 -0
- package/dist/components/MetricsDataTable.cjs.js.map +1 -0
- package/dist/components/MetricsDataTable.d.ts +2 -0
- package/dist/components/MetricsDataTable.es.js +2 -0
- package/dist/components/MetricsDataTable.es.js.map +1 -0
- package/dist/components/MetricsFlexGrid.cjs.js +10 -0
- package/dist/components/MetricsFlexGrid.cjs.js.map +1 -0
- package/dist/components/MetricsFlexGrid.d.ts +2 -0
- package/dist/components/MetricsFlexGrid.es.js +2 -0
- package/dist/components/MetricsFlexGrid.es.js.map +1 -0
- package/dist/components/MetricsKpiCard.cjs.js +10 -0
- package/dist/components/MetricsKpiCard.cjs.js.map +1 -0
- package/dist/components/MetricsKpiCard.d.ts +2 -0
- package/dist/components/MetricsKpiCard.es.js +2 -0
- package/dist/components/MetricsKpiCard.es.js.map +1 -0
- package/dist/components/MetricsLineChart.cjs.js +11 -0
- package/dist/components/MetricsLineChart.cjs.js.map +1 -0
- package/dist/components/MetricsLineChart.d.ts +2 -0
- package/dist/components/MetricsLineChart.es.js +2 -0
- package/dist/components/MetricsLineChart.es.js.map +1 -0
- package/dist/components/Notice.cjs.js +10 -0
- package/dist/components/Notice.cjs.js.map +1 -0
- package/dist/components/Notice.d.ts +2 -0
- package/dist/components/Notice.es.js +2 -0
- package/dist/components/Notice.es.js.map +1 -0
- package/dist/components/PageHeader.cjs.js +10 -0
- package/dist/components/PageHeader.cjs.js.map +1 -0
- package/dist/components/PageHeader.d.ts +2 -0
- package/dist/components/PageHeader.es.js +2 -0
- package/dist/components/PageHeader.es.js.map +1 -0
- package/dist/components/PageLayout.cjs.js +14 -0
- package/dist/components/PageLayout.cjs.js.map +1 -0
- package/dist/components/PageLayout.d.ts +2 -0
- package/dist/components/PageLayout.es.js +3 -0
- package/dist/components/PageLayout.es.js.map +1 -0
- package/dist/components/PendingIndicator.cjs.js +10 -0
- package/dist/components/PendingIndicator.cjs.js.map +1 -0
- package/dist/components/PendingIndicator.d.ts +2 -0
- package/dist/components/PendingIndicator.es.js +2 -0
- package/dist/components/PendingIndicator.es.js.map +1 -0
- package/dist/components/PermissionDenied.cjs.js +10 -0
- package/dist/components/PermissionDenied.cjs.js.map +1 -0
- package/dist/components/PermissionDenied.d.ts +2 -0
- package/dist/components/PermissionDenied.es.js +2 -0
- package/dist/components/PermissionDenied.es.js.map +1 -0
- package/dist/components/Popover.cjs.js +13 -0
- package/dist/components/Popover.cjs.js.map +1 -0
- package/dist/components/Popover.d.ts +2 -0
- package/dist/components/Popover.es.js +2 -0
- package/dist/components/Popover.es.js.map +1 -0
- package/dist/components/PrevNextNav.cjs.js +29 -0
- package/dist/components/PrevNextNav.cjs.js.map +1 -0
- package/dist/components/PrevNextNav.d.ts +2 -0
- package/dist/components/PrevNextNav.es.js +25 -0
- package/dist/components/PrevNextNav.es.js.map +1 -0
- package/dist/components/PropertyFilter.cjs.js +13 -0
- package/dist/components/PropertyFilter.cjs.js.map +1 -0
- package/dist/components/PropertyFilter.d.ts +2 -0
- package/dist/components/PropertyFilter.es.js +2 -0
- package/dist/components/PropertyFilter.es.js.map +1 -0
- package/dist/components/RadioGroup.cjs.js +11 -0
- package/dist/components/RadioGroup.cjs.js.map +1 -0
- package/dist/components/RadioGroup.d.ts +2 -0
- package/dist/components/RadioGroup.es.js +2 -0
- package/dist/components/RadioGroup.es.js.map +1 -0
- package/dist/components/ScrollArea.cjs.js +11 -0
- package/dist/components/ScrollArea.cjs.js.map +1 -0
- package/dist/components/ScrollArea.d.ts +2 -0
- package/dist/components/ScrollArea.es.js +2 -0
- package/dist/components/ScrollArea.es.js.map +1 -0
- package/dist/components/ScrollableContainer.cjs.js +10 -0
- package/dist/components/ScrollableContainer.cjs.js.map +1 -0
- package/dist/components/ScrollableContainer.d.ts +2 -0
- package/dist/components/ScrollableContainer.es.js +2 -0
- package/dist/components/ScrollableContainer.es.js.map +1 -0
- package/dist/components/Searchbar.cjs.js +11 -0
- package/dist/components/Searchbar.cjs.js.map +1 -0
- package/dist/components/Searchbar.d.ts +2 -0
- package/dist/components/Searchbar.es.js +2 -0
- package/dist/components/Searchbar.es.js.map +1 -0
- package/dist/components/Section.cjs.js +12 -0
- package/dist/components/Section.cjs.js.map +1 -0
- package/dist/components/Section.d.ts +2 -0
- package/dist/components/Section.es.js +2 -0
- package/dist/components/Section.es.js.map +1 -0
- package/dist/components/SectionCard.cjs.js +11 -0
- package/dist/components/SectionCard.cjs.js.map +1 -0
- package/dist/components/SectionCard.d.ts +2 -0
- package/dist/components/SectionCard.es.js +2 -0
- package/dist/components/SectionCard.es.js.map +1 -0
- package/dist/components/Sections.cjs.js +10 -0
- package/dist/components/Sections.cjs.js.map +1 -0
- package/dist/components/Sections.d.ts +2 -0
- package/dist/components/Sections.es.js +2 -0
- package/dist/components/Sections.es.js.map +1 -0
- package/dist/components/Select.cjs.js +15 -0
- package/dist/components/Select.cjs.js.map +1 -0
- package/dist/components/Select.d.ts +2 -0
- package/dist/components/Select.es.js +2 -0
- package/dist/components/Select.es.js.map +1 -0
- package/dist/components/SessionExpired.cjs.js +10 -0
- package/dist/components/SessionExpired.cjs.js.map +1 -0
- package/dist/components/SessionExpired.d.ts +2 -0
- package/dist/components/SessionExpired.es.js +2 -0
- package/dist/components/SessionExpired.es.js.map +1 -0
- package/dist/components/SettingsRow.cjs.js +27 -0
- package/dist/components/SettingsRow.cjs.js.map +1 -0
- package/dist/components/SettingsRow.d.ts +2 -0
- package/dist/components/SettingsRow.es.js +23 -0
- package/dist/components/SettingsRow.es.js.map +1 -0
- package/dist/components/Shimmer.cjs.js +10 -0
- package/dist/components/Shimmer.cjs.js.map +1 -0
- package/dist/components/Shimmer.d.ts +2 -0
- package/dist/components/Shimmer.es.js +2 -0
- package/dist/components/Shimmer.es.js.map +1 -0
- package/dist/components/SideDialog.cjs.js +297 -0
- package/dist/components/SideDialog.cjs.js.map +1 -0
- package/dist/components/SideDialog.d.ts +2 -0
- package/dist/components/SideDialog.es.js +275 -0
- package/dist/components/SideDialog.es.js.map +1 -0
- package/dist/components/Skeleton.cjs.js +10 -0
- package/dist/components/Skeleton.cjs.js.map +1 -0
- package/dist/components/Skeleton.d.ts +2 -0
- package/dist/components/Skeleton.es.js +2 -0
- package/dist/components/Skeleton.es.js.map +1 -0
- package/dist/components/Slider.cjs.js +10 -0
- package/dist/components/Slider.cjs.js.map +1 -0
- package/dist/components/Slider.d.ts +2 -0
- package/dist/components/Slider.es.js +2 -0
- package/dist/components/Slider.es.js.map +1 -0
- package/dist/components/Spinner.cjs.js +10 -0
- package/dist/components/Spinner.cjs.js.map +1 -0
- package/dist/components/Spinner.d.ts +2 -0
- package/dist/components/Spinner.es.js +2 -0
- package/dist/components/Spinner.es.js.map +1 -0
- package/dist/components/StatusBadge.cjs.js +10 -0
- package/dist/components/StatusBadge.cjs.js.map +1 -0
- package/dist/components/StatusBadge.d.ts +2 -0
- package/dist/components/StatusBadge.es.js +2 -0
- package/dist/components/StatusBadge.es.js.map +1 -0
- package/dist/components/Steps.cjs.js +13 -0
- package/dist/components/Steps.cjs.js.map +1 -0
- package/dist/components/Steps.d.ts +2 -0
- package/dist/components/Steps.es.js +2 -0
- package/dist/components/Steps.es.js.map +1 -0
- package/dist/components/Switch.cjs.js +10 -0
- package/dist/components/Switch.cjs.js.map +1 -0
- package/dist/components/Switch.d.ts +2 -0
- package/dist/components/Switch.es.js +2 -0
- package/dist/components/Switch.es.js.map +1 -0
- package/dist/components/Table.cjs.js +19 -0
- package/dist/components/Table.cjs.js.map +1 -0
- package/dist/components/Table.d.ts +2 -0
- package/dist/components/Table.es.js +2 -0
- package/dist/components/Table.es.js.map +1 -0
- package/dist/components/Tabs.cjs.js +14 -0
- package/dist/components/Tabs.cjs.js.map +1 -0
- package/dist/components/Tabs.d.ts +2 -0
- package/dist/components/Tabs.es.js +3 -0
- package/dist/components/Tabs.es.js.map +1 -0
- package/dist/components/Text.cjs.js +11 -0
- package/dist/components/Text.cjs.js.map +1 -0
- package/dist/components/Text.d.ts +2 -0
- package/dist/components/Text.es.js +2 -0
- package/dist/components/Text.es.js.map +1 -0
- package/dist/components/Textarea.cjs.js +10 -0
- package/dist/components/Textarea.cjs.js.map +1 -0
- package/dist/components/Textarea.d.ts +2 -0
- package/dist/components/Textarea.es.js +2 -0
- package/dist/components/Textarea.es.js.map +1 -0
- package/dist/components/ThemeProvider.cjs.js +11 -0
- package/dist/components/ThemeProvider.cjs.js.map +1 -0
- package/dist/components/ThemeProvider.d.ts +2 -0
- package/dist/components/ThemeProvider.es.js +2 -0
- package/dist/components/ThemeProvider.es.js.map +1 -0
- package/dist/components/ThemeToggle.cjs.js +10 -0
- package/dist/components/ThemeToggle.cjs.js.map +1 -0
- package/dist/components/ThemeToggle.d.ts +2 -0
- package/dist/components/ThemeToggle.es.js +2 -0
- package/dist/components/ThemeToggle.es.js.map +1 -0
- package/dist/components/Tooltip.cjs.js +13 -0
- package/dist/components/Tooltip.cjs.js.map +1 -0
- package/dist/components/Tooltip.d.ts +2 -0
- package/dist/components/Tooltip.es.js +2 -0
- package/dist/components/Tooltip.es.js.map +1 -0
- package/dist/components/Tree.cjs.js +10 -0
- package/dist/components/Tree.cjs.js.map +1 -0
- package/dist/components/Tree.d.ts +2 -0
- package/dist/components/Tree.es.js +2 -0
- package/dist/components/Tree.es.js.map +1 -0
- package/dist/components/Truncate.cjs.js +10 -0
- package/dist/components/Truncate.cjs.js.map +1 -0
- package/dist/components/Truncate.d.ts +2 -0
- package/dist/components/Truncate.es.js +2 -0
- package/dist/components/Truncate.es.js.map +1 -0
- package/dist/components/Txt.cjs.js +10 -0
- package/dist/components/Txt.cjs.js.map +1 -0
- package/dist/components/Txt.d.ts +2 -0
- package/dist/components/Txt.es.js +2 -0
- package/dist/components/Txt.es.js.map +1 -0
- package/dist/content-block-BTpK7gPz.js +38 -0
- package/dist/content-block-BTpK7gPz.js.map +1 -0
- package/dist/content-block-Csb01oxE.cjs +41 -0
- package/dist/content-block-Csb01oxE.cjs.map +1 -0
- package/dist/control-size-BdDLgGX4.js +22 -0
- package/dist/control-size-BdDLgGX4.js.map +1 -0
- package/dist/control-size-D67C0kPZ.cjs +26 -0
- package/dist/control-size-D67C0kPZ.cjs.map +1 -0
- package/dist/copy-button-DDKn1NUS.js +42 -0
- package/dist/copy-button-DDKn1NUS.js.map +1 -0
- package/dist/copy-button-lrxHKwwi.cjs +44 -0
- package/dist/copy-button-lrxHKwwi.cjs.map +1 -0
- package/dist/dashboard-card-B9enj4NG.cjs +11 -0
- package/dist/dashboard-card-B9enj4NG.cjs.map +1 -0
- package/dist/dashboard-card-C7nmBU5A.js +9 -0
- package/dist/dashboard-card-C7nmBU5A.js.map +1 -0
- package/dist/data-code-section-BYhkWiIy.js +332 -0
- package/dist/data-code-section-BYhkWiIy.js.map +1 -0
- package/dist/data-code-section-Bz_B8nrw.cjs +335 -0
- package/dist/data-code-section-Bz_B8nrw.cjs.map +1 -0
- package/dist/data-keys-and-values-BSeQG7jb.js +122 -0
- package/dist/data-keys-and-values-BSeQG7jb.js.map +1 -0
- package/dist/data-keys-and-values-Spy2O_IE.cjs +124 -0
- package/dist/data-keys-and-values-Spy2O_IE.cjs.map +1 -0
- package/dist/data-list-skeleton-Bges_t5u.cjs +416 -0
- package/dist/data-list-skeleton-Bges_t5u.cjs.map +1 -0
- package/dist/data-list-skeleton-C9Ncz3jM.js +389 -0
- package/dist/data-list-skeleton-C9Ncz3jM.js.map +1 -0
- package/dist/data-panel-CaS60apX.js +87 -0
- package/dist/data-panel-CaS60apX.js.map +1 -0
- package/dist/data-panel-CbV9Ycys.cjs +89 -0
- package/dist/data-panel-CbV9Ycys.cjs.map +1 -0
- package/dist/date-time-picker-BKqGpw5w.cjs +268 -0
- package/dist/date-time-picker-BKqGpw5w.cjs.map +1 -0
- package/dist/date-time-picker-t67keTZg.js +245 -0
- package/dist/date-time-picker-t67keTZg.js.map +1 -0
- package/dist/date-time-range-picker-Do-3VVvo.cjs +170 -0
- package/dist/date-time-range-picker-Do-3VVvo.cjs.map +1 -0
- package/dist/date-time-range-picker-iMvwOfiZ.js +168 -0
- package/dist/date-time-range-picker-iMvwOfiZ.js.map +1 -0
- package/dist/dialog-46zkb32X.cjs +105 -0
- package/dist/dialog-46zkb32X.cjs.map +1 -0
- package/dist/dialog-CSSfcjSX.js +74 -0
- package/dist/dialog-CSSfcjSX.js.map +1 -0
- package/dist/dialog.css +70 -0
- package/dist/drawer-BaUXhUlI.cjs +177 -0
- package/dist/drawer-BaUXhUlI.cjs.map +1 -0
- package/dist/drawer-wvz8SreU.js +137 -0
- package/dist/drawer-wvz8SreU.js.map +1 -0
- package/dist/drawer.css +131 -0
- package/dist/dropdown-menu-Dh-CMMjl.js +203 -0
- package/dist/dropdown-menu-Dh-CMMjl.js.map +1 -0
- package/dist/dropdown-menu-Vl_C0N5e.cjs +224 -0
- package/dist/dropdown-menu-Vl_C0N5e.cjs.map +1 -0
- package/dist/entity-header-CpClAdJT.js +17 -0
- package/dist/entity-header-CpClAdJT.js.map +1 -0
- package/dist/entity-header-D2q5PizE.cjs +19 -0
- package/dist/entity-header-D2q5PizE.cjs.map +1 -0
- package/dist/entry-B53NXi9c.js +12 -0
- package/dist/entry-B53NXi9c.js.map +1 -0
- package/dist/entry-BwpOISbt.cjs +14 -0
- package/dist/entry-BwpOISbt.cjs.map +1 -0
- package/dist/field-block-CdCFQi7X.js +85 -0
- package/dist/field-block-CdCFQi7X.js.map +1 -0
- package/dist/field-block-D9R9O6XE.cjs +87 -0
- package/dist/field-block-D9R9O6XE.cjs.map +1 -0
- package/dist/field-blocks-layout-BpbpaIev.js +31 -0
- package/dist/field-blocks-layout-BpbpaIev.js.map +1 -0
- package/dist/field-blocks-layout-Bqock2Nu.cjs +33 -0
- package/dist/field-blocks-layout-Bqock2Nu.cjs.map +1 -0
- package/dist/form-element-Cy7aV1Ds.cjs +22 -0
- package/dist/form-element-Cy7aV1Ds.cjs.map +1 -0
- package/dist/form-element-DUtZESwq.js +12 -0
- package/dist/form-element-DUtZESwq.js.map +1 -0
- package/dist/get-short-id-B4_2mLzM.js +25 -0
- package/dist/get-short-id-B4_2mLzM.js.map +1 -0
- package/dist/get-short-id-DtN4BmrD.cjs +28 -0
- package/dist/get-short-id-DtN4BmrD.cjs.map +1 -0
- package/dist/helpers-BH-wPlF0.js +346 -0
- package/dist/helpers-BH-wPlF0.js.map +1 -0
- package/dist/helpers-BbJUaSrW.cjs +352 -0
- package/dist/helpers-BbJUaSrW.cjs.map +1 -0
- package/dist/highlight-C2uRVhiA.cjs +68 -0
- package/dist/highlight-C2uRVhiA.cjs.map +1 -0
- package/dist/highlight-Dis62bkj.js +66 -0
- package/dist/highlight-Dis62bkj.js.map +1 -0
- package/dist/horizontal-bars-B43f5B_S.js +106 -0
- package/dist/horizontal-bars-B43f5B_S.js.map +1 -0
- package/dist/horizontal-bars-DkJlf6-x.cjs +108 -0
- package/dist/horizontal-bars-DkJlf6-x.cjs.map +1 -0
- package/dist/hover-card-ByLYfB05.cjs +56 -0
- package/dist/hover-card-ByLYfB05.cjs.map +1 -0
- package/dist/hover-card-CV2ASE_w.js +33 -0
- package/dist/hover-card-CV2ASE_w.js.map +1 -0
- package/dist/index-CsyK0ihk.js +45 -0
- package/dist/index-CsyK0ihk.js.map +1 -0
- package/dist/index-DPkWrpVb.cjs +47 -0
- package/dist/index-DPkWrpVb.cjs.map +1 -0
- package/dist/index.cjs.js +1477 -15901
- package/dist/index.cjs.js.map +1 -1
- package/dist/index.css +343 -1960
- package/dist/index.es.js +881 -15301
- package/dist/index.es.js.map +1 -1
- package/dist/input-DGvJg7no.cjs +86 -0
- package/dist/input-DGvJg7no.cjs.map +1 -0
- package/dist/input-DsX-P_dO.js +65 -0
- package/dist/input-DsX-P_dO.js.map +1 -0
- package/dist/input-group-Bi_4j-WW.cjs +245 -0
- package/dist/input-group-Bi_4j-WW.cjs.map +1 -0
- package/dist/input-group-DpQPpHRU.js +219 -0
- package/dist/input-group-DpQPpHRU.js.map +1 -0
- package/dist/kbd-CnIg1L19.cjs +29 -0
- package/dist/kbd-CnIg1L19.cjs.map +1 -0
- package/dist/kbd-DRd56y7q.js +27 -0
- package/dist/kbd-DRd56y7q.js.map +1 -0
- package/dist/key-value-list-BFGuMFbL.js +84 -0
- package/dist/key-value-list-BFGuMFbL.js.map +1 -0
- package/dist/key-value-list-D067I300.cjs +86 -0
- package/dist/key-value-list-D067I300.cjs.map +1 -0
- package/dist/label-Dgz2hRMg.js +13 -0
- package/dist/label-Dgz2hRMg.js.map +1 -0
- package/dist/label-U8omtW8w.cjs +34 -0
- package/dist/label-U8omtW8w.cjs.map +1 -0
- package/dist/list-search-DY84ZCM-.cjs +59 -0
- package/dist/list-search-DY84ZCM-.cjs.map +1 -0
- package/dist/list-search-Dk2A1fUf.js +57 -0
- package/dist/list-search-Dk2A1fUf.js.map +1 -0
- package/dist/logo-BvzT5a1s.cjs +70 -0
- package/dist/logo-BvzT5a1s.cjs.map +1 -0
- package/dist/logo-CaqfKyP7.js +67 -0
- package/dist/logo-CaqfKyP7.js.map +1 -0
- package/dist/logo.css +70 -0
- package/dist/logs-data-list-B0Y5AHWL.js +87 -0
- package/dist/logs-data-list-B0Y5AHWL.js.map +1 -0
- package/dist/logs-data-list-DikL8ZQ0.cjs +90 -0
- package/dist/logs-data-list-DikL8ZQ0.cjs.map +1 -0
- package/dist/main-content-CR0j00N1.js +75 -0
- package/dist/main-content-CR0j00N1.js.map +1 -0
- package/dist/main-content-CnmMWNin.cjs +79 -0
- package/dist/main-content-CnmMWNin.cjs.map +1 -0
- package/dist/main-header-Bp0d1TMi.js +96 -0
- package/dist/main-header-Bp0d1TMi.js.map +1 -0
- package/dist/main-header-DJLRceP9.cjs +98 -0
- package/dist/main-header-DJLRceP9.cjs.map +1 -0
- package/dist/main-sidebar-0q7MXh2j.js +761 -0
- package/dist/main-sidebar-0q7MXh2j.js.map +1 -0
- package/dist/main-sidebar-H8NQ7njm.cjs +771 -0
- package/dist/main-sidebar-H8NQ7njm.cjs.map +1 -0
- package/dist/markdown-renderer-BjWUNVYf.cjs +88 -0
- package/dist/markdown-renderer-BjWUNVYf.cjs.map +1 -0
- package/dist/markdown-renderer-fXSUbDkK.js +86 -0
- package/dist/markdown-renderer-fXSUbDkK.js.map +1 -0
- package/dist/metrics-card-Bk3X19xx.js +93 -0
- package/dist/metrics-card-Bk3X19xx.js.map +1 -0
- package/dist/metrics-card-hs1pqY2Y.cjs +95 -0
- package/dist/metrics-card-hs1pqY2Y.cjs.map +1 -0
- package/dist/metrics-data-table-BpEAlJi0.cjs +77 -0
- package/dist/metrics-data-table-BpEAlJi0.cjs.map +1 -0
- package/dist/metrics-data-table-Dds2TkvE.js +75 -0
- package/dist/metrics-data-table-Dds2TkvE.js.map +1 -0
- package/dist/metrics-flex-grid-BqtZ5emh.js +9 -0
- package/dist/metrics-flex-grid-BqtZ5emh.js.map +1 -0
- package/dist/metrics-flex-grid-DzlyAgr7.cjs +11 -0
- package/dist/metrics-flex-grid-DzlyAgr7.cjs.map +1 -0
- package/dist/metrics-kpi-card-CNUpkoQO.js +77 -0
- package/dist/metrics-kpi-card-CNUpkoQO.js.map +1 -0
- package/dist/metrics-kpi-card-D_SaIWBc.cjs +79 -0
- package/dist/metrics-kpi-card-D_SaIWBc.cjs.map +1 -0
- package/dist/metrics-line-chart-BUUqDQPW.js +106 -0
- package/dist/metrics-line-chart-BUUqDQPW.js.map +1 -0
- package/dist/metrics-line-chart-D1ZGVepo.cjs +109 -0
- package/dist/metrics-line-chart-D1ZGVepo.cjs.map +1 -0
- package/dist/multi-column-BzL86JPK.cjs +136 -0
- package/dist/multi-column-BzL86JPK.cjs.map +1 -0
- package/dist/multi-column-C1sXoVG3.js +132 -0
- package/dist/multi-column-C1sXoVG3.js.map +1 -0
- package/dist/multi-combobox-DkFLK64B.cjs +193 -0
- package/dist/multi-combobox-DkFLK64B.cjs.map +1 -0
- package/dist/multi-combobox-Y3gT0MqV.js +189 -0
- package/dist/multi-combobox-Y3gT0MqV.js.map +1 -0
- package/dist/no-data-page-layout-CZzEj0NE.js +101 -0
- package/dist/no-data-page-layout-CZzEj0NE.js.map +1 -0
- package/dist/no-data-page-layout-CiNBx-vK.cjs +104 -0
- package/dist/no-data-page-layout-CiNBx-vK.cjs.map +1 -0
- package/dist/page-header-BS_LNnKw.js +51 -0
- package/dist/page-header-BS_LNnKw.js.map +1 -0
- package/dist/page-header-C1ZlL4Ua.cjs +53 -0
- package/dist/page-header-C1ZlL4Ua.cjs.map +1 -0
- package/dist/page-heading-context-D3yjYoJE.js +9 -0
- package/dist/page-heading-context-D3yjYoJE.js.map +1 -0
- package/dist/page-heading-context-Du-CpxAx.cjs +12 -0
- package/dist/page-heading-context-Du-CpxAx.cjs.map +1 -0
- package/dist/pending-indicator-BxD-kwEk.cjs +9 -0
- package/dist/pending-indicator-BxD-kwEk.cjs.map +1 -0
- package/dist/pending-indicator-DmowRHLo.js +7 -0
- package/dist/pending-indicator-DmowRHLo.js.map +1 -0
- package/dist/popover-CRLP2Ay_.js +75 -0
- package/dist/popover-CRLP2Ay_.js.map +1 -0
- package/dist/popover-ttQgAb0m.cjs +99 -0
- package/dist/popover-ttQgAb0m.cjs.map +1 -0
- package/dist/portal-container-BlQ6JKob.js +17 -0
- package/dist/portal-container-BlQ6JKob.js.map +1 -0
- package/dist/portal-container-BsvHZxj7.cjs +39 -0
- package/dist/portal-container-BsvHZxj7.cjs.map +1 -0
- package/dist/process-step-progress-bar-C0mArMKD.js +136 -0
- package/dist/process-step-progress-bar-C0mArMKD.js.map +1 -0
- package/dist/process-step-progress-bar-D74Y-8Jo.cjs +141 -0
- package/dist/process-step-progress-bar-D74Y-8Jo.cjs.map +1 -0
- package/dist/property-filter-creator-Cl7xhaML.cjs +673 -0
- package/dist/property-filter-creator-Cl7xhaML.cjs.map +1 -0
- package/dist/property-filter-creator-CnuA0Otn.js +668 -0
- package/dist/property-filter-creator-CnuA0Otn.js.map +1 -0
- package/dist/radio-group-CcZMn-TY.cjs +77 -0
- package/dist/radio-group-CcZMn-TY.cjs.map +1 -0
- package/dist/radio-group-DIbajvIk.js +55 -0
- package/dist/radio-group-DIbajvIk.js.map +1 -0
- package/dist/scroll-area-BCZiAvhR.js +199 -0
- package/dist/scroll-area-BCZiAvhR.js.map +1 -0
- package/dist/scroll-area-KogxLVrV.cjs +221 -0
- package/dist/scroll-area-KogxLVrV.cjs.map +1 -0
- package/dist/scrollable-container-BqOFHwdb.js +151 -0
- package/dist/scrollable-container-BqOFHwdb.js.map +1 -0
- package/dist/scrollable-container-Btq-TfCL.cjs +153 -0
- package/dist/scrollable-container-Btq-TfCL.cjs.map +1 -0
- package/dist/search-field-block-Cn_Ffn5P.cjs +117 -0
- package/dist/search-field-block-Cn_Ffn5P.cjs.map +1 -0
- package/dist/search-field-block-CuyiDT1k.js +115 -0
- package/dist/search-field-block-CuyiDT1k.js.map +1 -0
- package/dist/searchbar-8KtQRL0s.cjs +105 -0
- package/dist/searchbar-8KtQRL0s.cjs.map +1 -0
- package/dist/searchbar-HmTfVgXd.js +102 -0
- package/dist/searchbar-HmTfVgXd.js.map +1 -0
- package/dist/section-BUngbrvn.js +36 -0
- package/dist/section-BUngbrvn.js.map +1 -0
- package/dist/section-card-23Os1QRs.cjs +96 -0
- package/dist/section-card-23Os1QRs.cjs.map +1 -0
- package/dist/section-card-BMArnkcD.js +93 -0
- package/dist/section-card-BMArnkcD.js.map +1 -0
- package/dist/section-muObW4n-.cjs +40 -0
- package/dist/section-muObW4n-.cjs.map +1 -0
- package/dist/sections-BgrvBjOR.cjs +11 -0
- package/dist/sections-BgrvBjOR.cjs.map +1 -0
- package/dist/sections-SdJxf4JD.js +9 -0
- package/dist/sections-SdJxf4JD.js.map +1 -0
- package/dist/select-D2w0zRz4.js +138 -0
- package/dist/select-D2w0zRz4.js.map +1 -0
- package/dist/select-DDgw1wG-.cjs +164 -0
- package/dist/select-DDgw1wG-.cjs.map +1 -0
- package/dist/select-data-filter-BFGZYkQ_.js +192 -0
- package/dist/select-data-filter-BFGZYkQ_.js.map +1 -0
- package/dist/select-data-filter-DxoxTXk2.cjs +194 -0
- package/dist/select-data-filter-DxoxTXk2.cjs.map +1 -0
- package/dist/select-field-block-BA6vHkOP.js +48 -0
- package/dist/select-field-block-BA6vHkOP.js.map +1 -0
- package/dist/select-field-block-BpXYm4K0.cjs +50 -0
- package/dist/select-field-block-BpXYm4K0.cjs.map +1 -0
- package/dist/shimmer-CTVYNDBn.js +22 -0
- package/dist/shimmer-CTVYNDBn.js.map +1 -0
- package/dist/shimmer-DK8TWAV-.cjs +24 -0
- package/dist/shimmer-DK8TWAV-.cjs.map +1 -0
- package/dist/skeleton-Bo71UMWV.cjs +25 -0
- package/dist/skeleton-Bo71UMWV.cjs.map +1 -0
- package/dist/skeleton-Dbr54vol.js +23 -0
- package/dist/skeleton-Dbr54vol.js.map +1 -0
- package/dist/slider-BhA0bVR8.js +88 -0
- package/dist/slider-BhA0bVR8.js.map +1 -0
- package/dist/slider-b9_82QLR.cjs +90 -0
- package/dist/slider-b9_82QLR.cjs.map +1 -0
- package/dist/spacings-0Zbr65EW.js +208 -0
- package/dist/spacings-0Zbr65EW.js.map +1 -0
- package/dist/spacings-BP8L49kn.cjs +218 -0
- package/dist/spacings-BP8L49kn.cjs.map +1 -0
- package/dist/spinner-DuizqJj9.js +51 -0
- package/dist/spinner-DuizqJj9.js.map +1 -0
- package/dist/spinner-PSUHmhye.cjs +53 -0
- package/dist/spinner-PSUHmhye.cjs.map +1 -0
- package/dist/spinner.css +114 -0
- package/dist/src/domains/metrics/components/index.d.ts +1 -0
- package/dist/src/domains/metrics/components/token-usage-timeline-card-view.d.ts +10 -0
- package/dist/src/domains/metrics/hooks/index.d.ts +1 -0
- package/dist/src/domains/metrics/hooks/use-token-usage-timeseries.d.ts +15 -0
- package/dist/src/domains/traces/hooks/index.d.ts +1 -0
- package/dist/src/domains/traces/hooks/use-download-trace-json.d.ts +4 -0
- package/dist/src/domains/traces/hooks/use-trace-url-state.d.ts +6 -0
- package/dist/src/ds/components/AlertDialog/alert-dialog.d.ts +1 -0
- package/dist/src/ds/components/Breadcrumb/Breadcrumb.d.ts +1 -0
- package/dist/src/ds/components/Button/Button.d.ts +3 -2
- package/dist/src/ds/components/ButtonsGroup/buttons-group.d.ts +4 -4
- package/dist/src/ds/components/Code/code.d.ts +14 -0
- package/dist/src/ds/components/Code/code.stories.d.ts +9 -0
- package/dist/src/ds/components/Code/index.d.ts +1 -0
- package/dist/src/ds/components/CodeBlock/code-block.d.ts +5 -1
- package/dist/src/ds/components/CodeBlock/code-block.stories.d.ts +1 -0
- package/dist/src/ds/components/Combobox/combobox-styles.d.ts +27 -12
- package/dist/src/ds/components/Combobox/combobox.d.ts +4 -3
- package/dist/src/ds/components/Combobox/multi-combobox.d.ts +5 -5
- package/dist/src/ds/components/DataList/data-list-cells.d.ts +2 -2
- package/dist/src/ds/components/DataList/data-list-row-wrapper-context.d.ts +2 -0
- package/dist/src/ds/components/DataList/data-list.stories.d.ts +2 -0
- package/dist/src/ds/components/DataList/shared.d.ts +8 -6
- package/dist/src/ds/components/DateTimeRangePicker/date-time-range-picker.d.ts +1 -1
- package/dist/src/ds/components/Dialog/dialog.d.ts +2 -0
- package/dist/src/ds/components/DropdownMenu/dropdown-menu.d.ts +1 -0
- package/dist/src/ds/components/Input/input.d.ts +2 -2
- package/dist/src/ds/components/InputGroup/input-group.d.ts +3 -3
- package/dist/src/ds/components/MetricsCard/index.d.ts +0 -1
- package/dist/src/ds/components/PendingIndicator/index.d.ts +1 -0
- package/dist/src/ds/components/PendingIndicator/pending-indicator.d.ts +9 -0
- package/dist/src/ds/components/Popover/popover.d.ts +1 -0
- package/dist/src/ds/components/Searchbar/searchbar.d.ts +2 -2
- package/dist/src/ds/components/Select/select.d.ts +12 -5
- package/dist/src/ds/components/Select/select.stories.d.ts +8 -0
- package/dist/src/ds/components/Shimmer/index.d.ts +1 -0
- package/dist/src/ds/components/Shimmer/shimmer.d.ts +6 -0
- package/dist/src/ds/components/Textarea/textarea.d.ts +2 -2
- package/dist/src/ds/primitives/control-size.d.ts +5 -0
- package/dist/src/ds/primitives/form-element.d.ts +1 -9
- package/dist/src/ds/primitives/resize-handle-indicator.d.ts +9 -0
- package/dist/src/ds/tokens/sizes.d.ts +1 -0
- package/dist/src/index.d.ts +4 -5
- package/dist/src/lib/as-child.d.ts +22 -0
- package/dist/src/lib/file/downloadJson.d.ts +1 -0
- package/dist/src/lib/file/index.d.ts +1 -0
- package/dist/src/lib/resize/separator.d.ts +5 -1
- package/dist/switch-DJRX_Onf.cjs +124 -0
- package/dist/switch-DJRX_Onf.cjs.map +1 -0
- package/dist/switch-VX4iYp3j.js +103 -0
- package/dist/switch-VX4iYp3j.js.map +1 -0
- package/dist/switch.css +51 -0
- package/dist/tabs-content-D-fKCtLW.js +18 -0
- package/dist/tabs-content-D-fKCtLW.js.map +1 -0
- package/dist/tabs-content-m86TGI_b.cjs +20 -0
- package/dist/tabs-content-m86TGI_b.cjs.map +1 -0
- package/dist/tabs-tab-Cjv_3xGC.js +118 -0
- package/dist/tabs-tab-Cjv_3xGC.js.map +1 -0
- package/dist/tabs-tab-Dl9FqQhm.cjs +122 -0
- package/dist/tabs-tab-Dl9FqQhm.cjs.map +1 -0
- package/dist/text-field-block-CGzVPqnF.cjs +50 -0
- package/dist/text-field-block-CGzVPqnF.cjs.map +1 -0
- package/dist/text-field-block-gjrZyIFr.js +48 -0
- package/dist/text-field-block-gjrZyIFr.js.map +1 -0
- package/dist/textarea-DTTTODYL.js +62 -0
- package/dist/textarea-DTTTODYL.js.map +1 -0
- package/dist/textarea-DdUaiUA3.cjs +83 -0
- package/dist/textarea-DdUaiUA3.cjs.map +1 -0
- package/dist/theme-provider-C9ih9jSS.js +117 -0
- package/dist/theme-provider-C9ih9jSS.js.map +1 -0
- package/dist/theme-provider-aO5-jZVp.cjs +120 -0
- package/dist/theme-provider-aO5-jZVp.cjs.map +1 -0
- package/dist/theme-toggle-AzjABhTN.js +85 -0
- package/dist/theme-toggle-AzjABhTN.js.map +1 -0
- package/dist/theme-toggle-DWtjTo-a.cjs +87 -0
- package/dist/theme-toggle-DWtjTo-a.cjs.map +1 -0
- package/dist/time-picker-BtJz6IU2.js +110 -0
- package/dist/time-picker-BtJz6IU2.js.map +1 -0
- package/dist/time-picker-DWrxHBfR.cjs +113 -0
- package/dist/time-picker-DWrxHBfR.cjs.map +1 -0
- package/dist/tokens.cjs.js +11 -214
- package/dist/tokens.cjs.js.map +1 -1
- package/dist/tokens.es.js +3 -206
- package/dist/tokens.es.js.map +1 -1
- package/dist/tooltip-DehuxlSR.js +90 -0
- package/dist/tooltip-DehuxlSR.js.map +1 -0
- package/dist/tooltip-j8gUR1Qk.cjs +114 -0
- package/dist/tooltip-j8gUR1Qk.cjs.map +1 -0
- package/dist/traces-data-list-5GA3JumQ.cjs +238 -0
- package/dist/traces-data-list-5GA3JumQ.cjs.map +1 -0
- package/dist/traces-data-list-Dru2XnRN.js +234 -0
- package/dist/traces-data-list-Dru2XnRN.js.map +1 -0
- package/dist/transitions-DpczSjmD.cjs +39 -0
- package/dist/transitions-DpczSjmD.cjs.map +1 -0
- package/dist/transitions-tFfqxz40.js +35 -0
- package/dist/transitions-tFfqxz40.js.map +1 -0
- package/dist/tree-D04KhP5w.js +212 -0
- package/dist/tree-D04KhP5w.js.map +1 -0
- package/dist/tree-P2k9UCFX.cjs +233 -0
- package/dist/tree-P2k9UCFX.cjs.map +1 -0
- package/dist/truncate-B2kAcoie.js +47 -0
- package/dist/truncate-B2kAcoie.js.map +1 -0
- package/dist/truncate-mOutaqxm.cjs +49 -0
- package/dist/truncate-mOutaqxm.cjs.map +1 -0
- package/dist/use-copy-to-clipboard-CGqfkXnN.js +73 -0
- package/dist/use-copy-to-clipboard-CGqfkXnN.js.map +1 -0
- package/dist/use-copy-to-clipboard-CQgIuR1c.cjs +77 -0
- package/dist/use-copy-to-clipboard-CQgIuR1c.cjs.map +1 -0
- package/dist/use-copy-to-clipboard.css +126 -0
- package/dist/use-table-keyboard-navigation-D9tbkeqJ.cjs +214 -0
- package/dist/use-table-keyboard-navigation-D9tbkeqJ.cjs.map +1 -0
- package/dist/use-table-keyboard-navigation-TaCn1tec.js +203 -0
- package/dist/use-table-keyboard-navigation-TaCn1tec.js.map +1 -0
- package/dist/utils-CzYGxqbG.js +3290 -0
- package/dist/utils-CzYGxqbG.js.map +1 -0
- package/dist/utils-vA5sWo9W.cjs +3293 -0
- package/dist/utils-vA5sWo9W.cjs.map +1 -0
- package/package.json +19 -8
- package/theme.css +412 -0
- package/dist/vite.config.d.ts +0 -3
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const jsxRuntime = require('react/jsx-runtime');
|
|
4
|
+
const recharts = require('recharts');
|
|
5
|
+
|
|
6
|
+
function MetricsLineChartTooltip({
|
|
7
|
+
active,
|
|
8
|
+
payload,
|
|
9
|
+
label,
|
|
10
|
+
suffix
|
|
11
|
+
}) {
|
|
12
|
+
if (!active || !payload?.length) return null;
|
|
13
|
+
return /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "rounded-md border border-border1 bg-surface2 px-3 py-2 text-xs shadow-lg", children: [
|
|
14
|
+
/* @__PURE__ */ jsxRuntime.jsx("p", { className: "mb-1 font-medium text-icon6", children: label }),
|
|
15
|
+
payload.map((entry) => /* @__PURE__ */ jsxRuntime.jsxs("p", { className: "text-icon2", children: [
|
|
16
|
+
/* @__PURE__ */ jsxRuntime.jsx("span", { className: "mr-2 inline-block size-2 rounded-full", style: { backgroundColor: entry.color } }),
|
|
17
|
+
entry.name,
|
|
18
|
+
":",
|
|
19
|
+
" ",
|
|
20
|
+
/* @__PURE__ */ jsxRuntime.jsxs("span", { className: "font-mono", children: [
|
|
21
|
+
entry.value,
|
|
22
|
+
suffix
|
|
23
|
+
] })
|
|
24
|
+
] }, entry.name))
|
|
25
|
+
] });
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
const LABEL_COLOR = "#a1a1aa";
|
|
29
|
+
function MetricsLineChart({
|
|
30
|
+
data,
|
|
31
|
+
series,
|
|
32
|
+
height = 210,
|
|
33
|
+
yDomain,
|
|
34
|
+
onPointClick
|
|
35
|
+
}) {
|
|
36
|
+
const isClickable = typeof onPointClick === "function";
|
|
37
|
+
return /* @__PURE__ */ jsxRuntime.jsxs("div", { children: [
|
|
38
|
+
/* @__PURE__ */ jsxRuntime.jsx("div", { className: "flex flex-wrap w-full items-end gap-4 gap-y-1 mb-4 ", children: series.map((s) => {
|
|
39
|
+
const aggregated = s.aggregate?.(data);
|
|
40
|
+
return /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "inline-flex items-baseline gap-2", children: [
|
|
41
|
+
/* @__PURE__ */ jsxRuntime.jsx("div", { className: "size-2 shrink-0 rounded-full -translate-y-px", style: { backgroundColor: s.color } }),
|
|
42
|
+
/* @__PURE__ */ jsxRuntime.jsx("span", { className: "text-ui-sm text-neutral3 truncate max-w-24", children: s.label }),
|
|
43
|
+
aggregated && /* @__PURE__ */ jsxRuntime.jsxs("span", { className: "text-ui-sm text-neutral4", children: [
|
|
44
|
+
aggregated.value,
|
|
45
|
+
aggregated.suffix && /* @__PURE__ */ jsxRuntime.jsxs("span", { className: "text-ui-sm text-neutral2", children: [
|
|
46
|
+
" ",
|
|
47
|
+
aggregated.suffix
|
|
48
|
+
] })
|
|
49
|
+
] })
|
|
50
|
+
] }, s.dataKey);
|
|
51
|
+
}) }),
|
|
52
|
+
/* @__PURE__ */ jsxRuntime.jsx("div", { style: { height }, children: /* @__PURE__ */ jsxRuntime.jsx(recharts.ResponsiveContainer, { width: "100%", height: "100%", children: /* @__PURE__ */ jsxRuntime.jsxs(recharts.LineChart, { data, children: [
|
|
53
|
+
/* @__PURE__ */ jsxRuntime.jsx(
|
|
54
|
+
recharts.CartesianGrid,
|
|
55
|
+
{
|
|
56
|
+
stroke: "currentColor",
|
|
57
|
+
strokeOpacity: 0.08,
|
|
58
|
+
vertical: false,
|
|
59
|
+
className: "text-black dark:text-white"
|
|
60
|
+
}
|
|
61
|
+
),
|
|
62
|
+
/* @__PURE__ */ jsxRuntime.jsx(
|
|
63
|
+
recharts.XAxis,
|
|
64
|
+
{
|
|
65
|
+
dataKey: "time",
|
|
66
|
+
tick: { fontSize: 10, fill: LABEL_COLOR, fontFamily: "var(--font-mono)" },
|
|
67
|
+
tickLine: false,
|
|
68
|
+
axisLine: false,
|
|
69
|
+
interval: 5
|
|
70
|
+
}
|
|
71
|
+
),
|
|
72
|
+
/* @__PURE__ */ jsxRuntime.jsx(
|
|
73
|
+
recharts.YAxis,
|
|
74
|
+
{
|
|
75
|
+
tick: { fontSize: 10, fill: LABEL_COLOR, fontFamily: "var(--font-mono)" },
|
|
76
|
+
tickLine: false,
|
|
77
|
+
axisLine: false,
|
|
78
|
+
width: 30,
|
|
79
|
+
domain: yDomain
|
|
80
|
+
}
|
|
81
|
+
),
|
|
82
|
+
/* @__PURE__ */ jsxRuntime.jsx(recharts.Tooltip, { content: /* @__PURE__ */ jsxRuntime.jsx(MetricsLineChartTooltip, {}) }),
|
|
83
|
+
series.map((s) => /* @__PURE__ */ jsxRuntime.jsx(
|
|
84
|
+
recharts.Line,
|
|
85
|
+
{
|
|
86
|
+
type: "linear",
|
|
87
|
+
dataKey: s.dataKey,
|
|
88
|
+
stroke: s.color,
|
|
89
|
+
strokeWidth: 2,
|
|
90
|
+
dot: false,
|
|
91
|
+
activeDot: isClickable ? {
|
|
92
|
+
r: 4,
|
|
93
|
+
style: { cursor: "pointer" },
|
|
94
|
+
onClick: (_, payload) => {
|
|
95
|
+
const datum = payload?.payload;
|
|
96
|
+
if (datum) onPointClick(datum, s.dataKey);
|
|
97
|
+
}
|
|
98
|
+
} : void 0,
|
|
99
|
+
name: s.label
|
|
100
|
+
},
|
|
101
|
+
s.dataKey
|
|
102
|
+
))
|
|
103
|
+
] }) }) })
|
|
104
|
+
] });
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
exports.MetricsLineChart = MetricsLineChart;
|
|
108
|
+
exports.MetricsLineChartTooltip = MetricsLineChartTooltip;
|
|
109
|
+
//# sourceMappingURL=metrics-line-chart-D1ZGVepo.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metrics-line-chart-D1ZGVepo.cjs","sources":["../src/ds/components/MetricsLineChart/metrics-line-chart-tooltip.tsx","../src/ds/components/MetricsLineChart/metrics-line-chart.tsx"],"sourcesContent":["export function MetricsLineChartTooltip({\n active,\n payload,\n label,\n suffix,\n}: {\n active?: boolean;\n payload?: Array<{ name: string; value: number; color: string }>;\n label?: string;\n suffix?: string;\n}) {\n if (!active || !payload?.length) return null;\n return (\n <div className=\"rounded-md border border-border1 bg-surface2 px-3 py-2 text-xs shadow-lg\">\n <p className=\"mb-1 font-medium text-icon6\">{label}</p>\n {payload.map(entry => (\n <p key={entry.name} className=\"text-icon2\">\n <span className=\"mr-2 inline-block size-2 rounded-full\" style={{ backgroundColor: entry.color }} />\n {entry.name}:{' '}\n <span className=\"font-mono\">\n {entry.value}\n {suffix}\n </span>\n </p>\n ))}\n </div>\n );\n}\n","import { LineChart, Line, XAxis, YAxis, CartesianGrid, Tooltip, ResponsiveContainer } from 'recharts';\nimport { MetricsLineChartTooltip } from './metrics-line-chart-tooltip';\n\nconst LABEL_COLOR = '#a1a1aa';\n\nexport type MetricsLineChartSeries = {\n dataKey: string;\n label: string;\n color: string;\n aggregate?: (data: Record<string, unknown>[]) => { value: string; suffix?: string };\n};\n\nexport type MetricsLineChartPointClickHandler = (point: Record<string, unknown>, seriesKey: string) => void;\n\nexport function MetricsLineChart({\n data,\n series,\n height = 210,\n yDomain,\n onPointClick,\n}: {\n data: Record<string, unknown>[];\n series: MetricsLineChartSeries[];\n height?: number;\n yDomain?: [number, number];\n onPointClick?: MetricsLineChartPointClickHandler;\n}) {\n const isClickable = typeof onPointClick === 'function';\n\n return (\n <div>\n <div className=\"flex flex-wrap w-full items-end gap-4 gap-y-1 mb-4 \">\n {series.map(s => {\n const aggregated = s.aggregate?.(data);\n return (\n <div key={s.dataKey} className=\"inline-flex items-baseline gap-2\">\n <div className=\"size-2 shrink-0 rounded-full -translate-y-px\" style={{ backgroundColor: s.color }} />\n <span className=\"text-ui-sm text-neutral3 truncate max-w-24\">{s.label}</span>\n {aggregated && (\n <span className=\"text-ui-sm text-neutral4\">\n {aggregated.value}\n {aggregated.suffix && <span className=\"text-ui-sm text-neutral2\"> {aggregated.suffix}</span>}\n </span>\n )}\n </div>\n );\n })}\n </div>\n <div style={{ height }}>\n <ResponsiveContainer width=\"100%\" height=\"100%\">\n <LineChart data={data}>\n <CartesianGrid\n stroke=\"currentColor\"\n strokeOpacity={0.08}\n vertical={false}\n className=\"text-black dark:text-white\"\n />\n <XAxis\n dataKey=\"time\"\n tick={{ fontSize: 10, fill: LABEL_COLOR, fontFamily: 'var(--font-mono)' }}\n tickLine={false}\n axisLine={false}\n interval={5}\n />\n <YAxis\n tick={{ fontSize: 10, fill: LABEL_COLOR, fontFamily: 'var(--font-mono)' }}\n tickLine={false}\n axisLine={false}\n width={30}\n domain={yDomain}\n />\n <Tooltip content={<MetricsLineChartTooltip />} />\n {series.map(s => (\n <Line\n key={s.dataKey}\n type=\"linear\"\n dataKey={s.dataKey}\n stroke={s.color}\n strokeWidth={2}\n dot={false}\n activeDot={\n isClickable\n ? {\n r: 4,\n style: { cursor: 'pointer' },\n onClick: (_: unknown, payload: unknown) => {\n const datum = (payload as { payload?: Record<string, unknown> } | undefined)?.payload;\n if (datum) onPointClick(datum, s.dataKey);\n },\n }\n : undefined\n }\n name={s.label}\n />\n ))}\n </LineChart>\n </ResponsiveContainer>\n </div>\n </div>\n );\n}\n"],"names":["jsxs","jsx","ResponsiveContainer","LineChart","CartesianGrid","XAxis","YAxis","Tooltip","Line"],"mappings":"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"}
|
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
require('./index.css');const jsxRuntime = require('react/jsx-runtime');
|
|
4
|
+
;/* empty css */
|
|
5
|
+
require('@base-ui/react/combobox');
|
|
6
|
+
require('./components/DataDetailsPanel.cjs.js');
|
|
7
|
+
const utils = require('./utils-vA5sWo9W.cjs');
|
|
8
|
+
const lucideReact = require('lucide-react');
|
|
9
|
+
const React = require('react');
|
|
10
|
+
const Button = require('./Button-DpIX8JMz.cjs');
|
|
11
|
+
|
|
12
|
+
function ColumnContent({ children, className }) {
|
|
13
|
+
return /* @__PURE__ */ jsxRuntime.jsx("div", { className: utils.cn(`grid overflow-y-auto gap-8 content-start`, className), children });
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
function ColumnRoot({ children, className, withLeftSeparator, withRightSeparator }) {
|
|
17
|
+
return /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex overflow-y-auto w-full", children: [
|
|
18
|
+
withLeftSeparator && /* @__PURE__ */ jsxRuntime.jsx(Separator, {}),
|
|
19
|
+
/* @__PURE__ */ jsxRuntime.jsx("div", { className: utils.cn(`grid gap-8 content-start w-full overflow-y-auto`, className), children }),
|
|
20
|
+
withRightSeparator && /* @__PURE__ */ jsxRuntime.jsx(Separator, {})
|
|
21
|
+
] });
|
|
22
|
+
}
|
|
23
|
+
function Separator() {
|
|
24
|
+
return /* @__PURE__ */ jsxRuntime.jsx("div", { className: utils.cn("bg-surface5 w-[3px] shrink-0 mx-[1.5vw]") });
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
function ColumnToolbar({ children, className }) {
|
|
28
|
+
return /* @__PURE__ */ jsxRuntime.jsx("div", { className: utils.cn(`flex items-center justify-between w-full flex-wrap gap-4 gap-x-6`, className), children });
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
const Column = Object.assign(ColumnRoot, {
|
|
32
|
+
Content: ColumnContent,
|
|
33
|
+
Toolbar: ColumnToolbar
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
function Columns({ children, className }) {
|
|
37
|
+
return /* @__PURE__ */ jsxRuntime.jsx("div", { className: utils.cn(`grid w-full h-full grid-cols-1 overflow-y-auto`, className), children });
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
function MultiColumn({ children, numOfColumns = 1, minColumnWidth }) {
|
|
41
|
+
const scrollRef = React.useRef(null);
|
|
42
|
+
const [canScrollLeft, setCanScrollLeft] = React.useState(false);
|
|
43
|
+
const [canScrollRight, setCanScrollRight] = React.useState(false);
|
|
44
|
+
const updateScrollState = React.useCallback(() => {
|
|
45
|
+
const el = scrollRef.current;
|
|
46
|
+
if (!el) return;
|
|
47
|
+
const { scrollLeft, scrollWidth, clientWidth } = el;
|
|
48
|
+
setCanScrollLeft(scrollLeft > 1);
|
|
49
|
+
setCanScrollRight(scrollLeft + clientWidth < scrollWidth - 1);
|
|
50
|
+
}, []);
|
|
51
|
+
React.useEffect(() => {
|
|
52
|
+
const el = scrollRef.current;
|
|
53
|
+
if (!el) return;
|
|
54
|
+
updateScrollState();
|
|
55
|
+
el.addEventListener("scroll", updateScrollState, { passive: true });
|
|
56
|
+
const observer = new ResizeObserver(updateScrollState);
|
|
57
|
+
observer.observe(el);
|
|
58
|
+
return () => {
|
|
59
|
+
el.removeEventListener("scroll", updateScrollState);
|
|
60
|
+
observer.disconnect();
|
|
61
|
+
};
|
|
62
|
+
}, [updateScrollState]);
|
|
63
|
+
const prevColumnsRef = React.useRef(numOfColumns);
|
|
64
|
+
React.useEffect(() => {
|
|
65
|
+
const el = scrollRef.current;
|
|
66
|
+
if (!el) return;
|
|
67
|
+
if (numOfColumns > prevColumnsRef.current) {
|
|
68
|
+
requestAnimationFrame(() => {
|
|
69
|
+
el.scrollTo({ left: el.scrollWidth, behavior: "smooth" });
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
prevColumnsRef.current = numOfColumns;
|
|
73
|
+
}, [numOfColumns]);
|
|
74
|
+
React.useEffect(() => {
|
|
75
|
+
const handleKeyDown = (e) => {
|
|
76
|
+
if (e.key === "ArrowLeft" || e.key === "ArrowRight") {
|
|
77
|
+
e.preventDefault();
|
|
78
|
+
scrollToColumn(e.key === "ArrowLeft" ? "left" : "right");
|
|
79
|
+
}
|
|
80
|
+
};
|
|
81
|
+
window.addEventListener("keydown", handleKeyDown);
|
|
82
|
+
return () => window.removeEventListener("keydown", handleKeyDown);
|
|
83
|
+
}, []);
|
|
84
|
+
const scrollToColumn = (direction) => {
|
|
85
|
+
const el = scrollRef.current;
|
|
86
|
+
if (!el) return;
|
|
87
|
+
const columns = Array.from(el.children);
|
|
88
|
+
const containerLeft = el.scrollLeft;
|
|
89
|
+
const containerRight = containerLeft + el.clientWidth;
|
|
90
|
+
if (direction === "right") {
|
|
91
|
+
const target = columns.find((col) => col.offsetLeft + col.offsetWidth > containerRight + 1);
|
|
92
|
+
if (target) {
|
|
93
|
+
el.scrollTo({ left: target.offsetLeft + target.offsetWidth - el.clientWidth, behavior: "smooth" });
|
|
94
|
+
}
|
|
95
|
+
} else {
|
|
96
|
+
const target = [...columns].reverse().find((col) => col.offsetLeft < containerLeft - 1);
|
|
97
|
+
if (target) {
|
|
98
|
+
el.scrollTo({ left: target.offsetLeft, behavior: "smooth" });
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
};
|
|
102
|
+
return /* @__PURE__ */ jsxRuntime.jsxs("div", { className: utils.cn("MULTI_COLUMN relative w-full h-full overflow-hidden"), children: [
|
|
103
|
+
canScrollLeft && /* @__PURE__ */ jsxRuntime.jsx(ScrollArrow, { direction: "left", onClick: () => scrollToColumn("left") }),
|
|
104
|
+
canScrollRight && /* @__PURE__ */ jsxRuntime.jsx(ScrollArrow, { direction: "right", onClick: () => scrollToColumn("right") }),
|
|
105
|
+
/* @__PURE__ */ jsxRuntime.jsx(
|
|
106
|
+
"div",
|
|
107
|
+
{
|
|
108
|
+
ref: scrollRef,
|
|
109
|
+
className: "grid overflow-x-auto w-full overflow-y-auto h-full",
|
|
110
|
+
style: {
|
|
111
|
+
gridTemplateColumns: `repeat(${numOfColumns}, minmax(${minColumnWidth ?? "0"}, 1fr))`
|
|
112
|
+
},
|
|
113
|
+
children
|
|
114
|
+
}
|
|
115
|
+
)
|
|
116
|
+
] });
|
|
117
|
+
}
|
|
118
|
+
function ScrollArrow({ direction, onClick }) {
|
|
119
|
+
const Icon = direction === "left" ? lucideReact.ChevronLeftIcon : lucideReact.ChevronRightIcon;
|
|
120
|
+
const isLeft = direction === "left";
|
|
121
|
+
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
122
|
+
"div",
|
|
123
|
+
{
|
|
124
|
+
className: utils.cn(
|
|
125
|
+
"absolute top-0 bottom-0 z-20 w-20 flex items-center justify-center px-5 bg-surface2",
|
|
126
|
+
isLeft ? "left-0" : "right-0"
|
|
127
|
+
),
|
|
128
|
+
children: /* @__PURE__ */ jsxRuntime.jsx(Button.Button, { onClick, className: "w-full h-full px-0", "aria-label": `Scroll ${direction}`, children: /* @__PURE__ */ jsxRuntime.jsx(Icon, {}) })
|
|
129
|
+
}
|
|
130
|
+
);
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
exports.Column = Column;
|
|
134
|
+
exports.Columns = Columns;
|
|
135
|
+
exports.MultiColumn = MultiColumn;
|
|
136
|
+
//# sourceMappingURL=multi-column-BzL86JPK.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"multi-column-BzL86JPK.cjs","sources":["../src/ds/components/Columns/column-content.tsx","../src/ds/components/Columns/column-root.tsx","../src/ds/components/Columns/column-toolbar.tsx","../src/ds/components/Columns/column.tsx","../src/ds/components/Columns/columns.tsx","../src/ds/components/Columns/multi-column.tsx"],"sourcesContent":["import { cn } from '@/index';\n\nexport type ColumnProps = {\n children?: React.ReactNode;\n className?: string;\n};\n\nexport function ColumnContent({ children, className }: ColumnProps) {\n return <div className={cn(`grid overflow-y-auto gap-8 content-start`, className)}>{children}</div>;\n}\n","import { cn } from '@/index';\n\nexport type ColumnProps = {\n children: React.ReactNode;\n className?: string;\n withRightSeparator?: boolean;\n withLeftSeparator?: boolean;\n};\n\nexport function ColumnRoot({ children, className, withLeftSeparator, withRightSeparator }: ColumnProps) {\n return (\n <div className=\"flex overflow-y-auto w-full\">\n {withLeftSeparator && <Separator />}\n\n <div className={cn(`grid gap-8 content-start w-full overflow-y-auto`, className)}>{children}</div>\n\n {withRightSeparator && <Separator />}\n </div>\n );\n}\n\nfunction Separator() {\n return <div className={cn('bg-surface5 w-[3px] shrink-0 mx-[1.5vw]')}></div>;\n}\n","import { cn } from '@/index';\n\nexport type ColumnToolbarProps = {\n children?: React.ReactNode;\n className?: string;\n};\n\nexport function ColumnToolbar({ children, className }: ColumnToolbarProps) {\n return (\n <div className={cn(`flex items-center justify-between w-full flex-wrap gap-4 gap-x-6`, className)}>{children}</div>\n );\n}\n","import { ColumnContent } from './column-content';\nimport { ColumnRoot } from './column-root';\nimport { ColumnToolbar } from './column-toolbar';\n\nexport const Column = Object.assign(ColumnRoot, {\n Content: ColumnContent,\n Toolbar: ColumnToolbar,\n});\n","import { cn } from '@/index';\n\nexport type ColumnsProps = {\n children: React.ReactNode;\n className?: string;\n};\n\nexport function Columns({ children, className }: ColumnsProps) {\n return <div className={cn(`grid w-full h-full grid-cols-1 overflow-y-auto`, className)}>{children}</div>;\n}\n","'use client';\n\nimport { ChevronLeftIcon, ChevronRightIcon } from 'lucide-react';\nimport React, { useCallback, useEffect, useRef, useState } from 'react';\nimport { Button } from '../Button';\nimport { cn } from '@/lib/utils';\n\nexport type MultiColumnProps = {\n children?: React.ReactNode;\n numOfColumns?: number;\n minColumnWidth?: string;\n};\n\nexport function MultiColumn({ children, numOfColumns = 1, minColumnWidth }: MultiColumnProps): React.JSX.Element {\n const scrollRef = useRef<HTMLDivElement>(null);\n const [canScrollLeft, setCanScrollLeft] = useState(false);\n const [canScrollRight, setCanScrollRight] = useState(false);\n const updateScrollState = useCallback(() => {\n const el = scrollRef.current;\n if (!el) return;\n const { scrollLeft, scrollWidth, clientWidth } = el;\n setCanScrollLeft(scrollLeft > 1);\n setCanScrollRight(scrollLeft + clientWidth < scrollWidth - 1);\n }, []);\n\n useEffect(() => {\n const el = scrollRef.current;\n if (!el) return;\n\n updateScrollState();\n\n el.addEventListener('scroll', updateScrollState, { passive: true });\n\n const observer = new ResizeObserver(updateScrollState);\n observer.observe(el);\n\n return () => {\n el.removeEventListener('scroll', updateScrollState);\n observer.disconnect();\n };\n }, [updateScrollState]);\n\n const prevColumnsRef = useRef(numOfColumns);\n useEffect(() => {\n const el = scrollRef.current;\n if (!el) return;\n if (numOfColumns > prevColumnsRef.current) {\n // New column added — scroll to the right end so it's visible\n requestAnimationFrame(() => {\n el.scrollTo({ left: el.scrollWidth, behavior: 'smooth' });\n });\n }\n prevColumnsRef.current = numOfColumns;\n }, [numOfColumns]);\n\n useEffect(() => {\n const handleKeyDown = (e: KeyboardEvent) => {\n if (e.key === 'ArrowLeft' || e.key === 'ArrowRight') {\n e.preventDefault();\n scrollToColumn(e.key === 'ArrowLeft' ? 'left' : 'right');\n }\n };\n window.addEventListener('keydown', handleKeyDown);\n return () => window.removeEventListener('keydown', handleKeyDown);\n }, []);\n\n const scrollToColumn = (direction: 'left' | 'right') => {\n const el = scrollRef.current;\n if (!el) return;\n\n const columns = Array.from(el.children) as HTMLElement[];\n const containerLeft = el.scrollLeft;\n const containerRight = containerLeft + el.clientWidth;\n\n if (direction === 'right') {\n // Find the first column whose right edge is past the container's right edge\n const target = columns.find(col => col.offsetLeft + col.offsetWidth > containerRight + 1);\n if (target) {\n el.scrollTo({ left: target.offsetLeft + target.offsetWidth - el.clientWidth, behavior: 'smooth' });\n }\n } else {\n // Find the last column whose left edge is before the container's left edge\n const target = [...columns].reverse().find(col => col.offsetLeft < containerLeft - 1);\n if (target) {\n el.scrollTo({ left: target.offsetLeft, behavior: 'smooth' });\n }\n }\n };\n\n return (\n <div className={cn('MULTI_COLUMN relative w-full h-full overflow-hidden')}>\n {canScrollLeft && <ScrollArrow direction=\"left\" onClick={() => scrollToColumn('left')} />}\n {canScrollRight && <ScrollArrow direction=\"right\" onClick={() => scrollToColumn('right')} />}\n <div\n ref={scrollRef}\n className=\"grid overflow-x-auto w-full overflow-y-auto h-full\"\n style={{\n gridTemplateColumns: `repeat(${numOfColumns}, minmax(${minColumnWidth ?? '0'}, 1fr))`,\n }}\n >\n {children}\n </div>\n </div>\n );\n}\n\nfunction ScrollArrow({ direction, onClick }: { direction: 'left' | 'right'; onClick: () => void }) {\n const Icon = direction === 'left' ? ChevronLeftIcon : ChevronRightIcon;\n const isLeft = direction === 'left';\n\n return (\n <div\n className={cn(\n 'absolute top-0 bottom-0 z-20 w-20 flex items-center justify-center px-5 bg-surface2',\n isLeft ? 'left-0' : 'right-0',\n )}\n >\n <Button onClick={onClick} className=\"w-full h-full px-0\" aria-label={`Scroll ${direction}`}>\n <Icon />\n </Button>\n </div>\n );\n}\n"],"names":["cn","jsxs","jsx","useRef","useState","useCallback","useEffect","ChevronLeftIcon","ChevronRightIcon","Button"],"mappings":";;;;;;;;;;;AAOO,SAAS,aAAA,CAAc,EAAE,QAAA,EAAU,SAAA,EAAU,EAAgB;AAClE,EAAA,sCAAQ,KAAA,EAAA,EAAI,SAAA,EAAWA,SAAG,CAAA,wCAAA,CAAA,EAA4C,SAAS,GAAI,QAAA,EAAS,CAAA;AAC9F;;ACAO,SAAS,WAAW,EAAE,QAAA,EAAU,SAAA,EAAW,iBAAA,EAAmB,oBAAmB,EAAgB;AACtG,EAAA,uBACEC,eAAA,CAAC,KAAA,EAAA,EAAI,SAAA,EAAU,6BAAA,EACZ,QAAA,EAAA;AAAA,IAAA,iBAAA,mCAAsB,SAAA,EAAA,EAAU,CAAA;AAAA,mCAEhC,KAAA,EAAA,EAAI,SAAA,EAAWD,SAAG,CAAA,+CAAA,CAAA,EAAmD,SAAS,GAAI,QAAA,EAAS,CAAA;AAAA,IAE3F,kBAAA,mCAAuB,SAAA,EAAA,EAAU;AAAA,GAAA,EACpC,CAAA;AAEJ;AAEA,SAAS,SAAA,GAAY;AACnB,EAAA,uBAAOE,cAAA,CAAC,KAAA,EAAA,EAAI,SAAA,EAAWF,QAAA,CAAG,yCAAyC,CAAA,EAAG,CAAA;AACxE;;AChBO,SAAS,aAAA,CAAc,EAAE,QAAA,EAAU,SAAA,EAAU,EAAuB;AACzE,EAAA,sCACG,KAAA,EAAA,EAAI,SAAA,EAAWA,SAAG,CAAA,gEAAA,CAAA,EAAoE,SAAS,GAAI,QAAA,EAAS,CAAA;AAEjH;;ACPO,MAAM,MAAA,GAAS,MAAA,CAAO,MAAA,CAAO,UAAA,EAAY;AAAA,EAC9C,OAAA,EAAS,aAAA;AAAA,EACT,OAAA,EAAS;AACX,CAAC;;ACAM,SAAS,OAAA,CAAQ,EAAE,QAAA,EAAU,SAAA,EAAU,EAAiB;AAC7D,EAAA,sCAAQ,KAAA,EAAA,EAAI,SAAA,EAAWA,SAAG,CAAA,8CAAA,CAAA,EAAkD,SAAS,GAAI,QAAA,EAAS,CAAA;AACpG;;ACIO,SAAS,YAAY,EAAE,QAAA,EAAU,YAAA,GAAe,CAAA,EAAG,gBAAe,EAAwC;AAC/G,EAAA,MAAM,SAAA,GAAYG,aAAuB,IAAI,CAAA;AAC7C,EAAA,MAAM,CAAC,aAAA,EAAe,gBAAgB,CAAA,GAAIC,eAAS,KAAK,CAAA;AACxD,EAAA,MAAM,CAAC,cAAA,EAAgB,iBAAiB,CAAA,GAAIA,eAAS,KAAK,CAAA;AAC1D,EAAA,MAAM,iBAAA,GAAoBC,kBAAY,MAAM;AAC1C,IAAA,MAAM,KAAK,SAAA,CAAU,OAAA;AACrB,IAAA,IAAI,CAAC,EAAA,EAAI;AACT,IAAA,MAAM,EAAE,UAAA,EAAY,WAAA,EAAa,WAAA,EAAY,GAAI,EAAA;AACjD,IAAA,gBAAA,CAAiB,aAAa,CAAC,CAAA;AAC/B,IAAA,iBAAA,CAAkB,UAAA,GAAa,WAAA,GAAc,WAAA,GAAc,CAAC,CAAA;AAAA,EAC9D,CAAA,EAAG,EAAE,CAAA;AAEL,EAAAC,eAAA,CAAU,MAAM;AACd,IAAA,MAAM,KAAK,SAAA,CAAU,OAAA;AACrB,IAAA,IAAI,CAAC,EAAA,EAAI;AAET,IAAA,iBAAA,EAAkB;AAElB,IAAA,EAAA,CAAG,iBAAiB,QAAA,EAAU,iBAAA,EAAmB,EAAE,OAAA,EAAS,MAAM,CAAA;AAElE,IAAA,MAAM,QAAA,GAAW,IAAI,cAAA,CAAe,iBAAiB,CAAA;AACrD,IAAA,QAAA,CAAS,QAAQ,EAAE,CAAA;AAEnB,IAAA,OAAO,MAAM;AACX,MAAA,EAAA,CAAG,mBAAA,CAAoB,UAAU,iBAAiB,CAAA;AAClD,MAAA,QAAA,CAAS,UAAA,EAAW;AAAA,IACtB,CAAA;AAAA,EACF,CAAA,EAAG,CAAC,iBAAiB,CAAC,CAAA;AAEtB,EAAA,MAAM,cAAA,GAAiBH,aAAO,YAAY,CAAA;AAC1C,EAAAG,eAAA,CAAU,MAAM;AACd,IAAA,MAAM,KAAK,SAAA,CAAU,OAAA;AACrB,IAAA,IAAI,CAAC,EAAA,EAAI;AACT,IAAA,IAAI,YAAA,GAAe,eAAe,OAAA,EAAS;AAEzC,MAAA,qBAAA,CAAsB,MAAM;AAC1B,QAAA,EAAA,CAAG,SAAS,EAAE,IAAA,EAAM,GAAG,WAAA,EAAa,QAAA,EAAU,UAAU,CAAA;AAAA,MAC1D,CAAC,CAAA;AAAA,IACH;AACA,IAAA,cAAA,CAAe,OAAA,GAAU,YAAA;AAAA,EAC3B,CAAA,EAAG,CAAC,YAAY,CAAC,CAAA;AAEjB,EAAAA,eAAA,CAAU,MAAM;AACd,IAAA,MAAM,aAAA,GAAgB,CAAC,CAAA,KAAqB;AAC1C,MAAA,IAAI,CAAA,CAAE,GAAA,KAAQ,WAAA,IAAe,CAAA,CAAE,QAAQ,YAAA,EAAc;AACnD,QAAA,CAAA,CAAE,cAAA,EAAe;AACjB,QAAA,cAAA,CAAe,CAAA,CAAE,GAAA,KAAQ,WAAA,GAAc,MAAA,GAAS,OAAO,CAAA;AAAA,MACzD;AAAA,IACF,CAAA;AACA,IAAA,MAAA,CAAO,gBAAA,CAAiB,WAAW,aAAa,CAAA;AAChD,IAAA,OAAO,MAAM,MAAA,CAAO,mBAAA,CAAoB,SAAA,EAAW,aAAa,CAAA;AAAA,EAClE,CAAA,EAAG,EAAE,CAAA;AAEL,EAAA,MAAM,cAAA,GAAiB,CAAC,SAAA,KAAgC;AACtD,IAAA,MAAM,KAAK,SAAA,CAAU,OAAA;AACrB,IAAA,IAAI,CAAC,EAAA,EAAI;AAET,IAAA,MAAM,OAAA,GAAU,KAAA,CAAM,IAAA,CAAK,EAAA,CAAG,QAAQ,CAAA;AACtC,IAAA,MAAM,gBAAgB,EAAA,CAAG,UAAA;AACzB,IAAA,MAAM,cAAA,GAAiB,gBAAgB,EAAA,CAAG,WAAA;AAE1C,IAAA,IAAI,cAAc,OAAA,EAAS;AAEzB,MAAA,MAAM,MAAA,GAAS,QAAQ,IAAA,CAAK,CAAA,GAAA,KAAO,IAAI,UAAA,GAAa,GAAA,CAAI,WAAA,GAAc,cAAA,GAAiB,CAAC,CAAA;AACxF,MAAA,IAAI,MAAA,EAAQ;AACV,QAAA,EAAA,CAAG,QAAA,CAAS,EAAE,IAAA,EAAM,MAAA,CAAO,UAAA,GAAa,MAAA,CAAO,WAAA,GAAc,EAAA,CAAG,WAAA,EAAa,QAAA,EAAU,QAAA,EAAU,CAAA;AAAA,MACnG;AAAA,IACF,CAAA,MAAO;AAEL,MAAA,MAAM,MAAA,GAAS,CAAC,GAAG,OAAO,CAAA,CAAE,OAAA,EAAQ,CAAE,IAAA,CAAK,CAAA,GAAA,KAAO,GAAA,CAAI,UAAA,GAAa,aAAA,GAAgB,CAAC,CAAA;AACpF,MAAA,IAAI,MAAA,EAAQ;AACV,QAAA,EAAA,CAAG,SAAS,EAAE,IAAA,EAAM,OAAO,UAAA,EAAY,QAAA,EAAU,UAAU,CAAA;AAAA,MAC7D;AAAA,IACF;AAAA,EACF,CAAA;AAEA,EAAA,uBACEL,eAAA,CAAC,KAAA,EAAA,EAAI,SAAA,EAAWD,QAAA,CAAG,qDAAqD,CAAA,EACrE,QAAA,EAAA;AAAA,IAAA,aAAA,oBAAiBE,cAAA,CAAC,eAAY,SAAA,EAAU,MAAA,EAAO,SAAS,MAAM,cAAA,CAAe,MAAM,CAAA,EAAG,CAAA;AAAA,IACtF,cAAA,mCAAmB,WAAA,EAAA,EAAY,SAAA,EAAU,SAAQ,OAAA,EAAS,MAAM,cAAA,CAAe,OAAO,CAAA,EAAG,CAAA;AAAA,oBAC1FA,cAAA;AAAA,MAAC,KAAA;AAAA,MAAA;AAAA,QACC,GAAA,EAAK,SAAA;AAAA,QACL,SAAA,EAAU,oDAAA;AAAA,QACV,KAAA,EAAO;AAAA,UACL,mBAAA,EAAqB,CAAA,OAAA,EAAU,YAAY,CAAA,SAAA,EAAY,kBAAkB,GAAG,CAAA,OAAA;AAAA,SAC9E;AAAA,QAEC;AAAA;AAAA;AACH,GAAA,EACF,CAAA;AAEJ;AAEA,SAAS,WAAA,CAAY,EAAE,SAAA,EAAW,OAAA,EAAQ,EAAyD;AACjG,EAAA,MAAM,IAAA,GAAO,SAAA,KAAc,MAAA,GAASK,2BAAA,GAAkBC,4BAAA;AACtD,EAAA,MAAM,SAAS,SAAA,KAAc,MAAA;AAE7B,EAAA,uBACEN,cAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACC,SAAA,EAAWF,QAAA;AAAA,QACT,qFAAA;AAAA,QACA,SAAS,QAAA,GAAW;AAAA,OACtB;AAAA,MAEA,QAAA,kBAAAE,cAAA,CAACO,aAAA,EAAA,EAAO,OAAA,EAAkB,SAAA,EAAU,oBAAA,EAAqB,YAAA,EAAY,CAAA,OAAA,EAAU,SAAS,CAAA,CAAA,EACtF,QAAA,kBAAAP,cAAA,CAAC,IAAA,EAAA,EAAK,CAAA,EACR;AAAA;AAAA,GACF;AAEJ;;;;;;"}
|
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
2
|
+
import './index.css';/* empty css */
|
|
3
|
+
import '@base-ui/react/combobox';
|
|
4
|
+
import './components/DataDetailsPanel.es.js';
|
|
5
|
+
import { c as cn } from './utils-CzYGxqbG.js';
|
|
6
|
+
import { ChevronLeftIcon, ChevronRightIcon } from 'lucide-react';
|
|
7
|
+
import { useRef, useState, useCallback, useEffect } from 'react';
|
|
8
|
+
import { B as Button } from './Button-DoOEJwa_.js';
|
|
9
|
+
|
|
10
|
+
function ColumnContent({ children, className }) {
|
|
11
|
+
return /* @__PURE__ */ jsx("div", { className: cn(`grid overflow-y-auto gap-8 content-start`, className), children });
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
function ColumnRoot({ children, className, withLeftSeparator, withRightSeparator }) {
|
|
15
|
+
return /* @__PURE__ */ jsxs("div", { className: "flex overflow-y-auto w-full", children: [
|
|
16
|
+
withLeftSeparator && /* @__PURE__ */ jsx(Separator, {}),
|
|
17
|
+
/* @__PURE__ */ jsx("div", { className: cn(`grid gap-8 content-start w-full overflow-y-auto`, className), children }),
|
|
18
|
+
withRightSeparator && /* @__PURE__ */ jsx(Separator, {})
|
|
19
|
+
] });
|
|
20
|
+
}
|
|
21
|
+
function Separator() {
|
|
22
|
+
return /* @__PURE__ */ jsx("div", { className: cn("bg-surface5 w-[3px] shrink-0 mx-[1.5vw]") });
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
function ColumnToolbar({ children, className }) {
|
|
26
|
+
return /* @__PURE__ */ jsx("div", { className: cn(`flex items-center justify-between w-full flex-wrap gap-4 gap-x-6`, className), children });
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
const Column = Object.assign(ColumnRoot, {
|
|
30
|
+
Content: ColumnContent,
|
|
31
|
+
Toolbar: ColumnToolbar
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
function Columns({ children, className }) {
|
|
35
|
+
return /* @__PURE__ */ jsx("div", { className: cn(`grid w-full h-full grid-cols-1 overflow-y-auto`, className), children });
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
function MultiColumn({ children, numOfColumns = 1, minColumnWidth }) {
|
|
39
|
+
const scrollRef = useRef(null);
|
|
40
|
+
const [canScrollLeft, setCanScrollLeft] = useState(false);
|
|
41
|
+
const [canScrollRight, setCanScrollRight] = useState(false);
|
|
42
|
+
const updateScrollState = useCallback(() => {
|
|
43
|
+
const el = scrollRef.current;
|
|
44
|
+
if (!el) return;
|
|
45
|
+
const { scrollLeft, scrollWidth, clientWidth } = el;
|
|
46
|
+
setCanScrollLeft(scrollLeft > 1);
|
|
47
|
+
setCanScrollRight(scrollLeft + clientWidth < scrollWidth - 1);
|
|
48
|
+
}, []);
|
|
49
|
+
useEffect(() => {
|
|
50
|
+
const el = scrollRef.current;
|
|
51
|
+
if (!el) return;
|
|
52
|
+
updateScrollState();
|
|
53
|
+
el.addEventListener("scroll", updateScrollState, { passive: true });
|
|
54
|
+
const observer = new ResizeObserver(updateScrollState);
|
|
55
|
+
observer.observe(el);
|
|
56
|
+
return () => {
|
|
57
|
+
el.removeEventListener("scroll", updateScrollState);
|
|
58
|
+
observer.disconnect();
|
|
59
|
+
};
|
|
60
|
+
}, [updateScrollState]);
|
|
61
|
+
const prevColumnsRef = useRef(numOfColumns);
|
|
62
|
+
useEffect(() => {
|
|
63
|
+
const el = scrollRef.current;
|
|
64
|
+
if (!el) return;
|
|
65
|
+
if (numOfColumns > prevColumnsRef.current) {
|
|
66
|
+
requestAnimationFrame(() => {
|
|
67
|
+
el.scrollTo({ left: el.scrollWidth, behavior: "smooth" });
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
prevColumnsRef.current = numOfColumns;
|
|
71
|
+
}, [numOfColumns]);
|
|
72
|
+
useEffect(() => {
|
|
73
|
+
const handleKeyDown = (e) => {
|
|
74
|
+
if (e.key === "ArrowLeft" || e.key === "ArrowRight") {
|
|
75
|
+
e.preventDefault();
|
|
76
|
+
scrollToColumn(e.key === "ArrowLeft" ? "left" : "right");
|
|
77
|
+
}
|
|
78
|
+
};
|
|
79
|
+
window.addEventListener("keydown", handleKeyDown);
|
|
80
|
+
return () => window.removeEventListener("keydown", handleKeyDown);
|
|
81
|
+
}, []);
|
|
82
|
+
const scrollToColumn = (direction) => {
|
|
83
|
+
const el = scrollRef.current;
|
|
84
|
+
if (!el) return;
|
|
85
|
+
const columns = Array.from(el.children);
|
|
86
|
+
const containerLeft = el.scrollLeft;
|
|
87
|
+
const containerRight = containerLeft + el.clientWidth;
|
|
88
|
+
if (direction === "right") {
|
|
89
|
+
const target = columns.find((col) => col.offsetLeft + col.offsetWidth > containerRight + 1);
|
|
90
|
+
if (target) {
|
|
91
|
+
el.scrollTo({ left: target.offsetLeft + target.offsetWidth - el.clientWidth, behavior: "smooth" });
|
|
92
|
+
}
|
|
93
|
+
} else {
|
|
94
|
+
const target = [...columns].reverse().find((col) => col.offsetLeft < containerLeft - 1);
|
|
95
|
+
if (target) {
|
|
96
|
+
el.scrollTo({ left: target.offsetLeft, behavior: "smooth" });
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
};
|
|
100
|
+
return /* @__PURE__ */ jsxs("div", { className: cn("MULTI_COLUMN relative w-full h-full overflow-hidden"), children: [
|
|
101
|
+
canScrollLeft && /* @__PURE__ */ jsx(ScrollArrow, { direction: "left", onClick: () => scrollToColumn("left") }),
|
|
102
|
+
canScrollRight && /* @__PURE__ */ jsx(ScrollArrow, { direction: "right", onClick: () => scrollToColumn("right") }),
|
|
103
|
+
/* @__PURE__ */ jsx(
|
|
104
|
+
"div",
|
|
105
|
+
{
|
|
106
|
+
ref: scrollRef,
|
|
107
|
+
className: "grid overflow-x-auto w-full overflow-y-auto h-full",
|
|
108
|
+
style: {
|
|
109
|
+
gridTemplateColumns: `repeat(${numOfColumns}, minmax(${minColumnWidth ?? "0"}, 1fr))`
|
|
110
|
+
},
|
|
111
|
+
children
|
|
112
|
+
}
|
|
113
|
+
)
|
|
114
|
+
] });
|
|
115
|
+
}
|
|
116
|
+
function ScrollArrow({ direction, onClick }) {
|
|
117
|
+
const Icon = direction === "left" ? ChevronLeftIcon : ChevronRightIcon;
|
|
118
|
+
const isLeft = direction === "left";
|
|
119
|
+
return /* @__PURE__ */ jsx(
|
|
120
|
+
"div",
|
|
121
|
+
{
|
|
122
|
+
className: cn(
|
|
123
|
+
"absolute top-0 bottom-0 z-20 w-20 flex items-center justify-center px-5 bg-surface2",
|
|
124
|
+
isLeft ? "left-0" : "right-0"
|
|
125
|
+
),
|
|
126
|
+
children: /* @__PURE__ */ jsx(Button, { onClick, className: "w-full h-full px-0", "aria-label": `Scroll ${direction}`, children: /* @__PURE__ */ jsx(Icon, {}) })
|
|
127
|
+
}
|
|
128
|
+
);
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
export { Column as C, MultiColumn as M, Columns as a };
|
|
132
|
+
//# sourceMappingURL=multi-column-C1sXoVG3.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"multi-column-C1sXoVG3.js","sources":["../src/ds/components/Columns/column-content.tsx","../src/ds/components/Columns/column-root.tsx","../src/ds/components/Columns/column-toolbar.tsx","../src/ds/components/Columns/column.tsx","../src/ds/components/Columns/columns.tsx","../src/ds/components/Columns/multi-column.tsx"],"sourcesContent":["import { cn } from '@/index';\n\nexport type ColumnProps = {\n children?: React.ReactNode;\n className?: string;\n};\n\nexport function ColumnContent({ children, className }: ColumnProps) {\n return <div className={cn(`grid overflow-y-auto gap-8 content-start`, className)}>{children}</div>;\n}\n","import { cn } from '@/index';\n\nexport type ColumnProps = {\n children: React.ReactNode;\n className?: string;\n withRightSeparator?: boolean;\n withLeftSeparator?: boolean;\n};\n\nexport function ColumnRoot({ children, className, withLeftSeparator, withRightSeparator }: ColumnProps) {\n return (\n <div className=\"flex overflow-y-auto w-full\">\n {withLeftSeparator && <Separator />}\n\n <div className={cn(`grid gap-8 content-start w-full overflow-y-auto`, className)}>{children}</div>\n\n {withRightSeparator && <Separator />}\n </div>\n );\n}\n\nfunction Separator() {\n return <div className={cn('bg-surface5 w-[3px] shrink-0 mx-[1.5vw]')}></div>;\n}\n","import { cn } from '@/index';\n\nexport type ColumnToolbarProps = {\n children?: React.ReactNode;\n className?: string;\n};\n\nexport function ColumnToolbar({ children, className }: ColumnToolbarProps) {\n return (\n <div className={cn(`flex items-center justify-between w-full flex-wrap gap-4 gap-x-6`, className)}>{children}</div>\n );\n}\n","import { ColumnContent } from './column-content';\nimport { ColumnRoot } from './column-root';\nimport { ColumnToolbar } from './column-toolbar';\n\nexport const Column = Object.assign(ColumnRoot, {\n Content: ColumnContent,\n Toolbar: ColumnToolbar,\n});\n","import { cn } from '@/index';\n\nexport type ColumnsProps = {\n children: React.ReactNode;\n className?: string;\n};\n\nexport function Columns({ children, className }: ColumnsProps) {\n return <div className={cn(`grid w-full h-full grid-cols-1 overflow-y-auto`, className)}>{children}</div>;\n}\n","'use client';\n\nimport { ChevronLeftIcon, ChevronRightIcon } from 'lucide-react';\nimport React, { useCallback, useEffect, useRef, useState } from 'react';\nimport { Button } from '../Button';\nimport { cn } from '@/lib/utils';\n\nexport type MultiColumnProps = {\n children?: React.ReactNode;\n numOfColumns?: number;\n minColumnWidth?: string;\n};\n\nexport function MultiColumn({ children, numOfColumns = 1, minColumnWidth }: MultiColumnProps): React.JSX.Element {\n const scrollRef = useRef<HTMLDivElement>(null);\n const [canScrollLeft, setCanScrollLeft] = useState(false);\n const [canScrollRight, setCanScrollRight] = useState(false);\n const updateScrollState = useCallback(() => {\n const el = scrollRef.current;\n if (!el) return;\n const { scrollLeft, scrollWidth, clientWidth } = el;\n setCanScrollLeft(scrollLeft > 1);\n setCanScrollRight(scrollLeft + clientWidth < scrollWidth - 1);\n }, []);\n\n useEffect(() => {\n const el = scrollRef.current;\n if (!el) return;\n\n updateScrollState();\n\n el.addEventListener('scroll', updateScrollState, { passive: true });\n\n const observer = new ResizeObserver(updateScrollState);\n observer.observe(el);\n\n return () => {\n el.removeEventListener('scroll', updateScrollState);\n observer.disconnect();\n };\n }, [updateScrollState]);\n\n const prevColumnsRef = useRef(numOfColumns);\n useEffect(() => {\n const el = scrollRef.current;\n if (!el) return;\n if (numOfColumns > prevColumnsRef.current) {\n // New column added — scroll to the right end so it's visible\n requestAnimationFrame(() => {\n el.scrollTo({ left: el.scrollWidth, behavior: 'smooth' });\n });\n }\n prevColumnsRef.current = numOfColumns;\n }, [numOfColumns]);\n\n useEffect(() => {\n const handleKeyDown = (e: KeyboardEvent) => {\n if (e.key === 'ArrowLeft' || e.key === 'ArrowRight') {\n e.preventDefault();\n scrollToColumn(e.key === 'ArrowLeft' ? 'left' : 'right');\n }\n };\n window.addEventListener('keydown', handleKeyDown);\n return () => window.removeEventListener('keydown', handleKeyDown);\n }, []);\n\n const scrollToColumn = (direction: 'left' | 'right') => {\n const el = scrollRef.current;\n if (!el) return;\n\n const columns = Array.from(el.children) as HTMLElement[];\n const containerLeft = el.scrollLeft;\n const containerRight = containerLeft + el.clientWidth;\n\n if (direction === 'right') {\n // Find the first column whose right edge is past the container's right edge\n const target = columns.find(col => col.offsetLeft + col.offsetWidth > containerRight + 1);\n if (target) {\n el.scrollTo({ left: target.offsetLeft + target.offsetWidth - el.clientWidth, behavior: 'smooth' });\n }\n } else {\n // Find the last column whose left edge is before the container's left edge\n const target = [...columns].reverse().find(col => col.offsetLeft < containerLeft - 1);\n if (target) {\n el.scrollTo({ left: target.offsetLeft, behavior: 'smooth' });\n }\n }\n };\n\n return (\n <div className={cn('MULTI_COLUMN relative w-full h-full overflow-hidden')}>\n {canScrollLeft && <ScrollArrow direction=\"left\" onClick={() => scrollToColumn('left')} />}\n {canScrollRight && <ScrollArrow direction=\"right\" onClick={() => scrollToColumn('right')} />}\n <div\n ref={scrollRef}\n className=\"grid overflow-x-auto w-full overflow-y-auto h-full\"\n style={{\n gridTemplateColumns: `repeat(${numOfColumns}, minmax(${minColumnWidth ?? '0'}, 1fr))`,\n }}\n >\n {children}\n </div>\n </div>\n );\n}\n\nfunction ScrollArrow({ direction, onClick }: { direction: 'left' | 'right'; onClick: () => void }) {\n const Icon = direction === 'left' ? ChevronLeftIcon : ChevronRightIcon;\n const isLeft = direction === 'left';\n\n return (\n <div\n className={cn(\n 'absolute top-0 bottom-0 z-20 w-20 flex items-center justify-center px-5 bg-surface2',\n isLeft ? 'left-0' : 'right-0',\n )}\n >\n <Button onClick={onClick} className=\"w-full h-full px-0\" aria-label={`Scroll ${direction}`}>\n <Icon />\n </Button>\n </div>\n );\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,193 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const jsxRuntime = require('react/jsx-runtime');
|
|
4
|
+
const combobox = require('@base-ui/react/combobox');
|
|
5
|
+
const lucideReact = require('lucide-react');
|
|
6
|
+
const Button = require('./Button-DpIX8JMz.cjs');
|
|
7
|
+
const controlSize = require('./control-size-D67C0kPZ.cjs');
|
|
8
|
+
const transitions = require('./transitions-DpczSjmD.cjs');
|
|
9
|
+
const utils = require('./utils-vA5sWo9W.cjs');
|
|
10
|
+
|
|
11
|
+
function normalizeComboboxVariant(variant) {
|
|
12
|
+
return variant === "link" ? "ghost" : variant;
|
|
13
|
+
}
|
|
14
|
+
function comboboxTriggerClass({
|
|
15
|
+
variant,
|
|
16
|
+
size,
|
|
17
|
+
error,
|
|
18
|
+
className
|
|
19
|
+
}) {
|
|
20
|
+
const visualVariant = normalizeComboboxVariant(variant);
|
|
21
|
+
return utils.cn(
|
|
22
|
+
Button.buttonVariants({ variant: visualVariant, size }),
|
|
23
|
+
// Fill the field and push the value left / chevron right (Button's base
|
|
24
|
+
// centers its content with `justify-center`).
|
|
25
|
+
"w-full min-w-32 justify-between",
|
|
26
|
+
// Read as "active" while the popup is open, per variant (see map above).
|
|
27
|
+
controlSize.controlTriggerOpenState[visualVariant],
|
|
28
|
+
"data-[placeholder]:text-neutral3",
|
|
29
|
+
error && "border-error hover:border-error focus-visible:border-error",
|
|
30
|
+
className
|
|
31
|
+
);
|
|
32
|
+
}
|
|
33
|
+
const comboboxStyles = {
|
|
34
|
+
/** Root wrapper */
|
|
35
|
+
root: "flex flex-col gap-1.5",
|
|
36
|
+
/** Chevron icon in trigger — inherits the variant's text color via currentColor. */
|
|
37
|
+
chevron: "ml-2 h-4 w-4 shrink-0 opacity-60",
|
|
38
|
+
/** Placeholder text color */
|
|
39
|
+
placeholder: "text-neutral3",
|
|
40
|
+
/** Popup container — concentric with rounded-xl + p-1 (8px items inside 12px container). */
|
|
41
|
+
popup: utils.cn(
|
|
42
|
+
"min-w-(--anchor-width) w-max max-w-(--available-width) rounded-xl border border-border1 bg-surface3 text-neutral4",
|
|
43
|
+
"shadow-dialog",
|
|
44
|
+
"origin-(--transform-origin)",
|
|
45
|
+
"transition-[transform,scale,opacity] duration-150 ease-out",
|
|
46
|
+
"data-starting-style:scale-95 data-starting-style:opacity-0",
|
|
47
|
+
"data-ending-style:scale-95 data-ending-style:opacity-0"
|
|
48
|
+
),
|
|
49
|
+
/** Positioner */
|
|
50
|
+
positioner: "z-50 pointer-events-auto",
|
|
51
|
+
/** Search input container — borderless top section, hairline divider below. */
|
|
52
|
+
searchContainer: utils.cn("flex items-center border-b border-border1 px-2.5 py-1.5", transitions.transitions.colors),
|
|
53
|
+
/** Search icon */
|
|
54
|
+
searchIcon: utils.cn("mr-2 h-3.5 w-3.5 shrink-0 text-neutral3", transitions.transitions.colors),
|
|
55
|
+
/** Search input */
|
|
56
|
+
searchInput: utils.cn(
|
|
57
|
+
"flex h-7 w-full rounded-md bg-transparent py-1 text-ui-smd leading-ui-sm text-neutral6",
|
|
58
|
+
"placeholder:text-neutral3 disabled:cursor-not-allowed disabled:opacity-50",
|
|
59
|
+
"outline-none focus:outline-none focus-visible:outline-none",
|
|
60
|
+
transitions.transitions.colors
|
|
61
|
+
),
|
|
62
|
+
/** Empty state */
|
|
63
|
+
empty: "not-empty:block hidden py-4 text-center text-ui-smd text-neutral3",
|
|
64
|
+
/** Options list */
|
|
65
|
+
list: "max-h-dropdown-max-height overflow-y-auto overflow-x-hidden p-1",
|
|
66
|
+
/** Option item base — rounded-md sits concentrically inside rounded-xl + p-1. */
|
|
67
|
+
item: utils.cn(
|
|
68
|
+
"group/item relative flex cursor-pointer select-none items-center gap-2 rounded-md",
|
|
69
|
+
"pl-2.5 pr-2 py-1.5 min-h-8",
|
|
70
|
+
"text-ui-smd leading-ui-sm text-neutral4",
|
|
71
|
+
"outline-none focus:outline-none focus-visible:outline-none",
|
|
72
|
+
transitions.transitions.colors,
|
|
73
|
+
"data-highlighted:bg-surface4 data-highlighted:text-neutral6",
|
|
74
|
+
"data-selected:text-neutral6"
|
|
75
|
+
),
|
|
76
|
+
/** Multi-select item — keeps the left checkbox slot, no right indicator. */
|
|
77
|
+
itemMulti: utils.cn(
|
|
78
|
+
"relative flex cursor-pointer select-none items-center gap-2.5 rounded-md",
|
|
79
|
+
"pl-2 pr-2.5 py-1.5 min-h-8",
|
|
80
|
+
"text-ui-smd leading-ui-sm text-neutral4",
|
|
81
|
+
"outline-none focus:outline-none focus-visible:outline-none",
|
|
82
|
+
transitions.transitions.colors,
|
|
83
|
+
"data-highlighted:bg-surface4 data-highlighted:text-neutral6",
|
|
84
|
+
"data-selected:text-neutral6"
|
|
85
|
+
),
|
|
86
|
+
/** Right-aligned slot grouping end content + selection check. */
|
|
87
|
+
itemRightSlot: "ml-auto flex items-center gap-2 shrink-0",
|
|
88
|
+
/** Check indicator container — inline, fixed 16x16, shown only when item is selected. */
|
|
89
|
+
checkContainer: "flex h-4 w-4 shrink-0 items-center justify-center text-accent1",
|
|
90
|
+
/** Check icon (single select) */
|
|
91
|
+
checkIcon: "h-3.5 w-3.5",
|
|
92
|
+
/** Checkbox container (multi select) */
|
|
93
|
+
checkbox: "flex h-4 w-4 shrink-0 items-center justify-center rounded-[4px] border",
|
|
94
|
+
/** Checkbox selected state */
|
|
95
|
+
checkboxSelected: "bg-accent1 border-accent1",
|
|
96
|
+
/** Checkbox unselected state */
|
|
97
|
+
checkboxUnselected: "border-border2",
|
|
98
|
+
/** Check icon for checkbox (multi select) */
|
|
99
|
+
checkboxIcon: "h-3 w-3 text-surface1",
|
|
100
|
+
/** Option content wrapper */
|
|
101
|
+
optionContent: "flex items-center gap-2 w-full min-w-0",
|
|
102
|
+
/** Option label/description wrapper */
|
|
103
|
+
optionText: "flex flex-col gap-0.5 min-w-0",
|
|
104
|
+
/** Option label */
|
|
105
|
+
optionLabel: "truncate",
|
|
106
|
+
/** Option description */
|
|
107
|
+
optionDescription: "text-ui-sm text-neutral3 truncate",
|
|
108
|
+
/** Option end slot — `ml-auto` makes it push right inside flex containers (used by multi-select). */
|
|
109
|
+
optionEnd: "ml-auto flex items-center shrink-0",
|
|
110
|
+
/** Error message */
|
|
111
|
+
error: "text-ui-sm text-accent2"
|
|
112
|
+
};
|
|
113
|
+
|
|
114
|
+
function MultiCombobox({
|
|
115
|
+
options,
|
|
116
|
+
value = [],
|
|
117
|
+
onValueChange,
|
|
118
|
+
placeholder = "Select options...",
|
|
119
|
+
searchPlaceholder = "Search...",
|
|
120
|
+
emptyText = "No option found.",
|
|
121
|
+
className,
|
|
122
|
+
disabled = false,
|
|
123
|
+
variant = "default",
|
|
124
|
+
size = "md",
|
|
125
|
+
open,
|
|
126
|
+
onOpenChange,
|
|
127
|
+
container,
|
|
128
|
+
error
|
|
129
|
+
}) {
|
|
130
|
+
const selectedOptions = options.filter((option) => value.includes(option.value));
|
|
131
|
+
const handleSelect = (items) => {
|
|
132
|
+
if (items) {
|
|
133
|
+
onValueChange?.(items.map((item) => item.value));
|
|
134
|
+
}
|
|
135
|
+
};
|
|
136
|
+
const triggerText = selectedOptions.length === 0 ? placeholder : `${selectedOptions.length} selected`;
|
|
137
|
+
return /* @__PURE__ */ jsxRuntime.jsxs("div", { className: comboboxStyles.root, children: [
|
|
138
|
+
/* @__PURE__ */ jsxRuntime.jsxs(
|
|
139
|
+
combobox.Combobox.Root,
|
|
140
|
+
{
|
|
141
|
+
multiple: true,
|
|
142
|
+
items: options,
|
|
143
|
+
value: selectedOptions,
|
|
144
|
+
onValueChange: handleSelect,
|
|
145
|
+
disabled,
|
|
146
|
+
open,
|
|
147
|
+
onOpenChange,
|
|
148
|
+
children: [
|
|
149
|
+
/* @__PURE__ */ jsxRuntime.jsxs(combobox.Combobox.Trigger, { className: comboboxTriggerClass({ variant, size, error: Boolean(error), className }), children: [
|
|
150
|
+
/* @__PURE__ */ jsxRuntime.jsx("span", { className: utils.cn("truncate", selectedOptions.length === 0 && comboboxStyles.placeholder), children: triggerText }),
|
|
151
|
+
/* @__PURE__ */ jsxRuntime.jsx("span", { className: "flex shrink-0 items-center", children: /* @__PURE__ */ jsxRuntime.jsx(lucideReact.ChevronsUpDown, { className: comboboxStyles.chevron }) })
|
|
152
|
+
] }),
|
|
153
|
+
/* @__PURE__ */ jsxRuntime.jsx(combobox.Combobox.Portal, { container, children: /* @__PURE__ */ jsxRuntime.jsx(combobox.Combobox.Positioner, { align: "start", sideOffset: 4, className: comboboxStyles.positioner, children: /* @__PURE__ */ jsxRuntime.jsxs(combobox.Combobox.Popup, { className: comboboxStyles.popup, children: [
|
|
154
|
+
/* @__PURE__ */ jsxRuntime.jsxs("div", { className: comboboxStyles.searchContainer, children: [
|
|
155
|
+
/* @__PURE__ */ jsxRuntime.jsx(lucideReact.Search, { className: comboboxStyles.searchIcon }),
|
|
156
|
+
/* @__PURE__ */ jsxRuntime.jsx(combobox.Combobox.Input, { className: comboboxStyles.searchInput, placeholder: searchPlaceholder })
|
|
157
|
+
] }),
|
|
158
|
+
/* @__PURE__ */ jsxRuntime.jsx(combobox.Combobox.Empty, { className: comboboxStyles.empty, children: emptyText }),
|
|
159
|
+
/* @__PURE__ */ jsxRuntime.jsx(combobox.Combobox.List, { className: comboboxStyles.list, children: (option) => {
|
|
160
|
+
const isSelected = value.includes(option.value);
|
|
161
|
+
return /* @__PURE__ */ jsxRuntime.jsxs(combobox.Combobox.Item, { value: option, className: comboboxStyles.itemMulti, children: [
|
|
162
|
+
/* @__PURE__ */ jsxRuntime.jsx(
|
|
163
|
+
"span",
|
|
164
|
+
{
|
|
165
|
+
className: utils.cn(
|
|
166
|
+
comboboxStyles.checkbox,
|
|
167
|
+
isSelected ? comboboxStyles.checkboxSelected : comboboxStyles.checkboxUnselected
|
|
168
|
+
),
|
|
169
|
+
children: isSelected && /* @__PURE__ */ jsxRuntime.jsx(lucideReact.Check, { className: comboboxStyles.checkboxIcon })
|
|
170
|
+
}
|
|
171
|
+
),
|
|
172
|
+
/* @__PURE__ */ jsxRuntime.jsxs("span", { className: comboboxStyles.optionContent, children: [
|
|
173
|
+
option.start,
|
|
174
|
+
/* @__PURE__ */ jsxRuntime.jsxs("span", { className: comboboxStyles.optionText, children: [
|
|
175
|
+
/* @__PURE__ */ jsxRuntime.jsx("span", { className: comboboxStyles.optionLabel, children: option.label }),
|
|
176
|
+
option.description && /* @__PURE__ */ jsxRuntime.jsx("span", { className: comboboxStyles.optionDescription, children: option.description })
|
|
177
|
+
] }),
|
|
178
|
+
option.end ? /* @__PURE__ */ jsxRuntime.jsx("div", { className: comboboxStyles.optionEnd, children: option.end }) : null
|
|
179
|
+
] })
|
|
180
|
+
] }, option.value);
|
|
181
|
+
} })
|
|
182
|
+
] }) }) })
|
|
183
|
+
]
|
|
184
|
+
}
|
|
185
|
+
),
|
|
186
|
+
error && /* @__PURE__ */ jsxRuntime.jsx("span", { className: comboboxStyles.error, children: error })
|
|
187
|
+
] });
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
exports.MultiCombobox = MultiCombobox;
|
|
191
|
+
exports.comboboxStyles = comboboxStyles;
|
|
192
|
+
exports.comboboxTriggerClass = comboboxTriggerClass;
|
|
193
|
+
//# sourceMappingURL=multi-combobox-DkFLK64B.cjs.map
|