@sbb-esta/lyne-elements-dev 4.9.0-dev.1774507634 → 4.9.0-dev.1774514108

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.
@@ -0,0 +1,470 @@
1
+ import { __esDecorate, __runInitializers } from "tslib";
2
+ import { css, html, nothing } from "lit";
3
+ import { property } from "lit/decorators.js";
4
+ import { SbbElement } from "./core/base-elements.js";
5
+ import { forceType } from "./core/decorators.js";
6
+ import { boxSizingStyles } from "./core/styles.js";
7
+ import { i18nItemsPerPage, i18nPage } from "./core/i18n.js";
8
+ import { sbbInputModalityDetector } from "./core/a11y.js";
9
+ import "./screen-reader-only.js";
10
+ import { SbbPaginatorCommonElementMixin } from "./paginator/common/paginator-common.js";
11
+ import { repeat } from "lit/directives/repeat.js";
12
+ import "./form-field.js";
13
+ import "./select.js";
14
+ import "./option.js";
15
+ //#region src/elements/paginator/paginator/paginator.scss?lit&inline
16
+ var paginator_default = css`:host {
17
+ --sbb-paginator-animation-duration: var(
18
+ --sbb-disable-animation-duration,
19
+ var(--sbb-animation-duration-2x)
20
+ );
21
+ display: block;
22
+ }
23
+
24
+ :host([size=s]) {
25
+ --sbb-paginator-height: var(--sbb-size-element-xs);
26
+ }
27
+
28
+ :host([size=m]) {
29
+ --sbb-paginator-height: var(--sbb-size-element-m);
30
+ }
31
+
32
+ :host([negative]) {
33
+ --sbb-paginator-page-color: var(--sbb-color-5);
34
+ --sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);
35
+ }
36
+
37
+ :host([pager-position=end]) {
38
+ --sbb-paginator-justify-content: end;
39
+ --sbb-paginator-wrapping-group-wrap: wrap;
40
+ --sbb-paginator-wrap: wrap-reverse;
41
+ }
42
+
43
+ .sbb-paginator,
44
+ .sbb-paginator__wrapping-group {
45
+ display: flex;
46
+ gap: var(--sbb-spacing-fixed-3x) var(--sbb-spacing-fixed-6x);
47
+ justify-content: var(--sbb-paginator-justify-content, start);
48
+ }
49
+
50
+ .sbb-paginator {
51
+ flex-wrap: var(--sbb-paginator-wrap, wrap);
52
+ min-height: var(--sbb-paginator-height);
53
+ }
54
+
55
+ .sbb-paginator__wrapping-group {
56
+ flex-wrap: var(--sbb-paginator-wrapping-group-wrap, wrap-reverse);
57
+ }
58
+
59
+ .sbb-paginator__page-size-options {
60
+ display: flex;
61
+ align-items: center;
62
+ gap: var(--sbb-spacing-fixed-2x);
63
+ white-space: nowrap;
64
+ color: var(--sbb-paginator-page-color);
65
+ font-size: var(--sbb-paginator-font-size);
66
+ letter-spacing: var(--sbb-typo-letter-spacing-text);
67
+ }
68
+ .sbb-paginator__page-size-options sbb-select {
69
+ color: var(--sbb-form-field-text-color);
70
+ font-size: var(--sbb-form-field-input-text-size);
71
+ letter-spacing: var(--sbb-typo-letter-spacing-text);
72
+ padding-inline-end: var(--sbb-form-field-select-inline-padding-end);
73
+ }
74
+
75
+ .sbb-paginator__pages {
76
+ list-style: none;
77
+ margin: 0;
78
+ padding: 0;
79
+ font-size: inherit;
80
+ display: flex;
81
+ align-items: center;
82
+ justify-content: center;
83
+ gap: var(--sbb-spacing-fixed-1x);
84
+ user-select: none;
85
+ -webkit-tap-highlight-color: transparent;
86
+ }
87
+
88
+ .sbb-paginator__page--ellipsis,
89
+ .sbb-paginator__page--number {
90
+ position: relative;
91
+ font-size: var(--sbb-paginator-font-size);
92
+ letter-spacing: var(--sbb-typo-letter-spacing-text);
93
+ color: var(--sbb-paginator-page-color);
94
+ }
95
+
96
+ .sbb-paginator__page--ellipsis-item,
97
+ .sbb-paginator__page--number-item {
98
+ display: flex;
99
+ justify-content: center;
100
+ align-items: center;
101
+ width: var(--sbb-size-element-xxs);
102
+ height: var(--sbb-size-element-xxs);
103
+ }
104
+
105
+ .sbb-paginator__page--number-item {
106
+ appearance: none;
107
+ box-sizing: border-box;
108
+ margin: 0;
109
+ outline: none;
110
+ border: none;
111
+ border-radius: 0;
112
+ padding: 0;
113
+ background: none;
114
+ -webkit-tap-highlight-color: transparent;
115
+ color: inherit;
116
+ --sbb-text-font-size: var(--sbb-paginator-font-size);
117
+ font-family: var(--sbb-typo-font-family);
118
+ font-weight: normal;
119
+ line-height: var(--sbb-typo-line-height-text);
120
+ letter-spacing: var(--sbb-typo-letter-spacing-text);
121
+ font-size: var(--sbb-text-font-size);
122
+ position: relative;
123
+ cursor: var(--sbb-paginator-page-cursor);
124
+ outline: none !important;
125
+ color: var(--sbb-paginator-page-color);
126
+ transition: color var(--sbb-paginator-animation-duration) var(--sbb-paginator-animation-easing);
127
+ }
128
+ .sbb-paginator__page--number-item::before {
129
+ content: "";
130
+ position: absolute;
131
+ background-color: var(--sbb-paginator-page-background-color, transparent);
132
+ border: var(--sbb-paginator-page-border-width) var(--sbb-paginator-page-border-style, none) var(--sbb-paginator-page-border-color, none);
133
+ border-radius: var(--sbb-border-radius-infinity);
134
+ inset: var(--sbb-paginator-page-inset, 0);
135
+ transition-property: background-color, border, inset;
136
+ transition-duration: var(--sbb-paginator-animation-duration);
137
+ transition-timing-function: var(--sbb-paginator-animation-easing);
138
+ }
139
+ .sbb-paginator__page--number-item:focus-visible::before {
140
+ outline-offset: var(--sbb-focus-outline-offset);
141
+ outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);
142
+ outline-offset: var(--sbb-border-width-2x);
143
+ }
144
+ .sbb-paginator__page--number-item[data-selected] {
145
+ font-weight: bold;
146
+ --sbb-paginator-page-color: var(--sbb-color-3);
147
+ --sbb-paginator-page-border-width: var(--sbb-border-width-2x);
148
+ --sbb-paginator-page-border-style: solid;
149
+ --sbb-paginator-page-border-color: var(--sbb-border-color-2);
150
+ }
151
+ :host([negative]) .sbb-paginator__page--number-item[data-selected] {
152
+ --sbb-paginator-page-color: var(--sbb-color-3-negative);
153
+ --sbb-paginator-page-border-color: var(--sbb-border-color-2-negative);
154
+ }
155
+ @media (forced-colors: active) {
156
+ .sbb-paginator__page--number-item[data-selected] {
157
+ --sbb-paginator-page-border-color: Highlight !important;
158
+ }
159
+ }
160
+ .sbb-paginator__page--number-item:disabled {
161
+ --sbb-paginator-page-color: var(--sbb-color-5);
162
+ --sbb-paginator-page-border-style: dashed;
163
+ --sbb-paginator-page-border-color: var(--sbb-border-color-5);
164
+ --sbb-paginator-page-background-color: var(--sbb-background-color-3);
165
+ --sbb-paginator-page-cursor: var(--sbb-cursor-default);
166
+ }
167
+ .sbb-paginator__page--number-item:disabled:not([data-selected]) {
168
+ --sbb-paginator-page-border-width: var(--sbb-border-width-1x);
169
+ }
170
+ :host([negative]) .sbb-paginator__page--number-item:disabled {
171
+ --sbb-paginator-page-color: var(--sbb-color-5);
172
+ --sbb-paginator-page-background-color: var(--sbb-background-color-3-negative);
173
+ }
174
+ @media (forced-colors: active) {
175
+ .sbb-paginator__page--number-item:disabled {
176
+ --sbb-paginator-page-border-color: GrayText;
177
+ --sbb-paginator-page-color: GrayText;
178
+ --sbb-paginator-page-background-color: Canvas;
179
+ }
180
+ }
181
+ @media (any-hover: hover) {
182
+ .sbb-paginator__page--number-item:not(:disabled):hover {
183
+ --sbb-paginator-page-background-color: var(--sbb-background-color-3);
184
+ --sbb-paginator-page-inset: calc(var(--sbb-border-width-2x) * -1);
185
+ --sbb-paginator-translate-y-content-hover: -0.0625rem;
186
+ }
187
+ :host([negative]) .sbb-paginator__page--number-item:not(:disabled):hover {
188
+ --sbb-paginator-page-background-color: var(--sbb-background-color-3-negative);
189
+ }
190
+ }
191
+ @media (any-hover: hover) and (forced-colors: active) {
192
+ .sbb-paginator__page--number-item:not(:disabled):hover {
193
+ --sbb-paginator-page-background-color: Highlight !important;
194
+ }
195
+ }
196
+ .sbb-paginator__page--number-item:not(:disabled):active {
197
+ --sbb-paginator-page-color: var(--sbb-color-3);
198
+ --sbb-paginator-page-background-color: var(--sbb-background-color-4);
199
+ --sbb-paginator-page-inset: 0;
200
+ --sbb-paginator-translate-y-content-hover: 0;
201
+ }
202
+ :host([negative]) .sbb-paginator__page--number-item:not(:disabled):active {
203
+ --sbb-paginator-page-color: var(--sbb-color-3-negative);
204
+ --sbb-paginator-page-background-color: var(--sbb-background-color-4-negative);
205
+ }
206
+ @media (forced-colors: active) {
207
+ .sbb-paginator__page--number-item:not(:disabled):active {
208
+ --sbb-paginator-page-background-color: Highlight !important;
209
+ }
210
+ }
211
+
212
+ .sbb-paginator__page--number-item-label {
213
+ transition: transform var(--sbb-paginator-animation-duration) var(--sbb-paginator-animation-easing);
214
+ transform: translateY(var(--sbb-paginator-translate-y-content-hover, 0rem));
215
+ }
216
+
217
+ .sbb-screen-reader-only {
218
+ border: 0;
219
+ clip-path: rect(0 0 0 0);
220
+ height: 1px;
221
+ margin: -1px;
222
+ overflow: hidden;
223
+ padding: 0;
224
+ position: absolute;
225
+ white-space: nowrap;
226
+ width: 1px;
227
+ }`;
228
+ //#endregion
229
+ //#region src/elements/paginator/paginator/paginator.component.ts
230
+ var MAX_PAGE_NUMBERS_DISPLAYED = 3;
231
+ /**
232
+ * It displays a paginator component.
233
+ */
234
+ var SbbPaginatorElement = (() => {
235
+ let _classSuper = SbbPaginatorCommonElementMixin(SbbElement);
236
+ let _pageSizeOptions_decorators;
237
+ let _pageSizeOptions_initializers = [];
238
+ let _pageSizeOptions_extraInitializers = [];
239
+ let _pagerPosition_decorators;
240
+ let _pagerPosition_initializers = [];
241
+ let _pagerPosition_extraInitializers = [];
242
+ let _accessibilityItemsPerPageLabel_decorators;
243
+ let _accessibilityItemsPerPageLabel_initializers = [];
244
+ let _accessibilityItemsPerPageLabel_extraInitializers = [];
245
+ return class SbbPaginatorElement extends _classSuper {
246
+ constructor() {
247
+ super(...arguments);
248
+ this.#pageSizeOptions_accessor_storage = __runInitializers(this, _pageSizeOptions_initializers, []);
249
+ this.#pagerPosition_accessor_storage = (__runInitializers(this, _pageSizeOptions_extraInitializers), __runInitializers(this, _pagerPosition_initializers, "start"));
250
+ this.#accessibilityItemsPerPageLabel_accessor_storage = (__runInitializers(this, _pagerPosition_extraInitializers), __runInitializers(this, _accessibilityItemsPerPageLabel_initializers, ""));
251
+ this._markForFocus = (__runInitializers(this, _accessibilityItemsPerPageLabel_extraInitializers), false);
252
+ }
253
+ static {
254
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
255
+ _pageSizeOptions_decorators = [property({
256
+ attribute: "page-size-options",
257
+ type: Array
258
+ })];
259
+ _pagerPosition_decorators = [property({
260
+ attribute: "pager-position",
261
+ reflect: true
262
+ })];
263
+ _accessibilityItemsPerPageLabel_decorators = [forceType(), property({ attribute: "accessibility-items-per-page-label" })];
264
+ __esDecorate(this, null, _pageSizeOptions_decorators, {
265
+ kind: "accessor",
266
+ name: "pageSizeOptions",
267
+ static: false,
268
+ private: false,
269
+ access: {
270
+ has: (obj) => "pageSizeOptions" in obj,
271
+ get: (obj) => obj.pageSizeOptions,
272
+ set: (obj, value) => {
273
+ obj.pageSizeOptions = value;
274
+ }
275
+ },
276
+ metadata: _metadata
277
+ }, _pageSizeOptions_initializers, _pageSizeOptions_extraInitializers);
278
+ __esDecorate(this, null, _pagerPosition_decorators, {
279
+ kind: "accessor",
280
+ name: "pagerPosition",
281
+ static: false,
282
+ private: false,
283
+ access: {
284
+ has: (obj) => "pagerPosition" in obj,
285
+ get: (obj) => obj.pagerPosition,
286
+ set: (obj, value) => {
287
+ obj.pagerPosition = value;
288
+ }
289
+ },
290
+ metadata: _metadata
291
+ }, _pagerPosition_initializers, _pagerPosition_extraInitializers);
292
+ __esDecorate(this, null, _accessibilityItemsPerPageLabel_decorators, {
293
+ kind: "accessor",
294
+ name: "accessibilityItemsPerPageLabel",
295
+ static: false,
296
+ private: false,
297
+ access: {
298
+ has: (obj) => "accessibilityItemsPerPageLabel" in obj,
299
+ get: (obj) => obj.accessibilityItemsPerPageLabel,
300
+ set: (obj, value) => {
301
+ obj.accessibilityItemsPerPageLabel = value;
302
+ }
303
+ },
304
+ metadata: _metadata
305
+ }, _accessibilityItemsPerPageLabel_initializers, _accessibilityItemsPerPageLabel_extraInitializers);
306
+ if (_metadata) Object.defineProperty(this, Symbol.metadata, {
307
+ enumerable: true,
308
+ configurable: true,
309
+ writable: true,
310
+ value: _metadata
311
+ });
312
+ }
313
+ static {
314
+ this.elementName = "sbb-paginator";
315
+ }
316
+ static {
317
+ this.styles = [boxSizingStyles, paginator_default];
318
+ }
319
+ static {
320
+ this.events = { page: "page" };
321
+ }
322
+ #pageSizeOptions_accessor_storage;
323
+ /** The available `pageSize` choices. */
324
+ get pageSizeOptions() {
325
+ return this.#pageSizeOptions_accessor_storage;
326
+ }
327
+ set pageSizeOptions(value) {
328
+ this.#pageSizeOptions_accessor_storage = value;
329
+ }
330
+ #pagerPosition_accessor_storage;
331
+ /**
332
+ * Position of the prev/next buttons: if `pageSizeOptions` is set,
333
+ * the sbb-select for the pageSize change will be positioned oppositely, with the page numbers always in the center.
334
+ */
335
+ get pagerPosition() {
336
+ return this.#pagerPosition_accessor_storage;
337
+ }
338
+ set pagerPosition(value) {
339
+ this.#pagerPosition_accessor_storage = value;
340
+ }
341
+ #accessibilityItemsPerPageLabel_accessor_storage;
342
+ /**
343
+ * Accessibility label for the items per page. Defaults to `Items per page.`.
344
+ * Can be set for cases like a carousel, where `slide` or `image` fits better.
345
+ */
346
+ get accessibilityItemsPerPageLabel() {
347
+ return this.#accessibilityItemsPerPageLabel_accessor_storage;
348
+ }
349
+ set accessibilityItemsPerPageLabel(value) {
350
+ this.#accessibilityItemsPerPageLabel_accessor_storage = value;
351
+ }
352
+ updated(changedProperties) {
353
+ super.updated(changedProperties);
354
+ /** Tab navigation can force a rerender when ellipsis elements need to be displayed; the focus must stay on the correct element. */
355
+ if (this._markForFocus) {
356
+ const focusElement = this._getVisiblePages().find((e) => this.pageIndex === +e.getAttribute("data-index"));
357
+ if (focusElement) focusElement.focus();
358
+ this._markForFocus = false;
359
+ }
360
+ }
361
+ /** Returns the displayed page elements. */
362
+ _getVisiblePages() {
363
+ return Array.from(this.shadowRoot.querySelectorAll(".sbb-paginator__page--number-item"));
364
+ }
365
+ /**
366
+ * Calculate the pages set based on the following rules:
367
+ * - the first page must always be visible;
368
+ * - the last page must always be visible;
369
+ * - if there are more than `MAX_PAGE_NUMBERS_DISPLAYED` other pages, ellipsis button must be used.
370
+ */
371
+ _getVisiblePagesIndex() {
372
+ const totalPages = this.numberOfPages();
373
+ const currentPageIndex = this.pageIndex;
374
+ if (totalPages <= MAX_PAGE_NUMBERS_DISPLAYED + 2) return this._range(totalPages);
375
+ else if (currentPageIndex < MAX_PAGE_NUMBERS_DISPLAYED) return [
376
+ ...this._range(MAX_PAGE_NUMBERS_DISPLAYED + 1),
377
+ "ellipsis",
378
+ totalPages - 1
379
+ ];
380
+ else if (currentPageIndex >= totalPages - MAX_PAGE_NUMBERS_DISPLAYED) return [
381
+ 0,
382
+ "ellipsis",
383
+ ...this._range(MAX_PAGE_NUMBERS_DISPLAYED + 1, totalPages - 1 - MAX_PAGE_NUMBERS_DISPLAYED)
384
+ ];
385
+ else return [
386
+ 0,
387
+ "ellipsis",
388
+ currentPageIndex - 1,
389
+ currentPageIndex,
390
+ currentPageIndex + 1,
391
+ "ellipsis",
392
+ totalPages - 1
393
+ ];
394
+ }
395
+ /** Creates an array of consecutive numbers given the length and the starting value. */
396
+ _range(length, offset = 0) {
397
+ return Array.from({ length }, (_, k) => k + offset);
398
+ }
399
+ _onPageNumberClick(index) {
400
+ this.selectPage(index);
401
+ this._markForFocus = sbbInputModalityDetector.mostRecentModality === "keyboard";
402
+ }
403
+ _renderItemPerPageTemplate() {
404
+ return this.pageSizeOptions && this.pageSizeOptions.length > 0 ? html`
405
+ <div class="sbb-paginator__page-size-options">
406
+ <label for="select"
407
+ >${this.accessibilityItemsPerPageLabel ? this.accessibilityItemsPerPageLabel : i18nItemsPerPage[this.language.current]}</label
408
+ >
409
+ <sbb-form-field
410
+ borderless
411
+ width="collapse"
412
+ ?negative=${this.negative}
413
+ size=${this.size || nothing}
414
+ >
415
+ <sbb-select
416
+ id="select"
417
+ ?disabled=${this.disabled}
418
+ value=${this.pageSizeOptions?.find((e) => e === this.pageSize) ?? this.pageSizeOptions[0]}
419
+ @change=${(e) => this.pageSize = +e.target.value}
420
+ >
421
+ ${repeat(this.pageSizeOptions, (element) => html`<sbb-option value=${element}>${element}</sbb-option>`)}
422
+ </sbb-select>
423
+ </sbb-form-field>
424
+ </div>
425
+ ` : nothing;
426
+ }
427
+ _renderPageNumbers() {
428
+ return html`
429
+ <ul class="sbb-paginator__pages">
430
+ ${repeat(this._getVisiblePagesIndex(), (item) => item === "ellipsis" ? html`
431
+ <li class="sbb-paginator__page--ellipsis">
432
+ <span class="sbb-paginator__page--ellipsis-item">…</span>
433
+ </li>
434
+ ` : html`
435
+ <li class="sbb-paginator__page--number">
436
+ <button
437
+ ?data-selected=${this.pageIndex === item}
438
+ ?disabled=${this.disabled}
439
+ class="sbb-paginator__page--number-item"
440
+ data-index=${item}
441
+ aria-label="${this.accessibilityPageLabel ? this.accessibilityPageLabel : i18nPage[this.language.current]} ${item + 1}"
442
+ aria-current=${this.pageIndex === item ? "true" : nothing}
443
+ @click=${() => this._onPageNumberClick(item)}
444
+ >
445
+ <span class="sbb-paginator__page--number-item-label">${item + 1}</span>
446
+ </button>
447
+ </li>
448
+ `)}
449
+ </ul>
450
+ `;
451
+ }
452
+ renderPaginator() {
453
+ return html`
454
+ <div class="sbb-paginator">
455
+ ${this.pagerPosition === "start" ? html`<span class="sbb-paginator__wrapping-group">
456
+ ${this.renderPrevNextButtons()} ${this._renderPageNumbers()}
457
+ </span>
458
+ ${this._renderItemPerPageTemplate()}` : html`${this._renderItemPerPageTemplate()}
459
+ <span class="sbb-paginator__wrapping-group">
460
+ ${this._renderPageNumbers()} ${this.renderPrevNextButtons()}
461
+ </span>`}</span>
462
+ </div>
463
+ `;
464
+ }
465
+ };
466
+ })();
467
+ //#endregion
468
+ export { SbbPaginatorElement as t };
469
+
470
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"paginator.component-C03vfQ7J.js","names":[],"sources":["../../../src/elements/paginator/paginator/paginator.scss?lit&inline","../../../src/elements/paginator/paginator/paginator.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --sbb-paginator-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-2x)\n  );\n\n  display: block;\n}\n\n:host([size='s']) {\n  --sbb-paginator-height: var(--sbb-size-element-xs);\n}\n\n:host([size='m']) {\n  --sbb-paginator-height: var(--sbb-size-element-m);\n}\n\n:host([negative]) {\n  --sbb-paginator-page-color: var(--sbb-color-5);\n  --sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);\n}\n\n:host([pager-position='end']) {\n  --sbb-paginator-justify-content: end;\n  --sbb-paginator-wrapping-group-wrap: wrap;\n  --sbb-paginator-wrap: wrap-reverse;\n}\n\n.sbb-paginator,\n.sbb-paginator__wrapping-group {\n  display: flex;\n  gap: var(--sbb-spacing-fixed-3x) var(--sbb-spacing-fixed-6x);\n  justify-content: var(--sbb-paginator-justify-content, start);\n}\n\n.sbb-paginator {\n  flex-wrap: var(--sbb-paginator-wrap, wrap);\n  min-height: var(--sbb-paginator-height);\n}\n\n.sbb-paginator__wrapping-group {\n  flex-wrap: var(--sbb-paginator-wrapping-group-wrap, wrap-reverse);\n}\n\n.sbb-paginator__page-size-options {\n  display: flex;\n  align-items: center;\n  gap: var(--sbb-spacing-fixed-2x);\n  white-space: nowrap;\n  color: var(--sbb-paginator-page-color);\n  font-size: var(--sbb-paginator-font-size);\n  letter-spacing: var(--sbb-typo-letter-spacing-text);\n\n  // Reapply part of the global form-field css that does not pierce the shadow DOM.\n  sbb-select {\n    color: var(--sbb-form-field-text-color);\n    font-size: var(--sbb-form-field-input-text-size);\n    letter-spacing: var(--sbb-typo-letter-spacing-text);\n    padding-inline-end: var(--sbb-form-field-select-inline-padding-end);\n  }\n}\n\n.sbb-paginator__pages {\n  @include sbb.list-reset;\n\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  gap: var(--sbb-spacing-fixed-1x);\n  user-select: none;\n  -webkit-tap-highlight-color: transparent;\n}\n\n.sbb-paginator__page--ellipsis,\n.sbb-paginator__page--number {\n  position: relative;\n  font-size: var(--sbb-paginator-font-size);\n  letter-spacing: var(--sbb-typo-letter-spacing-text);\n  color: var(--sbb-paginator-page-color);\n}\n\n.sbb-paginator__page--ellipsis-item,\n.sbb-paginator__page--number-item {\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  width: var(--sbb-size-element-xxs);\n  height: var(--sbb-size-element-xxs);\n}\n\n.sbb-paginator__page--number-item {\n  @include sbb.button-reset;\n\n  // The text mixin is needed to override the button base style\n  --sbb-text-font-size: var(--sbb-paginator-font-size);\n  @include sbb.text;\n\n  position: relative;\n  cursor: var(--sbb-paginator-page-cursor);\n  outline: none !important;\n  color: var(--sbb-paginator-page-color);\n  transition: color var(--sbb-paginator-animation-duration) var(--sbb-paginator-animation-easing);\n\n  &::before {\n    content: '';\n    position: absolute;\n    background-color: var(--sbb-paginator-page-background-color, transparent);\n    border: var(--sbb-paginator-page-border-width) var(--sbb-paginator-page-border-style, none)\n      var(--sbb-paginator-page-border-color, none);\n    border-radius: var(--sbb-border-radius-infinity);\n    inset: var(--sbb-paginator-page-inset, 0);\n    transition: {\n      property: background-color, border, inset;\n      duration: var(--sbb-paginator-animation-duration);\n      timing-function: var(--sbb-paginator-animation-easing);\n    }\n  }\n\n  &:focus-visible {\n    &::before {\n      @include sbb.focus-outline;\n\n      outline-offset: var(--sbb-border-width-2x);\n    }\n  }\n\n  &[data-selected] {\n    @include sbb.text--bold;\n\n    --sbb-paginator-page-color: var(--sbb-color-3);\n    --sbb-paginator-page-border-width: var(--sbb-border-width-2x);\n    --sbb-paginator-page-border-style: solid;\n    --sbb-paginator-page-border-color: var(--sbb-border-color-2);\n\n    :host([negative]) & {\n      --sbb-paginator-page-color: var(--sbb-color-3-negative);\n      --sbb-paginator-page-border-color: var(--sbb-border-color-2-negative);\n    }\n\n    @include sbb.if-forced-colors {\n      --sbb-paginator-page-border-color: Highlight !important;\n    }\n  }\n\n  &:disabled {\n    --sbb-paginator-page-color: var(--sbb-color-5);\n    --sbb-paginator-page-border-style: dashed;\n    --sbb-paginator-page-border-color: var(--sbb-border-color-5);\n    --sbb-paginator-page-background-color: var(--sbb-background-color-3);\n    --sbb-paginator-page-cursor: var(--sbb-cursor-default);\n\n    &:not([data-selected]) {\n      --sbb-paginator-page-border-width: var(--sbb-border-width-1x);\n    }\n\n    :host([negative]) & {\n      --sbb-paginator-page-color: var(--sbb-color-5);\n      --sbb-paginator-page-background-color: var(--sbb-background-color-3-negative);\n    }\n\n    @include sbb.if-forced-colors {\n      --sbb-paginator-page-border-color: GrayText;\n      --sbb-paginator-page-color: GrayText;\n      --sbb-paginator-page-background-color: Canvas;\n    }\n  }\n\n  &:not(:disabled):hover {\n    @include sbb.hover-mq($hover: true) {\n      --sbb-paginator-page-background-color: var(--sbb-background-color-3);\n      --sbb-paginator-page-inset: calc(var(--sbb-border-width-2x) * -1);\n      --sbb-paginator-translate-y-content-hover: #{sbb.px-to-rem-build(-1)};\n\n      :host([negative]) & {\n        --sbb-paginator-page-background-color: var(--sbb-background-color-3-negative);\n      }\n\n      @include sbb.if-forced-colors {\n        --sbb-paginator-page-background-color: Highlight !important;\n      }\n    }\n  }\n\n  &:not(:disabled):active {\n    --sbb-paginator-page-color: var(--sbb-color-3);\n    --sbb-paginator-page-background-color: var(--sbb-background-color-4);\n    --sbb-paginator-page-inset: 0;\n    --sbb-paginator-translate-y-content-hover: 0;\n\n    :host([negative]) & {\n      --sbb-paginator-page-color: var(--sbb-color-3-negative);\n      --sbb-paginator-page-background-color: var(--sbb-background-color-4-negative);\n    }\n\n    @include sbb.if-forced-colors {\n      --sbb-paginator-page-background-color: Highlight !important;\n    }\n  }\n}\n\n.sbb-paginator__page--number-item-label {\n  transition: transform var(--sbb-paginator-animation-duration)\n    var(--sbb-paginator-animation-easing);\n  transform: translateY(var(--sbb-paginator-translate-y-content-hover, #{sbb.px-to-rem-build(0)}));\n}\n\n// Needed for the sbb-select\n.sbb-screen-reader-only {\n  @include sbb.screen-reader-only;\n}\n","import { type CSSResultGroup, html, nothing, type PropertyValues, type TemplateResult } from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { repeat } from 'lit/directives/repeat.js';\n\nimport { sbbInputModalityDetector } from '../../core/a11y.ts';\nimport { SbbElement } from '../../core/base-elements.ts';\nimport { forceType } from '../../core/decorators.ts';\nimport { i18nItemsPerPage, i18nPage } from '../../core/i18n.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport type { SbbSelectElement } from '../../select.ts';\nimport { SbbPaginatorCommonElementMixin } from '../common/paginator-common.ts';\n\nimport style from './paginator.scss?lit&inline';\n\nimport '../../form-field.ts';\nimport '../../select.ts';\nimport '../../option.ts';\nimport '../../screen-reader-only.ts';\n\nconst MAX_PAGE_NUMBERS_DISPLAYED = 3;\n\n/**\n * It displays a paginator component.\n */\nexport class SbbPaginatorElement extends SbbPaginatorCommonElementMixin(SbbElement) {\n  public static override readonly elementName: string = 'sbb-paginator';\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  public static readonly events: Record<string, string> = {\n    page: 'page',\n  } as const;\n\n  /** The available `pageSize` choices. */\n  @property({ attribute: 'page-size-options', type: Array })\n  public accessor pageSizeOptions: number[] = [];\n\n  /**\n   * Position of the prev/next buttons: if `pageSizeOptions` is set,\n   * the sbb-select for the pageSize change will be positioned oppositely, with the page numbers always in the center.\n   */\n  @property({ attribute: 'pager-position', reflect: true }) public override accessor pagerPosition:\n    | 'start'\n    | 'end' = 'start';\n\n  /**\n   * Accessibility label for the items per page. Defaults to `Items per page.`.\n   * Can be set for cases like a carousel, where `slide` or `image` fits better.\n   */\n  @forceType()\n  @property({ attribute: 'accessibility-items-per-page-label' })\n  public accessor accessibilityItemsPerPageLabel: string = '';\n\n  private _markForFocus = false;\n\n  protected override updated(changedProperties: PropertyValues<this>): void {\n    super.updated(changedProperties);\n\n    /** Tab navigation can force a rerender when ellipsis elements need to be displayed; the focus must stay on the correct element. */\n    if (this._markForFocus) {\n      const focusElement = this._getVisiblePages().find(\n        (e) => this.pageIndex === +e.getAttribute('data-index')!,\n      );\n      if (focusElement) {\n        (focusElement as HTMLElement).focus();\n      }\n      this._markForFocus = false;\n    }\n  }\n\n  /** Returns the displayed page elements. */\n  private _getVisiblePages(): Element[] {\n    return Array.from(this.shadowRoot!.querySelectorAll('.sbb-paginator__page--number-item'));\n  }\n\n  /**\n   * Calculate the pages set based on the following rules:\n   *  - the first page must always be visible;\n   *  - the last page must always be visible;\n   *  - if there are more than `MAX_PAGE_NUMBERS_DISPLAYED` other pages, ellipsis button must be used.\n   */\n  private _getVisiblePagesIndex(): (number | 'ellipsis')[] {\n    const totalPages: number = this.numberOfPages();\n    const currentPageIndex: number = this.pageIndex;\n\n    if (totalPages <= MAX_PAGE_NUMBERS_DISPLAYED + 2) {\n      return this._range(totalPages);\n    } else if (currentPageIndex < MAX_PAGE_NUMBERS_DISPLAYED) {\n      return [...this._range(MAX_PAGE_NUMBERS_DISPLAYED + 1), 'ellipsis', totalPages - 1];\n    } else if (currentPageIndex >= totalPages - MAX_PAGE_NUMBERS_DISPLAYED) {\n      return [\n        0,\n        'ellipsis',\n        ...this._range(MAX_PAGE_NUMBERS_DISPLAYED + 1, totalPages - 1 - MAX_PAGE_NUMBERS_DISPLAYED),\n      ];\n    } else {\n      return [\n        0,\n        'ellipsis',\n        currentPageIndex - 1,\n        currentPageIndex,\n        currentPageIndex + 1,\n        'ellipsis',\n        totalPages - 1,\n      ];\n    }\n  }\n\n  /** Creates an array of consecutive numbers given the length and the starting value. */\n  private _range(length: number, offset: number = 0): number[] {\n    return Array.from({ length }, (_, k) => k + offset);\n  }\n\n  private _onPageNumberClick(index: number): void {\n    this.selectPage(index);\n\n    // When the page is changed, the new current page might change its position.\n    // After the render, we need to ensure that the focus stays on the selected page.\n    this._markForFocus = sbbInputModalityDetector.mostRecentModality === 'keyboard';\n  }\n\n  private _renderItemPerPageTemplate(): TemplateResult | typeof nothing {\n    return this.pageSizeOptions && this.pageSizeOptions.length > 0\n      ? html`\n          <div class=\"sbb-paginator__page-size-options\">\n            <label for=\"select\"\n              >${this.accessibilityItemsPerPageLabel\n                ? this.accessibilityItemsPerPageLabel\n                : i18nItemsPerPage[this.language.current]}</label\n            >\n            <sbb-form-field\n              borderless\n              width=\"collapse\"\n              ?negative=${this.negative}\n              size=${this.size || nothing}\n            >\n              <sbb-select\n                id=\"select\"\n                ?disabled=${this.disabled}\n                value=${this.pageSizeOptions?.find((e) => e === this.pageSize) ??\n                this.pageSizeOptions![0]}\n                @change=${(e: Event) =>\n                  (this.pageSize = +((e.target as SbbSelectElement).value as string))}\n              >\n                ${repeat(\n                  this.pageSizeOptions!,\n                  (element) => html`<sbb-option value=${element}>${element}</sbb-option>`,\n                )}\n              </sbb-select>\n            </sbb-form-field>\n          </div>\n        `\n      : nothing;\n  }\n\n  private _renderPageNumbers(): TemplateResult {\n    return html`\n      <ul class=\"sbb-paginator__pages\">\n        ${repeat(\n          this._getVisiblePagesIndex(),\n          (item: number | 'ellipsis'): TemplateResult =>\n            item === 'ellipsis'\n              ? html`\n                  <li class=\"sbb-paginator__page--ellipsis\">\n                    <span class=\"sbb-paginator__page--ellipsis-item\">…</span>\n                  </li>\n                `\n              : html`\n                  <li class=\"sbb-paginator__page--number\">\n                    <button\n                      ?data-selected=${this.pageIndex === item}\n                      ?disabled=${this.disabled}\n                      class=\"sbb-paginator__page--number-item\"\n                      data-index=${item}\n                      aria-label=\"${this.accessibilityPageLabel\n                        ? this.accessibilityPageLabel\n                        : i18nPage[this.language.current]} ${item + 1}\"\n                      aria-current=${this.pageIndex === item ? 'true' : nothing}\n                      @click=${() => this._onPageNumberClick(item)}\n                    >\n                      <span class=\"sbb-paginator__page--number-item-label\">${item + 1}</span>\n                    </button>\n                  </li>\n                `,\n        )}\n      </ul>\n    `;\n  }\n\n  protected override renderPaginator(): TemplateResult {\n    return html`\n      <div class=\"sbb-paginator\">\n        ${\n          this.pagerPosition === 'start'\n            ? html`<span class=\"sbb-paginator__wrapping-group\">\n                  ${this.renderPrevNextButtons()} ${this._renderPageNumbers()}\n                </span>\n                ${this._renderItemPerPageTemplate()}`\n            : html`${this._renderItemPerPageTemplate()}\n                <span class=\"sbb-paginator__wrapping-group\">\n                  ${this._renderPageNumbers()} ${this.renderPrevNextButtons()}\n                </span>`\n        }</span>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-paginator': SbbPaginatorElement;\n  }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACmBA,IAAM,6BAA6B;;;;IAKtB,6BAAmB;mBAAS,+BAA+B,WAAW;;;;;;;;;;cAAtE,4BAA4B,YAA0C;;;AASjE,SAAA,mCAAA,kBAAA,MAAA,+BAA4B,EAAE,CAAA;AAMqC,SAAA,kCAAA,kBAAA,MAAA,mCAAA,EAAA,kBAAA,MAAA,6BAEvE,QAAO;AAQH,SAAA,mDAAA,kBAAA,MAAA,iCAAA,EAAA,kBAAA,MAAA,8CAAyC,GAAE;AAEnD,QAAA,iBAAa,kBAAA,MAAA,kDAAA,EAAG;;;;kCAnBvB,SAAS;IAAE,WAAW;IAAqB,MAAM;IAAO,CAAC,CAAA;gCAOzD,SAAS;IAAE,WAAW;IAAkB,SAAS;IAAM,CAAC,CAAA;iDAQxD,WAAW,EACX,SAAS,EAAE,WAAW,sCAAsC,CAAC,CAAA;AAf9D,gBAAA,MAAA,MAAA,6BAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,qBAAA;KAAA,MAAA,QAAA,IAAgB;KAAe,MAAA,KAAA,UAAA;AAAA,UAAf,kBAAe;;KAAA;IAAA,UAAA;IAAA,EAAA,+BAAA,mCAAA;AAM2B,gBAAA,MAAA,MAAA,2BAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,mBAAA;KAAA,MAAA,QAAA,IAAyB;KAAa,MAAA,KAAA,UAAA;AAAA,UAAb,gBAAa;;KAAA;IAAA,UAAA;IAAA,EAAA,6BAAA,iCAAA;AAUhG,gBAAA,MAAA,MAAA,4CAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,oCAAA;KAAA,MAAA,QAAA,IAAgB;KAA8B,MAAA,KAAA,UAAA;AAAA,UAA9B,iCAA8B;;KAAA;IAAA,UAAA;IAAA,EAAA,8CAAA,kDAAA;;;;;;;;;AAxBd,QAAA,cAAsB;;;AAC/B,QAAA,SAAyB,CAAC,iBAAiB,kBAAM;;;AACjD,QAAA,SAAiC,EACtD,MAAM,QACE;;EAIV;;EAAA,IAAgB,kBAAe;AAAA,UAAA,MAAA;;EAA/B,IAAgB,gBAAe,OAAA;AAAA,SAAA,mCAAA;;EAM2B;;;;;EAAA,IAAyB,gBAAa;AAAA,UAAA,MAAA;;EAAtC,IAAyB,cAAa,OAAA;AAAA,SAAA,iCAAA;;EAUhG;;;;;EAAA,IAAgB,iCAA8B;AAAA,UAAA,MAAA;;EAA9C,IAAgB,+BAA8B,OAAA;AAAA,SAAA,kDAAA;;EAI3B,QAAQ,mBAAuC;AAChE,SAAM,QAAQ,kBAAkB;;AAGhC,OAAI,KAAK,eAAe;IACtB,MAAM,eAAe,KAAK,kBAAkB,CAAC,MAC1C,MAAM,KAAK,cAAc,CAAC,EAAE,aAAa,aAAc,CACzD;AACD,QAAI,aACD,cAA6B,OAAO;AAEvC,SAAK,gBAAgB;;;;EAKjB,mBAAgB;AACtB,UAAO,MAAM,KAAK,KAAK,WAAY,iBAAiB,oCAAoC,CAAC;;;;;;;;EASnF,wBAAqB;GAC3B,MAAM,aAAqB,KAAK,eAAe;GAC/C,MAAM,mBAA2B,KAAK;AAEtC,OAAI,cAAc,6BAA6B,EAC7C,QAAO,KAAK,OAAO,WAAW;YACrB,mBAAmB,2BAC5B,QAAO;IAAC,GAAG,KAAK,OAAO,6BAA6B,EAAE;IAAE;IAAY,aAAa;IAAE;YAC1E,oBAAoB,aAAa,2BAC1C,QAAO;IACL;IACA;IACA,GAAG,KAAK,OAAO,6BAA6B,GAAG,aAAa,IAAI,2BAAA;IACjE;OAED,QAAO;IACL;IACA;IACA,mBAAmB;IACnB;IACA,mBAAmB;IACnB;IACA,aAAa;IACd;;;EAKG,OAAO,QAAgB,SAAiB,GAAC;AAC/C,UAAO,MAAM,KAAK,EAAE,QAAQ,GAAG,GAAG,MAAM,IAAI,OAAO;;EAG7C,mBAAmB,OAAa;AACtC,QAAK,WAAW,MAAM;AAItB,QAAK,gBAAgB,yBAAyB,uBAAuB;;EAG/D,6BAA0B;AAChC,UAAO,KAAK,mBAAmB,KAAK,gBAAgB,SAAS,IACzD,IAAI;;;iBAGK,KAAK,iCACJ,KAAK,iCACL,iBAAiB,KAAK,SAAS,SAAQ;;;;;0BAK/B,KAAK,SAAA;qBACV,KAAK,QAAQ,QAAA;;;;4BAIN,KAAK,SAAA;wBACT,KAAK,iBAAiB,MAAM,MAAM,MAAM,KAAK,SAAS,IAC9D,KAAK,gBAAiB,GAAA;2BACX,MACR,KAAK,WAAW,CAAG,EAAE,OAA4B,MAAA;;kBAElD,OACA,KAAK,kBACJ,YAAY,IAAI,qBAAqB,QAAO,GAAI,QAAO,eACzD,CAAA;;;;YAKT;;EAGE,qBAAkB;AACxB,UAAO,IAAI;;UAEL,OACA,KAAK,uBAAuB,GAC3B,SACC,SAAS,aACL,IAAI;;;;oBAKJ,IAAI;;;uCAGmB,KAAK,cAAc,KAAA;kCACxB,KAAK,SAAA;;mCAEJ,KAAA;oCACC,KAAK,yBACf,KAAK,yBACL,SAAS,KAAK,SAAS,SAAQ,GAAI,OAAO,EAAC;qCAChC,KAAK,cAAc,OAAO,SAAS,QAAA;qCACnC,KAAK,mBAAmB,KAAK,CAAA;;6EAEW,OAAO,EAAC;;;kBAI5E,CAAA;;;;EAKY,kBAAe;AAChC,UAAO,IAAI;;UAGL,KAAK,kBAAkB,UACnB,IAAI;oBACE,KAAK,uBAAuB,CAAA,GAAI,KAAK,oBAAoB,CAAA;;kBAE3D,KAAK,4BAA4B,KACrC,IAAI,GAAG,KAAK,4BAA4B,CAAA;;oBAElC,KAAK,oBAAoB,CAAA,GAAI,KAAK,uBAAuB,CAAA;yBAErE"}
@@ -1,6 +1,6 @@
1
1
  import { SbbPaginatorCommonElementMixin } from "./paginator/common/paginator-common.js";
