@skyux/lists 7.0.0-beta.2 → 7.0.0-beta.4

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 (27) hide show
  1. package/documentation.json +423 -351
  2. package/esm2020/lib/modules/filter/filter-button.component.mjs +17 -5
  3. package/esm2020/lib/modules/filter/filter-summary-item.component.mjs +14 -5
  4. package/esm2020/lib/modules/infinite-scroll/infinite-scroll-dom-adapter.service.mjs +52 -60
  5. package/esm2020/lib/modules/infinite-scroll/infinite-scroll.component.mjs +51 -44
  6. package/esm2020/lib/modules/paging/paging.component.mjs +41 -40
  7. package/esm2020/testing/filter/filter-fixture-button.mjs +21 -15
  8. package/esm2020/testing/filter/filter-fixture-summary.mjs +11 -6
  9. package/esm2020/testing/filter/lists-filter-fixture-button.mjs +1 -1
  10. package/esm2020/testing/paging/paging-fixture.mjs +2 -2
  11. package/fesm2015/skyux-lists-testing.mjs +32 -21
  12. package/fesm2015/skyux-lists-testing.mjs.map +1 -1
  13. package/fesm2015/skyux-lists.mjs +167 -150
  14. package/fesm2015/skyux-lists.mjs.map +1 -1
  15. package/fesm2020/skyux-lists-testing.mjs +30 -21
  16. package/fesm2020/skyux-lists-testing.mjs.map +1 -1
  17. package/fesm2020/skyux-lists.mjs +167 -150
  18. package/fesm2020/skyux-lists.mjs.map +1 -1
  19. package/lib/modules/filter/filter-button.component.d.ts +9 -8
  20. package/lib/modules/filter/filter-summary-item.component.d.ts +3 -1
  21. package/lib/modules/infinite-scroll/infinite-scroll-dom-adapter.service.d.ts +3 -9
  22. package/lib/modules/infinite-scroll/infinite-scroll.component.d.ts +3 -10
  23. package/lib/modules/paging/paging.component.d.ts +2 -4
  24. package/package.json +10 -10
  25. package/testing/filter/filter-fixture-button.d.ts +1 -2
  26. package/testing/filter/filter-fixture-summary.d.ts +1 -2
  27. package/testing/filter/lists-filter-fixture-button.d.ts +2 -2
@@ -1,3 +1,5 @@
1
+ var _SkyFilterButtonComponent_defaultButtonId, _SkyFilterButtonComponent_filterButtonIdOrDefault;
2
+ import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
1
3
  import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
2
4
  import * as i0 from "@angular/core";
3
5
  import * as i1 from "@angular/common";
@@ -7,6 +9,12 @@ import * as i4 from "@skyux/i18n";
7
9
  let nextId = 0;
8
10
  export class SkyFilterButtonComponent {
9
11
  constructor() {
12
+ /**
13
+ * Indicates whether the filtering options are exposed.
14
+ * To support [accessibility rules for disclosures](https://www.w3.org/TR/wai-aria-practices-1.1/#disclosure),
15
+ * this property is necessary when using inline filters.
16
+ */
17
+ this.ariaExpanded = false;
10
18
  /**
11
19
  * Indicates whether to highlight the filter button to indicate that filters were applied.
12
20
  * We recommend setting this property to `true` when no indication of filtering is visible
@@ -25,26 +33,30 @@ export class SkyFilterButtonComponent {
25
33
  * Fires when the filter button is selected.
26
34
  */
27
35
  this.filterButtonClick = new EventEmitter();
36
+ _SkyFilterButtonComponent_defaultButtonId.set(this, void 0);
37
+ _SkyFilterButtonComponent_filterButtonIdOrDefault.set(this, void 0);
38
+ __classPrivateFieldSet(this, _SkyFilterButtonComponent_filterButtonIdOrDefault, __classPrivateFieldSet(this, _SkyFilterButtonComponent_defaultButtonId, `sky-filter-button-${++nextId}`, "f"), "f");
28
39
  }
29
40
  /**
30
41
  * Specifies an ID for the filter button.
31
42
  */
32
43
  get filterButtonId() {
33
- return this._filterButtonId || `sky-filter-button-${++nextId}`;
44
+ return __classPrivateFieldGet(this, _SkyFilterButtonComponent_filterButtonIdOrDefault, "f");
34
45
  }
35
46
  set filterButtonId(value) {
36
- this._filterButtonId = value;
47
+ __classPrivateFieldSet(this, _SkyFilterButtonComponent_filterButtonIdOrDefault, value || __classPrivateFieldGet(this, _SkyFilterButtonComponent_defaultButtonId, "f"), "f");
37
48
  }
38
49
  filterButtonOnClick() {
39
- this.filterButtonClick.emit(undefined);
50
+ this.filterButtonClick.emit();
40
51
  }
41
52
  }
53
+ _SkyFilterButtonComponent_defaultButtonId = new WeakMap(), _SkyFilterButtonComponent_filterButtonIdOrDefault = new WeakMap();
42
54
  SkyFilterButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyFilterButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
43
55
  SkyFilterButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: SkyFilterButtonComponent, selector: "sky-filter-button", inputs: { filterButtonId: "filterButtonId", ariaControls: "ariaControls", ariaExpanded: "ariaExpanded", 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]=\"'skyux_filter_button_title' | skyLibResources\"\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\"> </sky-icon>\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"filter\" iconType=\"skyux\"></sky-icon>\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,.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,.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,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:hover,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:focus,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active.sky-btn-focus,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:active,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active.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,.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,.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,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:hover,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:hover:hover,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:hover:focus,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:hover.sky-btn-focus,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:hover:active,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:hover.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,.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,.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,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:focus,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:focus:hover,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:focus:focus,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:focus.sky-btn-focus,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:focus:active,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:focus.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,.sky-theme-modern.sky-filter-btn-active:hover:focus,.sky-theme-modern.sky-filter-btn-active:focus:focus{outline:none}.sky-theme-modern.sky-filter-btn-active:focus:not(:active),.sky-theme-modern.sky-filter-btn-active:hover:focus:not(:active),.sky-theme-modern.sky-filter-btn-active:focus:focus: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: i4.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
44
56
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyFilterButtonComponent, decorators: [{
45
57
  type: Component,
46
58
  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]=\"'skyux_filter_button_title' | skyLibResources\"\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\"> </sky-icon>\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"filter\" iconType=\"skyux\"></sky-icon>\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,.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,.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,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:hover,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:focus,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active.sky-btn-focus,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:active,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active.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,.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,.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,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:hover,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:hover:hover,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:hover:focus,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:hover.sky-btn-focus,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:hover:active,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:hover.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,.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,.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,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:focus,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:focus:hover,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:focus:focus,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:focus.sky-btn-focus,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:focus:active,fieldset[disabled] .sky-theme-modern.sky-filter-btn-active:focus.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,.sky-theme-modern.sky-filter-btn-active:hover:focus,.sky-theme-modern.sky-filter-btn-active:focus:focus{outline:none}.sky-theme-modern.sky-filter-btn-active:focus:not(:active),.sky-theme-modern.sky-filter-btn-active:hover:focus:not(:active),.sky-theme-modern.sky-filter-btn-active:focus:focus: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"] }]
47
- }], propDecorators: { filterButtonId: [{
59
+ }], ctorParameters: function () { return []; }, propDecorators: { filterButtonId: [{
48
60
  type: Input
49
61
  }], ariaControls: [{
50
62
  type: Input
@@ -59,4 +71,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
59
71
  }], filterButtonClick: [{
60
72
  type: Output
61
73
  }] } });
