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,157 +0,0 @@
|
|
|
1
|
-
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
2
|
-
import { Command as Command$1 } from 'cmdk';
|
|
3
|
-
import * as React from 'react';
|
|
4
|
-
import { useState, useMemo, useEffect } from 'react';
|
|
5
|
-
import { Command, CommandList, CommandGroup, CommandItem } from '@/components/command';
|
|
6
|
-
import { Input } from '@/components/input';
|
|
7
|
-
import { Popover, PopoverTrigger, PopoverContent } from '@/components/popover';
|
|
8
|
-
import { Skeleton } from '@/components/skeleton';
|
|
9
|
-
import { cn } from '@/lib/utils';
|
|
10
|
-
|
|
11
|
-
function AutoComplete({
|
|
12
|
-
label = "",
|
|
13
|
-
placeholder = "",
|
|
14
|
-
options,
|
|
15
|
-
searchApi,
|
|
16
|
-
value,
|
|
17
|
-
onInputChange,
|
|
18
|
-
onSelectChange,
|
|
19
|
-
children,
|
|
20
|
-
enableAddNewItem,
|
|
21
|
-
newItemOption,
|
|
22
|
-
renderOption,
|
|
23
|
-
className,
|
|
24
|
-
renderEmpty,
|
|
25
|
-
...props
|
|
26
|
-
}) {
|
|
27
|
-
const triggerRef = React.useRef(null);
|
|
28
|
-
const [triggerWidth, setTriggerWidth] = useState();
|
|
29
|
-
const [open, setOpen] = useState(false);
|
|
30
|
-
const [isLoading, setIsLoading] = useState(false);
|
|
31
|
-
const [searchedOptions, setSearchedOptions] = useState([]);
|
|
32
|
-
const newItem = useMemo(() => newItemOption?.(value ?? ""), [newItemOption, value]);
|
|
33
|
-
useEffect(() => {
|
|
34
|
-
if (open) handleSearch(value);
|
|
35
|
-
if (triggerRef.current) {
|
|
36
|
-
setTriggerWidth(triggerRef.current.offsetWidth);
|
|
37
|
-
}
|
|
38
|
-
}, [open, value]);
|
|
39
|
-
const isPaginatedApi = (api) => {
|
|
40
|
-
return typeof api === "function" && api.length >= 2;
|
|
41
|
-
};
|
|
42
|
-
const handleSearch = async (searchValue) => {
|
|
43
|
-
if (!searchValue) {
|
|
44
|
-
setSearchedOptions([]);
|
|
45
|
-
} else if (searchApi) {
|
|
46
|
-
handleSearchApi(value, 1, 10);
|
|
47
|
-
} else if (options) {
|
|
48
|
-
handleSearchLocal(searchValue);
|
|
49
|
-
}
|
|
50
|
-
};
|
|
51
|
-
const handleSearchLocal = (searchValue) => {
|
|
52
|
-
if (searchValue && options && options?.length > 0) {
|
|
53
|
-
const resultOptions = [...options ?? []].filter(
|
|
54
|
-
// (option) => (option.name?.toLowerCase().search(searchValue.toLowerCase()) ?? -1) > -1,
|
|
55
|
-
(option) => option.name?.toLowerCase().normalize("NFD").replace(/[\u0300-\u036f]/g, "").includes(
|
|
56
|
-
searchValue.toLowerCase().normalize("NFD").replace(/[\u0300-\u036f]/g, "")
|
|
57
|
-
) ?? false
|
|
58
|
-
);
|
|
59
|
-
setSearchedOptions(resultOptions);
|
|
60
|
-
} else if (options && options?.length > 0) {
|
|
61
|
-
setSearchedOptions([...options ?? []]);
|
|
62
|
-
}
|
|
63
|
-
};
|
|
64
|
-
const handleSearchApi = async (searchValue = "", page = 1, size = 10) => {
|
|
65
|
-
try {
|
|
66
|
-
setIsLoading(true);
|
|
67
|
-
if (isPaginatedApi(searchApi)) {
|
|
68
|
-
const res = await searchApi?.(searchValue, page, size);
|
|
69
|
-
const resultOptions = res?.data ?? [];
|
|
70
|
-
setSearchedOptions(resultOptions);
|
|
71
|
-
} else {
|
|
72
|
-
const resultOptions = await searchApi(searchValue);
|
|
73
|
-
setSearchedOptions(resultOptions);
|
|
74
|
-
}
|
|
75
|
-
} catch (error) {
|
|
76
|
-
} finally {
|
|
77
|
-
setIsLoading(false);
|
|
78
|
-
}
|
|
79
|
-
};
|
|
80
|
-
const handleSelectItem = (option) => {
|
|
81
|
-
onSelectChange?.(option);
|
|
82
|
-
setOpen(false);
|
|
83
|
-
};
|
|
84
|
-
return /* @__PURE__ */ jsx(Popover, { open, onOpenChange: setOpen, children: /* @__PURE__ */ jsxs(Command, { shouldFilter: false, children: [
|
|
85
|
-
/* @__PURE__ */ jsx(PopoverTrigger, { asChild: true, children: /* @__PURE__ */ jsx("div", { ref: triggerRef, children: /* @__PURE__ */ jsx(
|
|
86
|
-
Command$1.Input,
|
|
87
|
-
{
|
|
88
|
-
...props,
|
|
89
|
-
asChild: true,
|
|
90
|
-
value,
|
|
91
|
-
onValueChange: onInputChange,
|
|
92
|
-
placeholder,
|
|
93
|
-
onKeyDown: (e) => setOpen(e.key !== "Escape"),
|
|
94
|
-
children: children ?? /* @__PURE__ */ jsx(Input, { label })
|
|
95
|
-
}
|
|
96
|
-
) }) }),
|
|
97
|
-
/* @__PURE__ */ jsx(
|
|
98
|
-
PopoverContent,
|
|
99
|
-
{
|
|
100
|
-
asChild: true,
|
|
101
|
-
onOpenAutoFocus: (e) => e.preventDefault(),
|
|
102
|
-
onInteractOutside: (e) => {
|
|
103
|
-
if (e.target instanceof Element && e.target.hasAttribute("cmdk-input")) {
|
|
104
|
-
e.preventDefault();
|
|
105
|
-
}
|
|
106
|
-
},
|
|
107
|
-
className: "w-full min-w-[300px] p-0",
|
|
108
|
-
hidden: !value,
|
|
109
|
-
align: "start",
|
|
110
|
-
style: { width: triggerWidth },
|
|
111
|
-
children: /* @__PURE__ */ jsxs(CommandList, { children: [
|
|
112
|
-
isLoading && /* @__PURE__ */ jsx(Command$1.Loading, { children: /* @__PURE__ */ jsx("div", { className: "space-y-2 p-3", children: new Array(5).fill(1).map((_item, index) => /* @__PURE__ */ jsx(Skeleton, { className: "h-10 w-full" }, index)) }) }),
|
|
113
|
-
searchedOptions?.length > 0 && !isLoading && /* @__PURE__ */ jsx(CommandGroup, { className: "px-0 py-2", children: searchedOptions.map((option, index) => /* @__PURE__ */ jsx(
|
|
114
|
-
CommandItem,
|
|
115
|
-
{
|
|
116
|
-
value: option.value,
|
|
117
|
-
onMouseDown: (e) => e.preventDefault(),
|
|
118
|
-
onSelect: () => handleSelectItem(option),
|
|
119
|
-
className: cn(
|
|
120
|
-
"text-t16m hover:!bg-accent data-[selected='true']:bg-accent rounded-none p-3",
|
|
121
|
-
index > 0 && "border-border border-t"
|
|
122
|
-
),
|
|
123
|
-
children: renderOption ? renderOption(option) : option.name ?? option.value
|
|
124
|
-
},
|
|
125
|
-
option.value
|
|
126
|
-
)) }),
|
|
127
|
-
searchedOptions?.length === 0 && !isLoading && enableAddNewItem && newItem && /* @__PURE__ */ jsx(CommandGroup, { className: "px-0 py-2", children: [newItem].filter((o) => !!o).map((option, index) => /* @__PURE__ */ jsx(
|
|
128
|
-
CommandItem,
|
|
129
|
-
{
|
|
130
|
-
value: option.value,
|
|
131
|
-
onMouseDown: (e) => e.preventDefault(),
|
|
132
|
-
onSelect: () => handleSelectItem(option),
|
|
133
|
-
className: cn(
|
|
134
|
-
"text-t16m hover:!bg-accent data-[selected='true']:bg-accent rounded-none px-3 py-4",
|
|
135
|
-
index > 0 && "border-border border-t"
|
|
136
|
-
),
|
|
137
|
-
children: renderOption ? renderOption(option, true) : option.name ?? option.value
|
|
138
|
-
},
|
|
139
|
-
option.value
|
|
140
|
-
)) }),
|
|
141
|
-
searchedOptions?.length === 0 && !isLoading && !enableAddNewItem && /* @__PURE__ */ jsx(CommandGroup, { className: "px-0 py-2", children: /* @__PURE__ */ jsx(
|
|
142
|
-
CommandItem,
|
|
143
|
-
{
|
|
144
|
-
onMouseDown: (e) => e.preventDefault(),
|
|
145
|
-
className: cn("!text-t16 !text-muted-foreground !bg-transparent px-3 py-4"),
|
|
146
|
-
children: renderEmpty ? renderEmpty() : /* @__PURE__ */ jsx("p", { children: "Kh\xF4ng c\xF3 th\xF4ng tin hi\u1EC3n th\u1ECB" })
|
|
147
|
-
}
|
|
148
|
-
) })
|
|
149
|
-
] })
|
|
150
|
-
}
|
|
151
|
-
)
|
|
152
|
-
] }) });
|
|
153
|
-
}
|
|
154
|
-
|
|
155
|
-
export { AutoComplete };
|
|
156
|
-
//# sourceMappingURL=autocomplete.mjs.map
|
|
157
|
-
//# sourceMappingURL=autocomplete.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/common/interactive/autocomplete.tsx"],"names":["CommandPrimitive"],"mappings":"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","file":"autocomplete.mjs","sourcesContent":["import { Command as CommandPrimitive } from 'cmdk';\nimport { useEffect, useMemo, useState } from 'react';\nimport { Command, CommandGroup, CommandItem, CommandList } from '@/components/command';\nimport { Input } from '@/components/input';\nimport { Popover, PopoverTrigger, PopoverContent } from '@/components/popover';\nimport { Skeleton } from '@/components/skeleton';\nimport { Option } from '@/common/interactive/select';\nimport {\n ApiSearchFunction,\n ApiSearchPaginatedFunction,\n} from '@/common/interactive/select-with-api';\nimport * as React from 'react';\nimport { cn } from '@/lib/utils';\n\ntype Props<T extends string> = {\n label?: string;\n placeholder?: string;\n options?: Option[];\n searchApi?: ApiSearchFunction<Option> | ApiSearchPaginatedFunction<Option>;\n value?: string;\n onInputChange?: (value?: string) => void;\n onSelectChange?: (value?: Option) => void;\n children?: React.ReactNode;\n enableAddNewItem?: boolean;\n newItemOption?: (value: string) => Option | null;\n renderOption?: (option: Option, isNewItem?: boolean) => React.ReactNode;\n renderEmpty?: () => React.ReactNode;\n className?: string;\n};\n\nexport function AutoComplete<T extends string>({\n label = '',\n placeholder = '',\n options,\n searchApi,\n value,\n onInputChange,\n onSelectChange,\n children,\n enableAddNewItem,\n newItemOption,\n renderOption,\n className,\n renderEmpty,\n ...props\n}: Props<T>) {\n const triggerRef = React.useRef<HTMLDivElement>(null);\n const [triggerWidth, setTriggerWidth] = useState<number>();\n const [open, setOpen] = useState(false);\n const [isLoading, setIsLoading] = useState(false);\n const [searchedOptions, setSearchedOptions] = useState<Option[]>([]);\n\n const newItem = useMemo(() => newItemOption?.(value ?? ''), [newItemOption, value]);\n\n useEffect(() => {\n if (open) handleSearch(value);\n\n if (triggerRef.current) {\n setTriggerWidth(triggerRef.current.offsetWidth);\n }\n }, [open, value]);\n\n const isPaginatedApi = (api: any): api is ApiSearchPaginatedFunction<Option> => {\n return typeof api === 'function' && api.length >= 2;\n };\n\n const handleSearch = async (searchValue?: string) => {\n if (!searchValue) {\n setSearchedOptions([]);\n } else if (searchApi) {\n handleSearchApi(value, 1, 10);\n } else if (options) {\n handleSearchLocal(searchValue);\n }\n };\n\n const handleSearchLocal = (searchValue?: string) => {\n if (searchValue && options && options?.length > 0) {\n const resultOptions = [...(options ?? [])].filter(\n // (option) => (option.name?.toLowerCase().search(searchValue.toLowerCase()) ?? -1) > -1,\n (option) =>\n option.name\n ?.toLowerCase()\n .normalize('NFD')\n .replace(/[\\u0300-\\u036f]/g, '')\n .includes(\n searchValue\n .toLowerCase()\n .normalize('NFD')\n .replace(/[\\u0300-\\u036f]/g, ''),\n ) ?? false,\n );\n\n setSearchedOptions(resultOptions);\n } else if (options && options?.length > 0) {\n setSearchedOptions([...(options ?? [])]);\n }\n };\n\n const handleSearchApi = async (searchValue: string = '', page: number = 1, size: number = 10) => {\n try {\n setIsLoading(true);\n if (isPaginatedApi(searchApi)) {\n const res = await searchApi?.(searchValue, page, size);\n const resultOptions = res?.data ?? [];\n setSearchedOptions(resultOptions);\n } else {\n const resultOptions = await (searchApi as ApiSearchFunction<Option>)(searchValue);\n setSearchedOptions(resultOptions);\n }\n } catch (error) {\n } finally {\n setIsLoading(false);\n }\n };\n\n const handleSelectItem = (option: Option) => {\n onSelectChange?.(option);\n setOpen(false);\n };\n\n return (\n <Popover open={open} onOpenChange={setOpen}>\n <Command shouldFilter={false}>\n <PopoverTrigger asChild>\n <div ref={triggerRef}>\n <CommandPrimitive.Input\n {...props}\n asChild\n value={value}\n onValueChange={onInputChange}\n placeholder={placeholder}\n onKeyDown={(e) => setOpen(e.key !== 'Escape')}\n >\n {children ?? <Input label={label} />}\n </CommandPrimitive.Input>\n </div>\n </PopoverTrigger>\n\n <PopoverContent\n asChild\n onOpenAutoFocus={(e) => e.preventDefault()}\n onInteractOutside={(e) => {\n if (e.target instanceof Element && e.target.hasAttribute('cmdk-input')) {\n e.preventDefault();\n }\n }}\n className=\"w-full min-w-[300px] p-0\"\n // hidden={\n // // (!searchedOptions || searchedOptions?.length == 0) &&\n // // (!enableAddNewItem || !value || !newItem) &&\n // // !isLoading\n // }\n hidden={!value}\n align=\"start\"\n style={{ width: triggerWidth }}\n >\n <CommandList>\n {isLoading && (\n <CommandPrimitive.Loading>\n <div className=\"space-y-2 p-3\">\n {new Array(5).fill(1).map((_item, index) => (\n <Skeleton className=\"h-10 w-full\" key={index} />\n ))}\n </div>\n </CommandPrimitive.Loading>\n )}\n\n {searchedOptions?.length > 0 && !isLoading && (\n <CommandGroup className=\"px-0 py-2\">\n {searchedOptions.map((option, index: number) => (\n <CommandItem\n key={option.value}\n value={option.value}\n onMouseDown={(e) => e.preventDefault()}\n onSelect={() => handleSelectItem(option)}\n className={cn(\n \"text-t16m hover:!bg-accent data-[selected='true']:bg-accent rounded-none p-3\",\n index > 0 && 'border-border border-t',\n )}\n >\n {renderOption ? renderOption(option) : (option.name ?? option.value)}\n </CommandItem>\n ))}\n </CommandGroup>\n )}\n\n {searchedOptions?.length === 0 && !isLoading && enableAddNewItem && newItem && (\n <CommandGroup className=\"px-0 py-2\">\n {[newItem]\n .filter((o) => !!o)\n .map((option, index: number) => (\n <CommandItem\n key={option.value}\n value={option.value}\n onMouseDown={(e) => e.preventDefault()}\n onSelect={() => handleSelectItem(option)}\n className={cn(\n \"text-t16m hover:!bg-accent data-[selected='true']:bg-accent rounded-none px-3 py-4\",\n index > 0 && 'border-border border-t',\n )}\n >\n {renderOption ? renderOption(option, true) : (option.name ?? option.value)}\n </CommandItem>\n ))}\n </CommandGroup>\n )}\n\n {searchedOptions?.length === 0 && !isLoading && !enableAddNewItem && (\n <CommandGroup className=\"px-0 py-2\">\n <CommandItem\n onMouseDown={(e) => e.preventDefault()}\n className={cn('!text-t16 !text-muted-foreground !bg-transparent px-3 py-4')}\n >\n {renderEmpty ? renderEmpty() : <p>Không có thông tin hiển thị</p>}\n </CommandItem>\n </CommandGroup>\n )}\n </CommandList>\n </PopoverContent>\n </Command>\n </Popover>\n );\n}\n"]}
|
|
@@ -1,152 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
|
-
var jsxRuntime = require('react/jsx-runtime');
|
|
6
|
-
var React = require('react');
|
|
7
|
-
var tooltip = require('../../components/tooltip');
|
|
8
|
-
var utils = require('../../lib/utils');
|
|
9
|
-
|
|
10
|
-
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
|
|
11
|
-
|
|
12
|
-
var React__default = /*#__PURE__*/_interopDefault(React);
|
|
13
|
-
|
|
14
|
-
const CopyTooltip = React__default.default.forwardRef(
|
|
15
|
-
({
|
|
16
|
-
// Trigger props
|
|
17
|
-
trigger,
|
|
18
|
-
triggerAsChild = false,
|
|
19
|
-
triggerClassName,
|
|
20
|
-
// Tooltip behavior props
|
|
21
|
-
delayDuration = 700,
|
|
22
|
-
open: controlledOpen,
|
|
23
|
-
onOpenChange: controlledOnOpenChange,
|
|
24
|
-
defaultOpen = false,
|
|
25
|
-
disableHoverableContent = true,
|
|
26
|
-
// Arrow props
|
|
27
|
-
showArrow = true,
|
|
28
|
-
arrowClassName,
|
|
29
|
-
// Content props
|
|
30
|
-
children,
|
|
31
|
-
text,
|
|
32
|
-
responseContent = "\u0110\xE3 sao ch\xE9p",
|
|
33
|
-
contentClassName,
|
|
34
|
-
childrenClassName,
|
|
35
|
-
// Copy behavior props
|
|
36
|
-
onCopySuccess,
|
|
37
|
-
onCopyError,
|
|
38
|
-
resetDelay = 2e3,
|
|
39
|
-
// Tooltip provider props
|
|
40
|
-
skipDelayDuration = 300,
|
|
41
|
-
// Other props
|
|
42
|
-
className,
|
|
43
|
-
...props
|
|
44
|
-
}, ref) => {
|
|
45
|
-
const [internalOpen, setInternalOpen] = React.useState(defaultOpen);
|
|
46
|
-
const [status, setStatus] = React.useState("idle");
|
|
47
|
-
const isControlled = controlledOpen !== void 0;
|
|
48
|
-
const open = isControlled ? controlledOpen : internalOpen && status !== "idle";
|
|
49
|
-
const setOpen = isControlled ? controlledOnOpenChange : setInternalOpen;
|
|
50
|
-
const handleOpenChange = React.useCallback(
|
|
51
|
-
(newOpen) => {
|
|
52
|
-
setOpen?.(newOpen);
|
|
53
|
-
},
|
|
54
|
-
[setOpen]
|
|
55
|
-
);
|
|
56
|
-
const copyToClipboard = React.useCallback(
|
|
57
|
-
async (textToCopy) => {
|
|
58
|
-
try {
|
|
59
|
-
await navigator.clipboard.writeText(textToCopy);
|
|
60
|
-
setStatus("copied");
|
|
61
|
-
setInternalOpen(true);
|
|
62
|
-
onCopySuccess?.(textToCopy);
|
|
63
|
-
return true;
|
|
64
|
-
} catch (error) {
|
|
65
|
-
const err = error;
|
|
66
|
-
setStatus("failed");
|
|
67
|
-
setInternalOpen(true);
|
|
68
|
-
onCopyError?.(err);
|
|
69
|
-
console.error("Failed to copy text to clipboard:", err);
|
|
70
|
-
return false;
|
|
71
|
-
}
|
|
72
|
-
},
|
|
73
|
-
[onCopySuccess, onCopyError]
|
|
74
|
-
);
|
|
75
|
-
const handleTriggerClick = React.useCallback(
|
|
76
|
-
(event) => {
|
|
77
|
-
event.preventDefault();
|
|
78
|
-
if (text) {
|
|
79
|
-
copyToClipboard(text);
|
|
80
|
-
}
|
|
81
|
-
},
|
|
82
|
-
[text, copyToClipboard]
|
|
83
|
-
);
|
|
84
|
-
React.useEffect(() => {
|
|
85
|
-
if (status === "copied" || status === "failed") {
|
|
86
|
-
const timeout = setTimeout(() => {
|
|
87
|
-
setStatus("idle");
|
|
88
|
-
setInternalOpen(false);
|
|
89
|
-
}, resetDelay);
|
|
90
|
-
return () => clearTimeout(timeout);
|
|
91
|
-
}
|
|
92
|
-
}, [status, resetDelay]);
|
|
93
|
-
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
94
|
-
tooltip.TooltipProvider,
|
|
95
|
-
{
|
|
96
|
-
delayDuration,
|
|
97
|
-
skipDelayDuration,
|
|
98
|
-
disableHoverableContent,
|
|
99
|
-
children: /* @__PURE__ */ jsxRuntime.jsxs(
|
|
100
|
-
tooltip.Tooltip,
|
|
101
|
-
{
|
|
102
|
-
open,
|
|
103
|
-
onOpenChange: handleOpenChange,
|
|
104
|
-
defaultOpen: false,
|
|
105
|
-
delayDuration,
|
|
106
|
-
disableHoverableContent,
|
|
107
|
-
children: [
|
|
108
|
-
trigger && /* @__PURE__ */ jsxRuntime.jsx(
|
|
109
|
-
tooltip.TooltipTrigger,
|
|
110
|
-
{
|
|
111
|
-
asChild: triggerAsChild,
|
|
112
|
-
className: utils.cn("cursor-pointer", triggerClassName),
|
|
113
|
-
onClick: handleTriggerClick,
|
|
114
|
-
children: trigger
|
|
115
|
-
}
|
|
116
|
-
),
|
|
117
|
-
children && /* @__PURE__ */ jsxRuntime.jsx(
|
|
118
|
-
tooltip.TooltipTrigger,
|
|
119
|
-
{
|
|
120
|
-
asChild: triggerAsChild,
|
|
121
|
-
className: utils.cn("cursor-pointer", triggerClassName),
|
|
122
|
-
onClick: handleTriggerClick,
|
|
123
|
-
children
|
|
124
|
-
}
|
|
125
|
-
),
|
|
126
|
-
/* @__PURE__ */ jsxRuntime.jsxs(
|
|
127
|
-
tooltip.TooltipContent,
|
|
128
|
-
{
|
|
129
|
-
ref,
|
|
130
|
-
showArrow,
|
|
131
|
-
className: utils.cn("flex flex-col px-3 py-1", className, contentClassName),
|
|
132
|
-
...props,
|
|
133
|
-
children: [
|
|
134
|
-
/* @__PURE__ */ jsxRuntime.jsx("div", { className: utils.cn(childrenClassName), children: responseContent }),
|
|
135
|
-
showArrow && /* @__PURE__ */ jsxRuntime.jsx(tooltip.TooltipArrow, { className: utils.cn("fill-foreground !h-[5px] !w-[8px]", arrowClassName) })
|
|
136
|
-
]
|
|
137
|
-
}
|
|
138
|
-
)
|
|
139
|
-
]
|
|
140
|
-
}
|
|
141
|
-
)
|
|
142
|
-
}
|
|
143
|
-
);
|
|
144
|
-
}
|
|
145
|
-
);
|
|
146
|
-
CopyTooltip.displayName = "CopyTooltip";
|
|
147
|
-
var copy_tooltip_default = CopyTooltip;
|
|
148
|
-
|
|
149
|
-
exports.CopyTooltip = CopyTooltip;
|
|
150
|
-
exports.default = copy_tooltip_default;
|
|
151
|
-
//# sourceMappingURL=copy-tooltip.js.map
|
|
152
|
-
//# sourceMappingURL=copy-tooltip.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/common/interactive/copy-tooltip.tsx"],"names":["React","useState","useCallback","useEffect","jsx","TooltipProvider","jsxs","Tooltip","TooltipTrigger","cn","TooltipContent","TooltipArrow"],"mappings":"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","file":"copy-tooltip.js","sourcesContent":["import React, { ComponentPropsWithoutRef, useCallback, useEffect, useState } from 'react';\nimport {\n Tooltip,\n TooltipArrow,\n TooltipContent,\n TooltipProvider,\n TooltipTrigger,\n} from '../../components/tooltip';\nimport { type CopyStatus } from '../../hooks/useCopyToClipboard';\nimport { cn } from '../../lib/utils';\n\nexport interface CopyTooltipProps extends ComponentPropsWithoutRef<typeof TooltipContent> {\n // Trigger props\n trigger?: React.ReactNode;\n triggerAsChild?: boolean;\n triggerClassName?: string;\n\n // Content props\n children?: React.ReactNode;\n text?: string;\n responseContent?: string;\n contentClassName?: string;\n childrenClassName?: string;\n\n // Tooltip behavior props\n delayDuration?: number;\n open?: boolean;\n onOpenChange?: (open: boolean) => void;\n defaultOpen?: boolean;\n disableHoverableContent?: boolean;\n\n // Arrow props\n showArrow?: boolean;\n arrowClassName?: string;\n\n // Copy behavior props\n onCopySuccess?: (text: string) => void;\n onCopyError?: (error: Error) => void;\n resetDelay?: number;\n\n // Tooltip provider props\n skipDelayDuration?: number;\n}\n\nconst CopyTooltip = React.forwardRef<React.ElementRef<typeof TooltipContent>, CopyTooltipProps>(\n (\n {\n // Trigger props\n trigger,\n triggerAsChild = false,\n triggerClassName,\n\n // Tooltip behavior props\n delayDuration = 700,\n open: controlledOpen,\n onOpenChange: controlledOnOpenChange,\n defaultOpen = false,\n disableHoverableContent = true,\n\n // Arrow props\n showArrow = true,\n arrowClassName,\n\n // Content props\n children,\n text,\n responseContent = 'Đã sao chép',\n contentClassName,\n childrenClassName,\n\n // Copy behavior props\n onCopySuccess,\n onCopyError,\n resetDelay = 2000,\n\n // Tooltip provider props\n skipDelayDuration = 300,\n\n // Other props\n className,\n ...props\n },\n ref,\n ) => {\n const [internalOpen, setInternalOpen] = useState(defaultOpen);\n const [status, setStatus] = useState<CopyStatus>('idle');\n\n // Use controlled or uncontrolled state\n const isControlled = controlledOpen !== undefined;\n const open = isControlled ? controlledOpen : internalOpen && status !== 'idle';\n const setOpen = isControlled ? controlledOnOpenChange : setInternalOpen;\n\n const handleOpenChange = useCallback(\n (newOpen: boolean) => {\n setOpen?.(newOpen);\n },\n [setOpen],\n );\n\n const copyToClipboard = useCallback(\n async (textToCopy: string): Promise<boolean> => {\n try {\n await navigator.clipboard.writeText(textToCopy);\n setStatus('copied');\n setInternalOpen(true);\n onCopySuccess?.(textToCopy);\n return true;\n } catch (error) {\n const err = error as Error;\n setStatus('failed');\n setInternalOpen(true);\n onCopyError?.(err);\n console.error('Failed to copy text to clipboard:', err);\n return false;\n }\n },\n [onCopySuccess, onCopyError],\n );\n\n const handleTriggerClick = useCallback(\n (event: React.MouseEvent) => {\n event.preventDefault();\n if (text) {\n copyToClipboard(text);\n }\n },\n [text, copyToClipboard],\n );\n\n // Reset status after specified delay\n useEffect(() => {\n if (status === 'copied' || status === 'failed') {\n const timeout = setTimeout(() => {\n setStatus('idle');\n setInternalOpen(false);\n }, resetDelay);\n\n return () => clearTimeout(timeout);\n }\n }, [status, resetDelay]);\n\n return (\n <TooltipProvider\n delayDuration={delayDuration}\n skipDelayDuration={skipDelayDuration}\n disableHoverableContent={disableHoverableContent}\n >\n <Tooltip\n open={open}\n onOpenChange={handleOpenChange}\n defaultOpen={false}\n delayDuration={delayDuration}\n disableHoverableContent={disableHoverableContent}\n >\n {trigger && (\n <TooltipTrigger\n asChild={triggerAsChild}\n className={cn('cursor-pointer', triggerClassName)}\n onClick={handleTriggerClick}\n >\n {trigger}\n </TooltipTrigger>\n )}\n {children && (\n <TooltipTrigger\n asChild={triggerAsChild}\n className={cn('cursor-pointer', triggerClassName)}\n onClick={handleTriggerClick}\n >\n {children}\n </TooltipTrigger>\n )}\n <TooltipContent\n ref={ref}\n showArrow={showArrow}\n className={cn('flex flex-col px-3 py-1', className, contentClassName)}\n {...props}\n >\n <div className={cn(childrenClassName)}>{responseContent}</div>\n {showArrow && (\n <TooltipArrow className={cn('fill-foreground !h-[5px] !w-[8px]', arrowClassName)} />\n )}\n </TooltipContent>\n </Tooltip>\n </TooltipProvider>\n );\n },\n);\n\nCopyTooltip.displayName = 'CopyTooltip';\n\nexport { CopyTooltip };\nexport default CopyTooltip;\n"]}
|
|
@@ -1,143 +0,0 @@
|
|
|
1
|
-
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
2
|
-
import React, { useState, useCallback, useEffect } from 'react';
|
|
3
|
-
import { TooltipProvider, Tooltip, TooltipTrigger, TooltipContent, TooltipArrow } from '../../components/tooltip';
|
|
4
|
-
import { cn } from '../../lib/utils';
|
|
5
|
-
|
|
6
|
-
const CopyTooltip = React.forwardRef(
|
|
7
|
-
({
|
|
8
|
-
// Trigger props
|
|
9
|
-
trigger,
|
|
10
|
-
triggerAsChild = false,
|
|
11
|
-
triggerClassName,
|
|
12
|
-
// Tooltip behavior props
|
|
13
|
-
delayDuration = 700,
|
|
14
|
-
open: controlledOpen,
|
|
15
|
-
onOpenChange: controlledOnOpenChange,
|
|
16
|
-
defaultOpen = false,
|
|
17
|
-
disableHoverableContent = true,
|
|
18
|
-
// Arrow props
|
|
19
|
-
showArrow = true,
|
|
20
|
-
arrowClassName,
|
|
21
|
-
// Content props
|
|
22
|
-
children,
|
|
23
|
-
text,
|
|
24
|
-
responseContent = "\u0110\xE3 sao ch\xE9p",
|
|
25
|
-
contentClassName,
|
|
26
|
-
childrenClassName,
|
|
27
|
-
// Copy behavior props
|
|
28
|
-
onCopySuccess,
|
|
29
|
-
onCopyError,
|
|
30
|
-
resetDelay = 2e3,
|
|
31
|
-
// Tooltip provider props
|
|
32
|
-
skipDelayDuration = 300,
|
|
33
|
-
// Other props
|
|
34
|
-
className,
|
|
35
|
-
...props
|
|
36
|
-
}, ref) => {
|
|
37
|
-
const [internalOpen, setInternalOpen] = useState(defaultOpen);
|
|
38
|
-
const [status, setStatus] = useState("idle");
|
|
39
|
-
const isControlled = controlledOpen !== void 0;
|
|
40
|
-
const open = isControlled ? controlledOpen : internalOpen && status !== "idle";
|
|
41
|
-
const setOpen = isControlled ? controlledOnOpenChange : setInternalOpen;
|
|
42
|
-
const handleOpenChange = useCallback(
|
|
43
|
-
(newOpen) => {
|
|
44
|
-
setOpen?.(newOpen);
|
|
45
|
-
},
|
|
46
|
-
[setOpen]
|
|
47
|
-
);
|
|
48
|
-
const copyToClipboard = useCallback(
|
|
49
|
-
async (textToCopy) => {
|
|
50
|
-
try {
|
|
51
|
-
await navigator.clipboard.writeText(textToCopy);
|
|
52
|
-
setStatus("copied");
|
|
53
|
-
setInternalOpen(true);
|
|
54
|
-
onCopySuccess?.(textToCopy);
|
|
55
|
-
return true;
|
|
56
|
-
} catch (error) {
|
|
57
|
-
const err = error;
|
|
58
|
-
setStatus("failed");
|
|
59
|
-
setInternalOpen(true);
|
|
60
|
-
onCopyError?.(err);
|
|
61
|
-
console.error("Failed to copy text to clipboard:", err);
|
|
62
|
-
return false;
|
|
63
|
-
}
|
|
64
|
-
},
|
|
65
|
-
[onCopySuccess, onCopyError]
|
|
66
|
-
);
|
|
67
|
-
const handleTriggerClick = useCallback(
|
|
68
|
-
(event) => {
|
|
69
|
-
event.preventDefault();
|
|
70
|
-
if (text) {
|
|
71
|
-
copyToClipboard(text);
|
|
72
|
-
}
|
|
73
|
-
},
|
|
74
|
-
[text, copyToClipboard]
|
|
75
|
-
);
|
|
76
|
-
useEffect(() => {
|
|
77
|
-
if (status === "copied" || status === "failed") {
|
|
78
|
-
const timeout = setTimeout(() => {
|
|
79
|
-
setStatus("idle");
|
|
80
|
-
setInternalOpen(false);
|
|
81
|
-
}, resetDelay);
|
|
82
|
-
return () => clearTimeout(timeout);
|
|
83
|
-
}
|
|
84
|
-
}, [status, resetDelay]);
|
|
85
|
-
return /* @__PURE__ */ jsx(
|
|
86
|
-
TooltipProvider,
|
|
87
|
-
{
|
|
88
|
-
delayDuration,
|
|
89
|
-
skipDelayDuration,
|
|
90
|
-
disableHoverableContent,
|
|
91
|
-
children: /* @__PURE__ */ jsxs(
|
|
92
|
-
Tooltip,
|
|
93
|
-
{
|
|
94
|
-
open,
|
|
95
|
-
onOpenChange: handleOpenChange,
|
|
96
|
-
defaultOpen: false,
|
|
97
|
-
delayDuration,
|
|
98
|
-
disableHoverableContent,
|
|
99
|
-
children: [
|
|
100
|
-
trigger && /* @__PURE__ */ jsx(
|
|
101
|
-
TooltipTrigger,
|
|
102
|
-
{
|
|
103
|
-
asChild: triggerAsChild,
|
|
104
|
-
className: cn("cursor-pointer", triggerClassName),
|
|
105
|
-
onClick: handleTriggerClick,
|
|
106
|
-
children: trigger
|
|
107
|
-
}
|
|
108
|
-
),
|
|
109
|
-
children && /* @__PURE__ */ jsx(
|
|
110
|
-
TooltipTrigger,
|
|
111
|
-
{
|
|
112
|
-
asChild: triggerAsChild,
|
|
113
|
-
className: cn("cursor-pointer", triggerClassName),
|
|
114
|
-
onClick: handleTriggerClick,
|
|
115
|
-
children
|
|
116
|
-
}
|
|
117
|
-
),
|
|
118
|
-
/* @__PURE__ */ jsxs(
|
|
119
|
-
TooltipContent,
|
|
120
|
-
{
|
|
121
|
-
ref,
|
|
122
|
-
showArrow,
|
|
123
|
-
className: cn("flex flex-col px-3 py-1", className, contentClassName),
|
|
124
|
-
...props,
|
|
125
|
-
children: [
|
|
126
|
-
/* @__PURE__ */ jsx("div", { className: cn(childrenClassName), children: responseContent }),
|
|
127
|
-
showArrow && /* @__PURE__ */ jsx(TooltipArrow, { className: cn("fill-foreground !h-[5px] !w-[8px]", arrowClassName) })
|
|
128
|
-
]
|
|
129
|
-
}
|
|
130
|
-
)
|
|
131
|
-
]
|
|
132
|
-
}
|
|
133
|
-
)
|
|
134
|
-
}
|
|
135
|
-
);
|
|
136
|
-
}
|
|
137
|
-
);
|
|
138
|
-
CopyTooltip.displayName = "CopyTooltip";
|
|
139
|
-
var copy_tooltip_default = CopyTooltip;
|
|
140
|
-
|
|
141
|
-
export { CopyTooltip, copy_tooltip_default as default };
|
|
142
|
-
//# sourceMappingURL=copy-tooltip.mjs.map
|
|
143
|
-
//# sourceMappingURL=copy-tooltip.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/common/interactive/copy-tooltip.tsx"],"names":[],"mappings":"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","file":"copy-tooltip.mjs","sourcesContent":["import React, { ComponentPropsWithoutRef, useCallback, useEffect, useState } from 'react';\nimport {\n Tooltip,\n TooltipArrow,\n TooltipContent,\n TooltipProvider,\n TooltipTrigger,\n} from '../../components/tooltip';\nimport { type CopyStatus } from '../../hooks/useCopyToClipboard';\nimport { cn } from '../../lib/utils';\n\nexport interface CopyTooltipProps extends ComponentPropsWithoutRef<typeof TooltipContent> {\n // Trigger props\n trigger?: React.ReactNode;\n triggerAsChild?: boolean;\n triggerClassName?: string;\n\n // Content props\n children?: React.ReactNode;\n text?: string;\n responseContent?: string;\n contentClassName?: string;\n childrenClassName?: string;\n\n // Tooltip behavior props\n delayDuration?: number;\n open?: boolean;\n onOpenChange?: (open: boolean) => void;\n defaultOpen?: boolean;\n disableHoverableContent?: boolean;\n\n // Arrow props\n showArrow?: boolean;\n arrowClassName?: string;\n\n // Copy behavior props\n onCopySuccess?: (text: string) => void;\n onCopyError?: (error: Error) => void;\n resetDelay?: number;\n\n // Tooltip provider props\n skipDelayDuration?: number;\n}\n\nconst CopyTooltip = React.forwardRef<React.ElementRef<typeof TooltipContent>, CopyTooltipProps>(\n (\n {\n // Trigger props\n trigger,\n triggerAsChild = false,\n triggerClassName,\n\n // Tooltip behavior props\n delayDuration = 700,\n open: controlledOpen,\n onOpenChange: controlledOnOpenChange,\n defaultOpen = false,\n disableHoverableContent = true,\n\n // Arrow props\n showArrow = true,\n arrowClassName,\n\n // Content props\n children,\n text,\n responseContent = 'Đã sao chép',\n contentClassName,\n childrenClassName,\n\n // Copy behavior props\n onCopySuccess,\n onCopyError,\n resetDelay = 2000,\n\n // Tooltip provider props\n skipDelayDuration = 300,\n\n // Other props\n className,\n ...props\n },\n ref,\n ) => {\n const [internalOpen, setInternalOpen] = useState(defaultOpen);\n const [status, setStatus] = useState<CopyStatus>('idle');\n\n // Use controlled or uncontrolled state\n const isControlled = controlledOpen !== undefined;\n const open = isControlled ? controlledOpen : internalOpen && status !== 'idle';\n const setOpen = isControlled ? controlledOnOpenChange : setInternalOpen;\n\n const handleOpenChange = useCallback(\n (newOpen: boolean) => {\n setOpen?.(newOpen);\n },\n [setOpen],\n );\n\n const copyToClipboard = useCallback(\n async (textToCopy: string): Promise<boolean> => {\n try {\n await navigator.clipboard.writeText(textToCopy);\n setStatus('copied');\n setInternalOpen(true);\n onCopySuccess?.(textToCopy);\n return true;\n } catch (error) {\n const err = error as Error;\n setStatus('failed');\n setInternalOpen(true);\n onCopyError?.(err);\n console.error('Failed to copy text to clipboard:', err);\n return false;\n }\n },\n [onCopySuccess, onCopyError],\n );\n\n const handleTriggerClick = useCallback(\n (event: React.MouseEvent) => {\n event.preventDefault();\n if (text) {\n copyToClipboard(text);\n }\n },\n [text, copyToClipboard],\n );\n\n // Reset status after specified delay\n useEffect(() => {\n if (status === 'copied' || status === 'failed') {\n const timeout = setTimeout(() => {\n setStatus('idle');\n setInternalOpen(false);\n }, resetDelay);\n\n return () => clearTimeout(timeout);\n }\n }, [status, resetDelay]);\n\n return (\n <TooltipProvider\n delayDuration={delayDuration}\n skipDelayDuration={skipDelayDuration}\n disableHoverableContent={disableHoverableContent}\n >\n <Tooltip\n open={open}\n onOpenChange={handleOpenChange}\n defaultOpen={false}\n delayDuration={delayDuration}\n disableHoverableContent={disableHoverableContent}\n >\n {trigger && (\n <TooltipTrigger\n asChild={triggerAsChild}\n className={cn('cursor-pointer', triggerClassName)}\n onClick={handleTriggerClick}\n >\n {trigger}\n </TooltipTrigger>\n )}\n {children && (\n <TooltipTrigger\n asChild={triggerAsChild}\n className={cn('cursor-pointer', triggerClassName)}\n onClick={handleTriggerClick}\n >\n {children}\n </TooltipTrigger>\n )}\n <TooltipContent\n ref={ref}\n showArrow={showArrow}\n className={cn('flex flex-col px-3 py-1', className, contentClassName)}\n {...props}\n >\n <div className={cn(childrenClassName)}>{responseContent}</div>\n {showArrow && (\n <TooltipArrow className={cn('fill-foreground !h-[5px] !w-[8px]', arrowClassName)} />\n )}\n </TooltipContent>\n </Tooltip>\n </TooltipProvider>\n );\n },\n);\n\nCopyTooltip.displayName = 'CopyTooltip';\n\nexport { CopyTooltip };\nexport default CopyTooltip;\n"]}
|