@sbb-esta/lyne-elements 1.2.0 → 1.2.1
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/accordion/accordion.d.ts +1 -1
- package/accordion/accordion.d.ts.map +1 -1
- package/alert/alert/alert.d.ts +1 -1
- package/alert/alert/alert.d.ts.map +1 -1
- package/clock/clock.d.ts +19 -13
- package/clock/clock.d.ts.map +1 -1
- package/clock.js +86 -75
- package/core/mixins/hydration-mixin.d.ts.map +1 -1
- package/core/mixins.js +126 -132
- package/custom-elements.json +46 -238
- package/development/accordion/accordion.d.ts +1 -1
- package/development/accordion/accordion.d.ts.map +1 -1
- package/development/accordion.js +1 -1
- package/development/alert/alert/alert.d.ts +1 -1
- package/development/alert/alert/alert.d.ts.map +1 -1
- package/development/alert/alert.js +1 -1
- package/development/clock/clock.d.ts +19 -13
- package/development/clock/clock.d.ts.map +1 -1
- package/development/clock.js +85 -80
- package/development/core/mixins/hydration-mixin.d.ts.map +1 -1
- package/development/core/mixins.js +15 -16
- package/development/icon/icon-request.d.ts.map +1 -1
- package/development/icon.js +8 -13
- package/development/toggle-check/toggle-check.d.ts +2 -2
- package/development/toggle-check/toggle-check.d.ts.map +1 -1
- package/development/toggle-check.js +1 -1
- package/development/visual-checkbox.js +2 -2
- package/icon/icon-request.d.ts.map +1 -1
- package/icon.js +86 -86
- package/package.json +1 -1
- package/toggle-check/toggle-check.d.ts +2 -2
- package/toggle-check/toggle-check.d.ts.map +1 -1
- package/visual-checkbox.js +4 -4
|
@@ -344,4 +344,4 @@ SbbAlertElement = __decorateClass([
|
|
|
344
344
|
export {
|
|
345
345
|
SbbAlertElement
|
|
346
346
|
};
|
|
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 `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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"}
|
|
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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAsCO,IAAM,kBAAN,cAA8B,iBAAiB,UAAU,EAAE;AAAA,EAA3D,cAAA;AAAA,UAAA,GAAA,SAAA;AAYuC,SAAO,WAAW;AAGjC,SAAO,OAAwB;AAOtB,SAAgB,WAAmB;AAMjC,SAAO,aAA4B;AAkB9C,SAAO,YAA6B;AAWjE,SAAQ,YAAgC,IAAI,aAAa,MAAM,gBAAgB,OAAO,QAAQ;AAG9F,SAAQ,WAA+B,IAAI,aAAa,MAAM,gBAAgB,OAAO,OAAO;AAG5F,SAAQ,sBAA0C,IAAI;AAAA,MACpD;AAAA,MACA,gBAAgB,OAAO;AAAA,IAAA;AAGjB,SAAA,YAAY,IAAI,sBAAsB,IAAI;AAAA,EAAA;AAAA;AAAA,EAnBlD,IAAY,SAAwB;AAC1B,WAAA,KAAK,aAAa,YAAY,KAA8B;AAAA,EACtE;AAAA,EACA,IAAY,OAAO,OAAsB;AAClC,SAAA,aAAa,cAAc,KAAK;AAAA,EACvC;AAAA,EAgBA,MAAyB,aAAa,mBAAwD;AAC5F,UAAM,aAAa,iBAAiB;AAEpC,SAAK,MAAM;AAAA,EACb;AAAA;AAAA,EAGO,mBAAyB;AAC9B,SAAK,oBAAoB;EAC3B;AAAA;AAAA,EAGQ,QAAc;AACpB,SAAK,SAAS;AACd,SAAK,UAAU;EACjB;AAAA,EAEQ,gBAAgB,OAA6B;AACnD,QAAI,KAAK,WAAW,aAAa,MAAM,kBAAkB,gBAAgB;AACvE,WAAK,SAAS;AACd,WAAK,SAAS;IAChB;AAAA,EACF;AAAA,EAEmB,SAAyB;AACnC,WAAA;AAAA,iEACsD,KAAK,eAAe;AAAA;AAAA;AAAA;AAAA,6CAIxC,KAAK,gBAAgB;AAAA;AAAA;AAAA;AAAA,wBAI1C,KAAK,UAAU;AAAA,+BACR,KAAK,SAAS,MAAM,MAAM,GAAG;AAAA;AAAA;AAAA,qCAGvB,KAAK,YAAY;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKtC,KAAK,OACH;AAAA,0CACwB,KAAK,sBAAsB,OAAO;AAAA,2BACjD,KAAK,QAAQ,OAAO;AAAA,6BAClB,KAAK,UAAU,OAAO;AAAA,0BACzB,KAAK,OAAO,OAAO;AAAA;AAAA;AAAA,sBAGvB,KAAK,cAAc,KAAK,cAAc,gBAAgB,KAAK,UAAU,OAAO,CAAC;AAAA,iCAEjF,OAAO;AAAA;AAAA,cAEX,CAAC,KAAK,WACJ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,2BAQW,KAAK,SAAS,MAAM,MAAM,KAAK,IAAI;AAAA;AAAA,6BAEjC,MAAM,KAAK,kBAAkB;AAAA,iCACzB,eAAe,KAAK,UAAU,OAAO,CAAC;AAAA;AAAA;AAAA,2BAIvD,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA,EAKrB;AACF;AAnJa,gBACY,SAAyB;AADrC,gBAEY,SAAS;AAAA,EAC9B,UAAU;AAAA,EACV,SAAS;AAAA,EACT,oBAAoB;AACtB;AAMmD,gBAAA;AAAA,EAAlD,SAAS,EAAE,SAAS,MAAM,MAAM,SAAS;AAAA,GAZ/B,gBAYwC,WAAA,YAAA,CAAA;AAGf,gBAAA;AAAA,EAAnC,SAAS,EAAE,SAAS,MAAM;AAAA,GAfhB,gBAeyB,WAAA,QAAA,CAAA;AAOkB,gBAAA;AAAA,EAArD,SAAS,EAAE,WAAW,aAAa;AAAA,GAtBzB,gBAsB2C,WAAA,YAAA,CAAA;AAGL,gBAAA;AAAA,EAAhD,SAAS,EAAE,WAAW,iBAAiB;AAAA,GAzB7B,gBAyBsC,WAAA,gBAAA,CAAA;AAGF,gBAAA;AAAA,EAA9C,SAAS,EAAE,WAAW,eAAe;AAAA,GA5B3B,gBA4BoC,WAAA,cAAA,CAAA;AAGC,gBAAA;AAAA,EAA/C,SAAS,EAAE,WAAW,gBAAgB;AAAA,GA/B5B,gBA+BqC,WAAA,eAAA,CAAA;AAG7B,gBAAA;AAAA,EAAlB,SAAS;AAAA,GAlCC,gBAkCQ,WAAA,QAAA,CAAA;AAGA,gBAAA;AAAA,EAAlB,SAAS;AAAA,GArCC,gBAqCQ,WAAA,UAAA,CAAA;AAGA,gBAAA;AAAA,EAAlB,SAAS;AAAA,GAxCC,gBAwCQ,WAAA,OAAA,CAAA;AAGoC,gBAAA;AAAA,EAAtD,SAAS,EAAE,WAAW,uBAAuB;AAAA,GA3CnC,gBA2C4C,WAAA,sBAAA,CAAA;AAGnB,gBAAA;AAAA,EAAnC,SAAS,EAAE,SAAS,MAAM;AAAA,GA9ChB,gBA8CyB,WAAA,aAAA,CAAA;AA9CzB,kBAAN,gBAAA;AAAA,EADN,cAAc,WAAW;AAAA,GACb,eAAA;"}
|
|
@@ -29,16 +29,19 @@ export declare class SbbClockElement extends LitElement {
|
|
|
29
29
|
private _moveMinutesHandFn;
|
|
30
30
|
/** Move the minutes hand every minute. */
|
|
31
31
|
private _handMovement?;
|
|
32
|
-
protected willUpdate(changedProperties: PropertyValues<this>): void
|
|
32
|
+
protected willUpdate(changedProperties: PropertyValues<this>): Promise<void>;
|
|
33
|
+
protected firstUpdated(changedProperties: PropertyValues<this>): Promise<void>;
|
|
34
|
+
disconnectedCallback(): void;
|
|
33
35
|
private _handlePageVisibilityChange;
|
|
34
|
-
private
|
|
35
|
-
|
|
36
|
-
private
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
private _assignCurrentTime;
|
|
36
|
+
private _startOrConfigureClock;
|
|
37
|
+
/** Starts the clock by defining the hands starting position then starting the animations. */
|
|
38
|
+
private _startClock;
|
|
39
|
+
/** Stops the clock by removing all the animations. */
|
|
40
|
+
private _stopClock;
|
|
40
41
|
/** Set the starting position for the three hands on the clock face. */
|
|
41
42
|
private _setHandsStartingPosition;
|
|
43
|
+
/** Given the current date, calculates the hh/mm/ss values and the hh/mm/ss left to the next midnight. */
|
|
44
|
+
private _assignCurrentTime;
|
|
42
45
|
/** Set the starting position for the minutes hand. */
|
|
43
46
|
private _setMinutesHand;
|
|
44
47
|
/** Move the hours hand to the next value. */
|
|
@@ -46,12 +49,15 @@ export declare class SbbClockElement extends LitElement {
|
|
|
46
49
|
/** Move the minutes hand to the next value. */
|
|
47
50
|
private _moveMinutesHand;
|
|
48
51
|
private _addMinutesAndSetHands;
|
|
49
|
-
/**
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
52
|
+
/**
|
|
53
|
+
* Removing animation by overriding with empty string,
|
|
54
|
+
* then triggering a reflow and re add original animation by removing override.
|
|
55
|
+
* @private
|
|
56
|
+
*/
|
|
57
|
+
private _resetSecondsHandAnimation;
|
|
58
|
+
private _removeEventListeners;
|
|
59
|
+
private _removeHoursAnimationStyles;
|
|
60
|
+
private _removeSecondsAnimationStyles;
|
|
55
61
|
protected render(): TemplateResult;
|
|
56
62
|
}
|
|
57
63
|
declare global {
|
|
@@ -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;
|
|
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;IAqBzB,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
|
@@ -177,52 +177,67 @@ let SbbClockElement = class extends LitElement {
|
|
|
177
177
|
}
|
|
178
178
|
};
|
|
179
179
|
}
|
|
180
|
-
willUpdate(changedProperties) {
|
|
180
|
+
async willUpdate(changedProperties) {
|
|
181
181
|
super.willUpdate(changedProperties);
|
|
182
182
|
if (!isServer && changedProperties.has("now")) {
|
|
183
|
-
|
|
184
|
-
this._removeSecondsAnimationStyles();
|
|
185
|
-
this._removeHoursAnimationStyles();
|
|
186
|
-
this._stopClock();
|
|
187
|
-
} else {
|
|
188
|
-
this._startClock();
|
|
189
|
-
}
|
|
183
|
+
await this._startOrConfigureClock();
|
|
190
184
|
}
|
|
191
185
|
}
|
|
192
|
-
|
|
193
|
-
|
|
186
|
+
async firstUpdated(changedProperties) {
|
|
187
|
+
super.firstUpdated(changedProperties);
|
|
188
|
+
if (!isServer) {
|
|
189
|
+
document.addEventListener("visibilitychange", this._handlePageVisibilityChange, false);
|
|
190
|
+
await this._startOrConfigureClock();
|
|
191
|
+
}
|
|
194
192
|
}
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
(_a = this._clockHandHours) == null ? void 0 : _a.removeEventListener("animationend", this._moveHoursHandFn);
|
|
199
|
-
(_b = this._clockHandSeconds) == null ? void 0 : _b.removeEventListener("animationend", this._moveMinutesHandFn);
|
|
200
|
-
clearInterval(this._handMovement);
|
|
193
|
+
disconnectedCallback() {
|
|
194
|
+
super.disconnectedCallback();
|
|
195
|
+
this._removeEventListeners();
|
|
201
196
|
}
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
197
|
+
async _startOrConfigureClock() {
|
|
198
|
+
if (this.now) {
|
|
199
|
+
await this._stopClock();
|
|
200
|
+
this._resetSecondsHandAnimation();
|
|
201
|
+
this._setHandsStartingPosition();
|
|
202
|
+
} else {
|
|
203
|
+
await this._startClock();
|
|
204
|
+
}
|
|
207
205
|
}
|
|
208
|
-
|
|
206
|
+
/** Starts the clock by defining the hands starting position then starting the animations. */
|
|
207
|
+
async _startClock() {
|
|
209
208
|
var _a, _b;
|
|
210
|
-
(_a = this.
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
209
|
+
(_a = this._clockHandHours) == null ? void 0 : _a.addEventListener(
|
|
210
|
+
"animationend",
|
|
211
|
+
this._moveHoursHandFn,
|
|
212
|
+
ADD_EVENT_LISTENER_OPTIONS
|
|
213
|
+
);
|
|
214
|
+
(_b = this._clockHandSeconds) == null ? void 0 : _b.addEventListener(
|
|
215
|
+
"animationend",
|
|
216
|
+
this._moveMinutesHandFn,
|
|
217
|
+
ADD_EVENT_LISTENER_OPTIONS
|
|
218
|
+
);
|
|
219
|
+
await new Promise(
|
|
220
|
+
() => setTimeout(() => {
|
|
221
|
+
var _a2;
|
|
222
|
+
this._setHandsStartingPosition();
|
|
223
|
+
(_a2 = this.style) == null ? void 0 : _a2.setProperty("--sbb-clock-animation-play-state", "running");
|
|
224
|
+
}, INITIAL_TIMEOUT_DURATION)
|
|
225
|
+
);
|
|
214
226
|
}
|
|
215
|
-
/**
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
this.
|
|
220
|
-
this.
|
|
221
|
-
this.
|
|
227
|
+
/** Stops the clock by removing all the animations. */
|
|
228
|
+
async _stopClock() {
|
|
229
|
+
var _a, _b, _c, _d;
|
|
230
|
+
clearInterval(this._handMovement);
|
|
231
|
+
this._removeSecondsAnimationStyles();
|
|
232
|
+
this._removeHoursAnimationStyles();
|
|
233
|
+
(_a = this._clockHandHours) == null ? void 0 : _a.removeEventListener("animationend", this._moveHoursHandFn);
|
|
234
|
+
(_b = this._clockHandSeconds) == null ? void 0 : _b.removeEventListener("animationend", this._moveMinutesHandFn);
|
|
235
|
+
(_c = this._clockHandMinutes) == null ? void 0 : _c.classList.add("sbb-clock__hand-minutes--no-transition");
|
|
236
|
+
(_d = this.style) == null ? void 0 : _d.setProperty("--sbb-clock-animation-play-state", "paused");
|
|
222
237
|
}
|
|
223
238
|
/** Set the starting position for the three hands on the clock face. */
|
|
224
239
|
_setHandsStartingPosition() {
|
|
225
|
-
var _a, _b, _c, _d, _e, _f
|
|
240
|
+
var _a, _b, _c, _d, _e, _f;
|
|
226
241
|
this._assignCurrentTime();
|
|
227
242
|
const remainingSeconds = TOTAL_SECONDS_ON_CLOCK_FACE - this._seconds;
|
|
228
243
|
const remainingMinutes = TOTAL_MINUTES_ON_CLOCK_FACE - this._minutes;
|
|
@@ -253,9 +268,16 @@ let SbbClockElement = class extends LitElement {
|
|
|
253
268
|
this._setMinutesHand();
|
|
254
269
|
(_e = this._clockHandSeconds) == null ? void 0 : _e.classList.add("sbb-clock__hand-seconds--initial-minute");
|
|
255
270
|
(_f = this._clockHandHours) == null ? void 0 : _f.classList.add("sbb-clock__hand-hours--initial-hour");
|
|
256
|
-
(_g = this.style) == null ? void 0 : _g.setProperty("--sbb-clock-animation-play-state", "running");
|
|
257
271
|
this.toggleAttribute("data-initialized", true);
|
|
258
272
|
}
|
|
273
|
+
/** Given the current date, calculates the hh/mm/ss values and the hh/mm/ss left to the next midnight. */
|
|
274
|
+
_assignCurrentTime() {
|
|
275
|
+
const date = this.now ? null : /* @__PURE__ */ new Date();
|
|
276
|
+
const [hours, minutes, seconds] = date ? [date.getHours(), date.getMinutes(), date.getSeconds()] : this.now.split(":").map((p) => +p);
|
|
277
|
+
this._hours = hours % 12;
|
|
278
|
+
this._minutes = minutes;
|
|
279
|
+
this._seconds = seconds;
|
|
280
|
+
}
|
|
259
281
|
/** Set the starting position for the minutes hand. */
|
|
260
282
|
_setMinutesHand() {
|
|
261
283
|
var _a;
|
|
@@ -289,55 +311,38 @@ let SbbClockElement = class extends LitElement {
|
|
|
289
311
|
this._minutes++;
|
|
290
312
|
this._setMinutesHand();
|
|
291
313
|
}
|
|
292
|
-
/**
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
(_b = this._clockHandHours) == null ? void 0 : _b.classList.add("sbb-clock__hand-hours--initial-hour");
|
|
301
|
-
} else {
|
|
302
|
-
this._removeSecondsAnimationStyles();
|
|
303
|
-
this._removeHoursAnimationStyles();
|
|
314
|
+
/**
|
|
315
|
+
* Removing animation by overriding with empty string,
|
|
316
|
+
* then triggering a reflow and re add original animation by removing override.
|
|
317
|
+
* @private
|
|
318
|
+
*/
|
|
319
|
+
_resetSecondsHandAnimation() {
|
|
320
|
+
if (!this._clockHandSeconds) {
|
|
321
|
+
return;
|
|
304
322
|
}
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
(_f = this.style) == null ? void 0 : _f.setProperty("--sbb-clock-animation-play-state", "paused");
|
|
323
|
+
this._clockHandSeconds.style.animation = "";
|
|
324
|
+
this._clockHandSeconds.offsetHeight;
|
|
325
|
+
this._clockHandSeconds.style.removeProperty("animation");
|
|
309
326
|
}
|
|
310
|
-
|
|
311
|
-
async _startClock() {
|
|
327
|
+
_removeEventListeners() {
|
|
312
328
|
var _a, _b;
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
);
|
|
318
|
-
(_b = this._clockHandSeconds) == null ? void 0 : _b.addEventListener(
|
|
319
|
-
"animationend",
|
|
320
|
-
this._moveMinutesHandFn,
|
|
321
|
-
ADD_EVENT_LISTENER_OPTIONS
|
|
322
|
-
);
|
|
323
|
-
await new Promise(
|
|
324
|
-
() => setTimeout(() => this._setHandsStartingPosition(), INITIAL_TIMEOUT_DURATION)
|
|
325
|
-
);
|
|
329
|
+
document == null ? void 0 : document.removeEventListener("visibilitychange", this._handlePageVisibilityChange);
|
|
330
|
+
(_a = this._clockHandHours) == null ? void 0 : _a.removeEventListener("animationend", this._moveHoursHandFn);
|
|
331
|
+
(_b = this._clockHandSeconds) == null ? void 0 : _b.removeEventListener("animationend", this._moveMinutesHandFn);
|
|
332
|
+
clearInterval(this._handMovement);
|
|
326
333
|
}
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
await this._stopClock();
|
|
333
|
-
} else {
|
|
334
|
-
await this._startClock();
|
|
335
|
-
}
|
|
336
|
-
}
|
|
334
|
+
_removeHoursAnimationStyles() {
|
|
335
|
+
var _a;
|
|
336
|
+
(_a = this._clockHandHours) == null ? void 0 : _a.classList.remove("sbb-clock__hand-hours--initial-hour");
|
|
337
|
+
this.style.removeProperty("--sbb-clock-hours-animation-start-angle");
|
|
338
|
+
this.style.removeProperty("--sbb-clock-hours-animation-duration");
|
|
337
339
|
}
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
this.
|
|
340
|
+
_removeSecondsAnimationStyles() {
|
|
341
|
+
var _a, _b;
|
|
342
|
+
(_a = this._clockHandSeconds) == null ? void 0 : _a.classList.remove("sbb-clock__hand-seconds--initial-minute");
|
|
343
|
+
(_b = this._clockHandMinutes) == null ? void 0 : _b.classList.remove("sbb-clock__hand-minutes--no-transition");
|
|
344
|
+
this.style.removeProperty("--sbb-clock-seconds-animation-start-angle");
|
|
345
|
+
this.style.removeProperty("--sbb-clock-seconds-animation-duration");
|
|
341
346
|
}
|
|
342
347
|
render() {
|
|
343
348
|
return html`
|
|
@@ -378,4 +383,4 @@ SbbClockElement = __decorateClass([
|
|
|
378
383
|
export {
|
|
379
384
|
SbbClockElement
|
|
380
385
|
};
|
|
381
|
-
//# 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 willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (!isServer && changedProperties.has('now')) {\n      if (this.now) {\n        this._removeSecondsAnimationStyles();\n        this._removeHoursAnimationStyles();\n        this._stopClock();\n      } else {\n        this._startClock();\n      }\n    }\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 _addEventListeners(): void {\n    document.addEventListener('visibilitychange', this._handlePageVisibilityChange, false);\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  /** 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 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    this.style?.setProperty('--sbb-clock-animation-play-state', 'running');\n\n    this.toggleAttribute('data-initialized', true);\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  /** Stops the clock by removing all the animations. */\n  private async _stopClock(): Promise<void> {\n    clearInterval(this._handMovement);\n\n    if (this.now) {\n      this._setHandsStartingPosition();\n\n      // Wait a tick to before animation is added. Otherwise, the animation gets not completely\n      // removed which can lead to a mispositioned seconds hand.\n      await new Promise((resolve) => setTimeout(resolve));\n\n      this._clockHandSeconds?.classList.add('sbb-clock__hand-seconds--initial-minute');\n      this._clockHandHours?.classList.add('sbb-clock__hand-hours--initial-hour');\n    } else {\n      this._removeSecondsAnimationStyles();\n      this._removeHoursAnimationStyles();\n    }\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  /** 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(() => this._setHandsStartingPosition(), INITIAL_TIMEOUT_DURATION),\n    );\n  }\n\n  protected override async firstUpdated(changedProperties: PropertyValues<this>): Promise<void> {\n    super.firstUpdated(changedProperties);\n\n    if (!isServer) {\n      this._addEventListeners();\n\n      if (this.now) {\n        await this._stopClock();\n      } else {\n        await this._startClock();\n      }\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._removeEventListeners();\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":[],"mappings":"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"}
|
|
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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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hydration-mixin.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/mixins/hydration-mixin.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"hydration-mixin.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/mixins/hydration-mixin.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAkB,MAAM,KAAK,CAAC;AAEtD,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAG5D,MAAM,CAAC,OAAO,CAAC,QAAQ,OAAO,qBAAqB;IACjD;;;;;;OAMG;IACH,IAAW,iBAAiB,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC;IAEjD,+DAA+D;IAC/D,SAAS,KAAK,iBAAiB,IAAI,OAAO,CAAC;CAC5C;AAED;;;;;;GAMG;AAEH,eAAO,MAAM,iBAAiB,GAAI,CAAC,SAAS,mBAAmB,CAAC,UAAU,CAAC,QACnE,CAAC,KACN,mBAAmB,CAAC,qBAAqB,CAAC,GAAG,CAwE/C,CAAC"}
|