62
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWJ1dHRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGlzdHMvc3JjL2xpYi9tb2R1bGVzL2ZpbHRlci9maWx0ZXItYnV0dG9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9saXN0cy9zcmMvbGliL21vZHVsZXMvZmlsdGVyL2ZpbHRlci1idXR0b24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsWUFBWSxFQUNaLEtBQUssRUFDTCxNQUFNLEdBQ1AsTUFBTSxlQUFlLENBQUM7Ozs7OztBQUV2QixJQUFJLE1BQU0sR0FBRyxDQUFDLENBQUM7QUFRZixNQUFNLE9BQU8sd0JBQXdCO0lBTnJDO1FBbUNFOzs7O1dBSUc7UUFFSSxXQUFNLEdBQUcsS0FBSyxDQUFDO1FBRXRCOztXQUVHO1FBRUksYUFBUSxHQUFHLEtBQUssQ0FBQztRQUV4Qjs7V0FFRztRQUVJLG1CQUFjLEdBQUcsS0FBSyxDQUFDO1FBRTlCOztXQUVHO1FBRUksc0JBQWlCLEdBQXNCLElBQUksWUFBWSxFQUFFLENBQUM7S0FPbEU7SUEzREM7O09BRUc7SUFDSCxJQUNXLGNBQWM7UUFDdkIsT0FBTyxJQUFJLENBQUMsZUFBZSxJQUFJLHFCQUFxQixFQUFFLE1BQU0sRUFBRSxDQUFDO0lBQ2pFLENBQUM7SUFDRCxJQUFXLGNBQWMsQ0FBQyxLQUFhO1FBQ3JDLElBQUksQ0FBQyxlQUFlLEdBQUcsS0FBSyxDQUFDO0lBQy9CLENBQUM7SUErQ00sbUJBQW1CO1FBQ3hCLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDekMsQ0FBQzs7cUhBM0RVLHdCQUF3Qjt5R0FBeEIsd0JBQXdCLGtTQ2hCckMsbzJCQXdCQTsyRkRSYSx3QkFBd0I7a0JBTnBDLFNBQVM7K0JBQ0UsbUJBQW1CLG1CQUdaLHVCQUF1QixDQUFDLE1BQU07OEJBT3BDLGNBQWM7c0JBRHhCLEtBQUs7Z0JBZUMsWUFBWTtzQkFEbEIsS0FBSztnQkFTQyxZQUFZO3NCQURsQixLQUFLO2dCQVNDLE1BQU07c0JBRFosS0FBSztnQkFPQyxRQUFRO3NCQURkLEtBQUs7Z0JBT0MsY0FBYztzQkFEcEIsS0FBSztnQkFPQyxpQkFBaUI7c0JBRHZCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBFdmVudEVtaXR0ZXIsXG4gIElucHV0LFxuICBPdXRwdXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5sZXQgbmV4dElkID0gMDtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnc2t5LWZpbHRlci1idXR0b24nLFxuICBzdHlsZVVybHM6IFsnLi9maWx0ZXItYnV0dG9uLmNvbXBvbmVudC5zY3NzJ10sXG4gIHRlbXBsYXRlVXJsOiAnLi9maWx0ZXItYnV0dG9uLmNvbXBvbmVudC5odG1sJyxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIFNreUZpbHRlckJ1dHRvbkNvbXBvbmVudCB7XG4gIC8qKlxuICAgKiBTcGVjaWZpZXMgYW4gSUQgZm9yIHRoZSBmaWx0ZXIgYnV0dG9uLlxuICAgKi9cbiAgQElucHV0KClcbiAgcHVibGljIGdldCBmaWx0ZXJCdXR0b25JZCgpIHtcbiAgICByZXR1cm4gdGhpcy5fZmlsdGVyQnV0dG9uSWQgfHwgYHNreS1maWx0ZXItYnV0dG9uLSR7KytuZXh0SWR9YDtcbiAgfVxuICBwdWJsaWMgc2V0IGZpbHRlckJ1dHRvbklkKHZhbHVlOiBzdHJpbmcpIHtcbiAgICB0aGlzLl9maWx0ZXJCdXR0b25JZCA9IHZhbHVlO1xuICB9XG5cbiAgLyoqXG4gICAqIFNwZWNpZmllcyBhbiBJRCB0byBpZGVudGlmeSB0aGUgZWxlbWVudCB0aGF0IGNvbnRhaW5zXG4gICAqIHRoZSBmaWx0ZXJpbmcgb3B0aW9ucyB0aGF0IHRoZSBmaWx0ZXIgYnV0dG9uIGV4cG9zZXMuXG4gICAqIFRvIHN1cHBvcnQgW2FjY2Vzc2liaWxpdHkgcnVsZXMgZm9yIGRpc2Nsb3N1cmVzXShodHRwczovL3d3dy53My5vcmcvVFIvd2FpLWFyaWEtcHJhY3RpY2VzLTEuMS8jZGlzY2xvc3VyZSksXG4gICAqIHRoaXMgcHJvcGVydHkgaXMgbmVjZXNzYXJ5IHdoZW4gdXNpbmcgaW5saW5lIGZpbHRlcnMuXG4gICAqL1xuICBASW5wdXQoKVxuICBwdWJsaWMgYXJpYUNvbnRyb2xzOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEluZGljYXRlcyB3aGV0aGVyIHRoZSBmaWx0ZXJpbmcgb3B0aW9ucyBhcmUgZXhwb3NlZC5cbiAgICogVG8gc3VwcG9ydCBbYWNjZXNzaWJpbGl0eSBydWxlcyBmb3IgZGlzY2xvc3VyZXNdKGh0dHBzOi8vd3d3LnczLm9yZy9UUi93YWktYXJpYS1wcmFjdGljZXMtMS4xLyNkaXNjbG9zdXJlKSxcbiAgICogdGhpcyBwcm9wZXJ0eSBpcyBuZWNlc3Nhcnkgd2hlbiB1c2luZyBpbmxpbmUgZmlsdGVycy5cbiAgICovXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBhcmlhRXhwYW5kZWQ6IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIEluZGljYXRlcyB3aGV0aGVyIHRvIGhpZ2hsaWdodCB0aGUgZmlsdGVyIGJ1dHRvbiB0byBpbmRpY2F0ZSB0aGF0IGZpbHRlcnMgd2VyZSBhcHBsaWVkLlxuICAgKiBXZSByZWNvbW1lbmQgc2V0dGluZyB0aGlzIHByb3BlcnR5IHRvIGB0cnVlYCB3aGVuIG5vIGluZGljYXRpb24gb2YgZmlsdGVyaW5nIGlzIHZpc2libGVcbiAgICogdG8gdXNlcnMuIEZvciBleGFtcGxlLCBzZXQgaXQgdG8gYHRydWVgIGlmIHlvdSBkbyBub3QgZGlzcGxheSB0aGUgZmlsdGVyIHN1bW1hcnkuXG4gICAqL1xuICBASW5wdXQoKVxuICBwdWJsaWMgYWN0aXZlID0gZmFsc2U7XG5cbiAgLyoqXG4gICAqIEluZGljYXRlcyB3aGV0aGVyIHRvIGRpc2FibGUgdGhlIGZpbHRlciBidXR0b24uXG4gICAqL1xuICBASW5wdXQoKVxuICBwdWJsaWMgZGlzYWJsZWQgPSBmYWxzZTtcblxuICAvKipcbiAgICogSW5kaWNhdGVzIHdoZXRoZXIgdG8gZGlzcGxheSBhICoqRmlsdGVyKiogbGFiZWwgYmVzaWRlIHRoZSBpY29uIG9uIHRoZSBmaWx0ZXIgYnV0dG9uLlxuICAgKi9cbiAgQElucHV0KClcbiAgcHVibGljIHNob3dCdXR0b25UZXh0ID0gZmFsc2U7XG5cbiAgLyoqXG4gICAqIEZpcmVzIHdoZW4gdGhlIGZpbHRlciBidXR0b24gaXMgc2VsZWN0ZWQuXG4gICAqL1xuICBAT3V0cHV0KClcbiAgcHVibGljIGZpbHRlckJ1dHRvbkNsaWNrOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcblxuICBwcml2YXRlIF9maWx0ZXJCdXR0b25JZDogc3RyaW5nO1xuXG4gIHB1YmxpYyBmaWx0ZXJCdXR0b25PbkNsaWNrKCk6IHZvaWQge1xuICAgIHRoaXMuZmlsdGVyQnV0dG9uQ2xpY2suZW1pdCh1bmRlZmluZWQpO1xuICB9XG59XG4iLCI8YnV0dG9uXG4gIGNsYXNzPVwic2t5LWJ0biBza3ktYnRuLWRlZmF1bHQgc2t5LWZpbHRlci1idG5cIlxuICB0eXBlPVwiYnV0dG9uXCJcbiAgW2F0dHIuYXJpYS1jb250cm9sc109XCJhcmlhQ29udHJvbHNcIlxuICBbYXR0ci5hcmlhLWV4cGFuZGVkXT1cImFyaWFFeHBhbmRlZFwiXG4gIFthdHRyLmFyaWEtbGFiZWxdPVwiJ3NreXV4X2ZpbHRlcl9idXR0b25fdGl0bGUnIHwgc2t5TGliUmVzb3VyY2VzXCJcbiAgW2F0dHIudGl0bGVdPVwiJ3NreXV4X2ZpbHRlcl9idXR0b25fdGl0bGUnIHwgc2t5TGliUmVzb3VyY2VzXCJcbiAgW2Rpc2FibGVkXT1cImRpc2FibGVkXCJcbiAgW2lkXT1cImZpbHRlckJ1dHRvbklkXCJcbiAgW25nQ2xhc3NdPVwie1xuICAgICdza3ktZmlsdGVyLWJ0bi1hY3RpdmUnOiBhY3RpdmVcbiAgfVwiXG4gIFtza3lUaGVtZUNsYXNzXT1cIntcbiAgICAnc2t5LXJvdW5kZWQtY29ybmVycyc6ICdkZWZhdWx0JyxcbiAgICAnc2t5LXRoZW1lLW1vZGVybic6ICdtb2Rlcm4nXG4gIH1cIlxuICAoY2xpY2spPVwiZmlsdGVyQnV0dG9uT25DbGljaygpXCJcbj5cbiAgPHNreS1pY29uICpza3lUaGVtZUlmPVwiJ2RlZmF1bHQnXCIgaWNvbj1cImZpbHRlclwiIHNpemU9XCJsZ1wiPiA8L3NreS1pY29uPlxuICA8c2t5LWljb24gKnNreVRoZW1lSWY9XCInbW9kZXJuJ1wiIGljb249XCJmaWx0ZXJcIiBpY29uVHlwZT1cInNreXV4XCI+PC9za3ktaWNvbj5cbiAgPHNwYW4gKm5nSWY9XCJzaG93QnV0dG9uVGV4dFwiIGNsYXNzPVwic2t5LWZpbHRlci1idG4tdGV4dFwiPlxuICAgIHt7ICdza3l1eF9maWx0ZXJfYnV0dG9uX3RpdGxlJyB8IHNreUxpYlJlc291cmNlcyB9fVxuICA8L3NwYW4+XG48L2J1dHRvbj5cbiJdfQ==
74
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWJ1dHRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGlzdHMvc3JjL2xpYi9tb2R1bGVzL2ZpbHRlci9maWx0ZXItYnV0dG9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9saXN0cy9zcmMvbGliL21vZHVsZXMvZmlsdGVyL2ZpbHRlci1idXR0b24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxZQUFZLEVBQ1osS0FBSyxFQUNMLE1BQU0sR0FDUCxNQUFNLGVBQWUsQ0FBQzs7Ozs7O0FBRXZCLElBQUksTUFBTSxHQUFHLENBQUMsQ0FBQztBQVFmLE1BQU0sT0FBTyx3QkFBd0I7SUF1RG5DO1FBbENBOzs7O1dBSUc7UUFFSSxpQkFBWSxHQUF3QixLQUFLLENBQUM7UUFFakQ7Ozs7V0FJRztRQUVJLFdBQU0sR0FBd0IsS0FBSyxDQUFDO1FBRTNDOztXQUVHO1FBRUksYUFBUSxHQUF3QixLQUFLLENBQUM7UUFFN0M7O1dBRUc7UUFFSSxtQkFBYyxHQUF3QixLQUFLLENBQUM7UUFFbkQ7O1dBRUc7UUFFSSxzQkFBaUIsR0FBdUIsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQU9sRSw0REFBeUI7UUFDekIsb0VBQWlDO1FBTC9CLHVCQUFBLElBQUkscURBQ0YsdUJBQUEsSUFBSSw2Q0FBb0IscUJBQXFCLEVBQUUsTUFBTSxFQUFFLE1BQUEsTUFBQSxDQUFDO0lBQzVELENBQUM7SUF6REQ7O09BRUc7SUFDSCxJQUNXLGNBQWM7UUFDdkIsT0FBTyx1QkFBQSxJQUFJLHlEQUF5QixDQUFDO0lBQ3ZDLENBQUM7SUFDRCxJQUFXLGNBQWMsQ0FBQyxLQUF5QjtRQUNqRCx1QkFBQSxJQUFJLHFEQUE0QixLQUFLLElBQUksdUJBQUEsSUFBSSxpREFBaUIsTUFBQSxDQUFDO0lBQ2pFLENBQUM7SUFxRE0sbUJBQW1CO1FBQ3hCLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNoQyxDQUFDOzs7cUhBakVVLHdCQUF3Qjt5R0FBeEIsd0JBQXdCLGtTQ2hCckMsbzJCQXdCQTsyRkRSYSx3QkFBd0I7a0JBTnBDLFNBQVM7K0JBQ0UsbUJBQW1CLG1CQUdaLHVCQUF1QixDQUFDLE1BQU07MEVBT3BDLGNBQWM7c0JBRHhCLEtBQUs7Z0JBZUMsWUFBWTtzQkFEbEIsS0FBSztnQkFTQyxZQUFZO3NCQURsQixLQUFLO2dCQVNDLE1BQU07c0JBRFosS0FBSztnQkFPQyxRQUFRO3NCQURkLEtBQUs7Z0JBT0MsY0FBYztzQkFEcEIsS0FBSztnQkFPQyxpQkFBaUI7c0JBRHZCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBFdmVudEVtaXR0ZXIsXG4gIElucHV0LFxuICBPdXRwdXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5sZXQgbmV4dElkID0gMDtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnc2t5LWZpbHRlci1idXR0b24nLFxuICBzdHlsZVVybHM6IFsnLi9maWx0ZXItYnV0dG9uLmNvbXBvbmVudC5zY3NzJ10sXG4gIHRlbXBsYXRlVXJsOiAnLi9maWx0ZXItYnV0dG9uLmNvbXBvbmVudC5odG1sJyxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIFNreUZpbHRlckJ1dHRvbkNvbXBvbmVudCB7XG4gIC8qKlxuICAgKiBTcGVjaWZpZXMgYW4gSUQgZm9yIHRoZSBmaWx0ZXIgYnV0dG9uLlxuICAgKi9cbiAgQElucHV0KClcbiAgcHVibGljIGdldCBmaWx0ZXJCdXR0b25JZCgpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLiNmaWx0ZXJCdXR0b25JZE9yRGVmYXVsdDtcbiAgfVxuICBwdWJsaWMgc2V0IGZpbHRlckJ1dHRvbklkKHZhbHVlOiBzdHJpbmcgfCB1bmRlZmluZWQpIHtcbiAgICB0aGlzLiNmaWx0ZXJCdXR0b25JZE9yRGVmYXVsdCA9IHZhbHVlIHx8IHRoaXMuI2RlZmF1bHRCdXR0b25JZDtcbiAgfVxuXG4gIC8qKlxuICAgKiBTcGVjaWZpZXMgYW4gSUQgdG8gaWRlbnRpZnkgdGhlIGVsZW1lbnQgdGhhdCBjb250YWluc1xuICAgKiB0aGUgZmlsdGVyaW5nIG9wdGlvbnMgdGhhdCB0aGUgZmlsdGVyIGJ1dHRvbiBleHBvc2VzLlxuICAgKiBUbyBzdXBwb3J0IFthY2Nlc3NpYmlsaXR5IHJ1bGVzIGZvciBkaXNjbG9zdXJlc10oaHR0cHM6Ly93d3cudzMub3JnL1RSL3dhaS1hcmlhLXByYWN0aWNlcy0xLjEvI2Rpc2Nsb3N1cmUpLFxuICAgKiB0aGlzIHByb3BlcnR5IGlzIG5lY2Vzc2FyeSB3aGVuIHVzaW5nIGlubGluZSBmaWx0ZXJzLlxuICAgKi9cbiAgQElucHV0KClcbiAgcHVibGljIGFyaWFDb250cm9sczogc3RyaW5nIHwgdW5kZWZpbmVkO1xuXG4gIC8qKlxuICAgKiBJbmRpY2F0ZXMgd2hldGhlciB0aGUgZmlsdGVyaW5nIG9wdGlvbnMgYXJlIGV4cG9zZWQuXG4gICAqIFRvIHN1cHBvcnQgW2FjY2Vzc2liaWxpdHkgcnVsZXMgZm9yIGRpc2Nsb3N1cmVzXShodHRwczovL3d3dy53My5vcmcvVFIvd2FpLWFyaWEtcHJhY3RpY2VzLTEuMS8jZGlzY2xvc3VyZSksXG4gICAqIHRoaXMgcHJvcGVydHkgaXMgbmVjZXNzYXJ5IHdoZW4gdXNpbmcgaW5saW5lIGZpbHRlcnMuXG4gICAqL1xuICBASW5wdXQoKVxuICBwdWJsaWMgYXJpYUV4cGFuZGVkOiBib29sZWFuIHwgdW5kZWZpbmVkID0gZmFsc2U7XG5cbiAgLyoqXG4gICAqIEluZGljYXRlcyB3aGV0aGVyIHRvIGhpZ2hsaWdodCB0aGUgZmlsdGVyIGJ1dHRvbiB0byBpbmRpY2F0ZSB0aGF0IGZpbHRlcnMgd2VyZSBhcHBsaWVkLlxuICAgKiBXZSByZWNvbW1lbmQgc2V0dGluZyB0aGlzIHByb3BlcnR5IHRvIGB0cnVlYCB3aGVuIG5vIGluZGljYXRpb24gb2YgZmlsdGVyaW5nIGlzIHZpc2libGVcbiAgICogdG8gdXNlcnMuIEZvciBleGFtcGxlLCBzZXQgaXQgdG8gYHRydWVgIGlmIHlvdSBkbyBub3QgZGlzcGxheSB0aGUgZmlsdGVyIHN1bW1hcnkuXG4gICAqL1xuICBASW5wdXQoKVxuICBwdWJsaWMgYWN0aXZlOiBib29sZWFuIHwgdW5kZWZpbmVkID0gZmFsc2U7XG5cbiAgLyoqXG4gICAqIEluZGljYXRlcyB3aGV0aGVyIHRvIGRpc2FibGUgdGhlIGZpbHRlciBidXR0b24uXG4gICAqL1xuICBASW5wdXQoKVxuICBwdWJsaWMgZGlzYWJsZWQ6IGJvb2xlYW4gfCB1bmRlZmluZWQgPSBmYWxzZTtcblxuICAvKipcbiAgICogSW5kaWNhdGVzIHdoZXRoZXIgdG8gZGlzcGxheSBhICoqRmlsdGVyKiogbGFiZWwgYmVzaWRlIHRoZSBpY29uIG9uIHRoZSBmaWx0ZXIgYnV0dG9uLlxuICAgKi9cbiAgQElucHV0KClcbiAgcHVibGljIHNob3dCdXR0b25UZXh0OiBib29sZWFuIHwgdW5kZWZpbmVkID0gZmFsc2U7XG5cbiAgLyoqXG4gICAqIEZpcmVzIHdoZW4gdGhlIGZpbHRlciBidXR0b24gaXMgc2VsZWN0ZWQuXG4gICAqL1xuICBAT3V0cHV0KClcbiAgcHVibGljIGZpbHRlckJ1dHRvbkNsaWNrOiBFdmVudEVtaXR0ZXI8dm9pZD4gPSBuZXcgRXZlbnRFbWl0dGVyKCk7XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy4jZmlsdGVyQnV0dG9uSWRPckRlZmF1bHQgPVxuICAgICAgdGhpcy4jZGVmYXVsdEJ1dHRvbklkID0gYHNreS1maWx0ZXItYnV0dG9uLSR7KytuZXh0SWR9YDtcbiAgfVxuXG4gICNkZWZhdWx0QnV0dG9uSWQ6IHN0cmluZztcbiAgI2ZpbHRlckJ1dHRvbklkT3JEZWZhdWx0OiBzdHJpbmc7XG5cbiAgcHVibGljIGZpbHRlckJ1dHRvbk9uQ2xpY2soKTogdm9pZCB7XG4gICAgdGhpcy5maWx0ZXJCdXR0b25DbGljay5lbWl0KCk7XG4gIH1cbn1cbiIsIjxidXR0b25cbiAgY2xhc3M9XCJza3ktYnRuIHNreS1idG4tZGVmYXVsdCBza3ktZmlsdGVyLWJ0blwiXG4gIHR5cGU9XCJidXR0b25cIlxuICBbYXR0ci5hcmlhLWNvbnRyb2xzXT1cImFyaWFDb250cm9sc1wiXG4gIFthdHRyLmFyaWEtZXhwYW5kZWRdPVwiYXJpYUV4cGFuZGVkXCJcbiAgW2F0dHIuYXJpYS1sYWJlbF09XCInc2t5dXhfZmlsdGVyX2J1dHRvbl90aXRsZScgfCBza3lMaWJSZXNvdXJjZXNcIlxuICBbYXR0ci50aXRsZV09XCInc2t5dXhfZmlsdGVyX2J1dHRvbl90aXRsZScgfCBza3lMaWJSZXNvdXJjZXNcIlxuICBbZGlzYWJsZWRdPVwiZGlzYWJsZWRcIlxuICBbaWRdPVwiZmlsdGVyQnV0dG9uSWRcIlxuICBbbmdDbGFzc109XCJ7XG4gICAgJ3NreS1maWx0ZXItYnRuLWFjdGl2ZSc6IGFjdGl2ZVxuICB9XCJcbiAgW3NreVRoZW1lQ2xhc3NdPVwie1xuICAgICdza3ktcm91bmRlZC1jb3JuZXJzJzogJ2RlZmF1bHQnLFxuICAgICdza3ktdGhlbWUtbW9kZXJuJzogJ21vZGVybidcbiAgfVwiXG4gIChjbGljayk9XCJmaWx0ZXJCdXR0b25PbkNsaWNrKClcIlxuPlxuICA8c2t5LWljb24gKnNreVRoZW1lSWY9XCInZGVmYXVsdCdcIiBpY29uPVwiZmlsdGVyXCIgc2l6ZT1cImxnXCI+IDwvc2t5LWljb24+XG4gIDxza3ktaWNvbiAqc2t5VGhlbWVJZj1cIidtb2Rlcm4nXCIgaWNvbj1cImZpbHRlclwiIGljb25UeXBlPVwic2t5dXhcIj48L3NreS1pY29uPlxuICA8c3BhbiAqbmdJZj1cInNob3dCdXR0b25UZXh0XCIgY2xhc3M9XCJza3ktZmlsdGVyLWJ0bi10ZXh0XCI+XG4gICAge3sgJ3NreXV4X2ZpbHRlcl9idXR0b25fdGl0bGUnIHwgc2t5TGliUmVzb3VyY2VzIH19XG4gIDwvc3Bhbj5cbjwvYnV0dG9uPlxuIl19
@@ -1,3 +1,5 @@
1
+ var _SkyFilterSummaryItemComponent__dismissible;
2
+ import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
1
3
  import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
