@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,1149 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { t as cn } from "./utils-D2bGp2p_.mjs";
|
|
3
|
+
import { a as SPRING_TACTILE, i as SPRING_GENTLE, r as SPRING_FLUID } from "./motion-zelaDelJ.mjs";
|
|
4
|
+
import { AI_FOCUS, AI_ICON, AI_NESTED_RADIUS, AI_SPACING, AI_TEXT, AI_TRANSITION } from "./components-ai-elements-constants.mjs";
|
|
5
|
+
import { t as Button } from "./button-DVOrrZLw.mjs";
|
|
6
|
+
import { a as DropdownMenuItem, h as DropdownMenuTrigger, r as DropdownMenuContent, t as DropdownMenu } from "./dropdown-menu-91g1g_Cl.mjs";
|
|
7
|
+
import { a as CommandInput, c as CommandSeparator, i as CommandGroup, o as CommandItem, r as CommandEmpty, s as CommandList, t as Command } from "./command-xK3X_A9t.mjs";
|
|
8
|
+
import { n as HoverCardContent, r as HoverCardTrigger, t as HoverCard } from "./hover-card-nn4fjJOh.mjs";
|
|
9
|
+
import { n as InputGroupAddon, o as InputGroupTextarea, t as InputGroup } from "./input-group-CTBpkGI9.mjs";
|
|
10
|
+
import { i as SelectItem, l as SelectTrigger, n as SelectContent, t as Select, u as SelectValue } from "./select-DI6PzHN3.mjs";
|
|
11
|
+
import { Children, createContext, forwardRef, useCallback, useContext, useEffect, useMemo, useRef, useState } from "react";
|
|
12
|
+
import { useClickOutside, useClickOutside as usePromptInputClickOutside, useFocusReturn, useFocusReturn as usePromptInputFocusReturn, useHotkeys, useHotkeys as usePromptInputHotkeys, useIdle, useIdle as usePromptInputIdle, useMediaQuery, useMediaQuery as usePromptInputMediaQuery, useMergedRef, useMergedRef as usePromptInputMergedRef, useReducedMotion, useReducedMotion as usePromptInputReducedMotion, useResizeObserver, useUncontrolled, useUncontrolled as usePromptInputUncontrolled } from "@mantine/hooks";
|
|
13
|
+
import { cva } from "class-variance-authority";
|
|
14
|
+
import { ArrowUpIcon, ImageIcon, Loader2Icon, MicIcon, PaperclipIcon, PlusIcon, SlidersHorizontalIcon, SquareIcon, WandSparklesIcon, XIcon } from "lucide-react";
|
|
15
|
+
import { AnimatePresence, motion } from "motion/react";
|
|
16
|
+
import { Fragment as Fragment$1, jsx, jsxs } from "react/jsx-runtime";
|
|
17
|
+
import { Logger } from "@repo/shared";
|
|
18
|
+
import { nanoid } from "nanoid";
|
|
19
|
+
import { useDropzone } from "react-dropzone";
|
|
20
|
+
|
|
21
|
+
//#region src/components/ai-elements/prompt-input/prompt-input.tsx
|
|
22
|
+
/**
|
|
23
|
+
* @fileoverview PromptInput Component - Premium Harmony V2
|
|
24
|
+
*
|
|
25
|
+
* A comprehensive AI chat input component with file attachments, speech-to-text,
|
|
26
|
+
* and extensible action menus. Supports both standalone and provider-controlled modes.
|
|
27
|
+
*
|
|
28
|
+
* Features:
|
|
29
|
+
* - Premium Harmony V2 spring physics animations with reduced motion support
|
|
30
|
+
* - Touch vs desktop detection with adaptive sizing and 44px minimum touch targets
|
|
31
|
+
* - CVA variants for button styles (default, outline, ghost, filled)
|
|
32
|
+
* - react-dropzone integration for drag & drop file uploads
|
|
33
|
+
* - Auto-expanding textarea with useTextareaAutosize hook
|
|
34
|
+
* - Web Speech API integration for voice input
|
|
35
|
+
* - Provider pattern for shared state across multiple inputs
|
|
36
|
+
* - Inline edit mode with glow border effect and focus pulse animation
|
|
37
|
+
* - Draft auto-save on idle with Mantine hooks integration
|
|
38
|
+
* - Keyboard shortcuts (Cmd/Ctrl+Enter submit, Backspace remove attachment, Escape cancel)
|
|
39
|
+
* - Paste and drop file handling with blob URL conversion
|
|
40
|
+
*
|
|
41
|
+
* @module @od-oneapp/uni-ui/components/ai-elements/prompt-input
|
|
42
|
+
*
|
|
43
|
+
* @component PromptInput, PromptInputProvider, PromptInputTextarea, PromptInputHeader, PromptInputFooter, PromptInputTools, PromptInputButton, PromptInputSubmit, PromptInputSpeechButton, PromptInputAttachments, PromptInputAttachment, PromptInputActionMenu, PromptInputSelect, PromptInputCommand
|
|
44
|
+
*
|
|
45
|
+
* @useCases
|
|
46
|
+
* - AI chat interfaces with multi-modal input (text + voice + files)
|
|
47
|
+
* - Inline message editing with cancel/submit actions
|
|
48
|
+
* - Multi-input forms sharing attachments via provider pattern
|
|
49
|
+
* - Voice-to-text dictation for accessibility
|
|
50
|
+
* - Drag-and-drop file uploads with visual feedback
|
|
51
|
+
* - Command palette integration for power users
|
|
52
|
+
* - Mobile-optimized touch targets and gestures
|
|
53
|
+
*
|
|
54
|
+
* @subcomponents
|
|
55
|
+
* - PromptInputProvider - Global state provider (optional)
|
|
56
|
+
* - PromptInput - Form container with drag & drop support
|
|
57
|
+
* - PromptInputTextarea - Auto-expanding text input
|
|
58
|
+
* - PromptInputHeader - Header section for attachments
|
|
59
|
+
* - PromptInputFooter - Footer section with tools and submit
|
|
60
|
+
* - PromptInputTools - Tool buttons container (left side)
|
|
61
|
+
* - PromptInputActions - Action buttons container (right side)
|
|
62
|
+
* - PromptInputButton - Styled button with CVA variants
|
|
63
|
+
* - PromptInputSubmit - Submit button with status indicator
|
|
64
|
+
* - PromptInputCancelButton - Cancel button for inline mode
|
|
65
|
+
* - PromptInputSpeechButton - Voice input toggle
|
|
66
|
+
* - PromptInputAttachments - File attachments list
|
|
67
|
+
* - PromptInputAttachment - Individual attachment display with preview
|
|
68
|
+
* - PromptInputActionMenu - Dropdown for additional actions
|
|
69
|
+
* - PromptInputSelect - Dropdown select for options
|
|
70
|
+
* - PromptInputCommand - Command palette integration
|
|
71
|
+
*
|
|
72
|
+
* @variants
|
|
73
|
+
* - variant: default (active), outline (tools), ghost (mic), filled (submit)
|
|
74
|
+
*
|
|
75
|
+
* @example
|
|
76
|
+
* <PromptInput onSubmit={handleSubmit} accept="image/*" multiple>
|
|
77
|
+
* <PromptInputAttachments>
|
|
78
|
+
* {(file) => <PromptInputAttachment data={file} />}
|
|
79
|
+
* </PromptInputAttachments>
|
|
80
|
+
* <PromptInputTextarea placeholder="Ask anything..." />
|
|
81
|
+
* <PromptInputFooter>
|
|
82
|
+
* <PromptInputTools>
|
|
83
|
+
* <PromptInputActionMenu>
|
|
84
|
+
* <PromptInputActionMenuTrigger />
|
|
85
|
+
* <PromptInputActionMenuContent>
|
|
86
|
+
* <PromptInputActionAddAttachments />
|
|
87
|
+
* </PromptInputActionMenuContent>
|
|
88
|
+
* </PromptInputActionMenu>
|
|
89
|
+
* </PromptInputTools>
|
|
90
|
+
* <PromptInputActions>
|
|
91
|
+
* <PromptInputSpeechButton />
|
|
92
|
+
* <PromptInputSubmit status={chatStatus} />
|
|
93
|
+
* </PromptInputActions>
|
|
94
|
+
* </PromptInputFooter>
|
|
95
|
+
* </PromptInput>
|
|
96
|
+
*/
|
|
97
|
+
const logger = new Logger("uni-ui:prompt-input");
|
|
98
|
+
/**
|
|
99
|
+
* Converts a blob URL to a data URL by fetching and reading the blob
|
|
100
|
+
*/
|
|
101
|
+
async function convertBlobUrlToDataUrl(url) {
|
|
102
|
+
const blob = await (await fetch(url)).blob();
|
|
103
|
+
return new Promise((resolve, reject) => {
|
|
104
|
+
const reader = new FileReader();
|
|
105
|
+
reader.onloadend = () => resolve(reader.result);
|
|
106
|
+
reader.onerror = reject;
|
|
107
|
+
reader.readAsDataURL(blob);
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
/**
|
|
111
|
+
* Auto-resize textarea based on content using scrollHeight
|
|
112
|
+
* Similar to Mantine's Textarea autosize behavior
|
|
113
|
+
*
|
|
114
|
+
* @param ref - Ref to the textarea element
|
|
115
|
+
* @param value - Current textarea value (triggers resize on change)
|
|
116
|
+
* @param options - Configuration for min/max rows
|
|
117
|
+
*/
|
|
118
|
+
function useTextareaAutosize(ref, value, options = {}) {
|
|
119
|
+
const { minRows = 1, maxRows, lineHeight = 20 } = options;
|
|
120
|
+
const [containerRef, containerRect] = useResizeObserver();
|
|
121
|
+
const adjustHeight = useCallback(() => {
|
|
122
|
+
const textarea = ref.current;
|
|
123
|
+
if (!textarea) return;
|
|
124
|
+
const scrollTop = window.scrollY;
|
|
125
|
+
textarea.style.height = "auto";
|
|
126
|
+
textarea.style.overflow = "hidden";
|
|
127
|
+
const minHeight = minRows * lineHeight;
|
|
128
|
+
const maxHeight = maxRows ? maxRows * lineHeight : Infinity;
|
|
129
|
+
const { scrollHeight } = textarea;
|
|
130
|
+
const newHeight = Math.min(Math.max(scrollHeight, minHeight), maxHeight);
|
|
131
|
+
textarea.style.height = `${newHeight}px`;
|
|
132
|
+
if (maxRows && scrollHeight > maxHeight) textarea.style.overflow = "auto";
|
|
133
|
+
window.scrollTo(0, scrollTop);
|
|
134
|
+
}, [
|
|
135
|
+
ref,
|
|
136
|
+
minRows,
|
|
137
|
+
maxRows,
|
|
138
|
+
lineHeight
|
|
139
|
+
]);
|
|
140
|
+
useEffect(() => {
|
|
141
|
+
adjustHeight();
|
|
142
|
+
}, [value, adjustHeight]);
|
|
143
|
+
useEffect(() => {
|
|
144
|
+
if (containerRect.width > 0) adjustHeight();
|
|
145
|
+
}, [containerRect.width, adjustHeight]);
|
|
146
|
+
useEffect(() => {
|
|
147
|
+
const timer = setTimeout(adjustHeight, 0);
|
|
148
|
+
return () => clearTimeout(timer);
|
|
149
|
+
}, [adjustHeight]);
|
|
150
|
+
return {
|
|
151
|
+
containerRef,
|
|
152
|
+
adjustHeight
|
|
153
|
+
};
|
|
154
|
+
}
|
|
155
|
+
const PromptInputController = createContext(null);
|
|
156
|
+
const ProviderAttachmentsContext = createContext(null);
|
|
157
|
+
const usePromptInputController = () => {
|
|
158
|
+
const ctx = useContext(PromptInputController);
|
|
159
|
+
if (!ctx) throw new Error("Wrap your component inside <PromptInputProvider> to use usePromptInputController().");
|
|
160
|
+
return ctx;
|
|
161
|
+
};
|
|
162
|
+
const useOptionalPromptInputController = () => useContext(PromptInputController);
|
|
163
|
+
const useProviderAttachments = () => {
|
|
164
|
+
const ctx = useContext(ProviderAttachmentsContext);
|
|
165
|
+
if (!ctx) throw new Error("Wrap your component inside <PromptInputProvider> to use useProviderAttachments().");
|
|
166
|
+
return ctx;
|
|
167
|
+
};
|
|
168
|
+
const useOptionalProviderAttachments = () => useContext(ProviderAttachmentsContext);
|
|
169
|
+
/**
|
|
170
|
+
* Provides a shared PromptInput controller and attachments context so descendant PromptInput components can share text input and file attachments.
|
|
171
|
+
*
|
|
172
|
+
* @param initialInput - Initial text value for the shared input (defaults to an empty string)
|
|
173
|
+
* @param onSaveDraft - Callback invoked when user goes idle to auto-save draft
|
|
174
|
+
* @param idleTimeout - Time in milliseconds before triggering draft save (default: 5000)
|
|
175
|
+
* @param children - React children that will consume the provider
|
|
176
|
+
*/
|
|
177
|
+
function PromptInputProvider({ initialInput: initialTextInput = "", onSaveDraft, idleTimeout = 5e3, children }) {
|
|
178
|
+
const [textInput, setTextInput] = useState(initialTextInput);
|
|
179
|
+
const clearInput = useCallback(() => setTextInput(""), []);
|
|
180
|
+
const isIdle = useIdle(idleTimeout);
|
|
181
|
+
const lastSavedRef = useRef("");
|
|
182
|
+
useEffect(() => {
|
|
183
|
+
if (isIdle && textInput && textInput !== lastSavedRef.current && onSaveDraft) {
|
|
184
|
+
onSaveDraft(textInput);
|
|
185
|
+
lastSavedRef.current = textInput;
|
|
186
|
+
}
|
|
187
|
+
}, [
|
|
188
|
+
isIdle,
|
|
189
|
+
textInput,
|
|
190
|
+
onSaveDraft
|
|
191
|
+
]);
|
|
192
|
+
const [attachements, setAttachements] = useState([]);
|
|
193
|
+
const fileInputRef = useRef(null);
|
|
194
|
+
const openRef = useRef(() => {});
|
|
195
|
+
const add = useCallback((files) => {
|
|
196
|
+
const incoming = [...files];
|
|
197
|
+
if (incoming.length === 0) return;
|
|
198
|
+
setAttachements((prev) => [...prev, ...incoming.map((file) => ({
|
|
199
|
+
id: nanoid(),
|
|
200
|
+
type: "file",
|
|
201
|
+
url: URL.createObjectURL(file),
|
|
202
|
+
mediaType: file.type,
|
|
203
|
+
filename: file.name
|
|
204
|
+
}))]);
|
|
205
|
+
}, []);
|
|
206
|
+
const remove = useCallback((id) => {
|
|
207
|
+
setAttachements((prev) => {
|
|
208
|
+
const found = prev.find((f) => f.id === id);
|
|
209
|
+
if (found?.url) URL.revokeObjectURL(found.url);
|
|
210
|
+
return prev.filter((f) => f.id !== id);
|
|
211
|
+
});
|
|
212
|
+
}, []);
|
|
213
|
+
const clear = useCallback(() => {
|
|
214
|
+
setAttachements((prev) => {
|
|
215
|
+
for (const f of prev) if (f.url) URL.revokeObjectURL(f.url);
|
|
216
|
+
return [];
|
|
217
|
+
});
|
|
218
|
+
}, []);
|
|
219
|
+
const openFileDialog = useCallback(() => {
|
|
220
|
+
openRef.current();
|
|
221
|
+
}, []);
|
|
222
|
+
const [dropzoneState, _setDropzoneState] = useState({
|
|
223
|
+
isDragActive: false,
|
|
224
|
+
isDragAccept: false,
|
|
225
|
+
isDragReject: false
|
|
226
|
+
});
|
|
227
|
+
const attachments = useMemo(() => ({
|
|
228
|
+
files: attachements,
|
|
229
|
+
add,
|
|
230
|
+
remove,
|
|
231
|
+
clear,
|
|
232
|
+
openFileDialog,
|
|
233
|
+
fileInputRef,
|
|
234
|
+
...dropzoneState
|
|
235
|
+
}), [
|
|
236
|
+
attachements,
|
|
237
|
+
add,
|
|
238
|
+
remove,
|
|
239
|
+
clear,
|
|
240
|
+
openFileDialog,
|
|
241
|
+
dropzoneState
|
|
242
|
+
]);
|
|
243
|
+
const registerFileInput = useCallback((ref, open) => {
|
|
244
|
+
fileInputRef.current = ref.current;
|
|
245
|
+
openRef.current = open;
|
|
246
|
+
}, []);
|
|
247
|
+
const controller = useMemo(() => ({
|
|
248
|
+
textInput: {
|
|
249
|
+
value: textInput,
|
|
250
|
+
setInput: setTextInput,
|
|
251
|
+
clear: clearInput
|
|
252
|
+
},
|
|
253
|
+
attachments,
|
|
254
|
+
registerFileInput
|
|
255
|
+
}), [
|
|
256
|
+
textInput,
|
|
257
|
+
clearInput,
|
|
258
|
+
attachments,
|
|
259
|
+
registerFileInput
|
|
260
|
+
]);
|
|
261
|
+
return /* @__PURE__ */ jsx(PromptInputController.Provider, {
|
|
262
|
+
value: controller,
|
|
263
|
+
children: /* @__PURE__ */ jsx(ProviderAttachmentsContext.Provider, {
|
|
264
|
+
value: attachments,
|
|
265
|
+
children
|
|
266
|
+
})
|
|
267
|
+
});
|
|
268
|
+
}
|
|
269
|
+
const LocalAttachmentsContext = createContext(null);
|
|
270
|
+
const InlineModeContext = createContext({ inline: false });
|
|
271
|
+
/**
|
|
272
|
+
* Hook to access inline mode state from child components
|
|
273
|
+
*/
|
|
274
|
+
const usePromptInputInlineMode = () => useContext(InlineModeContext);
|
|
275
|
+
const usePromptInputAttachments = () => {
|
|
276
|
+
const provider = useOptionalProviderAttachments();
|
|
277
|
+
const local = useContext(LocalAttachmentsContext);
|
|
278
|
+
const context = provider ?? local;
|
|
279
|
+
if (!context) throw new Error("usePromptInputAttachments must be used within a PromptInput or PromptInputProvider");
|
|
280
|
+
return context;
|
|
281
|
+
};
|
|
282
|
+
/**
|
|
283
|
+
* Hook to access the dropzone state from within PromptInput.
|
|
284
|
+
* Useful for building custom drag-and-drop UI overlays.
|
|
285
|
+
*
|
|
286
|
+
* @example
|
|
287
|
+
* ```tsx
|
|
288
|
+
* function MyDropzone() {
|
|
289
|
+
* const { isDragActive, isDragAccept, isDragReject } = usePromptInputDropzone();
|
|
290
|
+
* return (
|
|
291
|
+
* <div className={isDragActive ? 'bg-primary/10' : ''}>
|
|
292
|
+
* {isDragActive ? 'Drop files here...' : 'Drag files to upload'}
|
|
293
|
+
* </div>
|
|
294
|
+
* );
|
|
295
|
+
* }
|
|
296
|
+
* ```
|
|
297
|
+
*/
|
|
298
|
+
const usePromptInputDropzone = () => {
|
|
299
|
+
const ctx = usePromptInputAttachments();
|
|
300
|
+
return {
|
|
301
|
+
isDragActive: ctx.isDragActive,
|
|
302
|
+
isDragAccept: ctx.isDragAccept,
|
|
303
|
+
isDragReject: ctx.isDragReject
|
|
304
|
+
};
|
|
305
|
+
};
|
|
306
|
+
function PromptInputAttachment({ data, className, ...props }) {
|
|
307
|
+
const attachments = usePromptInputAttachments();
|
|
308
|
+
const reducedMotion = useReducedMotion();
|
|
309
|
+
const filename = data.filename ?? "";
|
|
310
|
+
const mediaType = data.mediaType.startsWith("image/") && data.url ? "image" : "file";
|
|
311
|
+
const isImage = mediaType === "image";
|
|
312
|
+
const attachmentLabel = filename ?? (isImage ? "Image" : "Attachment");
|
|
313
|
+
return /* @__PURE__ */ jsxs(PromptInputHoverCard, { children: [/* @__PURE__ */ jsx(HoverCardTrigger, {
|
|
314
|
+
asChild: true,
|
|
315
|
+
children: /* @__PURE__ */ jsxs("div", {
|
|
316
|
+
className: cn("group border-border hover:bg-accent hover:text-accent-foreground dark:hover:bg-accent/50 relative flex h-8 cursor-default items-center gap-1.5 border px-1.5 font-medium select-none", AI_NESTED_RADIUS, AI_TEXT.sm, reducedMotion ? "transition-none" : AI_TRANSITION.all, className),
|
|
317
|
+
"data-type": mediaType,
|
|
318
|
+
"data-filename": filename,
|
|
319
|
+
...props,
|
|
320
|
+
children: [/* @__PURE__ */ jsxs("div", {
|
|
321
|
+
className: "relative size-5 shrink-0",
|
|
322
|
+
children: [/* @__PURE__ */ jsx("div", {
|
|
323
|
+
className: "bg-background absolute inset-0 flex size-5 items-center justify-center overflow-hidden rounded transition-opacity group-hover:opacity-0",
|
|
324
|
+
children: isImage ? /* @__PURE__ */ jsx("img", {
|
|
325
|
+
alt: filename || "attachment",
|
|
326
|
+
className: "size-5 object-cover",
|
|
327
|
+
height: 20,
|
|
328
|
+
src: data.url,
|
|
329
|
+
width: 20
|
|
330
|
+
}) : /* @__PURE__ */ jsx("div", {
|
|
331
|
+
className: "text-muted-foreground flex size-5 items-center justify-center",
|
|
332
|
+
children: /* @__PURE__ */ jsx(PaperclipIcon, { className: "size-3" })
|
|
333
|
+
})
|
|
334
|
+
}), /* @__PURE__ */ jsxs(Button, {
|
|
335
|
+
"aria-label": "Remove attachment",
|
|
336
|
+
className: "absolute inset-0 size-5 cursor-pointer rounded p-0 opacity-0 transition-opacity group-hover:pointer-events-auto group-hover:opacity-100 [&>svg]:size-2.5",
|
|
337
|
+
onClick: (e) => {
|
|
338
|
+
e.stopPropagation();
|
|
339
|
+
attachments.remove(data.id);
|
|
340
|
+
},
|
|
341
|
+
type: "button",
|
|
342
|
+
variant: "ghost",
|
|
343
|
+
children: [/* @__PURE__ */ jsx(XIcon, {}), /* @__PURE__ */ jsx("span", {
|
|
344
|
+
className: "sr-only",
|
|
345
|
+
children: "Remove"
|
|
346
|
+
})]
|
|
347
|
+
})]
|
|
348
|
+
}), /* @__PURE__ */ jsx("span", {
|
|
349
|
+
className: "flex-1 truncate",
|
|
350
|
+
children: attachmentLabel
|
|
351
|
+
})]
|
|
352
|
+
}, data.id)
|
|
353
|
+
}), /* @__PURE__ */ jsx(PromptInputHoverCardContent, {
|
|
354
|
+
className: "w-auto p-2",
|
|
355
|
+
children: /* @__PURE__ */ jsxs("div", {
|
|
356
|
+
className: "w-auto space-y-3",
|
|
357
|
+
children: [isImage ? /* @__PURE__ */ jsx("div", {
|
|
358
|
+
className: "flex max-h-96 w-96 items-center justify-center overflow-hidden rounded-md border",
|
|
359
|
+
children: /* @__PURE__ */ jsx("img", {
|
|
360
|
+
alt: filename || "attachment preview",
|
|
361
|
+
className: "max-h-full max-w-full object-contain",
|
|
362
|
+
height: 384,
|
|
363
|
+
src: data.url,
|
|
364
|
+
width: 448
|
|
365
|
+
})
|
|
366
|
+
}) : null, /* @__PURE__ */ jsx("div", {
|
|
367
|
+
className: "flex items-center gap-2.5",
|
|
368
|
+
children: /* @__PURE__ */ jsxs("div", {
|
|
369
|
+
className: "min-w-0 flex-1 space-y-1 px-0.5",
|
|
370
|
+
children: [/* @__PURE__ */ jsx("h4", {
|
|
371
|
+
className: "truncate text-sm leading-none font-semibold",
|
|
372
|
+
children: filename ?? (isImage ? "Image" : "Attachment")
|
|
373
|
+
}), data.mediaType ? /* @__PURE__ */ jsx("p", {
|
|
374
|
+
className: "text-muted-foreground truncate font-mono text-xs",
|
|
375
|
+
children: data.mediaType
|
|
376
|
+
}) : null]
|
|
377
|
+
})
|
|
378
|
+
})]
|
|
379
|
+
})
|
|
380
|
+
})] });
|
|
381
|
+
}
|
|
382
|
+
function PromptInputAttachments({ children, className, ...props }) {
|
|
383
|
+
const attachments = usePromptInputAttachments();
|
|
384
|
+
const reducedMotion = useReducedMotion();
|
|
385
|
+
const itemVariants = useMemo(() => ({
|
|
386
|
+
initial: {
|
|
387
|
+
scale: .8,
|
|
388
|
+
opacity: 0
|
|
389
|
+
},
|
|
390
|
+
animate: {
|
|
391
|
+
scale: 1,
|
|
392
|
+
opacity: 1,
|
|
393
|
+
transition: reducedMotion ? { duration: 0 } : SPRING_GENTLE
|
|
394
|
+
},
|
|
395
|
+
exit: {
|
|
396
|
+
scale: .8,
|
|
397
|
+
opacity: 0,
|
|
398
|
+
transition: reducedMotion ? { duration: 0 } : SPRING_FLUID
|
|
399
|
+
}
|
|
400
|
+
}), [reducedMotion]);
|
|
401
|
+
if (!attachments.files.length) return null;
|
|
402
|
+
return /* @__PURE__ */ jsx("div", {
|
|
403
|
+
className: cn("flex flex-wrap items-center", AI_SPACING.xs, "p-3", className),
|
|
404
|
+
...props,
|
|
405
|
+
children: /* @__PURE__ */ jsx(AnimatePresence, {
|
|
406
|
+
mode: "popLayout",
|
|
407
|
+
initial: false,
|
|
408
|
+
children: attachments.files.map((file) => /* @__PURE__ */ jsx(motion.div, {
|
|
409
|
+
variants: itemVariants,
|
|
410
|
+
initial: "initial",
|
|
411
|
+
animate: "animate",
|
|
412
|
+
exit: "exit",
|
|
413
|
+
layout: !reducedMotion,
|
|
414
|
+
children: children(file)
|
|
415
|
+
}, file.id))
|
|
416
|
+
})
|
|
417
|
+
});
|
|
418
|
+
}
|
|
419
|
+
const PromptInputActionAddAttachments = ({ label = "Add photos or files", ...props }) => {
|
|
420
|
+
const attachments = usePromptInputAttachments();
|
|
421
|
+
return /* @__PURE__ */ jsxs(DropdownMenuItem, {
|
|
422
|
+
...props,
|
|
423
|
+
onSelect: (e) => {
|
|
424
|
+
e.preventDefault();
|
|
425
|
+
attachments.openFileDialog();
|
|
426
|
+
},
|
|
427
|
+
children: [
|
|
428
|
+
/* @__PURE__ */ jsx(ImageIcon, { className: cn("mr-2", AI_ICON.md) }),
|
|
429
|
+
" ",
|
|
430
|
+
label
|
|
431
|
+
]
|
|
432
|
+
});
|
|
433
|
+
};
|
|
434
|
+
const PromptInput = ({ className, accept, multiple, globalDrop, syncHiddenInput, maxFiles, maxFileSize, maxFileSizeMB, onError, onSubmit, inline = false, onCancel, children, ...props }) => {
|
|
435
|
+
const effectiveMaxFileSize = maxFileSizeMB ? maxFileSizeMB * 1024 * 1024 : maxFileSize;
|
|
436
|
+
const controller = useOptionalPromptInputController();
|
|
437
|
+
const usingProvider = Boolean(controller);
|
|
438
|
+
const reducedMotion = useReducedMotion();
|
|
439
|
+
const inlineModeValue = useMemo(() => ({
|
|
440
|
+
inline,
|
|
441
|
+
onCancel
|
|
442
|
+
}), [inline, onCancel]);
|
|
443
|
+
const inputRef = useRef(null);
|
|
444
|
+
const anchorRef = useRef(null);
|
|
445
|
+
const formRef = useRef(null);
|
|
446
|
+
useEffect(() => {
|
|
447
|
+
const root = anchorRef.current?.closest("form");
|
|
448
|
+
if (root instanceof HTMLFormElement) formRef.current = root;
|
|
449
|
+
}, []);
|
|
450
|
+
const [items, setItems] = useState([]);
|
|
451
|
+
const files = usingProvider && controller ? controller.attachments.files : items;
|
|
452
|
+
useCallback(() => {
|
|
453
|
+
inputRef.current?.click();
|
|
454
|
+
}, []);
|
|
455
|
+
const matchesAccept = useCallback((f) => {
|
|
456
|
+
if (!accept || accept.trim() === "") return true;
|
|
457
|
+
if (accept.includes("image/*")) return f.type.startsWith("image/");
|
|
458
|
+
return true;
|
|
459
|
+
}, [accept]);
|
|
460
|
+
const addLocal = useCallback((fileList) => {
|
|
461
|
+
const incoming = [...fileList];
|
|
462
|
+
const accepted = incoming.filter((f) => matchesAccept(f));
|
|
463
|
+
if (incoming.length && accepted.length === 0) {
|
|
464
|
+
onError?.({
|
|
465
|
+
code: "accept",
|
|
466
|
+
message: "No files match the accepted types."
|
|
467
|
+
});
|
|
468
|
+
return;
|
|
469
|
+
}
|
|
470
|
+
const sized = accepted.filter((f) => effectiveMaxFileSize ? f.size <= effectiveMaxFileSize : true);
|
|
471
|
+
if (accepted.length > 0 && sized.length === 0) {
|
|
472
|
+
onError?.({
|
|
473
|
+
code: "max_file_size",
|
|
474
|
+
message: "All files exceed the maximum size."
|
|
475
|
+
});
|
|
476
|
+
return;
|
|
477
|
+
}
|
|
478
|
+
setItems((prev) => {
|
|
479
|
+
const capacity = typeof maxFiles === "number" ? Math.max(0, maxFiles - prev.length) : void 0;
|
|
480
|
+
const capped = typeof capacity === "number" ? sized.slice(0, capacity) : sized;
|
|
481
|
+
if (typeof capacity === "number" && sized.length > capacity) onError?.({
|
|
482
|
+
code: "max_files",
|
|
483
|
+
message: "Too many files. Some were not added."
|
|
484
|
+
});
|
|
485
|
+
const next = capped.map((file) => ({
|
|
486
|
+
id: nanoid(),
|
|
487
|
+
type: "file",
|
|
488
|
+
url: URL.createObjectURL(file),
|
|
489
|
+
mediaType: file.type,
|
|
490
|
+
filename: file.name
|
|
491
|
+
}));
|
|
492
|
+
return [...prev, ...next];
|
|
493
|
+
});
|
|
494
|
+
}, [
|
|
495
|
+
matchesAccept,
|
|
496
|
+
maxFiles,
|
|
497
|
+
effectiveMaxFileSize,
|
|
498
|
+
onError
|
|
499
|
+
]);
|
|
500
|
+
const removeLocal = useCallback((id) => {
|
|
501
|
+
setItems((prev) => {
|
|
502
|
+
const found = prev.find((file) => file.id === id);
|
|
503
|
+
if (found?.url) URL.revokeObjectURL(found.url);
|
|
504
|
+
return prev.filter((file) => file.id !== id);
|
|
505
|
+
});
|
|
506
|
+
}, []);
|
|
507
|
+
const clearLocal = useCallback(() => {
|
|
508
|
+
setItems((prev) => {
|
|
509
|
+
for (const file of prev) if (file.url) URL.revokeObjectURL(file.url);
|
|
510
|
+
return [];
|
|
511
|
+
});
|
|
512
|
+
}, []);
|
|
513
|
+
const add = useMemo(() => controller ? (files) => controller.attachments.add(files) : addLocal, [controller, addLocal]);
|
|
514
|
+
const remove = useMemo(() => controller ? (id) => controller.attachments.remove(id) : removeLocal, [controller, removeLocal]);
|
|
515
|
+
const clear = useMemo(() => controller ? () => controller.attachments.clear() : clearLocal, [controller, clearLocal]);
|
|
516
|
+
useEffect(() => {
|
|
517
|
+
if (syncHiddenInput && inputRef.current && files.length === 0) inputRef.current.value = "";
|
|
518
|
+
}, [files, syncHiddenInput]);
|
|
519
|
+
const onDrop = useCallback((acceptedFiles, fileRejections) => {
|
|
520
|
+
if (fileRejections.length > 0) {
|
|
521
|
+
const firstRejection = fileRejections[0];
|
|
522
|
+
if (firstRejection) {
|
|
523
|
+
const errorCode = firstRejection.errors[0]?.code;
|
|
524
|
+
if (errorCode === "file-invalid-type") onError?.({
|
|
525
|
+
code: "accept",
|
|
526
|
+
message: "File type not accepted."
|
|
527
|
+
});
|
|
528
|
+
else if (errorCode === "file-too-large") onError?.({
|
|
529
|
+
code: "max_file_size",
|
|
530
|
+
message: "File exceeds the maximum size."
|
|
531
|
+
});
|
|
532
|
+
else if (errorCode === "too-many-files") onError?.({
|
|
533
|
+
code: "max_files",
|
|
534
|
+
message: "Too many files."
|
|
535
|
+
});
|
|
536
|
+
}
|
|
537
|
+
}
|
|
538
|
+
if (acceptedFiles.length > 0) add(acceptedFiles);
|
|
539
|
+
}, [add, onError]);
|
|
540
|
+
const { getRootProps, getInputProps, isDragActive, isDragAccept, isDragReject, open: dropzoneOpen } = useDropzone(useMemo(() => ({
|
|
541
|
+
onDrop,
|
|
542
|
+
accept: accept ? accept.split(",").reduce((acc, type) => {
|
|
543
|
+
const trimmed = type.trim();
|
|
544
|
+
if (trimmed.includes("/*")) acc[trimmed] = [];
|
|
545
|
+
else acc[trimmed] = [];
|
|
546
|
+
return acc;
|
|
547
|
+
}, {}) : void 0,
|
|
548
|
+
multiple: multiple ?? true,
|
|
549
|
+
maxFiles,
|
|
550
|
+
maxSize: effectiveMaxFileSize,
|
|
551
|
+
noClick: true,
|
|
552
|
+
noKeyboard: true,
|
|
553
|
+
preventDropOnDocument: !globalDrop
|
|
554
|
+
}), [
|
|
555
|
+
onDrop,
|
|
556
|
+
accept,
|
|
557
|
+
multiple,
|
|
558
|
+
maxFiles,
|
|
559
|
+
effectiveMaxFileSize,
|
|
560
|
+
globalDrop
|
|
561
|
+
]));
|
|
562
|
+
const effectiveOpenFileDialog = useCallback(() => {
|
|
563
|
+
dropzoneOpen();
|
|
564
|
+
}, [dropzoneOpen]);
|
|
565
|
+
useEffect(() => {
|
|
566
|
+
if (!usingProvider || !controller) return;
|
|
567
|
+
controller.registerFileInput(inputRef, effectiveOpenFileDialog);
|
|
568
|
+
}, [
|
|
569
|
+
usingProvider,
|
|
570
|
+
controller,
|
|
571
|
+
effectiveOpenFileDialog
|
|
572
|
+
]);
|
|
573
|
+
useEffect(() => () => {
|
|
574
|
+
if (!usingProvider) {
|
|
575
|
+
for (const f of files) if (f.url) URL.revokeObjectURL(f.url);
|
|
576
|
+
}
|
|
577
|
+
}, [usingProvider, files]);
|
|
578
|
+
const ctx = useMemo(() => ({
|
|
579
|
+
files: files.map((item) => ({
|
|
580
|
+
...item,
|
|
581
|
+
id: item.id
|
|
582
|
+
})),
|
|
583
|
+
add,
|
|
584
|
+
remove,
|
|
585
|
+
clear,
|
|
586
|
+
openFileDialog: effectiveOpenFileDialog,
|
|
587
|
+
fileInputRef: inputRef,
|
|
588
|
+
isDragActive,
|
|
589
|
+
isDragAccept,
|
|
590
|
+
isDragReject
|
|
591
|
+
}), [
|
|
592
|
+
files,
|
|
593
|
+
add,
|
|
594
|
+
remove,
|
|
595
|
+
clear,
|
|
596
|
+
effectiveOpenFileDialog,
|
|
597
|
+
isDragActive,
|
|
598
|
+
isDragAccept,
|
|
599
|
+
isDragReject
|
|
600
|
+
]);
|
|
601
|
+
const handleSubmit = (event) => {
|
|
602
|
+
event.preventDefault();
|
|
603
|
+
const form = event.currentTarget;
|
|
604
|
+
const text = usingProvider && controller ? controller.textInput.value : (() => {
|
|
605
|
+
const message = new FormData(form).get("message");
|
|
606
|
+
return typeof message === "string" ? message : "";
|
|
607
|
+
})();
|
|
608
|
+
if (!usingProvider) form.reset();
|
|
609
|
+
const processAndSubmit = async () => {
|
|
610
|
+
const convertedFiles = await Promise.all(files.map(async (fileWithId) => {
|
|
611
|
+
const item = {
|
|
612
|
+
type: fileWithId.type,
|
|
613
|
+
url: fileWithId.url,
|
|
614
|
+
mediaType: fileWithId.mediaType,
|
|
615
|
+
filename: fileWithId.filename
|
|
616
|
+
};
|
|
617
|
+
if (item.url.startsWith("blob:")) return {
|
|
618
|
+
...item,
|
|
619
|
+
url: await convertBlobUrlToDataUrl(item.url)
|
|
620
|
+
};
|
|
621
|
+
return item;
|
|
622
|
+
}));
|
|
623
|
+
try {
|
|
624
|
+
const result = onSubmit({
|
|
625
|
+
text,
|
|
626
|
+
files: convertedFiles
|
|
627
|
+
}, event);
|
|
628
|
+
if (result instanceof Promise) try {
|
|
629
|
+
await result;
|
|
630
|
+
clear();
|
|
631
|
+
if (usingProvider && controller) controller.textInput.clear();
|
|
632
|
+
} catch {}
|
|
633
|
+
else {
|
|
634
|
+
clear();
|
|
635
|
+
if (usingProvider && controller) controller.textInput.clear();
|
|
636
|
+
}
|
|
637
|
+
} catch {}
|
|
638
|
+
};
|
|
639
|
+
processAndSubmit();
|
|
640
|
+
};
|
|
641
|
+
const { onSubmit: _dropzoneOnSubmit, ...rootProps } = getRootProps();
|
|
642
|
+
const inner = /* @__PURE__ */ jsxs(InlineModeContext.Provider, {
|
|
643
|
+
value: inlineModeValue,
|
|
644
|
+
children: [
|
|
645
|
+
/* @__PURE__ */ jsx("span", {
|
|
646
|
+
"aria-hidden": "true",
|
|
647
|
+
className: "hidden",
|
|
648
|
+
ref: anchorRef
|
|
649
|
+
}),
|
|
650
|
+
!inline && /* @__PURE__ */ jsx("input", {
|
|
651
|
+
...getInputProps(),
|
|
652
|
+
ref: inputRef
|
|
653
|
+
}),
|
|
654
|
+
/* @__PURE__ */ jsx("form", {
|
|
655
|
+
className: cn("w-full", className),
|
|
656
|
+
onSubmit: handleSubmit,
|
|
657
|
+
...rootProps,
|
|
658
|
+
...props,
|
|
659
|
+
children: /* @__PURE__ */ jsx(InputGroup, {
|
|
660
|
+
className: cn("bg-surface text-foreground rounded-xl p-3", "flex flex-col items-stretch justify-between", reducedMotion ? "transition-none" : "transition-all duration-200", "has-[[data-slot=input-group-control]:focus-visible]:ring-0", "[&_[data-slot=input-group-control]]:py-0", "[&_[data-slot=input-group-addon]]:p-0", inline ? ["border-primary/30 h-auto", "shadow-[0_0_0_4px_color-mix(in_oklab,var(--color-primary),transparent_80%)]"] : [
|
|
661
|
+
"border-border shadow-none",
|
|
662
|
+
"h-auto min-h-[136px]",
|
|
663
|
+
"has-[[data-slot=input-group-control]:focus-visible]:border-primary/30",
|
|
664
|
+
"focus-within:border-primary/30",
|
|
665
|
+
!reducedMotion && "focus-within:animate-focus-pulse",
|
|
666
|
+
"focus-within:shadow-[0_0_0_4px_color-mix(in_oklab,var(--color-primary),transparent_80%)]"
|
|
667
|
+
], isDragActive && !inline && [
|
|
668
|
+
"border-primary/50",
|
|
669
|
+
"bg-primary/5",
|
|
670
|
+
"shadow-[0_0_0_3px_color-mix(in_oklab,var(--color-primary),0.1)]"
|
|
671
|
+
], isDragReject && !inline && ["border-destructive/50", "bg-destructive/5"]),
|
|
672
|
+
"data-inline": inline ?? void 0,
|
|
673
|
+
"data-drag-active": isDragActive || void 0,
|
|
674
|
+
"data-drag-accept": isDragAccept || void 0,
|
|
675
|
+
"data-drag-reject": isDragReject || void 0,
|
|
676
|
+
children
|
|
677
|
+
})
|
|
678
|
+
})
|
|
679
|
+
]
|
|
680
|
+
});
|
|
681
|
+
return usingProvider ? inner : /* @__PURE__ */ jsx(LocalAttachmentsContext.Provider, {
|
|
682
|
+
value: ctx,
|
|
683
|
+
children: inner
|
|
684
|
+
});
|
|
685
|
+
};
|
|
686
|
+
const PromptInputBody = ({ className, ...props }) => /* @__PURE__ */ jsx("div", {
|
|
687
|
+
className: cn("contents", className),
|
|
688
|
+
...props
|
|
689
|
+
});
|
|
690
|
+
/**
|
|
691
|
+
* PromptInputTextarea - Auto-expanding textarea with keyboard shortcuts
|
|
692
|
+
*
|
|
693
|
+
* Supports both controlled (value/onChange) and uncontrolled (defaultValue) modes
|
|
694
|
+
* via Mantine's useUncontrolled hook.
|
|
695
|
+
*
|
|
696
|
+
* @keyboard
|
|
697
|
+
* - Cmd/Ctrl+Enter: Submit form
|
|
698
|
+
* - Backspace (when empty): Remove last attachment
|
|
699
|
+
* - Escape: Blur textarea
|
|
700
|
+
*/
|
|
701
|
+
const PromptInputTextarea = forwardRef(({ value: valueProp, defaultValue, onChange, className, placeholder = "Ask me anything...", minRows = 1, maxRows = 12, ...props }, ref) => {
|
|
702
|
+
const controller = useOptionalPromptInputController();
|
|
703
|
+
const attachments = usePromptInputAttachments();
|
|
704
|
+
const { inline, onCancel } = usePromptInputInlineMode();
|
|
705
|
+
const [isComposing, setIsComposing] = useState(false);
|
|
706
|
+
const internalRef = useRef(null);
|
|
707
|
+
const mergedRef = useMergedRef(ref, internalRef, useFocusReturn({
|
|
708
|
+
opened: true,
|
|
709
|
+
shouldReturnFocus: true
|
|
710
|
+
}));
|
|
711
|
+
const controllerValue = controller?.textInput.value;
|
|
712
|
+
const [value, handleValueChange] = useUncontrolled({
|
|
713
|
+
value: controllerValue ?? (typeof valueProp === "string" ? valueProp : void 0),
|
|
714
|
+
defaultValue: defaultValue ?? "",
|
|
715
|
+
finalValue: "",
|
|
716
|
+
onChange: (newValue) => {
|
|
717
|
+
if (controller) controller.textInput.setInput(newValue);
|
|
718
|
+
}
|
|
719
|
+
});
|
|
720
|
+
const { containerRef } = useTextareaAutosize(internalRef, value, {
|
|
721
|
+
minRows,
|
|
722
|
+
maxRows,
|
|
723
|
+
lineHeight: 20
|
|
724
|
+
});
|
|
725
|
+
useHotkeys([[
|
|
726
|
+
"mod+Enter",
|
|
727
|
+
() => {
|
|
728
|
+
if (isComposing) return;
|
|
729
|
+
const form = internalRef.current?.closest("form");
|
|
730
|
+
if ((form?.querySelector("button[type=\"submit\"]"))?.disabled) return;
|
|
731
|
+
form?.requestSubmit();
|
|
732
|
+
},
|
|
733
|
+
{ preventDefault: true }
|
|
734
|
+
], ["Escape", () => {
|
|
735
|
+
if (inline && onCancel) onCancel();
|
|
736
|
+
else internalRef.current?.blur();
|
|
737
|
+
}]], []);
|
|
738
|
+
const handleKeyDown = (e) => {
|
|
739
|
+
if (e.key === "Enter" && (e.metaKey || e.ctrlKey)) {
|
|
740
|
+
if (isComposing || e.nativeEvent.isComposing) return;
|
|
741
|
+
e.preventDefault();
|
|
742
|
+
const { form } = e.currentTarget;
|
|
743
|
+
if ((form?.querySelector("button[type=\"submit\"]"))?.disabled) return;
|
|
744
|
+
form?.requestSubmit();
|
|
745
|
+
}
|
|
746
|
+
if (e.key === "Backspace" && e.currentTarget.value === "" && attachments.files.length > 0) {
|
|
747
|
+
e.preventDefault();
|
|
748
|
+
const lastAttachment = attachments.files.at(-1);
|
|
749
|
+
if (lastAttachment) attachments.remove(lastAttachment.id);
|
|
750
|
+
}
|
|
751
|
+
};
|
|
752
|
+
const handlePaste = (event) => {
|
|
753
|
+
const { items } = event.clipboardData;
|
|
754
|
+
const files = [];
|
|
755
|
+
for (const item of items) if (item.kind === "file") {
|
|
756
|
+
const file = item.getAsFile();
|
|
757
|
+
if (file) files.push(file);
|
|
758
|
+
}
|
|
759
|
+
if (files.length > 0) {
|
|
760
|
+
event.preventDefault();
|
|
761
|
+
attachments.add(files);
|
|
762
|
+
}
|
|
763
|
+
};
|
|
764
|
+
const handleChange = (e) => {
|
|
765
|
+
handleValueChange(e.currentTarget.value);
|
|
766
|
+
onChange?.(e);
|
|
767
|
+
};
|
|
768
|
+
return /* @__PURE__ */ jsxs("div", {
|
|
769
|
+
ref: containerRef,
|
|
770
|
+
className: "flex w-full flex-1 items-start gap-1 self-start",
|
|
771
|
+
children: [!inline && /* @__PURE__ */ jsx(PromptInputButton, {
|
|
772
|
+
variant: "ghost",
|
|
773
|
+
className: "shrink-0 opacity-80",
|
|
774
|
+
children: /* @__PURE__ */ jsx(WandSparklesIcon, { className: AI_ICON.md })
|
|
775
|
+
}), /* @__PURE__ */ jsx(InputGroupTextarea, {
|
|
776
|
+
ref: mergedRef,
|
|
777
|
+
className: cn("min-h-5 resize-none py-0", "text-foreground text-sm leading-5", "placeholder:text-foreground-subtle placeholder:text-xs placeholder:leading-4 placeholder:opacity-75", !inline && "mt-1.5", className),
|
|
778
|
+
name: "message",
|
|
779
|
+
onCompositionEnd: () => setIsComposing(false),
|
|
780
|
+
onCompositionStart: () => setIsComposing(true),
|
|
781
|
+
onKeyDown: handleKeyDown,
|
|
782
|
+
onPaste: handlePaste,
|
|
783
|
+
placeholder,
|
|
784
|
+
value,
|
|
785
|
+
onChange: handleChange,
|
|
786
|
+
...props
|
|
787
|
+
})]
|
|
788
|
+
});
|
|
789
|
+
});
|
|
790
|
+
PromptInputTextarea.displayName = "PromptInputTextarea";
|
|
791
|
+
const PromptInputHeader = ({ className, ...props }) => /* @__PURE__ */ jsx(InputGroupAddon, {
|
|
792
|
+
align: "block-end",
|
|
793
|
+
className: cn("order-first flex-wrap gap-1", "empty:hidden [&:not(:empty)]:mb-3", className),
|
|
794
|
+
...props
|
|
795
|
+
});
|
|
796
|
+
const PromptInputFooter = ({ className, ...props }) => /* @__PURE__ */ jsx(InputGroupAddon, {
|
|
797
|
+
align: "block-end",
|
|
798
|
+
className: cn("mt-3 w-full shrink-0 items-center justify-between gap-4", className),
|
|
799
|
+
...props
|
|
800
|
+
});
|
|
801
|
+
/**
|
|
802
|
+
* Left-side tools container with 5px gap (per Figma design)
|
|
803
|
+
*/
|
|
804
|
+
const PromptInputTools = ({ className, ...props }) => /* @__PURE__ */ jsx("div", {
|
|
805
|
+
className: cn("flex items-center gap-[5px]", className),
|
|
806
|
+
...props
|
|
807
|
+
});
|
|
808
|
+
/**
|
|
809
|
+
* Right-side actions container with 16px gap (per Figma design)
|
|
810
|
+
* Contains mic button and send button
|
|
811
|
+
*/
|
|
812
|
+
const PromptInputActions = ({ className, ...props }) => /* @__PURE__ */ jsx("div", {
|
|
813
|
+
className: cn("flex items-center gap-4", className),
|
|
814
|
+
...props
|
|
815
|
+
});
|
|
816
|
+
const PromptInputToolsButton = ({ className, label = "Tools", children, ...props }) => /* @__PURE__ */ jsxs(PromptInputButton, {
|
|
817
|
+
className: cn(AI_SPACING.xs, "px-3 py-1.5", "flex items-center justify-center", className),
|
|
818
|
+
...props,
|
|
819
|
+
children: [children ?? /* @__PURE__ */ jsx(SlidersHorizontalIcon, { className: AI_ICON.lg }), /* @__PURE__ */ jsx("span", {
|
|
820
|
+
className: cn("text-foreground-subtle leading-5 font-medium whitespace-nowrap", AI_TEXT.sm),
|
|
821
|
+
children: label
|
|
822
|
+
})]
|
|
823
|
+
});
|
|
824
|
+
/**
|
|
825
|
+
* CVA variants for PromptInput buttons matching Figma AXIO.ai design
|
|
826
|
+
* Premium Harmony V2: Uses AI_FOCUS for accessible focus styles
|
|
827
|
+
* @see https://www.figma.com/design/9DTQx1GRsJA4zSScFUSego/AXIO.ai
|
|
828
|
+
*/
|
|
829
|
+
const promptInputButtonVariants = cva([
|
|
830
|
+
"rounded-lg text-sm font-medium transition-all duration-150",
|
|
831
|
+
"active:scale-[0.98]",
|
|
832
|
+
AI_FOCUS.ring
|
|
833
|
+
].join(" "), {
|
|
834
|
+
variants: { variant: {
|
|
835
|
+
default: ["border border-primary/20 bg-primary/10 text-primary", "hover:bg-primary/15"],
|
|
836
|
+
outline: ["border border-border bg-surface text-foreground", "hover:bg-surface-subtle hover:text-foreground"],
|
|
837
|
+
ghost: ["border-0 bg-transparent text-foreground-subtle p-0", "hover:opacity-80"],
|
|
838
|
+
filled: [
|
|
839
|
+
"relative overflow-clip border border-primary text-primary-foreground",
|
|
840
|
+
"hover:opacity-90",
|
|
841
|
+
"disabled:active:scale-100"
|
|
842
|
+
]
|
|
843
|
+
} },
|
|
844
|
+
defaultVariants: { variant: "outline" }
|
|
845
|
+
});
|
|
846
|
+
const PromptInputButton = ({ variant = "outline", className, size, children, ...props }) => {
|
|
847
|
+
const isTouchDevice = useMediaQuery("(pointer: coarse)");
|
|
848
|
+
return /* @__PURE__ */ jsx(Button, {
|
|
849
|
+
type: "button",
|
|
850
|
+
variant: "ghost",
|
|
851
|
+
size: size ?? (Children.count(children) > 1 ? "sm" : isTouchDevice ? "icon" : "icon-sm"),
|
|
852
|
+
className: cn(promptInputButtonVariants({ variant }), isTouchDevice && "min-h-11 min-w-11", className),
|
|
853
|
+
...props,
|
|
854
|
+
children
|
|
855
|
+
});
|
|
856
|
+
};
|
|
857
|
+
/**
|
|
858
|
+
* PromptInputActionMenu - Dropdown menu with optional click-outside detection
|
|
859
|
+
*
|
|
860
|
+
* Uses Mantine's useClickOutside hook for advanced click-outside handling.
|
|
861
|
+
* The default Radix behavior handles basic click-outside; use onClickOutside
|
|
862
|
+
* for custom logic (e.g., closing multiple menus, analytics).
|
|
863
|
+
*/
|
|
864
|
+
const PromptInputActionMenu = ({ onClickOutside, ...props }) => {
|
|
865
|
+
const clickOutsideRef = useClickOutside(() => {
|
|
866
|
+
onClickOutside?.();
|
|
867
|
+
}, ["mousedown", "touchstart"]);
|
|
868
|
+
if (onClickOutside) return /* @__PURE__ */ jsx("div", {
|
|
869
|
+
ref: clickOutsideRef,
|
|
870
|
+
className: "contents",
|
|
871
|
+
children: /* @__PURE__ */ jsx(DropdownMenu, { ...props })
|
|
872
|
+
});
|
|
873
|
+
return /* @__PURE__ */ jsx(DropdownMenu, { ...props });
|
|
874
|
+
};
|
|
875
|
+
const PromptInputActionMenuTrigger = ({ className, children, ...props }) => /* @__PURE__ */ jsx(DropdownMenuTrigger, {
|
|
876
|
+
asChild: true,
|
|
877
|
+
children: /* @__PURE__ */ jsx(PromptInputButton, {
|
|
878
|
+
className: cn(AI_SPACING.xs, "p-[7px]", className),
|
|
879
|
+
...props,
|
|
880
|
+
children: children ?? /* @__PURE__ */ jsx(PlusIcon, { className: AI_ICON.lg })
|
|
881
|
+
})
|
|
882
|
+
});
|
|
883
|
+
/**
|
|
884
|
+
* PromptInputActionMenuContent - Styled dropdown menu content
|
|
885
|
+
*
|
|
886
|
+
* Uses Radix's built-in click-outside handling. For advanced click-outside logic,
|
|
887
|
+
* use the `onInteractOutside` prop from Radix DropdownMenuContent.
|
|
888
|
+
*/
|
|
889
|
+
const PromptInputActionMenuContent = ({ className, ...props }) => /* @__PURE__ */ jsx(DropdownMenuContent, {
|
|
890
|
+
align: "start",
|
|
891
|
+
className: cn(className),
|
|
892
|
+
...props
|
|
893
|
+
});
|
|
894
|
+
const PromptInputActionMenuItem = ({ className, ...props }) => /* @__PURE__ */ jsx(DropdownMenuItem, {
|
|
895
|
+
className: cn(className),
|
|
896
|
+
...props
|
|
897
|
+
});
|
|
898
|
+
const PromptInputSubmit = ({ className, status, children, ...props }) => {
|
|
899
|
+
const { inline } = usePromptInputInlineMode();
|
|
900
|
+
const isTouchDevice = useMediaQuery("(pointer: coarse)");
|
|
901
|
+
const reducedMotion = useReducedMotion();
|
|
902
|
+
const iconVariants = useMemo(() => ({
|
|
903
|
+
initial: {
|
|
904
|
+
scale: .8,
|
|
905
|
+
opacity: 0
|
|
906
|
+
},
|
|
907
|
+
animate: {
|
|
908
|
+
scale: 1,
|
|
909
|
+
opacity: 1,
|
|
910
|
+
transition: reducedMotion ? { duration: 0 } : SPRING_TACTILE
|
|
911
|
+
},
|
|
912
|
+
exit: {
|
|
913
|
+
scale: .8,
|
|
914
|
+
opacity: 0,
|
|
915
|
+
transition: reducedMotion ? { duration: 0 } : SPRING_FLUID
|
|
916
|
+
}
|
|
917
|
+
}), [reducedMotion]);
|
|
918
|
+
let Icon = /* @__PURE__ */ jsx(ArrowUpIcon, { className: AI_ICON.lg });
|
|
919
|
+
let iconKey = "arrow";
|
|
920
|
+
if (status === "submitted") {
|
|
921
|
+
Icon = /* @__PURE__ */ jsx(Loader2Icon, { className: cn(AI_ICON.lg, !reducedMotion && "animate-spin") });
|
|
922
|
+
iconKey = "loader";
|
|
923
|
+
} else if (status === "streaming") {
|
|
924
|
+
Icon = /* @__PURE__ */ jsx(SquareIcon, { className: AI_ICON.lg });
|
|
925
|
+
iconKey = "square";
|
|
926
|
+
} else if (status === "error") {
|
|
927
|
+
Icon = /* @__PURE__ */ jsx(XIcon, { className: AI_ICON.lg });
|
|
928
|
+
iconKey = "error";
|
|
929
|
+
}
|
|
930
|
+
if (inline) return /* @__PURE__ */ jsx(Button, {
|
|
931
|
+
type: "submit",
|
|
932
|
+
variant: "ghost",
|
|
933
|
+
"aria-label": "Submit",
|
|
934
|
+
className: cn("bg-foreground relative gap-1 overflow-clip rounded-lg border-0 py-1.5 pr-3 pl-1.5", "text-background", "hover:bg-foreground/90", "disabled:opacity-50", isTouchDevice && "min-h-11", className),
|
|
935
|
+
"data-testid": "prompt-input-submit",
|
|
936
|
+
"data-state": status ?? "idle",
|
|
937
|
+
"data-loading": status === "submitted" || status === "streaming" ? "" : void 0,
|
|
938
|
+
...props,
|
|
939
|
+
children: children ?? /* @__PURE__ */ jsxs(Fragment$1, { children: [/* @__PURE__ */ jsx(AnimatePresence, {
|
|
940
|
+
mode: "wait",
|
|
941
|
+
initial: false,
|
|
942
|
+
children: /* @__PURE__ */ jsx(motion.div, {
|
|
943
|
+
variants: iconVariants,
|
|
944
|
+
initial: "initial",
|
|
945
|
+
animate: "animate",
|
|
946
|
+
exit: "exit",
|
|
947
|
+
children: Icon
|
|
948
|
+
}, iconKey)
|
|
949
|
+
}), /* @__PURE__ */ jsx("span", {
|
|
950
|
+
className: "text-xs font-medium whitespace-nowrap",
|
|
951
|
+
children: "Send"
|
|
952
|
+
})] })
|
|
953
|
+
});
|
|
954
|
+
return /* @__PURE__ */ jsxs(Button, {
|
|
955
|
+
type: "submit",
|
|
956
|
+
variant: "ghost",
|
|
957
|
+
"aria-label": "Submit",
|
|
958
|
+
className: cn(promptInputButtonVariants({ variant: "filled" }), "gap-1 py-1.5 pr-3 pl-1.5", "from-primary to-primary bg-gradient-to-r", isTouchDevice && "min-h-11", className),
|
|
959
|
+
"data-testid": "prompt-input-submit",
|
|
960
|
+
"data-state": status ?? "idle",
|
|
961
|
+
"data-loading": status === "submitted" || status === "streaming" ? "" : void 0,
|
|
962
|
+
...props,
|
|
963
|
+
children: [children ?? /* @__PURE__ */ jsxs(Fragment$1, { children: [/* @__PURE__ */ jsx(AnimatePresence, {
|
|
964
|
+
mode: "wait",
|
|
965
|
+
initial: false,
|
|
966
|
+
children: /* @__PURE__ */ jsx(motion.div, {
|
|
967
|
+
variants: iconVariants,
|
|
968
|
+
initial: "initial",
|
|
969
|
+
animate: "animate",
|
|
970
|
+
exit: "exit",
|
|
971
|
+
children: Icon
|
|
972
|
+
}, iconKey)
|
|
973
|
+
}), /* @__PURE__ */ jsx("span", {
|
|
974
|
+
className: "whitespace-nowrap",
|
|
975
|
+
children: "Send"
|
|
976
|
+
})] }), /* @__PURE__ */ jsx("div", {
|
|
977
|
+
className: "pointer-events-none absolute inset-0 rounded-lg bg-gradient-to-b from-white/10 to-transparent",
|
|
978
|
+
"aria-hidden": "true"
|
|
979
|
+
})]
|
|
980
|
+
});
|
|
981
|
+
};
|
|
982
|
+
/**
|
|
983
|
+
* Cancel button for inline edit mode
|
|
984
|
+
* Triggers the onCancel callback from PromptInput
|
|
985
|
+
*/
|
|
986
|
+
const PromptInputCancelButton = ({ className, children, onClick, ...props }) => {
|
|
987
|
+
const { onCancel } = usePromptInputInlineMode();
|
|
988
|
+
const isTouchDevice = useMediaQuery("(pointer: coarse)");
|
|
989
|
+
const handleClick = (e) => {
|
|
990
|
+
onClick?.(e);
|
|
991
|
+
onCancel?.();
|
|
992
|
+
};
|
|
993
|
+
return /* @__PURE__ */ jsx(Button, {
|
|
994
|
+
type: "button",
|
|
995
|
+
variant: "ghost",
|
|
996
|
+
className: cn("border-border bg-surface rounded-lg border px-3 py-1.5", "text-foreground text-sm font-medium", "shadow-sm", "hover:bg-surface-subtle active:scale-95", AI_FOCUS.ring, isTouchDevice && "min-h-11", className),
|
|
997
|
+
onClick: handleClick,
|
|
998
|
+
...props,
|
|
999
|
+
children: children ?? "Cancel"
|
|
1000
|
+
});
|
|
1001
|
+
};
|
|
1002
|
+
const PromptInputSpeechButton = ({ className, textareaRef, onTranscriptionChange, ...props }) => {
|
|
1003
|
+
const [isListening, setIsListening] = useState(false);
|
|
1004
|
+
const [isReady, setIsReady] = useState(false);
|
|
1005
|
+
const recognitionRef = useRef(null);
|
|
1006
|
+
const isTouchDevice = useMediaQuery("(pointer: coarse)");
|
|
1007
|
+
const reducedMotion = useReducedMotion();
|
|
1008
|
+
const onTranscriptionChangeRef = useRef(onTranscriptionChange);
|
|
1009
|
+
useEffect(() => {
|
|
1010
|
+
onTranscriptionChangeRef.current = onTranscriptionChange;
|
|
1011
|
+
}, [onTranscriptionChange]);
|
|
1012
|
+
useEffect(() => {
|
|
1013
|
+
if (typeof window === "undefined") return;
|
|
1014
|
+
const SpeechRecognitionConstructor = window.SpeechRecognition ?? window.webkitSpeechRecognition;
|
|
1015
|
+
if (!SpeechRecognitionConstructor) return;
|
|
1016
|
+
const speechRecognition = new SpeechRecognitionConstructor();
|
|
1017
|
+
speechRecognition.continuous = true;
|
|
1018
|
+
speechRecognition.interimResults = true;
|
|
1019
|
+
speechRecognition.lang = "en-US";
|
|
1020
|
+
speechRecognition.onstart = () => {
|
|
1021
|
+
setIsListening(true);
|
|
1022
|
+
};
|
|
1023
|
+
speechRecognition.onend = () => {
|
|
1024
|
+
setIsListening(false);
|
|
1025
|
+
};
|
|
1026
|
+
speechRecognition.onresult = (event) => {
|
|
1027
|
+
let finalTranscript = "";
|
|
1028
|
+
for (let i = 0; i < event.results.length; i++) {
|
|
1029
|
+
const result = event.results[i];
|
|
1030
|
+
if (result?.isFinal) finalTranscript += result[0]?.transcript ?? "";
|
|
1031
|
+
}
|
|
1032
|
+
if (finalTranscript && textareaRef?.current) {
|
|
1033
|
+
const textarea = textareaRef.current;
|
|
1034
|
+
const currentValue = textarea.value;
|
|
1035
|
+
const newValue = currentValue + (currentValue ? " " : "") + finalTranscript;
|
|
1036
|
+
textarea.value = newValue;
|
|
1037
|
+
textarea.dispatchEvent(new Event("input", { bubbles: true }));
|
|
1038
|
+
onTranscriptionChangeRef.current?.(newValue);
|
|
1039
|
+
}
|
|
1040
|
+
};
|
|
1041
|
+
speechRecognition.onerror = (event) => {
|
|
1042
|
+
logger.error("Speech recognition error", { error: event.error });
|
|
1043
|
+
setIsListening(false);
|
|
1044
|
+
};
|
|
1045
|
+
recognitionRef.current = speechRecognition;
|
|
1046
|
+
const timer = setTimeout(() => setIsReady(true), 0);
|
|
1047
|
+
return () => {
|
|
1048
|
+
clearTimeout(timer);
|
|
1049
|
+
if (recognitionRef.current) recognitionRef.current.stop();
|
|
1050
|
+
};
|
|
1051
|
+
}, [textareaRef]);
|
|
1052
|
+
const toggleListening = useCallback(() => {
|
|
1053
|
+
if (!recognitionRef.current) return;
|
|
1054
|
+
if (isListening) recognitionRef.current.stop();
|
|
1055
|
+
else recognitionRef.current.start();
|
|
1056
|
+
}, [isListening]);
|
|
1057
|
+
return /* @__PURE__ */ jsx(Button, {
|
|
1058
|
+
type: "button",
|
|
1059
|
+
variant: "ghost",
|
|
1060
|
+
"aria-label": isListening ? "Stop recording" : "Start recording",
|
|
1061
|
+
className: cn(promptInputButtonVariants({ variant: "ghost" }), isListening && !reducedMotion && "animate-pulse", isTouchDevice && "min-h-11 min-w-11", className),
|
|
1062
|
+
disabled: !isReady,
|
|
1063
|
+
onClick: toggleListening,
|
|
1064
|
+
"data-state": isListening ? "listening" : "idle",
|
|
1065
|
+
"data-ready": isReady ? "" : void 0,
|
|
1066
|
+
...props,
|
|
1067
|
+
children: /* @__PURE__ */ jsx(MicIcon, { className: cn("text-foreground-subtle", "size-6") })
|
|
1068
|
+
});
|
|
1069
|
+
};
|
|
1070
|
+
const PromptInputSelect = (props) => /* @__PURE__ */ jsx(Select, { ...props });
|
|
1071
|
+
const PromptInputSelectTrigger = ({ className, ...props }) => /* @__PURE__ */ jsx(SelectTrigger, {
|
|
1072
|
+
className: cn("text-muted-foreground border-none bg-transparent font-medium shadow-none transition-colors", "hover:bg-accent hover:text-foreground aria-expanded:bg-accent aria-expanded:text-foreground", className),
|
|
1073
|
+
...props
|
|
1074
|
+
});
|
|
1075
|
+
const PromptInputSelectContent = ({ className, ...props }) => /* @__PURE__ */ jsx(SelectContent, {
|
|
1076
|
+
className: cn(className),
|
|
1077
|
+
...props
|
|
1078
|
+
});
|
|
1079
|
+
const PromptInputSelectItem = ({ className, ...props }) => /* @__PURE__ */ jsx(SelectItem, {
|
|
1080
|
+
className: cn(className),
|
|
1081
|
+
...props
|
|
1082
|
+
});
|
|
1083
|
+
const PromptInputSelectValue = ({ className, ...props }) => /* @__PURE__ */ jsx(SelectValue, {
|
|
1084
|
+
className: cn(className),
|
|
1085
|
+
...props
|
|
1086
|
+
});
|
|
1087
|
+
const PromptInputHoverCard = ({ openDelay = 0, closeDelay = 0, ...props }) => /* @__PURE__ */ jsx(HoverCard, {
|
|
1088
|
+
closeDelay,
|
|
1089
|
+
openDelay,
|
|
1090
|
+
...props
|
|
1091
|
+
});
|
|
1092
|
+
const PromptInputHoverCardTrigger = (props) => /* @__PURE__ */ jsx(HoverCardTrigger, { ...props });
|
|
1093
|
+
const PromptInputHoverCardContent = ({ align = "start", ...props }) => /* @__PURE__ */ jsx(HoverCardContent, {
|
|
1094
|
+
align,
|
|
1095
|
+
...props
|
|
1096
|
+
});
|
|
1097
|
+
const PromptInputTabsList = ({ className, ...props }) => /* @__PURE__ */ jsx("div", {
|
|
1098
|
+
className: cn(className),
|
|
1099
|
+
...props
|
|
1100
|
+
});
|
|
1101
|
+
const PromptInputTab = ({ className, ...props }) => /* @__PURE__ */ jsx("div", {
|
|
1102
|
+
className: cn(className),
|
|
1103
|
+
...props
|
|
1104
|
+
});
|
|
1105
|
+
const PromptInputTabLabel = ({ className, children, ...props }) => /* @__PURE__ */ jsx("h3", {
|
|
1106
|
+
className: cn("text-muted-foreground mb-2 px-3 font-medium", AI_TEXT.xs, className),
|
|
1107
|
+
...props,
|
|
1108
|
+
children
|
|
1109
|
+
});
|
|
1110
|
+
const PromptInputTabBody = ({ className, ...props }) => /* @__PURE__ */ jsx("div", {
|
|
1111
|
+
className: cn("space-y-1", className),
|
|
1112
|
+
...props
|
|
1113
|
+
});
|
|
1114
|
+
const PromptInputTabItem = ({ className, ...props }) => /* @__PURE__ */ jsx("div", {
|
|
1115
|
+
className: cn("hover:bg-accent flex items-center px-3 py-2", AI_SPACING.xs, AI_TEXT.xs, className),
|
|
1116
|
+
...props
|
|
1117
|
+
});
|
|
1118
|
+
const PromptInputCommand = ({ className, ...props }) => /* @__PURE__ */ jsx(Command, {
|
|
1119
|
+
className: cn(className),
|
|
1120
|
+
...props
|
|
1121
|
+
});
|
|
1122
|
+
const PromptInputCommandInput = ({ className, ...props }) => /* @__PURE__ */ jsx(CommandInput, {
|
|
1123
|
+
className: cn(className),
|
|
1124
|
+
...props
|
|
1125
|
+
});
|
|
1126
|
+
const PromptInputCommandList = ({ className, ...props }) => /* @__PURE__ */ jsx(CommandList, {
|
|
1127
|
+
className: cn(className),
|
|
1128
|
+
...props
|
|
1129
|
+
});
|
|
1130
|
+
const PromptInputCommandEmpty = ({ className, ...props }) => /* @__PURE__ */ jsx(CommandEmpty, {
|
|
1131
|
+
className: cn(className),
|
|
1132
|
+
...props
|
|
1133
|
+
});
|
|
1134
|
+
const PromptInputCommandGroup = ({ className, ...props }) => /* @__PURE__ */ jsx(CommandGroup, {
|
|
1135
|
+
className: cn(className),
|
|
1136
|
+
...props
|
|
1137
|
+
});
|
|
1138
|
+
const PromptInputCommandItem = ({ className, ...props }) => /* @__PURE__ */ jsx(CommandItem, {
|
|
1139
|
+
className: cn(className),
|
|
1140
|
+
...props
|
|
1141
|
+
});
|
|
1142
|
+
const PromptInputCommandSeparator = ({ className, ...props }) => /* @__PURE__ */ jsx(CommandSeparator, {
|
|
1143
|
+
className: cn(className),
|
|
1144
|
+
...props
|
|
1145
|
+
});
|
|
1146
|
+
|
|
1147
|
+
//#endregion
|
|
1148
|
+
export { usePromptInputUncontrolled as $, PromptInputSelectValue as A, PromptInputToolsButton as B, PromptInputHoverCardContent as C, PromptInputSelectContent as D, PromptInputSelect as E, PromptInputTabItem as F, usePromptInputDropzone as G, usePromptInputAttachments as H, PromptInputTabLabel as I, usePromptInputIdle as J, usePromptInputFocusReturn as K, PromptInputTabsList as L, PromptInputSubmit as M, PromptInputTab as N, PromptInputSelectItem as O, PromptInputTabBody as P, usePromptInputReducedMotion as Q, PromptInputTextarea as R, PromptInputHoverCard as S, PromptInputProvider as T, usePromptInputClickOutside as U, promptInputButtonVariants as V, usePromptInputController as W, usePromptInputMediaQuery as X, usePromptInputInlineMode as Y, usePromptInputMergedRef as Z, PromptInputCommandItem as _, PromptInputActionMenuItem as a, PromptInputFooter as b, PromptInputAttachment as c, PromptInputButton as d, useProviderAttachments as et, PromptInputCancelButton as f, PromptInputCommandInput as g, PromptInputCommandGroup as h, PromptInputActionMenuContent as i, PromptInputSpeechButton as j, PromptInputSelectTrigger as k, PromptInputAttachments as l, PromptInputCommandEmpty as m, PromptInputActionAddAttachments as n, PromptInputActionMenuTrigger as o, PromptInputCommand as p, usePromptInputHotkeys as q, PromptInputActionMenu as r, PromptInputActions as s, PromptInput as t, useTextareaAutosize as tt, PromptInputBody as u, PromptInputCommandList as v, PromptInputHoverCardTrigger as w, PromptInputHeader as x, PromptInputCommandSeparator as y, PromptInputTools as z };
|
|
1149
|
+
//# sourceMappingURL=prompt-input-SFJ9_lNw.mjs.map
|