ngx-histaff-alpha 2.8.2 → 2.8.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/app/libraries/core-form/core-form/core-form.component.mjs +28 -26
- package/esm2022/lib/app/libraries/navigator/navigator/item.component.mjs +5 -3
- package/esm2022/lib/app/libraries/navigator/navigator/navigator.component.mjs +15 -6
- package/esm2022/lib/app/services/navigator.service.mjs +3 -1
- package/esm2022/lib/app/services/random-avatar.service.mjs +4 -1
- package/fesm2022/ngx-histaff-alpha.mjs +50 -32
- package/fesm2022/ngx-histaff-alpha.mjs.map +1 -1
- package/lib/app/libraries/navigator/navigator/navigator.component.d.ts +3 -2
- package/lib/app/services/navigator.service.d.ts +2 -0
- package/lib/app/services/random-avatar.service.d.ts +1 -0
- package/package.json +1 -1
|
@@ -81,34 +81,36 @@ export class CoreFormComponent {
|
|
|
81
81
|
}
|
|
82
82
|
}
|
|
83
83
|
ngOnInit() {
|
|
84
|
+
/*
|
|
84
85
|
if (this.appConfigService.APP_TYPE === "WEBAPP") {
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
else {
|
|
92
|
-
this.buttonItems = [
|
|
93
|
-
EnumCoreButtonVNSCode.NONE_HEADER_CANCEL,
|
|
94
|
-
];
|
|
95
|
-
}
|
|
86
|
+
*/
|
|
87
|
+
if (!this.disableSaveButton) {
|
|
88
|
+
this.buttonItems = [
|
|
89
|
+
EnumCoreButtonVNSCode.NONE_HEADER_SAVE,
|
|
90
|
+
EnumCoreButtonVNSCode.NONE_HEADER_CANCEL,
|
|
91
|
+
];
|
|
96
92
|
}
|
|
97
|
-
else
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
93
|
+
else {
|
|
94
|
+
this.buttonItems = [
|
|
95
|
+
EnumCoreButtonVNSCode.NONE_HEADER_CANCEL,
|
|
96
|
+
];
|
|
97
|
+
}
|
|
98
|
+
/*
|
|
99
|
+
} else if (this.appConfigService.APP_TYPE === "PORTAL") {
|
|
100
|
+
if (!this.disableSaveButton) {
|
|
101
|
+
this.buttonItems = [
|
|
102
|
+
EnumCoreButtonVNSCode.SEND,
|
|
103
|
+
EnumCoreButtonVNSCode.CANCEL,
|
|
104
|
+
EnumCoreButtonVNSCode.SAVE,
|
|
105
|
+
]
|
|
106
|
+
} else {
|
|
107
|
+
this.buttonItems = [
|
|
108
|
+
EnumCoreButtonVNSCode.SEND,
|
|
109
|
+
EnumCoreButtonVNSCode.CANCEL,
|
|
110
|
+
]
|
|
111
|
+
}
|
|
111
112
|
}
|
|
113
|
+
*/
|
|
112
114
|
if (!!this.customFormButtonItems) {
|
|
113
115
|
this.buttonItems = this.customFormButtonItems;
|
|
114
116
|
}
|
|
@@ -256,4 +258,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
256
258
|
type: ViewChild,
|
|
257
259
|
args: ['formRef']
|
|
258
260
|
}] } });
|
|
259
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-form.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-form/core-form/core-form.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-form/core-form/core-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChanges, TemplateRef, ViewChild, isDevMode, } from '@angular/core';\r\nimport { AbstractControl, FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { ICoreFormSection } from './enum-interfaces';\r\nimport { CoreControlService } from '../core-control.service';\r\nimport { BehaviorSubject, Subscription } from 'rxjs';\r\nimport { AlertService } from '../../alert/alert.service';\r\nimport { EnumCorePageEditMode } from '../../core-page-edit/EnumCorePageEditMode';\r\nimport { CoreFormService } from '../core-form.service';\r\nimport { ICoreButtonVNS } from '../../core-button-group-vns/core-button-group-vns/ICoreButtonVNS';\r\nimport { EnumCoreButtonVNSCode } from '../../core-button-group-vns/core-button-group-vns/EnumCoreButtonVNSCode';\r\nimport { EnumTranslateKey } from \"alpha-global-constants\";\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { noneAutoClosedAlertOptions } from '../../../constants/alertOptions';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CoreControlComponent } from '../../core-control/core-control/core-control.component';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\nimport { CoreButtonGroupVnsComponent } from '../../core-button-group-vns/core-button-group-vns/core-button-group-vns.component';\r\nimport { AppConfigService } from '../../../services/app-config.service';\r\n\r\nexport interface IDynamicFormEmitOnFormCreated {\r\n  formName: string;\r\n  formGroup: FormGroup;\r\n}\r\n\r\n@Component({\r\n  selector: 'core-form',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    CoreControlComponent,\r\n    TranslatePipe,\r\n    CoreButtonGroupVnsComponent\r\n  ],\r\n  templateUrl: './core-form.component.html',\r\n  styleUrls: ['./core-form.component.scss'],\r\n})\r\nexport class CoreFormComponent implements OnChanges, OnInit, AfterViewInit, OnDestroy {\r\n\r\n  @Input() formName!: string;\r\n  @Input() submitText!: EnumTranslateKey;\r\n  @Input() leftInputSections!: ICoreFormSection[];\r\n  @Input() leftInputSectionsFlexSize!: number;\r\n  @Input() inputSections!: ICoreFormSection[];\r\n  @Input() mode$!: BehaviorSubject<EnumCorePageEditMode>;\r\n  @Input() bottomTemplateRef!: TemplateRef<any>;\r\n  @Input() customFormButtonItems!: EnumCoreButtonVNSCode[]; // Optional\r\n  @Input() showCaptionButton!: boolean;\r\n  @Input() disableSaveButton!: boolean;\r\n  @Input() checkError$ = new BehaviorSubject<boolean>(false);\r\n\r\n  @Output() onFormCreated = new EventEmitter<IDynamicFormEmitOnFormCreated>();\r\n  @Output() onFormRefCreated = new EventEmitter<ElementRef<any>>();\r\n  @Output() onSubmit = new EventEmitter();\r\n  @Output() onSave = new EventEmitter();\r\n  @Output() onCancal = new EventEmitter();\r\n  @Output() buttonClick = new EventEmitter<ICoreButtonVNS>();\r\n\r\n\r\n  @ViewChild('formRef') formRef!: ElementRef;\r\n\r\n  buttonItems!: EnumCoreButtonVNSCode[];\r\n\r\n  form!: FormGroup;\r\n  sections!: ICoreFormSection[];\r\n  lang!: string;\r\n  subscriptions: Subscription[] = [];\r\n\r\n  payLoad = '';\r\n  validatorOverview: any;\r\n  isDevMode!: boolean;\r\n  isUpdateMode!: boolean;\r\n\r\n  constructor(\r\n    private coreControlService: CoreControlService,\r\n    private multiLanguageService: MultiLanguageService,\r\n    private alertService: AlertService,\r\n    private coreFormService: CoreFormService,\r\n    private appConfigService: AppConfigService\r\n  ) {\r\n    this.isDevMode = isDevMode();\r\n  }\r\n\r\n  private updateSections(newSections: ICoreFormSection[]): void {\r\n\r\n    this.sections.map((section, sectionIndex) => {\r\n      const newSection = newSections[sectionIndex];\r\n      section.rows.map((row, rowIndex) => {\r\n        const newRow = newSection.rows[rowIndex];\r\n        row.map((control, controlIndex) => {\r\n          const newControl = newRow[controlIndex];\r\n\r\n          /* THE ONLY PROP TO BE UDATED IS 'hidden', THE OTHERS SHOULD BE MANIPULATED THROUGH this.form.get(YOUR_CONTROL_NAME)... */\r\n          control.hidden = newControl?.hidden;\r\n          /************************************************************************************************************************/\r\n        });\r\n      });\r\n\r\n      /* #region Oct the 11th 2023 */\r\n      /* Some sections was posibly have renderOff=true from previous state and their controls must be created/remove */\r\n      /*\r\n      BUT THIS TASK IS HARD SO FAR\r\n      */\r\n      /* #endregion Oct the 11th 2023 */\r\n\r\n    });\r\n\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['inputSections']) {\r\n      let newSections: ICoreFormSection[] =\r\n        changes['inputSections'].currentValue;\r\n\r\n      if (!!!this.form) {\r\n        this.sections = newSections;\r\n\r\n        let leftGroup;\r\n        let form: FormGroup<any>;\r\n\r\n        const mainGroup = this.coreControlService.toGroup(this.sections);\r\n\r\n        if (!!this.leftInputSections) {\r\n          leftGroup = this.coreControlService.toGroup(this.leftInputSections);\r\n          form = new FormGroup({ ...leftGroup, ...mainGroup });\r\n        } else {\r\n          form = new FormGroup(mainGroup);\r\n        }\r\n\r\n        this.form = form;\r\n\r\n      } else {\r\n        this.updateSections(newSections);\r\n      }\r\n\r\n      this.onFormCreated.emit({\r\n        formName: this.formName,\r\n        formGroup: this.form,\r\n      });\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n\r\n    if (this.appConfigService.APP_TYPE === \"WEBAPP\") {\r\n      if (!this.disableSaveButton) {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.NONE_HEADER_SAVE,\r\n          EnumCoreButtonVNSCode.NONE_HEADER_CANCEL,\r\n        ]\r\n      } else {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.NONE_HEADER_CANCEL,\r\n        ]\r\n      }\r\n    } else if (this.appConfigService.APP_TYPE === \"PORTAL\") {\r\n      if (!this.disableSaveButton) {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.SEND,\r\n          EnumCoreButtonVNSCode.CANCEL,\r\n          EnumCoreButtonVNSCode.SAVE,\r\n        ]\r\n      } else {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.SEND,\r\n          EnumCoreButtonVNSCode.CANCEL,\r\n        ]\r\n      }\r\n    }\r\n\r\n    if (!!this.customFormButtonItems) {\r\n      this.buttonItems = this.customFormButtonItems;\r\n    }\r\n\r\n    this.subscriptions.push(\r\n      this.mode$.subscribe(\r\n        (x) => (this.isUpdateMode = x === EnumCorePageEditMode.UPDATE)\r\n      )\r\n    );\r\n\r\n    console.log(this.mode$);\r\n\r\n    /* START: Check if id field is available */\r\n    if (!!!this.form.get('id') && isDevMode()) {\r\n      this.alertService.error(\r\n        `\r\n            Control \"id\" is mandatory. Please define one in your bussiness component. You can assign its \"hidden\" property to true if needed.\r\n          `,\r\n        noneAutoClosedAlertOptions\r\n      );\r\n    }\r\n    /* END: Check if id field is available */\r\n\r\n    if (isDevMode()) {\r\n      /* START: Check if each field is unique */\r\n\r\n      const fields = this.coreFormService.getAllFormBaseControlNames(\r\n        this.sections\r\n      );\r\n\r\n      fields.reduce((p, c) => {\r\n        if (c === '') {\r\n          this.alertService.error(\r\n            `Form control name must be definded, '${c}' is invalid form control name!!!`,\r\n            noneAutoClosedAlertOptions\r\n          );\r\n        } else {\r\n          if (p === c) {\r\n            this.alertService.error(\r\n              `Duplicate form control name: '${c}'. Consider to predefine one ONLY!!!.`,\r\n              noneAutoClosedAlertOptions\r\n            );\r\n          }\r\n        }\r\n        return c;\r\n      });\r\n      /* END: Check if each field is unique */\r\n    }\r\n\r\n    this.subscriptions.push(\r\n      this.multiLanguageService.lang$.subscribe((x) => (this.lang = x))\r\n    );\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.onFormRefCreated.emit(this.formRef);\r\n  }\r\n\r\n  onFormSubmit() {\r\n    this.checkError$.next(true);\r\n    if (!!this.form.valid) {\r\n      this.payLoad = JSON.stringify(this.form?.getRawValue(), null, 2);\r\n      this.onSubmit.emit(this.form?.getRawValue());\r\n    }\r\n  }\r\n\r\n  onFormSave() {\r\n    this.checkError$.next(true);\r\n    if (!!this.form.valid) {\r\n      this.payLoad = JSON.stringify(this.form?.getRawValue(), null, 2);\r\n      this.onSave.emit(this.form?.getRawValue());\r\n    }\r\n    setTimeout(() => this.checkError$.next(false), 3000);\r\n  }\r\n\r\n  onCancelLocal() {\r\n    this.onCancal.emit(null);\r\n  }\r\n\r\n  updatePayload(): void {\r\n    this.payLoad = JSON.stringify(this.form?.getRawValue(), null, 2);\r\n  }\r\n\r\n  updateValidorOverview(): void {\r\n    const result: { key: string; errors: any[] }[] = [];\r\n    Object.keys(this.form.controls).forEach((key) => {\r\n      const control: AbstractControl = this.form.get(key)!;\r\n      const errors: any[] = [];\r\n      if (!!control.invalid) {\r\n        Object.keys(control.errors!).forEach((key) => {\r\n          errors.push(key);\r\n        });\r\n      }\r\n      result.push({\r\n        key,\r\n        errors,\r\n      });\r\n    });\r\n    this.validatorOverview = JSON.stringify(result, null, 2);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.map((x) => x?.unsubscribe());\r\n  }\r\n\r\n  onButtonClick(e: ICoreButtonVNS): void {\r\n\r\n    switch (e.code) {\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_CANCEL:\r\n      case EnumCoreButtonVNSCode.CANCEL:\r\n        this.onCancelLocal();\r\n        break;\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_SAVE:\r\n      case EnumCoreButtonVNSCode.SEND:\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_DELETE:\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_LIQUIDATE_CONTRACT:\r\n      case EnumCoreButtonVNSCode.ONFORMDELETE:\r\n      case EnumCoreButtonVNSCode.SAVE_PASSWORD:\r\n        this.onFormSubmit();\r\n        break;\r\n      case EnumCoreButtonVNSCode.SAVE:\r\n        this.onFormSave();\r\n        break;\r\n      default:\r\n        break;\r\n    }\r\n    this.buttonClick.emit(e);\r\n  }\r\n}\r\n","<div class=\"core-form-container\" *ngIf=\"!!form\">\r\n\r\n    <form #formRef (ngSubmit)=\"onFormSubmit()\" [formGroup]=\"form\" autocomplete=\"off\">\r\n\r\n        <div class=\"row\">\r\n\r\n            <div [class]=\"'col-md-' + (leftInputSectionsFlexSize || 0)\" *ngIf=\"!!leftInputSections\">\r\n\r\n                <div *ngFor=\"let section of leftInputSections\" class=\"section\"\r\n                    [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!section.hidden\">\r\n\r\n                    <div class=\"section-header-label\" *ngIf=\"section.caption\">\r\n                        <div class=\"section-img-wrapper\">\r\n                            <div class=\"section-img\"></div>\r\n                        </div>\r\n                        <div class=\"section-caption\">{{ section.caption | translate: lang }}</div>\r\n                    </div>\r\n\r\n                    <div *ngFor=\"let row of section.rows\" class=\"row mb15\">\r\n                        <div *ngFor=\"let col of row\" [class]=\"'col-md-' + col.flexSize\"\r\n                            [class.grid-buffer]=\"col.controlType==='GRIDBUFFER'\"\r\n                            [class.button-control]=\"col.controlType==='BUTTON'\">\r\n                            <core-control [control]=\"col\" [form]=\"form\" [checkError$]=\"checkError$\"></core-control>\r\n                        </div>\r\n                    </div>\r\n\r\n                </div>\r\n\r\n            </div>\r\n\r\n            <div [class]=\"'col-md-' + (12 - (leftInputSectionsFlexSize || 0))\">\r\n\r\n                <div *ngFor=\"let section of sections\" class=\"section\"\r\n                    [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!section.hidden\">\r\n\r\n                    <div class=\"section-header-label\" *ngIf=\"section.caption\">\r\n                        <div class=\"section-img-wrapper\">\r\n                            <div class=\"section-img\"></div>\r\n                        </div>\r\n                        <div class=\"section-caption\">{{ section.caption | translate: lang }}</div>\r\n                    </div>\r\n\r\n                    <div *ngFor=\"let row of section.rows\" class=\"row mb15\">\r\n                        <div *ngFor=\"let col of row\" [class]=\"'col-md-' + col.flexSize\"\r\n                            [class.grid-buffer]=\"col.controlType==='GRIDBUFFER'\"\r\n                            [class.button-control]=\"col.controlType==='BUTTON'\">\r\n                            <core-control [control]=\"col\" [form]=\"form\" [checkError$]=\"checkError$\"></core-control>\r\n                        </div>\r\n                    </div>\r\n\r\n                </div>\r\n\r\n            </div>\r\n\r\n        </div>\r\n\r\n\r\n        <ng-container *ngIf=\"!!bottomTemplateRef\">\r\n            <ng-container *ngTemplateOutlet=\"bottomTemplateRef\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <div class=\"h10\"></div>\r\n\r\n        <div class=\"form-row\">\r\n\r\n            <core-button-group-vns [showCaption]=\"showCaptionButton\" [forHeader]=\"false\" (buttonClick)=\"onButtonClick($event)\"\r\n                [shownItems]=\"buttonItems\" class=\"buttonGroupCustom\"></core-button-group-vns>\r\n        </div>\r\n        <div class=\"form-row\" *ngIf=\"isDevMode\">\r\n            <button type=\"button\" class=\"btn btn-secondary text\" (click)=\"updatePayload()\">Show\r\n                values</button>\r\n            <button type=\"button\" class=\"btn btn-secondary text\" (click)=\"updateValidorOverview()\">Show\r\n                validators</button>\r\n        </div>\r\n    </form>\r\n\r\n    <div *ngIf=\"!!payLoad && isDevMode\" class=\"form-row payload-preview\">\r\n        <strong>Current values</strong><br>{{payLoad}}\r\n    </div>\r\n    <div *ngIf=\"!!validatorOverview && isDevMode\" class=\"form-row payload-preview\">\r\n        <strong>Current errors</strong><br>{{validatorOverview}}\r\n    </div>\r\n\r\n</div>"]}
|
|
261
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-form.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-form/core-form/core-form.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-form/core-form/core-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChanges, TemplateRef, ViewChild, isDevMode, } from '@angular/core';\r\nimport { AbstractControl, FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { ICoreFormSection } from './enum-interfaces';\r\nimport { CoreControlService } from '../core-control.service';\r\nimport { BehaviorSubject, Subscription } from 'rxjs';\r\nimport { AlertService } from '../../alert/alert.service';\r\nimport { EnumCorePageEditMode } from '../../core-page-edit/EnumCorePageEditMode';\r\nimport { CoreFormService } from '../core-form.service';\r\nimport { ICoreButtonVNS } from '../../core-button-group-vns/core-button-group-vns/ICoreButtonVNS';\r\nimport { EnumCoreButtonVNSCode } from '../../core-button-group-vns/core-button-group-vns/EnumCoreButtonVNSCode';\r\nimport { EnumTranslateKey } from \"alpha-global-constants\";\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { noneAutoClosedAlertOptions } from '../../../constants/alertOptions';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CoreControlComponent } from '../../core-control/core-control/core-control.component';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\nimport { CoreButtonGroupVnsComponent } from '../../core-button-group-vns/core-button-group-vns/core-button-group-vns.component';\r\nimport { AppConfigService } from '../../../services/app-config.service';\r\n\r\nexport interface IDynamicFormEmitOnFormCreated {\r\n  formName: string;\r\n  formGroup: FormGroup;\r\n}\r\n\r\n@Component({\r\n  selector: 'core-form',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    CoreControlComponent,\r\n    TranslatePipe,\r\n    CoreButtonGroupVnsComponent\r\n  ],\r\n  templateUrl: './core-form.component.html',\r\n  styleUrls: ['./core-form.component.scss'],\r\n})\r\nexport class CoreFormComponent implements OnChanges, OnInit, AfterViewInit, OnDestroy {\r\n\r\n  @Input() formName!: string;\r\n  @Input() submitText!: EnumTranslateKey;\r\n  @Input() leftInputSections!: ICoreFormSection[];\r\n  @Input() leftInputSectionsFlexSize!: number;\r\n  @Input() inputSections!: ICoreFormSection[];\r\n  @Input() mode$!: BehaviorSubject<EnumCorePageEditMode>;\r\n  @Input() bottomTemplateRef!: TemplateRef<any>;\r\n  @Input() customFormButtonItems!: EnumCoreButtonVNSCode[]; // Optional\r\n  @Input() showCaptionButton!: boolean;\r\n  @Input() disableSaveButton!: boolean;\r\n  @Input() checkError$ = new BehaviorSubject<boolean>(false);\r\n\r\n  @Output() onFormCreated = new EventEmitter<IDynamicFormEmitOnFormCreated>();\r\n  @Output() onFormRefCreated = new EventEmitter<ElementRef<any>>();\r\n  @Output() onSubmit = new EventEmitter();\r\n  @Output() onSave = new EventEmitter();\r\n  @Output() onCancal = new EventEmitter();\r\n  @Output() buttonClick = new EventEmitter<ICoreButtonVNS>();\r\n\r\n\r\n  @ViewChild('formRef') formRef!: ElementRef;\r\n\r\n  buttonItems!: EnumCoreButtonVNSCode[];\r\n\r\n  form!: FormGroup;\r\n  sections!: ICoreFormSection[];\r\n  lang!: string;\r\n  subscriptions: Subscription[] = [];\r\n\r\n  payLoad = '';\r\n  validatorOverview: any;\r\n  isDevMode!: boolean;\r\n  isUpdateMode!: boolean;\r\n\r\n  constructor(\r\n    private coreControlService: CoreControlService,\r\n    private multiLanguageService: MultiLanguageService,\r\n    private alertService: AlertService,\r\n    private coreFormService: CoreFormService,\r\n    private appConfigService: AppConfigService\r\n  ) {\r\n    this.isDevMode = isDevMode();\r\n  }\r\n\r\n  private updateSections(newSections: ICoreFormSection[]): void {\r\n\r\n    this.sections.map((section, sectionIndex) => {\r\n      const newSection = newSections[sectionIndex];\r\n      section.rows.map((row, rowIndex) => {\r\n        const newRow = newSection.rows[rowIndex];\r\n        row.map((control, controlIndex) => {\r\n          const newControl = newRow[controlIndex];\r\n\r\n          /* THE ONLY PROP TO BE UDATED IS 'hidden', THE OTHERS SHOULD BE MANIPULATED THROUGH this.form.get(YOUR_CONTROL_NAME)... */\r\n          control.hidden = newControl?.hidden;\r\n          /************************************************************************************************************************/\r\n        });\r\n      });\r\n\r\n      /* #region Oct the 11th 2023 */\r\n      /* Some sections was posibly have renderOff=true from previous state and their controls must be created/remove */\r\n      /*\r\n      BUT THIS TASK IS HARD SO FAR\r\n      */\r\n      /* #endregion Oct the 11th 2023 */\r\n\r\n    });\r\n\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['inputSections']) {\r\n      let newSections: ICoreFormSection[] =\r\n        changes['inputSections'].currentValue;\r\n\r\n      if (!!!this.form) {\r\n        this.sections = newSections;\r\n\r\n        let leftGroup;\r\n        let form: FormGroup<any>;\r\n\r\n        const mainGroup = this.coreControlService.toGroup(this.sections);\r\n\r\n        if (!!this.leftInputSections) {\r\n          leftGroup = this.coreControlService.toGroup(this.leftInputSections);\r\n          form = new FormGroup({ ...leftGroup, ...mainGroup });\r\n        } else {\r\n          form = new FormGroup(mainGroup);\r\n        }\r\n\r\n        this.form = form;\r\n\r\n      } else {\r\n        this.updateSections(newSections);\r\n      }\r\n\r\n      this.onFormCreated.emit({\r\n        formName: this.formName,\r\n        formGroup: this.form,\r\n      });\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n\r\n    /*\r\n    if (this.appConfigService.APP_TYPE === \"WEBAPP\") {\r\n    */\r\n\r\n      if (!this.disableSaveButton) {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.NONE_HEADER_SAVE,\r\n          EnumCoreButtonVNSCode.NONE_HEADER_CANCEL,\r\n        ]\r\n      } else {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.NONE_HEADER_CANCEL,\r\n        ]\r\n      }\r\n\r\n    /*\r\n    } else if (this.appConfigService.APP_TYPE === \"PORTAL\") {\r\n      if (!this.disableSaveButton) {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.SEND,\r\n          EnumCoreButtonVNSCode.CANCEL,\r\n          EnumCoreButtonVNSCode.SAVE,\r\n        ]\r\n      } else {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.SEND,\r\n          EnumCoreButtonVNSCode.CANCEL,\r\n        ]\r\n      }\r\n    }\r\n    */\r\n\r\n    if (!!this.customFormButtonItems) {\r\n      this.buttonItems = this.customFormButtonItems;\r\n    }\r\n\r\n    this.subscriptions.push(\r\n      this.mode$.subscribe(\r\n        (x) => (this.isUpdateMode = x === EnumCorePageEditMode.UPDATE)\r\n      )\r\n    );\r\n\r\n    console.log(this.mode$);\r\n\r\n    /* START: Check if id field is available */\r\n    if (!!!this.form.get('id') && isDevMode()) {\r\n      this.alertService.error(\r\n        `\r\n            Control \"id\" is mandatory. Please define one in your bussiness component. You can assign its \"hidden\" property to true if needed.\r\n          `,\r\n        noneAutoClosedAlertOptions\r\n      );\r\n    }\r\n    /* END: Check if id field is available */\r\n\r\n    if (isDevMode()) {\r\n      /* START: Check if each field is unique */\r\n\r\n      const fields = this.coreFormService.getAllFormBaseControlNames(\r\n        this.sections\r\n      );\r\n\r\n      fields.reduce((p, c) => {\r\n        if (c === '') {\r\n          this.alertService.error(\r\n            `Form control name must be definded, '${c}' is invalid form control name!!!`,\r\n            noneAutoClosedAlertOptions\r\n          );\r\n        } else {\r\n          if (p === c) {\r\n            this.alertService.error(\r\n              `Duplicate form control name: '${c}'. Consider to predefine one ONLY!!!.`,\r\n              noneAutoClosedAlertOptions\r\n            );\r\n          }\r\n        }\r\n        return c;\r\n      });\r\n      /* END: Check if each field is unique */\r\n    }\r\n\r\n    this.subscriptions.push(\r\n      this.multiLanguageService.lang$.subscribe((x) => (this.lang = x))\r\n    );\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.onFormRefCreated.emit(this.formRef);\r\n  }\r\n\r\n  onFormSubmit() {\r\n    this.checkError$.next(true);\r\n    if (!!this.form.valid) {\r\n      this.payLoad = JSON.stringify(this.form?.getRawValue(), null, 2);\r\n      this.onSubmit.emit(this.form?.getRawValue());\r\n    }\r\n  }\r\n\r\n  onFormSave() {\r\n    this.checkError$.next(true);\r\n    if (!!this.form.valid) {\r\n      this.payLoad = JSON.stringify(this.form?.getRawValue(), null, 2);\r\n      this.onSave.emit(this.form?.getRawValue());\r\n    }\r\n    setTimeout(() => this.checkError$.next(false), 3000);\r\n  }\r\n\r\n  onCancelLocal() {\r\n    this.onCancal.emit(null);\r\n  }\r\n\r\n  updatePayload(): void {\r\n    this.payLoad = JSON.stringify(this.form?.getRawValue(), null, 2);\r\n  }\r\n\r\n  updateValidorOverview(): void {\r\n    const result: { key: string; errors: any[] }[] = [];\r\n    Object.keys(this.form.controls).forEach((key) => {\r\n      const control: AbstractControl = this.form.get(key)!;\r\n      const errors: any[] = [];\r\n      if (!!control.invalid) {\r\n        Object.keys(control.errors!).forEach((key) => {\r\n          errors.push(key);\r\n        });\r\n      }\r\n      result.push({\r\n        key,\r\n        errors,\r\n      });\r\n    });\r\n    this.validatorOverview = JSON.stringify(result, null, 2);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.map((x) => x?.unsubscribe());\r\n  }\r\n\r\n  onButtonClick(e: ICoreButtonVNS): void {\r\n\r\n    switch (e.code) {\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_CANCEL:\r\n      case EnumCoreButtonVNSCode.CANCEL:\r\n        this.onCancelLocal();\r\n        break;\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_SAVE:\r\n      case EnumCoreButtonVNSCode.SEND:\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_DELETE:\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_LIQUIDATE_CONTRACT:\r\n      case EnumCoreButtonVNSCode.ONFORMDELETE:\r\n      case EnumCoreButtonVNSCode.SAVE_PASSWORD:\r\n        this.onFormSubmit();\r\n        break;\r\n      case EnumCoreButtonVNSCode.SAVE:\r\n        this.onFormSave();\r\n        break;\r\n      default:\r\n        break;\r\n    }\r\n    this.buttonClick.emit(e);\r\n  }\r\n}\r\n","<div class=\"core-form-container\" *ngIf=\"!!form\">\r\n\r\n    <form #formRef (ngSubmit)=\"onFormSubmit()\" [formGroup]=\"form\" autocomplete=\"off\">\r\n\r\n        <div class=\"row\">\r\n\r\n            <div [class]=\"'col-md-' + (leftInputSectionsFlexSize || 0)\" *ngIf=\"!!leftInputSections\">\r\n\r\n                <div *ngFor=\"let section of leftInputSections\" class=\"section\"\r\n                    [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!section.hidden\">\r\n\r\n                    <div class=\"section-header-label\" *ngIf=\"section.caption\">\r\n                        <div class=\"section-img-wrapper\">\r\n                            <div class=\"section-img\"></div>\r\n                        </div>\r\n                        <div class=\"section-caption\">{{ section.caption | translate: lang }}</div>\r\n                    </div>\r\n\r\n                    <div *ngFor=\"let row of section.rows\" class=\"row mb15\">\r\n                        <div *ngFor=\"let col of row\" [class]=\"'col-md-' + col.flexSize\"\r\n                            [class.grid-buffer]=\"col.controlType==='GRIDBUFFER'\"\r\n                            [class.button-control]=\"col.controlType==='BUTTON'\">\r\n                            <core-control [control]=\"col\" [form]=\"form\" [checkError$]=\"checkError$\"></core-control>\r\n                        </div>\r\n                    </div>\r\n\r\n                </div>\r\n\r\n            </div>\r\n\r\n            <div [class]=\"'col-md-' + (12 - (leftInputSectionsFlexSize || 0))\">\r\n\r\n                <div *ngFor=\"let section of sections\" class=\"section\"\r\n                    [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!section.hidden\">\r\n\r\n                    <div class=\"section-header-label\" *ngIf=\"section.caption\">\r\n                        <div class=\"section-img-wrapper\">\r\n                            <div class=\"section-img\"></div>\r\n                        </div>\r\n                        <div class=\"section-caption\">{{ section.caption | translate: lang }}</div>\r\n                    </div>\r\n\r\n                    <div *ngFor=\"let row of section.rows\" class=\"row mb15\">\r\n                        <div *ngFor=\"let col of row\" [class]=\"'col-md-' + col.flexSize\"\r\n                            [class.grid-buffer]=\"col.controlType==='GRIDBUFFER'\"\r\n                            [class.button-control]=\"col.controlType==='BUTTON'\">\r\n                            <core-control [control]=\"col\" [form]=\"form\" [checkError$]=\"checkError$\"></core-control>\r\n                        </div>\r\n                    </div>\r\n\r\n                </div>\r\n\r\n            </div>\r\n\r\n        </div>\r\n\r\n\r\n        <ng-container *ngIf=\"!!bottomTemplateRef\">\r\n            <ng-container *ngTemplateOutlet=\"bottomTemplateRef\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <div class=\"h10\"></div>\r\n\r\n        <div class=\"form-row\">\r\n\r\n            <core-button-group-vns [showCaption]=\"showCaptionButton\" [forHeader]=\"false\" (buttonClick)=\"onButtonClick($event)\"\r\n                [shownItems]=\"buttonItems\" class=\"buttonGroupCustom\"></core-button-group-vns>\r\n        </div>\r\n        <div class=\"form-row\" *ngIf=\"isDevMode\">\r\n            <button type=\"button\" class=\"btn btn-secondary text\" (click)=\"updatePayload()\">Show\r\n                values</button>\r\n            <button type=\"button\" class=\"btn btn-secondary text\" (click)=\"updateValidorOverview()\">Show\r\n                validators</button>\r\n        </div>\r\n    </form>\r\n\r\n    <div *ngIf=\"!!payLoad && isDevMode\" class=\"form-row payload-preview\">\r\n        <strong>Current values</strong><br>{{payLoad}}\r\n    </div>\r\n    <div *ngIf=\"!!validatorOverview && isDevMode\" class=\"form-row payload-preview\">\r\n        <strong>Current errors</strong><br>{{validatorOverview}}\r\n    </div>\r\n\r\n</div>"]}
|
|
@@ -161,13 +161,15 @@ export class ItemComponent {
|
|
|
161
161
|
this.me.nativeElement.style.setProperty('--color', this.navigatorService.color);
|
|
162
162
|
this.me.nativeElement.style.setProperty('--hover-bg-color', this.navigatorService.hoverBackgroundColor);
|
|
163
163
|
this.me.nativeElement.style.setProperty('--hover-color', this.navigatorService.hoverColor);
|
|
164
|
+
this.me.nativeElement.style.setProperty('--icon-border-radius', this.navigatorService.iconBorderRadius + 'px');
|
|
165
|
+
this.me.nativeElement.style.setProperty('--icon-gutter-y', this.navigatorService.iconGutterY + 'px');
|
|
164
166
|
});
|
|
165
167
|
}
|
|
166
168
|
ngOnDestroy() {
|
|
167
169
|
this.subscriptions.map(x => x.unsubscribe());
|
|
168
170
|
}
|
|
169
171
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ItemComponent, deps: [{ token: i1.Router }, { token: i2.NavigatorService }, { token: i3.MultiLanguageService }, { token: i4.LayoutService }, { token: i5.MenuService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
170
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.3", type: ItemComponent, isStandalone: true, selector: "app-item", inputs: { item: "item", level: "level" }, viewQueries: [{ propertyName: "me", first: true, predicate: ["me"], descendants: true }, { propertyName: "children", first: true, predicate: ["children"], descendants: true }, { propertyName: "link", first: true, predicate: ["link"], descendants: true }, { propertyName: "subArrow", first: true, predicate: ["subArrow"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<li #me [id]=\"'main-menu-' + item.id\" class=\"parent\" [attr.data-level]=\"level\" [class.reduced]=\"leftbarReduced\"\r\n [class.active]=\"!wideMode && active\" [class.expanded]=\"item.tree$Expanded\"\r\n [class.highlighted]=\"item.tree$Highlighted\" [class.li-thin-mode]=\"!wideMode\" [class.menu-item]=\"!wideMode\"\r\n [appTooltip]=\"level===1 && !active ? caption : undefined\" [position]=\"'right'\">\r\n <div class=\"menu-item-wrapper\" [attr.data-level]=\"level\" (click)=\"onClick($event, item)\"\r\n [class.module-thin-mode]=\"!wideMode && level===1\" [class.thin-branch]=\"!wideMode && level > 1\">\r\n\r\n @if (wideMode) {\r\n @if (!!!leftbarReduced) {\r\n @if (!!hasChildren) {\r\n @if (!item.tree$Selected) {\r\n <i [attr.data-level]=\"level\" class=\"custom-icon-parent-right\"></i>\r\n } @else {\r\n <i [attr.data-level]=\"level\" class=\"custom-icon-parent-down\"></i>\r\n }\r\n } @else {\r\n @if (item.tree$Selected && item.code !== 'MENU.DASHBOARD' && item.code !== 'MENU.HOME') {\r\n <i [attr.data-level]=\"level\" class=\"custom-icon-child-right\"></i>\r\n }\r\n }\r\n }\r\n }\r\n\r\n @if (!!item.iconSvg) {\r\n <i [attr.data-level]=\"level\" class=\"'module-icon'\"\r\n [appTooltip]=\"wideMode ? caption : undefined\" (click)=\"onModuleIconClick($event, item);false\" [ngStyle]=\"{\r\n position: 'absolute',\r\n left: wideMode ? '20px' : 'unset'\r\n }\"><span [innerHtml]=\"item.iconSvg | stringHtml\"></span></i>\r\n\r\n <!-- <span [innerHtml]=\"item.iconSvg | stringHtml\"></span> -->\r\n } @else if (!!item.iconClass) {\r\n <i [attr.data-level]=\"level\" [class]=\"item.iconClass + ' module-icon'\"\r\n [appTooltip]=\"wideMode ? caption : undefined\" (click)=\"onModuleIconClick($event, item);false\" [ngStyle]=\"{\r\n left: wideMode ? '20px' : 'unset'\r\n }\"></i>\r\n }\r\n\r\n @if (!wideMode || (!leftbarReduced && hasChildren)) {\r\n <a #link [attr.data-level]=\"level\" class=\"has-submenu\" [appTooltip]=\"level > 1 ? caption : undefined\"\r\n [class.thin-mode]=\"!wideMode\">\r\n <ng-container (click)=\"subArrowClicked($event, item);false\"> <!--false is important here-->\r\n <span #subArrow *ngIf=\"(!!item.pictureBase64 || !!item.pictureUri)\"\r\n [class]=\"'img-span plus level' + level\">\r\n <img [src]=\"item.pictureBase64 || item.pictureUri\" *ngIf=\"!!item.pictureBase64\">\r\n </span>\r\n <span #subArrow *ngIf=\"!!!item.pictureBase64 && !!!item.pictureUri\"\r\n [class]=\"'plus level' + level\"></span>\r\n </ng-container>\r\n\r\n <img *ngIf=\"(!!item.pictureBase64 || !!item.pictureUri)\" [src]=\"item.pictureBase64 || item.pictureUri\">\r\n\r\n {{ caption }}\r\n\r\n </a>\r\n } @else {\r\n <a [attr.data-level]=\"level\" [routerLink]=\"item.url\" (click)=\"onClick($event, item)\"\r\n [class.thin-mode]=\"!wideMode\" [appTooltip]=\"wideMode && caption\">\r\n {{ caption }}\r\n </a>\r\n }\r\n\r\n </div>\r\n\r\n @if (!!wideMode && !!hasChildren && !!item.tree$Children!.length && !!!leftbarReduced) {\r\n <ul #children [class.expanded]=\"!wideMode || item.tree$Expanded\" [class.ul-thin-mode]=\"!wideMode\" [ngStyle]=\"{\r\n padding: 0,\r\n width: !!wideMode ? (layoutService.leftBarCurrentWidth$.value - layoutService.basicSpacing - layoutService.scrollBarWidth + 5 + 'px') : ( layoutService.leftBarWideWidth$.value + 'px' ),\r\n }\" [class.submenu]=\"!wideMode\">\r\n <div>\r\n @for (child of item.tree$Children; track $index) {\r\n <app-item [item]=\"child\" [level]=\"level+1\" (clicked)=\"onClick($event, child)\"></app-item>\r\n }\r\n </div>\r\n </ul>\r\n }\r\n\r\n</li>", styles: [".navigator-container{--active-item-border-color: white;--line-height: 16px;--level-gap: 10px;--thin-mode-padding: 8px;--thin-mode-width: 66px;--wide-mode-width: 280px;--left-bar-current-width: 280px;--bg-color: #F1F1F1;--color: black;--hover-bg-color: #E1E3E5;--hover-color: black}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.navigator-container .d-none{display:none}.navigator-container svg{width:24px;height:24px}.navigator-container .module-thin-mode{display:flex!important;align-items:center!important;justify-content:center!important;padding:0!important;margin-bottom:5px!important;height:50px!important}.navigator-container .module-thin-mode svg{color:var(--color)}.navigator-container .module-thin-mode i{color:var(--color)!important}.navigator-container .li-thin-mode[data-level=\"1\"]{height:50px!important;margin:0!important}.navigator-container .li-thin-mode .thin-branch a{padding-left:15px;padding-right:15px;overflow:hidden;max-width:100%;text-overflow:ellipsis}.navigator-container .li-thin-mode .thin-branch:hover{background:#e1e3e5!important;border-radius:5px!important}.navigator-container .li-thin-mode:hover[data-level=\"1\"]>ul.ul-thin-mode{transform:translate(calc(var(--thin-mode-width)))}.navigator-container .li-thin-mode:hover:not([data-level=\"1\"])>ul.ul-thin-mode{transform:translate(calc(var(--wide-mode-width) - var(--size-layout-block-cell-spacing)))}.navigator-container .li-thin-mode.active .module-thin-mode{background:var(--hover-bg-color)!important;border-radius:5px!important;width:50px!important;transform:translate(var(--thin-mode-padding))}.navigator-container .li-thin-mode.active .module-thin-mode i{color:var(--hover-color)!important}.navigator-container .li-thin-mode.active .module-thin-mode svg{color:var(--hover-color)!important}.navigator-container .li-thin-mode.active>ul.ul-thin-mode{background-color:#fff;opacity:1;height:unset;overflow-y:auto;box-shadow:.4rem 0 2rem #0000002e}.navigator-container .li-thin-mode.active>ul.ul-thin-mode>div>app-item>li>div>a{display:block!important}.navigator-container .li-thin-mode.active[data-level=\"1\"]>ul.ul-thin-mode{display:block;transform:translate(calc(var(--thin-mode-width)))}.navigator-container .li-thin-mode.active:not([data-level=\"1\"])>ul.ul-thin-mode{display:block;transform:translate(calc(var(--wide-mode-width) - var(--size-layout-block-cell-spacing)))}.navigator-container ul.ul-thin-mode{display:none}.navigator-container .parent{--children-height: 0px;box-sizing:border-box;width:100%;transition:width 1s ease-out}.navigator-container .parent ul{animation:fadeIn .25s linear}.navigator-container .parent i[class^=custom-icon-parent-],.navigator-container .parent i[class^=custom-icon-child-]{position:absolute}.navigator-container .parent i[class^=custom-icon-parent-][data-level=\"1\"],.navigator-container .parent i[class^=custom-icon-child-][data-level=\"1\"]{left:var(--size-left-bar-the-first-icon-left)!important}.navigator-container .parent i[class^=custom-icon-parent-][data-level=\"2\"],.navigator-container .parent i[class^=custom-icon-child-][data-level=\"2\"]{left:46px!important}.navigator-container .parent i[class^=custom-icon-child-][data-level=\"3\"]{left:calc(var(--size-header-logo-left) - 2 * var(--level-gap))!important}.navigator-container .parent i.module-icon{position:absolute;display:inline-block;font-size:var(--size-left-bar-icon-font-size)!important;width:var(--size-left-bar-icon-font-size)!important;height:var(--size-left-bar-icon-font-size)!important}.navigator-container .parent .menu-item-wrapper{position:relative!important;margin-left:0!important;padding-left:0;border:none!important;cursor:pointer}.navigator-container .parent .menu-item-wrapper[data-level=\"1\"].module-thin-mode:hover{background-color:#e1e3e5;width:50px;border-radius:5px;transform:translate(8px);color:#000}.navigator-container .parent .menu-item-wrapper:not([data-level=\"1\"]).module-thin-mode:hover{background-color:#e1e3e5;color:#000;padding:var(--size-layout-block-cell-spacing)}.navigator-container .parent a.thin-mode{left:0!important;display:none;padding-left:15px;padding-right:15px;overflow:hidden;text-overflow:ellipsis}.navigator-container .parent a{position:absolute!important;margin-left:0!important;padding-left:0;border:none!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;user-select:none;-webkit-user-select:none}.navigator-container .parent a[data-level=\"1\"]:not(.thin-mode){left:var(--size-header-logo-left);max-width:calc(var(--left-bar-current-width) - var(--size-header-logo-left) - var(--size-scrollbar-width) - var(--size-layout-block-cell-spacing) * 2)}.navigator-container .parent a[data-level=\"2\"]:not(.thin-mode){left:calc(var(--size-header-logo-left) + var(--level-gap));max-width:calc(var(--left-bar-current-width) - var(--size-header-logo-left) - var(--size-scrollbar-width) - var(--size-layout-block-cell-spacing) * 2 - var(--level-gap))}.navigator-container .parent a[data-level=\"3\"]:not(.thin-mode){left:calc(var(--size-header-logo-left) - var(--level-gap) + 3px);max-width:calc(var(--left-bar-current-width) - var(--size-header-logo-left) - var(--size-scrollbar-width) - var(--size-layout-block-cell-spacing) * 2 - var(--level-gap) * 2)}.navigator-container .parent[data-level=\"1\"]{margin:10px 0}.navigator-container .parent[data-level=\"1\"] a{margin-left:0;font-size:13px}.navigator-container .parent[data-level=\"2\"]:not(.ul-thin-mode) a{margin-left:10px;font-size:13px}.navigator-container .parent[data-level=\"3\"]:not(.ul-thin-mode) a{margin-left:20px;font-size:13px}.navigator-container .parent[data-level=\"2\"]>.menu-item-wrapper{margin-left:20px}.navigator-container .parent .menu-item-wrapper{height:35px;padding-left:0!important;display:flex;align-items:center;margin:0}.navigator-container .parent .menu-item-wrapper>i{display:inline-block;font-size:13px;color:#a9a9a9;cursor:pointer}.navigator-container .parent .menu-item-wrapper>i{color:#000}.navigator-container .parent li:not(.li-thin-mode):hover>.menu-item-wrapper:before{content:\"\";display:inline-block;position:absolute;left:0;height:33px;width:calc(var(--size-left-bar-full-width) - 20px);background-color:#eaf1fb;border-top-right-radius:50px;border-bottom-right-radius:50px}.navigator-container .parent>ul:not(.ul-thin-mode){position:relative;overflow:hidden;display:none;opacity:0;transition:opacity .5s ease-out}.navigator-container .parent>ul.ul-thin-mode{overflow-x:hidden;display:none;margin-left:0!important;opacity:1;transition:opacity .5s ease-out}.navigator-container .parent>ul.ul-thin-mode{overflow-y:auto}.navigator-container .parent.active[data-level=\"2\"]>.menu-item-wrapper>a{transition:.5s ease-out}.navigator-container .parent.highlighted>.menu-item-wrapper>a{color:var(--color-core-org-tree-highlighted)!important;font-weight:700!important}.navigator-container .parent.expanded>ul:not(.submenu){display:block;opacity:1;transition:opacity .5s ease-out}.navigator-container .parent.expanded[data-level=\"2\"]>ul{margin-left:25px}.navigator-container .parent:not(.li-thin-mode) a{margin-left:0}.navigator-container .parent.reduced .menu-item-wrapper{padding:0}.navigator-container .expanded[data-level=\"1\"]:not(.li-thin-mode)>.menu-item-wrapper{background-color:#fff;border-top-right-radius:50px;border-bottom-right-radius:50px;margin-right:2px;display:flex;justify-content:flex-start}.navigator-container .expanded[data-level=\"1\"]:not(.li-thin-mode)>.menu-item-wrapper:hover{background-color:#fff}.navigator-container .expanded>ul:not(.submenu){overflow:visible!important}.navigator-container .expanded.reduced>.menu-item-wrapper{justify-content:flex-start!important;border-top-left-radius:50px;border-bottom-left-radius:50px;width:37px}.navigator-container .parent.reduced>.menu-item-wrapper{justify-content:flex-start!important;border-radius:20px;width:37px}.navigator-container .custom-icon-parent-down{background-image:url('data:image/svg+xml,<svg width=\"8\" height=\"4\" viewBox=\"0 0 8 4\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M4 3.88867L0.535899 0.555338L7.4641 0.555339L4 3.88867Z\" fill=\"%23000000\"/></svg>');display:flex;align-items:center;justify-content:center;width:8px;height:5px;background-size:contain;background-repeat:no-repeat}.navigator-container .custom-icon-parent-right{background-image:url('data:image/svg+xml,<svg width=\"5\" height=\"5\" viewBox=\"0 0 4 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M4 4L0.666667 7.4641L0.666667 0.535898L4 4Z\" fill=\"%23000000\"/></svg>');display:block;position:absolute;width:8px;height:8px;align-items:center;justify-content:center;background-size:contain;background-repeat:no-repeat;float:left}.navigator-container .custom-icon-child-right{position:absolute;background-image:url('data:image/svg+xml,<svg width=\"9\" height=\"12\" viewBox=\"0 0 9 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M8.08811 5.23421C8.56399 5.63384 8.56399 6.36616 8.08811 6.76579L2.3931 11.5484C1.74247 12.0947 0.75 11.6322 0.75 10.7826L0.750001 1.21742C0.750001 0.367809 1.74247 -0.0947444 2.39309 0.451638L8.08811 5.23421Z\" fill=\"%23F37540\"/></svg>');display:flex;width:8px;height:8px;align-items:center;justify-content:center;background-size:contain;background-repeat:no-repeat}.navigator-container .custom-organization-icon{background-image:url('data:image/svg+xml,<svg width=\"20\" height=\"19\" viewBox=\"0 0 20 19\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M4.98901 9.6555H15.0112V11.5377H15.989V8.67772H10.489V6.72217H9.51123V8.67772H4.01123V11.5377H4.98901V9.6555Z\" fill=\"%23000000\"/><path d=\"M7.5555 12.2222H1.44439C1.12024 12.2222 0.80936 12.3509 0.580149 12.5801C0.350937 12.8094 0.222168 13.1202 0.222168 13.4444V17.1111C0.222168 17.4352 0.350937 17.7461 0.580149 17.9753C0.80936 18.2045 1.12024 18.3333 1.44439 18.3333H7.5555C7.87966 18.3333 8.19053 18.2045 8.41974 17.9753C8.64895 17.7461 8.77772 17.4352 8.77772 17.1111V13.4444C8.77772 13.1202 8.64895 12.8094 8.41974 12.5801C8.19053 12.3509 7.87966 12.2222 7.5555 12.2222ZM1.44439 17.1111V13.4444H7.5555V17.1111H1.44439Z\" fill=\"%23000000\"/><path d=\"M18.5555 12.2222H12.4444C12.1202 12.2222 11.8094 12.3509 11.5801 12.5801C11.3509 12.8094 11.2222 13.1202 11.2222 13.4444V17.1111C11.2222 17.4352 11.3509 17.7461 11.5801 17.9753C11.8094 18.2045 12.1202 18.3333 12.4444 18.3333H18.5555C18.8797 18.3333 19.1905 18.2045 19.4197 17.9753C19.649 17.7461 19.7777 17.4352 19.7777 17.1111V13.4444C19.7777 13.1202 19.649 12.8094 19.4197 12.5801C19.1905 12.3509 18.8797 12.2222 18.5555 12.2222ZM12.4444 17.1111V13.4444H18.5555V17.1111H12.4444Z\" fill=\"%23000000\"/><path d=\"M6.94439 6.11111H13.0555C13.3797 6.11111 13.6905 5.98234 13.9197 5.75313C14.149 5.52392 14.2777 5.21304 14.2777 4.88889V1.22222C14.2777 0.898069 14.149 0.587192 13.9197 0.35798C13.6905 0.128769 13.3797 0 13.0555 0H6.94439C6.62024 0 6.30936 0.128769 6.08015 0.35798C5.85094 0.587192 5.72217 0.898069 5.72217 1.22222V4.88889C5.72217 5.21304 5.85094 5.52392 6.08015 5.75313C6.30936 5.98234 6.62024 6.11111 6.94439 6.11111ZM6.94439 1.22222H13.0555V4.88889H6.94439V1.22222Z\" fill=\"%23000000\"/></svg>');display:flex;align-items:center;justify-content:center;width:15px;height:15px;background-size:contain;background-repeat:no-repeat}.navigator-container .custom-profile-icon{background-image:url('data:image/svg+xml,<svg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><rect x=\"0.75\" y=\"0.75\" width=\"16.5\" height=\"16.5\" rx=\"4.25\" stroke=\"%23000000\" stroke-width=\"1.5\"/><path d=\"M14.5164 16.5755V15.2137C14.5164 14.4914 14.2258 13.7987 13.7086 13.2879C13.1913 12.7772 12.4898 12.4902 11.7583 12.4902H6.2422C5.51071 12.4902 4.80919 12.7772 4.29195 13.2879C3.77471 13.7987 3.48413 14.4914 3.48413 15.2137V16.5755\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M9.00011 9.57227C10.4432 9.57227 11.613 8.39647 11.613 6.94605C11.613 5.49562 10.4432 4.31982 9.00011 4.31982C7.55704 4.31982 6.38721 5.49562 6.38721 6.94605C6.38721 8.39647 7.55704 9.57227 9.00011 9.57227Z\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>');display:flex;align-items:center;justify-content:center;width:15px;height:15px;background-size:contain;background-repeat:no-repeat}.navigator-container .custom-insurence-icon{background-image:url('data:image/svg+xml,<svg width=\"20\" height=\"18\" viewBox=\"0 0 20 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.8 1H17.2C17.6774 1 18.1352 1.1873 18.4728 1.5207C18.8104 1.8541 19 2.30628 19 2.77778V8.11111C19 10.4686 18.0518 12.7295 16.364 14.3965C14.6761 16.0635 12.3869 17 10 17C8.8181 17 7.64778 16.7701 6.55585 16.3234C5.46392 15.8767 4.47177 15.2219 3.63604 14.3965C1.94821 12.7295 1 10.4686 1 8.11111V2.77778C1 2.30628 1.18964 1.8541 1.52721 1.5207C1.86477 1.1873 2.32261 1 2.8 1V1Z\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M7 8.5L9.5 11.5L15 6\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>');display:flex;align-items:center;justify-content:center;width:15px;height:15px;background-size:contain;background-repeat:no-repeat}.navigator-container .custom-education-icon{background-image:url('data:image/svg+xml,<svg width=\"21\" height=\"19\" viewBox=\"0 0 21 19\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M1 1H6.66667C7.6686 1 8.62949 1.39801 9.33796 2.10649C10.0464 2.81496 10.4444 3.77585 10.4444 4.77778V18C10.4444 17.2486 10.1459 16.5279 9.61458 15.9965C9.08323 15.4652 8.36256 15.1667 7.61111 15.1667H1V1Z\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M19.8889 1H14.2222C13.2203 1 12.2594 1.39801 11.5509 2.10649C10.8425 2.81496 10.4445 3.77585 10.4445 4.77778V18C10.4445 17.2486 10.743 16.5279 11.2743 15.9965C11.8057 15.4652 12.5263 15.1667 13.2778 15.1667H19.8889V1Z\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>');display:flex;align-items:center;justify-content:center;width:15px;height:15px;background-size:contain;background-repeat:no-repeat}.navigator-container .parent.expanded.reduced>.menu-item-wrapper{background-color:#fff;left:10px!important}.navigator-container .parent.expanded.reduced>.menu-item-wrapper>i{left:9px!important;top:8px!important}.navigator-container .parent.reduced>.menu-item-wrapper{left:10px!important}.navigator-container .parent.reduced>.menu-item-wrapper>i{left:9px!important}\n"], dependencies: [{ kind: "component", type: ItemComponent, selector: "app-item", inputs: ["item", "level"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: RouterModule }, { kind: "directive", type: i1.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: TooltipDirective, selector: "[appTooltip]", inputs: ["appTooltip", "showAnyway", "position"] }, { kind: "pipe", type: StringHtmlPipe, name: "stringHtml" }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
172
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.3", type: ItemComponent, isStandalone: true, selector: "app-item", inputs: { item: "item", level: "level" }, viewQueries: [{ propertyName: "me", first: true, predicate: ["me"], descendants: true }, { propertyName: "children", first: true, predicate: ["children"], descendants: true }, { propertyName: "link", first: true, predicate: ["link"], descendants: true }, { propertyName: "subArrow", first: true, predicate: ["subArrow"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<li #me [id]=\"'main-menu-' + item.id\" class=\"parent\" [attr.data-level]=\"level\" [class.reduced]=\"leftbarReduced\"\r\n [class.active]=\"!wideMode && active\" [class.expanded]=\"item.tree$Expanded\"\r\n [class.highlighted]=\"item.tree$Highlighted\" [class.li-thin-mode]=\"!wideMode\" [class.menu-item]=\"!wideMode\"\r\n [appTooltip]=\"level===1 && !active ? caption : undefined\" [position]=\"'right'\" [ngStyle]=\"{\r\n marginTop: (level===1 && !wideMode) ? navigatorService.iconGutterY + 'px' : '',\r\n marginBottom: (level===1 && !wideMode) ? navigatorService.iconGutterY + 'px' : ''\r\n }\">\r\n <div class=\"menu-item-wrapper\" [attr.data-level]=\"level\" (click)=\"onClick($event, item)\"\r\n [class.module-thin-mode]=\"!wideMode && level===1\" [class.thin-branch]=\"!wideMode && level > 1\" [ngStyle]=\"{\r\n borderRadius: (level===1 && !wideMode) ? navigatorService.iconBorderRadius + 'px' : ''\r\n }\">\r\n\r\n @if (wideMode) {\r\n @if (!!!leftbarReduced) {\r\n @if (!!hasChildren) {\r\n @if (!item.tree$Selected) {\r\n <i [attr.data-level]=\"level\" class=\"custom-icon-parent-right\"></i>\r\n } @else {\r\n <i [attr.data-level]=\"level\" class=\"custom-icon-parent-down\"></i>\r\n }\r\n } @else {\r\n @if (item.tree$Selected && item.code !== 'MENU.DASHBOARD' && item.code !== 'MENU.HOME') {\r\n <i [attr.data-level]=\"level\" class=\"custom-icon-child-right\"></i>\r\n }\r\n }\r\n }\r\n }\r\n\r\n @if (!!item.iconSvg) {\r\n <i [attr.data-level]=\"level\" class=\"'module-icon'\"\r\n [appTooltip]=\"wideMode ? caption : undefined\" (click)=\"onModuleIconClick($event, item);false\" [ngStyle]=\"{\r\n position: 'absolute',\r\n left: wideMode ? '20px' : 'unset'\r\n }\"><span [innerHtml]=\"item.iconSvg | stringHtml\"></span></i>\r\n\r\n <!-- <span [innerHtml]=\"item.iconSvg | stringHtml\"></span> -->\r\n } @else if (!!item.iconClass) {\r\n <i [attr.data-level]=\"level\" [class]=\"item.iconClass + ' module-icon'\"\r\n [appTooltip]=\"wideMode ? caption : undefined\" (click)=\"onModuleIconClick($event, item);false\" [ngStyle]=\"{\r\n left: wideMode ? '20px' : 'unset'\r\n }\"></i>\r\n }\r\n\r\n @if (!wideMode || (!leftbarReduced && hasChildren)) {\r\n <a #link [attr.data-level]=\"level\" class=\"has-submenu\" [appTooltip]=\"level > 1 ? caption : undefined\"\r\n [class.thin-mode]=\"!wideMode\">\r\n <ng-container (click)=\"subArrowClicked($event, item);false\"> <!--false is important here-->\r\n <span #subArrow *ngIf=\"(!!item.pictureBase64 || !!item.pictureUri)\"\r\n [class]=\"'img-span plus level' + level\">\r\n <img [src]=\"item.pictureBase64 || item.pictureUri\" *ngIf=\"!!item.pictureBase64\">\r\n </span>\r\n <span #subArrow *ngIf=\"!!!item.pictureBase64 && !!!item.pictureUri\"\r\n [class]=\"'plus level' + level\"></span>\r\n </ng-container>\r\n\r\n <img *ngIf=\"(!!item.pictureBase64 || !!item.pictureUri)\" [src]=\"item.pictureBase64 || item.pictureUri\">\r\n\r\n {{ caption }}\r\n\r\n </a>\r\n } @else {\r\n <a [attr.data-level]=\"level\" [routerLink]=\"item.url\" (click)=\"onClick($event, item)\"\r\n [class.thin-mode]=\"!wideMode\" [appTooltip]=\"wideMode && caption\">\r\n {{ caption }}\r\n </a>\r\n }\r\n\r\n </div>\r\n\r\n @if (!!wideMode && !!hasChildren && !!item.tree$Children!.length && !!!leftbarReduced) {\r\n <ul #children [class.expanded]=\"!wideMode || item.tree$Expanded\" [class.ul-thin-mode]=\"!wideMode\" [ngStyle]=\"{\r\n padding: 0,\r\n width: !!wideMode ? (layoutService.leftBarCurrentWidth$.value - layoutService.basicSpacing - layoutService.scrollBarWidth + 5 + 'px') : ( layoutService.leftBarWideWidth$.value + 'px' ),\r\n }\" [class.submenu]=\"!wideMode\">\r\n <div>\r\n @for (child of item.tree$Children; track $index) {\r\n <app-item [item]=\"child\" [level]=\"level+1\" (clicked)=\"onClick($event, child)\"></app-item>\r\n }\r\n </div>\r\n </ul>\r\n }\r\n\r\n</li>", styles: [".navigator-container{--active-item-border-color: white;--line-height: 16px;--level-gap: 10px;--thin-mode-padding: 8px;--thin-mode-width: 66px;--wide-mode-width: 280px;--left-bar-current-width: 280px;--bg-color: #F1F1F1;--color: black;--hover-bg-color: #E1E3E5;--hover-color: black;--icon-border-radius: 8px;--icon-gutter-y: 8px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.navigator-container .d-none{display:none}.navigator-container svg{width:24px;height:24px}.navigator-container .module-thin-mode{display:flex!important;align-items:center!important;justify-content:center!important;padding:0!important;margin-bottom:5px!important;height:50px!important}.navigator-container .module-thin-mode svg{color:var(--color)}.navigator-container .module-thin-mode i{color:var(--color)!important}.navigator-container .li-thin-mode[data-level=\"1\"]{height:50px!important;margin-left:0!important;margin-right:0!important}.navigator-container .li-thin-mode .thin-branch a{padding-left:15px;padding-right:15px;overflow:hidden;max-width:100%;text-overflow:ellipsis}.navigator-container .li-thin-mode .thin-branch:hover{background:#e1e3e5!important;border-radius:5px!important}.navigator-container .li-thin-mode:hover[data-level=\"1\"]>ul.ul-thin-mode{transform:translate(calc(var(--thin-mode-width)))}.navigator-container .li-thin-mode:hover:not([data-level=\"1\"])>ul.ul-thin-mode{transform:translate(calc(var(--wide-mode-width) - var(--size-layout-block-cell-spacing)))}.navigator-container .li-thin-mode.active .module-thin-mode{background:var(--hover-bg-color)!important;border-radius:var(--icon-border-radius)!important;width:50px!important;transform:translate(var(--thin-mode-padding))}.navigator-container .li-thin-mode.active .module-thin-mode i{color:var(--hover-color)!important}.navigator-container .li-thin-mode.active .module-thin-mode svg{color:var(--hover-color)!important}.navigator-container .li-thin-mode.active>ul.ul-thin-mode{background-color:#fff;opacity:1;height:unset;overflow-y:auto;box-shadow:.4rem 0 2rem #0000002e}.navigator-container .li-thin-mode.active>ul.ul-thin-mode>div>app-item>li>div>a{display:block!important}.navigator-container .li-thin-mode.active[data-level=\"1\"]>ul.ul-thin-mode{display:block;transform:translate(calc(var(--thin-mode-width)))}.navigator-container .li-thin-mode.active:not([data-level=\"1\"])>ul.ul-thin-mode{display:block;transform:translate(calc(var(--wide-mode-width) - var(--size-layout-block-cell-spacing)))}.navigator-container ul.ul-thin-mode{display:none}.navigator-container .parent{--children-height: 0px;box-sizing:border-box;width:100%;transition:width 1s ease-out}.navigator-container .parent ul{animation:fadeIn .25s linear}.navigator-container .parent i[class^=custom-icon-parent-],.navigator-container .parent i[class^=custom-icon-child-]{position:absolute}.navigator-container .parent i[class^=custom-icon-parent-][data-level=\"1\"],.navigator-container .parent i[class^=custom-icon-child-][data-level=\"1\"]{left:var(--size-left-bar-the-first-icon-left)!important}.navigator-container .parent i[class^=custom-icon-parent-][data-level=\"2\"],.navigator-container .parent i[class^=custom-icon-child-][data-level=\"2\"]{left:46px!important}.navigator-container .parent i[class^=custom-icon-child-][data-level=\"3\"]{left:calc(var(--size-header-logo-left) - 2 * var(--level-gap))!important}.navigator-container .parent i.module-icon{position:absolute;display:inline-block;font-size:var(--size-left-bar-icon-font-size)!important;width:var(--size-left-bar-icon-font-size)!important;height:var(--size-left-bar-icon-font-size)!important}.navigator-container .parent .menu-item-wrapper{position:relative!important;margin-left:0!important;padding-left:0;border:none!important;cursor:pointer}.navigator-container .parent .menu-item-wrapper[data-level=\"1\"].module-thin-mode:hover{background-color:var(--hover-bg-color);width:50px;border-radius:5px;transform:translate(8px);color:var(--hover-color)!important}.navigator-container .parent .menu-item-wrapper:not([data-level=\"1\"]).module-thin-mode:hover{background-color:#e1e3e5;color:#000;padding:var(--size-layout-block-cell-spacing)}.navigator-container .parent a.thin-mode{left:0!important;display:none;padding-left:15px;padding-right:15px;overflow:hidden;text-overflow:ellipsis}.navigator-container .parent a{position:absolute!important;margin-left:0!important;padding-left:0;border:none!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;user-select:none;-webkit-user-select:none}.navigator-container .parent a[data-level=\"1\"]:not(.thin-mode){left:var(--size-header-logo-left);max-width:calc(var(--left-bar-current-width) - var(--size-header-logo-left) - var(--size-scrollbar-width) - var(--size-layout-block-cell-spacing) * 2)}.navigator-container .parent a[data-level=\"2\"]:not(.thin-mode){left:calc(var(--size-header-logo-left) + var(--level-gap));max-width:calc(var(--left-bar-current-width) - var(--size-header-logo-left) - var(--size-scrollbar-width) - var(--size-layout-block-cell-spacing) * 2 - var(--level-gap))}.navigator-container .parent a[data-level=\"3\"]:not(.thin-mode){left:calc(var(--size-header-logo-left) - var(--level-gap) + 3px);max-width:calc(var(--left-bar-current-width) - var(--size-header-logo-left) - var(--size-scrollbar-width) - var(--size-layout-block-cell-spacing) * 2 - var(--level-gap) * 2)}.navigator-container .parent[data-level=\"1\"]{margin:10px 0}.navigator-container .parent[data-level=\"1\"] a{margin-left:0;font-size:13px}.navigator-container .parent[data-level=\"2\"]:not(.ul-thin-mode) a{margin-left:10px;font-size:13px}.navigator-container .parent[data-level=\"3\"]:not(.ul-thin-mode) a{margin-left:20px;font-size:13px}.navigator-container .parent[data-level=\"2\"]>.menu-item-wrapper{margin-left:20px}.navigator-container .parent .menu-item-wrapper{height:35px;padding-left:0!important;display:flex;align-items:center;margin:0}.navigator-container .parent .menu-item-wrapper>i{display:inline-block;font-size:13px;color:#a9a9a9;cursor:pointer}.navigator-container .parent .menu-item-wrapper>i{color:#000}.navigator-container .parent li:not(.li-thin-mode):hover>.menu-item-wrapper:before{content:\"\";display:inline-block;position:absolute;left:0;height:33px;width:calc(var(--size-left-bar-full-width) - 20px);background-color:#eaf1fb;border-top-right-radius:50px;border-bottom-right-radius:50px}.navigator-container .parent>ul:not(.ul-thin-mode){position:relative;overflow:hidden;display:none;opacity:0;transition:opacity .5s ease-out}.navigator-container .parent>ul.ul-thin-mode{overflow-x:hidden;display:none;margin-left:0!important;opacity:1;transition:opacity .5s ease-out}.navigator-container .parent>ul.ul-thin-mode{overflow-y:auto}.navigator-container .parent.active[data-level=\"2\"]>.menu-item-wrapper>a{transition:.5s ease-out}.navigator-container .parent.highlighted>.menu-item-wrapper>a{color:var(--color-core-org-tree-highlighted)!important;font-weight:700!important}.navigator-container .parent.expanded>ul:not(.submenu){display:block;opacity:1;transition:opacity .5s ease-out}.navigator-container .parent.expanded[data-level=\"2\"]>ul{margin-left:25px}.navigator-container .parent:not(.li-thin-mode) a{margin-left:0}.navigator-container .parent.reduced .menu-item-wrapper{padding:0}.navigator-container .expanded[data-level=\"1\"]:not(.li-thin-mode)>.menu-item-wrapper{background-color:#fff;border-top-right-radius:50px;border-bottom-right-radius:50px;margin-right:2px;display:flex;justify-content:flex-start}.navigator-container .expanded[data-level=\"1\"]:not(.li-thin-mode)>.menu-item-wrapper:hover{background-color:#fff}.navigator-container .expanded>ul:not(.submenu){overflow:visible!important}.navigator-container .expanded.reduced>.menu-item-wrapper{justify-content:flex-start!important;border-top-left-radius:50px;border-bottom-left-radius:50px;width:37px}.navigator-container .parent.reduced>.menu-item-wrapper{justify-content:flex-start!important;border-radius:20px;width:37px}.navigator-container .custom-icon-parent-down{background-image:url('data:image/svg+xml,<svg width=\"8\" height=\"4\" viewBox=\"0 0 8 4\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M4 3.88867L0.535899 0.555338L7.4641 0.555339L4 3.88867Z\" fill=\"%23000000\"/></svg>');display:flex;align-items:center;justify-content:center;width:8px;height:5px;background-size:contain;background-repeat:no-repeat}.navigator-container .custom-icon-parent-right{background-image:url('data:image/svg+xml,<svg width=\"5\" height=\"5\" viewBox=\"0 0 4 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M4 4L0.666667 7.4641L0.666667 0.535898L4 4Z\" fill=\"%23000000\"/></svg>');display:block;position:absolute;width:8px;height:8px;align-items:center;justify-content:center;background-size:contain;background-repeat:no-repeat;float:left}.navigator-container .custom-icon-child-right{position:absolute;background-image:url('data:image/svg+xml,<svg width=\"9\" height=\"12\" viewBox=\"0 0 9 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M8.08811 5.23421C8.56399 5.63384 8.56399 6.36616 8.08811 6.76579L2.3931 11.5484C1.74247 12.0947 0.75 11.6322 0.75 10.7826L0.750001 1.21742C0.750001 0.367809 1.74247 -0.0947444 2.39309 0.451638L8.08811 5.23421Z\" fill=\"%23F37540\"/></svg>');display:flex;width:8px;height:8px;align-items:center;justify-content:center;background-size:contain;background-repeat:no-repeat}.navigator-container .custom-organization-icon{background-image:url('data:image/svg+xml,<svg width=\"20\" height=\"19\" viewBox=\"0 0 20 19\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M4.98901 9.6555H15.0112V11.5377H15.989V8.67772H10.489V6.72217H9.51123V8.67772H4.01123V11.5377H4.98901V9.6555Z\" fill=\"%23000000\"/><path d=\"M7.5555 12.2222H1.44439C1.12024 12.2222 0.80936 12.3509 0.580149 12.5801C0.350937 12.8094 0.222168 13.1202 0.222168 13.4444V17.1111C0.222168 17.4352 0.350937 17.7461 0.580149 17.9753C0.80936 18.2045 1.12024 18.3333 1.44439 18.3333H7.5555C7.87966 18.3333 8.19053 18.2045 8.41974 17.9753C8.64895 17.7461 8.77772 17.4352 8.77772 17.1111V13.4444C8.77772 13.1202 8.64895 12.8094 8.41974 12.5801C8.19053 12.3509 7.87966 12.2222 7.5555 12.2222ZM1.44439 17.1111V13.4444H7.5555V17.1111H1.44439Z\" fill=\"%23000000\"/><path d=\"M18.5555 12.2222H12.4444C12.1202 12.2222 11.8094 12.3509 11.5801 12.5801C11.3509 12.8094 11.2222 13.1202 11.2222 13.4444V17.1111C11.2222 17.4352 11.3509 17.7461 11.5801 17.9753C11.8094 18.2045 12.1202 18.3333 12.4444 18.3333H18.5555C18.8797 18.3333 19.1905 18.2045 19.4197 17.9753C19.649 17.7461 19.7777 17.4352 19.7777 17.1111V13.4444C19.7777 13.1202 19.649 12.8094 19.4197 12.5801C19.1905 12.3509 18.8797 12.2222 18.5555 12.2222ZM12.4444 17.1111V13.4444H18.5555V17.1111H12.4444Z\" fill=\"%23000000\"/><path d=\"M6.94439 6.11111H13.0555C13.3797 6.11111 13.6905 5.98234 13.9197 5.75313C14.149 5.52392 14.2777 5.21304 14.2777 4.88889V1.22222C14.2777 0.898069 14.149 0.587192 13.9197 0.35798C13.6905 0.128769 13.3797 0 13.0555 0H6.94439C6.62024 0 6.30936 0.128769 6.08015 0.35798C5.85094 0.587192 5.72217 0.898069 5.72217 1.22222V4.88889C5.72217 5.21304 5.85094 5.52392 6.08015 5.75313C6.30936 5.98234 6.62024 6.11111 6.94439 6.11111ZM6.94439 1.22222H13.0555V4.88889H6.94439V1.22222Z\" fill=\"%23000000\"/></svg>');display:flex;align-items:center;justify-content:center;width:15px;height:15px;background-size:contain;background-repeat:no-repeat}.navigator-container .custom-profile-icon{background-image:url('data:image/svg+xml,<svg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><rect x=\"0.75\" y=\"0.75\" width=\"16.5\" height=\"16.5\" rx=\"4.25\" stroke=\"%23000000\" stroke-width=\"1.5\"/><path d=\"M14.5164 16.5755V15.2137C14.5164 14.4914 14.2258 13.7987 13.7086 13.2879C13.1913 12.7772 12.4898 12.4902 11.7583 12.4902H6.2422C5.51071 12.4902 4.80919 12.7772 4.29195 13.2879C3.77471 13.7987 3.48413 14.4914 3.48413 15.2137V16.5755\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M9.00011 9.57227C10.4432 9.57227 11.613 8.39647 11.613 6.94605C11.613 5.49562 10.4432 4.31982 9.00011 4.31982C7.55704 4.31982 6.38721 5.49562 6.38721 6.94605C6.38721 8.39647 7.55704 9.57227 9.00011 9.57227Z\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>');display:flex;align-items:center;justify-content:center;width:15px;height:15px;background-size:contain;background-repeat:no-repeat}.navigator-container .custom-insurence-icon{background-image:url('data:image/svg+xml,<svg width=\"20\" height=\"18\" viewBox=\"0 0 20 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.8 1H17.2C17.6774 1 18.1352 1.1873 18.4728 1.5207C18.8104 1.8541 19 2.30628 19 2.77778V8.11111C19 10.4686 18.0518 12.7295 16.364 14.3965C14.6761 16.0635 12.3869 17 10 17C8.8181 17 7.64778 16.7701 6.55585 16.3234C5.46392 15.8767 4.47177 15.2219 3.63604 14.3965C1.94821 12.7295 1 10.4686 1 8.11111V2.77778C1 2.30628 1.18964 1.8541 1.52721 1.5207C1.86477 1.1873 2.32261 1 2.8 1V1Z\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M7 8.5L9.5 11.5L15 6\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>');display:flex;align-items:center;justify-content:center;width:15px;height:15px;background-size:contain;background-repeat:no-repeat}.navigator-container .custom-education-icon{background-image:url('data:image/svg+xml,<svg width=\"21\" height=\"19\" viewBox=\"0 0 21 19\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M1 1H6.66667C7.6686 1 8.62949 1.39801 9.33796 2.10649C10.0464 2.81496 10.4444 3.77585 10.4444 4.77778V18C10.4444 17.2486 10.1459 16.5279 9.61458 15.9965C9.08323 15.4652 8.36256 15.1667 7.61111 15.1667H1V1Z\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M19.8889 1H14.2222C13.2203 1 12.2594 1.39801 11.5509 2.10649C10.8425 2.81496 10.4445 3.77585 10.4445 4.77778V18C10.4445 17.2486 10.743 16.5279 11.2743 15.9965C11.8057 15.4652 12.5263 15.1667 13.2778 15.1667H19.8889V1Z\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>');display:flex;align-items:center;justify-content:center;width:15px;height:15px;background-size:contain;background-repeat:no-repeat}.navigator-container .parent.expanded.reduced>.menu-item-wrapper{background-color:#fff;left:10px!important}.navigator-container .parent.expanded.reduced>.menu-item-wrapper>i{left:9px!important;top:8px!important}.navigator-container .parent.reduced>.menu-item-wrapper{left:10px!important}.navigator-container .parent.reduced>.menu-item-wrapper>i{left:9px!important}\n"], dependencies: [{ kind: "component", type: ItemComponent, selector: "app-item", inputs: ["item", "level"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: RouterModule }, { kind: "directive", type: i1.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: TooltipDirective, selector: "[appTooltip]", inputs: ["appTooltip", "showAnyway", "position"] }, { kind: "pipe", type: StringHtmlPipe, name: "stringHtml" }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
171
173
|
}
|
|
172
174
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ItemComponent, decorators: [{
|
|
173
175
|
type: Component,
|
|
@@ -176,7 +178,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
176
178
|
RouterModule,
|
|
177
179
|
TooltipDirective,
|
|
178
180
|
StringHtmlPipe,
|
|
179
|
-
], encapsulation: ViewEncapsulation.None, template: "<li #me [id]=\"'main-menu-' + item.id\" class=\"parent\" [attr.data-level]=\"level\" [class.reduced]=\"leftbarReduced\"\r\n [class.active]=\"!wideMode && active\" [class.expanded]=\"item.tree$Expanded\"\r\n [class.highlighted]=\"item.tree$Highlighted\" [class.li-thin-mode]=\"!wideMode\" [class.menu-item]=\"!wideMode\"\r\n [appTooltip]=\"level===1 && !active ? caption : undefined\" [position]=\"'right'\">\r\n <div class=\"menu-item-wrapper\" [attr.data-level]=\"level\" (click)=\"onClick($event, item)\"\r\n [class.module-thin-mode]=\"!wideMode && level===1\" [class.thin-branch]=\"!wideMode && level > 1\">\r\n\r\n @if (wideMode) {\r\n @if (!!!leftbarReduced) {\r\n @if (!!hasChildren) {\r\n @if (!item.tree$Selected) {\r\n <i [attr.data-level]=\"level\" class=\"custom-icon-parent-right\"></i>\r\n } @else {\r\n <i [attr.data-level]=\"level\" class=\"custom-icon-parent-down\"></i>\r\n }\r\n } @else {\r\n @if (item.tree$Selected && item.code !== 'MENU.DASHBOARD' && item.code !== 'MENU.HOME') {\r\n <i [attr.data-level]=\"level\" class=\"custom-icon-child-right\"></i>\r\n }\r\n }\r\n }\r\n }\r\n\r\n @if (!!item.iconSvg) {\r\n <i [attr.data-level]=\"level\" class=\"'module-icon'\"\r\n [appTooltip]=\"wideMode ? caption : undefined\" (click)=\"onModuleIconClick($event, item);false\" [ngStyle]=\"{\r\n position: 'absolute',\r\n left: wideMode ? '20px' : 'unset'\r\n }\"><span [innerHtml]=\"item.iconSvg | stringHtml\"></span></i>\r\n\r\n <!-- <span [innerHtml]=\"item.iconSvg | stringHtml\"></span> -->\r\n } @else if (!!item.iconClass) {\r\n <i [attr.data-level]=\"level\" [class]=\"item.iconClass + ' module-icon'\"\r\n [appTooltip]=\"wideMode ? caption : undefined\" (click)=\"onModuleIconClick($event, item);false\" [ngStyle]=\"{\r\n left: wideMode ? '20px' : 'unset'\r\n }\"></i>\r\n }\r\n\r\n @if (!wideMode || (!leftbarReduced && hasChildren)) {\r\n <a #link [attr.data-level]=\"level\" class=\"has-submenu\" [appTooltip]=\"level > 1 ? caption : undefined\"\r\n [class.thin-mode]=\"!wideMode\">\r\n <ng-container (click)=\"subArrowClicked($event, item);false\"> <!--false is important here-->\r\n <span #subArrow *ngIf=\"(!!item.pictureBase64 || !!item.pictureUri)\"\r\n [class]=\"'img-span plus level' + level\">\r\n <img [src]=\"item.pictureBase64 || item.pictureUri\" *ngIf=\"!!item.pictureBase64\">\r\n </span>\r\n <span #subArrow *ngIf=\"!!!item.pictureBase64 && !!!item.pictureUri\"\r\n [class]=\"'plus level' + level\"></span>\r\n </ng-container>\r\n\r\n <img *ngIf=\"(!!item.pictureBase64 || !!item.pictureUri)\" [src]=\"item.pictureBase64 || item.pictureUri\">\r\n\r\n {{ caption }}\r\n\r\n </a>\r\n } @else {\r\n <a [attr.data-level]=\"level\" [routerLink]=\"item.url\" (click)=\"onClick($event, item)\"\r\n [class.thin-mode]=\"!wideMode\" [appTooltip]=\"wideMode && caption\">\r\n {{ caption }}\r\n </a>\r\n }\r\n\r\n </div>\r\n\r\n @if (!!wideMode && !!hasChildren && !!item.tree$Children!.length && !!!leftbarReduced) {\r\n <ul #children [class.expanded]=\"!wideMode || item.tree$Expanded\" [class.ul-thin-mode]=\"!wideMode\" [ngStyle]=\"{\r\n padding: 0,\r\n width: !!wideMode ? (layoutService.leftBarCurrentWidth$.value - layoutService.basicSpacing - layoutService.scrollBarWidth + 5 + 'px') : ( layoutService.leftBarWideWidth$.value + 'px' ),\r\n }\" [class.submenu]=\"!wideMode\">\r\n <div>\r\n @for (child of item.tree$Children; track $index) {\r\n <app-item [item]=\"child\" [level]=\"level+1\" (clicked)=\"onClick($event, child)\"></app-item>\r\n }\r\n </div>\r\n </ul>\r\n }\r\n\r\n</li>", styles: [".navigator-container{--active-item-border-color: white;--line-height: 16px;--level-gap: 10px;--thin-mode-padding: 8px;--thin-mode-width: 66px;--wide-mode-width: 280px;--left-bar-current-width: 280px;--bg-color: #F1F1F1;--color: black;--hover-bg-color: #E1E3E5;--hover-color: black}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.navigator-container .d-none{display:none}.navigator-container svg{width:24px;height:24px}.navigator-container .module-thin-mode{display:flex!important;align-items:center!important;justify-content:center!important;padding:0!important;margin-bottom:5px!important;height:50px!important}.navigator-container .module-thin-mode svg{color:var(--color)}.navigator-container .module-thin-mode i{color:var(--color)!important}.navigator-container .li-thin-mode[data-level=\"1\"]{height:50px!important;margin:0!important}.navigator-container .li-thin-mode .thin-branch a{padding-left:15px;padding-right:15px;overflow:hidden;max-width:100%;text-overflow:ellipsis}.navigator-container .li-thin-mode .thin-branch:hover{background:#e1e3e5!important;border-radius:5px!important}.navigator-container .li-thin-mode:hover[data-level=\"1\"]>ul.ul-thin-mode{transform:translate(calc(var(--thin-mode-width)))}.navigator-container .li-thin-mode:hover:not([data-level=\"1\"])>ul.ul-thin-mode{transform:translate(calc(var(--wide-mode-width) - var(--size-layout-block-cell-spacing)))}.navigator-container .li-thin-mode.active .module-thin-mode{background:var(--hover-bg-color)!important;border-radius:5px!important;width:50px!important;transform:translate(var(--thin-mode-padding))}.navigator-container .li-thin-mode.active .module-thin-mode i{color:var(--hover-color)!important}.navigator-container .li-thin-mode.active .module-thin-mode svg{color:var(--hover-color)!important}.navigator-container .li-thin-mode.active>ul.ul-thin-mode{background-color:#fff;opacity:1;height:unset;overflow-y:auto;box-shadow:.4rem 0 2rem #0000002e}.navigator-container .li-thin-mode.active>ul.ul-thin-mode>div>app-item>li>div>a{display:block!important}.navigator-container .li-thin-mode.active[data-level=\"1\"]>ul.ul-thin-mode{display:block;transform:translate(calc(var(--thin-mode-width)))}.navigator-container .li-thin-mode.active:not([data-level=\"1\"])>ul.ul-thin-mode{display:block;transform:translate(calc(var(--wide-mode-width) - var(--size-layout-block-cell-spacing)))}.navigator-container ul.ul-thin-mode{display:none}.navigator-container .parent{--children-height: 0px;box-sizing:border-box;width:100%;transition:width 1s ease-out}.navigator-container .parent ul{animation:fadeIn .25s linear}.navigator-container .parent i[class^=custom-icon-parent-],.navigator-container .parent i[class^=custom-icon-child-]{position:absolute}.navigator-container .parent i[class^=custom-icon-parent-][data-level=\"1\"],.navigator-container .parent i[class^=custom-icon-child-][data-level=\"1\"]{left:var(--size-left-bar-the-first-icon-left)!important}.navigator-container .parent i[class^=custom-icon-parent-][data-level=\"2\"],.navigator-container .parent i[class^=custom-icon-child-][data-level=\"2\"]{left:46px!important}.navigator-container .parent i[class^=custom-icon-child-][data-level=\"3\"]{left:calc(var(--size-header-logo-left) - 2 * var(--level-gap))!important}.navigator-container .parent i.module-icon{position:absolute;display:inline-block;font-size:var(--size-left-bar-icon-font-size)!important;width:var(--size-left-bar-icon-font-size)!important;height:var(--size-left-bar-icon-font-size)!important}.navigator-container .parent .menu-item-wrapper{position:relative!important;margin-left:0!important;padding-left:0;border:none!important;cursor:pointer}.navigator-container .parent .menu-item-wrapper[data-level=\"1\"].module-thin-mode:hover{background-color:#e1e3e5;width:50px;border-radius:5px;transform:translate(8px);color:#000}.navigator-container .parent .menu-item-wrapper:not([data-level=\"1\"]).module-thin-mode:hover{background-color:#e1e3e5;color:#000;padding:var(--size-layout-block-cell-spacing)}.navigator-container .parent a.thin-mode{left:0!important;display:none;padding-left:15px;padding-right:15px;overflow:hidden;text-overflow:ellipsis}.navigator-container .parent a{position:absolute!important;margin-left:0!important;padding-left:0;border:none!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;user-select:none;-webkit-user-select:none}.navigator-container .parent a[data-level=\"1\"]:not(.thin-mode){left:var(--size-header-logo-left);max-width:calc(var(--left-bar-current-width) - var(--size-header-logo-left) - var(--size-scrollbar-width) - var(--size-layout-block-cell-spacing) * 2)}.navigator-container .parent a[data-level=\"2\"]:not(.thin-mode){left:calc(var(--size-header-logo-left) + var(--level-gap));max-width:calc(var(--left-bar-current-width) - var(--size-header-logo-left) - var(--size-scrollbar-width) - var(--size-layout-block-cell-spacing) * 2 - var(--level-gap))}.navigator-container .parent a[data-level=\"3\"]:not(.thin-mode){left:calc(var(--size-header-logo-left) - var(--level-gap) + 3px);max-width:calc(var(--left-bar-current-width) - var(--size-header-logo-left) - var(--size-scrollbar-width) - var(--size-layout-block-cell-spacing) * 2 - var(--level-gap) * 2)}.navigator-container .parent[data-level=\"1\"]{margin:10px 0}.navigator-container .parent[data-level=\"1\"] a{margin-left:0;font-size:13px}.navigator-container .parent[data-level=\"2\"]:not(.ul-thin-mode) a{margin-left:10px;font-size:13px}.navigator-container .parent[data-level=\"3\"]:not(.ul-thin-mode) a{margin-left:20px;font-size:13px}.navigator-container .parent[data-level=\"2\"]>.menu-item-wrapper{margin-left:20px}.navigator-container .parent .menu-item-wrapper{height:35px;padding-left:0!important;display:flex;align-items:center;margin:0}.navigator-container .parent .menu-item-wrapper>i{display:inline-block;font-size:13px;color:#a9a9a9;cursor:pointer}.navigator-container .parent .menu-item-wrapper>i{color:#000}.navigator-container .parent li:not(.li-thin-mode):hover>.menu-item-wrapper:before{content:\"\";display:inline-block;position:absolute;left:0;height:33px;width:calc(var(--size-left-bar-full-width) - 20px);background-color:#eaf1fb;border-top-right-radius:50px;border-bottom-right-radius:50px}.navigator-container .parent>ul:not(.ul-thin-mode){position:relative;overflow:hidden;display:none;opacity:0;transition:opacity .5s ease-out}.navigator-container .parent>ul.ul-thin-mode{overflow-x:hidden;display:none;margin-left:0!important;opacity:1;transition:opacity .5s ease-out}.navigator-container .parent>ul.ul-thin-mode{overflow-y:auto}.navigator-container .parent.active[data-level=\"2\"]>.menu-item-wrapper>a{transition:.5s ease-out}.navigator-container .parent.highlighted>.menu-item-wrapper>a{color:var(--color-core-org-tree-highlighted)!important;font-weight:700!important}.navigator-container .parent.expanded>ul:not(.submenu){display:block;opacity:1;transition:opacity .5s ease-out}.navigator-container .parent.expanded[data-level=\"2\"]>ul{margin-left:25px}.navigator-container .parent:not(.li-thin-mode) a{margin-left:0}.navigator-container .parent.reduced .menu-item-wrapper{padding:0}.navigator-container .expanded[data-level=\"1\"]:not(.li-thin-mode)>.menu-item-wrapper{background-color:#fff;border-top-right-radius:50px;border-bottom-right-radius:50px;margin-right:2px;display:flex;justify-content:flex-start}.navigator-container .expanded[data-level=\"1\"]:not(.li-thin-mode)>.menu-item-wrapper:hover{background-color:#fff}.navigator-container .expanded>ul:not(.submenu){overflow:visible!important}.navigator-container .expanded.reduced>.menu-item-wrapper{justify-content:flex-start!important;border-top-left-radius:50px;border-bottom-left-radius:50px;width:37px}.navigator-container .parent.reduced>.menu-item-wrapper{justify-content:flex-start!important;border-radius:20px;width:37px}.navigator-container .custom-icon-parent-down{background-image:url('data:image/svg+xml,<svg width=\"8\" height=\"4\" viewBox=\"0 0 8 4\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M4 3.88867L0.535899 0.555338L7.4641 0.555339L4 3.88867Z\" fill=\"%23000000\"/></svg>');display:flex;align-items:center;justify-content:center;width:8px;height:5px;background-size:contain;background-repeat:no-repeat}.navigator-container .custom-icon-parent-right{background-image:url('data:image/svg+xml,<svg width=\"5\" height=\"5\" viewBox=\"0 0 4 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M4 4L0.666667 7.4641L0.666667 0.535898L4 4Z\" fill=\"%23000000\"/></svg>');display:block;position:absolute;width:8px;height:8px;align-items:center;justify-content:center;background-size:contain;background-repeat:no-repeat;float:left}.navigator-container .custom-icon-child-right{position:absolute;background-image:url('data:image/svg+xml,<svg width=\"9\" height=\"12\" viewBox=\"0 0 9 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M8.08811 5.23421C8.56399 5.63384 8.56399 6.36616 8.08811 6.76579L2.3931 11.5484C1.74247 12.0947 0.75 11.6322 0.75 10.7826L0.750001 1.21742C0.750001 0.367809 1.74247 -0.0947444 2.39309 0.451638L8.08811 5.23421Z\" fill=\"%23F37540\"/></svg>');display:flex;width:8px;height:8px;align-items:center;justify-content:center;background-size:contain;background-repeat:no-repeat}.navigator-container .custom-organization-icon{background-image:url('data:image/svg+xml,<svg width=\"20\" height=\"19\" viewBox=\"0 0 20 19\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M4.98901 9.6555H15.0112V11.5377H15.989V8.67772H10.489V6.72217H9.51123V8.67772H4.01123V11.5377H4.98901V9.6555Z\" fill=\"%23000000\"/><path d=\"M7.5555 12.2222H1.44439C1.12024 12.2222 0.80936 12.3509 0.580149 12.5801C0.350937 12.8094 0.222168 13.1202 0.222168 13.4444V17.1111C0.222168 17.4352 0.350937 17.7461 0.580149 17.9753C0.80936 18.2045 1.12024 18.3333 1.44439 18.3333H7.5555C7.87966 18.3333 8.19053 18.2045 8.41974 17.9753C8.64895 17.7461 8.77772 17.4352 8.77772 17.1111V13.4444C8.77772 13.1202 8.64895 12.8094 8.41974 12.5801C8.19053 12.3509 7.87966 12.2222 7.5555 12.2222ZM1.44439 17.1111V13.4444H7.5555V17.1111H1.44439Z\" fill=\"%23000000\"/><path d=\"M18.5555 12.2222H12.4444C12.1202 12.2222 11.8094 12.3509 11.5801 12.5801C11.3509 12.8094 11.2222 13.1202 11.2222 13.4444V17.1111C11.2222 17.4352 11.3509 17.7461 11.5801 17.9753C11.8094 18.2045 12.1202 18.3333 12.4444 18.3333H18.5555C18.8797 18.3333 19.1905 18.2045 19.4197 17.9753C19.649 17.7461 19.7777 17.4352 19.7777 17.1111V13.4444C19.7777 13.1202 19.649 12.8094 19.4197 12.5801C19.1905 12.3509 18.8797 12.2222 18.5555 12.2222ZM12.4444 17.1111V13.4444H18.5555V17.1111H12.4444Z\" fill=\"%23000000\"/><path d=\"M6.94439 6.11111H13.0555C13.3797 6.11111 13.6905 5.98234 13.9197 5.75313C14.149 5.52392 14.2777 5.21304 14.2777 4.88889V1.22222C14.2777 0.898069 14.149 0.587192 13.9197 0.35798C13.6905 0.128769 13.3797 0 13.0555 0H6.94439C6.62024 0 6.30936 0.128769 6.08015 0.35798C5.85094 0.587192 5.72217 0.898069 5.72217 1.22222V4.88889C5.72217 5.21304 5.85094 5.52392 6.08015 5.75313C6.30936 5.98234 6.62024 6.11111 6.94439 6.11111ZM6.94439 1.22222H13.0555V4.88889H6.94439V1.22222Z\" fill=\"%23000000\"/></svg>');display:flex;align-items:center;justify-content:center;width:15px;height:15px;background-size:contain;background-repeat:no-repeat}.navigator-container .custom-profile-icon{background-image:url('data:image/svg+xml,<svg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><rect x=\"0.75\" y=\"0.75\" width=\"16.5\" height=\"16.5\" rx=\"4.25\" stroke=\"%23000000\" stroke-width=\"1.5\"/><path d=\"M14.5164 16.5755V15.2137C14.5164 14.4914 14.2258 13.7987 13.7086 13.2879C13.1913 12.7772 12.4898 12.4902 11.7583 12.4902H6.2422C5.51071 12.4902 4.80919 12.7772 4.29195 13.2879C3.77471 13.7987 3.48413 14.4914 3.48413 15.2137V16.5755\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M9.00011 9.57227C10.4432 9.57227 11.613 8.39647 11.613 6.94605C11.613 5.49562 10.4432 4.31982 9.00011 4.31982C7.55704 4.31982 6.38721 5.49562 6.38721 6.94605C6.38721 8.39647 7.55704 9.57227 9.00011 9.57227Z\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>');display:flex;align-items:center;justify-content:center;width:15px;height:15px;background-size:contain;background-repeat:no-repeat}.navigator-container .custom-insurence-icon{background-image:url('data:image/svg+xml,<svg width=\"20\" height=\"18\" viewBox=\"0 0 20 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.8 1H17.2C17.6774 1 18.1352 1.1873 18.4728 1.5207C18.8104 1.8541 19 2.30628 19 2.77778V8.11111C19 10.4686 18.0518 12.7295 16.364 14.3965C14.6761 16.0635 12.3869 17 10 17C8.8181 17 7.64778 16.7701 6.55585 16.3234C5.46392 15.8767 4.47177 15.2219 3.63604 14.3965C1.94821 12.7295 1 10.4686 1 8.11111V2.77778C1 2.30628 1.18964 1.8541 1.52721 1.5207C1.86477 1.1873 2.32261 1 2.8 1V1Z\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M7 8.5L9.5 11.5L15 6\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>');display:flex;align-items:center;justify-content:center;width:15px;height:15px;background-size:contain;background-repeat:no-repeat}.navigator-container .custom-education-icon{background-image:url('data:image/svg+xml,<svg width=\"21\" height=\"19\" viewBox=\"0 0 21 19\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M1 1H6.66667C7.6686 1 8.62949 1.39801 9.33796 2.10649C10.0464 2.81496 10.4444 3.77585 10.4444 4.77778V18C10.4444 17.2486 10.1459 16.5279 9.61458 15.9965C9.08323 15.4652 8.36256 15.1667 7.61111 15.1667H1V1Z\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M19.8889 1H14.2222C13.2203 1 12.2594 1.39801 11.5509 2.10649C10.8425 2.81496 10.4445 3.77585 10.4445 4.77778V18C10.4445 17.2486 10.743 16.5279 11.2743 15.9965C11.8057 15.4652 12.5263 15.1667 13.2778 15.1667H19.8889V1Z\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>');display:flex;align-items:center;justify-content:center;width:15px;height:15px;background-size:contain;background-repeat:no-repeat}.navigator-container .parent.expanded.reduced>.menu-item-wrapper{background-color:#fff;left:10px!important}.navigator-container .parent.expanded.reduced>.menu-item-wrapper>i{left:9px!important;top:8px!important}.navigator-container .parent.reduced>.menu-item-wrapper{left:10px!important}.navigator-container .parent.reduced>.menu-item-wrapper>i{left:9px!important}\n"] }]
|
|
181
|
+
], encapsulation: ViewEncapsulation.None, template: "<li #me [id]=\"'main-menu-' + item.id\" class=\"parent\" [attr.data-level]=\"level\" [class.reduced]=\"leftbarReduced\"\r\n [class.active]=\"!wideMode && active\" [class.expanded]=\"item.tree$Expanded\"\r\n [class.highlighted]=\"item.tree$Highlighted\" [class.li-thin-mode]=\"!wideMode\" [class.menu-item]=\"!wideMode\"\r\n [appTooltip]=\"level===1 && !active ? caption : undefined\" [position]=\"'right'\" [ngStyle]=\"{\r\n marginTop: (level===1 && !wideMode) ? navigatorService.iconGutterY + 'px' : '',\r\n marginBottom: (level===1 && !wideMode) ? navigatorService.iconGutterY + 'px' : ''\r\n }\">\r\n <div class=\"menu-item-wrapper\" [attr.data-level]=\"level\" (click)=\"onClick($event, item)\"\r\n [class.module-thin-mode]=\"!wideMode && level===1\" [class.thin-branch]=\"!wideMode && level > 1\" [ngStyle]=\"{\r\n borderRadius: (level===1 && !wideMode) ? navigatorService.iconBorderRadius + 'px' : ''\r\n }\">\r\n\r\n @if (wideMode) {\r\n @if (!!!leftbarReduced) {\r\n @if (!!hasChildren) {\r\n @if (!item.tree$Selected) {\r\n <i [attr.data-level]=\"level\" class=\"custom-icon-parent-right\"></i>\r\n } @else {\r\n <i [attr.data-level]=\"level\" class=\"custom-icon-parent-down\"></i>\r\n }\r\n } @else {\r\n @if (item.tree$Selected && item.code !== 'MENU.DASHBOARD' && item.code !== 'MENU.HOME') {\r\n <i [attr.data-level]=\"level\" class=\"custom-icon-child-right\"></i>\r\n }\r\n }\r\n }\r\n }\r\n\r\n @if (!!item.iconSvg) {\r\n <i [attr.data-level]=\"level\" class=\"'module-icon'\"\r\n [appTooltip]=\"wideMode ? caption : undefined\" (click)=\"onModuleIconClick($event, item);false\" [ngStyle]=\"{\r\n position: 'absolute',\r\n left: wideMode ? '20px' : 'unset'\r\n }\"><span [innerHtml]=\"item.iconSvg | stringHtml\"></span></i>\r\n\r\n <!-- <span [innerHtml]=\"item.iconSvg | stringHtml\"></span> -->\r\n } @else if (!!item.iconClass) {\r\n <i [attr.data-level]=\"level\" [class]=\"item.iconClass + ' module-icon'\"\r\n [appTooltip]=\"wideMode ? caption : undefined\" (click)=\"onModuleIconClick($event, item);false\" [ngStyle]=\"{\r\n left: wideMode ? '20px' : 'unset'\r\n }\"></i>\r\n }\r\n\r\n @if (!wideMode || (!leftbarReduced && hasChildren)) {\r\n <a #link [attr.data-level]=\"level\" class=\"has-submenu\" [appTooltip]=\"level > 1 ? caption : undefined\"\r\n [class.thin-mode]=\"!wideMode\">\r\n <ng-container (click)=\"subArrowClicked($event, item);false\"> <!--false is important here-->\r\n <span #subArrow *ngIf=\"(!!item.pictureBase64 || !!item.pictureUri)\"\r\n [class]=\"'img-span plus level' + level\">\r\n <img [src]=\"item.pictureBase64 || item.pictureUri\" *ngIf=\"!!item.pictureBase64\">\r\n </span>\r\n <span #subArrow *ngIf=\"!!!item.pictureBase64 && !!!item.pictureUri\"\r\n [class]=\"'plus level' + level\"></span>\r\n </ng-container>\r\n\r\n <img *ngIf=\"(!!item.pictureBase64 || !!item.pictureUri)\" [src]=\"item.pictureBase64 || item.pictureUri\">\r\n\r\n {{ caption }}\r\n\r\n </a>\r\n } @else {\r\n <a [attr.data-level]=\"level\" [routerLink]=\"item.url\" (click)=\"onClick($event, item)\"\r\n [class.thin-mode]=\"!wideMode\" [appTooltip]=\"wideMode && caption\">\r\n {{ caption }}\r\n </a>\r\n }\r\n\r\n </div>\r\n\r\n @if (!!wideMode && !!hasChildren && !!item.tree$Children!.length && !!!leftbarReduced) {\r\n <ul #children [class.expanded]=\"!wideMode || item.tree$Expanded\" [class.ul-thin-mode]=\"!wideMode\" [ngStyle]=\"{\r\n padding: 0,\r\n width: !!wideMode ? (layoutService.leftBarCurrentWidth$.value - layoutService.basicSpacing - layoutService.scrollBarWidth + 5 + 'px') : ( layoutService.leftBarWideWidth$.value + 'px' ),\r\n }\" [class.submenu]=\"!wideMode\">\r\n <div>\r\n @for (child of item.tree$Children; track $index) {\r\n <app-item [item]=\"child\" [level]=\"level+1\" (clicked)=\"onClick($event, child)\"></app-item>\r\n }\r\n </div>\r\n </ul>\r\n }\r\n\r\n</li>", styles: [".navigator-container{--active-item-border-color: white;--line-height: 16px;--level-gap: 10px;--thin-mode-padding: 8px;--thin-mode-width: 66px;--wide-mode-width: 280px;--left-bar-current-width: 280px;--bg-color: #F1F1F1;--color: black;--hover-bg-color: #E1E3E5;--hover-color: black;--icon-border-radius: 8px;--icon-gutter-y: 8px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.navigator-container .d-none{display:none}.navigator-container svg{width:24px;height:24px}.navigator-container .module-thin-mode{display:flex!important;align-items:center!important;justify-content:center!important;padding:0!important;margin-bottom:5px!important;height:50px!important}.navigator-container .module-thin-mode svg{color:var(--color)}.navigator-container .module-thin-mode i{color:var(--color)!important}.navigator-container .li-thin-mode[data-level=\"1\"]{height:50px!important;margin-left:0!important;margin-right:0!important}.navigator-container .li-thin-mode .thin-branch a{padding-left:15px;padding-right:15px;overflow:hidden;max-width:100%;text-overflow:ellipsis}.navigator-container .li-thin-mode .thin-branch:hover{background:#e1e3e5!important;border-radius:5px!important}.navigator-container .li-thin-mode:hover[data-level=\"1\"]>ul.ul-thin-mode{transform:translate(calc(var(--thin-mode-width)))}.navigator-container .li-thin-mode:hover:not([data-level=\"1\"])>ul.ul-thin-mode{transform:translate(calc(var(--wide-mode-width) - var(--size-layout-block-cell-spacing)))}.navigator-container .li-thin-mode.active .module-thin-mode{background:var(--hover-bg-color)!important;border-radius:var(--icon-border-radius)!important;width:50px!important;transform:translate(var(--thin-mode-padding))}.navigator-container .li-thin-mode.active .module-thin-mode i{color:var(--hover-color)!important}.navigator-container .li-thin-mode.active .module-thin-mode svg{color:var(--hover-color)!important}.navigator-container .li-thin-mode.active>ul.ul-thin-mode{background-color:#fff;opacity:1;height:unset;overflow-y:auto;box-shadow:.4rem 0 2rem #0000002e}.navigator-container .li-thin-mode.active>ul.ul-thin-mode>div>app-item>li>div>a{display:block!important}.navigator-container .li-thin-mode.active[data-level=\"1\"]>ul.ul-thin-mode{display:block;transform:translate(calc(var(--thin-mode-width)))}.navigator-container .li-thin-mode.active:not([data-level=\"1\"])>ul.ul-thin-mode{display:block;transform:translate(calc(var(--wide-mode-width) - var(--size-layout-block-cell-spacing)))}.navigator-container ul.ul-thin-mode{display:none}.navigator-container .parent{--children-height: 0px;box-sizing:border-box;width:100%;transition:width 1s ease-out}.navigator-container .parent ul{animation:fadeIn .25s linear}.navigator-container .parent i[class^=custom-icon-parent-],.navigator-container .parent i[class^=custom-icon-child-]{position:absolute}.navigator-container .parent i[class^=custom-icon-parent-][data-level=\"1\"],.navigator-container .parent i[class^=custom-icon-child-][data-level=\"1\"]{left:var(--size-left-bar-the-first-icon-left)!important}.navigator-container .parent i[class^=custom-icon-parent-][data-level=\"2\"],.navigator-container .parent i[class^=custom-icon-child-][data-level=\"2\"]{left:46px!important}.navigator-container .parent i[class^=custom-icon-child-][data-level=\"3\"]{left:calc(var(--size-header-logo-left) - 2 * var(--level-gap))!important}.navigator-container .parent i.module-icon{position:absolute;display:inline-block;font-size:var(--size-left-bar-icon-font-size)!important;width:var(--size-left-bar-icon-font-size)!important;height:var(--size-left-bar-icon-font-size)!important}.navigator-container .parent .menu-item-wrapper{position:relative!important;margin-left:0!important;padding-left:0;border:none!important;cursor:pointer}.navigator-container .parent .menu-item-wrapper[data-level=\"1\"].module-thin-mode:hover{background-color:var(--hover-bg-color);width:50px;border-radius:5px;transform:translate(8px);color:var(--hover-color)!important}.navigator-container .parent .menu-item-wrapper:not([data-level=\"1\"]).module-thin-mode:hover{background-color:#e1e3e5;color:#000;padding:var(--size-layout-block-cell-spacing)}.navigator-container .parent a.thin-mode{left:0!important;display:none;padding-left:15px;padding-right:15px;overflow:hidden;text-overflow:ellipsis}.navigator-container .parent a{position:absolute!important;margin-left:0!important;padding-left:0;border:none!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;user-select:none;-webkit-user-select:none}.navigator-container .parent a[data-level=\"1\"]:not(.thin-mode){left:var(--size-header-logo-left);max-width:calc(var(--left-bar-current-width) - var(--size-header-logo-left) - var(--size-scrollbar-width) - var(--size-layout-block-cell-spacing) * 2)}.navigator-container .parent a[data-level=\"2\"]:not(.thin-mode){left:calc(var(--size-header-logo-left) + var(--level-gap));max-width:calc(var(--left-bar-current-width) - var(--size-header-logo-left) - var(--size-scrollbar-width) - var(--size-layout-block-cell-spacing) * 2 - var(--level-gap))}.navigator-container .parent a[data-level=\"3\"]:not(.thin-mode){left:calc(var(--size-header-logo-left) - var(--level-gap) + 3px);max-width:calc(var(--left-bar-current-width) - var(--size-header-logo-left) - var(--size-scrollbar-width) - var(--size-layout-block-cell-spacing) * 2 - var(--level-gap) * 2)}.navigator-container .parent[data-level=\"1\"]{margin:10px 0}.navigator-container .parent[data-level=\"1\"] a{margin-left:0;font-size:13px}.navigator-container .parent[data-level=\"2\"]:not(.ul-thin-mode) a{margin-left:10px;font-size:13px}.navigator-container .parent[data-level=\"3\"]:not(.ul-thin-mode) a{margin-left:20px;font-size:13px}.navigator-container .parent[data-level=\"2\"]>.menu-item-wrapper{margin-left:20px}.navigator-container .parent .menu-item-wrapper{height:35px;padding-left:0!important;display:flex;align-items:center;margin:0}.navigator-container .parent .menu-item-wrapper>i{display:inline-block;font-size:13px;color:#a9a9a9;cursor:pointer}.navigator-container .parent .menu-item-wrapper>i{color:#000}.navigator-container .parent li:not(.li-thin-mode):hover>.menu-item-wrapper:before{content:\"\";display:inline-block;position:absolute;left:0;height:33px;width:calc(var(--size-left-bar-full-width) - 20px);background-color:#eaf1fb;border-top-right-radius:50px;border-bottom-right-radius:50px}.navigator-container .parent>ul:not(.ul-thin-mode){position:relative;overflow:hidden;display:none;opacity:0;transition:opacity .5s ease-out}.navigator-container .parent>ul.ul-thin-mode{overflow-x:hidden;display:none;margin-left:0!important;opacity:1;transition:opacity .5s ease-out}.navigator-container .parent>ul.ul-thin-mode{overflow-y:auto}.navigator-container .parent.active[data-level=\"2\"]>.menu-item-wrapper>a{transition:.5s ease-out}.navigator-container .parent.highlighted>.menu-item-wrapper>a{color:var(--color-core-org-tree-highlighted)!important;font-weight:700!important}.navigator-container .parent.expanded>ul:not(.submenu){display:block;opacity:1;transition:opacity .5s ease-out}.navigator-container .parent.expanded[data-level=\"2\"]>ul{margin-left:25px}.navigator-container .parent:not(.li-thin-mode) a{margin-left:0}.navigator-container .parent.reduced .menu-item-wrapper{padding:0}.navigator-container .expanded[data-level=\"1\"]:not(.li-thin-mode)>.menu-item-wrapper{background-color:#fff;border-top-right-radius:50px;border-bottom-right-radius:50px;margin-right:2px;display:flex;justify-content:flex-start}.navigator-container .expanded[data-level=\"1\"]:not(.li-thin-mode)>.menu-item-wrapper:hover{background-color:#fff}.navigator-container .expanded>ul:not(.submenu){overflow:visible!important}.navigator-container .expanded.reduced>.menu-item-wrapper{justify-content:flex-start!important;border-top-left-radius:50px;border-bottom-left-radius:50px;width:37px}.navigator-container .parent.reduced>.menu-item-wrapper{justify-content:flex-start!important;border-radius:20px;width:37px}.navigator-container .custom-icon-parent-down{background-image:url('data:image/svg+xml,<svg width=\"8\" height=\"4\" viewBox=\"0 0 8 4\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M4 3.88867L0.535899 0.555338L7.4641 0.555339L4 3.88867Z\" fill=\"%23000000\"/></svg>');display:flex;align-items:center;justify-content:center;width:8px;height:5px;background-size:contain;background-repeat:no-repeat}.navigator-container .custom-icon-parent-right{background-image:url('data:image/svg+xml,<svg width=\"5\" height=\"5\" viewBox=\"0 0 4 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M4 4L0.666667 7.4641L0.666667 0.535898L4 4Z\" fill=\"%23000000\"/></svg>');display:block;position:absolute;width:8px;height:8px;align-items:center;justify-content:center;background-size:contain;background-repeat:no-repeat;float:left}.navigator-container .custom-icon-child-right{position:absolute;background-image:url('data:image/svg+xml,<svg width=\"9\" height=\"12\" viewBox=\"0 0 9 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M8.08811 5.23421C8.56399 5.63384 8.56399 6.36616 8.08811 6.76579L2.3931 11.5484C1.74247 12.0947 0.75 11.6322 0.75 10.7826L0.750001 1.21742C0.750001 0.367809 1.74247 -0.0947444 2.39309 0.451638L8.08811 5.23421Z\" fill=\"%23F37540\"/></svg>');display:flex;width:8px;height:8px;align-items:center;justify-content:center;background-size:contain;background-repeat:no-repeat}.navigator-container .custom-organization-icon{background-image:url('data:image/svg+xml,<svg width=\"20\" height=\"19\" viewBox=\"0 0 20 19\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M4.98901 9.6555H15.0112V11.5377H15.989V8.67772H10.489V6.72217H9.51123V8.67772H4.01123V11.5377H4.98901V9.6555Z\" fill=\"%23000000\"/><path d=\"M7.5555 12.2222H1.44439C1.12024 12.2222 0.80936 12.3509 0.580149 12.5801C0.350937 12.8094 0.222168 13.1202 0.222168 13.4444V17.1111C0.222168 17.4352 0.350937 17.7461 0.580149 17.9753C0.80936 18.2045 1.12024 18.3333 1.44439 18.3333H7.5555C7.87966 18.3333 8.19053 18.2045 8.41974 17.9753C8.64895 17.7461 8.77772 17.4352 8.77772 17.1111V13.4444C8.77772 13.1202 8.64895 12.8094 8.41974 12.5801C8.19053 12.3509 7.87966 12.2222 7.5555 12.2222ZM1.44439 17.1111V13.4444H7.5555V17.1111H1.44439Z\" fill=\"%23000000\"/><path d=\"M18.5555 12.2222H12.4444C12.1202 12.2222 11.8094 12.3509 11.5801 12.5801C11.3509 12.8094 11.2222 13.1202 11.2222 13.4444V17.1111C11.2222 17.4352 11.3509 17.7461 11.5801 17.9753C11.8094 18.2045 12.1202 18.3333 12.4444 18.3333H18.5555C18.8797 18.3333 19.1905 18.2045 19.4197 17.9753C19.649 17.7461 19.7777 17.4352 19.7777 17.1111V13.4444C19.7777 13.1202 19.649 12.8094 19.4197 12.5801C19.1905 12.3509 18.8797 12.2222 18.5555 12.2222ZM12.4444 17.1111V13.4444H18.5555V17.1111H12.4444Z\" fill=\"%23000000\"/><path d=\"M6.94439 6.11111H13.0555C13.3797 6.11111 13.6905 5.98234 13.9197 5.75313C14.149 5.52392 14.2777 5.21304 14.2777 4.88889V1.22222C14.2777 0.898069 14.149 0.587192 13.9197 0.35798C13.6905 0.128769 13.3797 0 13.0555 0H6.94439C6.62024 0 6.30936 0.128769 6.08015 0.35798C5.85094 0.587192 5.72217 0.898069 5.72217 1.22222V4.88889C5.72217 5.21304 5.85094 5.52392 6.08015 5.75313C6.30936 5.98234 6.62024 6.11111 6.94439 6.11111ZM6.94439 1.22222H13.0555V4.88889H6.94439V1.22222Z\" fill=\"%23000000\"/></svg>');display:flex;align-items:center;justify-content:center;width:15px;height:15px;background-size:contain;background-repeat:no-repeat}.navigator-container .custom-profile-icon{background-image:url('data:image/svg+xml,<svg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><rect x=\"0.75\" y=\"0.75\" width=\"16.5\" height=\"16.5\" rx=\"4.25\" stroke=\"%23000000\" stroke-width=\"1.5\"/><path d=\"M14.5164 16.5755V15.2137C14.5164 14.4914 14.2258 13.7987 13.7086 13.2879C13.1913 12.7772 12.4898 12.4902 11.7583 12.4902H6.2422C5.51071 12.4902 4.80919 12.7772 4.29195 13.2879C3.77471 13.7987 3.48413 14.4914 3.48413 15.2137V16.5755\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M9.00011 9.57227C10.4432 9.57227 11.613 8.39647 11.613 6.94605C11.613 5.49562 10.4432 4.31982 9.00011 4.31982C7.55704 4.31982 6.38721 5.49562 6.38721 6.94605C6.38721 8.39647 7.55704 9.57227 9.00011 9.57227Z\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>');display:flex;align-items:center;justify-content:center;width:15px;height:15px;background-size:contain;background-repeat:no-repeat}.navigator-container .custom-insurence-icon{background-image:url('data:image/svg+xml,<svg width=\"20\" height=\"18\" viewBox=\"0 0 20 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.8 1H17.2C17.6774 1 18.1352 1.1873 18.4728 1.5207C18.8104 1.8541 19 2.30628 19 2.77778V8.11111C19 10.4686 18.0518 12.7295 16.364 14.3965C14.6761 16.0635 12.3869 17 10 17C8.8181 17 7.64778 16.7701 6.55585 16.3234C5.46392 15.8767 4.47177 15.2219 3.63604 14.3965C1.94821 12.7295 1 10.4686 1 8.11111V2.77778C1 2.30628 1.18964 1.8541 1.52721 1.5207C1.86477 1.1873 2.32261 1 2.8 1V1Z\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M7 8.5L9.5 11.5L15 6\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>');display:flex;align-items:center;justify-content:center;width:15px;height:15px;background-size:contain;background-repeat:no-repeat}.navigator-container .custom-education-icon{background-image:url('data:image/svg+xml,<svg width=\"21\" height=\"19\" viewBox=\"0 0 21 19\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M1 1H6.66667C7.6686 1 8.62949 1.39801 9.33796 2.10649C10.0464 2.81496 10.4444 3.77585 10.4444 4.77778V18C10.4444 17.2486 10.1459 16.5279 9.61458 15.9965C9.08323 15.4652 8.36256 15.1667 7.61111 15.1667H1V1Z\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M19.8889 1H14.2222C13.2203 1 12.2594 1.39801 11.5509 2.10649C10.8425 2.81496 10.4445 3.77585 10.4445 4.77778V18C10.4445 17.2486 10.743 16.5279 11.2743 15.9965C11.8057 15.4652 12.5263 15.1667 13.2778 15.1667H19.8889V1Z\" stroke=\"%23000000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>');display:flex;align-items:center;justify-content:center;width:15px;height:15px;background-size:contain;background-repeat:no-repeat}.navigator-container .parent.expanded.reduced>.menu-item-wrapper{background-color:#fff;left:10px!important}.navigator-container .parent.expanded.reduced>.menu-item-wrapper>i{left:9px!important;top:8px!important}.navigator-container .parent.reduced>.menu-item-wrapper{left:10px!important}.navigator-container .parent.reduced>.menu-item-wrapper>i{left:9px!important}\n"] }]
|
|
180
182
|
}], ctorParameters: () => [{ type: i1.Router }, { type: i2.NavigatorService }, { type: i3.MultiLanguageService }, { type: i4.LayoutService }, { type: i5.MenuService }], propDecorators: { item: [{
|
|
181
183
|
type: Input
|
|
182
184
|
}], level: [{
|
|
@@ -194,4 +196,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
194
196
|
type: ViewChild,
|
|
195
197
|
args: ['subArrow']
|
|
196
198
|
}] } });
|
|
197
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"item.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/navigator/navigator/item.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/navigator/navigator/item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, OnInit, OnDestroy, ViewChild, ViewEncapsulation, ChangeDetectorRef, ChangeDetectionStrategy, OnChanges, SimpleChanges, AfterViewInit } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { Router, RouterModule } from '@angular/router';\r\nimport { NavigatorService } from '../../../services/navigator.service';\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { LayoutService } from '../../../services/layout.service';\r\nimport { INavigatorItem } from '../../../interfaces/INavigatorItem';\r\nimport { MenuService } from '../../../services/menu.service';\r\nimport { CommonModule } from '@angular/common';\r\nimport { TooltipDirective } from '../../tooltip/tooltip.directive';\r\nimport { StringHtmlPipe } from '../../../app-pipes/string-html.pipe';\r\n\r\n@Component({\r\n  selector: 'app-item',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    RouterModule,\r\n    TooltipDirective,\r\n    StringHtmlPipe,\r\n    \r\n  ],\r\n  templateUrl: './item.component.html',\r\n  styleUrls: ['./item.component.scss'],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class ItemComponent implements OnChanges, OnInit, AfterViewInit, OnDestroy {\r\n\r\n  @Input() item!: INavigatorItem;\r\n  @Input() level!: number;\r\n  @ViewChild('me') me!: ElementRef;\r\n  @ViewChild('children') children!: ElementRef;\r\n  @ViewChild('link') link!: ElementRef;\r\n  @ViewChild('subArrow') subArrow!: ElementRef;\r\n\r\n  caption!: string;\r\n\r\n  hasChildren: boolean = false;\r\n  mainWindowState!: string;\r\n  expanded: boolean = false;\r\n  leftbarReduced!: boolean;\r\n  subscriptions: Subscription[] = [];\r\n\r\n  wideMode!: boolean;\r\n  currentWidth: number = 66;\r\n  active!: boolean;\r\n\r\n  constructor(\r\n    private router: Router,\r\n    public navigatorService: NavigatorService,\r\n    private mls: MultiLanguageService,\r\n    public layoutService: LayoutService,\r\n    private menuService: MenuService,\r\n  ) {\r\n    this.navigatorService.wideMode$.subscribe(x => this.wideMode = x);\r\n    this.layoutService.leftBarCurrentWidth$.subscribe(x => {\r\n      this.currentWidth = x;\r\n      this.me?.nativeElement.style.setProperty('--left-bar-current-width', x + 'px')\r\n    });\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['item']) {\r\n      const it = changes['item'];\r\n      if (it.currentValue.id === 382) {\r\n        console.log(\"item 382 changed, active = \", this.active)\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    if (this.item) {\r\n      if (this.item.tree$Children.length > 0) {\r\n        this.hasChildren = true;\r\n      }\r\n    }\r\n\r\n    this.navigatorService.activeItems$.subscribe(c => {\r\n      if (!c) return;\r\n      this.active = !!c.filter(x => x.id === this.item?.id).length\r\n      if (!!this.active) {\r\n        this.me?.nativeElement.classList.add(\"active\")\r\n      } else {\r\n        this.me?.nativeElement.classList.remove(\"active\")\r\n      }\r\n    })\r\n\r\n    this.subscriptions.push(\r\n      this.mls.lang$.subscribe(_ => {\r\n        this.caption = this.mls.trans(this.item!.code)\r\n      })\r\n    )\r\n\r\n    this.subscriptions.push(\r\n      this.layoutService.leftbarReduced$.subscribe(x => this.leftbarReduced = x)\r\n    )\r\n  }\r\n\r\n  subArrowClicked(event: Event, item: INavigatorItem) {\r\n\r\n    console.log(\"subArrowClicked triggered\")\r\n\r\n    event.stopPropagation();\r\n\r\n    if (!this.wideMode) {\r\n      let newActiveItems = this.navigatorService.activeItems$.value;\r\n      console.log(\"subArrowClicked newActiveItems be4 filtering\", newActiveItems)\r\n      newActiveItems = newActiveItems.filter(x => x.tree$Tier! < item.tree$Tier!);\r\n      newActiveItems.push(item);\r\n      console.log(\"subArrowClicked newActiveItems\", newActiveItems)\r\n      this.navigatorService.activeItems$.next(newActiveItems);\r\n    }\r\n\r\n\r\n    if (this.children.nativeElement.className === 'child sub-menu') {\r\n      this.children.nativeElement.className = 'child sub-menu expanded';\r\n      this.subArrow.nativeElement.className = this.subArrow.nativeElement.className.replace(' plus', '') + ' minus';\r\n    } else if (this.children.nativeElement.className === 'child sub-menu expanded') {\r\n      this.children.nativeElement.className = 'child sub-menu';\r\n      this.subArrow.nativeElement.className = this.subArrow.nativeElement.className.replace(' minus', '') + ' plus';\r\n    }\r\n  }\r\n\r\n  onClick(event: any, item: INavigatorItem) {\r\n\r\n    console.log(\"onClick triggered\")\r\n    event.preventDefault();\r\n    event.stopImmediatePropagation();\r\n\r\n    if (!this.wideMode) {\r\n\r\n      this.onModuleIconClick(event, item);\r\n      return;\r\n    }\r\n\r\n    if (!!this.wideMode && this.item!.tree$Selected == true && !!this.item!.tree$Parent && (this.item!.tree$Tier != 2 || this.item!.tree$Tier == 2 && this.item!.tree$Children.length == 0)) {\r\n      return\r\n    }\r\n\r\n    if (this.wideMode) {\r\n      if (this.children) {\r\n        const el = this.children.nativeElement;\r\n        const rect = el.getBoundingClientRect();\r\n        const height = rect.height;\r\n        if (height === 0) {\r\n          item.tree$Selected = true;\r\n        }\r\n        else {\r\n          if (item.tree$Tier == 1 || item.tree$Tier == 2) {\r\n            item.tree$Selected = false;\r\n          }\r\n        }\r\n        this.me.nativeElement.style.setProperty('--children-height', height + 'px')\r\n      } else {\r\n        item.tree$Selected = true;\r\n        this.menuService.navigation$.value.map(x => {\r\n          if (x.tree$Children) {\r\n            x.tree$Children.map((y: any) => {\r\n              if (y.tree$Children) {\r\n                y.tree$Children.map((z: any) => {\r\n                  if (z != item) {\r\n                    z.tree$Selected = false\r\n                  }\r\n                })\r\n              } else if (y != item) {\r\n                y.tree$Selected = false;\r\n              }\r\n            })\r\n          }\r\n        })\r\n      }\r\n\r\n    }\r\n\r\n    this.navigatorService.clickedItem$.next(item)\r\n\r\n    if (!!item.tree$Parent) {\r\n      localStorage.setItem('menuCurrentClicked', JSON.stringify(item));\r\n    }\r\n  }\r\n\r\n  onModuleIconClick(event: any, item: INavigatorItem) {\r\n    console.log(\"onModuleIconClick triggered\")\r\n    event.stopPropagation();\r\n\r\n    if (!this.navigatorService.clickedItem$.value) {\r\n      this.navigatorService.clickedItem$.next(item);\r\n      this.navigatorService.activeItems$.next([item]);\r\n    } else {\r\n      if (this.wideMode) {\r\n        this.navigatorService.clickedItem$.next(item);\r\n        this.navigatorService.activeItems$.next([item]);\r\n      } else {\r\n        if (this.navigatorService.clickedItem$.value.id !== item.id) {\r\n          this.navigatorService.clickedItem$.next(item);\r\n          this.navigatorService.activeItems$.next([item]);\r\n        } else {\r\n          this.navigatorService.clickedItem$.next(null);\r\n          this.navigatorService.activeItems$.next([]);\r\n        }\r\n      }\r\n    }\r\n\r\n  }\r\n\r\n  checkActive(): boolean {\r\n    return this.active;\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n      this.me.nativeElement.style.setProperty('--bg-color', this.navigatorService.backgroundColor);\r\n      this.me.nativeElement.style.setProperty('--color', this.navigatorService.color);\r\n      this.me.nativeElement.style.setProperty('--hover-bg-color', this.navigatorService.hoverBackgroundColor);\r\n      this.me.nativeElement.style.setProperty('--hover-color', this.navigatorService.hoverColor);\r\n    })\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.map(x => x.unsubscribe())\r\n  }\r\n\r\n}\r\n","<li #me [id]=\"'main-menu-' + item.id\" class=\"parent\" [attr.data-level]=\"level\" [class.reduced]=\"leftbarReduced\"\r\n    [class.active]=\"!wideMode && active\" [class.expanded]=\"item.tree$Expanded\"\r\n    [class.highlighted]=\"item.tree$Highlighted\" [class.li-thin-mode]=\"!wideMode\" [class.menu-item]=\"!wideMode\"\r\n    [appTooltip]=\"level===1 && !active ? caption : undefined\" [position]=\"'right'\">\r\n    <div class=\"menu-item-wrapper\" [attr.data-level]=\"level\" (click)=\"onClick($event, item)\"\r\n        [class.module-thin-mode]=\"!wideMode && level===1\" [class.thin-branch]=\"!wideMode && level > 1\">\r\n\r\n        @if (wideMode) {\r\n        @if (!!!leftbarReduced) {\r\n        @if (!!hasChildren) {\r\n        @if (!item.tree$Selected) {\r\n        <i [attr.data-level]=\"level\" class=\"custom-icon-parent-right\"></i>\r\n        } @else {\r\n        <i [attr.data-level]=\"level\" class=\"custom-icon-parent-down\"></i>\r\n        }\r\n        } @else {\r\n        @if (item.tree$Selected && item.code !== 'MENU.DASHBOARD' && item.code !== 'MENU.HOME') {\r\n        <i [attr.data-level]=\"level\" class=\"custom-icon-child-right\"></i>\r\n        }\r\n        }\r\n        }\r\n        }\r\n\r\n        @if (!!item.iconSvg) {\r\n        <i [attr.data-level]=\"level\" class=\"'module-icon'\"\r\n            [appTooltip]=\"wideMode ? caption : undefined\" (click)=\"onModuleIconClick($event, item);false\" [ngStyle]=\"{\r\n                position: 'absolute',\r\n                left: wideMode ? '20px' : 'unset'\r\n            }\"><span [innerHtml]=\"item.iconSvg | stringHtml\"></span></i>\r\n\r\n        <!-- <span [innerHtml]=\"item.iconSvg | stringHtml\"></span> -->\r\n        } @else if (!!item.iconClass) {\r\n        <i [attr.data-level]=\"level\" [class]=\"item.iconClass + ' module-icon'\"\r\n            [appTooltip]=\"wideMode ? caption : undefined\" (click)=\"onModuleIconClick($event, item);false\" [ngStyle]=\"{\r\n                left: wideMode ? '20px' : 'unset'\r\n            }\"></i>\r\n        }\r\n\r\n        @if (!wideMode || (!leftbarReduced && hasChildren)) {\r\n        <a #link [attr.data-level]=\"level\" class=\"has-submenu\" [appTooltip]=\"level > 1 ? caption : undefined\"\r\n            [class.thin-mode]=\"!wideMode\">\r\n            <ng-container (click)=\"subArrowClicked($event, item);false\"> <!--false is important here-->\r\n                <span #subArrow *ngIf=\"(!!item.pictureBase64 || !!item.pictureUri)\"\r\n                    [class]=\"'img-span plus level' + level\">\r\n                    <img [src]=\"item.pictureBase64 || item.pictureUri\" *ngIf=\"!!item.pictureBase64\">\r\n                </span>\r\n                <span #subArrow *ngIf=\"!!!item.pictureBase64 && !!!item.pictureUri\"\r\n                    [class]=\"'plus level' + level\"></span>\r\n            </ng-container>\r\n\r\n            <img *ngIf=\"(!!item.pictureBase64 || !!item.pictureUri)\" [src]=\"item.pictureBase64 || item.pictureUri\">\r\n\r\n            {{ caption }}\r\n\r\n        </a>\r\n        } @else {\r\n        <a [attr.data-level]=\"level\" [routerLink]=\"item.url\" (click)=\"onClick($event, item)\"\r\n            [class.thin-mode]=\"!wideMode\" [appTooltip]=\"wideMode && caption\">\r\n            {{ caption }}\r\n        </a>\r\n        }\r\n\r\n    </div>\r\n\r\n    @if (!!wideMode && !!hasChildren && !!item.tree$Children!.length && !!!leftbarReduced) {\r\n    <ul #children [class.expanded]=\"!wideMode || item.tree$Expanded\" [class.ul-thin-mode]=\"!wideMode\" [ngStyle]=\"{\r\n            padding: 0,\r\n            width: !!wideMode ? (layoutService.leftBarCurrentWidth$.value - layoutService.basicSpacing - layoutService.scrollBarWidth + 5 + 'px') : ( layoutService.leftBarWideWidth$.value + 'px' ),\r\n        }\" [class.submenu]=\"!wideMode\">\r\n        <div>\r\n            @for (child of item.tree$Children; track $index) {\r\n            <app-item [item]=\"child\" [level]=\"level+1\" (clicked)=\"onClick($event, child)\"></app-item>\r\n            }\r\n        </div>\r\n    </ul>\r\n    }\r\n\r\n</li>"]}
|
|
199
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"item.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/navigator/navigator/item.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/navigator/navigator/item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, OnInit, OnDestroy, ViewChild, ViewEncapsulation, ChangeDetectorRef, ChangeDetectionStrategy, OnChanges, SimpleChanges, AfterViewInit } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { Router, RouterModule } from '@angular/router';\r\nimport { NavigatorService } from '../../../services/navigator.service';\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { LayoutService } from '../../../services/layout.service';\r\nimport { INavigatorItem } from '../../../interfaces/INavigatorItem';\r\nimport { MenuService } from '../../../services/menu.service';\r\nimport { CommonModule } from '@angular/common';\r\nimport { TooltipDirective } from '../../tooltip/tooltip.directive';\r\nimport { StringHtmlPipe } from '../../../app-pipes/string-html.pipe';\r\n\r\n@Component({\r\n  selector: 'app-item',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    RouterModule,\r\n    TooltipDirective,\r\n    StringHtmlPipe,\r\n    \r\n  ],\r\n  templateUrl: './item.component.html',\r\n  styleUrls: ['./item.component.scss'],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class ItemComponent implements OnChanges, OnInit, AfterViewInit, OnDestroy {\r\n\r\n  @Input() item!: INavigatorItem;\r\n  @Input() level!: number;\r\n  @ViewChild('me') me!: ElementRef;\r\n  @ViewChild('children') children!: ElementRef;\r\n  @ViewChild('link') link!: ElementRef;\r\n  @ViewChild('subArrow') subArrow!: ElementRef;\r\n\r\n  caption!: string;\r\n\r\n  hasChildren: boolean = false;\r\n  mainWindowState!: string;\r\n  expanded: boolean = false;\r\n  leftbarReduced!: boolean;\r\n  subscriptions: Subscription[] = [];\r\n\r\n  wideMode!: boolean;\r\n  currentWidth: number = 66;\r\n  active!: boolean;\r\n\r\n  constructor(\r\n    private router: Router,\r\n    public navigatorService: NavigatorService,\r\n    private mls: MultiLanguageService,\r\n    public layoutService: LayoutService,\r\n    private menuService: MenuService,\r\n  ) {\r\n    this.navigatorService.wideMode$.subscribe(x => this.wideMode = x);\r\n    this.layoutService.leftBarCurrentWidth$.subscribe(x => {\r\n      this.currentWidth = x;\r\n      this.me?.nativeElement.style.setProperty('--left-bar-current-width', x + 'px')\r\n    });\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['item']) {\r\n      const it = changes['item'];\r\n      if (it.currentValue.id === 382) {\r\n        console.log(\"item 382 changed, active = \", this.active)\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    if (this.item) {\r\n      if (this.item.tree$Children.length > 0) {\r\n        this.hasChildren = true;\r\n      }\r\n    }\r\n\r\n    this.navigatorService.activeItems$.subscribe(c => {\r\n      if (!c) return;\r\n      this.active = !!c.filter(x => x.id === this.item?.id).length\r\n      if (!!this.active) {\r\n        this.me?.nativeElement.classList.add(\"active\")\r\n      } else {\r\n        this.me?.nativeElement.classList.remove(\"active\")\r\n      }\r\n    })\r\n\r\n    this.subscriptions.push(\r\n      this.mls.lang$.subscribe(_ => {\r\n        this.caption = this.mls.trans(this.item!.code)\r\n      })\r\n    )\r\n\r\n    this.subscriptions.push(\r\n      this.layoutService.leftbarReduced$.subscribe(x => this.leftbarReduced = x)\r\n    )\r\n  }\r\n\r\n  subArrowClicked(event: Event, item: INavigatorItem) {\r\n\r\n    console.log(\"subArrowClicked triggered\")\r\n\r\n    event.stopPropagation();\r\n\r\n    if (!this.wideMode) {\r\n      let newActiveItems = this.navigatorService.activeItems$.value;\r\n      console.log(\"subArrowClicked newActiveItems be4 filtering\", newActiveItems)\r\n      newActiveItems = newActiveItems.filter(x => x.tree$Tier! < item.tree$Tier!);\r\n      newActiveItems.push(item);\r\n      console.log(\"subArrowClicked newActiveItems\", newActiveItems)\r\n      this.navigatorService.activeItems$.next(newActiveItems);\r\n    }\r\n\r\n\r\n    if (this.children.nativeElement.className === 'child sub-menu') {\r\n      this.children.nativeElement.className = 'child sub-menu expanded';\r\n      this.subArrow.nativeElement.className = this.subArrow.nativeElement.className.replace(' plus', '') + ' minus';\r\n    } else if (this.children.nativeElement.className === 'child sub-menu expanded') {\r\n      this.children.nativeElement.className = 'child sub-menu';\r\n      this.subArrow.nativeElement.className = this.subArrow.nativeElement.className.replace(' minus', '') + ' plus';\r\n    }\r\n  }\r\n\r\n  onClick(event: any, item: INavigatorItem) {\r\n\r\n    console.log(\"onClick triggered\")\r\n    event.preventDefault();\r\n    event.stopImmediatePropagation();\r\n\r\n    if (!this.wideMode) {\r\n\r\n      this.onModuleIconClick(event, item);\r\n      return;\r\n    }\r\n\r\n    if (!!this.wideMode && this.item!.tree$Selected == true && !!this.item!.tree$Parent && (this.item!.tree$Tier != 2 || this.item!.tree$Tier == 2 && this.item!.tree$Children.length == 0)) {\r\n      return\r\n    }\r\n\r\n    if (this.wideMode) {\r\n      if (this.children) {\r\n        const el = this.children.nativeElement;\r\n        const rect = el.getBoundingClientRect();\r\n        const height = rect.height;\r\n        if (height === 0) {\r\n          item.tree$Selected = true;\r\n        }\r\n        else {\r\n          if (item.tree$Tier == 1 || item.tree$Tier == 2) {\r\n            item.tree$Selected = false;\r\n          }\r\n        }\r\n        this.me.nativeElement.style.setProperty('--children-height', height + 'px')\r\n      } else {\r\n        item.tree$Selected = true;\r\n        this.menuService.navigation$.value.map(x => {\r\n          if (x.tree$Children) {\r\n            x.tree$Children.map((y: any) => {\r\n              if (y.tree$Children) {\r\n                y.tree$Children.map((z: any) => {\r\n                  if (z != item) {\r\n                    z.tree$Selected = false\r\n                  }\r\n                })\r\n              } else if (y != item) {\r\n                y.tree$Selected = false;\r\n              }\r\n            })\r\n          }\r\n        })\r\n      }\r\n\r\n    }\r\n\r\n    this.navigatorService.clickedItem$.next(item)\r\n\r\n    if (!!item.tree$Parent) {\r\n      localStorage.setItem('menuCurrentClicked', JSON.stringify(item));\r\n    }\r\n  }\r\n\r\n  onModuleIconClick(event: any, item: INavigatorItem) {\r\n    console.log(\"onModuleIconClick triggered\")\r\n    event.stopPropagation();\r\n\r\n    if (!this.navigatorService.clickedItem$.value) {\r\n      this.navigatorService.clickedItem$.next(item);\r\n      this.navigatorService.activeItems$.next([item]);\r\n    } else {\r\n      if (this.wideMode) {\r\n        this.navigatorService.clickedItem$.next(item);\r\n        this.navigatorService.activeItems$.next([item]);\r\n      } else {\r\n        if (this.navigatorService.clickedItem$.value.id !== item.id) {\r\n          this.navigatorService.clickedItem$.next(item);\r\n          this.navigatorService.activeItems$.next([item]);\r\n        } else {\r\n          this.navigatorService.clickedItem$.next(null);\r\n          this.navigatorService.activeItems$.next([]);\r\n        }\r\n      }\r\n    }\r\n\r\n  }\r\n\r\n  checkActive(): boolean {\r\n    return this.active;\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n      this.me.nativeElement.style.setProperty('--bg-color', this.navigatorService.backgroundColor);\r\n      this.me.nativeElement.style.setProperty('--color', this.navigatorService.color);\r\n      this.me.nativeElement.style.setProperty('--hover-bg-color', this.navigatorService.hoverBackgroundColor);\r\n      this.me.nativeElement.style.setProperty('--hover-color', this.navigatorService.hoverColor);\r\n      this.me.nativeElement.style.setProperty('--icon-border-radius', this.navigatorService.iconBorderRadius + 'px');\r\n      this.me.nativeElement.style.setProperty('--icon-gutter-y', this.navigatorService.iconGutterY + 'px');\r\n    })\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.map(x => x.unsubscribe())\r\n  }\r\n\r\n}\r\n","<li #me [id]=\"'main-menu-' + item.id\" class=\"parent\" [attr.data-level]=\"level\" [class.reduced]=\"leftbarReduced\"\r\n    [class.active]=\"!wideMode && active\" [class.expanded]=\"item.tree$Expanded\"\r\n    [class.highlighted]=\"item.tree$Highlighted\" [class.li-thin-mode]=\"!wideMode\" [class.menu-item]=\"!wideMode\"\r\n    [appTooltip]=\"level===1 && !active ? caption : undefined\" [position]=\"'right'\" [ngStyle]=\"{\r\n        marginTop: (level===1 && !wideMode) ? navigatorService.iconGutterY + 'px' : '',\r\n        marginBottom: (level===1 && !wideMode) ? navigatorService.iconGutterY + 'px' : ''\r\n    }\">\r\n    <div class=\"menu-item-wrapper\" [attr.data-level]=\"level\" (click)=\"onClick($event, item)\"\r\n        [class.module-thin-mode]=\"!wideMode && level===1\" [class.thin-branch]=\"!wideMode && level > 1\" [ngStyle]=\"{\r\n            borderRadius: (level===1 && !wideMode) ? navigatorService.iconBorderRadius + 'px' : ''\r\n        }\">\r\n\r\n        @if (wideMode) {\r\n        @if (!!!leftbarReduced) {\r\n        @if (!!hasChildren) {\r\n        @if (!item.tree$Selected) {\r\n        <i [attr.data-level]=\"level\" class=\"custom-icon-parent-right\"></i>\r\n        } @else {\r\n        <i [attr.data-level]=\"level\" class=\"custom-icon-parent-down\"></i>\r\n        }\r\n        } @else {\r\n        @if (item.tree$Selected && item.code !== 'MENU.DASHBOARD' && item.code !== 'MENU.HOME') {\r\n        <i [attr.data-level]=\"level\" class=\"custom-icon-child-right\"></i>\r\n        }\r\n        }\r\n        }\r\n        }\r\n\r\n        @if (!!item.iconSvg) {\r\n        <i [attr.data-level]=\"level\" class=\"'module-icon'\"\r\n            [appTooltip]=\"wideMode ? caption : undefined\" (click)=\"onModuleIconClick($event, item);false\" [ngStyle]=\"{\r\n                position: 'absolute',\r\n                left: wideMode ? '20px' : 'unset'\r\n            }\"><span [innerHtml]=\"item.iconSvg | stringHtml\"></span></i>\r\n\r\n        <!-- <span [innerHtml]=\"item.iconSvg | stringHtml\"></span> -->\r\n        } @else if (!!item.iconClass) {\r\n        <i [attr.data-level]=\"level\" [class]=\"item.iconClass + ' module-icon'\"\r\n            [appTooltip]=\"wideMode ? caption : undefined\" (click)=\"onModuleIconClick($event, item);false\" [ngStyle]=\"{\r\n                left: wideMode ? '20px' : 'unset'\r\n            }\"></i>\r\n        }\r\n\r\n        @if (!wideMode || (!leftbarReduced && hasChildren)) {\r\n        <a #link [attr.data-level]=\"level\" class=\"has-submenu\" [appTooltip]=\"level > 1 ? caption : undefined\"\r\n            [class.thin-mode]=\"!wideMode\">\r\n            <ng-container (click)=\"subArrowClicked($event, item);false\"> <!--false is important here-->\r\n                <span #subArrow *ngIf=\"(!!item.pictureBase64 || !!item.pictureUri)\"\r\n                    [class]=\"'img-span plus level' + level\">\r\n                    <img [src]=\"item.pictureBase64 || item.pictureUri\" *ngIf=\"!!item.pictureBase64\">\r\n                </span>\r\n                <span #subArrow *ngIf=\"!!!item.pictureBase64 && !!!item.pictureUri\"\r\n                    [class]=\"'plus level' + level\"></span>\r\n            </ng-container>\r\n\r\n            <img *ngIf=\"(!!item.pictureBase64 || !!item.pictureUri)\" [src]=\"item.pictureBase64 || item.pictureUri\">\r\n\r\n            {{ caption }}\r\n\r\n        </a>\r\n        } @else {\r\n        <a [attr.data-level]=\"level\" [routerLink]=\"item.url\" (click)=\"onClick($event, item)\"\r\n            [class.thin-mode]=\"!wideMode\" [appTooltip]=\"wideMode && caption\">\r\n            {{ caption }}\r\n        </a>\r\n        }\r\n\r\n    </div>\r\n\r\n    @if (!!wideMode && !!hasChildren && !!item.tree$Children!.length && !!!leftbarReduced) {\r\n    <ul #children [class.expanded]=\"!wideMode || item.tree$Expanded\" [class.ul-thin-mode]=\"!wideMode\" [ngStyle]=\"{\r\n            padding: 0,\r\n            width: !!wideMode ? (layoutService.leftBarCurrentWidth$.value - layoutService.basicSpacing - layoutService.scrollBarWidth + 5 + 'px') : ( layoutService.leftBarWideWidth$.value + 'px' ),\r\n        }\" [class.submenu]=\"!wideMode\">\r\n        <div>\r\n            @for (child of item.tree$Children; track $index) {\r\n            <app-item [item]=\"child\" [level]=\"level+1\" (clicked)=\"onClick($event, child)\"></app-item>\r\n            }\r\n        </div>\r\n    </ul>\r\n    }\r\n\r\n</li>"]}
|