2
4
  import * as i0 from "@angular/core";
3
5
  import * as i1 from "@skyux/indicators";
@@ -7,10 +9,6 @@ import * as i2 from "@skyux/i18n";
7
9
  */
8
10
  export class SkyFilterSummaryItemComponent {
9
11
  constructor() {
10
- /**
11
- * Indicates whether the filter summary item has a close button.
12
- */
13
- this.dismissible = true;
14
12
  /**
15
13
  * Fires when the summary item close button is selected.
16
14
  */
@@ -19,6 +17,16 @@ export class SkyFilterSummaryItemComponent {
19
17
  * Fires when the summary item is selected.
20
18
  */
21
19
  this.itemClick = new EventEmitter();
20
+ _SkyFilterSummaryItemComponent__dismissible.set(this, true);
21
+ }
22
+ /**
23
+ * Indicates whether the filter summary item has a close button.
24
+ */
25
+ get dismissible() {
26
+ return __classPrivateFieldGet(this, _SkyFilterSummaryItemComponent__dismissible, "f");
27
+ }
28
+ set dismissible(value) {
29
+ __classPrivateFieldSet(this, _SkyFilterSummaryItemComponent__dismissible, value !== false, "f");
22
30
  }
23
31
  onItemDismiss() {
24
32
  this.dismiss.emit();
@@ -30,6 +38,7 @@ export class SkyFilterSummaryItemComponent {
30
38
  this.itemClick.emit();
31
39
  }
32
40
  }
41
+ _SkyFilterSummaryItemComponent__dismissible = new WeakMap();
33
42
  SkyFilterSummaryItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyFilterSummaryItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
34
43
  SkyFilterSummaryItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.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> </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"], outputs: ["dismiss", "tokenFocus"] }, { kind: "pipe", type: i2.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
35
44
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyFilterSummaryItemComponent, decorators: [{
@@ -42,4 +51,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
42
51
  }], itemClick: [{
43
52
  type: Output
44
53
  }] } });
