ngx-histaff-alpha 2.5.2 → 2.5.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.
@@ -52,67 +52,49 @@ export class CoreButtonGroupVnsComponent extends BaseComponent {
52
52
  }
53
53
  }
54
54
  ngAfterViewInit() {
55
- setTimeout(() => {
56
- this.subscriptions.push(this.routingService.currentFunction$.subscribe(x => {
57
- this.function = x;
58
- this.currentFunctionAssigmentDone = true;
59
- if (!!this.forHeader) {
60
- if (!!this.isRootUser || !!this.isAdminUser) {
61
- this.buttons = CORE_VNS_BUTTONS.filter(x => !x.hidden).filter(button => {
62
- if (!!this.function) {
63
- return this.function.actionCodes.indexOf(button.code) >= 0 && button.isHeader;
55
+ if (!this.fixedShow) {
56
+ setTimeout(() => {
57
+ this.subscriptions.push(this.routingService.currentFunction$.subscribe(x => {
58
+ this.function = x;
59
+ this.currentFunctionAssigmentDone = true;
60
+ if (!!this.forHeader) {
61
+ if (!!this.isRootUser || !!this.isAdminUser) {
62
+ this.buttons = CORE_VNS_BUTTONS.filter(x => !x.hidden).filter(button => {
63
+ if (!!this.function) {
64
+ return this.function.actionCodes.indexOf(button.code) >= 0 && button.isHeader;
65
+ }
66
+ else {
67
+ return false;
68
+ }
69
+ });
70
+ }
71
+ else {
72
+ const functionFilter = this.authService.data$.value.permissionActions.filter(pa => {
73
+ return pa.functionId === this.function?.id;
74
+ });
75
+ if (functionFilter.length) {
76
+ const { allowedActionCodes } = functionFilter[0];
77
+ this.buttons = CORE_VNS_BUTTONS.filter(x => !!!x.hidden).filter(button => {
78
+ return allowedActionCodes.indexOf(button.code) >= 0 && button.isHeader;
79
+ });
64
80
  }
65
81
  else {
66
- return false;
82
+ this.buttons = [];
67
83
  }
68
- });
84
+ }
69
85
  }
70
86
  else {
71
- const functionFilter = this.authService.data$.value.permissionActions.filter(pa => {
72
- return pa.functionId === this.function?.id;
73
- });
74
- if (functionFilter.length) {
75
- const { allowedActionCodes } = functionFilter[0];
76
- this.buttons = CORE_VNS_BUTTONS.filter(x => !!!x.hidden).filter(button => {
77
- return allowedActionCodes.indexOf(button.code) >= 0 && button.isHeader;
78
- });
87
+ // To be improved
88
+ if (!!!this.shownItems) {
89
+ this.buttons = CORE_VNS_BUTTONS.filter(x => !!!x.isHeader);
79
90
  }
80
91
  else {
81
- this.buttons = [];
92
+ this.buttons = CORE_VNS_BUTTONS.filter(x => this.shownItems.includes(x.code));
82
93
  }
83
94
  }
84
- }
85
- else {
86
- // To be improved
87
- if (!!!this.shownItems) {
88
- this.buttons = CORE_VNS_BUTTONS.filter(x => !!!x.isHeader);
89
- }
90
- else {
91
- this.buttons = CORE_VNS_BUTTONS.filter(x => this.shownItems.includes(x.code));
92
- }
93
- }
94
- }));
95
- /*
96
- const filter = this.coreButtonGroupService.instances.filter(x => x.instanceNumber === this.instanceNumber);
97
- if (!!filter.length) {
98
- this.subscriptions.push(
99
- filter[0].mustBeHidden$.subscribe(mbh => {
100
- this.buttons.map(b => {
101
- if (mbh.includes(b.code)) {
102
- b.hidden = true;
103
- } else {
104
- b.hidden = false;
105
- }
106
- })
107
- })
108
- )
109
- } else {
110
- if (isDevMode()) {
111
- this.alertService.warn("Không tìm thấy instance number của nhóm nút", noneAutoClosedAlertOptions);
112
- }
113
- }
114
- */
115
- });
95
+ }));
96
+ });
97
+ }
116
98
  }
117
99
  swapTrioEditSaveCancel(editActive) {
118
100
  this.headerEdit = this.buttons.filter(x => x.code === EnumCoreButtonVNSCode.HEADER_EDIT);
@@ -150,7 +132,7 @@ export class CoreButtonGroupVnsComponent extends BaseComponent {
150
132
  this.coreButtonGroupService.instances = newInstances;
151
133
  }
152
134
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreButtonGroupVnsComponent, deps: [{ token: i1.MultiLanguageService }, { token: i2.Router }, { token: i3.AuthService }, { token: i4.RoutingService }, { token: i5.AlertService }, { token: i6.CoreButtonGroupService }], target: i0.ɵɵFactoryTarget.Component }); }
153
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: CoreButtonGroupVnsComponent, isStandalone: true, selector: "core-button-group-vns", inputs: { height: "height", instanceNumber: "instanceNumber", forHeader: "forHeader", shownItems: "shownItems", showCaption: "showCaption" }, outputs: { buttonClick: "buttonClick" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"core-button-group-vns-container\" [ngStyle]=\"{ height: height + 'px' }\">\r\n <div [ngStyle]=\"{ height: height + 'px' }\" class=\"setting-trigger d-flex d-flex-center\"\r\n *ngIf=\"!!isRootUser && !!forHeader\" (click)=\"onMapperClick()\"\r\n [appTooltip]=\"'UI_BUTTON_GROUP_SETTING_ADD_REMOVE_ACTION_ITEM_FOR_THIS_SCREEN' | translate : lang\"\r\n position=\"left\">\r\n <i class=\"feather-settings\"></i>\r\n </div>\r\n\r\n <div [ngStyle]=\"{ height: height + 'px' }\" class=\"separator\" *ngIf=\"!!isRootUser && !!forHeader\"></div>\r\n\r\n <ng-container *ngFor=\"let button of buttons\">\r\n <ng-container *ngIf=\"!button.hidden\">\r\n <core-button-vns [showCaption]=\"showCaption\" [data]=\"button\" [instanceNumber]=\"instanceNumber\"\r\n (buttonClick)=\"onButtonClick($event)\"></core-button-vns>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <span *ngIf=\"!!isRootUser && !!forHeader && !!!buttons.length\">{{ currentFunctionAssigmentDone ?\r\n ('UI_BUTTON_GROUP_NO_ITEM_AVAILABLE_YET' | translate : lang) : '' }}</span>\r\n</div>", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i7.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: CoreButtonVnsComponent, selector: "core-button-vns", inputs: ["height", "data", "instanceNumber", "disabled", "showCaption"], outputs: ["buttonClick"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "directive", type: TooltipDirective, selector: "[appTooltip]", inputs: ["appTooltip", "showAnyway", "position"] }] }); }
135
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: CoreButtonGroupVnsComponent, isStandalone: true, selector: "core-button-group-vns", inputs: { height: "height", instanceNumber: "instanceNumber", forHeader: "forHeader", fixedShow: "fixedShow", shownItems: "shownItems", showCaption: "showCaption" }, outputs: { buttonClick: "buttonClick" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"core-button-group-vns-container\" [ngStyle]=\"{ height: height + 'px' }\">\r\n <div [ngStyle]=\"{ height: height + 'px' }\" class=\"setting-trigger d-flex d-flex-center\"\r\n *ngIf=\"!!isRootUser && !!forHeader\" (click)=\"onMapperClick()\"\r\n [appTooltip]=\"'UI_BUTTON_GROUP_SETTING_ADD_REMOVE_ACTION_ITEM_FOR_THIS_SCREEN' | translate : lang\"\r\n position=\"left\">\r\n <i class=\"feather-settings\"></i>\r\n </div>\r\n\r\n <div [ngStyle]=\"{ height: height + 'px' }\" class=\"separator\" *ngIf=\"!!isRootUser && !!forHeader\"></div>\r\n\r\n <ng-container *ngFor=\"let button of buttons\">\r\n <ng-container *ngIf=\"!button.hidden\">\r\n <core-button-vns [showCaption]=\"showCaption\" [data]=\"button\" [instanceNumber]=\"instanceNumber\"\r\n (buttonClick)=\"onButtonClick($event)\"></core-button-vns>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <span *ngIf=\"!!isRootUser && !!forHeader && !!!buttons.length\">{{ currentFunctionAssigmentDone ?\r\n ('UI_BUTTON_GROUP_NO_ITEM_AVAILABLE_YET' | translate : lang) : '' }}</span>\r\n</div>", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i7.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: CoreButtonVnsComponent, selector: "core-button-vns", inputs: ["height", "data", "instanceNumber", "disabled", "showCaption"], outputs: ["buttonClick"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "directive", type: TooltipDirective, selector: "[appTooltip]", inputs: ["appTooltip", "showAnyway", "position"] }] }); }
154
136
  }
155
137
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreButtonGroupVnsComponent, decorators: [{
156
138
  type: Component,
@@ -167,6 +149,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
167
149
  type: Input
168
150
  }], forHeader: [{
169
151
  type: Input
152
+ }], fixedShow: [{
153
+ type: Input
170
154
  }], shownItems: [{
171
155
  type: Input
172
156
  }], showCaption: [{
@@ -174,4 +158,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
174
158
  }], buttonClick: [{
175
159
  type: Output
176
160
  }] } });
