ets-fe-ng-sdk 17.0.411 → 17.0.412
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-td-rf.component.mjs +6 -10
- package/fesm2022/ets-fe-ng-sdk.mjs +4 -8
- package/fesm2022/ets-fe-ng-sdk.mjs.map +1 -1
- package/lib/Services/utility.service.d.ts +1 -1
- package/lib/Shared/components/index-comp-layout/index-comp-layout.component.d.ts +1 -1
- package/lib/Shared/components/info-dialog/info-dialog.component.d.ts +1 -1
- package/lib/Shared/components/table-https/table-https.component.d.ts +3 -3
- package/package.json +1 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
2
|
import { FormControl, FormGroup } from '@angular/forms';
|
|
3
3
|
import { InputBasicComponent } from './input-basic.component';
|
|
4
4
|
import { InputProviders, InputSharedModules } from './input-shared.module';
|
|
@@ -50,16 +50,15 @@ export class InputTD_RFComponent extends InputBasicComponent {
|
|
|
50
50
|
// super._type = v;
|
|
51
51
|
// if (v == 'percentage') this.oType = 'number';
|
|
52
52
|
// }
|
|
53
|
-
this.valueChanges2 = toObservable(this.valueSignal)
|
|
54
|
-
// .pipe(debounceTime(100))
|
|
55
|
-
.subscribe((r) => {
|
|
53
|
+
this.valueChanges2 = toObservable(this.valueSignal).subscribe((r) => {
|
|
56
54
|
// debugger;
|
|
55
|
+
this.model = r;
|
|
56
|
+
if (this.debug())
|
|
57
|
+
debugger;
|
|
57
58
|
this.modelChange.emit(r);
|
|
58
59
|
this.disableControl();
|
|
59
60
|
});
|
|
60
61
|
this.name.set('item');
|
|
61
|
-
// effect(()=>{
|
|
62
|
-
// })
|
|
63
62
|
}
|
|
64
63
|
ngOnInit() {
|
|
65
64
|
super.ngOnInit();
|
|
@@ -69,9 +68,6 @@ export class InputTD_RFComponent extends InputBasicComponent {
|
|
|
69
68
|
item: new FormControl(this.model, this.validators, this.asyncValidators),
|
|
70
69
|
}));
|
|
71
70
|
this.disableControl();
|
|
72
|
-
// this.control?.statusChanges.subscribe((r) => {
|
|
73
|
-
// if (this.debug) debugger;
|
|
74
|
-
// });
|
|
75
71
|
}
|
|
76
72
|
ngOnChanges(changes) {
|
|
77
73
|
if (this.name() != 'item') {
|
|
@@ -100,4 +96,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImpor
|
|
|
100
96
|
}], modelChange: [{
|
|
101
97
|
type: Output
|
|
102
98
|
}] } });
|
|
103
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-td-rf.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/input/input-td-rf.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  Output,\n  SimpleChanges,\n  effect,\n  signal,\n} from '@angular/core';\nimport { AsyncValidatorFn, FormControl, FormGroup, ValidatorFn } from '@angular/forms';\nimport { InputBasicComponent } from './input-basic.component';\nimport { InputProviders, InputSharedModules } from './input-shared.module';\nimport { DateInputComponent } from './date-input/date-input.component';\nimport { debounceTime } from 'rxjs';\nimport { cloneDeep } from 'lodash-es';\nimport { toObservable } from '@angular/core/rxjs-interop';\n\n@Component({\n  selector: 'app-input-td-rf',\n  templateUrl: './input.component.html',\n  styleUrls: ['./input.component.scss'],\n  standalone: true,\n  providers: InputProviders,\n  imports: [DateInputComponent, InputSharedModules],\n})\nexport class InputTD_RFComponent<TOption = any> extends InputBasicComponent<any, any, TOption> {\n  validators: ValidatorFn[];\n  @Input('validators') set _validators(v: ValidatorFn[]) {\n    this.control()?.removeValidators(this.validators);\n    this.validators = v;\n    this.control()?.setValidators(v);\n    this.control()?.updateValueAndValidity();\n  }\n\n  asyncValidators: AsyncValidatorFn[];\n  @Input('asyncValidators') set _asyncValidators(v: AsyncValidatorFn[]) {\n    this.control()?.removeValidators(this.asyncValidators);\n    this.asyncValidators = v;\n    this.control()?.setValidators(v);\n    this.control()?.updateValueAndValidity();\n  }\n\n  private model: any;\n  @Input('model') set _model(v: any) {\n    if (v == this.model) return;\n    this.model = v;\n    if (this.debug()) debugger;\n    this.control()?.enable();\n    this.control()?.patchValue(v);\n    if (this.disabledSignal()) this.control()?.disable();\n  }\n  @Output() modelChange = new EventEmitter();\n\n  // @Input('type') set _type(v: InputType) {\n  //   super._type = v;\n  //   if (v == 'percentage') this.oType = 'number';\n  // }\n\n  protected valueChanges2 = toObservable(this.valueSignal)\n    // .pipe(debounceTime(100))\n    .subscribe((r) => {\n      // debugger;\n      this.modelChange.emit(r);\n      this.disableControl();\n    });\n  constructor() {\n    super();\n    this.name.set('item');\n    // effect(()=>{\n\n    // })\n  }\n\n  override ngOnInit(): void {\n    super.ngOnInit();\n    if (this.debug()) debugger;\n    this.form.set(\n      new FormGroup({\n        item: new FormControl(this.model, this.validators, this.asyncValidators),\n      }),\n    );\n    this.disableControl();\n    // this.control?.statusChanges.subscribe((r) => {\n    //   if (this.debug) debugger;\n    // });\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.name() != 'item') {\n      // debugger;\n      this.name.set('item');\n    }\n  }\n\n  override ngAfterViewInit() {\n    super.ngAfterViewInit();\n  }\n}\n","<!-- <div>form().getRawValue: {{ff}}</div> -->\n@if (verbose()) {\n  <div>disabledSignal: {{ disabledSignal() }}</div>\n  <div>validSignal: {{ validSignal() }}</div>\n  <div>invalidSignal: {{ invalidSignal() }}</div>\n  <div>valueSignal: {{ valueSignal() }}</div>\n  <div>hasValue: {{ hasValue() }}</div>\n  <div>dirtySignal: {{ dirtySignal() }}</div>\n  <div>touchedSignal: {{ touchedSignal() }}</div>\n  <div>errorsSignal: {{ errorsSignaljson() }}</div>\n  <div>pendingSignal: {{ pendingSignal() }}</div>\n  <div>requiredSignal: {{ requiredSignal() }}</div>\n  <div>pristineSignal: {{ pristineSignal() }}</div>\n  <div>controlRequiredSignal: {{ controlRequiredSignal() }}</div>\n  <div>isRequiredSignal: {{ isRequiredSignal() }}</div>\n  <div class=\"\">onControlObtainedList Length: {{ onControlObtainedList().length }}</div>\n}\n<div\n  class=\"  custom-input align-items-center {{ typeSignal() }} gx-1\"\n  [formGroup]=\"form() | toAny\"\n  [ngClass]=\"{ 'd-flex': !stackedSignal() }\">\n  @if (computedShowLabel()) {\n    <app-input-label\n      [colored]=\"coloredSignal()\"\n      [form]=\"form()\"\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\n            type=\"file\"\n            [id]=\"idSignal()\"\n            [class]=\"inputClassSignal()\"\n            (change)=\"upload($event)\"\n            [accept]=\"accept\"\n            [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\" (onSelectionChange)=\"selectedOption(item)\">\n                <div\n                  class=\"option\"\n                  [matTooltip]=\"item.label\"\n                  [matTooltipShowDelay]=\"1000\"\n                  [matTooltipDisabled]=\"ele.scrollWidth <= ele.offsetWidth\"\n                  #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\n            class=\"password-icons pointer\"\n            (click)=\"showPasswordSignal.set(!showPasswordSignal())\">\n            @if (showPasswordSignal()) {\n              <i class=\"fa fa-eye-slash\"></i>\n            } @else {\n              <i class=\"fa fa-eye\"></i>\n            }\n          </div>\n        }\n        <!-- DEFAULT -->\n        @default {\n          <div\n            [class]=\"inputClassSignal()\"\n            [ngClass]=\"{\n              'has-prefix': !!prefixSignal(),\n              disabled: readonlySignal() || disabledSignal()\n            }\">\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          </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\n        class=\"col-auto text-primary ms-2\"\n        (click)=\"iS.log(form())\"\n        [matTooltip]=\"endLabelTooltipSignal() | appTranslate | async\">\n        {{ endLabelSignal() | appTranslate | async }}\n      </div>\n    }\n  </div>\n</div>\n@if (showValidationMsgSignal()) {\n  <app-validation-message\n    [label]=\"labelSignal()\"\n    [minLength]=\"minLength\"\n    [maxLength]=\"maxLength\"\n    [control]=\"control()\" />\n}\n"]}
|
|
99
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-td-rf.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/input/input-td-rf.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, Output, SimpleChanges } from '@angular/core';\nimport { AsyncValidatorFn, FormControl, FormGroup, ValidatorFn } from '@angular/forms';\nimport { InputBasicComponent } from './input-basic.component';\nimport { InputProviders, InputSharedModules } from './input-shared.module';\nimport { DateInputComponent } from './date-input/date-input.component';\nimport { toObservable } from '@angular/core/rxjs-interop';\n\n@Component({\n  selector: 'app-input-td-rf',\n  templateUrl: './input.component.html',\n  styleUrls: ['./input.component.scss'],\n  standalone: true,\n  providers: InputProviders,\n  imports: [DateInputComponent, InputSharedModules],\n})\nexport class InputTD_RFComponent<TOption = any> extends InputBasicComponent<any, any, TOption> {\n  validators: ValidatorFn[];\n  @Input('validators') set _validators(v: ValidatorFn[]) {\n    this.control()?.removeValidators(this.validators);\n    this.validators = v;\n    this.control()?.setValidators(v);\n    this.control()?.updateValueAndValidity();\n  }\n\n  asyncValidators: AsyncValidatorFn[];\n  @Input('asyncValidators') set _asyncValidators(v: AsyncValidatorFn[]) {\n    this.control()?.removeValidators(this.asyncValidators);\n    this.asyncValidators = v;\n    this.control()?.setValidators(v);\n    this.control()?.updateValueAndValidity();\n  }\n\n  private model: any;\n  @Input('model') set _model(v: any) {\n    if (v == this.model) return;\n    this.model = v;\n    if (this.debug()) debugger;\n    this.control()?.enable();\n    this.control()?.patchValue(v);\n    if (this.disabledSignal()) this.control()?.disable();\n  }\n  @Output() modelChange = new EventEmitter();\n\n  // @Input('type') set _type(v: InputType) {\n  //   super._type = v;\n  //   if (v == 'percentage') this.oType = 'number';\n  // }\n\n  protected valueChanges2 = toObservable(this.valueSignal).subscribe((r) => {\n    // debugger;\n    this.model = r;\n    if (this.debug()) debugger;\n    this.modelChange.emit(r);\n    this.disableControl();\n  });\n\n  constructor() {\n    super();\n    this.name.set('item');\n  }\n\n  override ngOnInit(): void {\n    super.ngOnInit();\n    if (this.debug()) debugger;\n    this.form.set(\n      new FormGroup({\n        item: new FormControl(this.model, this.validators, this.asyncValidators),\n      }),\n    );\n    this.disableControl();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.name() != 'item') {\n      // debugger;\n      this.name.set('item');\n    }\n  }\n\n  override ngAfterViewInit() {\n    super.ngAfterViewInit();\n  }\n}\n","<!-- <div>form().getRawValue: {{ff}}</div> -->\n@if (verbose()) {\n  <div>disabledSignal: {{ disabledSignal() }}</div>\n  <div>validSignal: {{ validSignal() }}</div>\n  <div>invalidSignal: {{ invalidSignal() }}</div>\n  <div>valueSignal: {{ valueSignal() }}</div>\n  <div>hasValue: {{ hasValue() }}</div>\n  <div>dirtySignal: {{ dirtySignal() }}</div>\n  <div>touchedSignal: {{ touchedSignal() }}</div>\n  <div>errorsSignal: {{ errorsSignaljson() }}</div>\n  <div>pendingSignal: {{ pendingSignal() }}</div>\n  <div>requiredSignal: {{ requiredSignal() }}</div>\n  <div>pristineSignal: {{ pristineSignal() }}</div>\n  <div>controlRequiredSignal: {{ controlRequiredSignal() }}</div>\n  <div>isRequiredSignal: {{ isRequiredSignal() }}</div>\n  <div class=\"\">onControlObtainedList Length: {{ onControlObtainedList().length }}</div>\n}\n<div\n  class=\"  custom-input align-items-center {{ typeSignal() }} gx-1\"\n  [formGroup]=\"form() | toAny\"\n  [ngClass]=\"{ 'd-flex': !stackedSignal() }\">\n  @if (computedShowLabel()) {\n    <app-input-label\n      [colored]=\"coloredSignal()\"\n      [form]=\"form()\"\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\n            type=\"file\"\n            [id]=\"idSignal()\"\n            [class]=\"inputClassSignal()\"\n            (change)=\"upload($event)\"\n            [accept]=\"accept\"\n            [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\" (onSelectionChange)=\"selectedOption(item)\">\n                <div\n                  class=\"option\"\n                  [matTooltip]=\"item.label\"\n                  [matTooltipShowDelay]=\"1000\"\n                  [matTooltipDisabled]=\"ele.scrollWidth <= ele.offsetWidth\"\n                  #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\n            class=\"password-icons pointer\"\n            (click)=\"showPasswordSignal.set(!showPasswordSignal())\">\n            @if (showPasswordSignal()) {\n              <i class=\"fa fa-eye-slash\"></i>\n            } @else {\n              <i class=\"fa fa-eye\"></i>\n            }\n          </div>\n        }\n        <!-- DEFAULT -->\n        @default {\n          <div\n            [class]=\"inputClassSignal()\"\n            [ngClass]=\"{\n              'has-prefix': !!prefixSignal(),\n              disabled: readonlySignal() || disabledSignal()\n            }\">\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          </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\n        class=\"col-auto text-primary ms-2\"\n        (click)=\"iS.log(form())\"\n        [matTooltip]=\"endLabelTooltipSignal() | appTranslate | async\">\n        {{ endLabelSignal() | appTranslate | async }}\n      </div>\n    }\n  </div>\n</div>\n@if (showValidationMsgSignal()) {\n  <app-validation-message\n    [label]=\"labelSignal()\"\n    [minLength]=\"minLength\"\n    [maxLength]=\"maxLength\"\n    [control]=\"control()\" />\n}\n"]}
|
|
@@ -6497,16 +6497,15 @@ class InputTD_RFComponent extends InputBasicComponent {
|
|
|
6497
6497
|
// super._type = v;
|
|
6498
6498
|
// if (v == 'percentage') this.oType = 'number';
|
|
6499
6499
|
// }
|
|
6500
|
-
this.valueChanges2 = toObservable(this.valueSignal)
|
|
6501
|
-
// .pipe(debounceTime(100))
|
|
6502
|
-
.subscribe((r) => {
|
|
6500
|
+
this.valueChanges2 = toObservable(this.valueSignal).subscribe((r) => {
|
|
6503
6501
|
// debugger;
|
|
6502
|
+
this.model = r;
|
|
6503
|
+
if (this.debug())
|
|
6504
|
+
debugger;
|
|
6504
6505
|
this.modelChange.emit(r);
|
|
6505
6506
|
this.disableControl();
|
|
6506
6507
|
});
|
|
6507
6508
|
this.name.set('item');
|
|
6508
|
-
// effect(()=>{
|
|
6509
|
-
// })
|
|
6510
6509
|
}
|
|
6511
6510
|
ngOnInit() {
|
|
6512
6511
|
super.ngOnInit();
|
|
@@ -6516,9 +6515,6 @@ class InputTD_RFComponent extends InputBasicComponent {
|
|
|
6516
6515
|
item: new FormControl(this.model, this.validators, this.asyncValidators),
|
|
6517
6516
|
}));
|
|
6518
6517
|
this.disableControl();
|
|
6519
|
-
// this.control?.statusChanges.subscribe((r) => {
|
|
6520
|
-
// if (this.debug) debugger;
|
|
6521
|
-
// });
|
|
6522
6518
|
}
|
|
6523
6519
|
ngOnChanges(changes) {
|
|
6524
6520
|
if (this.name() != 'item') {
|