2
- import { t as SbbCompactPaginatorElement } from "./compact-paginator.component-BSTPWGJx.js";
3
- import { t as SbbPaginatorElement } from "./paginator.component-DT-sZuFS.js";
2
+ import { t as SbbCompactPaginatorElement } from "./compact-paginator.component-BgdCSnNV.js";
3
+ import { t as SbbPaginatorElement } from "./paginator.component-C03vfQ7J.js";
4
4
  import "./paginator.pure.js";
5
5
  //#region src/elements/paginator.ts
6
6
  /** @entrypoint */
@@ -1,4 +1,4 @@
1
1
  import { SbbPaginatorCommonElementMixin } from "./paginator/common/paginator-common.js";
2
- import { t as SbbCompactPaginatorElement } from "./compact-paginator.component-BSTPWGJx.js";
3
- import { t as SbbPaginatorElement } from "./paginator.component-DT-sZuFS.js";
2
+ import { t as SbbCompactPaginatorElement } from "./compact-paginator.component-BgdCSnNV.js";
3
+ import { t as SbbPaginatorElement } from "./paginator.component-C03vfQ7J.js";
4
4
  export { SbbCompactPaginatorElement, SbbPaginatorCommonElementMixin, SbbPaginatorElement };
@@ -1692,6 +1692,19 @@ slot[name=error]::slotted(*) {
1692
1692
  --sbb-options-panel-background-color: var(--sbb-background-color-1);
1693
1693
  --sbb-options-panel-divider-margin-block: var(--sbb-spacing-fixed-3x);
1694
1694
  --sbb-options-panel-padding-block: var(--sbb-spacing-fixed-2x);
1695
+ --sbb-paginator-height: var(--sbb-size-element-m);
1696
+ --sbb-paginator-page-color: var(--sbb-color-metal);
1697
+ --sbb-paginator-page-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));
1698
+ --sbb-paginator-page-border-width: 0;
1699
+ --sbb-paginator-page-cursor: var(--sbb-cursor-pointer);
1700
+ --sbb-paginator-animation-easing: var(--sbb-animation-easing);
1701
+ --sbb-paginator-font-size: var(--sbb-text-font-size-s);
1702
+ --sbb-compact-paginator-height: var(--sbb-size-element-m);
1703
+ --sbb-compact-paginator-color: var(--sbb-color-metal);
1704
+ --sbb-compact-paginator-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));
1705
+ --sbb-compact-paginator-font-size: var(--sbb-text-font-size-m);
1706
+ --sbb-compact-paginator-gap: var(--sbb-spacing-fixed-5x);
1707
+ --sbb-compact-paginator-pages-gap: var(--sbb-spacing-fixed-2x);
1695
1708
  --sbb-popover-arrow-size: var(--sbb-spacing-fixed-4x);
