@sbb-esta/lyne-elements-dev 4.5.1-dev.1772017123 → 4.5.1-dev.1772034641
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/calendar/{calendar.component.js → calendar/calendar.component.js} +413 -401
- package/calendar/calendar-day/calendar-day.component.js +98 -0
- package/calendar/calendar-day.js +4 -0
- package/calendar/calendar.js +5 -0
- package/calendar.js +5 -2
- package/custom-elements.json +18816 -17938
- package/datepicker/datepicker/datepicker.component.js +1 -1
- package/development/calendar/{calendar.component.d.ts → calendar/calendar.component.d.ts} +23 -3
- package/development/calendar/calendar/calendar.component.d.ts.map +1 -0
- package/development/calendar/calendar/calendar.component.js +1990 -0
- package/development/calendar/calendar-day/calendar-day.component.d.ts +49 -0
- package/development/calendar/calendar-day/calendar-day.component.d.ts.map +1 -0
- package/development/calendar/calendar-day/calendar-day.component.js +255 -0
- package/development/calendar/calendar-day.d.ts +5 -0
- package/development/calendar/calendar-day.d.ts.map +1 -0
- package/development/calendar/calendar-day.js +5 -0
- package/development/calendar/calendar.d.ts +5 -0
- package/development/calendar/calendar.d.ts.map +1 -0
- package/development/calendar/calendar.js +6 -0
- package/development/calendar.d.ts +2 -1
- package/development/calendar.d.ts.map +1 -1
- package/development/calendar.js +6 -3
- package/development/datepicker/datepicker/datepicker.component.d.ts.map +1 -1
- package/development/datepicker/datepicker/datepicker.component.js +2 -1
- package/index.d.ts +3 -1
- package/index.js +3 -1
- package/package.json +12 -2
- package/development/calendar/calendar.component.d.ts.map +0 -1
- package/development/calendar/calendar.component.js +0 -1957
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { CSSResultGroup, TemplateResult } from 'lit';
|
|
2
|
+
import { SbbButtonLikeBaseElement } from '../../core/base-elements.ts';
|
|
3
|
+
import { DateAdapter } from '../../core/datetime/date-adapter.ts';
|
|
4
|
+
import { FormRestoreReason, FormRestoreState } from '../../core/mixins.ts';
|
|
5
|
+
declare const SbbCalendarDayElement_base: import('../../core/mixins.ts').AbstractConstructor<import('../../core/mixins.ts').SbbDisabledMixinType> & typeof SbbButtonLikeBaseElement;
|
|
6
|
+
/**
|
|
7
|
+
* It displays a single day cell in the `sbb-calendar` component.
|
|
8
|
+
*
|
|
9
|
+
* @slot - Use the unnamed slot to add some custom content to the day.
|
|
10
|
+
*/
|
|
11
|
+
export declare class SbbCalendarDayElement<T extends Date = Date> extends SbbCalendarDayElement_base {
|
|
12
|
+
static styles: CSSResultGroup;
|
|
13
|
+
protected dateAdapter: DateAdapter;
|
|
14
|
+
set slot(value: string);
|
|
15
|
+
get slot(): string;
|
|
16
|
+
/** Value of the calendar-day element. */
|
|
17
|
+
set value(value: T | null);
|
|
18
|
+
get value(): T | null;
|
|
19
|
+
private _value;
|
|
20
|
+
constructor();
|
|
21
|
+
/**
|
|
22
|
+
* Intentionally empty, as buttons are not targeted by form reset.
|
|
23
|
+
* @internal
|
|
24
|
+
*/
|
|
25
|
+
formResetCallback(): void;
|
|
26
|
+
/**
|
|
27
|
+
* Intentionally empty, as buttons are not targeted by form restore.
|
|
28
|
+
* @internal
|
|
29
|
+
*/
|
|
30
|
+
formStateRestoreCallback(_state: FormRestoreState | null, _reason: FormRestoreReason): void;
|
|
31
|
+
connectedCallback(): void;
|
|
32
|
+
/**
|
|
33
|
+
* The component is used as the default day cell within the `sbb-calendar`,
|
|
34
|
+
* or, if extra content is needed, it can be slotted.
|
|
35
|
+
*/
|
|
36
|
+
private _getParent;
|
|
37
|
+
private _setSelectedState;
|
|
38
|
+
private _setDisabledFilteredState;
|
|
39
|
+
private _isActiveDate;
|
|
40
|
+
private _isDayInRange;
|
|
41
|
+
protected renderTemplate(): TemplateResult;
|
|
42
|
+
}
|
|
43
|
+
declare global {
|
|
44
|
+
interface HTMLElementTagNameMap {
|
|
45
|
+
'sbb-calendar-day': SbbCalendarDayElement;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
export {};
|
|
49
|
+
//# sourceMappingURL=calendar-day.component.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"calendar-day.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/calendar/calendar-day/calendar-day.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAI1D,OAAO,EAAE,wBAAwB,EAAE,MAAM,6BAA6B,CAAC;AAGvE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,qCAAqC,CAAC;AAEvE,OAAO,EACL,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,EAEtB,MAAM,sBAAsB,CAAC;;AAM9B;;;;GAIG;AACH,qBAEM,qBAAqB,CAAC,CAAC,SAAS,IAAI,GAAG,IAAI,CAAE,SAAQ,0BAE1D;IACC,OAAuB,MAAM,EAAE,cAAc,CAA4B;IACzE,SAAS,CAAC,WAAW,EAAE,WAAW,CAA4D;IAE9F,IACoB,IAAI,CAAC,KAAK,EAAE,MAAM,EAGrC;IACD,IAAoB,IAAI,IAAI,MAAM,CAEjC;IAED,yCAAyC;IACzC,IACW,KAAK,CAAC,KAAK,EAAE,CAAC,GAAG,IAAI,EAc/B;IACD,IAAW,KAAK,IAAI,CAAC,GAAG,IAAI,CAE3B;IACD,OAAO,CAAC,MAAM,CAAkB;;IAchC;;;OAGG;IACa,iBAAiB,IAAI,IAAI;IAEzC;;;OAGG;IACa,wBAAwB,CACtC,MAAM,EAAE,gBAAgB,GAAG,IAAI,EAC/B,OAAO,EAAE,iBAAiB,GACzB,IAAI;IAES,iBAAiB,IAAI,IAAI;IAKzC;;;OAGG;IACH,OAAO,CAAC,UAAU;IAOlB,OAAO,CAAC,iBAAiB;IAUzB,OAAO,CAAC,yBAAyB;IAQjC,OAAO,CAAC,aAAa;IAIrB,OAAO,CAAC,aAAa;cAOF,cAAc,IAAI,cAAc;CAQpD;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,kBAAkB,EAAE,qBAAqB,CAAC;KAC3C;CACF"}
|
|
@@ -0,0 +1,255 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
+
import { css, html } from "lit";
|
|
3
|
+
import { customElement, property, state } from "lit/decorators.js";
|
|
4
|
+
import { SbbButtonLikeBaseElement } from "../../core/base-elements.js";
|
|
5
|
+
import { readConfig } from "../../core/config/config.js";
|
|
6
|
+
import { SbbPropertyWatcherController } from "../../core/controllers.js";
|
|
7
|
+
import { defaultDateAdapter } from "../../core/datetime/native-date-adapter.js";
|
|
8
|
+
import { SbbDisabledMixin } from "../../core/mixins.js";
|
|
9
|
+
import { boxSizingStyles } from "../../core/styles.js";
|
|
10
|
+
const style = css`:host {
|
|
11
|
+
display: block;
|
|
12
|
+
--sbb-calendar-day-width: 2.75rem;
|
|
13
|
+
--sbb-calendar-day-height: 3rem;
|
|
14
|
+
--sbb-calendar-day-cell-background-color: var(--sbb-calendar-cell-background-color);
|
|
15
|
+
--sbb-calendar-day-selected-border: none;
|
|
16
|
+
--sbb-calendar-day-transition-duration: var(
|
|
17
|
+
--sbb-disable-animation-duration,
|
|
18
|
+
var(--sbb-animation-duration-2x)
|
|
19
|
+
);
|
|
20
|
+
--sbb-calendar-day-transition-easing-function: var(--sbb-animation-easing);
|
|
21
|
+
--sbb-calendar-day-cursor: var(--sbb-cursor-pointer);
|
|
22
|
+
--sbb-calendar-day-border-radius: var(--sbb-border-radius-4x);
|
|
23
|
+
--sbb-calendar-day-flex-direction: column;
|
|
24
|
+
--sbb-calendar-day-justify-content: initial;
|
|
25
|
+
--sbb-calendar-day-align-items: initial;
|
|
26
|
+
--sbb-calendar-day-value-height: var(--sbb-spacing-fixed-6x);
|
|
27
|
+
--sbb-calendar-day-extra-display: block;
|
|
28
|
+
--sbb-calendar-day-extra-height: var(--sbb-spacing-fixed-4x);
|
|
29
|
+
--sbb-calendar-day-crossed-out-top: 33%;
|
|
30
|
+
--sbb-calendar-day-crossed-out-translate: translate(-50%, -33%) rotate(-45deg);
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
:host(:is(:state(selected),[state--selected])) {
|
|
34
|
+
--sbb-calendar-day-selected-border: var(--sbb-border-width-2x) solid var(--sbb-border-color-2);
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
:host(:disabled) {
|
|
38
|
+
--sbb-calendar-cell-color: var(--sbb-calendar-cell-disabled-color);
|
|
39
|
+
--sbb-calendar-day-cursor: unset;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
:host(:focus-visible) {
|
|
43
|
+
outline: 0;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
:host(:not(:disabled):active) {
|
|
47
|
+
--sbb-calendar-day-cell-background-color: var(--sbb-calendar-cell-background-color-active);
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
.sbb-calendar-day {
|
|
51
|
+
--sbb-text-font-size: var(--sbb-text-font-size-s);
|
|
52
|
+
font-family: var(--sbb-typo-font-family);
|
|
53
|
+
font-weight: normal;
|
|
54
|
+
line-height: var(--sbb-typo-line-height-text);
|
|
55
|
+
letter-spacing: var(--sbb-typo-letter-spacing-text);
|
|
56
|
+
font-size: var(--sbb-text-font-size);
|
|
57
|
+
display: flex;
|
|
58
|
+
flex-direction: var(--sbb-calendar-day-flex-direction);
|
|
59
|
+
justify-content: var(--sbb-calendar-day-justify-content);
|
|
60
|
+
align-items: var(--sbb-calendar-day-align-items);
|
|
61
|
+
height: var(--sbb-calendar-day-height);
|
|
62
|
+
width: var(--sbb-calendar-day-width);
|
|
63
|
+
padding: var(--sbb-calendar-cell-padding);
|
|
64
|
+
padding-block-end: var(--sbb-calendar-day-cell-padding-hover, var(--sbb-calendar-cell-padding));
|
|
65
|
+
margin: auto;
|
|
66
|
+
color: var(--sbb-calendar-cell-color);
|
|
67
|
+
cursor: var(--sbb-calendar-day-cursor);
|
|
68
|
+
position: relative;
|
|
69
|
+
z-index: 0;
|
|
70
|
+
}
|
|
71
|
+
.sbb-calendar-day::before {
|
|
72
|
+
content: "";
|
|
73
|
+
position: absolute;
|
|
74
|
+
inset: 0;
|
|
75
|
+
background-color: var(--sbb-calendar-day-cell-background-color);
|
|
76
|
+
border: var(--sbb-calendar-day-selected-border);
|
|
77
|
+
border-radius: var(--sbb-calendar-day-border-radius);
|
|
78
|
+
z-index: -1;
|
|
79
|
+
transition-duration: var(--sbb-calendar-day-transition-duration);
|
|
80
|
+
transition-timing-function: var(--sbb-calendar-day-transition-easing-function);
|
|
81
|
+
transition-property: background-color;
|
|
82
|
+
}
|
|
83
|
+
:host(:focus-visible) .sbb-calendar-day::before {
|
|
84
|
+
outline-offset: var(--sbb-focus-outline-offset);
|
|
85
|
+
outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);
|
|
86
|
+
}
|
|
87
|
+
@media (forced-colors: active) {
|
|
88
|
+
:host(:not(:disabled):active) .sbb-calendar-day::before {
|
|
89
|
+
outline-offset: var(--sbb-focus-outline-offset);
|
|
90
|
+
outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);
|
|
91
|
+
--sbb-focus-outline-style: initial;
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
@media (any-hover: hover) {
|
|
95
|
+
:host(:not(:active, :disabled):hover) .sbb-calendar-day {
|
|
96
|
+
--sbb-calendar-day-cell-background-color: var(--sbb-calendar-cell-background-color-hover);
|
|
97
|
+
--sbb-calendar-day-cell-padding-hover: calc(
|
|
98
|
+
0.0625rem + var(--sbb-calendar-cell-padding)
|
|
99
|
+
);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
@media (any-hover: hover) and (forced-colors: active) {
|
|
103
|
+
:host(:not(:active, :disabled):hover) .sbb-calendar-day::before {
|
|
104
|
+
outline-offset: var(--sbb-focus-outline-offset);
|
|
105
|
+
outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);
|
|
106
|
+
--sbb-focus-outline-style: initial;
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
.sbb-calendar-day__value {
|
|
111
|
+
height: var(--sbb-calendar-day-value-height);
|
|
112
|
+
}
|
|
113
|
+
:host(:is(:state(current),[state--current])) .sbb-calendar-day__value {
|
|
114
|
+
font-weight: bold;
|
|
115
|
+
}
|
|
116
|
+
:host(:is(:state(crossed-out),[state--crossed-out])) .sbb-calendar-day__value::after {
|
|
117
|
+
content: "";
|
|
118
|
+
height: var(--sbb-calendar-cell-disabled-height);
|
|
119
|
+
width: var(--sbb-calendar-cell-disabled-width);
|
|
120
|
+
position: absolute;
|
|
121
|
+
background-color: var(--sbb-calendar-cell-disabled-color);
|
|
122
|
+
inset-block-start: var(--sbb-calendar-day-crossed-out-top);
|
|
123
|
+
inset-inline-start: 50%;
|
|
124
|
+
transform: var(--sbb-calendar-day-crossed-out-translate);
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
.sbb-calendar-day__extra {
|
|
128
|
+
display: var(--sbb-calendar-day-extra-display);
|
|
129
|
+
height: var(--sbb-calendar-day-extra-height);
|
|
130
|
+
padding: var(--sbb-calendar-cell-padding);
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
::slotted(*) {
|
|
134
|
+
height: 1rem;
|
|
135
|
+
}`;
|
|
136
|
+
let SbbCalendarDayElement = (() => {
|
|
137
|
+
var _a;
|
|
138
|
+
let _classDecorators = [customElement("sbb-calendar-day")];
|
|
139
|
+
let _classDescriptor;
|
|
140
|
+
let _classExtraInitializers = [];
|
|
141
|
+
let _classThis;
|
|
142
|
+
let _classSuper = SbbDisabledMixin(SbbButtonLikeBaseElement);
|
|
143
|
+
let _instanceExtraInitializers = [];
|
|
144
|
+
let _set_slot_decorators;
|
|
145
|
+
let _set_value_decorators;
|
|
146
|
+
_a = class extends _classSuper {
|
|
147
|
+
set slot(value) {
|
|
148
|
+
super.slot = value;
|
|
149
|
+
this.value = this.dateAdapter.deserialize(value);
|
|
150
|
+
}
|
|
151
|
+
get slot() {
|
|
152
|
+
return super.slot;
|
|
153
|
+
}
|
|
154
|
+
/** Value of the calendar-day element. */
|
|
155
|
+
set value(value) {
|
|
156
|
+
const date = this.dateAdapter.getValidDateOrNull(this.dateAdapter.deserialize(value));
|
|
157
|
+
if (date) {
|
|
158
|
+
this._value = date;
|
|
159
|
+
const isToday = this.dateAdapter.sameDate(date, this.dateAdapter.today());
|
|
160
|
+
this.toggleState("current", isToday);
|
|
161
|
+
this.internals.ariaCurrent = isToday ? "date" : null;
|
|
162
|
+
this.internals.ariaLabel = this.dateAdapter.getAccessibilityFormatDate(date);
|
|
163
|
+
const parent = this._getParent();
|
|
164
|
+
if (parent) {
|
|
165
|
+
this._setDisabledFilteredState(parent);
|
|
166
|
+
this._setSelectedState(parent);
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
get value() {
|
|
171
|
+
return this._value;
|
|
172
|
+
}
|
|
173
|
+
constructor() {
|
|
174
|
+
super();
|
|
175
|
+
this.dateAdapter = (__runInitializers(this, _instanceExtraInitializers), readConfig().datetime?.dateAdapter ?? defaultDateAdapter);
|
|
176
|
+
this._value = null;
|
|
177
|
+
this.addController(new SbbPropertyWatcherController(this, () => this._getParent(), {
|
|
178
|
+
dateFilter: (component) => this._setDisabledFilteredState(component),
|
|
179
|
+
min: (component) => this._setDisabledFilteredState(component),
|
|
180
|
+
max: (component) => this._setDisabledFilteredState(component),
|
|
181
|
+
selected: (component) => this._setSelectedState(component)
|
|
182
|
+
}));
|
|
183
|
+
}
|
|
184
|
+
/**
|
|
185
|
+
* Intentionally empty, as buttons are not targeted by form reset.
|
|
186
|
+
* @internal
|
|
187
|
+
*/
|
|
188
|
+
formResetCallback() {
|
|
189
|
+
}
|
|
190
|
+
/**
|
|
191
|
+
* Intentionally empty, as buttons are not targeted by form restore.
|
|
192
|
+
* @internal
|
|
193
|
+
*/
|
|
194
|
+
formStateRestoreCallback(_state, _reason) {
|
|
195
|
+
}
|
|
196
|
+
connectedCallback() {
|
|
197
|
+
super.connectedCallback();
|
|
198
|
+
this.tabIndex = -1;
|
|
199
|
+
}
|
|
200
|
+
/**
|
|
201
|
+
* The component is used as the default day cell within the `sbb-calendar`,
|
|
202
|
+
* or, if extra content is needed, it can be slotted.
|
|
203
|
+
*/
|
|
204
|
+
_getParent() {
|
|
205
|
+
return this.closest?.("sbb-calendar") ?? this.getRootNode?.()?.host?.closest("sbb-calendar");
|
|
206
|
+
}
|
|
207
|
+
_setSelectedState(component) {
|
|
208
|
+
const selected = component.multiple ? component.selected.some((selDay) => this.dateAdapter.sameDate(this.value, selDay)) : !!component.selected && this.dateAdapter.compareDate(this.value, component.selected) === 0;
|
|
209
|
+
this.toggleState("selected", selected);
|
|
210
|
+
this.internals.ariaPressed = String(selected);
|
|
211
|
+
}
|
|
212
|
+
_setDisabledFilteredState(component) {
|
|
213
|
+
const isFilteredOut = !this._isActiveDate(component.dateFilter);
|
|
214
|
+
const isOutOfRange = !this._isDayInRange(component.min, component.max);
|
|
215
|
+
this.disabled = isFilteredOut || isOutOfRange;
|
|
216
|
+
this.internals.ariaDisabled = String(this.disabled);
|
|
217
|
+
this.toggleState("crossed-out", isFilteredOut && !isOutOfRange);
|
|
218
|
+
}
|
|
219
|
+
_isActiveDate(dateFilter) {
|
|
220
|
+
return dateFilter?.(this.value) ?? true;
|
|
221
|
+
}
|
|
222
|
+
_isDayInRange(min, max) {
|
|
223
|
+
if (!min && !max) {
|
|
224
|
+
return true;
|
|
225
|
+
}
|
|
226
|
+
return this.dateAdapter.sameDate(this.value, this.dateAdapter.clampDate(this.value, min, max));
|
|
227
|
+
}
|
|
228
|
+
renderTemplate() {
|
|
229
|
+
return html` <span class="sbb-calendar-day__value" aria-hidden="true">
|
|
230
|
+
${this.dateAdapter.getDate(this.value)}
|
|
231
|
+
</span>
|
|
232
|
+
<span class="sbb-calendar-day__extra">
|
|
233
|
+
<slot></slot>
|
|
234
|
+
</span>`;
|
|
235
|
+
}
|
|
236
|
+
}, _classThis = _a, (() => {
|
|
237
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
238
|
+
_set_slot_decorators = [property()];
|
|
239
|
+
_set_value_decorators = [state()];
|
|
240
|
+
__esDecorate(_a, null, _set_slot_decorators, { kind: "setter", name: "slot", static: false, private: false, access: { has: (obj) => "slot" in obj, set: (obj, value) => {
|
|
241
|
+
obj.slot = value;
|
|
242
|
+
} }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
243
|
+
__esDecorate(_a, null, _set_value_decorators, { kind: "setter", name: "value", static: false, private: false, access: { has: (obj) => "value" in obj, set: (obj, value) => {
|
|
244
|
+
obj.value = value;
|
|
245
|
+
} }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
246
|
+
__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
|
|
247
|
+
_classThis = _classDescriptor.value;
|
|
248
|
+
if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
249
|
+
})(), _a.styles = [boxSizingStyles, style], __runInitializers(_classThis, _classExtraInitializers), _a;
|
|
250
|
+
return _classThis;
|
|
251
|
+
})();
|
|
252
|
+
export {
|
|
253
|
+
SbbCalendarDayElement
|
|
254
|
+
};
|
|
255
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"calendar-day.component.js","sources":["../../../../../src/elements/calendar/calendar-day/calendar-day.component.ts"],"sourcesContent":["import type { CSSResultGroup, TemplateResult } from 'lit';\nimport { html } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\n\nimport { SbbButtonLikeBaseElement } from '../../core/base-elements.ts';\nimport { readConfig } from '../../core/config/config.ts';\nimport { SbbPropertyWatcherController } from '../../core/controllers.ts';\nimport type { DateAdapter } from '../../core/datetime/date-adapter.ts';\nimport { defaultDateAdapter } from '../../core/datetime/native-date-adapter.ts';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbDisabledMixin,\n} from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport type { SbbCalendarElement } from '../calendar/calendar.component.ts';\n\nimport style from './calendar-day.scss?lit&inline';\n\n/**\n * It displays a single day cell in the `sbb-calendar` component.\n *\n * @slot - Use the unnamed slot to add some custom content to the day.\n */\nexport\n@customElement('sbb-calendar-day')\nclass SbbCalendarDayElement<T extends Date = Date> extends SbbDisabledMixin(\n  SbbButtonLikeBaseElement,\n) {\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  protected dateAdapter: DateAdapter = readConfig().datetime?.dateAdapter ?? defaultDateAdapter;\n\n  @property()\n  public override set slot(value: string) {\n    super.slot = value;\n    this.value = this.dateAdapter.deserialize(value);\n  }\n  public override get slot(): string {\n    return super.slot;\n  }\n\n  /** Value of the calendar-day element. */\n  @state()\n  public set value(value: T | null) {\n    const date = this.dateAdapter.getValidDateOrNull(this.dateAdapter.deserialize(value));\n    if (date) {\n      this._value = date;\n      const isToday = this.dateAdapter.sameDate(date, this.dateAdapter.today());\n      this.toggleState('current', isToday);\n      this.internals.ariaCurrent = isToday ? 'date' : null;\n      this.internals.ariaLabel = this.dateAdapter.getAccessibilityFormatDate(date);\n      const parent = this._getParent();\n      if (parent) {\n        this._setDisabledFilteredState(parent);\n        this._setSelectedState(parent);\n      }\n    }\n  }\n  public get value(): T | null {\n    return this._value;\n  }\n  private _value: T | null = null;\n\n  public constructor() {\n    super();\n    this.addController(\n      new SbbPropertyWatcherController(this, () => this._getParent(), {\n        dateFilter: (component) => this._setDisabledFilteredState(component),\n        min: (component) => this._setDisabledFilteredState(component),\n        max: (component) => this._setDisabledFilteredState(component),\n        selected: (component) => this._setSelectedState(component),\n      }),\n    );\n  }\n\n  /**\n   * Intentionally empty, as buttons are not targeted by form reset.\n   * @internal\n   */\n  public override formResetCallback(): void {}\n\n  /**\n   * Intentionally empty, as buttons are not targeted by form restore.\n   * @internal\n   */\n  public override formStateRestoreCallback(\n    _state: FormRestoreState | null,\n    _reason: FormRestoreReason,\n  ): void {}\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.tabIndex = -1;\n  }\n\n  /**\n   * The component is used as the default day cell within the `sbb-calendar`,\n   * or, if extra content is needed, it can be slotted.\n   */\n  private _getParent(): SbbCalendarElement | null {\n    return (\n      this.closest?.<SbbCalendarElement>('sbb-calendar') ??\n      (this.getRootNode?.() as ShadowRoot)?.host?.closest('sbb-calendar')\n    );\n  }\n\n  private _setSelectedState(component: SbbCalendarElement): void {\n    const selected = component.multiple\n      ? (component.selected as Date[]).some((selDay) =>\n          this.dateAdapter.sameDate(this.value, selDay),\n        )\n      : !!component.selected && this.dateAdapter.compareDate(this.value, component.selected) === 0;\n    this.toggleState('selected', selected);\n    this.internals.ariaPressed = String(selected);\n  }\n\n  private _setDisabledFilteredState(component: SbbCalendarElement): void {\n    const isFilteredOut = !this._isActiveDate(component.dateFilter);\n    const isOutOfRange = !this._isDayInRange(component.min, component.max);\n    this.disabled = isFilteredOut || isOutOfRange;\n    this.internals.ariaDisabled = String(this.disabled);\n    this.toggleState('crossed-out', isFilteredOut && !isOutOfRange);\n  }\n\n  private _isActiveDate(dateFilter: ((date: Date | null) => boolean) | null): boolean {\n    return dateFilter?.(this.value) ?? true;\n  }\n\n  private _isDayInRange(min: Date | null, max: Date | null): boolean {\n    if (!min && !max) {\n      return true;\n    }\n    return this.dateAdapter.sameDate(this.value, this.dateAdapter.clampDate(this.value, min, max));\n  }\n\n  protected override renderTemplate(): TemplateResult {\n    return html` <span class=\"sbb-calendar-day__value\" aria-hidden=\"true\">\n        ${this.dateAdapter.getDate(this.value)}\n      </span>\n      <span class=\"sbb-calendar-day__extra\">\n        <slot></slot>\n      </span>`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-calendar-day': SbbCalendarDayElement;\n  }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"calendar-day.d.ts","sourceRoot":"","sources":["../../../../src/elements/calendar/calendar-day.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,cAAc,0CAA0C,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { SbbCalendarDayElement } from "./calendar-day/calendar-day.component.js";
|
|
2
|
+
export {
|
|
3
|
+
SbbCalendarDayElement
|
|
4
|
+
};
|
|
5
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXItZGF5LmpzIiwic291cmNlcyI6W10sInNvdXJjZXNDb250ZW50IjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjsifQ==
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"calendar.d.ts","sourceRoot":"","sources":["../../../../src/elements/calendar/calendar.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,cAAc,kCAAkC,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { SbbCalendarElement, SbbMonthChangeEvent } from "./calendar/calendar.component.js";
|
|
2
|
+
export {
|
|
3
|
+
SbbCalendarElement,
|
|
4
|
+
SbbMonthChangeEvent
|
|
5
|
+
};
|
|
6
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIuanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOyJ9
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"calendar.d.ts","sourceRoot":"","sources":["../../../src/elements/calendar.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,cAAc,
|
|
1
|
+
{"version":3,"file":"calendar.d.ts","sourceRoot":"","sources":["../../../src/elements/calendar.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,cAAc,wBAAwB,CAAC;AACvC,cAAc,4BAA4B,CAAC"}
|
package/development/calendar.js
CHANGED
|
@@ -1,5 +1,8 @@
|
|
|
1
|
-
import { SbbCalendarElement } from "./calendar/calendar.component.js";
|
|
1
|
+
import { SbbCalendarElement, SbbMonthChangeEvent } from "./calendar/calendar/calendar.component.js";
|
|
2
|
+
import { SbbCalendarDayElement } from "./calendar/calendar-day/calendar-day.component.js";
|
|
2
3
|
export {
|
|
3
|
-
|
|
4
|
+
SbbCalendarDayElement,
|
|
5
|
+
SbbCalendarElement,
|
|
6
|
+
SbbMonthChangeEvent
|
|
4
7
|
};
|
|
5
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
8
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIuanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzsifQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"datepicker.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/datepicker/datepicker/datepicker.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAInB,KAAK,mBAAmB,EACxB,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAGb,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAOtD,OAAO,EAAE,KAAK,sBAAsB,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AACvF,OAAO,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AAKzD,OAAO,mBAAmB,CAAC;;AAI3B;;;GAGG;AACH,qBAEM,oBAAoB,CAAC,CAAC,GAAG,IAAI,CACjC,SAAQ,yBACR,YAAW,sBAAsB,CAAC,CAAC,CAAC;IAEpC,OAAuB,MAAM,EAAE,cAAc,CAAyC;IACtF,gBAAuB,sBAAsB,QAAQ;IAErD,gDAAgD;IAChD,SAEgB,IAAI,EAAE,OAAO,CAAS;IAEtC;;;;OAIG;IACH,SAEgB,KAAK,EAAE,mBAAmB,CAAC,CAAC,CAAC,GAAG,IAAI,CAAQ;IAE5D,yEAAyE;IACzE,SAA4B,IAAI,EAAE,YAAY,CAAS;IAEvD,OAAO,CAAC,qBAAqB,CAAC,CAAkB;IAChD,OAAO,CAAC,YAAY,CAA4E;IAChG,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,MAAM,CAAS;;IAaP,iBAAiB,IAAI,IAAI;IAezB,aAAa,CAC3B,IAAI,CAAC,EAAE,WAAW,EAClB,QAAQ,CAAC,EAAE,OAAO,EAClB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,IAAI;cAkBY,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAW9E,OAAO,CAAC,aAAa;cAmBF,aAAa,IAAI,cAAc;
|
|
1
|
+
{"version":3,"file":"datepicker.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/datepicker/datepicker/datepicker.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAInB,KAAK,mBAAmB,EACxB,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAGb,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAOtD,OAAO,EAAE,KAAK,sBAAsB,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AACvF,OAAO,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AAKzD,OAAO,mBAAmB,CAAC;;AAI3B;;;GAGG;AACH,qBAEM,oBAAoB,CAAC,CAAC,GAAG,IAAI,CACjC,SAAQ,yBACR,YAAW,sBAAsB,CAAC,CAAC,CAAC;IAEpC,OAAuB,MAAM,EAAE,cAAc,CAAyC;IACtF,gBAAuB,sBAAsB,QAAQ;IAErD,gDAAgD;IAChD,SAEgB,IAAI,EAAE,OAAO,CAAS;IAEtC;;;;OAIG;IACH,SAEgB,KAAK,EAAE,mBAAmB,CAAC,CAAC,CAAC,GAAG,IAAI,CAAQ;IAE5D,yEAAyE;IACzE,SAA4B,IAAI,EAAE,YAAY,CAAS;IAEvD,OAAO,CAAC,qBAAqB,CAAC,CAAkB;IAChD,OAAO,CAAC,YAAY,CAA4E;IAChG,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,MAAM,CAAS;;IAaP,iBAAiB,IAAI,IAAI;IAezB,aAAa,CAC3B,IAAI,CAAC,EAAE,WAAW,EAClB,QAAQ,CAAC,EAAE,OAAO,EAClB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,IAAI;cAkBY,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAW9E,OAAO,CAAC,aAAa;cAmBF,aAAa,IAAI,cAAc;cAyB/B,MAAM,IAAI,cAAc;CAG5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,gBAAgB,EAAE,oBAAoB,CAAC;KACxC;CACF"}
|
|
@@ -152,6 +152,7 @@ let SbbDatepickerElement = (() => {
|
|
|
152
152
|
this.input.dispatchEvent(new InputEvent("input", { bubbles: true, composed: true }));
|
|
153
153
|
this.input.dispatchEvent(new Event("change", { bubbles: true, composed: true }));
|
|
154
154
|
this.input.dispatchEvent(new Event("blur", { composed: true }));
|
|
155
|
+
this.close();
|
|
155
156
|
}
|
|
156
157
|
}}
|
|
157
158
|
></sbb-calendar>
|
|
@@ -183,4 +184,4 @@ let SbbDatepickerElement = (() => {
|
|
|
183
184
|
export {
|
|
184
185
|
SbbDatepickerElement
|
|
185
186
|
};
|
|
186
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"datepicker.component.js","sources":["../../../../../src/elements/datepicker/datepicker/datepicker.component.ts"],"sourcesContent":["import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  nothing,\n  type PropertyDeclaration,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport type { CalendarView } from '../../calendar.ts';\nimport { readConfig } from '../../core/config.ts';\nimport { SbbLanguageController } from '../../core/controllers.ts';\nimport { type DateAdapter, defaultDateAdapter } from '../../core/datetime.ts';\nimport { forceType, idReference } from '../../core/decorators.ts';\nimport { i18nDateChangedTo } from '../../core/i18n.ts';\nimport { SbbUpdateSchedulerMixin } from '../../core/mixins.ts';\nimport { type SbbDateInputAssociated, SbbDateInputElement } from '../../date-input.ts';\nimport { SbbPopoverBaseElement } from '../../popover.ts';\nimport type { SbbDatepickerToggleElement } from '../datepicker-toggle.ts';\n\nimport style from './datepicker.scss?lit&inline';\n\nimport '../../calendar.ts';\n\nlet nextId = 0;\n\n/**\n * A datepicker component that allows users to select a date from a calendar view.\n * @event {CustomEvent<T>} dateselected - Event emitted on date selection.\n */\nexport\n@customElement('sbb-datepicker')\nclass SbbDatepickerElement<T = Date>\n  extends SbbUpdateSchedulerMixin(SbbPopoverBaseElement)\n  implements SbbDateInputAssociated<T>\n{\n  public static override styles: CSSResultGroup = [SbbPopoverBaseElement.styles, style];\n  public static readonly sbbDateInputAssociated = true;\n\n  /** If set to true, two months are displayed. */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor wide: boolean = false;\n\n  /**\n   * Reference to the sbb-date-input instance or the native input connected to the datepicker.\n   *\n   * For attribute usage, provide an id reference.\n   */\n  @idReference()\n  @property()\n  public accessor input: SbbDateInputElement<T> | null = null;\n\n  /** The initial view of calendar which should be displayed on opening. */\n  @property() public accessor view: CalendarView = 'day';\n\n  private _inputAbortController?: AbortController;\n  private _dateAdapter: DateAdapter<T> = readConfig().datetime?.dateAdapter ?? defaultDateAdapter;\n  private _language = new SbbLanguageController(this);\n  private _ready = false;\n\n  public constructor() {\n    super();\n    this.startUpdate();\n    this.addEventListener(SbbPopoverBaseElement.events.beforeopen, () => {\n      this.shadowRoot?.querySelector('sbb-calendar')?.resetPosition?.();\n    });\n    if (!isServer && this.hydrationRequired) {\n      this.hydrationComplete.then(() => this.requestUpdate());\n    }\n  }\n\n  public override connectedCallback(): void {\n    this.id ||= `sbb-datepicker-${++nextId}`;\n    super.connectedCallback();\n\n    const formField = this.closest?.('sbb-form-field');\n    if (formField) {\n      SbbDateInputElement.resolveAssociation(this);\n      const toggle =\n        formField.querySelector<SbbDatepickerToggleElement<T>>('sbb-datepicker-toggle');\n      if (toggle && !toggle.hasAttribute('datepicker')) {\n        toggle.datepicker ??= 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 (name === 'input' && this.input !== oldValue) {\n      this._inputAbortController?.abort();\n      if (this.input) {\n        const { signal } = (this._inputAbortController = new AbortController());\n        this.input?.addEventListener(\n          'ɵchange',\n          () => {\n            super.requestUpdate();\n            this._updateStatus();\n          },\n          { signal },\n        );\n      }\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n    setTimeout(() => {\n      // We want to delay the rendering of the calendar to avoid a slow initial render.\n      // The slow render can be a problem if a large amount of datepickers are rendered at once.\n      this._ready = true;\n      this.requestUpdate();\n      this.completeUpdate();\n    });\n  }\n\n  private _updateStatus(): void {\n    const status = this.shadowRoot?.getElementById('status-container');\n    if (!status) {\n      return;\n    }\n\n    const text = this._dateAdapter.isValid(this.input?.valueAsDate)\n      ? `${i18nDateChangedTo[this._language.current]} ${this._dateAdapter.format(\n          this.input!.valueAsDate,\n          {\n            weekdayStyle: 'long',\n          },\n        )}`\n      : '';\n    if (status.textContent !== text) {\n      status.textContent = text;\n    }\n  }\n\n  protected override renderContent(): TemplateResult {\n    return html`\n      <p id=\"status-container\" role=\"status\"></p>\n      <sbb-calendar\n        .view=${this.view}\n        .min=${this.input?.min ?? null}\n        .max=${this.input?.max ?? null}\n        .dateFilter=${this.input?.dateFilter ?? null}\n        .selected=${this.input?.valueAsDate ?? null}\n        ?wide=${this.wide}\n        @dateselected=${(d: CustomEvent<T>) => {\n          if (this.input) {\n            this.input.valueAsDate = d.detail;\n            this.input.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n            this.input.dispatchEvent(new Event('change', { bubbles: true, composed: true }));\n            // Emit blur event when value is changed programmatically to notify\n            // frameworks that rely on that event to update form status.\n            this.input.dispatchEvent(new Event('blur', { composed: true }));\n          }\n        }}\n      ></sbb-calendar>\n    `;\n  }\n\n  protected override render(): TemplateResult {\n    return isServer || this.hydrationRequired || !this._ready ? html`${nothing}` : super.render();\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-datepicker': SbbDatepickerElement;\n  }\n}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA0BA,IAAI,SAAS;IAQP,wBAAoB,MAAA;;0BADzB,cAAc,gBAAgB,CAAC;;;;oBAEtB,wBAAwB,qBAAqB;;;;;;;;;;AAArD,EAAA,mBAAQ,YAA8C;AAAA,IA4BtD,cAAA;AACE,YAAA;AApBF;AASA;AAGY;AAZI,yBAAA,wBAAA,kBAAA,MAAA,oBAAgB,KAAK;AASrB,yBAAA,0BAAA,kBAAA,MAAA,uBAAA,GAAA,kBAAA,MAAA,qBAAuC,IAAI;AAG/B,yBAAA,yBAAA,kBAAA,MAAA,wBAAA,GAAA,kBAAA,MAAA,oBAAqB,KAAK;AAE9C,WAAA,wBAAqB,kBAAA,MAAA,uBAAA;AACrB,WAAA,eAA+B,WAAA,EAAa,UAAU,eAAe;AACrE,WAAA,YAAY,IAAI,sBAAsB,IAAI;AAC1C,WAAA,SAAS;AAIf,WAAK,YAAA;AACL,WAAK,iBAAiB,sBAAsB,OAAO,YAAY,MAAK;AAClE,aAAK,YAAY,cAAc,cAAc,GAAG,gBAAA;AAAA,MAClD,CAAC;AACD,UAAI,CAAC,YAAY,KAAK,mBAAmB;AACvC,aAAK,kBAAkB,KAAK,MAAM,KAAK,eAAe;AAAA,MACxD;AAAA,IACF;AAAA;AAAA,IA5BA,IAAgB,OAAI;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAApB,IAAgB,KAAI,OAAA;AAAA,yBAAA,wBAAA;AAAA,IAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IASpB,IAAgB,QAAK;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAArB,IAAgB,MAAK,OAAA;AAAA,yBAAA,yBAAA;AAAA,IAAA;AAAA;AAAA,IAGT,IAAgB,OAAI;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAApB,IAAgB,KAAI,OAAA;AAAA,yBAAA,wBAAA;AAAA,IAAA;AAAA,IAkBhB,oBAAiB;AAC/B,WAAK,OAAO,kBAAkB,EAAE,MAAM;AACtC,YAAM,kBAAA;AAEN,YAAM,YAAY,KAAK,UAAU,gBAAgB;AACjD,UAAI,WAAW;AACb,4BAAoB,mBAAmB,IAAI;AAC3C,cAAM,SACJ,UAAU,cAA6C,uBAAuB;AAChF,YAAI,UAAU,CAAC,OAAO,aAAa,YAAY,GAAG;AAChD,iBAAO,eAAe;AAAA,QACxB;AAAA,MACF;AAAA,IACF;AAAA,IAEgB,cACd,MACA,UACA,SAA6B;AAE7B,YAAM,cAAc,MAAM,UAAU,OAAO;AAC3C,UAAI,SAAS,WAAW,KAAK,UAAU,UAAU;AAC/C,aAAK,uBAAuB,MAAA;AAC5B,YAAI,KAAK,OAAO;AACd,gBAAM,EAAE,OAAA,IAAY,KAAK,wBAAwB,IAAI,gBAAA;AACrD,eAAK,OAAO,iBACV,WACA,MAAK;AACH,kBAAM,cAAA;AACN,iBAAK,cAAA;AAAA,UACP,GACA,EAAE,QAAQ;AAAA,QAEd;AAAA,MACF;AAAA,IACF;AAAA,IAEmB,aAAa,mBAAuC;AACrE,YAAM,aAAa,iBAAiB;AACpC,iBAAW,MAAK;AAGd,aAAK,SAAS;AACd,aAAK,cAAA;AACL,aAAK,eAAA;AAAA,MACP,CAAC;AAAA,IACH;AAAA,IAEQ,gBAAa;AACnB,YAAM,SAAS,KAAK,YAAY,eAAe,kBAAkB;AACjE,UAAI,CAAC,QAAQ;AACX;AAAA,MACF;AAEA,YAAM,OAAO,KAAK,aAAa,QAAQ,KAAK,OAAO,WAAW,IAC1D,GAAG,kBAAkB,KAAK,UAAU,OAAO,CAAC,IAAI,KAAK,aAAa,OAChE,KAAK,MAAO,aACZ;AAAA,QACE,cAAc;AAAA,MAAA,CACf,CACF,KACD;AACJ,UAAI,OAAO,gBAAgB,MAAM;AAC/B,eAAO,cAAc;AAAA,MACvB;AAAA,IACF;AAAA,IAEmB,gBAAa;AAC9B,aAAO;AAAA;AAAA;AAAA,gBAGK,KAAK,IAAI;AAAA,eACV,KAAK,OAAO,OAAO,IAAI;AAAA,eACvB,KAAK,OAAO,OAAO,IAAI;AAAA,sBAChB,KAAK,OAAO,cAAc,IAAI;AAAA,oBAChC,KAAK,OAAO,eAAe,IAAI;AAAA,gBACnC,KAAK,IAAI;AAAA,wBACD,CAAC,MAAqB;AACpC,YAAI,KAAK,OAAO;AACd,eAAK,MAAM,cAAc,EAAE;AAC3B,eAAK,MAAM,cAAc,IAAI,WAAW,SAAS,EAAE,SAAS,MAAM,UAAU,KAAA,CAAM,CAAC;AACnF,eAAK,MAAM,cAAc,IAAI,MAAM,UAAU,EAAE,SAAS,MAAM,UAAU,KAAA,CAAM,CAAC;AAG/E,eAAK,MAAM,cAAc,IAAI,MAAM,QAAQ,EAAE,UAAU,KAAA,CAAM,CAAC;AAAA,QAChE;AAAA,MACF,CAAC;AAAA;AAAA;AAAA,IAGP;AAAA,IAEmB,SAAM;AACvB,aAAO,YAAY,KAAK,qBAAqB,CAAC,KAAK,SAAS,OAAO,OAAO,KAAK,MAAM,OAAA;AAAA,IACvF;AAAA,KA3HA,wCASA,yCAGY;;wBAdX,aACA,SAAS,EAAE,MAAM,QAAA,CAAS,CAAC;yBAQ3B,eACA,UAAU;AAIV,uBAAA,CAAA,UAAU;AAZX,iBAAA,IAAA,MAAA,kBAAA,EAAA,MAAA,YAAA,MAAA,QAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,UAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,MAAI,KAAA,CAAA,KAAA,UAAA;AAAA,UAAJ,OAAI;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,oBAAA,uBAAA;AASpB,iBAAA,IAAA,MAAA,mBAAA,EAAA,MAAA,YAAA,MAAA,SAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,WAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,OAAK,KAAA,CAAA,KAAA,UAAA;AAAA,UAAL,QAAK;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,qBAAA,wBAAA;AAGT,iBAAA,IAAA,MAAA,kBAAA,EAAA,MAAA,YAAA,MAAA,QAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,UAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,MAAI,KAAA,CAAA,KAAA,UAAA;AAAA,UAAJ,OAAI;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,oBAAA,uBAAA;AAtBlC,iBAAA,MAAA,mBAAA,EAAA,OAAA,WAAA,GAAA,kBAAA,EAAA,MAAA,SAAA,MAAA,WAAA,MAAA,UAAA,UAAA,GAAA,MAAA,uBAAA;;;QAIyB,GAAA,SAAyB,CAAC,sBAAsB,QAAQ,KAAK,GAC7D,GAAA,yBAAyB,MAL5C,kBAAA,YAAA,uBAAA,GACJ;;;"}
|
|
187
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"datepicker.component.js","sources":["../../../../../src/elements/datepicker/datepicker/datepicker.component.ts"],"sourcesContent":["import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  nothing,\n  type PropertyDeclaration,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport type { CalendarView } from '../../calendar.ts';\nimport { readConfig } from '../../core/config.ts';\nimport { SbbLanguageController } from '../../core/controllers.ts';\nimport { type DateAdapter, defaultDateAdapter } from '../../core/datetime.ts';\nimport { forceType, idReference } from '../../core/decorators.ts';\nimport { i18nDateChangedTo } from '../../core/i18n.ts';\nimport { SbbUpdateSchedulerMixin } from '../../core/mixins.ts';\nimport { type SbbDateInputAssociated, SbbDateInputElement } from '../../date-input.ts';\nimport { SbbPopoverBaseElement } from '../../popover.ts';\nimport type { SbbDatepickerToggleElement } from '../datepicker-toggle.ts';\n\nimport style from './datepicker.scss?lit&inline';\n\nimport '../../calendar.ts';\n\nlet nextId = 0;\n\n/**\n * A datepicker component that allows users to select a date from a calendar view.\n * @event {CustomEvent<T>} dateselected - Event emitted on date selection.\n */\nexport\n@customElement('sbb-datepicker')\nclass SbbDatepickerElement<T = Date>\n  extends SbbUpdateSchedulerMixin(SbbPopoverBaseElement)\n  implements SbbDateInputAssociated<T>\n{\n  public static override styles: CSSResultGroup = [SbbPopoverBaseElement.styles, style];\n  public static readonly sbbDateInputAssociated = true;\n\n  /** If set to true, two months are displayed. */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor wide: boolean = false;\n\n  /**\n   * Reference to the sbb-date-input instance or the native input connected to the datepicker.\n   *\n   * For attribute usage, provide an id reference.\n   */\n  @idReference()\n  @property()\n  public accessor input: SbbDateInputElement<T> | null = null;\n\n  /** The initial view of calendar which should be displayed on opening. */\n  @property() public accessor view: CalendarView = 'day';\n\n  private _inputAbortController?: AbortController;\n  private _dateAdapter: DateAdapter<T> = readConfig().datetime?.dateAdapter ?? defaultDateAdapter;\n  private _language = new SbbLanguageController(this);\n  private _ready = false;\n\n  public constructor() {\n    super();\n    this.startUpdate();\n    this.addEventListener(SbbPopoverBaseElement.events.beforeopen, () => {\n      this.shadowRoot?.querySelector('sbb-calendar')?.resetPosition?.();\n    });\n    if (!isServer && this.hydrationRequired) {\n      this.hydrationComplete.then(() => this.requestUpdate());\n    }\n  }\n\n  public override connectedCallback(): void {\n    this.id ||= `sbb-datepicker-${++nextId}`;\n    super.connectedCallback();\n\n    const formField = this.closest?.('sbb-form-field');\n    if (formField) {\n      SbbDateInputElement.resolveAssociation(this);\n      const toggle =\n        formField.querySelector<SbbDatepickerToggleElement<T>>('sbb-datepicker-toggle');\n      if (toggle && !toggle.hasAttribute('datepicker')) {\n        toggle.datepicker ??= 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 (name === 'input' && this.input !== oldValue) {\n      this._inputAbortController?.abort();\n      if (this.input) {\n        const { signal } = (this._inputAbortController = new AbortController());\n        this.input?.addEventListener(\n          'ɵchange',\n          () => {\n            super.requestUpdate();\n            this._updateStatus();\n          },\n          { signal },\n        );\n      }\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n    setTimeout(() => {\n      // We want to delay the rendering of the calendar to avoid a slow initial render.\n      // The slow render can be a problem if a large amount of datepickers are rendered at once.\n      this._ready = true;\n      this.requestUpdate();\n      this.completeUpdate();\n    });\n  }\n\n  private _updateStatus(): void {\n    const status = this.shadowRoot?.getElementById('status-container');\n    if (!status) {\n      return;\n    }\n\n    const text = this._dateAdapter.isValid(this.input?.valueAsDate)\n      ? `${i18nDateChangedTo[this._language.current]} ${this._dateAdapter.format(\n          this.input!.valueAsDate,\n          {\n            weekdayStyle: 'long',\n          },\n        )}`\n      : '';\n    if (status.textContent !== text) {\n      status.textContent = text;\n    }\n  }\n\n  protected override renderContent(): TemplateResult {\n    return html`\n      <p id=\"status-container\" role=\"status\"></p>\n      <sbb-calendar\n        .view=${this.view}\n        .min=${this.input?.min ?? null}\n        .max=${this.input?.max ?? null}\n        .dateFilter=${this.input?.dateFilter ?? null}\n        .selected=${this.input?.valueAsDate ?? null}\n        ?wide=${this.wide}\n        @dateselected=${(d: CustomEvent<T>) => {\n          if (this.input) {\n            this.input.valueAsDate = d.detail;\n            this.input.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n            this.input.dispatchEvent(new Event('change', { bubbles: true, composed: true }));\n            // Emit blur event when value is changed programmatically to notify\n            // frameworks that rely on that event to update form status.\n            this.input.dispatchEvent(new Event('blur', { composed: true }));\n            this.close();\n          }\n        }}\n      ></sbb-calendar>\n    `;\n  }\n\n  protected override render(): TemplateResult {\n    return isServer || this.hydrationRequired || !this._ready ? html`${nothing}` : super.render();\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-datepicker': SbbDatepickerElement;\n  }\n}\n"],"names":[],"mappings":"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"}
|
package/index.d.ts
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { SbbAccordionElement } from "./accordion/accordion.component.js";
|
|
2
2
|
import { SbbActionGroupElement } from "./action-group/action-group.component.js";
|
|
3
3
|
import { SbbAutocompleteElement } from "./autocomplete/autocomplete.component.js";
|
|
4
|
-
import { SbbCalendarElement } from "./calendar/calendar.component.js";
|
|
5
4
|
import { SbbChipLabelElement } from "./chip-label/chip-label.component.js";
|
|
6
5
|
import { SbbClockElement } from "./clock/clock.component.js";
|
|
7
6
|
import { SbbDateInputElement } from "./date-input/date-input.component.js";
|
|
@@ -56,6 +55,8 @@ import { SbbSecondaryButtonStaticElement } from "./button/secondary-button-stati
|
|
|
56
55
|
import { SbbTransparentButtonElement } from "./button/transparent-button/transparent-button.component.js";
|
|
57
56
|
import { SbbTransparentButtonLinkElement } from "./button/transparent-button-link/transparent-button-link.component.js";
|
|
58
57
|
import { SbbTransparentButtonStaticElement } from "./button/transparent-button-static/transparent-button-static.component.js";
|
|
58
|
+
import { SbbCalendarElement } from "./calendar/calendar/calendar.component.js";
|
|
59
|
+
import { SbbCalendarDayElement } from "./calendar/calendar-day/calendar-day.component.js";
|
|
59
60
|
import { SbbCardElement } from "./card/card/card.component.js";
|
|
60
61
|
import { SbbCardBadgeElement } from "./card/card-badge/card-badge.component.js";
|
|
61
62
|
import { SbbCardButtonElement } from "./card/card-button/card-button.component.js";
|
|
@@ -172,6 +173,7 @@ declare global {
|
|
|
172
173
|
var SbbButtonElement: SbbButtonElement;
|
|
173
174
|
var SbbButtonLinkElement: SbbButtonLinkElement;
|
|
174
175
|
var SbbButtonStaticElement: SbbButtonStaticElement;
|
|
176
|
+
var SbbCalendarDayElement: SbbCalendarDayElement;
|
|
175
177
|
var SbbCalendarElement: SbbCalendarElement;
|
|
176
178
|
var SbbCardBadgeElement: SbbCardBadgeElement;
|
|
177
179
|
var SbbCardButtonElement: SbbCardButtonElement;
|
package/index.js
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { SbbAccordionElement } from "./accordion/accordion.component.js";
|
|
2
2
|
import { SbbActionGroupElement } from "./action-group/action-group.component.js";
|
|
3
3
|
import { SbbAutocompleteElement } from "./autocomplete/autocomplete.component.js";
|
|
4
|
-
import { SbbCalendarElement } from "./calendar/calendar.component.js";
|
|
5
4
|
import { SbbChipLabelElement } from "./chip-label/chip-label.component.js";
|
|
6
5
|
import { SbbClockElement } from "./clock/clock.component.js";
|
|
7
6
|
import { SbbDateInputElement } from "./date-input/date-input.component.js";
|
|
@@ -56,6 +55,8 @@ import { SbbSecondaryButtonStaticElement } from "./button/secondary-button-stati
|
|
|
56
55
|
import { SbbTransparentButtonElement } from "./button/transparent-button/transparent-button.component.js";
|
|
57
56
|
import { SbbTransparentButtonLinkElement } from "./button/transparent-button-link/transparent-button-link.component.js";
|
|
58
57
|
import { SbbTransparentButtonStaticElement } from "./button/transparent-button-static/transparent-button-static.component.js";
|
|
58
|
+
import { SbbCalendarElement } from "./calendar/calendar/calendar.component.js";
|
|
59
|
+
import { SbbCalendarDayElement } from "./calendar/calendar-day/calendar-day.component.js";
|
|
59
60
|
import { SbbCardElement } from "./card/card/card.component.js";
|
|
60
61
|
import { SbbCardBadgeElement } from "./card/card-badge/card-badge.component.js";
|
|
61
62
|
import { SbbCardButtonElement } from "./card/card-button/card-button.component.js";
|
|
@@ -172,6 +173,7 @@ globalThis.SbbBreadcrumbGroupElement = SbbBreadcrumbGroupElement;
|
|
|
172
173
|
globalThis.SbbButtonElement = SbbButtonElement;
|
|
173
174
|
globalThis.SbbButtonLinkElement = SbbButtonLinkElement;
|
|
174
175
|
globalThis.SbbButtonStaticElement = SbbButtonStaticElement;
|
|
176
|
+
globalThis.SbbCalendarDayElement = SbbCalendarDayElement;
|
|
175
177
|
globalThis.SbbCalendarElement = SbbCalendarElement;
|
|
176
178
|
globalThis.SbbCardBadgeElement = SbbCardBadgeElement;
|
|
177
179
|
globalThis.SbbCardButtonElement = SbbCardButtonElement;
|
package/package.json
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@sbb-esta/lyne-elements-dev",
|
|
3
|
-
"version": "4.5.1-dev.
|
|
3
|
+
"version": "4.5.1-dev.1772034641",
|
|
4
4
|
"description": "Lyne Design System",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"design system",
|
|
7
7
|
"web components",
|
|
8
8
|
"lit",
|
|
9
9
|
"storybook",
|
|
10
|
-
"https://github.com/sbb-design-systems/lyne-components/commit/
|
|
10
|
+
"https://github.com/sbb-design-systems/lyne-components/commit/8d61c6ffb1a6d6707f27a826154078927c9d2f35"
|
|
11
11
|
],
|
|
12
12
|
"type": "module",
|
|
13
13
|
"exports": {
|
|
@@ -222,6 +222,16 @@
|
|
|
222
222
|
"development": "./development/calendar.js",
|
|
223
223
|
"default": "./calendar.js"
|
|
224
224
|
},
|
|
225
|
+
"./calendar/calendar.js": {
|
|
226
|
+
"types": "./development/calendar/calendar.d.ts",
|
|
227
|
+
"development": "./development/calendar/calendar.js",
|
|
228
|
+
"default": "./calendar/calendar.js"
|
|
229
|
+
},
|
|
230
|
+
"./calendar/calendar-day.js": {
|
|
231
|
+
"types": "./development/calendar/calendar-day.d.ts",
|
|
232
|
+
"development": "./development/calendar/calendar-day.js",
|
|
233
|
+
"default": "./calendar/calendar-day.js"
|
|
234
|
+
},
|
|
225
235
|
"./card.js": {
|
|
226
236
|
"types": "./development/card.d.ts",
|
|
227
237
|
"development": "./development/card.js",
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"calendar.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/calendar/calendar.component.ts"],"names":[],"mappings":"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"}
|