bromcom-ui-next 0.1.29 → 0.1.31
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/bromcom-ui/bcm-accordion-group.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bcm-accordion.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bcm-alert.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bcm-avatar.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bcm-badge.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bcm-basic-badge.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bcm-button-group.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bcm-button.entry.esm.js.map +1 -0
- package/dist/bromcom-ui/bcm-checkbox.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bcm-chip.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bcm-divider.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bcm-drawer.entry.esm.js.map +1 -0
- package/dist/bromcom-ui/bcm-dropdown-item.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bcm-dropdown.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bcm-file-upload.entry.esm.js.map +1 -0
- package/dist/bromcom-ui/bcm-input.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bcm-linked.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bcm-modal.entry.esm.js.map +1 -0
- package/dist/bromcom-ui/bcm-pop-confirm.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bcm-popover.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bcm-radio-group.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bcm-radio.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bcm-segment.bcm-segmented-picker.entry.esm.js.map +1 -0
- package/dist/bromcom-ui/bcm-shortcut.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bcm-switch.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bcm-tab.entry.esm.js.map +1 -0
- package/dist/bromcom-ui/bcm-tabs.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bcm-text.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bcm-textarea.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bcm-tooltip.entry.esm.js.map +1 -1
- package/dist/bromcom-ui/bromcom-ui.esm.js +1 -1
- package/dist/bromcom-ui/bromcom-ui.esm.js.map +1 -1
- package/dist/bromcom-ui/global/global.js +33 -30
- package/dist/bromcom-ui/p-010219cf.entry.js +2 -0
- package/dist/bromcom-ui/p-010219cf.entry.js.map +1 -0
- package/dist/bromcom-ui/p-01a4e00b.entry.js +2 -0
- package/dist/bromcom-ui/p-01a4e00b.entry.js.map +1 -0
- package/dist/bromcom-ui/p-14c63d61.entry.js +2 -0
- package/dist/bromcom-ui/p-14c63d61.entry.js.map +1 -0
- package/dist/bromcom-ui/p-20a94dec.entry.js +2 -0
- package/dist/bromcom-ui/p-20a94dec.entry.js.map +1 -0
- package/dist/bromcom-ui/p-398620c2.entry.js +2 -0
- package/dist/bromcom-ui/p-398620c2.entry.js.map +1 -0
- package/dist/bromcom-ui/p-3b898f90.entry.js +2 -0
- package/dist/bromcom-ui/p-3b898f90.entry.js.map +1 -0
- package/dist/bromcom-ui/p-43c85c84.entry.js +2 -0
- package/dist/bromcom-ui/p-43c85c84.entry.js.map +1 -0
- package/dist/bromcom-ui/p-4e6661a5.entry.js +2 -0
- package/dist/bromcom-ui/p-4e6661a5.entry.js.map +1 -0
- package/dist/bromcom-ui/p-52bb0cdc.entry.js +2 -0
- package/dist/bromcom-ui/p-52bb0cdc.entry.js.map +1 -0
- package/dist/bromcom-ui/p-61c1c1c8.entry.js +2 -0
- package/dist/bromcom-ui/p-61c1c1c8.entry.js.map +1 -0
- package/dist/bromcom-ui/p-82e4c5f2.entry.js +2 -0
- package/dist/bromcom-ui/p-82e4c5f2.entry.js.map +1 -0
- package/dist/bromcom-ui/p-86f85963.entry.js +2 -0
- package/dist/bromcom-ui/p-86f85963.entry.js.map +1 -0
- package/dist/bromcom-ui/p-9249c1d1.entry.js +2 -0
- package/dist/bromcom-ui/p-9249c1d1.entry.js.map +1 -0
- package/dist/bromcom-ui/p-B6Ppbs5O.js +3 -0
- package/dist/bromcom-ui/p-B6Ppbs5O.js.map +1 -0
- package/dist/bromcom-ui/p-BfTCfPZ1.js.map +1 -1
- package/dist/bromcom-ui/p-CEcVC0yX.js.map +1 -1
- package/dist/bromcom-ui/p-DBDSgIvP.js +2 -0
- package/dist/bromcom-ui/p-DBDSgIvP.js.map +1 -0
- package/dist/bromcom-ui/p-DaE0ZLar.js +2 -0
- package/dist/bromcom-ui/p-DaE0ZLar.js.map +1 -0
- package/dist/bromcom-ui/p-IBjzkjef.js.map +1 -1
- package/dist/bromcom-ui/p-a25d1cef.entry.js +2 -0
- package/dist/bromcom-ui/p-a25d1cef.entry.js.map +1 -0
- package/dist/bromcom-ui/p-a4cb2e79.entry.js +2 -0
- package/dist/bromcom-ui/p-a4cb2e79.entry.js.map +1 -0
- package/dist/bromcom-ui/p-a68925b4.entry.js +2 -0
- package/dist/bromcom-ui/p-a68925b4.entry.js.map +1 -0
- package/dist/bromcom-ui/p-a750186c.entry.js +2 -0
- package/dist/bromcom-ui/p-a750186c.entry.js.map +1 -0
- package/dist/bromcom-ui/p-ac768b56.entry.js +2 -0
- package/dist/bromcom-ui/p-ac768b56.entry.js.map +1 -0
- package/dist/bromcom-ui/p-b0b193e6.entry.js +2 -0
- package/dist/bromcom-ui/p-b0b193e6.entry.js.map +1 -0
- package/dist/bromcom-ui/p-bf4409ca.entry.js +2 -0
- package/dist/bromcom-ui/p-bf4409ca.entry.js.map +1 -0
- package/dist/bromcom-ui/p-c57fb29b.entry.js +2 -0
- package/dist/bromcom-ui/p-c57fb29b.entry.js.map +1 -0
- package/dist/bromcom-ui/{p-2480e468.entry.js → p-ccc310aa.entry.js} +2 -2
- package/dist/bromcom-ui/p-ccc310aa.entry.js.map +1 -0
- package/dist/bromcom-ui/p-d4ee962d.entry.js +2 -0
- package/dist/bromcom-ui/p-d4ee962d.entry.js.map +1 -0
- package/dist/bromcom-ui/p-e25a2f7a.entry.js +2 -0
- package/dist/bromcom-ui/p-e25a2f7a.entry.js.map +1 -0
- package/dist/bromcom-ui/p-e5b0b2ad.entry.js +2 -0
- package/dist/bromcom-ui/p-e5b0b2ad.entry.js.map +1 -0
- package/dist/bromcom-ui/p-e70d784d.entry.js +2 -0
- package/dist/bromcom-ui/p-e70d784d.entry.js.map +1 -0
- package/dist/bromcom-ui/p-e9fa3a22.entry.js +2 -0
- package/dist/bromcom-ui/p-e9fa3a22.entry.js.map +1 -0
- package/dist/bromcom-ui/p-ef281184.entry.js +2 -0
- package/dist/bromcom-ui/p-ef281184.entry.js.map +1 -0
- package/dist/bromcom-ui/{p-089edfdc.entry.js → p-fb6f616c.entry.js} +2 -2
- package/dist/bromcom-ui/p-fb6f616c.entry.js.map +1 -0
- package/dist/bromcom-ui/p-fd31c70c.entry.js +2 -0
- package/dist/bromcom-ui/p-fd31c70c.entry.js.map +1 -0
- package/dist/bromcom-ui/p-nf_HKsGq.js +2 -0
- package/dist/bromcom-ui/{p-CUvT12BL.js.map → p-nf_HKsGq.js.map} +1 -1
- package/dist/cjs/base-choice-control-EmA4JRjR.js +54 -0
- package/dist/cjs/base-choice-control-EmA4JRjR.js.map +1 -0
- package/dist/cjs/bcm-accordion-group.cjs.entry.js +21 -21
- package/dist/cjs/bcm-accordion-group.entry.cjs.js.map +1 -1
- package/dist/cjs/bcm-accordion.cjs.entry.js +75 -60
- package/dist/cjs/bcm-accordion.entry.cjs.js.map +1 -1
- package/dist/cjs/bcm-alert.cjs.entry.js +21 -23
- package/dist/cjs/bcm-alert.entry.cjs.js.map +1 -1
- package/dist/cjs/bcm-avatar.cjs.entry.js +22 -14
- package/dist/cjs/bcm-avatar.entry.cjs.js.map +1 -1
- package/dist/cjs/bcm-badge.cjs.entry.js +114 -84
- package/dist/cjs/bcm-badge.entry.cjs.js.map +1 -1
- package/dist/cjs/bcm-basic-badge.cjs.entry.js +73 -61
- package/dist/cjs/bcm-basic-badge.entry.cjs.js.map +1 -1
- package/dist/cjs/bcm-button-group.cjs.entry.js +36 -26
- package/dist/cjs/bcm-button-group.entry.cjs.js.map +1 -1
- package/dist/cjs/bcm-button.cjs.entry.js +338 -0
- package/dist/cjs/bcm-button.entry.cjs.js.map +1 -0
- package/dist/cjs/bcm-checkbox.cjs.entry.js +284 -176
- package/dist/cjs/bcm-checkbox.entry.cjs.js.map +1 -1
- package/dist/cjs/bcm-chip.cjs.entry.js +38 -37
- package/dist/cjs/bcm-chip.entry.cjs.js.map +1 -1
- package/dist/cjs/bcm-divider.cjs.entry.js +56 -58
- package/dist/cjs/bcm-divider.entry.cjs.js.map +1 -1
- package/dist/cjs/bcm-drawer.cjs.entry.js +332 -0
- package/dist/cjs/bcm-drawer.entry.cjs.js.map +1 -0
- package/dist/cjs/bcm-dropdown-item.cjs.entry.js +36 -35
- package/dist/cjs/bcm-dropdown-item.entry.cjs.js.map +1 -1
- package/dist/cjs/bcm-dropdown.cjs.entry.js +17 -26
- package/dist/cjs/bcm-dropdown.entry.cjs.js.map +1 -1
- package/dist/cjs/bcm-file-upload.cjs.entry.js +552 -0
- package/dist/cjs/bcm-file-upload.entry.cjs.js.map +1 -0
- package/dist/cjs/bcm-input.cjs.entry.js +250 -160
- package/dist/cjs/bcm-input.entry.cjs.js.map +1 -1
- package/dist/cjs/bcm-linked.cjs.entry.js +373 -264
- package/dist/cjs/bcm-linked.entry.cjs.js.map +1 -1
- package/dist/cjs/bcm-modal.cjs.entry.js +360 -0
- package/dist/cjs/bcm-modal.entry.cjs.js.map +1 -0
- package/dist/cjs/bcm-pop-confirm.cjs.entry.js +337 -206
- package/dist/cjs/bcm-pop-confirm.entry.cjs.js.map +1 -1
- package/dist/cjs/bcm-popover.cjs.entry.js +416 -154
- package/dist/cjs/bcm-popover.entry.cjs.js.map +1 -1
- package/dist/cjs/bcm-radio-group.cjs.entry.js +103 -82
- package/dist/cjs/bcm-radio-group.entry.cjs.js.map +1 -1
- package/dist/cjs/bcm-radio.cjs.entry.js +239 -108
- package/dist/cjs/bcm-radio.entry.cjs.js.map +1 -1
- package/dist/cjs/bcm-segment.bcm-segmented-picker.entry.cjs.js.map +1 -0
- package/dist/cjs/bcm-segment_2.cjs.entry.js +335 -0
- package/dist/cjs/bcm-shortcut.cjs.entry.js +5 -6
- package/dist/cjs/bcm-shortcut.entry.cjs.js.map +1 -1
- package/dist/cjs/bcm-switch.cjs.entry.js +281 -150
- package/dist/cjs/bcm-switch.entry.cjs.js.map +1 -1
- package/dist/cjs/bcm-tab.cjs.entry.js +44 -0
- package/dist/cjs/bcm-tab.entry.cjs.js.map +1 -0
- package/dist/cjs/bcm-tabs.cjs.entry.js +191 -239
- package/dist/cjs/bcm-tabs.entry.cjs.js.map +1 -1
- package/dist/cjs/bcm-text.cjs.entry.js +86 -87
- package/dist/cjs/bcm-text.entry.cjs.js.map +1 -1
- package/dist/cjs/bcm-textarea.cjs.entry.js +224 -156
- package/dist/cjs/bcm-textarea.entry.cjs.js.map +1 -1
- package/dist/cjs/bcm-tooltip.cjs.entry.js +386 -152
- package/dist/cjs/bcm-tooltip.entry.cjs.js.map +1 -1
- package/dist/cjs/bromcom-ui.cjs.js +3 -5
- package/dist/cjs/bromcom-ui.cjs.js.map +1 -1
- package/dist/cjs/{floating-ui.dom-DyKmFgkP.js → floating-ui.dom-S9nP6zZt.js} +40 -23
- package/dist/cjs/floating-ui.dom-S9nP6zZt.js.map +1 -0
- package/dist/cjs/generate-id-CG_BkTJu.js.map +1 -1
- package/dist/cjs/{index-BtiU-G2W.js → index-1Qal-onT.js} +165 -398
- package/dist/cjs/index-1Qal-onT.js.map +1 -0
- package/dist/cjs/index-Bp6Dd2i1.js.map +1 -1
- package/dist/cjs/index.cjs.js +0 -2
- package/dist/cjs/loader.cjs.js +2 -4
- package/dist/cjs/tv-ngpIbGlG.js.map +1 -1
- package/dist/cjs/{validation-messages-BjfpSEWk.js → validation-messages-DieKlSG4.js} +6 -7
- package/dist/{esm/validation-messages-CUvT12BL.js.map → cjs/validation-messages-DieKlSG4.js.map} +1 -1
- package/dist/collection/collection-manifest.json +7 -8
- package/dist/collection/components/_shared/form/base-choice-control.js +90 -0
- package/dist/collection/components/_shared/form/base-choice-control.js.map +1 -0
- package/dist/collection/components/_shared/form/base-form-control.js +115 -0
- package/dist/collection/components/_shared/form/base-form-control.js.map +1 -0
- package/dist/collection/components/accordion/accordion.component.js +80 -63
- package/dist/collection/components/accordion/accordion.component.js.map +1 -1
- package/dist/collection/components/accordion/accordion.css +1 -1
- package/dist/collection/components/accordion-group/accordion-group.component.js +23 -21
- package/dist/collection/components/accordion-group/accordion-group.component.js.map +1 -1
- package/dist/collection/components/accordion-group/types.js.map +1 -1
- package/dist/collection/components/alert/alert.component.js +24 -26
- package/dist/collection/components/alert/alert.component.js.map +1 -1
- package/dist/collection/components/alert/alert.css +1 -1
- package/dist/collection/components/avatar/avatar.component.js +34 -26
- package/dist/collection/components/avatar/avatar.component.js.map +1 -1
- package/dist/collection/components/avatar/avatar.css +1 -1
- package/dist/collection/components/badge/badge.component.js +124 -94
- package/dist/collection/components/badge/badge.component.js.map +1 -1
- package/dist/collection/components/badge/badge.css +1 -1
- package/dist/collection/components/basic-badge/basic-badge.component.js +77 -65
- package/dist/collection/components/basic-badge/basic-badge.component.js.map +1 -1
- package/dist/collection/components/basic-badge/basic-badge.css +1 -1
- package/dist/collection/components/button/button.component.js +135 -114
- package/dist/collection/components/button/button.component.js.map +1 -1
- package/dist/collection/components/button/button.css +1 -1
- package/dist/collection/components/button-group/button-group.component.js +47 -36
- package/dist/collection/components/button-group/button-group.component.js.map +1 -1
- package/dist/collection/components/button-group/button-group.css +1 -1
- package/dist/collection/components/checkbox/checkbox.component.js +362 -243
- package/dist/collection/components/checkbox/checkbox.component.js.map +1 -1
- package/dist/collection/components/checkbox/checkbox.css +1 -1
- package/dist/collection/components/chip/chip.component.js +42 -41
- package/dist/collection/components/chip/chip.component.js.map +1 -1
- package/dist/collection/components/chip/chip.css +1 -1
- package/dist/collection/components/divider/divider.component.js +56 -58
- package/dist/collection/components/divider/divider.component.js.map +1 -1
- package/dist/collection/components/divider/divider.css +1 -1
- package/dist/collection/components/drawer/drawer.component.js +476 -155
- package/dist/collection/components/drawer/drawer.component.js.map +1 -1
- package/dist/collection/components/drawer/drawer.css +1 -1
- package/dist/collection/components/drawer/types.js.map +1 -1
- package/dist/collection/components/dropdown/dropdown.component.js +18 -27
- package/dist/collection/components/dropdown/dropdown.component.js.map +1 -1
- package/dist/collection/components/dropdown-item/dropdown-item.component.js +41 -40
- package/dist/collection/components/dropdown-item/dropdown-item.component.js.map +1 -1
- package/dist/collection/components/dropdown-item/dropdown-item.css +1 -1
- package/dist/collection/components/input/input.component.js +283 -198
- package/dist/collection/components/input/input.component.js.map +1 -1
- package/dist/collection/components/linked/linked.component.js +551 -355
- package/dist/collection/components/linked/linked.component.js.map +1 -1
- package/dist/collection/components/linked/linked.css +1 -1
- package/dist/collection/components/modal/modal.component.js +276 -149
- package/dist/collection/components/modal/modal.component.js.map +1 -1
- package/dist/collection/components/modal/modal.css +1 -1
- package/dist/collection/components/pop-confirm/pop-confirm.component.js +745 -340
- package/dist/collection/components/pop-confirm/pop-confirm.component.js.map +1 -1
- package/dist/collection/components/pop-confirm/pop-confirm.css +1 -1
- package/dist/collection/components/popover/popover.component.js +609 -196
- package/dist/collection/components/popover/popover.component.js.map +1 -1
- package/dist/collection/components/popover/popover.css +1 -1
- package/dist/collection/components/radio/radio.component.js +294 -118
- package/dist/collection/components/radio/radio.component.js.map +1 -1
- package/dist/collection/components/radio-group/radio-group.component.js +115 -93
- package/dist/collection/components/radio-group/radio-group.component.js.map +1 -1
- package/dist/collection/components/segmented-picker/segment.component.js +228 -0
- package/dist/collection/components/segmented-picker/segment.component.js.map +1 -0
- package/dist/collection/components/segmented-picker/segment.css +1 -0
- package/dist/collection/components/segmented-picker/segmented-picker.component.js +357 -142
- package/dist/collection/components/segmented-picker/segmented-picker.component.js.map +1 -1
- package/dist/collection/components/segmented-picker/segmented-picker.css +1 -1
- package/dist/collection/components/shortcut/shortcut.js +7 -8
- package/dist/collection/components/shortcut/shortcut.js.map +1 -1
- package/dist/collection/components/switch/switch.component.js +357 -287
- package/dist/collection/components/switch/switch.component.js.map +1 -1
- package/dist/collection/components/switch/switch.css +1 -1
- package/dist/collection/components/tabs/bcm-tab.css +1 -0
- package/dist/collection/components/tabs/bcm-tabs.css +1 -1
- package/dist/collection/components/tabs/tab.component.js +169 -0
- package/dist/collection/components/tabs/tab.component.js.map +1 -0
- package/dist/collection/components/tabs/tabs.component.js +224 -355
- package/dist/collection/components/tabs/tabs.component.js.map +1 -1
- package/dist/collection/components/text/text.component.js +90 -91
- package/dist/collection/components/text/text.component.js.map +1 -1
- package/dist/collection/components/textarea/textarea.component.js +252 -190
- package/dist/collection/components/textarea/textarea.component.js.map +1 -1
- package/dist/collection/components/tooltip/tooltip.component.js +605 -220
- package/dist/collection/components/tooltip/tooltip.component.js.map +1 -1
- package/dist/collection/components/tooltip/tooltip.css +1 -1
- package/dist/collection/components/upload/file-upload.component.js +905 -0
- package/dist/collection/components/upload/file-upload.component.js.map +1 -0
- package/dist/collection/components/upload/file-upload.css +1 -0
- package/dist/collection/global/global.js +33 -30
- package/dist/collection/utils/i18n.js +3 -4
- package/dist/collection/utils/i18n.js.map +1 -1
- package/dist/collection/utils/slot/check-slot-content.js +1 -2
- package/dist/collection/utils/slot/check-slot-content.js.map +1 -1
- package/dist/collection/utils/validation-messages.js +1 -1
- package/dist/collection/utils/validation-messages.js.map +1 -1
- package/dist/components/bcm-accordion-group.js +24 -20
- package/dist/components/bcm-accordion-group.js.map +1 -1
- package/dist/components/bcm-accordion.js +78 -59
- package/dist/components/bcm-accordion.js.map +1 -1
- package/dist/components/bcm-alert.js +1 -112
- package/dist/components/bcm-alert.js.map +1 -1
- package/dist/components/bcm-avatar.js +26 -14
- package/dist/components/bcm-avatar.js.map +1 -1
- package/dist/components/bcm-badge.js +1 -1
- package/dist/components/bcm-basic-badge.js +76 -60
- package/dist/components/bcm-basic-badge.js.map +1 -1
- package/dist/components/bcm-button-group.js +39 -25
- package/dist/components/bcm-button-group.js.map +1 -1
- package/dist/components/bcm-button.js +1 -1
- package/dist/components/bcm-checkbox.js +300 -186
- package/dist/components/bcm-checkbox.js.map +1 -1
- package/dist/components/bcm-chip.js +41 -36
- package/dist/components/bcm-chip.js.map +1 -1
- package/dist/components/bcm-divider.js +59 -57
- package/dist/components/bcm-divider.js.map +1 -1
- package/dist/components/bcm-drawer.js +276 -138
- package/dist/components/bcm-drawer.js.map +1 -1
- package/dist/components/bcm-dropdown-item.js +40 -35
- package/dist/components/bcm-dropdown-item.js.map +1 -1
- package/dist/components/bcm-dropdown.js +22 -28
- package/dist/components/bcm-dropdown.js.map +1 -1
- package/dist/components/{bcm-tabs-content.d.ts → bcm-file-upload.d.ts} +4 -4
- package/dist/components/bcm-file-upload.js +593 -0
- package/dist/components/bcm-file-upload.js.map +1 -0
- package/dist/components/bcm-input.js +248 -160
- package/dist/components/bcm-input.js.map +1 -1
- package/dist/components/bcm-linked.js +1 -1
- package/dist/components/bcm-modal.js +196 -119
- package/dist/components/bcm-modal.js.map +1 -1
- package/dist/components/bcm-pop-confirm.js +354 -215
- package/dist/components/bcm-pop-confirm.js.map +1 -1
- package/dist/components/bcm-popover.js +431 -157
- package/dist/components/bcm-popover.js.map +1 -1
- package/dist/components/bcm-radio-group.js +106 -81
- package/dist/components/bcm-radio-group.js.map +1 -1
- package/dist/components/bcm-radio.js +245 -110
- package/dist/components/bcm-radio.js.map +1 -1
- package/dist/components/{bcm-tabs-list.d.ts → bcm-segment.d.ts} +4 -4
- package/dist/components/bcm-segment.js +110 -0
- package/dist/components/bcm-segment.js.map +1 -0
- package/dist/components/bcm-segmented-picker.js +238 -117
- package/dist/components/bcm-segmented-picker.js.map +1 -1
- package/dist/components/bcm-shortcut.js +8 -5
- package/dist/components/bcm-shortcut.js.map +1 -1
- package/dist/components/bcm-switch.js +296 -158
- package/dist/components/bcm-switch.js.map +1 -1
- package/dist/components/{bcm-tabs-trigger.d.ts → bcm-tab.d.ts} +4 -4
- package/dist/components/bcm-tab.js +71 -0
- package/dist/components/bcm-tab.js.map +1 -0
- package/dist/components/bcm-tabs.js +200 -249
- package/dist/components/bcm-tabs.js.map +1 -1
- package/dist/components/bcm-text.js +89 -86
- package/dist/components/bcm-text.js.map +1 -1
- package/dist/components/bcm-textarea.js +222 -156
- package/dist/components/bcm-textarea.js.map +1 -1
- package/dist/components/bcm-tooltip.js +402 -154
- package/dist/components/bcm-tooltip.js.map +1 -1
- package/dist/components/index.js +140 -392
- package/dist/components/index.js.map +1 -1
- package/dist/components/p-5_TgtzQU.js +119 -0
- package/dist/components/p-5_TgtzQU.js.map +1 -0
- package/dist/components/p-BfTCfPZ1.js.map +1 -1
- package/dist/components/p-CEcVC0yX.js.map +1 -1
- package/dist/components/{p-CzcTU1ty.js → p-DBDSgIvP.js} +40 -23
- package/dist/components/p-DBDSgIvP.js.map +1 -0
- package/dist/components/p-IBjzkjef.js.map +1 -1
- package/dist/components/p-RlBWOSgL.js +179 -0
- package/dist/components/p-RlBWOSgL.js.map +1 -0
- package/dist/components/p-SERXqWcS.js +51 -0
- package/dist/components/p-SERXqWcS.js.map +1 -0
- package/dist/components/{p-CUvT12BL.js → p-nf_HKsGq.js} +6 -7
- package/dist/components/p-nf_HKsGq.js.map +1 -0
- package/dist/components/{p-DHONP_n4.js → p-xQIzBLsS.js} +112 -87
- package/dist/components/p-xQIzBLsS.js.map +1 -0
- package/dist/components/p-z9ESseGb.js +492 -0
- package/dist/components/p-z9ESseGb.js.map +1 -0
- package/dist/esm/base-choice-control-CKR8UdZ6.js +52 -0
- package/dist/esm/base-choice-control-CKR8UdZ6.js.map +1 -0
- package/dist/esm/bcm-accordion-group.entry.js +21 -21
- package/dist/esm/bcm-accordion-group.entry.js.map +1 -1
- package/dist/esm/bcm-accordion.entry.js +75 -60
- package/dist/esm/bcm-accordion.entry.js.map +1 -1
- package/dist/esm/bcm-alert.entry.js +21 -23
- package/dist/esm/bcm-alert.entry.js.map +1 -1
- package/dist/esm/bcm-avatar.entry.js +22 -14
- package/dist/esm/bcm-avatar.entry.js.map +1 -1
- package/dist/esm/bcm-badge.entry.js +114 -84
- package/dist/esm/bcm-badge.entry.js.map +1 -1
- package/dist/esm/bcm-basic-badge.entry.js +73 -61
- package/dist/esm/bcm-basic-badge.entry.js.map +1 -1
- package/dist/esm/bcm-button-group.entry.js +36 -26
- package/dist/esm/bcm-button-group.entry.js.map +1 -1
- package/dist/esm/bcm-button.entry.js +336 -0
- package/dist/esm/bcm-button.entry.js.map +1 -0
- package/dist/esm/bcm-checkbox.entry.js +284 -176
- package/dist/esm/bcm-checkbox.entry.js.map +1 -1
- package/dist/esm/bcm-chip.entry.js +38 -37
- package/dist/esm/bcm-chip.entry.js.map +1 -1
- package/dist/esm/bcm-divider.entry.js +56 -58
- package/dist/esm/bcm-divider.entry.js.map +1 -1
- package/dist/esm/bcm-drawer.entry.js +330 -0
- package/dist/esm/bcm-drawer.entry.js.map +1 -0
- package/dist/esm/bcm-dropdown-item.entry.js +36 -35
- package/dist/esm/bcm-dropdown-item.entry.js.map +1 -1
- package/dist/esm/bcm-dropdown.entry.js +17 -26
- package/dist/esm/bcm-dropdown.entry.js.map +1 -1
- package/dist/esm/bcm-file-upload.entry.js +550 -0
- package/dist/esm/bcm-file-upload.entry.js.map +1 -0
- package/dist/esm/bcm-input.entry.js +250 -160
- package/dist/esm/bcm-input.entry.js.map +1 -1
- package/dist/esm/bcm-linked.entry.js +373 -264
- package/dist/esm/bcm-linked.entry.js.map +1 -1
- package/dist/esm/bcm-modal.entry.js +358 -0
- package/dist/esm/bcm-modal.entry.js.map +1 -0
- package/dist/esm/bcm-pop-confirm.entry.js +337 -206
- package/dist/esm/bcm-pop-confirm.entry.js.map +1 -1
- package/dist/esm/bcm-popover.entry.js +416 -154
- package/dist/esm/bcm-popover.entry.js.map +1 -1
- package/dist/esm/bcm-radio-group.entry.js +103 -82
- package/dist/esm/bcm-radio-group.entry.js.map +1 -1
- package/dist/esm/bcm-radio.entry.js +239 -108
- package/dist/esm/bcm-radio.entry.js.map +1 -1
- package/dist/esm/bcm-segment.bcm-segmented-picker.entry.js.map +1 -0
- package/dist/esm/bcm-segment_2.entry.js +332 -0
- package/dist/esm/bcm-shortcut.entry.js +5 -6
- package/dist/esm/bcm-shortcut.entry.js.map +1 -1
- package/dist/esm/bcm-switch.entry.js +281 -150
- package/dist/esm/bcm-switch.entry.js.map +1 -1
- package/dist/esm/bcm-tab.entry.js +42 -0
- package/dist/esm/bcm-tab.entry.js.map +1 -0
- package/dist/esm/bcm-tabs.entry.js +191 -239
- package/dist/esm/bcm-tabs.entry.js.map +1 -1
- package/dist/esm/bcm-text.entry.js +86 -87
- package/dist/esm/bcm-text.entry.js.map +1 -1
- package/dist/esm/bcm-textarea.entry.js +224 -156
- package/dist/esm/bcm-textarea.entry.js.map +1 -1
- package/dist/esm/bcm-tooltip.entry.js +386 -152
- package/dist/esm/bcm-tooltip.entry.js.map +1 -1
- package/dist/esm/bromcom-ui.js +4 -6
- package/dist/esm/bromcom-ui.js.map +1 -1
- package/dist/esm/{floating-ui.dom-DxMLMJ3r.js → floating-ui.dom-DBDSgIvP.js} +41 -24
- package/dist/esm/floating-ui.dom-DBDSgIvP.js.map +1 -0
- package/dist/esm/generate-id-IBjzkjef.js.map +1 -1
- package/dist/esm/{index-BuuGCw0z.js → index-B6Ppbs5O.js} +165 -398
- package/dist/esm/index-B6Ppbs5O.js.map +1 -0
- package/dist/esm/index-BfTCfPZ1.js.map +1 -1
- package/dist/esm/index.js +0 -2
- package/dist/esm/loader.js +3 -5
- package/dist/esm/tv-CEcVC0yX.js.map +1 -1
- package/dist/esm/{validation-messages-CUvT12BL.js → validation-messages-nf_HKsGq.js} +6 -7
- package/dist/{cjs/validation-messages-BjfpSEWk.js.map → esm/validation-messages-nf_HKsGq.js.map} +1 -1
- package/dist/types/components/_shared/form/base-choice-control.d.ts +15 -0
- package/dist/types/components/_shared/form/base-form-control.d.ts +11 -0
- package/dist/types/components/accordion-group/types.d.ts +2 -2
- package/dist/types/components/checkbox/checkbox.component.d.ts +89 -71
- package/dist/types/components/drawer/drawer.component.d.ts +143 -3
- package/dist/types/components/drawer/types.d.ts +1 -1
- package/dist/types/components/dropdown/dropdown.component.d.ts +0 -3
- package/dist/types/components/input/input.component.d.ts +5 -0
- package/dist/types/components/linked/linked.component.d.ts +152 -36
- package/dist/types/components/modal/modal.component.d.ts +121 -0
- package/dist/types/components/pop-confirm/pop-confirm.component.d.ts +263 -143
- package/dist/types/components/popover/popover.component.d.ts +94 -39
- package/dist/types/components/radio/radio.component.d.ts +21 -0
- package/dist/types/components/segmented-picker/segment.component.d.ts +42 -0
- package/dist/types/components/segmented-picker/segmented-picker.component.d.ts +91 -24
- package/dist/types/components/switch/switch.component.d.ts +83 -43
- package/dist/types/components/tabs/tab.component.d.ts +33 -0
- package/dist/types/components/tabs/tabs.component.d.ts +51 -64
- package/dist/types/components/textarea/textarea.component.d.ts +5 -0
- package/dist/types/components/tooltip/tooltip.component.d.ts +147 -56
- package/dist/types/components/upload/file-upload.component.d.ts +107 -0
- package/dist/types/components.d.ts +2400 -742
- package/dist/types/stencil-public-runtime.d.ts +50 -3
- package/package.json +2 -2
- package/dist/bromcom-ui/bcm-button.bcm-drawer.bcm-modal.entry.esm.js.map +0 -1
- package/dist/bromcom-ui/bcm-segmented-picker-option.entry.esm.js.map +0 -1
- package/dist/bromcom-ui/bcm-segmented-picker.entry.esm.js.map +0 -1
- package/dist/bromcom-ui/bcm-tabs-content.entry.esm.js.map +0 -1
- package/dist/bromcom-ui/bcm-tabs-list.entry.esm.js.map +0 -1
- package/dist/bromcom-ui/bcm-tabs-trigger.entry.esm.js.map +0 -1
- package/dist/bromcom-ui/p-0101b4f2.entry.js +0 -2
- package/dist/bromcom-ui/p-0101b4f2.entry.js.map +0 -1
- package/dist/bromcom-ui/p-089edfdc.entry.js.map +0 -1
- package/dist/bromcom-ui/p-08bc93c5.entry.js +0 -2
- package/dist/bromcom-ui/p-08bc93c5.entry.js.map +0 -1
- package/dist/bromcom-ui/p-09be61c3.entry.js +0 -2
- package/dist/bromcom-ui/p-09be61c3.entry.js.map +0 -1
- package/dist/bromcom-ui/p-11851391.entry.js +0 -2
- package/dist/bromcom-ui/p-11851391.entry.js.map +0 -1
- package/dist/bromcom-ui/p-11f3e129.entry.js +0 -2
- package/dist/bromcom-ui/p-11f3e129.entry.js.map +0 -1
- package/dist/bromcom-ui/p-211ca6e0.entry.js +0 -2
- package/dist/bromcom-ui/p-211ca6e0.entry.js.map +0 -1
- package/dist/bromcom-ui/p-22edf049.entry.js +0 -2
- package/dist/bromcom-ui/p-22edf049.entry.js.map +0 -1
- package/dist/bromcom-ui/p-2480e468.entry.js.map +0 -1
- package/dist/bromcom-ui/p-26d2db9e.entry.js +0 -2
- package/dist/bromcom-ui/p-26d2db9e.entry.js.map +0 -1
- package/dist/bromcom-ui/p-2d0a6472.entry.js +0 -2
- package/dist/bromcom-ui/p-2d0a6472.entry.js.map +0 -1
- package/dist/bromcom-ui/p-360bff8a.entry.js +0 -2
- package/dist/bromcom-ui/p-360bff8a.entry.js.map +0 -1
- package/dist/bromcom-ui/p-488d6ef4.entry.js +0 -2
- package/dist/bromcom-ui/p-488d6ef4.entry.js.map +0 -1
- package/dist/bromcom-ui/p-5e0702d1.entry.js +0 -2
- package/dist/bromcom-ui/p-5e0702d1.entry.js.map +0 -1
- package/dist/bromcom-ui/p-63228f7e.entry.js +0 -2
- package/dist/bromcom-ui/p-63228f7e.entry.js.map +0 -1
- package/dist/bromcom-ui/p-6b585adc.entry.js +0 -2
- package/dist/bromcom-ui/p-6b585adc.entry.js.map +0 -1
- package/dist/bromcom-ui/p-6d7d73d5.entry.js +0 -2
- package/dist/bromcom-ui/p-6d7d73d5.entry.js.map +0 -1
- package/dist/bromcom-ui/p-7234af90.entry.js +0 -2
- package/dist/bromcom-ui/p-7234af90.entry.js.map +0 -1
- package/dist/bromcom-ui/p-83f64814.entry.js +0 -2
- package/dist/bromcom-ui/p-83f64814.entry.js.map +0 -1
- package/dist/bromcom-ui/p-8ace5a6a.entry.js +0 -2
- package/dist/bromcom-ui/p-8ace5a6a.entry.js.map +0 -1
- package/dist/bromcom-ui/p-8d74249a.entry.js +0 -2
- package/dist/bromcom-ui/p-8d74249a.entry.js.map +0 -1
- package/dist/bromcom-ui/p-BuuGCw0z.js +0 -3
- package/dist/bromcom-ui/p-BuuGCw0z.js.map +0 -1
- package/dist/bromcom-ui/p-CUvT12BL.js +0 -2
- package/dist/bromcom-ui/p-DxMLMJ3r.js +0 -2
- package/dist/bromcom-ui/p-DxMLMJ3r.js.map +0 -1
- package/dist/bromcom-ui/p-a88f20e0.entry.js +0 -2
- package/dist/bromcom-ui/p-a88f20e0.entry.js.map +0 -1
- package/dist/bromcom-ui/p-bad299f2.entry.js +0 -2
- package/dist/bromcom-ui/p-bad299f2.entry.js.map +0 -1
- package/dist/bromcom-ui/p-bdaf5653.entry.js +0 -2
- package/dist/bromcom-ui/p-bdaf5653.entry.js.map +0 -1
- package/dist/bromcom-ui/p-c0e7f9d6.entry.js +0 -2
- package/dist/bromcom-ui/p-c0e7f9d6.entry.js.map +0 -1
- package/dist/bromcom-ui/p-c34f0a66.entry.js +0 -2
- package/dist/bromcom-ui/p-c34f0a66.entry.js.map +0 -1
- package/dist/bromcom-ui/p-d7cea19f.entry.js +0 -2
- package/dist/bromcom-ui/p-d7cea19f.entry.js.map +0 -1
- package/dist/bromcom-ui/p-e5e0ac07.entry.js +0 -2
- package/dist/bromcom-ui/p-e5e0ac07.entry.js.map +0 -1
- package/dist/bromcom-ui/p-ee5f877f.entry.js +0 -2
- package/dist/bromcom-ui/p-ee5f877f.entry.js.map +0 -1
- package/dist/bromcom-ui/p-fbccbffc.entry.js +0 -2
- package/dist/bromcom-ui/p-fbccbffc.entry.js.map +0 -1
- package/dist/cjs/bcm-accordion-group.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-accordion.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-alert.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-avatar.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-badge.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-basic-badge.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-button-group.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-button.bcm-drawer.bcm-modal.entry.cjs.js.map +0 -1
- package/dist/cjs/bcm-button_3.cjs.entry.js +0 -794
- package/dist/cjs/bcm-button_3.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-checkbox.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-chip.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-divider.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-dropdown-item.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-dropdown.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-input.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-linked.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-pop-confirm.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-popover.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-radio-group.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-radio.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-segmented-picker-option.cjs.entry.js +0 -107
- package/dist/cjs/bcm-segmented-picker-option.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-segmented-picker-option.entry.cjs.js.map +0 -1
- package/dist/cjs/bcm-segmented-picker.cjs.entry.js +0 -144
- package/dist/cjs/bcm-segmented-picker.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-segmented-picker.entry.cjs.js.map +0 -1
- package/dist/cjs/bcm-shortcut.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-switch.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-tabs-content.cjs.entry.js +0 -20
- package/dist/cjs/bcm-tabs-content.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-tabs-content.entry.cjs.js.map +0 -1
- package/dist/cjs/bcm-tabs-list.cjs.entry.js +0 -84
- package/dist/cjs/bcm-tabs-list.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-tabs-list.entry.cjs.js.map +0 -1
- package/dist/cjs/bcm-tabs-trigger.cjs.entry.js +0 -122
- package/dist/cjs/bcm-tabs-trigger.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-tabs-trigger.entry.cjs.js.map +0 -1
- package/dist/cjs/bcm-tabs.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-text.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-textarea.cjs.entry.js.map +0 -1
- package/dist/cjs/bcm-tooltip.cjs.entry.js.map +0 -1
- package/dist/cjs/floating-ui.dom-DyKmFgkP.js.map +0 -1
- package/dist/cjs/index-BtiU-G2W.js.map +0 -1
- package/dist/collection/components/segmented-picker/segmented-picker-option.component.js +0 -253
- package/dist/collection/components/segmented-picker/segmented-picker-option.component.js.map +0 -1
- package/dist/collection/components/segmented-picker/segmented-picker-option.css +0 -1
- package/dist/collection/components/tabs/tabs-content.component.js +0 -46
- package/dist/collection/components/tabs/tabs-content.component.js.map +0 -1
- package/dist/collection/components/tabs/tabs-content.css +0 -1
- package/dist/collection/components/tabs/tabs-list.component.js +0 -133
- package/dist/collection/components/tabs/tabs-list.component.js.map +0 -1
- package/dist/collection/components/tabs/tabs-list.css +0 -1
- package/dist/collection/components/tabs/tabs-trigger.component.js +0 -267
- package/dist/collection/components/tabs/tabs-trigger.component.js.map +0 -1
- package/dist/collection/components/tabs/tabs-trigger.css +0 -1
- package/dist/components/bcm-segmented-picker-option.d.ts +0 -11
- package/dist/components/bcm-segmented-picker-option.js +0 -131
- package/dist/components/bcm-segmented-picker-option.js.map +0 -1
- package/dist/components/bcm-tabs-content.js +0 -39
- package/dist/components/bcm-tabs-content.js.map +0 -1
- package/dist/components/bcm-tabs-list.js +0 -104
- package/dist/components/bcm-tabs-list.js.map +0 -1
- package/dist/components/bcm-tabs-trigger.js +0 -146
- package/dist/components/bcm-tabs-trigger.js.map +0 -1
- package/dist/components/p-BHwftRkk.js +0 -379
- package/dist/components/p-BHwftRkk.js.map +0 -1
- package/dist/components/p-CQF7wlXf.js +0 -145
- package/dist/components/p-CQF7wlXf.js.map +0 -1
- package/dist/components/p-CUvT12BL.js.map +0 -1
- package/dist/components/p-CzcTU1ty.js.map +0 -1
- package/dist/components/p-DHONP_n4.js.map +0 -1
- package/dist/esm/bcm-button.bcm-drawer.bcm-modal.entry.js.map +0 -1
- package/dist/esm/bcm-button_3.entry.js +0 -790
- package/dist/esm/bcm-button_3.entry.js.map +0 -1
- package/dist/esm/bcm-segmented-picker-option.entry.js +0 -105
- package/dist/esm/bcm-segmented-picker-option.entry.js.map +0 -1
- package/dist/esm/bcm-segmented-picker.entry.js +0 -142
- package/dist/esm/bcm-segmented-picker.entry.js.map +0 -1
- package/dist/esm/bcm-tabs-content.entry.js +0 -18
- package/dist/esm/bcm-tabs-content.entry.js.map +0 -1
- package/dist/esm/bcm-tabs-list.entry.js +0 -82
- package/dist/esm/bcm-tabs-list.entry.js.map +0 -1
- package/dist/esm/bcm-tabs-trigger.entry.js +0 -120
- package/dist/esm/bcm-tabs-trigger.entry.js.map +0 -1
- package/dist/esm/floating-ui.dom-DxMLMJ3r.js.map +0 -1
- package/dist/esm/index-BuuGCw0z.js.map +0 -1
- package/dist/types/components/segmented-picker/segmented-picker-option.component.d.ts +0 -30
- package/dist/types/components/tabs/tabs-content.component.d.ts +0 -13
- package/dist/types/components/tabs/tabs-list.component.d.ts +0 -20
- package/dist/types/components/tabs/tabs-trigger.component.d.ts +0 -49
|
@@ -1,250 +1,381 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var index = require('./index-
|
|
4
|
-
var floatingUi_dom = require('./floating-ui.dom-
|
|
3
|
+
var index = require('./index-1Qal-onT.js');
|
|
4
|
+
var floatingUi_dom = require('./floating-ui.dom-S9nP6zZt.js');
|
|
5
5
|
var tv = require('./tv-ngpIbGlG.js');
|
|
6
6
|
|
|
7
|
-
const popConfirmCss = ".
|
|
7
|
+
const popConfirmCss = ".visible{visibility:visible}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.text-wrap{text-wrap:wrap}.border{border-width:1px}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}:host{--popover-bg:var(--bcm-ui-color-background-basic-panel);display:inline-block}[popover]{border:none;overflow:visible;padding:0}[popover]:not(:popover-open){display:none}[popover]:popover-open{opacity:1;transform:scale(1);transition:opacity .15s ease-out,transform .15s ease-out}@starting-style{[popover]:popover-open{opacity:0;transform:scale(.95)}}::slotted([slot=body]){text-wrap:pretty;font-family:Inter,sans-serif}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.bcm-ui-element{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,sans-serif}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.right-3{right:.75rem}.right-4{right:1rem}.right-6{right:1.5rem}.top-3{top:.75rem}.top-4{top:1rem}.top-6{top:1.5rem}.z-\\[9999\\]{z-index:9999}.m-0{margin:0}.inline-block{display:inline-block}.flex{display:flex}.hidden{display:none}.size-6{height:1.5rem;width:1.5rem}.h-3{height:.75rem}.w-3{width:.75rem}.max-w-64{max-width:16rem}.max-w-80{max-width:20rem}.max-w-96{max-width:24rem}.flex-1{flex:1 1 0%}.rotate-45{--tw-rotate:45deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-pointer{cursor:pointer}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.text-pretty{text-wrap:pretty}.rounded-full{border-radius:var(--bcm-ui-border-radius-full,9999px)}.rounded-lg{border-radius:var(--bcm-ui-border-radius-lg,8px)}.bg-\\[--popover-bg\\]{background-color:var(--popover-bg)}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.pr-8{padding-right:2rem}.font-sans{font-family:Inter,sans-serif}.text-size-4{font-size:var(--bcm-ui-font-size-4,14px);line-height:var(--bcm-ui-line-height-4,20px)}.text-size-5{font-size:var(--bcm-ui-font-size-5,16px);line-height:var(--bcm-ui-line-height-5,24px)}.text-size-6{font-size:var(--bcm-ui-font-size-6,18px);line-height:var(--bcm-ui-line-height-6,24px)}.text-size-7{font-size:var(--bcm-ui-font-size-7,20px);line-height:var(--bcm-ui-line-height-7,28px)}.font-semibold{font-weight:600}.\\!text-color-header{color:var(--bcm-ui-color-text-header)!important}.text-\\[var\\(--bcm-ui-color-text-error\\)\\]{color:var(--bcm-ui-color-text-error)}.text-\\[var\\(--bcm-ui-color-text-info\\)\\]{color:var(--bcm-ui-color-text-info)}.text-\\[var\\(--bcm-ui-color-text-success\\)\\]{color:var(--bcm-ui-color-text-success)}.text-\\[var\\(--bcm-ui-color-text-warning\\)\\]{color:var(--bcm-ui-color-text-warning)}.shadow{--tw-shadow:var(--bcm-ui-box-shadow-default);--tw-shadow-colored:var(--bcm-ui-box-shadow-default)}.shadow,.shadow-3{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-3{--tw-shadow:var(--bcm-ui-box-shadow-3);--tw-shadow-colored:var(--bcm-ui-box-shadow-3)}.outline{outline-style:solid}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.hover\\:bg-gray-100:hover{background-color:oklch(.967 .003 264.542)}";
|
|
8
8
|
|
|
9
|
-
// Status icons for different states
|
|
10
9
|
const statusIcons = {
|
|
11
10
|
info: 'fa-solid fa-circle-info',
|
|
12
11
|
success: 'fa-solid fa-circle-check',
|
|
13
12
|
warning: 'fa-solid fa-triangle-exclamation',
|
|
14
|
-
error: 'fa-solid fa-circle-
|
|
13
|
+
error: 'fa-solid fa-circle-xmark',
|
|
15
14
|
};
|
|
16
|
-
const
|
|
15
|
+
const BcmPopConfirm = class {
|
|
17
16
|
constructor(hostRef) {
|
|
18
17
|
index.registerInstance(this, hostRef);
|
|
18
|
+
this.bcmBeforeOpen = index.createEvent(this, "bcmBeforeOpen", 1);
|
|
19
|
+
this.bcmOpen = index.createEvent(this, "bcmOpen", 1);
|
|
20
|
+
this.bcmBeforeClose = index.createEvent(this, "bcmBeforeClose", 1);
|
|
21
|
+
this.bcmClose = index.createEvent(this, "bcmClose", 1);
|
|
19
22
|
this.bcmConfirm = index.createEvent(this, "bcmConfirm", 1);
|
|
20
23
|
this.bcmCancel = index.createEvent(this, "bcmCancel", 1);
|
|
21
|
-
/**
|
|
22
|
-
* The color of the arrow pointing to the trigger element.
|
|
23
|
-
* Can be a CSS custom property or a specific color value.
|
|
24
|
-
* @default 'var(--bcm-ui-color-background-basic-panel)'
|
|
25
|
-
*/
|
|
26
|
-
this.arrowColor = 'var(--bcm-ui-color-background-basic-panel)'; // Default color
|
|
27
|
-
/**
|
|
28
|
-
* The text displayed on the cancel button.
|
|
29
|
-
* @default 'Cancel'
|
|
30
|
-
*/
|
|
31
|
-
this.cancelText = 'Cancel';
|
|
32
|
-
/**
|
|
33
|
-
* The text displayed on the confirm button.
|
|
34
|
-
* @default 'Yes'
|
|
35
|
-
*/
|
|
36
|
-
this.confirmText = 'Yes';
|
|
37
|
-
/**
|
|
38
|
-
* The description or body content of the pop-up.
|
|
39
|
-
* @default ''
|
|
40
|
-
*/
|
|
41
|
-
this.description = '';
|
|
42
|
-
/**
|
|
43
|
-
* The header text displayed at the top of the pop-up.
|
|
44
|
-
* @default ''
|
|
45
|
-
*/
|
|
46
|
-
this.headerText = '';
|
|
47
|
-
/**
|
|
48
|
-
* The placement position of the pop-up relative to the trigger element.
|
|
49
|
-
* @default 'bottom'
|
|
50
|
-
*/
|
|
51
|
-
this.placement = 'bottom';
|
|
52
|
-
/**
|
|
53
|
-
* The size of the pop-up, determining its dimensions and padding.
|
|
54
|
-
* @default 'medium'
|
|
55
|
-
*/
|
|
56
|
-
this.size = 'medium';
|
|
57
|
-
/**
|
|
58
|
-
* The status of the pop-up, affecting its icon and color scheme.
|
|
59
|
-
* @default 'info'
|
|
60
|
-
*/
|
|
61
|
-
this.status = 'info';
|
|
62
|
-
/**
|
|
63
|
-
* Whether to display a status icon based on the `status` prop.
|
|
64
|
-
* @default true
|
|
65
|
-
*/
|
|
66
|
-
this.statusIcon = true;
|
|
67
|
-
// State variables
|
|
68
|
-
/**
|
|
69
|
-
* Indicates whether the pop-up is currently open or closed.
|
|
70
|
-
* @default false
|
|
71
|
-
*/
|
|
72
|
-
this.isOpen = false;
|
|
73
|
-
/**
|
|
74
|
-
* Handles the click event on the trigger element to open the pop-up.
|
|
75
|
-
* Prevents default behavior and propagation, then opens the pop-up if it's closed.
|
|
76
|
-
* @param event The mouse event triggering the action.
|
|
77
|
-
*/
|
|
78
|
-
this.handleTriggerClick = (event) => {
|
|
79
|
-
event.preventDefault();
|
|
80
|
-
event.stopPropagation();
|
|
81
|
-
if (!this.isOpen) {
|
|
82
|
-
this.isOpen = true;
|
|
83
|
-
requestAnimationFrame(() => {
|
|
84
|
-
this.updatePosition();
|
|
85
|
-
});
|
|
86
|
-
}
|
|
87
|
-
};
|
|
88
|
-
/**
|
|
89
|
-
* Handles the confirm button click, closing the pop-up and emitting the confirm event.
|
|
90
|
-
* Prevents default behavior and propagation.
|
|
91
|
-
* @param event The mouse event triggering the action.
|
|
92
|
-
*/
|
|
93
|
-
this.handleConfirm = (event) => {
|
|
94
|
-
event.preventDefault();
|
|
95
|
-
event.stopPropagation();
|
|
96
|
-
this.isOpen = false;
|
|
97
|
-
this.bcmConfirm.emit();
|
|
98
|
-
};
|
|
99
|
-
/**
|
|
100
|
-
* Handles the cancel button click, closing the pop-up and emitting the cancel event.
|
|
101
|
-
* Prevents default behavior and propagation.
|
|
102
|
-
* @param event The mouse event triggering the action.
|
|
103
|
-
*/
|
|
104
|
-
this.handleCancel = (event) => {
|
|
105
|
-
event.preventDefault();
|
|
106
|
-
event.stopPropagation();
|
|
107
|
-
this.isOpen = false;
|
|
108
|
-
this.bcmCancel.emit();
|
|
109
|
-
};
|
|
110
|
-
/**
|
|
111
|
-
* Updates the position of the pop-up relative to the trigger element using Floating UI.
|
|
112
|
-
* Ensures the pop-up stays within viewport bounds and positions the arrow correctly.
|
|
113
|
-
*/
|
|
114
|
-
this.updatePosition = async () => {
|
|
115
|
-
if (!this.triggerElement || !this.popoverElement || !this.arrowElement)
|
|
116
|
-
return;
|
|
117
|
-
const { x, y, placement, middlewareData } = await floatingUi_dom.computePosition(this.triggerElement, this.popoverElement, {
|
|
118
|
-
placement: this.placement,
|
|
119
|
-
middleware: [floatingUi_dom.offset(12), floatingUi_dom.flip({ fallbackPlacements: ['top', 'left', 'bottom', 'right'] }), floatingUi_dom.shift({ padding: 8 }), floatingUi_dom.arrow({ element: this.arrowElement })],
|
|
120
|
-
});
|
|
121
|
-
this.currentPlacement = placement;
|
|
122
|
-
Object.assign(this.popoverElement.style, {
|
|
123
|
-
left: `${x}px`,
|
|
124
|
-
top: `${y}px`,
|
|
125
|
-
});
|
|
126
|
-
const { x: arrowX, y: arrowY } = middlewareData.arrow || { x: 0, y: 0 };
|
|
127
|
-
const basePlacement = placement.split('-')[0];
|
|
128
|
-
const staticSide = {
|
|
129
|
-
top: 'bottom',
|
|
130
|
-
right: 'left',
|
|
131
|
-
bottom: 'top',
|
|
132
|
-
left: 'right',
|
|
133
|
-
}[basePlacement];
|
|
134
|
-
Object.assign(this.arrowElement.style, {
|
|
135
|
-
left: arrowX != null ? `${arrowX}px` : '',
|
|
136
|
-
top: arrowY != null ? `${arrowY}px` : '',
|
|
137
|
-
[staticSide]: ['top', 'bottom'].includes(basePlacement) ? '-8px' : '-12px',
|
|
138
|
-
});
|
|
139
|
-
};
|
|
140
|
-
/**
|
|
141
|
-
* Defines Tailwind Variants classes for the pop-up's structure and styling.
|
|
142
|
-
* Supports different sizes and generates dynamic class names.
|
|
143
|
-
*/
|
|
144
|
-
this.classes = tv.tv({
|
|
145
|
-
slots: {
|
|
146
|
-
container: 'absolute bcm-ui-element flex flex-col shadow-2 rounded-[--popover-radius] bg-[--popover-bg] z-[9999] w-full',
|
|
147
|
-
header: 'flex justify-between items-center',
|
|
148
|
-
headerLeftContent: 'flex items-center gap-2 text-size-inherit text-[--text-color]',
|
|
149
|
-
closeIconArea: 'flex flex-row gap-2 size-6 items-center justify-center hover:bg-gray-100 rounded-full cursor-pointer text-size-inherit',
|
|
150
|
-
titleContainer: '!text-color-header font-semibold',
|
|
151
|
-
footer: 'flex flex-row justify-end gap-2',
|
|
152
|
-
},
|
|
153
|
-
variants: {
|
|
154
|
-
size: {
|
|
155
|
-
small: {
|
|
156
|
-
container: 'text-size-4 max-w-64 p-4 gap-4',
|
|
157
|
-
header: 'text-size-4',
|
|
158
|
-
footer: 'text-size-4',
|
|
159
|
-
titleContainer: 'text-size-5',
|
|
160
|
-
headerLeftContent: 'gap-2',
|
|
161
|
-
},
|
|
162
|
-
medium: {
|
|
163
|
-
container: 'text-size-5 max-w-80 gap-6 p-6',
|
|
164
|
-
header: 'text-size-5',
|
|
165
|
-
footer: 'text-size-5',
|
|
166
|
-
titleContainer: 'text-size-6',
|
|
167
|
-
headerLeftContent: 'gap-2.5',
|
|
168
|
-
},
|
|
169
|
-
large: {
|
|
170
|
-
container: 'text-size-6 max-w-96 p-8 gap-8',
|
|
171
|
-
header: 'text-size-6',
|
|
172
|
-
footer: 'text-size-6',
|
|
173
|
-
titleContainer: 'text-size-7',
|
|
174
|
-
headerLeftContent: 'gap-3',
|
|
175
|
-
},
|
|
176
|
-
},
|
|
177
|
-
},
|
|
178
|
-
defaultVariants: {
|
|
179
|
-
size: 'medium',
|
|
180
|
-
},
|
|
181
|
-
});
|
|
182
24
|
}
|
|
25
|
+
get host() { return index.getElement(this); }
|
|
26
|
+
popconfirmRef;
|
|
27
|
+
arrowRef;
|
|
28
|
+
triggerRef;
|
|
29
|
+
cleanupAutoUpdate;
|
|
30
|
+
popconfirmId;
|
|
183
31
|
/**
|
|
184
|
-
*
|
|
185
|
-
*
|
|
32
|
+
* @prop {PopConfirmPlacement} placement - Position of the popover relative to the trigger element.
|
|
33
|
+
* Automatically flips if there's not enough space.
|
|
34
|
+
* Default: 'top'
|
|
186
35
|
*/
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
36
|
+
placement = 'top';
|
|
37
|
+
/**
|
|
38
|
+
* @prop {PopConfirmSize} size - Size variant that controls padding and text size.
|
|
39
|
+
* - 'small': Compact size with minimal padding
|
|
40
|
+
* - 'medium': Standard size
|
|
41
|
+
* - 'large': Spacious size with more padding
|
|
42
|
+
* Default: 'medium'
|
|
43
|
+
*/
|
|
44
|
+
size = 'medium';
|
|
45
|
+
/**
|
|
46
|
+
* @prop {PopConfirmStatus} status - Status type that determines the color scheme and icon.
|
|
47
|
+
* - 'info': Informational (blue)
|
|
48
|
+
* - 'success': Success/positive action (green)
|
|
49
|
+
* - 'warning': Warning/caution (yellow)
|
|
50
|
+
* - 'error': Error/destructive action (red)
|
|
51
|
+
* Default: 'info'
|
|
52
|
+
*/
|
|
53
|
+
status = 'info';
|
|
54
|
+
/**
|
|
55
|
+
* @prop {string} headerText - Text displayed in the header section.
|
|
56
|
+
* Can be overridden by using the 'header' slot.
|
|
57
|
+
* Default: ''
|
|
58
|
+
*/
|
|
59
|
+
headerText = '';
|
|
60
|
+
/**
|
|
61
|
+
* @prop {string} description - Description text displayed in the body section.
|
|
62
|
+
* Can be overridden by using the 'body' slot.
|
|
63
|
+
* Default: ''
|
|
64
|
+
*/
|
|
65
|
+
description = '';
|
|
66
|
+
/**
|
|
67
|
+
* @prop {string} confirmText - Text for the confirm button.
|
|
68
|
+
* Default: 'Yes'
|
|
69
|
+
*/
|
|
70
|
+
confirmText = 'Yes';
|
|
71
|
+
/**
|
|
72
|
+
* @prop {string} cancelText - Text for the cancel button.
|
|
73
|
+
* Default: 'Cancel'
|
|
74
|
+
*/
|
|
75
|
+
cancelText = 'Cancel';
|
|
76
|
+
/**
|
|
77
|
+
* @prop {boolean} showArrow - Whether to show the arrow pointing to the trigger.
|
|
78
|
+
* Default: true
|
|
79
|
+
*/
|
|
80
|
+
showArrow = true;
|
|
81
|
+
/**
|
|
82
|
+
* @prop {boolean} statusIcon - Whether to show the status icon in the header.
|
|
83
|
+
* Icon only shows if headerText is also provided.
|
|
84
|
+
* Default: true
|
|
85
|
+
*/
|
|
86
|
+
statusIcon = true;
|
|
87
|
+
/**
|
|
88
|
+
* @prop {number} offsetDistance - Distance in pixels between the popover and trigger element.
|
|
89
|
+
* Default: 12
|
|
90
|
+
*/
|
|
91
|
+
offsetDistance = 12;
|
|
92
|
+
/**
|
|
93
|
+
* @prop {boolean} closeOnOutsideClick - Whether to close when clicking outside the popover.
|
|
94
|
+
* Default: true
|
|
95
|
+
*/
|
|
96
|
+
closeOnOutsideClick = true;
|
|
97
|
+
/**
|
|
98
|
+
* @prop {boolean} closeOnEscape - Whether to close when pressing the Escape key.
|
|
99
|
+
* Default: true
|
|
100
|
+
*/
|
|
101
|
+
closeOnEscape = true;
|
|
102
|
+
isOpen = false;
|
|
103
|
+
/**
|
|
104
|
+
* @event bcmBeforeOpen - Emitted before the popover opens.
|
|
105
|
+
* Useful for performing actions before the popover becomes visible.
|
|
106
|
+
*/
|
|
107
|
+
bcmBeforeOpen;
|
|
108
|
+
/**
|
|
109
|
+
* @event bcmOpen - Emitted when the popover is opened.
|
|
110
|
+
* Useful for tracking when the popover becomes visible.
|
|
111
|
+
*/
|
|
112
|
+
bcmOpen;
|
|
113
|
+
/**
|
|
114
|
+
* @event bcmBeforeClose - Emitted before the popover closes.
|
|
115
|
+
* Useful for performing cleanup actions before hiding.
|
|
116
|
+
*/
|
|
117
|
+
bcmBeforeClose;
|
|
118
|
+
/**
|
|
119
|
+
* @event bcmClose - Emitted when the popover is closed.
|
|
120
|
+
* Useful for tracking when the popover is hidden.
|
|
121
|
+
*/
|
|
122
|
+
bcmClose;
|
|
123
|
+
/**
|
|
124
|
+
* @event bcmConfirm - Emitted when the user clicks the confirm button.
|
|
125
|
+
* This is where you should handle the confirmed action.
|
|
126
|
+
*/
|
|
127
|
+
bcmConfirm;
|
|
128
|
+
/**
|
|
129
|
+
* @event bcmCancel - Emitted when the user clicks cancel, presses Escape, or clicks outside.
|
|
130
|
+
* Useful for tracking when the user dismisses the confirmation.
|
|
131
|
+
*/
|
|
132
|
+
bcmCancel;
|
|
133
|
+
async handleOpenChange(open) {
|
|
134
|
+
if (!this.popconfirmRef)
|
|
191
135
|
return;
|
|
136
|
+
if (open) {
|
|
137
|
+
this.popconfirmRef.showPopover();
|
|
138
|
+
await new Promise(resolve => requestAnimationFrame(() => resolve(undefined)));
|
|
139
|
+
await this.updatePosition();
|
|
140
|
+
this.startAutoUpdate();
|
|
141
|
+
this.bcmOpen.emit();
|
|
142
|
+
// Add outside click listener after a frame to avoid immediate close
|
|
143
|
+
if (this.closeOnOutsideClick) {
|
|
144
|
+
requestAnimationFrame(() => {
|
|
145
|
+
document.addEventListener('click', this.handleOutsideClick);
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
else {
|
|
150
|
+
this.popconfirmRef.hidePopover();
|
|
151
|
+
this.stopAutoUpdate();
|
|
152
|
+
this.bcmClose.emit();
|
|
153
|
+
document.removeEventListener('click', this.handleOutsideClick);
|
|
192
154
|
}
|
|
193
|
-
this.triggerElement.addEventListener('click', this.handleTriggerClick);
|
|
194
155
|
}
|
|
195
156
|
/**
|
|
196
|
-
* Programmatically shows the
|
|
197
|
-
* @returns
|
|
157
|
+
* Programmatically shows the popconfirm.
|
|
158
|
+
* @returns Promise that resolves when the show operation begins
|
|
198
159
|
*/
|
|
199
160
|
async show() {
|
|
161
|
+
if (this.isOpen)
|
|
162
|
+
return;
|
|
163
|
+
this.bcmBeforeOpen.emit();
|
|
200
164
|
this.isOpen = true;
|
|
201
|
-
requestAnimationFrame(() => {
|
|
202
|
-
this.updatePosition();
|
|
203
|
-
});
|
|
204
165
|
}
|
|
205
166
|
/**
|
|
206
|
-
* Programmatically hides the
|
|
207
|
-
* @returns
|
|
167
|
+
* Programmatically hides the popconfirm.
|
|
168
|
+
* @returns Promise that resolves when the hide operation begins
|
|
208
169
|
*/
|
|
209
170
|
async hide() {
|
|
171
|
+
if (!this.isOpen)
|
|
172
|
+
return;
|
|
173
|
+
this.bcmBeforeClose.emit();
|
|
210
174
|
this.isOpen = false;
|
|
211
175
|
}
|
|
212
176
|
/**
|
|
213
|
-
*
|
|
214
|
-
*
|
|
177
|
+
* Toggles the popconfirm visibility.
|
|
178
|
+
* If open, it will close. If closed, it will open.
|
|
179
|
+
* @returns Promise that resolves when the toggle operation completes
|
|
215
180
|
*/
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
181
|
+
async toggle() {
|
|
182
|
+
if (this.isOpen) {
|
|
183
|
+
await this.hide();
|
|
184
|
+
}
|
|
185
|
+
else {
|
|
186
|
+
await this.show();
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
startAutoUpdate() {
|
|
190
|
+
if (!this.triggerRef || !this.popconfirmRef)
|
|
191
|
+
return;
|
|
192
|
+
this.cleanupAutoUpdate = floatingUi_dom.autoUpdate(this.triggerRef, this.popconfirmRef, () => this.updatePosition(), {
|
|
193
|
+
ancestorScroll: true,
|
|
194
|
+
ancestorResize: true,
|
|
195
|
+
elementResize: true,
|
|
196
|
+
layoutShift: true,
|
|
197
|
+
});
|
|
198
|
+
}
|
|
199
|
+
stopAutoUpdate() {
|
|
200
|
+
if (this.cleanupAutoUpdate) {
|
|
201
|
+
this.cleanupAutoUpdate();
|
|
202
|
+
this.cleanupAutoUpdate = undefined;
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
async updatePosition() {
|
|
206
|
+
if (!this.triggerRef || !this.popconfirmRef)
|
|
207
|
+
return;
|
|
208
|
+
const middleware = [floatingUi_dom.offset(this.offsetDistance), floatingUi_dom.flip(), floatingUi_dom.shift({ padding: 8 })];
|
|
209
|
+
if (this.showArrow && this.arrowRef) {
|
|
210
|
+
middleware.push(floatingUi_dom.arrow({ element: this.arrowRef }));
|
|
211
|
+
}
|
|
212
|
+
const virtualElement = {
|
|
213
|
+
getBoundingClientRect: () => this.triggerRef.getBoundingClientRect(),
|
|
220
214
|
};
|
|
215
|
+
const { x, y, placement, middlewareData } = await floatingUi_dom.computePosition(virtualElement, this.popconfirmRef, {
|
|
216
|
+
placement: this.placement,
|
|
217
|
+
strategy: 'fixed',
|
|
218
|
+
middleware,
|
|
219
|
+
});
|
|
220
|
+
this.popconfirmRef.style.left = `${x}px`;
|
|
221
|
+
this.popconfirmRef.style.top = `${y}px`;
|
|
222
|
+
if (this.showArrow && this.arrowRef && middlewareData.arrow) {
|
|
223
|
+
const { x: arrowX, y: arrowY } = middlewareData.arrow;
|
|
224
|
+
const side = placement.split('-')[0];
|
|
225
|
+
const staticSide = {
|
|
226
|
+
top: 'bottom',
|
|
227
|
+
right: 'left',
|
|
228
|
+
bottom: 'top',
|
|
229
|
+
left: 'right',
|
|
230
|
+
}[side];
|
|
231
|
+
Object.assign(this.arrowRef.style, {
|
|
232
|
+
left: arrowX != null ? `${arrowX}px` : '',
|
|
233
|
+
top: arrowY != null ? `${arrowY}px` : '',
|
|
234
|
+
right: '',
|
|
235
|
+
bottom: '',
|
|
236
|
+
[staticSide]: '-4px',
|
|
237
|
+
});
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
handleSlotChange = () => {
|
|
241
|
+
const slot = this.host.shadowRoot?.querySelector('slot:not([name])');
|
|
242
|
+
if (!slot)
|
|
243
|
+
return;
|
|
244
|
+
const elements = slot.assignedElements();
|
|
245
|
+
const assignedElement = elements[0];
|
|
246
|
+
this.triggerRef = (assignedElement || this.host);
|
|
247
|
+
if (!this.triggerRef)
|
|
248
|
+
return;
|
|
249
|
+
if (this.popconfirmRef && this.popconfirmId) {
|
|
250
|
+
this.triggerRef.setAttribute('aria-describedby', this.popconfirmId);
|
|
251
|
+
}
|
|
252
|
+
this.removeTriggerListeners();
|
|
253
|
+
this.setupTriggerListeners();
|
|
254
|
+
};
|
|
255
|
+
setupTriggerListeners() {
|
|
256
|
+
if (!this.triggerRef)
|
|
257
|
+
return;
|
|
258
|
+
this.triggerRef.addEventListener('click', this.handleTriggerClick);
|
|
259
|
+
}
|
|
260
|
+
removeTriggerListeners() {
|
|
261
|
+
if (!this.triggerRef)
|
|
262
|
+
return;
|
|
263
|
+
this.triggerRef.removeEventListener('click', this.handleTriggerClick);
|
|
264
|
+
}
|
|
265
|
+
handleTriggerClick = () => {
|
|
266
|
+
this.toggle();
|
|
267
|
+
};
|
|
268
|
+
handleOutsideClick = (e) => {
|
|
269
|
+
if (!this.closeOnOutsideClick || !this.isOpen)
|
|
270
|
+
return;
|
|
271
|
+
const target = e.target;
|
|
272
|
+
if (!this.host.contains(target) && !this.popconfirmRef?.contains(target)) {
|
|
273
|
+
this.handleCancel();
|
|
274
|
+
}
|
|
275
|
+
};
|
|
276
|
+
handleKeyDown(e) {
|
|
277
|
+
if (!this.closeOnEscape || !this.isOpen)
|
|
278
|
+
return;
|
|
279
|
+
if (e.key === 'Escape') {
|
|
280
|
+
// Check if this is the topmost open popconfirm
|
|
281
|
+
const openPopconfirms = Array.from(document.querySelectorAll('bcm-pop-confirm')).filter(el => {
|
|
282
|
+
const popconfirmEl = el.shadowRoot?.querySelector('[popover]');
|
|
283
|
+
return popconfirmEl?.matches(':popover-open');
|
|
284
|
+
});
|
|
285
|
+
const topPopconfirm = openPopconfirms[openPopconfirms.length - 1];
|
|
286
|
+
if (topPopconfirm === this.host) {
|
|
287
|
+
e.preventDefault();
|
|
288
|
+
e.stopPropagation();
|
|
289
|
+
this.handleCancel();
|
|
290
|
+
}
|
|
291
|
+
}
|
|
292
|
+
}
|
|
293
|
+
handleToggle = (e) => {
|
|
294
|
+
const toggleEvent = e;
|
|
295
|
+
if (toggleEvent.newState === 'open' && !this.isOpen) {
|
|
296
|
+
this.isOpen = true;
|
|
297
|
+
}
|
|
298
|
+
else if (toggleEvent.newState === 'closed' && this.isOpen) {
|
|
299
|
+
this.isOpen = false;
|
|
300
|
+
}
|
|
301
|
+
};
|
|
302
|
+
handleConfirm = () => {
|
|
303
|
+
this.bcmConfirm.emit();
|
|
304
|
+
this.hide();
|
|
305
|
+
};
|
|
306
|
+
handleCancel = () => {
|
|
307
|
+
this.bcmCancel.emit();
|
|
308
|
+
this.hide();
|
|
309
|
+
};
|
|
310
|
+
componentWillLoad() {
|
|
311
|
+
this.popconfirmId = `popconfirm-${Math.random().toString(36).substring(2, 11)}`;
|
|
312
|
+
}
|
|
313
|
+
componentDidLoad() {
|
|
314
|
+
if (this.popconfirmRef) {
|
|
315
|
+
this.popconfirmRef.addEventListener('toggle', this.handleToggle);
|
|
316
|
+
}
|
|
221
317
|
}
|
|
222
|
-
/**
|
|
223
|
-
* Lifecycle method called when the component is removed from the DOM.
|
|
224
|
-
* Cleans up the event listener to prevent memory leaks.
|
|
225
|
-
*/
|
|
226
318
|
disconnectedCallback() {
|
|
227
|
-
|
|
228
|
-
|
|
319
|
+
this.stopAutoUpdate();
|
|
320
|
+
this.removeTriggerListeners();
|
|
321
|
+
document.removeEventListener('click', this.handleOutsideClick);
|
|
322
|
+
if (this.popconfirmRef) {
|
|
323
|
+
this.popconfirmRef.removeEventListener('toggle', this.handleToggle);
|
|
229
324
|
}
|
|
230
325
|
}
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
326
|
+
popconfirmClass = tv.tv({
|
|
327
|
+
slots: {
|
|
328
|
+
container: 'bcm-ui-element fixed m-0 flex flex-col bg-[--popover-bg] rounded-lg shadow-3 z-[9999]',
|
|
329
|
+
arrow: 'absolute w-3 h-3 bg-[--popover-bg] rotate-45',
|
|
330
|
+
closeBtn: 'absolute flex size-6 items-center justify-center hover:bg-gray-100 rounded-full cursor-pointer text-color-muted',
|
|
331
|
+
header: 'flex items-center pr-8',
|
|
332
|
+
headerLeft: 'flex items-center gap-2',
|
|
333
|
+
title: '!text-color-header font-semibold',
|
|
334
|
+
body: 'flex-1 font-sans text-pretty',
|
|
335
|
+
footer: 'flex flex-row justify-end gap-2',
|
|
336
|
+
},
|
|
337
|
+
variants: {
|
|
338
|
+
size: {
|
|
339
|
+
small: {
|
|
340
|
+
container: 'text-size-4 max-w-64 p-4 gap-4',
|
|
341
|
+
title: 'text-size-5',
|
|
342
|
+
closeBtn: 'top-3 right-3',
|
|
343
|
+
},
|
|
344
|
+
medium: {
|
|
345
|
+
container: 'text-size-5 max-w-80 p-6 gap-6',
|
|
346
|
+
title: 'text-size-6',
|
|
347
|
+
closeBtn: 'top-4 right-4',
|
|
348
|
+
},
|
|
349
|
+
large: {
|
|
350
|
+
container: 'text-size-6 max-w-96 p-8 gap-8',
|
|
351
|
+
title: 'text-size-7',
|
|
352
|
+
closeBtn: 'top-6 right-6',
|
|
353
|
+
},
|
|
354
|
+
},
|
|
355
|
+
status: {
|
|
356
|
+
info: { headerLeft: 'text-[var(--bcm-ui-color-text-info)]' },
|
|
357
|
+
success: { headerLeft: 'text-[var(--bcm-ui-color-text-success)]' },
|
|
358
|
+
warning: { headerLeft: 'text-[var(--bcm-ui-color-text-warning)]' },
|
|
359
|
+
error: { headerLeft: 'text-[var(--bcm-ui-color-text-error)]' },
|
|
360
|
+
},
|
|
361
|
+
},
|
|
362
|
+
});
|
|
236
363
|
render() {
|
|
237
|
-
|
|
238
|
-
const { container, header, footer, headerLeftContent, closeIconArea, titleContainer } = this.classes({
|
|
364
|
+
const { container, arrow: arrowClass, header, headerLeft, title, closeBtn, body, footer } = this.popconfirmClass({
|
|
239
365
|
size: this.size,
|
|
366
|
+
status: this.status,
|
|
240
367
|
});
|
|
241
|
-
|
|
368
|
+
// Only show header if there's actual header content (headerText or custom header slot)
|
|
369
|
+
// Status icon only shows if explicitly enabled AND there's header text
|
|
370
|
+
const showStatusIcon = this.statusIcon && this.headerText;
|
|
371
|
+
const hasHeaderText = Boolean(this.headerText);
|
|
372
|
+
return (index.h("div", { key: '7329eb6db100b57368ca73b36a2a2ad66b218b8e', class: "inline-block" }, index.h("slot", { key: '0d775cf4a00b4ef97e8e75e2620ddf420caf43c6', onSlotchange: this.handleSlotChange }), index.h("div", { key: '19c4c001fbf51b895a45b271365b3a7cb22590bb', ref: el => (this.popconfirmRef = el), id: this.popconfirmId, part: "container", class: container(), popover: "manual", role: "alertdialog", "aria-labelledby": hasHeaderText ? `${this.popconfirmId}-header` : undefined, "aria-describedby": `${this.popconfirmId}-body` }, this.showArrow && index.h("div", { key: '91aaa976265c10537cea1d0d57d08df27c838645', ref: el => (this.arrowRef = el), part: "arrow", class: arrowClass() }), index.h("div", { key: '91a049dd52d47d267d11c8e8c628aa417fb40663', class: closeBtn(), onClick: this.handleCancel, role: "button", tabIndex: 0, "aria-label": "Close" }, index.h("bcm-icon", { key: 'd15fb5922185f246c15e9480c3a4652ef9e96ffa', "icon-name": "far fa-times" })), index.h("header", { key: 'b62f81fd72a05aa116ecad7614f20645aa85f060', class: header() }, index.h("div", { key: '226cbb6ac92d294b67eb0c33ed0faea52d56689a', class: headerLeft() }, showStatusIcon && index.h("bcm-icon", { key: '0e5cd64e8369876b9016af3c9607cdb406828651', "icon-name": statusIcons[this.status] }), hasHeaderText && (index.h("span", { key: '4a1cf44acf56bc46ad52fda1d1d29da0c838fded', id: `${this.popconfirmId}-header`, class: title() }, this.headerText)), index.h("slot", { key: '5e159545f0b12d97c9b632653955f636866c2a14', name: "header" }))), index.h("main", { key: '6e082c73048583a1447dc4fb7c9940a677e7d587', id: `${this.popconfirmId}-body`, part: "body", class: body() }, index.h("slot", { key: '6d0546a06ca77118d82074fffb9164c4b4f86a5c', name: "body" }, this.description)), index.h("footer", { key: '4f36400e44847e31d6ceed5fd7f47d35f68af458', part: "footer", class: footer() }, index.h("slot", { key: '97b85bb7dd3d39790b91e6bffef01f7eb077c2c3', name: "footer" }, index.h("bcm-button", { key: '8e8b7175a1dd9e069e9cbca7b430fdc1e9a7beab', kind: "outline", size: this.size, onClick: this.handleCancel }, this.cancelText), index.h("bcm-button", { key: 'ae9daeacaf77c8abfe92951eefe2e885d23eab79', size: this.size, status: this.status, kind: "primary", onClick: this.handleConfirm }, this.confirmText))))));
|
|
242
373
|
}
|
|
243
|
-
get
|
|
374
|
+
static get watchers() { return {
|
|
375
|
+
"isOpen": ["handleOpenChange"]
|
|
376
|
+
}; }
|
|
244
377
|
};
|
|
245
|
-
|
|
378
|
+
BcmPopConfirm.style = popConfirmCss;
|
|
246
379
|
|
|
247
|
-
exports.bcm_pop_confirm =
|
|
380
|
+
exports.bcm_pop_confirm = BcmPopConfirm;
|
|
248
381
|
//# sourceMappingURL=bcm-pop-confirm.entry.cjs.js.map
|
|
249
|
-
|
|
250
|
-
//# sourceMappingURL=bcm-pop-confirm.cjs.entry.js.map
|