@sbb-esta/lyne-elements 1.2.1 → 1.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/button/common/button-common.d.ts.map +1 -1
- package/button/common.js +20 -20
- package/button/mini-button/mini-button.d.ts +0 -1
- package/button/mini-button/mini-button.d.ts.map +1 -1
- package/button/mini-button.js +16 -18
- package/calendar/calendar.d.ts.map +1 -1
- package/calendar.js +22 -20
- package/checkbox/checkbox/checkbox.d.ts +0 -1
- package/checkbox/checkbox/checkbox.d.ts.map +1 -1
- package/checkbox/checkbox-group/checkbox-group.d.ts +0 -1
- package/checkbox/checkbox-group/checkbox-group.d.ts.map +1 -1
- package/checkbox/checkbox-group.js +5 -3
- package/checkbox/checkbox-panel/checkbox-panel.d.ts +0 -1
- package/checkbox/checkbox-panel/checkbox-panel.d.ts.map +1 -1
- package/checkbox/checkbox-panel.js +12 -11
- package/checkbox/checkbox.js +12 -11
- package/core/datetime/date-adapter.d.ts +23 -13
- package/core/datetime/date-adapter.d.ts.map +1 -1
- package/core/datetime/native-date-adapter.d.ts +0 -1
- package/core/datetime/native-date-adapter.d.ts.map +1 -1
- package/core/datetime.js +23 -23
- package/core/decorators/host-attributes.d.ts +1 -1
- package/core/decorators/slot-state.d.ts +18 -0
- package/core/decorators/slot-state.d.ts.map +1 -0
- package/core/decorators.d.ts +1 -0
- package/core/decorators.d.ts.map +1 -1
- package/core/decorators.js +15 -9
- package/core/styles/mixins/buttons.scss +15 -48
- package/custom-elements.json +463 -302
- package/datepicker/common/datepicker-button.d.ts +5 -5
- package/datepicker/common/datepicker-button.d.ts.map +1 -1
- package/datepicker/common.js +21 -20
- package/datepicker/datepicker/datepicker.d.ts +55 -38
- package/datepicker/datepicker/datepicker.d.ts.map +1 -1
- package/datepicker/datepicker-next-day/datepicker-next-day.d.ts +1 -1
- package/datepicker/datepicker-next-day/datepicker-next-day.d.ts.map +1 -1
- package/datepicker/datepicker-next-day.js +16 -16
- package/datepicker/datepicker-previous-day/datepicker-previous-day.d.ts +1 -1
- package/datepicker/datepicker-previous-day/datepicker-previous-day.d.ts.map +1 -1
- package/datepicker/datepicker-previous-day.js +14 -14
- package/datepicker/datepicker-toggle/datepicker-toggle.d.ts +1 -1
- package/datepicker/datepicker-toggle/datepicker-toggle.d.ts.map +1 -1
- package/datepicker/datepicker-toggle.js +25 -23
- package/datepicker/datepicker.js +147 -181
- package/development/button/common/button-common.d.ts.map +1 -1
- package/development/button/common.js +30 -25
- package/development/button/mini-button/mini-button.d.ts +0 -1
- package/development/button/mini-button/mini-button.d.ts.map +1 -1
- package/development/button/mini-button.js +17 -55
- package/development/calendar/calendar.d.ts.map +1 -1
- package/development/calendar.js +4 -2
- package/development/checkbox/checkbox/checkbox.d.ts +0 -1
- package/development/checkbox/checkbox/checkbox.d.ts.map +1 -1
- package/development/checkbox/checkbox-group/checkbox-group.d.ts +0 -1
- package/development/checkbox/checkbox-group/checkbox-group.d.ts.map +1 -1
- package/development/checkbox/checkbox-group.js +6 -5
- package/development/checkbox/checkbox-panel/checkbox-panel.d.ts +0 -1
- package/development/checkbox/checkbox-panel/checkbox-panel.d.ts.map +1 -1
- package/development/checkbox/checkbox-panel.js +5 -5
- package/development/checkbox/checkbox.js +5 -5
- package/development/core/datetime/date-adapter.d.ts +23 -13
- package/development/core/datetime/date-adapter.d.ts.map +1 -1
- package/development/core/datetime/native-date-adapter.d.ts +0 -1
- package/development/core/datetime/native-date-adapter.d.ts.map +1 -1
- package/development/core/datetime.js +28 -26
- package/development/core/decorators/host-attributes.d.ts +1 -1
- package/development/core/decorators/slot-state.d.ts +18 -0
- package/development/core/decorators/slot-state.d.ts.map +1 -0
- package/development/core/decorators.d.ts +1 -0
- package/development/core/decorators.d.ts.map +1 -1
- package/development/core/decorators.js +11 -2
- package/development/datepicker/common/datepicker-button.d.ts +5 -5
- package/development/datepicker/common/datepicker-button.d.ts.map +1 -1
- package/development/datepicker/common.js +10 -9
- package/development/datepicker/datepicker/datepicker.d.ts +55 -38
- package/development/datepicker/datepicker/datepicker.d.ts.map +1 -1
- package/development/datepicker/datepicker-next-day/datepicker-next-day.d.ts +1 -1
- package/development/datepicker/datepicker-next-day/datepicker-next-day.d.ts.map +1 -1
- package/development/datepicker/datepicker-next-day.js +14 -54
- package/development/datepicker/datepicker-previous-day/datepicker-previous-day.d.ts +1 -1
- package/development/datepicker/datepicker-previous-day/datepicker-previous-day.d.ts.map +1 -1
- package/development/datepicker/datepicker-previous-day.js +14 -54
- package/development/datepicker/datepicker-toggle/datepicker-toggle.d.ts +1 -1
- package/development/datepicker/datepicker-toggle/datepicker-toggle.d.ts.map +1 -1
- package/development/datepicker/datepicker-toggle.js +16 -10
- package/development/datepicker/datepicker.js +134 -159
- package/development/dialog/dialog.js +1 -1
- package/development/file-selector/file-selector.d.ts +0 -1
- package/development/file-selector/file-selector.d.ts.map +1 -1
- package/development/file-selector.js +6 -5
- package/development/form-field/form-field/form-field.d.ts +1 -2
- package/development/form-field/form-field/form-field.d.ts.map +1 -1
- package/development/form-field/form-field-clear/form-field-clear.d.ts.map +1 -1
- package/development/form-field/form-field-clear.js +15 -51
- package/development/form-field/form-field.js +8 -7
- package/development/link/common/link-common.d.ts.map +1 -1
- package/development/link/common.js +6 -7
- package/development/link-list/link-list.d.ts +0 -1
- package/development/link-list/link-list.d.ts.map +1 -1
- package/development/link-list.js +5 -5
- package/development/map-container.js +5 -2
- package/development/navigation/navigation-list/navigation-list.d.ts +0 -1
- package/development/navigation/navigation-list/navigation-list.d.ts.map +1 -1
- package/development/navigation/navigation-list.js +5 -5
- package/development/navigation/navigation-section/navigation-section.d.ts +0 -1
- package/development/navigation/navigation-section/navigation-section.d.ts.map +1 -1
- package/development/navigation/navigation-section.js +6 -6
- package/development/notification/notification.d.ts +5 -16
- package/development/notification/notification.d.ts.map +1 -1
- package/development/notification.js +8 -9
- package/development/option/option/option.d.ts.map +1 -1
- package/development/option/option.js +5 -5
- package/development/popover/popover/popover.d.ts +3 -1
- package/development/popover/popover/popover.d.ts.map +1 -1
- package/development/popover/popover-trigger.js +14 -49
- package/development/popover/popover.js +11 -4
- package/development/radio-button/radio-button/radio-button.d.ts +0 -1
- package/development/radio-button/radio-button/radio-button.d.ts.map +1 -1
- package/development/radio-button/radio-button-group/radio-button-group.d.ts +0 -1
- package/development/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
- package/development/radio-button/radio-button-group.js +6 -6
- package/development/radio-button/radio-button-panel/radio-button-panel.d.ts +0 -1
- package/development/radio-button/radio-button-panel/radio-button-panel.d.ts.map +1 -1
- package/development/radio-button/radio-button-panel.js +4 -7
- package/development/radio-button/radio-button.js +4 -7
- package/development/selection-expansion-panel/selection-expansion-panel.d.ts +0 -1
- package/development/selection-expansion-panel/selection-expansion-panel.d.ts.map +1 -1
- package/development/selection-expansion-panel.js +6 -5
- package/development/skiplink-list/skiplink-list.d.ts +0 -1
- package/development/skiplink-list/skiplink-list.d.ts.map +1 -1
- package/development/skiplink-list.js +5 -5
- package/development/status/status.d.ts +0 -1
- package/development/status/status.d.ts.map +1 -1
- package/development/status.js +5 -5
- package/development/stepper/stepper/stepper.d.ts +3 -1
- package/development/stepper/stepper/stepper.d.ts.map +1 -1
- package/development/stepper/stepper.js +3 -2
- package/development/tabs/tab-group/tab-group.d.ts +3 -1
- package/development/tabs/tab-group/tab-group.d.ts.map +1 -1
- package/development/tabs/tab-group.js +3 -2
- package/development/tabs/tab-label/tab-label.d.ts +0 -1
- package/development/tabs/tab-label/tab-label.d.ts.map +1 -1
- package/development/tabs/tab-label.js +5 -5
- package/development/tag/tag/tag.d.ts +0 -1
- package/development/tag/tag/tag.d.ts.map +1 -1
- package/development/tag/tag.js +6 -5
- package/development/teaser/teaser.d.ts +0 -1
- package/development/teaser/teaser.d.ts.map +1 -1
- package/development/teaser.js +5 -5
- package/development/toast/toast.d.ts +1 -2
- package/development/toast/toast.d.ts.map +1 -1
- package/development/toast.js +10 -8
- package/development/toggle/toggle-option/toggle-option.d.ts +0 -1
- package/development/toggle/toggle-option/toggle-option.d.ts.map +1 -1
- package/development/toggle/toggle-option.js +6 -6
- package/development/toggle-check/toggle-check.d.ts +0 -1
- package/development/toggle-check/toggle-check.d.ts.map +1 -1
- package/development/toggle-check.js +5 -5
- package/dialog/dialog.js +1 -1
- package/file-selector/file-selector.d.ts +0 -1
- package/file-selector/file-selector.d.ts.map +1 -1
- package/file-selector.js +17 -15
- package/form-field/form-field/form-field.d.ts +1 -2
- package/form-field/form-field/form-field.d.ts.map +1 -1
- package/form-field/form-field-clear/form-field-clear.d.ts.map +1 -1
- package/form-field/form-field-clear.js +17 -18
- package/form-field/form-field.js +16 -14
- package/link/common/link-common.d.ts.map +1 -1
- package/link/common.js +9 -9
- package/link-list/link-list.d.ts +0 -1
- package/link-list/link-list.d.ts.map +1 -1
- package/link-list.js +8 -7
- package/map-container.js +1 -1
- package/navigation/navigation-list/navigation-list.d.ts +0 -1
- package/navigation/navigation-list/navigation-list.d.ts.map +1 -1
- package/navigation/navigation-list.js +9 -8
- package/navigation/navigation-section/navigation-section.d.ts +0 -1
- package/navigation/navigation-section/navigation-section.d.ts.map +1 -1
- package/navigation/navigation-section.js +10 -9
- package/notification/notification.d.ts +5 -16
- package/notification/notification.d.ts.map +1 -1
- package/notification.js +9 -9
- package/option/option/option.d.ts.map +1 -1
- package/option/option.js +6 -5
- package/package.json +1 -1
- package/popover/popover/popover.d.ts +3 -1
- package/popover/popover/popover.d.ts.map +1 -1
- package/popover/popover-trigger.js +13 -13
- package/popover/popover.js +55 -48
- package/radio-button/radio-button/radio-button.d.ts +0 -1
- package/radio-button/radio-button/radio-button.d.ts.map +1 -1
- package/radio-button/radio-button-group/radio-button-group.d.ts +0 -1
- package/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
- package/radio-button/radio-button-group.js +7 -6
- package/radio-button/radio-button-panel/radio-button-panel.d.ts +0 -1
- package/radio-button/radio-button-panel/radio-button-panel.d.ts.map +1 -1
- package/radio-button/radio-button-panel.js +12 -14
- package/radio-button/radio-button.js +7 -9
- package/selection-expansion-panel/selection-expansion-panel.d.ts +0 -1
- package/selection-expansion-panel/selection-expansion-panel.d.ts.map +1 -1
- package/selection-expansion-panel.js +15 -13
- package/skiplink-list/skiplink-list.d.ts +0 -1
- package/skiplink-list/skiplink-list.d.ts.map +1 -1
- package/skiplink-list.js +4 -3
- package/status/status.d.ts +0 -1
- package/status/status.d.ts.map +1 -1
- package/status.js +9 -8
- package/stepper/stepper/stepper.d.ts +3 -1
- package/stepper/stepper/stepper.d.ts.map +1 -1
- package/stepper/stepper.js +7 -6
- package/tabs/tab-group/tab-group.d.ts +3 -1
- package/tabs/tab-group/tab-group.d.ts.map +1 -1
- package/tabs/tab-group.js +14 -13
- package/tabs/tab-label/tab-label.d.ts +0 -1
- package/tabs/tab-label/tab-label.d.ts.map +1 -1
- package/tabs/tab-label.js +4 -3
- package/tag/tag/tag.d.ts +0 -1
- package/tag/tag/tag.d.ts.map +1 -1
- package/tag/tag.js +6 -4
- package/teaser/teaser.d.ts +0 -1
- package/teaser/teaser.d.ts.map +1 -1
- package/teaser.js +4 -3
- package/toast/toast.d.ts +1 -2
- package/toast/toast.d.ts.map +1 -1
- package/toast.js +15 -12
- package/toggle/toggle-option/toggle-option.d.ts +0 -1
- package/toggle/toggle-option/toggle-option.d.ts.map +1 -1
- package/toggle/toggle-option.js +12 -11
- package/toggle-check/toggle-check.d.ts +0 -1
- package/toggle-check/toggle-check.d.ts.map +1 -1
- package/toggle-check.js +4 -3
|
@@ -48,12 +48,10 @@ var __decorateClass = (decorators, target, key, kind) => {
|
|
|
48
48
|
if (kind && result) __defProp(target, key, result);
|
|
49
49
|
return result;
|
|
50
50
|
};
|
|
51
|
-
const FORMAT_DATE = /(^0?[1-9]?|[12]?[0-9]?|3?[01]?)[.,\\/\-\s](0?[1-9]?|1?[0-2]?)?[.,\\/\-\s](\d{1,4}$)?/;
|
|
52
51
|
function getDatePicker(element, trigger) {
|
|
53
|
-
var _a;
|
|
52
|
+
var _a, _b;
|
|
54
53
|
if (!trigger) {
|
|
55
|
-
|
|
56
|
-
return parent == null ? void 0 : parent.querySelector("sbb-datepicker");
|
|
54
|
+
return (_b = (_a = element.closest) == null ? void 0 : _a.call(element, "sbb-form-field")) == null ? void 0 : _b.querySelector("sbb-datepicker");
|
|
57
55
|
}
|
|
58
56
|
return findReferencedElement(trigger);
|
|
59
57
|
}
|
|
@@ -83,7 +81,8 @@ function findNextAvailableDate(date, dateFilter, dateAdapter, max) {
|
|
|
83
81
|
return date;
|
|
84
82
|
}
|
|
85
83
|
function isDateAvailable(date, dateFilter, min, max) {
|
|
86
|
-
|
|
84
|
+
var _a;
|
|
85
|
+
const dateAdapter = ((_a = readConfig().datetime) == null ? void 0 : _a.dateAdapter) ?? defaultDateAdapter;
|
|
87
86
|
const dateMin = dateAdapter.deserialize(min);
|
|
88
87
|
const dateMax = dateAdapter.deserialize(max);
|
|
89
88
|
if (dateAdapter.isValid(dateMin) && dateAdapter.compareDate(date, dateMin) < 0 || dateAdapter.isValid(dateMax) && dateAdapter.compareDate(date, dateMax) > 0) {
|
|
@@ -101,7 +100,6 @@ let SbbDatepickerElement = class extends LitElement {
|
|
|
101
100
|
super(...arguments);
|
|
102
101
|
this.wide = false;
|
|
103
102
|
this.dateFilter = () => true;
|
|
104
|
-
this._now = null;
|
|
105
103
|
this._didChange = new EventEmitter(this, SbbDatepickerElement.events.didChange, {
|
|
106
104
|
bubbles: true,
|
|
107
105
|
cancelable: true
|
|
@@ -126,16 +124,24 @@ let SbbDatepickerElement = class extends LitElement {
|
|
|
126
124
|
this,
|
|
127
125
|
SbbDatepickerElement.events.validationChange
|
|
128
126
|
);
|
|
129
|
-
this.
|
|
130
|
-
this.
|
|
127
|
+
this._inputElement = null;
|
|
128
|
+
this._inputElementPlaceholderMutable = false;
|
|
129
|
+
this._inputObserver = new AgnosticMutationObserver((mutationsList) => {
|
|
130
|
+
this._emitInputUpdated();
|
|
131
|
+
if (this._inputElement && (mutationsList == null ? void 0 : mutationsList.some((e) => e.attributeName === "value"))) {
|
|
132
|
+
const value = this._inputElement.getAttribute("value");
|
|
133
|
+
this.valueAsDate = this._dateAdapter.parse(value, this.now) ?? value;
|
|
134
|
+
}
|
|
135
|
+
});
|
|
131
136
|
this._dateAdapter = ((_a = readConfig().datetime) == null ? void 0 : _a.dateAdapter) ?? defaultDateAdapter;
|
|
132
137
|
this._abort = new SbbConnectedAbortController(this);
|
|
133
138
|
this._language = new SbbLanguageController(this).withHandler(() => {
|
|
134
139
|
if (this._inputElement) {
|
|
135
|
-
this.
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
140
|
+
if (this._inputElementPlaceholderMutable) {
|
|
141
|
+
this._inputElement.placeholder = i18nDatePickerPlaceholder[this._language.current];
|
|
142
|
+
}
|
|
143
|
+
if (this.valueAsDate) {
|
|
144
|
+
this._inputElement.value = this._format(this.valueAsDate);
|
|
139
145
|
}
|
|
140
146
|
}
|
|
141
147
|
});
|
|
@@ -146,107 +152,36 @@ let SbbDatepickerElement = class extends LitElement {
|
|
|
146
152
|
get now() {
|
|
147
153
|
return this._now ?? this._dateAdapter.today();
|
|
148
154
|
}
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
set _inputElement(value) {
|
|
153
|
-
const oldValue = this._inputElementState;
|
|
154
|
-
this._inputElementState = value;
|
|
155
|
-
this._registerInputElement(this._inputElementState, oldValue);
|
|
156
|
-
}
|
|
157
|
-
_findInput(newValue, oldValue) {
|
|
158
|
-
if (newValue !== oldValue) {
|
|
159
|
-
this._inputElement = findInput(this, this.input);
|
|
160
|
-
}
|
|
161
|
-
}
|
|
162
|
-
_registerInputElement(newValue, oldValue) {
|
|
163
|
-
var _a, _b;
|
|
164
|
-
if (newValue !== oldValue) {
|
|
165
|
-
(_a = this._datePickerController) == null ? void 0 : _a.abort();
|
|
166
|
-
this._datePickerController = new AbortController();
|
|
167
|
-
if (!this._inputElement) {
|
|
168
|
-
return;
|
|
169
|
-
}
|
|
170
|
-
(_b = this._inputObserver) == null ? void 0 : _b.disconnect();
|
|
171
|
-
this._inputObserver.observe(this._inputElement, {
|
|
172
|
-
attributeFilter: ["disabled", "readonly", "min", "max", "value"]
|
|
173
|
-
});
|
|
174
|
-
this._inputElement.type = "text";
|
|
175
|
-
if (!this._inputElement.placeholder) {
|
|
176
|
-
this._inputElement.placeholder = i18nDatePickerPlaceholder[this._language.current];
|
|
177
|
-
}
|
|
178
|
-
this._inputElement.addEventListener(
|
|
179
|
-
"change",
|
|
180
|
-
(event) => {
|
|
181
|
-
if (!(event instanceof CustomEvent)) {
|
|
182
|
-
this._valueChanged(event);
|
|
183
|
-
}
|
|
184
|
-
},
|
|
185
|
-
{
|
|
186
|
-
signal: this._datePickerController.signal
|
|
187
|
-
}
|
|
188
|
-
);
|
|
189
|
-
}
|
|
190
|
-
}
|
|
191
|
-
/** Gets the input value with the correct date format. */
|
|
192
|
-
getValueAsDate() {
|
|
193
|
-
if (this._inputElement && this._inputElement.value) {
|
|
194
|
-
return this._parse(this._inputElement.value);
|
|
195
|
-
}
|
|
196
|
-
return void 0;
|
|
197
|
-
}
|
|
198
|
-
/** Set the input value to the correctly formatted value. */
|
|
199
|
-
setValueAsDate(date) {
|
|
200
|
-
const parsedDate = date instanceof Date ? date : new Date(date);
|
|
201
|
-
if (this._inputElement) {
|
|
202
|
-
this._formatAndUpdateValue(this._inputElement.value, parsedDate);
|
|
155
|
+
set valueAsDate(value) {
|
|
156
|
+
this._valueAsDate = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));
|
|
157
|
+
if (this._tryApplyFormatToInput()) {
|
|
203
158
|
this._inputElement.dispatchEvent(new Event("blur", { composed: true }));
|
|
204
159
|
}
|
|
205
160
|
}
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
* Whether a custom now is configured.
|
|
209
|
-
*/
|
|
210
|
-
hasCustomNow() {
|
|
211
|
-
return !!this._now;
|
|
212
|
-
}
|
|
213
|
-
_onInputPropertiesChange(mutationsList) {
|
|
214
|
-
var _a, _b, _c, _d;
|
|
215
|
-
this._inputUpdated.emit({
|
|
216
|
-
disabled: (_a = this._inputElement) == null ? void 0 : _a.disabled,
|
|
217
|
-
readonly: (_b = this._inputElement) == null ? void 0 : _b.readOnly,
|
|
218
|
-
min: (_c = this._inputElement) == null ? void 0 : _c.min,
|
|
219
|
-
max: (_d = this._inputElement) == null ? void 0 : _d.max
|
|
220
|
-
});
|
|
221
|
-
if (this._inputElement && mutationsList && Array.from(mutationsList).some((e) => e.attributeName === "value")) {
|
|
222
|
-
this._inputElement.value = this._getValidValue(this._inputElement.getAttribute("value"));
|
|
223
|
-
}
|
|
161
|
+
get valueAsDate() {
|
|
162
|
+
return this._valueAsDate ?? null;
|
|
224
163
|
}
|
|
225
164
|
connectedCallback() {
|
|
226
165
|
super.connectedCallback();
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
signal
|
|
166
|
+
this.addEventListener("datepickerControlRegistered", () => this._emitInputUpdated(), {
|
|
167
|
+
signal: this._abort.signal
|
|
230
168
|
});
|
|
231
|
-
this.
|
|
169
|
+
this._attachInput();
|
|
232
170
|
if (this._inputElement) {
|
|
233
|
-
this.
|
|
234
|
-
this._inputUpdated.emit({
|
|
235
|
-
disabled: this._inputElement.disabled,
|
|
236
|
-
readonly: this._inputElement.readOnly,
|
|
237
|
-
min: this._inputElement.min,
|
|
238
|
-
max: this._inputElement.max
|
|
239
|
-
});
|
|
171
|
+
this._emitInputUpdated();
|
|
240
172
|
}
|
|
241
173
|
}
|
|
242
174
|
willUpdate(changedProperties) {
|
|
243
175
|
super.willUpdate(changedProperties);
|
|
244
176
|
if (changedProperties.has("input")) {
|
|
245
|
-
this.
|
|
177
|
+
this._attachInput();
|
|
246
178
|
}
|
|
247
179
|
if (changedProperties.has("wide") || changedProperties.has("dateFilter") || changedProperties.has("now")) {
|
|
248
180
|
this._datePickerUpdated.emit();
|
|
249
181
|
}
|
|
182
|
+
if (changedProperties.has("valueAsDate")) {
|
|
183
|
+
this._setAriaLiveMessage();
|
|
184
|
+
}
|
|
250
185
|
}
|
|
251
186
|
disconnectedCallback() {
|
|
252
187
|
var _a, _b;
|
|
@@ -256,86 +191,123 @@ let SbbDatepickerElement = class extends LitElement {
|
|
|
256
191
|
}
|
|
257
192
|
firstUpdated(changedProperties) {
|
|
258
193
|
super.firstUpdated(changedProperties);
|
|
259
|
-
this._setAriaLiveMessage(
|
|
194
|
+
this._setAriaLiveMessage();
|
|
260
195
|
}
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
196
|
+
/**
|
|
197
|
+
* Gets the input value with the correct date format.
|
|
198
|
+
* @deprecated Use property valueAsDate instead.
|
|
199
|
+
*/
|
|
200
|
+
getValueAsDate() {
|
|
201
|
+
return this.valueAsDate ?? void 0;
|
|
264
202
|
}
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
203
|
+
/**
|
|
204
|
+
* Set the input value to the correctly formatted value.
|
|
205
|
+
* @deprecated Use property valueAsDate instead.
|
|
206
|
+
*/
|
|
207
|
+
setValueAsDate(date) {
|
|
208
|
+
this.valueAsDate = date;
|
|
268
209
|
}
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
210
|
+
/**
|
|
211
|
+
* @internal
|
|
212
|
+
* Whether a custom now is configured.
|
|
213
|
+
*/
|
|
214
|
+
hasCustomNow() {
|
|
215
|
+
return !!this._now;
|
|
272
216
|
}
|
|
273
|
-
|
|
274
|
-
_formatAndUpdateValue(value, valueAsDate) {
|
|
217
|
+
_attachInput() {
|
|
275
218
|
var _a, _b;
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
this.
|
|
286
|
-
|
|
287
|
-
|
|
219
|
+
const input = findInput(this, this.input);
|
|
220
|
+
if (this._inputElement === input) {
|
|
221
|
+
return;
|
|
222
|
+
} else if (this._inputElement) {
|
|
223
|
+
(_a = this._datePickerController) == null ? void 0 : _a.abort();
|
|
224
|
+
(_b = this._inputObserver) == null ? void 0 : _b.disconnect();
|
|
225
|
+
}
|
|
226
|
+
this._inputElement = input;
|
|
227
|
+
if (input) {
|
|
228
|
+
this._datePickerController = new AbortController();
|
|
229
|
+
this._inputObserver.observe(input, {
|
|
230
|
+
attributeFilter: ["disabled", "readonly", "min", "max", "value"]
|
|
231
|
+
});
|
|
232
|
+
this._inputElementPlaceholderMutable = !input.placeholder;
|
|
233
|
+
input.type = "text";
|
|
234
|
+
if (this._inputElementPlaceholderMutable) {
|
|
235
|
+
input.placeholder = i18nDatePickerPlaceholder[this._language.current];
|
|
288
236
|
}
|
|
289
|
-
this.
|
|
237
|
+
const options = { signal: this._datePickerController.signal };
|
|
238
|
+
input.addEventListener("input", () => this._parseInput(), options);
|
|
239
|
+
input.addEventListener("change", () => this._handleInputChange(), options);
|
|
240
|
+
this._parseInput(true);
|
|
241
|
+
this._tryApplyFormatToInput();
|
|
242
|
+
this._validateDate();
|
|
290
243
|
}
|
|
291
244
|
}
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
this.
|
|
245
|
+
_emitInputUpdated() {
|
|
246
|
+
const { disabled, readOnly: readonly, min, max } = this._inputElement ?? {};
|
|
247
|
+
this._inputUpdated.emit({ disabled, readonly, min, max });
|
|
248
|
+
}
|
|
249
|
+
_handleInputChange() {
|
|
250
|
+
if (this._tryApplyFormatToInput()) {
|
|
251
|
+
return;
|
|
252
|
+
}
|
|
253
|
+
this._validateDate();
|
|
254
|
+
this._setAriaLiveMessage();
|
|
295
255
|
this._change.emit();
|
|
296
256
|
this._didChange.emit();
|
|
297
|
-
|
|
257
|
+
}
|
|
258
|
+
_tryApplyFormatToInput() {
|
|
259
|
+
if (!this._inputElement) {
|
|
260
|
+
return false;
|
|
261
|
+
}
|
|
262
|
+
const formattedDate = this.valueAsDate ? this._format(this.valueAsDate) : "";
|
|
263
|
+
if (formattedDate && this._inputElement.value !== formattedDate) {
|
|
264
|
+
this._inputElement.value = formattedDate;
|
|
298
265
|
this._inputElement.dispatchEvent(new InputEvent("input", { bubbles: true, composed: true }));
|
|
299
|
-
this._inputElement.dispatchEvent(
|
|
300
|
-
|
|
301
|
-
);
|
|
266
|
+
this._inputElement.dispatchEvent(new Event("change", { bubbles: true, composed: true }));
|
|
267
|
+
return true;
|
|
302
268
|
}
|
|
269
|
+
return false;
|
|
303
270
|
}
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
271
|
+
_validateDate() {
|
|
272
|
+
var _a, _b;
|
|
273
|
+
if (!this._inputElement) {
|
|
274
|
+
return;
|
|
307
275
|
}
|
|
308
|
-
const
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
276
|
+
const isEmptyOrValid = !this._inputElement.value || !!this.valueAsDate && isDateAvailable(
|
|
277
|
+
this.valueAsDate,
|
|
278
|
+
this.dateFilter,
|
|
279
|
+
(_a = this._inputElement) == null ? void 0 : _a.min,
|
|
280
|
+
(_b = this._inputElement) == null ? void 0 : _b.max
|
|
281
|
+
);
|
|
282
|
+
const wasValid = !this._inputElement.hasAttribute("data-sbb-invalid");
|
|
283
|
+
this._inputElement.toggleAttribute("data-sbb-invalid", !isEmptyOrValid);
|
|
284
|
+
if (wasValid !== isEmptyOrValid) {
|
|
285
|
+
this._validationChange.emit({ valid: isEmptyOrValid });
|
|
315
286
|
}
|
|
316
|
-
return value;
|
|
317
287
|
}
|
|
318
|
-
|
|
319
|
-
|
|
288
|
+
_parseInput(deserializeAsFallback = false) {
|
|
289
|
+
const value = this._inputElement.value;
|
|
290
|
+
const parse = this.dateParser ?? ((v) => this._dateAdapter.parse(v, this.now));
|
|
291
|
+
this._valueAsDate = this._dateAdapter.getValidDateOrNull(parse(value));
|
|
292
|
+
if (deserializeAsFallback && !this._valueAsDate) {
|
|
293
|
+
this._valueAsDate = this._dateAdapter.getValidDateOrNull(
|
|
294
|
+
this._dateAdapter.deserialize(value)
|
|
295
|
+
);
|
|
296
|
+
}
|
|
320
297
|
}
|
|
321
298
|
_format(date) {
|
|
322
299
|
return this.format ? this.format(date) : this._dateAdapter.format(date);
|
|
323
300
|
}
|
|
324
|
-
_setAriaLiveMessage(
|
|
301
|
+
_setAriaLiveMessage() {
|
|
325
302
|
var _a, _b;
|
|
326
|
-
const ariaLiveFormatter = new Intl.DateTimeFormat(`${this._language.current}-CH`, {
|
|
327
|
-
weekday: "long"
|
|
328
|
-
});
|
|
329
|
-
const dateFormatter = new Intl.DateTimeFormat("de-CH", {
|
|
330
|
-
day: "2-digit",
|
|
331
|
-
month: "2-digit",
|
|
332
|
-
year: "numeric"
|
|
333
|
-
});
|
|
334
303
|
const containerElement = (_b = (_a = this.shadowRoot) == null ? void 0 : _a.querySelector) == null ? void 0 : _b.call(_a, "#status-container");
|
|
335
|
-
if (containerElement) {
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
304
|
+
if (!containerElement) {
|
|
305
|
+
return;
|
|
306
|
+
} else if (!this.valueAsDate) {
|
|
307
|
+
containerElement.innerText = "";
|
|
308
|
+
} else {
|
|
309
|
+
const date = this._dateAdapter.format(this.valueAsDate, { weekdayStyle: "long" });
|
|
310
|
+
containerElement.innerText = `${i18nDateChangedTo[this._language.current]} ${date}`;
|
|
339
311
|
}
|
|
340
312
|
}
|
|
341
313
|
render() {
|
|
@@ -354,13 +326,13 @@ __decorateClass([
|
|
|
354
326
|
property({ type: Boolean })
|
|
355
327
|
], SbbDatepickerElement.prototype, "wide", 2);
|
|
356
328
|
__decorateClass([
|
|
357
|
-
property({ attribute:
|
|
329
|
+
property({ attribute: false })
|
|
358
330
|
], SbbDatepickerElement.prototype, "dateFilter", 2);
|
|
359
331
|
__decorateClass([
|
|
360
|
-
property({ attribute:
|
|
332
|
+
property({ attribute: false })
|
|
361
333
|
], SbbDatepickerElement.prototype, "dateParser", 2);
|
|
362
334
|
__decorateClass([
|
|
363
|
-
property()
|
|
335
|
+
property({ attribute: false })
|
|
364
336
|
], SbbDatepickerElement.prototype, "format", 2);
|
|
365
337
|
__decorateClass([
|
|
366
338
|
property()
|
|
@@ -368,9 +340,12 @@ __decorateClass([
|
|
|
368
340
|
__decorateClass([
|
|
369
341
|
property()
|
|
370
342
|
], SbbDatepickerElement.prototype, "now", 1);
|
|
343
|
+
__decorateClass([
|
|
344
|
+
property({ attribute: false })
|
|
345
|
+
], SbbDatepickerElement.prototype, "valueAsDate", 1);
|
|
371
346
|
__decorateClass([
|
|
372
347
|
state()
|
|
373
|
-
], SbbDatepickerElement.prototype, "_inputElement",
|
|
348
|
+
], SbbDatepickerElement.prototype, "_inputElement", 2);
|
|
374
349
|
SbbDatepickerElement = __decorateClass([
|
|
375
350
|
customElement("sbb-datepicker")
|
|
376
351
|
], SbbDatepickerElement);
|
|
@@ -383,4 +358,4 @@ export {
|
|
|
383
358
|
getDatePicker,
|
|
384
359
|
isDateAvailable
|
|
385
360
|
};
|
|
386
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"datepicker.js","sources":["../../../../src/elements/datepicker/datepicker/datepicker.ts"],"sourcesContent":["import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, LitElement } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\n\nimport { readConfig } from '../../core/config.js';\nimport { SbbConnectedAbortController, SbbLanguageController } from '../../core/controllers.js';\nimport { type DateAdapter, defaultDateAdapter } from '../../core/datetime.js';\nimport { findInput, findReferencedElement } from '../../core/dom.js';\nimport { EventEmitter } from '../../core/eventing.js';\nimport { i18nDateChangedTo, i18nDatePickerPlaceholder } from '../../core/i18n.js';\nimport type { SbbDateLike, SbbValidationChangeEvent } from '../../core/interfaces.js';\nimport { AgnosticMutationObserver } from '../../core/observers.js';\nimport type { SbbDatepickerButton } from '../common.js';\nimport type { SbbDatepickerToggleElement } from '../datepicker-toggle.js';\n\nimport style from './datepicker.scss?lit&inline';\n\nconst FORMAT_DATE =\n  /(^0?[1-9]?|[12]?[0-9]?|3?[01]?)[.,\\\\/\\-\\s](0?[1-9]?|1?[0-2]?)?[.,\\\\/\\-\\s](\\d{1,4}$)?/;\n\nexport interface SbbInputUpdateEvent {\n  disabled?: boolean;\n  readonly?: boolean;\n  min?: string | number;\n  max?: string | number;\n}\n\n/**\n * Given a SbbDatepickerPreviousDayElement, a SbbDatepickerNextDayElement or a SbbDatepickerToggleElement component,\n * it returns the related SbbDatepickerElement reference, if exists.\n * @param element The element potentially connected to the SbbDatepickerElement.\n * @param trigger The id or the reference of the SbbDatePicker.\n */\nexport function getDatePicker(\n  element: SbbDatepickerButton | SbbDatepickerToggleElement,\n  trigger?: string | HTMLElement,\n): SbbDatepickerElement | null | undefined {\n  if (!trigger) {\n    const parent = element.closest?.('sbb-form-field');\n    return parent?.querySelector('sbb-datepicker');\n  }\n\n  return findReferencedElement<SbbDatepickerElement>(trigger);\n}\n\n/**\n * Returns the first available date before or after a given one, considering the SbbDatepickerElement `dateFilter` property.\n * @param date The starting date for calculations.\n * @param delta The number of days to add/subtract from the starting one.\n * @param dateFilter The dateFilter function from the SbbDatepickerElement.\n * @param dateAdapter The adapter class.\n */\nexport function getAvailableDate(\n  date: Date,\n  delta: number,\n  dateFilter: ((date: Date) => boolean) | null,\n  dateAdapter: DateAdapter<Date>,\n): Date {\n  let availableDate = dateAdapter.addCalendarDays(date, delta);\n\n  if (dateFilter) {\n    while (!dateFilter(availableDate)) {\n      availableDate = dateAdapter.addCalendarDays(availableDate, delta);\n    }\n  }\n\n  return availableDate;\n}\n\n/**\n * Calculates the first available date before the given one,\n * considering the SbbDatepickerElement `dateFilter` property and `min` parameter (e.g. from the self-named input's attribute).\n * @param date The starting date for calculations.\n * @param dateFilter The dateFilter function from the SbbDatepickerElement.\n * @param dateAdapter The adapter class.\n * @param min The minimum value to consider in calculations.\n */\nexport function findPreviousAvailableDate(\n  date: Date,\n  dateFilter: ((date: Date) => boolean) | null,\n  dateAdapter: DateAdapter<Date>,\n  min: string | number | null,\n): Date {\n  const previousDate = getAvailableDate(date, -1, dateFilter, dateAdapter);\n  const dateMin = dateAdapter.deserialize(min);\n\n  if (\n    !dateMin ||\n    (dateAdapter.isValid(dateMin) && dateAdapter.compareDate(previousDate, dateMin) >= 0)\n  ) {\n    return previousDate;\n  }\n  return date;\n}\n\n/**\n * Calculates the first available date after the given one,\n * considering the SbbDatepickerElement `dateFilter` property and `max` parameter (e.g. from the self-named input's attribute).\n * @param date The starting date for calculations.\n * @param dateFilter The dateFilter function from the SbbDatepickerElement.\n * @param dateAdapter The adapter class.\n * @param max The maximum value to consider in calculations.\n */\nexport function findNextAvailableDate(\n  date: Date,\n  dateFilter: ((date: Date) => boolean) | null,\n  dateAdapter: DateAdapter<Date>,\n  max: string | number | null,\n): Date {\n  const nextDate = getAvailableDate(date, 1, dateFilter, dateAdapter);\n  const dateMax = dateAdapter.deserialize(max);\n\n  if (\n    !dateMax ||\n    (dateAdapter.isValid(dateMax) && dateAdapter.compareDate(nextDate, dateMax) <= 0)\n  ) {\n    return nextDate;\n  }\n  return date;\n}\n\n/**\n * Checks if the provided date is a valid one, considering the SbbDatepickerElement `dateFilter` property\n * and `min` and `max` parameters (e.g. from the self-named input's attributes).\n * @param date The starting date for calculations.\n * @param dateFilter The dateFilter function from the SbbDatepickerElement.\n * @param min The minimum value to consider in calculations.\n * @param max The maximum value to consider in calculations.\n */\nexport function isDateAvailable(\n  date: Date,\n  dateFilter: ((date: Date) => boolean) | null,\n  min: string | number | null | undefined,\n  max: string | number | null | undefined,\n): boolean {\n  // TODO: Get date adapter from config\n  const dateAdapter: DateAdapter<Date> = defaultDateAdapter;\n  const dateMin = dateAdapter.deserialize(min);\n  const dateMax = dateAdapter.deserialize(max);\n\n  if (\n    (dateAdapter.isValid(dateMin) && dateAdapter.compareDate(date, dateMin!) < 0) ||\n    (dateAdapter.isValid(dateMax) && dateAdapter.compareDate(date, dateMax!) > 0)\n  ) {\n    return false;\n  }\n\n  return dateFilter ? dateFilter(date) : true;\n}\n\nexport const datepickerControlRegisteredEventFactory = (): CustomEvent =>\n  new CustomEvent('datepickerControlRegistered', {\n    bubbles: false,\n    composed: true,\n  });\n\n/**\n * Combined with a native input, it displays the input's value as a formatted date.\n *\n * @event {CustomEvent<void>} didChange - Deprecated. used for React. Will probably be removed once React 19 is available.\n * @event {CustomEvent<void>} change - Notifies that the connected input has changes.\n * @event {CustomEvent<SbbInputUpdateEvent>} inputUpdated - Notifies that the attributes of the input connected to the datepicker have changes.\n * @event {CustomEvent<void>} datePickerUpdated - Notifies that the attributes of the datepicker have changes.\n * @event {CustomEvent<SbbValidationChangeEvent>} validationChange - Emits whenever the internal validation state changes.\n */\n@customElement('sbb-datepicker')\nexport class SbbDatepickerElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    didChange: 'didChange',\n    change: 'change',\n    inputUpdated: 'inputUpdated',\n    datePickerUpdated: 'datePickerUpdated',\n    validationChange: 'validationChange',\n  } as const;\n\n  /** If set to true, two months are displayed. */\n  @property({ type: Boolean }) public wide = false;\n\n  /** A function used to filter out dates. */\n  @property({ attribute: 'date-filter' }) public dateFilter: (date: Date | null) => boolean = () =>\n    true;\n\n  /** A function used to parse string value into dates. */\n  @property({ attribute: 'date-parser' }) public dateParser?: (value: string) => Date | undefined;\n\n  /** A function used to format dates into the preferred string format. */\n  @property() public format?: (date: Date) => string;\n\n  /** Reference of the native input connected to the datepicker. */\n  @property() public input?: string | HTMLElement;\n\n  /** A configured date which acts as the current date instead of the real current date. Recommended for testing purposes. */\n  @property()\n  public set now(value: SbbDateLike | undefined) {\n    this._now = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));\n  }\n  public get now(): Date {\n    return this._now ?? this._dateAdapter.today();\n  }\n  private _now: Date | null = null;\n\n  /**\n   * @deprecated only used for React. Will probably be removed once React 19 is available.\n   */\n  private _didChange: EventEmitter = new EventEmitter(this, SbbDatepickerElement.events.didChange, {\n    bubbles: true,\n    cancelable: true,\n  });\n\n  /** Notifies that the connected input has changes. */\n  private _change: EventEmitter = new EventEmitter(this, SbbDatepickerElement.events.change, {\n    bubbles: true,\n  });\n\n  /** Notifies that the attributes of the input connected to the datepicker have changes. */\n  private _inputUpdated: EventEmitter<SbbInputUpdateEvent> = new EventEmitter(\n    this,\n    SbbDatepickerElement.events.inputUpdated,\n    { bubbles: true, cancelable: true },\n  );\n\n  /** Notifies that the attributes of the datepicker have changes. */\n  private _datePickerUpdated: EventEmitter = new EventEmitter(\n    this,\n    SbbDatepickerElement.events.datePickerUpdated,\n    {\n      bubbles: true,\n      cancelable: true,\n    },\n  );\n\n  /** Emits whenever the internal validation state changes. */\n  private _validationChange: EventEmitter<SbbValidationChangeEvent> = new EventEmitter(\n    this,\n    SbbDatepickerElement.events.validationChange,\n  );\n\n  @state() private get _inputElement(): HTMLInputElement | null {\n    return this._inputElementState;\n  }\n\n  private set _inputElement(value) {\n    const oldValue = this._inputElementState;\n    this._inputElementState = value;\n    this._registerInputElement(this._inputElementState, oldValue);\n  }\n\n  private _inputElementState: HTMLInputElement | null = null;\n\n  private _findInput(newValue: string | HTMLElement, oldValue: string | HTMLElement): void {\n    if (newValue !== oldValue) {\n      this._inputElement = findInput(this, this.input);\n    }\n  }\n  private _registerInputElement(\n    newValue: HTMLInputElement | null,\n    oldValue: HTMLInputElement | null,\n  ): void {\n    if (newValue !== oldValue) {\n      this._datePickerController?.abort();\n      this._datePickerController = new AbortController();\n\n      if (!this._inputElement) {\n        return;\n      }\n\n      this._inputObserver?.disconnect();\n      this._inputObserver.observe(this._inputElement, {\n        attributeFilter: ['disabled', 'readonly', 'min', 'max', 'value'],\n      });\n\n      this._inputElement.type = 'text';\n\n      if (!this._inputElement.placeholder) {\n        this._inputElement.placeholder = i18nDatePickerPlaceholder[this._language.current];\n      }\n\n      this._inputElement.addEventListener(\n        'change',\n        (event: Event) => {\n          if (!(event instanceof CustomEvent)) {\n            this._valueChanged(event);\n          }\n        },\n        {\n          signal: this._datePickerController.signal,\n        },\n      );\n    }\n  }\n\n  /** Gets the input value with the correct date format. */\n  public getValueAsDate(): Date | undefined {\n    if (this._inputElement && this._inputElement.value) {\n      return this._parse(this._inputElement.value);\n    }\n    return undefined;\n  }\n\n  /** Set the input value to the correctly formatted value. */\n  public setValueAsDate(date: SbbDateLike): void {\n    const parsedDate = date instanceof Date ? date : new Date(date);\n    if (this._inputElement) {\n      this._formatAndUpdateValue(this._inputElement.value, parsedDate);\n      /* Emit blur event when value is changed programmatically to notify\n      frameworks that rely on that event to update form status. */\n      this._inputElement.dispatchEvent(new Event('blur', { composed: true }));\n    }\n  }\n\n  /**\n   * @internal\n   * Whether a custom now is configured.\n   */\n  public hasCustomNow(): boolean {\n    return !!this._now;\n  }\n\n  private _onInputPropertiesChange(mutationsList?: MutationRecord[]): void {\n    this._inputUpdated.emit({\n      disabled: this._inputElement?.disabled,\n      readonly: this._inputElement?.readOnly,\n      min: this._inputElement?.min,\n      max: this._inputElement?.max,\n    });\n\n    if (\n      this._inputElement &&\n      mutationsList &&\n      Array.from(mutationsList).some((e) => e.attributeName === 'value')\n    ) {\n      this._inputElement.value = this._getValidValue(this._inputElement.getAttribute('value')!);\n    }\n  }\n\n  private _datePickerController!: AbortController;\n\n  private _inputObserver = new AgnosticMutationObserver(this._onInputPropertiesChange.bind(this));\n\n  private _dateAdapter: DateAdapter<Date> =\n    readConfig().datetime?.dateAdapter ?? defaultDateAdapter;\n\n  private _abort = new SbbConnectedAbortController(this);\n  private _language = new SbbLanguageController(this).withHandler(() => {\n    if (this._inputElement) {\n      this._inputElement.placeholder = i18nDatePickerPlaceholder[this._language.current];\n      const valueAsDate = this.getValueAsDate();\n      if (valueAsDate) {\n        this._inputElement.value = this._format(valueAsDate);\n      }\n    }\n  });\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    const signal = this._abort.signal;\n    this.addEventListener('datepickerControlRegistered', () => this._onInputPropertiesChange(), {\n      signal,\n    });\n    this._inputElement = findInput(this, this.input);\n    if (this._inputElement) {\n      this._inputElement.value = this._getValidValue(this._inputElement.value);\n      this._inputUpdated.emit({\n        disabled: this._inputElement.disabled,\n        readonly: this._inputElement.readOnly,\n        min: this._inputElement.min,\n        max: this._inputElement.max,\n      });\n    }\n  }\n\n  public override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('input')) {\n      this._findInput(this.input!, changedProperties.get('input')!);\n    }\n    if (\n      changedProperties.has('wide') ||\n      changedProperties.has('dateFilter') ||\n      changedProperties.has('now')\n    ) {\n      this._datePickerUpdated.emit();\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._inputObserver?.disconnect();\n    this._datePickerController?.abort();\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n    this._setAriaLiveMessage(this.getValueAsDate());\n  }\n\n  private _parseAndFormatValue(value: string): string {\n    const d = this._parse(value);\n    return !this._dateAdapter.isValid(d) ? value : this._format(d!);\n  }\n\n  private _createAndComposeDate(value: SbbDateLike): string {\n    const date = new Date(value);\n    return this._format(date);\n  }\n\n  private _valueChanged(event: Event): void {\n    const value: string = (event.target as HTMLInputElement).value;\n    this._formatAndUpdateValue(value, this._parse(value));\n  }\n\n  /** Applies the correct format to values and triggers event dispatch. */\n  private _formatAndUpdateValue(value: string, valueAsDate: Date | null | undefined): void {\n    if (this._inputElement) {\n      this._inputElement.value = !this._dateAdapter.isValid(valueAsDate)\n        ? value\n        : this._format(valueAsDate!);\n\n      const isEmptyOrValid =\n        !value ||\n        (!!valueAsDate &&\n          isDateAvailable(\n            valueAsDate,\n            this.dateFilter,\n            this._inputElement?.min,\n            this._inputElement?.max,\n          ));\n      const wasValid = !this._inputElement.hasAttribute('data-sbb-invalid');\n      this._inputElement.toggleAttribute('data-sbb-invalid', !isEmptyOrValid);\n      if (wasValid !== isEmptyOrValid) {\n        this._validationChange.emit({ valid: isEmptyOrValid });\n      }\n      this._emitChange(valueAsDate!);\n    }\n  }\n\n  /** Emits the change event. */\n  private _emitChange(date: Date): void {\n    this._setAriaLiveMessage(date);\n\n    this._change.emit();\n    this._didChange.emit();\n\n    if (this._inputElement) {\n      this._inputElement.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n      this._inputElement.dispatchEvent(\n        new CustomEvent('change', { bubbles: true, composed: true }),\n      );\n    }\n  }\n\n  private _getValidValue(value: string): string {\n    if (!value) {\n      return '';\n    }\n\n    const match: RegExpMatchArray | null = value.match(FORMAT_DATE);\n\n    if (match?.index === 0) {\n      return this._parseAndFormatValue(value);\n    } else if (Number.isInteger(+value)) {\n      return this._createAndComposeDate(+value);\n    } else if (this._dateAdapter.isValid(new Date(value))) {\n      return this._createAndComposeDate(value);\n    }\n\n    return value;\n  }\n\n  private _parse(value: string): Date | undefined {\n    return this.dateParser ? this.dateParser(value) : this._dateAdapter.parse(value, this.now);\n  }\n\n  private _format(date: Date): string {\n    return this.format ? this.format(date) : this._dateAdapter.format(date);\n  }\n\n  private _setAriaLiveMessage(date?: Date): void {\n    const ariaLiveFormatter = new Intl.DateTimeFormat(`${this._language.current}-CH`, {\n      weekday: 'long',\n    });\n\n    const dateFormatter = new Intl.DateTimeFormat('de-CH', {\n      day: '2-digit',\n      month: '2-digit',\n      year: 'numeric',\n    });\n\n    const containerElement: HTMLParagraphElement | null | undefined =\n      this.shadowRoot?.querySelector?.<HTMLParagraphElement>('#status-container');\n\n    if (containerElement) {\n      containerElement.innerText = date\n        ? `${i18nDateChangedTo[this._language.current]} ${ariaLiveFormatter.format(\n            date,\n          )}, ${dateFormatter.format(date)}`\n        : '';\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return html`<p id=\"status-container\" role=\"status\"></p>`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-datepicker': SbbDatepickerElement;\n  }\n\n  interface GlobalEventHandlersEventMap {\n    inputUpdated: CustomEvent<SbbInputUpdateEvent>;\n  }\n}\n"],"names":[],"mappings":"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"}
|
|
361
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"datepicker.js","sources":["../../../../src/elements/datepicker/datepicker/datepicker.ts"],"sourcesContent":["import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, LitElement } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\n\nimport { readConfig } from '../../core/config.js';\nimport { SbbConnectedAbortController, SbbLanguageController } from '../../core/controllers.js';\nimport { type DateAdapter, defaultDateAdapter } from '../../core/datetime.js';\nimport { findInput, findReferencedElement } from '../../core/dom.js';\nimport { EventEmitter } from '../../core/eventing.js';\nimport { i18nDateChangedTo, i18nDatePickerPlaceholder } from '../../core/i18n.js';\nimport type { SbbDateLike, SbbValidationChangeEvent } from '../../core/interfaces.js';\nimport { AgnosticMutationObserver } from '../../core/observers.js';\nimport type { SbbDatepickerButton } from '../common.js';\nimport type { SbbDatepickerToggleElement } from '../datepicker-toggle.js';\n\nimport style from './datepicker.scss?lit&inline';\n\nexport interface SbbInputUpdateEvent {\n  disabled?: boolean;\n  readonly?: boolean;\n  min?: string | number;\n  max?: string | number;\n}\n\n// TODO(breaking-change): Inline deprecated functions in SbbDatepickerElement as public methods\n// where possible and use these methods where the functions are currently used.\n\n/**\n * Given a SbbDatepickerPreviousDayElement, a SbbDatepickerNextDayElement or a SbbDatepickerToggleElement component,\n * it returns the related SbbDatepickerElement reference, if exists.\n * @param element The element potentially connected to the SbbDatepickerElement.\n * @param trigger The id or the reference of the SbbDatePicker.\n */\nexport function getDatePicker<T = Date>(\n  element: SbbDatepickerButton<T> | SbbDatepickerToggleElement<T>,\n  trigger?: string | HTMLElement,\n): SbbDatepickerElement<T> | null | undefined {\n  if (!trigger) {\n    return element\n      .closest?.('sbb-form-field')\n      ?.querySelector<SbbDatepickerElement<T>>('sbb-datepicker');\n  }\n\n  return findReferencedElement<SbbDatepickerElement<T>>(trigger);\n}\n\n/**\n * Returns the first available date before or after a given one, considering the SbbDatepickerElement `dateFilter` property.\n * @param date The starting date for calculations.\n * @param delta The number of days to add/subtract from the starting one.\n * @param dateFilter The dateFilter function from the SbbDatepickerElement.\n * @param dateAdapter The adapter class.\n *\n * @deprecated Not intended as public API.\n */\nexport function getAvailableDate<T = Date>(\n  date: T,\n  delta: number,\n  dateFilter: ((date: T) => boolean) | null,\n  dateAdapter: DateAdapter<T>,\n): T {\n  let availableDate = dateAdapter.addCalendarDays(date, delta);\n\n  if (dateFilter) {\n    while (!dateFilter(availableDate)) {\n      availableDate = dateAdapter.addCalendarDays(availableDate, delta);\n    }\n  }\n\n  return availableDate;\n}\n\n/**\n * Calculates the first available date before the given one,\n * considering the SbbDatepickerElement `dateFilter` property and `min` parameter (e.g. from the self-named input's attribute).\n * @param date The starting date for calculations.\n * @param dateFilter The dateFilter function from the SbbDatepickerElement.\n * @param dateAdapter The adapter class.\n * @param min The minimum value to consider in calculations.\n *\n * @deprecated Not intended as public API.\n */\nexport function findPreviousAvailableDate<T = Date>(\n  date: T,\n  dateFilter: ((date: T) => boolean) | null,\n  dateAdapter: DateAdapter<T>,\n  min: string | number | null,\n): T {\n  const previousDate = getAvailableDate(date, -1, dateFilter, dateAdapter);\n  const dateMin = dateAdapter.deserialize(min);\n\n  if (\n    !dateMin ||\n    (dateAdapter.isValid(dateMin) && dateAdapter.compareDate(previousDate, dateMin) >= 0)\n  ) {\n    return previousDate;\n  }\n  return date;\n}\n\n/**\n * Calculates the first available date after the given one,\n * considering the SbbDatepickerElement `dateFilter` property and `max` parameter (e.g. from the self-named input's attribute).\n * @param date The starting date for calculations.\n * @param dateFilter The dateFilter function from the SbbDatepickerElement.\n * @param dateAdapter The adapter class.\n * @param max The maximum value to consider in calculations.\n *\n * @deprecated Not intended as public API.\n */\nexport function findNextAvailableDate<T = Date>(\n  date: T,\n  dateFilter: ((date: T) => boolean) | null,\n  dateAdapter: DateAdapter<T>,\n  max: string | number | null,\n): T {\n  const nextDate = getAvailableDate(date, 1, dateFilter, dateAdapter);\n  const dateMax = dateAdapter.deserialize(max);\n\n  if (\n    !dateMax ||\n    (dateAdapter.isValid(dateMax) && dateAdapter.compareDate(nextDate, dateMax) <= 0)\n  ) {\n    return nextDate;\n  }\n  return date;\n}\n\n/**\n * Checks if the provided date is a valid one, considering the SbbDatepickerElement `dateFilter` property\n * and `min` and `max` parameters (e.g. from the self-named input's attributes).\n * @param date The starting date for calculations.\n * @param dateFilter The dateFilter function from the SbbDatepickerElement.\n * @param min The minimum value to consider in calculations.\n * @param max The maximum value to consider in calculations.\n *\n * @deprecated Not intended as public API.\n */\nexport function isDateAvailable<T = Date>(\n  date: T,\n  dateFilter: ((date: T) => boolean) | null,\n  min: string | number | null | undefined,\n  max: string | number | null | undefined,\n): boolean {\n  // TODO: Get date adapter from config\n  const dateAdapter: DateAdapter<T> = readConfig().datetime?.dateAdapter ?? defaultDateAdapter;\n  const dateMin = dateAdapter.deserialize(min);\n  const dateMax = dateAdapter.deserialize(max);\n\n  if (\n    (dateAdapter.isValid(dateMin) && dateAdapter.compareDate(date, dateMin!) < 0) ||\n    (dateAdapter.isValid(dateMax) && dateAdapter.compareDate(date, dateMax!) > 0)\n  ) {\n    return false;\n  }\n\n  return dateFilter ? dateFilter(date) : true;\n}\n\nexport const datepickerControlRegisteredEventFactory = (): CustomEvent =>\n  new CustomEvent('datepickerControlRegistered', {\n    bubbles: false,\n    composed: true,\n  });\n\n/**\n * Combined with a native input, it displays the input's value as a formatted date.\n *\n * @event {CustomEvent<void>} didChange - Deprecated. used for React. Will probably be removed once React 19 is available.\n * @event {CustomEvent<void>} change - Notifies that the connected input has changes.\n * @event {CustomEvent<SbbInputUpdateEvent>} inputUpdated - Notifies that the attributes of the input connected to the datepicker have changes.\n * @event {CustomEvent<void>} datePickerUpdated - Notifies that the attributes of the datepicker have changes.\n * @event {CustomEvent<SbbValidationChangeEvent>} validationChange - Emits whenever the internal validation state changes.\n */\n@customElement('sbb-datepicker')\nexport class SbbDatepickerElement<T = Date> extends LitElement {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    didChange: 'didChange',\n    change: 'change',\n    inputUpdated: 'inputUpdated',\n    datePickerUpdated: 'datePickerUpdated',\n    validationChange: 'validationChange',\n  } as const;\n\n  /** If set to true, two months are displayed. */\n  @property({ type: Boolean }) public wide = false;\n\n  /** A function used to filter out dates. */\n  @property({ attribute: false }) public dateFilter: (date: T | null) => boolean = () => true;\n\n  /**\n   * A function used to parse string value into dates.\n   * @deprecated No longer required.\n   */\n  @property({ attribute: false }) public dateParser?: (value: string) => T | undefined;\n\n  /**\n   * A function used to format dates into the preferred string format.\n   * @deprecated No longer required.\n   */\n  @property({ attribute: false }) public format?: (date: T) => string;\n\n  /** Reference of the native input connected to the datepicker. */\n  @property() public input?: string | HTMLElement;\n\n  // TODO: Change undefined to null as a breaking change.\n  /** A configured date which acts as the current date instead of the real current date. Recommended for testing purposes. */\n  @property()\n  public set now(value: SbbDateLike<T> | undefined) {\n    this._now = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));\n  }\n  public get now(): T {\n    return this._now ?? this._dateAdapter.today();\n  }\n  private _now?: T | null;\n\n  /** The currently selected date as a Date or custom date provider instance. */\n  @property({ attribute: false })\n  public set valueAsDate(value: SbbDateLike<T> | null) {\n    this._valueAsDate = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));\n    if (this._tryApplyFormatToInput()) {\n      /* Emit blur event when value is changed programmatically to notify\n      frameworks that rely on that event to update form status. */\n      this._inputElement!.dispatchEvent(new Event('blur', { composed: true }));\n    }\n  }\n  public get valueAsDate(): T | null {\n    return this._valueAsDate ?? null;\n  }\n  private _valueAsDate?: T | null;\n\n  /**\n   * @deprecated only used for React. Will probably be removed once React 19 is available.\n   */\n  private _didChange: EventEmitter = new EventEmitter(this, SbbDatepickerElement.events.didChange, {\n    bubbles: true,\n    cancelable: true,\n  });\n\n  /** Notifies that the connected input has changes. */\n  private _change: EventEmitter = new EventEmitter(this, SbbDatepickerElement.events.change, {\n    bubbles: true,\n  });\n\n  /** Notifies that the attributes of the input connected to the datepicker have changes. */\n  private _inputUpdated: EventEmitter<SbbInputUpdateEvent> = new EventEmitter(\n    this,\n    SbbDatepickerElement.events.inputUpdated,\n    { bubbles: true, cancelable: true },\n  );\n\n  /** Notifies that the attributes of the datepicker have changes. */\n  private _datePickerUpdated: EventEmitter = new EventEmitter(\n    this,\n    SbbDatepickerElement.events.datePickerUpdated,\n    {\n      bubbles: true,\n      cancelable: true,\n    },\n  );\n\n  /** Emits whenever the internal validation state changes. */\n  private _validationChange: EventEmitter<SbbValidationChangeEvent> = new EventEmitter(\n    this,\n    SbbDatepickerElement.events.validationChange,\n  );\n\n  @state()\n  private _inputElement: HTMLInputElement | null = null;\n  private _inputElementPlaceholderMutable = false;\n\n  private _datePickerController!: AbortController;\n\n  private _inputObserver = new AgnosticMutationObserver((mutationsList) => {\n    this._emitInputUpdated();\n    // TODO: Decide whether to remove this logic by adding a value property to the datepicker.\n    if (this._inputElement && mutationsList?.some((e) => e.attributeName === 'value')) {\n      const value = this._inputElement.getAttribute('value');\n      this.valueAsDate = this._dateAdapter.parse(value, this.now) ?? value;\n    }\n  });\n\n  private _dateAdapter: DateAdapter<T> = readConfig().datetime?.dateAdapter ?? defaultDateAdapter;\n\n  private _abort = new SbbConnectedAbortController(this);\n  private _language = new SbbLanguageController(this).withHandler(() => {\n    if (this._inputElement) {\n      if (this._inputElementPlaceholderMutable) {\n        this._inputElement.placeholder = i18nDatePickerPlaceholder[this._language.current];\n      }\n      if (this.valueAsDate) {\n        this._inputElement.value = this._format(this.valueAsDate);\n      }\n    }\n  });\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.addEventListener('datepickerControlRegistered', () => this._emitInputUpdated(), {\n      signal: this._abort.signal,\n    });\n    this._attachInput();\n    if (this._inputElement) {\n      this._emitInputUpdated();\n    }\n  }\n\n  public override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('input')) {\n      this._attachInput();\n    }\n    if (\n      changedProperties.has('wide') ||\n      changedProperties.has('dateFilter') ||\n      changedProperties.has('now')\n    ) {\n      this._datePickerUpdated.emit();\n    }\n    if (changedProperties.has('valueAsDate')) {\n      this._setAriaLiveMessage();\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._inputObserver?.disconnect();\n    this._datePickerController?.abort();\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n    this._setAriaLiveMessage();\n  }\n\n  /**\n   * Gets the input value with the correct date format.\n   * @deprecated Use property valueAsDate instead.\n   */\n  public getValueAsDate(): T | undefined {\n    return this.valueAsDate ?? undefined;\n  }\n\n  /**\n   * Set the input value to the correctly formatted value.\n   * @deprecated Use property valueAsDate instead.\n   */\n  public setValueAsDate(date: SbbDateLike<T>): void {\n    this.valueAsDate = date;\n  }\n\n  /**\n   * @internal\n   * Whether a custom now is configured.\n   */\n  public hasCustomNow(): boolean {\n    return !!this._now;\n  }\n\n  private _attachInput(): void {\n    const input = findInput(this, this.input);\n    if (this._inputElement === input) {\n      return;\n    } else if (this._inputElement) {\n      this._datePickerController?.abort();\n      this._inputObserver?.disconnect();\n    }\n\n    this._inputElement = input;\n    if (input) {\n      this._datePickerController = new AbortController();\n      this._inputObserver.observe(input, {\n        attributeFilter: ['disabled', 'readonly', 'min', 'max', 'value'],\n      });\n\n      this._inputElementPlaceholderMutable = !input.placeholder;\n      input.type = 'text';\n      if (this._inputElementPlaceholderMutable) {\n        input.placeholder = i18nDatePickerPlaceholder[this._language.current];\n      }\n\n      const options: AddEventListenerOptions = { signal: this._datePickerController.signal };\n      input.addEventListener('input', () => this._parseInput(), options);\n      input.addEventListener('change', () => this._handleInputChange(), options);\n      this._parseInput(true);\n      this._tryApplyFormatToInput();\n      this._validateDate();\n    }\n  }\n\n  private _emitInputUpdated(): void {\n    const { disabled, readOnly: readonly, min, max } = this._inputElement ?? {};\n    this._inputUpdated.emit({ disabled, readonly, min, max });\n  }\n\n  private _handleInputChange(): void {\n    if (this._tryApplyFormatToInput()) {\n      return;\n    }\n    this._validateDate();\n    this._setAriaLiveMessage();\n    this._change.emit();\n    this._didChange.emit();\n  }\n\n  private _tryApplyFormatToInput(): boolean {\n    if (!this._inputElement) {\n      return false;\n    }\n\n    const formattedDate = this.valueAsDate ? this._format(this.valueAsDate!) : '';\n    if (formattedDate && this._inputElement.value !== formattedDate) {\n      this._inputElement.value = formattedDate;\n      this._inputElement.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n      this._inputElement.dispatchEvent(new Event('change', { bubbles: true, composed: true }));\n      return true;\n    }\n\n    return false;\n  }\n\n  private _validateDate(): void {\n    if (!this._inputElement) {\n      return;\n    }\n\n    const isEmptyOrValid =\n      !this._inputElement.value ||\n      (!!this.valueAsDate &&\n        isDateAvailable(\n          this.valueAsDate,\n          this.dateFilter,\n          this._inputElement?.min,\n          this._inputElement?.max,\n        ));\n    const wasValid = !this._inputElement.hasAttribute('data-sbb-invalid');\n    this._inputElement.toggleAttribute('data-sbb-invalid', !isEmptyOrValid);\n    if (wasValid !== isEmptyOrValid) {\n      this._validationChange.emit({ valid: isEmptyOrValid });\n    }\n  }\n\n  private _parseInput(deserializeAsFallback = false): void {\n    const value = this._inputElement!.value;\n    const parse = this.dateParser ?? ((v: string) => this._dateAdapter.parse(v, this.now));\n    // We are assigning directly to the private backing property of valueAsDate\n    // as we don't want to trigger a blur event during this time.\n    this._valueAsDate = this._dateAdapter.getValidDateOrNull(parse(value));\n    if (deserializeAsFallback && !this._valueAsDate) {\n      this._valueAsDate = this._dateAdapter.getValidDateOrNull(\n        this._dateAdapter.deserialize(value),\n      );\n    }\n  }\n\n  private _format(date: T): string {\n    return this.format ? this.format(date) : this._dateAdapter.format(date);\n  }\n\n  private _setAriaLiveMessage(): void {\n    const containerElement: HTMLParagraphElement | null | undefined =\n      this.shadowRoot?.querySelector?.<HTMLParagraphElement>('#status-container');\n\n    if (!containerElement) {\n      return;\n    } else if (!this.valueAsDate) {\n      containerElement.innerText = '';\n    } else {\n      const date = this._dateAdapter.format(this.valueAsDate, { weekdayStyle: 'long' });\n      containerElement.innerText = `${i18nDateChangedTo[this._language.current]} ${date}`;\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return html`<p id=\"status-container\" role=\"status\"></p>`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-datepicker': SbbDatepickerElement;\n  }\n\n  interface GlobalEventHandlersEventMap {\n    inputUpdated: CustomEvent<SbbInputUpdateEvent>;\n  }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -52,7 +52,7 @@ const style = css`/**
|
|
|
52
52
|
--sbb-dialog-border-radius: var(--sbb-border-radius-8x);
|
|
53
53
|
--sbb-dialog-padding-block: var(--sbb-spacing-responsive-s);
|
|
54
54
|
--sbb-dialog-animation-duration: var(
|
|
55
|
-
--sbb-disable-animation-
|
|
55
|
+
--sbb-disable-animation-time,
|
|
56
56
|
var(--sbb-animation-duration-6x)
|
|
57
57
|
);
|
|
58
58
|
--sbb-dialog-animation-easing: ease;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"file-selector.d.ts","sourceRoot":"","sources":["../../../../src/elements/file-selector/file-selector.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAW,MAAM,KAAK,CAAC;
|
|
1
|
+
{"version":3,"file":"file-selector.d.ts","sourceRoot":"","sources":["../../../../src/elements/file-selector/file-selector.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAW,MAAM,KAAK,CAAC;AAoB1C,OAAO,+BAA+B,CAAC;AACvC,OAAO,sCAAsC,CAAC;AAC9C,OAAO,YAAY,CAAC;AAEpB,MAAM,MAAM,QAAQ,GAAG,UAAU,CAAC,KAAK,CAAC;;AAExC;;;;;GAKG;AACH,qBAEa,sBAAuB,SAAQ,2BAA4B;IACtE,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;MAElB;IAEX,wDAAwD;IACrC,OAAO,EAAE,SAAS,GAAG,UAAU,CAAa;IAE/D,mCAAmC;IACC,IAAI,EAAE,GAAG,GAAG,GAAG,CAAO;IAE1D,kDAAkD;IACd,QAAQ,EAAE,OAAO,CAAS;IAE9D,+EAA+E;IAExE,YAAY,EAAE,SAAS,GAAG,YAAY,CAAa;IAE1D,qEAAqE;IAClD,MAAM,CAAC,EAAE,MAAM,CAAC;IAEnC,iDAAiD;IACA,YAAY,CAAC,EAAE,MAAM,CAAC;IAEvE,wEAAwE;IACjB,kBAAkB,EAAE,MAAM,GAAG,SAAS,CAAC;IAE9F,kCAAkC;IACzB,OAAO,CAAC,MAAM,CAAC,CAAS;IAEjC,iEAAiE;IACjE,OAAO,CAAC,iBAAiB,CAGvB;IAEF;;OAEG;IACH,IAAW,KAAK,IAAI,IAAI,EAAE,CAEzB;IAED;;OAEG;IACI,QAAQ,IAAI,IAAI,EAAE;IAMzB,OAAO,CAAC,QAAQ,CAAa;IAE7B,OAAO,CAAC,WAAW,CAAmC;IACtD,OAAO,CAAC,WAAW,CAAC,CAAc;IAClC,OAAO,CAAC,YAAY,CAAoB;IACxC,OAAO,CAAC,SAAS,CAA2C;IAC5D,OAAO,CAAC,WAAW,CAAwB;IAE3C,OAAO,CAAC,SAAS,CAAmC;IAEpD,OAAO,CAAC,WAAW;IAKnB,OAAO,CAAC,kBAAkB;IAQ1B,OAAO,CAAC,YAAY;IAQpB,OAAO,CAAC,YAAY;IAQpB,OAAO,CAAC,WAAW;IASnB,OAAO,CAAC,QAAQ;IAMhB,OAAO,CAAC,OAAO;IAMf,OAAO,CAAC,aAAa;IASrB,OAAO,CAAC,UAAU;IAOlB,OAAO,CAAC,eAAe;IAuBvB,OAAO,CAAC,WAAW;IAYnB,uDAAuD;IACvD,OAAO,CAAC,eAAe;IAKvB,OAAO,CAAC,kBAAkB;IAe1B,OAAO,CAAC,mBAAmB;IA2B3B,OAAO,CAAC,eAAe;cA4BJ,MAAM,IAAI,cAAc;CA2C5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,mBAAmB,EAAE,sBAAsB,CAAC;KAC7C;CACF"}
|