@skyux/layout 7.0.0-beta.1 → 7.0.0-beta.3

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 (76) hide show
  1. package/documentation.json +1355 -781
  2. package/esm2020/index.mjs +1 -2
  3. package/esm2020/lib/modules/action-button/action-button-container.component.mjs +2 -2
  4. package/esm2020/lib/modules/card/card.component.mjs +38 -11
  5. package/esm2020/lib/modules/definition-list/definition-list-label.component.mjs +1 -1
  6. package/esm2020/lib/modules/definition-list/definition-list-value.component.mjs +3 -3
  7. package/esm2020/lib/modules/definition-list/definition-list.component.mjs +1 -1
  8. package/esm2020/lib/modules/definition-list/definition-list.service.mjs +1 -1
  9. package/esm2020/lib/modules/description-list/description-list-adapter-service.mjs +26 -22
  10. package/esm2020/lib/modules/description-list/description-list-content.component.mjs +2 -2
  11. package/esm2020/lib/modules/description-list/description-list-description.component.mjs +16 -11
  12. package/esm2020/lib/modules/description-list/description-list-term.component.mjs +1 -1
  13. package/esm2020/lib/modules/description-list/description-list.component.mjs +25 -16
  14. package/esm2020/lib/modules/fluid-grid/column.component.mjs +19 -1
  15. package/esm2020/lib/modules/fluid-grid/fluid-grid.component.mjs +15 -35
  16. package/esm2020/lib/modules/fluid-grid/row.component.mjs +1 -1
  17. package/esm2020/lib/modules/fluid-grid/types/fluid-grid-gutter-size-type.mjs +1 -1
  18. package/esm2020/lib/modules/format/format.component.mjs +34 -26
  19. package/esm2020/lib/modules/inline-delete/inline-delete-adapter.service.mjs +91 -83
  20. package/esm2020/lib/modules/inline-delete/inline-delete.component.mjs +15 -9
  21. package/esm2020/lib/modules/page/page-theme-adapter.service.mjs +14 -8
  22. package/esm2020/lib/modules/page/page.component.mjs +8 -4
  23. package/esm2020/lib/modules/page-summary/page-summary-adapter.service.mjs +1 -1
  24. package/esm2020/lib/modules/page-summary/page-summary.component.mjs +40 -16
  25. package/esm2020/lib/modules/text-expand/text-expand-adapter.service.mjs +8 -10
  26. package/esm2020/lib/modules/text-expand/text-expand-modal-context-token.mjs +6 -0
  27. package/esm2020/lib/modules/text-expand/text-expand-modal-context.mjs +2 -6
  28. package/esm2020/lib/modules/text-expand/text-expand-modal.component.mjs +12 -10
  29. package/esm2020/lib/modules/text-expand/text-expand.component.mjs +188 -127
  30. package/esm2020/lib/modules/text-expand-repeater/text-expand-repeater-adapter.service.mjs +10 -12
  31. package/esm2020/lib/modules/text-expand-repeater/text-expand-repeater.component.mjs +139 -95
  32. package/esm2020/lib/modules/toolbar/toolbar.component.mjs +2 -2
  33. package/esm2020/testing/action-button-fixture.mjs +12 -6
  34. package/esm2020/testing/card-fixture.mjs +19 -16
  35. package/esm2020/testing/page-summary-fixture.mjs +9 -5
  36. package/fesm2015/skyux-layout-testing.mjs +35 -24
  37. package/fesm2015/skyux-layout-testing.mjs.map +1 -1
  38. package/fesm2015/skyux-layout.mjs +675 -506
  39. package/fesm2015/skyux-layout.mjs.map +1 -1
  40. package/fesm2020/skyux-layout-testing.mjs +35 -24
  41. package/fesm2020/skyux-layout-testing.mjs.map +1 -1
  42. package/fesm2020/skyux-layout.mjs +669 -506
  43. package/fesm2020/skyux-layout.mjs.map +1 -1
  44. package/index.d.ts +0 -1
  45. package/lib/modules/card/card.component.d.ts +7 -6
  46. package/lib/modules/definition-list/definition-list-label.component.d.ts +1 -1
  47. package/lib/modules/definition-list/definition-list-value.component.d.ts +1 -1
  48. package/lib/modules/definition-list/definition-list.component.d.ts +2 -2
  49. package/lib/modules/definition-list/definition-list.service.d.ts +2 -2
  50. package/lib/modules/description-list/description-list-adapter-service.d.ts +1 -2
  51. package/lib/modules/description-list/description-list-content.component.d.ts +2 -2
  52. package/lib/modules/description-list/description-list-description.component.d.ts +5 -7
  53. package/lib/modules/description-list/description-list-term.component.d.ts +1 -1
  54. package/lib/modules/description-list/description-list.component.d.ts +6 -7
  55. package/lib/modules/fluid-grid/column.component.d.ts +7 -5
  56. package/lib/modules/fluid-grid/fluid-grid.component.d.ts +3 -9
  57. package/lib/modules/fluid-grid/row.component.d.ts +1 -1
  58. package/lib/modules/fluid-grid/types/fluid-grid-gutter-size-type.d.ts +1 -1
  59. package/lib/modules/format/format.component.d.ts +5 -7
  60. package/lib/modules/inline-delete/inline-delete-adapter.service.d.ts +1 -11
  61. package/lib/modules/inline-delete/inline-delete.component.d.ts +3 -5
  62. package/lib/modules/page/page-theme-adapter.service.d.ts +1 -1
  63. package/lib/modules/page/page.component.d.ts +1 -1
  64. package/lib/modules/page-summary/page-summary.component.d.ts +8 -9
  65. package/lib/modules/text-expand/text-expand-adapter.service.d.ts +3 -4
  66. package/lib/modules/text-expand/text-expand-modal-context-token.d.ts +6 -0
  67. package/lib/modules/text-expand/text-expand-modal-context.d.ts +1 -1
  68. package/lib/modules/text-expand/text-expand.component.d.ts +18 -25
  69. package/lib/modules/text-expand-repeater/text-expand-repeater-adapter.service.d.ts +4 -5
  70. package/lib/modules/text-expand-repeater/text-expand-repeater.component.d.ts +13 -21
  71. package/package.json +9 -9
  72. package/testing/action-button-fixture.d.ts +4 -4
  73. package/testing/card-fixture.d.ts +3 -5
  74. package/testing/page-summary-fixture.d.ts +4 -4
  75. package/esm2020/lib/modules/fluid-grid/fluid-grid-gutter-size.mjs +0 -20
  76. package/lib/modules/fluid-grid/fluid-grid-gutter-size.d.ts +0 -18
@@ -1,4 +1,7 @@
1
- import { ChangeDetectorRef, Component, ElementRef, Input, TemplateRef, ViewChild, } from '@angular/core';
1
+ var _SkyTextExpandRepeaterComponent_instances, _SkyTextExpandRepeaterComponent_seeMoreText, _SkyTextExpandRepeaterComponent_seeLessText, _SkyTextExpandRepeaterComponent_htmlItems, _SkyTextExpandRepeaterComponent__data, _SkyTextExpandRepeaterComponent__maxItems, _SkyTextExpandRepeaterComponent_resources, _SkyTextExpandRepeaterComponent_elRef, _SkyTextExpandRepeaterComponent_textExpandRepeaterAdapter, _SkyTextExpandRepeaterComponent_changeDetector, _SkyTextExpandRepeaterComponent_animateRepeater, _SkyTextExpandRepeaterComponent_setup, _SkyTextExpandRepeaterComponent_hideItems, _SkyTextExpandRepeaterComponent_showItems;
2
+ import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
3
+ import { animate, state, style, transition, trigger, } from '@angular/animations';
4
+ import { ChangeDetectorRef, Component, ElementRef, Input, ViewChild, } from '@angular/core';
2
5
  import { SkyLibResourcesService } from '@skyux/i18n';
3
6
  import { forkJoin as observableForkJoin } from 'rxjs';
4
7
  import { take } from 'rxjs/operators';
@@ -13,146 +16,187 @@ import * as i3 from "@angular/common";
13
16
  let nextId = 0;
14
17
  export class SkyTextExpandRepeaterComponent {
15
18
  constructor(resources, elRef, textExpandRepeaterAdapter, changeDetector) {
16
- this.resources = resources;
17
- this.elRef = elRef;
18
- this.textExpandRepeaterAdapter = textExpandRepeaterAdapter;
19
- this.changeDetector = changeDetector;
19
+ _SkyTextExpandRepeaterComponent_instances.add(this);
20
20
  /**
21
21
  * Specifies the style of bullet to use
22
22
  * @default "unordered"
23
23
  */
24
24
  this.listStyle = 'unordered';
25
+ this.buttonText = '';
26
+ this.expandable = false;
25
27
  this.contentSectionId = `sky-text-expand-repeater-content-${++nextId}`;
26
- this.isExpanded = false;
28
+ this.transitionHeight = 1;
29
+ _SkyTextExpandRepeaterComponent_seeMoreText.set(this, '');
30
+ _SkyTextExpandRepeaterComponent_seeLessText.set(this, '');
31
+ _SkyTextExpandRepeaterComponent_htmlItems.set(this, void 0);
32
+ _SkyTextExpandRepeaterComponent__data.set(this, void 0);
33
+ _SkyTextExpandRepeaterComponent__maxItems.set(this, void 0);
34
+ _SkyTextExpandRepeaterComponent_resources.set(this, void 0);
35
+ _SkyTextExpandRepeaterComponent_elRef.set(this, void 0);
36
+ _SkyTextExpandRepeaterComponent_textExpandRepeaterAdapter.set(this, void 0);
37
+ _SkyTextExpandRepeaterComponent_changeDetector.set(this, void 0);
38
+ __classPrivateFieldSet(this, _SkyTextExpandRepeaterComponent_resources, resources, "f");
39
+ __classPrivateFieldSet(this, _SkyTextExpandRepeaterComponent_elRef, elRef, "f");
40
+ __classPrivateFieldSet(this, _SkyTextExpandRepeaterComponent_textExpandRepeaterAdapter, textExpandRepeaterAdapter, "f");
41
+ __classPrivateFieldSet(this, _SkyTextExpandRepeaterComponent_changeDetector, changeDetector, "f");
42
+ }
43
+ /**
44
+ * Specifies the data to truncate.
45
+ */
46
+ set data(value) {
47
+ __classPrivateFieldSet(this, _SkyTextExpandRepeaterComponent__data, value, "f");
48
+ // Wait for the dom to render the new items based on the updated data
49
+ setTimeout(() => {
50
+ __classPrivateFieldSet(this, _SkyTextExpandRepeaterComponent_htmlItems, __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_textExpandRepeaterAdapter, "f").getItems(__classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_elRef, "f")), "f");
51
+ __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_instances, "m", _SkyTextExpandRepeaterComponent_setup).call(this, value);
52
+ });
53
+ }
54
+ get data() {
55
+ return __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent__data, "f");
56
+ }
57
+ /**
58
+ * Specifies the number of items to display before truncating the list. If not supplied, all items are shown.
59
+ */
60
+ set maxItems(value) {
61
+ __classPrivateFieldSet(this, _SkyTextExpandRepeaterComponent__maxItems, value, "f");
62
+ __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_instances, "m", _SkyTextExpandRepeaterComponent_setup).call(this, this.data);
63
+ }
64
+ get maxItems() {
65
+ return __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent__maxItems, "f");
27
66
  }
28
67
  ngAfterViewInit() {
29
- if (this.contentItems) {
30
- this.items = this.textExpandRepeaterAdapter.getItems(this.elRef);
31
- for (let i = this.maxItems; i < this.contentItems.length; i++) {
32
- this.textExpandRepeaterAdapter.hideItem(this.items[i]);
33
- }
34
- }
35
68
  observableForkJoin([
36
- this.resources.getString('skyux_text_expand_see_more'),
37
- this.resources.getString('skyux_text_expand_see_less'),
69
+ __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_resources, "f").getString('skyux_text_expand_see_more'),
70
+ __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_resources, "f").getString('skyux_text_expand_see_less'),
38
71
  ])
39
72
  .pipe(take(1))
