@sbb-esta/lyne-elements-dev 4.7.0-dev.1773406096 → 4.7.0-dev.1773409936

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,14 +1,14 @@
1
- var x = (i) => {
2
- throw TypeError(i);
1
+ var x = (a) => {
2
+ throw TypeError(a);
3
3
  };
4
- var I = (i, a, l) => a.has(i) || x("Cannot " + l);
5
- var d = (i, a, l) => (I(i, a, "read from private field"), l ? l.call(i) : a.get(i)), g = (i, a, l) => a.has(i) ? x("Cannot add the same private member more than once") : a instanceof WeakSet ? a.add(i) : a.set(i, l), h = (i, a, l, c) => (I(i, a, "write to private field"), c ? c.call(i, l) : a.set(i, l), l);
4
+ var I = (a, i, l) => i.has(a) || x("Cannot " + l);
5
+ var d = (a, i, l) => (I(a, i, "read from private field"), l ? l.call(a) : i.get(a)), g = (a, i, l) => i.has(a) ? x("Cannot add the same private member more than once") : i instanceof WeakSet ? i.add(a) : i.set(a, l), h = (a, i, l, c) => (I(a, i, "write to private field"), c ? c.call(a, l) : i.set(a, l), l);
6
6
  import { __esDecorate as _, __runInitializers as p } from "tslib";
7
7
  import { css as B, isServer as O, html as D } from "lit";
8
8
  import { property as y } from "lit/decorators.js";
9
9
  import { isArrowKeyPressed as K, getNextElementIndex as L } from "../../core/a11y.js";
10
10
  import { SbbElement as W } from "../../core/base-elements.js";
11
- import { SbbLanguageController as T, SbbPropertyWatcherController as F } from "../../core/controllers.js";
11
+ import { SbbLanguageController as F, SbbPropertyWatcherController as T } from "../../core/controllers.js";
12
12
  import { forceType as q } from "../../core/decorators.js";
13
13
  import { isLean as V } from "../../core/dom/lean-context.js";
14
14
  import { i18nSelectionRequired as M, i18nChipGroupInputDescription as N } from "../../core/i18n.js";
@@ -16,16 +16,39 @@ import { SbbRequiredMixin as R, SbbDisabledMixin as $, SbbNegativeMixin as j, Sb
16
16
  import { boxSizingStyles as J } from "../../core/styles.js";
17
17
  import { SbbChipElement as P } from "../chip/chip.component.js";
18
18
  const H = B`: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%}`;
19
- let ht = (() => {
20
- var u, m, b, r;
21
- let i = R($(j(U(W)))), a = [], l, c, f = [], v = [], z, w = [], k = [], E, C = [], S = [];
22
- return r = class extends i {
19
+ class Q extends CustomEvent {
20
+ /**
21
+ * @deprecated Use event properties directly.
22
+ */
23
+ get detail() {
24
+ return this;
25
+ }
26
+ constructor(i) {
27
+ super("chipinputtokenend", {
28
+ cancelable: !0,
29
+ bubbles: !0,
30
+ composed: !0
31
+ }), this.origin = i.origin, this.value = i.value, this.label = i.label;
32
+ }
33
+ /** Set a new value for the chip that will be created */
34
+ setValue(i) {
35
+ this.value = i;
36
+ }
37
+ /** Set a label for the chip that will be created */
38
+ setLabel(i) {
39
+ this.label = i;
40
+ }
41
+ }
42
+ let pt = (() => {
43
+ var u, b, m, r;
44
+ let a = R($(j(U(W)))), i = [], l, c, f = [], v = [], z, w = [], k = [], E, C = [], S = [];
45
+ return r = class extends a {
23
46
  constructor() {
24
47
  super();
25
48
  g(this, u);
26
- g(this, m);
27
49
  g(this, b);
28
- h(this, u, (p(this, a), p(this, f, null))), h(this, m, (p(this, v), p(this, w, ["Enter"]))), h(this, b, (p(this, k), p(this, C, !1))), this._inputAttributeObserver = (p(this, S), O ? null : new MutationObserver(() => this._reactToInputChanges())), this._language = new T(this), this.addEventListener?.(P.events.requestdelete, (t) => this._deleteChip(t.target)), this.addEventListener?.("keydown", (t) => this._onChipKeyDown(t)), this.addController(new F(this, () => this.closest("sbb-form-field"), {
50
+ g(this, m);
51
+ h(this, u, (p(this, i), p(this, f, null))), h(this, b, (p(this, v), p(this, w, ["Enter"]))), h(this, m, (p(this, k), p(this, C, !1))), this._inputAttributeObserver = (p(this, S), O ? 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 T(this, () => this.closest("sbb-form-field"), {
29
52
  size: (t) => this._updateSize(t.size),
30
53
  label: (t) => this._updateLabelState(t),
31
54
  hiddenLabel: (t) => this._updateLabelState(t)
@@ -35,13 +58,13 @@ let ht = (() => {
35
58
  set value(t) {
36
59
  t = t ?? [];
37
60
  const e = this.value, s = [...e];
38
- for (const n of t)
39
- s.includes(n) && s.splice(s.indexOf(n), 1);
40
- s.forEach((n) => this._chipElements().find((A) => A.value === n)?.remove());
41
- const o = [...t];
42
- for (const n of e)
43
- o.includes(n) && o.splice(o.indexOf(n), 1);
44
- o.forEach((n) => this._createChipElement(n));
61
+ for (const o of t)
62
+ s.includes(o) && s.splice(s.indexOf(o), 1);
63
+ s.forEach((o) => this._chipElements().find((A) => A.value === o)?.remove());
64
+ const n = [...t];
65
+ for (const o of e)
66
+ n.includes(o) && n.splice(n.indexOf(o), 1);
67
+ n.forEach((o) => this._createChipElement(o));
45
68
  }
46
69
  get value() {
47
70
  return this._chipElements().map((t) => t.value);
@@ -55,17 +78,17 @@ let ht = (() => {
55
78
  }
56
79
  /** The array of keys that will trigger a `chipinputtokenend` event. Default `['Enter']` */
57
80
  get separatorKeys() {
58
- return d(this, m);
81
+ return d(this, b);
59
82
  }
60
83
  set separatorKeys(t) {
61
- h(this, m, t);
84
+ h(this, b, t);
62
85
  }
63
86
  /** Whether to automatically add a chip when the input loses focus if there's a value. */
64
87
  get addOnBlur() {
65
- return d(this, b);
88
+ return d(this, m);
66
89
  }
67
90
  set addOnBlur(t) {
68
- h(this, b, t);
91
+ h(this, m, t);
69
92
  }
70
93
  _updateLabelState(t) {
71
94
  this.toggleState("without-label", !t.label || t.hiddenLabel);
@@ -128,8 +151,8 @@ let ht = (() => {
128
151
  const e = t.target;
129
152
  if (e.localName === "sbb-chip") {
130
153
  if (K(t)) {
131
- const s = this._enabledChipElements(), o = L(t, s.indexOf(e), s.length);
132
- s[o].focus();
154
+ const s = this._enabledChipElements(), n = L(t, s.indexOf(e), s.length);
155
+ s[n].focus();
133
156
  return;
134
157
  }
135
158
  switch (t.key) {
@@ -168,22 +191,12 @@ let ht = (() => {
168
191
  const s = e ?? this._inputElement.value.trim();
169
192
  if (!s)
170
193
  return;
171
- const o = {
194
+ const n = new Q({
172
195
  origin: t,
173
196
  value: s,
174
- label: (e ? this.displayWith?.(e) : null) ?? void 0,
175
- setValue: (n) => o.value = n,
176
- setLabel: (n) => o.label = n
177
- };
178
- this._dispatchChipInputTokenEnd(o) && (this._createChipElement(o.value, o.label), this._inputElement.value = "", this._emitInputEvents());
179
- }
180
- _dispatchChipInputTokenEnd(t) {
181
- return this.dispatchEvent(new CustomEvent("chipinputtokenend", {
182
- detail: t,
183
- cancelable: !0,
184
- bubbles: !0,
185
- composed: !0
186
- }));
197
+ label: (e ? this.displayWith?.(e) : null) ?? void 0
198
+ });
199
+ this.dispatchEvent(n) && (this._createChipElement(n.value, n.label), this._inputElement.value = "", this._emitInputEvents());
187
200
  }
188
201
  _deleteChip(t) {
189
202
  const e = this._enabledChipElements();
@@ -231,11 +244,11 @@ let ht = (() => {
231
244
  render() {
232
245
  return D`<slot @slotchange=${this._setupComponent}></slot>`;
233
246
  }
234
- }, u = new WeakMap(), m = new WeakMap(), b = new WeakMap(), (() => {
235
- const t = typeof Symbol == "function" && Symbol.metadata ? Object.create(i[Symbol.metadata] ?? null) : void 0;
247
+ }, u = new WeakMap(), b = new WeakMap(), m = new WeakMap(), (() => {
248
+ const t = typeof Symbol == "function" && Symbol.metadata ? Object.create(a[Symbol.metadata] ?? null) : void 0;
236
249
  l = [y({ type: Array })], c = [y({ attribute: !1 })], z = [y({ attribute: "separator-keys", type: Array })], E = [q(), y({ attribute: "add-on-blur", type: Boolean })], _(r, null, l, { kind: "setter", name: "value", static: !1, private: !1, access: { has: (e) => "value" in e, set: (e, s) => {
237
250
  e.value = s;
238
- } }, metadata: t }, null, a), _(r, null, c, { kind: "accessor", name: "displayWith", static: !1, private: !1, access: { has: (e) => "displayWith" in e, get: (e) => e.displayWith, set: (e, s) => {
251
+ } }, metadata: t }, null, i), _(r, null, c, { kind: "accessor", name: "displayWith", static: !1, private: !1, access: { has: (e) => "displayWith" in e, get: (e) => e.displayWith, set: (e, s) => {
239
252
  e.displayWith = s;
240
253
  } }, metadata: t }, f, v), _(r, null, z, { kind: "accessor", name: "separatorKeys", static: !1, private: !1, access: { has: (e) => "separatorKeys" in e, get: (e) => e.separatorKeys, set: (e, s) => {
241
254
  e.separatorKeys = s;
@@ -249,5 +262,6 @@ let ht = (() => {
249
262
  }, r;
250
263
  })();
251
264
  export {
252
- ht as SbbChipGroupElement
265
+ pt as SbbChipGroupElement,
266
+ Q as SbbChipInputTokenEndEvent
253
267
  };
@@ -1,7 +1,9 @@
1
1
  import { SbbChipGroupElement as e } from "./chip-group/chip-group.component.js";
2
+ import { SbbChipInputTokenEndEvent as p } from "./chip-group/chip-group.component.js";
2
3
  e.define();
3
4
  console.warn(`The entrypoint '@sbb-esta/elements/chip/chip-group.js' has been deprecated.
4
5
  Use either '@sbb-esta/elements/chip.js' or '@sbb-esta/elements/chip.pure.js' instead.`);
5
6
  export {
6
- e as SbbChipGroupElement
7
+ e as SbbChipGroupElement,
8
+ p as SbbChipInputTokenEndEvent
7
9
  };
package/chip.js CHANGED
@@ -1,8 +1,10 @@
1
1
  import { SbbChipGroupElement as e } from "./chip/chip-group/chip-group.component.js";
2
- import { SbbChipElement as i } from "./chip/chip/chip.component.js";
3
- i.define();
2
+ import { SbbChipInputTokenEndEvent as i } from "./chip/chip-group/chip-group.component.js";
3
+ import { SbbChipElement as o } from "./chip/chip/chip.component.js";
4
+ o.define();
4
5
  e.define();
5
6
  export {
6
- i as SbbChipElement,
7
- e as SbbChipGroupElement
7
+ o as SbbChipElement,
8
+ e as SbbChipGroupElement,
9
+ i as SbbChipInputTokenEndEvent
8
10
  };
package/chip.pure.js CHANGED
@@ -1,6 +1,7 @@
1
- import { SbbChipGroupElement as p } from "./chip/chip-group/chip-group.component.js";
2
- import { SbbChipElement as b } from "./chip/chip/chip.component.js";
1
+ import { SbbChipGroupElement as b, SbbChipInputTokenEndEvent as n } from "./chip/chip-group/chip-group.component.js";
2
+ import { SbbChipElement as t } from "./chip/chip/chip.component.js";
3
3
  export {
4
- b as SbbChipElement,
5
- p as SbbChipGroupElement
4
+ t as SbbChipElement,
5
+ b as SbbChipGroupElement,
6
+ n as SbbChipInputTokenEndEvent
6
7
  };
@@ -55171,6 +55171,92 @@
55171
55171
  "kind": "javascript-module",
55172
55172
  "path": "chip/chip-group/chip-group.component.js",
55173
55173
  "declarations": [
55174
+ {
55175
+ "kind": "class",
55176
+ "description": "",
55177
+ "name": "SbbChipInputTokenEndEvent",
55178
+ "members": [
55179
+ {
55180
+ "kind": "field",
55181
+ "name": "origin",
55182
+ "type": {
55183
+ "text": "'input' | 'autocomplete'"
55184
+ },
55185
+ "privacy": "public",
55186
+ "description": "The element that triggered the chip creation"
55187
+ },
55188
+ {
55189
+ "kind": "field",
55190
+ "name": "value",
55191
+ "type": {
55192
+ "text": "T | string"
55193
+ },
55194
+ "privacy": "public",
55195
+ "description": "The value of the new chip. Either the input or the option value depending on the origin.\nEither the value from the input which is always `string` or the value from the selected option\nfrom an autocomplete, which can be either a string or any other type."
55196
+ },
55197
+ {
55198
+ "kind": "field",
55199
+ "name": "label",
55200
+ "type": {
55201
+ "text": "string | undefined"
55202
+ },
55203
+ "privacy": "public"
55204
+ },
55205
+ {
55206
+ "kind": "field",
55207
+ "name": "detail",
55208
+ "type": {
55209
+ "text": "SbbChipInputTokenEndEventDetails<T>"
55210
+ },
55211
+ "privacy": "public",
55212
+ "deprecated": "Use event properties directly.",
55213
+ "readonly": true
55214
+ },
55215
+ {
55216
+ "kind": "method",
55217
+ "name": "setValue",
55218
+ "privacy": "public",
55219
+ "return": {
55220
+ "type": {
55221
+ "text": "void"
55222
+ }
55223
+ },
55224
+ "parameters": [
55225
+ {
55226
+ "name": "value",
55227
+ "type": {
55228
+ "text": "T"
55229
+ }
55230
+ }
55231
+ ],
55232
+ "description": "Set a new value for the chip that will be created"
55233
+ },
55234
+ {
55235
+ "kind": "method",
55236
+ "name": "setLabel",
55237
+ "privacy": "public",
55238
+ "return": {
55239
+ "type": {
55240
+ "text": "void"
55241
+ }
55242
+ },
55243
+ "parameters": [
55244
+ {
55245
+ "name": "label",
55246
+ "type": {
55247
+ "text": "string"
55248
+ }
55249
+ }
55250
+ ],
55251
+ "description": "Set a label for the chip that will be created"
55252
+ }
55253
+ ],
55254
+ "superclass": {
55255
+ "name": "CustomEvent",
55256
+ "module": "chip/chip-group/chip-group.component.js"
55257
+ },
55258
+ "classGenerics": "T = string"
55259
+ },
55174
55260
  {
55175
55261
  "kind": "class",
55176
55262
  "description": "The `sbb-chip-group` component is used as a container for one or multiple `sbb-chip`.",
@@ -55483,24 +55569,6 @@
55483
55569
  ],
55484
55570
  "description": "If the input is not empty, create a chip with its value"
55485
55571
  },
55486
- {
55487
- "kind": "method",
55488
- "name": "_dispatchChipInputTokenEnd",
55489
- "privacy": "private",
55490
- "return": {
55491
- "type": {
55492
- "text": "boolean"
55493
- }
55494
- },
55495
- "parameters": [
55496
- {
55497
- "name": "eventDetail",
55498
- "type": {
55499
- "text": "SbbChipInputTokenEndEventDetails<T>"
55500
- }
55501
- }
55502
- ]
55503
- },
55504
55572
  {
55505
55573
  "kind": "method",
55506
55574
  "name": "_deleteChip",
@@ -56111,13 +56179,6 @@
56111
56179
  }
56112
56180
  ],
56113
56181
  "events": [
56114
- {
56115
- "name": "chipinputtokenend",
56116
- "type": {
56117
- "text": "CustomEvent<SbbChipInputTokenEndEventDetails>"
56118
- },
56119
- "description": "Notifies that a chip is about to be created. Can be prevented."
56120
- },
56121
56182
  {
56122
56183
  "name": "input",
56123
56184
  "type": {
@@ -56131,6 +56192,13 @@
56131
56192
  "text": "Event"
56132
56193
  },
56133
56194
  "description": "The change event is fired when the user modifies the element's value.\nUnlike the input event, the change event is not necessarily fired\nfor each alteration to an element's value."
56195
+ },
56196
+ {
56197
+ "type": {
56198
+ "text": "SbbChipInputTokenEndEvent<T>"
56199
+ },
56200
+ "description": "Notifies that a chip is about to be created. Can be prevented.",
56201
+ "name": "chipinputtokenend"
56134
56202
  }
56135
56203
  ],
56136
56204
  "attributes": [
@@ -56239,6 +56307,14 @@
56239
56307
  }
56240
56308
  ],
56241
56309
  "exports": [
56310
+ {
56311
+ "kind": "js",
56312
+ "name": "SbbChipInputTokenEndEvent",
56313
+ "declaration": {
56314
+ "name": "SbbChipInputTokenEndEvent",
56315
+ "module": "chip/chip-group/chip-group.component.js"
56316
+ }
56317
+ },
56242
56318
  {
56243
56319
  "kind": "js",
56244
56320
  "name": "SbbChipGroupElement",
@@ -1,6 +1,29 @@
1
1
  import { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';
2
2
  import { SbbElement } from '../../core/base-elements.ts';
3
3
  import { FormRestoreReason, FormRestoreState } from '../../core/mixins.ts';
4
+ export declare class SbbChipInputTokenEndEvent<T = string> extends CustomEvent<SbbChipInputTokenEndEventDetails<T>> {
5
+ /** The element that triggered the chip creation */
6
+ origin: 'input' | 'autocomplete';
7
+ /**
8
+ * The value of the new chip. Either the input or the option value depending on the origin.
9
+ * Either the value from the input which is always `string` or the value from the selected option
10
+ * from an autocomplete, which can be either a string or any other type.
11
+ */
12
+ value: T | string;
13
+ label?: string;
14
+ /**
15
+ * @deprecated Use event properties directly.
16
+ */
17
+ get detail(): SbbChipInputTokenEndEventDetails<T>;
18
+ constructor(options: Pick<SbbChipInputTokenEndEvent, 'origin' | 'value' | 'label'>);
19
+ /** Set a new value for the chip that will be created */
20
+ setValue(value: T): void;
21
+ /** Set a label for the chip that will be created */
22
+ setLabel(label: string): void;
23
+ }
24
+ /**
25
+ * @deprecated Use `SbbChipInputTokenEndEvent` instead.
26
+ */
4
27
  export interface SbbChipInputTokenEndEventDetails<T = string> {
5
28
  /** The element that triggered the chip creation */
6
29
  origin: 'input' | 'autocomplete';
@@ -21,6 +44,7 @@ declare const SbbChipGroupElement_base: import('../../core/mixins.ts').AbstractC
21
44
  * The `sbb-chip-group` component is used as a container for one or multiple `sbb-chip`.
22
45
  *
23
46
  * @slot - Use the unnamed slot to add `sbb-chip` elements.
47
+ * @event {SbbChipInputTokenEndEvent<T>} chipinputtokenend - Notifies that a chip is about to be created. Can be prevented.
24
48
  * @overrideType value - (T = string[]) | null
25
49
  */
26
50
  export declare class SbbChipGroupElement<T = string> extends SbbChipGroupElement_base {
@@ -81,7 +105,6 @@ export declare class SbbChipGroupElement<T = string> extends SbbChipGroupElement
81
105
  * If the input is not empty, create a chip with its value
82
106
  */
83
107
  private _createChipFromInput;
84
- private _dispatchChipInputTokenEnd;
85
108
  private _deleteChip;
86
109
  /**
87
110
  * Focus an enabled chip. If none are present, focus the input
@@ -100,10 +123,8 @@ declare global {
100
123
  interface HTMLElementTagNameMap {
101
124
  'sbb-chip-group': SbbChipGroupElement;
102
125
  }
103
- }
104
- declare global {
105
126
  interface HTMLElementEventMap {
106
- chipinputtokenend: CustomEvent<SbbChipInputTokenEndEventDetails<any>>;
127
+ chipinputtokenend: SbbChipInputTokenEndEvent<any>;
107
128
  }
108
129
  }
109
130
  export {};
@@ -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,EAAE,KAAK,cAAc,EAAkB,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAIpG,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AAKzD,OAAO,EACL,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,EAKtB,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,qBAAa,mBAAmB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,wBAEpD;IACC,gBAAgC,WAAW,EAAE,MAAM,CAAoB;IACvE,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,yFAAyF;IACzF,SAEgB,SAAS,EAAE,OAAO,CAAS;IAE3C;;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;IA4CvB;;QAEI;IACJ,OAAO,CAAC,cAAc;IAyBtB;;QAEI;IACJ,OAAO,CAAC,eAAe;IAoBvB;;QAEI;IACJ,OAAO,CAAC,YAAY;IAMpB;;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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"}
@@ -115,6 +115,32 @@ const style = css`:host {
115
115
  ::slotted(sbb-chip) {
116
116
  max-width: 100%;
117
117
  }`;
118
+ class SbbChipInputTokenEndEvent extends CustomEvent {
119
+ /**
120
+ * @deprecated Use event properties directly.
121
+ */
122
+ get detail() {
123
+ return this;
124
+ }
125
+ constructor(options) {
126
+ super("chipinputtokenend", {
127
+ cancelable: true,
128
+ bubbles: true,
129
+ composed: true
130
+ });
131
+ this.origin = options.origin;
132
+ this.value = options.value;
133
+ this.label = options.label;
134
+ }
135
+ /** Set a new value for the chip that will be created */
136
+ setValue(value) {
137
+ this.value = value;
138
+ }
139
+ /** Set a label for the chip that will be created */
140
+ setLabel(label) {
141
+ this.label = label;
142
+ }
143
+ }
118
144
  let SbbChipGroupElement = (() => {
119
145
  var _displayWith_accessor_storage, _separatorKeys_accessor_storage, _addOnBlur_accessor_storage, _a;
120
146
  let _classSuper = SbbRequiredMixin(SbbDisabledMixin(SbbNegativeMixin(SbbFormAssociatedMixin(SbbElement))));
@@ -330,28 +356,18 @@ let SbbChipGroupElement = (() => {
330
356
  if (!inputValue) {
331
357
  return;
332
358
  }
333
- const eventDetail = {
359
+ const event = new SbbChipInputTokenEndEvent({
334
360
  origin,
335
361
  value: inputValue,
336
- label: (value ? this.displayWith?.(value) : null) ?? void 0,
337
- setValue: (value2) => eventDetail.value = value2,
338
- setLabel: (label) => eventDetail.label = label
339
- };
340
- if (!this._dispatchChipInputTokenEnd(eventDetail)) {
362
+ label: (value ? this.displayWith?.(value) : null) ?? void 0
363
+ });
364
+ if (!this.dispatchEvent(event)) {
341
365
  return;
342
366
  }
343
- this._createChipElement(eventDetail.value, eventDetail.label);
367
+ this._createChipElement(event.value, event.label);
344
368
  this._inputElement.value = "";
345
369
  this._emitInputEvents();
346
370
  }
347
- _dispatchChipInputTokenEnd(eventDetail) {
348
- return this.dispatchEvent(new CustomEvent("chipinputtokenend", {
349
- detail: eventDetail,
350
- cancelable: true,
351
- bubbles: true,
352
- composed: true
353
- }));
354
- }
355
371
  _deleteChip(chip) {
356
372
  const chips = this._enabledChipElements();
357
373
  chip.remove();
@@ -442,6 +458,7 @@ let SbbChipGroupElement = (() => {
442
458
  }, _a;
443
459
  })();
444
460
  export {
445
- SbbChipGroupElement
461
+ SbbChipGroupElement,
462
+ SbbChipInputTokenEndEvent
446
463
  };
447
- //# 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 { type CSSResultGroup, html, isServer, type PropertyValues, type TemplateResult } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { getNextElementIndex, isArrowKeyPressed } from '../../core/a11y.ts';\nimport { SbbElement } from '../../core/base-elements.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  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/chip.component.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 class SbbChipGroupElement<T = string> extends SbbRequiredMixin(\n  SbbDisabledMixin(SbbNegativeMixin(SbbFormAssociatedMixin(SbbElement))),\n) {\n  public static override readonly elementName: string = 'sbb-chip-group';\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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"}
464
+ //# 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 { type CSSResultGroup, html, isServer, type PropertyValues, type TemplateResult } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { getNextElementIndex, isArrowKeyPressed } from '../../core/a11y.ts';\nimport { SbbElement } from '../../core/base-elements.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  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/chip.component.ts';\n\nimport style from './chip-group.scss?lit&inline';\n\nlet displayWithWarningLogged = false;\n\n// TODO(breaking-change): Replace base class with Event\nexport class SbbChipInputTokenEndEvent<T = string> extends CustomEvent<\n  SbbChipInputTokenEndEventDetails<T>\n> {\n  /** The element that triggered the chip creation */\n  public 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  public value: T | string;\n  public label?: string;\n\n  /**\n   * @deprecated Use event properties directly.\n   */\n  public override get detail(): SbbChipInputTokenEndEventDetails<T> {\n    return this;\n  }\n\n  public constructor(options: Pick<SbbChipInputTokenEndEvent, 'origin' | 'value' | 'label'>) {\n    super('chipinputtokenend', {\n      cancelable: true,\n      bubbles: true,\n      composed: true,\n    });\n    this.origin = options.origin;\n    this.value = options.value;\n    this.label = options.label;\n  }\n\n  /** Set a new value for the chip that will be created */\n  public setValue(value: T): void {\n    this.value = value;\n  }\n  /** Set a label for the chip that will be created */\n  public setLabel(label: string): void {\n    this.label = label;\n  }\n}\n\n/**\n * @deprecated Use `SbbChipInputTokenEndEvent` instead.\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 * @event {SbbChipInputTokenEndEvent<T>} chipinputtokenend - Notifies that a chip is about to be created. Can be prevented.\n * @overrideType value - (T = string[]) | null\n */\nexport class SbbChipGroupElement<T = string> extends SbbRequiredMixin(\n  SbbDisabledMixin(SbbNegativeMixin(SbbFormAssociatedMixin(SbbElement))),\n) {\n  public static override readonly elementName: string = 'sbb-chip-group';\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 event = new SbbChipInputTokenEndEvent<T>({\n      origin,\n      value: inputValue as string,\n      label: (value ? this.displayWith?.(value) : null) ?? undefined,\n    });\n    if (!this.dispatchEvent(event)) {\n      return; // event prevented; do nothing (the consumer has to create the chip)\n    }\n\n    this._createChipElement(event.value as T, event.label);\n    this._inputElement!.value = ''; // Empty the input\n    this._emitInputEvents();\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  interface HTMLElementEventMap {\n    chipinputtokenend: SbbChipInputTokenEndEvent<any>;\n  }\n}\n"],"names":["value"],"mappings":"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"}
@@ -1,8 +1,10 @@
1
1
  import { SbbChipGroupElement } from "./chip-group/chip-group.component.js";
2
+ import { SbbChipInputTokenEndEvent } from "./chip-group/chip-group.component.js";
2
3
  SbbChipGroupElement.define();
3
4
  console.warn(`The entrypoint '@sbb-esta/elements/chip/chip-group.js' has been deprecated.
4
5
  Use either '@sbb-esta/elements/chip.js' or '@sbb-esta/elements/chip.pure.js' instead.`);
5
6
  export {
6
- SbbChipGroupElement
7
+ SbbChipGroupElement,
8
+ SbbChipInputTokenEndEvent
7
9
  };
8
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hpcC1ncm91cC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzL2NoaXAvY2hpcC1ncm91cC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQGVudHJ5cG9pbnQgKi9cbmltcG9ydCB7IFNiYkNoaXBHcm91cEVsZW1lbnQgfSBmcm9tICcuL2NoaXAtZ3JvdXAvY2hpcC1ncm91cC5jb21wb25lbnQudHMnO1xuXG5leHBvcnQgKiBmcm9tICcuL2NoaXAtZ3JvdXAvY2hpcC1ncm91cC5jb21wb25lbnQudHMnO1xuXG5TYmJDaGlwR3JvdXBFbGVtZW50LmRlZmluZSgpO1xuXG5jb25zb2xlLndhcm4oYFRoZSBlbnRyeXBvaW50ICdAc2JiLWVzdGEvZWxlbWVudHMvY2hpcC9jaGlwLWdyb3VwLmpzJyBoYXMgYmVlbiBkZXByZWNhdGVkLlxuVXNlIGVpdGhlciAnQHNiYi1lc3RhL2VsZW1lbnRzL2NoaXAuanMnIG9yICdAc2JiLWVzdGEvZWxlbWVudHMvY2hpcC5wdXJlLmpzJyBpbnN0ZWFkLmApO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFLQSxvQkFBb0IsT0FBQTtBQUVwQixRQUFRLEtBQUs7QUFBQSxzRkFDeUU7In0=
10
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hpcC1ncm91cC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzL2NoaXAvY2hpcC1ncm91cC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQGVudHJ5cG9pbnQgKi9cbmltcG9ydCB7IFNiYkNoaXBHcm91cEVsZW1lbnQgfSBmcm9tICcuL2NoaXAtZ3JvdXAvY2hpcC1ncm91cC5jb21wb25lbnQudHMnO1xuXG5leHBvcnQgKiBmcm9tICcuL2NoaXAtZ3JvdXAvY2hpcC1ncm91cC5jb21wb25lbnQudHMnO1xuXG5TYmJDaGlwR3JvdXBFbGVtZW50LmRlZmluZSgpO1xuXG5jb25zb2xlLndhcm4oYFRoZSBlbnRyeXBvaW50ICdAc2JiLWVzdGEvZWxlbWVudHMvY2hpcC9jaGlwLWdyb3VwLmpzJyBoYXMgYmVlbiBkZXByZWNhdGVkLlxuVXNlIGVpdGhlciAnQHNiYi1lc3RhL2VsZW1lbnRzL2NoaXAuanMnIG9yICdAc2JiLWVzdGEvZWxlbWVudHMvY2hpcC5wdXJlLmpzJyBpbnN0ZWFkLmApO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBS0Esb0JBQW9CLE9BQUE7QUFFcEIsUUFBUSxLQUFLO0FBQUEsc0ZBQ3lFOyJ9
@@ -1,9 +1,11 @@
1
1
  import { SbbChipGroupElement } from "./chip/chip-group/chip-group.component.js";
2
+ import { SbbChipInputTokenEndEvent } from "./chip/chip-group/chip-group.component.js";
2
3
  import { SbbChipElement } from "./chip/chip/chip.component.js";
3
4
  SbbChipElement.define();
4
5
  SbbChipGroupElement.define();
5
6
  export {
6
7
  SbbChipElement,
7
- SbbChipGroupElement
8
+ SbbChipGroupElement,
9
+ SbbChipInputTokenEndEvent
8
10
  };
9
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hpcC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2VsZW1lbnRzL2NoaXAudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBlbnRyeXBvaW50ICovXG5pbXBvcnQgeyBTYmJDaGlwRWxlbWVudCwgU2JiQ2hpcEdyb3VwRWxlbWVudCB9IGZyb20gJy4vY2hpcC5wdXJlLnRzJztcblxuZXhwb3J0ICogZnJvbSAnLi9jaGlwLnB1cmUudHMnO1xuXG5TYmJDaGlwRWxlbWVudC5kZWZpbmUoKTtcblNiYkNoaXBHcm91cEVsZW1lbnQuZGVmaW5lKCk7XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFLQSxlQUFlLE9BQUE7QUFDZixvQkFBb0IsT0FBQTsifQ==
11
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hpcC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2VsZW1lbnRzL2NoaXAudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBlbnRyeXBvaW50ICovXG5pbXBvcnQgeyBTYmJDaGlwRWxlbWVudCwgU2JiQ2hpcEdyb3VwRWxlbWVudCB9IGZyb20gJy4vY2hpcC5wdXJlLnRzJztcblxuZXhwb3J0ICogZnJvbSAnLi9jaGlwLnB1cmUudHMnO1xuXG5TYmJDaGlwRWxlbWVudC5kZWZpbmUoKTtcblNiYkNoaXBHcm91cEVsZW1lbnQuZGVmaW5lKCk7XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBS0EsZUFBZSxPQUFBO0FBQ2Ysb0JBQW9CLE9BQUE7In0=
@@ -1,7 +1,8 @@
1
- import { SbbChipGroupElement } from "./chip/chip-group/chip-group.component.js";
1
+ import { SbbChipGroupElement, SbbChipInputTokenEndEvent } from "./chip/chip-group/chip-group.component.js";
2
2
  import { SbbChipElement } from "./chip/chip/chip.component.js";
3
3
  export {
4
4
  SbbChipElement,
5
- SbbChipGroupElement
5
+ SbbChipGroupElement,
6
+ SbbChipInputTokenEndEvent
6
7
  };
7
8
  //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hpcC5wdXJlLmpzIiwic291cmNlcyI6W10sInNvdXJjZXNDb250ZW50IjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7In0=
package/package.json CHANGED
@@ -1,13 +1,13 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements-dev",
3
- "version": "4.7.0-dev.1773406096",
3
+ "version": "4.7.0-dev.1773409936",
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/ae418284739cd5c4ceeff02034985efaa3edb83d"
10
+ "https://github.com/sbb-design-systems/lyne-components/commit/74df0ac8d85ee6197b18b6c89b50e232d86ccf69"
11
11
  ],
12
12
  "type": "module",
13
13
  "exports": {