@sbb-esta/lyne-elements 1.11.2 → 1.12.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (51) hide show
  1. package/_index.scss +1 -1
  2. package/core/a11y/focus.d.ts.map +1 -1
  3. package/core/a11y.js +1 -1
  4. package/core/i18n/i18n.d.ts +5 -0
  5. package/core/i18n/i18n.d.ts.map +1 -1
  6. package/core/i18n.js +85 -55
  7. package/core/styles/lists.scss +4 -0
  8. package/core/styles/mixins/lists.scss +128 -76
  9. package/custom-elements.json +774 -76
  10. package/development/core/a11y/focus.d.ts.map +1 -1
  11. package/development/core/a11y.js +2 -2
  12. package/development/core/i18n/i18n.d.ts +5 -0
  13. package/development/core/i18n/i18n.d.ts.map +1 -1
  14. package/development/core/i18n.js +36 -1
  15. package/development/paginator/index.d.ts +2 -0
  16. package/development/paginator/index.d.ts.map +1 -0
  17. package/development/paginator/paginator.d.ts +91 -0
  18. package/development/paginator/paginator.d.ts.map +1 -0
  19. package/development/paginator.d.ts +2 -0
  20. package/development/paginator.d.ts.map +1 -0
  21. package/development/paginator.js +526 -0
  22. package/development/radio-button/radio-button-group/radio-button-group.d.ts +1 -1
  23. package/development/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
  24. package/development/radio-button/radio-button-group.js +16 -12
  25. package/development/select/select.d.ts +6 -0
  26. package/development/select/select.d.ts.map +1 -1
  27. package/development/select.js +22 -2
  28. package/development/slider/slider.d.ts +35 -16
  29. package/development/slider/slider.d.ts.map +1 -1
  30. package/development/slider.js +102 -81
  31. package/index.d.ts +2 -0
  32. package/index.js +2 -0
  33. package/lists.css +102 -36
  34. package/package.json +6 -1
  35. package/paginator/index.d.ts +2 -0
  36. package/paginator/index.d.ts.map +1 -0
  37. package/paginator/paginator.d.ts +91 -0
  38. package/paginator/paginator.d.ts.map +1 -0
  39. package/paginator.d.ts +2 -0
  40. package/paginator.d.ts.map +1 -0
  41. package/paginator.js +263 -0
  42. package/radio-button/radio-button-group/radio-button-group.d.ts +1 -1
  43. package/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
  44. package/radio-button/radio-button-group.js +11 -7
  45. package/select/select.d.ts +6 -0
  46. package/select/select.d.ts.map +1 -1
  47. package/select.js +40 -24
  48. package/slider/slider.d.ts +35 -16
  49. package/slider/slider.d.ts.map +1 -1
  50. package/slider.js +111 -78
  51. package/standard-theme.css +102 -36