40
73
  .subscribe((resources) => {
41
- this.seeMoreText = resources[0];
42
- this.seeLessText = resources[1];
74
+ __classPrivateFieldSet(this, _SkyTextExpandRepeaterComponent_seeMoreText, resources[0], "f");
75
+ __classPrivateFieldSet(this, _SkyTextExpandRepeaterComponent_seeLessText, resources[1], "f");
43
76
  /* sanity check */
44
77
  /* istanbul ignore else */
45
78
  if (!this.isExpanded) {
46
- this.buttonText = this.seeMoreText;
79
+ this.buttonText = __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_seeMoreText, "f");
47
80
  }
48
81
  else {
49
- this.buttonText = this.seeLessText;
82
+ this.buttonText = __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_seeLessText, "f");
50
83
  }
51
- this.changeDetector.detectChanges();
84
+ __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_changeDetector, "f").detectChanges();
52
85
  });
53
86
  }
54
- ngOnChanges(changes) {
55
- /* istanbul ignore else */
56
- if (changes.maxItems || changes.data) {
57
- this.setup(this.data);
58
- }
59
- }
60
87
  animationEnd() {
61
- // Ensure the correct items are displayed
88
+ // Ensure all items that should be hidden are hidden. This is because we need them shown during the animation window for visual purposes.
62
89
  if (!this.isExpanded) {
63
- for (let i = this.maxItems; i < this.contentItems.length; i++) {
64
- this.textExpandRepeaterAdapter.hideItem(this.items[i]);
65
- }
90
+ __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_instances, "m", _SkyTextExpandRepeaterComponent_hideItems).call(this);
66
91
  }
67
- // Set height back to auto so the browser can change the height as needed with window changes
68
- this.textExpandRepeaterAdapter.setContainerHeight(this.containerEl, undefined);
92
+ // This set timeout is needed as the `animationEnd` function is called by the angular animation callback prior to the animation setting the style on the element
93
+ setTimeout(() => {
94
+ if (this.containerEl) {
95
+ // Set height back to auto so the browser can change the height as needed with window changes
96
+ __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_textExpandRepeaterAdapter, "f").removeContainerMaxHeight(this.containerEl);
97
+ }
98
+ });
69
99
  }
70
100
  repeaterExpand() {
71
101
  if (!this.isExpanded) {
72
- this.setContainerMaxHeight();
73
- setTimeout(() => {
74
- this.isExpanded = true;
75
- this.animateRepeater(true);
76
- });
102
+ __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_instances, "m", _SkyTextExpandRepeaterComponent_animateRepeater).call(this, true);
77
103
  }
78
104
  else {
79
- this.setContainerMaxHeight();
80
- setTimeout(() => {
81
- this.isExpanded = false;
82
- this.animateRepeater(false);
83
- });
105
+ __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_instances, "m", _SkyTextExpandRepeaterComponent_animateRepeater).call(this, false);
84
106
  }
85
107
  }
86
- setContainerMaxHeight() {
87
- // ensure everything is reset
88
- this.animationEnd();
89
- /* Before animation is kicked off, ensure that a maxHeight exists */
90
- /* Once we have support for angular v4 animations with parameters we can use that instead */
91
- const currentHeight = this.textExpandRepeaterAdapter.getContainerHeight(this.containerEl);
92
- this.textExpandRepeaterAdapter.setContainerHeight(this.containerEl, `${currentHeight}px`);
93
- }
94
- animateRepeater(expanding) {
95
- const adapter = this.textExpandRepeaterAdapter;
96
- const container = this.containerEl;
97
- adapter.setContainerHeight(container, undefined);
98
- const currentHeight = adapter.getContainerHeight(container);
99
- for (let i = this.maxItems; i < this.contentItems.length; i++) {
100
- if (!expanding) {
101
- adapter.hideItem(this.items[i]);
102
- }
103
- else {
104
- adapter.showItem(this.items[i]);
105
- }
108
+ }
109
+ _SkyTextExpandRepeaterComponent_seeMoreText = new WeakMap(), _SkyTextExpandRepeaterComponent_seeLessText = new WeakMap(), _SkyTextExpandRepeaterComponent_htmlItems = new WeakMap(), _SkyTextExpandRepeaterComponent__data = new WeakMap(), _SkyTextExpandRepeaterComponent__maxItems = new WeakMap(), _SkyTextExpandRepeaterComponent_resources = new WeakMap(), _SkyTextExpandRepeaterComponent_elRef = new WeakMap(), _SkyTextExpandRepeaterComponent_textExpandRepeaterAdapter = new WeakMap(), _SkyTextExpandRepeaterComponent_changeDetector = new WeakMap(), _SkyTextExpandRepeaterComponent_instances = new WeakSet(), _SkyTextExpandRepeaterComponent_animateRepeater = function _SkyTextExpandRepeaterComponent_animateRepeater(expanding) {
110
+ const adapter = __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_textExpandRepeaterAdapter, "f");
111
+ const container = this.containerEl;
112
+ if (container) {
113
+ if (expanding) {
114
+ __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_instances, "m", _SkyTextExpandRepeaterComponent_showItems).call(this);
115
+ }
116
+ else {
117
+ __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_instances, "m", _SkyTextExpandRepeaterComponent_hideItems).call(this);
106
118
  }
107
119
  const newHeight = adapter.getContainerHeight(container);
120
+ this.transitionHeight = newHeight;
108
121
  if (!expanding) {
109
- this.buttonText = this.seeMoreText;
122
+ this.buttonText = __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_seeMoreText, "f");
110
123
  }
111
124
  else {
112
- this.buttonText = this.seeLessText;
125
+ this.buttonText = __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_seeLessText, "f");
113
126
  }
114
- if (newHeight < currentHeight) {
115
- // The new text is smaller than the old text, so put the old text back before doing
116
- // the collapse animation to avoid showing a big chunk of whitespace.
117
- for (let i = this.maxItems; i < this.contentItems.length; i++) {
118
- adapter.showItem(this.items[i]);
119
- }
127
+ if (!expanding) {
128
+ // Show all items during animation for visual purposes.
129
+ __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_instances, "m", _SkyTextExpandRepeaterComponent_showItems).call(this);
120
130
  }
121
- adapter.setContainerHeight(container, `${currentHeight}px`);
122
- // This timeout is necessary due to the browser needing to pick up the non-auto height being set
123
- // in order to do the transtion in height correctly. Without it the transition does not fire.
124
- setTimeout(() => {
125
- adapter.setContainerHeight(container, `${newHeight}px`);
126
- /* This resets values if the transition does not get kicked off */
127
- setTimeout(() => {
128
- this.animationEnd();
129
- }, 500);
130
- }, 10);
131
+ this.isExpanded = expanding;
131
132
  }
132
- setup(value) {
133
- if (value) {
134
- const length = value.length;
135
- if (length > this.maxItems) {
136
- this.expandable = true;
137
- this.buttonText = this.seeMoreText;
138
- this.isExpanded = false;
133
+ }, _SkyTextExpandRepeaterComponent_setup = function _SkyTextExpandRepeaterComponent_setup(value) {
134
+ if (value) {
135
+ const length = value.length;
136
+ if (this.maxItems && length > this.maxItems) {
137
+ this.expandable = true;
138
+ this.buttonText = __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_seeMoreText, "f");
139
+ __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_instances, "m", _SkyTextExpandRepeaterComponent_hideItems).call(this);
140
+ if (this.containerEl) {
141
+ this.transitionHeight =
142
+ __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_textExpandRepeaterAdapter, "f").getContainerHeight(this.containerEl);
139
143
  }
140
- else {
141
- this.expandable = false;
142
- }
143
- this.contentItems = value;
144
+ this.isExpanded = false;
144
145
  }
145
146
  else {
146
- this.contentItems = undefined;
147
147
  this.expandable = false;
148
+ this.isExpanded = undefined;
148
149
  }
149
150
  }
