@skyux/lists 9.22.0 → 10.0.0-alpha.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (44) hide show
  1. package/documentation.json +504 -504
  2. package/esm2022/lib/modules/filter/filter-button.component.mjs +5 -5
  3. package/esm2022/lib/modules/filter/filter-inline-item.component.mjs +3 -3
  4. package/esm2022/lib/modules/filter/filter-inline.component.mjs +3 -3
  5. package/esm2022/lib/modules/filter/filter-summary-item.component.mjs +3 -3
  6. package/esm2022/lib/modules/filter/filter-summary.component.mjs +3 -3
  7. package/esm2022/lib/modules/filter/filter.module.mjs +4 -4
  8. package/esm2022/lib/modules/infinite-scroll/infinite-scroll-dom-adapter.service.mjs +5 -5
  9. package/esm2022/lib/modules/infinite-scroll/infinite-scroll.component.mjs +5 -5
  10. package/esm2022/lib/modules/infinite-scroll/infinite-scroll.module.mjs +4 -4
  11. package/esm2022/lib/modules/paging/paging-content.component.mjs +3 -3
  12. package/esm2022/lib/modules/paging/paging.component.mjs +4 -4
  13. package/esm2022/lib/modules/paging/paging.module.mjs +4 -4
  14. package/esm2022/lib/modules/repeater/repeater-adapter.service.mjs +5 -5
  15. package/esm2022/lib/modules/repeater/repeater-auto-scroll.service.mjs +3 -3
  16. package/esm2022/lib/modules/repeater/repeater-item-content.component.mjs +3 -3
  17. package/esm2022/lib/modules/repeater/repeater-item-context-menu.component.mjs +3 -3
  18. package/esm2022/lib/modules/repeater/repeater-item-title.component.mjs +3 -3
  19. package/esm2022/lib/modules/repeater/repeater-item.component.mjs +5 -5
  20. package/esm2022/lib/modules/repeater/repeater.component.mjs +5 -5
  21. package/esm2022/lib/modules/repeater/repeater.module.mjs +4 -4
  22. package/esm2022/lib/modules/repeater/repeater.service.mjs +4 -4
  23. package/esm2022/lib/modules/shared/sky-lists-resources.module.mjs +4 -4
  24. package/esm2022/lib/modules/sort/sort-item.component.mjs +5 -5
  25. package/esm2022/lib/modules/sort/sort-menu-heading.component.mjs +3 -3
  26. package/esm2022/lib/modules/sort/sort.component.mjs +5 -5
  27. package/esm2022/lib/modules/sort/sort.module.mjs +4 -4
  28. package/esm2022/lib/modules/sort/sort.service.mjs +3 -3
  29. package/esm2022/testing/filter/filter-fixture-button.mjs +1 -1
  30. package/esm2022/testing/filter/filter-fixture-summary.mjs +1 -1
  31. package/esm2022/testing/filter/filter-testing.module.mjs +4 -4
  32. package/esm2022/testing/infinite-scroll/infinite-scroll-fixture.mjs +1 -1
  33. package/esm2022/testing/infinite-scroll/infinite-scroll-harness.mjs +1 -1
  34. package/esm2022/testing/infinite-scroll/infinite-scroll-testing.module.mjs +4 -4
  35. package/esm2022/testing/paging/paging-fixture.mjs +1 -1
  36. package/esm2022/testing/paging/paging-testing.module.mjs +4 -4
  37. package/esm2022/testing/repeater/repeater-item-harness.mjs +1 -1
  38. package/esm2022/testing/sort/sort-fixture.mjs +1 -1
  39. package/esm2022/testing/sort/sort-testing.module.mjs +4 -4
  40. package/fesm2022/skyux-lists-testing.mjs +16 -16
  41. package/fesm2022/skyux-lists-testing.mjs.map +1 -1
  42. package/fesm2022/skyux-lists.mjs +95 -95
  43. package/fesm2022/skyux-lists.mjs.map +1 -1
  44. package/package.json +14 -14
