@od-oneapp/uni-ui 2026.1.1301
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +753 -0
- package/dist/actions-C-SEx2GS.mjs +180 -0
- package/dist/actions-C-SEx2GS.mjs.map +1 -0
- package/dist/actions-Ch7h6cYC.d.mts +50 -0
- package/dist/actions-Cnupw96c.d.mts +50 -0
- package/dist/alert-BVUF7Xzb.d.mts +22 -0
- package/dist/alert-BuPyEXF-.mjs +206 -0
- package/dist/alert-BuPyEXF-.mjs.map +1 -0
- package/dist/alert-CfjDnZpm.d.mts +22 -0
- package/dist/animated-size-container-DSKNt1Cn.mjs +106 -0
- package/dist/animated-size-container-DSKNt1Cn.mjs.map +1 -0
- package/dist/areas-CtE8w69A.mjs +144 -0
- package/dist/areas-CtE8w69A.mjs.map +1 -0
- package/dist/areas-DtGnjGuX.d.mts +22 -0
- package/dist/auth-nav-user-CRxDpY_7.d.mts +30 -0
- package/dist/auth-nav-user-DPFv8dTp.mjs +181 -0
- package/dist/auth-nav-user-DPFv8dTp.mjs.map +1 -0
- package/dist/avatar-DjiX7nT8.mjs +202 -0
- package/dist/avatar-DjiX7nT8.mjs.map +1 -0
- package/dist/badge-CGTN2VG0.d.mts +25 -0
- package/dist/badge-CVoIuyYX.mjs +242 -0
- package/dist/badge-CVoIuyYX.mjs.map +1 -0
- package/dist/badge-DH0tY3wJ.d.mts +25 -0
- package/dist/bars-CWTAPKgm.d.mts +20 -0
- package/dist/bars-DOLvecrq.mjs +125 -0
- package/dist/bars-DOLvecrq.mjs.map +1 -0
- package/dist/branch-BEl6eS77.mjs +323 -0
- package/dist/branch-BEl6eS77.mjs.map +1 -0
- package/dist/branch-BtdY_TLE.d.mts +58 -0
- package/dist/branch-Duq6cW0s.d.mts +58 -0
- package/dist/button-BAdq0gBE.d.mts +31 -0
- package/dist/button-DVOrrZLw.mjs +632 -0
- package/dist/button-DVOrrZLw.mjs.map +1 -0
- package/dist/button-DnjeAftr.d.mts +31 -0
- package/dist/carousel-D-J1Zgn1.d.mts +49 -0
- package/dist/carousel-Dx5AOW5k.mjs +345 -0
- package/dist/carousel-Dx5AOW5k.mjs.map +1 -0
- package/dist/carousel-sY0y1-or.d.mts +49 -0
- package/dist/chart-context-CLV35VLJ.mjs +27 -0
- package/dist/chart-context-CLV35VLJ.mjs.map +1 -0
- package/dist/checkbox-wiF-DV6q.mjs +194 -0
- package/dist/checkbox-wiF-DV6q.mjs.map +1 -0
- package/dist/code-block-Cg_XtPH7.mjs +243 -0
- package/dist/code-block-Cg_XtPH7.mjs.map +1 -0
- package/dist/collapsible-CRgTpRfr.d.mts +46 -0
- package/dist/collapsible-CXy4T04n.mjs +239 -0
- package/dist/collapsible-CXy4T04n.mjs.map +1 -0
- package/dist/combobox-DSrxSkSl.d.mts +79 -0
- package/dist/combobox-DYFh2eZf.d.mts +79 -0
- package/dist/combobox-uEKksQFR.mjs +410 -0
- package/dist/combobox-uEKksQFR.mjs.map +1 -0
- package/dist/command-xK3X_A9t.mjs +206 -0
- package/dist/command-xK3X_A9t.mjs.map +1 -0
- package/dist/components-ai-elements/actions/index.d.mts +5 -0
- package/dist/components-ai-elements/actions/index.mjs +4 -0
- package/dist/components-ai-elements/agent-step/index.d.mts +32 -0
- package/dist/components-ai-elements/agent-step/index.mjs +183 -0
- package/dist/components-ai-elements/agent-step/index.mjs.map +1 -0
- package/dist/components-ai-elements/artifact/index.d.mts +81 -0
- package/dist/components-ai-elements/artifact/index.mjs +153 -0
- package/dist/components-ai-elements/artifact/index.mjs.map +1 -0
- package/dist/components-ai-elements/branch/index.d.mts +5 -0
- package/dist/components-ai-elements/branch/index.mjs +4 -0
- package/dist/components-ai-elements/chain-of-thought/index.d.mts +90 -0
- package/dist/components-ai-elements/chain-of-thought/index.mjs +338 -0
- package/dist/components-ai-elements/chain-of-thought/index.mjs.map +1 -0
- package/dist/components-ai-elements/chat-input/index.d.mts +21 -0
- package/dist/components-ai-elements/chat-input/index.mjs +137 -0
- package/dist/components-ai-elements/chat-input/index.mjs.map +1 -0
- package/dist/components-ai-elements/checkpoint/index.d.mts +46 -0
- package/dist/components-ai-elements/checkpoint/index.mjs +161 -0
- package/dist/components-ai-elements/checkpoint/index.mjs.map +1 -0
- package/dist/components-ai-elements/code-block/index.d.mts +39 -0
- package/dist/components-ai-elements/code-block/index.mjs +4 -0
- package/dist/components-ai-elements/confirmation/index.d.mts +96 -0
- package/dist/components-ai-elements/confirmation/index.mjs +295 -0
- package/dist/components-ai-elements/confirmation/index.mjs.map +1 -0
- package/dist/components-ai-elements/context/index.d.mts +83 -0
- package/dist/components-ai-elements/context/index.mjs +456 -0
- package/dist/components-ai-elements/context/index.mjs.map +1 -0
- package/dist/components-ai-elements/conversation/index.d.mts +46 -0
- package/dist/components-ai-elements/conversation/index.mjs +180 -0
- package/dist/components-ai-elements/conversation/index.mjs.map +1 -0
- package/dist/components-ai-elements/custom/index.d.mts +1142 -0
- package/dist/components-ai-elements/custom/index.mjs +5578 -0
- package/dist/components-ai-elements/custom/index.mjs.map +1 -0
- package/dist/components-ai-elements/generative-ui/index.d.mts +4 -0
- package/dist/components-ai-elements/generative-ui/index.mjs +4 -0
- package/dist/components-ai-elements/image/index.d.mts +20 -0
- package/dist/components-ai-elements/image/index.mjs +121 -0
- package/dist/components-ai-elements/image/index.mjs.map +1 -0
- package/dist/components-ai-elements/inline-citation/index.d.mts +94 -0
- package/dist/components-ai-elements/inline-citation/index.mjs +371 -0
- package/dist/components-ai-elements/inline-citation/index.mjs.map +1 -0
- package/dist/components-ai-elements/loader/index.d.mts +24 -0
- package/dist/components-ai-elements/loader/index.mjs +4 -0
- package/dist/components-ai-elements/message/index.d.mts +153 -0
- package/dist/components-ai-elements/message/index.mjs +597 -0
- package/dist/components-ai-elements/message/index.mjs.map +1 -0
- package/dist/components-ai-elements/model-selector/index.d.mts +72 -0
- package/dist/components-ai-elements/model-selector/index.mjs +224 -0
- package/dist/components-ai-elements/model-selector/index.mjs.map +1 -0
- package/dist/components-ai-elements/open-in-chat/index.d.mts +64 -0
- package/dist/components-ai-elements/open-in-chat/index.mjs +502 -0
- package/dist/components-ai-elements/open-in-chat/index.mjs.map +1 -0
- package/dist/components-ai-elements/plan/index.d.mts +71 -0
- package/dist/components-ai-elements/plan/index.mjs +219 -0
- package/dist/components-ai-elements/plan/index.mjs.map +1 -0
- package/dist/components-ai-elements/prompt-char-counter/index.d.mts +19 -0
- package/dist/components-ai-elements/prompt-char-counter/index.mjs +116 -0
- package/dist/components-ai-elements/prompt-char-counter/index.mjs.map +1 -0
- package/dist/components-ai-elements/prompt-input/index.d.mts +386 -0
- package/dist/components-ai-elements/prompt-input/index.mjs +4 -0
- package/dist/components-ai-elements/queue/index.d.mts +121 -0
- package/dist/components-ai-elements/queue/index.mjs +284 -0
- package/dist/components-ai-elements/queue/index.mjs.map +1 -0
- package/dist/components-ai-elements/reasoning/index.d.mts +42 -0
- package/dist/components-ai-elements/reasoning/index.mjs +241 -0
- package/dist/components-ai-elements/reasoning/index.mjs.map +1 -0
- package/dist/components-ai-elements/shimmer/index.d.mts +23 -0
- package/dist/components-ai-elements/shimmer/index.mjs +4 -0
- package/dist/components-ai-elements/sources/index.d.mts +56 -0
- package/dist/components-ai-elements/sources/index.mjs +211 -0
- package/dist/components-ai-elements/sources/index.mjs.map +1 -0
- package/dist/components-ai-elements/suggestion/index.d.mts +40 -0
- package/dist/components-ai-elements/suggestion/index.mjs +145 -0
- package/dist/components-ai-elements/suggestion/index.mjs.map +1 -0
- package/dist/components-ai-elements/task/index.d.mts +70 -0
- package/dist/components-ai-elements/task/index.mjs +218 -0
- package/dist/components-ai-elements/task/index.mjs.map +1 -0
- package/dist/components-ai-elements/tool/index.d.mts +78 -0
- package/dist/components-ai-elements/tool/index.mjs +370 -0
- package/dist/components-ai-elements/tool/index.mjs.map +1 -0
- package/dist/components-ai-elements/tool-approval/index.d.mts +20 -0
- package/dist/components-ai-elements/tool-approval/index.mjs +252 -0
- package/dist/components-ai-elements/tool-approval/index.mjs.map +1 -0
- package/dist/components-ai-elements/web-preview/index.d.mts +136 -0
- package/dist/components-ai-elements/web-preview/index.mjs +773 -0
- package/dist/components-ai-elements/web-preview/index.mjs.map +1 -0
- package/dist/components-ai-elements-constants.d.mts +207 -0
- package/dist/components-ai-elements-constants.mjs +301 -0
- package/dist/components-ai-elements-constants.mjs.map +1 -0
- package/dist/components-ai-workflows/canvas/index.d.mts +22 -0
- package/dist/components-ai-workflows/canvas/index.mjs +135 -0
- package/dist/components-ai-workflows/canvas/index.mjs.map +1 -0
- package/dist/components-ai-workflows/connection/index.d.mts +22 -0
- package/dist/components-ai-workflows/connection/index.mjs +4 -0
- package/dist/components-ai-workflows/controls/index.d.mts +14 -0
- package/dist/components-ai-workflows/controls/index.mjs +89 -0
- package/dist/components-ai-workflows/controls/index.mjs.map +1 -0
- package/dist/components-ai-workflows/edge/index.d.mts +20 -0
- package/dist/components-ai-workflows/edge/index.mjs +102 -0
- package/dist/components-ai-workflows/edge/index.mjs.map +1 -0
- package/dist/components-ai-workflows/node/index.d.mts +3 -0
- package/dist/components-ai-workflows/node/index.mjs +4 -0
- package/dist/components-ai-workflows/panel/index.d.mts +15 -0
- package/dist/components-ai-workflows/panel/index.mjs +89 -0
- package/dist/components-ai-workflows/panel/index.mjs.map +1 -0
- package/dist/components-ai-workflows/resizable-node/index.d.mts +30 -0
- package/dist/components-ai-workflows/resizable-node/index.mjs +164 -0
- package/dist/components-ai-workflows/resizable-node/index.mjs.map +1 -0
- package/dist/components-ai-workflows/toolbar/index.d.mts +19 -0
- package/dist/components-ai-workflows/toolbar/index.mjs +91 -0
- package/dist/components-ai-workflows/toolbar/index.mjs.map +1 -0
- package/dist/components-auth-client-nav-user.d.mts +3 -0
- package/dist/components-auth-client-nav-user.mjs +4 -0
- package/dist/components-auth-client-providers.d.mts +13 -0
- package/dist/components-auth-client-providers.mjs +89 -0
- package/dist/components-auth-client-providers.mjs.map +1 -0
- package/dist/components-auth-client.d.mts +5 -0
- package/dist/components-auth-client.mjs +5 -0
- package/dist/components-auth-server.d.mts +1878 -0
- package/dist/components-auth-server.mjs +32769 -0
- package/dist/components-auth-server.mjs.map +1 -0
- package/dist/components-auth.d.mts +5 -0
- package/dist/components-auth.mjs +5 -0
- package/dist/components-charts/areas/index.d.mts +3 -0
- package/dist/components-charts/areas/index.mjs +4 -0
- package/dist/components-charts/bars/index.d.mts +3 -0
- package/dist/components-charts/bars/index.mjs +4 -0
- package/dist/components-charts/funnel-chart/index.d.mts +3 -0
- package/dist/components-charts/funnel-chart/index.mjs +4 -0
- package/dist/components-charts/mini-area-chart/index.d.mts +3 -0
- package/dist/components-charts/mini-area-chart/index.mjs +4 -0
- package/dist/components-charts/time-series-chart/index.d.mts +3 -0
- package/dist/components-charts/time-series-chart/index.mjs +4 -0
- package/dist/components-charts/tooltip-sync/index.d.mts +3 -0
- package/dist/components-charts/tooltip-sync/index.mjs +4 -0
- package/dist/components-charts/x-axis/index.d.mts +3 -0
- package/dist/components-charts/x-axis/index.mjs +4 -0
- package/dist/components-charts/y-axis/index.d.mts +3 -0
- package/dist/components-charts/y-axis/index.mjs +4 -0
- package/dist/components-elements-accordion.d.mts +59 -0
- package/dist/components-elements-accordion.mjs +275 -0
- package/dist/components-elements-accordion.mjs.map +1 -0
- package/dist/components-elements-alert.d.mts +3 -0
- package/dist/components-elements-alert.mjs +4 -0
- package/dist/components-elements-avatar.d.mts +24 -0
- package/dist/components-elements-avatar.mjs +4 -0
- package/dist/components-elements-badge.d.mts +4 -0
- package/dist/components-elements-badge.mjs +4 -0
- package/dist/components-elements-button.d.mts +4 -0
- package/dist/components-elements-button.mjs +4 -0
- package/dist/components-elements-card.d.mts +3 -0
- package/dist/components-elements-card.mjs +4 -0
- package/dist/components-elements-carousel.d.mts +5 -0
- package/dist/components-elements-carousel.mjs +4 -0
- package/dist/components-elements-chart.d.mts +24 -0
- package/dist/components-elements-chart.mjs +226 -0
- package/dist/components-elements-chart.mjs.map +1 -0
- package/dist/components-elements-collapsible.d.mts +3 -0
- package/dist/components-elements-collapsible.mjs +4 -0
- package/dist/components-elements-dialog.d.mts +3 -0
- package/dist/components-elements-dialog.mjs +4 -0
- package/dist/components-elements-dropdown-menu.d.mts +3 -0
- package/dist/components-elements-dropdown-menu.mjs +4 -0
- package/dist/components-elements-dynamic-breadcrumb.d.mts +16 -0
- package/dist/components-elements-dynamic-breadcrumb.mjs +4 -0
- package/dist/components-elements-empty.d.mts +18 -0
- package/dist/components-elements-empty.mjs +199 -0
- package/dist/components-elements-empty.mjs.map +1 -0
- package/dist/components-elements-hover-card.d.mts +3 -0
- package/dist/components-elements-hover-card.mjs +4 -0
- package/dist/components-elements-loading-dots.d.mts +3 -0
- package/dist/components-elements-loading-dots.mjs +4 -0
- package/dist/components-elements-pagination-controls.d.mts +28 -0
- package/dist/components-elements-pagination-controls.mjs +4 -0
- package/dist/components-elements-progress.d.mts +28 -0
- package/dist/components-elements-progress.mjs +4 -0
- package/dist/components-elements-resizable.d.mts +31 -0
- package/dist/components-elements-resizable.mjs +4 -0
- package/dist/components-elements-scroll-area.d.mts +3 -0
- package/dist/components-elements-scroll-area.mjs +4 -0
- package/dist/components-elements-separator.d.mts +3 -0
- package/dist/components-elements-separator.mjs +4 -0
- package/dist/components-elements-skeleton.d.mts +3 -0
- package/dist/components-elements-skeleton.mjs +4 -0
- package/dist/components-elements-status-badge.d.mts +22 -0
- package/dist/components-elements-status-badge.mjs +174 -0
- package/dist/components-elements-status-badge.mjs.map +1 -0
- package/dist/components-elements-table.d.mts +44 -0
- package/dist/components-elements-table.mjs +4 -0
- package/dist/components-elements-tabs.d.mts +43 -0
- package/dist/components-elements-tabs.mjs +435 -0
- package/dist/components-elements-tabs.mjs.map +1 -0
- package/dist/components-elements-tooltip.d.mts +3 -0
- package/dist/components-elements-tooltip.mjs +4 -0
- package/dist/components-filter/filter-list/index.d.mts +4 -0
- package/dist/components-filter/filter-list/index.mjs +4 -0
- package/dist/components-filter/filter-select/index.d.mts +4 -0
- package/dist/components-filter/filter-select/index.mjs +4 -0
- package/dist/components-forms/checkbox/index.d.mts +27 -0
- package/dist/components-forms/checkbox/index.mjs +4 -0
- package/dist/components-forms/combobox/index.d.mts +5 -0
- package/dist/components-forms/combobox/index.mjs +4 -0
- package/dist/components-forms/date-picker/index.d.mts +3 -0
- package/dist/components-forms/date-picker/index.mjs +4 -0
- package/dist/components-forms/file-upload/index.d.mts +49 -0
- package/dist/components-forms/file-upload/index.mjs +323 -0
- package/dist/components-forms/file-upload/index.mjs.map +1 -0
- package/dist/components-forms/input/index.d.mts +3 -0
- package/dist/components-forms/input/index.mjs +4 -0
- package/dist/components-forms/input-group/index.d.mts +5 -0
- package/dist/components-forms/input-group/index.mjs +4 -0
- package/dist/components-forms/label/index.d.mts +23 -0
- package/dist/components-forms/label/index.mjs +4 -0
- package/dist/components-forms/radio-group/index.d.mts +29 -0
- package/dist/components-forms/radio-group/index.mjs +215 -0
- package/dist/components-forms/radio-group/index.mjs.map +1 -0
- package/dist/components-forms/select/index.d.mts +3 -0
- package/dist/components-forms/select/index.mjs +4 -0
- package/dist/components-forms/switch/index.d.mts +30 -0
- package/dist/components-forms/switch/index.mjs +4 -0
- package/dist/components-forms/textarea/index.d.mts +19 -0
- package/dist/components-forms/textarea/index.mjs +4 -0
- package/dist/components-layout/app-sidebar/index.d.mts +47 -0
- package/dist/components-layout/app-sidebar/index.mjs +340 -0
- package/dist/components-layout/app-sidebar/index.mjs.map +1 -0
- package/dist/components-layout/artifact-panel/index.d.mts +3 -0
- package/dist/components-layout/artifact-panel/index.mjs +4 -0
- package/dist/components-layout/content-sidebar/index.d.mts +89 -0
- package/dist/components-layout/content-sidebar/index.mjs +202 -0
- package/dist/components-layout/content-sidebar/index.mjs.map +1 -0
- package/dist/components-layout/nav-app-switcher/index.d.mts +3 -0
- package/dist/components-layout/nav-app-switcher/index.mjs +4 -0
- package/dist/components-layout/nav-main/index.d.mts +30 -0
- package/dist/components-layout/nav-main/index.mjs +4 -0
- package/dist/components-layout/nav-projects/index.d.mts +18 -0
- package/dist/components-layout/nav-projects/index.mjs +153 -0
- package/dist/components-layout/nav-projects/index.mjs.map +1 -0
- package/dist/components-layout/nav-secondary/index.d.mts +31 -0
- package/dist/components-layout/nav-secondary/index.mjs +4 -0
- package/dist/components-layout/nav-user/index.d.mts +17 -0
- package/dist/components-layout/nav-user/index.mjs +4 -0
- package/dist/components-layout/oneapp/index.mjs +4 -0
- package/dist/components-layout/sidebar/index.d.mts +8 -0
- package/dist/components-layout/sidebar/index.mjs +4 -0
- package/dist/components-layout/sidebar-inset-header-portal/index.d.mts +3 -0
- package/dist/components-layout/sidebar-inset-header-portal/index.mjs +4 -0
- package/dist/components-layout/sidebar-slots/index.d.mts +3 -0
- package/dist/components-layout/sidebar-slots/index.mjs +4 -0
- package/dist/components-layout/theme-provider/index.d.mts +15 -0
- package/dist/components-layout/theme-provider/index.mjs +4 -0
- package/dist/components-layout-app-shell.d.mts +83 -0
- package/dist/components-layout-app-shell.mjs +185 -0
- package/dist/components-layout-app-shell.mjs.map +1 -0
- package/dist/components-layout-oneapp.d.mts +84 -0
- package/dist/components-layout-oneapp.mjs +4 -0
- package/dist/components-overlays-confirm-dialog.d.mts +38 -0
- package/dist/components-overlays-confirm-dialog.mjs +145 -0
- package/dist/components-overlays-confirm-dialog.mjs.map +1 -0
- package/dist/components-overlays-toast.d.mts +16 -0
- package/dist/components-overlays-toast.mjs +127 -0
- package/dist/components-overlays-toast.mjs.map +1 -0
- package/dist/connection-D_kWZtAX.mjs +105 -0
- package/dist/connection-D_kWZtAX.mjs.map +1 -0
- package/dist/dark-mode-B4L-MZr7.mjs +288 -0
- package/dist/dark-mode-B4L-MZr7.mjs.map +1 -0
- package/dist/dark-mode-CYb7lJ6G.d.mts +191 -0
- package/dist/date-range-picker-CdemRFs_.mjs +676 -0
- package/dist/date-range-picker-CdemRFs_.mjs.map +1 -0
- package/dist/dialog-Di5QhIga.d.mts +31 -0
- package/dist/dialog-DuluSpxA.mjs +293 -0
- package/dist/dialog-DuluSpxA.mjs.map +1 -0
- package/dist/dropdown-menu-91g1g_Cl.mjs +379 -0
- package/dist/dropdown-menu-91g1g_Cl.mjs.map +1 -0
- package/dist/dropdown-menu-CwRZCnNs.d.mts +91 -0
- package/dist/dynamic-breadcrumb-33t_hdEI.mjs +385 -0
- package/dist/dynamic-breadcrumb-33t_hdEI.mjs.map +1 -0
- package/dist/error-boundary-Ggc5btkU.mjs +297 -0
- package/dist/error-boundary-Ggc5btkU.mjs.map +1 -0
- package/dist/filter-list-BMT7Nrli.d.mts +27 -0
- package/dist/filter-list-B_9aV5Lp.mjs +279 -0
- package/dist/filter-list-B_9aV5Lp.mjs.map +1 -0
- package/dist/filter-select-COLb1S5z.d.mts +34 -0
- package/dist/filter-select-CYfBhJ_E.mjs +341 -0
- package/dist/filter-select-CYfBhJ_E.mjs.map +1 -0
- package/dist/fonts.d.mts +22 -0
- package/dist/fonts.mjs +104 -0
- package/dist/fonts.mjs.map +1 -0
- package/dist/funnel-chart-CUpUr1pl.d.mts +22 -0
- package/dist/funnel-chart-fdwagDvc.mjs +318 -0
- package/dist/funnel-chart-fdwagDvc.mjs.map +1 -0
- package/dist/generative-ui-renderer-D0ZgNRZF.mjs +484 -0
- package/dist/generative-ui-renderer-D0ZgNRZF.mjs.map +1 -0
- package/dist/generative-ui-renderer-D69qYK0D.d.mts +32 -0
- package/dist/hooks/index.d.mts +5 -0
- package/dist/hooks/index.mjs +6 -0
- package/dist/hooks/use-mobile.d.mts +6 -0
- package/dist/hooks/use-mobile.mjs +45 -0
- package/dist/hooks/use-mobile.mjs.map +1 -0
- package/dist/hooks/use-responsive.d.mts +13 -0
- package/dist/hooks/use-responsive.mjs +50 -0
- package/dist/hooks/use-responsive.mjs.map +1 -0
- package/dist/hooks/use-scroll-progress.d.mts +17 -0
- package/dist/hooks/use-scroll-progress.mjs +62 -0
- package/dist/hooks/use-scroll-progress.mjs.map +1 -0
- package/dist/hooks/use-toast.d.mts +21 -0
- package/dist/hooks/use-toast.mjs +40 -0
- package/dist/hooks/use-toast.mjs.map +1 -0
- package/dist/hover-card-BqEpbXMp.d.mts +31 -0
- package/dist/hover-card-nn4fjJOh.mjs +161 -0
- package/dist/hover-card-nn4fjJOh.mjs.map +1 -0
- package/dist/index-AwyfWaOP.d.mts +60 -0
- package/dist/index.d.mts +503 -0
- package/dist/index.mjs +2158 -0
- package/dist/index.mjs.map +1 -0
- package/dist/input-CT1C9DMs.d.mts +19 -0
- package/dist/input-D0T5jbR6.d.mts +19 -0
- package/dist/input-DhpkXN3J.mjs +176 -0
- package/dist/input-DhpkXN3J.mjs.map +1 -0
- package/dist/input-group-CTBpkGI9.mjs +231 -0
- package/dist/input-group-CTBpkGI9.mjs.map +1 -0
- package/dist/input-group-DcDPUaQ3.d.mts +20 -0
- package/dist/input-group-VSZJM_on.d.mts +20 -0
- package/dist/integrations-COjiOhkd.d.mts +60 -0
- package/dist/integrations-Doz6nfxm.d.mts +60 -0
- package/dist/integrations-lBG309ZD.mjs +471 -0
- package/dist/integrations-lBG309ZD.mjs.map +1 -0
- package/dist/label-DnUThLUR.mjs +148 -0
- package/dist/label-DnUThLUR.mjs.map +1 -0
- package/dist/lib/export-csv.d.mts +12 -0
- package/dist/lib/export-csv.mjs +63 -0
- package/dist/lib/export-csv.mjs.map +1 -0
- package/dist/lib/index.d.mts +6 -0
- package/dist/lib/index.mjs +7 -0
- package/dist/lib/resize-image.d.mts +11 -0
- package/dist/lib/resize-image.mjs +66 -0
- package/dist/lib/resize-image.mjs.map +1 -0
- package/dist/lib/stable-sort.d.mts +6 -0
- package/dist/lib/stable-sort.mjs +33 -0
- package/dist/lib/stable-sort.mjs.map +1 -0
- package/dist/lib/utils.d.mts +8 -0
- package/dist/lib/utils.mjs +4 -0
- package/dist/lib-utils.mjs +4 -0
- package/dist/loader-B2SF0yPJ.mjs +168 -0
- package/dist/loader-B2SF0yPJ.mjs.map +1 -0
- package/dist/loading-dots-DJfxDgv3.mjs +119 -0
- package/dist/loading-dots-DJfxDgv3.mjs.map +1 -0
- package/dist/loading-dots-DvR1lwC-.d.mts +11 -0
- package/dist/mini-area-chart-GIUU-ZLo.d.mts +30 -0
- package/dist/mini-area-chart-s5ItHBk8.mjs +225 -0
- package/dist/mini-area-chart-s5ItHBk8.mjs.map +1 -0
- package/dist/motion-DLlwbMJ0.d.mts +33 -0
- package/dist/motion-zelaDelJ.mjs +47 -0
- package/dist/motion-zelaDelJ.mjs.map +1 -0
- package/dist/nav-app-switcher-B1NTlYrm.d.mts +43 -0
- package/dist/nav-app-switcher-V7aJAC18.mjs +235 -0
- package/dist/nav-app-switcher-V7aJAC18.mjs.map +1 -0
- package/dist/nav-main-BscfzNoi.mjs +105 -0
- package/dist/nav-main-BscfzNoi.mjs.map +1 -0
- package/dist/nav-secondary-t-xeA0I4.mjs +51 -0
- package/dist/nav-secondary-t-xeA0I4.mjs.map +1 -0
- package/dist/nav-user-A4YHm3-O.mjs +193 -0
- package/dist/nav-user-A4YHm3-O.mjs.map +1 -0
- package/dist/node-BKXOPjw9.d.mts +100 -0
- package/dist/node-CdmDD4k-.mjs +116 -0
- package/dist/node-CdmDD4k-.mjs.map +1 -0
- package/dist/oneapp-CfwhNatF.mjs +322 -0
- package/dist/oneapp-CfwhNatF.mjs.map +1 -0
- package/dist/pagination-controls-CE3-eCxI.mjs +135 -0
- package/dist/pagination-controls-CE3-eCxI.mjs.map +1 -0
- package/dist/popover-DmWxl2lW.mjs +198 -0
- package/dist/popover-DmWxl2lW.mjs.map +1 -0
- package/dist/preview.d.mts +6 -0
- package/dist/progress-BWxdthl4.mjs +230 -0
- package/dist/progress-BWxdthl4.mjs.map +1 -0
- package/dist/prompt-input-SFJ9_lNw.mjs +1149 -0
- package/dist/prompt-input-SFJ9_lNw.mjs.map +1 -0
- package/dist/resizable--DaTse0W.mjs +124 -0
- package/dist/resizable--DaTse0W.mjs.map +1 -0
- package/dist/scroll-area-Bxi-Edjc.mjs +139 -0
- package/dist/scroll-area-Bxi-Edjc.mjs.map +1 -0
- package/dist/scroll-area-CDRGG59G.d.mts +19 -0
- package/dist/select-DI6PzHN3.mjs +411 -0
- package/dist/select-DI6PzHN3.mjs.map +1 -0
- package/dist/select-csqviwUw.d.mts +44 -0
- package/dist/separator-BG9BqZqg.d.mts +20 -0
- package/dist/separator-CNQqqwfO.d.mts +20 -0
- package/dist/separator-veJJBul5.mjs +118 -0
- package/dist/separator-veJJBul5.mjs.map +1 -0
- package/dist/shared-BqVcofZN.d.mts +91 -0
- package/dist/shared-auth.d.mts +5 -0
- package/dist/shared-auth.mjs +6 -0
- package/dist/shimmer-BLRAD4VL.mjs +102 -0
- package/dist/shimmer-BLRAD4VL.mjs.map +1 -0
- package/dist/sidebar-CPteoqnB.d.mts +163 -0
- package/dist/sidebar-CdWE7H3R.mjs +814 -0
- package/dist/sidebar-CdWE7H3R.mjs.map +1 -0
- package/dist/sidebar-DYgXCHqQ.d.mts +163 -0
- package/dist/sidebar-inset-header-portal-CIRN-lKw.mjs +153 -0
- package/dist/sidebar-inset-header-portal-CIRN-lKw.mjs.map +1 -0
- package/dist/sidebar-inset-header-portal-DjfK7xCt.d.mts +24 -0
- package/dist/sidebar-slots-DNCEnx5L.mjs +135 -0
- package/dist/sidebar-slots-DNCEnx5L.mjs.map +1 -0
- package/dist/sidebar-slots-OqNmzlIk.d.mts +47 -0
- package/dist/skeleton-ByXUFNDF.d.mts +35 -0
- package/dist/skeleton-aXwA3YID.mjs +211 -0
- package/dist/skeleton-aXwA3YID.mjs.map +1 -0
- package/dist/sources.css +16 -0
- package/dist/storybook-preview.mjs +184 -0
- package/dist/storybook-preview.mjs.map +1 -0
- package/dist/styles/colors.css +166 -0
- package/dist/styles/index.css +2 -0
- package/dist/styles/mantine.css +1024 -0
- package/dist/styles/spacing.css +62 -0
- package/dist/styles/theme.css +1687 -0
- package/dist/styles/typography.css +59 -0
- package/dist/styles/variables.css +998 -0
- package/dist/styles.css +1 -0
- package/dist/switch-BFct1r4a.mjs +223 -0
- package/dist/switch-BFct1r4a.mjs.map +1 -0
- package/dist/table-DNkLM1TB.mjs +261 -0
- package/dist/table-DNkLM1TB.mjs.map +1 -0
- package/dist/textarea-MpLFc9sB.mjs +173 -0
- package/dist/textarea-MpLFc9sB.mjs.map +1 -0
- package/dist/theme-provider-4D34sBmG.mjs +83 -0
- package/dist/theme-provider-4D34sBmG.mjs.map +1 -0
- package/dist/time-series-chart-B66xH88w.d.mts +69 -0
- package/dist/time-series-chart-DxnknDhW.mjs +400 -0
- package/dist/time-series-chart-DxnknDhW.mjs.map +1 -0
- package/dist/tokens/tokens.dtcg.json +4353 -0
- package/dist/tokens/tokens.json +895 -0
- package/dist/tokens-mantine-types.d.mts +3 -0
- package/dist/tokens-mantine-types.mjs +4 -0
- package/dist/tokens.css +2 -0
- package/dist/tokens.d.mts +9398 -0
- package/dist/tokens.mjs +9311 -0
- package/dist/tokens.mjs.map +1 -0
- package/dist/tooltip-B8_zKnHC.mjs +301 -0
- package/dist/tooltip-B8_zKnHC.mjs.map +1 -0
- package/dist/tooltip-BA27ygge.d.mts +44 -0
- package/dist/tooltip-FqB3srL-.d.mts +44 -0
- package/dist/tooltip-sync-Ax1GmpjC.d.mts +17 -0
- package/dist/tooltip-sync-DzJUgiTM.mjs +85 -0
- package/dist/tooltip-sync-DzJUgiTM.mjs.map +1 -0
- package/dist/types-B8z57DW2.d.mts +41 -0
- package/dist/use-artifact-panel-state-CUQTn2Uq.mjs +346 -0
- package/dist/use-artifact-panel-state-CUQTn2Uq.mjs.map +1 -0
- package/dist/use-artifact-panel-state-DPZC--sz.d.mts +150 -0
- package/dist/utils-BJGrUJ6T.mjs +77 -0
- package/dist/utils-BJGrUJ6T.mjs.map +1 -0
- package/dist/utils-D2bGp2p_.mjs +33 -0
- package/dist/utils-D2bGp2p_.mjs.map +1 -0
- package/dist/x-axis-BY00htJY.mjs +137 -0
- package/dist/x-axis-BY00htJY.mjs.map +1 -0
- package/dist/x-axis-Dh66iD8l.d.mts +21 -0
- package/dist/y-axis-DgHlVHRG.mjs +118 -0
- package/dist/y-axis-DgHlVHRG.mjs.map +1 -0
- package/dist/y-axis-DocBbrSp.d.mts +23 -0
- package/dist/z-index-BlBlZL-F.d.mts +10775 -0
- package/package.json +429 -0
- package/src/ai-oneapp/flow-chat/index.ts +3 -0
- package/src/ai-oneapp/flow-chat/node-suggestion-card.tsx +37 -0
- package/src/ai-oneapp/flow-chat/template-suggestion-card.tsx +49 -0
- package/src/ai-oneapp/flow-chat/workflow-action-toast.tsx +55 -0
- package/src/components/.gitkeep +0 -0
- package/src/components/ai-elements/__tests__/test-utils.tsx +12 -0
- package/src/components/ai-elements/actions/actions.stories.tsx +288 -0
- package/src/components/ai-elements/actions/actions.test.tsx +60 -0
- package/src/components/ai-elements/actions/actions.tsx +286 -0
- package/src/components/ai-elements/actions/index.ts +7 -0
- package/src/components/ai-elements/agent-step/agent-step.stories.tsx +167 -0
- package/src/components/ai-elements/agent-step/agent-step.tsx +206 -0
- package/src/components/ai-elements/agent-step/index.ts +7 -0
- package/src/components/ai-elements/ai-elements.constants.ts +516 -0
- package/src/components/ai-elements/artifact/artifact.stories.tsx +199 -0
- package/src/components/ai-elements/artifact/artifact.tsx +277 -0
- package/src/components/ai-elements/artifact/index.ts +7 -0
- package/src/components/ai-elements/branch/branch.stories.tsx +212 -0
- package/src/components/ai-elements/branch/branch.test.tsx +148 -0
- package/src/components/ai-elements/branch/branch.tsx +502 -0
- package/src/components/ai-elements/branch/index.ts +7 -0
- package/src/components/ai-elements/chain-of-thought/chain-of-thought.stories.tsx +172 -0
- package/src/components/ai-elements/chain-of-thought/chain-of-thought.tsx +505 -0
- package/src/components/ai-elements/chain-of-thought/index.ts +7 -0
- package/src/components/ai-elements/chat-input/chat-input.stories.tsx +185 -0
- package/src/components/ai-elements/chat-input/chat-input.tsx +201 -0
- package/src/components/ai-elements/chat-input/index.ts +7 -0
- package/src/components/ai-elements/checkpoint/checkpoint.stories.tsx +171 -0
- package/src/components/ai-elements/checkpoint/checkpoint.tsx +256 -0
- package/src/components/ai-elements/checkpoint/index.ts +7 -0
- package/src/components/ai-elements/code-block/code-block.stories.tsx +317 -0
- package/src/components/ai-elements/code-block/code-block.tsx +366 -0
- package/src/components/ai-elements/code-block/index.ts +7 -0
- package/src/components/ai-elements/confirmation/confirmation.stories.tsx +236 -0
- package/src/components/ai-elements/confirmation/confirmation.tsx +465 -0
- package/src/components/ai-elements/confirmation/index.ts +7 -0
- package/src/components/ai-elements/context/context.stories.tsx +80 -0
- package/src/components/ai-elements/context/context.tsx +585 -0
- package/src/components/ai-elements/context/index.ts +7 -0
- package/src/components/ai-elements/conversation/__tests__/conversation.test.tsx +402 -0
- package/src/components/ai-elements/conversation/conversation.stories.tsx +1019 -0
- package/src/components/ai-elements/conversation/conversation.tsx +260 -0
- package/src/components/ai-elements/conversation/index.ts +7 -0
- package/src/components/ai-elements/custom/__tests__/accessibility.test.tsx +27 -0
- package/src/components/ai-elements/custom/__tests__/chat-container.test.tsx +30 -0
- package/src/components/ai-elements/custom/__tests__/conversation-history.test.tsx +100 -0
- package/src/components/ai-elements/custom/__tests__/export-dropdown.test.tsx +60 -0
- package/src/components/ai-elements/custom/ai-label/ai-label.stories.tsx +86 -0
- package/src/components/ai-elements/custom/ai-label/ai-label.tsx +291 -0
- package/src/components/ai-elements/custom/ai-label/index.ts +7 -0
- package/src/components/ai-elements/custom/artifact-skeleton/artifact-skeleton.stories.tsx +155 -0
- package/src/components/ai-elements/custom/artifact-skeleton/artifact-skeleton.tsx +269 -0
- package/src/components/ai-elements/custom/artifact-skeleton/index.ts +18 -0
- package/src/components/ai-elements/custom/audio-player/audio-player.stories.tsx +50 -0
- package/src/components/ai-elements/custom/audio-player/audio-player.tsx +296 -0
- package/src/components/ai-elements/custom/audio-player/index.ts +1 -0
- package/src/components/ai-elements/custom/button-group/button-group.stories.tsx +108 -0
- package/src/components/ai-elements/custom/button-group/button-group.tsx +142 -0
- package/src/components/ai-elements/custom/button-group/index.ts +15 -0
- package/src/components/ai-elements/custom/chat-container/chat-container.stories.tsx +143 -0
- package/src/components/ai-elements/custom/chat-container/chat-container.tsx +406 -0
- package/src/components/ai-elements/custom/chat-container/index.ts +9 -0
- package/src/components/ai-elements/custom/collapsible/collapsible.stories.tsx +130 -0
- package/src/components/ai-elements/custom/collapsible/index.ts +11 -0
- package/src/components/ai-elements/custom/collapsible/use-collapsible.tsx +240 -0
- package/src/components/ai-elements/custom/collapsible-content/collapsible-content.stories.tsx +113 -0
- package/src/components/ai-elements/custom/collapsible-content/collapsible-content.tsx +141 -0
- package/src/components/ai-elements/custom/collapsible-content/index.ts +7 -0
- package/src/components/ai-elements/custom/content-placeholder/content-placeholder.stories.tsx +82 -0
- package/src/components/ai-elements/custom/content-placeholder/content-placeholder.tsx +319 -0
- package/src/components/ai-elements/custom/content-placeholder/index.ts +10 -0
- package/src/components/ai-elements/custom/conversation-header/conversation-header.stories.tsx +102 -0
- package/src/components/ai-elements/custom/conversation-header/conversation-header.tsx +202 -0
- package/src/components/ai-elements/custom/conversation-header/index.ts +12 -0
- package/src/components/ai-elements/custom/conversation-history/conversation-history.stories.tsx +191 -0
- package/src/components/ai-elements/custom/conversation-history/conversation-history.tsx +515 -0
- package/src/components/ai-elements/custom/conversation-history/index.ts +16 -0
- package/src/components/ai-elements/custom/diff-view/diff-view.stories.tsx +173 -0
- package/src/components/ai-elements/custom/diff-view/diff-view.tsx +261 -0
- package/src/components/ai-elements/custom/diff-view/index.ts +7 -0
- package/src/components/ai-elements/custom/draggable-tabs/draggable-tabs.stories.tsx +157 -0
- package/src/components/ai-elements/custom/draggable-tabs/draggable-tabs.tsx +311 -0
- package/src/components/ai-elements/custom/draggable-tabs/index.ts +7 -0
- package/src/components/ai-elements/custom/export-conversation/export-conversation.stories.tsx +73 -0
- package/src/components/ai-elements/custom/export-conversation/export-conversation.tsx +405 -0
- package/src/components/ai-elements/custom/export-conversation/index.ts +10 -0
- package/src/components/ai-elements/custom/export-dropdown/export-dropdown.stories.tsx +121 -0
- package/src/components/ai-elements/custom/export-dropdown/export-dropdown.tsx +315 -0
- package/src/components/ai-elements/custom/export-dropdown/index.ts +11 -0
- package/src/components/ai-elements/custom/feedback/feedback.stories.tsx +85 -0
- package/src/components/ai-elements/custom/feedback/feedback.tsx +425 -0
- package/src/components/ai-elements/custom/feedback/index.ts +13 -0
- package/src/components/ai-elements/custom/file-card/file-card.stories.tsx +65 -0
- package/src/components/ai-elements/custom/file-card/file-card.tsx +249 -0
- package/src/components/ai-elements/custom/file-card/index.ts +1 -0
- package/src/components/ai-elements/custom/file-tree/file-tree.stories.tsx +96 -0
- package/src/components/ai-elements/custom/file-tree/file-tree.tsx +266 -0
- package/src/components/ai-elements/custom/file-tree/index.ts +7 -0
- package/src/components/ai-elements/custom/index.ts +73 -0
- package/src/components/ai-elements/custom/keyboard-shortcut/index.ts +14 -0
- package/src/components/ai-elements/custom/keyboard-shortcut/keyboard-shortcut.stories.tsx +118 -0
- package/src/components/ai-elements/custom/keyboard-shortcut/keyboard-shortcut.tsx +292 -0
- package/src/components/ai-elements/custom/message-edit/index.ts +1 -0
- package/src/components/ai-elements/custom/message-edit/message-edit.stories.tsx +88 -0
- package/src/components/ai-elements/custom/message-edit/message-edit.tsx +225 -0
- package/src/components/ai-elements/custom/message-error/index.ts +7 -0
- package/src/components/ai-elements/custom/message-error/message-error.stories.tsx +85 -0
- package/src/components/ai-elements/custom/message-error/message-error.tsx +301 -0
- package/src/components/ai-elements/custom/message-group/index.ts +1 -0
- package/src/components/ai-elements/custom/message-group/message-group.stories.tsx +82 -0
- package/src/components/ai-elements/custom/message-group/message-group.tsx +77 -0
- package/src/components/ai-elements/custom/message-separator/index.ts +1 -0
- package/src/components/ai-elements/custom/message-separator/message-separator.stories.tsx +65 -0
- package/src/components/ai-elements/custom/message-separator/message-separator.tsx +132 -0
- package/src/components/ai-elements/custom/scroll-to-bottom/index.ts +11 -0
- package/src/components/ai-elements/custom/scroll-to-bottom/scroll-to-bottom.stories.tsx +116 -0
- package/src/components/ai-elements/custom/scroll-to-bottom/use-scroll-to-bottom.tsx +215 -0
- package/src/components/ai-elements/custom/snippet/index.ts +1 -0
- package/src/components/ai-elements/custom/snippet/snippet.stories.tsx +59 -0
- package/src/components/ai-elements/custom/snippet/snippet.tsx +158 -0
- package/src/components/ai-elements/custom/stack-trace/index.ts +1 -0
- package/src/components/ai-elements/custom/stack-trace/stack-trace.stories.tsx +112 -0
- package/src/components/ai-elements/custom/stack-trace/stack-trace.tsx +368 -0
- package/src/components/ai-elements/custom/terminal/index.ts +9 -0
- package/src/components/ai-elements/custom/terminal/terminal.stories.tsx +92 -0
- package/src/components/ai-elements/custom/terminal/terminal.tsx +233 -0
- package/src/components/ai-elements/custom/test-results/test-results.tsx +438 -0
- package/src/components/ai-elements/custom/thought-chain/index.ts +7 -0
- package/src/components/ai-elements/custom/thought-chain/thought-chain.stories.tsx +123 -0
- package/src/components/ai-elements/custom/thought-chain/thought-chain.tsx +246 -0
- package/src/components/ai-elements/custom/token-usage/index.ts +6 -0
- package/src/components/ai-elements/custom/token-usage/token-usage.stories.tsx +104 -0
- package/src/components/ai-elements/custom/token-usage/token-usage.tsx +236 -0
- package/src/components/ai-elements/custom/transcription/index.ts +1 -0
- package/src/components/ai-elements/custom/transcription/transcription.stories.tsx +80 -0
- package/src/components/ai-elements/custom/transcription/transcription.tsx +163 -0
- package/src/components/ai-elements/custom/typing-indicator/index.ts +1 -0
- package/src/components/ai-elements/custom/typing-indicator/typing-indicator.stories.tsx +71 -0
- package/src/components/ai-elements/custom/typing-indicator/typing-indicator.tsx +126 -0
- package/src/components/ai-elements/custom/undo-redo/index.ts +12 -0
- package/src/components/ai-elements/custom/undo-redo/undo-redo.stories.tsx +145 -0
- package/src/components/ai-elements/custom/undo-redo/use-undo-redo.tsx +324 -0
- package/src/components/ai-elements/custom/voice-selector/index.ts +7 -0
- package/src/components/ai-elements/custom/voice-selector/voice-selector.stories.tsx +67 -0
- package/src/components/ai-elements/custom/voice-selector/voice-selector.tsx +301 -0
- package/src/components/ai-elements/custom/welcome/index.ts +1 -0
- package/src/components/ai-elements/custom/welcome/welcome.stories.tsx +92 -0
- package/src/components/ai-elements/custom/welcome/welcome.tsx +213 -0
- package/src/components/ai-elements/generative-ui/generative-ui-renderer.stories.tsx +451 -0
- package/src/components/ai-elements/generative-ui/generative-ui-renderer.test.tsx +383 -0
- package/src/components/ai-elements/generative-ui/generative-ui-renderer.tsx +668 -0
- package/src/components/ai-elements/generative-ui/index.ts +21 -0
- package/src/components/ai-elements/image/image.stories.tsx +179 -0
- package/src/components/ai-elements/image/image.tsx +178 -0
- package/src/components/ai-elements/image/index.ts +7 -0
- package/src/components/ai-elements/index.ts +195 -0
- package/src/components/ai-elements/inline-citation/index.ts +7 -0
- package/src/components/ai-elements/inline-citation/inline-citation.stories.tsx +331 -0
- package/src/components/ai-elements/inline-citation/inline-citation.tsx +595 -0
- package/src/components/ai-elements/loader/index.ts +7 -0
- package/src/components/ai-elements/loader/loader.stories.tsx +185 -0
- package/src/components/ai-elements/loader/loader.tsx +177 -0
- package/src/components/ai-elements/message/__tests__/message.test.tsx +352 -0
- package/src/components/ai-elements/message/index.ts +7 -0
- package/src/components/ai-elements/message/message-actions.test.tsx +51 -0
- package/src/components/ai-elements/message/message.stories.tsx +609 -0
- package/src/components/ai-elements/message/message.test.tsx +52 -0
- package/src/components/ai-elements/message/message.tsx +1125 -0
- package/src/components/ai-elements/message/response.test.tsx +18 -0
- package/src/components/ai-elements/model-selector/index.ts +7 -0
- package/src/components/ai-elements/model-selector/model-selector.stories.tsx +198 -0
- package/src/components/ai-elements/model-selector/model-selector.tsx +406 -0
- package/src/components/ai-elements/modernization_walkthrough.md +51 -0
- package/src/components/ai-elements/open-in-chat/index.ts +7 -0
- package/src/components/ai-elements/open-in-chat/open-in-chat.stories.tsx +221 -0
- package/src/components/ai-elements/open-in-chat/open-in-chat.tsx +606 -0
- package/src/components/ai-elements/plan/index.ts +7 -0
- package/src/components/ai-elements/plan/plan.stories.tsx +233 -0
- package/src/components/ai-elements/plan/plan.tsx +337 -0
- package/src/components/ai-elements/prompt-char-counter/index.ts +7 -0
- package/src/components/ai-elements/prompt-char-counter/prompt-char-counter.stories.tsx +98 -0
- package/src/components/ai-elements/prompt-char-counter/prompt-char-counter.tsx +159 -0
- package/src/components/ai-elements/prompt-input/index.ts +7 -0
- package/src/components/ai-elements/prompt-input/prompt-input.stories.tsx +548 -0
- package/src/components/ai-elements/prompt-input/prompt-input.test.tsx +22 -0
- package/src/components/ai-elements/prompt-input/prompt-input.tsx +2112 -0
- package/src/components/ai-elements/queue/index.ts +7 -0
- package/src/components/ai-elements/queue/queue.stories.tsx +249 -0
- package/src/components/ai-elements/queue/queue.tsx +456 -0
- package/src/components/ai-elements/reasoning/index.ts +7 -0
- package/src/components/ai-elements/reasoning/reasoning.stories.tsx +147 -0
- package/src/components/ai-elements/reasoning/reasoning.tsx +356 -0
- package/src/components/ai-elements/shimmer/index.ts +7 -0
- package/src/components/ai-elements/shimmer/shimmer.stories.tsx +240 -0
- package/src/components/ai-elements/shimmer/shimmer.tsx +150 -0
- package/src/components/ai-elements/sources/index.ts +7 -0
- package/src/components/ai-elements/sources/sources.stories.tsx +259 -0
- package/src/components/ai-elements/sources/sources.test.tsx +40 -0
- package/src/components/ai-elements/sources/sources.tsx +327 -0
- package/src/components/ai-elements/suggestion/index.ts +7 -0
- package/src/components/ai-elements/suggestion/suggestion.stories.tsx +207 -0
- package/src/components/ai-elements/suggestion/suggestion.tsx +229 -0
- package/src/components/ai-elements/task/index.ts +7 -0
- package/src/components/ai-elements/task/task.stories.tsx +213 -0
- package/src/components/ai-elements/task/task.tsx +356 -0
- package/src/components/ai-elements/test-utils.tsx +28 -0
- package/src/components/ai-elements/tool/index.ts +7 -0
- package/src/components/ai-elements/tool/tool.stories.tsx +195 -0
- package/src/components/ai-elements/tool/tool.test.tsx +160 -0
- package/src/components/ai-elements/tool/tool.tsx +537 -0
- package/src/components/ai-elements/tool-approval/index.ts +7 -0
- package/src/components/ai-elements/tool-approval/tool-approval.stories.tsx +260 -0
- package/src/components/ai-elements/tool-approval/tool-approval.tsx +423 -0
- package/src/components/ai-elements/vitest.config.ts +17 -0
- package/src/components/ai-elements/vitest.setup.ts +6 -0
- package/src/components/ai-elements/web-preview/index.ts +7 -0
- package/src/components/ai-elements/web-preview/web-preview.stories.tsx +202 -0
- package/src/components/ai-elements/web-preview/web-preview.tsx +1166 -0
- package/src/components/ai-workflows/canvas/canvas.stories.tsx +120 -0
- package/src/components/ai-workflows/canvas/canvas.tsx +173 -0
- package/src/components/ai-workflows/canvas/index.ts +7 -0
- package/src/components/ai-workflows/connection/connection.stories.tsx +66 -0
- package/src/components/ai-workflows/connection/connection.tsx +119 -0
- package/src/components/ai-workflows/connection/index.ts +7 -0
- package/src/components/ai-workflows/controls/controls.stories.tsx +72 -0
- package/src/components/ai-workflows/controls/controls.tsx +132 -0
- package/src/components/ai-workflows/controls/index.ts +7 -0
- package/src/components/ai-workflows/edge/edge.stories.tsx +120 -0
- package/src/components/ai-workflows/edge/edge.test.tsx +47 -0
- package/src/components/ai-workflows/edge/edge.tsx +136 -0
- package/src/components/ai-workflows/edge/index.ts +7 -0
- package/src/components/ai-workflows/flow-constants.ts +11 -0
- package/src/components/ai-workflows/node/index.ts +7 -0
- package/src/components/ai-workflows/node/node.stories.tsx +111 -0
- package/src/components/ai-workflows/node/node.tsx +227 -0
- package/src/components/ai-workflows/panel/index.ts +7 -0
- package/src/components/ai-workflows/panel/panel.stories.tsx +102 -0
- package/src/components/ai-workflows/panel/panel.tsx +106 -0
- package/src/components/ai-workflows/resizable-node/index.ts +7 -0
- package/src/components/ai-workflows/resizable-node/resizable-node.stories.tsx +93 -0
- package/src/components/ai-workflows/resizable-node/resizable-node.tsx +228 -0
- package/src/components/ai-workflows/toolbar/index.ts +7 -0
- package/src/components/ai-workflows/toolbar/toolbar.stories.tsx +99 -0
- package/src/components/ai-workflows/toolbar/toolbar.tsx +130 -0
- package/src/components/auth/client/index.ts +12 -0
- package/src/components/auth/client/nav-user/auth-nav-user.tsx +237 -0
- package/src/components/auth/client/nav-user/index.ts +11 -0
- package/src/components/auth/client/providers/ThemeProvider.stories.tsx +59 -0
- package/src/components/auth/client/providers/ThemeProvider.tsx +39 -0
- package/src/components/auth/client/providers/index.ts +7 -0
- package/src/components/auth/client/providers.tsx +129 -0
- package/src/components/auth/index.ts +14 -0
- package/src/components/auth/server/account/ProfileForm.stories.tsx +105 -0
- package/src/components/auth/server/account/ProfileForm.tsx +236 -0
- package/src/components/auth/server/account/index.ts +7 -0
- package/src/components/auth/server/actions/index.ts +11 -0
- package/src/components/auth/server/actions.ts +88 -0
- package/src/components/auth/server/admin/AdminBulkUserActions.stories.tsx +129 -0
- package/src/components/auth/server/admin/AdminBulkUserActions.tsx +649 -0
- package/src/components/auth/server/admin/AdminDashboard.stories.tsx +215 -0
- package/src/components/auth/server/admin/AdminDashboard.tsx +785 -0
- package/src/components/auth/server/admin/AdminDevicesManager.tsx +411 -0
- package/src/components/auth/server/admin/AdminImpersonation.stories.tsx +121 -0
- package/src/components/auth/server/admin/AdminImpersonation.tsx +569 -0
- package/src/components/auth/server/admin/AdminPasskeysManager.tsx +393 -0
- package/src/components/auth/server/admin/AdminSecurityEventsViewer.tsx +395 -0
- package/src/components/auth/server/admin/AdminServiceAccountsManager.tsx +454 -0
- package/src/components/auth/server/admin/AdminSessionsManager.tsx +664 -0
- package/src/components/auth/server/admin/AdminTwoFactorManager.tsx +431 -0
- package/src/components/auth/server/admin/AdminUserCreation.stories.tsx +87 -0
- package/src/components/auth/server/admin/AdminUserCreation.tsx +777 -0
- package/src/components/auth/server/admin/AdminUserDetail.stories.tsx +178 -0
- package/src/components/auth/server/admin/AdminUserDetail.tsx +1044 -0
- package/src/components/auth/server/admin/AdminUsersList.stories.tsx +228 -0
- package/src/components/auth/server/admin/AdminUsersList.tsx +859 -0
- package/src/components/auth/server/admin/index.ts +59 -0
- package/src/components/auth/server/advanced/PasskeySetup.stories.tsx +70 -0
- package/src/components/auth/server/advanced/PasskeySetup.tsx +383 -0
- package/src/components/auth/server/advanced/TwoFactorSetup.stories.tsx +79 -0
- package/src/components/auth/server/advanced/TwoFactorSetup.tsx +459 -0
- package/src/components/auth/server/advanced/TwoFactorVerify.stories.tsx +69 -0
- package/src/components/auth/server/advanced/TwoFactorVerify.tsx +323 -0
- package/src/components/auth/server/advanced/index.ts +10 -0
- package/src/components/auth/server/api-keys/APIKeysList.stories.tsx +95 -0
- package/src/components/auth/server/api-keys/APIKeysList.tsx +470 -0
- package/src/components/auth/server/api-keys/CreateAPIKeyForm.stories.tsx +79 -0
- package/src/components/auth/server/api-keys/CreateAPIKeyForm.tsx +501 -0
- package/src/components/auth/server/api-keys/index.ts +9 -0
- package/src/components/auth/server/enhanced/AccountDeletionFlow.stories.tsx +115 -0
- package/src/components/auth/server/enhanced/AccountDeletionFlow.tsx +733 -0
- package/src/components/auth/server/enhanced/AnonymousSessionCreator.stories.tsx +80 -0
- package/src/components/auth/server/enhanced/AnonymousSessionCreator.tsx +398 -0
- package/src/components/auth/server/enhanced/AnonymousToAccountConverter.stories.tsx +61 -0
- package/src/components/auth/server/enhanced/AnonymousToAccountConverter.tsx +538 -0
- package/src/components/auth/server/enhanced/BackupCodesManager.stories.tsx +108 -0
- package/src/components/auth/server/enhanced/BackupCodesManager.tsx +718 -0
- package/src/components/auth/server/enhanced/BearerTokenGenerator.stories.tsx +85 -0
- package/src/components/auth/server/enhanced/BearerTokenGenerator.tsx +618 -0
- package/src/components/auth/server/enhanced/ChangePasswordForm.stories.tsx +108 -0
- package/src/components/auth/server/enhanced/ChangePasswordForm.tsx +313 -0
- package/src/components/auth/server/enhanced/DataExportRequest.stories.tsx +84 -0
- package/src/components/auth/server/enhanced/DataExportRequest.tsx +734 -0
- package/src/components/auth/server/enhanced/DeviceManagement.stories.tsx +161 -0
- package/src/components/auth/server/enhanced/DeviceManagement.tsx +700 -0
- package/src/components/auth/server/enhanced/EmailChangeVerification.stories.tsx +94 -0
- package/src/components/auth/server/enhanced/EmailChangeVerification.tsx +421 -0
- package/src/components/auth/server/enhanced/EmailOTPSignIn.stories.tsx +68 -0
- package/src/components/auth/server/enhanced/EmailOTPSignIn.tsx +516 -0
- package/src/components/auth/server/enhanced/EmailOTPVerification.stories.tsx +95 -0
- package/src/components/auth/server/enhanced/EmailOTPVerification.tsx +610 -0
- package/src/components/auth/server/enhanced/EmailVerificationRequest.stories.tsx +97 -0
- package/src/components/auth/server/enhanced/EmailVerificationRequest.tsx +461 -0
- package/src/components/auth/server/enhanced/EmailVerificationStatus.stories.tsx +96 -0
- package/src/components/auth/server/enhanced/EmailVerificationStatus.tsx +631 -0
- package/src/components/auth/server/enhanced/MagicLinkRequestForm.stories.tsx +88 -0
- package/src/components/auth/server/enhanced/MagicLinkRequestForm.tsx +439 -0
- package/src/components/auth/server/enhanced/MagicLinkStatusIndicator.stories.tsx +101 -0
- package/src/components/auth/server/enhanced/MagicLinkStatusIndicator.tsx +610 -0
- package/src/components/auth/server/enhanced/MultiSessionDashboard.stories.tsx +101 -0
- package/src/components/auth/server/enhanced/MultiSessionDashboard.tsx +996 -0
- package/src/components/auth/server/enhanced/OrganizationAuditLog.stories.tsx +86 -0
- package/src/components/auth/server/enhanced/OrganizationAuditLog.tsx +1006 -0
- package/src/components/auth/server/enhanced/PasskeyManagement.stories.tsx +102 -0
- package/src/components/auth/server/enhanced/PasskeyManagement.tsx +705 -0
- package/src/components/auth/server/enhanced/PasskeyRegistrationWizard.stories.tsx +83 -0
- package/src/components/auth/server/enhanced/PasskeyRegistrationWizard.tsx +566 -0
- package/src/components/auth/server/enhanced/PasskeySignInInterface.stories.tsx +90 -0
- package/src/components/auth/server/enhanced/PasskeySignInInterface.tsx +792 -0
- package/src/components/auth/server/enhanced/PasswordStrengthIndicator.stories.tsx +129 -0
- package/src/components/auth/server/enhanced/PasswordStrengthIndicator.tsx +539 -0
- package/src/components/auth/server/enhanced/PhoneNumberManagement.stories.tsx +103 -0
- package/src/components/auth/server/enhanced/PhoneNumberManagement.tsx +594 -0
- package/src/components/auth/server/enhanced/PhoneNumberSetupForm.stories.tsx +91 -0
- package/src/components/auth/server/enhanced/PhoneNumberSetupForm.tsx +518 -0
- package/src/components/auth/server/enhanced/PhoneSignInForm.stories.tsx +63 -0
- package/src/components/auth/server/enhanced/PhoneSignInForm.tsx +801 -0
- package/src/components/auth/server/enhanced/PhoneSignInWithSMS.stories.tsx +87 -0
- package/src/components/auth/server/enhanced/PhoneSignInWithSMS.tsx +886 -0
- package/src/components/auth/server/enhanced/PhoneVerificationForm.stories.tsx +81 -0
- package/src/components/auth/server/enhanced/PhoneVerificationForm.tsx +306 -0
- package/src/components/auth/server/enhanced/ResendVerificationEmail.stories.tsx +84 -0
- package/src/components/auth/server/enhanced/ResendVerificationEmail.tsx +407 -0
- package/src/components/auth/server/enhanced/SMSVerificationForm.stories.tsx +92 -0
- package/src/components/auth/server/enhanced/SMSVerificationForm.tsx +521 -0
- package/src/components/auth/server/enhanced/SecurityEventLog.stories.tsx +115 -0
- package/src/components/auth/server/enhanced/SecurityEventLog.tsx +916 -0
- package/src/components/auth/server/enhanced/TeamCreationWizard.stories.tsx +85 -0
- package/src/components/auth/server/enhanced/TeamCreationWizard.tsx +1023 -0
- package/src/components/auth/server/enhanced/__tests__/actions.test.ts +388 -0
- package/src/components/auth/server/enhanced/__tests__/more-actions.test.ts +139 -0
- package/src/components/auth/server/enhanced/actions.ts +1199 -0
- package/src/components/auth/server/enhanced/auth-enhanced-actions.ts +936 -0
- package/src/components/auth/server/enhanced/index.ts +37 -0
- package/src/components/auth/server/forms/ForgotPasswordForm.stories.tsx +82 -0
- package/src/components/auth/server/forms/ForgotPasswordForm.tsx +287 -0
- package/src/components/auth/server/forms/ResetPasswordForm.stories.tsx +79 -0
- package/src/components/auth/server/forms/ResetPasswordForm.tsx +217 -0
- package/src/components/auth/server/forms/SignInForm.stories.tsx +113 -0
- package/src/components/auth/server/forms/SignInForm.tsx +211 -0
- package/src/components/auth/server/forms/SignUpForm.stories.tsx +130 -0
- package/src/components/auth/server/forms/SignUpForm.tsx +243 -0
- package/src/components/auth/server/forms/index.ts +10 -0
- package/src/components/auth/server/index.ts +22 -0
- package/src/components/auth/server/jwt/JWTTokenManager.tsx +315 -0
- package/src/components/auth/server/jwt/index.ts +7 -0
- package/src/components/auth/server/organization/AuditLogViewer.tsx +288 -0
- package/src/components/auth/server/organization/CreateRoleDialog.tsx +540 -0
- package/src/components/auth/server/organization/EditRoleDialog.tsx +487 -0
- package/src/components/auth/server/organization/InviteMembers.stories.tsx +82 -0
- package/src/components/auth/server/organization/InviteMembers.tsx +264 -0
- package/src/components/auth/server/organization/MembersList.stories.tsx +117 -0
- package/src/components/auth/server/organization/MembersList.tsx +425 -0
- package/src/components/auth/server/organization/OrganizationCreation.stories.tsx +99 -0
- package/src/components/auth/server/organization/OrganizationCreation.tsx +293 -0
- package/src/components/auth/server/organization/OrganizationSettings.stories.tsx +99 -0
- package/src/components/auth/server/organization/OrganizationSettings.tsx +494 -0
- package/src/components/auth/server/organization/OrganizationSwitcher.stories.tsx +98 -0
- package/src/components/auth/server/organization/OrganizationSwitcher.tsx +308 -0
- package/src/components/auth/server/organization/PermissionMatrix.tsx +366 -0
- package/src/components/auth/server/organization/RoleManagement.stories.tsx +120 -0
- package/src/components/auth/server/organization/RoleManagement.tsx +318 -0
- package/src/components/auth/server/organization/index.ts +16 -0
- package/src/components/auth/server/session/SessionsList.stories.tsx +81 -0
- package/src/components/auth/server/session/SessionsList.tsx +274 -0
- package/src/components/auth/server/session/index.ts +7 -0
- package/src/components/auth/server/social/SocialLoginButtons.stories.tsx +139 -0
- package/src/components/auth/server/social/SocialLoginButtons.tsx +292 -0
- package/src/components/auth/server/social/index.ts +7 -0
- package/src/components/auth/server/ui/Alert.stories.tsx +97 -0
- package/src/components/auth/server/ui/Alert.tsx +159 -0
- package/src/components/auth/server/ui/Button.stories.tsx +149 -0
- package/src/components/auth/server/ui/Button.tsx +221 -0
- package/src/components/auth/server/ui/Card.stories.tsx +80 -0
- package/src/components/auth/server/ui/Card.tsx +51 -0
- package/src/components/auth/server/ui/Input.stories.tsx +143 -0
- package/src/components/auth/server/ui/Input.tsx +195 -0
- package/src/components/auth/server/ui/index.ts +18 -0
- package/src/components/charts/areas/areas.stories.tsx +113 -0
- package/src/components/charts/areas/areas.tsx +185 -0
- package/src/components/charts/areas/index.ts +11 -0
- package/src/components/charts/bars/bars.stories.tsx +109 -0
- package/src/components/charts/bars/bars.tsx +164 -0
- package/src/components/charts/bars/index.ts +11 -0
- package/src/components/charts/chart-context.ts +35 -0
- package/src/components/charts/funnel-chart/funnel-chart.stories.tsx +111 -0
- package/src/components/charts/funnel-chart/funnel-chart.tsx +392 -0
- package/src/components/charts/funnel-chart/index.ts +11 -0
- package/src/components/charts/index.ts +45 -0
- package/src/components/charts/mini-area-chart/index.ts +11 -0
- package/src/components/charts/mini-area-chart/mini-area-chart.stories.tsx +100 -0
- package/src/components/charts/mini-area-chart/mini-area-chart.tsx +244 -0
- package/src/components/charts/time-series-chart/index.ts +11 -0
- package/src/components/charts/time-series-chart/time-series-chart.stories.tsx +140 -0
- package/src/components/charts/time-series-chart/time-series-chart.tsx +337 -0
- package/src/components/charts/tooltip-sync/index.ts +11 -0
- package/src/components/charts/tooltip-sync/tooltip-sync.stories.tsx +89 -0
- package/src/components/charts/tooltip-sync/tooltip-sync.tsx +91 -0
- package/src/components/charts/types.ts +93 -0
- package/src/components/charts/use-tooltip.ts +230 -0
- package/src/components/charts/utils.ts +69 -0
- package/src/components/charts/x-axis/index.ts +11 -0
- package/src/components/charts/x-axis/x-axis.stories.tsx +94 -0
- package/src/components/charts/x-axis/x-axis.tsx +176 -0
- package/src/components/charts/y-axis/index.ts +7 -0
- package/src/components/charts/y-axis/y-axis.stories.tsx +110 -0
- package/src/components/charts/y-axis/y-axis.tsx +139 -0
- package/src/components/elements/atoms/alert/alert.stories.tsx +234 -0
- package/src/components/elements/atoms/alert/alert.tsx +293 -0
- package/src/components/elements/atoms/alert/index.ts +7 -0
- package/src/components/elements/atoms/avatar/avatar.stories.tsx +174 -0
- package/src/components/elements/atoms/avatar/avatar.tsx +274 -0
- package/src/components/elements/atoms/avatar/index.ts +7 -0
- package/src/components/elements/atoms/badge/badge.stories.tsx +186 -0
- package/src/components/elements/atoms/badge/badge.tsx +333 -0
- package/src/components/elements/atoms/badge/index.ts +7 -0
- package/src/components/elements/atoms/blur-image/blur-image.stories.tsx +140 -0
- package/src/components/elements/atoms/blur-image/blur-image.tsx +102 -0
- package/src/components/elements/atoms/blur-image/index.ts +7 -0
- package/src/components/elements/atoms/button/button.stories.tsx +776 -0
- package/src/components/elements/atoms/button/button.tsx +878 -0
- package/src/components/elements/atoms/button/index.ts +7 -0
- package/src/components/elements/atoms/copy-button/copy-button.stories.tsx +162 -0
- package/src/components/elements/atoms/copy-button/copy-button.tsx +232 -0
- package/src/components/elements/atoms/copy-button/index.ts +7 -0
- package/src/components/elements/atoms/copy-text/copy-text.stories.tsx +128 -0
- package/src/components/elements/atoms/copy-text/copy-text.tsx +201 -0
- package/src/components/elements/atoms/copy-text/index.ts +7 -0
- package/src/components/elements/atoms/empty-state/empty-state.stories.tsx +410 -0
- package/src/components/elements/atoms/empty-state/empty-state.tsx +338 -0
- package/src/components/elements/atoms/empty-state/index.ts +1 -0
- package/src/components/elements/atoms/go-back-button/go-back-button.stories.tsx +83 -0
- package/src/components/elements/atoms/go-back-button/go-back-button.tsx +104 -0
- package/src/components/elements/atoms/go-back-button/index.ts +7 -0
- package/src/components/elements/atoms/inline-snippet/index.ts +7 -0
- package/src/components/elements/atoms/inline-snippet/inline-snippet.stories.tsx +130 -0
- package/src/components/elements/atoms/inline-snippet/inline-snippet.tsx +140 -0
- package/src/components/elements/atoms/loading-dots/index.ts +1 -0
- package/src/components/elements/atoms/loading-dots/loading-dots.stories.tsx +274 -0
- package/src/components/elements/atoms/loading-dots/loading-dots.tsx +138 -0
- package/src/components/elements/atoms/mode-toggle/index.ts +7 -0
- package/src/components/elements/atoms/mode-toggle/mode-toggle.stories.tsx +67 -0
- package/src/components/elements/atoms/mode-toggle/mode-toggle.tsx +163 -0
- package/src/components/elements/atoms/progress/index.ts +7 -0
- package/src/components/elements/atoms/progress/progress.stories.tsx +141 -0
- package/src/components/elements/atoms/progress/progress.tsx +314 -0
- package/src/components/elements/atoms/progress-circle/index.ts +7 -0
- package/src/components/elements/atoms/progress-circle/progress-circle.stories.tsx +185 -0
- package/src/components/elements/atoms/progress-circle/progress-circle.tsx +207 -0
- package/src/components/elements/atoms/separator/index.ts +7 -0
- package/src/components/elements/atoms/separator/separator.stories.tsx +154 -0
- package/src/components/elements/atoms/separator/separator.tsx +169 -0
- package/src/components/elements/atoms/skeleton/index.ts +7 -0
- package/src/components/elements/atoms/skeleton/skeleton.stories.tsx +152 -0
- package/src/components/elements/atoms/skeleton/skeleton.tsx +336 -0
- package/src/components/elements/atoms/slider/index.ts +7 -0
- package/src/components/elements/atoms/slider/slider.stories.tsx +199 -0
- package/src/components/elements/atoms/slider/slider.tsx +487 -0
- package/src/components/elements/atoms/sonner/index.ts +7 -0
- package/src/components/elements/atoms/sonner/sonner.stories.tsx +408 -0
- package/src/components/elements/atoms/sonner/sonner.tsx +131 -0
- package/src/components/elements/atoms/status-badge/index.ts +7 -0
- package/src/components/elements/atoms/status-badge/status-badge.stories.tsx +166 -0
- package/src/components/elements/atoms/status-badge/status-badge.tsx +262 -0
- package/src/components/elements/atoms/timestamp-tooltip/index.ts +7 -0
- package/src/components/elements/atoms/timestamp-tooltip/timestamp-tooltip.stories.tsx +127 -0
- package/src/components/elements/atoms/timestamp-tooltip/timestamp-tooltip.tsx +404 -0
- package/src/components/elements/molecules/animated-size-container/animated-size-container.stories.tsx +165 -0
- package/src/components/elements/molecules/animated-size-container/animated-size-container.tsx +125 -0
- package/src/components/elements/molecules/animated-size-container/index.ts +7 -0
- package/src/components/elements/molecules/avatar-stack/avatar-stack.stories.tsx +179 -0
- package/src/components/elements/molecules/avatar-stack/avatar-stack.tsx +258 -0
- package/src/components/elements/molecules/avatar-stack/index.ts +7 -0
- package/src/components/elements/molecules/breadcrumb/breadcrumb.stories.tsx +273 -0
- package/src/components/elements/molecules/breadcrumb/breadcrumb.tsx +299 -0
- package/src/components/elements/molecules/breadcrumb/index.ts +7 -0
- package/src/components/elements/molecules/button-group/button-group.stories.tsx +267 -0
- package/src/components/elements/molecules/button-group/button-group.tsx +244 -0
- package/src/components/elements/molecules/button-group/index.ts +7 -0
- package/src/components/elements/molecules/collapsible/collapsible.stories.tsx +186 -0
- package/src/components/elements/molecules/collapsible/collapsible.tsx +362 -0
- package/src/components/elements/molecules/collapsible/index.ts +7 -0
- package/src/components/elements/molecules/empty/empty.stories.tsx +182 -0
- package/src/components/elements/molecules/empty/empty.tsx +230 -0
- package/src/components/elements/molecules/empty/index.ts +7 -0
- package/src/components/elements/molecules/pagination-controls/index.ts +8 -0
- package/src/components/elements/molecules/pagination-controls/pagination-controls.stories.tsx +193 -0
- package/src/components/elements/molecules/pagination-controls/pagination-controls.tsx +174 -0
- package/src/components/elements/molecules/tab-select/index.ts +7 -0
- package/src/components/elements/molecules/tab-select/tab-select.stories.tsx +175 -0
- package/src/components/elements/molecules/tab-select/tab-select.tsx +261 -0
- package/src/components/elements/molecules/tabs/index.ts +7 -0
- package/src/components/elements/molecules/tabs/tabs.stories.tsx +198 -0
- package/src/components/elements/molecules/tabs/tabs.tsx +744 -0
- package/src/components/elements/molecules/toggle-group/index.ts +7 -0
- package/src/components/elements/molecules/toggle-group/toggle-group.stories.tsx +201 -0
- package/src/components/elements/molecules/toggle-group/toggle-group.tsx +236 -0
- package/src/components/elements/organisms/accordion/accordion.stories.tsx +217 -0
- package/src/components/elements/organisms/accordion/accordion.tsx +456 -0
- package/src/components/elements/organisms/accordion/index.ts +7 -0
- package/src/components/elements/organisms/card/card.stories.tsx +406 -0
- package/src/components/elements/organisms/card/card.tsx +437 -0
- package/src/components/elements/organisms/card/index.ts +8 -0
- package/src/components/elements/organisms/card/integration-card.stories.tsx +348 -0
- package/src/components/elements/organisms/card/integration-compact.stories.tsx +310 -0
- package/src/components/elements/organisms/card/integrations.tsx +356 -0
- package/src/components/elements/organisms/carousel/carousel.stories.tsx +182 -0
- package/src/components/elements/organisms/carousel/carousel.tsx +537 -0
- package/src/components/elements/organisms/carousel/index.ts +7 -0
- package/src/components/elements/organisms/chart/chart.stories.tsx +147 -0
- package/src/components/elements/organisms/chart/chart.tsx +317 -0
- package/src/components/elements/organisms/chart/index.ts +7 -0
- package/src/components/elements/organisms/command/command.stories.tsx +246 -0
- package/src/components/elements/organisms/command/command.tsx +284 -0
- package/src/components/elements/organisms/command/index.ts +7 -0
- package/src/components/elements/organisms/dialog/dialog.stories.tsx +266 -0
- package/src/components/elements/organisms/dialog/dialog.tsx +366 -0
- package/src/components/elements/organisms/dialog/index.ts +7 -0
- package/src/components/elements/organisms/dropdown-menu/dropdown-menu.stories.tsx +334 -0
- package/src/components/elements/organisms/dropdown-menu/dropdown-menu.tsx +611 -0
- package/src/components/elements/organisms/dropdown-menu/index.ts +7 -0
- package/src/components/elements/organisms/dynamic-breadcrumb/dynamic-breadcrumb.stories.tsx +50 -0
- package/src/components/elements/organisms/dynamic-breadcrumb/dynamic-breadcrumb.tsx +257 -0
- package/src/components/elements/organisms/dynamic-breadcrumb/index.ts +7 -0
- package/src/components/elements/organisms/error-boundary/error-boundary.stories.tsx +142 -0
- package/src/components/elements/organisms/error-boundary/error-boundary.tsx +408 -0
- package/src/components/elements/organisms/error-boundary/index.ts +7 -0
- package/src/components/elements/organisms/hover-card/hover-card.stories.tsx +245 -0
- package/src/components/elements/organisms/hover-card/hover-card.tsx +370 -0
- package/src/components/elements/organisms/hover-card/index.ts +7 -0
- package/src/components/elements/organisms/modal/index.ts +7 -0
- package/src/components/elements/organisms/modal/modal.stories.tsx +189 -0
- package/src/components/elements/organisms/modal/modal.tsx +266 -0
- package/src/components/elements/organisms/popover/index.ts +7 -0
- package/src/components/elements/organisms/popover/popover.stories.tsx +200 -0
- package/src/components/elements/organisms/popover/popover.tsx +302 -0
- package/src/components/elements/organisms/resizable/index.ts +7 -0
- package/src/components/elements/organisms/resizable/resizable.stories.tsx +204 -0
- package/src/components/elements/organisms/resizable/resizable.tsx +178 -0
- package/src/components/elements/organisms/scroll-area/index.ts +7 -0
- package/src/components/elements/organisms/scroll-area/scroll-area.stories.tsx +170 -0
- package/src/components/elements/organisms/scroll-area/scroll-area.tsx +167 -0
- package/src/components/elements/organisms/sheet/index.ts +7 -0
- package/src/components/elements/organisms/sheet/sheet.stories.tsx +235 -0
- package/src/components/elements/organisms/sheet/sheet.tsx +381 -0
- package/src/components/elements/organisms/table/index.ts +7 -0
- package/src/components/elements/organisms/table/table.stories.tsx +238 -0
- package/src/components/elements/organisms/table/table.tsx +392 -0
- package/src/components/elements/organisms/tooltip/index.ts +7 -0
- package/src/components/elements/organisms/tooltip/tooltip.stories.tsx +205 -0
- package/src/components/elements/organisms/tooltip/tooltip.tsx +547 -0
- package/src/components/filter/filter-list/filter-list.stories.tsx +157 -0
- package/src/components/filter/filter-list/filter-list.tsx +435 -0
- package/src/components/filter/filter-list/index.ts +7 -0
- package/src/components/filter/filter-select/filter-select.stories.tsx +124 -0
- package/src/components/filter/filter-select/filter-select.tsx +558 -0
- package/src/components/filter/filter-select/index.ts +7 -0
- package/src/components/filter/index.ts +9 -0
- package/src/components/filter/types.ts +70 -0
- package/src/components/forms/checkbox/checkbox.stories.tsx +177 -0
- package/src/components/forms/checkbox/checkbox.tsx +332 -0
- package/src/components/forms/checkbox/index.ts +11 -0
- package/src/components/forms/combobox/combobox.stories.tsx +224 -0
- package/src/components/forms/combobox/combobox.tsx +679 -0
- package/src/components/forms/combobox/index.ts +7 -0
- package/src/components/forms/date-picker/calendar/calendar.stories.tsx +78 -0
- package/src/components/forms/date-picker/calendar/calendar.tsx +271 -0
- package/src/components/forms/date-picker/calendar/index.ts +7 -0
- package/src/components/forms/date-picker/date-range-picker/date-range-picker.stories.tsx +108 -0
- package/src/components/forms/date-picker/date-range-picker/date-range-picker.tsx +334 -0
- package/src/components/forms/date-picker/date-range-picker/index.ts +7 -0
- package/src/components/forms/date-picker/index.ts +10 -0
- package/src/components/forms/date-picker/presets/index.ts +7 -0
- package/src/components/forms/date-picker/presets/presets.stories.tsx +105 -0
- package/src/components/forms/date-picker/presets/presets.tsx +196 -0
- package/src/components/forms/date-picker/shared.ts +109 -0
- package/src/components/forms/date-picker/trigger/index.ts +7 -0
- package/src/components/forms/date-picker/trigger/trigger.stories.tsx +78 -0
- package/src/components/forms/date-picker/trigger/trigger.tsx +195 -0
- package/src/components/forms/date-picker/types.ts +63 -0
- package/src/components/forms/file-upload/file-upload.stories.tsx +145 -0
- package/src/components/forms/file-upload/file-upload.tsx +504 -0
- package/src/components/forms/file-upload/index.ts +7 -0
- package/src/components/forms/input/index.ts +7 -0
- package/src/components/forms/input/input.stories.tsx +185 -0
- package/src/components/forms/input/input.tsx +228 -0
- package/src/components/forms/input-group/index.ts +11 -0
- package/src/components/forms/input-group/input-group.stories.tsx +146 -0
- package/src/components/forms/input-group/input-group.tsx +344 -0
- package/src/components/forms/label/index.ts +7 -0
- package/src/components/forms/label/label.stories.tsx +140 -0
- package/src/components/forms/label/label.tsx +189 -0
- package/src/components/forms/radio-group/index.ts +7 -0
- package/src/components/forms/radio-group/radio-group.stories.tsx +233 -0
- package/src/components/forms/radio-group/radio-group.tsx +476 -0
- package/src/components/forms/select/index.ts +7 -0
- package/src/components/forms/select/select.stories.tsx +274 -0
- package/src/components/forms/select/select.tsx +654 -0
- package/src/components/forms/switch/index.ts +11 -0
- package/src/components/forms/switch/switch.stories.tsx +166 -0
- package/src/components/forms/switch/switch.tsx +362 -0
- package/src/components/forms/textarea/index.ts +7 -0
- package/src/components/forms/textarea/textarea.stories.tsx +176 -0
- package/src/components/forms/textarea/textarea.tsx +225 -0
- package/src/components/layout/app-shell.tsx +363 -0
- package/src/components/layout/app-sidebar/app-sidebar.stories.tsx +68 -0
- package/src/components/layout/app-sidebar/app-sidebar.tsx +418 -0
- package/src/components/layout/app-sidebar/index.ts +11 -0
- package/src/components/layout/artifact-panel/artifact-panel-header.tsx +89 -0
- package/src/components/layout/artifact-panel/expandable-panel.stories.tsx +484 -0
- package/src/components/layout/artifact-panel/expandable-panel.tsx +289 -0
- package/src/components/layout/artifact-panel/index.ts +23 -0
- package/src/components/layout/artifact-panel/split-panel-layout.tsx +70 -0
- package/src/components/layout/artifact-panel/types.ts +63 -0
- package/src/components/layout/artifact-panel/use-artifact-panel-state.ts +101 -0
- package/src/components/layout/content-sidebar/content-sidebar.stories.tsx +490 -0
- package/src/components/layout/content-sidebar/content-sidebar.tsx +337 -0
- package/src/components/layout/content-sidebar/index.ts +17 -0
- package/src/components/layout/nav-app-switcher/index.ts +7 -0
- package/src/components/layout/nav-app-switcher/nav-app-switcher.stories.tsx +138 -0
- package/src/components/layout/nav-app-switcher/nav-app-switcher.tsx +282 -0
- package/src/components/layout/nav-main/index.ts +11 -0
- package/src/components/layout/nav-main/nav-main.stories.tsx +103 -0
- package/src/components/layout/nav-main/nav-main.tsx +259 -0
- package/src/components/layout/nav-projects/index.ts +11 -0
- package/src/components/layout/nav-projects/nav-projects.stories.tsx +82 -0
- package/src/components/layout/nav-projects/nav-projects.tsx +218 -0
- package/src/components/layout/nav-secondary/index.ts +11 -0
- package/src/components/layout/nav-secondary/nav-secondary.stories.tsx +81 -0
- package/src/components/layout/nav-secondary/nav-secondary.tsx +145 -0
- package/src/components/layout/nav-user/index.ts +11 -0
- package/src/components/layout/nav-user/nav-user.stories.tsx +80 -0
- package/src/components/layout/nav-user/nav-user.tsx +226 -0
- package/src/components/layout/oneapp/auth-context.tsx +74 -0
- package/src/components/layout/oneapp/ensure-anonymous-session.tsx +218 -0
- package/src/components/layout/oneapp/index.ts +37 -0
- package/src/components/layout/oneapp/microfrontend-layout.tsx +191 -0
- package/src/components/layout/oneapp/types.ts +98 -0
- package/src/components/layout/sidebar/index.ts +7 -0
- package/src/components/layout/sidebar/sidebar.stories.tsx +170 -0
- package/src/components/layout/sidebar/sidebar.tsx +945 -0
- package/src/components/layout/sidebar-inset-header-portal/index.ts +8 -0
- package/src/components/layout/sidebar-inset-header-portal/sidebar-inset-header-portal.stories.tsx +355 -0
- package/src/components/layout/sidebar-inset-header-portal/sidebar-inset-header-portal.tsx +179 -0
- package/src/components/layout/sidebar-slots/USAGE.md +163 -0
- package/src/components/layout/sidebar-slots/__tests__/sidebar-slots.test.tsx +239 -0
- package/src/components/layout/sidebar-slots/index.ts +9 -0
- package/src/components/layout/sidebar-slots/sidebar-slots.stories.tsx +525 -0
- package/src/components/layout/sidebar-slots/sidebar-slots.tsx +205 -0
- package/src/components/layout/theme-provider/index.ts +11 -0
- package/src/components/layout/theme-provider/theme-provider.stories.tsx +82 -0
- package/src/components/layout/theme-provider/theme-provider.tsx +101 -0
- package/src/components/overlays/confirm-dialog.stories.tsx +371 -0
- package/src/components/overlays/confirm-dialog.tsx +201 -0
- package/src/components/overlays/toast.stories.tsx +373 -0
- package/src/components/overlays/toast.tsx +115 -0
- package/src/constants/container.ts +183 -0
- package/src/constants/index.ts +38 -0
- package/src/constants/motion.ts +104 -0
- package/src/fonts/Satoshi-Variable.woff2 +0 -0
- package/src/fonts/Satoshi-VariableItalic.woff2 +0 -0
- package/src/fonts/fonts.css +41 -0
- package/src/fonts/index.ts +106 -0
- package/src/hooks/.gitkeep +0 -0
- package/src/hooks/ai-chat/context.tsx +294 -0
- package/src/hooks/ai-chat/hooks.ts +297 -0
- package/src/hooks/ai-chat/index.ts +35 -0
- package/src/hooks/ai-chat/utils.ts +65 -0
- package/src/hooks/index.ts +18 -0
- package/src/hooks/use-mobile.ts +45 -0
- package/src/hooks/use-responsive.ts +64 -0
- package/src/hooks/use-scroll-progress.ts +101 -0
- package/src/hooks/use-toast.ts +65 -0
- package/src/index.ts +857 -0
- package/src/lib/export-csv.ts +107 -0
- package/src/lib/index.ts +10 -0
- package/src/lib/resize-image.ts +109 -0
- package/src/lib/stable-sort.ts +29 -0
- package/src/lib/utils.ts +28 -0
- package/src/react-19-compat.d.ts +28 -0
- package/src/shared/auth/index.ts +8 -0
- package/src/shared/auth/types/index.ts +163 -0
- package/src/shared/auth/types.ts +196 -0
- package/src/shared/auth/utils/dark-mode.ts +336 -0
- package/src/shared/index.ts +5 -0
- package/src/styles/_tokens.generated.scss +84 -0
- package/src/styles/ai-elements.scss +9 -0
- package/src/styles/base.scss +44 -0
- package/src/styles/flows.scss +62 -0
- package/src/styles/globals.css +627 -0
- package/src/styles/index.scss +9 -0
- package/src/styles/shadcn.scss +16 -0
- package/src/styles/sources.css +16 -0
- package/src/styles/theme.css +1687 -0
- package/src/styles/theme.template.css +95 -0
- package/src/tokens/accessibility.ts +494 -0
- package/src/tokens/animations.ts +305 -0
- package/src/tokens/aspect-ratio.ts +89 -0
- package/src/tokens/blur.ts +82 -0
- package/src/tokens/border-width.ts +86 -0
- package/src/tokens/breakpoints.ts +150 -0
- package/src/tokens/colors.ts +1199 -0
- package/src/tokens/component.ts +362 -0
- package/src/tokens/container.ts +42 -0
- package/src/tokens/focus.ts +266 -0
- package/src/tokens/form-states.ts +521 -0
- package/src/tokens/grid.ts +258 -0
- package/src/tokens/index.ts +1175 -0
- package/src/tokens/interactions.ts +558 -0
- package/src/tokens/mantine-types.ts +68 -0
- package/src/tokens/opacity.ts +139 -0
- package/src/tokens/palette.ts +854 -0
- package/src/tokens/pseudo-elements.ts +508 -0
- package/src/tokens/radius.ts +57 -0
- package/src/tokens/shadows.ts +313 -0
- package/src/tokens/spacing.ts +95 -0
- package/src/tokens/states.ts +392 -0
- package/src/tokens/structural.ts +589 -0
- package/src/tokens/timing.ts +224 -0
- package/src/tokens/typography.ts +242 -0
- package/src/tokens/z-index.ts +184 -0
- package/storybook/preview.tsx +201 -0
|
@@ -0,0 +1,410 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { t as cn } from "./utils-D2bGp2p_.mjs";
|
|
3
|
+
import { t as Button } from "./button-DVOrrZLw.mjs";
|
|
4
|
+
import { i as TooltipTrigger, n as TooltipContent, r as TooltipProvider, t as Tooltip } from "./tooltip-B8_zKnHC.mjs";
|
|
5
|
+
import { t as Popover } from "./popover-DmWxl2lW.mjs";
|
|
6
|
+
import { forwardRef, isValidElement, memo, useCallback, useMemo, useState } from "react";
|
|
7
|
+
import { useDisclosure, useInputState, useMediaQuery, useReducedMotion } from "@mantine/hooks";
|
|
8
|
+
import { Check, ChevronDown, Loader2, Plus, Square, SquareCheck } from "lucide-react";
|
|
9
|
+
import { motion } from "motion/react";
|
|
10
|
+
import { Fragment as Fragment$1, jsx, jsxs } from "react/jsx-runtime";
|
|
11
|
+
import { Command, useCommandState } from "cmdk";
|
|
12
|
+
|
|
13
|
+
//#region src/components/forms/combobox/combobox.tsx
|
|
14
|
+
/**
|
|
15
|
+
* @fileoverview Combobox Component - Premium Harmony V2
|
|
16
|
+
*
|
|
17
|
+
* Autocomplete/searchable select built on cmdk with Premium Harmony V2 motion standards.
|
|
18
|
+
* Supports single and multiple selection with rich options, touch detection, and accessibility.
|
|
19
|
+
* Features fuzzy search, stagger animations, and WCAG-compliant touch targets.
|
|
20
|
+
*
|
|
21
|
+
* Features:
|
|
22
|
+
* - ES2023 syntax with modern patterns
|
|
23
|
+
* - Tailwind v4 CSS-first theming with CSS variables
|
|
24
|
+
* - Premium Harmony V2 spring physics for smooth animations
|
|
25
|
+
* - Touch detection with automatic sizing for mobile devices
|
|
26
|
+
* - Reduced motion support for accessibility
|
|
27
|
+
* - Super light/dark mode with seamless switching
|
|
28
|
+
* - cmdk integration for fuzzy search
|
|
29
|
+
* - Single and multiple selection modes
|
|
30
|
+
* - Optional stagger animation on dropdown open
|
|
31
|
+
* - Custom option icons and disabled states
|
|
32
|
+
* - Create new option support with async
|
|
33
|
+
* - Keyboard navigation and shortcuts
|
|
34
|
+
* - Customizable trigger button
|
|
35
|
+
* - Option separators and tooltips
|
|
36
|
+
* - WCAG 2.5.5 compliant 44px minimum touch targets
|
|
37
|
+
* - Data attributes for state tracking (data-state, data-selected)
|
|
38
|
+
* - Enhanced focus styles with semantic color tokens
|
|
39
|
+
* - Mantine hooks for state management
|
|
40
|
+
*
|
|
41
|
+
* @module @od-oneapp/uni-ui/components/combobox
|
|
42
|
+
* @component Combobox
|
|
43
|
+
*
|
|
44
|
+
* @useCases
|
|
45
|
+
* - Form inputs: Country selector, language picker, category assignment
|
|
46
|
+
* - Search interfaces: Fuzzy search with autocomplete, command palette, quick actions
|
|
47
|
+
* - Multi-select: Tag assignment, user permissions, category filtering
|
|
48
|
+
* - Creation flows: Add new options dynamically, inline entity creation
|
|
49
|
+
* - Touch interfaces: Mobile-first dropdowns with WCAG 2.5.5 compliant 44px touch targets
|
|
50
|
+
* - Accessible selects: Screen reader support, keyboard navigation, focus management
|
|
51
|
+
* - Rich options: Custom icons, tooltips, separators, disabled states
|
|
52
|
+
*
|
|
53
|
+
* @example
|
|
54
|
+
* // Single selection
|
|
55
|
+
* <Combobox options={options} selected={selected} setSelected={setSelected} placeholder="Select option..." caret />
|
|
56
|
+
*
|
|
57
|
+
* @example
|
|
58
|
+
* // Multiple selection with stagger animation
|
|
59
|
+
* <Combobox multiple stagger options={options} selected={selectedItems} setSelected={setSelectedItems} />
|
|
60
|
+
*
|
|
61
|
+
* @example
|
|
62
|
+
* // Touch-optimized for mobile
|
|
63
|
+
* <Combobox size="touch" options={options} selected={selected} setSelected={setSelected} />
|
|
64
|
+
*/
|
|
65
|
+
/**
|
|
66
|
+
* Premium Harmony V2 Spring Physics Constants
|
|
67
|
+
* Optimized for tactile, fluid, and gentle interactions
|
|
68
|
+
*/
|
|
69
|
+
const SPRING_TACTILE = {
|
|
70
|
+
stiffness: 400,
|
|
71
|
+
damping: 25
|
|
72
|
+
};
|
|
73
|
+
const SPRING_FLUID = {
|
|
74
|
+
stiffness: 300,
|
|
75
|
+
damping: 30
|
|
76
|
+
};
|
|
77
|
+
function isMultipleSelection(multiple, setSelected) {
|
|
78
|
+
return multiple === true;
|
|
79
|
+
}
|
|
80
|
+
const DEFAULT_COMBOBOX_PLACEHOLDER = "Select...";
|
|
81
|
+
const DEFAULT_COMBOBOX_SEARCH_PLACEHOLDER = "Search...";
|
|
82
|
+
const DEFAULT_COMBOBOX_SHOULD_FILTER = true;
|
|
83
|
+
const DEFAULT_COMBOBOX_HIDE_SEARCH = false;
|
|
84
|
+
const DEFAULT_COMBOBOX_EMPTY_STATE = "No matches";
|
|
85
|
+
const COMBOBOX_CARET_ICON_BASE_CLASSNAME = "text-muted-foreground ml-1 size-4 shrink-0";
|
|
86
|
+
const COMBOBOX_CARET_ICON_TRANSITION_CLASSNAME = "transition-transform duration-75";
|
|
87
|
+
const COMBOBOX_CARET_ICON_OPEN_CLASSNAME = "group-data-[state=open]:rotate-180";
|
|
88
|
+
const COMBOBOX_CREATE_OPTION_ITEM_BASE_CLASSNAME = "text-foreground flex cursor-pointer items-center gap-3 rounded-md px-3 py-2 text-left text-sm whitespace-nowrap hover:bg-accent hover:text-accent-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 transition-colors";
|
|
89
|
+
const COMBOBOX_CREATE_OPTION_ITEM_SELECTED_CLASSNAME = "data-[selected=true]:bg-accent/50";
|
|
90
|
+
const COMBOBOX_CREATE_OPTION_ICON_CLASSNAME = "size-4 shrink-0";
|
|
91
|
+
const COMBOBOX_CREATE_OPTION_ICON_LOADING_CLASSNAME = "animate-spin";
|
|
92
|
+
const COMBOBOX_CREATE_OPTION_CONTENT_CLASSNAME = "grow truncate";
|
|
93
|
+
const COMBOBOX_COMMAND_WRAPPER_CLASSNAME = "pointer-events-auto";
|
|
94
|
+
const COMBOBOX_SEARCH_WRAPPER_CLASSNAME = "border-border bg-background flex items-center overflow-hidden rounded-t-lg border-b";
|
|
95
|
+
const COMBOBOX_INPUT_BASE_CLASSNAME = "placeholder:text-muted-foreground text-foreground grow border-0 bg-transparent py-3 pr-2 pl-4 outline-none focus:ring-0 focus-visible:outline-none sm:text-sm";
|
|
96
|
+
const COMBOBOX_INPUT_RIGHT_WRAPPER_CLASSNAME = "mr-2";
|
|
97
|
+
const COMBOBOX_SHORTCUT_HINT_CLASSNAME = "border-border bg-muted text-muted-foreground mr-2 hidden shrink-0 rounded border px-2 py-0.5 text-xs font-light md:block";
|
|
98
|
+
const COMBOBOX_OPTIONS_CONTAINER_BASE_CLASSNAME = "max-h-[min(50vh,250px)] overflow-auto";
|
|
99
|
+
const COMBOBOX_OPTIONS_CONTAINER_WITH_CREATE_CLASSNAME = "max-h-[calc(min(50vh,250px)-3.5rem)]";
|
|
100
|
+
const COMBOBOX_COMMAND_LIST_CLASSNAME = "flex w-full min-w-[100px] flex-col gap-1 p-1";
|
|
101
|
+
const COMBOBOX_LOADING_WRAPPER_CLASSNAME = "flex h-12 items-center justify-center";
|
|
102
|
+
const COMBOBOX_LOADING_ICON_CLASSNAME = "text-muted-foreground size-4 animate-spin";
|
|
103
|
+
const COMBOBOX_CREATE_STICKY_WRAPPER_CLASSNAME = "border-border bg-popover rounded-b-lg border-t p-1";
|
|
104
|
+
const COMBOBOX_BUTTON_BASE_CLASSNAME = "flex gap-2";
|
|
105
|
+
const COMBOBOX_ICON_WRAPPER_CLASSNAME = "shrink-0";
|
|
106
|
+
const COMBOBOX_ICON_CLASSNAME = "size-4";
|
|
107
|
+
const COMBOBOX_LABEL_WRAPPER_CLASSNAME = "min-w-0 grow truncate text-left";
|
|
108
|
+
const Combobox = memo(function Combobox({ multiple, selected: selectedProp, setSelected, onSelect, options, trigger, icon: IconProp, placeholder = DEFAULT_COMBOBOX_PLACEHOLDER, searchPlaceholder = DEFAULT_COMBOBOX_SEARCH_PLACEHOLDER, emptyState, createLabel, createIcon: CreateIcon = Plus, onCreate, buttonProps, labelProps, iconProps, popoverProps, shortcutHint, caret, side, open, onOpenChange, onSearchChange, shouldFilter = DEFAULT_COMBOBOX_SHOULD_FILTER, inputRight, inputClassName, optionRight, optionClassName, matchTriggerWidth, hideSearch = DEFAULT_COMBOBOX_HIDE_SEARCH, stagger = false, size = "default", children }) {
|
|
109
|
+
const isMultiple = isMultipleSelection(multiple, setSelected);
|
|
110
|
+
const reducedMotion = useReducedMotion();
|
|
111
|
+
const isTouchDevice = useMediaQuery("(pointer: coarse)");
|
|
112
|
+
const effectiveSize = useMemo(() => {
|
|
113
|
+
if (size === "touch") return "touch";
|
|
114
|
+
if (isTouchDevice && size === "default") return "touch";
|
|
115
|
+
return size;
|
|
116
|
+
}, [size, isTouchDevice]);
|
|
117
|
+
const selected = useMemo(() => {
|
|
118
|
+
if (Array.isArray(selectedProp)) return selectedProp;
|
|
119
|
+
if (selectedProp) return [selectedProp];
|
|
120
|
+
return [];
|
|
121
|
+
}, [selectedProp]);
|
|
122
|
+
const [isOpenInternal, { open: openInternal, close: closeInternal }] = useDisclosure(false);
|
|
123
|
+
const isOpen = open ?? isOpenInternal;
|
|
124
|
+
const setIsOpen = useCallback((newOpen) => {
|
|
125
|
+
if (onOpenChange != null) onOpenChange(newOpen);
|
|
126
|
+
else if (open == null) if (newOpen) openInternal();
|
|
127
|
+
else closeInternal();
|
|
128
|
+
}, [
|
|
129
|
+
onOpenChange,
|
|
130
|
+
open,
|
|
131
|
+
openInternal,
|
|
132
|
+
closeInternal
|
|
133
|
+
]);
|
|
134
|
+
const [search, setSearch] = useInputState("");
|
|
135
|
+
const [isCreating, setIsCreating] = useState(false);
|
|
136
|
+
const handleSelect = useCallback((option) => {
|
|
137
|
+
onSelect?.(option);
|
|
138
|
+
if (!setSelected) return;
|
|
139
|
+
if (isMultiple) setSelected(selected.some(({ value }) => value === option.value) ? selected.filter(({ value }) => value !== option.value) : [...selected, option]);
|
|
140
|
+
else {
|
|
141
|
+
setSelected(selected.length > 0 && selected[0]?.value === option.value ? null : option);
|
|
142
|
+
setIsOpen(false);
|
|
143
|
+
}
|
|
144
|
+
}, [
|
|
145
|
+
onSelect,
|
|
146
|
+
setSelected,
|
|
147
|
+
isMultiple,
|
|
148
|
+
selected,
|
|
149
|
+
setIsOpen
|
|
150
|
+
]);
|
|
151
|
+
const sortedOptions = useMemo(() => {
|
|
152
|
+
if (!options) return;
|
|
153
|
+
if (search !== "") return options;
|
|
154
|
+
return [
|
|
155
|
+
...options.filter((o) => o.first === true && !selected.some((s) => s.value === o.value)),
|
|
156
|
+
...selected,
|
|
157
|
+
...options.filter((o) => o.first !== true && !selected.some((s) => s.value === o.value))
|
|
158
|
+
];
|
|
159
|
+
}, [
|
|
160
|
+
options,
|
|
161
|
+
search,
|
|
162
|
+
selected
|
|
163
|
+
]);
|
|
164
|
+
const handleOpenChange = useCallback((newOpen) => {
|
|
165
|
+
if (!newOpen) setSearch("");
|
|
166
|
+
setIsOpen?.(newOpen);
|
|
167
|
+
}, [setIsOpen, setSearch]);
|
|
168
|
+
const handleSearchChange = useCallback((newSearch) => {
|
|
169
|
+
setSearch(newSearch);
|
|
170
|
+
onSearchChange?.(newSearch);
|
|
171
|
+
}, [onSearchChange, setSearch]);
|
|
172
|
+
const handleCreate = useCallback(async () => {
|
|
173
|
+
setIsCreating(true);
|
|
174
|
+
if (await onCreate?.(search)) {
|
|
175
|
+
setSearch("");
|
|
176
|
+
setIsOpen(false);
|
|
177
|
+
}
|
|
178
|
+
setIsCreating(false);
|
|
179
|
+
}, [onCreate, search]);
|
|
180
|
+
const createOptionItem = useMemo(() => /* @__PURE__ */ jsxs(Command.Item, {
|
|
181
|
+
className: cn(COMBOBOX_CREATE_OPTION_ITEM_BASE_CLASSNAME, COMBOBOX_CREATE_OPTION_ITEM_SELECTED_CLASSNAME, optionClassName),
|
|
182
|
+
onSelect: () => void handleCreate(),
|
|
183
|
+
children: [isCreating ? /* @__PURE__ */ jsx(Loader2, { className: cn(COMBOBOX_CREATE_OPTION_ICON_CLASSNAME, COMBOBOX_CREATE_OPTION_ICON_LOADING_CLASSNAME) }) : /* @__PURE__ */ jsx(CreateIcon, { className: COMBOBOX_CREATE_OPTION_ICON_CLASSNAME }), /* @__PURE__ */ jsx("div", {
|
|
184
|
+
className: COMBOBOX_CREATE_OPTION_CONTENT_CLASSNAME,
|
|
185
|
+
children: createLabel?.(search) ?? `Create ${search ? `"${search}"` : "new option..."}`
|
|
186
|
+
})]
|
|
187
|
+
}), [
|
|
188
|
+
isCreating,
|
|
189
|
+
search,
|
|
190
|
+
createLabel,
|
|
191
|
+
optionClassName,
|
|
192
|
+
handleCreate
|
|
193
|
+
]);
|
|
194
|
+
const emptyContent = useMemo(() => {
|
|
195
|
+
if (shouldFilter) return /* @__PURE__ */ jsx(Empty, {
|
|
196
|
+
className: "text-muted-foreground flex min-h-12 items-center justify-center text-sm",
|
|
197
|
+
children: emptyState ?? DEFAULT_COMBOBOX_EMPTY_STATE
|
|
198
|
+
});
|
|
199
|
+
if ((sortedOptions?.length ?? 0) === 0) return /* @__PURE__ */ jsx("div", {
|
|
200
|
+
className: "text-muted-foreground flex min-h-12 items-center justify-center text-sm",
|
|
201
|
+
children: emptyState ?? DEFAULT_COMBOBOX_EMPTY_STATE
|
|
202
|
+
});
|
|
203
|
+
return null;
|
|
204
|
+
}, [
|
|
205
|
+
shouldFilter,
|
|
206
|
+
sortedOptions?.length,
|
|
207
|
+
emptyState
|
|
208
|
+
]);
|
|
209
|
+
return /* @__PURE__ */ jsx(Popover, {
|
|
210
|
+
openPopover: isOpen,
|
|
211
|
+
setOpenPopover: handleOpenChange,
|
|
212
|
+
align: "start",
|
|
213
|
+
side,
|
|
214
|
+
onWheel: (e) => {
|
|
215
|
+
e.stopPropagation();
|
|
216
|
+
},
|
|
217
|
+
popoverContentClassName: cn(matchTriggerWidth === true && "sm:w-[var(--radix-popover-trigger-width)]", popoverProps?.contentClassName),
|
|
218
|
+
"data-state": isOpen ? "open" : "closed",
|
|
219
|
+
content: /* @__PURE__ */ jsx(motion.div, {
|
|
220
|
+
className: COMBOBOX_COMMAND_WRAPPER_CLASSNAME,
|
|
221
|
+
initial: reducedMotion ? void 0 : {
|
|
222
|
+
opacity: 0,
|
|
223
|
+
scale: .96,
|
|
224
|
+
y: -8
|
|
225
|
+
},
|
|
226
|
+
animate: reducedMotion ? void 0 : {
|
|
227
|
+
opacity: 1,
|
|
228
|
+
scale: 1,
|
|
229
|
+
y: 0
|
|
230
|
+
},
|
|
231
|
+
exit: reducedMotion ? void 0 : {
|
|
232
|
+
opacity: 0,
|
|
233
|
+
scale: .96,
|
|
234
|
+
y: -8
|
|
235
|
+
},
|
|
236
|
+
transition: reducedMotion ? void 0 : SPRING_FLUID,
|
|
237
|
+
children: /* @__PURE__ */ jsxs(Command, {
|
|
238
|
+
loop: true,
|
|
239
|
+
shouldFilter,
|
|
240
|
+
children: [
|
|
241
|
+
!hideSearch && /* @__PURE__ */ jsxs("div", {
|
|
242
|
+
className: COMBOBOX_SEARCH_WRAPPER_CLASSNAME,
|
|
243
|
+
children: [
|
|
244
|
+
/* @__PURE__ */ jsx(Command.Input, {
|
|
245
|
+
placeholder: searchPlaceholder,
|
|
246
|
+
value: search,
|
|
247
|
+
onValueChange: handleSearchChange,
|
|
248
|
+
className: cn(COMBOBOX_INPUT_BASE_CLASSNAME, inputClassName),
|
|
249
|
+
onKeyDown: (e) => {
|
|
250
|
+
if (e.key === "Escape" || e.key === "Backspace" && !search) {
|
|
251
|
+
e.preventDefault();
|
|
252
|
+
e.stopPropagation();
|
|
253
|
+
setIsOpen(false);
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
}),
|
|
257
|
+
inputRight != null && /* @__PURE__ */ jsx("div", {
|
|
258
|
+
className: COMBOBOX_INPUT_RIGHT_WRAPPER_CLASSNAME,
|
|
259
|
+
children: inputRight
|
|
260
|
+
}),
|
|
261
|
+
shortcutHint != null && /* @__PURE__ */ jsx("kbd", {
|
|
262
|
+
className: COMBOBOX_SHORTCUT_HINT_CLASSNAME,
|
|
263
|
+
children: shortcutHint
|
|
264
|
+
})
|
|
265
|
+
]
|
|
266
|
+
}),
|
|
267
|
+
/* @__PURE__ */ jsx("div", {
|
|
268
|
+
className: cn(COMBOBOX_OPTIONS_CONTAINER_BASE_CLASSNAME, onCreate != null && !multiple && COMBOBOX_OPTIONS_CONTAINER_WITH_CREATE_CLASSNAME),
|
|
269
|
+
children: /* @__PURE__ */ jsx(Command.List, {
|
|
270
|
+
className: COMBOBOX_COMMAND_LIST_CLASSNAME,
|
|
271
|
+
children: sortedOptions !== void 0 ? /* @__PURE__ */ jsxs(Fragment$1, { children: [
|
|
272
|
+
sortedOptions.map((option, index) => /* @__PURE__ */ jsx(Option, {
|
|
273
|
+
option,
|
|
274
|
+
multiple: isMultiple,
|
|
275
|
+
selected: selected.some(({ value }) => value === option.value),
|
|
276
|
+
onSelect: () => handleSelect(option),
|
|
277
|
+
right: optionRight?.(option),
|
|
278
|
+
className: optionClassName,
|
|
279
|
+
index,
|
|
280
|
+
stagger: stagger ? !reducedMotion : void 0,
|
|
281
|
+
size: effectiveSize
|
|
282
|
+
}, `${String(option.label)}, ${option.value}`)),
|
|
283
|
+
onCreate != null && multiple === true && search.length > 0 && createOptionItem,
|
|
284
|
+
emptyContent
|
|
285
|
+
] }) : /* @__PURE__ */ jsx(Command.Loading, { children: /* @__PURE__ */ jsx("div", {
|
|
286
|
+
className: COMBOBOX_LOADING_WRAPPER_CLASSNAME,
|
|
287
|
+
children: /* @__PURE__ */ jsx(Loader2, { className: COMBOBOX_LOADING_ICON_CLASSNAME })
|
|
288
|
+
}) })
|
|
289
|
+
})
|
|
290
|
+
}),
|
|
291
|
+
onCreate != null && !multiple && /* @__PURE__ */ jsx("div", {
|
|
292
|
+
className: COMBOBOX_CREATE_STICKY_WRAPPER_CLASSNAME,
|
|
293
|
+
children: createOptionItem
|
|
294
|
+
})
|
|
295
|
+
]
|
|
296
|
+
})
|
|
297
|
+
}),
|
|
298
|
+
children: trigger ?? /* @__PURE__ */ jsxs(Button, {
|
|
299
|
+
variant: "secondary",
|
|
300
|
+
size: effectiveSize === "touch" ? "touch" : effectiveSize,
|
|
301
|
+
whileTap: reducedMotion ? void 0 : { scale: .98 },
|
|
302
|
+
"data-state": isOpen ? "open" : "closed",
|
|
303
|
+
...buttonProps,
|
|
304
|
+
className: cn(buttonProps?.className, COMBOBOX_BUTTON_BASE_CLASSNAME),
|
|
305
|
+
children: [
|
|
306
|
+
IconProp != null && /* @__PURE__ */ jsx("span", {
|
|
307
|
+
className: cn(COMBOBOX_ICON_WRAPPER_CLASSNAME, iconProps?.className),
|
|
308
|
+
children: isReactNode(IconProp) ? IconProp : /* @__PURE__ */ jsx(IconProp, { className: COMBOBOX_ICON_CLASSNAME })
|
|
309
|
+
}),
|
|
310
|
+
/* @__PURE__ */ jsx("span", {
|
|
311
|
+
className: cn(COMBOBOX_LABEL_WRAPPER_CLASSNAME, labelProps?.className),
|
|
312
|
+
children: children ?? (selected.length > 0 ? selected.map((option) => option.label).join(", ") : placeholder)
|
|
313
|
+
}),
|
|
314
|
+
caret != null && (caret === true ? /* @__PURE__ */ jsx(ChevronDown, { className: cn(COMBOBOX_CARET_ICON_BASE_CLASSNAME, !reducedMotion && COMBOBOX_CARET_ICON_TRANSITION_CLASSNAME, COMBOBOX_CARET_ICON_OPEN_CLASSNAME) }) : caret)
|
|
315
|
+
]
|
|
316
|
+
})
|
|
317
|
+
});
|
|
318
|
+
});
|
|
319
|
+
const COMBOBOX_OPTION_ITEM_SELECTED_CLASSNAME = "aria-selected:bg-accent aria-selected:text-accent-foreground data-[selected=true]:bg-accent/50";
|
|
320
|
+
const COMBOBOX_OPTION_ITEM_DISABLED_CLASSNAME = "aria-disabled:pointer-events-none aria-disabled:opacity-50";
|
|
321
|
+
const COMBOBOX_OPTION_ITEM_FOCUS_CLASSNAME = "focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2";
|
|
322
|
+
const STAGGER_DELAY_MS = .03;
|
|
323
|
+
const MAX_STAGGER_ITEMS = 10;
|
|
324
|
+
const COMBOBOX_OPTION_CHECKBOX_WRAPPER_CLASSNAME = "text-muted-foreground shrink-0";
|
|
325
|
+
const COMBOBOX_OPTION_CHECKBOX_SELECTED_CLASSNAME = "text-foreground";
|
|
326
|
+
const COMBOBOX_OPTION_CHECKBOX_ICON_CLASSNAME = "size-4";
|
|
327
|
+
const COMBOBOX_OPTION_CONTENT_WRAPPER_CLASSNAME = "flex min-w-0 grow items-center gap-2";
|
|
328
|
+
const COMBOBOX_OPTION_ICON_WRAPPER_CLASSNAME = "text-muted-foreground shrink-0";
|
|
329
|
+
const COMBOBOX_OPTION_ICON_CLASSNAME = "size-4";
|
|
330
|
+
const COMBOBOX_OPTION_LABEL_CLASSNAME = "grow truncate";
|
|
331
|
+
const COMBOBOX_OPTION_CHECK_ICON_CLASSNAME = "text-foreground size-4 shrink-0";
|
|
332
|
+
const COMBOBOX_OPTION_SEPARATOR_CLASSNAME = "bg-border -mx-1 my-1 h-px";
|
|
333
|
+
const Option = memo(function Option({ option, onSelect, multiple, selected, right, className, index, stagger, size }) {
|
|
334
|
+
const hasDisabledTooltip = Boolean(option.disabledTooltip);
|
|
335
|
+
const itemClassName = useMemo(() => cn("relative flex cursor-default select-none items-center gap-3 rounded-sm outline-none", size === "sm" && "px-2 py-1 text-xs", size === "default" && "px-2 py-1.5 text-sm", size === "lg" && "px-3 py-2 text-base", size === "touch" && "min-h-[44px] px-3 py-2.5 text-base md:text-sm", COMBOBOX_OPTION_ITEM_SELECTED_CLASSNAME, COMBOBOX_OPTION_ITEM_DISABLED_CLASSNAME, COMBOBOX_OPTION_ITEM_FOCUS_CLASSNAME, className), [size, className]);
|
|
336
|
+
const staggerDelay = useMemo(() => {
|
|
337
|
+
if (!stagger || index === void 0) return 0;
|
|
338
|
+
return Math.min(index, MAX_STAGGER_ITEMS) * STAGGER_DELAY_MS;
|
|
339
|
+
}, [stagger, index]);
|
|
340
|
+
const checkboxWrapperClassName = useMemo(() => cn(COMBOBOX_OPTION_CHECKBOX_WRAPPER_CLASSNAME, selected && COMBOBOX_OPTION_CHECKBOX_SELECTED_CLASSNAME), [selected]);
|
|
341
|
+
return /* @__PURE__ */ jsxs(Fragment$1, { children: [/* @__PURE__ */ jsx(DisabledTooltip, {
|
|
342
|
+
disabledTooltip: option.disabledTooltip,
|
|
343
|
+
children: /* @__PURE__ */ jsx(Command.Item, {
|
|
344
|
+
asChild: true,
|
|
345
|
+
disabled: hasDisabledTooltip,
|
|
346
|
+
onSelect,
|
|
347
|
+
value: String(option.label) + option.value,
|
|
348
|
+
children: /* @__PURE__ */ jsxs(motion.div, {
|
|
349
|
+
className: itemClassName,
|
|
350
|
+
"data-selected": selected,
|
|
351
|
+
"data-disabled": hasDisabledTooltip,
|
|
352
|
+
initial: stagger ? {
|
|
353
|
+
opacity: 0,
|
|
354
|
+
x: -4
|
|
355
|
+
} : false,
|
|
356
|
+
animate: stagger ? {
|
|
357
|
+
opacity: 1,
|
|
358
|
+
x: 0
|
|
359
|
+
} : false,
|
|
360
|
+
transition: stagger ? {
|
|
361
|
+
type: "spring",
|
|
362
|
+
...SPRING_TACTILE,
|
|
363
|
+
delay: staggerDelay
|
|
364
|
+
} : void 0,
|
|
365
|
+
children: [
|
|
366
|
+
multiple ? /* @__PURE__ */ jsx("div", {
|
|
367
|
+
className: checkboxWrapperClassName,
|
|
368
|
+
children: selected ? /* @__PURE__ */ jsx(SquareCheck, { className: COMBOBOX_OPTION_CHECKBOX_ICON_CLASSNAME }) : /* @__PURE__ */ jsx(Square, { className: COMBOBOX_OPTION_CHECKBOX_ICON_CLASSNAME })
|
|
369
|
+
}) : null,
|
|
370
|
+
/* @__PURE__ */ jsxs("div", {
|
|
371
|
+
className: COMBOBOX_OPTION_CONTENT_WRAPPER_CLASSNAME,
|
|
372
|
+
children: [option.icon != null ? /* @__PURE__ */ jsx("span", {
|
|
373
|
+
className: COMBOBOX_OPTION_ICON_WRAPPER_CLASSNAME,
|
|
374
|
+
children: isReactNode(option.icon) ? option.icon : /* @__PURE__ */ jsx(option.icon, { className: COMBOBOX_OPTION_ICON_CLASSNAME })
|
|
375
|
+
}) : null, /* @__PURE__ */ jsx("span", {
|
|
376
|
+
className: COMBOBOX_OPTION_LABEL_CLASSNAME,
|
|
377
|
+
children: option.label
|
|
378
|
+
})]
|
|
379
|
+
}),
|
|
380
|
+
right,
|
|
381
|
+
!multiple && selected ? /* @__PURE__ */ jsx(Check, { className: COMBOBOX_OPTION_CHECK_ICON_CLASSNAME }) : null
|
|
382
|
+
]
|
|
383
|
+
})
|
|
384
|
+
})
|
|
385
|
+
}), option.separatorAfter === true && /* @__PURE__ */ jsx(Command.Separator, { className: COMBOBOX_OPTION_SEPARATOR_CLASSNAME })] });
|
|
386
|
+
});
|
|
387
|
+
Option.displayName = "ComboboxOption";
|
|
388
|
+
const DisabledTooltip = memo(function DisabledTooltip({ children, disabledTooltip }) {
|
|
389
|
+
if (disabledTooltip) return /* @__PURE__ */ jsx(TooltipProvider, { children: /* @__PURE__ */ jsxs(Tooltip, { children: [/* @__PURE__ */ jsx(TooltipTrigger, {
|
|
390
|
+
asChild: true,
|
|
391
|
+
children: /* @__PURE__ */ jsx("div", { children })
|
|
392
|
+
}), /* @__PURE__ */ jsx(TooltipContent, { children: disabledTooltip })] }) });
|
|
393
|
+
return children;
|
|
394
|
+
});
|
|
395
|
+
DisabledTooltip.displayName = "ComboboxDisabledTooltip";
|
|
396
|
+
const isReactNode = (element) => isValidElement(element);
|
|
397
|
+
const Empty = forwardRef((props, forwardedRef) => {
|
|
398
|
+
if (!useCommandState((state) => state.filtered.count === 0)) return null;
|
|
399
|
+
return /* @__PURE__ */ jsx("div", {
|
|
400
|
+
ref: forwardedRef,
|
|
401
|
+
"cmdk-empty": "",
|
|
402
|
+
role: "presentation",
|
|
403
|
+
...props
|
|
404
|
+
});
|
|
405
|
+
});
|
|
406
|
+
Empty.displayName = "Empty";
|
|
407
|
+
|
|
408
|
+
//#endregion
|
|
409
|
+
export { Combobox as t };
|
|
410
|
+
//# sourceMappingURL=combobox-uEKksQFR.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"combobox-uEKksQFR.mjs","names":[],"sources":["../src/components/forms/combobox/combobox.tsx"],"sourcesContent":["'use client';\n\n/**\n * @fileoverview Combobox Component - Premium Harmony V2\n *\n * Autocomplete/searchable select built on cmdk with Premium Harmony V2 motion standards.\n * Supports single and multiple selection with rich options, touch detection, and accessibility.\n * Features fuzzy search, stagger animations, and WCAG-compliant touch targets.\n *\n * Features:\n * - ES2023 syntax with modern patterns\n * - Tailwind v4 CSS-first theming with CSS variables\n * - Premium Harmony V2 spring physics for smooth animations\n * - Touch detection with automatic sizing for mobile devices\n * - Reduced motion support for accessibility\n * - Super light/dark mode with seamless switching\n * - cmdk integration for fuzzy search\n * - Single and multiple selection modes\n * - Optional stagger animation on dropdown open\n * - Custom option icons and disabled states\n * - Create new option support with async\n * - Keyboard navigation and shortcuts\n * - Customizable trigger button\n * - Option separators and tooltips\n * - WCAG 2.5.5 compliant 44px minimum touch targets\n * - Data attributes for state tracking (data-state, data-selected)\n * - Enhanced focus styles with semantic color tokens\n * - Mantine hooks for state management\n *\n * @module @od-oneapp/uni-ui/components/combobox\n * @component Combobox\n *\n * @useCases\n * - Form inputs: Country selector, language picker, category assignment\n * - Search interfaces: Fuzzy search with autocomplete, command palette, quick actions\n * - Multi-select: Tag assignment, user permissions, category filtering\n * - Creation flows: Add new options dynamically, inline entity creation\n * - Touch interfaces: Mobile-first dropdowns with WCAG 2.5.5 compliant 44px touch targets\n * - Accessible selects: Screen reader support, keyboard navigation, focus management\n * - Rich options: Custom icons, tooltips, separators, disabled states\n *\n * @example\n * // Single selection\n * <Combobox options={options} selected={selected} setSelected={setSelected} placeholder=\"Select option...\" caret />\n *\n * @example\n * // Multiple selection with stagger animation\n * <Combobox multiple stagger options={options} selected={selectedItems} setSelected={setSelectedItems} />\n *\n * @example\n * // Touch-optimized for mobile\n * <Combobox size=\"touch\" options={options} selected={selected} setSelected={setSelected} />\n */\n\nimport {\n forwardRef,\n isValidElement,\n memo,\n useCallback,\n useMemo,\n useState,\n type HTMLProps,\n type PropsWithChildren,\n type ReactNode,\n} from 'react';\n\nimport { useDisclosure, useInputState, useMediaQuery, useReducedMotion } from '@mantine/hooks';\nimport { Command, useCommandState } from 'cmdk';\nimport {\n Check,\n ChevronDown,\n Loader2,\n Plus,\n Square,\n SquareCheck,\n type LucideIcon,\n} from 'lucide-react';\nimport { motion } from 'motion/react';\n\nimport { cn } from '../../../lib/utils';\nimport { Button } from '../../elements/atoms/button';\nimport { Popover, type PopoverProps } from '../../elements/organisms/popover';\nimport {\n Tooltip,\n TooltipContent,\n TooltipProvider,\n TooltipTrigger,\n} from '../../elements/organisms/tooltip';\n\n/**\n * Premium Harmony V2 Spring Physics Constants\n * Optimized for tactile, fluid, and gentle interactions\n */\nconst SPRING_TACTILE = { stiffness: 400, damping: 25 } as const;\nconst SPRING_FLUID = { stiffness: 300, damping: 30 } as const;\nconst SPRING_GENTLE = { stiffness: 200, damping: 28 } as const;\n\nexport interface ComboboxOption<TMeta = unknown> {\n label: string | ReactNode;\n value: string;\n icon?: LucideIcon | ReactNode;\n disabledTooltip?: ReactNode;\n meta?: TMeta;\n separatorAfter?: boolean;\n first?: boolean;\n}\n\nexport interface ComboboxProps<\n TMultiple extends boolean | undefined,\n TMeta,\n> extends PropsWithChildren {\n multiple?: TMultiple;\n selected: TMultiple extends true ? ComboboxOption<TMeta>[] : ComboboxOption<TMeta> | null;\n setSelected?: TMultiple extends true\n ? (options: ComboboxOption<TMeta>[]) => void\n : (option: ComboboxOption<TMeta> | null) => void;\n onSelect?: (option: ComboboxOption<TMeta>) => void;\n options?: ComboboxOption<TMeta>[];\n trigger?: ReactNode;\n icon?: LucideIcon | ReactNode;\n placeholder?: ReactNode;\n searchPlaceholder?: string;\n emptyState?: ReactNode;\n createLabel?: (search: string) => ReactNode;\n createIcon?: LucideIcon;\n onCreate?: (search: string) => Promise<boolean>;\n buttonProps?: React.ComponentProps<typeof Button>;\n labelProps?: { className?: string };\n iconProps?: { className?: string };\n popoverProps?: { contentClassName?: string };\n shortcutHint?: string;\n caret?: boolean | ReactNode;\n side?: PopoverProps['side'];\n open?: boolean;\n onOpenChange?: (open: boolean) => void;\n onSearchChange?: (search: string) => void;\n shouldFilter?: boolean;\n inputRight?: ReactNode;\n inputClassName?: string;\n optionRight?: (option: ComboboxOption) => ReactNode;\n optionClassName?: string;\n matchTriggerWidth?: boolean;\n hideSearch?: boolean;\n /** Enable stagger animation for options when dropdown opens */\n stagger?: boolean;\n /** Sizing variants */\n size?: 'sm' | 'default' | 'lg' | 'touch';\n}\n\nfunction isMultipleSelection(\n multiple: boolean | undefined,\n setSelected: unknown,\n): setSelected is (tags: ComboboxOption[]) => void {\n return multiple === true;\n}\n\n// Default values - moved outside component to prevent recreation\nconst DEFAULT_COMBOBOX_PLACEHOLDER = 'Select...';\nconst DEFAULT_COMBOBOX_SEARCH_PLACEHOLDER = 'Search...';\nconst DEFAULT_COMBOBOX_SHOULD_FILTER = true;\nconst DEFAULT_COMBOBOX_HIDE_SEARCH = false;\nconst DEFAULT_COMBOBOX_EMPTY_STATE = 'No matches';\n\n// Static classNames - moved outside component to prevent recreation\n// Premium Harmony V2: Semantic color tokens for theming\nconst COMBOBOX_CARET_ICON_BASE_CLASSNAME = 'text-muted-foreground ml-1 size-4 shrink-0';\nconst COMBOBOX_CARET_ICON_TRANSITION_CLASSNAME = 'transition-transform duration-75';\nconst COMBOBOX_CARET_ICON_OPEN_CLASSNAME = 'group-data-[state=open]:rotate-180';\nconst COMBOBOX_CREATE_OPTION_ITEM_BASE_CLASSNAME =\n 'text-foreground flex cursor-pointer items-center gap-3 rounded-md px-3 py-2 text-left text-sm whitespace-nowrap hover:bg-accent hover:text-accent-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 transition-colors';\nconst COMBOBOX_CREATE_OPTION_ITEM_SELECTED_CLASSNAME = 'data-[selected=true]:bg-accent/50';\nconst COMBOBOX_CREATE_OPTION_ICON_CLASSNAME = 'size-4 shrink-0';\nconst COMBOBOX_CREATE_OPTION_ICON_LOADING_CLASSNAME = 'animate-spin';\nconst COMBOBOX_CREATE_OPTION_CONTENT_CLASSNAME = 'grow truncate';\nconst COMBOBOX_COMMAND_WRAPPER_CLASSNAME = 'pointer-events-auto';\nconst COMBOBOX_SEARCH_WRAPPER_CLASSNAME =\n 'border-border bg-background flex items-center overflow-hidden rounded-t-lg border-b';\nconst COMBOBOX_INPUT_BASE_CLASSNAME =\n 'placeholder:text-muted-foreground text-foreground grow border-0 bg-transparent py-3 pr-2 pl-4 outline-none focus:ring-0 focus-visible:outline-none sm:text-sm';\nconst COMBOBOX_INPUT_RIGHT_WRAPPER_CLASSNAME = 'mr-2';\nconst COMBOBOX_SHORTCUT_HINT_CLASSNAME =\n 'border-border bg-muted text-muted-foreground mr-2 hidden shrink-0 rounded border px-2 py-0.5 text-xs font-light md:block';\nconst COMBOBOX_OPTIONS_CONTAINER_BASE_CLASSNAME = 'max-h-[min(50vh,250px)] overflow-auto';\nconst COMBOBOX_OPTIONS_CONTAINER_WITH_CREATE_CLASSNAME = 'max-h-[calc(min(50vh,250px)-3.5rem)]';\nconst COMBOBOX_COMMAND_LIST_CLASSNAME = 'flex w-full min-w-[100px] flex-col gap-1 p-1';\nconst COMBOBOX_LOADING_WRAPPER_CLASSNAME = 'flex h-12 items-center justify-center';\nconst COMBOBOX_LOADING_ICON_CLASSNAME = 'text-muted-foreground size-4 animate-spin';\nconst COMBOBOX_CREATE_STICKY_WRAPPER_CLASSNAME =\n 'border-border bg-popover rounded-b-lg border-t p-1';\nconst COMBOBOX_BUTTON_BASE_CLASSNAME = 'flex gap-2';\nconst COMBOBOX_ICON_WRAPPER_CLASSNAME = 'shrink-0';\nconst COMBOBOX_ICON_CLASSNAME = 'size-4';\nconst COMBOBOX_LABEL_WRAPPER_CLASSNAME = 'min-w-0 grow truncate text-left';\n\nexport const Combobox = memo(function Combobox({\n multiple,\n selected: selectedProp,\n setSelected,\n onSelect,\n options,\n trigger,\n icon: IconProp,\n placeholder = DEFAULT_COMBOBOX_PLACEHOLDER,\n searchPlaceholder = DEFAULT_COMBOBOX_SEARCH_PLACEHOLDER,\n emptyState,\n createLabel,\n createIcon: CreateIcon = Plus,\n onCreate,\n buttonProps,\n labelProps,\n iconProps,\n popoverProps,\n shortcutHint,\n caret,\n side,\n open,\n onOpenChange,\n onSearchChange,\n shouldFilter = DEFAULT_COMBOBOX_SHOULD_FILTER,\n inputRight,\n inputClassName,\n optionRight,\n optionClassName,\n matchTriggerWidth,\n hideSearch = DEFAULT_COMBOBOX_HIDE_SEARCH,\n stagger = false,\n size = 'default',\n children,\n}: ComboboxProps<boolean | undefined, unknown>) {\n const isMultiple = isMultipleSelection(multiple, setSelected);\n const reducedMotion = useReducedMotion();\n const isTouchDevice = useMediaQuery('(pointer: coarse)');\n\n // Auto-adjust size for touch devices if not explicitly set\n const effectiveSize = useMemo(() => {\n if (size === 'touch') return 'touch';\n if (isTouchDevice && size === 'default') return 'touch';\n return size;\n }, [size, isTouchDevice]);\n\n // Ensure selectedProp is an array\n const selected = useMemo(() => {\n if (Array.isArray(selectedProp)) return selectedProp;\n if (selectedProp) return [selectedProp];\n return [];\n }, [selectedProp]);\n\n // Use Mantine's useDisclosure for boolean open/close state\n const [isOpenInternal, { open: openInternal, close: closeInternal }] = useDisclosure(false);\n const isOpen = open ?? isOpenInternal;\n\n // Memoize setIsOpen handler\n const setIsOpen = useCallback(\n (newOpen: boolean) => {\n if (onOpenChange != null) {\n onOpenChange(newOpen);\n } else if (open == null) {\n if (newOpen) openInternal();\n else closeInternal();\n }\n },\n [onOpenChange, open, openInternal, closeInternal],\n );\n\n // Use Mantine's useInputState for simplified search input state management\n const [search, setSearch] = useInputState('');\n const [isCreating, setIsCreating] = useState(false);\n\n // Memoize select handler\n const handleSelect = useCallback(\n (option: ComboboxOption) => {\n onSelect?.(option);\n\n if (!setSelected) return;\n\n if (isMultiple) {\n const isAlreadySelected = selected.some(({ value }) => value === option.value);\n (setSelected as (options: ComboboxOption[]) => void)(\n isAlreadySelected\n ? selected.filter(({ value }) => value !== option.value)\n : [...selected, option],\n );\n } else {\n (setSelected as (option: ComboboxOption | null) => void)(\n selected.length > 0 && selected[0]?.value === option.value ? null : option,\n );\n setIsOpen(false);\n }\n },\n [onSelect, setSelected, isMultiple, selected, setIsOpen],\n );\n\n // Compute sorted options directly without useEffect\n const sortedOptions = useMemo(() => {\n if (!options) return;\n if (search !== '') return options;\n return [\n ...options.filter(o => o.first === true && !selected.some(s => s.value === o.value)),\n ...selected,\n ...options.filter(o => o.first !== true && !selected.some(s => s.value === o.value)),\n ];\n }, [options, search, selected]);\n\n // Reset search when the popover closes\n const handleOpenChange = useCallback(\n (newOpen: boolean) => {\n if (!newOpen) {\n setSearch('');\n }\n setIsOpen?.(newOpen);\n },\n [setIsOpen, setSearch],\n );\n\n // Notify parent of search changes\n const handleSearchChange = useCallback(\n (newSearch: string) => {\n setSearch(newSearch);\n onSearchChange?.(newSearch);\n },\n [onSearchChange, setSearch],\n );\n\n const handleCreate = useCallback(async () => {\n setIsCreating(true);\n const success = await onCreate?.(search);\n if (success) {\n setSearch('');\n setIsOpen(false);\n }\n setIsCreating(false);\n }, [onCreate, search]);\n\n // Memoize create option item\n const createOptionItem = useMemo(\n () => (\n <Command.Item\n className={cn(\n COMBOBOX_CREATE_OPTION_ITEM_BASE_CLASSNAME,\n COMBOBOX_CREATE_OPTION_ITEM_SELECTED_CLASSNAME,\n optionClassName,\n )}\n onSelect={() => void handleCreate()}\n >\n {isCreating ? (\n <Loader2\n className={cn(\n COMBOBOX_CREATE_OPTION_ICON_CLASSNAME,\n COMBOBOX_CREATE_OPTION_ICON_LOADING_CLASSNAME,\n )}\n />\n ) : (\n <CreateIcon className={COMBOBOX_CREATE_OPTION_ICON_CLASSNAME} />\n )}\n <div className={COMBOBOX_CREATE_OPTION_CONTENT_CLASSNAME}>\n {createLabel?.(search) ?? `Create ${search ? `\"${search}\"` : 'new option...'}`}\n </div>\n </Command.Item>\n ),\n [isCreating, search, createLabel, optionClassName, handleCreate],\n );\n\n // Memoize empty content\n const emptyContent = useMemo<ReactNode>(() => {\n if (shouldFilter) {\n return (\n <Empty className=\"text-muted-foreground flex min-h-12 items-center justify-center text-sm\">\n {emptyState ?? DEFAULT_COMBOBOX_EMPTY_STATE}\n </Empty>\n );\n }\n if ((sortedOptions?.length ?? 0) === 0) {\n return (\n <div className=\"text-muted-foreground flex min-h-12 items-center justify-center text-sm\">\n {emptyState ?? DEFAULT_COMBOBOX_EMPTY_STATE}\n </div>\n );\n }\n return null;\n }, [shouldFilter, sortedOptions?.length, emptyState]);\n\n return (\n <Popover\n openPopover={isOpen}\n setOpenPopover={handleOpenChange}\n align=\"start\"\n side={side}\n onWheel={e => {\n // Allows scrolling to work when the popover's in a modal\n e.stopPropagation();\n }}\n popoverContentClassName={cn(\n matchTriggerWidth === true && 'sm:w-[var(--radix-popover-trigger-width)]',\n popoverProps?.contentClassName,\n )}\n data-state={isOpen ? 'open' : 'closed'}\n content={\n <motion.div\n className={COMBOBOX_COMMAND_WRAPPER_CLASSNAME}\n initial={reducedMotion ? undefined : { opacity: 0, scale: 0.96, y: -8 }}\n animate={reducedMotion ? undefined : { opacity: 1, scale: 1, y: 0 }}\n exit={reducedMotion ? undefined : { opacity: 0, scale: 0.96, y: -8 }}\n transition={reducedMotion ? undefined : SPRING_FLUID}\n >\n <Command loop shouldFilter={shouldFilter}>\n {!hideSearch && (\n <div className={COMBOBOX_SEARCH_WRAPPER_CLASSNAME}>\n <Command.Input\n placeholder={searchPlaceholder}\n value={search}\n onValueChange={handleSearchChange}\n className={cn(COMBOBOX_INPUT_BASE_CLASSNAME, inputClassName)}\n onKeyDown={(e: any) => {\n if (e.key === 'Escape' || (e.key === 'Backspace' && !search)) {\n e.preventDefault();\n e.stopPropagation();\n setIsOpen(false);\n }\n }}\n />\n {inputRight != null && (\n <div className={COMBOBOX_INPUT_RIGHT_WRAPPER_CLASSNAME}>{inputRight}</div>\n )}\n {shortcutHint != null && (\n <kbd className={COMBOBOX_SHORTCUT_HINT_CLASSNAME}>{shortcutHint}</kbd>\n )}\n </div>\n )}\n <div\n className={cn(\n COMBOBOX_OPTIONS_CONTAINER_BASE_CLASSNAME,\n onCreate != null && !multiple && COMBOBOX_OPTIONS_CONTAINER_WITH_CREATE_CLASSNAME,\n )}\n >\n <Command.List className={COMBOBOX_COMMAND_LIST_CLASSNAME}>\n {sortedOptions !== undefined ? (\n <>\n {sortedOptions.map((option, index) => (\n <Option\n key={`${String(option.label)}, ${option.value}`}\n option={option}\n multiple={isMultiple}\n selected={selected.some(({ value }) => value === option.value)}\n onSelect={() => handleSelect(option)}\n right={optionRight?.(option)}\n className={optionClassName}\n index={index}\n stagger={stagger ? !reducedMotion : undefined}\n size={effectiveSize}\n />\n ))}\n {/* for multiple selection, the create option item is shown at the bottom of the list */}\n {onCreate != null && multiple === true && search.length > 0 && createOptionItem}\n {emptyContent}\n </>\n ) : (\n // undefined data / explicit loading state\n <Command.Loading>\n <div className={COMBOBOX_LOADING_WRAPPER_CLASSNAME}>\n <Loader2 className={COMBOBOX_LOADING_ICON_CLASSNAME} />\n </div>\n </Command.Loading>\n )}\n </Command.List>\n </div>\n {/* for single selection, the create option item is shown as a sticky item outside of the scroll container */}\n {onCreate != null && !multiple && (\n <div className={COMBOBOX_CREATE_STICKY_WRAPPER_CLASSNAME}>{createOptionItem}</div>\n )}\n </Command>\n </motion.div>\n }\n >\n {trigger ?? (\n <Button\n variant=\"secondary\"\n size={effectiveSize === 'touch' ? 'touch' : (effectiveSize as any)}\n whileTap={reducedMotion ? undefined : { scale: 0.98 }}\n data-state={isOpen ? 'open' : 'closed'}\n {...buttonProps}\n className={cn(buttonProps?.className, COMBOBOX_BUTTON_BASE_CLASSNAME)}\n >\n {IconProp != null && (\n <span className={cn(COMBOBOX_ICON_WRAPPER_CLASSNAME, iconProps?.className)}>\n {isReactNode(IconProp) ? IconProp : <IconProp className={COMBOBOX_ICON_CLASSNAME} />}\n </span>\n )}\n <span className={cn(COMBOBOX_LABEL_WRAPPER_CLASSNAME, labelProps?.className)}>\n {}\n {children ??\n (selected.length > 0 ? selected.map(option => option.label).join(', ') : placeholder)}\n </span>\n {caret != null &&\n (caret === true ? (\n <ChevronDown\n className={cn(\n COMBOBOX_CARET_ICON_BASE_CLASSNAME,\n !reducedMotion && COMBOBOX_CARET_ICON_TRANSITION_CLASSNAME,\n COMBOBOX_CARET_ICON_OPEN_CLASSNAME,\n )}\n />\n ) : (\n caret\n ))}\n </Button>\n )}\n </Popover>\n );\n});\n\n// Static classNames for Option component - moved outside component to prevent recreation\nconst COMBOBOX_OPTION_ITEM_SELECTED_CLASSNAME =\n 'aria-selected:bg-accent aria-selected:text-accent-foreground data-[selected=true]:bg-accent/50';\nconst COMBOBOX_OPTION_ITEM_DISABLED_CLASSNAME =\n 'aria-disabled:pointer-events-none aria-disabled:opacity-50';\nconst COMBOBOX_OPTION_ITEM_FOCUS_CLASSNAME =\n 'focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2';\n// Stagger delay per item (30ms)\nconst STAGGER_DELAY_MS = 0.03;\n// Maximum stagger delay to prevent long waits (caps at 10 items)\nconst MAX_STAGGER_ITEMS = 10;\nconst COMBOBOX_OPTION_CHECKBOX_WRAPPER_CLASSNAME = 'text-muted-foreground shrink-0';\nconst COMBOBOX_OPTION_CHECKBOX_SELECTED_CLASSNAME = 'text-foreground';\nconst COMBOBOX_OPTION_CHECKBOX_ICON_CLASSNAME = 'size-4';\nconst COMBOBOX_OPTION_CONTENT_WRAPPER_CLASSNAME = 'flex min-w-0 grow items-center gap-2';\nconst COMBOBOX_OPTION_ICON_WRAPPER_CLASSNAME = 'text-muted-foreground shrink-0';\nconst COMBOBOX_OPTION_ICON_CLASSNAME = 'size-4';\nconst COMBOBOX_OPTION_LABEL_CLASSNAME = 'grow truncate';\nconst COMBOBOX_OPTION_CHECK_ICON_CLASSNAME = 'text-foreground size-4 shrink-0';\nconst COMBOBOX_OPTION_SEPARATOR_CLASSNAME = 'bg-border -mx-1 my-1 h-px';\n\nconst Option = memo(function Option({\n option,\n onSelect,\n multiple,\n selected,\n right,\n className,\n index,\n stagger,\n size,\n}: {\n option: ComboboxOption;\n onSelect: () => void;\n multiple: boolean;\n selected: boolean;\n right?: ReactNode;\n className?: string;\n index?: number;\n stagger?: boolean;\n size?: 'sm' | 'default' | 'lg' | 'touch';\n}) {\n const hasDisabledTooltip = Boolean(option.disabledTooltip);\n\n // Memoize item className\n const itemClassName = useMemo(\n () =>\n cn(\n 'relative flex cursor-default select-none items-center gap-3 rounded-sm outline-none',\n size === 'sm' && 'px-2 py-1 text-xs',\n size === 'default' && 'px-2 py-1.5 text-sm',\n size === 'lg' && 'px-3 py-2 text-base',\n size === 'touch' && 'min-h-[44px] px-3 py-2.5 text-base md:text-sm',\n COMBOBOX_OPTION_ITEM_SELECTED_CLASSNAME,\n COMBOBOX_OPTION_ITEM_DISABLED_CLASSNAME,\n COMBOBOX_OPTION_ITEM_FOCUS_CLASSNAME,\n className,\n ),\n [size, className],\n );\n\n // Memoize stagger animation delay style\n const staggerDelay = useMemo(() => {\n if (!stagger || index === undefined) return 0;\n return Math.min(index, MAX_STAGGER_ITEMS) * STAGGER_DELAY_MS;\n }, [stagger, index]);\n\n // Memoize checkbox wrapper className\n const checkboxWrapperClassName = useMemo(\n () =>\n cn(\n COMBOBOX_OPTION_CHECKBOX_WRAPPER_CLASSNAME,\n selected && COMBOBOX_OPTION_CHECKBOX_SELECTED_CLASSNAME,\n ),\n [selected],\n );\n\n return (\n <>\n <DisabledTooltip disabledTooltip={option.disabledTooltip}>\n <Command.Item\n asChild\n disabled={hasDisabledTooltip}\n onSelect={onSelect}\n value={String(option.label) + option.value}\n >\n <motion.div\n className={itemClassName}\n data-selected={selected}\n data-disabled={hasDisabledTooltip}\n initial={stagger ? { opacity: 0, x: -4 } : false}\n animate={stagger ? { opacity: 1, x: 0 } : false}\n transition={\n stagger\n ? {\n type: 'spring',\n ...SPRING_TACTILE,\n delay: staggerDelay,\n }\n : undefined\n }\n >\n {multiple ? (\n <div className={checkboxWrapperClassName}>\n {selected ? (\n <SquareCheck className={COMBOBOX_OPTION_CHECKBOX_ICON_CLASSNAME} />\n ) : (\n <Square className={COMBOBOX_OPTION_CHECKBOX_ICON_CLASSNAME} />\n )}\n </div>\n ) : null}\n <div className={COMBOBOX_OPTION_CONTENT_WRAPPER_CLASSNAME}>\n {option.icon != null ? (\n <span className={COMBOBOX_OPTION_ICON_WRAPPER_CLASSNAME}>\n {isReactNode(option.icon) ? (\n option.icon\n ) : (\n <option.icon className={COMBOBOX_OPTION_ICON_CLASSNAME} />\n )}\n </span>\n ) : null}\n <span className={COMBOBOX_OPTION_LABEL_CLASSNAME}>{option.label}</span>\n </div>\n {right}\n {!multiple && selected ? (\n <Check className={COMBOBOX_OPTION_CHECK_ICON_CLASSNAME} />\n ) : null}\n </motion.div>\n </Command.Item>\n </DisabledTooltip>\n {option.separatorAfter === true && (\n <Command.Separator className={COMBOBOX_OPTION_SEPARATOR_CLASSNAME} />\n )}\n </>\n );\n});\nOption.displayName = 'ComboboxOption';\n\nconst DisabledTooltip = memo(function DisabledTooltip({\n children,\n disabledTooltip,\n}: PropsWithChildren<{ disabledTooltip: ReactNode }>) {\n if (disabledTooltip) {\n return (\n <TooltipProvider>\n <Tooltip>\n <TooltipTrigger asChild>\n <div>{children}</div>\n </TooltipTrigger>\n <TooltipContent>{disabledTooltip}</TooltipContent>\n </Tooltip>\n </TooltipProvider>\n );\n }\n return children;\n});\nDisabledTooltip.displayName = 'ComboboxDisabledTooltip';\n\nconst isReactNode = (element: unknown): element is ReactNode => isValidElement(element);\n\n// Custom Empty component because our current cmdk version has an issue with first render\nconst Empty = forwardRef<HTMLDivElement, HTMLProps<HTMLDivElement>>((props, forwardedRef) => {\n const render = useCommandState(state => state.filtered.count === 0);\n\n if (!render) return null;\n // eslint-disable-next-line react/no-unknown-property\n return <div ref={forwardedRef} cmdk-empty=\"\" role=\"presentation\" {...props} />;\n});\nEmpty.displayName = 'Empty';\n"],"mappings":"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"}
|