45
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLXN1bW1hcnktaXRlbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGlzdHMvc3JjL2xpYi9tb2R1bGVzL2ZpbHRlci9maWx0ZXItc3VtbWFyeS1pdGVtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9saXN0cy9zcmMvbGliL21vZHVsZXMvZmlsdGVyL2ZpbHRlci1zdW1tYXJ5LWl0ZW0uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsWUFBWSxFQUNaLEtBQUssRUFDTCxNQUFNLEdBQ1AsTUFBTSxlQUFlLENBQUM7Ozs7QUFFdkI7O0dBRUc7QUFPSCxNQUFNLE9BQU8sNkJBQTZCO0lBTjFDO1FBT0U7O1dBRUc7UUFFSSxnQkFBVyxHQUFHLElBQUksQ0FBQztRQUUxQjs7V0FFRztRQUVJLFlBQU8sR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO1FBRTFDOztXQUVHO1FBRUksY0FBUyxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7S0FhN0M7SUFYUSxhQUFhO1FBQ2xCLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDdEIsQ0FBQztJQUVNLFdBQVc7UUFDaEIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUN4QixDQUFDO0lBRU0sY0FBYztRQUNuQixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3hCLENBQUM7OzBIQTdCVSw2QkFBNkI7OEdBQTdCLDZCQUE2QixnS0NqQjFDLDJVQWFBOzJGRElhLDZCQUE2QjtrQkFOekMsU0FBUzsrQkFDRSx5QkFBeUIsbUJBR2xCLHVCQUF1QixDQUFDLE1BQU07OEJBT3hDLFdBQVc7c0JBRGpCLEtBQUs7Z0JBT0MsT0FBTztzQkFEYixNQUFNO2dCQU9BLFNBQVM7c0JBRGYsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIEV2ZW50RW1pdHRlcixcbiAgSW5wdXQsXG4gIE91dHB1dCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKlxuICogU3BlY2lmaWVzIGEgZmlsdGVyIHRoYXQgd2FzIGFwcGxpZWQuXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NreS1maWx0ZXItc3VtbWFyeS1pdGVtJyxcbiAgc3R5bGVVcmxzOiBbJy4vZmlsdGVyLXN1bW1hcnktaXRlbS5jb21wb25lbnQuc2NzcyddLFxuICB0ZW1wbGF0ZVVybDogJy4vZmlsdGVyLXN1bW1hcnktaXRlbS5jb21wb25lbnQuaHRtbCcsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lGaWx0ZXJTdW1tYXJ5SXRlbUNvbXBvbmVudCB7XG4gIC8qKlxuICAgKiBJbmRpY2F0ZXMgd2hldGhlciB0aGUgZmlsdGVyIHN1bW1hcnkgaXRlbSBoYXMgYSBjbG9zZSBidXR0b24uXG4gICAqL1xuICBASW5wdXQoKVxuICBwdWJsaWMgZGlzbWlzc2libGUgPSB0cnVlO1xuXG4gIC8qKlxuICAgKiBGaXJlcyB3aGVuIHRoZSBzdW1tYXJ5IGl0ZW0gY2xvc2UgYnV0dG9uIGlzIHNlbGVjdGVkLlxuICAgKi9cbiAgQE91dHB1dCgpXG4gIHB1YmxpYyBkaXNtaXNzID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuXG4gIC8qKlxuICAgKiBGaXJlcyB3aGVuIHRoZSBzdW1tYXJ5IGl0ZW0gaXMgc2VsZWN0ZWQuXG4gICAqL1xuICBAT3V0cHV0KClcbiAgcHVibGljIGl0ZW1DbGljayA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcblxuICBwdWJsaWMgb25JdGVtRGlzbWlzcygpOiB2b2lkIHtcbiAgICB0aGlzLmRpc21pc3MuZW1pdCgpO1xuICB9XG5cbiAgcHVibGljIG9uSXRlbUNsaWNrKCk6IHZvaWQge1xuICAgIHRoaXMuaXRlbUNsaWNrLmVtaXQoKTtcbiAgfVxuXG4gIHB1YmxpYyBvbkl0ZW1LZXlwcmVzcygpOiB2b2lkIHtcbiAgICB0aGlzLml0ZW1DbGljay5lbWl0KCk7XG4gIH1cbn1cbiIsIjxkaXZcbiAgY2xhc3M9XCJza3ktZmlsdGVyLXN1bW1hcnktaXRlbVwiXG4gIChjbGljayk9XCJvbkl0ZW1DbGljaygpXCJcbiAgKGtleXByZXNzLmVudGVyKT1cIm9uSXRlbUtleXByZXNzKClcIlxuPlxuICA8c2t5LXRva2VuXG4gICAgW2FyaWFMYWJlbF09XCInc2t5dXhfZmlsdGVyX3N1bW1hcnlfY2xvc2UnIHwgc2t5TGliUmVzb3VyY2VzXCJcbiAgICBbZGlzbWlzc2libGVdPVwiZGlzbWlzc2libGVcIlxuICAgIChkaXNtaXNzKT1cIm9uSXRlbURpc21pc3MoKVwiXG4gID5cbiAgICA8bmctY29udGVudD4gPC9uZy1jb250ZW50PlxuICA8L3NreS10b2tlbj5cbjwvZGl2PlxuIl19
54
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLXN1bW1hcnktaXRlbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGlzdHMvc3JjL2xpYi9tb2R1bGVzL2ZpbHRlci9maWx0ZXItc3VtbWFyeS1pdGVtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9saXN0cy9zcmMvbGliL21vZHVsZXMvZmlsdGVyL2ZpbHRlci1zdW1tYXJ5LWl0ZW0uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxZQUFZLEVBQ1osS0FBSyxFQUNMLE1BQU0sR0FDUCxNQUFNLGVBQWUsQ0FBQzs7OztBQUV2Qjs7R0FFRztBQU9ILE1BQU0sT0FBTyw2QkFBNkI7SUFOMUM7UUFtQkU7O1dBRUc7UUFFSSxZQUFPLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUUxQzs7V0FFRztRQUVJLGNBQVMsR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO1FBRTVDLHNEQUFnQixJQUFJLEVBQUM7S0FhdEI7SUFyQ0M7O09BRUc7SUFDSCxJQUNXLFdBQVc7UUFDcEIsT0FBTyx1QkFBQSxJQUFJLG1EQUFjLENBQUM7SUFDNUIsQ0FBQztJQUVELElBQVcsV0FBVyxDQUFDLEtBQTBCO1FBQy9DLHVCQUFBLElBQUksK0NBQWlCLEtBQUssS0FBSyxLQUFLLE1BQUEsQ0FBQztJQUN2QyxDQUFDO0lBZ0JNLGFBQWE7UUFDbEIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUN0QixDQUFDO0lBRU0sV0FBVztRQUNoQixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3hCLENBQUM7SUFFTSxjQUFjO1FBQ25CLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDeEIsQ0FBQzs7OzBIQXJDVSw2QkFBNkI7OEdBQTdCLDZCQUE2QixnS0NqQjFDLDJVQWFBOzJGRElhLDZCQUE2QjtrQkFOekMsU0FBUzsrQkFDRSx5QkFBeUIsbUJBR2xCLHVCQUF1QixDQUFDLE1BQU07OEJBT3BDLFdBQVc7c0JBRHJCLEtBQUs7Z0JBYUMsT0FBTztzQkFEYixNQUFNO2dCQU9BLFNBQVM7c0JBRGYsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIEV2ZW50RW1pdHRlcixcbiAgSW5wdXQsXG4gIE91dHB1dCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKlxuICogU3BlY2lmaWVzIGEgZmlsdGVyIHRoYXQgd2FzIGFwcGxpZWQuXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NreS1maWx0ZXItc3VtbWFyeS1pdGVtJyxcbiAgc3R5bGVVcmxzOiBbJy4vZmlsdGVyLXN1bW1hcnktaXRlbS5jb21wb25lbnQuc2NzcyddLFxuICB0ZW1wbGF0ZVVybDogJy4vZmlsdGVyLXN1bW1hcnktaXRlbS5jb21wb25lbnQuaHRtbCcsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lGaWx0ZXJTdW1tYXJ5SXRlbUNvbXBvbmVudCB7XG4gIC8qKlxuICAgKiBJbmRpY2F0ZXMgd2hldGhlciB0aGUgZmlsdGVyIHN1bW1hcnkgaXRlbSBoYXMgYSBjbG9zZSBidXR0b24uXG4gICAqL1xuICBASW5wdXQoKVxuICBwdWJsaWMgZ2V0IGRpc21pc3NpYmxlKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLiNfZGlzbWlzc2libGU7XG4gIH1cblxuICBwdWJsaWMgc2V0IGRpc21pc3NpYmxlKHZhbHVlOiBib29sZWFuIHwgdW5kZWZpbmVkKSB7XG4gICAgdGhpcy4jX2Rpc21pc3NpYmxlID0gdmFsdWUgIT09IGZhbHNlO1xuICB9XG5cbiAgLyoqXG4gICAqIEZpcmVzIHdoZW4gdGhlIHN1bW1hcnkgaXRlbSBjbG9zZSBidXR0b24gaXMgc2VsZWN0ZWQuXG4gICAqL1xuICBAT3V0cHV0KClcbiAgcHVibGljIGRpc21pc3MgPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XG5cbiAgLyoqXG4gICAqIEZpcmVzIHdoZW4gdGhlIHN1bW1hcnkgaXRlbSBpcyBzZWxlY3RlZC5cbiAgICovXG4gIEBPdXRwdXQoKVxuICBwdWJsaWMgaXRlbUNsaWNrID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuXG4gICNfZGlzbWlzc2libGUgPSB0cnVlO1xuXG4gIHB1YmxpYyBvbkl0ZW1EaXNtaXNzKCk6IHZvaWQge1xuICAgIHRoaXMuZGlzbWlzcy5lbWl0KCk7XG4gIH1cblxuICBwdWJsaWMgb25JdGVtQ2xpY2soKTogdm9pZCB7XG4gICAgdGhpcy5pdGVtQ2xpY2suZW1pdCgpO1xuICB9XG5cbiAgcHVibGljIG9uSXRlbUtleXByZXNzKCk6IHZvaWQge1xuICAgIHRoaXMuaXRlbUNsaWNrLmVtaXQoKTtcbiAgfVxufVxuIiwiPGRpdlxuICBjbGFzcz1cInNreS1maWx0ZXItc3VtbWFyeS1pdGVtXCJcbiAgKGNsaWNrKT1cIm9uSXRlbUNsaWNrKClcIlxuICAoa2V5cHJlc3MuZW50ZXIpPVwib25JdGVtS2V5cHJlc3MoKVwiXG4+XG4gIDxza3ktdG9rZW5cbiAgICBbYXJpYUxhYmVsXT1cIidza3l1eF9maWx0ZXJfc3VtbWFyeV9jbG9zZScgfCBza3lMaWJSZXNvdXJjZXNcIlxuICAgIFtkaXNtaXNzaWJsZV09XCJkaXNtaXNzaWJsZVwiXG4gICAgKGRpc21pc3MpPVwib25JdGVtRGlzbWlzcygpXCJcbiAgPlxuICAgIDxuZy1jb250ZW50PiA8L25nLWNvbnRlbnQ+XG4gIDwvc2t5LXRva2VuPlxuPC9kaXY+XG4iXX0=
@@ -1,5 +1,7 @@
1
- import { EventEmitter, Injectable } from '@angular/core';
2
- import { SkyAppWindowRef } from '@skyux/core';
1
+ var _SkyInfiniteScrollDomAdapterService_instances, _SkyInfiniteScrollDomAdapterService_ngUnsubscribe, _SkyInfiniteScrollDomAdapterService_observer, _SkyInfiniteScrollDomAdapterService_parentChanges, _SkyInfiniteScrollDomAdapterService_parentChangesObs, _SkyInfiniteScrollDomAdapterService_scrollableHostSvc, _SkyInfiniteScrollDomAdapterService_windowRef, _SkyInfiniteScrollDomAdapterService_createObserver, _SkyInfiniteScrollDomAdapterService_isElementScrolledInView;
2
+ import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
3
+ import { Injectable } from '@angular/core';
4
+ import { SkyAppWindowRef, SkyScrollableHostService } from '@skyux/core';
3
5
  import { Subject, fromEvent as observableFromEvent } from 'rxjs';