@@ -53,13 +53,13 @@ export class SkyFilterButtonComponent {
53
53
  filterButtonOnClick() {
54
54
  this.filterButtonClick.emit();
55
55
  }
56
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyFilterButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
57
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.9", type: SkyFilterButtonComponent, selector: "sky-filter-button", inputs: { filterButtonId: "filterButtonId", ariaControls: "ariaControls", ariaExpanded: "ariaExpanded", ariaLabel: "ariaLabel", active: "active", disabled: "disabled", showButtonText: "showButtonText" }, outputs: { filterButtonClick: "filterButtonClick" }, ngImport: i0, template: "<button\n class=\"sky-btn sky-btn-default sky-filter-btn\"\n type=\"button\"\n [attr.aria-controls]=\"ariaControls\"\n [attr.aria-expanded]=\"ariaExpanded\"\n [attr.aria-label]=\"\n ariaLabel ||\n ((contentInfoObs | async)?.descriptor?.type === 'text'\n ? ('skyux_filter_aria_label_descriptor'\n | skyLibResources : (contentInfoObs | async)?.descriptor?.value)\n : ('skyux_filter_button_title' | skyLibResources))\n \"\n [attr.title]=\"'skyux_filter_button_title' | skyLibResources\"\n [disabled]=\"disabled\"\n [id]=\"filterButtonId\"\n [ngClass]=\"{\n 'sky-filter-btn-active': active\n }\"\n [skyThemeClass]=\"{\n 'sky-rounded-corners': 'default',\n 'sky-theme-modern': 'modern'\n }\"\n (click)=\"filterButtonOnClick()\"\n>\n <sky-icon *skyThemeIf=\"'default'\" icon=\"filter\" size=\"lg\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"filter\" />\n <span *ngIf=\"showButtonText\" class=\"sky-filter-btn-text\">\n {{ 'skyux_filter_button_title' | skyLibResources }}\n </span>\n</button>\n", styles: [".sky-filter-btn-active,.sky-filter-btn-active:hover,.sky-filter-btn-active:focus{color:#72bf44;border:2px solid #72bf44;padding:5px 11px}.sky-filter-btn-active:hover,.sky-filter-btn-active:focus{color:#212327}.sky-theme-modern.sky-filter-btn-active,.sky-theme-modern.sky-filter-btn-active:hover,.sky-theme-modern.sky-filter-btn-active:focus{color:initial;border:none;box-shadow:inset 0 0 0 1px #0974a1;background-color:#c1e8fb;color:#212327;padding:9px 21px}.sky-theme-modern.sky-filter-btn-active:hover,.sky-theme-modern.sky-filter-btn-active:hover:hover,.sky-theme-modern.sky-filter-btn-active:focus:hover{border:none;box-shadow:inset 0 0 0 1px #0974a1;text-decoration:none}.sky-theme-modern.sky-filter-btn-active:hover,.sky-theme-modern.sky-filter-btn-active:active,.sky-theme-modern.sky-filter-btn-active.sky-btn-active,.sky-theme-modern.sky-filter-btn-active:hover:hover,.sky-theme-modern.sky-filter-btn-active:hover:active,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-active,.sky-theme-modern.sky-filter-btn-active:focus:hover,.sky-theme-modern.sky-filter-btn-active:focus:active,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-active{color:#212327}.sky-theme-modern.sky-filter-btn-active:active,.sky-theme-modern.sky-filter-btn-active.sky-btn-active,.sky-theme-modern.sky-filter-btn-active:hover:active,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-active,.sky-theme-modern.sky-filter-btn-active:focus:active,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-active{border:none;box-shadow:inset 0 0 0 2px #0974a1;background-image:none}.sky-theme-modern.sky-filter-btn-active.sky-btn-disabled,.sky-theme-modern.sky-filter-btn-active.sky-btn-disabled:hover,.sky-theme-modern.sky-filter-btn-active.sky-btn-disabled:focus-visible,.sky-theme-modern.sky-filter-btn-active.sky-btn-disabled.sky-btn-focus,.sky-theme-modern.sky-filter-btn-active.sky-btn-disabled:active,.sky-theme-modern.sky-filter-btn-active.sky-btn-disabled.sky-btn-active,.sky-theme-modern.sky-filter-btn-active[disabled],.sky-theme-modern.sky-filter-btn-active[disabled]:hover,.sky-theme-modern.sky-filter-btn-active[disabled]:focus-visible,.sky-theme-modern.sky-filter-btn-active[disabled].sky-btn-focus,.sky-theme-modern.sky-filter-btn-active[disabled]:active,.sky-theme-modern.sky-filter-btn-active[disabled].sky-btn-active,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-disabled,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-disabled:hover,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-disabled:focus-visible,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-disabled.sky-btn-focus,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-disabled:active,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-disabled.sky-btn-active,.sky-theme-modern.sky-filter-btn-active:hover[disabled],.sky-theme-modern.sky-filter-btn-active:hover[disabled]:hover,.sky-theme-modern.sky-filter-btn-active:hover[disabled]:focus-visible,.sky-theme-modern.sky-filter-btn-active:hover[disabled].sky-btn-focus,.sky-theme-modern.sky-filter-btn-active:hover[disabled]:active,.sky-theme-modern.sky-filter-btn-active:hover[disabled].sky-btn-active,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-disabled,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-disabled:hover,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-disabled:focus-visible,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-disabled.sky-btn-focus,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-disabled:active,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-disabled.sky-btn-active,.sky-theme-modern.sky-filter-btn-active:focus[disabled],.sky-theme-modern.sky-filter-btn-active:focus[disabled]:hover,.sky-theme-modern.sky-filter-btn-active:focus[disabled]:focus-visible,.sky-theme-modern.sky-filter-btn-active:focus[disabled].sky-btn-focus,.sky-theme-modern.sky-filter-btn-active:focus[disabled]:active,.sky-theme-modern.sky-filter-btn-active:focus[disabled].sky-btn-active{border:none;box-shadow:inset 0 0 0 1px #d2d2d2;background-color:#ededee;color:#686c73;opacity:1}.sky-theme-modern.sky-filter-btn-active:focus-visible,.sky-theme-modern.sky-filter-btn-active:hover:focus-visible,.sky-theme-modern.sky-filter-btn-active:focus:focus-visible{outline:none}.sky-theme-modern.sky-filter-btn-active:focus-visible:not(:active),.sky-theme-modern.sky-filter-btn-active:hover:focus-visible:not(:active),.sky-theme-modern.sky-filter-btn-active:focus:focus-visible:not(:active){border:none;box-shadow:inset 0 0 0 2px #0974a1,0 1px 8px #0000004d}:host .sky-filter-btn-text{display:none}:host .sky-filter-btn ::ng-deep .sky-dropdown-caret{display:none}:host-context(.sky-responsive-container-xs) .sky-filter-btn-text,:host-context(.sky-responsive-container-sm) .sky-filter-btn-text,:host-context(.sky-responsive-container-md) .sky-filter-btn-text,:host-context(.sky-responsive-container-lg) .sky-filter-btn-text{display:none}:host-context(.sky-responsive-container-xs) .sky-filter-btn ::ng-deep .sky-dropdown-caret,:host-context(.sky-responsive-container-sm) .sky-filter-btn ::ng-deep .sky-dropdown-caret,:host-context(.sky-responsive-container-md) .sky-filter-btn ::ng-deep .sky-dropdown-caret,:host-context(.sky-responsive-container-lg) .sky-filter-btn ::ng-deep .sky-dropdown-caret{display:none}@media (min-width: 768px){:host .sky-filter-btn-text{display:inline}:host .sky-filter-btn ::ng-deep .sky-dropdown-caret{display:inline-block}}:host-context(.sky-responsive-container-sm) .sky-filter-btn-text,:host-context(.sky-responsive-container-md) .sky-filter-btn-text,:host-context(.sky-responsive-container-lg) .sky-filter-btn-text{display:inline}:host-context(.sky-responsive-container-sm) .sky-filter-btn ::ng-deep .sky-dropdown-caret,:host-context(.sky-responsive-container-md) .sky-filter-btn ::ng-deep .sky-dropdown-caret,:host-context(.sky-responsive-container-lg) .sky-filter-btn ::ng-deep .sky-dropdown-caret{display:inline-block}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "directive", type: i3.λ2, selector: "[skyThemeClass]", inputs: ["class", "skyThemeClass"] }, { kind: "directive", type: i3.λ3, selector: "[skyThemeIf]", inputs: ["skyThemeIf"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
56
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyFilterButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
57
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.0", type: SkyFilterButtonComponent, selector: "sky-filter-button", inputs: { filterButtonId: "filterButtonId", ariaControls: "ariaControls", ariaExpanded: "ariaExpanded", ariaLabel: "ariaLabel", active: "active", disabled: "disabled", showButtonText: "showButtonText" }, outputs: { filterButtonClick: "filterButtonClick" }, ngImport: i0, template: "<button\n class=\"sky-btn sky-btn-default sky-filter-btn\"\n type=\"button\"\n [attr.aria-controls]=\"ariaControls\"\n [attr.aria-expanded]=\"ariaExpanded\"\n [attr.aria-label]=\"\n ariaLabel ||\n ((contentInfoObs | async)?.descriptor?.type === 'text'\n ? ('skyux_filter_aria_label_descriptor'\n | skyLibResources : (contentInfoObs | async)?.descriptor?.value)\n : ('skyux_filter_button_title' | skyLibResources))\n \"\n [attr.title]=\"'skyux_filter_button_title' | skyLibResources\"\n [disabled]=\"disabled\"\n [id]=\"filterButtonId\"\n [ngClass]=\"{\n 'sky-filter-btn-active': active\n }\"\n [skyThemeClass]=\"{\n 'sky-rounded-corners': 'default',\n 'sky-theme-modern': 'modern'\n }\"\n (click)=\"filterButtonOnClick()\"\n>\n <sky-icon *skyThemeIf=\"'default'\" icon=\"filter\" size=\"lg\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"filter\" />\n <span *ngIf=\"showButtonText\" class=\"sky-filter-btn-text\">\n {{ 'skyux_filter_button_title' | skyLibResources }}\n </span>\n</button>\n", styles: [".sky-filter-btn-active,.sky-filter-btn-active:hover,.sky-filter-btn-active:focus{color:#72bf44;border:2px solid #72bf44;padding:5px 11px}.sky-filter-btn-active:hover,.sky-filter-btn-active:focus{color:#212327}.sky-theme-modern.sky-filter-btn-active,.sky-theme-modern.sky-filter-btn-active:hover,.sky-theme-modern.sky-filter-btn-active:focus{color:initial;border:none;box-shadow:inset 0 0 0 1px #0974a1;background-color:#c1e8fb;color:#212327;padding:9px 21px}.sky-theme-modern.sky-filter-btn-active:hover,.sky-theme-modern.sky-filter-btn-active:hover:hover,.sky-theme-modern.sky-filter-btn-active:focus:hover{border:none;box-shadow:inset 0 0 0 1px #0974a1;text-decoration:none}.sky-theme-modern.sky-filter-btn-active:hover,.sky-theme-modern.sky-filter-btn-active:active,.sky-theme-modern.sky-filter-btn-active.sky-btn-active,.sky-theme-modern.sky-filter-btn-active:hover:hover,.sky-theme-modern.sky-filter-btn-active:hover:active,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-active,.sky-theme-modern.sky-filter-btn-active:focus:hover,.sky-theme-modern.sky-filter-btn-active:focus:active,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-active{color:#212327}.sky-theme-modern.sky-filter-btn-active:active,.sky-theme-modern.sky-filter-btn-active.sky-btn-active,.sky-theme-modern.sky-filter-btn-active:hover:active,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-active,.sky-theme-modern.sky-filter-btn-active:focus:active,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-active{border:none;box-shadow:inset 0 0 0 2px #0974a1;background-image:none}.sky-theme-modern.sky-filter-btn-active.sky-btn-disabled,.sky-theme-modern.sky-filter-btn-active.sky-btn-disabled:hover,.sky-theme-modern.sky-filter-btn-active.sky-btn-disabled:focus-visible,.sky-theme-modern.sky-filter-btn-active.sky-btn-disabled.sky-btn-focus,.sky-theme-modern.sky-filter-btn-active.sky-btn-disabled:active,.sky-theme-modern.sky-filter-btn-active.sky-btn-disabled.sky-btn-active,.sky-theme-modern.sky-filter-btn-active[disabled],.sky-theme-modern.sky-filter-btn-active[disabled]:hover,.sky-theme-modern.sky-filter-btn-active[disabled]:focus-visible,.sky-theme-modern.sky-filter-btn-active[disabled].sky-btn-focus,.sky-theme-modern.sky-filter-btn-active[disabled]:active,.sky-theme-modern.sky-filter-btn-active[disabled].sky-btn-active,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-disabled,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-disabled:hover,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-disabled:focus-visible,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-disabled.sky-btn-focus,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-disabled:active,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-disabled.sky-btn-active,.sky-theme-modern.sky-filter-btn-active:hover[disabled],.sky-theme-modern.sky-filter-btn-active:hover[disabled]:hover,.sky-theme-modern.sky-filter-btn-active:hover[disabled]:focus-visible,.sky-theme-modern.sky-filter-btn-active:hover[disabled].sky-btn-focus,.sky-theme-modern.sky-filter-btn-active:hover[disabled]:active,.sky-theme-modern.sky-filter-btn-active:hover[disabled].sky-btn-active,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-disabled,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-disabled:hover,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-disabled:focus-visible,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-disabled.sky-btn-focus,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-disabled:active,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-disabled.sky-btn-active,.sky-theme-modern.sky-filter-btn-active:focus[disabled],.sky-theme-modern.sky-filter-btn-active:focus[disabled]:hover,.sky-theme-modern.sky-filter-btn-active:focus[disabled]:focus-visible,.sky-theme-modern.sky-filter-btn-active:focus[disabled].sky-btn-focus,.sky-theme-modern.sky-filter-btn-active:focus[disabled]:active,.sky-theme-modern.sky-filter-btn-active:focus[disabled].sky-btn-active{border:none;box-shadow:inset 0 0 0 1px #d2d2d2;background-color:#ededee;color:#686c73;opacity:1}.sky-theme-modern.sky-filter-btn-active:focus-visible,.sky-theme-modern.sky-filter-btn-active:hover:focus-visible,.sky-theme-modern.sky-filter-btn-active:focus:focus-visible{outline:none}.sky-theme-modern.sky-filter-btn-active:focus-visible:not(:active),.sky-theme-modern.sky-filter-btn-active:hover:focus-visible:not(:active),.sky-theme-modern.sky-filter-btn-active:focus:focus-visible:not(:active){border:none;box-shadow:inset 0 0 0 2px #0974a1,0 1px 8px #0000004d}:host .sky-filter-btn-text{display:none}:host .sky-filter-btn ::ng-deep .sky-dropdown-caret{display:none}:host-context(.sky-responsive-container-xs) .sky-filter-btn-text,:host-context(.sky-responsive-container-sm) .sky-filter-btn-text,:host-context(.sky-responsive-container-md) .sky-filter-btn-text,:host-context(.sky-responsive-container-lg) .sky-filter-btn-text{display:none}:host-context(.sky-responsive-container-xs) .sky-filter-btn ::ng-deep .sky-dropdown-caret,:host-context(.sky-responsive-container-sm) .sky-filter-btn ::ng-deep .sky-dropdown-caret,:host-context(.sky-responsive-container-md) .sky-filter-btn ::ng-deep .sky-dropdown-caret,:host-context(.sky-responsive-container-lg) .sky-filter-btn ::ng-deep .sky-dropdown-caret{display:none}@media (min-width: 768px){:host .sky-filter-btn-text{display:inline}:host .sky-filter-btn ::ng-deep .sky-dropdown-caret{display:inline-block}}:host-context(.sky-responsive-container-sm) .sky-filter-btn-text,:host-context(.sky-responsive-container-md) .sky-filter-btn-text,:host-context(.sky-responsive-container-lg) .sky-filter-btn-text{display:inline}:host-context(.sky-responsive-container-sm) .sky-filter-btn ::ng-deep .sky-dropdown-caret,:host-context(.sky-responsive-container-md) .sky-filter-btn ::ng-deep .sky-dropdown-caret,:host-context(.sky-responsive-container-lg) .sky-filter-btn ::ng-deep .sky-dropdown-caret{display:inline-block}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "directive", type: i3.λ2, selector: "[skyThemeClass]", inputs: ["class", "skyThemeClass"] }, { kind: "directive", type: i3.λ3, selector: "[skyThemeIf]", inputs: ["skyThemeIf"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
58
58
  }
59
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyFilterButtonComponent, decorators: [{
59
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyFilterButtonComponent, decorators: [{
60
60
  type: Component,
61
61
  args: [{ selector: 'sky-filter-button', changeDetection: ChangeDetectionStrategy.OnPush, template: "<button\n class=\"sky-btn sky-btn-default sky-filter-btn\"\n type=\"button\"\n [attr.aria-controls]=\"ariaControls\"\n [attr.aria-expanded]=\"ariaExpanded\"\n [attr.aria-label]=\"\n ariaLabel ||\n ((contentInfoObs | async)?.descriptor?.type === 'text'\n ? ('skyux_filter_aria_label_descriptor'\n | skyLibResources : (contentInfoObs | async)?.descriptor?.value)\n : ('skyux_filter_button_title' | skyLibResources))\n \"\n [attr.title]=\"'skyux_filter_button_title' | skyLibResources\"\n [disabled]=\"disabled\"\n [id]=\"filterButtonId\"\n [ngClass]=\"{\n 'sky-filter-btn-active': active\n }\"\n [skyThemeClass]=\"{\n 'sky-rounded-corners': 'default',\n 'sky-theme-modern': 'modern'\n }\"\n (click)=\"filterButtonOnClick()\"\n>\n <sky-icon *skyThemeIf=\"'default'\" icon=\"filter\" size=\"lg\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"filter\" />\n <span *ngIf=\"showButtonText\" class=\"sky-filter-btn-text\">\n {{ 'skyux_filter_button_title' | skyLibResources }}\n </span>\n</button>\n", styles: [".sky-filter-btn-active,.sky-filter-btn-active:hover,.sky-filter-btn-active:focus{color:#72bf44;border:2px solid #72bf44;padding:5px 11px}.sky-filter-btn-active:hover,.sky-filter-btn-active:focus{color:#212327}.sky-theme-modern.sky-filter-btn-active,.sky-theme-modern.sky-filter-btn-active:hover,.sky-theme-modern.sky-filter-btn-active:focus{color:initial;border:none;box-shadow:inset 0 0 0 1px #0974a1;background-color:#c1e8fb;color:#212327;padding:9px 21px}.sky-theme-modern.sky-filter-btn-active:hover,.sky-theme-modern.sky-filter-btn-active:hover:hover,.sky-theme-modern.sky-filter-btn-active:focus:hover{border:none;box-shadow:inset 0 0 0 1px #0974a1;text-decoration:none}.sky-theme-modern.sky-filter-btn-active:hover,.sky-theme-modern.sky-filter-btn-active:active,.sky-theme-modern.sky-filter-btn-active.sky-btn-active,.sky-theme-modern.sky-filter-btn-active:hover:hover,.sky-theme-modern.sky-filter-btn-active:hover:active,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-active,.sky-theme-modern.sky-filter-btn-active:focus:hover,.sky-theme-modern.sky-filter-btn-active:focus:active,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-active{color:#212327}.sky-theme-modern.sky-filter-btn-active:active,.sky-theme-modern.sky-filter-btn-active.sky-btn-active,.sky-theme-modern.sky-filter-btn-active:hover:active,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-active,.sky-theme-modern.sky-filter-btn-active:focus:active,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-active{border:none;box-shadow:inset 0 0 0 2px #0974a1;background-image:none}.sky-theme-modern.sky-filter-btn-active.sky-btn-disabled,.sky-theme-modern.sky-filter-btn-active.sky-btn-disabled:hover,.sky-theme-modern.sky-filter-btn-active.sky-btn-disabled:focus-visible,.sky-theme-modern.sky-filter-btn-active.sky-btn-disabled.sky-btn-focus,.sky-theme-modern.sky-filter-btn-active.sky-btn-disabled:active,.sky-theme-modern.sky-filter-btn-active.sky-btn-disabled.sky-btn-active,.sky-theme-modern.sky-filter-btn-active[disabled],.sky-theme-modern.sky-filter-btn-active[disabled]:hover,.sky-theme-modern.sky-filter-btn-active[disabled]:focus-visible,.sky-theme-modern.sky-filter-btn-active[disabled].sky-btn-focus,.sky-theme-modern.sky-filter-btn-active[disabled]:active,.sky-theme-modern.sky-filter-btn-active[disabled].sky-btn-active,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-disabled,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-disabled:hover,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-disabled:focus-visible,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-disabled.sky-btn-focus,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-disabled:active,.sky-theme-modern.sky-filter-btn-active:hover.sky-btn-disabled.sky-btn-active,.sky-theme-modern.sky-filter-btn-active:hover[disabled],.sky-theme-modern.sky-filter-btn-active:hover[disabled]:hover,.sky-theme-modern.sky-filter-btn-active:hover[disabled]:focus-visible,.sky-theme-modern.sky-filter-btn-active:hover[disabled].sky-btn-focus,.sky-theme-modern.sky-filter-btn-active:hover[disabled]:active,.sky-theme-modern.sky-filter-btn-active:hover[disabled].sky-btn-active,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-disabled,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-disabled:hover,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-disabled:focus-visible,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-disabled.sky-btn-focus,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-disabled:active,.sky-theme-modern.sky-filter-btn-active:focus.sky-btn-disabled.sky-btn-active,.sky-theme-modern.sky-filter-btn-active:focus[disabled],.sky-theme-modern.sky-filter-btn-active:focus[disabled]:hover,.sky-theme-modern.sky-filter-btn-active:focus[disabled]:focus-visible,.sky-theme-modern.sky-filter-btn-active:focus[disabled].sky-btn-focus,.sky-theme-modern.sky-filter-btn-active:focus[disabled]:active,.sky-theme-modern.sky-filter-btn-active:focus[disabled].sky-btn-active{border:none;box-shadow:inset 0 0 0 1px #d2d2d2;background-color:#ededee;color:#686c73;opacity:1}.sky-theme-modern.sky-filter-btn-active:focus-visible,.sky-theme-modern.sky-filter-btn-active:hover:focus-visible,.sky-theme-modern.sky-filter-btn-active:focus:focus-visible{outline:none}.sky-theme-modern.sky-filter-btn-active:focus-visible:not(:active),.sky-theme-modern.sky-filter-btn-active:hover:focus-visible:not(:active),.sky-theme-modern.sky-filter-btn-active:focus:focus-visible:not(:active){border:none;box-shadow:inset 0 0 0 2px #0974a1,0 1px 8px #0000004d}:host .sky-filter-btn-text{display:none}:host .sky-filter-btn ::ng-deep .sky-dropdown-caret{display:none}:host-context(.sky-responsive-container-xs) .sky-filter-btn-text,:host-context(.sky-responsive-container-sm) .sky-filter-btn-text,:host-context(.sky-responsive-container-md) .sky-filter-btn-text,:host-context(.sky-responsive-container-lg) .sky-filter-btn-text{display:none}:host-context(.sky-responsive-container-xs) .sky-filter-btn ::ng-deep .sky-dropdown-caret,:host-context(.sky-responsive-container-sm) .sky-filter-btn ::ng-deep .sky-dropdown-caret,:host-context(.sky-responsive-container-md) .sky-filter-btn ::ng-deep .sky-dropdown-caret,:host-context(.sky-responsive-container-lg) .sky-filter-btn ::ng-deep .sky-dropdown-caret{display:none}@media (min-width: 768px){:host .sky-filter-btn-text{display:inline}:host .sky-filter-btn ::ng-deep .sky-dropdown-caret{display:inline-block}}:host-context(.sky-responsive-container-sm) .sky-filter-btn-text,:host-context(.sky-responsive-container-md) .sky-filter-btn-text,:host-context(.sky-responsive-container-lg) .sky-filter-btn-text{display:inline}:host-context(.sky-responsive-container-sm) .sky-filter-btn ::ng-deep .sky-dropdown-caret,:host-context(.sky-responsive-container-md) .sky-filter-btn ::ng-deep .sky-dropdown-caret,:host-context(.sky-responsive-container-lg) .sky-filter-btn ::ng-deep .sky-dropdown-caret{display:inline-block}\n"] }]
62
- }], ctorParameters: function () { return []; }, propDecorators: { filterButtonId: [{
62
+ }], ctorParameters: () => [], propDecorators: { filterButtonId: [{
63
63
  type: Input
64
64
  }], ariaControls: [{
65
65
  type: Input
@@ -76,4 +76,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImpor
76
76
  }], filterButtonClick: [{
77
77
  type: Output
78
78
  }] } });
79
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-button.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/lists/src/lib/modules/filter/filter-button.component.ts","../../../../../../../../libs/components/lists/src/lib/modules/filter/filter-button.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,EACN,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAkB,sBAAsB,EAAE,MAAM,aAAa,CAAC;;;;;;AAIrE,IAAI,MAAM,GAAG,CAAC,CAAC;AAQf,MAAM,OAAO,wBAAwB;IACnC;;OAEG;IACH,IACW,cAAc;QACvB,OAAO,IAAI,CAAC,wBAAwB,CAAC;IACvC,CAAC;IACD,IAAW,cAAc,CAAC,KAAyB;QACjD,IAAI,CAAC,wBAAwB,GAAG,KAAK,IAAI,IAAI,CAAC,gBAAgB,CAAC;IACjE,CAAC;IA4DD,oBAAoB,CAAsD;IAE1E;QAlDA;;;;;WAKG;QAEI,iBAAY,GAAwB,KAAK,CAAC;QAajD;;;;WAIG;QAEI,WAAM,GAAwB,KAAK,CAAC;QAE3C;;WAEG;QAEI,aAAQ,GAAwB,KAAK,CAAC;QAE7C;;WAEG;QAEI,mBAAc,GAAwB,KAAK,CAAC;QAEnD;;WAEG;QAEI,sBAAiB,GAAuB,IAAI,YAAY,EAAE,CAAC;QAIlE,yBAAoB,GAAG,MAAM,CAAC,sBAAsB,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QAGxE,IAAI,CAAC,wBAAwB;YAC3B,IAAI,CAAC,gBAAgB,GAAG,qBAAqB,EAAE,MAAM,EAAE,CAAC;QAE1D,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,oBAAoB,EAAE,OAAO,EAAE,CAAC;IAC7D,CAAC;IAED,gBAAgB,CAAS;IACzB,wBAAwB,CAAS;IAE1B,mBAAmB;QACxB,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC;IAChC,CAAC;8GApFU,wBAAwB;kGAAxB,wBAAwB,0TCpBrC,shCA8BA;;2FDVa,wBAAwB;kBANpC,SAAS;+BACE,mBAAmB,mBAGZ,uBAAuB,CAAC,MAAM;0EAOpC,cAAc;sBADxB,KAAK;gBAgBC,YAAY;sBADlB,KAAK;gBAUC,YAAY;sBADlB,KAAK;gBAYC,SAAS;sBADf,KAAK;gBASC,MAAM;sBADZ,KAAK;gBAOC,QAAQ;sBADd,KAAK;gBAOC,cAAc;sBADpB,KAAK;gBAOC,iBAAiB;sBADvB,MAAM","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  inject,\n} from '@angular/core';\nimport { SkyContentInfo, SkyContentInfoProvider } from '@skyux/core';\n\nimport { Observable } from 'rxjs';\n\nlet nextId = 0;\n\n@Component({\n  selector: 'sky-filter-button',\n  styleUrls: ['./filter-button.component.scss'],\n  templateUrl: './filter-button.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyFilterButtonComponent {\n  /**\n   * The ID for the filter button.\n   */\n  @Input()\n  public get filterButtonId(): string {\n    return this.#filterButtonIdOrDefault;\n  }\n  public set filterButtonId(value: string | undefined) {\n    this.#filterButtonIdOrDefault = value || this.#defaultButtonId;\n  }\n\n  /**\n   * The ID to identify the element that contains\n   * the filtering options that the filter button exposes.\n   * To support [accessibility rules for disclosures](https://www.w3.org/TR/wai-aria-practices-1.1/#disclosure),\n   * this property is necessary to set the `aria-controls` attribute when using inline filters.\n   * For more information about the `aria-controls` attribute, see the [WAI-ARIA definition](https://www.w3.org/TR/wai-aria/#aria-controls).\n   */\n  @Input()\n  public ariaControls: string | undefined;\n\n  /**\n   * Whether the filtering options are exposed.\n   * To support [accessibility rules for disclosures](https://www.w3.org/TR/wai-aria-practices-1.1/#disclosure),\n   * this property is necessary to set the `aria-expanded` attribute when using inline filters.\n   * For more information about the `aria-expanded` attribute, see the [WAI-ARIA definition](https://www.w3.org/TR/wai-aria/#aria-expanded).\n   */\n  @Input()\n  public ariaExpanded: boolean | undefined = false;\n\n  /**\n   * The ARIA label for the filter button. This sets the\n   * filter button's `aria-label` attribute to provide a text equivalent for screen readers\n   * [to support accessibility](https://developer.blackbaud.com/skyux/learn/accessibility).\n   * Use a context-sensitive label, such as \"Filter constituents.\" Context is especially important when multiple filter buttons are in close proximity.\n   * In toolbars, filter buttons use the `listDescriptor` to provide context, and the ARIA label defaults to \"Filter <listDescriptor>.\"\n   * For more information about the `aria-label` attribute, see the [WAI-ARIA definition](https://www.w3.org/TR/wai-aria/#aria-label).\n   */\n  @Input()\n  public ariaLabel: string | undefined;\n\n  /**\n   * Whether to highlight the filter button to indicate that filters were applied.\n   * We recommend setting this property to `true` when no indication of filtering is visible\n   * to users. For example, set it to `true` if you do not display the filter summary.\n   */\n  @Input()\n  public active: boolean | undefined = false;\n\n  /**\n   * Whether to disable the filter button.\n   */\n  @Input()\n  public disabled: boolean | undefined = false;\n\n  /**\n   * Whether to display a \"Filter\" label beside the icon on the filter button.\n   */\n  @Input()\n  public showButtonText: boolean | undefined = false;\n\n  /**\n   * Fires when the filter button is selected.\n   */\n  @Output()\n  public filterButtonClick: EventEmitter<void> = new EventEmitter();\n\n  protected contentInfoObs: Observable<SkyContentInfo> | undefined;\n\n  #contentInfoProvider = inject(SkyContentInfoProvider, { optional: true });\n\n  constructor() {\n    this.#filterButtonIdOrDefault =\n      this.#defaultButtonId = `sky-filter-button-${++nextId}`;\n\n    this.contentInfoObs = this.#contentInfoProvider?.getInfo();\n  }\n\n  #defaultButtonId: string;\n  #filterButtonIdOrDefault: string;\n\n  public filterButtonOnClick(): void {\n    this.filterButtonClick.emit();\n  }\n}\n","<button\n  class=\"sky-btn sky-btn-default sky-filter-btn\"\n  type=\"button\"\n  [attr.aria-controls]=\"ariaControls\"\n  [attr.aria-expanded]=\"ariaExpanded\"\n  [attr.aria-label]=\"\n    ariaLabel ||\n    ((contentInfoObs | async)?.descriptor?.type === 'text'\n      ? ('skyux_filter_aria_label_descriptor'\n        | skyLibResources : (contentInfoObs | async)?.descriptor?.value)\n      : ('skyux_filter_button_title' | skyLibResources))\n  \"\n  [attr.title]=\"'skyux_filter_button_title' | skyLibResources\"\n  [disabled]=\"disabled\"\n  [id]=\"filterButtonId\"\n  [ngClass]=\"{\n    'sky-filter-btn-active': active\n  }\"\n  [skyThemeClass]=\"{\n    'sky-rounded-corners': 'default',\n    'sky-theme-modern': 'modern'\n  }\"\n  (click)=\"filterButtonOnClick()\"\n>\n  <sky-icon *skyThemeIf=\"'default'\" icon=\"filter\" size=\"lg\" />\n  <sky-icon *skyThemeIf=\"'modern'\" icon=\"filter\" />\n  <span *ngIf=\"showButtonText\" class=\"sky-filter-btn-text\">\n    {{ 'skyux_filter_button_title' | skyLibResources }}\n  </span>\n</button>\n"]}
79
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-button.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/lists/src/lib/modules/filter/filter-button.component.ts","../../../../../../../../libs/components/lists/src/lib/modules/filter/filter-button.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,EACN,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAkB,sBAAsB,EAAE,MAAM,aAAa,CAAC;;;;;;AAIrE,IAAI,MAAM,GAAG,CAAC,CAAC;AAQf,MAAM,OAAO,wBAAwB;IACnC;;OAEG;IACH,IACW,cAAc;QACvB,OAAO,IAAI,CAAC,wBAAwB,CAAC;IACvC,CAAC;IACD,IAAW,cAAc,CAAC,KAAyB;QACjD,IAAI,CAAC,wBAAwB,GAAG,KAAK,IAAI,IAAI,CAAC,gBAAgB,CAAC;IACjE,CAAC;IA4DD,oBAAoB,CAAsD;IAE1E;QAlDA;;;;;WAKG;QAEI,iBAAY,GAAwB,KAAK,CAAC;QAajD;;;;WAIG;QAEI,WAAM,GAAwB,KAAK,CAAC;QAE3C;;WAEG;QAEI,aAAQ,GAAwB,KAAK,CAAC;QAE7C;;WAEG;QAEI,mBAAc,GAAwB,KAAK,CAAC;QAEnD;;WAEG;QAEI,sBAAiB,GAAuB,IAAI,YAAY,EAAE,CAAC;QAIlE,yBAAoB,GAAG,MAAM,CAAC,sBAAsB,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QAGxE,IAAI,CAAC,wBAAwB;YAC3B,IAAI,CAAC,gBAAgB,GAAG,qBAAqB,EAAE,MAAM,EAAE,CAAC;QAE1D,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,oBAAoB,EAAE,OAAO,EAAE,CAAC;IAC7D,CAAC;IAED,gBAAgB,CAAS;IACzB,wBAAwB,CAAS;IAE1B,mBAAmB;QACxB,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC;IAChC,CAAC;8GApFU,wBAAwB;kGAAxB,wBAAwB,0TCpBrC,shCA8BA;;2FDVa,wBAAwB;kBANpC,SAAS;+BACE,mBAAmB,mBAGZ,uBAAuB,CAAC,MAAM;wDAOpC,cAAc;sBADxB,KAAK;gBAgBC,YAAY;sBADlB,KAAK;gBAUC,YAAY;sBADlB,KAAK;gBAYC,SAAS;sBADf,KAAK;gBASC,MAAM;sBADZ,KAAK;gBAOC,QAAQ;sBADd,KAAK;gBAOC,cAAc;sBADpB,KAAK;gBAOC,iBAAiB;sBADvB,MAAM","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  inject,\n} from '@angular/core';\nimport { SkyContentInfo, SkyContentInfoProvider } from '@skyux/core';\n\nimport { Observable } from 'rxjs';\n\nlet nextId = 0;\n\n@Component({\n  selector: 'sky-filter-button',\n  styleUrls: ['./filter-button.component.scss'],\n  templateUrl: './filter-button.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyFilterButtonComponent {\n  /**\n   * The ID for the filter button.\n   */\n  @Input()\n  public get filterButtonId(): string {\n    return this.#filterButtonIdOrDefault;\n  }\n  public set filterButtonId(value: string | undefined) {\n    this.#filterButtonIdOrDefault = value || this.#defaultButtonId;\n  }\n\n  /**\n   * The ID to identify the element that contains\n   * the filtering options that the filter button exposes.\n   * To support [accessibility rules for disclosures](https://www.w3.org/TR/wai-aria-practices-1.1/#disclosure),\n   * this property is necessary to set the `aria-controls` attribute when using inline filters.\n   * For more information about the `aria-controls` attribute, see the [WAI-ARIA definition](https://www.w3.org/TR/wai-aria/#aria-controls).\n   */\n  @Input()\n  public ariaControls: string | undefined;\n\n  /**\n   * Whether the filtering options are exposed.\n   * To support [accessibility rules for disclosures](https://www.w3.org/TR/wai-aria-practices-1.1/#disclosure),\n   * this property is necessary to set the `aria-expanded` attribute when using inline filters.\n   * For more information about the `aria-expanded` attribute, see the [WAI-ARIA definition](https://www.w3.org/TR/wai-aria/#aria-expanded).\n   */\n  @Input()\n  public ariaExpanded: boolean | undefined = false;\n\n  /**\n   * The ARIA label for the filter button. This sets the\n   * filter button's `aria-label` attribute to provide a text equivalent for screen readers\n   * [to support accessibility](https://developer.blackbaud.com/skyux/learn/accessibility).\n   * Use a context-sensitive label, such as \"Filter constituents.\" Context is especially important when multiple filter buttons are in close proximity.\n   * In toolbars, filter buttons use the `listDescriptor` to provide context, and the ARIA label defaults to \"Filter <listDescriptor>.\"\n   * For more information about the `aria-label` attribute, see the [WAI-ARIA definition](https://www.w3.org/TR/wai-aria/#aria-label).\n   */\n  @Input()\n  public ariaLabel: string | undefined;\n\n  /**\n   * Whether to highlight the filter button to indicate that filters were applied.\n   * We recommend setting this property to `true` when no indication of filtering is visible\n   * to users. For example, set it to `true` if you do not display the filter summary.\n   */\n  @Input()\n  public active: boolean | undefined = false;\n\n  /**\n   * Whether to disable the filter button.\n   */\n  @Input()\n  public disabled: boolean | undefined = false;\n\n  /**\n   * Whether to display a \"Filter\" label beside the icon on the filter button.\n   */\n  @Input()\n  public showButtonText: boolean | undefined = false;\n\n  /**\n   * Fires when the filter button is selected.\n   */\n  @Output()\n  public filterButtonClick: EventEmitter<void> = new EventEmitter();\n\n  protected contentInfoObs: Observable<SkyContentInfo> | undefined;\n\n  #contentInfoProvider = inject(SkyContentInfoProvider, { optional: true });\n\n  constructor() {\n    this.#filterButtonIdOrDefault =\n      this.#defaultButtonId = `sky-filter-button-${++nextId}`;\n\n    this.contentInfoObs = this.#contentInfoProvider?.getInfo();\n  }\n\n  #defaultButtonId: string;\n  #filterButtonIdOrDefault: string;\n\n  public filterButtonOnClick(): void {\n    this.filterButtonClick.emit();\n  }\n}\n","<button\n  class=\"sky-btn sky-btn-default sky-filter-btn\"\n  type=\"button\"\n  [attr.aria-controls]=\"ariaControls\"\n  [attr.aria-expanded]=\"ariaExpanded\"\n  [attr.aria-label]=\"\n    ariaLabel ||\n    ((contentInfoObs | async)?.descriptor?.type === 'text'\n      ? ('skyux_filter_aria_label_descriptor'\n        | skyLibResources : (contentInfoObs | async)?.descriptor?.value)\n      : ('skyux_filter_button_title' | skyLibResources))\n  \"\n  [attr.title]=\"'skyux_filter_button_title' | skyLibResources\"\n  [disabled]=\"disabled\"\n  [id]=\"filterButtonId\"\n  [ngClass]=\"{\n    'sky-filter-btn-active': active\n  }\"\n  [skyThemeClass]=\"{\n    'sky-rounded-corners': 'default',\n    'sky-theme-modern': 'modern'\n  }\"\n  (click)=\"filterButtonOnClick()\"\n>\n  <sky-icon *skyThemeIf=\"'default'\" icon=\"filter\" size=\"lg\" />\n  <sky-icon *skyThemeIf=\"'modern'\" icon=\"filter\" />\n  <span *ngIf=\"showButtonText\" class=\"sky-filter-btn-text\">\n    {{ 'skyux_filter_button_title' | skyLibResources }}\n  </span>\n</button>\n"]}
@@ -4,10 +4,10 @@ import * as i0 from "@angular/core";
4
4
  * Specifies an inline filter.
5
5
  */
6
6
  export class SkyFilterInlineItemComponent {
7
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyFilterInlineItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
8
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.9", type: SkyFilterInlineItemComponent, selector: "sky-filter-inline-item", ngImport: i0, template: "<div class=\"sky-filter-inline-item\">\n <ng-content />\n</div>\n", styles: [".sky-filter-inline-item{margin-right:10px}\n"] }); }
7
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyFilterInlineItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
8
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.0", type: SkyFilterInlineItemComponent, selector: "sky-filter-inline-item", ngImport: i0, template: "<div class=\"sky-filter-inline-item\">\n <ng-content />\n</div>\n", styles: [".sky-filter-inline-item{margin-right:10px}\n"] }); }
9
9
  }
10
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyFilterInlineItemComponent, decorators: [{
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyFilterInlineItemComponent, decorators: [{
11
11
  type: Component,
12
12
  args: [{ selector: 'sky-filter-inline-item', template: "<div class=\"sky-filter-inline-item\">\n <ng-content />\n</div>\n", styles: [".sky-filter-inline-item{margin-right:10px}\n"] }]
13
13
  }] });
@@ -4,10 +4,10 @@ import * as i0 from "@angular/core";
4
4
  * Specifies a wrapper for the inline filters.
5
5
  */
6
6
  export class SkyFilterInlineComponent {
7
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyFilterInlineComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
8
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.9", type: SkyFilterInlineComponent, selector: "sky-filter-inline", ngImport: i0, template: "<div class=\"sky-filter-inline sky-padding-even-default\">\n <ng-content />\n</div>\n", styles: [".sky-filter-inline{background-color:#eeeeef;display:flex;align-items:center}\n"] }); }
7
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyFilterInlineComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
8
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.0", type: SkyFilterInlineComponent, selector: "sky-filter-inline", ngImport: i0, template: "<div class=\"sky-filter-inline sky-padding-even-default\">\n <ng-content />\n</div>\n", styles: [".sky-filter-inline{background-color:#eeeeef;display:flex;align-items:center}\n"] }); }
9
9
  }
