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

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.
Files changed (32) hide show
  1. package/{compact-paginator.component-JM9tD9ys.js → compact-paginator.component-CrdZ6dqt.js} +2 -4
  2. package/core/styles/core.scss +8 -0
  3. package/core.css +13 -0
  4. package/custom-elements.json +668 -668
  5. package/development/calendar/calendar/calendar.component.js +1 -1
  6. package/development/calendar/calendar.js +1 -1
  7. package/development/{calendar.component-0Pl7qEXL.js → calendar.component-BvJGWtm-.js} +2 -2
  8. package/development/calendar.js +1 -1
  9. package/development/calendar.pure.js +1 -1
  10. package/development/compact-paginator.component-BgdCSnNV.js +86 -0
  11. package/development/paginator/compact-paginator/compact-paginator.component.d.ts.map +1 -1
  12. package/development/paginator/compact-paginator/compact-paginator.component.js +1 -1
  13. package/development/paginator/compact-paginator.js +1 -1
  14. package/development/paginator/paginator/paginator.component.js +1 -1
  15. package/development/paginator/paginator.js +1 -1
  16. package/development/paginator.component-C03vfQ7J.js +470 -0
  17. package/development/paginator.js +2 -2
  18. package/development/paginator.pure.js +2 -2
  19. package/off-brand-theme.css +13 -0
  20. package/package.json +2 -2
  21. package/paginator/compact-paginator/compact-paginator.component.js +1 -1
  22. package/paginator/compact-paginator.js +1 -1
  23. package/paginator/paginator/paginator.component.js +1 -1
  24. package/paginator/paginator.js +1 -1
  25. package/paginator.component-BoVsXIBx.js +206 -0
  26. package/paginator.js +2 -2
  27. package/paginator.pure.js +2 -2
  28. package/safety-theme.css +13 -0
  29. package/standard-theme.css +13 -0
  30. package/development/compact-paginator.component-BSTPWGJx.js +0 -96
  31. package/development/paginator.component-DT-sZuFS.js +0 -492
  32. package/paginator.component-nXF_Zbze.js +0 -206