1696
1709
  --sbb-popover-max-width: calc(100% - var(--sbb-spacing-fixed-2x));
1697
1710
  --sbb-popover-border-radius: var(--sbb-border-radius-8x);
package/package.json CHANGED
@@ -1,12 +1,12 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements-dev",
3
- "version": "4.9.0-dev.1774507634",
3
+ "version": "4.9.0-dev.1774514108",
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/e719ede6b528296fc0f36847302124d52a6f5c1c"
9
+ "https://github.com/sbb-design-systems/lyne-components/commit/56e17da2c761c38915b2561b83ec0efa2c6cbb1f"
10
10
  ],
11
11
  "type": "module",
12
12
  "exports": {
@@ -1,2 +1,2 @@
1
- import { t as e } from "../../compact-paginator.component-JM9tD9ys.js";
1
+ import { t as e } from "../../compact-paginator.component-CrdZ6dqt.js";
2
2
  export { e as SbbCompactPaginatorElement };
@@ -1,4 +1,4 @@
1
- import { t as e } from "../compact-paginator.component-JM9tD9ys.js";
1
+ import { t as e } from "../compact-paginator.component-CrdZ6dqt.js";
2
2
  e.define(), console.warn("The entrypoint '@sbb-esta/elements/paginator/compact-paginator.js' has been deprecated.\nUse either '@sbb-esta/elements/paginator.js' or '@sbb-esta/elements/paginator.pure.js' instead.");
3
3
  //#endregion
4
4
  export { e as SbbCompactPaginatorElement };
@@ -1,2 +1,2 @@
1
- import { t as e } from "../../paginator.component-nXF_Zbze.js";
1
+ import { t as e } from "../../paginator.component-BoVsXIBx.js";
2
2
  export { e as SbbPaginatorElement };
@@ -1,4 +1,4 @@
1
- import { t as e } from "../paginator.component-nXF_Zbze.js";
1
+ import { t as e } from "../paginator.component-BoVsXIBx.js";
2
2
  e.define(), console.warn("The entrypoint '@sbb-esta/elements/paginator/paginator.js' has been deprecated.\nUse either '@sbb-esta/elements/paginator.js' or '@sbb-esta/elements/paginator.pure.js' instead.");
3
3
  //#endregion
4
4
  export { e as SbbPaginatorElement };