10
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyFilterInlineComponent, decorators: [{
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyFilterInlineComponent, decorators: [{
11
11
  type: Component,
12
12
  args: [{ selector: 'sky-filter-inline', template: "<div class=\"sky-filter-inline sky-padding-even-default\">\n <ng-content />\n</div>\n", styles: [".sky-filter-inline{background-color:#eeeeef;display:flex;align-items:center}\n"] }]
13
13
  }] });
@@ -36,10 +36,10 @@ export class SkyFilterSummaryItemComponent {
36
36
  onItemKeypress() {
37
37
  this.itemClick.emit();
38
38
  }
39
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyFilterSummaryItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
40
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.9", type: SkyFilterSummaryItemComponent, selector: "sky-filter-summary-item", inputs: { dismissible: "dismissible" }, outputs: { dismiss: "dismiss", itemClick: "itemClick" }, ngImport: i0, template: "<div\n class=\"sky-filter-summary-item\"\n (click)=\"onItemClick()\"\n (keypress.enter)=\"onItemKeypress()\"\n>\n <sky-token\n [ariaLabel]=\"'skyux_filter_summary_close' | skyLibResources\"\n [dismissible]=\"dismissible\"\n (dismiss)=\"onItemDismiss()\"\n >\n <ng-content />\n </sky-token>\n</div>\n", styles: [".sky-filter-summary-item{display:inline-block}:host:not(:last-child){margin-right:5px}:host-context(.sky-theme-modern) .sky-filter-summary-item{padding:0 0 5px}.sky-theme-modern .sky-filter-summary-item{padding:0 0 5px}\n"], dependencies: [{ kind: "component", type: i1.λ12, selector: "sky-token", inputs: ["disabled", "ariaLabel", "dismissible", "focusable", "role"], outputs: ["dismiss", "tokenFocus"] }, { kind: "pipe", type: i2.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
39
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyFilterSummaryItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
40
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.0", type: SkyFilterSummaryItemComponent, selector: "sky-filter-summary-item", inputs: { dismissible: "dismissible" }, outputs: { dismiss: "dismiss", itemClick: "itemClick" }, ngImport: i0, template: "<div\n class=\"sky-filter-summary-item\"\n (click)=\"onItemClick()\"\n (keypress.enter)=\"onItemKeypress()\"\n>\n <sky-token\n [ariaLabel]=\"'skyux_filter_summary_close' | skyLibResources\"\n [dismissible]=\"dismissible\"\n (dismiss)=\"onItemDismiss()\"\n >\n <ng-content />\n </sky-token>\n</div>\n", styles: [".sky-filter-summary-item{display:inline-block}:host:not(:last-child){margin-right:5px}:host-context(.sky-theme-modern) .sky-filter-summary-item{padding:0 0 5px}.sky-theme-modern .sky-filter-summary-item{padding:0 0 5px}\n"], dependencies: [{ kind: "component", type: i1.λ12, selector: "sky-token", inputs: ["disabled", "ariaLabel", "dismissible", "focusable", "role"], outputs: ["dismiss", "tokenFocus"] }, { kind: "pipe", type: i2.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
41
41
  }
42
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyFilterSummaryItemComponent, decorators: [{
42
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyFilterSummaryItemComponent, decorators: [{
43
43
  type: Component,
44
44
  args: [{ selector: 'sky-filter-summary-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"sky-filter-summary-item\"\n (click)=\"onItemClick()\"\n (keypress.enter)=\"onItemKeypress()\"\n>\n <sky-token\n [ariaLabel]=\"'skyux_filter_summary_close' | skyLibResources\"\n [dismissible]=\"dismissible\"\n (dismiss)=\"onItemDismiss()\"\n >\n <ng-content />\n </sky-token>\n</div>\n", styles: [".sky-filter-summary-item{display:inline-block}:host:not(:last-child){margin-right:5px}:host-context(.sky-theme-modern) .sky-filter-summary-item{padding:0 0 5px}.sky-theme-modern .sky-filter-summary-item{padding:0 0 5px}\n"] }]
45
45
  }], propDecorators: { dismissible: [{
@@ -5,10 +5,10 @@ import * as i1 from "@skyux/i18n";
5
5
  * Specifies a wrapper for the filters that were applied.
6
6
  */
7
7
  export class SkyFilterSummaryComponent {
8
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyFilterSummaryComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
9
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.9", type: SkyFilterSummaryComponent, selector: "sky-filter-summary", ngImport: i0, template: "<div class=\"sky-filter-summary\">\n <span class=\"sky-filter-summary-header\"\n >{{ 'skyux_filter_summary_header' | skyLibResources }}:</span\n >\n <div class=\"sky-filter-summary-items\">\n <ng-content />\n </div>\n</div>\n", styles: [".sky-filter-summary-header{margin:5px 10px 0 0;font-weight:600}.sky-filter-summary{background-color:#fff;overflow-x:auto;display:flex;align-items:flex-start}.sky-filter-summary-items{display:flex;flex-wrap:wrap}:host-context(.sky-theme-modern) .sky-filter-summary-header{margin:0 10px 0 0}.sky-theme-modern .sky-filter-summary-header{margin:0 10px 0 0}\n"], dependencies: [{ kind: "pipe", type: i1.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
8
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyFilterSummaryComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
9
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.0", type: SkyFilterSummaryComponent, selector: "sky-filter-summary", ngImport: i0, template: "<div class=\"sky-filter-summary\">\n <span class=\"sky-filter-summary-header\"\n >{{ 'skyux_filter_summary_header' | skyLibResources }}:</span\n >\n <div class=\"sky-filter-summary-items\">\n <ng-content />\n </div>\n</div>\n", styles: [".sky-filter-summary-header{margin:5px 10px 0 0;font-weight:600}.sky-filter-summary{background-color:#fff;overflow-x:auto;display:flex;align-items:flex-start}.sky-filter-summary-items{display:flex;flex-wrap:wrap}:host-context(.sky-theme-modern) .sky-filter-summary-header{margin:0 10px 0 0}.sky-theme-modern .sky-filter-summary-header{margin:0 10px 0 0}\n"], dependencies: [{ kind: "pipe", type: i1.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
10
10
  }
11
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyFilterSummaryComponent, decorators: [{
11
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyFilterSummaryComponent, decorators: [{
12
12
  type: Component,
13
13
  args: [{ selector: 'sky-filter-summary', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"sky-filter-summary\">\n <span class=\"sky-filter-summary-header\"\n >{{ 'skyux_filter_summary_header' | skyLibResources }}:</span\n >\n <div class=\"sky-filter-summary-items\">\n <ng-content />\n </div>\n</div>\n", styles: [".sky-filter-summary-header{margin:5px 10px 0 0;font-weight:600}.sky-filter-summary{background-color:#fff;overflow-x:auto;display:flex;align-items:flex-start}.sky-filter-summary-items{display:flex;flex-wrap:wrap}:host-context(.sky-theme-modern) .sky-filter-summary-header{margin:0 10px 0 0}.sky-theme-modern .sky-filter-summary-header{margin:0 10px 0 0}\n"] }]
14
14
  }] });
@@ -10,8 +10,8 @@ import { SkyFilterSummaryItemComponent } from './filter-summary-item.component';
10
10
  import { SkyFilterSummaryComponent } from './filter-summary.component';
11
11
  import * as i0 from "@angular/core";
12
12
  export class SkyFilterModule {
13
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyFilterModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
14
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.9", ngImport: i0, type: SkyFilterModule, declarations: [SkyFilterButtonComponent,
13
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyFilterModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
14
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.1.0", ngImport: i0, type: SkyFilterModule, declarations: [SkyFilterButtonComponent,
15
15
  SkyFilterInlineComponent,
16
16
  SkyFilterInlineItemComponent,
17
17
  SkyFilterSummaryComponent,
@@ -24,13 +24,13 @@ export class SkyFilterModule {
24
24
  SkyFilterInlineItemComponent,
25
25
  SkyFilterSummaryComponent,
26
26
  SkyFilterSummaryItemComponent] }); }
27
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyFilterModule, imports: [CommonModule,
27
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyFilterModule, imports: [CommonModule,
28
28
  SkyIconModule,
29
29
  SkyListsResourcesModule,
30
30
  SkyTokensModule,
31
31
  SkyThemeModule] }); }
32
32
  }
33
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyFilterModule, decorators: [{
33
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyFilterModule, decorators: [{
34
34
  type: NgModule,
35
35
  args: [{
36
36
  declarations: [
@@ -72,10 +72,10 @@ export class SkyInfiniteScrollDomAdapterService {
72
72
  const parentRect = parentElement.getBoundingClientRect();
73
73
  return elementRect.top < parentRect.top + parentRect.height;
74
74
  }
75
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyInfiniteScrollDomAdapterService, deps: [{ token: i1.SkyScrollableHostService }, { token: i1.SkyAppWindowRef }], target: i0.ɵɵFactoryTarget.Injectable }); }
76
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyInfiniteScrollDomAdapterService }); }
75
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyInfiniteScrollDomAdapterService, deps: [{ token: i1.SkyScrollableHostService }, { token: i1.SkyAppWindowRef }], target: i0.ɵɵFactoryTarget.Injectable }); }
76
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyInfiniteScrollDomAdapterService }); }
77
77
  }
78
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyInfiniteScrollDomAdapterService, decorators: [{
78
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyInfiniteScrollDomAdapterService, decorators: [{
79
79
  type: Injectable
80
- }], ctorParameters: function () { return [{ type: i1.SkyScrollableHostService }, { type: i1.SkyAppWindowRef }]; } });
81
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"infinite-scroll-dom-adapter.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/lists/src/lib/modules/infinite-scroll/infinite-scroll-dom-adapter.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, Injectable, OnDestroy } from '@angular/core';\nimport { SkyAppWindowRef, SkyScrollableHostService } from '@skyux/core';\n\nimport { Observable, Subject, fromEvent as observableFromEvent } from 'rxjs';\nimport { filter, map, takeUntil } from 'rxjs/operators';\n\n/**\n * @internal\n */\n@Injectable()\nexport class SkyInfiniteScrollDomAdapterService implements OnDestroy {\n  #ngUnsubscribe = new Subject<void>();\n  #observer: MutationObserver | undefined;\n  #parentChanges: Subject<void>;\n  #parentChangesObs: Observable<void>;\n  #scrollableHostSvc: SkyScrollableHostService;\n  #windowRef: SkyAppWindowRef;\n\n  constructor(\n    scrollableHostSvc: SkyScrollableHostService,\n    windowRef: SkyAppWindowRef,\n  ) {\n    this.#scrollableHostSvc = scrollableHostSvc;\n    this.#windowRef = windowRef;\n\n    this.#parentChanges = new Subject<void>();\n    this.#parentChangesObs = this.#parentChanges.asObservable();\n  }\n\n  public ngOnDestroy(): void {\n    this.#parentChanges.complete();\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  /**\n   * This event is triggered when child nodes are added to the infinite\n   * scroll parent container. e.g., A repeating list of elements was added.\n   * @param elementRef The infinite scroll element reference.\n   */\n  public parentChanges(elementRef: ElementRef): Observable<void> {\n    this.#createObserver(elementRef);\n    return this.#parentChangesObs;\n  }\n\n  /**\n   * This event is triggered when the provided element reference\n   * is visible (or scrolled to) within its scrollable parent container.\n   * @param elementRef The infinite scroll element reference.\n   */\n  public scrollTo(elementRef: ElementRef): Observable<void> {\n    const parent = this.#scrollableHostSvc.getScrollableHost(elementRef);\n\n    return observableFromEvent(parent, 'scroll').pipe(\n      takeUntil(this.#ngUnsubscribe),\n      filter(() => {\n        return this.#isElementScrolledInView(elementRef.nativeElement, parent);\n      }),\n      map(() => undefined), // Change to void return type\n    );\n  }\n\n  #createObserver(elementRef: ElementRef): void {\n    this.#observer = new MutationObserver((mutations: MutationRecord[]) => {\n      const hasUpdates = !!mutations.find((mutation) => {\n        return (\n          !elementRef.nativeElement.contains(mutation.target) &&\n          mutation.addedNodes.length > 0\n        );\n      });\n\n      if (hasUpdates) {\n        this.#parentChanges.next();\n      }\n    });\n\n    const windowObj = this.#windowRef.nativeWindow;\n    const parent = this.#scrollableHostSvc.getScrollableHost(elementRef);\n    const observedParent =\n      parent === windowObj ? windowObj.document.body : parent;\n\n    this.#observer.observe(observedParent, {\n      childList: true,\n      subtree: true,\n    });\n  }\n\n  #isElementScrolledInView(\n    element: HTMLElement,\n    parentElement: HTMLElement | Window,\n  ): boolean {\n    const windowObj = this.#windowRef.nativeWindow as Window;\n\n    if (parentElement === windowObj) {\n      return (\n        parentElement.pageYOffset + parentElement.innerHeight >\n        element.offsetTop\n      );\n    }\n\n    const elementRect = element.getBoundingClientRect();\n    const parentRect = (parentElement as HTMLElement).getBoundingClientRect();\n\n    return elementRect.top < parentRect.top + parentRect.height;\n  }\n}\n"]}
80
+ }], ctorParameters: () => [{ type: i1.SkyScrollableHostService }, { type: i1.SkyAppWindowRef }] });
81
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"infinite-scroll-dom-adapter.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/lists/src/lib/modules/infinite-scroll/infinite-scroll-dom-adapter.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, Injectable, OnDestroy } from '@angular/core';\nimport { SkyAppWindowRef, SkyScrollableHostService } from '@skyux/core';\n\nimport { Observable, Subject, fromEvent as observableFromEvent } from 'rxjs';\nimport { filter, map, takeUntil } from 'rxjs/operators';\n\n/**\n * @internal\n */\n@Injectable()\nexport class SkyInfiniteScrollDomAdapterService implements OnDestroy {\n  #ngUnsubscribe = new Subject<void>();\n  #observer: MutationObserver | undefined;\n  #parentChanges: Subject<void>;\n  #parentChangesObs: Observable<void>;\n  #scrollableHostSvc: SkyScrollableHostService;\n  #windowRef: SkyAppWindowRef;\n\n  constructor(\n    scrollableHostSvc: SkyScrollableHostService,\n    windowRef: SkyAppWindowRef,\n  ) {\n    this.#scrollableHostSvc = scrollableHostSvc;\n    this.#windowRef = windowRef;\n\n    this.#parentChanges = new Subject<void>();\n    this.#parentChangesObs = this.#parentChanges.asObservable();\n  }\n\n  public ngOnDestroy(): void {\n    this.#parentChanges.complete();\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  /**\n   * This event is triggered when child nodes are added to the infinite\n   * scroll parent container. e.g., A repeating list of elements was added.\n   * @param elementRef The infinite scroll element reference.\n   */\n  public parentChanges(elementRef: ElementRef): Observable<void> {\n    this.#createObserver(elementRef);\n    return this.#parentChangesObs;\n  }\n\n  /**\n   * This event is triggered when the provided element reference\n   * is visible (or scrolled to) within its scrollable parent container.\n   * @param elementRef The infinite scroll element reference.\n   */\n  public scrollTo(elementRef: ElementRef): Observable<void> {\n    const parent = this.#scrollableHostSvc.getScrollableHost(elementRef);\n\n    return observableFromEvent(parent, 'scroll').pipe(\n      takeUntil(this.#ngUnsubscribe),\n      filter(() => {\n        return this.#isElementScrolledInView(elementRef.nativeElement, parent);\n      }),\n      map(() => undefined), // Change to void return type\n    );\n  }\n\n  #createObserver(elementRef: ElementRef): void {\n    this.#observer = new MutationObserver((mutations: MutationRecord[]) => {\n      const hasUpdates = !!mutations.find((mutation) => {\n        return (\n          !elementRef.nativeElement.contains(mutation.target) &&\n          mutation.addedNodes.length > 0\n        );\n      });\n\n      if (hasUpdates) {\n        this.#parentChanges.next();\n      }\n    });\n\n    const windowObj = this.#windowRef.nativeWindow;\n    const parent = this.#scrollableHostSvc.getScrollableHost(elementRef);\n    const observedParent =\n      parent === windowObj ? windowObj.document.body : parent;\n\n    this.#observer.observe(observedParent, {\n      childList: true,\n      subtree: true,\n    });\n  }\n\n  #isElementScrolledInView(\n    element: HTMLElement,\n    parentElement: HTMLElement | Window,\n  ): boolean {\n    const windowObj = this.#windowRef.nativeWindow as Window;\n\n    if (parentElement === windowObj) {\n      return (\n        parentElement.pageYOffset + parentElement.innerHeight >\n        element.offsetTop\n      );\n    }\n\n    const elementRect = element.getBoundingClientRect();\n    const parentRect = (parentElement as HTMLElement).getBoundingClientRect();\n\n    return elementRect.top < parentRect.top + parentRect.height;\n  }\n}\n"]}
@@ -100,17 +100,17 @@ export class SkyInfiniteScrollComponent {
100
100
  this.#ngUnsubscribe.next();
101
101
  }