177
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-button-group-vns.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-button-group-vns/core-button-group-vns/core-button-group-vns.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-button-group-vns/core-button-group-vns/core-button-group-vns.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, AfterViewInit, Output, SimpleChanges, OnDestroy, OnChanges } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { ICoreButtonVNS } from './ICoreButtonVNS';\r\nimport { EnumCoreButtonVNSCode } from './EnumCoreButtonVNSCode';\r\nimport { BaseComponent } from '../../base-component/base/base.component';\r\nimport { AlertService } from '../../alert/alert.service';\r\nimport { CoreButtonGroupService } from '../core-button-group-service';\r\nimport { BehaviorSubject } from 'rxjs';\r\nimport { EnumTranslateKey } from \"alpha-global-constants\";\r\nimport { IFunctionWithFullActions, RoutingService } from '../../../services/routing.service';\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { AuthService } from '../../../services/auth.service';\r\nimport { alertOptions } from '../../../constants/alertOptions';\r\nimport { CommonModule } from '@angular/common';\r\nimport { MapAvatarToServerPipe } from '../../../app-pipes/map-avatar-to-server.pipe';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\nimport { CoreButtonVnsComponent } from '../core-button-vns/core-button-vns.component';\r\nimport { TooltipDirective } from '../../tooltip/tooltip.directive';\r\nimport { CORE_VNS_BUTTONS } from '../../../constants/CORE_VNS_BUTTONS';\r\n\r\n@Component({\r\n  selector: 'core-button-group-vns',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    CoreButtonVnsComponent,\r\n    MapAvatarToServerPipe,\r\n    TranslatePipe,\r\n    TooltipDirective\r\n  ],\r\n  templateUrl: './core-button-group-vns.component.html',\r\n  styleUrls: ['./core-button-group-vns.component.scss']\r\n})\r\nexport class CoreButtonGroupVnsComponent extends BaseComponent implements OnChanges, OnInit, AfterViewInit, OnDestroy {\r\n\r\n  @Input() height!: number;\r\n  @Input() instanceNumber!: number;\r\n  @Input() forHeader!: boolean;\r\n  @Input() shownItems!: EnumCoreButtonVNSCode[];\r\n  @Input() showCaption!: boolean;\r\n  @Output() buttonClick = new EventEmitter<ICoreButtonVNS>();\r\n  \r\n  buttons: ICoreButtonVNS[] = [];\r\n\r\n  isRootUser!: boolean | undefined;\r\n  isAdminUser!: boolean | undefined;\r\n  function!: IFunctionWithFullActions | undefined;\r\n  currentFunctionAssigmentDone!: boolean;\r\n\r\n\r\n  /* Bộ ba các nút dưới đây cần ẩn/hiện theo tình huống */\r\n  headerEdit!: ICoreButtonVNS[];\r\n  headerSave!: ICoreButtonVNS[];\r\n  headerCancel!: ICoreButtonVNS[];\r\n  /*** */\r\n\r\n  constructor(\r\n    public override mls: MultiLanguageService,\r\n    private router: Router,\r\n    private authService: AuthService,\r\n    private routingService: RoutingService,\r\n    private alertService: AlertService,\r\n    private coreButtonGroupService: CoreButtonGroupService\r\n  ) {\r\n    super(mls);\r\n  }\r\n\r\n  override ngOnInit(): void {\r\n\r\n    this.coreButtonGroupService.instances.push({\r\n      instanceNumber: this.instanceNumber,\r\n      mustBeHidden$: new BehaviorSubject<EnumCoreButtonVNSCode[]>([])\r\n    })\r\n\r\n    this.subscriptions.push(\r\n      this.authService.data$.subscribe(x => {\r\n        this.isRootUser = x?.isRoot;\r\n        this.isAdminUser = x?.isAdmin;\r\n      })\r\n    )\r\n\r\n    this.subscriptions.push(\r\n      this.mls.lang$.subscribe(x => this.lang = x)\r\n    )\r\n  }\r\n\r\n  ngOnChanges(e: SimpleChanges): void {\r\n\r\n    if (!e['height']?.currentValue) {\r\n      // fallback\r\n      this.height = 30;\r\n    }\r\n    \r\n    if (!!e['shownItems']?.currentValue) {\r\n      this.buttons = CORE_VNS_BUTTONS.filter(x => this.shownItems.includes(x.code))\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n      this.subscriptions.push(\r\n        this.routingService.currentFunction$.subscribe(x => {\r\n          this.function = x;\r\n          this.currentFunctionAssigmentDone = true;\r\n          \r\n          if (!!this.forHeader) {\r\n            if (!!this.isRootUser || !!this.isAdminUser) {\r\n              this.buttons = CORE_VNS_BUTTONS.filter(x => !x.hidden).filter(button => {\r\n                if (!!this.function) {\r\n                  return this.function!.actionCodes!.indexOf(button.code) >= 0 && button.isHeader\r\n                } else {\r\n                  return false;\r\n                }\r\n              })\r\n            } else {\r\n              const functionFilter = this.authService.data$.value!.permissionActions.filter(pa => {\r\n                return pa.functionId === this.function?.id\r\n              });\r\n              if (functionFilter.length) {\r\n                const { allowedActionCodes } = functionFilter[0];\r\n                this.buttons = CORE_VNS_BUTTONS.filter(x => !!!x.hidden).filter(button => {\r\n                  return allowedActionCodes!.indexOf(button.code) >= 0 && button.isHeader\r\n                })\r\n              } else {\r\n                this.buttons = [];\r\n              }\r\n            }\r\n          } else {\r\n            // To be improved\r\n            if (!!!this.shownItems) {\r\n              this.buttons = CORE_VNS_BUTTONS.filter(x => !!!x.isHeader)\r\n            } else {\r\n              this.buttons = CORE_VNS_BUTTONS.filter(x => this.shownItems.includes(x.code))\r\n            }\r\n          }\r\n        })\r\n      )\r\n\r\n      /*\r\n      const filter = this.coreButtonGroupService.instances.filter(x => x.instanceNumber === this.instanceNumber);\r\n      if (!!filter.length) {\r\n        this.subscriptions.push(\r\n          filter[0].mustBeHidden$.subscribe(mbh => {\r\n            this.buttons.map(b => {\r\n              if (mbh.includes(b.code)) {\r\n                b.hidden = true;\r\n              } else {\r\n                b.hidden = false;\r\n              }\r\n            })\r\n          })\r\n        )\r\n      } else {\r\n        if (isDevMode()) {\r\n          this.alertService.warn(\"Không tìm thấy instance number của nhóm nút\", noneAutoClosedAlertOptions);\r\n        }\r\n      }\r\n      */\r\n\r\n    })\r\n  }\r\n\r\n  swapTrioEditSaveCancel(editActive: boolean): void {\r\n    this.headerEdit = this.buttons.filter(x => x.code === EnumCoreButtonVNSCode.HEADER_EDIT);\r\n    this.headerSave = this.buttons.filter(x => x.code === EnumCoreButtonVNSCode.HEADER_SAVE);\r\n    this.headerCancel = this.buttons.filter(x => x.code === EnumCoreButtonVNSCode.HEADER_CANCEL);\r\n    if (editActive) {\r\n      this.headerEdit[0].hidden = true;\r\n      this.headerSave[0].hidden = false;\r\n      this.headerCancel[0].hidden = false;\r\n    } else {\r\n      this.headerEdit[0].hidden = false;\r\n      this.headerSave[0].hidden = true;\r\n      this.headerCancel[0].hidden = true;\r\n    }\r\n  }\r\n\r\n  onButtonClick(e: ICoreButtonVNS): void {\r\n    console.log(\"button-group onButtonClick\", e)\r\n    this.buttonClick.emit(e);\r\n  }\r\n\r\n  onMapperClick(): void {\r\n    if (!!this.function) {\r\n      this.router.navigate(\r\n        [\r\n          '/root',\r\n          'action-mapper',\r\n        ]\r\n      );\r\n    } else {\r\n      this.alertService.info(this.mls.trans(EnumTranslateKey.ROOT_MAPPER_UPDATE_FUNCTION_ID_FOR_THE_MENU_ITEM), alertOptions)\r\n    }\r\n  }\r\n\r\n  override ngOnDestroy(): void {\r\n    this.subscriptions.map(x => x?.unsubscribe());\r\n    const newInstances = this.coreButtonGroupService.instances.filter(x => x.instanceNumber !== this.instanceNumber);\r\n    this.coreButtonGroupService.instances = newInstances;\r\n  }\r\n\r\n}\r\n","<div class=\"core-button-group-vns-container\" [ngStyle]=\"{ height: height + 'px' }\">\r\n    <div [ngStyle]=\"{ height: height + 'px' }\" class=\"setting-trigger d-flex d-flex-center\"\r\n        *ngIf=\"!!isRootUser && !!forHeader\" (click)=\"onMapperClick()\"\r\n        [appTooltip]=\"'UI_BUTTON_GROUP_SETTING_ADD_REMOVE_ACTION_ITEM_FOR_THIS_SCREEN' | translate : lang\"\r\n        position=\"left\">\r\n        <i class=\"feather-settings\"></i>\r\n    </div>\r\n\r\n    <div [ngStyle]=\"{ height: height + 'px' }\" class=\"separator\" *ngIf=\"!!isRootUser && !!forHeader\"></div>\r\n\r\n    <ng-container *ngFor=\"let button of buttons\">\r\n        <ng-container *ngIf=\"!button.hidden\">\r\n            <core-button-vns [showCaption]=\"showCaption\" [data]=\"button\" [instanceNumber]=\"instanceNumber\"\r\n                (buttonClick)=\"onButtonClick($event)\"></core-button-vns>\r\n        </ng-container>\r\n    </ng-container>\r\n\r\n    <span *ngIf=\"!!isRootUser && !!forHeader && !!!buttons.length\">{{ currentFunctionAssigmentDone ?\r\n        ('UI_BUTTON_GROUP_NO_ITEM_AVAILABLE_YET' | translate : lang) : '' }}</span>\r\n</div>"]}
161
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-button-group-vns.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-button-group-vns/core-button-group-vns/core-button-group-vns.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-button-group-vns/core-button-group-vns/core-button-group-vns.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAyB,MAAM,EAAuC,MAAM,eAAe,CAAC;AAGnI,OAAO,EAAE,qBAAqB,EAAE,MAAM,yBAAyB,CAAC;AAChE,OAAO,EAAE,aAAa,EAAE,MAAM,0CAA0C,CAAC;AAGzE,OAAO,EAAE,eAAe,EAAE,MAAM,MAAM,CAAC;AACvC,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAI1D,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,qBAAqB,EAAE,MAAM,8CAA8C,CAAC;AACrF,OAAO,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAClE,OAAO,EAAE,sBAAsB,EAAE,MAAM,8CAA8C,CAAC;AACtF,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AACnE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAC;;;;;;;;;AAevE,MAAM,OAAO,2BAA4B,SAAQ,aAAa;IAsB5D,OAAO;IAEP,YACkB,GAAyB,EACjC,MAAc,EACd,WAAwB,EACxB,cAA8B,EAC9B,YAA0B,EAC1B,sBAA8C;QAEtD,KAAK,CAAC,GAAG,CAAC,CAAC;QAPK,QAAG,GAAH,GAAG,CAAsB;QACjC,WAAM,GAAN,MAAM,CAAQ;QACd,gBAAW,GAAX,WAAW,CAAa;QACxB,mBAAc,GAAd,cAAc,CAAgB;QAC9B,iBAAY,GAAZ,YAAY,CAAc;QAC1B,2BAAsB,GAAtB,sBAAsB,CAAwB;QAtB9C,gBAAW,GAAG,IAAI,YAAY,EAAkB,CAAC;QAE3D,YAAO,GAAqB,EAAE,CAAC;IAuB/B,CAAC;IAEQ,QAAQ;QAEf,IAAI,CAAC,sBAAsB,CAAC,SAAS,CAAC,IAAI,CAAC;YACzC,cAAc,EAAE,IAAI,CAAC,cAAc;YACnC,aAAa,EAAE,IAAI,eAAe,CAA0B,EAAE,CAAC;SAChE,CAAC,CAAA;QAEF,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YACnC,IAAI,CAAC,UAAU,GAAG,CAAC,EAAE,MAAM,CAAC;YAC5B,IAAI,CAAC,WAAW,GAAG,CAAC,EAAE,OAAO,CAAC;QAChC,CAAC,CAAC,CACH,CAAA;QAED,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,CAC7C,CAAA;IACH,CAAC;IAED,WAAW,CAAC,CAAgB;QAE1B,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,YAAY,EAAE;YAC9B,WAAW;YACX,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;SAClB;QAED,IAAI,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,EAAE,YAAY,EAAE;YACnC,IAAI,CAAC,OAAO,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAA;SAC9E;IACH,CAAC;IAED,eAAe;QACb,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACnB,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;oBACjD,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC;oBAClB,IAAI,CAAC,4BAA4B,GAAG,IAAI,CAAC;oBAEzC,IAAI,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE;wBACpB,IAAI,CAAC,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE;4BAC3C,IAAI,CAAC,OAAO,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE;gCACrE,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE;oCACnB,OAAO,IAAI,CAAC,QAAS,CAAC,WAAY,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,MAAM,CAAC,QAAQ,CAAA;iCAChF;qCAAM;oCACL,OAAO,KAAK,CAAC;iCACd;4BACH,CAAC,CAAC,CAAA;yBACH;6BAAM;4BACL,MAAM,cAAc,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,KAAM,CAAC,iBAAiB,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE;gCACjF,OAAO,EAAE,CAAC,UAAU,KAAK,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAA;4BAC5C,CAAC,CAAC,CAAC;4BACH,IAAI,cAAc,CAAC,MAAM,EAAE;gCACzB,MAAM,EAAE,kBAAkB,EAAE,GAAG,cAAc,CAAC,CAAC,CAAC,CAAC;gCACjD,IAAI,CAAC,OAAO,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE;oCACvE,OAAO,kBAAmB,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,MAAM,CAAC,QAAQ,CAAA;gCACzE,CAAC,CAAC,CAAA;6BACH;iCAAM;gCACL,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;6BACnB;yBACF;qBACF;yBAAM;wBACL,iBAAiB;wBACjB,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,EAAE;4BACtB,IAAI,CAAC,OAAO,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAA;yBAC3D;6BAAM;4BACL,IAAI,CAAC,OAAO,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAA;yBAC9E;qBACF;gBACH,CAAC,CAAC,CACH,CAAA;YACH,CAAC,CAAC,CAAA;SACH;IACH,CAAC;IAED,sBAAsB,CAAC,UAAmB;QACxC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,qBAAqB,CAAC,WAAW,CAAC,CAAC;QACzF,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,qBAAqB,CAAC,WAAW,CAAC,CAAC;QACzF,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,qBAAqB,CAAC,aAAa,CAAC,CAAC;QAC7F,IAAI,UAAU,EAAE;YACd,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC;YACjC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,KAAK,CAAC;YAClC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,KAAK,CAAC;SACrC;aAAM;YACL,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,KAAK,CAAC;YAClC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC;YACjC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC;SACpC;IACH,CAAC;IAED,aAAa,CAAC,CAAiB;QAC7B,OAAO,CAAC,GAAG,CAAC,4BAA4B,EAAE,CAAC,CAAC,CAAA;QAC5C,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC3B,CAAC;IAED,aAAa;QACX,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE;YACnB,IAAI,CAAC,MAAM,CAAC,QAAQ,CAClB;gBACE,OAAO;gBACP,eAAe;aAChB,CACF,CAAC;SACH;aAAM;YACL,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,gBAAgB,CAAC,gDAAgD,CAAC,EAAE,YAAY,CAAC,CAAA;SACxH;IACH,CAAC;IAEQ,WAAW;QAClB,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC;QAC9C,MAAM,YAAY,GAAG,IAAI,CAAC,sBAAsB,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,cAAc,KAAK,IAAI,CAAC,cAAc,CAAC,CAAC;QACjH,IAAI,CAAC,sBAAsB,CAAC,SAAS,GAAG,YAAY,CAAC;IACvD,CAAC;8GAnJU,2BAA2B;kGAA3B,2BAA2B,4UCjCxC,6nCAmBM,yDDKF,YAAY,qVACZ,sBAAsB,0JAEtB,aAAa,kDACb,gBAAgB;;2FAKP,2BAA2B;kBAbvC,SAAS;+BACE,uBAAuB,cACrB,IAAI,WACP;wBACP,YAAY;wBACZ,sBAAsB;wBACtB,qBAAqB;wBACrB,aAAa;wBACb,gBAAgB;qBACjB;qOAMQ,MAAM;sBAAd,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACI,WAAW;sBAApB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, OnInit, AfterViewInit, Output, SimpleChanges, OnDestroy, OnChanges } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { ICoreButtonVNS } from './ICoreButtonVNS';\r\nimport { EnumCoreButtonVNSCode } from './EnumCoreButtonVNSCode';\r\nimport { BaseComponent } from '../../base-component/base/base.component';\r\nimport { AlertService } from '../../alert/alert.service';\r\nimport { CoreButtonGroupService } from '../core-button-group-service';\r\nimport { BehaviorSubject } from 'rxjs';\r\nimport { EnumTranslateKey } from \"alpha-global-constants\";\r\nimport { IFunctionWithFullActions, RoutingService } from '../../../services/routing.service';\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { AuthService } from '../../../services/auth.service';\r\nimport { alertOptions } from '../../../constants/alertOptions';\r\nimport { CommonModule } from '@angular/common';\r\nimport { MapAvatarToServerPipe } from '../../../app-pipes/map-avatar-to-server.pipe';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\nimport { CoreButtonVnsComponent } from '../core-button-vns/core-button-vns.component';\r\nimport { TooltipDirective } from '../../tooltip/tooltip.directive';\r\nimport { CORE_VNS_BUTTONS } from '../../../constants/CORE_VNS_BUTTONS';\r\n\r\n@Component({\r\n  selector: 'core-button-group-vns',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    CoreButtonVnsComponent,\r\n    MapAvatarToServerPipe,\r\n    TranslatePipe,\r\n    TooltipDirective\r\n  ],\r\n  templateUrl: './core-button-group-vns.component.html',\r\n  styleUrls: ['./core-button-group-vns.component.scss']\r\n})\r\nexport class CoreButtonGroupVnsComponent extends BaseComponent implements OnChanges, OnInit, AfterViewInit, OnDestroy {\r\n\r\n  @Input() height!: number;\r\n  @Input() instanceNumber!: number;\r\n  @Input() forHeader!: boolean;\r\n  @Input() fixedShow!: boolean;\r\n  @Input() shownItems!: EnumCoreButtonVNSCode[];\r\n  @Input() showCaption!: boolean;\r\n  @Output() buttonClick = new EventEmitter<ICoreButtonVNS>();\r\n\r\n  buttons: ICoreButtonVNS[] = [];\r\n\r\n  isRootUser!: boolean | undefined;\r\n  isAdminUser!: boolean | undefined;\r\n  function!: IFunctionWithFullActions | undefined;\r\n  currentFunctionAssigmentDone!: boolean;\r\n\r\n\r\n  /* Bộ ba các nút dưới đây cần ẩn/hiện theo tình huống */\r\n  headerEdit!: ICoreButtonVNS[];\r\n  headerSave!: ICoreButtonVNS[];\r\n  headerCancel!: ICoreButtonVNS[];\r\n  /*** */\r\n\r\n  constructor(\r\n    public override mls: MultiLanguageService,\r\n    private router: Router,\r\n    private authService: AuthService,\r\n    private routingService: RoutingService,\r\n    private alertService: AlertService,\r\n    private coreButtonGroupService: CoreButtonGroupService\r\n  ) {\r\n    super(mls);\r\n  }\r\n\r\n  override ngOnInit(): void {\r\n\r\n    this.coreButtonGroupService.instances.push({\r\n      instanceNumber: this.instanceNumber,\r\n      mustBeHidden$: new BehaviorSubject<EnumCoreButtonVNSCode[]>([])\r\n    })\r\n\r\n    this.subscriptions.push(\r\n      this.authService.data$.subscribe(x => {\r\n        this.isRootUser = x?.isRoot;\r\n        this.isAdminUser = x?.isAdmin;\r\n      })\r\n    )\r\n\r\n    this.subscriptions.push(\r\n      this.mls.lang$.subscribe(x => this.lang = x)\r\n    )\r\n  }\r\n\r\n  ngOnChanges(e: SimpleChanges): void {\r\n\r\n    if (!e['height']?.currentValue) {\r\n      // fallback\r\n      this.height = 30;\r\n    }\r\n\r\n    if (!!e['shownItems']?.currentValue) {\r\n      this.buttons = CORE_VNS_BUTTONS.filter(x => this.shownItems.includes(x.code))\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (!this.fixedShow) {\r\n      setTimeout(() => {\r\n        this.subscriptions.push(\r\n          this.routingService.currentFunction$.subscribe(x => {\r\n            this.function = x;\r\n            this.currentFunctionAssigmentDone = true;\r\n\r\n            if (!!this.forHeader) {\r\n              if (!!this.isRootUser || !!this.isAdminUser) {\r\n                this.buttons = CORE_VNS_BUTTONS.filter(x => !x.hidden).filter(button => {\r\n                  if (!!this.function) {\r\n                    return this.function!.actionCodes!.indexOf(button.code) >= 0 && button.isHeader\r\n                  } else {\r\n                    return false;\r\n                  }\r\n                })\r\n              } else {\r\n                const functionFilter = this.authService.data$.value!.permissionActions.filter(pa => {\r\n                  return pa.functionId === this.function?.id\r\n                });\r\n                if (functionFilter.length) {\r\n                  const { allowedActionCodes } = functionFilter[0];\r\n                  this.buttons = CORE_VNS_BUTTONS.filter(x => !!!x.hidden).filter(button => {\r\n                    return allowedActionCodes!.indexOf(button.code) >= 0 && button.isHeader\r\n                  })\r\n                } else {\r\n                  this.buttons = [];\r\n                }\r\n              }\r\n            } else {\r\n              // To be improved\r\n              if (!!!this.shownItems) {\r\n                this.buttons = CORE_VNS_BUTTONS.filter(x => !!!x.isHeader)\r\n              } else {\r\n                this.buttons = CORE_VNS_BUTTONS.filter(x => this.shownItems.includes(x.code))\r\n              }\r\n            }\r\n          })\r\n        )\r\n      })\r\n    }\r\n  }\r\n\r\n  swapTrioEditSaveCancel(editActive: boolean): void {\r\n    this.headerEdit = this.buttons.filter(x => x.code === EnumCoreButtonVNSCode.HEADER_EDIT);\r\n    this.headerSave = this.buttons.filter(x => x.code === EnumCoreButtonVNSCode.HEADER_SAVE);\r\n    this.headerCancel = this.buttons.filter(x => x.code === EnumCoreButtonVNSCode.HEADER_CANCEL);\r\n    if (editActive) {\r\n      this.headerEdit[0].hidden = true;\r\n      this.headerSave[0].hidden = false;\r\n      this.headerCancel[0].hidden = false;\r\n    } else {\r\n      this.headerEdit[0].hidden = false;\r\n      this.headerSave[0].hidden = true;\r\n      this.headerCancel[0].hidden = true;\r\n    }\r\n  }\r\n\r\n  onButtonClick(e: ICoreButtonVNS): void {\r\n    console.log(\"button-group onButtonClick\", e)\r\n    this.buttonClick.emit(e);\r\n  }\r\n\r\n  onMapperClick(): void {\r\n    if (!!this.function) {\r\n      this.router.navigate(\r\n        [\r\n          '/root',\r\n          'action-mapper',\r\n        ]\r\n      );\r\n    } else {\r\n      this.alertService.info(this.mls.trans(EnumTranslateKey.ROOT_MAPPER_UPDATE_FUNCTION_ID_FOR_THE_MENU_ITEM), alertOptions)\r\n    }\r\n  }\r\n\r\n  override ngOnDestroy(): void {\r\n    this.subscriptions.map(x => x?.unsubscribe());\r\n    const newInstances = this.coreButtonGroupService.instances.filter(x => x.instanceNumber !== this.instanceNumber);\r\n    this.coreButtonGroupService.instances = newInstances;\r\n  }\r\n\r\n}\r\n","<div class=\"core-button-group-vns-container\" [ngStyle]=\"{ height: height + 'px' }\">\r\n    <div [ngStyle]=\"{ height: height + 'px' }\" class=\"setting-trigger d-flex d-flex-center\"\r\n        *ngIf=\"!!isRootUser && !!forHeader\" (click)=\"onMapperClick()\"\r\n        [appTooltip]=\"'UI_BUTTON_GROUP_SETTING_ADD_REMOVE_ACTION_ITEM_FOR_THIS_SCREEN' | translate : lang\"\r\n        position=\"left\">\r\n        <i class=\"feather-settings\"></i>\r\n    </div>\r\n\r\n    <div [ngStyle]=\"{ height: height + 'px' }\" class=\"separator\" *ngIf=\"!!isRootUser && !!forHeader\"></div>\r\n\r\n    <ng-container *ngFor=\"let button of buttons\">\r\n        <ng-container *ngIf=\"!button.hidden\">\r\n            <core-button-vns [showCaption]=\"showCaption\" [data]=\"button\" [instanceNumber]=\"instanceNumber\"\r\n                (buttonClick)=\"onButtonClick($event)\"></core-button-vns>\r\n        </ng-container>\r\n    </ng-container>\r\n\r\n    <span *ngIf=\"!!isRootUser && !!forHeader && !!!buttons.length\">{{ currentFunctionAssigmentDone ?\r\n        ('UI_BUTTON_GROUP_NO_ITEM_AVAILABLE_YET' | translate : lang) : '' }}</span>\r\n</div>"]}
@@ -206,7 +206,7 @@ export class CoreFormComponent {
206
206
  this.buttonClick.emit(e);
207
207
  }
