@sbb-esta/lyne-elements-dev 4.6.0-dev.1772444903 → 4.6.0-dev.1772454706

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.
@@ -62934,6 +62934,25 @@
62934
62934
  "text": "T | null"
62935
62935
  }
62936
62936
  },
62937
+ "parameters": [
62938
+ {
62939
+ "name": "_date",
62940
+ "type": {
62941
+ "text": "T"
62942
+ }
62943
+ }
62944
+ ],
62945
+ "deprecated": "Use `getFollowingDate(date: T)` instead."
62946
+ },
62947
+ {
62948
+ "kind": "method",
62949
+ "name": "getFollowingDate",
62950
+ "privacy": "protected",
62951
+ "return": {
62952
+ "type": {
62953
+ "text": "T | null"
62954
+ }
62955
+ },
62937
62956
  "parameters": [
62938
62957
  {
62939
62958
  "name": "_date",
@@ -64738,7 +64757,7 @@
64738
64757
  },
64739
64758
  {
64740
64759
  "kind": "method",
64741
- "name": "findAvailableDate",
64760
+ "name": "getFollowingDate",
64742
64761
  "privacy": "protected",
64743
64762
  "return": {
64744
64763
  "type": {
@@ -64805,6 +64824,29 @@
64805
64824
  },
64806
64825
  "default": "true"
64807
64826
  },
64827
+ {
64828
+ "kind": "method",
64829
+ "name": "findAvailableDate",
64830
+ "privacy": "protected",
64831
+ "return": {
64832
+ "type": {
64833
+ "text": "T | null"
64834
+ }
64835
+ },
64836
+ "parameters": [
64837
+ {
64838
+ "name": "_date",
64839
+ "type": {
64840
+ "text": "T"
64841
+ }
64842
+ }
64843
+ ],
64844
+ "deprecated": "Use `getFollowingDate(date: T)` instead.",
64845
+ "inheritedFrom": {
64846
+ "name": "SbbDatepickerButton",
64847
+ "module": "datepicker/common/datepicker-button.js"
64848
+ }
64849
+ },
64808
64850
  {
64809
64851
  "kind": "method",
64810
64852
  "name": "_handleClick",
@@ -65673,7 +65715,7 @@
65673
65715
  },
65674
65716
  {
65675
65717
  "kind": "method",
65676
- "name": "findAvailableDate",
65718
+ "name": "getFollowingDate",
65677
65719
  "privacy": "protected",
65678
65720
  "return": {
65679
65721
  "type": {
@@ -65740,6 +65782,29 @@
65740
65782
  },
65741
65783
  "default": "true"
65742
65784
  },
65785
+ {
65786
+ "kind": "method",
65787
+ "name": "findAvailableDate",
65788
+ "privacy": "protected",
65789
+ "return": {
65790
+ "type": {
65791
+ "text": "T | null"
65792
+ }
65793
+ },
65794
+ "parameters": [
65795
+ {
65796
+ "name": "_date",
65797
+ "type": {
65798
+ "text": "T"
65799
+ }
65800
+ }
65801
+ ],
65802
+ "deprecated": "Use `getFollowingDate(date: T)` instead.",
65803
+ "inheritedFrom": {
65804
+ "name": "SbbDatepickerButton",
65805
+ "module": "datepicker/common/datepicker-button.js"
65806
+ }
65807
+ },
65743
65808
  {
65744
65809
  "kind": "method",
65745
65810
  "name": "_handleClick",
@@ -2,13 +2,13 @@ var l = (e) => {
2
2
  throw TypeError(e);
3
3
  };
4
4
  var p = (e, t, i) => t.has(e) || l("Cannot " + i);
5
- var h = (e, t, i) => (p(e, t, "read from private field"), i ? i.call(e) : t.get(e)), c = (e, t, i) => t.has(e) ? l("Cannot add the same private member more than once") : t instanceof WeakSet ? t.add(e) : t.set(e, i), o = (e, t, i, u) => (p(e, t, "write to private field"), u ? u.call(e, i) : t.set(e, i), i);
5
+ var h = (e, t, i) => (p(e, t, "read from private field"), i ? i.call(e) : t.get(e)), c = (e, t, i) => t.has(e) ? l("Cannot add the same private member more than once") : t instanceof WeakSet ? t.add(e) : t.set(e, i), d = (e, t, i, o) => (p(e, t, "write to private field"), o ? o.call(e, i) : t.set(e, i), i);
6
6
  import { __runInitializers as b, __esDecorate as m } from "tslib";
7
7
  import { html as f } from "lit";
8
8
  import { property as g } from "lit/decorators.js";
9
- import { SbbButtonBaseElement as A } from "../../core/base-elements.js";
10
- import { readConfig as D } from "../../core/config.js";
11
- import { SbbLanguageController as _ } from "../../core/controllers.js";
9
+ import { SbbButtonBaseElement as D } from "../../core/base-elements.js";
10
+ import { readConfig as _ } from "../../core/config.js";
11
+ import { SbbLanguageController as A } from "../../core/controllers.js";
12
12
  import { defaultDateAdapter as v } from "../../core/datetime.js";
13
13
  import { idReference as y } from "../../core/decorators.js";
14
14
  import { i18nToday as S } from "../../core/i18n.js";
@@ -17,12 +17,12 @@ import { SbbDateInputElement as I } from "../../date-input.js";
17
17
  import "../../icon.js";
18
18
  let C = (() => {
19
19
  var r, a;
20
- let e = E(A), t, i = [], u = [];
20
+ let e = E(D), t, i = [], o = [];
21
21
  return a = class extends e {
22
22
  constructor() {
23
23
  super(...arguments);
24
24
  c(this, r);
25
- o(this, r, b(this, i, null)), this._inputDisabled = (b(this, u), !0), this.dateAdapter = D().datetime?.dateAdapter ?? v, this.language = new _(this);
25
+ d(this, r, b(this, i, null)), this._inputDisabled = (b(this, o), !0), this.dateAdapter = _().datetime?.dateAdapter ?? v, this.language = new A(this);
26
26
  }
27
27
  /**
28
28
  * The associated date input element.
@@ -33,7 +33,7 @@ let C = (() => {
33
33
  return h(this, r);
34
34
  }
35
35
  set input(s) {
36
- o(this, r, s);
36
+ d(this, r, s);
37
37
  }
38
38
  /** Whether this button is disabled. */
39
39
  get disabled() {
@@ -44,8 +44,8 @@ let C = (() => {
44
44
  const s = this.closest?.("sbb-form-field");
45
45
  s && (customElements.upgrade?.(s), this.negative = s.negative, I.resolveAssociation(this), this.slot ||= this._findSlotPosition());
46
46
  }
47
- requestUpdate(s, n, d) {
48
- super.requestUpdate(s, n, d), s === "input" && this.input !== n ? (this._inputAbortController?.abort(), this._inputDisabled = !0, this.input && (this._inputAbortController = new AbortController(), this.slot = this._findSlotPosition(), customElements.upgrade?.(this.input), this._sync(), this.input.addEventListener("ɵchange", () => this._sync())), this.hasUpdated && this.toggleAttribute("disabled", this.disabled)) : !s && this.hasUpdated && this.input && this._sync();
47
+ requestUpdate(s, n, u) {
48
+ super.requestUpdate(s, n, u), s === "input" && this.input !== n ? (this._inputAbortController?.abort(), this._inputDisabled = !0, this.input && (this._inputAbortController = new AbortController(), this.slot = this._findSlotPosition(), customElements.upgrade?.(this.input), this._sync(), this.input.addEventListener("ɵchange", () => this._sync())), this.hasUpdated && this.toggleAttribute("disabled", this.disabled)) : !s && this.hasUpdated && this.input && this._sync();
49
49
  }
50
50
  _findSlotPosition() {
51
51
  return !this.input || this.compareDocumentPosition(this.input) & Node.DOCUMENT_POSITION_FOLLOWING ? "prefix" : "suffix";
@@ -61,9 +61,9 @@ let C = (() => {
61
61
  }
62
62
  }, r = new WeakMap(), (() => {
63
63
  const s = typeof Symbol == "function" && Symbol.metadata ? Object.create(e[Symbol.metadata] ?? null) : void 0;
64
- t = [y(), g()], m(a, null, t, { kind: "accessor", name: "input", static: !1, private: !1, access: { has: (n) => "input" in n, get: (n) => n.input, set: (n, d) => {
65
- n.input = d;
66
- } }, metadata: s }, i, u), s && Object.defineProperty(a, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: s });
64
+ t = [y(), g()], m(a, null, t, { kind: "accessor", name: "input", static: !1, private: !1, access: { has: (n) => "input" in n, get: (n) => n.input, set: (n, u) => {
65
+ n.input = u;
66
+ } }, metadata: s }, i, o), s && Object.defineProperty(a, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: s });
67
67
  })(), a.sbbDateInputAssociated = !0, a;
68
68
  })();
69
69
  class M extends C {
@@ -73,10 +73,14 @@ class M extends C {
73
73
  constructor() {
74
74
  super(), this._disabled = !0, this.addEventListener?.("click", () => this._handleClick());
75
75
  }
76
+ /** @deprecated Use `getFollowingDate(date: T)` instead. */
77
+ findAvailableDate(t) {
78
+ return this.getFollowingDate(t);
79
+ }
76
80
  _handleClick() {
77
81
  if (!this.input || this.disabled)
78
82
  return;
79
- const t = this.input.valueAsDate ?? this.dateAdapter.today(), i = this.findAvailableDate(t);
83
+ const t = this.input.valueAsDate ?? this.dateAdapter.today(), i = this.getFollowingDate(t);
80
84
  this.dateAdapter.isValid(i) && this.dateAdapter.compareDate(i, t) !== 0 && (this.input.valueAsDate = i, this.input.dispatchEvent(new InputEvent("input", { bubbles: !0, composed: !0 })), this.input.dispatchEvent(new Event("change", { bubbles: !0, composed: !0 })), this.input.dispatchEvent(new Event("blur", { composed: !0 })));
81
85
  }
82
86
  syncDateInputState() {
@@ -84,7 +88,7 @@ class M extends C {
84
88
  this._disabled = !0, this.internals.ariaLabel = this.i18nOffBoundaryDay[this.language.current];
85
89
  return;
86
90
  }
87
- const t = this.findAvailableDate(this.input.valueAsDate);
91
+ const t = this.getFollowingDate(this.input.valueAsDate);
88
92
  this._disabled = !this.dateAdapter.isValid(t) || this.dateAdapter.compareDate(t, this.input.valueAsDate) === 0;
89
93
  const i = this.dateAdapter.compareDate(this.dateAdapter.today(), this.input.valueAsDate) === 0 ? S[this.language.current].toLowerCase() : this.dateAdapter.getAccessibilityFormatDate(this.input.valueAsDate);
90
94
  this.internals.ariaLabel = this.i18nSelectOffBoundaryDay(i)[this.language.current];
@@ -1,40 +1,32 @@
1
- import { __esDecorate as m, __runInitializers as c } from "tslib";
2
- import { customElement as u } from "lit/decorators.js";
3
- import { miniButtonStyle as d } from "../../button/common.js";
4
- import { i18nNextDay as p, i18nSelectNextDay as f } from "../../core/i18n.js";
1
+ import { __esDecorate as o, __runInitializers as m } from "tslib";
2
+ import { customElement as c } from "lit/decorators.js";
3
+ import { miniButtonStyle as u } from "../../button/common.js";
4
+ import { i18nNextDay as d, i18nSelectNextDay as p } from "../../core/i18n.js";
5
5
  import { boxSizingStyles as y } from "../../core/styles.js";
6
- import { SbbDatepickerButton as b, datepickerButtonStyle as D } from "../common.js";
7
- let k = (() => {
6
+ import { SbbDatepickerButton as f, datepickerButtonStyle as b } from "../common.js";
7
+ let v = (() => {
8
8
  var e;
9
- let o = [u("sbb-datepicker-next-day")], r, l = [], t, s = b;
10
- return e = class extends s {
9
+ let n = [c("sbb-datepicker-next-day")], r, i = [], t, l = f;
10
+ return e = class extends l {
11
11
  constructor() {
12
- super(...arguments), this.iconName = "chevron-small-right-small", this.i18nOffBoundaryDay = p, this.i18nSelectOffBoundaryDay = f;
12
+ super(...arguments), this.iconName = "chevron-small-right-small", this.i18nOffBoundaryDay = d, this.i18nSelectOffBoundaryDay = p;
13
13
  }
14
- findAvailableDate(a) {
15
- let i = this.dateAdapter.addCalendarDays(a, 1);
16
- if (this._isAfterMaxDate(i))
17
- return null;
18
- const n = this.input.dateFilter;
19
- if (n) {
20
- for (; !n(i); )
21
- if (i = this.dateAdapter.addCalendarDays(i, 1), this._isAfterMaxDate(i))
22
- return null;
23
- }
24
- return i;
14
+ getFollowingDate(a) {
15
+ const s = this.dateAdapter.addCalendarDays(a, 1);
16
+ return this._isAfterMaxDate(s) ? null : s;
25
17
  }
26
18
  _isAfterMaxDate(a) {
27
19
  return !!this.input.max && this.dateAdapter.compareDate(a, this.input.max) > 0;
28
20
  }
29
21
  }, t = e, (() => {
30
- const a = typeof Symbol == "function" && Symbol.metadata ? Object.create(s[Symbol.metadata] ?? null) : void 0;
31
- m(null, r = { value: t }, o, { kind: "class", name: t.name, metadata: a }, null, l), t = r.value, a && Object.defineProperty(t, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: a });
22
+ const a = typeof Symbol == "function" && Symbol.metadata ? Object.create(l[Symbol.metadata] ?? null) : void 0;
23
+ o(null, r = { value: t }, n, { kind: "class", name: t.name, metadata: a }, null, i), t = r.value, a && Object.defineProperty(t, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: a });
32
24
  })(), e.styles = [
33
25
  y,
34
- d,
35
- D
36
- ], c(t, l), t;
26
+ u,
27
+ b
28
+ ], m(t, i), t;
37
29
  })();
38
30
  export {
39
- k as SbbDatepickerNextDayElement
31
+ v as SbbDatepickerNextDayElement
40
32
  };
@@ -1,40 +1,32 @@
1
- import { __esDecorate as u, __runInitializers as m } from "tslib";
2
- import { customElement as c } from "lit/decorators.js";
3
- import { miniButtonStyle as d } from "../../button/common.js";
4
- import { i18nPreviousDay as p, i18nSelectPreviousDay as f } from "../../core/i18n.js";
5
- import { boxSizingStyles as y } from "../../core/styles.js";
6
- import { SbbDatepickerButton as b, datepickerButtonStyle as D } from "../common.js";
7
- let x = (() => {
1
+ import { __esDecorate as n, __runInitializers as m } from "tslib";
2
+ import { customElement as u } from "lit/decorators.js";
3
+ import { miniButtonStyle as c } from "../../button/common.js";
4
+ import { i18nPreviousDay as p, i18nSelectPreviousDay as d } from "../../core/i18n.js";
5
+ import { boxSizingStyles as f } from "../../core/styles.js";
6
+ import { SbbDatepickerButton as y, datepickerButtonStyle as b } from "../common.js";
7
+ let g = (() => {
8
8
  var e;
9
- let o = [c("sbb-datepicker-previous-day")], r, s = [], t, l = b;
10
- return e = class extends l {
9
+ let o = [u("sbb-datepicker-previous-day")], i, r = [], t, s = y;
10
+ return e = class extends s {
11
11
  constructor() {
12
- super(...arguments), this.iconName = "chevron-small-left-small", this.i18nOffBoundaryDay = p, this.i18nSelectOffBoundaryDay = f;
12
+ super(...arguments), this.iconName = "chevron-small-left-small", this.i18nOffBoundaryDay = p, this.i18nSelectOffBoundaryDay = d;
13
13
  }
14
- findAvailableDate(a) {
15
- let i = this.dateAdapter.addCalendarDays(a, -1);
16
- if (this._isBeforeMinDate(i))
17
- return null;
18
- const n = this.input.dateFilter;
19
- if (n) {
20
- for (; !n(i); )
21
- if (i = this.dateAdapter.addCalendarDays(i, -1), this._isBeforeMinDate(i))
22
- return null;
23
- }
24
- return i;
14
+ getFollowingDate(a) {
15
+ const l = this.dateAdapter.addCalendarDays(a, -1);
16
+ return this._isBeforeMinDate(l) ? null : l;
25
17
  }
26
18
  _isBeforeMinDate(a) {
27
19
  return !!this.input.min && this.dateAdapter.compareDate(a, this.input.min) < 0;
28
20
  }
29
21
  }, t = e, (() => {
30
- const a = typeof Symbol == "function" && Symbol.metadata ? Object.create(l[Symbol.metadata] ?? null) : void 0;
31
- u(null, r = { value: t }, o, { kind: "class", name: t.name, metadata: a }, null, s), t = r.value, a && Object.defineProperty(t, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: a });
22
+ const a = typeof Symbol == "function" && Symbol.metadata ? Object.create(s[Symbol.metadata] ?? null) : void 0;
23
+ n(null, i = { value: t }, o, { kind: "class", name: t.name, metadata: a }, null, r), t = i.value, a && Object.defineProperty(t, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: a });
32
24
  })(), e.styles = [
33
- y,
34
- d,
35
- D
36
- ], m(t, s), t;
25
+ f,
26
+ c,
27
+ b
28
+ ], m(t, r), t;
37
29
  })();
38
30
  export {
39
- x as SbbDatepickerPreviousDayElement
31
+ g as SbbDatepickerPreviousDayElement
40
32
  };
@@ -34,7 +34,9 @@ export declare abstract class SbbDatepickerButton<T = Date> extends SbbDatepicke
34
34
  protected abstract i18nSelectOffBoundaryDay: (_currentDate: string) => Record<string, string>;
35
35
  get disabled(): boolean;
36
36
  constructor();
37
- protected abstract findAvailableDate(_date: T): T | null;
37
+ /** @deprecated Use `getFollowingDate(date: T)` instead. */
38
+ protected findAvailableDate(_date: T): T | null;
39
+ protected abstract getFollowingDate(_date: T): T | null;
38
40
  private _handleClick;
39
41
  protected syncDateInputState(): void;
40
42
  }
@@ -1 +1 @@
1
- {"version":3,"file":"datepicker-button.d.ts","sourceRoot":"","sources":["../../../../../src/elements/datepicker/common/datepicker-button.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,KAAK,mBAAmB,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAG1E,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAEnE,OAAO,EAAE,qBAAqB,EAAE,MAAM,2BAA2B,CAAC;AAClE,OAAO,EAAE,KAAK,WAAW,EAAsB,MAAM,wBAAwB,CAAC;AAI9E,OAAO,EAAE,mBAAmB,EAAE,KAAK,sBAAsB,EAAE,MAAM,qBAAqB,CAAC;AAEvF,OAAO,eAAe,CAAC;;AAEvB,8BAAsB,uBAAuB,CAAC,CAAC,GAAG,IAAI,CACpD,SAAQ,4BACR,YAAW,sBAAsB,CAAC,CAAC,CAAC;IAEpC,gBAAuB,sBAAsB,QAAQ;IAErD;;;;OAIG;IACH,SAEgB,KAAK,EAAE,mBAAmB,CAAC,CAAC,CAAC,GAAG,IAAI,CAAQ;IAE5D,uCAAuC;IACvC,IAAW,QAAQ,IAAI,OAAO,CAE7B;IAED,0EAA0E;IAC1E,OAAO,CAAC,cAAc,CAAQ;IAE9B,OAAO,CAAC,qBAAqB,CAAC,CAAkB;IAEhD,SAAS,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC,CAAC,CAA4D;IACjG,SAAS,CAAC,QAAQ,wBAAmC;IACrD,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAEpB,iBAAiB,IAAI,IAAI;IAYzB,aAAa,CAC3B,IAAI,CAAC,EAAE,WAAW,EAClB,QAAQ,CAAC,EAAE,OAAO,EAClB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,IAAI;IAuBP,OAAO,CAAC,iBAAiB;IAOzB,OAAO,CAAC,KAAK;IAUb,SAAS,CAAC,kBAAkB,IAAI,IAAI;cAIjB,cAAc,IAAI,cAAc;CAGpD;AAED,8BAAsB,mBAAmB,CAAC,CAAC,GAAG,IAAI,CAAE,SAAQ,uBAAuB,CAAC,CAAC,CAAC;IACpF,0EAA0E;IAC1E,OAAO,CAAC,SAAS,CAAQ;IAEzB,SAAS,CAAC,QAAQ,CAAC,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC9D,SAAS,CAAC,QAAQ,CAAC,wBAAwB,EAAE,CAAC,YAAY,EAAE,MAAM,KAAK,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAE9F,IAAoB,QAAQ,IAAI,OAAO,CAEtC;;IAOD,SAAS,CAAC,QAAQ,CAAC,iBAAiB,CAAC,KAAK,EAAE,CAAC,GAAG,CAAC,GAAG,IAAI;IAExD,OAAO,CAAC,YAAY;cAgBD,kBAAkB,IAAI,IAAI;CAmB9C"}
1
+ {"version":3,"file":"datepicker-button.d.ts","sourceRoot":"","sources":["../../../../../src/elements/datepicker/common/datepicker-button.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,KAAK,mBAAmB,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAG1E,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAEnE,OAAO,EAAE,qBAAqB,EAAE,MAAM,2BAA2B,CAAC;AAClE,OAAO,EAAE,KAAK,WAAW,EAAsB,MAAM,wBAAwB,CAAC;AAI9E,OAAO,EAAE,mBAAmB,EAAE,KAAK,sBAAsB,EAAE,MAAM,qBAAqB,CAAC;AAEvF,OAAO,eAAe,CAAC;;AAEvB,8BAAsB,uBAAuB,CAAC,CAAC,GAAG,IAAI,CACpD,SAAQ,4BACR,YAAW,sBAAsB,CAAC,CAAC,CAAC;IAEpC,gBAAuB,sBAAsB,QAAQ;IAErD;;;;OAIG;IACH,SAEgB,KAAK,EAAE,mBAAmB,CAAC,CAAC,CAAC,GAAG,IAAI,CAAQ;IAE5D,uCAAuC;IACvC,IAAW,QAAQ,IAAI,OAAO,CAE7B;IAED,0EAA0E;IAC1E,OAAO,CAAC,cAAc,CAAQ;IAE9B,OAAO,CAAC,qBAAqB,CAAC,CAAkB;IAEhD,SAAS,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC,CAAC,CAA4D;IACjG,SAAS,CAAC,QAAQ,wBAAmC;IACrD,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAEpB,iBAAiB,IAAI,IAAI;IAYzB,aAAa,CAC3B,IAAI,CAAC,EAAE,WAAW,EAClB,QAAQ,CAAC,EAAE,OAAO,EAClB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,IAAI;IAuBP,OAAO,CAAC,iBAAiB;IAOzB,OAAO,CAAC,KAAK;IAUb,SAAS,CAAC,kBAAkB,IAAI,IAAI;cAIjB,cAAc,IAAI,cAAc;CAGpD;AAED,8BAAsB,mBAAmB,CAAC,CAAC,GAAG,IAAI,CAAE,SAAQ,uBAAuB,CAAC,CAAC,CAAC;IACpF,0EAA0E;IAC1E,OAAO,CAAC,SAAS,CAAQ;IAEzB,SAAS,CAAC,QAAQ,CAAC,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC9D,SAAS,CAAC,QAAQ,CAAC,wBAAwB,EAAE,CAAC,YAAY,EAAE,MAAM,KAAK,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAE9F,IAAoB,QAAQ,IAAI,OAAO,CAEtC;;IAOD,2DAA2D;IAC3D,SAAS,CAAC,iBAAiB,CAAC,KAAK,EAAE,CAAC,GAAG,CAAC,GAAG,IAAI;IAI/C,SAAS,CAAC,QAAQ,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC,GAAG,CAAC,GAAG,IAAI;IAEvD,OAAO,CAAC,YAAY;cAgBD,kBAAkB,IAAI,IAAI;CAmB9C"}
@@ -113,12 +113,16 @@ class SbbDatepickerButton extends SbbDatepickerButtonBase {
113
113
  this._disabled = true;
114
114
  this.addEventListener?.("click", () => this._handleClick());
115
115
  }
116
+ /** @deprecated Use `getFollowingDate(date: T)` instead. */
117
+ findAvailableDate(_date) {
118
+ return this.getFollowingDate(_date);
119
+ }
116
120
  _handleClick() {
117
121
  if (!this.input || this.disabled) {
118
122
  return;
119
123
  }
120
124
  const startingDate = this.input.valueAsDate ?? this.dateAdapter.today();
121
- const date = this.findAvailableDate(startingDate);
125
+ const date = this.getFollowingDate(startingDate);
122
126
  if (this.dateAdapter.isValid(date) && this.dateAdapter.compareDate(date, startingDate) !== 0) {
123
127
  this.input.valueAsDate = date;
124
128
  this.input.dispatchEvent(new InputEvent("input", { bubbles: true, composed: true }));
@@ -133,8 +137,8 @@ class SbbDatepickerButton extends SbbDatepickerButtonBase {
133
137
  this.internals.ariaLabel = this.i18nOffBoundaryDay[this.language.current];
134
138
  return;
135
139
  }
136
- const availableDate = this.findAvailableDate(this.input.valueAsDate);
137
- this._disabled = !this.dateAdapter.isValid(availableDate) || this.dateAdapter.compareDate(availableDate, this.input.valueAsDate) === 0;
140
+ const date = this.getFollowingDate(this.input.valueAsDate);
141
+ this._disabled = !this.dateAdapter.isValid(date) || this.dateAdapter.compareDate(date, this.input.valueAsDate) === 0;
138
142
  const currentDateString = this.dateAdapter.compareDate(this.dateAdapter.today(), this.input.valueAsDate) === 0 ? i18nToday[this.language.current].toLowerCase() : this.dateAdapter.getAccessibilityFormatDate(this.input.valueAsDate);
139
143
  this.internals.ariaLabel = this.i18nSelectOffBoundaryDay(currentDateString)[this.language.current];
140
144
  }
@@ -143,4 +147,4 @@ export {
143
147
  SbbDatepickerButton,
144
148
  SbbDatepickerButtonBase
145
149
  };
146
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"datepicker-button.js","sources":["../../../../../src/elements/datepicker/common/datepicker-button.ts"],"sourcesContent":["import { html, type PropertyDeclaration, type TemplateResult } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { SbbButtonBaseElement } from '../../core/base-elements.ts';\nimport { readConfig } from '../../core/config.ts';\nimport { SbbLanguageController } from '../../core/controllers.ts';\nimport { type DateAdapter, defaultDateAdapter } from '../../core/datetime.ts';\nimport { idReference } from '../../core/decorators.ts';\nimport { i18nToday } from '../../core/i18n.ts';\nimport { SbbNegativeMixin } from '../../core/mixins.ts';\nimport { SbbDateInputElement, type SbbDateInputAssociated } from '../../date-input.ts';\n\nimport '../../icon.ts';\n\nexport abstract class SbbDatepickerButtonBase<T = Date>\n  extends SbbNegativeMixin(SbbButtonBaseElement)\n  implements SbbDateInputAssociated<T>\n{\n  public static readonly sbbDateInputAssociated = true;\n\n  /**\n   * The associated date input element.\n   *\n   * For attribute usage, provide an id reference.\n   */\n  @idReference()\n  @property()\n  public accessor input: SbbDateInputElement<T> | null = null;\n\n  /** Whether this button is disabled. */\n  public get disabled(): boolean {\n    return !!this._inputDisabled;\n  }\n\n  /** Whether the component is disabled due date-picker's input disabled. */\n  private _inputDisabled = true;\n\n  private _inputAbortController?: AbortController;\n\n  protected dateAdapter: DateAdapter<T> = readConfig().datetime?.dateAdapter ?? defaultDateAdapter;\n  protected language = new SbbLanguageController(this);\n  protected abstract iconName: string;\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.toggleAttribute('disabled', this.disabled);\n    const formField = this.closest?.('sbb-form-field');\n    if (formField) {\n      customElements.upgrade?.(formField);\n      this.negative = formField.negative;\n      SbbDateInputElement.resolveAssociation(this);\n      this.slot ||= this._findSlotPosition();\n    }\n  }\n\n  public override requestUpdate(\n    name?: PropertyKey,\n    oldValue?: unknown,\n    options?: PropertyDeclaration,\n  ): void {\n    super.requestUpdate(name, oldValue, options);\n    if (name === 'input' && this.input !== oldValue) {\n      this._inputAbortController?.abort();\n      this._inputDisabled = true;\n      if (this.input) {\n        this._inputAbortController = new AbortController();\n        this.slot = this._findSlotPosition();\n        // The sbb-date-input instance must be upgraded in order\n        // for properties to be accessible.\n        customElements.upgrade?.(this.input);\n        this._sync();\n        this.input.addEventListener('ɵchange', () => this._sync());\n      }\n      if (this.hasUpdated) {\n        this.toggleAttribute('disabled', this.disabled);\n      }\n    } else if (!name && this.hasUpdated && this.input) {\n      // If language changes, we need to update related aria properties.\n      this._sync();\n    }\n  }\n\n  private _findSlotPosition(): string {\n    return !this.input ||\n      this.compareDocumentPosition(this.input) & Node.DOCUMENT_POSITION_FOLLOWING\n      ? 'prefix'\n      : 'suffix';\n  }\n\n  private _sync(): void {\n    this.syncDateInputState();\n    this.toggleAttribute('disabled', this.disabled);\n    if (this.disabled) {\n      this.removeAttribute('tabindex');\n    } else {\n      this.setAttribute('tabindex', '0');\n    }\n  }\n\n  protected syncDateInputState(): void {\n    this._inputDisabled = this.input!.disabled || this.input!.readOnly;\n  }\n\n  protected override renderTemplate(): TemplateResult {\n    return html`<sbb-icon name=${this.iconName}></sbb-icon>`;\n  }\n}\n\nexport abstract class SbbDatepickerButton<T = Date> extends SbbDatepickerButtonBase<T> {\n  /** Whether the component is disabled due date equals to boundary date. */\n  private _disabled = true;\n\n  protected abstract i18nOffBoundaryDay: Record<string, string>;\n  protected abstract i18nSelectOffBoundaryDay: (_currentDate: string) => Record<string, string>;\n\n  public override get disabled(): boolean {\n    return this._disabled || super.disabled;\n  }\n\n  public constructor() {\n    super();\n    this.addEventListener?.('click', () => this._handleClick());\n  }\n\n  protected abstract findAvailableDate(_date: T): T | null;\n\n  private _handleClick(): void {\n    if (!this.input || this.disabled) {\n      return;\n    }\n    const startingDate: T = this.input.valueAsDate ?? this.dateAdapter.today();\n    const date = this.findAvailableDate(startingDate);\n    if (this.dateAdapter.isValid(date) && this.dateAdapter.compareDate(date, startingDate) !== 0) {\n      this.input.valueAsDate = date;\n      this.input.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n      this.input.dispatchEvent(new Event('change', { bubbles: true, composed: true }));\n      // Emit blur event when value is changed programmatically to notify\n      // frameworks that rely on that event to update form status.\n      this.input.dispatchEvent(new Event('blur', { composed: true }));\n    }\n  }\n\n  protected override syncDateInputState(): void {\n    super.syncDateInputState();\n    if (!this.dateAdapter.isValid(this.input!.valueAsDate)) {\n      this._disabled = true;\n      this.internals.ariaLabel = this.i18nOffBoundaryDay[this.language.current];\n      return;\n    }\n\n    const availableDate = this.findAvailableDate(this.input!.valueAsDate);\n    this._disabled =\n      !this.dateAdapter.isValid(availableDate) ||\n      this.dateAdapter.compareDate(availableDate, this.input!.valueAsDate) === 0;\n    const currentDateString =\n      this.dateAdapter.compareDate(this.dateAdapter.today(), this.input!.valueAsDate) === 0\n        ? i18nToday[this.language.current].toLowerCase()\n        : this.dateAdapter.getAccessibilityFormatDate(this.input!.valueAsDate);\n    this.internals.ariaLabel =\n      this.i18nSelectOffBoundaryDay(currentDateString)[this.language.current];\n  }\n}\n"],"names":[],"mappings":"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"}
150
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"datepicker-button.js","sources":["../../../../../src/elements/datepicker/common/datepicker-button.ts"],"sourcesContent":["import { html, type PropertyDeclaration, type TemplateResult } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { SbbButtonBaseElement } from '../../core/base-elements.ts';\nimport { readConfig } from '../../core/config.ts';\nimport { SbbLanguageController } from '../../core/controllers.ts';\nimport { type DateAdapter, defaultDateAdapter } from '../../core/datetime.ts';\nimport { idReference } from '../../core/decorators.ts';\nimport { i18nToday } from '../../core/i18n.ts';\nimport { SbbNegativeMixin } from '../../core/mixins.ts';\nimport { SbbDateInputElement, type SbbDateInputAssociated } from '../../date-input.ts';\n\nimport '../../icon.ts';\n\nexport abstract class SbbDatepickerButtonBase<T = Date>\n  extends SbbNegativeMixin(SbbButtonBaseElement)\n  implements SbbDateInputAssociated<T>\n{\n  public static readonly sbbDateInputAssociated = true;\n\n  /**\n   * The associated date input element.\n   *\n   * For attribute usage, provide an id reference.\n   */\n  @idReference()\n  @property()\n  public accessor input: SbbDateInputElement<T> | null = null;\n\n  /** Whether this button is disabled. */\n  public get disabled(): boolean {\n    return !!this._inputDisabled;\n  }\n\n  /** Whether the component is disabled due date-picker's input disabled. */\n  private _inputDisabled = true;\n\n  private _inputAbortController?: AbortController;\n\n  protected dateAdapter: DateAdapter<T> = readConfig().datetime?.dateAdapter ?? defaultDateAdapter;\n  protected language = new SbbLanguageController(this);\n  protected abstract iconName: string;\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.toggleAttribute('disabled', this.disabled);\n    const formField = this.closest?.('sbb-form-field');\n    if (formField) {\n      customElements.upgrade?.(formField);\n      this.negative = formField.negative;\n      SbbDateInputElement.resolveAssociation(this);\n      this.slot ||= this._findSlotPosition();\n    }\n  }\n\n  public override requestUpdate(\n    name?: PropertyKey,\n    oldValue?: unknown,\n    options?: PropertyDeclaration,\n  ): void {\n    super.requestUpdate(name, oldValue, options);\n    if (name === 'input' && this.input !== oldValue) {\n      this._inputAbortController?.abort();\n      this._inputDisabled = true;\n      if (this.input) {\n        this._inputAbortController = new AbortController();\n        this.slot = this._findSlotPosition();\n        // The sbb-date-input instance must be upgraded in order\n        // for properties to be accessible.\n        customElements.upgrade?.(this.input);\n        this._sync();\n        this.input.addEventListener('ɵchange', () => this._sync());\n      }\n      if (this.hasUpdated) {\n        this.toggleAttribute('disabled', this.disabled);\n      }\n    } else if (!name && this.hasUpdated && this.input) {\n      // If language changes, we need to update related aria properties.\n      this._sync();\n    }\n  }\n\n  private _findSlotPosition(): string {\n    return !this.input ||\n      this.compareDocumentPosition(this.input) & Node.DOCUMENT_POSITION_FOLLOWING\n      ? 'prefix'\n      : 'suffix';\n  }\n\n  private _sync(): void {\n    this.syncDateInputState();\n    this.toggleAttribute('disabled', this.disabled);\n    if (this.disabled) {\n      this.removeAttribute('tabindex');\n    } else {\n      this.setAttribute('tabindex', '0');\n    }\n  }\n\n  protected syncDateInputState(): void {\n    this._inputDisabled = this.input!.disabled || this.input!.readOnly;\n  }\n\n  protected override renderTemplate(): TemplateResult {\n    return html`<sbb-icon name=${this.iconName}></sbb-icon>`;\n  }\n}\n\nexport abstract class SbbDatepickerButton<T = Date> extends SbbDatepickerButtonBase<T> {\n  /** Whether the component is disabled due date equals to boundary date. */\n  private _disabled = true;\n\n  protected abstract i18nOffBoundaryDay: Record<string, string>;\n  protected abstract i18nSelectOffBoundaryDay: (_currentDate: string) => Record<string, string>;\n\n  public override get disabled(): boolean {\n    return this._disabled || super.disabled;\n  }\n\n  public constructor() {\n    super();\n    this.addEventListener?.('click', () => this._handleClick());\n  }\n\n  /** @deprecated Use `getFollowingDate(date: T)` instead. */\n  protected findAvailableDate(_date: T): T | null {\n    return this.getFollowingDate(_date);\n  }\n\n  protected abstract getFollowingDate(_date: T): T | null;\n\n  private _handleClick(): void {\n    if (!this.input || this.disabled) {\n      return;\n    }\n    const startingDate: T = this.input.valueAsDate ?? this.dateAdapter.today();\n    const date = this.getFollowingDate(startingDate);\n    if (this.dateAdapter.isValid(date) && this.dateAdapter.compareDate(date, startingDate) !== 0) {\n      this.input.valueAsDate = date;\n      this.input.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n      this.input.dispatchEvent(new Event('change', { bubbles: true, composed: true }));\n      // Emit blur event when value is changed programmatically to notify\n      // frameworks that rely on that event to update form status.\n      this.input.dispatchEvent(new Event('blur', { composed: true }));\n    }\n  }\n\n  protected override syncDateInputState(): void {\n    super.syncDateInputState();\n    if (!this.dateAdapter.isValid(this.input!.valueAsDate)) {\n      this._disabled = true;\n      this.internals.ariaLabel = this.i18nOffBoundaryDay[this.language.current];\n      return;\n    }\n\n    const date = this.getFollowingDate(this.input!.valueAsDate);\n    this._disabled =\n      !this.dateAdapter.isValid(date) ||\n      this.dateAdapter.compareDate(date, this.input!.valueAsDate) === 0;\n    const currentDateString =\n      this.dateAdapter.compareDate(this.dateAdapter.today(), this.input!.valueAsDate) === 0\n        ? i18nToday[this.language.current].toLowerCase()\n        : this.dateAdapter.getAccessibilityFormatDate(this.input!.valueAsDate);\n    this.internals.ariaLabel =\n      this.i18nSelectOffBoundaryDay(currentDateString)[this.language.current];\n  }\n}\n"],"names":[],"mappings":"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"}
@@ -8,7 +8,7 @@ export declare class SbbDatepickerNextDayElement<T = Date> extends SbbDatepicker
8
8
  protected iconName: string;
9
9
  protected i18nOffBoundaryDay: Record<string, string>;
10
10
  protected i18nSelectOffBoundaryDay: (currentDate: string) => Record<string, string>;
11
- protected findAvailableDate(date: T): T | null;
11
+ protected getFollowingDate(date: T): T | null;
12
12
  private _isAfterMaxDate;
13
13
  }
14
14
  declare global {
@@ -1 +1 @@
1
- {"version":3,"file":"datepicker-next-day.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/datepicker/datepicker-next-day/datepicker-next-day.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAM1C,OAAO,EAAyB,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAE1E;;GAEG;AACH,qBAEM,2BAA2B,CAAC,CAAC,GAAG,IAAI,CAAE,SAAQ,mBAAmB,CAAC,CAAC,CAAC;IACxE,OAAuB,MAAM,EAAE,cAAc,CAI3C;IAEF,SAAS,CAAC,QAAQ,EAAE,MAAM,CAA+B;IACzD,SAAS,CAAC,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAe;IACnE,SAAS,CAAC,wBAAwB,kDAAqB;IAEvD,SAAS,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC,GAAG,CAAC,GAAG,IAAI;IAmB9C,OAAO,CAAC,eAAe;CAGxB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,yBAAyB,EAAE,2BAA2B,CAAC;KACxD;CACF"}
1
+ {"version":3,"file":"datepicker-next-day.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/datepicker/datepicker-next-day/datepicker-next-day.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAM1C,OAAO,EAAyB,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAE1E;;GAEG;AACH,qBAEM,2BAA2B,CAAC,CAAC,GAAG,IAAI,CAAE,SAAQ,mBAAmB,CAAC,CAAC,CAAC;IACxE,OAAuB,MAAM,EAAE,cAAc,CAI3C;IAEF,SAAS,CAAC,QAAQ,EAAE,MAAM,CAA+B;IACzD,SAAS,CAAC,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAe;IACnE,SAAS,CAAC,wBAAwB,kDAAqB;IAEvD,SAAS,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC,GAAG,CAAC,GAAG,IAAI;IAS7C,OAAO,CAAC,eAAe;CAGxB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,yBAAyB,EAAE,2BAA2B,CAAC;KACxD;CACF"}
@@ -18,20 +18,11 @@ let SbbDatepickerNextDayElement = (() => {
18
18
  this.i18nOffBoundaryDay = i18nNextDay;
19
19
  this.i18nSelectOffBoundaryDay = i18nSelectNextDay;
20
20
  }
21
- findAvailableDate(date) {
22
- let availableDate = this.dateAdapter.addCalendarDays(date, 1);
21
+ getFollowingDate(date) {
22
+ const availableDate = this.dateAdapter.addCalendarDays(date, 1);
23
23
  if (this._isAfterMaxDate(availableDate)) {
24
24
  return null;
25
25
  }
26
- const dateFilter = this.input.dateFilter;
27
- if (dateFilter) {
28
- while (!dateFilter(availableDate)) {
29
- availableDate = this.dateAdapter.addCalendarDays(availableDate, 1);
30
- if (this._isAfterMaxDate(availableDate)) {
31
- return null;
32
- }
33
- }
34
- }
35
26
  return availableDate;
36
27
  }
37
28
  _isAfterMaxDate(date) {
@@ -52,4 +43,4 @@ let SbbDatepickerNextDayElement = (() => {
52
43
  export {
53
44
  SbbDatepickerNextDayElement
54
45
  };
55
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXBpY2tlci1uZXh0LWRheS5jb21wb25lbnQuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9lbGVtZW50cy9kYXRlcGlja2VyL2RhdGVwaWNrZXItbmV4dC1kYXkvZGF0ZXBpY2tlci1uZXh0LWRheS5jb21wb25lbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBDU1NSZXN1bHRHcm91cCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgeyBtaW5pQnV0dG9uU3R5bGUgfSBmcm9tICcuLi8uLi9idXR0b24vY29tbW9uLnRzJztcbmltcG9ydCB7IGkxOG5OZXh0RGF5LCBpMThuU2VsZWN0TmV4dERheSB9IGZyb20gJy4uLy4uL2NvcmUvaTE4bi50cyc7XG5pbXBvcnQgeyBib3hTaXppbmdTdHlsZXMgfSBmcm9tICcuLi8uLi9jb3JlL3N0eWxlcy50cyc7XG5pbXBvcnQgeyBkYXRlcGlja2VyQnV0dG9uU3R5bGUsIFNiYkRhdGVwaWNrZXJCdXR0b24gfSBmcm9tICcuLi9jb21tb24udHMnO1xuXG4vKipcbiAqIENvbWJpbmVkIHdpdGggYSBgc2JiLWRhdGVwaWNrZXJgLCBpdCBjYW4gYmUgdXNlZCB0byBtb3ZlIHRoZSBkYXRlIGFoZWFkLlxuICovXG5leHBvcnRcbkBjdXN0b21FbGVtZW50KCdzYmItZGF0ZXBpY2tlci1uZXh0LWRheScpXG5jbGFzcyBTYmJEYXRlcGlja2VyTmV4dERheUVsZW1lbnQ8VCA9IERhdGU+IGV4dGVuZHMgU2JiRGF0ZXBpY2tlckJ1dHRvbjxUPiB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IFtcbiAgICBib3hTaXppbmdTdHlsZXMsXG4gICAgbWluaUJ1dHRvblN0eWxlLFxuICAgIGRhdGVwaWNrZXJCdXR0b25TdHlsZSxcbiAgXTtcblxuICBwcm90ZWN0ZWQgaWNvbk5hbWU6IHN0cmluZyA9ICdjaGV2cm9uLXNtYWxsLXJpZ2h0LXNtYWxsJztcbiAgcHJvdGVjdGVkIGkxOG5PZmZCb3VuZGFyeURheTogUmVjb3JkPHN0cmluZywgc3RyaW5nPiA9IGkxOG5OZXh0RGF5O1xuICBwcm90ZWN0ZWQgaTE4blNlbGVjdE9mZkJvdW5kYXJ5RGF5ID0gaTE4blNlbGVjdE5leHREYXk7XG5cbiAgcHJvdGVjdGVkIGZpbmRBdmFpbGFibGVEYXRlKGRhdGU6IFQpOiBUIHwgbnVsbCB7XG4gICAgbGV0IGF2YWlsYWJsZURhdGUgPSB0aGlzLmRhdGVBZGFwdGVyLmFkZENhbGVuZGFyRGF5cyhkYXRlLCAxKTtcbiAgICBpZiAodGhpcy5faXNBZnRlck1heERhdGUoYXZhaWxhYmxlRGF0ZSkpIHtcbiAgICAgIHJldHVybiBudWxsO1xuICAgIH1cblxuICAgIGNvbnN0IGRhdGVGaWx0ZXIgPSB0aGlzLmlucHV0IS5kYXRlRmlsdGVyO1xuICAgIGlmIChkYXRlRmlsdGVyKSB7XG4gICAgICB3aGlsZSAoIWRhdGVGaWx0ZXIoYXZhaWxhYmxlRGF0ZSkpIHtcbiAgICAgICAgYXZhaWxhYmxlRGF0ZSA9IHRoaXMuZGF0ZUFkYXB0ZXIuYWRkQ2FsZW5kYXJEYXlzKGF2YWlsYWJsZURhdGUsIDEpO1xuICAgICAgICBpZiAodGhpcy5faXNBZnRlck1heERhdGUoYXZhaWxhYmxlRGF0ZSkpIHtcbiAgICAgICAgICByZXR1cm4gbnVsbDtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBhdmFpbGFibGVEYXRlO1xuICB9XG5cbiAgcHJpdmF0ZSBfaXNBZnRlck1heERhdGUoZGF0ZTogVCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiAhIXRoaXMuaW5wdXQhLm1heCAmJiB0aGlzLmRhdGVBZGFwdGVyLmNvbXBhcmVEYXRlKGRhdGUsIHRoaXMuaW5wdXQhLm1heCkgPiAwO1xuICB9XG59XG5cbmRlY2xhcmUgZ2xvYmFsIHtcbiAgaW50ZXJmYWNlIEhUTUxFbGVtZW50VGFnTmFtZU1hcCB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvblxuICAgICdzYmItZGF0ZXBpY2tlci1uZXh0LWRheSc6IFNiYkRhdGVwaWNrZXJOZXh0RGF5RWxlbWVudDtcbiAgfVxufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztJQWFNLCtCQUEyQixNQUFBOzswQkFEaEMsY0FBYyx5QkFBeUIsQ0FBQzs7OztvQkFDVztBQUFSLEVBQUEsbUJBQVEsWUFBc0I7QUFBQTs7QUFPOUQsV0FBQSxXQUFtQjtBQUNuQixXQUFBLHFCQUE2QztBQUM3QyxXQUFBLDJCQUEyQjtBQUFBLElBd0J2QztBQUFBLElBdEJZLGtCQUFrQixNQUFPO0FBQ2pDLFVBQUksZ0JBQWdCLEtBQUssWUFBWSxnQkFBZ0IsTUFBTSxDQUFDO0FBQzVELFVBQUksS0FBSyxnQkFBZ0IsYUFBYSxHQUFHO0FBQ3ZDLGVBQU87QUFBQSxNQUNUO0FBRUEsWUFBTSxhQUFhLEtBQUssTUFBTztBQUMvQixVQUFJLFlBQVk7QUFDZCxlQUFPLENBQUMsV0FBVyxhQUFhLEdBQUc7QUFDakMsMEJBQWdCLEtBQUssWUFBWSxnQkFBZ0IsZUFBZSxDQUFDO0FBQ2pFLGNBQUksS0FBSyxnQkFBZ0IsYUFBYSxHQUFHO0FBQ3ZDLG1CQUFPO0FBQUEsVUFDVDtBQUFBLFFBQ0Y7QUFBQSxNQUNGO0FBRUEsYUFBTztBQUFBLElBQ1Q7QUFBQSxJQUVRLGdCQUFnQixNQUFPO0FBQzdCLGFBQU8sQ0FBQyxDQUFDLEtBQUssTUFBTyxPQUFPLEtBQUssWUFBWSxZQUFZLE1BQU0sS0FBSyxNQUFPLEdBQUcsSUFBSTtBQUFBLElBQ3BGO0FBQUE7O0FBaENGLGlCQUFBLE1BQUEsbUJBQUEsRUFBQSxPQUFBLFdBQUEsR0FBQSxrQkFBQSxFQUFBLE1BQUEsU0FBQSxNQUFBLFdBQUEsTUFBQSxVQUFBLFVBQUEsR0FBQSxNQUFBLHVCQUFBOzs7UUFDeUIsR0FBQSxTQUF5QjtBQUFBLElBQzlDO0FBQUEsSUFDQTtBQUFBLElBQ0E7QUFBQSxFQUFBLEdBSkUsa0JBQUEsWUFBQSx1QkFBQSxHQUFzQzs7OyJ9
46
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXBpY2tlci1uZXh0LWRheS5jb21wb25lbnQuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9lbGVtZW50cy9kYXRlcGlja2VyL2RhdGVwaWNrZXItbmV4dC1kYXkvZGF0ZXBpY2tlci1uZXh0LWRheS5jb21wb25lbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBDU1NSZXN1bHRHcm91cCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgeyBtaW5pQnV0dG9uU3R5bGUgfSBmcm9tICcuLi8uLi9idXR0b24vY29tbW9uLnRzJztcbmltcG9ydCB7IGkxOG5OZXh0RGF5LCBpMThuU2VsZWN0TmV4dERheSB9IGZyb20gJy4uLy4uL2NvcmUvaTE4bi50cyc7XG5pbXBvcnQgeyBib3hTaXppbmdTdHlsZXMgfSBmcm9tICcuLi8uLi9jb3JlL3N0eWxlcy50cyc7XG5pbXBvcnQgeyBkYXRlcGlja2VyQnV0dG9uU3R5bGUsIFNiYkRhdGVwaWNrZXJCdXR0b24gfSBmcm9tICcuLi9jb21tb24udHMnO1xuXG4vKipcbiAqIENvbWJpbmVkIHdpdGggYSBgc2JiLWRhdGVwaWNrZXJgLCBpdCBjYW4gYmUgdXNlZCB0byBtb3ZlIHRoZSBkYXRlIGFoZWFkLlxuICovXG5leHBvcnRcbkBjdXN0b21FbGVtZW50KCdzYmItZGF0ZXBpY2tlci1uZXh0LWRheScpXG5jbGFzcyBTYmJEYXRlcGlja2VyTmV4dERheUVsZW1lbnQ8VCA9IERhdGU+IGV4dGVuZHMgU2JiRGF0ZXBpY2tlckJ1dHRvbjxUPiB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IFtcbiAgICBib3hTaXppbmdTdHlsZXMsXG4gICAgbWluaUJ1dHRvblN0eWxlLFxuICAgIGRhdGVwaWNrZXJCdXR0b25TdHlsZSxcbiAgXTtcblxuICBwcm90ZWN0ZWQgaWNvbk5hbWU6IHN0cmluZyA9ICdjaGV2cm9uLXNtYWxsLXJpZ2h0LXNtYWxsJztcbiAgcHJvdGVjdGVkIGkxOG5PZmZCb3VuZGFyeURheTogUmVjb3JkPHN0cmluZywgc3RyaW5nPiA9IGkxOG5OZXh0RGF5O1xuICBwcm90ZWN0ZWQgaTE4blNlbGVjdE9mZkJvdW5kYXJ5RGF5ID0gaTE4blNlbGVjdE5leHREYXk7XG5cbiAgcHJvdGVjdGVkIGdldEZvbGxvd2luZ0RhdGUoZGF0ZTogVCk6IFQgfCBudWxsIHtcbiAgICBjb25zdCBhdmFpbGFibGVEYXRlID0gdGhpcy5kYXRlQWRhcHRlci5hZGRDYWxlbmRhckRheXMoZGF0ZSwgMSk7XG4gICAgaWYgKHRoaXMuX2lzQWZ0ZXJNYXhEYXRlKGF2YWlsYWJsZURhdGUpKSB7XG4gICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG5cbiAgICByZXR1cm4gYXZhaWxhYmxlRGF0ZTtcbiAgfVxuXG4gIHByaXZhdGUgX2lzQWZ0ZXJNYXhEYXRlKGRhdGU6IFQpOiBib29sZWFuIHtcbiAgICByZXR1cm4gISF0aGlzLmlucHV0IS5tYXggJiYgdGhpcy5kYXRlQWRhcHRlci5jb21wYXJlRGF0ZShkYXRlLCB0aGlzLmlucHV0IS5tYXgpID4gMDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLWRhdGVwaWNrZXItbmV4dC1kYXknOiBTYmJEYXRlcGlja2VyTmV4dERheUVsZW1lbnQ7XG4gIH1cbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7SUFhTSwrQkFBMkIsTUFBQTs7MEJBRGhDLGNBQWMseUJBQXlCLENBQUM7Ozs7b0JBQ1c7QUFBUixFQUFBLG1CQUFRLFlBQXNCO0FBQUE7O0FBTzlELFdBQUEsV0FBbUI7QUFDbkIsV0FBQSxxQkFBNkM7QUFDN0MsV0FBQSwyQkFBMkI7QUFBQSxJQWN2QztBQUFBLElBWlksaUJBQWlCLE1BQU87QUFDaEMsWUFBTSxnQkFBZ0IsS0FBSyxZQUFZLGdCQUFnQixNQUFNLENBQUM7QUFDOUQsVUFBSSxLQUFLLGdCQUFnQixhQUFhLEdBQUc7QUFDdkMsZUFBTztBQUFBLE1BQ1Q7QUFFQSxhQUFPO0FBQUEsSUFDVDtBQUFBLElBRVEsZ0JBQWdCLE1BQU87QUFDN0IsYUFBTyxDQUFDLENBQUMsS0FBSyxNQUFPLE9BQU8sS0FBSyxZQUFZLFlBQVksTUFBTSxLQUFLLE1BQU8sR0FBRyxJQUFJO0FBQUEsSUFDcEY7QUFBQTs7QUF0QkYsaUJBQUEsTUFBQSxtQkFBQSxFQUFBLE9BQUEsV0FBQSxHQUFBLGtCQUFBLEVBQUEsTUFBQSxTQUFBLE1BQUEsV0FBQSxNQUFBLFVBQUEsVUFBQSxHQUFBLE1BQUEsdUJBQUE7OztRQUN5QixHQUFBLFNBQXlCO0FBQUEsSUFDOUM7QUFBQSxJQUNBO0FBQUEsSUFDQTtBQUFBLEVBQUEsR0FKRSxrQkFBQSxZQUFBLHVCQUFBLEdBQXNDOzs7In0=
@@ -8,7 +8,7 @@ export declare class SbbDatepickerPreviousDayElement<T = Date> extends SbbDatepi
8
8
  protected iconName: string;
9
9
  protected i18nOffBoundaryDay: Record<string, string>;
10
10
  protected i18nSelectOffBoundaryDay: (currentDate: string) => Record<string, string>;
11
- protected findAvailableDate(date: T): T | null;
11
+ protected getFollowingDate(date: T): T | null;
12
12
  private _isBeforeMinDate;
13
13
  }
14
14
  declare global {
@@ -1 +1 @@
1
- {"version":3,"file":"datepicker-previous-day.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/datepicker/datepicker-previous-day/datepicker-previous-day.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAM1C,OAAO,EAAyB,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAE1E;;GAEG;AACH,qBAEM,+BAA+B,CAAC,CAAC,GAAG,IAAI,CAAE,SAAQ,mBAAmB,CAAC,CAAC,CAAC;IAC5E,OAAuB,MAAM,EAAE,cAAc,CAI3C;IAEF,SAAS,CAAC,QAAQ,EAAE,MAAM,CAA8B;IACxD,SAAS,CAAC,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAmB;IACvE,SAAS,CAAC,wBAAwB,kDAAyB;IAE3D,SAAS,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC,GAAG,CAAC,GAAG,IAAI;IAmB9C,OAAO,CAAC,gBAAgB;CAGzB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,6BAA6B,EAAE,+BAA+B,CAAC;KAChE;CACF"}
1
+ {"version":3,"file":"datepicker-previous-day.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/datepicker/datepicker-previous-day/datepicker-previous-day.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAM1C,OAAO,EAAyB,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAE1E;;GAEG;AACH,qBAEM,+BAA+B,CAAC,CAAC,GAAG,IAAI,CAAE,SAAQ,mBAAmB,CAAC,CAAC,CAAC;IAC5E,OAAuB,MAAM,EAAE,cAAc,CAI3C;IAEF,SAAS,CAAC,QAAQ,EAAE,MAAM,CAA8B;IACxD,SAAS,CAAC,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAmB;IACvE,SAAS,CAAC,wBAAwB,kDAAyB;IAE3D,SAAS,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC,GAAG,CAAC,GAAG,IAAI;IAS7C,OAAO,CAAC,gBAAgB;CAGzB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,6BAA6B,EAAE,+BAA+B,CAAC;KAChE;CACF"}
@@ -18,20 +18,11 @@ let SbbDatepickerPreviousDayElement = (() => {
18
18
  this.i18nOffBoundaryDay = i18nPreviousDay;
19
19
  this.i18nSelectOffBoundaryDay = i18nSelectPreviousDay;
20
20
  }
21
- findAvailableDate(date) {
22
- let availableDate = this.dateAdapter.addCalendarDays(date, -1);
21
+ getFollowingDate(date) {
22
+ const availableDate = this.dateAdapter.addCalendarDays(date, -1);
23
23
  if (this._isBeforeMinDate(availableDate)) {
24
24
  return null;
25
25
  }
26
- const dateFilter = this.input.dateFilter;
27
- if (dateFilter) {
28
- while (!dateFilter(availableDate)) {
29
- availableDate = this.dateAdapter.addCalendarDays(availableDate, -1);
30
- if (this._isBeforeMinDate(availableDate)) {
31
- return null;
32
- }
33
- }
34
- }
35
26
  return availableDate;
36
27
  }
37
28
  _isBeforeMinDate(date) {
@@ -52,4 +43,4 @@ let SbbDatepickerPreviousDayElement = (() => {
52
43
  export {
53
44
  SbbDatepickerPreviousDayElement
54
45
  };
55
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXBpY2tlci1wcmV2aW91cy1kYXkuY29tcG9uZW50LmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvZWxlbWVudHMvZGF0ZXBpY2tlci9kYXRlcGlja2VyLXByZXZpb3VzLWRheS9kYXRlcGlja2VyLXByZXZpb3VzLWRheS5jb21wb25lbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBDU1NSZXN1bHRHcm91cCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgeyBtaW5pQnV0dG9uU3R5bGUgfSBmcm9tICcuLi8uLi9idXR0b24vY29tbW9uLnRzJztcbmltcG9ydCB7IGkxOG5QcmV2aW91c0RheSwgaTE4blNlbGVjdFByZXZpb3VzRGF5IH0gZnJvbSAnLi4vLi4vY29yZS9pMThuLnRzJztcbmltcG9ydCB7IGJveFNpemluZ1N0eWxlcyB9IGZyb20gJy4uLy4uL2NvcmUvc3R5bGVzLnRzJztcbmltcG9ydCB7IGRhdGVwaWNrZXJCdXR0b25TdHlsZSwgU2JiRGF0ZXBpY2tlckJ1dHRvbiB9IGZyb20gJy4uL2NvbW1vbi50cyc7XG5cbi8qKlxuICogQ29tYmluZWQgd2l0aCBhIGBzYmItZGF0ZXBpY2tlcmAsIGl0IGNhbiBiZSB1c2VkIHRvIG1vdmUgdGhlIGRhdGUgYmFjay5cbiAqL1xuZXhwb3J0XG5AY3VzdG9tRWxlbWVudCgnc2JiLWRhdGVwaWNrZXItcHJldmlvdXMtZGF5JylcbmNsYXNzIFNiYkRhdGVwaWNrZXJQcmV2aW91c0RheUVsZW1lbnQ8VCA9IERhdGU+IGV4dGVuZHMgU2JiRGF0ZXBpY2tlckJ1dHRvbjxUPiB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IFtcbiAgICBib3hTaXppbmdTdHlsZXMsXG4gICAgbWluaUJ1dHRvblN0eWxlLFxuICAgIGRhdGVwaWNrZXJCdXR0b25TdHlsZSxcbiAgXTtcblxuICBwcm90ZWN0ZWQgaWNvbk5hbWU6IHN0cmluZyA9ICdjaGV2cm9uLXNtYWxsLWxlZnQtc21hbGwnO1xuICBwcm90ZWN0ZWQgaTE4bk9mZkJvdW5kYXJ5RGF5OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+ID0gaTE4blByZXZpb3VzRGF5O1xuICBwcm90ZWN0ZWQgaTE4blNlbGVjdE9mZkJvdW5kYXJ5RGF5ID0gaTE4blNlbGVjdFByZXZpb3VzRGF5O1xuXG4gIHByb3RlY3RlZCBmaW5kQXZhaWxhYmxlRGF0ZShkYXRlOiBUKTogVCB8IG51bGwge1xuICAgIGxldCBhdmFpbGFibGVEYXRlID0gdGhpcy5kYXRlQWRhcHRlci5hZGRDYWxlbmRhckRheXMoZGF0ZSwgLTEpO1xuICAgIGlmICh0aGlzLl9pc0JlZm9yZU1pbkRhdGUoYXZhaWxhYmxlRGF0ZSkpIHtcbiAgICAgIHJldHVybiBudWxsO1xuICAgIH1cblxuICAgIGNvbnN0IGRhdGVGaWx0ZXIgPSB0aGlzLmlucHV0IS5kYXRlRmlsdGVyO1xuICAgIGlmIChkYXRlRmlsdGVyKSB7XG4gICAgICB3aGlsZSAoIWRhdGVGaWx0ZXIoYXZhaWxhYmxlRGF0ZSkpIHtcbiAgICAgICAgYXZhaWxhYmxlRGF0ZSA9IHRoaXMuZGF0ZUFkYXB0ZXIuYWRkQ2FsZW5kYXJEYXlzKGF2YWlsYWJsZURhdGUsIC0xKTtcbiAgICAgICAgaWYgKHRoaXMuX2lzQmVmb3JlTWluRGF0ZShhdmFpbGFibGVEYXRlKSkge1xuICAgICAgICAgIHJldHVybiBudWxsO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIGF2YWlsYWJsZURhdGU7XG4gIH1cblxuICBwcml2YXRlIF9pc0JlZm9yZU1pbkRhdGUoZGF0ZTogVCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiAhIXRoaXMuaW5wdXQhLm1pbiAmJiB0aGlzLmRhdGVBZGFwdGVyLmNvbXBhcmVEYXRlKGRhdGUsIHRoaXMuaW5wdXQhLm1pbikgPCAwO1xuICB9XG59XG5cbmRlY2xhcmUgZ2xvYmFsIHtcbiAgaW50ZXJmYWNlIEhUTUxFbGVtZW50VGFnTmFtZU1hcCB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvblxuICAgICdzYmItZGF0ZXBpY2tlci1wcmV2aW91cy1kYXknOiBTYmJEYXRlcGlja2VyUHJldmlvdXNEYXlFbGVtZW50O1xuICB9XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0lBYU0sbUNBQStCLE1BQUE7OzBCQURwQyxjQUFjLDZCQUE2QixDQUFDOzs7O29CQUNXO0FBQVIsRUFBQSxtQkFBUSxZQUFzQjtBQUFBOztBQU9sRSxXQUFBLFdBQW1CO0FBQ25CLFdBQUEscUJBQTZDO0FBQzdDLFdBQUEsMkJBQTJCO0FBQUEsSUF3QnZDO0FBQUEsSUF0Qlksa0JBQWtCLE1BQU87QUFDakMsVUFBSSxnQkFBZ0IsS0FBSyxZQUFZLGdCQUFnQixNQUFNLEVBQUU7QUFDN0QsVUFBSSxLQUFLLGlCQUFpQixhQUFhLEdBQUc7QUFDeEMsZUFBTztBQUFBLE1BQ1Q7QUFFQSxZQUFNLGFBQWEsS0FBSyxNQUFPO0FBQy9CLFVBQUksWUFBWTtBQUNkLGVBQU8sQ0FBQyxXQUFXLGFBQWEsR0FBRztBQUNqQywwQkFBZ0IsS0FBSyxZQUFZLGdCQUFnQixlQUFlLEVBQUU7QUFDbEUsY0FBSSxLQUFLLGlCQUFpQixhQUFhLEdBQUc7QUFDeEMsbUJBQU87QUFBQSxVQUNUO0FBQUEsUUFDRjtBQUFBLE1BQ0Y7QUFFQSxhQUFPO0FBQUEsSUFDVDtBQUFBLElBRVEsaUJBQWlCLE1BQU87QUFDOUIsYUFBTyxDQUFDLENBQUMsS0FBSyxNQUFPLE9BQU8sS0FBSyxZQUFZLFlBQVksTUFBTSxLQUFLLE1BQU8sR0FBRyxJQUFJO0FBQUEsSUFDcEY7QUFBQTs7QUFoQ0YsaUJBQUEsTUFBQSxtQkFBQSxFQUFBLE9BQUEsV0FBQSxHQUFBLGtCQUFBLEVBQUEsTUFBQSxTQUFBLE1BQUEsV0FBQSxNQUFBLFVBQUEsVUFBQSxHQUFBLE1BQUEsdUJBQUE7OztRQUN5QixHQUFBLFNBQXlCO0FBQUEsSUFDOUM7QUFBQSxJQUNBO0FBQUEsSUFDQTtBQUFBLEVBQUEsR0FKRSxrQkFBQSxZQUFBLHVCQUFBLEdBQTBDOzs7In0=
46
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXBpY2tlci1wcmV2aW91cy1kYXkuY29tcG9uZW50LmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvZWxlbWVudHMvZGF0ZXBpY2tlci9kYXRlcGlja2VyLXByZXZpb3VzLWRheS9kYXRlcGlja2VyLXByZXZpb3VzLWRheS5jb21wb25lbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBDU1NSZXN1bHRHcm91cCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgeyBtaW5pQnV0dG9uU3R5bGUgfSBmcm9tICcuLi8uLi9idXR0b24vY29tbW9uLnRzJztcbmltcG9ydCB7IGkxOG5QcmV2aW91c0RheSwgaTE4blNlbGVjdFByZXZpb3VzRGF5IH0gZnJvbSAnLi4vLi4vY29yZS9pMThuLnRzJztcbmltcG9ydCB7IGJveFNpemluZ1N0eWxlcyB9IGZyb20gJy4uLy4uL2NvcmUvc3R5bGVzLnRzJztcbmltcG9ydCB7IGRhdGVwaWNrZXJCdXR0b25TdHlsZSwgU2JiRGF0ZXBpY2tlckJ1dHRvbiB9IGZyb20gJy4uL2NvbW1vbi50cyc7XG5cbi8qKlxuICogQ29tYmluZWQgd2l0aCBhIGBzYmItZGF0ZXBpY2tlcmAsIGl0IGNhbiBiZSB1c2VkIHRvIG1vdmUgdGhlIGRhdGUgYmFjay5cbiAqL1xuZXhwb3J0XG5AY3VzdG9tRWxlbWVudCgnc2JiLWRhdGVwaWNrZXItcHJldmlvdXMtZGF5JylcbmNsYXNzIFNiYkRhdGVwaWNrZXJQcmV2aW91c0RheUVsZW1lbnQ8VCA9IERhdGU+IGV4dGVuZHMgU2JiRGF0ZXBpY2tlckJ1dHRvbjxUPiB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IFtcbiAgICBib3hTaXppbmdTdHlsZXMsXG4gICAgbWluaUJ1dHRvblN0eWxlLFxuICAgIGRhdGVwaWNrZXJCdXR0b25TdHlsZSxcbiAgXTtcblxuICBwcm90ZWN0ZWQgaWNvbk5hbWU6IHN0cmluZyA9ICdjaGV2cm9uLXNtYWxsLWxlZnQtc21hbGwnO1xuICBwcm90ZWN0ZWQgaTE4bk9mZkJvdW5kYXJ5RGF5OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+ID0gaTE4blByZXZpb3VzRGF5O1xuICBwcm90ZWN0ZWQgaTE4blNlbGVjdE9mZkJvdW5kYXJ5RGF5ID0gaTE4blNlbGVjdFByZXZpb3VzRGF5O1xuXG4gIHByb3RlY3RlZCBnZXRGb2xsb3dpbmdEYXRlKGRhdGU6IFQpOiBUIHwgbnVsbCB7XG4gICAgY29uc3QgYXZhaWxhYmxlRGF0ZSA9IHRoaXMuZGF0ZUFkYXB0ZXIuYWRkQ2FsZW5kYXJEYXlzKGRhdGUsIC0xKTtcbiAgICBpZiAodGhpcy5faXNCZWZvcmVNaW5EYXRlKGF2YWlsYWJsZURhdGUpKSB7XG4gICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG5cbiAgICByZXR1cm4gYXZhaWxhYmxlRGF0ZTtcbiAgfVxuXG4gIHByaXZhdGUgX2lzQmVmb3JlTWluRGF0ZShkYXRlOiBUKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuICEhdGhpcy5pbnB1dCEubWluICYmIHRoaXMuZGF0ZUFkYXB0ZXIuY29tcGFyZURhdGUoZGF0ZSwgdGhpcy5pbnB1dCEubWluKSA8IDA7XG4gIH1cbn1cblxuZGVjbGFyZSBnbG9iYWwge1xuICBpbnRlcmZhY2UgSFRNTEVsZW1lbnRUYWdOYW1lTWFwIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25hbWluZy1jb252ZW50aW9uXG4gICAgJ3NiYi1kYXRlcGlja2VyLXByZXZpb3VzLWRheSc6IFNiYkRhdGVwaWNrZXJQcmV2aW91c0RheUVsZW1lbnQ7XG4gIH1cbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7SUFhTSxtQ0FBK0IsTUFBQTs7MEJBRHBDLGNBQWMsNkJBQTZCLENBQUM7Ozs7b0JBQ1c7QUFBUixFQUFBLG1CQUFRLFlBQXNCO0FBQUE7O0FBT2xFLFdBQUEsV0FBbUI7QUFDbkIsV0FBQSxxQkFBNkM7QUFDN0MsV0FBQSwyQkFBMkI7QUFBQSxJQWN2QztBQUFBLElBWlksaUJBQWlCLE1BQU87QUFDaEMsWUFBTSxnQkFBZ0IsS0FBSyxZQUFZLGdCQUFnQixNQUFNLEVBQUU7QUFDL0QsVUFBSSxLQUFLLGlCQUFpQixhQUFhLEdBQUc7QUFDeEMsZUFBTztBQUFBLE1BQ1Q7QUFFQSxhQUFPO0FBQUEsSUFDVDtBQUFBLElBRVEsaUJBQWlCLE1BQU87QUFDOUIsYUFBTyxDQUFDLENBQUMsS0FBSyxNQUFPLE9BQU8sS0FBSyxZQUFZLFlBQVksTUFBTSxLQUFLLE1BQU8sR0FBRyxJQUFJO0FBQUEsSUFDcEY7QUFBQTs7QUF0QkYsaUJBQUEsTUFBQSxtQkFBQSxFQUFBLE9BQUEsV0FBQSxHQUFBLGtCQUFBLEVBQUEsTUFBQSxTQUFBLE1BQUEsV0FBQSxNQUFBLFVBQUEsVUFBQSxHQUFBLE1BQUEsdUJBQUE7OztRQUN5QixHQUFBLFNBQXlCO0FBQUEsSUFDOUM7QUFBQSxJQUNBO0FBQUEsSUFDQTtBQUFBLEVBQUEsR0FKRSxrQkFBQSxZQUFBLHVCQUFBLEdBQTBDOzs7In0=
package/package.json CHANGED
@@ -1,13 +1,13 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements-dev",
3
- "version": "4.6.0-dev.1772444903",
3
+ "version": "4.6.0-dev.1772454706",
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/c8263d5719390619b06dd5a2930e1d344e219e05"
10
+ "https://github.com/sbb-design-systems/lyne-components/commit/a54febddca9b29658c6e47ed26150ea4909eebad"
11
11
  ],
12
12
  "type": "module",
13
13
  "exports": {