@@ -1,492 +0,0 @@
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
- display: block;
18
- --sbb-paginator-height: var(--sbb-size-element-m);
19
- --sbb-paginator-page-color: var(--sbb-color-metal);
20
- --sbb-paginator-page-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));
21
- --sbb-paginator-page-background-color: transparent;
22
- --sbb-paginator-page-border-width: 0;
23
- --sbb-paginator-page-border-style: none;
24
- --sbb-paginator-page-border-color: none;
25
- --sbb-paginator-page-cursor: var(--sbb-cursor-pointer);
26
- --sbb-paginator-page-inset: 0;
27
- --sbb-paginator-animation-easing: var(--sbb-animation-easing);
28
- --sbb-paginator-animation-duration: var(
29
- --sbb-disable-animation-duration,
30
- var(--sbb-animation-duration-2x)
31
- );
32
- --sbb-paginator-justify-content: start;
33
- --sbb-paginator-wrapping-group-wrap: wrap-reverse;
34
- --sbb-paginator-wrap: wrap;
35
- }
36
-
37
- :host([size=s]) {
38
- --sbb-paginator-height: var(--sbb-size-element-xs);
39
- }
40
-
41
- :host([negative]) {
42
- --sbb-paginator-page-color: var(--sbb-color-5);
43
- --sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);
44
- }
45
-
46
- :host([pager-position=end]) {
47
- --sbb-paginator-justify-content: end;
48
- --sbb-paginator-wrapping-group-wrap: wrap;
49
- --sbb-paginator-wrap: wrap-reverse;
50
- }
51
-
52
- .sbb-paginator,
53
- .sbb-paginator__wrapping-group {
54
- display: flex;
55
- gap: var(--sbb-spacing-fixed-3x) var(--sbb-spacing-fixed-6x);
56
- justify-content: var(--sbb-paginator-justify-content);
57
- }
58
-
59
- .sbb-paginator {
60
- flex-wrap: var(--sbb-paginator-wrap);
61
- min-height: var(--sbb-paginator-height);
62
- }
63
-
64
- .sbb-paginator__wrapping-group {
65
- flex-wrap: var(--sbb-paginator-wrapping-group-wrap);
66
- }
67
-
68
- .sbb-paginator__page-size-options {
69
- --sbb-text-font-size: var(--sbb-text-font-size-s);
70
- font-family: var(--sbb-typo-font-family);
71
- font-weight: normal;
72
- line-height: var(--sbb-typo-line-height-text);
73
- letter-spacing: var(--sbb-typo-letter-spacing-text);
74
- font-size: var(--sbb-text-font-size);
75
- display: flex;
76
- align-items: center;
77
- gap: var(--sbb-spacing-fixed-2x);
78
- white-space: nowrap;
79
- color: var(--sbb-paginator-page-color);
80
- }
81
- .sbb-paginator__page-size-options sbb-select {
82
- --sbb-text-font-size: var(--sbb-text-font-size-m);
83
- font-family: var(--sbb-typo-font-family);
84
- font-weight: normal;
85
- line-height: var(--sbb-typo-line-height-text);
86
- letter-spacing: var(--sbb-typo-letter-spacing-text);
87
- font-size: var(--sbb-text-font-size);
88
- color: var(--sbb-form-field-text-color);
89
- font-size: var(--sbb-form-field-input-text-size);
90
- padding-inline-end: var(--sbb-form-field-select-inline-padding-end);
91
- }
92
-
93
- .sbb-paginator__pages {
94
- list-style: none;
95
- margin: 0;
96
- padding: 0;
97
- font-size: inherit;
98
- display: flex;
99
- align-items: center;
100
- justify-content: center;
101
- gap: var(--sbb-spacing-fixed-1x);
102
- user-select: none;
103
- -webkit-tap-highlight-color: transparent;
104
- }
105
-
106
- .sbb-paginator__page--ellipsis,
107
- .sbb-paginator__page--number {
108
- --sbb-text-font-size: var(--sbb-text-font-size-s);
109
- font-family: var(--sbb-typo-font-family);
110
- font-weight: normal;
111
- line-height: var(--sbb-typo-line-height-text);
112
- letter-spacing: var(--sbb-typo-letter-spacing-text);
113
- font-size: var(--sbb-text-font-size);
114
- position: relative;
115
- color: var(--sbb-paginator-page-color);
116
- }
117
-
118
- .sbb-paginator__page--ellipsis-item,
119
- .sbb-paginator__page--number-item {
120
- display: flex;
121
- justify-content: center;
122
- align-items: center;
123
- width: var(--sbb-size-element-xxs);
124
- height: var(--sbb-size-element-xxs);
125
- }
126
-
127
- .sbb-paginator__page--number-item {
128
- appearance: none;
129
- box-sizing: border-box;
130
- margin: 0;
131
- outline: none;
132
- border: none;
133
- border-radius: 0;
134
- padding: 0;
135
- background: none;
136
- -webkit-tap-highlight-color: transparent;
137
- color: inherit;
138
- --sbb-text-font-size: var(--sbb-text-font-size-s);
139
- font-family: var(--sbb-typo-font-family);
140
- font-weight: normal;
141
- line-height: var(--sbb-typo-line-height-text);
142
- letter-spacing: var(--sbb-typo-letter-spacing-text);
143
- font-size: var(--sbb-text-font-size);
144
- position: relative;
145
- cursor: var(--sbb-paginator-page-cursor);
146
- outline: none !important;
147
- color: var(--sbb-paginator-page-color);
148
- transition: color var(--sbb-paginator-animation-duration) var(--sbb-paginator-animation-easing);
149
- }
150
- .sbb-paginator__page--number-item::before {
151
- content: "";
152
- position: absolute;
153
- background-color: var(--sbb-paginator-page-background-color);
154
- border: var(--sbb-paginator-page-border-width) var(--sbb-paginator-page-border-style) var(--sbb-paginator-page-border-color);
155
- border-radius: var(--sbb-border-radius-infinity);
156
- inset: var(--sbb-paginator-page-inset);
157
- transition-property: background-color, border, inset;
158
- transition-duration: var(--sbb-paginator-animation-duration);
159
- transition-timing-function: var(--sbb-paginator-animation-easing);
160
- }
161
- .sbb-paginator__page--number-item:focus-visible::before {
162
- outline-offset: var(--sbb-focus-outline-offset);
163
- outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);
164
- outline-offset: var(--sbb-border-width-2x);
165
- }
166
- .sbb-paginator__page--number-item[data-selected] {
167
- font-weight: bold;
168
- --sbb-paginator-page-color: var(--sbb-color-3);
169
- --sbb-paginator-page-border-width: var(--sbb-border-width-2x);
170
- --sbb-paginator-page-border-style: solid;
171
- --sbb-paginator-page-border-color: var(--sbb-border-color-2);
172
- }
173
- :host([negative]) .sbb-paginator__page--number-item[data-selected] {
174
- --sbb-paginator-page-color: var(--sbb-color-3-negative);
175
- --sbb-paginator-page-border-color: var(--sbb-border-color-2-negative);
176
- }
177
- @media (forced-colors: active) {
178
- .sbb-paginator__page--number-item[data-selected] {
179
- --sbb-paginator-page-border-color: Highlight !important;
180
- }
181
- }
182
- .sbb-paginator__page--number-item:disabled {
183
- --sbb-paginator-page-color: var(--sbb-color-5);
184
- --sbb-paginator-page-border-style: dashed;
185
- --sbb-paginator-page-border-color: var(--sbb-border-color-5);
186
- --sbb-paginator-page-background-color: var(--sbb-background-color-3);
187
- --sbb-paginator-page-cursor: var(--sbb-cursor-default);
188
- }
189
- .sbb-paginator__page--number-item:disabled:not([data-selected]) {
190
- --sbb-paginator-page-border-width: var(--sbb-border-width-1x);
191
- }
192
- :host([negative]) .sbb-paginator__page--number-item:disabled {
193
- --sbb-paginator-page-color: var(--sbb-color-5);
194
- --sbb-paginator-page-background-color: var(--sbb-background-color-3-negative);
195
- }
196
- @media (forced-colors: active) {
197
- .sbb-paginator__page--number-item:disabled {
198
- --sbb-paginator-page-border-color: GrayText;
199
- --sbb-paginator-page-color: GrayText;
200
- --sbb-paginator-page-background-color: Canvas;
201
- }
202
- }
203
- @media (any-hover: hover) {
204
- .sbb-paginator__page--number-item:not(:disabled):hover {
205
- --sbb-paginator-page-background-color: var(--sbb-background-color-3);
206
- --sbb-paginator-page-inset: calc(var(--sbb-border-width-2x) * -1);
207
- --sbb-paginator-translate-y-content-hover: -0.0625rem;
208
- }
209
- :host([negative]) .sbb-paginator__page--number-item:not(:disabled):hover {
210
- --sbb-paginator-page-background-color: var(--sbb-background-color-3-negative);
211
- }
212
- }
213
- @media (any-hover: hover) and (forced-colors: active) {
214
- .sbb-paginator__page--number-item:not(:disabled):hover {
215
- --sbb-paginator-page-background-color: Highlight !important;
216
- }
217
- }
218
- .sbb-paginator__page--number-item:not(:disabled):active {
219
- --sbb-paginator-page-color: var(--sbb-color-3);
220
- --sbb-paginator-page-background-color: var(--sbb-background-color-4);
221
- --sbb-paginator-page-inset: 0;
222
- --sbb-paginator-translate-y-content-hover: 0;
223
- }
224
- :host([negative]) .sbb-paginator__page--number-item:not(:disabled):active {
225
- --sbb-paginator-page-color: var(--sbb-color-3-negative);
226
- --sbb-paginator-page-background-color: var(--sbb-background-color-4-negative);
227
- }
228
- @media (forced-colors: active) {
229
- .sbb-paginator__page--number-item:not(:disabled):active {
230
- --sbb-paginator-page-background-color: Highlight !important;
231
- }
232
- }
233
-
234
- .sbb-paginator__page--number-item-label {
235
- transition: transform var(--sbb-paginator-animation-duration) var(--sbb-paginator-animation-easing);
236
- transform: translateY(var(--sbb-paginator-translate-y-content-hover, 0rem));
237
- }
238
-
239
- .sbb-screen-reader-only {
240
- border: 0;
241
- clip-path: rect(0 0 0 0);
242
- height: 1px;
243
- margin: -1px;
244
- overflow: hidden;
245
- padding: 0;
246
- position: absolute;
247
- white-space: nowrap;
248
- width: 1px;
249
- }`;
250
- //#endregion
251
- //#region src/elements/paginator/paginator/paginator.component.ts
252
- var MAX_PAGE_NUMBERS_DISPLAYED = 3;
253
- /**
254
- * It displays a paginator component.
255
- */
256
- var SbbPaginatorElement = (() => {
257
- let _classSuper = SbbPaginatorCommonElementMixin(SbbElement);
258
- let _pageSizeOptions_decorators;
259
- let _pageSizeOptions_initializers = [];
260
- let _pageSizeOptions_extraInitializers = [];
261
- let _pagerPosition_decorators;
262
- let _pagerPosition_initializers = [];
263
- let _pagerPosition_extraInitializers = [];
264
- let _accessibilityItemsPerPageLabel_decorators;
265
- let _accessibilityItemsPerPageLabel_initializers = [];
266
- let _accessibilityItemsPerPageLabel_extraInitializers = [];
267
- return class SbbPaginatorElement extends _classSuper {
268
- constructor() {
269
- super(...arguments);
270
- this.#pageSizeOptions_accessor_storage = __runInitializers(this, _pageSizeOptions_initializers, []);
271
- this.#pagerPosition_accessor_storage = (__runInitializers(this, _pageSizeOptions_extraInitializers), __runInitializers(this, _pagerPosition_initializers, "start"));
272
- this.#accessibilityItemsPerPageLabel_accessor_storage = (__runInitializers(this, _pagerPosition_extraInitializers), __runInitializers(this, _accessibilityItemsPerPageLabel_initializers, ""));
273
- this._markForFocus = (__runInitializers(this, _accessibilityItemsPerPageLabel_extraInitializers), false);
274
- }
275
- static {
276
- const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
277
- _pageSizeOptions_decorators = [property({
278
- attribute: "page-size-options",
279
- type: Array
280
- })];
281
- _pagerPosition_decorators = [property({
282
- attribute: "pager-position",
283
- reflect: true
284
- })];
285
- _accessibilityItemsPerPageLabel_decorators = [forceType(), property({ attribute: "accessibility-items-per-page-label" })];
286
- __esDecorate(this, null, _pageSizeOptions_decorators, {
287
- kind: "accessor",
288
- name: "pageSizeOptions",
289
- static: false,
290
- private: false,
291
- access: {
292
- has: (obj) => "pageSizeOptions" in obj,
293
- get: (obj) => obj.pageSizeOptions,
294
- set: (obj, value) => {
295
- obj.pageSizeOptions = value;
296
- }
297
- },
298
- metadata: _metadata
299
- }, _pageSizeOptions_initializers, _pageSizeOptions_extraInitializers);
300
- __esDecorate(this, null, _pagerPosition_decorators, {
301
- kind: "accessor",
302
- name: "pagerPosition",
303
- static: false,
304
- private: false,
305
- access: {
306
- has: (obj) => "pagerPosition" in obj,
307
- get: (obj) => obj.pagerPosition,
308
- set: (obj, value) => {
309
- obj.pagerPosition = value;
310
- }
311
- },
312
- metadata: _metadata
313
- }, _pagerPosition_initializers, _pagerPosition_extraInitializers);
314
- __esDecorate(this, null, _accessibilityItemsPerPageLabel_decorators, {
315
- kind: "accessor",
316
- name: "accessibilityItemsPerPageLabel",
317
- static: false,
318
- private: false,
319
- access: {
320
- has: (obj) => "accessibilityItemsPerPageLabel" in obj,
321
- get: (obj) => obj.accessibilityItemsPerPageLabel,
322
- set: (obj, value) => {
323
- obj.accessibilityItemsPerPageLabel = value;
324
- }
325
- },
326
- metadata: _metadata
327
- }, _accessibilityItemsPerPageLabel_initializers, _accessibilityItemsPerPageLabel_extraInitializers);
328
- if (_metadata) Object.defineProperty(this, Symbol.metadata, {
329
- enumerable: true,
330
- configurable: true,
331
- writable: true,
332
- value: _metadata
333
- });
334
- }
335
- static {
336
- this.elementName = "sbb-paginator";
337
- }
338
- static {
339
- this.styles = [boxSizingStyles, paginator_default];
340
- }
341
- static {
342
- this.events = { page: "page" };
343
- }
344
- #pageSizeOptions_accessor_storage;
345
- /** The available `pageSize` choices. */
346
- get pageSizeOptions() {
347
- return this.#pageSizeOptions_accessor_storage;
348
- }
349
- set pageSizeOptions(value) {
350
- this.#pageSizeOptions_accessor_storage = value;
351
- }
352
- #pagerPosition_accessor_storage;
353
- /**
354
- * Position of the prev/next buttons: if `pageSizeOptions` is set,
355
- * the sbb-select for the pageSize change will be positioned oppositely, with the page numbers always in the center.
356
- */
357
- get pagerPosition() {
358
- return this.#pagerPosition_accessor_storage;
359
- }
360
- set pagerPosition(value) {
361
- this.#pagerPosition_accessor_storage = value;
362
- }
363
- #accessibilityItemsPerPageLabel_accessor_storage;
364
- /**
365
- * Accessibility label for the items per page. Defaults to `Items per page.`.
366
- * Can be set for cases like a carousel, where `slide` or `image` fits better.
367
- */
368
- get accessibilityItemsPerPageLabel() {
369
- return this.#accessibilityItemsPerPageLabel_accessor_storage;
370
- }
371
- set accessibilityItemsPerPageLabel(value) {
372
- this.#accessibilityItemsPerPageLabel_accessor_storage = value;
373
- }
374
- updated(changedProperties) {
375
- super.updated(changedProperties);
376
- /** Tab navigation can force a rerender when ellipsis elements need to be displayed; the focus must stay on the correct element. */
377
- if (this._markForFocus) {
378
- const focusElement = this._getVisiblePages().find((e) => this.pageIndex === +e.getAttribute("data-index"));
379
- if (focusElement) focusElement.focus();
380
- this._markForFocus = false;
381
- }
382
- }
383
- /** Returns the displayed page elements. */
384
- _getVisiblePages() {
385
- return Array.from(this.shadowRoot.querySelectorAll(".sbb-paginator__page--number-item"));
386
- }
387
- /**
388
- * Calculate the pages set based on the following rules:
389
- * - the first page must always be visible;
390
- * - the last page must always be visible;
391
- * - if there are more than `MAX_PAGE_NUMBERS_DISPLAYED` other pages, ellipsis button must be used.
392
- */
393
- _getVisiblePagesIndex() {
394
- const totalPages = this.numberOfPages();
395
- const currentPageIndex = this.pageIndex;
396
- if (totalPages <= MAX_PAGE_NUMBERS_DISPLAYED + 2) return this._range(totalPages);
397
- else if (currentPageIndex < MAX_PAGE_NUMBERS_DISPLAYED) return [
398
- ...this._range(MAX_PAGE_NUMBERS_DISPLAYED + 1),
399
- "ellipsis",
400
- totalPages - 1
401
- ];
402
- else if (currentPageIndex >= totalPages - MAX_PAGE_NUMBERS_DISPLAYED) return [
403
- 0,
404
- "ellipsis",
405
- ...this._range(MAX_PAGE_NUMBERS_DISPLAYED + 1, totalPages - 1 - MAX_PAGE_NUMBERS_DISPLAYED)
406
- ];
407
- else return [
408
- 0,
409
- "ellipsis",
410
- currentPageIndex - 1,
411
- currentPageIndex,
412
- currentPageIndex + 1,
413
- "ellipsis",
414
- totalPages - 1
415
- ];
416
- }
417
- /** Creates an array of consecutive numbers given the length and the starting value. */
418
- _range(length, offset = 0) {
419
- return Array.from({ length }, (_, k) => k + offset);
420
- }
421
- _onPageNumberClick(index) {
422
- this.selectPage(index);
423
- this._markForFocus = sbbInputModalityDetector.mostRecentModality === "keyboard";
424
- }
425
- _renderItemPerPageTemplate() {
426
- return this.pageSizeOptions && this.pageSizeOptions.length > 0 ? html`
427
- <div class="sbb-paginator__page-size-options">
428
- <label for="select"
429
- >${this.accessibilityItemsPerPageLabel ? this.accessibilityItemsPerPageLabel : i18nItemsPerPage[this.language.current]}</label
430
- >
431
- <sbb-form-field
432
- borderless
433
- width="collapse"
434
- ?negative=${this.negative}
435
- size=${this.size}
436
- >
437
- <sbb-select
438
- id="select"
439
- ?disabled=${this.disabled}
440
- value=${this.pageSizeOptions?.find((e) => e === this.pageSize) ?? this.pageSizeOptions[0]}
441
- @change=${(e) => this.pageSize = +e.target.value}
442
- >
443
- ${repeat(this.pageSizeOptions, (element) => html`<sbb-option value=${element}>${element}</sbb-option>`)}
444
- </sbb-select>
445
- </sbb-form-field>
446
- </div>
447
- ` : nothing;
448
- }
449
- _renderPageNumbers() {
450
- return html`
451
- <ul class="sbb-paginator__pages">
452
- ${repeat(this._getVisiblePagesIndex(), (item) => item === "ellipsis" ? html`
453
- <li class="sbb-paginator__page--ellipsis">
454
- <span class="sbb-paginator__page--ellipsis-item">…</span>
455
- </li>
456
- ` : html`
457
- <li class="sbb-paginator__page--number">
458
- <button
459
- ?data-selected=${this.pageIndex === item}
460
- ?disabled=${this.disabled}
461
- class="sbb-paginator__page--number-item"
462
- data-index=${item}
463
- aria-label="${this.accessibilityPageLabel ? this.accessibilityPageLabel : i18nPage[this.language.current]} ${item + 1}"
464
- aria-current=${this.pageIndex === item ? "true" : nothing}
465
- @click=${() => this._onPageNumberClick(item)}
466
- >
467
- <span class="sbb-paginator__page--number-item-label">${item + 1}</span>
468
- </button>
469
- </li>
470
- `)}
471
- </ul>
472
- `;
473
- }
474
- renderPaginator() {
475
- return html`
476
- <div class="sbb-paginator">
477
- ${this.pagerPosition === "start" ? html`<span class="sbb-paginator__wrapping-group">
478
- ${this.renderPrevNextButtons()} ${this._renderPageNumbers()}
479
- </span>
480
- ${this._renderItemPerPageTemplate()}` : html`${this._renderItemPerPageTemplate()}
481
- <span class="sbb-paginator__wrapping-group">
482
- ${this._renderPageNumbers()} ${this.renderPrevNextButtons()}
483
- </span>`}</span>
484
- </div>
485
- `;
486
- }
487
- };
488
- })();
489
- //#endregion
490
- export { SbbPaginatorElement as t };
491
-
492
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"paginator.component-DT-sZuFS.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  display: block;\n\n  --sbb-paginator-height: var(--sbb-size-element-m);\n  --sbb-paginator-page-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));\n  --sbb-paginator-page-background-color: transparent;\n  --sbb-paginator-page-border-width: 0;\n  --sbb-paginator-page-border-style: none;\n  --sbb-paginator-page-border-color: none;\n  --sbb-paginator-page-cursor: var(--sbb-cursor-pointer);\n  --sbb-paginator-page-inset: 0;\n  --sbb-paginator-animation-easing: var(--sbb-animation-easing);\n  --sbb-paginator-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-2x)\n  );\n  --sbb-paginator-justify-content: start;\n  --sbb-paginator-wrapping-group-wrap: wrap-reverse;\n  --sbb-paginator-wrap: wrap;\n}\n\n:host([size='s']) {\n  --sbb-paginator-height: var(--sbb-size-element-xs);\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);\n}\n\n.sbb-paginator {\n  flex-wrap: var(--sbb-paginator-wrap);\n  min-height: var(--sbb-paginator-height);\n}\n\n.sbb-paginator__wrapping-group {\n  flex-wrap: var(--sbb-paginator-wrapping-group-wrap);\n}\n\n.sbb-paginator__page-size-options {\n  @include sbb.text-s--regular;\n\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\n  // Reapply part of the global form-field css that does not pierce the shadow DOM.\n  sbb-select {\n    @include sbb.text-m--regular;\n\n    color: var(--sbb-form-field-text-color);\n    font-size: var(--sbb-form-field-input-text-size);\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  @include sbb.text-s--regular;\n\n  position: relative;\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  @include sbb.text-s--regular;\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);\n    border: var(--sbb-paginator-page-border-width) var(--sbb-paginator-page-border-style)\n      var(--sbb-paginator-page-border-color);\n    border-radius: var(--sbb-border-radius-infinity);\n    inset: var(--sbb-paginator-page-inset);\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}\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":"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"}