@sbb-esta/lyne-elements-dev 4.6.0-dev.1772088473 → 4.6.0-dev.1772094630

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.
@@ -1,28 +1,30 @@
1
- var x = (i) => {
1
+ var D = (i) => {
2
2
  throw TypeError(i);
3
3
  };
4
- var I = (i, a, r) => a.has(i) || x("Cannot " + r);
5
- var d = (i, a, r) => (I(i, a, "read from private field"), r ? r.call(i) : a.get(i)), g = (i, a, r) => a.has(i) ? x("Cannot add the same private member more than once") : a instanceof WeakSet ? a.add(i) : a.set(i, r), m = (i, a, r, p) => (I(i, a, "write to private field"), p ? p.call(i, r) : a.set(i, r), r);
6
- import { __esDecorate as c, __runInitializers as b } from "tslib";
7
- import { css as K, LitElement as L, isServer as A, html as O } from "lit";
8
- import { customElement as W, property as _ } from "lit/decorators.js";
9
- import { isArrowKeyPressed as T, getNextElementIndex as q } from "../../core/a11y.js";
10
- import { SbbLanguageController as F, SbbPropertyWatcherController as M } from "../../core/controllers.js";
11
- import { isLean as V } from "../../core/dom/lean-context.js";
12
- import { i18nSelectionRequired as R, i18nChipGroupInputDescription as $ } from "../../core/i18n.js";
13
- import { SbbRequiredMixin as B, SbbDisabledMixin as N, SbbNegativeMixin as j, SbbFormAssociatedMixin as G, SbbElementInternalsMixin as U } from "../../core/mixins.js";
14
- import { boxSizingStyles as J } from "../../core/styles.js";
15
- import { SbbChipElement as P } from "../chip.js";
16
- const H = K`:host{width:100%;display:flex;flex-wrap:wrap;gap:var(--sbb-chip-group-gap);align-items:center;margin-block:var(--sbb-chip-group-margin-block)}:host(:is(:is(:state(size-s),[state--size-s]),:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: 0}:host(:is(:state(size-s),[state--size-s]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: .375rem .3125rem}@media(min-width:64rem){:host(:is(:state(size-s),[state--size-s]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: .3125rem .1875rem}}:host(:is(:state(without-label),[state--without-label]):is(:state(size-s),[state--size-s]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: 0 .4375rem}@media(min-width:64rem){:host(:is(:state(without-label),[state--without-label]):is(:state(size-s),[state--size-s]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: 0 .3125rem}}:host(:is(:is(:state(size-l),[state--size-l]),:is(:state(size-m),[state--size-m]))){--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default) 0}@media(min-width:64rem){:host(:is(:is(:state(size-l),[state--size-l]),:is(:state(size-m),[state--size-m]))){--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default-large) 0}}:host(:is(:state(without-label),[state--without-label]):is(:state(size-m),[state--size-m]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: .1875rem .6875rem}@media(min-width:64rem){:host(:is(:state(without-label),[state--without-label]):is(:state(size-m),[state--size-m]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: .1875rem .875rem}}:host(:is(:state(without-label),[state--without-label]):not(:is(:state(empty),[state--empty]),:is(:state(size-s),[state--size-s]),:is(:state(size-m),[state--size-m]),:is(:state(size-l),[state--size-l]))){--sbb-chip-group-margin-block: var(--sbb-chip-group-margin-block-no-label-not-empty)}:host(:not(:is(:state(without-label),[state--without-label])):is(:state(size-m),[state--size-m]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default) var(--_sbb-chip-group-margin-block-start-default-large)}@media(min-width:64rem){:host(:not(:is(:state(without-label),[state--without-label])):is(:state(size-m),[state--size-m]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default-large) var(--_sbb-chip-group-margin-block-start-default-large)}}:host(:not(:is(:state(without-label),[state--without-label]),:is(:state(empty),[state--empty]),:is(:state(size-s),[state--size-s]),:is(:state(size-m),[state--size-m]),:is(:state(size-l),[state--size-l]))){--sbb-chip-group-margin-block: var(--sbb-chip-group-margin-block-with-label-not-empty)}:host(:is(:state(without-label),[state--without-label]):is(:state(size-l),[state--size-l]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default) 1rem}@media(min-width:64rem){:host(:is(:state(without-label),[state--without-label]):is(:state(size-l),[state--size-l]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default-large) 1.25rem}}:host(:not(:is(:state(without-label),[state--without-label])):is(:state(size-l),[state--size-l]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default) .46875rem}@media(min-width:64rem){:host(:not(:is(:state(without-label),[state--without-label])):is(:state(size-l),[state--size-l]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default-large) .46875rem}}::slotted(input){flex:1 1 var(--sbb-chip-group-input-min-width);max-height:1.5rem}::slotted(sbb-chip){max-width:100%}`;
17
- let ot = (() => {
18
- var h, u, n;
19
- let i = [W("sbb-chip-group")], a, r = [], p, y = B(N(j(G(U(L))))), f = [], v, z, w = [], k = [], E, C = [], S = [];
20
- return n = class extends y {
4
+ var B = (i, a, r) => a.has(i) || D("Cannot " + r);
5
+ var _ = (i, a, r) => (B(i, a, "read from private field"), r ? r.call(i) : a.get(i)), g = (i, a, r) => a.has(i) ? D("Cannot add the same private member more than once") : a instanceof WeakSet ? a.add(i) : a.set(i, r), u = (i, a, r, p) => (B(i, a, "write to private field"), p ? p.call(i, r) : a.set(i, r), r);
6
+ import { __esDecorate as d, __runInitializers as h } from "tslib";
7
+ import { css as W, LitElement as T, isServer as K, html as F } from "lit";
8
+ import { customElement as q, property as y } from "lit/decorators.js";
9
+ import { isArrowKeyPressed as M, getNextElementIndex as V } from "../../core/a11y.js";
10
+ import { SbbLanguageController as R, SbbPropertyWatcherController as $ } from "../../core/controllers.js";
11
+ import { forceType as N } from "../../core/decorators.js";
12
+ import { isLean as j } from "../../core/dom/lean-context.js";
13
+ import { i18nSelectionRequired as G, i18nChipGroupInputDescription as U } from "../../core/i18n.js";
14
+ import { SbbRequiredMixin as J, SbbDisabledMixin as P, SbbNegativeMixin as H, SbbFormAssociatedMixin as Q, SbbElementInternalsMixin as X } from "../../core/mixins.js";
15
+ import { boxSizingStyles as Y } from "../../core/styles.js";
16
+ import { SbbChipElement as Z } from "../chip.js";
17
+ const tt = W`:host{width:100%;display:flex;flex-wrap:wrap;gap:var(--sbb-chip-group-gap);align-items:center;margin-block:var(--sbb-chip-group-margin-block)}:host(:is(:is(:state(size-s),[state--size-s]),:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: 0}:host(:is(:state(size-s),[state--size-s]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: .375rem .3125rem}@media(min-width:64rem){:host(:is(:state(size-s),[state--size-s]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: .3125rem .1875rem}}:host(:is(:state(without-label),[state--without-label]):is(:state(size-s),[state--size-s]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: 0 .4375rem}@media(min-width:64rem){:host(:is(:state(without-label),[state--without-label]):is(:state(size-s),[state--size-s]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: 0 .3125rem}}:host(:is(:is(:state(size-l),[state--size-l]),:is(:state(size-m),[state--size-m]))){--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default) 0}@media(min-width:64rem){:host(:is(:is(:state(size-l),[state--size-l]),:is(:state(size-m),[state--size-m]))){--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default-large) 0}}:host(:is(:state(without-label),[state--without-label]):is(:state(size-m),[state--size-m]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: .1875rem .6875rem}@media(min-width:64rem){:host(:is(:state(without-label),[state--without-label]):is(:state(size-m),[state--size-m]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: .1875rem .875rem}}:host(:is(:state(without-label),[state--without-label]):not(:is(:state(empty),[state--empty]),:is(:state(size-s),[state--size-s]),:is(:state(size-m),[state--size-m]),:is(:state(size-l),[state--size-l]))){--sbb-chip-group-margin-block: var(--sbb-chip-group-margin-block-no-label-not-empty)}:host(:not(:is(:state(without-label),[state--without-label])):is(:state(size-m),[state--size-m]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default) var(--_sbb-chip-group-margin-block-start-default-large)}@media(min-width:64rem){:host(:not(:is(:state(without-label),[state--without-label])):is(:state(size-m),[state--size-m]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default-large) var(--_sbb-chip-group-margin-block-start-default-large)}}:host(:not(:is(:state(without-label),[state--without-label]),:is(:state(empty),[state--empty]),:is(:state(size-s),[state--size-s]),:is(:state(size-m),[state--size-m]),:is(:state(size-l),[state--size-l]))){--sbb-chip-group-margin-block: var(--sbb-chip-group-margin-block-with-label-not-empty)}:host(:is(:state(without-label),[state--without-label]):is(:state(size-l),[state--size-l]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default) 1rem}@media(min-width:64rem){:host(:is(:state(without-label),[state--without-label]):is(:state(size-l),[state--size-l]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default-large) 1.25rem}}:host(:not(:is(:state(without-label),[state--without-label])):is(:state(size-l),[state--size-l]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default) .46875rem}@media(min-width:64rem){:host(:not(:is(:state(without-label),[state--without-label])):is(:state(size-l),[state--size-l]):not(:is(:state(empty),[state--empty]))){--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default-large) .46875rem}}::slotted(input){flex:1 1 var(--sbb-chip-group-input-min-width);max-height:1.5rem}::slotted(sbb-chip){max-width:100%}`;
18
+ let ct = (() => {
19
+ var b, m, c, l;
20
+ let i = [q("sbb-chip-group")], a, r = [], p, f = J(P(H(Q(X(T))))), v = [], z, w, k = [], E = [], C, S = [], x = [], I, O = [], A = [];
21
+ return l = class extends f {
21
22
  constructor() {
22
23
  super();
23
- g(this, h);
24
- g(this, u);
25
- m(this, h, (b(this, f), b(this, w, null))), m(this, u, (b(this, k), b(this, C, ["Enter"]))), this._inputAttributeObserver = (b(this, S), A ? null : new MutationObserver(() => this._reactToInputChanges())), this._language = new F(this), this.addEventListener?.(P.events.requestdelete, (t) => this._deleteChip(t.target)), this.addEventListener?.("keydown", (t) => this._onChipKeyDown(t)), this.addController(new M(this, () => this.closest("sbb-form-field"), {
24
+ g(this, b);
25
+ g(this, m);
26
+ g(this, c);
27
+ u(this, b, (h(this, v), h(this, k, null))), u(this, m, (h(this, E), h(this, S, ["Enter"]))), u(this, c, (h(this, x), h(this, O, !1))), this._inputAttributeObserver = (h(this, A), K ? null : new MutationObserver(() => this._reactToInputChanges())), this._language = new R(this), this.addEventListener?.(Z.events.requestdelete, (t) => this._deleteChip(t.target)), this.addEventListener?.("keydown", (t) => this._onChipKeyDown(t)), this.addController(new $(this, () => this.closest("sbb-form-field"), {
26
28
  size: (t) => this._updateSize(t.size),
27
29
  label: (t) => this._updateLabelState(t),
28
30
  hiddenLabel: (t) => this._updateLabelState(t)
@@ -32,30 +34,37 @@ let ot = (() => {
32
34
  set value(t) {
33
35
  t = t ?? [];
34
36
  const e = this.value, s = [...e];
35
- for (const l of t)
36
- s.includes(l) && s.splice(s.indexOf(l), 1);
37
- s.forEach((l) => this._chipElements().find((D) => D.value === l)?.remove());
37
+ for (const n of t)
38
+ s.includes(n) && s.splice(s.indexOf(n), 1);
39
+ s.forEach((n) => this._chipElements().find((L) => L.value === n)?.remove());
38
40
  const o = [...t];
39
- for (const l of e)
40
- o.includes(l) && o.splice(o.indexOf(l), 1);
41
- o.forEach((l) => this._createChipElement(l));
41
+ for (const n of e)
42
+ o.includes(n) && o.splice(o.indexOf(n), 1);
43
+ o.forEach((n) => this._createChipElement(n));
42
44
  }
43
45
  get value() {
44
46
  return this._chipElements().map((t) => t.value);
45
47
  }
46
48
  /** Function that maps a chip's value to its display value. */
47
49
  get displayWith() {
48
- return d(this, h);
50
+ return _(this, b);
49
51
  }
50
52
  set displayWith(t) {
51
- m(this, h, t);
53
+ u(this, b, t);
52
54
  }
53
55
  /** The array of keys that will trigger a `chipinputtokenend` event. Default `['Enter']` */
54
56
  get separatorKeys() {
55
- return d(this, u);
57
+ return _(this, m);
56
58
  }
57
59
  set separatorKeys(t) {
58
- m(this, u, t);
60
+ u(this, m, t);
61
+ }
62
+ /** Whether to automatically add a chip when the input loses focus if there's a value. */
63
+ get addOnBlur() {
64
+ return _(this, c);
65
+ }
66
+ set addOnBlur(t) {
67
+ u(this, c, t);
59
68
  }
60
69
  _updateLabelState(t) {
61
70
  this.toggleState("without-label", !t.label || t.hiddenLabel);
@@ -85,7 +94,7 @@ let ot = (() => {
85
94
  return super.shouldValidate(t) || t === "required" || t === "value";
86
95
  }
87
96
  validate() {
88
- super.validate(), this.required && this.value.length === 0 ? this.setValidityFlag("valueMissing", R[this._language.current]) : this.removeValidityFlag("valueMissing");
97
+ super.validate(), this.required && this.value.length === 0 ? this.setValidityFlag("valueMissing", G[this._language.current]) : this.removeValidityFlag("valueMissing");
89
98
  }
90
99
  /** Return the list of chip elements **/
91
100
  _chipElements() {
@@ -99,6 +108,9 @@ let ot = (() => {
99
108
  const t = this.querySelector("input");
100
109
  t && t !== this._inputElement && (this._inputAbortController?.abort(), this._inputAttributeObserver?.disconnect(), this._inputElement = t, this._inputAbortController = new AbortController(), this._inputElement.addEventListener("keydown", (e) => this._onInputKeyDown(e), {
101
110
  signal: this._inputAbortController.signal
111
+ }), this._inputElement.addEventListener("blur", () => this._onInputBlur(), {
112
+ signal: this._inputAbortController.signal,
113
+ capture: !0
102
114
  }), this._inputElement.addEventListener("inputAutocomplete", (e) => {
103
115
  this._createChipFromInput("autocomplete", e.detail?.option.value);
104
116
  }, {
@@ -106,7 +118,7 @@ let ot = (() => {
106
118
  }), this._inputAttributeObserver?.observe(this._inputElement, {
107
119
  attributes: !0,
108
120
  attributeFilter: ["readonly", "disabled"]
109
- })), (!this._previousSize || !this.closest("sbb-form-field")) && this._updateSize(V() ? "s" : "m"), this.toggleState("empty", this.value.length === 0), this._reactToInputChanges(), this._updateInputDescription(), this.updateFormValue();
121
+ })), (!this._previousSize || !this.closest("sbb-form-field")) && this._updateSize(j() ? "s" : "m"), this.toggleState("empty", this.value.length === 0), this._reactToInputChanges(), this._updateInputDescription(), this.updateFormValue();
110
122
  }
111
123
  /**
112
124
  * Listen for keyboard events on the chip elements
@@ -114,8 +126,8 @@ let ot = (() => {
114
126
  _onChipKeyDown(t) {
115
127
  const e = t.target;
116
128
  if (e.localName === "sbb-chip") {
117
- if (T(t)) {
118
- const s = this._enabledChipElements(), o = q(t, s.indexOf(e), s.length);
129
+ if (M(t)) {
130
+ const s = this._enabledChipElements(), o = V(t, s.indexOf(e), s.length);
119
131
  s[o].focus();
120
132
  return;
121
133
  }
@@ -142,6 +154,12 @@ let ot = (() => {
142
154
  }
143
155
  this.separatorKeys.includes(t.key) && (t.preventDefault(), this._createChipFromInput("input"));
144
156
  }
157
+ /**
158
+ * Handle blur event on the input
159
+ **/
160
+ _onInputBlur() {
161
+ this.addOnBlur && this._createChipFromInput("input");
162
+ }
145
163
  /**
146
164
  * If the input is not empty, create a chip with its value
147
165
  */
@@ -153,8 +171,8 @@ let ot = (() => {
153
171
  origin: t,
154
172
  value: s,
155
173
  label: (e ? this.displayWith?.(e) : null) ?? void 0,
156
- setValue: (l) => o.value = l,
157
- setLabel: (l) => o.label = l
174
+ setValue: (n) => o.value = n,
175
+ setLabel: (n) => o.label = n
158
176
  };
159
177
  this._dispatchChipInputTokenEnd(o) && (this._createChipElement(o.value, o.label), this._inputElement.value = "", this._emitInputEvents());
160
178
  }
@@ -190,7 +208,7 @@ let ot = (() => {
190
208
  this.dispatchEvent(new InputEvent("input", { bubbles: !0, composed: !0 })), this.dispatchEvent(new Event("change", { bubbles: !0 }));
191
209
  }
192
210
  _createChipElement(t, e) {
193
- if (A)
211
+ if (K)
194
212
  return;
195
213
  const s = document.createElement("sbb-chip");
196
214
  s.value = t, s.innerText = e ?? (t ? this.displayWith?.(t) : null) ?? "", this.insertBefore(s, this._inputElement ?? this.querySelector("input"));
@@ -207,26 +225,28 @@ let ot = (() => {
207
225
  this._previousSize && this.internals.states.delete(`size-${this._previousSize}`), this._previousSize = t, this._previousSize && this.internals.states.add(`size-${this._previousSize}`);
208
226
  }
209
227
  _updateInputDescription() {
210
- this._inputElement && this._inputElement.setAttribute("aria-description", `${$[this._language.current]} ${this.value.length}`);
228
+ this._inputElement && this._inputElement.setAttribute("aria-description", `${U[this._language.current]} ${this.value.length}`);
211
229
  }
212
230
  render() {
213
- return O`<slot @slotchange=${this._setupComponent}></slot>`;
231
+ return F`<slot @slotchange=${this._setupComponent}></slot>`;
214
232
  }
215
- }, h = new WeakMap(), u = new WeakMap(), p = n, (() => {
216
- const t = typeof Symbol == "function" && Symbol.metadata ? Object.create(y[Symbol.metadata] ?? null) : void 0;
217
- v = [_({ type: Array })], z = [_({ attribute: !1 })], E = [_({ attribute: "separator-keys", type: Array })], c(n, null, v, { kind: "setter", name: "value", static: !1, private: !1, access: { has: (e) => "value" in e, set: (e, s) => {
233
+ }, b = new WeakMap(), m = new WeakMap(), c = new WeakMap(), p = l, (() => {
234
+ const t = typeof Symbol == "function" && Symbol.metadata ? Object.create(f[Symbol.metadata] ?? null) : void 0;
235
+ z = [y({ type: Array })], w = [y({ attribute: !1 })], C = [y({ attribute: "separator-keys", type: Array })], I = [N(), y({ attribute: "add-on-blur", type: Boolean })], d(l, null, z, { kind: "setter", name: "value", static: !1, private: !1, access: { has: (e) => "value" in e, set: (e, s) => {
218
236
  e.value = s;
219
- } }, metadata: t }, null, f), c(n, null, z, { kind: "accessor", name: "displayWith", static: !1, private: !1, access: { has: (e) => "displayWith" in e, get: (e) => e.displayWith, set: (e, s) => {
237
+ } }, metadata: t }, null, v), d(l, null, w, { kind: "accessor", name: "displayWith", static: !1, private: !1, access: { has: (e) => "displayWith" in e, get: (e) => e.displayWith, set: (e, s) => {
220
238
  e.displayWith = s;
221
- } }, metadata: t }, w, k), c(n, null, E, { kind: "accessor", name: "separatorKeys", static: !1, private: !1, access: { has: (e) => "separatorKeys" in e, get: (e) => e.separatorKeys, set: (e, s) => {
239
+ } }, metadata: t }, k, E), d(l, null, C, { kind: "accessor", name: "separatorKeys", static: !1, private: !1, access: { has: (e) => "separatorKeys" in e, get: (e) => e.separatorKeys, set: (e, s) => {
222
240
  e.separatorKeys = s;
223
- } }, metadata: t }, C, S), c(null, a = { value: p }, i, { kind: "class", name: p.name, metadata: t }, null, r), p = a.value, t && Object.defineProperty(p, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: t });
224
- })(), n.role = "listbox", n.styles = [J, H], n.events = {
241
+ } }, metadata: t }, S, x), d(l, null, I, { kind: "accessor", name: "addOnBlur", static: !1, private: !1, access: { has: (e) => "addOnBlur" in e, get: (e) => e.addOnBlur, set: (e, s) => {
242
+ e.addOnBlur = s;
243
+ } }, metadata: t }, O, A), d(null, a = { value: p }, i, { kind: "class", name: p.name, metadata: t }, null, r), p = a.value, t && Object.defineProperty(p, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: t });
244
+ })(), l.role = "listbox", l.styles = [Y, tt], l.events = {
225
245
  input: "input",
226
246
  change: "change",
227
247
  chipinputtokenend: "chipinputtokenend"
228
- }, b(p, r), p;
248
+ }, h(p, r), p;
229
249
  })();
230
250
  export {
231
- ot as SbbChipGroupElement
251
+ ct as SbbChipGroupElement
232
252
  };
@@ -44613,6 +44613,17 @@
44613
44613
  "description": "The array of keys that will trigger a `chipinputtokenend` event. Default `['Enter']`",
44614
44614
  "attribute": "separator-keys"
44615
44615
  },
44616
+ {
44617
+ "kind": "field",
44618
+ "name": "addOnBlur",
44619
+ "type": {
44620
+ "text": "boolean"
44621
+ },
44622
+ "privacy": "public",
44623
+ "default": "false",
44624
+ "description": "Whether to automatically add a chip when the input loses focus if there's a value.",
44625
+ "attribute": "add-on-blur"
44626
+ },
44616
44627
  {
44617
44628
  "kind": "field",
44618
44629
  "name": "_inputAttributeObserver",
@@ -44793,6 +44804,17 @@
44793
44804
  ],
44794
44805
  "description": "Listen for keyboard events on the input"
44795
44806
  },
44807
+ {
44808
+ "kind": "method",
44809
+ "name": "_onInputBlur",
44810
+ "privacy": "private",
44811
+ "return": {
44812
+ "type": {
44813
+ "text": "void"
44814
+ }
44815
+ },
44816
+ "description": "Handle blur event on the input"
44817
+ },
44796
44818
  {
44797
44819
  "kind": "method",
44798
44820
  "name": "_createChipFromInput",
@@ -45412,6 +45434,15 @@
45412
45434
  "description": "The array of keys that will trigger a `chipinputtokenend` event. Default `['Enter']`",
45413
45435
  "fieldName": "separatorKeys"
45414
45436
  },
45437
+ {
45438
+ "name": "add-on-blur",
45439
+ "type": {
45440
+ "text": "boolean"
45441
+ },
45442
+ "default": "false",
45443
+ "description": "Whether to automatically add a chip when the input loses focus if there's a value.",
45444
+ "fieldName": "addOnBlur"
45445
+ },
45415
45446
  {
45416
45447
  "name": "required",
45417
45448
  "description": "Whether the component is required.",
@@ -37,6 +37,8 @@ export declare class SbbChipGroupElement<T = string> extends SbbChipGroupElement
37
37
  accessor displayWith: ((value: T) => string) | null;
38
38
  /** The array of keys that will trigger a `chipinputtokenend` event. Default `['Enter']` */
39
39
  accessor separatorKeys: string[];
40
+ /** Whether to automatically add a chip when the input loses focus if there's a value. */
41
+ accessor addOnBlur: boolean;
40
42
  /**
41
43
  * Listens to the changes on `readonly` and `disabled` attributes of `<input>`.
42
44
  */
@@ -69,6 +71,10 @@ export declare class SbbChipGroupElement<T = string> extends SbbChipGroupElement
69
71
  * Listen for keyboard events on the input
70
72
  **/
71
73
  private _onInputKeyDown;
74
+ /**
75
+ * Handle blur event on the input
76
+ **/
77
+ private _onInputBlur;
72
78
  /**
73
79
  * If the input is not empty, create a chip with its value
74
80
  */
@@ -1 +1 @@
1
- {"version":3,"file":"chip-group.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/chip/chip-group/chip-group.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAGnB,UAAU,EACV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAOb,OAAO,EACL,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,EAMtB,MAAM,sBAAsB,CAAC;AAU9B,MAAM,WAAW,gCAAgC,CAAC,CAAC,GAAG,MAAM;IAC1D,mDAAmD;IACnD,MAAM,EAAE,OAAO,GAAG,cAAc,CAAC;IACjC;;;;OAIG;IACH,KAAK,EAAE,CAAC,GAAG,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,wDAAwD;IACxD,QAAQ,CAAC,KAAK,EAAE,CAAC,GAAG,IAAI,CAAC;IACzB,oDAAoD;IACpD,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;CAC/B;;AAED;;;;;GAKG;AACH,qBAEM,mBAAmB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,wBAE7C;IACC,gBAAgC,IAAI,aAAa;IACjD,OAAuB,MAAM,EAAE,cAAc,CAA4B;IACzE,gBAAuB,MAAM;;;;MAIlB;IAEX,iCAAiC;IACjC,IACW,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,EA2B1C;IACD,IAAW,KAAK,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,CAE/B;IAED,8DAA8D;IAC9D,SACgB,WAAW,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC,KAAK,MAAM,CAAC,GAAG,IAAI,CAAQ;IAElE,2FAA2F;IAC3F,SACgB,aAAa,EAAE,MAAM,EAAE,CAAa;IAEpD;;OAEG;IACH,OAAO,CAAC,uBAAuB,CAEtB;IAET,OAAO,CAAC,aAAa,CAA+B;IACpD,OAAO,CAAC,qBAAqB,CAA8B;IAC3D,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,aAAa,CAAC,CAA8B;;IAoBpD,OAAO,CAAC,iBAAiB;IAIT,iBAAiB,IAAI,IAAI;cAKtB,UAAU,CAAC,iBAAiB,EAAE,cAAc,GAAG,IAAI;IAYtE,gBAAgB;IACT,iBAAiB,IAAI,IAAI;IAIhC,gBAAgB;IACT,wBAAwB,CAC7B,KAAK,EAAE,gBAAgB,GAAG,IAAI,EAC9B,OAAO,EAAE,iBAAiB,GACzB,IAAI;YASO,aAAa;cAUR,cAAc,CAAC,IAAI,EAAE,WAAW,GAAG,SAAS,GAAG,OAAO;cAItD,QAAQ,IAAI,IAAI;IASnC,wCAAwC;IACxC,OAAO,CAAC,aAAa;IAIrB,gDAAgD;IAChD,OAAO,CAAC,oBAAoB;IAI5B,OAAO,CAAC,eAAe;IAwCvB;;QAEI;IACJ,OAAO,CAAC,cAAc;IAyBtB;;QAEI;IACJ,OAAO,CAAC,eAAe;IAoBvB;;OAEG;IACH,OAAO,CAAC,oBAAoB;IAuB5B,OAAO,CAAC,0BAA0B;IAelC,OAAO,CAAC,WAAW;IAOnB;;;OAGG;IACH,OAAO,CAAC,UAAU;IAgBlB,OAAO,CAAC,gBAAgB;IAYxB,OAAO,CAAC,kBAAkB;IAwB1B,OAAO,CAAC,oBAAoB;IAK5B,OAAO,CAAC,kBAAkB;IAQ1B,OAAO,CAAC,WAAW;IAUnB,OAAO,CAAC,uBAAuB;cAUZ,MAAM,IAAI,cAAc;CAG5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,gBAAgB,EAAE,mBAAmB,CAAC;KACvC;CACF;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,mBAAmB;QAC3B,iBAAiB,EAAE,WAAW,CAAC,gCAAgC,CAAC,GAAG,CAAC,CAAC,CAAC;KACvE;CACF"}
1
+ {"version":3,"file":"chip-group.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/chip/chip-group/chip-group.component.ts"],"names":[],"mappings":"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"}
@@ -10,6 +10,7 @@ import { css, LitElement, isServer, html } from "lit";
10
10
  import { customElement, property } from "lit/decorators.js";
11
11
  import { isArrowKeyPressed, getNextElementIndex } from "../../core/a11y.js";
12
12
  import { SbbLanguageController, SbbPropertyWatcherController } from "../../core/controllers.js";
13
+ import { forceType } from "../../core/decorators.js";
13
14
  import { isLean } from "../../core/dom/lean-context.js";
14
15
  import { i18nSelectionRequired, i18nChipGroupInputDescription } from "../../core/i18n.js";
15
16
  import { SbbRequiredMixin, SbbDisabledMixin, SbbNegativeMixin, SbbFormAssociatedMixin, SbbElementInternalsMixin } from "../../core/mixins.js";
@@ -114,7 +115,7 @@ const style = css`:host {
114
115
  max-width: 100%;
115
116
  }`;
116
117
  let SbbChipGroupElement = (() => {
117
- var _displayWith_accessor_storage, _separatorKeys_accessor_storage, _a;
118
+ var _displayWith_accessor_storage, _separatorKeys_accessor_storage, _addOnBlur_accessor_storage, _a;
118
119
  let _classDecorators = [customElement("sbb-chip-group")];
119
120
  let _classDescriptor;
120
121
  let _classExtraInitializers = [];
@@ -128,14 +129,19 @@ let SbbChipGroupElement = (() => {
128
129
  let _separatorKeys_decorators;
129
130
  let _separatorKeys_initializers = [];
130
131
  let _separatorKeys_extraInitializers = [];
132
+ let _addOnBlur_decorators;
133
+ let _addOnBlur_initializers = [];
134
+ let _addOnBlur_extraInitializers = [];
131
135
  _a = class extends _classSuper {
132
136
  constructor() {
133
137
  super();
134
138
  __privateAdd(this, _displayWith_accessor_storage);
135
139
  __privateAdd(this, _separatorKeys_accessor_storage);
140
+ __privateAdd(this, _addOnBlur_accessor_storage);
136
141
  __privateSet(this, _displayWith_accessor_storage, (__runInitializers(this, _instanceExtraInitializers), __runInitializers(this, _displayWith_initializers, null)));
137
142
  __privateSet(this, _separatorKeys_accessor_storage, (__runInitializers(this, _displayWith_extraInitializers), __runInitializers(this, _separatorKeys_initializers, ["Enter"])));
138
- this._inputAttributeObserver = (__runInitializers(this, _separatorKeys_extraInitializers), !isServer ? new MutationObserver(() => this._reactToInputChanges()) : null);
143
+ __privateSet(this, _addOnBlur_accessor_storage, (__runInitializers(this, _separatorKeys_extraInitializers), __runInitializers(this, _addOnBlur_initializers, false)));
144
+ this._inputAttributeObserver = (__runInitializers(this, _addOnBlur_extraInitializers), !isServer ? new MutationObserver(() => this._reactToInputChanges()) : null);
139
145
  this._language = new SbbLanguageController(this);
140
146
  this.addEventListener?.(SbbChipElement.events.requestdelete, (ev) => this._deleteChip(ev.target));
141
147
  this.addEventListener?.("keydown", (ev) => this._onChipKeyDown(ev));
@@ -181,6 +187,13 @@ let SbbChipGroupElement = (() => {
181
187
  set separatorKeys(value) {
182
188
  __privateSet(this, _separatorKeys_accessor_storage, value);
183
189
  }
190
+ /** Whether to automatically add a chip when the input loses focus if there's a value. */
191
+ get addOnBlur() {
192
+ return __privateGet(this, _addOnBlur_accessor_storage);
193
+ }
194
+ set addOnBlur(value) {
195
+ __privateSet(this, _addOnBlur_accessor_storage, value);
196
+ }
184
197
  _updateLabelState(formField) {
185
198
  this.toggleState("without-label", !formField.label || formField.hiddenLabel);
186
199
  }
@@ -238,6 +251,10 @@ let SbbChipGroupElement = (() => {
238
251
  this._inputElement.addEventListener("keydown", (ev) => this._onInputKeyDown(ev), {
239
252
  signal: this._inputAbortController.signal
240
253
  });
254
+ this._inputElement.addEventListener("blur", () => this._onInputBlur(), {
255
+ signal: this._inputAbortController.signal,
256
+ capture: true
257
+ });
241
258
  this._inputElement.addEventListener("inputAutocomplete", (event) => {
242
259
  this._createChipFromInput("autocomplete", event.detail?.option.value);
243
260
  }, {
@@ -300,6 +317,14 @@ let SbbChipGroupElement = (() => {
300
317
  this._createChipFromInput("input");
301
318
  }
302
319
  }
320
+ /**
321
+ * Handle blur event on the input
322
+ **/
323
+ _onInputBlur() {
324
+ if (this.addOnBlur) {
325
+ this._createChipFromInput("input");
326
+ }
327
+ }
303
328
  /**
304
329
  * If the input is not empty, create a chip with its value
305
330
  */
@@ -394,11 +419,12 @@ let SbbChipGroupElement = (() => {
394
419
  render() {
395
420
  return html`<slot @slotchange=${this._setupComponent}></slot>`;
396
421
  }
397
- }, _displayWith_accessor_storage = new WeakMap(), _separatorKeys_accessor_storage = new WeakMap(), _classThis = _a, (() => {
422
+ }, _displayWith_accessor_storage = new WeakMap(), _separatorKeys_accessor_storage = new WeakMap(), _addOnBlur_accessor_storage = new WeakMap(), _classThis = _a, (() => {
398
423
  const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
399
424
  _set_value_decorators = [property({ type: Array })];
400
425
  _displayWith_decorators = [property({ attribute: false })];
401
426
  _separatorKeys_decorators = [property({ attribute: "separator-keys", type: Array })];
427
+ _addOnBlur_decorators = [forceType(), property({ attribute: "add-on-blur", type: Boolean })];
402
428
  __esDecorate(_a, null, _set_value_decorators, { kind: "setter", name: "value", static: false, private: false, access: { has: (obj) => "value" in obj, set: (obj, value) => {
403
429
  obj.value = value;
404
430
  } }, metadata: _metadata }, null, _instanceExtraInitializers);
@@ -408,6 +434,9 @@ let SbbChipGroupElement = (() => {
408
434
  __esDecorate(_a, null, _separatorKeys_decorators, { kind: "accessor", name: "separatorKeys", static: false, private: false, access: { has: (obj) => "separatorKeys" in obj, get: (obj) => obj.separatorKeys, set: (obj, value) => {
409
435
  obj.separatorKeys = value;
410
436
  } }, metadata: _metadata }, _separatorKeys_initializers, _separatorKeys_extraInitializers);
437
+ __esDecorate(_a, null, _addOnBlur_decorators, { kind: "accessor", name: "addOnBlur", static: false, private: false, access: { has: (obj) => "addOnBlur" in obj, get: (obj) => obj.addOnBlur, set: (obj, value) => {
438
+ obj.addOnBlur = value;
439
+ } }, metadata: _metadata }, _addOnBlur_initializers, _addOnBlur_extraInitializers);
411
440
  __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
412
441
  _classThis = _classDescriptor.value;
413
442
  if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
@@ -421,4 +450,4 @@ let SbbChipGroupElement = (() => {
421
450
  export {
422
451
  SbbChipGroupElement
423
452
  };
424
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"chip-group.component.js","sources":["../../../../../src/elements/chip/chip-group/chip-group.component.ts"],"sourcesContent":["import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  LitElement,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { getNextElementIndex, isArrowKeyPressed } from '../../core/a11y.ts';\nimport { SbbLanguageController, SbbPropertyWatcherController } from '../../core/controllers.ts';\nimport { isLean } from '../../core/dom/lean-context.ts';\nimport { i18nChipGroupInputDescription, i18nSelectionRequired } from '../../core/i18n.ts';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbDisabledMixin,\n  SbbElementInternalsMixin,\n  SbbFormAssociatedMixin,\n  SbbNegativeMixin,\n  SbbRequiredMixin,\n} from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport type { SbbFormFieldElement } from '../../form-field/form-field/form-field.component.ts';\nimport type { SbbOptionBaseElement } from '../../option/option/option-base-element.ts';\nimport { SbbChipElement } from '../chip.ts';\n\nimport style from './chip-group.scss?lit&inline';\n\nlet displayWithWarningLogged = false;\n\nexport interface SbbChipInputTokenEndEventDetails<T = string> {\n  /** The element that triggered the chip creation */\n  origin: 'input' | 'autocomplete';\n  /**\n   * The value of the new chip. Either the input or the option value depending on the origin.\n   * Either the value from the input which is always `string` or the value from the selected option\n   * from an autocomplete, which can be either a string or any other type.\n   */\n  value: T | string;\n  label?: string;\n  /** Set a new value for the chip that will be created */\n  setValue(value: T): void;\n  /** Set a label for the chip that will be created */\n  setLabel(value: string): void;\n}\n\n/**\n * The `sbb-chip-group` component is used as a container for one or multiple `sbb-chip`.\n *\n * @slot - Use the unnamed slot to add `sbb-chip` elements.\n * @overrideType value - (T = string[]) | null\n */\nexport\n@customElement('sbb-chip-group')\nclass SbbChipGroupElement<T = string> extends SbbRequiredMixin(\n  SbbDisabledMixin(SbbNegativeMixin(SbbFormAssociatedMixin(SbbElementInternalsMixin(LitElement)))),\n) {\n  public static override readonly role = 'listbox';\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  public static readonly events = {\n    input: 'input',\n    change: 'change',\n    chipinputtokenend: 'chipinputtokenend',\n  } as const;\n\n  /** Value of the form element. */\n  @property({ type: Array })\n  public set value(value: (T | null)[] | null) {\n    value = value ?? [];\n    const oldValue = this.value;\n\n    // Subtract from 'oldValue' the new 'value'\n    // The result are the chips to remove (handle duplicates)\n    const toRemove = [...oldValue];\n    for (const c of value) {\n      if (toRemove.includes(c)) {\n        toRemove.splice(toRemove.indexOf(c), 1);\n      }\n    }\n    toRemove.forEach((value) =>\n      this._chipElements()\n        .find((c) => c.value === value)\n        ?.remove(),\n    );\n\n    // Subtract from the new 'value' what was already present\n    // The result are the new chips to add (handle duplicates)\n    const toAdd = [...value];\n    for (const c of oldValue) {\n      if (toAdd.includes(c)) {\n        toAdd.splice(toAdd.indexOf(c), 1);\n      }\n    }\n    toAdd.forEach((c) => this._createChipElement(c));\n  }\n  public get value(): (T | null)[] {\n    return this._chipElements().map((c) => c.value);\n  }\n\n  /** Function that maps a chip's value to its display value. */\n  @property({ attribute: false })\n  public accessor displayWith: ((value: T) => string) | null = null;\n\n  /** The array of keys that will trigger a `chipinputtokenend` event. Default `['Enter']` */\n  @property({ attribute: 'separator-keys', type: Array })\n  public accessor separatorKeys: string[] = ['Enter'];\n\n  /**\n   * Listens to the changes on `readonly` and `disabled` attributes of `<input>`.\n   */\n  private _inputAttributeObserver = !isServer\n    ? new MutationObserver(() => this._reactToInputChanges())\n    : null;\n\n  private _inputElement: HTMLInputElement | undefined;\n  private _inputAbortController: AbortController | undefined;\n  private _language = new SbbLanguageController(this);\n  private _previousSize?: SbbFormFieldElement['size'];\n\n  public constructor() {\n    super();\n\n    this.addEventListener?.(SbbChipElement.events.requestdelete, (ev) =>\n      this._deleteChip(ev.target as SbbChipElement<T>),\n    );\n\n    this.addEventListener?.('keydown', (ev) => this._onChipKeyDown(ev));\n\n    this.addController(\n      new SbbPropertyWatcherController(this, () => this.closest('sbb-form-field'), {\n        size: (formField) => this._updateSize(formField.size),\n        label: (formField) => this._updateLabelState(formField),\n        hiddenLabel: (formField) => this._updateLabelState(formField),\n      }),\n    );\n  }\n\n  private _updateLabelState(formField: SbbFormFieldElement): void {\n    this.toggleState('without-label', !formField.label || formField.hiddenLabel);\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this._setupComponent();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues): void {\n    super.willUpdate(changedProperties);\n\n    if (\n      changedProperties.has('disabled') ||\n      changedProperties.has('formDisabled') ||\n      changedProperties.has('negative')\n    ) {\n      this._proxyStateToChips();\n    }\n  }\n\n  /** @internal */\n  public formResetCallback(): void {\n    this.value = null;\n  }\n\n  /** @internal */\n  public formStateRestoreCallback(\n    state: FormRestoreState | null,\n    _reason: FormRestoreReason,\n  ): void {\n    if (!state) {\n      this.value = null;\n      return;\n    }\n\n    this._readFormData(state as FormData).then((array) => (this.value = array));\n  }\n\n  private async _readFormData(formData: FormData): Promise<T[]> {\n    return Promise.all(\n      formData\n        .getAll(this.name)\n        .map(async (entry) =>\n          entry instanceof Blob ? JSON.parse(await entry.text()) : (entry as T),\n        ),\n    );\n  }\n\n  protected override shouldValidate(name: PropertyKey | undefined): boolean {\n    return super.shouldValidate(name) || name === 'required' || name === 'value';\n  }\n\n  protected override validate(): void {\n    super.validate();\n    if (this.required && this.value.length === 0) {\n      this.setValidityFlag('valueMissing', i18nSelectionRequired[this._language.current]);\n    } else {\n      this.removeValidityFlag('valueMissing');\n    }\n  }\n\n  /** Return the list of chip elements **/\n  private _chipElements(): SbbChipElement<T>[] {\n    return Array.from(this.querySelectorAll?.<SbbChipElement<T>>('sbb-chip') ?? []);\n  }\n\n  /** Return the list of enabled chip elements **/\n  private _enabledChipElements(): SbbChipElement<T>[] {\n    return Array.from(this.querySelectorAll?.('sbb-chip:not([disabled])') ?? []);\n  }\n\n  private _setupComponent(): void {\n    const input = this.querySelector('input');\n\n    // Connect to the input\n    if (input && input !== this._inputElement) {\n      this._inputAbortController?.abort();\n      this._inputAttributeObserver?.disconnect();\n      this._inputElement = input;\n\n      this._inputAbortController = new AbortController();\n      this._inputElement.addEventListener('keydown', (ev) => this._onInputKeyDown(ev), {\n        signal: this._inputAbortController.signal,\n      });\n      this._inputElement.addEventListener(\n        'inputAutocomplete',\n        (event: CustomEvent<{ option: SbbOptionBaseElement<T> }>) => {\n          this._createChipFromInput('autocomplete', event.detail?.option.value);\n        },\n        {\n          signal: this._inputAbortController.signal,\n        },\n      );\n\n      this._inputAttributeObserver?.observe(this._inputElement, {\n        attributes: true,\n        attributeFilter: ['readonly', 'disabled'],\n      });\n    }\n\n    // Inherit size from the form-field and observe for changes\n    if (!this._previousSize || !this.closest('sbb-form-field')) {\n      this._updateSize(isLean() ? 's' : 'm');\n    }\n\n    this.toggleState('empty', this.value.length === 0);\n    this._reactToInputChanges();\n    this._updateInputDescription();\n    this.updateFormValue();\n  }\n\n  /**\n   * Listen for keyboard events on the chip elements\n   **/\n  private _onChipKeyDown(event: KeyboardEvent): void {\n    const eventTarget = event.target as SbbChipElement<T>;\n    if (eventTarget.localName !== 'sbb-chip') {\n      return;\n    }\n\n    // Arrow keys allow navigation between chips focus steps\n    if (isArrowKeyPressed(event)) {\n      const focusSteps = this._enabledChipElements();\n      const next = getNextElementIndex(event, focusSteps.indexOf(eventTarget), focusSteps.length);\n      focusSteps[next].focus();\n      return;\n    }\n\n    switch (event.key) {\n      case 'Backspace':\n      case 'Delete':\n        if (!eventTarget.readOnly && !eventTarget.disabled) {\n          event.preventDefault();\n          this._deleteChip(eventTarget);\n        }\n        break;\n    }\n  }\n\n  /**\n   * Listen for keyboard events on the input\n   **/\n  private _onInputKeyDown(event: KeyboardEvent): void {\n    switch (event.key) {\n      case 'Backspace':\n      case 'ArrowLeft':\n        if (!this._inputElement!.value) {\n          this._focusChip();\n        }\n        break;\n      case 'Enter':\n        event.preventDefault(); // Prevents the form submit\n        break;\n    }\n\n    // if the user typed one of the separator keys, trigger a 'chipinputtokenend' event\n    if (this.separatorKeys.includes(event.key)) {\n      event.preventDefault(); // prevent typing the separator key into the input\n      this._createChipFromInput('input');\n    }\n  }\n\n  /**\n   * If the input is not empty, create a chip with its value\n   */\n  private _createChipFromInput(origin: 'input' | 'autocomplete' = 'input', value?: T): void {\n    const inputValue = value ?? this._inputElement!.value.trim();\n    if (!inputValue) {\n      return;\n    }\n\n    const eventDetail: SbbChipInputTokenEndEventDetails<T> = {\n      origin: origin,\n      value: inputValue,\n      label: (value ? this.displayWith?.(value) : null) ?? undefined,\n      setValue: (value: T) => (eventDetail.value = value),\n      setLabel: (label: string) => (eventDetail.label = label),\n    };\n\n    if (!this._dispatchChipInputTokenEnd(eventDetail)) {\n      return; // event prevented; do nothing (the consumer has to create the chip)\n    }\n\n    this._createChipElement(eventDetail.value as T, eventDetail.label);\n    this._inputElement!.value = ''; // Empty the input\n    this._emitInputEvents();\n  }\n\n  private _dispatchChipInputTokenEnd(eventDetail: SbbChipInputTokenEndEventDetails<T>): boolean {\n    /**\n     * @type {CustomEvent<SbbChipInputTokenEndEventDetails>}\n     * Notifies that a chip is about to be created. Can be prevented.\n     */\n    return this.dispatchEvent(\n      new CustomEvent<SbbChipInputTokenEndEventDetails<T>>('chipinputtokenend', {\n        detail: eventDetail,\n        cancelable: true,\n        bubbles: true,\n        composed: true,\n      }),\n    );\n  }\n\n  private _deleteChip(chip: SbbChipElement<T>): void {\n    const chips = this._enabledChipElements();\n    chip.remove();\n    this._emitInputEvents();\n    this._focusChip(chips.indexOf(chip)); // Focus the next chip\n  }\n\n  /**\n   * Focus an enabled chip. If none are present, focus the input\n   * @param index The index of the enabled chip. If null, focus the last one.\n   */\n  private _focusChip(index?: number): void {\n    const enabledChips = this._enabledChipElements();\n\n    if (index !== undefined && enabledChips[index]) {\n      enabledChips[index].focus();\n      return;\n    }\n\n    if (enabledChips.length > 0) {\n      enabledChips[enabledChips.length - 1].focus();\n      return;\n    }\n\n    this._inputElement?.focus();\n  }\n\n  private _emitInputEvents(): void {\n    /** The input event fires when the value has been changed as a direct result of a user action. */\n    this.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n\n    /**\n     * The change event is fired when the user modifies the element's value.\n     * Unlike the input event, the change event is not necessarily fired\n     * for each alteration to an element's value.\n     */\n    this.dispatchEvent(new Event('change', { bubbles: true }));\n  }\n\n  private _createChipElement(value: T | null, label?: string): void {\n    if (isServer) {\n      return;\n    }\n    const newChip = document.createElement('sbb-chip') as SbbChipElement<T>;\n    newChip.value = value;\n    newChip.innerText = label ?? (value ? this.displayWith?.(value) : null) ?? '';\n    if (\n      import.meta.env.DEV &&\n      !displayWithWarningLogged &&\n      !label &&\n      typeof value === 'object' &&\n      !this.displayWith\n    ) {\n      console.warn(\n        `displayWith has not been set yet for sbb-chip-group and value is an object.\n         If you are using object values, you need to provide displayWidth before\n         setting or selecting any value.`,\n      );\n      displayWithWarningLogged = true;\n    }\n    this.insertBefore(newChip, this._inputElement ?? this.querySelector('input'));\n  }\n\n  private _reactToInputChanges(): void {\n    this.disabled = this._inputElement?.disabled ?? false;\n    this._proxyStateToChips();\n  }\n\n  private _proxyStateToChips(): void {\n    this._chipElements().forEach((c) => {\n      c.disabled = this.disabled || this.formDisabled;\n      c.readOnly = this._inputElement?.hasAttribute('readonly') ?? false;\n      c.negative = this.negative;\n    });\n  }\n\n  private _updateSize(size: SbbFormFieldElement['size']): void {\n    if (this._previousSize) {\n      this.internals.states.delete(`size-${this._previousSize}`);\n    }\n    this._previousSize = size;\n    if (this._previousSize) {\n      this.internals.states.add(`size-${this._previousSize}`);\n    }\n  }\n\n  private _updateInputDescription(): void {\n    if (!this._inputElement) {\n      return;\n    }\n    this._inputElement.setAttribute(\n      'aria-description',\n      `${i18nChipGroupInputDescription[this._language.current]} ${this.value.length}`,\n    );\n  }\n\n  protected override render(): TemplateResult {\n    return html`<slot @slotchange=${this._setupComponent}></slot>`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-chip-group': SbbChipGroupElement;\n  }\n}\n\ndeclare global {\n  interface HTMLElementEventMap {\n    chipinputtokenend: CustomEvent<SbbChipInputTokenEndEventDetails<any>>;\n  }\n}\n"],"names":["value"],"mappings":"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"}
453
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"chip-group.component.js","sources":["../../../../../src/elements/chip/chip-group/chip-group.component.ts"],"sourcesContent":["import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  LitElement,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { getNextElementIndex, isArrowKeyPressed } from '../../core/a11y.ts';\nimport { SbbLanguageController, SbbPropertyWatcherController } from '../../core/controllers.ts';\nimport { forceType } from '../../core/decorators.ts';\nimport { isLean } from '../../core/dom/lean-context.ts';\nimport { i18nChipGroupInputDescription, i18nSelectionRequired } from '../../core/i18n.ts';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbDisabledMixin,\n  SbbElementInternalsMixin,\n  SbbFormAssociatedMixin,\n  SbbNegativeMixin,\n  SbbRequiredMixin,\n} from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport type { SbbFormFieldElement } from '../../form-field/form-field/form-field.component.ts';\nimport type { SbbOptionBaseElement } from '../../option/option/option-base-element.ts';\nimport { SbbChipElement } from '../chip.ts';\n\nimport style from './chip-group.scss?lit&inline';\n\nlet displayWithWarningLogged = false;\n\nexport interface SbbChipInputTokenEndEventDetails<T = string> {\n  /** The element that triggered the chip creation */\n  origin: 'input' | 'autocomplete';\n  /**\n   * The value of the new chip. Either the input or the option value depending on the origin.\n   * Either the value from the input which is always `string` or the value from the selected option\n   * from an autocomplete, which can be either a string or any other type.\n   */\n  value: T | string;\n  label?: string;\n  /** Set a new value for the chip that will be created */\n  setValue(value: T): void;\n  /** Set a label for the chip that will be created */\n  setLabel(value: string): void;\n}\n\n/**\n * The `sbb-chip-group` component is used as a container for one or multiple `sbb-chip`.\n *\n * @slot - Use the unnamed slot to add `sbb-chip` elements.\n * @overrideType value - (T = string[]) | null\n */\nexport\n@customElement('sbb-chip-group')\nclass SbbChipGroupElement<T = string> extends SbbRequiredMixin(\n  SbbDisabledMixin(SbbNegativeMixin(SbbFormAssociatedMixin(SbbElementInternalsMixin(LitElement)))),\n) {\n  public static override readonly role = 'listbox';\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  public static readonly events = {\n    input: 'input',\n    change: 'change',\n    chipinputtokenend: 'chipinputtokenend',\n  } as const;\n\n  /** Value of the form element. */\n  @property({ type: Array })\n  public set value(value: (T | null)[] | null) {\n    value = value ?? [];\n    const oldValue = this.value;\n\n    // Subtract from 'oldValue' the new 'value'\n    // The result are the chips to remove (handle duplicates)\n    const toRemove = [...oldValue];\n    for (const c of value) {\n      if (toRemove.includes(c)) {\n        toRemove.splice(toRemove.indexOf(c), 1);\n      }\n    }\n    toRemove.forEach((value) =>\n      this._chipElements()\n        .find((c) => c.value === value)\n        ?.remove(),\n    );\n\n    // Subtract from the new 'value' what was already present\n    // The result are the new chips to add (handle duplicates)\n    const toAdd = [...value];\n    for (const c of oldValue) {\n      if (toAdd.includes(c)) {\n        toAdd.splice(toAdd.indexOf(c), 1);\n      }\n    }\n    toAdd.forEach((c) => this._createChipElement(c));\n  }\n  public get value(): (T | null)[] {\n    return this._chipElements().map((c) => c.value);\n  }\n\n  /** Function that maps a chip's value to its display value. */\n  @property({ attribute: false })\n  public accessor displayWith: ((value: T) => string) | null = null;\n\n  /** The array of keys that will trigger a `chipinputtokenend` event. Default `['Enter']` */\n  @property({ attribute: 'separator-keys', type: Array })\n  public accessor separatorKeys: string[] = ['Enter'];\n\n  /** Whether to automatically add a chip when the input loses focus if there's a value. */\n  @forceType()\n  @property({ attribute: 'add-on-blur', type: Boolean })\n  public accessor addOnBlur: boolean = false;\n\n  /**\n   * Listens to the changes on `readonly` and `disabled` attributes of `<input>`.\n   */\n  private _inputAttributeObserver = !isServer\n    ? new MutationObserver(() => this._reactToInputChanges())\n    : null;\n\n  private _inputElement: HTMLInputElement | undefined;\n  private _inputAbortController: AbortController | undefined;\n  private _language = new SbbLanguageController(this);\n  private _previousSize?: SbbFormFieldElement['size'];\n\n  public constructor() {\n    super();\n\n    this.addEventListener?.(SbbChipElement.events.requestdelete, (ev) =>\n      this._deleteChip(ev.target as SbbChipElement<T>),\n    );\n\n    this.addEventListener?.('keydown', (ev) => this._onChipKeyDown(ev));\n\n    this.addController(\n      new SbbPropertyWatcherController(this, () => this.closest('sbb-form-field'), {\n        size: (formField) => this._updateSize(formField.size),\n        label: (formField) => this._updateLabelState(formField),\n        hiddenLabel: (formField) => this._updateLabelState(formField),\n      }),\n    );\n  }\n\n  private _updateLabelState(formField: SbbFormFieldElement): void {\n    this.toggleState('without-label', !formField.label || formField.hiddenLabel);\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this._setupComponent();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues): void {\n    super.willUpdate(changedProperties);\n\n    if (\n      changedProperties.has('disabled') ||\n      changedProperties.has('formDisabled') ||\n      changedProperties.has('negative')\n    ) {\n      this._proxyStateToChips();\n    }\n  }\n\n  /** @internal */\n  public formResetCallback(): void {\n    this.value = null;\n  }\n\n  /** @internal */\n  public formStateRestoreCallback(\n    state: FormRestoreState | null,\n    _reason: FormRestoreReason,\n  ): void {\n    if (!state) {\n      this.value = null;\n      return;\n    }\n\n    this._readFormData(state as FormData).then((array) => (this.value = array));\n  }\n\n  private async _readFormData(formData: FormData): Promise<T[]> {\n    return Promise.all(\n      formData\n        .getAll(this.name)\n        .map(async (entry) =>\n          entry instanceof Blob ? JSON.parse(await entry.text()) : (entry as T),\n        ),\n    );\n  }\n\n  protected override shouldValidate(name: PropertyKey | undefined): boolean {\n    return super.shouldValidate(name) || name === 'required' || name === 'value';\n  }\n\n  protected override validate(): void {\n    super.validate();\n    if (this.required && this.value.length === 0) {\n      this.setValidityFlag('valueMissing', i18nSelectionRequired[this._language.current]);\n    } else {\n      this.removeValidityFlag('valueMissing');\n    }\n  }\n\n  /** Return the list of chip elements **/\n  private _chipElements(): SbbChipElement<T>[] {\n    return Array.from(this.querySelectorAll?.<SbbChipElement<T>>('sbb-chip') ?? []);\n  }\n\n  /** Return the list of enabled chip elements **/\n  private _enabledChipElements(): SbbChipElement<T>[] {\n    return Array.from(this.querySelectorAll?.('sbb-chip:not([disabled])') ?? []);\n  }\n\n  private _setupComponent(): void {\n    const input = this.querySelector('input');\n\n    // Connect to the input\n    if (input && input !== this._inputElement) {\n      this._inputAbortController?.abort();\n      this._inputAttributeObserver?.disconnect();\n      this._inputElement = input;\n\n      this._inputAbortController = new AbortController();\n      this._inputElement.addEventListener('keydown', (ev) => this._onInputKeyDown(ev), {\n        signal: this._inputAbortController.signal,\n      });\n      this._inputElement.addEventListener('blur', () => this._onInputBlur(), {\n        signal: this._inputAbortController.signal,\n        capture: true,\n      });\n      this._inputElement.addEventListener(\n        'inputAutocomplete',\n        (event: CustomEvent<{ option: SbbOptionBaseElement<T> }>) => {\n          this._createChipFromInput('autocomplete', event.detail?.option.value);\n        },\n        {\n          signal: this._inputAbortController.signal,\n        },\n      );\n\n      this._inputAttributeObserver?.observe(this._inputElement, {\n        attributes: true,\n        attributeFilter: ['readonly', 'disabled'],\n      });\n    }\n\n    // Inherit size from the form-field and observe for changes\n    if (!this._previousSize || !this.closest('sbb-form-field')) {\n      this._updateSize(isLean() ? 's' : 'm');\n    }\n\n    this.toggleState('empty', this.value.length === 0);\n    this._reactToInputChanges();\n    this._updateInputDescription();\n    this.updateFormValue();\n  }\n\n  /**\n   * Listen for keyboard events on the chip elements\n   **/\n  private _onChipKeyDown(event: KeyboardEvent): void {\n    const eventTarget = event.target as SbbChipElement<T>;\n    if (eventTarget.localName !== 'sbb-chip') {\n      return;\n    }\n\n    // Arrow keys allow navigation between chips focus steps\n    if (isArrowKeyPressed(event)) {\n      const focusSteps = this._enabledChipElements();\n      const next = getNextElementIndex(event, focusSteps.indexOf(eventTarget), focusSteps.length);\n      focusSteps[next].focus();\n      return;\n    }\n\n    switch (event.key) {\n      case 'Backspace':\n      case 'Delete':\n        if (!eventTarget.readOnly && !eventTarget.disabled) {\n          event.preventDefault();\n          this._deleteChip(eventTarget);\n        }\n        break;\n    }\n  }\n\n  /**\n   * Listen for keyboard events on the input\n   **/\n  private _onInputKeyDown(event: KeyboardEvent): void {\n    switch (event.key) {\n      case 'Backspace':\n      case 'ArrowLeft':\n        if (!this._inputElement!.value) {\n          this._focusChip();\n        }\n        break;\n      case 'Enter':\n        event.preventDefault(); // Prevents the form submit\n        break;\n    }\n\n    // if the user typed one of the separator keys, trigger a 'chipinputtokenend' event\n    if (this.separatorKeys.includes(event.key)) {\n      event.preventDefault(); // prevent typing the separator key into the input\n      this._createChipFromInput('input');\n    }\n  }\n\n  /**\n   * Handle blur event on the input\n   **/\n  private _onInputBlur(): void {\n    if (this.addOnBlur) {\n      this._createChipFromInput('input');\n    }\n  }\n\n  /**\n   * If the input is not empty, create a chip with its value\n   */\n  private _createChipFromInput(origin: 'input' | 'autocomplete' = 'input', value?: T): void {\n    const inputValue = value ?? this._inputElement!.value.trim();\n    if (!inputValue) {\n      return;\n    }\n\n    const eventDetail: SbbChipInputTokenEndEventDetails<T> = {\n      origin: origin,\n      value: inputValue,\n      label: (value ? this.displayWith?.(value) : null) ?? undefined,\n      setValue: (value: T) => (eventDetail.value = value),\n      setLabel: (label: string) => (eventDetail.label = label),\n    };\n\n    if (!this._dispatchChipInputTokenEnd(eventDetail)) {\n      return; // event prevented; do nothing (the consumer has to create the chip)\n    }\n\n    this._createChipElement(eventDetail.value as T, eventDetail.label);\n    this._inputElement!.value = ''; // Empty the input\n    this._emitInputEvents();\n  }\n\n  private _dispatchChipInputTokenEnd(eventDetail: SbbChipInputTokenEndEventDetails<T>): boolean {\n    /**\n     * @type {CustomEvent<SbbChipInputTokenEndEventDetails>}\n     * Notifies that a chip is about to be created. Can be prevented.\n     */\n    return this.dispatchEvent(\n      new CustomEvent<SbbChipInputTokenEndEventDetails<T>>('chipinputtokenend', {\n        detail: eventDetail,\n        cancelable: true,\n        bubbles: true,\n        composed: true,\n      }),\n    );\n  }\n\n  private _deleteChip(chip: SbbChipElement<T>): void {\n    const chips = this._enabledChipElements();\n    chip.remove();\n    this._emitInputEvents();\n    this._focusChip(chips.indexOf(chip)); // Focus the next chip\n  }\n\n  /**\n   * Focus an enabled chip. If none are present, focus the input\n   * @param index The index of the enabled chip. If null, focus the last one.\n   */\n  private _focusChip(index?: number): void {\n    const enabledChips = this._enabledChipElements();\n\n    if (index !== undefined && enabledChips[index]) {\n      enabledChips[index].focus();\n      return;\n    }\n\n    if (enabledChips.length > 0) {\n      enabledChips[enabledChips.length - 1].focus();\n      return;\n    }\n\n    this._inputElement?.focus();\n  }\n\n  private _emitInputEvents(): void {\n    /** The input event fires when the value has been changed as a direct result of a user action. */\n    this.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n\n    /**\n     * The change event is fired when the user modifies the element's value.\n     * Unlike the input event, the change event is not necessarily fired\n     * for each alteration to an element's value.\n     */\n    this.dispatchEvent(new Event('change', { bubbles: true }));\n  }\n\n  private _createChipElement(value: T | null, label?: string): void {\n    if (isServer) {\n      return;\n    }\n    const newChip = document.createElement('sbb-chip') as SbbChipElement<T>;\n    newChip.value = value;\n    newChip.innerText = label ?? (value ? this.displayWith?.(value) : null) ?? '';\n    if (\n      import.meta.env.DEV &&\n      !displayWithWarningLogged &&\n      !label &&\n      typeof value === 'object' &&\n      !this.displayWith\n    ) {\n      console.warn(\n        `displayWith has not been set yet for sbb-chip-group and value is an object.\n         If you are using object values, you need to provide displayWidth before\n         setting or selecting any value.`,\n      );\n      displayWithWarningLogged = true;\n    }\n    this.insertBefore(newChip, this._inputElement ?? this.querySelector('input'));\n  }\n\n  private _reactToInputChanges(): void {\n    this.disabled = this._inputElement?.disabled ?? false;\n    this._proxyStateToChips();\n  }\n\n  private _proxyStateToChips(): void {\n    this._chipElements().forEach((c) => {\n      c.disabled = this.disabled || this.formDisabled;\n      c.readOnly = this._inputElement?.hasAttribute('readonly') ?? false;\n      c.negative = this.negative;\n    });\n  }\n\n  private _updateSize(size: SbbFormFieldElement['size']): void {\n    if (this._previousSize) {\n      this.internals.states.delete(`size-${this._previousSize}`);\n    }\n    this._previousSize = size;\n    if (this._previousSize) {\n      this.internals.states.add(`size-${this._previousSize}`);\n    }\n  }\n\n  private _updateInputDescription(): void {\n    if (!this._inputElement) {\n      return;\n    }\n    this._inputElement.setAttribute(\n      'aria-description',\n      `${i18nChipGroupInputDescription[this._language.current]} ${this.value.length}`,\n    );\n  }\n\n  protected override render(): TemplateResult {\n    return html`<slot @slotchange=${this._setupComponent}></slot>`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-chip-group': SbbChipGroupElement;\n  }\n}\n\ndeclare global {\n  interface HTMLElementEventMap {\n    chipinputtokenend: CustomEvent<SbbChipInputTokenEndEventDetails<any>>;\n  }\n}\n"],"names":["value"],"mappings":"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"}
package/package.json CHANGED
@@ -1,13 +1,13 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements-dev",
3
- "version": "4.6.0-dev.1772088473",
3
+ "version": "4.6.0-dev.1772094630",
4
4
  "description": "Lyne Design System",
5
5
  "keywords": [
6
6
  "design system",
7
7
  "web components",
8
8
  "lit",
9
9
  "storybook",
10
- "https://github.com/sbb-design-systems/lyne-components/commit/0c239fd7a48c0db7e5f0aac852407126e1fb354e"
10
+ "https://github.com/sbb-design-systems/lyne-components/commit/de3c1c53c8e07f51393fcb6a281ba628e0362c19"
11
11
  ],
12
12
  "type": "module",
13
13
  "exports": {