4
6
  import { filter, map, takeUntil } from 'rxjs/operators';
5
7
  import * as i0 from "@angular/core";
@@ -8,15 +10,23 @@ import * as i1 from "@skyux/core";
8
10
  * @internal
9
11
  */
10
12
  export class SkyInfiniteScrollDomAdapterService {
11
- constructor(windowRef) {
12
- this.windowRef = windowRef;
13
- this.ngUnsubscribe = new Subject();
14
- this._parentChanges = new EventEmitter();
13
+ constructor(scrollableHostSvc, windowRef) {
14
+ _SkyInfiniteScrollDomAdapterService_instances.add(this);
15
+ _SkyInfiniteScrollDomAdapterService_ngUnsubscribe.set(this, new Subject());
16
+ _SkyInfiniteScrollDomAdapterService_observer.set(this, void 0);
17
+ _SkyInfiniteScrollDomAdapterService_parentChanges.set(this, void 0);
18
+ _SkyInfiniteScrollDomAdapterService_parentChangesObs.set(this, void 0);
19
+ _SkyInfiniteScrollDomAdapterService_scrollableHostSvc.set(this, void 0);
20
+ _SkyInfiniteScrollDomAdapterService_windowRef.set(this, void 0);
21
+ __classPrivateFieldSet(this, _SkyInfiniteScrollDomAdapterService_scrollableHostSvc, scrollableHostSvc, "f");
22
+ __classPrivateFieldSet(this, _SkyInfiniteScrollDomAdapterService_windowRef, windowRef, "f");
23
+ __classPrivateFieldSet(this, _SkyInfiniteScrollDomAdapterService_parentChanges, new Subject(), "f");
24
+ __classPrivateFieldSet(this, _SkyInfiniteScrollDomAdapterService_parentChangesObs, __classPrivateFieldGet(this, _SkyInfiniteScrollDomAdapterService_parentChanges, "f").asObservable(), "f");
15
25
  }
16
26
  ngOnDestroy() {
17
- this._parentChanges.complete();
18
- this.ngUnsubscribe.next();
19
- this.ngUnsubscribe.complete();
27
+ __classPrivateFieldGet(this, _SkyInfiniteScrollDomAdapterService_parentChanges, "f").complete();
28
+ __classPrivateFieldGet(this, _SkyInfiniteScrollDomAdapterService_ngUnsubscribe, "f").next();
29
+ __classPrivateFieldGet(this, _SkyInfiniteScrollDomAdapterService_ngUnsubscribe, "f").complete();
20
30
  }
21
31
  /**
22
32
  * This event is triggered when child nodes are added to the infinite
@@ -24,8 +34,8 @@ export class SkyInfiniteScrollDomAdapterService {
24
34
  * @param elementRef The infinite scroll element reference.
25
35
  */
26
36
  parentChanges(elementRef) {
27
- this.createObserver(elementRef.nativeElement);
28
- return this._parentChanges;
37
+ __classPrivateFieldGet(this, _SkyInfiniteScrollDomAdapterService_instances, "m", _SkyInfiniteScrollDomAdapterService_createObserver).call(this, elementRef);
38
+ return __classPrivateFieldGet(this, _SkyInfiniteScrollDomAdapterService_parentChangesObs, "f");
29
39
  }
30
40
  /**
31
41
  * This event is triggered when the provided element reference
@@ -33,61 +43,43 @@ export class SkyInfiniteScrollDomAdapterService {
33
43
  * @param elementRef The infinite scroll element reference.
34
44
  */
35
45
  scrollTo(elementRef) {
36
- const parent = this.findScrollableParent(elementRef.nativeElement);
37
- return observableFromEvent(parent, 'scroll').pipe(takeUntil(this.ngUnsubscribe), filter(() => {
38
- return this.isElementScrolledInView(elementRef.nativeElement, parent);
46
+ const parent = __classPrivateFieldGet(this, _SkyInfiniteScrollDomAdapterService_scrollableHostSvc, "f").getScrollableHost(elementRef);
47
+ return observableFromEvent(parent, 'scroll').pipe(takeUntil(__classPrivateFieldGet(this, _SkyInfiniteScrollDomAdapterService_ngUnsubscribe, "f")), filter(() => {
48
+ return __classPrivateFieldGet(this, _SkyInfiniteScrollDomAdapterService_instances, "m", _SkyInfiniteScrollDomAdapterService_isElementScrolledInView).call(this, elementRef.nativeElement, parent);
39
49
  }), map(() => undefined) // Change to void return type
40
50
  );
41
51
  }
42
- createObserver(element) {
43
- this.observer = new MutationObserver((mutations) => {
44
- const hasUpdates = !!mutations.find((mutation) => {
45
- return (!element.contains(mutation.target) && mutation.addedNodes.length > 0);
46
- });
47
- if (hasUpdates) {
48
- this._parentChanges.emit();
49
- }
50
- });
51
- const windowObj = this.windowRef.nativeWindow;
52
- const parent = this.findScrollableParent(element);
53
- const observedParent = parent === windowObj ? windowObj.document.body : parent;
54
- this.observer.observe(observedParent, {
55
- childList: true,
56
- subtree: true,
52
+ }
53
+ _SkyInfiniteScrollDomAdapterService_ngUnsubscribe = new WeakMap(), _SkyInfiniteScrollDomAdapterService_observer = new WeakMap(), _SkyInfiniteScrollDomAdapterService_parentChanges = new WeakMap(), _SkyInfiniteScrollDomAdapterService_parentChangesObs = new WeakMap(), _SkyInfiniteScrollDomAdapterService_scrollableHostSvc = new WeakMap(), _SkyInfiniteScrollDomAdapterService_windowRef = new WeakMap(), _SkyInfiniteScrollDomAdapterService_instances = new WeakSet(), _SkyInfiniteScrollDomAdapterService_createObserver = function _SkyInfiniteScrollDomAdapterService_createObserver(elementRef) {
54
+ __classPrivateFieldSet(this, _SkyInfiniteScrollDomAdapterService_observer, new MutationObserver((mutations) => {
55
+ const hasUpdates = !!mutations.find((mutation) => {
56
+ return (!elementRef.nativeElement.contains(mutation.target) &&
57
+ mutation.addedNodes.length > 0);
57
58
  });
58
- }
59
- findScrollableParent(element) {
60
- const regex = /(auto|scroll)/;
61
- const windowObj = this.windowRef.nativeWindow;
62
- const bodyObj = windowObj.document.body;
63
- let style = windowObj.getComputedStyle(element);
64
- let parent = element;
65
- do {
66
- parent = parent.parentNode;
67
- style = windowObj.getComputedStyle(parent);
68
- } while (!regex.test(style.overflow) &&
69
- !regex.test(style.overflowY) &&
70
- parent.parentNode &&
71
- parent !== bodyObj);
72
- if (parent === bodyObj) {
73
- return windowObj;
59
+ if (hasUpdates) {
60
+ __classPrivateFieldGet(this, _SkyInfiniteScrollDomAdapterService_parentChanges, "f").next();
74
61
  }
75
- return parent;
62
+ }), "f");
63
+ const windowObj = __classPrivateFieldGet(this, _SkyInfiniteScrollDomAdapterService_windowRef, "f").nativeWindow;
64
+ const parent = __classPrivateFieldGet(this, _SkyInfiniteScrollDomAdapterService_scrollableHostSvc, "f").getScrollableHost(elementRef);
65
+ const observedParent = parent === windowObj ? windowObj.document.body : parent;
66
+ __classPrivateFieldGet(this, _SkyInfiniteScrollDomAdapterService_observer, "f").observe(observedParent, {
67
+ childList: true,
68
+ subtree: true,
69
+ });
70
+ }, _SkyInfiniteScrollDomAdapterService_isElementScrolledInView = function _SkyInfiniteScrollDomAdapterService_isElementScrolledInView(element, parentElement) {
71
+ const windowObj = __classPrivateFieldGet(this, _SkyInfiniteScrollDomAdapterService_windowRef, "f").nativeWindow;
72
+ if (parentElement === windowObj) {
73
+ return (parentElement.pageYOffset + parentElement.innerHeight >
74
+ element.offsetTop);
76
75
  }
77
- isElementScrolledInView(element, parentElement) {
78
- const windowObj = this.windowRef.nativeWindow;
79
- if (parentElement === windowObj) {
80
- return (parentElement.pageYOffset + parentElement.innerHeight >
81
- element.offsetTop);
82
- }
83
- const elementRect = element.getBoundingClientRect();
84
- const parentRect = parentElement.getBoundingClientRect();
85
- return elementRect.top < parentRect.top + parentRect.height;
86
- }
87
- }
88
- SkyInfiniteScrollDomAdapterService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyInfiniteScrollDomAdapterService, deps: [{ token: i1.SkyAppWindowRef }], target: i0.ɵɵFactoryTarget.Injectable });
76
+ const elementRect = element.getBoundingClientRect();
77
+ const parentRect = parentElement.getBoundingClientRect();
78
+ return elementRect.top < parentRect.top + parentRect.height;
79
+ };
80
+ SkyInfiniteScrollDomAdapterService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyInfiniteScrollDomAdapterService, deps: [{ token: i1.SkyScrollableHostService }, { token: i1.SkyAppWindowRef }], target: i0.ɵɵFactoryTarget.Injectable });
89
81
  SkyInfiniteScrollDomAdapterService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyInfiniteScrollDomAdapterService });
90
82
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyInfiniteScrollDomAdapterService, decorators: [{
91
83
  type: Injectable
92
- }], ctorParameters: function () { return [{ type: i1.SkyAppWindowRef }]; } });
93
- //# 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, EventEmitter, Injectable, OnDestroy } from '@angular/core';\nimport { SkyAppWindowRef } 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  private ngUnsubscribe = new Subject<void>();\n\n  private observer: MutationObserver;\n\n  private _parentChanges = new EventEmitter<void>();\n\n  constructor(private windowRef: SkyAppWindowRef) {}\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.nativeElement);\n    return this._parentChanges;\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.findScrollableParent(elementRef.nativeElement);\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  private createObserver(element: any): void {\n    this.observer = new MutationObserver((mutations: MutationRecord[]) => {\n      const hasUpdates = !!mutations.find((mutation) => {\n        return (\n          !element.contains(mutation.target) && mutation.addedNodes.length > 0\n        );\n      });\n\n      if (hasUpdates) {\n        this._parentChanges.emit();\n      }\n    });\n\n    const windowObj = this.windowRef.nativeWindow;\n    const parent = this.findScrollableParent(element);\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  private findScrollableParent(element: any): any {\n    const regex = /(auto|scroll)/;\n    const windowObj = this.windowRef.nativeWindow;\n    const bodyObj = windowObj.document.body;\n\n    let style = windowObj.getComputedStyle(element);\n    let parent = element;\n\n    do {\n      parent = parent.parentNode;\n      style = windowObj.getComputedStyle(parent);\n    } while (\n      !regex.test(style.overflow) &&\n      !regex.test(style.overflowY) &&\n      parent.parentNode &&\n      parent !== bodyObj\n    );\n\n    if (parent === bodyObj) {\n      return windowObj;\n    }\n\n    return parent;\n  }\n\n  private isElementScrolledInView(element: any, parentElement: any): boolean {\n    const windowObj = this.windowRef.nativeWindow;\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.getBoundingClientRect();\n\n    return elementRect.top < parentRect.top + parentRect.height;\n  }\n}\n"]}
84
+ }], ctorParameters: function () { return [{ type: i1.SkyScrollableHostService }, { type: i1.SkyAppWindowRef }]; } });
85
+ //# 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"]}
@@ -1,3 +1,5 @@
1
+ var _SkyInfiniteScrollComponent_instances, _SkyInfiniteScrollComponent_changeDetector, _SkyInfiniteScrollComponent_domAdapter, _SkyInfiniteScrollComponent_elementRef, _SkyInfiniteScrollComponent_ngUnsubscribe, _SkyInfiniteScrollComponent__enabled, _SkyInfiniteScrollComponent__loading, _SkyInfiniteScrollComponent_notifyScrollEnd, _SkyInfiniteScrollComponent_setListeners;
2
+ import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
1
3
  import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, } from '@angular/core';
