@sellmate/design-system 1.0.78 → 1.1.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/cjs/component.table-B7brIpIQ.js +56 -0
- package/dist/cjs/design-system.cjs.js +2 -2
- package/dist/cjs/{index--F2wGuAi.js → index-BlxrCRYi.js} +1 -1
- package/dist/cjs/index.cjs.js +4 -4
- package/dist/cjs/loader.cjs.js +2 -2
- package/dist/cjs/{resolveColor-LhfOKtTZ.js → resolveColor-B0hzQNLG.js} +2 -2
- package/dist/cjs/sd-action-modal.cjs.entry.js +3 -3
- package/dist/cjs/sd-badge.cjs.entry.js +2 -3
- package/dist/cjs/sd-barcode-input.cjs.entry.js +3 -3
- package/dist/cjs/{sd-button-v2.config-CnqCQQMi.js → sd-button.config-DH08UNfl.js} +114 -28
- package/dist/cjs/{sd-button-v2_2.cjs.entry.js → sd-button_2.cjs.entry.js} +101 -85
- package/dist/cjs/sd-calendar.cjs.entry.js +15 -15
- package/dist/cjs/sd-card.cjs.entry.js +2 -2
- package/dist/cjs/sd-checkbox.cjs.entry.js +4 -4
- package/dist/cjs/sd-chip.cjs.entry.js +2 -2
- package/dist/cjs/sd-circle-progress.cjs.entry.js +3 -3
- package/dist/cjs/sd-confirm-modal_2.cjs.entry.js +19 -11
- package/dist/cjs/sd-date-box.cjs.entry.js +4 -4
- package/dist/cjs/{sd-date-picker-calendar.cjs.entry.js → sd-date-picker-calendar_2.cjs.entry.js} +51 -3
- package/dist/cjs/{sd-date-picker.config-CRgCT5dn.js → sd-date-picker.config-CjvrFpYK.js} +1 -2
- package/dist/cjs/sd-date-picker_7.cjs.entry.js +1230 -0
- package/dist/cjs/sd-date-range-picker-calendar.cjs.entry.js +3 -3
- package/dist/cjs/sd-dropdown-button.cjs.entry.js +28 -27
- package/dist/cjs/{sd-button_4.cjs.entry.js → sd-field_3.cjs.entry.js} +26 -82
- package/dist/cjs/sd-form.cjs.entry.js +2 -2
- package/dist/cjs/sd-ghost-button.cjs.entry.js +12 -10
- package/dist/cjs/sd-guide.cjs.entry.js +9 -9
- package/dist/cjs/sd-key-value-table.cjs.entry.js +230 -0
- package/dist/cjs/sd-linear-progress.cjs.entry.js +3 -3
- package/dist/cjs/sd-loading-container.cjs.entry.js +3 -3
- package/dist/cjs/sd-modal-container.cjs.entry.js +1 -1
- package/dist/cjs/{sd-pagination_5.cjs.entry.js → sd-pagination_4.cjs.entry.js} +34 -296
- package/dist/cjs/sd-popover.cjs.entry.js +17 -10
- package/dist/cjs/sd-popup.cjs.entry.js +112 -0
- package/dist/cjs/sd-portal.cjs.entry.js +2 -2
- package/dist/cjs/sd-radio-button.cjs.entry.js +4 -4
- package/dist/cjs/sd-radio.cjs.entry.js +2 -2
- package/dist/cjs/sd-select-list-item_2.cjs.entry.js +155 -0
- package/dist/cjs/sd-select.config-B19ptCT2.js +178 -0
- package/dist/cjs/{sd-select-list-item_4.cjs.entry.js → sd-select_3.cjs.entry.js} +286 -318
- package/dist/cjs/sd-switch.cjs.entry.js +2 -2
- package/dist/cjs/sd-table.cjs.entry.js +40 -23
- package/dist/cjs/sd-table.config-CDyioyE2.js +65 -0
- package/dist/cjs/sd-tabs.cjs.entry.js +2 -2
- package/dist/cjs/sd-tag.cjs.entry.js +49 -14
- package/dist/cjs/sd-td.cjs.entry.js +2 -2
- package/dist/cjs/sd-text-link.cjs.entry.js +8 -5
- package/dist/cjs/sd-toast-container.cjs.entry.js +5 -5
- package/dist/cjs/sd-toast.cjs.entry.js +35 -5
- package/dist/cjs/sd-toggle.cjs.entry.js +2 -2
- package/dist/cjs/{system-DpTN1vBC.js → system-VmZRYp6V.js} +4 -2
- package/dist/cjs/{tooltipArrow-D1-wcNm1.js → tooltipArrow-N6nQ1QT-.js} +1 -1
- package/dist/collection/collection-manifest.json +4 -3
- package/dist/collection/components/assets/CheckboxCheck.js +5 -0
- package/dist/collection/components/assets/CheckboxIndeterminate.js +5 -0
- package/dist/collection/components/assets/index.js +4 -0
- package/dist/collection/components/sd-action-modal/sd-action-modal.css +1 -1
- package/dist/collection/components/sd-action-modal/sd-action-modal.js +7 -7
- package/dist/collection/components/sd-badge/sd-badge.config.js +10 -1
- package/dist/collection/components/sd-badge/sd-badge.js +1 -22
- package/dist/collection/components/sd-barcode-input/sd-barcode-input.js +4 -4
- package/dist/collection/components/{sd-button-v2/sd-button-v2.config.js → sd-button/sd-button.config.js} +1 -1
- package/dist/collection/components/sd-button/sd-button.css +47 -93
- package/dist/collection/components/sd-button/sd-button.js +99 -173
- package/dist/collection/components/sd-calendar/sd-calendar.js +14 -14
- package/dist/collection/components/sd-card/sd-card.js +1 -1
- package/dist/collection/components/sd-checkbox/sd-checkbox.js +3 -3
- package/dist/collection/components/sd-chip/sd-chip.js +1 -1
- package/dist/collection/components/sd-circle-progress/sd-circle-progress.js +1 -1
- package/dist/collection/components/sd-confirm-modal/sd-confirm-modal.js +13 -8
- package/dist/collection/components/sd-date-box/sd-date-box.js +3 -3
- package/dist/collection/components/sd-date-picker/sd-date-picker-calendar/sd-date-picker-calendar.js +1 -1
- package/dist/collection/components/sd-date-picker/sd-date-picker-trigger/sd-date-picker-trigger.css +1 -1
- package/dist/collection/components/sd-date-picker/sd-date-picker-trigger/sd-date-picker-trigger.js +7 -5
- package/dist/collection/components/sd-date-picker/sd-date-picker.js +4 -4
- package/dist/collection/components/sd-date-range-picker/sd-date-range-picker-calendar/sd-date-range-picker-calendar.js +1 -1
- package/dist/collection/components/sd-date-range-picker/sd-date-range-picker.js +4 -4
- package/dist/collection/components/sd-dropdown-button/sd-dropdown-button.config.js +1 -1
- package/dist/collection/components/sd-dropdown-button/sd-dropdown-button.js +13 -11
- package/dist/collection/components/sd-field/sd-field.css +6 -2
- package/dist/collection/components/sd-field/sd-field.js +30 -5
- package/dist/collection/components/sd-file-picker/sd-file-picker.js +4 -4
- package/dist/collection/components/sd-floating-portal/sd-floating-portal.css +1 -3
- package/dist/collection/components/sd-floating-portal/sd-floating-portal.js +3 -3
- package/dist/collection/components/sd-form/sd-form.js +1 -1
- package/dist/collection/components/sd-ghost-button/sd-ghost-button.js +12 -10
- package/dist/collection/components/sd-guide/sd-guide.css +8 -172
- package/dist/collection/components/sd-guide/sd-guide.js +6 -4
- package/dist/collection/components/sd-icon/sd-icon.js +4 -4
- package/dist/collection/components/sd-input/sd-input.css +4 -2
- package/dist/collection/components/sd-input/sd-input.js +5 -5
- package/dist/collection/components/sd-key-value-table/sd-key-value-table.config.js +36 -0
- package/dist/collection/components/sd-key-value-table/sd-key-value-table.css +119 -0
- package/dist/collection/components/sd-key-value-table/sd-key-value-table.js +301 -0
- package/dist/collection/components/sd-linear-progress/sd-linear-progress.js +1 -1
- package/dist/collection/components/sd-loading-container/sd-loading-container.js +2 -2
- package/dist/collection/components/sd-loading-modal/sd-loading-modal.js +6 -3
- package/dist/collection/components/sd-number-input/sd-number-input.css +7 -0
- package/dist/collection/components/sd-number-input/sd-number-input.js +6 -3
- package/dist/collection/components/sd-pagination/sd-pagination.js +3 -3
- package/dist/collection/components/sd-popover/sd-popover.js +128 -35
- package/dist/collection/components/sd-popup/sd-popup.config.js +34 -0
- package/dist/collection/components/sd-popup/sd-popup.css +73 -0
- package/dist/collection/components/sd-popup/sd-popup.js +163 -0
- package/dist/collection/components/sd-portal/sd-portal.js +1 -1
- package/dist/collection/components/sd-radio/sd-radio.js +1 -1
- package/dist/collection/components/sd-radio-button/sd-radio-button.js +3 -3
- package/dist/collection/components/sd-radio-group/sd-radio-group.js +2 -2
- package/dist/collection/components/sd-select/sd-select-list-item/sd-select-list-item.js +2 -2
- package/dist/collection/components/sd-select/sd-select-list-item-search/sd-select-list-item-search.css +4 -4
- package/dist/collection/components/sd-select/sd-select-list-item-search/sd-select-list-item-search.js +4 -4
- package/dist/collection/components/sd-select/sd-select-listbox/sd-select-listbox.js +5 -5
- package/dist/collection/components/sd-select/sd-select-trigger/sd-select-trigger.js +2 -2
- package/dist/collection/components/sd-select/sd-select.js +5 -5
- package/dist/collection/components/sd-switch/sd-switch.js +1 -1
- package/dist/collection/components/sd-table/sd-table.config.js +2 -2
- package/dist/collection/components/sd-table/sd-table.css +8 -8
- package/dist/collection/components/sd-table/sd-table.js +54 -18
- package/dist/collection/components/sd-table/sd-tbody/sd-tbody.js +2 -2
- package/dist/collection/components/sd-table/sd-td/sd-td.js +1 -1
- package/dist/collection/components/sd-table/sd-thead/sd-thead.js +3 -3
- package/dist/collection/components/sd-table/sd-tr/sd-tr.css +4 -0
- package/dist/collection/components/sd-table/sd-tr/sd-tr.js +21 -3
- package/dist/collection/components/sd-tabs/sd-tabs.js +1 -1
- package/dist/collection/components/sd-tag/sd-tag.config.js +40 -8
- package/dist/collection/components/sd-tag/sd-tag.js +9 -6
- package/dist/collection/components/sd-text-link/sd-text-link.css +1 -0
- package/dist/collection/components/sd-text-link/sd-text-link.js +5 -4
- package/dist/collection/components/sd-textarea/sd-textarea.css +3 -0
- package/dist/collection/components/sd-textarea/sd-textarea.js +2 -2
- package/dist/collection/components/sd-toast/sd-toast.config.js +14 -0
- package/dist/collection/components/sd-toast/sd-toast.css +3 -5
- package/dist/collection/components/sd-toast/sd-toast.js +52 -5
- package/dist/collection/components/sd-toast-container/sd-toast-container.js +4 -4
- package/dist/collection/components/sd-toggle/sd-toggle.js +1 -1
- package/dist/collection/components/sd-tooltip/sd-tooltip.js +77 -30
- package/dist/collection/utils/color/resolveColor.js +2 -2
- package/dist/collection/utils/dropdown-manager.js +1 -1
- package/dist/collection/utils/toast.js +4 -4
- package/dist/components/index.js +1 -1
- package/dist/components/p--t9jBTYS.js +1 -0
- package/dist/components/p-At6nBeyO.js +1 -0
- package/dist/components/p-B1MabGRR.js +1 -0
- package/dist/components/{p-CeVMl_M9.js → p-B73VhbYi.js} +1 -1
- package/dist/components/p-BDQQllAo.js +1 -0
- package/dist/components/p-BDr27lvk.js +1 -0
- package/dist/components/p-BPsOJlCP.js +1 -0
- package/dist/components/p-BQ6at17Y.js +1 -0
- package/dist/components/p-BW_sBt7X.js +1 -0
- package/dist/components/p-BX3TJuQY.js +1 -0
- package/dist/components/p-BeK8amzx.js +1 -0
- package/dist/components/{p-Bvq0Vpln.js → p-BfkuCNCI.js} +1 -1
- package/dist/components/p-Bm_T3qE0.js +1 -0
- package/dist/components/{p-DegvQLTF.js → p-BnzK4uU4.js} +1 -1
- package/dist/components/{p-q0VWISKA.js → p-BqkJ0rZv.js} +1 -1
- package/dist/components/p-C4PmGpW8.js +1 -0
- package/dist/components/{p-Nvx13YlG.js → p-C9CszVFl.js} +1 -1
- package/dist/components/p-CGBnxqG2.js +1 -0
- package/dist/components/p-CGQWERwE.js +1 -0
- package/dist/components/{p-DkJqVXpD.js → p-CT3dfy3K.js} +1 -1
- package/dist/components/p-CZmKBmKx.js +1 -0
- package/dist/components/p-CnarDyZi.js +1 -0
- package/dist/components/p-Cr2ghUra.js +1 -0
- package/dist/components/{p-BStczlLa.js → p-Cspm6LxP.js} +1 -1
- package/dist/components/p-Cx3jXw9J.js +1 -0
- package/dist/components/{p-Dcc2Vm6z.js → p-D5TRyquv.js} +1 -1
- package/dist/components/p-D8WAP9T3.js +1 -0
- package/dist/components/p-DG-4Ifco.js +1 -0
- package/dist/components/{p-TwGlKfsC.js → p-DG45uNxd.js} +1 -1
- package/dist/components/p-DdLntfiw.js +1 -0
- package/dist/components/{p-BJsHakU2.js → p-DfXAgw0E.js} +1 -1
- package/dist/components/p-Dr1AMbBj.js +1 -0
- package/dist/components/p-GBlVDmy4.js +1 -0
- package/dist/components/p-MMkRcTBd.js +1 -0
- package/dist/components/p-MQTl8fGT.js +1 -0
- package/dist/components/p-ZstG0XdT.js +1 -0
- package/dist/components/p-h7eBUL4i.js +1 -0
- package/dist/components/p-lyB7zSp-.js +1 -0
- package/dist/components/{p-D1DpOp6M.js → p-oIM6jNZe.js} +1 -1
- package/dist/components/p-oKHZl8yu.js +1 -0
- package/dist/components/p-ofkgu5aS.js +1 -0
- package/dist/components/sd-action-modal.js +1 -1
- package/dist/components/sd-badge.js +1 -1
- package/dist/components/sd-barcode-input.js +1 -1
- package/dist/components/sd-button.js +1 -1
- package/dist/components/sd-calendar.js +1 -1
- package/dist/components/sd-card.js +1 -1
- package/dist/components/sd-checkbox.js +1 -1
- package/dist/components/sd-chip.js +1 -1
- package/dist/components/sd-circle-progress.js +1 -1
- package/dist/components/sd-confirm-modal.js +1 -1
- package/dist/components/sd-date-box.js +1 -1
- package/dist/components/sd-date-picker-calendar.js +1 -1
- package/dist/components/sd-date-picker-trigger.js +1 -1
- package/dist/components/sd-date-picker.js +1 -1
- package/dist/components/sd-date-range-picker-calendar.js +1 -1
- package/dist/components/sd-date-range-picker.js +1 -1
- package/dist/components/sd-dropdown-button.js +1 -1
- package/dist/components/sd-field.js +1 -1
- package/dist/components/sd-file-picker.js +1 -1
- package/dist/components/sd-floating-portal.js +1 -1
- package/dist/components/sd-form.js +1 -1
- package/dist/components/sd-ghost-button.js +1 -1
- package/dist/components/sd-guide.js +1 -1
- package/dist/components/sd-icon.js +1 -1
- package/dist/components/sd-input.js +1 -1
- package/dist/components/sd-key-value-table.d.ts +11 -0
- package/dist/components/sd-key-value-table.js +1 -0
- package/dist/components/sd-linear-progress.js +1 -1
- package/dist/components/sd-loading-container.js +1 -1
- package/dist/components/sd-loading-modal.js +1 -1
- package/dist/components/sd-modal-container.js +1 -1
- package/dist/components/sd-number-input.js +1 -1
- package/dist/components/sd-pagination.js +1 -1
- package/dist/components/sd-popover.js +1 -1
- package/dist/components/{sd-button-v2.d.ts → sd-popup.d.ts} +4 -4
- package/dist/components/sd-popup.js +1 -0
- package/dist/components/sd-portal.js +1 -1
- package/dist/components/sd-radio-button.js +1 -1
- package/dist/components/sd-radio-group.js +1 -1
- package/dist/components/sd-radio.js +1 -1
- package/dist/components/sd-select-list-item-search.js +1 -1
- package/dist/components/sd-select-list-item.js +1 -1
- package/dist/components/sd-select-listbox.js +1 -1
- package/dist/components/sd-select-trigger.js +1 -1
- package/dist/components/sd-select.js +1 -1
- package/dist/components/sd-switch.js +1 -1
- package/dist/components/sd-table.js +1 -1
- package/dist/components/sd-tabs.js +1 -1
- package/dist/components/sd-tag.js +1 -1
- package/dist/components/sd-tbody.js +1 -1
- package/dist/components/sd-td.js +1 -1
- package/dist/components/sd-text-link.js +1 -1
- package/dist/components/sd-textarea.js +1 -1
- package/dist/components/sd-thead.js +1 -1
- package/dist/components/sd-toast-container.js +1 -1
- package/dist/components/sd-toast.js +1 -1
- package/dist/components/sd-toggle.js +1 -1
- package/dist/components/sd-tooltip.js +1 -1
- package/dist/components/sd-tr.js +1 -1
- package/dist/design-system/design-system.css +1 -1
- package/dist/design-system/design-system.esm.js +1 -1
- package/dist/design-system/index.esm.js +1 -1
- package/dist/design-system/p-02289728.entry.js +1 -0
- package/dist/design-system/p-17d66d85.entry.js +1 -0
- package/dist/design-system/p-18466728.entry.js +1 -0
- package/dist/design-system/p-1bb86d69.entry.js +1 -0
- package/dist/design-system/p-20a50702.entry.js +1 -0
- package/dist/design-system/p-21874054.entry.js +1 -0
- package/dist/design-system/p-282cbefa.entry.js +1 -0
- package/dist/design-system/p-29ed11e5.entry.js +1 -0
- package/dist/design-system/p-328fae12.entry.js +1 -0
- package/dist/design-system/p-35dce399.entry.js +1 -0
- package/dist/design-system/{p-1cf87e87.entry.js → p-39ff56b4.entry.js} +1 -1
- package/dist/design-system/p-3cb712a6.entry.js +1 -0
- package/dist/design-system/{p-f522c91d.entry.js → p-4e2953eb.entry.js} +1 -1
- package/dist/design-system/p-7610153d.entry.js +1 -0
- package/dist/design-system/{p-25a08e98.entry.js → p-7722ddeb.entry.js} +1 -1
- package/dist/design-system/{p-6bfe3612.entry.js → p-7882e388.entry.js} +1 -1
- package/dist/design-system/p-7bfa0cf9.entry.js +1 -0
- package/dist/design-system/p-824ecfb5.entry.js +1 -0
- package/dist/design-system/p-9a04b341.entry.js +1 -0
- package/dist/design-system/p-BDjErF_K.js +1 -0
- package/dist/design-system/p-BQ6at17Y.js +1 -0
- package/dist/design-system/p-CGQWERwE.js +1 -0
- package/dist/design-system/p-CLCoul8o.js +2 -0
- package/dist/design-system/{p-BxPyZJaz.js → p-Ce0cmS4R.js} +1 -1
- package/dist/design-system/p-CxOCk_ge.js +1 -0
- package/dist/design-system/{p-DnCBBIoq.js → p-Dmf0PYdM.js} +1 -1
- package/dist/design-system/p-GBlVDmy4.js +1 -0
- package/dist/design-system/{p-455dccf5.entry.js → p-a7a0ca14.entry.js} +1 -1
- package/dist/design-system/{p-f44786a9.entry.js → p-a942dfbe.entry.js} +1 -1
- package/dist/design-system/p-b04b22c6.entry.js +1 -0
- package/dist/design-system/p-b1bb0d72.entry.js +1 -0
- package/dist/design-system/{p-ead3e688.entry.js → p-b6ca4461.entry.js} +1 -1
- package/dist/design-system/p-b96c694c.entry.js +1 -0
- package/dist/design-system/p-baed13e4.entry.js +1 -0
- package/dist/design-system/{p-045bc426.entry.js → p-bd45e65d.entry.js} +1 -1
- package/dist/design-system/p-bf4156d8.entry.js +1 -0
- package/dist/design-system/{p-e5cebccd.entry.js → p-c0f60b00.entry.js} +1 -1
- package/dist/design-system/p-c228c2c7.entry.js +1 -0
- package/dist/design-system/p-cbda9194.entry.js +1 -0
- package/dist/design-system/{p-fe9cef6a.entry.js → p-cd8e4dd6.entry.js} +1 -1
- package/dist/design-system/p-cf382479.entry.js +1 -0
- package/dist/design-system/p-d0de34fd.entry.js +1 -0
- package/dist/design-system/p-d78fbe16.entry.js +1 -0
- package/dist/design-system/p-e1c0a3c9.entry.js +1 -0
- package/dist/design-system/{p-797517b5.entry.js → p-f3cfff78.entry.js} +1 -1
- package/dist/design-system/{p-3f7bc660.entry.js → p-f5576a0d.entry.js} +1 -1
- package/dist/design-system/p-f60cc7be.entry.js +1 -0
- package/dist/design-system/{p-33bc3176.entry.js → p-feeb0cc5.entry.js} +1 -1
- package/dist/esm/component.table-BQ6at17Y.js +54 -0
- package/dist/esm/design-system.js +3 -3
- package/dist/esm/{index-Cnwbjz1F.js → index-CLCoul8o.js} +1 -1
- package/dist/esm/index.js +4 -4
- package/dist/esm/loader.js +3 -3
- package/dist/esm/{resolveColor-BxPyZJaz.js → resolveColor-Ce0cmS4R.js} +2 -2
- package/dist/esm/sd-action-modal.entry.js +3 -3
- package/dist/esm/sd-badge.entry.js +2 -3
- package/dist/esm/sd-barcode-input.entry.js +3 -3
- package/dist/esm/{sd-button-v2.config-CV4xelxV.js → sd-button.config-BDjErF_K.js} +88 -3
- package/dist/esm/{sd-button-v2_2.entry.js → sd-button_2.entry.js} +101 -85
- package/dist/esm/sd-calendar.entry.js +15 -15
- package/dist/esm/sd-card.entry.js +2 -2
- package/dist/esm/sd-checkbox.entry.js +4 -4
- package/dist/esm/sd-chip.entry.js +2 -2
- package/dist/esm/sd-circle-progress.entry.js +3 -3
- package/dist/esm/sd-confirm-modal_2.entry.js +19 -11
- package/dist/esm/sd-date-box.entry.js +4 -4
- package/dist/esm/{sd-date-picker-calendar.entry.js → sd-date-picker-calendar_2.entry.js} +51 -4
- package/dist/esm/{sd-date-picker.config-C2fDbE9d.js → sd-date-picker.config-B6cqMQaM.js} +1 -2
- package/dist/esm/sd-date-picker_7.entry.js +1222 -0
- package/dist/esm/sd-date-range-picker-calendar.entry.js +3 -3
- package/dist/esm/sd-dropdown-button.entry.js +15 -14
- package/dist/esm/{sd-button_4.entry.js → sd-field_3.entry.js} +27 -82
- package/dist/esm/sd-form.entry.js +2 -2
- package/dist/esm/sd-ghost-button.entry.js +12 -10
- package/dist/esm/sd-guide.entry.js +9 -9
- package/dist/esm/sd-key-value-table.entry.js +228 -0
- package/dist/esm/sd-linear-progress.entry.js +3 -3
- package/dist/esm/sd-loading-container.entry.js +3 -3
- package/dist/esm/sd-modal-container.entry.js +1 -1
- package/dist/esm/{sd-pagination_5.entry.js → sd-pagination_4.entry.js} +35 -296
- package/dist/esm/sd-popover.entry.js +17 -10
- package/dist/esm/sd-popup.entry.js +110 -0
- package/dist/esm/sd-portal.entry.js +2 -2
- package/dist/esm/sd-radio-button.entry.js +4 -4
- package/dist/esm/sd-radio.entry.js +2 -2
- package/dist/esm/sd-select-list-item_2.entry.js +152 -0
- package/dist/esm/sd-select.config-CxOCk_ge.js +165 -0
- package/dist/esm/{sd-select-list-item_4.entry.js → sd-select_3.entry.js} +271 -302
- package/dist/esm/sd-switch.entry.js +2 -2
- package/dist/esm/{sd-table.config-Bj-EEo7N.js → sd-table.config-0Te8GLCI.js} +4 -44
- package/dist/esm/sd-table.entry.js +40 -23
- package/dist/esm/sd-tabs.entry.js +2 -2
- package/dist/esm/sd-tag.entry.js +49 -14
- package/dist/esm/sd-td.entry.js +2 -2
- package/dist/esm/sd-text-link.entry.js +8 -5
- package/dist/esm/sd-toast-container.entry.js +5 -5
- package/dist/esm/sd-toast.entry.js +35 -5
- package/dist/esm/sd-toggle.entry.js +2 -2
- package/dist/esm/{system-CZ4ltUOw.js → system-GBlVDmy4.js} +4 -2
- package/dist/esm/{tooltipArrow-D8sr81Xw.js → tooltipArrow-Bc-yw2nt.js} +1 -1
- package/dist/types/components/assets/CheckboxCheck.d.ts +1 -0
- package/dist/types/components/assets/CheckboxIndeterminate.d.ts +1 -0
- package/dist/types/components/assets/index.d.ts +2 -0
- package/dist/types/components/sd-action-modal/sd-action-modal.d.ts +2 -2
- package/dist/types/components/sd-badge/sd-badge.d.ts +0 -1
- package/dist/types/components/{sd-button-v2/sd-button-v2.config.d.ts → sd-button/sd-button.config.d.ts} +9 -15
- package/dist/types/components/sd-button/sd-button.d.ts +11 -13
- package/dist/types/components/sd-confirm-modal/sd-confirm-modal.config.d.ts +3 -3
- package/dist/types/components/sd-confirm-modal/sd-confirm-modal.d.ts +2 -1
- package/dist/types/components/sd-dropdown-button/sd-dropdown-button.config.d.ts +3 -3
- package/dist/types/components/sd-dropdown-button/sd-dropdown-button.d.ts +1 -0
- package/dist/types/components/sd-field/sd-field.d.ts +1 -0
- package/dist/types/components/sd-key-value-table/sd-key-value-table.config.d.ts +105 -0
- package/dist/types/components/sd-key-value-table/sd-key-value-table.d.ts +38 -0
- package/dist/types/components/sd-loading-modal/sd-loading-modal.config.d.ts +2 -2
- package/dist/types/components/sd-loading-modal/sd-loading-modal.d.ts +1 -0
- package/dist/types/components/sd-modal-container/sd-modal-container.config.d.ts +1 -1
- package/dist/types/components/sd-popover/sd-popover.d.ts +16 -10
- package/dist/types/components/sd-popup/sd-popup.config.d.ts +30 -0
- package/dist/types/components/sd-popup/sd-popup.d.ts +11 -0
- package/dist/types/components/sd-table/sd-table.d.ts +2 -0
- package/dist/types/components/sd-table/sd-tr/sd-tr.d.ts +2 -0
- package/dist/types/components/sd-tag/sd-tag.d.ts +1 -0
- package/dist/types/components/sd-toast/sd-toast.config.d.ts +5 -1
- package/dist/types/components/sd-toast/sd-toast.d.ts +2 -0
- package/dist/types/components/sd-toast-container/sd-toast-container.config.d.ts +2 -0
- package/dist/types/components/sd-tooltip/sd-tooltip.config.d.ts +2 -13
- package/dist/types/components/sd-tooltip/sd-tooltip.d.ts +6 -4
- package/dist/types/components.d.ts +237 -184
- package/dist/types/index.d.ts +1 -1
- package/dist/types/types/form.d.ts +1 -1
- package/dist/types/types/global.d.ts +14 -13
- package/dist/types/utils/toast.d.ts +1 -1
- package/hydrate/index.js +5182 -4738
- package/hydrate/index.mjs +5182 -4738
- package/package.json +111 -97
- package/readme.md +13 -7
- package/dist/cjs/component.button-cqV-iCG5.js +0 -90
- package/dist/cjs/sd-date-picker-trigger.cjs.entry.js +0 -51
- package/dist/cjs/sd-date-picker.cjs.entry.js +0 -117
- package/dist/cjs/sd-date-range-picker.cjs.entry.js +0 -123
- package/dist/cjs/sd-file-picker.cjs.entry.js +0 -244
- package/dist/cjs/sd-input.cjs.entry.js +0 -175
- package/dist/cjs/sd-number-input.cjs.entry.js +0 -409
- package/dist/cjs/sd-radio-group.cjs.entry.js +0 -46
- package/dist/cjs/sd-table.config-Cb0Ot3C6.js +0 -105
- package/dist/cjs/sd-textarea.cjs.entry.js +0 -146
- package/dist/collection/components/sd-button-v2/sd-button-v2.css +0 -125
- package/dist/collection/components/sd-button-v2/sd-button-v2.js +0 -273
- package/dist/components/p-B1XBwjCW.js +0 -1
- package/dist/components/p-B8jXOXtJ.js +0 -1
- package/dist/components/p-BE6TxbtX.js +0 -1
- package/dist/components/p-BcMNA89i.js +0 -1
- package/dist/components/p-BheX6lAy.js +0 -1
- package/dist/components/p-BmYM7-4v.js +0 -1
- package/dist/components/p-BppjYHF6.js +0 -1
- package/dist/components/p-BwWDMpJc.js +0 -1
- package/dist/components/p-C-kw2p2a.js +0 -1
- package/dist/components/p-C5qZtNLl.js +0 -1
- package/dist/components/p-C7DajKYn.js +0 -1
- package/dist/components/p-CZ4ltUOw.js +0 -1
- package/dist/components/p-D3gjBBCU.js +0 -1
- package/dist/components/p-DC-6inj0.js +0 -1
- package/dist/components/p-DRF0He-x.js +0 -1
- package/dist/components/p-Dey-lS6x.js +0 -1
- package/dist/components/p-DfH_fO01.js +0 -1
- package/dist/components/p-DngV3MT1.js +0 -1
- package/dist/components/p-EbjZr2OA.js +0 -1
- package/dist/components/p-LwWOleLJ.js +0 -1
- package/dist/components/p-ZMpCZhXP.js +0 -1
- package/dist/components/p-dNJIFthT.js +0 -1
- package/dist/components/p-xnLvZ-xn.js +0 -1
- package/dist/components/sd-button-v2.js +0 -1
- package/dist/design-system/p-0356c195.entry.js +0 -1
- package/dist/design-system/p-12dfd239.entry.js +0 -1
- package/dist/design-system/p-16d3a485.entry.js +0 -1
- package/dist/design-system/p-1706ed6f.entry.js +0 -1
- package/dist/design-system/p-182548f7.entry.js +0 -1
- package/dist/design-system/p-1a79edce.entry.js +0 -1
- package/dist/design-system/p-2812b9ce.entry.js +0 -1
- package/dist/design-system/p-38f661ea.entry.js +0 -1
- package/dist/design-system/p-429dab5c.entry.js +0 -1
- package/dist/design-system/p-59313838.entry.js +0 -1
- package/dist/design-system/p-6af01ab0.entry.js +0 -1
- package/dist/design-system/p-70d4903f.entry.js +0 -1
- package/dist/design-system/p-767e99f9.entry.js +0 -1
- package/dist/design-system/p-7c370335.entry.js +0 -1
- package/dist/design-system/p-7fe8be6a.entry.js +0 -1
- package/dist/design-system/p-83b262dc.entry.js +0 -1
- package/dist/design-system/p-881adaa5.entry.js +0 -1
- package/dist/design-system/p-88d7303c.entry.js +0 -1
- package/dist/design-system/p-8a601e0f.entry.js +0 -1
- package/dist/design-system/p-B1XBwjCW.js +0 -1
- package/dist/design-system/p-BsrEibf7.js +0 -1
- package/dist/design-system/p-C5qZtNLl.js +0 -1
- package/dist/design-system/p-CZ4ltUOw.js +0 -1
- package/dist/design-system/p-Cnwbjz1F.js +0 -2
- package/dist/design-system/p-a82be987.entry.js +0 -1
- package/dist/design-system/p-b917c82a.entry.js +0 -1
- package/dist/design-system/p-b9f00eef.entry.js +0 -1
- package/dist/design-system/p-bcb53788.entry.js +0 -1
- package/dist/design-system/p-c24344ac.entry.js +0 -1
- package/dist/design-system/p-d76192bd.entry.js +0 -1
- package/dist/design-system/p-d9d8c51b.entry.js +0 -1
- package/dist/design-system/p-de67937d.entry.js +0 -1
- package/dist/design-system/p-ea5e6c2c.entry.js +0 -1
- package/dist/design-system/p-eeb1cac2.entry.js +0 -1
- package/dist/design-system/p-f1a74359.entry.js +0 -1
- package/dist/design-system/p-f69c7539.entry.js +0 -1
- package/dist/esm/component.button-B1XBwjCW.js +0 -88
- package/dist/esm/sd-date-picker-trigger.entry.js +0 -49
- package/dist/esm/sd-date-picker.entry.js +0 -115
- package/dist/esm/sd-date-range-picker.entry.js +0 -121
- package/dist/esm/sd-file-picker.entry.js +0 -242
- package/dist/esm/sd-input.entry.js +0 -173
- package/dist/esm/sd-number-input.entry.js +0 -407
- package/dist/esm/sd-radio-group.entry.js +0 -44
- package/dist/esm/sd-textarea.entry.js +0 -144
- package/dist/types/components/sd-button-v2/sd-button-v2.d.ts +0 -19
- /package/dist/components/{p-C2fDbE9d.js → p-B6cqMQaM.js} +0 -0
- /package/dist/design-system/{p-C2fDbE9d.js → p-B6cqMQaM.js} +0 -0
|
@@ -1,318 +1,287 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var index = require('./index
|
|
3
|
+
var index = require('./index-BlxrCRYi.js');
|
|
4
|
+
var index$1 = require('./index-BUvXpPc3.js');
|
|
5
|
+
var sdSelect_config = require('./sd-select.config-B19ptCT2.js');
|
|
4
6
|
|
|
5
|
-
const
|
|
6
|
-
paddingX: "12",
|
|
7
|
-
icon: {
|
|
8
|
-
"default": "#888888",
|
|
9
|
-
disabled: "#BBBBBB"
|
|
10
|
-
},
|
|
11
|
-
gap: "8",
|
|
12
|
-
typography: {
|
|
13
|
-
fontWeight: "400",
|
|
14
|
-
fontSize: "12",
|
|
15
|
-
lineHeight: "20"},
|
|
16
|
-
text: {
|
|
17
|
-
"default": "#222222",
|
|
18
|
-
disabled: "#888888"
|
|
19
|
-
}};
|
|
20
|
-
var selectTokens = {
|
|
21
|
-
select: select
|
|
22
|
-
};
|
|
23
|
-
|
|
24
|
-
const listItem = {
|
|
25
|
-
paddingY: "4",
|
|
26
|
-
paddingRight: "12",
|
|
27
|
-
gap: "8",
|
|
28
|
-
paddingLeft: {
|
|
29
|
-
depth1: "12",
|
|
30
|
-
depth2: "20",
|
|
31
|
-
depth3: "28"
|
|
32
|
-
},
|
|
33
|
-
typography: {
|
|
34
|
-
"default": {
|
|
35
|
-
fontWeight: "400",
|
|
36
|
-
fontSize: "12",
|
|
37
|
-
lineHeight: "20"},
|
|
38
|
-
selected: {
|
|
39
|
-
fontWeight: "700"}
|
|
40
|
-
},
|
|
41
|
-
bg: {
|
|
42
|
-
"default": "#FFFFFF",
|
|
43
|
-
hover: "#0075FF"
|
|
44
|
-
},
|
|
45
|
-
content: {
|
|
46
|
-
"default": "#222222",
|
|
47
|
-
hover: "#FFFFFF",
|
|
48
|
-
disabled: "#888888",
|
|
49
|
-
selected: "#0075FF"
|
|
50
|
-
},
|
|
51
|
-
depth1: {
|
|
52
|
-
bg: {
|
|
53
|
-
"default": "#EFF6FF"},
|
|
54
|
-
border: {
|
|
55
|
-
color: "#E1E1E1",
|
|
56
|
-
width: "1"
|
|
57
|
-
}},
|
|
58
|
-
depth2: {
|
|
59
|
-
middle: {
|
|
60
|
-
bg: "#F6F6F6"}
|
|
61
|
-
}};
|
|
62
|
-
var listItemTokens = {
|
|
63
|
-
listItem: listItem
|
|
64
|
-
};
|
|
7
|
+
const sdSelectCss = () => `sd-select{display:inline-flex}sd-select sd-portal{display:none}sd-select .sd-select{position:relative;width:100%;height:100%}`;
|
|
65
8
|
|
|
66
|
-
const
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
disabled
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
9
|
+
const SdSelect = class {
|
|
10
|
+
constructor(hostRef) {
|
|
11
|
+
index.registerInstance(this, hostRef);
|
|
12
|
+
this.update = index.createEvent(this, "sdUpdate", 7);
|
|
13
|
+
this.dropDownShow = index.createEvent(this, "sdDropDownShow", 7);
|
|
14
|
+
}
|
|
15
|
+
static VIEWPORT_PADDING = 20;
|
|
16
|
+
static PORTAL_OFFSET_Y = 4;
|
|
17
|
+
static CLOSE_ANIMATION_DURATION = 150;
|
|
18
|
+
get el() { return index.getElement(this); }
|
|
19
|
+
type = 'default';
|
|
20
|
+
value = null;
|
|
21
|
+
options = [];
|
|
22
|
+
placeholder = '선택';
|
|
23
|
+
maxDropdownWidth = '640px';
|
|
24
|
+
dropdownHeight = '260px';
|
|
25
|
+
disabled = false;
|
|
26
|
+
label = '';
|
|
27
|
+
labelWidth = '';
|
|
28
|
+
addonLabel = '';
|
|
29
|
+
addonAlign = 'start';
|
|
30
|
+
error = false;
|
|
31
|
+
hint = '';
|
|
32
|
+
errorMessage = '';
|
|
33
|
+
rules = [];
|
|
34
|
+
icon = undefined;
|
|
35
|
+
labelTooltip = '';
|
|
36
|
+
labelTooltipProps = null;
|
|
37
|
+
emitValue = false;
|
|
38
|
+
width = '';
|
|
39
|
+
useSearch = false;
|
|
40
|
+
allSelectedLabel = '전체';
|
|
41
|
+
useSelectAll = false;
|
|
42
|
+
isOpen = false;
|
|
43
|
+
isAnimatingOut = false;
|
|
44
|
+
triggerWidth = '200px';
|
|
45
|
+
resolvedDropdownHeight = '260px';
|
|
46
|
+
resolvedMaxDropdownWidth = '640px';
|
|
47
|
+
focused = false;
|
|
48
|
+
hovered = false;
|
|
49
|
+
update;
|
|
50
|
+
dropDownShow;
|
|
51
|
+
async sdFocus() {
|
|
52
|
+
if (this.disabled)
|
|
53
|
+
return;
|
|
54
|
+
await this.triggerComponentRef?.sdFocus();
|
|
55
|
+
}
|
|
56
|
+
async sdOpen() {
|
|
57
|
+
// sdFocus 직후 호출 시 트리거 ref/레이아웃이 안정될 때까지 한 틱 대기
|
|
58
|
+
await new Promise(resolve => setTimeout(resolve, 0));
|
|
59
|
+
if (this.disabled || this.isOpen)
|
|
60
|
+
return;
|
|
61
|
+
this.prepareDropdownGeometry();
|
|
62
|
+
if (this.closeAnimationTimer)
|
|
63
|
+
clearTimeout(this.closeAnimationTimer);
|
|
64
|
+
this.isAnimatingOut = false;
|
|
65
|
+
this.isOpen = true;
|
|
66
|
+
}
|
|
67
|
+
triggerRef;
|
|
68
|
+
triggerComponentRef;
|
|
69
|
+
closeAnimationTimer;
|
|
70
|
+
name = index$1.nanoid();
|
|
71
|
+
triggerHasFocus = false;
|
|
72
|
+
watchIsOpen(newValue) {
|
|
73
|
+
this.syncFocusedState(newValue);
|
|
74
|
+
this.dropDownShow.emit({ isOpen: newValue });
|
|
75
|
+
}
|
|
76
|
+
get isMulti() {
|
|
77
|
+
return this.type === 'multi' || this.type === 'multi_depth';
|
|
78
|
+
}
|
|
79
|
+
get displayText() {
|
|
80
|
+
if (this.isMulti) {
|
|
81
|
+
if (!Array.isArray(this.value) || this.value.length === 0)
|
|
82
|
+
return '';
|
|
83
|
+
const nonDisabledLeaves = this.getNonDisabledLeaves(this.options);
|
|
84
|
+
const selected = this.getSelectedOptions();
|
|
85
|
+
const allSelected = nonDisabledLeaves.length > 0 &&
|
|
86
|
+
nonDisabledLeaves.every(leaf => selected.some(s => s.value === leaf.value));
|
|
87
|
+
if (allSelected)
|
|
88
|
+
return this.allSelectedLabel ?? '전체';
|
|
89
|
+
const flat = this.flattenOptions(this.options);
|
|
90
|
+
return this.value
|
|
91
|
+
.map(item => {
|
|
92
|
+
if (item != null && typeof item === 'object') {
|
|
93
|
+
const opt = item;
|
|
94
|
+
return opt.label ?? flat.find(o => o.value === opt.value)?.label ?? '';
|
|
95
|
+
}
|
|
96
|
+
return flat.find(o => o.value === item)?.label ?? '';
|
|
97
|
+
})
|
|
98
|
+
.filter(Boolean)
|
|
99
|
+
.join(', ');
|
|
140
100
|
}
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
const lowerKeyword = keyword.toLowerCase();
|
|
146
|
-
return options.reduce((acc, option) => {
|
|
147
|
-
const selfMatch = option.label.toLowerCase().includes(lowerKeyword);
|
|
148
|
-
if (option.children) {
|
|
149
|
-
// 그룹: 자식은 항상 추가로 필터링한다.
|
|
150
|
-
// - 자식 중 일치하는 게 있으면 그 자식들만 노출
|
|
151
|
-
// - 자식 매칭이 없더라도 그룹명이 매칭되면 그룹 헤더는 그대로 노출
|
|
152
|
-
// (이때 children 은 빈 배열로 두고, 선택 동작은 collectVisibleLeaves
|
|
153
|
-
// 의 fallback 이 원본 트리를 사용해 처리한다)
|
|
154
|
-
const filteredChildren = filterTree(option.children, keyword);
|
|
155
|
-
if (filteredChildren.length > 0) {
|
|
156
|
-
acc.push({ ...option, children: filteredChildren });
|
|
157
|
-
}
|
|
158
|
-
else if (selfMatch) {
|
|
159
|
-
acc.push({ ...option, children: [] });
|
|
160
|
-
}
|
|
101
|
+
if (this.value == null)
|
|
102
|
+
return '';
|
|
103
|
+
if (!this.emitValue && typeof this.value === 'object' && !Array.isArray(this.value)) {
|
|
104
|
+
return this.value.label ?? '';
|
|
161
105
|
}
|
|
162
|
-
|
|
163
|
-
|
|
106
|
+
const flat = this.flattenOptions(this.options);
|
|
107
|
+
const found = flat.find(o => o.value === this.value);
|
|
108
|
+
return found?.label ?? '';
|
|
109
|
+
}
|
|
110
|
+
flattenOptions(options) {
|
|
111
|
+
return options.flatMap(o => (o.children ? this.flattenOptions(o.children) : [o]));
|
|
112
|
+
}
|
|
113
|
+
getNonDisabledLeaves(options) {
|
|
114
|
+
return options.flatMap(o => {
|
|
115
|
+
if (o.disabled)
|
|
116
|
+
return [];
|
|
117
|
+
if (o.children)
|
|
118
|
+
return this.getNonDisabledLeaves(o.children);
|
|
119
|
+
return [o];
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
getSelectedOptions() {
|
|
123
|
+
const val = this.value;
|
|
124
|
+
if (!val || !Array.isArray(val))
|
|
125
|
+
return [];
|
|
126
|
+
if (this.emitValue) {
|
|
127
|
+
return val
|
|
128
|
+
.map(v => this.findOriginalOption(v, this.options))
|
|
129
|
+
.filter((o) => !!o);
|
|
164
130
|
}
|
|
165
|
-
return
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
const
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
option;
|
|
177
|
-
depth = 1;
|
|
178
|
-
isSelected = false;
|
|
179
|
-
isFocused = false;
|
|
180
|
-
useCheckbox = false;
|
|
181
|
-
countInfo;
|
|
182
|
-
listItemClick;
|
|
183
|
-
get isGroup() {
|
|
184
|
-
return !!this.option.children;
|
|
185
|
-
}
|
|
186
|
-
get isSelectable() {
|
|
187
|
-
return !this.isGroup || this.useCheckbox;
|
|
188
|
-
}
|
|
189
|
-
get depthKey() {
|
|
190
|
-
if (this.depth <= 1)
|
|
191
|
-
return 'depth1';
|
|
192
|
-
if (this.depth === 2)
|
|
193
|
-
return 'depth2';
|
|
194
|
-
return 'depth3';
|
|
195
|
-
}
|
|
196
|
-
get paddingLeft() {
|
|
197
|
-
return `${LIST_ITEM_LAYOUT.paddingLeft[this.depthKey]}px`;
|
|
198
|
-
}
|
|
199
|
-
handleClick = (e) => {
|
|
200
|
-
e.stopPropagation();
|
|
201
|
-
if (this.option.disabled || !this.isSelectable)
|
|
131
|
+
return val;
|
|
132
|
+
}
|
|
133
|
+
toMultiValue(options) {
|
|
134
|
+
return this.emitValue ? options.map(o => o.value) : options;
|
|
135
|
+
}
|
|
136
|
+
parsePixelValue(value, fallback) {
|
|
137
|
+
const parsed = Number.parseFloat(value);
|
|
138
|
+
return Number.isFinite(parsed) ? parsed : fallback;
|
|
139
|
+
}
|
|
140
|
+
updateDropdownViewportConstraints() {
|
|
141
|
+
if (!this.triggerRef)
|
|
202
142
|
return;
|
|
203
|
-
this.
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
143
|
+
const triggerRect = this.triggerRef.getBoundingClientRect();
|
|
144
|
+
const viewportPadding = SdSelect.VIEWPORT_PADDING;
|
|
145
|
+
const offsetY = SdSelect.PORTAL_OFFSET_Y;
|
|
146
|
+
const preferredHeight = this.parsePixelValue(this.dropdownHeight, 260);
|
|
147
|
+
const preferredWidth = this.parsePixelValue(this.maxDropdownWidth, 640);
|
|
148
|
+
const availableBelow = Math.max(window.innerHeight - triggerRect.bottom - viewportPadding - offsetY, 0);
|
|
149
|
+
const availableAbove = Math.max(triggerRect.top - viewportPadding - offsetY, 0);
|
|
150
|
+
const availableHeight = Math.max(availableBelow, availableAbove);
|
|
151
|
+
const availableWidth = Math.max(window.innerWidth - viewportPadding * 2, 0);
|
|
152
|
+
this.resolvedDropdownHeight = `${Math.min(preferredHeight, availableHeight)}px`;
|
|
153
|
+
this.resolvedMaxDropdownWidth = `${Math.min(preferredWidth, availableWidth)}px`;
|
|
154
|
+
}
|
|
155
|
+
handleViewportResize = () => {
|
|
156
|
+
if (!this.isOpen)
|
|
211
157
|
return;
|
|
212
|
-
this.
|
|
158
|
+
this.updateDropdownViewportConstraints();
|
|
213
159
|
};
|
|
214
|
-
|
|
215
|
-
const
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
'--list-item-font-size': `${LIST_ITEM_TYPOGRAPHY.fontSize}px`,
|
|
224
|
-
'--list-item-line-height': `${LIST_ITEM_TYPOGRAPHY.lineHeight}px`,
|
|
225
|
-
'--list-item-font-weight': LIST_ITEM_TYPOGRAPHY.fontWeight,
|
|
226
|
-
'--list-item-bg': isDepth1Group
|
|
227
|
-
? LIST_ITEM_COLORS.depth1.bg
|
|
228
|
-
: isDepth2Group
|
|
229
|
-
? LIST_ITEM_COLORS.depth2.bg
|
|
230
|
-
: LIST_ITEM_COLORS.bg.default,
|
|
231
|
-
'--list-item-bg-hover': LIST_ITEM_COLORS.bg.hover,
|
|
232
|
-
'--list-item-color': LIST_ITEM_COLORS.content.default,
|
|
233
|
-
'--list-item-color-hover': LIST_ITEM_COLORS.content.hover,
|
|
234
|
-
'--list-item-color-disabled': LIST_ITEM_COLORS.content.disabled,
|
|
235
|
-
'--list-item-color-selected': LIST_ITEM_COLORS.content.selected,
|
|
236
|
-
'--list-item-font-weight-selected': LIST_ITEM_TYPOGRAPHY.selectedFontWeight,
|
|
237
|
-
};
|
|
238
|
-
if (isDepth1Group) {
|
|
239
|
-
cssVars['--list-item-border-top'] = `${LIST_ITEM_COLORS.depth1.borderWidth}px solid ${LIST_ITEM_COLORS.depth1.border}`;
|
|
160
|
+
findOriginalOption(value, options) {
|
|
161
|
+
for (const opt of options) {
|
|
162
|
+
if (opt.value === value)
|
|
163
|
+
return opt;
|
|
164
|
+
if (opt.children) {
|
|
165
|
+
const found = this.findOriginalOption(value, opt.children);
|
|
166
|
+
if (found)
|
|
167
|
+
return found;
|
|
168
|
+
}
|
|
240
169
|
}
|
|
241
|
-
return
|
|
242
|
-
'sd-select-list-item': true,
|
|
243
|
-
'sd-select-list-item--group': isGroup,
|
|
244
|
-
'sd-select-list-item--depth1-group': isDepth1Group,
|
|
245
|
-
'sd-select-list-item--depth2-group': isDepth2Group,
|
|
246
|
-
'sd-select-list-item--selected': this.isSelected === true,
|
|
247
|
-
'sd-select-list-item--indeterminate': this.isSelected === null,
|
|
248
|
-
'sd-select-list-item--focused': this.isFocused,
|
|
249
|
-
'sd-select-list-item--selectable': this.isSelectable && !this.option.disabled,
|
|
250
|
-
'sd-select-list-item--disabled': !!this.option.disabled,
|
|
251
|
-
}, style: cssVars, onClick: this.handleClick }, this.useCheckbox && (index.h("sd-checkbox", { key: 'a884bd82722cd45efc19abd2139d08596f7eda86', value: this.isSelected === null ? null : !!this.isSelected, disabled: this.option.disabled, inverse: this.isFocused && this.isSelected !== false, class: "sd-select-list-item__checkbox", onClick: this.handleCheckboxClick, onSdUpdate: this.handleCheckboxUpdate })), index.h("span", { key: '9aacbeca13e591406454ef7e1c7be40a56a2926b', class: "sd-select-list-item__label" }, this.option.label), this.countInfo && (index.h("span", { key: '76be4eda3799cfa329016c2ea636feaf624e5025', class: "sd-select-list-item__count" }, "(", this.countInfo.selected, "/", this.countInfo.total, ")"))));
|
|
170
|
+
return undefined;
|
|
252
171
|
}
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
172
|
+
closeDropdown() {
|
|
173
|
+
if (!this.isOpen)
|
|
174
|
+
return;
|
|
175
|
+
this.isOpen = false;
|
|
176
|
+
this.isAnimatingOut = true;
|
|
177
|
+
if (this.closeAnimationTimer)
|
|
178
|
+
clearTimeout(this.closeAnimationTimer);
|
|
179
|
+
this.closeAnimationTimer = setTimeout(() => {
|
|
180
|
+
this.isAnimatingOut = false;
|
|
181
|
+
}, SdSelect.CLOSE_ANIMATION_DURATION);
|
|
182
|
+
}
|
|
183
|
+
prepareDropdownGeometry() {
|
|
184
|
+
if (this.triggerRef) {
|
|
185
|
+
this.triggerWidth = `${this.triggerRef.offsetWidth}px`;
|
|
186
|
+
}
|
|
187
|
+
this.updateDropdownViewportConstraints();
|
|
263
188
|
}
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
searchFilter;
|
|
267
|
-
searchFocus;
|
|
268
|
-
inputEl;
|
|
269
|
-
debounceTimer;
|
|
270
|
-
focusRafId;
|
|
271
|
-
componentDidLoad() {
|
|
272
|
-
requestAnimationFrame(() => {
|
|
273
|
-
this.focusRafId = requestAnimationFrame(() => {
|
|
274
|
-
this.inputEl?.focus();
|
|
275
|
-
});
|
|
276
|
-
});
|
|
189
|
+
syncFocusedState(isOpen = this.isOpen) {
|
|
190
|
+
this.focused = isOpen || this.triggerHasFocus;
|
|
277
191
|
}
|
|
278
|
-
|
|
279
|
-
this.
|
|
280
|
-
|
|
281
|
-
handleInput = (e) => {
|
|
282
|
-
this.searchText = e.target.value;
|
|
283
|
-
if (this.debounceTimer)
|
|
284
|
-
clearTimeout(this.debounceTimer);
|
|
285
|
-
this.debounceTimer = setTimeout(() => {
|
|
286
|
-
this.searchFilter.emit(this.searchText);
|
|
287
|
-
}, SEARCH_DEBOUNCE_MS);
|
|
192
|
+
handleTriggerFocus = () => {
|
|
193
|
+
this.triggerHasFocus = true;
|
|
194
|
+
this.syncFocusedState();
|
|
288
195
|
};
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
this.
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
this.
|
|
295
|
-
|
|
196
|
+
handleTriggerBlur = () => {
|
|
197
|
+
this.triggerHasFocus = false;
|
|
198
|
+
this.syncFocusedState();
|
|
199
|
+
};
|
|
200
|
+
handleTriggerClick = () => {
|
|
201
|
+
if (this.isOpen) {
|
|
202
|
+
this.closeDropdown();
|
|
203
|
+
return;
|
|
204
|
+
}
|
|
205
|
+
this.prepareDropdownGeometry();
|
|
206
|
+
if (this.closeAnimationTimer)
|
|
207
|
+
clearTimeout(this.closeAnimationTimer);
|
|
208
|
+
this.isAnimatingOut = false;
|
|
209
|
+
this.isOpen = true;
|
|
210
|
+
};
|
|
211
|
+
emitUpdate(value) {
|
|
212
|
+
this.update.emit(value);
|
|
213
|
+
}
|
|
214
|
+
handleOptionSelect = (detail) => {
|
|
215
|
+
const { option, leaves } = detail;
|
|
216
|
+
if (this.isMulti) {
|
|
217
|
+
this.handleMultiSelect(option, leaves);
|
|
218
|
+
}
|
|
219
|
+
else {
|
|
220
|
+
this.closeDropdown();
|
|
221
|
+
this.value = this.emitValue ? option.value : option;
|
|
222
|
+
const nextValue = this.value;
|
|
223
|
+
requestAnimationFrame(() => {
|
|
224
|
+
this.emitUpdate(nextValue);
|
|
225
|
+
});
|
|
226
|
+
}
|
|
296
227
|
};
|
|
228
|
+
handleMultiSelect(option, leaves) {
|
|
229
|
+
const selected = this.getSelectedOptions();
|
|
230
|
+
const isGroup = !!option.children;
|
|
231
|
+
let newSelected;
|
|
232
|
+
if (isGroup) {
|
|
233
|
+
const allSelected = leaves.every(l => selected.some(s => s.value === l.value));
|
|
234
|
+
if (allSelected) {
|
|
235
|
+
const leafValues = new Set(leaves.map(l => l.value));
|
|
236
|
+
newSelected = selected.filter(s => !leafValues.has(s.value));
|
|
237
|
+
}
|
|
238
|
+
else {
|
|
239
|
+
const existing = new Set(selected.map(s => s.value));
|
|
240
|
+
const toAdd = leaves.filter(l => !existing.has(l.value));
|
|
241
|
+
newSelected = [...selected, ...toAdd];
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
else {
|
|
245
|
+
const exists = selected.some(s => s.value === option.value);
|
|
246
|
+
newSelected = exists ? selected.filter(s => s.value !== option.value) : [...selected, option];
|
|
247
|
+
}
|
|
248
|
+
this.value = this.toMultiValue(newSelected);
|
|
249
|
+
this.emitUpdate(this.value);
|
|
250
|
+
}
|
|
251
|
+
connectedCallback() {
|
|
252
|
+
window.addEventListener('resize', this.handleViewportResize);
|
|
253
|
+
}
|
|
297
254
|
disconnectedCallback() {
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
clearTimeout(this.debounceTimer);
|
|
255
|
+
window.removeEventListener('resize', this.handleViewportResize);
|
|
256
|
+
if (this.closeAnimationTimer)
|
|
257
|
+
clearTimeout(this.closeAnimationTimer);
|
|
302
258
|
}
|
|
303
259
|
render() {
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
260
|
+
const portalProps = {
|
|
261
|
+
open: this.isOpen,
|
|
262
|
+
parentRef: this.triggerRef,
|
|
263
|
+
viewportPadding: SdSelect.VIEWPORT_PADDING,
|
|
264
|
+
onSdClose: () => {
|
|
265
|
+
this.closeDropdown();
|
|
266
|
+
},
|
|
267
|
+
};
|
|
268
|
+
return (index.h("sd-field", { key: '18edcdfdc3a9a2bd17ae0e3852eec94151275e18', name: this.name, label: this.label, labelWidth: this.labelWidth, addonLabel: this.addonLabel, addonAlign: this.addonAlign, hint: this.hint, errorMessage: this.errorMessage, width: this.width, rules: this.rules, error: this.error, disabled: this.disabled, focused: this.focused, hovered: this.hovered, icon: this.icon, labelTooltip: this.labelTooltip, labelTooltipProps: this.labelTooltipProps, onMouseEnter: () => {
|
|
269
|
+
this.hovered = true;
|
|
270
|
+
}, onMouseLeave: () => {
|
|
271
|
+
this.hovered = false;
|
|
272
|
+
} }, index.h("div", { key: '39efa02a58acbc53315087cceb732b488920dbe8', class: "sd-select", ref: el => {
|
|
273
|
+
this.triggerRef = el;
|
|
274
|
+
} }, index.h("sd-select-trigger", { key: 'e03ce9208f4af5226461ecdfb0d15bade4f277dd', ref: el => {
|
|
275
|
+
this.triggerComponentRef = el;
|
|
276
|
+
}, displayText: this.displayText, placeholder: this.placeholder ?? '선택', disabled: this.disabled, isOpen: this.isOpen, onSdTriggerClick: this.handleTriggerClick, onSdTriggerFocus: this.handleTriggerFocus, onSdTriggerBlur: this.handleTriggerBlur })), (this.isOpen || this.isAnimatingOut) && (index.h("sd-portal", { key: '9181fd551885e001f139cab9634a2ac3b0f89d47', ...portalProps }, index.h("sd-select-listbox", { key: '6ed356d2ceea79562ce448584514c23fbff20090', type: this.type, options: this.options, value: this.value, emitValue: this.emitValue, useSearch: this.useSearch, useSelectAll: this.useSelectAll, triggerWidth: this.triggerWidth, maxWidth: this.resolvedMaxDropdownWidth, maxHeight: this.resolvedDropdownHeight, onSdOptionSelect: event => this.handleOptionSelect(event.detail) })))));
|
|
313
277
|
}
|
|
278
|
+
static get watchers() { return {
|
|
279
|
+
"isOpen": [{
|
|
280
|
+
"watchIsOpen": 0
|
|
281
|
+
}]
|
|
282
|
+
}; }
|
|
314
283
|
};
|
|
315
|
-
|
|
284
|
+
SdSelect.style = sdSelectCss();
|
|
316
285
|
|
|
317
286
|
const sdSelectListboxCss = () => `:host{display:block}:host .sd-select-listbox{display:flex;flex-direction:column;width:var(--listbox-trigger-width);max-width:var(--listbox-max-width);max-height:var(--listbox-max-height);border-radius:var(--listbox-radius);background:white;box-shadow:2px 2px 12px 2px rgba(0, 0, 0, 0.1);overflow:hidden;outline:none}:host .sd-select-listbox__list{flex:1;min-height:0;overflow-y:auto;padding-bottom:0}:host .sd-select-listbox__empty{padding:12px;text-align:center;font-size:12px;line-height:20px;color:#888888}`;
|
|
318
287
|
|
|
@@ -378,20 +347,20 @@ const SdSelectListbox = class {
|
|
|
378
347
|
get showSearch() {
|
|
379
348
|
if (!this.useSearch)
|
|
380
349
|
return false;
|
|
381
|
-
const count = this.isDepth ? countLeaves(this.options) : this.options.length;
|
|
382
|
-
return count >= SEARCH_THRESHOLD;
|
|
350
|
+
const count = this.isDepth ? sdSelect_config.countLeaves(this.options) : this.options.length;
|
|
351
|
+
return count >= sdSelect_config.SEARCH_THRESHOLD;
|
|
383
352
|
}
|
|
384
353
|
get filteredOptions() {
|
|
385
354
|
if (!this.searchKeyword)
|
|
386
355
|
return this.options;
|
|
387
356
|
if (this.isDepth)
|
|
388
|
-
return filterTree(this.options, this.searchKeyword);
|
|
357
|
+
return sdSelect_config.filterTree(this.options, this.searchKeyword);
|
|
389
358
|
const keyword = this.searchKeyword.toLowerCase();
|
|
390
359
|
return this.options.filter(o => o.label.toLowerCase().includes(keyword));
|
|
391
360
|
}
|
|
392
361
|
get isEmpty() {
|
|
393
362
|
if (this.isDepth)
|
|
394
|
-
return countLeaves(this.filteredOptions) === 0 && this.filteredOptions.length === 0;
|
|
363
|
+
return sdSelect_config.countLeaves(this.filteredOptions) === 0 && this.filteredOptions.length === 0;
|
|
395
364
|
return this.filteredOptions.length === 0;
|
|
396
365
|
}
|
|
397
366
|
getSelectedValues() {
|
|
@@ -663,14 +632,14 @@ const SdSelectListbox = class {
|
|
|
663
632
|
}
|
|
664
633
|
render() {
|
|
665
634
|
const cssVars = {
|
|
666
|
-
'--listbox-trigger-width': this.triggerWidth,
|
|
667
|
-
'--listbox-max-width': this.maxWidth,
|
|
668
|
-
'--listbox-max-height': this.maxHeight,
|
|
669
|
-
'--listbox-radius': `${LIST_BOX_LAYOUT.radius}px`,
|
|
635
|
+
'--listbox-trigger-width': this.triggerWidth ?? '200px',
|
|
636
|
+
'--listbox-max-width': this.maxWidth ?? '640px',
|
|
637
|
+
'--listbox-max-height': this.maxHeight ?? '260px',
|
|
638
|
+
'--listbox-radius': `${sdSelect_config.LIST_BOX_LAYOUT.radius}px`,
|
|
670
639
|
};
|
|
671
|
-
return (index.h("div", { key: '
|
|
640
|
+
return (index.h("div", { key: 'be3a46d2a17522799374eb7e59faea8960e7b41a', class: "sd-select-listbox", style: cssVars }, this.showSearch && (index.h("sd-select-list-item-search", { key: '68fa6b9f958ee662ac400716ade0ae4823ad99a3', isScrolled: this.isScrolled, onSdSearchFilter: this.handleSearchFilter })), index.h("div", { key: 'b0a6daf94c69ccb33d31434014c93b2f414309f3', class: "sd-select-listbox__list", onScroll: this.handleScroll, ref: el => {
|
|
672
641
|
this.listEl = el;
|
|
673
|
-
} }, this.showSelectAll && (index.h("sd-select-list-item", { key: '
|
|
642
|
+
} }, this.showSelectAll && (index.h("sd-select-list-item", { key: '120fea009df513e3346877044ee65c132ece70cf', option: SdSelectListbox.SELECT_ALL_OPTION, depth: 1, isSelected: this.selectAllState, isFocused: this.isOptionFocused(SdSelectListbox.SELECT_ALL_OPTION), useCheckbox: true, onSdListItemClick: this.handleSelectAllClick, onMouseEnter: () => this.handleOptionHover(SdSelectListbox.SELECT_ALL_OPTION) })), this.isEmpty ? (index.h("div", { class: "sd-select-listbox__empty" }, sdSelect_config.EMPTY_MESSAGE)) : this.isDepth ? (this.renderOptions(this.filteredOptions)) : (this.filteredOptions.map(option => (index.h("sd-select-list-item", { option: option, depth: 1, isSelected: this.isOptionSelected(option), isFocused: this.isOptionFocused(option), useCheckbox: this.isMulti, onSdListItemClick: this.handleOptionClick, onMouseEnter: () => this.handleOptionHover(option) })))))));
|
|
674
643
|
}
|
|
675
644
|
static get watchers() { return {
|
|
676
645
|
"searchKeyword": [{
|
|
@@ -716,27 +685,27 @@ const SdSelectTrigger = class {
|
|
|
716
685
|
render() {
|
|
717
686
|
const hasValue = !!this.displayText;
|
|
718
687
|
const cssVars = {
|
|
719
|
-
'--trigger-padding-x': `${SELECT_LAYOUT.paddingX}px`,
|
|
720
|
-
'--trigger-gap': `${SELECT_LAYOUT.gap}px`,
|
|
721
|
-
'--trigger-font-size': `${SELECT_TYPOGRAPHY.fontSize}px`,
|
|
722
|
-
'--trigger-line-height': `${SELECT_TYPOGRAPHY.lineHeight}px`,
|
|
723
|
-
'--trigger-font-weight': SELECT_TYPOGRAPHY.fontWeight,
|
|
688
|
+
'--trigger-padding-x': `${sdSelect_config.SELECT_LAYOUT.paddingX}px`,
|
|
689
|
+
'--trigger-gap': `${sdSelect_config.SELECT_LAYOUT.gap}px`,
|
|
690
|
+
'--trigger-font-size': `${sdSelect_config.SELECT_TYPOGRAPHY.fontSize}px`,
|
|
691
|
+
'--trigger-line-height': `${sdSelect_config.SELECT_TYPOGRAPHY.lineHeight}px`,
|
|
692
|
+
'--trigger-font-weight': sdSelect_config.SELECT_TYPOGRAPHY.fontWeight,
|
|
724
693
|
'--trigger-color': this.disabled
|
|
725
|
-
? SELECT_COLORS.text.disabled
|
|
694
|
+
? sdSelect_config.SELECT_COLORS.text.disabled
|
|
726
695
|
: hasValue
|
|
727
|
-
? SELECT_COLORS.text.default
|
|
728
|
-
: SELECT_COLORS.icon.default,
|
|
696
|
+
? sdSelect_config.SELECT_COLORS.text.default
|
|
697
|
+
: sdSelect_config.SELECT_COLORS.icon.default,
|
|
729
698
|
'--trigger-icon-color': this.disabled
|
|
730
|
-
? SELECT_COLORS.icon.disabled
|
|
731
|
-
: SELECT_COLORS.icon.default,
|
|
699
|
+
? sdSelect_config.SELECT_COLORS.icon.disabled
|
|
700
|
+
: sdSelect_config.SELECT_COLORS.icon.default,
|
|
732
701
|
};
|
|
733
|
-
return (index.h("div", { key: '
|
|
702
|
+
return (index.h("div", { key: '69a87c509e16605feb217f12ce055e0097f09a6f', ref: el => {
|
|
734
703
|
this.triggerEl = el;
|
|
735
704
|
}, tabindex: this.disabled ? -1 : 0, class: {
|
|
736
705
|
'sd-select-trigger': true,
|
|
737
706
|
'sd-select-trigger--open': this.isOpen,
|
|
738
707
|
'sd-select-trigger--disabled': this.disabled,
|
|
739
|
-
}, style: cssVars, onClick: this.handleClick, onFocus: this.handleFocus, onBlur: this.handleBlur }, index.h("div", { key: '
|
|
708
|
+
}, style: cssVars, onClick: this.handleClick, onFocus: this.handleFocus, onBlur: this.handleBlur }, index.h("div", { key: '0886f40b2427fc4b5825b06682531a26be4c4eec', class: "sd-select-trigger__content" }, index.h("span", { key: '9e2fb73a34153b0744fbf2cc7490ecdc7a125233', class: "sd-select-trigger__text" }, hasValue ? this.displayText : (this.placeholder ?? '선택')), index.h("sd-icon", { key: 'c8a80bf912c50bf97a5d5af4d4c5307e416aea6d', name: "chevronDown", size: 12, color: "var(--trigger-icon-color)", class: {
|
|
740
709
|
'sd-select-trigger__icon': true,
|
|
741
710
|
'sd-select-trigger__icon--open': this.isOpen,
|
|
742
711
|
} }))));
|
|
@@ -744,7 +713,6 @@ const SdSelectTrigger = class {
|
|
|
744
713
|
};
|
|
745
714
|
SdSelectTrigger.style = sdSelectTriggerCss();
|
|
746
715
|
|
|
747
|
-
exports.
|
|
748
|
-
exports.sd_select_list_item_search = SdSelectListItemSearch;
|
|
716
|
+
exports.sd_select = SdSelect;
|
|
749
717
|
exports.sd_select_listbox = SdSelectListbox;
|
|
750
718
|
exports.sd_select_trigger = SdSelectTrigger;
|