@sbb-esta/lyne-elements 1.4.0 → 1.6.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/alert/alert/alert.d.ts +22 -16
- package/alert/alert/alert.d.ts.map +1 -1
- package/alert/alert-group/alert-group.d.ts +1 -1
- package/alert/alert-group/alert-group.d.ts.map +1 -1
- package/alert/alert-group.js +31 -26
- package/alert/alert.js +45 -37
- package/checkbox/checkbox/checkbox.d.ts +5 -0
- package/checkbox/checkbox/checkbox.d.ts.map +1 -1
- package/checkbox/checkbox-panel/checkbox-panel.d.ts +5 -0
- package/checkbox/checkbox-panel/checkbox-panel.d.ts.map +1 -1
- package/checkbox/checkbox-panel.js +28 -18
- package/checkbox/checkbox.js +26 -15
- package/checkbox/common/checkbox-common.d.ts +1 -3
- package/checkbox/common/checkbox-common.d.ts.map +1 -1
- package/checkbox/common.js +15 -24
- package/clock/clock.d.ts.map +1 -1
- package/clock.js +14 -14
- package/core/i18n/i18n.d.ts +2 -0
- package/core/i18n/i18n.d.ts.map +1 -1
- package/core/i18n.js +61 -49
- package/core/mixins/panel-mixin.d.ts +1 -0
- package/core/mixins/panel-mixin.d.ts.map +1 -1
- package/core/testing/wait-for-event.d.ts +2 -0
- package/core/testing/wait-for-event.d.ts.map +1 -0
- package/core/testing.d.ts +1 -0
- package/core/testing.d.ts.map +1 -1
- package/core/testing.js +49 -36
- package/custom-elements.json +701 -193
- package/development/alert/alert/alert.d.ts +22 -16
- package/development/alert/alert/alert.d.ts.map +1 -1
- package/development/alert/alert-group/alert-group.d.ts +1 -1
- package/development/alert/alert-group/alert-group.d.ts.map +1 -1
- package/development/alert/alert-group.js +16 -11
- package/development/alert/alert.js +65 -24
- package/development/checkbox/checkbox/checkbox.d.ts +5 -0
- package/development/checkbox/checkbox/checkbox.d.ts.map +1 -1
- package/development/checkbox/checkbox-panel/checkbox-panel.d.ts +5 -0
- package/development/checkbox/checkbox-panel/checkbox-panel.d.ts.map +1 -1
- package/development/checkbox/checkbox-panel.js +13 -2
- package/development/checkbox/checkbox.js +13 -1
- package/development/checkbox/common/checkbox-common.d.ts +1 -3
- package/development/checkbox/common/checkbox-common.d.ts.map +1 -1
- package/development/checkbox/common.js +13 -17
- package/development/clock/clock.d.ts.map +1 -1
- package/development/clock.js +3 -2
- package/development/core/i18n/i18n.d.ts +2 -0
- package/development/core/i18n/i18n.d.ts.map +1 -1
- package/development/core/i18n.js +15 -1
- package/development/core/mixins/panel-mixin.d.ts +1 -0
- package/development/core/mixins/panel-mixin.d.ts.map +1 -1
- package/development/core/mixins.js +1 -1
- package/development/core/testing/wait-for-event.d.ts +2 -0
- package/development/core/testing/wait-for-event.d.ts.map +1 -0
- package/development/core/testing.d.ts +1 -0
- package/development/core/testing.d.ts.map +1 -1
- package/development/core/testing.js +17 -1
- package/development/flip-card/flip-card/flip-card.d.ts +32 -0
- package/development/flip-card/flip-card/flip-card.d.ts.map +1 -0
- package/development/flip-card/flip-card/index.d.ts +2 -0
- package/development/flip-card/flip-card/index.d.ts.map +1 -0
- package/development/flip-card/flip-card-details/flip-card-details.d.ts +22 -0
- package/development/flip-card/flip-card-details/flip-card-details.d.ts.map +1 -0
- package/development/flip-card/flip-card-details/index.d.ts +2 -0
- package/development/flip-card/flip-card-details/index.d.ts.map +1 -0
- package/development/flip-card/flip-card-details.d.ts +2 -0
- package/development/flip-card/flip-card-details.d.ts.map +1 -0
- package/development/flip-card/flip-card-details.js +105 -0
- package/development/flip-card/flip-card-summary/flip-card-summary.d.ts +22 -0
- package/development/flip-card/flip-card-summary/flip-card-summary.d.ts.map +1 -0
- package/development/flip-card/flip-card-summary/index.d.ts +2 -0
- package/development/flip-card/flip-card-summary/index.d.ts.map +1 -0
- package/development/flip-card/flip-card-summary.d.ts +2 -0
- package/development/flip-card/flip-card-summary.d.ts.map +1 -0
- package/development/flip-card/flip-card-summary.js +151 -0
- package/development/flip-card/flip-card.d.ts +2 -0
- package/development/flip-card/flip-card.d.ts.map +1 -0
- package/development/flip-card/flip-card.js +187 -0
- package/development/flip-card.d.ts +4 -0
- package/development/flip-card.d.ts.map +1 -0
- package/development/flip-card.js +4 -0
- package/development/icon/icon.d.ts +9 -1
- package/development/icon/icon.d.ts.map +1 -1
- package/development/icon.js +16 -2
- package/development/menu/menu/menu.d.ts.map +1 -1
- package/development/menu/menu.js +2 -1
- package/development/navigation/navigation/navigation.d.ts.map +1 -1
- package/development/navigation/navigation.js +2 -1
- package/development/notification/notification.d.ts +4 -4
- package/development/notification.js +1 -1
- package/development/overlay/overlay-base-element.d.ts.map +1 -1
- package/development/overlay.js +35 -17
- package/development/radio-button/radio-button-panel/radio-button-panel.d.ts +3 -3
- package/development/radio-button/radio-button-panel/radio-button-panel.d.ts.map +1 -1
- package/development/radio-button/radio-button-panel.js +1 -1
- package/development/status/status.d.ts +1 -1
- package/development/status/status.d.ts.map +1 -1
- package/development/status.js +39 -2
- package/development/toggle/toggle.js +1 -1
- package/development/visual-checkbox/visual-checkbox.d.ts +3 -0
- package/development/visual-checkbox/visual-checkbox.d.ts.map +1 -1
- package/development/visual-checkbox.js +11 -3
- package/flip-card/flip-card/flip-card.d.ts +32 -0
- package/flip-card/flip-card/flip-card.d.ts.map +1 -0
- package/flip-card/flip-card/index.d.ts +2 -0
- package/flip-card/flip-card/index.d.ts.map +1 -0
- package/flip-card/flip-card-details/flip-card-details.d.ts +22 -0
- package/flip-card/flip-card-details/flip-card-details.d.ts.map +1 -0
- package/flip-card/flip-card-details/index.d.ts +2 -0
- package/flip-card/flip-card-details/index.d.ts.map +1 -0
- package/flip-card/flip-card-details.d.ts +2 -0
- package/flip-card/flip-card-details.d.ts.map +1 -0
- package/flip-card/flip-card-details.js +52 -0
- package/flip-card/flip-card-summary/flip-card-summary.d.ts +22 -0
- package/flip-card/flip-card-summary/flip-card-summary.d.ts.map +1 -0
- package/flip-card/flip-card-summary/index.d.ts +2 -0
- package/flip-card/flip-card-summary/index.d.ts.map +1 -0
- package/flip-card/flip-card-summary.d.ts +2 -0
- package/flip-card/flip-card-summary.d.ts.map +1 -0
- package/flip-card/flip-card-summary.js +41 -0
- package/flip-card/flip-card.d.ts +2 -0
- package/flip-card/flip-card.d.ts.map +1 -0
- package/flip-card/flip-card.js +58 -0
- package/flip-card.d.ts +4 -0
- package/flip-card.d.ts.map +1 -0
- package/flip-card.js +3 -0
- package/icon/icon.d.ts +9 -1
- package/icon/icon.d.ts.map +1 -1
- package/icon.js +71 -62
- package/index.d.ts +6 -0
- package/index.js +6 -0
- package/menu/menu/menu.d.ts.map +1 -1
- package/menu/menu.js +3 -3
- package/navigation/navigation/navigation.d.ts.map +1 -1
- package/navigation/navigation.js +4 -4
- package/notification/notification.d.ts +4 -4
- package/overlay/overlay-base-element.d.ts.map +1 -1
- package/overlay.js +33 -33
- package/package.json +21 -1
- package/radio-button/radio-button-panel/radio-button-panel.d.ts +3 -3
- package/radio-button/radio-button-panel/radio-button-panel.d.ts.map +1 -1
- package/status/status.d.ts +1 -1
- package/status/status.d.ts.map +1 -1
- package/status.js +17 -13
- package/toggle/toggle.js +1 -1
- package/visual-checkbox/visual-checkbox.d.ts +3 -0
- package/visual-checkbox/visual-checkbox.d.ts.map +1 -1
- package/visual-checkbox.js +23 -20
|
@@ -1,16 +1,18 @@
|
|
|
1
|
-
import { CSSResultGroup,
|
|
2
|
-
import { LinkTargetType } from '../../core/base-elements.js';
|
|
1
|
+
import { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';
|
|
2
|
+
import { LinkTargetType, SbbOpenCloseBaseElement } from '../../core/base-elements.js';
|
|
3
3
|
import { SbbTitleLevel } from '../../title.js';
|
|
4
4
|
|
|
5
|
-
declare const SbbAlertElement_base: import('../../core/mixins.js').AbstractConstructor<import('../../icon.js').SbbIconNameMixinType> & typeof
|
|
5
|
+
declare const SbbAlertElement_base: import('../../core/mixins.js').AbstractConstructor<import('../../icon.js').SbbIconNameMixinType> & typeof SbbOpenCloseBaseElement;
|
|
6
6
|
/**
|
|
7
7
|
* It displays messages which require user's attention.
|
|
8
8
|
*
|
|
9
9
|
* @slot - Use the unnamed slot to add content to the `sbb-alert`.
|
|
10
10
|
* @slot icon - Should be a `sbb-icon` which is displayed next to the title. Styling is optimized for icons of type HIM-CUS.
|
|
11
11
|
* @slot title - Title content.
|
|
12
|
-
* @event {CustomEvent<void>} willOpen - Emits when the
|
|
13
|
-
* @event {CustomEvent<void>} didOpen - Emits when the
|
|
12
|
+
* @event {CustomEvent<void>} willOpen - Emits when the opening animation starts.
|
|
13
|
+
* @event {CustomEvent<void>} didOpen - Emits when the opening animation ends.
|
|
14
|
+
* @event {CustomEvent<void>} willClose - Emits when the closing animation starts. Can be canceled.
|
|
15
|
+
* @event {CustomEvent<void>} didClose - Emits when the closing animation ends.
|
|
14
16
|
* @event {CustomEvent<void>} dismissalRequested - Emits when dismissal of an alert was requested.
|
|
15
17
|
*/
|
|
16
18
|
export declare class SbbAlertElement extends SbbAlertElement_base {
|
|
@@ -18,6 +20,8 @@ export declare class SbbAlertElement extends SbbAlertElement_base {
|
|
|
18
20
|
static readonly events: {
|
|
19
21
|
readonly willOpen: "willOpen";
|
|
20
22
|
readonly didOpen: "didOpen";
|
|
23
|
+
readonly willClose: "willClose";
|
|
24
|
+
readonly didClose: "didClose";
|
|
21
25
|
readonly dismissalRequested: "dismissalRequested";
|
|
22
26
|
};
|
|
23
27
|
/**
|
|
@@ -48,23 +52,25 @@ export declare class SbbAlertElement extends SbbAlertElement_base {
|
|
|
48
52
|
/** This will be forwarded as aria-label to the relevant nested element. */
|
|
49
53
|
accessibilityLabel: string | undefined;
|
|
50
54
|
/** The enabled animations. */
|
|
51
|
-
animation: 'open' | 'none';
|
|
52
|
-
/**
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
private _willOpen;
|
|
57
|
-
/** Emits when the fade in animation ends and the button is displayed. */
|
|
58
|
-
private _didOpen;
|
|
59
|
-
/** Emits when dismissal of an alert was requested. */
|
|
55
|
+
animation: 'open' | 'close' | 'all' | 'none';
|
|
56
|
+
/**
|
|
57
|
+
* Emits when dismissal of an alert was requested.
|
|
58
|
+
* @deprecated
|
|
59
|
+
*/
|
|
60
60
|
private _dismissalRequested;
|
|
61
61
|
private _language;
|
|
62
62
|
protected firstUpdated(changedProperties: PropertyValues<this>): Promise<void>;
|
|
63
|
-
/** Requests dismissal of the alert.
|
|
63
|
+
/** Requests dismissal of the alert.
|
|
64
|
+
* @deprecated in favour of 'willClose' and 'didClose' events
|
|
65
|
+
*/
|
|
64
66
|
requestDismissal(): void;
|
|
65
67
|
/** Open the alert. */
|
|
66
|
-
|
|
68
|
+
open(): void;
|
|
69
|
+
/** Close the alert. */
|
|
70
|
+
close(): void;
|
|
67
71
|
private _onAnimationEnd;
|
|
72
|
+
private _handleOpening;
|
|
73
|
+
private _handleClosing;
|
|
68
74
|
protected render(): TemplateResult;
|
|
69
75
|
}
|
|
70
76
|
declare global {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"alert.d.ts","sourceRoot":"","sources":["../../../../../src/elements/alert/alert/alert.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"alert.d.ts","sourceRoot":"","sources":["../../../../../src/elements/alert/alert/alert.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAiB,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAGnG,OAAO,EAAE,KAAK,cAAc,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AAK3F,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAIpD,OAAO,oCAAoC,CAAC;AAC5C,OAAO,kBAAkB,CAAC;AAC1B,OAAO,eAAe,CAAC;AACvB,OAAO,gBAAgB,CAAC;;AAExB;;;;;;;;;;;GAWG;AACH,qBACa,eAAgB,SAAQ,oBAAyC;IAC5E,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAgC,MAAM;;;;;;MAM3B;IAEX;;;OAGG;IACgD,QAAQ,UAAS;IAEpE,mDAAmD;IACf,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,CAAO;IAEhE;;;;OAIG;IACmD,QAAQ,EAAE,MAAM,CAAU;IAEhF,wBAAwB;IACyB,YAAY,CAAC,EAAE,MAAM,CAAC;IAEvE,sFAAsF;IACvC,UAAU,EAAE,aAAa,CAAO;IAE/E,2BAA2B;IACqB,WAAW,CAAC,EAAE,MAAM,CAAC;IAErE,0CAA0C;IACvB,IAAI,EAAE,MAAM,GAAG,SAAS,CAAC;IAE5C,uCAAuC;IACpB,MAAM,EAAE,cAAc,GAAG,MAAM,GAAG,SAAS,CAAC;IAE/D,wEAAwE;IACrD,GAAG,EAAE,MAAM,GAAG,SAAS,CAAC;IAE3C,2EAA2E;IACpB,kBAAkB,EAAE,MAAM,GAAG,SAAS,CAAC;IAE9F,8BAA8B;IACM,SAAS,EAAE,MAAM,GAAG,OAAO,GAAG,KAAK,GAAG,MAAM,CAAS;IAEzF;;;OAGG;IACH,OAAO,CAAC,mBAAmB,CAGzB;IAEF,OAAO,CAAC,SAAS,CAAmC;cAE3B,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAM7F;;OAEG;IACI,gBAAgB,IAAI,IAAI;IAI/B,sBAAsB;IACf,IAAI,IAAI,IAAI;IAKnB,uBAAuB;IAChB,KAAK,IAAI,IAAI;IAMpB,OAAO,CAAC,eAAe;IAQvB,OAAO,CAAC,cAAc;IAKtB,OAAO,CAAC,cAAc;cAMH,MAAM,IAAI,cAAc;CAqD5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,WAAW,EAAE,eAAe,CAAC;KAC9B;CACF"}
|
|
@@ -34,8 +34,8 @@ export declare class SbbAlertGroupElement extends SbbAlertGroupElement_base {
|
|
|
34
34
|
/** Emits when `sbb-alert-group` becomes empty. */
|
|
35
35
|
private _empty;
|
|
36
36
|
private _abort;
|
|
37
|
-
private _removeAlert;
|
|
38
37
|
connectedCallback(): void;
|
|
38
|
+
private _alertClosed;
|
|
39
39
|
private _slotChanged;
|
|
40
40
|
protected render(): TemplateResult;
|
|
41
41
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"alert-group.d.ts","sourceRoot":"","sources":["../../../../../src/elements/alert/alert-group/alert-group.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAW,MAAM,KAAK,CAAC;AAO1C,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;;AAKpD;;;;;;;GAOG;AACH,qBACa,oBAAqB,SAAQ,yBAA6B;IACrE,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;;MAGlB;IAEX;;;;;OAKG;IAEa,IAAI,EAAE,OAAO,GAAG,QAAQ,GAAG,MAAM,CAAY;IAE7D,gFAAgF;IACzB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAEnF,wGAAwG;IAEjG,uBAAuB,EAAE,aAAa,CAAO;IAEpD,kDAAkD;IACzC,OAAO,CAAC,UAAU,CAAC,CAAU;IAEtC,gDAAgD;IAChD,OAAO,CAAC,gBAAgB,CAGtB;IAEF,kDAAkD;IAClD,OAAO,CAAC,MAAM,CAAiF;IAE/F,OAAO,CAAC,MAAM,CAAyC;
|
|
1
|
+
{"version":3,"file":"alert-group.d.ts","sourceRoot":"","sources":["../../../../../src/elements/alert/alert-group/alert-group.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAW,MAAM,KAAK,CAAC;AAO1C,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;;AAKpD;;;;;;;GAOG;AACH,qBACa,oBAAqB,SAAQ,yBAA6B;IACrE,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;;MAGlB;IAEX;;;;;OAKG;IAEa,IAAI,EAAE,OAAO,GAAG,QAAQ,GAAG,MAAM,CAAY;IAE7D,gFAAgF;IACzB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAEnF,wGAAwG;IAEjG,uBAAuB,EAAE,aAAa,CAAO;IAEpD,kDAAkD;IACzC,OAAO,CAAC,UAAU,CAAC,CAAU;IAEtC,gDAAgD;IAChD,OAAO,CAAC,gBAAgB,CAGtB;IAEF,kDAAkD;IAClD,OAAO,CAAC,MAAM,CAAiF;IAE/F,OAAO,CAAC,MAAM,CAAyC;IAEvC,iBAAiB,IAAI,IAAI;IAezC,OAAO,CAAC,YAAY;IAkBpB,OAAO,CAAC,YAAY;cAaD,MAAM,IAAI,cAAc;CAe5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,iBAAiB,EAAE,oBAAoB,CAAC;KACzC;CACF"}
|
|
@@ -82,11 +82,23 @@ let SbbAlertGroupElement = class extends SbbHydrationMixin(LitElement) {
|
|
|
82
82
|
this._empty = new EventEmitter(this, SbbAlertGroupElement.events.empty);
|
|
83
83
|
this._abort = new SbbConnectedAbortController(this);
|
|
84
84
|
}
|
|
85
|
-
|
|
86
|
-
|
|
85
|
+
connectedCallback() {
|
|
86
|
+
super.connectedCallback();
|
|
87
|
+
const signal = this._abort.signal;
|
|
88
|
+
this.addEventListener(
|
|
89
|
+
SbbAlertElement.events.dismissalRequested,
|
|
90
|
+
(e) => e.target.close(),
|
|
91
|
+
{
|
|
92
|
+
signal
|
|
93
|
+
}
|
|
94
|
+
);
|
|
95
|
+
this.addEventListener(SbbAlertElement.events.didClose, (e) => this._alertClosed(e), {
|
|
96
|
+
signal
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
_alertClosed(event) {
|
|
87
100
|
const target = event.target;
|
|
88
101
|
const hasFocusInsideAlertGroup = document.activeElement === target;
|
|
89
|
-
(_a = target.parentNode) == null ? void 0 : _a.removeChild(target);
|
|
90
102
|
this._didDismissAlert.emit(target);
|
|
91
103
|
if (hasFocusInsideAlertGroup) {
|
|
92
104
|
this.tabIndex = 0;
|
|
@@ -96,13 +108,6 @@ let SbbAlertGroupElement = class extends SbbHydrationMixin(LitElement) {
|
|
|
96
108
|
});
|
|
97
109
|
}
|
|
98
110
|
}
|
|
99
|
-
connectedCallback() {
|
|
100
|
-
super.connectedCallback();
|
|
101
|
-
const signal = this._abort.signal;
|
|
102
|
-
this.addEventListener(SbbAlertElement.events.dismissalRequested, (e) => this._removeAlert(e), {
|
|
103
|
-
signal
|
|
104
|
-
});
|
|
105
|
-
}
|
|
106
111
|
_slotChanged(event) {
|
|
107
112
|
const hadAlerts = this._hasAlerts;
|
|
108
113
|
this._hasAlerts = event.target.assignedElements().filter((e) => e instanceof Element && e.localName === "sbb-alert").length > 0;
|
|
@@ -146,4 +151,4 @@ SbbAlertGroupElement = __decorateClass([
|
|
|
146
151
|
export {
|
|
147
152
|
SbbAlertGroupElement
|
|
148
153
|
};
|
|
149
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxlcnQtZ3JvdXAuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9lbGVtZW50cy9hbGVydC9hbGVydC1ncm91cC9hbGVydC1ncm91cC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENTU1Jlc3VsdEdyb3VwLCBUZW1wbGF0ZVJlc3VsdCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBMaXRFbGVtZW50LCBub3RoaW5nIH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQsIHByb3BlcnR5LCBzdGF0ZSB9IGZyb20gJ2xpdC9kZWNvcmF0b3JzLmpzJztcbmltcG9ydCB7IGh0bWwsIHVuc2FmZVN0YXRpYyB9IGZyb20gJ2xpdC9zdGF0aWMtaHRtbC5qcyc7XG5cbmltcG9ydCB7IFNiYkNvbm5lY3RlZEFib3J0Q29udHJvbGxlciB9IGZyb20gJy4uLy4uL2NvcmUvY29udHJvbGxlcnMuanMnO1xuaW1wb3J0IHsgRXZlbnRFbWl0dGVyIH0gZnJvbSAnLi4vLi4vY29yZS9ldmVudGluZy5qcyc7XG5pbXBvcnQgeyBTYmJIeWRyYXRpb25NaXhpbiB9IGZyb20gJy4uLy4uL2NvcmUvbWl4aW5zLmpzJztcbmltcG9ydCB0eXBlIHsgU2JiVGl0bGVMZXZlbCB9IGZyb20gJy4uLy4uL3RpdGxlLmpzJztcbmltcG9ydCB7IFNiYkFsZXJ0RWxlbWVudCB9IGZyb20gJy4uL2FsZXJ0LmpzJztcblxuaW1wb3J0IHN0eWxlIGZyb20gJy4vYWxlcnQtZ3JvdXAuc2Nzcz9saXQmaW5saW5lJztcblxuLyoqXG4gKiBJdCBjYW4gYmUgdXNlZCBhcyBhIGNvbnRhaW5lciBmb3Igb25lIG9yIG1vcmUgYHNiYi1hbGVydGAgY29tcG9uZW50LlxuICpcbiAqIEBzbG90IC0gVXNlIHRoZSB1bm5hbWVkIHNsb3QgdG8gYWRkIGBzYmItYWxlcnRgIGVsZW1lbnRzIHRvIHRoZSBgc2JiLWFsZXJ0LWdyb3VwYC5cbiAqIEBzbG90IGFjY2Vzc2liaWxpdHktdGl0bGUgLSB0aXRsZSBmb3IgdGhpcyBgc2JiLWFsZXJ0LWdyb3VwYCB3aGljaCBpcyBvbmx5IHZpc2libGUgZm9yIHNjcmVlbiByZWFkZXIgdXNlcnMuXG4gKiBAZXZlbnQge0N1c3RvbUV2ZW50PFNiYkFsZXJ0RWxlbWVudD59IGRpZERpc21pc3NBbGVydCAtIEVtaXRzIHdoZW4gYW4gYWxlcnQgd2FzIHJlbW92ZWQgZnJvbSBET00uXG4gKiBAZXZlbnQge0N1c3RvbUV2ZW50PHZvaWQ+fSBlbXB0eSAtIEVtaXRzIHdoZW4gYHNiYi1hbGVydC1ncm91cGAgYmVjb21lcyBlbXB0eS5cbiAqL1xuQGN1c3RvbUVsZW1lbnQoJ3NiYi1hbGVydC1ncm91cCcpXG5leHBvcnQgY2xhc3MgU2JiQWxlcnRHcm91cEVsZW1lbnQgZXh0ZW5kcyBTYmJIeWRyYXRpb25NaXhpbihMaXRFbGVtZW50KSB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IHN0eWxlO1xuICBwdWJsaWMgc3RhdGljIHJlYWRvbmx5IGV2ZW50cyA9IHtcbiAgICBkaWREaXNtaXNzQWxlcnQ6ICdkaWREaXNtaXNzQWxlcnQnLFxuICAgIGVtcHR5OiAnZW1wdHknLFxuICB9IGFzIGNvbnN0O1xuXG4gIC8qKlxuICAgKiBUaGUgcm9sZSBhdHRyaWJ1dGUgZGVmaW5lcyBob3cgdG8gYW5ub3VuY2UgYWxlcnRzIHRvIHRoZSB1c2VyLlxuICAgKlxuICAgKiAnc3RhdHVzJzogc2V0cyBhcmlhLWxpdmUgdG8gcG9saXRlIGFuZCBhcmlhLWF0b21pYyB0byB0cnVlLlxuICAgKiAnYWxlcnQnOiBzZXRzIGFyaWEtbGl2ZSB0byBhc3NlcnRpdmUgYW5kIGFyaWEtYXRvbWljIHRvIHRydWUuXG4gICAqL1xuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pXG4gIHB1YmxpYyBvdmVycmlkZSByb2xlOiAnYWxlcnQnIHwgJ3N0YXR1cycgfCBzdHJpbmcgPSAnc3RhdHVzJztcblxuICAvKiogVGl0bGUgZm9yIHRoaXMgYWxlcnQgZ3JvdXAgd2hpY2ggaXMgb25seSB2aXNpYmxlIGZvciBzY3JlZW4gcmVhZGVyIHVzZXJzLiAqL1xuICBAcHJvcGVydHkoeyBhdHRyaWJ1dGU6ICdhY2Nlc3NpYmlsaXR5LXRpdGxlJyB9KSBwdWJsaWMgYWNjZXNzaWJpbGl0eVRpdGxlPzogc3RyaW5nO1xuXG4gIC8qKiBMZXZlbCBvZiB0aGUgYWNjZXNzaWJpbGl0eSB0aXRsZSwgd2lsbCBiZSByZW5kZXJlZCBhcyBoZWFkaW5nIHRhZyAoZS5nLiBoMikuIERlZmF1bHRzIHRvIGxldmVsIDIuICovXG4gIEBwcm9wZXJ0eSh7IGF0dHJpYnV0ZTogJ2FjY2Vzc2liaWxpdHktdGl0bGUtbGV2ZWwnIH0pXG4gIHB1YmxpYyBhY2Nlc3NpYmlsaXR5VGl0bGVMZXZlbDogU2JiVGl0bGVMZXZlbCA9ICcyJztcblxuICAvKiogV2hldGhlciB0aGUgZ3JvdXAgY3VycmVudGx5IGhhcyBhbnkgYWxlcnRzLiAqL1xuICBAc3RhdGUoKSBwcml2YXRlIF9oYXNBbGVydHM/OiBib29sZWFuO1xuXG4gIC8qKiBFbWl0cyB3aGVuIGFuIGFsZXJ0IHdhcyByZW1vdmVkIGZyb20gRE9NLiAqL1xuICBwcml2YXRlIF9kaWREaXNtaXNzQWxlcnQ6IEV2ZW50RW1pdHRlcjxTYmJBbGVydEVsZW1lbnQ+
|
|
154
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"alert-group.js","sources":["../../../../src/elements/alert/alert-group/alert-group.ts"],"sourcesContent":["import type { CSSResultGroup, TemplateResult } from 'lit';\nimport { LitElement, nothing } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { html, unsafeStatic } from 'lit/static-html.js';\n\nimport { SbbConnectedAbortController } from '../../core/controllers.js';\nimport { EventEmitter } from '../../core/eventing.js';\nimport { SbbHydrationMixin } from '../../core/mixins.js';\nimport type { SbbTitleLevel } from '../../title.js';\nimport { SbbAlertElement } from '../alert.js';\n\nimport style from './alert-group.scss?lit&inline';\n\n/**\n * It can be used as a container for one or more `sbb-alert` component.\n *\n * @slot - Use the unnamed slot to add `sbb-alert` elements to the `sbb-alert-group`.\n * @slot accessibility-title - title for this `sbb-alert-group` which is only visible for screen reader users.\n * @event {CustomEvent<SbbAlertElement>} didDismissAlert - Emits when an alert was removed from DOM.\n * @event {CustomEvent<void>} empty - Emits when `sbb-alert-group` becomes empty.\n */\n@customElement('sbb-alert-group')\nexport class SbbAlertGroupElement extends SbbHydrationMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    didDismissAlert: 'didDismissAlert',\n    empty: 'empty',\n  } as const;\n\n  /**\n   * The role attribute defines how to announce alerts to the user.\n   *\n   * 'status': sets aria-live to polite and aria-atomic to true.\n   * 'alert': sets aria-live to assertive and aria-atomic to true.\n   */\n  @property({ reflect: true })\n  public override role: 'alert' | 'status' | string = 'status';\n\n  /** Title for this alert group which is only visible for screen reader users. */\n  @property({ attribute: 'accessibility-title' }) public accessibilityTitle?: string;\n\n  /** Level of the accessibility title, will be rendered as heading tag (e.g. h2). Defaults to level 2. */\n  @property({ attribute: 'accessibility-title-level' })\n  public accessibilityTitleLevel: SbbTitleLevel = '2';\n\n  /** Whether the group currently has any alerts. */\n  @state() private _hasAlerts?: boolean;\n\n  /** Emits when an alert was removed from DOM. */\n  private _didDismissAlert: EventEmitter<SbbAlertElement> = new EventEmitter(\n    this,\n    SbbAlertGroupElement.events.didDismissAlert,\n  );\n\n  /** Emits when `sbb-alert-group` becomes empty. */\n  private _empty: EventEmitter<void> = new EventEmitter(this, SbbAlertGroupElement.events.empty);\n\n  private _abort = new SbbConnectedAbortController(this);\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    const signal = this._abort.signal;\n    this.addEventListener(\n      SbbAlertElement.events.dismissalRequested,\n      (e) => (e.target as SbbAlertElement).close(),\n      {\n        signal,\n      },\n    );\n    this.addEventListener(SbbAlertElement.events.didClose, (e) => this._alertClosed(e), {\n      signal,\n    });\n  }\n\n  private _alertClosed(event: Event): void {\n    const target = event.target as SbbAlertElement;\n    const hasFocusInsideAlertGroup = document.activeElement === target;\n    this._didDismissAlert.emit(target);\n\n    // Restore focus\n    if (hasFocusInsideAlertGroup) {\n      // Set tabindex to 0 the make it focusable and afterwards focus it.\n      // This is done to not completely lose focus after removal of an alert.\n      // Once the sbb-alert-group was blurred, make the alert group not focusable again.\n      this.tabIndex = 0;\n      this.focus();\n      this.addEventListener('blur', () => this.removeAttribute('tabindex'), {\n        once: true,\n      });\n    }\n  }\n\n  private _slotChanged(event: Event): void {\n    const hadAlerts = this._hasAlerts;\n    this._hasAlerts =\n      (event.target as HTMLSlotElement)\n        .assignedElements()\n        .filter((e) => e instanceof Element && e.localName === 'sbb-alert').length > 0;\n    if (!this._hasAlerts && hadAlerts) {\n      this._empty.emit();\n    }\n\n    this.toggleAttribute('data-empty', !this._hasAlerts);\n  }\n\n  protected override render(): TemplateResult {\n    const TITLE_TAG_NAME = `h${this.accessibilityTitleLevel}`;\n\n    /* eslint-disable lit/binding-positions */\n    return html`\n      <div class=\"sbb-alert-group\">\n        ${this._hasAlerts\n          ? html`<${unsafeStatic(TITLE_TAG_NAME)} class=\"sbb-alert-group__title\">\n              <slot name=\"accessibility-title\">${this.accessibilityTitle}</slot>\n            </${unsafeStatic(TITLE_TAG_NAME)}>`\n          : nothing}\n        <slot @slotchange=${(event: Event) => this._slotChanged(event)}></slot>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-alert-group': SbbAlertGroupElement;\n  }\n}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAsBO,IAAM,uBAAN,cAAmC,kBAAkB,UAAU,EAAE;AAAA,EAAjE,cAAA;AAAA,UAAA,GAAA,SAAA;AAcL,SAAgB,OAAoC;AAOpD,SAAO,0BAAyC;AAMhD,SAAQ,mBAAkD,IAAI;AAAA,MAC5D;AAAA,MACA,qBAAqB,OAAO;AAAA,IAAA;AAI9B,SAAQ,SAA6B,IAAI,aAAa,MAAM,qBAAqB,OAAO,KAAK;AAErF,SAAA,SAAS,IAAI,4BAA4B,IAAI;AAAA,EAAA;AAAA,EAErC,oBAA0B;AACxC,UAAM,kBAAkB;AAClB,UAAA,SAAS,KAAK,OAAO;AACtB,SAAA;AAAA,MACH,gBAAgB,OAAO;AAAA,MACvB,CAAC,MAAO,EAAE,OAA2B,MAAM;AAAA,MAC3C;AAAA,QACE;AAAA,MACF;AAAA,IAAA;AAEG,SAAA,iBAAiB,gBAAgB,OAAO,UAAU,CAAC,MAAM,KAAK,aAAa,CAAC,GAAG;AAAA,MAClF;AAAA,IAAA,CACD;AAAA,EACH;AAAA,EAEQ,aAAa,OAAoB;AACvC,UAAM,SAAS,MAAM;AACf,UAAA,2BAA2B,SAAS,kBAAkB;AACvD,SAAA,iBAAiB,KAAK,MAAM;AAGjC,QAAI,0BAA0B;AAI5B,WAAK,WAAW;AAChB,WAAK,MAAM;AACX,WAAK,iBAAiB,QAAQ,MAAM,KAAK,gBAAgB,UAAU,GAAG;AAAA,QACpE,MAAM;AAAA,MAAA,CACP;AAAA,IACH;AAAA,EACF;AAAA,EAEQ,aAAa,OAAoB;AACvC,UAAM,YAAY,KAAK;AACvB,SAAK,aACF,MAAM,OACJ,iBAAA,EACA,OAAO,CAAC,MAAM,aAAa,WAAW,EAAE,cAAc,WAAW,EAAE,SAAS;AAC7E,QAAA,CAAC,KAAK,cAAc,WAAW;AACjC,WAAK,OAAO;IACd;AAEA,SAAK,gBAAgB,cAAc,CAAC,KAAK,UAAU;AAAA,EACrD;AAAA,EAEmB,SAAyB;AACpC,UAAA,iBAAiB,IAAI,KAAK,uBAAuB;AAGhD,WAAA;AAAA;AAAA,UAED,KAAK,aACH,QAAQ,aAAa,cAAc,CAAC;AAAA,iDACC,KAAK,kBAAkB;AAAA,gBACxD,aAAa,cAAc,CAAC,MAChC,OAAO;AAAA,4BACS,CAAC,UAAiB,KAAK,aAAa,KAAK,CAAC;AAAA;AAAA;AAAA,EAGpE;AACF;AAlGa,qBACY,SAAyB;AADrC,qBAEY,SAAS;AAAA,EAC9B,iBAAiB;AAAA,EACjB,OAAO;AACT;AASgB,gBAAA;AAAA,EADf,SAAS,EAAE,SAAS,MAAM;AAAA,GAbhB,qBAcK,WAAA,QAAA,CAAA;AAGuC,gBAAA;AAAA,EAAtD,SAAS,EAAE,WAAW,uBAAuB;AAAA,GAjBnC,qBAiB4C,WAAA,sBAAA,CAAA;AAIhD,gBAAA;AAAA,EADN,SAAS,EAAE,WAAW,6BAA6B;AAAA,GApBzC,qBAqBJ,WAAA,2BAAA,CAAA;AAGU,gBAAA;AAAA,EAAhB,MAAM;AAAA,GAxBI,qBAwBM,WAAA,cAAA,CAAA;AAxBN,uBAAN,gBAAA;AAAA,EADN,cAAc,iBAAiB;AAAA,GACnB,oBAAA;"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
import { css,
|
|
1
|
+
import { css, html, nothing } from "lit";
|
|
2
2
|
import { property, customElement } from "lit/decorators.js";
|
|
3
|
+
import { SbbOpenCloseBaseElement } from "../core/base-elements.js";
|
|
3
4
|
import { SbbLanguageController } from "../core/controllers.js";
|
|
4
5
|
import { EventEmitter } from "../core/eventing.js";
|
|
5
6
|
import { i18nFindOutMore, i18nCloseAlert } from "../core/i18n.js";
|
|
@@ -48,6 +49,7 @@ const style = css`/**
|
|
|
48
49
|
--sbb-disable-animation-zero-time,
|
|
49
50
|
var(--sbb-animation-duration-6x)
|
|
50
51
|
);
|
|
52
|
+
--sbb-alert-timing-function: ease-in;
|
|
51
53
|
display: block;
|
|
52
54
|
}
|
|
53
55
|
@media (min-width: calc(52.5rem)) {
|
|
@@ -62,7 +64,12 @@ const style = css`/**
|
|
|
62
64
|
}
|
|
63
65
|
}
|
|
64
66
|
|
|
65
|
-
:host([animation=
|
|
67
|
+
:host([data-state=opening]:not([animation=open], [animation=all])) {
|
|
68
|
+
--sbb-disable-animation-time: 0.1ms;
|
|
69
|
+
--sbb-disable-animation-zero-time: 0s;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
:host([data-state=closing]:not([animation=close], [animation=all])) {
|
|
66
73
|
--sbb-disable-animation-time: 0.1ms;
|
|
67
74
|
--sbb-disable-animation-zero-time: 0s;
|
|
68
75
|
}
|
|
@@ -86,7 +93,7 @@ const style = css`/**
|
|
|
86
93
|
grid-template-rows: 0fr;
|
|
87
94
|
opacity: 0;
|
|
88
95
|
}
|
|
89
|
-
:host([data-state=opened]) .sbb-alert__transition-wrapper {
|
|
96
|
+
:host(:is([data-state=opened], [data-state=closing])) .sbb-alert__transition-wrapper {
|
|
90
97
|
grid-template-rows: 1fr;
|
|
91
98
|
opacity: 1;
|
|
92
99
|
}
|
|
@@ -94,9 +101,16 @@ const style = css`/**
|
|
|
94
101
|
animation-name: open, open-opacity;
|
|
95
102
|
animation-fill-mode: forwards;
|
|
96
103
|
animation-duration: var(--sbb-alert-animation-duration);
|
|
97
|
-
animation-timing-function:
|
|
104
|
+
animation-timing-function: var(--sbb-alert-timing-function);
|
|
98
105
|
animation-delay: 0s, var(--sbb-alert-animation-duration);
|
|
99
106
|
}
|
|
107
|
+
:host([data-state=closing]) .sbb-alert__transition-wrapper {
|
|
108
|
+
animation-name: close-opacity, close;
|
|
109
|
+
animation-fill-mode: forwards;
|
|
110
|
+
animation-duration: var(--sbb-alert-animation-duration);
|
|
111
|
+
animation-timing-function: var(--sbb-alert-timing-function);
|
|
112
|
+
animation-delay: 0s, var(--sbb-disable-animation-zero-time, var(--sbb-animation-duration-2x));
|
|
113
|
+
}
|
|
100
114
|
|
|
101
115
|
.sbb-alert__transition-sub-wrapper {
|
|
102
116
|
overflow: hidden;
|
|
@@ -196,6 +210,22 @@ const style = css`/**
|
|
|
196
210
|
to {
|
|
197
211
|
opacity: 1;
|
|
198
212
|
}
|
|
213
|
+
}
|
|
214
|
+
@keyframes close {
|
|
215
|
+
from {
|
|
216
|
+
grid-template-rows: 1fr;
|
|
217
|
+
}
|
|
218
|
+
to {
|
|
219
|
+
grid-template-rows: 0fr;
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
@keyframes close-opacity {
|
|
223
|
+
from {
|
|
224
|
+
opacity: 1;
|
|
225
|
+
}
|
|
226
|
+
to {
|
|
227
|
+
opacity: 0;
|
|
228
|
+
}
|
|
199
229
|
}`;
|
|
200
230
|
var __defProp = Object.defineProperty;
|
|
201
231
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
@@ -207,48 +237,57 @@ var __decorateClass = (decorators, target, key, kind) => {
|
|
|
207
237
|
if (kind && result) __defProp(target, key, result);
|
|
208
238
|
return result;
|
|
209
239
|
};
|
|
210
|
-
let SbbAlertElement = class extends SbbIconNameMixin(
|
|
240
|
+
let SbbAlertElement = class extends SbbIconNameMixin(SbbOpenCloseBaseElement) {
|
|
211
241
|
constructor() {
|
|
212
242
|
super(...arguments);
|
|
213
243
|
this.readonly = false;
|
|
214
244
|
this.size = "m";
|
|
215
245
|
this.iconName = "info";
|
|
216
246
|
this.titleLevel = "3";
|
|
217
|
-
this.animation = "
|
|
218
|
-
this._willOpen = new EventEmitter(this, SbbAlertElement.events.willOpen);
|
|
219
|
-
this._didOpen = new EventEmitter(this, SbbAlertElement.events.didOpen);
|
|
247
|
+
this.animation = "all";
|
|
220
248
|
this._dismissalRequested = new EventEmitter(
|
|
221
249
|
this,
|
|
222
250
|
SbbAlertElement.events.dismissalRequested
|
|
223
251
|
);
|
|
224
252
|
this._language = new SbbLanguageController(this);
|
|
225
253
|
}
|
|
226
|
-
/** The state of the alert. */
|
|
227
|
-
get _state() {
|
|
228
|
-
return this.getAttribute("data-state") ?? "closed";
|
|
229
|
-
}
|
|
230
|
-
set _state(value) {
|
|
231
|
-
this.setAttribute("data-state", value);
|
|
232
|
-
}
|
|
233
254
|
async firstUpdated(changedProperties) {
|
|
234
255
|
super.firstUpdated(changedProperties);
|
|
235
|
-
this.
|
|
256
|
+
this.open();
|
|
236
257
|
}
|
|
237
|
-
/** Requests dismissal of the alert.
|
|
258
|
+
/** Requests dismissal of the alert.
|
|
259
|
+
* @deprecated in favour of 'willClose' and 'didClose' events
|
|
260
|
+
*/
|
|
238
261
|
requestDismissal() {
|
|
239
262
|
this._dismissalRequested.emit();
|
|
240
263
|
}
|
|
241
264
|
/** Open the alert. */
|
|
242
|
-
|
|
243
|
-
this.
|
|
244
|
-
this.
|
|
265
|
+
open() {
|
|
266
|
+
this.willOpen.emit();
|
|
267
|
+
this.state = "opening";
|
|
268
|
+
}
|
|
269
|
+
/** Close the alert. */
|
|
270
|
+
close() {
|
|
271
|
+
if (this.willClose.emit()) {
|
|
272
|
+
this.state = "closing";
|
|
273
|
+
}
|
|
245
274
|
}
|
|
246
275
|
_onAnimationEnd(event) {
|
|
247
|
-
if (this.
|
|
248
|
-
this.
|
|
249
|
-
|
|
276
|
+
if (this.state === "opening" && event.animationName === "open-opacity") {
|
|
277
|
+
this._handleOpening();
|
|
278
|
+
} else if (this.state === "closing" && event.animationName === "close") {
|
|
279
|
+
this._handleClosing();
|
|
250
280
|
}
|
|
251
281
|
}
|
|
282
|
+
_handleOpening() {
|
|
283
|
+
this.state = "opened";
|
|
284
|
+
this.didOpen.emit();
|
|
285
|
+
}
|
|
286
|
+
_handleClosing() {
|
|
287
|
+
this.state = "closed";
|
|
288
|
+
this.didClose.emit();
|
|
289
|
+
setTimeout(() => this.remove());
|
|
290
|
+
}
|
|
252
291
|
render() {
|
|
253
292
|
return html`
|
|
254
293
|
<div class="sbb-alert__transition-wrapper" @animationend=${this._onAnimationEnd}>
|
|
@@ -303,6 +342,8 @@ SbbAlertElement.styles = style;
|
|
|
303
342
|
SbbAlertElement.events = {
|
|
304
343
|
willOpen: "willOpen",
|
|
305
344
|
didOpen: "didOpen",
|
|
345
|
+
willClose: "willClose",
|
|
346
|
+
didClose: "didClose",
|
|
306
347
|
dismissalRequested: "dismissalRequested"
|
|
307
348
|
};
|
|
308
349
|
__decorateClass([
|
|
@@ -344,4 +385,4 @@ SbbAlertElement = __decorateClass([
|
|
|
344
385
|
export {
|
|
345
386
|
SbbAlertElement
|
|
346
387
|
};
|
|
347
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"alert.js","sources":["../../../../src/elements/alert/alert/alert.ts"],"sourcesContent":["import {\n  type CSSResultGroup,\n  html,\n  LitElement,\n  nothing,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport type { LinkTargetType } from '../../core/base-elements.js';\nimport { SbbLanguageController } from '../../core/controllers.js';\nimport { EventEmitter } from '../../core/eventing.js';\nimport { i18nCloseAlert, i18nFindOutMore } from '../../core/i18n.js';\nimport type { SbbOpenedClosedState } from '../../core/interfaces.js';\nimport { SbbIconNameMixin } from '../../icon.js';\nimport type { SbbTitleLevel } from '../../title.js';\n\nimport style from './alert.scss?lit&inline';\n\nimport '../../button/transparent-button.js';\nimport '../../divider.js';\nimport '../../link.js';\nimport '../../title.js';\n\ntype SbbAlertState = Exclude<SbbOpenedClosedState, 'closing'>;\n\n/**\n * It displays messages which require user's attention.\n *\n * @slot - Use the unnamed slot to add content to the `sbb-alert`.\n * @slot icon - Should be a `sbb-icon` which is displayed next to the title. Styling is optimized for icons of type HIM-CUS.\n * @slot title - Title content.\n * @event {CustomEvent<void>} willOpen - Emits when the fade in animation starts.\n * @event {CustomEvent<void>} didOpen - Emits when the fade in animation ends and the button is displayed.\n * @event {CustomEvent<void>} dismissalRequested - Emits when dismissal of an alert was requested.\n */\n@customElement('sbb-alert')\nexport class SbbAlertElement extends SbbIconNameMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    willOpen: 'willOpen',\n    didOpen: 'didOpen',\n    dismissalRequested: 'dismissalRequested',\n  } as const;\n\n  /**\n   * Whether the alert is readonly.\n   * In readonly mode, there is no dismiss button offered to the user.\n   */\n  @property({ reflect: true, type: Boolean }) public readonly = false;\n\n  /** You can choose between `s`, `m` or `l` size. */\n  @property({ reflect: true }) public size: 's' | 'm' | 'l' = 'm';\n\n  /**\n   * Name of the icon which will be forward to the nested `sbb-icon`.\n   * Choose the icons from https://icons.app.sbb.ch.\n   * Styling is optimized for icons of type HIM-CUS.\n   */\n  @property({ attribute: 'icon-name' }) public override iconName: string = 'info';\n\n  /** Content of title. */\n  @property({ attribute: 'title-content' }) public titleContent?: string;\n\n  /** Level of title, will be rendered as heading tag (e.g. h3). Defaults to level 3. */\n  @property({ attribute: 'title-level' }) public titleLevel: SbbTitleLevel = '3';\n\n  /** Content of the link. */\n  @property({ attribute: 'link-content' }) public linkContent?: string;\n\n  /** The href value you want to link to. */\n  @property() public href: string | undefined;\n\n  /** Where to display the linked URL. */\n  @property() public target: LinkTargetType | string | undefined;\n\n  /** The relationship of the linked URL as space-separated link types. */\n  @property() public rel: string | undefined;\n\n  /** This will be forwarded as aria-label to the relevant nested element. */\n  @property({ attribute: 'accessibility-label' }) public accessibilityLabel: string | undefined;\n\n  /** The enabled animations. */\n  @property({ reflect: true }) public animation: 'open' | 'none' = 'open';\n\n  /** The state of the alert. */\n  private get _state(): SbbAlertState {\n    return (this.getAttribute('data-state') as SbbAlertState | null) ?? 'closed';\n  }\n  private set _state(value: SbbAlertState) {\n    this.setAttribute('data-state', value);\n  }\n\n  /** Emits when the fade in animation starts. */\n  private _willOpen: EventEmitter<void> = new EventEmitter(this, SbbAlertElement.events.willOpen);\n\n  /** Emits when the fade in animation ends and the button is displayed. */\n  private _didOpen: EventEmitter<void> = new EventEmitter(this, SbbAlertElement.events.didOpen);\n\n  /** Emits when dismissal of an alert was requested. */\n  private _dismissalRequested: EventEmitter<void> = new EventEmitter(\n    this,\n    SbbAlertElement.events.dismissalRequested,\n  );\n\n  private _language = new SbbLanguageController(this);\n\n  protected override async firstUpdated(changedProperties: PropertyValues<this>): Promise<void> {\n    super.firstUpdated(changedProperties);\n\n    this._open();\n  }\n\n  /** Requests dismissal of the alert. */\n  public requestDismissal(): void {\n    this._dismissalRequested.emit();\n  }\n\n  /** Open the alert. */\n  private _open(): void {\n    this._state = 'opening';\n    this._willOpen.emit();\n  }\n\n  private _onAnimationEnd(event: AnimationEvent): void {\n    if (this._state === 'opening' && event.animationName === 'open-opacity') {\n      this._state = 'opened';\n      this._didOpen.emit();\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-alert__transition-wrapper\" @animationend=${this._onAnimationEnd}>\n        <!-- sub wrapper needed to properly support fade in animation -->\n        <div class=\"sbb-alert__transition-sub-wrapper\">\n          <div class=\"sbb-alert\">\n            <span class=\"sbb-alert__icon\"> ${this.renderIconSlot()} </span>\n            <span class=\"sbb-alert__content\">\n              <sbb-title\n                class=\"sbb-alert__title\"\n                level=${this.titleLevel}\n                visual-level=${this.size === 'l' ? '3' : '5'}\n                negative\n              >\n                <slot name=\"title\">${this.titleContent}</slot>\n              </sbb-title>\n              <p class=\"sbb-alert__content-slot\">\n                <slot></slot>\n              </p>\n              ${this.href\n                ? html` <sbb-link\n                    accessibility-label=${this.accessibilityLabel ?? nothing}\n                    href=${this.href ?? nothing}\n                    target=${this.target ?? nothing}\n                    rel=${this.rel ?? nothing}\n                    negative\n                  >\n                    ${this.linkContent ? this.linkContent : i18nFindOutMore[this._language.current]}\n                  </sbb-link>`\n                : nothing}\n            </span>\n            ${!this.readonly\n              ? html`<span class=\"sbb-alert__close-button-wrapper\">\n                  <sbb-divider\n                    orientation=\"vertical\"\n                    negative\n                    class=\"sbb-alert__close-button-divider\"\n                  ></sbb-divider>\n                  <sbb-transparent-button\n                    negative\n                    size=${this.size === 'l' ? 'm' : this.size}\n                    icon-name=\"cross-small\"\n                    @click=${() => this.requestDismissal()}\n                    aria-label=${i18nCloseAlert[this._language.current]}\n                    class=\"sbb-alert__close-button\"\n                  ></sbb-transparent-button>\n                </span>`\n              : nothing}\n          </div>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-alert': SbbAlertElement;\n  }\n}\n"],"names":[],"mappings":"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"}
|
|
388
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"alert.js","sources":["../../../../src/elements/alert/alert/alert.ts"],"sourcesContent":["import { type CSSResultGroup, html, nothing, type PropertyValues, type TemplateResult } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { type LinkTargetType, SbbOpenCloseBaseElement } from '../../core/base-elements.js';\nimport { SbbLanguageController } from '../../core/controllers.js';\nimport { EventEmitter } from '../../core/eventing.js';\nimport { i18nCloseAlert, i18nFindOutMore } from '../../core/i18n.js';\nimport { SbbIconNameMixin } from '../../icon.js';\nimport type { SbbTitleLevel } from '../../title.js';\n\nimport style from './alert.scss?lit&inline';\n\nimport '../../button/transparent-button.js';\nimport '../../divider.js';\nimport '../../link.js';\nimport '../../title.js';\n\n/**\n * It displays messages which require user's attention.\n *\n * @slot - Use the unnamed slot to add content to the `sbb-alert`.\n * @slot icon - Should be a `sbb-icon` which is displayed next to the title. Styling is optimized for icons of type HIM-CUS.\n * @slot title - Title content.\n * @event {CustomEvent<void>} willOpen - Emits when the opening animation starts.\n * @event {CustomEvent<void>} didOpen - Emits when the opening animation ends.\n * @event {CustomEvent<void>} willClose - Emits when the closing animation starts. Can be canceled.\n * @event {CustomEvent<void>} didClose - Emits when the closing animation ends.\n * @event {CustomEvent<void>} dismissalRequested - Emits when dismissal of an alert was requested.\n */\n@customElement('sbb-alert')\nexport class SbbAlertElement extends SbbIconNameMixin(SbbOpenCloseBaseElement) {\n  public static override styles: CSSResultGroup = style;\n  public static override readonly events = {\n    willOpen: 'willOpen',\n    didOpen: 'didOpen',\n    willClose: 'willClose',\n    didClose: 'didClose',\n    dismissalRequested: 'dismissalRequested',\n  } as const;\n\n  /**\n   * Whether the alert is readonly.\n   * In readonly mode, there is no dismiss button offered to the user.\n   */\n  @property({ reflect: true, type: Boolean }) public readonly = false;\n\n  /** You can choose between `s`, `m` or `l` size. */\n  @property({ reflect: true }) public size: 's' | 'm' | 'l' = 'm';\n\n  /**\n   * Name of the icon which will be forward to the nested `sbb-icon`.\n   * Choose the icons from https://icons.app.sbb.ch.\n   * Styling is optimized for icons of type HIM-CUS.\n   */\n  @property({ attribute: 'icon-name' }) public override iconName: string = 'info';\n\n  /** Content of title. */\n  @property({ attribute: 'title-content' }) public titleContent?: string;\n\n  /** Level of title, will be rendered as heading tag (e.g. h3). Defaults to level 3. */\n  @property({ attribute: 'title-level' }) public titleLevel: SbbTitleLevel = '3';\n\n  /** Content of the link. */\n  @property({ attribute: 'link-content' }) public linkContent?: string;\n\n  /** The href value you want to link to. */\n  @property() public href: string | undefined;\n\n  /** Where to display the linked URL. */\n  @property() public target: LinkTargetType | string | undefined;\n\n  /** The relationship of the linked URL as space-separated link types. */\n  @property() public rel: string | undefined;\n\n  /** This will be forwarded as aria-label to the relevant nested element. */\n  @property({ attribute: 'accessibility-label' }) public accessibilityLabel: string | undefined;\n\n  /** The enabled animations. */\n  @property({ reflect: true }) public animation: 'open' | 'close' | 'all' | 'none' = 'all';\n\n  /**\n   * Emits when dismissal of an alert was requested.\n   * @deprecated\n   */\n  private _dismissalRequested: EventEmitter<void> = new EventEmitter(\n    this,\n    SbbAlertElement.events.dismissalRequested,\n  );\n\n  private _language = new SbbLanguageController(this);\n\n  protected override async firstUpdated(changedProperties: PropertyValues<this>): Promise<void> {\n    super.firstUpdated(changedProperties);\n\n    this.open();\n  }\n\n  /** Requests dismissal of the alert.\n   * @deprecated in favour of 'willClose' and 'didClose' events\n   */\n  public requestDismissal(): void {\n    this._dismissalRequested.emit();\n  }\n\n  /** Open the alert. */\n  public open(): void {\n    this.willOpen.emit();\n    this.state = 'opening';\n  }\n\n  /** Close the alert. */\n  public close(): void {\n    if (this.willClose.emit()) {\n      this.state = 'closing';\n    }\n  }\n\n  private _onAnimationEnd(event: AnimationEvent): void {\n    if (this.state === 'opening' && event.animationName === 'open-opacity') {\n      this._handleOpening();\n    } else if (this.state === 'closing' && event.animationName === 'close') {\n      this._handleClosing();\n    }\n  }\n\n  private _handleOpening(): void {\n    this.state = 'opened';\n    this.didOpen.emit();\n  }\n\n  private _handleClosing(): void {\n    this.state = 'closed';\n    this.didClose.emit();\n    setTimeout(() => this.remove());\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-alert__transition-wrapper\" @animationend=${this._onAnimationEnd}>\n        <!-- sub wrapper needed to properly support fade in animation -->\n        <div class=\"sbb-alert__transition-sub-wrapper\">\n          <div class=\"sbb-alert\">\n            <span class=\"sbb-alert__icon\"> ${this.renderIconSlot()} </span>\n            <span class=\"sbb-alert__content\">\n              <sbb-title\n                class=\"sbb-alert__title\"\n                level=${this.titleLevel}\n                visual-level=${this.size === 'l' ? '3' : '5'}\n                negative\n              >\n                <slot name=\"title\">${this.titleContent}</slot>\n              </sbb-title>\n              <p class=\"sbb-alert__content-slot\">\n                <slot></slot>\n              </p>\n              ${this.href\n                ? html` <sbb-link\n                    accessibility-label=${this.accessibilityLabel ?? nothing}\n                    href=${this.href ?? nothing}\n                    target=${this.target ?? nothing}\n                    rel=${this.rel ?? nothing}\n                    negative\n                  >\n                    ${this.linkContent ? this.linkContent : i18nFindOutMore[this._language.current]}\n                  </sbb-link>`\n                : nothing}\n            </span>\n            ${!this.readonly\n              ? html`<span class=\"sbb-alert__close-button-wrapper\">\n                  <sbb-divider\n                    orientation=\"vertical\"\n                    negative\n                    class=\"sbb-alert__close-button-divider\"\n                  ></sbb-divider>\n                  <sbb-transparent-button\n                    negative\n                    size=${this.size === 'l' ? 'm' : this.size}\n                    icon-name=\"cross-small\"\n                    @click=${() => this.requestDismissal()}\n                    aria-label=${i18nCloseAlert[this._language.current]}\n                    class=\"sbb-alert__close-button\"\n                  ></sbb-transparent-button>\n                </span>`\n              : nothing}\n          </div>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-alert': SbbAlertElement;\n  }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { LitElement, CSSResultGroup, TemplateResult } from 'lit';
|
|
2
2
|
import { SbbIconPlacement } from '../../core/interfaces.js';
|
|
3
|
+
import { SbbCheckboxSize } from '../common.js';
|
|
3
4
|
|
|
4
5
|
declare const SbbCheckboxElement_base: import('../../core/mixins.js').Constructor<import('../common.js').SbbCheckboxCommonElementMixinType> & import('../../core/mixins.js').AbstractConstructor<import('../../icon.js').SbbIconNameMixinType> & typeof LitElement;
|
|
5
6
|
/**
|
|
@@ -16,6 +17,10 @@ export declare class SbbCheckboxElement extends SbbCheckboxElement_base {
|
|
|
16
17
|
static readonly events: {
|
|
17
18
|
readonly didChange: "didChange";
|
|
18
19
|
};
|
|
20
|
+
/** Size variant. */
|
|
21
|
+
set size(value: SbbCheckboxSize);
|
|
22
|
+
get size(): SbbCheckboxSize;
|
|
23
|
+
private _size;
|
|
19
24
|
/** The label position relative to the labelIcon. Defaults to end */
|
|
20
25
|
iconPlacement: SbbIconPlacement;
|
|
21
26
|
protected render(): TemplateResult;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"checkbox.d.ts","sourceRoot":"","sources":["../../../../../src/elements/checkbox/checkbox/checkbox.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAQ,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAIjF,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;
|
|
1
|
+
{"version":3,"file":"checkbox.d.ts","sourceRoot":"","sources":["../../../../../src/elements/checkbox/checkbox/checkbox.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAQ,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAIjF,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAEjE,OAAO,EAGL,KAAK,eAAe,EACrB,MAAM,cAAc,CAAC;AAItB,OAAO,0BAA0B,CAAC;;AAElC;;;;;;;;GAQG;AACH,qBAEa,kBAAmB,SAAQ,uBAEvC;IACC,OAAuB,MAAM,EAAE,cAAc,CAAwC;IAErF,gBAAuB,MAAM;;MAElB;IAEX,oBAAoB;IACpB,IACW,IAAI,CAAC,KAAK,EAAE,eAAe,EAErC;IACD,IAAW,IAAI,IAAI,eAAe,CAEjC;IACD,OAAO,CAAC,KAAK,CAAwB;IAErC,oEAAoE;IAE7D,aAAa,EAAE,gBAAgB,CAAS;cAE5B,MAAM,IAAI,cAAc;CAwB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,cAAc,EAAE,kBAAkB,CAAC;KACpC;CACF"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { CSSResultGroup, LitElement, PropertyValues, TemplateResult } from 'lit';
|
|
2
2
|
import { EventEmitter } from '../../core/eventing.js';
|
|
3
3
|
import { SbbCheckedStateChange, SbbDisabledStateChange, SbbStateChange } from '../../core/interfaces/types.js';
|
|
4
|
+
import { SbbPanelSize } from '../../core/mixins.js';
|
|
4
5
|
|
|
5
6
|
export type SbbCheckboxPanelStateChange = Extract<SbbStateChange, SbbDisabledStateChange | SbbCheckedStateChange>;
|
|
6
7
|
declare const SbbCheckboxPanelElement_base: import('../../core/mixins.js').AbstractConstructor<import('../../core/mixins.js').SbbPanelMixinType> & import('../../core/mixins.js').Constructor<import('../common.js').SbbCheckboxCommonElementMixinType> & import('../../core/mixins.js').AbstractConstructor<import('../../core/mixins.js').SbbUpdateSchedulerMixinType> & typeof LitElement;
|
|
@@ -22,6 +23,10 @@ export declare class SbbCheckboxPanelElement extends SbbCheckboxPanelElement_bas
|
|
|
22
23
|
readonly stateChange: "stateChange";
|
|
23
24
|
readonly panelConnected: "panelConnected";
|
|
24
25
|
};
|
|
26
|
+
/** Size variant. */
|
|
27
|
+
set size(value: SbbPanelSize);
|
|
28
|
+
get size(): SbbPanelSize;
|
|
29
|
+
private _size;
|
|
25
30
|
/**
|
|
26
31
|
* @internal
|
|
27
32
|
* Internal event that emits whenever the state of the checkbox
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"checkbox-panel.d.ts","sourceRoot":"","sources":["../../../../../src/elements/checkbox/checkbox-panel/checkbox-panel.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAEnB,UAAU,EAEV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAIb,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,KAAK,EACV,qBAAqB,EACrB,sBAAsB,EACtB,cAAc,EACf,MAAM,gCAAgC,CAAC;
|
|
1
|
+
{"version":3,"file":"checkbox-panel.d.ts","sourceRoot":"","sources":["../../../../../src/elements/checkbox/checkbox-panel/checkbox-panel.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAEnB,UAAU,EAEV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAIb,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,KAAK,EACV,qBAAqB,EACrB,sBAAsB,EACtB,cAAc,EACf,MAAM,gCAAgC,CAAC;AACxC,OAAO,EAGL,KAAK,YAAY,EAElB,MAAM,sBAAsB,CAAC;AAG9B,OAAO,6BAA6B,CAAC;AACrC,OAAO,0BAA0B,CAAC;AAElC,MAAM,MAAM,2BAA2B,GAAG,OAAO,CAC/C,cAAc,EACd,sBAAsB,GAAG,qBAAqB,CAC/C,CAAC;;AAEF;;;;;;;;;;GAUG;AACH,qBAEa,uBAAwB,SAAQ,4BAE5C;IACC,OAAuB,MAAM,EAAE,cAAc,CAA2C;IAGxF,gBAAuB,MAAM;;;;MAIlB;IAEX,oBAAoB;IACpB,IACW,IAAI,CAAC,KAAK,EAAE,YAAY,EAElC;IACD,IAAW,IAAI,IAAI,YAAY,CAE9B;IACD,OAAO,CAAC,KAAK,CAAqB;IAElC;;;;OAIG;IACH,SAAS,CAAC,WAAW,EAAE,YAAY,CAAC,2BAA2B,CAAC,CAI9D;cAEuB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;cAkBxE,MAAM,IAAI,cAAc;CA8B5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,oBAAoB,EAAE,uBAAuB,CAAC;KAC/C;CACF"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { LitElement, html, nothing } from "lit";
|
|
2
|
-
import { customElement } from "lit/decorators.js";
|
|
2
|
+
import { property, customElement } from "lit/decorators.js";
|
|
3
3
|
import { slotState } from "../core/decorators.js";
|
|
4
4
|
import { EventEmitter } from "../core/eventing.js";
|
|
5
5
|
import { SbbPanelMixin, SbbUpdateSchedulerMixin, panelCommonStyle } from "../core/mixins.js";
|
|
@@ -21,12 +21,20 @@ let SbbCheckboxPanelElement = class extends SbbPanelMixin(
|
|
|
21
21
|
) {
|
|
22
22
|
constructor() {
|
|
23
23
|
super(...arguments);
|
|
24
|
+
this._size = "m";
|
|
24
25
|
this.stateChange = new EventEmitter(
|
|
25
26
|
this,
|
|
26
27
|
SbbCheckboxPanelElement.events.stateChange,
|
|
27
28
|
{ bubbles: true }
|
|
28
29
|
);
|
|
29
30
|
}
|
|
31
|
+
set size(value) {
|
|
32
|
+
this._size = value;
|
|
33
|
+
}
|
|
34
|
+
get size() {
|
|
35
|
+
var _a;
|
|
36
|
+
return ((_a = this.group) == null ? void 0 : _a.size) ? this.group.size === "xs" ? "s" : this.group.size : this._size;
|
|
37
|
+
}
|
|
30
38
|
async willUpdate(changedProperties) {
|
|
31
39
|
super.willUpdate(changedProperties);
|
|
32
40
|
if (changedProperties.has("checked")) {
|
|
@@ -76,6 +84,9 @@ SbbCheckboxPanelElement.events = {
|
|
|
76
84
|
stateChange: "stateChange",
|
|
77
85
|
panelConnected: "panelConnected"
|
|
78
86
|
};
|
|
87
|
+
__decorateClass([
|
|
88
|
+
property({ reflect: true })
|
|
89
|
+
], SbbCheckboxPanelElement.prototype, "size", 1);
|
|
79
90
|
SbbCheckboxPanelElement = __decorateClass([
|
|
80
91
|
customElement("sbb-checkbox-panel"),
|
|
81
92
|
slotState()
|
|
@@ -83,4 +94,4 @@ SbbCheckboxPanelElement = __decorateClass([
|
|
|
83
94
|
export {
|
|
84
95
|
SbbCheckboxPanelElement
|
|
85
96
|
};
|
|
86
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
97
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"checkbox-panel.js","sources":["../../../../src/elements/checkbox/checkbox-panel/checkbox-panel.ts"],"sourcesContent":["import {\n  type CSSResultGroup,\n  html,\n  LitElement,\n  nothing,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { slotState } from '../../core/decorators.js';\nimport { EventEmitter } from '../../core/eventing.js';\nimport type {\n  SbbCheckedStateChange,\n  SbbDisabledStateChange,\n  SbbStateChange,\n} from '../../core/interfaces/types.js';\nimport {\n  panelCommonStyle,\n  SbbPanelMixin,\n  type SbbPanelSize,\n  SbbUpdateSchedulerMixin,\n} from '../../core/mixins.js';\nimport { checkboxCommonStyle, SbbCheckboxCommonElementMixin } from '../common.js';\n\nimport '../../screen-reader-only.js';\nimport '../../visual-checkbox.js';\n\nexport type SbbCheckboxPanelStateChange = Extract<\n  SbbStateChange,\n  SbbDisabledStateChange | SbbCheckedStateChange\n>;\n\n/**\n * It displays a checkbox enhanced with selection panel design.\n *\n * @slot - Use the unnamed slot to add content to the `sbb-checkbox`.\n * @slot subtext - Slot used to render a subtext under the label (only visible within a selection panel).\n * @slot suffix - Slot used to render additional content after the label (only visible within a selection panel).\n * @slot badge - Use this slot to provide a `sbb-card-badge` (optional).\n * @event {CustomEvent<void>} didChange - Deprecated. used for React. Will probably be removed once React 19 is available.\n * @event {Event} change - Event fired on change.\n * @event {InputEvent} input - Event fired on input.\n */\n@customElement('sbb-checkbox-panel')\n@slotState()\nexport class SbbCheckboxPanelElement extends SbbPanelMixin(\n  SbbCheckboxCommonElementMixin(SbbUpdateSchedulerMixin(LitElement)),\n) {\n  public static override styles: CSSResultGroup = [checkboxCommonStyle, panelCommonStyle];\n\n  // FIXME using ...super.events requires: https://github.com/sbb-design-systems/lyne-components/issues/2600\n  public static readonly events = {\n    didChange: 'didChange',\n    stateChange: 'stateChange',\n    panelConnected: 'panelConnected',\n  } as const;\n\n  /** Size variant. */\n  @property({ reflect: true })\n  public set size(value: SbbPanelSize) {\n    this._size = value;\n  }\n  public get size(): SbbPanelSize {\n    return this.group?.size ? (this.group.size === 'xs' ? 's' : this.group.size) : this._size;\n  }\n  private _size: SbbPanelSize = 'm';\n\n  /**\n   * @internal\n   * Internal event that emits whenever the state of the checkbox\n   * in relation to the parent selection panel changes.\n   */\n  protected stateChange: EventEmitter<SbbCheckboxPanelStateChange> = new EventEmitter(\n    this,\n    SbbCheckboxPanelElement.events.stateChange,\n    { bubbles: true },\n  );\n\n  protected override async willUpdate(changedProperties: PropertyValues<this>): Promise<void> {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('checked')) {\n      // As SbbFormAssociatedCheckboxMixin does not reflect checked property, we add a data-checked.\n      this.toggleAttribute('data-checked', this.checked);\n\n      if (this.checked !== changedProperties.get('checked')!) {\n        this.stateChange.emit({ type: 'checked', checked: this.checked });\n      }\n    }\n    if (changedProperties.has('disabled')) {\n      if (this.disabled !== changedProperties.get('disabled')!) {\n        this.stateChange.emit({ type: 'disabled', disabled: this.disabled });\n      }\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <span class=\"sbb-selection-panel\">\n        <div class=\"sbb-selection-panel__badge\">\n          <slot name=\"badge\"></slot>\n        </div>\n        <span class=\"sbb-checkbox-wrapper\">\n          <span class=\"sbb-checkbox\">\n            <span class=\"sbb-checkbox__inner\">\n              <span class=\"sbb-checkbox__aligner\">\n                <sbb-visual-checkbox\n                  ?checked=${this.checked}\n                  ?indeterminate=${this.indeterminate}\n                  ?disabled=${this.disabled || this.formDisabled}\n                ></sbb-visual-checkbox>\n              </span>\n              <span class=\"sbb-checkbox__label\">\n                <slot></slot>\n                <slot name=\"suffix\"></slot>\n              </span>\n            </span>\n            <slot name=\"subtext\"></slot>\n            ${this.expansionState\n              ? html`<sbb-screen-reader-only>${this.expansionState}</sbb-screen-reader-only>`\n              : nothing}\n          </span>\n        </span>\n      </span>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-checkbox-panel': SbbCheckboxPanelElement;\n  }\n}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;AA8CO,IAAM,0BAAN,cAAsC;AAAA,EAC3C,8BAA8B,wBAAwB,UAAU,CAAC;AACnE,EAAE;AAAA,EAFK,cAAA;AAAA,UAAA,GAAA,SAAA;AAoBL,SAAQ,QAAsB;AAO9B,SAAU,cAAyD,IAAI;AAAA,MACrE;AAAA,MACA,wBAAwB,OAAO;AAAA,MAC/B,EAAE,SAAS,KAAK;AAAA,IAAA;AAAA,EAClB;AAAA,EAjBA,IAAW,KAAK,OAAqB;AACnC,SAAK,QAAQ;AAAA,EACf;AAAA,EACA,IAAW,OAAqB;;AACvB,aAAA,UAAK,UAAL,mBAAY,QAAQ,KAAK,MAAM,SAAS,OAAO,MAAM,KAAK,MAAM,OAAQ,KAAK;AAAA,EACtF;AAAA,EAcA,MAAyB,WAAW,mBAAwD;AAC1F,UAAM,WAAW,iBAAiB;AAE9B,QAAA,kBAAkB,IAAI,SAAS,GAAG;AAE/B,WAAA,gBAAgB,gBAAgB,KAAK,OAAO;AAEjD,UAAI,KAAK,YAAY,kBAAkB,IAAI,SAAS,GAAI;AACjD,aAAA,YAAY,KAAK,EAAE,MAAM,WAAW,SAAS,KAAK,SAAS;AAAA,MAClE;AAAA,IACF;AACI,QAAA,kBAAkB,IAAI,UAAU,GAAG;AACrC,UAAI,KAAK,aAAa,kBAAkB,IAAI,UAAU,GAAI;AACnD,aAAA,YAAY,KAAK,EAAE,MAAM,YAAY,UAAU,KAAK,UAAU;AAAA,MACrE;AAAA,IACF;AAAA,EACF;AAAA,EAEmB,SAAyB;AACnC,WAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,6BAUkB,KAAK,OAAO;AAAA,mCACN,KAAK,aAAa;AAAA,8BACvB,KAAK,YAAY,KAAK,YAAY;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,cASlD,KAAK,iBACH,+BAA+B,KAAK,cAAc,8BAClD,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA,EAKrB;AACF;AAjFa,wBAGY,SAAyB,CAAC,qBAAqB,gBAAgB;AAH3E,wBAMY,SAAS;AAAA,EAC9B,WAAW;AAAA,EACX,aAAa;AAAA,EACb,gBAAgB;AAClB;AAIW,gBAAA;AAAA,EADV,SAAS,EAAE,SAAS,MAAM;AAAA,GAbhB,wBAcA,WAAA,QAAA,CAAA;AAdA,0BAAN,gBAAA;AAAA,EAFN,cAAc,oBAAoB;AAAA,EAClC,UAAU;AAAA,GACE,uBAAA;"}
|
|
@@ -74,8 +74,16 @@ let SbbCheckboxElement = class extends SbbCheckboxCommonElementMixin(
|
|
|
74
74
|
) {
|
|
75
75
|
constructor() {
|
|
76
76
|
super(...arguments);
|
|
77
|
+
this._size = "m";
|
|
77
78
|
this.iconPlacement = "end";
|
|
78
79
|
}
|
|
80
|
+
set size(value) {
|
|
81
|
+
this._size = value;
|
|
82
|
+
}
|
|
83
|
+
get size() {
|
|
84
|
+
var _a;
|
|
85
|
+
return ((_a = this.group) == null ? void 0 : _a.size) ?? this._size;
|
|
86
|
+
}
|
|
79
87
|
render() {
|
|
80
88
|
return html`
|
|
81
89
|
<span class="sbb-checkbox-wrapper">
|
|
@@ -86,6 +94,7 @@ let SbbCheckboxElement = class extends SbbCheckboxCommonElementMixin(
|
|
|
86
94
|
?checked=${this.checked}
|
|
87
95
|
?indeterminate=${this.indeterminate}
|
|
88
96
|
?disabled=${this.disabled || this.formDisabled}
|
|
97
|
+
size=${this.size}
|
|
89
98
|
></sbb-visual-checkbox>
|
|
90
99
|
</span>
|
|
91
100
|
<span class="sbb-checkbox__label">
|
|
@@ -104,6 +113,9 @@ SbbCheckboxElement.styles = [checkboxCommonStyle, checkboxStyle];
|
|
|
104
113
|
SbbCheckboxElement.events = {
|
|
105
114
|
didChange: "didChange"
|
|
106
115
|
};
|
|
116
|
+
__decorateClass([
|
|
117
|
+
property({ reflect: true })
|
|
118
|
+
], SbbCheckboxElement.prototype, "size", 1);
|
|
107
119
|
__decorateClass([
|
|
108
120
|
property({ attribute: "icon-placement", reflect: true })
|
|
109
121
|
], SbbCheckboxElement.prototype, "iconPlacement", 2);
|
|
@@ -114,4 +126,4 @@ SbbCheckboxElement = __decorateClass([
|
|
|
114
126
|
export {
|
|
115
127
|
SbbCheckboxElement
|
|
116
128
|
};
|
|
117
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
129
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3guanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9lbGVtZW50cy9jaGVja2JveC9jaGVja2JveC9jaGVja2JveC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBMaXRFbGVtZW50LCBodG1sLCB0eXBlIENTU1Jlc3VsdEdyb3VwLCB0eXBlIFRlbXBsYXRlUmVzdWx0IH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQsIHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgeyBzbG90U3RhdGUgfSBmcm9tICcuLi8uLi9jb3JlL2RlY29yYXRvcnMuanMnO1xuaW1wb3J0IHR5cGUgeyBTYmJJY29uUGxhY2VtZW50IH0gZnJvbSAnLi4vLi4vY29yZS9pbnRlcmZhY2VzLmpzJztcbmltcG9ydCB7IFNiYkljb25OYW1lTWl4aW4gfSBmcm9tICcuLi8uLi9pY29uLmpzJztcbmltcG9ydCB7XG4gIFNiYkNoZWNrYm94Q29tbW9uRWxlbWVudE1peGluLFxuICBjaGVja2JveENvbW1vblN0eWxlLFxuICB0eXBlIFNiYkNoZWNrYm94U2l6ZSxcbn0gZnJvbSAnLi4vY29tbW9uLmpzJztcblxuaW1wb3J0IGNoZWNrYm94U3R5bGUgZnJvbSAnLi9jaGVja2JveC5zY3NzP2xpdCZpbmxpbmUnO1xuXG5pbXBvcnQgJy4uLy4uL3Zpc3VhbC1jaGVja2JveC5qcyc7XG5cbi8qKlxuICogSXQgZGlzcGxheXMgYSBjaGVja2JveCBlbmhhbmNlZCB3aXRoIHRoZSBTQkIgRGVzaWduLlxuICpcbiAqIEBzbG90IC0gVXNlIHRoZSB1bm5hbWVkIHNsb3QgdG8gYWRkIGNvbnRlbnQgdG8gdGhlIGBzYmItY2hlY2tib3hgLlxuICogQHNsb3QgaWNvbiAtIFNsb3QgdXNlZCB0byByZW5kZXIgdGhlIGNoZWNrYm94IGljb24gKGRpc2FibGVkIGluc2lkZSBhIHNlbGVjdGlvbiBwYW5lbCkuXG4gKiBAZXZlbnQge0N1c3RvbUV2ZW50PHZvaWQ+fSBkaWRDaGFuZ2UgLSBEZXByZWNhdGVkLiB1c2VkIGZvciBSZWFjdC4gV2lsbCBwcm9iYWJseSBiZSByZW1vdmVkIG9uY2UgUmVhY3QgMTkgaXMgYXZhaWxhYmxlLlxuICogQGV2ZW50IHtFdmVudH0gY2hhbmdlIC0gRXZlbnQgZmlyZWQgb24gY2hhbmdlLlxuICogQGV2ZW50IHtJbnB1dEV2ZW50fSBpbnB1dCAtIEV2ZW50IGZpcmVkIG9uIGlucHV0LlxuICovXG5AY3VzdG9tRWxlbWVudCgnc2JiLWNoZWNrYm94JylcbkBzbG90U3RhdGUoKVxuZXhwb3J0IGNsYXNzIFNiYkNoZWNrYm94RWxlbWVudCBleHRlbmRzIFNiYkNoZWNrYm94Q29tbW9uRWxlbWVudE1peGluKFxuICBTYmJJY29uTmFtZU1peGluKExpdEVsZW1lbnQpLFxuKSB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IFtjaGVja2JveENvbW1vblN0eWxlLCBjaGVja2JveFN0eWxlXTtcblxuICBwdWJsaWMgc3RhdGljIHJlYWRvbmx5IGV2ZW50cyA9IHtcbiAgICBkaWRDaGFuZ2U6ICdkaWRDaGFuZ2UnLFxuICB9IGFzIGNvbnN0O1xuXG4gIC8qKiBTaXplIHZhcmlhbnQuICovXG4gIEBwcm9wZXJ0eSh7IHJlZmxlY3Q6IHRydWUgfSlcbiAgcHVibGljIHNldCBzaXplKHZhbHVlOiBTYmJDaGVja2JveFNpemUpIHtcbiAgICB0aGlzLl9zaXplID0gdmFsdWU7XG4gIH1cbiAgcHVibGljIGdldCBzaXplKCk6IFNiYkNoZWNrYm94U2l6ZSB7XG4gICAgcmV0dXJuIHRoaXMuZ3JvdXA/LnNpemUgPz8gdGhpcy5fc2l6ZTtcbiAgfVxuICBwcml2YXRlIF9zaXplOiBTYmJDaGVja2JveFNpemUgPSAnbSc7XG5cbiAgLyoqIFRoZSBsYWJlbCBwb3NpdGlvbiByZWxhdGl2ZSB0byB0aGUgbGFiZWxJY29uLiBEZWZhdWx0cyB0byBlbmQgKi9cbiAgQHByb3BlcnR5KHsgYXR0cmlidXRlOiAnaWNvbi1wbGFjZW1lbnQnLCByZWZsZWN0OiB0cnVlIH0pXG4gIHB1YmxpYyBpY29uUGxhY2VtZW50OiBTYmJJY29uUGxhY2VtZW50ID0gJ2VuZCc7XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlbmRlcigpOiBUZW1wbGF0ZVJlc3VsdCB7XG4gICAgcmV0dXJuIGh0bWxgXG4gICAgICA8c3BhbiBjbGFzcz1cInNiYi1jaGVja2JveC13cmFwcGVyXCI+XG4gICAgICAgIDxzcGFuIGNsYXNzPVwic2JiLWNoZWNrYm94XCI+XG4gICAgICAgICAgPHNwYW4gY2xhc3M9XCJzYmItY2hlY2tib3hfX2lubmVyXCI+XG4gICAgICAgICAgICA8c3BhbiBjbGFzcz1cInNiYi1jaGVja2JveF9fYWxpZ25lclwiPlxuICAgICAgICAgICAgICA8c2JiLXZpc3VhbC1jaGVja2JveFxuICAgICAgICAgICAgICAgID9jaGVja2VkPSR7dGhpcy5jaGVja2VkfVxuICAgICAgICAgICAgICAgID9pbmRldGVybWluYXRlPSR7dGhpcy5pbmRldGVybWluYXRlfVxuICAgICAgICAgICAgICAgID9kaXNhYmxlZD0ke3RoaXMuZGlzYWJsZWQgfHwgdGhpcy5mb3JtRGlzYWJsZWR9XG4gICAgICAgICAgICAgICAgc2l6ZT0ke3RoaXMuc2l6ZX1cbiAgICAgICAgICAgICAgPjwvc2JiLXZpc3VhbC1jaGVja2JveD5cbiAgICAgICAgICAgIDwvc3Bhbj5cbiAgICAgICAgICAgIDxzcGFuIGNsYXNzPVwic2JiLWNoZWNrYm94X19sYWJlbFwiPlxuICAgICAgICAgICAgICA8c2xvdD48L3Nsb3Q+XG4gICAgICAgICAgICAgIDxzcGFuIGNsYXNzPVwic2JiLWNoZWNrYm94X19sYWJlbC0taWNvbiBzYmItY2hlY2tib3hfX2FsaWduZXJcIlxuICAgICAgICAgICAgICAgID4ke3RoaXMucmVuZGVySWNvblNsb3QoKX08L3NwYW5cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgPC9zcGFuPlxuICAgICAgICAgIDwvc3Bhbj5cbiAgICAgICAgPC9zcGFuPlxuICAgICAgPC9zcGFuPlxuICAgIGA7XG4gIH1cbn1cblxuZGVjbGFyZSBnbG9iYWwge1xuICBpbnRlcmZhY2UgSFRNTEVsZW1lbnRUYWdOYW1lTWFwIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25hbWluZy1jb252ZW50aW9uXG4gICAgJ3NiYi1jaGVja2JveCc6IFNiYkNoZWNrYm94RWxlbWVudDtcbiAgfVxufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBMkJPLElBQU0scUJBQU4sY0FBaUM7QUFBQSxFQUN0QyxpQkFBaUIsVUFBVTtBQUM3QixFQUFFO0FBQUEsRUFGSyxjQUFBO0FBQUEsVUFBQSxHQUFBLFNBQUE7QUFpQkwsU0FBUSxRQUF5QjtBQUlqQyxTQUFPLGdCQUFrQztBQUFBLEVBQUE7QUFBQSxFQVZ6QyxJQUFXLEtBQUssT0FBd0I7QUFDdEMsU0FBSyxRQUFRO0FBQUEsRUFDZjtBQUFBLEVBQ0EsSUFBVyxPQUF3Qjs7QUFDMUIsYUFBQSxVQUFLLFVBQUwsbUJBQVksU0FBUSxLQUFLO0FBQUEsRUFDbEM7QUFBQSxFQU9tQixTQUF5QjtBQUNuQyxXQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLDJCQU1nQixLQUFLLE9BQU87QUFBQSxpQ0FDTixLQUFLLGFBQWE7QUFBQSw0QkFDdkIsS0FBSyxZQUFZLEtBQUssWUFBWTtBQUFBLHVCQUN2QyxLQUFLLElBQUk7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsbUJBTWIsS0FBSyxnQkFBZ0I7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxFQU90QztBQUNGO0FBL0NhLG1CQUdZLFNBQXlCLENBQUMscUJBQXFCLGFBQWE7QUFIeEUsbUJBS1ksU0FBUztBQUFBLEVBQzlCLFdBQVc7QUFDYjtBQUlXLGdCQUFBO0FBQUEsRUFEVixTQUFTLEVBQUUsU0FBUyxNQUFNO0FBQUEsR0FWaEIsbUJBV0EsV0FBQSxRQUFBLENBQUE7QUFVSixnQkFBQTtBQUFBLEVBRE4sU0FBUyxFQUFFLFdBQVcsa0JBQWtCLFNBQVMsTUFBTTtBQUFBLEdBcEI3QyxtQkFxQkosV0FBQSxpQkFBQSxDQUFBO0FBckJJLHFCQUFOLGdCQUFBO0FBQUEsRUFGTixjQUFjLGNBQWM7QUFBQSxFQUM1QixVQUFVO0FBQUEsR0FDRSxrQkFBQTsifQ==
|
|
@@ -2,11 +2,9 @@ import { LitElement } from 'lit';
|
|
|
2
2
|
import { Constructor, SbbDisabledMixinType, SbbFormAssociatedCheckboxMixinType, SbbRequiredMixinType } from '../../core/mixins.js';
|
|
3
3
|
import { SbbCheckboxGroupElement } from '../checkbox-group.js';
|
|
4
4
|
|
|
5
|
-
export type SbbCheckboxSize = 's' | 'm';
|
|
5
|
+
export type SbbCheckboxSize = 'xs' | 's' | 'm';
|
|
6
6
|
export declare class SbbCheckboxCommonElementMixinType extends SbbFormAssociatedCheckboxMixinType implements Partial<SbbDisabledMixinType>, Partial<SbbRequiredMixinType> {
|
|
7
7
|
indeterminate: boolean;
|
|
8
|
-
set size(value: SbbCheckboxSize);
|
|
9
|
-
get size(): SbbCheckboxSize;
|
|
10
8
|
get group(): SbbCheckboxGroupElement | null;
|
|
11
9
|
}
|
|
12
10
|
export declare const SbbCheckboxCommonElementMixin: <T extends Constructor<LitElement>>(superClass: T) => Constructor<SbbCheckboxCommonElementMixinType> & T;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"checkbox-common.d.ts","sourceRoot":"","sources":["../../../../../src/elements/checkbox/common/checkbox-common.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAkB,MAAM,KAAK,CAAC;AAGtD,OAAO,EACL,KAAK,WAAW,EAChB,KAAK,oBAAoB,EAEzB,KAAK,kCAAkC,EACvC,KAAK,oBAAoB,EAC1B,MAAM,sBAAsB,CAAC;AAC9B,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,sBAAsB,CAAC;AAEpE,MAAM,MAAM,eAAe,GAAG,GAAG,GAAG,GAAG,CAAC;
|
|
1
|
+
{"version":3,"file":"checkbox-common.d.ts","sourceRoot":"","sources":["../../../../../src/elements/checkbox/common/checkbox-common.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAkB,MAAM,KAAK,CAAC;AAGtD,OAAO,EACL,KAAK,WAAW,EAChB,KAAK,oBAAoB,EAEzB,KAAK,kCAAkC,EACvC,KAAK,oBAAoB,EAC1B,MAAM,sBAAsB,CAAC;AAC9B,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,sBAAsB,CAAC;AAEpE,MAAM,MAAM,eAAe,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,CAAC;AAE/C,MAAM,CAAC,OAAO,OAAO,iCACnB,SAAQ,kCACR,YAAW,OAAO,CAAC,oBAAoB,CAAC,EAAE,OAAO,CAAC,oBAAoB,CAAC;IAEhE,aAAa,EAAE,OAAO,CAAC;IAE9B,IAAW,KAAK,IAAI,uBAAuB,GAAG,IAAI,CAAC;CACpD;AAGD,eAAO,MAAM,6BAA6B,GAAI,CAAC,SAAS,WAAW,CAAC,UAAU,CAAC,cACjE,CAAC,KACZ,WAAW,CAAC,iCAAiC,CAAC,GAAG,CA6CnD,CAAC"}
|