@skyux/tiles 7.0.0-beta.9 → 7.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (24) hide show
  1. package/documentation.json +402 -203
  2. package/esm2020/lib/modules/shared/sky-tiles-resources.module.mjs +5 -5
  3. package/esm2020/lib/modules/tiles/tile/tile-summary.component.mjs +4 -4
  4. package/esm2020/lib/modules/tiles/tile/tile-title.component.mjs +4 -4
  5. package/esm2020/lib/modules/tiles/tile/tile.component.mjs +36 -32
  6. package/esm2020/lib/modules/tiles/tile/tile.module.mjs +5 -5
  7. package/esm2020/lib/modules/tiles/tile-content/tile-content-section.component.mjs +4 -4
  8. package/esm2020/lib/modules/tiles/tile-content/tile-content.component.mjs +4 -4
  9. package/esm2020/lib/modules/tiles/tile-content/tile-content.module.mjs +5 -5
  10. package/esm2020/lib/modules/tiles/tile-dashboard/tile-dashboard.component.mjs +45 -35
  11. package/esm2020/lib/modules/tiles/tile-dashboard/tile-dashboard.module.mjs +5 -5
  12. package/esm2020/lib/modules/tiles/tile-dashboard/tile-dashboard.service.mjs +353 -327
  13. package/esm2020/lib/modules/tiles/tile-dashboard-column/tile-dashboard-column.component.mjs +15 -14
  14. package/esm2020/lib/modules/tiles/tile-dashboard-column/tile-dashboard-column.module.mjs +5 -5
  15. package/esm2020/lib/modules/tiles/tiles.module.mjs +5 -5
  16. package/fesm2015/skyux-tiles.mjs +486 -433
  17. package/fesm2015/skyux-tiles.mjs.map +1 -1
  18. package/fesm2020/skyux-tiles.mjs +475 -433
  19. package/fesm2020/skyux-tiles.mjs.map +1 -1
  20. package/lib/modules/tiles/tile/tile.component.d.ts +5 -9
  21. package/lib/modules/tiles/tile-dashboard/tile-dashboard.component.d.ts +8 -14
  22. package/lib/modules/tiles/tile-dashboard/tile-dashboard.service.d.ts +7 -36
  23. package/lib/modules/tiles/tile-dashboard-column/tile-dashboard-column.component.d.ts +4 -5
  24. package/package.json +8 -8
@@ -1,6 +1,7 @@
1
- import { EventEmitter, Injectable, Injector, Output, } from '@angular/core';
2
- import { SkyMediaBreakpoints, SkyMediaQueryService, SkyUIConfigService, } from '@skyux/core';
3
- import { DragulaService } from 'ng2-dragula';
1
+ var _SkyTileDashboardService_instances, _SkyTileDashboardService_columns, _SkyTileDashboardService_config, _SkyTileDashboardService_dragulaService, _SkyTileDashboardService_dynamicComponentService, _SkyTileDashboardService_mediaSubscription, _SkyTileDashboardService_mediaQuery, _SkyTileDashboardService_singleColumn, _SkyTileDashboardService_settingsKey, _SkyTileDashboardService_tileComponents, _SkyTileDashboardService_uiConfigService, _SkyTileDashboardService_getTileId, _SkyTileDashboardService_getTileOrRemoveFromLayout, _SkyTileDashboardService_checkReadyAndLoadTiles, _SkyTileDashboardService_loadTiles, _SkyTileDashboardService_loadTileIntoColumn, _SkyTileDashboardService_moveTilesToSingleColumn, _SkyTileDashboardService_moveTilesToMultiColumn, _SkyTileDashboardService_moveTilesToColumn, _SkyTileDashboardService_getConfigForUIState, _SkyTileDashboardService_getSingleColumnLayoutForUIState, _SkyTileDashboardService_getMultiColumnLayoutForUIState, _SkyTileDashboardService_getTilesInEl, _SkyTileDashboardService_initMediaQueries, _SkyTileDashboardService_initDragula, _SkyTileDashboardService_getColumnEl, _SkyTileDashboardService_findTile, _SkyTileDashboardService_findTileColumn, _SkyTileDashboardService_initToDefaults, _SkyTileDashboardService_setUserConfig, _SkyTileDashboardService_checkForNewTiles;
2
+ import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
3
+ import { EventEmitter, Injectable, Optional, Output, } from '@angular/core';
4
+ import { SkyDynamicComponentLocation, SkyMediaBreakpoints, } from '@skyux/core';
4
5
  import { take } from 'rxjs/operators';
5
6
  import * as i0 from "@angular/core";
6
7
  import * as i1 from "ng2-dragula";
@@ -8,10 +9,9 @@ import * as i2 from "@skyux/core";
8
9
  const ATTR_TILE_ID = '_sky-tile-dashboard-tile-id';
9
10
  let bagIdIndex = 0;
10
11
  export class SkyTileDashboardService {
11
- constructor(dragulaService, mediaQuery, uiConfigService) {
12
- this.dragulaService = dragulaService;
13
- this.mediaQuery = mediaQuery;
14
- this.uiConfigService = uiConfigService;
12
+ // TODO: remove @optional tag in a future breaking change
13
+ constructor(dragulaService, mediaQuery, uiConfigService, dynamicComponentService) {
14
+ _SkyTileDashboardService_instances.add(this);
15
15
  /**
16
16
  * @internal
17
17
  */
@@ -20,8 +20,25 @@ export class SkyTileDashboardService {
20
20
  * Fires when the tile dashboard's initialization is complete.
21
21
  */
22
22
  this.dashboardInitialized = new EventEmitter();
23
- this.bagId = 'sky-tile-dashboard-bag-' + ++bagIdIndex;
24
- this.initDragula();
23
+ _SkyTileDashboardService_columns.set(this, void 0);
24
+ _SkyTileDashboardService_config.set(this, void 0);
25
+ _SkyTileDashboardService_dragulaService.set(this, void 0);
26
+ _SkyTileDashboardService_dynamicComponentService.set(this, void 0);
27
+ _SkyTileDashboardService_mediaSubscription.set(this, void 0);
28
+ _SkyTileDashboardService_mediaQuery.set(this, void 0);
29
+ _SkyTileDashboardService_singleColumn.set(this, void 0);
30
+ _SkyTileDashboardService_settingsKey.set(this, void 0);
31
+ _SkyTileDashboardService_tileComponents.set(this, void 0);
32
+ _SkyTileDashboardService_uiConfigService.set(this, void 0);
33
+ if (!dynamicComponentService) {
34
+ console.warn('The SkyTileDashboardService was created without a reference to the SkyDynamicComponentService. The service will be unable to create tiles from the dashboard configuration. Constructing the SkyTileDashboardService without a SkyDynamicComponentService will be removed in a future breaking change.');
35
+ }
36
+ __classPrivateFieldSet(this, _SkyTileDashboardService_dragulaService, dragulaService, "f");
37
+ __classPrivateFieldSet(this, _SkyTileDashboardService_dynamicComponentService, dynamicComponentService, "f");
38
+ __classPrivateFieldSet(this, _SkyTileDashboardService_mediaQuery, mediaQuery, "f");
39
+ __classPrivateFieldSet(this, _SkyTileDashboardService_uiConfigService, uiConfigService, "f");
40
+ this.bagId = `sky-tile-dashboard-bag-${++bagIdIndex}`;
41
+ __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_initDragula).call(this);
25
42
  }
26
43
  /**
27
44
  * @internal
@@ -30,31 +47,31 @@ export class SkyTileDashboardService {
30
47
  if (settingsKey) {
31
48
  // Clone this so changes to the config object outside of this class don't modify
32
49
  // the config used inside and vice versa.
33
- this.defaultConfig = this.config = Object.assign({}, config);
34
- this.settingsKey = settingsKey;
35
- this.uiConfigService
50
+ __classPrivateFieldSet(this, _SkyTileDashboardService_config, Object.assign({}, config), "f");
51
+ __classPrivateFieldSet(this, _SkyTileDashboardService_settingsKey, settingsKey, "f");
52
+ __classPrivateFieldGet(this, _SkyTileDashboardService_uiConfigService, "f")
36
53
  .getConfig(settingsKey, config)
37
54
  .pipe(take(1))
38
55
  .subscribe((value) => {
39
- if (value.persisted) {
40
- this.config.layout = value.layout;
41
- this.checkForNewTiles(value.tileIds);
42
- this.configChange.emit(this.config);
43
- this.columns = columns;
44
- this.singleColumn = singleColumn;
45
- this.checkReadyAndLoadTiles();
56
+ if (__classPrivateFieldGet(this, _SkyTileDashboardService_config, "f") && value.persisted) {
57
+ __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f").layout = value.layout;
58
+ __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_checkForNewTiles).call(this, value.tileIds);
59
+ this.configChange.emit(__classPrivateFieldGet(this, _SkyTileDashboardService_config, "f"));
60
+ __classPrivateFieldSet(this, _SkyTileDashboardService_columns, columns, "f");
61
+ __classPrivateFieldSet(this, _SkyTileDashboardService_singleColumn, singleColumn, "f");
62
+ __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_checkReadyAndLoadTiles).call(this);
46
63
  }
47
64
  else {
48
65
  // Bad data, or config is the default config.
49
- this.initToDefaults(config, columns, singleColumn);
66
+ __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_initToDefaults).call(this, config, columns, singleColumn);
50
67
  }
51
68
  }, (error) => {
52
69
  // Config setting key doesn't exist or other config service error
53
- this.initToDefaults(config, columns, singleColumn);
70
+ __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_initToDefaults).call(this, config, columns, singleColumn);
54
71
  });
55
72
  }
56
73
  else {
57
- this.initToDefaults(config, columns, singleColumn);
74
+ __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_initToDefaults).call(this, config, columns, singleColumn);
58
75
  }
59
76
  }
60
77
  /**
@@ -63,8 +80,8 @@ export class SkyTileDashboardService {
63
80
  * @param component Specifies the tile component to add.
64
81
  */
65
82
  addTileComponent(tile, component) {
66
- this.tileComponents = this.tileComponents || [];
67
- this.tileComponents.push(component);
83
+ __classPrivateFieldSet(this, _SkyTileDashboardService_tileComponents, __classPrivateFieldGet(this, _SkyTileDashboardService_tileComponents, "f") || [], "f");
84
+ __classPrivateFieldGet(this, _SkyTileDashboardService_tileComponents, "f").push(component);
68
85
  component.location.nativeElement.setAttribute(ATTR_TILE_ID, tile.id);
69
86
  }
70
87
  /**
@@ -72,11 +89,11 @@ export class SkyTileDashboardService {
72
89
  * @param tile Specifies the tile component to check.
73
90
  */
74
91
  tileIsCollapsed(tile) {
75
- const tileConfig = this.findTile(this.getTileId(tile));
92
+ const tileConfig = __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_findTile).call(this, __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_getTileId).call(this, tile));
76
93
  if (tileConfig) {
77
94
  return tileConfig.isCollapsed;
78
95
  }
79
- return undefined;
96
+ return false;
80
97
  }
81
98
  /**
82
99
  * Sets the collapsed state of all tiles.
@@ -84,20 +101,20 @@ export class SkyTileDashboardService {
84
101
  */