150
- }
151
+ else {
152
+ this.expandable = false;
153
+ this.isExpanded = undefined;
154
+ }
155
+ __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_changeDetector, "f").markForCheck();
156
+ }, _SkyTextExpandRepeaterComponent_hideItems = function _SkyTextExpandRepeaterComponent_hideItems() {
157
+ if (__classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_htmlItems, "f") && this.maxItems) {
158
+ for (let i = this.maxItems; i < __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_htmlItems, "f").length; i++) {
159
+ __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_textExpandRepeaterAdapter, "f").hideItem(__classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_htmlItems, "f")[i]);
160
+ }
161
+ }
162
+ }, _SkyTextExpandRepeaterComponent_showItems = function _SkyTextExpandRepeaterComponent_showItems() {
163
+ if (__classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_htmlItems, "f") && this.maxItems) {
164
+ for (let i = this.maxItems; i < __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_htmlItems, "f").length; i++) {
165
+ __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_textExpandRepeaterAdapter, "f").showItem(__classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_htmlItems, "f")[i]);
166
+ }
167
+ }
168
+ };
151
169
  SkyTextExpandRepeaterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyTextExpandRepeaterComponent, deps: [{ token: i1.SkyLibResourcesService }, { token: i0.ElementRef }, { token: i2.SkyTextExpandRepeaterAdapterService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
152
- SkyTextExpandRepeaterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: SkyTextExpandRepeaterComponent, selector: "sky-text-expand-repeater", inputs: { data: "data", itemTemplate: "itemTemplate", listStyle: "listStyle", maxItems: "maxItems" }, providers: [SkyTextExpandRepeaterAdapterService], viewQueries: [{ propertyName: "containerEl", first: true, predicate: ["container"], descendants: true, read: ElementRef }], usesOnChanges: true, ngImport: i0, template: "<div class=\"sky-text-expand-repeater\">\n <ul\n *ngIf=\"listStyle !== 'ordered'\"\n class=\"sky-text-expand-repeater-container\"\n [id]=\"contentSectionId\"\n (transitionend)=\"animationEnd()\"\n [ngClass]=\"{\n 'sky-text-expand-repeater-list-style-none': listStyle === 'unstyled'\n }\"\n #container\n >\n <ng-template [ngTemplateOutlet]=\"listItemTemplate\"></ng-template>\n </ul>\n <ol\n *ngIf=\"listStyle === 'ordered'\"\n class=\"sky-text-expand-repeater-container\"\n [id]=\"contentSectionId\"\n (transitionend)=\"animationEnd()\"\n #container\n >\n <ng-template [ngTemplateOutlet]=\"listItemTemplate\"></ng-template>\n </ol>\n <button\n *ngIf=\"expandable\"\n type=\"button\"\n class=\"sky-btn sky-btn-link-inline sky-text-expand-repeater-see-more\"\n [attr.aria-expanded]=\"isExpanded\"\n [attr.aria-controls]=\"contentSectionId\"\n (click)=\"repeaterExpand()\"\n [ngClass]=\"{\n 'sky-text-expand-repeater-see-more-list-style-none':\n listStyle === 'unstyled'\n }\"\n >\n {{ buttonText }}\n </button>\n</div>\n\n<ng-template let-item #defaultItemTemplate>\n {{ item }}\n</ng-template>\n\n<ng-template #listItemTemplate>\n <li *ngFor=\"let item of contentItems\" class=\"sky-text-expand-repeater-item\">\n <ng-template\n [ngTemplateOutlet]=\"itemTemplate || defaultItemTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: item }\"\n ></ng-template>\n </li>\n</ng-template>\n", styles: [".sky-text-expand-repeater-container{overflow-y:hidden;height:auto;margin-bottom:0;transition:max-height .25s}.sky-text-expand-repeater-see-more{white-space:nowrap;margin-left:40px}.sky-text-expand-repeater-list-style-none{list-style-type:none;padding-left:0}.sky-text-expand-repeater-see-more-list-style-none{margin-left:0}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] });
170
+ SkyTextExpandRepeaterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: SkyTextExpandRepeaterComponent, selector: "sky-text-expand-repeater", inputs: { data: "data", itemTemplate: "itemTemplate", listStyle: "listStyle", maxItems: "maxItems" }, providers: [SkyTextExpandRepeaterAdapterService], viewQueries: [{ propertyName: "containerEl", first: true, predicate: ["container"], descendants: true, read: ElementRef }], ngImport: i0, template: "<div class=\"sky-text-expand-repeater\">\n <ul\n *ngIf=\"listStyle !== 'ordered'\"\n class=\"sky-text-expand-repeater-container\"\n [@expansionAnimation]=\"{\n value: isExpanded,\n params: { transitionHeight: transitionHeight }\n }\"\n (@expansionAnimation.done)=\"animationEnd()\"\n [id]=\"contentSectionId\"\n [ngClass]=\"{\n 'sky-text-expand-repeater-list-style-none': listStyle === 'unstyled'\n }\"\n #container\n >\n <ng-template [ngTemplateOutlet]=\"listItemTemplate\"></ng-template>\n </ul>\n <ol\n *ngIf=\"listStyle === 'ordered'\"\n class=\"sky-text-expand-repeater-container\"\n [@expansionAnimation]=\"{\n value: isExpanded,\n params: { transitionHeight: transitionHeight }\n }\"\n (@expansionAnimation.done)=\"animationEnd()\"\n [id]=\"contentSectionId\"\n #container\n >\n <ng-template [ngTemplateOutlet]=\"listItemTemplate\"></ng-template>\n </ol>\n <button\n *ngIf=\"expandable\"\n type=\"button\"\n class=\"sky-btn sky-btn-link-inline sky-text-expand-repeater-see-more\"\n [attr.aria-expanded]=\"!!isExpanded\"\n [attr.aria-controls]=\"contentSectionId\"\n (click)=\"repeaterExpand()\"\n [ngClass]=\"{\n 'sky-text-expand-repeater-see-more-list-style-none':\n listStyle === 'unstyled'\n }\"\n >\n {{ buttonText }}\n </button>\n</div>\n\n<ng-template let-item #defaultItemTemplate>\n {{ item }}\n</ng-template>\n\n<ng-template #listItemTemplate>\n <li *ngFor=\"let item of data\" class=\"sky-text-expand-repeater-item\">\n <ng-template\n [ngTemplateOutlet]=\"itemTemplate || defaultItemTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: item }\"\n ></ng-template>\n </li>\n</ng-template>\n", styles: [".sky-text-expand-repeater-container{overflow-y:hidden;height:auto;margin-bottom:0}.sky-text-expand-repeater-see-more{white-space:nowrap;margin-left:40px}.sky-text-expand-repeater-list-style-none{list-style-type:none;padding-left:0}.sky-text-expand-repeater-see-more-list-style-none{margin-left:0}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], animations: [
171
+ trigger('expansionAnimation', [
172
+ transition(':enter', []),
173
+ state('true', style({
174
+ maxHeight: '{{transitionHeight}}px',
175
+ }), { params: { transitionHeight: 0 } }),
176
+ state('false', style({
177
+ maxHeight: '{{transitionHeight}}px',
178
+ }), { params: { transitionHeight: 0 } }),
179
+ transition('true => false', animate('250ms ease')),
180
+ transition('false => true', animate('250ms ease')),
181
+ transition('void => *', []),
182
+ ]),
183
+ ] });
153
184
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyTextExpandRepeaterComponent, decorators: [{
154
185
  type: Component,
155
- args: [{ selector: 'sky-text-expand-repeater', providers: [SkyTextExpandRepeaterAdapterService], template: "<div class=\"sky-text-expand-repeater\">\n <ul\n *ngIf=\"listStyle !== 'ordered'\"\n class=\"sky-text-expand-repeater-container\"\n [id]=\"contentSectionId\"\n (transitionend)=\"animationEnd()\"\n [ngClass]=\"{\n 'sky-text-expand-repeater-list-style-none': listStyle === 'unstyled'\n }\"\n #container\n >\n <ng-template [ngTemplateOutlet]=\"listItemTemplate\"></ng-template>\n </ul>\n <ol\n *ngIf=\"listStyle === 'ordered'\"\n class=\"sky-text-expand-repeater-container\"\n [id]=\"contentSectionId\"\n (transitionend)=\"animationEnd()\"\n #container\n >\n <ng-template [ngTemplateOutlet]=\"listItemTemplate\"></ng-template>\n </ol>\n <button\n *ngIf=\"expandable\"\n type=\"button\"\n class=\"sky-btn sky-btn-link-inline sky-text-expand-repeater-see-more\"\n [attr.aria-expanded]=\"isExpanded\"\n [attr.aria-controls]=\"contentSectionId\"\n (click)=\"repeaterExpand()\"\n [ngClass]=\"{\n 'sky-text-expand-repeater-see-more-list-style-none':\n listStyle === 'unstyled'\n }\"\n >\n {{ buttonText }}\n </button>\n</div>\n\n<ng-template let-item #defaultItemTemplate>\n {{ item }}\n</ng-template>\n\n<ng-template #listItemTemplate>\n <li *ngFor=\"let item of contentItems\" class=\"sky-text-expand-repeater-item\">\n <ng-template\n [ngTemplateOutlet]=\"itemTemplate || defaultItemTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: item }\"\n ></ng-template>\n </li>\n</ng-template>\n", styles: [".sky-text-expand-repeater-container{overflow-y:hidden;height:auto;margin-bottom:0;transition:max-height .25s}.sky-text-expand-repeater-see-more{white-space:nowrap;margin-left:40px}.sky-text-expand-repeater-list-style-none{list-style-type:none;padding-left:0}.sky-text-expand-repeater-see-more-list-style-none{margin-left:0}\n"] }]
186
+ args: [{ animations: [
187
+ trigger('expansionAnimation', [
188
+ transition(':enter', []),
189
+ state('true', style({
190
+ maxHeight: '{{transitionHeight}}px',
191
+ }), { params: { transitionHeight: 0 } }),
192
+ state('false', style({
193
+ maxHeight: '{{transitionHeight}}px',
194
+ }), { params: { transitionHeight: 0 } }),
195
+ transition('true => false', animate('250ms ease')),
196
+ transition('false => true', animate('250ms ease')),
197
+ transition('void => *', []),
198
+ ]),
199
+ ], selector: 'sky-text-expand-repeater', providers: [SkyTextExpandRepeaterAdapterService], template: "<div class=\"sky-text-expand-repeater\">\n <ul\n *ngIf=\"listStyle !== 'ordered'\"\n class=\"sky-text-expand-repeater-container\"\n [@expansionAnimation]=\"{\n value: isExpanded,\n params: { transitionHeight: transitionHeight }\n }\"\n (@expansionAnimation.done)=\"animationEnd()\"\n [id]=\"contentSectionId\"\n [ngClass]=\"{\n 'sky-text-expand-repeater-list-style-none': listStyle === 'unstyled'\n }\"\n #container\n >\n <ng-template [ngTemplateOutlet]=\"listItemTemplate\"></ng-template>\n </ul>\n <ol\n *ngIf=\"listStyle === 'ordered'\"\n class=\"sky-text-expand-repeater-container\"\n [@expansionAnimation]=\"{\n value: isExpanded,\n params: { transitionHeight: transitionHeight }\n }\"\n (@expansionAnimation.done)=\"animationEnd()\"\n [id]=\"contentSectionId\"\n #container\n >\n <ng-template [ngTemplateOutlet]=\"listItemTemplate\"></ng-template>\n </ol>\n <button\n *ngIf=\"expandable\"\n type=\"button\"\n class=\"sky-btn sky-btn-link-inline sky-text-expand-repeater-see-more\"\n [attr.aria-expanded]=\"!!isExpanded\"\n [attr.aria-controls]=\"contentSectionId\"\n (click)=\"repeaterExpand()\"\n [ngClass]=\"{\n 'sky-text-expand-repeater-see-more-list-style-none':\n listStyle === 'unstyled'\n }\"\n >\n {{ buttonText }}\n </button>\n</div>\n\n<ng-template let-item #defaultItemTemplate>\n {{ item }}\n</ng-template>\n\n<ng-template #listItemTemplate>\n <li *ngFor=\"let item of data\" class=\"sky-text-expand-repeater-item\">\n <ng-template\n [ngTemplateOutlet]=\"itemTemplate || defaultItemTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: item }\"\n ></ng-template>\n </li>\n</ng-template>\n", styles: [".sky-text-expand-repeater-container{overflow-y:hidden;height:auto;margin-bottom:0}.sky-text-expand-repeater-see-more{white-space:nowrap;margin-left:40px}.sky-text-expand-repeater-list-style-none{list-style-type:none;padding-left:0}.sky-text-expand-repeater-see-more-list-style-none{margin-left:0}\n"] }]
156
200
  }], ctorParameters: function () { return [{ type: i1.SkyLibResourcesService }, { type: i0.ElementRef }, { type: i2.SkyTextExpandRepeaterAdapterService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { data: [{
157
201
  type: Input
158
202
  }], itemTemplate: [{
@@ -168,4 +212,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
168
212
  static: false,
169
213
  }]
170
214
  }] } });