@@ -0,0 +1,526 @@
1
+ import { css, LitElement, html, nothing } from "lit";
2
+ import { property, customElement } from "lit/decorators.js";
3
+ import { repeat } from "lit/directives/repeat.js";
4
+ import { sbbInputModalityDetector } from "./core/a11y.js";
5
+ import { SbbLanguageController } from "./core/controllers.js";
6
+ import { hostAttributes } from "./core/decorators.js";
7
+ import { EventEmitter } from "./core/eventing.js";
8
+ import { i18nSelectedPage, i18nPreviousPage, i18nNextPage, i18nItemsPerPage, i18nPage } from "./core/i18n.js";
9
+ import { SbbNegativeMixin } from "./core/mixins.js";
10
+ import "./button/mini-button.js";
11
+ import "./button/mini-button-group.js";
12
+ import "./divider.js";
13
+ import "./form-field.js";
14
+ import "./select.js";
15
+ import "./option.js";
16
+ import "./screen-reader-only.js";
17
+ const style = css`/** This mixin can be used to avoid spacing problems by inserting an invisible space as pseudo element. */
18
+ /*
19
+ * SBB table mixin
20
+ * Notes:
21
+ * We cannot use \`border-collapse\` because it is not compatible with the \`border-radius\` property.
22
+ * Therefore, we have to build the grid avoiding double borders.
23
+ */
24
+ *,
25
+ ::before,
26
+ ::after {
27
+ box-sizing: border-box;
28
+ }
29
+
30
+ :host {
31
+ display: block;
32
+ --sbb-paginator-height: var(--sbb-size-element-m);
33
+ --sbb-paginator-page-color: var(--sbb-color-metal);
34
+ --sbb-paginator-page-background-color: transparent;
35
+ --sbb-paginator-page-border-width: 0;
36
+ --sbb-paginator-page-border-style: none;
37
+ --sbb-paginator-page-border-color: none;
38
+ --sbb-paginator-page-inset: 0;
39
+ --sbb-paginator-animation-easing: var(--sbb-animation-easing);
40
+ --sbb-paginator-animation-duration: var(
41
+ --sbb-disable-animation-zero-time,
42
+ var(--sbb-animation-duration-2x)
43
+ );
44
+ --sbb-paginator-justify-content: start;
45
+ --sbb-paginator-wrapping-group-wrap: wrap-reverse;
46
+ --sbb-paginator-wrap: wrap;
47
+ }
48
+
49
+ :host([size=s]) {
50
+ --sbb-paginator-height: var(--sbb-size-element-xs);
51
+ }
52
+
53
+ :host([negative]) {
54
+ --sbb-paginator-page-color: var(--sbb-color-smoke);
55
+ --sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);
56
+ }
57
+
58
+ :host([pager-position=end]) {
59
+ --sbb-paginator-justify-content: end;
60
+ --sbb-paginator-wrapping-group-wrap: wrap;
61
+ --sbb-paginator-wrap: wrap-reverse;
62
+ }
63
+
64
+ .sbb-paginator,
65
+ .sbb-paginator__wrapping-group {
66
+ display: flex;
67
+ gap: var(--sbb-spacing-fixed-3x) var(--sbb-spacing-fixed-6x);
68
+ justify-content: var(--sbb-paginator-justify-content);
69
+ }
70
+
71
+ .sbb-paginator {
72
+ flex-wrap: var(--sbb-paginator-wrap);
73
+ min-height: var(--sbb-paginator-height);
74
+ }
75
+
76
+ .sbb-paginator__wrapping-group {
77
+ flex-wrap: var(--sbb-paginator-wrapping-group-wrap);
78
+ }
79
+
80
+ .sbb-paginator__page-size-options {
81
+ --sbb-text-font-size: var(--sbb-font-size-text-s);
82
+ font-family: var(--sbb-typo-font-family);
83
+ font-weight: normal;
84
+ line-height: var(--sbb-typo-line-height-body-text);
85
+ letter-spacing: var(--sbb-typo-letter-spacing-body-text);
86
+ font-size: var(--sbb-text-font-size);
87
+ display: flex;
88
+ align-items: center;
89
+ gap: var(--sbb-spacing-fixed-2x);
90
+ white-space: nowrap;
91
+ color: var(--sbb-paginator-page-color);
92
+ }
93
+
94
+ .sbb-paginator__pages {
95
+ list-style: none;
96
+ margin: 0;
97
+ padding: 0;
98
+ font-size: inherit;
99
+ display: flex;
100
+ align-items: center;
101
+ justify-content: center;
102
+ gap: var(--sbb-spacing-fixed-1x);
103
+ user-select: none;
104
+ -webkit-tap-highlight-color: transparent;
105
+ }
106
+
107
+ .sbb-paginator__page--ellipsis,
108
+ .sbb-paginator__page--number {
109
+ --sbb-text-font-size: var(--sbb-font-size-text-s);
110
+ font-family: var(--sbb-typo-font-family);
111
+ font-weight: normal;
112
+ line-height: var(--sbb-typo-line-height-body-text);
113
+ letter-spacing: var(--sbb-typo-letter-spacing-body-text);
114
+ font-size: var(--sbb-text-font-size);
115
+ position: relative;
116
+ color: var(--sbb-paginator-page-color);
117
+ }
118
+
119
+ .sbb-paginator__page--ellipsis-item,
120
+ .sbb-paginator__page--number-item {
121
+ display: flex;
122
+ justify-content: center;
123
+ align-items: center;
124
+ width: var(--sbb-size-element-xxs);
125
+ height: var(--sbb-size-element-xxs);
126
+ }
127
+
128
+ .sbb-paginator__page--number-item {
129
+ -webkit-appearance: none;
130
+ -moz-appearance: none;
131
+ box-sizing: border-box;
132
+ margin: 0;
133
+ outline: none;
134
+ border: none;
135
+ border-radius: 0;
136
+ padding: 0;
137
+ background: none;
138
+ -webkit-tap-highlight-color: transparent;
139
+ color: inherit;
140
+ --sbb-text-font-size: var(--sbb-font-size-text-s);
141
+ font-family: var(--sbb-typo-font-family);
142
+ font-weight: normal;
143
+ line-height: var(--sbb-typo-line-height-body-text);
144
+ letter-spacing: var(--sbb-typo-letter-spacing-body-text);
145
+ font-size: var(--sbb-text-font-size);
146
+ position: relative;
147
+ cursor: pointer;
148
+ outline: none !important;
149
+ color: var(--sbb-paginator-page-color);
150
+ transition: color var(--sbb-paginator-animation-duration) var(--sbb-paginator-animation-easing);
151
+ }
152
+ .sbb-paginator__page--number-item::before {
153
+ content: "";
154
+ position: absolute;
155
+ background-color: var(--sbb-paginator-page-background-color);
156
+ border: var(--sbb-paginator-page-border-width) var(--sbb-paginator-page-border-style) var(--sbb-paginator-page-border-color);
157
+ border-radius: var(--sbb-border-radius-infinity);
158
+ inset: var(--sbb-paginator-page-inset);
159
+ transition-property: background-color, border, inset;
160
+ transition-duration: var(--sbb-paginator-animation-duration);
161
+ transition-timing-function: var(--sbb-paginator-animation-easing);
162
+ }
163
+ .sbb-paginator__page--number-item:focus-visible:not([data-focus-origin=mouse], [data-focus-origin=touch])::before {
164
+ outline-offset: var(--sbb-focus-outline-offset);
165
+ outline: var(--sbb-focus-outline-color) solid var(--sbb-focus-outline-width);
166
+ outline-offset: var(--sbb-border-width-2x);
167
+ }
168
+ .sbb-paginator__page--number-item[data-selected] {
169
+ font-weight: bold;
170
+ --sbb-paginator-page-color: var(--sbb-color-charcoal);
171
+ --sbb-paginator-page-border-width: var(--sbb-border-width-2x);
172
+ --sbb-paginator-page-border-style: solid;
173
+ --sbb-paginator-page-border-color: var(--sbb-color-charcoal);
174
+ }
175
+ :host([negative]) .sbb-paginator__page--number-item[data-selected] {
176
+ --sbb-paginator-page-color: var(--sbb-color-milk);
177
+ --sbb-paginator-page-border-width: var(--sbb-border-width-2x);
178
+ --sbb-paginator-page-border-style: solid;
179
+ --sbb-paginator-page-border-color: var(--sbb-color-white);
180
+ }
181
+ @media (forced-colors: active) {
182
+ .sbb-paginator__page--number-item[data-selected] {
183
+ --sbb-paginator-page-border-color: Highlight !important;
184
+ }
185
+ }
186
+ @media (any-hover: hover) {
187
+ .sbb-paginator__page--number-item:hover {
188
+ --sbb-paginator-page-background-color: var(--sbb-color-milk);
189
+ --sbb-paginator-page-inset: calc(var(--sbb-border-width-2x) * -1);
190
+ --sbb-paginator-translate-y-content-hover: -0.0625rem;
191
+ }
192
+ :host([negative]) .sbb-paginator__page--number-item:hover {
193
+ --sbb-paginator-page-background-color: var(--sbb-color-charcoal);
194
+ }
195
+ }
196
+ @media (any-hover: hover) and (forced-colors: active) {
197
+ .sbb-paginator__page--number-item:hover {
198
+ --sbb-paginator-page-background-color: Highlight !important;
199
+ }
200
+ }
201
+ .sbb-paginator__page--number-item:active {
202
+ --sbb-paginator-page-color: var(--sbb-color-charcoal);
203
+ --sbb-paginator-page-background-color: var(--sbb-color-cloud);
204
+ --sbb-paginator-page-inset: 0;
205
+ --sbb-paginator-translate-y-content-hover: 0;
206
+ }
207
+ :host([negative]) .sbb-paginator__page--number-item:active {
208
+ --sbb-paginator-page-color: var(--sbb-color-milk);
209
+ --sbb-paginator-page-background-color: var(--sbb-color-iron);
210
+ }
211
+ @media (forced-colors: active) {
212
+ .sbb-paginator__page--number-item:active {
213
+ --sbb-paginator-page-background-color: Highlight !important;
214
+ }
215
+ }
216
+
217
+ .sbb-paginator__page--number-item-label {
218
+ transition: transform var(--sbb-paginator-animation-duration) var(--sbb-paginator-animation-easing);
219
+ transform: translateY(var(--sbb-paginator-translate-y-content-hover, 0rem));
220
+ }
221
+
222
+ .sbb-screen-reader-only {
223
+ border: 0;
224
+ clip: rect(0 0 0 0);
225
+ height: 1px;
226
+ margin: -1px;
227
+ overflow: hidden;
228
+ padding: 0;
229
+ position: absolute;
230
+ white-space: nowrap;
231
+ width: 1px;
232
+ }`;
233
+ var __defProp = Object.defineProperty;
234
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
235
+ var __decorateClass = (decorators, target, key, kind) => {
236
+ var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
237
+ for (var i = decorators.length - 1, decorator; i >= 0; i--)
238
+ if (decorator = decorators[i])
239
+ result = (kind ? decorator(target, key, result) : decorator(result)) || result;
240
+ if (kind && result) __defProp(target, key, result);
241
+ return result;
242
+ };
243
+ const MAX_PAGE_NUMBERS_DISPLAYED = 3;
244
+ let nextId = 0;
245
+ let SbbPaginatorElement = class extends SbbNegativeMixin(LitElement) {
246
+ constructor() {
247
+ super(...arguments);
248
+ this._length = 0;
249
+ this._pageSize = 10;
250
+ this._pageIndex = 0;
251
+ this.pagerPosition = "start";
252
+ this.size = "m";
253
+ this._page = new EventEmitter(
254
+ this,
255
+ SbbPaginatorElement.events.page,
256
+ { composed: true, bubbles: true }
257
+ );
258
+ this._paginatorOptionsLabel = `sbb-paginator-options-label-${++nextId}`;
259
+ this._language = new SbbLanguageController(this);
260
+ this._markForFocus = null;
261
+ this._updateSelectAriaLabelledBy = false;
262
+ }
263
+ set length(value) {
264
+ this._length = isNaN(value) || value < 0 ? 0 : value;
265
+ this.pageIndex = this.pageIndex;
266
+ }
267
+ get length() {
268
+ return this._length;
269
+ }
270
+ set pageSize(value) {
271
+ const previousPageSize = this.pageSize;
272
+ this._pageSize = Math.max(value, 0);
273
+ this.pageIndex = Math.floor(this.pageIndex * previousPageSize / this.pageSize) || 0;
274
+ }
275
+ get pageSize() {
276
+ return this._pageSize;
277
+ }
278
+ set pageIndex(value) {
279
+ this._pageIndex = this._coercePageIndexInRange(value);
280
+ }
281
+ get pageIndex() {
282
+ return this._pageIndex;
283
+ }
284
+ set pageSizeOptions(value) {
285
+ this._pageSizeOptions = value;
286
+ this._updateSelectAriaLabelledBy = true;
287
+ }
288
+ get pageSizeOptions() {
289
+ return this._pageSizeOptions;
290
+ }
291
+ updated(changedProperties) {
292
+ super.updated(changedProperties);
293
+ if (this._markForFocus && sbbInputModalityDetector.mostRecentModality === "keyboard") {
294
+ const focusElement = this._getVisiblePages().find(
295
+ (e) => this.pageIndex === +e.getAttribute("data-index")
296
+ );
297
+ if (focusElement) {
298
+ focusElement.focus();
299
+ }
300
+ this._markForFocus = null;
301
+ }
302
+ const select = this.shadowRoot.querySelector("sbb-select");
303
+ if (select && this._updateSelectAriaLabelledBy) {
304
+ select.setAttribute("aria-labelledby", this._paginatorOptionsLabel);
305
+ this._updateSelectAriaLabelledBy = false;
306
+ }
307
+ this.shadowRoot.querySelector("sbb-screen-reader-only").textContent = this._currentPageLabel();
308
+ }
309
+ /**
310
+ * Calculates the current number of pages based on the `length` and the `pageSize`;
311
+ * value must be rounded up (e.g. `length = 21` and `pageSize = 10` means 3 pages).
312
+ */
313
+ _numberOfPages() {
314
+ return this.pageSize ? Math.ceil(this.length / this.pageSize) : 0;
315
+ }
316
+ /**
317
+ * If the `pageSize` changes due to user interaction with the `pageSizeOptions` select,
318
+ * emit the `page` event and then update the `pageSize` value.
319
+ */
320
+ _pageSizeChanged(value) {
321
+ const previousPageSize = this.pageSize;
322
+ const previousPageIndex = this.pageIndex;
323
+ this.pageSize = value;
324
+ if (previousPageSize !== this.pageSize) {
325
+ this._emitPageEvent(previousPageIndex);
326
+ }
327
+ }
328
+ /**
329
+ * If the `pageIndex` changes due to user interaction,
330
+ * emit the `page` event and then update the `pageIndex` value.
331
+ */
332
+ _pageIndexChanged(value) {
333
+ const previousPageIndex = this.pageIndex;
334
+ this.pageIndex = value;
335
+ if (previousPageIndex !== this.pageIndex) {
336
+ this._emitPageEvent(previousPageIndex);
337
+ }
338
+ }
339
+ _emitPageEvent(previousPageIndex) {
340
+ this._page.emit({
341
+ previousPageIndex,
342
+ pageIndex: this.pageIndex,
343
+ length: this.length,
344
+ pageSize: this.pageSize
345
+ });
346
+ }
347
+ /** Returns the displayed page elements. */
348
+ _getVisiblePages() {
349
+ return Array.from(this.shadowRoot.querySelectorAll(".sbb-paginator__page--number-item"));
350
+ }
351
+ /** Evaluate `pageIndex` by excluding edge cases. */
352
+ _coercePageIndexInRange(pageIndex) {
353
+ return Math.max(
354
+ Math.min(Math.max(isNaN(pageIndex) ? 0 : pageIndex, 0), this._numberOfPages() - 1),
355
+ 0
356
+ );
357
+ }
358
+ /**
359
+ * Calculate the pages set based on the following rules:
360
+ * - the first page must always be visible;
361
+ * - the last page must always be visible;
362
+ * - if there are more than `MAX_PAGE_NUMBERS_DISPLAYED` other pages, ellipsis button must be used.
363
+ */
364
+ _getVisiblePagesIndex() {
365
+ const totalPages = this._numberOfPages();
366
+ const currentPageIndex = this.pageIndex;
367
+ if (totalPages <= MAX_PAGE_NUMBERS_DISPLAYED + 2) {
368
+ return this._range(totalPages);
369
+ } else if (currentPageIndex < MAX_PAGE_NUMBERS_DISPLAYED) {
370
+ return [...this._range(MAX_PAGE_NUMBERS_DISPLAYED + 1), "ellipsis", totalPages - 1];
371
+ } else if (currentPageIndex >= totalPages - MAX_PAGE_NUMBERS_DISPLAYED) {
372
+ return [
373
+ 0,
374
+ "ellipsis",
375
+ ...this._range(MAX_PAGE_NUMBERS_DISPLAYED + 1, totalPages - 1 - MAX_PAGE_NUMBERS_DISPLAYED)
376
+ ];
377
+ } else {
378
+ return [
379
+ 0,
380
+ "ellipsis",
381
+ currentPageIndex - 1,
382
+ currentPageIndex,
383
+ currentPageIndex + 1,
384
+ "ellipsis",
385
+ totalPages - 1
386
+ ];
387
+ }
388
+ }
389
+ /** Creates an array of consecutive numbers given the length and the starting value. */
390
+ _range(length, offset = 0) {
391
+ return Array.from({ length }, (_, k) => k + offset);
392
+ }
393
+ _handleKeyUp(event) {
394
+ if (event.key !== " " && event.key !== "Enter") {
395
+ return;
396
+ }
397
+ const current = this._getVisiblePages().find((e) => e === event.target);
398
+ if (current) {
399
+ this._markForFocus = this.pageIndex;
400
+ }
401
+ }
402
+ _currentPageLabel() {
403
+ return i18nSelectedPage(this.pageIndex + 1)[this._language.current];
404
+ }
405
+ _renderPrevNextButtons() {
406
+ return html`
407
+ <sbb-mini-button-group ?negative=${this.negative} size=${this.size === "s" ? "s" : "l"}>
408
+ <sbb-mini-button
409
+ id="sbb-paginator-prev-page"
410
+ aria-label=${i18nPreviousPage[this._language.current]}
411
+ icon-name="chevron-small-left-small"
412
+ ?disabled=${this.pageIndex === 0}
413
+ @click=${() => this._pageIndexChanged(this._pageIndex - 1)}
414
+ ></sbb-mini-button>
415
+ <sbb-divider orientation="vertical"></sbb-divider>
416
+ <sbb-mini-button
417
+ id="sbb-paginator-next-page"
418
+ aria-label=${i18nNextPage[this._language.current]}
419
+ icon-name="chevron-small-right-small"
420
+ ?disabled=${this.pageIndex === this._numberOfPages() - 1}
421
+ @click=${() => this._pageIndexChanged(this._pageIndex + 1)}
422
+ ></sbb-mini-button>
423
+ </sbb-mini-button-group>
424
+ `;
425
+ }
426
+ _renderItemPerPageTemplate() {
427
+ var _a;
428
+ return this.pageSizeOptions && this.pageSizeOptions.length > 0 ? html`
429
+ <div class="sbb-paginator__page-size-options">
430
+ <label id=${this._paginatorOptionsLabel}>
431
+ ${i18nItemsPerPage[this._language.current]}
432
+ </label>
433
+ <sbb-form-field
434
+ borderless
435
+ width="collapse"
436
+ ?negative=${this.negative}
437
+ size=${this.size}
438
+ >
439
+ <sbb-select
440
+ value=${((_a = this.pageSizeOptions) == null ? void 0 : _a.find((e) => e === this.pageSize)) ?? this.pageSizeOptions[0]}
441
+ @change=${(e) => this._pageSizeChanged(+e.target.value)}
442
+ >
443
+ ${repeat(
444
+ this.pageSizeOptions,
445
+ (element) => html`<sbb-option value=${element}>${element}</sbb-option>`
446
+ )}
447
+ </sbb-select>
448
+ </sbb-form-field>
449
+ </div>
450
+ ` : nothing;
451
+ }
452
+ _renderPageNumbers() {
453
+ return html`
454
+ <ul class="sbb-paginator__pages">
455
+ ${repeat(
456
+ this._getVisiblePagesIndex(),
457
+ (item) => item === "ellipsis" ? html`
458
+ <li class="sbb-paginator__page--ellipsis">
459
+ <span class="sbb-paginator__page--ellipsis-item">…</span>
460
+ </li>
461
+ ` : html`
462
+ <li class="sbb-paginator__page--number">
463
+ <button
464
+ ?data-selected=${this.pageIndex === item}
465
+ class="sbb-paginator__page--number-item"
466
+ data-index=${item}
467
+ aria-label="${i18nPage[this._language.current]} ${item + 1}"
468
+ aria-current=${this.pageIndex === item ? "true" : nothing}
469
+ @click=${() => this._pageIndexChanged(item)}
470
+ @keyup=${this._handleKeyUp}
471
+ >
472
+ <span class="sbb-paginator__page--number-item-label">${item + 1}</span>
473
+ </button>
474
+ </li>
475
+ `
476
+ )}
477
+ </ul>
478
+ `;
479
+ }
480
+ render() {
481
+ return html`
482
+ <div class="sbb-paginator">
483
+ ${this.pagerPosition === "start" ? html`<span class="sbb-paginator__wrapping-group">
484
+ ${this._renderPrevNextButtons()} ${this._renderPageNumbers()}
485
+ </span>
486
+ ${this._renderItemPerPageTemplate()}` : html`${this._renderItemPerPageTemplate()}
487
+ <span class="sbb-paginator__wrapping-group">
488
+ ${this._renderPageNumbers()} ${this._renderPrevNextButtons()}
489
+ </span>`}</span>
490
+ </div>
491
+ <sbb-screen-reader-only role='status'></sbb-screen-reader-only>
492
+ `;
493
+ }
494
+ };
495
+ SbbPaginatorElement.styles = style;
496
+ SbbPaginatorElement.events = {
497
+ page: "page"
498
+ };
499
+ __decorateClass([
500
+ property({ type: Number })
501
+ ], SbbPaginatorElement.prototype, "length", 1);
502
+ __decorateClass([
503
+ property({ attribute: "page-size", type: Number })
504
+ ], SbbPaginatorElement.prototype, "pageSize", 1);
505
+ __decorateClass([
506
+ property({ attribute: "page-index", type: Number })
507
+ ], SbbPaginatorElement.prototype, "pageIndex", 1);
508
+ __decorateClass([
509
+ property({ attribute: "page-size-options", type: Array })
510
+ ], SbbPaginatorElement.prototype, "pageSizeOptions", 1);
511
+ __decorateClass([
512
+ property({ attribute: "pager-position", reflect: true })
513
+ ], SbbPaginatorElement.prototype, "pagerPosition", 2);
514
+ __decorateClass([
515
+ property({ reflect: true })
516
+ ], SbbPaginatorElement.prototype, "size", 2);
517
+ SbbPaginatorElement = __decorateClass([
518
+ customElement("sbb-paginator"),
519
+ hostAttributes({
520
+ role: "group"
521
+ })
522
+ ], SbbPaginatorElement);
523
+ export {
524
+ SbbPaginatorElement
525
+ };
526
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"paginator.js","sources":["../../../src/elements/paginator/paginator.ts"],"sourcesContent":["import {\n  type CSSResultGroup,\n  html,\n  LitElement,\n  nothing,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { repeat } from 'lit/directives/repeat.js';\n\nimport { sbbInputModalityDetector } from '../core/a11y.js';\nimport { SbbLanguageController } from '../core/controllers.js';\nimport { hostAttributes } from '../core/decorators.js';\nimport { EventEmitter } from '../core/eventing.js';\nimport {\n  i18nItemsPerPage,\n  i18nNextPage,\n  i18nPage,\n  i18nPreviousPage,\n  i18nSelectedPage,\n} from '../core/i18n.js';\nimport { SbbNegativeMixin } from '../core/mixins.js';\nimport type { SbbSelectElement } from '../select.js';\n\nimport style from './paginator.scss?lit&inline';\n\nimport '../button/mini-button.js';\nimport '../button/mini-button-group.js';\nimport '../divider.js';\nimport '../form-field.js';\nimport '../select.js';\nimport '../option.js';\nimport '../screen-reader-only.js';\n\nexport type SbbPaginatorPageEventDetails = {\n  length: number;\n  pageSize: number;\n  pageIndex: number;\n  previousPageIndex: number;\n};\n\nconst MAX_PAGE_NUMBERS_DISPLAYED = 3;\n\nlet nextId = 0;\n\n/**\n * It displays a paginator component.\n *\n * @event {CustomEvent<SbbPaginatorPageEventDetails>} page - Emits when the pageIndex changes.\n */\n@customElement('sbb-paginator')\n@hostAttributes({\n  role: 'group',\n})\nexport class SbbPaginatorElement extends SbbNegativeMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events: Record<string, string> = {\n    page: 'page',\n  } as const;\n\n  /** Total number of items. */\n  @property({ type: Number })\n  public set length(value: number) {\n    this._length = isNaN(value) || value < 0 ? 0 : value;\n    // Call setter of pageIndex to ensure bounds\n    // eslint-disable-next-line no-self-assign\n    this.pageIndex = this.pageIndex;\n  }\n  public get length(): number {\n    return this._length;\n  }\n  private _length: number = 0;\n\n  /** Number of items per page. */\n  @property({ attribute: 'page-size', type: Number })\n  public set pageSize(value: number) {\n    // Current page needs to be updated to reflect the new page size. Navigate to the page\n    // containing the previous page's first item.\n    const previousPageSize = this.pageSize;\n    this._pageSize = Math.max(value, 0);\n    this.pageIndex = Math.floor((this.pageIndex * previousPageSize) / this.pageSize) || 0;\n  }\n  public get pageSize(): number {\n    return this._pageSize;\n  }\n  private _pageSize: number = 10;\n\n  /** Current page index. */\n  @property({ attribute: 'page-index', type: Number })\n  public set pageIndex(value: number) {\n    this._pageIndex = this._coercePageIndexInRange(value);\n  }\n  public get pageIndex(): number {\n    return this._pageIndex;\n  }\n  private _pageIndex: number = 0;\n\n  /** The available `pageSize` choices. */\n  @property({ attribute: 'page-size-options', type: Array })\n  public set pageSizeOptions(value: number[]) {\n    this._pageSizeOptions = value;\n    this._updateSelectAriaLabelledBy = true;\n  }\n  public get pageSizeOptions(): number[] | undefined {\n    return this._pageSizeOptions;\n  }\n  private _pageSizeOptions?: number[];\n\n  /**\n   * Position of the prev/next buttons: if `pageSizeOptions` is set, the sbb-select for the pageSize change\n   * will be positioned oppositely with the page numbers always in the center.\n   */\n  @property({ attribute: 'pager-position', reflect: true }) public pagerPosition: 'start' | 'end' =\n    'start';\n\n  /** Size variant, either m or s. */\n  @property({ reflect: true }) public size: 'm' | 's' = 'm';\n\n  private _page: EventEmitter<SbbPaginatorPageEventDetails> = new EventEmitter(\n    this,\n    SbbPaginatorElement.events.page,\n    { composed: true, bubbles: true },\n  );\n\n  private _paginatorOptionsLabel = `sbb-paginator-options-label-${++nextId}`;\n  private _language = new SbbLanguageController(this);\n  private _markForFocus: number | null = null;\n  private _updateSelectAriaLabelledBy: boolean = 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 && sbbInputModalityDetector.mostRecentModality === 'keyboard') {\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      // Reset mark for focus\n      this._markForFocus = null;\n    }\n\n    /**\n     * TODO: Accessibility fix required to correctly read the label;\n     * can be possibly removed after the merge of https://github.com/sbb-design-systems/lyne-components/issues/3062\n     */\n    const select = this.shadowRoot!.querySelector('sbb-select');\n    if (select && this._updateSelectAriaLabelledBy) {\n      select.setAttribute('aria-labelledby', this._paginatorOptionsLabel);\n      this._updateSelectAriaLabelledBy = false;\n    }\n\n    // To reliably announce page change, we have to set the label in updated() (a tick later than the other changes).\n    this.shadowRoot!.querySelector('sbb-screen-reader-only')!.textContent =\n      this._currentPageLabel();\n  }\n\n  /**\n   * Calculates the current number of pages based on the `length` and the `pageSize`;\n   * value must be rounded up (e.g. `length = 21` and `pageSize = 10` means 3 pages).\n   */\n  private _numberOfPages(): number {\n    return this.pageSize ? Math.ceil(this.length / this.pageSize) : 0;\n  }\n\n  /**\n   * If the `pageSize` changes due to user interaction with the `pageSizeOptions` select,\n   * emit the `page` event and then update the `pageSize` value.\n   */\n  private _pageSizeChanged(value: number): void {\n    const previousPageSize = this.pageSize;\n    const previousPageIndex = this.pageIndex;\n    this.pageSize = value;\n\n    if (previousPageSize !== this.pageSize) {\n      this._emitPageEvent(previousPageIndex);\n    }\n  }\n\n  /**\n   * If the `pageIndex` changes due to user interaction,\n   * emit the `page` event and then update the `pageIndex` value.\n   */\n  private _pageIndexChanged(value: number): void {\n    const previousPageIndex = this.pageIndex;\n    this.pageIndex = value;\n\n    if (previousPageIndex !== this.pageIndex) {\n      this._emitPageEvent(previousPageIndex);\n    }\n  }\n\n  private _emitPageEvent(previousPageIndex: number): void {\n    this._page.emit({\n      previousPageIndex,\n      pageIndex: this.pageIndex,\n      length: this.length,\n      pageSize: this.pageSize,\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  /** Evaluate `pageIndex` by excluding edge cases. */\n  private _coercePageIndexInRange(pageIndex: number): number {\n    return Math.max(\n      Math.min(Math.max(isNaN(pageIndex) ? 0 : pageIndex, 0), this._numberOfPages() - 1),\n      0,\n    );\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 _handleKeyUp(event: KeyboardEvent): void {\n    if (event.key !== ' ' && event.key !== 'Enter') {\n      return;\n    }\n\n    const current = this._getVisiblePages().find((e: Element) => e === event.target);\n    if (current) {\n      this._markForFocus = this.pageIndex;\n    }\n  }\n\n  private _currentPageLabel(): string {\n    return i18nSelectedPage(this.pageIndex + 1)[this._language.current];\n  }\n\n  private _renderPrevNextButtons(): TemplateResult {\n    return html`\n      <sbb-mini-button-group ?negative=${this.negative} size=${this.size === 's' ? 's' : 'l'}>\n        <sbb-mini-button\n          id=\"sbb-paginator-prev-page\"\n          aria-label=${i18nPreviousPage[this._language.current]}\n          icon-name=\"chevron-small-left-small\"\n          ?disabled=${this.pageIndex === 0}\n          @click=${() => this._pageIndexChanged(this._pageIndex - 1)}\n        ></sbb-mini-button>\n        <sbb-divider orientation=\"vertical\"></sbb-divider>\n        <sbb-mini-button\n          id=\"sbb-paginator-next-page\"\n          aria-label=${i18nNextPage[this._language.current]}\n          icon-name=\"chevron-small-right-small\"\n          ?disabled=${this.pageIndex === this._numberOfPages() - 1}\n          @click=${() => this._pageIndexChanged(this._pageIndex + 1)}\n        ></sbb-mini-button>\n      </sbb-mini-button-group>\n    `;\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 id=${this._paginatorOptionsLabel}>\n              ${i18nItemsPerPage[this._language.current]}\n            </label>\n            <sbb-form-field\n              borderless\n              width=\"collapse\"\n              ?negative=${this.negative}\n              size=${this.size}\n            >\n              <sbb-select\n                value=${this.pageSizeOptions?.find((e) => e === this.pageSize) ??\n                this.pageSizeOptions![0]}\n                @change=${(e: CustomEvent) =>\n                  this._pageSizeChanged(+((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                      class=\"sbb-paginator__page--number-item\"\n                      data-index=${item}\n                      aria-label=\"${i18nPage[this._language.current]} ${item + 1}\"\n                      aria-current=${this.pageIndex === item ? 'true' : nothing}\n                      @click=${() => this._pageIndexChanged(item)}\n                      @keyup=${this._handleKeyUp}\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 render(): 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      <sbb-screen-reader-only role='status'></sbb-screen-reader-only>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-paginator': SbbPaginatorElement;\n  }\n  interface HTMLElementEventMap {\n    page: CustomEvent<SbbPaginatorPageEventDetails>;\n  }\n}\n"],"names":[],"mappings":"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"}
@@ -74,7 +74,7 @@ export declare class SbbRadioButtonGroupElement extends SbbRadioButtonGroupEleme
74
74
  private _valueChanged;
