@sbb-esta/lyne-elements-dev 5.0.0-next-dev.1776959321 → 5.0.0-next-dev.1776960216
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/custom-elements.json +1352 -1352
- package/development/step.component-D1Gq0VRW.js +146 -0
- package/development/stepper/step/step.component.d.ts.map +1 -1
- package/development/stepper/step/step.component.js +1 -1
- package/development/stepper.js +1 -1
- package/development/stepper.pure.js +1 -1
- package/package.json +2 -2
- package/{step.component-sQbJslHx.js → step.component-DuLOqjZk.js} +3 -5
- package/stepper/step/step.component.js +1 -1
- package/stepper.js +1 -1
- package/stepper.pure.js +1 -1
- package/development/step.component-CVWxYkrv.js +0 -148
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
import { html, unsafeCSS } from "lit";
|
|
2
|
+
import { SbbElement, SbbPropertyWatcherController, appendAriaElements, boxSizingStyles, removeAriaElements } from "./core.js";
|
|
3
|
+
import { ResizeController } from "@lit-labs/observers/resize-controller.js";
|
|
4
|
+
//#region src/elements/stepper/step/step.scss?inline
|
|
5
|
+
var step_default = ":host {\n --sbb-step-opacity: 0;\n --sbb-step-margin-inline-start: var(--sbb-spacing-fixed-4x);\n --sbb-step-animation-duration: var(\n --sbb-disable-animation-duration,\n var(--sbb-animation-duration-2x)\n );\n display: block;\n}\n\n:host(:is(:state(orientation-vertical),[state--orientation-vertical])) {\n margin-inline-start: var(--sbb-step-margin-inline-start);\n opacity: 0;\n height: 0;\n transition: display var(--sbb-step-animation-duration) var(--sbb-animation-easing), height var(--sbb-stepper-animation-duration) var(--sbb-animation-easing), opacity var(--sbb-step-animation-duration) var(--sbb-animation-easing);\n transition-behavior: allow-discrete;\n}\n\n:host(:is(:state(selected),[state--selected]):is(:state(orientation-vertical),[state--orientation-vertical])) {\n opacity: 1;\n height: var(--sbb-stepper-content-height);\n transition: display var(--sbb-step-animation-duration) var(--sbb-animation-easing), height var(--sbb-stepper-animation-duration) var(--sbb-animation-easing), opacity var(--sbb-step-animation-duration) var(--sbb-stepper-animation-duration) var(--sbb-animation-easing);\n transition-behavior: allow-discrete;\n}\n\n:host(:is(:state(selected),[state--selected])) {\n --sbb-step-opacity: 1;\n --sbb-step-display: block;\n --sbb-step-height: fit-content;\n --sbb-step-animation-duration: var(\n --sbb-disable-animation-duration,\n var(--sbb-animation-duration-4x)\n );\n --sbb-step-animation-delay: var(--sbb-step-animation-duration);\n}\n\n:host(:is(:state(orientation-horizontal),[state--orientation-horizontal])) {\n --sbb-step-position: absolute;\n --sbb-step-inset-block-start: 0;\n}\n\n.sbb-step {\n position: var(--sbb-step-position, initial);\n width: 100%;\n inset-block-start: var(--sbb-step-inset-block-start, unset);\n opacity: var(--sbb-step-opacity);\n display: var(--sbb-step-display, none);\n height: var(--sbb-step-height, 0);\n transition-property: display, opacity;\n transition-duration: var(--sbb-step-animation-duration);\n transition-delay: var(--sbb-step-animation-delay, 0);\n transition-timing-function: var(--sbb-animation-easing);\n transition-behavior: allow-discrete;\n}\n@starting-style {\n .sbb-step {\n --sbb-step-opacity: 0;\n }\n}";
|
|
6
|
+
//#endregion
|
|
7
|
+
//#region src/elements/stepper/step/step.component.ts
|
|
8
|
+
/**
|
|
9
|
+
* Combined with a `sbb-stepper`, it displays a step's content.
|
|
10
|
+
*
|
|
11
|
+
* @slot - Use the unnamed slot to provide content.
|
|
12
|
+
*/
|
|
13
|
+
var SbbStepElement = class extends SbbElement {
|
|
14
|
+
static {
|
|
15
|
+
this.elementName = "sbb-step";
|
|
16
|
+
}
|
|
17
|
+
static {
|
|
18
|
+
this.role = "tabpanel";
|
|
19
|
+
}
|
|
20
|
+
static {
|
|
21
|
+
this.styles = [boxSizingStyles, unsafeCSS(step_default)];
|
|
22
|
+
}
|
|
23
|
+
static {
|
|
24
|
+
this.events = {
|
|
25
|
+
validate: "validate",
|
|
26
|
+
resizechange: "resizechange"
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
/** The label of the step. */
|
|
30
|
+
get label() {
|
|
31
|
+
return this._label;
|
|
32
|
+
}
|
|
33
|
+
get stepper() {
|
|
34
|
+
return this.closest("sbb-stepper");
|
|
35
|
+
}
|
|
36
|
+
constructor() {
|
|
37
|
+
super();
|
|
38
|
+
this._stepResizeObserver = new ResizeController(this, {
|
|
39
|
+
target: null,
|
|
40
|
+
skipInitial: true,
|
|
41
|
+
callback: () => setTimeout(() => this._onStepElementResize())
|
|
42
|
+
});
|
|
43
|
+
this._label = null;
|
|
44
|
+
this.addEventListener?.("click", (e) => this._handleClick(e));
|
|
45
|
+
this.addController(new SbbPropertyWatcherController(this, () => this.stepper, { orientation: (s) => {
|
|
46
|
+
if (this._previousOrientation) this.internals.states.delete(`orientation-${this._previousOrientation}`);
|
|
47
|
+
this._previousOrientation = s.orientation;
|
|
48
|
+
if (this._previousOrientation) this.internals.states.add(`orientation-${this._previousOrientation}`);
|
|
49
|
+
} }));
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Selects and configures the step.
|
|
53
|
+
* @internal
|
|
54
|
+
* TODO: @breaking-change: make protected
|
|
55
|
+
*/
|
|
56
|
+
select() {
|
|
57
|
+
if (!this.hasUpdated || !this.label) return;
|
|
58
|
+
this.internals.states.add("selected");
|
|
59
|
+
this.label.select();
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* Deselects and configures the step.
|
|
63
|
+
* @internal
|
|
64
|
+
* TODO: @breaking-change: make protected
|
|
65
|
+
*/
|
|
66
|
+
deselect() {
|
|
67
|
+
if (!this.label) return;
|
|
68
|
+
this.internals.states.delete("selected");
|
|
69
|
+
this.label.deselect();
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* Emits a validate event whenever step switch is triggered.
|
|
73
|
+
* @internal
|
|
74
|
+
* TODO: @breaking-change: make protected
|
|
75
|
+
*/
|
|
76
|
+
validate(eventData) {
|
|
77
|
+
/**
|
|
78
|
+
* @type {CustomEvent<SbbStepValidateEventDetails>}
|
|
79
|
+
* The validate event is dispatched when a step change is triggered. Can be canceled to abort the step change.
|
|
80
|
+
*/
|
|
81
|
+
return this.dispatchEvent(new CustomEvent("validate", {
|
|
82
|
+
bubbles: true,
|
|
83
|
+
composed: true,
|
|
84
|
+
cancelable: true,
|
|
85
|
+
detail: eventData
|
|
86
|
+
}));
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Configures the step.
|
|
90
|
+
* @internal
|
|
91
|
+
* TODO: @breaking-change: make protected
|
|
92
|
+
*/
|
|
93
|
+
configure(stepperLoaded) {
|
|
94
|
+
if (stepperLoaded) this._assignLabel();
|
|
95
|
+
}
|
|
96
|
+
/** Watches for clicked elements with `sbb-stepper-next` or `sbb-stepper-previous` attributes. */
|
|
97
|
+
_handleClick(event) {
|
|
98
|
+
const composedPathElements = event.composedPath().filter((el) => el instanceof window.HTMLElement);
|
|
99
|
+
if (composedPathElements.some((el) => this._isGoNextElement(el))) this.stepper?.next();
|
|
100
|
+
else if (composedPathElements.some((el) => this._isGoPreviousElement(el))) this.stepper?.previous();
|
|
101
|
+
}
|
|
102
|
+
_isGoNextElement(element) {
|
|
103
|
+
return element.hasAttribute("sbb-stepper-next") && !element.hasAttribute("disabled");
|
|
104
|
+
}
|
|
105
|
+
_isGoPreviousElement(element) {
|
|
106
|
+
return element.hasAttribute("sbb-stepper-previous") && !element.hasAttribute("disabled");
|
|
107
|
+
}
|
|
108
|
+
_onStepElementResize() {
|
|
109
|
+
if (!this.matches(":is(:state(selected),[state--selected])")) return;
|
|
110
|
+
/**
|
|
111
|
+
* @internal
|
|
112
|
+
* Emits when a resize happens, used to avoid setting the height of the stepper from the step component.
|
|
113
|
+
*/
|
|
114
|
+
this.dispatchEvent(new Event("resizechange", { bubbles: true }));
|
|
115
|
+
}
|
|
116
|
+
connectedCallback() {
|
|
117
|
+
super.connectedCallback();
|
|
118
|
+
this.slot ||= "step";
|
|
119
|
+
this._assignLabel();
|
|
120
|
+
}
|
|
121
|
+
firstUpdated(changedProperties) {
|
|
122
|
+
super.firstUpdated(changedProperties);
|
|
123
|
+
this.updateComplete.then(() => {
|
|
124
|
+
this._stepResizeObserver.observe(this.shadowRoot.querySelector(".sbb-step"));
|
|
125
|
+
});
|
|
126
|
+
}
|
|
127
|
+
_assignLabel() {
|
|
128
|
+
let previousSibling = this.previousElementSibling;
|
|
129
|
+
while (previousSibling && previousSibling.localName !== "sbb-step-label") previousSibling = previousSibling.previousElementSibling;
|
|
130
|
+
const value = previousSibling;
|
|
131
|
+
this.internals.ariaLabelledByElements = removeAriaElements(this.internals.ariaLabelledByElements, this._label);
|
|
132
|
+
this._label = value instanceof Element ? value : null;
|
|
133
|
+
this.internals.ariaLabelledByElements = appendAriaElements(this.internals.ariaLabelledByElements, this._label);
|
|
134
|
+
}
|
|
135
|
+
render() {
|
|
136
|
+
return html`
|
|
137
|
+
<div class="sbb-step">
|
|
138
|
+
<slot></slot>
|
|
139
|
+
</div>
|
|
140
|
+
`;
|
|
141
|
+
}
|
|
142
|
+
};
|
|
143
|
+
//#endregion
|
|
144
|
+
export { SbbStepElement as t };
|
|
145
|
+
|
|
146
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"step.component-D1Gq0VRW.js","names":[],"sources":["../../../src/elements/stepper/step/step.scss?inline","../../../src/elements/stepper/step/step.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --sbb-step-opacity: 0;\n  --sbb-step-margin-inline-start: var(--sbb-spacing-fixed-4x);\n  --sbb-step-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-2x)\n  );\n\n  display: block;\n}\n\n:host(:state(orientation-vertical)) {\n  margin-inline-start: var(--sbb-step-margin-inline-start);\n  opacity: 0;\n  height: 0;\n  transition:\n    display var(--sbb-step-animation-duration) var(--sbb-animation-easing),\n    height var(--sbb-stepper-animation-duration) var(--sbb-animation-easing),\n    opacity var(--sbb-step-animation-duration) var(--sbb-animation-easing);\n\n  // Experimental property, but supported in every major browser.\n  transition-behavior: allow-discrete;\n}\n\n:host(:state(selected):state(orientation-vertical)) {\n  opacity: 1;\n  height: var(--sbb-stepper-content-height);\n  transition:\n    display var(--sbb-step-animation-duration) var(--sbb-animation-easing),\n    height var(--sbb-stepper-animation-duration) var(--sbb-animation-easing),\n    opacity var(--sbb-step-animation-duration) var(--sbb-stepper-animation-duration)\n      var(--sbb-animation-easing);\n\n  // Experimental property, but supported in every major browser.\n  transition-behavior: allow-discrete;\n}\n\n:host(:state(selected)) {\n  --sbb-step-opacity: 1;\n  --sbb-step-display: block;\n  --sbb-step-height: fit-content;\n  --sbb-step-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-4x)\n  );\n  --sbb-step-animation-delay: var(--sbb-step-animation-duration);\n}\n\n:host(:state(orientation-horizontal)) {\n  --sbb-step-position: absolute;\n  --sbb-step-inset-block-start: 0;\n}\n\n.sbb-step {\n  position: var(--sbb-step-position, initial);\n  width: 100%;\n  inset-block-start: var(--sbb-step-inset-block-start, unset);\n  opacity: var(--sbb-step-opacity);\n  display: var(--sbb-step-display, none);\n  height: var(--sbb-step-height, 0);\n  transition: {\n    property: display, opacity;\n    duration: var(--sbb-step-animation-duration);\n    delay: var(--sbb-step-animation-delay, 0);\n    timing-function: var(--sbb-animation-easing);\n  }\n\n  // Experimental property, but supported in every major browser.\n  transition-behavior: allow-discrete;\n\n  // Experimental property, currently supported in every major browser except Firefox.\n  @starting-style {\n    --sbb-step-opacity: 0;\n  }\n}\n","import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport {\n  type CSSResultGroup,\n  html,\n  type PropertyValues,\n  type TemplateResult,\n  unsafeCSS,\n} from 'lit';\n\nimport {\n  appendAriaElements,\n  boxSizingStyles,\n  removeAriaElements,\n  SbbElement,\n  SbbPropertyWatcherController,\n} from '../../core.ts';\nimport type { SbbStepLabelElement } from '../step-label/step-label.component.ts';\nimport type { SbbStepperElement } from '../stepper/stepper.component.ts';\n\nimport style from './step.scss?inline';\n\nexport interface SbbStepValidateEventDetails {\n  currentIndex: number | null;\n  currentStep: SbbStepElement | null;\n  nextIndex: number | null;\n  nextStep: SbbStepElement | null;\n}\n\n/**\n * Combined with a `sbb-stepper`, it displays a step's content.\n *\n * @slot - Use the unnamed slot to provide content.\n */\nexport class SbbStepElement extends SbbElement {\n  public static override readonly elementName: string = 'sbb-step';\n  public static override readonly role = 'tabpanel';\n  public static override styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(style)];\n  public static readonly events = {\n    validate: 'validate',\n    resizechange: 'resizechange',\n  } as const;\n\n  // We use a timeout as a workaround to the \"ResizeObserver loop completed with undelivered notifications\" error.\n  // For more details:\n  // - https://github.com/WICG/resize-observer/issues/38#issuecomment-422126006\n  // - https://github.com/juggle/resize-observer/issues/103#issuecomment-1711148285\n  private _stepResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: () => setTimeout(() => this._onStepElementResize()),\n  });\n\n  /** The label of the step. */\n  public get label(): SbbStepLabelElement | null {\n    return this._label;\n  }\n  private _label: SbbStepLabelElement | null = null;\n\n  public get stepper(): SbbStepperElement | null {\n    return this.closest('sbb-stepper');\n  }\n\n  private _previousOrientation?: string;\n\n  public constructor() {\n    super();\n    this.addEventListener?.('click', (e) => this._handleClick(e));\n    this.addController(\n      new SbbPropertyWatcherController(this, () => this.stepper, {\n        orientation: (s) => {\n          if (this._previousOrientation) {\n            this.internals.states.delete(`orientation-${this._previousOrientation}`);\n          }\n          this._previousOrientation = s.orientation;\n          if (this._previousOrientation) {\n            this.internals.states.add(`orientation-${this._previousOrientation}`);\n          }\n        },\n      }),\n    );\n  }\n\n  /**\n   * Selects and configures the step.\n   * @internal\n   * TODO: @breaking-change: make protected\n   */\n  public select(): void {\n    if (!this.hasUpdated || !this.label) {\n      return;\n    }\n    this.internals.states.add('selected');\n    this.label.select();\n  }\n\n  /**\n   * Deselects and configures the step.\n   * @internal\n   * TODO: @breaking-change: make protected\n   */\n  public deselect(): void {\n    if (!this.label) {\n      return;\n    }\n    this.internals.states.delete('selected');\n    this.label.deselect();\n  }\n\n  /**\n   * Emits a validate event whenever step switch is triggered.\n   * @internal\n   * TODO: @breaking-change: make protected\n   */\n  public validate(eventData: SbbStepValidateEventDetails): boolean {\n    // TODO: @breaking-change: Create a specific event type for this event.\n    /**\n     * @type {CustomEvent<SbbStepValidateEventDetails>}\n     * The validate event is dispatched when a step change is triggered. Can be canceled to abort the step change.\n     */\n    return this.dispatchEvent(\n      new CustomEvent<SbbStepValidateEventDetails>('validate', {\n        bubbles: true,\n        composed: true,\n        cancelable: true,\n        detail: eventData,\n      }),\n    );\n  }\n\n  /**\n   * Configures the step.\n   * @internal\n   * TODO: @breaking-change: make protected\n   */\n  public configure(stepperLoaded: boolean): void {\n    if (stepperLoaded) {\n      this._assignLabel();\n    }\n  }\n\n  /** Watches for clicked elements with `sbb-stepper-next` or `sbb-stepper-previous` attributes. */\n  private _handleClick(event: Event): void {\n    const composedPathElements = event\n      .composedPath()\n      .filter((el) => el instanceof window.HTMLElement);\n    if (composedPathElements.some((el) => this._isGoNextElement(el as HTMLElement))) {\n      this.stepper?.next();\n    } else if (composedPathElements.some((el) => this._isGoPreviousElement(el as HTMLElement))) {\n      this.stepper?.previous();\n    }\n  }\n\n  private _isGoNextElement(element: HTMLElement): boolean {\n    return element.hasAttribute('sbb-stepper-next') && !element.hasAttribute('disabled');\n  }\n\n  private _isGoPreviousElement(element: HTMLElement): boolean {\n    return element.hasAttribute('sbb-stepper-previous') && !element.hasAttribute('disabled');\n  }\n\n  private _onStepElementResize(): void {\n    if (!this.matches(':state(selected)')) {\n      return;\n    }\n\n    /**\n     * @internal\n     * Emits when a resize happens, used to avoid setting the height of the stepper from the step component.\n     */\n    this.dispatchEvent(new Event('resizechange', { bubbles: true }));\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.slot ||= 'step';\n    this._assignLabel();\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n    this.updateComplete.then(() => {\n      this._stepResizeObserver.observe(this.shadowRoot!.querySelector('.sbb-step') as HTMLElement);\n    });\n  }\n\n  private _assignLabel(): void {\n    let previousSibling = this.previousElementSibling;\n    while (previousSibling && previousSibling.localName !== 'sbb-step-label') {\n      previousSibling = previousSibling.previousElementSibling;\n    }\n    const value = previousSibling as SbbStepLabelElement | null;\n\n    this.internals.ariaLabelledByElements = removeAriaElements(\n      this.internals.ariaLabelledByElements,\n      this._label,\n    );\n    this._label = value instanceof Element ? value : null;\n    this.internals.ariaLabelledByElements = appendAriaElements(\n      this.internals.ariaLabelledByElements,\n      this._label,\n    );\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-step\">\n        <slot></slot>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-step': SbbStepElement;\n  }\n}\n\ndeclare global {\n  interface GlobalEventHandlersEventMap {\n    resizechange: Event;\n  }\n}\n"],"mappings":";;;;;;;;;;;;ACiCA,IAAa,iBAAb,cAAoC,WAAU;;AACZ,OAAA,cAAsB;;;AACtB,OAAA,OAAO;;;AAChB,OAAA,SAAyB,CAAC,iBAAiB,UAAU,aAAM,CAAC;;;AAC5D,OAAA,SAAS;GAC9B,UAAU;GACV,cAAc;GACN;;;CAaV,IAAW,QAAK;AACd,SAAO,KAAK;;CAId,IAAW,UAAO;AAChB,SAAO,KAAK,QAAQ,cAAc;;CAKpC,cAAA;AACE,SAAO;AAnBD,OAAA,sBAAsB,IAAI,iBAAiB,MAAM;GACvD,QAAQ;GACR,aAAa;GACb,gBAAgB,iBAAiB,KAAK,sBAAsB,CAAA;GAC7D,CAAC;AAMM,OAAA,SAAqC;AAU3C,OAAK,mBAAmB,UAAU,MAAM,KAAK,aAAa,EAAE,CAAC;AAC7D,OAAK,cACH,IAAI,6BAA6B,YAAY,KAAK,SAAS,EACzD,cAAc,MAAK;AACjB,OAAI,KAAK,qBACP,MAAK,UAAU,OAAO,OAAO,eAAe,KAAK,uBAAuB;AAE1E,QAAK,uBAAuB,EAAE;AAC9B,OAAI,KAAK,qBACP,MAAK,UAAU,OAAO,IAAI,eAAe,KAAK,uBAAuB;KAG1E,CAAC,CACH;;;;;;;CAQI,SAAM;AACX,MAAI,CAAC,KAAK,cAAc,CAAC,KAAK,MAC5B;AAEF,OAAK,UAAU,OAAO,IAAI,WAAW;AACrC,OAAK,MAAM,QAAQ;;;;;;;CAQd,WAAQ;AACb,MAAI,CAAC,KAAK,MACR;AAEF,OAAK,UAAU,OAAO,OAAO,WAAW;AACxC,OAAK,MAAM,UAAU;;;;;;;CAQhB,SAAS,WAAsC;;;;;AAMpD,SAAO,KAAK,cACV,IAAI,YAAyC,YAAY;GACvD,SAAS;GACT,UAAU;GACV,YAAY;GACZ,QAAQ;GACT,CAAC,CACH;;;;;;;CAQI,UAAU,eAAsB;AACrC,MAAI,cACF,MAAK,cAAc;;;CAKf,aAAa,OAAY;EAC/B,MAAM,uBAAuB,MAC1B,cAAc,CACd,QAAQ,OAAO,cAAc,OAAO,YAAY;AACnD,MAAI,qBAAqB,MAAM,OAAO,KAAK,iBAAiB,GAAkB,CAAC,CAC7E,MAAK,SAAS,MAAM;WACX,qBAAqB,MAAM,OAAO,KAAK,qBAAqB,GAAkB,CAAC,CACxF,MAAK,SAAS,UAAU;;CAIpB,iBAAiB,SAAoB;AAC3C,SAAO,QAAQ,aAAa,mBAAmB,IAAI,CAAC,QAAQ,aAAa,WAAW;;CAG9E,qBAAqB,SAAoB;AAC/C,SAAO,QAAQ,aAAa,uBAAuB,IAAI,CAAC,QAAQ,aAAa,WAAW;;CAGlF,uBAAoB;AAC1B,MAAI,CAAC,KAAK,QAAQ,0CAAmB,CACnC;;;;;AAOF,OAAK,cAAc,IAAI,MAAM,gBAAgB,EAAE,SAAS,MAAM,CAAC,CAAC;;CAGlD,oBAAiB;AAC/B,QAAM,mBAAmB;AACzB,OAAK,SAAS;AACd,OAAK,cAAc;;CAGF,aAAa,mBAAuC;AACrE,QAAM,aAAa,kBAAkB;AACrC,OAAK,eAAe,WAAU;AAC5B,QAAK,oBAAoB,QAAQ,KAAK,WAAY,cAAc,YAA2B,CAAC;IAC5F;;CAGI,eAAY;EAClB,IAAI,kBAAkB,KAAK;AAC3B,SAAO,mBAAmB,gBAAgB,cAAc,iBACtD,mBAAkB,gBAAgB;EAEpC,MAAM,QAAQ;AAEd,OAAK,UAAU,yBAAyB,mBACtC,KAAK,UAAU,wBACf,KAAK,OACN;AACD,OAAK,SAAS,iBAAiB,UAAU,QAAQ;AACjD,OAAK,UAAU,yBAAyB,mBACtC,KAAK,UAAU,wBACf,KAAK,OACN;;CAGgB,SAAM;AACvB,SAAO,IAAI"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"step.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/stepper/step/step.component.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,cAAc,EAEnB,KAAK,cAAc,EACnB,KAAK,cAAc,EAEpB,MAAM,KAAK,CAAC;AAEb,OAAO,EAIL,UAAU,EAEX,MAAM,eAAe,CAAC;AACvB,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,uCAAuC,CAAC;AACjF,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;AAIzE,MAAM,WAAW,2BAA2B;IAC1C,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,WAAW,EAAE,cAAc,GAAG,IAAI,CAAC;IACnC,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,QAAQ,EAAE,cAAc,GAAG,IAAI,CAAC;CACjC;AAED;;;;GAIG;AACH,qBAAa,cAAe,SAAQ,UAAU;IAC5C,gBAAgC,WAAW,EAAE,MAAM,CAAc;IACjE,gBAAgC,IAAI,cAAc;IAClD,OAAuB,MAAM,EAAE,cAAc,CAAuC;IACpF,gBAAuB,MAAM;;;MAGlB;IAMX,OAAO,CAAC,mBAAmB,CAIxB;IAEH,6BAA6B;IAC7B,IAAW,KAAK,IAAI,mBAAmB,GAAG,IAAI,CAE7C;IACD,OAAO,CAAC,MAAM,CAAoC;IAElD,IAAW,OAAO,IAAI,iBAAiB,GAAG,IAAI,CAE7C;IAED,OAAO,CAAC,oBAAoB,CAAC,CAAS;;IAoBtC;;;;OAIG;IACI,MAAM,IAAI,IAAI;IAQrB;;;;OAIG;IACI,QAAQ,IAAI,IAAI;IAQvB;;;;OAIG;IACI,QAAQ,CAAC,SAAS,EAAE,2BAA2B,GAAG,OAAO;IAgBhE;;;;OAIG;IACI,SAAS,CAAC,aAAa,EAAE,OAAO,GAAG,IAAI;IAM9C,iGAAiG;IACjG,OAAO,CAAC,YAAY;IAWpB,OAAO,CAAC,gBAAgB;IAIxB,OAAO,CAAC,oBAAoB;IAI5B,OAAO,CAAC,oBAAoB;IAYZ,iBAAiB,IAAI,IAAI;cAMtB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAO9E,OAAO,CAAC,YAAY;cAkBD,MAAM,IAAI,cAAc;
|
|
1
|
+
{"version":3,"file":"step.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/stepper/step/step.component.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,cAAc,EAEnB,KAAK,cAAc,EACnB,KAAK,cAAc,EAEpB,MAAM,KAAK,CAAC;AAEb,OAAO,EAIL,UAAU,EAEX,MAAM,eAAe,CAAC;AACvB,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,uCAAuC,CAAC;AACjF,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;AAIzE,MAAM,WAAW,2BAA2B;IAC1C,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,WAAW,EAAE,cAAc,GAAG,IAAI,CAAC;IACnC,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,QAAQ,EAAE,cAAc,GAAG,IAAI,CAAC;CACjC;AAED;;;;GAIG;AACH,qBAAa,cAAe,SAAQ,UAAU;IAC5C,gBAAgC,WAAW,EAAE,MAAM,CAAc;IACjE,gBAAgC,IAAI,cAAc;IAClD,OAAuB,MAAM,EAAE,cAAc,CAAuC;IACpF,gBAAuB,MAAM;;;MAGlB;IAMX,OAAO,CAAC,mBAAmB,CAIxB;IAEH,6BAA6B;IAC7B,IAAW,KAAK,IAAI,mBAAmB,GAAG,IAAI,CAE7C;IACD,OAAO,CAAC,MAAM,CAAoC;IAElD,IAAW,OAAO,IAAI,iBAAiB,GAAG,IAAI,CAE7C;IAED,OAAO,CAAC,oBAAoB,CAAC,CAAS;;IAoBtC;;;;OAIG;IACI,MAAM,IAAI,IAAI;IAQrB;;;;OAIG;IACI,QAAQ,IAAI,IAAI;IAQvB;;;;OAIG;IACI,QAAQ,CAAC,SAAS,EAAE,2BAA2B,GAAG,OAAO;IAgBhE;;;;OAIG;IACI,SAAS,CAAC,aAAa,EAAE,OAAO,GAAG,IAAI;IAM9C,iGAAiG;IACjG,OAAO,CAAC,YAAY;IAWpB,OAAO,CAAC,gBAAgB;IAIxB,OAAO,CAAC,oBAAoB;IAI5B,OAAO,CAAC,oBAAoB;IAYZ,iBAAiB,IAAI,IAAI;cAMtB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAO9E,OAAO,CAAC,YAAY;cAkBD,MAAM,IAAI,cAAc;CAO5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,UAAU,EAAE,cAAc,CAAC;KAC5B;CACF;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,2BAA2B;QACnC,YAAY,EAAE,KAAK,CAAC;KACrB;CACF"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as SbbStepElement } from "../../step.component-
|
|
1
|
+
import { t as SbbStepElement } from "../../step.component-D1Gq0VRW.js";
|
|
2
2
|
export { SbbStepElement };
|
package/development/stepper.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { t as SbbStepLabelElement } from "./step-label.component-Dfx9rLcN.js";
|
|
2
|
-
import { t as SbbStepElement } from "./step.component-
|
|
2
|
+
import { t as SbbStepElement } from "./step.component-D1Gq0VRW.js";
|
|
3
3
|
import { n as SbbStepperElement, t as SbbStepChangeEvent } from "./stepper.component-BTwJttZt.js";
|
|
4
4
|
import "./stepper.pure.js";
|
|
5
5
|
//#region src/elements/stepper.ts
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import { t as SbbStepLabelElement } from "./step-label.component-Dfx9rLcN.js";
|
|
2
|
-
import { t as SbbStepElement } from "./step.component-
|
|
2
|
+
import { t as SbbStepElement } from "./step.component-D1Gq0VRW.js";
|
|
3
3
|
import { n as SbbStepperElement, t as SbbStepChangeEvent } from "./stepper.component-BTwJttZt.js";
|
|
4
4
|
export { SbbStepChangeEvent, SbbStepElement, SbbStepLabelElement, SbbStepperElement };
|
package/package.json
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@sbb-esta/lyne-elements-dev",
|
|
3
|
-
"version": "5.0.0-next-dev.
|
|
3
|
+
"version": "5.0.0-next-dev.1776960216",
|
|
4
4
|
"description": "Lyne Design System",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"design system",
|
|
7
7
|
"web components",
|
|
8
8
|
"lit",
|
|
9
|
-
"https://github.com/sbb-design-systems/lyne-components/commit/
|
|
9
|
+
"https://github.com/sbb-design-systems/lyne-components/commit/c08f2ee0b06a9e30239772ad0362e47750a35868"
|
|
10
10
|
],
|
|
11
11
|
"type": "module",
|
|
12
12
|
"exports": {
|
|
@@ -2,7 +2,7 @@ import { html as e, unsafeCSS as t } from "lit";
|
|
|
2
2
|
import { SbbElement as n, SbbPropertyWatcherController as r, appendAriaElements as i, boxSizingStyles as a, removeAriaElements as o } from "./core.js";
|
|
3
3
|
import { ResizeController as s } from "@lit-labs/observers/resize-controller.js";
|
|
4
4
|
//#region src/elements/stepper/step/step.scss?inline
|
|
5
|
-
var c = ":host{--sbb-step-opacity: 0;--sbb-step-margin-inline-start: var(--sbb-spacing-fixed-4x);--sbb-step-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-2x) );display:
|
|
5
|
+
var c = ":host{--sbb-step-opacity: 0;--sbb-step-margin-inline-start: var(--sbb-spacing-fixed-4x);--sbb-step-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-2x) );display:block}:host(:is(:state(orientation-vertical),[state--orientation-vertical])){margin-inline-start:var(--sbb-step-margin-inline-start);opacity:0;height:0;transition:display var(--sbb-step-animation-duration) var(--sbb-animation-easing),height var(--sbb-stepper-animation-duration) var(--sbb-animation-easing),opacity var(--sbb-step-animation-duration) var(--sbb-animation-easing);transition-behavior:allow-discrete}:host(:is(:state(selected),[state--selected]):is(:state(orientation-vertical),[state--orientation-vertical])){opacity:1;height:var(--sbb-stepper-content-height);transition:display var(--sbb-step-animation-duration) var(--sbb-animation-easing),height var(--sbb-stepper-animation-duration) var(--sbb-animation-easing),opacity var(--sbb-step-animation-duration) var(--sbb-stepper-animation-duration) var(--sbb-animation-easing);transition-behavior:allow-discrete}:host(:is(:state(selected),[state--selected])){--sbb-step-opacity: 1;--sbb-step-display: block;--sbb-step-height: fit-content;--sbb-step-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-4x) );--sbb-step-animation-delay: var(--sbb-step-animation-duration)}:host(:is(:state(orientation-horizontal),[state--orientation-horizontal])){--sbb-step-position: absolute;--sbb-step-inset-block-start: 0}.sbb-step{position:var(--sbb-step-position, initial);width:100%;inset-block-start:var(--sbb-step-inset-block-start, unset);opacity:var(--sbb-step-opacity);display:var(--sbb-step-display, none);height:var(--sbb-step-height, 0);transition-property:display,opacity;transition-duration:var(--sbb-step-animation-duration);transition-delay:var(--sbb-step-animation-delay, 0);transition-timing-function:var(--sbb-animation-easing);transition-behavior:allow-discrete}@starting-style{.sbb-step{--sbb-step-opacity: 0}}", l = class extends n {
|
|
6
6
|
static {
|
|
7
7
|
this.elementName = "sbb-step";
|
|
8
8
|
}
|
|
@@ -79,10 +79,8 @@ var c = ":host{--sbb-step-opacity: 0;--sbb-step-margin-inline-start: var(--sbb-s
|
|
|
79
79
|
}
|
|
80
80
|
render() {
|
|
81
81
|
return e`
|
|
82
|
-
<div class="sbb-step
|
|
83
|
-
<
|
|
84
|
-
<slot></slot>
|
|
85
|
-
</div>
|
|
82
|
+
<div class="sbb-step">
|
|
83
|
+
<slot></slot>
|
|
86
84
|
</div>
|
|
87
85
|
`;
|
|
88
86
|
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as e } from "../../step.component-
|
|
1
|
+
import { t as e } from "../../step.component-DuLOqjZk.js";
|
|
2
2
|
export { e as SbbStepElement };
|
package/stepper.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { t as e } from "./step-label.component-DM7lQw8b.js";
|
|
2
|
-
import { t } from "./step.component-
|
|
2
|
+
import { t } from "./step.component-DuLOqjZk.js";
|
|
3
3
|
import { n, t as r } from "./stepper.component-8IXNrdx7.js";
|
|
4
4
|
import "./stepper.pure.js";
|
|
5
5
|
t.define(), e.define(), n.define();
|
package/stepper.pure.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import { t as e } from "./step-label.component-DM7lQw8b.js";
|
|
2
|
-
import { t } from "./step.component-
|
|
2
|
+
import { t } from "./step.component-DuLOqjZk.js";
|
|
3
3
|
import { n, t as r } from "./stepper.component-8IXNrdx7.js";
|
|
4
4
|
export { r as SbbStepChangeEvent, t as SbbStepElement, e as SbbStepLabelElement, n as SbbStepperElement };
|
|
@@ -1,148 +0,0 @@
|
|
|
1
|
-
import { html, unsafeCSS } from "lit";
|
|
2
|
-
import { SbbElement, SbbPropertyWatcherController, appendAriaElements, boxSizingStyles, removeAriaElements } from "./core.js";
|
|
3
|
-
import { ResizeController } from "@lit-labs/observers/resize-controller.js";
|
|
4
|
-
//#region src/elements/stepper/step/step.scss?inline
|
|
5
|
-
var step_default = ":host {\n --sbb-step-opacity: 0;\n --sbb-step-margin-inline-start: var(--sbb-spacing-fixed-4x);\n --sbb-step-animation-duration: var(\n --sbb-disable-animation-duration,\n var(--sbb-animation-duration-2x)\n );\n display: contents;\n font-size: var(--sbb-text-font-size-m);\n letter-spacing: var(--sbb-typo-letter-spacing-text);\n}\n\n:host(:is(:state(selected),[state--selected])) {\n --sbb-step-opacity: 1;\n --sbb-step-display: block;\n --sbb-step-height: fit-content;\n --sbb-step-animation-duration: var(\n --sbb-disable-animation-duration,\n var(--sbb-animation-duration-4x)\n );\n --sbb-step-animation-delay: var(--sbb-step-animation-duration);\n}\n\n:host(:is(:state(orientation-horizontal),[state--orientation-horizontal])) {\n --sbb-step-position: absolute;\n --sbb-step-inset-block-start: 0;\n}\n\n:host(:is(:state(orientation-vertical),[state--orientation-vertical])) .sbb-step--wrapper {\n margin-inline-start: var(--sbb-step-margin-inline-start);\n opacity: 0;\n height: 0;\n transition: display var(--sbb-step-animation-duration) var(--sbb-animation-easing), height var(--sbb-stepper-animation-duration) var(--sbb-animation-easing), opacity var(--sbb-step-animation-duration) var(--sbb-animation-easing);\n transition-behavior: allow-discrete;\n}\n:host(:is(:state(selected),[state--selected]):is(:state(orientation-vertical),[state--orientation-vertical])) .sbb-step--wrapper {\n opacity: 1;\n height: var(--sbb-stepper-content-height);\n transition: display var(--sbb-step-animation-duration) var(--sbb-animation-easing), height var(--sbb-stepper-animation-duration) var(--sbb-animation-easing), opacity var(--sbb-step-animation-duration) var(--sbb-stepper-animation-duration) var(--sbb-animation-easing);\n transition-behavior: allow-discrete;\n}\n\n.sbb-step {\n position: var(--sbb-step-position, initial);\n width: 100%;\n inset-block-start: var(--sbb-step-inset-block-start, unset);\n opacity: var(--sbb-step-opacity);\n display: var(--sbb-step-display, none);\n height: var(--sbb-step-height, 0);\n transition-property: display, opacity;\n transition-duration: var(--sbb-step-animation-duration);\n transition-delay: var(--sbb-step-animation-delay, 0);\n transition-timing-function: var(--sbb-animation-easing);\n transition-behavior: allow-discrete;\n}\n@starting-style {\n .sbb-step {\n --sbb-step-opacity: 0;\n }\n}";
|
|
6
|
-
//#endregion
|
|
7
|
-
//#region src/elements/stepper/step/step.component.ts
|
|
8
|
-
/**
|
|
9
|
-
* Combined with a `sbb-stepper`, it displays a step's content.
|
|
10
|
-
*
|
|
11
|
-
* @slot - Use the unnamed slot to provide content.
|
|
12
|
-
*/
|
|
13
|
-
var SbbStepElement = class extends SbbElement {
|
|
14
|
-
static {
|
|
15
|
-
this.elementName = "sbb-step";
|
|
16
|
-
}
|
|
17
|
-
static {
|
|
18
|
-
this.role = "tabpanel";
|
|
19
|
-
}
|
|
20
|
-
static {
|
|
21
|
-
this.styles = [boxSizingStyles, unsafeCSS(step_default)];
|
|
22
|
-
}
|
|
23
|
-
static {
|
|
24
|
-
this.events = {
|
|
25
|
-
validate: "validate",
|
|
26
|
-
resizechange: "resizechange"
|
|
27
|
-
};
|
|
28
|
-
}
|
|
29
|
-
/** The label of the step. */
|
|
30
|
-
get label() {
|
|
31
|
-
return this._label;
|
|
32
|
-
}
|
|
33
|
-
get stepper() {
|
|
34
|
-
return this.closest("sbb-stepper");
|
|
35
|
-
}
|
|
36
|
-
constructor() {
|
|
37
|
-
super();
|
|
38
|
-
this._stepResizeObserver = new ResizeController(this, {
|
|
39
|
-
target: null,
|
|
40
|
-
skipInitial: true,
|
|
41
|
-
callback: () => setTimeout(() => this._onStepElementResize())
|
|
42
|
-
});
|
|
43
|
-
this._label = null;
|
|
44
|
-
this.addEventListener?.("click", (e) => this._handleClick(e));
|
|
45
|
-
this.addController(new SbbPropertyWatcherController(this, () => this.stepper, { orientation: (s) => {
|
|
46
|
-
if (this._previousOrientation) this.internals.states.delete(`orientation-${this._previousOrientation}`);
|
|
47
|
-
this._previousOrientation = s.orientation;
|
|
48
|
-
if (this._previousOrientation) this.internals.states.add(`orientation-${this._previousOrientation}`);
|
|
49
|
-
} }));
|
|
50
|
-
}
|
|
51
|
-
/**
|
|
52
|
-
* Selects and configures the step.
|
|
53
|
-
* @internal
|
|
54
|
-
* TODO: @breaking-change: make protected
|
|
55
|
-
*/
|
|
56
|
-
select() {
|
|
57
|
-
if (!this.hasUpdated || !this.label) return;
|
|
58
|
-
this.internals.states.add("selected");
|
|
59
|
-
this.label.select();
|
|
60
|
-
}
|
|
61
|
-
/**
|
|
62
|
-
* Deselects and configures the step.
|
|
63
|
-
* @internal
|
|
64
|
-
* TODO: @breaking-change: make protected
|
|
65
|
-
*/
|
|
66
|
-
deselect() {
|
|
67
|
-
if (!this.label) return;
|
|
68
|
-
this.internals.states.delete("selected");
|
|
69
|
-
this.label.deselect();
|
|
70
|
-
}
|
|
71
|
-
/**
|
|
72
|
-
* Emits a validate event whenever step switch is triggered.
|
|
73
|
-
* @internal
|
|
74
|
-
* TODO: @breaking-change: make protected
|
|
75
|
-
*/
|
|
76
|
-
validate(eventData) {
|
|
77
|
-
/**
|
|
78
|
-
* @type {CustomEvent<SbbStepValidateEventDetails>}
|
|
79
|
-
* The validate event is dispatched when a step change is triggered. Can be canceled to abort the step change.
|
|
80
|
-
*/
|
|
81
|
-
return this.dispatchEvent(new CustomEvent("validate", {
|
|
82
|
-
bubbles: true,
|
|
83
|
-
composed: true,
|
|
84
|
-
cancelable: true,
|
|
85
|
-
detail: eventData
|
|
86
|
-
}));
|
|
87
|
-
}
|
|
88
|
-
/**
|
|
89
|
-
* Configures the step.
|
|
90
|
-
* @internal
|
|
91
|
-
* TODO: @breaking-change: make protected
|
|
92
|
-
*/
|
|
93
|
-
configure(stepperLoaded) {
|
|
94
|
-
if (stepperLoaded) this._assignLabel();
|
|
95
|
-
}
|
|
96
|
-
/** Watches for clicked elements with `sbb-stepper-next` or `sbb-stepper-previous` attributes. */
|
|
97
|
-
_handleClick(event) {
|
|
98
|
-
const composedPathElements = event.composedPath().filter((el) => el instanceof window.HTMLElement);
|
|
99
|
-
if (composedPathElements.some((el) => this._isGoNextElement(el))) this.stepper?.next();
|
|
100
|
-
else if (composedPathElements.some((el) => this._isGoPreviousElement(el))) this.stepper?.previous();
|
|
101
|
-
}
|
|
102
|
-
_isGoNextElement(element) {
|
|
103
|
-
return element.hasAttribute("sbb-stepper-next") && !element.hasAttribute("disabled");
|
|
104
|
-
}
|
|
105
|
-
_isGoPreviousElement(element) {
|
|
106
|
-
return element.hasAttribute("sbb-stepper-previous") && !element.hasAttribute("disabled");
|
|
107
|
-
}
|
|
108
|
-
_onStepElementResize() {
|
|
109
|
-
if (!this.matches(":is(:state(selected),[state--selected])")) return;
|
|
110
|
-
/**
|
|
111
|
-
* @internal
|
|
112
|
-
* Emits when a resize happens, used to avoid setting the height of the stepper from the step component.
|
|
113
|
-
*/
|
|
114
|
-
this.dispatchEvent(new Event("resizechange", { bubbles: true }));
|
|
115
|
-
}
|
|
116
|
-
connectedCallback() {
|
|
117
|
-
super.connectedCallback();
|
|
118
|
-
this.slot ||= "step";
|
|
119
|
-
this._assignLabel();
|
|
120
|
-
}
|
|
121
|
-
firstUpdated(changedProperties) {
|
|
122
|
-
super.firstUpdated(changedProperties);
|
|
123
|
-
this.updateComplete.then(() => {
|
|
124
|
-
this._stepResizeObserver.observe(this.shadowRoot.querySelector(".sbb-step"));
|
|
125
|
-
});
|
|
126
|
-
}
|
|
127
|
-
_assignLabel() {
|
|
128
|
-
let previousSibling = this.previousElementSibling;
|
|
129
|
-
while (previousSibling && previousSibling.localName !== "sbb-step-label") previousSibling = previousSibling.previousElementSibling;
|
|
130
|
-
const value = previousSibling;
|
|
131
|
-
this.internals.ariaLabelledByElements = removeAriaElements(this.internals.ariaLabelledByElements, this._label);
|
|
132
|
-
this._label = value instanceof Element ? value : null;
|
|
133
|
-
this.internals.ariaLabelledByElements = appendAriaElements(this.internals.ariaLabelledByElements, this._label);
|
|
134
|
-
}
|
|
135
|
-
render() {
|
|
136
|
-
return html`
|
|
137
|
-
<div class="sbb-step--wrapper">
|
|
138
|
-
<div class="sbb-step">
|
|
139
|
-
<slot></slot>
|
|
140
|
-
</div>
|
|
141
|
-
</div>
|
|
142
|
-
`;
|
|
143
|
-
}
|
|
144
|
-
};
|
|
145
|
-
//#endregion
|
|
146
|
-
export { SbbStepElement as t };
|
|
147
|
-
|
|
148
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"step.component-CVWxYkrv.js","names":[],"sources":["../../../src/elements/stepper/step/step.scss?inline","../../../src/elements/stepper/step/step.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --sbb-step-opacity: 0;\n  --sbb-step-margin-inline-start: var(--sbb-spacing-fixed-4x);\n  --sbb-step-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-2x)\n  );\n\n  display: contents;\n  font-size: var(--sbb-text-font-size-m);\n  letter-spacing: var(--sbb-typo-letter-spacing-text);\n}\n\n:host(:state(selected)) {\n  --sbb-step-opacity: 1;\n  --sbb-step-display: block;\n  --sbb-step-height: fit-content;\n  --sbb-step-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-4x)\n  );\n  --sbb-step-animation-delay: var(--sbb-step-animation-duration);\n}\n\n:host(:state(orientation-horizontal)) {\n  --sbb-step-position: absolute;\n  --sbb-step-inset-block-start: 0;\n}\n\n.sbb-step--wrapper {\n  :host(:state(orientation-vertical)) & {\n    margin-inline-start: var(--sbb-step-margin-inline-start);\n    opacity: 0;\n    height: 0;\n    transition:\n      display var(--sbb-step-animation-duration) var(--sbb-animation-easing),\n      height var(--sbb-stepper-animation-duration) var(--sbb-animation-easing),\n      opacity var(--sbb-step-animation-duration) var(--sbb-animation-easing);\n\n    // Experimental property, but supported in every major browser.\n    transition-behavior: allow-discrete;\n  }\n\n  :host(:state(selected):state(orientation-vertical)) & {\n    opacity: 1;\n    height: var(--sbb-stepper-content-height);\n    transition:\n      display var(--sbb-step-animation-duration) var(--sbb-animation-easing),\n      height var(--sbb-stepper-animation-duration) var(--sbb-animation-easing),\n      opacity var(--sbb-step-animation-duration) var(--sbb-stepper-animation-duration)\n        var(--sbb-animation-easing);\n\n    // Experimental property, but supported in every major browser.\n    transition-behavior: allow-discrete;\n  }\n}\n\n.sbb-step {\n  position: var(--sbb-step-position, initial);\n  width: 100%;\n  inset-block-start: var(--sbb-step-inset-block-start, unset);\n  opacity: var(--sbb-step-opacity);\n  display: var(--sbb-step-display, none);\n  height: var(--sbb-step-height, 0);\n  transition: {\n    property: display, opacity;\n    duration: var(--sbb-step-animation-duration);\n    delay: var(--sbb-step-animation-delay, 0);\n    timing-function: var(--sbb-animation-easing);\n  }\n\n  // Experimental property, but supported in every major browser.\n  transition-behavior: allow-discrete;\n\n  // Experimental property, currently supported in every major browser except Firefox.\n  @starting-style {\n    --sbb-step-opacity: 0;\n  }\n}\n","import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport {\n  type CSSResultGroup,\n  html,\n  type PropertyValues,\n  type TemplateResult,\n  unsafeCSS,\n} from 'lit';\n\nimport {\n  appendAriaElements,\n  boxSizingStyles,\n  removeAriaElements,\n  SbbElement,\n  SbbPropertyWatcherController,\n} from '../../core.ts';\nimport type { SbbStepLabelElement } from '../step-label/step-label.component.ts';\nimport type { SbbStepperElement } from '../stepper/stepper.component.ts';\n\nimport style from './step.scss?inline';\n\nexport interface SbbStepValidateEventDetails {\n  currentIndex: number | null;\n  currentStep: SbbStepElement | null;\n  nextIndex: number | null;\n  nextStep: SbbStepElement | null;\n}\n\n/**\n * Combined with a `sbb-stepper`, it displays a step's content.\n *\n * @slot - Use the unnamed slot to provide content.\n */\nexport class SbbStepElement extends SbbElement {\n  public static override readonly elementName: string = 'sbb-step';\n  public static override readonly role = 'tabpanel';\n  public static override styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(style)];\n  public static readonly events = {\n    validate: 'validate',\n    resizechange: 'resizechange',\n  } as const;\n\n  // We use a timeout as a workaround to the \"ResizeObserver loop completed with undelivered notifications\" error.\n  // For more details:\n  // - https://github.com/WICG/resize-observer/issues/38#issuecomment-422126006\n  // - https://github.com/juggle/resize-observer/issues/103#issuecomment-1711148285\n  private _stepResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: () => setTimeout(() => this._onStepElementResize()),\n  });\n\n  /** The label of the step. */\n  public get label(): SbbStepLabelElement | null {\n    return this._label;\n  }\n  private _label: SbbStepLabelElement | null = null;\n\n  public get stepper(): SbbStepperElement | null {\n    return this.closest('sbb-stepper');\n  }\n\n  private _previousOrientation?: string;\n\n  public constructor() {\n    super();\n    this.addEventListener?.('click', (e) => this._handleClick(e));\n    this.addController(\n      new SbbPropertyWatcherController(this, () => this.stepper, {\n        orientation: (s) => {\n          if (this._previousOrientation) {\n            this.internals.states.delete(`orientation-${this._previousOrientation}`);\n          }\n          this._previousOrientation = s.orientation;\n          if (this._previousOrientation) {\n            this.internals.states.add(`orientation-${this._previousOrientation}`);\n          }\n        },\n      }),\n    );\n  }\n\n  /**\n   * Selects and configures the step.\n   * @internal\n   * TODO: @breaking-change: make protected\n   */\n  public select(): void {\n    if (!this.hasUpdated || !this.label) {\n      return;\n    }\n    this.internals.states.add('selected');\n    this.label.select();\n  }\n\n  /**\n   * Deselects and configures the step.\n   * @internal\n   * TODO: @breaking-change: make protected\n   */\n  public deselect(): void {\n    if (!this.label) {\n      return;\n    }\n    this.internals.states.delete('selected');\n    this.label.deselect();\n  }\n\n  /**\n   * Emits a validate event whenever step switch is triggered.\n   * @internal\n   * TODO: @breaking-change: make protected\n   */\n  public validate(eventData: SbbStepValidateEventDetails): boolean {\n    // TODO: @breaking-change: Create a specific event type for this event.\n    /**\n     * @type {CustomEvent<SbbStepValidateEventDetails>}\n     * The validate event is dispatched when a step change is triggered. Can be canceled to abort the step change.\n     */\n    return this.dispatchEvent(\n      new CustomEvent<SbbStepValidateEventDetails>('validate', {\n        bubbles: true,\n        composed: true,\n        cancelable: true,\n        detail: eventData,\n      }),\n    );\n  }\n\n  /**\n   * Configures the step.\n   * @internal\n   * TODO: @breaking-change: make protected\n   */\n  public configure(stepperLoaded: boolean): void {\n    if (stepperLoaded) {\n      this._assignLabel();\n    }\n  }\n\n  /** Watches for clicked elements with `sbb-stepper-next` or `sbb-stepper-previous` attributes. */\n  private _handleClick(event: Event): void {\n    const composedPathElements = event\n      .composedPath()\n      .filter((el) => el instanceof window.HTMLElement);\n    if (composedPathElements.some((el) => this._isGoNextElement(el as HTMLElement))) {\n      this.stepper?.next();\n    } else if (composedPathElements.some((el) => this._isGoPreviousElement(el as HTMLElement))) {\n      this.stepper?.previous();\n    }\n  }\n\n  private _isGoNextElement(element: HTMLElement): boolean {\n    return element.hasAttribute('sbb-stepper-next') && !element.hasAttribute('disabled');\n  }\n\n  private _isGoPreviousElement(element: HTMLElement): boolean {\n    return element.hasAttribute('sbb-stepper-previous') && !element.hasAttribute('disabled');\n  }\n\n  private _onStepElementResize(): void {\n    if (!this.matches(':state(selected)')) {\n      return;\n    }\n\n    /**\n     * @internal\n     * Emits when a resize happens, used to avoid setting the height of the stepper from the step component.\n     */\n    this.dispatchEvent(new Event('resizechange', { bubbles: true }));\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.slot ||= 'step';\n    this._assignLabel();\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n    this.updateComplete.then(() => {\n      this._stepResizeObserver.observe(this.shadowRoot!.querySelector('.sbb-step') as HTMLElement);\n    });\n  }\n\n  private _assignLabel(): void {\n    let previousSibling = this.previousElementSibling;\n    while (previousSibling && previousSibling.localName !== 'sbb-step-label') {\n      previousSibling = previousSibling.previousElementSibling;\n    }\n    const value = previousSibling as SbbStepLabelElement | null;\n\n    this.internals.ariaLabelledByElements = removeAriaElements(\n      this.internals.ariaLabelledByElements,\n      this._label,\n    );\n    this._label = value instanceof Element ? value : null;\n    this.internals.ariaLabelledByElements = appendAriaElements(\n      this.internals.ariaLabelledByElements,\n      this._label,\n    );\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-step--wrapper\">\n        <div class=\"sbb-step\">\n          <slot></slot>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-step': SbbStepElement;\n  }\n}\n\ndeclare global {\n  interface GlobalEventHandlersEventMap {\n    resizechange: Event;\n  }\n}\n"],"mappings":";;;;;;;;;;;;ACiCA,IAAa,iBAAb,cAAoC,WAAU;;AACZ,OAAA,cAAsB;;;AACtB,OAAA,OAAO;;;AAChB,OAAA,SAAyB,CAAC,iBAAiB,UAAU,aAAM,CAAC;;;AAC5D,OAAA,SAAS;GAC9B,UAAU;GACV,cAAc;GACN;;;CAaV,IAAW,QAAK;AACd,SAAO,KAAK;;CAId,IAAW,UAAO;AAChB,SAAO,KAAK,QAAQ,cAAc;;CAKpC,cAAA;AACE,SAAO;AAnBD,OAAA,sBAAsB,IAAI,iBAAiB,MAAM;GACvD,QAAQ;GACR,aAAa;GACb,gBAAgB,iBAAiB,KAAK,sBAAsB,CAAA;GAC7D,CAAC;AAMM,OAAA,SAAqC;AAU3C,OAAK,mBAAmB,UAAU,MAAM,KAAK,aAAa,EAAE,CAAC;AAC7D,OAAK,cACH,IAAI,6BAA6B,YAAY,KAAK,SAAS,EACzD,cAAc,MAAK;AACjB,OAAI,KAAK,qBACP,MAAK,UAAU,OAAO,OAAO,eAAe,KAAK,uBAAuB;AAE1E,QAAK,uBAAuB,EAAE;AAC9B,OAAI,KAAK,qBACP,MAAK,UAAU,OAAO,IAAI,eAAe,KAAK,uBAAuB;KAG1E,CAAC,CACH;;;;;;;CAQI,SAAM;AACX,MAAI,CAAC,KAAK,cAAc,CAAC,KAAK,MAC5B;AAEF,OAAK,UAAU,OAAO,IAAI,WAAW;AACrC,OAAK,MAAM,QAAQ;;;;;;;CAQd,WAAQ;AACb,MAAI,CAAC,KAAK,MACR;AAEF,OAAK,UAAU,OAAO,OAAO,WAAW;AACxC,OAAK,MAAM,UAAU;;;;;;;CAQhB,SAAS,WAAsC;;;;;AAMpD,SAAO,KAAK,cACV,IAAI,YAAyC,YAAY;GACvD,SAAS;GACT,UAAU;GACV,YAAY;GACZ,QAAQ;GACT,CAAC,CACH;;;;;;;CAQI,UAAU,eAAsB;AACrC,MAAI,cACF,MAAK,cAAc;;;CAKf,aAAa,OAAY;EAC/B,MAAM,uBAAuB,MAC1B,cAAc,CACd,QAAQ,OAAO,cAAc,OAAO,YAAY;AACnD,MAAI,qBAAqB,MAAM,OAAO,KAAK,iBAAiB,GAAkB,CAAC,CAC7E,MAAK,SAAS,MAAM;WACX,qBAAqB,MAAM,OAAO,KAAK,qBAAqB,GAAkB,CAAC,CACxF,MAAK,SAAS,UAAU;;CAIpB,iBAAiB,SAAoB;AAC3C,SAAO,QAAQ,aAAa,mBAAmB,IAAI,CAAC,QAAQ,aAAa,WAAW;;CAG9E,qBAAqB,SAAoB;AAC/C,SAAO,QAAQ,aAAa,uBAAuB,IAAI,CAAC,QAAQ,aAAa,WAAW;;CAGlF,uBAAoB;AAC1B,MAAI,CAAC,KAAK,QAAQ,0CAAmB,CACnC;;;;;AAOF,OAAK,cAAc,IAAI,MAAM,gBAAgB,EAAE,SAAS,MAAM,CAAC,CAAC;;CAGlD,oBAAiB;AAC/B,QAAM,mBAAmB;AACzB,OAAK,SAAS;AACd,OAAK,cAAc;;CAGF,aAAa,mBAAuC;AACrE,QAAM,aAAa,kBAAkB;AACrC,OAAK,eAAe,WAAU;AAC5B,QAAK,oBAAoB,QAAQ,KAAK,WAAY,cAAc,YAA2B,CAAC;IAC5F;;CAGI,eAAY;EAClB,IAAI,kBAAkB,KAAK;AAC3B,SAAO,mBAAmB,gBAAgB,cAAc,iBACtD,mBAAkB,gBAAgB;EAEpC,MAAM,QAAQ;AAEd,OAAK,UAAU,yBAAyB,mBACtC,KAAK,UAAU,wBACf,KAAK,OACN;AACD,OAAK,SAAS,iBAAiB,UAAU,QAAQ;AACjD,OAAK,UAAU,yBAAyB,mBACtC,KAAK,UAAU,wBACf,KAAK,OACN;;CAGgB,SAAM;AACvB,SAAO,IAAI"}
|