@skyux/lists 8.0.0-alpha.8 → 8.0.0-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/documentation.json +1970 -457
- package/esm2020/lib/modules/infinite-scroll/infinite-scroll.component.mjs +1 -1
- package/esm2020/lib/modules/paging/paging.component.mjs +2 -2
- package/esm2020/lib/modules/repeater/repeater-auto-scroll-options.mjs +2 -0
- package/esm2020/lib/modules/repeater/repeater-auto-scroll.service.mjs +17 -0
- package/esm2020/lib/modules/repeater/repeater-auto-scroller.mjs +2 -0
- package/esm2020/lib/modules/repeater/repeater-item.component.mjs +13 -11
- package/esm2020/lib/modules/repeater/repeater.component.mjs +82 -37
- package/esm2020/lib/modules/shared/sky-lists-resources.module.mjs +5 -3
- package/esm2020/lib/modules/sort/sort-item.component.mjs +3 -3
- package/esm2020/testing/repeater/repeater-harness.mjs +1 -2
- package/esm2020/testing/repeater/repeater-item-harness.mjs +97 -10
- package/fesm2015/skyux-lists-testing.mjs +119 -12
- package/fesm2015/skyux-lists-testing.mjs.map +1 -1
- package/fesm2015/skyux-lists.mjs +124 -61
- package/fesm2015/skyux-lists.mjs.map +1 -1
- package/fesm2020/skyux-lists-testing.mjs +96 -10
- package/fesm2020/skyux-lists-testing.mjs.map +1 -1
- package/fesm2020/skyux-lists.mjs +123 -61
- package/fesm2020/skyux-lists.mjs.map +1 -1
- package/lib/modules/repeater/repeater-auto-scroll-options.d.ts +9 -0
- package/lib/modules/repeater/repeater-auto-scroll.service.d.ts +11 -0
- package/lib/modules/repeater/repeater-auto-scroller.d.ts +6 -0
- package/lib/modules/repeater/repeater-item.component.d.ts +2 -1
- package/lib/modules/repeater/repeater.component.d.ts +4 -6
- package/package.json +11 -10
- package/testing/repeater/repeater-harness.d.ts +0 -1
- package/testing/repeater/repeater-item-harness.d.ts +45 -6
|
@@ -1,17 +1,19 @@
|
|
|
1
|
-
var _SkyRepeaterComponent_instances, _SkyRepeaterComponent_adapterService, _SkyRepeaterComponent_changeDetector, _SkyRepeaterComponent_dragulaService, _SkyRepeaterComponent_elementRef, _SkyRepeaterComponent_renderer, _SkyRepeaterComponent_repeaterService,
|
|
1
|
+
var _SkyRepeaterComponent_instances, _SkyRepeaterComponent_autoScroller, _SkyRepeaterComponent_ngUnsubscribe, _SkyRepeaterComponent_itemNameWarned, _SkyRepeaterComponent_adapterService, _SkyRepeaterComponent_changeDetector, _SkyRepeaterComponent_dragulaService, _SkyRepeaterComponent_elementRef, _SkyRepeaterComponent_renderer, _SkyRepeaterComponent_repeaterService, _SkyRepeaterComponent_autoScrollSvc, _SkyRepeaterComponent_scrollableHostSvc, _SkyRepeaterComponent_logSvc, _SkyRepeaterComponent_updateForExpandMode, _SkyRepeaterComponent_initializeDragAndDrop, _SkyRepeaterComponent_destroyDragAndDrop, _SkyRepeaterComponent_destroyAutoScroll, _SkyRepeaterComponent_emitTags, _SkyRepeaterComponent_everyItemHasTag, _SkyRepeaterComponent_updateRole, _SkyRepeaterComponent_updateReorderability, _SkyRepeaterComponent_validateTags;
|
|
2
2
|
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
|
-
import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Input, Output, } from '@angular/core';
|
|
3
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, ElementRef, EventEmitter, Input, Output, Renderer2, inject, } from '@angular/core';
|
|
4
|
+
import { SkyLogService } from '@skyux/core';
|
|
5
|
+
import { SkyScrollableHostService } from '@skyux/core';
|
|
6
|
+
import { DragulaService } from 'ng2-dragula';
|
|
4
7
|
import { Subject } from 'rxjs';
|
|
5
8
|
import { takeUntil } from 'rxjs/operators';
|
|
6
9
|
import { SkyRepeaterAdapterService } from './repeater-adapter.service';
|
|
10
|
+
import { SkyRepeaterAutoScrollService } from './repeater-auto-scroll.service';
|
|
7
11
|
import { SkyRepeaterItemComponent } from './repeater-item.component';
|
|
8
12
|
import { SkyRepeaterService } from './repeater.service';
|
|
9
13
|
import * as i0 from "@angular/core";
|
|
10
|
-
import * as i1 from "
|
|
11
|
-
import * as i2 from "
|
|
12
|
-
import * as i3 from "
|
|
13
|
-
import * as i4 from "@angular/cdk/observers";
|
|
14
|
-
import * as i5 from "@skyux/i18n";
|
|
14
|
+
import * as i1 from "ng2-dragula";
|
|
15
|
+
import * as i2 from "@angular/cdk/observers";
|
|
16
|
+
import * as i3 from "@skyux/i18n";
|
|
15
17
|
/**
|
|
16
18
|
* Creates a container to display repeater items.
|
|
17
19
|
*/
|
|
@@ -42,7 +44,7 @@ export class SkyRepeaterComponent {
|
|
|
42
44
|
get expandMode() {
|
|
43
45
|
return __classPrivateFieldGet(this, _SkyRepeaterComponent_repeaterService, "f").expandMode;
|
|
44
46
|
}
|
|
45
|
-
constructor(
|
|
47
|
+
constructor() {
|
|
46
48
|
_SkyRepeaterComponent_instances.add(this);
|
|
47
49
|
/**
|
|
48
50
|
* Whether users can change the order of items in the repeater list.
|
|
@@ -59,19 +61,18 @@ export class SkyRepeaterComponent {
|
|
|
59
61
|
* This event emits an ordered array of the `tag` properties that the consumer provides for each repeater item.
|
|
60
62
|
*/
|
|
61
63
|
this.orderChange = new EventEmitter();
|
|
62
|
-
|
|
63
|
-
_SkyRepeaterComponent_changeDetector.set(this, void 0);
|
|
64
|
-
_SkyRepeaterComponent_dragulaService.set(this, void 0);
|
|
65
|
-
_SkyRepeaterComponent_elementRef.set(this, void 0);
|
|
66
|
-
_SkyRepeaterComponent_renderer.set(this, void 0);
|
|
67
|
-
_SkyRepeaterComponent_repeaterService.set(this, void 0);
|
|
64
|
+
_SkyRepeaterComponent_autoScroller.set(this, void 0);
|
|
68
65
|
_SkyRepeaterComponent_ngUnsubscribe.set(this, new Subject());
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
66
|
+
_SkyRepeaterComponent_itemNameWarned.set(this, false);
|
|
67
|
+
_SkyRepeaterComponent_adapterService.set(this, inject(SkyRepeaterAdapterService));
|
|
68
|
+
_SkyRepeaterComponent_changeDetector.set(this, inject(ChangeDetectorRef));
|
|
69
|
+
_SkyRepeaterComponent_dragulaService.set(this, inject(DragulaService));
|
|
70
|
+
_SkyRepeaterComponent_elementRef.set(this, inject(ElementRef));
|
|
71
|
+
_SkyRepeaterComponent_renderer.set(this, inject(Renderer2));
|
|
72
|
+
_SkyRepeaterComponent_repeaterService.set(this, inject(SkyRepeaterService));
|
|
73
|
+
_SkyRepeaterComponent_autoScrollSvc.set(this, inject(SkyRepeaterAutoScrollService));
|
|
74
|
+
_SkyRepeaterComponent_scrollableHostSvc.set(this, inject(SkyScrollableHostService));
|
|
75
|
+
_SkyRepeaterComponent_logSvc.set(this, inject(SkyLogService));
|
|
75
76
|
this.dragulaGroupName = `sky-repeater-dragula-${__classPrivateFieldGet(this, _SkyRepeaterComponent_repeaterService, "f").repeaterGroupId}`;
|
|
76
77
|
__classPrivateFieldGet(this, _SkyRepeaterComponent_repeaterService, "f").itemCollapseStateChange
|
|
77
78
|
.pipe(takeUntil(__classPrivateFieldGet(this, _SkyRepeaterComponent_ngUnsubscribe, "f")))
|
|
@@ -109,22 +110,22 @@ export class SkyRepeaterComponent {
|
|
|
109
110
|
if (this.activeIndex || this.activeIndex === 0) {
|
|
110
111
|
__classPrivateFieldGet(this, _SkyRepeaterComponent_repeaterService, "f").activateItemByIndex(this.activeIndex);
|
|
111
112
|
}
|
|
112
|
-
|
|
113
|
-
console.warn('Please supply tag properties for each repeater item when reordering functionality is enabled.');
|
|
114
|
-
}
|
|
113
|
+
__classPrivateFieldGet(this, _SkyRepeaterComponent_instances, "m", _SkyRepeaterComponent_validateTags).call(this);
|
|
115
114
|
});
|
|
116
115
|
// HACK: Not updating for expand mode in a timeout causes an error.
|
|
117
116
|
// https://github.com/angular/angular/issues/6005
|
|
118
117
|
this.items?.changes.pipe(takeUntil(__classPrivateFieldGet(this, _SkyRepeaterComponent_ngUnsubscribe, "f"))).subscribe(() => {
|
|
119
118
|
setTimeout(() => {
|
|
120
|
-
if (this.items?.
|
|
119
|
+
if (this.items?.length) {
|
|
121
120
|
__classPrivateFieldGet(this, _SkyRepeaterComponent_instances, "m", _SkyRepeaterComponent_updateForExpandMode).call(this, this.items.last);
|
|
122
|
-
this
|
|
121
|
+
__classPrivateFieldGet(this, _SkyRepeaterComponent_instances, "m", _SkyRepeaterComponent_updateReorderability).call(this);
|
|
122
|
+
__classPrivateFieldGet(this, _SkyRepeaterComponent_repeaterService, "f").items = this.items.toArray();
|
|
123
123
|
}
|
|
124
124
|
if (this.activeIndex !== undefined) {
|
|
125
125
|
__classPrivateFieldGet(this, _SkyRepeaterComponent_repeaterService, "f").activateItemByIndex(this.activeIndex);
|
|
126
126
|
}
|
|
127
127
|
__classPrivateFieldGet(this, _SkyRepeaterComponent_instances, "m", _SkyRepeaterComponent_updateRole).call(this);
|
|
128
|
+
__classPrivateFieldGet(this, _SkyRepeaterComponent_instances, "m", _SkyRepeaterComponent_validateTags).call(this);
|
|
128
129
|
});
|
|
129
130
|
});
|
|
130
131
|
setTimeout(() => {
|
|
@@ -135,6 +136,15 @@ export class SkyRepeaterComponent {
|
|
|
135
136
|
__classPrivateFieldGet(this, _SkyRepeaterComponent_instances, "m", _SkyRepeaterComponent_updateRole).call(this);
|
|
136
137
|
}, 0);
|
|
137
138
|
}
|
|
139
|
+
ngAfterViewChecked() {
|
|
140
|
+
if (!__classPrivateFieldGet(this, _SkyRepeaterComponent_itemNameWarned, "f") && this.items?.some((item) => !item.itemName)) {
|
|
141
|
+
__classPrivateFieldGet(this, _SkyRepeaterComponent_logSvc, "f")?.deprecated('SkyRepeaterItemComponent without `itemName`', {
|
|
142
|
+
deprecationMajorVersion: 8,
|
|
143
|
+
replacementRecommendation: 'Always specify an `itemName` property.',
|
|
144
|
+
});
|
|
145
|
+
__classPrivateFieldSet(this, _SkyRepeaterComponent_itemNameWarned, true, "f");
|
|
146
|
+
}
|
|
147
|
+
}
|
|
138
148
|
ngOnChanges(changes) {
|
|
139
149
|
if (changes['activeIndex']) {
|
|
140
150
|
__classPrivateFieldGet(this, _SkyRepeaterComponent_repeaterService, "f").enableActiveState = true;
|
|
@@ -145,7 +155,7 @@ export class SkyRepeaterComponent {
|
|
|
145
155
|
}
|
|
146
156
|
if (changes.reorderable) {
|
|
147
157
|
if (this.items) {
|
|
148
|
-
this
|
|
158
|
+
__classPrivateFieldGet(this, _SkyRepeaterComponent_instances, "m", _SkyRepeaterComponent_updateReorderability).call(this);
|
|
149
159
|
}
|
|
150
160
|
__classPrivateFieldGet(this, _SkyRepeaterComponent_instances, "m", _SkyRepeaterComponent_updateRole).call(this);
|
|
151
161
|
__classPrivateFieldGet(this, _SkyRepeaterComponent_changeDetector, "f").markForCheck();
|
|
@@ -163,7 +173,7 @@ export class SkyRepeaterComponent {
|
|
|
163
173
|
__classPrivateFieldGet(this, _SkyRepeaterComponent_instances, "m", _SkyRepeaterComponent_updateRole).call(this);
|
|
164
174
|
}
|
|
165
175
|
}
|
|
166
|
-
_SkyRepeaterComponent_adapterService = new WeakMap(), _SkyRepeaterComponent_changeDetector = new WeakMap(), _SkyRepeaterComponent_dragulaService = new WeakMap(), _SkyRepeaterComponent_elementRef = new WeakMap(), _SkyRepeaterComponent_renderer = new WeakMap(), _SkyRepeaterComponent_repeaterService = new WeakMap(),
|
|
176
|
+
_SkyRepeaterComponent_autoScroller = new WeakMap(), _SkyRepeaterComponent_ngUnsubscribe = new WeakMap(), _SkyRepeaterComponent_itemNameWarned = new WeakMap(), _SkyRepeaterComponent_adapterService = new WeakMap(), _SkyRepeaterComponent_changeDetector = new WeakMap(), _SkyRepeaterComponent_dragulaService = new WeakMap(), _SkyRepeaterComponent_elementRef = new WeakMap(), _SkyRepeaterComponent_renderer = new WeakMap(), _SkyRepeaterComponent_repeaterService = new WeakMap(), _SkyRepeaterComponent_autoScrollSvc = new WeakMap(), _SkyRepeaterComponent_scrollableHostSvc = new WeakMap(), _SkyRepeaterComponent_logSvc = new WeakMap(), _SkyRepeaterComponent_instances = new WeakSet(), _SkyRepeaterComponent_updateForExpandMode = function _SkyRepeaterComponent_updateForExpandMode(itemAdded) {
|
|
167
177
|
if (this.items) {
|
|
168
178
|
let foundExpanded = false;
|
|
169
179
|
const isCollapsible = this.expandMode !== 'none';
|
|
@@ -172,15 +182,18 @@ _SkyRepeaterComponent_adapterService = new WeakMap(), _SkyRepeaterComponent_chan
|
|
|
172
182
|
if (itemAdded && itemAdded.isExpanded) {
|
|
173
183
|
foundExpanded = true;
|
|
174
184
|
}
|
|
175
|
-
this.items
|
|
185
|
+
for (const item of this.items) {
|
|
176
186
|
item.isCollapsible = isCollapsible && !!item.hasItemContent;
|
|
187
|
+
// Collapse any items that aren't the item that was just added.
|
|
177
188
|
if (item !== itemAdded && isSingle && item.isExpanded) {
|
|
178
189
|
if (foundExpanded) {
|
|
179
|
-
item
|
|
190
|
+
// If this item is being collapsed because a new item was
|
|
191
|
+
// added, animate it.
|
|
192
|
+
item.updateForExpanded(false, !!itemAdded);
|
|
180
193
|
}
|
|
181
194
|
foundExpanded = true;
|
|
182
195
|
}
|
|
183
|
-
}
|
|
196
|
+
}
|
|
184
197
|
__classPrivateFieldGet(this, _SkyRepeaterComponent_instances, "m", _SkyRepeaterComponent_updateRole).call(this);
|
|
185
198
|
}
|
|
186
199
|
}, _SkyRepeaterComponent_initializeDragAndDrop = function _SkyRepeaterComponent_initializeDragAndDrop() {
|
|
@@ -188,9 +201,9 @@ _SkyRepeaterComponent_adapterService = new WeakMap(), _SkyRepeaterComponent_chan
|
|
|
188
201
|
/* istanbul ignore else */
|
|
189
202
|
if (!__classPrivateFieldGet(this, _SkyRepeaterComponent_dragulaService, "f").find(this.dragulaGroupName)) {
|
|
190
203
|
__classPrivateFieldGet(this, _SkyRepeaterComponent_dragulaService, "f").createGroup(this.dragulaGroupName, {
|
|
191
|
-
moves: (el,
|
|
204
|
+
moves: (el, _container, handle) => {
|
|
192
205
|
const target = el?.querySelector('.sky-repeater-item-grab-handle');
|
|
193
|
-
return !!this.reorderable &&
|
|
206
|
+
return !!(this.reorderable && target?.contains(handle));
|
|
194
207
|
},
|
|
195
208
|
});
|
|
196
209
|
}
|
|
@@ -201,6 +214,13 @@ _SkyRepeaterComponent_adapterService = new WeakMap(), _SkyRepeaterComponent_chan
|
|
|
201
214
|
.subscribe((args) => {
|
|
202
215
|
/* istanbul ignore else */
|
|
203
216
|
if (args.name === this.dragulaGroupName) {
|
|
217
|
+
__classPrivateFieldGet(this, _SkyRepeaterComponent_instances, "m", _SkyRepeaterComponent_destroyAutoScroll).call(this);
|
|
218
|
+
__classPrivateFieldSet(this, _SkyRepeaterComponent_autoScroller, __classPrivateFieldGet(this, _SkyRepeaterComponent_autoScrollSvc, "f").autoScroll([__classPrivateFieldGet(this, _SkyRepeaterComponent_scrollableHostSvc, "f").getScrollableHost(__classPrivateFieldGet(this, _SkyRepeaterComponent_elementRef, "f"))], {
|
|
219
|
+
margin: 20,
|
|
220
|
+
maxSpeed: 10,
|
|
221
|
+
scrollWhenOutside: true,
|
|
222
|
+
autoScroll: () => true,
|
|
223
|
+
}), "f");
|
|
204
224
|
__classPrivateFieldGet(this, _SkyRepeaterComponent_renderer, "f").addClass(args.el, 'sky-repeater-item-dragging');
|
|
205
225
|
draggedItemIndex = __classPrivateFieldGet(this, _SkyRepeaterComponent_adapterService, "f").getRepeaterItemIndex(args.el);
|
|
206
226
|
}
|
|
@@ -211,6 +231,7 @@ _SkyRepeaterComponent_adapterService = new WeakMap(), _SkyRepeaterComponent_chan
|
|
|
211
231
|
.subscribe((args) => {
|
|
212
232
|
/* istanbul ignore else */
|
|
213
233
|
if (args.name === this.dragulaGroupName) {
|
|
234
|
+
__classPrivateFieldGet(this, _SkyRepeaterComponent_instances, "m", _SkyRepeaterComponent_destroyAutoScroll).call(this);
|
|
214
235
|
__classPrivateFieldGet(this, _SkyRepeaterComponent_renderer, "f").removeClass(args.el, 'sky-repeater-item-dragging');
|
|
215
236
|
const newItemIndex = __classPrivateFieldGet(this, _SkyRepeaterComponent_adapterService, "f").getRepeaterItemIndex(args.el);
|
|
216
237
|
/* sanity check */
|
|
@@ -228,6 +249,12 @@ _SkyRepeaterComponent_adapterService = new WeakMap(), _SkyRepeaterComponent_chan
|
|
|
228
249
|
if (__classPrivateFieldGet(this, _SkyRepeaterComponent_dragulaService, "f").find(this.dragulaGroupName)) {
|
|
229
250
|
__classPrivateFieldGet(this, _SkyRepeaterComponent_dragulaService, "f").destroy(this.dragulaGroupName);
|
|
230
251
|
}
|
|
252
|
+
__classPrivateFieldGet(this, _SkyRepeaterComponent_instances, "m", _SkyRepeaterComponent_destroyAutoScroll).call(this);
|
|
253
|
+
}, _SkyRepeaterComponent_destroyAutoScroll = function _SkyRepeaterComponent_destroyAutoScroll() {
|
|
254
|
+
if (__classPrivateFieldGet(this, _SkyRepeaterComponent_autoScroller, "f")) {
|
|
255
|
+
__classPrivateFieldGet(this, _SkyRepeaterComponent_autoScroller, "f").destroy();
|
|
256
|
+
__classPrivateFieldSet(this, _SkyRepeaterComponent_autoScroller, undefined, "f");
|
|
257
|
+
}
|
|
231
258
|
}, _SkyRepeaterComponent_emitTags = function _SkyRepeaterComponent_emitTags() {
|
|
232
259
|
const tags = __classPrivateFieldGet(this, _SkyRepeaterComponent_repeaterService, "f").items.map((item) => item.tag);
|
|
233
260
|
this.orderChange.emit(tags);
|
|
@@ -287,13 +314,31 @@ _SkyRepeaterComponent_adapterService = new WeakMap(), _SkyRepeaterComponent_chan
|
|
|
287
314
|
this.role = `${autoRole}`;
|
|
288
315
|
__classPrivateFieldGet(this, _SkyRepeaterComponent_changeDetector, "f").markForCheck();
|
|
289
316
|
}
|
|
317
|
+
}, _SkyRepeaterComponent_updateReorderability = function _SkyRepeaterComponent_updateReorderability() {
|
|
318
|
+
if (this.items) {
|
|
319
|
+
for (const item of this.items) {
|
|
320
|
+
item.reorderable = this.reorderable;
|
|
321
|
+
}
|
|
322
|
+
}
|
|
323
|
+
}, _SkyRepeaterComponent_validateTags = function _SkyRepeaterComponent_validateTags() {
|
|
324
|
+
if (this.reorderable && !__classPrivateFieldGet(this, _SkyRepeaterComponent_instances, "m", _SkyRepeaterComponent_everyItemHasTag).call(this)) {
|
|
325
|
+
console.warn('Please supply tag properties for each repeater item when reordering functionality is enabled.');
|
|
326
|
+
}
|
|
290
327
|
};
|
|
291
|
-
SkyRepeaterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.1", ngImport: i0, type: SkyRepeaterComponent, deps: [
|
|
292
|
-
SkyRepeaterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.1", type: SkyRepeaterComponent, selector: "sky-repeater", inputs: { activeIndex: "activeIndex", ariaLabel: "ariaLabel", reorderable: "reorderable", expandMode: "expandMode" }, outputs: { activeIndexChange: "activeIndexChange", orderChange: "orderChange" }, providers: [
|
|
328
|
+
SkyRepeaterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.1", ngImport: i0, type: SkyRepeaterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
329
|
+
SkyRepeaterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.1", type: SkyRepeaterComponent, selector: "sky-repeater", inputs: { activeIndex: "activeIndex", ariaLabel: "ariaLabel", reorderable: "reorderable", expandMode: "expandMode" }, outputs: { activeIndexChange: "activeIndexChange", orderChange: "orderChange" }, providers: [
|
|
330
|
+
SkyRepeaterService,
|
|
331
|
+
SkyRepeaterAdapterService,
|
|
332
|
+
SkyRepeaterAutoScrollService,
|
|
333
|
+
], queries: [{ propertyName: "items", predicate: SkyRepeaterItemComponent }], usesOnChanges: true, ngImport: i0, template: "<ng-container #repeaterHost>\n <div\n class=\"sky-repeater\"\n [attr.role]=\"role\"\n [attr.aria-label]=\"ariaLabel || ('skyux_repeater_label' | skyLibResources)\"\n [dragula]=\"dragulaGroupName\"\n (cdkObserveContent)=\"onCdkObserveContent()\"\n >\n <ng-content></ng-content>\n </div>\n</ng-container>\n", styles: [".sky-repeater{padding:0}\n"], dependencies: [{ kind: "directive", type: i1.DragulaDirective, selector: "[dragula]", inputs: ["dragula", "dragulaModel"], outputs: ["dragulaModelChange"] }, { kind: "directive", type: i2.CdkObserveContent, selector: "[cdkObserveContent]", inputs: ["cdkObserveContentDisabled", "debounce"], outputs: ["cdkObserveContent"], exportAs: ["cdkObserveContent"] }, { kind: "pipe", type: i3.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
293
334
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.1", ngImport: i0, type: SkyRepeaterComponent, decorators: [{
|
|
294
335
|
type: Component,
|
|
295
|
-
args: [{ selector: 'sky-repeater', providers: [
|
|
296
|
-
|
|
336
|
+
args: [{ selector: 'sky-repeater', providers: [
|
|
337
|
+
SkyRepeaterService,
|
|
338
|
+
SkyRepeaterAdapterService,
|
|
339
|
+
SkyRepeaterAutoScrollService,
|
|
340
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container #repeaterHost>\n <div\n class=\"sky-repeater\"\n [attr.role]=\"role\"\n [attr.aria-label]=\"ariaLabel || ('skyux_repeater_label' | skyLibResources)\"\n [dragula]=\"dragulaGroupName\"\n (cdkObserveContent)=\"onCdkObserveContent()\"\n >\n <ng-content></ng-content>\n </div>\n</ng-container>\n", styles: [".sky-repeater{padding:0}\n"] }]
|
|
341
|
+
}], ctorParameters: function () { return []; }, propDecorators: { activeIndex: [{
|
|
297
342
|
type: Input
|
|
298
343
|
}], ariaLabel: [{
|
|
299
344
|
type: Input
|
|
@@ -309,4 +354,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.1", ngImpor
|
|
|
309
354
|
type: ContentChildren,
|
|
310
355
|
args: [SkyRepeaterItemComponent]
|
|
311
356
|
}] } });
|
|
312
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"repeater.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/lists/src/lib/modules/repeater/repeater.component.ts","../../../../../../../../libs/components/lists/src/lib/modules/repeater/repeater.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  QueryList,\n  Renderer2,\n  SimpleChanges,\n} from '@angular/core';\n\nimport { DragulaService } from 'ng2-dragula';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyRepeaterAdapterService } from './repeater-adapter.service';\nimport { SkyRepeaterExpandModeType } from './repeater-expand-mode-type';\nimport { SkyRepeaterItemRolesType } from './repeater-item-roles.type';\nimport { SkyRepeaterItemComponent } from './repeater-item.component';\nimport { SkyRepeaterRoleType } from './repeater-role.type';\nimport { SkyRepeaterService } from './repeater.service';\n\n/**\n * Creates a container to display repeater items.\n */\n@Component({\n  selector: 'sky-repeater',\n  styleUrls: ['./repeater.component.scss'],\n  templateUrl: './repeater.component.html',\n  providers: [SkyRepeaterService, SkyRepeaterAdapterService],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyRepeaterComponent\n  implements AfterContentInit, OnChanges, OnDestroy, OnInit\n{\n  /**\n   * The index of the repeater item to visually highlight as active.\n   * For example, use this property in conjunction with the\n   * [split view component](https://developer.blackbaud.com/skyux/components/split-view)\n   * to highlight a repeater item while users edit it. Only one item can be active at a time.\n   */\n  @Input()\n  public activeIndex: number | undefined;\n\n  /**\n   * The ARIA label for the repeater list.\n   * This sets the repeater list's `aria-label` attribute to provide a text equivalent for screen readers\n   * [to support accessibility](https://developer.blackbaud.com/skyux/learn/accessibility).\n   * For more information about the `aria-label` attribute, see the [WAI-ARIA definition](https://www.w3.org/TR/wai-aria/#aria-label).\n   * @default \"List of items\"\n   */\n  @Input()\n  public ariaLabel: string | undefined;\n\n  /**\n   * Whether users can change the order of items in the repeater list.\n   * Each repeater item also has `reorderable` property to indicate whether\n   * users can change its order.\n   */\n  @Input()\n  public reorderable: boolean | undefined = false;\n\n  /**\n   * The layout that determines which repeater items are expanded by default and whether\n   * repeater items are expandable and collapsible. Collapsed items display titles only.\n   * The valid options are `multiple`, `none`, and `single`.\n   * - `multiple` loads repeater items in an expanded state unless `isExpanded` is set to\n   * `false` for a repeater item. This layout allows users to expand and collapse\n   * as many repeater items as necessary. It is best-suited to repeater items where body\n   * content is important but users don't always need to see it.\n   * - `none` loads all repeater items in an expanded state and does not allow users to\n   * collapse them. This default layout provides the quickest access to the details in the\n   * repeater items. It is best-suited to repeater items with concise content\n   * that users need to view frequently.\n   * - `single` loads one repeater item in an expanded state and collapses all others.\n   * The expanded repeater item is the first one where `isExpanded` is set to `true`. This layout\n   * allows users to expand one item at a time. It provides the most compact view and is\n   * best-suited to repeater items where the most important information is in the titles\n   * and users only occasionally need to view the body content.\n   * @default \"none\"\n   */\n  @Input()\n  public set expandMode(value: SkyRepeaterExpandModeType | undefined) {\n    this.#repeaterService.expandMode = value;\n    this.#updateForExpandMode();\n  }\n\n  public get expandMode(): SkyRepeaterExpandModeType {\n    return this.#repeaterService.expandMode;\n  }\n\n  /**\n   * Fires when the active repeater item changes.\n   */\n  @Output()\n  public activeIndexChange = new EventEmitter<number>();\n\n  /**\n   * Fires when users change the order of repeater items.\n   * This event emits an ordered array of the `tag` properties that the consumer provides for each repeater item.\n   */\n  @Output()\n  public orderChange = new EventEmitter<any[]>();\n\n  @ContentChildren(SkyRepeaterItemComponent)\n  public items: QueryList<SkyRepeaterItemComponent> | undefined;\n\n  public dragulaGroupName: string;\n\n  public role: SkyRepeaterRoleType | undefined;\n\n  #adapterService: SkyRepeaterAdapterService;\n  #changeDetector: ChangeDetectorRef;\n  #dragulaService: DragulaService;\n  #elementRef: ElementRef;\n  #renderer: Renderer2;\n  #repeaterService: SkyRepeaterService;\n  #ngUnsubscribe = new Subject<void>();\n\n  constructor(\n    changeDetector: ChangeDetectorRef,\n    repeaterService: SkyRepeaterService,\n    adapterService: SkyRepeaterAdapterService,\n    dragulaService: DragulaService,\n    elementRef: ElementRef,\n    renderer: Renderer2\n  ) {\n    this.#changeDetector = changeDetector;\n    this.#repeaterService = repeaterService;\n    this.#adapterService = adapterService;\n    this.#dragulaService = dragulaService;\n    this.#elementRef = elementRef;\n    this.#renderer = renderer;\n\n    this.dragulaGroupName = `sky-repeater-dragula-${\n      this.#repeaterService.repeaterGroupId\n    }`;\n\n    this.#repeaterService.itemCollapseStateChange\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((item: SkyRepeaterItemComponent) => {\n        if (this.expandMode === 'single' && item.isExpanded) {\n          this.items?.forEach((otherItem) => {\n            if (\n              otherItem !== item &&\n              otherItem.isExpanded &&\n              otherItem.isCollapsible\n            ) {\n              otherItem.isExpanded = false;\n            }\n          });\n        }\n      });\n\n    this.#repeaterService.activeItemIndexChange\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((index) => {\n        if (index !== this.activeIndex) {\n          this.activeIndex = index;\n          this.activeIndexChange.emit(index);\n        }\n      });\n\n    this.#repeaterService.orderChange\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        this.#emitTags();\n      });\n\n    this.#updateForExpandMode();\n\n    this.#adapterService.setRepeaterHost(this.#elementRef);\n\n    this.#initializeDragAndDrop();\n  }\n\n  public ngAfterContentInit(): void {\n    // If activeIndex has been set on init, call service to activate the appropriate item.\n    setTimeout(() => {\n      if (this.activeIndex || this.activeIndex === 0) {\n        this.#repeaterService.activateItemByIndex(this.activeIndex);\n      }\n\n      if (this.reorderable && !this.#everyItemHasTag()) {\n        console.warn(\n          'Please supply tag properties for each repeater item when reordering functionality is enabled.'\n        );\n      }\n    });\n\n    // HACK: Not updating for expand mode in a timeout causes an error.\n    // https://github.com/angular/angular/issues/6005\n    this.items?.changes.pipe(takeUntil(this.#ngUnsubscribe)).subscribe(() => {\n      setTimeout(() => {\n        if (this.items?.last) {\n          this.#updateForExpandMode(this.items.last);\n          this.items.last.reorderable = this.reorderable;\n        }\n\n        if (this.activeIndex !== undefined) {\n          this.#repeaterService.activateItemByIndex(this.activeIndex);\n        }\n\n        this.#updateRole();\n      });\n    });\n\n    setTimeout(() => {\n      this.#updateForExpandMode();\n\n      this.items?.forEach((item) => {\n        item.reorderable = this.reorderable;\n      });\n\n      this.#updateRole();\n    }, 0);\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes['activeIndex']) {\n      this.#repeaterService.enableActiveState = true;\n      if (\n        changes['activeIndex'].currentValue !==\n        changes['activeIndex'].previousValue\n      ) {\n        this.#repeaterService.activateItemByIndex(this.activeIndex);\n      }\n    }\n\n    if (changes.reorderable) {\n      if (this.items) {\n        this.items.forEach((item) => (item.reorderable = this.reorderable));\n      }\n      this.#updateRole();\n\n      this.#changeDetector.markForCheck();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n    this.#destroyDragAndDrop();\n  }\n\n  public ngOnInit(): void {\n    this.#updateRole();\n  }\n\n  public onCdkObserveContent(): void {\n    this.#updateRole();\n  }\n\n  #updateForExpandMode(itemAdded?: SkyRepeaterItemComponent): void {\n    if (this.items) {\n      let foundExpanded = false;\n      const isCollapsible = this.expandMode !== 'none';\n      const isSingle = this.expandMode === 'single';\n\n      // Keep any newly-added expanded item expanded and collapse the rest.\n      if (itemAdded && itemAdded.isExpanded) {\n        foundExpanded = true;\n      }\n\n      this.items.forEach((item) => {\n        item.isCollapsible = isCollapsible && !!item.hasItemContent;\n\n        if (item !== itemAdded && isSingle && item.isExpanded) {\n          if (foundExpanded) {\n            item.updateForExpanded(false);\n          }\n\n          foundExpanded = true;\n        }\n      });\n\n      this.#updateRole();\n    }\n  }\n\n  #initializeDragAndDrop(): void {\n    /* Sanity check that we haven't already set up dragging abilities */\n    /* istanbul ignore else */\n    if (!this.#dragulaService.find(this.dragulaGroupName)) {\n      this.#dragulaService.createGroup(this.dragulaGroupName, {\n        moves: (el, container, handle) => {\n          const target = el?.querySelector('.sky-repeater-item-grab-handle');\n          return !!this.reorderable && !!target && target.contains(handle!);\n        },\n      });\n    }\n\n    let draggedItemIndex = -1;\n\n    this.#dragulaService\n      .drag(this.dragulaGroupName)\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((args) => {\n        /* istanbul ignore else */\n        if (args.name === this.dragulaGroupName) {\n          this.#renderer.addClass(args.el, 'sky-repeater-item-dragging');\n          draggedItemIndex = this.#adapterService.getRepeaterItemIndex(\n            args.el as HTMLElement\n          );\n        }\n      });\n\n    this.#dragulaService\n      .dragend(this.dragulaGroupName)\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((args) => {\n        /* istanbul ignore else */\n        if (args.name === this.dragulaGroupName) {\n          this.#renderer.removeClass(args.el, 'sky-repeater-item-dragging');\n          const newItemIndex = this.#adapterService.getRepeaterItemIndex(\n            args.el as HTMLElement\n          );\n\n          /* sanity check */\n          /* istanbul ignore else */\n          if (draggedItemIndex >= 0) {\n            this.#repeaterService.reorderItem(draggedItemIndex, newItemIndex);\n            draggedItemIndex = -1;\n          }\n\n          this.#emitTags();\n        }\n      });\n  }\n\n  #destroyDragAndDrop(): void {\n    /* Sanity check that we have set up dragging abilities */\n    /* istanbul ignore else */\n    if (this.#dragulaService.find(this.dragulaGroupName)) {\n      this.#dragulaService.destroy(this.dragulaGroupName);\n    }\n  }\n\n  #emitTags(): void {\n    const tags = this.#repeaterService.items.map((item) => item.tag);\n    this.orderChange.emit(tags);\n  }\n\n  #everyItemHasTag(): boolean {\n    /* sanity check */\n    /* istanbul ignore if */\n    if (!this.items || this.items.length === 0) {\n      return false;\n    }\n    return this.items.toArray().every((item) => {\n      return item.tag !== undefined;\n    });\n  }\n\n  #updateRole(): void {\n    // Determine a role using a hierarchy based on https://www.w3.org/TR/wai-aria-practices-1.1/\n    //   1. If there are one or more interactions in the repeater item projected content, use grid.\n    //   2. If there are selectable repeater items and no other interactions, use listbox.\n    //   3. If there are no interactions, use list.\n\n    // Default to list role.\n    let autoRole: SkyRepeaterRoleType = 'list';\n\n    const roleMap: Record<SkyRepeaterRoleType, SkyRepeaterItemRolesType> = {\n      list: { item: 'listitem', title: undefined, content: undefined },\n      listbox: { item: 'option', title: undefined, content: undefined },\n      grid: { item: 'row', title: 'rowheader', content: 'gridcell' },\n    };\n\n    // Based on https://html.spec.whatwg.org/multipage/dom.html#interactive-content\n    const interactionSelector = [\n      'a[href]',\n      'audio[controls]',\n      'button',\n      'details',\n      'embed',\n      'iframe',\n      'img[usemap]',\n      'input:not([type=\"hidden\"])',\n      'label',\n      'select',\n      'textarea',\n      'video[controls]',\n      '[contenteditable]',\n      '.sky-repeater[role=\"grid\"]',\n    ]\n      .map(\n        (selector) =>\n          `sky-repeater-item-title ${selector}:not([hidden]), sky-repeater-item-content ${selector}:not([hidden])`\n      )\n      .concat([`skyux-dropdown`])\n      .join(', ');\n\n    const hasInteraction =\n      this.reorderable ||\n      this.items?.some((item) => item.isCollapsible) ||\n      this.items?.some((item) => !!item.selectable) ||\n      !!(this.#elementRef.nativeElement as HTMLElement).querySelector(\n        interactionSelector\n      );\n\n    if (hasInteraction) {\n      // If the repeater matches interaction selector https://www.w3.org/TR/wai-aria-practices-1.1/#grid\n      autoRole = 'grid';\n    }\n\n    if (this.role !== autoRole) {\n      this.#repeaterService.itemRole.next({\n        ...roleMap[autoRole],\n      });\n      this.role = `${autoRole}`;\n      this.#changeDetector.markForCheck();\n    }\n  }\n}\n","<ng-container #repeaterHost>\n  <div\n    class=\"sky-repeater\"\n    [attr.role]=\"role\"\n    [attr.aria-label]=\"ariaLabel || ('skyux_repeater_label' | skyLibResources)\"\n    [dragula]=\"dragulaGroupName\"\n    (cdkObserveContent)=\"onCdkObserveContent()\"\n  >\n    <ng-content></ng-content>\n  </div>\n</ng-container>\n"]}
|
|
357
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"repeater.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/lists/src/lib/modules/repeater/repeater.component.ts","../../../../../../../../libs/components/lists/src/lib/modules/repeater/repeater.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  AfterViewChecked,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  QueryList,\n  Renderer2,\n  SimpleChanges,\n  inject,\n} from '@angular/core';\nimport { SkyLogService } from '@skyux/core';\nimport { SkyScrollableHostService } from '@skyux/core';\n\nimport { DragulaService } from 'ng2-dragula';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyRepeaterAdapterService } from './repeater-adapter.service';\nimport { SkyRepeaterAutoScrollService } from './repeater-auto-scroll.service';\nimport { SkyRepeaterAutoScroller } from './repeater-auto-scroller';\nimport { SkyRepeaterExpandModeType } from './repeater-expand-mode-type';\nimport { SkyRepeaterItemRolesType } from './repeater-item-roles.type';\nimport { SkyRepeaterItemComponent } from './repeater-item.component';\nimport { SkyRepeaterRoleType } from './repeater-role.type';\nimport { SkyRepeaterService } from './repeater.service';\n\n/**\n * Creates a container to display repeater items.\n */\n@Component({\n  selector: 'sky-repeater',\n  styleUrls: ['./repeater.component.scss'],\n  templateUrl: './repeater.component.html',\n  providers: [\n    SkyRepeaterService,\n    SkyRepeaterAdapterService,\n    SkyRepeaterAutoScrollService,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyRepeaterComponent\n  implements AfterContentInit, AfterViewChecked, OnChanges, OnDestroy, OnInit\n{\n  /**\n   * The index of the repeater item to visually highlight as active.\n   * For example, use this property in conjunction with the\n   * [split view component](https://developer.blackbaud.com/skyux/components/split-view)\n   * to highlight a repeater item while users edit it. Only one item can be active at a time.\n   */\n  @Input()\n  public activeIndex: number | undefined;\n\n  /**\n   * The ARIA label for the repeater list.\n   * This sets the repeater list's `aria-label` attribute to provide a text equivalent for screen readers\n   * [to support accessibility](https://developer.blackbaud.com/skyux/learn/accessibility).\n   * For more information about the `aria-label` attribute, see the [WAI-ARIA definition](https://www.w3.org/TR/wai-aria/#aria-label).\n   * @default \"List of items\"\n   */\n  @Input()\n  public ariaLabel: string | undefined;\n\n  /**\n   * Whether users can change the order of items in the repeater list.\n   * Each repeater item also has `reorderable` property to indicate whether\n   * users can change its order.\n   */\n  @Input()\n  public reorderable: boolean | undefined = false;\n\n  /**\n   * The layout that determines which repeater items are expanded by default and whether\n   * repeater items are expandable and collapsible. Collapsed items display titles only.\n   * The valid options are `multiple`, `none`, and `single`.\n   * - `multiple` loads repeater items in an expanded state unless `isExpanded` is set to\n   * `false` for a repeater item. This layout allows users to expand and collapse\n   * as many repeater items as necessary. It is best-suited to repeater items where body\n   * content is important but users don't always need to see it.\n   * - `none` loads all repeater items in an expanded state and does not allow users to\n   * collapse them. This default layout provides the quickest access to the details in the\n   * repeater items. It is best-suited to repeater items with concise content\n   * that users need to view frequently.\n   * - `single` loads one repeater item in an expanded state and collapses all others.\n   * The expanded repeater item is the first one where `isExpanded` is set to `true`. This layout\n   * allows users to expand one item at a time. It provides the most compact view and is\n   * best-suited to repeater items where the most important information is in the titles\n   * and users only occasionally need to view the body content.\n   * @default \"none\"\n   */\n  @Input()\n  public set expandMode(value: SkyRepeaterExpandModeType | undefined) {\n    this.#repeaterService.expandMode = value;\n    this.#updateForExpandMode();\n  }\n\n  public get expandMode(): SkyRepeaterExpandModeType {\n    return this.#repeaterService.expandMode;\n  }\n\n  /**\n   * Fires when the active repeater item changes.\n   */\n  @Output()\n  public activeIndexChange = new EventEmitter<number>();\n\n  /**\n   * Fires when users change the order of repeater items.\n   * This event emits an ordered array of the `tag` properties that the consumer provides for each repeater item.\n   */\n  @Output()\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  public orderChange = new EventEmitter<any[]>();\n\n  @ContentChildren(SkyRepeaterItemComponent)\n  public items: QueryList<SkyRepeaterItemComponent> | undefined;\n\n  public dragulaGroupName: string;\n\n  public role: SkyRepeaterRoleType | undefined;\n\n  #autoScroller: SkyRepeaterAutoScroller | undefined;\n  #ngUnsubscribe = new Subject<void>();\n  #itemNameWarned = false;\n\n  #adapterService = inject(SkyRepeaterAdapterService);\n  #changeDetector = inject(ChangeDetectorRef);\n  #dragulaService = inject(DragulaService);\n  #elementRef = inject(ElementRef);\n  #renderer = inject(Renderer2);\n  #repeaterService = inject(SkyRepeaterService);\n  #autoScrollSvc = inject(SkyRepeaterAutoScrollService);\n  #scrollableHostSvc = inject(SkyScrollableHostService);\n  #logSvc = inject(SkyLogService);\n\n  constructor() {\n    this.dragulaGroupName = `sky-repeater-dragula-${\n      this.#repeaterService.repeaterGroupId\n    }`;\n\n    this.#repeaterService.itemCollapseStateChange\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((item: SkyRepeaterItemComponent) => {\n        if (this.expandMode === 'single' && item.isExpanded) {\n          this.items?.forEach((otherItem) => {\n            if (\n              otherItem !== item &&\n              otherItem.isExpanded &&\n              otherItem.isCollapsible\n            ) {\n              otherItem.isExpanded = false;\n            }\n          });\n        }\n      });\n\n    this.#repeaterService.activeItemIndexChange\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((index) => {\n        if (index !== this.activeIndex) {\n          this.activeIndex = index;\n          this.activeIndexChange.emit(index);\n        }\n      });\n\n    this.#repeaterService.orderChange\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        this.#emitTags();\n      });\n\n    this.#updateForExpandMode();\n\n    this.#adapterService.setRepeaterHost(this.#elementRef);\n\n    this.#initializeDragAndDrop();\n  }\n\n  public ngAfterContentInit(): void {\n    // If activeIndex has been set on init, call service to activate the appropriate item.\n    setTimeout(() => {\n      if (this.activeIndex || this.activeIndex === 0) {\n        this.#repeaterService.activateItemByIndex(this.activeIndex);\n      }\n\n      this.#validateTags();\n    });\n\n    // HACK: Not updating for expand mode in a timeout causes an error.\n    // https://github.com/angular/angular/issues/6005\n    this.items?.changes.pipe(takeUntil(this.#ngUnsubscribe)).subscribe(() => {\n      setTimeout(() => {\n        if (this.items?.length) {\n          this.#updateForExpandMode(this.items.last);\n\n          this.#updateReorderability();\n\n          this.#repeaterService.items = this.items.toArray();\n        }\n\n        if (this.activeIndex !== undefined) {\n          this.#repeaterService.activateItemByIndex(this.activeIndex);\n        }\n\n        this.#updateRole();\n\n        this.#validateTags();\n      });\n    });\n\n    setTimeout(() => {\n      this.#updateForExpandMode();\n\n      this.items?.forEach((item) => {\n        item.reorderable = this.reorderable;\n      });\n\n      this.#updateRole();\n    }, 0);\n  }\n\n  public ngAfterViewChecked(): void {\n    if (!this.#itemNameWarned && this.items?.some((item) => !item.itemName)) {\n      this.#logSvc?.deprecated('SkyRepeaterItemComponent without `itemName`', {\n        deprecationMajorVersion: 8,\n        replacementRecommendation: 'Always specify an `itemName` property.',\n      });\n\n      this.#itemNameWarned = true;\n    }\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes['activeIndex']) {\n      this.#repeaterService.enableActiveState = true;\n      if (\n        changes['activeIndex'].currentValue !==\n        changes['activeIndex'].previousValue\n      ) {\n        this.#repeaterService.activateItemByIndex(this.activeIndex);\n      }\n    }\n\n    if (changes.reorderable) {\n      if (this.items) {\n        this.#updateReorderability();\n      }\n      this.#updateRole();\n\n      this.#changeDetector.markForCheck();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n    this.#destroyDragAndDrop();\n  }\n\n  public ngOnInit(): void {\n    this.#updateRole();\n  }\n\n  public onCdkObserveContent(): void {\n    this.#updateRole();\n  }\n\n  #updateForExpandMode(itemAdded?: SkyRepeaterItemComponent): void {\n    if (this.items) {\n      let foundExpanded = false;\n      const isCollapsible = this.expandMode !== 'none';\n      const isSingle = this.expandMode === 'single';\n\n      // Keep any newly-added expanded item expanded and collapse the rest.\n      if (itemAdded && itemAdded.isExpanded) {\n        foundExpanded = true;\n      }\n\n      for (const item of this.items) {\n        item.isCollapsible = isCollapsible && !!item.hasItemContent;\n\n        // Collapse any items that aren't the item that was just added.\n        if (item !== itemAdded && isSingle && item.isExpanded) {\n          if (foundExpanded) {\n            // If this item is being collapsed because a new item was\n            // added, animate it.\n            item.updateForExpanded(false, !!itemAdded);\n          }\n\n          foundExpanded = true;\n        }\n      }\n\n      this.#updateRole();\n    }\n  }\n\n  #initializeDragAndDrop(): void {\n    /* Sanity check that we haven't already set up dragging abilities */\n    /* istanbul ignore else */\n    if (!this.#dragulaService.find(this.dragulaGroupName)) {\n      this.#dragulaService.createGroup(this.dragulaGroupName, {\n        moves: (el, _container, handle) => {\n          const target = el?.querySelector('.sky-repeater-item-grab-handle');\n          return !!(\n            this.reorderable && target?.contains(handle as Element | null)\n          );\n        },\n      });\n    }\n\n    let draggedItemIndex = -1;\n\n    this.#dragulaService\n      .drag(this.dragulaGroupName)\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((args) => {\n        /* istanbul ignore else */\n        if (args.name === this.dragulaGroupName) {\n          this.#destroyAutoScroll();\n\n          this.#autoScroller = this.#autoScrollSvc.autoScroll(\n            [this.#scrollableHostSvc.getScrollableHost(this.#elementRef)],\n            {\n              margin: 20,\n              maxSpeed: 10,\n              scrollWhenOutside: true,\n              autoScroll: () => true,\n            }\n          );\n\n          this.#renderer.addClass(args.el, 'sky-repeater-item-dragging');\n          draggedItemIndex = this.#adapterService.getRepeaterItemIndex(\n            args.el as HTMLElement\n          );\n        }\n      });\n\n    this.#dragulaService\n      .dragend(this.dragulaGroupName)\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((args) => {\n        /* istanbul ignore else */\n        if (args.name === this.dragulaGroupName) {\n          this.#destroyAutoScroll();\n\n          this.#renderer.removeClass(args.el, 'sky-repeater-item-dragging');\n          const newItemIndex = this.#adapterService.getRepeaterItemIndex(\n            args.el as HTMLElement\n          );\n\n          /* sanity check */\n          /* istanbul ignore else */\n          if (draggedItemIndex >= 0) {\n            this.#repeaterService.reorderItem(draggedItemIndex, newItemIndex);\n            draggedItemIndex = -1;\n          }\n\n          this.#emitTags();\n        }\n      });\n  }\n\n  #destroyDragAndDrop(): void {\n    /* Sanity check that we have set up dragging abilities */\n    /* istanbul ignore else */\n    if (this.#dragulaService.find(this.dragulaGroupName)) {\n      this.#dragulaService.destroy(this.dragulaGroupName);\n    }\n\n    this.#destroyAutoScroll();\n  }\n\n  #destroyAutoScroll(): void {\n    if (this.#autoScroller) {\n      this.#autoScroller.destroy();\n      this.#autoScroller = undefined;\n    }\n  }\n\n  #emitTags(): void {\n    const tags = this.#repeaterService.items.map((item) => item.tag);\n    this.orderChange.emit(tags);\n  }\n\n  #everyItemHasTag(): boolean {\n    /* sanity check */\n    /* istanbul ignore if */\n    if (!this.items || this.items.length === 0) {\n      return false;\n    }\n    return this.items.toArray().every((item) => {\n      return item.tag !== undefined;\n    });\n  }\n\n  #updateRole(): void {\n    // Determine a role using a hierarchy based on https://www.w3.org/TR/wai-aria-practices-1.1/\n    //   1. If there are one or more interactions in the repeater item projected content, use grid.\n    //   2. If there are selectable repeater items and no other interactions, use listbox.\n    //   3. If there are no interactions, use list.\n\n    // Default to list role.\n    let autoRole: SkyRepeaterRoleType = 'list';\n\n    const roleMap: Record<SkyRepeaterRoleType, SkyRepeaterItemRolesType> = {\n      list: { item: 'listitem', title: undefined, content: undefined },\n      listbox: { item: 'option', title: undefined, content: undefined },\n      grid: { item: 'row', title: 'rowheader', content: 'gridcell' },\n    };\n\n    // Based on https://html.spec.whatwg.org/multipage/dom.html#interactive-content\n    const interactionSelector = [\n      'a[href]',\n      'audio[controls]',\n      'button',\n      'details',\n      'embed',\n      'iframe',\n      'img[usemap]',\n      'input:not([type=\"hidden\"])',\n      'label',\n      'select',\n      'textarea',\n      'video[controls]',\n      '[contenteditable]',\n      '.sky-repeater[role=\"grid\"]',\n    ]\n      .map(\n        (selector) =>\n          `sky-repeater-item-title ${selector}:not([hidden]), sky-repeater-item-content ${selector}:not([hidden])`\n      )\n      .concat([`skyux-dropdown`])\n      .join(', ');\n\n    const hasInteraction =\n      this.reorderable ||\n      this.items?.some((item) => item.isCollapsible) ||\n      this.items?.some((item) => !!item.selectable) ||\n      !!(this.#elementRef.nativeElement as HTMLElement).querySelector(\n        interactionSelector\n      );\n\n    if (hasInteraction) {\n      // If the repeater matches interaction selector https://www.w3.org/TR/wai-aria-practices-1.1/#grid\n      autoRole = 'grid';\n    }\n\n    if (this.role !== autoRole) {\n      this.#repeaterService.itemRole.next({\n        ...roleMap[autoRole],\n      });\n      this.role = `${autoRole}`;\n      this.#changeDetector.markForCheck();\n    }\n  }\n\n  #updateReorderability(): void {\n    if (this.items) {\n      for (const item of this.items) {\n        item.reorderable = this.reorderable;\n      }\n    }\n  }\n\n  #validateTags(): void {\n    if (this.reorderable && !this.#everyItemHasTag()) {\n      console.warn(\n        'Please supply tag properties for each repeater item when reordering functionality is enabled.'\n      );\n    }\n  }\n}\n","<ng-container #repeaterHost>\n  <div\n    class=\"sky-repeater\"\n    [attr.role]=\"role\"\n    [attr.aria-label]=\"ariaLabel || ('skyux_repeater_label' | skyLibResources)\"\n    [dragula]=\"dragulaGroupName\"\n    (cdkObserveContent)=\"onCdkObserveContent()\"\n  >\n    <ng-content></ng-content>\n  </div>\n</ng-container>\n"]}
|
|
@@ -18,8 +18,10 @@ const RESOURCES = {
|
|
|
18
18
|
skyux_paging_page_link_aria_label: { message: 'Page {0}' },
|
|
19
19
|
skyux_paging_previous: { message: 'Previous' },
|
|
20
20
|
skyux_repeater_label: { message: 'List of items' },
|
|
21
|
-
|
|
22
|
-
|
|
21
|
+
skyux_repeater_item_collapse: { message: 'Collapse {0}' },
|
|
22
|
+
skyux_repeater_item_collapse_default: { message: 'Collapse' },
|
|
23
|
+
skyux_repeater_item_expand: { message: 'Expand {0}' },
|
|
24
|
+
skyux_repeater_item_expand_default: { message: 'Expand' },
|
|
23
25
|
skyux_repeater_item_checkbox_label: { message: 'Select {0}' },
|
|
24
26
|
skyux_repeater_item_checkbox_label_default: { message: 'Select row' },
|
|
25
27
|
skyux_repeater_item_reorder_cancel: {
|
|
@@ -78,4 +80,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.1", ngImpor
|
|
|
78
80
|
],
|
|
79
81
|
}]
|
|
80
82
|
}] });
|
|
81
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2t5LWxpc3RzLXJlc291cmNlcy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGlzdHMvc3JjL2xpYi9tb2R1bGVzL3NoYXJlZC9za3ktbGlzdHMtcmVzb3VyY2VzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7R0FLRztBQUNILE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUNMLDJCQUEyQixFQUUzQixhQUFhLEVBR2IscUJBQXFCLEdBQ3RCLE1BQU0sYUFBYSxDQUFDOztBQUVyQixNQUFNLFNBQVMsR0FBMEM7SUFDdkQsT0FBTyxFQUFFO1FBQ1AseUJBQXlCLEVBQUUsRUFBRSxPQUFPLEVBQUUsUUFBUSxFQUFFO1FBQ2hELDBCQUEwQixFQUFFLEVBQUUsT0FBTyxFQUFFLGVBQWUsRUFBRTtRQUN4RCwyQkFBMkIsRUFBRSxFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUU7UUFDbEQsc0NBQXNDLEVBQUUsRUFBRSxPQUFPLEVBQUUsV0FBVyxFQUFFO1FBQ2hFLGtCQUFrQixFQUFFLEVBQUUsT0FBTyxFQUFFLFlBQVksRUFBRTtRQUM3QyxpQkFBaUIsRUFBRSxFQUFFLE9BQU8sRUFBRSxNQUFNLEVBQUU7UUFDdEMsaUNBQWlDLEVBQUUsRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFO1FBQzFELHFCQUFxQixFQUFFLEVBQUUsT0FBTyxFQUFFLFVBQVUsRUFBRTtRQUM5QyxvQkFBb0IsRUFBRSxFQUFFLE9BQU8sRUFBRSxlQUFlLEVBQUU7UUFDbEQsNEJBQTRCLEVBQUUsRUFBRSxPQUFPLEVBQUUsY0FBYyxFQUFFO1FBQ3pELG9DQUFvQyxFQUFFLEVBQUUsT0FBTyxFQUFFLFVBQVUsRUFBRTtRQUM3RCwwQkFBMEIsRUFBRSxFQUFFLE9BQU8sRUFBRSxZQUFZLEVBQUU7UUFDckQsa0NBQWtDLEVBQUUsRUFBRSxPQUFPLEVBQUUsUUFBUSxFQUFFO1FBQ3pELGtDQUFrQyxFQUFFLEVBQUUsT0FBTyxFQUFFLFlBQVksRUFBRTtRQUM3RCwwQ0FBMEMsRUFBRSxFQUFFLE9BQU8sRUFBRSxZQUFZLEVBQUU7UUFDckUsa0NBQWtDLEVBQUU7WUFDbEMsT0FBTyxFQUNMLCtFQUErRTtTQUNsRjtRQUNELGtDQUFrQyxFQUFFO1lBQ2xDLE9BQU8sRUFBRSw4QkFBOEI7U0FDeEM7UUFDRCx3Q0FBd0MsRUFBRTtZQUN4QyxPQUFPLEVBQ0wsaUpBQWlKO1NBQ3BKO1FBQ0QsaUNBQWlDLEVBQUU7WUFDakMsT0FBTyxFQUFFLDRCQUE0QjtTQUN0QztRQUNELHlDQUF5QyxFQUFFLEVBQUUsT0FBTyxFQUFFLFNBQVMsRUFBRTtRQUNqRSxpQ0FBaUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxhQUFhLEVBQUU7UUFDN0QscUNBQXFDLEVBQUU7WUFDckMsT0FBTyxFQUFFLDZDQUE2QztTQUN2RDtRQUNELCtCQUErQixFQUFFLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRTtRQUNuRCxxQ0FBcUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRTtRQUNyRSw2Q0FBNkMsRUFBRSxFQUFFLE9BQU8sRUFBRSxhQUFhLEVBQUU7UUFDekUsdUJBQXVCLEVBQUUsRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFFO1FBQzVDLHVCQUF1QixFQUFFLEVBQUUsT0FBTyxFQUFFLFNBQVMsRUFBRTtLQUNoRDtDQUNGLENBQUM7QUFFRixNQUFNLE9BQU8seUJBQXlCO0lBQzdCLFNBQVMsQ0FDZCxVQUE0QixFQUM1QixJQUFZO1FBRVosT0FBTyxxQkFBcUIsQ0FBQyxTQUFTLEVBQUUsVUFBVSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztJQUNuRSxDQUFDO0NBQ0Y7QUFFRDs7R0FFRztBQVdILE1BQU0sT0FBTyx1QkFBdUI7O29IQUF2Qix1QkFBdUI7cUhBQXZCLHVCQUF1QixZQVR4QixhQUFhO3FIQVNaLHVCQUF1QixhQVJ2QjtRQUNUO1lBQ0UsT0FBTyxFQUFFLDJCQUEyQjtZQUNwQyxRQUFRLEVBQUUseUJBQXlCO1lBQ25DLEtBQUssRUFBRSxJQUFJO1NBQ1o7S0FDRixZQVBTLGFBQWE7MkZBU1osdUJBQXVCO2tCQVZuQyxRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLGFBQWEsQ0FBQztvQkFDeEIsU0FBUyxFQUFFO3dCQUNUOzRCQUNFLE9BQU8sRUFBRSwyQkFBMkI7NEJBQ3BDLFFBQVEsRUFBRSx5QkFBeUI7NEJBQ25DLEtBQUssRUFBRSxJQUFJO3lCQUNaO3FCQUNGO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBOT1RJQ0U6IERPIE5PVCBNT0RJRlkgVEhJUyBGSUxFIVxuICogVGhlIGNvbnRlbnRzIG9mIHRoaXMgZmlsZSB3ZXJlIGF1dG9tYXRpY2FsbHkgZ2VuZXJhdGVkIGJ5XG4gKiB0aGUgJ25nIGdlbmVyYXRlIEBza3l1eC9pMThuOmxpYi1yZXNvdXJjZXMtbW9kdWxlIGxpYi9tb2R1bGVzL3NoYXJlZC9za3ktbGlzdHMnIHNjaGVtYXRpYy5cbiAqIFRvIHVwZGF0ZSB0aGlzIGZpbGUsIHNpbXBseSByZXJ1biB0aGUgY29tbWFuZC5cbiAqL1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIFNLWV9MSUJfUkVTT1VSQ0VTX1BST1ZJREVSUyxcbiAgU2t5QXBwTG9jYWxlSW5mbyxcbiAgU2t5STE4bk1vZHVsZSxcbiAgU2t5TGliUmVzb3VyY2VzLFxuICBTa3lMaWJSZXNvdXJjZXNQcm92aWRlcixcbiAgZ2V0TGliU3RyaW5nRm9yTG9jYWxlLFxufSBmcm9tICdAc2t5dXgvaTE4bic7XG5cbmNvbnN0IFJFU09VUkNFUzogeyBbbG9jYWxlOiBzdHJpbmddOiBTa3lMaWJSZXNvdXJjZXMgfSA9IHtcbiAgJ0VOLVVTJzoge1xuICAgIHNreXV4X2ZpbHRlcl9idXR0b25fdGl0bGU6IHsgbWVzc2FnZTogJ0ZpbHRlcicgfSxcbiAgICBza3l1eF9maWx0ZXJfc3VtbWFyeV9jbG9zZTogeyBtZXNzYWdlOiAnUmVtb3ZlIGZpbHRlcicgfSxcbiAgICBza3l1eF9maWx0ZXJfc3VtbWFyeV9oZWFkZXI6IHsgbWVzc2FnZTogJ0ZpbHRlcicgfSxcbiAgICBza3l1eF9pbmZpbml0ZV9zY3JvbGxfbG9hZF9tb3JlX2J1dHRvbjogeyBtZXNzYWdlOiAnTG9hZCBtb3JlJyB9LFxuICAgIHNreXV4X3BhZ2luZ19sYWJlbDogeyBtZXNzYWdlOiAnUGFnaW5hdGlvbicgfSxcbiAgICBza3l1eF9wYWdpbmdfbmV4dDogeyBtZXNzYWdlOiAnTmV4dCcgfSxcbiAgICBza3l1eF9wYWdpbmdfcGFnZV9saW5rX2FyaWFfbGFiZWw6IHsgbWVzc2FnZTogJ1BhZ2UgezB9JyB9LFxuICAgIHNreXV4X3BhZ2luZ19wcmV2aW91czogeyBtZXNzYWdlOiAnUHJldmlvdXMnIH0sXG4gICAgc2t5dXhfcmVwZWF0ZXJfbGFiZWw6IHsgbWVzc2FnZTogJ0xpc3Qgb2YgaXRlbXMnIH0sXG4gICAgc2t5dXhfcmVwZWF0ZXJfaXRlbV9jb2xsYXBzZTogeyBtZXNzYWdlOiAnQ29sbGFwc2UgezB9JyB9LFxuICAgIHNreXV4X3JlcGVhdGVyX2l0ZW1fY29sbGFwc2VfZGVmYXVsdDogeyBtZXNzYWdlOiAnQ29sbGFwc2UnIH0sXG4gICAgc2t5dXhfcmVwZWF0ZXJfaXRlbV9leHBhbmQ6IHsgbWVzc2FnZTogJ0V4cGFuZCB7MH0nIH0sXG4gICAgc2t5dXhfcmVwZWF0ZXJfaXRlbV9leHBhbmRfZGVmYXVsdDogeyBtZXNzYWdlOiAnRXhwYW5kJyB9LFxuICAgIHNreXV4X3JlcGVhdGVyX2l0ZW1fY2hlY2tib3hfbGFiZWw6IHsgbWVzc2FnZTogJ1NlbGVjdCB7MH0nIH0sXG4gICAgc2t5dXhfcmVwZWF0ZXJfaXRlbV9jaGVja2JveF9sYWJlbF9kZWZhdWx0OiB7IG1lc3NhZ2U6ICdTZWxlY3Qgcm93JyB9LFxuICAgIHNreXV4X3JlcGVhdGVyX2l0ZW1fcmVvcmRlcl9jYW5jZWw6IHtcbiAgICAgIG1lc3NhZ2U6XG4gICAgICAgICdJdGVtIHJlb3JkZXJpbmcgd2FzIGNhbmNlbGVkLiBUaGUgaXRlbSB3YXMgcmV0dXJuZWQgdG8gaXRzIG9yaWdpbmFsIHBvc2l0aW9uLicsXG4gICAgfSxcbiAgICBza3l1eF9yZXBlYXRlcl9pdGVtX3Jlb3JkZXJfZmluaXNoOiB7XG4gICAgICBtZXNzYWdlOiAnRHJvcHBlZCB0aGUgaXRlbSBpbiBwb3NpdGlvbicsXG4gICAgfSxcbiAgICBza3l1eF9yZXBlYXRlcl9pdGVtX3Jlb3JkZXJfaW5zdHJ1Y3Rpb25zOiB7XG4gICAgICBtZXNzYWdlOlxuICAgICAgICAnSXRlbSBncmFiYmVkLiBQcmVzcyB0aGUgdXAgYW5kIGRvd24gYXJyb3cga2V5cyB0byBjaGFuZ2UgcG9zaXRpb24uIFByZXNzIHRoZSBzcGFjZWJhciBvciBlbnRlciBrZXkgdG8gZHJvcC4gQW5kIHByZXNzIHRoZSBlc2NhcGUga2V5IHRvIGNhbmNlbC4nLFxuICAgIH0sXG4gICAgc2t5dXhfcmVwZWF0ZXJfaXRlbV9yZW9yZGVyX21vdmVkOiB7XG4gICAgICBtZXNzYWdlOiAnTW92ZWQgdGhlIGl0ZW0gdG8gcG9zaXRpb24nLFxuICAgIH0sXG4gICAgc2t5dXhfcmVwZWF0ZXJfaXRlbV9yZW9yZGVyX2xhYmVsX2RlZmF1bHQ6IHsgbWVzc2FnZTogJ1Jlb3JkZXInIH0sXG4gICAgc2t5dXhfcmVwZWF0ZXJfaXRlbV9yZW9yZGVyX2xhYmVsOiB7IG1lc3NhZ2U6ICdSZW9yZGVyIHswfScgfSxcbiAgICBza3l1eF9yZXBlYXRlcl9pdGVtX3Jlb3JkZXJfb3BlcmF0aW9uOiB7XG4gICAgICBtZXNzYWdlOiAnUHJlc3MgdGhlIHNwYWNlYmFyIG9yIGVudGVyIGtleSB0byByZW9yZGVyLicsXG4gICAgfSxcbiAgICBza3l1eF9yZXBlYXRlcl9pdGVtX3Jlb3JkZXJfdG9wOiB7IG1lc3NhZ2U6ICdUb3AnIH0sXG4gICAgc2t5dXhfcmVwZWF0ZXJfaXRlbV9yZW9yZGVyX3RvcF9sYWJlbDogeyBtZXNzYWdlOiAnTW92ZSB7MH0gdG8gdG9wJyB9LFxuICAgIHNreXV4X3JlcGVhdGVyX2l0ZW1fcmVvcmRlcl90b3BfbGFiZWxfZGVmYXVsdDogeyBtZXNzYWdlOiAnTW92ZSB0byB0b3AnIH0sXG4gICAgc2t5dXhfc29ydF9idXR0b25fbGFiZWw6IHsgbWVzc2FnZTogJ1NvcnQnIH0sXG4gICAgc2t5dXhfc29ydF9tZW51X2hlYWRpbmc6IHsgbWVzc2FnZTogJ1NvcnQgYnknIH0sXG4gIH0sXG59O1xuXG5leHBvcnQgY2xhc3MgU2t5TGlzdHNSZXNvdXJjZXNQcm92aWRlciBpbXBsZW1lbnRzIFNreUxpYlJlc291cmNlc1Byb3ZpZGVyIHtcbiAgcHVibGljIGdldFN0cmluZyhcbiAgICBsb2NhbGVJbmZvOiBTa3lBcHBMb2NhbGVJbmZvLFxuICAgIG5hbWU6IHN0cmluZ1xuICApOiBzdHJpbmcgfCB1bmRlZmluZWQge1xuICAgIHJldHVybiBnZXRMaWJTdHJpbmdGb3JMb2NhbGUoUkVTT1VSQ0VTLCBsb2NhbGVJbmZvLmxvY2FsZSwgbmFtZSk7XG4gIH1cbn1cblxuLyoqXG4gKiBJbXBvcnQgaW50byBhbnkgY29tcG9uZW50IGxpYnJhcnkgbW9kdWxlIHRoYXQgbmVlZHMgdG8gdXNlIHJlc291cmNlIHN0cmluZ3MuXG4gKi9cbkBOZ01vZHVsZSh7XG4gIGV4cG9ydHM6IFtTa3lJMThuTW9kdWxlXSxcbiAgcHJvdmlkZXJzOiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogU0tZX0xJQl9SRVNPVVJDRVNfUFJPVklERVJTLFxuICAgICAgdXNlQ2xhc3M6IFNreUxpc3RzUmVzb3VyY2VzUHJvdmlkZXIsXG4gICAgICBtdWx0aTogdHJ1ZSxcbiAgICB9LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lMaXN0c1Jlc291cmNlc01vZHVsZSB7fVxuIl19
|
|
@@ -57,13 +57,13 @@ export class SkySortItemComponent {
|
|
|
57
57
|
}
|
|
58
58
|
_SkySortItemComponent_subscription = new WeakMap(), _SkySortItemComponent_sortItemId = new WeakMap(), _SkySortItemComponent_sortService = new WeakMap(), _SkySortItemComponent_detector = new WeakMap();
|
|
59
59
|
SkySortItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.1", ngImport: i0, type: SkySortItemComponent, deps: [{ token: i1.SkySortService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
60
|
-
SkySortItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.1", type: SkySortItemComponent, selector: "sky-sort-item", inputs: { active: "active" }, outputs: { itemSelect: "itemSelect" }, usesOnChanges: true, ngImport: i0, template: "<div\n class=\"sky-sort-item\"\n role=\"menuitemradio\"\n [attr.aria-checked]=\"isSelected | async\"\n [ngClass]=\"{ 'sky-sort-item-selected': (isSelected | async) }\"\n>\n <button\n type=\"button\"\n [ngClass]=\"{ 'sky-emphasized': (isSelected | async) }\"\n (click)=\"itemClicked()\"\n >\n <ng-content></ng-content>\n </button>\n</div>\n", styles: [".sky-sort-item{background-color:transparent;border:none;display:block;margin:4px;min-width:160px;text-align:left;transition:background-color .15s}.sky-sort-item.sky-dropdown-item-active,.sky-sort-item:hover{background-color:var(--sky-background-color-neutral-light)}.sky-sort-item.sky-dropdown-item-disabled{cursor:default}.sky-sort-item.sky-dropdown-item-disabled:hover{background-color:transparent}.sky-sort-item ::ng-deep>button{background-color:transparent;border:none;color:var(--sky-text-color-default);cursor:pointer;display:block;padding:3px 20px;text-align:left;width:100%}.sky-sort-item ::ng-deep>button[disabled]{color:var(--sky-text-color-deemphasized)}.sky-sort-item ::ng-deep>button[disabled]:hover{cursor:default}.sky-sort-item-selected{background-color:#f1eef6;padding:4px;margin:0}:host-context(.sky-theme-modern) .sky-sort-item{margin:0;border:none;color:var(--sky-text-color-deemphasized);font-weight:400;transition:box-shadow .15s;border-radius:6px;padding:10px 20px}:host-context(.sky-theme-modern) .sky-sort-item:hover:not(.sky-btn-tab-disabled):not(.sky-btn-tab-selected):not(.sky-dropdown-button-type-tab):not(:focus-visible){background-color:transparent;border-bottom:solid 1px var(--sky-highlight-color-info);color:var(--sky-text-color-default);padding-bottom:9px}:host-context(.sky-theme-modern) .sky-sort-item:focus-visible{background-color:transparent;color:var(--sky-text-color-default);outline:none}:host-context(.sky-theme-modern) .sky-sort-item:focus-visible:not(:active){color:var(--sky-text-color-default);outline:solid 2px var(--sky-background-color-primary-dark);outline-offset:-2px;box-shadow:0 1px 8px #0000004d}:host-context(.sky-theme-modern) .sky-sort-item:active{color:var(--sky-text-color-default);padding-bottom:7px}:host-context(.sky-theme-modern) .sky-sort-item.sky-btn-tab-disabled{background-color:transparent;font-family:BLKB Sans,Helvetica Neue,Arial,sans-serif;color:var(--sky-text-color-deemphasized);font-weight:400;font-size:15px;font-style:italic}:host-context(.sky-theme-modern) .sky-sort-item.sky-btn-tab-disabled .sky-btn-tab-close{font-size:16px}:host-context(.sky-theme-modern) .sky-sort-item:hover:not(.sky-btn-tab-disabled){background-color:transparent;border-bottom:none;outline:solid 1px var(--sky-background-color-primary-dark);outline-offset:-1px}:host-context(.sky-theme-modern) .sky-sort-item:focus-visible:not(:active){background-color:transparent;box-shadow:0 1px 8px #0000004d;outline:solid 2px var(--sky-background-color-primary-dark);outline-offset:-2px}:host-context(.sky-theme-modern) .sky-sort-item button{padding:0;color:#686c73}:host-context(.sky-theme-modern) .sky-sort-item-selected{color:var(--sky-text-color-default);border-bottom:none;border-radius:0 6px 6px 0;border-left:solid 3px var(--sky-background-color-primary-dark);padding-bottom:10px;padding-left:17px;background-color:inherit}:host-context(.sky-theme-modern) .sky-sort-item-selected button{font-weight:400;color:#212327}.sky-theme-modern .sky-sort-item{margin:0;border:none;color:var(--sky-text-color-deemphasized);font-weight:400;transition:box-shadow .15s;border-radius:6px;padding:10px 20px}.sky-theme-modern .sky-sort-item:hover:not(.sky-btn-tab-disabled):not(.sky-btn-tab-selected):not(.sky-dropdown-button-type-tab):not(:focus-visible){background-color:transparent;border-bottom:solid 1px var(--sky-highlight-color-info);color:var(--sky-text-color-default);padding-bottom:9px}.sky-theme-modern .sky-sort-item:focus-visible{background-color:transparent;color:var(--sky-text-color-default);outline:none}.sky-theme-modern .sky-sort-item:focus-visible:not(:active){color:var(--sky-text-color-default);outline:solid 2px var(--sky-background-color-primary-dark);outline-offset:-2px;box-shadow:0 1px 8px #0000004d}.sky-theme-modern .sky-sort-item:active{color:var(--sky-text-color-default);padding-bottom:7px}.sky-theme-modern .sky-sort-item.sky-btn-tab-disabled{background-color:transparent;font-family:BLKB Sans,Helvetica Neue,Arial,sans-serif;color:var(--sky-text-color-deemphasized);font-weight:400;font-size:15px;font-style:italic}.sky-theme-modern .sky-sort-item.sky-btn-tab-disabled .sky-btn-tab-close{font-size:16px}.sky-theme-modern .sky-sort-item:hover:not(.sky-btn-tab-disabled){background-color:transparent;border-bottom:none;outline:solid 1px var(--sky-background-color-primary-dark);outline-offset:-1px}.sky-theme-modern .sky-sort-item:focus-visible:not(:active){background-color:transparent;box-shadow:0 1px 8px #0000004d;outline:solid 2px var(--sky-background-color-primary-dark);outline-offset:-2px}.sky-theme-modern .sky-sort-item button{padding:0;color:#686c73}.sky-theme-modern .sky-sort-item-selected{color:var(--sky-text-color-default);border-bottom:none;border-radius:0 6px 6px 0;border-left:solid 3px var(--sky-background-color-primary-dark);padding-bottom:10px;padding-left:17px;background-color:inherit}.sky-theme-modern .sky-sort-item-selected button{font-weight:400;color:#212327}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-sort-item button{color:#c0c2c5}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-sort-item-selected button{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-sort-item button{color:#c0c2c5}.sky-theme-modern.sky-theme-mode-dark .sky-sort-item-selected button{color:#fbfcfe}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
60
|
+
SkySortItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.1", type: SkySortItemComponent, selector: "sky-sort-item", inputs: { active: "active" }, outputs: { itemSelect: "itemSelect" }, usesOnChanges: true, ngImport: i0, template: "<div\n class=\"sky-sort-item\"\n role=\"menuitemradio\"\n [attr.aria-checked]=\"isSelected | async\"\n [ngClass]=\"{ 'sky-sort-item-selected': (isSelected | async) }\"\n>\n <button\n type=\"button\"\n [ngClass]=\"{ 'sky-font-emphasized': (isSelected | async) }\"\n (click)=\"itemClicked()\"\n >\n <ng-content></ng-content>\n </button>\n</div>\n", styles: [".sky-sort-item{background-color:transparent;border:none;display:block;margin:4px;min-width:160px;text-align:left;transition:background-color .15s}.sky-sort-item.sky-dropdown-item-active,.sky-sort-item:hover{background-color:var(--sky-background-color-neutral-light)}.sky-sort-item.sky-dropdown-item-disabled{cursor:default}.sky-sort-item.sky-dropdown-item-disabled:hover{background-color:transparent}.sky-sort-item ::ng-deep>button{background-color:transparent;border:none;color:var(--sky-text-color-default);cursor:pointer;display:block;padding:3px 20px;text-align:left;width:100%}.sky-sort-item ::ng-deep>button[disabled]{color:var(--sky-text-color-deemphasized)}.sky-sort-item ::ng-deep>button[disabled]:hover{cursor:default}.sky-sort-item-selected{background-color:#f1eef6;padding:4px;margin:0}:host-context(.sky-theme-modern) .sky-sort-item{margin:0;border:none;color:var(--sky-text-color-deemphasized);font-weight:400;transition:box-shadow .15s;border-radius:6px;padding:10px 20px}:host-context(.sky-theme-modern) .sky-sort-item:hover:not(.sky-btn-tab-disabled):not(.sky-btn-tab-selected):not(.sky-dropdown-button-type-tab):not(:focus-visible){background-color:transparent;border-bottom:solid 1px var(--sky-highlight-color-info);color:var(--sky-text-color-default);padding-bottom:9px}:host-context(.sky-theme-modern) .sky-sort-item:focus-visible{background-color:transparent;color:var(--sky-text-color-default);outline:none}:host-context(.sky-theme-modern) .sky-sort-item:focus-visible:not(:active){color:var(--sky-text-color-default);outline:solid 2px var(--sky-background-color-primary-dark);outline-offset:-2px;box-shadow:0 1px 8px #0000004d}:host-context(.sky-theme-modern) .sky-sort-item:active{color:var(--sky-text-color-default);padding-bottom:7px}:host-context(.sky-theme-modern) .sky-sort-item.sky-btn-tab-disabled{background-color:transparent;font-family:BLKB Sans,Helvetica Neue,Arial,sans-serif;color:var(--sky-text-color-deemphasized);font-weight:400;font-size:15px;font-style:italic}:host-context(.sky-theme-modern) .sky-sort-item.sky-btn-tab-disabled .sky-btn-tab-close{font-size:16px}:host-context(.sky-theme-modern) .sky-sort-item:hover:not(.sky-btn-tab-disabled){background-color:transparent;border-bottom:none;outline:solid 1px var(--sky-background-color-primary-dark);outline-offset:-1px}:host-context(.sky-theme-modern) .sky-sort-item:focus-visible:not(:active){background-color:transparent;box-shadow:0 1px 8px #0000004d;outline:solid 2px var(--sky-background-color-primary-dark);outline-offset:-2px}:host-context(.sky-theme-modern) .sky-sort-item button{padding:0;color:#686c73}:host-context(.sky-theme-modern) .sky-sort-item-selected{color:var(--sky-text-color-default);border-bottom:none;border-radius:0 6px 6px 0;border-left:solid 3px var(--sky-background-color-primary-dark);padding-bottom:10px;padding-left:17px;background-color:inherit}:host-context(.sky-theme-modern) .sky-sort-item-selected button{font-weight:400;color:#212327}.sky-theme-modern .sky-sort-item{margin:0;border:none;color:var(--sky-text-color-deemphasized);font-weight:400;transition:box-shadow .15s;border-radius:6px;padding:10px 20px}.sky-theme-modern .sky-sort-item:hover:not(.sky-btn-tab-disabled):not(.sky-btn-tab-selected):not(.sky-dropdown-button-type-tab):not(:focus-visible){background-color:transparent;border-bottom:solid 1px var(--sky-highlight-color-info);color:var(--sky-text-color-default);padding-bottom:9px}.sky-theme-modern .sky-sort-item:focus-visible{background-color:transparent;color:var(--sky-text-color-default);outline:none}.sky-theme-modern .sky-sort-item:focus-visible:not(:active){color:var(--sky-text-color-default);outline:solid 2px var(--sky-background-color-primary-dark);outline-offset:-2px;box-shadow:0 1px 8px #0000004d}.sky-theme-modern .sky-sort-item:active{color:var(--sky-text-color-default);padding-bottom:7px}.sky-theme-modern .sky-sort-item.sky-btn-tab-disabled{background-color:transparent;font-family:BLKB Sans,Helvetica Neue,Arial,sans-serif;color:var(--sky-text-color-deemphasized);font-weight:400;font-size:15px;font-style:italic}.sky-theme-modern .sky-sort-item.sky-btn-tab-disabled .sky-btn-tab-close{font-size:16px}.sky-theme-modern .sky-sort-item:hover:not(.sky-btn-tab-disabled){background-color:transparent;border-bottom:none;outline:solid 1px var(--sky-background-color-primary-dark);outline-offset:-1px}.sky-theme-modern .sky-sort-item:focus-visible:not(:active){background-color:transparent;box-shadow:0 1px 8px #0000004d;outline:solid 2px var(--sky-background-color-primary-dark);outline-offset:-2px}.sky-theme-modern .sky-sort-item button{padding:0;color:#686c73}.sky-theme-modern .sky-sort-item-selected{color:var(--sky-text-color-default);border-bottom:none;border-radius:0 6px 6px 0;border-left:solid 3px var(--sky-background-color-primary-dark);padding-bottom:10px;padding-left:17px;background-color:inherit}.sky-theme-modern .sky-sort-item-selected button{font-weight:400;color:#212327}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-sort-item button{color:#c0c2c5}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-sort-item-selected button{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-sort-item button{color:#c0c2c5}.sky-theme-modern.sky-theme-mode-dark .sky-sort-item-selected button{color:#fbfcfe}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
61
61
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.1", ngImport: i0, type: SkySortItemComponent, decorators: [{
|
|
62
62
|
type: Component,
|
|
63
|
-
args: [{ selector: 'sky-sort-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"sky-sort-item\"\n role=\"menuitemradio\"\n [attr.aria-checked]=\"isSelected | async\"\n [ngClass]=\"{ 'sky-sort-item-selected': (isSelected | async) }\"\n>\n <button\n type=\"button\"\n [ngClass]=\"{ 'sky-emphasized': (isSelected | async) }\"\n (click)=\"itemClicked()\"\n >\n <ng-content></ng-content>\n </button>\n</div>\n", styles: [".sky-sort-item{background-color:transparent;border:none;display:block;margin:4px;min-width:160px;text-align:left;transition:background-color .15s}.sky-sort-item.sky-dropdown-item-active,.sky-sort-item:hover{background-color:var(--sky-background-color-neutral-light)}.sky-sort-item.sky-dropdown-item-disabled{cursor:default}.sky-sort-item.sky-dropdown-item-disabled:hover{background-color:transparent}.sky-sort-item ::ng-deep>button{background-color:transparent;border:none;color:var(--sky-text-color-default);cursor:pointer;display:block;padding:3px 20px;text-align:left;width:100%}.sky-sort-item ::ng-deep>button[disabled]{color:var(--sky-text-color-deemphasized)}.sky-sort-item ::ng-deep>button[disabled]:hover{cursor:default}.sky-sort-item-selected{background-color:#f1eef6;padding:4px;margin:0}:host-context(.sky-theme-modern) .sky-sort-item{margin:0;border:none;color:var(--sky-text-color-deemphasized);font-weight:400;transition:box-shadow .15s;border-radius:6px;padding:10px 20px}:host-context(.sky-theme-modern) .sky-sort-item:hover:not(.sky-btn-tab-disabled):not(.sky-btn-tab-selected):not(.sky-dropdown-button-type-tab):not(:focus-visible){background-color:transparent;border-bottom:solid 1px var(--sky-highlight-color-info);color:var(--sky-text-color-default);padding-bottom:9px}:host-context(.sky-theme-modern) .sky-sort-item:focus-visible{background-color:transparent;color:var(--sky-text-color-default);outline:none}:host-context(.sky-theme-modern) .sky-sort-item:focus-visible:not(:active){color:var(--sky-text-color-default);outline:solid 2px var(--sky-background-color-primary-dark);outline-offset:-2px;box-shadow:0 1px 8px #0000004d}:host-context(.sky-theme-modern) .sky-sort-item:active{color:var(--sky-text-color-default);padding-bottom:7px}:host-context(.sky-theme-modern) .sky-sort-item.sky-btn-tab-disabled{background-color:transparent;font-family:BLKB Sans,Helvetica Neue,Arial,sans-serif;color:var(--sky-text-color-deemphasized);font-weight:400;font-size:15px;font-style:italic}:host-context(.sky-theme-modern) .sky-sort-item.sky-btn-tab-disabled .sky-btn-tab-close{font-size:16px}:host-context(.sky-theme-modern) .sky-sort-item:hover:not(.sky-btn-tab-disabled){background-color:transparent;border-bottom:none;outline:solid 1px var(--sky-background-color-primary-dark);outline-offset:-1px}:host-context(.sky-theme-modern) .sky-sort-item:focus-visible:not(:active){background-color:transparent;box-shadow:0 1px 8px #0000004d;outline:solid 2px var(--sky-background-color-primary-dark);outline-offset:-2px}:host-context(.sky-theme-modern) .sky-sort-item button{padding:0;color:#686c73}:host-context(.sky-theme-modern) .sky-sort-item-selected{color:var(--sky-text-color-default);border-bottom:none;border-radius:0 6px 6px 0;border-left:solid 3px var(--sky-background-color-primary-dark);padding-bottom:10px;padding-left:17px;background-color:inherit}:host-context(.sky-theme-modern) .sky-sort-item-selected button{font-weight:400;color:#212327}.sky-theme-modern .sky-sort-item{margin:0;border:none;color:var(--sky-text-color-deemphasized);font-weight:400;transition:box-shadow .15s;border-radius:6px;padding:10px 20px}.sky-theme-modern .sky-sort-item:hover:not(.sky-btn-tab-disabled):not(.sky-btn-tab-selected):not(.sky-dropdown-button-type-tab):not(:focus-visible){background-color:transparent;border-bottom:solid 1px var(--sky-highlight-color-info);color:var(--sky-text-color-default);padding-bottom:9px}.sky-theme-modern .sky-sort-item:focus-visible{background-color:transparent;color:var(--sky-text-color-default);outline:none}.sky-theme-modern .sky-sort-item:focus-visible:not(:active){color:var(--sky-text-color-default);outline:solid 2px var(--sky-background-color-primary-dark);outline-offset:-2px;box-shadow:0 1px 8px #0000004d}.sky-theme-modern .sky-sort-item:active{color:var(--sky-text-color-default);padding-bottom:7px}.sky-theme-modern .sky-sort-item.sky-btn-tab-disabled{background-color:transparent;font-family:BLKB Sans,Helvetica Neue,Arial,sans-serif;color:var(--sky-text-color-deemphasized);font-weight:400;font-size:15px;font-style:italic}.sky-theme-modern .sky-sort-item.sky-btn-tab-disabled .sky-btn-tab-close{font-size:16px}.sky-theme-modern .sky-sort-item:hover:not(.sky-btn-tab-disabled){background-color:transparent;border-bottom:none;outline:solid 1px var(--sky-background-color-primary-dark);outline-offset:-1px}.sky-theme-modern .sky-sort-item:focus-visible:not(:active){background-color:transparent;box-shadow:0 1px 8px #0000004d;outline:solid 2px var(--sky-background-color-primary-dark);outline-offset:-2px}.sky-theme-modern .sky-sort-item button{padding:0;color:#686c73}.sky-theme-modern .sky-sort-item-selected{color:var(--sky-text-color-default);border-bottom:none;border-radius:0 6px 6px 0;border-left:solid 3px var(--sky-background-color-primary-dark);padding-bottom:10px;padding-left:17px;background-color:inherit}.sky-theme-modern .sky-sort-item-selected button{font-weight:400;color:#212327}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-sort-item button{color:#c0c2c5}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-sort-item-selected button{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-sort-item button{color:#c0c2c5}.sky-theme-modern.sky-theme-mode-dark .sky-sort-item-selected button{color:#fbfcfe}\n"] }]
|
|
63
|
+
args: [{ selector: 'sky-sort-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"sky-sort-item\"\n role=\"menuitemradio\"\n [attr.aria-checked]=\"isSelected | async\"\n [ngClass]=\"{ 'sky-sort-item-selected': (isSelected | async) }\"\n>\n <button\n type=\"button\"\n [ngClass]=\"{ 'sky-font-emphasized': (isSelected | async) }\"\n (click)=\"itemClicked()\"\n >\n <ng-content></ng-content>\n </button>\n</div>\n", styles: [".sky-sort-item{background-color:transparent;border:none;display:block;margin:4px;min-width:160px;text-align:left;transition:background-color .15s}.sky-sort-item.sky-dropdown-item-active,.sky-sort-item:hover{background-color:var(--sky-background-color-neutral-light)}.sky-sort-item.sky-dropdown-item-disabled{cursor:default}.sky-sort-item.sky-dropdown-item-disabled:hover{background-color:transparent}.sky-sort-item ::ng-deep>button{background-color:transparent;border:none;color:var(--sky-text-color-default);cursor:pointer;display:block;padding:3px 20px;text-align:left;width:100%}.sky-sort-item ::ng-deep>button[disabled]{color:var(--sky-text-color-deemphasized)}.sky-sort-item ::ng-deep>button[disabled]:hover{cursor:default}.sky-sort-item-selected{background-color:#f1eef6;padding:4px;margin:0}:host-context(.sky-theme-modern) .sky-sort-item{margin:0;border:none;color:var(--sky-text-color-deemphasized);font-weight:400;transition:box-shadow .15s;border-radius:6px;padding:10px 20px}:host-context(.sky-theme-modern) .sky-sort-item:hover:not(.sky-btn-tab-disabled):not(.sky-btn-tab-selected):not(.sky-dropdown-button-type-tab):not(:focus-visible){background-color:transparent;border-bottom:solid 1px var(--sky-highlight-color-info);color:var(--sky-text-color-default);padding-bottom:9px}:host-context(.sky-theme-modern) .sky-sort-item:focus-visible{background-color:transparent;color:var(--sky-text-color-default);outline:none}:host-context(.sky-theme-modern) .sky-sort-item:focus-visible:not(:active){color:var(--sky-text-color-default);outline:solid 2px var(--sky-background-color-primary-dark);outline-offset:-2px;box-shadow:0 1px 8px #0000004d}:host-context(.sky-theme-modern) .sky-sort-item:active{color:var(--sky-text-color-default);padding-bottom:7px}:host-context(.sky-theme-modern) .sky-sort-item.sky-btn-tab-disabled{background-color:transparent;font-family:BLKB Sans,Helvetica Neue,Arial,sans-serif;color:var(--sky-text-color-deemphasized);font-weight:400;font-size:15px;font-style:italic}:host-context(.sky-theme-modern) .sky-sort-item.sky-btn-tab-disabled .sky-btn-tab-close{font-size:16px}:host-context(.sky-theme-modern) .sky-sort-item:hover:not(.sky-btn-tab-disabled){background-color:transparent;border-bottom:none;outline:solid 1px var(--sky-background-color-primary-dark);outline-offset:-1px}:host-context(.sky-theme-modern) .sky-sort-item:focus-visible:not(:active){background-color:transparent;box-shadow:0 1px 8px #0000004d;outline:solid 2px var(--sky-background-color-primary-dark);outline-offset:-2px}:host-context(.sky-theme-modern) .sky-sort-item button{padding:0;color:#686c73}:host-context(.sky-theme-modern) .sky-sort-item-selected{color:var(--sky-text-color-default);border-bottom:none;border-radius:0 6px 6px 0;border-left:solid 3px var(--sky-background-color-primary-dark);padding-bottom:10px;padding-left:17px;background-color:inherit}:host-context(.sky-theme-modern) .sky-sort-item-selected button{font-weight:400;color:#212327}.sky-theme-modern .sky-sort-item{margin:0;border:none;color:var(--sky-text-color-deemphasized);font-weight:400;transition:box-shadow .15s;border-radius:6px;padding:10px 20px}.sky-theme-modern .sky-sort-item:hover:not(.sky-btn-tab-disabled):not(.sky-btn-tab-selected):not(.sky-dropdown-button-type-tab):not(:focus-visible){background-color:transparent;border-bottom:solid 1px var(--sky-highlight-color-info);color:var(--sky-text-color-default);padding-bottom:9px}.sky-theme-modern .sky-sort-item:focus-visible{background-color:transparent;color:var(--sky-text-color-default);outline:none}.sky-theme-modern .sky-sort-item:focus-visible:not(:active){color:var(--sky-text-color-default);outline:solid 2px var(--sky-background-color-primary-dark);outline-offset:-2px;box-shadow:0 1px 8px #0000004d}.sky-theme-modern .sky-sort-item:active{color:var(--sky-text-color-default);padding-bottom:7px}.sky-theme-modern .sky-sort-item.sky-btn-tab-disabled{background-color:transparent;font-family:BLKB Sans,Helvetica Neue,Arial,sans-serif;color:var(--sky-text-color-deemphasized);font-weight:400;font-size:15px;font-style:italic}.sky-theme-modern .sky-sort-item.sky-btn-tab-disabled .sky-btn-tab-close{font-size:16px}.sky-theme-modern .sky-sort-item:hover:not(.sky-btn-tab-disabled){background-color:transparent;border-bottom:none;outline:solid 1px var(--sky-background-color-primary-dark);outline-offset:-1px}.sky-theme-modern .sky-sort-item:focus-visible:not(:active){background-color:transparent;box-shadow:0 1px 8px #0000004d;outline:solid 2px var(--sky-background-color-primary-dark);outline-offset:-2px}.sky-theme-modern .sky-sort-item button{padding:0;color:#686c73}.sky-theme-modern .sky-sort-item-selected{color:var(--sky-text-color-default);border-bottom:none;border-radius:0 6px 6px 0;border-left:solid 3px var(--sky-background-color-primary-dark);padding-bottom:10px;padding-left:17px;background-color:inherit}.sky-theme-modern .sky-sort-item-selected button{font-weight:400;color:#212327}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-sort-item button{color:#c0c2c5}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-sort-item-selected button{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-sort-item button{color:#c0c2c5}.sky-theme-modern.sky-theme-mode-dark .sky-sort-item-selected button{color:#fbfcfe}\n"] }]
|
|
64
64
|
}], ctorParameters: function () { return [{ type: i1.SkySortService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { active: [{
|
|
65
65
|
type: Input
|
|
66
66
|
}], itemSelect: [{
|
|
67
67
|
type: Output
|
|
68
68
|
}] } });
|
|
69
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29ydC1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9saXN0cy9zcmMvbGliL21vZHVsZXMvc29ydC9zb3J0LWl0ZW0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xpc3RzL3NyYy9saWIvbW9kdWxlcy9zb3J0L3NvcnQtaXRlbS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFFdkIsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEVBSUwsTUFBTSxHQUVQLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBRSxlQUFlLEVBQWdCLE1BQU0sTUFBTSxDQUFDOzs7O0FBSXJELE1BQU0sbUJBQW1CLEdBQUcsZ0JBQWdCLENBQUM7QUFFN0MsSUFBSSxnQkFBZ0IsR0FBRyxDQUFDLENBQUM7QUFRekIsTUFBTSxPQUFPLG9CQUFvQjtJQXdCL0IsWUFBWSxXQUEyQixFQUFFLFFBQTJCO1FBakJwRTs7V0FFRztRQUVJLGVBQVUsR0FBc0IsSUFBSSxZQUFZLEVBQUUsQ0FBQyxDQUFDLDZEQUE2RDtRQUVqSCxlQUFVLEdBQTZCLElBQUksZUFBZSxDQUMvRCxLQUFLLENBQ04sQ0FBQztRQUVGLHFEQUF3QztRQUV4QyxtREFBZ0M7UUFFaEMsb0RBQTZCO1FBQzdCLGlEQUE2QjtRQUczQix1QkFBQSxJQUFJLHFDQUFnQixXQUFXLE1BQUEsQ0FBQztRQUNoQyx1QkFBQSxJQUFJLGtDQUFhLFFBQVEsTUFBQSxDQUFDO0lBQzVCLENBQUM7SUFFTSxRQUFRO1FBQ2IsZ0JBQWdCLEVBQUUsQ0FBQztRQUNuQix1QkFBQSxJQUFJLG9DQUFlLG1CQUFtQixHQUFHLGdCQUFnQixDQUFDLFFBQVEsRUFBRSxNQUFBLENBQUM7UUFDckUsdUJBQUEsSUFBSSxzQ0FBaUIsdUJBQUEsSUFBSSx5Q0FBYSxDQUFDLFlBQVksQ0FBQyxTQUFTLENBQzNELENBQUMsTUFBYyxFQUFFLEVBQUU7WUFDakIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsTUFBTSxLQUFLLHVCQUFBLElBQUksd0NBQVksQ0FBQyxDQUFDO1lBQ2xELHVCQUFBLElBQUksc0NBQVUsQ0FBQyxhQUFhLEVBQUUsQ0FBQztRQUNqQyxDQUFDLENBQ0YsTUFBQSxDQUFDO1FBRUYsSUFBSSxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ2YsdUJBQUEsSUFBSSx5Q0FBYSxDQUFDLFVBQVUsQ0FBQyx1QkFBQSxJQUFJLHdDQUFZLENBQUMsQ0FBQztTQUNoRDtJQUNILENBQUM7SUFFTSxXQUFXLENBQUMsT0FBc0I7UUFDdkMsSUFDRSx1QkFBQSxJQUFJLHdDQUFZO1lBQ2hCLE9BQU87WUFDUCxPQUFPLENBQUMsUUFBUSxDQUFDO1lBQ2pCLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxZQUFZO1lBQzlCLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxZQUFZLEtBQUssT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDLGFBQWEsRUFDbEU7WUFDQSx1QkFBQSxJQUFJLHlDQUFhLENBQUMsVUFBVSxDQUFDLHVCQUFBLElBQUksd0NBQVksQ0FBQyxDQUFDO1NBQ2hEO0lBQ0gsQ0FBQztJQUVNLFdBQVc7UUFDaEIsSUFBSSx1QkFBQSxJQUFJLHdDQUFZLEVBQUU7WUFDcEIsdUJBQUEsSUFBSSx5Q0FBYSxDQUFDLFVBQVUsQ0FBQyx1QkFBQSxJQUFJLHdDQUFZLENBQUMsQ0FBQztZQUMvQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksRUFBRSxDQUFDO1NBQ3hCO0lBQ0gsQ0FBQztJQUVNLFdBQVc7UUFDaEIsMEJBQTBCO1FBQzFCLGtCQUFrQjtRQUNsQixJQUFJLHVCQUFBLElBQUksMENBQWMsRUFBRTtZQUN0Qix1QkFBQSxJQUFJLDBDQUFjLENBQUMsV0FBVyxFQUFFLENBQUM7U0FDbEM7SUFDSCxDQUFDOzs7aUhBckVVLG9CQUFvQjtxR0FBcEIsb0JBQW9CLCtJQzNCakMsNldBY0E7MkZEYWEsb0JBQW9CO2tCQU5oQyxTQUFTOytCQUNFLGVBQWUsbUJBR1IsdUJBQXVCLENBQUMsTUFBTTtxSUFPeEMsTUFBTTtzQkFEWixLQUFLO2dCQU9DLFVBQVU7c0JBRGhCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gIENvbXBvbmVudCxcbiAgRXZlbnRFbWl0dGVyLFxuICBJbnB1dCxcbiAgT25DaGFuZ2VzLFxuICBPbkRlc3Ryb3ksXG4gIE9uSW5pdCxcbiAgT3V0cHV0LFxuICBTaW1wbGVDaGFuZ2VzLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0LCBTdWJzY3JpcHRpb24gfSBmcm9tICdyeGpzJztcblxuaW1wb3J0IHsgU2t5U29ydFNlcnZpY2UgfSBmcm9tICcuL3NvcnQuc2VydmljZSc7XG5cbmNvbnN0IFNPUlRfSVRFTV9JRF9QUkVGSVggPSAnc2t5LXNvcnQtaXRlbS0nO1xuXG5sZXQgc29ydEl0ZW1JZE51bWJlciA9IDA7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NreS1zb3J0LWl0ZW0nLFxuICBzdHlsZVVybHM6IFsnLi9zb3J0LWl0ZW0uY29tcG9uZW50LnNjc3MnXSxcbiAgdGVtcGxhdGVVcmw6ICcuL3NvcnQtaXRlbS5jb21wb25lbnQuaHRtbCcsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lTb3J0SXRlbUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25DaGFuZ2VzLCBPbkRlc3Ryb3kge1xuICAvKipcbiAgICogV2hldGhlciB0aGUgc29ydGluZyBvcHRpb24gaXMgYWN0aXZlLlxuICAgKi9cbiAgQElucHV0KClcbiAgcHVibGljIGFjdGl2ZTogYm9vbGVhbiB8IHVuZGVmaW5lZDtcblxuICAvKipcbiAgICogRmlyZXMgd2hlbiBhIHNvcnQgaXRlbSBpcyBzZWxlY3RlZC5cbiAgICovXG4gIEBPdXRwdXQoKVxuICBwdWJsaWMgaXRlbVNlbGVjdDogRXZlbnRFbWl0dGVyPGFueT4gPSBuZXcgRXZlbnRFbWl0dGVyKCk7IC8vIFRPRE86IENoYW5nZSB0byBgRXZlbnRFbWl0dGVyPHZvaWQ+YCBpbiBhIGJyZWFraW5nIGNoYW5nZS5cblxuICBwdWJsaWMgaXNTZWxlY3RlZDogQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+ID0gbmV3IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPihcbiAgICBmYWxzZVxuICApO1xuXG4gICNzdWJzY3JpcHRpb246IFN1YnNjcmlwdGlvbiB8IHVuZGVmaW5lZDtcblxuICAjc29ydEl0ZW1JZDogc3RyaW5nIHwgdW5kZWZpbmVkO1xuXG4gICNzb3J0U2VydmljZTogU2t5U29ydFNlcnZpY2U7XG4gICNkZXRlY3RvcjogQ2hhbmdlRGV0ZWN0b3JSZWY7XG5cbiAgY29uc3RydWN0b3Ioc29ydFNlcnZpY2U6IFNreVNvcnRTZXJ2aWNlLCBkZXRlY3RvcjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHtcbiAgICB0aGlzLiNzb3J0U2VydmljZSA9IHNvcnRTZXJ2aWNlO1xuICAgIHRoaXMuI2RldGVjdG9yID0gZGV0ZWN0b3I7XG4gIH1cblxuICBwdWJsaWMgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgc29ydEl0ZW1JZE51bWJlcisrO1xuICAgIHRoaXMuI3NvcnRJdGVtSWQgPSBTT1JUX0lURU1fSURfUFJFRklYICsgc29ydEl0ZW1JZE51bWJlci50b1N0cmluZygpO1xuICAgIHRoaXMuI3N1YnNjcmlwdGlvbiA9IHRoaXMuI3NvcnRTZXJ2aWNlLnNlbGVjdGVkSXRlbS5zdWJzY3JpYmUoXG4gICAgICAoaXRlbUlkOiBzdHJpbmcpID0+IHtcbiAgICAgICAgdGhpcy5pc1NlbGVjdGVkLm5leHQoaXRlbUlkID09PSB0aGlzLiNzb3J0SXRlbUlkKTtcbiAgICAgICAgdGhpcy4jZGV0ZWN0b3IuZGV0ZWN0Q2hhbmdlcygpO1xuICAgICAgfVxuICAgICk7XG5cbiAgICBpZiAodGhpcy5hY3RpdmUpIHtcbiAgICAgIHRoaXMuI3NvcnRTZXJ2aWNlLnNlbGVjdEl0ZW0odGhpcy4jc29ydEl0ZW1JZCk7XG4gICAgfVxuICB9XG5cbiAgcHVibGljIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcbiAgICBpZiAoXG4gICAgICB0aGlzLiNzb3J0SXRlbUlkICYmXG4gICAgICBjaGFuZ2VzICYmXG4gICAgICBjaGFuZ2VzWydhY3RpdmUnXSAmJlxuICAgICAgY2hhbmdlc1snYWN0aXZlJ10uY3VycmVudFZhbHVlICYmXG4gICAgICBjaGFuZ2VzWydhY3RpdmUnXS5jdXJyZW50VmFsdWUgIT09IGNoYW5nZXNbJ2FjdGl2ZSddLnByZXZpb3VzVmFsdWVcbiAgICApIHtcbiAgICAgIHRoaXMuI3NvcnRTZXJ2aWNlLnNlbGVjdEl0ZW0odGhpcy4jc29ydEl0ZW1JZCk7XG4gICAgfVxuICB9XG5cbiAgcHVibGljIGl0ZW1DbGlja2VkKCk6IHZvaWQge1xuICAgIGlmICh0aGlzLiNzb3J0SXRlbUlkKSB7XG4gICAgICB0aGlzLiNzb3J0U2VydmljZS5zZWxlY3RJdGVtKHRoaXMuI3NvcnRJdGVtSWQpO1xuICAgICAgdGhpcy5pdGVtU2VsZWN0LmVtaXQoKTtcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgLyogaXN0YW5idWwgaWdub3JlIGVsc2UgKi9cbiAgICAvKiBzYW5pdHkgY2hlY2sgKi9cbiAgICBpZiAodGhpcy4jc3Vic2NyaXB0aW9uKSB7XG4gICAgICB0aGlzLiNzdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKTtcbiAgICB9XG4gIH1cbn1cbiIsIjxkaXZcbiAgY2xhc3M9XCJza3ktc29ydC1pdGVtXCJcbiAgcm9sZT1cIm1lbnVpdGVtcmFkaW9cIlxuICBbYXR0ci5hcmlhLWNoZWNrZWRdPVwiaXNTZWxlY3RlZCB8IGFzeW5jXCJcbiAgW25nQ2xhc3NdPVwieyAnc2t5LXNvcnQtaXRlbS1zZWxlY3RlZCc6IChpc1NlbGVjdGVkIHwgYXN5bmMpIH1cIlxuPlxuICA8YnV0dG9uXG4gICAgdHlwZT1cImJ1dHRvblwiXG4gICAgW25nQ2xhc3NdPVwieyAnc2t5LWZvbnQtZW1waGFzaXplZCc6IChpc1NlbGVjdGVkIHwgYXN5bmMpIH1cIlxuICAgIChjbGljayk9XCJpdGVtQ2xpY2tlZCgpXCJcbiAgPlxuICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgPC9idXR0b24+XG48L2Rpdj5cbiJdfQ==
|
|
@@ -2,7 +2,6 @@ import { SkyComponentHarness } from '@skyux/core/testing';
|
|
|
2
2
|
import { SkyRepeaterItemHarness } from './repeater-item-harness';
|
|
3
3
|
/**
|
|
4
4
|
* Harness for interacting with a repeater component in tests.
|
|
5
|
-
* @internal
|
|
6
5
|
*/
|
|
7
6
|
export class SkyRepeaterHarness extends SkyComponentHarness {
|
|
8
7
|
/**
|
|
@@ -23,4 +22,4 @@ export class SkyRepeaterHarness extends SkyComponentHarness {
|
|
|
23
22
|
* @internal
|
|
24
23
|
*/
|
|
25
24
|
SkyRepeaterHarness.hostSelector = 'sky-repeater';
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVwZWF0ZXItaGFybmVzcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9saXN0cy90ZXN0aW5nL3NyYy9yZXBlYXRlci9yZXBlYXRlci1oYXJuZXNzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRzFELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBR2pFOztHQUVHO0FBQ0gsTUFBTSxPQUFPLGtCQUFtQixTQUFRLG1CQUFtQjtJQU16RDs7O09BR0c7SUFDSSxNQUFNLENBQUMsSUFBSSxDQUNoQixPQUFrQztRQUVsQyxPQUFPLGtCQUFrQixDQUFDLHFCQUFxQixDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQzNELENBQUM7SUFFRDs7T0FFRztJQUNJLEtBQUssQ0FBQyxnQkFBZ0IsQ0FDM0IsT0FBdUM7UUFFdkMsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLHNCQUFzQixDQUFDLElBQUksQ0FBQyxPQUFPLElBQUksRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDO0lBQzFFLENBQUM7O0FBdEJEOztHQUVHO0FBQ1csK0JBQVksR0FBRyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIYXJuZXNzUHJlZGljYXRlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL3Rlc3RpbmcnO1xuaW1wb3J0IHsgU2t5Q29tcG9uZW50SGFybmVzcyB9IGZyb20gJ0Bza3l1eC9jb3JlL3Rlc3RpbmcnO1xuXG5pbXBvcnQgeyBTa3lSZXBlYXRlckhhcm5lc3NGaWx0ZXJzIH0gZnJvbSAnLi9yZXBlYXRlci1oYXJuZXNzLWZpbHRlcnMnO1xuaW1wb3J0IHsgU2t5UmVwZWF0ZXJJdGVtSGFybmVzcyB9IGZyb20gJy4vcmVwZWF0ZXItaXRlbS1oYXJuZXNzJztcbmltcG9ydCB7IFNreVJlcGVhdGVySXRlbUhhcm5lc3NGaWx0ZXJzIH0gZnJvbSAnLi9yZXBlYXRlci1pdGVtLWhhcm5lc3MtZmlsdGVycyc7XG5cbi8qKlxuICogSGFybmVzcyBmb3IgaW50ZXJhY3Rpbmcgd2l0aCBhIHJlcGVhdGVyIGNvbXBvbmVudCBpbiB0ZXN0cy5cbiAqL1xuZXhwb3J0IGNsYXNzIFNreVJlcGVhdGVySGFybmVzcyBleHRlbmRzIFNreUNvbXBvbmVudEhhcm5lc3Mge1xuICAvKipcbiAgICogQGludGVybmFsXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIGhvc3RTZWxlY3RvciA9ICdza3ktcmVwZWF0ZXInO1xuXG4gIC8qKlxuICAgKiBHZXRzIGEgYEhhcm5lc3NQcmVkaWNhdGVgIHRoYXQgY2FuIGJlIHVzZWQgdG8gc2VhcmNoIGZvciBhXG4gICAqIGBTa3lSZXBlYXRlckhhcm5lc3NgIHRoYXQgbWVldHMgY2VydGFpbiBjcml0ZXJpYS5cbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgd2l0aChcbiAgICBmaWx0ZXJzOiBTa3lSZXBlYXRlckhhcm5lc3NGaWx0ZXJzXG4gICk6IEhhcm5lc3NQcmVkaWNhdGU8U2t5UmVwZWF0ZXJIYXJuZXNzPiB7XG4gICAgcmV0dXJuIFNreVJlcGVhdGVySGFybmVzcy5nZXREYXRhU2t5SWRQcmVkaWNhdGUoZmlsdGVycyk7XG4gIH1cblxuICAvKipcbiAgICogR2V0cyBhIGxpc3Qgb2YgY2hpbGQgcmVwZWF0ZXIgaXRlbXMuXG4gICAqL1xuICBwdWJsaWMgYXN5bmMgZ2V0UmVwZWF0ZXJJdGVtcyhcbiAgICBmaWx0ZXJzPzogU2t5UmVwZWF0ZXJJdGVtSGFybmVzc0ZpbHRlcnNcbiAgKTogUHJvbWlzZTxTa3lSZXBlYXRlckl0ZW1IYXJuZXNzW10+IHtcbiAgICByZXR1cm4gdGhpcy5sb2NhdG9yRm9yQWxsKFNreVJlcGVhdGVySXRlbUhhcm5lc3Mud2l0aChmaWx0ZXJzIHx8IHt9KSkoKTtcbiAgfVxufVxuIl19
|