@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,27 @@
|
|
|
1
|
+
import { jsxs, jsx } from "react/jsx-runtime";
|
|
2
|
+
import Text from "../../typography/text/text.js";
|
|
3
|
+
function ProgressBar({ value, max = 100, showLabel, variant = "neutral", className = "" }) {
|
|
4
|
+
const percentage = Math.min(value / max * 100, 100);
|
|
5
|
+
return /* @__PURE__ */ jsxs("div", { className: `flex items-center gap-3 ${className}`, children: [
|
|
6
|
+
/* @__PURE__ */ jsx("div", { className: "flex-1 bg-muted/30 rounded-full h-2.5 overflow-hidden shadow-inner", children: /* @__PURE__ */ jsx(
|
|
7
|
+
"div",
|
|
8
|
+
{
|
|
9
|
+
role: "progressbar",
|
|
10
|
+
"aria-valuenow": value,
|
|
11
|
+
"aria-valuemin": 0,
|
|
12
|
+
"aria-valuemax": max,
|
|
13
|
+
className: `h-full transition-all duration-500 ease-out rounded-full bg-${variant}`,
|
|
14
|
+
style: { width: `${percentage}%` }
|
|
15
|
+
}
|
|
16
|
+
) }),
|
|
17
|
+
showLabel && /* @__PURE__ */ jsxs(Text, { variant: "muted", weight: "medium", size: "sm", children: [
|
|
18
|
+
Math.round(percentage),
|
|
19
|
+
"%"
|
|
20
|
+
] })
|
|
21
|
+
] });
|
|
22
|
+
}
|
|
23
|
+
ProgressBar.displayName = "ProgressBar";
|
|
24
|
+
export {
|
|
25
|
+
ProgressBar as default
|
|
26
|
+
};
|
|
27
|
+
//# sourceMappingURL=progress-bar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"progress-bar.js","sources":["../../../../src/components/feedback/progress-bar/progress-bar.tsx"],"sourcesContent":["import Text from '../../typography/text/text';\nimport { ColorVariant } from '../../../theme/tokens';\n\nexport type ProgressBarProps = {\n /** Current progress value */\n value: number;\n /** Maximum value for the progress bar (defaults to 100) */\n max?: number;\n /** Whether to display the percentage label next to the progress bar */\n showLabel?: boolean;\n /** Visual style variant indicating the progress state */\n variant?: ColorVariant;\n /** Additional CSS classes to apply to the progress bar container */\n className?: string;\n};\n\n/**\n * ProgressBar - Visual representation of completion\n */\nfunction ProgressBar({ value, max = 100, showLabel, variant = 'neutral', className = '' }: Readonly<ProgressBarProps>) {\n const percentage = Math.min((value / max) * 100, 100);\n\n return (\n <div className={`flex items-center gap-3 ${className}`}>\n <div className=\"flex-1 bg-muted/30 rounded-full h-2.5 overflow-hidden shadow-inner\">\n <div\n role=\"progressbar\"\n aria-valuenow={value}\n aria-valuemin={0}\n aria-valuemax={max}\n className={`h-full transition-all duration-500 ease-out rounded-full bg-${variant}`}\n style={{ width: `${percentage}%` }}\n />\n </div>\n {showLabel && (\n <Text variant=\"muted\" weight=\"medium\" size=\"sm\">\n {Math.round(percentage)}%\n </Text>\n )}\n </div>\n );\n}\n\nProgressBar.displayName = 'ProgressBar';\n\nexport default ProgressBar;\n"],"names":[],"mappings":";;AAmBA,SAAS,YAAY,EAAE,OAAO,MAAM,KAAK,WAAW,UAAU,WAAW,YAAY,MAAkC;AACrH,QAAM,aAAa,KAAK,IAAK,QAAQ,MAAO,KAAK,GAAG;AAEpD,SACE,qBAAC,OAAA,EAAI,WAAW,2BAA2B,SAAS,IAClD,UAAA;AAAA,IAAA,oBAAC,OAAA,EAAI,WAAU,sEACb,UAAA;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,MAAK;AAAA,QACL,iBAAe;AAAA,QACf,iBAAe;AAAA,QACf,iBAAe;AAAA,QACf,WAAW,+DAA+D,OAAO;AAAA,QACjF,OAAO,EAAE,OAAO,GAAG,UAAU,IAAA;AAAA,MAAI;AAAA,IAAA,GAErC;AAAA,IACC,kCACE,MAAA,EAAK,SAAQ,SAAQ,QAAO,UAAS,MAAK,MACxC,UAAA;AAAA,MAAA,KAAK,MAAM,UAAU;AAAA,MAAE;AAAA,IAAA,EAAA,CAC1B;AAAA,EAAA,GAEJ;AAEJ;AAEA,YAAY,cAAc;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/feedback/skeleton/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AACrC,YAAY,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export type SkeletonProps = {
|
|
2
|
+
/** Shape variant of the skeleton placeholder */
|
|
3
|
+
variant?: 'text' | 'circular' | 'rectangular';
|
|
4
|
+
/** Width of the skeleton (CSS value, defaults to 100% for text/rectangular, 40px for circular) */
|
|
5
|
+
width?: string;
|
|
6
|
+
/** Height of the skeleton (CSS value, defaults based on variant) */
|
|
7
|
+
height?: string;
|
|
8
|
+
/** Additional CSS classes to apply to the skeleton container */
|
|
9
|
+
className?: string;
|
|
10
|
+
} & React.HTMLAttributes<HTMLDivElement>;
|
|
11
|
+
/**
|
|
12
|
+
* Skeleton - Placeholder for loading state
|
|
13
|
+
*/
|
|
14
|
+
declare function Skeleton({ variant, width, height, className, ...props }: Readonly<SkeletonProps>): import("react/jsx-runtime").JSX.Element;
|
|
15
|
+
declare namespace Skeleton {
|
|
16
|
+
var displayName: string;
|
|
17
|
+
}
|
|
18
|
+
export default Skeleton;
|
|
19
|
+
//# sourceMappingURL=skeleton.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"skeleton.d.ts","sourceRoot":"","sources":["../../../../src/components/feedback/skeleton/skeleton.tsx"],"names":[],"mappings":"AAAA,MAAM,MAAM,aAAa,GAAG;IAC1B,gDAAgD;IAChD,OAAO,CAAC,EAAE,MAAM,GAAG,UAAU,GAAG,aAAa,CAAC;IAC9C,kGAAkG;IAClG,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,oEAAoE;IACpE,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,gEAAgE;IAChE,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,GAAG,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC;AAEzC;;GAEG;AACH,iBAAS,QAAQ,CAAC,EAAE,OAAgB,EAAE,KAAK,EAAE,MAAM,EAAE,SAAc,EAAE,GAAG,KAAK,EAAE,EAAE,QAAQ,CAAC,aAAa,CAAC,2CAuBvG;kBAvBQ,QAAQ;;;AA2BjB,eAAe,QAAQ,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { jsx } from "react/jsx-runtime";
|
|
2
|
+
function Skeleton({ variant = "text", width, height, className = "", ...props }) {
|
|
3
|
+
const variantClasses = {
|
|
4
|
+
text: "rounded h-4",
|
|
5
|
+
circular: "rounded-full",
|
|
6
|
+
rectangular: "rounded-md"
|
|
7
|
+
};
|
|
8
|
+
const style = {
|
|
9
|
+
width: width || (variant === "circular" ? "40px" : "100%"),
|
|
10
|
+
height: height || (variant === "circular" ? "40px" : void 0)
|
|
11
|
+
};
|
|
12
|
+
return /* @__PURE__ */ jsx(
|
|
13
|
+
"div",
|
|
14
|
+
{
|
|
15
|
+
className: `bg-muted animate-pulse ${variantClasses[variant]} ${className}`,
|
|
16
|
+
style,
|
|
17
|
+
"aria-busy": "true",
|
|
18
|
+
"aria-live": "polite",
|
|
19
|
+
...props,
|
|
20
|
+
children: /* @__PURE__ */ jsx("span", { className: "sr-only", children: "Loading..." })
|
|
21
|
+
}
|
|
22
|
+
);
|
|
23
|
+
}
|
|
24
|
+
Skeleton.displayName = "Skeleton";
|
|
25
|
+
export {
|
|
26
|
+
Skeleton as default
|
|
27
|
+
};
|
|
28
|
+
//# sourceMappingURL=skeleton.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"skeleton.js","sources":["../../../../src/components/feedback/skeleton/skeleton.tsx"],"sourcesContent":["export type SkeletonProps = {\n /** Shape variant of the skeleton placeholder */\n variant?: 'text' | 'circular' | 'rectangular';\n /** Width of the skeleton (CSS value, defaults to 100% for text/rectangular, 40px for circular) */\n width?: string;\n /** Height of the skeleton (CSS value, defaults based on variant) */\n height?: string;\n /** Additional CSS classes to apply to the skeleton container */\n className?: string;\n} & React.HTMLAttributes<HTMLDivElement>;\n\n/**\n * Skeleton - Placeholder for loading state\n */\nfunction Skeleton({ variant = 'text', width, height, className = '', ...props }: Readonly<SkeletonProps>) {\n const variantClasses = {\n text: 'rounded h-4',\n circular: 'rounded-full',\n rectangular: 'rounded-md'\n };\n\n const style = {\n width: width || (variant === 'circular' ? '40px' : '100%'),\n height: height || (variant === 'circular' ? '40px' : undefined)\n };\n\n return (\n <div\n className={`bg-muted animate-pulse ${variantClasses[variant]} ${className}`}\n style={style}\n aria-busy=\"true\"\n aria-live=\"polite\"\n {...props}\n >\n <span className=\"sr-only\">Loading...</span>\n </div>\n );\n}\n\nSkeleton.displayName = 'Skeleton';\n\nexport default Skeleton;\n"],"names":[],"mappings":";AAcA,SAAS,SAAS,EAAE,UAAU,QAAQ,OAAO,QAAQ,YAAY,IAAI,GAAG,SAAkC;AACxG,QAAM,iBAAiB;AAAA,IACrB,MAAM;AAAA,IACN,UAAU;AAAA,IACV,aAAa;AAAA,EAAA;AAGf,QAAM,QAAQ;AAAA,IACZ,OAAO,UAAU,YAAY,aAAa,SAAS;AAAA,IACnD,QAAQ,WAAW,YAAY,aAAa,SAAS;AAAA,EAAA;AAGvD,SACE;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAW,0BAA0B,eAAe,OAAO,CAAC,IAAI,SAAS;AAAA,MACzE;AAAA,MACA,aAAU;AAAA,MACV,aAAU;AAAA,MACT,GAAG;AAAA,MAEJ,UAAA,oBAAC,QAAA,EAAK,WAAU,WAAU,UAAA,aAAA,CAAU;AAAA,IAAA;AAAA,EAAA;AAG1C;AAEA,SAAS,cAAc;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/feedback/smooth-transition/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,sBAAsB,EAAE,MAAM,qBAAqB,CAAC;AACtE,YAAY,EAAE,qBAAqB,EAAE,cAAc,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC"}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { ReactNode, CSSProperties } from 'react';
|
|
2
|
+
export type TransitionType = 'fade' | 'slide-up' | 'slide-down' | 'slide-left' | 'slide-right' | 'scale' | 'scale-fade' | 'slide-fade-up' | 'slide-fade-down' | 'zoom';
|
|
3
|
+
export type TransitionDuration = 'fast' | 'normal' | 'slow' | number;
|
|
4
|
+
export type SmoothTransitionProps = {
|
|
5
|
+
/** Content to animate */
|
|
6
|
+
children: ReactNode;
|
|
7
|
+
/** Whether to show the content (controls animation state) */
|
|
8
|
+
show?: boolean;
|
|
9
|
+
/** Type of animation to apply */
|
|
10
|
+
type?: TransitionType;
|
|
11
|
+
/** Duration of the animation ('fast', 'normal', 'slow', or custom milliseconds) */
|
|
12
|
+
duration?: TransitionDuration;
|
|
13
|
+
/** Delay before animation starts (in ms) */
|
|
14
|
+
delay?: number;
|
|
15
|
+
/** Additional CSS classes */
|
|
16
|
+
className?: string;
|
|
17
|
+
/** Additional inline styles */
|
|
18
|
+
style?: CSSProperties;
|
|
19
|
+
/** Apply hover effect (scale and shadow on hover) */
|
|
20
|
+
hover?: boolean;
|
|
21
|
+
/** Apply active effect (scale down on click) */
|
|
22
|
+
active?: boolean;
|
|
23
|
+
};
|
|
24
|
+
/**
|
|
25
|
+
* SmoothTransition - A reusable component for smooth animations and transitions
|
|
26
|
+
*
|
|
27
|
+
* @example
|
|
28
|
+
* // Fade in/out
|
|
29
|
+
* <SmoothTransition show={isOpen} type="fade">
|
|
30
|
+
* <div>Content</div>
|
|
31
|
+
* </SmoothTransition>
|
|
32
|
+
*
|
|
33
|
+
* @example
|
|
34
|
+
* // Slide up with hover effect
|
|
35
|
+
* <SmoothTransition show={true} type="slide-fade-up" hover>
|
|
36
|
+
* <button>Click me</button>
|
|
37
|
+
* </SmoothTransition>
|
|
38
|
+
*
|
|
39
|
+
* @example
|
|
40
|
+
* // Custom duration
|
|
41
|
+
* <SmoothTransition show={isVisible} type="scale-fade" duration={500}>
|
|
42
|
+
* <div>Animated content</div>
|
|
43
|
+
* </SmoothTransition>
|
|
44
|
+
*
|
|
45
|
+
* @example
|
|
46
|
+
* // Delayed animation
|
|
47
|
+
* <SmoothTransition show={true} type="fade" delay={200}>
|
|
48
|
+
* <div>Appears after 200ms</div>
|
|
49
|
+
* </SmoothTransition>
|
|
50
|
+
*/
|
|
51
|
+
declare function SmoothTransition({ children, show, type, duration, delay, className, style, hover, active }: Readonly<SmoothTransitionProps>): import("react/jsx-runtime").JSX.Element;
|
|
52
|
+
declare namespace SmoothTransition {
|
|
53
|
+
var displayName: string;
|
|
54
|
+
}
|
|
55
|
+
export default SmoothTransition;
|
|
56
|
+
/**
|
|
57
|
+
* Hook for creating staggered animations
|
|
58
|
+
*
|
|
59
|
+
* @example
|
|
60
|
+
* const delays = useStaggeredTransition(5, 100);
|
|
61
|
+
* items.map((item, i) => (
|
|
62
|
+
* <SmoothTransition key={i} delay={delays[i]}>
|
|
63
|
+
* {item}
|
|
64
|
+
* </SmoothTransition>
|
|
65
|
+
* ))
|
|
66
|
+
*/
|
|
67
|
+
export declare function useStaggeredTransition(count: number, baseDelay?: number): number[];
|
|
68
|
+
//# sourceMappingURL=smooth-transition.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"smooth-transition.d.ts","sourceRoot":"","sources":["../../../../src/components/feedback/smooth-transition/smooth-transition.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AAEjD,MAAM,MAAM,cAAc,GACtB,MAAM,GACN,UAAU,GACV,YAAY,GACZ,YAAY,GACZ,aAAa,GACb,OAAO,GACP,YAAY,GACZ,eAAe,GACf,iBAAiB,GACjB,MAAM,CAAC;AAEX,MAAM,MAAM,kBAAkB,GAAG,MAAM,GAAG,QAAQ,GAAG,MAAM,GAAG,MAAM,CAAC;AAErE,MAAM,MAAM,qBAAqB,GAAG;IAClC,yBAAyB;IACzB,QAAQ,EAAE,SAAS,CAAC;IACpB,6DAA6D;IAC7D,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,iCAAiC;IACjC,IAAI,CAAC,EAAE,cAAc,CAAC;IACtB,mFAAmF;IACnF,QAAQ,CAAC,EAAE,kBAAkB,CAAC;IAC9B,4CAA4C;IAC5C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,6BAA6B;IAC7B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,+BAA+B;IAC/B,KAAK,CAAC,EAAE,aAAa,CAAC;IACtB,qDAAqD;IACrD,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,gDAAgD;IAChD,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB,CAAC;AAkEF;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,iBAAS,gBAAgB,CAAC,EACxB,QAAQ,EACR,IAAW,EACX,IAAa,EACb,QAAmB,EACnB,KAAS,EACT,SAAc,EACd,KAAU,EACV,KAAa,EACb,MAAc,EACf,EAAE,QAAQ,CAAC,qBAAqB,CAAC,2CAejC;kBAzBQ,gBAAgB;;;AA6BzB,eAAe,gBAAgB,CAAC;AAEhC;;;;;;;;;;GAUG;AACH,wBAAgB,sBAAsB,CAAC,KAAK,EAAE,MAAM,EAAE,SAAS,GAAE,MAAW,GAAG,MAAM,EAAE,CAEtF"}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import { jsx } from "react/jsx-runtime";
|
|
2
|
+
const getDurationClass = (duration) => {
|
|
3
|
+
if (typeof duration === "number") {
|
|
4
|
+
return "";
|
|
5
|
+
}
|
|
6
|
+
switch (duration) {
|
|
7
|
+
case "fast":
|
|
8
|
+
return "duration-150";
|
|
9
|
+
case "slow":
|
|
10
|
+
return "duration-500";
|
|
11
|
+
case "normal":
|
|
12
|
+
default:
|
|
13
|
+
return "duration-300";
|
|
14
|
+
}
|
|
15
|
+
};
|
|
16
|
+
const getTransitionClasses = (type, show, hover, active) => {
|
|
17
|
+
const baseClasses = "transition-all";
|
|
18
|
+
let typeClasses = "";
|
|
19
|
+
if (!show) {
|
|
20
|
+
switch (type) {
|
|
21
|
+
case "fade":
|
|
22
|
+
typeClasses = "opacity-0";
|
|
23
|
+
break;
|
|
24
|
+
case "slide-up":
|
|
25
|
+
typeClasses = "translate-y-4 opacity-0";
|
|
26
|
+
break;
|
|
27
|
+
case "slide-down":
|
|
28
|
+
typeClasses = "-translate-y-4 opacity-0";
|
|
29
|
+
break;
|
|
30
|
+
case "slide-left":
|
|
31
|
+
typeClasses = "translate-x-4 opacity-0";
|
|
32
|
+
break;
|
|
33
|
+
case "slide-right":
|
|
34
|
+
typeClasses = "-translate-x-4 opacity-0";
|
|
35
|
+
break;
|
|
36
|
+
case "scale":
|
|
37
|
+
typeClasses = "scale-95 opacity-0";
|
|
38
|
+
break;
|
|
39
|
+
case "scale-fade":
|
|
40
|
+
typeClasses = "scale-90 opacity-0";
|
|
41
|
+
break;
|
|
42
|
+
case "slide-fade-up":
|
|
43
|
+
typeClasses = "translate-y-2 opacity-0";
|
|
44
|
+
break;
|
|
45
|
+
case "slide-fade-down":
|
|
46
|
+
typeClasses = "-translate-y-2 opacity-0";
|
|
47
|
+
break;
|
|
48
|
+
case "zoom":
|
|
49
|
+
typeClasses = "scale-0 opacity-0";
|
|
50
|
+
break;
|
|
51
|
+
default:
|
|
52
|
+
typeClasses = "opacity-0";
|
|
53
|
+
}
|
|
54
|
+
} else {
|
|
55
|
+
typeClasses = "translate-y-0 translate-x-0 scale-100 opacity-100";
|
|
56
|
+
}
|
|
57
|
+
const hoverClasses = hover ? "hover:scale-105 hover:shadow-lg" : "";
|
|
58
|
+
const activeClasses = active ? "active:scale-95" : "";
|
|
59
|
+
return `${baseClasses} ${typeClasses} ${hoverClasses} ${activeClasses}`.trim();
|
|
60
|
+
};
|
|
61
|
+
function SmoothTransition({
|
|
62
|
+
children,
|
|
63
|
+
show = true,
|
|
64
|
+
type = "fade",
|
|
65
|
+
duration = "normal",
|
|
66
|
+
delay = 0,
|
|
67
|
+
className = "",
|
|
68
|
+
style = {},
|
|
69
|
+
hover = false,
|
|
70
|
+
active = false
|
|
71
|
+
}) {
|
|
72
|
+
const durationClass = getDurationClass(duration);
|
|
73
|
+
const transitionClasses = getTransitionClasses(type, show, hover, active);
|
|
74
|
+
const customStyle = {
|
|
75
|
+
...style,
|
|
76
|
+
transitionDuration: typeof duration === "number" ? `${duration}ms` : void 0,
|
|
77
|
+
transitionDelay: delay > 0 ? `${delay}ms` : void 0
|
|
78
|
+
};
|
|
79
|
+
return /* @__PURE__ */ jsx("div", { className: `${transitionClasses} ${durationClass} ${className}`, style: customStyle, children });
|
|
80
|
+
}
|
|
81
|
+
SmoothTransition.displayName = "SmoothTransition";
|
|
82
|
+
function useStaggeredTransition(count, baseDelay = 50) {
|
|
83
|
+
return Array.from({ length: count }, (_, i) => i * baseDelay);
|
|
84
|
+
}
|
|
85
|
+
export {
|
|
86
|
+
SmoothTransition as default,
|
|
87
|
+
useStaggeredTransition
|
|
88
|
+
};
|
|
89
|
+
//# sourceMappingURL=smooth-transition.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"smooth-transition.js","sources":["../../../../src/components/feedback/smooth-transition/smooth-transition.tsx"],"sourcesContent":["import { ReactNode, CSSProperties } from 'react';\n\nexport type TransitionType =\n | 'fade'\n | 'slide-up'\n | 'slide-down'\n | 'slide-left'\n | 'slide-right'\n | 'scale'\n | 'scale-fade'\n | 'slide-fade-up'\n | 'slide-fade-down'\n | 'zoom';\n\nexport type TransitionDuration = 'fast' | 'normal' | 'slow' | number;\n\nexport type SmoothTransitionProps = {\n /** Content to animate */\n children: ReactNode;\n /** Whether to show the content (controls animation state) */\n show?: boolean;\n /** Type of animation to apply */\n type?: TransitionType;\n /** Duration of the animation ('fast', 'normal', 'slow', or custom milliseconds) */\n duration?: TransitionDuration;\n /** Delay before animation starts (in ms) */\n delay?: number;\n /** Additional CSS classes */\n className?: string;\n /** Additional inline styles */\n style?: CSSProperties;\n /** Apply hover effect (scale and shadow on hover) */\n hover?: boolean;\n /** Apply active effect (scale down on click) */\n active?: boolean;\n};\n\nconst getDurationClass = (duration: TransitionDuration): string => {\n if (typeof duration === 'number') {\n return '';\n }\n switch (duration) {\n case 'fast':\n return 'duration-150';\n case 'slow':\n return 'duration-500';\n case 'normal':\n default:\n return 'duration-300';\n }\n};\n\nconst getTransitionClasses = (type: TransitionType, show: boolean, hover: boolean, active: boolean): string => {\n const baseClasses = 'transition-all';\n let typeClasses = '';\n\n if (!show) {\n switch (type) {\n case 'fade':\n typeClasses = 'opacity-0';\n break;\n case 'slide-up':\n typeClasses = 'translate-y-4 opacity-0';\n break;\n case 'slide-down':\n typeClasses = '-translate-y-4 opacity-0';\n break;\n case 'slide-left':\n typeClasses = 'translate-x-4 opacity-0';\n break;\n case 'slide-right':\n typeClasses = '-translate-x-4 opacity-0';\n break;\n case 'scale':\n typeClasses = 'scale-95 opacity-0';\n break;\n case 'scale-fade':\n typeClasses = 'scale-90 opacity-0';\n break;\n case 'slide-fade-up':\n typeClasses = 'translate-y-2 opacity-0';\n break;\n case 'slide-fade-down':\n typeClasses = '-translate-y-2 opacity-0';\n break;\n case 'zoom':\n typeClasses = 'scale-0 opacity-0';\n break;\n default:\n typeClasses = 'opacity-0';\n }\n } else {\n typeClasses = 'translate-y-0 translate-x-0 scale-100 opacity-100';\n }\n\n const hoverClasses = hover ? 'hover:scale-105 hover:shadow-lg' : '';\n const activeClasses = active ? 'active:scale-95' : '';\n\n return `${baseClasses} ${typeClasses} ${hoverClasses} ${activeClasses}`.trim();\n};\n\n/**\n * SmoothTransition - A reusable component for smooth animations and transitions\n *\n * @example\n * // Fade in/out\n * <SmoothTransition show={isOpen} type=\"fade\">\n * <div>Content</div>\n * </SmoothTransition>\n *\n * @example\n * // Slide up with hover effect\n * <SmoothTransition show={true} type=\"slide-fade-up\" hover>\n * <button>Click me</button>\n * </SmoothTransition>\n *\n * @example\n * // Custom duration\n * <SmoothTransition show={isVisible} type=\"scale-fade\" duration={500}>\n * <div>Animated content</div>\n * </SmoothTransition>\n *\n * @example\n * // Delayed animation\n * <SmoothTransition show={true} type=\"fade\" delay={200}>\n * <div>Appears after 200ms</div>\n * </SmoothTransition>\n */\nfunction SmoothTransition({\n children,\n show = true,\n type = 'fade',\n duration = 'normal',\n delay = 0,\n className = '',\n style = {},\n hover = false,\n active = false\n}: Readonly<SmoothTransitionProps>) {\n const durationClass = getDurationClass(duration);\n const transitionClasses = getTransitionClasses(type, show, hover, active);\n\n const customStyle: CSSProperties = {\n ...style,\n transitionDuration: typeof duration === 'number' ? `${duration}ms` : undefined,\n transitionDelay: delay > 0 ? `${delay}ms` : undefined\n };\n\n return (\n <div className={`${transitionClasses} ${durationClass} ${className}`} style={customStyle}>\n {children}\n </div>\n );\n}\n\nSmoothTransition.displayName = 'SmoothTransition';\n\nexport default SmoothTransition;\n\n/**\n * Hook for creating staggered animations\n *\n * @example\n * const delays = useStaggeredTransition(5, 100);\n * items.map((item, i) => (\n * <SmoothTransition key={i} delay={delays[i]}>\n * {item}\n * </SmoothTransition>\n * ))\n */\nexport function useStaggeredTransition(count: number, baseDelay: number = 50): number[] {\n return Array.from({ length: count }, (_, i) => i * baseDelay);\n}\n"],"names":[],"mappings":";AAqCA,MAAM,mBAAmB,CAAC,aAAyC;AACjE,MAAI,OAAO,aAAa,UAAU;AAChC,WAAO;AAAA,EACT;AACA,UAAQ,UAAA;AAAA,IACN,KAAK;AACH,aAAO;AAAA,IACT,KAAK;AACH,aAAO;AAAA,IACT,KAAK;AAAA,IACL;AACE,aAAO;AAAA,EAAA;AAEb;AAEA,MAAM,uBAAuB,CAAC,MAAsB,MAAe,OAAgB,WAA4B;AAC7G,QAAM,cAAc;AACpB,MAAI,cAAc;AAElB,MAAI,CAAC,MAAM;AACT,YAAQ,MAAA;AAAA,MACN,KAAK;AACH,sBAAc;AACd;AAAA,MACF,KAAK;AACH,sBAAc;AACd;AAAA,MACF,KAAK;AACH,sBAAc;AACd;AAAA,MACF,KAAK;AACH,sBAAc;AACd;AAAA,MACF,KAAK;AACH,sBAAc;AACd;AAAA,MACF,KAAK;AACH,sBAAc;AACd;AAAA,MACF,KAAK;AACH,sBAAc;AACd;AAAA,MACF,KAAK;AACH,sBAAc;AACd;AAAA,MACF,KAAK;AACH,sBAAc;AACd;AAAA,MACF,KAAK;AACH,sBAAc;AACd;AAAA,MACF;AACE,sBAAc;AAAA,IAAA;AAAA,EAEpB,OAAO;AACL,kBAAc;AAAA,EAChB;AAEA,QAAM,eAAe,QAAQ,oCAAoC;AACjE,QAAM,gBAAgB,SAAS,oBAAoB;AAEnD,SAAO,GAAG,WAAW,IAAI,WAAW,IAAI,YAAY,IAAI,aAAa,GAAG,KAAA;AAC1E;AA6BA,SAAS,iBAAiB;AAAA,EACxB;AAAA,EACA,OAAO;AAAA,EACP,OAAO;AAAA,EACP,WAAW;AAAA,EACX,QAAQ;AAAA,EACR,YAAY;AAAA,EACZ,QAAQ,CAAA;AAAA,EACR,QAAQ;AAAA,EACR,SAAS;AACX,GAAoC;AAClC,QAAM,gBAAgB,iBAAiB,QAAQ;AAC/C,QAAM,oBAAoB,qBAAqB,MAAM,MAAM,OAAO,MAAM;AAExE,QAAM,cAA6B;AAAA,IACjC,GAAG;AAAA,IACH,oBAAoB,OAAO,aAAa,WAAW,GAAG,QAAQ,OAAO;AAAA,IACrE,iBAAiB,QAAQ,IAAI,GAAG,KAAK,OAAO;AAAA,EAAA;AAG9C,SACE,oBAAC,OAAA,EAAI,WAAW,GAAG,iBAAiB,IAAI,aAAa,IAAI,SAAS,IAAI,OAAO,aAC1E,SAAA,CACH;AAEJ;AAEA,iBAAiB,cAAc;AAexB,SAAS,uBAAuB,OAAe,YAAoB,IAAc;AACtF,SAAO,MAAM,KAAK,EAAE,QAAQ,SAAS,CAAC,GAAG,MAAM,IAAI,SAAS;AAC9D;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/feedback/spinner/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,YAAY,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { Size } from '../../../theme/size-tokens';
|
|
2
|
+
export type SpinnerProps = {
|
|
3
|
+
/** Size variant - uses unified size system */
|
|
4
|
+
size?: Size;
|
|
5
|
+
/** Color variant */
|
|
6
|
+
variant?: 'primary' | 'accent' | 'neutral';
|
|
7
|
+
/** Additional CSS classes to apply to the spinner container */
|
|
8
|
+
className?: string;
|
|
9
|
+
/** Override animation duration (e.g. '0.6s') */
|
|
10
|
+
speed?: string;
|
|
11
|
+
} & React.HTMLAttributes<HTMLDivElement>;
|
|
12
|
+
/**
|
|
13
|
+
* Spinner - Loading indicator
|
|
14
|
+
* Uses unified size system from theme/size-tokens
|
|
15
|
+
*/
|
|
16
|
+
declare function Spinner({ size, variant, className, speed, ...props }: Readonly<SpinnerProps>): import("react/jsx-runtime").JSX.Element;
|
|
17
|
+
declare namespace Spinner {
|
|
18
|
+
var displayName: string;
|
|
19
|
+
}
|
|
20
|
+
export default Spinner;
|
|
21
|
+
//# sourceMappingURL=spinner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"spinner.d.ts","sourceRoot":"","sources":["../../../../src/components/feedback/spinner/spinner.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAgB,MAAM,4BAA4B,CAAC;AAEhE,MAAM,MAAM,YAAY,GAAG;IACzB,8CAA8C;IAC9C,IAAI,CAAC,EAAE,IAAI,CAAC;IACZ,oBAAoB;IACpB,OAAO,CAAC,EAAE,SAAS,GAAG,QAAQ,GAAG,SAAS,CAAC;IAC3C,+DAA+D;IAC/D,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,gDAAgD;IAChD,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,GAAG,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC;AAEzC;;;GAGG;AACH,iBAAS,OAAO,CAAC,EAAE,IAAW,EAAE,OAAmB,EAAE,SAAc,EAAE,KAAK,EAAE,GAAG,KAAK,EAAE,EAAE,QAAQ,CAAC,YAAY,CAAC,2CAsB7G;kBAtBQ,OAAO;;;AA0BhB,eAAe,OAAO,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { jsx } from "react/jsx-runtime";
|
|
2
|
+
import { spinnerSizes } from "../../../theme/size-tokens.js";
|
|
3
|
+
function Spinner({ size = "xl", variant = "primary", className = "", speed, ...props }) {
|
|
4
|
+
const sizeConfig = spinnerSizes[size];
|
|
5
|
+
const variantTopBorder = {
|
|
6
|
+
primary: "border-t-primary",
|
|
7
|
+
accent: "border-t-accent",
|
|
8
|
+
neutral: "border-t-neutral"
|
|
9
|
+
}[variant];
|
|
10
|
+
const duration = speed ? `[animation-duration:${speed}]` : "";
|
|
11
|
+
return /* @__PURE__ */ jsx(
|
|
12
|
+
"div",
|
|
13
|
+
{
|
|
14
|
+
role: "status",
|
|
15
|
+
"aria-label": "Loading",
|
|
16
|
+
"data-variant": variant,
|
|
17
|
+
className: `inline-block border-muted ${variantTopBorder} rounded-full animate-spin box-border ${duration} ${sizeConfig.classes} ${sizeConfig.border} ${className}`,
|
|
18
|
+
...props,
|
|
19
|
+
children: /* @__PURE__ */ jsx("span", { className: "sr-only", children: "Loading..." })
|
|
20
|
+
}
|
|
21
|
+
);
|
|
22
|
+
}
|
|
23
|
+
Spinner.displayName = "Spinner";
|
|
24
|
+
export {
|
|
25
|
+
Spinner as default
|
|
26
|
+
};
|
|
27
|
+
//# sourceMappingURL=spinner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"spinner.js","sources":["../../../../src/components/feedback/spinner/spinner.tsx"],"sourcesContent":["import { Size, spinnerSizes } from '../../../theme/size-tokens';\n\nexport type SpinnerProps = {\n /** Size variant - uses unified size system */\n size?: Size;\n /** Color variant */\n variant?: 'primary' | 'accent' | 'neutral';\n /** Additional CSS classes to apply to the spinner container */\n className?: string;\n /** Override animation duration (e.g. '0.6s') */\n speed?: string;\n} & React.HTMLAttributes<HTMLDivElement>;\n\n/**\n * Spinner - Loading indicator\n * Uses unified size system from theme/size-tokens\n */\nfunction Spinner({ size = 'xl', variant = 'primary', className = '', speed, ...props }: Readonly<SpinnerProps>) {\n const sizeConfig = spinnerSizes[size];\n\n const variantTopBorder = {\n primary: 'border-t-primary',\n accent: 'border-t-accent',\n neutral: 'border-t-neutral'\n }[variant];\n\n const duration = speed ? `[animation-duration:${speed}]` : '';\n\n return (\n <div\n role=\"status\"\n aria-label=\"Loading\"\n data-variant={variant}\n className={`inline-block border-muted ${variantTopBorder} rounded-full animate-spin box-border ${duration} ${sizeConfig.classes} ${sizeConfig.border} ${className}`}\n {...props}\n >\n <span className=\"sr-only\">Loading...</span>\n </div>\n );\n}\n\nSpinner.displayName = 'Spinner';\n\nexport default Spinner;\n"],"names":[],"mappings":";;AAiBA,SAAS,QAAQ,EAAE,OAAO,MAAM,UAAU,WAAW,YAAY,IAAI,OAAO,GAAG,SAAiC;AAC9G,QAAM,aAAa,aAAa,IAAI;AAEpC,QAAM,mBAAmB;AAAA,IACvB,SAAS;AAAA,IACT,QAAQ;AAAA,IACR,SAAS;AAAA,EAAA,EACT,OAAO;AAET,QAAM,WAAW,QAAQ,uBAAuB,KAAK,MAAM;AAE3D,SACE;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,MAAK;AAAA,MACL,cAAW;AAAA,MACX,gBAAc;AAAA,MACd,WAAW,6BAA6B,gBAAgB,yCAAyC,QAAQ,IAAI,WAAW,OAAO,IAAI,WAAW,MAAM,IAAI,SAAS;AAAA,MAChK,GAAG;AAAA,MAEJ,UAAA,oBAAC,QAAA,EAAK,WAAU,WAAU,UAAA,aAAA,CAAU;AAAA,IAAA;AAAA,EAAA;AAG1C;AAEA,QAAQ,cAAc;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/feedback/toast/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,YAAY,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
export type ToastProps = {
|
|
2
|
+
/** Text message to display in the toast (alternative to children) */
|
|
3
|
+
message?: string;
|
|
4
|
+
/** React content to display in the toast (takes precedence over message) */
|
|
5
|
+
children?: React.ReactNode;
|
|
6
|
+
/** Visual style variant indicating the type of notification (info, success, warning, or error) */
|
|
7
|
+
type?: 'info' | 'success' | 'warning' | 'error';
|
|
8
|
+
/** Callback function invoked when the toast is closed (either manually or via auto-dismiss) */
|
|
9
|
+
onClose?: () => void;
|
|
10
|
+
/** Additional CSS classes to apply to the toast container */
|
|
11
|
+
className?: string;
|
|
12
|
+
/** Auto-dismiss duration in milliseconds (0 to disable) */
|
|
13
|
+
duration?: number;
|
|
14
|
+
};
|
|
15
|
+
/**
|
|
16
|
+
* Toast - Notification popup with slide-in/out animations and auto-dismiss
|
|
17
|
+
*/
|
|
18
|
+
declare function Toast({ message, children, type, onClose, className, duration }: Readonly<ToastProps>): import("react/jsx-runtime").JSX.Element;
|
|
19
|
+
declare namespace Toast {
|
|
20
|
+
var displayName: string;
|
|
21
|
+
}
|
|
22
|
+
export default Toast;
|
|
23
|
+
//# sourceMappingURL=toast.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toast.d.ts","sourceRoot":"","sources":["../../../../src/components/feedback/toast/toast.tsx"],"names":[],"mappings":"AAGA,MAAM,MAAM,UAAU,GAAG;IACvB,qEAAqE;IACrE,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,4EAA4E;IAC5E,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,kGAAkG;IAClG,IAAI,CAAC,EAAE,MAAM,GAAG,SAAS,GAAG,SAAS,GAAG,OAAO,CAAC;IAChD,+FAA+F;IAC/F,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,6DAA6D;IAC7D,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,2DAA2D;IAC3D,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF;;GAEG;AACH,iBAAS,KAAK,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,IAAa,EAAE,OAAO,EAAE,SAAc,EAAE,QAAe,EAAE,EAAE,QAAQ,CAAC,UAAU,CAAC,2CA8ClH;kBA9CQ,KAAK;;;AAkDd,eAAe,KAAK,CAAC"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { jsxs, jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useState, useCallback, useEffect } from "react";
|
|
3
|
+
import { createPortal } from "react-dom";
|
|
4
|
+
function Toast({ message, children, type = "info", onClose, className = "", duration = 5e3 }) {
|
|
5
|
+
const [isClosing, setIsClosing] = useState(false);
|
|
6
|
+
const typeClasses = {
|
|
7
|
+
info: "bg-info text-info-foreground",
|
|
8
|
+
success: "bg-success text-success-foreground",
|
|
9
|
+
warning: "bg-warning text-warning-foreground",
|
|
10
|
+
error: "bg-error text-error-foreground"
|
|
11
|
+
};
|
|
12
|
+
const handleClose = useCallback(() => {
|
|
13
|
+
setIsClosing(true);
|
|
14
|
+
setTimeout(() => {
|
|
15
|
+
onClose?.();
|
|
16
|
+
}, 300);
|
|
17
|
+
}, [onClose]);
|
|
18
|
+
useEffect(() => {
|
|
19
|
+
if (duration > 0) {
|
|
20
|
+
const timer = setTimeout(() => {
|
|
21
|
+
handleClose();
|
|
22
|
+
}, duration);
|
|
23
|
+
return () => clearTimeout(timer);
|
|
24
|
+
}
|
|
25
|
+
return void 0;
|
|
26
|
+
}, [duration, handleClose]);
|
|
27
|
+
const toast = /* @__PURE__ */ jsxs(
|
|
28
|
+
"div",
|
|
29
|
+
{
|
|
30
|
+
role: "alert",
|
|
31
|
+
"aria-live": "polite",
|
|
32
|
+
className: `fixed bottom-4 right-4 left-4 sm:left-auto sm:max-w-md px-4 py-3 rounded-md shadow-lg z-[9999] ${typeClasses[type]} transition-all duration-300 ease-out ${isClosing ? "opacity-0 translate-x-full" : "opacity-100 translate-x-0 animate-slideInRight"} ${className}`,
|
|
33
|
+
children: [
|
|
34
|
+
/* @__PURE__ */ jsx("span", { children: children || message }),
|
|
35
|
+
onClose && /* @__PURE__ */ jsx("button", { onClick: handleClose, className: "ml-4 font-bold hover:opacity-70 transition-opacity", "aria-label": "Close", children: "×" })
|
|
36
|
+
]
|
|
37
|
+
}
|
|
38
|
+
);
|
|
39
|
+
return typeof document !== "undefined" ? createPortal(toast, document.body) : toast;
|
|
40
|
+
}
|
|
41
|
+
Toast.displayName = "Toast";
|
|
42
|
+
export {
|
|
43
|
+
Toast as default
|
|
44
|
+
};
|
|
45
|
+
//# sourceMappingURL=toast.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toast.js","sources":["../../../../src/components/feedback/toast/toast.tsx"],"sourcesContent":["import { useEffect, useState, useCallback } from 'react';\nimport { createPortal } from 'react-dom';\n\nexport type ToastProps = {\n /** Text message to display in the toast (alternative to children) */\n message?: string;\n /** React content to display in the toast (takes precedence over message) */\n children?: React.ReactNode;\n /** Visual style variant indicating the type of notification (info, success, warning, or error) */\n type?: 'info' | 'success' | 'warning' | 'error';\n /** Callback function invoked when the toast is closed (either manually or via auto-dismiss) */\n onClose?: () => void;\n /** Additional CSS classes to apply to the toast container */\n className?: string;\n /** Auto-dismiss duration in milliseconds (0 to disable) */\n duration?: number;\n};\n\n/**\n * Toast - Notification popup with slide-in/out animations and auto-dismiss\n */\nfunction Toast({ message, children, type = 'info', onClose, className = '', duration = 5000 }: Readonly<ToastProps>) {\n const [isClosing, setIsClosing] = useState(false);\n\n const typeClasses = {\n info: 'bg-info text-info-foreground',\n success: 'bg-success text-success-foreground',\n warning: 'bg-warning text-warning-foreground',\n error: 'bg-error text-error-foreground'\n };\n\n const handleClose = useCallback(() => {\n setIsClosing(true);\n // Wait for animation to complete before calling onClose\n setTimeout(() => {\n onClose?.();\n }, 300); // Match animation duration\n }, [onClose]);\n\n useEffect(() => {\n if (duration > 0) {\n const timer = setTimeout(() => {\n handleClose();\n }, duration);\n return () => clearTimeout(timer);\n }\n return undefined;\n }, [duration, handleClose]);\n\n const toast = (\n <div\n role=\"alert\"\n aria-live=\"polite\"\n className={`fixed bottom-4 right-4 left-4 sm:left-auto sm:max-w-md px-4 py-3 rounded-md shadow-lg z-[9999] ${typeClasses[type]} transition-all duration-300 ease-out ${\n isClosing ? 'opacity-0 translate-x-full' : 'opacity-100 translate-x-0 animate-slideInRight'\n } ${className}`}\n >\n <span>{children || message}</span>\n {onClose && (\n <button onClick={handleClose} className=\"ml-4 font-bold hover:opacity-70 transition-opacity\" aria-label=\"Close\">\n ×\n </button>\n )}\n </div>\n );\n\n return typeof document !== 'undefined' ? createPortal(toast, document.body) : toast;\n}\n\nToast.displayName = 'Toast';\n\nexport default Toast;\n"],"names":[],"mappings":";;;AAqBA,SAAS,MAAM,EAAE,SAAS,UAAU,OAAO,QAAQ,SAAS,YAAY,IAAI,WAAW,IAAA,GAA8B;AACnH,QAAM,CAAC,WAAW,YAAY,IAAI,SAAS,KAAK;AAEhD,QAAM,cAAc;AAAA,IAClB,MAAM;AAAA,IACN,SAAS;AAAA,IACT,SAAS;AAAA,IACT,OAAO;AAAA,EAAA;AAGT,QAAM,cAAc,YAAY,MAAM;AACpC,iBAAa,IAAI;AAEjB,eAAW,MAAM;AACf,gBAAA;AAAA,IACF,GAAG,GAAG;AAAA,EACR,GAAG,CAAC,OAAO,CAAC;AAEZ,YAAU,MAAM;AACd,QAAI,WAAW,GAAG;AAChB,YAAM,QAAQ,WAAW,MAAM;AAC7B,oBAAA;AAAA,MACF,GAAG,QAAQ;AACX,aAAO,MAAM,aAAa,KAAK;AAAA,IACjC;AACA,WAAO;AAAA,EACT,GAAG,CAAC,UAAU,WAAW,CAAC;AAE1B,QAAM,QACJ;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,MAAK;AAAA,MACL,aAAU;AAAA,MACV,WAAW,kGAAkG,YAAY,IAAI,CAAC,yCAC5H,YAAY,+BAA+B,gDAC7C,IAAI,SAAS;AAAA,MAEb,UAAA;AAAA,QAAA,oBAAC,QAAA,EAAM,sBAAY,QAAA,CAAQ;AAAA,QAC1B,+BACE,UAAA,EAAO,SAAS,aAAa,WAAU,sDAAqD,cAAW,SAAQ,UAAA,IAAA,CAEhH;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAKN,SAAO,OAAO,aAAa,cAAc,aAAa,OAAO,SAAS,IAAI,IAAI;AAChF;AAEA,MAAM,cAAc;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/feedback/tooltip/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,YAAY,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
import { ColorVariant } from '../..';
|
|
3
|
+
export type TooltipProps = {
|
|
4
|
+
/** The element that triggers the tooltip */
|
|
5
|
+
children: ReactNode;
|
|
6
|
+
/** Tooltip text content */
|
|
7
|
+
content: string | ReactNode;
|
|
8
|
+
/** Position of the tooltip relative to the trigger element */
|
|
9
|
+
position?: 'top' | 'bottom' | 'left' | 'right';
|
|
10
|
+
/** Color variant of the tooltip */
|
|
11
|
+
variant?: ColorVariant;
|
|
12
|
+
/** Delay before showing tooltip in ms */
|
|
13
|
+
delayDuration?: number;
|
|
14
|
+
/** Additional CSS classes */
|
|
15
|
+
className?: string;
|
|
16
|
+
};
|
|
17
|
+
/**
|
|
18
|
+
* Tooltip - Simple CSS-based tooltip component
|
|
19
|
+
*
|
|
20
|
+
* Displays a tooltip message on hover. Uses CSS for positioning with
|
|
21
|
+
* portal rendering to escape overflow constraints.
|
|
22
|
+
*
|
|
23
|
+
* @example
|
|
24
|
+
* ```tsx
|
|
25
|
+
* <Tooltip content="Hello">
|
|
26
|
+
* <Button>Hover me</Button>
|
|
27
|
+
* </Tooltip>
|
|
28
|
+
*
|
|
29
|
+
* <Tooltip content="Success!" position="right" variant="success">
|
|
30
|
+
* <Button>Submit</Button>
|
|
31
|
+
* </Tooltip>
|
|
32
|
+
* ```
|
|
33
|
+
*/
|
|
34
|
+
declare function Tooltip({ children, content, position, variant, delayDuration, className }: Readonly<TooltipProps>): import("react/jsx-runtime").JSX.Element;
|
|
35
|
+
declare namespace Tooltip {
|
|
36
|
+
var displayName: string;
|
|
37
|
+
}
|
|
38
|
+
export default Tooltip;
|
|
39
|
+
//# sourceMappingURL=tooltip.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tooltip.d.ts","sourceRoot":"","sources":["../../../../src/components/feedback/tooltip/tooltip.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAA4C,MAAM,OAAO,CAAC;AAE5E,OAAO,EAAE,YAAY,EAAE,MAAM,OAAO,CAAC;AAErC,MAAM,MAAM,YAAY,GAAG;IACzB,4CAA4C;IAC5C,QAAQ,EAAE,SAAS,CAAC;IACpB,2BAA2B;IAC3B,OAAO,EAAE,MAAM,GAAG,SAAS,CAAC;IAC5B,8DAA8D;IAC9D,QAAQ,CAAC,EAAE,KAAK,GAAG,QAAQ,GAAG,MAAM,GAAG,OAAO,CAAC;IAC/C,mCAAmC;IACnC,OAAO,CAAC,EAAE,YAAY,CAAC;IACvB,yCAAyC;IACzC,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,6BAA6B;IAC7B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF;;;;;;;;;;;;;;;;GAgBG;AACH,iBAAS,OAAO,CAAC,EACf,QAAQ,EACR,OAAO,EACP,QAAgB,EAChB,OAAmB,EACnB,aAAmB,EACnB,SAAc,EACf,EAAE,QAAQ,CAAC,YAAY,CAAC,2CAkIxB;kBAzIQ,OAAO;;;AA6IhB,eAAe,OAAO,CAAC"}
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
import { jsx, jsxs, Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { useState, useRef, useCallback, useEffect } from "react";
|
|
3
|
+
import { createPortal } from "react-dom";
|
|
4
|
+
function Tooltip({
|
|
5
|
+
children,
|
|
6
|
+
content,
|
|
7
|
+
position = "top",
|
|
8
|
+
variant = "neutral",
|
|
9
|
+
delayDuration = 200,
|
|
10
|
+
className = ""
|
|
11
|
+
}) {
|
|
12
|
+
const [isOpen, setIsOpen] = useState(false);
|
|
13
|
+
const [coords, setCoords] = useState({ top: 0, left: 0 });
|
|
14
|
+
const triggerRef = useRef(null);
|
|
15
|
+
const tooltipRef = useRef(null);
|
|
16
|
+
const timeoutRef = useRef(void 0);
|
|
17
|
+
const calculatePosition = useCallback(() => {
|
|
18
|
+
if (!triggerRef.current || !tooltipRef.current) return;
|
|
19
|
+
const triggerRect = triggerRef.current.getBoundingClientRect();
|
|
20
|
+
const tooltipRect = tooltipRef.current.getBoundingClientRect();
|
|
21
|
+
const offset = 8;
|
|
22
|
+
let top = 0;
|
|
23
|
+
let left = 0;
|
|
24
|
+
switch (position) {
|
|
25
|
+
case "top":
|
|
26
|
+
top = triggerRect.top - tooltipRect.height - offset;
|
|
27
|
+
left = triggerRect.left + triggerRect.width / 2 - tooltipRect.width / 2;
|
|
28
|
+
break;
|
|
29
|
+
case "bottom":
|
|
30
|
+
top = triggerRect.bottom + offset;
|
|
31
|
+
left = triggerRect.left + triggerRect.width / 2 - tooltipRect.width / 2;
|
|
32
|
+
break;
|
|
33
|
+
case "left":
|
|
34
|
+
top = triggerRect.top + triggerRect.height / 2 - tooltipRect.height / 2;
|
|
35
|
+
left = triggerRect.left - tooltipRect.width - offset;
|
|
36
|
+
break;
|
|
37
|
+
case "right":
|
|
38
|
+
top = triggerRect.top + triggerRect.height / 2 - tooltipRect.height / 2;
|
|
39
|
+
left = triggerRect.right + offset;
|
|
40
|
+
break;
|
|
41
|
+
}
|
|
42
|
+
const padding = 8;
|
|
43
|
+
if (left < padding) left = padding;
|
|
44
|
+
if (left + tooltipRect.width > window.innerWidth - padding) {
|
|
45
|
+
left = window.innerWidth - tooltipRect.width - padding;
|
|
46
|
+
}
|
|
47
|
+
if (top < padding) top = padding;
|
|
48
|
+
if (top + tooltipRect.height > window.innerHeight - padding) {
|
|
49
|
+
top = window.innerHeight - tooltipRect.height - padding;
|
|
50
|
+
}
|
|
51
|
+
setCoords({ top, left });
|
|
52
|
+
}, [position]);
|
|
53
|
+
const handleMouseEnter = () => {
|
|
54
|
+
timeoutRef.current = window.setTimeout(() => {
|
|
55
|
+
setIsOpen(true);
|
|
56
|
+
}, delayDuration);
|
|
57
|
+
};
|
|
58
|
+
const handleMouseLeave = () => {
|
|
59
|
+
if (timeoutRef.current) {
|
|
60
|
+
clearTimeout(timeoutRef.current);
|
|
61
|
+
}
|
|
62
|
+
setIsOpen(false);
|
|
63
|
+
};
|
|
64
|
+
useEffect(() => {
|
|
65
|
+
if (isOpen) {
|
|
66
|
+
requestAnimationFrame(() => {
|
|
67
|
+
calculatePosition();
|
|
68
|
+
});
|
|
69
|
+
const handleScroll = () => calculatePosition();
|
|
70
|
+
const handleResize = () => calculatePosition();
|
|
71
|
+
window.addEventListener("scroll", handleScroll, true);
|
|
72
|
+
window.addEventListener("resize", handleResize);
|
|
73
|
+
return () => {
|
|
74
|
+
window.removeEventListener("scroll", handleScroll, true);
|
|
75
|
+
window.removeEventListener("resize", handleResize);
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
return void 0;
|
|
79
|
+
}, [isOpen, calculatePosition]);
|
|
80
|
+
useEffect(() => {
|
|
81
|
+
return () => {
|
|
82
|
+
if (timeoutRef.current) {
|
|
83
|
+
clearTimeout(timeoutRef.current);
|
|
84
|
+
}
|
|
85
|
+
};
|
|
86
|
+
}, []);
|
|
87
|
+
const variantClasses = {
|
|
88
|
+
primary: "bg-primary text-primary-foreground",
|
|
89
|
+
accent: "bg-accent text-accent-foreground",
|
|
90
|
+
info: "bg-info text-info-foreground",
|
|
91
|
+
success: "bg-success text-success-foreground",
|
|
92
|
+
warning: "bg-warning text-warning-foreground",
|
|
93
|
+
error: "bg-error text-error-foreground",
|
|
94
|
+
neutral: "bg-muted text-muted-foreground"
|
|
95
|
+
};
|
|
96
|
+
const tooltip = isOpen ? /* @__PURE__ */ jsx(
|
|
97
|
+
"div",
|
|
98
|
+
{
|
|
99
|
+
ref: tooltipRef,
|
|
100
|
+
role: "tooltip",
|
|
101
|
+
className: `fixed z-9999 px-3 py-1.5 text-xs font-medium rounded-md shadow-md max-w-xs animate-in fade-in-0 zoom-in-95 ${variantClasses[variant]} ${className}`,
|
|
102
|
+
style: {
|
|
103
|
+
top: `${coords.top}px`,
|
|
104
|
+
left: `${coords.left}px`
|
|
105
|
+
},
|
|
106
|
+
children: content
|
|
107
|
+
}
|
|
108
|
+
) : null;
|
|
109
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
110
|
+
/* @__PURE__ */ jsx(
|
|
111
|
+
"span",
|
|
112
|
+
{
|
|
113
|
+
ref: triggerRef,
|
|
114
|
+
onMouseEnter: handleMouseEnter,
|
|
115
|
+
onMouseLeave: handleMouseLeave,
|
|
116
|
+
onFocus: handleMouseEnter,
|
|
117
|
+
onBlur: handleMouseLeave,
|
|
118
|
+
className: "inline-flex",
|
|
119
|
+
children
|
|
120
|
+
}
|
|
121
|
+
),
|
|
122
|
+
tooltip && createPortal(tooltip, document.body)
|
|
123
|
+
] });
|
|
124
|
+
}
|
|
125
|
+
Tooltip.displayName = "Tooltip";
|
|
126
|
+
export {
|
|
127
|
+
Tooltip as default
|
|
128
|
+
};
|
|
129
|
+
//# sourceMappingURL=tooltip.js.map
|