ets-fe-ng-sdk 17.0.63 → 17.0.64

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,4 +1,4 @@
1
- import { Component, EventEmitter, Input, Output, ViewChild, booleanAttribute, } from '@angular/core';
1
+ import { Component, EventEmitter, Input, Output, ViewChild, booleanAttribute } from '@angular/core';
2
2
  import { Validators } from '@angular/forms';
3
3
  import { ReplaySubject } from 'rxjs';
4
4
  import { InputProviders, InputSharedModules } from './input-shared.module';
@@ -116,10 +116,7 @@ export class InputBasicComponent extends InputBase {
116
116
  }
117
117
  if (this.min == 0 && this.max == 100)
118
118
  this.oType = 'percentage';
119
- if ((this.type == 'viewer' ||
120
- this.showValidation ||
121
- this.showValidationIcon ||
122
- this.label?.includes('code')) &&
119
+ if ((this.type == 'viewer' || this.showValidation || this.showValidationIcon || this.label?.includes('code')) &&
123
120
  (this.noFormat == null || this.noFormat == undefined))
124
121
  this.noFormat = true;
125
122
  // if (this.type == 'select' || this.type == 'autocomplete')
@@ -166,9 +163,7 @@ export class InputBasicComponent extends InputBase {
166
163
  }
167
164
  }
168
165
  if (this.maxLength && this.control?.value?.toString().length > this.maxLength)
169
- this.control.setValue(this.type == 'number'
170
- ? +this.control?.value?.toString().slice(0, this.maxLength)
171
- : this.control?.value?.toString().slice(0, this.maxLength));
166
+ this.control.setValue(this.type == 'number' ? +this.control?.value?.toString().slice(0, this.maxLength) : this.control?.value?.toString().slice(0, this.maxLength));
172
167
  this.__value = this.control.value;
173
168
  this.mchange.emit(this.control.value);
174
169
  // debugger
@@ -358,4 +353,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.7", ngImpor
358
353
  type: ViewChild,
359
354
  args: ['matSelectTag']
360
355
  }] } });
