sgh-navbar 0.0.40-patch.1.1 → 0.0.40-patch.1.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.
@@ -4,44 +4,64 @@ import * as i0 from "@angular/core";
4
4
  import * as i1 from "@angular/material/dialog";
5
5
  import * as i2 from "../../sgh-navbar.service";
6
6
  import * as i3 from "@angular/common";
7
- import * as i4 from "@angular/material/radio";
7
+ import * as i4 from "@angular/forms";
8
+ import * as i5 from "@angular/material/radio";
8
9
  export class SubClientDialogComponent {
9
10
  constructor(data, dialogRef, sghNavbarService) {
10
11
  this.data = data;
11
12
  this.dialogRef = dialogRef;
12
13
  this.sghNavbarService = sghNavbarService;
13
14
  this.subClient = new EventEmitter();
15
+ this.tempSelectedSubClient = null;
16
+ this.orginalSubClient = null;
17
+ this.selectedSubClientValue = undefined;
14
18
  this.client = data.client;
15
19
  this.subClientList = data.client.subClientList;
16
- // find the selected sub client
17
- let selectedSubClientIndex = this.subClientList.findIndex((subClient) => subClient.checked == true);
18
- this.selectedSubClient = this.subClientList[selectedSubClientIndex];
20
+ // find the selected sub client (the one with checked = true)
21
+ let selectedSubClientIndex = this.subClientList.findIndex((subClient) => subClient.checked === true);
22
+ // Only set if a checked subclient is found, otherwise keep as null
23
+ if (selectedSubClientIndex !== -1) {
24
+ this.tempSelectedSubClient = this.subClientList[selectedSubClientIndex];
25
+ this.orginalSubClient = this.subClientList[selectedSubClientIndex];
26
+ this.selectedSubClientValue = this.tempSelectedSubClient.value;
27
+ }
28
+ else {
29
+ // Explicitly ensure all values are null/undefined when no checked subclient exists
30
+ this.tempSelectedSubClient = null;
31
+ this.orginalSubClient = null;
32
+ this.selectedSubClientValue = undefined;
33
+ }
34
+ this.orginalClient = data.client;
19
35
  }
20
- onSubClientSelect(item) {
36
+ onSubClientChange(item) {
37
+ this.tempSelectedSubClient = item;
38
+ }
39
+ onSelectBtnClick() {
40
+ this.orginalSubClient = this.tempSelectedSubClient;
41
+ this.dialogRef.close({ data: { selectedSubClient: this.tempSelectedSubClient, cancelled: false } });
21
42
  // update the sub client list with newly selected values
22
43
  this.subClientList.forEach((subClient) => {
23
- if (subClient == item) {
44
+ if (subClient == this.tempSelectedSubClient) {
24
45
  subClient.checked = true;
25
46
  }
26
47
  else {
27
48
  subClient.checked = false;
28
49
  }
29
50
  });
30
- this.selectedSubClient = item;
31
51
  }
32
- onSelectBtnClick() {
33
- this.dialogRef.close({ data: { selectedSubClient: this.selectedSubClient } });
52
+ onCloseBtnClick() {
53
+ this.dialogRef.close({ data: { selectedSubClient: this.orginalSubClient, cancelled: true } });
34
54
  }
35
55
  }
36
56
  SubClientDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SubClientDialogComponent, deps: [{ token: MAT_DIALOG_DATA }, { token: i1.MatDialogRef }, { token: i2.SghNavbarService }], target: i0.ɵɵFactoryTarget.Component });
37
- SubClientDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: SubClientDialogComponent, selector: "lib-subclient-dialog", outputs: { subClient: "subClient" }, ngImport: i0, template: "<div class=\"subclientlist-wrapper dialog-wrapper\">\r\n <div class=\"modal-header-wrapper\">\r\n <h4 class=\"subclientlist-header\">Select Sub Client</h4>\r\n <button type=\"button\" mat-dialog-close class=\"close-round-btn\">\r\n <i class=\"fa fa-times-circle\"></i>\r\n </button>\r\n </div>\r\n <div class=\"subclientlist-body\">\r\n <div>\r\n <mat-radio-group class=\"subclientlist-radiogrp\" aria-label=\"Select an option\">\r\n <mat-radio-button [value]=\"item.value\" *ngFor=\"let item of subClientList;index as i\" (click)=\"onSubClientSelect(item)\" [checked]=\"item.checked\">{{item.text}}</mat-radio-button>\r\n </mat-radio-group>\r\n </div>\r\n </div>\r\n <div class=\"subclientlist-btns\">\r\n <button class=\"sgh-btn-primary\" (click)=\"onSelectBtnClick()\">Select</button>\r\n </div>\r\n</div>\r\n\r\n", styles: [".subclientlist-wrapper .subclientlist-header{font-weight:500;line-height:48px;display:flex;justify-content:center;align-items:center;padding-bottom:0;margin:0}.subclientlist-wrapper .subclientlist-body{font-weight:400;text-align:center;color:#000;padding:0 15px 15px}.subclientlist-wrapper .subclientlist-body .subclientlist-radiogrp{display:flex;flex-direction:column;justify-content:flex-start;align-items:flex-start}.subclientlist-wrapper .subclientlist-btns{padding:0;min-height:48px}.subclientlist-wrapper button{width:100%;margin-bottom:0}.subclientlist-wrapper .mat-mdc-dialog-actions .mat-mdc-button-base+.mat-mdc-button-base{margin-left:0}.modal-header-wrapper{display:flex;justify-content:space-between;margin:0 10px}.modal-header-wrapper .close-round-btn{position:absolute;top:12px;right:12px;width:28px;height:28px;border-radius:50%;border:none;background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.modal-header-wrapper .close-round-btn i{font-size:25px;color:#006068}.modal-header-wrapper .close-round-btn:hover{background:#f3f3f3}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i4.MatRadioGroup, selector: "mat-radio-group", exportAs: ["matRadioGroup"] }, { kind: "component", type: i4.MatRadioButton, selector: "mat-radio-button", inputs: ["disableRipple", "tabIndex"], exportAs: ["matRadioButton"] }] });
57
+ SubClientDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: SubClientDialogComponent, selector: "lib-subclient-dialog", outputs: { subClient: "subClient" }, ngImport: i0, template: "<div class=\"subclientlist-wrapper dialog-wrapper\">\r\n <div class=\"modal-header-wrapper\">\r\n <h4 class=\"subclientlist-header\">Select Sub Client</h4>\r\n <button type=\"button\" (click)=\"onCloseBtnClick()\" class=\"close-round-btn\">\r\n <i class=\"fa fa-times-circle\"></i>\r\n </button>\r\n </div>\r\n <div class=\"subclientlist-body\">\r\n <div>\r\n <mat-radio-group class=\"subclientlist-radiogrp\" aria-label=\"Select an option\" [(ngModel)]=\"selectedSubClientValue\">\r\n <mat-radio-button [value]=\"item.value\" *ngFor=\"let item of subClientList;index as i\" (change)=\"onSubClientChange(item)\">{{item.text}}</mat-radio-button>\r\n </mat-radio-group>\r\n </div>\r\n </div>\r\n <div class=\"subclientlist-btns\">\r\n <button class=\"sgh-btn-primary\" (click)=\"onSelectBtnClick()\">Select</button>\r\n </div>\r\n</div>\r\n\r\n", styles: [".subclientlist-wrapper .subclientlist-header{font-weight:500;line-height:48px;display:flex;justify-content:center;align-items:center;padding-bottom:0;margin:0}.subclientlist-wrapper .subclientlist-body{font-weight:400;text-align:center;color:#000;padding:0 15px 15px}.subclientlist-wrapper .subclientlist-body .subclientlist-radiogrp{display:flex;flex-direction:column;justify-content:flex-start;align-items:flex-start}.subclientlist-wrapper .subclientlist-btns{padding:0;min-height:48px}.subclientlist-wrapper button{width:100%;margin-bottom:0}.subclientlist-wrapper .mat-mdc-dialog-actions .mat-mdc-button-base+.mat-mdc-button-base{margin-left:0}.modal-header-wrapper{display:flex;justify-content:space-between;margin:0 10px}.modal-header-wrapper .close-round-btn{position:absolute;top:12px;right:12px;width:28px;height:28px;border-radius:50%;border:none;background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.modal-header-wrapper .close-round-btn i{font-size:25px;color:#006068}.modal-header-wrapper .close-round-btn:hover{background:#f3f3f3}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i5.MatRadioGroup, selector: "mat-radio-group", exportAs: ["matRadioGroup"] }, { kind: "component", type: i5.MatRadioButton, selector: "mat-radio-button", inputs: ["disableRipple", "tabIndex"], exportAs: ["matRadioButton"] }] });
38
58
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SubClientDialogComponent, decorators: [{
39
59
  type: Component,
40
- args: [{ selector: 'lib-subclient-dialog', template: "<div class=\"subclientlist-wrapper dialog-wrapper\">\r\n <div class=\"modal-header-wrapper\">\r\n <h4 class=\"subclientlist-header\">Select Sub Client</h4>\r\n <button type=\"button\" mat-dialog-close class=\"close-round-btn\">\r\n <i class=\"fa fa-times-circle\"></i>\r\n </button>\r\n </div>\r\n <div class=\"subclientlist-body\">\r\n <div>\r\n <mat-radio-group class=\"subclientlist-radiogrp\" aria-label=\"Select an option\">\r\n <mat-radio-button [value]=\"item.value\" *ngFor=\"let item of subClientList;index as i\" (click)=\"onSubClientSelect(item)\" [checked]=\"item.checked\">{{item.text}}</mat-radio-button>\r\n </mat-radio-group>\r\n </div>\r\n </div>\r\n <div class=\"subclientlist-btns\">\r\n <button class=\"sgh-btn-primary\" (click)=\"onSelectBtnClick()\">Select</button>\r\n </div>\r\n</div>\r\n\r\n", styles: [".subclientlist-wrapper .subclientlist-header{font-weight:500;line-height:48px;display:flex;justify-content:center;align-items:center;padding-bottom:0;margin:0}.subclientlist-wrapper .subclientlist-body{font-weight:400;text-align:center;color:#000;padding:0 15px 15px}.subclientlist-wrapper .subclientlist-body .subclientlist-radiogrp{display:flex;flex-direction:column;justify-content:flex-start;align-items:flex-start}.subclientlist-wrapper .subclientlist-btns{padding:0;min-height:48px}.subclientlist-wrapper button{width:100%;margin-bottom:0}.subclientlist-wrapper .mat-mdc-dialog-actions .mat-mdc-button-base+.mat-mdc-button-base{margin-left:0}.modal-header-wrapper{display:flex;justify-content:space-between;margin:0 10px}.modal-header-wrapper .close-round-btn{position:absolute;top:12px;right:12px;width:28px;height:28px;border-radius:50%;border:none;background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.modal-header-wrapper .close-round-btn i{font-size:25px;color:#006068}.modal-header-wrapper .close-round-btn:hover{background:#f3f3f3}\n"] }]
60
+ args: [{ selector: 'lib-subclient-dialog', template: "<div class=\"subclientlist-wrapper dialog-wrapper\">\r\n <div class=\"modal-header-wrapper\">\r\n <h4 class=\"subclientlist-header\">Select Sub Client</h4>\r\n <button type=\"button\" (click)=\"onCloseBtnClick()\" class=\"close-round-btn\">\r\n <i class=\"fa fa-times-circle\"></i>\r\n </button>\r\n </div>\r\n <div class=\"subclientlist-body\">\r\n <div>\r\n <mat-radio-group class=\"subclientlist-radiogrp\" aria-label=\"Select an option\" [(ngModel)]=\"selectedSubClientValue\">\r\n <mat-radio-button [value]=\"item.value\" *ngFor=\"let item of subClientList;index as i\" (change)=\"onSubClientChange(item)\">{{item.text}}</mat-radio-button>\r\n </mat-radio-group>\r\n </div>\r\n </div>\r\n <div class=\"subclientlist-btns\">\r\n <button class=\"sgh-btn-primary\" (click)=\"onSelectBtnClick()\">Select</button>\r\n </div>\r\n</div>\r\n\r\n", styles: [".subclientlist-wrapper .subclientlist-header{font-weight:500;line-height:48px;display:flex;justify-content:center;align-items:center;padding-bottom:0;margin:0}.subclientlist-wrapper .subclientlist-body{font-weight:400;text-align:center;color:#000;padding:0 15px 15px}.subclientlist-wrapper .subclientlist-body .subclientlist-radiogrp{display:flex;flex-direction:column;justify-content:flex-start;align-items:flex-start}.subclientlist-wrapper .subclientlist-btns{padding:0;min-height:48px}.subclientlist-wrapper button{width:100%;margin-bottom:0}.subclientlist-wrapper .mat-mdc-dialog-actions .mat-mdc-button-base+.mat-mdc-button-base{margin-left:0}.modal-header-wrapper{display:flex;justify-content:space-between;margin:0 10px}.modal-header-wrapper .close-round-btn{position:absolute;top:12px;right:12px;width:28px;height:28px;border-radius:50%;border:none;background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.modal-header-wrapper .close-round-btn i{font-size:25px;color:#006068}.modal-header-wrapper .close-round-btn:hover{background:#f3f3f3}\n"] }]
41
61
  }], ctorParameters: function () { return [{ type: undefined, decorators: [{
42
62
  type: Inject,
43
63
  args: [MAT_DIALOG_DATA]
44
64
  }] }, { type: i1.MatDialogRef }, { type: i2.SghNavbarService }]; }, propDecorators: { subClient: [{
45
65
  type: Output
46
66
  }] } });
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ViLWNsaWVudC1kaWFsb2cuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2doLW5hdmJhci9zcmMvbGliL3Rvb2xiYXIvc3ViLWNsaWVudC1kaWFsb2cvc3ViLWNsaWVudC1kaWFsb2cuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2doLW5hdmJhci9zcmMvbGliL3Rvb2xiYXIvc3ViLWNsaWVudC1kaWFsb2cvc3ViLWNsaWVudC1kaWFsb2cuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN0RSxPQUFPLEVBQUMsZUFBZSxFQUFlLE1BQU0sMEJBQTBCLENBQUM7Ozs7OztBQVN2RSxNQUFNLE9BQU8sd0JBQXdCO0lBTW5DLFlBQTRDLElBQVMsRUFBVSxTQUFpRCxFQUFVLGdCQUFrQztRQUFoSCxTQUFJLEdBQUosSUFBSSxDQUFLO1FBQVUsY0FBUyxHQUFULFNBQVMsQ0FBd0M7UUFBVSxxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO1FBSGxKLGNBQVMsR0FBRyxJQUFJLFlBQVksRUFBTyxDQUFDO1FBSTVDLElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQztRQUMxQixJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsYUFBYSxDQUFDO1FBQy9DLCtCQUErQjtRQUMvQixJQUFJLHNCQUFzQixHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDLENBQUMsU0FBUyxFQUFFLEVBQUUsQ0FBQyxTQUFTLENBQUMsT0FBTyxJQUFJLElBQUksQ0FBQyxDQUFDO1FBQ3BHLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLHNCQUFzQixDQUFDLENBQUM7SUFDdEUsQ0FBQztJQUVELGlCQUFpQixDQUFDLElBQXVCO1FBRXZDLHdEQUF3RDtRQUN4RCxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxDQUFDLFNBQVMsRUFBRSxFQUFFO1lBQ3ZDLElBQUksU0FBUyxJQUFJLElBQUksRUFBRTtnQkFDckIsU0FBUyxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUE7YUFDekI7aUJBQU07Z0JBQ0wsU0FBUyxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7YUFDM0I7UUFDSCxDQUFDLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxpQkFBaUIsR0FBRyxJQUFJLENBQUM7SUFDaEMsQ0FBQztJQUVELGdCQUFnQjtRQUNkLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLEVBQUMsSUFBSSxFQUFFLEVBQUMsaUJBQWlCLEVBQUUsSUFBSSxDQUFDLGlCQUFpQixFQUFDLEVBQUMsQ0FBQyxDQUFDO0lBQzVFLENBQUM7O3FIQTdCVSx3QkFBd0Isa0JBTWYsZUFBZTt5R0FOeEIsd0JBQXdCLGlHQ1ZyQyw0MUJBbUJBOzJGRFRhLHdCQUF3QjtrQkFMcEMsU0FBUzsrQkFDRSxzQkFBc0I7OzBCQVVuQixNQUFNOzJCQUFDLGVBQWU7c0dBSHpCLFNBQVM7c0JBQWxCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbmplY3QsIE91dHB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7TUFUX0RJQUxPR19EQVRBLCBNYXREaWFsb2dSZWZ9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2dcIjtcclxuaW1wb3J0IHtDbGllbnRMaXN0SXRlbSwgU3ViQ2xpZW50TGlzdEl0ZW19IGZyb20gXCIuLi90b29sYmFyLWRhdGFcIjtcclxuaW1wb3J0IHtTZ2hOYXZiYXJTZXJ2aWNlfSBmcm9tIFwiLi4vLi4vc2doLW5hdmJhci5zZXJ2aWNlXCI7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2xpYi1zdWJjbGllbnQtZGlhbG9nJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vc3ViLWNsaWVudC1kaWFsb2cuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3N1Yi1jbGllbnQtZGlhbG9nLmNvbXBvbmVudC5zY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIFN1YkNsaWVudERpYWxvZ0NvbXBvbmVudCB7XHJcbiAgY2xpZW50OiBDbGllbnRMaXN0SXRlbTtcclxuICBzdWJDbGllbnRMaXN0OiBTdWJDbGllbnRMaXN0SXRlbVtdO1xyXG4gIEBPdXRwdXQoKSBzdWJDbGllbnQgPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcclxuICBzZWxlY3RlZFN1YkNsaWVudDogU3ViQ2xpZW50TGlzdEl0ZW07XHJcblxyXG4gIGNvbnN0cnVjdG9yKEBJbmplY3QoTUFUX0RJQUxPR19EQVRBKSBwdWJsaWMgZGF0YTogYW55LCBwcml2YXRlIGRpYWxvZ1JlZjogTWF0RGlhbG9nUmVmPFN1YkNsaWVudERpYWxvZ0NvbXBvbmVudD4sIHByaXZhdGUgc2doTmF2YmFyU2VydmljZTogU2doTmF2YmFyU2VydmljZSkge1xyXG4gICAgdGhpcy5jbGllbnQgPSBkYXRhLmNsaWVudDtcclxuICAgIHRoaXMuc3ViQ2xpZW50TGlzdCA9IGRhdGEuY2xpZW50LnN1YkNsaWVudExpc3Q7XHJcbiAgICAvLyBmaW5kIHRoZSBzZWxlY3RlZCBzdWIgY2xpZW50XHJcbiAgICBsZXQgc2VsZWN0ZWRTdWJDbGllbnRJbmRleCA9IHRoaXMuc3ViQ2xpZW50TGlzdC5maW5kSW5kZXgoKHN1YkNsaWVudCkgPT4gc3ViQ2xpZW50LmNoZWNrZWQgPT0gdHJ1ZSk7XHJcbiAgICB0aGlzLnNlbGVjdGVkU3ViQ2xpZW50ID0gdGhpcy5zdWJDbGllbnRMaXN0W3NlbGVjdGVkU3ViQ2xpZW50SW5kZXhdO1xyXG4gIH1cclxuXHJcbiAgb25TdWJDbGllbnRTZWxlY3QoaXRlbTogU3ViQ2xpZW50TGlzdEl0ZW0pIHtcclxuXHJcbiAgICAvLyB1cGRhdGUgdGhlIHN1YiBjbGllbnQgbGlzdCB3aXRoIG5ld2x5IHNlbGVjdGVkIHZhbHVlc1xyXG4gICAgdGhpcy5zdWJDbGllbnRMaXN0LmZvckVhY2goKHN1YkNsaWVudCkgPT4ge1xyXG4gICAgICBpZiAoc3ViQ2xpZW50ID09IGl0ZW0pIHtcclxuICAgICAgICBzdWJDbGllbnQuY2hlY2tlZCA9IHRydWVcclxuICAgICAgfSBlbHNlIHtcclxuICAgICAgICBzdWJDbGllbnQuY2hlY2tlZCA9IGZhbHNlO1xyXG4gICAgICB9XHJcbiAgICB9KTtcclxuICAgIHRoaXMuc2VsZWN0ZWRTdWJDbGllbnQgPSBpdGVtO1xyXG4gIH1cclxuXHJcbiAgb25TZWxlY3RCdG5DbGljaygpIHtcclxuICAgIHRoaXMuZGlhbG9nUmVmLmNsb3NlKHtkYXRhOiB7c2VsZWN0ZWRTdWJDbGllbnQ6IHRoaXMuc2VsZWN0ZWRTdWJDbGllbnR9fSk7XHJcbiAgfVxyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJzdWJjbGllbnRsaXN0LXdyYXBwZXIgZGlhbG9nLXdyYXBwZXJcIj5cclxuIDxkaXYgY2xhc3M9XCJtb2RhbC1oZWFkZXItd3JhcHBlclwiPlxyXG4gICA8aDQgY2xhc3M9XCJzdWJjbGllbnRsaXN0LWhlYWRlclwiPlNlbGVjdCBTdWIgQ2xpZW50PC9oND5cclxuICAgPGJ1dHRvbiAgdHlwZT1cImJ1dHRvblwiIG1hdC1kaWFsb2ctY2xvc2UgY2xhc3M9XCJjbG9zZS1yb3VuZC1idG5cIj5cclxuICAgICA8aSBjbGFzcz1cImZhICBmYS10aW1lcy1jaXJjbGVcIj48L2k+XHJcbiAgIDwvYnV0dG9uPlxyXG4gPC9kaXY+XHJcbiAgPGRpdiBjbGFzcz1cInN1YmNsaWVudGxpc3QtYm9keVwiPlxyXG4gICAgPGRpdj5cclxuICAgICAgPG1hdC1yYWRpby1ncm91cCBjbGFzcz1cInN1YmNsaWVudGxpc3QtcmFkaW9ncnBcIiBhcmlhLWxhYmVsPVwiU2VsZWN0IGFuIG9wdGlvblwiPlxyXG4gICAgICAgIDxtYXQtcmFkaW8tYnV0dG9uIFt2YWx1ZV09XCJpdGVtLnZhbHVlXCIgKm5nRm9yPVwibGV0IGl0ZW0gb2Ygc3ViQ2xpZW50TGlzdDtpbmRleCBhcyBpXCIgKGNsaWNrKT1cIm9uU3ViQ2xpZW50U2VsZWN0KGl0ZW0pXCIgW2NoZWNrZWRdPVwiaXRlbS5jaGVja2VkXCI+e3tpdGVtLnRleHR9fTwvbWF0LXJhZGlvLWJ1dHRvbj5cclxuICAgICAgPC9tYXQtcmFkaW8tZ3JvdXA+XHJcbiAgICA8L2Rpdj5cclxuICA8L2Rpdj5cclxuICA8ZGl2IGNsYXNzPVwic3ViY2xpZW50bGlzdC1idG5zXCI+XHJcbiAgICA8YnV0dG9uIGNsYXNzPVwic2doLWJ0bi1wcmltYXJ5XCIgKGNsaWNrKT1cIm9uU2VsZWN0QnRuQ2xpY2soKVwiPlNlbGVjdDwvYnV0dG9uPlxyXG4gIDwvZGl2PlxyXG48L2Rpdj5cclxuXHJcbiJdfQ==
67
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ViLWNsaWVudC1kaWFsb2cuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2doLW5hdmJhci9zcmMvbGliL3Rvb2xiYXIvc3ViLWNsaWVudC1kaWFsb2cvc3ViLWNsaWVudC1kaWFsb2cuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2doLW5hdmJhci9zcmMvbGliL3Rvb2xiYXIvc3ViLWNsaWVudC1kaWFsb2cvc3ViLWNsaWVudC1kaWFsb2cuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN0RSxPQUFPLEVBQUMsZUFBZSxFQUFlLE1BQU0sMEJBQTBCLENBQUM7Ozs7Ozs7QUFTdkUsTUFBTSxPQUFPLHdCQUF3QjtJQVNuQyxZQUE0QyxJQUFTLEVBQVUsU0FBaUQsRUFBVSxnQkFBa0M7UUFBaEgsU0FBSSxHQUFKLElBQUksQ0FBSztRQUFVLGNBQVMsR0FBVCxTQUFTLENBQXdDO1FBQVUscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtRQU5sSixjQUFTLEdBQUcsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUM5QywwQkFBcUIsR0FBNkIsSUFBSSxDQUFDO1FBQ3ZELHFCQUFnQixHQUE2QixJQUFJLENBQUM7UUFFbEQsMkJBQXNCLEdBQXVCLFNBQVMsQ0FBQztRQUdyRCxJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUM7UUFDMUIsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLGFBQWEsQ0FBQztRQUUvQyw2REFBNkQ7UUFDN0QsSUFBSSxzQkFBc0IsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxDQUFDLFNBQVMsRUFBRSxFQUFFLENBQUMsU0FBUyxDQUFDLE9BQU8sS0FBSyxJQUFJLENBQUMsQ0FBQztRQUVyRyxtRUFBbUU7UUFDbkUsSUFBSSxzQkFBc0IsS0FBSyxDQUFDLENBQUMsRUFBRTtZQUNqQyxJQUFJLENBQUMscUJBQXFCLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxzQkFBc0IsQ0FBQyxDQUFDO1lBQ3hFLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLHNCQUFzQixDQUFDLENBQUM7WUFDbkUsSUFBSSxDQUFDLHNCQUFzQixHQUFHLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxLQUFLLENBQUM7U0FDaEU7YUFBTTtZQUNMLG1GQUFtRjtZQUNuRixJQUFJLENBQUMscUJBQXFCLEdBQUcsSUFBSSxDQUFDO1lBQ2xDLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxJQUFJLENBQUM7WUFDN0IsSUFBSSxDQUFDLHNCQUFzQixHQUFHLFNBQVMsQ0FBQztTQUN6QztRQUNELElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQztJQUNuQyxDQUFDO0lBRUQsaUJBQWlCLENBQUMsSUFBdUI7UUFDdkMsSUFBSSxDQUFDLHFCQUFxQixHQUFHLElBQUksQ0FBQztJQUNwQyxDQUFDO0lBRUQsZ0JBQWdCO1FBQ2QsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksQ0FBQyxxQkFBcUIsQ0FBQztRQUNuRCxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxFQUFDLElBQUksRUFBRSxFQUFDLGlCQUFpQixFQUFFLElBQUksQ0FBQyxxQkFBcUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFDLEVBQUMsQ0FBQyxDQUFDO1FBRWhHLHdEQUF3RDtRQUN4RCxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxDQUFDLFNBQVMsRUFBRSxFQUFFO1lBQ3ZDLElBQUksU0FBUyxJQUFJLElBQUksQ0FBQyxxQkFBcUIsRUFBRTtnQkFDM0MsU0FBUyxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUE7YUFDekI7aUJBQU07Z0JBQ0wsU0FBUyxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7YUFDM0I7UUFDSCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxlQUFlO1FBQ2IsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsRUFBQyxJQUFJLEVBQUUsRUFBQyxpQkFBaUIsRUFBRSxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsU0FBUyxFQUFFLElBQUksRUFBQyxFQUFDLENBQUMsQ0FBQztJQUM1RixDQUFDOztxSEFsRFUsd0JBQXdCLGtCQVNmLGVBQWU7eUdBVHhCLHdCQUF3QixpR0NWckMsczNCQW1CQTsyRkRUYSx3QkFBd0I7a0JBTHBDLFNBQVM7K0JBQ0Usc0JBQXNCOzswQkFhbkIsTUFBTTsyQkFBQyxlQUFlO3NHQU56QixTQUFTO3NCQUFsQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5qZWN0LCBPdXRwdXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge01BVF9ESUFMT0dfREFUQSwgTWF0RGlhbG9nUmVmfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nXCI7XHJcbmltcG9ydCB7Q2xpZW50TGlzdEl0ZW0sIFN1YkNsaWVudExpc3RJdGVtfSBmcm9tIFwiLi4vdG9vbGJhci1kYXRhXCI7XHJcbmltcG9ydCB7U2doTmF2YmFyU2VydmljZX0gZnJvbSBcIi4uLy4uL3NnaC1uYXZiYXIuc2VydmljZVwiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdsaWItc3ViY2xpZW50LWRpYWxvZycsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL3N1Yi1jbGllbnQtZGlhbG9nLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9zdWItY2xpZW50LWRpYWxvZy5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTdWJDbGllbnREaWFsb2dDb21wb25lbnQge1xyXG4gIGNsaWVudDogQ2xpZW50TGlzdEl0ZW07XHJcbiAgc3ViQ2xpZW50TGlzdDogU3ViQ2xpZW50TGlzdEl0ZW1bXTtcclxuICBAT3V0cHV0KCkgc3ViQ2xpZW50ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XHJcbiAgdGVtcFNlbGVjdGVkU3ViQ2xpZW50OiBTdWJDbGllbnRMaXN0SXRlbSB8IG51bGwgPSBudWxsO1xyXG4gIG9yZ2luYWxTdWJDbGllbnQ6IFN1YkNsaWVudExpc3RJdGVtIHwgbnVsbCA9IG51bGw7XHJcbiAgb3JnaW5hbENsaWVudDogQ2xpZW50TGlzdEl0ZW07XHJcbiAgc2VsZWN0ZWRTdWJDbGllbnRWYWx1ZTogc3RyaW5nIHwgdW5kZWZpbmVkID0gdW5kZWZpbmVkO1xyXG5cclxuICBjb25zdHJ1Y3RvcihASW5qZWN0KE1BVF9ESUFMT0dfREFUQSkgcHVibGljIGRhdGE6IGFueSwgcHJpdmF0ZSBkaWFsb2dSZWY6IE1hdERpYWxvZ1JlZjxTdWJDbGllbnREaWFsb2dDb21wb25lbnQ+LCBwcml2YXRlIHNnaE5hdmJhclNlcnZpY2U6IFNnaE5hdmJhclNlcnZpY2UpIHtcclxuICAgIHRoaXMuY2xpZW50ID0gZGF0YS5jbGllbnQ7XHJcbiAgICB0aGlzLnN1YkNsaWVudExpc3QgPSBkYXRhLmNsaWVudC5zdWJDbGllbnRMaXN0O1xyXG5cclxuICAgIC8vIGZpbmQgdGhlIHNlbGVjdGVkIHN1YiBjbGllbnQgKHRoZSBvbmUgd2l0aCBjaGVja2VkID0gdHJ1ZSlcclxuICAgIGxldCBzZWxlY3RlZFN1YkNsaWVudEluZGV4ID0gdGhpcy5zdWJDbGllbnRMaXN0LmZpbmRJbmRleCgoc3ViQ2xpZW50KSA9PiBzdWJDbGllbnQuY2hlY2tlZCA9PT0gdHJ1ZSk7XHJcblxyXG4gICAgLy8gT25seSBzZXQgaWYgYSBjaGVja2VkIHN1YmNsaWVudCBpcyBmb3VuZCwgb3RoZXJ3aXNlIGtlZXAgYXMgbnVsbFxyXG4gICAgaWYgKHNlbGVjdGVkU3ViQ2xpZW50SW5kZXggIT09IC0xKSB7XHJcbiAgICAgIHRoaXMudGVtcFNlbGVjdGVkU3ViQ2xpZW50ID0gdGhpcy5zdWJDbGllbnRMaXN0W3NlbGVjdGVkU3ViQ2xpZW50SW5kZXhdO1xyXG4gICAgICB0aGlzLm9yZ2luYWxTdWJDbGllbnQgPSB0aGlzLnN1YkNsaWVudExpc3Rbc2VsZWN0ZWRTdWJDbGllbnRJbmRleF07XHJcbiAgICAgIHRoaXMuc2VsZWN0ZWRTdWJDbGllbnRWYWx1ZSA9IHRoaXMudGVtcFNlbGVjdGVkU3ViQ2xpZW50LnZhbHVlO1xyXG4gICAgfSBlbHNlIHtcclxuICAgICAgLy8gRXhwbGljaXRseSBlbnN1cmUgYWxsIHZhbHVlcyBhcmUgbnVsbC91bmRlZmluZWQgd2hlbiBubyBjaGVja2VkIHN1YmNsaWVudCBleGlzdHNcclxuICAgICAgdGhpcy50ZW1wU2VsZWN0ZWRTdWJDbGllbnQgPSBudWxsO1xyXG4gICAgICB0aGlzLm9yZ2luYWxTdWJDbGllbnQgPSBudWxsO1xyXG4gICAgICB0aGlzLnNlbGVjdGVkU3ViQ2xpZW50VmFsdWUgPSB1bmRlZmluZWQ7XHJcbiAgICB9XHJcbiAgICB0aGlzLm9yZ2luYWxDbGllbnQgPSBkYXRhLmNsaWVudDtcclxuICB9XHJcblxyXG4gIG9uU3ViQ2xpZW50Q2hhbmdlKGl0ZW06IFN1YkNsaWVudExpc3RJdGVtKSB7XHJcbiAgICB0aGlzLnRlbXBTZWxlY3RlZFN1YkNsaWVudCA9IGl0ZW07XHJcbiAgfVxyXG5cclxuICBvblNlbGVjdEJ0bkNsaWNrKCkge1xyXG4gICAgdGhpcy5vcmdpbmFsU3ViQ2xpZW50ID0gdGhpcy50ZW1wU2VsZWN0ZWRTdWJDbGllbnQ7XHJcbiAgICB0aGlzLmRpYWxvZ1JlZi5jbG9zZSh7ZGF0YToge3NlbGVjdGVkU3ViQ2xpZW50OiB0aGlzLnRlbXBTZWxlY3RlZFN1YkNsaWVudCwgY2FuY2VsbGVkOiBmYWxzZX19KTtcclxuXHJcbiAgICAvLyB1cGRhdGUgdGhlIHN1YiBjbGllbnQgbGlzdCB3aXRoIG5ld2x5IHNlbGVjdGVkIHZhbHVlc1xyXG4gICAgdGhpcy5zdWJDbGllbnRMaXN0LmZvckVhY2goKHN1YkNsaWVudCkgPT4ge1xyXG4gICAgICBpZiAoc3ViQ2xpZW50ID09IHRoaXMudGVtcFNlbGVjdGVkU3ViQ2xpZW50KSB7XHJcbiAgICAgICAgc3ViQ2xpZW50LmNoZWNrZWQgPSB0cnVlXHJcbiAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgc3ViQ2xpZW50LmNoZWNrZWQgPSBmYWxzZTtcclxuICAgICAgfVxyXG4gICAgfSk7XHJcbiAgfVxyXG5cclxuICBvbkNsb3NlQnRuQ2xpY2soKSB7XHJcbiAgICB0aGlzLmRpYWxvZ1JlZi5jbG9zZSh7ZGF0YToge3NlbGVjdGVkU3ViQ2xpZW50OiB0aGlzLm9yZ2luYWxTdWJDbGllbnQsIGNhbmNlbGxlZDogdHJ1ZX19KTtcclxuICB9XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cInN1YmNsaWVudGxpc3Qtd3JhcHBlciBkaWFsb2ctd3JhcHBlclwiPlxyXG4gPGRpdiBjbGFzcz1cIm1vZGFsLWhlYWRlci13cmFwcGVyXCI+XHJcbiAgIDxoNCBjbGFzcz1cInN1YmNsaWVudGxpc3QtaGVhZGVyXCI+U2VsZWN0IFN1YiBDbGllbnQ8L2g0PlxyXG4gICA8YnV0dG9uICB0eXBlPVwiYnV0dG9uXCIgKGNsaWNrKT1cIm9uQ2xvc2VCdG5DbGljaygpXCIgY2xhc3M9XCJjbG9zZS1yb3VuZC1idG5cIj5cclxuICAgICA8aSBjbGFzcz1cImZhICBmYS10aW1lcy1jaXJjbGVcIj48L2k+XHJcbiAgIDwvYnV0dG9uPlxyXG4gPC9kaXY+XHJcbiAgPGRpdiBjbGFzcz1cInN1YmNsaWVudGxpc3QtYm9keVwiPlxyXG4gICAgPGRpdj5cclxuICAgICAgPG1hdC1yYWRpby1ncm91cCBjbGFzcz1cInN1YmNsaWVudGxpc3QtcmFkaW9ncnBcIiBhcmlhLWxhYmVsPVwiU2VsZWN0IGFuIG9wdGlvblwiIFsobmdNb2RlbCldPVwic2VsZWN0ZWRTdWJDbGllbnRWYWx1ZVwiPlxyXG4gICAgICAgIDxtYXQtcmFkaW8tYnV0dG9uIFt2YWx1ZV09XCJpdGVtLnZhbHVlXCIgKm5nRm9yPVwibGV0IGl0ZW0gb2Ygc3ViQ2xpZW50TGlzdDtpbmRleCBhcyBpXCIgKGNoYW5nZSk9XCJvblN1YkNsaWVudENoYW5nZShpdGVtKVwiPnt7aXRlbS50ZXh0fX08L21hdC1yYWRpby1idXR0b24+XHJcbiAgICAgIDwvbWF0LXJhZGlvLWdyb3VwPlxyXG4gICAgPC9kaXY+XHJcbiAgPC9kaXY+XHJcbiAgPGRpdiBjbGFzcz1cInN1YmNsaWVudGxpc3QtYnRuc1wiPlxyXG4gICAgPGJ1dHRvbiBjbGFzcz1cInNnaC1idG4tcHJpbWFyeVwiIChjbGljayk9XCJvblNlbGVjdEJ0bkNsaWNrKClcIj5TZWxlY3Q8L2J1dHRvbj5cclxuICA8L2Rpdj5cclxuPC9kaXY+XHJcblxyXG4iXX0=
@@ -52,16 +52,16 @@ export class ToolbarComponent {
52
52
  clientList: [{
53
53
  text: 'Client 1',
54
54
  value: 'CLIENT_1',
55
- selected: true,
55
+ selected: false,
56
56
  subClientList: [
57
- { text: 'Sub Client 1', value: 'SUB_CLIENT_1', checked: true },
57
+ { text: 'Sub Client 1', value: 'SUB_CLIENT_1', checked: false },
58
58
  { text: 'Sub Client 2', value: 'SUB_CLIENT_2', checked: false },
59
59
  { text: 'Sub Client 3', value: 'SUB_CLIENT_3', checked: false }
60
60
  ]
61
61
  }, {
62
62
  text: 'Client 2',
63
63
  value: 'CLIENT_2',
64
- selected: false,
64
+ selected: true,
65
65
  subClientList: [
66
66
  { text: 'Sub Client 1', value: 'SUB_CLIENT_1', checked: true },
67
67
  { text: 'Sub Client 2', value: 'SUB_CLIENT_2', checked: false }
@@ -100,19 +100,18 @@ export class ToolbarComponent {
100
100
  ngAfterViewInit() {
101
101
  // initially set client and subclients
102
102
  setTimeout(() => {
103
- this.toolbarData.clientList?.forEach((client, index) => {
104
- // select the first client
105
- if (this.sghNavbarSvc.getClientIndexCache() == index) {
106
- client.selected = true;
107
- this.sghNavbarSvc.setClient(client);
108
- this.sghNavbarSvc.setClientIndexCache(index, this.toolbarData.activeClientCache);
109
- this.selectedClient = client;
110
- }
111
- else {
112
- client.selected = false;
113
- }
114
- this.initSelectedSubClient(client);
115
- });
103
+ const clientList = this.toolbarData?.clientList ?? [];
104
+ const selectedClientIndex = clientList.findIndex(c => c.selected === true);
105
+ if (selectedClientIndex === -1) {
106
+ this.sghNavbarSvc.setClient(null);
107
+ this.sghNavbarSvc.setSubclient(null);
108
+ return;
109
+ }
110
+ const orgClient = clientList[selectedClientIndex];
111
+ const orgSubClient = orgClient?.subClientList?.find(c => c.checked === true) ?? null;
112
+ this.sghNavbarSvc.setClient(orgClient);
113
+ this.sghNavbarSvc.setSubclient(orgSubClient);
114
+ this.selectedClient = orgClient;
116
115
  }, 100);
117
116
  }
118
117
  setClass(selected) {
@@ -126,13 +125,8 @@ export class ToolbarComponent {
126
125
  this.setClass(themeValue);
127
126
  }
128
127
  toggleSelect(event, clientItem, index) {
129
- this.selectedClient = clientItem;
130
- // unselect current selected client
131
- this.unselectClientItems();
132
- // select current client
133
- clientItem.selected = true;
134
- this.sghNavbarSvc.setClient(clientItem);
135
- this.sghNavbarSvc.setClientIndexCache(index, this.toolbarData?.activeClientCache);
128
+ this.previousClient = this.selectedClient;
129
+ // event on client selection
136
130
  // at least one subclient should exist
137
131
  if (clientItem.subClientList && clientItem.subClientList.length > 0) { // if sub clients exist open sub client dialog
138
132
  const subClientDialogRef = this.dialog.open(SubClientDialogComponent, {
@@ -143,15 +137,28 @@ export class ToolbarComponent {
143
137
  disableClose: true
144
138
  });
145
139
  // select first item of each subclient
146
- this.selectFirstSubclient();
147
140
  subClientDialogRef.afterClosed().subscribe((event) => {
148
- this.clientMenuTrigger.focus();
149
- this.sghNavbarSvc.setSubclient(event?.data?.selectedSubClient);
150
- this.sghNavbarSvc.setSubClientIndexCache(clientItem?.subClientList?.indexOf(event?.data?.selectedSubClient) ?? 0, this.toolbarData?.activeClientCache);
151
- // set the selected subclient item as checked, search by name comparison
152
- let selectedObj = clientItem?.subClientList?.find((scItem) => scItem.text == event?.data?.selectedSubClient?.text);
153
- if (selectedObj) {
154
- selectedObj.checked = true;
141
+ if (!event?.data?.cancelled) {
142
+ this.selectedClient = clientItem;
143
+ // unselect current selected client
144
+ this.unselectClientItems();
145
+ // select current client
146
+ clientItem.selected = true;
147
+ this.sghNavbarSvc.setClient(clientItem);
148
+ // this.sghNavbarSvc.setClientIndexCache(index,this.toolbarData?.activeClientCache);
149
+ this.clientMenuTrigger.focus();
150
+ this.sghNavbarSvc.setSubclient(event?.data?.selectedSubClient);
151
+ // this.sghNavbarSvc.setSubClientIndexCache(clientItem?.subClientList?.indexOf(event?.data?.selectedSubClient) ?? 0, this.toolbarData?.activeClientCache)
152
+ // set the selected subclient item as checked, search by name comparison
153
+ let selectedObj = clientItem?.subClientList?.find((scItem) => scItem.text == event?.data?.selectedSubClient?.text);
154
+ if (selectedObj) {
155
+ selectedObj.checked = true;
156
+ }
157
+ if (this.previousClient.text !== this.selectedClient.text) {
158
+ this.previousClient?.subClientList?.forEach((subClient) => {
159
+ subClient.checked = false;
160
+ });
161
+ }
155
162
  }
156
163
  });
157
164
  }
@@ -218,4 +225,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
218
225
  type: HostListener,
219
226
  args: ['document:click']
220
227
  }] } });
221
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbar.component.js","sourceRoot":"","sources":["../../../../../projects/sgh-navbar/src/lib/toolbar/toolbar.component.ts","../../../../../projects/sgh-navbar/src/lib/toolbar/toolbar.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EACT,YAAY,EACZ,YAAY,EACZ,KAAK,EACL,MAAM,EACN,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,SAAS,EAAC,MAAM,mBAAmB,CAAC;AAI5C,OAAO,EAAC,wBAAwB,EAAC,MAAM,iDAAiD,CAAC;;;;;;;;;;AAWzF,MAAM,OAAO,gBAAgB;IAkE3B,WAAW;QACT,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;IACxB,CAAC;IAGD,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACnB,IAAI,CAAC,WAAW,CAAC,WAAW,GAAG,KAAK,CAAC;YACrC,IAAI,CAAC,WAAW,CAAC,gBAAgB,GAAG,KAAK,CAAC;YAC1C,IAAI,CAAC,WAAW,CAAC,mBAAmB,GAAG,KAAK,CAAC;SAC9C;QACD,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IAED,YAAoB,MAAiB,EAAU,YAA8B;QAAzD,WAAM,GAAN,MAAM,CAAW;QAAU,iBAAY,GAAZ,YAAY,CAAkB;QA9EnE,uBAAkB,GAAG,IAAI,YAAY,EAAW,CAAC;QAClD,gBAAW,GAAgB;YAClC,YAAY,EAAE,CAAC;oBACb,IAAI,EAAE,mBAAmB;oBACzB,KAAK,EAAE,mBAAmB;oBAC1B,OAAO,EAAE,IAAI;iBACd,EAAE;oBACD,IAAI,EAAE,iBAAiB;oBACvB,KAAK,EAAE,iBAAiB;oBACxB,OAAO,EAAE,KAAK;iBACf,EAAE;oBACD,IAAI,EAAE,gBAAgB;oBACtB,KAAK,EAAE,gBAAgB;oBACvB,OAAO,EAAE,KAAK;iBACf,CAAC;YACF,OAAO,EAAE,MAAM;YACf,GAAG,EAAE,wCAAwC;YAC7C,WAAW,EAAE,KAAK;YAClB,mBAAmB,EAAE,KAAK;YAC1B,YAAY,EAAE,IAAI;YAClB,kBAAkB,EAAE,IAAI;YACxB,aAAa,EAAE,IAAI;YACnB,cAAc,EAAE,IAAI;YACpB,iBAAiB,EAAE,IAAI;YACvB,UAAU,EAAE,CAAC;oBACX,IAAI,EAAE,UAAU;oBAChB,KAAK,EAAE,UAAU;oBACjB,QAAQ,EAAE,IAAI;oBACd,aAAa,EAAE;wBACb,EAAC,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE,cAAc,EAAE,OAAO,EAAE,IAAI,EAAC;wBAC5D,EAAC,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE,cAAc,EAAE,OAAO,EAAE,KAAK,EAAC;wBAC7D,EAAC,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE,cAAc,EAAE,OAAO,EAAE,KAAK,EAAC;qBAC9D;iBACF,EAAE;oBACD,IAAI,EAAE,UAAU;oBAChB,KAAK,EAAE,UAAU;oBACjB,QAAQ,EAAE,KAAK;oBACf,aAAa,EAAE;wBACb,EAAC,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE,cAAc,EAAE,OAAO,EAAE,IAAI,EAAC;wBAC5D,EAAC,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE,cAAc,EAAE,OAAO,EAAE,KAAK,EAAC;qBAC9D;iBACF,EAAE;oBACD,IAAI,EAAE,UAAU;oBAChB,KAAK,EAAE,UAAU;oBACjB,QAAQ,EAAE,KAAK;iBAChB,CAAC;YACF,cAAc,EAAE,4BAA4B;YAC5C,yBAAyB,EAAE,IAAI;YAC/B,8BAA8B,EAAE,IAAI;SACrC,CAAC;QACQ,qBAAgB,GAAG,IAAI,YAAY,EAAU,CAAC;QAC9C,WAAM,GAAG,IAAI,YAAY,EAAO,CAAC;QACjC,cAAS,GAAG,IAAI,YAAY,EAAO,CAAC;QAE9C,gBAAW,GAAG,EAAE,CAAC;QAEjB,aAAQ,GAAQ,mBAAmB,CAAC;QAC5B,cAAS,GAAG,KAAK,CAAC;QAmEP,UAAK,GAAG,KAAK,CAAC;QACjC,kBAAa,GAAW,EAAE,CAAC,CAAC,2CAA2C;IA9CvE,CAAC;IAGD,aAAa;QACX,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC5C,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAED,sBAAsB;QACpB,IAAI,CAAC,WAAW,CAAC,mBAAmB,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,mBAAmB,CAAA;IAC9E,CAAC;IAED,YAAY;QACV,IAAI,CAAC,WAAW,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,CAAA;IAC9D,CAAC;IAED,aAAa;QACX,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IAC/C,CAAC;IAED,eAAe;QACb,sCAAsC;QACtC,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC,MAAsB,EAAC,KAAK,EAAE,EAAE;gBACpE,0BAA0B;gBAC1B,IAAG,IAAI,CAAC,YAAY,CAAC,mBAAmB,EAAE,IAAE,KAAK,EAAC;oBAChD,MAAM,CAAC,QAAQ,GAAG,IAAI,CAAC;oBACvB,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;oBACpC,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,KAAK,EAAC,IAAI,CAAC,WAAW,CAAC,iBAAiB,CAAC,CAAC;oBAChF,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC;iBAC9B;qBAAM;oBACL,MAAM,CAAC,QAAQ,GAAG,KAAK,CAAC;iBACzB;gBACD,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;YACrC,CAAC,CAAC,CAAC;QACL,CAAC,EAAC,GAAG,CAAC,CAAA;IACR,CAAC;IAED,QAAQ,CAAC,QAAa;QACpB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACjD,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAC7C,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC;IACvB,CAAC;IAMD,YAAY,CAAC,UAAkB;QAC7B,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;QAC3B,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;IAC5B,CAAC;IAED,YAAY,CAAC,KAAK,EAAE,UAA0B,EAAE,KAAa;QAC3D,IAAI,CAAC,cAAc,GAAG,UAAU,CAAC;QACjC,mCAAmC;QACnC,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,wBAAwB;QACxB,UAAU,CAAC,QAAQ,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QACxC,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,KAAK,EAAC,IAAI,CAAC,WAAW,EAAE,iBAAiB,CAAC,CAAC;QACjF,sCAAsC;QACtC,IAAI,UAAU,CAAC,aAAa,IAAI,UAAU,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,EAAE,8CAA8C;YACnH,MAAM,kBAAkB,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,wBAAwB,EAAE;gBACpE,IAAI,EAAE;oBACJ,MAAM,EAAE,UAAU;iBACnB;gBACD,QAAQ,EAAE,GAAG;gBACb,YAAY,EAAE,IAAI;aACnB,CAAC,CAAC;YACH,sCAAsC;YACtC,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAE5B,kBAAkB,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;gBACnD,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,CAAC;gBAC/B,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,KAAK,EAAE,IAAI,EAAE,iBAAiB,CAAC,CAAC;gBAC/D,IAAI,CAAC,YAAY,CAAC,sBAAsB,CAAC,UAAU,EAAE,aAAa,EAAE,OAAO,CAAC,KAAK,EAAE,IAAI,EAAE,iBAAiB,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,WAAW,EAAE,iBAAiB,CAAC,CAAA;gBAEtJ,wEAAwE;gBACxE,IAAI,WAAW,GAAG,UAAU,EAAE,aAAa,EAAE,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,IAAI,KAAK,EAAE,IAAI,EAAE,iBAAiB,EAAE,IAAI,CAAC,CAAC;gBACnH,IAAI,WAAW,EAAE;oBACf,WAAW,CAAC,OAAO,GAAG,IAAI,CAAC;iBAC5B;YACH,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAED,qBAAqB,CAAC,MAAsB;QAC1C,MAAM,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC,SAA4B,EAAC,KAAK,EAAE,EAAE;YACnE,IAAG,IAAI,CAAC,YAAY,CAAC,sBAAsB,EAAE,IAAE,KAAK,EAAE;gBACpD,SAAS,CAAC,OAAO,GAAG,IAAI,CAAC;gBACzB,IAAI,MAAM,CAAC,QAAQ,EAAE,EAAE,0DAA0D;oBAC/E,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;oBAC1C,IAAI,CAAC,YAAY,CAAC,sBAAsB,CAAC,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,iBAAiB,CAAC,CAAC;iBACrF;aACF;iBAAM;gBAAE,SAAS,CAAC,OAAO,GAAG,KAAK,CAAC;aAAE;QACvC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,mBAAmB;QACjB,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC,MAAsB,EAAE,EAAE;YAC9D,IAAI,MAAM,CAAC,QAAQ,EAAE;gBACnB,MAAM,CAAC,QAAQ,GAAG,KAAK,CAAC;aACzB;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,oBAAoB;QAClB,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;YAC9C,IAAG,MAAM,KAAK,IAAI,CAAC,cAAc,EAAE;gBACjC,MAAM,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC,MAAM,EAAC,KAAK,EAAE,EAAE;oBAC7C,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,GAAG,IAAI,CAAA,CAAC,CAAC,MAAM,CAAC,OAAO,GAAG,KAAK,CAAC;gBAC7D,CAAC,CAAC,CAAC;aACJ;QACH,CAAC,CAAC,CAAA;IACJ,CAAC;;6GArMU,gBAAgB;iGAAhB,gBAAgB,mcCxB7B,y8GA+EA,qq8JD3Dc;QACV,SAAS;KACV;2FAEU,gBAAgB;kBAR5B,SAAS;+BACE,aAAa,cAGX;wBACV,SAAS;qBACV;+HAGQ,QAAQ;sBAAhB,KAAK;gBACI,kBAAkB;sBAA3B,MAAM;gBACE,WAAW;sBAAnB,KAAK;gBAiDI,gBAAgB;sBAAzB,MAAM;gBACG,MAAM;sBAAf,MAAM;gBACG,SAAS;sBAAlB,MAAM;gBAQyB,iBAAiB;sBAAhD,SAAS;uBAAC,mBAAmB;gBAI9B,WAAW;sBADV,YAAY;uBAAC,OAAO;gBAMrB,QAAQ;sBADP,YAAY;uBAAC,gBAAgB","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport {fadeInOut} from '../sidenav/helper';\r\nimport {MatDialog} from \"@angular/material/dialog\";\r\nimport {MatMenuTrigger} from \"@angular/material/menu\";\r\nimport {ClientListItem, SubClientListItem, ToolbarData} from \"./toolbar-data\";\r\nimport {SubClientDialogComponent} from \"./sub-client-dialog/sub-client-dialog.component\";\r\nimport {SghNavbarService} from \"../sgh-navbar.service\";\r\n\r\n@Component({\r\n  selector: 'app-toolbar',\r\n  templateUrl: './toolbar.component.html',\r\n  styleUrls: ['./toolbar.component.scss'],\r\n  animations: [\r\n    fadeInOut\r\n  ]\r\n})\r\nexport class ToolbarComponent implements AfterViewInit {\r\n  @Input() expanded: boolean;\r\n  @Output() toggleSidebarEvent = new EventEmitter<boolean>();\r\n  @Input() toolbarData: ToolbarData = {\r\n    themeOptions: [{\r\n      name: 'Sgh-default-theme',\r\n      value: 'sgh-default-theme',\r\n      checked: true\r\n    }, {\r\n      name: 'Sgh-light-theme',\r\n      value: 'sgh-light-theme',\r\n      checked: false\r\n    }, {\r\n      name: 'Sgh-blue-theme',\r\n      value: 'sgh-blue-theme',\r\n      checked: false\r\n    }],\r\n    bgColor: '#fff',\r\n    img: '../assets/images/Synergen_Logo-new.svg',\r\n    profileView: false,\r\n    isNotifNavCollapsed: false,\r\n    searchEnable: true,\r\n    notificationEnable: true,\r\n    profileEnable: true,\r\n    settingsEnable: true,\r\n    activeClientCache: true,\r\n    clientList: [{\r\n      text: 'Client 1',\r\n      value: 'CLIENT_1',\r\n      selected: true,\r\n      subClientList: [\r\n        {text: 'Sub Client 1', value: 'SUB_CLIENT_1', checked: true},\r\n        {text: 'Sub Client 2', value: 'SUB_CLIENT_2', checked: false},\r\n        {text: 'Sub Client 3', value: 'SUB_CLIENT_3', checked: false}\r\n      ]\r\n    }, {\r\n      text: 'Client 2',\r\n      value: 'CLIENT_2',\r\n      selected: false,\r\n      subClientList: [\r\n        {text: 'Sub Client 1', value: 'SUB_CLIENT_1', checked: true},\r\n        {text: 'Sub Client 2', value: 'SUB_CLIENT_2', checked: false}\r\n      ]\r\n    }, {\r\n      text: 'Client 3',\r\n      value: 'CLIENT_3',\r\n      selected: false\r\n    }],\r\n    profileContent: '<div>profile content</div>',\r\n    clientConfigurationEnable: true,\r\n    applicationConfigurationEnable: true,\r\n  };\r\n  @Output() searchInputEvent = new EventEmitter<string>();\r\n  @Output() client = new EventEmitter<any>();\r\n  @Output() subClient = new EventEmitter<any>();\r\n\r\n  searchInput = \"\";\r\n  private prev: any;\r\n  selected: any = 'sgh-default-theme';\r\n  private wasInside = false;\r\n  selectedClient;\r\n\r\n  @ViewChild('clientMenuTrigger') clientMenuTrigger: MatMenuTrigger;\r\n\r\n\r\n  @HostListener('click')\r\n  clickInside() {\r\n    this.wasInside = true;\r\n  }\r\n\r\n  @HostListener('document:click')\r\n  clickOut() {\r\n    if (!this.wasInside) {\r\n      this.toolbarData.profileView = false;\r\n      this.toolbarData.isThemeCollapsed = false;\r\n      this.toolbarData.isNotifNavCollapsed = false;\r\n    }\r\n    this.wasInside = false;\r\n  }\r\n\r\n  constructor(private dialog: MatDialog, private sghNavbarSvc: SghNavbarService) {\r\n  }\r\n\r\n\r\n  toggleSidebar(): boolean {\r\n    this.toggleSidebarEvent.emit(this.expanded);\r\n    return this.expanded;\r\n  }\r\n\r\n  toggleNotificationList() {\r\n    this.toolbarData.isNotifNavCollapsed = !this.toolbarData.isNotifNavCollapsed\r\n  }\r\n\r\n  clickProfile() {\r\n    this.toolbarData.profileView = !this.toolbarData.profileView\r\n  }\r\n\r\n  onSearchInput() {\r\n    this.searchInputEvent.emit(this.searchInput);\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    // initially set client and subclients\r\n    setTimeout(() => {\r\n      this.toolbarData.clientList?.forEach((client: ClientListItem,index) => {\r\n        // select the first client\r\n        if(this.sghNavbarSvc.getClientIndexCache()==index){\r\n          client.selected = true;\r\n          this.sghNavbarSvc.setClient(client);\r\n          this.sghNavbarSvc.setClientIndexCache(index,this.toolbarData.activeClientCache);\r\n          this.selectedClient = client;\r\n        } else {\r\n          client.selected = false;\r\n        }\r\n        this.initSelectedSubClient(client);\r\n      });\r\n    },100)\r\n  }\r\n\r\n  setClass(selected: any) {\r\n    this.selected = selected;\r\n    window.document.body.classList.remove(this.prev);\r\n    window.document.body.classList.add(selected);\r\n    this.prev = selected;\r\n  }\r\n\r\n  protected readonly event = event;\r\n  selectedTheme: string = ''; // To store the selected radio button value\r\n  searchText: any;\r\n\r\n  onRadioClick(themeValue: string) {\r\n    this.selected = themeValue;\r\n    this.setClass(themeValue);\r\n  }\r\n\r\n  toggleSelect(event, clientItem: ClientListItem, index: number) { // event on client selection\r\n    this.selectedClient = clientItem;\r\n    // unselect current selected client\r\n    this.unselectClientItems();\r\n    // select current client\r\n    clientItem.selected = true;\r\n    this.sghNavbarSvc.setClient(clientItem);\r\n    this.sghNavbarSvc.setClientIndexCache(index,this.toolbarData?.activeClientCache);\r\n    // at least one subclient should exist\r\n    if (clientItem.subClientList && clientItem.subClientList.length > 0) { // if sub clients exist open sub client dialog\r\n      const subClientDialogRef = this.dialog.open(SubClientDialogComponent, {\r\n        data: {\r\n          client: clientItem\r\n        },\r\n        minWidth: 400,\r\n        disableClose: true\r\n      });\r\n      // select first item of each subclient\r\n      this.selectFirstSubclient();\r\n\r\n      subClientDialogRef.afterClosed().subscribe((event) => {\r\n        this.clientMenuTrigger.focus();\r\n        this.sghNavbarSvc.setSubclient(event?.data?.selectedSubClient);\r\n        this.sghNavbarSvc.setSubClientIndexCache(clientItem?.subClientList?.indexOf(event?.data?.selectedSubClient) ?? 0, this.toolbarData?.activeClientCache)\r\n\r\n        // set the selected subclient item as checked, search by name comparison\r\n        let selectedObj = clientItem?.subClientList?.find((scItem) => scItem.text == event?.data?.selectedSubClient?.text);\r\n        if (selectedObj) {\r\n          selectedObj.checked = true;\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  initSelectedSubClient(client: ClientListItem) {\r\n    client.subClientList?.forEach((subclient: SubClientListItem,index) => {\r\n      if(this.sghNavbarSvc.getSubClientIndexCache()==index) {\r\n        subclient.checked = true;\r\n        if (client.selected) { // set the first subclient of the first client as selected\r\n          this.sghNavbarSvc.setSubclient(subclient);\r\n          this.sghNavbarSvc.setSubClientIndexCache(index, this.toolbarData.activeClientCache);\r\n        }\r\n      } else { subclient.checked = false; }\r\n    });\r\n  }\r\n\r\n  unselectClientItems() {\r\n    this.toolbarData.clientList?.forEach((client: ClientListItem) => {\r\n      if (client.selected) {\r\n        client.selected = false;\r\n      }\r\n    });\r\n  }\r\n\r\n  selectFirstSubclient() {\r\n    this.toolbarData.clientList?.forEach((client) => {\r\n      if(client !== this.selectedClient) {\r\n        client.subClientList?.forEach((scItem,index) => {\r\n          index == 0 ? scItem.checked = true: scItem.checked = false;\r\n        });\r\n      }\r\n    })\r\n  }\r\n}\r\n","<nav class=\"toolbar-main-wrapper\" [style.background-color]=\"toolbarData.bgColor\" id=\"toolBarWrapper\">\r\n  <div class=\"logo-wrapper\">\r\n    <img class=\"logo\" [src]=\"toolbarData.img\"/>\r\n  </div>\r\n  <div>\r\n    <button class=\"toggle-button\" (click)=\"toggleSidebar()\">\r\n      <i class=\"fa fa-lg fa-bars\"></i>\r\n    </button>\r\n  </div>\r\n  <div class=\"search\">\r\n    <div class=\"form\" *ngIf=\"toolbarData.searchEnable\">\r\n      <input type=\"text\" name=\"text\" autocomplete=\"off\" required/>\r\n      <label class=\"label-name\">\r\n    <span class=\"content-name\">\r\n      Search\r\n    </span>\r\n      </label>\r\n      <button class=\"search-wrapper\">\r\n        <i class=\"fa fa-search\"></i>\r\n      </button>\r\n    </div>\r\n  </div>\r\n  <div *ngIf=\"toolbarData.notificationEnable\" class=\"icon\" id=\"bell\" (click)=\"toggleNotificationList()\">\r\n    <i class=\"fa fa-bell\"></i>\r\n  </div>\r\n  <div *ngIf=\"toolbarData.profileEnable\" class=\"icon\" id=\"bell3\" (click)=\"clickProfile()\">\r\n    <i class=\"fa fa-user\"></i>\r\n  </div>\r\n  <div *ngIf=\"toolbarData.settingsEnable\" class=\"icon\" id=\"bell2\" [matMenuTriggerFor]=\"settingsMenu\">\r\n    <i class=\"fa fa-gear\"></i>\r\n  </div>\r\n</nav>\r\n\r\n<div *ngIf=\"toolbarData.profileView\" class=\"notifications\">\r\n  <div class=\"notifications-list-wrapper profile-list-wrapper\">\r\n    <div class=\"notifications-list\">\r\n      <div class=\"notifications-list-item\">\r\n        <div [innerHTML]=\"toolbarData.profileContent\"></div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<!--Settings related menus start-->\r\n<mat-menu #settingsMenu=\"matMenu\" xPosition=\"before\">\r\n  <button mat-menu-item [matMenuTriggerFor]=\"appConfig\" *ngIf=\"toolbarData.applicationConfigurationEnable\">Application Settings</button>\r\n  <button mat-menu-item [matMenuTriggerFor]=\"clientConfig\" *ngIf=\"toolbarData.clientConfigurationEnable\" #clientMenuTrigger>Client Settings</button>\r\n</mat-menu>\r\n<mat-menu #appConfig=\"matMenu\" xPosition=\"after\">\r\n  <div *ngFor=\"let themeoption of toolbarData.themeOptions\">\r\n    <button mat-menu-item class=\"radio\" (click)=\"onRadioClick(themeoption.value)\">\r\n      <input value=\"{{themeoption.value}}\" name=\"radio\" type=\"radio\" checked [ngModel]=\"selected\"\r\n             (ngModelChange)=\"setClass($event)\">\r\n      <span>{{themeoption.name}}</span>\r\n    </button>\r\n  </div>\r\n</mat-menu>\r\n<mat-menu #clientConfig=\"matMenu\" xPosition=\"after\">\r\n  <div style=\"width: 250px\" class=\"client-menu-wrapper\">\r\n    <div class=\"container-fluid\">\r\n      <div class=\"row\">\r\n        <div class=\"col-sm-12\" (click)=\"$event.stopPropagation();\">\r\n          <input type=\"text\" class=\"search-input\" placeholder=\"Search Client\" [(ngModel)]=\"searchText\"/>\r\n        </div>\r\n        <div class=\"col-sm-12\">\r\n          <div class=\"mt-2 list-item-container\">\r\n            <div class=\"list-item text-truncate\" *ngFor=\"let item of toolbarData.clientList | search : searchText;let i = index\"\r\n                 [ngClass]=\"{'client-selected': item.selected}\"\r\n                 (click)=\"toggleSelect($event, item, i);\" mat-ripple>{{item.text}}</div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</mat-menu>\r\n\r\n<!--Settings related menus end-->\r\n\r\n<app-noftification-list *ngIf=\"toolbarData.isNotifNavCollapsed\"></app-noftification-list>\r\n"]}
228
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbar.component.js","sourceRoot":"","sources":["../../../../../projects/sgh-navbar/src/lib/toolbar/toolbar.component.ts","../../../../../projects/sgh-navbar/src/lib/toolbar/toolbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport {fadeInOut} from '../sidenav/helper';\r\nimport {MatDialog} from \"@angular/material/dialog\";\r\nimport {MatMenuTrigger} from \"@angular/material/menu\";\r\nimport {ClientListItem, SubClientListItem, ToolbarData} from \"./toolbar-data\";\r\nimport {SubClientDialogComponent} from \"./sub-client-dialog/sub-client-dialog.component\";\r\nimport {SghNavbarService} from \"../sgh-navbar.service\";\r\n\r\n@Component({\r\n  selector: 'app-toolbar',\r\n  templateUrl: './toolbar.component.html',\r\n  styleUrls: ['./toolbar.component.scss'],\r\n  animations: [\r\n    fadeInOut\r\n  ]\r\n})\r\nexport class ToolbarComponent implements AfterViewInit {\r\n  @Input() expanded: boolean;\r\n  @Output() toggleSidebarEvent = new EventEmitter<boolean>();\r\n  @Input() toolbarData: ToolbarData = {\r\n    themeOptions: [{\r\n      name: 'Sgh-default-theme',\r\n      value: 'sgh-default-theme',\r\n      checked: true\r\n    }, {\r\n      name: 'Sgh-light-theme',\r\n      value: 'sgh-light-theme',\r\n      checked: false\r\n    }, {\r\n      name: 'Sgh-blue-theme',\r\n      value: 'sgh-blue-theme',\r\n      checked: false\r\n    }],\r\n    bgColor: '#fff',\r\n    img: '../assets/images/Synergen_Logo-new.svg',\r\n    profileView: false,\r\n    isNotifNavCollapsed: false,\r\n    searchEnable: true,\r\n    notificationEnable: true,\r\n    profileEnable: true,\r\n    settingsEnable: true,\r\n    activeClientCache: true,\r\n    clientList: [{\r\n      text: 'Client 1',\r\n      value: 'CLIENT_1',\r\n      selected: false,\r\n      subClientList: [\r\n        {text: 'Sub Client 1', value: 'SUB_CLIENT_1', checked: false},\r\n        {text: 'Sub Client 2', value: 'SUB_CLIENT_2', checked: false},\r\n        {text: 'Sub Client 3', value: 'SUB_CLIENT_3', checked: false}\r\n      ]\r\n    }, {\r\n      text: 'Client 2',\r\n      value: 'CLIENT_2',\r\n      selected: true,\r\n      subClientList: [\r\n        {text: 'Sub Client 1', value: 'SUB_CLIENT_1', checked: true},\r\n        {text: 'Sub Client 2', value: 'SUB_CLIENT_2', checked: false}\r\n      ]\r\n    }, {\r\n      text: 'Client 3',\r\n      value: 'CLIENT_3',\r\n      selected: false\r\n    }],\r\n    profileContent: '<div>profile content</div>',\r\n    clientConfigurationEnable: true,\r\n    applicationConfigurationEnable: true,\r\n  };\r\n  @Output() searchInputEvent = new EventEmitter<string>();\r\n  @Output() client = new EventEmitter<any>();\r\n  @Output() subClient = new EventEmitter<any>();\r\n\r\n  searchInput = \"\";\r\n  private prev: any;\r\n  selected: any = 'sgh-default-theme';\r\n  private wasInside = false;\r\n  selectedClient;\r\n  previousClient;\r\n\r\n  @ViewChild('clientMenuTrigger') clientMenuTrigger: MatMenuTrigger;\r\n\r\n\r\n  @HostListener('click')\r\n  clickInside() {\r\n    this.wasInside = true;\r\n  }\r\n\r\n  @HostListener('document:click')\r\n  clickOut() {\r\n    if (!this.wasInside) {\r\n      this.toolbarData.profileView = false;\r\n      this.toolbarData.isThemeCollapsed = false;\r\n      this.toolbarData.isNotifNavCollapsed = false;\r\n    }\r\n    this.wasInside = false;\r\n  }\r\n\r\n  constructor(private dialog: MatDialog, private sghNavbarSvc: SghNavbarService) {\r\n\r\n  }\r\n\r\n\r\n  toggleSidebar(): boolean {\r\n    this.toggleSidebarEvent.emit(this.expanded);\r\n    return this.expanded;\r\n  }\r\n\r\n  toggleNotificationList() {\r\n    this.toolbarData.isNotifNavCollapsed = !this.toolbarData.isNotifNavCollapsed\r\n  }\r\n\r\n  clickProfile() {\r\n    this.toolbarData.profileView = !this.toolbarData.profileView\r\n  }\r\n\r\n  onSearchInput() {\r\n    this.searchInputEvent.emit(this.searchInput);\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    // initially set client and subclients\r\n    setTimeout(() => {\r\n      const clientList = this.toolbarData?.clientList ?? [];\r\n\r\n      const selectedClientIndex = clientList.findIndex(c => c.selected === true);\r\n\r\n      if (selectedClientIndex === -1) {\r\n        this.sghNavbarSvc.setClient(null);\r\n        this.sghNavbarSvc.setSubclient(null);\r\n        return;\r\n      }\r\n\r\n      const orgClient = clientList[selectedClientIndex];\r\n\r\n      const orgSubClient = orgClient?.subClientList?.find(c => c.checked === true) ?? null;\r\n\r\n      this.sghNavbarSvc.setClient(orgClient);\r\n      this.sghNavbarSvc.setSubclient(orgSubClient);\r\n      this.selectedClient = orgClient;\r\n\r\n    },100)\r\n  }\r\n\r\n  setClass(selected: any) {\r\n    this.selected = selected;\r\n    window.document.body.classList.remove(this.prev);\r\n    window.document.body.classList.add(selected);\r\n    this.prev = selected;\r\n  }\r\n\r\n  protected readonly event = event;\r\n  selectedTheme: string = ''; // To store the selected radio button value\r\n  searchText: any;\r\n\r\n  onRadioClick(themeValue: string) {\r\n    this.selected = themeValue;\r\n    this.setClass(themeValue);\r\n  }\r\n\r\n  toggleSelect(event, clientItem: ClientListItem, index: number) {\r\n    this.previousClient = this.selectedClient;\r\n    // event on client selection\r\n    // at least one subclient should exist\r\n    if (clientItem.subClientList && clientItem.subClientList.length > 0) { // if sub clients exist open sub client dialog\r\n      const subClientDialogRef = this.dialog.open(SubClientDialogComponent, {\r\n        data: {\r\n          client: clientItem\r\n        },\r\n        minWidth: 400,\r\n        disableClose: true\r\n      });\r\n      // select first item of each subclient\r\n\r\n      subClientDialogRef.afterClosed().subscribe((event) => {\r\n        if (!event?.data?.cancelled) {\r\n          this.selectedClient = clientItem;\r\n          // unselect current selected client\r\n          this.unselectClientItems();\r\n          // select current client\r\n          clientItem.selected = true;\r\n          this.sghNavbarSvc.setClient(clientItem);\r\n          // this.sghNavbarSvc.setClientIndexCache(index,this.toolbarData?.activeClientCache);\r\n          this.clientMenuTrigger.focus();\r\n          this.sghNavbarSvc.setSubclient(event?.data?.selectedSubClient);\r\n          // this.sghNavbarSvc.setSubClientIndexCache(clientItem?.subClientList?.indexOf(event?.data?.selectedSubClient) ?? 0, this.toolbarData?.activeClientCache)\r\n\r\n          // set the selected subclient item as checked, search by name comparison\r\n          let selectedObj = clientItem?.subClientList?.find((scItem) => scItem.text == event?.data?.selectedSubClient?.text);\r\n          if (selectedObj) {\r\n            selectedObj.checked = true;\r\n          }\r\n\r\n          if(this.previousClient.text !== this.selectedClient.text){\r\n            this.previousClient?.subClientList?.forEach((subClient) => {\r\n              subClient.checked = false;\r\n            });\r\n          }\r\n        }\r\n\r\n      });\r\n    }\r\n  }\r\n\r\n  initSelectedSubClient(client: ClientListItem) {\r\n    client.subClientList?.forEach((subclient: SubClientListItem,index) => {\r\n      if(this.sghNavbarSvc.getSubClientIndexCache()==index) {\r\n        subclient.checked = true;\r\n        if (client.selected) { // set the first subclient of the first client as selected\r\n          this.sghNavbarSvc.setSubclient(subclient);\r\n          this.sghNavbarSvc.setSubClientIndexCache(index, this.toolbarData.activeClientCache);\r\n        }\r\n      } else { subclient.checked = false; }\r\n    });\r\n  }\r\n\r\n  unselectClientItems() {\r\n    this.toolbarData.clientList?.forEach((client: ClientListItem) => {\r\n      if (client.selected) {\r\n        client.selected = false;\r\n      }\r\n    });\r\n  }\r\n\r\n  selectFirstSubclient() {\r\n    this.toolbarData.clientList?.forEach((client) => {\r\n      if(client !== this.selectedClient) {\r\n        client.subClientList?.forEach((scItem,index) => {\r\n          index == 0 ? scItem.checked = true: scItem.checked = false;\r\n        });\r\n      }\r\n    })\r\n  }\r\n}\r\n","<nav class=\"toolbar-main-wrapper\" [style.background-color]=\"toolbarData.bgColor\" id=\"toolBarWrapper\">\r\n  <div class=\"logo-wrapper\">\r\n    <img class=\"logo\" [src]=\"toolbarData.img\"/>\r\n  </div>\r\n  <div>\r\n    <button class=\"toggle-button\" (click)=\"toggleSidebar()\">\r\n      <i class=\"fa fa-lg fa-bars\"></i>\r\n    </button>\r\n  </div>\r\n  <div class=\"search\">\r\n    <div class=\"form\" *ngIf=\"toolbarData.searchEnable\">\r\n      <input type=\"text\" name=\"text\" autocomplete=\"off\" required/>\r\n      <label class=\"label-name\">\r\n    <span class=\"content-name\">\r\n      Search\r\n    </span>\r\n      </label>\r\n      <button class=\"search-wrapper\">\r\n        <i class=\"fa fa-search\"></i>\r\n      </button>\r\n    </div>\r\n  </div>\r\n  <div *ngIf=\"toolbarData.notificationEnable\" class=\"icon\" id=\"bell\" (click)=\"toggleNotificationList()\">\r\n    <i class=\"fa fa-bell\"></i>\r\n  </div>\r\n  <div *ngIf=\"toolbarData.profileEnable\" class=\"icon\" id=\"bell3\" (click)=\"clickProfile()\">\r\n    <i class=\"fa fa-user\"></i>\r\n  </div>\r\n  <div *ngIf=\"toolbarData.settingsEnable\" class=\"icon\" id=\"bell2\" [matMenuTriggerFor]=\"settingsMenu\">\r\n    <i class=\"fa fa-gear\"></i>\r\n  </div>\r\n</nav>\r\n\r\n<div *ngIf=\"toolbarData.profileView\" class=\"notifications\">\r\n  <div class=\"notifications-list-wrapper profile-list-wrapper\">\r\n    <div class=\"notifications-list\">\r\n      <div class=\"notifications-list-item\">\r\n        <div [innerHTML]=\"toolbarData.profileContent\"></div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<!--Settings related menus start-->\r\n<mat-menu #settingsMenu=\"matMenu\" xPosition=\"before\">\r\n  <button mat-menu-item [matMenuTriggerFor]=\"appConfig\" *ngIf=\"toolbarData.applicationConfigurationEnable\">Application Settings</button>\r\n  <button mat-menu-item [matMenuTriggerFor]=\"clientConfig\" *ngIf=\"toolbarData.clientConfigurationEnable\" #clientMenuTrigger>Client Settings</button>\r\n</mat-menu>\r\n<mat-menu #appConfig=\"matMenu\" xPosition=\"after\">\r\n  <div *ngFor=\"let themeoption of toolbarData.themeOptions\">\r\n    <button mat-menu-item class=\"radio\" (click)=\"onRadioClick(themeoption.value)\">\r\n      <input value=\"{{themeoption.value}}\" name=\"radio\" type=\"radio\" checked [ngModel]=\"selected\"\r\n             (ngModelChange)=\"setClass($event)\">\r\n      <span>{{themeoption.name}}</span>\r\n    </button>\r\n  </div>\r\n</mat-menu>\r\n<mat-menu #clientConfig=\"matMenu\" xPosition=\"after\">\r\n  <div style=\"width: 250px\" class=\"client-menu-wrapper\">\r\n    <div class=\"container-fluid\">\r\n      <div class=\"row\">\r\n        <div class=\"col-sm-12\" (click)=\"$event.stopPropagation();\">\r\n          <input type=\"text\" class=\"search-input\" placeholder=\"Search Client\" [(ngModel)]=\"searchText\"/>\r\n        </div>\r\n        <div class=\"col-sm-12\">\r\n          <div class=\"mt-2 list-item-container\">\r\n            <div class=\"list-item text-truncate\" *ngFor=\"let item of toolbarData.clientList | search : searchText;let i = index\"\r\n                 [ngClass]=\"{'client-selected': item.selected}\"\r\n                 (click)=\"toggleSelect($event, item, i);\" mat-ripple>{{item.text}}</div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</mat-menu>\r\n\r\n<!--Settings related menus end-->\r\n\r\n<app-noftification-list *ngIf=\"toolbarData.isNotifNavCollapsed\"></app-noftification-list>\r\n"]}