@crowdstrike/glide-core 0.26.1 → 0.27.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/accordion.d.ts +2 -2
- package/dist/accordion.js +1 -1
- package/dist/button-group.button.d.ts +2 -2
- package/dist/button-group.button.js +1 -1
- package/dist/button-group.d.ts +3 -3
- package/dist/button-group.js +1 -1
- package/dist/button.d.ts +2 -2
- package/dist/button.js +1 -1
- package/dist/checkbox-group.d.ts +3 -3
- package/dist/checkbox-group.js +9 -9
- package/dist/checkbox.d.ts +2 -3
- package/dist/checkbox.js +3 -3
- package/dist/checkbox.styles.js +8 -16
- package/dist/drawer.d.ts +2 -2
- package/dist/drawer.js +1 -1
- package/dist/dropdown.d.ts +6 -12
- package/dist/dropdown.js +47 -49
- package/dist/dropdown.option.d.ts +2 -3
- package/dist/dropdown.option.js +1 -1
- package/dist/dropdown.option.styles.js +16 -79
- package/dist/dropdown.styles.js +8 -26
- package/dist/form-controls-layout.d.ts +3 -3
- package/dist/form-controls-layout.js +1 -1
- package/dist/icon-button.d.ts +2 -2
- package/dist/icon-button.js +1 -1
- package/dist/inline-alert.d.ts +2 -2
- package/dist/inline-alert.js +1 -1
- package/dist/input.d.ts +2 -2
- package/dist/input.js +2 -2
- package/dist/label.d.ts +2 -2
- package/dist/label.js +1 -1
- package/dist/label.styles.js +5 -1
- package/dist/library/assert-slot.d.ts +1 -1
- package/dist/library/assert-slot.test.js +22 -22
- package/dist/library/expect-window-error.js +1 -1
- package/dist/library/final.test.js +9 -9
- package/dist/library/localize.test.js +6 -6
- package/dist/library/required.test.js +5 -5
- package/dist/library/unique-id.d.ts +2 -0
- package/dist/library/unique-id.js +1 -0
- package/dist/link.d.ts +2 -3
- package/dist/link.js +1 -1
- package/dist/link.styles.js +1 -1
- package/dist/menu.button.d.ts +2 -2
- package/dist/menu.button.js +1 -1
- package/dist/menu.d.ts +3 -9
- package/dist/menu.js +1 -1
- package/dist/menu.link.d.ts +2 -2
- package/dist/menu.link.js +1 -1
- package/dist/menu.options.d.ts +3 -4
- package/dist/menu.options.js +1 -1
- package/dist/menu.options.styles.js +6 -19
- package/dist/modal.d.ts +6 -6
- package/dist/modal.icon-button.d.ts +2 -2
- package/dist/modal.icon-button.js +1 -1
- package/dist/modal.js +1 -1
- package/dist/popover.d.ts +2 -2
- package/dist/popover.js +1 -1
- package/dist/radio-group.d.ts +3 -3
- package/dist/radio-group.js +6 -6
- package/dist/radio-group.radio.d.ts +2 -2
- package/dist/radio-group.radio.js +1 -1
- package/dist/spinner.d.ts +2 -2
- package/dist/spinner.js +1 -1
- package/dist/split-button.d.ts +4 -10
- package/dist/split-button.js +1 -1
- package/dist/split-button.primary-button.d.ts +2 -2
- package/dist/split-button.primary-button.js +1 -1
- package/dist/split-button.primary-button.styles.js +4 -14
- package/dist/split-button.primary-link.d.ts +2 -2
- package/dist/split-button.primary-link.js +1 -1
- package/dist/split-button.secondary-button.d.ts +3 -4
- package/dist/split-button.secondary-button.js +1 -1
- package/dist/split-button.secondary-button.styles.js +4 -15
- package/dist/tab.d.ts +12 -4
- package/dist/tab.group.d.ts +4 -5
- package/dist/tab.group.js +1 -1
- package/dist/tab.group.styles.js +14 -16
- package/dist/tab.js +1 -1
- package/dist/tab.panel.d.ts +12 -5
- package/dist/tab.panel.js +1 -1
- package/dist/tag.d.ts +2 -4
- package/dist/tag.js +1 -1
- package/dist/tag.styles.js +7 -52
- package/dist/textarea.d.ts +2 -2
- package/dist/textarea.js +7 -7
- package/dist/textarea.styles.js +2 -1
- package/dist/toast.d.ts +3 -3
- package/dist/toast.js +1 -1
- package/dist/toast.toasts.d.ts +9 -9
- package/dist/toast.toasts.js +17 -17
- package/dist/toggle.d.ts +2 -2
- package/dist/toggle.js +1 -1
- package/dist/tooltip.container.d.ts +2 -2
- package/dist/tooltip.container.js +1 -1
- package/dist/tooltip.d.ts +3 -3
- package/dist/tooltip.js +1 -1
- package/package.json +4 -4
package/dist/dropdown.js
CHANGED
@@ -1,8 +1,8 @@
|
|
1
|
-
var __decorate=this&&this.__decorate||function(e,
|
1
|
+
var __decorate=this&&this.__decorate||function(t,e,i,s){var o,l=arguments.length,n=l<3?e:null===s?s=Object.getOwnPropertyDescriptor(e,i):s;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)n=Reflect.decorate(t,e,i,s);else for(var a=t.length-1;a>=0;a--)(o=t[a])&&(n=(l<3?o(n):l>3?o(e,i,n):o(e,i))||n);return l>3&&n&&Object.defineProperty(e,i,n),n};import"./checkbox.js";import"./icon-button.js";import"./label.js";import"./tooltip.js";import{html,LitElement}from"lit";import{autoUpdate,computePosition,flip,offset}from"@floating-ui/dom";import{classMap}from"lit/directives/class-map.js";import{createRef,ref}from"lit/directives/ref.js";import{customElement,property,state}from"lit/decorators.js";import{ifDefined}from"lit/directives/if-defined.js";import{repeat}from"lit/directives/repeat.js";import{range}from"lit/directives/range.js";import{map}from"lit/directives/map.js";import{styleMap}from"lit/directives/style-map.js";import{unsafeHTML}from"lit/directives/unsafe-html.js";import{when}from"lit/directives/when.js";import packageJson from"../package.json"with{type:"json"};import onResize from"./library/on-resize.js";import DropdownOption from"./dropdown.option.js";import{LocalizeController}from"./library/localize.js";import Tag from"./tag.js";import chevronIcon from"./icons/chevron.js";import magnifyingGlassIcon from"./icons/magnifying-glass.js";import pencilIcon from"./icons/pencil.js";import styles from"./dropdown.styles.js";import assertSlot from"./library/assert-slot.js";import shadowRootMode from"./library/shadow-root-mode.js";import final from"./library/final.js";import required from"./library/required.js";let Dropdown=class Dropdown extends LitElement{static{this.formAssociated=!0}static{this.shadowRootOptions={...LitElement.shadowRootOptions,mode:shadowRootMode}}static{this.styles=styles}get disabled(){return this.#t}set disabled(t){this.#t=t,this.open&&t?this.#e():this.open&&this.#i()}get filterable(){return this.#s}set filterable(t){this.#s!==t&&t&&!this.multiple?this.#o.value&&this.selectedOptions[0]?.label&&(this.#o.value.value=this.selectedOptions[0].label,this.inputValue=this.selectedOptions[0].label,this.isInputOverflow=this.#o.value.scrollWidth>this.#o.value.clientWidth):this.#s!==t&&this.#l(),this.#s=t}get open(){return this.#n}set open(t){const e=t!==this.#n;if(this.#n=t,t&&e&&!this.disabled)return this.hasNoAvailableOptions=0===this.#a.length,this.#i(),void this.dispatchEvent(new Event("toggle",{bubbles:!0,composed:!0}));if(!this.open&&e){!this.multiple&&this.#o.value&&this.selectedOptions[0]?.label?(this.#o.value.value=this.selectedOptions[0].label,this.inputValue=this.selectedOptions[0].label):(!this.multiple&&this.#o.value&&0===this.selectedOptions.length||this.multiple&&this.#o.value)&&(this.#o.value.value="",this.inputValue=""),this.isFiltering=!1,this.hasNoMatchingOptions=!1,this.isShowSingleSelectIcon=Boolean(this.selectedOptions.at(0)?.value);for(const t of this.#a)t.hidden=!1;this.#e(),this.dispatchEvent(new Event("toggle",{bubbles:!0,composed:!0}))}}get multiple(){return this.#r}set multiple(t){const e=this.#r&&!t,i=!this.#r&&t;this.#r=t,this.isShowSingleSelectIcon=!1;for(const i of this.#a)i.privateMultiple=t,e&&i!==this.lastSelectedOption&&(i.selected=!1);e&&this.lastSelectedOption?.value?this.value=[this.lastSelectedOption.value]:i&&this.lastSelectedOption&&(this.#o.value&&(this.#o.value.value=""),this.lastSelectedOption.privateUpdateCheckbox(),this.#p())}get value(){return this.#d}set value(t){if(this.#d=t,!this.multiple&&t.length>1)throw new Error("Only one value is allowed when not `multiple`.");!this.multiple&&0===this.value.length&&this.#o.value&&1===this.selectedOptions.length&&(this.#o.value.value="");for(const e of this.#a)this.#h=!0,e.selected=t.some((t=>t&&t===e.value)),this.#h=!1,e.selected&&e.disabled&&(e.disabled=!1)}get activeOption(){return this.#c?.find((({privateActive:t})=>t))}checkValidity(){this.isCheckingValidity=!0;const t=this.#u.checkValidity();return this.isCheckingValidity=!1,t}click(){this.filterable||this.isFilterable?(this.#o.value?.click(),this.#o.value?.select()):this.#v.value?.click()}get selectedOptions(){return this.#a.filter((t=>t instanceof DropdownOption&&t.selected&&!t.disabled))}get lastSelectedOption(){return this.#a.findLast((t=>t.selected))}get isAllSelected(){return this.#a.length>0&&this.#a.filter((({selected:t})=>t)).length===this.#a.filter((({disabled:t})=>!t)).length}get isSomeSelected(){return this.#a.some((({selected:t})=>t))}get internalLabel(){const t=this.filterable||this.isFilterable;return t||0!==this.selectedOptions.length?this.multiple||t||!this.selectedOptions.at(-1)?.label?"":this.selectedOptions.at(-1)?.label:this.placeholder}connectedCallback(){super.connectedCallback(),document.addEventListener("click",this.#m,{capture:!0})}createRenderRoot(){return this.#f=super.createRenderRoot(),this.#f}disconnectedCallback(){super.disconnectedCallback(),this.form?.removeEventListener("formdata",this.#g),document.removeEventListener("click",this.#m,{capture:!0})}async filter(t){return this.#a.filter((({label:e})=>e?.toLowerCase().includes(t.toLowerCase().trim())))}firstUpdated(){this.#b.value&&(this.#b.value.popover="manual"),this.open&&!this.disabled&&this.#i(),!this.multiple&&this.lastSelectedOption&&this.#o.value&&this.lastSelectedOption.label&&(this.#o.value.value=this.lastSelectedOption.label);if(this.#a.every((({selected:t})=>!t)))for(const t of this.#a)t.selected=this.value.some((e=>""!==e&&e===t.value)),t.selected&&t.disabled&&(t.disabled=!1)}focus(t){this.filterable||this.isFilterable?this.#o.value?.focus(t):this.#v.value?.focus(t)}get form(){return this.#u.form}get validity(){return this.required&&0===this.selectedOptions.length?(this.#u.setValidity({customError:Boolean(this.validityMessage),valueMissing:!0}," ",this.filterable||this.isFilterable?this.#o.value:this.#v.value),this.#u.validity):this.required&&this.#u.validity.valueMissing&&this.selectedOptions.length>0?(this.#u.setValidity({}),this.#u.validity):this.#u.validity}formAssociatedCallback(){this.form?.addEventListener("formdata",this.#g)}formResetCallback(){for(const t of this.#a){t.hasAttribute("selected")||(t.selected=!1)}const t=this.#a.filter((t=>t.hasAttribute("selected"))),e=t.at(-1)?.value;this.#d=this.multiple&&t.length>0?t.map((({value:t})=>t)):!this.multiple&&e?[e]:[]}render(){return html`<div
|
2
2
|
class=${classMap({component:!0,horizontal:"horizontal"===this.orientation,vertical:"vertical"===this.orientation})}
|
3
|
-
@mouseup=${this.#
|
3
|
+
@mouseup=${this.#O}
|
4
4
|
${onResize(this.#p.bind(this))}
|
5
|
-
${ref(this.#
|
5
|
+
${ref(this.#E)}
|
6
6
|
>
|
7
7
|
<glide-core-private-label
|
8
8
|
label=${ifDefined(this.label)}
|
@@ -10,7 +10,7 @@ var __decorate=this&&this.__decorate||function(e,t,i,s){var o,l=arguments.length
|
|
10
10
|
split=${ifDefined(this.privateSplit??void 0)}
|
11
11
|
tooltip=${ifDefined(this.tooltip)}
|
12
12
|
?disabled=${this.disabled}
|
13
|
-
?error=${this.#
|
13
|
+
?error=${this.#y}
|
14
14
|
?hide=${this.hideLabel}
|
15
15
|
?required=${this.required}
|
16
16
|
>
|
@@ -19,19 +19,19 @@ var __decorate=this&&this.__decorate||function(e,t,i,s){var o,l=arguments.length
|
|
19
19
|
<div
|
20
20
|
class="dropdown-and-options"
|
21
21
|
slot="control"
|
22
|
-
@focusin=${this.#
|
23
|
-
@focusout=${this.#
|
24
|
-
@keydown=${this.#
|
22
|
+
@focusin=${this.#w}
|
23
|
+
@focusout=${this.#R}
|
24
|
+
@keydown=${this.#A}
|
25
25
|
>
|
26
26
|
<div
|
27
|
-
class=${classMap({dropdown:!0,quiet:"quiet"===this.variant,disabled:this.disabled,error:this.#
|
27
|
+
class=${classMap({dropdown:!0,quiet:"quiet"===this.variant,disabled:this.disabled,error:this.#y,readonly:this.readonly,multiple:this.multiple})}
|
28
28
|
@click=${this.#S}
|
29
29
|
@mousedown=${this.#$}
|
30
30
|
${ref(this.#D)}
|
31
31
|
>
|
32
32
|
<span class="selected-option-labels" id="selected-option-labels">
|
33
|
-
${this.selectedOptions.map((({label:
|
34
|
-
${
|
33
|
+
${this.selectedOptions.map((({label:t})=>html`<span data-test="selected-option-label">
|
34
|
+
${t},
|
35
35
|
</span>`))}
|
36
36
|
</span>
|
37
37
|
|
@@ -40,21 +40,20 @@ var __decorate=this&&this.__decorate||function(e,t,i,s){var o,l=arguments.length
|
|
40
40
|
class="tags"
|
41
41
|
${ref(this.#I)}
|
42
42
|
>
|
43
|
-
${repeat(this.selectedOptions,(({id:
|
43
|
+
${repeat(this.selectedOptions,(({id:t})=>t),(({id:t,editable:e,label:i,value:s},o)=>html`<li
|
44
44
|
class=${classMap({"tag-container":!0,hidden:o>this.tagOverflowLimit-1})}
|
45
45
|
data-test="tag-container"
|
46
46
|
data-test-hidden=${o>this.tagOverflowLimit-1}
|
47
47
|
>
|
48
48
|
<glide-core-tag
|
49
49
|
data-test="tag"
|
50
|
-
data-id=${
|
50
|
+
data-id=${t}
|
51
51
|
label=${ifDefined(i)}
|
52
52
|
removable
|
53
|
-
size=${this.size}
|
54
53
|
?disabled=${this.disabled||this.readonly}
|
55
|
-
?private-editable=${
|
56
|
-
@edit=${this.#
|
57
|
-
@remove=${this.#
|
54
|
+
?private-editable=${e}
|
55
|
+
@edit=${this.#F}
|
56
|
+
@remove=${this.#k.bind(this,t)}
|
58
57
|
>
|
59
58
|
${when(s,(()=>html`
|
60
59
|
<slot
|
@@ -93,7 +92,7 @@ var __decorate=this&&this.__decorate||function(e,t,i,s){var o,l=arguments.length
|
|
93
92
|
offset=${8}
|
94
93
|
?disabled=${this.open||!this.isInputOverflow}
|
95
94
|
?open=${!this.open&&this.isInputTooltipOpen}
|
96
|
-
@toggle=${this.#
|
95
|
+
@toggle=${this.#C}
|
97
96
|
screenreader-hidden
|
98
97
|
>
|
99
98
|
<div class="input-container" slot="target">
|
@@ -114,9 +113,9 @@ var __decorate=this&&this.__decorate||function(e,t,i,s){var o,l=arguments.length
|
|
114
113
|
tabindex=${this.disabled?"-1":"0"}
|
115
114
|
?disabled=${this.disabled}
|
116
115
|
?readonly=${this.readonly}
|
117
|
-
@blur=${this.#
|
118
|
-
@focus=${this.#
|
119
|
-
@input=${this.#
|
116
|
+
@blur=${this.#T}
|
117
|
+
@focus=${this.#_}
|
118
|
+
@input=${this.#L}
|
120
119
|
@keydown=${this.#B}
|
121
120
|
${onResize(this.#V.bind(this))}
|
122
121
|
${ref(this.#o)}
|
@@ -143,7 +142,7 @@ var __decorate=this&&this.__decorate||function(e,t,i,s){var o,l=arguments.length
|
|
143
142
|
offset=${8}
|
144
143
|
?disabled=${this.open||this.multiple||this.filterable||this.isFilterable||!this.isInternalLabelOverflow}
|
145
144
|
?open=${!this.open&&this.isInternalLabelTooltipOpen}
|
146
|
-
@toggle=${this.#
|
145
|
+
@toggle=${this.#C}
|
147
146
|
screenreader-hidden
|
148
147
|
>
|
149
148
|
<div
|
@@ -151,7 +150,7 @@ var __decorate=this&&this.__decorate||function(e,t,i,s){var o,l=arguments.length
|
|
151
150
|
data-test="internal-label"
|
152
151
|
slot="target"
|
153
152
|
${onResize(this.#N.bind(this))}
|
154
|
-
${ref(this.#
|
153
|
+
${ref(this.#j)}
|
155
154
|
>
|
156
155
|
${when(this.internalLabel===this.placeholder,(()=>html`<span
|
157
156
|
class=${classMap({placeholder:!0,quiet:"quiet"===this.variant})}
|
@@ -182,8 +181,8 @@ var __decorate=this&&this.__decorate||function(e,t,i,s){var o,l=arguments.length
|
|
182
181
|
tabindex=${this.disabled||this.readonly?"-1":"0"}
|
183
182
|
variant="tertiary"
|
184
183
|
?disabled=${this.disabled||this.readonly}
|
185
|
-
@click=${this.#
|
186
|
-
${ref(this.#
|
184
|
+
@click=${this.#q}
|
185
|
+
${ref(this.#x)}
|
187
186
|
>
|
188
187
|
${pencilIcon}
|
189
188
|
</glide-core-icon-button>`))}
|
@@ -201,9 +200,9 @@ var __decorate=this&&this.__decorate||function(e,t,i,s){var o,l=arguments.length
|
|
201
200
|
tabindex=${this.filterable||this.isFilterable||this.disabled?"-1":"0"}
|
202
201
|
type="button"
|
203
202
|
?disabled=${this.disabled}
|
204
|
-
@focusin=${this.#
|
203
|
+
@focusin=${this.#z}
|
205
204
|
@focusout=${this.#H}
|
206
|
-
${ref(this.#
|
205
|
+
${ref(this.#v)}
|
207
206
|
>
|
208
207
|
${when(this.isFiltering,(()=>html`<div data-test="magnifying-glass-icon">
|
209
208
|
${magnifyingGlassIcon}
|
@@ -214,46 +213,45 @@ var __decorate=this&&this.__decorate||function(e,t,i,s){var o,l=arguments.length
|
|
214
213
|
|
215
214
|
<div
|
216
215
|
class=${classMap({"options-and-footer":!0,optionless:(this.hasNoAvailableOptions||this.hasNoMatchingOptions)&&!this.loading})}
|
217
|
-
${ref(this.#
|
216
|
+
${ref(this.#b)}
|
218
217
|
>
|
219
218
|
<div
|
220
219
|
aria-labelledby=${this.filterable||this.isFilterable?"input":"primary-button"}
|
221
|
-
class=${classMap({options:!0,hidden:this.hasNoAvailableOptions||this.hasNoMatchingOptions||this.loading
|
220
|
+
class=${classMap({options:!0,hidden:this.hasNoAvailableOptions||this.hasNoMatchingOptions||this.loading})}
|
222
221
|
data-test="options"
|
223
222
|
id="options"
|
224
223
|
role="listbox"
|
225
224
|
tabindex="-1"
|
226
225
|
@change=${this.#U}
|
227
|
-
@click=${this.#
|
228
|
-
@focusin=${this.#
|
226
|
+
@click=${this.#W}
|
227
|
+
@focusin=${this.#P}
|
229
228
|
@mousedown=${this.#K}
|
230
229
|
@mouseover=${this.#J}
|
231
|
-
@private-disabled-change=${this.#
|
232
|
-
@private-editable-change=${this.#
|
233
|
-
@private-label-change=${this.#
|
234
|
-
@private-
|
235
|
-
@private-value-change=${this.#ee}
|
230
|
+
@private-disabled-change=${this.#G}
|
231
|
+
@private-editable-change=${this.#Q}
|
232
|
+
@private-label-change=${this.#X}
|
233
|
+
@private-value-change=${this.#Y}
|
236
234
|
>
|
237
235
|
<glide-core-dropdown-option
|
238
236
|
class="select-all"
|
239
237
|
data-test="select-all"
|
240
238
|
label=${this.#M.term("selectAll")}
|
241
|
-
private-size=${this.size}
|
242
239
|
private-multiple
|
243
240
|
?hidden=${!this.selectAll||!this.multiple||this.isFiltering}
|
244
241
|
?private-indeterminate=${this.isSomeSelected&&!this.isAllSelected}
|
245
|
-
${ref(this.#
|
242
|
+
${ref(this.#Z)}
|
246
243
|
></glide-core-dropdown-option>
|
247
244
|
|
248
245
|
<slot
|
249
246
|
class="default-slot"
|
250
|
-
@
|
251
|
-
|
252
|
-
${
|
247
|
+
@private-selected-change=${this.#tt}
|
248
|
+
@slotchange=${this.#et}
|
249
|
+
${assertSlot([DropdownOption,Text],!0)}
|
250
|
+
${ref(this.#it)}
|
253
251
|
>
|
254
252
|
<!--
|
255
253
|
@required
|
256
|
-
@type {
|
254
|
+
@type {DropdownOption}
|
257
255
|
-->
|
258
256
|
</slot>
|
259
257
|
</div>
|
@@ -274,13 +272,13 @@ var __decorate=this&&this.__decorate||function(e,t,i,s){var o,l=arguments.length
|
|
274
272
|
class=${classMap({footer:!0,visible:Boolean(this.addButtonLabel)})}
|
275
273
|
>
|
276
274
|
<button
|
277
|
-
class
|
275
|
+
class="add-button"
|
278
276
|
data-test="add-button"
|
279
277
|
type="button"
|
280
|
-
@click=${this.#
|
281
|
-
@focusin=${this.#
|
282
|
-
@mouseover=${this.#
|
283
|
-
${ref(this.#
|
278
|
+
@click=${this.#st}
|
279
|
+
@focusin=${this.#ot}
|
280
|
+
@mouseover=${this.#lt}
|
281
|
+
${ref(this.#nt)}
|
284
282
|
>
|
285
283
|
${icons.plus} ${this.addButtonLabel}
|
286
284
|
</button>
|
@@ -290,7 +288,7 @@ var __decorate=this&&this.__decorate||function(e,t,i,s){var o,l=arguments.length
|
|
290
288
|
|
291
289
|
<div id="description" slot="description">
|
292
290
|
<slot
|
293
|
-
class=${classMap({description:!0,hidden:Boolean(this.#
|
291
|
+
class=${classMap({description:!0,hidden:Boolean(this.#y&&this.validityMessage)})}
|
294
292
|
name="description"
|
295
293
|
>
|
296
294
|
<!--
|
@@ -299,12 +297,12 @@ var __decorate=this&&this.__decorate||function(e,t,i,s){var o,l=arguments.length
|
|
299
297
|
-->
|
300
298
|
</slot>
|
301
299
|
|
302
|
-
${when(this.#
|
300
|
+
${when(this.#y&&this.validityMessage,(()=>html`<span class="validity-message" data-test="validity-message"
|
303
301
|
>${unsafeHTML(this.validityMessage)}</span
|
304
302
|
>`))}
|
305
303
|
</div>
|
306
304
|
</glide-core-private-label>
|
307
|
-
</div>`}reportValidity(){this.isReportValidityOrSubmit=!0;const e=this.#v.reportValidity();return this.requestUpdate(),e}resetValidityFeedback(){this.isReportValidityOrSubmit=!1}setCustomValidity(e){this.validityMessage=e,""===e?this.#v.setValidity({customError:!1},"",this.filterable||this.isFilterable?this.#o.value:this.#m.value):this.#v.setValidity({customError:!0,valueMissing:this.#v.validity.valueMissing}," ",this.filterable||this.isFilterable?this.#o.value:this.#m.value)}setValidity(e,t){this.validityMessage=t,this.#v.setValidity(e," ",this.filterable||this.isFilterable?this.#o.value:this.#m.value)}constructor(){super(),this.hideLabel=!1,this.loading=!1,this.name="",this.orientation="horizontal",this.readonly=!1,this.selectAll=!1,this.required=!1,this.version=packageJson.version,this.ariaActivedescendant="",this.hasNoAvailableOptions=!1,this.hasNoMatchingOptions=!1,this.inputValue="",this.isBlurring=!1,this.isCheckingValidity=!1,this.isCommunicateItemCountToScreenreaders=!1,this.isFilterable=!1,this.isFiltering=!1,this.isInputOverflow=!1,this.isInputTooltipOpen=!1,this.isInternalLabelOverflow=!1,this.isInternalLabelTooltipOpen=!1,this.isReportValidityOrSubmit=!1,this.isShowSingleSelectIcon=!1,this.itemCount=0,this.tagOverflowLimit=0,this.#ae=createRef(),this.#y=createRef(),this.#se=createRef(),this.#D=createRef(),this.#q=createRef(),this.#o=createRef(),this.#z=createRef(),this.#re=!1,this.#e=!1,this.#pe=!1,this.#s=!1,this.#de=!0,this.#r=!1,this.#n=!1,this.#he=!1,this.#ce=!1,this.#u=!1,this.#ue=!1,this.#ve=!1,this.#M=new LocalizeController(this),this.#O=createRef(),this.#m=createRef(),this.#te=createRef(),this.#d="large",this.#I=createRef(),this.#c=[],this.#f=()=>{this.#re?setTimeout((()=>{this.#re=!1})):this.open=!1},this.#b=({formData:e})=>{this.name&&this.value.length>0&&!this.disabled&&e.append(this.name,JSON.stringify(this.value))},this.#v=this.attachInternals(),this.addEventListener("invalid",(e=>{if(e.preventDefault(),this.isCheckingValidity||this.isBlurring)return;this.isReportValidityOrSubmit=!0;this.form?.querySelector(":invalid")===this&&this.focus()}))}#ae;#me;#y;#se;#D;#q;#o;#z;#v;#re;#e;#pe;#s;#de;#r;#n;#he;#ce;#u;#ue;#ve;#M;#O;#fe;#m;#te;#g;#d;#I;#c;#f;#b;#t(){this.#me?.(),this.#O.value?.hidePopover(),this.ariaActivedescendant="",this.activeOption&&(this.#fe=this.activeOption,this.activeOption.privateIsTooltipOpen=!1,this.activeOption.privateActive=!1)}get#w(){return!this.disabled&&!this.validity.valid&&this.isReportValidityOrSubmit}#oe(){this.open=!1,this.dispatchEvent(new Event("add",{bubbles:!0,composed:!0}))}#le(){this.activeOption&&(this.activeOption.privateIsTooltipOpen=!1,this.#fe=this.activeOption,this.activeOption.privateActive=!1)}#ne(){this.activeOption&&!this.#he&&(this.#fe=this.activeOption,this.activeOption.privateActive=!1)}#E(){this.#re=!0}async#ie(){this.#de&&(this.isFilterable=this.#a.length>10,this.#de=!1),this.tagOverflowLimit=this.selectedOptions.length,this.hasNoAvailableOptions=0===this.#a.length;for(const e of this.#a)e.privateSize=this.size,e.privateMultiple=this.multiple;const e=this.#ge?.find((e=>!e.disabled));!this.activeOption&&this.lastSelectedOption?(this.lastSelectedOption.privateActive=!0,this.#fe=this.lastSelectedOption,this.ariaActivedescendant=this.open?this.lastSelectedOption.id:""):!this.activeOption&&e&&(this.#fe=e,this.ariaActivedescendant=this.open?e.id:"",e.privateActive=!0),this.#te.value&&(this.#u=!0,this.#te.value.selected=this.isAllSelected,this.#u=!1),this.multiple?this.#c=this.selectedOptions.filter((e=>Boolean(e.value)&&!e.disabled)).map((({value:e})=>e)):this.lastSelectedOption?.value&&!this.lastSelectedOption.disabled&&(this.#c=[this.lastSelectedOption.value]),this.requestUpdate(),await this.updateComplete,!this.multiple&&this.#o.value&&this.lastSelectedOption?.label?(this.#o.value.value=this.lastSelectedOption.label,this.inputValue=this.lastSelectedOption.label,this.isInputOverflow=this.#o.value.scrollWidth>this.#o.value.clientWidth):this.multiple||!this.#o.value||this.isFiltering||(this.#o.value.value="",this.inputValue="",this.isInputOverflow=this.#o.value.scrollWidth>this.#o.value.clientWidth)}#R(e){this.open&&this.#fe&&e.relatedTarget===this.#ae.value&&(this.#fe.privateActive=!0,this.#fe.privateIsTooltipOpen=!this.#fe.editable)}#A(e){(null===e.relatedTarget||e.relatedTarget instanceof Node&&!this.#g?.contains(e.relatedTarget)&&!this.contains(e.relatedTarget))&&!this.#pe&&(this.open=!1,this.isBlurring=!0,this.reportValidity(),this.isBlurring=!1)}#C(e){if(this.disabled||this.readonly)return;if(("Enter"===e.key||" "===e.key)&&e.target===this.#q.value)return void(this.#re=!0);if(!this.open&&"Enter"===e.key)return void this.form?.requestSubmit();if(this.open&&"ArrowUp"===e.key&&this.#g?.activeElement===this.#ae.value)return this.focus(),void(this.#fe&&(this.#fe.privateActive=!0,this.#fe.privateIsEditActive=this.#fe.editable,this.#fe.privateIsTooltipOpen=!this.#fe.privateIsEditActive));if(this.open&&"ArrowDown"===e.key&&this.#g?.activeElement===this.#ae.value)return void e.preventDefault();if(this.open&&"ArrowDown"===e.key&&this.addButtonLabel&&this.activeOption===this.#be?.at(-1)&&(!this.activeOption?.editable||this.activeOption?.privateIsEditActive))return e.preventDefault(),this.activeOption&&(this.#fe=this.activeOption,this.activeOption.privateIsTooltipOpen=!1,this.activeOption.privateActive=!1),void this.#ae.value?.focus();if("Escape"===e.key)return e.preventDefault(),this.open=!1,void(this.#g?.activeElement===this.#ae.value&&this.focus());const t=e.target===this.#m.value||e.target===this.#o.value||e.target instanceof GlideCoreDropdownOption;if(!this.multiple||t){if(!this.open&&[" ","ArrowUp","ArrowDown"].includes(e.key))return e.preventDefault(),this.open=!0,void(this.activeOption&&(this.activeOption.privateIsTooltipOpen=!this.activeOption.privateIsEditActive));if(this.activeOption&&this.open){if("Enter"===e.key||" "===e.key){if(this.activeOption.privateIsEditActive)return this.activeOption.privateEdit(),void(this.open=!1);if("Enter"===e.key&&this.#be&&this.#be.length>0||" "===e.key&&!this.filterable&&!this.isFilterable)return this.#ve=!0,e.preventDefault(),this.isFiltering=!1,this.activeOption.selected=!this.multiple||!this.activeOption.selected,this.activeOption===this.#te.value&&this.#Oe(),this.#ve=!1,this.#l(),this.multiple||(this.open=!1),this.dispatchEvent(new Event("input",{bubbles:!0,composed:!0})),void this.dispatchEvent(new Event("change",{bubbles:!0,composed:!0}))}const t=this.#ge?.indexOf(this.activeOption);if("ArrowUp"===e.key&&!e.metaKey&&this.#ge&&"number"==typeof t){e.preventDefault();const i=this.#ge.findLast(((e,i)=>!e.disabled&&i<t));return void(this.activeOption?.privateIsEditActive?(this.activeOption.privateIsEditActive=!1,this.activeOption.privateIsTooltipOpen=!0):i&&0!==t&&(this.activeOption.privateIsEditActive=!1,this.activeOption.privateIsTooltipOpen=!1,this.activeOption.privateActive=!1,this.ariaActivedescendant=i.id,this.#fe=i,i.privateActive=!0,i.privateIsEditActive=i.editable,i.privateIsTooltipOpen=!i.editable,i.scrollIntoView({block:"center"})))}if("ArrowDown"===e.key&&!e.metaKey&&this.#ge&&"number"==typeof t){e.preventDefault();const i=this.#ge.find(((e,i)=>!e.disabled&&i>t));return void(this.activeOption.editable&&!this.activeOption.privateIsEditActive?(this.activeOption.privateIsEditActive=!0,this.activeOption.privateIsTooltipOpen=!1):i&&(this.activeOption.privateIsEditActive=!1,this.activeOption.privateIsTooltipOpen=!1,this.activeOption.privateActive=!1,this.ariaActivedescendant=i.id,this.#fe=i,i.privateActive=!0,i.privateIsTooltipOpen=!0,i.scrollIntoView({block:"center"})))}if(("ArrowUp"===e.key&&e.metaKey||"Home"===e.key||"PageUp"===e.key)&&this.#ge){e.preventDefault();const t=[...this.#ge].reverse().findLast((e=>!e.disabled));return void(t&&(this.activeOption.privateIsEditActive=!1,this.activeOption.privateIsTooltipOpen=!1,this.activeOption.privateActive=!1,this.ariaActivedescendant=t.id,this.#fe=t,t.privateActive=!0,t.privateIsTooltipOpen=!0,t.scrollIntoView({block:"nearest"})))}if(("ArrowDown"===e.key&&e.metaKey||"End"===e.key||"PageDown"===e.key)&&this.#ge){e.preventDefault();const t=[...this.#ge].findLast((e=>!e.disabled));return void(t&&this.activeOption&&(this.activeOption.privateIsEditActive=!1,this.activeOption.privateIsTooltipOpen=!1,this.activeOption.privateActive=!1,this.ariaActivedescendant=t.id,this.#fe=t,t.privateActive=!0,t.privateIsTooltipOpen=!0,t.scrollIntoView({block:"nearest"})))}}}}#S(e){if(this.disabled||this.readonly)return;if(this.#pe)return void(this.#pe=!1);if(e.target instanceof Node&&this.#q.value?.contains(e.target))return void this.selectedOptions[0]?.privateEdit();const t=this.filterable||this.isFilterable;if(this.#ve||!this.open||t&&!(e.target instanceof Element&&this.#m.value?.contains(e.target)))return 0!==e.detail?(this.open=!0,this.focus(),this.#he=!0,void setTimeout((()=>{this.#he=!1}))):void 0;this.open=!1}#$(e){const t=this.filterable||this.isFilterable,i=e.target instanceof GlideCoreTag;t&&!i?e.target!==this.#o.value&&(e.preventDefault(),this.focus()):i||e.preventDefault()}#j(){this.open=!1}#_(){this.isCommunicateItemCountToScreenreaders=!1,this.isInputTooltipOpen=!1}#L(){this.#o.value?.select(),this.isInputTooltipOpen=!0}async#G(e){let t;if(e.stopPropagation(),this.open=!0,this.isShowSingleSelectIcon=!1,this.#o.value?.value&&(this.inputValue=this.#o.value.value),this.multiple&&""!==this.#o.value?.value?this.isFiltering=!0:this.multiple?this.isFiltering=!1:""!==this.#o.value?.value&&this.#o.value?.value!==this.selectedOptions.at(0)?.label?this.isFiltering=!0:this.isFiltering=!1,this.#o.value)try{t=await this.filter(this.#o.value.value)}catch{}if(t){for(const e of this.#a)e.hidden=!t.includes(e);const e=this.#be?.at(0);e&&this.activeOption?.hidden&&(this.activeOption.privateActive=!1,this.#fe=e,this.ariaActivedescendant=e.id,e.privateActive=!0),this.hasNoMatchingOptions=!this.#be||0===this.#be.length,this.isCommunicateItemCountToScreenreaders=!0,this.#be&&(this.itemCount=this.#be.length)}}#B(e){const t=this.selectedOptions.findLast(((e,t)=>t<=this.tagOverflowLimit-1));if(t&&"Backspace"===e.key&&!e.metaKey&&this.multiple&&this.#o.value&&0===this.#o.value.selectionStart)return this.#pe=!0,t.selected=!1,void(this.#pe=!1);const i=this.selectedOptions.filter(((e,t)=>t<=this.tagOverflowLimit-1));if(t&&"Backspace"===e.key&&e.metaKey&&this.multiple&&this.#o.value&&0===this.#o.value.selectionStart){this.#pe=!0;for(const e of i)e.selected=!1;this.#pe=!1}else;}#V(){this.#o.value&&(this.isInputOverflow=this.#o.value.scrollWidth-1>this.#o.value.clientWidth)}#N(){this.#z.value&&(this.isInternalLabelOverflow=this.#z.value.scrollWidth>this.#z.value.clientWidth)}get#a(){return this.#se.value?.assignedElements().filter((e=>e instanceof GlideCoreDropdownOption))??[]}get#h(){const e=this.#se.value?.assignedElements().filter((e=>e instanceof GlideCoreDropdownOption));if(e&&this.#te.value)return[this.#te.value,...e]}get#be(){return this.#se.value?.assignedElements().filter((e=>e instanceof GlideCoreDropdownOption&&!e.hidden))}get#ge(){const e=this.#se.value?.assignedElements().filter((e=>e instanceof GlideCoreDropdownOption&&!e.hidden));return this.#te.value&&!this.#te.value.hidden&&e?[this.#te.value,...e]:e}#U(e){e.target instanceof GlideCoreDropdownOption&&(e.target.selected=!e.target.selected),e.target===this.#te.value&&this.#Oe(),this.#l()}#P(e){if(e.target instanceof Element){const t=e.target.closest("glide-core-dropdown-option");if(t instanceof GlideCoreDropdownOption&&t.disabled)return;if(t instanceof GlideCoreDropdownOption&&t.privateIsEditActive)return t.privateEdit(),void(this.open=!1);if(t&&!t.selected)return t.selected=!0,this.#l(),this.multiple||(this.open=!1),this.dispatchEvent(new Event("input",{bubbles:!0,composed:!0})),void this.dispatchEvent(new Event("change",{bubbles:!0,composed:!0}));if(t?.selected&&!this.multiple)return void(this.open=!1)}}#Q(e){if(e.target instanceof GlideCoreDropdownOption&&e.target.disabled&&e.target.selected){const t=this.#c.lastIndexOf(e.target.value);this.#c.splice(t,t+1)}else this.multiple&&e.target instanceof GlideCoreDropdownOption&&e.target.selected&&e.target.value?this.#c.push(e.target.value):e.target instanceof GlideCoreDropdownOption&&e.target.selected&&e.target.value&&e.target===this.lastSelectedOption&&(this.#c=[e.target.value]);this.requestUpdate()}#X(){this.requestUpdate()}#W(e){e.target instanceof GlideCoreDropdownOption&&(this.activeOption&&(this.activeOption.privateActive=!1),e.target.privateActive=!0,this.#fe=e.target)}#Y(){this.selectedOptions.length>0&&(this.multiple?(this.requestUpdate(),this.updateComplete.then((()=>{this.#p()}))):(this.filterable||this.isFilterable)&&this.#o.value&&this.selectedOptions[0]?.label?(this.#o.value.value=this.selectedOptions[0].label,this.inputValue=this.selectedOptions[0].label,this.isInputOverflow=this.#o.value.scrollWidth>this.#o.value.clientWidth):this.requestUpdate())}#K(e){(this.filterable||this.isFilterable)&&e.preventDefault()}#J(e){if(e.target instanceof GlideCoreDropdownOption&&this.#ge){if(e.target.disabled)return;this.activeOption&&(this.activeOption.privateIsTooltipOpen=!1,this.activeOption.privateActive=!1),this.ariaActivedescendant=e.target.id,this.#fe=e.target,e.target.privateActive=!0,e.target.privateIsEditActive=!1,this.#g?.activeElement===this.#ae.value&&this.focus()}}#Z(e){if(!this.multiple)for(const t of this.#a)t!==e.target&&e.target instanceof GlideCoreDropdownOption&&e.target.selected&&t.selected&&e.target!==this.#te.value&&(t.selected=!1);e.target!==this.#te.value&&!this.#ue&&this.#te.value&&(this.#te.value.selected=this.isAllSelected),this.isShowSingleSelectIcon=!this.multiple&&Boolean(this.selectedOptions.at(0)?.value),e.target instanceof GlideCoreDropdownOption&&(this.multiple&&!this.#u?(this.#c=e.target.selected&&e.target.value&&!e.target.disabled?[...this.value,e.target.value]:this.value.filter((t=>e.target instanceof GlideCoreDropdownOption&&t!==e.target.value)),this.#o.value&&!this.#pe&&(this.isFiltering=!1,this.#o.value.value="",this.inputValue="")):this.multiple||!e.target.selected||e.target.disabled||(this.#c=e.target.value?[e.target.value]:[],this.#o.value&&e.target.label&&(this.isFiltering=!1,this.#o.value.value=e.target.label,this.inputValue=e.target.label))),this.#o.value&&(this.isInputOverflow=this.#o.value.scrollWidth>this.#o.value.clientWidth),this.requestUpdate(),this.updateComplete.then((()=>{this.#p()}))}#ee(e){e.target instanceof GlideCoreDropdownOption&&this.multiple&&e.target.selected&&e.detail.new?this.#c=this.value.map((t=>t===e.detail.old?e.detail.new:t)):e.target instanceof GlideCoreDropdownOption&&this.multiple?this.#c=this.value.filter((t=>t!==e.detail.old)):e.target instanceof GlideCoreDropdownOption&&(this.#c=e.detail.new?[e.detail.new]:[])}#x(){this.isInternalLabelTooltipOpen=!0}#H(){this.isInternalLabelTooltipOpen=!1}#k(){this.#pe=!0,this.open=!1}async#F(e){this.#pe=!0;for(const t of this.#a)t.id===e&&(t.selected=!1,this.#c=this.value.filter((e=>e!==t.value)));const t=this.#I.value?.querySelectorAll("glide-core-tag");if(t&&this.selectedOptions.length>0){const i=[...t].findIndex((t=>t.dataset.id===e)),s=t[i<t.length-1?i+1:i-1];await this.updateComplete,setTimeout((()=>{s?.focus(),this.#pe=!1}))}else setTimeout((()=>{this.focus(),this.#pe=!1}));this.dispatchEvent(new Event("input",{bubbles:!0,composed:!0})),this.dispatchEvent(new Event("change",{bubbles:!0,composed:!0}))}#T(e){e.stopPropagation()}#Oe(){this.#ue=!0;for(const e of this.#a)!this.#te.value?.selected||e.selected||e.disabled?!this.#te.value?.selected&&e.selected&&(e.selected=!1):e.selected=!0;this.#ue=!1}async#p(){if(this.#y.value){const e=this.#y.value.scrollWidth>this.#y.value.clientWidth;e&&this.tagOverflowLimit>1?(this.tagOverflowLimit=this.tagOverflowLimit-1,await this.updateComplete,this.#p()):!e&&!this.#ce&&this.tagOverflowLimit<this.selectedOptions.length?(this.tagOverflowLimit=this.tagOverflowLimit+1,this.#ce=!0,await this.updateComplete,this.#p()):this.#ce=!1}}#i(){this.#me?.(),this.#fe&&(this.#fe.privateActive=!0,this.ariaActivedescendant=this.#fe.id),this.#D.value&&this.#O.value&&(this.#me=autoUpdate(this.#D.value,this.#O.value,(()=>{(async()=>{if(this.#D.value&&this.#O.value){const{x:e,y:t,placement:i}=await computePosition(this.#D.value,this.#O.value,{placement:"bottom-start",middleware:[offset({mainAxis:Number.parseFloat(window.getComputedStyle(document.body).getPropertyValue("--glide-core-spacing-base-xxs"))*Number.parseFloat(window.getComputedStyle(document.documentElement).fontSize)}),flip()]});this.#O.value.dataset.placement=i,Object.assign(this.#O.value.style,{left:`${e}px`,top:`${t}px`}),this.#O.value?.showPopover()}})()})))}#l(){if((this.filterable||this.isFilterable)&&this.#o.value){this.isFiltering=!1;for(const e of this.#a)e.hidden=!1}}};__decorate([property({reflect:!0}),required],GlideCoreDropdown.prototype,"label",void 0),__decorate([property({attribute:"add-button-label",reflect:!0})],GlideCoreDropdown.prototype,"addButtonLabel",void 0),__decorate([property({reflect:!0,type:Boolean})],GlideCoreDropdown.prototype,"disabled",null),__decorate([property({reflect:!0,type:Boolean})],GlideCoreDropdown.prototype,"filterable",null),__decorate([property({attribute:"hide-label",reflect:!0,type:Boolean})],GlideCoreDropdown.prototype,"hideLabel",void 0),__decorate([property({reflect:!0,type:Boolean})],GlideCoreDropdown.prototype,"loading",void 0),__decorate([property({reflect:!0,useDefault:!0})],GlideCoreDropdown.prototype,"name",void 0),__decorate([property({reflect:!0,type:Boolean})],GlideCoreDropdown.prototype,"open",null),__decorate([property({reflect:!0,useDefault:!0})],GlideCoreDropdown.prototype,"orientation",void 0),__decorate([property({reflect:!0})],GlideCoreDropdown.prototype,"placeholder",void 0),__decorate([property()],GlideCoreDropdown.prototype,"privateSplit",void 0),__decorate([property({reflect:!0,type:Boolean})],GlideCoreDropdown.prototype,"readonly",void 0),__decorate([property({attribute:"select-all",reflect:!0,type:Boolean})],GlideCoreDropdown.prototype,"selectAll",void 0),__decorate([property({reflect:!0,type:Boolean})],GlideCoreDropdown.prototype,"required",void 0),__decorate([property({reflect:!0,type:Boolean})],GlideCoreDropdown.prototype,"multiple",null),__decorate([property({reflect:!0})],GlideCoreDropdown.prototype,"size",null),__decorate([property({reflect:!0})],GlideCoreDropdown.prototype,"tooltip",void 0),__decorate([property({type:Array})],GlideCoreDropdown.prototype,"value",null),__decorate([property({reflect:!0})],GlideCoreDropdown.prototype,"variant",void 0),__decorate([property({reflect:!0})],GlideCoreDropdown.prototype,"version",void 0),__decorate([state()],GlideCoreDropdown.prototype,"ariaActivedescendant",void 0),__decorate([state()],GlideCoreDropdown.prototype,"hasNoAvailableOptions",void 0),__decorate([state()],GlideCoreDropdown.prototype,"hasNoMatchingOptions",void 0),__decorate([state()],GlideCoreDropdown.prototype,"inputValue",void 0),__decorate([state()],GlideCoreDropdown.prototype,"isBlurring",void 0),__decorate([state()],GlideCoreDropdown.prototype,"isCheckingValidity",void 0),__decorate([state()],GlideCoreDropdown.prototype,"isCommunicateItemCountToScreenreaders",void 0),__decorate([state()],GlideCoreDropdown.prototype,"isFilterable",void 0),__decorate([state()],GlideCoreDropdown.prototype,"isFiltering",void 0),__decorate([state()],GlideCoreDropdown.prototype,"isInputOverflow",void 0),__decorate([state()],GlideCoreDropdown.prototype,"isInputTooltipOpen",void 0),__decorate([state()],GlideCoreDropdown.prototype,"isInternalLabelOverflow",void 0),__decorate([state()],GlideCoreDropdown.prototype,"isInternalLabelTooltipOpen",void 0),__decorate([state()],GlideCoreDropdown.prototype,"isReportValidityOrSubmit",void 0),__decorate([state()],GlideCoreDropdown.prototype,"isShowSingleSelectIcon",void 0),__decorate([state()],GlideCoreDropdown.prototype,"itemCount",void 0),__decorate([state()],GlideCoreDropdown.prototype,"tagOverflowLimit",void 0),__decorate([state()],GlideCoreDropdown.prototype,"validityMessage",void 0),GlideCoreDropdown=__decorate([customElement("glide-core-dropdown"),final],GlideCoreDropdown);export default GlideCoreDropdown;const icons={plus:html`
|
305
|
+
</div>`}reportValidity(){this.isReportValidityOrSubmit=!0;const t=this.#u.reportValidity();return this.requestUpdate(),t}resetValidityFeedback(){this.isReportValidityOrSubmit=!1}setCustomValidity(t){this.validityMessage=t,""===t?this.#u.setValidity({customError:!1},"",this.filterable||this.isFilterable?this.#o.value:this.#v.value):this.#u.setValidity({customError:!0,valueMissing:this.#u.validity.valueMissing}," ",this.filterable||this.isFilterable?this.#o.value:this.#v.value)}setValidity(t,e){this.validityMessage=e,this.#u.setValidity(t," ",this.filterable||this.isFilterable?this.#o.value:this.#v.value)}constructor(){super(),this.hideLabel=!1,this.loading=!1,this.name="",this.orientation="horizontal",this.readonly=!1,this.selectAll=!1,this.required=!1,this.version=packageJson.version,this.ariaActivedescendant="",this.hasNoAvailableOptions=!1,this.hasNoMatchingOptions=!1,this.inputValue="",this.isBlurring=!1,this.isCheckingValidity=!1,this.isCommunicateItemCountToScreenreaders=!1,this.isFilterable=!1,this.isFiltering=!1,this.isInputOverflow=!1,this.isInputTooltipOpen=!1,this.isInternalLabelOverflow=!1,this.isInternalLabelTooltipOpen=!1,this.isReportValidityOrSubmit=!1,this.isShowSingleSelectIcon=!1,this.itemCount=0,this.tagOverflowLimit=0,this.#nt=createRef(),this.#E=createRef(),this.#it=createRef(),this.#D=createRef(),this.#x=createRef(),this.#o=createRef(),this.#j=createRef(),this.#at=!1,this.#t=!1,this.#rt=!1,this.#s=!1,this.#pt=!0,this.#r=!1,this.#n=!1,this.#dt=!1,this.#ht=!1,this.#ct=!1,this.#h=!1,this.#ut=!1,this.#M=new LocalizeController(this),this.#b=createRef(),this.#v=createRef(),this.#Z=createRef(),this.#I=createRef(),this.#d=[],this.#m=()=>{this.#at?setTimeout((()=>{this.#at=!1})):this.open=!1},this.#g=({formData:t})=>{this.name&&this.value.length>0&&!this.disabled&&t.append(this.name,JSON.stringify(this.value))},this.#u=this.attachInternals(),this.addEventListener("invalid",(t=>{if(t.preventDefault(),this.isCheckingValidity||this.isBlurring)return;this.isReportValidityOrSubmit=!0;this.form?.querySelector(":invalid")===this&&this.focus()}))}#nt;#vt;#E;#it;#D;#x;#o;#j;#u;#at;#t;#rt;#s;#pt;#r;#n;#dt;#ht;#ct;#h;#ut;#M;#b;#mt;#v;#Z;#f;#I;#d;#m;#g;#e(){this.#vt?.(),this.#b.value?.hidePopover(),this.ariaActivedescendant="",this.activeOption&&(this.#mt=this.activeOption,this.activeOption.privateIsTooltipOpen=!1,this.activeOption.privateActive=!1)}get#y(){return!this.disabled&&!this.validity.valid&&this.isReportValidityOrSubmit}#st(){this.open=!1,this.dispatchEvent(new Event("add",{bubbles:!0,composed:!0}))}#ot(){this.activeOption&&(this.activeOption.privateIsTooltipOpen=!1,this.#mt=this.activeOption,this.activeOption.privateActive=!1)}#lt(){this.activeOption&&!this.#dt&&(this.#mt=this.activeOption,this.activeOption.privateActive=!1)}#O(){this.#at=!0}async#et(){this.#pt&&(this.isFilterable=this.#a.length>10,this.#pt=!1),this.tagOverflowLimit=this.selectedOptions.length,this.hasNoAvailableOptions=0===this.#a.length;for(const t of this.#a)t.privateMultiple=this.multiple;const t=this.#ft?.find((t=>!t.disabled));!this.activeOption&&this.lastSelectedOption?(this.lastSelectedOption.privateActive=!0,this.#mt=this.lastSelectedOption,this.ariaActivedescendant=this.open?this.lastSelectedOption.id:""):!this.activeOption&&t&&(this.#mt=t,this.ariaActivedescendant=this.open?t.id:"",t.privateActive=!0),this.#Z.value&&(this.#Z.value.selected=this.isAllSelected),this.multiple?this.#d=this.selectedOptions.filter((t=>Boolean(t.value)&&!t.disabled)).map((({value:t})=>t)):this.lastSelectedOption?.value&&!this.lastSelectedOption.disabled&&(this.#d=[this.lastSelectedOption.value],this.isShowSingleSelectIcon=Boolean(this.selectedOptions.at(0)?.value)),this.requestUpdate(),await this.updateComplete,!this.multiple&&this.#o.value&&this.lastSelectedOption?.label?(this.#o.value.value=this.lastSelectedOption.label,this.inputValue=this.lastSelectedOption.label,this.isInputOverflow=this.#o.value.scrollWidth>this.#o.value.clientWidth):this.multiple||!this.#o.value||this.isFiltering||(this.#o.value.value="",this.inputValue="",this.isInputOverflow=this.#o.value.scrollWidth>this.#o.value.clientWidth)}#w(t){this.open&&this.#mt&&t.relatedTarget===this.#nt.value&&(this.#mt.privateActive=!0,this.#mt.privateIsTooltipOpen=!this.#mt.editable)}#R(t){(null===t.relatedTarget||t.relatedTarget instanceof Node&&!this.#f?.contains(t.relatedTarget)&&!this.contains(t.relatedTarget))&&!this.#rt&&(this.open=!1,this.isBlurring=!0,this.reportValidity(),this.isBlurring=!1)}#A(t){if(this.disabled||this.readonly)return;if(("Enter"===t.key||" "===t.key)&&t.target===this.#x.value)return void(this.#at=!0);if(!this.open&&"Enter"===t.key)return void this.form?.requestSubmit();if(this.open&&"ArrowUp"===t.key&&this.#f?.activeElement===this.#nt.value)return this.focus(),void(this.#mt&&(this.#mt.privateActive=!0,this.#mt.privateIsEditActive=this.#mt.editable,this.#mt.privateIsTooltipOpen=!this.#mt.privateIsEditActive));if(this.open&&"ArrowDown"===t.key&&this.#f?.activeElement===this.#nt.value)return void t.preventDefault();if(this.open&&"ArrowDown"===t.key&&this.addButtonLabel&&this.activeOption===this.#gt?.at(-1)&&(!this.activeOption?.editable||this.activeOption?.privateIsEditActive))return t.preventDefault(),this.activeOption&&(this.#mt=this.activeOption,this.activeOption.privateIsTooltipOpen=!1,this.activeOption.privateActive=!1),void this.#nt.value?.focus();if("Escape"===t.key)return t.preventDefault(),this.open=!1,void(this.#f?.activeElement===this.#nt.value&&this.focus());const e=t.target===this.#v.value||t.target===this.#o.value||t.target instanceof DropdownOption;if(!this.multiple||e){if(!this.open&&[" ","ArrowUp","ArrowDown"].includes(t.key))return t.preventDefault(),this.open=!0,void(this.activeOption&&(this.activeOption.privateIsTooltipOpen=!this.activeOption.privateIsEditActive));if(this.activeOption&&this.open){if("Enter"===t.key||" "===t.key){if(this.activeOption.privateIsEditActive)return this.activeOption.privateEdit(),void(this.open=!1);if("Enter"===t.key&&this.#gt&&this.#gt.length>0||" "===t.key&&!this.filterable&&!this.isFilterable)return this.#ut=!0,t.preventDefault(),this.isFiltering=!1,this.activeOption.selected=!this.multiple||!this.activeOption.selected,this.activeOption===this.#Z.value&&this.#bt(),this.#ut=!1,this.#l(),this.multiple||(this.open=!1),this.dispatchEvent(new Event("input",{bubbles:!0,composed:!0})),void this.dispatchEvent(new Event("change",{bubbles:!0,composed:!0}))}const e=this.#ft?.indexOf(this.activeOption);if("ArrowUp"===t.key&&!t.metaKey&&this.#ft&&"number"==typeof e){t.preventDefault();const i=this.#ft.findLast(((t,i)=>!t.disabled&&i<e));return void(this.activeOption?.privateIsEditActive?(this.activeOption.privateIsEditActive=!1,this.activeOption.privateIsTooltipOpen=!0):i&&0!==e&&(this.activeOption.privateIsEditActive=!1,this.activeOption.privateIsTooltipOpen=!1,this.activeOption.privateActive=!1,this.ariaActivedescendant=i.id,this.#mt=i,i.privateActive=!0,i.privateIsEditActive=i.editable,i.privateIsTooltipOpen=!i.editable,i.scrollIntoView({block:"center"})))}if("ArrowDown"===t.key&&!t.metaKey&&this.#ft&&"number"==typeof e){t.preventDefault();const i=this.#ft.find(((t,i)=>!t.disabled&&i>e));return void(this.activeOption.editable&&!this.activeOption.privateIsEditActive?(this.activeOption.privateIsEditActive=!0,this.activeOption.privateIsTooltipOpen=!1):i&&(this.activeOption.privateIsEditActive=!1,this.activeOption.privateIsTooltipOpen=!1,this.activeOption.privateActive=!1,this.ariaActivedescendant=i.id,this.#mt=i,i.privateActive=!0,i.privateIsTooltipOpen=!0,i.scrollIntoView({block:"center"})))}if(("ArrowUp"===t.key&&t.metaKey||"Home"===t.key||"PageUp"===t.key)&&this.#ft){t.preventDefault();const e=[...this.#ft].reverse().findLast((t=>!t.disabled));return void(e&&(this.activeOption.privateIsEditActive=!1,this.activeOption.privateIsTooltipOpen=!1,this.activeOption.privateActive=!1,this.ariaActivedescendant=e.id,this.#mt=e,e.privateActive=!0,e.privateIsTooltipOpen=!0,e.scrollIntoView({block:"nearest"})))}if(("ArrowDown"===t.key&&t.metaKey||"End"===t.key||"PageDown"===t.key)&&this.#ft){t.preventDefault();const e=[...this.#ft].findLast((t=>!t.disabled));return void(e&&this.activeOption&&(this.activeOption.privateIsEditActive=!1,this.activeOption.privateIsTooltipOpen=!1,this.activeOption.privateActive=!1,this.ariaActivedescendant=e.id,this.#mt=e,e.privateActive=!0,e.privateIsTooltipOpen=!0,e.scrollIntoView({block:"nearest"})))}}}}#S(t){if(this.disabled||this.readonly)return;if(this.#rt)return void(this.#rt=!1);if(t.target instanceof Node&&this.#x.value?.contains(t.target))return void this.selectedOptions[0]?.privateEdit();const e=this.filterable||this.isFilterable;if(this.#ut||!this.open||e&&!(t.target instanceof Element&&this.#v.value?.contains(t.target)))return 0!==t.detail?(this.open=!0,this.focus(),this.#dt=!0,void setTimeout((()=>{this.#dt=!1}))):void 0;this.open=!1}#$(t){const e=this.filterable||this.isFilterable,i=t.target instanceof Tag;e&&!i?t.target!==this.#o.value&&(t.preventDefault(),this.focus()):i||t.preventDefault()}#q(){this.open=!1}#T(){this.isCommunicateItemCountToScreenreaders=!1,this.isInputTooltipOpen=!1}#_(){this.#o.value?.select(),this.isInputTooltipOpen=!0}async#L(t){let e;if(t.stopPropagation(),this.open=!0,this.isShowSingleSelectIcon=!1,this.#o.value?.value&&(this.inputValue=this.#o.value.value),this.multiple&&""!==this.#o.value?.value?this.isFiltering=!0:this.multiple?this.isFiltering=!1:""!==this.#o.value?.value&&this.#o.value?.value!==this.selectedOptions.at(0)?.label?this.isFiltering=!0:this.isFiltering=!1,this.#o.value)try{e=await this.filter(this.#o.value.value)}catch{}if(e){for(const t of this.#a)t.hidden=!e.includes(t);const t=this.#gt?.at(0);t&&this.activeOption?.hidden&&(this.activeOption.privateActive=!1,this.#mt=t,this.ariaActivedescendant=t.id,t.privateActive=!0),this.hasNoMatchingOptions=!this.#gt||0===this.#gt.length,this.isCommunicateItemCountToScreenreaders=!0,this.#gt&&(this.itemCount=this.#gt.length)}}#B(t){const e=this.selectedOptions.findLast(((t,e)=>e<=this.tagOverflowLimit-1));if(e&&"Backspace"===t.key&&!t.metaKey&&this.multiple&&this.#o.value&&0===this.#o.value.selectionStart)return this.#rt=!0,e.selected=!1,void(this.#rt=!1);const i=this.selectedOptions.filter(((t,e)=>e<=this.tagOverflowLimit-1));if(e&&"Backspace"===t.key&&t.metaKey&&this.multiple&&this.#o.value&&0===this.#o.value.selectionStart){this.#rt=!0;for(const t of i)t.selected=!1;this.#rt=!1}else;}#V(){this.#o.value&&(this.isInputOverflow=this.#o.value.scrollWidth-1>this.#o.value.clientWidth)}#N(){this.#j.value&&(this.isInternalLabelOverflow=this.#j.value.scrollWidth>this.#j.value.clientWidth)}get#a(){return this.#it.value?.assignedElements().filter((t=>t instanceof DropdownOption))??[]}get#c(){const t=this.#it.value?.assignedElements().filter((t=>t instanceof DropdownOption));if(t&&this.#Z.value)return[this.#Z.value,...t]}get#gt(){return this.#it.value?.assignedElements().filter((t=>t instanceof DropdownOption&&!t.hidden))}get#ft(){const t=this.#it.value?.assignedElements().filter((t=>t instanceof DropdownOption&&!t.hidden));return this.#Z.value&&!this.#Z.value.hidden&&t?[this.#Z.value,...t]:t}#U(t){t.target instanceof DropdownOption&&(t.target.selected=!t.target.selected),t.target===this.#Z.value&&this.#bt(),this.#l()}#W(t){if(t.target instanceof Element){const e=t.target.closest("glide-core-dropdown-option");if(e instanceof DropdownOption&&e.disabled)return;if(e instanceof DropdownOption&&e.privateIsEditActive)return e.privateEdit(),void(this.open=!1);if(e&&!e.selected)return e.selected=!0,this.#l(),this.multiple||(this.open=!1),this.dispatchEvent(new Event("input",{bubbles:!0,composed:!0})),void this.dispatchEvent(new Event("change",{bubbles:!0,composed:!0}));if(e?.selected&&!this.multiple)return void(this.open=!1)}}#G(t){if(t.target instanceof DropdownOption&&t.target.disabled&&t.target.selected){const e=this.#d.lastIndexOf(t.target.value);this.#d.splice(e,e+1)}else this.multiple&&t.target instanceof DropdownOption&&t.target.selected&&t.target.value?this.#d.push(t.target.value):t.target instanceof DropdownOption&&t.target.selected&&t.target.value&&t.target===this.lastSelectedOption&&(this.#d=[t.target.value]);this.requestUpdate()}#Q(){this.requestUpdate()}#P(t){t.target instanceof DropdownOption&&(this.activeOption&&(this.activeOption.privateActive=!1),t.target.privateActive=!0,this.#mt=t.target)}#X(){this.selectedOptions.length>0&&(this.multiple?(this.requestUpdate(),this.updateComplete.then((()=>{this.#p()}))):(this.filterable||this.isFilterable)&&this.#o.value&&this.selectedOptions[0]?.label?(this.#o.value.value=this.selectedOptions[0].label,this.inputValue=this.selectedOptions[0].label,this.isInputOverflow=this.#o.value.scrollWidth>this.#o.value.clientWidth):this.requestUpdate())}#K(t){(this.filterable||this.isFilterable)&&t.preventDefault()}#J(t){if(t.target instanceof DropdownOption&&this.#ft){if(t.target.disabled)return;this.activeOption&&(this.activeOption.privateIsTooltipOpen=!1,this.activeOption.privateActive=!1),this.ariaActivedescendant=t.target.id,this.#mt=t.target,t.target.privateActive=!0,t.target.privateIsEditActive=!1,this.#f?.activeElement===this.#nt.value&&this.focus()}}#tt(t){if(!this.#ct){if(this.#Z.value&&(this.#Z.value.selected=this.isAllSelected),t.target instanceof DropdownOption)if(this.multiple&&!this.#h)this.#d=t.target.selected&&t.target.value&&!t.target.disabled?[...this.value,t.target.value]:this.value.filter((e=>t.target instanceof DropdownOption&&e!==t.target.value)),this.#o.value&&!this.#rt&&(this.isFiltering=!1,this.#o.value.value="",this.inputValue="");else if(!this.multiple&&t.target.selected&&!t.target.disabled){for(const e of this.#a)e!==t.target&&t.target instanceof DropdownOption&&t.target.selected&&e.selected&&(e.selected=!1);this.#d=t.target.value?[t.target.value]:[],this.isShowSingleSelectIcon=Boolean(this.selectedOptions.at(0)?.value),this.#o.value&&t.target.label&&(this.isFiltering=!1,this.#o.value.value=t.target.label,this.inputValue=t.target.label)}this.#o.value&&(this.isInputOverflow=this.#o.value.scrollWidth>this.#o.value.clientWidth),this.requestUpdate(),this.updateComplete.then((()=>{this.#p()}))}}#Y(t){t.target instanceof DropdownOption&&this.multiple&&t.target.selected&&t.detail.new?this.#d=this.value.map((e=>e===t.detail.old?t.detail.new:e)):t.target instanceof DropdownOption&&this.multiple?this.#d=this.value.filter((e=>e!==t.detail.old)):t.target instanceof DropdownOption&&(this.#d=t.detail.new?[t.detail.new]:[])}#z(){this.isInternalLabelTooltipOpen=!0}#H(){this.isInternalLabelTooltipOpen=!1}#F(){this.#rt=!0,this.open=!1}async#k(t){this.#rt=!0;for(const e of this.#a)e.id===t&&(e.selected=!1,this.#d=this.value.filter((t=>t!==e.value)));const e=this.#I.value?.querySelectorAll("glide-core-tag");if(e&&this.selectedOptions.length>0){const i=[...e].findIndex((e=>e.dataset.id===t)),s=e[i<e.length-1?i+1:i-1];await this.updateComplete,setTimeout((()=>{s?.focus(),this.#rt=!1}))}else setTimeout((()=>{this.focus(),this.#rt=!1}));this.dispatchEvent(new Event("input",{bubbles:!0,composed:!0})),this.dispatchEvent(new Event("change",{bubbles:!0,composed:!0}))}#C(t){t.stopPropagation()}#bt(){this.#ct=!0;for(const t of this.#a)!this.#Z.value?.selected||t.selected||t.disabled?!this.#Z.value?.selected&&t.selected&&(t.selected=!1):t.selected=!0;this.#d=this.#a.filter((({selected:t,value:e})=>t&&e)).map((({value:t})=>t)),this.#ct=!1}async#p(){if(this.#E.value){const t=this.#E.value.scrollWidth>this.#E.value.clientWidth;t&&this.tagOverflowLimit>1?(this.tagOverflowLimit=this.tagOverflowLimit-1,await this.updateComplete,this.#p()):!t&&!this.#ht&&this.tagOverflowLimit<this.selectedOptions.length?(this.tagOverflowLimit=this.tagOverflowLimit+1,this.#ht=!0,await this.updateComplete,this.#p()):this.#ht=!1}}#i(){this.#vt?.(),this.#mt&&(this.#mt.privateActive=!0,this.ariaActivedescendant=this.#mt.id),this.#D.value&&this.#b.value&&(this.#vt=autoUpdate(this.#D.value,this.#b.value,(()=>{(async()=>{if(this.#D.value&&this.#b.value){const{x:t,y:e,placement:i}=await computePosition(this.#D.value,this.#b.value,{placement:"bottom-start",middleware:[offset({mainAxis:Number.parseFloat(window.getComputedStyle(document.body).getPropertyValue("--glide-core-spacing-base-xxs"))*Number.parseFloat(window.getComputedStyle(document.documentElement).fontSize)}),flip()]});this.#b.value.dataset.placement=i,Object.assign(this.#b.value.style,{left:`${t}px`,top:`${e}px`}),this.#b.value?.showPopover()}})()})))}#l(){if((this.filterable||this.isFilterable)&&this.#o.value){this.isFiltering=!1;for(const t of this.#a)t.hidden=!1}}};__decorate([property({reflect:!0}),required],Dropdown.prototype,"label",void 0),__decorate([property({attribute:"add-button-label",reflect:!0})],Dropdown.prototype,"addButtonLabel",void 0),__decorate([property({reflect:!0,type:Boolean})],Dropdown.prototype,"disabled",null),__decorate([property({reflect:!0,type:Boolean})],Dropdown.prototype,"filterable",null),__decorate([property({attribute:"hide-label",reflect:!0,type:Boolean})],Dropdown.prototype,"hideLabel",void 0),__decorate([property({reflect:!0,type:Boolean})],Dropdown.prototype,"loading",void 0),__decorate([property({reflect:!0,useDefault:!0})],Dropdown.prototype,"name",void 0),__decorate([property({reflect:!0,type:Boolean})],Dropdown.prototype,"open",null),__decorate([property({reflect:!0,useDefault:!0})],Dropdown.prototype,"orientation",void 0),__decorate([property({reflect:!0})],Dropdown.prototype,"placeholder",void 0),__decorate([property()],Dropdown.prototype,"privateSplit",void 0),__decorate([property({reflect:!0,type:Boolean})],Dropdown.prototype,"readonly",void 0),__decorate([property({attribute:"select-all",reflect:!0,type:Boolean})],Dropdown.prototype,"selectAll",void 0),__decorate([property({reflect:!0,type:Boolean})],Dropdown.prototype,"required",void 0),__decorate([property({reflect:!0,type:Boolean})],Dropdown.prototype,"multiple",null),__decorate([property({reflect:!0})],Dropdown.prototype,"tooltip",void 0),__decorate([property({type:Array})],Dropdown.prototype,"value",null),__decorate([property({reflect:!0})],Dropdown.prototype,"variant",void 0),__decorate([property({reflect:!0})],Dropdown.prototype,"version",void 0),__decorate([state()],Dropdown.prototype,"ariaActivedescendant",void 0),__decorate([state()],Dropdown.prototype,"hasNoAvailableOptions",void 0),__decorate([state()],Dropdown.prototype,"hasNoMatchingOptions",void 0),__decorate([state()],Dropdown.prototype,"inputValue",void 0),__decorate([state()],Dropdown.prototype,"isBlurring",void 0),__decorate([state()],Dropdown.prototype,"isCheckingValidity",void 0),__decorate([state()],Dropdown.prototype,"isCommunicateItemCountToScreenreaders",void 0),__decorate([state()],Dropdown.prototype,"isFilterable",void 0),__decorate([state()],Dropdown.prototype,"isFiltering",void 0),__decorate([state()],Dropdown.prototype,"isInputOverflow",void 0),__decorate([state()],Dropdown.prototype,"isInputTooltipOpen",void 0),__decorate([state()],Dropdown.prototype,"isInternalLabelOverflow",void 0),__decorate([state()],Dropdown.prototype,"isInternalLabelTooltipOpen",void 0),__decorate([state()],Dropdown.prototype,"isReportValidityOrSubmit",void 0),__decorate([state()],Dropdown.prototype,"isShowSingleSelectIcon",void 0),__decorate([state()],Dropdown.prototype,"itemCount",void 0),__decorate([state()],Dropdown.prototype,"tagOverflowLimit",void 0),__decorate([state()],Dropdown.prototype,"validityMessage",void 0),Dropdown=__decorate([customElement("glide-core-dropdown"),final],Dropdown);export default Dropdown;const icons={plus:html`
|
308
306
|
<svg
|
309
307
|
aria-hidden="true"
|
310
308
|
viewBox="0 0 16 16"
|
@@ -3,7 +3,7 @@ import './tooltip.js';
|
|
3
3
|
import { LitElement } from 'lit';
|
4
4
|
declare global {
|
5
5
|
interface HTMLElementTagNameMap {
|
6
|
-
'glide-core-dropdown-option':
|
6
|
+
'glide-core-dropdown-option': DropdownOption;
|
7
7
|
}
|
8
8
|
}
|
9
9
|
/**
|
@@ -32,7 +32,7 @@ declare global {
|
|
32
32
|
*
|
33
33
|
* @fires {Event} edit
|
34
34
|
*/
|
35
|
-
export default class
|
35
|
+
export default class DropdownOption extends LitElement {
|
36
36
|
#private;
|
37
37
|
static shadowRootOptions: ShadowRootInit;
|
38
38
|
static styles: import("lit").CSSResult[];
|
@@ -58,7 +58,6 @@ export default class GlideCoreDropdownOption extends LitElement {
|
|
58
58
|
privateIsEditActive: boolean;
|
59
59
|
privateIsTooltipOpen: boolean;
|
60
60
|
privateMultiple: boolean;
|
61
|
-
privateSize: 'large' | 'small';
|
62
61
|
readonly role = "option";
|
63
62
|
/**
|
64
63
|
* @default false
|
package/dist/dropdown.option.js
CHANGED
@@ -1 +1 @@
|
|
1
|
-
var __decorate=this&&this.__decorate||function(e,t,i,o){var l,s=arguments.length,
|
1
|
+
var __decorate=this&&this.__decorate||function(e,t,i,o){var l,s=arguments.length,a=s<3?t:null===o?o=Object.getOwnPropertyDescriptor(t,i):o;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)a=Reflect.decorate(e,t,i,o);else for(var n=e.length-1;n>=0;n--)(l=e[n])&&(a=(s<3?l(a):s>3?l(t,i,a):l(t,i))||a);return s>3&&a&&Object.defineProperty(t,i,a),a};import"./checkbox.js";import"./tooltip.js";import{html,LitElement}from"lit";import{ifDefined}from"lit/directives/if-defined.js";import{classMap}from"lit/directives/class-map.js";import{createRef,ref}from"lit/directives/ref.js";import{customElement,property,state}from"lit/decorators.js";import{when}from"lit/directives/when.js";import packageJson from"../package.json"with{type:"json"};import checkedIcon from"./icons/checked.js";import pencilIcon from"./icons/pencil.js";import{LocalizeController}from"./library/localize.js";import styles from"./dropdown.option.styles.js";import shadowRootMode from"./library/shadow-root-mode.js";import final from"./library/final.js";import required from"./library/required.js";import uniqueId from"./library/unique-id.js";let DropdownOption=class DropdownOption extends LitElement{constructor(){super(...arguments),this.id=uniqueId(),this.privateActive=!1,this.privateIndeterminate=!1,this.privateIsEditActive=!1,this.privateIsTooltipOpen=!1,this.privateMultiple=!1,this.role="option",this.tabIndex=-1,this.version=packageJson.version,this.isLabelOverflow=!1,this.#e=createRef(),this.#t=createRef(),this.#i=!1,this.#o=!1,this.#l=createRef(),this.#s=new LocalizeController(this),this.#a=!1,this.#n=""}static{this.shadowRootOptions={...LitElement.shadowRootOptions,mode:shadowRootMode}}static{this.styles=styles}get label(){return this.#r}set label(e){this.#r=e,setTimeout((()=>{this.#c()})),this.dispatchEvent(new Event("private-label-change",{bubbles:!0}))}get disabled(){return this.#i}set disabled(e){this.#i=e,this.#e.value?.checked&&e?this.#e.value.checked=!1:this.#e.value&&this.selected&&!e&&(this.#e.value.checked=!0),this.ariaDisabled=e.toString(),this.ariaSelected=!e&&this.selected?"true":"false",this.dispatchEvent(new Event("private-disabled-change",{bubbles:!0}))}get editable(){return this.#o}set editable(e){this.#o=e,this.dispatchEvent(new Event("private-editable-change",{bubbles:!0}))}get selected(){return this.#a}set selected(e){this.#a=e,this.ariaSelected=!this.disabled&&e?"true":"false",this.isMultiple&&this.#e.value&&(this.#e.value.checked=e),this.dispatchEvent(new Event("private-selected-change",{bubbles:!0}))}get isMultiple(){return this.privateMultiple||this.closest("glide-core-dropdown")?.multiple}get lastSelectedOption(){const e=this.parentElement?.querySelectorAll("glide-core-dropdown-option");if(e&&e.length>0)return[...e].findLast((e=>e.selected))}click(){this.privateMultiple?this.#e.value?.click():this.#t.value?.click()}connectedCallback(){super.connectedCallback(),this.ariaDisabled=this.disabled.toString(),this.ariaSelected=!this.disabled&&this.selected?"true":"false",this.#d=new IntersectionObserver((()=>{this.checkVisibility()&&this.#c()})),this.#d.observe(this)}disconnectedCallback(){super.disconnectedCallback(),this.#d?.disconnect()}firstUpdated(){this.#e.value&&(this.#e.value.checked=this.selected&&!this.disabled)}get value(){return this.#n}set value(e){this.dispatchEvent(new CustomEvent("private-value-change",{bubbles:!0,detail:{old:this.value,new:e}})),this.#n=e}privateEdit(){this.dispatchEvent(new Event("edit",{bubbles:!0,composed:!0}))}async privateUpdateCheckbox(){await this.updateComplete,this.#e.value&&(this.#e.value.checked=this.selected)}render(){return html`<div class="${classMap({component:!0,active:this.privateActive,disabled:this.disabled})}" data-test="component" ${ref(this.#t)}>${when(this.isMultiple,(()=>html`<glide-core-checkbox class="${classMap({checkbox:!0,editable:this.editable})}" data-test="checkbox" label="${this.label??""}" tabindex="-1" private-label-tooltip-offset="${12}" private-variant="minimal" value="${this.value}" @click="${this.#p}" private-internally-inert ?disabled="${this.disabled}" ?indeterminate="${this.privateIndeterminate}" ?private-show-label-tooltip="${this.privateIsTooltipOpen}" ?private-disable-label-tooltip="${this.disabled}" ${ref(this.#e)}><slot class="checkbox-icon-slot" name="icon" slot="private-icon"></slot></glide-core-checkbox>${when(this.editable,(()=>html`<button aria-label="${this.#s.term("editOption",this.label)}" class="${classMap({"edit-button":!0,active:this.privateIsEditActive,count:Boolean(this.count),disabled:this.disabled,multiple:Boolean(this.isMultiple)})}" data-test="edit-button" type="button" @mouseover="${this.#h}" @mouseout="${this.#b}">${pencilIcon}</button>`))} ${when(this.count&&this.count>0,(()=>html`<div class="${classMap({"count-container":!0,disabled:this.disabled})}" data-test="count-container">${when(this.count>=1e3,(()=>"999+"),(()=>this.count))}</div>`))}`),(()=>html`<div class="${classMap({option:!0,count:Boolean(this.count),disabled:this.disabled,editable:this.editable})}"><slot class="${classMap({"icon-slot":!0})}" name="icon"></slot><glide-core-tooltip class="tooltip" data-test="tooltip" label="${ifDefined(this.label)}" offset="${10}" ?disabled="${!this.isLabelOverflow||this.disabled}" ?open="${this.privateIsTooltipOpen}" screenreader-hidden @toggle="${this.#u}"><div class="label" data-test="label" slot="target" ${ref(this.#l)}>${this.label}</div></glide-core-tooltip>${when(this.selected&&this===this.lastSelectedOption&&!this.disabled,(()=>html`<div class="checked-icon-container" data-test="checked-icon-container">${checkedIcon}</div>`))} ${when(this.editable,(()=>html`<button aria-label="${this.#s.term("editOption",this.label)}" class="${classMap({"edit-button":!0,active:this.privateActive&&this.privateIsEditActive,count:Boolean(this.count),disabled:this.disabled})}" data-test="edit-button" type="button" @mouseover="${this.#h}" @mouseout="${this.#b}">${pencilIcon}</button>`))} ${when(this.count&&this.count>0,(()=>html`<div class="${classMap({"count-container":!0,disabled:this.disabled})}" data-test="count-container">${when(this.count>=1e3,(()=>"999+"),(()=>this.count))}</div>`))}</div>`))}</div>`}#e;#t;#d;#i;#o;#r;#l;#s;#a;#n;#p(e){e.stopPropagation()}#b(){this.privateIsEditActive=!1}#h(){this.privateIsEditActive=!0}#u(e){e.stopPropagation()}#c(){this.#l.value&&(this.isLabelOverflow=this.#l.value.scrollWidth>this.#l.value.clientWidth)}};__decorate([property({reflect:!0}),required],DropdownOption.prototype,"label",null),__decorate([property({reflect:!0,type:Number})],DropdownOption.prototype,"count",void 0),__decorate([property({reflect:!0,type:Boolean})],DropdownOption.prototype,"disabled",null),__decorate([property({reflect:!0,type:Boolean})],DropdownOption.prototype,"editable",null),__decorate([property({reflect:!0})],DropdownOption.prototype,"id",void 0),__decorate([property({type:Boolean})],DropdownOption.prototype,"privateActive",void 0),__decorate([property({attribute:"private-indeterminate",type:Boolean})],DropdownOption.prototype,"privateIndeterminate",void 0),__decorate([property({type:Boolean})],DropdownOption.prototype,"privateIsEditActive",void 0),__decorate([property({type:Boolean})],DropdownOption.prototype,"privateIsTooltipOpen",void 0),__decorate([property({attribute:"private-multiple",type:Boolean})],DropdownOption.prototype,"privateMultiple",void 0),__decorate([property({reflect:!0})],DropdownOption.prototype,"role",void 0),__decorate([property({reflect:!0,type:Boolean})],DropdownOption.prototype,"selected",null),__decorate([property({attribute:"tabindex",reflect:!0,type:Number})],DropdownOption.prototype,"tabIndex",void 0),__decorate([property({reflect:!0})],DropdownOption.prototype,"version",void 0),__decorate([state()],DropdownOption.prototype,"isMultiple",null),__decorate([state()],DropdownOption.prototype,"lastSelectedOption",null),__decorate([property({reflect:!0})],DropdownOption.prototype,"value",null),__decorate([state()],DropdownOption.prototype,"isLabelOverflow",void 0),DropdownOption=__decorate([customElement("glide-core-dropdown-option"),final],DropdownOption);export default DropdownOption;
|
@@ -23,29 +23,15 @@ import{css}from"lit";export default[css`
|
|
23
23
|
color: var(--glide-core-color-static-text-default);
|
24
24
|
display: flex;
|
25
25
|
flex-grow: 1;
|
26
|
+
font-family: var(--glide-core-typography-family-primary);
|
27
|
+
font-size: var(--glide-core-typography-size-body-default);
|
28
|
+
font-weight: var(--glide-core-typography-weight-regular);
|
26
29
|
overflow: hidden;
|
30
|
+
padding-inline-start: 0.625rem;
|
27
31
|
user-select: none;
|
28
32
|
|
29
|
-
|
30
|
-
|
31
|
-
font-size: var(--glide-core-typography-size-body-default);
|
32
|
-
font-weight: var(--glide-core-typography-weight-regular);
|
33
|
-
padding-inline-start: 0.625rem;
|
34
|
-
|
35
|
-
&:not(.count, .editable) {
|
36
|
-
padding-inline-end: var(--glide-core-spacing-base-sm);
|
37
|
-
}
|
38
|
-
}
|
39
|
-
|
40
|
-
&.small {
|
41
|
-
font-family: var(--glide-core-typography-family-primary);
|
42
|
-
font-size: var(--glide-core-typography-size-body-small);
|
43
|
-
font-weight: var(--glide-core-typography-weight-regular);
|
44
|
-
padding-inline-start: var(--glide-core-spacing-base-sm);
|
45
|
-
|
46
|
-
&:not(.count, .editable) {
|
47
|
-
padding-inline-end: var(--glide-core-spacing-base-xs);
|
48
|
-
}
|
33
|
+
&:not(.count, .editable) {
|
34
|
+
padding-inline-end: var(--glide-core-spacing-base-sm);
|
49
35
|
}
|
50
36
|
|
51
37
|
&.disabled {
|
@@ -57,33 +43,16 @@ import{css}from"lit";export default[css`
|
|
57
43
|
flex-grow: 1;
|
58
44
|
overflow: hidden;
|
59
45
|
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
}
|
64
|
-
|
65
|
-
&:not(.count, .editable) {
|
66
|
-
&::part(private-label-and-input-and-checkbox) {
|
67
|
-
padding-inline-end: var(--glide-core-spacing-base-sm);
|
68
|
-
}
|
69
|
-
}
|
46
|
+
&::part(private-label-and-input-and-checkbox) {
|
47
|
+
block-size: var(--private-option-height);
|
48
|
+
padding-inline-start: var(--glide-core-spacing-base-sm);
|
70
49
|
}
|
71
50
|
|
72
|
-
|
51
|
+
&:not(.count, .editable) {
|
73
52
|
&::part(private-label-and-input-and-checkbox) {
|
74
|
-
padding-inline-
|
75
|
-
}
|
76
|
-
|
77
|
-
&:not(.count, .editable) {
|
78
|
-
&::part(private-label-and-input-and-checkbox) {
|
79
|
-
padding-inline-end: var(--glide-core-spacing-base-xs);
|
80
|
-
}
|
53
|
+
padding-inline-end: var(--glide-core-spacing-base-sm);
|
81
54
|
}
|
82
55
|
}
|
83
|
-
|
84
|
-
&::part(private-label-and-input-and-checkbox) {
|
85
|
-
block-size: var(--private-option-height);
|
86
|
-
}
|
87
56
|
}
|
88
57
|
|
89
58
|
.indeterminate-icon {
|
@@ -91,47 +60,21 @@ import{css}from"lit";export default[css`
|
|
91
60
|
}
|
92
61
|
|
93
62
|
.icon-slot {
|
94
|
-
&.large {
|
95
|
-
&::slotted(*) {
|
96
|
-
block-size: 1rem;
|
97
|
-
inline-size: 1rem;
|
98
|
-
}
|
99
|
-
}
|
100
|
-
|
101
|
-
&.small {
|
102
|
-
&::slotted(*) {
|
103
|
-
block-size: 0.75rem;
|
104
|
-
inline-size: 0.75rem;
|
105
|
-
}
|
106
|
-
}
|
107
|
-
|
108
63
|
&::slotted(*) {
|
109
64
|
align-items: center;
|
65
|
+
block-size: 1rem;
|
110
66
|
display: flex;
|
67
|
+
inline-size: 1rem;
|
111
68
|
padding-inline-end: var(--glide-core-spacing-base-xs);
|
112
69
|
}
|
113
70
|
}
|
114
71
|
|
115
72
|
.checkbox-icon-slot {
|
116
|
-
&.large {
|
117
|
-
&::slotted(*) {
|
118
|
-
block-size: 1rem;
|
119
|
-
inline-size: 1rem;
|
120
|
-
}
|
121
|
-
}
|
122
|
-
|
123
|
-
&.small {
|
124
|
-
&::slotted(*) {
|
125
|
-
block-size: 0.75rem;
|
126
|
-
inline-size: 0.75rem;
|
127
|
-
}
|
128
|
-
}
|
129
|
-
|
130
73
|
&::slotted(*) {
|
131
74
|
align-items: center;
|
132
|
-
block-size:
|
75
|
+
block-size: 1rem;
|
133
76
|
display: flex;
|
134
|
-
inline-size:
|
77
|
+
inline-size: 1rem;
|
135
78
|
}
|
136
79
|
}
|
137
80
|
|
@@ -178,13 +121,7 @@ import{css}from"lit";export default[css`
|
|
178
121
|
}
|
179
122
|
|
180
123
|
&:not(.count) {
|
181
|
-
|
182
|
-
padding-inline-end: var(--glide-core-spacing-base-sm);
|
183
|
-
}
|
184
|
-
|
185
|
-
&.small {
|
186
|
-
padding-inline-end: var(--glide-core-spacing-base-xs);
|
187
|
-
}
|
124
|
+
padding-inline-end: var(--glide-core-spacing-base-sm);
|
188
125
|
}
|
189
126
|
|
190
127
|
&:focus {
|