@hyddenlabs/hydn-ui 0.3.0-alpha.99 → 0.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +46 -29
- package/dist/components/branding/google-logo.d.ts +14 -0
- package/dist/components/branding/google-logo.d.ts.map +1 -0
- package/dist/components/branding/google-logo.js +49 -0
- package/dist/components/branding/google-logo.js.map +1 -0
- package/dist/components/branding/hydden-logo.d.ts +14 -0
- package/dist/components/branding/hydden-logo.d.ts.map +1 -0
- package/dist/components/branding/hydden-logo.js +8 -0
- package/dist/components/branding/hydden-logo.js.map +1 -0
- package/dist/components/branding/microsoft-logo.d.ts +14 -0
- package/dist/components/branding/microsoft-logo.d.ts.map +1 -0
- package/dist/components/branding/microsoft-logo.js +25 -0
- package/dist/components/branding/microsoft-logo.js.map +1 -0
- package/dist/components/data-display/avatar/avatar.d.ts +24 -0
- package/dist/components/data-display/avatar/avatar.d.ts.map +1 -0
- package/dist/components/data-display/avatar/avatar.js +25 -0
- package/dist/components/data-display/avatar/avatar.js.map +1 -0
- package/dist/components/data-display/avatar/index.d.ts +3 -0
- package/dist/components/data-display/avatar/index.d.ts.map +1 -0
- package/dist/components/data-display/badge/badge.d.ts +24 -0
- package/dist/components/data-display/badge/badge.d.ts.map +1 -0
- package/dist/components/data-display/badge/badge.js +27 -0
- package/dist/components/data-display/badge/badge.js.map +1 -0
- package/dist/components/data-display/badge/index.d.ts +5 -0
- package/dist/components/data-display/badge/index.d.ts.map +1 -0
- package/dist/components/data-display/badge/status-label.d.ts +25 -0
- package/dist/components/data-display/badge/status-label.d.ts.map +1 -0
- package/dist/components/data-display/badge/status-label.js +63 -0
- package/dist/components/data-display/badge/status-label.js.map +1 -0
- package/dist/components/data-display/chip/chip.d.ts +42 -0
- package/dist/components/data-display/chip/chip.d.ts.map +1 -0
- package/dist/components/data-display/chip/chip.js +79 -0
- package/dist/components/data-display/chip/chip.js.map +1 -0
- package/dist/components/data-display/chip/index.d.ts +3 -0
- package/dist/components/data-display/chip/index.d.ts.map +1 -0
- package/dist/components/data-display/code-block/code-block.d.ts +17 -0
- package/dist/components/data-display/code-block/code-block.d.ts.map +1 -0
- package/dist/components/data-display/code-block/code-block.js +34 -0
- package/dist/components/data-display/code-block/code-block.js.map +1 -0
- package/dist/components/data-display/data-table/data-table.d.ts +226 -0
- package/dist/components/data-display/data-table/data-table.d.ts.map +1 -0
- package/dist/components/data-display/data-table/data-table.js +404 -0
- package/dist/components/data-display/data-table/data-table.js.map +1 -0
- package/dist/components/data-display/data-table/index.d.ts +5 -0
- package/dist/components/data-display/data-table/index.d.ts.map +1 -0
- package/dist/components/data-display/data-table/use-table.d.ts +42 -0
- package/dist/components/data-display/data-table/use-table.d.ts.map +1 -0
- package/dist/components/data-display/data-table/use-table.js +120 -0
- package/dist/components/data-display/data-table/use-table.js.map +1 -0
- package/dist/components/data-display/empty-state/empty-state.d.ts +8 -0
- package/dist/components/data-display/empty-state/empty-state.d.ts.map +1 -0
- package/dist/components/data-display/empty-state/empty-state.js +17 -0
- package/dist/components/data-display/empty-state/empty-state.js.map +1 -0
- package/dist/components/data-display/empty-state/index.d.ts +3 -0
- package/dist/components/data-display/empty-state/index.d.ts.map +1 -0
- package/dist/components/data-display/list/index.d.ts +3 -0
- package/dist/components/data-display/list/index.d.ts.map +1 -0
- package/dist/components/data-display/list/list.d.ts +31 -0
- package/dist/components/data-display/list/list.d.ts.map +1 -0
- package/dist/components/data-display/list/list.js +16 -0
- package/dist/components/data-display/list/list.js.map +1 -0
- package/dist/components/data-display/table/index.d.ts +3 -0
- package/dist/components/data-display/table/index.d.ts.map +1 -0
- package/dist/components/data-display/table/table.d.ts +101 -0
- package/dist/components/data-display/table/table.d.ts.map +1 -0
- package/dist/components/data-display/table/table.js +98 -0
- package/dist/components/data-display/table/table.js.map +1 -0
- package/dist/components/data-display/timeline/index.d.ts +3 -0
- package/dist/components/data-display/timeline/index.d.ts.map +1 -0
- package/dist/components/data-display/timeline/timeline.d.ts +57 -0
- package/dist/components/data-display/timeline/timeline.d.ts.map +1 -0
- package/dist/components/data-display/timeline/timeline.js +52 -0
- package/dist/components/data-display/timeline/timeline.js.map +1 -0
- package/dist/components/feedback/alert/alert.d.ts +27 -0
- package/dist/components/feedback/alert/alert.d.ts.map +1 -0
- package/dist/components/feedback/alert/alert.js +86 -0
- package/dist/components/feedback/alert/alert.js.map +1 -0
- package/dist/components/feedback/alert/index.d.ts +3 -0
- package/dist/components/feedback/alert/index.d.ts.map +1 -0
- package/dist/components/feedback/dialog/delete-dialog.d.ts +41 -0
- package/dist/components/feedback/dialog/delete-dialog.d.ts.map +1 -0
- package/dist/components/feedback/dialog/delete-dialog.js +52 -0
- package/dist/components/feedback/dialog/delete-dialog.js.map +1 -0
- package/dist/components/feedback/dialog/dialog.d.ts +24 -0
- package/dist/components/feedback/dialog/dialog.d.ts.map +1 -0
- package/dist/components/feedback/dialog/dialog.js +15 -0
- package/dist/components/feedback/dialog/dialog.js.map +1 -0
- package/dist/components/feedback/dialog/index.d.ts +5 -0
- package/dist/components/feedback/dialog/index.d.ts.map +1 -0
- package/dist/components/feedback/error-page/error-400.d.ts +22 -0
- package/dist/components/feedback/error-page/error-400.d.ts.map +1 -0
- package/dist/components/feedback/error-page/error-400.js +28 -0
- package/dist/components/feedback/error-page/error-400.js.map +1 -0
- package/dist/components/feedback/error-page/error-401.d.ts +26 -0
- package/dist/components/feedback/error-page/error-401.d.ts.map +1 -0
- package/dist/components/feedback/error-page/error-401.js +33 -0
- package/dist/components/feedback/error-page/error-401.js.map +1 -0
- package/dist/components/feedback/error-page/error-403.d.ts +26 -0
- package/dist/components/feedback/error-page/error-403.d.ts.map +1 -0
- package/dist/components/feedback/error-page/error-403.js +33 -0
- package/dist/components/feedback/error-page/error-403.js.map +1 -0
- package/dist/components/feedback/error-page/error-404.d.ts +26 -0
- package/dist/components/feedback/error-page/error-404.d.ts.map +1 -0
- package/dist/components/feedback/error-page/error-404.js +33 -0
- package/dist/components/feedback/error-page/error-404.js.map +1 -0
- package/dist/components/feedback/error-page/index.d.ts +9 -0
- package/dist/components/feedback/error-page/index.d.ts.map +1 -0
- package/dist/components/feedback/loading-container/index.d.ts +3 -0
- package/dist/components/feedback/loading-container/index.d.ts.map +1 -0
- package/dist/components/feedback/loading-container/loading-container.d.ts +16 -0
- package/dist/components/feedback/loading-container/loading-container.d.ts.map +1 -0
- package/dist/components/feedback/loading-container/loading-container.js +28 -0
- package/dist/components/feedback/loading-container/loading-container.js.map +1 -0
- package/dist/components/feedback/modal/index.d.ts +3 -0
- package/dist/components/feedback/modal/index.d.ts.map +1 -0
- package/dist/components/feedback/modal/modal.d.ts +33 -0
- package/dist/components/feedback/modal/modal.d.ts.map +1 -0
- package/dist/components/feedback/modal/modal.js +88 -0
- package/dist/components/feedback/modal/modal.js.map +1 -0
- package/dist/components/feedback/overlay/useOverlay.d.ts +24 -0
- package/dist/components/feedback/overlay/useOverlay.d.ts.map +1 -0
- package/dist/components/feedback/overlay/useOverlay.js +119 -0
- package/dist/components/feedback/overlay/useOverlay.js.map +1 -0
- package/dist/components/feedback/popover/index.d.ts +3 -0
- package/dist/components/feedback/popover/index.d.ts.map +1 -0
- package/dist/components/feedback/popover/popover.d.ts +25 -0
- package/dist/components/feedback/popover/popover.d.ts.map +1 -0
- package/dist/components/feedback/popover/popover.js +118 -0
- package/dist/components/feedback/popover/popover.js.map +1 -0
- package/dist/components/feedback/progress-bar/index.d.ts +3 -0
- package/dist/components/feedback/progress-bar/index.d.ts.map +1 -0
- package/dist/components/feedback/progress-bar/progress-bar.d.ts +22 -0
- package/dist/components/feedback/progress-bar/progress-bar.d.ts.map +1 -0
- package/dist/components/feedback/progress-bar/progress-bar.js +27 -0
- package/dist/components/feedback/progress-bar/progress-bar.js.map +1 -0
- package/dist/components/feedback/skeleton/index.d.ts +3 -0
- package/dist/components/feedback/skeleton/index.d.ts.map +1 -0
- package/dist/components/feedback/skeleton/skeleton.d.ts +19 -0
- package/dist/components/feedback/skeleton/skeleton.d.ts.map +1 -0
- package/dist/components/feedback/skeleton/skeleton.js +28 -0
- package/dist/components/feedback/skeleton/skeleton.js.map +1 -0
- package/dist/components/feedback/smooth-transition/index.d.ts +3 -0
- package/dist/components/feedback/smooth-transition/index.d.ts.map +1 -0
- package/dist/components/feedback/smooth-transition/smooth-transition.d.ts +68 -0
- package/dist/components/feedback/smooth-transition/smooth-transition.d.ts.map +1 -0
- package/dist/components/feedback/smooth-transition/smooth-transition.js +89 -0
- package/dist/components/feedback/smooth-transition/smooth-transition.js.map +1 -0
- package/dist/components/feedback/spinner/index.d.ts +3 -0
- package/dist/components/feedback/spinner/index.d.ts.map +1 -0
- package/dist/components/feedback/spinner/spinner.d.ts +21 -0
- package/dist/components/feedback/spinner/spinner.d.ts.map +1 -0
- package/dist/components/feedback/spinner/spinner.js +27 -0
- package/dist/components/feedback/spinner/spinner.js.map +1 -0
- package/dist/components/feedback/toast/index.d.ts +3 -0
- package/dist/components/feedback/toast/index.d.ts.map +1 -0
- package/dist/components/feedback/toast/toast.d.ts +23 -0
- package/dist/components/feedback/toast/toast.d.ts.map +1 -0
- package/dist/components/feedback/toast/toast.js +45 -0
- package/dist/components/feedback/toast/toast.js.map +1 -0
- package/dist/components/feedback/tooltip/index.d.ts +3 -0
- package/dist/components/feedback/tooltip/index.d.ts.map +1 -0
- package/dist/components/feedback/tooltip/tooltip.d.ts +39 -0
- package/dist/components/feedback/tooltip/tooltip.d.ts.map +1 -0
- package/dist/components/feedback/tooltip/tooltip.js +129 -0
- package/dist/components/feedback/tooltip/tooltip.js.map +1 -0
- package/dist/components/forms/button/button-with-icon.d.ts +18 -0
- package/dist/components/forms/button/button-with-icon.d.ts.map +1 -0
- package/dist/components/forms/button/button-with-icon.js +15 -0
- package/dist/components/forms/button/button-with-icon.js.map +1 -0
- package/dist/components/forms/button/button.d.ts +66 -0
- package/dist/components/forms/button/button.d.ts.map +1 -0
- package/dist/components/forms/button/button.examples.d.ts +73 -0
- package/dist/components/forms/button/button.examples.d.ts.map +1 -0
- package/dist/components/forms/button/button.js +118 -0
- package/dist/components/forms/button/button.js.map +1 -0
- package/dist/components/forms/button/icon-button.d.ts +23 -0
- package/dist/components/forms/button/icon-button.d.ts.map +1 -0
- package/dist/components/forms/button/icon-button.js +85 -0
- package/dist/components/forms/button/icon-button.js.map +1 -0
- package/dist/components/forms/button/index.d.ts +10 -0
- package/dist/components/forms/button/index.d.ts.map +1 -0
- package/dist/components/forms/button/inline-button.d.ts +45 -0
- package/dist/components/forms/button/inline-button.d.ts.map +1 -0
- package/dist/components/forms/button/inline-button.js +59 -0
- package/dist/components/forms/button/inline-button.js.map +1 -0
- package/dist/components/forms/button-group/button-group.d.ts +20 -0
- package/dist/components/forms/button-group/button-group.d.ts.map +1 -0
- package/dist/components/forms/button-group/button-group.js +24 -0
- package/dist/components/forms/button-group/button-group.js.map +1 -0
- package/dist/components/forms/button-group/index.d.ts +3 -0
- package/dist/components/forms/button-group/index.d.ts.map +1 -0
- package/dist/components/forms/calendar/calendar.d.ts +37 -0
- package/dist/components/forms/calendar/calendar.d.ts.map +1 -0
- package/dist/components/forms/calendar/calendar.js +131 -0
- package/dist/components/forms/calendar/calendar.js.map +1 -0
- package/dist/components/forms/calendar/index.d.ts +3 -0
- package/dist/components/forms/calendar/index.d.ts.map +1 -0
- package/dist/components/forms/checkbox/checkbox.d.ts +31 -0
- package/dist/components/forms/checkbox/checkbox.d.ts.map +1 -0
- package/dist/components/forms/checkbox/checkbox.js +39 -0
- package/dist/components/forms/checkbox/checkbox.js.map +1 -0
- package/dist/components/forms/checkbox/index.d.ts +3 -0
- package/dist/components/forms/checkbox/index.d.ts.map +1 -0
- package/dist/components/forms/code/code.d.ts +32 -0
- package/dist/components/forms/code/code.d.ts.map +1 -0
- package/dist/components/forms/code/code.js +31 -0
- package/dist/components/forms/code/code.js.map +1 -0
- package/dist/components/forms/code/index.d.ts +1 -0
- package/dist/components/forms/code/index.d.ts.map +1 -0
- package/dist/components/forms/date-picker/date-picker.d.ts +72 -0
- package/dist/components/forms/date-picker/date-picker.d.ts.map +1 -0
- package/dist/components/forms/date-picker/date-picker.js +173 -0
- package/dist/components/forms/date-picker/date-picker.js.map +1 -0
- package/dist/components/forms/date-picker/index.d.ts +3 -0
- package/dist/components/forms/date-picker/index.d.ts.map +1 -0
- package/dist/components/forms/editable-text/editable-text.d.ts +59 -0
- package/dist/components/forms/editable-text/editable-text.d.ts.map +1 -0
- package/dist/components/forms/editable-text/editable-text.js +188 -0
- package/dist/components/forms/editable-text/editable-text.js.map +1 -0
- package/dist/components/forms/editable-text/index.d.ts +3 -0
- package/dist/components/forms/editable-text/index.d.ts.map +1 -0
- package/dist/components/forms/fieldset/fieldset.d.ts +46 -0
- package/dist/components/forms/fieldset/fieldset.d.ts.map +1 -0
- package/dist/components/forms/fieldset/fieldset.js +40 -0
- package/dist/components/forms/fieldset/fieldset.js.map +1 -0
- package/dist/components/forms/fieldset/index.d.ts +3 -0
- package/dist/components/forms/fieldset/index.d.ts.map +1 -0
- package/dist/components/forms/form/form-example.d.ts +11 -0
- package/dist/components/forms/form/form-example.d.ts.map +1 -0
- package/dist/components/forms/form/form.d.ts +44 -0
- package/dist/components/forms/form/form.d.ts.map +1 -0
- package/dist/components/forms/form/form.js +39 -0
- package/dist/components/forms/form/form.js.map +1 -0
- package/dist/components/forms/form/index.d.ts +3 -0
- package/dist/components/forms/form/index.d.ts.map +1 -0
- package/dist/components/forms/form-checkbox/form-checkbox.d.ts +27 -0
- package/dist/components/forms/form-checkbox/form-checkbox.d.ts.map +1 -0
- package/dist/components/forms/form-checkbox/form-checkbox.js +58 -0
- package/dist/components/forms/form-checkbox/form-checkbox.js.map +1 -0
- package/dist/components/forms/form-checkbox/index.d.ts +3 -0
- package/dist/components/forms/form-checkbox/index.d.ts.map +1 -0
- package/dist/components/forms/form-checkbox-group/form-checkbox-group.d.ts +40 -0
- package/dist/components/forms/form-checkbox-group/form-checkbox-group.d.ts.map +1 -0
- package/dist/components/forms/form-checkbox-group/form-checkbox-group.js +74 -0
- package/dist/components/forms/form-checkbox-group/form-checkbox-group.js.map +1 -0
- package/dist/components/forms/form-field/form-field.d.ts +53 -0
- package/dist/components/forms/form-field/form-field.d.ts.map +1 -0
- package/dist/components/forms/form-field/form-field.js +56 -0
- package/dist/components/forms/form-field/form-field.js.map +1 -0
- package/dist/components/forms/form-field/index.d.ts +3 -0
- package/dist/components/forms/form-field/index.d.ts.map +1 -0
- package/dist/components/forms/form-input/form-input.d.ts +60 -0
- package/dist/components/forms/form-input/form-input.d.ts.map +1 -0
- package/dist/components/forms/form-input/form-input.js +53 -0
- package/dist/components/forms/form-input/form-input.js.map +1 -0
- package/dist/components/forms/form-select/form-select.d.ts +32 -0
- package/dist/components/forms/form-select/form-select.d.ts.map +1 -0
- package/dist/components/forms/form-select/form-select.js +34 -0
- package/dist/components/forms/form-select/form-select.js.map +1 -0
- package/dist/components/forms/form-textarea/form-textarea.d.ts +31 -0
- package/dist/components/forms/form-textarea/form-textarea.d.ts.map +1 -0
- package/dist/components/forms/form-textarea/form-textarea.js +34 -0
- package/dist/components/forms/form-textarea/form-textarea.js.map +1 -0
- package/dist/components/forms/input/index.d.ts +3 -0
- package/dist/components/forms/input/index.d.ts.map +1 -0
- package/dist/components/forms/input/input.d.ts +71 -0
- package/dist/components/forms/input/input.d.ts.map +1 -0
- package/dist/components/forms/input/input.js +64 -0
- package/dist/components/forms/input/input.js.map +1 -0
- package/dist/components/forms/input-group/index.d.ts +3 -0
- package/dist/components/forms/input-group/index.d.ts.map +1 -0
- package/dist/components/forms/input-group/input-group.d.ts +43 -0
- package/dist/components/forms/input-group/input-group.d.ts.map +1 -0
- package/dist/components/forms/input-group/input-group.js +55 -0
- package/dist/components/forms/input-group/input-group.js.map +1 -0
- package/dist/components/forms/multi-select/index.d.ts +3 -0
- package/dist/components/forms/multi-select/index.d.ts.map +1 -0
- package/dist/components/forms/multi-select/multi-select.d.ts +75 -0
- package/dist/components/forms/multi-select/multi-select.d.ts.map +1 -0
- package/dist/components/forms/multi-select/multi-select.js +259 -0
- package/dist/components/forms/multi-select/multi-select.js.map +1 -0
- package/dist/components/forms/radio/index.d.ts +3 -0
- package/dist/components/forms/radio/index.d.ts.map +1 -0
- package/dist/components/forms/radio/radio.d.ts +31 -0
- package/dist/components/forms/radio/radio.d.ts.map +1 -0
- package/dist/components/forms/radio/radio.js +74 -0
- package/dist/components/forms/radio/radio.js.map +1 -0
- package/dist/components/forms/radio-group/index.d.ts +3 -0
- package/dist/components/forms/radio-group/index.d.ts.map +1 -0
- package/dist/components/forms/radio-group/radio-group.d.ts +32 -0
- package/dist/components/forms/radio-group/radio-group.d.ts.map +1 -0
- package/dist/components/forms/radio-group/radio-group.js +28 -0
- package/dist/components/forms/radio-group/radio-group.js.map +1 -0
- package/dist/components/forms/select/index.d.ts +5 -0
- package/dist/components/forms/select/index.d.ts.map +1 -0
- package/dist/components/forms/select/select-item.d.ts +16 -0
- package/dist/components/forms/select/select-item.d.ts.map +1 -0
- package/dist/components/forms/select/select-item.js +9 -0
- package/dist/components/forms/select/select-item.js.map +1 -0
- package/dist/components/forms/select/select.d.ts +52 -0
- package/dist/components/forms/select/select.d.ts.map +1 -0
- package/dist/components/forms/select/select.js +51 -0
- package/dist/components/forms/select/select.js.map +1 -0
- package/dist/components/forms/slider/index.d.ts +3 -0
- package/dist/components/forms/slider/index.d.ts.map +1 -0
- package/dist/components/forms/slider/slider.d.ts +21 -0
- package/dist/components/forms/slider/slider.d.ts.map +1 -0
- package/dist/components/forms/slider/slider.js +65 -0
- package/dist/components/forms/slider/slider.js.map +1 -0
- package/dist/components/forms/switch/index.d.ts +3 -0
- package/dist/components/forms/switch/index.d.ts.map +1 -0
- package/dist/components/forms/switch/switch.d.ts +30 -0
- package/dist/components/forms/switch/switch.d.ts.map +1 -0
- package/dist/components/forms/switch/switch.js +104 -0
- package/dist/components/forms/switch/switch.js.map +1 -0
- package/dist/components/forms/textarea/index.d.ts +3 -0
- package/dist/components/forms/textarea/index.d.ts.map +1 -0
- package/dist/components/forms/textarea/textarea.d.ts +54 -0
- package/dist/components/forms/textarea/textarea.d.ts.map +1 -0
- package/dist/components/forms/textarea/textarea.js +55 -0
- package/dist/components/forms/textarea/textarea.js.map +1 -0
- package/dist/components/index.d.ts +124 -0
- package/dist/components/index.d.ts.map +1 -0
- package/dist/components/layout/accordion/accordion.d.ts +30 -0
- package/dist/components/layout/accordion/accordion.d.ts.map +1 -0
- package/dist/components/layout/accordion/accordion.js +38 -0
- package/dist/components/layout/accordion/accordion.js.map +1 -0
- package/dist/components/layout/accordion/index.d.ts +3 -0
- package/dist/components/layout/accordion/index.d.ts.map +1 -0
- package/dist/components/layout/action-card/action-card.d.ts +37 -0
- package/dist/components/layout/action-card/action-card.d.ts.map +1 -0
- package/dist/components/layout/action-card/action-card.js +104 -0
- package/dist/components/layout/action-card/action-card.js.map +1 -0
- package/dist/components/layout/action-card/index.d.ts +3 -0
- package/dist/components/layout/action-card/index.d.ts.map +1 -0
- package/dist/components/layout/card/card-actions.d.ts +47 -0
- package/dist/components/layout/card/card-actions.d.ts.map +1 -0
- package/dist/components/layout/card/card-actions.js +30 -0
- package/dist/components/layout/card/card-actions.js.map +1 -0
- package/dist/components/layout/card/card-body.d.ts +26 -0
- package/dist/components/layout/card/card-body.d.ts.map +1 -0
- package/dist/components/layout/card/card-body.js +22 -0
- package/dist/components/layout/card/card-body.js.map +1 -0
- package/dist/components/layout/card/card-figure.d.ts +50 -0
- package/dist/components/layout/card/card-figure.d.ts.map +1 -0
- package/dist/components/layout/card/card-figure.js +27 -0
- package/dist/components/layout/card/card-figure.js.map +1 -0
- package/dist/components/layout/card/card-footer.d.ts +46 -0
- package/dist/components/layout/card/card-footer.d.ts.map +1 -0
- package/dist/components/layout/card/card-footer.js +39 -0
- package/dist/components/layout/card/card-footer.js.map +1 -0
- package/dist/components/layout/card/card-header.d.ts +41 -0
- package/dist/components/layout/card/card-header.d.ts.map +1 -0
- package/dist/components/layout/card/card-header.js +27 -0
- package/dist/components/layout/card/card-header.js.map +1 -0
- package/dist/components/layout/card/card-title.d.ts +43 -0
- package/dist/components/layout/card/card-title.d.ts.map +1 -0
- package/dist/components/layout/card/card-title.js +21 -0
- package/dist/components/layout/card/card-title.js.map +1 -0
- package/dist/components/layout/card/card.d.ts +74 -0
- package/dist/components/layout/card/card.d.ts.map +1 -0
- package/dist/components/layout/card/card.js +64 -0
- package/dist/components/layout/card/card.js.map +1 -0
- package/dist/components/layout/card/index.d.ts +15 -0
- package/dist/components/layout/card/index.d.ts.map +1 -0
- package/dist/components/layout/container/container.d.ts +33 -0
- package/dist/components/layout/container/container.d.ts.map +1 -0
- package/dist/components/layout/container/container.js +36 -0
- package/dist/components/layout/container/container.js.map +1 -0
- package/dist/components/layout/container/index.d.ts +3 -0
- package/dist/components/layout/container/index.d.ts.map +1 -0
- package/dist/components/layout/divider/divider.d.ts +15 -0
- package/dist/components/layout/divider/divider.d.ts.map +1 -0
- package/dist/components/layout/divider/divider.js +10 -0
- package/dist/components/layout/divider/divider.js.map +1 -0
- package/dist/components/layout/divider/index.d.ts +3 -0
- package/dist/components/layout/divider/index.d.ts.map +1 -0
- package/dist/components/layout/drawer/drawer.d.ts +35 -0
- package/dist/components/layout/drawer/drawer.d.ts.map +1 -0
- package/dist/components/layout/drawer/drawer.js +108 -0
- package/dist/components/layout/drawer/drawer.js.map +1 -0
- package/dist/components/layout/drawer/index.d.ts +3 -0
- package/dist/components/layout/drawer/index.d.ts.map +1 -0
- package/dist/components/layout/feature-section/feature-section.d.ts +36 -0
- package/dist/components/layout/feature-section/feature-section.d.ts.map +1 -0
- package/dist/components/layout/feature-section/feature-section.js +37 -0
- package/dist/components/layout/feature-section/feature-section.js.map +1 -0
- package/dist/components/layout/feature-section/index.d.ts +3 -0
- package/dist/components/layout/feature-section/index.d.ts.map +1 -0
- package/dist/components/layout/footer/footer.d.ts +37 -0
- package/dist/components/layout/footer/footer.d.ts.map +1 -0
- package/dist/components/layout/footer/footer.js +36 -0
- package/dist/components/layout/footer/footer.js.map +1 -0
- package/dist/components/layout/footer/index.d.ts +3 -0
- package/dist/components/layout/footer/index.d.ts.map +1 -0
- package/dist/components/layout/grid/grid.d.ts +66 -0
- package/dist/components/layout/grid/grid.d.ts.map +1 -0
- package/dist/components/layout/grid/grid.js +62 -0
- package/dist/components/layout/grid/grid.js.map +1 -0
- package/dist/components/layout/grid/index.d.ts +3 -0
- package/dist/components/layout/grid/index.d.ts.map +1 -0
- package/dist/components/layout/hero/hero.d.ts +61 -0
- package/dist/components/layout/hero/hero.d.ts.map +1 -0
- package/dist/components/layout/hero/hero.js +79 -0
- package/dist/components/layout/hero/hero.js.map +1 -0
- package/dist/components/layout/hero/index.d.ts +3 -0
- package/dist/components/layout/hero/index.d.ts.map +1 -0
- package/dist/components/layout/left-nav-layout/index.d.ts +7 -0
- package/dist/components/layout/left-nav-layout/index.d.ts.map +1 -0
- package/dist/components/layout/left-nav-layout/left-nav-item.d.ts +56 -0
- package/dist/components/layout/left-nav-layout/left-nav-item.d.ts.map +1 -0
- package/dist/components/layout/left-nav-layout/left-nav-item.js +105 -0
- package/dist/components/layout/left-nav-layout/left-nav-item.js.map +1 -0
- package/dist/components/layout/left-nav-layout/left-nav-layout.d.ts +67 -0
- package/dist/components/layout/left-nav-layout/left-nav-layout.d.ts.map +1 -0
- package/dist/components/layout/left-nav-layout/left-nav-layout.js +182 -0
- package/dist/components/layout/left-nav-layout/left-nav-layout.js.map +1 -0
- package/dist/components/layout/left-nav-layout/left-nav-section.d.ts +40 -0
- package/dist/components/layout/left-nav-layout/left-nav-section.d.ts.map +1 -0
- package/dist/components/layout/left-nav-layout/left-nav-section.js +119 -0
- package/dist/components/layout/left-nav-layout/left-nav-section.js.map +1 -0
- package/dist/components/layout/page/index.d.ts +3 -0
- package/dist/components/layout/page/index.d.ts.map +1 -0
- package/dist/components/layout/page/page.d.ts +17 -0
- package/dist/components/layout/page/page.d.ts.map +1 -0
- package/dist/components/layout/page/page.js +9 -0
- package/dist/components/layout/page/page.js.map +1 -0
- package/dist/components/layout/page-header/index.d.ts +3 -0
- package/dist/components/layout/page-header/index.d.ts.map +1 -0
- package/dist/components/layout/page-header/page-header.d.ts +21 -0
- package/dist/components/layout/page-header/page-header.d.ts.map +1 -0
- package/dist/components/layout/page-header/page-header.js +18 -0
- package/dist/components/layout/page-header/page-header.js.map +1 -0
- package/dist/components/layout/page-transition/index.d.ts +3 -0
- package/dist/components/layout/page-transition/index.d.ts.map +1 -0
- package/dist/components/layout/page-transition/page-transition.d.ts +52 -0
- package/dist/components/layout/page-transition/page-transition.d.ts.map +1 -0
- package/dist/components/layout/page-transition/page-transition.js +43 -0
- package/dist/components/layout/page-transition/page-transition.js.map +1 -0
- package/dist/components/layout/section/index.d.ts +3 -0
- package/dist/components/layout/section/index.d.ts.map +1 -0
- package/dist/components/layout/section/section.d.ts +35 -0
- package/dist/components/layout/section/section.d.ts.map +1 -0
- package/dist/components/layout/section/section.js +18 -0
- package/dist/components/layout/section/section.js.map +1 -0
- package/dist/components/layout/section-header/index.d.ts +3 -0
- package/dist/components/layout/section-header/index.d.ts.map +1 -0
- package/dist/components/layout/section-header/section-header.d.ts +23 -0
- package/dist/components/layout/section-header/section-header.d.ts.map +1 -0
- package/dist/components/layout/section-header/section-header.js +18 -0
- package/dist/components/layout/section-header/section-header.js.map +1 -0
- package/dist/components/layout/settings-page/index.d.ts +4 -0
- package/dist/components/layout/settings-page/index.d.ts.map +1 -0
- package/dist/components/layout/settings-page/setting-item.d.ts +52 -0
- package/dist/components/layout/settings-page/setting-item.d.ts.map +1 -0
- package/dist/components/layout/settings-page/setting-item.js +31 -0
- package/dist/components/layout/settings-page/setting-item.js.map +1 -0
- package/dist/components/layout/settings-page/settings-page.d.ts +37 -0
- package/dist/components/layout/settings-page/settings-page.d.ts.map +1 -0
- package/dist/components/layout/settings-page/settings-page.js +18 -0
- package/dist/components/layout/settings-page/settings-page.js.map +1 -0
- package/dist/components/layout/settings-page/settings-section.d.ts +35 -0
- package/dist/components/layout/settings-page/settings-section.d.ts.map +1 -0
- package/dist/components/layout/settings-page/settings-section.js +17 -0
- package/dist/components/layout/settings-page/settings-section.js.map +1 -0
- package/dist/components/layout/stack/index.d.ts +3 -0
- package/dist/components/layout/stack/index.d.ts.map +1 -0
- package/dist/components/layout/stack/stack.d.ts +33 -0
- package/dist/components/layout/stack/stack.d.ts.map +1 -0
- package/dist/components/layout/stack/stack.js +44 -0
- package/dist/components/layout/stack/stack.js.map +1 -0
- package/dist/components/navigation/breadcrumbs/breadcrumbs.d.ts +61 -0
- package/dist/components/navigation/breadcrumbs/breadcrumbs.d.ts.map +1 -0
- package/dist/components/navigation/breadcrumbs/breadcrumbs.js +30 -0
- package/dist/components/navigation/breadcrumbs/breadcrumbs.js.map +1 -0
- package/dist/components/navigation/breadcrumbs/index.d.ts +3 -0
- package/dist/components/navigation/breadcrumbs/index.d.ts.map +1 -0
- package/dist/components/navigation/dropdown/dropdown.d.ts +83 -0
- package/dist/components/navigation/dropdown/dropdown.d.ts.map +1 -0
- package/dist/components/navigation/dropdown/dropdown.js +295 -0
- package/dist/components/navigation/dropdown/dropdown.js.map +1 -0
- package/dist/components/navigation/dropdown/index.d.ts +5 -0
- package/dist/components/navigation/dropdown/index.d.ts.map +1 -0
- package/dist/components/navigation/nav/index.d.ts +3 -0
- package/dist/components/navigation/nav/index.d.ts.map +1 -0
- package/dist/components/navigation/nav/nav.d.ts +24 -0
- package/dist/components/navigation/nav/nav.d.ts.map +1 -0
- package/dist/components/navigation/nav/nav.js +32 -0
- package/dist/components/navigation/nav/nav.js.map +1 -0
- package/dist/components/navigation/nav-dropdown/index.d.ts +5 -0
- package/dist/components/navigation/nav-dropdown/index.d.ts.map +1 -0
- package/dist/components/navigation/nav-dropdown/nav-dropdown-item.d.ts +17 -0
- package/dist/components/navigation/nav-dropdown/nav-dropdown-item.d.ts.map +1 -0
- package/dist/components/navigation/nav-dropdown/nav-dropdown-item.js +17 -0
- package/dist/components/navigation/nav-dropdown/nav-dropdown-item.js.map +1 -0
- package/dist/components/navigation/nav-dropdown/nav-dropdown.d.ts +20 -0
- package/dist/components/navigation/nav-dropdown/nav-dropdown.d.ts.map +1 -0
- package/dist/components/navigation/nav-dropdown/nav-dropdown.js +24 -0
- package/dist/components/navigation/nav-dropdown/nav-dropdown.js.map +1 -0
- package/dist/components/navigation/navbar/index.d.ts +9 -0
- package/dist/components/navigation/navbar/index.d.ts.map +1 -0
- package/dist/components/navigation/navbar/navbar-brand.d.ts +23 -0
- package/dist/components/navigation/navbar/navbar-brand.d.ts.map +1 -0
- package/dist/components/navigation/navbar/navbar-brand.js +21 -0
- package/dist/components/navigation/navbar/navbar-brand.js.map +1 -0
- package/dist/components/navigation/navbar/navbar-link.d.ts +23 -0
- package/dist/components/navigation/navbar/navbar-link.d.ts.map +1 -0
- package/dist/components/navigation/navbar/navbar-link.js +34 -0
- package/dist/components/navigation/navbar/navbar-link.js.map +1 -0
- package/dist/components/navigation/navbar/navbar-toggle.d.ts +34 -0
- package/dist/components/navigation/navbar/navbar-toggle.d.ts.map +1 -0
- package/dist/components/navigation/navbar/navbar-toggle.js +37 -0
- package/dist/components/navigation/navbar/navbar-toggle.js.map +1 -0
- package/dist/components/navigation/navbar/navbar.d.ts +33 -0
- package/dist/components/navigation/navbar/navbar.d.ts.map +1 -0
- package/dist/components/navigation/navbar/navbar.js +40 -0
- package/dist/components/navigation/navbar/navbar.js.map +1 -0
- package/dist/components/navigation/notification-dropdown/index.d.ts +3 -0
- package/dist/components/navigation/notification-dropdown/index.d.ts.map +1 -0
- package/dist/components/navigation/notification-dropdown/notification-dropdown.d.ts +59 -0
- package/dist/components/navigation/notification-dropdown/notification-dropdown.d.ts.map +1 -0
- package/dist/components/navigation/notification-dropdown/notification-dropdown.js +456 -0
- package/dist/components/navigation/notification-dropdown/notification-dropdown.js.map +1 -0
- package/dist/components/navigation/pagination/index.d.ts +3 -0
- package/dist/components/navigation/pagination/index.d.ts.map +1 -0
- package/dist/components/navigation/pagination/pagination.d.ts +21 -0
- package/dist/components/navigation/pagination/pagination.d.ts.map +1 -0
- package/dist/components/navigation/pagination/pagination.js +72 -0
- package/dist/components/navigation/pagination/pagination.js.map +1 -0
- package/dist/components/navigation/scroll-nav/index.d.ts +3 -0
- package/dist/components/navigation/scroll-nav/index.d.ts.map +1 -0
- package/dist/components/navigation/scroll-nav/scroll-nav.d.ts +53 -0
- package/dist/components/navigation/scroll-nav/scroll-nav.d.ts.map +1 -0
- package/dist/components/navigation/scroll-nav/scroll-nav.js +188 -0
- package/dist/components/navigation/scroll-nav/scroll-nav.js.map +1 -0
- package/dist/components/navigation/sidebar/index.d.ts +3 -0
- package/dist/components/navigation/sidebar/index.d.ts.map +1 -0
- package/dist/components/navigation/sidebar/sidebar.d.ts +18 -0
- package/dist/components/navigation/sidebar/sidebar.d.ts.map +1 -0
- package/dist/components/navigation/sidebar/sidebar.js +41 -0
- package/dist/components/navigation/sidebar/sidebar.js.map +1 -0
- package/dist/components/navigation/stepper/index.d.ts +3 -0
- package/dist/components/navigation/stepper/index.d.ts.map +1 -0
- package/dist/components/navigation/stepper/stepper.d.ts +50 -0
- package/dist/components/navigation/stepper/stepper.d.ts.map +1 -0
- package/dist/components/navigation/stepper/stepper.js +159 -0
- package/dist/components/navigation/stepper/stepper.js.map +1 -0
- package/dist/components/navigation/tabs/index.d.ts +3 -0
- package/dist/components/navigation/tabs/index.d.ts.map +1 -0
- package/dist/components/navigation/tabs/tabs.d.ts +32 -0
- package/dist/components/navigation/tabs/tabs.d.ts.map +1 -0
- package/dist/components/navigation/tabs/tabs.js +61 -0
- package/dist/components/navigation/tabs/tabs.js.map +1 -0
- package/dist/components/system/auth-provider/auth-provider.d.ts +103 -0
- package/dist/components/system/auth-provider/auth-provider.d.ts.map +1 -0
- package/dist/components/system/auth-provider/auth-provider.js +118 -0
- package/dist/components/system/auth-provider/auth-provider.js.map +1 -0
- package/dist/components/system/auth-provider/auth-utils.d.ts +32 -0
- package/dist/components/system/auth-provider/auth-utils.d.ts.map +1 -0
- package/dist/components/system/auth-provider/auth-utils.js +83 -0
- package/dist/components/system/auth-provider/auth-utils.js.map +1 -0
- package/dist/components/system/auth-provider/index.d.ts +4 -0
- package/dist/components/system/auth-provider/index.d.ts.map +1 -0
- package/dist/components/system/color-mode-toggle/color-mode-toggle.d.ts +18 -0
- package/dist/components/system/color-mode-toggle/color-mode-toggle.d.ts.map +1 -0
- package/dist/components/system/color-mode-toggle/color-mode-toggle.js +27 -0
- package/dist/components/system/color-mode-toggle/color-mode-toggle.js.map +1 -0
- package/dist/components/system/color-mode-toggle/index.d.ts +3 -0
- package/dist/components/system/color-mode-toggle/index.d.ts.map +1 -0
- package/dist/components/system/error-boundary/error-boundary.d.ts +21 -0
- package/dist/components/system/error-boundary/error-boundary.d.ts.map +1 -0
- package/dist/components/system/icon/icon.d.ts +35 -0
- package/dist/components/system/icon/icon.d.ts.map +1 -0
- package/dist/components/system/icon/icon.js +83 -0
- package/dist/components/system/icon/icon.js.map +1 -0
- package/dist/components/system/icon/index.d.ts +3 -0
- package/dist/components/system/icon/index.d.ts.map +1 -0
- package/dist/components/system/theme-provider/index.d.ts +3 -0
- package/dist/components/system/theme-provider/index.d.ts.map +1 -0
- package/dist/components/system/theme-provider/theme-provider.d.ts +40 -0
- package/dist/components/system/theme-provider/theme-provider.d.ts.map +1 -0
- package/dist/components/system/theme-provider/theme-provider.js +55 -0
- package/dist/components/system/theme-provider/theme-provider.js.map +1 -0
- package/dist/components/typography/code/code.d.ts +24 -0
- package/dist/components/typography/code/code.d.ts.map +1 -0
- package/dist/components/typography/code/code.js +18 -0
- package/dist/components/typography/code/code.js.map +1 -0
- package/dist/components/typography/code/index.d.ts +3 -0
- package/dist/components/typography/code/index.d.ts.map +1 -0
- package/dist/components/typography/heading/heading.d.ts +32 -0
- package/dist/components/typography/heading/heading.d.ts.map +1 -0
- package/dist/components/typography/heading/heading.js +39 -0
- package/dist/components/typography/heading/heading.js.map +1 -0
- package/dist/components/typography/heading/index.d.ts +3 -0
- package/dist/components/typography/heading/index.d.ts.map +1 -0
- package/dist/components/typography/link/index.d.ts +3 -0
- package/dist/components/typography/link/index.d.ts.map +1 -0
- package/dist/components/typography/link/link.d.ts +44 -0
- package/dist/components/typography/link/link.d.ts.map +1 -0
- package/dist/components/typography/link/link.js +72 -0
- package/dist/components/typography/link/link.js.map +1 -0
- package/dist/components/typography/text/index.d.ts +3 -0
- package/dist/components/typography/text/index.d.ts.map +1 -0
- package/dist/components/typography/text/text.d.ts +104 -0
- package/dist/components/typography/text/text.d.ts.map +1 -0
- package/dist/components/typography/text/text.js +148 -0
- package/dist/components/typography/text/text.js.map +1 -0
- package/dist/components.d.ts +2 -0
- package/dist/components.d.ts.map +1 -0
- package/dist/hooks/useDebounce.d.ts +29 -0
- package/dist/hooks/useDebounce.d.ts.map +1 -0
- package/dist/hooks/useDebounce.js +26 -0
- package/dist/hooks/useDebounce.js.map +1 -0
- package/dist/hooks/useScrollReset.d.ts +11 -0
- package/dist/hooks/useScrollReset.d.ts.map +1 -0
- package/dist/hooks/useScrollReset.js +55 -0
- package/dist/hooks/useScrollReset.js.map +1 -0
- package/dist/humans.txt +8 -0
- package/dist/icons/logo.svg +9 -0
- package/dist/index.d.ts +7 -1170
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +287 -4333
- package/dist/index.js.map +1 -1
- package/dist/manifest.json +16 -0
- package/dist/node_modules/clsx/dist/clsx.js +18 -0
- package/dist/node_modules/clsx/dist/clsx.js.map +1 -0
- package/dist/robots.txt +5 -0
- package/dist/sitemap.xml +8 -0
- package/dist/staticwebapp.config.json +23 -0
- package/dist/style.css +2 -2
- package/dist/styles.d.ts +9 -0
- package/dist/theme/hydn-presets.d.ts +4 -0
- package/dist/theme/hydn-presets.d.ts.map +1 -0
- package/dist/theme/size-tokens.d.ts +686 -0
- package/dist/theme/size-tokens.d.ts.map +1 -0
- package/dist/theme/size-tokens.js +636 -0
- package/dist/theme/size-tokens.js.map +1 -0
- package/dist/theme/tokens.d.ts +116 -0
- package/dist/theme/tokens.d.ts.map +1 -0
- package/dist/theme/tokens.js +164 -0
- package/dist/theme/tokens.js.map +1 -0
- package/dist/utils/debounce.d.ts +7 -0
- package/dist/utils/debounce.d.ts.map +1 -0
- package/dist/utils/debounce.js +40 -0
- package/dist/utils/debounce.js.map +1 -0
- package/package.json +49 -43
- package/dist/index.cjs +0 -4425
- package/dist/index.cjs.map +0 -1
- package/dist/index.d.cts +0 -1170
|
@@ -0,0 +1,259 @@
|
|
|
1
|
+
import { jsxs, jsx, Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { useState, useRef, useEffect } from "react";
|
|
3
|
+
import { Icon } from "../../system/icon/icon.js";
|
|
4
|
+
import { getIconPixels, chipSizes, interactiveSizes } from "../../../theme/size-tokens.js";
|
|
5
|
+
function MultiSelect({
|
|
6
|
+
options,
|
|
7
|
+
value = [],
|
|
8
|
+
onChange,
|
|
9
|
+
placeholder = "Select options...",
|
|
10
|
+
noneFoundText = "No options found",
|
|
11
|
+
disabled = false,
|
|
12
|
+
maxSelections,
|
|
13
|
+
size = "md",
|
|
14
|
+
className = ""
|
|
15
|
+
}) {
|
|
16
|
+
const [isOpen, setIsOpen] = useState(false);
|
|
17
|
+
const [searchQuery, setSearchQuery] = useState("");
|
|
18
|
+
const [focusedIndex, setFocusedIndex] = useState(-1);
|
|
19
|
+
const containerRef = useRef(null);
|
|
20
|
+
const searchInputRef = useRef(null);
|
|
21
|
+
const selectedValues = value || [];
|
|
22
|
+
useEffect(() => {
|
|
23
|
+
const handleClickOutside = (event) => {
|
|
24
|
+
if (containerRef.current && !containerRef.current.contains(event.target)) {
|
|
25
|
+
setIsOpen(false);
|
|
26
|
+
setSearchQuery("");
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
if (isOpen) {
|
|
30
|
+
document.addEventListener("mousedown", handleClickOutside);
|
|
31
|
+
return () => document.removeEventListener("mousedown", handleClickOutside);
|
|
32
|
+
}
|
|
33
|
+
return void 0;
|
|
34
|
+
}, [isOpen]);
|
|
35
|
+
useEffect(() => {
|
|
36
|
+
if (isOpen && searchInputRef.current) {
|
|
37
|
+
searchInputRef.current.focus();
|
|
38
|
+
}
|
|
39
|
+
}, [isOpen]);
|
|
40
|
+
const filteredOptions = options.filter((option) => option.label.toLowerCase().includes(searchQuery.toLowerCase()));
|
|
41
|
+
const handleToggleOption = (optionValue) => {
|
|
42
|
+
const isSelected = selectedValues.includes(optionValue);
|
|
43
|
+
let newValues;
|
|
44
|
+
if (isSelected) {
|
|
45
|
+
newValues = selectedValues.filter((v) => v !== optionValue);
|
|
46
|
+
} else {
|
|
47
|
+
if (maxSelections && selectedValues.length >= maxSelections) {
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
newValues = [...selectedValues, optionValue];
|
|
51
|
+
}
|
|
52
|
+
onChange?.(newValues);
|
|
53
|
+
};
|
|
54
|
+
const handleRemoveValue = (valueToRemove, e) => {
|
|
55
|
+
e.stopPropagation();
|
|
56
|
+
const newValues = selectedValues.filter((v) => v !== valueToRemove);
|
|
57
|
+
onChange?.(newValues);
|
|
58
|
+
};
|
|
59
|
+
const handleClearAll = (e) => {
|
|
60
|
+
e.stopPropagation();
|
|
61
|
+
onChange?.([]);
|
|
62
|
+
};
|
|
63
|
+
const handleKeyDown = (e) => {
|
|
64
|
+
if (disabled) return;
|
|
65
|
+
switch (e.key) {
|
|
66
|
+
case "Enter":
|
|
67
|
+
e.preventDefault();
|
|
68
|
+
if (!isOpen) {
|
|
69
|
+
setIsOpen(true);
|
|
70
|
+
} else if (focusedIndex >= 0 && focusedIndex < filteredOptions.length) {
|
|
71
|
+
handleToggleOption(filteredOptions[focusedIndex].value);
|
|
72
|
+
}
|
|
73
|
+
break;
|
|
74
|
+
case "Escape":
|
|
75
|
+
e.preventDefault();
|
|
76
|
+
setIsOpen(false);
|
|
77
|
+
setSearchQuery("");
|
|
78
|
+
break;
|
|
79
|
+
case "ArrowDown":
|
|
80
|
+
e.preventDefault();
|
|
81
|
+
if (!isOpen) {
|
|
82
|
+
setIsOpen(true);
|
|
83
|
+
} else {
|
|
84
|
+
setFocusedIndex((prev) => prev < filteredOptions.length - 1 ? prev + 1 : prev);
|
|
85
|
+
}
|
|
86
|
+
break;
|
|
87
|
+
case "ArrowUp":
|
|
88
|
+
e.preventDefault();
|
|
89
|
+
setFocusedIndex((prev) => prev > 0 ? prev - 1 : 0);
|
|
90
|
+
break;
|
|
91
|
+
}
|
|
92
|
+
};
|
|
93
|
+
const sizeClasses = {
|
|
94
|
+
xs: {
|
|
95
|
+
container: interactiveSizes.xs.height.split(" ")[0].replace("h-", "min-h-") + " py-0.5 px-1.5",
|
|
96
|
+
text: interactiveSizes.xs.text,
|
|
97
|
+
chip: chipSizes.sm.classes.split(" ").filter((c) => !c.includes("gap")).join(" "),
|
|
98
|
+
icon: getIconPixels("xs", "desktop")
|
|
99
|
+
},
|
|
100
|
+
sm: {
|
|
101
|
+
container: interactiveSizes.sm.height.split(" ")[0].replace("h-", "min-h-") + " py-1 px-2",
|
|
102
|
+
text: interactiveSizes.sm.text,
|
|
103
|
+
chip: chipSizes.sm.classes.split(" ").filter((c) => !c.includes("gap")).join(" "),
|
|
104
|
+
icon: getIconPixels("sm", "desktop")
|
|
105
|
+
},
|
|
106
|
+
md: {
|
|
107
|
+
container: interactiveSizes.md.height.split(" ")[0].replace("h-", "min-h-") + " py-2 px-3",
|
|
108
|
+
text: interactiveSizes.md.text,
|
|
109
|
+
chip: chipSizes.md.classes.split(" ").filter((c) => !c.includes("gap")).join(" "),
|
|
110
|
+
icon: getIconPixels("md", "desktop")
|
|
111
|
+
},
|
|
112
|
+
lg: {
|
|
113
|
+
container: interactiveSizes.lg.height.split(" ")[0].replace("h-", "min-h-") + " py-2 px-4",
|
|
114
|
+
text: interactiveSizes.lg.text,
|
|
115
|
+
chip: chipSizes.lg.classes.split(" ").filter((c) => !c.includes("gap")).join(" "),
|
|
116
|
+
icon: getIconPixels("lg", "desktop")
|
|
117
|
+
},
|
|
118
|
+
xl: {
|
|
119
|
+
container: interactiveSizes.xl.height.split(" ")[0].replace("h-", "min-h-") + " py-2.5 px-5",
|
|
120
|
+
text: interactiveSizes.xl.text,
|
|
121
|
+
chip: chipSizes.lg.classes.split(" ").filter((c) => !c.includes("gap")).join(" "),
|
|
122
|
+
icon: getIconPixels("xl", "desktop")
|
|
123
|
+
}
|
|
124
|
+
};
|
|
125
|
+
const currentSize = sizeClasses[size];
|
|
126
|
+
const getSelectedLabels = () => {
|
|
127
|
+
return selectedValues.map((v) => options.find((opt) => opt.value === v)?.label).filter(Boolean);
|
|
128
|
+
};
|
|
129
|
+
return /* @__PURE__ */ jsxs("div", { ref: containerRef, className: `relative w-full ${className}`, children: [
|
|
130
|
+
/* @__PURE__ */ jsxs(
|
|
131
|
+
"div",
|
|
132
|
+
{
|
|
133
|
+
className: `
|
|
134
|
+
w-full flex flex-wrap items-center gap-1.5
|
|
135
|
+
border border-input rounded-md
|
|
136
|
+
bg-background text-foreground
|
|
137
|
+
cursor-pointer
|
|
138
|
+
transition-all duration-200
|
|
139
|
+
${currentSize.container}
|
|
140
|
+
${currentSize.text}
|
|
141
|
+
${isOpen ? "ring-2 ring-ring ring-offset-2" : "hover:border-ring"}
|
|
142
|
+
${disabled ? "opacity-50 cursor-not-allowed" : ""}
|
|
143
|
+
`.trim(),
|
|
144
|
+
onClick: () => !disabled && setIsOpen(!isOpen),
|
|
145
|
+
onKeyDown: handleKeyDown,
|
|
146
|
+
tabIndex: disabled ? -1 : 0,
|
|
147
|
+
role: "button",
|
|
148
|
+
"aria-haspopup": "listbox",
|
|
149
|
+
"aria-expanded": isOpen,
|
|
150
|
+
"aria-label": "Multi-select",
|
|
151
|
+
children: [
|
|
152
|
+
selectedValues.length > 0 ? /* @__PURE__ */ jsx(Fragment, { children: getSelectedLabels().map((label, index) => /* @__PURE__ */ jsxs(
|
|
153
|
+
"span",
|
|
154
|
+
{
|
|
155
|
+
className: `
|
|
156
|
+
inline-flex items-center gap-1
|
|
157
|
+
bg-primary/10 text-primary rounded-md font-medium
|
|
158
|
+
animate-scaleIn origin-left
|
|
159
|
+
transition-all duration-200
|
|
160
|
+
${currentSize.chip}
|
|
161
|
+
`.trim(),
|
|
162
|
+
children: [
|
|
163
|
+
label,
|
|
164
|
+
/* @__PURE__ */ jsx(
|
|
165
|
+
"button",
|
|
166
|
+
{
|
|
167
|
+
type: "button",
|
|
168
|
+
onClick: (e) => handleRemoveValue(selectedValues[index], e),
|
|
169
|
+
className: "hover:bg-primary/20 rounded-sm transition-colors duration-150",
|
|
170
|
+
"aria-label": `Remove ${label}`,
|
|
171
|
+
tabIndex: -1,
|
|
172
|
+
children: /* @__PURE__ */ jsx(Icon, { name: "x", size })
|
|
173
|
+
}
|
|
174
|
+
)
|
|
175
|
+
]
|
|
176
|
+
},
|
|
177
|
+
selectedValues[index]
|
|
178
|
+
)) }) : /* @__PURE__ */ jsx("span", { className: "text-muted-foreground", children: placeholder }),
|
|
179
|
+
/* @__PURE__ */ jsxs("div", { className: "flex items-center gap-1 ml-auto shrink-0", children: [
|
|
180
|
+
selectedValues.length > 0 && !disabled && /* @__PURE__ */ jsx(
|
|
181
|
+
"button",
|
|
182
|
+
{
|
|
183
|
+
type: "button",
|
|
184
|
+
onClick: handleClearAll,
|
|
185
|
+
className: "p-1 hover:bg-muted rounded transition-colors",
|
|
186
|
+
"aria-label": "Clear all",
|
|
187
|
+
tabIndex: -1,
|
|
188
|
+
children: /* @__PURE__ */ jsx(Icon, { name: "x", size })
|
|
189
|
+
}
|
|
190
|
+
),
|
|
191
|
+
/* @__PURE__ */ jsx(
|
|
192
|
+
Icon,
|
|
193
|
+
{
|
|
194
|
+
name: "chevron-down",
|
|
195
|
+
size,
|
|
196
|
+
className: `text-muted-foreground transition-transform ${isOpen ? "rotate-180" : ""}`
|
|
197
|
+
}
|
|
198
|
+
)
|
|
199
|
+
] })
|
|
200
|
+
]
|
|
201
|
+
}
|
|
202
|
+
),
|
|
203
|
+
isOpen && !disabled && /* @__PURE__ */ jsxs("div", { className: "absolute top-full left-0 right-0 mt-2 z-50 bg-card border border-border rounded-md shadow-lg max-h-64 overflow-hidden flex flex-col animate-scaleIn origin-top", children: [
|
|
204
|
+
/* @__PURE__ */ jsx("div", { className: "p-2 border-b border-border", children: /* @__PURE__ */ jsx(
|
|
205
|
+
"input",
|
|
206
|
+
{
|
|
207
|
+
ref: searchInputRef,
|
|
208
|
+
type: "text",
|
|
209
|
+
value: searchQuery,
|
|
210
|
+
onChange: (e) => {
|
|
211
|
+
setSearchQuery(e.target.value);
|
|
212
|
+
setFocusedIndex(-1);
|
|
213
|
+
},
|
|
214
|
+
placeholder: "Search...",
|
|
215
|
+
className: `w-full px-3 py-1.5 ${currentSize.text} border border-input rounded-md bg-background text-foreground placeholder:text-muted-foreground focus:outline-none focus:ring-2 focus:ring-ring`,
|
|
216
|
+
onClick: (e) => e.stopPropagation()
|
|
217
|
+
}
|
|
218
|
+
) }),
|
|
219
|
+
/* @__PURE__ */ jsx("div", { className: "overflow-y-auto", role: "listbox", children: filteredOptions.length > 0 ? filteredOptions.map((option, index) => {
|
|
220
|
+
const isSelected = selectedValues.includes(option.value);
|
|
221
|
+
const isFocused = index === focusedIndex;
|
|
222
|
+
const isDisabled = Boolean(maxSelections && !isSelected && selectedValues.length >= maxSelections);
|
|
223
|
+
return /* @__PURE__ */ jsxs(
|
|
224
|
+
"button",
|
|
225
|
+
{
|
|
226
|
+
type: "button",
|
|
227
|
+
onClick: () => !isDisabled && handleToggleOption(option.value),
|
|
228
|
+
className: `
|
|
229
|
+
w-full px-3 py-2 flex items-center justify-between gap-2
|
|
230
|
+
transition-all duration-200 text-left ${currentSize.text}
|
|
231
|
+
${isFocused ? "bg-muted" : ""}
|
|
232
|
+
${isSelected ? "bg-primary/10 text-primary font-medium" : "hover:bg-muted"}
|
|
233
|
+
${isDisabled ? "opacity-50 cursor-not-allowed" : ""}
|
|
234
|
+
`.trim(),
|
|
235
|
+
role: "option",
|
|
236
|
+
"aria-selected": isSelected,
|
|
237
|
+
disabled: isDisabled,
|
|
238
|
+
children: [
|
|
239
|
+
/* @__PURE__ */ jsx("span", { className: "flex-1 truncate", children: option.label }),
|
|
240
|
+
isSelected && /* @__PURE__ */ jsx(Icon, { name: "check", size, className: "shrink-0 animate-scaleIn" })
|
|
241
|
+
]
|
|
242
|
+
},
|
|
243
|
+
option.value
|
|
244
|
+
);
|
|
245
|
+
}) : /* @__PURE__ */ jsx("div", { className: "px-3 py-6 text-center text-muted-foreground", children: noneFoundText }) }),
|
|
246
|
+
maxSelections && /* @__PURE__ */ jsxs("div", { className: "px-3 py-2 border-t border-border bg-muted/30 text-xs text-muted-foreground", children: [
|
|
247
|
+
selectedValues.length,
|
|
248
|
+
" / ",
|
|
249
|
+
maxSelections,
|
|
250
|
+
" selected"
|
|
251
|
+
] })
|
|
252
|
+
] })
|
|
253
|
+
] });
|
|
254
|
+
}
|
|
255
|
+
MultiSelect.displayName = "MultiSelect";
|
|
256
|
+
export {
|
|
257
|
+
MultiSelect as default
|
|
258
|
+
};
|
|
259
|
+
//# sourceMappingURL=multi-select.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"multi-select.js","sources":["../../../../src/components/forms/multi-select/multi-select.tsx"],"sourcesContent":["import { useState, useRef, useEffect } from 'react';\nimport Icon from '../../system/icon/icon';\nimport { interactiveSizes, chipSizes, getIconPixels, type InteractiveSize } from '../../../theme/size-tokens';\n\nexport type MultiSelectOption = {\n value: string;\n label: string;\n};\n\nexport type MultiSelectProps = {\n /**\n * Available options to select from\n */\n options: MultiSelectOption[];\n /**\n * Currently selected values\n */\n value?: string[];\n /**\n * Callback when selection changes\n */\n onChange?: (values: string[]) => void;\n /**\n * Placeholder text when no selection\n */\n placeholder?: string;\n /**\n * Disabled state\n */\n disabled?: boolean;\n /**\n * Maximum number of selections allowed\n */\n maxSelections?: number;\n /**\n * Size variant - uses unified size system\n */\n size?: InteractiveSize;\n /**\n * Additional CSS classes\n */\n className?: string;\n /**\n * Text to display when no options are found\n */\n noneFoundText?: string;\n};\n\n/**\n * MultiSelect - Select multiple options from a dropdown list\n *\n * Features:\n * - Multiple selections with chips\n * - Searchable dropdown\n * - Keyboard navigation\n * - Max selections limit\n * - Clearable\n * - Accessible\n *\n * @example\n * ```tsx\n * const [selected, setSelected] = useState<string[]>([]);\n *\n * <MultiSelect\n * options={[\n * { value: '1', label: 'Option 1' },\n * { value: '2', label: 'Option 2' }\n * ]}\n * value={selected}\n * onChange={setSelected}\n * placeholder=\"Select options...\"\n * />\n * ```\n */\nfunction MultiSelect({\n options,\n value = [],\n onChange,\n placeholder = 'Select options...',\n noneFoundText = 'No options found',\n disabled = false,\n maxSelections,\n size = 'md',\n className = ''\n}: Readonly<MultiSelectProps>) {\n const [isOpen, setIsOpen] = useState(false);\n const [searchQuery, setSearchQuery] = useState('');\n const [focusedIndex, setFocusedIndex] = useState(-1);\n const containerRef = useRef<HTMLDivElement>(null);\n const searchInputRef = useRef<HTMLInputElement>(null);\n\n const selectedValues = value || [];\n\n // Close on click outside\n useEffect(() => {\n const handleClickOutside = (event: MouseEvent) => {\n if (containerRef.current && !containerRef.current.contains(event.target as Node)) {\n setIsOpen(false);\n setSearchQuery('');\n }\n };\n\n if (isOpen) {\n document.addEventListener('mousedown', handleClickOutside);\n return () => document.removeEventListener('mousedown', handleClickOutside);\n }\n return undefined;\n }, [isOpen]);\n\n // Focus search input when opened\n useEffect(() => {\n if (isOpen && searchInputRef.current) {\n searchInputRef.current.focus();\n }\n }, [isOpen]);\n\n const filteredOptions = options.filter((option) => option.label.toLowerCase().includes(searchQuery.toLowerCase()));\n\n const handleToggleOption = (optionValue: string) => {\n const isSelected = selectedValues.includes(optionValue);\n let newValues: string[];\n\n if (isSelected) {\n newValues = selectedValues.filter((v) => v !== optionValue);\n } else {\n if (maxSelections && selectedValues.length >= maxSelections) {\n return; // Don't add if max reached\n }\n newValues = [...selectedValues, optionValue];\n }\n\n onChange?.(newValues);\n };\n\n const handleRemoveValue = (valueToRemove: string, e: React.MouseEvent) => {\n e.stopPropagation();\n const newValues = selectedValues.filter((v) => v !== valueToRemove);\n onChange?.(newValues);\n };\n\n const handleClearAll = (e: React.MouseEvent) => {\n e.stopPropagation();\n onChange?.([]);\n };\n\n const handleKeyDown = (e: React.KeyboardEvent) => {\n if (disabled) return;\n\n switch (e.key) {\n case 'Enter':\n e.preventDefault();\n if (!isOpen) {\n setIsOpen(true);\n } else if (focusedIndex >= 0 && focusedIndex < filteredOptions.length) {\n handleToggleOption(filteredOptions[focusedIndex].value);\n }\n break;\n case 'Escape':\n e.preventDefault();\n setIsOpen(false);\n setSearchQuery('');\n break;\n case 'ArrowDown':\n e.preventDefault();\n if (!isOpen) {\n setIsOpen(true);\n } else {\n setFocusedIndex((prev) => (prev < filteredOptions.length - 1 ? prev + 1 : prev));\n }\n break;\n case 'ArrowUp':\n e.preventDefault();\n setFocusedIndex((prev) => (prev > 0 ? prev - 1 : 0));\n break;\n }\n };\n\n const sizeClasses = {\n xs: {\n container: interactiveSizes.xs.height.split(' ')[0].replace('h-', 'min-h-') + ' py-0.5 px-1.5',\n text: interactiveSizes.xs.text,\n chip: chipSizes.sm.classes\n .split(' ')\n .filter((c) => !c.includes('gap'))\n .join(' '),\n icon: getIconPixels('xs', 'desktop')\n },\n sm: {\n container: interactiveSizes.sm.height.split(' ')[0].replace('h-', 'min-h-') + ' py-1 px-2',\n text: interactiveSizes.sm.text,\n chip: chipSizes.sm.classes\n .split(' ')\n .filter((c) => !c.includes('gap'))\n .join(' '),\n icon: getIconPixels('sm', 'desktop')\n },\n md: {\n container: interactiveSizes.md.height.split(' ')[0].replace('h-', 'min-h-') + ' py-2 px-3',\n text: interactiveSizes.md.text,\n chip: chipSizes.md.classes\n .split(' ')\n .filter((c) => !c.includes('gap'))\n .join(' '),\n icon: getIconPixels('md', 'desktop')\n },\n lg: {\n container: interactiveSizes.lg.height.split(' ')[0].replace('h-', 'min-h-') + ' py-2 px-4',\n text: interactiveSizes.lg.text,\n chip: chipSizes.lg.classes\n .split(' ')\n .filter((c) => !c.includes('gap'))\n .join(' '),\n icon: getIconPixels('lg', 'desktop')\n },\n xl: {\n container: interactiveSizes.xl.height.split(' ')[0].replace('h-', 'min-h-') + ' py-2.5 px-5',\n text: interactiveSizes.xl.text,\n chip: chipSizes.lg.classes\n .split(' ')\n .filter((c) => !c.includes('gap'))\n .join(' '),\n icon: getIconPixels('xl', 'desktop')\n }\n };\n\n const currentSize = sizeClasses[size];\n\n const getSelectedLabels = () => {\n return selectedValues.map((v) => options.find((opt) => opt.value === v)?.label).filter(Boolean);\n };\n\n return (\n <div ref={containerRef} className={`relative w-full ${className}`}>\n {/* Trigger */}\n <div\n className={`\n w-full flex flex-wrap items-center gap-1.5\n border border-input rounded-md\n bg-background text-foreground\n cursor-pointer\n transition-all duration-200\n ${currentSize.container}\n ${currentSize.text}\n ${isOpen ? 'ring-2 ring-ring ring-offset-2' : 'hover:border-ring'}\n ${disabled ? 'opacity-50 cursor-not-allowed' : ''}\n `.trim()}\n onClick={() => !disabled && setIsOpen(!isOpen)}\n onKeyDown={handleKeyDown}\n tabIndex={disabled ? -1 : 0}\n role=\"button\"\n aria-haspopup=\"listbox\"\n aria-expanded={isOpen}\n aria-label=\"Multi-select\"\n >\n {/* Selected items as chips */}\n {selectedValues.length > 0 ? (\n <>\n {getSelectedLabels().map((label, index) => (\n <span\n key={selectedValues[index]}\n className={`\n inline-flex items-center gap-1 \n bg-primary/10 text-primary rounded-md font-medium \n animate-scaleIn origin-left\n transition-all duration-200\n ${currentSize.chip}\n `.trim()}\n >\n {label}\n <button\n type=\"button\"\n onClick={(e) => handleRemoveValue(selectedValues[index], e)}\n className=\"hover:bg-primary/20 rounded-sm transition-colors duration-150\"\n aria-label={`Remove ${label}`}\n tabIndex={-1}\n >\n <Icon name=\"x\" size={size} />\n </button>\n </span>\n ))}\n </>\n ) : (\n <span className=\"text-muted-foreground\">{placeholder}</span>\n )}\n\n {/* Right side icons */}\n <div className=\"flex items-center gap-1 ml-auto shrink-0\">\n {selectedValues.length > 0 && !disabled && (\n <button\n type=\"button\"\n onClick={handleClearAll}\n className=\"p-1 hover:bg-muted rounded transition-colors\"\n aria-label=\"Clear all\"\n tabIndex={-1}\n >\n <Icon name=\"x\" size={size} />\n </button>\n )}\n <Icon\n name=\"chevron-down\"\n size={size}\n className={`text-muted-foreground transition-transform ${isOpen ? 'rotate-180' : ''}`}\n />\n </div>\n </div>\n\n {/* Dropdown */}\n {isOpen && !disabled && (\n <div className=\"absolute top-full left-0 right-0 mt-2 z-50 bg-card border border-border rounded-md shadow-lg max-h-64 overflow-hidden flex flex-col animate-scaleIn origin-top\">\n {/* Search input */}\n <div className=\"p-2 border-b border-border\">\n <input\n ref={searchInputRef}\n type=\"text\"\n value={searchQuery}\n onChange={(e) => {\n setSearchQuery(e.target.value);\n setFocusedIndex(-1);\n }}\n placeholder=\"Search...\"\n className={`w-full px-3 py-1.5 ${currentSize.text} border border-input rounded-md bg-background text-foreground placeholder:text-muted-foreground focus:outline-none focus:ring-2 focus:ring-ring`}\n onClick={(e) => e.stopPropagation()}\n />\n </div>\n\n {/* Options list */}\n <div className=\"overflow-y-auto\" role=\"listbox\">\n {filteredOptions.length > 0 ? (\n filteredOptions.map((option, index) => {\n const isSelected = selectedValues.includes(option.value);\n const isFocused = index === focusedIndex;\n const isDisabled = Boolean(maxSelections && !isSelected && selectedValues.length >= maxSelections);\n\n return (\n <button\n key={option.value}\n type=\"button\"\n onClick={() => !isDisabled && handleToggleOption(option.value)}\n className={`\n w-full px-3 py-2 flex items-center justify-between gap-2\n transition-all duration-200 text-left ${currentSize.text}\n ${isFocused ? 'bg-muted' : ''}\n ${isSelected ? 'bg-primary/10 text-primary font-medium' : 'hover:bg-muted'}\n ${isDisabled ? 'opacity-50 cursor-not-allowed' : ''}\n `.trim()}\n role=\"option\"\n aria-selected={isSelected}\n disabled={isDisabled}\n >\n <span className=\"flex-1 truncate\">{option.label}</span>\n {isSelected && <Icon name=\"check\" size={size} className=\"shrink-0 animate-scaleIn\" />}\n </button>\n );\n })\n ) : (\n <div className=\"px-3 py-6 text-center text-muted-foreground\">{noneFoundText}</div>\n )}\n </div>\n\n {/* Footer info */}\n {maxSelections && (\n <div className=\"px-3 py-2 border-t border-border bg-muted/30 text-xs text-muted-foreground\">\n {selectedValues.length} / {maxSelections} selected\n </div>\n )}\n </div>\n )}\n </div>\n );\n}\n\nMultiSelect.displayName = 'MultiSelect';\n\nexport default MultiSelect;\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/forms/radio/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,YAAY,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { default as React } from 'react';
|
|
2
|
+
export type ValidationState = 'default' | 'error' | 'success' | 'warning';
|
|
3
|
+
export type RadioProps = {
|
|
4
|
+
/** Controlled checked state - overridden by RadioGroup context if present */
|
|
5
|
+
checked?: boolean;
|
|
6
|
+
/** Change event handler - called in addition to RadioGroup onChange if both are provided */
|
|
7
|
+
onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;
|
|
8
|
+
/** Disables radio interaction and applies disabled styling */
|
|
9
|
+
disabled?: boolean;
|
|
10
|
+
/** Additional CSS classes applied to the radio button indicator */
|
|
11
|
+
className?: string;
|
|
12
|
+
/** Accessible label for screen readers when visual label is not present */
|
|
13
|
+
ariaLabel?: string;
|
|
14
|
+
/** HTML id attribute - auto-generated if not provided */
|
|
15
|
+
id?: string;
|
|
16
|
+
/** Form input name - overridden by RadioGroup context if present */
|
|
17
|
+
name?: string;
|
|
18
|
+
/** Input value submitted with form - required when used in RadioGroup */
|
|
19
|
+
value?: string;
|
|
20
|
+
/** Visual validation state affecting border and ring colors */
|
|
21
|
+
validationState?: ValidationState;
|
|
22
|
+
};
|
|
23
|
+
/**
|
|
24
|
+
* Accessible Radio component
|
|
25
|
+
*/
|
|
26
|
+
declare function Radio({ checked, onChange, disabled, className, ariaLabel, id, name: nameProp, value, validationState }: Readonly<RadioProps>): import("react/jsx-runtime").JSX.Element;
|
|
27
|
+
declare namespace Radio {
|
|
28
|
+
var displayName: string;
|
|
29
|
+
}
|
|
30
|
+
export default Radio;
|
|
31
|
+
//# sourceMappingURL=radio.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"radio.d.ts","sourceRoot":"","sources":["../../../../src/components/forms/radio/radio.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAgB,MAAM,OAAO,CAAC;AAGrC,MAAM,MAAM,eAAe,GAAG,SAAS,GAAG,OAAO,GAAG,SAAS,GAAG,SAAS,CAAC;AAE1E,MAAM,MAAM,UAAU,GAAG;IACvB,6EAA6E;IAC7E,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,4FAA4F;IAC5F,QAAQ,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,CAAC,WAAW,CAAC,gBAAgB,CAAC,KAAK,IAAI,CAAC;IAC5D,8DAA8D;IAC9D,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,mEAAmE;IACnE,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,2EAA2E;IAC3E,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,yDAAyD;IACzD,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,oEAAoE;IACpE,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,yEAAyE;IACzE,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,+DAA+D;IAC/D,eAAe,CAAC,EAAE,eAAe,CAAC;CACnC,CAAC;AAEF;;GAEG;AACH,iBAAS,KAAK,CAAC,EACb,OAAO,EACP,QAAQ,EACR,QAAgB,EAChB,SAAc,EACd,SAAS,EACT,EAAE,EACF,IAAI,EAAE,QAAQ,EACd,KAAK,EACL,eAA2B,EAC5B,EAAE,QAAQ,CAAC,UAAU,CAAC,2CAwDtB;kBAlEQ,KAAK;;;AAsEd,eAAe,KAAK,CAAC"}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { jsxs, jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useId } from "react";
|
|
3
|
+
import { useRadioGroup } from "../radio-group/radio-group.js";
|
|
4
|
+
function Radio({
|
|
5
|
+
checked,
|
|
6
|
+
onChange,
|
|
7
|
+
disabled = false,
|
|
8
|
+
className = "",
|
|
9
|
+
ariaLabel,
|
|
10
|
+
id,
|
|
11
|
+
name: nameProp,
|
|
12
|
+
value,
|
|
13
|
+
validationState = "default"
|
|
14
|
+
}) {
|
|
15
|
+
const radioGroup = useRadioGroup();
|
|
16
|
+
const name = radioGroup?.name || nameProp;
|
|
17
|
+
const isChecked = radioGroup?.value !== void 0 ? radioGroup.value === value : checked;
|
|
18
|
+
const handleChange = (e) => {
|
|
19
|
+
if (radioGroup?.onChange && value) {
|
|
20
|
+
radioGroup.onChange(value);
|
|
21
|
+
}
|
|
22
|
+
onChange?.(e);
|
|
23
|
+
};
|
|
24
|
+
const validationClasses = {
|
|
25
|
+
default: "border-input focus:ring-ring",
|
|
26
|
+
error: "border-error focus:ring-error",
|
|
27
|
+
success: "border-success focus:ring-success",
|
|
28
|
+
warning: "border-warning focus:ring-warning"
|
|
29
|
+
};
|
|
30
|
+
const generatedId = useId();
|
|
31
|
+
const inputId = id || `radio-${value || generatedId}`;
|
|
32
|
+
return /* @__PURE__ */ jsxs(
|
|
33
|
+
"div",
|
|
34
|
+
{
|
|
35
|
+
className: `inline-flex items-center justify-center relative ${disabled ? "opacity-60 cursor-not-allowed" : "cursor-pointer"}`,
|
|
36
|
+
children: [
|
|
37
|
+
/* @__PURE__ */ jsx(
|
|
38
|
+
"input",
|
|
39
|
+
{
|
|
40
|
+
type: "radio",
|
|
41
|
+
checked: isChecked,
|
|
42
|
+
onChange: handleChange,
|
|
43
|
+
disabled,
|
|
44
|
+
"aria-label": ariaLabel,
|
|
45
|
+
"aria-invalid": validationState === "error" ? "true" : void 0,
|
|
46
|
+
id: inputId,
|
|
47
|
+
name,
|
|
48
|
+
value,
|
|
49
|
+
className: "peer sr-only"
|
|
50
|
+
}
|
|
51
|
+
),
|
|
52
|
+
/* @__PURE__ */ jsx(
|
|
53
|
+
"span",
|
|
54
|
+
{
|
|
55
|
+
"aria-hidden": "true",
|
|
56
|
+
onClick: () => !disabled && document.getElementById(inputId)?.click(),
|
|
57
|
+
className: `w-6 h-6 sm:w-5 sm:h-5 rounded-full border-2 flex items-center justify-center transition-all duration-200 ease-out bg-background shadow-sm
|
|
58
|
+
before:content-[''] before:w-3 before:h-3 sm:before:w-2.5 sm:before:h-2.5 before:rounded-full before:scale-0 before:transition-transform before:duration-200 before:ease-out before:bg-primary
|
|
59
|
+
peer-checked:before:scale-100 peer-checked:border-primary
|
|
60
|
+
peer-focus-visible:ring-2 peer-focus-visible:ring-offset-2 peer-focus-visible:ring-ring
|
|
61
|
+
peer-disabled:opacity-50 peer-disabled:cursor-not-allowed
|
|
62
|
+
peer-hover:border-primary/60 peer-active:scale-95
|
|
63
|
+
${validationClasses[validationState]} ${className}`
|
|
64
|
+
}
|
|
65
|
+
)
|
|
66
|
+
]
|
|
67
|
+
}
|
|
68
|
+
);
|
|
69
|
+
}
|
|
70
|
+
Radio.displayName = "Radio";
|
|
71
|
+
export {
|
|
72
|
+
Radio as default
|
|
73
|
+
};
|
|
74
|
+
//# sourceMappingURL=radio.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"radio.js","sources":["../../../../src/components/forms/radio/radio.tsx"],"sourcesContent":["import React, { useId } from 'react';\nimport { useRadioGroup } from '../radio-group/radio-group';\n\nexport type ValidationState = 'default' | 'error' | 'success' | 'warning';\n\nexport type RadioProps = {\n /** Controlled checked state - overridden by RadioGroup context if present */\n checked?: boolean;\n /** Change event handler - called in addition to RadioGroup onChange if both are provided */\n onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;\n /** Disables radio interaction and applies disabled styling */\n disabled?: boolean;\n /** Additional CSS classes applied to the radio button indicator */\n className?: string;\n /** Accessible label for screen readers when visual label is not present */\n ariaLabel?: string;\n /** HTML id attribute - auto-generated if not provided */\n id?: string;\n /** Form input name - overridden by RadioGroup context if present */\n name?: string;\n /** Input value submitted with form - required when used in RadioGroup */\n value?: string;\n /** Visual validation state affecting border and ring colors */\n validationState?: ValidationState;\n};\n\n/**\n * Accessible Radio component\n */\nfunction Radio({\n checked,\n onChange,\n disabled = false,\n className = '',\n ariaLabel,\n id,\n name: nameProp,\n value,\n validationState = 'default'\n}: Readonly<RadioProps>) {\n const radioGroup = useRadioGroup();\n\n // Use name from RadioGroup context if available, otherwise use prop\n const name = radioGroup?.name || nameProp;\n\n // Use checked state from RadioGroup if available\n const isChecked = radioGroup?.value !== undefined ? radioGroup.value === value : checked;\n\n // Handle change with RadioGroup callback if available\n const handleChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n if (radioGroup?.onChange && value) {\n radioGroup.onChange(value);\n }\n onChange?.(e);\n };\n\n const validationClasses = {\n default: 'border-input focus:ring-ring',\n error: 'border-error focus:ring-error',\n success: 'border-success focus:ring-success',\n warning: 'border-warning focus:ring-warning'\n };\n\n const generatedId = useId();\n const inputId = id || `radio-${value || generatedId}`;\n\n return (\n <div\n className={`inline-flex items-center justify-center relative ${disabled ? 'opacity-60 cursor-not-allowed' : 'cursor-pointer'}`}\n >\n <input\n type=\"radio\"\n checked={isChecked}\n onChange={handleChange}\n disabled={disabled}\n aria-label={ariaLabel}\n aria-invalid={validationState === 'error' ? 'true' : undefined}\n id={inputId}\n name={name}\n value={value}\n className=\"peer sr-only\"\n />\n <span\n aria-hidden=\"true\"\n onClick={() => !disabled && document.getElementById(inputId)?.click()}\n className={`w-6 h-6 sm:w-5 sm:h-5 rounded-full border-2 flex items-center justify-center transition-all duration-200 ease-out bg-background shadow-sm\n before:content-[''] before:w-3 before:h-3 sm:before:w-2.5 sm:before:h-2.5 before:rounded-full before:scale-0 before:transition-transform before:duration-200 before:ease-out before:bg-primary\n peer-checked:before:scale-100 peer-checked:border-primary\n peer-focus-visible:ring-2 peer-focus-visible:ring-offset-2 peer-focus-visible:ring-ring\n peer-disabled:opacity-50 peer-disabled:cursor-not-allowed\n peer-hover:border-primary/60 peer-active:scale-95\n ${validationClasses[validationState]} ${className}`}\n />\n </div>\n );\n}\n\nRadio.displayName = 'Radio';\n\nexport default Radio;\n"],"names":[],"mappings":";;;AA6BA,SAAS,MAAM;AAAA,EACb;AAAA,EACA;AAAA,EACA,WAAW;AAAA,EACX,YAAY;AAAA,EACZ;AAAA,EACA;AAAA,EACA,MAAM;AAAA,EACN;AAAA,EACA,kBAAkB;AACpB,GAAyB;AACvB,QAAM,aAAa,cAAA;AAGnB,QAAM,OAAO,YAAY,QAAQ;AAGjC,QAAM,YAAY,YAAY,UAAU,SAAY,WAAW,UAAU,QAAQ;AAGjF,QAAM,eAAe,CAAC,MAA2C;AAC/D,QAAI,YAAY,YAAY,OAAO;AACjC,iBAAW,SAAS,KAAK;AAAA,IAC3B;AACA,eAAW,CAAC;AAAA,EACd;AAEA,QAAM,oBAAoB;AAAA,IACxB,SAAS;AAAA,IACT,OAAO;AAAA,IACP,SAAS;AAAA,IACT,SAAS;AAAA,EAAA;AAGX,QAAM,cAAc,MAAA;AACpB,QAAM,UAAU,MAAM,SAAS,SAAS,WAAW;AAEnD,SACE;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAW,oDAAoD,WAAW,kCAAkC,gBAAgB;AAAA,MAE5H,UAAA;AAAA,QAAA;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,MAAK;AAAA,YACL,SAAS;AAAA,YACT,UAAU;AAAA,YACV;AAAA,YACA,cAAY;AAAA,YACZ,gBAAc,oBAAoB,UAAU,SAAS;AAAA,YACrD,IAAI;AAAA,YACJ;AAAA,YACA;AAAA,YACA,WAAU;AAAA,UAAA;AAAA,QAAA;AAAA,QAEZ;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,eAAY;AAAA,YACZ,SAAS,MAAM,CAAC,YAAY,SAAS,eAAe,OAAO,GAAG,MAAA;AAAA,YAC9D,WAAW;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,UAMT,kBAAkB,eAAe,CAAC,IAAI,SAAS;AAAA,UAAA;AAAA,QAAA;AAAA,MACnD;AAAA,IAAA;AAAA,EAAA;AAGN;AAEA,MAAM,cAAc;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/forms/radio-group/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AACvD,YAAY,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
export type RadioGroupProps = {
|
|
3
|
+
/** Radio components - typically multiple Radio components */
|
|
4
|
+
children: ReactNode;
|
|
5
|
+
/** Form input name shared by all child radios for grouping */
|
|
6
|
+
name: string;
|
|
7
|
+
/** Optional legend text displayed above the radio group */
|
|
8
|
+
label?: string;
|
|
9
|
+
/** Layout direction - horizontal arranges radios in a row, vertical stacks them */
|
|
10
|
+
orientation?: 'horizontal' | 'vertical';
|
|
11
|
+
/** Additional CSS classes applied to the fieldset container */
|
|
12
|
+
className?: string;
|
|
13
|
+
/** Controlled value - matches the value prop of the selected Radio */
|
|
14
|
+
value?: string;
|
|
15
|
+
/** Change handler receiving the selected radio's value */
|
|
16
|
+
onChange?: (value: string) => void;
|
|
17
|
+
};
|
|
18
|
+
type RadioGroupContextValue = {
|
|
19
|
+
name: string;
|
|
20
|
+
value?: string;
|
|
21
|
+
onChange?: (value: string) => void;
|
|
22
|
+
};
|
|
23
|
+
export declare const useRadioGroup: () => RadioGroupContextValue | null;
|
|
24
|
+
/**
|
|
25
|
+
* RadioGroup - Wrapper for radio inputs with consistent spacing and shared name
|
|
26
|
+
*/
|
|
27
|
+
declare function RadioGroup({ children, name, label, orientation, className, value, onChange }: Readonly<RadioGroupProps>): import("react/jsx-runtime").JSX.Element;
|
|
28
|
+
declare namespace RadioGroup {
|
|
29
|
+
var displayName: string;
|
|
30
|
+
}
|
|
31
|
+
export default RadioGroup;
|
|
32
|
+
//# sourceMappingURL=radio-group.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"radio-group.d.ts","sourceRoot":"","sources":["../../../../src/components/forms/radio-group/radio-group.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAA6B,MAAM,OAAO,CAAC;AAE7D,MAAM,MAAM,eAAe,GAAG;IAC5B,6DAA6D;IAC7D,QAAQ,EAAE,SAAS,CAAC;IACpB,8DAA8D;IAC9D,IAAI,EAAE,MAAM,CAAC;IACb,2DAA2D;IAC3D,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,mFAAmF;IACnF,WAAW,CAAC,EAAE,YAAY,GAAG,UAAU,CAAC;IACxC,+DAA+D;IAC/D,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,sEAAsE;IACtE,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,0DAA0D;IAC1D,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;CACpC,CAAC;AAEF,KAAK,sBAAsB,GAAG;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;CACpC,CAAC;AAIF,eAAO,MAAM,aAAa,qCAGzB,CAAC;AAEF;;GAEG;AACH,iBAAS,UAAU,CAAC,EAClB,QAAQ,EACR,IAAI,EACJ,KAAK,EACL,WAAwB,EACxB,SAAc,EACd,KAAK,EACL,QAAQ,EACT,EAAE,QAAQ,CAAC,eAAe,CAAC,2CAa3B;kBArBQ,UAAU;;;AAyBnB,eAAe,UAAU,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useContext, createContext } from "react";
|
|
3
|
+
const RadioGroupContext = createContext(null);
|
|
4
|
+
const useRadioGroup = () => {
|
|
5
|
+
const context = useContext(RadioGroupContext);
|
|
6
|
+
return context;
|
|
7
|
+
};
|
|
8
|
+
function RadioGroup({
|
|
9
|
+
children,
|
|
10
|
+
name,
|
|
11
|
+
label,
|
|
12
|
+
orientation = "vertical",
|
|
13
|
+
className = "",
|
|
14
|
+
value,
|
|
15
|
+
onChange
|
|
16
|
+
}) {
|
|
17
|
+
const orientationClasses = orientation === "horizontal" ? "flex flex-row gap-4" : "flex flex-col gap-2";
|
|
18
|
+
return /* @__PURE__ */ jsx(RadioGroupContext.Provider, { value: { name, value, onChange }, children: /* @__PURE__ */ jsxs("fieldset", { className, children: [
|
|
19
|
+
label && /* @__PURE__ */ jsx("legend", { className: "text-sm font-medium text-foreground mb-2", children: label }),
|
|
20
|
+
/* @__PURE__ */ jsx("div", { className: orientationClasses, role: "radiogroup", children })
|
|
21
|
+
] }) });
|
|
22
|
+
}
|
|
23
|
+
RadioGroup.displayName = "RadioGroup";
|
|
24
|
+
export {
|
|
25
|
+
RadioGroup as default,
|
|
26
|
+
useRadioGroup
|
|
27
|
+
};
|
|
28
|
+
//# sourceMappingURL=radio-group.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"radio-group.js","sources":["../../../../src/components/forms/radio-group/radio-group.tsx"],"sourcesContent":["import { ReactNode, createContext, useContext } from 'react';\n\nexport type RadioGroupProps = {\n /** Radio components - typically multiple Radio components */\n children: ReactNode;\n /** Form input name shared by all child radios for grouping */\n name: string;\n /** Optional legend text displayed above the radio group */\n label?: string;\n /** Layout direction - horizontal arranges radios in a row, vertical stacks them */\n orientation?: 'horizontal' | 'vertical';\n /** Additional CSS classes applied to the fieldset container */\n className?: string;\n /** Controlled value - matches the value prop of the selected Radio */\n value?: string;\n /** Change handler receiving the selected radio's value */\n onChange?: (value: string) => void;\n};\n\ntype RadioGroupContextValue = {\n name: string;\n value?: string;\n onChange?: (value: string) => void;\n};\n\nconst RadioGroupContext = createContext<RadioGroupContextValue | null>(null);\n\nexport const useRadioGroup = () => {\n const context = useContext(RadioGroupContext);\n return context;\n};\n\n/**\n * RadioGroup - Wrapper for radio inputs with consistent spacing and shared name\n */\nfunction RadioGroup({\n children,\n name,\n label,\n orientation = 'vertical',\n className = '',\n value,\n onChange\n}: Readonly<RadioGroupProps>) {\n const orientationClasses = orientation === 'horizontal' ? 'flex flex-row gap-4' : 'flex flex-col gap-2';\n\n return (\n <RadioGroupContext.Provider value={{ name, value, onChange }}>\n <fieldset className={className}>\n {label && <legend className=\"text-sm font-medium text-foreground mb-2\">{label}</legend>}\n <div className={orientationClasses} role=\"radiogroup\">\n {children}\n </div>\n </fieldset>\n </RadioGroupContext.Provider>\n );\n}\n\nRadioGroup.displayName = 'RadioGroup';\n\nexport default RadioGroup;\n"],"names":[],"mappings":";;AAyBA,MAAM,oBAAoB,cAA6C,IAAI;AAEpE,MAAM,gBAAgB,MAAM;AACjC,QAAM,UAAU,WAAW,iBAAiB;AAC5C,SAAO;AACT;AAKA,SAAS,WAAW;AAAA,EAClB;AAAA,EACA;AAAA,EACA;AAAA,EACA,cAAc;AAAA,EACd,YAAY;AAAA,EACZ;AAAA,EACA;AACF,GAA8B;AAC5B,QAAM,qBAAqB,gBAAgB,eAAe,wBAAwB;AAElF,SACE,oBAAC,kBAAkB,UAAlB,EAA2B,OAAO,EAAE,MAAM,OAAO,SAAA,GAChD,UAAA,qBAAC,YAAA,EAAS,WACP,UAAA;AAAA,IAAA,SAAS,oBAAC,UAAA,EAAO,WAAU,4CAA4C,UAAA,OAAM;AAAA,wBAC7E,OAAA,EAAI,WAAW,oBAAoB,MAAK,cACtC,SAAA,CACH;AAAA,EAAA,EAAA,CACF,EAAA,CACF;AAEJ;AAEA,WAAW,cAAc;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/forms/select/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,UAAU,CAAC;AACnC,YAAY,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAC5C,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,eAAe,CAAC;AACtD,YAAY,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { default as React } from 'react';
|
|
2
|
+
export type SelectItemProps = {
|
|
3
|
+
value?: string;
|
|
4
|
+
disabled?: boolean;
|
|
5
|
+
children: React.ReactNode;
|
|
6
|
+
};
|
|
7
|
+
/**
|
|
8
|
+
* SelectItem - Option element for Select component
|
|
9
|
+
* Replaces native <option> element with semantic component
|
|
10
|
+
*/
|
|
11
|
+
declare function SelectItem({ value, disabled, children }: Readonly<SelectItemProps>): import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
declare namespace SelectItem {
|
|
13
|
+
var displayName: string;
|
|
14
|
+
}
|
|
15
|
+
export default SelectItem;
|
|
16
|
+
//# sourceMappingURL=select-item.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"select-item.d.ts","sourceRoot":"","sources":["../../../../src/components/forms/select/select-item.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,MAAM,MAAM,eAAe,GAAG;IAC5B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC3B,CAAC;AAEF;;;GAGG;AACH,iBAAS,UAAU,CAAC,EAAE,KAAK,EAAE,QAAgB,EAAE,QAAQ,EAAE,EAAE,QAAQ,CAAC,eAAe,CAAC,2CAMnF;kBANQ,UAAU;;;AAUnB,eAAe,UAAU,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { jsx } from "react/jsx-runtime";
|
|
2
|
+
function SelectItem({ value, disabled = false, children }) {
|
|
3
|
+
return /* @__PURE__ */ jsx("option", { value, disabled, children });
|
|
4
|
+
}
|
|
5
|
+
SelectItem.displayName = "SelectItem";
|
|
6
|
+
export {
|
|
7
|
+
SelectItem as default
|
|
8
|
+
};
|
|
9
|
+
//# sourceMappingURL=select-item.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"select-item.js","sources":["../../../../src/components/forms/select/select-item.tsx"],"sourcesContent":["import React from 'react';\n\nexport type SelectItemProps = {\n value?: string;\n disabled?: boolean;\n children: React.ReactNode;\n};\n\n/**\n * SelectItem - Option element for Select component\n * Replaces native <option> element with semantic component\n */\nfunction SelectItem({ value, disabled = false, children }: Readonly<SelectItemProps>) {\n return (\n <option value={value} disabled={disabled}>\n {children}\n </option>\n );\n}\n\nSelectItem.displayName = 'SelectItem';\n\nexport default SelectItem;\n"],"names":[],"mappings":";AAYA,SAAS,WAAW,EAAE,OAAO,WAAW,OAAO,YAAuC;AACpF,SACE,oBAAC,UAAA,EAAO,OAAc,UACnB,SAAA,CACH;AAEJ;AAEA,WAAW,cAAc;"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { default as React } from 'react';
|
|
2
|
+
import { InteractiveSize, InputWidth, ValidationState } from '../../../theme/size-tokens';
|
|
3
|
+
export type { ValidationState };
|
|
4
|
+
export type SelectProps = {
|
|
5
|
+
/** Current selected value (controlled) */
|
|
6
|
+
value?: string;
|
|
7
|
+
/** Default value for uncontrolled select */
|
|
8
|
+
defaultValue?: string;
|
|
9
|
+
/** Change event handler for controlled select */
|
|
10
|
+
onChange?: (e: React.ChangeEvent<HTMLSelectElement>) => void;
|
|
11
|
+
/** Focus event handler */
|
|
12
|
+
onFocus?: (e: React.FocusEvent<HTMLSelectElement>) => void;
|
|
13
|
+
/** Blur event handler */
|
|
14
|
+
onBlur?: (e: React.FocusEvent<HTMLSelectElement>) => void;
|
|
15
|
+
/** Disables select interaction and applies disabled styling */
|
|
16
|
+
disabled?: boolean;
|
|
17
|
+
/** Accessible label for screen readers */
|
|
18
|
+
ariaLabel?: string;
|
|
19
|
+
/** HTML id attribute for the select */
|
|
20
|
+
id?: string;
|
|
21
|
+
/** HTML name attribute for form submission */
|
|
22
|
+
name?: string;
|
|
23
|
+
/** SelectItem children defining the available options */
|
|
24
|
+
children: React.ReactNode;
|
|
25
|
+
/** Marks select as required for form validation */
|
|
26
|
+
required?: boolean;
|
|
27
|
+
/** Size variant - uses unified size system */
|
|
28
|
+
size?: InteractiveSize;
|
|
29
|
+
/** Width of the select field - uses semantic sizing */
|
|
30
|
+
width?: InputWidth;
|
|
31
|
+
/** Visual validation state affecting border color and styling */
|
|
32
|
+
validationState?: ValidationState;
|
|
33
|
+
/** Placeholder text shown as disabled, selected, hidden option */
|
|
34
|
+
label?: string;
|
|
35
|
+
};
|
|
36
|
+
/**
|
|
37
|
+
* Select - Accessible select dropdown with validation state support
|
|
38
|
+
*
|
|
39
|
+
* @example
|
|
40
|
+
* ```tsx
|
|
41
|
+
* <Select>
|
|
42
|
+
* <SelectItem value="1">Option 1</SelectItem>
|
|
43
|
+
* <SelectItem value="2">Option 2</SelectItem>
|
|
44
|
+
* </Select>
|
|
45
|
+
* ```
|
|
46
|
+
*/
|
|
47
|
+
declare function Select({ value, defaultValue, onChange, onFocus, onBlur, disabled, ariaLabel, id, name, children, required, size, width, validationState, label }: Readonly<SelectProps>): import("react/jsx-runtime").JSX.Element;
|
|
48
|
+
declare namespace Select {
|
|
49
|
+
var displayName: string;
|
|
50
|
+
}
|
|
51
|
+
export default Select;
|
|
52
|
+
//# sourceMappingURL=select.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"select.d.ts","sourceRoot":"","sources":["../../../../src/components/forms/select/select.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAML,KAAK,eAAe,EACpB,KAAK,UAAU,EACf,KAAK,eAAe,EACrB,MAAM,4BAA4B,CAAC;AAEpC,YAAY,EAAE,eAAe,EAAE,CAAC;AAEhC,MAAM,MAAM,WAAW,GAAG;IACxB,0CAA0C;IAC1C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,4CAA4C;IAC5C,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,iDAAiD;IACjD,QAAQ,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,CAAC,WAAW,CAAC,iBAAiB,CAAC,KAAK,IAAI,CAAC;IAC7D,0BAA0B;IAC1B,OAAO,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,CAAC,UAAU,CAAC,iBAAiB,CAAC,KAAK,IAAI,CAAC;IAC3D,yBAAyB;IACzB,MAAM,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,CAAC,UAAU,CAAC,iBAAiB,CAAC,KAAK,IAAI,CAAC;IAC1D,+DAA+D;IAC/D,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,0CAA0C;IAC1C,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,uCAAuC;IACvC,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,8CAA8C;IAC9C,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,yDAAyD;IACzD,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,mDAAmD;IACnD,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,8CAA8C;IAC9C,IAAI,CAAC,EAAE,eAAe,CAAC;IACvB,uDAAuD;IACvD,KAAK,CAAC,EAAE,UAAU,CAAC;IACnB,iEAAiE;IACjE,eAAe,CAAC,EAAE,eAAe,CAAC;IAClC,kEAAkE;IAClE,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAMF;;;;;;;;;;GAUG;AACH,iBAAS,MAAM,CAAC,EACd,KAAK,EACL,YAAY,EACZ,QAAQ,EACR,OAAO,EACP,MAAM,EACN,QAAgB,EAChB,SAAS,EACT,EAAE,EACF,IAAI,EACJ,QAAQ,EACR,QAAgB,EAChB,IAAW,EACX,KAAK,EACL,eAA2B,EAC3B,KAAK,EACN,EAAE,QAAQ,CAAC,WAAW,CAAC,2CA8BvB;kBA9CQ,MAAM;;;AAkDf,eAAe,MAAM,CAAC"}
|