85
102
  setAllTilesCollapsed(isCollapsed) {
86
103
  /*istanbul ignore else */
87
- if (this.config && this.config.layout.multiColumn) {
88
- for (const column of this.config.layout.multiColumn) {
104
+ if (__classPrivateFieldGet(this, _SkyTileDashboardService_config, "f") && __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f").layout.multiColumn) {
105
+ for (const column of __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f").layout.multiColumn) {
89
106
  for (const tile of column.tiles) {
90
107
  tile.isCollapsed = isCollapsed;
91
108
  }
92
109
  }
93
- for (const tile of this.config.layout.singleColumn.tiles) {
110
+ for (const tile of __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f").layout.singleColumn.tiles) {
94
111
  tile.isCollapsed = isCollapsed;
95
112
  }
96
113
  }
97
- if (this.settingsKey) {
98
- this.setUserConfig(this.config);
114
+ if (__classPrivateFieldGet(this, _SkyTileDashboardService_settingsKey, "f")) {
115
+ __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_setUserConfig).call(this, __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f"));
99
116
  }
100
- this.configChange.emit(this.config);
117
+ this.configChange.emit(__classPrivateFieldGet(this, _SkyTileDashboardService_config, "f"));
101
118
  }
102
119
  /**
103
120
  * Sets the collapsed state of a specified tile.
@@ -105,21 +122,21 @@ export class SkyTileDashboardService {
105
122
  * @param isCollapsed Indicates whether the tile is collapsed.
106
123
  */
107
124
  setTileCollapsed(tile, isCollapsed) {
108
- const tileConfig = this.findTile(this.getTileId(tile));
125
+ const tileConfig = __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_findTile).call(this, __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_getTileId).call(this, tile));
109
126
  if (tileConfig) {
110
127
  tileConfig.isCollapsed = isCollapsed;
111
- if (this.settingsKey) {
112
- this.setUserConfig(this.config);
128
+ if (__classPrivateFieldGet(this, _SkyTileDashboardService_settingsKey, "f")) {
129
+ __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_setUserConfig).call(this, __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f"));
113
130
  }
114
- this.configChange.emit(this.config);
131
+ this.configChange.emit(__classPrivateFieldGet(this, _SkyTileDashboardService_config, "f"));
115
132
  }
116
133
  }
117
134
  /**
118
135
  * @internal
119
136
  */
120
137
  getTileComponentType(layoutTile) {
121
- if (layoutTile) {
122
- for (const tile of this.config.tiles) {
138
+ if (layoutTile && __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f")) {
139
+ for (const tile of __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f").tiles) {
123
140
  if (tile.id === layoutTile.id) {
124
141
  return tile.componentType;
125
142
  }
@@ -132,12 +149,12 @@ export class SkyTileDashboardService {
132
149
  */
133
150
  changeColumnMode(isSingleColumn) {
134
151
  /*istanbul ignore else */
135
- if (this.config) {
152
+ if (__classPrivateFieldGet(this, _SkyTileDashboardService_config, "f")) {
136
153
  if (isSingleColumn) {
137
- this.moveTilesToSingleColumn();
154
+ __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_moveTilesToSingleColumn).call(this);
138
155
  }
139
156
  else {
140
- this.moveTilesToMultiColumn();
157
+ __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_moveTilesToMultiColumn).call(this);
141
158
  }
142
159
  }
143
160
  }
@@ -145,10 +162,12 @@ export class SkyTileDashboardService {
145
162
  * @internal
146
163
  */
147
164
  getTileComponent(tileId) {
148
- for (const tileComponent of this.tileComponents) {
149
- if (tileComponent.location.nativeElement.getAttribute(ATTR_TILE_ID) ===
150
- tileId) {
151
- return tileComponent;
165
+ if (__classPrivateFieldGet(this, _SkyTileDashboardService_tileComponents, "f")) {
166
+ for (const tileComponent of __classPrivateFieldGet(this, _SkyTileDashboardService_tileComponents, "f")) {
167
+ if (tileComponent.location.nativeElement.getAttribute(ATTR_TILE_ID) ===
168
+ tileId) {
169
+ return tileComponent;
170
+ }
152
171
  }
153
172
  }
154
173
  /*istanbul ignore next */
@@ -159,305 +178,311 @@ export class SkyTileDashboardService {
159
178
  */
160
179
  destroy() {
161
180
  /*istanbul ignore else */
162
- if (this.mediaSubscription) {
163
- this.mediaSubscription.unsubscribe();
181
+ if (__classPrivateFieldGet(this, _SkyTileDashboardService_mediaSubscription, "f")) {
182
+ __classPrivateFieldGet(this, _SkyTileDashboardService_mediaSubscription, "f").unsubscribe();
164
183
  }
165
184
  }
166
185
  /**
167
186
  * @internal
168
187
  */
169
188
  moveTileOnKeyDown(tileCmp, direction, tileDescription) {
170
- const isSingleColumnMode = this.mediaQuery.current === SkyMediaBreakpoints.xs ||
171
- this.mediaQuery.current === SkyMediaBreakpoints.sm;
172
- const tileId = this.getTileId(tileCmp);
173
- const tile = this.findTile(tileId);
174
- let column;
175
- let colIndex;
176
- if (isSingleColumnMode) {
177
- column = this.config.layout.singleColumn;
178
- }
179
- else {
180
- column = this.findTileColumn(tileId);
181
- colIndex = this.config.layout.multiColumn.findIndex((value) => value === column);
182
- }
183
- if ((direction === 'left' || direction === 'right') &&
184
- !isSingleColumnMode) {
185
- const operator = direction === 'left' ? -1 : 1;
186
- const newColumn = this.config.layout.multiColumn[colIndex + operator];
187
- if (newColumn) {
188
- // Move the tile to the end of the new column
189
- newColumn.tiles.push(tile);
190
- column.tiles = column.tiles.filter((item) => item !== tile);
191
- this.moveTilesToColumn(this.columns.toArray()[colIndex + operator], [
192
- tile,
193
- ]);
194
- // Report the change in configuration
195
- const reportConfig = this.config;
196
- reportConfig.movedTile = {
197
- tileDescription: tileDescription || /* istanbul ignore next */ tile.id,
198
- column: colIndex + operator + 1,
199
- position: newColumn.tiles.length,
200
- };
201
- this.configChange.emit(reportConfig);
189
+ if (__classPrivateFieldGet(this, _SkyTileDashboardService_config, "f")) {
190
+ const isSingleColumnMode = __classPrivateFieldGet(this, _SkyTileDashboardService_mediaQuery, "f").current === SkyMediaBreakpoints.xs ||
191
+ __classPrivateFieldGet(this, _SkyTileDashboardService_mediaQuery, "f").current === SkyMediaBreakpoints.sm;
192
+ const tileId = __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_getTileId).call(this, tileCmp);
193
+ const tile = __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_findTile).call(this, tileId);
194
+ let column;
195
+ let colIndex = 0;
196
+ if (isSingleColumnMode) {
197
+ column = __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f").layout.singleColumn;
202
198
  }
203
- }
204
- else {
205
- const operator = direction === 'up' ? -1 : 1;
206
- const curIndex = column.tiles.findIndex((value) => value.id === tile.id);
207
- const tileComponentInstance = this.getTileComponent(tileId);
208
- if (tileComponentInstance && column.tiles[curIndex + operator]) {
209
- const temp = column.tiles[curIndex + operator];
210
- column.tiles[curIndex + operator] = tile;
211
- column.tiles[curIndex] = temp;
212
- // Get the column element
213
- let columnEl;
214
- if (isSingleColumnMode) {
215
- columnEl = this.getColumnEl(this.singleColumn);
216
- }
217
- else {
218
- columnEl = this.getColumnEl(this.columns.toArray()[colIndex]);
219
- }
220
- // Move the tile element in the document
221
- if (curIndex + operator === column.tiles.length - 1) {
222
- columnEl.appendChild(tileComponentInstance.location.nativeElement);
199
+ else {
200
+ column = __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_findTileColumn).call(this, tileId);
201
+ colIndex = __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f").layout.multiColumn.findIndex((value) => value === column);
202
+ }
203
+ if (column && tile && tileId) {
204
+ if ((direction === 'left' || direction === 'right') &&
205
+ !isSingleColumnMode) {
206
+ const operator = direction === 'left' ? -1 : 1;
207
+ const newColumn = __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f").layout.multiColumn[colIndex + operator];
208
+ if (newColumn) {
209
+ // Move the tile to the end of the new column
210
+ newColumn.tiles.push(tile);
211
+ column.tiles = column.tiles.filter((item) => item !== tile);
212
+ __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_moveTilesToColumn).call(this, __classPrivateFieldGet(this, _SkyTileDashboardService_columns, "f")?.toArray()[colIndex + operator], [tile]);
213
+ // Report the change in configuration
214
+ const reportConfig = __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f");
215
+ reportConfig.movedTile = {
216
+ tileDescription: tileDescription || /* istanbul ignore next */ tile.id,
217
+ column: colIndex + operator + 1,
218
+ position: newColumn.tiles.length,
219
+ };
220
+ this.configChange.emit(reportConfig);
221
+ }
223
222
  }
224
223
  else {
225
- columnEl.insertBefore(tileComponentInstance.location.nativeElement, this.getTileComponent(column.tiles[curIndex + operator + 1].id)
226
- .location.nativeElement);
224
+ const operator = direction === 'up' ? -1 : 1;
225
+ const curIndex = column.tiles.findIndex((value) => value.id === tile.id);
226
+ const tileComponentInstance = this.getTileComponent(tileId);
227
+ if (tileComponentInstance && column.tiles[curIndex + operator]) {
228
+ const temp = column.tiles[curIndex + operator];
229
+ column.tiles[curIndex + operator] = tile;
230
+ column.tiles[curIndex] = temp;
231
+ // Get the column element
232
+ let columnEl;
233
+ if (isSingleColumnMode) {
234
+ columnEl = __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_getColumnEl).call(this, __classPrivateFieldGet(this, _SkyTileDashboardService_singleColumn, "f"));
235
+ }
236
+ else {
237
+ columnEl = __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_getColumnEl).call(this, __classPrivateFieldGet(this, _SkyTileDashboardService_columns, "f")?.toArray()[colIndex]);
238
+ }
239
+ // Move the tile element in the document
240
+ if (curIndex + operator === column.tiles.length - 1) {
241
+ columnEl?.appendChild(tileComponentInstance.location.nativeElement);
242
+ }
243
+ else {
244
+ columnEl?.insertBefore(tileComponentInstance.location.nativeElement, this.getTileComponent(column.tiles[curIndex + operator + 1].id)
245
+ ?.location.nativeElement);
246
+ }
247
+ // Report the change in configuration
248
+ const reportConfig = __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f");
249
+ reportConfig.movedTile = {
250
+ tileDescription: tileDescription || /* istanbul ignore next */ tile.id,
251
+ column: isSingleColumnMode ? 1 : colIndex + 1,
252
+ position: curIndex + operator + 1,
253
+ };
254
+ this.configChange.emit(reportConfig);
255
+ }
227
256
  }
228
- // Report the change in configuration
229
- const reportConfig = this.config;
230
- reportConfig.movedTile = {
231
- tileDescription: tileDescription || /* istanbul ignore next */ tile.id,
232
- column: isSingleColumnMode ? undefined : colIndex + 1,
233
- position: curIndex + operator + 1,
234
- };
235
- this.configChange.emit(reportConfig);
236
257
  }
237
258
  }
238
259
  }
239
- getTileId(tile) {
240
- if (tile) {
241
- let el = tile.elementRef.nativeElement;
242
- let tileId;
243
- while (el) {
244
- tileId = el.getAttribute(ATTR_TILE_ID);
245
- if (tileId) {
246
- return tileId;
247
- }
248
- el = el.parentElement;
260
+ }
261
+ _SkyTileDashboardService_columns = new WeakMap(), _SkyTileDashboardService_config = new WeakMap(), _SkyTileDashboardService_dragulaService = new WeakMap(), _SkyTileDashboardService_dynamicComponentService = new WeakMap(), _SkyTileDashboardService_mediaSubscription = new WeakMap(), _SkyTileDashboardService_mediaQuery = new WeakMap(), _SkyTileDashboardService_singleColumn = new WeakMap(), _SkyTileDashboardService_settingsKey = new WeakMap(), _SkyTileDashboardService_tileComponents = new WeakMap(), _SkyTileDashboardService_uiConfigService = new WeakMap(), _SkyTileDashboardService_instances = new WeakSet(), _SkyTileDashboardService_getTileId = function _SkyTileDashboardService_getTileId(tile) {
262
+ if (tile) {
263
+ let el = tile.elementRef.nativeElement;
264
+ let tileId;
265
+ while (el) {
266
+ tileId = el.getAttribute(ATTR_TILE_ID);
267
+ if (tileId) {
268
+ return tileId;
249
269
  }
270
+ el = el.parentElement;
250
271
  }
251
- return undefined;
252
272
  }
253
- getTileOrRemoveFromLayout(layoutTile) {
254
- /*istanbul ignore else */
255
- if (layoutTile) {
256
- for (const tile of this.config.tiles) {
257
- if (tile.id === layoutTile.id) {
258
- return tile;
259
- }
260
- }
261
- // If the layout tile was not found in the list of tiles, it was removed since last the user updated settings
262
- /*istanbul ignore else */
263
- if (this.config.layout.singleColumn) {
264
- this.config.layout.singleColumn.tiles =
265
- this.config.layout.singleColumn.tiles.filter((elem) => elem.id !== layoutTile.id);
266
- }
267
- /*istanbul ignore else */
268
- if (this.config.layout.multiColumn) {
269
- this.config.layout.multiColumn.forEach((elem) => {
270
- elem.tiles = elem.tiles.filter((res) => res.id !== layoutTile.id);
271
- });
273
+ return undefined;
274
+ }, _SkyTileDashboardService_getTileOrRemoveFromLayout = function _SkyTileDashboardService_getTileOrRemoveFromLayout(layoutTile) {
275
+ /*istanbul ignore else */
276
+ if (layoutTile && __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f")) {
277
+ for (const tile of __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f").tiles) {
278
+ if (tile.id === layoutTile.id) {
279
+ return tile;
272
280
  }
273
281
  }
274
- /*istanbul ignore next */
275
- return undefined;
282
+ // If the layout tile was not found in the list of tiles, it was removed since last the user updated settings
283
+ /*istanbul ignore else */
284
+ if (__classPrivateFieldGet(this, _SkyTileDashboardService_config, "f")?.layout.singleColumn) {
285
+ __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f").layout.singleColumn.tiles =
286
+ __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f").layout.singleColumn.tiles.filter((elem) => elem.id !== layoutTile.id);
287
+ }
288
+ /*istanbul ignore else */
289
+ if (__classPrivateFieldGet(this, _SkyTileDashboardService_config, "f")?.layout.multiColumn) {
290
+ __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f").layout.multiColumn.forEach((elem) => {
291
+ elem.tiles = elem.tiles.filter((res) => res.id !== layoutTile.id);
292
+ });
293
+ }
294
+ }
295
+ /*istanbul ignore next */
296
+ return undefined;
297
+ }, _SkyTileDashboardService_checkReadyAndLoadTiles = function _SkyTileDashboardService_checkReadyAndLoadTiles() {
298
+ if (__classPrivateFieldGet(this, _SkyTileDashboardService_config, "f") && __classPrivateFieldGet(this, _SkyTileDashboardService_columns, "f")) {
299
+ __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_loadTiles).call(this, __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f"));
300
+ __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_initMediaQueries).call(this);
301
+ this.dashboardInitialized.emit();
276
302
  }
277
- checkReadyAndLoadTiles() {
278
- if (this.config && this.columns) {
279
- this.loadTiles();
280
- this.initMediaQueries();
281
- this.dashboardInitialized.emit();
303
+ }, _SkyTileDashboardService_loadTiles = function _SkyTileDashboardService_loadTiles(config) {
304
+ const layout = config.layout;
305
+ if (__classPrivateFieldGet(this, _SkyTileDashboardService_mediaQuery, "f").current === SkyMediaBreakpoints.xs ||
306
+ __classPrivateFieldGet(this, _SkyTileDashboardService_mediaQuery, "f").current === SkyMediaBreakpoints.sm) {
307
+ for (const tile of layout.singleColumn.tiles) {
308
+ __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_loadTileIntoColumn).call(this, __classPrivateFieldGet(this, _SkyTileDashboardService_singleColumn, "f"), tile);
282
309
  }
283
310
  }
284
- loadTiles() {
285
- const layout = this.config.layout;
286
- if (this.mediaQuery.current === SkyMediaBreakpoints.xs ||
287
- this.mediaQuery.current === SkyMediaBreakpoints.sm) {
288
- for (const tile of layout.singleColumn.tiles) {
289
- this.loadTileIntoColumn(this.singleColumn, tile);
290
- }
311
+ else {
312
+ let columns = [];
313
+ /*istanbul ignore else */
314
+ if (__classPrivateFieldGet(this, _SkyTileDashboardService_columns, "f")) {
315
+ columns = __classPrivateFieldGet(this, _SkyTileDashboardService_columns, "f")?.toArray();
291
316
  }
292
- else {
293
- const columns = this.columns.toArray();
294
- for (let i = 0, n = layout.multiColumn.length; i < n; i++) {
295
- const column = columns[i];
296
- for (const tile of layout.multiColumn[i].tiles) {
297
- this.loadTileIntoColumn(column, tile);
298
- }
317
+ for (let i = 0, n = layout.multiColumn.length; i < n; i++) {
318
+ const column = columns[i];
319
+ for (const tile of layout.multiColumn[i].tiles) {
320
+ __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_loadTileIntoColumn).call(this, column, tile);
299
321
  }
300
322
  }
301
323
  }
302
- loadTileIntoColumn(column, layoutTile) {
303
- const tile = this.getTileOrRemoveFromLayout(layoutTile);
324
+ }, _SkyTileDashboardService_loadTileIntoColumn = function _SkyTileDashboardService_loadTileIntoColumn(column, layoutTile) {
325
+ if (column) {
326
+ const tile = __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_getTileOrRemoveFromLayout).call(this, layoutTile);
304
327
  /*istanbul ignore else */
305
- if (tile) {
328
+ if (tile && __classPrivateFieldGet(this, _SkyTileDashboardService_dynamicComponentService, "f")) {
306
329
  const componentType = tile.componentType;
307
330
  const providers = tile.providers /* istanbul ignore next */ || [];
308
- const injector = Injector.create({
309
- providers,
310
- parent: column.injector,
331
+ const componentRef = __classPrivateFieldGet(this, _SkyTileDashboardService_dynamicComponentService, "f").createComponent(componentType, {
332
+ location: SkyDynamicComponentLocation.ElementBottom,
333
+ providers: providers,
334
+ referenceEl: column.content?.nativeElement,
335
+ parentInjector: column.injector,
311
336
  });
312
- const factory = column.resolver.resolveComponentFactory(componentType);
313
- const componentRef = column.content.createComponent(factory, undefined, injector);
314
337
  this.addTileComponent(layoutTile, componentRef);
315
338
  // Make sure the component is marked for changes in case the parent component uses
316
339
  // the OnPush change detection strategy.
317
340
  componentRef.changeDetectorRef.markForCheck();
318
341
  }
319
342
  }
320
- moveTilesToSingleColumn() {
321
- this.moveTilesToColumn(this.singleColumn, this.config.layout.singleColumn.tiles);
343
+ }, _SkyTileDashboardService_moveTilesToSingleColumn = function _SkyTileDashboardService_moveTilesToSingleColumn() {
344
+ __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_moveTilesToColumn).call(this, __classPrivateFieldGet(this, _SkyTileDashboardService_singleColumn, "f"), __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f")?.layout.singleColumn.tiles);
345
+ }, _SkyTileDashboardService_moveTilesToMultiColumn = function _SkyTileDashboardService_moveTilesToMultiColumn() {
346
+ let layoutColumns = [];
347
+ /*istanbul ignore else */
348
+ if (__classPrivateFieldGet(this, _SkyTileDashboardService_config, "f")) {
349
+ layoutColumns = __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f").layout.multiColumn;
322
350
  }
323
- moveTilesToMultiColumn() {
324
- const layoutColumns = this.config.layout.multiColumn;
325
- const columns = this.columns.toArray();
326
- for (let i = 0, n = layoutColumns.length; i < n; i++) {
327
- this.moveTilesToColumn(columns[i], layoutColumns[i].tiles);
328
- }
351
+ let columns = [];
352
+ /*istanbul ignore else */
353
+ if (__classPrivateFieldGet(this, _SkyTileDashboardService_columns, "f")) {
354
+ columns = __classPrivateFieldGet(this, _SkyTileDashboardService_columns, "f")?.toArray();
355
+ }
356
+ for (let i = 0, n = layoutColumns.length; i < n; i++) {
357
+ __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_moveTilesToColumn).call(this, columns[i], layoutColumns[i].tiles);
329
358
  }
330
- moveTilesToColumn(column, layoutTiles) {
331
- const columnEl = this.getColumnEl(column);
359
+ }, _SkyTileDashboardService_moveTilesToColumn = function _SkyTileDashboardService_moveTilesToColumn(column, layoutTiles) {
360
+ if (column && layoutTiles) {
361
+ const columnEl = __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_getColumnEl).call(this, column);
332
362
  for (const layoutTile of layoutTiles) {
333
363
  const tileComponentInstance = this.getTileComponent(layoutTile.id);
334
364
  /*istanbul ignore else */
335
365
  if (tileComponentInstance) {
336
- columnEl.appendChild(tileComponentInstance.location.nativeElement);
366
+ columnEl?.appendChild(tileComponentInstance.location.nativeElement);
337
367
  }
338
368
  }
339
369
  }
340
- getConfigForUIState() {
341
- /*istanbul ignore else */
342
- if (this.config) {
343
- this.config = {
344
- tiles: this.config.tiles,
345
- layout: {
346
- singleColumn: this.getSingleColumnLayoutForUIState(),
347
- multiColumn: this.getMultiColumnLayoutForUIState(),
348
- },
349
- };
350
- }
351
- return this.config;
352
- }
353
- getSingleColumnLayoutForUIState() {
354
- if (this.mediaQuery.current === SkyMediaBreakpoints.xs ||
355
- this.mediaQuery.current === SkyMediaBreakpoints.sm) {
356
- return {
357
- tiles: this.getTilesInEl(this.getColumnEl(this.singleColumn)),
358
- };
359
- }
360
- return this.config.layout.singleColumn;
370
+ }, _SkyTileDashboardService_getConfigForUIState = function _SkyTileDashboardService_getConfigForUIState() {
371
+ /*istanbul ignore else */
372
+ if (__classPrivateFieldGet(this, _SkyTileDashboardService_config, "f")) {
373
+ __classPrivateFieldSet(this, _SkyTileDashboardService_config, {
374
+ tiles: __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f").tiles,
375
+ layout: {
376
+ singleColumn: __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_getSingleColumnLayoutForUIState).call(this, __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f")),
377
+ multiColumn: __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_getMultiColumnLayoutForUIState).call(this, __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f")),
378
+ },
379
+ }, "f");
361
380
  }
362
- getMultiColumnLayoutForUIState() {
363
- if (!(this.mediaQuery.current === SkyMediaBreakpoints.xs ||
364
- this.mediaQuery.current === SkyMediaBreakpoints.sm)) {
365
- const layoutColumns = [];
366
- const columns = this.columns.toArray();
367
- for (const column of columns) {
368
- if (column !== this.singleColumn) {
369
- const layoutColumn = {
370
- tiles: this.getTilesInEl(this.getColumnEl(column)),
371
- };
372
- layoutColumns.push(layoutColumn);
373
- }
374
- }
375
- return layoutColumns;
376
- }
377
- return this.config.layout.multiColumn;
381
+ return __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f");
382
+ }, _SkyTileDashboardService_getSingleColumnLayoutForUIState = function _SkyTileDashboardService_getSingleColumnLayoutForUIState(config) {
383
+ if (__classPrivateFieldGet(this, _SkyTileDashboardService_mediaQuery, "f").current === SkyMediaBreakpoints.xs ||
384
+ __classPrivateFieldGet(this, _SkyTileDashboardService_mediaQuery, "f").current === SkyMediaBreakpoints.sm) {
385
+ return {
386
+ tiles: __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_getTilesInEl).call(this, __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_getColumnEl).call(this, __classPrivateFieldGet(this, _SkyTileDashboardService_singleColumn, "f"))),
387
+ };
378
388
  }
379
- getTilesInEl(el) {
380
- const tileEls = el.querySelectorAll('[' + ATTR_TILE_ID + ']');
381
- const layoutTiles = [];
389
+ return config.layout.singleColumn;
390
+ }, _SkyTileDashboardService_getMultiColumnLayoutForUIState = function _SkyTileDashboardService_getMultiColumnLayoutForUIState(config) {
391
+ if (!(__classPrivateFieldGet(this, _SkyTileDashboardService_mediaQuery, "f").current === SkyMediaBreakpoints.xs ||
392
+ __classPrivateFieldGet(this, _SkyTileDashboardService_mediaQuery, "f").current === SkyMediaBreakpoints.sm)) {
393
+ const layoutColumns = [];
394
+ let columns = [];
382
395
  /*istanbul ignore else */
383
- if (tileEls) {
384
- for (let i = 0, n = tileEls.length; i < n; i++) {
385
- const tileEl = tileEls[i];
386
- const tileId = tileEl.getAttribute(ATTR_TILE_ID);
387
- const tile = this.findTile(tileId);
388
- /*istanbul ignore else */
389
- if (tile) {
390
- layoutTiles.push(tile);
391
- }
392
- }
396
+ if (__classPrivateFieldGet(this, _SkyTileDashboardService_columns, "f")) {
397
+ columns = __classPrivateFieldGet(this, _SkyTileDashboardService_columns, "f")?.toArray();
393
398
  }
394
- return layoutTiles;
395
- }
396
- initMediaQueries() {
397
- /*istanbul ignore else */
398
- if (!this.mediaSubscription) {
399
- this.mediaSubscription = this.mediaQuery.subscribe((args) => {
400
- this.changeColumnMode(args === SkyMediaBreakpoints.xs || args === SkyMediaBreakpoints.sm);
401
- });
399
+ for (const column of columns) {
400
+ if (column !== __classPrivateFieldGet(this, _SkyTileDashboardService_singleColumn, "f")) {
401
+ const layoutColumn = {
402
+ tiles: __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_getTilesInEl).call(this, __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_getColumnEl).call(this, column)),
403
+ };
404
+ layoutColumns.push(layoutColumn);
405
+ }
402
406
  }
407
+ return layoutColumns;
403
408
  }
404
- initDragula() {
405
- this.dragulaService.createGroup(this.bagId, {
406
- moves: (el, container, handle) => {
407
- const target = el.querySelector('.sky-tile-grab-handle');
408
- return target.contains(handle);
409
- },
410
- });
411
- this.dragulaService.drop(this.bagId).subscribe(() => {
412
- const config = this.getConfigForUIState();
409
+ return config.layout.multiColumn;
410
+ }, _SkyTileDashboardService_getTilesInEl = function _SkyTileDashboardService_getTilesInEl(el) {
411
+ const tileEls = el?.querySelectorAll('[' + ATTR_TILE_ID + ']');
412
+ const layoutTiles = [];
413
+ /*istanbul ignore else */
414
+ if (tileEls) {
415
+ for (let i = 0, n = tileEls.length; i < n; i++) {
416
+ const tileEl = tileEls[i];
417
+ const tileId = tileEl.getAttribute(ATTR_TILE_ID);
418
+ const tile = __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_findTile).call(this, tileId);
413
419
  /*istanbul ignore else */
414
- if (config) {
415
- if (this.settingsKey) {
416
- this.setUserConfig(config);
417
- }
418
- this.configChange.emit(config);
420
+ if (tile) {
421
+ layoutTiles.push(tile);
419
422
  }
420
- });
423
+ }
421
424
  }
422
- getColumnEl(column) {
423
- return column.content.element.nativeElement.parentNode;
425
+ return layoutTiles;
426
+ }, _SkyTileDashboardService_initMediaQueries = function _SkyTileDashboardService_initMediaQueries() {
427
+ /*istanbul ignore else */
428
+ if (!__classPrivateFieldGet(this, _SkyTileDashboardService_mediaSubscription, "f")) {
429
+ __classPrivateFieldSet(this, _SkyTileDashboardService_mediaSubscription, __classPrivateFieldGet(this, _SkyTileDashboardService_mediaQuery, "f").subscribe((args) => {
430
+ this.changeColumnMode(args === SkyMediaBreakpoints.xs || args === SkyMediaBreakpoints.sm);
431
+ }), "f");
424
432
  }
425
- findTile(tileId) {
433
+ }, _SkyTileDashboardService_initDragula = function _SkyTileDashboardService_initDragula() {
434
+ __classPrivateFieldGet(this, _SkyTileDashboardService_dragulaService, "f").createGroup(this.bagId, {
435
+ moves: (el, container, handle) => {
436
+ const target = el?.querySelector('.sky-tile-grab-handle');
437
+ return !!target && target.contains(handle);
438
+ },
439
+ });
440
+ __classPrivateFieldGet(this, _SkyTileDashboardService_dragulaService, "f").drop(this.bagId).subscribe(() => {
441
+ const config = __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_getConfigForUIState).call(this);
426
442
  /*istanbul ignore else */
427
- if (this.config && this.config.layout.multiColumn) {
428
- for (const column of this.config.layout.multiColumn) {
429
- /*istanbul ignore else */
430
- if (column.tiles) {
431
- for (const tile of column.tiles) {
432
- if (tile.id === tileId) {
433
- return tile;
434
- }
443
+ if (config) {
444
+ if (__classPrivateFieldGet(this, _SkyTileDashboardService_settingsKey, "f")) {
445
+ __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_setUserConfig).call(this, config);
446
+ }
447
+ this.configChange.emit(config);
448
+ }
449
+ });
450
+ }, _SkyTileDashboardService_getColumnEl = function _SkyTileDashboardService_getColumnEl(column) {
451
+ return column?.content?.nativeElement.parentNode;
452
+ }, _SkyTileDashboardService_findTile = function _SkyTileDashboardService_findTile(tileId) {
453
+ /*istanbul ignore else */
454
+ if (__classPrivateFieldGet(this, _SkyTileDashboardService_config, "f") && __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f").layout.multiColumn) {
455
+ for (const column of __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f").layout.multiColumn) {
456
+ /*istanbul ignore else */
457
+ if (column.tiles) {
458
+ for (const tile of column.tiles) {
459
+ if (tile.id === tileId) {
460
+ return tile;
435
461
  }
436
462
  }
437
463
  }
438
464
  }
439
- return undefined;
440
465
  }
441
- findTileColumn(tileId) {
442
- /*istanbul ignore else */
443
- if (this.config && this.config.layout.multiColumn) {
444
- return this.config.layout.multiColumn.find((col) => col.tiles && !!col.tiles.find((tile) => tile.id === tileId));
445
- }
446
- /*istanbul ignore next */
447
- return undefined;
466
+ return undefined;
467
+ }, _SkyTileDashboardService_findTileColumn = function _SkyTileDashboardService_findTileColumn(tileId) {
468
+ /*istanbul ignore else */
469
+ if (__classPrivateFieldGet(this, _SkyTileDashboardService_config, "f") && __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f").layout.multiColumn) {
470
+ return __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f").layout.multiColumn.find((col) => col.tiles && !!col.tiles.find((tile) => tile.id === tileId));
448
471
  }
449
- initToDefaults(config, columns, singleColumn) {
450
- this.config = config;
451
- this.columns = columns;
452
- this.singleColumn = singleColumn;
453
- this.checkReadyAndLoadTiles();
454
- }
455
- setUserConfig(config) {
456
- this.uiConfigService
457
- .setConfig(this.settingsKey, {
458
- layout: this.config.layout,
472
+ /*istanbul ignore next */
473
+ return undefined;
474
+ }, _SkyTileDashboardService_initToDefaults = function _SkyTileDashboardService_initToDefaults(config, columns, singleColumn) {
475
+ __classPrivateFieldSet(this, _SkyTileDashboardService_config, config, "f");
476
+ __classPrivateFieldSet(this, _SkyTileDashboardService_columns, columns, "f");
477
+ __classPrivateFieldSet(this, _SkyTileDashboardService_singleColumn, singleColumn, "f");
478
+ __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_checkReadyAndLoadTiles).call(this);
479
+ }, _SkyTileDashboardService_setUserConfig = function _SkyTileDashboardService_setUserConfig(config) {
480
+ if (config && __classPrivateFieldGet(this, _SkyTileDashboardService_settingsKey, "f"))
481
+ __classPrivateFieldGet(this, _SkyTileDashboardService_uiConfigService, "f")
482
+ .setConfig(__classPrivateFieldGet(this, _SkyTileDashboardService_settingsKey, "f"), {
483
+ layout: config.layout,
459
484
  persisted: true,
460
- tileIds: this.defaultConfig.tiles.map((elem) => elem.id),
485
+ tileIds: config.tiles.map((elem) => elem.id),
461
486
  })
462
487
  .subscribe(
463
488
  // eslint-disable-next-line @typescript-eslint/no-empty-function
@@ -465,61 +490,62 @@ export class SkyTileDashboardService {
465
490
  console.warn('Could not save tile dashboard settings.');
466
491
  console.warn(err);
467
492
  });
468
- }
469
- checkForNewTiles(oldUserTiles) {
470
- // Get a list of tiles that are in the config's default list but not in the user's settings
471
- const newTiles = this.config.tiles.filter((elem) => {
472
- return oldUserTiles.indexOf(elem.id) === -1;
473
- });
474
- const { multiColumn, singleColumn } = this.config.layout;
475
- // Append new tiles to the end of the layouts
493
+ }, _SkyTileDashboardService_checkForNewTiles = function _SkyTileDashboardService_checkForNewTiles(oldUserTiles) {
494
+ // Get a list of tiles that are in the config's default list but not in the user's settings
495
+ const newTiles = __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f")?.tiles.filter((elem) => {
496
+ return oldUserTiles.indexOf(elem.id) === -1;
497
+ });
498
+ const multiColumn = __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f")?.layout.multiColumn;
499
+ const singleColumn = __classPrivateFieldGet(this, _SkyTileDashboardService_config, "f")?.layout.singleColumn;
500
+ // Append new tiles to the end of the layouts
501
+ /*istanbul ignore else */
502
+ if (newTiles?.length) {
476
503
  /*istanbul ignore else */
477
- if (newTiles.length > 0) {
478
- /*istanbul ignore else */
479
- if (multiColumn) {
480
- newTiles.forEach((elem) => {
481
- let locationToAdd = 0;
482
- let smallest = multiColumn[0].tiles.length;
483
- multiColumn.forEach((item, index) => {
484
- if (item.tiles.length < smallest) {
485
- locationToAdd = index;
486
- smallest = item.tiles.length;
487
- }
488
- });
489
- multiColumn[locationToAdd].tiles.push({
490
- id: elem.id,
491
- isCollapsed: false,
492
- });
504
+ if (multiColumn) {
505
+ newTiles?.forEach((elem) => {
506
+ let locationToAdd = 0;
507
+ let smallest = multiColumn[0].tiles.length;
508
+ multiColumn.forEach((item, index) => {
509
+ if (item.tiles.length < smallest) {
510
+ locationToAdd = index;
511
+ smallest = item.tiles.length;
512
+ }
493
513
  });
494
- }
495
- /*istanbul ignore else */
496
- if (singleColumn) {
497
- newTiles.forEach((elem) => {
498
- singleColumn.tiles.push({ id: elem.id, isCollapsed: false });
514
+ multiColumn[locationToAdd].tiles.push({
515
+ id: elem.id,
516
+ isCollapsed: false,
499
517
  });
500
- }
518
+ });
501
519
  }
502
520
  /*istanbul ignore else */
503
521
  if (singleColumn) {
504
- for (const tile of singleColumn.tiles) {
505
- this.getTileOrRemoveFromLayout(tile);
506
- }
522
+ newTiles?.forEach((elem) => {
523
+ singleColumn.tiles.push({ id: elem.id, isCollapsed: false });
524
+ });
507
525
  }
508
- /*istanbul ignore else */
509
- if (multiColumn) {
510
- for (let i = 0, n = multiColumn.length; i < n; i++) {
511
- for (const tile of multiColumn[i].tiles) {
512
- this.getTileOrRemoveFromLayout(tile);
513
- }
526
+ }
527
+ /*istanbul ignore else */
528
+ if (singleColumn) {
529
+ for (const tile of singleColumn.tiles) {
530
+ __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_getTileOrRemoveFromLayout).call(this, tile);
531
+ }
532
+ }
533
+ /*istanbul ignore else */
534
+ if (multiColumn) {
535
+ for (let i = 0, n = multiColumn.length; i < n; i++) {
536
+ for (const tile of multiColumn[i].tiles) {
537
+ __classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_getTileOrRemoveFromLayout).call(this, tile);
514
538
  }
515
539
  }
516
540
  }
517
- }
518
- SkyTileDashboardService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyTileDashboardService, deps: [{ token: i1.DragulaService }, { token: i2.SkyMediaQueryService }, { token: i2.SkyUIConfigService }], target: i0.ɵɵFactoryTarget.Injectable });
519
- SkyTileDashboardService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyTileDashboardService });
520
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyTileDashboardService, decorators: [{
541
+ };
542
+ SkyTileDashboardService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: SkyTileDashboardService, deps: [{ token: i1.DragulaService }, { token: i2.SkyMediaQueryService }, { token: i2.SkyUIConfigService }, { token: i2.SkyDynamicComponentService, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
543
+ SkyTileDashboardService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: SkyTileDashboardService });
544
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: SkyTileDashboardService, decorators: [{
521
545
  type: Injectable
522
- }], ctorParameters: function () { return [{ type: i1.DragulaService }, { type: i2.SkyMediaQueryService }, { type: i2.SkyUIConfigService }]; }, propDecorators: { dashboardInitialized: [{
546
+ }], ctorParameters: function () { return [{ type: i1.DragulaService }, { type: i2.SkyMediaQueryService }, { type: i2.SkyUIConfigService }, { type: i2.SkyDynamicComponentService, decorators: [{
547
+ type: Optional
548
+ }] }]; }, propDecorators: { dashboardInitialized: [{
523
549
  type: Output
524
550
  }] } });
525
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tile-dashboard.service.js","sourceRoot":"","sources":["../../../../../../../../../libs/components/tiles/src/lib/modules/tiles/tile-dashboard/tile-dashboard.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ComponentRef,\n  EventEmitter,\n  Injectable,\n  Injector,\n  Output,\n  QueryList,\n} from '@angular/core';\nimport {\n  SkyMediaBreakpoints,\n  SkyMediaQueryService,\n  SkyUIConfigService,\n} from '@skyux/core';\n\nimport { DragulaService } from 'ng2-dragula';\nimport { Subscription } from 'rxjs';\nimport { take } from 'rxjs/operators';\n\nimport { SkyTileDashboardColumnComponent } from '../tile-dashboard-column/tile-dashboard-column.component';\nimport { SkyTileDashboardConfig } from '../tile-dashboard-config/tile-dashboard-config';\nimport { SkyTileDashboardConfigLayoutColumn } from '../tile-dashboard-config/tile-dashboard-config-layout-column';\nimport { SkyTileDashboardConfigLayoutTile } from '../tile-dashboard-config/tile-dashboard-config-layout-tile';\nimport { SkyTileDashboardConfigTile } from '../tile-dashboard-config/tile-dashboard-config-tile';\nimport { SkyTileComponent } from '../tile/tile.component';\n\nconst ATTR_TILE_ID = '_sky-tile-dashboard-tile-id';\n\nlet bagIdIndex = 0;\n\n@Injectable()\nexport class SkyTileDashboardService {\n  /**\n   * @internal\n   */\n  public bagId: string;\n\n  /**\n   * @internal\n   */\n  public configChange = new EventEmitter<SkyTileDashboardConfig>();\n\n  /**\n   * Fires when the tile dashboard's initialization is complete.\n   */\n  @Output()\n  public dashboardInitialized = new EventEmitter<void>();\n\n  private tileComponents: ComponentRef<any>[];\n\n  private config: SkyTileDashboardConfig;\n\n  private defaultConfig: SkyTileDashboardConfig;\n\n  private columns: QueryList<SkyTileDashboardColumnComponent>;\n\n  private singleColumn: SkyTileDashboardColumnComponent;\n\n  private mediaSubscription: Subscription;\n\n  private settingsKey: string;\n\n  constructor(\n    private dragulaService: DragulaService,\n    private mediaQuery: SkyMediaQueryService,\n    private uiConfigService: SkyUIConfigService\n  ) {\n    this.bagId = 'sky-tile-dashboard-bag-' + ++bagIdIndex;\n\n    this.initDragula();\n  }\n\n  /**\n   * @internal\n   */\n  public init(\n    config: SkyTileDashboardConfig,\n    columns?: QueryList<SkyTileDashboardColumnComponent>,\n    singleColumn?: SkyTileDashboardColumnComponent,\n    settingsKey?: string\n  ) {\n    if (settingsKey) {\n      // Clone this so changes to the config object outside of this class don't modify\n      // the config used inside and vice versa.\n      this.defaultConfig = this.config = Object.assign({}, config);\n\n      this.settingsKey = settingsKey;\n\n      this.uiConfigService\n        .getConfig(settingsKey, config)\n        .pipe(take(1))\n        .subscribe(\n          (value: any) => {\n            if (value.persisted) {\n              this.config.layout = value.layout;\n              this.checkForNewTiles(value.tileIds);\n              this.configChange.emit(this.config);\n\n              this.columns = columns;\n              this.singleColumn = singleColumn;\n              this.checkReadyAndLoadTiles();\n            } else {\n              // Bad data, or config is the default config.\n              this.initToDefaults(config, columns, singleColumn);\n            }\n          },\n          (error: any) => {\n            // Config setting key doesn't exist or other config service error\n            this.initToDefaults(config, columns, singleColumn);\n          }\n        );\n    } else {\n      this.initToDefaults(config, columns, singleColumn);\n    }\n  }\n\n  /**\n   * Adds a new tile to the tile dashboard.\n   * @param tile Specifies the tile configuration.\n   * @param component Specifies the tile component to add.\n   */\n  public addTileComponent(\n    tile: SkyTileDashboardConfigLayoutTile,\n    component: ComponentRef<any>\n  ) {\n    this.tileComponents = this.tileComponents || [];\n\n    this.tileComponents.push(component);\n\n    component.location.nativeElement.setAttribute(ATTR_TILE_ID, tile.id);\n  }\n\n  /**\n   * Checks whether a specified tile is collapsed.\n   * @param tile Specifies the tile component to check.\n   */\n  public tileIsCollapsed(tile: SkyTileComponent): boolean {\n    const tileConfig = this.findTile(this.getTileId(tile));\n\n    if (tileConfig) {\n      return tileConfig.isCollapsed;\n    }\n\n    return undefined;\n  }\n\n  /**\n   * Sets the collapsed state of all tiles.\n   * @param isCollapsed Indicates whether tiles are collapsed.\n   */\n  public setAllTilesCollapsed(isCollapsed: boolean): void {\n    /*istanbul ignore else */\n    if (this.config && this.config.layout.multiColumn) {\n      for (const column of this.config.layout.multiColumn) {\n        for (const tile of column.tiles) {\n          tile.isCollapsed = isCollapsed;\n        }\n      }\n      for (const tile of this.config.layout.singleColumn.tiles) {\n        tile.isCollapsed = isCollapsed;\n      }\n    }\n\n    if (this.settingsKey) {\n      this.setUserConfig(this.config);\n    }\n\n    this.configChange.emit(this.config);\n  }\n\n  /**\n   * Sets the collapsed state of a specified tile.\n   * @param tile Specifies the tile component.\n   * @param isCollapsed Indicates whether the tile is collapsed.\n   */\n  public setTileCollapsed(tile: SkyTileComponent, isCollapsed: boolean) {\n    const tileConfig = this.findTile(this.getTileId(tile));\n\n    if (tileConfig) {\n      tileConfig.isCollapsed = isCollapsed;\n\n      if (this.settingsKey) {\n        this.setUserConfig(this.config);\n      }\n\n      this.configChange.emit(this.config);\n    }\n  }\n\n  /**\n   * @internal\n   */\n  public getTileComponentType(\n    layoutTile: SkyTileDashboardConfigLayoutTile\n  ): any {\n    if (layoutTile) {\n      for (const tile of this.config.tiles) {\n        if (tile.id === layoutTile.id) {\n          return tile.componentType;\n        }\n      }\n    }\n\n    return undefined;\n  }\n\n  /**\n   * @internal\n   */\n  public changeColumnMode(isSingleColumn: boolean) {\n    /*istanbul ignore else */\n    if (this.config) {\n      if (isSingleColumn) {\n        this.moveTilesToSingleColumn();\n      } else {\n        this.moveTilesToMultiColumn();\n      }\n    }\n  }\n\n  /**\n   * @internal\n   */\n  public getTileComponent(tileId: string): ComponentRef<any> {\n    for (const tileComponent of this.tileComponents) {\n      if (\n        tileComponent.location.nativeElement.getAttribute(ATTR_TILE_ID) ===\n        tileId\n      ) {\n        return tileComponent;\n      }\n    }\n\n    /*istanbul ignore next */\n    return undefined;\n  }\n\n  /**\n   * @internal\n   */\n  public destroy() {\n    /*istanbul ignore else */\n    if (this.mediaSubscription) {\n      this.mediaSubscription.unsubscribe();\n    }\n  }\n\n  /**\n   * @internal\n   */\n  public moveTileOnKeyDown(\n    tileCmp: SkyTileComponent,\n    direction: string,\n    tileDescription: string\n  ) {\n    const isSingleColumnMode =\n      this.mediaQuery.current === SkyMediaBreakpoints.xs ||\n      this.mediaQuery.current === SkyMediaBreakpoints.sm;\n\n    const tileId = this.getTileId(tileCmp);\n    const tile = this.findTile(tileId);\n\n    let column: SkyTileDashboardConfigLayoutColumn;\n    let colIndex: number;\n    if (isSingleColumnMode) {\n      column = this.config.layout.singleColumn;\n    } else {\n      column = this.findTileColumn(tileId);\n      colIndex = this.config.layout.multiColumn.findIndex(\n        (value) => value === column\n      );\n    }\n\n    if (\n      (direction === 'left' || direction === 'right') &&\n      !isSingleColumnMode\n    ) {\n      const operator = direction === 'left' ? -1 : 1;\n      const newColumn = this.config.layout.multiColumn[colIndex + operator];\n\n      if (newColumn) {\n        // Move the tile to the end of the new column\n        newColumn.tiles.push(tile);\n        column.tiles = column.tiles.filter((item) => item !== tile);\n        this.moveTilesToColumn(this.columns.toArray()[colIndex + operator], [\n          tile,\n        ]);\n\n        // Report the change in configuration\n        const reportConfig = this.config;\n        reportConfig.movedTile = {\n          tileDescription:\n            tileDescription || /* istanbul ignore next */ tile.id,\n          column: colIndex + operator + 1,\n          position: newColumn.tiles.length,\n        };\n        this.configChange.emit(reportConfig);\n      }\n    } else {\n      const operator = direction === 'up' ? -1 : 1;\n      const curIndex = column.tiles.findIndex((value) => value.id === tile.id);\n      const tileComponentInstance = this.getTileComponent(tileId);\n\n      if (tileComponentInstance && column.tiles[curIndex + operator]) {\n        const temp = column.tiles[curIndex + operator];\n        column.tiles[curIndex + operator] = tile;\n        column.tiles[curIndex] = temp;\n\n        // Get the column element\n        let columnEl: Element;\n        if (isSingleColumnMode) {\n          columnEl = this.getColumnEl(this.singleColumn);\n        } else {\n          columnEl = this.getColumnEl(this.columns.toArray()[colIndex]);\n        }\n\n        // Move the tile element in the document\n        if (curIndex + operator === column.tiles.length - 1) {\n          columnEl.appendChild(tileComponentInstance.location.nativeElement);\n        } else {\n          columnEl.insertBefore(\n            tileComponentInstance.location.nativeElement,\n            this.getTileComponent(column.tiles[curIndex + operator + 1].id)\n              .location.nativeElement\n          );\n        }\n\n        // Report the change in configuration\n        const reportConfig = this.config;\n        reportConfig.movedTile = {\n          tileDescription:\n            tileDescription || /* istanbul ignore next */ tile.id,\n          column: isSingleColumnMode ? undefined : colIndex + 1,\n          position: curIndex + operator + 1,\n        };\n        this.configChange.emit(reportConfig);\n      }\n    }\n  }\n\n  private getTileId(tile: SkyTileComponent): string {\n    if (tile) {\n      let el = tile.elementRef.nativeElement;\n      let tileId: string;\n\n      while (el) {\n        tileId = el.getAttribute(ATTR_TILE_ID);\n\n        if (tileId) {\n          return tileId;\n        }\n\n        el = el.parentElement;\n      }\n    }\n\n    return undefined;\n  }\n\n  private getTileOrRemoveFromLayout(\n    layoutTile: SkyTileDashboardConfigLayoutTile\n  ): SkyTileDashboardConfigTile {\n    /*istanbul ignore else */\n    if (layoutTile) {\n      for (const tile of this.config.tiles) {\n        if (tile.id === layoutTile.id) {\n          return tile;\n        }\n      }\n\n      // If the layout tile was not found in the list of tiles, it was removed since last the user updated settings\n      /*istanbul ignore else */\n      if (this.config.layout.singleColumn) {\n        this.config.layout.singleColumn.tiles =\n          this.config.layout.singleColumn.tiles.filter(\n            (elem) => elem.id !== layoutTile.id\n          );\n      }\n\n      /*istanbul ignore else */\n      if (this.config.layout.multiColumn) {\n        this.config.layout.multiColumn.forEach((elem) => {\n          elem.tiles = elem.tiles.filter((res) => res.id !== layoutTile.id);\n        });\n      }\n    }\n\n    /*istanbul ignore next */\n    return undefined;\n  }\n\n  private checkReadyAndLoadTiles() {\n    if (this.config && this.columns) {\n      this.loadTiles();\n      this.initMediaQueries();\n      this.dashboardInitialized.emit();\n    }\n  }\n\n  private loadTiles() {\n    const layout = this.config.layout;\n\n    if (\n      this.mediaQuery.current === SkyMediaBreakpoints.xs ||\n      this.mediaQuery.current === SkyMediaBreakpoints.sm\n    ) {\n      for (const tile of layout.singleColumn.tiles) {\n        this.loadTileIntoColumn(this.singleColumn, tile);\n      }\n    } else {\n      const columns = this.columns.toArray();\n\n      for (let i = 0, n = layout.multiColumn.length; i < n; i++) {\n        const column = columns[i];\n\n        for (const tile of layout.multiColumn[i].tiles) {\n          this.loadTileIntoColumn(column, tile);\n        }\n      }\n    }\n  }\n\n  private loadTileIntoColumn(\n    column: SkyTileDashboardColumnComponent,\n    layoutTile: SkyTileDashboardConfigLayoutTile\n  ) {\n    const tile = this.getTileOrRemoveFromLayout(layoutTile);\n\n    /*istanbul ignore else */\n    if (tile) {\n      const componentType = tile.componentType;\n      const providers = tile.providers /* istanbul ignore next */ || [];\n\n      const injector = Injector.create({\n        providers,\n        parent: column.injector,\n      });\n\n      const factory = column.resolver.resolveComponentFactory(componentType);\n      const componentRef = column.content.createComponent(\n        factory,\n        undefined,\n        injector\n      );\n\n      this.addTileComponent(layoutTile, componentRef);\n\n      // Make sure the component is marked for changes in case the parent component uses\n      // the OnPush change detection strategy.\n      componentRef.changeDetectorRef.markForCheck();\n    }\n  }\n\n  private moveTilesToSingleColumn() {\n    this.moveTilesToColumn(\n      this.singleColumn,\n      this.config.layout.singleColumn.tiles\n    );\n  }\n\n  private moveTilesToMultiColumn() {\n    const layoutColumns = this.config.layout.multiColumn;\n    const columns = this.columns.toArray();\n\n    for (let i = 0, n = layoutColumns.length; i < n; i++) {\n      this.moveTilesToColumn(columns[i], layoutColumns[i].tiles);\n    }\n  }\n\n  private moveTilesToColumn(\n    column: SkyTileDashboardColumnComponent,\n    layoutTiles: SkyTileDashboardConfigLayoutTile[]\n  ) {\n    const columnEl = this.getColumnEl(column);\n\n    for (const layoutTile of layoutTiles) {\n      const tileComponentInstance = this.getTileComponent(layoutTile.id);\n\n      /*istanbul ignore else */\n      if (tileComponentInstance) {\n        columnEl.appendChild(tileComponentInstance.location.nativeElement);\n      }\n    }\n  }\n\n  private getConfigForUIState(): SkyTileDashboardConfig {\n    /*istanbul ignore else */\n    if (this.config) {\n      this.config = {\n        tiles: this.config.tiles,\n        layout: {\n          singleColumn: this.getSingleColumnLayoutForUIState(),\n          multiColumn: this.getMultiColumnLayoutForUIState(),\n        },\n      };\n    }\n\n    return this.config;\n  }\n\n  private getSingleColumnLayoutForUIState(): SkyTileDashboardConfigLayoutColumn {\n    if (\n      this.mediaQuery.current === SkyMediaBreakpoints.xs ||\n      this.mediaQuery.current === SkyMediaBreakpoints.sm\n    ) {\n      return {\n        tiles: this.getTilesInEl(this.getColumnEl(this.singleColumn)),\n      };\n    }\n\n    return this.config.layout.singleColumn;\n  }\n\n  private getMultiColumnLayoutForUIState(): SkyTileDashboardConfigLayoutColumn[] {\n    if (\n      !(\n        this.mediaQuery.current === SkyMediaBreakpoints.xs ||\n        this.mediaQuery.current === SkyMediaBreakpoints.sm\n      )\n    ) {\n      const layoutColumns: SkyTileDashboardConfigLayoutColumn[] = [];\n      const columns = this.columns.toArray();\n\n      for (const column of columns) {\n        if (column !== this.singleColumn) {\n          const layoutColumn: SkyTileDashboardConfigLayoutColumn = {\n            tiles: this.getTilesInEl(this.getColumnEl(column)),\n          };\n\n          layoutColumns.push(layoutColumn);\n        }\n      }\n\n      return layoutColumns;\n    }\n\n    return this.config.layout.multiColumn;\n  }\n\n  private getTilesInEl(el: Element): SkyTileDashboardConfigLayoutTile[] {\n    const tileEls: any = el.querySelectorAll('[' + ATTR_TILE_ID + ']');\n    const layoutTiles: SkyTileDashboardConfigLayoutTile[] = [];\n\n    /*istanbul ignore else */\n    if (tileEls) {\n      for (let i = 0, n = tileEls.length; i < n; i++) {\n        const tileEl = tileEls[i];\n        const tileId = tileEl.getAttribute(ATTR_TILE_ID);\n        const tile = this.findTile(tileId);\n\n        /*istanbul ignore else */\n        if (tile) {\n          layoutTiles.push(tile);\n        }\n      }\n    }\n\n    return layoutTiles;\n  }\n\n  private initMediaQueries() {\n    /*istanbul ignore else */\n    if (!this.mediaSubscription) {\n      this.mediaSubscription = this.mediaQuery.subscribe(\n        (args: SkyMediaBreakpoints) => {\n          this.changeColumnMode(\n            args === SkyMediaBreakpoints.xs || args === SkyMediaBreakpoints.sm\n          );\n        }\n      );\n    }\n  }\n\n  private initDragula() {\n    this.dragulaService.createGroup(this.bagId, {\n      moves: (el: HTMLElement, container: HTMLElement, handle: HTMLElement) => {\n        const target = el.querySelector('.sky-tile-grab-handle');\n        return target.contains(handle);\n      },\n    });\n\n    this.dragulaService.drop(this.bagId).subscribe(() => {\n      const config = this.getConfigForUIState();\n\n      /*istanbul ignore else */\n      if (config) {\n        if (this.settingsKey) {\n          this.setUserConfig(config);\n        }\n\n        this.configChange.emit(config);\n      }\n    });\n  }\n\n  private getColumnEl(column: SkyTileDashboardColumnComponent): Element {\n    return column.content.element.nativeElement.parentNode;\n  }\n\n  private findTile(tileId: string): SkyTileDashboardConfigLayoutTile {\n    /*istanbul ignore else */\n    if (this.config && this.config.layout.multiColumn) {\n      for (const column of this.config.layout.multiColumn) {\n        /*istanbul ignore else */\n        if (column.tiles) {\n          for (const tile of column.tiles) {\n            if (tile.id === tileId) {\n              return tile;\n            }\n          }\n        }\n      }\n    }\n\n    return undefined;\n  }\n\n  private findTileColumn(tileId: string): SkyTileDashboardConfigLayoutColumn {\n    /*istanbul ignore else */\n    if (this.config && this.config.layout.multiColumn) {\n      return this.config.layout.multiColumn.find(\n        (col) => col.tiles && !!col.tiles.find((tile) => tile.id === tileId)\n      );\n    }\n\n    /*istanbul ignore next */\n    return undefined;\n  }\n\n  private initToDefaults(\n    config: SkyTileDashboardConfig,\n    columns: QueryList<SkyTileDashboardColumnComponent>,\n    singleColumn: SkyTileDashboardColumnComponent\n  ) {\n    this.config = config;\n    this.columns = columns;\n    this.singleColumn = singleColumn;\n    this.checkReadyAndLoadTiles();\n  }\n\n  private setUserConfig(config: SkyTileDashboardConfig) {\n    this.uiConfigService\n      .setConfig(this.settingsKey, {\n        layout: this.config.layout,\n        persisted: true,\n        tileIds: this.defaultConfig.tiles.map((elem) => elem.id),\n      })\n      .subscribe(\n        // eslint-disable-next-line @typescript-eslint/no-empty-function\n        () => {},\n        (err) => {\n          console.warn('Could not save tile dashboard settings.');\n          console.warn(err);\n        }\n      );\n  }\n\n  private checkForNewTiles(oldUserTiles: string[]) {\n    // Get a list of tiles that are in the config's default list but not in the user's settings\n    const newTiles = this.config.tiles.filter((elem) => {\n      return oldUserTiles.indexOf(elem.id) === -1;\n    });\n\n    const { multiColumn, singleColumn } = this.config.layout;\n\n    // Append new tiles to the end of the layouts\n    /*istanbul ignore else */\n    if (newTiles.length > 0) {\n      /*istanbul ignore else */\n      if (multiColumn) {\n        newTiles.forEach((elem) => {\n          let locationToAdd = 0;\n          let smallest = multiColumn[0].tiles.length;\n          multiColumn.forEach((item, index) => {\n            if (item.tiles.length < smallest) {\n              locationToAdd = index;\n              smallest = item.tiles.length;\n            }\n          });\n          multiColumn[locationToAdd].tiles.push({\n            id: elem.id,\n            isCollapsed: false,\n          });\n        });\n      }\n\n      /*istanbul ignore else */\n      if (singleColumn) {\n        newTiles.forEach((elem) => {\n          singleColumn.tiles.push({ id: elem.id, isCollapsed: false });\n        });\n      }\n    }\n\n    /*istanbul ignore else */\n    if (singleColumn) {\n      for (const tile of singleColumn.tiles) {\n        this.getTileOrRemoveFromLayout(tile);\n      }\n    }\n\n    /*istanbul ignore else */\n    if (multiColumn) {\n      for (let i = 0, n = multiColumn.length; i < n; i++) {\n        for (const tile of multiColumn[i].tiles) {\n          this.getTileOrRemoveFromLayout(tile);\n        }\n      }\n    }\n  }\n}\n"]}
551
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tile-dashboard.service.js","sourceRoot":"","sources":["../../../../../../../../../libs/components/tiles/src/lib/modules/tiles/tile-dashboard/tile-dashboard.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ComponentRef,\n  EventEmitter,\n  Injectable,\n  Optional,\n  Output,\n  QueryList,\n} from '@angular/core';\nimport {\n  SkyDynamicComponentLocation,\n  SkyDynamicComponentService,\n  SkyMediaBreakpoints,\n  SkyMediaQueryService,\n  SkyUIConfigService,\n} from '@skyux/core';\n\nimport { DragulaService } from 'ng2-dragula';\nimport { Subscription } from 'rxjs';\nimport { take } from 'rxjs/operators';\n\nimport { SkyTileDashboardColumnComponent } from '../tile-dashboard-column/tile-dashboard-column.component';\nimport { SkyTileDashboardConfig } from '../tile-dashboard-config/tile-dashboard-config';\nimport { SkyTileDashboardConfigLayoutColumn } from '../tile-dashboard-config/tile-dashboard-config-layout-column';\nimport { SkyTileDashboardConfigLayoutTile } from '../tile-dashboard-config/tile-dashboard-config-layout-tile';\nimport { SkyTileDashboardConfigTile } from '../tile-dashboard-config/tile-dashboard-config-tile';\nimport { SkyTileComponent } from '../tile/tile.component';\n\nconst ATTR_TILE_ID = '_sky-tile-dashboard-tile-id';\n\nlet bagIdIndex = 0;\n\n@Injectable()\nexport class SkyTileDashboardService {\n  /**\n   * @internal\n   */\n  public bagId: string;\n\n  /**\n   * @internal\n   */\n  public configChange = new EventEmitter<SkyTileDashboardConfig>();\n\n  /**\n   * Fires when the tile dashboard's initialization is complete.\n   */\n  @Output()\n  public dashboardInitialized = new EventEmitter<void>();\n\n  #columns: QueryList<SkyTileDashboardColumnComponent> | undefined;\n  #config: SkyTileDashboardConfig | undefined;\n  #dragulaService: DragulaService;\n  #dynamicComponentService: SkyDynamicComponentService | undefined;\n  #mediaSubscription: Subscription | undefined;\n  #mediaQuery: SkyMediaQueryService;\n  #singleColumn: SkyTileDashboardColumnComponent | undefined;\n  #settingsKey: string | undefined;\n  #tileComponents: ComponentRef<any>[] | undefined;\n  #uiConfigService: SkyUIConfigService;\n\n  // TODO: remove @optional tag in a future breaking change\n  constructor(\n    dragulaService: DragulaService,\n    mediaQuery: SkyMediaQueryService,\n    uiConfigService: SkyUIConfigService,\n    @Optional() dynamicComponentService?: SkyDynamicComponentService\n  ) {\n    if (!dynamicComponentService) {\n      console.warn(\n        'The SkyTileDashboardService was created without a reference to the SkyDynamicComponentService. The service will be unable to create tiles from the dashboard configuration. Constructing the SkyTileDashboardService without a SkyDynamicComponentService will be removed in a future breaking change.'\n      );\n    }\n\n    this.#dragulaService = dragulaService;\n    this.#dynamicComponentService = dynamicComponentService;\n    this.#mediaQuery = mediaQuery;\n    this.#uiConfigService = uiConfigService;\n\n    this.bagId = `sky-tile-dashboard-bag-${++bagIdIndex}`;\n\n    this.#initDragula();\n  }\n\n  /**\n   * @internal\n   */\n  public init(\n    config: SkyTileDashboardConfig,\n    columns?: QueryList<SkyTileDashboardColumnComponent>,\n    singleColumn?: SkyTileDashboardColumnComponent,\n    settingsKey?: string\n  ): void {\n    if (settingsKey) {\n      // Clone this so changes to the config object outside of this class don't modify\n      // the config used inside and vice versa.\n      this.#config = Object.assign({}, config) as SkyTileDashboardConfig;\n\n      this.#settingsKey = settingsKey;\n\n      this.#uiConfigService\n        .getConfig(settingsKey, config)\n        .pipe(take(1))\n        .subscribe(\n          (value: any) => {\n            if (this.#config && value.persisted) {\n              this.#config.layout = value.layout;\n              this.#checkForNewTiles(value.tileIds);\n              this.configChange.emit(this.#config);\n\n              this.#columns = columns;\n              this.#singleColumn = singleColumn;\n              this.#checkReadyAndLoadTiles();\n            } else {\n              // Bad data, or config is the default config.\n              this.#initToDefaults(config, columns, singleColumn);\n            }\n          },\n          (error: any) => {\n            // Config setting key doesn't exist or other config service error\n            this.#initToDefaults(config, columns, singleColumn);\n          }\n        );\n    } else {\n      this.#initToDefaults(config, columns, singleColumn);\n    }\n  }\n\n  /**\n   * Adds a new tile to the tile dashboard.\n   * @param tile Specifies the tile configuration.\n   * @param component Specifies the tile component to add.\n   */\n  public addTileComponent(\n    tile: SkyTileDashboardConfigLayoutTile,\n    component: ComponentRef<any>\n  ): void {\n    this.#tileComponents = this.#tileComponents || [];\n\n    this.#tileComponents.push(component);\n\n    component.location.nativeElement.setAttribute(ATTR_TILE_ID, tile.id);\n  }\n\n  /**\n   * Checks whether a specified tile is collapsed.\n   * @param tile Specifies the tile component to check.\n   */\n  public tileIsCollapsed(tile: SkyTileComponent): boolean {\n    const tileConfig = this.#findTile(this.#getTileId(tile));\n\n    if (tileConfig) {\n      return tileConfig.isCollapsed;\n    }\n\n    return false;\n  }\n\n  /**\n   * Sets the collapsed state of all tiles.\n   * @param isCollapsed Indicates whether tiles are collapsed.\n   */\n  public setAllTilesCollapsed(isCollapsed: boolean): void {\n    /*istanbul ignore else */\n    if (this.#config && this.#config.layout.multiColumn) {\n      for (const column of this.#config.layout.multiColumn) {\n        for (const tile of column.tiles) {\n          tile.isCollapsed = isCollapsed;\n        }\n      }\n      for (const tile of this.#config.layout.singleColumn.tiles) {\n        tile.isCollapsed = isCollapsed;\n      }\n    }\n\n    if (this.#settingsKey) {\n      this.#setUserConfig(this.#config);\n    }\n\n    this.configChange.emit(this.#config);\n  }\n\n  /**\n   * Sets the collapsed state of a specified tile.\n   * @param tile Specifies the tile component.\n   * @param isCollapsed Indicates whether the tile is collapsed.\n   */\n  public setTileCollapsed(\n    tile: SkyTileComponent | undefined,\n    isCollapsed: boolean\n  ): void {\n    const tileConfig = this.#findTile(this.#getTileId(tile));\n\n    if (tileConfig) {\n      tileConfig.isCollapsed = isCollapsed;\n\n      if (this.#settingsKey) {\n        this.#setUserConfig(this.#config);\n      }\n\n      this.configChange.emit(this.#config);\n    }\n  }\n\n  /**\n   * @internal\n   */\n  public getTileComponentType(\n    layoutTile: SkyTileDashboardConfigLayoutTile | undefined\n  ): any {\n    if (layoutTile && this.#config) {\n      for (const tile of this.#config.tiles) {\n        if (tile.id === layoutTile.id) {\n          return tile.componentType;\n        }\n      }\n    }\n\n    return undefined;\n  }\n\n  /**\n   * @internal\n   */\n  public changeColumnMode(isSingleColumn: boolean): void {\n    /*istanbul ignore else */\n    if (this.#config) {\n      if (isSingleColumn) {\n        this.#moveTilesToSingleColumn();\n      } else {\n        this.#moveTilesToMultiColumn();\n      }\n    }\n  }\n\n  /**\n   * @internal\n   */\n  public getTileComponent(tileId: string): ComponentRef<any> | undefined {\n    if (this.#tileComponents) {\n      for (const tileComponent of this.#tileComponents) {\n        if (\n          tileComponent.location.nativeElement.getAttribute(ATTR_TILE_ID) ===\n          tileId\n        ) {\n          return tileComponent;\n        }\n      }\n    }\n\n    /*istanbul ignore next */\n    return undefined;\n  }\n\n  /**\n   * @internal\n   */\n  public destroy(): void {\n    /*istanbul ignore else */\n    if (this.#mediaSubscription) {\n      this.#mediaSubscription.unsubscribe();\n    }\n  }\n\n  /**\n   * @internal\n   */\n  public moveTileOnKeyDown(\n    tileCmp: SkyTileComponent,\n    direction: string,\n    tileDescription: string\n  ): void {\n    if (this.#config) {\n      const isSingleColumnMode =\n        this.#mediaQuery.current === SkyMediaBreakpoints.xs ||\n        this.#mediaQuery.current === SkyMediaBreakpoints.sm;\n\n      const tileId = this.#getTileId(tileCmp);\n      const tile = this.#findTile(tileId);\n\n      let column: SkyTileDashboardConfigLayoutColumn | undefined;\n      let colIndex = 0;\n      if (isSingleColumnMode) {\n        column = this.#config.layout.singleColumn;\n      } else {\n        column = this.#findTileColumn(tileId);\n        colIndex = this.#config.layout.multiColumn.findIndex(\n          (value) => value === column\n        );\n      }\n\n      if (column && tile && tileId) {\n        if (\n          (direction === 'left' || direction === 'right') &&\n          !isSingleColumnMode\n        ) {\n          const operator = direction === 'left' ? -1 : 1;\n          const newColumn =\n            this.#config.layout.multiColumn[colIndex + operator];\n\n          if (newColumn) {\n            // Move the tile to the end of the new column\n            newColumn.tiles.push(tile);\n            column.tiles = column.tiles.filter((item) => item !== tile);\n            this.#moveTilesToColumn(\n              this.#columns?.toArray()[colIndex + operator],\n              [tile]\n            );\n\n            // Report the change in configuration\n            const reportConfig = this.#config;\n            reportConfig.movedTile = {\n              tileDescription:\n                tileDescription || /* istanbul ignore next */ tile.id,\n              column: colIndex + operator + 1,\n              position: newColumn.tiles.length,\n            };\n            this.configChange.emit(reportConfig);\n          }\n        } else {\n          const operator = direction === 'up' ? -1 : 1;\n          const curIndex = column.tiles.findIndex(\n            (value) => value.id === tile.id\n          );\n          const tileComponentInstance = this.getTileComponent(tileId);\n\n          if (tileComponentInstance && column.tiles[curIndex + operator]) {\n            const temp = column.tiles[curIndex + operator];\n            column.tiles[curIndex + operator] = tile;\n            column.tiles[curIndex] = temp;\n\n            // Get the column element\n            let columnEl: Element | undefined;\n            if (isSingleColumnMode) {\n              columnEl = this.#getColumnEl(this.#singleColumn);\n            } else {\n              columnEl = this.#getColumnEl(this.#columns?.toArray()[colIndex]);\n            }\n\n            // Move the tile element in the document\n            if (curIndex + operator === column.tiles.length - 1) {\n              columnEl?.appendChild(\n                tileComponentInstance.location.nativeElement\n              );\n            } else {\n              columnEl?.insertBefore(\n                tileComponentInstance.location.nativeElement,\n                this.getTileComponent(column.tiles[curIndex + operator + 1].id)\n                  ?.location.nativeElement\n              );\n            }\n\n            // Report the change in configuration\n            const reportConfig = this.#config;\n            reportConfig.movedTile = {\n              tileDescription:\n                tileDescription || /* istanbul ignore next */ tile.id,\n              column: isSingleColumnMode ? 1 : colIndex + 1,\n              position: curIndex + operator + 1,\n            };\n            this.configChange.emit(reportConfig);\n          }\n        }\n      }\n    }\n  }\n\n  #getTileId(tile: SkyTileComponent | undefined): string | undefined {\n    if (tile) {\n      let el = tile.elementRef.nativeElement;\n      let tileId: string;\n\n      while (el) {\n        tileId = el.getAttribute(ATTR_TILE_ID);\n\n        if (tileId) {\n          return tileId;\n        }\n\n        el = el.parentElement;\n      }\n    }\n\n    return undefined;\n  }\n\n  #getTileOrRemoveFromLayout(\n    layoutTile: SkyTileDashboardConfigLayoutTile\n  ): SkyTileDashboardConfigTile | undefined {\n    /*istanbul ignore else */\n    if (layoutTile && this.#config) {\n      for (const tile of this.#config.tiles) {\n        if (tile.id === layoutTile.id) {\n          return tile;\n        }\n      }\n\n      // If the layout tile was not found in the list of tiles, it was removed since last the user updated settings\n      /*istanbul ignore else */\n      if (this.#config?.layout.singleColumn) {\n        this.#config.layout.singleColumn.tiles =\n          this.#config.layout.singleColumn.tiles.filter(\n            (elem) => elem.id !== layoutTile.id\n          );\n      }\n\n      /*istanbul ignore else */\n      if (this.#config?.layout.multiColumn) {\n        this.#config.layout.multiColumn.forEach((elem) => {\n          elem.tiles = elem.tiles.filter((res) => res.id !== layoutTile.id);\n        });\n      }\n    }\n\n    /*istanbul ignore next */\n    return undefined;\n  }\n\n  #checkReadyAndLoadTiles(): void {\n    if (this.#config && this.#columns) {\n      this.#loadTiles(this.#config);\n      this.#initMediaQueries();\n      this.dashboardInitialized.emit();\n    }\n  }\n\n  #loadTiles(config: SkyTileDashboardConfig): void {\n    const layout = config.layout;\n\n    if (\n      this.#mediaQuery.current === SkyMediaBreakpoints.xs ||\n      this.#mediaQuery.current === SkyMediaBreakpoints.sm\n    ) {\n      for (const tile of layout.singleColumn.tiles) {\n        this.#loadTileIntoColumn(this.#singleColumn, tile);\n      }\n    } else {\n      let columns: SkyTileDashboardColumnComponent[] = [];\n      /*istanbul ignore else */\n      if (this.#columns) {\n        columns = this.#columns?.toArray();\n      }\n\n      for (let i = 0, n = layout.multiColumn.length; i < n; i++) {\n        const column = columns[i];\n\n        for (const tile of layout.multiColumn[i].tiles) {\n          this.#loadTileIntoColumn(column, tile);\n        }\n      }\n    }\n  }\n\n  #loadTileIntoColumn(\n    column: SkyTileDashboardColumnComponent | undefined,\n    layoutTile: SkyTileDashboardConfigLayoutTile\n  ): void {\n    if (column) {\n      const tile = this.#getTileOrRemoveFromLayout(layoutTile);\n\n      /*istanbul ignore else */\n      if (tile && this.#dynamicComponentService) {\n        const componentType = tile.componentType;\n        const providers = tile.providers /* istanbul ignore next */ || [];\n\n        const componentRef = this.#dynamicComponentService.createComponent(\n          componentType,\n          {\n            location: SkyDynamicComponentLocation.ElementBottom,\n            providers: providers,\n            referenceEl: column.content?.nativeElement,\n            parentInjector: column.injector,\n          }\n        );\n\n        this.addTileComponent(layoutTile, componentRef);\n\n        // Make sure the component is marked for changes in case the parent component uses\n        // the OnPush change detection strategy.\n        componentRef.changeDetectorRef.markForCheck();\n      }\n    }\n  }\n\n  #moveTilesToSingleColumn(): void {\n    this.#moveTilesToColumn(\n      this.#singleColumn,\n      this.#config?.layout.singleColumn.tiles\n    );\n  }\n\n  #moveTilesToMultiColumn(): void {\n    let layoutColumns: SkyTileDashboardConfigLayoutColumn[] = [];\n    /*istanbul ignore else */\n    if (this.#config) {\n      layoutColumns = this.#config.layout.multiColumn;\n    }\n    let columns: SkyTileDashboardColumnComponent[] = [];\n    /*istanbul ignore else */\n    if (this.#columns) {\n      columns = this.#columns?.toArray();\n    }\n\n    for (let i = 0, n = layoutColumns.length; i < n; i++) {\n      this.#moveTilesToColumn(columns[i], layoutColumns[i].tiles);\n    }\n  }\n\n  #moveTilesToColumn(\n    column: SkyTileDashboardColumnComponent | undefined,\n    layoutTiles: SkyTileDashboardConfigLayoutTile[] | undefined\n  ): void {\n    if (column && layoutTiles) {\n      const columnEl = this.#getColumnEl(column);\n\n      for (const layoutTile of layoutTiles) {\n        const tileComponentInstance = this.getTileComponent(layoutTile.id);\n\n        /*istanbul ignore else */\n        if (tileComponentInstance) {\n          columnEl?.appendChild(tileComponentInstance.location.nativeElement);\n        }\n      }\n    }\n  }\n\n  #getConfigForUIState(): SkyTileDashboardConfig | undefined {\n    /*istanbul ignore else */\n    if (this.#config) {\n      this.#config = {\n        tiles: this.#config.tiles,\n        layout: {\n          singleColumn: this.#getSingleColumnLayoutForUIState(this.#config),\n          multiColumn: this.#getMultiColumnLayoutForUIState(this.#config),\n        },\n      };\n    }\n\n    return this.#config;\n  }\n\n  #getSingleColumnLayoutForUIState(\n    config: SkyTileDashboardConfig\n  ): SkyTileDashboardConfigLayoutColumn {\n    if (\n      this.#mediaQuery.current === SkyMediaBreakpoints.xs ||\n      this.#mediaQuery.current === SkyMediaBreakpoints.sm\n    ) {\n      return {\n        tiles: this.#getTilesInEl(this.#getColumnEl(this.#singleColumn)),\n      };\n    }\n\n    return config.layout.singleColumn;\n  }\n\n  #getMultiColumnLayoutForUIState(\n    config: SkyTileDashboardConfig\n  ): SkyTileDashboardConfigLayoutColumn[] {\n    if (\n      !(\n        this.#mediaQuery.current === SkyMediaBreakpoints.xs ||\n        this.#mediaQuery.current === SkyMediaBreakpoints.sm\n      )\n    ) {\n      const layoutColumns: SkyTileDashboardConfigLayoutColumn[] = [];\n      let columns: SkyTileDashboardColumnComponent[] = [];\n      /*istanbul ignore else */\n      if (this.#columns) {\n        columns = this.#columns?.toArray();\n      }\n\n      for (const column of columns) {\n        if (column !== this.#singleColumn) {\n          const layoutColumn: SkyTileDashboardConfigLayoutColumn = {\n            tiles: this.#getTilesInEl(this.#getColumnEl(column)),\n          };\n\n          layoutColumns.push(layoutColumn);\n        }\n      }\n\n      return layoutColumns;\n    }\n\n    return config.layout.multiColumn;\n  }\n\n  #getTilesInEl(el: Element | undefined): SkyTileDashboardConfigLayoutTile[] {\n    const tileEls = el?.querySelectorAll('[' + ATTR_TILE_ID + ']');\n    const layoutTiles: SkyTileDashboardConfigLayoutTile[] = [];\n\n    /*istanbul ignore else */\n    if (tileEls) {\n      for (let i = 0, n = tileEls.length; i < n; i++) {\n        const tileEl = tileEls[i];\n        const tileId = tileEl.getAttribute(ATTR_TILE_ID);\n        const tile = this.#findTile(tileId);\n\n        /*istanbul ignore else */\n        if (tile) {\n          layoutTiles.push(tile);\n        }\n      }\n    }\n\n    return layoutTiles;\n  }\n\n  #initMediaQueries(): void {\n    /*istanbul ignore else */\n    if (!this.#mediaSubscription) {\n      this.#mediaSubscription = this.#mediaQuery.subscribe(\n        (args: SkyMediaBreakpoints) => {\n          this.changeColumnMode(\n            args === SkyMediaBreakpoints.xs || args === SkyMediaBreakpoints.sm\n          );\n        }\n      );\n    }\n  }\n\n  #initDragula(): void {\n    this.#dragulaService.createGroup(this.bagId, {\n      moves: (el, container, handle) => {\n        const target = el?.querySelector('.sky-tile-grab-handle');\n        return !!target && target.contains(handle!);\n      },\n    });\n\n    this.#dragulaService.drop(this.bagId).subscribe(() => {\n      const config = this.#getConfigForUIState();\n\n      /*istanbul ignore else */\n      if (config) {\n        if (this.#settingsKey) {\n          this.#setUserConfig(config);\n        }\n\n        this.configChange.emit(config);\n      }\n    });\n  }\n\n  #getColumnEl(\n    column: SkyTileDashboardColumnComponent | undefined\n  ): Element | undefined {\n    return column?.content?.nativeElement.parentNode;\n  }\n\n  #findTile(\n    tileId: string | undefined | null\n  ): SkyTileDashboardConfigLayoutTile | undefined {\n    /*istanbul ignore else */\n    if (this.#config && this.#config.layout.multiColumn) {\n      for (const column of this.#config.layout.multiColumn) {\n        /*istanbul ignore else */\n        if (column.tiles) {\n          for (const tile of column.tiles) {\n            if (tile.id === tileId) {\n              return tile;\n            }\n          }\n        }\n      }\n    }\n\n    return undefined;\n  }\n\n  #findTileColumn(\n    tileId: string | undefined\n  ): SkyTileDashboardConfigLayoutColumn | undefined {\n    /*istanbul ignore else */\n    if (this.#config && this.#config.layout.multiColumn) {\n      return this.#config.layout.multiColumn.find(\n        (col) => col.tiles && !!col.tiles.find((tile) => tile.id === tileId)\n      );\n    }\n\n    /*istanbul ignore next */\n    return undefined;\n  }\n\n  #initToDefaults(\n    config: SkyTileDashboardConfig,\n    columns: QueryList<SkyTileDashboardColumnComponent> | undefined,\n    singleColumn: SkyTileDashboardColumnComponent | undefined\n  ): void {\n    this.#config = config;\n    this.#columns = columns;\n    this.#singleColumn = singleColumn;\n    this.#checkReadyAndLoadTiles();\n  }\n\n  #setUserConfig(config?: SkyTileDashboardConfig): void {\n    if (config && this.#settingsKey)\n      this.#uiConfigService\n        .setConfig(this.#settingsKey, {\n          layout: config.layout,\n          persisted: true,\n          tileIds: config.tiles.map((elem) => elem.id),\n        })\n        .subscribe(\n          // eslint-disable-next-line @typescript-eslint/no-empty-function\n          () => {},\n          (err) => {\n            console.warn('Could not save tile dashboard settings.');\n            console.warn(err);\n          }\n        );\n  }\n\n  #checkForNewTiles(oldUserTiles: string[]): void {\n    // Get a list of tiles that are in the config's default list but not in the user's settings\n    const newTiles = this.#config?.tiles.filter((elem) => {\n      return oldUserTiles.indexOf(elem.id) === -1;\n    });\n\n    const multiColumn = this.#config?.layout.multiColumn;\n    const singleColumn = this.#config?.layout.singleColumn;\n\n    // Append new tiles to the end of the layouts\n    /*istanbul ignore else */\n    if (newTiles?.length) {\n      /*istanbul ignore else */\n      if (multiColumn) {\n        newTiles?.forEach((elem) => {\n          let locationToAdd = 0;\n          let smallest = multiColumn[0].tiles.length;\n          multiColumn.forEach((item, index) => {\n            if (item.tiles.length < smallest) {\n              locationToAdd = index;\n              smallest = item.tiles.length;\n            }\n          });\n          multiColumn[locationToAdd].tiles.push({\n            id: elem.id,\n            isCollapsed: false,\n          });\n        });\n      }\n\n      /*istanbul ignore else */\n      if (singleColumn) {\n        newTiles?.forEach((elem) => {\n          singleColumn.tiles.push({ id: elem.id, isCollapsed: false });\n        });\n      }\n    }\n\n    /*istanbul ignore else */\n    if (singleColumn) {\n      for (const tile of singleColumn.tiles) {\n        this.#getTileOrRemoveFromLayout(tile);\n      }\n    }\n\n    /*istanbul ignore else */\n    if (multiColumn) {\n      for (let i = 0, n = multiColumn.length; i < n; i++) {\n        for (const tile of multiColumn[i].tiles) {\n          this.#getTileOrRemoveFromLayout(tile);\n        }\n      }\n    }\n  }\n}\n"]}