208
208
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreFormComponent, deps: [{ token: i1.CoreControlService }, { token: i2.MultiLanguageService }, { token: i3.AlertService }, { token: i4.CoreFormService }, { token: i5.AppConfigService }], target: i0.ɵɵFactoryTarget.Component }); }
209
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: CoreFormComponent, isStandalone: true, selector: "core-form", inputs: { formName: "formName", submitText: "submitText", leftInputSections: "leftInputSections", leftInputSectionsFlexSize: "leftInputSectionsFlexSize", inputSections: "inputSections", mode$: "mode$", bottomTemplateRef: "bottomTemplateRef", customFormButtonItems: "customFormButtonItems", showCaptionButton: "showCaptionButton", disableSaveButton: "disableSaveButton", checkError$: "checkError$" }, outputs: { onFormCreated: "onFormCreated", onFormRefCreated: "onFormRefCreated", onSubmit: "onSubmit", onSave: "onSave", onCancal: "onCancal", buttonClick: "buttonClick" }, viewQueries: [{ propertyName: "formRef", first: true, predicate: ["formRef"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<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>", styles: [".core-form-container>form .section .section-header-label{display:block;height:34px;line-height:34px;margin-bottom:15px;margin-left:12px}.core-form-container>form .section .section-header-label .section-img-wrapper{position:relative}.core-form-container>form .section .section-header-label .section-img-wrapper .section-img{position:absolute;width:34px;height:34px;border-radius:50%;background-color:#d3d3d3;float:left;background-image:url(/assets/images/info.svg);background-repeat:no-repeat;background-position:center}.core-form-container>form .section .section-header-label .section-caption{padding-left:40px;font-weight:700;color:#696969}.core-form-container .row{margin-left:var(--size-layout-block-cell-spacing) 0px;margin-right:var(--size-layout-block-cell-spacing) 0px}.core-form-container .row .grid-buffer{border:dotted 2px darkgray}.core-form-container .row .button-control{display:flex;align-items:flex-end}.core-form-container .form-row{margin:var(--size-layout-block-cell-spacing) 0px;display:flex;align-items:center;justify-content:center}.core-form-container .form-row>button{cursor:pointer}.core-form-container .form-row>button:not(:first-child){margin-left:var(--size-layout-block-cell-spacing)}.core-form-container .payload-preview{display:block;width:100%;height:200px;white-space:pre-wrap;overflow-x:hidden;overflow-y:auto}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i7.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i7.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i7.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: CoreControlComponent, selector: "core-control", inputs: ["control", "form", "checkError$", "rangeLimit"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "component", type: CoreButtonGroupVnsComponent, selector: "core-button-group-vns", inputs: ["height", "instanceNumber", "forHeader", "shownItems", "showCaption"], outputs: ["buttonClick"] }] }); }
209
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: CoreFormComponent, isStandalone: true, selector: "core-form", inputs: { formName: "formName", submitText: "submitText", leftInputSections: "leftInputSections", leftInputSectionsFlexSize: "leftInputSectionsFlexSize", inputSections: "inputSections", mode$: "mode$", bottomTemplateRef: "bottomTemplateRef", customFormButtonItems: "customFormButtonItems", showCaptionButton: "showCaptionButton", disableSaveButton: "disableSaveButton", checkError$: "checkError$" }, outputs: { onFormCreated: "onFormCreated", onFormRefCreated: "onFormRefCreated", onSubmit: "onSubmit", onSave: "onSave", onCancal: "onCancal", buttonClick: "buttonClick" }, viewQueries: [{ propertyName: "formRef", first: true, predicate: ["formRef"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<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>", styles: [".core-form-container>form .section .section-header-label{display:block;height:34px;line-height:34px;margin-bottom:15px;margin-left:12px}.core-form-container>form .section .section-header-label .section-img-wrapper{position:relative}.core-form-container>form .section .section-header-label .section-img-wrapper .section-img{position:absolute;width:34px;height:34px;border-radius:50%;background-color:#d3d3d3;float:left;background-image:url(/assets/images/info.svg);background-repeat:no-repeat;background-position:center}.core-form-container>form .section .section-header-label .section-caption{padding-left:40px;font-weight:700;color:#696969}.core-form-container .row{margin-left:var(--size-layout-block-cell-spacing) 0px;margin-right:var(--size-layout-block-cell-spacing) 0px}.core-form-container .row .grid-buffer{border:dotted 2px darkgray}.core-form-container .row .button-control{display:flex;align-items:flex-end}.core-form-container .form-row{margin:var(--size-layout-block-cell-spacing) 0px;display:flex;align-items:center;justify-content:center}.core-form-container .form-row>button{cursor:pointer}.core-form-container .form-row>button:not(:first-child){margin-left:var(--size-layout-block-cell-spacing)}.core-form-container .payload-preview{display:block;width:100%;height:200px;white-space:pre-wrap;overflow-x:hidden;overflow-y:auto}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i7.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i7.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i7.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: CoreControlComponent, selector: "core-control", inputs: ["control", "form", "checkError$", "rangeLimit"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "component", type: CoreButtonGroupVnsComponent, selector: "core-button-group-vns", inputs: ["height", "instanceNumber", "forHeader", "fixedShow", "shownItems", "showCaption"], outputs: ["buttonClick"] }] }); }
210
210
  }
211
211
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreFormComponent, decorators: [{
212
212
  type: Component,
@@ -151,7 +151,7 @@ export class CoreFormLiteComponent {
151
151
  this.buttonClick.emit(e);
152
152
  }
153
153
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreFormLiteComponent, deps: [{ token: i1.CoreControlService }, { token: i2.MultiLanguageService }, { token: i3.AlertService }, { token: i4.CoreFormService }, { token: i5.AppConfigService }], target: i0.ɵɵFactoryTarget.Component }); }
154
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.3", type: CoreFormLiteComponent, isStandalone: true, selector: "core-form-lite", inputs: { formName: "formName", submitText: "submitText", inputSections: "inputSections", mode$: "mode$", customFormButtonItems: "customFormButtonItems", showButonCaptions: "showButonCaptions", disableSaveButton: "disableSaveButton", checkError$: "checkError$" }, outputs: { onFormCreated: "onFormCreated", onFormRefCreated: "onFormRefCreated", onSubmit: "onSubmit", onSave: "onSave", onCancal: "onCancal", buttonClick: "buttonClick" }, viewQueries: [{ propertyName: "formRef", first: true, predicate: ["formRef"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"core-form-lite-container\">\r\n @if (!!form) {\r\n <form #formRef (ngSubmit)=\"onFormSubmit()\" [formGroup]=\"form\" autocomplete=\"off\">\r\n <div class=\"row\">\r\n <div [class]=\"'col-md-12'\">\r\n\r\n <div *ngFor=\"let section of sections\" class=\"section\" [class.d-none]=\"!!section.hidden\">\r\n\r\n @if (!!section.caption) {\r\n <div class=\"section-header-label\">\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\r\n @for (row of section.rows; track row) {\r\n <div class=\"row mb15\">\r\n @for (col of row; track col) {\r\n <div [class]=\"'col-md-' + col.flexSize\" [class.button-control]=\"col.controlType==='BUTTON'\">\r\n <core-control-no-seeker [control]=\"col\" [form]=\"form\"\r\n [checkError$]=\"checkError$\"></core-control-no-seeker>\r\n </div>\r\n }\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n </div>\r\n\r\n </div>\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]=\"showButonCaptions\" [forHeader]=\"false\"\r\n (buttonClick)=\"onButtonClick($event)\" [shownItems]=\"buttonItems\"\r\n 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\r\n</div>", styles: [".core-form-lite-container>form .section .section-header-label{display:block;height:34px;line-height:34px;margin-bottom:15px;margin-left:12px}.core-form-lite-container>form .section .section-header-label .section-img-wrapper{position:relative}.core-form-lite-container>form .section .section-header-label .section-img-wrapper .section-img{position:absolute;width:34px;height:34px;border-radius:50%;background-color:#d3d3d3;float:left;background-image:url(/assets/images/info.svg);background-repeat:no-repeat;background-position:center}.core-form-lite-container>form .section .section-header-label .section-caption{padding-left:40px;font-weight:700;color:#696969}.core-form-lite-container .row{margin-left:var(--size-layout-block-cell-spacing) 0px;margin-right:var(--size-layout-block-cell-spacing) 0px}.core-form-lite-container .row .grid-buffer{border:dotted 2px darkgray}.core-form-lite-container .row .button-control{display:flex;align-items:flex-end}.core-form-lite-container .form-row{margin:var(--size-layout-block-cell-spacing) 0px;display:flex;align-items:center;justify-content:center}.core-form-lite-container .form-row>button{cursor:pointer}.core-form-lite-container .form-row>button:not(:first-child){margin-left:var(--size-layout-block-cell-spacing)}.core-form-lite-container .payload-preview{display:block;width:100%;height:200px;white-space:pre-wrap;overflow-x:hidden;overflow-y:auto}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i7.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i7.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i7.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: CoreControlNoSeekerComponent, selector: "core-control-no-seeker", inputs: ["control", "form", "checkError$", "rangeLimit"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "component", type: CoreButtonGroupVnsComponent, selector: "core-button-group-vns", inputs: ["height", "instanceNumber", "forHeader", "shownItems", "showCaption"], outputs: ["buttonClick"] }] }); }
154
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.3", type: CoreFormLiteComponent, isStandalone: true, selector: "core-form-lite", inputs: { formName: "formName", submitText: "submitText", inputSections: "inputSections", mode$: "mode$", customFormButtonItems: "customFormButtonItems", showButonCaptions: "showButonCaptions", disableSaveButton: "disableSaveButton", checkError$: "checkError$" }, outputs: { onFormCreated: "onFormCreated", onFormRefCreated: "onFormRefCreated", onSubmit: "onSubmit", onSave: "onSave", onCancal: "onCancal", buttonClick: "buttonClick" }, viewQueries: [{ propertyName: "formRef", first: true, predicate: ["formRef"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"core-form-lite-container\">\r\n @if (!!form) {\r\n <form #formRef (ngSubmit)=\"onFormSubmit()\" [formGroup]=\"form\" autocomplete=\"off\">\r\n <div class=\"row\">\r\n <div [class]=\"'col-md-12'\">\r\n\r\n <div *ngFor=\"let section of sections\" class=\"section\" [class.d-none]=\"!!section.hidden\">\r\n\r\n @if (!!section.caption) {\r\n <div class=\"section-header-label\">\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\r\n @for (row of section.rows; track row) {\r\n <div class=\"row mb15\">\r\n @for (col of row; track col) {\r\n <div [class]=\"'col-md-' + col.flexSize\" [class.button-control]=\"col.controlType==='BUTTON'\">\r\n <core-control-no-seeker [control]=\"col\" [form]=\"form\"\r\n [checkError$]=\"checkError$\"></core-control-no-seeker>\r\n </div>\r\n }\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n </div>\r\n\r\n </div>\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]=\"showButonCaptions\" [forHeader]=\"false\"\r\n (buttonClick)=\"onButtonClick($event)\" [shownItems]=\"buttonItems\"\r\n 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\r\n</div>", styles: [".core-form-lite-container>form .section .section-header-label{display:block;height:34px;line-height:34px;margin-bottom:15px;margin-left:12px}.core-form-lite-container>form .section .section-header-label .section-img-wrapper{position:relative}.core-form-lite-container>form .section .section-header-label .section-img-wrapper .section-img{position:absolute;width:34px;height:34px;border-radius:50%;background-color:#d3d3d3;float:left;background-image:url(/assets/images/info.svg);background-repeat:no-repeat;background-position:center}.core-form-lite-container>form .section .section-header-label .section-caption{padding-left:40px;font-weight:700;color:#696969}.core-form-lite-container .row{margin-left:var(--size-layout-block-cell-spacing) 0px;margin-right:var(--size-layout-block-cell-spacing) 0px}.core-form-lite-container .row .grid-buffer{border:dotted 2px darkgray}.core-form-lite-container .row .button-control{display:flex;align-items:flex-end}.core-form-lite-container .form-row{margin:var(--size-layout-block-cell-spacing) 0px;display:flex;align-items:center;justify-content:center}.core-form-lite-container .form-row>button{cursor:pointer}.core-form-lite-container .form-row>button:not(:first-child){margin-left:var(--size-layout-block-cell-spacing)}.core-form-lite-container .payload-preview{display:block;width:100%;height:200px;white-space:pre-wrap;overflow-x:hidden;overflow-y:auto}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i7.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i7.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i7.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: CoreControlNoSeekerComponent, selector: "core-control-no-seeker", inputs: ["control", "form", "checkError$", "rangeLimit"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "component", type: CoreButtonGroupVnsComponent, selector: "core-button-group-vns", inputs: ["height", "instanceNumber", "forHeader", "fixedShow", "shownItems", "showCaption"], outputs: ["buttonClick"] }] }); }
155
155
  }
156
156
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreFormLiteComponent, decorators: [{
157
157
  type: Component,
@@ -22,7 +22,7 @@ export class CorePageHeaderComponent extends BaseComponent {
22
22
  ngAfterViewInit() {
23
23
  }
24
24
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CorePageHeaderComponent, deps: [{ token: i1.MultiLanguageService }], target: i0.ɵɵFactoryTarget.Component }); }
25
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.3", type: CorePageHeaderComponent, isStandalone: true, selector: "core-page-header", inputs: { instanceNumber: "instanceNumber", shownItems: "shownItems", title: "title", hideButtonGroup: "hideButtonGroup" }, outputs: { buttonClick: "buttonClick" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"core-page-header-container\" #container>\r\n <div class=\"d-flex-between pd-25\">\r\n <div class=\"title\">{{ title | translate: lang }}</div>\r\n @if (!hideButtonGroup) {\r\n <core-button-group-vns [instanceNumber]=\"instanceNumber\" [forHeader]=\"true\"\r\n (buttonClick)=\"onButtonClick($event)\"></core-button-group-vns>\r\n }\r\n </div>\r\n</div>", styles: [".core-page-header-container{height:var(--size-core-page-header-height);background-color:#fff}.core-page-header-container .title{color:#000;font-weight:400;font-size:20px;text-wrap:nowrap;overflow:hidden;text-overflow:ellipsis}.d-flex-between{height:var(--size-core-page-header-height)}.buttonGroupCustom{overflow-x:scroll}.buttonGroupCustom::-webkit-scrollbar-thumb{width:20%!important}.buttonGroupCustom:hover{overflow-x:scroll}.buttonGroupCustom::-webkit-scrollbar-thumb{background-color:transparent;width:50px!important;border-radius:10px;transition:background-color 2s}.buttonGroupCustom:hover::-webkit-scrollbar-thumb{background-color:#a5a4a4;width:50px!important;border-radius:10px;transition:background-color 2s}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "component", type: CoreButtonGroupVnsComponent, selector: "core-button-group-vns", inputs: ["height", "instanceNumber", "forHeader", "shownItems", "showCaption"], outputs: ["buttonClick"] }] }); }
25
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.3", type: CorePageHeaderComponent, isStandalone: true, selector: "core-page-header", inputs: { instanceNumber: "instanceNumber", shownItems: "shownItems", title: "title", hideButtonGroup: "hideButtonGroup" }, outputs: { buttonClick: "buttonClick" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"core-page-header-container\" #container>\r\n <div class=\"d-flex-between pd-25\">\r\n <div class=\"title\">{{ title | translate: lang }}</div>\r\n @if (!hideButtonGroup) {\r\n <core-button-group-vns [instanceNumber]=\"instanceNumber\" [forHeader]=\"true\" [shownItems]=\"shownItems\"\r\n (buttonClick)=\"onButtonClick($event)\"></core-button-group-vns>\r\n }\r\n </div>\r\n</div>", styles: [".core-page-header-container{height:var(--size-core-page-header-height);background-color:#fff}.core-page-header-container .title{color:#000;font-weight:400;font-size:20px;text-wrap:nowrap;overflow:hidden;text-overflow:ellipsis}.d-flex-between{height:var(--size-core-page-header-height)}.buttonGroupCustom{overflow-x:scroll}.buttonGroupCustom::-webkit-scrollbar-thumb{width:20%!important}.buttonGroupCustom:hover{overflow-x:scroll}.buttonGroupCustom::-webkit-scrollbar-thumb{background-color:transparent;width:50px!important;border-radius:10px;transition:background-color 2s}.buttonGroupCustom:hover::-webkit-scrollbar-thumb{background-color:#a5a4a4;width:50px!important;border-radius:10px;transition:background-color 2s}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "component", type: CoreButtonGroupVnsComponent, selector: "core-button-group-vns", inputs: ["height", "instanceNumber", "forHeader", "fixedShow", "shownItems", "showCaption"], outputs: ["buttonClick"] }] }); }
26
26
  }
27
27
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CorePageHeaderComponent, decorators: [{
28
28
  type: Component,
@@ -30,7 +30,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
30
30
  CommonModule,
31
31
  TranslatePipe,
32
32
  CoreButtonGroupVnsComponent
33
- ], template: "<div class=\"core-page-header-container\" #container>\r\n <div class=\"d-flex-between pd-25\">\r\n <div class=\"title\">{{ title | translate: lang }}</div>\r\n @if (!hideButtonGroup) {\r\n <core-button-group-vns [instanceNumber]=\"instanceNumber\" [forHeader]=\"true\"\r\n (buttonClick)=\"onButtonClick($event)\"></core-button-group-vns>\r\n }\r\n </div>\r\n</div>", styles: [".core-page-header-container{height:var(--size-core-page-header-height);background-color:#fff}.core-page-header-container .title{color:#000;font-weight:400;font-size:20px;text-wrap:nowrap;overflow:hidden;text-overflow:ellipsis}.d-flex-between{height:var(--size-core-page-header-height)}.buttonGroupCustom{overflow-x:scroll}.buttonGroupCustom::-webkit-scrollbar-thumb{width:20%!important}.buttonGroupCustom:hover{overflow-x:scroll}.buttonGroupCustom::-webkit-scrollbar-thumb{background-color:transparent;width:50px!important;border-radius:10px;transition:background-color 2s}.buttonGroupCustom:hover::-webkit-scrollbar-thumb{background-color:#a5a4a4;width:50px!important;border-radius:10px;transition:background-color 2s}\n"] }]
33
+ ], template: "<div class=\"core-page-header-container\" #container>\r\n <div class=\"d-flex-between pd-25\">\r\n <div class=\"title\">{{ title | translate: lang }}</div>\r\n @if (!hideButtonGroup) {\r\n <core-button-group-vns [instanceNumber]=\"instanceNumber\" [forHeader]=\"true\" [shownItems]=\"shownItems\"\r\n (buttonClick)=\"onButtonClick($event)\"></core-button-group-vns>\r\n }\r\n </div>\r\n</div>", styles: [".core-page-header-container{height:var(--size-core-page-header-height);background-color:#fff}.core-page-header-container .title{color:#000;font-weight:400;font-size:20px;text-wrap:nowrap;overflow:hidden;text-overflow:ellipsis}.d-flex-between{height:var(--size-core-page-header-height)}.buttonGroupCustom{overflow-x:scroll}.buttonGroupCustom::-webkit-scrollbar-thumb{width:20%!important}.buttonGroupCustom:hover{overflow-x:scroll}.buttonGroupCustom::-webkit-scrollbar-thumb{background-color:transparent;width:50px!important;border-radius:10px;transition:background-color 2s}.buttonGroupCustom:hover::-webkit-scrollbar-thumb{background-color:#a5a4a4;width:50px!important;border-radius:10px;transition:background-color 2s}\n"] }]
34
34
  }], ctorParameters: () => [{ type: i1.MultiLanguageService }], propDecorators: { instanceNumber: [{
35
35
  type: Input
36
36
  }], shownItems: [{
@@ -45,4 +45,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
45
45
  type: ViewChild,
46
46
  args: ['container']
47
47
  }] } });
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29yZS1wYWdlLWhlYWRlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtaGlzdGFmZi1hbHBoYS9zcmMvbGliL2FwcC9saWJyYXJpZXMvY29yZS1wYWdlLWhlYWRlci9jb3JlLXBhZ2UtaGVhZGVyL2NvcmUtcGFnZS1oZWFkZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWhpc3RhZmYtYWxwaGEvc3JjL2xpYi9hcHAvbGlicmFyaWVzL2NvcmUtcGFnZS1oZWFkZXIvY29yZS1wYWdlLWhlYWRlci9jb3JlLXBhZ2UtaGVhZGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBaUIsU0FBUyxFQUFjLFlBQVksRUFBRSxLQUFLLEVBQWEsTUFBTSxFQUFpQixTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkksT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBS3pFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDbEUsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sbUZBQW1GLENBQUM7OztBQWFoSSxNQUFNLE9BQU8sdUJBQXdCLFNBQVEsYUFBYTtJQVd4RCxZQUNrQixHQUF5QjtRQUV6QyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFGSyxRQUFHLEdBQUgsR0FBRyxDQUFzQjtRQU5qQyxnQkFBVyxHQUFHLElBQUksWUFBWSxFQUFrQixDQUFDO0lBUzNELENBQUM7SUFFRCxXQUFXLENBQUMsT0FBc0I7UUFDaEMsSUFBSSxPQUFPLENBQUMsaUJBQWlCLENBQUMsRUFBRTtZQUM5QixPQUFPLENBQUMsR0FBRyxDQUFDLDRCQUE0QixFQUFFLE9BQU8sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLFlBQVksQ0FBQyxDQUFBO1NBQ25GO0lBQ0gsQ0FBQztJQUVELGFBQWEsQ0FBQyxDQUFpQjtRQUM3QixJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUMzQixDQUFDO0lBRUQsZUFBZTtJQUNmLENBQUM7OEdBNUJVLHVCQUF1QjtrR0FBdkIsdUJBQXVCLHFZQ3JCcEMsMlpBUU0sMHdCRE1GLFlBQVksMEJBQ1osYUFBYSxrREFDYiwyQkFBMkI7OzJGQUtsQix1QkFBdUI7a0JBWG5DLFNBQVM7K0JBQ0Usa0JBQWtCLGNBQ2hCLElBQUksV0FDUDt3QkFDUCxZQUFZO3dCQUNaLGFBQWE7d0JBQ2IsMkJBQTJCO3FCQUM1Qjt5RkFNUSxjQUFjO3NCQUF0QixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLGVBQWU7c0JBQXZCLEtBQUs7Z0JBQ0ksV0FBVztzQkFBcEIsTUFBTTtnQkFHaUIsU0FBUztzQkFBaEMsU0FBUzt1QkFBQyxXQUFXIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWZ0ZXJWaWV3SW5pdCwgQ29tcG9uZW50LCBFbGVtZW50UmVmLCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkNoYW5nZXMsIE91dHB1dCwgU2ltcGxlQ2hhbmdlcywgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEJhc2VDb21wb25lbnQgfSBmcm9tICcuLi8uLi9iYXNlLWNvbXBvbmVudC9iYXNlL2Jhc2UuY29tcG9uZW50JztcclxuaW1wb3J0IHsgSUNvcmVCdXR0b25WTlMgfSBmcm9tICcuLi8uLi9jb3JlLWJ1dHRvbi1ncm91cC12bnMvY29yZS1idXR0b24tZ3JvdXAtdm5zL0lDb3JlQnV0dG9uVk5TJztcclxuaW1wb3J0IHsgRW51bUNvcmVCdXR0b25WTlNDb2RlIH0gZnJvbSAnLi4vLi4vY29yZS1idXR0b24tZ3JvdXAtdm5zL2NvcmUtYnV0dG9uLWdyb3VwLXZucy9FbnVtQ29yZUJ1dHRvblZOU0NvZGUnO1xyXG5pbXBvcnQgeyBFbnVtVHJhbnNsYXRlS2V5IH0gZnJvbSBcImFscGhhLWdsb2JhbC1jb25zdGFudHNcIjtcclxuaW1wb3J0IHsgTXVsdGlMYW5ndWFnZVNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9zZXJ2aWNlcy9tdWx0aS1sYW5ndWFnZS5zZXJ2aWNlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgVHJhbnNsYXRlUGlwZSB9IGZyb20gJy4uLy4uLy4uL2FwcC1waXBlcy90cmFuc2xhdGUucGlwZSc7XHJcbmltcG9ydCB7IENvcmVCdXR0b25Hcm91cFZuc0NvbXBvbmVudCB9IGZyb20gJy4uLy4uL2NvcmUtYnV0dG9uLWdyb3VwLXZucy9jb3JlLWJ1dHRvbi1ncm91cC12bnMvY29yZS1idXR0b24tZ3JvdXAtdm5zLmNvbXBvbmVudCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2NvcmUtcGFnZS1oZWFkZXInLFxyXG4gIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgVHJhbnNsYXRlUGlwZSxcclxuICAgIENvcmVCdXR0b25Hcm91cFZuc0NvbXBvbmVudFxyXG4gIF0sXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2NvcmUtcGFnZS1oZWFkZXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2NvcmUtcGFnZS1oZWFkZXIuY29tcG9uZW50LnNjc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ29yZVBhZ2VIZWFkZXJDb21wb25lbnQgZXh0ZW5kcyBCYXNlQ29tcG9uZW50IGltcGxlbWVudHMgT25DaGFuZ2VzLCBBZnRlclZpZXdJbml0IHtcclxuXHJcbiAgQElucHV0KCkgaW5zdGFuY2VOdW1iZXIhOiBudW1iZXI7XHJcbiAgQElucHV0KCkgc2hvd25JdGVtcyE6IEVudW1Db3JlQnV0dG9uVk5TQ29kZVtdO1xyXG4gIEBJbnB1dCgpIHRpdGxlITogRW51bVRyYW5zbGF0ZUtleSB8IHN0cmluZztcclxuICBASW5wdXQoKSBoaWRlQnV0dG9uR3JvdXAhOiBib29sZWFuO1xyXG4gIEBPdXRwdXQoKSBidXR0b25DbGljayA9IG5ldyBFdmVudEVtaXR0ZXI8SUNvcmVCdXR0b25WTlM+KCk7XHJcblxyXG5cclxuICBAVmlld0NoaWxkKCdjb250YWluZXInKSBjb250YWluZXIhOiBFbGVtZW50UmVmO1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHB1YmxpYyBvdmVycmlkZSBtbHM6IE11bHRpTGFuZ3VhZ2VTZXJ2aWNlLFxyXG4gICkge1xyXG4gICAgc3VwZXIobWxzKTtcclxuICB9XHJcblxyXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcclxuICAgIGlmIChjaGFuZ2VzWydoaWRlQnV0dG9uR3JvdXAnXSkge1xyXG4gICAgICBjb25zb2xlLmxvZyhcImNoYW5nZXNbJ2hpZGVCdXR0b25Hcm91cCddXCIsIGNoYW5nZXNbJ2hpZGVCdXR0b25Hcm91cCddLmN1cnJlbnRWYWx1ZSlcclxuICAgIH1cclxuICB9XHJcblxyXG4gIG9uQnV0dG9uQ2xpY2soZTogSUNvcmVCdXR0b25WTlMpIHtcclxuICAgIHRoaXMuYnV0dG9uQ2xpY2suZW1pdChlKTtcclxuICB9XHJcblxyXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpOiB2b2lkIHtcclxuICB9XHJcblxyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJjb3JlLXBhZ2UtaGVhZGVyLWNvbnRhaW5lclwiICNjb250YWluZXI+XHJcbiAgICA8ZGl2IGNsYXNzPVwiZC1mbGV4LWJldHdlZW4gcGQtMjVcIj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwidGl0bGVcIj57eyB0aXRsZSB8IHRyYW5zbGF0ZTogbGFuZyB9fTwvZGl2PlxyXG4gICAgICAgIEBpZiAoIWhpZGVCdXR0b25Hcm91cCkge1xyXG4gICAgICAgIDxjb3JlLWJ1dHRvbi1ncm91cC12bnMgW2luc3RhbmNlTnVtYmVyXT1cImluc3RhbmNlTnVtYmVyXCIgW2ZvckhlYWRlcl09XCJ0cnVlXCJcclxuICAgICAgICAgICAgKGJ1dHRvbkNsaWNrKT1cIm9uQnV0dG9uQ2xpY2soJGV2ZW50KVwiPjwvY29yZS1idXR0b24tZ3JvdXAtdm5zPlxyXG4gICAgICAgIH1cclxuICAgIDwvZGl2PlxyXG48L2Rpdj4iXX0=
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29yZS1wYWdlLWhlYWRlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtaGlzdGFmZi1hbHBoYS9zcmMvbGliL2FwcC9saWJyYXJpZXMvY29yZS1wYWdlLWhlYWRlci9jb3JlLXBhZ2UtaGVhZGVyL2NvcmUtcGFnZS1oZWFkZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWhpc3RhZmYtYWxwaGEvc3JjL2xpYi9hcHAvbGlicmFyaWVzL2NvcmUtcGFnZS1oZWFkZXIvY29yZS1wYWdlLWhlYWRlci9jb3JlLXBhZ2UtaGVhZGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBaUIsU0FBUyxFQUFjLFlBQVksRUFBRSxLQUFLLEVBQWEsTUFBTSxFQUFpQixTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkksT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBS3pFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDbEUsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sbUZBQW1GLENBQUM7OztBQWFoSSxNQUFNLE9BQU8sdUJBQXdCLFNBQVEsYUFBYTtJQVd4RCxZQUNrQixHQUF5QjtRQUV6QyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFGSyxRQUFHLEdBQUgsR0FBRyxDQUFzQjtRQU5qQyxnQkFBVyxHQUFHLElBQUksWUFBWSxFQUFrQixDQUFDO0lBUzNELENBQUM7SUFFRCxXQUFXLENBQUMsT0FBc0I7UUFDaEMsSUFBSSxPQUFPLENBQUMsaUJBQWlCLENBQUMsRUFBRTtZQUM5QixPQUFPLENBQUMsR0FBRyxDQUFDLDRCQUE0QixFQUFFLE9BQU8sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLFlBQVksQ0FBQyxDQUFBO1NBQ25GO0lBQ0gsQ0FBQztJQUVELGFBQWEsQ0FBQyxDQUFpQjtRQUM3QixJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUMzQixDQUFDO0lBRUQsZUFBZTtJQUNmLENBQUM7OEdBNUJVLHVCQUF1QjtrR0FBdkIsdUJBQXVCLHFZQ3JCcEMsdWJBUU0sMHdCRE1GLFlBQVksMEJBQ1osYUFBYSxrREFDYiwyQkFBMkI7OzJGQUtsQix1QkFBdUI7a0JBWG5DLFNBQVM7K0JBQ0Usa0JBQWtCLGNBQ2hCLElBQUksV0FDUDt3QkFDUCxZQUFZO3dCQUNaLGFBQWE7d0JBQ2IsMkJBQTJCO3FCQUM1Qjt5RkFNUSxjQUFjO3NCQUF0QixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLGVBQWU7c0JBQXZCLEtBQUs7Z0JBQ0ksV0FBVztzQkFBcEIsTUFBTTtnQkFHaUIsU0FBUztzQkFBaEMsU0FBUzt1QkFBQyxXQUFXIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWZ0ZXJWaWV3SW5pdCwgQ29tcG9uZW50LCBFbGVtZW50UmVmLCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkNoYW5nZXMsIE91dHB1dCwgU2ltcGxlQ2hhbmdlcywgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEJhc2VDb21wb25lbnQgfSBmcm9tICcuLi8uLi9iYXNlLWNvbXBvbmVudC9iYXNlL2Jhc2UuY29tcG9uZW50JztcclxuaW1wb3J0IHsgSUNvcmVCdXR0b25WTlMgfSBmcm9tICcuLi8uLi9jb3JlLWJ1dHRvbi1ncm91cC12bnMvY29yZS1idXR0b24tZ3JvdXAtdm5zL0lDb3JlQnV0dG9uVk5TJztcclxuaW1wb3J0IHsgRW51bUNvcmVCdXR0b25WTlNDb2RlIH0gZnJvbSAnLi4vLi4vY29yZS1idXR0b24tZ3JvdXAtdm5zL2NvcmUtYnV0dG9uLWdyb3VwLXZucy9FbnVtQ29yZUJ1dHRvblZOU0NvZGUnO1xyXG5pbXBvcnQgeyBFbnVtVHJhbnNsYXRlS2V5IH0gZnJvbSBcImFscGhhLWdsb2JhbC1jb25zdGFudHNcIjtcclxuaW1wb3J0IHsgTXVsdGlMYW5ndWFnZVNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9zZXJ2aWNlcy9tdWx0aS1sYW5ndWFnZS5zZXJ2aWNlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgVHJhbnNsYXRlUGlwZSB9IGZyb20gJy4uLy4uLy4uL2FwcC1waXBlcy90cmFuc2xhdGUucGlwZSc7XHJcbmltcG9ydCB7IENvcmVCdXR0b25Hcm91cFZuc0NvbXBvbmVudCB9IGZyb20gJy4uLy4uL2NvcmUtYnV0dG9uLWdyb3VwLXZucy9jb3JlLWJ1dHRvbi1ncm91cC12bnMvY29yZS1idXR0b24tZ3JvdXAtdm5zLmNvbXBvbmVudCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2NvcmUtcGFnZS1oZWFkZXInLFxyXG4gIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgVHJhbnNsYXRlUGlwZSxcclxuICAgIENvcmVCdXR0b25Hcm91cFZuc0NvbXBvbmVudFxyXG4gIF0sXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2NvcmUtcGFnZS1oZWFkZXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2NvcmUtcGFnZS1oZWFkZXIuY29tcG9uZW50LnNjc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ29yZVBhZ2VIZWFkZXJDb21wb25lbnQgZXh0ZW5kcyBCYXNlQ29tcG9uZW50IGltcGxlbWVudHMgT25DaGFuZ2VzLCBBZnRlclZpZXdJbml0IHtcclxuXHJcbiAgQElucHV0KCkgaW5zdGFuY2VOdW1iZXIhOiBudW1iZXI7XHJcbiAgQElucHV0KCkgc2hvd25JdGVtcyE6IEVudW1Db3JlQnV0dG9uVk5TQ29kZVtdO1xyXG4gIEBJbnB1dCgpIHRpdGxlITogRW51bVRyYW5zbGF0ZUtleSB8IHN0cmluZztcclxuICBASW5wdXQoKSBoaWRlQnV0dG9uR3JvdXAhOiBib29sZWFuO1xyXG4gIEBPdXRwdXQoKSBidXR0b25DbGljayA9IG5ldyBFdmVudEVtaXR0ZXI8SUNvcmVCdXR0b25WTlM+KCk7XHJcblxyXG5cclxuICBAVmlld0NoaWxkKCdjb250YWluZXInKSBjb250YWluZXIhOiBFbGVtZW50UmVmO1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHB1YmxpYyBvdmVycmlkZSBtbHM6IE11bHRpTGFuZ3VhZ2VTZXJ2aWNlLFxyXG4gICkge1xyXG4gICAgc3VwZXIobWxzKTtcclxuICB9XHJcblxyXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcclxuICAgIGlmIChjaGFuZ2VzWydoaWRlQnV0dG9uR3JvdXAnXSkge1xyXG4gICAgICBjb25zb2xlLmxvZyhcImNoYW5nZXNbJ2hpZGVCdXR0b25Hcm91cCddXCIsIGNoYW5nZXNbJ2hpZGVCdXR0b25Hcm91cCddLmN1cnJlbnRWYWx1ZSlcclxuICAgIH1cclxuICB9XHJcblxyXG4gIG9uQnV0dG9uQ2xpY2soZTogSUNvcmVCdXR0b25WTlMpIHtcclxuICAgIHRoaXMuYnV0dG9uQ2xpY2suZW1pdChlKTtcclxuICB9XHJcblxyXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpOiB2b2lkIHtcclxuICB9XHJcblxyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJjb3JlLXBhZ2UtaGVhZGVyLWNvbnRhaW5lclwiICNjb250YWluZXI+XHJcbiAgICA8ZGl2IGNsYXNzPVwiZC1mbGV4LWJldHdlZW4gcGQtMjVcIj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwidGl0bGVcIj57eyB0aXRsZSB8IHRyYW5zbGF0ZTogbGFuZyB9fTwvZGl2PlxyXG4gICAgICAgIEBpZiAoIWhpZGVCdXR0b25Hcm91cCkge1xyXG4gICAgICAgIDxjb3JlLWJ1dHRvbi1ncm91cC12bnMgW2luc3RhbmNlTnVtYmVyXT1cImluc3RhbmNlTnVtYmVyXCIgW2ZvckhlYWRlcl09XCJ0cnVlXCIgW3Nob3duSXRlbXNdPVwic2hvd25JdGVtc1wiXHJcbiAgICAgICAgICAgIChidXR0b25DbGljayk9XCJvbkJ1dHRvbkNsaWNrKCRldmVudClcIj48L2NvcmUtYnV0dG9uLWdyb3VwLXZucz5cclxuICAgICAgICB9XHJcbiAgICA8L2Rpdj5cclxuPC9kaXY+Il19