@sbb-esta/lyne-elements 1.5.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/clock/clock.d.ts.map +1 -1
- package/clock.js +14 -14
- 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 +211 -51
- 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/clock/clock.d.ts.map +1 -1
- package/development/clock.js +3 -2
- 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/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/toggle/toggle.js +1 -1
- package/icon/icon.d.ts +9 -1
- package/icon/icon.d.ts.map +1 -1
- package/icon.js +71 -62
- 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 +1 -1
- package/toggle/toggle.js +1 -1
|
@@ -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 +1 @@
|
|
|
1
|
-
{"version":3,"file":"clock.d.ts","sourceRoot":"","sources":["../../../../src/elements/clock/clock.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAkB,UAAU,EAAE,MAAM,KAAK,CAAC;AAIjD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,uBAAuB,CAAC;AA2CrD;;GAEG;AACH,qBACa,eAAgB,SAAQ,UAAU;IAC7C,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD;;;OAGG;IACgB,GAAG,EAAE,OAAO,GAAG,IAAI,CAAQ;IAE9C,kCAAkC;IAClC,OAAO,CAAC,eAAe,CAAe;IAEtC,oCAAoC;IACpC,OAAO,CAAC,iBAAiB,CAAe;IAExC,oCAAoC;IACpC,OAAO,CAAC,iBAAiB,CAAe;IAExC,wCAAwC;IACxC,OAAO,CAAC,MAAM,CAAU;IAExB,0CAA0C;IAC1C,OAAO,CAAC,QAAQ,CAAU;IAE1B,0CAA0C;IAC1C,OAAO,CAAC,QAAQ,CAAU;IAE1B,wCAAwC;IACxC,OAAO,CAAC,gBAAgB,CAAqC;IAE7D,0CAA0C;IAC1C,OAAO,CAAC,kBAAkB,CAAuC;IAEjE,0CAA0C;IAC1C,OAAO,CAAC,aAAa,CAAC,CAAiC;cAE9B,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;cAQlE,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAS7E,oBAAoB,IAAI,IAAI;IAK5C,OAAO,CAAC,2BAA2B,CAMjC;YAEY,sBAAsB;IAUpC,6FAA6F;YAC/E,WAAW;
|
|
1
|
+
{"version":3,"file":"clock.d.ts","sourceRoot":"","sources":["../../../../src/elements/clock/clock.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAkB,UAAU,EAAE,MAAM,KAAK,CAAC;AAIjD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,uBAAuB,CAAC;AA2CrD;;GAEG;AACH,qBACa,eAAgB,SAAQ,UAAU;IAC7C,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD;;;OAGG;IACgB,GAAG,EAAE,OAAO,GAAG,IAAI,CAAQ;IAE9C,kCAAkC;IAClC,OAAO,CAAC,eAAe,CAAe;IAEtC,oCAAoC;IACpC,OAAO,CAAC,iBAAiB,CAAe;IAExC,oCAAoC;IACpC,OAAO,CAAC,iBAAiB,CAAe;IAExC,wCAAwC;IACxC,OAAO,CAAC,MAAM,CAAU;IAExB,0CAA0C;IAC1C,OAAO,CAAC,QAAQ,CAAU;IAE1B,0CAA0C;IAC1C,OAAO,CAAC,QAAQ,CAAU;IAE1B,wCAAwC;IACxC,OAAO,CAAC,gBAAgB,CAAqC;IAE7D,0CAA0C;IAC1C,OAAO,CAAC,kBAAkB,CAAuC;IAEjE,0CAA0C;IAC1C,OAAO,CAAC,aAAa,CAAC,CAAiC;cAE9B,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;cAQlE,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAS7E,oBAAoB,IAAI,IAAI;IAK5C,OAAO,CAAC,2BAA2B,CAMjC;YAEY,sBAAsB;IAUpC,6FAA6F;YAC/E,WAAW;IAsBzB,sDAAsD;YACxC,UAAU;IAcxB,uEAAuE;IACvE,OAAO,CAAC,yBAAyB;IA4CjC,yGAAyG;IACzG,OAAO,CAAC,kBAAkB;IAW1B,sDAAsD;IACtD,OAAO,CAAC,eAAe;IAOvB,6CAA6C;IAC7C,OAAO,CAAC,cAAc;IAYtB,+CAA+C;IAC/C,OAAO,CAAC,gBAAgB;IAaxB,OAAO,CAAC,sBAAsB;IAK9B;;;;OAIG;IACH,OAAO,CAAC,0BAA0B;IAUlC,OAAO,CAAC,qBAAqB;IAO7B,OAAO,CAAC,2BAA2B;IAMnC,OAAO,CAAC,6BAA6B;cAOlB,MAAM,IAAI,cAAc;CA4B5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,WAAW,EAAE,eAAe,CAAC;KAC9B;CACF"}
|
package/development/clock.js
CHANGED
|
@@ -217,10 +217,11 @@ let SbbClockElement = class extends LitElement {
|
|
|
217
217
|
ADD_EVENT_LISTENER_OPTIONS
|
|
218
218
|
);
|
|
219
219
|
await new Promise(
|
|
220
|
-
() => setTimeout(() => {
|
|
220
|
+
(resolve) => setTimeout(() => {
|
|
221
221
|
var _a2;
|
|
222
222
|
this._setHandsStartingPosition();
|
|
223
223
|
(_a2 = this.style) == null ? void 0 : _a2.setProperty("--sbb-clock-animation-play-state", "running");
|
|
224
|
+
resolve();
|
|
224
225
|
}, INITIAL_TIMEOUT_DURATION)
|
|
225
226
|
);
|
|
226
227
|
}
|
|
@@ -383,4 +384,4 @@ SbbClockElement = __decorateClass([
|
|
|
383
384
|
export {
|
|
384
385
|
SbbClockElement
|
|
385
386
|
};
|
|
386
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"clock.js","sources":["../../../src/elements/clock/assets/sbb_clock_face.svg?raw","../../../src/elements/clock/assets/sbb_clock_hours.svg?raw","../../../src/elements/clock/assets/sbb_clock_minutes.svg?raw","../../../src/elements/clock/assets/sbb_clock_seconds.svg?raw","../../../src/elements/clock/clock.ts"],"sourcesContent":["export default \"<svg focusable=\\\"false\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" viewBox=\\\"0 0 105 105\\\"><g class=\\\"face\\\"><circle fill=\\\"#FFF\\\" cx=\\\"52.5\\\" cy=\\\"52.5\\\" r=\\\"52.5\\\"/><path d=\\\"M50.75 4h3.5v12h-3.5zM50.75 89h3.5v12h-3.5zM75.233 9.623l3.03 1.75-6 10.392-3.03-1.75zM32.734 83.233l3.03 1.75-6 10.392-3.03-1.75zM93.628 26.732l1.75 3.031-10.392 6-1.75-3.03zM20.017 69.234l1.75 3.031-10.392 6-1.75-3.03zM101 50.75v3.5H89v-3.5zM16 50.75v3.5H4v-3.5zM95.379 75.232l-1.75 3.031-10.392-6 1.75-3.03zM21.766 32.734l-1.75 3.031-10.392-6 1.75-3.03zM78.267 93.63l-3.03 1.75-6-10.393 3.03-1.75zM35.766 20.015l-3.03 1.75-6-10.392 3.03-1.75z\\\"/><g><path d=\\\"M56.873 4.19l1.392.147-.366 3.48-1.392-.145zM47.101 97.177l1.393.146-.366 3.481-1.392-.146zM61.896 4.914l1.37.29-.728 3.424-1.37-.29zM42.458 96.366l1.37.29-.728 3.424-1.37-.291zM66.825 6.157l1.332.432-1.082 3.33-1.331-.434zM37.931 95.085l1.332.432-1.082 3.33-1.331-.433zM71.584 7.906l1.28.569-1.424 3.197-1.28-.57zM33.56 93.32l1.278.569-1.423 3.197-1.28-.57zM80.44 12.852l1.133.823-2.058 2.831-1.132-.823zM25.481 88.494l1.133.822-2.057 2.832-1.133-.823zM84.43 15.986l1.04.937-2.342 2.6-1.04-.936zM21.87 85.469l1.04.936-2.341 2.601-1.04-.937zM88.072 19.522l.937 1.04-2.6 2.343-.937-1.04zM18.593 82.088l.937 1.04-2.601 2.342-.937-1.04zM91.328 23.425l.823 1.133-2.832 2.057-.823-1.132zM15.684 78.385l.823 1.132-2.832 2.058-.822-1.133zM96.52 32.128l.57 1.279-3.198 1.423-.57-1.278zM11.109 70.161l.569 1.279-3.197 1.423-.57-1.279zM98.407 36.85l.433 1.332-3.33 1.081-.432-1.331zM9.483 65.74l.432 1.33-3.329 1.082-.432-1.331zM99.795 41.726l.291 1.37-3.423.727-.29-1.37zM8.34 61.17l.292 1.37-3.424.728-.29-1.37zM100.66 46.73l.146 1.393-3.48.366-.147-1.392zM7.674 56.506l.146 1.392-3.48.366-.147-1.392zM100.811 56.873l-.146 1.392-3.48-.365.145-1.393zM7.821 47.101l-.146 1.392-3.48-.365.145-1.393zM100.09 61.895l-.291 1.369-3.424-.728.291-1.369zM8.631 42.46l-.291 1.37-3.423-.728.29-1.37zM98.84 66.827l-.432 1.331-3.329-1.081.433-1.332zM9.918 37.93l-.433 1.331-3.329-1.082.433-1.331zM97.098 71.585l-.569 1.28-3.197-1.424.57-1.28zM11.677 33.558l-.57 1.28-3.197-1.424.57-1.279zM92.149 80.439l-.823 1.133-2.832-2.058.823-1.132zM16.506 25.482l-.823 1.133-2.831-2.057.823-1.133zM89.017 84.431l-.937 1.04-2.6-2.341.936-1.04zM19.528 21.869l-.936 1.04-2.601-2.342.936-1.04zM85.48 88.076l-1.041.936-2.342-2.6 1.04-.937zM22.91 18.59l-1.04.937-2.341-2.601 1.04-.937zM81.574 91.328l-1.133.823-2.057-2.831 1.132-.823zM26.617 15.684l-1.133.823-2.057-2.832 1.132-.823zM72.873 96.524l-1.279.57-1.423-3.198 1.278-.57zM34.838 11.105l-1.279.57-1.423-3.198 1.279-.57zM68.151 98.405l-1.331.432-1.082-3.329 1.332-.432zM39.259 9.485l-1.332.433-1.081-3.33 1.331-.432zM63.272 99.799l-1.369.29-.728-3.422 1.37-.291zM43.83 8.337l-1.369.291-.727-3.423 1.37-.291zM58.27 100.662l-1.393.146-.366-3.48 1.393-.147zM48.494 7.672l-1.392.147-.366-3.481 1.392-.147z\\\"/></g></g></svg>\\n\"","export default \"<svg focusable=\\\"false\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" viewBox=\\\"0 0 105 105\\\"><path id=\\\"mod_clock_svg_hours\\\" d=\\\"M55.7 64.5h-6.4l.6-44h5.2z\\\"/></svg>\\n\"","export default \"<svg focusable=\\\"false\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" viewBox=\\\"0 0 105 105\\\"><path d=\\\"M55.1,64.5h-5.2l0.8-58h3.6L55.1,64.5z\\\"/></svg>\\n\"","export default \"<svg focusable=\\\"false\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" viewBox=\\\"0 0 105 105\\\"><path d=\\\"M57.8,21.3c0-2.9-2.4-5.2-5.2-5.2s-5.3,2.3-5.3,5.2c0,2.7,2,4.8,4.5,5.2V69h1.5V26.5C55.8,26.2,57.8,24,57.8,21.3z\\\"/></svg>\\n\"","import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, isServer, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport type { SbbTime } from '../core/interfaces.js';\n\nimport clockFaceSVG from './assets/sbb_clock_face.svg?raw';\nimport clockHandleHoursSVG from './assets/sbb_clock_hours.svg?raw';\nimport clockHandleMinutesSVG from './assets/sbb_clock_minutes.svg?raw';\nimport clockHandleSecondsSVG from './assets/sbb_clock_seconds.svg?raw';\nimport style from './clock.scss?lit&inline';\n\n/** Number of hours on the clock face. */\nconst TOTAL_HOURS_ON_CLOCK_FACE = 12;\n\n/** Number of minutes on the clock face. */\nconst TOTAL_MINUTES_ON_CLOCK_FACE = 60;\n\n/** Number of seconds on the clock face. */\nconst TOTAL_SECONDS_ON_CLOCK_FACE = 60;\n\n/** Timeout for the clock start. */\nconst INITIAL_TIMEOUT_DURATION = 50;\n\n/** Angle in a single rotation. */\nconst FULL_ANGLE = 360;\n\n/** Angle between two consecutive hours: 360/12, means a full rotation / number of hours in a rotation. */\nconst HOURS_ANGLE = 30;\n\n/** Angle between two consecutive minutes: 360/60, means a full rotation / number of minutes in one hour. */\nconst MINUTES_ANGLE = 6;\n\n/** Angle between two consecutive seconds for SBB clock custom behavior. */\nconst SBB_SECONDS_ANGLE = 360 / 58.5;\n\n/** Number of seconds in a minute. */\nconst SECONDS_IN_A_MINUTE = 60;\n\n/** Number of seconds in an hour. */\nconst SECONDS_IN_AN_HOUR = 3600;\n\nconst ADD_EVENT_LISTENER_OPTIONS: AddEventListenerOptions = {\n  once: true,\n  passive: true,\n};\n\n/**\n * It displays an analog clock with the classic SBB face.\n */\n@customElement('sbb-clock')\nexport class SbbClockElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n\n  /**\n   * Define a specific time which the clock should show statically.\n   * @param value HH:MM:ss\n   */\n  @property() public now: SbbTime | null = null;\n\n  /** Reference to the hour hand. */\n  private _clockHandHours!: HTMLElement;\n\n  /** Reference to the minute hand. */\n  private _clockHandMinutes!: HTMLElement;\n\n  /** Reference to the second hand. */\n  private _clockHandSeconds!: HTMLElement;\n\n  /** Hours value for the current date. */\n  private _hours!: number;\n\n  /** Minutes value for the current date. */\n  private _minutes!: number;\n\n  /** Seconds value for the current date. */\n  private _seconds!: number;\n\n  /** Callback function for hours hand. */\n  private _moveHoursHandFn = (): void => this._moveHoursHand();\n\n  /** Callback function for minutes hand. */\n  private _moveMinutesHandFn = (): void => this._moveMinutesHand();\n\n  /** Move the minutes hand every minute. */\n  private _handMovement?: ReturnType<typeof setInterval>;\n\n  protected override async willUpdate(changedProperties: PropertyValues<this>): Promise<void> {\n    super.willUpdate(changedProperties);\n\n    if (!isServer && changedProperties.has('now')) {\n      await this._startOrConfigureClock();\n    }\n  }\n\n  protected override async firstUpdated(changedProperties: PropertyValues<this>): Promise<void> {\n    super.firstUpdated(changedProperties);\n\n    if (!isServer) {\n      document.addEventListener('visibilitychange', this._handlePageVisibilityChange, false);\n      await this._startOrConfigureClock();\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._removeEventListeners();\n  }\n\n  private _handlePageVisibilityChange = async (): Promise<void> => {\n    if (document.visibilityState === 'hidden') {\n      await this._stopClock();\n    } else if (!this.now) {\n      await this._startClock();\n    }\n  };\n\n  private async _startOrConfigureClock(): Promise<void> {\n    if (this.now) {\n      await this._stopClock();\n      this._resetSecondsHandAnimation();\n      this._setHandsStartingPosition();\n    } else {\n      await this._startClock();\n    }\n  }\n\n  /** Starts the clock by defining the hands starting position then starting the animations. */\n  private async _startClock(): Promise<void> {\n    this._clockHandHours?.addEventListener(\n      'animationend',\n      this._moveHoursHandFn,\n      ADD_EVENT_LISTENER_OPTIONS,\n    );\n    this._clockHandSeconds?.addEventListener(\n      'animationend',\n      this._moveMinutesHandFn,\n      ADD_EVENT_LISTENER_OPTIONS,\n    );\n\n    await new Promise(() =>\n      setTimeout(() => {\n        this._setHandsStartingPosition();\n\n        this.style?.setProperty('--sbb-clock-animation-play-state', 'running');\n      }, INITIAL_TIMEOUT_DURATION),\n    );\n  }\n\n  /** Stops the clock by removing all the animations. */\n  private async _stopClock(): Promise<void> {\n    clearInterval(this._handMovement);\n\n    this._removeSecondsAnimationStyles();\n    this._removeHoursAnimationStyles();\n\n    this._clockHandHours?.removeEventListener('animationend', this._moveHoursHandFn);\n    this._clockHandSeconds?.removeEventListener('animationend', this._moveMinutesHandFn);\n\n    this._clockHandMinutes?.classList.add('sbb-clock__hand-minutes--no-transition');\n\n    this.style?.setProperty('--sbb-clock-animation-play-state', 'paused');\n  }\n\n  /** Set the starting position for the three hands on the clock face. */\n  private _setHandsStartingPosition(): void {\n    this._assignCurrentTime();\n    const remainingSeconds = TOTAL_SECONDS_ON_CLOCK_FACE - this._seconds;\n    const remainingMinutes = TOTAL_MINUTES_ON_CLOCK_FACE - this._minutes;\n    const remainingHours = TOTAL_HOURS_ON_CLOCK_FACE - this._hours;\n\n    let hoursAnimationDuration = 0;\n    let hasRemainingMinutesOrSeconds = 0;\n\n    if (remainingSeconds > 0) {\n      hoursAnimationDuration += remainingSeconds;\n      hasRemainingMinutesOrSeconds = 1;\n    }\n\n    if (remainingMinutes > 0) {\n      hoursAnimationDuration +=\n        (remainingMinutes - hasRemainingMinutesOrSeconds) * SECONDS_IN_A_MINUTE;\n      hasRemainingMinutesOrSeconds = 1;\n    }\n\n    if (remainingHours > 0) {\n      hoursAnimationDuration +=\n        (remainingHours - hasRemainingMinutesOrSeconds) * SECONDS_IN_AN_HOUR;\n    }\n\n    this.style?.setProperty(\n      '--sbb-clock-hours-animation-start-angle',\n      `${Math.ceil(this._hours * HOURS_ANGLE + this._minutes / 2)}deg`,\n    );\n    this.style?.setProperty('--sbb-clock-hours-animation-duration', `${hoursAnimationDuration}s`);\n    this.style?.setProperty(\n      '--sbb-clock-seconds-animation-start-angle',\n      `${Math.ceil(this._seconds * SBB_SECONDS_ANGLE)}deg`,\n    );\n    this.style?.setProperty('--sbb-clock-seconds-animation-duration', `${remainingSeconds}s`);\n\n    this._setMinutesHand();\n\n    this._clockHandSeconds?.classList.add('sbb-clock__hand-seconds--initial-minute');\n    this._clockHandHours?.classList.add('sbb-clock__hand-hours--initial-hour');\n\n    this.toggleAttribute('data-initialized', true);\n  }\n\n  /** Given the current date, calculates the hh/mm/ss values and the hh/mm/ss left to the next midnight. */\n  private _assignCurrentTime(): void {\n    const date = this.now ? null : new Date();\n    const [hours, minutes, seconds] = date\n      ? [date.getHours(), date.getMinutes(), date.getSeconds()]\n      : this.now!.split(':').map((p) => +p);\n\n    this._hours = hours % 12;\n    this._minutes = minutes;\n    this._seconds = seconds;\n  }\n\n  /** Set the starting position for the minutes hand. */\n  private _setMinutesHand(): void {\n    this._clockHandMinutes?.style.setProperty(\n      'transform',\n      `rotateZ(${Math.ceil(this._minutes * MINUTES_ANGLE)}deg)`,\n    );\n  }\n\n  /** Move the hours hand to the next value. */\n  private _moveHoursHand(): void {\n    this._removeHoursAnimationStyles();\n\n    let hoursAngle = Math.ceil(this._hours * HOURS_ANGLE + this._minutes / 2);\n\n    if (hoursAngle >= FULL_ANGLE) {\n      hoursAngle -= FULL_ANGLE;\n    }\n\n    this._clockHandHours?.style.setProperty('transform', `rotateZ(${hoursAngle}deg)`);\n  }\n\n  /** Move the minutes hand to the next value. */\n  private _moveMinutesHand(): void {\n    this._clockHandSeconds?.removeEventListener('animationend', this._moveMinutesHandFn);\n\n    this._removeSecondsAnimationStyles();\n\n    this._addMinutesAndSetHands();\n\n    this._handMovement = setInterval(\n      () => this._addMinutesAndSetHands(),\n      TOTAL_SECONDS_ON_CLOCK_FACE * 1000,\n    );\n  }\n\n  private _addMinutesAndSetHands(): void {\n    this._minutes++;\n    this._setMinutesHand();\n  }\n\n  /**\n   * Removing animation by overriding with empty string,\n   * then triggering a reflow and re add original animation by removing override.\n   * @private\n   */\n  private _resetSecondsHandAnimation(): void {\n    if (!this._clockHandSeconds) {\n      return;\n    }\n    this._clockHandSeconds.style.animation = '';\n    // Hack to trigger reflow\n    this._clockHandSeconds.offsetHeight;\n    this._clockHandSeconds.style.removeProperty('animation');\n  }\n\n  private _removeEventListeners(): void {\n    document?.removeEventListener('visibilitychange', this._handlePageVisibilityChange);\n    this._clockHandHours?.removeEventListener('animationend', this._moveHoursHandFn);\n    this._clockHandSeconds?.removeEventListener('animationend', this._moveMinutesHandFn);\n    clearInterval(this._handMovement);\n  }\n\n  private _removeHoursAnimationStyles(): void {\n    this._clockHandHours?.classList.remove('sbb-clock__hand-hours--initial-hour');\n    this.style.removeProperty('--sbb-clock-hours-animation-start-angle');\n    this.style.removeProperty('--sbb-clock-hours-animation-duration');\n  }\n\n  private _removeSecondsAnimationStyles(): void {\n    this._clockHandSeconds?.classList.remove('sbb-clock__hand-seconds--initial-minute');\n    this._clockHandMinutes?.classList.remove('sbb-clock__hand-minutes--no-transition');\n    this.style.removeProperty('--sbb-clock-seconds-animation-start-angle');\n    this.style.removeProperty('--sbb-clock-seconds-animation-duration');\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-clock\">\n        <span class=\"sbb-clock__face\" .innerHTML=${clockFaceSVG}></span>\n        <span\n          class=\"sbb-clock__hand-hours\"\n          .innerHTML=${clockHandleHoursSVG}\n          ${ref((e?: Element): void => {\n            this._clockHandHours = e as HTMLSpanElement;\n          })}\n        ></span>\n        <span\n          class=\"sbb-clock__hand-minutes sbb-clock__hand-minutes--no-transition\"\n          .innerHTML=${clockHandleMinutesSVG}\n          ${ref((el?: Element): void => {\n            this._clockHandMinutes = el as HTMLSpanElement;\n          })}\n        ></span>\n        <span\n          class=\"sbb-clock__hand-seconds\"\n          .innerHTML=${clockHandleSecondsSVG}\n          ${ref((el?: Element): void => {\n            this._clockHandSeconds = el as HTMLSpanElement;\n          })}\n        ></span>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-clock': SbbClockElement;\n  }\n}\n"],"names":["_a"],"mappings":"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"}
|
|
387
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"clock.js","sources":["../../../src/elements/clock/assets/sbb_clock_face.svg?raw","../../../src/elements/clock/assets/sbb_clock_hours.svg?raw","../../../src/elements/clock/assets/sbb_clock_minutes.svg?raw","../../../src/elements/clock/assets/sbb_clock_seconds.svg?raw","../../../src/elements/clock/clock.ts"],"sourcesContent":["export default \"<svg focusable=\\\"false\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" viewBox=\\\"0 0 105 105\\\"><g class=\\\"face\\\"><circle fill=\\\"#FFF\\\" cx=\\\"52.5\\\" cy=\\\"52.5\\\" r=\\\"52.5\\\"/><path d=\\\"M50.75 4h3.5v12h-3.5zM50.75 89h3.5v12h-3.5zM75.233 9.623l3.03 1.75-6 10.392-3.03-1.75zM32.734 83.233l3.03 1.75-6 10.392-3.03-1.75zM93.628 26.732l1.75 3.031-10.392 6-1.75-3.03zM20.017 69.234l1.75 3.031-10.392 6-1.75-3.03zM101 50.75v3.5H89v-3.5zM16 50.75v3.5H4v-3.5zM95.379 75.232l-1.75 3.031-10.392-6 1.75-3.03zM21.766 32.734l-1.75 3.031-10.392-6 1.75-3.03zM78.267 93.63l-3.03 1.75-6-10.393 3.03-1.75zM35.766 20.015l-3.03 1.75-6-10.392 3.03-1.75z\\\"/><g><path d=\\\"M56.873 4.19l1.392.147-.366 3.48-1.392-.145zM47.101 97.177l1.393.146-.366 3.481-1.392-.146zM61.896 4.914l1.37.29-.728 3.424-1.37-.29zM42.458 96.366l1.37.29-.728 3.424-1.37-.291zM66.825 6.157l1.332.432-1.082 3.33-1.331-.434zM37.931 95.085l1.332.432-1.082 3.33-1.331-.433zM71.584 7.906l1.28.569-1.424 3.197-1.28-.57zM33.56 93.32l1.278.569-1.423 3.197-1.28-.57zM80.44 12.852l1.133.823-2.058 2.831-1.132-.823zM25.481 88.494l1.133.822-2.057 2.832-1.133-.823zM84.43 15.986l1.04.937-2.342 2.6-1.04-.936zM21.87 85.469l1.04.936-2.341 2.601-1.04-.937zM88.072 19.522l.937 1.04-2.6 2.343-.937-1.04zM18.593 82.088l.937 1.04-2.601 2.342-.937-1.04zM91.328 23.425l.823 1.133-2.832 2.057-.823-1.132zM15.684 78.385l.823 1.132-2.832 2.058-.822-1.133zM96.52 32.128l.57 1.279-3.198 1.423-.57-1.278zM11.109 70.161l.569 1.279-3.197 1.423-.57-1.279zM98.407 36.85l.433 1.332-3.33 1.081-.432-1.331zM9.483 65.74l.432 1.33-3.329 1.082-.432-1.331zM99.795 41.726l.291 1.37-3.423.727-.29-1.37zM8.34 61.17l.292 1.37-3.424.728-.29-1.37zM100.66 46.73l.146 1.393-3.48.366-.147-1.392zM7.674 56.506l.146 1.392-3.48.366-.147-1.392zM100.811 56.873l-.146 1.392-3.48-.365.145-1.393zM7.821 47.101l-.146 1.392-3.48-.365.145-1.393zM100.09 61.895l-.291 1.369-3.424-.728.291-1.369zM8.631 42.46l-.291 1.37-3.423-.728.29-1.37zM98.84 66.827l-.432 1.331-3.329-1.081.433-1.332zM9.918 37.93l-.433 1.331-3.329-1.082.433-1.331zM97.098 71.585l-.569 1.28-3.197-1.424.57-1.28zM11.677 33.558l-.57 1.28-3.197-1.424.57-1.279zM92.149 80.439l-.823 1.133-2.832-2.058.823-1.132zM16.506 25.482l-.823 1.133-2.831-2.057.823-1.133zM89.017 84.431l-.937 1.04-2.6-2.341.936-1.04zM19.528 21.869l-.936 1.04-2.601-2.342.936-1.04zM85.48 88.076l-1.041.936-2.342-2.6 1.04-.937zM22.91 18.59l-1.04.937-2.341-2.601 1.04-.937zM81.574 91.328l-1.133.823-2.057-2.831 1.132-.823zM26.617 15.684l-1.133.823-2.057-2.832 1.132-.823zM72.873 96.524l-1.279.57-1.423-3.198 1.278-.57zM34.838 11.105l-1.279.57-1.423-3.198 1.279-.57zM68.151 98.405l-1.331.432-1.082-3.329 1.332-.432zM39.259 9.485l-1.332.433-1.081-3.33 1.331-.432zM63.272 99.799l-1.369.29-.728-3.422 1.37-.291zM43.83 8.337l-1.369.291-.727-3.423 1.37-.291zM58.27 100.662l-1.393.146-.366-3.48 1.393-.147zM48.494 7.672l-1.392.147-.366-3.481 1.392-.147z\\\"/></g></g></svg>\\n\"","export default \"<svg focusable=\\\"false\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" viewBox=\\\"0 0 105 105\\\"><path id=\\\"mod_clock_svg_hours\\\" d=\\\"M55.7 64.5h-6.4l.6-44h5.2z\\\"/></svg>\\n\"","export default \"<svg focusable=\\\"false\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" viewBox=\\\"0 0 105 105\\\"><path d=\\\"M55.1,64.5h-5.2l0.8-58h3.6L55.1,64.5z\\\"/></svg>\\n\"","export default \"<svg focusable=\\\"false\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" viewBox=\\\"0 0 105 105\\\"><path d=\\\"M57.8,21.3c0-2.9-2.4-5.2-5.2-5.2s-5.3,2.3-5.3,5.2c0,2.7,2,4.8,4.5,5.2V69h1.5V26.5C55.8,26.2,57.8,24,57.8,21.3z\\\"/></svg>\\n\"","import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, isServer, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport type { SbbTime } from '../core/interfaces.js';\n\nimport clockFaceSVG from './assets/sbb_clock_face.svg?raw';\nimport clockHandleHoursSVG from './assets/sbb_clock_hours.svg?raw';\nimport clockHandleMinutesSVG from './assets/sbb_clock_minutes.svg?raw';\nimport clockHandleSecondsSVG from './assets/sbb_clock_seconds.svg?raw';\nimport style from './clock.scss?lit&inline';\n\n/** Number of hours on the clock face. */\nconst TOTAL_HOURS_ON_CLOCK_FACE = 12;\n\n/** Number of minutes on the clock face. */\nconst TOTAL_MINUTES_ON_CLOCK_FACE = 60;\n\n/** Number of seconds on the clock face. */\nconst TOTAL_SECONDS_ON_CLOCK_FACE = 60;\n\n/** Timeout for the clock start. */\nconst INITIAL_TIMEOUT_DURATION = 50;\n\n/** Angle in a single rotation. */\nconst FULL_ANGLE = 360;\n\n/** Angle between two consecutive hours: 360/12, means a full rotation / number of hours in a rotation. */\nconst HOURS_ANGLE = 30;\n\n/** Angle between two consecutive minutes: 360/60, means a full rotation / number of minutes in one hour. */\nconst MINUTES_ANGLE = 6;\n\n/** Angle between two consecutive seconds for SBB clock custom behavior. */\nconst SBB_SECONDS_ANGLE = 360 / 58.5;\n\n/** Number of seconds in a minute. */\nconst SECONDS_IN_A_MINUTE = 60;\n\n/** Number of seconds in an hour. */\nconst SECONDS_IN_AN_HOUR = 3600;\n\nconst ADD_EVENT_LISTENER_OPTIONS: AddEventListenerOptions = {\n  once: true,\n  passive: true,\n};\n\n/**\n * It displays an analog clock with the classic SBB face.\n */\n@customElement('sbb-clock')\nexport class SbbClockElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n\n  /**\n   * Define a specific time which the clock should show statically.\n   * @param value HH:MM:ss\n   */\n  @property() public now: SbbTime | null = null;\n\n  /** Reference to the hour hand. */\n  private _clockHandHours!: HTMLElement;\n\n  /** Reference to the minute hand. */\n  private _clockHandMinutes!: HTMLElement;\n\n  /** Reference to the second hand. */\n  private _clockHandSeconds!: HTMLElement;\n\n  /** Hours value for the current date. */\n  private _hours!: number;\n\n  /** Minutes value for the current date. */\n  private _minutes!: number;\n\n  /** Seconds value for the current date. */\n  private _seconds!: number;\n\n  /** Callback function for hours hand. */\n  private _moveHoursHandFn = (): void => this._moveHoursHand();\n\n  /** Callback function for minutes hand. */\n  private _moveMinutesHandFn = (): void => this._moveMinutesHand();\n\n  /** Move the minutes hand every minute. */\n  private _handMovement?: ReturnType<typeof setInterval>;\n\n  protected override async willUpdate(changedProperties: PropertyValues<this>): Promise<void> {\n    super.willUpdate(changedProperties);\n\n    if (!isServer && changedProperties.has('now')) {\n      await this._startOrConfigureClock();\n    }\n  }\n\n  protected override async firstUpdated(changedProperties: PropertyValues<this>): Promise<void> {\n    super.firstUpdated(changedProperties);\n\n    if (!isServer) {\n      document.addEventListener('visibilitychange', this._handlePageVisibilityChange, false);\n      await this._startOrConfigureClock();\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._removeEventListeners();\n  }\n\n  private _handlePageVisibilityChange = async (): Promise<void> => {\n    if (document.visibilityState === 'hidden') {\n      await this._stopClock();\n    } else if (!this.now) {\n      await this._startClock();\n    }\n  };\n\n  private async _startOrConfigureClock(): Promise<void> {\n    if (this.now) {\n      await this._stopClock();\n      this._resetSecondsHandAnimation();\n      this._setHandsStartingPosition();\n    } else {\n      await this._startClock();\n    }\n  }\n\n  /** Starts the clock by defining the hands starting position then starting the animations. */\n  private async _startClock(): Promise<void> {\n    this._clockHandHours?.addEventListener(\n      'animationend',\n      this._moveHoursHandFn,\n      ADD_EVENT_LISTENER_OPTIONS,\n    );\n    this._clockHandSeconds?.addEventListener(\n      'animationend',\n      this._moveMinutesHandFn,\n      ADD_EVENT_LISTENER_OPTIONS,\n    );\n\n    await new Promise<void>((resolve) =>\n      setTimeout(() => {\n        this._setHandsStartingPosition();\n\n        this.style?.setProperty('--sbb-clock-animation-play-state', 'running');\n        resolve();\n      }, INITIAL_TIMEOUT_DURATION),\n    );\n  }\n\n  /** Stops the clock by removing all the animations. */\n  private async _stopClock(): Promise<void> {\n    clearInterval(this._handMovement);\n\n    this._removeSecondsAnimationStyles();\n    this._removeHoursAnimationStyles();\n\n    this._clockHandHours?.removeEventListener('animationend', this._moveHoursHandFn);\n    this._clockHandSeconds?.removeEventListener('animationend', this._moveMinutesHandFn);\n\n    this._clockHandMinutes?.classList.add('sbb-clock__hand-minutes--no-transition');\n\n    this.style?.setProperty('--sbb-clock-animation-play-state', 'paused');\n  }\n\n  /** Set the starting position for the three hands on the clock face. */\n  private _setHandsStartingPosition(): void {\n    this._assignCurrentTime();\n    const remainingSeconds = TOTAL_SECONDS_ON_CLOCK_FACE - this._seconds;\n    const remainingMinutes = TOTAL_MINUTES_ON_CLOCK_FACE - this._minutes;\n    const remainingHours = TOTAL_HOURS_ON_CLOCK_FACE - this._hours;\n\n    let hoursAnimationDuration = 0;\n    let hasRemainingMinutesOrSeconds = 0;\n\n    if (remainingSeconds > 0) {\n      hoursAnimationDuration += remainingSeconds;\n      hasRemainingMinutesOrSeconds = 1;\n    }\n\n    if (remainingMinutes > 0) {\n      hoursAnimationDuration +=\n        (remainingMinutes - hasRemainingMinutesOrSeconds) * SECONDS_IN_A_MINUTE;\n      hasRemainingMinutesOrSeconds = 1;\n    }\n\n    if (remainingHours > 0) {\n      hoursAnimationDuration +=\n        (remainingHours - hasRemainingMinutesOrSeconds) * SECONDS_IN_AN_HOUR;\n    }\n\n    this.style?.setProperty(\n      '--sbb-clock-hours-animation-start-angle',\n      `${Math.ceil(this._hours * HOURS_ANGLE + this._minutes / 2)}deg`,\n    );\n    this.style?.setProperty('--sbb-clock-hours-animation-duration', `${hoursAnimationDuration}s`);\n    this.style?.setProperty(\n      '--sbb-clock-seconds-animation-start-angle',\n      `${Math.ceil(this._seconds * SBB_SECONDS_ANGLE)}deg`,\n    );\n    this.style?.setProperty('--sbb-clock-seconds-animation-duration', `${remainingSeconds}s`);\n\n    this._setMinutesHand();\n\n    this._clockHandSeconds?.classList.add('sbb-clock__hand-seconds--initial-minute');\n    this._clockHandHours?.classList.add('sbb-clock__hand-hours--initial-hour');\n\n    this.toggleAttribute('data-initialized', true);\n  }\n\n  /** Given the current date, calculates the hh/mm/ss values and the hh/mm/ss left to the next midnight. */\n  private _assignCurrentTime(): void {\n    const date = this.now ? null : new Date();\n    const [hours, minutes, seconds] = date\n      ? [date.getHours(), date.getMinutes(), date.getSeconds()]\n      : this.now!.split(':').map((p) => +p);\n\n    this._hours = hours % 12;\n    this._minutes = minutes;\n    this._seconds = seconds;\n  }\n\n  /** Set the starting position for the minutes hand. */\n  private _setMinutesHand(): void {\n    this._clockHandMinutes?.style.setProperty(\n      'transform',\n      `rotateZ(${Math.ceil(this._minutes * MINUTES_ANGLE)}deg)`,\n    );\n  }\n\n  /** Move the hours hand to the next value. */\n  private _moveHoursHand(): void {\n    this._removeHoursAnimationStyles();\n\n    let hoursAngle = Math.ceil(this._hours * HOURS_ANGLE + this._minutes / 2);\n\n    if (hoursAngle >= FULL_ANGLE) {\n      hoursAngle -= FULL_ANGLE;\n    }\n\n    this._clockHandHours?.style.setProperty('transform', `rotateZ(${hoursAngle}deg)`);\n  }\n\n  /** Move the minutes hand to the next value. */\n  private _moveMinutesHand(): void {\n    this._clockHandSeconds?.removeEventListener('animationend', this._moveMinutesHandFn);\n\n    this._removeSecondsAnimationStyles();\n\n    this._addMinutesAndSetHands();\n\n    this._handMovement = setInterval(\n      () => this._addMinutesAndSetHands(),\n      TOTAL_SECONDS_ON_CLOCK_FACE * 1000,\n    );\n  }\n\n  private _addMinutesAndSetHands(): void {\n    this._minutes++;\n    this._setMinutesHand();\n  }\n\n  /**\n   * Removing animation by overriding with empty string,\n   * then triggering a reflow and re add original animation by removing override.\n   * @private\n   */\n  private _resetSecondsHandAnimation(): void {\n    if (!this._clockHandSeconds) {\n      return;\n    }\n    this._clockHandSeconds.style.animation = '';\n    // Hack to trigger reflow\n    this._clockHandSeconds.offsetHeight;\n    this._clockHandSeconds.style.removeProperty('animation');\n  }\n\n  private _removeEventListeners(): void {\n    document?.removeEventListener('visibilitychange', this._handlePageVisibilityChange);\n    this._clockHandHours?.removeEventListener('animationend', this._moveHoursHandFn);\n    this._clockHandSeconds?.removeEventListener('animationend', this._moveMinutesHandFn);\n    clearInterval(this._handMovement);\n  }\n\n  private _removeHoursAnimationStyles(): void {\n    this._clockHandHours?.classList.remove('sbb-clock__hand-hours--initial-hour');\n    this.style.removeProperty('--sbb-clock-hours-animation-start-angle');\n    this.style.removeProperty('--sbb-clock-hours-animation-duration');\n  }\n\n  private _removeSecondsAnimationStyles(): void {\n    this._clockHandSeconds?.classList.remove('sbb-clock__hand-seconds--initial-minute');\n    this._clockHandMinutes?.classList.remove('sbb-clock__hand-minutes--no-transition');\n    this.style.removeProperty('--sbb-clock-seconds-animation-start-angle');\n    this.style.removeProperty('--sbb-clock-seconds-animation-duration');\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-clock\">\n        <span class=\"sbb-clock__face\" .innerHTML=${clockFaceSVG}></span>\n        <span\n          class=\"sbb-clock__hand-hours\"\n          .innerHTML=${clockHandleHoursSVG}\n          ${ref((e?: Element): void => {\n            this._clockHandHours = e as HTMLSpanElement;\n          })}\n        ></span>\n        <span\n          class=\"sbb-clock__hand-minutes sbb-clock__hand-minutes--no-transition\"\n          .innerHTML=${clockHandleMinutesSVG}\n          ${ref((el?: Element): void => {\n            this._clockHandMinutes = el as HTMLSpanElement;\n          })}\n        ></span>\n        <span\n          class=\"sbb-clock__hand-seconds\"\n          .innerHTML=${clockHandleSecondsSVG}\n          ${ref((el?: Element): void => {\n            this._clockHandSeconds = el as HTMLSpanElement;\n          })}\n        ></span>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-clock': SbbClockElement;\n  }\n}\n"],"names":["_a"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"wait-for-event.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/testing/wait-for-event.ts"],"names":[],"mappings":"AAAA,wBAAgB,YAAY,CAC1B,OAAO,EAAE,WAAW,EACpB,SAAS,EAAE,MAAM,EACjB,OAAO,SAAO,GACb,OAAO,CAAC,IAAI,CAAC,CAcf"}
|
|
@@ -2,6 +2,7 @@ export * from './testing/event-spy.js';
|
|
|
2
2
|
export * from './testing/mocha-extensions.js';
|
|
3
3
|
export * from './testing/scroll.js';
|
|
4
4
|
export * from './testing/wait-for-condition.js';
|
|
5
|
+
export * from './testing/wait-for-event.js';
|
|
5
6
|
export * from './testing/wait-for-image-ready.js';
|
|
6
7
|
export * from './testing/wait-for-render.js';
|
|
7
8
|
//# sourceMappingURL=testing.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"testing.d.ts","sourceRoot":"","sources":["../../../../src/elements/core/testing.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAC;AACvC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,qBAAqB,CAAC;AACpC,cAAc,iCAAiC,CAAC;AAChD,cAAc,mCAAmC,CAAC;AAClD,cAAc,8BAA8B,CAAC"}
|
|
1
|
+
{"version":3,"file":"testing.d.ts","sourceRoot":"","sources":["../../../../src/elements/core/testing.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAC;AACvC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,qBAAqB,CAAC;AACpC,cAAc,iCAAiC,CAAC;AAChD,cAAc,6BAA6B,CAAC;AAC5C,cAAc,mCAAmC,CAAC;AAClD,cAAc,8BAA8B,CAAC"}
|
|
@@ -60,6 +60,21 @@ async function waitForCondition(condition, interval = 30, timeoutInMilliseconds
|
|
|
60
60
|
}
|
|
61
61
|
return Promise.resolve(true);
|
|
62
62
|
}
|
|
63
|
+
function waitForEvent(element, eventName, timeout = 1e3) {
|
|
64
|
+
return new Promise((resolve, reject) => {
|
|
65
|
+
const signal = AbortSignal.timeout(timeout);
|
|
66
|
+
const timeoutReached = () => reject(`Timeout of ${timeout} reached`);
|
|
67
|
+
signal.addEventListener("abort", timeoutReached);
|
|
68
|
+
element.addEventListener(
|
|
69
|
+
eventName,
|
|
70
|
+
() => {
|
|
71
|
+
signal.removeEventListener("abort", timeoutReached);
|
|
72
|
+
resolve();
|
|
73
|
+
},
|
|
74
|
+
{ passive: true, signal }
|
|
75
|
+
);
|
|
76
|
+
});
|
|
77
|
+
}
|
|
63
78
|
async function waitForImageReady(element, timeoutInMilliseconds = 2 * 1e3) {
|
|
64
79
|
if (!element.complete) {
|
|
65
80
|
await new Promise((resolve, reject) => {
|
|
@@ -98,7 +113,8 @@ export {
|
|
|
98
113
|
mockScrollTo,
|
|
99
114
|
testIf,
|
|
100
115
|
waitForCondition,
|
|
116
|
+
waitForEvent,
|
|
101
117
|
waitForImageReady,
|
|
102
118
|
waitForLitRender
|
|
103
119
|
};
|
|
104
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"testing.js","sources":["../../../../src/elements/core/testing/event-spy.ts","../../../../src/elements/core/testing/mocha-extensions.ts","../../../../src/elements/core/testing/scroll.ts","../../../../src/elements/core/testing/wait-for-condition.ts","../../../../src/elements/core/testing/wait-for-image-ready.ts","../../../../src/elements/core/testing/wait-for-render.ts"],"sourcesContent":["/**\n * This class exists to facilitate the test migration from stencil to lit.\n * It mimics the API that stencil provided to test events.\n *\n * TODO: Document me\n */\nexport class EventSpy<T extends Event> {\n  private _count: number = 0;\n  public get count(): number {\n    return this._count;\n  }\n\n  private _events: T[] = [];\n  public get events(): T[] {\n    return this._events;\n  }\n\n  public get firstEvent(): T | null {\n    return this.events.length ? this.events[0] : null;\n  }\n\n  public get lastEvent(): T | null {\n    return this.events.length ? this.events[this.events.length - 1] : null;\n  }\n\n  public constructor(\n    private _event: string,\n    private readonly _target: Node | null = null,\n  ) {\n    if (!this._target) {\n      this._target = document;\n    }\n    this._listenForEvent();\n  }\n\n  private _listenForEvent(): void {\n    this._target?.addEventListener(this._event, (ev) => {\n      this._events.push(ev as T);\n      this._count++;\n    });\n  }\n}\n","import type { Func, Suite, Test } from 'mocha';\n\n/**\n * Skip the `describe` if the condition is not met\n */\nexport const describeIf = (\n  condition: boolean,\n  title: string,\n  fn: (this: Suite) => void,\n): Suite | void => {\n  if (condition) {\n    return Mocha.describe(title, fn);\n  }\n};\n\n/**\n * Skip the `test` if the condition is not met\n */\nexport const testIf = (condition: boolean, title: string, fn?: Func): Test | void => {\n  if (condition) {\n    return Mocha.test(title, fn);\n  }\n};\n","/**\n * Can be used in tests where scroll events are not triggered by default.\n * @param options ScrollToOptions\n */\nexport function mockScrollTo(options: ScrollToOptions): void {\n  window.scrollTo(options);\n\n  // We need to manually dispatching the scroll as the scrollTo\n  // does not fire a scroll event in test env.\n  document.dispatchEvent(new Event('scroll'));\n}\n","export async function waitForCondition(\n  condition: () => boolean | Promise<boolean>,\n  interval = 30,\n  timeoutInMilliseconds = 2 * 1000,\n): Promise<boolean> {\n  const start = new Date();\n  let counter = 0;\n  function checkCondition(): boolean | Promise<boolean> {\n    counter++;\n    return condition();\n  }\n  while (\n    !(await checkCondition()) &&\n    start.getTime() + timeoutInMilliseconds >= new Date().getTime()\n  ) {\n    await new Promise((resolve) => setTimeout(resolve, interval));\n  }\n  if (start.getTime() + timeoutInMilliseconds < new Date().getTime()) {\n    return Promise.reject(\n      `waitForCondition timeout: ${condition.toString()}, attempts: ${counter}, start: ${start.getTime()}, end: ${new Date().getTime()}`,\n    );\n  }\n  return Promise.resolve(true);\n}\n","import type { SbbImageElement } from '../../image.js';\n\nexport async function waitForImageReady(\n  element: HTMLImageElement | SbbImageElement,\n  timeoutInMilliseconds = 2 * 1000,\n): Promise<void> {\n  if (!element.complete) {\n    await new Promise<void>((resolve, reject) => {\n      const timeout = setTimeout(() => reject('image loading timeout'), timeoutInMilliseconds);\n      element.addEventListener('load', () => {\n        clearTimeout(timeout);\n        resolve();\n      });\n      element.addEventListener('error', () => {\n        clearTimeout(timeout);\n        reject('image error');\n      });\n    });\n  }\n}\n","import type { ReactiveElement } from 'lit';\n\nimport type { SbbHydrationMixinType } from '../mixins.js';\n\n/**\n * Tests if an element is a Lit `ReactiveElement`.\n *\n * @param element the element to test.\n * @return true if the element is a `ReactiveElement`.\n */\nexport const isReactiveElement = (\n  element: Element,\n): element is ReactiveElement & Partial<SbbHydrationMixinType> => {\n  return Boolean((element as ReactiveElement).updateComplete);\n};\n\nconst promiseComplete = Promise.resolve();\n\n/**\n * Waits for all Lit `ReactiveElement` children of the given parent node to\n * finish rendering.\n *\n * @param root a parent node to wait for rendering on.\n */\nexport const waitForLitRender = async <\n  T extends HTMLElement | DocumentFragment = HTMLElement | DocumentFragment,\n>(\n  node: T | Promise<T>,\n): Promise<T> => {\n  const root = await node;\n  (root.parentElement ?? root)\n    .querySelectorAll?.('[defer-hydration]')\n    .forEach((e) => e.removeAttribute('defer-hydration'));\n  const completables = [root as Element, ...root.querySelectorAll('*')]\n    .filter(isReactiveElement)\n    .map((e) => [\n      e.updateComplete,\n      e.hydrationComplete ?? promiseComplete,\n      waitForLitRender(e.renderRoot),\n    ])\n    .flat(Infinity);\n  await Promise.all(completables);\n  return root;\n};\n"],"names":[],"mappings":"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"}
|
|
120
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"testing.js","sources":["../../../../src/elements/core/testing/event-spy.ts","../../../../src/elements/core/testing/mocha-extensions.ts","../../../../src/elements/core/testing/scroll.ts","../../../../src/elements/core/testing/wait-for-condition.ts","../../../../src/elements/core/testing/wait-for-event.ts","../../../../src/elements/core/testing/wait-for-image-ready.ts","../../../../src/elements/core/testing/wait-for-render.ts"],"sourcesContent":["/**\n * This class exists to facilitate the test migration from stencil to lit.\n * It mimics the API that stencil provided to test events.\n *\n * TODO: Document me\n */\nexport class EventSpy<T extends Event> {\n  private _count: number = 0;\n  public get count(): number {\n    return this._count;\n  }\n\n  private _events: T[] = [];\n  public get events(): T[] {\n    return this._events;\n  }\n\n  public get firstEvent(): T | null {\n    return this.events.length ? this.events[0] : null;\n  }\n\n  public get lastEvent(): T | null {\n    return this.events.length ? this.events[this.events.length - 1] : null;\n  }\n\n  public constructor(\n    private _event: string,\n    private readonly _target: Node | null = null,\n  ) {\n    if (!this._target) {\n      this._target = document;\n    }\n    this._listenForEvent();\n  }\n\n  private _listenForEvent(): void {\n    this._target?.addEventListener(this._event, (ev) => {\n      this._events.push(ev as T);\n      this._count++;\n    });\n  }\n}\n","import type { Func, Suite, Test } from 'mocha';\n\n/**\n * Skip the `describe` if the condition is not met\n */\nexport const describeIf = (\n  condition: boolean,\n  title: string,\n  fn: (this: Suite) => void,\n): Suite | void => {\n  if (condition) {\n    return Mocha.describe(title, fn);\n  }\n};\n\n/**\n * Skip the `test` if the condition is not met\n */\nexport const testIf = (condition: boolean, title: string, fn?: Func): Test | void => {\n  if (condition) {\n    return Mocha.test(title, fn);\n  }\n};\n","/**\n * Can be used in tests where scroll events are not triggered by default.\n * @param options ScrollToOptions\n */\nexport function mockScrollTo(options: ScrollToOptions): void {\n  window.scrollTo(options);\n\n  // We need to manually dispatching the scroll as the scrollTo\n  // does not fire a scroll event in test env.\n  document.dispatchEvent(new Event('scroll'));\n}\n","export async function waitForCondition(\n  condition: () => boolean | Promise<boolean>,\n  interval = 30,\n  timeoutInMilliseconds = 2 * 1000,\n): Promise<boolean> {\n  const start = new Date();\n  let counter = 0;\n  function checkCondition(): boolean | Promise<boolean> {\n    counter++;\n    return condition();\n  }\n  while (\n    !(await checkCondition()) &&\n    start.getTime() + timeoutInMilliseconds >= new Date().getTime()\n  ) {\n    await new Promise((resolve) => setTimeout(resolve, interval));\n  }\n  if (start.getTime() + timeoutInMilliseconds < new Date().getTime()) {\n    return Promise.reject(\n      `waitForCondition timeout: ${condition.toString()}, attempts: ${counter}, start: ${start.getTime()}, end: ${new Date().getTime()}`,\n    );\n  }\n  return Promise.resolve(true);\n}\n","export function waitForEvent(\n  element: HTMLElement,\n  eventName: string,\n  timeout = 1000,\n): Promise<void> {\n  return new Promise<void>((resolve, reject) => {\n    const signal = AbortSignal.timeout(timeout);\n    const timeoutReached = (): void => reject(`Timeout of ${timeout} reached`);\n    signal.addEventListener('abort', timeoutReached);\n    element.addEventListener(\n      eventName,\n      () => {\n        signal.removeEventListener('abort', timeoutReached);\n        resolve();\n      },\n      { passive: true, signal },\n    );\n  });\n}\n","import type { SbbImageElement } from '../../image.js';\n\nexport async function waitForImageReady(\n  element: HTMLImageElement | SbbImageElement,\n  timeoutInMilliseconds = 2 * 1000,\n): Promise<void> {\n  if (!element.complete) {\n    await new Promise<void>((resolve, reject) => {\n      const timeout = setTimeout(() => reject('image loading timeout'), timeoutInMilliseconds);\n      element.addEventListener('load', () => {\n        clearTimeout(timeout);\n        resolve();\n      });\n      element.addEventListener('error', () => {\n        clearTimeout(timeout);\n        reject('image error');\n      });\n    });\n  }\n}\n","import type { ReactiveElement } from 'lit';\n\nimport type { SbbHydrationMixinType } from '../mixins.js';\n\n/**\n * Tests if an element is a Lit `ReactiveElement`.\n *\n * @param element the element to test.\n * @return true if the element is a `ReactiveElement`.\n */\nexport const isReactiveElement = (\n  element: Element,\n): element is ReactiveElement & Partial<SbbHydrationMixinType> => {\n  return Boolean((element as ReactiveElement).updateComplete);\n};\n\nconst promiseComplete = Promise.resolve();\n\n/**\n * Waits for all Lit `ReactiveElement` children of the given parent node to\n * finish rendering.\n *\n * @param root a parent node to wait for rendering on.\n */\nexport const waitForLitRender = async <\n  T extends HTMLElement | DocumentFragment = HTMLElement | DocumentFragment,\n>(\n  node: T | Promise<T>,\n): Promise<T> => {\n  const root = await node;\n  (root.parentElement ?? root)\n    .querySelectorAll?.('[defer-hydration]')\n    .forEach((e) => e.removeAttribute('defer-hydration'));\n  const completables = [root as Element, ...root.querySelectorAll('*')]\n    .filter(isReactiveElement)\n    .map((e) => [\n      e.updateComplete,\n      e.hydrationComplete ?? promiseComplete,\n      waitForLitRender(e.renderRoot),\n    ])\n    .flat(Infinity);\n  await Promise.all(completables);\n  return root;\n};\n"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { PropertyValues } from 'lit';
|
|
1
|
+
import { PropertyValues, TemplateResult } from 'lit';
|
|
2
2
|
import { SbbIconBase } from './icon-base.js';
|
|
3
3
|
|
|
4
4
|
/**
|
|
@@ -12,9 +12,17 @@ export declare class SbbIconElement extends SbbIconBase {
|
|
|
12
12
|
*/
|
|
13
13
|
name: string;
|
|
14
14
|
private _defaultAriaLabel;
|
|
15
|
+
/**
|
|
16
|
+
* The sbb-angular library has a sbb-icon component as well. In order to provide
|
|
17
|
+
* compatibility with it (as some icons are used internally inside the other sbb-angular
|
|
18
|
+
* components) we need to check whether the attribute svgicon is used.
|
|
19
|
+
*/
|
|
20
|
+
private _sbbAngularCompatibility;
|
|
15
21
|
protected fetchSvgIcon(namespace: string, name: string): Promise<string>;
|
|
16
22
|
protected willUpdate(changedProperties: PropertyValues<this>): void;
|
|
23
|
+
attributeChangedCallback(name: string, _old: string | null, value: string | null): void;
|
|
17
24
|
protected firstUpdated(changedProperties: PropertyValues<this>): void;
|
|
25
|
+
protected render(): TemplateResult;
|
|
18
26
|
}
|
|
19
27
|
declare global {
|
|
20
28
|
interface HTMLElementTagNameMap {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"icon.d.ts","sourceRoot":"","sources":["../../../../src/elements/icon/icon.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;
|
|
1
|
+
{"version":3,"file":"icon.d.ts","sourceRoot":"","sources":["../../../../src/elements/icon/icon.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAGrE,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAE7C;;GAEG;AACH,qBACa,cAAe,SAAQ,WAAW;IAC7C;;;;OAIG;IACiC,IAAI,EAAG,MAAM,CAAC;IAElD,OAAO,CAAC,iBAAiB,CAAM;IAE/B;;;;OAIG;IACM,OAAO,CAAC,wBAAwB,CAAS;cAEzB,YAAY,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;cAiBpE,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAQ5D,wBAAwB,CACtC,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,MAAM,GAAG,IAAI,EACnB,KAAK,EAAE,MAAM,GAAG,IAAI,GACnB,IAAI;cAQY,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAQ3D,MAAM,IAAI,cAAc;CAG5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,UAAU,EAAE,cAAc,CAAC;KAC5B;CACF"}
|