171
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-expand-repeater.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/layout/src/lib/modules/text-expand-repeater/text-expand-repeater.component.ts","../../../../../../../../libs/components/layout/src/lib/modules/text-expand-repeater/text-expand-repeater.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Input,\n  OnChanges,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { SkyLibResourcesService } from '@skyux/i18n';\n\nimport { forkJoin as observableForkJoin } from 'rxjs';\nimport { take } from 'rxjs/operators';\n\nimport { SkyTextExpandRepeaterAdapterService } from './text-expand-repeater-adapter.service';\nimport { SkyTextExpandRepeaterListStyleType } from './types/text-expand-repeater-list-style-type';\n\n/**\n * Auto-incrementing integer used to generate unique ids for text expand repeater components.\n */\nlet nextId = 0;\n\n@Component({\n  selector: 'sky-text-expand-repeater',\n  templateUrl: './text-expand-repeater.component.html',\n  styleUrls: ['./text-expand-repeater.component.scss'],\n  providers: [SkyTextExpandRepeaterAdapterService],\n})\nexport class SkyTextExpandRepeaterComponent\n  implements AfterViewInit, OnChanges\n{\n  /**\n   * Specifies the data to truncate.\n   */\n  @Input()\n  public data: any[];\n\n  /**\n   * Specifies a template for items in the list.\n   */\n  @Input()\n  public itemTemplate: TemplateRef<unknown>;\n\n  /**\n   * Specifies the style of bullet to use\n   * @default \"unordered\"\n   */\n  @Input()\n  public listStyle: SkyTextExpandRepeaterListStyleType = 'unordered';\n\n  /**\n   * Specifies the number of items to display before truncating the list.\n   */\n  @Input()\n  public maxItems: number;\n\n  public buttonText: string;\n  public contentItems: Array<any>;\n  public expandable: boolean;\n  public contentSectionId = `sky-text-expand-repeater-content-${++nextId}`;\n\n  public isExpanded = false;\n\n  private seeMoreText: string;\n  private seeLessText: string;\n\n  @ViewChild('container', {\n    read: ElementRef,\n    static: false,\n  })\n  private containerEl: ElementRef;\n\n  private items: Array<HTMLElement>;\n\n  constructor(\n    private resources: SkyLibResourcesService,\n    private elRef: ElementRef,\n    private textExpandRepeaterAdapter: SkyTextExpandRepeaterAdapterService,\n    private changeDetector: ChangeDetectorRef\n  ) {}\n\n  public ngAfterViewInit() {\n    if (this.contentItems) {\n      this.items = this.textExpandRepeaterAdapter.getItems(this.elRef);\n      for (let i = this.maxItems; i < this.contentItems.length; i++) {\n        this.textExpandRepeaterAdapter.hideItem(this.items[i]);\n      }\n    }\n\n    observableForkJoin([\n      this.resources.getString('skyux_text_expand_see_more'),\n      this.resources.getString('skyux_text_expand_see_less'),\n    ])\n      .pipe(take(1))\n      .subscribe((resources) => {\n        this.seeMoreText = resources[0];\n        this.seeLessText = resources[1];\n        /* sanity check */\n        /* istanbul ignore else */\n        if (!this.isExpanded) {\n          this.buttonText = this.seeMoreText;\n        } else {\n          this.buttonText = this.seeLessText;\n        }\n        this.changeDetector.detectChanges();\n      });\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    /* istanbul ignore else */\n    if (changes.maxItems || changes.data) {\n      this.setup(this.data);\n    }\n  }\n\n  public animationEnd() {\n    // Ensure the correct items are displayed\n    if (!this.isExpanded) {\n      for (let i = this.maxItems; i < this.contentItems.length; i++) {\n        this.textExpandRepeaterAdapter.hideItem(this.items[i]);\n      }\n    }\n    // Set height back to auto so the browser can change the height as needed with window changes\n    this.textExpandRepeaterAdapter.setContainerHeight(\n      this.containerEl,\n      undefined\n    );\n  }\n\n  public repeaterExpand() {\n    if (!this.isExpanded) {\n      this.setContainerMaxHeight();\n      setTimeout(() => {\n        this.isExpanded = true;\n        this.animateRepeater(true);\n      });\n    } else {\n      this.setContainerMaxHeight();\n      setTimeout(() => {\n        this.isExpanded = false;\n        this.animateRepeater(false);\n      });\n    }\n  }\n\n  private setContainerMaxHeight() {\n    // ensure everything is reset\n    this.animationEnd();\n    /* Before animation is kicked off, ensure that a maxHeight exists */\n    /* Once we have support for angular v4 animations with parameters we can use that instead */\n    const currentHeight = this.textExpandRepeaterAdapter.getContainerHeight(\n      this.containerEl\n    );\n    this.textExpandRepeaterAdapter.setContainerHeight(\n      this.containerEl,\n      `${currentHeight}px`\n    );\n  }\n\n  private animateRepeater(expanding: boolean) {\n    const adapter = this.textExpandRepeaterAdapter;\n    const container = this.containerEl;\n\n    adapter.setContainerHeight(container, undefined);\n    const currentHeight = adapter.getContainerHeight(container);\n    for (let i = this.maxItems; i < this.contentItems.length; i++) {\n      if (!expanding) {\n        adapter.hideItem(this.items[i]);\n      } else {\n        adapter.showItem(this.items[i]);\n      }\n    }\n    const newHeight = adapter.getContainerHeight(container);\n    if (!expanding) {\n      this.buttonText = this.seeMoreText;\n    } else {\n      this.buttonText = this.seeLessText;\n    }\n    if (newHeight < currentHeight) {\n      // The new text is smaller than the old text, so put the old text back before doing\n      // the collapse animation to avoid showing a big chunk of whitespace.\n      for (let i = this.maxItems; i < this.contentItems.length; i++) {\n        adapter.showItem(this.items[i]);\n      }\n    }\n\n    adapter.setContainerHeight(container, `${currentHeight}px`);\n    // This timeout is necessary due to the browser needing to pick up the non-auto height being set\n    // in order to do the transtion in height correctly. Without it the transition does not fire.\n    setTimeout(() => {\n      adapter.setContainerHeight(container, `${newHeight}px`);\n      /* This resets values if the transition does not get kicked off */\n      setTimeout(() => {\n        this.animationEnd();\n      }, 500);\n    }, 10);\n  }\n\n  private setup(value: Array<any>) {\n    if (value) {\n      const length = value.length;\n      if (length > this.maxItems) {\n        this.expandable = true;\n        this.buttonText = this.seeMoreText;\n        this.isExpanded = false;\n      } else {\n        this.expandable = false;\n      }\n      this.contentItems = value;\n    } else {\n      this.contentItems = undefined;\n      this.expandable = false;\n    }\n  }\n}\n","<div class=\"sky-text-expand-repeater\">\n  <ul\n    *ngIf=\"listStyle !== 'ordered'\"\n    class=\"sky-text-expand-repeater-container\"\n    [id]=\"contentSectionId\"\n    (transitionend)=\"animationEnd()\"\n    [ngClass]=\"{\n      'sky-text-expand-repeater-list-style-none': listStyle === 'unstyled'\n    }\"\n    #container\n  >\n    <ng-template [ngTemplateOutlet]=\"listItemTemplate\"></ng-template>\n  </ul>\n  <ol\n    *ngIf=\"listStyle === 'ordered'\"\n    class=\"sky-text-expand-repeater-container\"\n    [id]=\"contentSectionId\"\n    (transitionend)=\"animationEnd()\"\n    #container\n  >\n    <ng-template [ngTemplateOutlet]=\"listItemTemplate\"></ng-template>\n  </ol>\n  <button\n    *ngIf=\"expandable\"\n    type=\"button\"\n    class=\"sky-btn sky-btn-link-inline sky-text-expand-repeater-see-more\"\n    [attr.aria-expanded]=\"isExpanded\"\n    [attr.aria-controls]=\"contentSectionId\"\n    (click)=\"repeaterExpand()\"\n    [ngClass]=\"{\n      'sky-text-expand-repeater-see-more-list-style-none':\n        listStyle === 'unstyled'\n    }\"\n  >\n    {{ buttonText }}\n  </button>\n</div>\n\n<ng-template let-item #defaultItemTemplate>\n  {{ item }}\n</ng-template>\n\n<ng-template #listItemTemplate>\n  <li *ngFor=\"let item of contentItems\" class=\"sky-text-expand-repeater-item\">\n    <ng-template\n      [ngTemplateOutlet]=\"itemTemplate || defaultItemTemplate\"\n      [ngTemplateOutletContext]=\"{ $implicit: item }\"\n    ></ng-template>\n  </li>\n</ng-template>\n"]}
215
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-expand-repeater.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/layout/src/lib/modules/text-expand-repeater/text-expand-repeater.component.ts","../../../../../../../../libs/components/layout/src/lib/modules/text-expand-repeater/text-expand-repeater.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  animate,\n  state,\n  style,\n  transition,\n  trigger,\n} from '@angular/animations';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Input,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { SkyLibResourcesService } from '@skyux/i18n';\n\nimport { forkJoin as observableForkJoin } from 'rxjs';\nimport { take } from 'rxjs/operators';\n\nimport { SkyTextExpandRepeaterAdapterService } from './text-expand-repeater-adapter.service';\nimport { SkyTextExpandRepeaterListStyleType } from './types/text-expand-repeater-list-style-type';\n\n/**\n * Auto-incrementing integer used to generate unique ids for text expand repeater components.\n */\nlet nextId = 0;\n\n@Component({\n  animations: [\n    trigger('expansionAnimation', [\n      transition(':enter', []),\n      state(\n        'true',\n        style({\n          maxHeight: '{{transitionHeight}}px',\n        }),\n        { params: { transitionHeight: 0 } }\n      ),\n      state(\n        'false',\n        style({\n          maxHeight: '{{transitionHeight}}px',\n        }),\n        { params: { transitionHeight: 0 } }\n      ),\n      transition('true => false', animate('250ms ease')),\n      transition('false => true', animate('250ms ease')),\n      transition('void => *', []),\n    ]),\n  ],\n  selector: 'sky-text-expand-repeater',\n  templateUrl: './text-expand-repeater.component.html',\n  styleUrls: ['./text-expand-repeater.component.scss'],\n  providers: [SkyTextExpandRepeaterAdapterService],\n})\nexport class SkyTextExpandRepeaterComponent implements AfterViewInit {\n  /**\n   * Specifies the data to truncate.\n   */\n  @Input()\n  public set data(value: any[] | undefined) {\n    this.#_data = value;\n\n    // Wait for the dom to render the new items based on the updated data\n    setTimeout(() => {\n      this.#htmlItems = this.#textExpandRepeaterAdapter.getItems(this.#elRef);\n      this.#setup(value);\n    });\n  }\n\n  public get data(): any[] | undefined {\n    return this.#_data;\n  }\n\n  /**\n   * Specifies a template for items in the list.\n   */\n  @Input()\n  public itemTemplate: TemplateRef<unknown> | undefined;\n\n  /**\n   * Specifies the style of bullet to use\n   * @default \"unordered\"\n   */\n  @Input()\n  public listStyle: SkyTextExpandRepeaterListStyleType | undefined =\n    'unordered';\n\n  /**\n   * Specifies the number of items to display before truncating the list. If not supplied, all items are shown.\n   */\n  @Input()\n  public set maxItems(value: number | undefined) {\n    this.#_maxItems = value;\n    this.#setup(this.data);\n  }\n\n  public get maxItems(): number | undefined {\n    return this.#_maxItems;\n  }\n\n  public buttonText = '';\n  public expandable = false;\n  public contentSectionId = `sky-text-expand-repeater-content-${++nextId}`;\n\n  public isExpanded: boolean | undefined;\n  public transitionHeight = 1;\n\n  #seeMoreText = '';\n  #seeLessText = '';\n\n  @ViewChild('container', {\n    read: ElementRef,\n    static: false,\n  })\n  public containerEl: ElementRef | undefined;\n\n  #htmlItems: NodeListOf<HTMLElement> | undefined;\n\n  #_data: any[] | undefined;\n  #_maxItems: number | undefined;\n\n  #resources: SkyLibResourcesService;\n  #elRef: ElementRef;\n  #textExpandRepeaterAdapter: SkyTextExpandRepeaterAdapterService;\n  #changeDetector: ChangeDetectorRef;\n\n  constructor(\n    resources: SkyLibResourcesService,\n    elRef: ElementRef,\n    textExpandRepeaterAdapter: SkyTextExpandRepeaterAdapterService,\n    changeDetector: ChangeDetectorRef\n  ) {\n    this.#resources = resources;\n    this.#elRef = elRef;\n    this.#textExpandRepeaterAdapter = textExpandRepeaterAdapter;\n    this.#changeDetector = changeDetector;\n  }\n\n  public ngAfterViewInit(): void {\n    observableForkJoin([\n      this.#resources.getString('skyux_text_expand_see_more'),\n      this.#resources.getString('skyux_text_expand_see_less'),\n    ])\n      .pipe(take(1))\n      .subscribe((resources) => {\n        this.#seeMoreText = resources[0];\n        this.#seeLessText = resources[1];\n        /* sanity check */\n        /* istanbul ignore else */\n        if (!this.isExpanded) {\n          this.buttonText = this.#seeMoreText;\n        } else {\n          this.buttonText = this.#seeLessText;\n        }\n        this.#changeDetector.detectChanges();\n      });\n  }\n\n  public animationEnd(): void {\n    // Ensure all items that should be hidden are hidden. This is because we need them shown during the animation window for visual purposes.\n    if (!this.isExpanded) {\n      this.#hideItems();\n    }\n\n    // This set timeout is needed as the `animationEnd` function is called by the angular animation callback prior to the animation setting the style on the element\n    setTimeout(() => {\n      if (this.containerEl) {\n        // Set height back to auto so the browser can change the height as needed with window changes\n        this.#textExpandRepeaterAdapter.removeContainerMaxHeight(\n          this.containerEl\n        );\n      }\n    });\n  }\n\n  public repeaterExpand(): void {\n    if (!this.isExpanded) {\n      this.#animateRepeater(true);\n    } else {\n      this.#animateRepeater(false);\n    }\n  }\n\n  #animateRepeater(expanding: boolean): void {\n    const adapter = this.#textExpandRepeaterAdapter;\n    const container = this.containerEl;\n    if (container) {\n      if (expanding) {\n        this.#showItems();\n      } else {\n        this.#hideItems();\n      }\n      const newHeight = adapter.getContainerHeight(container);\n      this.transitionHeight = newHeight;\n      if (!expanding) {\n        this.buttonText = this.#seeMoreText;\n      } else {\n        this.buttonText = this.#seeLessText;\n      }\n      if (!expanding) {\n        // Show all items during animation for visual purposes.\n        this.#showItems();\n      }\n      this.isExpanded = expanding;\n    }\n  }\n\n  #setup(value: Array<unknown> | undefined): void {\n    if (value) {\n      const length = value.length;\n      if (this.maxItems && length > this.maxItems) {\n        this.expandable = true;\n        this.buttonText = this.#seeMoreText;\n        this.#hideItems();\n        if (this.containerEl) {\n          this.transitionHeight =\n            this.#textExpandRepeaterAdapter.getContainerHeight(\n              this.containerEl\n            );\n        }\n        this.isExpanded = false;\n      } else {\n        this.expandable = false;\n        this.isExpanded = undefined;\n      }\n    } else {\n      this.expandable = false;\n      this.isExpanded = undefined;\n    }\n    this.#changeDetector.markForCheck();\n  }\n\n  #hideItems(): void {\n    if (this.#htmlItems && this.maxItems) {\n      for (let i = this.maxItems; i < this.#htmlItems.length; i++) {\n        this.#textExpandRepeaterAdapter.hideItem(this.#htmlItems[i]);\n      }\n    }\n  }\n\n  #showItems(): void {\n    if (this.#htmlItems && this.maxItems) {\n      for (let i = this.maxItems; i < this.#htmlItems.length; i++) {\n        this.#textExpandRepeaterAdapter.showItem(this.#htmlItems[i]);\n      }\n    }\n  }\n}\n","<div class=\"sky-text-expand-repeater\">\n  <ul\n    *ngIf=\"listStyle !== 'ordered'\"\n    class=\"sky-text-expand-repeater-container\"\n    [@expansionAnimation]=\"{\n      value: isExpanded,\n      params: { transitionHeight: transitionHeight }\n    }\"\n    (@expansionAnimation.done)=\"animationEnd()\"\n    [id]=\"contentSectionId\"\n    [ngClass]=\"{\n      'sky-text-expand-repeater-list-style-none': listStyle === 'unstyled'\n    }\"\n    #container\n  >\n    <ng-template [ngTemplateOutlet]=\"listItemTemplate\"></ng-template>\n  </ul>\n  <ol\n    *ngIf=\"listStyle === 'ordered'\"\n    class=\"sky-text-expand-repeater-container\"\n    [@expansionAnimation]=\"{\n      value: isExpanded,\n      params: { transitionHeight: transitionHeight }\n    }\"\n    (@expansionAnimation.done)=\"animationEnd()\"\n    [id]=\"contentSectionId\"\n    #container\n  >\n    <ng-template [ngTemplateOutlet]=\"listItemTemplate\"></ng-template>\n  </ol>\n  <button\n    *ngIf=\"expandable\"\n    type=\"button\"\n    class=\"sky-btn sky-btn-link-inline sky-text-expand-repeater-see-more\"\n    [attr.aria-expanded]=\"!!isExpanded\"\n    [attr.aria-controls]=\"contentSectionId\"\n    (click)=\"repeaterExpand()\"\n    [ngClass]=\"{\n      'sky-text-expand-repeater-see-more-list-style-none':\n        listStyle === 'unstyled'\n    }\"\n  >\n    {{ buttonText }}\n  </button>\n</div>\n\n<ng-template let-item #defaultItemTemplate>\n  {{ item }}\n</ng-template>\n\n<ng-template #listItemTemplate>\n  <li *ngFor=\"let item of data\" class=\"sky-text-expand-repeater-item\">\n    <ng-template\n      [ngTemplateOutlet]=\"itemTemplate || defaultItemTemplate\"\n      [ngTemplateOutletContext]=\"{ $implicit: item }\"\n    ></ng-template>\n  </li>\n</ng-template>\n"]}
@@ -1,4 +1,4 @@
1
- import { Component, ContentChildren, QueryList } from '@angular/core';
1
+ import { Component, ContentChildren } from '@angular/core';
2
2
  import { SkyToolbarSectionComponent } from './toolbar-section.component';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "@angular/common";
@@ -22,4 +22,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
22
22
  type: ContentChildren,
23
23
  args: [SkyToolbarSectionComponent, { descendants: true }]
24
24
  }] } });
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbGJhci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGF5b3V0L3NyYy9saWIvbW9kdWxlcy90b29sYmFyL3Rvb2xiYXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xheW91dC9zcmMvbGliL21vZHVsZXMvdG9vbGJhci90b29sYmFyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsZUFBZSxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV0RSxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQzs7O0FBRXpFOztHQUVHO0FBTUgsTUFBTSxPQUFPLG1CQUFtQjtJQUxoQztRQU1TLGdCQUFXLEdBQUcsS0FBSyxDQUFDO0tBUTVCO0lBTkMsSUFDVyxpQkFBaUIsQ0FDMUIsS0FBd0Q7UUFFeEQsSUFBSSxDQUFDLFdBQVcsR0FBRyxDQUFDLENBQUMsS0FBSyxJQUFJLEtBQUssQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDO0lBQ2pELENBQUM7O2dIQVJVLG1CQUFtQjtvR0FBbkIsbUJBQW1CLHFGQUdiLDBCQUEwQixnRENmN0MsMlRBVUE7MkZERWEsbUJBQW1CO2tCQUwvQixTQUFTOytCQUNFLGFBQWE7OEJBUVosaUJBQWlCO3NCQUQzQixlQUFlO3VCQUFDLDBCQUEwQixFQUFFLEVBQUUsV0FBVyxFQUFFLElBQUksRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgQ29udGVudENoaWxkcmVuLCBRdWVyeUxpc3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgU2t5VG9vbGJhclNlY3Rpb25Db21wb25lbnQgfSBmcm9tICcuL3Rvb2xiYXItc2VjdGlvbi5jb21wb25lbnQnO1xuXG4vKipcbiAqIERpc3BsYXlzIGFjdGlvbnMgZm9yIGxpc3RzLCByZWNvcmRzLCBhbmQgdGlsZXMuXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NreS10b29sYmFyJyxcbiAgc3R5bGVVcmxzOiBbJy4vdG9vbGJhci5jb21wb25lbnQuc2NzcyddLFxuICB0ZW1wbGF0ZVVybDogJy4vdG9vbGJhci5jb21wb25lbnQuaHRtbCcsXG59KVxuZXhwb3J0IGNsYXNzIFNreVRvb2xiYXJDb21wb25lbnQge1xuICBwdWJsaWMgaGFzU2VjdGlvbnMgPSBmYWxzZTtcblxuICBAQ29udGVudENoaWxkcmVuKFNreVRvb2xiYXJTZWN0aW9uQ29tcG9uZW50LCB7IGRlc2NlbmRhbnRzOiB0cnVlIH0pXG4gIHB1YmxpYyBzZXQgc2VjdGlvbkNvbXBvbmVudHMoXG4gICAgdmFsdWU6IFF1ZXJ5TGlzdDxTa3lUb29sYmFyU2VjdGlvbkNvbXBvbmVudD4gfCB1bmRlZmluZWRcbiAgKSB7XG4gICAgdGhpcy5oYXNTZWN0aW9ucyA9ICEhdmFsdWUgJiYgdmFsdWUubGVuZ3RoID4gMDtcbiAgfVxufVxuIiwiPGRpdlxuICBjbGFzcz1cInNreS10b29sYmFyLWNvbnRhaW5lclwiXG4gIFtuZ0NsYXNzXT1cInsgJ3NreS10b29sYmFyLXNlY3Rpb25lZCc6IGhhc1NlY3Rpb25zIH1cIlxuPlxuICA8bmctY29udGVudCBzZWxlY3Q9XCJza3ktdG9vbGJhci1zZWN0aW9uXCI+PC9uZy1jb250ZW50PlxuICA8ZGl2IGNsYXNzPVwic2t5LXRvb2xiYXItaXRlbXNcIj5cbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gIDwvZGl2PlxuICA8bmctY29udGVudCBzZWxlY3Q9XCJza3ktdG9vbGJhci12aWV3LWFjdGlvbnNcIj48L25nLWNvbnRlbnQ+XG48L2Rpdj5cbiJdfQ==
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbGJhci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGF5b3V0L3NyYy9saWIvbW9kdWxlcy90b29sYmFyL3Rvb2xiYXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xheW91dC9zcmMvbGliL21vZHVsZXMvdG9vbGJhci90b29sYmFyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsZUFBZSxFQUFhLE1BQU0sZUFBZSxDQUFDO0FBRXRFLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLDZCQUE2QixDQUFDOzs7QUFFekU7O0dBRUc7QUFNSCxNQUFNLE9BQU8sbUJBQW1CO0lBTGhDO1FBTVMsZ0JBQVcsR0FBRyxLQUFLLENBQUM7S0FRNUI7SUFOQyxJQUNXLGlCQUFpQixDQUMxQixLQUF3RDtRQUV4RCxJQUFJLENBQUMsV0FBVyxHQUFHLENBQUMsQ0FBQyxLQUFLLElBQUksS0FBSyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUM7SUFDakQsQ0FBQzs7Z0hBUlUsbUJBQW1CO29HQUFuQixtQkFBbUIscUZBR2IsMEJBQTBCLGdEQ2Y3QywyVEFVQTsyRkRFYSxtQkFBbUI7a0JBTC9CLFNBQVM7K0JBQ0UsYUFBYTs4QkFRWixpQkFBaUI7c0JBRDNCLGVBQWU7dUJBQUMsMEJBQTBCLEVBQUUsRUFBRSxXQUFXLEVBQUUsSUFBSSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBDb250ZW50Q2hpbGRyZW4sIFF1ZXJ5TGlzdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBTa3lUb29sYmFyU2VjdGlvbkNvbXBvbmVudCB9IGZyb20gJy4vdG9vbGJhci1zZWN0aW9uLmNvbXBvbmVudCc7XG5cbi8qKlxuICogRGlzcGxheXMgYWN0aW9ucyBmb3IgbGlzdHMsIHJlY29yZHMsIGFuZCB0aWxlcy5cbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnc2t5LXRvb2xiYXInLFxuICBzdHlsZVVybHM6IFsnLi90b29sYmFyLmNvbXBvbmVudC5zY3NzJ10sXG4gIHRlbXBsYXRlVXJsOiAnLi90b29sYmFyLmNvbXBvbmVudC5odG1sJyxcbn0pXG5leHBvcnQgY2xhc3MgU2t5VG9vbGJhckNvbXBvbmVudCB7XG4gIHB1YmxpYyBoYXNTZWN0aW9ucyA9IGZhbHNlO1xuXG4gIEBDb250ZW50Q2hpbGRyZW4oU2t5VG9vbGJhclNlY3Rpb25Db21wb25lbnQsIHsgZGVzY2VuZGFudHM6IHRydWUgfSlcbiAgcHVibGljIHNldCBzZWN0aW9uQ29tcG9uZW50cyhcbiAgICB2YWx1ZTogUXVlcnlMaXN0PFNreVRvb2xiYXJTZWN0aW9uQ29tcG9uZW50PiB8IHVuZGVmaW5lZFxuICApIHtcbiAgICB0aGlzLmhhc1NlY3Rpb25zID0gISF2YWx1ZSAmJiB2YWx1ZS5sZW5ndGggPiAwO1xuICB9XG59XG4iLCI8ZGl2XG4gIGNsYXNzPVwic2t5LXRvb2xiYXItY29udGFpbmVyXCJcbiAgW25nQ2xhc3NdPVwieyAnc2t5LXRvb2xiYXItc2VjdGlvbmVkJzogaGFzU2VjdGlvbnMgfVwiXG4+XG4gIDxuZy1jb250ZW50IHNlbGVjdD1cInNreS10b29sYmFyLXNlY3Rpb25cIj48L25nLWNvbnRlbnQ+XG4gIDxkaXYgY2xhc3M9XCJza3ktdG9vbGJhci1pdGVtc1wiPlxuICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgPC9kaXY+XG4gIDxuZy1jb250ZW50IHNlbGVjdD1cInNreS10b29sYmFyLXZpZXctYWN0aW9uc1wiPjwvbmctY29udGVudD5cbjwvZGl2PlxuIl19
@@ -1,3 +1,5 @@
1
+ var _SkyActionButtonFixture_debugEl;
2
+ import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
1
3
  import { By } from '@angular/platform-browser';
