@skyux/list-builder-view-grids 4.0.2 → 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 (113) hide show
  1. package/LICENSE +21 -0
  2. package/bundles/skyux-list-builder-view-grids-testing.umd.js +10 -6
  3. package/bundles/skyux-list-builder-view-grids-testing.umd.js.map +1 -1
  4. package/bundles/skyux-list-builder-view-grids.umd.js +794 -529
  5. package/bundles/skyux-list-builder-view-grids.umd.js.map +1 -1
  6. package/documentation.json +2925 -0
  7. package/esm2015/modules/column-selector/column-selector-context.js +1 -1
  8. package/esm2015/modules/column-selector/column-selector-modal.component.js +18 -17
  9. package/esm2015/modules/column-selector/column-selector-modal.module.js +29 -21
  10. package/esm2015/modules/list-column-selector-action/list-column-selector-action.component.js +61 -54
  11. package/esm2015/modules/list-column-selector-action/list-column-selector-action.module.js +34 -21
  12. package/esm2015/modules/list-column-selector-action/list-column-selector-button.component.js +16 -12
  13. package/esm2015/modules/list-view-grid/list-view-grid.component.js +182 -129
  14. package/esm2015/modules/list-view-grid/list-view-grid.module.js +33 -21
  15. package/esm2015/modules/list-view-grid/state/columns/columns.orchestrator.js +6 -4
  16. package/esm2015/modules/list-view-grid/state/columns/load.action.js +4 -1
  17. package/esm2015/modules/list-view-grid/state/displayed-columns/displayed-columns.orchestrator.js +6 -4
  18. package/esm2015/modules/list-view-grid/state/displayed-columns/load.action.js +4 -1
  19. package/esm2015/modules/list-view-grid/state/grid-state-action.type.js +2 -1
  20. package/esm2015/modules/list-view-grid/state/grid-state.model.js +4 -1
  21. package/esm2015/modules/list-view-grid/state/grid-state.rxstate.js +15 -8
  22. package/esm2015/modules/list-view-grid/state/grid-state.state-node.js +15 -16
  23. package/esm2015/modules/list-view-grid/types/list-view-grid-message-type.js +4 -4
  24. package/esm2015/modules/list-view-grid/types/list-view-grid-message.js +2 -1
  25. package/esm2015/modules/list-view-grid/types/list-view-grid-row-delete-cancel-args.js +2 -1
  26. package/esm2015/modules/list-view-grid/types/list-view-grid-row-delete-confirm-args.js +2 -1
  27. package/esm2015/modules/shared/sky-list-builder-view-grids-resources.module.js +56 -0
  28. package/esm2015/public-api.js +21 -0
  29. package/esm2015/skyux-list-builder-view-grids.js +2 -7
  30. package/esm2015/testing/list-view-grid-fixture-cell.js +2 -1
  31. package/esm2015/testing/list-view-grid-fixture-header.js +2 -1
  32. package/esm2015/testing/list-view-grid-fixture-row.js +2 -1
  33. package/esm2015/testing/list-view-grid-fixture.js +4 -4
  34. package/esm2015/testing/public-api.js +5 -0
  35. package/esm2015/testing/skyux-list-builder-view-grids-testing.js +2 -2
  36. package/fesm2015/skyux-list-builder-view-grids-testing.js +3 -3
  37. package/fesm2015/skyux-list-builder-view-grids-testing.js.map +1 -1
  38. package/fesm2015/skyux-list-builder-view-grids.js +449 -302
  39. package/fesm2015/skyux-list-builder-view-grids.js.map +1 -1
  40. package/modules/column-selector/column-selector-modal.component.d.ts +3 -0
  41. package/modules/column-selector/column-selector-modal.module.d.ts +10 -0
  42. package/modules/list-column-selector-action/list-column-selector-action.component.d.ts +18 -0
  43. package/modules/list-column-selector-action/list-column-selector-action.module.d.ts +12 -0
  44. package/modules/list-column-selector-action/list-column-selector-button.component.d.ts +3 -0
  45. package/modules/list-view-grid/list-view-grid.component.d.ts +72 -2
  46. package/modules/list-view-grid/list-view-grid.module.d.ts +10 -0
  47. package/modules/list-view-grid/state/columns/columns.orchestrator.d.ts +3 -0
  48. package/modules/list-view-grid/state/columns/load.action.d.ts +3 -0
  49. package/modules/list-view-grid/state/displayed-columns/displayed-columns.orchestrator.d.ts +3 -0
  50. package/modules/list-view-grid/state/displayed-columns/load.action.d.ts +3 -0
  51. package/modules/list-view-grid/state/grid-state-action.type.d.ts +3 -0
  52. package/modules/list-view-grid/state/grid-state.model.d.ts +3 -0
  53. package/modules/list-view-grid/state/grid-state.rxstate.d.ts +9 -0
  54. package/modules/list-view-grid/state/grid-state.state-node.d.ts +6 -0
  55. package/modules/list-view-grid/types/list-view-grid-message-type.d.ts +3 -3
  56. package/modules/list-view-grid/types/list-view-grid-message.d.ts +3 -3
  57. package/modules/list-view-grid/types/list-view-grid-row-delete-cancel-args.d.ts +3 -0
  58. package/modules/list-view-grid/types/list-view-grid-row-delete-confirm-args.d.ts +3 -0
  59. package/modules/shared/sky-list-builder-view-grids-resources.module.d.ts +14 -0
  60. package/package.json +13 -28
  61. package/{public_api.d.ts → public-api.d.ts} +1 -0
  62. package/skyux-list-builder-view-grids.d.ts +2 -6
  63. package/testing/package.json +2 -5
  64. package/testing/{public_api.d.ts → public-api.d.ts} +0 -0
  65. package/testing/skyux-list-builder-view-grids-testing.d.ts +2 -1
  66. package/CHANGELOG.md +0 -126
  67. package/bundles/skyux-list-builder-view-grids-testing.umd.min.js +0 -2
  68. package/bundles/skyux-list-builder-view-grids-testing.umd.min.js.map +0 -1
  69. package/bundles/skyux-list-builder-view-grids.umd.min.js +0 -16
  70. package/bundles/skyux-list-builder-view-grids.umd.min.js.map +0 -1
  71. package/esm2015/modules/shared/list-view-grid-resources.module.js +0 -17
  72. package/esm2015/plugin-resources/list-view-grid-resources-provider.js +0 -16
  73. package/esm2015/public_api.js +0 -14
  74. package/esm2015/testing/public_api.js +0 -2
  75. package/esm5/modules/column-selector/column-selector-context.js +0 -17
  76. package/esm5/modules/column-selector/column-selector-modal.component.js +0 -40
  77. package/esm5/modules/column-selector/column-selector-modal.module.js +0 -36
  78. package/esm5/modules/list-column-selector-action/list-column-selector-action.component.js +0 -139
  79. package/esm5/modules/list-column-selector-action/list-column-selector-action.module.js +0 -37
  80. package/esm5/modules/list-column-selector-action/list-column-selector-button.component.js +0 -16
  81. package/esm5/modules/list-view-grid/list-view-grid.component.js +0 -444
  82. package/esm5/modules/list-view-grid/list-view-grid.module.js +0 -33
  83. package/esm5/modules/list-view-grid/state/columns/columns.orchestrator.js +0 -25
  84. package/esm5/modules/list-view-grid/state/columns/load.action.js +0 -10
  85. package/esm5/modules/list-view-grid/state/displayed-columns/displayed-columns.orchestrator.js +0 -25
  86. package/esm5/modules/list-view-grid/state/displayed-columns/load.action.js +0 -10
  87. package/esm5/modules/list-view-grid/state/grid-state-action.type.js +0 -1
  88. package/esm5/modules/list-view-grid/state/grid-state.model.js +0 -10
  89. package/esm5/modules/list-view-grid/state/grid-state.rxstate.js +0 -23
  90. package/esm5/modules/list-view-grid/state/grid-state.state-node.js +0 -29
  91. package/esm5/modules/list-view-grid/types/list-view-grid-message-type.js +0 -15
  92. package/esm5/modules/list-view-grid/types/list-view-grid-message.js +0 -1
  93. package/esm5/modules/list-view-grid/types/list-view-grid-row-delete-cancel-args.js +0 -1
  94. package/esm5/modules/list-view-grid/types/list-view-grid-row-delete-confirm-args.js +0 -1
  95. package/esm5/modules/shared/list-view-grid-resources.module.js +0 -20
  96. package/esm5/plugin-resources/list-view-grid-resources-provider.js +0 -17
  97. package/esm5/public_api.js +0 -14
  98. package/esm5/skyux-list-builder-view-grids.js +0 -10
  99. package/esm5/testing/list-view-grid-fixture-cell.js +0 -1
  100. package/esm5/testing/list-view-grid-fixture-header.js +0 -1
  101. package/esm5/testing/list-view-grid-fixture-row.js +0 -1
  102. package/esm5/testing/list-view-grid-fixture.js +0 -68
  103. package/esm5/testing/public_api.js +0 -2
  104. package/esm5/testing/skyux-list-builder-view-grids-testing.js +0 -5
  105. package/fesm5/skyux-list-builder-view-grids-testing.js +0 -74
  106. package/fesm5/skyux-list-builder-view-grids-testing.js.map +0 -1
  107. package/fesm5/skyux-list-builder-view-grids.js +0 -864
  108. package/fesm5/skyux-list-builder-view-grids.js.map +0 -1
  109. package/modules/shared/list-view-grid-resources.module.d.ts +0 -2
  110. package/plugin-resources/list-view-grid-resources-provider.d.ts +0 -5
  111. package/skyux-list-builder-view-grids.metadata.json +0 -1
  112. package/src/assets/locales/resources_en_US.json +0 -26
  113. package/testing/skyux-list-builder-view-grids-testing.metadata.json +0 -1
