@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.
- package/documentation.json +1355 -781
- package/esm2020/index.mjs +1 -2
- package/esm2020/lib/modules/action-button/action-button-container.component.mjs +2 -2
- package/esm2020/lib/modules/card/card.component.mjs +38 -11
- package/esm2020/lib/modules/definition-list/definition-list-label.component.mjs +1 -1
- package/esm2020/lib/modules/definition-list/definition-list-value.component.mjs +3 -3
- package/esm2020/lib/modules/definition-list/definition-list.component.mjs +1 -1
- package/esm2020/lib/modules/definition-list/definition-list.service.mjs +1 -1
- package/esm2020/lib/modules/description-list/description-list-adapter-service.mjs +26 -22
- package/esm2020/lib/modules/description-list/description-list-content.component.mjs +2 -2
- package/esm2020/lib/modules/description-list/description-list-description.component.mjs +16 -11
- package/esm2020/lib/modules/description-list/description-list-term.component.mjs +1 -1
- package/esm2020/lib/modules/description-list/description-list.component.mjs +25 -16
- package/esm2020/lib/modules/fluid-grid/column.component.mjs +19 -1
- package/esm2020/lib/modules/fluid-grid/fluid-grid.component.mjs +15 -35
- package/esm2020/lib/modules/fluid-grid/row.component.mjs +1 -1
- package/esm2020/lib/modules/fluid-grid/types/fluid-grid-gutter-size-type.mjs +1 -1
- package/esm2020/lib/modules/format/format.component.mjs +34 -26
- package/esm2020/lib/modules/inline-delete/inline-delete-adapter.service.mjs +91 -83
- package/esm2020/lib/modules/inline-delete/inline-delete.component.mjs +15 -9
- package/esm2020/lib/modules/page/page-theme-adapter.service.mjs +14 -8
- package/esm2020/lib/modules/page/page.component.mjs +8 -4
- package/esm2020/lib/modules/page-summary/page-summary-adapter.service.mjs +1 -1
- package/esm2020/lib/modules/page-summary/page-summary.component.mjs +40 -16
- package/esm2020/lib/modules/text-expand/text-expand-adapter.service.mjs +8 -10
- package/esm2020/lib/modules/text-expand/text-expand-modal-context-token.mjs +6 -0
- package/esm2020/lib/modules/text-expand/text-expand-modal-context.mjs +2 -6
- package/esm2020/lib/modules/text-expand/text-expand-modal.component.mjs +12 -10
- package/esm2020/lib/modules/text-expand/text-expand.component.mjs +188 -127
- package/esm2020/lib/modules/text-expand-repeater/text-expand-repeater-adapter.service.mjs +10 -12
- package/esm2020/lib/modules/text-expand-repeater/text-expand-repeater.component.mjs +139 -95
- package/esm2020/lib/modules/toolbar/toolbar.component.mjs +2 -2
- package/esm2020/testing/action-button-fixture.mjs +12 -6
- package/esm2020/testing/card-fixture.mjs +19 -16
- package/esm2020/testing/page-summary-fixture.mjs +9 -5
- package/fesm2015/skyux-layout-testing.mjs +35 -24
- package/fesm2015/skyux-layout-testing.mjs.map +1 -1
- package/fesm2015/skyux-layout.mjs +675 -506
- package/fesm2015/skyux-layout.mjs.map +1 -1
- package/fesm2020/skyux-layout-testing.mjs +35 -24
- package/fesm2020/skyux-layout-testing.mjs.map +1 -1
- package/fesm2020/skyux-layout.mjs +669 -506
- package/fesm2020/skyux-layout.mjs.map +1 -1
- package/index.d.ts +0 -1
- package/lib/modules/card/card.component.d.ts +7 -6
- package/lib/modules/definition-list/definition-list-label.component.d.ts +1 -1
- package/lib/modules/definition-list/definition-list-value.component.d.ts +1 -1
- package/lib/modules/definition-list/definition-list.component.d.ts +2 -2
- package/lib/modules/definition-list/definition-list.service.d.ts +2 -2
- package/lib/modules/description-list/description-list-adapter-service.d.ts +1 -2
- package/lib/modules/description-list/description-list-content.component.d.ts +2 -2
- package/lib/modules/description-list/description-list-description.component.d.ts +5 -7
- package/lib/modules/description-list/description-list-term.component.d.ts +1 -1
- package/lib/modules/description-list/description-list.component.d.ts +6 -7
- package/lib/modules/fluid-grid/column.component.d.ts +7 -5
- package/lib/modules/fluid-grid/fluid-grid.component.d.ts +3 -9
- package/lib/modules/fluid-grid/row.component.d.ts +1 -1
- package/lib/modules/fluid-grid/types/fluid-grid-gutter-size-type.d.ts +1 -1
- package/lib/modules/format/format.component.d.ts +5 -7
- package/lib/modules/inline-delete/inline-delete-adapter.service.d.ts +1 -11
- package/lib/modules/inline-delete/inline-delete.component.d.ts +3 -5
- package/lib/modules/page/page-theme-adapter.service.d.ts +1 -1
- package/lib/modules/page/page.component.d.ts +1 -1
- package/lib/modules/page-summary/page-summary.component.d.ts +8 -9
- package/lib/modules/text-expand/text-expand-adapter.service.d.ts +3 -4
- package/lib/modules/text-expand/text-expand-modal-context-token.d.ts +6 -0
- package/lib/modules/text-expand/text-expand-modal-context.d.ts +1 -1
- package/lib/modules/text-expand/text-expand.component.d.ts +18 -25
- package/lib/modules/text-expand-repeater/text-expand-repeater-adapter.service.d.ts +4 -5
- package/lib/modules/text-expand-repeater/text-expand-repeater.component.d.ts +13 -21
- package/package.json +9 -9
- package/testing/action-button-fixture.d.ts +4 -4
- package/testing/card-fixture.d.ts +3 -5
- package/testing/page-summary-fixture.d.ts +4 -4
- package/esm2020/lib/modules/fluid-grid/fluid-grid-gutter-size.mjs +0 -20
- package/lib/modules/fluid-grid/fluid-grid-gutter-size.d.ts +0 -18
|
@@ -1,4 +1,7 @@
|
|
|
1
|
-
|
|
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
|
|
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.
|
|
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.
|
|
37
|
-
this.
|
|
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
|
|
42
|
-
this
|
|
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
|
|
79
|
+
this.buttonText = __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_seeMoreText, "f");
|
|
47
80
|
}
|
|
48
81
|
else {
|
|
49
|
-
this.buttonText = this
|
|
82
|
+
this.buttonText = __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_seeLessText, "f");
|
|
50
83
|
}
|
|
51
|
-
this.
|
|
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
|
|
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
|
-
|
|
64
|
-
this.textExpandRepeaterAdapter.hideItem(this.items[i]);
|
|
65
|
-
}
|
|
90
|
+
__classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_instances, "m", _SkyTextExpandRepeaterComponent_hideItems).call(this);
|
|
66
91
|
}
|
|
67
|
-
//
|
|
68
|
-
|
|
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.
|
|
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.
|
|
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
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
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
|
|
122
|
+
this.buttonText = __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_seeMoreText, "f");
|
|
110
123
|
}
|
|
111
124
|
else {
|
|
112
|
-
this.buttonText = this
|
|
125
|
+
this.buttonText = __classPrivateFieldGet(this, _SkyTextExpandRepeaterComponent_seeLessText, "f");
|
|
113
126
|
}
|
|
114
|
-
if (
|
|
115
|
-
//
|
|
116
|
-
|
|
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
|
-
|
|
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
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
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
|
-
|
|
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 }],
|
|
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: [{
|
|
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
|
|
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,
|
|
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
|
-
|
|
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.
|
|
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.
|
|
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.
|
|
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
|
|
45
|
+
__classPrivateFieldGet(this, _SkyActionButtonFixture_debugEl, "f")
|
|
41
46
|
.query(By.css('.sky-action-button'))
|
|
42
47
|
.triggerEventHandler('click', {});
|
|
43
48
|
}
|
|
44
49
|
}
|
|
45
|
-
|
|
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
|
-
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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
|
-
|
|
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
|