ngx-histaff-alpha 2.5.3 → 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.
- package/esm2022/lib/app/libraries/core-button-group-vns/core-button-group-vns/core-button-group-vns.component.mjs +38 -54
- package/esm2022/lib/app/libraries/core-form/core-form/core-form.component.mjs +1 -1
- package/esm2022/lib/app/libraries/core-form-lite/core-form-lite.component.mjs +1 -1
- package/esm2022/lib/app/libraries/core-page-header/core-page-header/core-page-header.component.mjs +1 -1
- package/esm2022/lib/app/libraries/core-tree-grid/core-tree-grid/core-tree-grid.component.mjs +2 -2
- package/esm2022/lib/app/libraries/evaluate-dialog/evaluate-dialog.component.mjs +2 -2
- package/esm2022/lib/app/root/sys-function-action-mapper/sys-function-action-mapper.component.mjs +2 -2
- package/fesm2022/ngx-histaff-alpha.mjs +43 -59
- package/fesm2022/ngx-histaff-alpha.mjs.map +1 -1
- package/lib/app/libraries/core-button-group-vns/core-button-group-vns/core-button-group-vns.component.d.ts +2 -1
- package/package.json +1 -1
|
@@ -52,67 +52,49 @@ export class CoreButtonGroupVnsComponent extends BaseComponent {
|
|
|
52
52
|
}
|
|
53
53
|
}
|
|
54
54
|
ngAfterViewInit() {
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
this.
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
if (!!this.
|
|
61
|
-
this.
|
|
62
|
-
|
|
63
|
-
|
|
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
|
-
|
|
82
|
+
this.buttons = [];
|
|
67
83
|
}
|
|
68
|
-
}
|
|
84
|
+
}
|
|
69
85
|
}
|
|
70
86
|
else {
|
|
71
|
-
|
|
72
|
-
|
|
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
|
-
|
|
86
|
-
|
|
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":"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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() 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,
|
package/esm2022/lib/app/libraries/core-page-header/core-page-header/core-page-header.component.mjs
CHANGED
|
@@ -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\" [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", "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,
|