ngx-histaff-alpha 0.7.2 → 0.7.3
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.
|
@@ -42,7 +42,7 @@ export class CoreControlComponent extends BaseComponent {
|
|
|
42
42
|
}
|
|
43
43
|
}
|
|
44
44
|
checkError() {
|
|
45
|
-
if (this.rawControl
|
|
45
|
+
if (!!this.rawControl?.errors) {
|
|
46
46
|
const newErrors = [];
|
|
47
47
|
Object.keys(this.form.controls[this.control.field].errors).forEach(key => {
|
|
48
48
|
/*
|
|
@@ -147,4 +147,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
147
147
|
}], rangeLimit: [{
|
|
148
148
|
type: Input
|
|
149
149
|
}] } });
|
|
150
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-control.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-control/core-control/core-control.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-control/core-control/core-control.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, OnDestroy, isDevMode } from '@angular/core';\r\nimport { AbstractControl, FormGroup, ReactiveFormsModule } from '@angular/forms';\r\nimport { BehaviorSubject } from 'rxjs';\r\n\r\nimport { IFormBaseControl } from '../../core-form/core-form/enum-interfaces';\r\nimport { BaseComponent } from '../../base-component/base/base.component';\r\nimport { AlertService } from '../../alert/alert.service';\r\nimport { EnumCoreOrgTreeaAccessorMode } from '../../core-org-tree/core-org-tree/core-org-tree.component';\r\nimport { CoreDatePickerComponent, ICoreDatePickerRange } from '../../core-date-picker/core-date-picker/core-date-picker.component';\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { noneAutoClosedAlertOptions } from '../../../constants/alertOptions';\r\nimport { IError } from './IError';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CoreChecklistComponent } from '../../core-checklist/core-checklist/core-checklist.component';\r\nimport { CoreFormControlSeekerComponent } from '../../core-form-control-seeker/core-form-control-seeker/core-form-control-seeker.component';\r\nimport { CoreCheckboxComponent } from '../../core-checkbox/core-checkbox/core-checkbox.component';\r\nimport { CoreOrgTreeComponent } from '../../core-org-tree/core-org-tree/core-org-tree.component';\r\nimport { CoreGridBufferComponent } from '../../core-grid-buffer/core-grid-buffer/core-grid-buffer.component';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\nimport { CoreMccComponent } from '../../core-mcc/core-mcc/core-mcc.component';\r\nimport { CoreMonthSelectorComponent } from '../../core-month-selector/core-month-selector/core-month-selector.component';\r\nimport { CoreDropdownComponent } from '../../core-dropdown/core-dropdown/core-dropdown.component';\r\nimport { CoreListComponent } from '../../core-list/core-list/core-list.component';\r\nimport { CoreFileUploaderComponent } from '../../core-file-uploader/core-file-uploader/core-file-uploader.component';\r\nimport { CoreAttachmentComponent } from '../../core-attachment/core-attachment/core-attachment.component';\r\nimport { CoreRadioGroupComponent } from '../../core-radio-group/core-radio-group/core-radio-group.component';\r\nimport { TooltipDirective } from '../../tooltip/tooltip.directive';\r\nimport { CoreCurrencyInputComponent } from '../../core-currency-input/core-currency-input/core-currency-input.component';\r\nimport { TableCellPipe } from '../../pipes/table-cell.pipe';\r\n\r\n\r\n@Component({\r\n  selector: 'core-control',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    ReactiveFormsModule,\r\n    TranslatePipe,\r\n    TableCellPipe,\r\n    CoreDropdownComponent,\r\n    CoreListComponent,\r\n    CoreChecklistComponent,\r\n    CoreFormControlSeekerComponent,\r\n    CoreCheckboxComponent,\r\n    CoreFileUploaderComponent,\r\n    CoreAttachmentComponent,\r\n    CoreGridBufferComponent,\r\n    CoreDatePickerComponent,\r\n    CoreOrgTreeComponent,\r\n    CoreRadioGroupComponent,\r\n    CoreMccComponent,\r\n    CoreMonthSelectorComponent,\r\n    TooltipDirective,\r\n    CoreCurrencyInputComponent,\r\n  ],\r\n  templateUrl: './core-control.component.html',\r\n  styleUrls: ['./core-control.component.scss']\r\n})\r\nexport class CoreControlComponent extends BaseComponent implements OnInit, OnDestroy {\r\n\r\n  @Input() control!: IFormBaseControl;\r\n  @Input() form!: FormGroup;\r\n  @Input() checkError$!: BehaviorSubject<boolean>;\r\n  @Input() rangeLimit!: ICoreDatePickerRange;\r\n\r\n  /* START: THIS IS NATIVE FORM CONTROL */\r\n  rawControl!: AbstractControl;\r\n  /* END: THIS IS NATIVE FORM CONTROL */\r\n\r\n  controlType!: string;\r\n  required!: boolean;\r\n  errors: IError[] = [];\r\n\r\n  coreOrgTreeDefaultAccessorMode = EnumCoreOrgTreeaAccessorMode.CHECKED;\r\n\r\n  constructor(public override mls: MultiLanguageService, public alertService: AlertService) {\r\n    super(mls);\r\n  }\r\n\r\n  private displayValidatorNameMathchingError(): void {\r\n    if (isDevMode()) {\r\n      this.alertService.error(`\r\n        '${this.control.field}' validator array definition error: validator name must equal Validators.&lt;key&gt;\r\n      `, noneAutoClosedAlertOptions)\r\n    }\r\n  }\r\n\r\n  private checkError(): void {\r\n\r\n    if (this.rawControl.errors) {\r\n\r\n      const newErrors: IError[] = [];\r\n      Object.keys(this.form.controls[this.control.field].errors!).forEach(key => {\r\n        /*  \r\n          tanleica:\r\n            By custom design, custom error is an array\r\n            while built-in validator should produce an object error if any\r\n        */\r\n        if (this.form.controls[this.control.field].errors![key] instanceof Array) {\r\n          newErrors.push({\r\n            key: key,\r\n            errorMessage: this.form.controls[this.control.field].errors![key][1]\r\n          })\r\n        } else {\r\n          if (!!this.control.validators) {\r\n            const filter = this.control.validators?.filter(x => x.name.toLowerCase() === key.toLowerCase())\r\n            if (!!filter.length) {\r\n              newErrors.push({\r\n                key: key,\r\n                errorMessage: filter![0].errorMessage!\r\n              })\r\n            } else {\r\n              this.displayValidatorNameMathchingError();\r\n            }\r\n          } else {\r\n            this.displayValidatorNameMathchingError();\r\n          }\r\n        }\r\n      })\r\n      this.errors = newErrors;\r\n    } else {\r\n      this.errors = [];\r\n    }\r\n\r\n  }\r\n\r\n  private resetError(): void {\r\n    this.errors = [];\r\n  }\r\n\r\n  override ngOnInit(): void {\r\n    this.subscriptions.push(this.mls.lang$.subscribe(x => this.lang = x));\r\n    this.controlType = this.control.controlType;\r\n    this.required = !!this.control.validators?.filter(x => x.validator.name === 'required').length\r\n\r\n    this.rawControl = this.form.get(this.control.field)!;\r\n\r\n    this.subscriptions.push(\r\n      this.rawControl?.statusChanges.subscribe(_ => {\r\n        this.checkError();\r\n      })\r\n    )\r\n\r\n    if (!!this.checkError$) {\r\n      this.subscriptions.push(\r\n        this.checkError$.subscribe(x => {\r\n          if (x) {\r\n            this.checkError();\r\n          } else {\r\n            this.resetError();\r\n          }\r\n        })\r\n      )\r\n    }\r\n\r\n  }\r\n\r\n  get isValid() { return this.form.controls[this.control.field].valid; }\r\n\r\n  onFocus(e: any) {\r\n    this.control.focus$?.next(e);\r\n  }\r\n\r\n  onBlur(e: any) {\r\n    this.control.blur$?.next(e);\r\n  }\r\n  oHandleClick(e: any) {\r\n    this.control.click$?.next(e);\r\n  }\r\n}\r\n","<div class=\"core-control-container\">\r\n    <div [formGroup]=\"form\" [class.hidden]=\"!!control.hidden\">\r\n\r\n        <!-- START: LABEL SESSION-->\r\n        <label [class]=\"'control-label' +  (required ? ' required' : '')\" [attr.for]=\"control.field\"\r\n            [class.avatar-label]=\"control.uploadFileType==='IMAGE_AVATAR'\" [appTooltip]=\"control.tooltip! | translate: lang\" [ngStyle]=\"{\r\n                display: 'inline-block'\r\n            }\">\r\n            {{(control.controlType!=='CHECKBOX' && control.controlType!=='BUTTON') ? (control.label | translate: lang) : ''}}\r\n        </label>\r\n        <i *ngIf=\"!!control.hint! && control.controlType !== 'CHECKBOX'\" class=\"feather-help-circle\" [appTooltip]=\"control.hint!\" [ngStyle]=\"{\r\n            display: 'inline-block',\r\n            marginLeft: '2px'\r\n        }\"></i>\r\n        <!-- START: LABEL SESSION-->\r\n\r\n        <!-- START: FORM-CONTROL SESSION-->\r\n\r\n        <ng-container *ngIf=\"control.controlType==='TEXTBOX'\">\r\n            <input *ngIf=\"control.type==='date'\" [formControlName]=\"control.field\" [type]=\"control.type\"\r\n                class=\"form-control\" [readonly]=\"control.readonly!\" useValueAsDate>\r\n\r\n            <input *ngIf=\"control.type==='number'\" [formControlName]=\"control.field\" [type]=\"control.type\"\r\n                class=\"form-control\" [readonly]=\"control.readonly\" [step]=\"control.step || '1'\">\r\n\r\n            <input *ngIf=\"control.type!=='date' && control.type!=='number'\" [formControlName]=\"control.field\"\r\n                [value]=\"form.get(control.field)?.value | tableCell: control.pipe : lang\" [type]=\"control.type\"\r\n                class=\"form-control\" [readonly]=\"control.readonly\"\r\n                [appTooltip]=\"form.get(control.field)?.value\"\r\n                (focus)=\"onFocus($event)\"\r\n                (blur)=\"onBlur($event)\"\r\n                >\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='CURRENCY'\">\r\n            <core-currency-input [formControlName]=\"control.field\"></core-currency-input>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='TEXTAREA'\">\r\n            <textarea [rows]=\"control.textareaRows?.toString() || '3'\" [ngStyle]=\"{ height: 'unset' }\"\r\n                [formControlName]=\"control.field\" class=\"form-control\" [readonly]=\"control.readonly\"></textarea>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='CHECKBOX'\">\r\n            <core-checkbox [formControlName]=\"control.field\" [text]=\"control.label\"\r\n                [inputValue]=\"control.value\"></core-checkbox>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='MCC'\">\r\n            <core-mcc [formControlName]=\"control.field\" [columns]=\"control.columns!\" [shownFrom]=\"control.shownFrom!\" \r\n            [apiDefinition]=\"control.apiDefinition!\" [getByIdApi]=\"control.getByIdApi!\" [selectedRow$]=\"control.selectedRow$!\"\r\n            [outerParam$]=\"control.outerParam$!\"\r\n            ></core-mcc>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='DATEPICKER'\">\r\n            <core-date-picker [formControlName]=\"control.field\" [rangeLimit]=\"control.rangeLimit!\"></core-date-picker>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='DROPDOWN' && !!control.dropdownOptions$\">\r\n            <core-dropdown [formControlName]=\"control.field\" [options$]=\"control.dropdownOptions$!\"\r\n                [getByIdObject$]=\"control.getByIdObject$!\" [shownFrom]=\"control.shownFrom!\"></core-dropdown>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='LIST'\">\r\n            <core-list [formControlName]=\"control.field\" [options]=\"control.listOptions!\"></core-list>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='CHECKLIST' && !!control.checklistOptions$\">\r\n            <core-checklist [formControlName]=\"control.field\" [options$]=\"control.checklistOptions$!\"\r\n                [getByIdObject$]=\"control.getByIdObject$!\" [shownFrom]=\"control.shownFrom!\"></core-checklist>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='SEEKER' && !!control.seekerSourceType\">\r\n            <core-form-control-seeker *ngIf=\"control.seekerSourceType==='EMPLOYEE_SEEK'\"\r\n                [multiMode]=\"control.multiMode!\" [objectList$]=\"control.objectList$!\" [formControlName]=\"control.field\"\r\n                [seekerSourceType]=\"control.seekerSourceType!\" [preDefinedOuterParam$]=\"control.preDefinedOuterParam$!\"\r\n                [boundFrom]=\"control.boundFrom!\" [shownFrom]=\"control.shownFrom!\" [alsoBindTo]=\"control.alsoBindTo!\"\r\n                [getByIdObject$]=\"control.getByIdObject$!\"\r\n                [click$]=\"control.click$\"\r\n                ></core-form-control-seeker>\r\n            <core-form-control-seeker *ngIf=\"control.seekerSourceType==='CONTRACT_SEEK'\"\r\n                [multiMode]=\"control.multiMode!\" [objectList$]=\"control.objectList$!\" [formControlName]=\"control.field\"\r\n                [seekerSourceType]=\"control.seekerSourceType!\" [boundFrom]=\"control.boundFrom!\"\r\n                [preDefinedOuterParam$]=\"control.preDefinedOuterParam$!\" [shownFrom]=\"control.shownFrom!\"\r\n                [alsoBindTo]=\"control.alsoBindTo!\"\r\n                [getByIdObject$]=\"control.getByIdObject$!\"\r\n                [click$]=\"control.click$\"\r\n                ></core-form-control-seeker>\r\n            <core-form-control-seeker *ngIf=\"control.seekerSourceType==='WORKING_SEEK'\" [multiMode]=\"control.multiMode!\"\r\n                [objectList$]=\"control.objectList$!\" [formControlName]=\"control.field\"\r\n                [seekerSourceType]=\"control.seekerSourceType!\" [preDefinedOuterParam$]=\"control.preDefinedOuterParam$!\"\r\n                [boundFrom]=\"control.boundFrom!\" [shownFrom]=\"control.shownFrom!\" [alsoBindTo]=\"control.alsoBindTo!\"\r\n                [getByIdObject$]=\"control.getByIdObject$!\"\r\n                [click$]=\"control.click$\"\r\n                ></core-form-control-seeker>\r\n            <core-form-control-seeker *ngIf=\"control.seekerSourceType==='WAGE_SEEK'\" [formControlName]=\"control.field\"\r\n                [multiMode]=\"control.multiMode!\" [objectList$]=\"control.objectList$!\"\r\n                [seekerSourceType]=\"control.seekerSourceType!\" [preDefinedOuterParam$]=\"control.preDefinedOuterParam$!\"\r\n                [boundFrom]=\"control.boundFrom!\" [shownFrom]=\"control.shownFrom!\" [alsoBindTo]=\"control.alsoBindTo!\"\r\n                [getByIdObject$]=\"control.getByIdObject$!\"\r\n                [click$]=\"control.click$\"\r\n                ></core-form-control-seeker>\r\n            <core-form-control-seeker *ngIf=\"control.seekerSourceType==='POSITION_SEEK'\" [objectList$]=\"control.objectList$!\"\r\n                [multiMode]=\"control.multiMode!\" [formControlName]=\"control.field\" [alsoBindTo]=\"control.alsoBindTo!\"\r\n                [seekerSourceType]=\"control.seekerSourceType!\" [preDefinedOuterParam$]=\"control.preDefinedOuterParam$!\"\r\n                [boundFrom]=\"control.boundFrom!\" [shownFrom]=\"control.shownFrom!\"\r\n                [getByIdObject$]=\"control.getByIdObject$!\"\r\n                [seekerVerifyIgnore]=\"control.seekerVerifyIgnore!\"\r\n                [click$]=\"control.click$\"\r\n                ></core-form-control-seeker>\r\n            <core-form-control-seeker *ngIf=\"control.seekerSourceType==='POSITION_CONCURRENT_SEEK'\"\r\n                [multiMode]=\"control.multiMode!\" [formControlName]=\"control.field\" [alsoBindTo]=\"control.alsoBindTo!\"\r\n                [seekerSourceType]=\"control.seekerSourceType!\" [preDefinedOuterParam$]=\"control.preDefinedOuterParam$!\"\r\n                [boundFrom]=\"control.boundFrom!\" [shownFrom]=\"control.shownFrom!\"\r\n                [getByIdObject$]=\"control.getByIdObject$!\"\r\n                [click$]=\"control.click$\"\r\n                ></core-form-control-seeker>\r\n\r\n            <core-form-control-seeker *ngIf=\"control.seekerSourceType==='ORGANIZATION_UNIT_SEEK'\"\r\n                [formControlName]=\"control.field\" [seekerSourceType]=\"control.seekerSourceType!\"\r\n                [boundFrom]=\"control.boundFrom!\" [alsoBindTo]=\"control.alsoBindTo!\" [shownFrom]=\"control.shownFrom!\"\r\n                [getByIdObject$]=\"control.getByIdObject$!\"\r\n                [click$]=\"control.click$\"\r\n                ></core-form-control-seeker>\r\n\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='FILEUPLOADER' && !!control.uploadFileType\">\r\n            <core-file-uploader [formControlName]=\"control.field\" [uploadFileType]=\"control.uploadFileType\"\r\n                [fileDataControlName]=\"control.fileDataControlName!\"\r\n                [fileNameControlName]=\"control.fileNameControlName!\"\r\n                [fileTypeControlName]=\"control.fileTypeControlName!\"\r\n                [verticalMode]=\"control.verticalMode!\"></core-file-uploader>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='ATTACHMENT'\">\r\n            <core-attachment [formControlName]=\"control.field\" [assignTo]=\"control.assignTo!\"\r\n                [valueToShow]=\"control.valueToShow!\"></core-attachment>\r\n        </ng-container>\r\n\r\n        <ng-container\r\n            *ngIf=\"control.controlType==='GRIDBUFFER' && !!control.gridBufferFormSections && !!control.gridBufferTableColumns\">\r\n            <core-grid-buffer [formControlName]=\"control.field\" [formSections]=\"control.gridBufferFormSections\"\r\n                [gridColumns]=\"control.gridBufferTableColumns\"\r\n                (onBufferFormCreated)=\"!!control.onBufferFormCreated ? control.onBufferFormCreated($event) : null\"></core-grid-buffer>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='ORGTREECHECK'\">\r\n            <core-org-tree [formControlName]=\"control.field\"\r\n                [accessorMode]=\"coreOrgTreeDefaultAccessorMode\"></core-org-tree>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='RADIOGROUP'\">\r\n            <core-radio-group [formControlName]=\"control.field\"\r\n                [options$]=\"control.radioGroupOptions$!\"\r\n                [vertical]=\"control.verticalMode!\"\r\n                ></core-radio-group>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='MONTHSELECTOR'\">\r\n            <core-month-selector [formControlName]=\"control.field\"\r\n                ></core-month-selector>\r\n        </ng-container>\r\n\r\n\r\n        <ng-container *ngIf=\"control.controlType==='BUTTON'\">\r\n            <button type=\"button\" class=\"btn btn-secondary text\" (click)=\"oHandleClick($event)\">{{control.label| translate: lang}}</button>\r\n        </ng-container>\r\n        <!-- END: FORM-CONTROL SESSION-->\r\n\r\n        <!-- START: ERROR SESSION-->\r\n        <div *ngIf=\"!!errors!.length\">\r\n            <div class=\"form-control-error\" *ngFor=\"let error of errors\">\r\n                {{ error.errorMessage | translate: lang }}\r\n            </div>\r\n        </div>\r\n        <div *ngIf=\"!!!errors!.length && !!checkError$.value\">\r\n            <div>\r\n                {{ '&nbsp;' }}\r\n            </div>\r\n        </div>\r\n        <!-- END: ERROR SESSION-->\r\n\r\n    </div>\r\n</div>"]}
|
|
150
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-control.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-control/core-control/core-control.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-control/core-control/core-control.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, OnDestroy, isDevMode } from '@angular/core';\r\nimport { AbstractControl, FormGroup, ReactiveFormsModule } from '@angular/forms';\r\nimport { BehaviorSubject } from 'rxjs';\r\n\r\nimport { IFormBaseControl } from '../../core-form/core-form/enum-interfaces';\r\nimport { BaseComponent } from '../../base-component/base/base.component';\r\nimport { AlertService } from '../../alert/alert.service';\r\nimport { EnumCoreOrgTreeaAccessorMode } from '../../core-org-tree/core-org-tree/core-org-tree.component';\r\nimport { CoreDatePickerComponent, ICoreDatePickerRange } from '../../core-date-picker/core-date-picker/core-date-picker.component';\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { noneAutoClosedAlertOptions } from '../../../constants/alertOptions';\r\nimport { IError } from './IError';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CoreChecklistComponent } from '../../core-checklist/core-checklist/core-checklist.component';\r\nimport { CoreFormControlSeekerComponent } from '../../core-form-control-seeker/core-form-control-seeker/core-form-control-seeker.component';\r\nimport { CoreCheckboxComponent } from '../../core-checkbox/core-checkbox/core-checkbox.component';\r\nimport { CoreOrgTreeComponent } from '../../core-org-tree/core-org-tree/core-org-tree.component';\r\nimport { CoreGridBufferComponent } from '../../core-grid-buffer/core-grid-buffer/core-grid-buffer.component';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\nimport { CoreMccComponent } from '../../core-mcc/core-mcc/core-mcc.component';\r\nimport { CoreMonthSelectorComponent } from '../../core-month-selector/core-month-selector/core-month-selector.component';\r\nimport { CoreDropdownComponent } from '../../core-dropdown/core-dropdown/core-dropdown.component';\r\nimport { CoreListComponent } from '../../core-list/core-list/core-list.component';\r\nimport { CoreFileUploaderComponent } from '../../core-file-uploader/core-file-uploader/core-file-uploader.component';\r\nimport { CoreAttachmentComponent } from '../../core-attachment/core-attachment/core-attachment.component';\r\nimport { CoreRadioGroupComponent } from '../../core-radio-group/core-radio-group/core-radio-group.component';\r\nimport { TooltipDirective } from '../../tooltip/tooltip.directive';\r\nimport { CoreCurrencyInputComponent } from '../../core-currency-input/core-currency-input/core-currency-input.component';\r\nimport { TableCellPipe } from '../../pipes/table-cell.pipe';\r\n\r\n\r\n@Component({\r\n  selector: 'core-control',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    ReactiveFormsModule,\r\n    TranslatePipe,\r\n    TableCellPipe,\r\n    CoreDropdownComponent,\r\n    CoreListComponent,\r\n    CoreChecklistComponent,\r\n    CoreFormControlSeekerComponent,\r\n    CoreCheckboxComponent,\r\n    CoreFileUploaderComponent,\r\n    CoreAttachmentComponent,\r\n    CoreGridBufferComponent,\r\n    CoreDatePickerComponent,\r\n    CoreOrgTreeComponent,\r\n    CoreRadioGroupComponent,\r\n    CoreMccComponent,\r\n    CoreMonthSelectorComponent,\r\n    TooltipDirective,\r\n    CoreCurrencyInputComponent,\r\n  ],\r\n  templateUrl: './core-control.component.html',\r\n  styleUrls: ['./core-control.component.scss']\r\n})\r\nexport class CoreControlComponent extends BaseComponent implements OnInit, OnDestroy {\r\n\r\n  @Input() control!: IFormBaseControl;\r\n  @Input() form!: FormGroup;\r\n  @Input() checkError$!: BehaviorSubject<boolean>;\r\n  @Input() rangeLimit!: ICoreDatePickerRange;\r\n\r\n  /* START: THIS IS NATIVE FORM CONTROL */\r\n  rawControl!: AbstractControl;\r\n  /* END: THIS IS NATIVE FORM CONTROL */\r\n\r\n  controlType!: string;\r\n  required!: boolean;\r\n  errors: IError[] = [];\r\n\r\n  coreOrgTreeDefaultAccessorMode = EnumCoreOrgTreeaAccessorMode.CHECKED;\r\n\r\n  constructor(public override mls: MultiLanguageService, public alertService: AlertService) {\r\n    super(mls);\r\n  }\r\n\r\n  private displayValidatorNameMathchingError(): void {\r\n    if (isDevMode()) {\r\n      this.alertService.error(`\r\n        '${this.control.field}' validator array definition error: validator name must equal Validators.&lt;key&gt;\r\n      `, noneAutoClosedAlertOptions)\r\n    }\r\n  }\r\n\r\n  private checkError(): void {\r\n\r\n    if (!!this.rawControl?.errors) {\r\n\r\n      const newErrors: IError[] = [];\r\n      Object.keys(this.form.controls[this.control.field].errors!).forEach(key => {\r\n        /*  \r\n          tanleica:\r\n            By custom design, custom error is an array\r\n            while built-in validator should produce an object error if any\r\n        */\r\n        if (this.form.controls[this.control.field].errors![key] instanceof Array) {\r\n          newErrors.push({\r\n            key: key,\r\n            errorMessage: this.form.controls[this.control.field].errors![key][1]\r\n          })\r\n        } else {\r\n          if (!!this.control.validators) {\r\n            const filter = this.control.validators?.filter(x => x.name.toLowerCase() === key.toLowerCase())\r\n            if (!!filter.length) {\r\n              newErrors.push({\r\n                key: key,\r\n                errorMessage: filter![0].errorMessage!\r\n              })\r\n            } else {\r\n              this.displayValidatorNameMathchingError();\r\n            }\r\n          } else {\r\n            this.displayValidatorNameMathchingError();\r\n          }\r\n        }\r\n      })\r\n      this.errors = newErrors;\r\n    } else {\r\n      this.errors = [];\r\n    }\r\n\r\n  }\r\n\r\n  private resetError(): void {\r\n    this.errors = [];\r\n  }\r\n\r\n  override ngOnInit(): void {\r\n    this.subscriptions.push(this.mls.lang$.subscribe(x => this.lang = x));\r\n    this.controlType = this.control.controlType;\r\n    this.required = !!this.control.validators?.filter(x => x.validator.name === 'required').length\r\n\r\n    this.rawControl = this.form.get(this.control.field)!;\r\n\r\n    this.subscriptions.push(\r\n      this.rawControl?.statusChanges.subscribe(_ => {\r\n        this.checkError();\r\n      })\r\n    )\r\n\r\n    if (!!this.checkError$) {\r\n      this.subscriptions.push(\r\n        this.checkError$.subscribe(x => {\r\n          if (x) {\r\n            this.checkError();\r\n          } else {\r\n            this.resetError();\r\n          }\r\n        })\r\n      )\r\n    }\r\n\r\n  }\r\n\r\n  get isValid() { return this.form.controls[this.control.field].valid; }\r\n\r\n  onFocus(e: any) {\r\n    this.control.focus$?.next(e);\r\n  }\r\n\r\n  onBlur(e: any) {\r\n    this.control.blur$?.next(e);\r\n  }\r\n  oHandleClick(e: any) {\r\n    this.control.click$?.next(e);\r\n  }\r\n}\r\n","<div class=\"core-control-container\">\r\n    <div [formGroup]=\"form\" [class.hidden]=\"!!control.hidden\">\r\n\r\n        <!-- START: LABEL SESSION-->\r\n        <label [class]=\"'control-label' +  (required ? ' required' : '')\" [attr.for]=\"control.field\"\r\n            [class.avatar-label]=\"control.uploadFileType==='IMAGE_AVATAR'\" [appTooltip]=\"control.tooltip! | translate: lang\" [ngStyle]=\"{\r\n                display: 'inline-block'\r\n            }\">\r\n            {{(control.controlType!=='CHECKBOX' && control.controlType!=='BUTTON') ? (control.label | translate: lang) : ''}}\r\n        </label>\r\n        <i *ngIf=\"!!control.hint! && control.controlType !== 'CHECKBOX'\" class=\"feather-help-circle\" [appTooltip]=\"control.hint!\" [ngStyle]=\"{\r\n            display: 'inline-block',\r\n            marginLeft: '2px'\r\n        }\"></i>\r\n        <!-- START: LABEL SESSION-->\r\n\r\n        <!-- START: FORM-CONTROL SESSION-->\r\n\r\n        <ng-container *ngIf=\"control.controlType==='TEXTBOX'\">\r\n            <input *ngIf=\"control.type==='date'\" [formControlName]=\"control.field\" [type]=\"control.type\"\r\n                class=\"form-control\" [readonly]=\"control.readonly!\" useValueAsDate>\r\n\r\n            <input *ngIf=\"control.type==='number'\" [formControlName]=\"control.field\" [type]=\"control.type\"\r\n                class=\"form-control\" [readonly]=\"control.readonly\" [step]=\"control.step || '1'\">\r\n\r\n            <input *ngIf=\"control.type!=='date' && control.type!=='number'\" [formControlName]=\"control.field\"\r\n                [value]=\"form.get(control.field)?.value | tableCell: control.pipe : lang\" [type]=\"control.type\"\r\n                class=\"form-control\" [readonly]=\"control.readonly\"\r\n                [appTooltip]=\"form.get(control.field)?.value\"\r\n                (focus)=\"onFocus($event)\"\r\n                (blur)=\"onBlur($event)\"\r\n                >\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='CURRENCY'\">\r\n            <core-currency-input [formControlName]=\"control.field\"></core-currency-input>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='TEXTAREA'\">\r\n            <textarea [rows]=\"control.textareaRows?.toString() || '3'\" [ngStyle]=\"{ height: 'unset' }\"\r\n                [formControlName]=\"control.field\" class=\"form-control\" [readonly]=\"control.readonly\"></textarea>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='CHECKBOX'\">\r\n            <core-checkbox [formControlName]=\"control.field\" [text]=\"control.label\"\r\n                [inputValue]=\"control.value\"></core-checkbox>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='MCC'\">\r\n            <core-mcc [formControlName]=\"control.field\" [columns]=\"control.columns!\" [shownFrom]=\"control.shownFrom!\" \r\n            [apiDefinition]=\"control.apiDefinition!\" [getByIdApi]=\"control.getByIdApi!\" [selectedRow$]=\"control.selectedRow$!\"\r\n            [outerParam$]=\"control.outerParam$!\"\r\n            ></core-mcc>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='DATEPICKER'\">\r\n            <core-date-picker [formControlName]=\"control.field\" [rangeLimit]=\"control.rangeLimit!\"></core-date-picker>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='DROPDOWN' && !!control.dropdownOptions$\">\r\n            <core-dropdown [formControlName]=\"control.field\" [options$]=\"control.dropdownOptions$!\"\r\n                [getByIdObject$]=\"control.getByIdObject$!\" [shownFrom]=\"control.shownFrom!\"></core-dropdown>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='LIST'\">\r\n            <core-list [formControlName]=\"control.field\" [options]=\"control.listOptions!\"></core-list>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='CHECKLIST' && !!control.checklistOptions$\">\r\n            <core-checklist [formControlName]=\"control.field\" [options$]=\"control.checklistOptions$!\"\r\n                [getByIdObject$]=\"control.getByIdObject$!\" [shownFrom]=\"control.shownFrom!\"></core-checklist>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='SEEKER' && !!control.seekerSourceType\">\r\n            <core-form-control-seeker *ngIf=\"control.seekerSourceType==='EMPLOYEE_SEEK'\"\r\n                [multiMode]=\"control.multiMode!\" [objectList$]=\"control.objectList$!\" [formControlName]=\"control.field\"\r\n                [seekerSourceType]=\"control.seekerSourceType!\" [preDefinedOuterParam$]=\"control.preDefinedOuterParam$!\"\r\n                [boundFrom]=\"control.boundFrom!\" [shownFrom]=\"control.shownFrom!\" [alsoBindTo]=\"control.alsoBindTo!\"\r\n                [getByIdObject$]=\"control.getByIdObject$!\"\r\n                [click$]=\"control.click$\"\r\n                ></core-form-control-seeker>\r\n            <core-form-control-seeker *ngIf=\"control.seekerSourceType==='CONTRACT_SEEK'\"\r\n                [multiMode]=\"control.multiMode!\" [objectList$]=\"control.objectList$!\" [formControlName]=\"control.field\"\r\n                [seekerSourceType]=\"control.seekerSourceType!\" [boundFrom]=\"control.boundFrom!\"\r\n                [preDefinedOuterParam$]=\"control.preDefinedOuterParam$!\" [shownFrom]=\"control.shownFrom!\"\r\n                [alsoBindTo]=\"control.alsoBindTo!\"\r\n                [getByIdObject$]=\"control.getByIdObject$!\"\r\n                [click$]=\"control.click$\"\r\n                ></core-form-control-seeker>\r\n            <core-form-control-seeker *ngIf=\"control.seekerSourceType==='WORKING_SEEK'\" [multiMode]=\"control.multiMode!\"\r\n                [objectList$]=\"control.objectList$!\" [formControlName]=\"control.field\"\r\n                [seekerSourceType]=\"control.seekerSourceType!\" [preDefinedOuterParam$]=\"control.preDefinedOuterParam$!\"\r\n                [boundFrom]=\"control.boundFrom!\" [shownFrom]=\"control.shownFrom!\" [alsoBindTo]=\"control.alsoBindTo!\"\r\n                [getByIdObject$]=\"control.getByIdObject$!\"\r\n                [click$]=\"control.click$\"\r\n                ></core-form-control-seeker>\r\n            <core-form-control-seeker *ngIf=\"control.seekerSourceType==='WAGE_SEEK'\" [formControlName]=\"control.field\"\r\n                [multiMode]=\"control.multiMode!\" [objectList$]=\"control.objectList$!\"\r\n                [seekerSourceType]=\"control.seekerSourceType!\" [preDefinedOuterParam$]=\"control.preDefinedOuterParam$!\"\r\n                [boundFrom]=\"control.boundFrom!\" [shownFrom]=\"control.shownFrom!\" [alsoBindTo]=\"control.alsoBindTo!\"\r\n                [getByIdObject$]=\"control.getByIdObject$!\"\r\n                [click$]=\"control.click$\"\r\n                ></core-form-control-seeker>\r\n            <core-form-control-seeker *ngIf=\"control.seekerSourceType==='POSITION_SEEK'\" [objectList$]=\"control.objectList$!\"\r\n                [multiMode]=\"control.multiMode!\" [formControlName]=\"control.field\" [alsoBindTo]=\"control.alsoBindTo!\"\r\n                [seekerSourceType]=\"control.seekerSourceType!\" [preDefinedOuterParam$]=\"control.preDefinedOuterParam$!\"\r\n                [boundFrom]=\"control.boundFrom!\" [shownFrom]=\"control.shownFrom!\"\r\n                [getByIdObject$]=\"control.getByIdObject$!\"\r\n                [seekerVerifyIgnore]=\"control.seekerVerifyIgnore!\"\r\n                [click$]=\"control.click$\"\r\n                ></core-form-control-seeker>\r\n            <core-form-control-seeker *ngIf=\"control.seekerSourceType==='POSITION_CONCURRENT_SEEK'\"\r\n                [multiMode]=\"control.multiMode!\" [formControlName]=\"control.field\" [alsoBindTo]=\"control.alsoBindTo!\"\r\n                [seekerSourceType]=\"control.seekerSourceType!\" [preDefinedOuterParam$]=\"control.preDefinedOuterParam$!\"\r\n                [boundFrom]=\"control.boundFrom!\" [shownFrom]=\"control.shownFrom!\"\r\n                [getByIdObject$]=\"control.getByIdObject$!\"\r\n                [click$]=\"control.click$\"\r\n                ></core-form-control-seeker>\r\n\r\n            <core-form-control-seeker *ngIf=\"control.seekerSourceType==='ORGANIZATION_UNIT_SEEK'\"\r\n                [formControlName]=\"control.field\" [seekerSourceType]=\"control.seekerSourceType!\"\r\n                [boundFrom]=\"control.boundFrom!\" [alsoBindTo]=\"control.alsoBindTo!\" [shownFrom]=\"control.shownFrom!\"\r\n                [getByIdObject$]=\"control.getByIdObject$!\"\r\n                [click$]=\"control.click$\"\r\n                ></core-form-control-seeker>\r\n\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='FILEUPLOADER' && !!control.uploadFileType\">\r\n            <core-file-uploader [formControlName]=\"control.field\" [uploadFileType]=\"control.uploadFileType\"\r\n                [fileDataControlName]=\"control.fileDataControlName!\"\r\n                [fileNameControlName]=\"control.fileNameControlName!\"\r\n                [fileTypeControlName]=\"control.fileTypeControlName!\"\r\n                [verticalMode]=\"control.verticalMode!\"></core-file-uploader>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='ATTACHMENT'\">\r\n            <core-attachment [formControlName]=\"control.field\" [assignTo]=\"control.assignTo!\"\r\n                [valueToShow]=\"control.valueToShow!\"></core-attachment>\r\n        </ng-container>\r\n\r\n        <ng-container\r\n            *ngIf=\"control.controlType==='GRIDBUFFER' && !!control.gridBufferFormSections && !!control.gridBufferTableColumns\">\r\n            <core-grid-buffer [formControlName]=\"control.field\" [formSections]=\"control.gridBufferFormSections\"\r\n                [gridColumns]=\"control.gridBufferTableColumns\"\r\n                (onBufferFormCreated)=\"!!control.onBufferFormCreated ? control.onBufferFormCreated($event) : null\"></core-grid-buffer>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='ORGTREECHECK'\">\r\n            <core-org-tree [formControlName]=\"control.field\"\r\n                [accessorMode]=\"coreOrgTreeDefaultAccessorMode\"></core-org-tree>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='RADIOGROUP'\">\r\n            <core-radio-group [formControlName]=\"control.field\"\r\n                [options$]=\"control.radioGroupOptions$!\"\r\n                [vertical]=\"control.verticalMode!\"\r\n                ></core-radio-group>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"control.controlType==='MONTHSELECTOR'\">\r\n            <core-month-selector [formControlName]=\"control.field\"\r\n                ></core-month-selector>\r\n        </ng-container>\r\n\r\n\r\n        <ng-container *ngIf=\"control.controlType==='BUTTON'\">\r\n            <button type=\"button\" class=\"btn btn-secondary text\" (click)=\"oHandleClick($event)\">{{control.label| translate: lang}}</button>\r\n        </ng-container>\r\n        <!-- END: FORM-CONTROL SESSION-->\r\n\r\n        <!-- START: ERROR SESSION-->\r\n        <div *ngIf=\"!!errors!.length\">\r\n            <div class=\"form-control-error\" *ngFor=\"let error of errors\">\r\n                {{ error.errorMessage | translate: lang }}\r\n            </div>\r\n        </div>\r\n        <div *ngIf=\"!!!errors!.length && !!checkError$.value\">\r\n            <div>\r\n                {{ '&nbsp;' }}\r\n            </div>\r\n        </div>\r\n        <!-- END: ERROR SESSION-->\r\n\r\n    </div>\r\n</div>"]}
|
|
@@ -13474,7 +13474,7 @@ class CoreControlComponent extends BaseComponent {
|
|
|
13474
13474
|
}
|
|
13475
13475
|
}
|
|
13476
13476
|
checkError() {
|
|
13477
|
-
if (this.rawControl
|
|
13477
|
+
if (!!this.rawControl?.errors) {
|
|
13478
13478
|
const newErrors = [];
|
|
13479
13479
|
Object.keys(this.form.controls[this.control.field].errors).forEach(key => {
|
|
13480
13480
|
/*
|