102
102
  }
103
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyInfiniteScrollComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i1.SkyInfiniteScrollDomAdapterService }], target: i0.ɵɵFactoryTarget.Component }); }
104
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.9", type: SkyInfiniteScrollComponent, selector: "sky-infinite-scroll", inputs: { enabled: "enabled", loading: "loading" }, outputs: { scrollEnd: "scrollEnd" }, providers: [SkyInfiniteScrollDomAdapterService], ngImport: i0, template: "<div *ngIf=\"enabled\" class=\"sky-infinite-scroll\">\n <button\n *ngIf=\"!isWaiting && enabled\"\n class=\"sky-btn sky-btn-default sky-infinite-scroll-load-more-button\"\n type=\"button\"\n (click)=\"startInfiniteScrollLoad()\"\n >\n {{ 'skyux_infinite_scroll_load_more_button' | skyLibResources }}\n </button>\n <sky-wait [isWaiting]=\"isWaiting\"> </sky-wait>\n</div>\n", styles: [".sky-infinite-scroll{margin-top:20px;text-align:center;min-height:75px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.λ14, selector: "sky-wait", inputs: ["ariaLabel", "isWaiting", "isFullPage", "isNonBlocking", "screenReaderCompletedText"] }, { kind: "pipe", type: i4.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
103
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyInfiniteScrollComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i1.SkyInfiniteScrollDomAdapterService }], target: i0.ɵɵFactoryTarget.Component }); }
104
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.0", type: SkyInfiniteScrollComponent, selector: "sky-infinite-scroll", inputs: { enabled: "enabled", loading: "loading" }, outputs: { scrollEnd: "scrollEnd" }, providers: [SkyInfiniteScrollDomAdapterService], ngImport: i0, template: "<div *ngIf=\"enabled\" class=\"sky-infinite-scroll\">\n <button\n *ngIf=\"!isWaiting && enabled\"\n class=\"sky-btn sky-btn-default sky-infinite-scroll-load-more-button\"\n type=\"button\"\n (click)=\"startInfiniteScrollLoad()\"\n >\n {{ 'skyux_infinite_scroll_load_more_button' | skyLibResources }}\n </button>\n <sky-wait [isWaiting]=\"isWaiting\"> </sky-wait>\n</div>\n", styles: [".sky-infinite-scroll{margin-top:20px;text-align:center;min-height:75px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.λ14, selector: "sky-wait", inputs: ["ariaLabel", "isWaiting", "isFullPage", "isNonBlocking", "screenReaderCompletedText"] }, { kind: "pipe", type: i4.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
105
105
  }