75
75
  protected firstUpdated(changedProperties: PropertyValues<this>): void;
76
76
  disconnectedCallback(): void;
77
- private _onRadioButtonSelect;
77
+ private _onRadioButtonChange;
78
78
  private _emitChange;
79
79
  private _updateRadios;
80
80
  private _setFocusableRadio;
@@ -1 +1 @@
1
- {"version":3,"file":"radio-button-group.d.ts","sourceRoot":"","sources":["../../../../../src/elements/radio-button/radio-button-group/radio-button-group.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAE,UAAU,EAAQ,MAAM,KAAK,CAAC;AAOvC,OAAO,KAAK,EAAE,iBAAiB,EAAE,cAAc,EAAkB,MAAM,0BAA0B,CAAC;AAElG,OAAO,KAAK,EAA6B,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAClF,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,0BAA0B,CAAC;AAC3E,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,oBAAoB,CAAC;AAIhE,MAAM,MAAM,8BAA8B,GAAG;IAC3C,KAAK,EAAE,GAAG,GAAG,IAAI,CAAC;IAClB,WAAW,EAAE,qBAAqB,GAAG,0BAA0B,CAAC;CACjE,CAAC;;AAEF;;;;;;;;GAQG;AACH,qBAKa,0BAA2B,SAAQ,+BAA4B;IAC1E,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;;;MAIlB;IAEX;;OAEG;IAEI,mBAAmB,EAAE,OAAO,CAAS;IAE5C;;OAEG;IACiC,QAAQ,EAAE,OAAO,CAAS;IAE9D;;OAEG;IACgB,KAAK,CAAC,EAAE,GAAG,GAAG,IAAI,CAAC;IAEtC;;OAEG;IACgB,IAAI,EAAE,kBAAkB,CAAO;IAElD;;OAEG;IAEI,cAAc,CAAC,EAAE,iBAAiB,CAAC;IAE1C;;OAEG;IAEI,WAAW,EAAE,cAAc,CAAgB;IAElD;;OAEG;IACH,IAAW,YAAY,IAAI,CAAC,qBAAqB,GAAG,0BAA0B,CAAC,EAAE,CAOhF;IAED,OAAO,KAAK,cAAc,GAIzB;IAED,OAAO,CAAC,kCAAkC,CAAkB;IAC5D,OAAO,CAAC,QAAQ,CAAS;IACzB,OAAO,CAAC,MAAM,CAAyC;IAEvD;;;OAGG;IACH,OAAO,CAAC,UAAU,CAGhB;IAEF;;OAEG;IACH,OAAO,CAAC,OAAO,CAGb;IAEF;;OAEG;IACH,OAAO,CAAC,MAAM,CAGZ;IAEc,iBAAiB,IAAI,IAAI;IAuBzB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAqBzE,OAAO,CAAC,aAAa;cAQF,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAO9D,oBAAoB,IAAI,IAAI;IAI5C,OAAO,CAAC,oBAAoB;IAmB5B,OAAO,CAAC,WAAW;IAMnB,OAAO,CAAC,aAAa;IAiBrB,OAAO,CAAC,kBAAkB;IAS1B,OAAO,CAAC,iBAAiB;IAMzB,OAAO,CAAC,cAAc;cA+BH,MAAM,IAAI,cAAc;CAU5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,wBAAwB,EAAE,0BAA0B,CAAC;KACtD;CACF"}
1
+ {"version":3,"file":"radio-button-group.d.ts","sourceRoot":"","sources":["../../../../../src/elements/radio-button/radio-button-group/radio-button-group.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAE,UAAU,EAAQ,MAAM,KAAK,CAAC;AAOvC,OAAO,KAAK,EAAE,iBAAiB,EAAE,cAAc,EAAkB,MAAM,0BAA0B,CAAC;AAElG,OAAO,KAAK,EAA6B,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAClF,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,0BAA0B,CAAC;AAC3E,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,oBAAoB,CAAC;AAIhE,MAAM,MAAM,8BAA8B,GAAG;IAC3C,KAAK,EAAE,GAAG,GAAG,IAAI,CAAC;IAClB,WAAW,EAAE,qBAAqB,GAAG,0BAA0B,CAAC;CACjE,CAAC;;AAEF;;;;;;;;GAQG;AACH,qBAKa,0BAA2B,SAAQ,+BAA4B;IAC1E,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;;;MAIlB;IAEX;;OAEG;IAEI,mBAAmB,EAAE,OAAO,CAAS;IAE5C;;OAEG;IACiC,QAAQ,EAAE,OAAO,CAAS;IAE9D;;OAEG;IACgB,KAAK,CAAC,EAAE,GAAG,GAAG,IAAI,CAAC;IAEtC;;OAEG;IACgB,IAAI,EAAE,kBAAkB,CAAO;IAElD;;OAEG;IAEI,cAAc,CAAC,EAAE,iBAAiB,CAAC;IAE1C;;OAEG;IAEI,WAAW,EAAE,cAAc,CAAgB;IAElD;;OAEG;IACH,IAAW,YAAY,IAAI,CAAC,qBAAqB,GAAG,0BAA0B,CAAC,EAAE,CAOhF;IAED,OAAO,KAAK,cAAc,GAIzB;IAED,OAAO,CAAC,kCAAkC,CAAkB;IAC5D,OAAO,CAAC,QAAQ,CAAS;IACzB,OAAO,CAAC,MAAM,CAAyC;IAEvD;;;OAGG;IACH,OAAO,CAAC,UAAU,CAGhB;IAEF;;OAEG;IACH,OAAO,CAAC,OAAO,CAGb;IAEF;;OAEG;IACH,OAAO,CAAC,MAAM,CAGZ;IAEc,iBAAiB,IAAI,IAAI;IAuBzB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAqBzE,OAAO,CAAC,aAAa;cAQF,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAO9D,oBAAoB,IAAI,IAAI;IAI5C,OAAO,CAAC,oBAAoB;IAwB5B,OAAO,CAAC,WAAW;IAMnB,OAAO,CAAC,aAAa;IAiBrB,OAAO,CAAC,kBAAkB;IAS1B,OAAO,CAAC,iBAAiB;IAMzB,OAAO,CAAC,cAAc;cA+BH,MAAM,IAAI,cAAc;CAU5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,wBAAwB,EAAE,0BAA0B,CAAC;KACtD;CACF"}