@acorex/layout 1.3.90

Sign up to get free protection for your applications and to get access to all the features.
Files changed (41) hide show
  1. package/README.md +2 -0
  2. package/acorex-layout.d.ts +6 -0
  3. package/acorex-layout.metadata.json +1 -0
  4. package/bundles/acorex-layout.umd.js +1479 -0
  5. package/bundles/acorex-layout.umd.js.map +1 -0
  6. package/bundles/acorex-layout.umd.min.js +16 -0
  7. package/bundles/acorex-layout.umd.min.js.map +1 -0
  8. package/esm2015/acorex-layout.js +7 -0
  9. package/esm2015/lib/widget-board/editors/widget-size-editor/widget-size.editor.js +49 -0
  10. package/esm2015/lib/widget-board/editors/widget-size-editor/widget-size.module.js +22 -0
  11. package/esm2015/lib/widget-board/widget-board.component.js +468 -0
  12. package/esm2015/lib/widget-board/widget-board.module.js +69 -0
  13. package/esm2015/lib/widget-board/widget-config.component.js +86 -0
  14. package/esm2015/lib/widget-board/widget-host.component.js +313 -0
  15. package/esm2015/lib/widget-board/widget-save.component.js +79 -0
  16. package/esm2015/lib/widget-board/widget.class.js +123 -0
  17. package/esm2015/public-api.js +7 -0
  18. package/esm5/acorex-layout.js +7 -0
  19. package/esm5/lib/widget-board/editors/widget-size-editor/widget-size.editor.js +52 -0
  20. package/esm5/lib/widget-board/editors/widget-size-editor/widget-size.module.js +23 -0
  21. package/esm5/lib/widget-board/widget-board.component.js +494 -0
  22. package/esm5/lib/widget-board/widget-board.module.js +70 -0
  23. package/esm5/lib/widget-board/widget-config.component.js +90 -0
  24. package/esm5/lib/widget-board/widget-host.component.js +349 -0
  25. package/esm5/lib/widget-board/widget-save.component.js +83 -0
  26. package/esm5/lib/widget-board/widget.class.js +134 -0
  27. package/esm5/public-api.js +7 -0
  28. package/fesm2015/acorex-layout.js +1171 -0
  29. package/fesm2015/acorex-layout.js.map +1 -0
  30. package/fesm5/acorex-layout.js +1256 -0
  31. package/fesm5/acorex-layout.js.map +1 -0
  32. package/lib/widget-board/editors/widget-size-editor/widget-size.editor.d.ts +16 -0
  33. package/lib/widget-board/editors/widget-size-editor/widget-size.module.d.ts +3 -0
  34. package/lib/widget-board/widget-board.component.d.ts +58 -0
  35. package/lib/widget-board/widget-board.module.d.ts +6 -0
  36. package/lib/widget-board/widget-config.component.d.ts +20 -0
  37. package/lib/widget-board/widget-host.component.d.ts +48 -0
  38. package/lib/widget-board/widget-save.component.d.ts +16 -0
  39. package/lib/widget-board/widget.class.d.ts +53 -0
  40. package/package.json +21 -0
  41. package/public-api.d.ts +6 -0