106
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyInfiniteScrollComponent, decorators: [{
106
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyInfiniteScrollComponent, decorators: [{
107
107
  type: Component,
108
108
  args: [{ selector: 'sky-infinite-scroll', changeDetection: ChangeDetectionStrategy.OnPush, providers: [SkyInfiniteScrollDomAdapterService], template: "<div *ngIf=\"enabled\" class=\"sky-infinite-scroll\">\n <button\n *ngIf=\"!isWaiting && enabled\"\n class=\"sky-btn sky-btn-default sky-infinite-scroll-load-more-button\"\n type=\"button\"\n (click)=\"startInfiniteScrollLoad()\"\n >\n {{ 'skyux_infinite_scroll_load_more_button' | skyLibResources }}\n </button>\n <sky-wait [isWaiting]=\"isWaiting\"> </sky-wait>\n</div>\n", styles: [".sky-infinite-scroll{margin-top:20px;text-align:center;min-height:75px}\n"] }]
109
- }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i1.SkyInfiniteScrollDomAdapterService }]; }, propDecorators: { enabled: [{
109
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i1.SkyInfiniteScrollDomAdapterService }], propDecorators: { enabled: [{
110
110
  type: Input
111
111
  }], loading: [{
112
112
  type: Input
113
113
  }], scrollEnd: [{
114
114
  type: Output
115
115
  }] } });