2
4
  import { SkyAppTestUtility } from '@skyux-sdk/testing';
3
5
  /**
@@ -6,25 +8,26 @@ import { SkyAppTestUtility } from '@skyux-sdk/testing';
6
8
  */
7
9
  export class SkyActionButtonFixture {
8
10
  constructor(fixture, skyTestId) {
9
- this.debugEl = SkyAppTestUtility.getDebugElementByTestId(fixture, skyTestId, 'sky-action-button');
11
+ _SkyActionButtonFixture_debugEl.set(this, void 0);
12
+ __classPrivateFieldSet(this, _SkyActionButtonFixture_debugEl, SkyAppTestUtility.getDebugElementByTestId(fixture, skyTestId, 'sky-action-button'), "f");
10
13
  }
11
14
  /**
12
15
  * The action button's current header text.
13
16
  */
14
17
  get headerText() {
15
- return SkyAppTestUtility.getText(this.debugEl.query(By.css('.sky-action-button-header')));
18
+ return SkyAppTestUtility.getText(__classPrivateFieldGet(this, _SkyActionButtonFixture_debugEl, "f").query(By.css('.sky-action-button-header')));
16
19
  }
17
20
  /**
18
21
  * The action button's current details text.
19
22
  */
20
23
  get detailsText() {
21
- return SkyAppTestUtility.getText(this.debugEl.query(By.css('sky-action-button-details')));
24
+ return SkyAppTestUtility.getText(__classPrivateFieldGet(this, _SkyActionButtonFixture_debugEl, "f").query(By.css('sky-action-button-details')));
22
25
  }
23
26
  /**
24
27
  * The action button's current icon type.
25
28
  */
26
29
  get iconType() {
27
- const classList = this.debugEl.query(By.css('.fa.sky-icon')).nativeElement
30
+ const classList = __classPrivateFieldGet(this, _SkyActionButtonFixture_debugEl, "f").query(By.css('.fa.sky-icon')).nativeElement
28
31
  .classList;
29
32
  for (let i = 0, n = classList.length; i < n; i++) {
30
33
  const cls = classList.item(i);
@@ -32,14 +35,17 @@ export class SkyActionButtonFixture {
32
35
  return cls.substr(3);
33
36
  }
34
37
  }
38
+ /* istanbul ignore next */
39
+ return undefined;
35
40
  }
36
41
  /**
37
42
  * Clicks the action button.
38
43
  */
39
44
  actionClick() {
40
- this.debugEl
45
+ __classPrivateFieldGet(this, _SkyActionButtonFixture_debugEl, "f")
41
46
  .query(By.css('.sky-action-button'))
42
47
  .triggerEventHandler('click', {});
43
48
  }
44
49
  }