@@ -1,444 +0,0 @@
1
- import { __decorate, __extends } from "tslib";
2
- import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, forwardRef, Input, Output, ViewChild } from '@angular/core';
3
- import { of as observableOf, Subject } from 'rxjs';
4
- import { distinctUntilChanged, map as observableMap, scan, take, takeUntil } from 'rxjs/operators';
5
- import { getValue } from '@skyux/list-builder-common';
6
- import { SkyGridColumnComponent, SkyGridColumnModel, SkyGridComponent, SkyGridMessageType, SkyGridSelectedRowsSource } from '@skyux/grids';
7
- import { ListSearchModel, ListSelectedModel, ListState, ListStateDispatcher, ListViewComponent } from '@skyux/list-builder';
8
- import { getData, isObservable } from '@skyux/list-builder-common';
9
- import { GridState } from './state/grid-state.state-node';
10
- import { GridStateDispatcher } from './state/grid-state.rxstate';
11
- import { GridStateModel } from './state/grid-state.model';
12
- import { ListViewGridColumnsLoadAction } from './state/columns/load.action';
13
- import { ListViewDisplayedGridColumnsLoadAction } from './state/displayed-columns/load.action';
14
- import { SkyListViewGridMessageType } from './types/list-view-grid-message-type';
15
- var SkyListViewGridComponent = /** @class */ (function (_super) {
16
- __extends(SkyListViewGridComponent, _super);
17
- function SkyListViewGridComponent(state, dispatcher, gridState, gridDispatcher) {
18
- var _this = _super.call(this, state, 'Grid View') || this;
19
- _this.dispatcher = dispatcher;
20
- _this.gridState = gridState;
21
- _this.gridDispatcher = gridDispatcher;
22
- _this.fit = 'width';
23
- _this.highlightSearchText = true;
24
- _this.enableMultiselect = false;
25
- _this.rowDeleteCancel = new EventEmitter();
26
- _this.rowDeleteConfirm = new EventEmitter();
27
- _this.selectedColumnIdsChange = new EventEmitter();
28
- /**
29
- * Message stream for communicating with the internal grid instance
30
- * @interal
31
- */
32
- _this.gridMessageStream = new Subject();
33
- _this.multiselectSelectedIds = [];
34
- _this.ngUnsubscribe = new Subject();
35
- _this._messageStream = new Subject();
36
- return _this;
37
- }
38
- SkyListViewGridComponent_1 = SkyListViewGridComponent;
39
- Object.defineProperty(SkyListViewGridComponent.prototype, "name", {
40
- set: function (value) {
41
- this.viewName = value;
42
- },
43
- enumerable: true,
44
- configurable: true
45
- });
46
- Object.defineProperty(SkyListViewGridComponent.prototype, "messageStream", {
47
- get: function () {
48
- return this._messageStream;
49
- },
50
- /**
51
- * Provides an observable to send commands to the grid.
52
- * The commands should respect the `SkyListViewGridMessage` type. (See below.)
53
- */
54
- set: function (stream) {
55
- if (this._messageStream) {
56
- this._messageStream.unsubscribe();
57
- }
58
- this._messageStream = stream;
59
- this.initInlineDeleteMessages();
60
- },
61
- enumerable: true,
62
- configurable: true
63
- });
64
- Object.defineProperty(SkyListViewGridComponent.prototype, "gridHeight", {
65
- get: function () {
66
- return (typeof this.height === 'number')
67
- /* istanbul ignore next */
68
- ? observableOf(this.height)
69
- : this.height;
70
- },
71
- enumerable: true,
72
- configurable: true
73
- });
74
- Object.defineProperty(SkyListViewGridComponent.prototype, "gridWidth", {
75
- get: function () {
76
- /* istanbul ignore next */
77
- return (typeof this.width === 'number')
78
- ? observableOf(this.width)
79
- : this.width;
80
- },
81
- enumerable: true,
82
- configurable: true
83
- });
84
- SkyListViewGridComponent.prototype.ngAfterContentInit = function () {
85
- var _this = this;
86
- // Watch for selection changes and update multiselectSelectedIds for local comparison.
87
- this.state.pipe(observableMap(function (s) { return s.selected.item; }), takeUntil(this.ngUnsubscribe), distinctUntilChanged(this.selectedMapEqual))
88
- .subscribe(function (items) {
89
- var selectedIds = [];
90
- items.selectedIdMap.forEach(function (isSelected, id) {
91
- if (items.selectedIdMap.get(id) === true) {
92
- selectedIds.push(id);
93
- }
94
- });
95
- _this.multiselectSelectedIds = selectedIds;
96
- });
97
- if (this.columnComponents.length === 0) {
98
- throw new Error('Grid view requires at least one sky-grid-column to render.');
99
- }
100
- var columnModels = this.columnComponents.map(function (columnComponent) {
101
- return new SkyGridColumnModel(columnComponent.template, columnComponent);
102
- });
103
- if (this.width && !isObservable(this.width)) {
104
- this.width = observableOf(this.width);
105
- }
106
- if (this.height && !isObservable(this.height)) {
107
- this.height = observableOf(this.height);
108
- }
109
- // Setup Observables for template
110
- this.columns = this.gridState.pipe(observableMap(function (s) { return s.columns.items; }), distinctUntilChanged(this.arraysEqual), takeUntil(this.ngUnsubscribe));
111
- this.selectedColumnIds = this.getSelectedIds();
112
- this.items = this.getGridItems();
113
- this.loading = this.state.pipe(observableMap(function (s) {
114
- return s.items.loading;
115
- }), distinctUntilChanged(), takeUntil(this.ngUnsubscribe));
116
- this.sortField = this.state.pipe(observableMap(function (s) {
117
- /* istanbul ignore else */
118
- /* sanity check */
119
- if (s.sort && s.sort.fieldSelectors) {
120
- return s.sort.fieldSelectors[0];
121
- }
122
- /* istanbul ignore next */
123
- /* sanity check */
124
- return undefined;
125
- }), distinctUntilChanged(), takeUntil(this.ngUnsubscribe));
126
- this.gridState.pipe(observableMap(function (s) { return s.columns.items; }), takeUntil(this.ngUnsubscribe), distinctUntilChanged(this.arraysEqual))
127
- .subscribe(function (columns) {
128
- if (_this.hiddenColumns) {
129
- getValue(_this.hiddenColumns, function (hiddenColumns) {
130
- _this.gridDispatcher.next(new ListViewDisplayedGridColumnsLoadAction(columns.filter(function (x) {
131
- /* istanbul ignore next */
132
- /* sanity check */
133
- var id = x.id || x.field;
134
- return hiddenColumns.indexOf(id) === -1;
135
- }), true));
136
- });
137
- }
138
- else if (_this.displayedColumns) {
139
- getValue(_this.displayedColumns, function (displayedColumns) {
140
- _this.gridDispatcher.next(new ListViewDisplayedGridColumnsLoadAction(columns.filter(function (x) { return displayedColumns.indexOf(x.id || x.field) !== -1; }), true));
141
- });
142
- }
143
- else {
144
- _this.gridDispatcher.next(new ListViewDisplayedGridColumnsLoadAction(columns.filter(function (x) { return !x.hidden; }), true));
145
- }
146
- });
147
- this.currentSearchText = this.state.pipe(observableMap(function (s) { return s.search.searchText; }), distinctUntilChanged(), takeUntil(this.ngUnsubscribe));
148
- this.gridDispatcher.next(new ListViewGridColumnsLoadAction(columnModels, true));
149
- this.handleColumnChange();
150
- if (this.enableMultiselect) {
151
- this.dispatcher.toolbarShowMultiselectToolbar(true);
152
- }
153
- this.initInlineDeleteMessages();
154
- };
155
- SkyListViewGridComponent.prototype.ngOnDestroy = function () {
156
- this.ngUnsubscribe.next();
157
- this.ngUnsubscribe.complete();
158
- };
159
- /**
160
- * If user makes selection, tell list-builder to update the list state.
161
- * This logic should only run on user interaction - NOT programmatic updates.
162
- */
163
- SkyListViewGridComponent.prototype.onMultiselectSelectionChange = function (event) {
164
- var _this = this;
165
- if (event.source === SkyGridSelectedRowsSource.CheckboxChange ||
166
- event.source === SkyGridSelectedRowsSource.RowClick) {
167
- this.state.pipe(observableMap(function (s) { return s.items.items; }), take(1))
168
- .subscribe(function (items) {
169
- var newItemIds = _this.arrayIntersection(items.map(function (i) { return i.id; }), _this.multiselectSelectedIds);
170
- var newIds = items.filter(function (i) { return i.isSelected; }).map(function (i) { return i.id; });
171
- // Check for deselected ids & send message to dispatcher.
172
- var deselectedIds = _this.arrayDiff(newItemIds, newIds);
173
- if (deselectedIds.length > 0) {
174
- _this.dispatcher.setSelected(deselectedIds, false);
175
- }
176
- // Check for selected ids & send message to dispatcher.
177
- var selectedIds = _this.arrayDiff(newIds, newItemIds);
178
- if (selectedIds.length > 0) {
179
- _this.dispatcher.setSelected(selectedIds, true);
180
- }
181
- });
182
- }
183
- };
184
- SkyListViewGridComponent.prototype.columnIdsChanged = function (selectedColumnIds) {
185
- var _this = this;
186
- this.selectedColumnIds.pipe(take(1))
187
- .subscribe(function (currentIds) {
188
- if (!(_this.arraysEqual(selectedColumnIds, currentIds))) {
189
- _this.gridState.pipe(observableMap(function (s) { return s.columns.items; }), take(1))
190
- .subscribe(function (columns) {
191
- var displayedColumns = selectedColumnIds.map(function (columnId) { return columns.filter(function (c) { return c.id === columnId; })[0]; });
192
- _this.gridDispatcher.next(new ListViewDisplayedGridColumnsLoadAction(displayedColumns, true));
193
- });
194
- }
195
- });
196
- };
197
- SkyListViewGridComponent.prototype.cancelRowDelete = function (args) {
198
- this.rowDeleteCancel.emit(args);
199
- };
200
- SkyListViewGridComponent.prototype.confirmRowDelete = function (args) {
201
- this.rowDeleteConfirm.emit(args);
202
- };
203
- SkyListViewGridComponent.prototype.sortFieldChanged = function (sortField) {
204
- this.dispatcher.sortSetFieldSelectors([sortField]);
205
- };
206
- SkyListViewGridComponent.prototype.onViewActive = function () {
207
- var _this = this;
208
- /*
209
- Ran into problem where state updates were consumed out of order. For example, on search text
210
- update, the searchText update was consumed after the resulting list item update. Scanning the
211
- previous value of items lastUpdate ensures that we only receive the latest items.
212
- */
213
- this.gridState.pipe(takeUntil(this.ngUnsubscribe), scan(function (previousValue, newValue) {
214
- if (previousValue.displayedColumns.lastUpdate > newValue.displayedColumns.lastUpdate) {
215
- return previousValue;
216
- }
217
- else {
218
- return newValue;
219
- }
220
- }), observableMap(function (s) { return s.displayedColumns.items; }), distinctUntilChanged(this.arraysEqual))
221
- .subscribe(function (displayedColumns) {
222
- var setFunctions = _this.searchFunction !== undefined ? [_this.searchFunction] :
223
- displayedColumns
224
- .map(function (column) { return function (data, searchText) {
225
- return column.searchFunction(getData(data, column.field), searchText);
226
- }; })
227
- .filter(function (c) { return c !== undefined; });
228
- _this.state.pipe(take(1)).subscribe(function (s) {
229
- _this.dispatcher.searchSetOptions(new ListSearchModel({
230
- searchText: s.search.searchText,
231
- functions: setFunctions,
232
- fieldSelectors: displayedColumns.map(function (d) { return d.field; })
233
- }));
234
- });
235
- });
236
- };
237
- SkyListViewGridComponent.prototype.initInlineDeleteMessages = function () {
238
- var _this = this;
239
- if (this.messageStream) {
240
- this.messageStream.subscribe(function (message) {
241
- if (message.type === SkyListViewGridMessageType.AbortDeleteRow) {
242
- _this.gridMessageStream.next({
243
- type: SkyGridMessageType.AbortDeleteRow,
244
- data: {
245
- abortDeleteRow: message.data.abortDeleteRow
246
- }
247
- });
248
- }
249
- else if (message.type === SkyListViewGridMessageType.PromptDeleteRow) {
250
- _this.gridMessageStream.next({
251
- type: SkyGridMessageType.PromptDeleteRow,
252
- data: {
253
- promptDeleteRow: message.data.promptDeleteRow
254
- }
255
- });
256
- }
257
- });
258
- }
259
- };
260
- SkyListViewGridComponent.prototype.handleColumnChange = function () {
261
- var _this = this;
262
- // watch for changes in column components
263
- this.columnComponents.changes.pipe(takeUntil(this.ngUnsubscribe))
264
- .subscribe(function (columnComponents) {
265
- var columnModels = _this.columnComponents.map(function (column) {
266
- return new SkyGridColumnModel(column.template, column);
267
- });
268
- _this.gridDispatcher.next(new ListViewGridColumnsLoadAction(columnModels, true));
269
- });
270
- // Watch for column heading changes:
271
- this.columnComponents.forEach(function (comp) {
272
- comp.headingModelChanges.pipe(takeUntil(_this.ngUnsubscribe))
273
- .subscribe(function (change) {
274
- _this.gridComponent.updateColumnHeading(change);
275
- });
276
- comp.descriptionModelChanges.pipe(takeUntil(_this.ngUnsubscribe))
277
- .subscribe(function (change) {
278
- _this.gridComponent.updateColumnDescription(change);
279
- });
280
- });
281
- };
282
- SkyListViewGridComponent.prototype.getGridItems = function () {
283
- /*
284
- Same problem as above. We should move from having a state object observable with a bunch of
285
- static properties to a static state object with observable properties that you can subscribe
286
- to.
287
- */
288
- return this.state.pipe(observableMap(function (s) {
289
- return s.items;
290
- }), scan(function (previousValue, newValue) {
291
- if (previousValue.lastUpdate > newValue.lastUpdate) {
292
- return previousValue;
293
- }
294
- else {
295
- return newValue;
296
- }
297
- }), observableMap(function (result) {
298
- return result.items;
299
- }), distinctUntilChanged());
300
- };
301
- SkyListViewGridComponent.prototype.getSelectedIds = function () {
302
- var _this = this;
303
- /*
304
- Same problem as above. We should move from having a state object observable with a bunch of
305
- static properties to a static state object with observable properties that you can subscribe
306
- to.
307
- */
308
- return this.gridState.pipe(observableMap(function (s) { return s.displayedColumns; }), scan(function (previousValue, newValue) {
309
- if (previousValue.lastUpdate > newValue.lastUpdate) {
310
- return previousValue;
311
- }
312
- else {
313
- return newValue;
314
- }
315
- }), observableMap(function (result) {
316
- /* istanbul ignore next */
317
- /* sanity check */
318
- return result.items.map(function (column) {
319
- return column.id || column.field;
320
- });
321
- }), distinctUntilChanged(function (previousValue, newValue) {
322
- return _this.haveColumnIdsChanged(previousValue, newValue);
323
- }));
324
- };
325
- SkyListViewGridComponent.prototype.haveColumnIdsChanged = function (previousValue, newValue) {
326
- if (previousValue.length !== newValue.length) {
327
- this.selectedColumnIdsChange.emit(newValue);
328
- return false;
329
- }
330
- for (var i = 0; i < previousValue.length; i++) {
331
- if (previousValue[i] !== newValue[i]) {
332
- this.selectedColumnIdsChange.emit(newValue);
333
- return false;
334
- }
335
- }
336
- return true;
337
- };
338
- SkyListViewGridComponent.prototype.selectedMapEqual = function (prev, next) {
339
- if (prev.selectedIdMap.size !== next.selectedIdMap.size) {
340
- return false;
341
- }
342
- var keys = [];
343
- next.selectedIdMap.forEach(function (value, key) {
344
- keys.push(key);
345
- });
346
- for (var i = 0; i < keys.length; i++) {
347
- var key = keys[i];
348
- var value = next.selectedIdMap.get(key);
349
- if (value !== prev.selectedIdMap.get(key)) {
350
- return false;
351
- }
352
- }
353
- return true;
354
- };
355
- SkyListViewGridComponent.prototype.arrayDiff = function (arrA, arrB) {
356
- return arrA.filter(function (i) { return arrB.indexOf(i) < 0; });
357
- };
358
- SkyListViewGridComponent.prototype.arrayIntersection = function (arrA, arrB) {
359
- return arrA.filter(function (value) { return -1 !== arrB.indexOf(value); });
360
- };
361
- SkyListViewGridComponent.prototype.arraysEqual = function (arrayA, arrayB) {
362
- return arrayA.length === arrayB.length &&
363
- arrayA.every(function (value, index) {
364
- return value === arrayB[index];
365
- });
366
- };
367
- var SkyListViewGridComponent_1;
368
- SkyListViewGridComponent.ctorParameters = function () { return [
369
- { type: ListState },
370
- { type: ListStateDispatcher },
371
- { type: GridState },
372
- { type: GridStateDispatcher }
373
- ]; };
374
- __decorate([
375
- Input()
376
- ], SkyListViewGridComponent.prototype, "name", null);
377
- __decorate([
378
- Input()
379
- ], SkyListViewGridComponent.prototype, "displayedColumns", void 0);
380
- __decorate([
381
- Input()
382
- ], SkyListViewGridComponent.prototype, "hiddenColumns", void 0);
383
- __decorate([
384
- Input()
385
- ], SkyListViewGridComponent.prototype, "fit", void 0);
386
- __decorate([
387
- Input()
388
- ], SkyListViewGridComponent.prototype, "width", void 0);
389
- __decorate([
390
- Input()
391
- ], SkyListViewGridComponent.prototype, "height", void 0);
392
- __decorate([
393
- Input()
394
- ], SkyListViewGridComponent.prototype, "highlightSearchText", void 0);
395
- __decorate([
396
- Input()
397
- ], SkyListViewGridComponent.prototype, "messageStream", null);
398
- __decorate([
399
- Input()
400
- ], SkyListViewGridComponent.prototype, "rowHighlightedId", void 0);
401
- __decorate([
402
- Input()
403
- ], SkyListViewGridComponent.prototype, "enableMultiselect", void 0);
404
- __decorate([
405
- Input()
406
- ], SkyListViewGridComponent.prototype, "settingsKey", void 0);
407
- __decorate([
408
- Output()
409
- ], SkyListViewGridComponent.prototype, "rowDeleteCancel", void 0);
410
- __decorate([
411
- Output()
412
- ], SkyListViewGridComponent.prototype, "rowDeleteConfirm", void 0);
413
- __decorate([
414
- Output()
415
- ], SkyListViewGridComponent.prototype, "selectedColumnIdsChange", void 0);
416
- __decorate([
417
- ViewChild(SkyGridComponent)
418
- ], SkyListViewGridComponent.prototype, "gridComponent", void 0);
419
- __decorate([
420
- Input('search')
421
- ], SkyListViewGridComponent.prototype, "searchFunction", void 0);
422
- __decorate([
423
- ContentChildren(SkyGridColumnComponent)
424
- ], SkyListViewGridComponent.prototype, "columnComponents", void 0);
425
- SkyListViewGridComponent = SkyListViewGridComponent_1 = __decorate([
426
- Component({
427
- selector: 'sky-list-view-grid',
428
- 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",
429
- providers: [
430
- /* tslint:disable */
431
- { provide: ListViewComponent, useExisting: forwardRef(function () { return SkyListViewGridComponent_1; }) },
432
- /* tslint:enable */
433
- GridState,
434
- GridStateDispatcher,
435
- GridStateModel
436
- ],
437
- changeDetection: ChangeDetectionStrategy.OnPush,
438
- styles: [":host ::ng-deep .sky-grid-heading{border-top:0!important}"]
439
- })
440
- ], SkyListViewGridComponent);
441
- return SkyListViewGridComponent;
442
- }(ListViewComponent));
443
- export { SkyListViewGridComponent };
444
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-view-grid.component.js","sourceRoot":"ng://@skyux/list-builder-view-grids/","sources":["modules/list-view-grid/list-view-grid.component.ts"],"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@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  @Input()\n  public set name(value: string) {\n    this.viewName = value;\n  }\n\n  @Input()\n  public displayedColumns: Array<string> | Observable<Array<string>>;\n\n  @Input()\n  public hiddenColumns: Array<string> | Observable<Array<string>>;\n\n  @Input()\n  public fit: string = 'width';\n\n  @Input()\n  public width: number | Observable<number>;\n\n  @Input()\n  public height: number | Observable<number>;\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. (See below.)\n   */\n  @Input()\n  public set messageStream(stream: Subject<SkyListViewGridMessage>) {\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  @Input()\n  public rowHighlightedId: string;\n\n  @Input()\n  public enableMultiselect: boolean = false;\n\n  @Input()\n  public settingsKey: string;\n\n  @Output()\n  public rowDeleteCancel = new EventEmitter<SkyListViewGridRowDeleteCancelArgs>();\n\n  @Output()\n  public rowDeleteConfirm = new EventEmitter<SkyListViewGridRowDeleteConfirmArgs>();\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    return (typeof this.height === 'number')\n      /* istanbul ignore next */\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  /* tslint:disable */\n  @Input('search')\n  private searchFunction: (data: any, searchText: string) => boolean;\n  /* tslint:enable */\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    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        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          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    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      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"]}
@@ -1,33 +0,0 @@
1
- import { __decorate } from "tslib";
2
- import { NgModule } from '@angular/core';
3
- import { CommonModule } from '@angular/common';
4
- import { SkyWaitModule } from '@skyux/indicators';
5
- import { SkyGridModule } from '@skyux/grids';
6
- import { SkyListViewGridResourcesModule } from '../shared/list-view-grid-resources.module';
7
- import { SkyListColumnSelectorActionModule } from '../list-column-selector-action/list-column-selector-action.module';
8
- import { SkyListViewGridComponent } from './list-view-grid.component';
9
- var SkyListViewGridModule = /** @class */ (function () {
10
- function SkyListViewGridModule() {
11
- }
12
- SkyListViewGridModule = __decorate([
13
- NgModule({
14
- declarations: [
15
- SkyListViewGridComponent
16
- ],
17
- imports: [
18
- CommonModule,
19
- SkyWaitModule,
20
- SkyGridModule,
21
- SkyListViewGridResourcesModule
22
- ],
23
- exports: [
24
- SkyListViewGridComponent,
25
- SkyListColumnSelectorActionModule,
26
- SkyGridModule
27
- ]
28
- })
29
- ], SkyListViewGridModule);
30
- return SkyListViewGridModule;
31
- }());
32
- export { SkyListViewGridModule };
33
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC12aWV3LWdyaWQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNreXV4L2xpc3QtYnVpbGRlci12aWV3LWdyaWRzLyIsInNvdXJjZXMiOlsibW9kdWxlcy9saXN0LXZpZXctZ3JpZC9saXN0LXZpZXctZ3JpZC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFDTCxRQUFRLEVBQ1QsTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUNMLFlBQVksRUFDYixNQUFNLGlCQUFpQixDQUFDO0FBRXpCLE9BQU8sRUFDTCxhQUFhLEVBQ2QsTUFBTSxtQkFBbUIsQ0FBQztBQUUzQixPQUFPLEVBQ0wsYUFBYSxFQUNkLE1BQU0sY0FBYyxDQUFDO0FBRXRCLE9BQU8sRUFDTCw4QkFBOEIsRUFDL0IsTUFBTSwyQ0FBMkMsQ0FBQztBQUVuRCxPQUFPLEVBQ0wsaUNBQWlDLEVBQ2xDLE1BQU0sbUVBQW1FLENBQUM7QUFFM0UsT0FBTyxFQUNMLHdCQUF3QixFQUN6QixNQUFNLDRCQUE0QixDQUFDO0FBa0JwQztJQUFBO0lBQXFDLENBQUM7SUFBekIscUJBQXFCO1FBaEJqQyxRQUFRLENBQUM7WUFDUixZQUFZLEVBQUU7Z0JBQ1osd0JBQXdCO2FBQ3pCO1lBQ0QsT0FBTyxFQUFFO2dCQUNQLFlBQVk7Z0JBQ1osYUFBYTtnQkFDYixhQUFhO2dCQUNiLDhCQUE4QjthQUMvQjtZQUNELE9BQU8sRUFBRTtnQkFDUCx3QkFBd0I7Z0JBQ3hCLGlDQUFpQztnQkFDakMsYUFBYTthQUNkO1NBQ0YsQ0FBQztPQUNXLHFCQUFxQixDQUFJO0lBQUQsNEJBQUM7Q0FBQSxBQUF0QyxJQUFzQztTQUF6QixxQkFBcUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBOZ01vZHVsZVxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHtcbiAgQ29tbW9uTW9kdWxlXG59IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbmltcG9ydCB7XG4gIFNreVdhaXRNb2R1bGVcbn0gZnJvbSAnQHNreXV4L2luZGljYXRvcnMnO1xuXG5pbXBvcnQge1xuICBTa3lHcmlkTW9kdWxlXG59IGZyb20gJ0Bza3l1eC9ncmlkcyc7XG5cbmltcG9ydCB7XG4gIFNreUxpc3RWaWV3R3JpZFJlc291cmNlc01vZHVsZVxufSBmcm9tICcuLi9zaGFyZWQvbGlzdC12aWV3LWdyaWQtcmVzb3VyY2VzLm1vZHVsZSc7XG5cbmltcG9ydCB7XG4gIFNreUxpc3RDb2x1bW5TZWxlY3RvckFjdGlvbk1vZHVsZVxufSBmcm9tICcuLi9saXN0LWNvbHVtbi1zZWxlY3Rvci1hY3Rpb24vbGlzdC1jb2x1bW4tc2VsZWN0b3ItYWN0aW9uLm1vZHVsZSc7XG5cbmltcG9ydCB7XG4gIFNreUxpc3RWaWV3R3JpZENvbXBvbmVudFxufSBmcm9tICcuL2xpc3Qtdmlldy1ncmlkLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1xuICAgIFNreUxpc3RWaWV3R3JpZENvbXBvbmVudFxuICBdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIFNreVdhaXRNb2R1bGUsXG4gICAgU2t5R3JpZE1vZHVsZSxcbiAgICBTa3lMaXN0Vmlld0dyaWRSZXNvdXJjZXNNb2R1bGVcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIFNreUxpc3RWaWV3R3JpZENvbXBvbmVudCxcbiAgICBTa3lMaXN0Q29sdW1uU2VsZWN0b3JBY3Rpb25Nb2R1bGUsXG4gICAgU2t5R3JpZE1vZHVsZVxuICBdXG59KVxuZXhwb3J0IGNsYXNzIFNreUxpc3RWaWV3R3JpZE1vZHVsZSB7IH1cbiJdfQ==
@@ -1,25 +0,0 @@
1
- import { __extends, __read, __spread } from "tslib";
2
- import { GridStateOrchestrator } from '../grid-state.rxstate';
3
- import { AsyncList } from '@skyux/list-builder-common';
4
- import { SkyGridColumnModel } from '@skyux/grids';
5
- import { ListViewGridColumnsLoadAction } from './load.action';
6
- var ListViewGridColumnsOrchestrator = /** @class */ (function (_super) {
7
- __extends(ListViewGridColumnsOrchestrator, _super);
8
- /* istanbul ignore next */
9
- function ListViewGridColumnsOrchestrator() {
10
- var _this = _super.call(this) || this;
11
- _this
12
- .register(ListViewGridColumnsLoadAction, _this.load);
13
- return _this;
14
- }
15
- ListViewGridColumnsOrchestrator.prototype.load = function (state, action) {
16
- var newColumns = action.columns.map(function (g) { return new SkyGridColumnModel(g.template, g); });
17
- if (action.refresh) {
18
- return new AsyncList(__spread(newColumns), new Date());
19
- }
20
- return new AsyncList(__spread(state.items, newColumns), new Date());
21
- };
22
- return ListViewGridColumnsOrchestrator;
23
- }(GridStateOrchestrator));
24
- export { ListViewGridColumnsOrchestrator };
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sdW1ucy5vcmNoZXN0cmF0b3IuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2t5dXgvbGlzdC1idWlsZGVyLXZpZXctZ3JpZHMvIiwic291cmNlcyI6WyJtb2R1bGVzL2xpc3Qtdmlldy1ncmlkL3N0YXRlL2NvbHVtbnMvY29sdW1ucy5vcmNoZXN0cmF0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBRTlELE9BQU8sRUFDTCxTQUFTLEVBQ1YsTUFBTSw0QkFBNEIsQ0FBQztBQUVwQyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFFbEQsT0FBTyxFQUNMLDZCQUE2QixFQUM5QixNQUFNLGVBQWUsQ0FBQztBQUV2QjtJQUNVLG1EQUFvRDtJQUM1RCwwQkFBMEI7SUFDMUI7UUFBQSxZQUNFLGlCQUFPLFNBSVI7UUFGQyxLQUFJO2FBQ0QsUUFBUSxDQUFDLDZCQUE2QixFQUFFLEtBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQzs7SUFDeEQsQ0FBQztJQUVPLDhDQUFJLEdBQVosVUFDRSxLQUFvQyxFQUNwQyxNQUFxQztRQUNyQyxJQUFNLFVBQVUsR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxVQUFBLENBQUMsSUFBSSxPQUFBLElBQUksa0JBQWtCLENBQUMsQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUMsRUFBckMsQ0FBcUMsQ0FBQyxDQUFDO1FBRWxGLElBQUksTUFBTSxDQUFDLE9BQU8sRUFBRTtZQUNsQixPQUFPLElBQUksU0FBUyxVQUF5QixVQUFVLEdBQUcsSUFBSSxJQUFJLEVBQUUsQ0FBQyxDQUFDO1NBQ3ZFO1FBRUQsT0FBTyxJQUFJLFNBQVMsVUFBeUIsS0FBSyxDQUFDLEtBQUssRUFBSyxVQUFVLEdBQUcsSUFBSSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQ3hGLENBQUM7SUFDSCxzQ0FBQztBQUFELENBQUMsQUFyQkQsQ0FDVSxxQkFBcUIsR0FvQjlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgR3JpZFN0YXRlT3JjaGVzdHJhdG9yIH0gZnJvbSAnLi4vZ3JpZC1zdGF0ZS5yeHN0YXRlJztcblxuaW1wb3J0IHtcbiAgQXN5bmNMaXN0XG59IGZyb20gJ0Bza3l1eC9saXN0LWJ1aWxkZXItY29tbW9uJztcblxuaW1wb3J0IHsgU2t5R3JpZENvbHVtbk1vZGVsIH0gZnJvbSAnQHNreXV4L2dyaWRzJztcblxuaW1wb3J0IHtcbiAgTGlzdFZpZXdHcmlkQ29sdW1uc0xvYWRBY3Rpb25cbn0gZnJvbSAnLi9sb2FkLmFjdGlvbic7XG5cbmV4cG9ydCBjbGFzcyBMaXN0Vmlld0dyaWRDb2x1bW5zT3JjaGVzdHJhdG9yXG4gIGV4dGVuZHMgR3JpZFN0YXRlT3JjaGVzdHJhdG9yPEFzeW5jTGlzdDxTa3lHcmlkQ29sdW1uTW9kZWw+PiB7XG4gIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHN1cGVyKCk7XG5cbiAgICB0aGlzXG4gICAgICAucmVnaXN0ZXIoTGlzdFZpZXdHcmlkQ29sdW1uc0xvYWRBY3Rpb24sIHRoaXMubG9hZCk7XG4gIH1cblxuICBwcml2YXRlIGxvYWQoXG4gICAgc3RhdGU6IEFzeW5jTGlzdDxTa3lHcmlkQ29sdW1uTW9kZWw+LFxuICAgIGFjdGlvbjogTGlzdFZpZXdHcmlkQ29sdW1uc0xvYWRBY3Rpb24pOiBBc3luY0xpc3Q8U2t5R3JpZENvbHVtbk1vZGVsPiB7XG4gICAgY29uc3QgbmV3Q29sdW1ucyA9IGFjdGlvbi5jb2x1bW5zLm1hcChnID0+IG5ldyBTa3lHcmlkQ29sdW1uTW9kZWwoZy50ZW1wbGF0ZSwgZykpO1xuXG4gICAgaWYgKGFjdGlvbi5yZWZyZXNoKSB7XG4gICAgICByZXR1cm4gbmV3IEFzeW5jTGlzdDxTa3lHcmlkQ29sdW1uTW9kZWw+KFsuLi5uZXdDb2x1bW5zXSwgbmV3IERhdGUoKSk7XG4gICAgfVxuXG4gICAgcmV0dXJuIG5ldyBBc3luY0xpc3Q8U2t5R3JpZENvbHVtbk1vZGVsPihbLi4uc3RhdGUuaXRlbXMsIC4uLm5ld0NvbHVtbnNdLCBuZXcgRGF0ZSgpKTtcbiAgfVxufVxuIl19
@@ -1,10 +0,0 @@
1
- var ListViewGridColumnsLoadAction = /** @class */ (function () {
2
- function ListViewGridColumnsLoadAction(columns, refresh) {
3
- if (refresh === void 0) { refresh = false; }
4
- this.columns = columns;
5
- this.refresh = refresh;
6
- }
7
- return ListViewGridColumnsLoadAction;
8
- }());
9
- export { ListViewGridColumnsLoadAction };
10
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZC5hY3Rpb24uanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2t5dXgvbGlzdC1idWlsZGVyLXZpZXctZ3JpZHMvIiwic291cmNlcyI6WyJtb2R1bGVzL2xpc3Qtdmlldy1ncmlkL3N0YXRlL2NvbHVtbnMvbG9hZC5hY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUE7SUFDRSx1Q0FDUyxPQUFrQyxFQUNsQyxPQUF3QjtRQUF4Qix3QkFBQSxFQUFBLGVBQXdCO1FBRHhCLFlBQU8sR0FBUCxPQUFPLENBQTJCO1FBQ2xDLFlBQU8sR0FBUCxPQUFPLENBQWlCO0lBRWpDLENBQUM7SUFDSCxvQ0FBQztBQUFELENBQUMsQUFORCxJQU1DIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2t5R3JpZENvbHVtbk1vZGVsIH0gZnJvbSAnQHNreXV4L2dyaWRzJztcblxuZXhwb3J0IGNsYXNzIExpc3RWaWV3R3JpZENvbHVtbnNMb2FkQWN0aW9uIHtcbiAgY29uc3RydWN0b3IoXG4gICAgcHVibGljIGNvbHVtbnM6IEFycmF5PFNreUdyaWRDb2x1bW5Nb2RlbD4sXG4gICAgcHVibGljIHJlZnJlc2g6IGJvb2xlYW4gPSBmYWxzZVxuICApIHtcbiAgfVxufVxuIl19
@@ -1,25 +0,0 @@
1
- import { __extends, __read, __spread } from "tslib";
2
- import { GridStateOrchestrator } from '../grid-state.rxstate';
3
- import { AsyncList } from '@skyux/list-builder-common';
4
- import { SkyGridColumnModel } from '@skyux/grids';
5
- import { ListViewDisplayedGridColumnsLoadAction } from './load.action';
6
- var ListViewDisplayedGridColumnsOrchestrator = /** @class */ (function (_super) {
7
- __extends(ListViewDisplayedGridColumnsOrchestrator, _super);
8
- /* istanbul ignore next */
9
- function ListViewDisplayedGridColumnsOrchestrator() {
10
- var _this = _super.call(this) || this;
11
- _this
12
- .register(ListViewDisplayedGridColumnsLoadAction, _this.load);
13
- return _this;
14
- }
15
- ListViewDisplayedGridColumnsOrchestrator.prototype.load = function (state, action) {
16
- var newColumns = action.columns.map(function (g) { return new SkyGridColumnModel(g.template, g); });
17
- if (action.refresh) {
18
- return new AsyncList(__spread(newColumns), new Date());
19
- }
20
- return new AsyncList(__spread(state.items, newColumns), new Date());
21
- };
22
- return ListViewDisplayedGridColumnsOrchestrator;
23
- }(GridStateOrchestrator));
24
- export { ListViewDisplayedGridColumnsOrchestrator };
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzcGxheWVkLWNvbHVtbnMub3JjaGVzdHJhdG9yLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNreXV4L2xpc3QtYnVpbGRlci12aWV3LWdyaWRzLyIsInNvdXJjZXMiOlsibW9kdWxlcy9saXN0LXZpZXctZ3JpZC9zdGF0ZS9kaXNwbGF5ZWQtY29sdW1ucy9kaXNwbGF5ZWQtY29sdW1ucy5vcmNoZXN0cmF0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBRTlELE9BQU8sRUFDTCxTQUFTLEVBQ1YsTUFBTSw0QkFBNEIsQ0FBQztBQUVwQyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFFbEQsT0FBTyxFQUNMLHNDQUFzQyxFQUN2QyxNQUFNLGVBQWUsQ0FBQztBQUV2QjtJQUNVLDREQUFvRDtJQUM1RCwwQkFBMEI7SUFDMUI7UUFBQSxZQUNFLGlCQUFPLFNBSVI7UUFGQyxLQUFJO2FBQ0QsUUFBUSxDQUFDLHNDQUFzQyxFQUFFLEtBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQzs7SUFDakUsQ0FBQztJQUVPLHVEQUFJLEdBQVosVUFDRSxLQUFvQyxFQUNwQyxNQUE4QztRQUM5QyxJQUFNLFVBQVUsR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxVQUFBLENBQUMsSUFBSSxPQUFBLElBQUksa0JBQWtCLENBQUMsQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUMsRUFBckMsQ0FBcUMsQ0FBQyxDQUFDO1FBRWxGLElBQUksTUFBTSxDQUFDLE9BQU8sRUFBRTtZQUNsQixPQUFPLElBQUksU0FBUyxVQUF5QixVQUFVLEdBQUcsSUFBSSxJQUFJLEVBQUUsQ0FBQyxDQUFDO1NBQ3ZFO1FBRUQsT0FBTyxJQUFJLFNBQVMsVUFBeUIsS0FBSyxDQUFDLEtBQUssRUFBSyxVQUFVLEdBQUcsSUFBSSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQ3hGLENBQUM7SUFDSCwrQ0FBQztBQUFELENBQUMsQUFyQkQsQ0FDVSxxQkFBcUIsR0FvQjlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgR3JpZFN0YXRlT3JjaGVzdHJhdG9yIH0gZnJvbSAnLi4vZ3JpZC1zdGF0ZS5yeHN0YXRlJztcblxuaW1wb3J0IHtcbiAgQXN5bmNMaXN0XG59IGZyb20gJ0Bza3l1eC9saXN0LWJ1aWxkZXItY29tbW9uJztcblxuaW1wb3J0IHsgU2t5R3JpZENvbHVtbk1vZGVsIH0gZnJvbSAnQHNreXV4L2dyaWRzJztcblxuaW1wb3J0IHtcbiAgTGlzdFZpZXdEaXNwbGF5ZWRHcmlkQ29sdW1uc0xvYWRBY3Rpb25cbn0gZnJvbSAnLi9sb2FkLmFjdGlvbic7XG5cbmV4cG9ydCBjbGFzcyBMaXN0Vmlld0Rpc3BsYXllZEdyaWRDb2x1bW5zT3JjaGVzdHJhdG9yXG4gIGV4dGVuZHMgR3JpZFN0YXRlT3JjaGVzdHJhdG9yPEFzeW5jTGlzdDxTa3lHcmlkQ29sdW1uTW9kZWw+PiB7XG4gIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHN1cGVyKCk7XG5cbiAgICB0aGlzXG4gICAgICAucmVnaXN0ZXIoTGlzdFZpZXdEaXNwbGF5ZWRHcmlkQ29sdW1uc0xvYWRBY3Rpb24sIHRoaXMubG9hZCk7XG4gIH1cblxuICBwcml2YXRlIGxvYWQoXG4gICAgc3RhdGU6IEFzeW5jTGlzdDxTa3lHcmlkQ29sdW1uTW9kZWw+LFxuICAgIGFjdGlvbjogTGlzdFZpZXdEaXNwbGF5ZWRHcmlkQ29sdW1uc0xvYWRBY3Rpb24pOiBBc3luY0xpc3Q8U2t5R3JpZENvbHVtbk1vZGVsPiB7XG4gICAgY29uc3QgbmV3Q29sdW1ucyA9IGFjdGlvbi5jb2x1bW5zLm1hcChnID0+IG5ldyBTa3lHcmlkQ29sdW1uTW9kZWwoZy50ZW1wbGF0ZSwgZykpO1xuXG4gICAgaWYgKGFjdGlvbi5yZWZyZXNoKSB7XG4gICAgICByZXR1cm4gbmV3IEFzeW5jTGlzdDxTa3lHcmlkQ29sdW1uTW9kZWw+KFsuLi5uZXdDb2x1bW5zXSwgbmV3IERhdGUoKSk7XG4gICAgfVxuXG4gICAgcmV0dXJuIG5ldyBBc3luY0xpc3Q8U2t5R3JpZENvbHVtbk1vZGVsPihbLi4uc3RhdGUuaXRlbXMsIC4uLm5ld0NvbHVtbnNdLCBuZXcgRGF0ZSgpKTtcbiAgfVxufVxuIl19