116
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"infinite-scroll.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/lists/src/lib/modules/infinite-scroll/infinite-scroll.component.ts","../../../../../../../../libs/components/lists/src/lib/modules/infinite-scroll/infinite-scroll.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n} from '@angular/core';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyInfiniteScrollDomAdapterService } from './infinite-scroll-dom-adapter.service';\n\n@Component({\n  selector: 'sky-infinite-scroll',\n  templateUrl: './infinite-scroll.component.html',\n  styleUrls: ['./infinite-scroll.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [SkyInfiniteScrollDomAdapterService],\n})\nexport class SkyInfiniteScrollComponent implements OnDestroy {\n  /**\n   * Whether to make the infinite scroll component active when more data is available\n   * to load. By default, infinite scroll is inactive and does not call the load function.\n   * @default false\n   */\n  @Input()\n  public get enabled(): boolean | undefined {\n    return this.#_enabled;\n  }\n  public set enabled(value: boolean | undefined) {\n    if (this.#_enabled !== value) {\n      this.#_enabled = value;\n      this.#setListeners();\n    }\n  }\n\n  /**\n   * Whether data is loading because of a `scrollEnd` event. Setting the property\n   * to `true` disables new `scrollEnd` events from firing until it changes to `false`. If this\n   * property is not specified, the infinite scroll component watches the DOM for changes\n   * and fires `scrollEnd` events when changes occur on its parent DOM element. Relying\n   * on this default behavior could fire an excessive number of `scrollEnd` events\n   * if the DOM changes are not related to loading data, so we strongly recommend using this\n   * property to explicitly set the infinite scroll's loading state.\n   * @required\n   */\n  @Input()\n  public get loading(): boolean | undefined {\n    return this.#_loading;\n  }\n\n  public set loading(value: boolean | undefined) {\n    this.#_loading = value;\n\n    if (value !== undefined) {\n      this.isWaiting = value;\n    }\n  }\n\n  /**\n   * Fires when scrolling triggers the need to load more data or when users select the button\n   * to load more data. This event only fires when the `enabled` property is set to `true`\n   * and data is not already loading.\n   */\n  @Output()\n  public scrollEnd = new EventEmitter<void>();\n\n  public isWaiting = false;\n\n  #changeDetector: ChangeDetectorRef;\n  #domAdapter: SkyInfiniteScrollDomAdapterService;\n  #elementRef: ElementRef;\n  #ngUnsubscribe = new Subject<void>();\n  #_enabled: boolean | undefined = false;\n  #_loading: boolean | undefined;\n\n  constructor(\n    changeDetector: ChangeDetectorRef,\n    elementRef: ElementRef,\n    domAdapter: SkyInfiniteScrollDomAdapterService,\n  ) {\n    this.#changeDetector = changeDetector;\n    this.#elementRef = elementRef;\n    this.#domAdapter = domAdapter;\n  }\n\n  public ngOnDestroy(): void {\n    this.enabled = false;\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  public startInfiniteScrollLoad(): void {\n    this.#notifyScrollEnd();\n  }\n\n  #notifyScrollEnd(): void {\n    this.isWaiting = true;\n    this.scrollEnd.emit();\n    this.#changeDetector.markForCheck();\n  }\n\n  #setListeners(): void {\n    if (this.enabled) {\n      // The user has scrolled to the infinite scroll element.\n      this.#domAdapter\n        .scrollTo(this.#elementRef)\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe(() => {\n          if (!this.isWaiting && this.enabled) {\n            this.#notifyScrollEnd();\n          }\n        });\n\n      // New items have been loaded into the parent element.\n      this.#domAdapter\n        .parentChanges(this.#elementRef)\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe(() => {\n          if (!this.loading) {\n            this.isWaiting = false;\n            this.#changeDetector.markForCheck();\n          }\n        });\n    } else {\n      this.#ngUnsubscribe.next();\n    }\n  }\n}\n","<div *ngIf=\"enabled\" class=\"sky-infinite-scroll\">\n  <button\n    *ngIf=\"!isWaiting && enabled\"\n    class=\"sky-btn sky-btn-default sky-infinite-scroll-load-more-button\"\n    type=\"button\"\n    (click)=\"startInfiniteScrollLoad()\"\n  >\n    {{ 'skyux_infinite_scroll_load_more_button' | skyLibResources }}\n  </button>\n  <sky-wait [isWaiting]=\"isWaiting\"> </sky-wait>\n</div>\n"]}
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"infinite-scroll.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/lists/src/lib/modules/infinite-scroll/infinite-scroll.component.ts","../../../../../../../../libs/components/lists/src/lib/modules/infinite-scroll/infinite-scroll.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n} from '@angular/core';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyInfiniteScrollDomAdapterService } from './infinite-scroll-dom-adapter.service';\n\n@Component({\n  selector: 'sky-infinite-scroll',\n  templateUrl: './infinite-scroll.component.html',\n  styleUrls: ['./infinite-scroll.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [SkyInfiniteScrollDomAdapterService],\n})\nexport class SkyInfiniteScrollComponent implements OnDestroy {\n  /**\n   * Whether to make the infinite scroll component active when more data is available\n   * to load. By default, infinite scroll is inactive and does not call the load function.\n   * @default false\n   */\n  @Input()\n  public get enabled(): boolean | undefined {\n    return this.#_enabled;\n  }\n  public set enabled(value: boolean | undefined) {\n    if (this.#_enabled !== value) {\n      this.#_enabled = value;\n      this.#setListeners();\n    }\n  }\n\n  /**\n   * Whether data is loading because of a `scrollEnd` event. Setting the property\n   * to `true` disables new `scrollEnd` events from firing until it changes to `false`. If this\n   * property is not specified, the infinite scroll component watches the DOM for changes\n   * and fires `scrollEnd` events when changes occur on its parent DOM element. Relying\n   * on this default behavior could fire an excessive number of `scrollEnd` events\n   * if the DOM changes are not related to loading data, so we strongly recommend using this\n   * property to explicitly set the infinite scroll's loading state.\n   * @required\n   */\n  @Input()\n  public get loading(): boolean | undefined {\n    return this.#_loading;\n  }\n\n  public set loading(value: boolean | undefined) {\n    this.#_loading = value;\n\n    if (value !== undefined) {\n      this.isWaiting = value;\n    }\n  }\n\n  /**\n   * Fires when scrolling triggers the need to load more data or when users select the button\n   * to load more data. This event only fires when the `enabled` property is set to `true`\n   * and data is not already loading.\n   */\n  @Output()\n  public scrollEnd = new EventEmitter<void>();\n\n  public isWaiting = false;\n\n  #changeDetector: ChangeDetectorRef;\n  #domAdapter: SkyInfiniteScrollDomAdapterService;\n  #elementRef: ElementRef;\n  #ngUnsubscribe = new Subject<void>();\n  #_enabled: boolean | undefined = false;\n  #_loading: boolean | undefined;\n\n  constructor(\n    changeDetector: ChangeDetectorRef,\n    elementRef: ElementRef,\n    domAdapter: SkyInfiniteScrollDomAdapterService,\n  ) {\n    this.#changeDetector = changeDetector;\n    this.#elementRef = elementRef;\n    this.#domAdapter = domAdapter;\n  }\n\n  public ngOnDestroy(): void {\n    this.enabled = false;\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  public startInfiniteScrollLoad(): void {\n    this.#notifyScrollEnd();\n  }\n\n  #notifyScrollEnd(): void {\n    this.isWaiting = true;\n    this.scrollEnd.emit();\n    this.#changeDetector.markForCheck();\n  }\n\n  #setListeners(): void {\n    if (this.enabled) {\n      // The user has scrolled to the infinite scroll element.\n      this.#domAdapter\n        .scrollTo(this.#elementRef)\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe(() => {\n          if (!this.isWaiting && this.enabled) {\n            this.#notifyScrollEnd();\n          }\n        });\n\n      // New items have been loaded into the parent element.\n      this.#domAdapter\n        .parentChanges(this.#elementRef)\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe(() => {\n          if (!this.loading) {\n            this.isWaiting = false;\n            this.#changeDetector.markForCheck();\n          }\n        });\n    } else {\n      this.#ngUnsubscribe.next();\n    }\n  }\n}\n","<div *ngIf=\"enabled\" class=\"sky-infinite-scroll\">\n  <button\n    *ngIf=\"!isWaiting && enabled\"\n    class=\"sky-btn sky-btn-default sky-infinite-scroll-load-more-button\"\n    type=\"button\"\n    (click)=\"startInfiniteScrollLoad()\"\n  >\n    {{ 'skyux_infinite_scroll_load_more_button' | skyLibResources }}\n  </button>\n  <sky-wait [isWaiting]=\"isWaiting\"> </sky-wait>\n</div>\n"]}
@@ -5,11 +5,11 @@ import { SkyListsResourcesModule } from '../shared/sky-lists-resources.module';
5
5
  import { SkyInfiniteScrollComponent } from './infinite-scroll.component';
6
6
  import * as i0 from "@angular/core";
7
7
  export class SkyInfiniteScrollModule {
8
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyInfiniteScrollModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
9
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.9", ngImport: i0, type: SkyInfiniteScrollModule, declarations: [SkyInfiniteScrollComponent], imports: [CommonModule, SkyListsResourcesModule, SkyWaitModule], exports: [SkyInfiniteScrollComponent] }); }
10
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyInfiniteScrollModule, imports: [CommonModule, SkyListsResourcesModule, SkyWaitModule] }); }
8
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyInfiniteScrollModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
9
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.1.0", ngImport: i0, type: SkyInfiniteScrollModule, declarations: [SkyInfiniteScrollComponent], imports: [CommonModule, SkyListsResourcesModule, SkyWaitModule], exports: [SkyInfiniteScrollComponent] }); }
10
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyInfiniteScrollModule, imports: [CommonModule, SkyListsResourcesModule, SkyWaitModule] }); }
11
11
  }
