@huntsman-cancer-institute/dashboard 17.9.0 → 17.9.2

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.
@@ -190,129 +190,129 @@ export class DashboardComponent {
190
190
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: DashboardComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i1.DashboardService }, { token: i2.DashboardGlobalService }, { token: i3.DragulaService }, { token: i4.NgbModal }], target: i0.ɵɵFactoryTarget.Component }); }
191
191
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: DashboardComponent, selector: "dashboard", host: { properties: { "class": "this.classList" } }, providers: [
192
192
  DashboardService
193
- ], viewQueries: [{ propertyName: "widgetConfigure", first: true, predicate: ["widgetConfigure"], descendants: true }, { propertyName: "widgetContainers", predicate: WidgetContainerComponent, descendants: true, read: ElementRef }], ngImport: i0, template: `
194
- <ng-template #confirmDialog let-c="close" let-d="dismiss">
195
- <div class="modal-header">
196
- <h5 class="modal-title">Delete</h5>
197
- </div>
198
- <div class="modal-body">
199
- <p>Are you sure?</p>
200
- </div>
201
- <div class="modal-footer">
202
- <button type="button" class="btn btn-primary" (click)="c('Yes')">Yes</button>
203
- <button type="button" class="btn btn-secondary" (click)="d('No')">No</button>
204
- </div>
205
- </ng-template>
206
-
207
- <widget-add [dashboardIndex]="selectedIndex"></widget-add>
208
-
209
- <div class="edit-mode-header"
210
- [@openEditModeHeader]="editMode"
211
- [@openEditModeHeaderDisplay]="editMode">
212
- <button class="btn btn-primary btn-space"
213
- (click)="addWidget()">
214
- <i class="fas fa-plus fa-2x"></i>
215
- <br />
216
- <span>Widget</span>
217
- </button>
218
- <button *ngIf="configMode === 'true'"
219
- class="btn btn-primary btn-space red"
220
- (click)="deleteWidget()">
221
- <i class="fas fa-times fa-2x"></i>
222
- <br />
223
- <span>Widget</span>
224
- </button>
225
- <button class="btn btn-primary btn-space"
226
- (click)="addDashboard()">
227
- <i class="fas fa-plus fa-2x"></i>
228
- <br />
229
- <span>Dashboard</span>
230
- </button>
231
- <button class="btn btn-primary btn-space red"
232
- *ngIf="dashboards.length > 1"
233
- (click)="deleteDashboard(confirmDialog)">
234
- <i class="fas fa-times fa-2x"></i>
235
- <br />
236
- <span>Dashboard</span>
237
- </button>
238
- <button class="btn btn-primary btn-space green"
239
- (click)="setEditMode(false)">
240
- <i class="fas fa-check fa-2x"></i>
241
- <br />
242
- <span>Done</span>
243
- </button>
244
- </div>
245
-
246
- <div class="outlet-row">
247
-
248
- <!-- Iterate over all dashboards. Show non selected dashboards off screen. -->
249
- <ng-template ngFor let-dashboard [ngForOf]="dashboards" let-dashboardIndex="index">
250
- <div class="d-flex"
251
- [style.left]="selectedIndex !== dashboardIndex ? '100vw' : 'inherit'"
252
- [style.position]="selectedIndex !== dashboardIndex ? 'fixed' : 'inherit'"
253
- [@openConfigContent]="configMode">
254
- <widget-container
255
- [dashboard]="dashboard"
256
- [dashboardIndex]="dashboardIndex">
257
- </widget-container>
258
- </div>
259
- </ng-template>
260
-
261
- <div [style.display]="configMode === 'true' ? 'flex' : 'none'" class="sidebar-widget-config" [@openConfigSidebar]="configMode">
262
- <div class="outlet-column" style="background-color: white; height: 100%; padding: 2px;">
263
- <div class="d-flex flex-nowrap">
264
- <div><h4>Settings</h4></div>
265
- <div style="margin-right: 0px; margin-left: auto;">
266
- <span style="color: var(--pure-green);" (click)="saveConfiguration()">
267
- <i class="fas fa-check-circle fa-2x"></i>
268
- </span>
269
- <span style="color: var(--pure-red);" (click)="cancelConfiguration()">
270
- <i class="fas fa-times-circle fa-2x"></i>
271
- </span>
272
- </div>
273
- </div>
274
- <widget-configure #widgetConfigure></widget-configure>
275
- </div>
276
- </div>
277
- </div>
278
-
279
- <ng-container *ngIf="dashboards?.length > 1">
280
- <div class="dashboard-nav-trigger">
281
- <span (mouseenter)="openDashboardNavState = 'opened'">
282
- <i class="fas fa-th fa-2x"></i>
283
- </span>
284
- </div>
285
-
286
- <div class="dashboard-nav"
287
- [@openDashboardNav]="openDashboardNavState"
288
- [style.left]="'calc(50vw - ' + dashboards?.length * 50 + 'px)'"
289
- (mouseleave)="openDashboardNavState = 'closed'">
290
- <ng-container *ngFor="let dashboard of dashboards; index as i">
291
- <div [id]="'dash-image-' + i"
292
- class="widget-image"
293
- [ngClass]="i === selectedIndex ? 'selected' : ''"
294
- (click)="selectDashboard(i)">
295
- </div>
296
- </ng-container>
297
- </div>
298
- </ng-container>
299
-
300
- <ng-container *ngIf="helpMode">
301
- <div id="helpParent">
302
- <div id="helpChild">
303
- <div style="width: 100%; display: inline-flex;">
304
- <h4>Help</h4>
305
- <span style="margin-right: 0; margin-left: auto; color: var(--pure-red);" (click)="setHelpMode(false)">
306
- <i class="fas fa-times fa-lg"></i>
307
- </span>
308
- </div>
309
- <div>
310
- The dashboard is a collection of widgets that you can customize to your own needs. In this edit mode, you
311
- can drag and drop widgets to change the order and double click a widget to change its configuration.
312
- </div>
313
- </div>
314
- </div>
315
- </ng-container>
193
+ ], viewQueries: [{ propertyName: "widgetConfigure", first: true, predicate: ["widgetConfigure"], descendants: true }, { propertyName: "widgetContainers", predicate: WidgetContainerComponent, descendants: true, read: ElementRef }], ngImport: i0, template: `
194
+ <ng-template #confirmDialog let-c="close" let-d="dismiss">
195
+ <div class="modal-header">
196
+ <h5 class="modal-title">Delete</h5>
197
+ </div>
198
+ <div class="modal-body">
199
+ <p>Are you sure?</p>
200
+ </div>
201
+ <div class="modal-footer">
202
+ <button type="button" class="btn btn-primary" (click)="c('Yes')">Yes</button>
203
+ <button type="button" class="btn btn-secondary" (click)="d('No')">No</button>
204
+ </div>
205
+ </ng-template>
206
+
207
+ <widget-add [dashboardIndex]="selectedIndex"></widget-add>
208
+
209
+ <div class="edit-mode-header"
210
+ [@openEditModeHeader]="editMode"
211
+ [@openEditModeHeaderDisplay]="editMode">
212
+ <button class="btn btn-primary btn-space"
213
+ (click)="addWidget()">
214
+ <i class="fas fa-plus fa-2x"></i>
215
+ <br />
216
+ <span>Widget</span>
217
+ </button>
218
+ <button *ngIf="configMode === 'true'"
219
+ class="btn btn-primary btn-space red"
220
+ (click)="deleteWidget()">
221
+ <i class="fas fa-times fa-2x"></i>
222
+ <br />
223
+ <span>Widget</span>
224
+ </button>
225
+ <button class="btn btn-primary btn-space"
226
+ (click)="addDashboard()">
227
+ <i class="fas fa-plus fa-2x"></i>
228
+ <br />
229
+ <span>Dashboard</span>
230
+ </button>
231
+ <button class="btn btn-primary btn-space red"
232
+ *ngIf="dashboards.length > 1"
233
+ (click)="deleteDashboard(confirmDialog)">
234
+ <i class="fas fa-times fa-2x"></i>
235
+ <br />
236
+ <span>Dashboard</span>
237
+ </button>
238
+ <button class="btn btn-primary btn-space green"
239
+ (click)="setEditMode(false)">
240
+ <i class="fas fa-check fa-2x"></i>
241
+ <br />
242
+ <span>Done</span>
243
+ </button>
244
+ </div>
245
+
246
+ <div class="outlet-row">
247
+
248
+ <!-- Iterate over all dashboards. Show non selected dashboards off screen. -->
249
+ <ng-template ngFor let-dashboard [ngForOf]="dashboards" let-dashboardIndex="index">
250
+ <div class="d-flex"
251
+ [style.left]="selectedIndex !== dashboardIndex ? '100vw' : 'inherit'"
252
+ [style.position]="selectedIndex !== dashboardIndex ? 'fixed' : 'inherit'"
253
+ [@openConfigContent]="configMode">
254
+ <widget-container
255
+ [dashboard]="dashboard"
256
+ [dashboardIndex]="dashboardIndex">
257
+ </widget-container>
258
+ </div>
259
+ </ng-template>
260
+
261
+ <div [style.display]="configMode === 'true' ? 'flex' : 'none'" class="sidebar-widget-config" [@openConfigSidebar]="configMode">
262
+ <div class="outlet-column" style="background-color: white; height: 100%; padding: 2px;">
263
+ <div class="d-flex flex-nowrap">
264
+ <div><h4>Settings</h4></div>
265
+ <div style="margin-right: 0px; margin-left: auto;">
266
+ <span style="color: var(--pure-green);" (click)="saveConfiguration()">
267
+ <i class="fas fa-check-circle fa-2x"></i>
268
+ </span>
269
+ <span style="color: var(--pure-red);" (click)="cancelConfiguration()">
270
+ <i class="fas fa-times-circle fa-2x"></i>
271
+ </span>
272
+ </div>
273
+ </div>
274
+ <widget-configure #widgetConfigure></widget-configure>
275
+ </div>
276
+ </div>
277
+ </div>
278
+
279
+ <ng-container *ngIf="dashboards?.length > 1">
280
+ <div class="dashboard-nav-trigger">
281
+ <span (mouseenter)="openDashboardNavState = 'opened'">
282
+ <i class="fas fa-th fa-2x"></i>
283
+ </span>
284
+ </div>
285
+
286
+ <div class="dashboard-nav"
287
+ [@openDashboardNav]="openDashboardNavState"
288
+ [style.left]="'calc(50vw - ' + dashboards?.length * 50 + 'px)'"
289
+ (mouseleave)="openDashboardNavState = 'closed'">
290
+ <ng-container *ngFor="let dashboard of dashboards; index as i">
291
+ <div [id]="'dash-image-' + i"
292
+ class="widget-image"
293
+ [ngClass]="i === selectedIndex ? 'selected' : ''"
294
+ (click)="selectDashboard(i)">
295
+ </div>
296
+ </ng-container>
297
+ </div>
298
+ </ng-container>
299
+
300
+ <ng-container *ngIf="helpMode">
301
+ <div id="helpParent">
302
+ <div id="helpChild">
303
+ <div style="width: 100%; display: inline-flex;">
304
+ <h4>Help</h4>
305
+ <span style="margin-right: 0; margin-left: auto; color: var(--pure-red);" (click)="setHelpMode(false)">
306
+ <i class="fas fa-times fa-lg"></i>
307
+ </span>
308
+ </div>
309
+ <div>
310
+ The dashboard is a collection of widgets that you can customize to your own needs. In this edit mode, you
311
+ can drag and drop widgets to change the order and double click a widget to change its configuration.
312
+ </div>
313
+ </div>
314
+ </div>
315
+ </ng-container>
316
316
  `, isInline: true, styles: ["#helpParent{position:fixed;display:flex;width:100vw;height:100vh;left:0;top:0;z-index:999;background:#00000040}#helpChild{width:75%;height:75%;margin:auto;background:#fff;border-radius:25px;box-shadow:2px 2px #000;padding:20px}.sidebar-widget-config{background-color:#fdd;border-left:gray 1px solid;padding:10px 0 10px 10px;opacity:0;width:0%}.modal{background-color:#00000040}.edit-mode-header{border-bottom:black 1px dashed;padding-top:10px;padding-bottom:10px;z-index:10;background-color:#fff}.edit-mode-header button{padding:.2rem .5rem}.btn-space{margin-left:10px}.btn.green{background-color:green}.btn.red{background-color:red}.dashboard-nav-trigger{bottom:40px;position:fixed;z-index:100;display:inline-block;width:100%;text-align:center;padding-top:15px;background:#fff;background:linear-gradient(0deg,white,white,transparent)}.dashboard-nav{bottom:-150px;position:fixed;z-index:101;display:inline-block;background-color:#fff}.widget-image{display:inline-block;max-height:100px;height:100px;min-height:100px;max-width:100px;width:100px;min-width:100px;border:black 1px solid;vertical-align:bottom;overflow-y:hidden;overflow-x:hidden}.widget-image.selected{border:red 2px solid}\n"], dependencies: [{ kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i6.WidgetContainerComponent, selector: "widget-container", inputs: ["dashboard", "dashboardIndex"] }, { kind: "component", type: i7.WidgetAddComponent, selector: "widget-add", inputs: ["dashboardIndex"] }, { kind: "component", type: i8.WidgetConfigureComponent, selector: "widget-configure" }], animations: [
317
317
  trigger("openConfigContent", [
318
318
  state("false", style({
@@ -384,129 +384,129 @@ export class DashboardComponent {
384
384
  }
385
385
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: DashboardComponent, decorators: [{
386
386
  type: Component,
387
- args: [{ selector: "dashboard", template: `
388
- <ng-template #confirmDialog let-c="close" let-d="dismiss">
389
- <div class="modal-header">
390
- <h5 class="modal-title">Delete</h5>
391
- </div>
392
- <div class="modal-body">
393
- <p>Are you sure?</p>
394
- </div>
395
- <div class="modal-footer">
396
- <button type="button" class="btn btn-primary" (click)="c('Yes')">Yes</button>
397
- <button type="button" class="btn btn-secondary" (click)="d('No')">No</button>
398
- </div>
399
- </ng-template>
400
-
401
- <widget-add [dashboardIndex]="selectedIndex"></widget-add>
402
-
403
- <div class="edit-mode-header"
404
- [@openEditModeHeader]="editMode"
405
- [@openEditModeHeaderDisplay]="editMode">
406
- <button class="btn btn-primary btn-space"
407
- (click)="addWidget()">
408
- <i class="fas fa-plus fa-2x"></i>
409
- <br />
410
- <span>Widget</span>
411
- </button>
412
- <button *ngIf="configMode === 'true'"
413
- class="btn btn-primary btn-space red"
414
- (click)="deleteWidget()">
415
- <i class="fas fa-times fa-2x"></i>
416
- <br />
417
- <span>Widget</span>
418
- </button>
419
- <button class="btn btn-primary btn-space"
420
- (click)="addDashboard()">
421
- <i class="fas fa-plus fa-2x"></i>
422
- <br />
423
- <span>Dashboard</span>
424
- </button>
425
- <button class="btn btn-primary btn-space red"
426
- *ngIf="dashboards.length > 1"
427
- (click)="deleteDashboard(confirmDialog)">
428
- <i class="fas fa-times fa-2x"></i>
429
- <br />
430
- <span>Dashboard</span>
431
- </button>
432
- <button class="btn btn-primary btn-space green"
433
- (click)="setEditMode(false)">
434
- <i class="fas fa-check fa-2x"></i>
435
- <br />
436
- <span>Done</span>
437
- </button>
438
- </div>
439
-
440
- <div class="outlet-row">
441
-
442
- <!-- Iterate over all dashboards. Show non selected dashboards off screen. -->
443
- <ng-template ngFor let-dashboard [ngForOf]="dashboards" let-dashboardIndex="index">
444
- <div class="d-flex"
445
- [style.left]="selectedIndex !== dashboardIndex ? '100vw' : 'inherit'"
446
- [style.position]="selectedIndex !== dashboardIndex ? 'fixed' : 'inherit'"
447
- [@openConfigContent]="configMode">
448
- <widget-container
449
- [dashboard]="dashboard"
450
- [dashboardIndex]="dashboardIndex">
451
- </widget-container>
452
- </div>
453
- </ng-template>
454
-
455
- <div [style.display]="configMode === 'true' ? 'flex' : 'none'" class="sidebar-widget-config" [@openConfigSidebar]="configMode">
456
- <div class="outlet-column" style="background-color: white; height: 100%; padding: 2px;">
457
- <div class="d-flex flex-nowrap">
458
- <div><h4>Settings</h4></div>
459
- <div style="margin-right: 0px; margin-left: auto;">
460
- <span style="color: var(--pure-green);" (click)="saveConfiguration()">
461
- <i class="fas fa-check-circle fa-2x"></i>
462
- </span>
463
- <span style="color: var(--pure-red);" (click)="cancelConfiguration()">
464
- <i class="fas fa-times-circle fa-2x"></i>
465
- </span>
466
- </div>
467
- </div>
468
- <widget-configure #widgetConfigure></widget-configure>
469
- </div>
470
- </div>
471
- </div>
472
-
473
- <ng-container *ngIf="dashboards?.length > 1">
474
- <div class="dashboard-nav-trigger">
475
- <span (mouseenter)="openDashboardNavState = 'opened'">
476
- <i class="fas fa-th fa-2x"></i>
477
- </span>
478
- </div>
479
-
480
- <div class="dashboard-nav"
481
- [@openDashboardNav]="openDashboardNavState"
482
- [style.left]="'calc(50vw - ' + dashboards?.length * 50 + 'px)'"
483
- (mouseleave)="openDashboardNavState = 'closed'">
484
- <ng-container *ngFor="let dashboard of dashboards; index as i">
485
- <div [id]="'dash-image-' + i"
486
- class="widget-image"
487
- [ngClass]="i === selectedIndex ? 'selected' : ''"
488
- (click)="selectDashboard(i)">
489
- </div>
490
- </ng-container>
491
- </div>
492
- </ng-container>
493
-
494
- <ng-container *ngIf="helpMode">
495
- <div id="helpParent">
496
- <div id="helpChild">
497
- <div style="width: 100%; display: inline-flex;">
498
- <h4>Help</h4>
499
- <span style="margin-right: 0; margin-left: auto; color: var(--pure-red);" (click)="setHelpMode(false)">
500
- <i class="fas fa-times fa-lg"></i>
501
- </span>
502
- </div>
503
- <div>
504
- The dashboard is a collection of widgets that you can customize to your own needs. In this edit mode, you
505
- can drag and drop widgets to change the order and double click a widget to change its configuration.
506
- </div>
507
- </div>
508
- </div>
509
- </ng-container>
387
+ args: [{ selector: "dashboard", template: `
388
+ <ng-template #confirmDialog let-c="close" let-d="dismiss">
389
+ <div class="modal-header">
390
+ <h5 class="modal-title">Delete</h5>
391
+ </div>
392
+ <div class="modal-body">
393
+ <p>Are you sure?</p>
394
+ </div>
395
+ <div class="modal-footer">
396
+ <button type="button" class="btn btn-primary" (click)="c('Yes')">Yes</button>
397
+ <button type="button" class="btn btn-secondary" (click)="d('No')">No</button>
398
+ </div>
399
+ </ng-template>
400
+
401
+ <widget-add [dashboardIndex]="selectedIndex"></widget-add>
402
+
403
+ <div class="edit-mode-header"
404
+ [@openEditModeHeader]="editMode"
405
+ [@openEditModeHeaderDisplay]="editMode">
406
+ <button class="btn btn-primary btn-space"
407
+ (click)="addWidget()">
408
+ <i class="fas fa-plus fa-2x"></i>
409
+ <br />
410
+ <span>Widget</span>
411
+ </button>
412
+ <button *ngIf="configMode === 'true'"
413
+ class="btn btn-primary btn-space red"
414
+ (click)="deleteWidget()">
415
+ <i class="fas fa-times fa-2x"></i>
416
+ <br />
417
+ <span>Widget</span>
418
+ </button>
419
+ <button class="btn btn-primary btn-space"
420
+ (click)="addDashboard()">
421
+ <i class="fas fa-plus fa-2x"></i>
422
+ <br />
423
+ <span>Dashboard</span>
424
+ </button>
425
+ <button class="btn btn-primary btn-space red"
426
+ *ngIf="dashboards.length > 1"
427
+ (click)="deleteDashboard(confirmDialog)">
428
+ <i class="fas fa-times fa-2x"></i>
429
+ <br />
430
+ <span>Dashboard</span>
431
+ </button>
432
+ <button class="btn btn-primary btn-space green"
433
+ (click)="setEditMode(false)">
434
+ <i class="fas fa-check fa-2x"></i>
435
+ <br />
436
+ <span>Done</span>
437
+ </button>
438
+ </div>
439
+
440
+ <div class="outlet-row">
441
+
442
+ <!-- Iterate over all dashboards. Show non selected dashboards off screen. -->
443
+ <ng-template ngFor let-dashboard [ngForOf]="dashboards" let-dashboardIndex="index">
444
+ <div class="d-flex"
445
+ [style.left]="selectedIndex !== dashboardIndex ? '100vw' : 'inherit'"
446
+ [style.position]="selectedIndex !== dashboardIndex ? 'fixed' : 'inherit'"
447
+ [@openConfigContent]="configMode">
448
+ <widget-container
449
+ [dashboard]="dashboard"
450
+ [dashboardIndex]="dashboardIndex">
451
+ </widget-container>
452
+ </div>
453
+ </ng-template>
454
+
455
+ <div [style.display]="configMode === 'true' ? 'flex' : 'none'" class="sidebar-widget-config" [@openConfigSidebar]="configMode">
456
+ <div class="outlet-column" style="background-color: white; height: 100%; padding: 2px;">
457
+ <div class="d-flex flex-nowrap">
458
+ <div><h4>Settings</h4></div>
459
+ <div style="margin-right: 0px; margin-left: auto;">
460
+ <span style="color: var(--pure-green);" (click)="saveConfiguration()">
461
+ <i class="fas fa-check-circle fa-2x"></i>
462
+ </span>
463
+ <span style="color: var(--pure-red);" (click)="cancelConfiguration()">
464
+ <i class="fas fa-times-circle fa-2x"></i>
465
+ </span>
466
+ </div>
467
+ </div>
468
+ <widget-configure #widgetConfigure></widget-configure>
469
+ </div>
470
+ </div>
471
+ </div>
472
+
473
+ <ng-container *ngIf="dashboards?.length > 1">
474
+ <div class="dashboard-nav-trigger">
475
+ <span (mouseenter)="openDashboardNavState = 'opened'">
476
+ <i class="fas fa-th fa-2x"></i>
477
+ </span>
478
+ </div>
479
+
480
+ <div class="dashboard-nav"
481
+ [@openDashboardNav]="openDashboardNavState"
482
+ [style.left]="'calc(50vw - ' + dashboards?.length * 50 + 'px)'"
483
+ (mouseleave)="openDashboardNavState = 'closed'">
484
+ <ng-container *ngFor="let dashboard of dashboards; index as i">
485
+ <div [id]="'dash-image-' + i"
486
+ class="widget-image"
487
+ [ngClass]="i === selectedIndex ? 'selected' : ''"
488
+ (click)="selectDashboard(i)">
489
+ </div>
490
+ </ng-container>
491
+ </div>
492
+ </ng-container>
493
+
494
+ <ng-container *ngIf="helpMode">
495
+ <div id="helpParent">
496
+ <div id="helpChild">
497
+ <div style="width: 100%; display: inline-flex;">
498
+ <h4>Help</h4>
499
+ <span style="margin-right: 0; margin-left: auto; color: var(--pure-red);" (click)="setHelpMode(false)">
500
+ <i class="fas fa-times fa-lg"></i>
501
+ </span>
502
+ </div>
503
+ <div>
504
+ The dashboard is a collection of widgets that you can customize to your own needs. In this edit mode, you
505
+ can drag and drop widgets to change the order and double click a widget to change its configuration.
506
+ </div>
507
+ </div>
508
+ </div>
509
+ </ng-container>
510
510
  `, animations: [
511
511
  trigger("openConfigContent", [
512
512
  state("false", style({
@@ -587,4 +587,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
587
587
  type: ViewChild,
588
588
  args: ["widgetConfigure", { static: false }]
589
589
  }] } });
590
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dashboard.component.js","sourceRoot":"","sources":["../../../projects/dashboard/src/dashboard.component.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,EACL,iBAAiB,EAAE,SAAS,EAAE,UAAU,EAAE,SAAS,EAAE,SAAS,EAAE,YAAY,EAAE,SAAS,EACvF,WAAW,EACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAC,MAAM,qBAAqB,CAAC;AAE/E,OAAO,EAAC,cAAc,EAAC,MAAM,aAAa,CAAC;AAC3C,OAAO,UAAU,MAAM,cAAc,CAAC;AACtC,OAAO,EAAC,QAAQ,EAAC,MAAM,4BAA4B,CAAC;AAEpD,OAAO,EAAC,SAAS,EAAiB,MAAM,eAAe,CAAC;AACxD,OAAO,EAAC,gBAAgB,EAAC,MAAM,8BAA8B,CAAC;AAC9D,OAAO,EAAC,wBAAwB,EAAC,MAAM,wCAAwC,CAAC;AAChF,OAAO,EAAC,wBAAwB,EAAC,MAAM,qCAAqC,CAAC;AAC7E,OAAO,EAAC,sBAAsB,EAAC,MAAM,qCAAqC,CAAC;;;;;;;;;;AAE3E;;;;;;GAMG;AAkTH,MAAM,OAAO,kBAAkB;IAoB7B,YAAoB,iBAAoC,EACpC,UAAsB,EACtB,gBAAkC,EAClC,sBAA8C,EAC9C,cAA8B,EAC9B,YAAsB;QALtB,sBAAiB,GAAjB,iBAAiB,CAAmB;QACpC,eAAU,GAAV,UAAU,CAAY;QACtB,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,2BAAsB,GAAtB,sBAAsB,CAAwB;QAC9C,mBAAc,GAAd,cAAc,CAAgB;QAC9B,iBAAY,GAAZ,YAAY,CAAU;QAvBpB,cAAS,GAAW,eAAe,CAAC;QAEnD,0BAAqB,GAAW,QAAQ,CAAC;QAEzC,aAAQ,GAAY,KAAK,CAAC;QAC1B,aAAQ,GAAW,QAAQ,CAAC;QAC5B,kBAAa,GAAG,CAAC,CAAC;QAElB,eAAU,GAAgB,EAAE,CAAC;QAE7B,2BAAsB,GAAY,KAAK,CAAC;QAE/C,eAAU,GAAW,OAAO,CAAC;QAY3B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,CAAC;QAExD,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,UAAuB,EAAE,EAAE;YAC1E,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC/B,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,gBAAgB,CAAC,kCAAkC,CAAC,SAAS,CAAC,CAAC,cAA8B,EAAE,EAAE;YACpG,IAAI,cAAc,EAAE,CAAC;gBACnB,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC;YAC3B,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC;YAC5B,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,CAAC,QAAiB,EAAE,EAAE;YAClE,IAAI,SAAS,EAAE,EAAE,CAAC;gBAChB,OAAO,CAAC,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC,CAAC;YAC1C,CAAC;YAED,IAAI,QAAQ,EAAE,CAAC;gBACb,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;YAC3B,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;YAC3B,CAAC;QACH,CAAC,CAAC,CAAC;QAEH;;;;;;;;;;;;;;;;;;;;aAoBK;IACP,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,sBAAsB,CAAC,yBAAyB,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;IAC/E,CAAC;IAED,eAAe;QACb,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,gBAAwC,EAAE,EAAE;YACnF,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAClC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,WAAW;QACT,IAAI,CAAC,sBAAsB,CAAC,yBAAyB,EAAE,CAAC;IAC1D,CAAC;IAED,eAAe,CAAC,KAAa;QAC3B,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;IAC7B,CAAC;IAED;;;;OAIG;IACH,WAAW,CAAC,QAAiB;QAC3B,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;IAC9C,CAAC;IAED,WAAW,CAAC,QAAiB;QAC3B,IAAI,SAAS,EAAE,EAAE,CAAC;YAChB,OAAO,CAAC,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC,CAAC;QAC1C,CAAC;QAED,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;IACxC,CAAC;IAED;;;OAGG;IACH,wBAAwB;QACtB,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,IAAI,GAAG,IAAI,CAAC;YAChB,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,UAAsB,EAAE,KAAa,EAAE,EAAE;gBACtE,IAAI,EAAE,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,aAAa,CAAC,cAAc,GAAG,KAAK,CAAC,CAAC;gBAC7E,IAAI,EAAE,EAAE,CAAC;oBACP,UAAU,CAAC,KAAK,CAAC,UAAU,CAAC,aAAa,CAAC;yBACvC,IAAI,CAAC,UAAU,OAAO;wBACrB,IAAI,GAAG,GAAG,IAAI,KAAK,EAAE,CAAC;wBACtB,GAAG,CAAC,KAAK,GAAG,GAAG,CAAC;wBAChB,GAAG,CAAC,GAAG,GAAG,OAAO,CAAC;wBAClB,EAAE,CAAC,SAAS,GAAG,EAAE,CAAC;wBAClB,EAAE,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;wBACpB,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC;oBACrC,CAAC,CAAC;yBACD,KAAK,CAAC,UAAU,KAAK;wBACpB,OAAO,CAAC,KAAK,CAAC,oBAAoB,EAAE,KAAK,CAAC,CAAC;oBAC7C,CAAC,CAAC,CAAC;gBACP,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC,EAAE,IAAI,CAAC,CAAC;IACX,CAAC;IAED;;;OAGG;IACH,SAAS;QACP,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpD,CAAC;IAED,YAAY;QACV,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,IAAI,CAAC,gBAAgB,CAAC,kCAAkC,CAAC,QAAQ,EAAE,CAAC,CAAC;IAC1G,CAAC;IAED,mBAAmB;QACjB,IAAI,CAAC,gBAAgB,CAAC,yBAAyB,EAAE,CAAC;IACpD,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,gBAAgB,CAAC,uBAAuB,EAAE,CAAC;IAClD,CAAC;IAED;;;OAGG;IACH,YAAY;QACV,IAAI,SAAS,GAAc,IAAI,SAAS,EAAE,CAAC;QAC3C,SAAS,CAAC,IAAI,GAAG,MAAM,CAAC;QACxB,SAAS,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC;QAC7C,SAAS,CAAC,eAAe,GAAG,EAAE,CAAC;QAC/B,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,CAAC,KAAa,EAAE,EAAE;YACxE,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC7B,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;;;;OAKG;IACH,eAAe,CAAC,OAAO;QACrB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,MAAc,EAAE,EAAE;YAC7D,IAAI,MAAM,KAAK,KAAK,EAAE,CAAC;gBACrB,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,SAAS,CAAC,CAAC,KAAa,EAAE,EAAE;oBACpF,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;gBAC7B,CAAC,CAAC,CAAC;YACL,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;8GA1LU,kBAAkB;kGAAlB,kBAAkB,yFAJlB;YACT,gBAAgB;SACjB,oKAkBa,wBAAwB,2BAAU,UAAU,6BA/ThD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2HT,+1DACW;YACV,OAAO,CAAC,mBAAmB,EACzB;gBACE,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC;oBACnB,KAAK,EAAE,MAAM;iBACd,CAAC,CAAC;gBACH,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC;oBAClB,KAAK,EAAE,KAAK;iBACb,CAAC,CAAC;gBACH,UAAU,CAAC,eAAe,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;gBACzC,UAAU,CAAC,eAAe,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;aAC1C,CACF;YACD,OAAO,CAAC,mBAAmB,EACzB;gBACE,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC;oBACnB,OAAO,EAAE,GAAG;oBACZ,KAAK,EAAE,IAAI;iBACZ,CAAC,CAAC;gBACH,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC;oBAClB,OAAO,EAAE,GAAG;oBACZ,KAAK,EAAE,KAAK;iBACb,CAAC,CAAC;gBACH,UAAU,CAAC,eAAe,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;gBACzC,UAAU,CAAC,eAAe,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;aAC1C,CACF;YACD,OAAO,CAAC,kBAAkB,EACxB;gBACE,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC;oBACpB,OAAO,EAAE,GAAG;oBACZ,MAAM,EAAE,QAAQ;iBACjB,CAAC,CAAC;gBACH,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC;oBACpB,OAAO,EAAE,GAAG;oBACZ,MAAM,EAAE,MAAM;iBACf,CAAC,CAAC;gBACH,UAAU,CAAC,kBAAkB,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;gBAC5C,UAAU,CAAC,kBAAkB,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;aAC7C,CACF;YACD;;;;;;;;;iBASK;YACL,OAAO,CAAC,oBAAoB,EAAE;gBAC5B,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC;oBACpB,SAAS,EAAE,GAAG;oBACd,YAAY,EAAE,QAAQ;iBACvB,CAAC,CAAC;gBACH,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC;oBACpB,SAAS,EAAE,GAAG;oBACd,YAAY,EAAE,SAAS;iBACxB,CAAC,CAAC;gBACH,UAAU,CAAC,kBAAkB,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;gBAC5C,UAAU,CAAC,kBAAkB,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;aAC7C,CAAC;YACF,OAAO,CAAC,2BAA2B,EAAE;gBACnC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC;oBACpB,SAAS,EAAE,MAAM;iBAClB,CAAC,CAAC;gBACH,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC;oBACpB,SAAS,EAAE,MAAM;iBAClB,CAAC,CAAC;gBACH,UAAU,CAAC,kBAAkB,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;gBAC5C,UAAU,CAAC,kBAAkB,EAAE,OAAO,CAAC,aAAa,CAAC,CAAC;aACvD,CAAC;SACH;;2FA0GU,kBAAkB;kBAjT9B,SAAS;+BACE,WAAW,YACX;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2HT,cACW;wBACV,OAAO,CAAC,mBAAmB,EACzB;4BACE,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC;gCACnB,KAAK,EAAE,MAAM;6BACd,CAAC,CAAC;4BACH,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC;gCAClB,KAAK,EAAE,KAAK;6BACb,CAAC,CAAC;4BACH,UAAU,CAAC,eAAe,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;4BACzC,UAAU,CAAC,eAAe,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;yBAC1C,CACF;wBACD,OAAO,CAAC,mBAAmB,EACzB;4BACE,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC;gCACnB,OAAO,EAAE,GAAG;gCACZ,KAAK,EAAE,IAAI;6BACZ,CAAC,CAAC;4BACH,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC;gCAClB,OAAO,EAAE,GAAG;gCACZ,KAAK,EAAE,KAAK;6BACb,CAAC,CAAC;4BACH,UAAU,CAAC,eAAe,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;4BACzC,UAAU,CAAC,eAAe,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;yBAC1C,CACF;wBACD,OAAO,CAAC,kBAAkB,EACxB;4BACE,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC;gCACpB,OAAO,EAAE,GAAG;gCACZ,MAAM,EAAE,QAAQ;6BACjB,CAAC,CAAC;4BACH,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC;gCACpB,OAAO,EAAE,GAAG;gCACZ,MAAM,EAAE,MAAM;6BACf,CAAC,CAAC;4BACH,UAAU,CAAC,kBAAkB,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;4BAC5C,UAAU,CAAC,kBAAkB,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;yBAC7C,CACF;wBACD;;;;;;;;;6BASK;wBACL,OAAO,CAAC,oBAAoB,EAAE;4BAC5B,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC;gCACpB,SAAS,EAAE,GAAG;gCACd,YAAY,EAAE,QAAQ;6BACvB,CAAC,CAAC;4BACH,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC;gCACpB,SAAS,EAAE,GAAG;gCACd,YAAY,EAAE,SAAS;6BACxB,CAAC,CAAC;4BACH,UAAU,CAAC,kBAAkB,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;4BAC5C,UAAU,CAAC,kBAAkB,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;yBAC7C,CAAC;wBACF,OAAO,CAAC,2BAA2B,EAAE;4BACnC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC;gCACpB,SAAS,EAAE,MAAM;6BAClB,CAAC,CAAC;4BACH,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC;gCACpB,SAAS,EAAE,MAAM;6BAClB,CAAC,CAAC;4BACH,UAAU,CAAC,kBAAkB,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;4BAC5C,UAAU,CAAC,kBAAkB,EAAE,OAAO,CAAC,aAAa,CAAC,CAAC;yBACvD,CAAC;qBACH,aAsGU;wBACT,gBAAgB;qBACjB;uOAIqB,SAAS;sBAA9B,WAAW;uBAAC,OAAO;gBAc0C,gBAAgB;sBAA7E,YAAY;uBAAC,wBAAwB,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;gBAEb,eAAe;sBAA7D,SAAS;uBAAC,iBAAiB,EAAE,EAAC,MAAM,EAAE,KAAK,EAAC","sourcesContent":["/*\n * Copyright (c) 2016 Huntsman Cancer Institute at the University of Utah, Confidential and Proprietary\n */\nimport {\n  ChangeDetectorRef, Component, ElementRef, isDevMode, QueryList, ViewChildren, ViewChild,\n  HostBinding\n} from \"@angular/core\";\nimport {animate, state, style, transition, trigger} from \"@angular/animations\";\n\nimport {DragulaService} from \"ng2-dragula\";\nimport domtoimage from \"dom-to-image\";\nimport {NgbModal} from \"@ng-bootstrap/ng-bootstrap\";\n\nimport {Dashboard, WidgetInstance} from \"./model/model\";\nimport {DashboardService} from \"./services/dashboard.service\";\nimport {WidgetConfigureComponent} from \"./configure/widget-configure.component\";\nimport {WidgetContainerComponent} from \"./widget/widget-container.component\";\nimport {DashboardGlobalService} from \"./services/dashboard-global.service\";\n\n/**\n * Dashboard (within a card-group) iterates over configured widgets to produce each one in a card.  The widgets can\n * always get access to any configuration held by the dashboard service, but they are intended to be largely\n * independent.\n *\n * @since 1.0.0\n */\n@Component({\n  selector: \"dashboard\",\n  template: `\n    <ng-template #confirmDialog let-c=\"close\" let-d=\"dismiss\">\n      <div class=\"modal-header\">\n        <h5 class=\"modal-title\">Delete</h5>\n      </div>\n      <div class=\"modal-body\">\n        <p>Are you sure?</p>\n      </div>\n      <div class=\"modal-footer\">\n        <button type=\"button\" class=\"btn btn-primary\" (click)=\"c('Yes')\">Yes</button>\n        <button type=\"button\" class=\"btn btn-secondary\" (click)=\"d('No')\">No</button>\n      </div>\n    </ng-template>\n\n    <widget-add [dashboardIndex]=\"selectedIndex\"></widget-add>\n\n    <div class=\"edit-mode-header\"\n         [@openEditModeHeader]=\"editMode\"\n         [@openEditModeHeaderDisplay]=\"editMode\">\n      <button class=\"btn btn-primary btn-space\"\n              (click)=\"addWidget()\">\n        <i class=\"fas fa-plus fa-2x\"></i>\n        <br />\n        <span>Widget</span>\n      </button>\n      <button *ngIf=\"configMode === 'true'\"\n              class=\"btn btn-primary btn-space red\"\n              (click)=\"deleteWidget()\">\n        <i class=\"fas fa-times fa-2x\"></i>\n        <br />\n        <span>Widget</span>\n      </button>\n      <button class=\"btn btn-primary btn-space\"\n              (click)=\"addDashboard()\">\n        <i class=\"fas fa-plus fa-2x\"></i>\n        <br />\n        <span>Dashboard</span>\n      </button>\n      <button class=\"btn btn-primary btn-space red\"\n              *ngIf=\"dashboards.length > 1\"\n              (click)=\"deleteDashboard(confirmDialog)\">\n        <i class=\"fas fa-times fa-2x\"></i>\n        <br />\n        <span>Dashboard</span>\n      </button>\n      <button class=\"btn btn-primary btn-space green\"\n              (click)=\"setEditMode(false)\">\n        <i class=\"fas fa-check fa-2x\"></i>\n        <br />\n        <span>Done</span>\n      </button>\n    </div>\n\n    <div class=\"outlet-row\">\n\n      <!-- Iterate over all dashboards.  Show non selected dashboards off screen. -->\n      <ng-template ngFor let-dashboard [ngForOf]=\"dashboards\" let-dashboardIndex=\"index\">\n        <div class=\"d-flex\"\n             [style.left]=\"selectedIndex !== dashboardIndex ? '100vw' : 'inherit'\"\n             [style.position]=\"selectedIndex !== dashboardIndex ? 'fixed' : 'inherit'\"\n             [@openConfigContent]=\"configMode\">\n          <widget-container\n              [dashboard]=\"dashboard\"\n              [dashboardIndex]=\"dashboardIndex\">\n          </widget-container>\n        </div>\n      </ng-template>\n\n      <div [style.display]=\"configMode === 'true' ? 'flex' : 'none'\" class=\"sidebar-widget-config\" [@openConfigSidebar]=\"configMode\">\n        <div class=\"outlet-column\" style=\"background-color: white; height: 100%; padding: 2px;\">\n          <div class=\"d-flex flex-nowrap\">\n            <div><h4>Settings</h4></div>\n            <div style=\"margin-right: 0px; margin-left: auto;\">\n              <span style=\"color: var(--pure-green);\" (click)=\"saveConfiguration()\">\n                <i class=\"fas fa-check-circle fa-2x\"></i>\n              </span>\n              <span style=\"color: var(--pure-red);\" (click)=\"cancelConfiguration()\">\n                <i class=\"fas fa-times-circle fa-2x\"></i>\n              </span>\n            </div>\n          </div>\n          <widget-configure #widgetConfigure></widget-configure>\n        </div>\n      </div>\n    </div>\n\n    <ng-container *ngIf=\"dashboards?.length > 1\">\n      <div class=\"dashboard-nav-trigger\">\n        <span (mouseenter)=\"openDashboardNavState = 'opened'\">\n          <i class=\"fas fa-th fa-2x\"></i>\n        </span>\n      </div>\n\n      <div class=\"dashboard-nav\"\n           [@openDashboardNav]=\"openDashboardNavState\"\n           [style.left]=\"'calc(50vw - ' + dashboards?.length * 50 + 'px)'\"\n           (mouseleave)=\"openDashboardNavState = 'closed'\">\n        <ng-container *ngFor=\"let dashboard of dashboards; index as i\">\n          <div [id]=\"'dash-image-' + i\"\n               class=\"widget-image\"\n               [ngClass]=\"i === selectedIndex ? 'selected' : ''\"\n               (click)=\"selectDashboard(i)\">\n          </div>\n        </ng-container>\n      </div>\n    </ng-container>\n\n    <ng-container *ngIf=\"helpMode\">\n      <div id=\"helpParent\">\n        <div id=\"helpChild\">\n          <div style=\"width: 100%; display: inline-flex;\">\n            <h4>Help</h4>\n            <span style=\"margin-right: 0; margin-left: auto; color: var(--pure-red);\" (click)=\"setHelpMode(false)\">\n              <i class=\"fas fa-times fa-lg\"></i>\n            </span>\n          </div>\n          <div>\n            The dashboard is a collection of widgets that you can customize to your own needs.  In this edit mode, you\n            can drag and drop widgets to change the order and double click a widget to change its configuration.\n          </div>\n        </div>\n      </div>\n    </ng-container>\n  `,\n  animations: [\n    trigger(\"openConfigContent\",\n      [\n        state(\"false\", style({\n          width: \"100%\"\n        })),\n        state(\"true\", style({\n          width: \"80%\"\n        })),\n        transition(\"false => true\", animate(300)),\n        transition(\"true => false\", animate(300))\n      ]\n    ),\n    trigger(\"openConfigSidebar\",\n      [\n        state(\"false\", style({\n          opacity: \"0\",\n          width: \"0%\"\n        })),\n        state(\"true\", style({\n          opacity: \"1\",\n          width: \"20%\"\n        })),\n        transition(\"false => true\", animate(300)),\n        transition(\"true => false\", animate(300))\n      ]\n    ),\n    trigger(\"openDashboardNav\",\n      [\n        state(\"closed\", style({\n          opacity: \"0\",\n          bottom: \"-150px\"\n        })),\n        state(\"opened\", style({\n          opacity: \"1\",\n          bottom: \"40px\"\n        })),\n        transition(\"closed => opened\", animate(250)),\n        transition(\"opened => closed\", animate(100))\n      ]\n    ),\n    /*trigger(\"openEditModeHeaderContent\", [\n      state(\"closed\", style({\n        \"padding-top\": \"0px\"\n      })),\n      state(\"opened\", style({\n        \"padding-top\": \"91px\"\n      })),\n      transition(\"closed => opened\", animate(300)),\n      transition(\"opened => closed\", animate(300))\n    ]),*/\n    trigger(\"openEditModeHeader\", [\n      state(\"closed\", style({\n        \"opacity\": \"0\",\n        \"overflow-y\": \"hidden\"\n      })),\n      state(\"opened\", style({\n        \"opacity\": \"1\",\n        \"overflow-y\": \"visible\"\n      })),\n      transition(\"closed => opened\", animate(300)),\n      transition(\"opened => closed\", animate(300))\n    ]),\n    trigger(\"openEditModeHeaderDisplay\", [\n      state(\"closed\", style({\n        \"display\": \"none\"\n      })),\n      state(\"opened\", style({\n        \"display\": \"flex\"\n      })),\n      transition(\"closed => opened\", animate(100)),\n      transition(\"opened => closed\", animate(\"100ms 100ms\"))\n    ])\n  ],\n  styles: [`\n\n    #helpParent {\n      position: fixed;\n      display: flex;\n      width: 100vw;\n      height: 100vh;\n      left: 0;\n      top: 0;\n      z-index: 999;\n      background: rgba(0, 0, 0, 0.25);\n    }\n\n    #helpChild {\n      width: 75%;\n      height: 75%;\n      margin-left: auto;\n      margin-right: auto;\n      margin-top: auto;\n      margin-bottom: auto;\n      background: white;\n      border-radius: 25px;\n      box-shadow: 2px 2px black;\n      padding: 20px;\n    }\n\n    .sidebar-widget-config {\n      background-color: #ffdddd;\n      border-left: gray 1px solid;\n      padding: 10px;\n      padding-right: 0px;\n      opacity: 0;\n      width: 0%;\n    }\n\n    .modal {\n      background-color: rgba(0, 0, 0, 0.25);\n    }\n\n    .edit-mode-header {\n      border-bottom: black 1px dashed;\n      padding-top: 10px;\n      padding-bottom: 10px;\n      z-index: 10;\n      background-color: white;\n    }\n\n    .edit-mode-header button {\n      padding: .2rem .5rem;\n    }\n\n    .btn-space {\n      margin-left: 10px;\n    }\n\n    .btn.green {\n      background-color: green;\n    }\n\n    .btn.red {\n      background-color: red;\n    }\n\n    .dashboard-nav-trigger {\n      bottom: 40px;\n      position: fixed;\n      z-index: 100;\n      display: inline-block;\n      width: 100%;\n      text-align: center;\n      padding-top: 15px;\n      background: white;\n      background: linear-gradient(0deg, white, white, transparent);\n    }\n\n    .dashboard-nav {\n      bottom: -150px;\n      position: fixed;\n      z-index: 101;\n      display: inline-block;\n      background-color: white;\n    }\n\n    .widget-image {\n      display: inline-block;\n      max-height: 100px;\n      height: 100px;\n      min-height: 100px;\n      max-width: 100px;\n      width: 100px;\n      min-width: 100px;\n      border: black 1px solid;\n      vertical-align: bottom;\n      overflow-y: hidden;\n      overflow-x: hidden;\n    }\n\n    .widget-image.selected {\n      border: red 2px solid;\n    }\n  `],\n  providers: [\n    DashboardService\n  ]\n})\nexport class DashboardComponent {\n\n  @HostBinding(\"class\") classList: string = \"outlet-column\";\n\n  public openDashboardNavState: string = \"closed\";\n\n  public helpMode: boolean = false;\n  public editMode: string = \"closed\";\n  public selectedIndex = 0;\n\n  public dashboards: Dashboard[] = [];\n\n  public showWidgetContainerNav: boolean = false;\n\n  configMode: string = \"false\";\n\n  @ViewChildren(WidgetContainerComponent, { read: ElementRef }) widgetContainers: QueryList<ElementRef>;\n\n  @ViewChild(\"widgetConfigure\", {static: false}) widgetConfigure: WidgetConfigureComponent;\n\n  constructor(private changeDetectorRef: ChangeDetectorRef,\n              private elementRef: ElementRef,\n              private dashboardService: DashboardService,\n              private dashboardGlobalService: DashboardGlobalService,\n              private dragulaService: DragulaService,\n              private modalService: NgbModal) {\n    this.dashboards = this.dashboardService.getDashboards();\n\n    this.dashboardService.dashboardsState.subscribe((dashboards: Dashboard[]) => {\n      this.dashboards = dashboards;\n    });\n\n    this.dashboardService.configurationWidgetInstanceSubject.subscribe((widgetInstance: WidgetInstance) => {\n      if (widgetInstance) {\n        this.configMode = \"true\";\n      } else {\n        this.configMode = \"false\";\n      }\n    });\n\n    this.dashboardService.getEditMode().subscribe((editMode: boolean) => {\n      if (isDevMode()) {\n        console.info(\"getEditMode \" + editMode);\n      }\n\n      if (editMode) {\n        this.editMode = \"opened\";\n      } else {\n        this.editMode = \"closed\";\n      }\n    });\n\n    /*let bag = this.dragulaService.find(\"attribute-choices\");\n    if (bag !== undefined) {\n      this.dragulaService.destroy(\"attribute-choices\");\n    }\n    this.dragulaService.createGroup(\"attribute-choices\", {\n      direction: \"vertical\",\n      moves: function (el: any, container: any, handle: any) {\n        return true;\n      }\n    });\n    this.dragulaService.find(\"attribute-choices\")\n      .drake\n      .containers\n      .push(this.elementRef.nativeElement.querySelector(\"#attribute-choices\"));\n    this.dragulaService.drop(\"\").subscribe((value: any) => {\n      let n: number = 1;\n\n      for (let el of this.elementRef.nativeElement.querySelectorAll(\"widget-host\")) {\n        this.dashboardService.saveWidgetSortOrder(this.selectedIndex, +el.getAttribute(\"id\"), n++);\n      }\n    });*/\n  }\n\n  ngOnInit(): void {\n    this.dashboardGlobalService.setActiveDashboardService(this.dashboardService);\n  }\n\n  ngAfterViewInit() {\n    this.widgetContainers.changes.subscribe((widgetContainers: QueryList <ElementRef>) => {\n      this.renderDashboardNavImages();\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.dashboardGlobalService.setActiveDashboardService();\n  }\n\n  selectDashboard(index: number) {\n    this.selectedIndex = index;\n  }\n\n  /**\n   * Informs dashboardService of editMode change.  Widget hosts will listen for this change.\n   *\n   * @param editMode\n   */\n  setEditMode(editMode: boolean) {\n    this.dashboardService.setEditMode(editMode);\n  }\n\n  setHelpMode(helpMode: boolean) {\n    if (isDevMode()) {\n      console.info(\"setHelpMode \" + helpMode);\n    }\n\n    this.helpMode = helpMode;\n    this.changeDetectorRef.markForCheck();\n  }\n\n  /**\n   * Use dom-to-image to render each widgetContainer as an image.  Add an image for each widgetContainer\n   * to the dashboardNav view.\n   */\n  renderDashboardNavImages() {\n    setTimeout(() => {\n      var self = this;\n      this.widgetContainers.forEach((elementRef: ElementRef, index: number) => {\n        var el = self.elementRef.nativeElement.querySelector(\"#dash-image-\" + index);\n        if (el) {\n          domtoimage.toPng(elementRef.nativeElement)\n            .then(function (dataUrl) {\n              var img = new Image();\n              img.width = 100;\n              img.src = dataUrl;\n              el.innerHTML = \"\";\n              el.appendChild(img);\n              self.showWidgetContainerNav = true;\n            })\n            .catch(function (error) {\n              console.error(\"Widget Image Error\", error);\n            });\n        }\n      });\n    }, 2000);\n  }\n\n  /**\n   * Sends trigger to dashboardService to open the widget add component.  That component listens for\n   * this trigger.\n   */\n  addWidget() {\n    this.dashboardService.addWidgetSubject.next(true);\n  }\n\n  deleteWidget() {\n    this.dashboardService.deleteWidget(this.dashboardService.configurationWidgetInstanceSubject.getValue());\n  }\n\n  cancelConfiguration() {\n    this.dashboardService.cancelConfigurationWidget();\n  }\n\n  saveConfiguration() {\n    this.dashboardService.saveConfigurationWidget();\n  }\n\n  /**\n   * Calls dashboardService to add a dashboard.  Add dashboard will update dashboards through subscribe and\n   * this waits for completion of the process which returns the new selectedIndex (which is the last dashboard).\n   */\n  addDashboard() {\n    let dashboard: Dashboard = new Dashboard();\n    dashboard.name = \"Temp\";\n    dashboard.sortOrder = this.dashboards.length;\n    dashboard.widgetInstances = [];\n    this.dashboardService.addDashboard(dashboard).subscribe((index: number) => {\n      this.selectedIndex = index;\n    });\n  }\n\n  /**\n   * Calls dashboardService to delete dashboard.  Delete dashboard will update dashboards through subscribe and\n   * this waits for completion of the process which returns the new selectedIndex.\n   *\n   * @param content\n   */\n  deleteDashboard(content) {\n    this.modalService.open(content).result.then((result: string) => {\n      if (result === \"Yes\") {\n        this.dashboardService.deleteDashboard(this.selectedIndex).subscribe((index: number) => {\n          this.selectedIndex = index;\n        });\n      }\n    });\n  }\n\n}\n"]}
590
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dashboard.component.js","sourceRoot":"","sources":["../../../projects/dashboard/src/dashboard.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\r\n * Copyright (c) 2016 Huntsman Cancer Institute at the University of Utah, Confidential and Proprietary\r\n */\r\nimport {\r\n  ChangeDetectorRef, Component, ElementRef, isDevMode, QueryList, ViewChildren, ViewChild,\r\n  HostBinding\r\n} from \"@angular/core\";\r\nimport {animate, state, style, transition, trigger} from \"@angular/animations\";\r\n\r\nimport {DragulaService} from \"ng2-dragula\";\r\nimport domtoimage from \"dom-to-image\";\r\nimport {NgbModal} from \"@ng-bootstrap/ng-bootstrap\";\r\n\r\nimport {Dashboard, WidgetInstance} from \"./model/model\";\r\nimport {DashboardService} from \"./services/dashboard.service\";\r\nimport {WidgetConfigureComponent} from \"./configure/widget-configure.component\";\r\nimport {WidgetContainerComponent} from \"./widget/widget-container.component\";\r\nimport {DashboardGlobalService} from \"./services/dashboard-global.service\";\r\n\r\n/**\r\n * Dashboard (within a card-group) iterates over configured widgets to produce each one in a card.  The widgets can\r\n * always get access to any configuration held by the dashboard service, but they are intended to be largely\r\n * independent.\r\n *\r\n * @since 1.0.0\r\n */\r\n@Component({\r\n  selector: \"dashboard\",\r\n  template: `\r\n    <ng-template #confirmDialog let-c=\"close\" let-d=\"dismiss\">\r\n      <div class=\"modal-header\">\r\n        <h5 class=\"modal-title\">Delete</h5>\r\n      </div>\r\n      <div class=\"modal-body\">\r\n        <p>Are you sure?</p>\r\n      </div>\r\n      <div class=\"modal-footer\">\r\n        <button type=\"button\" class=\"btn btn-primary\" (click)=\"c('Yes')\">Yes</button>\r\n        <button type=\"button\" class=\"btn btn-secondary\" (click)=\"d('No')\">No</button>\r\n      </div>\r\n    </ng-template>\r\n\r\n    <widget-add [dashboardIndex]=\"selectedIndex\"></widget-add>\r\n\r\n    <div class=\"edit-mode-header\"\r\n         [@openEditModeHeader]=\"editMode\"\r\n         [@openEditModeHeaderDisplay]=\"editMode\">\r\n      <button class=\"btn btn-primary btn-space\"\r\n              (click)=\"addWidget()\">\r\n        <i class=\"fas fa-plus fa-2x\"></i>\r\n        <br />\r\n        <span>Widget</span>\r\n      </button>\r\n      <button *ngIf=\"configMode === 'true'\"\r\n              class=\"btn btn-primary btn-space red\"\r\n              (click)=\"deleteWidget()\">\r\n        <i class=\"fas fa-times fa-2x\"></i>\r\n        <br />\r\n        <span>Widget</span>\r\n      </button>\r\n      <button class=\"btn btn-primary btn-space\"\r\n              (click)=\"addDashboard()\">\r\n        <i class=\"fas fa-plus fa-2x\"></i>\r\n        <br />\r\n        <span>Dashboard</span>\r\n      </button>\r\n      <button class=\"btn btn-primary btn-space red\"\r\n              *ngIf=\"dashboards.length > 1\"\r\n              (click)=\"deleteDashboard(confirmDialog)\">\r\n        <i class=\"fas fa-times fa-2x\"></i>\r\n        <br />\r\n        <span>Dashboard</span>\r\n      </button>\r\n      <button class=\"btn btn-primary btn-space green\"\r\n              (click)=\"setEditMode(false)\">\r\n        <i class=\"fas fa-check fa-2x\"></i>\r\n        <br />\r\n        <span>Done</span>\r\n      </button>\r\n    </div>\r\n\r\n    <div class=\"outlet-row\">\r\n\r\n      <!-- Iterate over all dashboards.  Show non selected dashboards off screen. -->\r\n      <ng-template ngFor let-dashboard [ngForOf]=\"dashboards\" let-dashboardIndex=\"index\">\r\n        <div class=\"d-flex\"\r\n             [style.left]=\"selectedIndex !== dashboardIndex ? '100vw' : 'inherit'\"\r\n             [style.position]=\"selectedIndex !== dashboardIndex ? 'fixed' : 'inherit'\"\r\n             [@openConfigContent]=\"configMode\">\r\n          <widget-container\r\n              [dashboard]=\"dashboard\"\r\n              [dashboardIndex]=\"dashboardIndex\">\r\n          </widget-container>\r\n        </div>\r\n      </ng-template>\r\n\r\n      <div [style.display]=\"configMode === 'true' ? 'flex' : 'none'\" class=\"sidebar-widget-config\" [@openConfigSidebar]=\"configMode\">\r\n        <div class=\"outlet-column\" style=\"background-color: white; height: 100%; padding: 2px;\">\r\n          <div class=\"d-flex flex-nowrap\">\r\n            <div><h4>Settings</h4></div>\r\n            <div style=\"margin-right: 0px; margin-left: auto;\">\r\n              <span style=\"color: var(--pure-green);\" (click)=\"saveConfiguration()\">\r\n                <i class=\"fas fa-check-circle fa-2x\"></i>\r\n              </span>\r\n              <span style=\"color: var(--pure-red);\" (click)=\"cancelConfiguration()\">\r\n                <i class=\"fas fa-times-circle fa-2x\"></i>\r\n              </span>\r\n            </div>\r\n          </div>\r\n          <widget-configure #widgetConfigure></widget-configure>\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n    <ng-container *ngIf=\"dashboards?.length > 1\">\r\n      <div class=\"dashboard-nav-trigger\">\r\n        <span (mouseenter)=\"openDashboardNavState = 'opened'\">\r\n          <i class=\"fas fa-th fa-2x\"></i>\r\n        </span>\r\n      </div>\r\n\r\n      <div class=\"dashboard-nav\"\r\n           [@openDashboardNav]=\"openDashboardNavState\"\r\n           [style.left]=\"'calc(50vw - ' + dashboards?.length * 50 + 'px)'\"\r\n           (mouseleave)=\"openDashboardNavState = 'closed'\">\r\n        <ng-container *ngFor=\"let dashboard of dashboards; index as i\">\r\n          <div [id]=\"'dash-image-' + i\"\r\n               class=\"widget-image\"\r\n               [ngClass]=\"i === selectedIndex ? 'selected' : ''\"\r\n               (click)=\"selectDashboard(i)\">\r\n          </div>\r\n        </ng-container>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <ng-container *ngIf=\"helpMode\">\r\n      <div id=\"helpParent\">\r\n        <div id=\"helpChild\">\r\n          <div style=\"width: 100%; display: inline-flex;\">\r\n            <h4>Help</h4>\r\n            <span style=\"margin-right: 0; margin-left: auto; color: var(--pure-red);\" (click)=\"setHelpMode(false)\">\r\n              <i class=\"fas fa-times fa-lg\"></i>\r\n            </span>\r\n          </div>\r\n          <div>\r\n            The dashboard is a collection of widgets that you can customize to your own needs.  In this edit mode, you\r\n            can drag and drop widgets to change the order and double click a widget to change its configuration.\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n  `,\r\n  animations: [\r\n    trigger(\"openConfigContent\",\r\n      [\r\n        state(\"false\", style({\r\n          width: \"100%\"\r\n        })),\r\n        state(\"true\", style({\r\n          width: \"80%\"\r\n        })),\r\n        transition(\"false => true\", animate(300)),\r\n        transition(\"true => false\", animate(300))\r\n      ]\r\n    ),\r\n    trigger(\"openConfigSidebar\",\r\n      [\r\n        state(\"false\", style({\r\n          opacity: \"0\",\r\n          width: \"0%\"\r\n        })),\r\n        state(\"true\", style({\r\n          opacity: \"1\",\r\n          width: \"20%\"\r\n        })),\r\n        transition(\"false => true\", animate(300)),\r\n        transition(\"true => false\", animate(300))\r\n      ]\r\n    ),\r\n    trigger(\"openDashboardNav\",\r\n      [\r\n        state(\"closed\", style({\r\n          opacity: \"0\",\r\n          bottom: \"-150px\"\r\n        })),\r\n        state(\"opened\", style({\r\n          opacity: \"1\",\r\n          bottom: \"40px\"\r\n        })),\r\n        transition(\"closed => opened\", animate(250)),\r\n        transition(\"opened => closed\", animate(100))\r\n      ]\r\n    ),\r\n    /*trigger(\"openEditModeHeaderContent\", [\r\n      state(\"closed\", style({\r\n        \"padding-top\": \"0px\"\r\n      })),\r\n      state(\"opened\", style({\r\n        \"padding-top\": \"91px\"\r\n      })),\r\n      transition(\"closed => opened\", animate(300)),\r\n      transition(\"opened => closed\", animate(300))\r\n    ]),*/\r\n    trigger(\"openEditModeHeader\", [\r\n      state(\"closed\", style({\r\n        \"opacity\": \"0\",\r\n        \"overflow-y\": \"hidden\"\r\n      })),\r\n      state(\"opened\", style({\r\n        \"opacity\": \"1\",\r\n        \"overflow-y\": \"visible\"\r\n      })),\r\n      transition(\"closed => opened\", animate(300)),\r\n      transition(\"opened => closed\", animate(300))\r\n    ]),\r\n    trigger(\"openEditModeHeaderDisplay\", [\r\n      state(\"closed\", style({\r\n        \"display\": \"none\"\r\n      })),\r\n      state(\"opened\", style({\r\n        \"display\": \"flex\"\r\n      })),\r\n      transition(\"closed => opened\", animate(100)),\r\n      transition(\"opened => closed\", animate(\"100ms 100ms\"))\r\n    ])\r\n  ],\r\n  styles: [`\r\n\r\n    #helpParent {\r\n      position: fixed;\r\n      display: flex;\r\n      width: 100vw;\r\n      height: 100vh;\r\n      left: 0;\r\n      top: 0;\r\n      z-index: 999;\r\n      background: rgba(0, 0, 0, 0.25);\r\n    }\r\n\r\n    #helpChild {\r\n      width: 75%;\r\n      height: 75%;\r\n      margin-left: auto;\r\n      margin-right: auto;\r\n      margin-top: auto;\r\n      margin-bottom: auto;\r\n      background: white;\r\n      border-radius: 25px;\r\n      box-shadow: 2px 2px black;\r\n      padding: 20px;\r\n    }\r\n\r\n    .sidebar-widget-config {\r\n      background-color: #ffdddd;\r\n      border-left: gray 1px solid;\r\n      padding: 10px;\r\n      padding-right: 0px;\r\n      opacity: 0;\r\n      width: 0%;\r\n    }\r\n\r\n    .modal {\r\n      background-color: rgba(0, 0, 0, 0.25);\r\n    }\r\n\r\n    .edit-mode-header {\r\n      border-bottom: black 1px dashed;\r\n      padding-top: 10px;\r\n      padding-bottom: 10px;\r\n      z-index: 10;\r\n      background-color: white;\r\n    }\r\n\r\n    .edit-mode-header button {\r\n      padding: .2rem .5rem;\r\n    }\r\n\r\n    .btn-space {\r\n      margin-left: 10px;\r\n    }\r\n\r\n    .btn.green {\r\n      background-color: green;\r\n    }\r\n\r\n    .btn.red {\r\n      background-color: red;\r\n    }\r\n\r\n    .dashboard-nav-trigger {\r\n      bottom: 40px;\r\n      position: fixed;\r\n      z-index: 100;\r\n      display: inline-block;\r\n      width: 100%;\r\n      text-align: center;\r\n      padding-top: 15px;\r\n      background: white;\r\n      background: linear-gradient(0deg, white, white, transparent);\r\n    }\r\n\r\n    .dashboard-nav {\r\n      bottom: -150px;\r\n      position: fixed;\r\n      z-index: 101;\r\n      display: inline-block;\r\n      background-color: white;\r\n    }\r\n\r\n    .widget-image {\r\n      display: inline-block;\r\n      max-height: 100px;\r\n      height: 100px;\r\n      min-height: 100px;\r\n      max-width: 100px;\r\n      width: 100px;\r\n      min-width: 100px;\r\n      border: black 1px solid;\r\n      vertical-align: bottom;\r\n      overflow-y: hidden;\r\n      overflow-x: hidden;\r\n    }\r\n\r\n    .widget-image.selected {\r\n      border: red 2px solid;\r\n    }\r\n  `],\r\n  providers: [\r\n    DashboardService\r\n  ]\r\n})\r\nexport class DashboardComponent {\r\n\r\n  @HostBinding(\"class\") classList: string = \"outlet-column\";\r\n\r\n  public openDashboardNavState: string = \"closed\";\r\n\r\n  public helpMode: boolean = false;\r\n  public editMode: string = \"closed\";\r\n  public selectedIndex = 0;\r\n\r\n  public dashboards: Dashboard[] = [];\r\n\r\n  public showWidgetContainerNav: boolean = false;\r\n\r\n  configMode: string = \"false\";\r\n\r\n  @ViewChildren(WidgetContainerComponent, { read: ElementRef }) widgetContainers: QueryList<ElementRef>;\r\n\r\n  @ViewChild(\"widgetConfigure\", {static: false}) widgetConfigure: WidgetConfigureComponent;\r\n\r\n  constructor(private changeDetectorRef: ChangeDetectorRef,\r\n              private elementRef: ElementRef,\r\n              private dashboardService: DashboardService,\r\n              private dashboardGlobalService: DashboardGlobalService,\r\n              private dragulaService: DragulaService,\r\n              private modalService: NgbModal) {\r\n    this.dashboards = this.dashboardService.getDashboards();\r\n\r\n    this.dashboardService.dashboardsState.subscribe((dashboards: Dashboard[]) => {\r\n      this.dashboards = dashboards;\r\n    });\r\n\r\n    this.dashboardService.configurationWidgetInstanceSubject.subscribe((widgetInstance: WidgetInstance) => {\r\n      if (widgetInstance) {\r\n        this.configMode = \"true\";\r\n      } else {\r\n        this.configMode = \"false\";\r\n      }\r\n    });\r\n\r\n    this.dashboardService.getEditMode().subscribe((editMode: boolean) => {\r\n      if (isDevMode()) {\r\n        console.info(\"getEditMode \" + editMode);\r\n      }\r\n\r\n      if (editMode) {\r\n        this.editMode = \"opened\";\r\n      } else {\r\n        this.editMode = \"closed\";\r\n      }\r\n    });\r\n\r\n    /*let bag = this.dragulaService.find(\"attribute-choices\");\r\n    if (bag !== undefined) {\r\n      this.dragulaService.destroy(\"attribute-choices\");\r\n    }\r\n    this.dragulaService.createGroup(\"attribute-choices\", {\r\n      direction: \"vertical\",\r\n      moves: function (el: any, container: any, handle: any) {\r\n        return true;\r\n      }\r\n    });\r\n    this.dragulaService.find(\"attribute-choices\")\r\n      .drake\r\n      .containers\r\n      .push(this.elementRef.nativeElement.querySelector(\"#attribute-choices\"));\r\n    this.dragulaService.drop(\"\").subscribe((value: any) => {\r\n      let n: number = 1;\r\n\r\n      for (let el of this.elementRef.nativeElement.querySelectorAll(\"widget-host\")) {\r\n        this.dashboardService.saveWidgetSortOrder(this.selectedIndex, +el.getAttribute(\"id\"), n++);\r\n      }\r\n    });*/\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.dashboardGlobalService.setActiveDashboardService(this.dashboardService);\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.widgetContainers.changes.subscribe((widgetContainers: QueryList <ElementRef>) => {\r\n      this.renderDashboardNavImages();\r\n    });\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.dashboardGlobalService.setActiveDashboardService();\r\n  }\r\n\r\n  selectDashboard(index: number) {\r\n    this.selectedIndex = index;\r\n  }\r\n\r\n  /**\r\n   * Informs dashboardService of editMode change.  Widget hosts will listen for this change.\r\n   *\r\n   * @param editMode\r\n   */\r\n  setEditMode(editMode: boolean) {\r\n    this.dashboardService.setEditMode(editMode);\r\n  }\r\n\r\n  setHelpMode(helpMode: boolean) {\r\n    if (isDevMode()) {\r\n      console.info(\"setHelpMode \" + helpMode);\r\n    }\r\n\r\n    this.helpMode = helpMode;\r\n    this.changeDetectorRef.markForCheck();\r\n  }\r\n\r\n  /**\r\n   * Use dom-to-image to render each widgetContainer as an image.  Add an image for each widgetContainer\r\n   * to the dashboardNav view.\r\n   */\r\n  renderDashboardNavImages() {\r\n    setTimeout(() => {\r\n      var self = this;\r\n      this.widgetContainers.forEach((elementRef: ElementRef, index: number) => {\r\n        var el = self.elementRef.nativeElement.querySelector(\"#dash-image-\" + index);\r\n        if (el) {\r\n          domtoimage.toPng(elementRef.nativeElement)\r\n            .then(function (dataUrl) {\r\n              var img = new Image();\r\n              img.width = 100;\r\n              img.src = dataUrl;\r\n              el.innerHTML = \"\";\r\n              el.appendChild(img);\r\n              self.showWidgetContainerNav = true;\r\n            })\r\n            .catch(function (error) {\r\n              console.error(\"Widget Image Error\", error);\r\n            });\r\n        }\r\n      });\r\n    }, 2000);\r\n  }\r\n\r\n  /**\r\n   * Sends trigger to dashboardService to open the widget add component.  That component listens for\r\n   * this trigger.\r\n   */\r\n  addWidget() {\r\n    this.dashboardService.addWidgetSubject.next(true);\r\n  }\r\n\r\n  deleteWidget() {\r\n    this.dashboardService.deleteWidget(this.dashboardService.configurationWidgetInstanceSubject.getValue());\r\n  }\r\n\r\n  cancelConfiguration() {\r\n    this.dashboardService.cancelConfigurationWidget();\r\n  }\r\n\r\n  saveConfiguration() {\r\n    this.dashboardService.saveConfigurationWidget();\r\n  }\r\n\r\n  /**\r\n   * Calls dashboardService to add a dashboard.  Add dashboard will update dashboards through subscribe and\r\n   * this waits for completion of the process which returns the new selectedIndex (which is the last dashboard).\r\n   */\r\n  addDashboard() {\r\n    let dashboard: Dashboard = new Dashboard();\r\n    dashboard.name = \"Temp\";\r\n    dashboard.sortOrder = this.dashboards.length;\r\n    dashboard.widgetInstances = [];\r\n    this.dashboardService.addDashboard(dashboard).subscribe((index: number) => {\r\n      this.selectedIndex = index;\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Calls dashboardService to delete dashboard.  Delete dashboard will update dashboards through subscribe and\r\n   * this waits for completion of the process which returns the new selectedIndex.\r\n   *\r\n   * @param content\r\n   */\r\n  deleteDashboard(content) {\r\n    this.modalService.open(content).result.then((result: string) => {\r\n      if (result === \"Yes\") {\r\n        this.dashboardService.deleteDashboard(this.selectedIndex).subscribe((index: number) => {\r\n          this.selectedIndex = index;\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n}\r\n"]}