@alfadocs/ui-kit 0.70.0 → 0.71.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/_chunks/address-fields-CPbFJ8e8.js +246 -0
- package/dist/_chunks/{ai-prompt-input-CuhTo9mh.js → ai-prompt-input-V4DdOeqv.js} +2 -2
- package/dist/_chunks/{alia-sidebar-B47qRQb5.js → alia-sidebar-DvIUzIX9.js} +107 -106
- package/dist/_chunks/{anatomy-scheme-CJB6dI6p.js → anatomy-scheme-CXSk11UJ.js} +2 -2
- package/dist/_chunks/{app-frame-BYx1gcV7.js → app-frame-DIEMIC5V.js} +67 -56
- package/dist/_chunks/{appointment-card-C06aZqA7.js → appointment-card-DVaeJNVB.js} +82 -98
- package/dist/_chunks/{appointment-timeline-BJM0S_Fg.js → appointment-timeline-PJgnrjFb.js} +159 -157
- package/dist/_chunks/{appointment-tray-DRRw5ROi.js → appointment-tray-B16QPGbm.js} +2 -2
- package/dist/_chunks/{audio-recorder-Cpdk5qpQ.js → audio-recorder-DNDsOLqO.js} +2 -2
- package/dist/_chunks/{autocomplete-DOeGouCL.js → autocomplete-BrONKN8l.js} +168 -146
- package/dist/_chunks/{bishop-score-DnYWtZa_.js → bishop-score-Cym_TeQY.js} +2 -2
- package/dist/_chunks/{booking-DUBI0oqt.js → booking-C7do4vaR.js} +4 -4
- package/dist/_chunks/{button-group-Ciq6J4IW.js → button-group-CvEnVzY7.js} +32 -35
- package/dist/_chunks/{care-plan-card-C5sTfY9G.js → care-plan-card-DzPDYgtK.js} +3 -3
- package/dist/_chunks/{care-plan-entry-card-CXnxGCWA.js → care-plan-entry-card-CEnQy7YP.js} +3 -3
- package/dist/_chunks/care-plan-header-DcXFXWit.js +198 -0
- package/dist/_chunks/{chat-message-3V54YipB.js → chat-message-DzpcJR-q.js} +25 -23
- package/dist/_chunks/city-input-Dkgaak7I.js +169 -0
- package/dist/_chunks/clipboard-list-S7s-MXQq.js +25 -0
- package/dist/_chunks/{combobox-Clum7gJ1.js → combobox-DnqSF0IH.js} +131 -114
- package/dist/_chunks/connection-status-CY1HV8Wg.js +108 -0
- package/dist/_chunks/control-room-rail-FAQZrGVL.js +333 -0
- package/dist/_chunks/country-select-BwUZQvTa.js +709 -0
- package/dist/_chunks/editable-currency-cell-renderer-CGELrkIj.js +410 -0
- package/dist/_chunks/{entity-card-9_62gY7l.js → entity-card-DmrgYSEX.js} +4 -4
- package/dist/_chunks/entity-summary-CaM1Y-xE.js +291 -0
- package/dist/_chunks/field-array-siUZzfYe.js +146 -0
- package/dist/_chunks/{field-value-NXYczdpO.js → field-value-3jMM0uDx.js} +2 -2
- package/dist/_chunks/{gestational-age-calculator-CF2ISaYQ.js → gestational-age-calculator-DKzEV5Qi.js} +2 -2
- package/dist/_chunks/iban-input-B0TWzR1R.js +436 -0
- package/dist/_chunks/icon-picker-0B7KhrF1.js +272 -0
- package/dist/_chunks/image-cropper-D9jqJy19.js +367 -0
- package/dist/_chunks/{link-cell-renderer-CTXqtXV-.js → link-cell-renderer-De_SLjSq.js} +262 -261
- package/dist/_chunks/list-checks-BUs75d_o.js +18 -0
- package/dist/_chunks/{marketplace-app-shell-Skhfp6vK.js → marketplace-app-shell-BGqkywsi.js} +3 -3
- package/dist/_chunks/message-card-DsHFFiL1.js +319 -0
- package/dist/_chunks/{message-tray-DwrBLJlf.js → message-tray-C0a6CL1_.js} +172 -135
- package/dist/_chunks/{multi-select-BdHHDrRN.js → multi-select-WE4S9FIF.js} +75 -63
- package/dist/_chunks/nav-grid-9xphY3FM.js +169 -0
- package/dist/_chunks/notes-panel-DXiMfuvp.js +320 -0
- package/dist/_chunks/notification-card-BMqNzCIt.js +290 -0
- package/dist/_chunks/{notification-tray-AEun6DN2.js → notification-tray-BmUlCx3g.js} +201 -166
- package/dist/_chunks/{operator-hero-CR0Rqh4-.js → operator-hero-BO8TqzX2.js} +2 -2
- package/dist/_chunks/panel-header-D313n_9-.js +105 -0
- package/dist/_chunks/{patient-details-Dlhqb5ig.js → patient-details-DgfTJimE.js} +280 -196
- package/dist/_chunks/{patient-search-Be6cLrHR.js → patient-search-CSWQKOSP.js} +2 -2
- package/dist/_chunks/{patient-shell-DV3XEtIB.js → patient-shell-BMwsIKlW.js} +3 -3
- package/dist/_chunks/{patient-summary-card-WySCMwwA.js → patient-summary-card-D4NdgYJB.js} +27 -12
- package/dist/_chunks/{patient-table-CHxf3Oqk.js → patient-table-CERknpd8.js} +3 -3
- package/dist/_chunks/{payment-request-card-BcZJwu9z.js → payment-request-card-Blf-MFNY.js} +2 -2
- package/dist/_chunks/permission-matrix-Bw5oexUt.js +174 -0
- package/dist/_chunks/position-grid-CcvqHaKN.js +169 -0
- package/dist/_chunks/postal-code-input-UCOYuRY2.js +192 -0
- package/dist/_chunks/{practice-results-C6qDfxos.js → practice-results-El5Z-oVp.js} +2 -2
- package/dist/_chunks/{pregnancy-dating-CRVWswD-.js → pregnancy-dating-CunHrOpO.js} +2 -2
- package/dist/_chunks/{product-hub-panel-e6pW220e.js → product-hub-panel-DtU7KXxm.js} +257 -217
- package/dist/_chunks/province-select-D_TZvix3.js +261 -0
- package/dist/_chunks/{public-header.agent-DqkqA-ca.js → public-header.agent-TxmC_x1I.js} +2 -2
- package/dist/_chunks/radiograph-panel.agent-tWjN2nHX.js +553 -0
- package/dist/_chunks/reviews-panel-DxkSrgMl.js +559 -0
- package/dist/_chunks/rich-text-editor-C8tyGjfb.js +2621 -0
- package/dist/_chunks/{scroll-area-5wNK0Cyz.js → scroll-area-BZOvUhwQ.js} +2 -2
- package/dist/_chunks/{select-DMLG44F5.js → select-KsyRr8WH.js} +114 -102
- package/dist/_chunks/{sheet-BxsE7eQm.js → sheet-umkfZjF6.js} +53 -42
- package/dist/_chunks/{sidebar-DY9jGjgt.js → sidebar-QCp9wHNP.js} +125 -113
- package/dist/_chunks/{tabs-BxcOziCo.js → tabs-CYZVKKDl.js} +2 -2
- package/dist/_chunks/task-card-DCdsI0ZT.js +189 -0
- package/dist/_chunks/{task-tray-qOEQflu4.js → task-tray-DNVejijD.js} +2 -2
- package/dist/_chunks/tasks-panel-C9odmawT.js +757 -0
- package/dist/_chunks/token-insert-menu-CFQqTe_n.js +147 -0
- package/dist/_chunks/{ai-tools-rail-B5NEghsp.js → tool-rail-BZx0-yIr.js} +152 -139
- package/dist/_chunks/{tooth-scheme-BhQoPNBD.js → tooth-scheme-DJZtzfeY.js} +470 -468
- package/dist/_chunks/{transcript-panel-3THQX6nJ.js → transcript-panel-CHGHHHdT.js} +95 -83
- package/dist/_chunks/{unit-converter-YEpD9evj.js → unit-converter-CwlZbfdn.js} +2 -2
- package/dist/_chunks/{workflow-map-Dy8mLCqF.js → workflow-map-M8MBBHQm.js} +106 -118
- package/dist/agent-catalog.json +2062 -226
- package/dist/agent-i18n/en.json +206 -8
- package/dist/components/_shared/option.d.ts +2 -0
- package/dist/components/_shared/patient-fields.d.ts +1 -1
- package/dist/components/address-fields/address-fields.agent.d.ts +9 -0
- package/dist/components/address-fields/address-fields.d.ts +29 -0
- package/dist/components/address-fields/index.d.ts +5 -0
- package/dist/components/address-fields/index.js +6 -0
- package/dist/components/ai-prompt-input/index.js +1 -1
- package/dist/components/anatomy-scheme/index.js +1 -1
- package/dist/components/app-frame/app-frame.d.ts +2 -2
- package/dist/components/app-frame/index.js +1 -1
- package/dist/components/appointment-card/index.js +2 -2
- package/dist/components/appointment-timeline/index.js +1 -1
- package/dist/components/audio-recorder/index.js +1 -1
- package/dist/components/autocomplete/autocomplete.d.ts +10 -0
- package/dist/components/autocomplete/index.js +1 -1
- package/dist/components/bishop-score/index.js +1 -1
- package/dist/components/booking/index.js +1 -1
- package/dist/components/button-group/index.js +1 -1
- package/dist/components/care-plan-card/index.js +1 -1
- package/dist/components/care-plan-entry-card/index.js +1 -1
- package/dist/components/care-plan-header/care-plan-header.d.ts +16 -5
- package/dist/components/care-plan-header/index.js +1 -1
- package/dist/components/chat-message/index.js +1 -1
- package/dist/components/city-input/city-input.agent.d.ts +8 -0
- package/dist/components/city-input/city-input.d.ts +57 -0
- package/dist/components/city-input/index.d.ts +5 -0
- package/dist/components/city-input/index.js +6 -0
- package/dist/components/combobox/combobox.d.ts +17 -0
- package/dist/components/combobox/index.js +1 -1
- package/dist/components/connection-status/connection-status.agent.d.ts +4 -0
- package/dist/components/connection-status/connection-status.d.ts +36 -0
- package/dist/components/connection-status/index.d.ts +4 -0
- package/dist/components/connection-status/index.js +6 -0
- package/dist/components/control-room-rail/control-room-context.d.ts +5 -5
- package/dist/components/control-room-rail/control-room-rail.agent.d.ts +4 -0
- package/dist/components/control-room-rail/control-room-rail.d.ts +5 -5
- package/dist/components/control-room-rail/index.d.ts +1 -0
- package/dist/components/control-room-rail/index.js +4 -3
- package/dist/components/counter/counter.d.ts +1 -1
- package/dist/components/country-select/country-select.agent.d.ts +8 -0
- package/dist/components/country-select/country-select.d.ts +51 -0
- package/dist/components/country-select/index.d.ts +6 -0
- package/dist/components/country-select/index.js +9 -0
- package/dist/components/country-select/iso-3166.d.ts +15 -0
- package/dist/components/data-table/cell-renderers/reorder-cell-renderer.d.ts +34 -0
- package/dist/components/data-table/index.d.ts +2 -0
- package/dist/components/data-table/index.js +13 -11
- package/dist/components/entity-summary/entity-summary.agent.d.ts +4 -0
- package/dist/components/entity-summary/entity-summary.d.ts +53 -4
- package/dist/components/entity-summary/index.js +1 -1
- package/dist/components/field-array/field-array.agent.d.ts +4 -0
- package/dist/components/field-array/field-array.d.ts +45 -0
- package/dist/components/field-array/index.d.ts +4 -0
- package/dist/components/field-array/index.js +6 -0
- package/dist/components/freemium-paywall/freemium-paywall.d.ts +1 -1
- package/dist/components/gestational-age-calculator/index.js +1 -1
- package/dist/components/iban-input/iban-input.agent.d.ts +4 -0
- package/dist/components/iban-input/iban-input.d.ts +51 -0
- package/dist/components/iban-input/index.d.ts +5 -0
- package/dist/components/iban-input/index.js +13 -0
- package/dist/components/iban-input/is-valid-iban.d.ts +31 -0
- package/dist/components/icon-picker/icon-picker.agent.d.ts +4 -0
- package/dist/components/icon-picker/icon-picker.d.ts +41 -0
- package/dist/components/icon-picker/index.d.ts +4 -0
- package/dist/components/icon-picker/index.js +6 -0
- package/dist/components/image-cropper/crop-geometry.d.ts +30 -0
- package/dist/components/image-cropper/image-cropper.agent.d.ts +4 -0
- package/dist/components/image-cropper/image-cropper.d.ts +32 -0
- package/dist/components/image-cropper/index.d.ts +5 -0
- package/dist/components/image-cropper/index.js +11 -0
- package/dist/components/index.d.ts +16 -1
- package/dist/components/message-card/index.js +1 -1
- package/dist/components/message-card/message-card.d.ts +14 -0
- package/dist/components/message-tray/index.js +1 -1
- package/dist/components/message-tray/message-tray.d.ts +4 -0
- package/dist/components/multi-select/index.js +1 -1
- package/dist/components/nav-grid/index.d.ts +4 -0
- package/dist/components/nav-grid/index.js +7 -0
- package/dist/components/nav-grid/nav-grid.agent.d.ts +4 -0
- package/dist/components/nav-grid/nav-grid.d.ts +41 -0
- package/dist/components/notes-panel/index.js +1 -1
- package/dist/components/notes-panel/notes-panel.agent.d.ts +4 -0
- package/dist/components/notes-panel/notes-panel.d.ts +30 -0
- package/dist/components/notification-card/index.js +1 -1
- package/dist/components/notification-card/notification-card.d.ts +15 -0
- package/dist/components/notification-tray/index.js +1 -1
- package/dist/components/notification-tray/notification-tray.d.ts +4 -0
- package/dist/components/operator-hero/index.js +1 -1
- package/dist/components/panel-header/index.d.ts +3 -0
- package/dist/components/panel-header/index.js +7 -0
- package/dist/components/panel-header/panel-header.d.ts +41 -0
- package/dist/components/patient-details/index.js +1 -1
- package/dist/components/patient-search/index.js +1 -1
- package/dist/components/patient-summary-card/index.js +1 -1
- package/dist/components/patient-table/index.js +1 -1
- package/dist/components/payment-card/index.js +1 -1
- package/dist/components/permission-matrix/index.d.ts +4 -0
- package/dist/components/permission-matrix/index.js +7 -0
- package/dist/components/permission-matrix/permission-matrix.agent.d.ts +4 -0
- package/dist/components/permission-matrix/permission-matrix.d.ts +47 -0
- package/dist/components/position-grid/index.d.ts +4 -0
- package/dist/components/position-grid/index.js +7 -0
- package/dist/components/position-grid/position-grid.agent.d.ts +4 -0
- package/dist/components/position-grid/position-grid.d.ts +39 -0
- package/dist/components/postal-code-input/index.d.ts +5 -0
- package/dist/components/postal-code-input/index.js +6 -0
- package/dist/components/postal-code-input/postal-code-input.agent.d.ts +8 -0
- package/dist/components/postal-code-input/postal-code-input.d.ts +27 -0
- package/dist/components/practice-results/index.js +1 -1
- package/dist/components/pregnancy-dating/index.js +1 -1
- package/dist/components/product-hub-tray/index.js +1 -1
- package/dist/components/product-hub-tray/product-hub-tray.d.ts +13 -1
- package/dist/components/province-select/index.d.ts +6 -0
- package/dist/components/province-select/index.js +7 -0
- package/dist/components/province-select/it-provinces.d.ts +8 -0
- package/dist/components/province-select/province-select.agent.d.ts +8 -0
- package/dist/components/province-select/province-select.d.ts +38 -0
- package/dist/components/public-footer/public-footer.d.ts +1 -1
- package/dist/components/public-header/index.js +1 -1
- package/dist/components/radiograph-panel/index.js +1 -1
- package/dist/components/reviews-panel/index.js +1 -1
- package/dist/components/rich-text-editor/editor-toolbar.d.ts +17 -0
- package/dist/components/rich-text-editor/index.js +1 -1
- package/dist/components/scroll-area/index.js +1 -1
- package/dist/components/select/index.js +1 -1
- package/dist/components/select/select.d.ts +8 -2
- package/dist/components/sheet/index.js +1 -1
- package/dist/components/sidebar/index.js +1 -1
- package/dist/components/skeleton/skeleton.d.ts +1 -1
- package/dist/components/tabs/index.js +1 -1
- package/dist/components/task-card/index.js +1 -1
- package/dist/components/task-card/task-card.d.ts +14 -6
- package/dist/components/task-tray/index.js +1 -1
- package/dist/components/tasks-panel/index.d.ts +4 -0
- package/dist/components/tasks-panel/index.js +6 -0
- package/dist/components/tasks-panel/tasks-panel.agent.d.ts +4 -0
- package/dist/components/tasks-panel/tasks-panel.d.ts +152 -0
- package/dist/components/token-insert-menu/index.d.ts +4 -0
- package/dist/components/token-insert-menu/index.js +6 -0
- package/dist/components/token-insert-menu/token-insert-menu.agent.d.ts +4 -0
- package/dist/components/token-insert-menu/token-insert-menu.d.ts +33 -0
- package/dist/components/tool-rail/index.d.ts +4 -0
- package/dist/components/tool-rail/index.js +6 -0
- package/dist/components/tool-rail/tool-rail.agent.d.ts +4 -0
- package/dist/components/{ai-tools-rail/ai-tools-rail.d.ts → tool-rail/tool-rail.d.ts} +29 -12
- package/dist/components/tooth-scheme/index.js +1 -1
- package/dist/components/tooth-scheme/tooth-scheme.d.ts +9 -0
- package/dist/components/transcript-panel/index.js +1 -1
- package/dist/components/transcript-panel/transcript-panel.d.ts +2 -2
- package/dist/components/unit-converter/index.js +1 -1
- package/dist/components/workflow/index.js +1 -1
- package/dist/hooks/use-edge-resize.d.ts +2 -2
- package/dist/i18n/locales/ar.d.ts +167 -2
- package/dist/i18n/locales/ar.js +157 -5
- package/dist/i18n/locales/de.d.ts +167 -2
- package/dist/i18n/locales/de.js +159 -5
- package/dist/i18n/locales/el.d.ts +167 -2
- package/dist/i18n/locales/el.js +164 -5
- package/dist/i18n/locales/en.d.ts +167 -2
- package/dist/i18n/locales/en.js +170 -5
- package/dist/i18n/locales/es.d.ts +167 -2
- package/dist/i18n/locales/es.js +156 -5
- package/dist/i18n/locales/fr.d.ts +167 -2
- package/dist/i18n/locales/fr.js +159 -5
- package/dist/i18n/locales/hi.d.ts +167 -2
- package/dist/i18n/locales/hi.js +155 -5
- package/dist/i18n/locales/it.d.ts +167 -2
- package/dist/i18n/locales/it.js +159 -5
- package/dist/i18n/locales/ja.d.ts +167 -2
- package/dist/i18n/locales/ja.js +160 -5
- package/dist/i18n/locales/nl.d.ts +167 -2
- package/dist/i18n/locales/nl.js +152 -5
- package/dist/i18n/locales/pl.d.ts +167 -2
- package/dist/i18n/locales/pl.js +160 -5
- package/dist/i18n/locales/pt.d.ts +167 -2
- package/dist/i18n/locales/pt.js +164 -5
- package/dist/i18n/locales/ro.d.ts +167 -2
- package/dist/i18n/locales/ro.js +164 -5
- package/dist/i18n/locales/ru.d.ts +167 -2
- package/dist/i18n/locales/ru.js +157 -5
- package/dist/i18n/locales/sq.d.ts +167 -2
- package/dist/i18n/locales/sq.js +161 -5
- package/dist/i18n/locales/sv.d.ts +167 -2
- package/dist/i18n/locales/sv.js +159 -5
- package/dist/i18n/locales/tr.d.ts +167 -2
- package/dist/i18n/locales/tr.js +157 -5
- package/dist/i18n/locales/zh.d.ts +167 -2
- package/dist/i18n/locales/zh.js +152 -5
- package/dist/index.js +823 -755
- package/dist/locales/ar.json +170 -5
- package/dist/locales/de.json +170 -5
- package/dist/locales/el.json +170 -5
- package/dist/locales/en.json +170 -5
- package/dist/locales/es.json +170 -5
- package/dist/locales/fr.json +170 -5
- package/dist/locales/hi.json +170 -5
- package/dist/locales/it.json +170 -5
- package/dist/locales/ja.json +170 -5
- package/dist/locales/nl.json +170 -5
- package/dist/locales/pl.json +170 -5
- package/dist/locales/pt.json +170 -5
- package/dist/locales/ro.json +170 -5
- package/dist/locales/ru.json +170 -5
- package/dist/locales/sq.json +170 -5
- package/dist/locales/sv.json +170 -5
- package/dist/locales/tr.json +170 -5
- package/dist/locales/zh.json +170 -5
- package/dist/patterns/alia-assistant/alia-types.d.ts +9 -0
- package/dist/patterns/alia-assistant/index.js +1 -1
- package/dist/patterns/marketplace-app-shell/index.js +1 -1
- package/dist/patterns/patient-shell/index.js +1 -1
- package/dist/tokens.css +9 -1
- package/package.json +65 -5
- package/dist/_chunks/care-plan-header-BUwqDTtz.js +0 -206
- package/dist/_chunks/control-room-rail-Y8ryLYsP.js +0 -229
- package/dist/_chunks/editable-currency-cell-renderer-C9twtALM.js +0 -328
- package/dist/_chunks/entity-summary-BxRjFh_4.js +0 -138
- package/dist/_chunks/message-card-Bx4GmLvf.js +0 -277
- package/dist/_chunks/notes-panel-ay8_lPrA.js +0 -158
- package/dist/_chunks/notification-card-D2jiKSJJ.js +0 -259
- package/dist/_chunks/radiograph-panel.agent-CAX-C3g3.js +0 -558
- package/dist/_chunks/reviews-panel-Dq7LMDcH.js +0 -555
- package/dist/_chunks/rich-text-editor-DlCqPixb.js +0 -2158
- package/dist/_chunks/task-card-BwY9jaV1.js +0 -124
- package/dist/components/ai-tools-rail/ai-tools-rail.agent.d.ts +0 -4
- package/dist/components/ai-tools-rail/index.d.ts +0 -4
- package/dist/components/ai-tools-rail/index.js +0 -6
|
@@ -0,0 +1,436 @@
|
|
|
1
|
+
import { jsxs as B, jsx as d, Fragment as He } from "react/jsx-runtime";
|
|
2
|
+
import { forwardRef as Le, useContext as _e, useState as O, useRef as _, useId as $e, useEffect as Ge, useMemo as $, useCallback as ee } from "react";
|
|
3
|
+
import { c as re } from "./index-D2ZczOXr.js";
|
|
4
|
+
import { useTranslation as Ke } from "react-i18next";
|
|
5
|
+
import { u as Pe, F as Ue } from "./form-field-context-B3APVHKx.js";
|
|
6
|
+
import { I as te, c as we, a as G, b as K } from "./input-surface-xyERuLU_.js";
|
|
7
|
+
import { c as Ze } from "./compose-refs-C0k0tdqF.js";
|
|
8
|
+
import { u as ze } from "./use-isomorphic-layout-effect-BGfaCOP1.js";
|
|
9
|
+
import { u as De } from "./registry-DvAUVLHh.js";
|
|
10
|
+
import { C as ne } from "./circle-alert-ChA9opNA.js";
|
|
11
|
+
import { C as se } from "./circle-check-9AeSgJD_.js";
|
|
12
|
+
const je = {
|
|
13
|
+
id: "iban-input",
|
|
14
|
+
capabilities: ["set_value"],
|
|
15
|
+
state: {
|
|
16
|
+
value: {
|
|
17
|
+
type: "string",
|
|
18
|
+
descriptionKey: "ui.agent.ibanInput.state.value",
|
|
19
|
+
description: "Current IBAN, normalised (uppercased, [A-Z0-9], no spaces, ≤34 characters).",
|
|
20
|
+
read: (e) => e.getValue()
|
|
21
|
+
},
|
|
22
|
+
isValid: {
|
|
23
|
+
type: "boolean",
|
|
24
|
+
descriptionKey: "ui.agent.ibanInput.state.isValid",
|
|
25
|
+
description: "Whether the value is a structurally complete IBAN with a passing mod-97-10 checksum.",
|
|
26
|
+
read: (e) => e.isValid()
|
|
27
|
+
}
|
|
28
|
+
},
|
|
29
|
+
actions: {
|
|
30
|
+
set_value: {
|
|
31
|
+
safety: "write",
|
|
32
|
+
argsType: "{ value: string }",
|
|
33
|
+
argsSchema: {
|
|
34
|
+
type: "object",
|
|
35
|
+
properties: { value: { type: "string" } },
|
|
36
|
+
required: ["value"]
|
|
37
|
+
},
|
|
38
|
+
idempotent: !0,
|
|
39
|
+
descriptionKey: "ui.agent.ibanInput.actions.setValue",
|
|
40
|
+
description: "Replace the IBAN. The value is uppercased and stripped to [A-Z0-9], capped at 34 characters.",
|
|
41
|
+
examples: [
|
|
42
|
+
{
|
|
43
|
+
args: { value: "DE89370400440532013000" },
|
|
44
|
+
note: "A complete, checksum-valid German IBAN."
|
|
45
|
+
}
|
|
46
|
+
],
|
|
47
|
+
invoke: (e, s) => {
|
|
48
|
+
e.setValue(s.value);
|
|
49
|
+
}
|
|
50
|
+
},
|
|
51
|
+
clear: {
|
|
52
|
+
safety: "destructive",
|
|
53
|
+
idempotent: !0,
|
|
54
|
+
descriptionKey: "ui.agent.ibanInput.actions.clear",
|
|
55
|
+
description: "Empty the input. Loses any typed value.",
|
|
56
|
+
invoke: (e) => {
|
|
57
|
+
e.clear();
|
|
58
|
+
}
|
|
59
|
+
},
|
|
60
|
+
focus: {
|
|
61
|
+
safety: "read",
|
|
62
|
+
descriptionKey: "ui.agent.ibanInput.actions.focus",
|
|
63
|
+
description: "Move keyboard focus to the IBAN input.",
|
|
64
|
+
invoke: (e) => {
|
|
65
|
+
e.focus();
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
},
|
|
69
|
+
domHooks: {
|
|
70
|
+
root: {
|
|
71
|
+
attr: "data-component",
|
|
72
|
+
value: "iban-input",
|
|
73
|
+
description: "Marks the IbanInput wrapper."
|
|
74
|
+
},
|
|
75
|
+
instanceId: {
|
|
76
|
+
attr: "data-component-id",
|
|
77
|
+
sourceProp: "id",
|
|
78
|
+
description: "Sourced from the id prop."
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
}, qe = {
|
|
82
|
+
AD: 24,
|
|
83
|
+
AE: 23,
|
|
84
|
+
AL: 28,
|
|
85
|
+
AT: 20,
|
|
86
|
+
AZ: 28,
|
|
87
|
+
BA: 20,
|
|
88
|
+
BE: 16,
|
|
89
|
+
BG: 22,
|
|
90
|
+
BH: 22,
|
|
91
|
+
BR: 29,
|
|
92
|
+
BY: 28,
|
|
93
|
+
CH: 21,
|
|
94
|
+
CR: 22,
|
|
95
|
+
CY: 28,
|
|
96
|
+
CZ: 24,
|
|
97
|
+
DE: 22,
|
|
98
|
+
DK: 18,
|
|
99
|
+
DO: 28,
|
|
100
|
+
EE: 20,
|
|
101
|
+
EG: 29,
|
|
102
|
+
ES: 24,
|
|
103
|
+
FI: 18,
|
|
104
|
+
FO: 18,
|
|
105
|
+
FR: 27,
|
|
106
|
+
GB: 22,
|
|
107
|
+
GE: 22,
|
|
108
|
+
GI: 23,
|
|
109
|
+
GL: 18,
|
|
110
|
+
GR: 27,
|
|
111
|
+
GT: 28,
|
|
112
|
+
HR: 21,
|
|
113
|
+
HU: 28,
|
|
114
|
+
IE: 22,
|
|
115
|
+
IL: 23,
|
|
116
|
+
IS: 26,
|
|
117
|
+
IT: 27,
|
|
118
|
+
JO: 30,
|
|
119
|
+
KW: 30,
|
|
120
|
+
KZ: 20,
|
|
121
|
+
LB: 28,
|
|
122
|
+
LC: 32,
|
|
123
|
+
LI: 21,
|
|
124
|
+
LT: 20,
|
|
125
|
+
LU: 20,
|
|
126
|
+
LV: 21,
|
|
127
|
+
MC: 27,
|
|
128
|
+
MD: 24,
|
|
129
|
+
ME: 22,
|
|
130
|
+
MK: 19,
|
|
131
|
+
MR: 27,
|
|
132
|
+
MT: 31,
|
|
133
|
+
MU: 30,
|
|
134
|
+
NL: 18,
|
|
135
|
+
NO: 15,
|
|
136
|
+
PK: 24,
|
|
137
|
+
PL: 28,
|
|
138
|
+
PS: 29,
|
|
139
|
+
PT: 25,
|
|
140
|
+
QA: 29,
|
|
141
|
+
RO: 24,
|
|
142
|
+
RS: 22,
|
|
143
|
+
SA: 24,
|
|
144
|
+
SC: 31,
|
|
145
|
+
SE: 24,
|
|
146
|
+
SI: 19,
|
|
147
|
+
SK: 24,
|
|
148
|
+
SM: 27,
|
|
149
|
+
TN: 24,
|
|
150
|
+
TR: 26,
|
|
151
|
+
UA: 29,
|
|
152
|
+
VG: 24,
|
|
153
|
+
XK: 20
|
|
154
|
+
}, Xe = 15, ae = 34;
|
|
155
|
+
function We(e) {
|
|
156
|
+
const s = e.slice(4) + e.slice(0, 4);
|
|
157
|
+
let i = 0;
|
|
158
|
+
for (let a = 0; a < s.length; a += 1) {
|
|
159
|
+
const o = s.charCodeAt(a), N = o >= 65 && o <= 90 ? String(o - 55) : String.fromCharCode(o);
|
|
160
|
+
for (let m = 0; m < N.length; m += 1)
|
|
161
|
+
i = (i * 10 + (N.charCodeAt(m) - 48)) % 97;
|
|
162
|
+
}
|
|
163
|
+
return i;
|
|
164
|
+
}
|
|
165
|
+
function S(e) {
|
|
166
|
+
if (e === "") return "empty";
|
|
167
|
+
const s = /^[A-Z]{2}/.test(e) ? e.slice(0, 2) : void 0, i = s ? qe[s] : void 0;
|
|
168
|
+
return i && e.length > i ? "badFormat" : (i ? e.length === i : e.length >= Xe) ? /^[A-Z]{2}\d{2}[A-Z0-9]+$/.test(e) ? We(e) === 1 ? "valid" : "badChecksum" : "badFormat" : "incomplete";
|
|
169
|
+
}
|
|
170
|
+
function pt(e) {
|
|
171
|
+
return S(e) === "valid";
|
|
172
|
+
}
|
|
173
|
+
const Ye = re(
|
|
174
|
+
["ds:relative ds:flex ds:items-center ds:w-full", we].join(
|
|
175
|
+
" "
|
|
176
|
+
),
|
|
177
|
+
{
|
|
178
|
+
variants: {
|
|
179
|
+
size: {
|
|
180
|
+
sm: G.sm,
|
|
181
|
+
md: G.md,
|
|
182
|
+
lg: G.lg
|
|
183
|
+
},
|
|
184
|
+
tone: {
|
|
185
|
+
default: te.default,
|
|
186
|
+
error: `${te.error} ds:focus-within:outline-destructive`
|
|
187
|
+
}
|
|
188
|
+
},
|
|
189
|
+
defaultVariants: { size: "md", tone: "default" }
|
|
190
|
+
}
|
|
191
|
+
), Je = re(
|
|
192
|
+
[
|
|
193
|
+
// dir="ltr" + tabular-nums keep the IBAN rendering left-to-right and evenly
|
|
194
|
+
// spaced even under an RTL/CJK surrounding UI — this is a value-RENDERING
|
|
195
|
+
// concern (the IBAN is never mirrored), not a layout-direction violation,
|
|
196
|
+
// so logical-prop rules don't apply to the IBAN glyphs themselves.
|
|
197
|
+
"ds:w-full ds:min-w-0 ds:bg-transparent ds:text-foreground ds:placeholder:text-muted-foreground",
|
|
198
|
+
"ds:border-0 ds:outline-none ds:tabular-nums ds:uppercase ds:tracking-wide",
|
|
199
|
+
"ds:disabled:cursor-not-allowed",
|
|
200
|
+
"ds:read-only:cursor-default"
|
|
201
|
+
].join(" "),
|
|
202
|
+
{
|
|
203
|
+
variants: {
|
|
204
|
+
size: {
|
|
205
|
+
sm: `ds:ps-3 ds:pe-3 ${K.sm}`,
|
|
206
|
+
md: `ds:ps-3 ds:pe-3 ${K.md}`,
|
|
207
|
+
lg: `ds:ps-4 ds:pe-4 ${K.lg}`
|
|
208
|
+
},
|
|
209
|
+
hasEnd: {
|
|
210
|
+
true: "ds:pe-10",
|
|
211
|
+
false: ""
|
|
212
|
+
}
|
|
213
|
+
},
|
|
214
|
+
defaultVariants: { size: "md", hasEnd: !1 }
|
|
215
|
+
}
|
|
216
|
+
), Qe = "ds:absolute ds:inset-y-0 ds:end-0 ds:pe-3 ds:flex ds:items-center ds:pointer-events-none ds:[&_svg]:size-4", P = "type-body-sm ds:mt-[var(--spacing-xs)]";
|
|
217
|
+
function f(e) {
|
|
218
|
+
return e.normalize("NFKC").replace(/[٠-٩]/g, (s) => String(s.charCodeAt(0) - 1632)).replace(/[۰-۹]/g, (s) => String(s.charCodeAt(0) - 1776)).toUpperCase().replace(/[^A-Z0-9]/g, "").slice(0, ae);
|
|
219
|
+
}
|
|
220
|
+
function Oe(e, s) {
|
|
221
|
+
let i = 0;
|
|
222
|
+
for (let a = 0; a < s && a < e.length; a += 1) {
|
|
223
|
+
const o = e[a];
|
|
224
|
+
(o >= "0" && o <= "9" || o >= "A" && o <= "Z" || o >= "a" && o <= "z") && (i += 1);
|
|
225
|
+
}
|
|
226
|
+
return i;
|
|
227
|
+
}
|
|
228
|
+
const et = Le(
|
|
229
|
+
function({
|
|
230
|
+
value: s,
|
|
231
|
+
defaultValue: i,
|
|
232
|
+
onChange: a,
|
|
233
|
+
size: o = "md",
|
|
234
|
+
tone: N = "default",
|
|
235
|
+
validateOn: m = "blur",
|
|
236
|
+
showError: oe,
|
|
237
|
+
errorMessage: y,
|
|
238
|
+
disabled: ie,
|
|
239
|
+
readOnly: u,
|
|
240
|
+
required: ce,
|
|
241
|
+
placeholder: de,
|
|
242
|
+
showFormatHint: le = !0,
|
|
243
|
+
id: R,
|
|
244
|
+
name: ue,
|
|
245
|
+
className: pe,
|
|
246
|
+
"aria-label": U
|
|
247
|
+
}, me) {
|
|
248
|
+
const { t: p } = Ke(), C = Pe(), l = _e(Ue) !== null, h = s !== void 0, [fe, T] = O(
|
|
249
|
+
() => f(i ?? "")
|
|
250
|
+
), c = h ? f(s ?? "") : fe, [he, ge] = O(!1), F = _(!1), g = _(null), b = _(null), be = Ze(me, b), V = $e(), w = `${V}-hint`, Z = `${V}-status`, z = `${V}-error`;
|
|
251
|
+
Ge(() => {
|
|
252
|
+
}, [l, U]);
|
|
253
|
+
const v = $(() => S(c), [c]), D = v !== "empty" && v !== "incomplete", E = v === "valid", ve = (l ? C.disabled : !1) || !!ie, Ie = (l ? C.required : !1) || !!ce, Ce = !u && (!!oe || D && !E && (m === "change" || m === "blur" && he)), j = l && C.invalid, I = Ce && !j, q = j || I, Ee = q || N === "error" ? "error" : "default", Ae = $(() => y || p(v === "badChecksum" ? "inputs.iban.errorChecksum" : v === "badFormat" ? "inputs.iban.errorFormat" : "inputs.iban.errorIncomplete"), [y, v, p]), X = !l && le && !u, xe = l ? void 0 : [
|
|
254
|
+
X ? w : null,
|
|
255
|
+
I ? z : Z
|
|
256
|
+
].filter(Boolean).join(" ") || void 0, Ne = l ? C.describedBy || void 0 : xe, Be = R ?? C.id, A = ee(
|
|
257
|
+
(t) => {
|
|
258
|
+
const n = S(t);
|
|
259
|
+
a == null || a(t, {
|
|
260
|
+
isValid: n === "valid",
|
|
261
|
+
isComplete: n !== "empty" && n !== "incomplete",
|
|
262
|
+
reason: n
|
|
263
|
+
});
|
|
264
|
+
},
|
|
265
|
+
[a]
|
|
266
|
+
), k = ee(
|
|
267
|
+
(t) => {
|
|
268
|
+
h || T(t), A(t);
|
|
269
|
+
},
|
|
270
|
+
[h, A]
|
|
271
|
+
);
|
|
272
|
+
ze(() => {
|
|
273
|
+
if (g.current == null) return;
|
|
274
|
+
const t = g.current;
|
|
275
|
+
g.current = null;
|
|
276
|
+
const n = b.current;
|
|
277
|
+
if (n && document.activeElement === n) {
|
|
278
|
+
const r = Math.min(t, n.value.length);
|
|
279
|
+
n.setSelectionRange(r, r);
|
|
280
|
+
}
|
|
281
|
+
});
|
|
282
|
+
const Se = (t) => {
|
|
283
|
+
if (u || F.current) return;
|
|
284
|
+
const n = t.target, r = n.value, H = n.selectionStart ?? r.length, L = Oe(r, H), x = f(r);
|
|
285
|
+
g.current = Math.min(L, x.length), k(x);
|
|
286
|
+
}, ye = () => {
|
|
287
|
+
F.current = !0;
|
|
288
|
+
}, Re = (t) => {
|
|
289
|
+
if (F.current = !1, u) return;
|
|
290
|
+
const n = f(t.currentTarget.value);
|
|
291
|
+
g.current = n.length, k(n);
|
|
292
|
+
}, Te = (t) => {
|
|
293
|
+
if (u) return;
|
|
294
|
+
const n = t.clipboardData.getData("text");
|
|
295
|
+
t.preventDefault();
|
|
296
|
+
const r = b.current, H = (r == null ? void 0 : r.selectionStart) ?? c.length, L = (r == null ? void 0 : r.selectionEnd) ?? c.length, x = f(n), J = c.slice(0, H), Me = c.slice(L), Q = f(J + x + Me);
|
|
297
|
+
g.current = Math.min(
|
|
298
|
+
(J + x).length,
|
|
299
|
+
Q.length
|
|
300
|
+
), k(Q);
|
|
301
|
+
}, Fe = () => {
|
|
302
|
+
m === "blur" && ge(!0);
|
|
303
|
+
}, Ve = $(
|
|
304
|
+
() => ({
|
|
305
|
+
getValue: () => c,
|
|
306
|
+
setValue: (t) => {
|
|
307
|
+
var r;
|
|
308
|
+
const n = f(t);
|
|
309
|
+
h || T(n), A(n), (r = b.current) == null || r.focus();
|
|
310
|
+
},
|
|
311
|
+
clear: () => {
|
|
312
|
+
var t;
|
|
313
|
+
h || T(""), A(""), (t = b.current) == null || t.focus();
|
|
314
|
+
},
|
|
315
|
+
focus: () => {
|
|
316
|
+
var t;
|
|
317
|
+
return (t = b.current) == null ? void 0 : t.focus();
|
|
318
|
+
},
|
|
319
|
+
isValid: () => S(c) === "valid"
|
|
320
|
+
}),
|
|
321
|
+
[c, h, A]
|
|
322
|
+
);
|
|
323
|
+
De(je, Ve, R);
|
|
324
|
+
const ke = de ?? p("inputs.iban.placeholder"), M = u || l ? "" : E ? p("inputs.iban.valid") : c.length > 0 && !D ? p("inputs.iban.charactersEntered", { count: c.length }) : "", W = I ? Ae : "", Y = !u && (I || E && !l);
|
|
325
|
+
return /* @__PURE__ */ B(
|
|
326
|
+
"div",
|
|
327
|
+
{
|
|
328
|
+
className: "ds:flex ds:flex-col",
|
|
329
|
+
"data-component": "iban-input",
|
|
330
|
+
"data-component-id": R,
|
|
331
|
+
children: [
|
|
332
|
+
/* @__PURE__ */ B(
|
|
333
|
+
"div",
|
|
334
|
+
{
|
|
335
|
+
"data-slot": "iban-input",
|
|
336
|
+
className: Ye({ size: o, tone: Ee, className: pe }),
|
|
337
|
+
children: [
|
|
338
|
+
/* @__PURE__ */ d(
|
|
339
|
+
"input",
|
|
340
|
+
{
|
|
341
|
+
ref: be,
|
|
342
|
+
id: Be,
|
|
343
|
+
name: ue,
|
|
344
|
+
dir: "ltr",
|
|
345
|
+
type: "text",
|
|
346
|
+
inputMode: "text",
|
|
347
|
+
autoCapitalize: "characters",
|
|
348
|
+
autoCorrect: "off",
|
|
349
|
+
autoComplete: "off",
|
|
350
|
+
spellCheck: !1,
|
|
351
|
+
maxLength: ae,
|
|
352
|
+
pattern: "[A-Za-z]{2}[0-9]{2}[A-Za-z0-9]+",
|
|
353
|
+
value: c,
|
|
354
|
+
placeholder: ke,
|
|
355
|
+
disabled: ve,
|
|
356
|
+
readOnly: u,
|
|
357
|
+
"aria-label": U,
|
|
358
|
+
"aria-describedby": Ne,
|
|
359
|
+
"aria-invalid": q || void 0,
|
|
360
|
+
"aria-required": Ie || void 0,
|
|
361
|
+
onChange: Se,
|
|
362
|
+
onCompositionStart: ye,
|
|
363
|
+
onCompositionEnd: Re,
|
|
364
|
+
onPaste: Te,
|
|
365
|
+
onBlur: Fe,
|
|
366
|
+
className: Je({ size: o, hasEnd: Y })
|
|
367
|
+
}
|
|
368
|
+
),
|
|
369
|
+
Y ? /* @__PURE__ */ d(
|
|
370
|
+
"span",
|
|
371
|
+
{
|
|
372
|
+
"aria-hidden": "true",
|
|
373
|
+
className: `${Qe} ${I ? "ds:text-destructive" : "ds:text-success"}`,
|
|
374
|
+
children: I ? /* @__PURE__ */ d(ne, {}) : /* @__PURE__ */ d(se, {})
|
|
375
|
+
}
|
|
376
|
+
) : null
|
|
377
|
+
]
|
|
378
|
+
}
|
|
379
|
+
),
|
|
380
|
+
X ? /* @__PURE__ */ d(
|
|
381
|
+
"p",
|
|
382
|
+
{
|
|
383
|
+
id: w,
|
|
384
|
+
className: `${P} ds:text-muted-foreground`,
|
|
385
|
+
children: p("inputs.iban.formatHint")
|
|
386
|
+
}
|
|
387
|
+
) : null,
|
|
388
|
+
/* @__PURE__ */ d(
|
|
389
|
+
"p",
|
|
390
|
+
{
|
|
391
|
+
id: Z,
|
|
392
|
+
role: "status",
|
|
393
|
+
"aria-live": "polite",
|
|
394
|
+
className: `${P} ds:inline-flex ds:items-center ds:gap-[var(--spacing-xs)] ${E ? "ds:text-success" : "ds:text-muted-foreground"} ${M ? "" : "ds:sr-only"}`,
|
|
395
|
+
children: M ? /* @__PURE__ */ B(He, { children: [
|
|
396
|
+
E ? /* @__PURE__ */ d(
|
|
397
|
+
se,
|
|
398
|
+
{
|
|
399
|
+
"aria-hidden": "true",
|
|
400
|
+
className: "ds:size-4 ds:shrink-0"
|
|
401
|
+
}
|
|
402
|
+
) : null,
|
|
403
|
+
/* @__PURE__ */ d("span", { children: M })
|
|
404
|
+
] }) : null
|
|
405
|
+
}
|
|
406
|
+
),
|
|
407
|
+
W ? /* @__PURE__ */ B(
|
|
408
|
+
"p",
|
|
409
|
+
{
|
|
410
|
+
id: z,
|
|
411
|
+
role: "alert",
|
|
412
|
+
className: `${P} ds:inline-flex ds:items-center ds:gap-[var(--spacing-xs)] ds:text-destructive`,
|
|
413
|
+
children: [
|
|
414
|
+
/* @__PURE__ */ d(ne, { "aria-hidden": "true", className: "ds:size-4 ds:shrink-0" }),
|
|
415
|
+
/* @__PURE__ */ d("span", { children: W })
|
|
416
|
+
]
|
|
417
|
+
}
|
|
418
|
+
) : null
|
|
419
|
+
]
|
|
420
|
+
}
|
|
421
|
+
);
|
|
422
|
+
}
|
|
423
|
+
);
|
|
424
|
+
et.displayName = "IbanInput";
|
|
425
|
+
export {
|
|
426
|
+
qe as I,
|
|
427
|
+
ae as M,
|
|
428
|
+
et as a,
|
|
429
|
+
Xe as b,
|
|
430
|
+
S as c,
|
|
431
|
+
We as d,
|
|
432
|
+
pt as e,
|
|
433
|
+
je as i,
|
|
434
|
+
Ye as w
|
|
435
|
+
};
|
|
436
|
+
//# sourceMappingURL=iban-input-B0TWzR1R.js.map
|
|
@@ -0,0 +1,272 @@
|
|
|
1
|
+
import { jsxs as N, jsx as r } from "react/jsx-runtime";
|
|
2
|
+
import { forwardRef as H, useState as y, useRef as h, useCallback as v, useMemo as b } from "react";
|
|
3
|
+
import { c as M } from "./index-D2ZczOXr.js";
|
|
4
|
+
import { useTranslation as F } from "react-i18next";
|
|
5
|
+
import { P as k } from "./popover-B2qCDhJC.js";
|
|
6
|
+
import { B as D } from "./button-DD_0Xdmr.js";
|
|
7
|
+
import { T as E } from "./text-input-B-OWQ1Je.js";
|
|
8
|
+
import { u as G } from "./registry-DvAUVLHh.js";
|
|
9
|
+
import { S as J } from "./search-BonnQsHv.js";
|
|
10
|
+
const U = {
|
|
11
|
+
id: "icon-picker",
|
|
12
|
+
capabilities: ["pick", "filter", "open", "close"],
|
|
13
|
+
state: {
|
|
14
|
+
value: {
|
|
15
|
+
type: "string",
|
|
16
|
+
descriptionKey: "ui.agent.iconPicker.state.value",
|
|
17
|
+
description: "Id of the currently selected icon, or an empty string when nothing is picked.",
|
|
18
|
+
read: (t) => t.getValue()
|
|
19
|
+
},
|
|
20
|
+
isOpen: {
|
|
21
|
+
type: "boolean",
|
|
22
|
+
descriptionKey: "ui.agent.iconPicker.state.isOpen",
|
|
23
|
+
description: "True when the picker popover is currently open.",
|
|
24
|
+
read: (t) => t.isOpen()
|
|
25
|
+
},
|
|
26
|
+
query: {
|
|
27
|
+
type: "string",
|
|
28
|
+
descriptionKey: "ui.agent.iconPicker.state.query",
|
|
29
|
+
description: "Current search query filtering the icon grid by label.",
|
|
30
|
+
read: (t) => t.getQuery()
|
|
31
|
+
}
|
|
32
|
+
},
|
|
33
|
+
actions: {
|
|
34
|
+
set_value: {
|
|
35
|
+
safety: "write",
|
|
36
|
+
argsType: "{ id: string }",
|
|
37
|
+
argsSchema: {
|
|
38
|
+
type: "object",
|
|
39
|
+
properties: {
|
|
40
|
+
id: {
|
|
41
|
+
type: "string",
|
|
42
|
+
description: "Id of an icon in the supplied `icons` set."
|
|
43
|
+
}
|
|
44
|
+
},
|
|
45
|
+
required: ["id"]
|
|
46
|
+
},
|
|
47
|
+
idempotent: !0,
|
|
48
|
+
descriptionKey: "ui.agent.iconPicker.actions.setValue",
|
|
49
|
+
description: "Select the icon with the given id.",
|
|
50
|
+
examples: [{ args: { id: "star" }, note: 'Pick the "star" icon.' }],
|
|
51
|
+
invoke: (t, i) => {
|
|
52
|
+
t.setValue(i.id);
|
|
53
|
+
}
|
|
54
|
+
},
|
|
55
|
+
open: {
|
|
56
|
+
safety: "read",
|
|
57
|
+
idempotent: !0,
|
|
58
|
+
descriptionKey: "ui.agent.iconPicker.actions.open",
|
|
59
|
+
description: "Open the picker popover.",
|
|
60
|
+
invoke: (t) => {
|
|
61
|
+
t.open();
|
|
62
|
+
}
|
|
63
|
+
},
|
|
64
|
+
close: {
|
|
65
|
+
safety: "read",
|
|
66
|
+
idempotent: !0,
|
|
67
|
+
descriptionKey: "ui.agent.iconPicker.actions.close",
|
|
68
|
+
description: "Close the picker popover.",
|
|
69
|
+
invoke: (t) => {
|
|
70
|
+
t.close();
|
|
71
|
+
}
|
|
72
|
+
},
|
|
73
|
+
filter: {
|
|
74
|
+
safety: "write",
|
|
75
|
+
argsType: "{ query: string }",
|
|
76
|
+
argsSchema: {
|
|
77
|
+
type: "object",
|
|
78
|
+
properties: {
|
|
79
|
+
query: {
|
|
80
|
+
type: "string",
|
|
81
|
+
description: "Case-insensitive substring matched against icon labels."
|
|
82
|
+
}
|
|
83
|
+
},
|
|
84
|
+
required: ["query"]
|
|
85
|
+
},
|
|
86
|
+
idempotent: !0,
|
|
87
|
+
descriptionKey: "ui.agent.iconPicker.actions.filter",
|
|
88
|
+
description: "Filter the icon grid to labels containing the query.",
|
|
89
|
+
examples: [
|
|
90
|
+
{
|
|
91
|
+
args: { query: "star" },
|
|
92
|
+
note: 'Show icons whose label contains "star".'
|
|
93
|
+
}
|
|
94
|
+
],
|
|
95
|
+
invoke: (t, i) => {
|
|
96
|
+
t.setQuery(i.query);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
},
|
|
100
|
+
domHooks: {
|
|
101
|
+
root: {
|
|
102
|
+
attr: "data-component",
|
|
103
|
+
value: "icon-picker",
|
|
104
|
+
description: "Marks the IconPicker trigger button."
|
|
105
|
+
},
|
|
106
|
+
instanceId: {
|
|
107
|
+
attr: "data-component-id",
|
|
108
|
+
sourceProp: "id",
|
|
109
|
+
description: "Sourced from the id prop."
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
}, W = M(
|
|
113
|
+
[
|
|
114
|
+
"ds:relative ds:inline-flex ds:items-center ds:justify-center",
|
|
115
|
+
"ds:size-[var(--min-target-size)] ds:rounded-[var(--radius-sm)]",
|
|
116
|
+
"ds:border ds:text-foreground ds:bg-transparent",
|
|
117
|
+
"ds:transition-colors ds:duration-[var(--animation-duration)] ds:motion-reduce:transition-none",
|
|
118
|
+
"ds:hover:bg-muted/10",
|
|
119
|
+
"ds:focus-visible:outline-[length:var(--focus-ring-width)] ds:focus-visible:outline-solid",
|
|
120
|
+
"ds:focus-visible:outline-ring ds:focus-visible:outline-offset-[length:var(--focus-ring-offset)]",
|
|
121
|
+
"ds:forced-colors:focus-visible:outline-[CanvasText]",
|
|
122
|
+
"ds:[&_svg]:size-5"
|
|
123
|
+
].join(" "),
|
|
124
|
+
{
|
|
125
|
+
variants: {
|
|
126
|
+
selected: {
|
|
127
|
+
true: "ds:border-primary ds:bg-muted",
|
|
128
|
+
false: "ds:border-transparent"
|
|
129
|
+
}
|
|
130
|
+
},
|
|
131
|
+
defaultVariants: { selected: !1 }
|
|
132
|
+
}
|
|
133
|
+
), X = H(
|
|
134
|
+
function({
|
|
135
|
+
icons: i,
|
|
136
|
+
value: P,
|
|
137
|
+
defaultValue: S,
|
|
138
|
+
onChange: a,
|
|
139
|
+
placeholder: O,
|
|
140
|
+
disabled: R,
|
|
141
|
+
id: u,
|
|
142
|
+
className: T,
|
|
143
|
+
"aria-label": j
|
|
144
|
+
}, K) {
|
|
145
|
+
const { t: n } = F(), p = P !== void 0, [Q, z] = y(
|
|
146
|
+
S ?? ""
|
|
147
|
+
), o = p ? P ?? "" : Q, [g, A] = y(!1), [c, d] = y(""), x = h(o);
|
|
148
|
+
x.current = o;
|
|
149
|
+
const w = h(g);
|
|
150
|
+
w.current = g;
|
|
151
|
+
const q = h(c);
|
|
152
|
+
q.current = c;
|
|
153
|
+
const s = v((e) => {
|
|
154
|
+
A(e), e || d("");
|
|
155
|
+
}, []), l = v(
|
|
156
|
+
(e) => {
|
|
157
|
+
p || z(e), a == null || a(e);
|
|
158
|
+
},
|
|
159
|
+
[p, a]
|
|
160
|
+
), L = v(
|
|
161
|
+
(e) => {
|
|
162
|
+
l(e), s(!1);
|
|
163
|
+
},
|
|
164
|
+
[l, s]
|
|
165
|
+
), _ = b(
|
|
166
|
+
() => ({
|
|
167
|
+
getValue: () => x.current,
|
|
168
|
+
setValue: (e) => l(e),
|
|
169
|
+
isOpen: () => w.current,
|
|
170
|
+
open: () => s(!0),
|
|
171
|
+
close: () => s(!1),
|
|
172
|
+
getQuery: () => q.current,
|
|
173
|
+
setQuery: (e) => d(e)
|
|
174
|
+
}),
|
|
175
|
+
[l, s]
|
|
176
|
+
);
|
|
177
|
+
G(U, _, u);
|
|
178
|
+
const V = b(
|
|
179
|
+
() => i.find((e) => e.id === o),
|
|
180
|
+
[i, o]
|
|
181
|
+
), m = c.trim().toLowerCase(), C = b(
|
|
182
|
+
() => m ? i.filter(
|
|
183
|
+
(e) => e.label.toLowerCase().includes(m)
|
|
184
|
+
) : i,
|
|
185
|
+
[i, m]
|
|
186
|
+
), f = j ?? n("iconPicker.trigger"), B = O ?? n("iconPicker.trigger");
|
|
187
|
+
return /* @__PURE__ */ N(k.Root, { open: g, onOpenChange: s, id: u, children: [
|
|
188
|
+
/* @__PURE__ */ r(k.Trigger, { asChild: !0, children: /* @__PURE__ */ r(
|
|
189
|
+
D,
|
|
190
|
+
{
|
|
191
|
+
ref: K,
|
|
192
|
+
type: "button",
|
|
193
|
+
intent: "outline",
|
|
194
|
+
disabled: R,
|
|
195
|
+
"aria-label": f,
|
|
196
|
+
className: T,
|
|
197
|
+
"data-component": "icon-picker",
|
|
198
|
+
"data-component-id": u,
|
|
199
|
+
children: V ? /* @__PURE__ */ r(
|
|
200
|
+
"span",
|
|
201
|
+
{
|
|
202
|
+
"aria-hidden": "true",
|
|
203
|
+
className: "ds:inline-flex ds:items-center ds:justify-center ds:[&_svg]:size-5",
|
|
204
|
+
children: V.node
|
|
205
|
+
}
|
|
206
|
+
) : /* @__PURE__ */ r("span", { className: "ds:inline-flex ds:items-center ds:text-muted-foreground", children: B })
|
|
207
|
+
}
|
|
208
|
+
) }),
|
|
209
|
+
/* @__PURE__ */ r(
|
|
210
|
+
k.Content,
|
|
211
|
+
{
|
|
212
|
+
align: "start",
|
|
213
|
+
showArrow: !1,
|
|
214
|
+
"aria-label": f,
|
|
215
|
+
className: "ds:w-72",
|
|
216
|
+
children: /* @__PURE__ */ N("div", { className: "ds:flex ds:flex-col ds:gap-[var(--spacing-sm)]", children: [
|
|
217
|
+
/* @__PURE__ */ r(
|
|
218
|
+
E,
|
|
219
|
+
{
|
|
220
|
+
size: "sm",
|
|
221
|
+
value: c,
|
|
222
|
+
onChange: (e) => d(e.target.value),
|
|
223
|
+
placeholder: n("iconPicker.search"),
|
|
224
|
+
"aria-label": n("iconPicker.search"),
|
|
225
|
+
startAdornment: /* @__PURE__ */ r(J, {}),
|
|
226
|
+
clearable: !0,
|
|
227
|
+
onClear: () => d(""),
|
|
228
|
+
autoComplete: "off"
|
|
229
|
+
}
|
|
230
|
+
),
|
|
231
|
+
C.length === 0 ? /* @__PURE__ */ r(
|
|
232
|
+
"p",
|
|
233
|
+
{
|
|
234
|
+
role: "status",
|
|
235
|
+
className: "type-body-sm ds:text-muted-foreground ds:text-center ds:py-[var(--spacing-sm)]",
|
|
236
|
+
children: n("iconPicker.noResults")
|
|
237
|
+
}
|
|
238
|
+
) : /* @__PURE__ */ r(
|
|
239
|
+
"div",
|
|
240
|
+
{
|
|
241
|
+
role: "group",
|
|
242
|
+
"aria-label": f,
|
|
243
|
+
className: "ds:grid ds:grid-cols-5 ds:gap-[var(--spacing-xs)] ds:max-h-64 ds:overflow-y-auto",
|
|
244
|
+
children: C.map((e) => {
|
|
245
|
+
const I = e.id === o;
|
|
246
|
+
return /* @__PURE__ */ r(
|
|
247
|
+
"button",
|
|
248
|
+
{
|
|
249
|
+
type: "button",
|
|
250
|
+
"aria-label": e.label,
|
|
251
|
+
"aria-pressed": I,
|
|
252
|
+
onClick: () => L(e.id),
|
|
253
|
+
className: W({ selected: I }),
|
|
254
|
+
children: /* @__PURE__ */ r("span", { "aria-hidden": "true", className: "ds:inline-flex", children: e.node })
|
|
255
|
+
},
|
|
256
|
+
e.id
|
|
257
|
+
);
|
|
258
|
+
})
|
|
259
|
+
}
|
|
260
|
+
)
|
|
261
|
+
] })
|
|
262
|
+
}
|
|
263
|
+
)
|
|
264
|
+
] });
|
|
265
|
+
}
|
|
266
|
+
);
|
|
267
|
+
X.displayName = "IconPicker";
|
|
268
|
+
export {
|
|
269
|
+
X as I,
|
|
270
|
+
U as i
|
|
271
|
+
};
|
|
272
|
+
//# sourceMappingURL=icon-picker-0B7KhrF1.js.map
|