12
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyInfiniteScrollModule, decorators: [{
12
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyInfiniteScrollModule, decorators: [{
13
13
  type: NgModule,
14
14
  args: [{
15
15
  declarations: [SkyInfiniteScrollComponent],
@@ -2,10 +2,10 @@ import { CommonModule } from '@angular/common';
2
2
  import { Component } from '@angular/core';
3
3
  import * as i0 from "@angular/core";
4
4
  export class SkyPagingContentComponent {
5
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyPagingContentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
6
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.9", type: SkyPagingContentComponent, isStandalone: true, selector: "sky-paging-content", ngImport: i0, template: `<ng-content />`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }] }); }
5
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyPagingContentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
6
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.0", type: SkyPagingContentComponent, isStandalone: true, selector: "sky-paging-content", ngImport: i0, template: `<ng-content />`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }] }); }
7
7
  }
8
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyPagingContentComponent, decorators: [{
8
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyPagingContentComponent, decorators: [{
9
9
  type: Component,
10
10
  args: [{
11
11
  standalone: true,
@@ -123,10 +123,10 @@ export class SkyPagingComponent {
123
123
  #moveFocusToTop() {
124
124
  this.contentWrapper?.nativeElement.focus();
125
125
  }
126
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyPagingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
127
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.9", type: SkyPagingComponent, selector: "sky-paging", inputs: { currentPage: "currentPage", itemCount: "itemCount", maxPages: "maxPages", pageSize: "pageSize", pagingLabel: "pagingLabel" }, outputs: { currentPageChange: "currentPageChange", contentChange: "contentChange" }, viewQueries: [{ propertyName: "contentWrapper", first: true, predicate: ["contentWrapper"], descendants: true, read: ElementRef }], usesOnChanges: true, ngImport: i0, template: "<sky-wait\n [ariaLabel]=\"\n 'skyux_paging_loading' | skyLibResources : currentPage : pageCount\n \"\n [isWaiting]=\"!!(isLoading | async)\"\n [screenReaderCompletedText]=\"\n 'skyux_paging_loaded' | skyLibResources : currentPage\n \"\n/>\n<div\n class=\"sky-paging-content-wrapper\"\n role=\"group\"\n tabindex=\"-1\"\n [attr.aria-label]=\"\n 'skyux_paging_page_label' | skyLibResources : currentPage : pageCount\n \"\n #contentWrapper\n>\n <ng-content select=\"sky-paging-content\" />\n</div>\n<nav\n *ngIf=\"pageCount > 1\"\n class=\"sky-paging\"\n [attr.aria-label]=\"pagingLabel || ('skyux_paging_label' | skyLibResources)\"\n>\n <ul>\n <li>\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-previous sky-box\"\n sky-cmp-id=\"previous\"\n type=\"button\"\n [attr.aria-label]=\"'skyux_paging_previous' | skyLibResources\"\n [disabled]=\"isPreviousButtonDisabled\"\n (click)=\"previousPage()\"\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-left\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-left\" />\n </button>\n </li>\n <li *ngFor=\"let pageNumber of displayedPages\" class=\"sky-list-paging-link\">\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-box\"\n type=\"button\"\n [attr.aria-current]=\"currentPage === pageNumber ? 'page' : null\"\n [attr.sky-cmp-id]=\"pageNumber\"\n [attr.aria-label]=\"\n 'skyux_paging_page_link_aria_label' | skyLibResources : pageNumber\n \"\n [disabled]=\"currentPage === pageNumber\"\n [ngClass]=\"{ 'sky-paging-current': currentPage === pageNumber }\"\n (click)=\"setPage(pageNumber)\"\n >\n {{ pageNumber }}\n </button>\n </li>\n <li>\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-next sky-box\"\n sky-cmp-id=\"next\"\n type=\"button\"\n [attr.aria-label]=\"'skyux_paging_next' | skyLibResources\"\n [disabled]=\"isNextButtonDisabled\"\n (click)=\"nextPage()\"\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-right\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-right\" />\n </button>\n </li>\n </ul>\n</nav>\n", styles: [":host{display:block}.sky-paging-content-wrapper{display:none}.sky-paging-content-wrapper:not(:empty){display:block;margin-bottom:var(--sky-margin-stacked-lg)}.sky-paging-content-wrapper:focus-visible{outline:none;border:none}ul{margin:15px 0 0;display:inline-block;padding-left:0;border-radius:4px}li{display:inline}.sky-paging-btn{border-top:1px solid #e2e3e4;border-right:1px solid #e2e3e4;border-bottom:1px solid #e2e3e4;border-left:1px solid #e2e3e4;border-radius:0;background-color:#fff;color:inherit;float:left;margin-left:-1px;padding:4px 10px;text-decoration:none;line-height:1.428571429;font-size:15px;cursor:pointer}.sky-paging-btn.sky-paging-caret{transform:none}.sky-paging-btn.sky-paging-current,.sky-paging-btn.sky-paging-current:disabled,.sky-paging-btn.sky-paging-current[disabled]{background-color:#eeeeef;cursor:default;color:inherit;opacity:1}.sky-paging-btn:hover{background-color:#d4d4d6}.sky-paging-btn:disabled{color:#686c73;cursor:not-allowed;pointer-events:none}.sky-paging-btn.sky-paging-btn-previous,.sky-paging-btn.sky-paging-btn-next{padding-left:8.5px;padding-right:8.5px}:host-context(.sky-theme-modern) .sky-paging-btn{background-color:transparent;border:none;box-shadow:none;border-radius:6px;margin-right:10px;padding:3px 10px}:host-context(.sky-theme-modern) .sky-paging-btn:hover{background-color:transparent;border:solid 1px #1870B8;padding:2px 9px;z-index:1}:host-context(.sky-theme-modern) .sky-paging-btn:active,:host-context(.sky-theme-modern) .sky-paging-btn:focus{border:solid 2px #1870B8;color:#212327;padding:1px 8px}:host-context(.sky-theme-modern) .sky-paging-btn:focus:not(:active){outline:none;box-shadow:0 1px 3px #0000004d}:host-context(.sky-theme-modern) .sky-paging-current{background-color:var(--sky-background-color-item-selected);border:solid 1px #1870B8;padding:2px 9px}.sky-theme-modern .sky-paging-btn{background-color:transparent;border:none;box-shadow:none;border-radius:6px;margin-right:10px;padding:3px 10px}.sky-theme-modern .sky-paging-btn:hover{background-color:transparent;border:solid 1px #1870B8;padding:2px 9px;z-index:1}.sky-theme-modern .sky-paging-btn:active,.sky-theme-modern .sky-paging-btn:focus{border:solid 2px #1870B8;color:#212327;padding:1px 8px}.sky-theme-modern .sky-paging-btn:focus:not(:active){outline:none;box-shadow:0 1px 3px #0000004d}.sky-theme-modern .sky-paging-current{background-color:var(--sky-background-color-item-selected);border:solid 1px #1870B8;padding:2px 9px}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-btn:active,:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-btn:focus{color:#fbfcfe}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-current{background-color:#1870b8}.sky-theme-modern.sky-theme-mode-dark .sky-paging-btn:active,.sky-theme-modern.sky-theme-mode-dark .sky-paging-btn:focus{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-paging-current{background-color:#1870b8}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "directive", type: i3.λ3, selector: "[skyThemeIf]", inputs: ["skyThemeIf"] }, { kind: "component", type: i2.λ14, selector: "sky-wait", inputs: ["ariaLabel", "isWaiting", "isFullPage", "isNonBlocking", "screenReaderCompletedText"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
126
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyPagingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
127
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.0", type: SkyPagingComponent, selector: "sky-paging", inputs: { currentPage: "currentPage", itemCount: "itemCount", maxPages: "maxPages", pageSize: "pageSize", pagingLabel: "pagingLabel" }, outputs: { currentPageChange: "currentPageChange", contentChange: "contentChange" }, viewQueries: [{ propertyName: "contentWrapper", first: true, predicate: ["contentWrapper"], descendants: true, read: ElementRef }], usesOnChanges: true, ngImport: i0, template: "<sky-wait\n [ariaLabel]=\"\n 'skyux_paging_loading' | skyLibResources : currentPage : pageCount\n \"\n [isWaiting]=\"!!(isLoading | async)\"\n [screenReaderCompletedText]=\"\n 'skyux_paging_loaded' | skyLibResources : currentPage\n \"\n/>\n<div\n class=\"sky-paging-content-wrapper\"\n role=\"group\"\n tabindex=\"-1\"\n [attr.aria-label]=\"\n 'skyux_paging_page_label' | skyLibResources : currentPage : pageCount\n \"\n #contentWrapper\n>\n <ng-content select=\"sky-paging-content\" />\n</div>\n<nav\n *ngIf=\"pageCount > 1\"\n class=\"sky-paging\"\n [attr.aria-label]=\"pagingLabel || ('skyux_paging_label' | skyLibResources)\"\n>\n <ul>\n <li>\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-previous sky-box\"\n sky-cmp-id=\"previous\"\n type=\"button\"\n [attr.aria-label]=\"'skyux_paging_previous' | skyLibResources\"\n [disabled]=\"isPreviousButtonDisabled\"\n (click)=\"previousPage()\"\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-left\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-left\" />\n </button>\n </li>\n <li *ngFor=\"let pageNumber of displayedPages\" class=\"sky-list-paging-link\">\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-box\"\n type=\"button\"\n [attr.aria-current]=\"currentPage === pageNumber ? 'page' : null\"\n [attr.sky-cmp-id]=\"pageNumber\"\n [attr.aria-label]=\"\n 'skyux_paging_page_link_aria_label' | skyLibResources : pageNumber\n \"\n [disabled]=\"currentPage === pageNumber\"\n [ngClass]=\"{ 'sky-paging-current': currentPage === pageNumber }\"\n (click)=\"setPage(pageNumber)\"\n >\n {{ pageNumber }}\n </button>\n </li>\n <li>\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-next sky-box\"\n sky-cmp-id=\"next\"\n type=\"button\"\n [attr.aria-label]=\"'skyux_paging_next' | skyLibResources\"\n [disabled]=\"isNextButtonDisabled\"\n (click)=\"nextPage()\"\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-right\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-right\" />\n </button>\n </li>\n </ul>\n</nav>\n", styles: [":host{display:block}.sky-paging-content-wrapper{display:none}.sky-paging-content-wrapper:not(:empty){display:block;margin-bottom:var(--sky-margin-stacked-lg)}.sky-paging-content-wrapper:focus-visible{outline:none;border:none}ul{margin:15px 0 0;display:inline-block;padding-left:0;border-radius:4px}li{display:inline}.sky-paging-btn{border-top:1px solid #e2e3e4;border-right:1px solid #e2e3e4;border-bottom:1px solid #e2e3e4;border-left:1px solid #e2e3e4;border-radius:0;background-color:#fff;color:inherit;float:left;margin-left:-1px;padding:4px 10px;text-decoration:none;line-height:1.428571429;font-size:15px;cursor:pointer}.sky-paging-btn.sky-paging-caret{transform:none}.sky-paging-btn.sky-paging-current,.sky-paging-btn.sky-paging-current:disabled,.sky-paging-btn.sky-paging-current[disabled]{background-color:#eeeeef;cursor:default;color:inherit;opacity:1}.sky-paging-btn:hover{background-color:#d4d4d6}.sky-paging-btn:disabled{color:#686c73;cursor:not-allowed;pointer-events:none}.sky-paging-btn.sky-paging-btn-previous,.sky-paging-btn.sky-paging-btn-next{padding-left:8.5px;padding-right:8.5px}:host-context(.sky-theme-modern) .sky-paging-btn{background-color:transparent;border:none;box-shadow:none;border-radius:6px;margin-right:10px;padding:3px 10px}:host-context(.sky-theme-modern) .sky-paging-btn:hover{background-color:transparent;border:solid 1px #1870B8;padding:2px 9px;z-index:1}:host-context(.sky-theme-modern) .sky-paging-btn:active,:host-context(.sky-theme-modern) .sky-paging-btn:focus{border:solid 2px #1870B8;color:#212327;padding:1px 8px}:host-context(.sky-theme-modern) .sky-paging-btn:focus:not(:active){outline:none;box-shadow:0 1px 3px #0000004d}:host-context(.sky-theme-modern) .sky-paging-current{background-color:var(--sky-background-color-item-selected);border:solid 1px #1870B8;padding:2px 9px}.sky-theme-modern .sky-paging-btn{background-color:transparent;border:none;box-shadow:none;border-radius:6px;margin-right:10px;padding:3px 10px}.sky-theme-modern .sky-paging-btn:hover{background-color:transparent;border:solid 1px #1870B8;padding:2px 9px;z-index:1}.sky-theme-modern .sky-paging-btn:active,.sky-theme-modern .sky-paging-btn:focus{border:solid 2px #1870B8;color:#212327;padding:1px 8px}.sky-theme-modern .sky-paging-btn:focus:not(:active){outline:none;box-shadow:0 1px 3px #0000004d}.sky-theme-modern .sky-paging-current{background-color:var(--sky-background-color-item-selected);border:solid 1px #1870B8;padding:2px 9px}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-btn:active,:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-btn:focus{color:#fbfcfe}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-current{background-color:#1870b8}.sky-theme-modern.sky-theme-mode-dark .sky-paging-btn:active,.sky-theme-modern.sky-theme-mode-dark .sky-paging-btn:focus{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-paging-current{background-color:#1870b8}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "directive", type: i3.λ3, selector: "[skyThemeIf]", inputs: ["skyThemeIf"] }, { kind: "component", type: i2.λ14, selector: "sky-wait", inputs: ["ariaLabel", "isWaiting", "isFullPage", "isNonBlocking", "screenReaderCompletedText"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
128
128
  }
129
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyPagingComponent, decorators: [{
129
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyPagingComponent, decorators: [{
130
130
  type: Component,
131
131
  args: [{ selector: 'sky-paging', changeDetection: ChangeDetectionStrategy.OnPush, template: "<sky-wait\n [ariaLabel]=\"\n 'skyux_paging_loading' | skyLibResources : currentPage : pageCount\n \"\n [isWaiting]=\"!!(isLoading | async)\"\n [screenReaderCompletedText]=\"\n 'skyux_paging_loaded' | skyLibResources : currentPage\n \"\n/>\n<div\n class=\"sky-paging-content-wrapper\"\n role=\"group\"\n tabindex=\"-1\"\n [attr.aria-label]=\"\n 'skyux_paging_page_label' | skyLibResources : currentPage : pageCount\n \"\n #contentWrapper\n>\n <ng-content select=\"sky-paging-content\" />\n</div>\n<nav\n *ngIf=\"pageCount > 1\"\n class=\"sky-paging\"\n [attr.aria-label]=\"pagingLabel || ('skyux_paging_label' | skyLibResources)\"\n>\n <ul>\n <li>\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-previous sky-box\"\n sky-cmp-id=\"previous\"\n type=\"button\"\n [attr.aria-label]=\"'skyux_paging_previous' | skyLibResources\"\n [disabled]=\"isPreviousButtonDisabled\"\n (click)=\"previousPage()\"\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-left\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-left\" />\n </button>\n </li>\n <li *ngFor=\"let pageNumber of displayedPages\" class=\"sky-list-paging-link\">\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-box\"\n type=\"button\"\n [attr.aria-current]=\"currentPage === pageNumber ? 'page' : null\"\n [attr.sky-cmp-id]=\"pageNumber\"\n [attr.aria-label]=\"\n 'skyux_paging_page_link_aria_label' | skyLibResources : pageNumber\n \"\n [disabled]=\"currentPage === pageNumber\"\n [ngClass]=\"{ 'sky-paging-current': currentPage === pageNumber }\"\n (click)=\"setPage(pageNumber)\"\n >\n {{ pageNumber }}\n </button>\n </li>\n <li>\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-next sky-box\"\n sky-cmp-id=\"next\"\n type=\"button\"\n [attr.aria-label]=\"'skyux_paging_next' | skyLibResources\"\n [disabled]=\"isNextButtonDisabled\"\n (click)=\"nextPage()\"\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-right\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-right\" />\n </button>\n </li>\n </ul>\n</nav>\n", styles: [":host{display:block}.sky-paging-content-wrapper{display:none}.sky-paging-content-wrapper:not(:empty){display:block;margin-bottom:var(--sky-margin-stacked-lg)}.sky-paging-content-wrapper:focus-visible{outline:none;border:none}ul{margin:15px 0 0;display:inline-block;padding-left:0;border-radius:4px}li{display:inline}.sky-paging-btn{border-top:1px solid #e2e3e4;border-right:1px solid #e2e3e4;border-bottom:1px solid #e2e3e4;border-left:1px solid #e2e3e4;border-radius:0;background-color:#fff;color:inherit;float:left;margin-left:-1px;padding:4px 10px;text-decoration:none;line-height:1.428571429;font-size:15px;cursor:pointer}.sky-paging-btn.sky-paging-caret{transform:none}.sky-paging-btn.sky-paging-current,.sky-paging-btn.sky-paging-current:disabled,.sky-paging-btn.sky-paging-current[disabled]{background-color:#eeeeef;cursor:default;color:inherit;opacity:1}.sky-paging-btn:hover{background-color:#d4d4d6}.sky-paging-btn:disabled{color:#686c73;cursor:not-allowed;pointer-events:none}.sky-paging-btn.sky-paging-btn-previous,.sky-paging-btn.sky-paging-btn-next{padding-left:8.5px;padding-right:8.5px}:host-context(.sky-theme-modern) .sky-paging-btn{background-color:transparent;border:none;box-shadow:none;border-radius:6px;margin-right:10px;padding:3px 10px}:host-context(.sky-theme-modern) .sky-paging-btn:hover{background-color:transparent;border:solid 1px #1870B8;padding:2px 9px;z-index:1}:host-context(.sky-theme-modern) .sky-paging-btn:active,:host-context(.sky-theme-modern) .sky-paging-btn:focus{border:solid 2px #1870B8;color:#212327;padding:1px 8px}:host-context(.sky-theme-modern) .sky-paging-btn:focus:not(:active){outline:none;box-shadow:0 1px 3px #0000004d}:host-context(.sky-theme-modern) .sky-paging-current{background-color:var(--sky-background-color-item-selected);border:solid 1px #1870B8;padding:2px 9px}.sky-theme-modern .sky-paging-btn{background-color:transparent;border:none;box-shadow:none;border-radius:6px;margin-right:10px;padding:3px 10px}.sky-theme-modern .sky-paging-btn:hover{background-color:transparent;border:solid 1px #1870B8;padding:2px 9px;z-index:1}.sky-theme-modern .sky-paging-btn:active,.sky-theme-modern .sky-paging-btn:focus{border:solid 2px #1870B8;color:#212327;padding:1px 8px}.sky-theme-modern .sky-paging-btn:focus:not(:active){outline:none;box-shadow:0 1px 3px #0000004d}.sky-theme-modern .sky-paging-current{background-color:var(--sky-background-color-item-selected);border:solid 1px #1870B8;padding:2px 9px}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-btn:active,:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-btn:focus{color:#fbfcfe}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-current{background-color:#1870b8}.sky-theme-modern.sky-theme-mode-dark .sky-paging-btn:active,.sky-theme-modern.sky-theme-mode-dark .sky-paging-btn:focus{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-paging-current{background-color:#1870b8}\n"] }]
132
132
  }], propDecorators: { currentPage: [{
@@ -147,4 +147,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImpor
147
147
  type: ViewChild,
148
148
  args: ['contentWrapper', { read: ElementRef }]
149
149
  }] } });
150
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paging.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/lists/src/lib/modules/paging/paging.component.ts","../../../../../../../../libs/components/lists/src/lib/modules/paging/paging.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\n\nimport { BehaviorSubject } from 'rxjs';\n\nimport { SkyPagingContentChangeArgs } from './types/paging-content-change-args';\n\n@Component({\n  selector: 'sky-paging',\n  templateUrl: './paging.component.html',\n  styleUrls: ['./paging.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyPagingComponent implements OnChanges {\n  /**\n   * The page number of the current page. Page numbers start at 1 and increment.\n   */\n  @Input()\n  public currentPage = 1;\n\n  /**\n   * The total number of items across all pages.\n   */\n  @Input()\n  public itemCount = 0;\n\n  /**\n   * The maximum number of pages to display in the pagination control.\n   */\n  @Input()\n  public maxPages = 5;\n\n  /**\n   * The number of items to display per page.\n   */\n  @Input()\n  public pageSize = 10;\n\n  /**\n   * The label for the pagination control when an application includes\n   * multiple paging components on the same page. The label should be unique and descriptive\n   * to help users of assistive technology differentiate pagination controls\n   * and understand what each one does.\n   * @default \"Pagination\"\n   */\n  @Input()\n  public pagingLabel: string | undefined;\n\n  /**\n   * Fires when the current page changes and emits the new current page.\n   */\n  @Output()\n  public currentPageChange = new EventEmitter<number>();\n\n  /**\n   * Fires when the current page changes and emits the new current page with a function\n   * to call when loading the new page completes. Handling this event will display the\n   * wait component until the callback function is called, and focus will move to the top\n   * of the list for keyboard navigation if the list contents are placed inside the\n   * sky-paging-content element.\n   */\n  @Output()\n  public contentChange = new EventEmitter<SkyPagingContentChangeArgs>();\n\n  @ViewChild('contentWrapper', { read: ElementRef })\n  public contentWrapper: ElementRef | undefined;\n\n  public displayedPages: Array<number> = [];\n\n  public pageCount = 0;\n\n  protected isLoading = new BehaviorSubject(false);\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    this.setPage(this.currentPage, changes['currentPage']?.isFirstChange());\n  }\n\n  public setPage(pageNumber: number, forceContentChange?: boolean): void {\n    const previousPage = this.currentPage;\n\n    this.#setPageCount();\n\n    if (pageNumber < 1 || this.pageCount < 1) {\n      this.currentPage = 1;\n    } else if (pageNumber > this.pageCount) {\n      this.currentPage = this.pageCount;\n    } else {\n      this.currentPage = pageNumber;\n    }\n\n    this.#setDisplayedPages();\n\n    let doContentChange = forceContentChange;\n\n    if (previousPage !== this.currentPage) {\n      this.currentPageChange.emit(this.currentPage);\n      doContentChange = true;\n    }\n\n    if (doContentChange && this.contentChange.observed) {\n      this.#moveFocusToTop();\n      this.isLoading.next(true);\n\n      this.contentChange.emit({\n        currentPage: this.currentPage,\n        loadingComplete: () => this.isLoading.next(false),\n      });\n    }\n  }\n\n  public nextPage(): void {\n    this.setPage(this.currentPage + 1);\n  }\n\n  public previousPage(): void {\n    this.setPage(this.currentPage - 1);\n  }\n\n  public get isPreviousButtonDisabled(): boolean {\n    return this.currentPage === 1;\n  }\n\n  public get isNextButtonDisabled(): boolean {\n    return this.currentPage === this.pageCount;\n  }\n\n  #getDisplayedPageNumbers(\n    pageCount: number,\n    maxDisplayedPages: number,\n    pageNumber: number,\n  ): Array<number> {\n    const pageIndex = pageNumber - 1;\n    const pageBounds = Math.floor(maxDisplayedPages / 2);\n\n    let upperBound = pageIndex + pageBounds;\n    let lowerBound = pageIndex - pageBounds;\n    if (maxDisplayedPages % 2 !== 0) {\n      upperBound += 1;\n    }\n\n    // Wrap negative values to increase the upper bound\n    if (lowerBound < 0) {\n      upperBound -= lowerBound;\n      lowerBound = 0;\n    }\n    // Wrap overflow to decrease the lower bound\n    if (upperBound > pageCount) {\n      lowerBound -= upperBound - pageCount;\n      upperBound = pageCount;\n    }\n\n    // If both are the same ignore everything else and just display it all\n    if (pageCount < maxDisplayedPages) {\n      lowerBound = 0;\n      upperBound = pageCount;\n    }\n\n    const displayedPageNumbers: Array<number> = [];\n    for (let i = lowerBound; i < upperBound; i++) {\n      displayedPageNumbers.push(i + 1);\n    }\n    return displayedPageNumbers;\n  }\n\n  #setPageCount(): void {\n    if (this.itemCount === 0 || this.pageSize === 0) {\n      this.pageCount = 0;\n      return;\n    }\n\n    this.pageCount = Math.ceil(this.itemCount / this.pageSize);\n  }\n\n  #setDisplayedPages(): void {\n    this.displayedPages = this.#getDisplayedPageNumbers(\n      this.pageCount,\n      this.maxPages,\n      this.currentPage,\n    );\n  }\n\n  #moveFocusToTop(): void {\n    this.contentWrapper?.nativeElement.focus();\n  }\n}\n","<sky-wait\n  [ariaLabel]=\"\n    'skyux_paging_loading' | skyLibResources : currentPage : pageCount\n  \"\n  [isWaiting]=\"!!(isLoading | async)\"\n  [screenReaderCompletedText]=\"\n    'skyux_paging_loaded' | skyLibResources : currentPage\n  \"\n/>\n<div\n  class=\"sky-paging-content-wrapper\"\n  role=\"group\"\n  tabindex=\"-1\"\n  [attr.aria-label]=\"\n    'skyux_paging_page_label' | skyLibResources : currentPage : pageCount\n  \"\n  #contentWrapper\n>\n  <ng-content select=\"sky-paging-content\" />\n</div>\n<nav\n  *ngIf=\"pageCount > 1\"\n  class=\"sky-paging\"\n  [attr.aria-label]=\"pagingLabel || ('skyux_paging_label' | skyLibResources)\"\n>\n  <ul>\n    <li>\n      <button\n        class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-previous sky-box\"\n        sky-cmp-id=\"previous\"\n        type=\"button\"\n        [attr.aria-label]=\"'skyux_paging_previous' | skyLibResources\"\n        [disabled]=\"isPreviousButtonDisabled\"\n        (click)=\"previousPage()\"\n      >\n        <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-left\" />\n        <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-left\" />\n      </button>\n    </li>\n    <li *ngFor=\"let pageNumber of displayedPages\" class=\"sky-list-paging-link\">\n      <button\n        class=\"sky-btn sky-btn-default sky-paging-btn sky-box\"\n        type=\"button\"\n        [attr.aria-current]=\"currentPage === pageNumber ? 'page' : null\"\n        [attr.sky-cmp-id]=\"pageNumber\"\n        [attr.aria-label]=\"\n          'skyux_paging_page_link_aria_label' | skyLibResources : pageNumber\n        \"\n        [disabled]=\"currentPage === pageNumber\"\n        [ngClass]=\"{ 'sky-paging-current': currentPage === pageNumber }\"\n        (click)=\"setPage(pageNumber)\"\n      >\n        {{ pageNumber }}\n      </button>\n    </li>\n    <li>\n      <button\n        class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-next sky-box\"\n        sky-cmp-id=\"next\"\n        type=\"button\"\n        [attr.aria-label]=\"'skyux_paging_next' | skyLibResources\"\n        [disabled]=\"isNextButtonDisabled\"\n        (click)=\"nextPage()\"\n      >\n        <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-right\" />\n        <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-right\" />\n      </button>\n    </li>\n  </ul>\n</nav>\n"]}
150
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paging.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/lists/src/lib/modules/paging/paging.component.ts","../../../../../../../../libs/components/lists/src/lib/modules/paging/paging.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\n\nimport { BehaviorSubject } from 'rxjs';\n\nimport { SkyPagingContentChangeArgs } from './types/paging-content-change-args';\n\n@Component({\n  selector: 'sky-paging',\n  templateUrl: './paging.component.html',\n  styleUrls: ['./paging.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyPagingComponent implements OnChanges {\n  /**\n   * The page number of the current page. Page numbers start at 1 and increment.\n   */\n  @Input()\n  public currentPage = 1;\n\n  /**\n   * The total number of items across all pages.\n   */\n  @Input()\n  public itemCount = 0;\n\n  /**\n   * The maximum number of pages to display in the pagination control.\n   */\n  @Input()\n  public maxPages = 5;\n\n  /**\n   * The number of items to display per page.\n   */\n  @Input()\n  public pageSize = 10;\n\n  /**\n   * The label for the pagination control when an application includes\n   * multiple paging components on the same page. The label should be unique and descriptive\n   * to help users of assistive technology differentiate pagination controls\n   * and understand what each one does.\n   * @default \"Pagination\"\n   */\n  @Input()\n  public pagingLabel: string | undefined;\n\n  /**\n   * Fires when the current page changes and emits the new current page.\n   */\n  @Output()\n  public currentPageChange = new EventEmitter<number>();\n\n  /**\n   * Fires when the current page changes and emits the new current page with a function\n   * to call when loading the new page completes. Handling this event will display the\n   * wait component until the callback function is called, and focus will move to the top\n   * of the list for keyboard navigation if the list contents are placed inside the\n   * sky-paging-content element.\n   */\n  @Output()\n  public contentChange = new EventEmitter<SkyPagingContentChangeArgs>();\n\n  @ViewChild('contentWrapper', { read: ElementRef })\n  public contentWrapper: ElementRef | undefined;\n\n  public displayedPages: Array<number> = [];\n\n  public pageCount = 0;\n\n  protected isLoading = new BehaviorSubject(false);\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    this.setPage(this.currentPage, changes['currentPage']?.isFirstChange());\n  }\n\n  public setPage(pageNumber: number, forceContentChange?: boolean): void {\n    const previousPage = this.currentPage;\n\n    this.#setPageCount();\n\n    if (pageNumber < 1 || this.pageCount < 1) {\n      this.currentPage = 1;\n    } else if (pageNumber > this.pageCount) {\n      this.currentPage = this.pageCount;\n    } else {\n      this.currentPage = pageNumber;\n    }\n\n    this.#setDisplayedPages();\n\n    let doContentChange = forceContentChange;\n\n    if (previousPage !== this.currentPage) {\n      this.currentPageChange.emit(this.currentPage);\n      doContentChange = true;\n    }\n\n    if (doContentChange && this.contentChange.observed) {\n      this.#moveFocusToTop();\n      this.isLoading.next(true);\n\n      this.contentChange.emit({\n        currentPage: this.currentPage,\n        loadingComplete: () => this.isLoading.next(false),\n      });\n    }\n  }\n\n  public nextPage(): void {\n    this.setPage(this.currentPage + 1);\n  }\n\n  public previousPage(): void {\n    this.setPage(this.currentPage - 1);\n  }\n\n  public get isPreviousButtonDisabled(): boolean {\n    return this.currentPage === 1;\n  }\n\n  public get isNextButtonDisabled(): boolean {\n    return this.currentPage === this.pageCount;\n  }\n\n  #getDisplayedPageNumbers(\n    pageCount: number,\n    maxDisplayedPages: number,\n    pageNumber: number,\n  ): Array<number> {\n    const pageIndex = pageNumber - 1;\n    const pageBounds = Math.floor(maxDisplayedPages / 2);\n\n    let upperBound = pageIndex + pageBounds;\n    let lowerBound = pageIndex - pageBounds;\n    if (maxDisplayedPages % 2 !== 0) {\n      upperBound += 1;\n    }\n\n    // Wrap negative values to increase the upper bound\n    if (lowerBound < 0) {\n      upperBound -= lowerBound;\n      lowerBound = 0;\n    }\n    // Wrap overflow to decrease the lower bound\n    if (upperBound > pageCount) {\n      lowerBound -= upperBound - pageCount;\n      upperBound = pageCount;\n    }\n\n    // If both are the same ignore everything else and just display it all\n    if (pageCount < maxDisplayedPages) {\n      lowerBound = 0;\n      upperBound = pageCount;\n    }\n\n    const displayedPageNumbers: Array<number> = [];\n    for (let i = lowerBound; i < upperBound; i++) {\n      displayedPageNumbers.push(i + 1);\n    }\n    return displayedPageNumbers;\n  }\n\n  #setPageCount(): void {\n    if (this.itemCount === 0 || this.pageSize === 0) {\n      this.pageCount = 0;\n      return;\n    }\n\n    this.pageCount = Math.ceil(this.itemCount / this.pageSize);\n  }\n\n  #setDisplayedPages(): void {\n    this.displayedPages = this.#getDisplayedPageNumbers(\n      this.pageCount,\n      this.maxPages,\n      this.currentPage,\n    );\n  }\n\n  #moveFocusToTop(): void {\n    this.contentWrapper?.nativeElement.focus();\n  }\n}\n","<sky-wait\n  [ariaLabel]=\"\n    'skyux_paging_loading' | skyLibResources : currentPage : pageCount\n  \"\n  [isWaiting]=\"!!(isLoading | async)\"\n  [screenReaderCompletedText]=\"\n    'skyux_paging_loaded' | skyLibResources : currentPage\n  \"\n/>\n<div\n  class=\"sky-paging-content-wrapper\"\n  role=\"group\"\n  tabindex=\"-1\"\n  [attr.aria-label]=\"\n    'skyux_paging_page_label' | skyLibResources : currentPage : pageCount\n  \"\n  #contentWrapper\n>\n  <ng-content select=\"sky-paging-content\" />\n</div>\n<nav\n  *ngIf=\"pageCount > 1\"\n  class=\"sky-paging\"\n  [attr.aria-label]=\"pagingLabel || ('skyux_paging_label' | skyLibResources)\"\n>\n  <ul>\n    <li>\n      <button\n        class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-previous sky-box\"\n        sky-cmp-id=\"previous\"\n        type=\"button\"\n        [attr.aria-label]=\"'skyux_paging_previous' | skyLibResources\"\n        [disabled]=\"isPreviousButtonDisabled\"\n        (click)=\"previousPage()\"\n      >\n        <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-left\" />\n        <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-left\" />\n      </button>\n    </li>\n    <li *ngFor=\"let pageNumber of displayedPages\" class=\"sky-list-paging-link\">\n      <button\n        class=\"sky-btn sky-btn-default sky-paging-btn sky-box\"\n        type=\"button\"\n        [attr.aria-current]=\"currentPage === pageNumber ? 'page' : null\"\n        [attr.sky-cmp-id]=\"pageNumber\"\n        [attr.aria-label]=\"\n          'skyux_paging_page_link_aria_label' | skyLibResources : pageNumber\n        \"\n        [disabled]=\"currentPage === pageNumber\"\n        [ngClass]=\"{ 'sky-paging-current': currentPage === pageNumber }\"\n        (click)=\"setPage(pageNumber)\"\n      >\n        {{ pageNumber }}\n      </button>\n    </li>\n    <li>\n      <button\n        class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-next sky-box\"\n        sky-cmp-id=\"next\"\n        type=\"button\"\n        [attr.aria-label]=\"'skyux_paging_next' | skyLibResources\"\n        [disabled]=\"isNextButtonDisabled\"\n        (click)=\"nextPage()\"\n      >\n        <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-right\" />\n        <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-right\" />\n      </button>\n    </li>\n  </ul>\n</nav>\n"]}
@@ -7,21 +7,21 @@ import { SkyPagingContentComponent } from './paging-content.component';
7
7
  import { SkyPagingComponent } from './paging.component';
8
8
  import * as i0 from "@angular/core";
9
9
  export class SkyPagingModule {
10
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyPagingModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
11
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.9", ngImport: i0, type: SkyPagingModule, declarations: [SkyPagingComponent], imports: [CommonModule,
10
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyPagingModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
11
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.1.0", ngImport: i0, type: SkyPagingModule, declarations: [SkyPagingComponent], imports: [CommonModule,
12
12
  SkyIconModule,
13
13
  SkyListsResourcesModule,
14
14
  SkyPagingContentComponent,
15
15
  SkyThemeModule,
16
16
  SkyWaitModule], exports: [SkyPagingComponent, SkyPagingContentComponent] }); }
17
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyPagingModule, imports: [CommonModule,
17
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyPagingModule, imports: [CommonModule,
18
18
  SkyIconModule,
19
19
  SkyListsResourcesModule,
20
20
  SkyPagingContentComponent,
21
21
  SkyThemeModule,
22
22
  SkyWaitModule] }); }
23
23
  }
24
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyPagingModule, decorators: [{
24
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: SkyPagingModule, decorators: [{
25
25
  type: NgModule,
26
26
  args: [{
27
27
  declarations: [SkyPagingComponent],