@justeattakeaway/pie-select 0.8.19 → 0.8.20
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/index.js +28 -28
- package/package.json +1 -1
- package/src/select.scss +2 -0
package/dist/index.js
CHANGED
|
@@ -1,29 +1,29 @@
|
|
|
1
|
-
import { LitElement as
|
|
2
|
-
import { FormControlMixin as I, RtlMixin as w, DelegatesFocusMixin as z, wrapNativeEvent as k, validPropertyValues as
|
|
3
|
-
import { property as n, query as
|
|
1
|
+
import { LitElement as x, html as p, nothing as _, unsafeCSS as $ } from "lit";
|
|
2
|
+
import { FormControlMixin as I, RtlMixin as w, DelegatesFocusMixin as z, wrapNativeEvent as k, validPropertyValues as f, safeCustomElement as S } from "@justeattakeaway/pie-webc-core";
|
|
3
|
+
import { property as n, query as b, queryAssignedElements as C, state as V } from "lit/decorators.js";
|
|
4
4
|
import { ifDefined as u } from "lit/directives/if-defined.js";
|
|
5
5
|
import { classMap as L } from "lit/directives/class-map.js";
|
|
6
6
|
import { live as T } from "lit/directives/live.js";
|
|
7
7
|
import "@justeattakeaway/pie-icons-webc/dist/IconChevronDown.js";
|
|
8
8
|
import "@justeattakeaway/pie-assistive-text";
|
|
9
|
-
const h = class h extends
|
|
9
|
+
const h = class h extends x {
|
|
10
10
|
willUpdate() {
|
|
11
11
|
this.getAttribute("v") || this.setAttribute("v", h.v);
|
|
12
12
|
}
|
|
13
13
|
};
|
|
14
|
-
h.v = "0.8.
|
|
14
|
+
h.v = "0.8.20";
|
|
15
15
|
let g = h;
|
|
16
|
-
const A = "*,*:after,*:before{box-sizing:inherit}:host{display:block}.c-select{--select-padding-block: var(--dt-spacing-c);--select-padding-inline-start: var(--dt-spacing-d);--select-padding-inline-end: 52px;--select-background-color: var(--dt-color-container-default);--select-text-color: var(--dt-color-content-default);--select-border-color: var(--dt-color-border-form);--select-font-size: calc(var(--dt-font-body-l-size) * 1px);--select-line-height: calc(var(--dt-font-body-l-line-height) * 1px);--select-height: 48px;--select-cursor: pointer;position:relative;color:var(--select-text-color);font-size:var(--select-font-size);line-height:var(--select-line-height)}.c-select select{height:var(--select-height);width:100%;border:1px solid var(--select-border-color);border-radius:var(--dt-radius-rounded-c);padding-inline-start:var(--select-padding-inline-start);padding-inline-end:var(--select-padding-inline-end);padding-block-start:var(--select-padding-block);padding-block-end:var(--select-padding-block);background-color:var(--select-background-color);font-family:inherit;font-size:inherit;line-height:inherit;color:inherit;outline:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:var(--select-cursor);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.c-select select:focus-within{box-shadow:0 0 0 2px var(--dt-color-focus-inner),0 0 0 4px var(--dt-color-focus-outer);outline:none}.c-select.c-select--small{--select-padding-block: var(--dt-spacing-b);--select-height: 40px}.c-select.c-select--large{--select-padding-block: var(--dt-spacing-d);--select-height: 56px}.c-select.c-select--error{--select-border-color: var(--dt-color-support-error)}.c-select.c-select--withLeadingIcon{--select-padding-inline-start: calc(var(--dt-spacing-h) - var(--dt-spacing-a))}.c-select ::slotted([slot=leadingIcon]),.c-select .c-select-trailingIcon{position:absolute;top:50%;transform:translateY(-50%);pointer-events:none}.c-select:not(.is-disabled) ::slotted([slot=leadingIcon]),.c-select:not(.is-disabled) .c-select-trailingIcon{color:var(--dt-color-content-subdued)}.c-select ::slotted([slot=leadingIcon]){--icon-size-override: 24px;inset-inline-start:var(--dt-spacing-d)}.c-select .c-select-trailingIcon{inset-inline-end:var(--dt-spacing-d)}@media (hover: hover){.c-select:hover{--select-background-color: hsl(var(--dt-color-container-default-h), var(--dt-color-container-default-s), calc(var(--dt-color-container-default-l) + calc(-1 * var(--dt-color-hover-01))))}@supports (background-color: color-mix(in srgb,black,white)){.c-select:hover{--select-background-color: color-mix(in srgb, var(--dt-color-hover-01-bg) var(--dt-color-hover-01), var(--dt-color-container-default))}}}.c-select.is-disabled{--select-background-color: var(--dt-color-disabled-01);--select-border-color: var(--dt-color-disabled-01);--select-text-color: var(--dt-color-content-disabled);--select-cursor: auto}", F = ["small", "medium", "large"], D = ["default", "error"], c = {
|
|
16
|
+
const A = "*,*:after,*:before{box-sizing:inherit}:host{display:block}.c-select{--select-padding-block: var(--dt-spacing-c);--select-padding-inline-start: var(--dt-spacing-d);--select-padding-inline-end: 52px;--select-background-color: var(--dt-color-container-default);--select-text-color: var(--dt-color-content-default);--select-border-color: var(--dt-color-border-form);--select-font-family: var(--dt-font-body-l-family);--select-font-size: calc(var(--dt-font-body-l-size) * 1px);--select-line-height: calc(var(--dt-font-body-l-line-height) * 1px);--select-height: 48px;--select-cursor: pointer;position:relative;color:var(--select-text-color);font-family:var(--select-font-family);font-size:var(--select-font-size);line-height:var(--select-line-height)}.c-select select{height:var(--select-height);width:100%;border:1px solid var(--select-border-color);border-radius:var(--dt-radius-rounded-c);padding-inline-start:var(--select-padding-inline-start);padding-inline-end:var(--select-padding-inline-end);padding-block-start:var(--select-padding-block);padding-block-end:var(--select-padding-block);background-color:var(--select-background-color);font-family:inherit;font-size:inherit;line-height:inherit;color:inherit;outline:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:var(--select-cursor);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.c-select select:focus-within{box-shadow:0 0 0 2px var(--dt-color-focus-inner),0 0 0 4px var(--dt-color-focus-outer);outline:none}.c-select.c-select--small{--select-padding-block: var(--dt-spacing-b);--select-height: 40px}.c-select.c-select--large{--select-padding-block: var(--dt-spacing-d);--select-height: 56px}.c-select.c-select--error{--select-border-color: var(--dt-color-support-error)}.c-select.c-select--withLeadingIcon{--select-padding-inline-start: calc(var(--dt-spacing-h) - var(--dt-spacing-a))}.c-select ::slotted([slot=leadingIcon]),.c-select .c-select-trailingIcon{position:absolute;top:50%;transform:translateY(-50%);pointer-events:none}.c-select:not(.is-disabled) ::slotted([slot=leadingIcon]),.c-select:not(.is-disabled) .c-select-trailingIcon{color:var(--dt-color-content-subdued)}.c-select ::slotted([slot=leadingIcon]){--icon-size-override: 24px;inset-inline-start:var(--dt-spacing-d)}.c-select .c-select-trailingIcon{inset-inline-end:var(--dt-spacing-d)}@media (hover: hover){.c-select:hover{--select-background-color: hsl(var(--dt-color-container-default-h), var(--dt-color-container-default-s), calc(var(--dt-color-container-default-l) + calc(-1 * var(--dt-color-hover-01))))}@supports (background-color: color-mix(in srgb,black,white)){.c-select:hover{--select-background-color: color-mix(in srgb, var(--dt-color-hover-01-bg) var(--dt-color-hover-01), var(--dt-color-container-default))}}}.c-select.is-disabled{--select-background-color: var(--dt-color-disabled-01);--select-border-color: var(--dt-color-disabled-01);--select-text-color: var(--dt-color-content-disabled);--select-cursor: auto}", F = ["small", "medium", "large"], D = ["default", "error"], c = {
|
|
17
17
|
size: "medium",
|
|
18
18
|
status: "default",
|
|
19
19
|
disabled: !1,
|
|
20
20
|
options: [],
|
|
21
21
|
value: ""
|
|
22
22
|
};
|
|
23
|
-
var O = Object.defineProperty, P = Object.getOwnPropertyDescriptor, o = (t, e,
|
|
24
|
-
for (var s =
|
|
25
|
-
(d = t[a]) && (s = (
|
|
26
|
-
return
|
|
23
|
+
var O = Object.defineProperty, P = Object.getOwnPropertyDescriptor, o = (t, e, i, r) => {
|
|
24
|
+
for (var s = r > 1 ? void 0 : r ? P(e, i) : e, a = t.length - 1, d; a >= 0; a--)
|
|
25
|
+
(d = t[a]) && (s = (r ? d(e, i, s) : d(s)) || s);
|
|
26
|
+
return r && s && O(e, i, s), s;
|
|
27
27
|
};
|
|
28
28
|
const m = "pie-select", v = "assistive-text";
|
|
29
29
|
let l = class extends I(w(z(g))) {
|
|
@@ -31,8 +31,8 @@ let l = class extends I(w(z(g))) {
|
|
|
31
31
|
super(...arguments), this.size = c.size, this.disabled = c.disabled, this.status = c.status, this.options = c.options, this._value = c.value, this._hasLeadingIcon = !1, this._handleChange = (t) => {
|
|
32
32
|
const { value: e } = this._select;
|
|
33
33
|
this._value = e, this._internals.setFormValue(e);
|
|
34
|
-
const
|
|
35
|
-
this.dispatchEvent(
|
|
34
|
+
const i = k(t);
|
|
35
|
+
this.dispatchEvent(i);
|
|
36
36
|
};
|
|
37
37
|
}
|
|
38
38
|
firstUpdated() {
|
|
@@ -66,8 +66,8 @@ let l = class extends I(w(z(g))) {
|
|
|
66
66
|
* Resets the value to the default select value.
|
|
67
67
|
*/
|
|
68
68
|
formResetCallback() {
|
|
69
|
-
const t = this.options.reduce((s, a) => a.tag === "optgroup" ? s.concat(a.options) : (s.push(a), s), []), e = t.length > 0 ? t[0].value : "",
|
|
70
|
-
this._select.value =
|
|
69
|
+
const t = this.options.reduce((s, a) => a.tag === "optgroup" ? s.concat(a.options) : (s.push(a), s), []), e = t.length > 0 ? t[0].value : "", i = t.find((s) => s.selected === !0), r = i ? i.value : e;
|
|
70
|
+
this._select.value = r || "", this._internals.setFormValue(r || null), this._value = r || "", this.requestUpdate();
|
|
71
71
|
}
|
|
72
72
|
_handleLeadingIconSlotchange() {
|
|
73
73
|
this._hasLeadingIcon = !!this._leadingIconSlot.length;
|
|
@@ -88,12 +88,12 @@ let l = class extends I(w(z(g))) {
|
|
|
88
88
|
${this.renderChildren(e.options)}
|
|
89
89
|
</optgroup>
|
|
90
90
|
`;
|
|
91
|
-
const
|
|
91
|
+
const r = this._value !== "" ? this._value === e.value : e.selected;
|
|
92
92
|
return p`
|
|
93
93
|
<option
|
|
94
94
|
.value="${T(e.value || "")}"
|
|
95
95
|
?disabled="${e.disabled}"
|
|
96
|
-
?selected="${
|
|
96
|
+
?selected="${r}">
|
|
97
97
|
${e.text}
|
|
98
98
|
</option>
|
|
99
99
|
`;
|
|
@@ -112,27 +112,27 @@ let l = class extends I(w(z(g))) {
|
|
|
112
112
|
data-test-id="pie-select-assistive-text">
|
|
113
113
|
${this.assistiveText}
|
|
114
114
|
</pie-assistive-text>
|
|
115
|
-
` :
|
|
115
|
+
` : _;
|
|
116
116
|
}
|
|
117
117
|
render() {
|
|
118
118
|
const {
|
|
119
119
|
assistiveText: t,
|
|
120
120
|
disabled: e,
|
|
121
|
-
status:
|
|
122
|
-
size:
|
|
121
|
+
status: i,
|
|
122
|
+
size: r,
|
|
123
123
|
name: s,
|
|
124
124
|
options: a,
|
|
125
125
|
_hasLeadingIcon: d
|
|
126
|
-
} = this,
|
|
126
|
+
} = this, y = {
|
|
127
127
|
"c-select": !0,
|
|
128
|
-
[`c-select--${i}`]: !0,
|
|
129
128
|
[`c-select--${r}`]: !0,
|
|
129
|
+
[`c-select--${i}`]: !0,
|
|
130
130
|
"c-select--withLeadingIcon": d,
|
|
131
131
|
"is-disabled": e
|
|
132
132
|
};
|
|
133
133
|
return p`
|
|
134
134
|
<div
|
|
135
|
-
class="${L(
|
|
135
|
+
class="${L(y)}"
|
|
136
136
|
data-test-id="pie-select-shell">
|
|
137
137
|
<slot name="leadingIcon" @slotchange=${this._handleLeadingIconSlotchange}></slot>
|
|
138
138
|
<select
|
|
@@ -140,8 +140,8 @@ let l = class extends I(w(z(g))) {
|
|
|
140
140
|
name="${u(s)}"
|
|
141
141
|
?disabled="${e}"
|
|
142
142
|
aria-describedby="${u(t ? v : void 0)}"
|
|
143
|
-
aria-invalid="${
|
|
144
|
-
aria-errormessage="${u(
|
|
143
|
+
aria-invalid="${i === "error" ? "true" : "false"}"
|
|
144
|
+
aria-errormessage="${u(i === "error" ? v : void 0)}"
|
|
145
145
|
@change=${this._handleChange}>
|
|
146
146
|
${this.renderChildren(a)}
|
|
147
147
|
</select>
|
|
@@ -154,14 +154,14 @@ let l = class extends I(w(z(g))) {
|
|
|
154
154
|
l.styles = $(A);
|
|
155
155
|
o([
|
|
156
156
|
n({ type: String }),
|
|
157
|
-
|
|
157
|
+
f(m, F, c.size)
|
|
158
158
|
], l.prototype, "size", 2);
|
|
159
159
|
o([
|
|
160
160
|
n({ type: Boolean })
|
|
161
161
|
], l.prototype, "disabled", 2);
|
|
162
162
|
o([
|
|
163
163
|
n({ type: String }),
|
|
164
|
-
|
|
164
|
+
f(m, D, c.status)
|
|
165
165
|
], l.prototype, "status", 2);
|
|
166
166
|
o([
|
|
167
167
|
n({ type: String })
|
|
@@ -173,10 +173,10 @@ o([
|
|
|
173
173
|
n({ type: Array })
|
|
174
174
|
], l.prototype, "options", 2);
|
|
175
175
|
o([
|
|
176
|
-
|
|
176
|
+
b("select")
|
|
177
177
|
], l.prototype, "focusTarget", 2);
|
|
178
178
|
o([
|
|
179
|
-
|
|
179
|
+
b("select")
|
|
180
180
|
], l.prototype, "_select", 2);
|
|
181
181
|
o([
|
|
182
182
|
C({ slot: "leadingIcon", flatten: !0 })
|
package/package.json
CHANGED
package/src/select.scss
CHANGED
|
@@ -11,6 +11,7 @@
|
|
|
11
11
|
--select-background-color: var(--dt-color-container-default);
|
|
12
12
|
--select-text-color: var(--dt-color-content-default);
|
|
13
13
|
--select-border-color: var(--dt-color-border-form);
|
|
14
|
+
--select-font-family: var(--dt-font-body-l-family);
|
|
14
15
|
--select-font-size: #{p.font-size(--dt-font-body-l-size)};
|
|
15
16
|
--select-line-height: #{p.font-size(--dt-font-body-l-line-height)};
|
|
16
17
|
--select-height: 48px;
|
|
@@ -18,6 +19,7 @@
|
|
|
18
19
|
|
|
19
20
|
position: relative;
|
|
20
21
|
color: var(--select-text-color);
|
|
22
|
+
font-family: var(--select-font-family);
|
|
21
23
|
font-size: var(--select-font-size);
|
|
22
24
|
line-height: var(--select-line-height);
|
|
23
25
|
|