@@ -0,0 +1,494 @@
1
+ import { __decorate, __metadata, __read, __spread } from "tslib";
2
+ import { Component, OnInit, Input, ViewEncapsulation, ElementRef, ViewChild, NgZone, ChangeDetectionStrategy, ChangeDetectorRef, Output, EventEmitter, ViewChildren, QueryList } from '@angular/core';
3
+ import { AXWidgetHostComponent } from './widget-host.component';
4
+ import { AXHtmlUtil, AXClientRec } from '@acorex/core';
5
+ import { Observable } from 'rxjs';
6
+ import { debounceTime, distinctUntilChanged } from 'rxjs/operators';
7
+ var AXWidgetBoardComponent = /** @class */ (function () {
8
+ function AXWidgetBoardComponent(ref, zone, cdr) {
9
+ this.ref = ref;
10
+ this.zone = zone;
11
+ this.cdr = cdr;
12
+ this.widgets = [];
13
+ this.galleryItems = [];
14
+ this.tileSize = 80;
15
+ this.gapSize = 5;
16
+ this.newWidget = null;
17
+ this._isInEditing = false;
18
+ this.isDragging = false;
19
+ this.DATA_COL = 'data-col';
20
+ this.DATA_ROW = 'data-row';
21
+ this.DATA_SIZE_X = 'data-size-x';
22
+ this.DATA_SIZE_Y = 'data-size-y';
23
+ this.DATA_OLD_COL = 'data-old-col';
24
+ this.DATA_OLD_ROW = 'data-old-row';
25
+ this.onConfigChanged = new EventEmitter();
26
+ this.onWidgetSave = new EventEmitter();
27
+ }
28
+ AXWidgetBoardComponent.prototype.isInEditing = function () {
29
+ return this._isInEditing;
30
+ };
31
+ AXWidgetBoardComponent.prototype.ngOnInit = function () {
32
+ if (this.rtl == null) {
33
+ this.rtl = window.getComputedStyle(this.ref.nativeElement, null).getPropertyValue('direction') === 'rtl';
34
+ }
35
+ };
36
+ AXWidgetBoardComponent.prototype.ngAfterViewInit = function () {
37
+ var _this = this;
38
+ this.zone.runOutsideAngular(function (c) {
39
+ var style = document.createElement('style');
40
+ style.type = 'text/css';
41
+ _this.ref.nativeElement.appendChild(style);
42
+ // add css data classes
43
+ for (var i = 1; i <= 50; i++) {
44
+ style.innerHTML += "[" + _this.DATA_COL + "=\"" + i + "\"] { " + (_this.rtl ? 'right' : 'left') + ": " + (i - 1) * (_this.tileSize + _this.gapSize) + "px; }";
45
+ style.innerHTML += "[" + _this.DATA_ROW + "=\"" + i + "\"] { top: " + (i - 1) * (_this.tileSize + _this.gapSize) + "px; }";
46
+ style.innerHTML += "[" + _this.DATA_SIZE_X + "=\"" + i + "\"] { width: " + ((i * _this.tileSize) + ((i - 1) * _this.gapSize)) + "px; }";
47
+ style.innerHTML += "[" + _this.DATA_SIZE_Y + "=\"" + i + "\"] { height: " + ((i * _this.tileSize) + ((i - 1) * _this.gapSize)) + "px; }";
48
+ }
49
+ });
50
+ };
51
+ AXWidgetBoardComponent.prototype.calcGridSize = function () {
52
+ var _this = this;
53
+ this.zone.runOutsideAngular(function () {
54
+ var width = (Math.max.apply(Math, __spread(_this.widgets.map(function (c) { return c.col + c.sizeX - 1; })))) * (_this.tileSize + _this.gapSize);
55
+ var height = (Math.max.apply(Math, __spread(_this.widgets.map(function (c) { return c.row + c.sizeY - 1; })))) * (_this.tileSize + _this.gapSize);
56
+ _this.container.nativeElement.style.width = width + 'px';
57
+ _this.container.nativeElement.style.height = height + 'px';
58
+ });
59
+ };
60
+ AXWidgetBoardComponent.prototype.toggleEdit = function () {
61
+ this._isInEditing ? this.finishEdit() : this.startEdit();
62
+ };
63
+ AXWidgetBoardComponent.prototype.dragStart = function (e) {
64
+ var _this = this;
65
+ e.preventDefault();
66
+ e.stopPropagation();
67
+ this.zone.runOutsideAngular(function () {
68
+ if (_this._isInEditing && e.which === 1) {
69
+ _this.dragItem = e.currentTarget;
70
+ _this.dragItem.setAttribute('data-x-offset', (_this.dragItem.offsetLeft - e.clientX).toString());
71
+ //
72
+ _this.dragItem.setAttribute('data-y-offset', (_this.dragItem.offsetTop - e.clientY).toString());
73
+ _this.dragItem.classList.add('widget-dragging');
74
+ _this.dragItem.classList.remove('animate__animated', 'animate__pulse');
75
+ }
76
+ });
77
+ return false;
78
+ };
79
+ AXWidgetBoardComponent.prototype.removePositionData = function () {
80
+ var _this = this;
81
+ this.zone.runOutsideAngular(function () {
82
+ if (_this.dragItem && _this._isInEditing && _this.dragItem.getAttribute(_this.DATA_OLD_COL) == null) {
83
+ _this.dragItem.setAttribute(_this.DATA_OLD_COL, _this.dragItem.getAttribute(_this.DATA_COL));
84
+ _this.dragItem.setAttribute(_this.DATA_OLD_ROW, _this.dragItem.getAttribute(_this.DATA_ROW));
85
+ _this.dragItem.removeAttribute(_this.DATA_COL);
86
+ _this.dragItem.removeAttribute(_this.DATA_ROW);
87
+ }
88
+ });
89
+ };
90
+ AXWidgetBoardComponent.prototype.resetPositionData = function () {
91
+ var _this = this;
92
+ this.zone.runOutsideAngular(function () {
93
+ if (_this.dragItem && _this._isInEditing) {
94
+ _this.setPosition(_this.dragItem, _this.dragItem.getAttribute(_this.DATA_OLD_COL), _this.dragItem.getAttribute(_this.DATA_OLD_ROW));
95
+ }
96
+ });
97
+ };
98
+ AXWidgetBoardComponent.prototype.setPosition = function (element, col, row) {
99
+ var _this = this;
100
+ this.zone.runOutsideAngular(function () {
101
+ element.setAttribute(_this.DATA_COL, col);
102
+ element.setAttribute(_this.DATA_ROW, row);
103
+ element.removeAttribute(_this.DATA_OLD_COL);
104
+ element.removeAttribute(_this.DATA_OLD_ROW);
105
+ element.style.removeProperty('top');
106
+ element.style.removeProperty('left');
107
+ var widget = _this.widgets.find(function (c) { return c['__meta__'].instance.element === element; });
108
+ widget.col = Number(col);
109
+ widget.row = Number(row);
110
+ });
111
+ };
112
+ AXWidgetBoardComponent.prototype.drag = function (e) {
113
+ var _this = this;
114
+ e.preventDefault();
115
+ e.stopPropagation();
116
+ this.zone.runOutsideAngular(function () {
117
+ if (_this.dragItem && _this._isInEditing) {
118
+ _this.isDragging = true;
119
+ _this.addPlaceholder();
120
+ var xOffset = Number(_this.dragItem.getAttribute('data-x-offset'));
121
+ var yOffset = Number(_this.dragItem.getAttribute('data-y-offset'));
122
+ _this.dragItem.style.left = e.clientX + xOffset + 'px';
123
+ _this.dragItem.style.top = e.clientY + yOffset + 'px';
124
+ //
125
+ _this.detectBestPlacement();
126
+ _this.removePositionData();
127
+ }
128
+ });
129
+ return false;
130
+ };
131
+ AXWidgetBoardComponent.prototype.dragEnd = function (e) {
132
+ var _this = this;
133
+ this.zone.runOutsideAngular(function () {
134
+ if (_this.dragItem && _this._isInEditing && _this.isDragging) {
135
+ _this.dragItem.classList.remove('widget-dragging');
136
+ _this.dragItem.classList.add('animate__animated', 'animate__pulse');
137
+ //
138
+ var p = _this.container.nativeElement.querySelector('.widget-blank-placeholder');
139
+ if (_this.newWidget) {
140
+ var w_1 = {
141
+ uniqueName: _this.newWidget.uniqueName,
142
+ component: _this.newWidget.component,
143
+ title: _this.newWidget.title,
144
+ options: _this.newWidget.options,
145
+ sizeX: _this.newWidget.sizeX,
146
+ sizeY: _this.newWidget.sizeY,
147
+ col: Number(p.getAttribute(_this.DATA_COL)),
148
+ row: Number(p.getAttribute(_this.DATA_ROW))
149
+ };
150
+ _this.widgets.push(w_1);
151
+ _this.newWidget = null;
152
+ _this.container.nativeElement.removeChild(_this.dragItem);
153
+ _this.zone.run(function () {
154
+ _this.cdr.detectChanges();
155
+ _this.calcGridSize();
156
+ setTimeout(function () {
157
+ w_1['__meta__'].instance.element.addEventListener('mousedown', _this.dragStart.bind(_this), false);
158
+ }, 1000);
159
+ });
160
+ }
161
+ else {
162
+ if (p) {
163
+ _this.setPosition(_this.dragItem, p.getAttribute(_this.DATA_COL), p.getAttribute(_this.DATA_ROW));
164
+ }
165
+ else {
166
+ _this.setPosition(_this.dragItem, _this.dragItem.getAttribute(_this.DATA_OLD_COL), _this.dragItem.getAttribute(_this.DATA_OLD_ROW));
167
+ }
168
+ }
169
+ //
170
+ _this.removePlaceholder();
171
+ _this.dragItem = null;
172
+ _this.calcGridSize();
173
+ _this.emitConfigChanged();
174
+ }
175
+ _this.isDragging = false;
176
+ });
177
+ };
178
+ AXWidgetBoardComponent.prototype.detectFirstEmptySlot = function (w) {
179
+ var xTile = Math.floor(this.ref.nativeElement.parentElement.offsetWidth / this.tileSize);
180
+ for (var j = 1; j <= 100; j++) {
181
+ var _loop_1 = function (i) {
182
+ var rec = new AXClientRec({
183
+ left: i,
184
+ top: j,
185
+ width: w.sizeX,
186
+ height: w.sizeY
187
+ });
188
+ var el = this_1.widgets.filter(function (c) { return c !== w; }).find(function (c) {
189
+ return rec.intersect({
190
+ left: c.col,
191
+ top: c.row,
192
+ width: c.sizeX,
193
+ height: c.sizeY
194
+ });
195
+ });
196
+ if (el == null) {
197
+ w.col = i;
198
+ w.row = j;
199
+ return { value: void 0 };
200
+ }
201
+ };
202
+ var this_1 = this;
203
+ for (var i = 1; i <= xTile - w.sizeX; i++) {
204
+ var state_1 = _loop_1(i);
205
+ if (typeof state_1 === "object")
206
+ return state_1.value;
207
+ }
208
+ }
209
+ };
210
+ AXWidgetBoardComponent.prototype.detectBestPlacement = function () {
211
+ var _this = this;
212
+ this.zone.runOutsideAngular(function () {
213
+ var p = _this.container.nativeElement.querySelector('.widget-blank-placeholder');
214
+ var col = Math.ceil(_this.dragItem.offsetLeft / _this.tileSize);
215
+ if (_this.rtl) {
216
+ col = Math.ceil((_this.container.nativeElement.clientWidth - (_this.dragItem.offsetLeft + _this.dragItem.clientWidth)) / _this.tileSize);
217
+ }
218
+ var row = Math.ceil(_this.dragItem.offsetTop / _this.tileSize);
219
+ if (col < 1) {
220
+ col = 1;
221
+ }
222
+ if (row < 1) {
223
+ row = 1;
224
+ }
225
+ var widgets = Array.from(_this.ref.nativeElement.querySelectorAll('.widget-host')).map(function (c) { return c; });
226
+ p.setAttribute(_this.DATA_COL, col.toString());
227
+ p.setAttribute(_this.DATA_ROW, row.toString());
228
+ var collision = widgets.filter(function (c) { return c !== _this.dragItem; }).some(function (c) { return AXHtmlUtil.collision(c, _this.dragItem); });
229
+ if (collision) {
230
+ _this.removePlaceholder();
231
+ }
232
+ });
233
+ };
234
+ AXWidgetBoardComponent.prototype.addPlaceholder = function () {
235
+ var _this = this;
236
+ this.zone.runOutsideAngular(function () {
237
+ _this.removePlaceholder();
238
+ if (_this.dragItem) {
239
+ var p = document.createElement('div');
240
+ p.classList.add('widget-blank-placeholder');
241
+ p.setAttribute(_this.DATA_COL, _this.dragItem.getAttribute(_this.DATA_COL));
242
+ p.setAttribute(_this.DATA_ROW, _this.dragItem.getAttribute(_this.DATA_ROW));
243
+ p.setAttribute(_this.DATA_SIZE_X, _this.dragItem.getAttribute(_this.DATA_SIZE_X));
244
+ p.setAttribute(_this.DATA_SIZE_Y, _this.dragItem.getAttribute(_this.DATA_SIZE_Y));
245
+ _this.container.nativeElement.appendChild(p);
246
+ }
247
+ });
248
+ };
249
+ AXWidgetBoardComponent.prototype.removePlaceholder = function () {
250
+ var _a;
251
+ var p = this.container.nativeElement.querySelector('.widget-blank-placeholder');
252
+ (_a = p) === null || _a === void 0 ? void 0 : _a.remove();
253
+ };
254
+ AXWidgetBoardComponent.prototype.startEdit = function () {
255
+ var _this = this;
256
+ this._isInEditing = true;
257
+ this.calcGridSize();
258
+ this.ref.nativeElement.classList.add('grid-background');
259
+ var bg = this.ref.nativeElement;
260
+ bg.style.setProperty('background-position', (this.rtl ? 'right' : 'left') + " top");
261
+ // tslint:disable-next-line: max-line-length
262
+ var pattern = "url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"" + (this.tileSize + this.gapSize) + "\" height=\"" + (this.tileSize + this.gapSize) + "\"> <rect style=\"fill: %23dadada\" x=\"" + (this.rtl ? this.gapSize : 0) + "\" width=\"" + this.tileSize + "\" height=\"" + this.tileSize + "\" y=\"0\"></rect></svg>')";
263
+ bg.style.setProperty('background-image', pattern);
264
+ //
265
+ var widgets = Array.from(this.ref.nativeElement.querySelectorAll('.widget-host'));
266
+ widgets.forEach(function (w) {
267
+ w.addEventListener('mousedown', _this.dragStart.bind(_this), false);
268
+ });
269
+ this.ref.nativeElement.addEventListener('mousemove', this.drag.bind(this), false);
270
+ this.ref.nativeElement.addEventListener('mouseup', this.dragEnd.bind(this), false);
271
+ };
272
+ AXWidgetBoardComponent.prototype.finishEdit = function () {
273
+ var _this = this;
274
+ this.ref.nativeElement.classList.remove('grid-background');
275
+ var bg = this.ref.nativeElement;
276
+ bg.style.removeProperty('background-image');
277
+ //
278
+ this._isInEditing = false;
279
+ var widgets = Array.from(this.ref.nativeElement.querySelectorAll('.widget-host'));
280
+ widgets.forEach(function (w) {
281
+ w.removeEventListener('mousedown', _this.dragStart.bind(_this), false);
282
+ });
283
+ this.ref.nativeElement.removeEventListener('mousemove', this.drag.bind(this), false);
284
+ this.ref.nativeElement.removeEventListener('mouseup', this.dragEnd.bind(this), false);
285
+ this.emitConfigChanged();
286
+ };
287
+ AXWidgetBoardComponent.prototype.addWidget = function (widget) {
288
+ var _this = this;
289
+ this.zone.runOutsideAngular(function () {
290
+ _this.newWidget = {
291
+ uniqueName: widget.uniqueName,
292
+ component: widget.component,
293
+ title: widget.title,
294
+ col: 1,
295
+ row: 1,
296
+ sizeX: widget.sizeX,
297
+ sizeY: widget.sizeY,
298
+ options: widget.options,
299
+ props: widget.props
300
+ };
301
+ _this.detectFirstEmptySlot(_this.newWidget);
302
+ var w = {
303
+ uniqueName: _this.newWidget.uniqueName,
304
+ component: _this.newWidget.component,
305
+ title: _this.newWidget.title,
306
+ options: _this.newWidget.options,
307
+ props: _this.newWidget.props,
308
+ sizeX: _this.newWidget.sizeX,
309
+ sizeY: _this.newWidget.sizeY,
310
+ col: _this.newWidget.col,
311
+ row: _this.newWidget.row
312
+ };
313
+ _this.widgets.push(w);
314
+ _this.newWidget = null;
315
+ _this.zone.run(function () {
316
+ _this.cdr.detectChanges();
317
+ _this.calcGridSize();
318
+ _this.emitConfigChanged();
319
+ setTimeout(function () {
320
+ w['__meta__'].instance.element.addEventListener('mousedown', _this.dragStart.bind(_this), false);
321
+ }, 1000);
322
+ });
323
+ });
324
+ };
325
+ AXWidgetBoardComponent.prototype.handleOnRemove = function (w) {
326
+ var _this = this;
327
+ w.element.classList.add('animate__animated', 'animate__zoomOut');
328
+ w.element.addEventListener('animationend', function () {
329
+ _this.widgets = _this.widgets.filter(function (c) { return c.__meta__.id !== w.config.__meta__.id; });
330
+ _this.cdr.detectChanges();
331
+ _this.calcGridSize();
332
+ _this.emitConfigChanged();
333
+ });
334
+ };
335
+ AXWidgetBoardComponent.prototype.handleOnSave = function (e) {
336
+ this.onWidgetSave.emit(e);
337
+ };
338
+ AXWidgetBoardComponent.prototype.trackByFn = function (index, item) {
339
+ var _a, _b;
340
+ if (!((_a = item['__meta__']) === null || _a === void 0 ? void 0 : _a.id)) {
341
+ item['__meta__'] = {};
342
+ item['__meta__'].id = AXHtmlUtil.getUID();
343
+ }
344
+ return (_b = item['__meta__']) === null || _b === void 0 ? void 0 : _b.id;
345
+ };
346
+ AXWidgetBoardComponent.prototype.load = function (widgets) {
347
+ var _this = this;
348
+ this.clear();
349
+ return new Promise(function (resolve, reject) {
350
+ if (widgets) {
351
+ var loadedWidgets_1 = [];
352
+ if (typeof widgets === 'string') {
353
+ try {
354
+ loadedWidgets_1.push.apply(loadedWidgets_1, __spread(JSON.parse(widgets)));
355
+ }
356
+ catch (error) {
357
+ reject('Invalid widget json data!');
358
+ }
359
+ }
360
+ else {
361
+ loadedWidgets_1.push.apply(loadedWidgets_1, __spread(widgets));
362
+ }
363
+ var intervalId_1 = -1;
364
+ var loadFunc = function () {
365
+ var _a;
366
+ if (_this.galleryItems && _this.galleryItems.length > 0) {
367
+ loadedWidgets_1.forEach(function (w) {
368
+ var gitem = _this.galleryItems.find(function (c) { return c.uniqueName === w.uniqueName; });
369
+ if (gitem) {
370
+ w.component = gitem.component;
371
+ if (gitem.props) {
372
+ w.props = JSON.parse(JSON.stringify(gitem.props));
373
+ }
374
+ }
375
+ });
376
+ (_a = _this.widgets).push.apply(_a, __spread(loadedWidgets_1));
377
+ window.clearInterval(intervalId_1);
378
+ _this.cdr.detectChanges();
379
+ resolve();
380
+ }
381
+ };
382
+ intervalId_1 = window.setInterval(loadFunc, 200);
383
+ }
384
+ else {
385
+ resolve();
386
+ }
387
+ });
388
+ };
389
+ AXWidgetBoardComponent.prototype.clear = function () {
390
+ if (this.widgets.length) {
391
+ this.widgets = [];
392
+ this.cdr.detectChanges();
393
+ this.emitConfigChanged();
394
+ }
395
+ };
396
+ AXWidgetBoardComponent.prototype.save = function () {
397
+ var obj = this.widgets.map(function (c) { return ({
398
+ uniqueName: c.uniqueName,
399
+ component: c.component,
400
+ title: c.title,
401
+ sizeX: c.sizeX,
402
+ sizeY: c.sizeY,
403
+ col: c.col,
404
+ row: c.row,
405
+ options: c.options,
406
+ props: c.props
407
+ }); });
408
+ return Promise.resolve(JSON.stringify(obj));
409
+ };
410
+ AXWidgetBoardComponent.prototype.refresh = function () {
411
+ this.widgetHosts.forEach(function (host) {
412
+ host.widget.refresh();
413
+ });
414
+ };
415
+ AXWidgetBoardComponent.prototype.handleOnConfigChanged = function (e) {
416
+ this.cdr.detectChanges();
417
+ this.emitConfigChanged();
418
+ };
419
+ AXWidgetBoardComponent.prototype.handleOnResizedChanged = function (e) {
420
+ this.detectFirstEmptySlot(e.config);
421
+ this.cdr.detectChanges();
422
+ this.emitConfigChanged();
423
+ };
424
+ AXWidgetBoardComponent.prototype.emitConfigChanged = function () {
425
+ var _this = this;
426
+ if (!this.resizeChangeObserver) {
427
+ this.resizeChangeObserver = new Observable();
428
+ Observable.create(function (observer) {
429
+ _this.resizeChangeObserver = observer;
430
+ })
431
+ .pipe(debounceTime(750))
432
+ .pipe(distinctUntilChanged())
433
+ .subscribe(function (c) {
434
+ _this.onConfigChanged.emit({
435
+ component: _this
436
+ });
437
+ });
438
+ }
439
+ this.resizeChangeObserver.next(new Date());
440
+ };
441
+ AXWidgetBoardComponent.ctorParameters = function () { return [
442
+ { type: ElementRef },
443
+ { type: NgZone },
444
+ { type: ChangeDetectorRef }
445
+ ]; };
446
+ __decorate([
447
+ ViewChild('container'),
448
+ __metadata("design:type", ElementRef)
449
+ ], AXWidgetBoardComponent.prototype, "container", void 0);
450
+ __decorate([
451
+ ViewChildren(AXWidgetHostComponent),
452
+ __metadata("design:type", QueryList)
453
+ ], AXWidgetBoardComponent.prototype, "widgetHosts", void 0);
454
+ __decorate([
455
+ Input(),
456
+ __metadata("design:type", Array)
457
+ ], AXWidgetBoardComponent.prototype, "galleryItems", void 0);
458
+ __decorate([
459
+ Input(),
460
+ __metadata("design:type", Number)
461
+ ], AXWidgetBoardComponent.prototype, "tileSize", void 0);
462
+ __decorate([
463
+ Input(),
464
+ __metadata("design:type", Number)
465
+ ], AXWidgetBoardComponent.prototype, "gapSize", void 0);
466
+ __decorate([
467
+ Input(),
468
+ __metadata("design:type", Function)
469
+ ], AXWidgetBoardComponent.prototype, "provideValue", void 0);
470
+ __decorate([
471
+ Output(),
472
+ __metadata("design:type", EventEmitter)
473
+ ], AXWidgetBoardComponent.prototype, "onConfigChanged", void 0);
474
+ __decorate([
475
+ Output(),
476
+ __metadata("design:type", EventEmitter)
477
+ ], AXWidgetBoardComponent.prototype, "onWidgetSave", void 0);
478
+ AXWidgetBoardComponent = __decorate([
479
+ Component({
480
+ selector: 'ax-widget-board',
481
+ template: "<div class=\"widgets-container\" [class.rtl]=\"rtl\" #container>\r\n <ax-widget-host *ngFor=\"let w of widgets;trackBy: trackByFn\" [config]='w' [sizeX]=\"w.sizeX\"\r\n [sizeY]=\"w.sizeY\" [col]=\"w.col\" [row]=\"w.row\" (onRemove)=\"handleOnRemove($event)\" (onSave)=\"handleOnSave($event)\"\r\n (onConfigChanged)=\"handleOnConfigChanged($event)\" (onResized)=\"handleOnResizedChanged($event)\"\r\n [provideValue]=\"provideValue\">\r\n </ax-widget-host>\r\n</div>\r\n",
482
+ host: { class: 'ax widget-board' },
483
+ encapsulation: ViewEncapsulation.None,
484
+ changeDetection: ChangeDetectionStrategy.OnPush,
485
+ styles: [".widget-board{display:inline-block;margin:15px 20px;min-width:calc(100% - 40px);min-height:calc(100% - 34px);--animate-duration:0.5s;background-repeat:no-repeat}.widget-board.grid-background{background-repeat:repeat!important}.widget-board.grid-background .widgets-container .widget-host{touch-action:none;touch-action:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.widget-board.grid-background .widgets-container .widget-host .widget-edit-overlay{display:block;cursor:move}.widget-board.grid-background .widgets-container .widget-host.widget-dragging{z-index:1000}.widget-board.grid-background .widgets-container .widget-host:focus{outline-width:1px;outline-style:solid;outline-color:var(--ax-primary-color)}.widget-board.grid-background .widget-blank-placeholder{background:var(--ax-primary-trans-light-color);position:absolute}.widget-board .widgets-container{position:relative;touch-action:none}.widget-board .widgets-container.rtl .widget-host .widget-options-menu{right:unset!important;left:0!important}.widget-board .widgets-container .widget-host{position:absolute;background:#fff;box-shadow:2px 2px 3px #dadada}.widget-board .widgets-container .widget-host .widget-content{width:100%;height:100%;display:flex;flex-direction:column}.widget-board .widgets-container .widget-host .widget-content .widget-title{padding:var(--ax-size-md);text-align:start;font-size:1.5em;position:absolute}.widget-board .widgets-container .widget-host .widget-edit-loading{display:none;background:rgba(255,255,255,.85);position:absolute;width:100%;height:100%;top:0;left:0;z-index:2;display:flex}.widget-board .widgets-container .widget-host .widget-config-overlay{position:absolute;background:#fff;width:100%;height:100%;top:0;left:0;z-index:1;padding:var(--ax-size-md);cursor:pointer}.widget-board .widgets-container .widget-host .widget-config-overlay:hover .widget-title{text-decoration:underline}.widget-board .widgets-container .widget-host .widget-config-overlay .widget-title{text-align:start;font-size:1.5em}.widget-board .widgets-container .widget-host .widget-config-overlay .widget-config-box{align-self:center;text-align:center;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--ax-gray-dark-color)}.widget-board .widgets-container .widget-host .widget-config-overlay .widget-config-box .config-title{font-size:1.2em;margin-bottom:var(--ax-size-md)}.widget-board .widgets-container .widget-host .widget-edit-overlay{display:none;background:rgba(255,255,255,.5);position:absolute;width:100%;height:100%;top:0;left:0;z-index:10}.widget-board .widgets-container .widget-host .widget-edit-overlay .widget-edit-menu{margin:6px;text-align:end;float:inline-end;opacity:1;transition:opacity 1s}.widget-board .widgets-container .widget-host .widget-edit-overlay .widget-edit-menu .widget-edit-menu-button{display:inline-block;background-color:#f0f0f0;border-radius:1px;border:2px solid #fff;box-sizing:border-box;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;padding:0;height:32px;width:32px;cursor:pointer;color:#666}.widget-board .widgets-container .widget-host .widget-edit-overlay .widget-edit-menu .widget-edit-menu-button:hover{border-color:#a6a6a6;background-color:#c8c8c8}.widget-board .widgets-container .widget-host .widget-options-menu{display:none;position:absolute;top:0;right:0;z-index:2;cursor:pointer;padding:2px 5px}.widget-board .widgets-container .widget-host .widget-options-menu:hover{background-color:#f0f0f0}.widget-board .widgets-container .widget-host .widget-container{padding:1px;height:100%}.widget-board .widgets-container .widget-host .widget-container:hover .widget-options-menu{display:block}"]
486
+ }),
487
+ __metadata("design:paramtypes", [ElementRef,
488
+ NgZone,
489
+ ChangeDetectorRef])
490
+ ], AXWidgetBoardComponent);
491
+ return AXWidgetBoardComponent;
492
+ }());
493
+ export { AXWidgetBoardComponent };
494
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-board.component.js","sourceRoot":"ng://@acorex/layout/","sources":["lib/widget-board/widget-board.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  Input,\r\n  ViewEncapsulation,\r\n  ElementRef,\r\n  ViewChild,\r\n  NgZone,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Output,\r\n  EventEmitter, ViewChildren, QueryList\r\n} from '@angular/core';\r\nimport {\r\n  AXWidgetConfig,\r\n  AXWidgetConfigChanged,\r\n  AXWidgetBoardConfigChanged,\r\n  AXWidgetConfigSavedEvent\r\n} from './widget.class';\r\nimport { AXWidgetHostComponent } from './widget-host.component';\r\nimport { AXHtmlUtil, AXClientRec } from '@acorex/core';\r\nimport { Observable } from 'rxjs';\r\nimport { debounceTime, distinctUntilChanged } from 'rxjs/operators';\r\n\r\n@Component({\r\n  selector: 'ax-widget-board',\r\n  templateUrl: './widget-board.component.html',\r\n  styleUrls: ['./widget-board.component.scss'],\r\n  host: { class: 'ax widget-board' },\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class AXWidgetBoardComponent implements OnInit {\r\n\r\n  @ViewChild('container')\r\n  private container: ElementRef<HTMLDivElement>;\r\n\r\n  @ViewChildren(AXWidgetHostComponent)\r\n  private widgetHosts: QueryList<AXWidgetHostComponent>;\r\n\r\n  widgets: AXWidgetConfig[] = [];\r\n\r\n  @Input()\r\n  galleryItems: AXWidgetConfig[] = [];\r\n\r\n  @Input()\r\n  tileSize: number = 80;\r\n\r\n  @Input()\r\n  gapSize: number = 5;\r\n\r\n  private newWidget: AXWidgetConfig = null;\r\n\r\n  public rtl: boolean;\r\n\r\n  private _isInEditing: boolean = false;\r\n  public isInEditing(): boolean {\r\n    return this._isInEditing;\r\n  }\r\n  private isDragging: boolean = false;\r\n  private dragItem: HTMLElement;\r\n\r\n  @Input()\r\n  provideValue: (e: any) => any;\r\n\r\n  private readonly DATA_COL = 'data-col';\r\n  private readonly DATA_ROW = 'data-row';\r\n  private readonly DATA_SIZE_X = 'data-size-x';\r\n  private readonly DATA_SIZE_Y = 'data-size-y';\r\n  private readonly DATA_OLD_COL = 'data-old-col';\r\n  private readonly DATA_OLD_ROW = 'data-old-row';\r\n\r\n\r\n  @Output()\r\n  onConfigChanged: EventEmitter<AXWidgetBoardConfigChanged> = new EventEmitter<AXWidgetBoardConfigChanged>();\r\n\r\n  @Output()\r\n  onWidgetSave: EventEmitter<AXWidgetConfigSavedEvent> = new EventEmitter<AXWidgetConfigSavedEvent>();\r\n\r\n  constructor(\r\n    private ref: ElementRef<HTMLDivElement>,\r\n    private zone: NgZone,\r\n    private cdr: ChangeDetectorRef\r\n  ) { }\r\n\r\n\r\n  ngOnInit() {\r\n    if (this.rtl == null) {\r\n      this.rtl = window.getComputedStyle(this.ref.nativeElement, null).getPropertyValue('direction') === 'rtl';\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.zone.runOutsideAngular((c) => {\r\n      const style = document.createElement('style');\r\n      style.type = 'text/css';\r\n      this.ref.nativeElement.appendChild(style);\r\n      // add css data classes\r\n      for (let i = 1; i <= 50; i++) {\r\n        style.innerHTML += `[${this.DATA_COL}=\"${i}\"] {  ${this.rtl ? 'right' : 'left'}: ${(i - 1) * (this.tileSize + this.gapSize)}px; }`;\r\n        style.innerHTML += `[${this.DATA_ROW}=\"${i}\"] {  top: ${(i - 1) * (this.tileSize + this.gapSize)}px; }`;\r\n        style.innerHTML += `[${this.DATA_SIZE_X}=\"${i}\"] {  width:  ${(i * this.tileSize) + ((i - 1) * this.gapSize)}px; }`;\r\n        style.innerHTML += `[${this.DATA_SIZE_Y}=\"${i}\"] {  height: ${(i * this.tileSize) + ((i - 1) * this.gapSize)}px; }`;\r\n      }\r\n    });\r\n  }\r\n\r\n  private calcGridSize() {\r\n    this.zone.runOutsideAngular(() => {\r\n      const width =\r\n        (Math.max(...this.widgets.map((c) => c.col + c.sizeX - 1))) * (this.tileSize + this.gapSize);\r\n      const height =\r\n        (Math.max(...this.widgets.map((c) => c.row + c.sizeY - 1))) * (this.tileSize + this.gapSize);\r\n      this.container.nativeElement.style.width = width + 'px';\r\n      this.container.nativeElement.style.height = height + 'px';\r\n    });\r\n  }\r\n\r\n  toggleEdit() {\r\n    this._isInEditing ? this.finishEdit() : this.startEdit();\r\n  }\r\n\r\n\r\n\r\n  private dragStart(e: MouseEvent) {\r\n    e.preventDefault();\r\n    e.stopPropagation();\r\n    this.zone.runOutsideAngular(() => {\r\n      if (this._isInEditing && e.which === 1) {\r\n        this.dragItem = e.currentTarget as any;\r\n        this.dragItem.setAttribute('data-x-offset', (this.dragItem.offsetLeft - e.clientX).toString());\r\n        //\r\n        this.dragItem.setAttribute('data-y-offset', (this.dragItem.offsetTop - e.clientY).toString());\r\n        this.dragItem.classList.add('widget-dragging');\r\n        this.dragItem.classList.remove('animate__animated', 'animate__pulse');\r\n      }\r\n    });\r\n    return false;\r\n  }\r\n\r\n  removePositionData() {\r\n    this.zone.runOutsideAngular(() => {\r\n      if (this.dragItem && this._isInEditing && this.dragItem.getAttribute(this.DATA_OLD_COL) == null) {\r\n        this.dragItem.setAttribute(this.DATA_OLD_COL, this.dragItem.getAttribute(this.DATA_COL));\r\n        this.dragItem.setAttribute(this.DATA_OLD_ROW, this.dragItem.getAttribute(this.DATA_ROW));\r\n        this.dragItem.removeAttribute(this.DATA_COL);\r\n        this.dragItem.removeAttribute(this.DATA_ROW);\r\n      }\r\n    });\r\n  }\r\n\r\n  resetPositionData() {\r\n    this.zone.runOutsideAngular(() => {\r\n      if (this.dragItem && this._isInEditing) {\r\n        this.setPosition(this.dragItem, this.dragItem.getAttribute(this.DATA_OLD_COL), this.dragItem.getAttribute(this.DATA_OLD_ROW));\r\n      }\r\n    });\r\n  }\r\n\r\n  private setPosition(element: HTMLElement, col: string, row: string) {\r\n    this.zone.runOutsideAngular(() => {\r\n      element.setAttribute(this.DATA_COL, col);\r\n      element.setAttribute(this.DATA_ROW, row);\r\n      element.removeAttribute(this.DATA_OLD_COL);\r\n      element.removeAttribute(this.DATA_OLD_ROW);\r\n      element.style.removeProperty('top');\r\n      element.style.removeProperty('left');\r\n      const widget = this.widgets.find(c => c['__meta__'].instance.element === element);\r\n      widget.col = Number(col);\r\n      widget.row = Number(row);\r\n    });\r\n  }\r\n\r\n  private drag(e) {\r\n    e.preventDefault();\r\n    e.stopPropagation();\r\n    this.zone.runOutsideAngular(() => {\r\n      if (this.dragItem && this._isInEditing) {\r\n        this.isDragging = true;\r\n        this.addPlaceholder();\r\n        const xOffset = Number(this.dragItem.getAttribute('data-x-offset'));\r\n        const yOffset = Number(this.dragItem.getAttribute('data-y-offset'));\r\n        this.dragItem.style.left = e.clientX + xOffset + 'px';\r\n        this.dragItem.style.top = e.clientY + yOffset + 'px';\r\n        //\r\n        this.detectBestPlacement();\r\n        this.removePositionData();\r\n      }\r\n    });\r\n    return false;\r\n  }\r\n\r\n  private dragEnd(e) {\r\n    this.zone.runOutsideAngular(() => {\r\n      if (this.dragItem && this._isInEditing && this.isDragging) {\r\n        this.dragItem.classList.remove('widget-dragging');\r\n        this.dragItem.classList.add('animate__animated', 'animate__pulse');\r\n        //\r\n        const p = this.container.nativeElement.querySelector('.widget-blank-placeholder');\r\n        if (this.newWidget) {\r\n          const w = {\r\n            uniqueName: this.newWidget.uniqueName,\r\n            component: this.newWidget.component,\r\n            title: this.newWidget.title,\r\n            options: this.newWidget.options,\r\n            sizeX: this.newWidget.sizeX,\r\n            sizeY: this.newWidget.sizeY,\r\n            col: Number(p.getAttribute(this.DATA_COL)),\r\n            row: Number(p.getAttribute(this.DATA_ROW))\r\n          };\r\n\r\n          this.widgets.push(w);\r\n          this.newWidget = null;\r\n          this.container.nativeElement.removeChild(this.dragItem);\r\n          this.zone.run(() => {\r\n            this.cdr.detectChanges();\r\n            this.calcGridSize();\r\n            setTimeout(() => {\r\n              w['__meta__'].instance.element.addEventListener('mousedown', this.dragStart.bind(this), false);\r\n            }, 1000);\r\n          });\r\n        } else {\r\n          if (p) {\r\n            this.setPosition(this.dragItem, p.getAttribute(this.DATA_COL), p.getAttribute(this.DATA_ROW));\r\n          }\r\n          else {\r\n            this.setPosition(this.dragItem, this.dragItem.getAttribute(this.DATA_OLD_COL), this.dragItem.getAttribute(this.DATA_OLD_ROW));\r\n          }\r\n        }\r\n        //\r\n        this.removePlaceholder();\r\n        this.dragItem = null;\r\n        this.calcGridSize();\r\n        this.emitConfigChanged();\r\n      }\r\n      this.isDragging = false;\r\n    });\r\n  }\r\n\r\n  private detectFirstEmptySlot(w: AXWidgetConfig) {\r\n    const xTile = Math.floor(this.ref.nativeElement.parentElement.offsetWidth / this.tileSize);\r\n    for (let j = 1; j <= 100; j++) {\r\n      for (let i = 1; i <= xTile - w.sizeX; i++) {\r\n        const rec = new AXClientRec({\r\n          left: i,\r\n          top: j,\r\n          width: w.sizeX,\r\n          height: w.sizeY\r\n        });\r\n        const el = this.widgets.filter(c => c !== w).find((c) =>\r\n          rec.intersect({\r\n            left: c.col,\r\n            top: c.row,\r\n            width: c.sizeX,\r\n            height: c.sizeY\r\n          })\r\n        );\r\n        if (el == null) {\r\n          w.col = i;\r\n          w.row = j;\r\n          return;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private detectBestPlacement() {\r\n    this.zone.runOutsideAngular(() => {\r\n      const p = this.container.nativeElement.querySelector('.widget-blank-placeholder') as HTMLElement;\r\n      let col = Math.ceil(this.dragItem.offsetLeft / this.tileSize);\r\n      if (this.rtl) {\r\n        col = Math.ceil((this.container.nativeElement.clientWidth - (this.dragItem.offsetLeft + this.dragItem.clientWidth)) / this.tileSize);\r\n      }\r\n\r\n      let row = Math.ceil(this.dragItem.offsetTop / this.tileSize);\r\n      if (col < 1) {\r\n        col = 1;\r\n      }\r\n      if (row < 1) {\r\n        row = 1;\r\n      }\r\n      const widgets = Array.from(this.ref.nativeElement.querySelectorAll('.widget-host')).map((c) => c as HTMLElement);\r\n      p.setAttribute(this.DATA_COL, col.toString());\r\n      p.setAttribute(this.DATA_ROW, row.toString());\r\n      const collision = widgets.filter(c => c !== this.dragItem).some(c => AXHtmlUtil.collision(c, this.dragItem));\r\n      if (collision) {\r\n        this.removePlaceholder();\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n\r\n\r\n  private addPlaceholder() {\r\n    this.zone.runOutsideAngular(() => {\r\n      this.removePlaceholder();\r\n      if (this.dragItem) {\r\n        const p = document.createElement('div');\r\n        p.classList.add('widget-blank-placeholder');\r\n        p.setAttribute(this.DATA_COL, this.dragItem.getAttribute(this.DATA_COL));\r\n        p.setAttribute(this.DATA_ROW, this.dragItem.getAttribute(this.DATA_ROW));\r\n        p.setAttribute(this.DATA_SIZE_X, this.dragItem.getAttribute(this.DATA_SIZE_X));\r\n        p.setAttribute(this.DATA_SIZE_Y, this.dragItem.getAttribute(this.DATA_SIZE_Y));\r\n        this.container.nativeElement.appendChild(p);\r\n      }\r\n    });\r\n  }\r\n\r\n  private removePlaceholder() {\r\n    const p = this.container.nativeElement.querySelector('.widget-blank-placeholder');\r\n    p?.remove();\r\n  }\r\n\r\n  public startEdit() {\r\n    this._isInEditing = true;\r\n    this.calcGridSize();\r\n    this.ref.nativeElement.classList.add('grid-background');\r\n    const bg = this.ref.nativeElement as HTMLDivElement;\r\n    bg.style.setProperty('background-position', `${this.rtl ? 'right' : 'left'} top`);\r\n    // tslint:disable-next-line: max-line-length\r\n    const pattern = `url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"${this.tileSize + this.gapSize}\" height=\"${this.tileSize + this.gapSize}\"> <rect style=\"fill: %23dadada\" x=\"${this.rtl ? this.gapSize : 0}\" width=\"${this.tileSize}\" height=\"${this.tileSize}\" y=\"0\"></rect></svg>')`;\r\n    bg.style.setProperty('background-image', pattern);\r\n    //\r\n    const widgets = Array.from(this.ref.nativeElement.querySelectorAll('.widget-host'));\r\n    widgets.forEach((w) => {\r\n      w.addEventListener('mousedown', this.dragStart.bind(this), false);\r\n    });\r\n    this.ref.nativeElement.addEventListener('mousemove', this.drag.bind(this), false);\r\n    this.ref.nativeElement.addEventListener('mouseup', this.dragEnd.bind(this), false);\r\n  }\r\n\r\n  public finishEdit() {\r\n    this.ref.nativeElement.classList.remove('grid-background');\r\n    const bg = this.ref.nativeElement as HTMLDivElement;\r\n    bg.style.removeProperty('background-image');\r\n    //\r\n    this._isInEditing = false;\r\n    const widgets = Array.from(this.ref.nativeElement.querySelectorAll('.widget-host'));\r\n    widgets.forEach((w) => {\r\n      w.removeEventListener('mousedown', this.dragStart.bind(this), false);\r\n    });\r\n    this.ref.nativeElement.removeEventListener('mousemove', this.drag.bind(this), false);\r\n    this.ref.nativeElement.removeEventListener('mouseup', this.dragEnd.bind(this), false);\r\n    this.emitConfigChanged();\r\n  }\r\n\r\n\r\n  addWidget(widget: AXWidgetConfig) {\r\n    this.zone.runOutsideAngular(() => {\r\n      this.newWidget = {\r\n        uniqueName: widget.uniqueName,\r\n        component: widget.component,\r\n        title: widget.title,\r\n        col: 1,\r\n        row: 1,\r\n        sizeX: widget.sizeX,\r\n        sizeY: widget.sizeY,\r\n        options: widget.options,\r\n        props: widget.props\r\n      };\r\n      this.detectFirstEmptySlot(this.newWidget);\r\n      const w = {\r\n        uniqueName: this.newWidget.uniqueName,\r\n        component: this.newWidget.component,\r\n        title: this.newWidget.title,\r\n        options: this.newWidget.options,\r\n        props: this.newWidget.props,\r\n        sizeX: this.newWidget.sizeX,\r\n        sizeY: this.newWidget.sizeY,\r\n        col: this.newWidget.col,\r\n        row: this.newWidget.row\r\n      };\r\n      this.widgets.push(w);\r\n      this.newWidget = null;\r\n      this.zone.run(() => {\r\n        this.cdr.detectChanges();\r\n        this.calcGridSize();\r\n        this.emitConfigChanged();\r\n        setTimeout(() => {\r\n          w['__meta__'].instance.element.addEventListener('mousedown', this.dragStart.bind(this), false);\r\n        }, 1000);\r\n      });\r\n    });\r\n  }\r\n\r\n\r\n  handleOnRemove(w: AXWidgetHostComponent) {\r\n    w.element.classList.add('animate__animated', 'animate__zoomOut');\r\n    w.element.addEventListener('animationend', () => {\r\n      this.widgets = this.widgets.filter((c) => (c as any).__meta__.id !== (w.config as any).__meta__.id);\r\n      this.cdr.detectChanges();\r\n      this.calcGridSize();\r\n      this.emitConfigChanged();\r\n    });\r\n  }\r\n\r\n  handleOnSave(e: AXWidgetConfigSavedEvent) {\r\n    this.onWidgetSave.emit(e);\r\n  }\r\n\r\n  trackByFn(index, item) {\r\n    if (!item['__meta__']?.id) {\r\n      item['__meta__'] = {};\r\n      item['__meta__'].id = AXHtmlUtil.getUID();\r\n    }\r\n    return item['__meta__']?.id;\r\n  }\r\n\r\n\r\n  load(widgets: string | AXWidgetConfig[]): Promise<void> {\r\n    this.clear();\r\n    return new Promise<void>((resolve, reject) => {\r\n      if (widgets) {\r\n        const loadedWidgets: AXWidgetConfig[] = [];\r\n        if (typeof widgets === 'string') {\r\n          try {\r\n            loadedWidgets.push(...JSON.parse(widgets));\r\n          } catch (error) {\r\n            reject('Invalid widget json data!');\r\n          }\r\n        }\r\n        else {\r\n          loadedWidgets.push(...widgets);\r\n        }\r\n        let intervalId: number = -1;\r\n        const loadFunc = () => {\r\n\r\n          if (this.galleryItems && this.galleryItems.length > 0) {\r\n            loadedWidgets.forEach(w => {\r\n              const gitem = this.galleryItems.find(c => c.uniqueName === w.uniqueName);\r\n              if (gitem) {\r\n                w.component = gitem.component;\r\n                if (gitem.props) {\r\n                  w.props = JSON.parse(JSON.stringify(gitem.props));\r\n                }\r\n              }\r\n            });\r\n            this.widgets.push(...loadedWidgets);\r\n            window.clearInterval(intervalId);\r\n            this.cdr.detectChanges();\r\n            resolve();\r\n          }\r\n        };\r\n        intervalId = window.setInterval(loadFunc, 200);\r\n      }\r\n      else {\r\n        resolve();\r\n      }\r\n    });\r\n  }\r\n\r\n  clear() {\r\n    if (this.widgets.length) {\r\n      this.widgets = [];\r\n      this.cdr.detectChanges();\r\n      this.emitConfigChanged();\r\n    }\r\n  }\r\n\r\n  save(): Promise<string> {\r\n    const obj = this.widgets.map(c => ({\r\n      uniqueName: c.uniqueName,\r\n      component: c.component,\r\n      title: c.title,\r\n      sizeX: c.sizeX,\r\n      sizeY: c.sizeY,\r\n      col: c.col,\r\n      row: c.row,\r\n      options: c.options,\r\n      props: c.props\r\n    }));\r\n    return Promise.resolve(JSON.stringify(obj));\r\n  }\r\n\r\n  refresh() {\r\n    this.widgetHosts.forEach(host => {\r\n      host.widget.refresh();\r\n    });\r\n  }\r\n\r\n  handleOnConfigChanged(e: AXWidgetConfigChanged) {\r\n    this.cdr.detectChanges();\r\n    this.emitConfigChanged();\r\n  }\r\n\r\n  handleOnResizedChanged(e: AXWidgetConfigChanged) {\r\n    this.detectFirstEmptySlot(e.config);\r\n    this.cdr.detectChanges();\r\n    this.emitConfigChanged();\r\n  }\r\n\r\n  private resizeChangeObserver: any;\r\n  private emitConfigChanged() {\r\n    if (!this.resizeChangeObserver) {\r\n      this.resizeChangeObserver = new Observable();\r\n      Observable.create(observer => {\r\n        this.resizeChangeObserver = observer;\r\n      })\r\n        .pipe(debounceTime(750))\r\n        .pipe(distinctUntilChanged())\r\n        .subscribe(c => {\r\n          this.onConfigChanged.emit({\r\n            component: this\r\n          });\r\n        });\r\n    }\r\n    this.resizeChangeObserver.next(new Date());\r\n  }\r\n}\r\n"]}