45
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9uLWJ1dHRvbi1maXh0dXJlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xheW91dC90ZXN0aW5nL3NyYy9hY3Rpb24tYnV0dG9uLWZpeHR1cmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLEVBQUUsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRXZEOzs7R0FHRztBQUNILE1BQU0sT0FBTyxzQkFBc0I7SUFxQ2pDLFlBQVksT0FBOEIsRUFBRSxTQUFpQjtRQUMzRCxJQUFJLENBQUMsT0FBTyxHQUFHLGlCQUFpQixDQUFDLHVCQUF1QixDQUN0RCxPQUFPLEVBQ1AsU0FBUyxFQUNULG1CQUFtQixDQUNwQixDQUFDO0lBQ0osQ0FBQztJQTFDRDs7T0FFRztJQUNILElBQVcsVUFBVTtRQUNuQixPQUFPLGlCQUFpQixDQUFDLE9BQU8sQ0FDOUIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQywyQkFBMkIsQ0FBQyxDQUFDLENBQ3hELENBQUM7SUFDSixDQUFDO0lBRUQ7O09BRUc7SUFDSCxJQUFXLFdBQVc7UUFDcEIsT0FBTyxpQkFBaUIsQ0FBQyxPQUFPLENBQzlCLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsMkJBQTJCLENBQUMsQ0FBQyxDQUN4RCxDQUFDO0lBQ0osQ0FBQztJQUVEOztPQUVHO0lBQ0gsSUFBVyxRQUFRO1FBQ2pCLE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxhQUFhO2FBQ3ZFLFNBQVMsQ0FBQztRQUViLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxTQUFTLENBQUMsTUFBTSxFQUFFLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUU7WUFDaEQsTUFBTSxHQUFHLEdBQUcsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUU5QixJQUFJLEdBQUcsQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxFQUFFO2dCQUM1QixPQUFPLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7YUFDdEI7U0FDRjtJQUNILENBQUM7SUFZRDs7T0FFRztJQUNJLFdBQVc7UUFDaEIsSUFBSSxDQUFDLE9BQU87YUFDVCxLQUFLLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO2FBQ25DLG1CQUFtQixDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsQ0FBQztJQUN0QyxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEZWJ1Z0VsZW1lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbXBvbmVudEZpeHR1cmUgfSBmcm9tICdAYW5ndWxhci9jb3JlL3Rlc3RpbmcnO1xuaW1wb3J0IHsgQnkgfSBmcm9tICdAYW5ndWxhci9wbGF0Zm9ybS1icm93c2VyJztcbmltcG9ydCB7IFNreUFwcFRlc3RVdGlsaXR5IH0gZnJvbSAnQHNreXV4LXNkay90ZXN0aW5nJztcblxuLyoqXG4gKiBBbGxvd3MgaW50ZXJhY3Rpb24gd2l0aCBhIFNLWSBVWCBhY3Rpb24gYnV0dG9uIGNvbXBvbmVudC5cbiAqIEBpbnRlcm5hbFxuICovXG5leHBvcnQgY2xhc3MgU2t5QWN0aW9uQnV0dG9uRml4dHVyZSB7XG4gIC8qKlxuICAgKiBUaGUgYWN0aW9uIGJ1dHRvbidzIGN1cnJlbnQgaGVhZGVyIHRleHQuXG4gICAqL1xuICBwdWJsaWMgZ2V0IGhlYWRlclRleHQoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gU2t5QXBwVGVzdFV0aWxpdHkuZ2V0VGV4dChcbiAgICAgIHRoaXMuZGVidWdFbC5xdWVyeShCeS5jc3MoJy5za3ktYWN0aW9uLWJ1dHRvbi1oZWFkZXInKSlcbiAgICApO1xuICB9XG5cbiAgLyoqXG4gICAqIFRoZSBhY3Rpb24gYnV0dG9uJ3MgY3VycmVudCBkZXRhaWxzIHRleHQuXG4gICAqL1xuICBwdWJsaWMgZ2V0IGRldGFpbHNUZXh0KCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIFNreUFwcFRlc3RVdGlsaXR5LmdldFRleHQoXG4gICAgICB0aGlzLmRlYnVnRWwucXVlcnkoQnkuY3NzKCdza3ktYWN0aW9uLWJ1dHRvbi1kZXRhaWxzJykpXG4gICAgKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBUaGUgYWN0aW9uIGJ1dHRvbidzIGN1cnJlbnQgaWNvbiB0eXBlLlxuICAgKi9cbiAgcHVibGljIGdldCBpY29uVHlwZSgpOiBzdHJpbmcge1xuICAgIGNvbnN0IGNsYXNzTGlzdCA9IHRoaXMuZGVidWdFbC5xdWVyeShCeS5jc3MoJy5mYS5za3ktaWNvbicpKS5uYXRpdmVFbGVtZW50XG4gICAgICAuY2xhc3NMaXN0O1xuXG4gICAgZm9yIChsZXQgaSA9IDAsIG4gPSBjbGFzc0xpc3QubGVuZ3RoOyBpIDwgbjsgaSsrKSB7XG4gICAgICBjb25zdCBjbHMgPSBjbGFzc0xpc3QuaXRlbShpKTtcblxuICAgICAgaWYgKGNscy5pbmRleE9mKCdmYS0nKSA9PT0gMCkge1xuICAgICAgICByZXR1cm4gY2xzLnN1YnN0cigzKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBwcml2YXRlIGRlYnVnRWw6IERlYnVnRWxlbWVudDtcblxuICBjb25zdHJ1Y3RvcihmaXh0dXJlOiBDb21wb25lbnRGaXh0dXJlPGFueT4sIHNreVRlc3RJZDogc3RyaW5nKSB7XG4gICAgdGhpcy5kZWJ1Z0VsID0gU2t5QXBwVGVzdFV0aWxpdHkuZ2V0RGVidWdFbGVtZW50QnlUZXN0SWQoXG4gICAgICBmaXh0dXJlLFxuICAgICAgc2t5VGVzdElkLFxuICAgICAgJ3NreS1hY3Rpb24tYnV0dG9uJ1xuICAgICk7XG4gIH1cblxuICAvKipcbiAgICogQ2xpY2tzIHRoZSBhY3Rpb24gYnV0dG9uLlxuICAgKi9cbiAgcHVibGljIGFjdGlvbkNsaWNrKCk6IHZvaWQge1xuICAgIHRoaXMuZGVidWdFbFxuICAgICAgLnF1ZXJ5KEJ5LmNzcygnLnNreS1hY3Rpb24tYnV0dG9uJykpXG4gICAgICAudHJpZ2dlckV2ZW50SGFuZGxlcignY2xpY2snLCB7fSk7XG4gIH1cbn1cbiJdfQ==
50
+ _SkyActionButtonFixture_debugEl = new WeakMap();
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9uLWJ1dHRvbi1maXh0dXJlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xheW91dC90ZXN0aW5nL3NyYy9hY3Rpb24tYnV0dG9uLWZpeHR1cmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFFQSxPQUFPLEVBQUUsRUFBRSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFdkQ7OztHQUdHO0FBQ0gsTUFBTSxPQUFPLHNCQUFzQjtJQXVDakMsWUFBWSxPQUE4QixFQUFFLFNBQWlCO1FBRjdELGtEQUF1QjtRQUdyQix1QkFBQSxJQUFJLG1DQUFZLGlCQUFpQixDQUFDLHVCQUF1QixDQUN2RCxPQUFPLEVBQ1AsU0FBUyxFQUNULG1CQUFtQixDQUNwQixNQUFBLENBQUM7SUFDSixDQUFDO0lBNUNEOztPQUVHO0lBQ0gsSUFBVyxVQUFVO1FBQ25CLE9BQU8saUJBQWlCLENBQUMsT0FBTyxDQUM5Qix1QkFBQSxJQUFJLHVDQUFTLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsMkJBQTJCLENBQUMsQ0FBQyxDQUN6RCxDQUFDO0lBQ0osQ0FBQztJQUVEOztPQUVHO0lBQ0gsSUFBVyxXQUFXO1FBQ3BCLE9BQU8saUJBQWlCLENBQUMsT0FBTyxDQUM5Qix1QkFBQSxJQUFJLHVDQUFTLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsMkJBQTJCLENBQUMsQ0FBQyxDQUN6RCxDQUFDO0lBQ0osQ0FBQztJQUVEOztPQUVHO0lBQ0gsSUFBVyxRQUFRO1FBQ2pCLE1BQU0sU0FBUyxHQUFHLHVCQUFBLElBQUksdUNBQVMsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLGFBQWE7YUFDeEUsU0FBUyxDQUFDO1FBRWIsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRTtZQUNoRCxNQUFNLEdBQUcsR0FBRyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBRTlCLElBQUksR0FBRyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLEVBQUU7Z0JBQzVCLE9BQU8sR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQzthQUN0QjtTQUNGO1FBQ0QsMEJBQTBCO1FBQzFCLE9BQU8sU0FBUyxDQUFDO0lBQ25CLENBQUM7SUFZRDs7T0FFRztJQUNJLFdBQVc7UUFDaEIsdUJBQUEsSUFBSSx1Q0FBUzthQUNWLEtBQUssQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLG9CQUFvQixDQUFDLENBQUM7YUFDbkMsbUJBQW1CLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3RDLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERlYnVnRWxlbWVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tcG9uZW50Rml4dHVyZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUvdGVzdGluZyc7XG5pbXBvcnQgeyBCeSB9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xuaW1wb3J0IHsgU2t5QXBwVGVzdFV0aWxpdHkgfSBmcm9tICdAc2t5dXgtc2RrL3Rlc3RpbmcnO1xuXG4vKipcbiAqIEFsbG93cyBpbnRlcmFjdGlvbiB3aXRoIGEgU0tZIFVYIGFjdGlvbiBidXR0b24gY29tcG9uZW50LlxuICogQGludGVybmFsXG4gKi9cbmV4cG9ydCBjbGFzcyBTa3lBY3Rpb25CdXR0b25GaXh0dXJlIHtcbiAgLyoqXG4gICAqIFRoZSBhY3Rpb24gYnV0dG9uJ3MgY3VycmVudCBoZWFkZXIgdGV4dC5cbiAgICovXG4gIHB1YmxpYyBnZXQgaGVhZGVyVGV4dCgpOiBzdHJpbmcgfCB1bmRlZmluZWQge1xuICAgIHJldHVybiBTa3lBcHBUZXN0VXRpbGl0eS5nZXRUZXh0KFxuICAgICAgdGhpcy4jZGVidWdFbC5xdWVyeShCeS5jc3MoJy5za3ktYWN0aW9uLWJ1dHRvbi1oZWFkZXInKSlcbiAgICApO1xuICB9XG5cbiAgLyoqXG4gICAqIFRoZSBhY3Rpb24gYnV0dG9uJ3MgY3VycmVudCBkZXRhaWxzIHRleHQuXG4gICAqL1xuICBwdWJsaWMgZ2V0IGRldGFpbHNUZXh0KCk6IHN0cmluZyB8IHVuZGVmaW5lZCB7XG4gICAgcmV0dXJuIFNreUFwcFRlc3RVdGlsaXR5LmdldFRleHQoXG4gICAgICB0aGlzLiNkZWJ1Z0VsLnF1ZXJ5KEJ5LmNzcygnc2t5LWFjdGlvbi1idXR0b24tZGV0YWlscycpKVxuICAgICk7XG4gIH1cblxuICAvKipcbiAgICogVGhlIGFjdGlvbiBidXR0b24ncyBjdXJyZW50IGljb24gdHlwZS5cbiAgICovXG4gIHB1YmxpYyBnZXQgaWNvblR5cGUoKTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcbiAgICBjb25zdCBjbGFzc0xpc3QgPSB0aGlzLiNkZWJ1Z0VsLnF1ZXJ5KEJ5LmNzcygnLmZhLnNreS1pY29uJykpLm5hdGl2ZUVsZW1lbnRcbiAgICAgIC5jbGFzc0xpc3Q7XG5cbiAgICBmb3IgKGxldCBpID0gMCwgbiA9IGNsYXNzTGlzdC5sZW5ndGg7IGkgPCBuOyBpKyspIHtcbiAgICAgIGNvbnN0IGNscyA9IGNsYXNzTGlzdC5pdGVtKGkpO1xuXG4gICAgICBpZiAoY2xzLmluZGV4T2YoJ2ZhLScpID09PSAwKSB7XG4gICAgICAgIHJldHVybiBjbHMuc3Vic3RyKDMpO1xuICAgICAgfVxuICAgIH1cbiAgICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICAjZGVidWdFbDogRGVidWdFbGVtZW50O1xuXG4gIGNvbnN0cnVjdG9yKGZpeHR1cmU6IENvbXBvbmVudEZpeHR1cmU8YW55Piwgc2t5VGVzdElkOiBzdHJpbmcpIHtcbiAgICB0aGlzLiNkZWJ1Z0VsID0gU2t5QXBwVGVzdFV0aWxpdHkuZ2V0RGVidWdFbGVtZW50QnlUZXN0SWQoXG4gICAgICBmaXh0dXJlLFxuICAgICAgc2t5VGVzdElkLFxuICAgICAgJ3NreS1hY3Rpb24tYnV0dG9uJ1xuICAgICk7XG4gIH1cblxuICAvKipcbiAgICogQ2xpY2tzIHRoZSBhY3Rpb24gYnV0dG9uLlxuICAgKi9cbiAgcHVibGljIGFjdGlvbkNsaWNrKCk6IHZvaWQge1xuICAgIHRoaXMuI2RlYnVnRWxcbiAgICAgIC5xdWVyeShCeS5jc3MoJy5za3ktYWN0aW9uLWJ1dHRvbicpKVxuICAgICAgLnRyaWdnZXJFdmVudEhhbmRsZXIoJ2NsaWNrJywge30pO1xuICB9XG59XG4iXX0=
@@ -1,3 +1,5 @@
1
+ var _SkyCardFixture_instances, _SkyCardFixture_debugEl, _SkyCardFixture_clickCheckLabelEl, _SkyCardFixture_getCheckInputEl;
2
+ import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
1
3
  import { By } from '@angular/platform-browser';
