ngx-histaff-alpha 3.5.9 → 3.6.1
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/contractinfor/contractinfor.component.mjs +3 -1
- package/esm2022/lib/app/libraries/core-form/core-form/core-form.component.mjs +3 -3
- package/esm2022/lib/app/libraries/core-page-edit/core-page-edit.component.mjs +3 -3
- package/fesm2022/ngx-histaff-alpha.mjs +6 -4
- package/fesm2022/ngx-histaff-alpha.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -100,6 +100,7 @@ export class ContractInforComponent extends BaseComponent {
|
|
|
100
100
|
{
|
|
101
101
|
caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_EMPLOYEENAME,
|
|
102
102
|
field: 'employeeName',
|
|
103
|
+
showForConfirmation: true,
|
|
103
104
|
type: 'string',
|
|
104
105
|
align: 'left',
|
|
105
106
|
width: 250,
|
|
@@ -121,6 +122,7 @@ export class ContractInforComponent extends BaseComponent {
|
|
|
121
122
|
{
|
|
122
123
|
caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_CONTRACTNO,
|
|
123
124
|
field: 'contractNo',
|
|
125
|
+
showForConfirmation: true,
|
|
124
126
|
type: 'string',
|
|
125
127
|
align: 'left',
|
|
126
128
|
width: 150,
|
|
@@ -326,4 +328,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
326
328
|
type: ViewChild,
|
|
327
329
|
args: ['sticker']
|
|
328
330
|
}] } });
|
|
329
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contractinfor.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/contractinfor/contractinfor.component.ts","../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/contractinfor/contractinfor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit,Component,Input,TemplateRef,ViewChild,} from \"@angular/core\";\r\nimport { ContractInforService } from \"./contractinfor.service\";\r\nimport { BaseComponent } from \"../base-component/base/base.component\";\r\nimport { BehaviorSubject } from \"rxjs\";\r\nimport { ICoreTableColumnItem } from \"../core-table/ICoreTableColumnItem\";\r\nimport { EnumCoreTablePipeType } from \"../core-table/EnumCoreTablePipeType\";\r\nimport { ActivatedRoute, Router } from \"@angular/router\";\r\nimport { HttpClient } from \"@angular/common/http\";\r\nimport { EnumFilterOperator, IFilterOperator, IInOperator, ISortItem } from \"../../interfaces/IQueryListRequest\";\r\nimport { EnumSortDirection } from \"../../enum/EnumSortDirection\";\r\nimport { CorePageListComponent, ICorePageListApiDefinition, ICorePageListCRUD, ICorePageListEditRouting } from \"../core-page-list/core-page-list.component\";\r\nimport { CorePageListService, IGenerateTemplateRequest } from \"../core-page-list/core-page-list.service\";\r\nimport { MultiLanguageService } from \"../../services/multi-language.service\";\r\nimport { OrganizationService } from \"../../services/organization.service\";\r\nimport { RandomAvatarService } from \"../../services/random-avatar.service\";\r\nimport { AppService } from \"../../services/app.service\";\r\nimport { EnumTranslateKey } from \"alpha-global-constants\";\r\nimport { api } from \"alpha-global-constants\";\r\nimport { AlertService } from \"../alert/alert.service\";\r\nimport { ICoreButtonVNS } from \"../core-button-group-vns/core-button-group-vns/ICoreButtonVNS\";\r\nimport { IAlertOptions } from \"../alert/alert/alert.model\";\r\nimport { EnumCoreButtonVNSCode } from \"../core-button-group-vns/core-button-group-vns/EnumCoreButtonVNSCode\";\r\nimport { alertOptions } from \"../../constants/alertOptions\";\r\nimport { CommonModule } from \"@angular/common\";\r\nimport { CoreOrgTreeComponent } from \"../core-org-tree/core-org-tree/core-org-tree.component\";\r\nimport { FormsModule } from \"@angular/forms\";\r\nimport { CoreStatusStickerComponent } from \"../core-status-sticker/core-status-sticker/core-status-sticker.component\";\r\n\r\n@Component({\r\n  selector: \"cms-profile-contractinfor\",\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    CorePageListComponent,\r\n    CoreOrgTreeComponent,\r\n    CoreStatusStickerComponent,\r\n  ],\r\n  templateUrl: \"./contractinfor.component.html\",\r\n  styleUrls: [\"./contractinfor.component.scss\"],\r\n})\r\nexport class ContractInforComponent extends BaseComponent implements AfterViewInit {\r\n  loading!: boolean;\r\n\r\n  @Input() hideHeader!: boolean;\r\n  @Input() outerFilter$ = new BehaviorSubject<IFilterOperator[] | undefined>(undefined);\r\n  \r\n\r\n  @ViewChild('sticker') sticker!: TemplateRef<any>;\r\n  /* START: Local filter params */\r\n  orgIds!: number[];\r\n  /* END: Local filter params */\r\n\r\n  /*\r\n  Properties being passed to core-page-list\r\n  */\r\n  datePeriodComparisonFor: string = 'startDate';\r\n  datePeriodComparisonForLabelKey: EnumTranslateKey = EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_STARTDATE_FILTER;\r\n  statusInclusionFor: string = 'workStatusId';\r\n  statusInclusionForLabelKey: EnumTranslateKey = EnumTranslateKey.UI_CORE_PARAMS_EMPLOYEE_STATUS_IN;\r\n  statusOptionsApi: api = api.HU_EMPLOYEE_CV_GET_EMPLOYEE_STATUS_LIST;\r\n\r\n  id: any;\r\n\r\n  title = EnumTranslateKey.UI_COMPONENT_TITLE_CONTRACT\r\n  outerParam$ = new BehaviorSubject<any>(null);\r\n\r\n  outerFilterOperators: IFilterOperator[] = [\r\n    {\r\n      field: 'orgId',\r\n      operator: EnumFilterOperator.EQUAL\r\n    }\r\n  ]\r\n  outerInOperators: IInOperator[] = [\r\n    {\r\n      field: 'orgId',\r\n      values: this.orgIds || []\r\n    }\r\n  ]\r\n  outerSort: ISortItem[] = [\r\n    {\r\n      field: \"jobOrderNum\",\r\n      sortDirection: EnumSortDirection.ASC\r\n    }\r\n  ]\r\n  apiDefinition: ICorePageListApiDefinition = {\r\n    queryListRelativePath: api.HU_CONTRACT_QUERY_LIST,\r\n  }\r\n\r\n  crud: ICorePageListCRUD = {\r\n    deleteIds: api.HU_CONTRACT_DELETE_IDS,\r\n    toggleApproveIds: api.HU_CONTRACT_CHANGESTATUSAPPROVE\r\n  }\r\n\r\n  avatarTemplate!: TemplateRef<any>;\r\n\r\n  columns: ICoreTableColumnItem[] = [\r\n    {\r\n      caption: EnumTranslateKey.UI_ENTITY_FIELD_CAPTION_COMMON_ID,\r\n      field: 'id',\r\n      hidden: true,\r\n      type: 'number',\r\n      align: 'left',\r\n      width: 10,\r\n    },\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_STATUSNAME,\r\n      field: 'statusName',\r\n      type: 'string',\r\n      align: 'left',\r\n      width: 150,\r\n    },\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_EMPLOYEECODE,\r\n      field: 'employeeCode',\r\n      type: 'string',\r\n      align: 'left',\r\n      width: 70,\r\n    },\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_EMPLOYEENAME,\r\n      field: 'employeeName',\r\n      type: 'string',\r\n      align: 'left',\r\n      width: 250,\r\n    },\r\n    {\r\n      caption: EnumTranslateKey.UI_ENTITY_FIELD_CAPTION_STAFF_PROFILE_POSITION_NAME,\r\n      field: 'positionName',\r\n      type: 'string',\r\n      align: 'left',\r\n      width: 250,\r\n    },\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_ORGNAME,\r\n      field: 'orgName',\r\n      type: 'string',\r\n      align: 'left',\r\n      width: 200,\r\n    },\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_CONTRACTNO,\r\n      field: 'contractNo',\r\n      type: 'string',\r\n      align: 'left',\r\n      width: 150,\r\n    },\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_CONTRACTTYPENAME,\r\n      field: 'contractTypeName',\r\n      type: 'string',\r\n      align: 'left',\r\n      width: 250,\r\n    },\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_STARTDATE,\r\n      field: 'startDate',\r\n      type: 'date',\r\n      pipe: EnumCoreTablePipeType.DATE,\r\n      align: 'center',\r\n      width: 120,\r\n    },\r\n\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_EXPIREDATE,\r\n      field: 'expireDate',\r\n      type: 'date',\r\n      pipe: EnumCoreTablePipeType.DATE,\r\n      align: 'center',\r\n      width: 120,\r\n    },\r\n\r\n    // chắc là viết code ở đây\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_LIQUIDATION_DATE,\r\n      field: 'liquidationDate',\r\n      type: 'date',\r\n      pipe: EnumCoreTablePipeType.DATE,\r\n      align: 'center',\r\n      width: 100,\r\n    },\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_LIQUIDATION_REASON,\r\n      field: 'liquidationReason',\r\n      type: 'string',\r\n      align: 'left',\r\n      width: 200,\r\n    },\r\n\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_SIGNDATE,\r\n      field: 'signDate',\r\n      type: 'date',\r\n      pipe: EnumCoreTablePipeType.DATE,\r\n      align: 'center',\r\n      width: 100,\r\n    },\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_SIGNERNAME,\r\n      field: 'signerName',\r\n      type: 'string',\r\n      align: 'left',\r\n      width: 150,\r\n    },\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_SIGNERPOSITION,\r\n      field: 'signerPosition',\r\n      type: 'string',\r\n      align: 'left',\r\n      width: 250,\r\n    },\r\n\r\n  ]\r\n\r\n  defaultAvatar!: string;\r\n\r\n  editRoute: ICorePageListEditRouting = {\r\n    auxiliary: 'popupAux'\r\n  }\r\n  /* End Properties being passed to core-page-list */\r\n  generateTemplateRequest!: IGenerateTemplateRequest;\r\n  constructor(\r\n    public override mls: MultiLanguageService,\r\n    private ras: RandomAvatarService,\r\n    private router: Router,\r\n    private route: ActivatedRoute,\r\n    private organizationService: OrganizationService,\r\n    private http: HttpClient,\r\n    private appService: AppService,\r\n    private corePageListService: CorePageListService,\r\n    private contractInforService: ContractInforService,\r\n    private alertService: AlertService\r\n  ) {\r\n    super(mls);\r\n    this.defaultAvatar = ras.get();\r\n    /* Get orgIds startup value */\r\n    const newOrgIds: number[] = [];\r\n    this.organizationService.status$.value.activeKeys.map(x => newOrgIds.push(Number(x)))\r\n    this.onOrgIdsChange(newOrgIds)\r\n    this.corePageListInstanceNumber = new Date().getTime();\r\n  }\r\n  override ngOnInit(): void {\r\n    this.mls.lang$.subscribe(x => {\r\n      this.lang = x;\r\n      this.generateTemplateRequest = {\r\n        exCode: 'HU_CONTRACT',\r\n        lang: x\r\n      }\r\n    })\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    const stickerFilter = this.columns.filter(c => c.field === 'statusName');\r\n    if (!!stickerFilter.length) stickerFilter[0].templateRef = this.sticker;\r\n  }\r\n\r\n  onOrgIdsChange(orgIds: number[]) {\r\n    this.orgIds = orgIds\r\n    this.outerInOperators = [\r\n      {\r\n        field: 'orgId',\r\n        values: orgIds\r\n      }\r\n    ]\r\n  }\r\n\r\n  onRowClick(e: any) {\r\n    this.id = e.id\r\n  }\r\n\r\n  selectedIds: number[] = [];\r\n  \r\n  listInstance!: number;\r\n  \r\n  onInstanceCreated(event: number) {\r\n    this.listInstance = event;\r\n  }\r\n\r\n  alertOptions: IAlertOptions = {\r\n    autoClose: true,\r\n    keepAfterRouteChange: true,\r\n    timeClose: 10000\r\n  };\r\n\r\n  employeeId!: number;\r\n\r\n  customizeSelectedIdsChange(e: number[]): void {\r\n    this.selectedIds = e;\r\n\r\n    this.contractInforService.changeListEmployeeSelected(e);\r\n    this.contractInforService.currentListEmployeeSelected.subscribe(id => this.employeeId = id[0]);\r\n  }\r\n\r\n  corePageListInstanceNumber!: number;\r\n\r\n  onCorePageHeaderButtonClick(e: ICoreButtonVNS) {\r\n    let filename = '';\r\n\r\n    switch (e.code) {\r\n      case EnumCoreButtonVNSCode.HEADER_LIQUIDATE_CONTRACT:\r\n        if (this.selectedIds.length != 0) {\r\n          this.router.navigate(\r\n            [\r\n              {\r\n                outlets: {\r\n                  corePageListAux: [\r\n                    btoa('0'),\r\n                    { listInstance: this.corePageListInstanceNumber },\r\n                  ],\r\n                },\r\n              },\r\n            ],\r\n            { relativeTo: this.route }\r\n          );\r\n        }\r\n        else {\r\n          // bắn ra thông báo chưa chọn bản ghi\r\n          this.alertService.error(this.mls.trans('NO_SELECTED_ID_TO_DELETE'), this.alertOptions);\r\n        }\r\n\r\n        break;\r\n\r\n      case EnumCoreButtonVNSCode.HEADER_PRINT:\r\n        if (this.selectedIds.length > 1) {\r\n          this.alertService.warn(this.mls.trans('PRINT_ONE_RECORD'), alertOptions);\r\n        }\r\n        else {\r\n          this.http.get(api.HU_CONTRACT_GET_FILE_NAME + this.selectedIds[0].toString()).subscribe((response: any) => {\r\n            filename = response.innerBody;\r\n          });\r\n\r\n          this.loading = true;\r\n\r\n          this.http\r\n            .get(api.HU_CONTRACT_GET_PROBATION_CONTRACT, {\r\n              responseType: 'blob',\r\n              params: { id: this.selectedIds[0].toString() }\r\n            })\r\n            .subscribe((response: Blob) => {\r\n              if (response.type === 'application/octet-stream') {\r\n                const downloadUrl = URL.createObjectURL(response);\r\n                \r\n                const link = document.createElement('a');\r\n                \r\n                link.href = downloadUrl;\r\n                \r\n                // link.setAttribute('download', '2C_BNV_2008_' + filename + '.doc');\r\n                link.setAttribute('download', filename + '.doc');\r\n                \r\n                document.body.appendChild(link);\r\n                \r\n                link.click();\r\n                \r\n                document.body.removeChild(link);\r\n                \r\n                URL.revokeObjectURL(downloadUrl);\r\n              }\r\n              else {\r\n                const reader = new FileReader();\r\n                \r\n                reader.onload = () => {\r\n                  const jsonBody = reader.result as string;\r\n                  \r\n                  const data = JSON.parse(jsonBody);\r\n                  \r\n                  if (data.statusCode == 200) {\r\n                    this.alertService.success(data.messageCode, alertOptions);\r\n                  }\r\n                  else {\r\n                    this.alertService.error(data.messageCode, alertOptions);\r\n                  }\r\n                };\r\n\r\n                reader.readAsText(response);\r\n              }\r\n\r\n              this.loading = false;\r\n            });\r\n        }\r\n        break;\r\n\r\n      default:\r\n        break;\r\n    }\r\n  }\r\n\r\n}\r\n","<div class=\"cms-profile-contractinfor-container\">\r\n  <core-page-list\r\n    [apiDefinition]=\"apiDefinition\"\r\n    [columns]=\"columns\"\r\n    [editRoute]=\"editRoute\"\r\n    [crud]=\"crud\"\r\n    [title]=\"title\"\r\n    [left]=\"orgTree\"\r\n    [outerParam$]=\"outerParam$\"\r\n    [normalMode]=\"true\"\r\n    [outerInOperators]=\"outerInOperators\"\r\n    [autoResizeWithWindow]=\"true\"\r\n    (rowClick)=\"onRowClick($event)\"\r\n    [showParamKit]=\"true\"\r\n    [datePeriodComparisonFor]=\"datePeriodComparisonFor\"\r\n    [datePeriodComparisonForLabelKey]=\"datePeriodComparisonForLabelKey\"\r\n    [statusInclusionFor]=\"statusInclusionFor\"\r\n    [statusInclusionForLabelKey]=\"statusInclusionForLabelKey\"\r\n    [statusOptionsApi]=\"statusOptionsApi\"\r\n    [generateTemplateRequest]=\"generateTemplateRequest\"\r\n    (corePageHeaderButtonClick)=\"onCorePageHeaderButtonClick($event)\"\r\n    [importPreviewPath]=\"'contract-import'\"\r\n    [outerSort]=\"outerSort\"\r\n    [frozen]=\"3\"\r\n\r\n    (selectedIdsChange)=\"customizeSelectedIdsChange($event)\"\r\n    (onInstanceCreated)=\"onInstanceCreated($event)\"\r\n  >\r\n  </core-page-list>\r\n\r\n  <ng-template #orgTree>\r\n    <core-org-tree [(ngModel)]=\"orgIds\" (ngModelChange)=\"onOrgIdsChange($event)\">\r\n    </core-org-tree>\r\n  </ng-template>\r\n\r\n  <ng-template #sticker let-code=\"context.statusName\">\r\n    <core-status-sticker [code]=\"code\"></core-status-sticker>\r\n  </ng-template>\r\n</div>"]}
|
|
331
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contractinfor.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/contractinfor/contractinfor.component.ts","../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/contractinfor/contractinfor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit,Component,Input,TemplateRef,ViewChild,} from \"@angular/core\";\r\nimport { ContractInforService } from \"./contractinfor.service\";\r\nimport { BaseComponent } from \"../base-component/base/base.component\";\r\nimport { BehaviorSubject } from \"rxjs\";\r\nimport { ICoreTableColumnItem } from \"../core-table/ICoreTableColumnItem\";\r\nimport { EnumCoreTablePipeType } from \"../core-table/EnumCoreTablePipeType\";\r\nimport { ActivatedRoute, Router } from \"@angular/router\";\r\nimport { HttpClient } from \"@angular/common/http\";\r\nimport { EnumFilterOperator, IFilterOperator, IInOperator, ISortItem } from \"../../interfaces/IQueryListRequest\";\r\nimport { EnumSortDirection } from \"../../enum/EnumSortDirection\";\r\nimport { CorePageListComponent, ICorePageListApiDefinition, ICorePageListCRUD, ICorePageListEditRouting } from \"../core-page-list/core-page-list.component\";\r\nimport { CorePageListService, IGenerateTemplateRequest } from \"../core-page-list/core-page-list.service\";\r\nimport { MultiLanguageService } from \"../../services/multi-language.service\";\r\nimport { OrganizationService } from \"../../services/organization.service\";\r\nimport { RandomAvatarService } from \"../../services/random-avatar.service\";\r\nimport { AppService } from \"../../services/app.service\";\r\nimport { EnumTranslateKey } from \"alpha-global-constants\";\r\nimport { api } from \"alpha-global-constants\";\r\nimport { AlertService } from \"../alert/alert.service\";\r\nimport { ICoreButtonVNS } from \"../core-button-group-vns/core-button-group-vns/ICoreButtonVNS\";\r\nimport { IAlertOptions } from \"../alert/alert/alert.model\";\r\nimport { EnumCoreButtonVNSCode } from \"../core-button-group-vns/core-button-group-vns/EnumCoreButtonVNSCode\";\r\nimport { alertOptions } from \"../../constants/alertOptions\";\r\nimport { CommonModule } from \"@angular/common\";\r\nimport { CoreOrgTreeComponent } from \"../core-org-tree/core-org-tree/core-org-tree.component\";\r\nimport { FormsModule } from \"@angular/forms\";\r\nimport { CoreStatusStickerComponent } from \"../core-status-sticker/core-status-sticker/core-status-sticker.component\";\r\n\r\n@Component({\r\n  selector: \"cms-profile-contractinfor\",\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    CorePageListComponent,\r\n    CoreOrgTreeComponent,\r\n    CoreStatusStickerComponent,\r\n  ],\r\n  templateUrl: \"./contractinfor.component.html\",\r\n  styleUrls: [\"./contractinfor.component.scss\"],\r\n})\r\nexport class ContractInforComponent extends BaseComponent implements AfterViewInit {\r\n  loading!: boolean;\r\n\r\n  @Input() hideHeader!: boolean;\r\n  @Input() outerFilter$ = new BehaviorSubject<IFilterOperator[] | undefined>(undefined);\r\n  \r\n\r\n  @ViewChild('sticker') sticker!: TemplateRef<any>;\r\n  /* START: Local filter params */\r\n  orgIds!: number[];\r\n  /* END: Local filter params */\r\n\r\n  /*\r\n  Properties being passed to core-page-list\r\n  */\r\n  datePeriodComparisonFor: string = 'startDate';\r\n  datePeriodComparisonForLabelKey: EnumTranslateKey = EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_STARTDATE_FILTER;\r\n  statusInclusionFor: string = 'workStatusId';\r\n  statusInclusionForLabelKey: EnumTranslateKey = EnumTranslateKey.UI_CORE_PARAMS_EMPLOYEE_STATUS_IN;\r\n  statusOptionsApi: api = api.HU_EMPLOYEE_CV_GET_EMPLOYEE_STATUS_LIST;\r\n\r\n  id: any;\r\n\r\n  title = EnumTranslateKey.UI_COMPONENT_TITLE_CONTRACT\r\n  outerParam$ = new BehaviorSubject<any>(null);\r\n\r\n  outerFilterOperators: IFilterOperator[] = [\r\n    {\r\n      field: 'orgId',\r\n      operator: EnumFilterOperator.EQUAL\r\n    }\r\n  ]\r\n  outerInOperators: IInOperator[] = [\r\n    {\r\n      field: 'orgId',\r\n      values: this.orgIds || []\r\n    }\r\n  ]\r\n  outerSort: ISortItem[] = [\r\n    {\r\n      field: \"jobOrderNum\",\r\n      sortDirection: EnumSortDirection.ASC\r\n    }\r\n  ]\r\n  apiDefinition: ICorePageListApiDefinition = {\r\n    queryListRelativePath: api.HU_CONTRACT_QUERY_LIST,\r\n  }\r\n\r\n  crud: ICorePageListCRUD = {\r\n    deleteIds: api.HU_CONTRACT_DELETE_IDS,\r\n    toggleApproveIds: api.HU_CONTRACT_CHANGESTATUSAPPROVE\r\n  }\r\n\r\n  avatarTemplate!: TemplateRef<any>;\r\n\r\n  columns: ICoreTableColumnItem[] = [\r\n    {\r\n      caption: EnumTranslateKey.UI_ENTITY_FIELD_CAPTION_COMMON_ID,\r\n      field: 'id',\r\n      hidden: true,\r\n      type: 'number',\r\n      align: 'left',\r\n      width: 10,\r\n    },\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_STATUSNAME,\r\n      field: 'statusName',\r\n      type: 'string',\r\n      align: 'left',\r\n      width: 150,\r\n    },\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_EMPLOYEECODE,\r\n      field: 'employeeCode',\r\n      type: 'string',\r\n      align: 'left',\r\n      width: 70,\r\n    },\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_EMPLOYEENAME,\r\n      field: 'employeeName',\r\n      showForConfirmation: true,\r\n      type: 'string',\r\n      align: 'left',\r\n      width: 250,\r\n    },\r\n    {\r\n      caption: EnumTranslateKey.UI_ENTITY_FIELD_CAPTION_STAFF_PROFILE_POSITION_NAME,\r\n      field: 'positionName',\r\n      type: 'string',\r\n      align: 'left',\r\n      width: 250,\r\n    },\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_ORGNAME,\r\n      field: 'orgName',\r\n      type: 'string',\r\n      align: 'left',\r\n      width: 200,\r\n    },\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_CONTRACTNO,\r\n      field: 'contractNo',\r\n      showForConfirmation: true,\r\n      type: 'string',\r\n      align: 'left',\r\n      width: 150,\r\n    },\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_CONTRACTTYPENAME,\r\n      field: 'contractTypeName',\r\n      type: 'string',\r\n      align: 'left',\r\n      width: 250,\r\n    },\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_STARTDATE,\r\n      field: 'startDate',\r\n      type: 'date',\r\n      pipe: EnumCoreTablePipeType.DATE,\r\n      align: 'center',\r\n      width: 120,\r\n    },\r\n\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_EXPIREDATE,\r\n      field: 'expireDate',\r\n      type: 'date',\r\n      pipe: EnumCoreTablePipeType.DATE,\r\n      align: 'center',\r\n      width: 120,\r\n    },\r\n\r\n    // chắc là viết code ở đây\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_LIQUIDATION_DATE,\r\n      field: 'liquidationDate',\r\n      type: 'date',\r\n      pipe: EnumCoreTablePipeType.DATE,\r\n      align: 'center',\r\n      width: 100,\r\n    },\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_LIQUIDATION_REASON,\r\n      field: 'liquidationReason',\r\n      type: 'string',\r\n      align: 'left',\r\n      width: 200,\r\n    },\r\n\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_SIGNDATE,\r\n      field: 'signDate',\r\n      type: 'date',\r\n      pipe: EnumCoreTablePipeType.DATE,\r\n      align: 'center',\r\n      width: 100,\r\n    },\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_SIGNERNAME,\r\n      field: 'signerName',\r\n      type: 'string',\r\n      align: 'left',\r\n      width: 150,\r\n    },\r\n    {\r\n      caption: EnumTranslateKey.UI_COMPONENT_LABEL_CONTRACT_SIGNERPOSITION,\r\n      field: 'signerPosition',\r\n      type: 'string',\r\n      align: 'left',\r\n      width: 250,\r\n    },\r\n\r\n  ]\r\n\r\n  defaultAvatar!: string;\r\n\r\n  editRoute: ICorePageListEditRouting = {\r\n    auxiliary: 'popupAux'\r\n  }\r\n  /* End Properties being passed to core-page-list */\r\n  generateTemplateRequest!: IGenerateTemplateRequest;\r\n  constructor(\r\n    public override mls: MultiLanguageService,\r\n    private ras: RandomAvatarService,\r\n    private router: Router,\r\n    private route: ActivatedRoute,\r\n    private organizationService: OrganizationService,\r\n    private http: HttpClient,\r\n    private appService: AppService,\r\n    private corePageListService: CorePageListService,\r\n    private contractInforService: ContractInforService,\r\n    private alertService: AlertService\r\n  ) {\r\n    super(mls);\r\n    this.defaultAvatar = ras.get();\r\n    /* Get orgIds startup value */\r\n    const newOrgIds: number[] = [];\r\n    this.organizationService.status$.value.activeKeys.map(x => newOrgIds.push(Number(x)))\r\n    this.onOrgIdsChange(newOrgIds)\r\n    this.corePageListInstanceNumber = new Date().getTime();\r\n  }\r\n  override ngOnInit(): void {\r\n    this.mls.lang$.subscribe(x => {\r\n      this.lang = x;\r\n      this.generateTemplateRequest = {\r\n        exCode: 'HU_CONTRACT',\r\n        lang: x\r\n      }\r\n    })\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    const stickerFilter = this.columns.filter(c => c.field === 'statusName');\r\n    if (!!stickerFilter.length) stickerFilter[0].templateRef = this.sticker;\r\n  }\r\n\r\n  onOrgIdsChange(orgIds: number[]) {\r\n    this.orgIds = orgIds\r\n    this.outerInOperators = [\r\n      {\r\n        field: 'orgId',\r\n        values: orgIds\r\n      }\r\n    ]\r\n  }\r\n\r\n  onRowClick(e: any) {\r\n    this.id = e.id\r\n  }\r\n\r\n  selectedIds: number[] = [];\r\n  \r\n  listInstance!: number;\r\n  \r\n  onInstanceCreated(event: number) {\r\n    this.listInstance = event;\r\n  }\r\n\r\n  alertOptions: IAlertOptions = {\r\n    autoClose: true,\r\n    keepAfterRouteChange: true,\r\n    timeClose: 10000\r\n  };\r\n\r\n  employeeId!: number;\r\n\r\n  customizeSelectedIdsChange(e: number[]): void {\r\n    this.selectedIds = e;\r\n\r\n    this.contractInforService.changeListEmployeeSelected(e);\r\n    this.contractInforService.currentListEmployeeSelected.subscribe(id => this.employeeId = id[0]);\r\n  }\r\n\r\n  corePageListInstanceNumber!: number;\r\n\r\n  onCorePageHeaderButtonClick(e: ICoreButtonVNS) {\r\n    let filename = '';\r\n\r\n    switch (e.code) {\r\n      case EnumCoreButtonVNSCode.HEADER_LIQUIDATE_CONTRACT:\r\n        if (this.selectedIds.length != 0) {\r\n          this.router.navigate(\r\n            [\r\n              {\r\n                outlets: {\r\n                  corePageListAux: [\r\n                    btoa('0'),\r\n                    { listInstance: this.corePageListInstanceNumber },\r\n                  ],\r\n                },\r\n              },\r\n            ],\r\n            { relativeTo: this.route }\r\n          );\r\n        }\r\n        else {\r\n          // bắn ra thông báo chưa chọn bản ghi\r\n          this.alertService.error(this.mls.trans('NO_SELECTED_ID_TO_DELETE'), this.alertOptions);\r\n        }\r\n\r\n        break;\r\n\r\n      case EnumCoreButtonVNSCode.HEADER_PRINT:\r\n        if (this.selectedIds.length > 1) {\r\n          this.alertService.warn(this.mls.trans('PRINT_ONE_RECORD'), alertOptions);\r\n        }\r\n        else {\r\n          this.http.get(api.HU_CONTRACT_GET_FILE_NAME + this.selectedIds[0].toString()).subscribe((response: any) => {\r\n            filename = response.innerBody;\r\n          });\r\n\r\n          this.loading = true;\r\n\r\n          this.http\r\n            .get(api.HU_CONTRACT_GET_PROBATION_CONTRACT, {\r\n              responseType: 'blob',\r\n              params: { id: this.selectedIds[0].toString() }\r\n            })\r\n            .subscribe((response: Blob) => {\r\n              if (response.type === 'application/octet-stream') {\r\n                const downloadUrl = URL.createObjectURL(response);\r\n                \r\n                const link = document.createElement('a');\r\n                \r\n                link.href = downloadUrl;\r\n                \r\n                // link.setAttribute('download', '2C_BNV_2008_' + filename + '.doc');\r\n                link.setAttribute('download', filename + '.doc');\r\n                \r\n                document.body.appendChild(link);\r\n                \r\n                link.click();\r\n                \r\n                document.body.removeChild(link);\r\n                \r\n                URL.revokeObjectURL(downloadUrl);\r\n              }\r\n              else {\r\n                const reader = new FileReader();\r\n                \r\n                reader.onload = () => {\r\n                  const jsonBody = reader.result as string;\r\n                  \r\n                  const data = JSON.parse(jsonBody);\r\n                  \r\n                  if (data.statusCode == 200) {\r\n                    this.alertService.success(data.messageCode, alertOptions);\r\n                  }\r\n                  else {\r\n                    this.alertService.error(data.messageCode, alertOptions);\r\n                  }\r\n                };\r\n\r\n                reader.readAsText(response);\r\n              }\r\n\r\n              this.loading = false;\r\n            });\r\n        }\r\n        break;\r\n\r\n      default:\r\n        break;\r\n    }\r\n  }\r\n\r\n}\r\n","<div class=\"cms-profile-contractinfor-container\">\r\n  <core-page-list\r\n    [apiDefinition]=\"apiDefinition\"\r\n    [columns]=\"columns\"\r\n    [editRoute]=\"editRoute\"\r\n    [crud]=\"crud\"\r\n    [title]=\"title\"\r\n    [left]=\"orgTree\"\r\n    [outerParam$]=\"outerParam$\"\r\n    [normalMode]=\"true\"\r\n    [outerInOperators]=\"outerInOperators\"\r\n    [autoResizeWithWindow]=\"true\"\r\n    (rowClick)=\"onRowClick($event)\"\r\n    [showParamKit]=\"true\"\r\n    [datePeriodComparisonFor]=\"datePeriodComparisonFor\"\r\n    [datePeriodComparisonForLabelKey]=\"datePeriodComparisonForLabelKey\"\r\n    [statusInclusionFor]=\"statusInclusionFor\"\r\n    [statusInclusionForLabelKey]=\"statusInclusionForLabelKey\"\r\n    [statusOptionsApi]=\"statusOptionsApi\"\r\n    [generateTemplateRequest]=\"generateTemplateRequest\"\r\n    (corePageHeaderButtonClick)=\"onCorePageHeaderButtonClick($event)\"\r\n    [importPreviewPath]=\"'contract-import'\"\r\n    [outerSort]=\"outerSort\"\r\n    [frozen]=\"3\"\r\n\r\n    (selectedIdsChange)=\"customizeSelectedIdsChange($event)\"\r\n    (onInstanceCreated)=\"onInstanceCreated($event)\"\r\n  >\r\n  </core-page-list>\r\n\r\n  <ng-template #orgTree>\r\n    <core-org-tree [(ngModel)]=\"orgIds\" (ngModelChange)=\"onOrgIdsChange($event)\">\r\n    </core-org-tree>\r\n  </ng-template>\r\n\r\n  <ng-template #sticker let-code=\"context.statusName\">\r\n    <core-status-sticker [code]=\"code\"></core-status-sticker>\r\n  </ng-template>\r\n</div>"]}
|
|
@@ -208,7 +208,7 @@ export class CoreFormComponent {
|
|
|
208
208
|
this.buttonClick.emit(e);
|
|
209
209
|
}
|
|
210
210
|
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 }); }
|
|
211
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.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: "@if (!!form) {\r\n<div class=\"core-form-container\">\r\n\r\n <form #formRef (ngSubmit)=\"onFormSubmit()\" [formGroup]=\"form\" autocomplete=\"off\">\r\n\r\n <div class=\"row\">\r\n\r\n @if (!!leftInputSections) {\r\n <div [class]=\"'col-md-' + (leftInputSectionsFlexSize || 0)\">\r\n\r\n @for (section of leftInputSections; track $index) {\r\n <div class=\"section\"\r\n [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!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 $index) {\r\n <div class=\"row mb15\">\r\n @for (col of row; track $index) {\r\n <div [class]=\"'col-md-' + col.flexSize\" [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 }\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n }\r\n\r\n </div>\r\n }\r\n\r\n <div [class]=\"'col-md-' + (12 - (leftInputSectionsFlexSize || 0))\">\r\n\r\n @for (section of sections; track $index) {\r\n <div class=\"section\"\r\n [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!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 $index) {\r\n <div class=\"row mb15\">\r\n @for (col of row; track $index) {\r\n <div [class]=\"'col-md-' + col.flexSize\" [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 }\r\n </div>\r\n }\r\n\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n </div>\r\n\r\n\r\n @if (!!bottomTemplateRef) {\r\n <ng-container *ngTemplateOutlet=\"bottomTemplateRef\"></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\"\r\n (buttonClick)=\"onButtonClick($event)\" [shownItems]=\"buttonItems\"\r\n class=\"buttonGroupCustom\"></core-button-group-vns>\r\n </div>\r\n @if (isDevMode) {\r\n <div class=\"form-row\">\r\n <
|
|
211
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.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: "@if (!!form) {\r\n<div class=\"core-form-container\">\r\n\r\n <form #formRef (ngSubmit)=\"onFormSubmit()\" [formGroup]=\"form\" autocomplete=\"off\">\r\n\r\n <div class=\"row\">\r\n\r\n @if (!!leftInputSections) {\r\n <div [class]=\"'col-md-' + (leftInputSectionsFlexSize || 0)\">\r\n\r\n @for (section of leftInputSections; track $index) {\r\n <div class=\"section\"\r\n [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!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 $index) {\r\n <div class=\"row mb15\">\r\n @for (col of row; track $index) {\r\n <div [class]=\"'col-md-' + col.flexSize\" [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 }\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n }\r\n\r\n </div>\r\n }\r\n\r\n <div [class]=\"'col-md-' + (12 - (leftInputSectionsFlexSize || 0))\">\r\n\r\n @for (section of sections; track $index) {\r\n <div class=\"section\"\r\n [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!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 $index) {\r\n <div class=\"row mb15\">\r\n @for (col of row; track $index) {\r\n <div [class]=\"'col-md-' + col.flexSize\" [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 }\r\n </div>\r\n }\r\n\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n </div>\r\n\r\n\r\n @if (!!bottomTemplateRef) {\r\n <ng-container *ngTemplateOutlet=\"bottomTemplateRef\"></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\"\r\n (buttonClick)=\"onButtonClick($event)\" [shownItems]=\"buttonItems\"\r\n class=\"buttonGroupCustom\"></core-button-group-vns>\r\n </div>\r\n @if (isDevMode) {\r\n <div class=\"form-row d-flex d-flex-center\">\r\n <div class=\"dev-button\" (click)=\"updatePayload()\">Show\r\n values</div>\r\n <div class=\"dev-button\" (click)=\"updateValidorOverview()\">Show\r\n validators</div>\r\n </div>\r\n }\r\n\r\n </form>\r\n\r\n @if (!!payLoad && isDevMode) {\r\n <div class=\"form-row payload-preview\">\r\n <strong>Current values</strong><br>{{payLoad}}\r\n </div>\r\n }\r\n\r\n @if (!!validatorOverview && isDevMode) {\r\n <div class=\"form-row payload-preview\">\r\n <strong>Current errors</strong><br>{{validatorOverview}}\r\n </div>\r\n }\r\n\r\n</div>\r\n}", 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;border-radius:0}.core-form-container .form-row>button:not(:first-child){margin-left:var(--size-layout-block-cell-spacing)}.core-form-container .dev-button{cursor:pointer;display:flex;align-items:center;border:1px gray solid;font-size:13px;padding:8px}.core-form-container .payload-preview{display:block;width:100%;height:200px;white-space:pre-wrap;overflow-x:hidden;overflow-y:auto;color:gray!important;background-color:transparent!important}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { 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"] }] }); }
|
|
212
212
|
}
|
|
213
213
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreFormComponent, decorators: [{
|
|
214
214
|
type: Component,
|
|
@@ -219,7 +219,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
219
219
|
CoreControlComponent,
|
|
220
220
|
TranslatePipe,
|
|
221
221
|
CoreButtonGroupVnsComponent
|
|
222
|
-
], template: "@if (!!form) {\r\n<div class=\"core-form-container\">\r\n\r\n <form #formRef (ngSubmit)=\"onFormSubmit()\" [formGroup]=\"form\" autocomplete=\"off\">\r\n\r\n <div class=\"row\">\r\n\r\n @if (!!leftInputSections) {\r\n <div [class]=\"'col-md-' + (leftInputSectionsFlexSize || 0)\">\r\n\r\n @for (section of leftInputSections; track $index) {\r\n <div class=\"section\"\r\n [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!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 $index) {\r\n <div class=\"row mb15\">\r\n @for (col of row; track $index) {\r\n <div [class]=\"'col-md-' + col.flexSize\" [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 }\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n }\r\n\r\n </div>\r\n }\r\n\r\n <div [class]=\"'col-md-' + (12 - (leftInputSectionsFlexSize || 0))\">\r\n\r\n @for (section of sections; track $index) {\r\n <div class=\"section\"\r\n [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!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 $index) {\r\n <div class=\"row mb15\">\r\n @for (col of row; track $index) {\r\n <div [class]=\"'col-md-' + col.flexSize\" [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 }\r\n </div>\r\n }\r\n\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n </div>\r\n\r\n\r\n @if (!!bottomTemplateRef) {\r\n <ng-container *ngTemplateOutlet=\"bottomTemplateRef\"></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\"\r\n (buttonClick)=\"onButtonClick($event)\" [shownItems]=\"buttonItems\"\r\n class=\"buttonGroupCustom\"></core-button-group-vns>\r\n </div>\r\n @if (isDevMode) {\r\n <div class=\"form-row\">\r\n <
|
|
222
|
+
], template: "@if (!!form) {\r\n<div class=\"core-form-container\">\r\n\r\n <form #formRef (ngSubmit)=\"onFormSubmit()\" [formGroup]=\"form\" autocomplete=\"off\">\r\n\r\n <div class=\"row\">\r\n\r\n @if (!!leftInputSections) {\r\n <div [class]=\"'col-md-' + (leftInputSectionsFlexSize || 0)\">\r\n\r\n @for (section of leftInputSections; track $index) {\r\n <div class=\"section\"\r\n [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!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 $index) {\r\n <div class=\"row mb15\">\r\n @for (col of row; track $index) {\r\n <div [class]=\"'col-md-' + col.flexSize\" [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 }\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n }\r\n\r\n </div>\r\n }\r\n\r\n <div [class]=\"'col-md-' + (12 - (leftInputSectionsFlexSize || 0))\">\r\n\r\n @for (section of sections; track $index) {\r\n <div class=\"section\"\r\n [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!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 $index) {\r\n <div class=\"row mb15\">\r\n @for (col of row; track $index) {\r\n <div [class]=\"'col-md-' + col.flexSize\" [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 }\r\n </div>\r\n }\r\n\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n </div>\r\n\r\n\r\n @if (!!bottomTemplateRef) {\r\n <ng-container *ngTemplateOutlet=\"bottomTemplateRef\"></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\"\r\n (buttonClick)=\"onButtonClick($event)\" [shownItems]=\"buttonItems\"\r\n class=\"buttonGroupCustom\"></core-button-group-vns>\r\n </div>\r\n @if (isDevMode) {\r\n <div class=\"form-row d-flex d-flex-center\">\r\n <div class=\"dev-button\" (click)=\"updatePayload()\">Show\r\n values</div>\r\n <div class=\"dev-button\" (click)=\"updateValidorOverview()\">Show\r\n validators</div>\r\n </div>\r\n }\r\n\r\n </form>\r\n\r\n @if (!!payLoad && isDevMode) {\r\n <div class=\"form-row payload-preview\">\r\n <strong>Current values</strong><br>{{payLoad}}\r\n </div>\r\n }\r\n\r\n @if (!!validatorOverview && isDevMode) {\r\n <div class=\"form-row payload-preview\">\r\n <strong>Current errors</strong><br>{{validatorOverview}}\r\n </div>\r\n }\r\n\r\n</div>\r\n}", 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;border-radius:0}.core-form-container .form-row>button:not(:first-child){margin-left:var(--size-layout-block-cell-spacing)}.core-form-container .dev-button{cursor:pointer;display:flex;align-items:center;border:1px gray solid;font-size:13px;padding:8px}.core-form-container .payload-preview{display:block;width:100%;height:200px;white-space:pre-wrap;overflow-x:hidden;overflow-y:auto;color:gray!important;background-color:transparent!important}\n"] }]
|
|
223
223
|
}], ctorParameters: () => [{ type: i1.CoreControlService }, { type: i2.MultiLanguageService }, { type: i3.AlertService }, { type: i4.CoreFormService }, { type: i5.AppConfigService }], propDecorators: { formName: [{
|
|
224
224
|
type: Input
|
|
225
225
|
}], submitText: [{
|
|
@@ -258,4 +258,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
258
258
|
type: ViewChild,
|
|
259
259
|
args: ['formRef']
|
|
260
260
|
}] } });
|
|
261
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-form.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-form/core-form/core-form.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-form/core-form/core-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChanges, TemplateRef, ViewChild, isDevMode, } from '@angular/core';\r\nimport { AbstractControl, FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { ICoreFormSection } from './enum-interfaces';\r\nimport { CoreControlService } from '../core-control.service';\r\nimport { BehaviorSubject, Subscription } from 'rxjs';\r\nimport { AlertService } from '../../alert/alert.service';\r\nimport { EnumCorePageEditMode } from '../../core-page-edit/EnumCorePageEditMode';\r\nimport { CoreFormService } from '../core-form.service';\r\nimport { ICoreButtonVNS } from '../../core-button-group-vns/core-button-group-vns/ICoreButtonVNS';\r\nimport { EnumCoreButtonVNSCode } from '../../core-button-group-vns/core-button-group-vns/EnumCoreButtonVNSCode';\r\nimport { EnumTranslateKey } from \"alpha-global-constants\";\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { noneAutoClosedAlertOptions } from '../../../constants/alertOptions';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CoreControlComponent } from '../../core-control/core-control/core-control.component';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\nimport { CoreButtonGroupVnsComponent } from '../../core-button-group-vns/core-button-group-vns/core-button-group-vns.component';\r\nimport { AppConfigService } from '../../../services/app-config.service';\r\n\r\nexport interface IDynamicFormEmitOnFormCreated {\r\n  formName: string;\r\n  formGroup: FormGroup;\r\n}\r\n\r\n@Component({\r\n  selector: 'core-form',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    CoreControlComponent,\r\n    TranslatePipe,\r\n    CoreButtonGroupVnsComponent\r\n  ],\r\n  templateUrl: './core-form.component.html',\r\n  styleUrls: ['./core-form.component.scss'],\r\n})\r\nexport class CoreFormComponent implements OnChanges, OnInit, AfterViewInit, OnDestroy {\r\n\r\n  @Input() formName!: string;\r\n  @Input() submitText!: EnumTranslateKey;\r\n  @Input() leftInputSections!: ICoreFormSection[];\r\n  @Input() leftInputSectionsFlexSize!: number;\r\n  @Input() inputSections!: ICoreFormSection[];\r\n  @Input() mode$!: BehaviorSubject<EnumCorePageEditMode>;\r\n  @Input() bottomTemplateRef!: TemplateRef<any>;\r\n  @Input() customFormButtonItems!: EnumCoreButtonVNSCode[]; // Optional\r\n  @Input() showCaptionButton!: boolean;\r\n  @Input() disableSaveButton!: boolean;\r\n  @Input() checkError$ = new BehaviorSubject<boolean>(false);\r\n\r\n  @Output() onFormCreated = new EventEmitter<IDynamicFormEmitOnFormCreated>();\r\n  @Output() onFormRefCreated = new EventEmitter<ElementRef<any>>();\r\n  @Output() onSubmit = new EventEmitter();\r\n  @Output() onSave = new EventEmitter();\r\n  @Output() onCancal = new EventEmitter();\r\n  @Output() buttonClick = new EventEmitter<ICoreButtonVNS>();\r\n\r\n\r\n  @ViewChild('formRef') formRef!: ElementRef;\r\n\r\n  buttonItems!: EnumCoreButtonVNSCode[];\r\n\r\n  form!: FormGroup;\r\n  sections!: ICoreFormSection[];\r\n  lang!: string;\r\n  subscriptions: Subscription[] = [];\r\n\r\n  payLoad = '';\r\n  validatorOverview: any;\r\n  isDevMode!: boolean;\r\n  isUpdateMode!: boolean;\r\n\r\n  constructor(\r\n    private coreControlService: CoreControlService,\r\n    private multiLanguageService: MultiLanguageService,\r\n    private alertService: AlertService,\r\n    private coreFormService: CoreFormService,\r\n    private appConfigService: AppConfigService\r\n  ) {\r\n    this.isDevMode = isDevMode();\r\n  }\r\n\r\n  private updateSections(newSections: ICoreFormSection[]): void {\r\n\r\n    this.sections.map((section, sectionIndex) => {\r\n      const newSection = newSections[sectionIndex];\r\n      section.rows.map((row, rowIndex) => {\r\n        const newRow = newSection.rows[rowIndex];\r\n        row.map((control, controlIndex) => {\r\n          const newControl = newRow[controlIndex];\r\n\r\n          /* THE ONLY PROP TO BE UDATED IS 'hidden', THE OTHERS SHOULD BE MANIPULATED THROUGH this.form.get(YOUR_CONTROL_NAME)... */\r\n          control.hidden = newControl?.hidden;\r\n          /************************************************************************************************************************/\r\n        });\r\n      });\r\n\r\n      /* #region Oct the 11th 2023 */\r\n      /* Some sections was posibly have renderOff=true from previous state and their controls must be created/remove */\r\n      /*\r\n      BUT THIS TASK IS HARD SO FAR\r\n      */\r\n      /* #endregion Oct the 11th 2023 */\r\n\r\n    });\r\n\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['inputSections']) {\r\n      let newSections: ICoreFormSection[] =\r\n        changes['inputSections'].currentValue;\r\n\r\n      if (!!!this.form) {\r\n        this.sections = newSections;\r\n\r\n        let leftGroup;\r\n        let form: FormGroup<any>;\r\n\r\n        const mainGroup = this.coreControlService.toGroup(this.sections);\r\n\r\n        if (!!this.leftInputSections) {\r\n          leftGroup = this.coreControlService.toGroup(this.leftInputSections);\r\n          form = new FormGroup({ ...leftGroup, ...mainGroup });\r\n        } else {\r\n          form = new FormGroup(mainGroup);\r\n        }\r\n\r\n        this.form = form;\r\n\r\n      } else {\r\n        this.updateSections(newSections);\r\n      }\r\n\r\n      this.onFormCreated.emit({\r\n        formName: this.formName,\r\n        formGroup: this.form,\r\n      });\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n\r\n    /*\r\n    if (this.appConfigService.APP_TYPE === \"WEBAPP\") {\r\n    */\r\n\r\n      if (!this.disableSaveButton) {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.NONE_HEADER_SAVE,\r\n          EnumCoreButtonVNSCode.NONE_HEADER_CANCEL,\r\n        ]\r\n      } else {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.NONE_HEADER_CANCEL,\r\n        ]\r\n      }\r\n\r\n    /*\r\n    } else if (this.appConfigService.APP_TYPE === \"PORTAL\") {\r\n      if (!this.disableSaveButton) {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.SEND,\r\n          EnumCoreButtonVNSCode.CANCEL,\r\n          EnumCoreButtonVNSCode.SAVE,\r\n        ]\r\n      } else {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.SEND,\r\n          EnumCoreButtonVNSCode.CANCEL,\r\n        ]\r\n      }\r\n    }\r\n    */\r\n\r\n    if (!!this.customFormButtonItems) {\r\n      this.buttonItems = this.customFormButtonItems;\r\n    }\r\n\r\n    this.subscriptions.push(\r\n      this.mode$.subscribe(\r\n        (x) => (this.isUpdateMode = x === EnumCorePageEditMode.UPDATE)\r\n      )\r\n    );\r\n\r\n    console.log(this.mode$);\r\n\r\n    /* START: Check if id field is available */\r\n    if (!!!this.form.get('id') && isDevMode()) {\r\n      this.alertService.error(\r\n        `\r\n            Control \"id\" is mandatory. Please define one in your bussiness component. You can assign its \"hidden\" property to true if needed.\r\n          `,\r\n        noneAutoClosedAlertOptions\r\n      );\r\n    }\r\n    /* END: Check if id field is available */\r\n\r\n    if (isDevMode()) {\r\n      /* START: Check if each field is unique */\r\n\r\n      const fields = this.coreFormService.getAllFormBaseControlNames(\r\n        this.sections\r\n      );\r\n\r\n      fields.reduce((p, c) => {\r\n        if (c === '') {\r\n          this.alertService.error(\r\n            `Form control name must be definded, '${c}' is invalid form control name!!!`,\r\n            noneAutoClosedAlertOptions\r\n          );\r\n        } else {\r\n          if (p === c) {\r\n            this.alertService.error(\r\n              `Duplicate form control name: '${c}'. Consider to predefine one ONLY!!!.`,\r\n              noneAutoClosedAlertOptions\r\n            );\r\n          }\r\n        }\r\n        return c;\r\n      });\r\n      /* END: Check if each field is unique */\r\n    }\r\n\r\n    this.subscriptions.push(\r\n      this.multiLanguageService.lang$.subscribe((x) => (this.lang = x))\r\n    );\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.onFormRefCreated.emit(this.formRef);\r\n  }\r\n\r\n  onFormSubmit() {\r\n    this.checkError$.next(true);\r\n    if (!!this.form.valid) {\r\n      this.payLoad = JSON.stringify(this.form?.getRawValue(), null, 2);\r\n      this.onSubmit.emit(this.form?.getRawValue());\r\n    }\r\n  }\r\n\r\n  onFormSave() {\r\n    this.checkError$.next(true);\r\n    if (!!this.form.valid) {\r\n      this.payLoad = JSON.stringify(this.form?.getRawValue(), null, 2);\r\n      this.onSave.emit(this.form?.getRawValue());\r\n    }\r\n    setTimeout(() => this.checkError$.next(false), 3000);\r\n  }\r\n\r\n  onCancelLocal() {\r\n    this.onCancal.emit(null);\r\n  }\r\n\r\n  updatePayload(): void {\r\n    this.payLoad = JSON.stringify(this.form?.getRawValue(), null, 2);\r\n  }\r\n\r\n  updateValidorOverview(): void {\r\n    const result: { key: string; errors: any[] }[] = [];\r\n    Object.keys(this.form.controls).forEach((key) => {\r\n      const control: AbstractControl = this.form.get(key)!;\r\n      const errors: any[] = [];\r\n      if (!!control.invalid) {\r\n        Object.keys(control.errors!).forEach((key) => {\r\n          errors.push(key);\r\n        });\r\n      }\r\n      result.push({\r\n        key,\r\n        errors,\r\n      });\r\n    });\r\n    this.validatorOverview = JSON.stringify(result, null, 2);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.map((x) => x?.unsubscribe());\r\n  }\r\n\r\n  onButtonClick(e: ICoreButtonVNS): void {\r\n\r\n    switch (e.code) {\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_CANCEL:\r\n      case EnumCoreButtonVNSCode.CANCEL:\r\n        this.onCancelLocal();\r\n        break;\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_SAVE:\r\n      case EnumCoreButtonVNSCode.SEND:\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_DELETE:\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_LIQUIDATE_CONTRACT:\r\n      case EnumCoreButtonVNSCode.ONFORMDELETE:\r\n      case EnumCoreButtonVNSCode.SAVE_PASSWORD:\r\n        this.onFormSubmit();\r\n        break;\r\n      case EnumCoreButtonVNSCode.SAVE:\r\n        this.onFormSave();\r\n        break;\r\n      default:\r\n        break;\r\n    }\r\n    this.buttonClick.emit(e);\r\n  }\r\n}\r\n","@if (!!form) {\r\n<div class=\"core-form-container\">\r\n\r\n    <form #formRef (ngSubmit)=\"onFormSubmit()\" [formGroup]=\"form\" autocomplete=\"off\">\r\n\r\n        <div class=\"row\">\r\n\r\n            @if (!!leftInputSections) {\r\n            <div [class]=\"'col-md-' + (leftInputSectionsFlexSize || 0)\">\r\n\r\n                @for (section of leftInputSections; track $index) {\r\n                <div class=\"section\"\r\n                    [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!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 $index) {\r\n                    <div class=\"row mb15\">\r\n                        @for (col of row; track $index) {\r\n                        <div [class]=\"'col-md-' + col.flexSize\" [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                        }\r\n                    </div>\r\n                    }\r\n\r\n                </div>\r\n\r\n                }\r\n\r\n            </div>\r\n            }\r\n\r\n            <div [class]=\"'col-md-' + (12 - (leftInputSectionsFlexSize || 0))\">\r\n\r\n                @for (section of sections; track $index) {\r\n                <div class=\"section\"\r\n                    [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!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 $index) {\r\n                    <div class=\"row mb15\">\r\n                        @for (col of row; track $index) {\r\n                        <div [class]=\"'col-md-' + col.flexSize\" [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                        }\r\n                    </div>\r\n                    }\r\n\r\n                </div>\r\n                }\r\n\r\n            </div>\r\n\r\n        </div>\r\n\r\n\r\n        @if (!!bottomTemplateRef) {\r\n        <ng-container *ngTemplateOutlet=\"bottomTemplateRef\"></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\"\r\n                (buttonClick)=\"onButtonClick($event)\" [shownItems]=\"buttonItems\"\r\n                class=\"buttonGroupCustom\"></core-button-group-vns>\r\n        </div>\r\n        @if (isDevMode) {\r\n        <div class=\"form-row\">\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        }\r\n\r\n    </form>\r\n\r\n    @if (!!payLoad && isDevMode) {\r\n    <div class=\"form-row payload-preview\">\r\n        <strong>Current values</strong><br>{{payLoad}}\r\n    </div>\r\n    }\r\n\r\n    @if (!!validatorOverview && isDevMode) {\r\n    <div class=\"form-row payload-preview\">\r\n        <strong>Current errors</strong><br>{{validatorOverview}}\r\n    </div>\r\n    }\r\n\r\n</div>\r\n}"]}
|
|
261
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-form.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-form/core-form/core-form.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-form/core-form/core-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChanges, TemplateRef, ViewChild, isDevMode, } from '@angular/core';\r\nimport { AbstractControl, FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { ICoreFormSection } from './enum-interfaces';\r\nimport { CoreControlService } from '../core-control.service';\r\nimport { BehaviorSubject, Subscription } from 'rxjs';\r\nimport { AlertService } from '../../alert/alert.service';\r\nimport { EnumCorePageEditMode } from '../../core-page-edit/EnumCorePageEditMode';\r\nimport { CoreFormService } from '../core-form.service';\r\nimport { ICoreButtonVNS } from '../../core-button-group-vns/core-button-group-vns/ICoreButtonVNS';\r\nimport { EnumCoreButtonVNSCode } from '../../core-button-group-vns/core-button-group-vns/EnumCoreButtonVNSCode';\r\nimport { EnumTranslateKey } from \"alpha-global-constants\";\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { noneAutoClosedAlertOptions } from '../../../constants/alertOptions';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CoreControlComponent } from '../../core-control/core-control/core-control.component';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\nimport { CoreButtonGroupVnsComponent } from '../../core-button-group-vns/core-button-group-vns/core-button-group-vns.component';\r\nimport { AppConfigService } from '../../../services/app-config.service';\r\n\r\nexport interface IDynamicFormEmitOnFormCreated {\r\n  formName: string;\r\n  formGroup: FormGroup;\r\n}\r\n\r\n@Component({\r\n  selector: 'core-form',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    CoreControlComponent,\r\n    TranslatePipe,\r\n    CoreButtonGroupVnsComponent\r\n  ],\r\n  templateUrl: './core-form.component.html',\r\n  styleUrls: ['./core-form.component.scss'],\r\n})\r\nexport class CoreFormComponent implements OnChanges, OnInit, AfterViewInit, OnDestroy {\r\n\r\n  @Input() formName!: string;\r\n  @Input() submitText!: EnumTranslateKey;\r\n  @Input() leftInputSections!: ICoreFormSection[];\r\n  @Input() leftInputSectionsFlexSize!: number;\r\n  @Input() inputSections!: ICoreFormSection[];\r\n  @Input() mode$!: BehaviorSubject<EnumCorePageEditMode>;\r\n  @Input() bottomTemplateRef!: TemplateRef<any>;\r\n  @Input() customFormButtonItems!: EnumCoreButtonVNSCode[]; // Optional\r\n  @Input() showCaptionButton!: boolean;\r\n  @Input() disableSaveButton!: boolean;\r\n  @Input() checkError$ = new BehaviorSubject<boolean>(false);\r\n\r\n  @Output() onFormCreated = new EventEmitter<IDynamicFormEmitOnFormCreated>();\r\n  @Output() onFormRefCreated = new EventEmitter<ElementRef<any>>();\r\n  @Output() onSubmit = new EventEmitter();\r\n  @Output() onSave = new EventEmitter();\r\n  @Output() onCancal = new EventEmitter();\r\n  @Output() buttonClick = new EventEmitter<ICoreButtonVNS>();\r\n\r\n\r\n  @ViewChild('formRef') formRef!: ElementRef;\r\n\r\n  buttonItems!: EnumCoreButtonVNSCode[];\r\n\r\n  form!: FormGroup;\r\n  sections!: ICoreFormSection[];\r\n  lang!: string;\r\n  subscriptions: Subscription[] = [];\r\n\r\n  payLoad = '';\r\n  validatorOverview: any;\r\n  isDevMode!: boolean;\r\n  isUpdateMode!: boolean;\r\n\r\n  constructor(\r\n    private coreControlService: CoreControlService,\r\n    private multiLanguageService: MultiLanguageService,\r\n    private alertService: AlertService,\r\n    private coreFormService: CoreFormService,\r\n    private appConfigService: AppConfigService\r\n  ) {\r\n    this.isDevMode = isDevMode();\r\n  }\r\n\r\n  private updateSections(newSections: ICoreFormSection[]): void {\r\n\r\n    this.sections.map((section, sectionIndex) => {\r\n      const newSection = newSections[sectionIndex];\r\n      section.rows.map((row, rowIndex) => {\r\n        const newRow = newSection.rows[rowIndex];\r\n        row.map((control, controlIndex) => {\r\n          const newControl = newRow[controlIndex];\r\n\r\n          /* THE ONLY PROP TO BE UDATED IS 'hidden', THE OTHERS SHOULD BE MANIPULATED THROUGH this.form.get(YOUR_CONTROL_NAME)... */\r\n          control.hidden = newControl?.hidden;\r\n          /************************************************************************************************************************/\r\n        });\r\n      });\r\n\r\n      /* #region Oct the 11th 2023 */\r\n      /* Some sections was posibly have renderOff=true from previous state and their controls must be created/remove */\r\n      /*\r\n      BUT THIS TASK IS HARD SO FAR\r\n      */\r\n      /* #endregion Oct the 11th 2023 */\r\n\r\n    });\r\n\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['inputSections']) {\r\n      let newSections: ICoreFormSection[] =\r\n        changes['inputSections'].currentValue;\r\n\r\n      if (!!!this.form) {\r\n        this.sections = newSections;\r\n\r\n        let leftGroup;\r\n        let form: FormGroup<any>;\r\n\r\n        const mainGroup = this.coreControlService.toGroup(this.sections);\r\n\r\n        if (!!this.leftInputSections) {\r\n          leftGroup = this.coreControlService.toGroup(this.leftInputSections);\r\n          form = new FormGroup({ ...leftGroup, ...mainGroup });\r\n        } else {\r\n          form = new FormGroup(mainGroup);\r\n        }\r\n\r\n        this.form = form;\r\n\r\n      } else {\r\n        this.updateSections(newSections);\r\n      }\r\n\r\n      this.onFormCreated.emit({\r\n        formName: this.formName,\r\n        formGroup: this.form,\r\n      });\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n\r\n    /*\r\n    if (this.appConfigService.APP_TYPE === \"WEBAPP\") {\r\n    */\r\n\r\n      if (!this.disableSaveButton) {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.NONE_HEADER_SAVE,\r\n          EnumCoreButtonVNSCode.NONE_HEADER_CANCEL,\r\n        ]\r\n      } else {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.NONE_HEADER_CANCEL,\r\n        ]\r\n      }\r\n\r\n    /*\r\n    } else if (this.appConfigService.APP_TYPE === \"PORTAL\") {\r\n      if (!this.disableSaveButton) {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.SEND,\r\n          EnumCoreButtonVNSCode.CANCEL,\r\n          EnumCoreButtonVNSCode.SAVE,\r\n        ]\r\n      } else {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.SEND,\r\n          EnumCoreButtonVNSCode.CANCEL,\r\n        ]\r\n      }\r\n    }\r\n    */\r\n\r\n    if (!!this.customFormButtonItems) {\r\n      this.buttonItems = this.customFormButtonItems;\r\n    }\r\n\r\n    this.subscriptions.push(\r\n      this.mode$.subscribe(\r\n        (x) => (this.isUpdateMode = x === EnumCorePageEditMode.UPDATE)\r\n      )\r\n    );\r\n\r\n    console.log(this.mode$);\r\n\r\n    /* START: Check if id field is available */\r\n    if (!!!this.form.get('id') && isDevMode()) {\r\n      this.alertService.error(\r\n        `\r\n            Control \"id\" is mandatory. Please define one in your bussiness component. You can assign its \"hidden\" property to true if needed.\r\n          `,\r\n        noneAutoClosedAlertOptions\r\n      );\r\n    }\r\n    /* END: Check if id field is available */\r\n\r\n    if (isDevMode()) {\r\n      /* START: Check if each field is unique */\r\n\r\n      const fields = this.coreFormService.getAllFormBaseControlNames(\r\n        this.sections\r\n      );\r\n\r\n      fields.reduce((p, c) => {\r\n        if (c === '') {\r\n          this.alertService.error(\r\n            `Form control name must be definded, '${c}' is invalid form control name!!!`,\r\n            noneAutoClosedAlertOptions\r\n          );\r\n        } else {\r\n          if (p === c) {\r\n            this.alertService.error(\r\n              `Duplicate form control name: '${c}'. Consider to predefine one ONLY!!!.`,\r\n              noneAutoClosedAlertOptions\r\n            );\r\n          }\r\n        }\r\n        return c;\r\n      });\r\n      /* END: Check if each field is unique */\r\n    }\r\n\r\n    this.subscriptions.push(\r\n      this.multiLanguageService.lang$.subscribe((x) => (this.lang = x))\r\n    );\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.onFormRefCreated.emit(this.formRef);\r\n  }\r\n\r\n  onFormSubmit() {\r\n    this.checkError$.next(true);\r\n    if (!!this.form.valid) {\r\n      this.payLoad = JSON.stringify(this.form?.getRawValue(), null, 2);\r\n      this.onSubmit.emit(this.form?.getRawValue());\r\n    }\r\n  }\r\n\r\n  onFormSave() {\r\n    this.checkError$.next(true);\r\n    if (!!this.form.valid) {\r\n      this.payLoad = JSON.stringify(this.form?.getRawValue(), null, 2);\r\n      this.onSave.emit(this.form?.getRawValue());\r\n    }\r\n    setTimeout(() => this.checkError$.next(false), 3000);\r\n  }\r\n\r\n  onCancelLocal() {\r\n    this.onCancal.emit(null);\r\n  }\r\n\r\n  updatePayload(): void {\r\n    this.payLoad = JSON.stringify(this.form?.getRawValue(), null, 2);\r\n  }\r\n\r\n  updateValidorOverview(): void {\r\n    const result: { key: string; errors: any[] }[] = [];\r\n    Object.keys(this.form.controls).forEach((key) => {\r\n      const control: AbstractControl = this.form.get(key)!;\r\n      const errors: any[] = [];\r\n      if (!!control.invalid) {\r\n        Object.keys(control.errors!).forEach((key) => {\r\n          errors.push(key);\r\n        });\r\n      }\r\n      result.push({\r\n        key,\r\n        errors,\r\n      });\r\n    });\r\n    this.validatorOverview = JSON.stringify(result, null, 2);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.map((x) => x?.unsubscribe());\r\n  }\r\n\r\n  onButtonClick(e: ICoreButtonVNS): void {\r\n\r\n    switch (e.code) {\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_CANCEL:\r\n      case EnumCoreButtonVNSCode.CANCEL:\r\n        this.onCancelLocal();\r\n        break;\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_SAVE:\r\n      case EnumCoreButtonVNSCode.SEND:\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_DELETE:\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_LIQUIDATE_CONTRACT:\r\n      case EnumCoreButtonVNSCode.ONFORMDELETE:\r\n      case EnumCoreButtonVNSCode.SAVE_PASSWORD:\r\n        this.onFormSubmit();\r\n        break;\r\n      case EnumCoreButtonVNSCode.SAVE:\r\n        this.onFormSave();\r\n        break;\r\n      default:\r\n        break;\r\n    }\r\n    this.buttonClick.emit(e);\r\n  }\r\n}\r\n","@if (!!form) {\r\n<div class=\"core-form-container\">\r\n\r\n    <form #formRef (ngSubmit)=\"onFormSubmit()\" [formGroup]=\"form\" autocomplete=\"off\">\r\n\r\n        <div class=\"row\">\r\n\r\n            @if (!!leftInputSections) {\r\n            <div [class]=\"'col-md-' + (leftInputSectionsFlexSize || 0)\">\r\n\r\n                @for (section of leftInputSections; track $index) {\r\n                <div class=\"section\"\r\n                    [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!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 $index) {\r\n                    <div class=\"row mb15\">\r\n                        @for (col of row; track $index) {\r\n                        <div [class]=\"'col-md-' + col.flexSize\" [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                        }\r\n                    </div>\r\n                    }\r\n\r\n                </div>\r\n\r\n                }\r\n\r\n            </div>\r\n            }\r\n\r\n            <div [class]=\"'col-md-' + (12 - (leftInputSectionsFlexSize || 0))\">\r\n\r\n                @for (section of sections; track $index) {\r\n                <div class=\"section\"\r\n                    [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!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 $index) {\r\n                    <div class=\"row mb15\">\r\n                        @for (col of row; track $index) {\r\n                        <div [class]=\"'col-md-' + col.flexSize\" [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                        }\r\n                    </div>\r\n                    }\r\n\r\n                </div>\r\n                }\r\n\r\n            </div>\r\n\r\n        </div>\r\n\r\n\r\n        @if (!!bottomTemplateRef) {\r\n        <ng-container *ngTemplateOutlet=\"bottomTemplateRef\"></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\"\r\n                (buttonClick)=\"onButtonClick($event)\" [shownItems]=\"buttonItems\"\r\n                class=\"buttonGroupCustom\"></core-button-group-vns>\r\n        </div>\r\n        @if (isDevMode) {\r\n        <div class=\"form-row d-flex d-flex-center\">\r\n            <div class=\"dev-button\" (click)=\"updatePayload()\">Show\r\n                values</div>\r\n            <div class=\"dev-button\" (click)=\"updateValidorOverview()\">Show\r\n                validators</div>\r\n        </div>\r\n        }\r\n\r\n    </form>\r\n\r\n    @if (!!payLoad && isDevMode) {\r\n    <div class=\"form-row payload-preview\">\r\n        <strong>Current values</strong><br>{{payLoad}}\r\n    </div>\r\n    }\r\n\r\n    @if (!!validatorOverview && isDevMode) {\r\n    <div class=\"form-row payload-preview\">\r\n        <strong>Current errors</strong><br>{{validatorOverview}}\r\n    </div>\r\n    }\r\n\r\n</div>\r\n}"]}
|