@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.
- package/documentation.json +402 -203
- package/esm2020/lib/modules/shared/sky-tiles-resources.module.mjs +5 -5
- package/esm2020/lib/modules/tiles/tile/tile-summary.component.mjs +4 -4
- package/esm2020/lib/modules/tiles/tile/tile-title.component.mjs +4 -4
- package/esm2020/lib/modules/tiles/tile/tile.component.mjs +36 -32
- package/esm2020/lib/modules/tiles/tile/tile.module.mjs +5 -5
- package/esm2020/lib/modules/tiles/tile-content/tile-content-section.component.mjs +4 -4
- package/esm2020/lib/modules/tiles/tile-content/tile-content.component.mjs +4 -4
- package/esm2020/lib/modules/tiles/tile-content/tile-content.module.mjs +5 -5
- package/esm2020/lib/modules/tiles/tile-dashboard/tile-dashboard.component.mjs +45 -35
- package/esm2020/lib/modules/tiles/tile-dashboard/tile-dashboard.module.mjs +5 -5
- package/esm2020/lib/modules/tiles/tile-dashboard/tile-dashboard.service.mjs +353 -327
- package/esm2020/lib/modules/tiles/tile-dashboard-column/tile-dashboard-column.component.mjs +15 -14
- package/esm2020/lib/modules/tiles/tile-dashboard-column/tile-dashboard-column.module.mjs +5 -5
- package/esm2020/lib/modules/tiles/tiles.module.mjs +5 -5
- package/fesm2015/skyux-tiles.mjs +486 -433
- package/fesm2015/skyux-tiles.mjs.map +1 -1
- package/fesm2020/skyux-tiles.mjs +475 -433
- package/fesm2020/skyux-tiles.mjs.map +1 -1
- package/lib/modules/tiles/tile/tile.component.d.ts +5 -9
- package/lib/modules/tiles/tile-dashboard/tile-dashboard.component.d.ts +8 -14
- package/lib/modules/tiles/tile-dashboard/tile-dashboard.service.d.ts +7 -36
- package/lib/modules/tiles/tile-dashboard-column/tile-dashboard-column.component.d.ts +4 -5
- package/package.json +8 -8
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
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
|
-
|
|
12
|
-
|
|
13
|
-
this
|
|
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
|
|
24
|
-
|
|
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
|
|
34
|
-
this
|
|
35
|
-
this
|
|
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.
|
|
41
|
-
this.
|
|
42
|
-
this.configChange.emit(this
|
|
43
|
-
this
|
|
44
|
-
this
|
|
45
|
-
this.
|
|
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.
|
|
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.
|
|
70
|
+
__classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_initToDefaults).call(this, config, columns, singleColumn);
|
|
54
71
|
});
|
|
55
72
|
}
|
|
56
73
|
else {
|
|
57
|
-
this.
|
|
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
|
|
67
|
-
this.
|
|
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.
|
|
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
|
|
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
|
|
88
|
-
for (const column of this.
|
|
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.
|
|
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
|
|
98
|
-
this.
|
|
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
|
|
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.
|
|
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
|
|
112
|
-
this.
|
|
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
|
|
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.
|
|
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
|
|
152
|
+
if (__classPrivateFieldGet(this, _SkyTileDashboardService_config, "f")) {
|
|
136
153
|
if (isSingleColumn) {
|
|
137
|
-
this.
|
|
154
|
+
__classPrivateFieldGet(this, _SkyTileDashboardService_instances, "m", _SkyTileDashboardService_moveTilesToSingleColumn).call(this);
|
|
138
155
|
}
|
|
139
156
|
else {
|
|
140
|
-
this.
|
|
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
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
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
|
|
163
|
-
this.
|
|
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
|
-
|
|
171
|
-
this.
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
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
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
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
|
-
|
|
226
|
-
|
|
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
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
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
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
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
|
-
|
|
275
|
-
|
|
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
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
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
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
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
|
-
|
|
293
|
-
const
|
|
294
|
-
for (
|
|
295
|
-
|
|
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
|
-
|
|
303
|
-
|
|
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
|
|
309
|
-
|
|
310
|
-
|
|
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
|
-
|
|
321
|
-
|
|
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
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
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
|
-
|
|
331
|
-
|
|
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
|
|
366
|
+
columnEl?.appendChild(tileComponentInstance.location.nativeElement);
|
|
337
367
|
}
|
|
338
368
|
}
|
|
339
369
|
}
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
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
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
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
|
-
|
|
380
|
-
|
|
381
|
-
|
|
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 (
|
|
384
|
-
|
|
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
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
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
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
const
|
|
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 (
|
|
415
|
-
|
|
416
|
-
this.setUserConfig(config);
|
|
417
|
-
}
|
|
418
|
-
this.configChange.emit(config);
|
|
420
|
+
if (tile) {
|
|
421
|
+
layoutTiles.push(tile);
|
|
419
422
|
}
|
|
420
|
-
}
|
|
423
|
+
}
|
|
421
424
|
}
|
|
422
|
-
|
|
423
|
-
|
|
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
|
-
|
|
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 (
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
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
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
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
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
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:
|
|
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
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
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 (
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
|
|
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
|
-
|
|
496
|
-
|
|
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
|
-
|
|
505
|
-
|
|
506
|
-
}
|
|
522
|
+
newTiles?.forEach((elem) => {
|
|
523
|
+
singleColumn.tiles.push({ id: elem.id, isCollapsed: false });
|
|
524
|
+
});
|
|
507
525
|
}
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
|
|
511
|
-
|
|
512
|
-
|
|
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.
|
|
519
|
-
SkyTileDashboardService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.
|
|
520
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.
|
|
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 }
|
|
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":"AAAA,OAAO,EAEL,YAAY,EACZ,UAAU,EACV,QAAQ,EACR,MAAM,GAEP,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,mBAAmB,EACnB,oBAAoB,EACpB,kBAAkB,GACnB,MAAM,aAAa,CAAC;AAErB,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAE7C,OAAO,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;;;;AAStC,MAAM,YAAY,GAAG,6BAA6B,CAAC;AAEnD,IAAI,UAAU,GAAG,CAAC,CAAC;AAGnB,MAAM,OAAO,uBAAuB;IA+BlC,YACU,cAA8B,EAC9B,UAAgC,EAChC,eAAmC;QAFnC,mBAAc,GAAd,cAAc,CAAgB;QAC9B,eAAU,GAAV,UAAU,CAAsB;QAChC,oBAAe,GAAf,eAAe,CAAoB;QA5B7C;;WAEG;QACI,iBAAY,GAAG,IAAI,YAAY,EAA0B,CAAC;QAEjE;;WAEG;QAEI,yBAAoB,GAAG,IAAI,YAAY,EAAQ,CAAC;QAqBrD,IAAI,CAAC,KAAK,GAAG,yBAAyB,GAAG,EAAE,UAAU,CAAC;QAEtD,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED;;OAEG;IACI,IAAI,CACT,MAA8B,EAC9B,OAAoD,EACpD,YAA8C,EAC9C,WAAoB;QAEpB,IAAI,WAAW,EAAE;YACf,gFAAgF;YAChF,yCAAyC;YACzC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,MAAM,CAAC,CAAC;YAE7D,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;YAE/B,IAAI,CAAC,eAAe;iBACjB,SAAS,CAAC,WAAW,EAAE,MAAM,CAAC;iBAC9B,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;iBACb,SAAS,CACR,CAAC,KAAU,EAAE,EAAE;gBACb,IAAI,KAAK,CAAC,SAAS,EAAE;oBACnB,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;oBAClC,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;oBACrC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;oBAEpC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;oBACvB,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;oBACjC,IAAI,CAAC,sBAAsB,EAAE,CAAC;iBAC/B;qBAAM;oBACL,6CAA6C;oBAC7C,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,OAAO,EAAE,YAAY,CAAC,CAAC;iBACpD;YACH,CAAC,EACD,CAAC,KAAU,EAAE,EAAE;gBACb,iEAAiE;gBACjE,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,OAAO,EAAE,YAAY,CAAC,CAAC;YACrD,CAAC,CACF,CAAC;SACL;aAAM;YACL,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,OAAO,EAAE,YAAY,CAAC,CAAC;SACpD;IACH,CAAC;IAED;;;;OAIG;IACI,gBAAgB,CACrB,IAAsC,EACtC,SAA4B;QAE5B,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,IAAI,EAAE,CAAC;QAEhD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAEpC,SAAS,CAAC,QAAQ,CAAC,aAAa,CAAC,YAAY,CAAC,YAAY,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;IACvE,CAAC;IAED;;;OAGG;IACI,eAAe,CAAC,IAAsB;QAC3C,MAAM,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC;QAEvD,IAAI,UAAU,EAAE;YACd,OAAO,UAAU,CAAC,WAAW,CAAC;SAC/B;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;IAED;;;OAGG;IACI,oBAAoB,CAAC,WAAoB;QAC9C,yBAAyB;QACzB,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,WAAW,EAAE;YACjD,KAAK,MAAM,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,WAAW,EAAE;gBACnD,KAAK,MAAM,IAAI,IAAI,MAAM,CAAC,KAAK,EAAE;oBAC/B,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;iBAChC;aACF;YACD,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,KAAK,EAAE;gBACxD,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;aAChC;SACF;QAED,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SACjC;QAED,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACtC,CAAC;IAED;;;;OAIG;IACI,gBAAgB,CAAC,IAAsB,EAAE,WAAoB;QAClE,MAAM,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC;QAEvD,IAAI,UAAU,EAAE;YACd,UAAU,CAAC,WAAW,GAAG,WAAW,CAAC;YAErC,IAAI,IAAI,CAAC,WAAW,EAAE;gBACpB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;aACjC;YAED,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SACrC;IACH,CAAC;IAED;;OAEG;IACI,oBAAoB,CACzB,UAA4C;QAE5C,IAAI,UAAU,EAAE;YACd,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE;gBACpC,IAAI,IAAI,CAAC,EAAE,KAAK,UAAU,CAAC,EAAE,EAAE;oBAC7B,OAAO,IAAI,CAAC,aAAa,CAAC;iBAC3B;aACF;SACF;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;IAED;;OAEG;IACI,gBAAgB,CAAC,cAAuB;QAC7C,yBAAyB;QACzB,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,cAAc,EAAE;gBAClB,IAAI,CAAC,uBAAuB,EAAE,CAAC;aAChC;iBAAM;gBACL,IAAI,CAAC,sBAAsB,EAAE,CAAC;aAC/B;SACF;IACH,CAAC;IAED;;OAEG;IACI,gBAAgB,CAAC,MAAc;QACpC,KAAK,MAAM,aAAa,IAAI,IAAI,CAAC,cAAc,EAAE;YAC/C,IACE,aAAa,CAAC,QAAQ,CAAC,aAAa,CAAC,YAAY,CAAC,YAAY,CAAC;gBAC/D,MAAM,EACN;gBACA,OAAO,aAAa,CAAC;aACtB;SACF;QAED,yBAAyB;QACzB,OAAO,SAAS,CAAC;IACnB,CAAC;IAED;;OAEG;IACI,OAAO;QACZ,yBAAyB;QACzB,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE,CAAC;SACtC;IACH,CAAC;IAED;;OAEG;IACI,iBAAiB,CACtB,OAAyB,EACzB,SAAiB,EACjB,eAAuB;QAEvB,MAAM,kBAAkB,GACtB,IAAI,CAAC,UAAU,CAAC,OAAO,KAAK,mBAAmB,CAAC,EAAE;YAClD,IAAI,CAAC,UAAU,CAAC,OAAO,KAAK,mBAAmB,CAAC,EAAE,CAAC;QAErD,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QACvC,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QAEnC,IAAI,MAA0C,CAAC;QAC/C,IAAI,QAAgB,CAAC;QACrB,IAAI,kBAAkB,EAAE;YACtB,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC;SAC1C;aAAM;YACL,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;YACrC,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,SAAS,CACjD,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,KAAK,MAAM,CAC5B,CAAC;SACH;QAED,IACE,CAAC,SAAS,KAAK,MAAM,IAAI,SAAS,KAAK,OAAO,CAAC;YAC/C,CAAC,kBAAkB,EACnB;YACA,MAAM,QAAQ,GAAG,SAAS,KAAK,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC/C,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,QAAQ,GAAG,QAAQ,CAAC,CAAC;YAEtE,IAAI,SAAS,EAAE;gBACb,6CAA6C;gBAC7C,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAC3B,MAAM,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC;gBAC5D,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,QAAQ,GAAG,QAAQ,CAAC,EAAE;oBAClE,IAAI;iBACL,CAAC,CAAC;gBAEH,qCAAqC;gBACrC,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC;gBACjC,YAAY,CAAC,SAAS,GAAG;oBACvB,eAAe,EACb,eAAe,IAAI,0BAA0B,CAAC,IAAI,CAAC,EAAE;oBACvD,MAAM,EAAE,QAAQ,GAAG,QAAQ,GAAG,CAAC;oBAC/B,QAAQ,EAAE,SAAS,CAAC,KAAK,CAAC,MAAM;iBACjC,CAAC;gBACF,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;aACtC;SACF;aAAM;YACL,MAAM,QAAQ,GAAG,SAAS,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC7C,MAAM,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,CAAC,CAAC;YACzE,MAAM,qBAAqB,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;YAE5D,IAAI,qBAAqB,IAAI,MAAM,CAAC,KAAK,CAAC,QAAQ,GAAG,QAAQ,CAAC,EAAE;gBAC9D,MAAM,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC,QAAQ,GAAG,QAAQ,CAAC,CAAC;gBAC/C,MAAM,CAAC,KAAK,CAAC,QAAQ,GAAG,QAAQ,CAAC,GAAG,IAAI,CAAC;gBACzC,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC;gBAE9B,yBAAyB;gBACzB,IAAI,QAAiB,CAAC;gBACtB,IAAI,kBAAkB,EAAE;oBACtB,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;iBAChD;qBAAM;oBACL,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC;iBAC/D;gBAED,wCAAwC;gBACxC,IAAI,QAAQ,GAAG,QAAQ,KAAK,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;oBACnD,QAAQ,CAAC,WAAW,CAAC,qBAAqB,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;iBACpE;qBAAM;oBACL,QAAQ,CAAC,YAAY,CACnB,qBAAqB,CAAC,QAAQ,CAAC,aAAa,EAC5C,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,KAAK,CAAC,QAAQ,GAAG,QAAQ,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;yBAC5D,QAAQ,CAAC,aAAa,CAC1B,CAAC;iBACH;gBAED,qCAAqC;gBACrC,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC;gBACjC,YAAY,CAAC,SAAS,GAAG;oBACvB,eAAe,EACb,eAAe,IAAI,0BAA0B,CAAC,IAAI,CAAC,EAAE;oBACvD,MAAM,EAAE,kBAAkB,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,GAAG,CAAC;oBACrD,QAAQ,EAAE,QAAQ,GAAG,QAAQ,GAAG,CAAC;iBAClC,CAAC;gBACF,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;aACtC;SACF;IACH,CAAC;IAEO,SAAS,CAAC,IAAsB;QACtC,IAAI,IAAI,EAAE;YACR,IAAI,EAAE,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;YACvC,IAAI,MAAc,CAAC;YAEnB,OAAO,EAAE,EAAE;gBACT,MAAM,GAAG,EAAE,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC;gBAEvC,IAAI,MAAM,EAAE;oBACV,OAAO,MAAM,CAAC;iBACf;gBAED,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC;aACvB;SACF;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;IAEO,yBAAyB,CAC/B,UAA4C;QAE5C,yBAAyB;QACzB,IAAI,UAAU,EAAE;YACd,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE;gBACpC,IAAI,IAAI,CAAC,EAAE,KAAK,UAAU,CAAC,EAAE,EAAE;oBAC7B,OAAO,IAAI,CAAC;iBACb;aACF;YAED,6GAA6G;YAC7G,yBAAyB;YACzB,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,YAAY,EAAE;gBACnC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,KAAK;oBACnC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,KAAK,CAAC,MAAM,CAC1C,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,UAAU,CAAC,EAAE,CACpC,CAAC;aACL;YAED,yBAAyB;YACzB,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,WAAW,EAAE;gBAClC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;oBAC9C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,UAAU,CAAC,EAAE,CAAC,CAAC;gBACpE,CAAC,CAAC,CAAC;aACJ;SACF;QAED,yBAAyB;QACzB,OAAO,SAAS,CAAC;IACnB,CAAC;IAEO,sBAAsB;QAC5B,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,OAAO,EAAE;YAC/B,IAAI,CAAC,SAAS,EAAE,CAAC;YACjB,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACxB,IAAI,CAAC,oBAAoB,CAAC,IAAI,EAAE,CAAC;SAClC;IACH,CAAC;IAEO,SAAS;QACf,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;QAElC,IACE,IAAI,CAAC,UAAU,CAAC,OAAO,KAAK,mBAAmB,CAAC,EAAE;YAClD,IAAI,CAAC,UAAU,CAAC,OAAO,KAAK,mBAAmB,CAAC,EAAE,EAClD;YACA,KAAK,MAAM,IAAI,IAAI,MAAM,CAAC,YAAY,CAAC,KAAK,EAAE;gBAC5C,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;aAClD;SACF;aAAM;YACL,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;YAEvC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;gBACzD,MAAM,MAAM,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;gBAE1B,KAAK,MAAM,IAAI,IAAI,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE;oBAC9C,IAAI,CAAC,kBAAkB,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;iBACvC;aACF;SACF;IACH,CAAC;IAEO,kBAAkB,CACxB,MAAuC,EACvC,UAA4C;QAE5C,MAAM,IAAI,GAAG,IAAI,CAAC,yBAAyB,CAAC,UAAU,CAAC,CAAC;QAExD,yBAAyB;QACzB,IAAI,IAAI,EAAE;YACR,MAAM,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;YACzC,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,0BAA0B,IAAI,EAAE,CAAC;YAElE,MAAM,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC;gBAC/B,SAAS;gBACT,MAAM,EAAE,MAAM,CAAC,QAAQ;aACxB,CAAC,CAAC;YAEH,MAAM,OAAO,GAAG,MAAM,CAAC,QAAQ,CAAC,uBAAuB,CAAC,aAAa,CAAC,CAAC;YACvE,MAAM,YAAY,GAAG,MAAM,CAAC,OAAO,CAAC,eAAe,CACjD,OAAO,EACP,SAAS,EACT,QAAQ,CACT,CAAC;YAEF,IAAI,CAAC,gBAAgB,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;YAEhD,kFAAkF;YAClF,wCAAwC;YACxC,YAAY,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;SAC/C;IACH,CAAC;IAEO,uBAAuB;QAC7B,IAAI,CAAC,iBAAiB,CACpB,IAAI,CAAC,YAAY,EACjB,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,KAAK,CACtC,CAAC;IACJ,CAAC;IAEO,sBAAsB;QAC5B,MAAM,aAAa,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC;QACrD,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;QAEvC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,aAAa,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;YACpD,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;SAC5D;IACH,CAAC;IAEO,iBAAiB,CACvB,MAAuC,EACvC,WAA+C;QAE/C,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;QAE1C,KAAK,MAAM,UAAU,IAAI,WAAW,EAAE;YACpC,MAAM,qBAAqB,GAAG,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;YAEnE,yBAAyB;YACzB,IAAI,qBAAqB,EAAE;gBACzB,QAAQ,CAAC,WAAW,CAAC,qBAAqB,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;aACpE;SACF;IACH,CAAC;IAEO,mBAAmB;QACzB,yBAAyB;QACzB,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,MAAM,GAAG;gBACZ,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,KAAK;gBACxB,MAAM,EAAE;oBACN,YAAY,EAAE,IAAI,CAAC,+BAA+B,EAAE;oBACpD,WAAW,EAAE,IAAI,CAAC,8BAA8B,EAAE;iBACnD;aACF,CAAC;SACH;QAED,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAEO,+BAA+B;QACrC,IACE,IAAI,CAAC,UAAU,CAAC,OAAO,KAAK,mBAAmB,CAAC,EAAE;YAClD,IAAI,CAAC,UAAU,CAAC,OAAO,KAAK,mBAAmB,CAAC,EAAE,EAClD;YACA,OAAO;gBACL,KAAK,EAAE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;aAC9D,CAAC;SACH;QAED,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC;IACzC,CAAC;IAEO,8BAA8B;QACpC,IACE,CAAC,CACC,IAAI,CAAC,UAAU,CAAC,OAAO,KAAK,mBAAmB,CAAC,EAAE;YAClD,IAAI,CAAC,UAAU,CAAC,OAAO,KAAK,mBAAmB,CAAC,EAAE,CACnD,EACD;YACA,MAAM,aAAa,GAAyC,EAAE,CAAC;YAC/D,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;YAEvC,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE;gBAC5B,IAAI,MAAM,KAAK,IAAI,CAAC,YAAY,EAAE;oBAChC,MAAM,YAAY,GAAuC;wBACvD,KAAK,EAAE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;qBACnD,CAAC;oBAEF,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;iBAClC;aACF;YAED,OAAO,aAAa,CAAC;SACtB;QAED,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC;IACxC,CAAC;IAEO,YAAY,CAAC,EAAW;QAC9B,MAAM,OAAO,GAAQ,EAAE,CAAC,gBAAgB,CAAC,GAAG,GAAG,YAAY,GAAG,GAAG,CAAC,CAAC;QACnE,MAAM,WAAW,GAAuC,EAAE,CAAC;QAE3D,yBAAyB;QACzB,IAAI,OAAO,EAAE;YACX,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;gBAC9C,MAAM,MAAM,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;gBAC1B,MAAM,MAAM,GAAG,MAAM,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC;gBACjD,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;gBAEnC,yBAAyB;gBACzB,IAAI,IAAI,EAAE;oBACR,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;iBACxB;aACF;SACF;QAED,OAAO,WAAW,CAAC;IACrB,CAAC;IAEO,gBAAgB;QACtB,yBAAyB;QACzB,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE;YAC3B,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,UAAU,CAAC,SAAS,CAChD,CAAC,IAAyB,EAAE,EAAE;gBAC5B,IAAI,CAAC,gBAAgB,CACnB,IAAI,KAAK,mBAAmB,CAAC,EAAE,IAAI,IAAI,KAAK,mBAAmB,CAAC,EAAE,CACnE,CAAC;YACJ,CAAC,CACF,CAAC;SACH;IACH,CAAC;IAEO,WAAW;QACjB,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,EAAE;YAC1C,KAAK,EAAE,CAAC,EAAe,EAAE,SAAsB,EAAE,MAAmB,EAAE,EAAE;gBACtE,MAAM,MAAM,GAAG,EAAE,CAAC,aAAa,CAAC,uBAAuB,CAAC,CAAC;gBACzD,OAAO,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;YACjC,CAAC;SACF,CAAC,CAAC;QAEH,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAClD,MAAM,MAAM,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAE1C,yBAAyB;YACzB,IAAI,MAAM,EAAE;gBACV,IAAI,IAAI,CAAC,WAAW,EAAE;oBACpB,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;iBAC5B;gBAED,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;aAChC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,WAAW,CAAC,MAAuC;QACzD,OAAO,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,aAAa,CAAC,UAAU,CAAC;IACzD,CAAC;IAEO,QAAQ,CAAC,MAAc;QAC7B,yBAAyB;QACzB,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,WAAW,EAAE;YACjD,KAAK,MAAM,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,WAAW,EAAE;gBACnD,yBAAyB;gBACzB,IAAI,MAAM,CAAC,KAAK,EAAE;oBAChB,KAAK,MAAM,IAAI,IAAI,MAAM,CAAC,KAAK,EAAE;wBAC/B,IAAI,IAAI,CAAC,EAAE,KAAK,MAAM,EAAE;4BACtB,OAAO,IAAI,CAAC;yBACb;qBACF;iBACF;aACF;SACF;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;IAEO,cAAc,CAAC,MAAc;QACnC,yBAAyB;QACzB,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,WAAW,EAAE;YACjD,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CACxC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,KAAK,IAAI,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,MAAM,CAAC,CACrE,CAAC;SACH;QAED,yBAAyB;QACzB,OAAO,SAAS,CAAC;IACnB,CAAC;IAEO,cAAc,CACpB,MAA8B,EAC9B,OAAmD,EACnD,YAA6C;QAE7C,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;QACjC,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAChC,CAAC;IAEO,aAAa,CAAC,MAA8B;QAClD,IAAI,CAAC,eAAe;aACjB,SAAS,CAAC,IAAI,CAAC,WAAW,EAAE;YAC3B,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM;YAC1B,SAAS,EAAE,IAAI;YACf,OAAO,EAAE,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;SACzD,CAAC;aACD,SAAS;QACR,gEAAgE;QAChE,GAAG,EAAE,GAAE,CAAC,EACR,CAAC,GAAG,EAAE,EAAE;YACN,OAAO,CAAC,IAAI,CAAC,yCAAyC,CAAC,CAAC;YACxD,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACpB,CAAC,CACF,CAAC;IACN,CAAC;IAEO,gBAAgB,CAAC,YAAsB;QAC7C,2FAA2F;QAC3F,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE;YACjD,OAAO,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;QAC9C,CAAC,CAAC,CAAC;QAEH,MAAM,EAAE,WAAW,EAAE,YAAY,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;QAEzD,6CAA6C;QAC7C,yBAAyB;QACzB,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;YACvB,yBAAyB;YACzB,IAAI,WAAW,EAAE;gBACf,QAAQ,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;oBACxB,IAAI,aAAa,GAAG,CAAC,CAAC;oBACtB,IAAI,QAAQ,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC;oBAC3C,WAAW,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;wBAClC,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,QAAQ,EAAE;4BAChC,aAAa,GAAG,KAAK,CAAC;4BACtB,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;yBAC9B;oBACH,CAAC,CAAC,CAAC;oBACH,WAAW,CAAC,aAAa,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC;wBACpC,EAAE,EAAE,IAAI,CAAC,EAAE;wBACX,WAAW,EAAE,KAAK;qBACnB,CAAC,CAAC;gBACL,CAAC,CAAC,CAAC;aACJ;YAED,yBAAyB;YACzB,IAAI,YAAY,EAAE;gBAChB,QAAQ,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;oBACxB,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,IAAI,CAAC,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC;gBAC/D,CAAC,CAAC,CAAC;aACJ;SACF;QAED,yBAAyB;QACzB,IAAI,YAAY,EAAE;YAChB,KAAK,MAAM,IAAI,IAAI,YAAY,CAAC,KAAK,EAAE;gBACrC,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,CAAC;aACtC;SACF;QAED,yBAAyB;QACzB,IAAI,WAAW,EAAE;YACf,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;gBAClD,KAAK,MAAM,IAAI,IAAI,WAAW,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE;oBACvC,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,CAAC;iBACtC;aACF;SACF;IACH,CAAC;;oHAtqBU,uBAAuB;wHAAvB,uBAAuB;2FAAvB,uBAAuB;kBADnC,UAAU;yKAgBF,oBAAoB;sBAD1B,MAAM","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"]}
|