@skyux/list-builder-view-grids 5.0.0 → 5.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (32) hide show
  1. package/bundles/skyux-list-builder-view-grids-testing.umd.js +6 -6
  2. package/bundles/skyux-list-builder-view-grids-testing.umd.js.map +1 -1
  3. package/bundles/skyux-list-builder-view-grids.umd.js +147 -130
  4. package/bundles/skyux-list-builder-view-grids.umd.js.map +1 -1
  5. package/documentation.json +80 -75
  6. package/esm2015/modules/column-selector/column-selector-modal.component.js +5 -5
  7. package/esm2015/modules/column-selector/column-selector-modal.module.js +9 -13
  8. package/esm2015/modules/list-column-selector-action/list-column-selector-action.component.js +29 -27
  9. package/esm2015/modules/list-column-selector-action/list-column-selector-action.module.js +11 -15
  10. package/esm2015/modules/list-column-selector-action/list-column-selector-button.component.js +5 -5
  11. package/esm2015/modules/list-view-grid/list-view-grid.component.js +73 -58
  12. package/esm2015/modules/list-view-grid/list-view-grid.module.js +10 -12
  13. package/esm2015/modules/list-view-grid/state/columns/columns.orchestrator.js +3 -4
  14. package/esm2015/modules/list-view-grid/state/columns/load.action.js +1 -1
  15. package/esm2015/modules/list-view-grid/state/displayed-columns/displayed-columns.orchestrator.js +3 -4
  16. package/esm2015/modules/list-view-grid/state/displayed-columns/load.action.js +1 -1
  17. package/esm2015/modules/list-view-grid/state/grid-state-action.type.js +1 -1
  18. package/esm2015/modules/list-view-grid/state/grid-state.model.js +1 -1
  19. package/esm2015/modules/list-view-grid/state/grid-state.rxstate.js +4 -4
  20. package/esm2015/modules/list-view-grid/state/grid-state.state-node.js +5 -6
  21. package/esm2015/modules/list-view-grid/types/list-view-grid-message-type.js +1 -1
  22. package/esm2015/modules/list-view-grid/types/list-view-grid-message.js +1 -1
  23. package/esm2015/modules/shared/sky-list-builder-view-grids-resources.module.js +27 -12
  24. package/esm2015/testing/list-view-grid-fixture-cell.js +1 -1
  25. package/esm2015/testing/list-view-grid-fixture-header.js +1 -1
  26. package/esm2015/testing/list-view-grid-fixture-row.js +1 -1
  27. package/esm2015/testing/list-view-grid-fixture.js +4 -4
  28. package/fesm2015/skyux-list-builder-view-grids-testing.js +3 -3
  29. package/fesm2015/skyux-list-builder-view-grids-testing.js.map +1 -1
  30. package/fesm2015/skyux-list-builder-view-grids.js +161 -142
  31. package/fesm2015/skyux-list-builder-view-grids.js.map +1 -1
  32. package/package.json +9 -9
@@ -1,10 +1,10 @@
1
- import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, forwardRef, Input, Output, ViewChild } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, forwardRef, Input, Output, ViewChild, } from '@angular/core';
2
2
  import { of as observableOf, Subject } from 'rxjs';
3
- import { distinctUntilChanged, map as observableMap, scan, take, takeUntil } from 'rxjs/operators';
3
+ import { distinctUntilChanged, map as observableMap, scan, take, takeUntil, } from 'rxjs/operators';
4
4
  import { getValue } from '@skyux/list-builder-common';
5
- import { SkyGridColumnComponent, SkyGridColumnModel, SkyGridComponent, SkyGridMessageType, SkyGridSelectedRowsSource } from '@skyux/grids';
6
- import { ListSearchModel, ListViewComponent } from '@skyux/list-builder';
7
- import { getData, isObservable } from '@skyux/list-builder-common';
5
+ import { SkyGridColumnComponent, SkyGridColumnModel, SkyGridComponent, SkyGridMessageType, SkyGridSelectedRowsSource, } from '@skyux/grids';
6
+ import { ListSearchModel, ListViewComponent, } from '@skyux/list-builder';
7
+ import { getData, isObservable, } from '@skyux/list-builder-common';
8
8
  import { GridState } from './state/grid-state.state-node';
9
9
  import { GridStateDispatcher } from './state/grid-state.rxstate';
10
10
  import { GridStateModel } from './state/grid-state.model';
@@ -97,19 +97,20 @@ export class SkyListViewGridComponent extends ListViewComponent {
97
97
  }
98
98
  get gridHeight() {
99
99
  /* istanbul ignore next */
100
- return (typeof this.height === 'number')
100
+ return typeof this.height === 'number'
101
101
  ? observableOf(this.height)
102
102
  : this.height;
103
103
  }
104
104
  get gridWidth() {
105
105
  /* istanbul ignore next */
106
- return (typeof this.width === 'number')
106
+ return typeof this.width === 'number'
107
107
  ? observableOf(this.width)
108
108
  : this.width;
109
109
  }