361
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-basic.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/input/input-basic.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  ViewChild,\n  booleanAttribute,\n} from '@angular/core';\nimport { AbstractControl, Validators } from '@angular/forms';\nimport { Observable, ReplaySubject } from 'rxjs';\nimport { FCInput, InputType, IValidationMessage } from '../../models/index.model';\nimport { MatSelect } from '@angular/material/select';\nimport { MatOption } from '@angular/material/core';\nimport { InputProviders, InputSharedModules } from './input-shared.module';\nimport { DateInputComponent } from './date-input/date-input.component';\nimport { InputBase } from './input-base.component'; \nimport { IOption, InputService } from './input.service';\n\n@Component({\n  selector: 'app-input-basic,app-input',\n  templateUrl: './input.component.html',\n  styleUrls: ['./input.component.scss'],\n  standalone: true,\n  providers: InputProviders,\n  imports: [DateInputComponent, InputSharedModules],\n})\nexport class InputBasicComponent<\n    TFormGroup extends {\n      [K in keyof TFormGroup]: AbstractControl<any, any>;\n    } = any,\n    TControl = any,\n    TOption = any\n  >\n  extends InputBase<TFormGroup, TControl, TOption>\n  implements OnInit\n{\n  @Input() accept: string;\n  @Input() autocomplete: boolean = true;\n  @Input() autoPickValueField: boolean;\n  @Input() clearOnDisable: boolean = true;\n  @Input() cls: string;\n  @Input('input') inp: FCInput;\n  @Input() colored: boolean = true;\n  @Input() checked: boolean = false; //optional checked option for checkboxes\n  @Input() contextData: any;\n  @Input() debug: boolean;\n  @Input() decimalPoints: number;\n  @Input() endLabel: string;\n  @Input() endLabelTooltip: string;\n  @Input() files: File[];\n  @Input() noFormat: boolean;\n  @Input() hide: boolean;\n  @Input() hint: string | number;\n  @Input() id: string = 'id' + Math.round(Math.random() * 1000000);\n  @Input() inpCl: string = 'control-bg-gray';\n  @Input() label: string;\n  @Input() labelLink: string;\n  @Input() labelField: keyof TOption;\n  @Input() labelType: OptionLabelType; //use this to pick a preset value label group for the options\n  @Input() lblCl: string = '2';\n  @Input() light: boolean = true;\n  @Input() loading: boolean;\n  @Input() max: number | string;\n  @Input() set maxToday(v: boolean) {\n    if (v) this.max = new Date().toISOString();\n  }\n  @Input() set minToday(v: boolean) {\n    if (v) this.min = new Date().toISOString();\n  }\n  @Input() min: number | string;\n  @Input() minLength: number;\n  @Input() maxLength: number;\n  @Input() mini: boolean;\n  @Input() multiple: boolean;\n  @Input() optionFormatter: (item: TOption) => string;\n  @Input() optionsFunc: (...val: any) => Observable<any[]>;\n  @Input() placeholder: string;\n  @Input() prefix: string;\n  @Input({ transform: booleanAttribute }) readonly: boolean;\n  @Input({ transform: booleanAttribute }) required?: boolean;\n  @Input({ transform: booleanAttribute }) showEmptyOption?: boolean = true;\n  @Input({ transform: booleanAttribute }) showLabel: boolean;\n  @Input({ transform: booleanAttribute }) showValidation: boolean = false;\n  @Input({ transform: booleanAttribute }) showValidationMsg: boolean = false;\n  @Input({ transform: booleanAttribute }) showValidationIcon: boolean;\n  @Input({ transform: booleanAttribute }) small: boolean;\n  @Input({ transform: booleanAttribute }) stacked: boolean = true;\n  @Input() suffix: string;\n  @Input() theme: InputTheme = 1;\n  @Input() translateOptions: boolean = false;\n  @Input() valueField: keyof TOption; //use this to choose a field in the option for modeling\n  @Input() vms: IValidationMessage[];\n  @Input() xsmall: boolean;\n  @Output() mchange = new EventEmitter();\n  @Output() mSelectOptionChange = new EventEmitter<TOption>();\n  @Output() mSelectedOptionLabel = new EventEmitter<string>();\n  @Output() mContextChange = new EventEmitter();\n  disabled: boolean;\n  options: IOption[];\n  options$ = new ReplaySubject<IOption[]>();\n  rawOptions: any[];\n  showPassword: boolean;\n  type: InputType = 'text';\n  viewInited: boolean;\n  forcePatched: boolean;\n  selectionObject: TOption;\n  oType: InputType;\n  // labelValue: string;\n  @Input('setCurrentDate') set _setCurrentDate(v: boolean) {\n    if (v) this.control.patchValue(new Date().toISOString().split('T')[0]);\n  }\n  @Input('duplicateCheck') duplicateCheck: boolean;\n  @Input('disabled') set _disabled(v: boolean) {\n    if (this.debug) debugger;\n    this.disabled = v;\n    if (this.control?.parent?.disabled) return;\n    if (v) {\n      if (this.clearOnDisable) this.control?.reset();\n      this.control?.disable();\n    } else if (this.control?.disabled) {\n      this.control?.enable();\n    }\n  }InputType\n  @Input() customSelectChangeAction: (\n    val: string | number,\n    options: any[],\n    rawOptions: any[]\n  ) => any;\n  @Input('options') set _options(v: TOption[]) {\n    // debugger\n    // console.log('options', v);\n    if (this.debug) debugger;\n    this.rawOptions = v;\n    this.options = this.iS.optionsFormatter(\n      v,\n      this.valueField as string,\n      this.optionFormatter,\n      this.labelType,\n      this.labelField as string,\n      this.autoPickValueField\n    );\n    // debugger\n    this.options$.next(this.options);\n  }\n  @Input('type') set _type(v: InputType) {\n    this.oType = v;\n    if (v == 'percentage') {\n      this.type = 'number';\n      this.max = 100;\n      this.min = 0;\n    } else this.type = v;\n    // if (this.forcePatched) {\n    //   this.control.reset();\n    //   this.forcePatched = false;\n    // }\n    // if (v == 'checkbox' && (this.value == null || this.value == undefined)) {\n    //   this.control?.patchValue(false);\n    //   this.forcePatched = tInputType\n    // }\n  }\n  __value: string | number;\n  @Input('mvalue') set _value(v: string | number) {\n    this.__value = v;\n  }\n  @ViewChild('matSelectTag') matSelect: MatSelect;\n  constructor(public iS: InputService) {\n    super();\n  }\n\n  ngOnInit(): void {\n    if (this.showLabel == null) this.showLabel = !!this.label;\n    if (this.autoPickValueField) {\n      if (!this.labelType) this.labelType = 'cdt';\n      if (!this.valueField) this.valueField = 'code' as any;\n    }\n    if (this.min == 0 && this.max == 100) this.oType = 'percentage';\n    if (\n      (this.type == 'viewer' ||\n        this.showValidation ||\n        this.showValidationIcon ||\n        this.label?.includes('code')) &&\n      (this.noFormat == null || this.noFormat == undefined)\n    )\n      this.noFormat = true;\n\n    // if (this.type == 'select' || this.type == 'autocomplete')\n    //   this.control.valueChanges.subscribe((r) => {\n    //     this.labelValue = this.options.find((x) => x.value == r)?.label;\n    //   });\n    // console.log(this.id)\n    // if (this.disabled) this._disabled = this.disabled;\n  }\n  ngAfterViewInit(): void {\n    // this.viewInited = true;\n  }\n  disableControl(control: AbstractControl = this.control) {\n    if (!this.disabled) return;\n    control?.disable({ emitEvent: false });\n  }\n  get isRequired() {\n    return this.required || this.control?.hasValidator(Validators.required);\n  }\n  change(e: { target: { checked?: boolean; value: any } } | Event) {\n    // debugger;\n    let val;\n    if (this.type == 'checkbox') {\n      val = e.target?.['checked'];\n      this.control.setValue(e.target?.['checked']);\n    } else val = e.target?.['value'];\n    if (this.type == 'number') {\n      // debugger;\n      if (this.oType == 'percentage' && !this.max) {\n        this.max = 100;\n        this.min = 0;\n      }\n      if (val != null && val != '') {\n        // debugger;\n        if (this.max && +val > +this.max) this.control.setValue(this.max);\n        else if (this.min != null && this.min != undefined && +val < +this.min)\n          this.control.setValue(this.min);\n        if (this.decimalPoints != undefined && this.decimalPoints != null)\n          this.control.setValue(+(+val).toFixed(this.decimalPoints));\n      }\n    }\n    if (this.maxLength && this.control?.value?.toString().length > this.maxLength)\n      this.control.setValue(\n        this.type == 'number'\n          ? +this.control?.value?.toString().slice(0, this.maxLength)\n          : this.control?.value?.toString().slice(0, this.maxLength)\n      );\n    this.__value = this.control.value;\n    this.mchange.emit(this.control.value);\n\n    // debugger\n    if (this.rawOptions) {\n      this.selectionObject = this.rawOptions.find((x) => x[this.valueField] == this.__value);\n      this.mSelectOptionChange.emit(this.selectionObject);\n      if (this.type == 'select') {\n        // debugger;\n        this.control.formattedValue = (<MatOption>this.matSelect?.selected)?.viewValue;\n        this.mSelectedOptionLabel.emit((<MatOption>this.matSelect?.selected)?.viewValue);\n      }\n    }\n    if (this.customSelectChangeAction)\n      this.mContextChange.emit(\n        this.customSelectChangeAction(this.control.value, this.options, this.rawOptions)\n      );\n    this.control.labelValue = this.label;\n  }\n  get valid() {\n    return this.control?.valid && this.control?.dirty;\n  }\n  get invalid() {\n    return this.control?.invalid && this.control?.dirty;\n  }\n  get value() {\n    return this.control?.value;\n  }\n  get hasValue() {\n    return !!this.control?.value?.toString()?.trim();\n  }\n  get invalidCheckbox() {\n    return this.invalid && this.type == 'checkbox';\n  }\n  upload(e) {\n    this.files = e.target.files;\n    this.mchange.emit(e);\n  }\n}\ntype InputTheme = 1 | 2;\nexport type OptionLabelType =\n  | 'acd'\n  | 'bnk'\n  | 'ccd'\n  | 'cd'\n  | 'cdt'\n  | 'cf'\n  | 'cg'\n  | 'cl'\n  | 'cmd'\n  | 'cn'\n  | 'ct'\n  | 'cu'\n  | 'gd'\n  | 'ha'\n  | 'id'\n  | 'if'\n  | 'ifl'\n  | 'il'\n  | 'it'\n  | 'md'\n  | 'na'\n  | 'pd'\n  | 'pep'\n  | 'pam'\n  | 'nf'\n  | 'td'\n  | 'title'\n  | 'ud'\n  | 'uf'\n  | 'vl'\n  | 'vv';\n\nexport { IOption } from './input.service';\n","<div class=\"  custom-input align-items-center {{type}} gx-1\" [formGroup]=\"form|toAny\" [ngClass]=\"{'d-flex':!stacked}\">\n  @if (showLabel) {\n  <app-input-label [colored]=\"colored\" [form]=\"form\" [hint]=\"hint\" [id]=\"id\" [invalidCheckbox]=\"invalidCheckbox\"\n    [isRequired]=\"isRequired\" [label]=\"label\" [lblCl]=\"lblCl\" [light]=\"light\" [mini]=\"mini\"\n    [ngClass]=\"{'w-100': stacked}\" [inlineHint]=\"inlineHint\" [showRequiredTag]=\"showRequiredTag\" [showLabel]=\"showLabel\"\n    [small]=\"small\" [stacked]=\"stacked\" [theme]=\"theme\" [xsmall]=\"xsmall\">\n  </app-input-label>\n  }\n  <div class=\"d-flex align-items-center {{inputContClass}} \">\n    <div class=\" position-relative d-flex input-content w-100\"\n      [ngClass]=\"{'ms-2':!stacked,showValidationIcon:showValidation || showValidationIcon,dontFormatAsInput}\">\n\n      <ng-template #date>\n        <date-input [debug]=\"debug\" [readonly]=\"readonly\" [id]=\"id\" class=\"w-100\" [type]=\"type\"\n          (valueChanged)=\"change($event)\" [value]=\"control?.value\" [inpCl]=\"inpCl\" [cls]=\"cls\" [max]=\"max\" [min]=\"min\"\n          [valid]=\"valid\" [invalid]=\"invalid\" [showValidation]=\"showValidation\" [control]=\"control\" />\n      </ng-template>\n      @switch (type) {\n\n      <!-- DATE -->\n      @case ('date') {\n\n      <ng-container *ngTemplateOutlet=\"date\" />\n\n      }\n      <!-- DATETIME-LOCAL -->\n      @case ('datetime-local') {\n\n      <ng-container *ngTemplateOutlet=\"date\" />\n\n      }\n      <!-- CHECKBOX -->\n      @case ('checkbox') {\n\n      <input type=\"checkbox\" id=\"{{ id }}\" [formControlName]=\"name|toAny\" [attr.data-noformat]=\"noFormat\"\n        [attr.data-debug]=\"debug\" class=\"{{ inpCl }} d-inline-block form-control width-unset\"\n        placeholder=\"{{ placeholder }}\" [required]=\"required\" [readonly]=\"readonly\" (change)=\"change($event)\"\n        [checked]=\"checked\" [attr.indeterminate]=\"indeterminate\" />\n\n      }\n      @case ('checkedbox') {\n\n      <input type=\"checkbox\" class=\"{{ inpCl }} d-inline-block form-control width-unset\" [checked]=\"checked\"\n        [attr.data-debug]=\"debug\" [attr.data-noformat]=\"noFormat\" [required]=\"required\" [readonly]=\"readonly\"\n        (change)=\"change($event)\" />\n\n      }\n      <!-- FILE -->\n      @case ('file') {\n\n      <input type=\"file\" id=\"{{ id }}\" [class]=\"inpCl | inputClass: valid:invalid:showValidation\"\n        (change)=\"upload($event)\" [accept]=\"accept\" [attr.multiple]=\"multiple\" />\n\n      }\n      <!-- FILE BUTTON-->\n      @case ('fileButton') {\n\n      <input type=\"file\" id=\"{{ id }}\" [class]=\"inpCl | inputClass: valid:invalid:showValidation\"\n        (change)=\"upload($event)\" [accept]=\"accept\" [attr.multiple]=\"multiple\" hidden #file />\n      <app-btn class=\"w-100\" (mclick)=\"file.click()\" icon=\"upload\" [type]=\"files ? 'primary' : 'secondary'\"\n        text=\"{{placeholder||label||'Upload'}}\">\n      </app-btn>\n\n      }\n      <!-- SELECT -->\n      @case ('select') {\n\n      <!-- [attr.disabled]=\"disabled\" -->\n      <mat-select #matSelectTag placeholder=\"{{placeholder}}\" formControlName=\"{{name|toAny}}\" id=\"{{ id }}\"\n        class=\"{{cls}} {{inpCl | inputClass: valid:invalid:showValidation}}\" [required]=\"required\"\n        (selectionChange)=\"change({target:$event})\">\n        @if (showEmptyOption) {\n        <mat-option selected [value]=\"null\" class=\"empty-option\">\n          {{ placeholder }}\n        </mat-option>\n        }\n        @for (item of options; track iS.trackByValue($index, item)) {\n        <mat-option [value]=\"item.value\">\n          <div class=\"option\" [matTooltip]=\"item.label\" [matTooltipDisabled]=\"ele.scrollWidth<=ele.offsetWidth\" #ele>\n            {{ item.label | appTranslate: translateOptions | async }}\n          </div>\n        </mat-option>\n        }\n      </mat-select>\n\n      }\n      <!-- AUTOCOMPLETE -->\n      <!-- <ng-container *ngSwitchCase=\"'autocomplete'\">\n          <app-autocomplete [form]=\"form\" [label]=\"label\" [labelField]=\"labelField\"\n            [autoPickValueField]=\"autoPickValueField\" [labelType]=\"labelType\"\n            [optionsFunc]=\"optionsFunc\" [name]=\"name|toAny\" [optionFormatter]=\"optionFormatter\"\n            [valueField]=\"valueField\" [options]=\"options\" [hint]=\"hint\" [disabled]=\"disabled\" />\n        </ng-container> -->\n      <!-- TEXTAREA -->\n      @case ('textarea') {\n\n      <textarea [formControlName]=\"name|toAny\" id=\"{{ id }}\" [class]=\"inpCl | inputClass: valid:invalid:showValidation\"\n        [attr.data-noformat]=\"noFormat\" [rows]=\"textareaRows\" [required]=\"required\" [readonly]=\"readonly\"\n        (change)=\"change($event)\"></textarea>\n\n      }\n      <!-- Radio -->\n      @case ('radio') {\n\n      <input type=\"radio\" [formControlName]=\"name|toAny\" id=\"{{ id }}\" [readonly]=\"readonly\" (change)=\"change($event)\"\n        [attr.data-noformat]=\"noFormat\" [value]=\"__value\" />\n\n      }\n      <!-- Viewer -->\n      @case ('viewer') {\n\n      <input type=\"text\" id=\"{{ id }}\" placeholder=\"{{ placeholder }}\" [attr.data-noformat]=\"noFormat\"\n        [class]=\"inpCl | inputClass: valid:invalid:showValidation\" [readonly]=\"true\" [value]=\"value\" />\n\n      }\n      <!-- PASSWORD -->\n      @case ('password') {\n\n      <input type=\"{{ showPassword ? 'text' : 'password' }}\" [formControlName]=\"name|toAny\"\n        placeholder=\"{{ placeholder }}\" [attr.data-noformat]=\"noFormat\" id=\"{{ id }}\"\n        [class]=\"inpCl | inputClass: valid:invalid:showValidation\" [required]=\"required\" [max]=\"max\" [min]=\"min\"\n        [readonly]=\"readonly\" (change)=\"change($event)\" value=\"{{ __value }}\" />\n      <div class=\"password-icons pointer\" (click)=\"showPassword = !showPassword\">\n        @if (showPassword) {\n        <i class=\"fa fa-eye-slash\"></i>\n        }\n        @if (!showPassword) {\n        <i class=\"fa fa-eye\"></i>\n        }\n      </div>\n\n      }\n      <!-- DEFAULT -->\n      @default {\n\n\n      <div [class]=\"inpCl | inputClass: valid:invalid:showValidation\"\n        [ngClass]=\"{'has-prefix': !!prefix,disabled:readonly||control?.disabled}\">\n        @if (prefix) {\n        <div class=\"prefix-val\" #prefixVal>\n          {{prefix}}\n        </div>\n        }\n        <input type=\"{{ type }}\" [formControlName]=\"name|toAny\" placeholder=\"{{ placeholder}}\" id=\"{{ id }}\"\n          [matTooltip]=\"ele.innerText\" [matTooltipDisabled]=\"ele.scrollWidth<=ele.offsetWidth\" #ele\n          [attr.data-debug]=\"debug\" [attr.data-noformat]=\"noFormat\" [attr.data-otype]=\"oType\" [required]=\"required\"\n          [max]=\"max\" [min]=\"min\" [readonly]=\"readonly \" (change)=\"change($event)\" value=\"{{ __value }}\" />\n      </div>\n\n      }\n      }\n\n      @if (control?.dirty && (showValidation || showValidationIcon)) {\n\n      <div [ngClass]=\"{ valid: control?.valid }\" class=\"validity-icon\">\n        <i class=\"fa fa-check\"></i>\n      </div>\n      <div [ngClass]=\"{ pending: control?.pending }\" class=\"validity-icon\">\n        <i class=\"fa fa-spinner fa-spin\"></i>\n      </div>\n      <div [ngClass]=\"{ invalid: control?.invalid }\" class=\"validity-icon\">\n        <i class=\"fa fa-times\"></i>\n      </div>\n\n      }\n      <!-- <mat-form-field class=\"input\" appearance=\"fill\">\n        <input type=\"{{inp.type}}\" matInput [formControl]=\"inp.formControl\">\n        <mat-error *ngFor=\"let validation of inp.vms\">\n          <ng-container *ngIf=\"validation|validator:inp.formControl:inp.formControl?.value\">\n            {{validation.message|validationMsg:inp.prefix:inp.suffix}}\n          </ng-container>\n        </mat-error>\n      </mat-form-field> -->\n    </div>\n    @if (endLabel) {\n    <div class=\"col-auto text-primary ms-2\" (click)=\"iS.log(form)\" [matTooltip]=\"endLabelTooltip|appTranslate|async\">\n      {{endLabel|appTranslate|async}}\n    </div>\n    }\n  </div>\n</div>\n@if (showValidationMsg) {\n<app-validation-message [label]=\"label\" [control]=\"control\" />\n}"]}
356
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-basic.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/input/input-basic.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, ViewChild, booleanAttribute } from '@angular/core';\nimport { AbstractControl, Validators } from '@angular/forms';\nimport { Observable, ReplaySubject } from 'rxjs';\nimport { FCInput, InputType, IValidationMessage } from '../../models/index.model';\nimport { MatSelect } from '@angular/material/select';\nimport { MatOption } from '@angular/material/core';\nimport { InputProviders, InputSharedModules } from './input-shared.module';\nimport { DateInputComponent } from './date-input/date-input.component';\nimport { InputBase } from './input-base.component';\nimport { IOption, InputService } from './input.service';\n\n@Component({\n  selector: 'app-input-basic,app-input',\n  templateUrl: './input.component.html',\n  styleUrls: ['./input.component.scss'],\n  standalone: true,\n  providers: InputProviders,\n  imports: [DateInputComponent, InputSharedModules],\n})\nexport class InputBasicComponent<\n    TFormGroup extends {\n      [K in keyof TFormGroup]: AbstractControl<any, any>;\n    } = any,\n    TControl = any,\n    TOption = any,\n  >\n  extends InputBase<TFormGroup, TControl, TOption>\n  implements OnInit\n{\n  @Input() accept: string;\n  @Input() autocomplete: boolean = true;\n  @Input() autoPickValueField: boolean;\n  @Input() clearOnDisable: boolean = true;\n  @Input() cls: string;\n  @Input('input') inp: FCInput;\n  @Input() colored: boolean = true;\n  @Input() checked: boolean = false; //optional checked option for checkboxes\n  @Input() contextData: any;\n  @Input() debug: boolean;\n  @Input() decimalPoints: number;\n  @Input() endLabel: string;\n  @Input() endLabelTooltip: string;\n  @Input() files: File[];\n  @Input() noFormat: boolean;\n  @Input() hide: boolean;\n  @Input() hint: string | number;\n  @Input() id: string = 'id' + Math.round(Math.random() * 1000000);\n  @Input() inpCl: string = 'control-bg-gray';\n  @Input() label: string;\n  @Input() labelLink: string;\n  @Input() labelField: keyof TOption;\n  @Input() labelType: OptionLabelType; //use this to pick a preset value label group for the options\n  @Input() lblCl: string = '2';\n  @Input() light: boolean = true;\n  @Input() loading: boolean;\n  @Input() max: number | string;\n  @Input() set maxToday(v: boolean) {\n    if (v) this.max = new Date().toISOString();\n  }\n  @Input() set minToday(v: boolean) {\n    if (v) this.min = new Date().toISOString();\n  }\n  @Input() min: number | string;\n  @Input() minLength: number;\n  @Input() maxLength: number;\n  @Input() mini: boolean;\n  @Input() multiple: boolean;\n  @Input() optionFormatter: (item: TOption) => string;\n  @Input() optionsFunc: (...val: any) => Observable<any[]>;\n  @Input() placeholder: string;\n  @Input() prefix: string;\n  @Input({ transform: booleanAttribute }) readonly: boolean;\n  @Input({ transform: booleanAttribute }) required?: boolean;\n  @Input({ transform: booleanAttribute }) showEmptyOption?: boolean = true;\n  @Input({ transform: booleanAttribute }) showLabel: boolean;\n  @Input({ transform: booleanAttribute }) showValidation: boolean = false;\n  @Input({ transform: booleanAttribute }) showValidationMsg: boolean = false;\n  @Input({ transform: booleanAttribute }) showValidationIcon: boolean;\n  @Input({ transform: booleanAttribute }) small: boolean;\n  @Input({ transform: booleanAttribute }) stacked: boolean = true;\n  @Input() suffix: string;\n  @Input() theme: InputTheme = 1;\n  @Input() translateOptions: boolean = false;\n  @Input() valueField: keyof TOption; //use this to choose a field in the option for modeling\n  @Input() vms: IValidationMessage[];\n  @Input() xsmall: boolean;\n  @Output() mchange = new EventEmitter();\n  @Output() mSelectOptionChange = new EventEmitter<TOption>();\n  @Output() mSelectedOptionLabel = new EventEmitter<string>();\n  @Output() mContextChange = new EventEmitter();\n  disabled: boolean;\n  options: IOption[];\n  options$ = new ReplaySubject<IOption[]>();\n  rawOptions: any[];\n  showPassword: boolean;\n  type: InputType = 'text';\n  viewInited: boolean;\n  forcePatched: boolean;\n  selectionObject: TOption;\n  oType: InputType;\n  // labelValue: string;\n  @Input('setCurrentDate') set _setCurrentDate(v: boolean) {\n    if (v) this.control.patchValue(new Date().toISOString().split('T')[0]);\n  }\n  @Input('duplicateCheck') duplicateCheck: boolean;\n  @Input('disabled') set _disabled(v: boolean) {\n    if (this.debug) debugger;\n    this.disabled = v;\n    if (this.control?.parent?.disabled) return;\n    if (v) {\n      if (this.clearOnDisable) this.control?.reset();\n      this.control?.disable();\n    } else if (this.control?.disabled) {\n      this.control?.enable();\n    }\n  }\n  InputType;\n  @Input() customSelectChangeAction: (val: string | number, options: any[], rawOptions: any[]) => any;\n  @Input('options') set _options(v: TOption[] | null) {\n    // debugger\n    // console.log('options', v);\n    if (this.debug) debugger;\n    this.rawOptions = v;\n    this.options = this.iS.optionsFormatter(\n      v,\n      this.valueField as string,\n      this.optionFormatter,\n      this.labelType,\n      this.labelField as string,\n      this.autoPickValueField,\n    );\n    // debugger\n    this.options$.next(this.options);\n  }\n  @Input('type') set _type(v: InputType) {\n    this.oType = v;\n    if (v == 'percentage') {\n      this.type = 'number';\n      this.max = 100;\n      this.min = 0;\n    } else this.type = v;\n    // if (this.forcePatched) {\n    //   this.control.reset();\n    //   this.forcePatched = false;\n    // }\n    // if (v == 'checkbox' && (this.value == null || this.value == undefined)) {\n    //   this.control?.patchValue(false);\n    //   this.forcePatched = tInputType\n    // }\n  }\n  __value: string | number;\n  @Input('mvalue') set _value(v: string | number) {\n    this.__value = v;\n  }\n  @ViewChild('matSelectTag') matSelect: MatSelect;\n  constructor(public iS: InputService) {\n    super();\n  }\n\n  ngOnInit(): void {\n    if (this.showLabel == null) this.showLabel = !!this.label;\n    if (this.autoPickValueField) {\n      if (!this.labelType) this.labelType = 'cdt';\n      if (!this.valueField) this.valueField = 'code' as any;\n    }\n    if (this.min == 0 && this.max == 100) this.oType = 'percentage';\n    if (\n      (this.type == 'viewer' || this.showValidation || this.showValidationIcon || this.label?.includes('code')) &&\n      (this.noFormat == null || this.noFormat == undefined)\n    )\n      this.noFormat = true;\n\n    // if (this.type == 'select' || this.type == 'autocomplete')\n    //   this.control.valueChanges.subscribe((r) => {\n    //     this.labelValue = this.options.find((x) => x.value == r)?.label;\n    //   });\n    // console.log(this.id)\n    // if (this.disabled) this._disabled = this.disabled;\n  }\n  ngAfterViewInit(): void {\n    // this.viewInited = true;\n  }\n  disableControl(control: AbstractControl = this.control) {\n    if (!this.disabled) return;\n    control?.disable({ emitEvent: false });\n  }\n  get isRequired() {\n    return this.required || this.control?.hasValidator(Validators.required);\n  }\n  change(e: { target: { checked?: boolean; value: any } } | Event) {\n    // debugger;\n    let val;\n    if (this.type == 'checkbox') {\n      val = e.target?.['checked'];\n      this.control.setValue(e.target?.['checked']);\n    } else val = e.target?.['value'];\n    if (this.type == 'number') {\n      // debugger;\n      if (this.oType == 'percentage' && !this.max) {\n        this.max = 100;\n        this.min = 0;\n      }\n      if (val != null && val != '') {\n        // debugger;\n        if (this.max && +val > +this.max) this.control.setValue(this.max);\n        else if (this.min != null && this.min != undefined && +val < +this.min) this.control.setValue(this.min);\n        if (this.decimalPoints != undefined && this.decimalPoints != null) this.control.setValue(+(+val).toFixed(this.decimalPoints));\n      }\n    }\n    if (this.maxLength && this.control?.value?.toString().length > this.maxLength)\n      this.control.setValue(\n        this.type == 'number' ? +this.control?.value?.toString().slice(0, this.maxLength) : this.control?.value?.toString().slice(0, this.maxLength),\n      );\n    this.__value = this.control.value;\n    this.mchange.emit(this.control.value);\n\n    // debugger\n    if (this.rawOptions) {\n      this.selectionObject = this.rawOptions.find((x) => x[this.valueField] == this.__value);\n      this.mSelectOptionChange.emit(this.selectionObject);\n      if (this.type == 'select') {\n        // debugger;\n        this.control.formattedValue = (<MatOption>this.matSelect?.selected)?.viewValue;\n        this.mSelectedOptionLabel.emit((<MatOption>this.matSelect?.selected)?.viewValue);\n      }\n    }\n    if (this.customSelectChangeAction) this.mContextChange.emit(this.customSelectChangeAction(this.control.value, this.options, this.rawOptions));\n    this.control.labelValue = this.label;\n  }\n  get valid() {\n    return this.control?.valid && this.control?.dirty;\n  }\n  get invalid() {\n    return this.control?.invalid && this.control?.dirty;\n  }\n  get value() {\n    return this.control?.value;\n  }\n  get hasValue() {\n    return !!this.control?.value?.toString()?.trim();\n  }\n  get invalidCheckbox() {\n    return this.invalid && this.type == 'checkbox';\n  }\n  upload(e) {\n    this.files = e.target.files;\n    this.mchange.emit(e);\n  }\n}\ntype InputTheme = 1 | 2;\nexport type OptionLabelType =\n  | 'acd'\n  | 'bnk'\n  | 'ccd'\n  | 'cd'\n  | 'cdt'\n  | 'cf'\n  | 'cg'\n  | 'cl'\n  | 'cmd'\n  | 'cn'\n  | 'ct'\n  | 'cu'\n  | 'gd'\n  | 'ha'\n  | 'id'\n  | 'if'\n  | 'ifl'\n  | 'il'\n  | 'it'\n  | 'md'\n  | 'na'\n  | 'pd'\n  | 'pep'\n  | 'pam'\n  | 'nf'\n  | 'td'\n  | 'title'\n  | 'ud'\n  | 'uf'\n  | 'vl'\n  | 'vv';\n\nexport { IOption } from './input.service';\n","<div class=\"  custom-input align-items-center {{type}} gx-1\" [formGroup]=\"form|toAny\" [ngClass]=\"{'d-flex':!stacked}\">\n  @if (showLabel) {\n  <app-input-label [colored]=\"colored\" [form]=\"form\" [hint]=\"hint\" [id]=\"id\" [invalidCheckbox]=\"invalidCheckbox\"\n    [isRequired]=\"isRequired\" [label]=\"label\" [lblCl]=\"lblCl\" [light]=\"light\" [mini]=\"mini\"\n    [ngClass]=\"{'w-100': stacked}\" [inlineHint]=\"inlineHint\" [showRequiredTag]=\"showRequiredTag\" [showLabel]=\"showLabel\"\n    [small]=\"small\" [stacked]=\"stacked\" [theme]=\"theme\" [xsmall]=\"xsmall\">\n  </app-input-label>\n  }\n  <div class=\"d-flex align-items-center {{inputContClass}} \">\n    <div class=\" position-relative d-flex input-content w-100\"\n      [ngClass]=\"{'ms-2':!stacked,showValidationIcon:showValidation || showValidationIcon,dontFormatAsInput}\">\n\n      <ng-template #date>\n        <date-input [debug]=\"debug\" [readonly]=\"readonly\" [id]=\"id\" class=\"w-100\" [type]=\"type\"\n          (valueChanged)=\"change($event)\" [value]=\"control?.value\" [inpCl]=\"inpCl\" [cls]=\"cls\" [max]=\"max\" [min]=\"min\"\n          [valid]=\"valid\" [invalid]=\"invalid\" [showValidation]=\"showValidation\" [control]=\"control\" />\n      </ng-template>\n      @switch (type) {\n\n      <!-- DATE -->\n      @case ('date') {\n\n      <ng-container *ngTemplateOutlet=\"date\" />\n\n      }\n      <!-- DATETIME-LOCAL -->\n      @case ('datetime-local') {\n\n      <ng-container *ngTemplateOutlet=\"date\" />\n\n      }\n      <!-- CHECKBOX -->\n      @case ('checkbox') {\n\n      <input type=\"checkbox\" id=\"{{ id }}\" [formControlName]=\"name|toAny\" [attr.data-noformat]=\"noFormat\"\n        [attr.data-debug]=\"debug\" class=\"{{ inpCl }} d-inline-block form-control width-unset\"\n        placeholder=\"{{ placeholder }}\" [required]=\"required\" [readonly]=\"readonly\" (change)=\"change($event)\"\n        [checked]=\"checked\" [attr.indeterminate]=\"indeterminate\" />\n\n      }\n      @case ('checkedbox') {\n\n      <input type=\"checkbox\" class=\"{{ inpCl }} d-inline-block form-control width-unset\" [checked]=\"checked\"\n        [attr.data-debug]=\"debug\" [attr.data-noformat]=\"noFormat\" [required]=\"required\" [readonly]=\"readonly\"\n        (change)=\"change($event)\" />\n\n      }\n      <!-- FILE -->\n      @case ('file') {\n\n      <input type=\"file\" id=\"{{ id }}\" [class]=\"inpCl | inputClass: valid:invalid:showValidation\"\n        (change)=\"upload($event)\" [accept]=\"accept\" [attr.multiple]=\"multiple\" />\n\n      }\n      <!-- FILE BUTTON-->\n      @case ('fileButton') {\n\n      <input type=\"file\" id=\"{{ id }}\" [class]=\"inpCl | inputClass: valid:invalid:showValidation\"\n        (change)=\"upload($event)\" [accept]=\"accept\" [attr.multiple]=\"multiple\" hidden #file />\n      <app-btn class=\"w-100\" (mclick)=\"file.click()\" icon=\"upload\" [type]=\"files ? 'primary' : 'secondary'\"\n        text=\"{{placeholder||label||'Upload'}}\">\n      </app-btn>\n\n      }\n      <!-- SELECT -->\n      @case ('select') {\n\n      <!-- [attr.disabled]=\"disabled\" -->\n      <mat-select #matSelectTag placeholder=\"{{placeholder}}\" formControlName=\"{{name|toAny}}\" id=\"{{ id }}\"\n        class=\"{{cls}} {{inpCl | inputClass: valid:invalid:showValidation}}\" [required]=\"required\"\n        (selectionChange)=\"change({target:$event})\">\n        @if (showEmptyOption) {\n        <mat-option selected [value]=\"null\" class=\"empty-option\">\n          {{ placeholder }}\n        </mat-option>\n        }\n        @for (item of options; track iS.trackByValue($index, item)) {\n        <mat-option [value]=\"item.value\">\n          <div class=\"option\" [matTooltip]=\"item.label\" [matTooltipDisabled]=\"ele.scrollWidth<=ele.offsetWidth\" #ele>\n            {{ item.label | appTranslate: translateOptions | async }}\n          </div>\n        </mat-option>\n        }\n      </mat-select>\n\n      }\n      <!-- AUTOCOMPLETE -->\n      <!-- <ng-container *ngSwitchCase=\"'autocomplete'\">\n          <app-autocomplete [form]=\"form\" [label]=\"label\" [labelField]=\"labelField\"\n            [autoPickValueField]=\"autoPickValueField\" [labelType]=\"labelType\"\n            [optionsFunc]=\"optionsFunc\" [name]=\"name|toAny\" [optionFormatter]=\"optionFormatter\"\n            [valueField]=\"valueField\" [options]=\"options\" [hint]=\"hint\" [disabled]=\"disabled\" />\n        </ng-container> -->\n      <!-- TEXTAREA -->\n      @case ('textarea') {\n\n      <textarea [formControlName]=\"name|toAny\" id=\"{{ id }}\" [class]=\"inpCl | inputClass: valid:invalid:showValidation\"\n        [attr.data-noformat]=\"noFormat\" [rows]=\"textareaRows\" [required]=\"required\" [readonly]=\"readonly\"\n        (change)=\"change($event)\"></textarea>\n\n      }\n      <!-- Radio -->\n      @case ('radio') {\n\n      <input type=\"radio\" [formControlName]=\"name|toAny\" id=\"{{ id }}\" [readonly]=\"readonly\" (change)=\"change($event)\"\n        [attr.data-noformat]=\"noFormat\" [value]=\"__value\" />\n\n      }\n      <!-- Viewer -->\n      @case ('viewer') {\n\n      <input type=\"text\" id=\"{{ id }}\" placeholder=\"{{ placeholder }}\" [attr.data-noformat]=\"noFormat\"\n        [class]=\"inpCl | inputClass: valid:invalid:showValidation\" [readonly]=\"true\" [value]=\"value\" />\n\n      }\n      <!-- PASSWORD -->\n      @case ('password') {\n\n      <input type=\"{{ showPassword ? 'text' : 'password' }}\" [formControlName]=\"name|toAny\"\n        placeholder=\"{{ placeholder }}\" [attr.data-noformat]=\"noFormat\" id=\"{{ id }}\"\n        [class]=\"inpCl | inputClass: valid:invalid:showValidation\" [required]=\"required\" [max]=\"max\" [min]=\"min\"\n        [readonly]=\"readonly\" (change)=\"change($event)\" value=\"{{ __value }}\" />\n      <div class=\"password-icons pointer\" (click)=\"showPassword = !showPassword\">\n        @if (showPassword) {\n        <i class=\"fa fa-eye-slash\"></i>\n        }\n        @if (!showPassword) {\n        <i class=\"fa fa-eye\"></i>\n        }\n      </div>\n\n      }\n      <!-- DEFAULT -->\n      @default {\n\n\n      <div [class]=\"inpCl | inputClass: valid:invalid:showValidation\"\n        [ngClass]=\"{'has-prefix': !!prefix,disabled:readonly||control?.disabled}\">\n        @if (prefix) {\n        <div class=\"prefix-val\" #prefixVal>\n          {{prefix}}\n        </div>\n        }\n        <input type=\"{{ type }}\" [formControlName]=\"name|toAny\" placeholder=\"{{ placeholder}}\" id=\"{{ id }}\"\n          [matTooltip]=\"ele.innerText\" [matTooltipDisabled]=\"ele.scrollWidth<=ele.offsetWidth\" #ele\n          [attr.data-debug]=\"debug\" [attr.data-noformat]=\"noFormat\" [attr.data-otype]=\"oType\" [required]=\"required\"\n          [max]=\"max\" [min]=\"min\" [readonly]=\"readonly \" (change)=\"change($event)\" value=\"{{ __value }}\" />\n      </div>\n\n      }\n      }\n\n      @if (control?.dirty && (showValidation || showValidationIcon)) {\n\n      <div [ngClass]=\"{ valid: control?.valid }\" class=\"validity-icon\">\n        <i class=\"fa fa-check\"></i>\n      </div>\n      <div [ngClass]=\"{ pending: control?.pending }\" class=\"validity-icon\">\n        <i class=\"fa fa-spinner fa-spin\"></i>\n      </div>\n      <div [ngClass]=\"{ invalid: control?.invalid }\" class=\"validity-icon\">\n        <i class=\"fa fa-times\"></i>\n      </div>\n\n      }\n      <!-- <mat-form-field class=\"input\" appearance=\"fill\">\n        <input type=\"{{inp.type}}\" matInput [formControl]=\"inp.formControl\">\n        <mat-error *ngFor=\"let validation of inp.vms\">\n          <ng-container *ngIf=\"validation|validator:inp.formControl:inp.formControl?.value\">\n            {{validation.message|validationMsg:inp.prefix:inp.suffix}}\n          </ng-container>\n        </mat-error>\n      </mat-form-field> -->\n    </div>\n    @if (endLabel) {\n    <div class=\"col-auto text-primary ms-2\" (click)=\"iS.log(form)\" [matTooltip]=\"endLabelTooltip|appTranslate|async\">\n      {{endLabel|appTranslate|async}}\n    </div>\n    }\n  </div>\n</div>\n@if (showValidationMsg) {\n<app-validation-message [label]=\"label\" [control]=\"control\" />\n}"]}
@@ -6200,10 +6200,7 @@ class InputBasicComponent extends InputBase {
6200
6200
  }
6201
6201
  if (this.min == 0 && this.max == 100)
6202
6202
  this.oType = 'percentage';
6203
- if ((this.type == 'viewer' ||
6204
- this.showValidation ||
6205
- this.showValidationIcon ||
6206
- this.label?.includes('code')) &&
6203
+ if ((this.type == 'viewer' || this.showValidation || this.showValidationIcon || this.label?.includes('code')) &&
6207
6204
  (this.noFormat == null || this.noFormat == undefined))
6208
6205
  this.noFormat = true;
6209
6206
  // if (this.type == 'select' || this.type == 'autocomplete')
@@ -6250,9 +6247,7 @@ class InputBasicComponent extends InputBase {
6250
6247
  }
6251
6248
  }
6252
6249
  if (this.maxLength && this.control?.value?.toString().length > this.maxLength)
6253
- this.control.setValue(this.type == 'number'
6254
- ? +this.control?.value?.toString().slice(0, this.maxLength)
6255
- : this.control?.value?.toString().slice(0, this.maxLength));
6250
+ this.control.setValue(this.type == 'number' ? +this.control?.value?.toString().slice(0, this.maxLength) : this.control?.value?.toString().slice(0, this.maxLength));
6256
6251
  this.__value = this.control.value;
6257
6252
  this.mchange.emit(this.control.value);
6258
6253
  // debugger