ets-fe-ng-sdk 17.0.185 → 17.0.186
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/Shared/components/input/input-basic.component.mjs +2 -2
- package/fesm2022/ets-fe-ng-sdk.mjs +1 -1
- package/fesm2022/ets-fe-ng-sdk.mjs.map +1 -1
- package/lib/Services/utility.service.d.ts +1 -1
- package/lib/Shared/components/info-dialog/info-dialog.component.d.ts +1 -1
- package/lib/Shared/components/table-plain/table.pipe.d.ts +1 -1
- package/package.json +1 -1
|
@@ -86,7 +86,7 @@ export class InputBasicComponent extends InputBase {
|
|
|
86
86
|
this.control.setValue(e.target?.['checked']);
|
|
87
87
|
}
|
|
88
88
|
else
|
|
89
|
-
val =
|
|
89
|
+
val = this.control?.value;
|
|
90
90
|
if (this.typeSignal() == 'number') {
|
|
91
91
|
// debugger;
|
|
92
92
|
if (this.oTypeSignal() == 'percentage' && !this.maxSignal()) {
|
|
@@ -177,4 +177,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
|
|
|
177
177
|
type: ViewChild,
|
|
178
178
|
args: ['matSelectTag']
|
|
179
179
|
}] } });
|
|
180
|
-
//# 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":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,SAAS,EAAoB,QAAQ,EAAE,MAAM,EAAyB,MAAM,eAAe,CAAC;AAErJ,OAAO,EAAc,aAAa,EAAE,MAAM,MAAM,CAAC;AAIjD,OAAO,EAAE,cAAc,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAC3E,OAAO,EAAE,kBAAkB,EAAE,MAAM,mCAAmC,CAAC;AACvE,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;;;;;;;;;;;;;;;AAWnD,MAAM,OAAO,mBAOX,SAAQ,SAAwC;IAiChD,sBAAsB;IACtB,IAA6B,eAAe,CAAC,CAAU;QACrD,IAAI,CAAC;YAAE,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC1E,CAAC;IACD,IAAsB,QAAQ,CAAC,CAAmB;QAChD,IAAI,IAAI,CAAC,KAAK,EAAE;YAAE,QAAQ,CAAC;QAC3B,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;QACnC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;IACrC,CAAC;IACD,IAAqB,MAAM,CAAC,CAAkB;QAC5C,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC1B,CAAC;IAGD;QACE,KAAK,EAAE,CAAC;QA5CD,iBAAY,GAAY,IAAI,CAAC;QAS7B,UAAK,GAAW,GAAG,CAAC;QACpB,UAAK,GAAY,IAAI,CAAC;QAMtB,UAAK,GAAe,CAAC,CAAC;QAGrB,wBAAmB,GAAG,IAAI,YAAY,EAAW,CAAC;QAClD,yBAAoB,GAAG,IAAI,YAAY,EAAU,CAAC;QAC5D,aAAQ,GAAG,IAAI,aAAa,EAAa,CAAC;QAG1C,0BAAqB,GAAG,QAAQ,CAAU,GAAG,EAAE;YAC7C,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,EAAE,EAC9B,OAAO,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACpC,OAAO,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,KAAK,CAAC,CAAC;QAClE,CAAC,CAAC,CAAC;QAiBD,MAAM,CAAC,GAAG,EAAE;YACV,IAAI,IAAI,CAAC,UAAU,EAAE,IAAI,QAAQ,EAAE;gBACjC,IAAI,CAAC,OAAO,CAAC,cAAc,GAAe,IAAI,CAAC,SAAS,EAAE,QAAS,EAAE,SAAS,CAAC;gBAC/E,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAa,IAAI,CAAC,SAAS,EAAE,QAAS,EAAE,SAAS,CAAC,CAAC;aAClF;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAC3B,IAAI,CAAC,IAAI,CAAC,SAAS;gBAAE,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YAC5C,IAAI,CAAC,IAAI,CAAC,UAAU;gBAAE,IAAI,CAAC,UAAU,GAAG,MAAa,CAAC;SACvD;QACD,IAAI,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,IAAI,CAAC,SAAS,EAAE,IAAI,GAAG;YAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QAEzF,4DAA4D;QAC5D,iDAAiD;QACjD,uEAAuE;QACvE,QAAQ;QACR,uBAAuB;QACvB,qDAAqD;IACvD,CAAC;IAED,eAAe;QACb,0BAA0B;IAC5B,CAAC;IAED,cAAc,CAAC,UAA2B,IAAI,CAAC,OAAO;QACpD,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;YAAE,OAAO;QACnC,OAAO,EAAE,OAAO,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;IACzC,CAAC;IAED,MAAM,CAAC,CAAwD;QAC7D,YAAY;QACZ,IAAI,IAAI,CAAC,KAAK,EAAE;YAAE,QAAQ,CAAC;QAC3B,IAAI,GAAG,CAAC;QACR,IAAI,IAAI,CAAC,UAAU,EAAE,IAAI,UAAU,EAAE;YACnC,GAAG,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,SAAS,CAAC,CAAC;YAC5B,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;SAC9C;;YAAM,GAAG,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,CAAC;QACjC,IAAI,IAAI,CAAC,UAAU,EAAE,IAAI,QAAQ,EAAE;YACjC,YAAY;YACZ,IAAI,IAAI,CAAC,WAAW,EAAE,IAAI,YAAY,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,EAAE;gBAC3D,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;gBACxB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;aACvB;YACD,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,EAAE,EAAE;gBAC5B,YAAY;gBACZ,IAAI,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,GAAG,GAAG,CAAC,IAAI,CAAC,SAAS,EAAE;oBAAE,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;qBACrF,IAAI,IAAI,CAAC,SAAS,EAAE,IAAI,IAAI,IAAI,IAAI,CAAC,SAAS,EAAE,IAAI,SAAS,IAAI,CAAC,GAAG,GAAG,CAAC,IAAI,CAAC,SAAS,EAAE;oBAAE,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;gBACxI,IAAI,IAAI,CAAC,aAAa,IAAI,SAAS,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI;oBAAE,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC;aAC/H;SACF;QACD,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,MAAM,GAAG,IAAI,CAAC,SAAS;YAC3E,IAAI,CAAC,OAAO,CAAC,QAAQ,CACnB,IAAI,CAAC,UAAU,EAAE,IAAI,QAAQ;gBAC3B,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC;gBAC3D,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,CAC7D,CAAC;QACJ,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACzC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAEtC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,qBAAqB,EAAE,CAAC,CAAC;IAC9D,CAAC;IAED,MAAM,CAAC,CAAC;QACN,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;QAC5B,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC;8GA5HU,mBAAmB;kGAAnB,mBAAmB,+rBAHnB,cAAc,4JChB3B,8oTAwPA,u5BDvOY,kBAAkB;;2FAEjB,mBAAmB;kBAR/B,SAAS;+BACE,2BAA2B,cAGzB,IAAI,aACL,cAAc,WAChB,CAAC,kBAAkB,EAAE,kBAAkB,CAAC;wDAYxC,MAAM;sBAAd,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACU,GAAG;sBAAlB,KAAK;uBAAC,OAAO;gBACL,WAAW;sBAAnB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,GAAG;sBAAX,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACI,mBAAmB;sBAA5B,MAAM;gBACG,oBAAoB;sBAA7B,MAAM;gBAUsB,eAAe;sBAA3C,KAAK;uBAAC,gBAAgB;gBAGD,QAAQ;sBAA7B,KAAK;uBAAC,SAAS;gBAKK,MAAM;sBAA1B,KAAK;uBAAC,QAAQ;gBAGY,SAAS;sBAAnC,SAAS;uBAAC,cAAc","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, ViewChild, booleanAttribute, computed, effect, inject, input, signal } 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('input') inp: FCInput;\n  @Input() contextData: any;\n  @Input() decimalPoints: number;\n  @Input() files: File[];\n  @Input() hide: boolean;\n  @Input() hint: string | number;\n\n  @Input() labelLink: string;\n  @Input() lblCl: string = '2';\n  @Input() light: boolean = true;\n  @Input() loading: boolean;\n  @Input() minLength: number;\n  @Input() maxLength: number;\n  @Input() multiple: boolean;\n  @Input() optionsFunc: (...val: any) => Observable<any[]>;\n  @Input() theme: InputTheme = 1;\n  @Input() vms: IValidationMessage[];\n  @Input() xsmall: boolean;\n  @Output() mSelectOptionChange = new EventEmitter<TOption>();\n  @Output() mSelectedOptionLabel = new EventEmitter<string>();\n  options$ = new ReplaySubject<IOption[]>();\n  viewInited: boolean;\n  forcePatched: boolean;\n  selectionObjectSignal = computed<TOption>(() => {\n    const value = this.valueSignal(),\n      options = this.rawOptionsSignal();\n    return (options || []).find((x) => x[this.valueField] == value);\n  });\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('options') set _options(v: TOption[] | null) {\n    if (this.debug()) debugger;\n    this.rawOptionsSignal.set(v || []);\n    this.options$.next(this.options());\n  }\n  @Input('mvalue') set _value(v: string | number) {\n    this.valueSignal.set(v);\n  }\n  @ViewChild('matSelectTag') matSelect: MatSelect;\n\n  constructor() {\n    super();\n    effect(() => {\n      if (this.typeSignal() == 'select') {\n        this.control.formattedValue = (<MatOption>this.matSelect?.selected)?.viewValue;\n        this.mSelectedOptionLabel.emit((<MatOption>this.matSelect?.selected)?.viewValue);\n      }\n    });\n  }\n\n  ngOnInit(): void {\n    if (this.autoPickValueField) {\n      if (!this.labelType) this.labelType = 'cdt';\n      if (!this.valueField) this.valueField = 'code' as any;\n    }\n    if (this.minSignal() == 0 && this.maxSignal() == 100) this.oTypeSignal.set('percentage');\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\n  ngAfterViewInit(): void {\n    // this.viewInited = true;\n  }\n\n  disableControl(control: AbstractControl = this.control) {\n    if (!this.disabledSignal()) return;\n    control?.disable({ emitEvent: false });\n  }\n\n  change(e: { target: { checked?: boolean; value: any } } | Event) {\n    // debugger;\n    if (this.debug()) debugger;\n    let val;\n    if (this.typeSignal() == 'checkbox') {\n      val = e.target?.['checked'];\n      this.control.setValue(e.target?.['checked']);\n    } else val = e.target?.['value'];\n    if (this.typeSignal() == 'number') {\n      // debugger;\n      if (this.oTypeSignal() == 'percentage' && !this.maxSignal()) {\n        this.maxSignal.set(100);\n        this.minSignal.set(0);\n      }\n      if (val != null && val != '') {\n        // debugger;\n        if (this.maxSignal() && +val > +this.maxSignal()) this.control.setValue(this.maxSignal());\n        else if (this.minSignal() != null && this.minSignal() != undefined && +val < +this.minSignal()) this.control.setValue(this.minSignal());\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.typeSignal() == 'number'\n          ? +this.control?.value?.toString().slice(0, this.maxLength)\n          : this.control?.value?.toString().slice(0, this.maxLength),\n      );\n    this.valueSignal.set(this.control.value);\n    this.mchange.emit(this.control.value);\n\n    this.mSelectOptionChange.emit(this.selectionObjectSignal());\n  }\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 {{ typeSignal() }} gx-1\" [formGroup]=\"formSignal()\" [ngClass]=\"{ 'd-flex': !stackedSignal() }\">\n  @if (computedShowLabel()) {\n    <app-input-label\n      [colored]=\"coloredSignal()\"\n      [form]=\"formSignal()\"\n      [hint]=\"hint\"\n      [id]=\"idSignal()\"\n      [invalidCheckbox]=\"invalidCheckboxSignal()\"\n      [isRequired]=\"isRequiredSignal()\"\n      [label]=\"labelSignal()\"\n      [lblCl]=\"lblCl\"\n      [light]=\"light\"\n      [mini]=\"miniSignal()\"\n      [ngClass]=\"{ 'w-100': stackedSignal() }\"\n      [inlineHint]=\"inlineHint\"\n      [showRequiredTag]=\"showRequiredTagSignal()\"\n      [showLabel]=\"showLabelSignal()\"\n      [small]=\"smallSignal()\"\n      [stacked]=\"stackedSignal()\"\n      [theme]=\"theme\"\n      [xsmall]=\"xsmall\"></app-input-label>\n  }\n  <div class=\"d-flex align-items-center {{ inputContClassSignal() }} \">\n    <div\n      class=\"position-relative d-flex input-content w-100\"\n      [ngClass]=\"{\n        'ms-2': !stackedSignal(),\n        showValidationIcon: showValidationSignal() || showValidationIconSignal(),\n        dontFormatAsInput: dontFormatAsInputSignal()\n      }\">\n      <ng-template #date>\n        <date-input\n          #dateInput\n          [debug]=\"debug()\"\n          [readonly]=\"readonlySignal()\"\n          [id]=\"idSignal()\"\n          class=\"w-100\"\n          [type]=\"typeSignal()\"\n          (valueChanged)=\"dateChanged($event)\"\n          [value]=\"valueSignal()\"\n          [inputClass]=\"inputClassSignal()\"\n          [disabled]=\"disabledSignal()\"\n          [max]=\"maxSignal()\"\n          [min]=\"minSignal()\"\n          [valid]=\"validSignal()\"\n          [invalid]=\"invalidSignal()\"\n          [showValidation]=\"showValidationSignal()\" />\n      </ng-template>\n      @switch (typeSignal()) {\n        <!-- DATE -->\n        @case ('date') {\n          <ng-container *ngTemplateOutlet=\"date\" />\n        }\n        <!-- DATETIME-LOCAL -->\n        @case ('datetime-local') {\n          <ng-container *ngTemplateOutlet=\"date\" />\n        }\n        <!-- CHECKBOX -->\n        @case ('checkbox') {\n          <input\n            type=\"checkbox\"\n            [id]=\"idSignal()\"\n            [formControlName]=\"nameStrSignal()\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [attr.data-debug]=\"debug()\"\n            class=\"{{ inpClSignal() }} d-inline-block form-control width-unset\"\n            placeholder=\"{{ placeholder() }}\"\n            [required]=\"requiredSignal()\"\n            [readonly]=\"readonlySignal()\"\n            (change)=\"change($event)\"\n            [checked]=\"checkedSignal()\"\n            [attr.indeterminate]=\"indeterminate\" />\n        }\n        @case ('checkedbox') {\n          <input\n            type=\"checkbox\"\n            class=\"{{ inpClSignal() }} d-inline-block form-control width-unset\"\n            [checked]=\"checkedSignal()\"\n            [attr.data-debug]=\"debug()\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [required]=\"requiredSignal()\"\n            [readonly]=\"readonlySignal()\"\n            (change)=\"change($event)\" />\n        }\n        <!-- FILE -->\n        @case ('file') {\n          <input type=\"file\" [id]=\"idSignal()\" [class]=\"inputClassSignal()\" (change)=\"upload($event)\" [accept]=\"accept\" [attr.multiple]=\"multiple\" />\n        }\n        <!-- FILE BUTTON-->\n        @case ('fileButton') {\n          <input\n            type=\"file\"\n            [id]=\"idSignal()\"\n            [class]=\"inputClassSignal()\"\n            (change)=\"upload($event)\"\n            [accept]=\"accept\"\n            [attr.multiple]=\"multiple\"\n            hidden\n            #file />\n          <app-btn\n            class=\"w-100\"\n            (mclick)=\"file.click()\"\n            icon=\"upload\"\n            [type]=\"files ? 'primary' : 'secondary'\"\n            text=\"{{ placeholder() || labelSignal() || 'Upload' }}\"></app-btn>\n        }\n        <!-- SELECT -->\n        @case ('select') {\n          <!-- [attr.disabled]=\"disabled\" -->\n          <mat-select\n            #matSelectTag\n            placeholder=\"{{ placeholder() }}\"\n            formControlName=\"{{ nameStrSignal() }}\"\n            [id]=\"idSignal()\"\n            class=\"{{ cls() }} {{ inputClassSignal() }}\"\n            [required]=\"requiredSignal()\"\n            (selectionChange)=\"change({ target: $event })\">\n            @if (showEmptyOptionSignal()) {\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        <!-- TEXTAREA -->\n        @case ('textarea') {\n          <textarea\n            [formControlName]=\"nameStrSignal()\"\n            [id]=\"idSignal()\"\n            [class]=\"inputClassSignal()\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [rows]=\"textareaRowsSignal()\"\n            [required]=\"requiredSignal()\"\n            [readonly]=\"readonlySignal()\"\n            (change)=\"change($event)\"></textarea>\n        }\n        <!-- Radio -->\n        @case ('radio') {\n          <input\n            type=\"radio\"\n            [formControlName]=\"nameStrSignal()\"\n            [id]=\"idSignal()\"\n            [readonly]=\"readonlySignal()\"\n            (change)=\"change($event)\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [value]=\"valueSignal()\" />\n        }\n        <!-- Viewer -->\n        @case ('viewer') {\n          <input\n            type=\"text\"\n            [id]=\"idSignal()\"\n            placeholder=\"{{ placeholder() }}\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [class]=\"inputClassSignal()\"\n            [readonly]=\"true\"\n            [value]=\"valueSignal()\" />\n        }\n        <!-- PASSWORD -->\n        @case ('password') {\n          <input\n            type=\"{{ showPasswordSignal() ? 'text' : 'password' }}\"\n            [formControlName]=\"nameStrSignal()\"\n            placeholder=\"{{ placeholder() }}\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [id]=\"idSignal()\"\n            [class]=\"inputClassSignal()\"\n            [required]=\"requiredSignal()\"\n            [max]=\"maxSignal()\"\n            [min]=\"minSignal()\"\n            [readonly]=\"readonlySignal()\"\n            (change)=\"change($event)\"\n            [value]=\"valueSignal()\" />\n          <div class=\"password-icons pointer\" (click)=\"showPasswordSignal.set(!showPasswordSignal)\">\n            @if (showPasswordSignal()) {\n              <i class=\"fa fa-eye-slash\"></i>\n            }\n            @if (!showPasswordSignal()) {\n              <i class=\"fa fa-eye\"></i>\n            }\n          </div>\n        }\n        <!-- DEFAULT -->\n        @default {\n          <div [class]=\"inputClassSignal()\" [ngClass]=\"{ 'has-prefix': !!prefixSignal(), disabled: readonlySignal() || disabledSignal() }\">\n            @if (prefixSignal()) {\n              <div class=\"prefix-val\" #prefixVal>\n                {{ prefixSignal() }}\n              </div>\n            }\n            <input\n              [type]=\"typeSignal()\"\n              [formControlName]=\"nameStrSignal()\"\n              placeholder=\"{{ placeholder() }}\"\n              [id]=\"idSignal()\"\n              [matTooltip]=\"ele.innerText\"\n              [matTooltipDisabled]=\"ele.scrollWidth <= ele.offsetWidth\"\n              #ele\n              [attr.data-debug]=\"debug()\"\n              [attr.data-noformat]=\"computedNoFormat()\"\n              [attr.data-otype]=\"oTypeSignal()\"\n              [required]=\"requiredSignal()\"\n              [max]=\"maxSignal()\"\n              [min]=\"minSignal()\"\n              [readonly]=\"readonlySignal()\"\n              (change)=\"change($event)\"\n              [value]=\"valueSignal()\" />\n          </div>\n        }\n      }\n\n      @if (dirtySignal() && (showValidationSignal() || showValidationIconSignal())) {\n        <div [ngClass]=\"{ valid: validSignal() }\" class=\"validity-icon\">\n          <i class=\"fa fa-check\"></i>\n        </div>\n        <div [ngClass]=\"{ pending: pendingSignal() }\" class=\"validity-icon\">\n          <i class=\"fa fa-spinner fa-spin\"></i>\n        </div>\n        <div [ngClass]=\"{ invalid: invalidSignal() }\" class=\"validity-icon\">\n          <i class=\"fa fa-times\"></i>\n        </div>\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 (endLabelSignal()) {\n      <div class=\"col-auto text-primary ms-2\" (click)=\"iS.log(formSignal())\" [matTooltip]=\"endLabelTooltipSignal() | appTranslate | async\">\n        {{ endLabelSignal() | appTranslate | async }}\n      </div>\n    }\n  </div>\n</div>\n@if (showValidationMsgSignal()) {\n  <app-validation-message [label]=\"labelSignal()\" [control]=\"controlSignal()\" />\n}\n"]}
|
|
180
|
+
//# 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, computed, effect, inject, input, signal } 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('input') inp: FCInput;\n  @Input() contextData: any;\n  @Input() decimalPoints: number;\n  @Input() files: File[];\n  @Input() hide: boolean;\n  @Input() hint: string | number;\n\n  @Input() labelLink: string;\n  @Input() lblCl: string = '2';\n  @Input() light: boolean = true;\n  @Input() loading: boolean;\n  @Input() minLength: number;\n  @Input() maxLength: number;\n  @Input() multiple: boolean;\n  @Input() optionsFunc: (...val: any) => Observable<any[]>;\n  @Input() theme: InputTheme = 1;\n  @Input() vms: IValidationMessage[];\n  @Input() xsmall: boolean;\n  @Output() mSelectOptionChange = new EventEmitter<TOption>();\n  @Output() mSelectedOptionLabel = new EventEmitter<string>();\n  options$ = new ReplaySubject<IOption[]>();\n  viewInited: boolean;\n  forcePatched: boolean;\n  selectionObjectSignal = computed<TOption>(() => {\n    const value = this.valueSignal(),\n      options = this.rawOptionsSignal();\n    return (options || []).find((x) => x[this.valueField] == value);\n  });\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('options') set _options(v: TOption[] | null) {\n    if (this.debug()) debugger;\n    this.rawOptionsSignal.set(v || []);\n    this.options$.next(this.options());\n  }\n  @Input('mvalue') set _value(v: string | number) {\n    this.valueSignal.set(v);\n  }\n  @ViewChild('matSelectTag') matSelect: MatSelect;\n\n  constructor() {\n    super();\n    effect(() => {\n      if (this.typeSignal() == 'select') {\n        this.control.formattedValue = (<MatOption>this.matSelect?.selected)?.viewValue;\n        this.mSelectedOptionLabel.emit((<MatOption>this.matSelect?.selected)?.viewValue);\n      }\n    });\n  }\n\n  ngOnInit(): void {\n    if (this.autoPickValueField) {\n      if (!this.labelType) this.labelType = 'cdt';\n      if (!this.valueField) this.valueField = 'code' as any;\n    }\n    if (this.minSignal() == 0 && this.maxSignal() == 100) this.oTypeSignal.set('percentage');\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\n  ngAfterViewInit(): void {\n    // this.viewInited = true;\n  }\n\n  disableControl(control: AbstractControl = this.control) {\n    if (!this.disabledSignal()) return;\n    control?.disable({ emitEvent: false });\n  }\n\n  change(e: { target: { checked?: boolean; value: any } } | Event) {\n    // debugger;\n    if (this.debug()) debugger;\n    let val;\n    if (this.typeSignal() == 'checkbox') {\n      val = e.target?.['checked'];\n      this.control.setValue(e.target?.['checked']);\n    } else val = this.control?.value;\n    if (this.typeSignal() == 'number') {\n      // debugger;\n      if (this.oTypeSignal() == 'percentage' && !this.maxSignal()) {\n        this.maxSignal.set(100);\n        this.minSignal.set(0);\n      }\n      if (val != null && val != '') {\n        // debugger;\n        if (this.maxSignal() && +val > +this.maxSignal()) this.control.setValue(this.maxSignal());\n        else if (this.minSignal() != null && this.minSignal() != undefined && +val < +this.minSignal()) this.control.setValue(this.minSignal());\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.typeSignal() == 'number'\n          ? +this.control?.value?.toString().slice(0, this.maxLength)\n          : this.control?.value?.toString().slice(0, this.maxLength),\n      );\n    this.valueSignal.set(this.control.value);\n    this.mchange.emit(this.control.value);\n\n    this.mSelectOptionChange.emit(this.selectionObjectSignal());\n  }\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 {{ typeSignal() }} gx-1\" [formGroup]=\"formSignal()\" [ngClass]=\"{ 'd-flex': !stackedSignal() }\">\n  @if (computedShowLabel()) {\n    <app-input-label\n      [colored]=\"coloredSignal()\"\n      [form]=\"formSignal()\"\n      [hint]=\"hint\"\n      [id]=\"idSignal()\"\n      [invalidCheckbox]=\"invalidCheckboxSignal()\"\n      [isRequired]=\"isRequiredSignal()\"\n      [label]=\"labelSignal()\"\n      [lblCl]=\"lblCl\"\n      [light]=\"light\"\n      [mini]=\"miniSignal()\"\n      [ngClass]=\"{ 'w-100': stackedSignal() }\"\n      [inlineHint]=\"inlineHint\"\n      [showRequiredTag]=\"showRequiredTagSignal()\"\n      [showLabel]=\"showLabelSignal()\"\n      [small]=\"smallSignal()\"\n      [stacked]=\"stackedSignal()\"\n      [theme]=\"theme\"\n      [xsmall]=\"xsmall\"></app-input-label>\n  }\n  <div class=\"d-flex align-items-center {{ inputContClassSignal() }} \">\n    <div\n      class=\"position-relative d-flex input-content w-100\"\n      [ngClass]=\"{\n        'ms-2': !stackedSignal(),\n        showValidationIcon: showValidationSignal() || showValidationIconSignal(),\n        dontFormatAsInput: dontFormatAsInputSignal()\n      }\">\n      <ng-template #date>\n        <date-input\n          #dateInput\n          [debug]=\"debug()\"\n          [readonly]=\"readonlySignal()\"\n          [id]=\"idSignal()\"\n          class=\"w-100\"\n          [type]=\"typeSignal()\"\n          (valueChanged)=\"dateChanged($event)\"\n          [value]=\"valueSignal()\"\n          [inputClass]=\"inputClassSignal()\"\n          [disabled]=\"disabledSignal()\"\n          [max]=\"maxSignal()\"\n          [min]=\"minSignal()\"\n          [valid]=\"validSignal()\"\n          [invalid]=\"invalidSignal()\"\n          [showValidation]=\"showValidationSignal()\" />\n      </ng-template>\n      @switch (typeSignal()) {\n        <!-- DATE -->\n        @case ('date') {\n          <ng-container *ngTemplateOutlet=\"date\" />\n        }\n        <!-- DATETIME-LOCAL -->\n        @case ('datetime-local') {\n          <ng-container *ngTemplateOutlet=\"date\" />\n        }\n        <!-- CHECKBOX -->\n        @case ('checkbox') {\n          <input\n            type=\"checkbox\"\n            [id]=\"idSignal()\"\n            [formControlName]=\"nameStrSignal()\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [attr.data-debug]=\"debug()\"\n            class=\"{{ inpClSignal() }} d-inline-block form-control width-unset\"\n            placeholder=\"{{ placeholder() }}\"\n            [required]=\"requiredSignal()\"\n            [readonly]=\"readonlySignal()\"\n            (change)=\"change($event)\"\n            [checked]=\"checkedSignal()\"\n            [attr.indeterminate]=\"indeterminate\" />\n        }\n        @case ('checkedbox') {\n          <input\n            type=\"checkbox\"\n            class=\"{{ inpClSignal() }} d-inline-block form-control width-unset\"\n            [checked]=\"checkedSignal()\"\n            [attr.data-debug]=\"debug()\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [required]=\"requiredSignal()\"\n            [readonly]=\"readonlySignal()\"\n            (change)=\"change($event)\" />\n        }\n        <!-- FILE -->\n        @case ('file') {\n          <input type=\"file\" [id]=\"idSignal()\" [class]=\"inputClassSignal()\" (change)=\"upload($event)\" [accept]=\"accept\" [attr.multiple]=\"multiple\" />\n        }\n        <!-- FILE BUTTON-->\n        @case ('fileButton') {\n          <input\n            type=\"file\"\n            [id]=\"idSignal()\"\n            [class]=\"inputClassSignal()\"\n            (change)=\"upload($event)\"\n            [accept]=\"accept\"\n            [attr.multiple]=\"multiple\"\n            hidden\n            #file />\n          <app-btn\n            class=\"w-100\"\n            (mclick)=\"file.click()\"\n            icon=\"upload\"\n            [type]=\"files ? 'primary' : 'secondary'\"\n            text=\"{{ placeholder() || labelSignal() || 'Upload' }}\"></app-btn>\n        }\n        <!-- SELECT -->\n        @case ('select') {\n          <!-- [attr.disabled]=\"disabled\" -->\n          <mat-select\n            #matSelectTag\n            placeholder=\"{{ placeholder() }}\"\n            formControlName=\"{{ nameStrSignal() }}\"\n            [id]=\"idSignal()\"\n            class=\"{{ cls() }} {{ inputClassSignal() }}\"\n            [required]=\"requiredSignal()\"\n            (selectionChange)=\"change({ target: $event })\">\n            @if (showEmptyOptionSignal()) {\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        <!-- TEXTAREA -->\n        @case ('textarea') {\n          <textarea\n            [formControlName]=\"nameStrSignal()\"\n            [id]=\"idSignal()\"\n            [class]=\"inputClassSignal()\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [rows]=\"textareaRowsSignal()\"\n            [required]=\"requiredSignal()\"\n            [readonly]=\"readonlySignal()\"\n            (change)=\"change($event)\"></textarea>\n        }\n        <!-- Radio -->\n        @case ('radio') {\n          <input\n            type=\"radio\"\n            [formControlName]=\"nameStrSignal()\"\n            [id]=\"idSignal()\"\n            [readonly]=\"readonlySignal()\"\n            (change)=\"change($event)\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [value]=\"valueSignal()\" />\n        }\n        <!-- Viewer -->\n        @case ('viewer') {\n          <input\n            type=\"text\"\n            [id]=\"idSignal()\"\n            placeholder=\"{{ placeholder() }}\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [class]=\"inputClassSignal()\"\n            [readonly]=\"true\"\n            [value]=\"valueSignal()\" />\n        }\n        <!-- PASSWORD -->\n        @case ('password') {\n          <input\n            type=\"{{ showPasswordSignal() ? 'text' : 'password' }}\"\n            [formControlName]=\"nameStrSignal()\"\n            placeholder=\"{{ placeholder() }}\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [id]=\"idSignal()\"\n            [class]=\"inputClassSignal()\"\n            [required]=\"requiredSignal()\"\n            [max]=\"maxSignal()\"\n            [min]=\"minSignal()\"\n            [readonly]=\"readonlySignal()\"\n            (change)=\"change($event)\"\n            [value]=\"valueSignal()\" />\n          <div class=\"password-icons pointer\" (click)=\"showPasswordSignal.set(!showPasswordSignal)\">\n            @if (showPasswordSignal()) {\n              <i class=\"fa fa-eye-slash\"></i>\n            }\n            @if (!showPasswordSignal()) {\n              <i class=\"fa fa-eye\"></i>\n            }\n          </div>\n        }\n        <!-- DEFAULT -->\n        @default {\n          <div [class]=\"inputClassSignal()\" [ngClass]=\"{ 'has-prefix': !!prefixSignal(), disabled: readonlySignal() || disabledSignal() }\">\n            @if (prefixSignal()) {\n              <div class=\"prefix-val\" #prefixVal>\n                {{ prefixSignal() }}\n              </div>\n            }\n            <input\n              [type]=\"typeSignal()\"\n              [formControlName]=\"nameStrSignal()\"\n              placeholder=\"{{ placeholder() }}\"\n              [id]=\"idSignal()\"\n              [matTooltip]=\"ele.innerText\"\n              [matTooltipDisabled]=\"ele.scrollWidth <= ele.offsetWidth\"\n              #ele\n              [attr.data-debug]=\"debug()\"\n              [attr.data-noformat]=\"computedNoFormat()\"\n              [attr.data-otype]=\"oTypeSignal()\"\n              [required]=\"requiredSignal()\"\n              [max]=\"maxSignal()\"\n              [min]=\"minSignal()\"\n              [readonly]=\"readonlySignal()\"\n              (change)=\"change($event)\"\n              [value]=\"valueSignal()\" />\n          </div>\n        }\n      }\n\n      @if (dirtySignal() && (showValidationSignal() || showValidationIconSignal())) {\n        <div [ngClass]=\"{ valid: validSignal() }\" class=\"validity-icon\">\n          <i class=\"fa fa-check\"></i>\n        </div>\n        <div [ngClass]=\"{ pending: pendingSignal() }\" class=\"validity-icon\">\n          <i class=\"fa fa-spinner fa-spin\"></i>\n        </div>\n        <div [ngClass]=\"{ invalid: invalidSignal() }\" class=\"validity-icon\">\n          <i class=\"fa fa-times\"></i>\n        </div>\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 (endLabelSignal()) {\n      <div class=\"col-auto text-primary ms-2\" (click)=\"iS.log(formSignal())\" [matTooltip]=\"endLabelTooltipSignal() | appTranslate | async\">\n        {{ endLabelSignal() | appTranslate | async }}\n      </div>\n    }\n  </div>\n</div>\n@if (showValidationMsgSignal()) {\n  <app-validation-message [label]=\"labelSignal()\" [control]=\"controlSignal()\" />\n}\n"]}
|
|
@@ -6255,7 +6255,7 @@ class InputBasicComponent extends InputBase {
|
|
|
6255
6255
|
this.control.setValue(e.target?.['checked']);
|
|
6256
6256
|
}
|
|
6257
6257
|
else
|
|
6258
|
-
val =
|
|
6258
|
+
val = this.control?.value;
|
|
6259
6259
|
if (this.typeSignal() == 'number') {
|
|
6260
6260
|
// debugger;
|
|
6261
6261
|
if (this.oTypeSignal() == 'percentage' && !this.maxSignal()) {
|