q2-tecton-elements 1.13.0-alpha.0 → 1.13.2
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/click-elsewhere.cjs.entry.js +5 -7
- package/dist/cjs/{icons-4595ee47.js → icons-08ffe5c9.js} +394 -384
- package/dist/cjs/{index-c2e53804.js → index-7febb200.js} +112 -65
- package/dist/cjs/{index-a55d3c34.js → index-dd823ee6.js} +27 -14
- package/dist/cjs/loader.cjs.js +3 -3
- package/dist/cjs/q2-avatar.cjs.entry.js +2 -2
- package/dist/cjs/q2-badge.cjs.entry.js +43 -0
- package/dist/cjs/q2-btn_2.cjs.entry.js +13 -13
- package/dist/cjs/q2-calendar.cjs.entry.js +54 -59
- package/dist/cjs/q2-card.cjs.entry.js +127 -0
- package/dist/cjs/q2-carousel-pane.cjs.entry.js +5 -5
- package/dist/cjs/q2-carousel.cjs.entry.js +318 -106
- package/dist/cjs/q2-checkbox-group.cjs.entry.js +6 -3
- package/dist/cjs/q2-checkbox.cjs.entry.js +19 -11
- package/dist/cjs/q2-dropdown-item.cjs.entry.js +7 -7
- package/dist/cjs/q2-dropdown.cjs.entry.js +8 -17
- package/dist/cjs/q2-editable-field.cjs.entry.js +5 -8
- package/dist/cjs/q2-icon.cjs.entry.js +3 -3
- package/dist/cjs/q2-input.cjs.entry.js +439 -437
- package/dist/cjs/q2-loading-element.cjs.entry.js +3 -3
- package/dist/cjs/q2-loc.cjs.entry.js +2 -2
- package/dist/cjs/q2-message.cjs.entry.js +5 -5
- package/dist/cjs/q2-optgroup.cjs.entry.js +3 -3
- package/dist/cjs/q2-option-list.cjs.entry.js +359 -0
- package/dist/cjs/q2-option.cjs.entry.js +3 -11
- package/dist/cjs/q2-pagination.cjs.entry.js +116 -0
- package/dist/cjs/q2-pill.cjs.entry.js +137 -0
- package/dist/cjs/q2-radio-group.cjs.entry.js +43 -18
- package/dist/cjs/q2-radio.cjs.entry.js +21 -4
- package/dist/cjs/q2-section.cjs.entry.js +5 -7
- package/dist/cjs/q2-select.cjs.entry.js +36 -31
- package/dist/cjs/q2-stepper-pane.cjs.entry.js +42 -4
- package/dist/cjs/q2-stepper-vertical.cjs.entry.js +278 -0
- package/dist/cjs/q2-stepper.cjs.entry.js +10 -12
- package/dist/cjs/q2-tab-container.cjs.entry.js +12 -8
- package/dist/cjs/q2-tab-pane.cjs.entry.js +1 -1
- package/dist/cjs/q2-tag.cjs.entry.js +94 -0
- package/dist/cjs/q2-tecton-elements.cjs.js +3 -3
- package/dist/cjs/q2-textarea.cjs.entry.js +8 -8
- package/dist/cjs/{shapes-086c0365.js → shapes-305746b5.js} +9 -16
- package/dist/cjs/tecton-tab-pane.cjs.entry.js +2 -5
- package/dist/collection/collection-manifest.json +10 -3
- package/dist/collection/components/click-elsewhere/index.js +4 -6
- package/dist/collection/components/q2-badge/index.js +148 -0
- package/dist/collection/components/q2-badge/styles.css +134 -0
- package/dist/collection/components/q2-btn/index.js +14 -14
- package/dist/collection/components/q2-btn/styles.css +1 -1
- package/dist/collection/components/q2-calendar/helpers.js +22 -20
- package/dist/collection/components/q2-calendar/index.js +45 -37
- package/dist/collection/components/q2-calendar/validation.js +4 -2
- package/dist/collection/components/q2-card/index.js +347 -0
- package/dist/collection/components/q2-card/styles.css +177 -0
- package/dist/collection/components/q2-carousel/index.js +11 -16
- package/dist/collection/components/q2-carousel/styles.css +3 -3
- package/dist/collection/components/q2-carousel-pane/index.js +2 -2
- package/dist/collection/components/q2-carousel-pane/styles.css +8 -3
- package/dist/collection/components/q2-checkbox/index.js +36 -11
- package/dist/collection/components/q2-checkbox/styles.css +1 -0
- package/dist/collection/components/q2-checkbox-group/index.js +22 -1
- package/dist/collection/components/q2-dropdown/index.js +6 -15
- package/dist/collection/components/q2-dropdown-item/index.js +5 -5
- package/dist/collection/components/q2-editable-field/index.js +3 -6
- package/dist/collection/components/q2-icon/icons.js +393 -383
- package/dist/collection/components/q2-input/formatting/credit-card.js +15 -13
- package/dist/collection/components/q2-input/formatting/currency.js +162 -162
- package/dist/collection/components/q2-input/formatting/date.js +1 -1
- package/dist/collection/components/q2-input/formatting/generic.js +7 -8
- package/dist/collection/components/q2-input/formatting/number.js +6 -9
- package/dist/collection/components/q2-input/formatting/numeric.js +5 -5
- package/dist/collection/components/q2-input/formatting/phone.js +215 -215
- package/dist/collection/components/q2-input/formatting/postal.js +1 -1
- package/dist/collection/components/q2-input/index.js +81 -25
- package/dist/collection/components/q2-input/styles.css +19 -14
- package/dist/collection/components/q2-loading/index.js +4 -4
- package/dist/collection/components/q2-loading/skeleton/q2-loading-element/index.js +1 -1
- package/dist/collection/components/q2-loading/skeleton/shapes.js +8 -15
- package/dist/collection/components/q2-message/index.js +3 -3
- package/dist/collection/components/q2-optgroup/index.js +1 -1
- package/dist/collection/components/q2-option/index.js +19 -25
- package/dist/collection/components/q2-option/styles.css +5 -0
- package/dist/collection/components/q2-option-list/index.js +648 -0
- package/dist/collection/components/q2-option-list/styles.css +128 -0
- package/dist/collection/components/q2-pagination/index.js +275 -0
- package/dist/collection/components/q2-pagination/styles.css +120 -0
- package/dist/collection/components/q2-pill/index.js +324 -0
- package/dist/collection/components/q2-pill/styles.css +229 -0
- package/dist/collection/components/q2-radio/index.js +38 -1
- package/dist/collection/components/q2-radio-group/index.js +66 -24
- package/dist/collection/components/q2-section/index.js +5 -7
- package/dist/collection/components/q2-select/index.js +53 -30
- package/dist/collection/components/q2-stepper/index.js +8 -10
- package/dist/collection/components/q2-stepper/styles.css +5 -5
- package/dist/collection/components/q2-stepper-pane/index.js +133 -5
- package/dist/collection/components/q2-stepper-vertical/index.js +346 -0
- package/dist/collection/components/q2-stepper-vertical/styles.css +273 -0
- package/dist/collection/components/q2-tab-container/index.js +11 -7
- package/dist/collection/components/q2-tag/index.js +200 -0
- package/dist/collection/components/q2-tag/styles.css +141 -0
- package/dist/collection/components/q2-textarea/index.js +6 -6
- package/dist/collection/components/tecton-tab-pane/index.js +3 -10
- package/dist/collection/utils/index.js +25 -13
- package/dist/esm/click-elsewhere.entry.js +5 -7
- package/dist/esm/{icons-3ee662ea.js → icons-b1e11526.js} +394 -384
- package/dist/esm/{index-ec6660af.js → index-0ff8de52.js} +27 -15
- package/dist/esm/{index-be8376c0.js → index-dbfb3ecc.js} +112 -65
- package/dist/esm/loader.js +3 -3
- package/dist/esm/polyfills/css-shim.js +1 -1
- package/dist/esm/q2-avatar.entry.js +2 -2
- package/dist/esm/q2-badge.entry.js +39 -0
- package/dist/esm/q2-btn_2.entry.js +13 -13
- package/dist/esm/q2-calendar.entry.js +54 -59
- package/dist/esm/q2-card.entry.js +123 -0
- package/dist/esm/q2-carousel-pane.entry.js +5 -5
- package/dist/esm/q2-carousel.entry.js +318 -106
- package/dist/esm/q2-checkbox-group.entry.js +6 -3
- package/dist/esm/q2-checkbox.entry.js +19 -11
- package/dist/esm/q2-dropdown-item.entry.js +7 -7
- package/dist/esm/q2-dropdown.entry.js +8 -17
- package/dist/esm/q2-editable-field.entry.js +5 -8
- package/dist/esm/q2-icon.entry.js +3 -3
- package/dist/esm/q2-input.entry.js +439 -437
- package/dist/esm/q2-loading-element.entry.js +3 -3
- package/dist/esm/q2-loc.entry.js +2 -2
- package/dist/esm/q2-message.entry.js +5 -5
- package/dist/esm/q2-optgroup.entry.js +3 -3
- package/dist/esm/q2-option-list.entry.js +355 -0
- package/dist/esm/q2-option.entry.js +3 -11
- package/dist/esm/q2-pagination.entry.js +112 -0
- package/dist/esm/q2-pill.entry.js +133 -0
- package/dist/esm/q2-radio-group.entry.js +43 -18
- package/dist/esm/q2-radio.entry.js +21 -4
- package/dist/esm/q2-section.entry.js +5 -7
- package/dist/esm/q2-select.entry.js +36 -31
- package/dist/esm/q2-stepper-pane.entry.js +42 -4
- package/dist/esm/q2-stepper-vertical.entry.js +274 -0
- package/dist/esm/q2-stepper.entry.js +10 -12
- package/dist/esm/q2-tab-container.entry.js +12 -8
- package/dist/esm/q2-tab-pane.entry.js +1 -1
- package/dist/esm/q2-tag.entry.js +90 -0
- package/dist/esm/q2-tecton-elements.js +3 -3
- package/dist/esm/q2-textarea.entry.js +8 -8
- package/dist/esm/{shapes-81c11dfe.js → shapes-cff4e1f0.js} +9 -16
- package/dist/esm/tecton-tab-pane.entry.js +2 -5
- package/dist/loader/index.d.ts +0 -1
- package/dist/q2-tecton-elements/{p-75e87cca.entry.js → p-00e8f782.entry.js} +1 -1
- package/dist/q2-tecton-elements/p-01ae8461.entry.js +1 -0
- package/dist/q2-tecton-elements/p-0900bec1.entry.js +1 -0
- package/dist/q2-tecton-elements/p-10264ecb.entry.js +1 -0
- package/dist/q2-tecton-elements/{p-fbf7c5e6.entry.js → p-1305ec5f.entry.js} +1 -1
- package/dist/q2-tecton-elements/p-148391d6.entry.js +1 -0
- package/dist/q2-tecton-elements/p-1dfaee64.entry.js +1 -0
- package/dist/q2-tecton-elements/{p-32ad664c.entry.js → p-221abbf6.entry.js} +1 -1
- package/dist/q2-tecton-elements/{p-c90a6016.js → p-255b2b4c.js} +1 -1
- package/dist/q2-tecton-elements/p-27736b6b.entry.js +1 -0
- package/dist/q2-tecton-elements/p-2846ab94.entry.js +1 -0
- package/dist/q2-tecton-elements/p-2bc1de01.entry.js +1 -0
- package/dist/q2-tecton-elements/{p-8ea2c4f7.entry.js → p-2c15414c.entry.js} +1 -1
- package/dist/q2-tecton-elements/p-2caa89fd.js +1 -0
- package/dist/q2-tecton-elements/p-327cca41.entry.js +1 -0
- package/dist/q2-tecton-elements/p-3a420dbf.entry.js +1 -0
- package/dist/q2-tecton-elements/p-3abcb09d.entry.js +1 -0
- package/dist/q2-tecton-elements/p-3fe98e3e.entry.js +1 -0
- package/dist/q2-tecton-elements/{p-bb2e110a.entry.js → p-430a979b.entry.js} +1 -1
- package/dist/q2-tecton-elements/{p-7e6fc65d.entry.js → p-45eb7739.entry.js} +1 -1
- package/dist/q2-tecton-elements/{p-750bcd33.entry.js → p-49b2abc4.entry.js} +1 -1
- package/dist/q2-tecton-elements/{p-9b50c3c3.entry.js → p-4ab30466.entry.js} +1 -1
- package/dist/q2-tecton-elements/p-5bbf2bfe.entry.js +1 -0
- package/dist/q2-tecton-elements/{p-ac859fcc.entry.js → p-6fec9235.entry.js} +1 -1
- package/dist/q2-tecton-elements/p-824aebd9.js +1 -0
- package/dist/q2-tecton-elements/p-a4ae89cc.entry.js +1 -0
- package/dist/q2-tecton-elements/{p-50967020.entry.js → p-a5562aaa.entry.js} +1 -1
- package/dist/q2-tecton-elements/p-ae130f70.entry.js +1 -0
- package/dist/q2-tecton-elements/p-b2302cd3.entry.js +1 -0
- package/dist/q2-tecton-elements/p-c20cbb2d.entry.js +1 -0
- package/dist/q2-tecton-elements/p-ca7a3380.entry.js +1 -0
- package/dist/q2-tecton-elements/{p-a6f8d09a.entry.js → p-d33e152c.entry.js} +1 -1
- package/dist/q2-tecton-elements/{p-9024859f.entry.js → p-d5218cd6.entry.js} +1 -1
- package/dist/q2-tecton-elements/p-d52b435e.entry.js +1 -0
- package/dist/q2-tecton-elements/p-dd02cf8d.js +1 -0
- package/dist/q2-tecton-elements/{p-07a5d703.entry.js → p-e0e7ae8b.entry.js} +1 -1
- package/dist/q2-tecton-elements/{p-7e030e92.entry.js → p-ede12fc1.entry.js} +1 -1
- package/dist/q2-tecton-elements/{p-df182f61.entry.js → p-fdfbe75b.entry.js} +1 -1
- package/dist/q2-tecton-elements/p-ffbded54.entry.js +1 -0
- package/dist/q2-tecton-elements/q2-tecton-elements.esm.js +1 -1
- package/dist/test/elements/q2-tag-test.js +151 -0
- package/dist/test/helpers.js +20 -9
- package/dist/types/components/q2-badge/index.d.ts +13 -0
- package/dist/types/components/q2-btn/index.d.ts +3 -3
- package/dist/types/components/q2-calendar/helpers.d.ts +1 -0
- package/dist/types/components/q2-calendar/index.d.ts +2 -1
- package/dist/types/components/q2-calendar/validation.d.ts +1 -1
- package/dist/types/components/q2-card/index.d.ts +35 -0
- package/dist/types/components/q2-checkbox/index.d.ts +3 -1
- package/dist/types/components/q2-checkbox-group/index.d.ts +1 -0
- package/dist/types/components/q2-dropdown/index.d.ts +1 -1
- package/dist/types/components/q2-editable-field/index.d.ts +1 -1
- package/dist/types/components/q2-input/formatting/credit-card.d.ts +1 -3
- package/dist/types/components/q2-input/index.d.ts +5 -2
- package/dist/types/components/q2-option/index.d.ts +2 -3
- package/dist/types/components/q2-option-list/index.d.ts +62 -0
- package/dist/types/components/q2-pagination/index.d.ts +30 -0
- package/dist/types/components/q2-pill/index.d.ts +39 -0
- package/dist/types/components/q2-radio/index.d.ts +4 -1
- package/dist/types/components/q2-radio-group/index.d.ts +5 -1
- package/dist/types/components/q2-select/index.d.ts +2 -1
- package/dist/types/components/q2-stepper/index.d.ts +1 -1
- package/dist/types/components/q2-stepper-pane/index.d.ts +16 -1
- package/dist/types/components/q2-stepper-vertical/index.d.ts +52 -0
- package/dist/types/components/q2-tab-container/index.d.ts +1 -1
- package/dist/types/components/q2-tag/index.d.ts +28 -0
- package/dist/types/components/tecton-tab-pane/index.d.ts +2 -2
- package/dist/types/components.d.ts +235 -11
- package/dist/types/global.d.ts +1 -0
- package/dist/types/stencil-public-runtime.d.ts +6 -4
- package/dist/types/util.d.ts +2 -10
- package/dist/types/utils/index.d.ts +1 -0
- package/dist/types/workspace/workspace/tecton-production_release_1.13.x/packages/q2-tecton-elements/.stencil/test/elements/q2-tag-test.d.ts +1 -0
- package/dist/types/workspace/workspace/{_production_release_1.11.0-alpha → tecton-production_release_1.13.x}/packages/q2-tecton-elements/.stencil/test/helpers.d.ts +6 -3
- package/package.json +13 -13
- package/dist/q2-tecton-elements/p-06fff43d.entry.js +0 -1
- package/dist/q2-tecton-elements/p-080839ed.js +0 -1
- package/dist/q2-tecton-elements/p-29a37091.entry.js +0 -1
- package/dist/q2-tecton-elements/p-37aba2a4.js +0 -1
- package/dist/q2-tecton-elements/p-4cd00f1a.js +0 -1
- package/dist/q2-tecton-elements/p-6702eb4d.entry.js +0 -1
- package/dist/q2-tecton-elements/p-768e3a5d.entry.js +0 -1
- package/dist/q2-tecton-elements/p-843b1ee9.entry.js +0 -1
- package/dist/q2-tecton-elements/p-943c7745.entry.js +0 -1
- package/dist/q2-tecton-elements/p-95a73559.entry.js +0 -1
- package/dist/q2-tecton-elements/p-9a977ee6.entry.js +0 -1
- package/dist/q2-tecton-elements/p-b281c349.entry.js +0 -1
- package/dist/q2-tecton-elements/p-c5e55b9f.entry.js +0 -1
- package/dist/q2-tecton-elements/p-ccbe9158.entry.js +0 -1
- package/dist/q2-tecton-elements/p-db6f90ac.entry.js +0 -1
- package/dist/q2-tecton-elements/p-fa6eea5c.entry.js +0 -1
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
import { r as registerInstance, c as createEvent, h, F as Fragment, g as getElement } from './index-dbfb3ecc.js';
|
|
2
|
+
import { o as overrideFocus, l as loc, i as isEventFromElement } from './index-0ff8de52.js';
|
|
3
|
+
|
|
4
|
+
const stylesCss = "*{box-sizing:border-box}*:active{outline:none}*:focus{outline:none;box-shadow:var(--const-global-focus)}:host{box-shadow:none !important}::-moz-focus-inner{border:none}input,textarea,button{font-family:inherit;font-size:inherit}:host(.sr),:host(.sr) button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.sr,.sr button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.hidden{display:none}:host([hidden]){display:none}.invisible{visibility:hidden}:host{display:inline-block;position:relative}:host(:not(:last-child)){margin-inline-end:var(--tct-pill-margin, var(--t-pill-margin, var(--app-scale-2x, 10px)))}.btn-wrapper{--comp-pill-min-height:var(--tct-pill-min-height, var(--t-pill-min-height, 44px));--comp-pill-btn-border-width:var(--tct-pill-btn-border-width, var(--t-pill-btn-border-width, 2px));--comp-pill-btn-height:var(--tct-pill-btn-height, var(--t-pill-btn-height, 30px));--comp-close-size:0px;--comp-btn-background:var(--tct-pill-btn-background, var(--t-pill-btn-background, var(--t-base, #ffffff)));--compt-hover-btn-background:var(--tct-pill-hover-btn-background, var(--t-pill-hover-btn-background, var(--t-gray-13, #e6e6e6)));--comp-btn-padding:var(--tct-pill-btn-padding-inline, var(--t-pill-btn-padding-inline, var(--app-scale-3x, 15px)));--comp-btn-color:var(--tct-pill-btn-color, var(--t-pill-btn-color, var(--t-gray-3, #262626)));--comp-active-btn-background:var(--tct-pill-active-btn-background, var(--t-pill-active-btn-background, var(--t-gray-7, #666666)));--comp-active-btn-border-color:var(--tct-pill-active-btn-border-color, var(--t-pill-active-btn-border-color, var(--t-gray-7, #666666)));--comp-hover-active-btn-background:var(--tct-pill-active-btn-background, var(--t-pill-active-btn-background, var(--t-gray-6, #4d4d4d)));--comp-hover-active-btn-border-color:var(--tct-pill-active-btn-background, var(--t-pill-active-btn-background, var(--t-gray-6, #4d4d4d)));position:relative}:host(:not(:empty)) .btn-wrapper,.btn-wrapper.has-icon{--comp-close-size:var(--comp-pill-btn-height)}:host([active]) .btn-wrapper{--comp-btn-color:var(--tct-pill-active-btn-color, var(--t-pill-active-btn-color, var(--t-base, #ffffff)))}:host([theme=primary]) .btn-wrapper{--comp-active-btn-background:var(--t-primary-l5, #61c4ff);--comp-btn-color:var(--t-primary-text, #ffffff);--comp-active-btn-border-color:var(--t-primary-l5, #61c4ff);--comp-hover-active-btn-background:var(--t-primary-l3, #21acff);--comp-hover-active-btn-border-color:var(--t-primary-l3, #21acff)}:host([theme=secondary]) .btn-wrapper{--comp-active-btn-background:var(--t-secondary-l5, #61c4ff);--comp-btn-color:var(--t-secondary-text, #000000);--comp-active-btn-border-color:var(--t-secondary-l5, #61c4ff);--comp-hover-active-btn-background:var(--t-secondary-l3, #21acff);--comp-hover-active-btn-border-color:var(--t-secondary-l3, #21acff)}:host([theme=tertiary]) .btn-wrapper{--comp-active-btn-background:var(--t-tertiary-l5, #61c4ff);--comp-btn-color:var(--t-tertiary-text, #000000);--comp-active-btn-border-color:var(--t-tertiary-l5, #61c4ff);--comp-hover-active-btn-background:var(--t-tertiary-l3, #21acff);--comp-hover-active-btn-border-color:var(--t-tertiary-l3, #21acff)}q2-option-list{position:absolute;left:0}.btn-height-wrapper{height:var(--comp-pill-min-height);display:flex;align-items:center;cursor:pointer}.btn-height-wrapper:focus{box-shadow:none}:host([disabled]) .btn-height-wrapper{cursor:not-allowed}.btn-close,.btn-primary{cursor:pointer;height:var(--comp-pill-btn-height);border-style:solid;border-radius:var(--tct-pill-btn-border-radius, var(--t-pill-btn-border-radius, 30px));transition-property:background, color, padding, width, opacity;transition:var(--tct-pill-btn-tween, var(--t-pill-btn-tween, var(--app-tween-1, 0.2s ease)))}:host([disabled]) .btn-close,:host([disabled]) .btn-primary,:host([disabled]) q2-icon{opacity:var(--tct-pill-disabled-opacity, var(--t-pill-disabled-opacity, var(--tct-disabled-opacity, var(--app-disabled-opacity, 0.4))));cursor:not-allowed}.btn-primary{background:var(--comp-btn-background);border-width:var(--comp-pill-btn-border-width);border-color:var(--tct-pill-btn-border-color, var(--t-pill-btn-border-color, var(--t-gray-9, #999999)));padding-inline:var(--comp-btn-padding);padding-right:calc(var(--comp-btn-padding) + var(--comp-close-size));font-size:var(--tct-pill-btn-font-size, var(--t-pill-btn-font-size, var(--app-font-size, 14px)));color:var(--comp-btn-color);display:block;width:100%;text-align:start}.btn-primary:focus,.btn-primary:hover{background:var(--comp-hover-btn-background)}:host(:not(:empty)) .btn-primary,.has-icon .btn-primary{padding-right:calc(\n var(--tct-pill-icon-gap, var(--t-pill-icon-gap, var(--app-size-1x, 5px))) + var(--comp-close-size)\n )}.has-options .btn-primary{text-overflow:ellipsis;overflow:hidden;white-space:nowrap;max-width:var(--tct-pill-max-width, var(--t-pill-max-width, 200px))}:host([active]) .btn-primary{background:var(--comp-active-btn-background);border-color:var(--comp-active-btn-border-color)}:host([active]) .btn-primary:focus,:host([active]) .btn-primary:hover{background:var(--comp-hover-active-btn-background);border-color:var(--comp-hover-active-btn-border-color)}.btn-close{background:transparent;border-color:transparent;border-width:var(--comp-pill-btn-border-width);width:var(--comp-close-size);height:var(--comp-close-size);padding:0;border:0;display:inline-flex;justify-content:center;align-items:center;position:absolute;right:0;top:50%;transform:translateY(-50%);opacity:0;stroke:var(--comp-btn-color);--tct-icon-stroke-primary:var(--comp-btn-color)}:host(:not(:empty)) .btn-close,.has-icon .btn-close{opacity:1}q2-icon{width:var(--tct-pill-icon-size, var(--t-pill-icon-size, 14px));height:var(--tct-pill-icon-size, var(--t-pill-icon-size, 14px));transition-property:transform;transition:var(--tct-pill-btn-tween, var(--t-pill-btn-tween, var(--app-tween-1, 0.2s ease)))}div.btn-close{pointer-events:none}:host([open]) div.btn-close q2-icon{transform:rotate(180deg)}:host([active]) button.btn-close:focus,:host([active]) button.btn-close:hover{background:var(--tct-pill-hover-close-btn-background, var(--t-pill-hover-close-btn-background, var(--t-top-a1, rgba(13, 13, 13, 0.35))));border-color:var(--tct-pill-hover-close-btn-border-color, var(--t-pill-hover-close-btn-border-color, var(--t-top-a1, rgba(13, 13, 13, 0.35))))}";
|
|
5
|
+
|
|
6
|
+
const Q2Pill = class {
|
|
7
|
+
constructor(hostRef) {
|
|
8
|
+
registerInstance(this, hostRef);
|
|
9
|
+
this.change = createEvent(this, "change", 7);
|
|
10
|
+
this.selectedOptions = [];
|
|
11
|
+
this.scheduledAfterRender = [];
|
|
12
|
+
/// Helpers ///
|
|
13
|
+
this.determineHasOptions = () => {
|
|
14
|
+
const hasOptions = !!this.hostElement.querySelectorAll('q2-option').length;
|
|
15
|
+
this.hasOptions = hasOptions;
|
|
16
|
+
};
|
|
17
|
+
this.clearSelectedOptions = () => {
|
|
18
|
+
this.selectedOptions = [];
|
|
19
|
+
this.active = false;
|
|
20
|
+
this.open = false;
|
|
21
|
+
this.primaryBtn.focus();
|
|
22
|
+
this.change.emit({ value: null, values: [], active: false });
|
|
23
|
+
};
|
|
24
|
+
/// Event Handlers ///
|
|
25
|
+
this.handleClick = (event) => {
|
|
26
|
+
event.stopPropagation();
|
|
27
|
+
if (this.disabled)
|
|
28
|
+
return;
|
|
29
|
+
if (this.hasOptions) {
|
|
30
|
+
this.optionList.toggle();
|
|
31
|
+
}
|
|
32
|
+
else {
|
|
33
|
+
const { value, label } = this;
|
|
34
|
+
const isActive = (this.active = !this.active);
|
|
35
|
+
const values = isActive ? [{ value, display: label }] : [];
|
|
36
|
+
this.selectedOptions = values;
|
|
37
|
+
this.change.emit({
|
|
38
|
+
value,
|
|
39
|
+
values,
|
|
40
|
+
active: isActive,
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
this.handleKeydown = (event) => {
|
|
45
|
+
if (!this.hasOptions || this.disabled)
|
|
46
|
+
return;
|
|
47
|
+
this.optionList.handleExternalKeydown(event);
|
|
48
|
+
};
|
|
49
|
+
this.handleChange = event => {
|
|
50
|
+
if (!this.hasOptions)
|
|
51
|
+
return;
|
|
52
|
+
const { value, values } = event.detail;
|
|
53
|
+
const isActive = !!values.length;
|
|
54
|
+
if (!this.hostElement.onchange) {
|
|
55
|
+
this.selectedOptions = values;
|
|
56
|
+
this.active = isActive;
|
|
57
|
+
}
|
|
58
|
+
this.change.emit({ value, values, active: isActive });
|
|
59
|
+
};
|
|
60
|
+
this.handleFocusout = (event) => {
|
|
61
|
+
const relatedTarget = event.relatedTarget;
|
|
62
|
+
if (Array.from(this.hostElement.children).includes(relatedTarget))
|
|
63
|
+
return;
|
|
64
|
+
if (relatedTarget && !(event.relatedTarget instanceof HTMLElement))
|
|
65
|
+
return;
|
|
66
|
+
if (relatedTarget && relatedTarget.closest('.btn-height-wrapper'))
|
|
67
|
+
return;
|
|
68
|
+
this.optionList.open = false;
|
|
69
|
+
};
|
|
70
|
+
this.handleWrapperClick = () => {
|
|
71
|
+
this.primaryBtn.focus();
|
|
72
|
+
this.primaryBtn.click();
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
/// LifeCycle Hooks ///
|
|
76
|
+
componentWillLoad() {
|
|
77
|
+
const observer = new MutationObserver(this.determineHasOptions);
|
|
78
|
+
observer.observe(this.hostElement, { childList: true, attributes: true });
|
|
79
|
+
this.mutationObserver = observer;
|
|
80
|
+
}
|
|
81
|
+
componentDidLoad() {
|
|
82
|
+
overrideFocus(this.hostElement);
|
|
83
|
+
}
|
|
84
|
+
componentDidRender() {
|
|
85
|
+
this.scheduledAfterRender.forEach(fn => fn());
|
|
86
|
+
this.scheduledAfterRender = [];
|
|
87
|
+
}
|
|
88
|
+
disconnectedCallback() {
|
|
89
|
+
this.mutationObserver.disconnect();
|
|
90
|
+
this.mutationObserver = null;
|
|
91
|
+
}
|
|
92
|
+
/// Getters ///
|
|
93
|
+
get buttonContent() {
|
|
94
|
+
const { label, selectedOptions, hasOptions } = this;
|
|
95
|
+
if (!hasOptions || selectedOptions.length === 0)
|
|
96
|
+
return label;
|
|
97
|
+
else if (selectedOptions.length === 1)
|
|
98
|
+
return selectedOptions[0].display;
|
|
99
|
+
return loc('tecton.element.pill.activeCount', { count: selectedOptions.length });
|
|
100
|
+
}
|
|
101
|
+
/// Listeners ///
|
|
102
|
+
delegateFocus(event) {
|
|
103
|
+
if (!isEventFromElement(event, this.hostElement))
|
|
104
|
+
return;
|
|
105
|
+
this.primaryBtn.focus();
|
|
106
|
+
}
|
|
107
|
+
optionListStateEvent({ detail: { open } }) {
|
|
108
|
+
this.open = open;
|
|
109
|
+
if (!open)
|
|
110
|
+
this.primaryBtn.focus();
|
|
111
|
+
}
|
|
112
|
+
/// DOM ///
|
|
113
|
+
generateIcon() {
|
|
114
|
+
const { hasOptions, active } = this;
|
|
115
|
+
const isButton = hasOptions && active;
|
|
116
|
+
const TagName = isButton ? 'button' : 'div';
|
|
117
|
+
const iconName = isButton || !hasOptions ? 'close' : 'chevron-down';
|
|
118
|
+
return (h(TagName, { class: "btn-close", onClick: isButton && this.clearSelectedOptions, disabled: isButton && this.disabled, "aria-label": isButton && loc('tecton.element.pill.clearSelection'), type: isButton && 'button' }, h("q2-icon", { type: iconName })));
|
|
119
|
+
}
|
|
120
|
+
render() {
|
|
121
|
+
const { hasOptions, active, open } = this;
|
|
122
|
+
const wrapperClassNames = ['btn-wrapper'];
|
|
123
|
+
if (hasOptions || active)
|
|
124
|
+
wrapperClassNames.push('has-icon');
|
|
125
|
+
if (hasOptions)
|
|
126
|
+
wrapperClassNames.push('has-options');
|
|
127
|
+
return (h(Fragment, null, h("div", { class: wrapperClassNames.join(' ') }, h("div", { class: "btn-height-wrapper", onClick: this.handleWrapperClick, tabIndex: -1 }, h("button", { class: "btn-primary", type: "button", "test-id": "btn-control", ref: el => (this.primaryBtn = el), onClick: this.handleClick, onKeyDown: this.handleKeydown, disabled: this.disabled, onFocusout: this.handleFocusout, "aria-selected": !hasOptions && active ? 'true' : 'false', "aria-roledescription": !hasOptions && 'filter', "aria-controls": hasOptions && 'option-list', "aria-haspopup": hasOptions && 'true', "aria-expanded": hasOptions && open ? 'true' : 'false' }, this.buttonContent, !hasOptions && active && h("span", { class: "sr" }, "(", loc('tecton.element.pill.active'), ")"))), this.generateIcon()), this.hasOptions && (h("q2-option-list", { id: "option-list", ref: el => (this.optionList = el), open: this.open, onChange: this.handleChange, multiple: this.multiple, onFocusout: this.handleFocusout, selectedOptions: this.selectedOptions }, h("slot", null)))));
|
|
128
|
+
}
|
|
129
|
+
get hostElement() { return getElement(this); }
|
|
130
|
+
};
|
|
131
|
+
Q2Pill.style = stylesCss;
|
|
132
|
+
|
|
133
|
+
export { Q2Pill as q2_pill };
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { r as registerInstance, c as createEvent, h, g as getElement } from './index-
|
|
2
|
-
import { c as createGuid, o as overrideFocus, i as isEventFromElement, l as loc } from './index-
|
|
1
|
+
import { r as registerInstance, c as createEvent, h, F as Fragment, g as getElement } from './index-dbfb3ecc.js';
|
|
2
|
+
import { c as createGuid, o as overrideFocus, i as isEventFromElement, l as loc } from './index-0ff8de52.js';
|
|
3
3
|
|
|
4
4
|
const stylesCss = "*{box-sizing:border-box}*:active{outline:none}*:focus{outline:none;box-shadow:var(--const-global-focus)}:host{box-shadow:none !important}::-moz-focus-inner{border:none}input,textarea,button{font-family:inherit;font-size:inherit}:host(.sr),:host(.sr) button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.sr,.sr button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.hidden{display:none}:host([hidden]){display:none}.invisible{visibility:hidden}:host{margin-top:var(--tct-scale-2, var(--app-scale-2, 10px))}fieldset{padding:0;margin:0;border:0}fieldset.has-error{border-color:var(--tct-input-error-border-color, var(--const-stoplight-alert, #c30000));border-width:1px;border-style:solid;border-radius:var(--tct-border-radius-1, var(--app-border-radius-1, 2px));position:relative}fieldset.has-error .error-icon-container{top:8px;right:8px;position:absolute;width:40%;text-align:right;background:linear-gradient(to right, transparent, white)}fieldset.has-error legend+div.error-icon-container.no-label{top:28px}.group-legend{font-weight:600}legend.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;border:0}.optional-tag{margin-left:var(--tct-input-label-optional-margin-left, var(--t-input-label-optional-margin-left, var(--tct-scale-1, var(--app-scale-1, 5px))));color:var(--tct-input-label-optional-font-color, var(--t-input-label-optional-font-color, var(--t-textA, var(--t-a11y-gray-color, rgba(77, 77, 77, 0.77)))));font-size:var(--tct-input-label-optional-font-size, var(--t-input-label-optional-font-size, 12px));font-weight:var(--tct-input-label-optional-font-weight, var(--t-input-label-optional-font-weight, 400))}.flexed{margin:0;display:flex;flex-wrap:wrap;align-items:center;justify-content:center}.flexed.left{justify-content:left}.flexed.right{justify-content:right}";
|
|
5
5
|
|
|
@@ -12,13 +12,16 @@ const Q2RadioGroup = class {
|
|
|
12
12
|
this.hasError = false;
|
|
13
13
|
this.id = `radio-group-${createGuid()}`;
|
|
14
14
|
this.onMutationObserved = () => {
|
|
15
|
-
this.valueUpdated();
|
|
15
|
+
this.valueUpdated(this.value);
|
|
16
16
|
this.nameUpdated();
|
|
17
17
|
this.disabledUpdated();
|
|
18
|
+
this.readonlyUpdated();
|
|
18
19
|
this.tileLayoutUpdated();
|
|
19
20
|
};
|
|
20
21
|
this.onInnerRadioChange = (event) => {
|
|
21
22
|
event.stopImmediatePropagation();
|
|
23
|
+
if (this.readonly)
|
|
24
|
+
return;
|
|
22
25
|
this.change.emit({ value: event.detail.value });
|
|
23
26
|
};
|
|
24
27
|
}
|
|
@@ -26,17 +29,19 @@ const Q2RadioGroup = class {
|
|
|
26
29
|
return Array.from(this.hostElement.querySelectorAll('q2-radio'));
|
|
27
30
|
}
|
|
28
31
|
/////// LIFECYCLE HOOK ///////
|
|
32
|
+
componentWillLoad() {
|
|
33
|
+
this.onMutationObserved();
|
|
34
|
+
}
|
|
29
35
|
componentDidLoad() {
|
|
30
36
|
const observer = new MutationObserver(this.onMutationObserved);
|
|
31
37
|
observer.observe(this.hostElement, { childList: true });
|
|
32
38
|
this.mutationObserver = observer;
|
|
33
|
-
this.onMutationObserved();
|
|
34
39
|
overrideFocus(this.hostElement);
|
|
35
40
|
}
|
|
36
41
|
/////// OBSERVERS ///////
|
|
37
|
-
valueUpdated() {
|
|
42
|
+
valueUpdated(newVal) {
|
|
38
43
|
this.radioElements.forEach(radio => {
|
|
39
|
-
radio.checked =
|
|
44
|
+
radio.checked = newVal === radio.value;
|
|
40
45
|
});
|
|
41
46
|
}
|
|
42
47
|
nameUpdated() {
|
|
@@ -49,6 +54,10 @@ const Q2RadioGroup = class {
|
|
|
49
54
|
radio.groupDisabled = this.disabled;
|
|
50
55
|
});
|
|
51
56
|
}
|
|
57
|
+
readonlyUpdated() {
|
|
58
|
+
const readonly = this.readonly;
|
|
59
|
+
this.radioElements.forEach(radio => (radio.groupReadonly = readonly));
|
|
60
|
+
}
|
|
52
61
|
tileLayoutUpdated() {
|
|
53
62
|
this.radioElements.forEach(radio => {
|
|
54
63
|
radio.groupTileLayout = this.tilelayout;
|
|
@@ -64,19 +73,22 @@ const Q2RadioGroup = class {
|
|
|
64
73
|
delegateFocus(event) {
|
|
65
74
|
if (!isEventFromElement(event, this.hostElement))
|
|
66
75
|
return;
|
|
67
|
-
const radio = this.hostElement.querySelector('q2-radio[checked]') ||
|
|
68
|
-
this.hostElement.querySelector('q2-radio');
|
|
76
|
+
const radio = this.hostElement.querySelector('q2-radio[checked]') || this.hostElement.querySelector('q2-radio');
|
|
69
77
|
radio === null || radio === void 0 ? void 0 : radio.dispatchEvent(new FocusEvent('focus'));
|
|
70
78
|
}
|
|
71
79
|
keydownHandler(event) {
|
|
72
80
|
const currentValue = event.target.getAttribute('value') || this.value;
|
|
73
81
|
let index = this.radioElements.findIndex(el => el === event.target || el.getAttribute('value') === currentValue);
|
|
74
82
|
let sign = 0;
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
83
|
+
switch (event.key) {
|
|
84
|
+
case 'ArrowLeft':
|
|
85
|
+
case 'ArrowUp':
|
|
86
|
+
sign = -1;
|
|
87
|
+
break;
|
|
88
|
+
case 'ArrowRight':
|
|
89
|
+
case 'ArrowDown':
|
|
90
|
+
sign = 1;
|
|
91
|
+
break;
|
|
80
92
|
}
|
|
81
93
|
if (index === -1 || sign === 0) {
|
|
82
94
|
return;
|
|
@@ -84,18 +96,30 @@ const Q2RadioGroup = class {
|
|
|
84
96
|
index += sign;
|
|
85
97
|
index = sign < 0 ? Math.max(0, index) : Math.min(this.radioElements.length - 1, index);
|
|
86
98
|
event.preventDefault();
|
|
87
|
-
this.
|
|
99
|
+
if (!this.readonly) {
|
|
100
|
+
this.value = this.radioElements[index].value;
|
|
101
|
+
}
|
|
88
102
|
this.radioElements[index].dispatchEvent(new FocusEvent('focus'));
|
|
89
103
|
}
|
|
104
|
+
labelDOM() {
|
|
105
|
+
const { label, optional, readonly } = this;
|
|
106
|
+
let helpText = '';
|
|
107
|
+
if (readonly) {
|
|
108
|
+
helpText = h("span", { class: "optional-tag" }, loc('tecton.element.input.readonly'));
|
|
109
|
+
}
|
|
110
|
+
else if (optional) {
|
|
111
|
+
helpText = h("span", { class: "optional-tag" }, loc('tecton.element.input.optional'));
|
|
112
|
+
}
|
|
113
|
+
return (h(Fragment, null, label && loc(label), !!helpText && h("span", { class: "optional-tag" }, helpText)));
|
|
114
|
+
}
|
|
90
115
|
render() {
|
|
91
|
-
|
|
116
|
+
const showLabel = this.label || this.optional || this.readonly;
|
|
117
|
+
return (h("div", null, showLabel && h("div", { class: "group-legend" }, this.labelDOM()), h("fieldset", { class: `q2-radio-fieldset ${this.hasError ? 'has-error' : ''}`, onChange: this.onInnerRadioChange, "aria-required": `${!this.optional}`, "aria-readonly": `${this.readonly}` }, showLabel && h("legend", { class: "sr-only" }, this.labelDOM()), this.hasError ? (h("div", { class: `error-icon-container ${!showLabel && 'no-label'}` }, h("q2-icon", { class: "h(4) w(4) mrg-b(2)", type: "error" }))) : (''), this.inputDom())));
|
|
92
118
|
}
|
|
93
119
|
inputDom() {
|
|
94
120
|
if (this.tilelayout) {
|
|
95
121
|
const { tileAlignment } = this;
|
|
96
|
-
const alignment = ['left', 'center', 'right'].includes(tileAlignment)
|
|
97
|
-
? tileAlignment
|
|
98
|
-
: 'center';
|
|
122
|
+
const alignment = ['left', 'center', 'right'].includes(tileAlignment) ? tileAlignment : 'center';
|
|
99
123
|
return (h("div", { class: `flexed ${alignment}` }, h("slot", null)));
|
|
100
124
|
}
|
|
101
125
|
else {
|
|
@@ -107,6 +131,7 @@ const Q2RadioGroup = class {
|
|
|
107
131
|
"value": ["valueUpdated"],
|
|
108
132
|
"name": ["nameUpdated"],
|
|
109
133
|
"disabled": ["disabledUpdated"],
|
|
134
|
+
"readonly": ["readonlyUpdated"],
|
|
110
135
|
"tilelayout": ["tileLayoutUpdated"]
|
|
111
136
|
}; }
|
|
112
137
|
};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { r as registerInstance, c as createEvent, h, g as getElement } from './index-
|
|
2
|
-
import { c as createGuid, h as handleAriaLabel, o as overrideFocus, l as loc } from './index-
|
|
1
|
+
import { r as registerInstance, c as createEvent, h, g as getElement } from './index-dbfb3ecc.js';
|
|
2
|
+
import { c as createGuid, h as handleAriaLabel, o as overrideFocus, l as loc } from './index-0ff8de52.js';
|
|
3
3
|
|
|
4
4
|
const stylesCss = "*{box-sizing:border-box}*:active{outline:none}*:focus{outline:none;box-shadow:var(--const-global-focus)}:host{box-shadow:none !important}::-moz-focus-inner{border:none}input,textarea,button{font-family:inherit;font-size:inherit}:host(.sr),:host(.sr) button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.sr,.sr button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.hidden{display:none}:host([hidden]){display:none}.invisible{visibility:hidden}:host{margin-top:var(--tct-radio-margin-vertical, var(--tct-scale-2, 10px));margin-right:var(--tct-radio-margin-horizontal, var(--tct-scale-3, 15px));display:block}:host .radio-container{margin-bottom:var(--tct-radio-margin-vertical, var(--tct-scale-2, 10px))}:host .radio-container label[for]{font-weight:var(--tct-radio-font-weight, var(--tct-checkbox-font-weight, 400));align-items:center;cursor:pointer;margin-right:1rem;display:grid;grid-template-columns:18px 1fr;gap:var(--tct-scale-1, var(--app-scale-1, 5px))}:host .radio-container svg{border-radius:50%;transition:box-shadow var(--tct-tween-1, var(--app-tween-1, 0.2s ease));outline:0;width:100%}:host .radio-container circle:nth-child(1){stroke-width:2;stroke:var(--tct-radio-stroke-color, var(--tct-gray-11, var(--t-gray-11, var(--tct-gray-l1, var(--app-gray-l1, #cccccc)))))}:host .radio-container input:focus+label svg{box-shadow:var(--tct-global-focus, var(--const-global-focus, 0 0 0 2px #33b4ff))}:host .radio-container input:focus+label circle:nth-child(1){stroke:var(--tct-radio-focus-stroke-color, var(--tct-checkbox-check-stroke-color, var(--t-checkbox-fill, #2e2e2e)))}:host .radio-container input:checked+label circle:nth-child(1){background-color:var(--tct-radio-checked-bg, transparent);stroke:var(--tct-radio-checked-stroke-color, var(--tct-radio-stroke-color, var(--tct-gray-11, var(--t-gray-11, var(--tct-gray-l1, var(--app-gray-l1, #cccccc))))))}:host .radio-container input:checked+label .label-content{font-weight:var(--tct-checkbox-selected-font-weight, 600);letter-spacing:var(--tct-checkbox-selected-letter-spacing, 0.25)}:host .radio-container input:checked+label circle:nth-child(2){fill:var(--tct-radio-checked-fill, var(--tct-checkbox-check-stroke-color, var(--t-checkbox-fill, #2e2e2e)))}:host .radio-tile{flex-basis:100px;flex-grow:0;flex-wrap:wrap}:host .radio-tile label[for]{align-items:center;border-radius:3px;border:2px solid var(--tct-radio-stroke-color, var(--tct-gray-11, var(--t-gray-11, var(--tct-gray-l1, var(--app-gray-l1, #cccccc)))));cursor:pointer;display:block;padding:1rem;position:relative;text-align:center;transition:border-color var(--tct-tween-1, var(--app-tween-1, 0.2s ease));white-space:nowrap}:host .radio-tile input:focus+label{border-color:#0079c1;box-shadow:var(--tct-global-focus, var(--const-global-focus, 0 0 0 2px #33b4ff))}:host .radio-tile input:checked+label{border-color:var(--tct-checkbox-check-stroke-color, var(--t-checkbox-fill, #2e2e2e));box-shadow:inset 0 0 0 2px #ffffff}:host .radio-tile input:checked+label:after{border-bottom-width:3px;border-bottom:5px solid #0079c1;border-left-width:5px;border-left:8px solid transparent;border-right-width:5px;border-right:8px solid transparent;bottom:0;content:\"\";height:0;left:50%;margin-left:-5px;position:absolute;width:0}:host input:disabled+label{cursor:not-allowed;opacity:var(--tct-disabled-opacity, var(--app-disabled-opacity, 0.4))}";
|
|
5
5
|
|
|
@@ -10,11 +10,19 @@ const Q2Radio = class {
|
|
|
10
10
|
this.disabled = false;
|
|
11
11
|
this.checked = false;
|
|
12
12
|
this.groupDisabled = false;
|
|
13
|
+
this.groupReadonly = false;
|
|
13
14
|
this.groupTileLayout = false;
|
|
14
15
|
this.id = `radio-${createGuid()}`;
|
|
16
|
+
this.isLoaded = false;
|
|
15
17
|
this.inputChange = (event) => {
|
|
16
18
|
event.stopPropagation();
|
|
17
|
-
|
|
19
|
+
if (this.groupReadonly) {
|
|
20
|
+
event.preventDefault();
|
|
21
|
+
return false;
|
|
22
|
+
}
|
|
23
|
+
if (event.target instanceof HTMLInputElement) {
|
|
24
|
+
this.checked = event.target.checked;
|
|
25
|
+
}
|
|
18
26
|
};
|
|
19
27
|
}
|
|
20
28
|
////////// LIFECYCLE HOOKS ////////
|
|
@@ -22,12 +30,20 @@ const Q2Radio = class {
|
|
|
22
30
|
handleAriaLabel(this);
|
|
23
31
|
}
|
|
24
32
|
componentDidLoad() {
|
|
33
|
+
this.isLoaded = true;
|
|
25
34
|
overrideFocus(this.hostElement);
|
|
26
35
|
}
|
|
27
36
|
////////// OBSERVERS //////////
|
|
28
37
|
ariaLabelObserver() {
|
|
29
38
|
handleAriaLabel(this);
|
|
30
39
|
}
|
|
40
|
+
checkedObserver() {
|
|
41
|
+
if (!this.isLoaded)
|
|
42
|
+
return;
|
|
43
|
+
if (!this.checked)
|
|
44
|
+
return;
|
|
45
|
+
this.change.emit({ value: this.value });
|
|
46
|
+
}
|
|
31
47
|
/////// HOST ELEMENT EVENTS ///////
|
|
32
48
|
onHostClick(event) {
|
|
33
49
|
if (this.disabled) {
|
|
@@ -44,7 +60,8 @@ const Q2Radio = class {
|
|
|
44
60
|
}
|
|
45
61
|
get hostElement() { return getElement(this); }
|
|
46
62
|
static get watchers() { return {
|
|
47
|
-
"ariaLabel": ["ariaLabelObserver"]
|
|
63
|
+
"ariaLabel": ["ariaLabelObserver"],
|
|
64
|
+
"checked": ["checkedObserver"]
|
|
48
65
|
}; }
|
|
49
66
|
};
|
|
50
67
|
Q2Radio.style = stylesCss;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { r as registerInstance, c as createEvent, h, g as getElement } from './index-
|
|
2
|
-
import { c as createGuid, o as overrideFocus, i as isEventFromElement, l as loc } from './index-
|
|
1
|
+
import { r as registerInstance, c as createEvent, h, g as getElement } from './index-dbfb3ecc.js';
|
|
2
|
+
import { c as createGuid, o as overrideFocus, i as isEventFromElement, l as loc } from './index-0ff8de52.js';
|
|
3
3
|
|
|
4
4
|
const stylesCss = "*{box-sizing:border-box}*:active{outline:none}*:focus{outline:none;box-shadow:var(--const-global-focus)}:host{box-shadow:none !important}::-moz-focus-inner{border:none}input,textarea,button{font-family:inherit;font-size:inherit}:host(.sr),:host(.sr) button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.sr,.sr button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.hidden{display:none}:host([hidden]){display:none}.invisible{visibility:hidden}@keyframes expandVertical{0%{height:0}}@keyframes collapseVertical{100%{height:0}}:host{display:block;background-color:var(--tct-section-bg, var(--t-section-bg, var(--tct-white, var(--app-white, #ffffff))));color:var(--tct-section-font-color, var(--t-section-font-color, #2e2e2e));border-radius:var(--tct-section-border-radius, var(--t-section-border-radius, 3px));margin:var(--tct-scale-3, var(--app-scale-3, 15px))}@media screen and (max-width: 767px){:host{margin:var(--tct-scale-3, var(--app-scale-3, 15px)) 0}}.q2-section-wrapper{display:block;padding:var(--tct-scale-1, var(--app-scale-1, 5px)) 0}.q2-section-wrapper:hover{box-shadow:var(--tct-section-wrapper-hover-box-shadow, inherit)}.q2-section-header{padding:0 var(--tct-scale-3, var(--app-scale-3, 15px));display:flex}.has-header .q2-section-header{min-height:44px}.q2-section-header-content{flex:1 1 100%;min-width:0;align-self:center}.collapsible .q2-section-header-content{cursor:pointer}.title{margin:0;font-size:20px;font-weight:600;text-transform:uppercase;letter-spacing:0.5px}.toggle-icon{transition:transform var(--tct-tween-1, var(--app-tween-1, 0.2s ease))}.collapsed .toggle-icon{transform:rotate(180deg)}.q2-section-content-wrapper{height:auto}.q2-section-content{padding:var(--tct-scale-2, var(--app-scale-2, 10px)) var(--tct-scale-3, var(--app-scale-3, 15px))}.q2-section-content:focus{box-shadow:none}.expanded.animate .q2-section-content-wrapper{animation:expandVertical var(--tct-tween-2, var(--app-tween-2, 0.4s ease)) forwards}.collapsed .q2-section-content-wrapper{height:0;animation:collapseVertical 0s forwards;animation-duration:0;padding-top:0;visibility:hidden;overflow:hidden}.collapsed.animate .q2-section-content-wrapper{animation:collapseVertical var(--tct-tween-1, var(--app-tween-1, 0.2s ease)) forwards}.animate .q2-section-content-wrapper{overflow:hidden}";
|
|
5
5
|
|
|
@@ -16,7 +16,7 @@ const Q2Section = class {
|
|
|
16
16
|
this.onHeaderClick = () => {
|
|
17
17
|
this.collapsible &&
|
|
18
18
|
this.change.emit({
|
|
19
|
-
expanded: !this.expanded
|
|
19
|
+
expanded: !this.expanded,
|
|
20
20
|
});
|
|
21
21
|
};
|
|
22
22
|
this.onAnimationStart = () => {
|
|
@@ -84,9 +84,7 @@ const Q2Section = class {
|
|
|
84
84
|
};
|
|
85
85
|
}
|
|
86
86
|
resizeIframe() {
|
|
87
|
-
return
|
|
88
|
-
window.TectonElements.resizeIframe &&
|
|
89
|
-
window.TectonElements.resizeIframe());
|
|
87
|
+
return window.TectonElements && window.TectonElements.resizeIframe && window.TectonElements.resizeIframe();
|
|
90
88
|
}
|
|
91
89
|
componentWillLoad() {
|
|
92
90
|
this.onHeaderSlotChange();
|
|
@@ -157,7 +155,7 @@ const Q2Section = class {
|
|
|
157
155
|
}
|
|
158
156
|
}
|
|
159
157
|
render() {
|
|
160
|
-
return (h("section", { class: this.wrapperClasses }, h("div", { class: "q2-section-header" }, h("div", { class: "q2-section-header-content", id: this.titleId, onClick: this.onHeaderClick }, !this.hasYieldedHeader && !!this.label ?
|
|
158
|
+
return (h("section", { class: this.wrapperClasses }, h("div", { class: "q2-section-header" }, h("div", { class: "q2-section-header-content", id: this.titleId, onClick: this.onHeaderClick }, !this.hasYieldedHeader && !!this.label ? h("h2", { class: "title" }, loc(this.label)) : '', h("div", { class: "q2-section-header-slot-wrapper" }, h("slot", { name: "q2-section-header" }))), this.collapsible && !this.noCollapseIcon ? (h("q2-btn", { class: `q2-section-content-toggle ${this.expanded ? 'expanded' : 'collapsed'}`, label: this.label, ariaExpanded: `${!!this.expanded}`, ariaControls: this.contentId, "test-id": "toggleButton", "hide-label": true, onClick: this.onHeaderClick }, h("q2-icon", { type: "chevron-up", class: "toggle-icon" }))) : ('')), h("div", { class: "q2-section-content-wrapper", id: this.contentId, "aria-labelledby": this.titleId, role: "region", onAnimationStart: this.onAnimationStart, onAnimationEnd: this.onAnimationEnd }, h("div", { class: "q2-section-content", tabindex: "-1" }, h("slot", null)))));
|
|
161
159
|
}
|
|
162
160
|
get hostElement() { return getElement(this); }
|
|
163
161
|
static get watchers() { return {
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { r as registerInstance, c as createEvent, h, g as getElement } from './index-
|
|
2
|
-
import { c as createGuid, s as setPopProperties, l as loc, h as handleAriaLabel, o as overrideFocus, i as isEventFromElement } from './index-
|
|
1
|
+
import { r as registerInstance, c as createEvent, h, g as getElement } from './index-dbfb3ecc.js';
|
|
2
|
+
import { c as createGuid, s as setPopProperties, l as loc, h as handleAriaLabel, o as overrideFocus, i as isEventFromElement } from './index-0ff8de52.js';
|
|
3
3
|
|
|
4
4
|
const stylesCss = "*{box-sizing:border-box}*:active{outline:none}*:focus{outline:none;box-shadow:var(--const-global-focus)}:host{box-shadow:none !important}::-moz-focus-inner{border:none}input,textarea,button{font-family:inherit;font-size:inherit}:host(.sr),:host(.sr) button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.sr,.sr button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.hidden{display:none}:host([hidden]){display:none}.invisible{visibility:hidden}.q2-element-dropdown{display:none;position:absolute;background-color:var(--app-white);color:var(--t-font-color);left:0;width:100%;z-index:100;margin-top:1px;box-shadow:var(--app-shadow-1);height:0;overflow:hidden;opacity:0;visibility:hidden;transition:opacity var(--app-tween-1);border-radius:var(--tct-dropdown-border-radius, --t-dropdown-border-radius, 0);--comp-scrollbar-size:var(--tct-scrollbar-size, var(--t-scrollbar-size, var(--app-scale-1x, 5px)));--comp-scrollbar-border-radius:var(--tct-scrollbar-border-radius, var(--t-scrollbar-border-radius, var(--app-border-radius-1, 3px)));--comp-scrollbar-color:var(--tct-scrollbar-color, var(--t-scrollbar-color, var(--t-a11y-gray-color, #747474)));scrollbar-width:thin;scrollbar-color:var(--comp-scrollbar-color) transparent}.q2-element-dropdown::-webkit-scrollbar{width:var(--comp-scrollbar-size);height:var(--comp-scrollbar-size);margin:5px}.q2-element-dropdown::-webkit-scrollbar-thumb{background:var(--comp-scrollbar-color);border-radius:var(--comp-scrollbar-border-radius)}.q2-element-dropdown::-webkit-scrollbar-track{background:transparent;border-radius:var(--comp-scrollbar-border-radius)}.q2-element-dropdown.sizable{display:block;height:auto}.dropdown-open .q2-element-dropdown{display:block;height:auto;overflow:auto;opacity:1;visibility:visible}:host([alignment=right]) .q2-element-dropdown{left:auto;right:0}:host{display:block;margin-top:var(--tct-select-margin-top, var(--app-scale-4, 30px));margin-bottom:var(--tct-select-margin-bottom, var(--app-scale-4, 30px))}.q2-select-container{position:relative;display:block}.q2-select-input{margin:0}.custom-display-content{position:absolute;bottom:0;left:calc(var(--tct-scale-2, var(--app-scale-2, 10px)) + 1px);height:44px;width:calc(100% - 34px - var(--tct-scale-3, var(--app-scale-3, 15px)));overflow:hidden;cursor:pointer;transition:left var(--tct-tween-2, var(--app-tween-1, 0.2s ease))}.custom-display-content:not([hidden]){display:flex;align-items:center}.is-searchable.is-focused .custom-display-content,.is-searchable .custom-display-content:active{left:calc(var(--tct-scale-3, var(--app-scale-3, 15px)) + 1px)}.has-error .custom-display-content{width:calc(100% - 68px - var(--tct-scale-3, var(--app-scale-3, 15px)))}.dropdown-open .q2-select-dropdown{overflow-y:auto;max-height:300px}.multi-select-header{padding:var(--tct-scale-1, var(--app-scale-1, 5px)) var(--tct-scale-2, var(--app-scale-2, 10px))}.show-all-options{margin-right:var(--tct-scale-1, var(--app-scale-1, 5px));margin-left:var(--tct-scale-2, var(--app-scale-2, 10px))}.q2-element-dropdown.dropup{bottom:40px}";
|
|
5
5
|
|
|
@@ -10,6 +10,7 @@ const Q2Select = class {
|
|
|
10
10
|
this.input = createEvent(this, "input", 7);
|
|
11
11
|
this.selectedOptions = [];
|
|
12
12
|
this.disabled = false;
|
|
13
|
+
this.readonly = false;
|
|
13
14
|
this.multiple = false;
|
|
14
15
|
this.minRows = 3;
|
|
15
16
|
this.searchable = false;
|
|
@@ -17,12 +18,13 @@ const Q2Select = class {
|
|
|
17
18
|
this.optional = false;
|
|
18
19
|
this.dropdownOpen = false;
|
|
19
20
|
this.onlyShowingSelected = false;
|
|
21
|
+
this.searchText = '';
|
|
20
22
|
this.hasCustomDisplay = false;
|
|
21
23
|
this.inputFocused = false;
|
|
22
24
|
this.scheduledAfterRender = [];
|
|
23
25
|
this.keyStore = {
|
|
24
26
|
queue: [],
|
|
25
|
-
lastPressedAt: new Date()
|
|
27
|
+
lastPressedAt: new Date(),
|
|
26
28
|
};
|
|
27
29
|
this.guid = createGuid();
|
|
28
30
|
this.onMutationObserved = () => {
|
|
@@ -67,9 +69,7 @@ const Q2Select = class {
|
|
|
67
69
|
return list.find(v => {
|
|
68
70
|
return (!v.element.disabled &&
|
|
69
71
|
v.element.display &&
|
|
70
|
-
v.element.display
|
|
71
|
-
.replace(/\s/g, '')
|
|
72
|
-
.match(new RegExp(`^${this.keyStore.queue.join('')}`, 'i')));
|
|
72
|
+
v.element.display.replace(/\s/g, '').match(new RegExp(`^${this.keyStore.queue.join('')}`, 'i')));
|
|
73
73
|
});
|
|
74
74
|
};
|
|
75
75
|
const setFocus = ({ element, index }) => {
|
|
@@ -99,13 +99,13 @@ const Q2Select = class {
|
|
|
99
99
|
return;
|
|
100
100
|
this.closeDropdown();
|
|
101
101
|
};
|
|
102
|
+
/* tslint:disable:cyclomatic-complexity */
|
|
102
103
|
this.dropdownKeydownHandler = (event) => {
|
|
103
104
|
event.stopPropagation();
|
|
104
105
|
const { activeIndex, searchable, optionElements, multiSelectHeader } = this;
|
|
105
106
|
const { key, shiftKey } = event;
|
|
106
|
-
if (
|
|
107
|
-
multiSelectHeader.contains(event.target) &&
|
|
108
|
-
[' ', 'Enter'].includes(key))
|
|
107
|
+
if (this.readonly ||
|
|
108
|
+
(multiSelectHeader && multiSelectHeader.contains(event.target) && [' ', 'Enter'].includes(key)))
|
|
109
109
|
return;
|
|
110
110
|
switch (key) {
|
|
111
111
|
case ' ':
|
|
@@ -236,10 +236,17 @@ const Q2Select = class {
|
|
|
236
236
|
};
|
|
237
237
|
this.inputInputHandler = (event) => {
|
|
238
238
|
event.stopPropagation();
|
|
239
|
+
const inputValue = this.inputField.value;
|
|
240
|
+
const eventValue = event.detail.value;
|
|
241
|
+
const didChangeText = inputValue !== eventValue;
|
|
242
|
+
const shouldClearValue = !!this.value && didChangeText;
|
|
243
|
+
if (shouldClearValue) {
|
|
244
|
+
this.selectOption('');
|
|
245
|
+
}
|
|
239
246
|
if (!this.dropdownOpen)
|
|
240
247
|
this.openDropdownWithoutActiveElement();
|
|
241
|
-
this.searchText =
|
|
242
|
-
this.input.emit({ query:
|
|
248
|
+
this.searchText = eventValue;
|
|
249
|
+
this.input.emit({ query: eventValue });
|
|
243
250
|
};
|
|
244
251
|
this.inputFocusHandler = () => {
|
|
245
252
|
this.inputFocused = true;
|
|
@@ -280,9 +287,7 @@ const Q2Select = class {
|
|
|
280
287
|
};
|
|
281
288
|
}
|
|
282
289
|
resizeIframe() {
|
|
283
|
-
return
|
|
284
|
-
window.TectonElements.resizeIframe &&
|
|
285
|
-
window.TectonElements.resizeIframe());
|
|
290
|
+
return window.TectonElements && window.TectonElements.resizeIframe && window.TectonElements.resizeIframe();
|
|
286
291
|
}
|
|
287
292
|
getDefaultActiveIndex() {
|
|
288
293
|
const firstSelected = this.optionElements.findIndex(element => element.selected);
|
|
@@ -343,9 +348,7 @@ const Q2Select = class {
|
|
|
343
348
|
const selectedOption = this.optionElements.find(option => {
|
|
344
349
|
return this.value === option.value;
|
|
345
350
|
});
|
|
346
|
-
return (
|
|
347
|
-
this.value ||
|
|
348
|
-
'');
|
|
351
|
+
return (selectedOption && selectedOption.display && loc(selectedOption.display)) || this.value || '';
|
|
349
352
|
}
|
|
350
353
|
get minPopHeight() {
|
|
351
354
|
const { minRows } = this;
|
|
@@ -362,9 +365,7 @@ const Q2Select = class {
|
|
|
362
365
|
// when closed they display the same as non searchable select (what is selected)
|
|
363
366
|
return this.searchText || '';
|
|
364
367
|
}
|
|
365
|
-
return this.multiple
|
|
366
|
-
? this.calculateMultiSelectSelectedDisplay()
|
|
367
|
-
: this.calculateSingleSelectSelectedDisplay();
|
|
368
|
+
return this.multiple ? this.calculateMultiSelectSelectedDisplay() : this.calculateSingleSelectSelectedDisplay();
|
|
368
369
|
}
|
|
369
370
|
get selectedOptionsCount() {
|
|
370
371
|
return this.selectedOptions.length;
|
|
@@ -402,7 +403,7 @@ const Q2Select = class {
|
|
|
402
403
|
const isSelected = this.selectedOptions.includes(value);
|
|
403
404
|
if (isSelected) {
|
|
404
405
|
this.change.emit({
|
|
405
|
-
selectedOptions: this.selectedOptions.filter(selectedValue => selectedValue !== value)
|
|
406
|
+
selectedOptions: this.selectedOptions.filter(selectedValue => selectedValue !== value),
|
|
406
407
|
});
|
|
407
408
|
}
|
|
408
409
|
else {
|
|
@@ -421,12 +422,16 @@ const Q2Select = class {
|
|
|
421
422
|
activeOption === null || activeOption === void 0 ? void 0 : activeOption.scrollIntoView({ block: 'nearest' });
|
|
422
423
|
}
|
|
423
424
|
openDropdownWithoutActiveElement() {
|
|
425
|
+
if (this.readonly)
|
|
426
|
+
return;
|
|
424
427
|
this.activeIndex = undefined;
|
|
425
428
|
this.setActiveOption();
|
|
426
429
|
this.dropdownOpen = true;
|
|
427
430
|
this.scheduledAfterRender.push(this.resizeIframe);
|
|
428
431
|
}
|
|
429
432
|
openDropdownWithActiveElement(activeIndex) {
|
|
433
|
+
if (this.readonly)
|
|
434
|
+
return;
|
|
430
435
|
this.activeIndex = activeIndex;
|
|
431
436
|
this.dropdownOpen = true;
|
|
432
437
|
this.setActiveOption();
|
|
@@ -536,6 +541,8 @@ const Q2Select = class {
|
|
|
536
541
|
});
|
|
537
542
|
}
|
|
538
543
|
onHostElementChange(event) {
|
|
544
|
+
if (this.readonly)
|
|
545
|
+
return;
|
|
539
546
|
if (event.target === this.hostElement && !this.hostElement.onchange) {
|
|
540
547
|
if (this.multiple) {
|
|
541
548
|
this.selectedOptions = event.detail.selectedOptions;
|
|
@@ -556,14 +563,13 @@ const Q2Select = class {
|
|
|
556
563
|
}
|
|
557
564
|
else {
|
|
558
565
|
const { display = '', innerText = '' } = option;
|
|
559
|
-
const matched = display.toLowerCase().includes(query) ||
|
|
560
|
-
innerText.toLowerCase().includes(query);
|
|
566
|
+
const matched = display.toLowerCase().includes(query) || innerText.toLowerCase().includes(query);
|
|
561
567
|
option.hidden = !matched;
|
|
562
568
|
if (matched)
|
|
563
569
|
matchedCount++;
|
|
564
570
|
}
|
|
565
571
|
});
|
|
566
|
-
|
|
572
|
+
const statusMessageLocString = query
|
|
567
573
|
? 'tecton.element.select.searchable.results'
|
|
568
574
|
: 'tecton.element.select.allOptions';
|
|
569
575
|
const count = query ? matchedCount : options.length;
|
|
@@ -583,12 +589,13 @@ const Q2Select = class {
|
|
|
583
589
|
}, 1000);
|
|
584
590
|
}
|
|
585
591
|
clickHandler(event) {
|
|
586
|
-
const
|
|
587
|
-
if (
|
|
592
|
+
const selected = event.target.closest('q2-option');
|
|
593
|
+
if (!selected || (selected.hasAttribute('disabled') && selected.getAttribute('disabled') !== 'false')) {
|
|
588
594
|
return;
|
|
589
595
|
}
|
|
590
|
-
this.selectOption(
|
|
596
|
+
this.selectOption(selected.getAttribute('value'), true);
|
|
591
597
|
}
|
|
598
|
+
/* tslint:enable:cyclomatic-complexity */
|
|
592
599
|
keydownHandler(event) {
|
|
593
600
|
this.inputKeydownHandler(event);
|
|
594
601
|
}
|
|
@@ -597,16 +604,14 @@ const Q2Select = class {
|
|
|
597
604
|
this.errors.length > 0 &&
|
|
598
605
|
this.errors.map(error => loc(error))) ||
|
|
599
606
|
(this.invalid && ['tecton.element.select.invalid']) ||
|
|
600
|
-
[], disabled: this.disabled, optional: this.optional, hideLabel: this.hideLabel, ariaExpanded: this.dropdownOpen
|
|
607
|
+
[], disabled: this.disabled, optional: this.optional, readonly: this.readonly, hideLabel: this.hideLabel, ariaExpanded: `${!!this.dropdownOpen}`, ariaOwns: "dropdown", ariaHaspopup: "listbox", role: this.searchable ? 'combobox' : null, pseudo: !this.searchable, "test-id": "toggleDropdown", "hide-messages": true, iconRight: "chevron-down", onClick: this.inputClickHandler, onInput: this.inputInputHandler, onKeyDown: this.inputKeydownHandler, onFocus: this.inputFocusHandler, onBlur: this.inputBlurHandler, onChange: this.inputChangeHandler }), h("div", { class: "custom-display-content", hidden: !this.hasCustomDisplay || !!this.searchText, onClick: this.onCustomDisplayClick }, h("slot", { name: "q2-select-display" })), this.optionsDropdown()));
|
|
601
608
|
}
|
|
602
609
|
optionsDropdown() {
|
|
603
610
|
const dropDirection = this.privatePopDirection === 'up' ? 'dropup' : '';
|
|
604
611
|
return (h("div", { class: `q2-select-dropdown q2-element-dropdown ${dropDirection}`, ref: el => (this.dropdownContainer = el), onKeyDown: this.dropdownKeydownHandler, onFocusout: this.dropdownFocusoutHandler }, this.multiple ? this.visibilityToggle() : '', h("div", { class: "q2-select-options", id: "dropdown", role: "listbox" }, h("slot", null))));
|
|
605
612
|
}
|
|
606
613
|
visibilityToggle() {
|
|
607
|
-
return (h("div", { class: "multi-select-header", ref: el => (this.multiSelectHeader = el) }, loc('tecton.element.select.multiHeader.showing'), h("q2-btn", { class: `option-toggle show-all-options${this.onlyShowingSelected ? '' : ' selected'}`, badge: true, "aria-selected": !this.onlyShowingSelected || undefined, "test-id": "allOptionsButton", onClick: this.showAllOptions, label: loc('tecton.element.select.multiHeader.allAriaLabel'), "hide-label": true }, loc('tecton.element.select.multiHeader.all')), h("q2-btn", { class: `option-toggle show-selected-options${this.onlyShowingSelected ? ' selected' : ''}`, "aria-selected": this.onlyShowingSelected || undefined, disabled: this.selectedOptions.length === 0, badge: true, "test-id": "selectedOptionsButton", onClick: this.showSelectedOptions, label: loc('tecton.element.select.multiHeader.selectedAriaLabel', [
|
|
608
|
-
this.selectedOptionsCount
|
|
609
|
-
]), "hide-label": true }, loc('tecton.element.select.multiHeader.selected', [this.selectedOptionsCount]))));
|
|
614
|
+
return (h("div", { class: "multi-select-header", ref: el => (this.multiSelectHeader = el) }, loc('tecton.element.select.multiHeader.showing'), h("q2-btn", { class: `option-toggle show-all-options${this.onlyShowingSelected ? '' : ' selected'}`, badge: true, "aria-selected": !this.onlyShowingSelected || undefined, "test-id": "allOptionsButton", onClick: this.showAllOptions, label: loc('tecton.element.select.multiHeader.allAriaLabel'), "hide-label": true }, loc('tecton.element.select.multiHeader.all')), h("q2-btn", { class: `option-toggle show-selected-options${this.onlyShowingSelected ? ' selected' : ''}`, "aria-selected": this.onlyShowingSelected || undefined, disabled: this.selectedOptions.length === 0, badge: true, "test-id": "selectedOptionsButton", onClick: this.showSelectedOptions, label: loc('tecton.element.select.multiHeader.selectedAriaLabel', [this.selectedOptionsCount]), "hide-label": true }, loc('tecton.element.select.multiHeader.selected', [this.selectedOptionsCount]))));
|
|
610
615
|
}
|
|
611
616
|
get hostElement() { return getElement(this); }
|
|
612
617
|
static get watchers() { return {
|