2
4
  import { Subject } from 'rxjs';
3
5
  import { takeUntil } from 'rxjs/operators';
@@ -9,9 +11,7 @@ import * as i3 from "@skyux/indicators";
9
11
  import * as i4 from "@skyux/i18n";
10
12
  export class SkyInfiniteScrollComponent {
11
13
  constructor(changeDetector, elementRef, domAdapter) {
12
- this.changeDetector = changeDetector;
13
- this.elementRef = elementRef;
14
- this.domAdapter = domAdapter;
14
+ _SkyInfiniteScrollComponent_instances.add(this);
15
15
  /**
16
16
  * Fires when scrolling triggers the need to load more data or when users select the button
17
17
  * to load more data. This event only fires when the `enabled` property is set to `true`
@@ -19,7 +19,15 @@ export class SkyInfiniteScrollComponent {
19
19
  */
20
20
  this.scrollEnd = new EventEmitter();
21
21
  this.isWaiting = false;
22
- this.ngUnsubscribe = new Subject();
22
+ _SkyInfiniteScrollComponent_changeDetector.set(this, void 0);
23
+ _SkyInfiniteScrollComponent_domAdapter.set(this, void 0);
24
+ _SkyInfiniteScrollComponent_elementRef.set(this, void 0);
25
+ _SkyInfiniteScrollComponent_ngUnsubscribe.set(this, new Subject());
26
+ _SkyInfiniteScrollComponent__enabled.set(this, false);
27
+ _SkyInfiniteScrollComponent__loading.set(this, void 0);
28
+ __classPrivateFieldSet(this, _SkyInfiniteScrollComponent_changeDetector, changeDetector, "f");
29
+ __classPrivateFieldSet(this, _SkyInfiniteScrollComponent_elementRef, elementRef, "f");
30
+ __classPrivateFieldSet(this, _SkyInfiniteScrollComponent_domAdapter, domAdapter, "f");
23
31
  }
24
32
  /**
25
33
  * Indicates whether to make the infinite scroll component active when more data is available
@@ -27,12 +35,12 @@ export class SkyInfiniteScrollComponent {
27
35
  * @default false
28
36
  */
29
37
  get enabled() {
30
- return this._enabled || false;
38
+ return __classPrivateFieldGet(this, _SkyInfiniteScrollComponent__enabled, "f");
31
39
  }
32
40
  set enabled(value) {
33
- if (this._enabled !== value) {
34
- this._enabled = value;
35
- this.setListeners();
41
+ if (__classPrivateFieldGet(this, _SkyInfiniteScrollComponent__enabled, "f") !== value) {
42
+ __classPrivateFieldSet(this, _SkyInfiniteScrollComponent__enabled, value, "f");
43
+ __classPrivateFieldGet(this, _SkyInfiniteScrollComponent_instances, "m", _SkyInfiniteScrollComponent_setListeners).call(this);
36
44
  }
37
45
  }
38
46
  /**
@@ -46,54 +54,53 @@ export class SkyInfiniteScrollComponent {
46
54
  * @required
47
55
  */
48
56
  get loading() {
49
- return this._loading;
57
+ return __classPrivateFieldGet(this, _SkyInfiniteScrollComponent__loading, "f");
50
58
  }
51
59
  set loading(value) {
52
- this._loading = value;
60
+ __classPrivateFieldSet(this, _SkyInfiniteScrollComponent__loading, value, "f");
53
61
  if (value !== undefined) {
54
62
  this.isWaiting = value;
55
63
  }
56
64
  }
57
65
  ngOnDestroy() {
58
66
  this.enabled = false;
59
- this.ngUnsubscribe.next();
60
- this.ngUnsubscribe.complete();
67
+ __classPrivateFieldGet(this, _SkyInfiniteScrollComponent_ngUnsubscribe, "f").next();
68
+ __classPrivateFieldGet(this, _SkyInfiniteScrollComponent_ngUnsubscribe, "f").complete();
61
69
  }
62
70
  startInfiniteScrollLoad() {
63
- this.notifyScrollEnd();
71
+ __classPrivateFieldGet(this, _SkyInfiniteScrollComponent_instances, "m", _SkyInfiniteScrollComponent_notifyScrollEnd).call(this);
64
72
  }
65
- notifyScrollEnd() {
66
- this.isWaiting = true;
67
- this.scrollEnd.emit();
68
- this.changeDetector.markForCheck();
73
+ }
74
+ _SkyInfiniteScrollComponent_changeDetector = new WeakMap(), _SkyInfiniteScrollComponent_domAdapter = new WeakMap(), _SkyInfiniteScrollComponent_elementRef = new WeakMap(), _SkyInfiniteScrollComponent_ngUnsubscribe = new WeakMap(), _SkyInfiniteScrollComponent__enabled = new WeakMap(), _SkyInfiniteScrollComponent__loading = new WeakMap(), _SkyInfiniteScrollComponent_instances = new WeakSet(), _SkyInfiniteScrollComponent_notifyScrollEnd = function _SkyInfiniteScrollComponent_notifyScrollEnd() {
75
+ this.isWaiting = true;
76
+ this.scrollEnd.emit();
77
+ __classPrivateFieldGet(this, _SkyInfiniteScrollComponent_changeDetector, "f").markForCheck();
78
+ }, _SkyInfiniteScrollComponent_setListeners = function _SkyInfiniteScrollComponent_setListeners() {
79
+ if (this.enabled) {
80
+ // The user has scrolled to the infinite scroll element.
81
+ __classPrivateFieldGet(this, _SkyInfiniteScrollComponent_domAdapter, "f")
82
+ .scrollTo(__classPrivateFieldGet(this, _SkyInfiniteScrollComponent_elementRef, "f"))
83
+ .pipe(takeUntil(__classPrivateFieldGet(this, _SkyInfiniteScrollComponent_ngUnsubscribe, "f")))
84
+ .subscribe(() => {
85
+ if (!this.isWaiting && this.enabled) {
86
+ __classPrivateFieldGet(this, _SkyInfiniteScrollComponent_instances, "m", _SkyInfiniteScrollComponent_notifyScrollEnd).call(this);
87
+ }
88
+ });
89
+ // New items have been loaded into the parent element.
90
+ __classPrivateFieldGet(this, _SkyInfiniteScrollComponent_domAdapter, "f")
91
+ .parentChanges(__classPrivateFieldGet(this, _SkyInfiniteScrollComponent_elementRef, "f"))
92
+ .pipe(takeUntil(__classPrivateFieldGet(this, _SkyInfiniteScrollComponent_ngUnsubscribe, "f")))
93
+ .subscribe(() => {
94
+ if (!this.loading) {
95
+ this.isWaiting = false;
96
+ __classPrivateFieldGet(this, _SkyInfiniteScrollComponent_changeDetector, "f").markForCheck();
97
+ }
98
+ });
69
99
  }
70
- setListeners() {
71
- if (this.enabled) {
72
- // The user has scrolled to the infinite scroll element.
73
- this.domAdapter
74
- .scrollTo(this.elementRef)
75
- .pipe(takeUntil(this.ngUnsubscribe))
76
- .subscribe(() => {
77
- if (!this.isWaiting && this.enabled) {
78
- this.notifyScrollEnd();
79
- }
80
- });
81
- // New items have been loaded into the parent element.
82
- this.domAdapter
83
- .parentChanges(this.elementRef)
84
- .pipe(takeUntil(this.ngUnsubscribe))
85
- .subscribe(() => {
86
- if (!this.loading) {
87
- this.isWaiting = false;
88
- this.changeDetector.markForCheck();
89
- }
90
- });
91
- }
92
- else {
93
- this.ngUnsubscribe.next();
94
- }
100
+ else {
101
+ __classPrivateFieldGet(this, _SkyInfiniteScrollComponent_ngUnsubscribe, "f").next();
95
102
  }
96
- }
103
+ };
97
104
  SkyInfiniteScrollComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyInfiniteScrollComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i1.SkyInfiniteScrollDomAdapterService }], target: i0.ɵɵFactoryTarget.Component });
98
105
  SkyInfiniteScrollComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.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"] }, { kind: "pipe", type: i4.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
99
106
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyInfiniteScrollComponent, decorators: [{
@@ -106,4 +113,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
106
113
  }], scrollEnd: [{
107
114
  type: Output
108
115
  }] } });
109
- //# 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   * Indicates 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 {\n    return this._enabled || false;\n  }\n  public set enabled(value: boolean) {\n    if (this._enabled !== value) {\n      this._enabled = value;\n      this.setListeners();\n    }\n  }\n\n  /**\n   * Indicates 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  private ngUnsubscribe = new Subject<void>();\n\n  private _enabled: boolean;\n\n  private _loading: boolean | undefined;\n\n  constructor(\n    private changeDetector: ChangeDetectorRef,\n    private elementRef: ElementRef,\n    private domAdapter: SkyInfiniteScrollDomAdapterService\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  private notifyScrollEnd(): void {\n    this.isWaiting = true;\n    this.scrollEnd.emit();\n    this.changeDetector.markForCheck();\n  }\n\n  private 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   * Indicates 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   * Indicates 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"]}