ngx-histaff-alpha 3.7.4 → 3.7.5

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.
@@ -1,4 +1,5 @@
1
1
  import { Component, Input, ViewChild, ViewEncapsulation } from '@angular/core';
2
+ import { BehaviorSubject, buffer, debounceTime, filter, map } from 'rxjs';
2
3
  import { RouterModule } from '@angular/router';
3
4
  import { CommonModule } from '@angular/common';
4
5
  import { TooltipDirective } from '../../tooltip/tooltip.directive';
@@ -10,7 +11,7 @@ import * as i3 from "../../../services/multi-language.service";
10
11
  import * as i4 from "../../../services/layout.service";
11
12
  import * as i5 from "../../../services/menu.service";
12
13
  import * as i6 from "@angular/common";
13
- const DEFAULT_SVG = '<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather feather-help-circle"><circle cx="12" cy="12" r="10"></circle><path d="M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3"></path><line x1="12" y1="17" x2="12.01" y2="17"></line></svg>';
14
+ export const DEFAULT_SVG = '<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather feather-help-circle"><circle cx="12" cy="12" r="10"></circle><path d="M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3"></path><line x1="12" y1="17" x2="12.01" y2="17"></line></svg>';
14
15
  export class ItemComponent {
15
16
  constructor(router, navigatorService, mls, layoutService, menuService) {
16
17
  this.router = router;
@@ -23,6 +24,7 @@ export class ItemComponent {
23
24
  this.expanded = false;
24
25
  this.subscriptions = [];
25
26
  this.currentWidth = 66;
27
+ this.iconClickStream$ = new BehaviorSubject('');
26
28
  this.navigatorService.wideMode$.subscribe(x => this.wideMode = x);
27
29
  this.layoutService.leftBarCurrentWidth$.subscribe(x => {
28
30
  this.currentWidth = x;
@@ -32,6 +34,7 @@ export class ItemComponent {
32
34
  ngOnChanges(changes) {
33
35
  if (changes['item']) {
34
36
  const it = changes['item'].currentValue;
37
+ this.hasChildren = it?.tree$Children?.length > 0;
35
38
  this.caption = this.caption = this.mls.trans(this.item.code);
36
39
  }
37
40
  }
@@ -129,8 +132,9 @@ export class ItemComponent {
129
132
  }
130
133
  }
131
134
  onModuleIconClick(event, item) {
132
- console.log("onModuleIconClick triggered");
133
135
  event.stopPropagation();
136
+ this.navigatorService.clickedModuleItem$.next(item);
137
+ this.iconClickStream$.next(crypto.randomUUID());
134
138
  if (!this.navigatorService.clickedItem$.value) {
135
139
  this.navigatorService.clickedItem$.next(item);
136
140
  this.navigatorService.activeItems$.next([item]);
@@ -157,6 +161,10 @@ export class ItemComponent {
157
161
  }
158
162
  ngAfterViewInit() {
159
163
  setTimeout(() => {
164
+ this.subscriptions.push(this.iconClickStream$.pipe(buffer(this.iconClickStream$.pipe(debounceTime(250))), map(clicks => clicks.length), filter(clicksLength => clicksLength >= 5))
165
+ .subscribe(_ => {
166
+ this.navigatorService.showEditSvg$.next(true);
167
+ }));
160
168
  this.me.nativeElement.style.setProperty('--bg-color', this.navigatorService.backgroundColor);
161
169
  this.me.nativeElement.style.setProperty('--color', this.navigatorService.color);
162
170
  this.me.nativeElement.style.setProperty('--hover-bg-color', this.navigatorService.hoverBackgroundColor);
@@ -196,4 +204,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
196
204
  type: ViewChild,
197
205
  args: ['subArrow']
198
206
  }] } });
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":"AAAA,OAAO,EAAE,SAAS,EAAc,KAAK,EAAqB,SAAS,EAAE,iBAAiB,EAAuF,MAAM,eAAe,CAAC;AAEnM,OAAO,EAAU,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAMvD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AACnE,OAAO,EAAE,cAAc,EAAE,MAAM,qCAAqC,CAAC;;;;;;;;AAErE,MAAM,WAAW,GAAG,+WAA+W,CAAA;AAgBnY,MAAM,OAAO,aAAa;IAsBxB,YACU,MAAc,EACf,gBAAkC,EACjC,GAAyB,EAC1B,aAA4B,EAC3B,WAAwB;QAJxB,WAAM,GAAN,MAAM,CAAQ;QACf,qBAAgB,GAAhB,gBAAgB,CAAkB;QACjC,QAAG,GAAH,GAAG,CAAsB;QAC1B,kBAAa,GAAb,aAAa,CAAe;QAC3B,gBAAW,GAAX,WAAW,CAAa;QAjBlC,eAAU,GAAG,WAAW,CAAA;QAExB,gBAAW,GAAY,KAAK,CAAC;QAE7B,aAAQ,GAAY,KAAK,CAAC;QAE1B,kBAAa,GAAmB,EAAE,CAAC;QAGnC,iBAAY,GAAW,EAAE,CAAC;QAUxB,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;QAClE,IAAI,CAAC,aAAa,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YACpD,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;YACtB,IAAI,CAAC,EAAE,EAAE,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,0BAA0B,EAAE,CAAC,GAAG,IAAI,CAAC,CAAA;QAChF,CAAC,CAAC,CAAC;IACL,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,MAAM,CAAC,EAAE;YACnB,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,YAAY,CAAC;YACxC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,IAAK,CAAC,IAAI,CAAC,CAAA;SAC9D;IACH,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,IAAI,EAAE;YACb,IAAI,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE;gBACtC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;aACzB;SACF;QAED,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YAC/C,IAAI,CAAC,CAAC;gBAAE,OAAO;YACf,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,MAAM,CAAA;YAC5D,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM,EAAE;gBACjB,IAAI,CAAC,EAAE,EAAE,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAA;aAC/C;iBAAM;gBACL,IAAI,CAAC,EAAE,EAAE,aAAa,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAA;aAClD;QACH,CAAC,CAAC,CAAA;QAEF,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YAC3B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,IAAK,CAAC,IAAI,CAAC,CAAA;QAChD,CAAC,CAAC,CACH,CAAA;QAED,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC,CAC3E,CAAA;IACH,CAAC;IAED,eAAe,CAAC,KAAY,EAAE,IAAoB;QAEhD,OAAO,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAA;QAExC,KAAK,CAAC,eAAe,EAAE,CAAC;QAExB,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,cAAc,GAAG,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,KAAK,CAAC;YAC9D,OAAO,CAAC,GAAG,CAAC,8CAA8C,EAAE,cAAc,CAAC,CAAA;YAC3E,cAAc,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAU,GAAG,IAAI,CAAC,SAAU,CAAC,CAAC;YAC5E,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC1B,OAAO,CAAC,GAAG,CAAC,gCAAgC,EAAE,cAAc,CAAC,CAAA;YAC7D,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SACzD;QAGD,IAAI,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,SAAS,KAAK,gBAAgB,EAAE;YAC9D,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,SAAS,GAAG,yBAAyB,CAAC;YAClE,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,SAAS,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,GAAG,QAAQ,CAAC;SAC/G;aAAM,IAAI,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,SAAS,KAAK,yBAAyB,EAAE;YAC9E,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,SAAS,GAAG,gBAAgB,CAAC;YACzD,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,SAAS,CAAC,OAAO,CAAC,QAAQ,EAAE,EAAE,CAAC,GAAG,OAAO,CAAC;SAC/G;IACH,CAAC;IAED,OAAO,CAAC,KAAU,EAAE,IAAoB;QAEtC,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAA;QAChC,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,wBAAwB,EAAE,CAAC;QAEjC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAElB,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;YACpC,OAAO;SACR;QAED,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,IAAK,CAAC,aAAa,IAAI,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,IAAK,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,IAAK,CAAC,SAAS,IAAI,CAAC,IAAI,IAAI,CAAC,IAAK,CAAC,SAAS,IAAI,CAAC,IAAI,IAAI,CAAC,IAAK,CAAC,aAAa,CAAC,MAAM,IAAI,CAAC,CAAC,EAAE;YACvL,OAAM;SACP;QAED,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,MAAM,EAAE,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC;gBACvC,MAAM,IAAI,GAAG,EAAE,CAAC,qBAAqB,EAAE,CAAC;gBACxC,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;gBAC3B,IAAI,MAAM,KAAK,CAAC,EAAE;oBAChB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;iBAC3B;qBACI;oBACH,IAAI,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,IAAI,CAAC,SAAS,IAAI,CAAC,EAAE;wBAC9C,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;qBAC5B;iBACF;gBACD,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,mBAAmB,EAAE,MAAM,GAAG,IAAI,CAAC,CAAA;aAC5E;iBAAM;gBACL,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;gBAC1B,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;oBACzC,IAAI,CAAC,CAAC,aAAa,EAAE;wBACnB,CAAC,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAM,EAAE,EAAE;4BAC7B,IAAI,CAAC,CAAC,aAAa,EAAE;gCACnB,CAAC,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAM,EAAE,EAAE;oCAC7B,IAAI,CAAC,IAAI,IAAI,EAAE;wCACb,CAAC,CAAC,aAAa,GAAG,KAAK,CAAA;qCACxB;gCACH,CAAC,CAAC,CAAA;6BACH;iCAAM,IAAI,CAAC,IAAI,IAAI,EAAE;gCACpB,CAAC,CAAC,aAAa,GAAG,KAAK,CAAC;6BACzB;wBACH,CAAC,CAAC,CAAA;qBACH;gBACH,CAAC,CAAC,CAAA;aACH;SAEF;QAED,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QAE7C,IAAI,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE;YACtB,YAAY,CAAC,OAAO,CAAC,oBAAoB,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC;SAClE;IACH,CAAC;IAED,iBAAiB,CAAC,KAAU,EAAE,IAAoB;QAChD,OAAO,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAA;QAC1C,KAAK,CAAC,eAAe,EAAE,CAAC;QAExB,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,KAAK,EAAE;YAC7C,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC9C,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;SACjD;aAAM;YACL,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAC9C,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;aACjD;iBAAM;gBACL,IAAI,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,KAAK,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,EAAE;oBAC3D,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBAC9C,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;iBACjD;qBAAM;oBACL,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBAC9C,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;iBAC7C;aACF;SACF;IAEH,CAAC;IAED,WAAW;QACT,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,eAAe;QACb,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,YAAY,EAAE,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,CAAC;YAC7F,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,SAAS,EAAE,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;YAChF,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,kBAAkB,EAAE,IAAI,CAAC,gBAAgB,CAAC,oBAAoB,CAAC,CAAC;YACxG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,eAAe,EAAE,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAAC,CAAC;YAC3F,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,sBAAsB,EAAE,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,GAAG,IAAI,CAAC,CAAC;YAC/G,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,iBAAiB,EAAE,IAAI,CAAC,gBAAgB,CAAC,WAAW,GAAG,IAAI,CAAC,CAAC;QACvG,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,WAAW;QACT,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAA;IAC9C,CAAC;8GAnMU,aAAa;kGAAb,aAAa,0dC5B1B,owJAwFK,gqcD5DQ,aAAa,+EAVtB,YAAY,uNACZ,YAAY,gRACZ,gBAAgB,sGAChB,cAAc;;2FAOL,aAAa;kBAdzB,SAAS;+BACE,UAAU,cACR,IAAI,WACP;wBACP,YAAY;wBACZ,YAAY;wBACZ,gBAAgB;wBAChB,cAAc;qBAEf,iBAGc,iBAAiB,CAAC,IAAI;mMAI5B,IAAI;sBAAZ,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACW,EAAE;sBAAlB,SAAS;uBAAC,IAAI;gBACQ,QAAQ;sBAA9B,SAAS;uBAAC,UAAU;gBACF,IAAI;sBAAtB,SAAS;uBAAC,MAAM;gBACM,QAAQ;sBAA9B,SAAS;uBAAC,UAAU","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\nconst DEFAULT_SVG = '<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" class=\"feather feather-help-circle\"><circle cx=\"12\" cy=\"12\" r=\"10\"></circle><path d=\"M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3\"></path><line x1=\"12\" y1=\"17\" x2=\"12.01\" y2=\"17\"></line></svg>'\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  defaultSvg = DEFAULT_SVG\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'].currentValue;\r\n      this.caption = this.caption = this.mls.trans(this.item!.code)\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        } @else if (!item.parent) {\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]=\"defaultSvg | stringHtml\"></span></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 : undefined\">\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>"]}
207
+ //# 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 { BehaviorSubject, buffer, debounceTime, filter, map, 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\nexport const DEFAULT_SVG = '<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" class=\"feather feather-help-circle\"><circle cx=\"12\" cy=\"12\" r=\"10\"></circle><path d=\"M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3\"></path><line x1=\"12\" y1=\"17\" x2=\"12.01\" y2=\"17\"></line></svg>'\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  defaultSvg = DEFAULT_SVG\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  iconClickStream$ = new BehaviorSubject<string>('');\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: INavigatorItem = changes['item'].currentValue;\r\n      this.hasChildren = it?.tree$Children?.length > 0;\r\n      this.caption = this.caption = this.mls.trans(this.item!.code)\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    event.stopPropagation();\r\n    this.navigatorService.clickedModuleItem$.next(item);\r\n    this.iconClickStream$.next(crypto.randomUUID());\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\r\n      this.subscriptions.push(\r\n        this.iconClickStream$.pipe(\r\n          buffer(this.iconClickStream$.pipe(debounceTime(250))),\r\n          map(clicks => clicks.length),\r\n          filter(clicksLength => clicksLength >= 5))\r\n          .subscribe(_ => {\r\n            this.navigatorService.showEditSvg$.next(true);\r\n          })\r\n      )\r\n\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\nngOnDestroy(): 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        } @else if (!item.parent) {\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]=\"defaultSvg | stringHtml\"></span></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 : undefined\">\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>"]}
@@ -0,0 +1,134 @@
1
+ import { NgStyle } from '@angular/common';
2
+ import { Component } from '@angular/core';
3
+ import { FormsModule } from '@angular/forms';
4
+ import { CorePageHeaderComponent } from '../../../core-page-header/core-page-header/core-page-header.component';
5
+ import { DEFAULT_SVG } from '../item.component';
6
+ import { StringHtmlPipe } from '../../../../app-pipes/string-html.pipe';
7
+ import { CoreButtonGroupVnsComponent } from '../../../core-button-group-vns/core-button-group-vns/core-button-group-vns.component';
8
+ import { EnumCoreButtonVNSCode } from '../../../core-button-group-vns/core-button-group-vns/EnumCoreButtonVNSCode';
9
+ import { BaseComponent } from '../../../base-component/base/base.component';
10
+ import { TranslatePipe } from '../../../../app-pipes/translate.pipe';
11
+ import { alertOptions } from '../../../../constants/alertOptions';
12
+ import * as i0 from "@angular/core";
13
+ import * as i1 from "../../../../services/multi-language.service";
14
+ import * as i2 from "../../../../services/navigator.service";
15
+ import * as i3 from "../../../../services/app.service";
16
+ import * as i4 from "../../../alert/alert.service";
17
+ import * as i5 from "@angular/forms";
18
+ export class MenuItemSvgEditComponent extends BaseComponent {
19
+ constructor(mls, navigatorService, appService, alertService) {
20
+ super(mls);
21
+ this.mls = mls;
22
+ this.navigatorService = navigatorService;
23
+ this.appService = appService;
24
+ this.alertService = alertService;
25
+ this.buttonItems = [
26
+ EnumCoreButtonVNSCode.NONE_HEADER_SAVE,
27
+ EnumCoreButtonVNSCode.NONE_HEADER_CANCEL,
28
+ ];
29
+ this.navigatorService.clickedModuleItem$.subscribe(x => {
30
+ this.id = x?.id;
31
+ this.code = x?.code;
32
+ this.svg = x?.iconSvg || DEFAULT_SVG;
33
+ });
34
+ }
35
+ onButtonClick(e) {
36
+ switch (e.code) {
37
+ case EnumCoreButtonVNSCode.NONE_HEADER_CANCEL:
38
+ this.navigatorService.showEditSvg$.next(false);
39
+ break;
40
+ case EnumCoreButtonVNSCode.NONE_HEADER_SAVE:
41
+ const result = this.validateSvg(this.svg);
42
+ if (!result.isValid) {
43
+ // Inform the user about the errors
44
+ console.log('SVG is invalid due to the following errors:');
45
+ result.errors.forEach(error => this.alertService.error(error, alertOptions));
46
+ break;
47
+ }
48
+ if (!!this.navigatorService.clickedItem$.value?.id) {
49
+ const request = {
50
+ id: this.navigatorService.clickedItem$.value?.id,
51
+ iconSvg: this.svg
52
+ };
53
+ this.subscriptions.push(this.appService.post("/api/SysMenu/UpdateIconSvg", request).subscribe(x => {
54
+ if (x.ok && x.status === 200 && x.body?.statusCode === 200) {
55
+ // Update UI icon
56
+ // Find the li element by id
57
+ const liElement = document.getElementById("main-menu-" + x.body.innerBody?.id);
58
+ // Check if the li element exists
59
+ if (liElement) {
60
+ // Find the closest child <svg> element inside the <i> tag within the liElement
61
+ const svgElement = liElement.querySelector(":scope > div i > span > svg");
62
+ // Check if the svg element exists
63
+ if (svgElement) {
64
+ // Get the new SVG markup from your data (e.g., x.body.innerBody?.iconSvg)
65
+ const newSvgMarkup = x.body.innerBody?.iconSvg || DEFAULT_SVG;
66
+ // Check if the newSvgMarkup exists and is not empty
67
+ if (newSvgMarkup) {
68
+ // Replace the old <svg> with the new SVG markup directly
69
+ svgElement.outerHTML = newSvgMarkup;
70
+ }
71
+ }
72
+ }
73
+ this.navigatorService.showEditSvg$.next(false);
74
+ }
75
+ }));
76
+ }
77
+ break;
78
+ default:
79
+ break;
80
+ }
81
+ }
82
+ validateSvg(svgString) {
83
+ if (!svgString)
84
+ return { isValid: true, errors: [] };
85
+ const errors = [];
86
+ // Create a temporary DOM element to parse the string
87
+ const parser = new DOMParser();
88
+ const svgDoc = parser.parseFromString(svgString, 'image/svg+xml');
89
+ const svgElement = svgDoc.querySelector('svg');
90
+ // If there is no <svg> element, return an error
91
+ if (!svgElement) {
92
+ errors.push('The provided string does not contain a valid <svg> element.');
93
+ return { isValid: false, errors };
94
+ }
95
+ // Check for the width, height, and viewBox attributes
96
+ const width = svgElement.getAttribute('width');
97
+ const height = svgElement.getAttribute('height');
98
+ const viewBox = svgElement.getAttribute('viewBox');
99
+ const stroke = svgElement.getAttribute('stroke');
100
+ // Validate each attribute and push corresponding errors if invalid
101
+ if (width !== '24') {
102
+ errors.push(`Expected width="24", but found width="${width}".`);
103
+ }
104
+ if (height !== '24') {
105
+ errors.push(`Expected height="24", but found height="${height}".`);
106
+ }
107
+ if (viewBox !== '0 0 24 24') {
108
+ errors.push(`Expected viewBox="0 0 24 24", but found viewBox="${viewBox}".`);
109
+ }
110
+ if (stroke !== 'currentColor' && stroke !== 'currentcolor') {
111
+ errors.push(`Expected stroke="currentColor" or stroke="currentcolor", but found stroke="${stroke}".`);
112
+ }
113
+ // If there are errors, return them along with isValid: false
114
+ if (errors.length > 0) {
115
+ return { isValid: false, errors };
116
+ }
117
+ // If everything is valid, return isValid: true with no errors
118
+ return { isValid: true, errors };
119
+ }
120
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: MenuItemSvgEditComponent, deps: [{ token: i1.MultiLanguageService }, { token: i2.NavigatorService }, { token: i3.AppService }, { token: i4.AlertService }], target: i0.ɵɵFactoryTarget.Component }); }
121
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: MenuItemSvgEditComponent, isStandalone: true, selector: "menu-item-svg-edit", usesInheritance: true, ngImport: i0, template: "<div class=\"modal-container\">\r\n <div class=\"modal-container-root\">\r\n <div class=\"edit-container\">\r\n\r\n <core-page-header [title]=\"'EDIT_MENU_ITEM_SVG_ICON'\" [hideButtonGroup]=\"true\"></core-page-header>\r\n\r\n <div class=\"object-property w-100 fw700 color-gray\">\r\n <div>{{ id }} <span> \u2022 </span> {{ code }} <span> \u2022 </span> {{ (code || '') | translate: lang }} </div>\r\n </div>\r\n\r\n <div class=\"h15\"></div>\r\n\r\n <div class=\"d-flex d-flex-between\">\r\n\r\n <div class=\"entry\">\r\n <div class=\"label\">Enter Svg element here:</div>\r\n <textarea class=\"form-control\" [(ngModel)]=\"svg\" [rows]=\"'10'\"\r\n [ngStyle]=\"{ height: 'unset'}\"></textarea>\r\n </div>\r\n <div class=\"preview d-flex d-flex-v d-flex-between\">\r\n <div class=\"label\">Preview:</div>\r\n <div class=\"preview-icon\" [innerHtml]=\"svg | stringHtml\">\r\n\r\n </div>\r\n </div>\r\n\r\n </div>\r\n\r\n <div class=\"h15\"></div>\r\n <div class=\"d-flex d-flex-end\">\r\n <core-button-group-vns [showCaption]=\"true\" [forHeader]=\"false\" (buttonClick)=\"onButtonClick($event)\"\r\n [shownItems]=\"buttonItems\" class=\"buttonGroupCustom\"></core-button-group-vns>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [".edit-container{width:800px;height:385px;padding:0 15px 15px;background-color:#fff}.edit-container .entry{width:655px}.edit-container .preview{width:100px;height:100px}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: CorePageHeaderComponent, selector: "core-page-header", inputs: ["instanceNumber", "shownItems", "title", "hideButtonGroup"], outputs: ["buttonClick"] }, { kind: "pipe", type: StringHtmlPipe, name: "stringHtml" }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "component", type: CoreButtonGroupVnsComponent, selector: "core-button-group-vns", inputs: ["height", "instanceNumber", "forHeader", "fixedShow", "shownItems", "showCaption"], outputs: ["buttonClick"] }] }); }
122
+ }
123
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: MenuItemSvgEditComponent, decorators: [{
124
+ type: Component,
125
+ args: [{ selector: 'menu-item-svg-edit', standalone: true, imports: [
126
+ FormsModule,
127
+ NgStyle,
128
+ CorePageHeaderComponent,
129
+ StringHtmlPipe,
130
+ TranslatePipe,
131
+ CoreButtonGroupVnsComponent
132
+ ], template: "<div class=\"modal-container\">\r\n <div class=\"modal-container-root\">\r\n <div class=\"edit-container\">\r\n\r\n <core-page-header [title]=\"'EDIT_MENU_ITEM_SVG_ICON'\" [hideButtonGroup]=\"true\"></core-page-header>\r\n\r\n <div class=\"object-property w-100 fw700 color-gray\">\r\n <div>{{ id }} <span> \u2022 </span> {{ code }} <span> \u2022 </span> {{ (code || '') | translate: lang }} </div>\r\n </div>\r\n\r\n <div class=\"h15\"></div>\r\n\r\n <div class=\"d-flex d-flex-between\">\r\n\r\n <div class=\"entry\">\r\n <div class=\"label\">Enter Svg element here:</div>\r\n <textarea class=\"form-control\" [(ngModel)]=\"svg\" [rows]=\"'10'\"\r\n [ngStyle]=\"{ height: 'unset'}\"></textarea>\r\n </div>\r\n <div class=\"preview d-flex d-flex-v d-flex-between\">\r\n <div class=\"label\">Preview:</div>\r\n <div class=\"preview-icon\" [innerHtml]=\"svg | stringHtml\">\r\n\r\n </div>\r\n </div>\r\n\r\n </div>\r\n\r\n <div class=\"h15\"></div>\r\n <div class=\"d-flex d-flex-end\">\r\n <core-button-group-vns [showCaption]=\"true\" [forHeader]=\"false\" (buttonClick)=\"onButtonClick($event)\"\r\n [shownItems]=\"buttonItems\" class=\"buttonGroupCustom\"></core-button-group-vns>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [".edit-container{width:800px;height:385px;padding:0 15px 15px;background-color:#fff}.edit-container .entry{width:655px}.edit-container .preview{width:100px;height:100px}\n"] }]
133
+ }], ctorParameters: () => [{ type: i1.MultiLanguageService }, { type: i2.NavigatorService }, { type: i3.AppService }, { type: i4.AlertService }] });
134
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu-item-svg-edit.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/navigator/navigator/menu-item-svg-edit/menu-item-svg-edit.component.ts","../../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/navigator/navigator/menu-item-svg-edit/menu-item-svg-edit.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgStyle } from '@angular/common';\r\nimport { Component } from '@angular/core';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { CorePageHeaderComponent } from '../../../core-page-header/core-page-header/core-page-header.component';\r\nimport { NavigatorService } from '../../../../services/navigator.service';\r\nimport { DEFAULT_SVG } from '../item.component';\r\nimport { StringHtmlPipe } from '../../../../app-pipes/string-html.pipe';\r\nimport { CoreButtonGroupVnsComponent } from '../../../core-button-group-vns/core-button-group-vns/core-button-group-vns.component';\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 { BaseComponent } from '../../../base-component/base/base.component';\r\nimport { MultiLanguageService } from '../../../../services/multi-language.service';\r\nimport { TranslatePipe } from '../../../../app-pipes/translate.pipe';\r\nimport { AppService } from '../../../../services/app.service';\r\nimport { AlertService } from '../../../alert/alert.service';\r\nimport { alertOptions } from '../../../../constants/alertOptions';\r\n\r\ninterface IUpdateIconSvgRequest {\r\n  id: number;\r\n  iconSvg: string | undefined;\r\n}\r\n\r\n@Component({\r\n  selector: 'menu-item-svg-edit',\r\n  standalone: true,\r\n  imports: [\r\n    FormsModule,\r\n    NgStyle,\r\n    CorePageHeaderComponent,\r\n    StringHtmlPipe,\r\n    TranslatePipe,\r\n    CoreButtonGroupVnsComponent\r\n  ],\r\n  templateUrl: './menu-item-svg-edit.component.html',\r\n  styleUrl: './menu-item-svg-edit.component.scss'\r\n})\r\nexport class MenuItemSvgEditComponent extends BaseComponent {\r\n\r\n  id: number | undefined;\r\n  code: string | undefined;\r\n\r\n  svg!: string;\r\n\r\n  buttonItems: EnumCoreButtonVNSCode[] = [\r\n    EnumCoreButtonVNSCode.NONE_HEADER_SAVE,\r\n    EnumCoreButtonVNSCode.NONE_HEADER_CANCEL,\r\n  ]\r\n\r\n  constructor(\r\n    public override mls: MultiLanguageService,\r\n    private navigatorService: NavigatorService,\r\n    private appService: AppService,\r\n    private alertService: AlertService\r\n  ) {\r\n    super(mls);\r\n    this.navigatorService.clickedModuleItem$.subscribe(x => {\r\n      this.id = x?.id;\r\n      this.code = x?.code;\r\n      this.svg = x?.iconSvg || DEFAULT_SVG;\r\n    })\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        this.navigatorService.showEditSvg$.next(false);\r\n        break;\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_SAVE:\r\n\r\n        const result = this.validateSvg(this.svg);\r\n\r\n        if (!result.isValid) {\r\n          // Inform the user about the errors\r\n          console.log('SVG is invalid due to the following errors:');\r\n          result.errors.forEach(error => this.alertService.error(error, alertOptions));\r\n          break;\r\n        }\r\n\r\n        if (!!this.navigatorService.clickedItem$.value?.id) {\r\n          const request: IUpdateIconSvgRequest = {\r\n            id: this.navigatorService.clickedItem$.value?.id,\r\n            iconSvg: this.svg\r\n          }\r\n          this.subscriptions.push(\r\n            this.appService.post(\"/api/SysMenu/UpdateIconSvg\", request).subscribe(x => {\r\n              if (x.ok && x.status === 200 && x.body?.statusCode === 200) {\r\n\r\n                // Update UI icon\r\n                // Find the li element by id\r\n                const liElement = document.getElementById(\"main-menu-\" + x.body.innerBody?.id);\r\n\r\n                // Check if the li element exists\r\n                if (liElement) {\r\n                  // Find the closest child <svg> element inside the <i> tag within the liElement\r\n                  const svgElement = liElement.querySelector(\":scope > div i > span > svg\");\r\n\r\n                  // Check if the svg element exists\r\n                  if (svgElement) {\r\n                    // Get the new SVG markup from your data (e.g., x.body.innerBody?.iconSvg)\r\n                    const newSvgMarkup = x.body.innerBody?.iconSvg || DEFAULT_SVG;\r\n\r\n                    // Check if the newSvgMarkup exists and is not empty\r\n                    if (newSvgMarkup) {\r\n                      // Replace the old <svg> with the new SVG markup directly\r\n                      svgElement.outerHTML = newSvgMarkup;\r\n                    }\r\n                  }\r\n                }\r\n\r\n                this.navigatorService.showEditSvg$.next(false);\r\n              }\r\n            })\r\n          )\r\n        }\r\n        break;\r\n      default:\r\n        break;\r\n    }\r\n  }\r\n\r\n  validateSvg(svgString: string | undefined): { isValid: boolean; errors: string[] } {\r\n\r\n    if (!svgString) return { isValid: true, errors: [] }\r\n\r\n    const errors: string[] = [];\r\n\r\n    // Create a temporary DOM element to parse the string\r\n    const parser = new DOMParser();\r\n    const svgDoc = parser.parseFromString(svgString, 'image/svg+xml');\r\n    const svgElement = svgDoc.querySelector('svg');\r\n\r\n    // If there is no <svg> element, return an error\r\n    if (!svgElement) {\r\n      errors.push('The provided string does not contain a valid <svg> element.');\r\n      return { isValid: false, errors };\r\n    }\r\n\r\n    // Check for the width, height, and viewBox attributes\r\n    const width = svgElement.getAttribute('width');\r\n    const height = svgElement.getAttribute('height');\r\n    const viewBox = svgElement.getAttribute('viewBox');\r\n    const stroke = svgElement.getAttribute('stroke');\r\n\r\n    // Validate each attribute and push corresponding errors if invalid\r\n    if (width !== '24') {\r\n      errors.push(`Expected width=\"24\", but found width=\"${width}\".`);\r\n    }\r\n    if (height !== '24') {\r\n      errors.push(`Expected height=\"24\", but found height=\"${height}\".`);\r\n    }\r\n    if (viewBox !== '0 0 24 24') {\r\n      errors.push(`Expected viewBox=\"0 0 24 24\", but found viewBox=\"${viewBox}\".`);\r\n    }\r\n    if (stroke !== 'currentColor' && stroke !== 'currentcolor') {\r\n      errors.push(`Expected stroke=\"currentColor\" or stroke=\"currentcolor\", but found stroke=\"${stroke}\".`);\r\n    }\r\n\r\n    // If there are errors, return them along with isValid: false\r\n    if (errors.length > 0) {\r\n      return { isValid: false, errors };\r\n    }\r\n\r\n    // If everything is valid, return isValid: true with no errors\r\n    return { isValid: true, errors };\r\n  }\r\n}\r\n","<div class=\"modal-container\">\r\n    <div class=\"modal-container-root\">\r\n        <div class=\"edit-container\">\r\n\r\n            <core-page-header [title]=\"'EDIT_MENU_ITEM_SVG_ICON'\" [hideButtonGroup]=\"true\"></core-page-header>\r\n\r\n            <div class=\"object-property w-100 fw700 color-gray\">\r\n                <div>{{ id }} <span> • </span> {{ code }} <span> • </span> {{ (code || '') | translate: lang }} </div>\r\n            </div>\r\n\r\n            <div class=\"h15\"></div>\r\n\r\n            <div class=\"d-flex d-flex-between\">\r\n\r\n                <div class=\"entry\">\r\n                    <div class=\"label\">Enter Svg element here:</div>\r\n                    <textarea class=\"form-control\" [(ngModel)]=\"svg\" [rows]=\"'10'\"\r\n                        [ngStyle]=\"{ height: 'unset'}\"></textarea>\r\n                </div>\r\n                <div class=\"preview d-flex d-flex-v d-flex-between\">\r\n                    <div class=\"label\">Preview:</div>\r\n                    <div class=\"preview-icon\" [innerHtml]=\"svg | stringHtml\">\r\n\r\n                    </div>\r\n                </div>\r\n\r\n            </div>\r\n\r\n            <div class=\"h15\"></div>\r\n            <div class=\"d-flex d-flex-end\">\r\n                <core-button-group-vns [showCaption]=\"true\" [forHeader]=\"false\" (buttonClick)=\"onButtonClick($event)\"\r\n                    [shownItems]=\"buttonItems\" class=\"buttonGroupCustom\"></core-button-group-vns>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>"]}