110
110
  ngAfterContentInit() {
111
111
  // Watch for selection changes and update multiselectSelectedIds for local comparison.
112
- this.state.pipe(observableMap(s => s.selected.item), takeUntil(this.ngUnsubscribe), distinctUntilChanged(this.selectedMapEqual))
112
+ this.state
113
+ .pipe(observableMap((s) => s.selected.item), takeUntil(this.ngUnsubscribe), distinctUntilChanged(this.selectedMapEqual))
113
114
  .subscribe((items) => {
114
115
  const selectedIds = [];
115
116
  items.selectedIdMap.forEach((isSelected, id) => {
@@ -123,7 +124,7 @@ export class SkyListViewGridComponent extends ListViewComponent {
123
124
  if (this.columnComponents.length === 0) {
124
125
  throw new Error('Grid view requires at least one sky-grid-column to render.');
125
126
  }
126
- let columnModels = this.columnComponents.map(columnComponent => {
127
+ let columnModels = this.columnComponents.map((columnComponent) => {
127
128
  return new SkyGridColumnModel(columnComponent.template, columnComponent);
128
129
  });
129
130
  if (this.width && !isObservable(this.width)) {
@@ -133,7 +134,7 @@ export class SkyListViewGridComponent extends ListViewComponent {
133
134
  this.height = observableOf(this.height);
134
135
  }
135
136
  // Setup Observables for template
136
- this.columns = this.gridState.pipe(observableMap(s => s.columns.items), distinctUntilChanged(this.arraysEqual), takeUntil(this.ngUnsubscribe));
137
+ this.columns = this.gridState.pipe(observableMap((s) => s.columns.items), distinctUntilChanged(this.arraysEqual), takeUntil(this.ngUnsubscribe));
137
138
  this.selectedColumnIds = this.getSelectedIds();
138
139
  this.items = this.getGridItems();
139
140
  this.loading = this.state.pipe(observableMap((s) => {
@@ -149,12 +150,13 @@ export class SkyListViewGridComponent extends ListViewComponent {
149
150
  /* sanity check */
150
151
  return undefined;
151
152
  }), distinctUntilChanged(), takeUntil(this.ngUnsubscribe));
152
- this.gridState.pipe(observableMap(s => s.columns.items), takeUntil(this.ngUnsubscribe), distinctUntilChanged(this.arraysEqual))
153
- .subscribe(columns => {
153
+ this.gridState
154
+ .pipe(observableMap((s) => s.columns.items), takeUntil(this.ngUnsubscribe), distinctUntilChanged(this.arraysEqual))
155
+ .subscribe((columns) => {
154
156
  /* istanbul ignore else */
155
157
  if (this.hiddenColumns) {
156
158
  getValue(this.hiddenColumns, (hiddenColumns) => {
157
- this.gridDispatcher.next(new ListViewDisplayedGridColumnsLoadAction(columns.filter(x => {
159
+ this.gridDispatcher.next(new ListViewDisplayedGridColumnsLoadAction(columns.filter((x) => {
158
160
  /* istanbul ignore next */
159
161
  /* sanity check */
160
162
  let id = x.id || x.field;
@@ -165,14 +167,14 @@ export class SkyListViewGridComponent extends ListViewComponent {
165
167
  else if (this.displayedColumns) {
166
168
  /* istanbul ignore next */
167
169
  getValue(this.displayedColumns, (displayedColumns) => {
168
- this.gridDispatcher.next(new ListViewDisplayedGridColumnsLoadAction(columns.filter(x => displayedColumns.indexOf(x.id || x.field) !== -1), true));
170
+ this.gridDispatcher.next(new ListViewDisplayedGridColumnsLoadAction(columns.filter((x) => displayedColumns.indexOf(x.id || x.field) !== -1), true));
169
171
  });
170
172
  }
171
173
  else {
172
- this.gridDispatcher.next(new ListViewDisplayedGridColumnsLoadAction(columns.filter(x => !x.hidden), true));
174
+ this.gridDispatcher.next(new ListViewDisplayedGridColumnsLoadAction(columns.filter((x) => !x.hidden), true));
173
175
  }
174
176
  });
175
- this.currentSearchText = this.state.pipe(observableMap(s => s.search.searchText), distinctUntilChanged(), takeUntil(this.ngUnsubscribe));
177
+ this.currentSearchText = this.state.pipe(observableMap((s) => s.search.searchText), distinctUntilChanged(), takeUntil(this.ngUnsubscribe));
176
178
  this.gridDispatcher.next(new ListViewGridColumnsLoadAction(columnModels, true));
177
179
  this.handleColumnChange();
178
180
  if (this.enableMultiselect) {
@@ -191,10 +193,11 @@ export class SkyListViewGridComponent extends ListViewComponent {
191
193
  onMultiselectSelectionChange(event) {
192
194
  if (event.source === SkyGridSelectedRowsSource.CheckboxChange ||
193
195
  event.source === SkyGridSelectedRowsSource.RowClick) {
194
- this.state.pipe(observableMap(s => s.items.items), take(1))
196
+ this.state
197
+ .pipe(observableMap((s) => s.items.items), take(1))
195
198
  .subscribe((items) => {
196
- const newItemIds = this.arrayIntersection(items.map(i => i.id), this.multiselectSelectedIds);
197
- const newIds = items.filter(i => i.isSelected).map(i => i.id);
199
+ const newItemIds = this.arrayIntersection(items.map((i) => i.id), this.multiselectSelectedIds);
200
+ const newIds = items.filter((i) => i.isSelected).map((i) => i.id);
198
201
  // Check for deselected ids & send message to dispatcher.
199
202
  const deselectedIds = this.arrayDiff(newItemIds, newIds);
200
203
  if (deselectedIds.length > 0) {
@@ -209,12 +212,12 @@ export class SkyListViewGridComponent extends ListViewComponent {
209
212
  }
210
213
  }
211
214
  columnIdsChanged(selectedColumnIds) {
212
- this.selectedColumnIds.pipe(take(1))
213
- .subscribe(currentIds => {
214
- if (!(this.arraysEqual(selectedColumnIds, currentIds))) {
215
- this.gridState.pipe(observableMap(s => s.columns.items), take(1))
216
- .subscribe(columns => {
217
- let displayedColumns = selectedColumnIds.map(columnId => columns.filter(c => c.id === columnId)[0]);
215
+ this.selectedColumnIds.pipe(take(1)).subscribe((currentIds) => {
216
+ if (!this.arraysEqual(selectedColumnIds, currentIds)) {
217
+ this.gridState
218
+ .pipe(observableMap((s) => s.columns.items), take(1))
219
+ .subscribe((columns) => {
220
+ let displayedColumns = selectedColumnIds.map((columnId) => columns.filter((c) => c.id === columnId)[0]);
218
221
  this.gridDispatcher.next(new ListViewDisplayedGridColumnsLoadAction(displayedColumns, true));
219
222
  });
220
223
  }
@@ -235,24 +238,27 @@ export class SkyListViewGridComponent extends ListViewComponent {
235
238
  update, the searchText update was consumed after the resulting list item update. Scanning the
236
239
  previous value of items lastUpdate ensures that we only receive the latest items.
237
240
  */
238
- this.gridState.pipe(takeUntil(this.ngUnsubscribe), scan((previousValue, newValue) => {
239
- if (previousValue.displayedColumns.lastUpdate > newValue.displayedColumns.lastUpdate) {
241
+ this.gridState
242
+ .pipe(takeUntil(this.ngUnsubscribe), scan((previousValue, newValue) => {
243
+ if (previousValue.displayedColumns.lastUpdate >
244
+ newValue.displayedColumns.lastUpdate) {
240
245
  return previousValue;
241
246
  }
242
247
  else {
243
248
  return newValue;
244
249
  }
245
- }), observableMap(s => s.displayedColumns.items), distinctUntilChanged(this.arraysEqual))
246
- .subscribe(displayedColumns => {
247
- let setFunctions = this.searchFunction !== undefined ? [this.searchFunction] :
248
- displayedColumns
249
- .map(column => (data, searchText) => column.searchFunction(getData(data, column.field), searchText))
250
- .filter(c => c !== undefined);
251
- this.state.pipe(take(1)).subscribe(s => {
250
+ }), observableMap((s) => s.displayedColumns.items), distinctUntilChanged(this.arraysEqual))
251
+ .subscribe((displayedColumns) => {
252
+ let setFunctions = this.searchFunction !== undefined
253
+ ? [this.searchFunction]
254
+ : displayedColumns
255
+ .map((column) => (data, searchText) => column.searchFunction(getData(data, column.field), searchText))
256
+ .filter((c) => c !== undefined);
257
+ this.state.pipe(take(1)).subscribe((s) => {
252
258
  this.dispatcher.searchSetOptions(new ListSearchModel({
253
259
  searchText: s.search.searchText,
254
260
  functions: setFunctions,
255
- fieldSelectors: displayedColumns.map(d => d.field)
261
+ fieldSelectors: displayedColumns.map((d) => d.field),
256
262
  }));
257
263
  });
258
264
  });
@@ -265,16 +271,16 @@ export class SkyListViewGridComponent extends ListViewComponent {
265
271
  this.gridMessageStream.next({
266
272
  type: SkyGridMessageType.AbortDeleteRow,
267
273
  data: {
268
- abortDeleteRow: message.data.abortDeleteRow
269
- }
274
+ abortDeleteRow: message.data.abortDeleteRow,
275
+ },
270
276
  });
271
277
  }
272
278
  else if (message.type === SkyListViewGridMessageType.PromptDeleteRow) {
273
279
  this.gridMessageStream.next({
274
280
  type: SkyGridMessageType.PromptDeleteRow,
275
281
  data: {
276
- promptDeleteRow: message.data.promptDeleteRow
277
- }
282
+ promptDeleteRow: message.data.promptDeleteRow,
283
+ },
278
284
  });
279
285
  }
280
286
  });
@@ -282,20 +288,23 @@ export class SkyListViewGridComponent extends ListViewComponent {
282
288
  }
283
289
  handleColumnChange() {
284
290
  // watch for changes in column components
285
- this.columnComponents.changes.pipe(takeUntil(this.ngUnsubscribe))
291
+ this.columnComponents.changes
292
+ .pipe(takeUntil(this.ngUnsubscribe))
286
293
  .subscribe((columnComponents) => {
287
- let columnModels = this.columnComponents.map(column => {
294
+ let columnModels = this.columnComponents.map((column) => {
288
295
  return new SkyGridColumnModel(column.template, column);
289
296
  });
290
297
  this.gridDispatcher.next(new ListViewGridColumnsLoadAction(columnModels, true));
291
298
  });
292
299
  // Watch for column heading changes:
293
300
  this.columnComponents.forEach((comp) => {
294
- comp.headingModelChanges.pipe(takeUntil(this.ngUnsubscribe))
301
+ comp.headingModelChanges
302
+ .pipe(takeUntil(this.ngUnsubscribe))
295
303
  .subscribe((change) => {
296
304
  this.gridComponent.updateColumnHeading(change);
297
305
  });
298
- comp.descriptionModelChanges.pipe(takeUntil(this.ngUnsubscribe))
306
+ comp.descriptionModelChanges
307
+ .pipe(takeUntil(this.ngUnsubscribe))
299
308
  .subscribe((change) => {
300
309
  this.gridComponent.updateColumnDescription(change);
301
310
  });
@@ -326,7 +335,7 @@ export class SkyListViewGridComponent extends ListViewComponent {
326
335
  static properties to a static state object with observable properties that you can subscribe
327
336
  to.
328
337
  */
329
- return this.gridState.pipe(observableMap(s => s.displayedColumns), scan((previousValue, newValue) => {
338
+ return this.gridState.pipe(observableMap((s) => s.displayedColumns), scan((previousValue, newValue) => {
330
339
  if (previousValue.lastUpdate > newValue.lastUpdate) {
331
340
  return previousValue;
332
341
  }
@@ -375,26 +384,29 @@ export class SkyListViewGridComponent extends ListViewComponent {
375
384
  return true;
376
385
  }
377
386
  arrayDiff(arrA, arrB) {
378
- return arrA.filter(i => arrB.indexOf(i) < 0);
387
+ return arrA.filter((i) => arrB.indexOf(i) < 0);
379
388
  }
380
389
  arrayIntersection(arrA, arrB) {
381
- return arrA.filter(value => -1 !== arrB.indexOf(value));
390
+ return arrA.filter((value) => -1 !== arrB.indexOf(value));
382
391
  }
383
392
  arraysEqual(arrayA, arrayB) {
384
- return arrayA.length === arrayB.length &&
385
- arrayA.every((value, index) => value === arrayB[index]);
393
+ return (arrayA.length === arrayB.length &&
394
+ arrayA.every((value, index) => value === arrayB[index]));
386
395
  }
387
396
  }
388
- SkyListViewGridComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.8", ngImport: i0, type: SkyListViewGridComponent, deps: [{ token: i1.ListState }, { token: i1.ListStateDispatcher }, { token: i2.GridState }, { token: i3.GridStateDispatcher }], target: i0.ɵɵFactoryTarget.Component });
389
- SkyListViewGridComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.8", type: SkyListViewGridComponent, selector: "sky-list-view-grid", inputs: { name: "name", displayedColumns: "displayedColumns", hiddenColumns: "hiddenColumns", fit: "fit", width: "width", height: "height", highlightSearchText: "highlightSearchText", messageStream: "messageStream", rowHighlightedId: "rowHighlightedId", enableMultiselect: "enableMultiselect", settingsKey: "settingsKey", searchFunction: ["search", "searchFunction"] }, outputs: { rowDeleteCancel: "rowDeleteCancel", rowDeleteConfirm: "rowDeleteConfirm", selectedColumnIdsChange: "selectedColumnIdsChange" }, providers: [
397
+ SkyListViewGridComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: SkyListViewGridComponent, deps: [{ token: i1.ListState }, { token: i1.ListStateDispatcher }, { token: i2.GridState }, { token: i3.GridStateDispatcher }], target: i0.ɵɵFactoryTarget.Component });
398
+ SkyListViewGridComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.13", type: SkyListViewGridComponent, selector: "sky-list-view-grid", inputs: { name: "name", displayedColumns: "displayedColumns", hiddenColumns: "hiddenColumns", fit: "fit", width: "width", height: "height", highlightSearchText: "highlightSearchText", messageStream: "messageStream", rowHighlightedId: "rowHighlightedId", enableMultiselect: "enableMultiselect", settingsKey: "settingsKey", searchFunction: ["search", "searchFunction"] }, outputs: { rowDeleteCancel: "rowDeleteCancel", rowDeleteConfirm: "rowDeleteConfirm", selectedColumnIdsChange: "selectedColumnIdsChange" }, providers: [
390
399
  /* tslint:disable */
391
- { provide: ListViewComponent, useExisting: forwardRef(() => SkyListViewGridComponent) },
400
+ {
401
+ provide: ListViewComponent,
402
+ useExisting: forwardRef(() => SkyListViewGridComponent),
403
+ },
392
404
  /* tslint:enable */
393
405
  GridState,
394
406
  GridStateDispatcher,
395
- GridStateModel
396
- ], queries: [{ propertyName: "columnComponents", predicate: SkyGridColumnComponent }], viewQueries: [{ propertyName: "gridComponent", first: true, predicate: SkyGridComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div *ngIf=\"active | async\">\n <sky-grid\n [columns]=\"columns | async\"\n [data]=\"items | async\"\n [enableMultiselect]=\"enableMultiselect\"\n [fit]=\"fit\"\n [height]=\"gridHeight | async\"\n [highlightText]=\"highlightSearchText ? (currentSearchText | async) : undefined\"\n [rowHighlightedId]=\"rowHighlightedId\"\n [messageStream]=\"gridMessageStream\"\n [selectedColumnIds]=\"selectedColumnIds | async\"\n [selectedRowIds]=\"multiselectSelectedIds\"\n [settingsKey]=\"settingsKey\"\n [sortField]=\"sortField | async\"\n [width]=\"gridWidth | async\"\n (multiselectSelectionChange)=\"onMultiselectSelectionChange($event)\"\n (rowDeleteCancel)=\"cancelRowDelete($event)\"\n (rowDeleteConfirm)=\"confirmRowDelete($event)\"\n (selectedColumnIdsChange)=\"columnIdsChanged($event)\"\n (sortFieldChange)=\"sortFieldChanged($event)\"\n #skyGrid\n >\n </sky-grid>\n <sky-wait\n [isWaiting]=\"loading | async\"\n >\n </sky-wait>\n</div>\n", styles: [":host ::ng-deep .sky-grid-heading{border-top:0!important}\n"], components: [{ type: i4.SkyGridComponent, selector: "sky-grid", inputs: ["columns", "data", "enableMultiselect", "fit", "hasToolbar", "height", "highlightText", "messageStream", "multiselectRowId", "rowHighlightedId", "selectedColumnIds", "selectedRowIds", "settingsKey", "sortField", "width"], outputs: ["columnWidthChange", "multiselectSelectionChange", "rowDeleteCancel", "rowDeleteConfirm", "selectedColumnIdsChange", "sortFieldChange"] }, { type: i5.λ14, selector: "sky-wait", inputs: ["ariaLabel", "isWaiting", "isFullPage", "isNonBlocking"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i6.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
397
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.8", ngImport: i0, type: SkyListViewGridComponent, decorators: [{
407
+ GridStateModel,
408
+ ], queries: [{ propertyName: "columnComponents", predicate: SkyGridColumnComponent }], viewQueries: [{ propertyName: "gridComponent", first: true, predicate: SkyGridComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div *ngIf=\"active | async\">\n <sky-grid\n [columns]=\"columns | async\"\n [data]=\"items | async\"\n [enableMultiselect]=\"enableMultiselect\"\n [fit]=\"fit\"\n [height]=\"gridHeight | async\"\n [highlightText]=\"\n highlightSearchText ? (currentSearchText | async) : undefined\n \"\n [rowHighlightedId]=\"rowHighlightedId\"\n [messageStream]=\"gridMessageStream\"\n [selectedColumnIds]=\"selectedColumnIds | async\"\n [selectedRowIds]=\"multiselectSelectedIds\"\n [settingsKey]=\"settingsKey\"\n [sortField]=\"sortField | async\"\n [width]=\"gridWidth | async\"\n (multiselectSelectionChange)=\"onMultiselectSelectionChange($event)\"\n (rowDeleteCancel)=\"cancelRowDelete($event)\"\n (rowDeleteConfirm)=\"confirmRowDelete($event)\"\n (selectedColumnIdsChange)=\"columnIdsChanged($event)\"\n (sortFieldChange)=\"sortFieldChanged($event)\"\n #skyGrid\n >\n </sky-grid>\n <sky-wait [isWaiting]=\"loading | async\"> </sky-wait>\n</div>\n", styles: [":host ::ng-deep .sky-grid-heading{border-top:0!important}\n"], components: [{ type: i4.SkyGridComponent, selector: "sky-grid", inputs: ["columns", "data", "enableMultiselect", "fit", "hasToolbar", "height", "highlightText", "messageStream", "multiselectRowId", "rowHighlightedId", "selectedColumnIds", "selectedRowIds", "settingsKey", "sortField", "width"], outputs: ["columnWidthChange", "multiselectSelectionChange", "rowDeleteCancel", "rowDeleteConfirm", "selectedColumnIdsChange", "sortFieldChange"] }, { type: i5.λ14, selector: "sky-wait", inputs: ["ariaLabel", "isWaiting", "isFullPage", "isNonBlocking"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i6.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
409
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: SkyListViewGridComponent, decorators: [{
398
410
  type: Component,
399
411
  args: [{
400
412
  selector: 'sky-list-view-grid',
@@ -402,13 +414,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.8", ngImpor
402
414
  styleUrls: ['./list-view-grid.component.scss'],
403
415
  providers: [
404
416
  /* tslint:disable */
405
- { provide: ListViewComponent, useExisting: forwardRef(() => SkyListViewGridComponent) },
417
+ {
418
+ provide: ListViewComponent,
419
+ useExisting: forwardRef(() => SkyListViewGridComponent),
420
+ },
406
421
  /* tslint:enable */
407
422
  GridState,
408
423
  GridStateDispatcher,
409
- GridStateModel
424
+ GridStateModel,
410
425
  ],
411
- changeDetection: ChangeDetectionStrategy.OnPush
426
+ changeDetection: ChangeDetectionStrategy.OnPush,
412
427
  }]
413
428
  }], ctorParameters: function () { return [{ type: i1.ListState }, { type: i1.ListStateDispatcher }, { type: i2.GridState }, { type: i3.GridStateDispatcher }]; }, propDecorators: { name: [{
414
429
  type: Input
@@ -448,4 +463,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.8", ngImpor
448
463
  type: ContentChildren,
449
464
  args: [SkyGridColumnComponent]
450
465
  }] } });
451
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-view-grid.component.js","sourceRoot":"","sources":["../../../../../projects/list-builder-view-grids/src/modules/list-view-grid/list-view-grid.component.ts","../../../../../projects/list-builder-view-grids/src/modules/list-view-grid/list-view-grid.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnDestroy,\n  Output,\n  QueryList,\n  ViewChild\n} from '@angular/core';\n\nimport {\n  Observable,\n  of as observableOf,\n  Subject\n} from 'rxjs';\n\nimport {\n  distinctUntilChanged,\n  map as observableMap,\n  scan,\n  take,\n  takeUntil\n} from 'rxjs/operators';\n\nimport {\n  AsyncList,\n  getValue\n} from '@skyux/list-builder-common';\n\nimport {\n  SkyGridColumnComponent,\n  SkyGridColumnHeadingModelChange,\n  SkyGridColumnDescriptionModelChange,\n  SkyGridColumnModel,\n  SkyGridComponent,\n  SkyGridMessage,\n  SkyGridMessageType,\n  SkyGridSelectedRowsModelChange,\n  SkyGridSelectedRowsSource\n} from '@skyux/grids';\n\nimport {\n  ListSearchModel,\n  ListSelectedModel,\n  ListState,\n  ListStateDispatcher,\n  ListViewComponent\n} from '@skyux/list-builder';\n\nimport {\n  getData,\n  isObservable,\n  ListItemModel,\n  ListSortFieldSelectorModel\n} from '@skyux/list-builder-common';\n\nimport {\n  GridState\n} from './state/grid-state.state-node';\n\nimport {\n  GridStateDispatcher\n} from './state/grid-state.rxstate';\n\nimport {\n  GridStateModel\n} from './state/grid-state.model';\n\nimport {\n  ListViewGridColumnsLoadAction\n} from './state/columns/load.action';\n\nimport {\n  ListViewDisplayedGridColumnsLoadAction\n} from './state/displayed-columns/load.action';\n\nimport {\n  SkyListViewGridMessage\n} from './types/list-view-grid-message';\n\nimport {\n  SkyListViewGridMessageType\n} from './types/list-view-grid-message-type';\n\nimport {\n  SkyListViewGridRowDeleteCancelArgs\n} from './types/list-view-grid-row-delete-cancel-args';\n\nimport {\n  SkyListViewGridRowDeleteConfirmArgs\n} from './types/list-view-grid-row-delete-confirm-args';\n\n/**\n * Displays a grid for a\n * [SKY UX-themed list of data](https://developer.blackbaud.com/skyux/components/list/overview)\n * using the [grid component](https://developer.blackbaud.com/skyux/components/grid).\n * You must install `SkyListModule` as a dependency.\n */\n@Component({\n  selector: 'sky-list-view-grid',\n  templateUrl: './list-view-grid.component.html',\n  styleUrls: ['./list-view-grid.component.scss'],\n  providers: [\n    /* tslint:disable */\n    { provide: ListViewComponent, useExisting: forwardRef(() => SkyListViewGridComponent) },\n    /* tslint:enable */\n    GridState,\n    GridStateDispatcher,\n    GridStateModel\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class SkyListViewGridComponent extends ListViewComponent\n  implements AfterContentInit, OnDestroy {\n\n  /**\n   * Specifies the name of the view.\n   * @required\n   */\n  @Input()\n  public set name(value: string) {\n    this.viewName = value;\n  }\n\n  /**\n   * Specifies the columns to display by default based on the ID or field of the item.\n   */\n  @Input()\n  public displayedColumns: Array<string> | Observable<Array<string>>;\n\n  /**\n   * Specifies the columns to hide by default based on the ID or field of the item.\n   */\n  @Input()\n  public hiddenColumns: Array<string> | Observable<Array<string>>;\n\n  /**\n   * Specifies how the grid fits to its parent. `width` fits the grid to the parent's full\n   * width, and `scroll` allows the grid to exceed the parent's width. If the grid does not have\n   * enough columns to fill the parent's width, it always stretches to the parent's full width.\n   * @default width\n   */\n  @Input()\n  public fit: string = 'width';\n\n  /**\n   * Specifies the width of the grid.\n   */\n  @Input()\n  public width: number | Observable<number>;\n\n  /**\n   * Specifies the height of the grid.\n   */\n  @Input()\n  public height: number | Observable<number>;\n\n  /**\n   * Indicates whether to highlight search text within the grid.\n   * @default true\n   */\n  @Input()\n  public highlightSearchText: boolean = true;\n\n  /**\n   * Provides an observable to send commands to the grid.\n   * The commands should respect the `SkyListViewGridMessage` type.\n   */\n  @Input()\n  public set messageStream(stream: Subject<SkyListViewGridMessage>) {\n    /* istanbul ignore else */\n    if (this._messageStream) {\n      this._messageStream.unsubscribe();\n    }\n\n    this._messageStream = stream;\n\n    this.initInlineDeleteMessages();\n  }\n\n  public get messageStream(): Subject<SkyListViewGridMessage> {\n    return this._messageStream;\n  }\n\n  /**\n   * Specifies the ID of the row to highlight. The ID matches the `id` property of\n   * the `data` object. Typically, this property is used in conjunction with the\n   * [flyout component](https://developer.blackbaud.com/skyux/components/flyout) to\n   * indicate the currently selected row.\n   */\n  @Input()\n  public rowHighlightedId: string;\n\n  /**\n   * Indicates whether to enable the multiselect feature to display a column of checkboxes\n   * on the left side of the grid. Multiselect also displays an action bar with buttons to\n   * select and clear all checkboxes. Multiselect defaults to the `id` property on the list's\n   * `data` object.\n   * @default false\n   */\n  @Input()\n  public enableMultiselect: boolean = false;\n\n  /**\n   * Specifies a unique key for the UI Config Service to retrieve stored settings from\n   * a database. The service saves configuration settings for users and returns `selectedColumnIds`\n   * for the columns to display and the preferred column order. For more information, see the\n   * [sticky settings documentation](https://developer.blackbaud.com/skyux/learn/get-started/advanced/sticky-settings).\n   */\n  @Input()\n  public settingsKey: string;\n\n  /**\n   * Fires when users cancel the deletion of a row.\n   */\n  @Output()\n  public rowDeleteCancel = new EventEmitter<SkyListViewGridRowDeleteCancelArgs>();\n\n  /**\n   * Fires when users confirm the deletion of a row.\n   */\n  @Output()\n  public rowDeleteConfirm = new EventEmitter<SkyListViewGridRowDeleteConfirmArgs>();\n\n  /**\n   * Fires when columns change. This includes changes to the displayed columns and changes\n   * to the order of columns. The event emits an array of IDs for the displayed columns that\n   * reflects the column order.\n   */\n  @Output()\n  public selectedColumnIdsChange = new EventEmitter<Array<string>>();\n\n  @ViewChild(SkyGridComponent)\n  public gridComponent: SkyGridComponent;\n\n  public get gridHeight(): Observable<number> {\n    /* istanbul ignore next */\n    return (typeof this.height === 'number')\n      ? observableOf(this.height)\n      : this.height;\n  }\n\n  public get gridWidth(): Observable<number> {\n    /* istanbul ignore next */\n    return (typeof this.width === 'number')\n      ? observableOf(this.width)\n      : this.width;\n  }\n\n  public columns: Observable<Array<SkyGridColumnModel>>;\n\n  public selectedColumnIds: Observable<Array<string>>;\n\n  public items: Observable<ListItemModel[]>;\n\n  /**\n   * Message stream for communicating with the internal grid instance\n   * @interal\n   */\n  public gridMessageStream = new Subject<SkyGridMessage>();\n\n  public loading: Observable<boolean>;\n\n  public sortField: Observable<ListSortFieldSelectorModel>;\n\n  public currentSearchText: Observable<string>;\n\n  public multiselectSelectedIds: string[] = [];\n\n  /**\n   * Specifies a search function to apply on the view data.\n   * @param data Specifies the data to search.\n   * @param searchText Specifies a text string to search for.\n   */\n  // eslint-disable-next-line @angular-eslint/no-input-rename\n  @Input('search')\n  public searchFunction: (data: any, searchText: string) => boolean;\n\n  @ContentChildren(SkyGridColumnComponent)\n  private columnComponents: QueryList<SkyGridColumnComponent>;\n\n  private ngUnsubscribe = new Subject();\n\n  private _messageStream = new Subject<SkyListViewGridMessage>();\n\n  constructor(\n    state: ListState,\n    private dispatcher: ListStateDispatcher,\n    public gridState: GridState,\n    public gridDispatcher: GridStateDispatcher\n  ) {\n    super(state, 'Grid View');\n  }\n\n  public ngAfterContentInit() {\n\n    // Watch for selection changes and update multiselectSelectedIds for local comparison.\n    this.state.pipe(\n      observableMap(s => s.selected.item),\n      takeUntil(this.ngUnsubscribe),\n      distinctUntilChanged(this.selectedMapEqual)\n    )\n      .subscribe((items: ListSelectedModel) => {\n        const selectedIds: string[] = [];\n\n        items.selectedIdMap.forEach((isSelected, id) => {\n          if (items.selectedIdMap.get(id) === true) {\n            selectedIds.push(id);\n          }\n        });\n\n        this.multiselectSelectedIds = selectedIds;\n      });\n\n    /* istanbul ignore next */\n    if (this.columnComponents.length === 0) {\n      throw new Error('Grid view requires at least one sky-grid-column to render.');\n    }\n\n    let columnModels = this.columnComponents.map(columnComponent => {\n      return new SkyGridColumnModel(columnComponent.template, columnComponent);\n    });\n\n    if (this.width && !isObservable(this.width)) {\n      this.width = observableOf(this.width);\n    }\n\n    if (this.height && !isObservable(this.height)) {\n      this.height = observableOf(this.height);\n    }\n\n    // Setup Observables for template\n    this.columns = this.gridState.pipe(\n      observableMap(s => s.columns.items),\n      distinctUntilChanged(this.arraysEqual),\n      takeUntil(this.ngUnsubscribe)\n    );\n\n    this.selectedColumnIds = this.getSelectedIds();\n\n    this.items = this.getGridItems();\n\n    this.loading = this.state.pipe(\n      observableMap((s) => {\n        return s.items.loading;\n      }),\n      distinctUntilChanged(),\n      takeUntil(this.ngUnsubscribe)\n    );\n\n    this.sortField = this.state.pipe(\n      observableMap((s) => {\n        /* istanbul ignore else */\n        /* sanity check */\n        if (s.sort && s.sort.fieldSelectors) {\n          return s.sort.fieldSelectors[0];\n        }\n        /* istanbul ignore next */\n        /* sanity check */\n        return undefined;\n      }),\n      distinctUntilChanged(),\n      takeUntil(this.ngUnsubscribe)\n    );\n\n    this.gridState.pipe(\n      observableMap(s => s.columns.items),\n      takeUntil(this.ngUnsubscribe),\n      distinctUntilChanged(this.arraysEqual)\n    )\n      .subscribe(columns => {\n        /* istanbul ignore else */\n        if (this.hiddenColumns) {\n          getValue(this.hiddenColumns, (hiddenColumns: string[]) => {\n            this.gridDispatcher.next(\n              new ListViewDisplayedGridColumnsLoadAction(\n                columns.filter(x => {\n                  /* istanbul ignore next */\n                  /* sanity check */\n                  let id = x.id || x.field;\n                  return hiddenColumns.indexOf(id) === -1;\n                }),\n                true\n              )\n            );\n          });\n\n        } else if (this.displayedColumns) {\n          /* istanbul ignore next */\n          getValue(this.displayedColumns, (displayedColumns: string[]) => {\n            this.gridDispatcher.next(\n              new ListViewDisplayedGridColumnsLoadAction(\n                columns.filter(x => displayedColumns.indexOf(x.id || x.field) !== -1),\n                true\n              )\n            );\n          });\n\n        } else {\n          this.gridDispatcher.next(\n            new ListViewDisplayedGridColumnsLoadAction(columns.filter(x => !x.hidden), true)\n          );\n        }\n      });\n\n    this.currentSearchText = this.state.pipe(\n      observableMap(s => s.search.searchText),\n      distinctUntilChanged(),\n      takeUntil(this.ngUnsubscribe)\n    );\n\n    this.gridDispatcher.next(new ListViewGridColumnsLoadAction(columnModels, true));\n\n    this.handleColumnChange();\n\n    if (this.enableMultiselect) {\n      this.dispatcher.toolbarShowMultiselectToolbar(true);\n    }\n\n    this.initInlineDeleteMessages();\n  }\n\n  public ngOnDestroy() {\n    this.ngUnsubscribe.next();\n    this.ngUnsubscribe.complete();\n  }\n\n  /**\n   * If user makes selection, tell list-builder to update the list state.\n   * This logic should only run on user interaction - NOT programmatic updates.\n   */\n  public onMultiselectSelectionChange(event: SkyGridSelectedRowsModelChange): void {\n    if (\n      event.source === SkyGridSelectedRowsSource.CheckboxChange ||\n      event.source === SkyGridSelectedRowsSource.RowClick\n    ) {\n    this.state.pipe(\n      observableMap(s => s.items.items),\n      take(1)\n    )\n      .subscribe((items: ListItemModel[]) => {\n        const newItemIds = this.arrayIntersection(items.map(i => i.id), this.multiselectSelectedIds);\n        const newIds = items.filter(i => i.isSelected).map(i => i.id);\n\n        // Check for deselected ids & send message to dispatcher.\n        const deselectedIds = this.arrayDiff(newItemIds, newIds);\n        if (deselectedIds.length > 0) {\n          this.dispatcher.setSelected(deselectedIds, false);\n        }\n\n        // Check for selected ids & send message to dispatcher.\n        const selectedIds = this.arrayDiff(newIds, newItemIds);\n        if (selectedIds.length > 0) {\n          this.dispatcher.setSelected(selectedIds, true);\n        }\n      });\n    }\n  }\n\n  public columnIdsChanged(selectedColumnIds: Array<string>) {\n    this.selectedColumnIds.pipe(take(1))\n      .subscribe(currentIds => {\n        if (!(this.arraysEqual(selectedColumnIds, currentIds))) {\n          this.gridState.pipe(\n            observableMap(s => s.columns.items),\n            take(1)\n          )\n            .subscribe(columns => {\n              let displayedColumns = selectedColumnIds.map(\n                columnId => columns.filter(c => c.id === columnId)[0]\n              );\n              this.gridDispatcher.next(\n                new ListViewDisplayedGridColumnsLoadAction(displayedColumns, true)\n              );\n            });\n        }\n      });\n  }\n\n  public cancelRowDelete(args: SkyListViewGridRowDeleteCancelArgs): void {\n    this.rowDeleteCancel.emit(args);\n  }\n\n  public confirmRowDelete(args: SkyListViewGridRowDeleteConfirmArgs): void {\n    this.rowDeleteConfirm.emit(args);\n  }\n\n  public sortFieldChanged(sortField: ListSortFieldSelectorModel) {\n    this.dispatcher.sortSetFieldSelectors([sortField]);\n  }\n\n  public onViewActive() {\n    /*\n      Ran into problem where state updates were consumed out of order. For example, on search text\n      update, the searchText update was consumed after the resulting list item update. Scanning the\n      previous value of items lastUpdate ensures that we only receive the latest items.\n    */\n    this.gridState.pipe(\n      takeUntil(this.ngUnsubscribe),\n      scan((previousValue: GridStateModel, newValue: GridStateModel) => {\n        if (previousValue.displayedColumns.lastUpdate > newValue.displayedColumns.lastUpdate) {\n          return previousValue;\n        } else {\n          return newValue;\n        }\n      }),\n      observableMap(s => s.displayedColumns.items),\n      distinctUntilChanged(this.arraysEqual)\n    )\n      .subscribe(displayedColumns => {\n        let setFunctions =\n          this.searchFunction !== undefined ? [this.searchFunction] :\n            displayedColumns\n              .map(column => (data: any, searchText: string) =>\n                column.searchFunction(getData(data, column.field), searchText)\n              )\n              .filter(c => c !== undefined);\n\n        this.state.pipe(take(1)).subscribe(s => {\n          this.dispatcher.searchSetOptions(new ListSearchModel({\n            searchText: s.search.searchText,\n            functions: setFunctions,\n            fieldSelectors: displayedColumns.map(d => d.field)\n          }));\n        });\n      });\n  }\n\n  private initInlineDeleteMessages(): void {\n    /* istanbul ignore next */\n    if (this.messageStream) {\n      this.messageStream.subscribe((message: SkyListViewGridMessage) => {\n        if (message.type === SkyListViewGridMessageType.AbortDeleteRow) {\n          this.gridMessageStream.next({\n            type: SkyGridMessageType.AbortDeleteRow,\n            data: {\n              abortDeleteRow: message.data.abortDeleteRow\n            }\n          });\n        } else if (message.type === SkyListViewGridMessageType.PromptDeleteRow) {\n          this.gridMessageStream.next({\n            type: SkyGridMessageType.PromptDeleteRow,\n            data: {\n              promptDeleteRow: message.data.promptDeleteRow\n            }\n          });\n        }\n      });\n    }\n  }\n\n  private handleColumnChange() {\n    // watch for changes in column components\n    this.columnComponents.changes.pipe(\n      takeUntil(this.ngUnsubscribe)\n    )\n      .subscribe((columnComponents) => {\n        let columnModels = this.columnComponents.map(column => {\n          return new SkyGridColumnModel(column.template, column);\n        });\n        this.gridDispatcher.next(new ListViewGridColumnsLoadAction(columnModels, true));\n      });\n\n    // Watch for column heading changes:\n    this.columnComponents.forEach((comp) => {\n      comp.headingModelChanges.pipe(\n        takeUntil(this.ngUnsubscribe)\n      )\n        .subscribe((change: SkyGridColumnHeadingModelChange) => {\n          this.gridComponent.updateColumnHeading(change);\n        });\n      comp.descriptionModelChanges.pipe(\n        takeUntil(this.ngUnsubscribe)\n      )\n        .subscribe((change: SkyGridColumnDescriptionModelChange) => {\n          this.gridComponent.updateColumnDescription(change);\n        });\n    });\n  }\n\n  private getGridItems(): Observable<Array<ListItemModel>> {\n    /*\n      Same problem as above. We should move from having a state object observable with a bunch of\n      static properties to a static state object with observable properties that you can subscribe\n      to.\n    */\n    return this.state.pipe(\n      observableMap((s) => {\n        return s.items;\n      }),\n      scan((previousValue: AsyncList<ListItemModel>, newValue: AsyncList<ListItemModel>) => {\n        if (previousValue.lastUpdate > newValue.lastUpdate) {\n          return previousValue;\n        } else {\n          return newValue;\n        }\n      }),\n      observableMap((result: AsyncList<ListItemModel>) => {\n        return result.items;\n      }),\n      distinctUntilChanged()\n    );\n  }\n\n  private getSelectedIds(): Observable<Array<string>> {\n    /*\n      Same problem as above. We should move from having a state object observable with a bunch of\n      static properties to a static state object with observable properties that you can subscribe\n      to.\n    */\n    return this.gridState.pipe(\n      observableMap(s => s.displayedColumns),\n      scan((previousValue: AsyncList<SkyGridColumnModel>, newValue: AsyncList<SkyGridColumnModel>) => {\n        if (previousValue.lastUpdate > newValue.lastUpdate) {\n          return previousValue;\n        } else {\n          return newValue;\n        }\n      }),\n      observableMap((result: AsyncList<SkyGridColumnModel>) => {\n        /* istanbul ignore next */\n        /* sanity check */\n        return result.items.map((column: SkyGridColumnModel) => {\n          return column.id || column.field;\n        });\n      }),\n      distinctUntilChanged((previousValue: string[], newValue: string[]) => {\n        return this.haveColumnIdsChanged(previousValue, newValue);\n      })\n    );\n  }\n\n  private haveColumnIdsChanged(previousValue: string[], newValue: string[]) {\n    if (previousValue.length !== newValue.length) {\n      this.selectedColumnIdsChange.emit(newValue);\n      return false;\n    }\n\n    for (let i = 0; i < previousValue.length; i++) {\n      /* istanbul ignore if */\n      if (previousValue[i] !== newValue[i]) {\n        this.selectedColumnIdsChange.emit(newValue);\n        return false;\n      }\n    }\n    return true;\n  }\n\n  private selectedMapEqual(prev: ListSelectedModel, next: ListSelectedModel): boolean {\n    if (prev.selectedIdMap.size !== next.selectedIdMap.size) {\n      return false;\n    }\n\n    let keys: string[] = [];\n    next.selectedIdMap.forEach((value, key) => {\n      keys.push(key);\n    });\n\n    for (let i = 0; i < keys.length; i++) {\n      const key = keys[i];\n\n      const value = next.selectedIdMap.get(key);\n      if (value !== prev.selectedIdMap.get(key)) {\n        return false;\n      }\n    }\n\n    return true;\n  }\n\n  private arrayDiff(arrA: Array<any>, arrB: Array<any>): Array<any> {\n    return arrA.filter(i => arrB.indexOf(i) < 0);\n  }\n\n  private arrayIntersection(arrA: Array<any>, arrB: Array<any>): Array<any> {\n    return arrA.filter(value => -1 !== arrB.indexOf(value));\n  }\n\n  private arraysEqual(arrayA: any[], arrayB: any[]) {\n    return arrayA.length === arrayB.length &&\n      arrayA.every((value, index) =>\n        value === arrayB[index]);\n  }\n}\n","<div *ngIf=\"active | async\">\n  <sky-grid\n    [columns]=\"columns | async\"\n    [data]=\"items | async\"\n    [enableMultiselect]=\"enableMultiselect\"\n    [fit]=\"fit\"\n    [height]=\"gridHeight | async\"\n    [highlightText]=\"highlightSearchText ? (currentSearchText | async) : undefined\"\n    [rowHighlightedId]=\"rowHighlightedId\"\n    [messageStream]=\"gridMessageStream\"\n    [selectedColumnIds]=\"selectedColumnIds | async\"\n    [selectedRowIds]=\"multiselectSelectedIds\"\n    [settingsKey]=\"settingsKey\"\n    [sortField]=\"sortField | async\"\n    [width]=\"gridWidth | async\"\n    (multiselectSelectionChange)=\"onMultiselectSelectionChange($event)\"\n    (rowDeleteCancel)=\"cancelRowDelete($event)\"\n    (rowDeleteConfirm)=\"confirmRowDelete($event)\"\n    (selectedColumnIdsChange)=\"columnIdsChanged($event)\"\n    (sortFieldChange)=\"sortFieldChanged($event)\"\n    #skyGrid\n  >\n  </sky-grid>\n  <sky-wait\n    [isWaiting]=\"loading | async\"\n  >\n  </sky-wait>\n</div>\n"]}
466
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-view-grid.component.js","sourceRoot":"","sources":["../../../../../projects/list-builder-view-grids/src/modules/list-view-grid/list-view-grid.component.ts","../../../../../projects/list-builder-view-grids/src/modules/list-view-grid/list-view-grid.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnDestroy,\n  Output,\n  QueryList,\n  ViewChild,\n} from '@angular/core';\n\nimport { Observable, of as observableOf, Subject } from 'rxjs';\n\nimport {\n  distinctUntilChanged,\n  map as observableMap,\n  scan,\n  take,\n  takeUntil,\n} from 'rxjs/operators';\n\nimport { AsyncList, getValue } from '@skyux/list-builder-common';\n\nimport {\n  SkyGridColumnComponent,\n  SkyGridColumnHeadingModelChange,\n  SkyGridColumnDescriptionModelChange,\n  SkyGridColumnModel,\n  SkyGridComponent,\n  SkyGridMessage,\n  SkyGridMessageType,\n  SkyGridSelectedRowsModelChange,\n  SkyGridSelectedRowsSource,\n} from '@skyux/grids';\n\nimport {\n  ListSearchModel,\n  ListSelectedModel,\n  ListState,\n  ListStateDispatcher,\n  ListViewComponent,\n} from '@skyux/list-builder';\n\nimport {\n  getData,\n  isObservable,\n  ListItemModel,\n  ListSortFieldSelectorModel,\n} from '@skyux/list-builder-common';\n\nimport { GridState } from './state/grid-state.state-node';\n\nimport { GridStateDispatcher } from './state/grid-state.rxstate';\n\nimport { GridStateModel } from './state/grid-state.model';\n\nimport { ListViewGridColumnsLoadAction } from './state/columns/load.action';\n\nimport { ListViewDisplayedGridColumnsLoadAction } from './state/displayed-columns/load.action';\n\nimport { SkyListViewGridMessage } from './types/list-view-grid-message';\n\nimport { SkyListViewGridMessageType } from './types/list-view-grid-message-type';\n\nimport { SkyListViewGridRowDeleteCancelArgs } from './types/list-view-grid-row-delete-cancel-args';\n\nimport { SkyListViewGridRowDeleteConfirmArgs } from './types/list-view-grid-row-delete-confirm-args';\n\n/**\n * Displays a grid for a\n * [SKY UX-themed list of data](https://developer.blackbaud.com/skyux/components/list/overview)\n * using the [grid component](https://developer.blackbaud.com/skyux/components/grid).\n * You must install `SkyListModule` as a dependency.\n */\n@Component({\n  selector: 'sky-list-view-grid',\n  templateUrl: './list-view-grid.component.html',\n  styleUrls: ['./list-view-grid.component.scss'],\n  providers: [\n    /* tslint:disable */\n    {\n      provide: ListViewComponent,\n      useExisting: forwardRef(() => SkyListViewGridComponent),\n    },\n    /* tslint:enable */\n    GridState,\n    GridStateDispatcher,\n    GridStateModel,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyListViewGridComponent\n  extends ListViewComponent\n  implements AfterContentInit, OnDestroy\n{\n  /**\n   * Specifies the name of the view.\n   * @required\n   */\n  @Input()\n  public set name(value: string) {\n    this.viewName = value;\n  }\n\n  /**\n   * Specifies the columns to display by default based on the ID or field of the item.\n   */\n  @Input()\n  public displayedColumns: Array<string> | Observable<Array<string>>;\n\n  /**\n   * Specifies the columns to hide by default based on the ID or field of the item.\n   */\n  @Input()\n  public hiddenColumns: Array<string> | Observable<Array<string>>;\n\n  /**\n   * Specifies how the grid fits to its parent. `width` fits the grid to the parent's full\n   * width, and `scroll` allows the grid to exceed the parent's width. If the grid does not have\n   * enough columns to fill the parent's width, it always stretches to the parent's full width.\n   * @default width\n   */\n  @Input()\n  public fit: string = 'width';\n\n  /**\n   * Specifies the width of the grid.\n   */\n  @Input()\n  public width: number | Observable<number>;\n\n  /**\n   * Specifies the height of the grid.\n   */\n  @Input()\n  public height: number | Observable<number>;\n\n  /**\n   * Indicates whether to highlight search text within the grid.\n   * @default true\n   */\n  @Input()\n  public highlightSearchText: boolean = true;\n\n  /**\n   * Provides an observable to send commands to the grid.\n   * The commands should respect the `SkyListViewGridMessage` type.\n   */\n  @Input()\n  public set messageStream(stream: Subject<SkyListViewGridMessage>) {\n    /* istanbul ignore else */\n    if (this._messageStream) {\n      this._messageStream.unsubscribe();\n    }\n\n    this._messageStream = stream;\n\n    this.initInlineDeleteMessages();\n  }\n\n  public get messageStream(): Subject<SkyListViewGridMessage> {\n    return this._messageStream;\n  }\n\n  /**\n   * Specifies the ID of the row to highlight. The ID matches the `id` property of\n   * the `data` object. Typically, this property is used in conjunction with the\n   * [flyout component](https://developer.blackbaud.com/skyux/components/flyout) to\n   * indicate the currently selected row.\n   */\n  @Input()\n  public rowHighlightedId: string;\n\n  /**\n   * Indicates whether to enable the multiselect feature to display a column of checkboxes\n   * on the left side of the grid. Multiselect also displays an action bar with buttons to\n   * select and clear all checkboxes. Multiselect defaults to the `id` property on the list's\n   * `data` object.\n   * @default false\n   */\n  @Input()\n  public enableMultiselect: boolean = false;\n\n  /**\n   * Specifies a unique key for the UI Config Service to retrieve stored settings from\n   * a database. The service saves configuration settings for users and returns `selectedColumnIds`\n   * for the columns to display and the preferred column order. For more information, see the\n   * [sticky settings documentation](https://developer.blackbaud.com/skyux/learn/get-started/advanced/sticky-settings).\n   */\n  @Input()\n  public settingsKey: string;\n\n  /**\n   * Fires when users cancel the deletion of a row.\n   */\n  @Output()\n  public rowDeleteCancel = new EventEmitter<SkyListViewGridRowDeleteCancelArgs>();\n\n  /**\n   * Fires when users confirm the deletion of a row.\n   */\n  @Output()\n  public rowDeleteConfirm = new EventEmitter<SkyListViewGridRowDeleteConfirmArgs>();\n\n  /**\n   * Fires when columns change. This includes changes to the displayed columns and changes\n   * to the order of columns. The event emits an array of IDs for the displayed columns that\n   * reflects the column order.\n   */\n  @Output()\n  public selectedColumnIdsChange = new EventEmitter<Array<string>>();\n\n  @ViewChild(SkyGridComponent)\n  public gridComponent: SkyGridComponent;\n\n  public get gridHeight(): Observable<number> {\n    /* istanbul ignore next */\n    return typeof this.height === 'number'\n      ? observableOf(this.height)\n      : this.height;\n  }\n\n  public get gridWidth(): Observable<number> {\n    /* istanbul ignore next */\n    return typeof this.width === 'number'\n      ? observableOf(this.width)\n      : this.width;\n  }\n\n  public columns: Observable<Array<SkyGridColumnModel>>;\n\n  public selectedColumnIds: Observable<Array<string>>;\n\n  public items: Observable<ListItemModel[]>;\n\n  /**\n   * Message stream for communicating with the internal grid instance\n   * @interal\n   */\n  public gridMessageStream = new Subject<SkyGridMessage>();\n\n  public loading: Observable<boolean>;\n\n  public sortField: Observable<ListSortFieldSelectorModel>;\n\n  public currentSearchText: Observable<string>;\n\n  public multiselectSelectedIds: string[] = [];\n\n  /**\n   * Specifies a search function to apply on the view data.\n   * @param data Specifies the data to search.\n   * @param searchText Specifies a text string to search for.\n   */\n  // eslint-disable-next-line @angular-eslint/no-input-rename\n  @Input('search')\n  public searchFunction: (data: any, searchText: string) => boolean;\n\n  @ContentChildren(SkyGridColumnComponent)\n  private columnComponents: QueryList<SkyGridColumnComponent>;\n\n  private ngUnsubscribe = new Subject();\n\n  private _messageStream = new Subject<SkyListViewGridMessage>();\n\n  constructor(\n    state: ListState,\n    private dispatcher: ListStateDispatcher,\n    public gridState: GridState,\n    public gridDispatcher: GridStateDispatcher\n  ) {\n    super(state, 'Grid View');\n  }\n\n  public ngAfterContentInit() {\n    // Watch for selection changes and update multiselectSelectedIds for local comparison.\n    this.state\n      .pipe(\n        observableMap((s) => s.selected.item),\n        takeUntil(this.ngUnsubscribe),\n        distinctUntilChanged(this.selectedMapEqual)\n      )\n      .subscribe((items: ListSelectedModel) => {\n        const selectedIds: string[] = [];\n\n        items.selectedIdMap.forEach((isSelected, id) => {\n          if (items.selectedIdMap.get(id) === true) {\n            selectedIds.push(id);\n          }\n        });\n\n        this.multiselectSelectedIds = selectedIds;\n      });\n\n    /* istanbul ignore next */\n    if (this.columnComponents.length === 0) {\n      throw new Error(\n        'Grid view requires at least one sky-grid-column to render.'\n      );\n    }\n\n    let columnModels = this.columnComponents.map((columnComponent) => {\n      return new SkyGridColumnModel(columnComponent.template, columnComponent);\n    });\n\n    if (this.width && !isObservable(this.width)) {\n      this.width = observableOf(this.width);\n    }\n\n    if (this.height && !isObservable(this.height)) {\n      this.height = observableOf(this.height);\n    }\n\n    // Setup Observables for template\n    this.columns = this.gridState.pipe(\n      observableMap((s) => s.columns.items),\n      distinctUntilChanged(this.arraysEqual),\n      takeUntil(this.ngUnsubscribe)\n    );\n\n    this.selectedColumnIds = this.getSelectedIds();\n\n    this.items = this.getGridItems();\n\n    this.loading = this.state.pipe(\n      observableMap((s) => {\n        return s.items.loading;\n      }),\n      distinctUntilChanged(),\n      takeUntil(this.ngUnsubscribe)\n    );\n\n    this.sortField = this.state.pipe(\n      observableMap((s) => {\n        /* istanbul ignore else */\n        /* sanity check */\n        if (s.sort && s.sort.fieldSelectors) {\n          return s.sort.fieldSelectors[0];\n        }\n        /* istanbul ignore next */\n        /* sanity check */\n        return undefined;\n      }),\n      distinctUntilChanged(),\n      takeUntil(this.ngUnsubscribe)\n    );\n\n    this.gridState\n      .pipe(\n        observableMap((s) => s.columns.items),\n        takeUntil(this.ngUnsubscribe),\n        distinctUntilChanged(this.arraysEqual)\n      )\n      .subscribe((columns) => {\n        /* istanbul ignore else */\n        if (this.hiddenColumns) {\n          getValue(this.hiddenColumns, (hiddenColumns: string[]) => {\n            this.gridDispatcher.next(\n              new ListViewDisplayedGridColumnsLoadAction(\n                columns.filter((x) => {\n                  /* istanbul ignore next */\n                  /* sanity check */\n                  let id = x.id || x.field;\n                  return hiddenColumns.indexOf(id) === -1;\n                }),\n                true\n              )\n            );\n          });\n        } else if (this.displayedColumns) {\n          /* istanbul ignore next */\n          getValue(this.displayedColumns, (displayedColumns: string[]) => {\n            this.gridDispatcher.next(\n              new ListViewDisplayedGridColumnsLoadAction(\n                columns.filter(\n                  (x) => displayedColumns.indexOf(x.id || x.field) !== -1\n                ),\n                true\n              )\n            );\n          });\n        } else {\n          this.gridDispatcher.next(\n            new ListViewDisplayedGridColumnsLoadAction(\n              columns.filter((x) => !x.hidden),\n              true\n            )\n          );\n        }\n      });\n\n    this.currentSearchText = this.state.pipe(\n      observableMap((s) => s.search.searchText),\n      distinctUntilChanged(),\n      takeUntil(this.ngUnsubscribe)\n    );\n\n    this.gridDispatcher.next(\n      new ListViewGridColumnsLoadAction(columnModels, true)\n    );\n\n    this.handleColumnChange();\n\n    if (this.enableMultiselect) {\n      this.dispatcher.toolbarShowMultiselectToolbar(true);\n    }\n\n    this.initInlineDeleteMessages();\n  }\n\n  public ngOnDestroy() {\n    this.ngUnsubscribe.next();\n    this.ngUnsubscribe.complete();\n  }\n\n  /**\n   * If user makes selection, tell list-builder to update the list state.\n   * This logic should only run on user interaction - NOT programmatic updates.\n   */\n  public onMultiselectSelectionChange(\n    event: SkyGridSelectedRowsModelChange\n  ): void {\n    if (\n      event.source === SkyGridSelectedRowsSource.CheckboxChange ||\n      event.source === SkyGridSelectedRowsSource.RowClick\n    ) {\n      this.state\n        .pipe(\n          observableMap((s) => s.items.items),\n          take(1)\n        )\n        .subscribe((items: ListItemModel[]) => {\n          const newItemIds = this.arrayIntersection(\n            items.map((i) => i.id),\n            this.multiselectSelectedIds\n          );\n          const newIds = items.filter((i) => i.isSelected).map((i) => i.id);\n\n          // Check for deselected ids & send message to dispatcher.\n          const deselectedIds = this.arrayDiff(newItemIds, newIds);\n          if (deselectedIds.length > 0) {\n            this.dispatcher.setSelected(deselectedIds, false);\n          }\n\n          // Check for selected ids & send message to dispatcher.\n          const selectedIds = this.arrayDiff(newIds, newItemIds);\n          if (selectedIds.length > 0) {\n            this.dispatcher.setSelected(selectedIds, true);\n          }\n        });\n    }\n  }\n\n  public columnIdsChanged(selectedColumnIds: Array<string>) {\n    this.selectedColumnIds.pipe(take(1)).subscribe((currentIds) => {\n      if (!this.arraysEqual(selectedColumnIds, currentIds)) {\n        this.gridState\n          .pipe(\n            observableMap((s) => s.columns.items),\n            take(1)\n          )\n          .subscribe((columns) => {\n            let displayedColumns = selectedColumnIds.map(\n              (columnId) => columns.filter((c) => c.id === columnId)[0]\n            );\n            this.gridDispatcher.next(\n              new ListViewDisplayedGridColumnsLoadAction(displayedColumns, true)\n            );\n          });\n      }\n    });\n  }\n\n  public cancelRowDelete(args: SkyListViewGridRowDeleteCancelArgs): void {\n    this.rowDeleteCancel.emit(args);\n  }\n\n  public confirmRowDelete(args: SkyListViewGridRowDeleteConfirmArgs): void {\n    this.rowDeleteConfirm.emit(args);\n  }\n\n  public sortFieldChanged(sortField: ListSortFieldSelectorModel) {\n    this.dispatcher.sortSetFieldSelectors([sortField]);\n  }\n\n  public onViewActive() {\n    /*\n      Ran into problem where state updates were consumed out of order. For example, on search text\n      update, the searchText update was consumed after the resulting list item update. Scanning the\n      previous value of items lastUpdate ensures that we only receive the latest items.\n    */\n    this.gridState\n      .pipe(\n        takeUntil(this.ngUnsubscribe),\n        scan((previousValue: GridStateModel, newValue: GridStateModel) => {\n          if (\n            previousValue.displayedColumns.lastUpdate >\n            newValue.displayedColumns.lastUpdate\n          ) {\n            return previousValue;\n          } else {\n            return newValue;\n          }\n        }),\n        observableMap((s) => s.displayedColumns.items),\n        distinctUntilChanged(this.arraysEqual)\n      )\n      .subscribe((displayedColumns) => {\n        let setFunctions =\n          this.searchFunction !== undefined\n            ? [this.searchFunction]\n            : displayedColumns\n                .map(\n                  (column) => (data: any, searchText: string) =>\n                    column.searchFunction(\n                      getData(data, column.field),\n                      searchText\n                    )\n                )\n                .filter((c) => c !== undefined);\n\n        this.state.pipe(take(1)).subscribe((s) => {\n          this.dispatcher.searchSetOptions(\n            new ListSearchModel({\n              searchText: s.search.searchText,\n              functions: setFunctions,\n              fieldSelectors: displayedColumns.map((d) => d.field),\n            })\n          );\n        });\n      });\n  }\n\n  private initInlineDeleteMessages(): void {\n    /* istanbul ignore next */\n    if (this.messageStream) {\n      this.messageStream.subscribe((message: SkyListViewGridMessage) => {\n        if (message.type === SkyListViewGridMessageType.AbortDeleteRow) {\n          this.gridMessageStream.next({\n            type: SkyGridMessageType.AbortDeleteRow,\n            data: {\n              abortDeleteRow: message.data.abortDeleteRow,\n            },\n          });\n        } else if (\n          message.type === SkyListViewGridMessageType.PromptDeleteRow\n        ) {\n          this.gridMessageStream.next({\n            type: SkyGridMessageType.PromptDeleteRow,\n            data: {\n              promptDeleteRow: message.data.promptDeleteRow,\n            },\n          });\n        }\n      });\n    }\n  }\n\n  private handleColumnChange() {\n    // watch for changes in column components\n    this.columnComponents.changes\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe((columnComponents) => {\n        let columnModels = this.columnComponents.map((column) => {\n          return new SkyGridColumnModel(column.template, column);\n        });\n        this.gridDispatcher.next(\n          new ListViewGridColumnsLoadAction(columnModels, true)\n        );\n      });\n\n    // Watch for column heading changes:\n    this.columnComponents.forEach((comp) => {\n      comp.headingModelChanges\n        .pipe(takeUntil(this.ngUnsubscribe))\n        .subscribe((change: SkyGridColumnHeadingModelChange) => {\n          this.gridComponent.updateColumnHeading(change);\n        });\n      comp.descriptionModelChanges\n        .pipe(takeUntil(this.ngUnsubscribe))\n        .subscribe((change: SkyGridColumnDescriptionModelChange) => {\n          this.gridComponent.updateColumnDescription(change);\n        });\n    });\n  }\n\n  private getGridItems(): Observable<Array<ListItemModel>> {\n    /*\n      Same problem as above. We should move from having a state object observable with a bunch of\n      static properties to a static state object with observable properties that you can subscribe\n      to.\n    */\n    return this.state.pipe(\n      observableMap((s) => {\n        return s.items;\n      }),\n      scan(\n        (\n          previousValue: AsyncList<ListItemModel>,\n          newValue: AsyncList<ListItemModel>\n        ) => {\n          if (previousValue.lastUpdate > newValue.lastUpdate) {\n            return previousValue;\n          } else {\n            return newValue;\n          }\n        }\n      ),\n      observableMap((result: AsyncList<ListItemModel>) => {\n        return result.items;\n      }),\n      distinctUntilChanged()\n    );\n  }\n\n  private getSelectedIds(): Observable<Array<string>> {\n    /*\n      Same problem as above. We should move from having a state object observable with a bunch of\n      static properties to a static state object with observable properties that you can subscribe\n      to.\n    */\n    return this.gridState.pipe(\n      observableMap((s) => s.displayedColumns),\n      scan(\n        (\n          previousValue: AsyncList<SkyGridColumnModel>,\n          newValue: AsyncList<SkyGridColumnModel>\n        ) => {\n          if (previousValue.lastUpdate > newValue.lastUpdate) {\n            return previousValue;\n          } else {\n            return newValue;\n          }\n        }\n      ),\n      observableMap((result: AsyncList<SkyGridColumnModel>) => {\n        /* istanbul ignore next */\n        /* sanity check */\n        return result.items.map((column: SkyGridColumnModel) => {\n          return column.id || column.field;\n        });\n      }),\n      distinctUntilChanged((previousValue: string[], newValue: string[]) => {\n        return this.haveColumnIdsChanged(previousValue, newValue);\n      })\n    );\n  }\n\n  private haveColumnIdsChanged(previousValue: string[], newValue: string[]) {\n    if (previousValue.length !== newValue.length) {\n      this.selectedColumnIdsChange.emit(newValue);\n      return false;\n    }\n\n    for (let i = 0; i < previousValue.length; i++) {\n      /* istanbul ignore if */\n      if (previousValue[i] !== newValue[i]) {\n        this.selectedColumnIdsChange.emit(newValue);\n        return false;\n      }\n    }\n    return true;\n  }\n\n  private selectedMapEqual(\n    prev: ListSelectedModel,\n    next: ListSelectedModel\n  ): boolean {\n    if (prev.selectedIdMap.size !== next.selectedIdMap.size) {\n      return false;\n    }\n\n    let keys: string[] = [];\n    next.selectedIdMap.forEach((value, key) => {\n      keys.push(key);\n    });\n\n    for (let i = 0; i < keys.length; i++) {\n      const key = keys[i];\n\n      const value = next.selectedIdMap.get(key);\n      if (value !== prev.selectedIdMap.get(key)) {\n        return false;\n      }\n    }\n\n    return true;\n  }\n\n  private arrayDiff(arrA: Array<any>, arrB: Array<any>): Array<any> {\n    return arrA.filter((i) => arrB.indexOf(i) < 0);\n  }\n\n  private arrayIntersection(arrA: Array<any>, arrB: Array<any>): Array<any> {\n    return arrA.filter((value) => -1 !== arrB.indexOf(value));\n  }\n\n  private arraysEqual(arrayA: any[], arrayB: any[]) {\n    return (\n      arrayA.length === arrayB.length &&\n      arrayA.every((value, index) => value === arrayB[index])\n    );\n  }\n}\n","<div *ngIf=\"active | async\">\n  <sky-grid\n    [columns]=\"columns | async\"\n    [data]=\"items | async\"\n    [enableMultiselect]=\"enableMultiselect\"\n    [fit]=\"fit\"\n    [height]=\"gridHeight | async\"\n    [highlightText]=\"\n      highlightSearchText ? (currentSearchText | async) : undefined\n    \"\n    [rowHighlightedId]=\"rowHighlightedId\"\n    [messageStream]=\"gridMessageStream\"\n    [selectedColumnIds]=\"selectedColumnIds | async\"\n    [selectedRowIds]=\"multiselectSelectedIds\"\n    [settingsKey]=\"settingsKey\"\n    [sortField]=\"sortField | async\"\n    [width]=\"gridWidth | async\"\n    (multiselectSelectionChange)=\"onMultiselectSelectionChange($event)\"\n    (rowDeleteCancel)=\"cancelRowDelete($event)\"\n    (rowDeleteConfirm)=\"confirmRowDelete($event)\"\n    (selectedColumnIdsChange)=\"columnIdsChanged($event)\"\n    (sortFieldChange)=\"sortFieldChanged($event)\"\n    #skyGrid\n  >\n  </sky-grid>\n  <sky-wait [isWaiting]=\"loading | async\"> </sky-wait>\n</div>\n"]}
@@ -8,37 +8,35 @@ import { SkyListViewGridComponent } from './list-view-grid.component';
8
8
  import * as i0 from "@angular/core";
9
9
  export class SkyListViewGridModule {
10
10
  }
11
- SkyListViewGridModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.8", ngImport: i0, type: SkyListViewGridModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
12
- SkyListViewGridModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.8", ngImport: i0, type: SkyListViewGridModule, declarations: [SkyListViewGridComponent], imports: [CommonModule,
11
+ SkyListViewGridModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: SkyListViewGridModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
12
+ SkyListViewGridModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: SkyListViewGridModule, declarations: [SkyListViewGridComponent], imports: [CommonModule,
13
13
  SkyWaitModule,
14
14
  SkyGridModule,
15
15
  SkyListBuilderViewGridsResourcesModule], exports: [SkyListViewGridComponent,
16
16
  SkyListColumnSelectorActionModule,
17
17
  SkyGridModule] });
18
- SkyListViewGridModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.8", ngImport: i0, type: SkyListViewGridModule, imports: [[
18
+ SkyListViewGridModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: SkyListViewGridModule, imports: [[
19
19
  CommonModule,
20
20
  SkyWaitModule,
21
21
  SkyGridModule,
22
- SkyListBuilderViewGridsResourcesModule
22
+ SkyListBuilderViewGridsResourcesModule,
23
23
  ], SkyListColumnSelectorActionModule,
24
24
  SkyGridModule] });
25
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.8", ngImport: i0, type: SkyListViewGridModule, decorators: [{
25
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: SkyListViewGridModule, decorators: [{
26
26
  type: NgModule,
27
27
  args: [{
28
- declarations: [
29
- SkyListViewGridComponent
30
- ],
28
+ declarations: [SkyListViewGridComponent],
31
29
  imports: [
32
30
  CommonModule,
33
31
  SkyWaitModule,
34
32
  SkyGridModule,
35
- SkyListBuilderViewGridsResourcesModule
33
+ SkyListBuilderViewGridsResourcesModule,
36
34
  ],
37
35
  exports: [
38
36
  SkyListViewGridComponent,
39
37
  SkyListColumnSelectorActionModule,
40
- SkyGridModule
41
- ]
38
+ SkyGridModule,
39
+ ],
42
40
  }]
43
41
  }] });
44
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC12aWV3LWdyaWQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbGlzdC1idWlsZGVyLXZpZXctZ3JpZHMvc3JjL21vZHVsZXMvbGlzdC12aWV3LWdyaWQvbGlzdC12aWV3LWdyaWQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxRQUFRLEVBQ1QsTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUNMLFlBQVksRUFDYixNQUFNLGlCQUFpQixDQUFDO0FBRXpCLE9BQU8sRUFDTCxhQUFhLEVBQ2QsTUFBTSxtQkFBbUIsQ0FBQztBQUUzQixPQUFPLEVBQ0wsYUFBYSxFQUNkLE1BQU0sY0FBYyxDQUFDO0FBRXRCLE9BQU8sRUFDTCxzQ0FBc0MsRUFDdkMsTUFBTSx3REFBd0QsQ0FBQztBQUVoRSxPQUFPLEVBQ0wsaUNBQWlDLEVBQ2xDLE1BQU0sbUVBQW1FLENBQUM7QUFFM0UsT0FBTyxFQUNMLHdCQUF3QixFQUN6QixNQUFNLDRCQUE0QixDQUFDOztBQWtCcEMsTUFBTSxPQUFPLHFCQUFxQjs7a0hBQXJCLHFCQUFxQjttSEFBckIscUJBQXFCLGlCQWQ5Qix3QkFBd0IsYUFHeEIsWUFBWTtRQUNaLGFBQWE7UUFDYixhQUFhO1FBQ2Isc0NBQXNDLGFBR3RDLHdCQUF3QjtRQUN4QixpQ0FBaUM7UUFDakMsYUFBYTttSEFHSixxQkFBcUIsWUFadkI7WUFDUCxZQUFZO1lBQ1osYUFBYTtZQUNiLGFBQWE7WUFDYixzQ0FBc0M7U0FDdkMsRUFHQyxpQ0FBaUM7UUFDakMsYUFBYTsyRkFHSixxQkFBcUI7a0JBaEJqQyxRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWix3QkFBd0I7cUJBQ3pCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGFBQWE7d0JBQ2IsYUFBYTt3QkFDYixzQ0FBc0M7cUJBQ3ZDO29CQUNELE9BQU8sRUFBRTt3QkFDUCx3QkFBd0I7d0JBQ3hCLGlDQUFpQzt3QkFDakMsYUFBYTtxQkFDZDtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIE5nTW9kdWxlXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQge1xuICBDb21tb25Nb2R1bGVcbn0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuaW1wb3J0IHtcbiAgU2t5V2FpdE1vZHVsZVxufSBmcm9tICdAc2t5dXgvaW5kaWNhdG9ycyc7XG5cbmltcG9ydCB7XG4gIFNreUdyaWRNb2R1bGVcbn0gZnJvbSAnQHNreXV4L2dyaWRzJztcblxuaW1wb3J0IHtcbiAgU2t5TGlzdEJ1aWxkZXJWaWV3R3JpZHNSZXNvdXJjZXNNb2R1bGVcbn0gZnJvbSAnLi4vc2hhcmVkL3NreS1saXN0LWJ1aWxkZXItdmlldy1ncmlkcy1yZXNvdXJjZXMubW9kdWxlJztcblxuaW1wb3J0IHtcbiAgU2t5TGlzdENvbHVtblNlbGVjdG9yQWN0aW9uTW9kdWxlXG59IGZyb20gJy4uL2xpc3QtY29sdW1uLXNlbGVjdG9yLWFjdGlvbi9saXN0LWNvbHVtbi1zZWxlY3Rvci1hY3Rpb24ubW9kdWxlJztcblxuaW1wb3J0IHtcbiAgU2t5TGlzdFZpZXdHcmlkQ29tcG9uZW50XG59IGZyb20gJy4vbGlzdC12aWV3LWdyaWQuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgU2t5TGlzdFZpZXdHcmlkQ29tcG9uZW50XG4gIF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgU2t5V2FpdE1vZHVsZSxcbiAgICBTa3lHcmlkTW9kdWxlLFxuICAgIFNreUxpc3RCdWlsZGVyVmlld0dyaWRzUmVzb3VyY2VzTW9kdWxlXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBTa3lMaXN0Vmlld0dyaWRDb21wb25lbnQsXG4gICAgU2t5TGlzdENvbHVtblNlbGVjdG9yQWN0aW9uTW9kdWxlLFxuICAgIFNreUdyaWRNb2R1bGVcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBTa3lMaXN0Vmlld0dyaWRNb2R1bGUgeyB9XG4iXX0=
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC12aWV3LWdyaWQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbGlzdC1idWlsZGVyLXZpZXctZ3JpZHMvc3JjL21vZHVsZXMvbGlzdC12aWV3LWdyaWQvbGlzdC12aWV3LWdyaWQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRS9DLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUVsRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBRTdDLE9BQU8sRUFBRSxzQ0FBc0MsRUFBRSxNQUFNLHdEQUF3RCxDQUFDO0FBRWhILE9BQU8sRUFBRSxpQ0FBaUMsRUFBRSxNQUFNLG1FQUFtRSxDQUFDO0FBRXRILE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDOztBQWdCdEUsTUFBTSxPQUFPLHFCQUFxQjs7bUhBQXJCLHFCQUFxQjtvSEFBckIscUJBQXFCLGlCQWJqQix3QkFBd0IsYUFFckMsWUFBWTtRQUNaLGFBQWE7UUFDYixhQUFhO1FBQ2Isc0NBQXNDLGFBR3RDLHdCQUF3QjtRQUN4QixpQ0FBaUM7UUFDakMsYUFBYTtvSEFHSixxQkFBcUIsWUFadkI7WUFDUCxZQUFZO1lBQ1osYUFBYTtZQUNiLGFBQWE7WUFDYixzQ0FBc0M7U0FDdkMsRUFHQyxpQ0FBaUM7UUFDakMsYUFBYTs0RkFHSixxQkFBcUI7a0JBZGpDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsd0JBQXdCLENBQUM7b0JBQ3hDLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGFBQWE7d0JBQ2IsYUFBYTt3QkFDYixzQ0FBc0M7cUJBQ3ZDO29CQUNELE9BQU8sRUFBRTt3QkFDUCx3QkFBd0I7d0JBQ3hCLGlDQUFpQzt3QkFDakMsYUFBYTtxQkFDZDtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbmltcG9ydCB7IFNreVdhaXRNb2R1bGUgfSBmcm9tICdAc2t5dXgvaW5kaWNhdG9ycyc7XG5cbmltcG9ydCB7IFNreUdyaWRNb2R1bGUgfSBmcm9tICdAc2t5dXgvZ3JpZHMnO1xuXG5pbXBvcnQgeyBTa3lMaXN0QnVpbGRlclZpZXdHcmlkc1Jlc291cmNlc01vZHVsZSB9IGZyb20gJy4uL3NoYXJlZC9za3ktbGlzdC1idWlsZGVyLXZpZXctZ3JpZHMtcmVzb3VyY2VzLm1vZHVsZSc7XG5cbmltcG9ydCB7IFNreUxpc3RDb2x1bW5TZWxlY3RvckFjdGlvbk1vZHVsZSB9IGZyb20gJy4uL2xpc3QtY29sdW1uLXNlbGVjdG9yLWFjdGlvbi9saXN0LWNvbHVtbi1zZWxlY3Rvci1hY3Rpb24ubW9kdWxlJztcblxuaW1wb3J0IHsgU2t5TGlzdFZpZXdHcmlkQ29tcG9uZW50IH0gZnJvbSAnLi9saXN0LXZpZXctZ3JpZC5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtTa3lMaXN0Vmlld0dyaWRDb21wb25lbnRdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIFNreVdhaXRNb2R1bGUsXG4gICAgU2t5R3JpZE1vZHVsZSxcbiAgICBTa3lMaXN0QnVpbGRlclZpZXdHcmlkc1Jlc291cmNlc01vZHVsZSxcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIFNreUxpc3RWaWV3R3JpZENvbXBvbmVudCxcbiAgICBTa3lMaXN0Q29sdW1uU2VsZWN0b3JBY3Rpb25Nb2R1bGUsXG4gICAgU2t5R3JpZE1vZHVsZSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgU2t5TGlzdFZpZXdHcmlkTW9kdWxlIHt9XG4iXX0=
@@ -9,15 +9,14 @@ export class ListViewGridColumnsOrchestrator extends GridStateOrchestrator {
9
9
  /* istanbul ignore next */
10
10
  constructor() {
11
11
  super();
12
- this
13
- .register(ListViewGridColumnsLoadAction, this.load);
12
+ this.register(ListViewGridColumnsLoadAction, this.load);
14
13
  }
15
14
  load(state, action) {
16
- const newColumns = action.columns.map(g => new SkyGridColumnModel(g.template, g));
15
+ const newColumns = action.columns.map((g) => new SkyGridColumnModel(g.template, g));
17
16
  if (action.refresh) {
18
17
  return new AsyncList([...newColumns], new Date());
19
18
  }
20
19
  return new AsyncList([...state.items, ...newColumns], new Date());
21
20
  }
22
21
  }
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sdW1ucy5vcmNoZXN0cmF0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9saXN0LWJ1aWxkZXItdmlldy1ncmlkcy9zcmMvbW9kdWxlcy9saXN0LXZpZXctZ3JpZC9zdGF0ZS9jb2x1bW5zL2NvbHVtbnMub3JjaGVzdHJhdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBRTlELE9BQU8sRUFDTCxTQUFTLEVBQ1YsTUFBTSw0QkFBNEIsQ0FBQztBQUVwQyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFFbEQsT0FBTyxFQUNMLDZCQUE2QixFQUM5QixNQUFNLGVBQWUsQ0FBQztBQUV2Qjs7R0FFRztBQUNILE1BQU0sT0FBTywrQkFDWCxTQUFRLHFCQUFvRDtJQUM1RCwwQkFBMEI7SUFDMUI7UUFDRSxLQUFLLEVBQUUsQ0FBQztRQUVSLElBQUk7YUFDRCxRQUFRLENBQUMsNkJBQTZCLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3hELENBQUM7SUFFTyxJQUFJLENBQ1YsS0FBb0MsRUFDcEMsTUFBcUM7UUFDckMsTUFBTSxVQUFVLEdBQUcsTUFBTSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxJQUFJLGtCQUFrQixDQUFDLENBQUMsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUVsRixJQUFJLE1BQU0sQ0FBQyxPQUFPLEVBQUU7WUFDbEIsT0FBTyxJQUFJLFNBQVMsQ0FBcUIsQ0FBQyxHQUFHLFVBQVUsQ0FBQyxFQUFFLElBQUksSUFBSSxFQUFFLENBQUMsQ0FBQztTQUN2RTtRQUVELE9BQU8sSUFBSSxTQUFTLENBQXFCLENBQUMsR0FBRyxLQUFLLENBQUMsS0FBSyxFQUFFLEdBQUcsVUFBVSxDQUFDLEVBQUUsSUFBSSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQ3hGLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEdyaWRTdGF0ZU9yY2hlc3RyYXRvciB9IGZyb20gJy4uL2dyaWQtc3RhdGUucnhzdGF0ZSc7XG5cbmltcG9ydCB7XG4gIEFzeW5jTGlzdFxufSBmcm9tICdAc2t5dXgvbGlzdC1idWlsZGVyLWNvbW1vbic7XG5cbmltcG9ydCB7IFNreUdyaWRDb2x1bW5Nb2RlbCB9IGZyb20gJ0Bza3l1eC9ncmlkcyc7XG5cbmltcG9ydCB7XG4gIExpc3RWaWV3R3JpZENvbHVtbnNMb2FkQWN0aW9uXG59IGZyb20gJy4vbG9hZC5hY3Rpb24nO1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5leHBvcnQgY2xhc3MgTGlzdFZpZXdHcmlkQ29sdW1uc09yY2hlc3RyYXRvclxuICBleHRlbmRzIEdyaWRTdGF0ZU9yY2hlc3RyYXRvcjxBc3luY0xpc3Q8U2t5R3JpZENvbHVtbk1vZGVsPj4ge1xuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcigpO1xuXG4gICAgdGhpc1xuICAgICAgLnJlZ2lzdGVyKExpc3RWaWV3R3JpZENvbHVtbnNMb2FkQWN0aW9uLCB0aGlzLmxvYWQpO1xuICB9XG5cbiAgcHJpdmF0ZSBsb2FkKFxuICAgIHN0YXRlOiBBc3luY0xpc3Q8U2t5R3JpZENvbHVtbk1vZGVsPixcbiAgICBhY3Rpb246IExpc3RWaWV3R3JpZENvbHVtbnNMb2FkQWN0aW9uKTogQXN5bmNMaXN0PFNreUdyaWRDb2x1bW5Nb2RlbD4ge1xuICAgIGNvbnN0IG5ld0NvbHVtbnMgPSBhY3Rpb24uY29sdW1ucy5tYXAoZyA9PiBuZXcgU2t5R3JpZENvbHVtbk1vZGVsKGcudGVtcGxhdGUsIGcpKTtcblxuICAgIGlmIChhY3Rpb24ucmVmcmVzaCkge1xuICAgICAgcmV0dXJuIG5ldyBBc3luY0xpc3Q8U2t5R3JpZENvbHVtbk1vZGVsPihbLi4ubmV3Q29sdW1uc10sIG5ldyBEYXRlKCkpO1xuICAgIH1cblxuICAgIHJldHVybiBuZXcgQXN5bmNMaXN0PFNreUdyaWRDb2x1bW5Nb2RlbD4oWy4uLnN0YXRlLml0ZW1zLCAuLi5uZXdDb2x1bW5zXSwgbmV3IERhdGUoKSk7XG4gIH1cbn1cbiJdfQ==
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sdW1ucy5vcmNoZXN0cmF0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9saXN0LWJ1aWxkZXItdmlldy1ncmlkcy9zcmMvbW9kdWxlcy9saXN0LXZpZXctZ3JpZC9zdGF0ZS9jb2x1bW5zL2NvbHVtbnMub3JjaGVzdHJhdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBRTlELE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUV2RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFFbEQsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTlEOztHQUVHO0FBQ0gsTUFBTSxPQUFPLCtCQUFnQyxTQUFRLHFCQUVwRDtJQUNDLDBCQUEwQjtJQUMxQjtRQUNFLEtBQUssRUFBRSxDQUFDO1FBRVIsSUFBSSxDQUFDLFFBQVEsQ0FBQyw2QkFBNkIsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDMUQsQ0FBQztJQUVPLElBQUksQ0FDVixLQUFvQyxFQUNwQyxNQUFxQztRQUVyQyxNQUFNLFVBQVUsR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FDbkMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLElBQUksa0JBQWtCLENBQUMsQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUMsQ0FDN0MsQ0FBQztRQUVGLElBQUksTUFBTSxDQUFDLE9BQU8sRUFBRTtZQUNsQixPQUFPLElBQUksU0FBUyxDQUFxQixDQUFDLEdBQUcsVUFBVSxDQUFDLEVBQUUsSUFBSSxJQUFJLEVBQUUsQ0FBQyxDQUFDO1NBQ3ZFO1FBRUQsT0FBTyxJQUFJLFNBQVMsQ0FDbEIsQ0FBQyxHQUFHLEtBQUssQ0FBQyxLQUFLLEVBQUUsR0FBRyxVQUFVLENBQUMsRUFDL0IsSUFBSSxJQUFJLEVBQUUsQ0FDWCxDQUFDO0lBQ0osQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgR3JpZFN0YXRlT3JjaGVzdHJhdG9yIH0gZnJvbSAnLi4vZ3JpZC1zdGF0ZS5yeHN0YXRlJztcblxuaW1wb3J0IHsgQXN5bmNMaXN0IH0gZnJvbSAnQHNreXV4L2xpc3QtYnVpbGRlci1jb21tb24nO1xuXG5pbXBvcnQgeyBTa3lHcmlkQ29sdW1uTW9kZWwgfSBmcm9tICdAc2t5dXgvZ3JpZHMnO1xuXG5pbXBvcnQgeyBMaXN0Vmlld0dyaWRDb2x1bW5zTG9hZEFjdGlvbiB9IGZyb20gJy4vbG9hZC5hY3Rpb24nO1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5leHBvcnQgY2xhc3MgTGlzdFZpZXdHcmlkQ29sdW1uc09yY2hlc3RyYXRvciBleHRlbmRzIEdyaWRTdGF0ZU9yY2hlc3RyYXRvcjxcbiAgQXN5bmNMaXN0PFNreUdyaWRDb2x1bW5Nb2RlbD5cbj4ge1xuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcigpO1xuXG4gICAgdGhpcy5yZWdpc3RlcihMaXN0Vmlld0dyaWRDb2x1bW5zTG9hZEFjdGlvbiwgdGhpcy5sb2FkKTtcbiAgfVxuXG4gIHByaXZhdGUgbG9hZChcbiAgICBzdGF0ZTogQXN5bmNMaXN0PFNreUdyaWRDb2x1bW5Nb2RlbD4sXG4gICAgYWN0aW9uOiBMaXN0Vmlld0dyaWRDb2x1bW5zTG9hZEFjdGlvblxuICApOiBBc3luY0xpc3Q8U2t5R3JpZENvbHVtbk1vZGVsPiB7XG4gICAgY29uc3QgbmV3Q29sdW1ucyA9IGFjdGlvbi5jb2x1bW5zLm1hcChcbiAgICAgIChnKSA9PiBuZXcgU2t5R3JpZENvbHVtbk1vZGVsKGcudGVtcGxhdGUsIGcpXG4gICAgKTtcblxuICAgIGlmIChhY3Rpb24ucmVmcmVzaCkge1xuICAgICAgcmV0dXJuIG5ldyBBc3luY0xpc3Q8U2t5R3JpZENvbHVtbk1vZGVsPihbLi4ubmV3Q29sdW1uc10sIG5ldyBEYXRlKCkpO1xuICAgIH1cblxuICAgIHJldHVybiBuZXcgQXN5bmNMaXN0PFNreUdyaWRDb2x1bW5Nb2RlbD4oXG4gICAgICBbLi4uc3RhdGUuaXRlbXMsIC4uLm5ld0NvbHVtbnNdLFxuICAgICAgbmV3IERhdGUoKVxuICAgICk7XG4gIH1cbn1cbiJdfQ==