2
4
  import { SkyAppTestUtility } from '@skyux-sdk/testing';
3
5
  /**
@@ -6,25 +8,27 @@ import { SkyAppTestUtility } from '@skyux-sdk/testing';
6
8
  */
7
9
  export class SkyCardFixture {
8
10
  constructor(fixture, skyTestId) {
9
- this.debugEl = SkyAppTestUtility.getDebugElementByTestId(fixture, skyTestId, 'sky-card');
11
+ _SkyCardFixture_instances.add(this);
12
+ _SkyCardFixture_debugEl.set(this, void 0);
13
+ __classPrivateFieldSet(this, _SkyCardFixture_debugEl, SkyAppTestUtility.getDebugElementByTestId(fixture, skyTestId, 'sky-card'), "f");
10
14
  }
11
15
  /**
12
16
  * The card's current title.
13
17
  */
14
18
  get titleText() {
15
- return SkyAppTestUtility.getText(this.debugEl.query(By.css('sky-card-title')));
19
+ return SkyAppTestUtility.getText(__classPrivateFieldGet(this, _SkyCardFixture_debugEl, "f").query(By.css('sky-card-title')));
16
20
  }
17
21
  /**
18
22
  * The card's current content text.
19
23
  */
20
24
  get contentText() {
21
- return SkyAppTestUtility.getText(this.debugEl.query(By.css('sky-card-content')));
25
+ return SkyAppTestUtility.getText(__classPrivateFieldGet(this, _SkyCardFixture_debugEl, "f").query(By.css('sky-card-content')));
22
26
  }
23
27
  /**
24
28
  * A flag indicating whether the user can select the card.
25
29
  */
26
30
  get selectable() {
27
- return !!this.debugEl.query(By.css('.sky-card-check'));
31
+ return !!__classPrivateFieldGet(this, _SkyCardFixture_debugEl, "f").query(By.css('.sky-card-check'));
28
32
  }
29
33
  /**
30
34
  * A flag indicating whether the card is currently selected. If the card
@@ -32,7 +36,7 @@ export class SkyCardFixture {
32
36
  */
33
37
  get selected() {
34
38
  if (this.selectable) {
35
- return this.getCheckInputEl().nativeElement.checked;
39
+ return __classPrivateFieldGet(this, _SkyCardFixture_instances, "m", _SkyCardFixture_getCheckInputEl).call(this).nativeElement.checked;
36
40
  }
37
41
  throw new Error('The card is not selectable.');
38
42
  }
@@ -41,7 +45,7 @@ export class SkyCardFixture {
41
45
  */
42
46
  select() {
43
47
  if (!this.selected) {
44
- this.clickCheckLabelEl();
48
+ __classPrivateFieldGet(this, _SkyCardFixture_instances, "m", _SkyCardFixture_clickCheckLabelEl).call(this);
45
49
  }
46
50
  }
47
51
  /**
@@ -49,16 +53,15 @@ export class SkyCardFixture {
49
53
  */
50
54
  deselect() {
51
55
  if (this.selected) {
52
- this.clickCheckLabelEl();
56
+ __classPrivateFieldGet(this, _SkyCardFixture_instances, "m", _SkyCardFixture_clickCheckLabelEl).call(this);
53
57
  }
54
58
  }
55
- clickCheckLabelEl() {
56
- this.debugEl
57
- .query(By.css('.sky-card-check label.sky-checkbox-wrapper'))
58
- .nativeElement.click();
59
- }
60
- getCheckInputEl() {
61
- return this.debugEl.query(By.css('.sky-card-check .sky-checkbox-wrapper input'));
62
- }
63
59
  }
64
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FyZC1maXh0dXJlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xheW91dC90ZXN0aW5nL3NyYy9jYXJkLWZpeHR1cmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLEVBQUUsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRXZEOzs7R0FHRztBQUNILE1BQU0sT0FBTyxjQUFjO0lBd0N6QixZQUFZLE9BQThCLEVBQUUsU0FBaUI7UUFDM0QsSUFBSSxDQUFDLE9BQU8sR0FBRyxpQkFBaUIsQ0FBQyx1QkFBdUIsQ0FDdEQsT0FBTyxFQUNQLFNBQVMsRUFDVCxVQUFVLENBQ1gsQ0FBQztJQUNKLENBQUM7SUE3Q0Q7O09BRUc7SUFDSCxJQUFXLFNBQVM7UUFDbEIsT0FBTyxpQkFBaUIsQ0FBQyxPQUFPLENBQzlCLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxDQUM3QyxDQUFDO0lBQ0osQ0FBQztJQUVEOztPQUVHO0lBQ0gsSUFBVyxXQUFXO1FBQ3BCLE9BQU8saUJBQWlCLENBQUMsT0FBTyxDQUM5QixJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLGtCQUFrQixDQUFDLENBQUMsQ0FDL0MsQ0FBQztJQUNKLENBQUM7SUFFRDs7T0FFRztJQUNILElBQVcsVUFBVTtRQUNuQixPQUFPLENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLGlCQUFpQixDQUFDLENBQUMsQ0FBQztJQUN6RCxDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsSUFBVyxRQUFRO1FBQ2pCLElBQUksSUFBSSxDQUFDLFVBQVUsRUFBRTtZQUNuQixPQUFPLElBQUksQ0FBQyxlQUFlLEVBQUUsQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDO1NBQ3JEO1FBRUQsTUFBTSxJQUFJLEtBQUssQ0FBQyw2QkFBNkIsQ0FBQyxDQUFDO0lBQ2pELENBQUM7SUFZRDs7T0FFRztJQUNJLE1BQU07UUFDWCxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNsQixJQUFJLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztTQUMxQjtJQUNILENBQUM7SUFFRDs7T0FFRztJQUNJLFFBQVE7UUFDYixJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDakIsSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUM7U0FDMUI7SUFDSCxDQUFDO0lBRU8saUJBQWlCO1FBQ3ZCLElBQUksQ0FBQyxPQUFPO2FBQ1QsS0FBSyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsNENBQTRDLENBQUMsQ0FBQzthQUMzRCxhQUFhLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVPLGVBQWU7UUFDckIsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FDdkIsRUFBRSxDQUFDLEdBQUcsQ0FBQyw2Q0FBNkMsQ0FBQyxDQUN0RCxDQUFDO0lBQ0osQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGVidWdFbGVtZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21wb25lbnRGaXh0dXJlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZS90ZXN0aW5nJztcbmltcG9ydCB7IEJ5IH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XG5pbXBvcnQgeyBTa3lBcHBUZXN0VXRpbGl0eSB9IGZyb20gJ0Bza3l1eC1zZGsvdGVzdGluZyc7XG5cbi8qKlxuICogQWxsb3dzIGludGVyYWN0aW9uIHdpdGggYSBTS1kgVVggYXZhdGFyIGNvbXBvbmVudC5cbiAqIEBpbnRlcm5hbFxuICovXG5leHBvcnQgY2xhc3MgU2t5Q2FyZEZpeHR1cmUge1xuICAvKipcbiAgICogVGhlIGNhcmQncyBjdXJyZW50IHRpdGxlLlxuICAgKi9cbiAgcHVibGljIGdldCB0aXRsZVRleHQoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gU2t5QXBwVGVzdFV0aWxpdHkuZ2V0VGV4dChcbiAgICAgIHRoaXMuZGVidWdFbC5xdWVyeShCeS5jc3MoJ3NreS1jYXJkLXRpdGxlJykpXG4gICAgKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBUaGUgY2FyZCdzIGN1cnJlbnQgY29udGVudCB0ZXh0LlxuICAgKi9cbiAgcHVibGljIGdldCBjb250ZW50VGV4dCgpOiBzdHJpbmcge1xuICAgIHJldHVybiBTa3lBcHBUZXN0VXRpbGl0eS5nZXRUZXh0KFxuICAgICAgdGhpcy5kZWJ1Z0VsLnF1ZXJ5KEJ5LmNzcygnc2t5LWNhcmQtY29udGVudCcpKVxuICAgICk7XG4gIH1cblxuICAvKipcbiAgICogQSBmbGFnIGluZGljYXRpbmcgd2hldGhlciB0aGUgdXNlciBjYW4gc2VsZWN0IHRoZSBjYXJkLlxuICAgKi9cbiAgcHVibGljIGdldCBzZWxlY3RhYmxlKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiAhIXRoaXMuZGVidWdFbC5xdWVyeShCeS5jc3MoJy5za3ktY2FyZC1jaGVjaycpKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBBIGZsYWcgaW5kaWNhdGluZyB3aGV0aGVyIHRoZSBjYXJkIGlzIGN1cnJlbnRseSBzZWxlY3RlZC4gIElmIHRoZSBjYXJkXG4gICAqIGlzIG5vdCBzZWxlY3RhYmxlLCBhbiBlcnJvciBpcyB0aHJvd24uXG4gICAqL1xuICBwdWJsaWMgZ2V0IHNlbGVjdGVkKCk6IGJvb2xlYW4ge1xuICAgIGlmICh0aGlzLnNlbGVjdGFibGUpIHtcbiAgICAgIHJldHVybiB0aGlzLmdldENoZWNrSW5wdXRFbCgpLm5hdGl2ZUVsZW1lbnQuY2hlY2tlZDtcbiAgICB9XG5cbiAgICB0aHJvdyBuZXcgRXJyb3IoJ1RoZSBjYXJkIGlzIG5vdCBzZWxlY3RhYmxlLicpO1xuICB9XG5cbiAgcHJpdmF0ZSBkZWJ1Z0VsOiBEZWJ1Z0VsZW1lbnQ7XG5cbiAgY29uc3RydWN0b3IoZml4dHVyZTogQ29tcG9uZW50Rml4dHVyZTxhbnk+LCBza3lUZXN0SWQ6IHN0cmluZykge1xuICAgIHRoaXMuZGVidWdFbCA9IFNreUFwcFRlc3RVdGlsaXR5LmdldERlYnVnRWxlbWVudEJ5VGVzdElkKFxuICAgICAgZml4dHVyZSxcbiAgICAgIHNreVRlc3RJZCxcbiAgICAgICdza3ktY2FyZCdcbiAgICApO1xuICB9XG5cbiAgLyoqXG4gICAqIFNlbGVjdHMgdGhlIGNhcmQuXG4gICAqL1xuICBwdWJsaWMgc2VsZWN0KCk6IHZvaWQge1xuICAgIGlmICghdGhpcy5zZWxlY3RlZCkge1xuICAgICAgdGhpcy5jbGlja0NoZWNrTGFiZWxFbCgpO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBEZXNlbGVjdHMgdGhlIGNhcmQuXG4gICAqL1xuICBwdWJsaWMgZGVzZWxlY3QoKTogdm9pZCB7XG4gICAgaWYgKHRoaXMuc2VsZWN0ZWQpIHtcbiAgICAgIHRoaXMuY2xpY2tDaGVja0xhYmVsRWwoKTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIGNsaWNrQ2hlY2tMYWJlbEVsKCk6IHZvaWQge1xuICAgIHRoaXMuZGVidWdFbFxuICAgICAgLnF1ZXJ5KEJ5LmNzcygnLnNreS1jYXJkLWNoZWNrIGxhYmVsLnNreS1jaGVja2JveC13cmFwcGVyJykpXG4gICAgICAubmF0aXZlRWxlbWVudC5jbGljaygpO1xuICB9XG5cbiAgcHJpdmF0ZSBnZXRDaGVja0lucHV0RWwoKTogRGVidWdFbGVtZW50IHtcbiAgICByZXR1cm4gdGhpcy5kZWJ1Z0VsLnF1ZXJ5KFxuICAgICAgQnkuY3NzKCcuc2t5LWNhcmQtY2hlY2sgLnNreS1jaGVja2JveC13cmFwcGVyIGlucHV0JylcbiAgICApO1xuICB9XG59XG4iXX0=
60
+ _SkyCardFixture_debugEl = new WeakMap(), _SkyCardFixture_instances = new WeakSet(), _SkyCardFixture_clickCheckLabelEl = function _SkyCardFixture_clickCheckLabelEl() {
61
+ __classPrivateFieldGet(this, _SkyCardFixture_debugEl, "f")
62
+ .query(By.css('.sky-card-check label.sky-checkbox-wrapper'))
63
+ .nativeElement.click();
64
+ }, _SkyCardFixture_getCheckInputEl = function _SkyCardFixture_getCheckInputEl() {
65
+ return __classPrivateFieldGet(this, _SkyCardFixture_debugEl, "f").query(By.css('.sky-card-check .sky-checkbox-wrapper input'));
66
+ };
67
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FyZC1maXh0dXJlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xheW91dC90ZXN0aW5nL3NyYy9jYXJkLWZpeHR1cmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFFQSxPQUFPLEVBQUUsRUFBRSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFdkQ7OztHQUdHO0FBQ0gsTUFBTSxPQUFPLGNBQWM7SUF3Q3pCLFlBQVksT0FBOEIsRUFBRSxTQUFpQjs7UUFGN0QsMENBQXVCO1FBR3JCLHVCQUFBLElBQUksMkJBQVksaUJBQWlCLENBQUMsdUJBQXVCLENBQ3ZELE9BQU8sRUFDUCxTQUFTLEVBQ1QsVUFBVSxDQUNYLE1BQUEsQ0FBQztJQUNKLENBQUM7SUE3Q0Q7O09BRUc7SUFDSCxJQUFXLFNBQVM7UUFDbEIsT0FBTyxpQkFBaUIsQ0FBQyxPQUFPLENBQzlCLHVCQUFBLElBQUksK0JBQVMsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQzlDLENBQUM7SUFDSixDQUFDO0lBRUQ7O09BRUc7SUFDSCxJQUFXLFdBQVc7UUFDcEIsT0FBTyxpQkFBaUIsQ0FBQyxPQUFPLENBQzlCLHVCQUFBLElBQUksK0JBQVMsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDLENBQ2hELENBQUM7SUFDSixDQUFDO0lBRUQ7O09BRUc7SUFDSCxJQUFXLFVBQVU7UUFDbkIsT0FBTyxDQUFDLENBQUMsdUJBQUEsSUFBSSwrQkFBUyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLGlCQUFpQixDQUFDLENBQUMsQ0FBQztJQUMxRCxDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsSUFBVyxRQUFRO1FBQ2pCLElBQUksSUFBSSxDQUFDLFVBQVUsRUFBRTtZQUNuQixPQUFPLHVCQUFBLElBQUksa0VBQWlCLE1BQXJCLElBQUksQ0FBbUIsQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDO1NBQ3REO1FBRUQsTUFBTSxJQUFJLEtBQUssQ0FBQyw2QkFBNkIsQ0FBQyxDQUFDO0lBQ2pELENBQUM7SUFZRDs7T0FFRztJQUNJLE1BQU07UUFDWCxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNsQix1QkFBQSxJQUFJLG9FQUFtQixNQUF2QixJQUFJLENBQXFCLENBQUM7U0FDM0I7SUFDSCxDQUFDO0lBRUQ7O09BRUc7SUFDSSxRQUFRO1FBQ2IsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2pCLHVCQUFBLElBQUksb0VBQW1CLE1BQXZCLElBQUksQ0FBcUIsQ0FBQztTQUMzQjtJQUNILENBQUM7Q0FhRjs7SUFWRyx1QkFBQSxJQUFJLCtCQUFTO1NBQ1YsS0FBSyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsNENBQTRDLENBQUMsQ0FBQztTQUMzRCxhQUFhLENBQUMsS0FBSyxFQUFFLENBQUM7QUFDM0IsQ0FBQztJQUdDLE9BQU8sdUJBQUEsSUFBSSwrQkFBUyxDQUFDLEtBQUssQ0FDeEIsRUFBRSxDQUFDLEdBQUcsQ0FBQyw2Q0FBNkMsQ0FBQyxDQUN0RCxDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERlYnVnRWxlbWVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tcG9uZW50Rml4dHVyZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUvdGVzdGluZyc7XG5pbXBvcnQgeyBCeSB9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xuaW1wb3J0IHsgU2t5QXBwVGVzdFV0aWxpdHkgfSBmcm9tICdAc2t5dXgtc2RrL3Rlc3RpbmcnO1xuXG4vKipcbiAqIEFsbG93cyBpbnRlcmFjdGlvbiB3aXRoIGEgU0tZIFVYIGF2YXRhciBjb21wb25lbnQuXG4gKiBAaW50ZXJuYWxcbiAqL1xuZXhwb3J0IGNsYXNzIFNreUNhcmRGaXh0dXJlIHtcbiAgLyoqXG4gICAqIFRoZSBjYXJkJ3MgY3VycmVudCB0aXRsZS5cbiAgICovXG4gIHB1YmxpYyBnZXQgdGl0bGVUZXh0KCk6IHN0cmluZyB8IHVuZGVmaW5lZCB7XG4gICAgcmV0dXJuIFNreUFwcFRlc3RVdGlsaXR5LmdldFRleHQoXG4gICAgICB0aGlzLiNkZWJ1Z0VsLnF1ZXJ5KEJ5LmNzcygnc2t5LWNhcmQtdGl0bGUnKSlcbiAgICApO1xuICB9XG5cbiAgLyoqXG4gICAqIFRoZSBjYXJkJ3MgY3VycmVudCBjb250ZW50IHRleHQuXG4gICAqL1xuICBwdWJsaWMgZ2V0IGNvbnRlbnRUZXh0KCk6IHN0cmluZyB8IHVuZGVmaW5lZCB7XG4gICAgcmV0dXJuIFNreUFwcFRlc3RVdGlsaXR5LmdldFRleHQoXG4gICAgICB0aGlzLiNkZWJ1Z0VsLnF1ZXJ5KEJ5LmNzcygnc2t5LWNhcmQtY29udGVudCcpKVxuICAgICk7XG4gIH1cblxuICAvKipcbiAgICogQSBmbGFnIGluZGljYXRpbmcgd2hldGhlciB0aGUgdXNlciBjYW4gc2VsZWN0IHRoZSBjYXJkLlxuICAgKi9cbiAgcHVibGljIGdldCBzZWxlY3RhYmxlKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiAhIXRoaXMuI2RlYnVnRWwucXVlcnkoQnkuY3NzKCcuc2t5LWNhcmQtY2hlY2snKSk7XG4gIH1cblxuICAvKipcbiAgICogQSBmbGFnIGluZGljYXRpbmcgd2hldGhlciB0aGUgY2FyZCBpcyBjdXJyZW50bHkgc2VsZWN0ZWQuICBJZiB0aGUgY2FyZFxuICAgKiBpcyBub3Qgc2VsZWN0YWJsZSwgYW4gZXJyb3IgaXMgdGhyb3duLlxuICAgKi9cbiAgcHVibGljIGdldCBzZWxlY3RlZCgpOiBib29sZWFuIHtcbiAgICBpZiAodGhpcy5zZWxlY3RhYmxlKSB7XG4gICAgICByZXR1cm4gdGhpcy4jZ2V0Q2hlY2tJbnB1dEVsKCkubmF0aXZlRWxlbWVudC5jaGVja2VkO1xuICAgIH1cblxuICAgIHRocm93IG5ldyBFcnJvcignVGhlIGNhcmQgaXMgbm90IHNlbGVjdGFibGUuJyk7XG4gIH1cblxuICAjZGVidWdFbDogRGVidWdFbGVtZW50O1xuXG4gIGNvbnN0cnVjdG9yKGZpeHR1cmU6IENvbXBvbmVudEZpeHR1cmU8YW55Piwgc2t5VGVzdElkOiBzdHJpbmcpIHtcbiAgICB0aGlzLiNkZWJ1Z0VsID0gU2t5QXBwVGVzdFV0aWxpdHkuZ2V0RGVidWdFbGVtZW50QnlUZXN0SWQoXG4gICAgICBmaXh0dXJlLFxuICAgICAgc2t5VGVzdElkLFxuICAgICAgJ3NreS1jYXJkJ1xuICAgICk7XG4gIH1cblxuICAvKipcbiAgICogU2VsZWN0cyB0aGUgY2FyZC5cbiAgICovXG4gIHB1YmxpYyBzZWxlY3QoKTogdm9pZCB7XG4gICAgaWYgKCF0aGlzLnNlbGVjdGVkKSB7XG4gICAgICB0aGlzLiNjbGlja0NoZWNrTGFiZWxFbCgpO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBEZXNlbGVjdHMgdGhlIGNhcmQuXG4gICAqL1xuICBwdWJsaWMgZGVzZWxlY3QoKTogdm9pZCB7XG4gICAgaWYgKHRoaXMuc2VsZWN0ZWQpIHtcbiAgICAgIHRoaXMuI2NsaWNrQ2hlY2tMYWJlbEVsKCk7XG4gICAgfVxuICB9XG5cbiAgI2NsaWNrQ2hlY2tMYWJlbEVsKCk6IHZvaWQge1xuICAgIHRoaXMuI2RlYnVnRWxcbiAgICAgIC5xdWVyeShCeS5jc3MoJy5za3ktY2FyZC1jaGVjayBsYWJlbC5za3ktY2hlY2tib3gtd3JhcHBlcicpKVxuICAgICAgLm5hdGl2ZUVsZW1lbnQuY2xpY2soKTtcbiAgfVxuXG4gICNnZXRDaGVja0lucHV0RWwoKTogRGVidWdFbGVtZW50IHtcbiAgICByZXR1cm4gdGhpcy4jZGVidWdFbC5xdWVyeShcbiAgICAgIEJ5LmNzcygnLnNreS1jYXJkLWNoZWNrIC5za3ktY2hlY2tib3gtd3JhcHBlciBpbnB1dCcpXG4gICAgKTtcbiAgfVxufVxuIl19