shad-m 1.0.0 → 1.0.2
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/dist/common/interactive/list.d.ts +1 -1
- package/dist/common/interactive/select/variants.d.ts +1 -1
- package/dist/components/alert-dialog.d.ts +2 -2
- package/dist/components/badge.d.ts +3 -3
- package/dist/components/button.d.ts +4 -4
- package/dist/components/chip.d.ts +2 -2
- package/dist/components/command.d.ts +7 -7
- package/dist/components/dialog.d.ts +2 -2
- package/dist/components/input-otp.d.ts +2 -2
- package/dist/components/resizable.d.ts +1 -1
- package/dist/components/sidebar.d.ts +1 -1
- package/dist/components/spinner.d.ts +2 -2
- package/dist/components/stepper.d.ts +3 -3
- package/dist/components/toggle-group.d.ts +2 -2
- package/dist/components/toggle.d.ts +2 -2
- package/dist/index.css +43 -0
- package/dist/index.css.map +1 -0
- package/dist/index.d.ts +59 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +8189 -0
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +7846 -0
- package/dist/index.mjs.map +1 -0
- package/package.json +34 -2
- package/dist/assets/Animation/index.js +0 -180
- package/dist/assets/Animation/index.js.map +0 -1
- package/dist/assets/Animation/index.mjs +0 -79
- package/dist/assets/Animation/index.mjs.map +0 -1
- package/dist/assets/Icon/index.js +0 -2102
- package/dist/assets/Icon/index.js.map +0 -1
- package/dist/assets/Icon/index.mjs +0 -421
- package/dist/assets/Icon/index.mjs.map +0 -1
- package/dist/assets/Image/index.js +0 -755
- package/dist/assets/Image/index.js.map +0 -1
- package/dist/assets/Image/index.mjs +0 -150
- package/dist/assets/Image/index.mjs.map +0 -1
- package/dist/common/display/countdown.js +0 -68
- package/dist/common/display/countdown.js.map +0 -1
- package/dist/common/display/countdown.mjs +0 -46
- package/dist/common/display/countdown.mjs.map +0 -1
- package/dist/common/display/display-field-group.js +0 -91
- package/dist/common/display/display-field-group.js.map +0 -1
- package/dist/common/display/display-field-group.mjs +0 -89
- package/dist/common/display/display-field-group.mjs.map +0 -1
- package/dist/common/display/display-field.js +0 -46
- package/dist/common/display/display-field.js.map +0 -1
- package/dist/common/display/display-field.mjs +0 -40
- package/dist/common/display/display-field.mjs.map +0 -1
- package/dist/common/display/display-html-string.js +0 -52
- package/dist/common/display/display-html-string.js.map +0 -1
- package/dist/common/display/display-html-string.mjs +0 -30
- package/dist/common/display/display-html-string.mjs.map +0 -1
- package/dist/common/display/index.js +0 -59
- package/dist/common/display/index.js.map +0 -1
- package/dist/common/display/index.mjs +0 -10
- package/dist/common/display/index.mjs.map +0 -1
- package/dist/common/display/page-breadcrumb.js +0 -43
- package/dist/common/display/page-breadcrumb.js.map +0 -1
- package/dist/common/display/page-breadcrumb.mjs +0 -37
- package/dist/common/display/page-breadcrumb.mjs.map +0 -1
- package/dist/common/display/page-v2.js +0 -58
- package/dist/common/display/page-v2.js.map +0 -1
- package/dist/common/display/page-v2.mjs +0 -20
- package/dist/common/display/page-v2.mjs.map +0 -1
- package/dist/common/display/page.js +0 -155
- package/dist/common/display/page.js.map +0 -1
- package/dist/common/display/page.mjs +0 -138
- package/dist/common/display/page.mjs.map +0 -1
- package/dist/common/display/score-meter.js +0 -161
- package/dist/common/display/score-meter.js.map +0 -1
- package/dist/common/display/score-meter.mjs +0 -140
- package/dist/common/display/score-meter.mjs.map +0 -1
- package/dist/common/display/sidebar/app-sidebar.js +0 -114
- package/dist/common/display/sidebar/app-sidebar.js.map +0 -1
- package/dist/common/display/sidebar/app-sidebar.mjs +0 -92
- package/dist/common/display/sidebar/app-sidebar.mjs.map +0 -1
- package/dist/common/display/sidebar/index.js +0 -89
- package/dist/common/display/sidebar/index.js.map +0 -1
- package/dist/common/display/sidebar/index.mjs +0 -81
- package/dist/common/display/sidebar/index.mjs.map +0 -1
- package/dist/common/display/sidebar/nav-main.js +0 -406
- package/dist/common/display/sidebar/nav-main.js.map +0 -1
- package/dist/common/display/sidebar/nav-main.mjs +0 -400
- package/dist/common/display/sidebar/nav-main.mjs.map +0 -1
- package/dist/common/display/sidebar/sidebar-sheet.js +0 -140
- package/dist/common/display/sidebar/sidebar-sheet.js.map +0 -1
- package/dist/common/display/sidebar/sidebar-sheet.mjs +0 -118
- package/dist/common/display/sidebar/sidebar-sheet.mjs.map +0 -1
- package/dist/common/display/sidebar/types.js +0 -4
- package/dist/common/display/sidebar/types.js.map +0 -1
- package/dist/common/display/sidebar/types.mjs +0 -3
- package/dist/common/display/sidebar/types.mjs.map +0 -1
- package/dist/common/display/status-state.js +0 -97
- package/dist/common/display/status-state.js.map +0 -1
- package/dist/common/display/status-state.mjs +0 -88
- package/dist/common/display/status-state.mjs.map +0 -1
- package/dist/common/forms/auto-form.js +0 -101
- package/dist/common/forms/auto-form.js.map +0 -1
- package/dist/common/forms/auto-form.mjs +0 -78
- package/dist/common/forms/auto-form.mjs.map +0 -1
- package/dist/common/forms/form-field.js +0 -58
- package/dist/common/forms/form-field.js.map +0 -1
- package/dist/common/forms/form-field.mjs +0 -56
- package/dist/common/forms/form-field.mjs.map +0 -1
- package/dist/common/forms/form-input-field.js +0 -64
- package/dist/common/forms/form-input-field.js.map +0 -1
- package/dist/common/forms/form-input-field.mjs +0 -62
- package/dist/common/forms/form-input-field.mjs.map +0 -1
- package/dist/common/forms/index.js +0 -22
- package/dist/common/forms/index.js.map +0 -1
- package/dist/common/forms/index.mjs +0 -5
- package/dist/common/forms/index.mjs.map +0 -1
- package/dist/common/forms/switch-field.js +0 -106
- package/dist/common/forms/switch-field.js.map +0 -1
- package/dist/common/forms/switch-field.mjs +0 -104
- package/dist/common/forms/switch-field.mjs.map +0 -1
- package/dist/common/interactive/alert-dialog-wrapper.js +0 -141
- package/dist/common/interactive/alert-dialog-wrapper.js.map +0 -1
- package/dist/common/interactive/alert-dialog-wrapper.mjs +0 -119
- package/dist/common/interactive/alert-dialog-wrapper.mjs.map +0 -1
- package/dist/common/interactive/autocomplete.js +0 -178
- package/dist/common/interactive/autocomplete.js.map +0 -1
- package/dist/common/interactive/autocomplete.mjs +0 -157
- package/dist/common/interactive/autocomplete.mjs.map +0 -1
- package/dist/common/interactive/copy-tooltip.js +0 -152
- package/dist/common/interactive/copy-tooltip.js.map +0 -1
- package/dist/common/interactive/copy-tooltip.mjs +0 -143
- package/dist/common/interactive/copy-tooltip.mjs.map +0 -1
- package/dist/common/interactive/date-field.js +0 -303
- package/dist/common/interactive/date-field.js.map +0 -1
- package/dist/common/interactive/date-field.mjs +0 -281
- package/dist/common/interactive/date-field.mjs.map +0 -1
- package/dist/common/interactive/date-input/date-input.js +0 -68
- package/dist/common/interactive/date-input/date-input.js.map +0 -1
- package/dist/common/interactive/date-input/date-input.mjs +0 -62
- package/dist/common/interactive/date-input/date-input.mjs.map +0 -1
- package/dist/common/interactive/date-input/index.js +0 -17
- package/dist/common/interactive/date-input/index.js.map +0 -1
- package/dist/common/interactive/date-input/index.mjs +0 -4
- package/dist/common/interactive/date-input/index.mjs.map +0 -1
- package/dist/common/interactive/date-input/types.js +0 -4
- package/dist/common/interactive/date-input/types.js.map +0 -1
- package/dist/common/interactive/date-input/types.mjs +0 -3
- package/dist/common/interactive/date-input/types.mjs.map +0 -1
- package/dist/common/interactive/date-input/use-typed-date.js +0 -478
- package/dist/common/interactive/date-input/use-typed-date.js.map +0 -1
- package/dist/common/interactive/date-input/use-typed-date.mjs +0 -476
- package/dist/common/interactive/date-input/use-typed-date.mjs.map +0 -1
- package/dist/common/interactive/date-input/utils.js +0 -34
- package/dist/common/interactive/date-input/utils.js.map +0 -1
- package/dist/common/interactive/date-input/utils.mjs +0 -29
- package/dist/common/interactive/date-input/utils.mjs.map +0 -1
- package/dist/common/interactive/date-picker.js +0 -616
- package/dist/common/interactive/date-picker.js.map +0 -1
- package/dist/common/interactive/date-picker.mjs +0 -594
- package/dist/common/interactive/date-picker.mjs.map +0 -1
- package/dist/common/interactive/date-range-input/date-range-input.js +0 -82
- package/dist/common/interactive/date-range-input/date-range-input.js.map +0 -1
- package/dist/common/interactive/date-range-input/date-range-input.mjs +0 -76
- package/dist/common/interactive/date-range-input/date-range-input.mjs.map +0 -1
- package/dist/common/interactive/date-range-input/index.js +0 -12
- package/dist/common/interactive/date-range-input/index.js.map +0 -1
- package/dist/common/interactive/date-range-input/index.mjs +0 -3
- package/dist/common/interactive/date-range-input/index.mjs.map +0 -1
- package/dist/common/interactive/date-range-input/types.js +0 -4
- package/dist/common/interactive/date-range-input/types.js.map +0 -1
- package/dist/common/interactive/date-range-input/types.mjs +0 -3
- package/dist/common/interactive/date-range-input/types.mjs.map +0 -1
- package/dist/common/interactive/date-range-input/use-typed-date-range.js +0 -602
- package/dist/common/interactive/date-range-input/use-typed-date-range.js.map +0 -1
- package/dist/common/interactive/date-range-input/use-typed-date-range.mjs +0 -600
- package/dist/common/interactive/date-range-input/use-typed-date-range.mjs.map +0 -1
- package/dist/common/interactive/date-time-picker.js +0 -215
- package/dist/common/interactive/date-time-picker.js.map +0 -1
- package/dist/common/interactive/date-time-picker.mjs +0 -213
- package/dist/common/interactive/date-time-picker.mjs.map +0 -1
- package/dist/common/interactive/dialog-wrapper.js +0 -124
- package/dist/common/interactive/dialog-wrapper.js.map +0 -1
- package/dist/common/interactive/dialog-wrapper.mjs +0 -102
- package/dist/common/interactive/dialog-wrapper.mjs.map +0 -1
- package/dist/common/interactive/filter.js +0 -287
- package/dist/common/interactive/filter.js.map +0 -1
- package/dist/common/interactive/filter.mjs +0 -280
- package/dist/common/interactive/filter.mjs.map +0 -1
- package/dist/common/interactive/index.js +0 -235
- package/dist/common/interactive/index.js.map +0 -1
- package/dist/common/interactive/index.mjs +0 -24
- package/dist/common/interactive/index.mjs.map +0 -1
- package/dist/common/interactive/list.js +0 -160
- package/dist/common/interactive/list.js.map +0 -1
- package/dist/common/interactive/list.mjs +0 -134
- package/dist/common/interactive/list.mjs.map +0 -1
- package/dist/common/interactive/otp-dialog/index.js +0 -35
- package/dist/common/interactive/otp-dialog/index.js.map +0 -1
- package/dist/common/interactive/otp-dialog/index.mjs +0 -6
- package/dist/common/interactive/otp-dialog/index.mjs.map +0 -1
- package/dist/common/interactive/otp-dialog/otp-dialog.js +0 -325
- package/dist/common/interactive/otp-dialog/otp-dialog.js.map +0 -1
- package/dist/common/interactive/otp-dialog/otp-dialog.mjs +0 -303
- package/dist/common/interactive/otp-dialog/otp-dialog.mjs.map +0 -1
- package/dist/common/interactive/otp-dialog/reducer.js +0 -40
- package/dist/common/interactive/otp-dialog/reducer.js.map +0 -1
- package/dist/common/interactive/otp-dialog/reducer.mjs +0 -37
- package/dist/common/interactive/otp-dialog/reducer.mjs.map +0 -1
- package/dist/common/interactive/otp-dialog/types.js +0 -15
- package/dist/common/interactive/otp-dialog/types.js.map +0 -1
- package/dist/common/interactive/otp-dialog/types.mjs +0 -13
- package/dist/common/interactive/otp-dialog/types.mjs.map +0 -1
- package/dist/common/interactive/otp-dialog/utils.js +0 -24
- package/dist/common/interactive/otp-dialog/utils.js.map +0 -1
- package/dist/common/interactive/otp-dialog/utils.mjs +0 -21
- package/dist/common/interactive/otp-dialog/utils.mjs.map +0 -1
- package/dist/common/interactive/pagination/PaginationSkeleton.js +0 -51
- package/dist/common/interactive/pagination/PaginationSkeleton.js.map +0 -1
- package/dist/common/interactive/pagination/PaginationSkeleton.mjs +0 -49
- package/dist/common/interactive/pagination/PaginationSkeleton.mjs.map +0 -1
- package/dist/common/interactive/pagination/index.js +0 -235
- package/dist/common/interactive/pagination/index.js.map +0 -1
- package/dist/common/interactive/pagination/index.mjs +0 -223
- package/dist/common/interactive/pagination/index.mjs.map +0 -1
- package/dist/common/interactive/pagination/usePagination.js +0 -28
- package/dist/common/interactive/pagination/usePagination.js.map +0 -1
- package/dist/common/interactive/pagination/usePagination.mjs +0 -25
- package/dist/common/interactive/pagination/usePagination.mjs.map +0 -1
- package/dist/common/interactive/popover-wrapper.js +0 -138
- package/dist/common/interactive/popover-wrapper.js.map +0 -1
- package/dist/common/interactive/popover-wrapper.mjs +0 -116
- package/dist/common/interactive/popover-wrapper.mjs.map +0 -1
- package/dist/common/interactive/pressable.js +0 -84
- package/dist/common/interactive/pressable.js.map +0 -1
- package/dist/common/interactive/pressable.mjs +0 -62
- package/dist/common/interactive/pressable.mjs.map +0 -1
- package/dist/common/interactive/select/context.js +0 -38
- package/dist/common/interactive/select/context.js.map +0 -1
- package/dist/common/interactive/select/context.mjs +0 -14
- package/dist/common/interactive/select/context.mjs.map +0 -1
- package/dist/common/interactive/select/index.js +0 -123
- package/dist/common/interactive/select/index.js.map +0 -1
- package/dist/common/interactive/select/index.mjs +0 -18
- package/dist/common/interactive/select/index.mjs.map +0 -1
- package/dist/common/interactive/select/select-body.js +0 -89
- package/dist/common/interactive/select/select-body.js.map +0 -1
- package/dist/common/interactive/select/select-body.mjs +0 -67
- package/dist/common/interactive/select/select-body.mjs.map +0 -1
- package/dist/common/interactive/select/select-close.js +0 -38
- package/dist/common/interactive/select/select-close.js.map +0 -1
- package/dist/common/interactive/select/select-close.mjs +0 -16
- package/dist/common/interactive/select/select-close.mjs.map +0 -1
- package/dist/common/interactive/select/select-content-auto-layout.js +0 -221
- package/dist/common/interactive/select/select-content-auto-layout.js.map +0 -1
- package/dist/common/interactive/select/select-content-auto-layout.mjs +0 -199
- package/dist/common/interactive/select/select-content-auto-layout.mjs.map +0 -1
- package/dist/common/interactive/select/select-content-group-auto-layout.js +0 -411
- package/dist/common/interactive/select/select-content-group-auto-layout.js.map +0 -1
- package/dist/common/interactive/select/select-content-group-auto-layout.mjs +0 -389
- package/dist/common/interactive/select/select-content-group-auto-layout.mjs.map +0 -1
- package/dist/common/interactive/select/select-content.js +0 -187
- package/dist/common/interactive/select/select-content.js.map +0 -1
- package/dist/common/interactive/select/select-content.mjs +0 -165
- package/dist/common/interactive/select/select-content.mjs.map +0 -1
- package/dist/common/interactive/select/select-footer.js +0 -82
- package/dist/common/interactive/select/select-footer.js.map +0 -1
- package/dist/common/interactive/select/select-footer.mjs +0 -60
- package/dist/common/interactive/select/select-footer.mjs.map +0 -1
- package/dist/common/interactive/select/select-item.js +0 -214
- package/dist/common/interactive/select/select-item.js.map +0 -1
- package/dist/common/interactive/select/select-item.mjs +0 -191
- package/dist/common/interactive/select/select-item.mjs.map +0 -1
- package/dist/common/interactive/select/select-layout.js +0 -66
- package/dist/common/interactive/select/select-layout.js.map +0 -1
- package/dist/common/interactive/select/select-layout.mjs +0 -41
- package/dist/common/interactive/select/select-layout.mjs.map +0 -1
- package/dist/common/interactive/select/select-search.js +0 -55
- package/dist/common/interactive/select/select-search.js.map +0 -1
- package/dist/common/interactive/select/select-search.mjs +0 -33
- package/dist/common/interactive/select/select-search.mjs.map +0 -1
- package/dist/common/interactive/select/select-states.js +0 -57
- package/dist/common/interactive/select/select-states.js.map +0 -1
- package/dist/common/interactive/select/select-states.mjs +0 -34
- package/dist/common/interactive/select/select-states.mjs.map +0 -1
- package/dist/common/interactive/select/select-trigger.js +0 -310
- package/dist/common/interactive/select/select-trigger.js.map +0 -1
- package/dist/common/interactive/select/select-trigger.mjs +0 -286
- package/dist/common/interactive/select/select-trigger.mjs.map +0 -1
- package/dist/common/interactive/select/select-value.js +0 -52
- package/dist/common/interactive/select/select-value.js.map +0 -1
- package/dist/common/interactive/select/select-value.mjs +0 -30
- package/dist/common/interactive/select/select-value.mjs.map +0 -1
- package/dist/common/interactive/select/select.js +0 -184
- package/dist/common/interactive/select/select.js.map +0 -1
- package/dist/common/interactive/select/select.mjs +0 -162
- package/dist/common/interactive/select/select.mjs.map +0 -1
- package/dist/common/interactive/select/types.js +0 -4
- package/dist/common/interactive/select/types.js.map +0 -1
- package/dist/common/interactive/select/types.mjs +0 -3
- package/dist/common/interactive/select/types.mjs.map +0 -1
- package/dist/common/interactive/select/utils.js +0 -31
- package/dist/common/interactive/select/utils.js.map +0 -1
- package/dist/common/interactive/select/utils.mjs +0 -28
- package/dist/common/interactive/select/utils.mjs.map +0 -1
- package/dist/common/interactive/select/variants.js +0 -27
- package/dist/common/interactive/select/variants.js.map +0 -1
- package/dist/common/interactive/select/variants.mjs +0 -25
- package/dist/common/interactive/select/variants.mjs.map +0 -1
- package/dist/common/interactive/select-chip.js +0 -76
- package/dist/common/interactive/select-chip.js.map +0 -1
- package/dist/common/interactive/select-chip.mjs +0 -74
- package/dist/common/interactive/select-chip.mjs.map +0 -1
- package/dist/common/interactive/select-level.js +0 -236
- package/dist/common/interactive/select-level.js.map +0 -1
- package/dist/common/interactive/select-level.mjs +0 -230
- package/dist/common/interactive/select-level.mjs.map +0 -1
- package/dist/common/interactive/select-range.js +0 -211
- package/dist/common/interactive/select-range.js.map +0 -1
- package/dist/common/interactive/select-range.mjs +0 -209
- package/dist/common/interactive/select-range.mjs.map +0 -1
- package/dist/common/interactive/select-with-api.js +0 -767
- package/dist/common/interactive/select-with-api.js.map +0 -1
- package/dist/common/interactive/select-with-api.mjs +0 -758
- package/dist/common/interactive/select-with-api.mjs.map +0 -1
- package/dist/common/interactive/select.js +0 -15
- package/dist/common/interactive/select.js.map +0 -1
- package/dist/common/interactive/select.mjs +0 -4
- package/dist/common/interactive/select.mjs.map +0 -1
- package/dist/common/interactive/sheet-wrapper.js +0 -105
- package/dist/common/interactive/sheet-wrapper.js.map +0 -1
- package/dist/common/interactive/sheet-wrapper.mjs +0 -83
- package/dist/common/interactive/sheet-wrapper.mjs.map +0 -1
- package/dist/common/interactive/table/enhanced-table.js +0 -390
- package/dist/common/interactive/table/enhanced-table.js.map +0 -1
- package/dist/common/interactive/table/enhanced-table.mjs +0 -388
- package/dist/common/interactive/table/enhanced-table.mjs.map +0 -1
- package/dist/common/interactive/table/index.js +0 -83
- package/dist/common/interactive/table/index.js.map +0 -1
- package/dist/common/interactive/table/index.mjs +0 -68
- package/dist/common/interactive/table/index.mjs.map +0 -1
- package/dist/common/interactive/table/table-pagination.js +0 -12
- package/dist/common/interactive/table/table-pagination.js.map +0 -1
- package/dist/common/interactive/table/table-pagination.mjs +0 -10
- package/dist/common/interactive/table/table-pagination.mjs.map +0 -1
- package/dist/common/interactive/table/types.js +0 -4
- package/dist/common/interactive/table/types.js.map +0 -1
- package/dist/common/interactive/table/types.mjs +0 -3
- package/dist/common/interactive/table/types.mjs.map +0 -1
- package/dist/common/interactive/time-picker.js +0 -313
- package/dist/common/interactive/time-picker.js.map +0 -1
- package/dist/common/interactive/time-picker.mjs +0 -307
- package/dist/common/interactive/time-picker.mjs.map +0 -1
- package/dist/common/interactive/types.js +0 -4
- package/dist/common/interactive/types.js.map +0 -1
- package/dist/common/interactive/types.mjs +0 -3
- package/dist/common/interactive/types.mjs.map +0 -1
- package/dist/common/pages/page-404.js +0 -16
- package/dist/common/pages/page-404.js.map +0 -1
- package/dist/common/pages/page-404.mjs +0 -11
- package/dist/common/pages/page-404.mjs.map +0 -1
- package/dist/common/pages/page-500.js +0 -30
- package/dist/common/pages/page-500.js.map +0 -1
- package/dist/common/pages/page-500.mjs +0 -25
- package/dist/common/pages/page-500.mjs.map +0 -1
- package/dist/components/accordion.js +0 -65
- package/dist/components/accordion.js.map +0 -1
- package/dist/components/accordion.mjs +0 -39
- package/dist/components/accordion.mjs.map +0 -1
- package/dist/components/alert-dialog.js +0 -231
- package/dist/components/alert-dialog.js.map +0 -1
- package/dist/components/alert-dialog.mjs +0 -197
- package/dist/components/alert-dialog.mjs.map +0 -1
- package/dist/components/alert.js +0 -97
- package/dist/components/alert.js.map +0 -1
- package/dist/components/alert.mjs +0 -72
- package/dist/components/alert.mjs.map +0 -1
- package/dist/components/aspect-ratio.js +0 -29
- package/dist/components/aspect-ratio.js.map +0 -1
- package/dist/components/aspect-ratio.mjs +0 -7
- package/dist/components/aspect-ratio.mjs.map +0 -1
- package/dist/components/avatar.js +0 -64
- package/dist/components/avatar.js.map +0 -1
- package/dist/components/avatar.mjs +0 -39
- package/dist/components/avatar.mjs.map +0 -1
- package/dist/components/badge.js +0 -72
- package/dist/components/badge.js.map +0 -1
- package/dist/components/badge.mjs +0 -69
- package/dist/components/badge.mjs.map +0 -1
- package/dist/components/breadcrumb.js +0 -109
- package/dist/components/breadcrumb.js.map +0 -1
- package/dist/components/breadcrumb.mjs +0 -81
- package/dist/components/breadcrumb.mjs.map +0 -1
- package/dist/components/button.js +0 -250
- package/dist/components/button.js.map +0 -1
- package/dist/components/button.mjs +0 -226
- package/dist/components/button.mjs.map +0 -1
- package/dist/components/calendar.js +0 -681
- package/dist/components/calendar.js.map +0 -1
- package/dist/components/calendar.mjs +0 -659
- package/dist/components/calendar.mjs.map +0 -1
- package/dist/components/card.js +0 -98
- package/dist/components/card.js.map +0 -1
- package/dist/components/card.mjs +0 -71
- package/dist/components/card.mjs.map +0 -1
- package/dist/components/carousel.js +0 -237
- package/dist/components/carousel.js.map +0 -1
- package/dist/components/carousel.mjs +0 -208
- package/dist/components/carousel.mjs.map +0 -1
- package/dist/components/chart.js +0 -252
- package/dist/components/chart.js.map +0 -1
- package/dist/components/chart.mjs +0 -224
- package/dist/components/chart.mjs.map +0 -1
- package/dist/components/checkbox.js +0 -97
- package/dist/components/checkbox.js.map +0 -1
- package/dist/components/checkbox.mjs +0 -74
- package/dist/components/checkbox.mjs.map +0 -1
- package/dist/components/chip.js +0 -88
- package/dist/components/chip.js.map +0 -1
- package/dist/components/chip.mjs +0 -82
- package/dist/components/chip.mjs.map +0 -1
- package/dist/components/collapsible.js +0 -33
- package/dist/components/collapsible.js.map +0 -1
- package/dist/components/collapsible.mjs +0 -9
- package/dist/components/collapsible.mjs.map +0 -1
- package/dist/components/command.js +0 -125
- package/dist/components/command.js.map +0 -1
- package/dist/components/command.mjs +0 -95
- package/dist/components/command.mjs.map +0 -1
- package/dist/components/context-menu.js +0 -168
- package/dist/components/context-menu.js.map +0 -1
- package/dist/components/context-menu.mjs +0 -131
- package/dist/components/context-menu.mjs.map +0 -1
- package/dist/components/dialog.js +0 -192
- package/dist/components/dialog.js.map +0 -1
- package/dist/components/dialog.mjs +0 -159
- package/dist/components/dialog.mjs.map +0 -1
- package/dist/components/drawer.js +0 -98
- package/dist/components/drawer.js.map +0 -1
- package/dist/components/drawer.mjs +0 -67
- package/dist/components/drawer.mjs.map +0 -1
- package/dist/components/dropdown-menu.js +0 -163
- package/dist/components/dropdown-menu.js.map +0 -1
- package/dist/components/dropdown-menu.mjs +0 -126
- package/dist/components/dropdown-menu.mjs.map +0 -1
- package/dist/components/form.js +0 -123
- package/dist/components/form.js.map +0 -1
- package/dist/components/form.mjs +0 -94
- package/dist/components/form.mjs.map +0 -1
- package/dist/components/hover-card.js +0 -50
- package/dist/components/hover-card.js.map +0 -1
- package/dist/components/hover-card.mjs +0 -25
- package/dist/components/hover-card.mjs.map +0 -1
- package/dist/components/input-otp.js +0 -84
- package/dist/components/input-otp.js.map +0 -1
- package/dist/components/input-otp.mjs +0 -59
- package/dist/components/input-otp.mjs.map +0 -1
- package/dist/components/input.js +0 -858
- package/dist/components/input.js.map +0 -1
- package/dist/components/input.mjs +0 -831
- package/dist/components/input.mjs.map +0 -1
- package/dist/components/label.js +0 -38
- package/dist/components/label.js.map +0 -1
- package/dist/components/label.mjs +0 -15
- package/dist/components/label.mjs.map +0 -1
- package/dist/components/lottie.js +0 -59
- package/dist/components/lottie.js.map +0 -1
- package/dist/components/lottie.mjs +0 -49
- package/dist/components/lottie.mjs.map +0 -1
- package/dist/components/menubar.js +0 -195
- package/dist/components/menubar.js.map +0 -1
- package/dist/components/menubar.mjs +0 -157
- package/dist/components/menubar.mjs.map +0 -1
- package/dist/components/navigation-menu.js +0 -126
- package/dist/components/navigation-menu.js.map +0 -1
- package/dist/components/navigation-menu.mjs +0 -95
- package/dist/components/navigation-menu.mjs.map +0 -1
- package/dist/components/pagination.js +0 -112
- package/dist/components/pagination.js.map +0 -1
- package/dist/components/pagination.mjs +0 -84
- package/dist/components/pagination.mjs.map +0 -1
- package/dist/components/popover.js +0 -63
- package/dist/components/popover.js.map +0 -1
- package/dist/components/popover.mjs +0 -38
- package/dist/components/popover.mjs.map +0 -1
- package/dist/components/progress.js +0 -50
- package/dist/components/progress.js.map +0 -1
- package/dist/components/progress.mjs +0 -27
- package/dist/components/progress.mjs.map +0 -1
- package/dist/components/radio-group.js +0 -91
- package/dist/components/radio-group.js.map +0 -1
- package/dist/components/radio-group.mjs +0 -67
- package/dist/components/radio-group.mjs.map +0 -1
- package/dist/components/resizable.js +0 -59
- package/dist/components/resizable.js.map +0 -1
- package/dist/components/resizable.mjs +0 -35
- package/dist/components/resizable.mjs.map +0 -1
- package/dist/components/responsive-popover.js +0 -74
- package/dist/components/responsive-popover.js.map +0 -1
- package/dist/components/responsive-popover.mjs +0 -50
- package/dist/components/responsive-popover.mjs.map +0 -1
- package/dist/components/scroll-area.js +0 -63
- package/dist/components/scroll-area.js.map +0 -1
- package/dist/components/scroll-area.mjs +0 -39
- package/dist/components/scroll-area.mjs.map +0 -1
- package/dist/components/separator.js +0 -47
- package/dist/components/separator.js.map +0 -1
- package/dist/components/separator.mjs +0 -24
- package/dist/components/separator.mjs.map +0 -1
- package/dist/components/sheet.js +0 -239
- package/dist/components/sheet.js.map +0 -1
- package/dist/components/sheet.mjs +0 -206
- package/dist/components/sheet.mjs.map +0 -1
- package/dist/components/sidebar.js +0 -888
- package/dist/components/sidebar.js.map +0 -1
- package/dist/components/sidebar.mjs +0 -842
- package/dist/components/sidebar.mjs.map +0 -1
- package/dist/components/skeleton.js +0 -153
- package/dist/components/skeleton.js.map +0 -1
- package/dist/components/skeleton.mjs +0 -127
- package/dist/components/skeleton.mjs.map +0 -1
- package/dist/components/slider.js +0 -45
- package/dist/components/slider.js.map +0 -1
- package/dist/components/slider.mjs +0 -22
- package/dist/components/slider.mjs.map +0 -1
- package/dist/components/sonner.js +0 -76
- package/dist/components/sonner.js.map +0 -1
- package/dist/components/sonner.mjs +0 -71
- package/dist/components/sonner.mjs.map +0 -1
- package/dist/components/spinner.js +0 -59
- package/dist/components/spinner.js.map +0 -1
- package/dist/components/spinner.mjs +0 -36
- package/dist/components/spinner.mjs.map +0 -1
- package/dist/components/stepper.js +0 -726
- package/dist/components/stepper.js.map +0 -1
- package/dist/components/stepper.mjs +0 -702
- package/dist/components/stepper.mjs.map +0 -1
- package/dist/components/switch.js +0 -85
- package/dist/components/switch.js.map +0 -1
- package/dist/components/switch.mjs +0 -62
- package/dist/components/switch.mjs.map +0 -1
- package/dist/components/table.js +0 -91
- package/dist/components/table.js.map +0 -1
- package/dist/components/table.mjs +0 -62
- package/dist/components/table.mjs.map +0 -1
- package/dist/components/tabs.js +0 -287
- package/dist/components/tabs.js.map +0 -1
- package/dist/components/tabs.mjs +0 -261
- package/dist/components/tabs.mjs.map +0 -1
- package/dist/components/textarea.js +0 -200
- package/dist/components/textarea.js.map +0 -1
- package/dist/components/textarea.mjs +0 -174
- package/dist/components/textarea.mjs.map +0 -1
- package/dist/components/toggle-group.js +0 -67
- package/dist/components/toggle-group.js.map +0 -1
- package/dist/components/toggle-group.mjs +0 -43
- package/dist/components/toggle-group.mjs.map +0 -1
- package/dist/components/toggle.js +0 -63
- package/dist/components/toggle.js.map +0 -1
- package/dist/components/toggle.mjs +0 -39
- package/dist/components/toggle.mjs.map +0 -1
- package/dist/components/tooltip.js +0 -172
- package/dist/components/tooltip.js.map +0 -1
- package/dist/components/tooltip.mjs +0 -145
- package/dist/components/tooltip.mjs.map +0 -1
- package/dist/hooks/index.js +0 -27
- package/dist/hooks/index.js.map +0 -1
- package/dist/hooks/index.mjs +0 -6
- package/dist/hooks/index.mjs.map +0 -1
- package/dist/hooks/useCopyToClipboard.js +0 -59
- package/dist/hooks/useCopyToClipboard.js.map +0 -1
- package/dist/hooks/useCopyToClipboard.mjs +0 -57
- package/dist/hooks/useCopyToClipboard.mjs.map +0 -1
- package/dist/hooks/useDevice.js +0 -20
- package/dist/hooks/useDevice.js.map +0 -1
- package/dist/hooks/useDevice.mjs +0 -14
- package/dist/hooks/useDevice.mjs.map +0 -1
- package/dist/hooks/useDialogTracking.js +0 -113
- package/dist/hooks/useDialogTracking.js.map +0 -1
- package/dist/hooks/useDialogTracking.mjs +0 -91
- package/dist/hooks/useDialogTracking.mjs.map +0 -1
- package/dist/hooks/useIsMounted.js +0 -15
- package/dist/hooks/useIsMounted.js.map +0 -1
- package/dist/hooks/useIsMounted.mjs +0 -13
- package/dist/hooks/useIsMounted.mjs.map +0 -1
- package/dist/hooks/usePathname.js +0 -85
- package/dist/hooks/usePathname.js.map +0 -1
- package/dist/hooks/usePathname.mjs +0 -83
- package/dist/hooks/usePathname.mjs.map +0 -1
- package/dist/icons.js +0 -14
- package/dist/icons.js.map +0 -1
- package/dist/icons.mjs +0 -3
- package/dist/icons.mjs.map +0 -1
- package/dist/lib/formatCurrency.js +0 -187
- package/dist/lib/formatCurrency.js.map +0 -1
- package/dist/lib/formatCurrency.mjs +0 -185
- package/dist/lib/formatCurrency.mjs.map +0 -1
- package/dist/lib/helpers.js +0 -171
- package/dist/lib/helpers.js.map +0 -1
- package/dist/lib/helpers.mjs +0 -157
- package/dist/lib/helpers.mjs.map +0 -1
- package/dist/lib/index.js +0 -33
- package/dist/lib/index.js.map +0 -1
- package/dist/lib/index.mjs +0 -6
- package/dist/lib/index.mjs.map +0 -1
- package/dist/lib/types.js +0 -11
- package/dist/lib/types.js.map +0 -1
- package/dist/lib/types.mjs +0 -9
- package/dist/lib/types.mjs.map +0 -1
- package/dist/lib/utils.js +0 -24
- package/dist/lib/utils.js.map +0 -1
- package/dist/lib/utils.mjs +0 -19
- package/dist/lib/utils.mjs.map +0 -1
- package/dist/providers/DeviceSizeWatcher/index.js +0 -72
- package/dist/providers/DeviceSizeWatcher/index.js.map +0 -1
- package/dist/providers/DeviceSizeWatcher/index.mjs +0 -47
- package/dist/providers/DeviceSizeWatcher/index.mjs.map +0 -1
- package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.js +0 -22
- package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.js.map +0 -1
- package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.mjs +0 -20
- package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.mjs.map +0 -1
- package/dist/providers/UISystemProvider.js +0 -197
- package/dist/providers/UISystemProvider.js.map +0 -1
- package/dist/providers/UISystemProvider.mjs +0 -188
- package/dist/providers/UISystemProvider.mjs.map +0 -1
- package/dist/providers/index.js +0 -24
- package/dist/providers/index.js.map +0 -1
- package/dist/providers/index.mjs +0 -3
- package/dist/providers/index.mjs.map +0 -1
- package/dist/theme.js +0 -333
- package/dist/theme.js.map +0 -1
- package/dist/theme.mjs +0 -327
- package/dist/theme.mjs.map +0 -1
|
@@ -1,138 +0,0 @@
|
|
|
1
|
-
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
2
|
-
import { ArrowLeftIcon } from '@/assets/Icon';
|
|
3
|
-
import { Button } from '@/components/button';
|
|
4
|
-
import { Skeleton } from '@/components/skeleton';
|
|
5
|
-
import { cn } from '@/lib/utils';
|
|
6
|
-
import React from 'react';
|
|
7
|
-
import { PageBreadcrumb } from './page-breadcrumb';
|
|
8
|
-
export { PageBreadcrumb } from './page-breadcrumb';
|
|
9
|
-
|
|
10
|
-
const PageTitle = React.forwardRef(({ className, level = 1, addonBefore, addonAfter, ...props }, ref) => {
|
|
11
|
-
const Component = `h${level}`;
|
|
12
|
-
const componentProps = {
|
|
13
|
-
ref,
|
|
14
|
-
className: cn("text-t20sb text-ink-500s font-medium", className),
|
|
15
|
-
...props
|
|
16
|
-
};
|
|
17
|
-
return /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
|
|
18
|
-
addonBefore && /* @__PURE__ */ jsx("span", { children: addonBefore }),
|
|
19
|
-
React.createElement(Component, componentProps),
|
|
20
|
-
addonAfter && /* @__PURE__ */ jsx("span", { children: addonAfter })
|
|
21
|
-
] });
|
|
22
|
-
});
|
|
23
|
-
PageTitle.displayName = "PageTitle";
|
|
24
|
-
const PageSubtitle = React.forwardRef(
|
|
25
|
-
({ className, ...props }, ref) => /* @__PURE__ */ jsx("div", { ref, className: cn("text-t14m text-ink-400s", className), ...props })
|
|
26
|
-
);
|
|
27
|
-
PageSubtitle.displayName = "PageSubtitle";
|
|
28
|
-
const PageBack = React.forwardRef(
|
|
29
|
-
({ className, onBack, ...props }, ref) => {
|
|
30
|
-
return /* @__PURE__ */ jsx(
|
|
31
|
-
Button,
|
|
32
|
-
{
|
|
33
|
-
ref,
|
|
34
|
-
variant: "ghost",
|
|
35
|
-
size: "icon",
|
|
36
|
-
className: cn("h-8 w-8 p-0", className),
|
|
37
|
-
onClick: onBack,
|
|
38
|
-
...props,
|
|
39
|
-
children: /* @__PURE__ */ jsx(ArrowLeftIcon, { className: "h-6 w-6" })
|
|
40
|
-
}
|
|
41
|
-
);
|
|
42
|
-
}
|
|
43
|
-
);
|
|
44
|
-
PageBack.displayName = "PageBack";
|
|
45
|
-
const PageAction = React.forwardRef(
|
|
46
|
-
({ className, ...props }, ref) => /* @__PURE__ */ jsx("div", { ref, className: cn("flex items-center gap-3", className), ...props })
|
|
47
|
-
);
|
|
48
|
-
PageAction.displayName = "PageAction";
|
|
49
|
-
const getChildByType = (children, targetType) => {
|
|
50
|
-
return React.Children.toArray(children).find((child) => {
|
|
51
|
-
if (!React.isValidElement(child)) return false;
|
|
52
|
-
if (child.type === targetType) return true;
|
|
53
|
-
const childDisplayName = child.type?.displayName;
|
|
54
|
-
const targetDisplayName = targetType?.displayName;
|
|
55
|
-
return childDisplayName && targetDisplayName && childDisplayName === targetDisplayName;
|
|
56
|
-
});
|
|
57
|
-
};
|
|
58
|
-
const PageHeader = React.forwardRef(
|
|
59
|
-
({
|
|
60
|
-
className,
|
|
61
|
-
children,
|
|
62
|
-
title,
|
|
63
|
-
subtitle,
|
|
64
|
-
action,
|
|
65
|
-
back,
|
|
66
|
-
loading,
|
|
67
|
-
variant = "default",
|
|
68
|
-
responsive = true,
|
|
69
|
-
...props
|
|
70
|
-
}, ref) => {
|
|
71
|
-
const headerTitle = title || getChildByType(children, PageTitle);
|
|
72
|
-
const headerSubtitle = subtitle || getChildByType(children, PageSubtitle);
|
|
73
|
-
const headerAction = action || getChildByType(children, PageAction);
|
|
74
|
-
const headerBack = back || getChildByType(children, PageBack);
|
|
75
|
-
const variantClasses = {
|
|
76
|
-
default: "flex flex-col items-start justify-between gap-4 sm:flex-row",
|
|
77
|
-
compact: "flex flex-col items-start justify-between gap-2 sm:flex-row",
|
|
78
|
-
centered: "flex flex-col items-center justify-center gap-4 text-center"
|
|
79
|
-
};
|
|
80
|
-
const baseClasses = responsive ? variantClasses[variant] : "flex flex-col items-start justify-between gap-4";
|
|
81
|
-
if (loading) {
|
|
82
|
-
return /* @__PURE__ */ jsxs("div", { ref, className: cn(baseClasses, className), ...props, children: [
|
|
83
|
-
/* @__PURE__ */ jsxs("div", { className: "space-y-1", children: [
|
|
84
|
-
/* @__PURE__ */ jsx(Skeleton, { className: "h-8 w-48" }),
|
|
85
|
-
/* @__PURE__ */ jsx(Skeleton, { className: "h-4 w-32" })
|
|
86
|
-
] }),
|
|
87
|
-
/* @__PURE__ */ jsx(Skeleton, { className: "h-10 w-20" })
|
|
88
|
-
] });
|
|
89
|
-
}
|
|
90
|
-
return /* @__PURE__ */ jsxs("div", { ref, className: cn(baseClasses, className), ...props, children: [
|
|
91
|
-
/* @__PURE__ */ jsxs("div", { className: "flex items-start gap-2", children: [
|
|
92
|
-
headerBack,
|
|
93
|
-
/* @__PURE__ */ jsxs("div", { className: "flex-1 space-y-1", children: [
|
|
94
|
-
headerTitle,
|
|
95
|
-
headerSubtitle
|
|
96
|
-
] })
|
|
97
|
-
] }),
|
|
98
|
-
headerAction
|
|
99
|
-
] });
|
|
100
|
-
}
|
|
101
|
-
);
|
|
102
|
-
PageHeader.displayName = "PageHeader";
|
|
103
|
-
const PageContainer = React.forwardRef(
|
|
104
|
-
({ className, size = "full", ...props }, ref) => {
|
|
105
|
-
const sizeClasses = {
|
|
106
|
-
full: "h-full w-full mx-auto max-w-[1920px]",
|
|
107
|
-
md: "w-full md:!w-[640px] lg:!w-[970px] mx-auto",
|
|
108
|
-
// Matches old Container (fixed width with !important, no mx-auto)
|
|
109
|
-
lg: "mx-auto h-full w-full max-w-[1328px]"
|
|
110
|
-
};
|
|
111
|
-
const baseClasses = size === "md" ? "flex flex-col" : "bg-background-pg flex flex-col gap-4 p-4 md:p-6";
|
|
112
|
-
return /* @__PURE__ */ jsx("div", { ref, className: cn(baseClasses, sizeClasses[size], className), ...props });
|
|
113
|
-
}
|
|
114
|
-
);
|
|
115
|
-
PageContainer.displayName = "PageContainer";
|
|
116
|
-
const PageContent = React.forwardRef(
|
|
117
|
-
({ className, ...props }, ref) => /* @__PURE__ */ jsx(
|
|
118
|
-
"div",
|
|
119
|
-
{
|
|
120
|
-
ref,
|
|
121
|
-
className: cn("border-ink-50s rounded-lg border bg-white", className),
|
|
122
|
-
...props
|
|
123
|
-
}
|
|
124
|
-
)
|
|
125
|
-
);
|
|
126
|
-
PageContent.displayName = "PageContent";
|
|
127
|
-
const Page = Object.assign(PageContainer, {
|
|
128
|
-
Header: PageHeader,
|
|
129
|
-
Title: PageTitle,
|
|
130
|
-
Subtitle: PageSubtitle,
|
|
131
|
-
Action: PageAction,
|
|
132
|
-
Content: PageContent,
|
|
133
|
-
Breadcrumb: PageBreadcrumb
|
|
134
|
-
});
|
|
135
|
-
|
|
136
|
-
export { Page, PageAction, PageBack, PageContainer, PageContent, PageHeader, PageSubtitle, PageTitle, getChildByType };
|
|
137
|
-
//# sourceMappingURL=page.mjs.map
|
|
138
|
-
//# sourceMappingURL=page.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/common/display/page.tsx"],"names":["PageBreadcrumbComponent"],"mappings":"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","file":"page.mjs","sourcesContent":["import { ArrowLeftIcon } from '@/assets/Icon';\nimport { Button } from '@/components/button';\nimport { Skeleton } from '@/components/skeleton';\nimport { cn } from '@/lib/utils';\nimport React from 'react';\n\n// Import with alias to avoid naming conflict\nimport { PageBreadcrumb as PageBreadcrumbComponent } from './page-breadcrumb';\n\n// Re-export for public API\nexport { PageBreadcrumb } from './page-breadcrumb';\nexport type { PageBreadcrumbItem } from './page-breadcrumb';\n\n// Define sub-components BEFORE PageHeader so they can be referenced\nconst PageTitle = React.forwardRef<\n HTMLHeadingElement,\n Omit<React.HTMLAttributes<HTMLHeadingElement>, 'title'> & {\n level?: 1 | 2 | 3 | 4 | 5 | 6;\n addonBefore?: React.ReactNode;\n addonAfter?: React.ReactNode;\n }\n>(({ className, level = 1, addonBefore, addonAfter, ...props }, ref) => {\n const Component = `h${level}` as 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n const componentProps = {\n ref,\n className: cn('text-t20sb text-ink-500s font-medium', className),\n ...props,\n } as React.HTMLAttributes<HTMLHeadingElement> & { ref: React.ForwardedRef<HTMLHeadingElement> };\n\n return (\n <div className=\"flex items-center gap-2\">\n {addonBefore && <span>{addonBefore}</span>}\n {React.createElement(Component, componentProps)}\n {addonAfter && <span>{addonAfter}</span>}\n </div>\n );\n});\nPageTitle.displayName = 'PageTitle';\n\nconst PageSubtitle = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div ref={ref} className={cn('text-t14m text-ink-400s', className)} {...props} />\n ),\n);\nPageSubtitle.displayName = 'PageSubtitle';\n\ninterface PageBackProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {\n onBack: () => void;\n}\nconst PageBack = React.forwardRef<HTMLButtonElement, PageBackProps>(\n ({ className, onBack, ...props }, ref) => {\n return (\n <Button\n ref={ref}\n variant=\"ghost\"\n size=\"icon\"\n className={cn('h-8 w-8 p-0', className)}\n onClick={onBack}\n {...props}\n >\n <ArrowLeftIcon className=\"h-6 w-6\" />\n </Button>\n );\n },\n);\nPageBack.displayName = 'PageBack';\n\nconst PageAction = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div ref={ref} className={cn('flex items-center gap-3', className)} {...props} />\n ),\n);\nPageAction.displayName = 'PageAction';\n\n// Helper function for better type safety\nexport const getChildByType = (children: React.ReactNode, targetType: React.ComponentType<any>) => {\n return React.Children.toArray(children).find((child): child is React.ReactElement => {\n if (!React.isValidElement(child)) return false;\n\n // Check direct type match\n if (child.type === targetType) return true;\n\n // Check displayName for forwardRef components\n const childDisplayName = (child.type as any)?.displayName;\n const targetDisplayName = (targetType as any)?.displayName;\n\n return childDisplayName && targetDisplayName && childDisplayName === targetDisplayName;\n });\n};\n\ninterface PageHeaderProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'title'> {\n className?: string;\n children?: React.ReactNode;\n /** Alternative to children composition - more explicit */\n title?: React.ReactNode;\n subtitle?: React.ReactNode;\n action?: React.ReactNode;\n back?: React.ReactNode;\n /** Control responsive behavior */\n responsive?: boolean;\n /** Show loading state */\n loading?: boolean;\n /** Control responsive behavior */\n variant?: 'default' | 'compact' | 'centered';\n /** Link component for breadcrumbs */\n LinkComponent?: React.ComponentType<any>;\n}\n\nconst PageHeader = React.forwardRef<HTMLDivElement, PageHeaderProps>(\n (\n {\n className,\n children,\n title,\n subtitle,\n action,\n back,\n loading,\n variant = 'default',\n responsive = true,\n ...props\n },\n ref,\n ) => {\n // Support both prop-based and children-based composition\n const headerTitle = title || getChildByType(children, PageTitle);\n const headerSubtitle = subtitle || getChildByType(children, PageSubtitle);\n const headerAction = action || getChildByType(children, PageAction);\n const headerBack = back || getChildByType(children, PageBack);\n\n const variantClasses = {\n default: 'flex flex-col items-start justify-between gap-4 sm:flex-row',\n compact: 'flex flex-col items-start justify-between gap-2 sm:flex-row',\n centered: 'flex flex-col items-center justify-center gap-4 text-center',\n };\n\n const baseClasses = responsive\n ? variantClasses[variant]\n : 'flex flex-col items-start justify-between gap-4';\n\n if (loading) {\n return (\n <div ref={ref} className={cn(baseClasses, className)} {...props}>\n <div className=\"space-y-1\">\n <Skeleton className=\"h-8 w-48\" />\n <Skeleton className=\"h-4 w-32\" />\n </div>\n <Skeleton className=\"h-10 w-20\" />\n </div>\n );\n }\n\n return (\n <div ref={ref} className={cn(baseClasses, className)} {...props}>\n <div className=\"flex items-start gap-2\">\n {headerBack}\n <div className=\"flex-1 space-y-1\">\n {headerTitle}\n {headerSubtitle}\n </div>\n </div>\n {headerAction}\n </div>\n );\n },\n);\nPageHeader.displayName = 'PageHeader';\n\ninterface PageContainerProps extends React.HTMLAttributes<HTMLDivElement> {\n /** Control page width */\n size?: 'full' | 'md' | 'lg';\n}\n\nconst PageContainer = React.forwardRef<HTMLDivElement, PageContainerProps>(\n ({ className, size = 'full', ...props }, ref) => {\n const sizeClasses = {\n full: 'h-full w-full mx-auto max-w-[1920px]',\n md: 'w-full md:!w-[640px] lg:!w-[970px] mx-auto', // Matches old Container (fixed width with !important, no mx-auto)\n lg: 'mx-auto h-full w-full max-w-[1328px]',\n };\n\n // Size 'md' has minimal styling (like old Container component)\n // Other sizes have default page styling\n const baseClasses =\n size === 'md' ? 'flex flex-col' : 'bg-background-pg flex flex-col gap-4 p-4 md:p-6';\n\n return <div ref={ref} className={cn(baseClasses, sizeClasses[size], className)} {...props} />;\n },\n);\nPageContainer.displayName = 'PageContainer';\n\nconst PageContent = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={cn('border-ink-50s rounded-lg border bg-white', className)}\n {...props}\n />\n ),\n);\nPageContent.displayName = 'PageContent';\n\n// Compound component pattern for better DX\nconst Page = Object.assign(PageContainer, {\n Header: PageHeader,\n Title: PageTitle,\n Subtitle: PageSubtitle,\n Action: PageAction,\n Content: PageContent,\n Breadcrumb: PageBreadcrumbComponent,\n});\n\nexport {\n Page,\n PageAction,\n PageBack,\n PageContainer,\n PageContent,\n PageHeader,\n PageSubtitle,\n PageTitle,\n};\n"]}
|
|
@@ -1,161 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
var jsxRuntime = require('react/jsx-runtime');
|
|
4
|
-
var React = require('react');
|
|
5
|
-
var utils = require('@/lib/utils');
|
|
6
|
-
|
|
7
|
-
function _interopNamespace(e) {
|
|
8
|
-
if (e && e.__esModule) return e;
|
|
9
|
-
var n = Object.create(null);
|
|
10
|
-
if (e) {
|
|
11
|
-
Object.keys(e).forEach(function (k) {
|
|
12
|
-
if (k !== 'default') {
|
|
13
|
-
var d = Object.getOwnPropertyDescriptor(e, k);
|
|
14
|
-
Object.defineProperty(n, k, d.get ? d : {
|
|
15
|
-
enumerable: true,
|
|
16
|
-
get: function () { return e[k]; }
|
|
17
|
-
});
|
|
18
|
-
}
|
|
19
|
-
});
|
|
20
|
-
}
|
|
21
|
-
n.default = e;
|
|
22
|
-
return Object.freeze(n);
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
var React__namespace = /*#__PURE__*/_interopNamespace(React);
|
|
26
|
-
|
|
27
|
-
function ScoreMeter({
|
|
28
|
-
score,
|
|
29
|
-
milestones,
|
|
30
|
-
showTooltip = true,
|
|
31
|
-
className = "",
|
|
32
|
-
progresBarClassName = "",
|
|
33
|
-
renderTooltip,
|
|
34
|
-
renderTick,
|
|
35
|
-
progressFillColor
|
|
36
|
-
}) {
|
|
37
|
-
const progresBarRef = React__namespace.useRef(null);
|
|
38
|
-
const tooltipRef = React__namespace.useRef(null);
|
|
39
|
-
const sortedMilestones = [...milestones].sort((a, b) => a.maxScore - b.maxScore);
|
|
40
|
-
const maximumScore = sortedMilestones[sortedMilestones.length - 1]?.maxScore || 100;
|
|
41
|
-
const validScore = React.useMemo(
|
|
42
|
-
() => score < 0 ? 0 : score > maximumScore ? maximumScore : score,
|
|
43
|
-
[score, maximumScore]
|
|
44
|
-
);
|
|
45
|
-
const currentMilestone = sortedMilestones.find((milestone) => score <= milestone.maxScore) || (score > maximumScore ? sortedMilestones[sortedMilestones.length - 1] : sortedMilestones[0]);
|
|
46
|
-
const [progresWidth, setProgresWidth] = React__namespace.useState(0);
|
|
47
|
-
React__namespace.useEffect(() => {
|
|
48
|
-
if (progresBarRef?.current) {
|
|
49
|
-
const progresWidth2 = progresBarRef.current.offsetWidth;
|
|
50
|
-
setProgresWidth(progresWidth2);
|
|
51
|
-
}
|
|
52
|
-
}, [score, tooltipRef, progresBarRef]);
|
|
53
|
-
const formatLabel = (template, scoreValue) => {
|
|
54
|
-
return typeof template === "function" ? template(scoreValue) : template.replace("${score}", scoreValue.toString());
|
|
55
|
-
};
|
|
56
|
-
const tooltipArrowStyles = React__namespace.useMemo(() => {
|
|
57
|
-
const tooltipPosition = validScore / maximumScore * progresWidth;
|
|
58
|
-
const isNearLeft = tooltipPosition < 10;
|
|
59
|
-
const isNearRight = tooltipPosition > progresWidth - 10;
|
|
60
|
-
const borderLeftWidth = isNearRight ? 4 : Math.min(4, validScore);
|
|
61
|
-
const borderRightWidth = isNearLeft ? 4 : Math.min(4, maximumScore - validScore);
|
|
62
|
-
const translateX = isNearLeft ? "0%" : isNearRight ? "-100%" : "-50%";
|
|
63
|
-
return {
|
|
64
|
-
borderTopColor: currentMilestone?.tooltipColor ?? currentMilestone?.bgColor ?? "",
|
|
65
|
-
marginLeft: `${tooltipPosition}px`,
|
|
66
|
-
transform: `translateX(${translateX})`,
|
|
67
|
-
borderLeftWidth: `${borderLeftWidth}px`,
|
|
68
|
-
borderRightWidth: `${borderRightWidth}px`
|
|
69
|
-
};
|
|
70
|
-
}, [maximumScore, validScore, progresWidth, currentMilestone]);
|
|
71
|
-
const tooltipStyles = React__namespace.useMemo(() => {
|
|
72
|
-
const tooltipWidth = tooltipRef.current?.offsetWidth || 0;
|
|
73
|
-
const tooltipPosition = validScore / maximumScore * progresWidth;
|
|
74
|
-
let tooltipLeft = tooltipPosition - tooltipWidth / 2;
|
|
75
|
-
if (tooltipLeft < 0) tooltipLeft = 0;
|
|
76
|
-
if (tooltipLeft + tooltipWidth > progresWidth) tooltipLeft = progresWidth - tooltipWidth;
|
|
77
|
-
const borderBottomLeftRadius = tooltipLeft === 0 ? 0 : Math.min(8, validScore);
|
|
78
|
-
const borderBottomRightRadius = tooltipLeft + tooltipWidth === progresWidth ? 0 : Math.min(8, maximumScore - validScore);
|
|
79
|
-
return {
|
|
80
|
-
background: currentMilestone?.tooltipColor ?? currentMilestone?.bgColor ?? "",
|
|
81
|
-
marginLeft: `${tooltipLeft}px`,
|
|
82
|
-
borderBottomLeftRadius: `${borderBottomLeftRadius}px`,
|
|
83
|
-
borderBottomRightRadius: `${borderBottomRightRadius}px`
|
|
84
|
-
};
|
|
85
|
-
}, [validScore, maximumScore, progresWidth, currentMilestone]);
|
|
86
|
-
const tooltipValue = React.useMemo(() => {
|
|
87
|
-
return renderTooltip?.(score) ?? currentMilestone?.description;
|
|
88
|
-
}, [renderTooltip, currentMilestone]);
|
|
89
|
-
return /* @__PURE__ */ jsxRuntime.jsxs("div", { className: `w-full ${className}`, ref: progresBarRef, children: [
|
|
90
|
-
showTooltip && currentMilestone && /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "mb-1 w-full", children: [
|
|
91
|
-
/* @__PURE__ */ jsxRuntime.jsx(
|
|
92
|
-
"div",
|
|
93
|
-
{
|
|
94
|
-
className: "text-t14m inline-block whitespace-nowrap rounded-[8px] px-3 py-1 font-medium text-white",
|
|
95
|
-
style: tooltipStyles,
|
|
96
|
-
ref: tooltipRef,
|
|
97
|
-
children: formatLabel(currentMilestone?.label ?? "", score)
|
|
98
|
-
}
|
|
99
|
-
),
|
|
100
|
-
/* @__PURE__ */ jsxRuntime.jsx(
|
|
101
|
-
"div",
|
|
102
|
-
{
|
|
103
|
-
className: utils.cn("top-full h-0 w-0 rounded-[1px] border-t-[6px] border-transparent"),
|
|
104
|
-
style: tooltipArrowStyles
|
|
105
|
-
}
|
|
106
|
-
)
|
|
107
|
-
] }),
|
|
108
|
-
/* @__PURE__ */ jsxRuntime.jsxs("div", { className: utils.cn("bg-ink-100s relative h-3 w-full rounded-full", progresBarClassName), children: [
|
|
109
|
-
/* @__PURE__ */ jsxRuntime.jsx("div", { className: "h-full w-full overflow-hidden rounded-full", children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
110
|
-
"div",
|
|
111
|
-
{
|
|
112
|
-
className: "h-full w-full overflow-hidden rounded-full",
|
|
113
|
-
style: {
|
|
114
|
-
transform: `translateX(${validScore / maximumScore * 100 - 100}%)`
|
|
115
|
-
},
|
|
116
|
-
children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
117
|
-
"div",
|
|
118
|
-
{
|
|
119
|
-
className: "h-full w-full rounded-full",
|
|
120
|
-
style: {
|
|
121
|
-
background: progressFillColor ?? currentMilestone?.bgColor ?? "#6366f1",
|
|
122
|
-
transform: `translateX(${100 - validScore / maximumScore * 100}%)`
|
|
123
|
-
}
|
|
124
|
-
}
|
|
125
|
-
)
|
|
126
|
-
}
|
|
127
|
-
) }),
|
|
128
|
-
sortedMilestones.map((milestone, index) => {
|
|
129
|
-
if (index === sortedMilestones.length - 1) return null;
|
|
130
|
-
if (renderTick)
|
|
131
|
-
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
132
|
-
"div",
|
|
133
|
-
{
|
|
134
|
-
className: "absolute top-1/2 -translate-y-1/2",
|
|
135
|
-
style: {
|
|
136
|
-
left: `${milestone.maxScore / maximumScore * 100}%`
|
|
137
|
-
},
|
|
138
|
-
children: renderTick(milestone, score)
|
|
139
|
-
},
|
|
140
|
-
index
|
|
141
|
-
);
|
|
142
|
-
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
143
|
-
"div",
|
|
144
|
-
{
|
|
145
|
-
className: "absolute top-0 h-full w-0.5 cursor-pointer transition-opacity hover:opacity-80",
|
|
146
|
-
style: {
|
|
147
|
-
left: `${milestone.maxScore / maximumScore * 100}%`,
|
|
148
|
-
background: milestone.tickColor ?? "#f97316"
|
|
149
|
-
}
|
|
150
|
-
},
|
|
151
|
-
index
|
|
152
|
-
);
|
|
153
|
-
})
|
|
154
|
-
] }),
|
|
155
|
-
tooltipValue && /* @__PURE__ */ jsxRuntime.jsx("div", { className: "text-t14m text-ink-400s mt-3", children: tooltipValue })
|
|
156
|
-
] });
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
module.exports = ScoreMeter;
|
|
160
|
-
//# sourceMappingURL=score-meter.js.map
|
|
161
|
-
//# sourceMappingURL=score-meter.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/common/display/score-meter.tsx"],"names":["React","useMemo","progresWidth","jsxs","jsx","cn"],"mappings":"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","file":"score-meter.js","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"]}
|
|
@@ -1,140 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"]}
|
|
@@ -1,114 +0,0 @@
|
|
|
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
|