@sbb-esta/lyne-elements-dev 4.9.0-dev.1775050914 → 4.9.0-dev.1775054429
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/autocomplete/autocomplete-base-element.js +1 -1
- package/autocomplete/autocomplete.component.js +1 -1
- package/{autocomplete-base-element-DFRA5eoY.js → autocomplete-base-element-DarHnnYC.js} +1 -1
- package/autocomplete.js +1 -1
- package/autocomplete.pure.js +1 -1
- package/custom-elements.json +24 -24
- package/date-input/date-input.component.js +1 -1
- package/{date-input.component-C6UN7HzO.js → date-input.component-B3f_GThS.js} +1 -1
- package/date-input.js +1 -1
- package/date-input.pure.js +1 -1
- package/development/autocomplete/autocomplete-base-element.js +1 -1
- package/development/autocomplete/autocomplete.component.js +1 -1
- package/development/autocomplete-base-element-YwfObJzm.js +678 -0
- package/development/autocomplete.js +1 -1
- package/development/autocomplete.pure.js +1 -1
- package/development/date-input/date-input.component.js +1 -1
- package/development/date-input.component-UP1afzgy.js +307 -0
- package/development/date-input.js +1 -1
- package/development/date-input.pure.js +1 -1
- package/development/form-field/form-field/form-field.component.js +1 -1
- package/development/form-field/form-field.js +1 -1
- package/development/form-field.component-DnUA6Uds.js +650 -0
- package/development/form-field.js +1 -1
- package/development/form-field.pure.js +1 -1
- package/development/select/select.component.js +1 -1
- package/development/select.component-Il_cpCFV.js +784 -0
- package/development/select.js +1 -1
- package/development/select.pure.js +1 -1
- package/development/time-input/time-input.component.js +1 -1
- package/development/time-input.component-XS0aJ6M7.js +191 -0
- package/development/time-input.js +1 -1
- package/development/time-input.pure.js +1 -1
- package/form-field/form-field/form-field.component.js +1 -1
- package/form-field/form-field.js +1 -1
- package/{form-field.component-BKjqLhmy.js → form-field.component-D2R9BpyQ.js} +1 -1
- package/form-field.js +1 -1
- package/form-field.pure.js +1 -1
- package/package.json +2 -2
- package/select/select.component.js +1 -1
- package/{select.component-A-TwBa65.js → select.component-DMzvfiNM.js} +1 -1
- package/select.js +1 -1
- package/select.pure.js +1 -1
- package/time-input/time-input.component.js +1 -1
- package/{time-input.component-KSyUufTP.js → time-input.component-Jv2xorV5.js} +1 -1
- package/time-input.js +1 -1
- package/time-input.pure.js +1 -1
- package/development/autocomplete-base-element-CNoHrX63.js +0 -678
- package/development/date-input.component-B7Eq5hCB.js +0 -307
- package/development/form-field.component-KEFq2rmY.js +0 -650
- package/development/select.component-DNMAVhaz.js +0 -784
- package/development/time-input.component-B4HBAe0K.js +0 -191
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { t as SbbAutocompleteBaseElement } from "./autocomplete-base-element-
|
|
1
|
+
import { t as SbbAutocompleteBaseElement } from "./autocomplete-base-element-YwfObJzm.js";
|
|
2
2
|
import { SbbAutocompleteElement } from "./autocomplete/autocomplete.component.js";
|
|
3
3
|
import "./autocomplete.pure.js";
|
|
4
4
|
//#region src/elements/autocomplete.ts
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import { t as SbbAutocompleteBaseElement } from "./autocomplete-base-element-
|
|
1
|
+
import { t as SbbAutocompleteBaseElement } from "./autocomplete-base-element-YwfObJzm.js";
|
|
2
2
|
import { SbbAutocompleteElement } from "./autocomplete/autocomplete.component.js";
|
|
3
3
|
export { SbbAutocompleteBaseElement, SbbAutocompleteElement };
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as SbbDateInputElement } from "../date-input.component-
|
|
1
|
+
import { t as SbbDateInputElement } from "../date-input.component-UP1afzgy.js";
|
|
2
2
|
export { SbbDateInputElement };
|
|
@@ -0,0 +1,307 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
+
import { isServer, unsafeCSS } from "lit";
|
|
3
|
+
import { property } from "lit/decorators.js";
|
|
4
|
+
import { SbbElement } from "./core/base-elements.js";
|
|
5
|
+
import { plainDate, plainDateConverter } from "./core/decorators.js";
|
|
6
|
+
import { SbbFormAssociatedInputMixin } from "./core/mixins.js";
|
|
7
|
+
import { i18nDateInvalid, i18nDateMax, i18nDateMin, i18nDatePickerPlaceholder } from "./core/i18n.js";
|
|
8
|
+
import { readConfig } from "./core/config.js";
|
|
9
|
+
import { defaultDateAdapter } from "./core/datetime.js";
|
|
10
|
+
//#region src/elements/date-input/date-input.scss?inline
|
|
11
|
+
var date_input_default = ":host {\n display: inline-flex;\n min-width: 9.375rem;\n max-width: 100%;\n cursor: text;\n align-items: center;\n font-weight: normal;\n}\n@media (forced-colors: active) {\n :host {\n color: FieldText;\n }\n}\n\n:host(:disabled) {\n cursor: var(--sbb-cursor-default);\n}\n\n:host(:focus) {\n text-overflow: initial !important;\n}\n\n:host(:empty)::after {\n content: attr(placeholder);\n color: var(--sbb-color-5);\n -webkit-text-fill-color: var(--sbb-color-5);\n opacity: 1;\n}\n@media (forced-colors: active) {\n :host(:empty)::after {\n color: GrayText;\n }\n}";
|
|
12
|
+
//#endregion
|
|
13
|
+
//#region src/elements/date-input/date-input.component.ts
|
|
14
|
+
Object.assign(ValidityState.prototype, { get sbbDateFilter() {
|
|
15
|
+
return false;
|
|
16
|
+
} });
|
|
17
|
+
/**
|
|
18
|
+
* Custom input for a date.
|
|
19
|
+
*/
|
|
20
|
+
var SbbDateInputElement = (() => {
|
|
21
|
+
let _classSuper = SbbFormAssociatedInputMixin(SbbElement);
|
|
22
|
+
let _instanceExtraInitializers = [];
|
|
23
|
+
let _set_valueAsDate_decorators;
|
|
24
|
+
let _min_decorators;
|
|
25
|
+
let _min_initializers = [];
|
|
26
|
+
let _min_extraInitializers = [];
|
|
27
|
+
let _max_decorators;
|
|
28
|
+
let _max_initializers = [];
|
|
29
|
+
let _max_extraInitializers = [];
|
|
30
|
+
let _set_dateFilter_decorators;
|
|
31
|
+
let _weekdayStyle_decorators;
|
|
32
|
+
let _weekdayStyle_initializers = [];
|
|
33
|
+
let _weekdayStyle_extraInitializers = [];
|
|
34
|
+
return class SbbDateInputElement extends _classSuper {
|
|
35
|
+
static {
|
|
36
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
37
|
+
_set_valueAsDate_decorators = [property({ attribute: false })];
|
|
38
|
+
_min_decorators = [plainDate(), property({
|
|
39
|
+
converter: plainDateConverter,
|
|
40
|
+
reflect: true
|
|
41
|
+
})];
|
|
42
|
+
_max_decorators = [plainDate(), property({
|
|
43
|
+
converter: plainDateConverter,
|
|
44
|
+
reflect: true
|
|
45
|
+
})];
|
|
46
|
+
_set_dateFilter_decorators = [property({ attribute: false })];
|
|
47
|
+
_weekdayStyle_decorators = [property({ attribute: "weekday-style" })];
|
|
48
|
+
__esDecorate(this, null, _set_valueAsDate_decorators, {
|
|
49
|
+
kind: "setter",
|
|
50
|
+
name: "valueAsDate",
|
|
51
|
+
static: false,
|
|
52
|
+
private: false,
|
|
53
|
+
access: {
|
|
54
|
+
has: (obj) => "valueAsDate" in obj,
|
|
55
|
+
set: (obj, value) => {
|
|
56
|
+
obj.valueAsDate = value;
|
|
57
|
+
}
|
|
58
|
+
},
|
|
59
|
+
metadata: _metadata
|
|
60
|
+
}, null, _instanceExtraInitializers);
|
|
61
|
+
__esDecorate(this, null, _min_decorators, {
|
|
62
|
+
kind: "accessor",
|
|
63
|
+
name: "min",
|
|
64
|
+
static: false,
|
|
65
|
+
private: false,
|
|
66
|
+
access: {
|
|
67
|
+
has: (obj) => "min" in obj,
|
|
68
|
+
get: (obj) => obj.min,
|
|
69
|
+
set: (obj, value) => {
|
|
70
|
+
obj.min = value;
|
|
71
|
+
}
|
|
72
|
+
},
|
|
73
|
+
metadata: _metadata
|
|
74
|
+
}, _min_initializers, _min_extraInitializers);
|
|
75
|
+
__esDecorate(this, null, _max_decorators, {
|
|
76
|
+
kind: "accessor",
|
|
77
|
+
name: "max",
|
|
78
|
+
static: false,
|
|
79
|
+
private: false,
|
|
80
|
+
access: {
|
|
81
|
+
has: (obj) => "max" in obj,
|
|
82
|
+
get: (obj) => obj.max,
|
|
83
|
+
set: (obj, value) => {
|
|
84
|
+
obj.max = value;
|
|
85
|
+
}
|
|
86
|
+
},
|
|
87
|
+
metadata: _metadata
|
|
88
|
+
}, _max_initializers, _max_extraInitializers);
|
|
89
|
+
__esDecorate(this, null, _set_dateFilter_decorators, {
|
|
90
|
+
kind: "setter",
|
|
91
|
+
name: "dateFilter",
|
|
92
|
+
static: false,
|
|
93
|
+
private: false,
|
|
94
|
+
access: {
|
|
95
|
+
has: (obj) => "dateFilter" in obj,
|
|
96
|
+
set: (obj, value) => {
|
|
97
|
+
obj.dateFilter = value;
|
|
98
|
+
}
|
|
99
|
+
},
|
|
100
|
+
metadata: _metadata
|
|
101
|
+
}, null, _instanceExtraInitializers);
|
|
102
|
+
__esDecorate(this, null, _weekdayStyle_decorators, {
|
|
103
|
+
kind: "accessor",
|
|
104
|
+
name: "weekdayStyle",
|
|
105
|
+
static: false,
|
|
106
|
+
private: false,
|
|
107
|
+
access: {
|
|
108
|
+
has: (obj) => "weekdayStyle" in obj,
|
|
109
|
+
get: (obj) => obj.weekdayStyle,
|
|
110
|
+
set: (obj, value) => {
|
|
111
|
+
obj.weekdayStyle = value;
|
|
112
|
+
}
|
|
113
|
+
},
|
|
114
|
+
metadata: _metadata
|
|
115
|
+
}, _weekdayStyle_initializers, _weekdayStyle_extraInitializers);
|
|
116
|
+
if (_metadata) Object.defineProperty(this, Symbol.metadata, {
|
|
117
|
+
enumerable: true,
|
|
118
|
+
configurable: true,
|
|
119
|
+
writable: true,
|
|
120
|
+
value: _metadata
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
static {
|
|
124
|
+
this.elementName = "sbb-date-input";
|
|
125
|
+
}
|
|
126
|
+
static {
|
|
127
|
+
this.styles = unsafeCSS(date_input_default);
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* The value of the date input. Reflects the current text value
|
|
131
|
+
* of this input.
|
|
132
|
+
* The attribute `value` Accepts ISO8601 formatted values, which will be
|
|
133
|
+
* formatted according to the current locale.
|
|
134
|
+
*/
|
|
135
|
+
set value(value) {
|
|
136
|
+
this._tryParseValue(value);
|
|
137
|
+
if (!isServer && !this.matches(":focus") && this.valueAsDate !== null) value = this._formatDate();
|
|
138
|
+
super.value = value;
|
|
139
|
+
}
|
|
140
|
+
get value() {
|
|
141
|
+
return super.value ?? "";
|
|
142
|
+
}
|
|
143
|
+
/** Formats the current input's value as date. */
|
|
144
|
+
set valueAsDate(value) {
|
|
145
|
+
value = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));
|
|
146
|
+
if (!value) {
|
|
147
|
+
this._valueAsDate = null;
|
|
148
|
+
this._valueCache = ["", null];
|
|
149
|
+
this.value = "";
|
|
150
|
+
} else if (!this._dateAdapter.isDateInstance(this._valueAsDate) || this._dateAdapter.compareDate(this._valueAsDate, value) !== 0) {
|
|
151
|
+
this._valueAsDate = this._dateAdapter.createDate(this._dateAdapter.getYear(value), this._dateAdapter.getMonth(value), this._dateAdapter.getDate(value));
|
|
152
|
+
const stringValue = this._formatDate();
|
|
153
|
+
this._valueCache = [stringValue, this._valueAsDate];
|
|
154
|
+
this.value = stringValue;
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
get valueAsDate() {
|
|
158
|
+
return this._valueAsDate ? this._dateAdapter.clone(this._valueAsDate) : null;
|
|
159
|
+
}
|
|
160
|
+
#min_accessor_storage;
|
|
161
|
+
/**
|
|
162
|
+
* The minimum valid date. Accepts a date object or null.
|
|
163
|
+
* Accepts an ISO8601 formatted string (e.g. 2024-12-24) as attribute.
|
|
164
|
+
*/
|
|
165
|
+
get min() {
|
|
166
|
+
return this.#min_accessor_storage;
|
|
167
|
+
}
|
|
168
|
+
set min(value) {
|
|
169
|
+
this.#min_accessor_storage = value;
|
|
170
|
+
}
|
|
171
|
+
#max_accessor_storage;
|
|
172
|
+
/**
|
|
173
|
+
* The maximum valid date. Accepts a date object or null.
|
|
174
|
+
* Accepts an ISO8601 formatted string (e.g. 2024-12-24) as attribute.
|
|
175
|
+
*/
|
|
176
|
+
get max() {
|
|
177
|
+
return this.#max_accessor_storage;
|
|
178
|
+
}
|
|
179
|
+
set max(value) {
|
|
180
|
+
this.#max_accessor_storage = value;
|
|
181
|
+
}
|
|
182
|
+
/**
|
|
183
|
+
* A function used to filter out dates.
|
|
184
|
+
* It is strongly recommended to use min and max dates alongside
|
|
185
|
+
* this filter.
|
|
186
|
+
*/
|
|
187
|
+
set dateFilter(value) {
|
|
188
|
+
this._dateFilter = value;
|
|
189
|
+
}
|
|
190
|
+
get dateFilter() {
|
|
191
|
+
return this._dateFilter;
|
|
192
|
+
}
|
|
193
|
+
#weekdayStyle_accessor_storage;
|
|
194
|
+
/**
|
|
195
|
+
* How to format the displayed date.
|
|
196
|
+
* `short`: Two letter abbreviation of the week day (e.g. Fr).
|
|
197
|
+
* `none`: The weekday is not displayed.
|
|
198
|
+
*/
|
|
199
|
+
get weekdayStyle() {
|
|
200
|
+
return this.#weekdayStyle_accessor_storage;
|
|
201
|
+
}
|
|
202
|
+
set weekdayStyle(value) {
|
|
203
|
+
this.#weekdayStyle_accessor_storage = value;
|
|
204
|
+
}
|
|
205
|
+
/**
|
|
206
|
+
* Gets the associated datepicker, if any.
|
|
207
|
+
* The sbb-date-input and the sbb-datepicker are assumed to be in the same parent container.
|
|
208
|
+
*/
|
|
209
|
+
get datepicker() {
|
|
210
|
+
return this.parentElement.querySelector("sbb-datepicker");
|
|
211
|
+
}
|
|
212
|
+
constructor() {
|
|
213
|
+
super();
|
|
214
|
+
this._valueAsDate = __runInitializers(this, _instanceExtraInitializers);
|
|
215
|
+
this.#min_accessor_storage = __runInitializers(this, _min_initializers, null);
|
|
216
|
+
this.#max_accessor_storage = (__runInitializers(this, _min_extraInitializers), __runInitializers(this, _max_initializers, null));
|
|
217
|
+
this.#weekdayStyle_accessor_storage = (__runInitializers(this, _max_extraInitializers), __runInitializers(this, _weekdayStyle_initializers, "short"));
|
|
218
|
+
/**
|
|
219
|
+
* Stores the last string and parsed date object value to prevent repeated
|
|
220
|
+
* parsing of the string value.
|
|
221
|
+
*/
|
|
222
|
+
this._valueCache = __runInitializers(this, _weekdayStyle_extraInitializers);
|
|
223
|
+
this._dateAdapter = readConfig().datetime?.dateAdapter ?? defaultDateAdapter;
|
|
224
|
+
this._placeholderMutable = false;
|
|
225
|
+
this._dateFilter = () => true;
|
|
226
|
+
this.addEventListener?.("change", () => this._updateValueDateFormat(), { capture: true });
|
|
227
|
+
}
|
|
228
|
+
/**
|
|
229
|
+
* Attempts to resolve the associated date input with the given element.
|
|
230
|
+
*/
|
|
231
|
+
static resolveAssociation(host) {
|
|
232
|
+
if (host.hasAttribute("input") || host.input) return;
|
|
233
|
+
const input = host.closest("sbb-form-field")?.querySelector("sbb-date-input");
|
|
234
|
+
if (input) host.input = input;
|
|
235
|
+
}
|
|
236
|
+
connectedCallback() {
|
|
237
|
+
super.connectedCallback();
|
|
238
|
+
if (!this.placeholder) {
|
|
239
|
+
this._placeholderMutable = true;
|
|
240
|
+
this.placeholder = i18nDatePickerPlaceholder[this.language.current];
|
|
241
|
+
}
|
|
242
|
+
for (const child of Array.from(this.closest("sbb-form-field")?.children ?? [])) {
|
|
243
|
+
customElements.upgrade?.(child);
|
|
244
|
+
if (child.constructor.sbbDateInputAssociated && !child.hasAttribute("input") && !child.input) child.input = this;
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
requestUpdate(name, oldValue, options) {
|
|
248
|
+
super.requestUpdate(name, oldValue, options);
|
|
249
|
+
if (this.hasUpdated && !name) {
|
|
250
|
+
this._updateValueDateFormat();
|
|
251
|
+
if (this._placeholderMutable) this.placeholder = i18nDatePickerPlaceholder[this.language.current];
|
|
252
|
+
} else if (name === "weekdayStyle") this._updateValueDateFormat();
|
|
253
|
+
if (this.isConnected)
|
|
254
|
+
/** @internal */
|
|
255
|
+
this.dispatchEvent(new Event("ɵchange"));
|
|
256
|
+
}
|
|
257
|
+
updateFormValue() {
|
|
258
|
+
this._tryParseValue();
|
|
259
|
+
const formValue = this.valueAsDate !== null ? this._dateAdapter.toIso8601(this.valueAsDate) : null;
|
|
260
|
+
this.internals.setFormValue(formValue, this.value);
|
|
261
|
+
}
|
|
262
|
+
_tryParseValue(value = this.value) {
|
|
263
|
+
if (this._valueCache?.[0] !== value) {
|
|
264
|
+
this._valueAsDate = this._dateAdapter.parse(value);
|
|
265
|
+
this._valueCache = [value, this._valueAsDate];
|
|
266
|
+
}
|
|
267
|
+
}
|
|
268
|
+
_updateValueDateFormat() {
|
|
269
|
+
if (this.valueAsDate) {
|
|
270
|
+
const formattedDate = this._formatDate();
|
|
271
|
+
if (this.value !== formattedDate) super.value = formattedDate;
|
|
272
|
+
}
|
|
273
|
+
}
|
|
274
|
+
_formatDate() {
|
|
275
|
+
return this._dateAdapter.format(this.valueAsDate, { weekdayStyle: this.weekdayStyle });
|
|
276
|
+
}
|
|
277
|
+
shouldValidate(name) {
|
|
278
|
+
return super.shouldValidate(name) || [
|
|
279
|
+
"valueAsDate",
|
|
280
|
+
"min",
|
|
281
|
+
"max",
|
|
282
|
+
"dateFilter"
|
|
283
|
+
].includes(name);
|
|
284
|
+
}
|
|
285
|
+
validate() {
|
|
286
|
+
super.validate();
|
|
287
|
+
if (!this.value) this._removeValidityErrors();
|
|
288
|
+
else if (!this._dateAdapter.isValid(this.valueAsDate)) this.setValidityFlag("badInput", i18nDateInvalid[this.language.current]);
|
|
289
|
+
else if (this._dateAdapter.isValid(this.min) && this._dateAdapter.compareDate(this.min, this.valueAsDate) > 0) this.setValidityFlag("rangeUnderflow", i18nDateMin(this._dateAdapter.format(this.min, { weekdayStyle: "none" }))[this.language.current]);
|
|
290
|
+
else if (this._dateAdapter.isValid(this.max) && this._dateAdapter.compareDate(this.valueAsDate, this.max) > 0) this.setValidityFlag("rangeOverflow", i18nDateMax(this._dateAdapter.format(this.max, { weekdayStyle: "none" }))[this.language.current]);
|
|
291
|
+
else if (this.dateFilter && !this.dateFilter(this.valueAsDate)) this.setValidityFlag("sbbDateFilter", i18nDateInvalid[this.language.current]);
|
|
292
|
+
else this._removeValidityErrors();
|
|
293
|
+
}
|
|
294
|
+
_removeValidityErrors() {
|
|
295
|
+
[
|
|
296
|
+
"badInput",
|
|
297
|
+
"rangeUnderflow",
|
|
298
|
+
"rangeOverflow",
|
|
299
|
+
"sbbDateFilter"
|
|
300
|
+
].forEach((f) => this.removeValidityFlag(f));
|
|
301
|
+
}
|
|
302
|
+
};
|
|
303
|
+
})();
|
|
304
|
+
//#endregion
|
|
305
|
+
export { SbbDateInputElement as t };
|
|
306
|
+
|
|
307
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"date-input.component-UP1afzgy.js","names":[],"sources":["../../../src/elements/date-input/date-input.scss?inline","../../../src/elements/date-input/date-input.component.ts"],"sourcesContent":["@use '../core/styles' as sbb;\n\n:host {\n  display: inline-flex;\n\n  // With sbb-form-field[width=\"collapsed\"], the default min width of a\n  // an inline element is basically nothing (except potentially the placeholder).\n  // Due to this, we set a minimum width of the date input element.\n  min-width: #{sbb.px-to-rem-build(150)};\n  max-width: 100%;\n  cursor: text;\n  align-items: center;\n  font-weight: normal;\n\n  @include sbb.if-forced-colors {\n    color: FieldText;\n  }\n}\n\n:host(:disabled) {\n  cursor: var(--sbb-cursor-default);\n}\n\n:host(:focus) {\n  text-overflow: initial !important;\n}\n\n:host(:empty)::after {\n  content: attr(placeholder);\n  @include sbb.placeholder;\n  @include sbb.if-forced-colors {\n    color: GrayText;\n  }\n}\n","import { type CSSResultGroup, isServer, type PropertyDeclaration, unsafeCSS } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { SbbElement } from '../core/base-elements.ts';\nimport { readConfig } from '../core/config.ts';\nimport { type DateAdapter, defaultDateAdapter } from '../core/datetime.ts';\nimport { plainDate, plainDateConverter } from '../core/decorators.ts';\nimport {\n  i18nDateInvalid,\n  i18nDateMax,\n  i18nDateMin,\n  i18nDatePickerPlaceholder,\n} from '../core/i18n.ts';\nimport { SbbFormAssociatedInputMixin } from '../core/mixins.ts';\nimport type { SbbDatepickerElement } from '../datepicker.ts';\n\nimport style from './date-input.scss?inline';\n\n// As documented in form-associated-mixin.ts, we extend the prototype of\n// ValidityState with custom error states for the date input.\nObject.assign(ValidityState.prototype, {\n  get sbbDateFilter(): boolean {\n    return false;\n  },\n});\n\n/**\n * Interface for elements that can be associated with a date input.\n * Implementing classes must also have a static property `sbbDateInputAssociated` set to `true`.\n */\nexport interface SbbDateInputAssociated<T> {\n  input: SbbDateInputElement<T> | null;\n}\n\n/**\n * Custom input for a date.\n */\nexport class SbbDateInputElement<T = Date> extends SbbFormAssociatedInputMixin(SbbElement) {\n  public static override readonly elementName: string = 'sbb-date-input';\n  public static override styles: CSSResultGroup = unsafeCSS(style);\n\n  /**\n   * The value of the date input. Reflects the current text value\n   * of this input.\n   * The attribute `value` Accepts ISO8601 formatted values, which will be\n   * formatted according to the current locale.\n   */\n  public override set value(value: string) {\n    this._tryParseValue(value);\n    // As long as this element has focus we delay automatically updating\n    // the value with the formatted string of the parsed date.\n    if (!isServer && !this.matches(':focus') && this.valueAsDate !== null) {\n      value = this._formatDate();\n    }\n    super.value = value;\n  }\n  public override get value(): string {\n    return super.value ?? '';\n  }\n\n  /** Formats the current input's value as date. */\n  @property({ attribute: false })\n  public set valueAsDate(value: T | null) {\n    value = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));\n    if (!value) {\n      this._valueAsDate = null;\n      this._valueCache = ['', null];\n      this.value = '';\n    } else if (\n      !this._dateAdapter.isDateInstance(this._valueAsDate) ||\n      this._dateAdapter.compareDate(this._valueAsDate!, value!) !== 0\n    ) {\n      // Align with the native date input, as it copies the value of\n      // the given date without the time and does not retain the\n      // original instance.\n      this._valueAsDate = this._dateAdapter.createDate(\n        this._dateAdapter.getYear(value),\n        this._dateAdapter.getMonth(value),\n        this._dateAdapter.getDate(value),\n      );\n      const stringValue = this._formatDate();\n      this._valueCache = [stringValue, this._valueAsDate];\n      this.value = stringValue;\n    }\n  }\n  public get valueAsDate(): T | null {\n    // We should never return the internal date object directly, as it\n    // could be manipulated outside of this class.\n    return this._valueAsDate ? this._dateAdapter.clone(this._valueAsDate) : null;\n  }\n  private _valueAsDate?: T | null;\n\n  /**\n   * The minimum valid date. Accepts a date object or null.\n   * Accepts an ISO8601 formatted string (e.g. 2024-12-24) as attribute.\n   */\n  @plainDate()\n  @property({ converter: plainDateConverter, reflect: true })\n  public accessor min: T | null = null;\n\n  /**\n   * The maximum valid date. Accepts a date object or null.\n   * Accepts an ISO8601 formatted string (e.g. 2024-12-24) as attribute.\n   */\n  @plainDate()\n  @property({ converter: plainDateConverter, reflect: true })\n  public accessor max: T | null = null;\n\n  /**\n   * A function used to filter out dates.\n   * It is strongly recommended to use min and max dates alongside\n   * this filter.\n   */\n  @property({ attribute: false })\n  public set dateFilter(value: (date: T | null) => boolean) {\n    this._dateFilter = value;\n  }\n  public get dateFilter(): (date: T | null) => boolean {\n    return this._dateFilter;\n  }\n\n  /**\n   * How to format the displayed date.\n   * `short`: Two letter abbreviation of the week day (e.g. Fr).\n   * `none`: The weekday is not displayed.\n   */\n  @property({ attribute: 'weekday-style' })\n  public accessor weekdayStyle: 'short' | 'none' = 'short';\n\n  /**\n   * Stores the last string and parsed date object value to prevent repeated\n   * parsing of the string value.\n   */\n  private _valueCache?: [string, T | null];\n  private _dateAdapter: DateAdapter<T> = readConfig().datetime?.dateAdapter ?? defaultDateAdapter;\n  private _placeholderMutable = false;\n\n  /**\n   * Gets the associated datepicker, if any.\n   * The sbb-date-input and the sbb-datepicker are assumed to be in the same parent container.\n   */\n  public get datepicker(): SbbDatepickerElement<T> | null {\n    return this.parentElement!.querySelector<SbbDatepickerElement<T>>('sbb-datepicker');\n  }\n\n  public constructor() {\n    super();\n    this.addEventListener?.('change', () => this._updateValueDateFormat(), { capture: true });\n  }\n\n  /**\n   * Attempts to resolve the associated date input with the given element.\n   */\n  public static resolveAssociation<T>(host: HTMLElement & SbbDateInputAssociated<T>): void {\n    if (host.hasAttribute('input') || host.input) {\n      return;\n    }\n\n    const input = host\n      .closest('sbb-form-field')\n      ?.querySelector<SbbDateInputElement<T>>('sbb-date-input');\n    if (input) {\n      host.input = input;\n    }\n  }\n\n  private _dateFilter: (date: T | null) => boolean = () => true;\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    if (!this.placeholder) {\n      this._placeholderMutable = true;\n      this.placeholder = i18nDatePickerPlaceholder[this.language.current];\n    }\n    for (const child of Array.from(this.closest('sbb-form-field')?.children ?? [])) {\n      // Elements must be upgraded in order for the constructor to be accessible.\n      customElements.upgrade?.(child);\n      if (\n        (child.constructor as { sbbDateInputAssociated?: boolean }).sbbDateInputAssociated &&\n        !child.hasAttribute('input') &&\n        !(child as Partial<SbbDateInputAssociated<T>>).input\n      ) {\n        (child as Partial<SbbDateInputAssociated<T>>).input = this;\n      }\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 (this.hasUpdated && !name) {\n      this._updateValueDateFormat();\n      if (this._placeholderMutable) {\n        this.placeholder = i18nDatePickerPlaceholder[this.language.current];\n      }\n    } else if (name === 'weekdayStyle') {\n      this._updateValueDateFormat();\n    }\n    if (this.isConnected) {\n      // Used to notify associated components to update state\n      /** @internal */\n      this.dispatchEvent(new Event('ɵchange'));\n    }\n  }\n\n  protected override updateFormValue(): void {\n    this._tryParseValue();\n    const formValue =\n      this.valueAsDate !== null ? this._dateAdapter.toIso8601(this.valueAsDate) : null;\n    this.internals.setFormValue(formValue, this.value);\n  }\n\n  private _tryParseValue(value = this.value): void {\n    if (this._valueCache?.[0] !== value) {\n      this._valueAsDate = this._dateAdapter.parse(value);\n      this._valueCache = [value, this._valueAsDate];\n    }\n  }\n\n  private _updateValueDateFormat(): void {\n    if (this.valueAsDate) {\n      const formattedDate = this._formatDate();\n      if (this.value !== formattedDate) {\n        super.value = formattedDate;\n      }\n    }\n  }\n\n  private _formatDate(): string {\n    return this._dateAdapter.format(this.valueAsDate, { weekdayStyle: this.weekdayStyle });\n  }\n\n  protected override shouldValidate(name: PropertyKey | undefined): boolean {\n    return (\n      super.shouldValidate(name) ||\n      ['valueAsDate', 'min', 'max', 'dateFilter'].includes(name as string)\n    );\n  }\n\n  protected override validate(): void {\n    super.validate();\n    if (!this.value) {\n      this._removeValidityErrors();\n    } else if (!this._dateAdapter.isValid(this.valueAsDate)) {\n      this.setValidityFlag('badInput', i18nDateInvalid[this.language.current]);\n    } else if (\n      this._dateAdapter.isValid(this.min) &&\n      this._dateAdapter.compareDate(this.min, this.valueAsDate) > 0\n    ) {\n      this.setValidityFlag(\n        'rangeUnderflow',\n        i18nDateMin(this._dateAdapter.format(this.min, { weekdayStyle: 'none' }))[\n          this.language.current\n        ],\n      );\n    } else if (\n      this._dateAdapter.isValid(this.max) &&\n      this._dateAdapter.compareDate(this.valueAsDate, this.max) > 0\n    ) {\n      this.setValidityFlag(\n        'rangeOverflow',\n        i18nDateMax(this._dateAdapter.format(this.max, { weekdayStyle: 'none' }))[\n          this.language.current\n        ],\n      );\n    } else if (this.dateFilter && !this.dateFilter(this.valueAsDate)) {\n      this.setValidityFlag('sbbDateFilter', i18nDateInvalid[this.language.current]);\n    } else {\n      this._removeValidityErrors();\n    }\n  }\n\n  private _removeValidityErrors(): void {\n    (['badInput', 'rangeUnderflow', 'rangeOverflow', 'sbbDateFilter'] as const).forEach((f) =>\n      this.removeValidityFlag(f),\n    );\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-date-input': SbbDateInputElement;\n  }\n\n  interface CustomValidityState {\n    sbbDateFilter: boolean;\n  }\n}\n"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as SbbDateInputElement } from "./date-input.component-
|
|
1
|
+
import { t as SbbDateInputElement } from "./date-input.component-UP1afzgy.js";
|
|
2
2
|
export { SbbDateInputElement };
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { n as SbbFormFieldElement, t as SbbFormFieldControlEvent } from "../../form-field.component-
|
|
1
|
+
import { n as SbbFormFieldElement, t as SbbFormFieldControlEvent } from "../../form-field.component-DnUA6Uds.js";
|
|
2
2
|
export { SbbFormFieldControlEvent, SbbFormFieldElement };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { n as SbbFormFieldElement, t as SbbFormFieldControlEvent } from "../form-field.component-
|
|
1
|
+
import { n as SbbFormFieldElement, t as SbbFormFieldControlEvent } from "../form-field.component-DnUA6Uds.js";
|
|
2
2
|
//#region src/elements/form-field/form-field.ts
|
|
3
3
|
/** @entrypoint */
|
|
4
4
|
SbbFormFieldElement.define();
|