shad-m 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +260 -0
- package/dist/assets/Animation/index.d.ts +25655 -0
- package/dist/assets/Animation/index.d.ts.map +1 -0
- package/dist/assets/Animation/index.js +180 -0
- package/dist/assets/Animation/index.js.map +1 -0
- package/dist/assets/Animation/index.mjs +79 -0
- package/dist/assets/Animation/index.mjs.map +1 -0
- package/dist/assets/Icon/index.d.ts +420 -0
- package/dist/assets/Icon/index.d.ts.map +1 -0
- package/dist/assets/Icon/index.js +2102 -0
- package/dist/assets/Icon/index.js.map +1 -0
- package/dist/assets/Icon/index.mjs +421 -0
- package/dist/assets/Icon/index.mjs.map +1 -0
- package/dist/assets/Image/index.d.ts +151 -0
- package/dist/assets/Image/index.d.ts.map +1 -0
- package/dist/assets/Image/index.js +755 -0
- package/dist/assets/Image/index.js.map +1 -0
- package/dist/assets/Image/index.mjs +150 -0
- package/dist/assets/Image/index.mjs.map +1 -0
- package/dist/common/display/countdown.d.ts +26 -0
- package/dist/common/display/countdown.d.ts.map +1 -0
- package/dist/common/display/countdown.js +68 -0
- package/dist/common/display/countdown.js.map +1 -0
- package/dist/common/display/countdown.mjs +46 -0
- package/dist/common/display/countdown.mjs.map +1 -0
- package/dist/common/display/display-field-group.d.ts +59 -0
- package/dist/common/display/display-field-group.d.ts.map +1 -0
- package/dist/common/display/display-field-group.js +91 -0
- package/dist/common/display/display-field-group.js.map +1 -0
- package/dist/common/display/display-field-group.mjs +89 -0
- package/dist/common/display/display-field-group.mjs.map +1 -0
- package/dist/common/display/display-field.d.ts +45 -0
- package/dist/common/display/display-field.d.ts.map +1 -0
- package/dist/common/display/display-field.js +46 -0
- package/dist/common/display/display-field.js.map +1 -0
- package/dist/common/display/display-field.mjs +40 -0
- package/dist/common/display/display-field.mjs.map +1 -0
- package/dist/common/display/display-html-string.d.ts +7 -0
- package/dist/common/display/display-html-string.d.ts.map +1 -0
- package/dist/common/display/display-html-string.js +52 -0
- package/dist/common/display/display-html-string.js.map +1 -0
- package/dist/common/display/display-html-string.mjs +30 -0
- package/dist/common/display/display-html-string.mjs.map +1 -0
- package/dist/common/display/index.d.ts +16 -0
- package/dist/common/display/index.d.ts.map +1 -0
- package/dist/common/display/index.js +59 -0
- package/dist/common/display/index.js.map +1 -0
- package/dist/common/display/index.mjs +10 -0
- package/dist/common/display/index.mjs.map +1 -0
- package/dist/common/display/page-breadcrumb.d.ts +19 -0
- package/dist/common/display/page-breadcrumb.d.ts.map +1 -0
- package/dist/common/display/page-breadcrumb.js +43 -0
- package/dist/common/display/page-breadcrumb.js.map +1 -0
- package/dist/common/display/page-breadcrumb.mjs +37 -0
- package/dist/common/display/page-breadcrumb.mjs.map +1 -0
- package/dist/common/display/page-v2.d.ts +15 -0
- package/dist/common/display/page-v2.d.ts.map +1 -0
- package/dist/common/display/page-v2.js +58 -0
- package/dist/common/display/page-v2.js.map +1 -0
- package/dist/common/display/page-v2.mjs +20 -0
- package/dist/common/display/page-v2.mjs.map +1 -0
- package/dist/common/display/page.d.ts +53 -0
- package/dist/common/display/page.d.ts.map +1 -0
- package/dist/common/display/page.js +155 -0
- package/dist/common/display/page.js.map +1 -0
- package/dist/common/display/page.mjs +138 -0
- package/dist/common/display/page.mjs.map +1 -0
- package/dist/common/display/score-meter.d.ts +22 -0
- package/dist/common/display/score-meter.d.ts.map +1 -0
- package/dist/common/display/score-meter.js +161 -0
- package/dist/common/display/score-meter.js.map +1 -0
- package/dist/common/display/score-meter.mjs +140 -0
- package/dist/common/display/score-meter.mjs.map +1 -0
- package/dist/common/display/sidebar/app-sidebar.d.ts +28 -0
- package/dist/common/display/sidebar/app-sidebar.d.ts.map +1 -0
- package/dist/common/display/sidebar/app-sidebar.js +114 -0
- package/dist/common/display/sidebar/app-sidebar.js.map +1 -0
- package/dist/common/display/sidebar/app-sidebar.mjs +92 -0
- package/dist/common/display/sidebar/app-sidebar.mjs.map +1 -0
- package/dist/common/display/sidebar/index.d.ts +30 -0
- package/dist/common/display/sidebar/index.d.ts.map +1 -0
- package/dist/common/display/sidebar/index.js +89 -0
- package/dist/common/display/sidebar/index.js.map +1 -0
- package/dist/common/display/sidebar/index.mjs +81 -0
- package/dist/common/display/sidebar/index.mjs.map +1 -0
- package/dist/common/display/sidebar/nav-main.d.ts +17 -0
- package/dist/common/display/sidebar/nav-main.d.ts.map +1 -0
- package/dist/common/display/sidebar/nav-main.js +406 -0
- package/dist/common/display/sidebar/nav-main.js.map +1 -0
- package/dist/common/display/sidebar/nav-main.mjs +400 -0
- package/dist/common/display/sidebar/nav-main.mjs.map +1 -0
- package/dist/common/display/sidebar/sidebar-sheet.d.ts +46 -0
- package/dist/common/display/sidebar/sidebar-sheet.d.ts.map +1 -0
- package/dist/common/display/sidebar/sidebar-sheet.js +140 -0
- package/dist/common/display/sidebar/sidebar-sheet.js.map +1 -0
- package/dist/common/display/sidebar/sidebar-sheet.mjs +118 -0
- package/dist/common/display/sidebar/sidebar-sheet.mjs.map +1 -0
- package/dist/common/display/sidebar/types.d.ts +18 -0
- package/dist/common/display/sidebar/types.d.ts.map +1 -0
- package/dist/common/display/sidebar/types.js +4 -0
- package/dist/common/display/sidebar/types.js.map +1 -0
- package/dist/common/display/sidebar/types.mjs +3 -0
- package/dist/common/display/sidebar/types.mjs.map +1 -0
- package/dist/common/display/status-state.d.ts +16 -0
- package/dist/common/display/status-state.d.ts.map +1 -0
- package/dist/common/display/status-state.js +97 -0
- package/dist/common/display/status-state.js.map +1 -0
- package/dist/common/display/status-state.mjs +88 -0
- package/dist/common/display/status-state.mjs.map +1 -0
- package/dist/common/forms/auto-form.d.ts +17 -0
- package/dist/common/forms/auto-form.d.ts.map +1 -0
- package/dist/common/forms/auto-form.js +101 -0
- package/dist/common/forms/auto-form.js.map +1 -0
- package/dist/common/forms/auto-form.mjs +78 -0
- package/dist/common/forms/auto-form.mjs.map +1 -0
- package/dist/common/forms/form-field.d.ts +16 -0
- package/dist/common/forms/form-field.d.ts.map +1 -0
- package/dist/common/forms/form-field.js +58 -0
- package/dist/common/forms/form-field.js.map +1 -0
- package/dist/common/forms/form-field.mjs +56 -0
- package/dist/common/forms/form-field.mjs.map +1 -0
- package/dist/common/forms/form-input-field.d.ts +16 -0
- package/dist/common/forms/form-input-field.d.ts.map +1 -0
- package/dist/common/forms/form-input-field.js +64 -0
- package/dist/common/forms/form-input-field.js.map +1 -0
- package/dist/common/forms/form-input-field.mjs +62 -0
- package/dist/common/forms/form-input-field.mjs.map +1 -0
- package/dist/common/forms/index.d.ts +7 -0
- package/dist/common/forms/index.d.ts.map +1 -0
- package/dist/common/forms/index.js +22 -0
- package/dist/common/forms/index.js.map +1 -0
- package/dist/common/forms/index.mjs +5 -0
- package/dist/common/forms/index.mjs.map +1 -0
- package/dist/common/forms/switch-field.d.ts +19 -0
- package/dist/common/forms/switch-field.d.ts.map +1 -0
- package/dist/common/forms/switch-field.js +106 -0
- package/dist/common/forms/switch-field.js.map +1 -0
- package/dist/common/forms/switch-field.mjs +104 -0
- package/dist/common/forms/switch-field.mjs.map +1 -0
- package/dist/common/interactive/alert-dialog-wrapper.d.ts +41 -0
- package/dist/common/interactive/alert-dialog-wrapper.d.ts.map +1 -0
- package/dist/common/interactive/alert-dialog-wrapper.js +141 -0
- package/dist/common/interactive/alert-dialog-wrapper.js.map +1 -0
- package/dist/common/interactive/alert-dialog-wrapper.mjs +119 -0
- package/dist/common/interactive/alert-dialog-wrapper.mjs.map +1 -0
- package/dist/common/interactive/autocomplete.d.ts +21 -0
- package/dist/common/interactive/autocomplete.d.ts.map +1 -0
- package/dist/common/interactive/autocomplete.js +178 -0
- package/dist/common/interactive/autocomplete.js.map +1 -0
- package/dist/common/interactive/autocomplete.mjs +157 -0
- package/dist/common/interactive/autocomplete.mjs.map +1 -0
- package/dist/common/interactive/copy-tooltip.d.ts +27 -0
- package/dist/common/interactive/copy-tooltip.d.ts.map +1 -0
- package/dist/common/interactive/copy-tooltip.js +152 -0
- package/dist/common/interactive/copy-tooltip.js.map +1 -0
- package/dist/common/interactive/copy-tooltip.mjs +143 -0
- package/dist/common/interactive/copy-tooltip.mjs.map +1 -0
- package/dist/common/interactive/date-field.d.ts +98 -0
- package/dist/common/interactive/date-field.d.ts.map +1 -0
- package/dist/common/interactive/date-field.js +303 -0
- package/dist/common/interactive/date-field.js.map +1 -0
- package/dist/common/interactive/date-field.mjs +281 -0
- package/dist/common/interactive/date-field.mjs.map +1 -0
- package/dist/common/interactive/date-input/date-input.d.ts +12 -0
- package/dist/common/interactive/date-input/date-input.d.ts.map +1 -0
- package/dist/common/interactive/date-input/date-input.js +68 -0
- package/dist/common/interactive/date-input/date-input.js.map +1 -0
- package/dist/common/interactive/date-input/date-input.mjs +62 -0
- package/dist/common/interactive/date-input/date-input.mjs.map +1 -0
- package/dist/common/interactive/date-input/index.d.ts +4 -0
- package/dist/common/interactive/date-input/index.d.ts.map +1 -0
- package/dist/common/interactive/date-input/index.js +17 -0
- package/dist/common/interactive/date-input/index.js.map +1 -0
- package/dist/common/interactive/date-input/index.mjs +4 -0
- package/dist/common/interactive/date-input/index.mjs.map +1 -0
- package/dist/common/interactive/date-input/types.d.ts +17 -0
- package/dist/common/interactive/date-input/types.d.ts.map +1 -0
- package/dist/common/interactive/date-input/types.js +4 -0
- package/dist/common/interactive/date-input/types.js.map +1 -0
- package/dist/common/interactive/date-input/types.mjs +3 -0
- package/dist/common/interactive/date-input/types.mjs.map +1 -0
- package/dist/common/interactive/date-input/use-typed-date.d.ts +17 -0
- package/dist/common/interactive/date-input/use-typed-date.d.ts.map +1 -0
- package/dist/common/interactive/date-input/use-typed-date.js +478 -0
- package/dist/common/interactive/date-input/use-typed-date.js.map +1 -0
- package/dist/common/interactive/date-input/use-typed-date.mjs +476 -0
- package/dist/common/interactive/date-input/use-typed-date.mjs.map +1 -0
- package/dist/common/interactive/date-input/utils.d.ts +5 -0
- package/dist/common/interactive/date-input/utils.d.ts.map +1 -0
- package/dist/common/interactive/date-input/utils.js +34 -0
- package/dist/common/interactive/date-input/utils.js.map +1 -0
- package/dist/common/interactive/date-input/utils.mjs +29 -0
- package/dist/common/interactive/date-input/utils.mjs.map +1 -0
- package/dist/common/interactive/date-picker.d.ts +114 -0
- package/dist/common/interactive/date-picker.d.ts.map +1 -0
- package/dist/common/interactive/date-picker.js +616 -0
- package/dist/common/interactive/date-picker.js.map +1 -0
- package/dist/common/interactive/date-picker.mjs +594 -0
- package/dist/common/interactive/date-picker.mjs.map +1 -0
- package/dist/common/interactive/date-range-input/date-range-input.d.ts +23 -0
- package/dist/common/interactive/date-range-input/date-range-input.d.ts.map +1 -0
- package/dist/common/interactive/date-range-input/date-range-input.js +82 -0
- package/dist/common/interactive/date-range-input/date-range-input.js.map +1 -0
- package/dist/common/interactive/date-range-input/date-range-input.mjs +76 -0
- package/dist/common/interactive/date-range-input/date-range-input.mjs.map +1 -0
- package/dist/common/interactive/date-range-input/index.d.ts +4 -0
- package/dist/common/interactive/date-range-input/index.d.ts.map +1 -0
- package/dist/common/interactive/date-range-input/index.js +12 -0
- package/dist/common/interactive/date-range-input/index.js.map +1 -0
- package/dist/common/interactive/date-range-input/index.mjs +3 -0
- package/dist/common/interactive/date-range-input/index.mjs.map +1 -0
- package/dist/common/interactive/date-range-input/types.d.ts +35 -0
- package/dist/common/interactive/date-range-input/types.d.ts.map +1 -0
- package/dist/common/interactive/date-range-input/types.js +4 -0
- package/dist/common/interactive/date-range-input/types.js.map +1 -0
- package/dist/common/interactive/date-range-input/types.mjs +3 -0
- package/dist/common/interactive/date-range-input/types.mjs.map +1 -0
- package/dist/common/interactive/date-range-input/use-typed-date-range.d.ts +17 -0
- package/dist/common/interactive/date-range-input/use-typed-date-range.d.ts.map +1 -0
- package/dist/common/interactive/date-range-input/use-typed-date-range.js +602 -0
- package/dist/common/interactive/date-range-input/use-typed-date-range.js.map +1 -0
- package/dist/common/interactive/date-range-input/use-typed-date-range.mjs +600 -0
- package/dist/common/interactive/date-range-input/use-typed-date-range.mjs.map +1 -0
- package/dist/common/interactive/date-time-picker.d.ts +86 -0
- package/dist/common/interactive/date-time-picker.d.ts.map +1 -0
- package/dist/common/interactive/date-time-picker.js +215 -0
- package/dist/common/interactive/date-time-picker.js.map +1 -0
- package/dist/common/interactive/date-time-picker.mjs +213 -0
- package/dist/common/interactive/date-time-picker.mjs.map +1 -0
- package/dist/common/interactive/dialog-wrapper.d.ts +34 -0
- package/dist/common/interactive/dialog-wrapper.d.ts.map +1 -0
- package/dist/common/interactive/dialog-wrapper.js +124 -0
- package/dist/common/interactive/dialog-wrapper.js.map +1 -0
- package/dist/common/interactive/dialog-wrapper.mjs +102 -0
- package/dist/common/interactive/dialog-wrapper.mjs.map +1 -0
- package/dist/common/interactive/filter.d.ts +51 -0
- package/dist/common/interactive/filter.d.ts.map +1 -0
- package/dist/common/interactive/filter.js +287 -0
- package/dist/common/interactive/filter.js.map +1 -0
- package/dist/common/interactive/filter.mjs +280 -0
- package/dist/common/interactive/filter.mjs.map +1 -0
- package/dist/common/interactive/index.d.ts +41 -0
- package/dist/common/interactive/index.d.ts.map +1 -0
- package/dist/common/interactive/index.js +235 -0
- package/dist/common/interactive/index.js.map +1 -0
- package/dist/common/interactive/index.mjs +24 -0
- package/dist/common/interactive/index.mjs.map +1 -0
- package/dist/common/interactive/list.d.ts +36 -0
- package/dist/common/interactive/list.d.ts.map +1 -0
- package/dist/common/interactive/list.js +160 -0
- package/dist/common/interactive/list.js.map +1 -0
- package/dist/common/interactive/list.mjs +134 -0
- package/dist/common/interactive/list.mjs.map +1 -0
- package/dist/common/interactive/otp-dialog/index.d.ts +7 -0
- package/dist/common/interactive/otp-dialog/index.d.ts.map +1 -0
- package/dist/common/interactive/otp-dialog/index.js +35 -0
- package/dist/common/interactive/otp-dialog/index.js.map +1 -0
- package/dist/common/interactive/otp-dialog/index.mjs +6 -0
- package/dist/common/interactive/otp-dialog/index.mjs.map +1 -0
- package/dist/common/interactive/otp-dialog/otp-dialog.d.ts +34 -0
- package/dist/common/interactive/otp-dialog/otp-dialog.d.ts.map +1 -0
- package/dist/common/interactive/otp-dialog/otp-dialog.js +325 -0
- package/dist/common/interactive/otp-dialog/otp-dialog.js.map +1 -0
- package/dist/common/interactive/otp-dialog/otp-dialog.mjs +303 -0
- package/dist/common/interactive/otp-dialog/otp-dialog.mjs.map +1 -0
- package/dist/common/interactive/otp-dialog/reducer.d.ts +11 -0
- package/dist/common/interactive/otp-dialog/reducer.d.ts.map +1 -0
- package/dist/common/interactive/otp-dialog/reducer.js +40 -0
- package/dist/common/interactive/otp-dialog/reducer.js.map +1 -0
- package/dist/common/interactive/otp-dialog/reducer.mjs +37 -0
- package/dist/common/interactive/otp-dialog/reducer.mjs.map +1 -0
- package/dist/common/interactive/otp-dialog/types.d.ts +82 -0
- package/dist/common/interactive/otp-dialog/types.d.ts.map +1 -0
- package/dist/common/interactive/otp-dialog/types.js +15 -0
- package/dist/common/interactive/otp-dialog/types.js.map +1 -0
- package/dist/common/interactive/otp-dialog/types.mjs +13 -0
- package/dist/common/interactive/otp-dialog/types.mjs.map +1 -0
- package/dist/common/interactive/otp-dialog/utils.d.ts +17 -0
- package/dist/common/interactive/otp-dialog/utils.d.ts.map +1 -0
- package/dist/common/interactive/otp-dialog/utils.js +24 -0
- package/dist/common/interactive/otp-dialog/utils.js.map +1 -0
- package/dist/common/interactive/otp-dialog/utils.mjs +21 -0
- package/dist/common/interactive/otp-dialog/utils.mjs.map +1 -0
- package/dist/common/interactive/pagination/PaginationSkeleton.d.ts +6 -0
- package/dist/common/interactive/pagination/PaginationSkeleton.d.ts.map +1 -0
- package/dist/common/interactive/pagination/PaginationSkeleton.js +51 -0
- package/dist/common/interactive/pagination/PaginationSkeleton.js.map +1 -0
- package/dist/common/interactive/pagination/PaginationSkeleton.mjs +49 -0
- package/dist/common/interactive/pagination/PaginationSkeleton.mjs.map +1 -0
- package/dist/common/interactive/pagination/index.d.ts +14 -0
- package/dist/common/interactive/pagination/index.d.ts.map +1 -0
- package/dist/common/interactive/pagination/index.js +235 -0
- package/dist/common/interactive/pagination/index.js.map +1 -0
- package/dist/common/interactive/pagination/index.mjs +223 -0
- package/dist/common/interactive/pagination/index.mjs.map +1 -0
- package/dist/common/interactive/pagination/usePagination.d.ts +3 -0
- package/dist/common/interactive/pagination/usePagination.d.ts.map +1 -0
- package/dist/common/interactive/pagination/usePagination.js +28 -0
- package/dist/common/interactive/pagination/usePagination.js.map +1 -0
- package/dist/common/interactive/pagination/usePagination.mjs +25 -0
- package/dist/common/interactive/pagination/usePagination.mjs.map +1 -0
- package/dist/common/interactive/popover-wrapper.d.ts +38 -0
- package/dist/common/interactive/popover-wrapper.d.ts.map +1 -0
- package/dist/common/interactive/popover-wrapper.js +138 -0
- package/dist/common/interactive/popover-wrapper.js.map +1 -0
- package/dist/common/interactive/popover-wrapper.mjs +116 -0
- package/dist/common/interactive/popover-wrapper.mjs.map +1 -0
- package/dist/common/interactive/pressable.d.ts +11 -0
- package/dist/common/interactive/pressable.d.ts.map +1 -0
- package/dist/common/interactive/pressable.js +84 -0
- package/dist/common/interactive/pressable.js.map +1 -0
- package/dist/common/interactive/pressable.mjs +62 -0
- package/dist/common/interactive/pressable.mjs.map +1 -0
- package/dist/common/interactive/select/context.d.ts +6 -0
- package/dist/common/interactive/select/context.d.ts.map +1 -0
- package/dist/common/interactive/select/context.js +38 -0
- package/dist/common/interactive/select/context.js.map +1 -0
- package/dist/common/interactive/select/context.mjs +14 -0
- package/dist/common/interactive/select/context.mjs.map +1 -0
- package/dist/common/interactive/select/index.d.ts +18 -0
- package/dist/common/interactive/select/index.d.ts.map +1 -0
- package/dist/common/interactive/select/index.js +123 -0
- package/dist/common/interactive/select/index.js.map +1 -0
- package/dist/common/interactive/select/index.mjs +18 -0
- package/dist/common/interactive/select/index.mjs.map +1 -0
- package/dist/common/interactive/select/select-body.d.ts +5 -0
- package/dist/common/interactive/select/select-body.d.ts.map +1 -0
- package/dist/common/interactive/select/select-body.js +89 -0
- package/dist/common/interactive/select/select-body.js.map +1 -0
- package/dist/common/interactive/select/select-body.mjs +67 -0
- package/dist/common/interactive/select/select-body.mjs.map +1 -0
- package/dist/common/interactive/select/select-close.d.ts +3 -0
- package/dist/common/interactive/select/select-close.d.ts.map +1 -0
- package/dist/common/interactive/select/select-close.js +38 -0
- package/dist/common/interactive/select/select-close.js.map +1 -0
- package/dist/common/interactive/select/select-close.mjs +16 -0
- package/dist/common/interactive/select/select-close.mjs.map +1 -0
- package/dist/common/interactive/select/select-content-auto-layout.d.ts +5 -0
- package/dist/common/interactive/select/select-content-auto-layout.d.ts.map +1 -0
- package/dist/common/interactive/select/select-content-auto-layout.js +221 -0
- package/dist/common/interactive/select/select-content-auto-layout.js.map +1 -0
- package/dist/common/interactive/select/select-content-auto-layout.mjs +199 -0
- package/dist/common/interactive/select/select-content-auto-layout.mjs.map +1 -0
- package/dist/common/interactive/select/select-content-group-auto-layout.d.ts +5 -0
- package/dist/common/interactive/select/select-content-group-auto-layout.d.ts.map +1 -0
- package/dist/common/interactive/select/select-content-group-auto-layout.js +411 -0
- package/dist/common/interactive/select/select-content-group-auto-layout.js.map +1 -0
- package/dist/common/interactive/select/select-content-group-auto-layout.mjs +389 -0
- package/dist/common/interactive/select/select-content-group-auto-layout.mjs.map +1 -0
- package/dist/common/interactive/select/select-content.d.ts +5 -0
- package/dist/common/interactive/select/select-content.d.ts.map +1 -0
- package/dist/common/interactive/select/select-content.js +187 -0
- package/dist/common/interactive/select/select-content.js.map +1 -0
- package/dist/common/interactive/select/select-content.mjs +165 -0
- package/dist/common/interactive/select/select-content.mjs.map +1 -0
- package/dist/common/interactive/select/select-footer.d.ts +5 -0
- package/dist/common/interactive/select/select-footer.d.ts.map +1 -0
- package/dist/common/interactive/select/select-footer.js +82 -0
- package/dist/common/interactive/select/select-footer.js.map +1 -0
- package/dist/common/interactive/select/select-footer.mjs +60 -0
- package/dist/common/interactive/select/select-footer.mjs.map +1 -0
- package/dist/common/interactive/select/select-item.d.ts +6 -0
- package/dist/common/interactive/select/select-item.d.ts.map +1 -0
- package/dist/common/interactive/select/select-item.js +214 -0
- package/dist/common/interactive/select/select-item.js.map +1 -0
- package/dist/common/interactive/select/select-item.mjs +191 -0
- package/dist/common/interactive/select/select-item.mjs.map +1 -0
- package/dist/common/interactive/select/select-layout.d.ts +8 -0
- package/dist/common/interactive/select/select-layout.d.ts.map +1 -0
- package/dist/common/interactive/select/select-layout.js +66 -0
- package/dist/common/interactive/select/select-layout.js.map +1 -0
- package/dist/common/interactive/select/select-layout.mjs +41 -0
- package/dist/common/interactive/select/select-layout.mjs.map +1 -0
- package/dist/common/interactive/select/select-search.d.ts +8 -0
- package/dist/common/interactive/select/select-search.d.ts.map +1 -0
- package/dist/common/interactive/select/select-search.js +55 -0
- package/dist/common/interactive/select/select-search.js.map +1 -0
- package/dist/common/interactive/select/select-search.mjs +33 -0
- package/dist/common/interactive/select/select-search.mjs.map +1 -0
- package/dist/common/interactive/select/select-states.d.ts +6 -0
- package/dist/common/interactive/select/select-states.d.ts.map +1 -0
- package/dist/common/interactive/select/select-states.js +57 -0
- package/dist/common/interactive/select/select-states.js.map +1 -0
- package/dist/common/interactive/select/select-states.mjs +34 -0
- package/dist/common/interactive/select/select-states.mjs.map +1 -0
- package/dist/common/interactive/select/select-trigger.d.ts +7 -0
- package/dist/common/interactive/select/select-trigger.d.ts.map +1 -0
- package/dist/common/interactive/select/select-trigger.js +310 -0
- package/dist/common/interactive/select/select-trigger.js.map +1 -0
- package/dist/common/interactive/select/select-trigger.mjs +286 -0
- package/dist/common/interactive/select/select-trigger.mjs.map +1 -0
- package/dist/common/interactive/select/select-value.d.ts +5 -0
- package/dist/common/interactive/select/select-value.d.ts.map +1 -0
- package/dist/common/interactive/select/select-value.js +52 -0
- package/dist/common/interactive/select/select-value.js.map +1 -0
- package/dist/common/interactive/select/select-value.mjs +30 -0
- package/dist/common/interactive/select/select-value.mjs.map +1 -0
- package/dist/common/interactive/select/select.css +62 -0
- package/dist/common/interactive/select/select.d.ts +4 -0
- package/dist/common/interactive/select/select.d.ts.map +1 -0
- package/dist/common/interactive/select/select.js +184 -0
- package/dist/common/interactive/select/select.js.map +1 -0
- package/dist/common/interactive/select/select.mjs +162 -0
- package/dist/common/interactive/select/select.mjs.map +1 -0
- package/dist/common/interactive/select/types.d.ts +213 -0
- package/dist/common/interactive/select/types.d.ts.map +1 -0
- package/dist/common/interactive/select/types.js +4 -0
- package/dist/common/interactive/select/types.js.map +1 -0
- package/dist/common/interactive/select/types.mjs +3 -0
- package/dist/common/interactive/select/types.mjs.map +1 -0
- package/dist/common/interactive/select/utils.d.ts +8 -0
- package/dist/common/interactive/select/utils.d.ts.map +1 -0
- package/dist/common/interactive/select/utils.js +31 -0
- package/dist/common/interactive/select/utils.js.map +1 -0
- package/dist/common/interactive/select/utils.mjs +28 -0
- package/dist/common/interactive/select/utils.mjs.map +1 -0
- package/dist/common/interactive/select/variants.d.ts +4 -0
- package/dist/common/interactive/select/variants.d.ts.map +1 -0
- package/dist/common/interactive/select/variants.js +27 -0
- package/dist/common/interactive/select/variants.js.map +1 -0
- package/dist/common/interactive/select/variants.mjs +25 -0
- package/dist/common/interactive/select/variants.mjs.map +1 -0
- package/dist/common/interactive/select-chip.d.ts +20 -0
- package/dist/common/interactive/select-chip.d.ts.map +1 -0
- package/dist/common/interactive/select-chip.js +76 -0
- package/dist/common/interactive/select-chip.js.map +1 -0
- package/dist/common/interactive/select-chip.mjs +74 -0
- package/dist/common/interactive/select-chip.mjs.map +1 -0
- package/dist/common/interactive/select-level.d.ts +19 -0
- package/dist/common/interactive/select-level.d.ts.map +1 -0
- package/dist/common/interactive/select-level.js +236 -0
- package/dist/common/interactive/select-level.js.map +1 -0
- package/dist/common/interactive/select-level.mjs +230 -0
- package/dist/common/interactive/select-level.mjs.map +1 -0
- package/dist/common/interactive/select-range.d.ts +30 -0
- package/dist/common/interactive/select-range.d.ts.map +1 -0
- package/dist/common/interactive/select-range.js +211 -0
- package/dist/common/interactive/select-range.js.map +1 -0
- package/dist/common/interactive/select-range.mjs +209 -0
- package/dist/common/interactive/select-range.mjs.map +1 -0
- package/dist/common/interactive/select-with-api.d.ts +97 -0
- package/dist/common/interactive/select-with-api.d.ts.map +1 -0
- package/dist/common/interactive/select-with-api.js +767 -0
- package/dist/common/interactive/select-with-api.js.map +1 -0
- package/dist/common/interactive/select-with-api.mjs +758 -0
- package/dist/common/interactive/select-with-api.mjs.map +1 -0
- package/dist/common/interactive/select.d.ts +3 -0
- package/dist/common/interactive/select.d.ts.map +1 -0
- package/dist/common/interactive/select.js +15 -0
- package/dist/common/interactive/select.js.map +1 -0
- package/dist/common/interactive/select.mjs +4 -0
- package/dist/common/interactive/select.mjs.map +1 -0
- package/dist/common/interactive/sheet-wrapper.d.ts +34 -0
- package/dist/common/interactive/sheet-wrapper.d.ts.map +1 -0
- package/dist/common/interactive/sheet-wrapper.js +105 -0
- package/dist/common/interactive/sheet-wrapper.js.map +1 -0
- package/dist/common/interactive/sheet-wrapper.mjs +83 -0
- package/dist/common/interactive/sheet-wrapper.mjs.map +1 -0
- package/dist/common/interactive/table/enhanced-table.d.ts +5 -0
- package/dist/common/interactive/table/enhanced-table.d.ts.map +1 -0
- package/dist/common/interactive/table/enhanced-table.js +390 -0
- package/dist/common/interactive/table/enhanced-table.js.map +1 -0
- package/dist/common/interactive/table/enhanced-table.mjs +388 -0
- package/dist/common/interactive/table/enhanced-table.mjs.map +1 -0
- package/dist/common/interactive/table/index.d.ts +10 -0
- package/dist/common/interactive/table/index.d.ts.map +1 -0
- package/dist/common/interactive/table/index.js +83 -0
- package/dist/common/interactive/table/index.js.map +1 -0
- package/dist/common/interactive/table/index.mjs +68 -0
- package/dist/common/interactive/table/index.mjs.map +1 -0
- package/dist/common/interactive/table/table-pagination.d.ts +5 -0
- package/dist/common/interactive/table/table-pagination.d.ts.map +1 -0
- package/dist/common/interactive/table/table-pagination.js +12 -0
- package/dist/common/interactive/table/table-pagination.js.map +1 -0
- package/dist/common/interactive/table/table-pagination.mjs +10 -0
- package/dist/common/interactive/table/table-pagination.mjs.map +1 -0
- package/dist/common/interactive/table/types.d.ts +54 -0
- package/dist/common/interactive/table/types.d.ts.map +1 -0
- package/dist/common/interactive/table/types.js +4 -0
- package/dist/common/interactive/table/types.js.map +1 -0
- package/dist/common/interactive/table/types.mjs +3 -0
- package/dist/common/interactive/table/types.mjs.map +1 -0
- package/dist/common/interactive/time-picker.d.ts +74 -0
- package/dist/common/interactive/time-picker.d.ts.map +1 -0
- package/dist/common/interactive/time-picker.js +313 -0
- package/dist/common/interactive/time-picker.js.map +1 -0
- package/dist/common/interactive/time-picker.mjs +307 -0
- package/dist/common/interactive/time-picker.mjs.map +1 -0
- package/dist/common/interactive/types.d.ts +2 -0
- package/dist/common/interactive/types.d.ts.map +1 -0
- package/dist/common/interactive/types.js +4 -0
- package/dist/common/interactive/types.js.map +1 -0
- package/dist/common/interactive/types.mjs +3 -0
- package/dist/common/interactive/types.mjs.map +1 -0
- package/dist/common/pages/page-404.d.ts +3 -0
- package/dist/common/pages/page-404.d.ts.map +1 -0
- package/dist/common/pages/page-404.js +16 -0
- package/dist/common/pages/page-404.js.map +1 -0
- package/dist/common/pages/page-404.mjs +11 -0
- package/dist/common/pages/page-404.mjs.map +1 -0
- package/dist/common/pages/page-500.d.ts +9 -0
- package/dist/common/pages/page-500.d.ts.map +1 -0
- package/dist/common/pages/page-500.js +30 -0
- package/dist/common/pages/page-500.js.map +1 -0
- package/dist/common/pages/page-500.mjs +25 -0
- package/dist/common/pages/page-500.mjs.map +1 -0
- package/dist/components/accordion.d.ts +8 -0
- package/dist/components/accordion.d.ts.map +1 -0
- package/dist/components/accordion.js +65 -0
- package/dist/components/accordion.js.map +1 -0
- package/dist/components/accordion.mjs +39 -0
- package/dist/components/accordion.mjs.map +1 -0
- package/dist/components/alert-dialog.d.ts +33 -0
- package/dist/components/alert-dialog.d.ts.map +1 -0
- package/dist/components/alert-dialog.js +231 -0
- package/dist/components/alert-dialog.js.map +1 -0
- package/dist/components/alert-dialog.mjs +197 -0
- package/dist/components/alert-dialog.mjs.map +1 -0
- package/dist/components/alert.d.ts +13 -0
- package/dist/components/alert.d.ts.map +1 -0
- package/dist/components/alert.js +97 -0
- package/dist/components/alert.js.map +1 -0
- package/dist/components/alert.mjs +72 -0
- package/dist/components/alert.mjs.map +1 -0
- package/dist/components/aspect-ratio.d.ts +4 -0
- package/dist/components/aspect-ratio.d.ts.map +1 -0
- package/dist/components/aspect-ratio.js +29 -0
- package/dist/components/aspect-ratio.js.map +1 -0
- package/dist/components/aspect-ratio.mjs +7 -0
- package/dist/components/aspect-ratio.mjs.map +1 -0
- package/dist/components/avatar.d.ts +7 -0
- package/dist/components/avatar.d.ts.map +1 -0
- package/dist/components/avatar.js +64 -0
- package/dist/components/avatar.js.map +1 -0
- package/dist/components/avatar.mjs +39 -0
- package/dist/components/avatar.mjs.map +1 -0
- package/dist/components/badge.d.ts +12 -0
- package/dist/components/badge.d.ts.map +1 -0
- package/dist/components/badge.js +72 -0
- package/dist/components/badge.js.map +1 -0
- package/dist/components/badge.mjs +69 -0
- package/dist/components/badge.mjs.map +1 -0
- package/dist/components/breadcrumb.d.ts +20 -0
- package/dist/components/breadcrumb.d.ts.map +1 -0
- package/dist/components/breadcrumb.js +109 -0
- package/dist/components/breadcrumb.js.map +1 -0
- package/dist/components/breadcrumb.mjs +81 -0
- package/dist/components/breadcrumb.mjs.map +1 -0
- package/dist/components/button.d.ts +28 -0
- package/dist/components/button.d.ts.map +1 -0
- package/dist/components/button.js +250 -0
- package/dist/components/button.js.map +1 -0
- package/dist/components/button.mjs +226 -0
- package/dist/components/button.mjs.map +1 -0
- package/dist/components/calendar.d.ts +57 -0
- package/dist/components/calendar.d.ts.map +1 -0
- package/dist/components/calendar.js +681 -0
- package/dist/components/calendar.js.map +1 -0
- package/dist/components/calendar.mjs +659 -0
- package/dist/components/calendar.mjs.map +1 -0
- package/dist/components/card.d.ts +12 -0
- package/dist/components/card.d.ts.map +1 -0
- package/dist/components/card.js +98 -0
- package/dist/components/card.js.map +1 -0
- package/dist/components/card.mjs +71 -0
- package/dist/components/card.mjs.map +1 -0
- package/dist/components/carousel.d.ts +23 -0
- package/dist/components/carousel.d.ts.map +1 -0
- package/dist/components/carousel.js +237 -0
- package/dist/components/carousel.js.map +1 -0
- package/dist/components/carousel.mjs +208 -0
- package/dist/components/carousel.mjs.map +1 -0
- package/dist/components/chart.d.ts +63 -0
- package/dist/components/chart.d.ts.map +1 -0
- package/dist/components/chart.js +252 -0
- package/dist/components/chart.js.map +1 -0
- package/dist/components/chart.mjs +224 -0
- package/dist/components/chart.mjs.map +1 -0
- package/dist/components/checkbox.d.ts +18 -0
- package/dist/components/checkbox.d.ts.map +1 -0
- package/dist/components/checkbox.js +97 -0
- package/dist/components/checkbox.js.map +1 -0
- package/dist/components/checkbox.mjs +74 -0
- package/dist/components/checkbox.mjs.map +1 -0
- package/dist/components/chip.d.ts +30 -0
- package/dist/components/chip.d.ts.map +1 -0
- package/dist/components/chip.js +88 -0
- package/dist/components/chip.js.map +1 -0
- package/dist/components/chip.mjs +82 -0
- package/dist/components/chip.mjs.map +1 -0
- package/dist/components/collapsible.d.ts +6 -0
- package/dist/components/collapsible.d.ts.map +1 -0
- package/dist/components/collapsible.js +33 -0
- package/dist/components/collapsible.js.map +1 -0
- package/dist/components/collapsible.mjs +9 -0
- package/dist/components/collapsible.mjs.map +1 -0
- package/dist/components/command.d.ts +81 -0
- package/dist/components/command.d.ts.map +1 -0
- package/dist/components/command.js +125 -0
- package/dist/components/command.js.map +1 -0
- package/dist/components/command.mjs +95 -0
- package/dist/components/command.mjs.map +1 -0
- package/dist/components/context-menu.d.ts +28 -0
- package/dist/components/context-menu.d.ts.map +1 -0
- package/dist/components/context-menu.js +168 -0
- package/dist/components/context-menu.js.map +1 -0
- package/dist/components/context-menu.mjs +131 -0
- package/dist/components/context-menu.mjs.map +1 -0
- package/dist/components/dialog.d.ts +32 -0
- package/dist/components/dialog.d.ts.map +1 -0
- package/dist/components/dialog.js +192 -0
- package/dist/components/dialog.js.map +1 -0
- package/dist/components/dialog.mjs +159 -0
- package/dist/components/dialog.mjs.map +1 -0
- package/dist/components/drawer.d.ts +23 -0
- package/dist/components/drawer.d.ts.map +1 -0
- package/dist/components/drawer.js +98 -0
- package/dist/components/drawer.js.map +1 -0
- package/dist/components/drawer.mjs +67 -0
- package/dist/components/drawer.mjs.map +1 -0
- package/dist/components/dropdown-menu.d.ts +28 -0
- package/dist/components/dropdown-menu.d.ts.map +1 -0
- package/dist/components/dropdown-menu.js +163 -0
- package/dist/components/dropdown-menu.js.map +1 -0
- package/dist/components/dropdown-menu.mjs +126 -0
- package/dist/components/dropdown-menu.mjs.map +1 -0
- package/dist/components/form.d.ts +24 -0
- package/dist/components/form.d.ts.map +1 -0
- package/dist/components/form.js +123 -0
- package/dist/components/form.js.map +1 -0
- package/dist/components/form.mjs +94 -0
- package/dist/components/form.mjs.map +1 -0
- package/dist/components/hover-card.d.ts +7 -0
- package/dist/components/hover-card.d.ts.map +1 -0
- package/dist/components/hover-card.js +50 -0
- package/dist/components/hover-card.js.map +1 -0
- package/dist/components/hover-card.mjs +25 -0
- package/dist/components/hover-card.mjs.map +1 -0
- package/dist/components/input-otp.d.ts +39 -0
- package/dist/components/input-otp.d.ts.map +1 -0
- package/dist/components/input-otp.js +84 -0
- package/dist/components/input-otp.js.map +1 -0
- package/dist/components/input-otp.mjs +59 -0
- package/dist/components/input-otp.mjs.map +1 -0
- package/dist/components/input.d.ts +150 -0
- package/dist/components/input.d.ts.map +1 -0
- package/dist/components/input.js +858 -0
- package/dist/components/input.js.map +1 -0
- package/dist/components/input.mjs +831 -0
- package/dist/components/input.mjs.map +1 -0
- package/dist/components/label.d.ts +6 -0
- package/dist/components/label.d.ts.map +1 -0
- package/dist/components/label.js +38 -0
- package/dist/components/label.js.map +1 -0
- package/dist/components/label.mjs +15 -0
- package/dist/components/label.mjs.map +1 -0
- package/dist/components/lottie.d.ts +63 -0
- package/dist/components/lottie.d.ts.map +1 -0
- package/dist/components/lottie.js +59 -0
- package/dist/components/lottie.js.map +1 -0
- package/dist/components/lottie.mjs +49 -0
- package/dist/components/lottie.mjs.map +1 -0
- package/dist/components/menubar.d.ts +29 -0
- package/dist/components/menubar.d.ts.map +1 -0
- package/dist/components/menubar.js +195 -0
- package/dist/components/menubar.js.map +1 -0
- package/dist/components/menubar.mjs +157 -0
- package/dist/components/menubar.mjs.map +1 -0
- package/dist/components/navigation-menu.d.ts +13 -0
- package/dist/components/navigation-menu.d.ts.map +1 -0
- package/dist/components/navigation-menu.js +126 -0
- package/dist/components/navigation-menu.js.map +1 -0
- package/dist/components/navigation-menu.mjs +95 -0
- package/dist/components/navigation-menu.mjs.map +1 -0
- package/dist/components/pagination.d.ts +29 -0
- package/dist/components/pagination.d.ts.map +1 -0
- package/dist/components/pagination.js +112 -0
- package/dist/components/pagination.js.map +1 -0
- package/dist/components/pagination.mjs +84 -0
- package/dist/components/pagination.mjs.map +1 -0
- package/dist/components/popover.d.ts +7 -0
- package/dist/components/popover.d.ts.map +1 -0
- package/dist/components/popover.js +63 -0
- package/dist/components/popover.js.map +1 -0
- package/dist/components/popover.mjs +38 -0
- package/dist/components/popover.mjs.map +1 -0
- package/dist/components/progress.d.ts +7 -0
- package/dist/components/progress.d.ts.map +1 -0
- package/dist/components/progress.js +50 -0
- package/dist/components/progress.js.map +1 -0
- package/dist/components/progress.mjs +27 -0
- package/dist/components/progress.mjs.map +1 -0
- package/dist/components/radio-group.d.ts +17 -0
- package/dist/components/radio-group.d.ts.map +1 -0
- package/dist/components/radio-group.js +91 -0
- package/dist/components/radio-group.js.map +1 -0
- package/dist/components/radio-group.mjs +67 -0
- package/dist/components/radio-group.mjs.map +1 -0
- package/dist/components/resizable.d.ts +24 -0
- package/dist/components/resizable.d.ts.map +1 -0
- package/dist/components/resizable.js +59 -0
- package/dist/components/resizable.js.map +1 -0
- package/dist/components/resizable.mjs +35 -0
- package/dist/components/resizable.mjs.map +1 -0
- package/dist/components/responsive-popover.d.ts +25 -0
- package/dist/components/responsive-popover.d.ts.map +1 -0
- package/dist/components/responsive-popover.js +74 -0
- package/dist/components/responsive-popover.js.map +1 -0
- package/dist/components/responsive-popover.mjs +50 -0
- package/dist/components/responsive-popover.mjs.map +1 -0
- package/dist/components/scroll-area.d.ts +6 -0
- package/dist/components/scroll-area.d.ts.map +1 -0
- package/dist/components/scroll-area.js +63 -0
- package/dist/components/scroll-area.js.map +1 -0
- package/dist/components/scroll-area.mjs +39 -0
- package/dist/components/scroll-area.mjs.map +1 -0
- package/dist/components/separator.d.ts +5 -0
- package/dist/components/separator.d.ts.map +1 -0
- package/dist/components/separator.js +47 -0
- package/dist/components/separator.js.map +1 -0
- package/dist/components/separator.mjs +24 -0
- package/dist/components/separator.mjs.map +1 -0
- package/dist/components/sheet.d.ts +29 -0
- package/dist/components/sheet.d.ts.map +1 -0
- package/dist/components/sheet.js +239 -0
- package/dist/components/sheet.js.map +1 -0
- package/dist/components/sheet.mjs +206 -0
- package/dist/components/sheet.mjs.map +1 -0
- package/dist/components/sidebar.d.ts +87 -0
- package/dist/components/sidebar.d.ts.map +1 -0
- package/dist/components/sidebar.js +888 -0
- package/dist/components/sidebar.js.map +1 -0
- package/dist/components/sidebar.mjs +842 -0
- package/dist/components/sidebar.mjs.map +1 -0
- package/dist/components/skeleton.d.ts +36 -0
- package/dist/components/skeleton.d.ts.map +1 -0
- package/dist/components/skeleton.js +153 -0
- package/dist/components/skeleton.js.map +1 -0
- package/dist/components/skeleton.mjs +127 -0
- package/dist/components/skeleton.mjs.map +1 -0
- package/dist/components/slider.d.ts +5 -0
- package/dist/components/slider.d.ts.map +1 -0
- package/dist/components/slider.js +45 -0
- package/dist/components/slider.js.map +1 -0
- package/dist/components/slider.mjs +22 -0
- package/dist/components/slider.mjs.map +1 -0
- package/dist/components/sonner.d.ts +4 -0
- package/dist/components/sonner.d.ts.map +1 -0
- package/dist/components/sonner.js +76 -0
- package/dist/components/sonner.js.map +1 -0
- package/dist/components/sonner.mjs +71 -0
- package/dist/components/sonner.mjs.map +1 -0
- package/dist/components/spinner.d.ts +11 -0
- package/dist/components/spinner.d.ts.map +1 -0
- package/dist/components/spinner.js +59 -0
- package/dist/components/spinner.js.map +1 -0
- package/dist/components/spinner.mjs +36 -0
- package/dist/components/spinner.mjs.map +1 -0
- package/dist/components/stepper.d.ts +114 -0
- package/dist/components/stepper.d.ts.map +1 -0
- package/dist/components/stepper.js +726 -0
- package/dist/components/stepper.js.map +1 -0
- package/dist/components/stepper.mjs +702 -0
- package/dist/components/stepper.mjs.map +1 -0
- package/dist/components/switch.d.ts +16 -0
- package/dist/components/switch.d.ts.map +1 -0
- package/dist/components/switch.js +85 -0
- package/dist/components/switch.js.map +1 -0
- package/dist/components/switch.mjs +62 -0
- package/dist/components/switch.mjs.map +1 -0
- package/dist/components/table.d.ts +11 -0
- package/dist/components/table.d.ts.map +1 -0
- package/dist/components/table.js +91 -0
- package/dist/components/table.js.map +1 -0
- package/dist/components/table.mjs +62 -0
- package/dist/components/table.mjs.map +1 -0
- package/dist/components/tabs.d.ts +32 -0
- package/dist/components/tabs.d.ts.map +1 -0
- package/dist/components/tabs.js +287 -0
- package/dist/components/tabs.js.map +1 -0
- package/dist/components/tabs.mjs +261 -0
- package/dist/components/tabs.mjs.map +1 -0
- package/dist/components/textarea.d.ts +21 -0
- package/dist/components/textarea.d.ts.map +1 -0
- package/dist/components/textarea.js +200 -0
- package/dist/components/textarea.js.map +1 -0
- package/dist/components/textarea.mjs +174 -0
- package/dist/components/textarea.mjs.map +1 -0
- package/dist/components/toggle-group.d.ts +13 -0
- package/dist/components/toggle-group.d.ts.map +1 -0
- package/dist/components/toggle-group.js +67 -0
- package/dist/components/toggle-group.js.map +1 -0
- package/dist/components/toggle-group.mjs +43 -0
- package/dist/components/toggle-group.mjs.map +1 -0
- package/dist/components/toggle.d.ts +13 -0
- package/dist/components/toggle.d.ts.map +1 -0
- package/dist/components/toggle.js +63 -0
- package/dist/components/toggle.js.map +1 -0
- package/dist/components/toggle.mjs +39 -0
- package/dist/components/toggle.mjs.map +1 -0
- package/dist/components/tooltip.d.ts +31 -0
- package/dist/components/tooltip.d.ts.map +1 -0
- package/dist/components/tooltip.js +172 -0
- package/dist/components/tooltip.js.map +1 -0
- package/dist/components/tooltip.mjs +145 -0
- package/dist/components/tooltip.mjs.map +1 -0
- package/dist/globals.css +1179 -0
- package/dist/hooks/index.d.ts +6 -0
- package/dist/hooks/index.d.ts.map +1 -0
- package/dist/hooks/index.js +27 -0
- package/dist/hooks/index.js.map +1 -0
- package/dist/hooks/index.mjs +6 -0
- package/dist/hooks/index.mjs.map +1 -0
- package/dist/hooks/useCopyToClipboard.d.ts +26 -0
- package/dist/hooks/useCopyToClipboard.d.ts.map +1 -0
- package/dist/hooks/useCopyToClipboard.js +59 -0
- package/dist/hooks/useCopyToClipboard.js.map +1 -0
- package/dist/hooks/useCopyToClipboard.mjs +57 -0
- package/dist/hooks/useCopyToClipboard.mjs.map +1 -0
- package/dist/hooks/useDevice.d.ts +7 -0
- package/dist/hooks/useDevice.d.ts.map +1 -0
- package/dist/hooks/useDevice.js +20 -0
- package/dist/hooks/useDevice.js.map +1 -0
- package/dist/hooks/useDevice.mjs +14 -0
- package/dist/hooks/useDevice.mjs.map +1 -0
- package/dist/hooks/useDialogTracking.d.ts +17 -0
- package/dist/hooks/useDialogTracking.d.ts.map +1 -0
- package/dist/hooks/useDialogTracking.js +113 -0
- package/dist/hooks/useDialogTracking.js.map +1 -0
- package/dist/hooks/useDialogTracking.mjs +91 -0
- package/dist/hooks/useDialogTracking.mjs.map +1 -0
- package/dist/hooks/useIsMounted.d.ts +8 -0
- package/dist/hooks/useIsMounted.d.ts.map +1 -0
- package/dist/hooks/useIsMounted.js +15 -0
- package/dist/hooks/useIsMounted.js.map +1 -0
- package/dist/hooks/useIsMounted.mjs +13 -0
- package/dist/hooks/useIsMounted.mjs.map +1 -0
- package/dist/hooks/usePathname.d.ts +20 -0
- package/dist/hooks/usePathname.d.ts.map +1 -0
- package/dist/hooks/usePathname.js +85 -0
- package/dist/hooks/usePathname.js.map +1 -0
- package/dist/hooks/usePathname.mjs +83 -0
- package/dist/hooks/usePathname.mjs.map +1 -0
- package/dist/icons.d.ts +2 -0
- package/dist/icons.d.ts.map +1 -0
- package/dist/icons.js +14 -0
- package/dist/icons.js.map +1 -0
- package/dist/icons.mjs +3 -0
- package/dist/icons.mjs.map +1 -0
- package/dist/lib/formatCurrency.d.ts +106 -0
- package/dist/lib/formatCurrency.d.ts.map +1 -0
- package/dist/lib/formatCurrency.js +187 -0
- package/dist/lib/formatCurrency.js.map +1 -0
- package/dist/lib/formatCurrency.mjs +185 -0
- package/dist/lib/formatCurrency.mjs.map +1 -0
- package/dist/lib/helpers.d.ts +64 -0
- package/dist/lib/helpers.d.ts.map +1 -0
- package/dist/lib/helpers.js +171 -0
- package/dist/lib/helpers.js.map +1 -0
- package/dist/lib/helpers.mjs +157 -0
- package/dist/lib/helpers.mjs.map +1 -0
- package/dist/lib/index.d.ts +6 -0
- package/dist/lib/index.d.ts.map +1 -0
- package/dist/lib/index.js +33 -0
- package/dist/lib/index.js.map +1 -0
- package/dist/lib/index.mjs +6 -0
- package/dist/lib/index.mjs.map +1 -0
- package/dist/lib/types.d.ts +37 -0
- package/dist/lib/types.d.ts.map +1 -0
- package/dist/lib/types.js +11 -0
- package/dist/lib/types.js.map +1 -0
- package/dist/lib/types.mjs +9 -0
- package/dist/lib/types.mjs.map +1 -0
- package/dist/lib/utils.d.ts +4 -0
- package/dist/lib/utils.d.ts.map +1 -0
- package/dist/lib/utils.js +24 -0
- package/dist/lib/utils.js.map +1 -0
- package/dist/lib/utils.mjs +19 -0
- package/dist/lib/utils.mjs.map +1 -0
- package/dist/providers/DeviceSizeWatcher/index.d.ts +3 -0
- package/dist/providers/DeviceSizeWatcher/index.d.ts.map +1 -0
- package/dist/providers/DeviceSizeWatcher/index.js +72 -0
- package/dist/providers/DeviceSizeWatcher/index.js.map +1 -0
- package/dist/providers/DeviceSizeWatcher/index.mjs +47 -0
- package/dist/providers/DeviceSizeWatcher/index.mjs.map +1 -0
- package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.d.ts +13 -0
- package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.d.ts.map +1 -0
- package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.js +22 -0
- package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.js.map +1 -0
- package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.mjs +20 -0
- package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.mjs.map +1 -0
- package/dist/providers/UISystemProvider.d.ts +68 -0
- package/dist/providers/UISystemProvider.d.ts.map +1 -0
- package/dist/providers/UISystemProvider.js +197 -0
- package/dist/providers/UISystemProvider.js.map +1 -0
- package/dist/providers/UISystemProvider.mjs +188 -0
- package/dist/providers/UISystemProvider.mjs.map +1 -0
- package/dist/providers/index.d.ts +3 -0
- package/dist/providers/index.d.ts.map +1 -0
- package/dist/providers/index.js +24 -0
- package/dist/providers/index.js.map +1 -0
- package/dist/providers/index.mjs +3 -0
- package/dist/providers/index.mjs.map +1 -0
- package/dist/theme.d.ts +10 -0
- package/dist/theme.d.ts.map +1 -0
- package/dist/theme.js +333 -0
- package/dist/theme.js.map +1 -0
- package/dist/theme.mjs +327 -0
- package/dist/theme.mjs.map +1 -0
- package/package.json +252 -0
- package/postcss.config.mjs +6 -0
- package/tailwind.config.ts +350 -0
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import { useMemo } from 'react';
|
|
4
|
+
import { cn } from '@/lib/utils';
|
|
5
|
+
|
|
6
|
+
function ScoreMeter({
|
|
7
|
+
score,
|
|
8
|
+
milestones,
|
|
9
|
+
showTooltip = true,
|
|
10
|
+
className = "",
|
|
11
|
+
progresBarClassName = "",
|
|
12
|
+
renderTooltip,
|
|
13
|
+
renderTick,
|
|
14
|
+
progressFillColor
|
|
15
|
+
}) {
|
|
16
|
+
const progresBarRef = React.useRef(null);
|
|
17
|
+
const tooltipRef = React.useRef(null);
|
|
18
|
+
const sortedMilestones = [...milestones].sort((a, b) => a.maxScore - b.maxScore);
|
|
19
|
+
const maximumScore = sortedMilestones[sortedMilestones.length - 1]?.maxScore || 100;
|
|
20
|
+
const validScore = useMemo(
|
|
21
|
+
() => score < 0 ? 0 : score > maximumScore ? maximumScore : score,
|
|
22
|
+
[score, maximumScore]
|
|
23
|
+
);
|
|
24
|
+
const currentMilestone = sortedMilestones.find((milestone) => score <= milestone.maxScore) || (score > maximumScore ? sortedMilestones[sortedMilestones.length - 1] : sortedMilestones[0]);
|
|
25
|
+
const [progresWidth, setProgresWidth] = React.useState(0);
|
|
26
|
+
React.useEffect(() => {
|
|
27
|
+
if (progresBarRef?.current) {
|
|
28
|
+
const progresWidth2 = progresBarRef.current.offsetWidth;
|
|
29
|
+
setProgresWidth(progresWidth2);
|
|
30
|
+
}
|
|
31
|
+
}, [score, tooltipRef, progresBarRef]);
|
|
32
|
+
const formatLabel = (template, scoreValue) => {
|
|
33
|
+
return typeof template === "function" ? template(scoreValue) : template.replace("${score}", scoreValue.toString());
|
|
34
|
+
};
|
|
35
|
+
const tooltipArrowStyles = React.useMemo(() => {
|
|
36
|
+
const tooltipPosition = validScore / maximumScore * progresWidth;
|
|
37
|
+
const isNearLeft = tooltipPosition < 10;
|
|
38
|
+
const isNearRight = tooltipPosition > progresWidth - 10;
|
|
39
|
+
const borderLeftWidth = isNearRight ? 4 : Math.min(4, validScore);
|
|
40
|
+
const borderRightWidth = isNearLeft ? 4 : Math.min(4, maximumScore - validScore);
|
|
41
|
+
const translateX = isNearLeft ? "0%" : isNearRight ? "-100%" : "-50%";
|
|
42
|
+
return {
|
|
43
|
+
borderTopColor: currentMilestone?.tooltipColor ?? currentMilestone?.bgColor ?? "",
|
|
44
|
+
marginLeft: `${tooltipPosition}px`,
|
|
45
|
+
transform: `translateX(${translateX})`,
|
|
46
|
+
borderLeftWidth: `${borderLeftWidth}px`,
|
|
47
|
+
borderRightWidth: `${borderRightWidth}px`
|
|
48
|
+
};
|
|
49
|
+
}, [maximumScore, validScore, progresWidth, currentMilestone]);
|
|
50
|
+
const tooltipStyles = React.useMemo(() => {
|
|
51
|
+
const tooltipWidth = tooltipRef.current?.offsetWidth || 0;
|
|
52
|
+
const tooltipPosition = validScore / maximumScore * progresWidth;
|
|
53
|
+
let tooltipLeft = tooltipPosition - tooltipWidth / 2;
|
|
54
|
+
if (tooltipLeft < 0) tooltipLeft = 0;
|
|
55
|
+
if (tooltipLeft + tooltipWidth > progresWidth) tooltipLeft = progresWidth - tooltipWidth;
|
|
56
|
+
const borderBottomLeftRadius = tooltipLeft === 0 ? 0 : Math.min(8, validScore);
|
|
57
|
+
const borderBottomRightRadius = tooltipLeft + tooltipWidth === progresWidth ? 0 : Math.min(8, maximumScore - validScore);
|
|
58
|
+
return {
|
|
59
|
+
background: currentMilestone?.tooltipColor ?? currentMilestone?.bgColor ?? "",
|
|
60
|
+
marginLeft: `${tooltipLeft}px`,
|
|
61
|
+
borderBottomLeftRadius: `${borderBottomLeftRadius}px`,
|
|
62
|
+
borderBottomRightRadius: `${borderBottomRightRadius}px`
|
|
63
|
+
};
|
|
64
|
+
}, [validScore, maximumScore, progresWidth, currentMilestone]);
|
|
65
|
+
const tooltipValue = useMemo(() => {
|
|
66
|
+
return renderTooltip?.(score) ?? currentMilestone?.description;
|
|
67
|
+
}, [renderTooltip, currentMilestone]);
|
|
68
|
+
return /* @__PURE__ */ jsxs("div", { className: `w-full ${className}`, ref: progresBarRef, children: [
|
|
69
|
+
showTooltip && currentMilestone && /* @__PURE__ */ jsxs("div", { className: "mb-1 w-full", children: [
|
|
70
|
+
/* @__PURE__ */ jsx(
|
|
71
|
+
"div",
|
|
72
|
+
{
|
|
73
|
+
className: "text-t14m inline-block whitespace-nowrap rounded-[8px] px-3 py-1 font-medium text-white",
|
|
74
|
+
style: tooltipStyles,
|
|
75
|
+
ref: tooltipRef,
|
|
76
|
+
children: formatLabel(currentMilestone?.label ?? "", score)
|
|
77
|
+
}
|
|
78
|
+
),
|
|
79
|
+
/* @__PURE__ */ jsx(
|
|
80
|
+
"div",
|
|
81
|
+
{
|
|
82
|
+
className: cn("top-full h-0 w-0 rounded-[1px] border-t-[6px] border-transparent"),
|
|
83
|
+
style: tooltipArrowStyles
|
|
84
|
+
}
|
|
85
|
+
)
|
|
86
|
+
] }),
|
|
87
|
+
/* @__PURE__ */ jsxs("div", { className: cn("bg-ink-100s relative h-3 w-full rounded-full", progresBarClassName), children: [
|
|
88
|
+
/* @__PURE__ */ jsx("div", { className: "h-full w-full overflow-hidden rounded-full", children: /* @__PURE__ */ jsx(
|
|
89
|
+
"div",
|
|
90
|
+
{
|
|
91
|
+
className: "h-full w-full overflow-hidden rounded-full",
|
|
92
|
+
style: {
|
|
93
|
+
transform: `translateX(${validScore / maximumScore * 100 - 100}%)`
|
|
94
|
+
},
|
|
95
|
+
children: /* @__PURE__ */ jsx(
|
|
96
|
+
"div",
|
|
97
|
+
{
|
|
98
|
+
className: "h-full w-full rounded-full",
|
|
99
|
+
style: {
|
|
100
|
+
background: progressFillColor ?? currentMilestone?.bgColor ?? "#6366f1",
|
|
101
|
+
transform: `translateX(${100 - validScore / maximumScore * 100}%)`
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
)
|
|
105
|
+
}
|
|
106
|
+
) }),
|
|
107
|
+
sortedMilestones.map((milestone, index) => {
|
|
108
|
+
if (index === sortedMilestones.length - 1) return null;
|
|
109
|
+
if (renderTick)
|
|
110
|
+
return /* @__PURE__ */ jsx(
|
|
111
|
+
"div",
|
|
112
|
+
{
|
|
113
|
+
className: "absolute top-1/2 -translate-y-1/2",
|
|
114
|
+
style: {
|
|
115
|
+
left: `${milestone.maxScore / maximumScore * 100}%`
|
|
116
|
+
},
|
|
117
|
+
children: renderTick(milestone, score)
|
|
118
|
+
},
|
|
119
|
+
index
|
|
120
|
+
);
|
|
121
|
+
return /* @__PURE__ */ jsx(
|
|
122
|
+
"div",
|
|
123
|
+
{
|
|
124
|
+
className: "absolute top-0 h-full w-0.5 cursor-pointer transition-opacity hover:opacity-80",
|
|
125
|
+
style: {
|
|
126
|
+
left: `${milestone.maxScore / maximumScore * 100}%`,
|
|
127
|
+
background: milestone.tickColor ?? "#f97316"
|
|
128
|
+
}
|
|
129
|
+
},
|
|
130
|
+
index
|
|
131
|
+
);
|
|
132
|
+
})
|
|
133
|
+
] }),
|
|
134
|
+
tooltipValue && /* @__PURE__ */ jsx("div", { className: "text-t14m text-ink-400s mt-3", children: tooltipValue })
|
|
135
|
+
] });
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
export { ScoreMeter as default };
|
|
139
|
+
//# sourceMappingURL=score-meter.mjs.map
|
|
140
|
+
//# sourceMappingURL=score-meter.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/common/display/score-meter.tsx"],"names":["progresWidth"],"mappings":"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","file":"score-meter.mjs","sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { cn } from '@/lib/utils';\nimport { CSSProperties, useMemo } from 'react';\n\nexport interface Milestone {\n maxScore: number;\n label: string | ((score: number) => string);\n bgColor?: string;\n tooltipColor?: string;\n tickColor?: string;\n description?: string;\n}\n\ninterface ScoreMeterProps {\n score: number;\n milestones: Milestone[];\n showTooltip?: boolean;\n className?: string;\n progresBarClassName?: string;\n renderTooltip?: (score: number) => string | React.ReactNode;\n renderTick?: (milestone: Milestone, score: number) => React.ReactNode;\n progressFillColor?: string;\n}\n\nexport default function ScoreMeter({\n score,\n milestones,\n showTooltip = true,\n className = '',\n progresBarClassName = '',\n renderTooltip,\n renderTick,\n progressFillColor,\n}: ScoreMeterProps) {\n const progresBarRef = React.useRef<HTMLDivElement>(null);\n const tooltipRef = React.useRef<HTMLDivElement>(null);\n\n // Sắp xếp milestones theo thứ tự tăng dần\n const sortedMilestones = [...milestones].sort((a, b) => a.maxScore - b.maxScore);\n\n // Tính điểm tối đa từ milestones\n const maximumScore = sortedMilestones[sortedMilestones.length - 1]?.maxScore || 100;\n\n const validScore = useMemo(\n () => (score < 0 ? 0 : score > maximumScore ? maximumScore : score),\n [score, maximumScore],\n );\n\n // Tìm milestone hiện tại dựa trên điểm số\n const currentMilestone =\n sortedMilestones.find((milestone) => score <= milestone.maxScore) ||\n (score > maximumScore ? sortedMilestones[sortedMilestones.length - 1] : sortedMilestones[0]);\n\n const [progresWidth, setProgresWidth] = React.useState(0);\n\n React.useEffect(() => {\n if (progresBarRef?.current) {\n const progresWidth = progresBarRef.current.offsetWidth;\n\n setProgresWidth(progresWidth);\n }\n }, [score, tooltipRef, progresBarRef]);\n\n // Tạo label với điểm số được thay thế\n const formatLabel = (template: string | ((scoreValue: number) => string), scoreValue: number) => {\n return typeof template === 'function'\n ? template(scoreValue)\n : template.replace('${score}', scoreValue.toString());\n };\n\n const tooltipArrowStyles = React.useMemo(() => {\n const tooltipPosition = (validScore / maximumScore) * progresWidth;\n const isNearLeft = tooltipPosition < 10; // Ngưỡng gần bên trái\n const isNearRight = tooltipPosition > progresWidth - 10; // Ngưỡng gần bên phải\n\n const borderLeftWidth = isNearRight ? 4 : Math.min(4, validScore);\n const borderRightWidth = isNearLeft ? 4 : Math.min(4, maximumScore - validScore);\n const translateX = isNearLeft ? '0%' : isNearRight ? '-100%' : '-50%';\n\n return {\n borderTopColor: currentMilestone?.tooltipColor ?? currentMilestone?.bgColor ?? '',\n marginLeft: `${tooltipPosition}px`,\n transform: `translateX(${translateX})`,\n borderLeftWidth: `${borderLeftWidth}px`,\n borderRightWidth: `${borderRightWidth}px`,\n };\n }, [maximumScore, validScore, progresWidth, currentMilestone]);\n\n const tooltipStyles = React.useMemo(() => {\n const tooltipWidth = tooltipRef.current?.offsetWidth || 0;\n const tooltipPosition = (validScore / maximumScore) * progresWidth;\n\n // Clamp tooltip position to stay within bounds\n let tooltipLeft = tooltipPosition - tooltipWidth / 2;\n if (tooltipLeft < 0) tooltipLeft = 0;\n if (tooltipLeft + tooltipWidth > progresWidth) tooltipLeft = progresWidth - tooltipWidth;\n\n // Adjust border radii based on proximity to edges\n const borderBottomLeftRadius = tooltipLeft === 0 ? 0 : Math.min(8, validScore);\n const borderBottomRightRadius =\n tooltipLeft + tooltipWidth === progresWidth ? 0 : Math.min(8, maximumScore - validScore);\n\n return {\n background: currentMilestone?.tooltipColor ?? currentMilestone?.bgColor ?? '',\n marginLeft: `${tooltipLeft}px`,\n borderBottomLeftRadius: `${borderBottomLeftRadius}px`,\n borderBottomRightRadius: `${borderBottomRightRadius}px`,\n };\n }, [validScore, maximumScore, progresWidth, currentMilestone]);\n\n const tooltipValue = useMemo(() => {\n return renderTooltip?.(score) ?? currentMilestone?.description;\n }, [renderTooltip, currentMilestone]);\n\n return (\n <div className={`w-full ${className}`} ref={progresBarRef}>\n {/* Tooltip */}\n {showTooltip && currentMilestone && (\n <div className=\"mb-1 w-full\">\n <div\n className=\"text-t14m inline-block whitespace-nowrap rounded-[8px] px-3 py-1 font-medium text-white\"\n style={tooltipStyles}\n ref={tooltipRef}\n >\n {formatLabel(currentMilestone?.label ?? '', score)}\n </div>\n\n {/* Mũi tên tooltip */}\n <div\n className={cn('top-full h-0 w-0 rounded-[1px] border-t-[6px] border-transparent')}\n style={tooltipArrowStyles}\n />\n </div>\n )}\n\n {/* Progress bar container */}\n <div className={cn('bg-ink-100s relative h-3 w-full rounded-full', progresBarClassName)}>\n {/* Progress bar fill */}\n <div className=\"h-full w-full overflow-hidden rounded-full\">\n <div\n className=\"h-full w-full overflow-hidden rounded-full\"\n style={{\n transform: `translateX(${(validScore / maximumScore) * 100 - 100}%)`,\n }}\n >\n <div\n className=\"h-full w-full rounded-full\"\n style={{\n background: progressFillColor ?? currentMilestone?.bgColor ?? '#6366f1',\n transform: `translateX(${100 - (validScore / maximumScore) * 100}%)`,\n }}\n />\n </div>\n </div>\n\n {/* Tick marks */}\n {sortedMilestones.map((milestone, index) => {\n if (index === sortedMilestones.length - 1) return null; // Không hiển thị tick cho milestone cuối cùng\n\n if (renderTick)\n return (\n <div\n key={index}\n className=\"absolute top-1/2 -translate-y-1/2\"\n style={{\n left: `${(milestone.maxScore / maximumScore) * 100}%`,\n }}\n >\n {renderTick(milestone, score)}\n </div>\n );\n\n return (\n <div\n key={index}\n className=\"absolute top-0 h-full w-0.5 cursor-pointer transition-opacity hover:opacity-80\"\n style={{\n left: `${(milestone.maxScore / maximumScore) * 100}%`,\n background: milestone.tickColor ?? '#f97316',\n }}\n />\n );\n })}\n </div>\n\n {/* Description */}\n {tooltipValue && <div className=\"text-t14m text-ink-400s mt-3\">{tooltipValue}</div>}\n </div>\n );\n}\n"]}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import { NavSectionType } from '@/lib/types';
|
|
3
|
+
import { Sidebar } from '@repo/ui/components/sidebar';
|
|
4
|
+
import { NavItemClassNames, SidebarClassNames } from './types';
|
|
5
|
+
type AppSidebar = {
|
|
6
|
+
navSections: NavSectionType[];
|
|
7
|
+
LinkComponent?: React.ComponentType<any>;
|
|
8
|
+
sidebarHeader: React.ReactNode;
|
|
9
|
+
sidebarHeaderAsMenuItem?: boolean;
|
|
10
|
+
sidebarHeaderLink?: string;
|
|
11
|
+
sidebarFooter?: React.ReactNode;
|
|
12
|
+
sidebarContent?: React.ReactNode;
|
|
13
|
+
hasSideRail?: boolean;
|
|
14
|
+
classNames?: SidebarClassNames;
|
|
15
|
+
navClassNames?: NavItemClassNames;
|
|
16
|
+
mobileSheetClassName?: string;
|
|
17
|
+
showHeader?: boolean;
|
|
18
|
+
showFooter?: boolean;
|
|
19
|
+
/**
|
|
20
|
+
* Control gap behavior when sidebar is collapsed
|
|
21
|
+
* - true: Use smaller gap (gap-2) when collapsed
|
|
22
|
+
* - false: Keep consistent gap (gap-6)
|
|
23
|
+
*/
|
|
24
|
+
compactWhenCollapsed?: boolean;
|
|
25
|
+
} & React.ComponentProps<typeof Sidebar>;
|
|
26
|
+
export declare function AppSidebar({ navSections, sidebarHeader, sidebarHeaderAsMenuItem, sidebarHeaderLink, sidebarFooter, sidebarContent, hasSideRail, LinkComponent, classNames, navClassNames, className, mobileSheetClassName, showHeader, showFooter, compactWhenCollapsed, ...props }: AppSidebar): import("react/jsx-runtime").JSX.Element;
|
|
27
|
+
export {};
|
|
28
|
+
//# sourceMappingURL=app-sidebar.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"app-sidebar.d.ts","sourceRoot":"","sources":["../../../../src/common/display/sidebar/app-sidebar.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAE7C,OAAO,EACL,OAAO,EAUR,MAAM,6BAA6B,CAAC;AAErC,OAAO,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,MAAM,SAAS,CAAC;AAE/D,KAAK,UAAU,GAAG;IAChB,WAAW,EAAE,cAAc,EAAE,CAAC;IAC9B,aAAa,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;IACzC,aAAa,EAAE,KAAK,CAAC,SAAS,CAAC;IAC/B,uBAAuB,CAAC,EAAE,OAAO,CAAC;IAClC,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,aAAa,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAChC,cAAc,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACjC,WAAW,CAAC,EAAE,OAAO,CAAC;IAEtB,UAAU,CAAC,EAAE,iBAAiB,CAAC;IAC/B,aAAa,CAAC,EAAE,iBAAiB,CAAC;IAClC,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAC9B,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB;;;;OAIG;IACH,oBAAoB,CAAC,EAAE,OAAO,CAAC;CAChC,GAAG,KAAK,CAAC,cAAc,CAAC,OAAO,OAAO,CAAC,CAAC;AAEzC,wBAAgB,UAAU,CAAC,EACzB,WAAW,EACX,aAAa,EACb,uBAA8B,EAC9B,iBAAuB,EACvB,aAAa,EACb,cAAc,EACd,WAAmB,EACnB,aAAa,EACb,UAAU,EACV,aAAa,EACb,SAAS,EACT,oBAAoB,EACpB,UAAiB,EACjB,UAAiB,EACjB,oBAA2B,EAC3B,GAAG,KAAK,EACT,EAAE,UAAU,2CAkFZ"}
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
4
|
+
var React = require('react');
|
|
5
|
+
var utils = require('@/lib/utils');
|
|
6
|
+
var sidebar = require('@repo/ui/components/sidebar');
|
|
7
|
+
var navMain = require('./nav-main');
|
|
8
|
+
|
|
9
|
+
function _interopNamespace(e) {
|
|
10
|
+
if (e && e.__esModule) return e;
|
|
11
|
+
var n = Object.create(null);
|
|
12
|
+
if (e) {
|
|
13
|
+
Object.keys(e).forEach(function (k) {
|
|
14
|
+
if (k !== 'default') {
|
|
15
|
+
var d = Object.getOwnPropertyDescriptor(e, k);
|
|
16
|
+
Object.defineProperty(n, k, d.get ? d : {
|
|
17
|
+
enumerable: true,
|
|
18
|
+
get: function () { return e[k]; }
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
n.default = e;
|
|
24
|
+
return Object.freeze(n);
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
var React__namespace = /*#__PURE__*/_interopNamespace(React);
|
|
28
|
+
|
|
29
|
+
function AppSidebar({
|
|
30
|
+
navSections,
|
|
31
|
+
sidebarHeader,
|
|
32
|
+
sidebarHeaderAsMenuItem = true,
|
|
33
|
+
sidebarHeaderLink = "/",
|
|
34
|
+
sidebarFooter,
|
|
35
|
+
sidebarContent,
|
|
36
|
+
hasSideRail = false,
|
|
37
|
+
LinkComponent,
|
|
38
|
+
classNames,
|
|
39
|
+
navClassNames,
|
|
40
|
+
className,
|
|
41
|
+
mobileSheetClassName,
|
|
42
|
+
showHeader = true,
|
|
43
|
+
showFooter = true,
|
|
44
|
+
compactWhenCollapsed = true,
|
|
45
|
+
...props
|
|
46
|
+
}) {
|
|
47
|
+
const { isMobile, openMobile, state, isHovered, open } = sidebar.useSidebar();
|
|
48
|
+
const Link = LinkComponent || (({ href, children, ...linkProps }) => /* @__PURE__ */ jsxRuntime.jsx("a", { href, ...linkProps, children }));
|
|
49
|
+
return /* @__PURE__ */ jsxRuntime.jsxs(
|
|
50
|
+
sidebar.Sidebar,
|
|
51
|
+
{
|
|
52
|
+
collapsible: "icon",
|
|
53
|
+
className: utils.cn("z-40", className),
|
|
54
|
+
mobileSheetClassName: classNames?.mobileRoot,
|
|
55
|
+
...props,
|
|
56
|
+
children: [
|
|
57
|
+
showHeader && /* @__PURE__ */ jsxRuntime.jsxs(sidebar.SidebarHeader, { className: utils.cn("relative", classNames?.header), children: [
|
|
58
|
+
sidebarHeaderAsMenuItem ? /* @__PURE__ */ jsxRuntime.jsx(sidebar.SidebarMenu, { children: /* @__PURE__ */ jsxRuntime.jsx(Link, { href: sidebarHeaderLink, className: "cursor-pointer", children: /* @__PURE__ */ jsxRuntime.jsx(sidebar.SidebarMenuItem, { children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
59
|
+
sidebar.SidebarMenuButton,
|
|
60
|
+
{
|
|
61
|
+
size: "lg",
|
|
62
|
+
className: "data-[state=open]:bg-sidebar-accent data-[state=open]:text-sidebar-accent-foreground",
|
|
63
|
+
children: sidebarHeader
|
|
64
|
+
}
|
|
65
|
+
) }) }) }) : /* @__PURE__ */ jsxRuntime.jsx(jsxRuntime.Fragment, { children: sidebarHeader }),
|
|
66
|
+
/* @__PURE__ */ jsxRuntime.jsx(
|
|
67
|
+
sidebar.SidebarTrigger,
|
|
68
|
+
{
|
|
69
|
+
className: utils.cn(
|
|
70
|
+
"absolute right-[-16px] top-4 z-30 hidden h-8 w-8 rounded-full lg:flex",
|
|
71
|
+
classNames?.trigger
|
|
72
|
+
)
|
|
73
|
+
}
|
|
74
|
+
)
|
|
75
|
+
] }),
|
|
76
|
+
/* @__PURE__ */ jsxRuntime.jsxs(
|
|
77
|
+
sidebar.SidebarContent,
|
|
78
|
+
{
|
|
79
|
+
className: utils.cn(
|
|
80
|
+
"gap-6",
|
|
81
|
+
classNames?.content,
|
|
82
|
+
!showHeader && "pt-6"
|
|
83
|
+
// Add padding-top when header is hidden
|
|
84
|
+
),
|
|
85
|
+
children: [
|
|
86
|
+
sidebarContent,
|
|
87
|
+
navSections.map((section, index) => /* @__PURE__ */ jsxRuntime.jsx(React__namespace.Fragment, { children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
88
|
+
navMain.NavMain,
|
|
89
|
+
{
|
|
90
|
+
label: section.label,
|
|
91
|
+
items: section.items,
|
|
92
|
+
LinkComponent,
|
|
93
|
+
labelClassName: navClassNames?.label,
|
|
94
|
+
itemClassName: navClassNames?.item,
|
|
95
|
+
itemActiveClassName: navClassNames?.itemActive,
|
|
96
|
+
itemHoverClassName: navClassNames?.itemHover,
|
|
97
|
+
subItemClassName: navClassNames?.subItem,
|
|
98
|
+
subItemActiveClassName: navClassNames?.subItemActive,
|
|
99
|
+
subItemHoverClassName: navClassNames?.subItemHover
|
|
100
|
+
}
|
|
101
|
+
) }, section.label || index))
|
|
102
|
+
]
|
|
103
|
+
}
|
|
104
|
+
),
|
|
105
|
+
showFooter && sidebarFooter && /* @__PURE__ */ jsxRuntime.jsx(sidebar.SidebarFooter, { className: classNames?.footer, children: sidebarFooter }),
|
|
106
|
+
hasSideRail && /* @__PURE__ */ jsxRuntime.jsx(sidebar.SidebarRail, {})
|
|
107
|
+
]
|
|
108
|
+
}
|
|
109
|
+
);
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
exports.AppSidebar = AppSidebar;
|
|
113
|
+
//# sourceMappingURL=app-sidebar.js.map
|
|
114
|
+
//# sourceMappingURL=app-sidebar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/common/display/sidebar/app-sidebar.tsx"],"names":["useSidebar","jsx","jsxs","Sidebar","cn","SidebarHeader","SidebarMenu","SidebarMenuItem","SidebarMenuButton","SidebarTrigger","SidebarContent","React","NavMain","SidebarFooter","SidebarRail"],"mappings":"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","file":"app-sidebar.js","sourcesContent":["'use client';\n\nimport * as React from 'react';\n\nimport { NavSectionType } from '@/lib/types';\nimport { cn } from '@/lib/utils';\nimport {\n Sidebar,\n SidebarContent,\n SidebarFooter,\n SidebarHeader,\n SidebarMenu,\n SidebarMenuButton,\n SidebarMenuItem,\n SidebarRail,\n SidebarTrigger,\n useSidebar,\n} from '@repo/ui/components/sidebar';\nimport { NavMain } from './nav-main';\nimport { NavItemClassNames, SidebarClassNames } from './types';\n\ntype AppSidebar = {\n navSections: NavSectionType[]; // Changed from navItems to navSections\n LinkComponent?: React.ComponentType<any>;\n sidebarHeader: React.ReactNode;\n sidebarHeaderAsMenuItem?: boolean; // If true, wraps sidebarHeader in SidebarMenu structure\n sidebarHeaderLink?: string; // Optional link for header when used as menu item\n sidebarFooter?: React.ReactNode; // Footer content (parent decides what to show)\n sidebarContent?: React.ReactNode; // Additional content before navigation (e.g., userInfo on mobile)\n hasSideRail?: boolean; // Controls SidebarRail visibility for drag-to-resize functionality (default: false)\n // Grouped style customization props\n classNames?: SidebarClassNames;\n navClassNames?: NavItemClassNames;\n mobileSheetClassName?: string;\n showHeader?: boolean; // Control header visibility\n showFooter?: boolean; // Control footer visibility\n /**\n * Control gap behavior when sidebar is collapsed\n * - true: Use smaller gap (gap-2) when collapsed\n * - false: Keep consistent gap (gap-6)\n */\n compactWhenCollapsed?: boolean;\n} & React.ComponentProps<typeof Sidebar>;\n\nexport function AppSidebar({\n navSections,\n sidebarHeader,\n sidebarHeaderAsMenuItem = true,\n sidebarHeaderLink = '/',\n sidebarFooter,\n sidebarContent,\n hasSideRail = false,\n LinkComponent,\n classNames,\n navClassNames,\n className,\n mobileSheetClassName,\n showHeader = true,\n showFooter = true,\n compactWhenCollapsed = true,\n ...props\n}: AppSidebar) {\n const { isMobile, openMobile, state, isHovered, open } = useSidebar();\n // On mobile: use openMobile state\n // On desktop: show expanded when open OR when collapsed but hovered\n const isExpanded = isMobile ? openMobile : open || (state === 'collapsed' && isHovered);\n\n const Link =\n LinkComponent ||\n (({ href, children, ...linkProps }) => (\n <a href={href} {...linkProps}>\n {children}\n </a>\n ));\n\n return (\n <Sidebar\n collapsible=\"icon\"\n className={cn('z-40', className)}\n mobileSheetClassName={classNames?.mobileRoot}\n {...props}\n >\n {showHeader && (\n <SidebarHeader className={cn('relative', classNames?.header)}>\n {sidebarHeaderAsMenuItem ? (\n <SidebarMenu>\n <Link href={sidebarHeaderLink} className=\"cursor-pointer\">\n <SidebarMenuItem>\n <SidebarMenuButton\n size=\"lg\"\n className=\"data-[state=open]:bg-sidebar-accent data-[state=open]:text-sidebar-accent-foreground\"\n >\n {sidebarHeader}\n </SidebarMenuButton>\n </SidebarMenuItem>\n </Link>\n </SidebarMenu>\n ) : (\n <>{sidebarHeader}</>\n )}\n <SidebarTrigger\n className={cn(\n 'absolute right-[-16px] top-4 z-30 hidden h-8 w-8 rounded-full lg:flex',\n classNames?.trigger,\n )}\n />\n </SidebarHeader>\n )}\n {/* ...existing code... */}\n <SidebarContent\n className={cn(\n 'gap-6',\n classNames?.content,\n !showHeader && 'pt-6', // Add padding-top when header is hidden\n )}\n >\n {/* Additional content before navigation (e.g., userInfo on mobile) */}\n {sidebarContent}\n\n {/* Navigation Sections */}\n {navSections.map((section, index) => (\n <React.Fragment key={section.label || index}>\n <NavMain\n label={section.label}\n items={section.items}\n LinkComponent={LinkComponent}\n labelClassName={navClassNames?.label}\n itemClassName={navClassNames?.item}\n itemActiveClassName={navClassNames?.itemActive}\n itemHoverClassName={navClassNames?.itemHover}\n subItemClassName={navClassNames?.subItem}\n subItemActiveClassName={navClassNames?.subItemActive}\n subItemHoverClassName={navClassNames?.subItemHover}\n />\n </React.Fragment>\n ))}\n </SidebarContent>\n {showFooter && sidebarFooter && (\n <SidebarFooter className={classNames?.footer}>{sidebarFooter}</SidebarFooter>\n )}\n {hasSideRail && <SidebarRail />}\n </Sidebar>\n );\n}\n"]}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import { jsxs, jsx, Fragment } from 'react/jsx-runtime';
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import { cn } from '@/lib/utils';
|
|
4
|
+
import { useSidebar, Sidebar, SidebarHeader, SidebarMenu, SidebarMenuItem, SidebarMenuButton, SidebarTrigger, SidebarContent, SidebarFooter, SidebarRail } from '@repo/ui/components/sidebar';
|
|
5
|
+
import { NavMain } from './nav-main';
|
|
6
|
+
|
|
7
|
+
function AppSidebar({
|
|
8
|
+
navSections,
|
|
9
|
+
sidebarHeader,
|
|
10
|
+
sidebarHeaderAsMenuItem = true,
|
|
11
|
+
sidebarHeaderLink = "/",
|
|
12
|
+
sidebarFooter,
|
|
13
|
+
sidebarContent,
|
|
14
|
+
hasSideRail = false,
|
|
15
|
+
LinkComponent,
|
|
16
|
+
classNames,
|
|
17
|
+
navClassNames,
|
|
18
|
+
className,
|
|
19
|
+
mobileSheetClassName,
|
|
20
|
+
showHeader = true,
|
|
21
|
+
showFooter = true,
|
|
22
|
+
compactWhenCollapsed = true,
|
|
23
|
+
...props
|
|
24
|
+
}) {
|
|
25
|
+
const { isMobile, openMobile, state, isHovered, open } = useSidebar();
|
|
26
|
+
const Link = LinkComponent || (({ href, children, ...linkProps }) => /* @__PURE__ */ jsx("a", { href, ...linkProps, children }));
|
|
27
|
+
return /* @__PURE__ */ jsxs(
|
|
28
|
+
Sidebar,
|
|
29
|
+
{
|
|
30
|
+
collapsible: "icon",
|
|
31
|
+
className: cn("z-40", className),
|
|
32
|
+
mobileSheetClassName: classNames?.mobileRoot,
|
|
33
|
+
...props,
|
|
34
|
+
children: [
|
|
35
|
+
showHeader && /* @__PURE__ */ jsxs(SidebarHeader, { className: cn("relative", classNames?.header), children: [
|
|
36
|
+
sidebarHeaderAsMenuItem ? /* @__PURE__ */ jsx(SidebarMenu, { children: /* @__PURE__ */ jsx(Link, { href: sidebarHeaderLink, className: "cursor-pointer", children: /* @__PURE__ */ jsx(SidebarMenuItem, { children: /* @__PURE__ */ jsx(
|
|
37
|
+
SidebarMenuButton,
|
|
38
|
+
{
|
|
39
|
+
size: "lg",
|
|
40
|
+
className: "data-[state=open]:bg-sidebar-accent data-[state=open]:text-sidebar-accent-foreground",
|
|
41
|
+
children: sidebarHeader
|
|
42
|
+
}
|
|
43
|
+
) }) }) }) : /* @__PURE__ */ jsx(Fragment, { children: sidebarHeader }),
|
|
44
|
+
/* @__PURE__ */ jsx(
|
|
45
|
+
SidebarTrigger,
|
|
46
|
+
{
|
|
47
|
+
className: cn(
|
|
48
|
+
"absolute right-[-16px] top-4 z-30 hidden h-8 w-8 rounded-full lg:flex",
|
|
49
|
+
classNames?.trigger
|
|
50
|
+
)
|
|
51
|
+
}
|
|
52
|
+
)
|
|
53
|
+
] }),
|
|
54
|
+
/* @__PURE__ */ jsxs(
|
|
55
|
+
SidebarContent,
|
|
56
|
+
{
|
|
57
|
+
className: cn(
|
|
58
|
+
"gap-6",
|
|
59
|
+
classNames?.content,
|
|
60
|
+
!showHeader && "pt-6"
|
|
61
|
+
// Add padding-top when header is hidden
|
|
62
|
+
),
|
|
63
|
+
children: [
|
|
64
|
+
sidebarContent,
|
|
65
|
+
navSections.map((section, index) => /* @__PURE__ */ jsx(React.Fragment, { children: /* @__PURE__ */ jsx(
|
|
66
|
+
NavMain,
|
|
67
|
+
{
|
|
68
|
+
label: section.label,
|
|
69
|
+
items: section.items,
|
|
70
|
+
LinkComponent,
|
|
71
|
+
labelClassName: navClassNames?.label,
|
|
72
|
+
itemClassName: navClassNames?.item,
|
|
73
|
+
itemActiveClassName: navClassNames?.itemActive,
|
|
74
|
+
itemHoverClassName: navClassNames?.itemHover,
|
|
75
|
+
subItemClassName: navClassNames?.subItem,
|
|
76
|
+
subItemActiveClassName: navClassNames?.subItemActive,
|
|
77
|
+
subItemHoverClassName: navClassNames?.subItemHover
|
|
78
|
+
}
|
|
79
|
+
) }, section.label || index))
|
|
80
|
+
]
|
|
81
|
+
}
|
|
82
|
+
),
|
|
83
|
+
showFooter && sidebarFooter && /* @__PURE__ */ jsx(SidebarFooter, { className: classNames?.footer, children: sidebarFooter }),
|
|
84
|
+
hasSideRail && /* @__PURE__ */ jsx(SidebarRail, {})
|
|
85
|
+
]
|
|
86
|
+
}
|
|
87
|
+
);
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
export { AppSidebar };
|
|
91
|
+
//# sourceMappingURL=app-sidebar.mjs.map
|
|
92
|
+
//# sourceMappingURL=app-sidebar.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/common/display/sidebar/app-sidebar.tsx"],"names":[],"mappings":"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","file":"app-sidebar.mjs","sourcesContent":["'use client';\n\nimport * as React from 'react';\n\nimport { NavSectionType } from '@/lib/types';\nimport { cn } from '@/lib/utils';\nimport {\n Sidebar,\n SidebarContent,\n SidebarFooter,\n SidebarHeader,\n SidebarMenu,\n SidebarMenuButton,\n SidebarMenuItem,\n SidebarRail,\n SidebarTrigger,\n useSidebar,\n} from '@repo/ui/components/sidebar';\nimport { NavMain } from './nav-main';\nimport { NavItemClassNames, SidebarClassNames } from './types';\n\ntype AppSidebar = {\n navSections: NavSectionType[]; // Changed from navItems to navSections\n LinkComponent?: React.ComponentType<any>;\n sidebarHeader: React.ReactNode;\n sidebarHeaderAsMenuItem?: boolean; // If true, wraps sidebarHeader in SidebarMenu structure\n sidebarHeaderLink?: string; // Optional link for header when used as menu item\n sidebarFooter?: React.ReactNode; // Footer content (parent decides what to show)\n sidebarContent?: React.ReactNode; // Additional content before navigation (e.g., userInfo on mobile)\n hasSideRail?: boolean; // Controls SidebarRail visibility for drag-to-resize functionality (default: false)\n // Grouped style customization props\n classNames?: SidebarClassNames;\n navClassNames?: NavItemClassNames;\n mobileSheetClassName?: string;\n showHeader?: boolean; // Control header visibility\n showFooter?: boolean; // Control footer visibility\n /**\n * Control gap behavior when sidebar is collapsed\n * - true: Use smaller gap (gap-2) when collapsed\n * - false: Keep consistent gap (gap-6)\n */\n compactWhenCollapsed?: boolean;\n} & React.ComponentProps<typeof Sidebar>;\n\nexport function AppSidebar({\n navSections,\n sidebarHeader,\n sidebarHeaderAsMenuItem = true,\n sidebarHeaderLink = '/',\n sidebarFooter,\n sidebarContent,\n hasSideRail = false,\n LinkComponent,\n classNames,\n navClassNames,\n className,\n mobileSheetClassName,\n showHeader = true,\n showFooter = true,\n compactWhenCollapsed = true,\n ...props\n}: AppSidebar) {\n const { isMobile, openMobile, state, isHovered, open } = useSidebar();\n // On mobile: use openMobile state\n // On desktop: show expanded when open OR when collapsed but hovered\n const isExpanded = isMobile ? openMobile : open || (state === 'collapsed' && isHovered);\n\n const Link =\n LinkComponent ||\n (({ href, children, ...linkProps }) => (\n <a href={href} {...linkProps}>\n {children}\n </a>\n ));\n\n return (\n <Sidebar\n collapsible=\"icon\"\n className={cn('z-40', className)}\n mobileSheetClassName={classNames?.mobileRoot}\n {...props}\n >\n {showHeader && (\n <SidebarHeader className={cn('relative', classNames?.header)}>\n {sidebarHeaderAsMenuItem ? (\n <SidebarMenu>\n <Link href={sidebarHeaderLink} className=\"cursor-pointer\">\n <SidebarMenuItem>\n <SidebarMenuButton\n size=\"lg\"\n className=\"data-[state=open]:bg-sidebar-accent data-[state=open]:text-sidebar-accent-foreground\"\n >\n {sidebarHeader}\n </SidebarMenuButton>\n </SidebarMenuItem>\n </Link>\n </SidebarMenu>\n ) : (\n <>{sidebarHeader}</>\n )}\n <SidebarTrigger\n className={cn(\n 'absolute right-[-16px] top-4 z-30 hidden h-8 w-8 rounded-full lg:flex',\n classNames?.trigger,\n )}\n />\n </SidebarHeader>\n )}\n {/* ...existing code... */}\n <SidebarContent\n className={cn(\n 'gap-6',\n classNames?.content,\n !showHeader && 'pt-6', // Add padding-top when header is hidden\n )}\n >\n {/* Additional content before navigation (e.g., userInfo on mobile) */}\n {sidebarContent}\n\n {/* Navigation Sections */}\n {navSections.map((section, index) => (\n <React.Fragment key={section.label || index}>\n <NavMain\n label={section.label}\n items={section.items}\n LinkComponent={LinkComponent}\n labelClassName={navClassNames?.label}\n itemClassName={navClassNames?.item}\n itemActiveClassName={navClassNames?.itemActive}\n itemHoverClassName={navClassNames?.itemHover}\n subItemClassName={navClassNames?.subItem}\n subItemActiveClassName={navClassNames?.subItemActive}\n subItemHoverClassName={navClassNames?.subItemHover}\n />\n </React.Fragment>\n ))}\n </SidebarContent>\n {showFooter && sidebarFooter && (\n <SidebarFooter className={classNames?.footer}>{sidebarFooter}</SidebarFooter>\n )}\n {hasSideRail && <SidebarRail />}\n </Sidebar>\n );\n}\n"]}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { NavSectionType } from '@/lib/types';
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import { NavItemClassNames, SidebarClassNames } from './types';
|
|
4
|
+
interface ISidebarWrapperProps {
|
|
5
|
+
navSections: NavSectionType[];
|
|
6
|
+
sidebarHeader: React.ReactNode;
|
|
7
|
+
sidebarHeaderAsMenuItem?: boolean;
|
|
8
|
+
sidebarHeaderLink?: string;
|
|
9
|
+
header?: React.ReactNode | (() => React.ReactNode);
|
|
10
|
+
children: React.ReactNode;
|
|
11
|
+
LinkComponent?: React.ComponentType<any>;
|
|
12
|
+
sidebarFooter?: React.ReactNode;
|
|
13
|
+
sidebarContent?: React.ReactNode;
|
|
14
|
+
userInfo?: React.ReactNode;
|
|
15
|
+
userInfoPlacement?: 'content' | 'footer' | 'both' | 'none';
|
|
16
|
+
hasSideRail?: boolean;
|
|
17
|
+
headerClass?: string;
|
|
18
|
+
mainClass?: string;
|
|
19
|
+
sidebarClassNames?: SidebarClassNames;
|
|
20
|
+
navClassNames?: NavItemClassNames;
|
|
21
|
+
showHeader?: boolean;
|
|
22
|
+
showFooter?: boolean;
|
|
23
|
+
compactWhenCollapsed?: boolean;
|
|
24
|
+
}
|
|
25
|
+
declare const SidebarLayout: React.FunctionComponent<ISidebarWrapperProps>;
|
|
26
|
+
export default SidebarLayout;
|
|
27
|
+
export { SidebarSheet } from './sidebar-sheet';
|
|
28
|
+
export type { SidebarSheetProps } from './sidebar-sheet';
|
|
29
|
+
export type { NavItemClassNames, SidebarClassNames };
|
|
30
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/common/display/sidebar/index.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAE7C,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,MAAM,SAAS,CAAC;AAE/D,UAAU,oBAAoB;IAC5B,WAAW,EAAE,cAAc,EAAE,CAAC;IAC9B,aAAa,EAAE,KAAK,CAAC,SAAS,CAAC;IAC/B,uBAAuB,CAAC,EAAE,OAAO,CAAC;IAClC,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,GAAG,CAAC,MAAM,KAAK,CAAC,SAAS,CAAC,CAAC;IACnD,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,aAAa,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;IACzC,aAAa,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAChC,cAAc,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACjC,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,iBAAiB,CAAC,EAAE,SAAS,GAAG,QAAQ,GAAG,MAAM,GAAG,MAAM,CAAC;IAC3D,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB,iBAAiB,CAAC,EAAE,iBAAiB,CAAC;IACtC,aAAa,CAAC,EAAE,iBAAiB,CAAC;IAClC,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,oBAAoB,CAAC,EAAE,OAAO,CAAC;CAChC;AA0BD,QAAA,MAAM,aAAa,EAAE,KAAK,CAAC,iBAAiB,CAAC,oBAAoB,CA0DhE,CAAC;AAEF,eAAe,aAAa,CAAC;AAC7B,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,YAAY,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACzD,YAAY,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,CAAC"}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
6
|
+
var sidebar = require('@/components/sidebar');
|
|
7
|
+
var utils = require('@/lib/utils');
|
|
8
|
+
var appSidebar = require('./app-sidebar');
|
|
9
|
+
var sidebarSheet = require('./sidebar-sheet');
|
|
10
|
+
|
|
11
|
+
const SidebarContent = ({ header, children, headerClass, mainClass }) => {
|
|
12
|
+
const headerContent = typeof header === "function" ? header() : header;
|
|
13
|
+
return /* @__PURE__ */ jsxRuntime.jsxs(sidebar.SidebarInset, { className: "flex min-h-svh min-w-0 flex-1 flex-col", "data-sidebar": "inset", children: [
|
|
14
|
+
/* @__PURE__ */ jsxRuntime.jsx(
|
|
15
|
+
"header",
|
|
16
|
+
{
|
|
17
|
+
className: utils.cn(
|
|
18
|
+
"bg-background fixed left-0 right-0 top-0 z-30 flex h-16 shrink-0 items-center justify-between gap-2 border-b px-4",
|
|
19
|
+
headerClass
|
|
20
|
+
),
|
|
21
|
+
children: headerContent
|
|
22
|
+
}
|
|
23
|
+
),
|
|
24
|
+
/* @__PURE__ */ jsxRuntime.jsx("main", { className: utils.cn("flex-1 pt-16", mainClass), children })
|
|
25
|
+
] });
|
|
26
|
+
};
|
|
27
|
+
const SidebarLayout = ({
|
|
28
|
+
navSections,
|
|
29
|
+
sidebarHeader,
|
|
30
|
+
sidebarHeaderAsMenuItem = false,
|
|
31
|
+
sidebarHeaderLink = "/",
|
|
32
|
+
sidebarFooter,
|
|
33
|
+
sidebarContent,
|
|
34
|
+
userInfo,
|
|
35
|
+
userInfoPlacement = "content",
|
|
36
|
+
hasSideRail,
|
|
37
|
+
header,
|
|
38
|
+
children,
|
|
39
|
+
LinkComponent,
|
|
40
|
+
headerClass,
|
|
41
|
+
mainClass,
|
|
42
|
+
sidebarClassNames,
|
|
43
|
+
navClassNames,
|
|
44
|
+
showHeader = true,
|
|
45
|
+
showFooter = true,
|
|
46
|
+
compactWhenCollapsed = true
|
|
47
|
+
}) => {
|
|
48
|
+
const showUserInfoInContent = userInfoPlacement === "content" || userInfoPlacement === "both";
|
|
49
|
+
const showUserInfoInFooter = userInfoPlacement === "footer" || userInfoPlacement === "both";
|
|
50
|
+
const composedSidebarContent = showUserInfoInContent && userInfo ? /* @__PURE__ */ jsxRuntime.jsx(jsxRuntime.Fragment, { children: userInfo }) : sidebarContent;
|
|
51
|
+
const composedSidebarFooter = showUserInfoInFooter && userInfo ? /* @__PURE__ */ jsxRuntime.jsx(jsxRuntime.Fragment, { children: userInfo }) : sidebarFooter;
|
|
52
|
+
return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
|
|
53
|
+
/* @__PURE__ */ jsxRuntime.jsx(
|
|
54
|
+
appSidebar.AppSidebar,
|
|
55
|
+
{
|
|
56
|
+
navSections,
|
|
57
|
+
sidebarHeader,
|
|
58
|
+
sidebarHeaderAsMenuItem,
|
|
59
|
+
sidebarHeaderLink,
|
|
60
|
+
sidebarFooter: composedSidebarFooter,
|
|
61
|
+
sidebarContent: composedSidebarContent,
|
|
62
|
+
LinkComponent,
|
|
63
|
+
showHeader,
|
|
64
|
+
showFooter,
|
|
65
|
+
compactWhenCollapsed,
|
|
66
|
+
className: sidebarClassNames?.root,
|
|
67
|
+
classNames: {
|
|
68
|
+
header: sidebarClassNames?.header,
|
|
69
|
+
content: sidebarClassNames?.content,
|
|
70
|
+
footer: sidebarClassNames?.footer,
|
|
71
|
+
trigger: sidebarClassNames?.trigger,
|
|
72
|
+
mobileRoot: sidebarClassNames?.mobileRoot
|
|
73
|
+
},
|
|
74
|
+
hasSideRail,
|
|
75
|
+
navClassNames
|
|
76
|
+
}
|
|
77
|
+
),
|
|
78
|
+
/* @__PURE__ */ jsxRuntime.jsx(SidebarContent, { header, headerClass, mainClass, children })
|
|
79
|
+
] });
|
|
80
|
+
};
|
|
81
|
+
var sidebar_default = SidebarLayout;
|
|
82
|
+
|
|
83
|
+
Object.defineProperty(exports, "SidebarSheet", {
|
|
84
|
+
enumerable: true,
|
|
85
|
+
get: function () { return sidebarSheet.SidebarSheet; }
|
|
86
|
+
});
|
|
87
|
+
exports.default = sidebar_default;
|
|
88
|
+
//# sourceMappingURL=index.js.map
|
|
89
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/common/display/sidebar/index.tsx"],"names":["jsxs","SidebarInset","jsx","cn","Fragment","AppSidebar"],"mappings":";;;;;;;;;;AA+BA,MAAM,iBAKD,CAAC,EAAE,QAAQ,QAAA,EAAU,WAAA,EAAa,WAAU,KAAM;AAErD,EAAA,MAAM,aAAA,GAAgB,OAAO,MAAA,KAAW,UAAA,GAAa,QAAO,GAAI,MAAA;AAEhE,EAAA,uBACEA,eAAA,CAACC,oBAAA,EAAA,EAAa,SAAA,EAAU,wCAAA,EAAyC,gBAAa,OAAA,EAC5E,QAAA,EAAA;AAAA,oBAAAC,cAAA;AAAA,MAAC,QAAA;AAAA,MAAA;AAAA,QACC,SAAA,EAAWC,QAAA;AAAA,UACT,mHAAA;AAAA,UACA;AAAA,SACF;AAAA,QAEC,QAAA,EAAA;AAAA;AAAA,KACH;AAAA,mCACC,MAAA,EAAA,EAAK,SAAA,EAAWA,SAAG,cAAA,EAAgB,SAAS,GAAI,QAAA,EAAS;AAAA,GAAA,EAC5D,CAAA;AAEJ,CAAA;AAEA,MAAM,gBAA+D,CAAC;AAAA,EACpE,WAAA;AAAA,EACA,aAAA;AAAA,EACA,uBAAA,GAA0B,KAAA;AAAA,EAC1B,iBAAA,GAAoB,GAAA;AAAA,EACpB,aAAA;AAAA,EACA,cAAA;AAAA,EACA,QAAA;AAAA,EACA,iBAAA,GAAoB,SAAA;AAAA,EACpB,WAAA;AAAA,EACA,MAAA;AAAA,EACA,QAAA;AAAA,EACA,aAAA;AAAA,EACA,WAAA;AAAA,EACA,SAAA;AAAA,EACA,iBAAA;AAAA,EACA,aAAA;AAAA,EACA,UAAA,GAAa,IAAA;AAAA,EACb,UAAA,GAAa,IAAA;AAAA,EACb,oBAAA,GAAuB;AACzB,CAAA,KAAM;AAEJ,EAAA,MAAM,qBAAA,GAAwB,iBAAA,KAAsB,SAAA,IAAa,iBAAA,KAAsB,MAAA;AACvF,EAAA,MAAM,oBAAA,GAAuB,iBAAA,KAAsB,QAAA,IAAY,iBAAA,KAAsB,MAAA;AAErF,EAAA,MAAM,sBAAA,GACJ,qBAAA,IAAyB,QAAA,mBAAWD,cAAA,CAAAE,mBAAA,EAAA,EAAG,oBAAS,CAAA,GAAM,cAAA;AACxD,EAAA,MAAM,qBAAA,GAAwB,oBAAA,IAAwB,QAAA,mBAAWF,cAAA,CAAAE,mBAAA,EAAA,EAAG,oBAAS,CAAA,GAAM,aAAA;AAEnF,EAAA,uBACEJ,eAAA,CAAAI,mBAAA,EAAA,EACE,QAAA,EAAA;AAAA,oBAAAF,cAAA;AAAA,MAACG,qBAAA;AAAA,MAAA;AAAA,QACC,WAAA;AAAA,QACA,aAAA;AAAA,QACA,uBAAA;AAAA,QACA,iBAAA;AAAA,QACA,aAAA,EAAe,qBAAA;AAAA,QACf,cAAA,EAAgB,sBAAA;AAAA,QAChB,aAAA;AAAA,QACA,UAAA;AAAA,QACA,UAAA;AAAA,QACA,oBAAA;AAAA,QACA,WAAW,iBAAA,EAAmB,IAAA;AAAA,QAC9B,UAAA,EAAY;AAAA,UACV,QAAQ,iBAAA,EAAmB,MAAA;AAAA,UAC3B,SAAS,iBAAA,EAAmB,OAAA;AAAA,UAC5B,QAAQ,iBAAA,EAAmB,MAAA;AAAA,UAC3B,SAAS,iBAAA,EAAmB,OAAA;AAAA,UAC5B,YAAY,iBAAA,EAAmB;AAAA,SACjC;AAAA,QACA,WAAA;AAAA,QACA;AAAA;AAAA,KACF;AAAA,oBACAH,cAAA,CAAC,cAAA,EAAA,EAAe,MAAA,EAAgB,WAAA,EAA0B,WACvD,QAAA,EACH;AAAA,GAAA,EACF,CAAA;AAEJ,CAAA;AAEA,IAAO,eAAA,GAAQ","file":"index.js","sourcesContent":["'use client';\nimport { SidebarInset } from '@/components/sidebar';\nimport { NavSectionType } from '@/lib/types';\nimport { cn } from '@/lib/utils';\nimport * as React from 'react';\nimport { AppSidebar } from './app-sidebar';\nimport { NavItemClassNames, SidebarClassNames } from './types';\n\ninterface ISidebarWrapperProps {\n navSections: NavSectionType[]; // Changed from navItems to navSections\n sidebarHeader: React.ReactNode;\n sidebarHeaderAsMenuItem?: boolean; // If true, wraps sidebarHeader in SidebarMenu structure\n sidebarHeaderLink?: string; // Optional link for header when used as menu item\n header?: React.ReactNode | (() => React.ReactNode); // Can be ReactNode or function that returns ReactNode\n children: React.ReactNode;\n LinkComponent?: React.ComponentType<any>;\n sidebarFooter?: React.ReactNode; // Footer content (can be overridden by userInfo)\n sidebarContent?: React.ReactNode; // Content before navigation (can be overridden by userInfo)\n userInfo?: React.ReactNode; // User info section (will be placed based on userInfoPlacement)\n userInfoPlacement?: 'content' | 'footer' | 'both' | 'none'; // Control where userInfo is displayed\n hasSideRail?: boolean; // Controls SidebarRail visibility for drag-to-resize functionality\n headerClass?: string;\n mainClass?: string;\n // Grouped style customization props\n sidebarClassNames?: SidebarClassNames;\n navClassNames?: NavItemClassNames;\n showHeader?: boolean;\n showFooter?: boolean;\n compactWhenCollapsed?: boolean;\n}\n\nconst SidebarContent: React.FunctionComponent<{\n header: React.ReactNode | (() => React.ReactNode);\n children: React.ReactNode;\n headerClass?: string;\n mainClass?: string;\n}> = ({ header, children, headerClass, mainClass }) => {\n // Render header - if it's a function, call it inside the component so it has access to context\n const headerContent = typeof header === 'function' ? header() : header;\n\n return (\n <SidebarInset className=\"flex min-h-svh min-w-0 flex-1 flex-col\" data-sidebar=\"inset\">\n <header\n className={cn(\n 'bg-background fixed left-0 right-0 top-0 z-30 flex h-16 shrink-0 items-center justify-between gap-2 border-b px-4',\n headerClass,\n )}\n >\n {headerContent}\n </header>\n <main className={cn('flex-1 pt-16', mainClass)}>{children}</main>\n </SidebarInset>\n );\n};\n\nconst SidebarLayout: React.FunctionComponent<ISidebarWrapperProps> = ({\n navSections,\n sidebarHeader,\n sidebarHeaderAsMenuItem = false,\n sidebarHeaderLink = '/',\n sidebarFooter,\n sidebarContent,\n userInfo,\n userInfoPlacement = 'content',\n hasSideRail,\n header,\n children,\n LinkComponent,\n headerClass,\n mainClass,\n sidebarClassNames,\n navClassNames,\n showHeader = true,\n showFooter = true,\n compactWhenCollapsed = true,\n}) => {\n // Compose sidebar content and footer based on userInfoPlacement\n const showUserInfoInContent = userInfoPlacement === 'content' || userInfoPlacement === 'both';\n const showUserInfoInFooter = userInfoPlacement === 'footer' || userInfoPlacement === 'both';\n\n const composedSidebarContent =\n showUserInfoInContent && userInfo ? <>{userInfo}</> : sidebarContent;\n const composedSidebarFooter = showUserInfoInFooter && userInfo ? <>{userInfo}</> : sidebarFooter;\n\n return (\n <>\n <AppSidebar\n navSections={navSections}\n sidebarHeader={sidebarHeader}\n sidebarHeaderAsMenuItem={sidebarHeaderAsMenuItem}\n sidebarHeaderLink={sidebarHeaderLink}\n sidebarFooter={composedSidebarFooter}\n sidebarContent={composedSidebarContent}\n LinkComponent={LinkComponent}\n showHeader={showHeader}\n showFooter={showFooter}\n compactWhenCollapsed={compactWhenCollapsed}\n className={sidebarClassNames?.root}\n classNames={{\n header: sidebarClassNames?.header,\n content: sidebarClassNames?.content,\n footer: sidebarClassNames?.footer,\n trigger: sidebarClassNames?.trigger,\n mobileRoot: sidebarClassNames?.mobileRoot,\n }}\n hasSideRail={hasSideRail}\n navClassNames={navClassNames}\n />\n <SidebarContent header={header} headerClass={headerClass} mainClass={mainClass}>\n {children}\n </SidebarContent>\n </>\n );\n};\n\nexport default SidebarLayout;\nexport { SidebarSheet } from './sidebar-sheet';\nexport type { SidebarSheetProps } from './sidebar-sheet';\nexport type { NavItemClassNames, SidebarClassNames };\n"]}
|