ets-fe-ng-sdk 18.0.8 → 18.0.10
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/autocomplete/autocomplete.service.mjs +3 -3
- package/esm2022/lib/Shared/components/input/input-basic.component.mjs +2 -2
- package/esm2022/lib/Shared/components/table-input/table-input.component.mjs +4 -4
- package/fesm2022/ets-fe-ng-sdk.mjs +6 -6
- package/fesm2022/ets-fe-ng-sdk.mjs.map +1 -1
- package/lib/Shared/components/btn/btn.component.d.ts +3 -3
- package/lib/Shared/components/form-generator/form-generated-value/form-generated-value.component.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/page-template/page-template.component.d.ts +1 -1
- package/lib/Shared/components/table-https/table-https.component.d.ts +3 -3
- package/lib/Shared/components/table-input/table-input.component.d.ts +1 -1
- package/lib/Shared/components/text-case-2/text-case-2.component.d.ts +1 -1
- package/package.json +1 -1
|
@@ -20,9 +20,9 @@ export class AutocompleteService {
|
|
|
20
20
|
if (filterValue) {
|
|
21
21
|
const res = [], resIncludes = [];
|
|
22
22
|
for (const option of options)
|
|
23
|
-
if (option._normalizedLabel
|
|
23
|
+
if (option._normalizedLabel?.startsWith(filterValue))
|
|
24
24
|
res.push(option);
|
|
25
|
-
else if (option._normalizedLabel
|
|
25
|
+
else if (option._normalizedLabel?.includes(filterValue))
|
|
26
26
|
resIncludes.push(option);
|
|
27
27
|
return res.concat(resIncludes);
|
|
28
28
|
}
|
|
@@ -41,4 +41,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
|
|
|
41
41
|
providedIn: 'root',
|
|
42
42
|
}]
|
|
43
43
|
}], ctorParameters: () => [{ type: i1.UtilityService }] });
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2NvbXBsZXRlLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ldHMtZmUtbmctc2RrL3NyYy9saWIvU2hhcmVkL2NvbXBvbmVudHMvYXV0b2NvbXBsZXRlL2F1dG9jb21wbGV0ZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQVEzQyxNQUFNLE9BQU8sbUJBQW1CO0lBRzlCLFlBQW1CLEVBQWtCO1FBQWxCLE9BQUUsR0FBRixFQUFFLENBQWdCO1FBRjVCLDBCQUFxQixHQUEwQixFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsQ0FBQztRQW1CMUUscUJBQWdCLEdBQUcsQ0FBQyxPQUFrQixFQUFFLEVBQUUsQ0FDeEMsT0FBTyxFQUFFLEdBQUcsQ0FBc0IsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUM7WUFDeEMsR0FBRyxDQUFDO1lBQ0osZ0JBQWdCLEVBQUUsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDO1lBQzlDLCtCQUErQjtTQUNoQyxDQUFDLENBQUMsQ0FBQztRQUNOLGdCQUFXLEdBQUcsQ0FBQyxPQUFjLEVBQUUsRUFBRSxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUU7WUFDeEMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxjQUFjLEVBQUUsT0FBTyxDQUFDLENBQUM7WUFDckMsT0FBTyxPQUFPLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsS0FBSyxJQUFJLEdBQUcsQ0FBQyxFQUFFLEtBQUssSUFBSSxHQUFHLENBQUM7UUFDNUQsQ0FBQyxDQUFDO0lBMUJzQyxDQUFDO0lBRXpDLGFBQWEsQ0FBeUMsS0FBYSxFQUFFLE9BQVk7UUFDL0UsTUFBTSxXQUFXLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMvQyxJQUFJLFdBQVcsRUFBRSxDQUFDO1lBQ2hCLE1BQU0sR0FBRyxHQUFRLEVBQUUsRUFDakIsV0FBVyxHQUFRLEVBQUUsQ0FBQztZQUN4QixLQUFLLE1BQU0sTUFBTSxJQUFJLE9BQU87Z0JBQzFCLElBQUksTUFBTSxDQUFDLGdCQUFnQixFQUFFLFVBQVUsQ0FBQyxXQUFXLENBQUM7b0JBQUUsR0FBRyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztxQkFDbEUsSUFBSSxNQUFNLENBQUMsZ0JBQWdCLEVBQUUsUUFBUSxDQUFDLFdBQVcsQ0FBQztvQkFBRSxXQUFXLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQ3BGLE9BQU8sR0FBRyxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUNqQyxDQUFDOztZQUFNLE9BQU8sT0FBTyxDQUFDO0lBQ3hCLENBQUM7SUFFRCxjQUFjLENBQUMsS0FBYTtRQUMxQixPQUFPLEtBQUssRUFBRSxRQUFRLEVBQUUsRUFBRSxXQUFXLEVBQUUsQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQzdELENBQUM7OEdBbkJVLG1CQUFtQjtrSEFBbkIsbUJBQW1CLGNBRmxCLE1BQU07OzJGQUVQLG1CQUFtQjtrQkFIL0IsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJT3B0aW9uIH0gZnJvbSAnLi4vaW5wdXQvaW5wdXQuc2VydmljZSc7XG5pbXBvcnQgeyBDdXN0b21WYWxpZGF0aW9uRXJyb3IgfSBmcm9tICcuLi8uLi9tb2RlbHMvaW5kZXgubW9kZWwnO1xuaW1wb3J0IHsgVXRpbGl0eVNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9TZXJ2aWNlcy91dGlsaXR5LnNlcnZpY2UnO1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgQXV0b2NvbXBsZXRlU2VydmljZSB7XG4gIHJlYWRvbmx5IGludmFsaWRTZWxlY3Rpb25FcnJvcjogQ3VzdG9tVmFsaWRhdGlvbkVycm9yID0geyBpbnZhbGlkOiB0cnVlIH07XG5cbiAgY29uc3RydWN0b3IocHVibGljIHVTOiBVdGlsaXR5U2VydmljZSkge31cblxuICBmaWx0ZXJPcHRpb25zPFQgZXh0ZW5kcyB7IF9ub3JtYWxpemVkTGFiZWw6IHN0cmluZyB9PihxdWVyeTogc3RyaW5nLCBvcHRpb25zOiBUW10pOiBUW10ge1xuICAgIGNvbnN0IGZpbHRlclZhbHVlID0gdGhpcy5ub3JtYWxpemVWYWx1ZShxdWVyeSk7XG4gICAgaWYgKGZpbHRlclZhbHVlKSB7XG4gICAgICBjb25zdCByZXM6IFRbXSA9IFtdLFxuICAgICAgICByZXNJbmNsdWRlczogVFtdID0gW107XG4gICAgICBmb3IgKGNvbnN0IG9wdGlvbiBvZiBvcHRpb25zKVxuICAgICAgICBpZiAob3B0aW9uLl9ub3JtYWxpemVkTGFiZWw/LnN0YXJ0c1dpdGgoZmlsdGVyVmFsdWUpKSByZXMucHVzaChvcHRpb24pO1xuICAgICAgICBlbHNlIGlmIChvcHRpb24uX25vcm1hbGl6ZWRMYWJlbD8uaW5jbHVkZXMoZmlsdGVyVmFsdWUpKSByZXNJbmNsdWRlcy5wdXNoKG9wdGlvbik7XG4gICAgICByZXR1cm4gcmVzLmNvbmNhdChyZXNJbmNsdWRlcyk7XG4gICAgfSBlbHNlIHJldHVybiBvcHRpb25zO1xuICB9XG5cbiAgbm9ybWFsaXplVmFsdWUodmFsdWU6IHN0cmluZyk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHZhbHVlPy50b1N0cmluZygpPy50b0xvd2VyQ2FzZSgpLnJlcGxhY2UoL1xccy9nLCAnJyk7XG4gIH1cbiAgbm9ybWFsaXplT3B0aW9ucyA9IChvcHRpb25zOiBJT3B0aW9uW10pID0+XG4gICAgb3B0aW9ucz8ubWFwPElBdXRvQ29tcGxldGVPcHRpb24+KCh4KSA9PiAoe1xuICAgICAgLi4ueCxcbiAgICAgIF9ub3JtYWxpemVkTGFiZWw6IHRoaXMubm9ybWFsaXplVmFsdWUoeC5sYWJlbCksXG4gICAgICAvLyBfaWQ6IHRoaXMudVMuZ2VuZXJhdGVVVUlEKCksXG4gICAgfSkpO1xuICBkaXNwbGF5V2l0aCA9IChvcHRpb25zOiBhbnlbXSkgPT4gKHZhbCkgPT4ge1xuICAgIGNvbnNvbGUubG9nKCd0aGlzLm9wdGlvbnMnLCBvcHRpb25zKTtcbiAgICByZXR1cm4gb3B0aW9ucz8uZmluZCgoeCkgPT4geC52YWx1ZSA9PSB2YWwpPy5sYWJlbCB8fCB2YWw7XG4gIH07XG59XG5leHBvcnQgaW50ZXJmYWNlIElBdXRvQ29tcGxldGVPcHRpb24gZXh0ZW5kcyBJT3B0aW9uIHtcbiAgX25vcm1hbGl6ZWRMYWJlbDogc3RyaW5nO1xufVxuIl19
|
|
@@ -27,7 +27,7 @@ export class InputBasicComponent extends InputBase {
|
|
|
27
27
|
set _options(v) {
|
|
28
28
|
if (this.debug())
|
|
29
29
|
debugger;
|
|
30
|
-
this.rawOptionsSignal.set(v || []);
|
|
30
|
+
this.rawOptionsSignal.set(v?.filter((x) => x != null) || []);
|
|
31
31
|
this.options$.next(this.options());
|
|
32
32
|
}
|
|
33
33
|
constructor() {
|
|
@@ -163,4 +163,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
|
|
|
163
163
|
type: ViewChild,
|
|
164
164
|
args: ['matSelectTag']
|
|
165
165
|
}] } });
|
|
166
|
-
//# 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  computed,\n  effect,\n  inject,\n  input,\n  signal,\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('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  override readonly clearOnDisable = input<boolean>(true);\n  @Input() labelLink: string;\n  @Input() lblCl: string = '2';\n  @Input() light: boolean = true;\n  @Input() loading: boolean;\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() mSelectedOptionLabel = new EventEmitter<string>();\n  options$ = new ReplaySubject<IOption[]>();\n  viewInited: boolean;\n  forcePatched: boolean;\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\n  @ViewChild('matSelectTag') matSelect: MatSelect;\n\n  constructor() {\n    super();\n    effect(() => {\n      if (this.setFormattedValue() && this.control() && 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()?.getRawValue();\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 (\n          this.minSignal() != null &&\n          this.minSignal() != undefined &&\n          +val < +this.minSignal()\n        )\n          this.control().setValue(this.minSignal());\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.typeSignal() == 'number'\n          ? +this.control()?.getRawValue()?.toString().slice(0, this.maxLength)\n          : this.control()?.getRawValue()?.toString().slice(0, this.maxLength),\n      );\n    this.mchange.emit(this.control()?.getRawValue());\n    // debugger\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>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 item._id) {\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"]}
|
|
166
|
+
//# 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  computed,\n  effect,\n  inject,\n  input,\n  signal,\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('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  override readonly clearOnDisable = input<boolean>(true);\n  @Input() labelLink: string;\n  @Input() lblCl: string = '2';\n  @Input() light: boolean = true;\n  @Input() loading: boolean;\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() mSelectedOptionLabel = new EventEmitter<string>();\n  options$ = new ReplaySubject<IOption[]>();\n  viewInited: boolean;\n  forcePatched: boolean;\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?.filter((x) => x != null) || []);\n    this.options$.next(this.options());\n  }\n\n  @ViewChild('matSelectTag') matSelect: MatSelect;\n\n  constructor() {\n    super();\n    effect(() => {\n      if (this.setFormattedValue() && this.control() && 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()?.getRawValue();\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 (\n          this.minSignal() != null &&\n          this.minSignal() != undefined &&\n          +val < +this.minSignal()\n        )\n          this.control().setValue(this.minSignal());\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.typeSignal() == 'number'\n          ? +this.control()?.getRawValue()?.toString().slice(0, this.maxLength)\n          : this.control()?.getRawValue()?.toString().slice(0, this.maxLength),\n      );\n    this.mchange.emit(this.control()?.getRawValue());\n    // debugger\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>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 item._id) {\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"]}
|
|
@@ -34,7 +34,7 @@ export class TableInputComponent extends FormGeneratorComponent {
|
|
|
34
34
|
this.pageSize = signal(10);
|
|
35
35
|
this.pageState = signal(null);
|
|
36
36
|
this.actionBtns = input();
|
|
37
|
-
this.tableClass = input();
|
|
37
|
+
this.tableClass = input('table table-responsive table-responsive table-borderless');
|
|
38
38
|
this.filterForm = new FormGroup({});
|
|
39
39
|
this.filterForms = signal([]);
|
|
40
40
|
this.usePaginator = signal(true);
|
|
@@ -174,7 +174,7 @@ export class TableInputComponent extends FormGeneratorComponent {
|
|
|
174
174
|
this.singleFormStructure?.controls[scheme.field]?.hasValidator(Validators.required);
|
|
175
175
|
}
|
|
176
176
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableInputComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
177
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: TableInputComponent, isStandalone: true, selector: "table-input", inputs: { formArray: { classPropertyName: "formArray", publicName: "formArray", isSignal: true, isRequired: false, transformFunction: null }, filterContainerClass: { classPropertyName: "filterContainerClass", publicName: "filterContainerClass", isSignal: true, isRequired: false, transformFunction: null }, border: { classPropertyName: "border", publicName: "border", isSignal: true, isRequired: false, transformFunction: null }, isShow: { classPropertyName: "isShow", publicName: "isShow", isSignal: true, isRequired: false, transformFunction: null }, _pageSize: { classPropertyName: "_pageSize", publicName: "pageSize", isSignal: false, isRequired: false, transformFunction: null }, actionBtns: { classPropertyName: "actionBtns", publicName: "actionBtns", isSignal: true, isRequired: false, transformFunction: null }, _formSchema: { classPropertyName: "_formSchema", publicName: "formSchema", isSignal: false, isRequired: true, transformFunction: null }, singleFormStructure: { classPropertyName: "singleFormStructure", publicName: "singleFormStructure", isSignal: false, isRequired: true, transformFunction: null }, deleteRowFunc: { classPropertyName: "deleteRowFunc", publicName: "deleteRowFunc", isSignal: false, isRequired: false, transformFunction: null }, addRowFunc: { classPropertyName: "addRowFunc", publicName: "addRowFunc", isSignal: false, isRequired: false, transformFunction: null }, _usePaginator: { classPropertyName: "_usePaginator", publicName: "usePaginator", isSignal: false, isRequired: false, transformFunction: null }, tableClass: { classPropertyName: "tableClass", publicName: "tableClass", isSignal: true, isRequired: false, transformFunction: null } }, providers: [FilterFormArrayGroupPipe, PaginatorPipe], viewQueries: [{ propertyName: "paginatorComponent", first: true, predicate: PaginatorComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"table-input\">\n @if (filterForms()?.length) {\n <div class=\"mb-3 {{ filterContainerClass() }}\">\n <div class=\"d-flex\">\n <app-btn\n text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n </div>\n <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n <form-generator
|
|
177
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: TableInputComponent, isStandalone: true, selector: "table-input", inputs: { formArray: { classPropertyName: "formArray", publicName: "formArray", isSignal: true, isRequired: false, transformFunction: null }, filterContainerClass: { classPropertyName: "filterContainerClass", publicName: "filterContainerClass", isSignal: true, isRequired: false, transformFunction: null }, border: { classPropertyName: "border", publicName: "border", isSignal: true, isRequired: false, transformFunction: null }, isShow: { classPropertyName: "isShow", publicName: "isShow", isSignal: true, isRequired: false, transformFunction: null }, _pageSize: { classPropertyName: "_pageSize", publicName: "pageSize", isSignal: false, isRequired: false, transformFunction: null }, actionBtns: { classPropertyName: "actionBtns", publicName: "actionBtns", isSignal: true, isRequired: false, transformFunction: null }, _formSchema: { classPropertyName: "_formSchema", publicName: "formSchema", isSignal: false, isRequired: true, transformFunction: null }, singleFormStructure: { classPropertyName: "singleFormStructure", publicName: "singleFormStructure", isSignal: false, isRequired: true, transformFunction: null }, deleteRowFunc: { classPropertyName: "deleteRowFunc", publicName: "deleteRowFunc", isSignal: false, isRequired: false, transformFunction: null }, addRowFunc: { classPropertyName: "addRowFunc", publicName: "addRowFunc", isSignal: false, isRequired: false, transformFunction: null }, _usePaginator: { classPropertyName: "_usePaginator", publicName: "usePaginator", isSignal: false, isRequired: false, transformFunction: null }, tableClass: { classPropertyName: "tableClass", publicName: "tableClass", isSignal: true, isRequired: false, transformFunction: null } }, providers: [FilterFormArrayGroupPipe, PaginatorPipe], viewQueries: [{ propertyName: "paginatorComponent", first: true, predicate: PaginatorComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"table-input\">\n @if (filterForms()?.length) {\n <div class=\"mb-3 {{ filterContainerClass() }}\">\n <div class=\"d-flex\">\n <app-btn\n text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n </div>\n <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n <form-generator\n [form]=\"filterForm\"\n [formSchema]=\"filterForms()\"\n [gridLGStyle]=\"3\"\n [showSubmitBtn]=\"false\"\n (mchange)=\"resetPaginator()\" />\n <div class=\"d-flex justify-content-end\">\n <app-btn type=\"danger-outline\" text=\"Clear\" (mclick)=\"filterForm.reset()\" />\n </div>\n </div>\n </div>\n }\n\n <div class=\"bg-white\" [ngClass]=\"{ 'border rounded-10': border() }\">\n <div class=\" \">\n <table class=\" {{ tableClass() }} \" [ngClass]=\"{ 'is-show-form': isShow() }\">\n <thead (click)=\"utilityService.logForm(filteredFormArray())\">\n <tr class=\"text-center\">\n @for (item of formSchema(); track item.label) {\n <th class=\"{{ item.cls }}\" (click)=\"logColumn(item)\">\n {{ item.label | appTranslate | async }}\n {{ item.isRequired ? '*' : '' }}\n </th>\n }\n @if (!isShow()) {\n <th></th>\n <th></th>\n @for (actionBtn of actionBtns(); track actionBtn) {\n <th></th>\n }\n }\n </tr>\n </thead>\n <tbody>\n @for (subForm of paginatedAndFilteredFormArray(); track subForm.id; let i = $index) {\n <tr\n table-input-row\n (onAddRowFunc)=\"addRowClicked(subForm.index)\"\n [isShow]=\"isShow()\"\n [form]=\"subForm.form\"\n [actionBtns]=\"actionBtns()\"\n [formSchema]=\"formSchema()\"\n [childrenFormSchemaMap]=\"childrenFormSchemaMap\"\n (onDeleteRowFunc)=\"\n deleteRowClicked(subForm.index, subForm.form, {\n btn: $event?.btn\n })\n \"\n (onActionButtonClick)=\"\n handleActionButtonClick(subForm.index, subForm.form, $event)\n \"></tr>\n } @empty {\n <tr>\n <td class=\"text-center\" [colSpan]=\"formSchema()?.length\">\n {{ 'There are no items' | appTranslate | async }}\n </td>\n </tr>\n }\n </tbody>\n </table>\n </div>\n\n <div\n class=\"\"\n [hidden]=\"\n !usePaginator() || !filteredFormArrayLength() || filteredFormArrayLength() < pageSize()\n \">\n <paginator\n #paginatorTag\n [arrayLength]=\"filteredFormArrayLength()\"\n (pageChanged)=\"pageChanged($event)\"\n [pageSize]=\"pageSize()\"\n [resetIndexFunc]=\"filterForm.valueChanges\" />\n </div>\n </div>\n</div>\n", styles: ["tr{vertical-align:top}:host ::ng-deep .text-center input{text-align:center}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "component", type: BtnComponent, selector: "app-btn", inputs: ["formSchema", "debug", "centerBtn", "danger", "warning", "verbose", "loading", "icon", "rightIcon", "leftIcon", "type", "group", "actionType", "animate", "excludeLogging", "loggingValue", "badge", "class", "customIcon", "form", "forms", "help", "iconBtn", "mclass", "showHelpIcon", "rightCustomIcon", "leftCustomIcon", "text", "valid", "mini", "onFormInvalid", "disabled"], outputs: ["loadingChange", "leftCustomIconChange", "mclick", "disabledChange"] }, { kind: "component", type: FormGeneratorComponent, selector: "form-generator", inputs: ["keyField", "presetValueForSingleOption", "isCreate", "submitOnEnterKey", "submitFunc", "submitBtnText", "submitBtnTemplate", "submitSuccessText", "showSubmitBtn", "gridStyle", "gridMDStyle", "gridLGStyle", "gridXXLStyle", "formGridClass", "useLoader", "loading", "form", "formSchema", "formSchemaNoForm", "isShow"], outputs: ["onSubmit", "mchange", "saved", "formChange"] }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: MatExpansionModule }, { kind: "ngmodule", type: MatTabsModule }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: PaginatorComponent, selector: "paginator", inputs: ["pageSize", "pageIndex", "arrayLength", "resetIndexFunc", "pageSizeOptions"], outputs: ["pageChanged"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "component", type: TableInputRowComponent, selector: "tr[table-input-row]", inputs: ["isShow", "hideAdd", "actionBtns", "childrenFormSchemaMap"], outputs: ["onDeleteRowFunc", "onAddRowFunc", "onActionButtonClick"] }, { kind: "pipe", type: SDKTranslatePipe, name: "appTranslate" }] }); }
|
|
178
178
|
}
|
|
179
179
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableInputComponent, decorators: [{
|
|
180
180
|
type: Component,
|
|
@@ -210,7 +210,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
|
|
|
210
210
|
SDKTranslatePipe,
|
|
211
211
|
FilterFormArrayGroupPipe,
|
|
212
212
|
ValidationMessageComponent,
|
|
213
|
-
], providers: [FilterFormArrayGroupPipe, PaginatorPipe], template: "<div class=\"table-input\">\n @if (filterForms()?.length) {\n <div class=\"mb-3 {{ filterContainerClass() }}\">\n <div class=\"d-flex\">\n <app-btn\n text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n </div>\n <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n <form-generator
|
|
213
|
+
], providers: [FilterFormArrayGroupPipe, PaginatorPipe], template: "<div class=\"table-input\">\n @if (filterForms()?.length) {\n <div class=\"mb-3 {{ filterContainerClass() }}\">\n <div class=\"d-flex\">\n <app-btn\n text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n </div>\n <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n <form-generator\n [form]=\"filterForm\"\n [formSchema]=\"filterForms()\"\n [gridLGStyle]=\"3\"\n [showSubmitBtn]=\"false\"\n (mchange)=\"resetPaginator()\" />\n <div class=\"d-flex justify-content-end\">\n <app-btn type=\"danger-outline\" text=\"Clear\" (mclick)=\"filterForm.reset()\" />\n </div>\n </div>\n </div>\n }\n\n <div class=\"bg-white\" [ngClass]=\"{ 'border rounded-10': border() }\">\n <div class=\" \">\n <table class=\" {{ tableClass() }} \" [ngClass]=\"{ 'is-show-form': isShow() }\">\n <thead (click)=\"utilityService.logForm(filteredFormArray())\">\n <tr class=\"text-center\">\n @for (item of formSchema(); track item.label) {\n <th class=\"{{ item.cls }}\" (click)=\"logColumn(item)\">\n {{ item.label | appTranslate | async }}\n {{ item.isRequired ? '*' : '' }}\n </th>\n }\n @if (!isShow()) {\n <th></th>\n <th></th>\n @for (actionBtn of actionBtns(); track actionBtn) {\n <th></th>\n }\n }\n </tr>\n </thead>\n <tbody>\n @for (subForm of paginatedAndFilteredFormArray(); track subForm.id; let i = $index) {\n <tr\n table-input-row\n (onAddRowFunc)=\"addRowClicked(subForm.index)\"\n [isShow]=\"isShow()\"\n [form]=\"subForm.form\"\n [actionBtns]=\"actionBtns()\"\n [formSchema]=\"formSchema()\"\n [childrenFormSchemaMap]=\"childrenFormSchemaMap\"\n (onDeleteRowFunc)=\"\n deleteRowClicked(subForm.index, subForm.form, {\n btn: $event?.btn\n })\n \"\n (onActionButtonClick)=\"\n handleActionButtonClick(subForm.index, subForm.form, $event)\n \"></tr>\n } @empty {\n <tr>\n <td class=\"text-center\" [colSpan]=\"formSchema()?.length\">\n {{ 'There are no items' | appTranslate | async }}\n </td>\n </tr>\n }\n </tbody>\n </table>\n </div>\n\n <div\n class=\"\"\n [hidden]=\"\n !usePaginator() || !filteredFormArrayLength() || filteredFormArrayLength() < pageSize()\n \">\n <paginator\n #paginatorTag\n [arrayLength]=\"filteredFormArrayLength()\"\n (pageChanged)=\"pageChanged($event)\"\n [pageSize]=\"pageSize()\"\n [resetIndexFunc]=\"filterForm.valueChanges\" />\n </div>\n </div>\n</div>\n", styles: ["tr{vertical-align:top}:host ::ng-deep .text-center input{text-align:center}\n"] }]
|
|
214
214
|
}], propDecorators: { _pageSize: [{
|
|
215
215
|
type: Input,
|
|
216
216
|
args: ['pageSize']
|
|
@@ -231,4 +231,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
|
|
|
231
231
|
type: ViewChild,
|
|
232
232
|
args: [PaginatorComponent]
|
|
233
233
|
}] } });
|
|
234
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/table-input/table-input.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/table-input/table-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  OnInit,\n  ViewChild,\n  computed,\n  effect,\n  inject,\n  input,\n  signal,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  FormArray,\n  FormControl,\n  FormGroup,\n  FormsModule,\n  ReactiveFormsModule,\n  Validators,\n} from '@angular/forms';\nimport { IFormSchema } from '../../models/form-schema.model';\nimport {\n  FilterFormArrayGroupPipe,\n  FormValuePipe,\n  FunctionCaller2,\n  HasFormValuePipe,\n  ToAnyPipe,\n} from '../../pipes/utility.pipe';\n\nimport { BtnComponent } from '../btn/btn.component';\nimport { InputBasicComponent } from '../input/input-basic.component';\nimport { AutocompleteComponent } from '../autocomplete/autocomplete.component';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\nimport { PhoneNumberComponent } from '../phone-number/phone-number.component';\nimport {\n  AsyncPipe,\n  JsonPipe,\n  NgClass,\n  NgFor,\n  NgIf,\n  NgSwitch,\n  NgSwitchCase,\n  NgSwitchDefault,\n} from '@angular/common';\nimport { LoaderComponent } from '../loader/loader.component';\nimport { FormGeneratorComponent } from '../form-generator/form-generator.component';\n\nimport { PaginatorComponent } from '../paginator/paginator.component';\nimport { ModalComponent } from '../modal/modal.component';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { MatExpansionModule } from '@angular/material/expansion';\nimport { MatTabsModule } from '@angular/material/tabs';\nimport { TableInputRowComponent } from './table-input-row/table-input-row.component';\nimport { Subscription, filter, map, switchMap } from 'rxjs';\nimport { IBtn } from '../btn/btn.model';\nimport { UtilityService } from '../../../Services/utility.service';\nimport { SDKTranslatePipe } from '../../pipes/translate.pipe';\nimport { PaginatorPipe } from '../../pipes/paginator.pipe';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\n\n/**\n * Table Input Component\n */\n@Component({\n  selector: 'table-input',\n  standalone: true,\n  imports: [\n    AsyncPipe,\n    AutocompleteComponent,\n    BtnComponent,\n    FilterFormArrayGroupPipe,\n    FormGeneratorComponent,\n    FormsModule,\n    FormValuePipe,\n    FunctionCaller2,\n    HasFormValuePipe,\n    InputBasicComponent,\n    JsonPipe,\n    LoaderComponent,\n    MatExpansionModule,\n    MatTabsModule,\n    MatTooltipModule,\n    ModalComponent,\n    NgClass,\n    NgFor,\n    NgIf,\n    NgSwitch,\n    NgSwitchCase,\n    NgSwitchDefault,\n    PaginatorComponent,\n    PaginatorPipe,\n    PhoneNumberComponent,\n    ReactiveFormsModule,\n    TableInputRowComponent,\n    ToAnyPipe,\n    SDKTranslatePipe,\n    FilterFormArrayGroupPipe,\n    ValidationMessageComponent,\n  ],\n  templateUrl: './table-input.component.html',\n  styleUrls: ['./table-input.component.scss'],\n  providers: [FilterFormArrayGroupPipe, PaginatorPipe],\n})\nexport class TableInputComponent<\n    TFormGroup extends {\n      [K in keyof TFormGroup]: AbstractControl<any, any>;\n    } = any,\n  >\n  extends FormGeneratorComponent<TFormGroup>\n  implements OnInit\n{\n  logColumn(_t20: IFormSchema<TFormGroup>) {\n    console.log(_t20);\n  }\n  readonly formArray = input<FormArray<FormGroup<TFormGroup>>>();\n\n  readonly filterContainerClass = input<string>();\n  readonly border = input(true);\n  readonly isShow = input<boolean>();\n  @Input('pageSize') set _pageSize(v: number) {\n    this.pageSize.set(v);\n  }\n  readonly pageSize = signal<number>(10);\n  readonly pageState = signal<{ pageIndex: number; pageSize: number }>(null);\n  readonly actionBtns = input<ITableInputBtn[]>();\n  @Input({ required: true, alias: 'formSchema' }) override set _formSchema(\n    v: IFormSchema<TFormGroup>[],\n  ) {\n    this.preFormatFormSchema(v);\n    super._formSchema = v;\n  }\n  @Input({ required: true })\n  singleFormStructure: FormGroup<TFormGroup>;\n  /**\n   * Leave empty if you don't want the delete button to show\n   */\n  @Input() deleteRowFunc: (\n    index: number,\n    data?: FormGroup<TFormGroup>['value'],\n    config?: { btn: BtnComponent },\n  ) => any;\n  /**\n   * Leave empty if you don't want the add button to show\n   */\n  @Input() addRowFunc: (index: number, data?: FormGroup<TFormGroup>['value']) => any;\n  @Input('usePaginator') set _usePaginator(v: boolean) {\n    if (v) {\n      this.usePaginator.set(true);\n      this.pageSize.update((pageSize) => pageSize || 10);\n    } else {\n      this.usePaginator.set(false);\n      this.pageSize.set(undefined);\n    }\n  }\n\n  readonly tableClass = input<'table table-responsive table-responsive table-borderless'>();\n  protected readonly filterForm = new FormGroup({});\n  protected readonly filterForms = signal<IFormSchema[]>([]);\n  protected readonly usePaginator = signal<boolean>(true);\n  protected childrenFormSchemaMap: {\n    [k in keyof TFormGroup]?: {\n      formSchema: IFormSchema[];\n      formSchemaStr: string[];\n    };\n  } = {};\n  refresher: number;\n  formArrayPaginationSub: Subscription;\n\n  @ViewChild(PaginatorComponent) paginatorComponent: PaginatorComponent;\n\n  readonly filterFormValueSignal = toSignal(this.filterForm.valueChanges);\n  readonly formArrayLengthSignal = toSignal<number>(\n    toObservable(this.formArray).pipe(\n      switchMap((form) => form?.valueChanges.pipe(map(() => form?.length))),\n    ),\n  );\n\n  readonly filteredFormArray = computed(() => {\n    this.formArrayLengthSignal();\n    const formArray = this.formArray(),\n      filterFormValue = this.filterFormValueSignal();\n    const formGroups = formArray?.controls?.map((c, index) => ({\n      index,\n      form: c,\n      id: this.utilityService.generateUUID(),\n    }));\n    const filterObject = this.filterFormArrayGroupPipe.queryMapper(filterFormValue);\n    return filterObject\n      ? formGroups.filter(({ form }) =>\n          this.filterFormArrayGroupPipe.filterFunc(filterObject)(form),\n        )\n      : formGroups;\n  });\n  readonly paginatedAndFilteredFormArray = computed(() => {\n    const formArray = this.filteredFormArray(),\n      pageState = this.pageState();\n    return this.usePaginator()\n      ? this.paginatorPipe.transform(\n          formArray,\n          pageState?.pageSize || this.pageSize(),\n          pageState?.pageIndex || 0,\n        )\n      : formArray;\n  });\n\n  readonly filteredFormArrayLength = computed(() => this.filteredFormArray().length);\n\n  public override utilityService = inject(UtilityService);\n  public filterFormArrayGroupPipe = inject(FilterFormArrayGroupPipe);\n  public paginatorPipe = inject(PaginatorPipe);\n\n  ngOnInit(): void {\n    if (this.usePaginator == undefined) {\n      this._usePaginator = true;\n    }\n  }\n\n  ngAfterViewInit(): void {\n    setTimeout(() => {\n      this.refresh();\n    }, 1000);\n  }\n\n  refresh() {\n    this.refresher = Math.random();\n  }\n\n  override onDestroy() {\n    this.formArrayPaginationSub?.unsubscribe();\n    return super.onDestroy();\n  }\n\n  pageChanged($event: { pageIndex: number; pageSize: number }) {\n    this.pageState.set($event);\n  }\n\n  resetPaginator() {\n    this.paginatorComponent?.reset();\n  }\n\n  protected preFormatFormSchema = (items: IFormSchema<TFormGroup>[]) => {\n    items.forEach((x) => {\n      if (x.onChangeFunc) x.triggerOnChangeOnInit = true;\n      else if (x.type == 'button') this.preFormatFormSchema(x.children);\n    });\n  };\n\n  override init(schema: IFormSchema<TFormGroup>[]): void {\n    this.filterForms.set([]);\n    for (const key in this.filterForm.controls) {\n      if (Object.prototype.hasOwnProperty.call(this.filterForm.controls, key)) {\n        this.filterForm.removeControl(key);\n      }\n    }\n    // debugger;\n    this.onDestroy();\n    if (schema)\n      for (const scheme of schema) {\n        // scheme.form = this.form || scheme.form;\n        this.handleFormScheme(scheme);\n      }\n    this._setFormSchemas(schema);\n  }\n\n  handleActionButtonClick(\n    index: number,\n    form: FormGroup<TFormGroup>,\n    e: { btn?: BtnComponent; actionButton: ITableInputBtn },\n  ) {\n    e.actionButton.action({ index, form, btn: e.btn });\n    // this.refresh();\n  }\n\n  deleteRowClicked = (\n    index: number,\n    rowForm: FormGroup<TFormGroup>,\n    config?: { btn: BtnComponent },\n  ) => {\n    this.deleteRowFunc(index, rowForm?.getRawValue(), config);\n    // this.refresh();\n  };\n\n  addRowClicked = (index: number) => {\n    this.addRowFunc(index + 1, this.filterFormValueSignal());\n    // this.refresh();\n    // this.filterForm.updateValueAndValidity();\n  };\n\n  checkRequiredFields = () => {\n    console.log(this.singleFormStructure);\n  };\n\n  override handleFormScheme(scheme: IFormSchema) {\n    scheme.id = this.utilityService.generateUUID();\n    if (scheme.autoPickValueField == null && (!scheme.valueField || !scheme.labelField))\n      scheme.autoPickValueField = true;\n\n    if (scheme.optionsInitFunc) {\n      scheme.optionsInitFunc.subscribe((r) => {\n        scheme.options = r;\n        // this.optionsMap[scheme.field] = r;\n      });\n    }\n    if (scheme.isSearchField) {\n      this.filterForms.update((filterForms) => filterForms.concat([scheme]));\n      this.filterForm.addControl(scheme.field?.toString(), new FormControl());\n    } else if (scheme.type == 'button') {\n      if (scheme.children?.length)\n        this.childrenFormSchemaMap[scheme.field as string] = {\n          formSchema: scheme.children,\n          formSchemaStr: scheme.children.map((x) => x.field as string),\n        };\n    }\n    scheme.isRequired =\n      scheme.isRequired ||\n      (<FormGroup>this.singleFormStructure?.controls[scheme.field])?.hasValidator(\n        Validators.required,\n      );\n  }\n}\n\nexport interface ITableInputBtn extends IBtn {\n  action?: (arg?: { index: number; form: FormGroup; btn: BtnComponent }) => void;\n}\n","<div class=\"table-input\">\n  @if (filterForms()?.length) {\n    <div class=\"mb-3 {{ filterContainerClass() }}\">\n      <div class=\"d-flex\">\n        <app-btn\n          text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n          [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n          (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n      </div>\n      <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n        <form-generator [form]=\"filterForm\" [formSchema]=\"filterForms()\" [gridLGStyle]=\"3\" [showSubmitBtn]=\"false\" (mchange)=\"resetPaginator()\" />\n        <div class=\"d-flex justify-content-end\">\n          <app-btn type=\"danger-outline\" text=\"Clear\" (mclick)=\"filterForm.reset()\" />\n        </div>\n      </div>\n    </div>\n  }\n\n  <div class=\"bg-white\" [ngClass]=\"{ 'border rounded-10': border() }\">\n    <div class=\" \">\n      <table class=\" {{ tableClass() }} \" [ngClass]=\"{ 'is-show-form': isShow() }\">\n        <thead (click)=\"utilityService.logForm(filteredFormArray())\">\n          <tr class=\"text-center\">\n            @for (item of formSchema(); track item.label) {\n              <th class=\"{{ item.cls }}\" (click)=\"logColumn(item)\">\n                {{ item.label | appTranslate | async }}\n                {{ item.isRequired ? '*' : '' }}\n              </th>\n            }\n            @if (!isShow()) {\n              <th></th>\n              <th></th>\n              @for (actionBtn of actionBtns(); track actionBtn) {\n                <th></th>\n              }\n            }\n          </tr>\n        </thead>\n        <tbody>\n          @for (subForm of paginatedAndFilteredFormArray(); track subForm.id; let i = $index) {\n            <tr\n              table-input-row\n              (onAddRowFunc)=\"addRowClicked(subForm.index)\"\n              [isShow]=\"isShow()\"\n              [form]=\"subForm.form\"\n              [actionBtns]=\"actionBtns()\"\n              [formSchema]=\"formSchema()\"\n              [childrenFormSchemaMap]=\"childrenFormSchemaMap\"\n              (onDeleteRowFunc)=\"\n                deleteRowClicked(subForm.index, subForm.form, {\n                  btn: $event?.btn\n                })\n              \"\n              (onActionButtonClick)=\"handleActionButtonClick(subForm.index, subForm.form, $event)\"></tr>\n          } @empty {\n            <tr>\n              <td class=\"text-center\" [colSpan]=\"formSchema()?.length\">\n                {{ 'There are no items' | appTranslate | async }}\n              </td>\n            </tr>\n          }\n        </tbody>\n      </table>\n    </div>\n\n    <div class=\"\" [hidden]=\"!usePaginator() || !filteredFormArrayLength() || filteredFormArrayLength() < pageSize()\">\n      <paginator\n        #paginatorTag\n        [arrayLength]=\"filteredFormArrayLength()\"\n        (pageChanged)=\"pageChanged($event)\"\n        [pageSize]=\"pageSize()\"\n        [resetIndexFunc]=\"filterForm.valueChanges\" />\n    </div>\n  </div>\n</div>\n"]}
|
|
234
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/table-input/table-input.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/table-input/table-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  OnInit,\n  ViewChild,\n  computed,\n  effect,\n  inject,\n  input,\n  signal,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  FormArray,\n  FormControl,\n  FormGroup,\n  FormsModule,\n  ReactiveFormsModule,\n  Validators,\n} from '@angular/forms';\nimport { IFormSchema } from '../../models/form-schema.model';\nimport {\n  FilterFormArrayGroupPipe,\n  FormValuePipe,\n  FunctionCaller2,\n  HasFormValuePipe,\n  ToAnyPipe,\n} from '../../pipes/utility.pipe';\n\nimport { BtnComponent } from '../btn/btn.component';\nimport { InputBasicComponent } from '../input/input-basic.component';\nimport { AutocompleteComponent } from '../autocomplete/autocomplete.component';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\nimport { PhoneNumberComponent } from '../phone-number/phone-number.component';\nimport {\n  AsyncPipe,\n  JsonPipe,\n  NgClass,\n  NgFor,\n  NgIf,\n  NgSwitch,\n  NgSwitchCase,\n  NgSwitchDefault,\n} from '@angular/common';\nimport { LoaderComponent } from '../loader/loader.component';\nimport { FormGeneratorComponent } from '../form-generator/form-generator.component';\n\nimport { PaginatorComponent } from '../paginator/paginator.component';\nimport { ModalComponent } from '../modal/modal.component';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { MatExpansionModule } from '@angular/material/expansion';\nimport { MatTabsModule } from '@angular/material/tabs';\nimport { TableInputRowComponent } from './table-input-row/table-input-row.component';\nimport { Subscription, filter, map, switchMap } from 'rxjs';\nimport { IBtn } from '../btn/btn.model';\nimport { UtilityService } from '../../../Services/utility.service';\nimport { SDKTranslatePipe } from '../../pipes/translate.pipe';\nimport { PaginatorPipe } from '../../pipes/paginator.pipe';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\n\n/**\n * Table Input Component\n */\n@Component({\n  selector: 'table-input',\n  standalone: true,\n  imports: [\n    AsyncPipe,\n    AutocompleteComponent,\n    BtnComponent,\n    FilterFormArrayGroupPipe,\n    FormGeneratorComponent,\n    FormsModule,\n    FormValuePipe,\n    FunctionCaller2,\n    HasFormValuePipe,\n    InputBasicComponent,\n    JsonPipe,\n    LoaderComponent,\n    MatExpansionModule,\n    MatTabsModule,\n    MatTooltipModule,\n    ModalComponent,\n    NgClass,\n    NgFor,\n    NgIf,\n    NgSwitch,\n    NgSwitchCase,\n    NgSwitchDefault,\n    PaginatorComponent,\n    PaginatorPipe,\n    PhoneNumberComponent,\n    ReactiveFormsModule,\n    TableInputRowComponent,\n    ToAnyPipe,\n    SDKTranslatePipe,\n    FilterFormArrayGroupPipe,\n    ValidationMessageComponent,\n  ],\n  templateUrl: './table-input.component.html',\n  styleUrls: ['./table-input.component.scss'],\n  providers: [FilterFormArrayGroupPipe, PaginatorPipe],\n})\nexport class TableInputComponent<\n    TFormGroup extends {\n      [K in keyof TFormGroup]: AbstractControl<any, any>;\n    } = any,\n  >\n  extends FormGeneratorComponent<TFormGroup>\n  implements OnInit\n{\n  logColumn(_t20: IFormSchema<TFormGroup>) {\n    console.log(_t20);\n  }\n  readonly formArray = input<FormArray<FormGroup<TFormGroup>>>();\n\n  readonly filterContainerClass = input<string>();\n  readonly border = input(true);\n  readonly isShow = input<boolean>();\n  @Input('pageSize') set _pageSize(v: number) {\n    this.pageSize.set(v);\n  }\n  readonly pageSize = signal<number>(10);\n  readonly pageState = signal<{ pageIndex: number; pageSize: number }>(null);\n  readonly actionBtns = input<ITableInputBtn[]>();\n  @Input({ required: true, alias: 'formSchema' }) override set _formSchema(\n    v: IFormSchema<TFormGroup>[],\n  ) {\n    this.preFormatFormSchema(v);\n    super._formSchema = v;\n  }\n  @Input({ required: true })\n  singleFormStructure: FormGroup<TFormGroup>;\n  /**\n   * Leave empty if you don't want the delete button to show\n   */\n  @Input() deleteRowFunc: (\n    index: number,\n    data?: FormGroup<TFormGroup>['value'],\n    config?: { btn: BtnComponent },\n  ) => any;\n  /**\n   * Leave empty if you don't want the add button to show\n   */\n  @Input() addRowFunc: (index: number, data?: FormGroup<TFormGroup>['value']) => any;\n  @Input('usePaginator') set _usePaginator(v: boolean) {\n    if (v) {\n      this.usePaginator.set(true);\n      this.pageSize.update((pageSize) => pageSize || 10);\n    } else {\n      this.usePaginator.set(false);\n      this.pageSize.set(undefined);\n    }\n  }\n\n  readonly tableClass = input<string>('table table-responsive table-responsive table-borderless');\n  protected readonly filterForm = new FormGroup({});\n  protected readonly filterForms = signal<IFormSchema[]>([]);\n  protected readonly usePaginator = signal<boolean>(true);\n  protected childrenFormSchemaMap: {\n    [k in keyof TFormGroup]?: {\n      formSchema: IFormSchema[];\n      formSchemaStr: string[];\n    };\n  } = {};\n  refresher: number;\n  formArrayPaginationSub: Subscription;\n\n  @ViewChild(PaginatorComponent) paginatorComponent: PaginatorComponent;\n\n  readonly filterFormValueSignal = toSignal(this.filterForm.valueChanges);\n  readonly formArrayLengthSignal = toSignal<number>(\n    toObservable(this.formArray).pipe(\n      switchMap((form) => form?.valueChanges.pipe(map(() => form?.length))),\n    ),\n  );\n\n  readonly filteredFormArray = computed(() => {\n    this.formArrayLengthSignal();\n    const formArray = this.formArray(),\n      filterFormValue = this.filterFormValueSignal();\n    const formGroups = formArray?.controls?.map((c, index) => ({\n      index,\n      form: c,\n      id: this.utilityService.generateUUID(),\n    }));\n    const filterObject = this.filterFormArrayGroupPipe.queryMapper(filterFormValue);\n    return filterObject\n      ? formGroups.filter(({ form }) =>\n          this.filterFormArrayGroupPipe.filterFunc(filterObject)(form),\n        )\n      : formGroups;\n  });\n  readonly paginatedAndFilteredFormArray = computed(() => {\n    const formArray = this.filteredFormArray(),\n      pageState = this.pageState();\n    return this.usePaginator()\n      ? this.paginatorPipe.transform(\n          formArray,\n          pageState?.pageSize || this.pageSize(),\n          pageState?.pageIndex || 0,\n        )\n      : formArray;\n  });\n\n  readonly filteredFormArrayLength = computed(() => this.filteredFormArray().length);\n\n  public override utilityService = inject(UtilityService);\n  public filterFormArrayGroupPipe = inject(FilterFormArrayGroupPipe);\n  public paginatorPipe = inject(PaginatorPipe);\n\n  ngOnInit(): void {\n    if (this.usePaginator == undefined) {\n      this._usePaginator = true;\n    }\n  }\n\n  ngAfterViewInit(): void {\n    setTimeout(() => {\n      this.refresh();\n    }, 1000);\n  }\n\n  refresh() {\n    this.refresher = Math.random();\n  }\n\n  override onDestroy() {\n    this.formArrayPaginationSub?.unsubscribe();\n    return super.onDestroy();\n  }\n\n  pageChanged($event: { pageIndex: number; pageSize: number }) {\n    this.pageState.set($event);\n  }\n\n  resetPaginator() {\n    this.paginatorComponent?.reset();\n  }\n\n  protected preFormatFormSchema = (items: IFormSchema<TFormGroup>[]) => {\n    items.forEach((x) => {\n      if (x.onChangeFunc) x.triggerOnChangeOnInit = true;\n      else if (x.type == 'button') this.preFormatFormSchema(x.children);\n    });\n  };\n\n  override init(schema: IFormSchema<TFormGroup>[]): void {\n    this.filterForms.set([]);\n    for (const key in this.filterForm.controls) {\n      if (Object.prototype.hasOwnProperty.call(this.filterForm.controls, key)) {\n        this.filterForm.removeControl(key);\n      }\n    }\n    // debugger;\n    this.onDestroy();\n    if (schema)\n      for (const scheme of schema) {\n        // scheme.form = this.form || scheme.form;\n        this.handleFormScheme(scheme);\n      }\n    this._setFormSchemas(schema);\n  }\n\n  handleActionButtonClick(\n    index: number,\n    form: FormGroup<TFormGroup>,\n    e: { btn?: BtnComponent; actionButton: ITableInputBtn },\n  ) {\n    e.actionButton.action({ index, form, btn: e.btn });\n    // this.refresh();\n  }\n\n  deleteRowClicked = (\n    index: number,\n    rowForm: FormGroup<TFormGroup>,\n    config?: { btn: BtnComponent },\n  ) => {\n    this.deleteRowFunc(index, rowForm?.getRawValue(), config);\n    // this.refresh();\n  };\n\n  addRowClicked = (index: number) => {\n    this.addRowFunc(index + 1, this.filterFormValueSignal());\n    // this.refresh();\n    // this.filterForm.updateValueAndValidity();\n  };\n\n  checkRequiredFields = () => {\n    console.log(this.singleFormStructure);\n  };\n\n  override handleFormScheme(scheme: IFormSchema) {\n    scheme.id = this.utilityService.generateUUID();\n    if (scheme.autoPickValueField == null && (!scheme.valueField || !scheme.labelField))\n      scheme.autoPickValueField = true;\n\n    if (scheme.optionsInitFunc) {\n      scheme.optionsInitFunc.subscribe((r) => {\n        scheme.options = r;\n        // this.optionsMap[scheme.field] = r;\n      });\n    }\n    if (scheme.isSearchField) {\n      this.filterForms.update((filterForms) => filterForms.concat([scheme]));\n      this.filterForm.addControl(scheme.field?.toString(), new FormControl());\n    } else if (scheme.type == 'button') {\n      if (scheme.children?.length)\n        this.childrenFormSchemaMap[scheme.field as string] = {\n          formSchema: scheme.children,\n          formSchemaStr: scheme.children.map((x) => x.field as string),\n        };\n    }\n    scheme.isRequired =\n      scheme.isRequired ||\n      (<FormGroup>this.singleFormStructure?.controls[scheme.field])?.hasValidator(\n        Validators.required,\n      );\n  }\n}\n\nexport interface ITableInputBtn extends IBtn {\n  action?: (arg?: { index: number; form: FormGroup; btn: BtnComponent }) => void;\n}\n","<div class=\"table-input\">\n  @if (filterForms()?.length) {\n    <div class=\"mb-3 {{ filterContainerClass() }}\">\n      <div class=\"d-flex\">\n        <app-btn\n          text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n          [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n          (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n      </div>\n      <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n        <form-generator\n          [form]=\"filterForm\"\n          [formSchema]=\"filterForms()\"\n          [gridLGStyle]=\"3\"\n          [showSubmitBtn]=\"false\"\n          (mchange)=\"resetPaginator()\" />\n        <div class=\"d-flex justify-content-end\">\n          <app-btn type=\"danger-outline\" text=\"Clear\" (mclick)=\"filterForm.reset()\" />\n        </div>\n      </div>\n    </div>\n  }\n\n  <div class=\"bg-white\" [ngClass]=\"{ 'border rounded-10': border() }\">\n    <div class=\" \">\n      <table class=\" {{ tableClass() }} \" [ngClass]=\"{ 'is-show-form': isShow() }\">\n        <thead (click)=\"utilityService.logForm(filteredFormArray())\">\n          <tr class=\"text-center\">\n            @for (item of formSchema(); track item.label) {\n              <th class=\"{{ item.cls }}\" (click)=\"logColumn(item)\">\n                {{ item.label | appTranslate | async }}\n                {{ item.isRequired ? '*' : '' }}\n              </th>\n            }\n            @if (!isShow()) {\n              <th></th>\n              <th></th>\n              @for (actionBtn of actionBtns(); track actionBtn) {\n                <th></th>\n              }\n            }\n          </tr>\n        </thead>\n        <tbody>\n          @for (subForm of paginatedAndFilteredFormArray(); track subForm.id; let i = $index) {\n            <tr\n              table-input-row\n              (onAddRowFunc)=\"addRowClicked(subForm.index)\"\n              [isShow]=\"isShow()\"\n              [form]=\"subForm.form\"\n              [actionBtns]=\"actionBtns()\"\n              [formSchema]=\"formSchema()\"\n              [childrenFormSchemaMap]=\"childrenFormSchemaMap\"\n              (onDeleteRowFunc)=\"\n                deleteRowClicked(subForm.index, subForm.form, {\n                  btn: $event?.btn\n                })\n              \"\n              (onActionButtonClick)=\"\n                handleActionButtonClick(subForm.index, subForm.form, $event)\n              \"></tr>\n          } @empty {\n            <tr>\n              <td class=\"text-center\" [colSpan]=\"formSchema()?.length\">\n                {{ 'There are no items' | appTranslate | async }}\n              </td>\n            </tr>\n          }\n        </tbody>\n      </table>\n    </div>\n\n    <div\n      class=\"\"\n      [hidden]=\"\n        !usePaginator() || !filteredFormArrayLength() || filteredFormArrayLength() < pageSize()\n      \">\n      <paginator\n        #paginatorTag\n        [arrayLength]=\"filteredFormArrayLength()\"\n        (pageChanged)=\"pageChanged($event)\"\n        [pageSize]=\"pageSize()\"\n        [resetIndexFunc]=\"filterForm.valueChanges\" />\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -6375,7 +6375,7 @@ class InputBasicComponent extends InputBase {
|
|
|
6375
6375
|
set _options(v) {
|
|
6376
6376
|
if (this.debug())
|
|
6377
6377
|
debugger;
|
|
6378
|
-
this.rawOptionsSignal.set(v || []);
|
|
6378
|
+
this.rawOptionsSignal.set(v?.filter((x) => x != null) || []);
|
|
6379
6379
|
this.options$.next(this.options());
|
|
6380
6380
|
}
|
|
6381
6381
|
constructor() {
|
|
@@ -6610,9 +6610,9 @@ class AutocompleteService {
|
|
|
6610
6610
|
if (filterValue) {
|
|
6611
6611
|
const res = [], resIncludes = [];
|
|
6612
6612
|
for (const option of options)
|
|
6613
|
-
if (option._normalizedLabel
|
|
6613
|
+
if (option._normalizedLabel?.startsWith(filterValue))
|
|
6614
6614
|
res.push(option);
|
|
6615
|
-
else if (option._normalizedLabel
|
|
6615
|
+
else if (option._normalizedLabel?.includes(filterValue))
|
|
6616
6616
|
resIncludes.push(option);
|
|
6617
6617
|
return res.concat(resIncludes);
|
|
6618
6618
|
}
|
|
@@ -15262,7 +15262,7 @@ class TableInputComponent extends FormGeneratorComponent {
|
|
|
15262
15262
|
this.pageSize = signal(10);
|
|
15263
15263
|
this.pageState = signal(null);
|
|
15264
15264
|
this.actionBtns = input();
|
|
15265
|
-
this.tableClass = input();
|
|
15265
|
+
this.tableClass = input('table table-responsive table-responsive table-borderless');
|
|
15266
15266
|
this.filterForm = new FormGroup({});
|
|
15267
15267
|
this.filterForms = signal([]);
|
|
15268
15268
|
this.usePaginator = signal(true);
|
|
@@ -15402,7 +15402,7 @@ class TableInputComponent extends FormGeneratorComponent {
|
|
|
15402
15402
|
this.singleFormStructure?.controls[scheme.field]?.hasValidator(Validators.required);
|
|
15403
15403
|
}
|
|
15404
15404
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableInputComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
15405
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: TableInputComponent, isStandalone: true, selector: "table-input", inputs: { formArray: { classPropertyName: "formArray", publicName: "formArray", isSignal: true, isRequired: false, transformFunction: null }, filterContainerClass: { classPropertyName: "filterContainerClass", publicName: "filterContainerClass", isSignal: true, isRequired: false, transformFunction: null }, border: { classPropertyName: "border", publicName: "border", isSignal: true, isRequired: false, transformFunction: null }, isShow: { classPropertyName: "isShow", publicName: "isShow", isSignal: true, isRequired: false, transformFunction: null }, _pageSize: { classPropertyName: "_pageSize", publicName: "pageSize", isSignal: false, isRequired: false, transformFunction: null }, actionBtns: { classPropertyName: "actionBtns", publicName: "actionBtns", isSignal: true, isRequired: false, transformFunction: null }, _formSchema: { classPropertyName: "_formSchema", publicName: "formSchema", isSignal: false, isRequired: true, transformFunction: null }, singleFormStructure: { classPropertyName: "singleFormStructure", publicName: "singleFormStructure", isSignal: false, isRequired: true, transformFunction: null }, deleteRowFunc: { classPropertyName: "deleteRowFunc", publicName: "deleteRowFunc", isSignal: false, isRequired: false, transformFunction: null }, addRowFunc: { classPropertyName: "addRowFunc", publicName: "addRowFunc", isSignal: false, isRequired: false, transformFunction: null }, _usePaginator: { classPropertyName: "_usePaginator", publicName: "usePaginator", isSignal: false, isRequired: false, transformFunction: null }, tableClass: { classPropertyName: "tableClass", publicName: "tableClass", isSignal: true, isRequired: false, transformFunction: null } }, providers: [FilterFormArrayGroupPipe, PaginatorPipe], viewQueries: [{ propertyName: "paginatorComponent", first: true, predicate: PaginatorComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"table-input\">\n @if (filterForms()?.length) {\n <div class=\"mb-3 {{ filterContainerClass() }}\">\n <div class=\"d-flex\">\n <app-btn\n text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n </div>\n <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n <form-generator
|
|
15405
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: TableInputComponent, isStandalone: true, selector: "table-input", inputs: { formArray: { classPropertyName: "formArray", publicName: "formArray", isSignal: true, isRequired: false, transformFunction: null }, filterContainerClass: { classPropertyName: "filterContainerClass", publicName: "filterContainerClass", isSignal: true, isRequired: false, transformFunction: null }, border: { classPropertyName: "border", publicName: "border", isSignal: true, isRequired: false, transformFunction: null }, isShow: { classPropertyName: "isShow", publicName: "isShow", isSignal: true, isRequired: false, transformFunction: null }, _pageSize: { classPropertyName: "_pageSize", publicName: "pageSize", isSignal: false, isRequired: false, transformFunction: null }, actionBtns: { classPropertyName: "actionBtns", publicName: "actionBtns", isSignal: true, isRequired: false, transformFunction: null }, _formSchema: { classPropertyName: "_formSchema", publicName: "formSchema", isSignal: false, isRequired: true, transformFunction: null }, singleFormStructure: { classPropertyName: "singleFormStructure", publicName: "singleFormStructure", isSignal: false, isRequired: true, transformFunction: null }, deleteRowFunc: { classPropertyName: "deleteRowFunc", publicName: "deleteRowFunc", isSignal: false, isRequired: false, transformFunction: null }, addRowFunc: { classPropertyName: "addRowFunc", publicName: "addRowFunc", isSignal: false, isRequired: false, transformFunction: null }, _usePaginator: { classPropertyName: "_usePaginator", publicName: "usePaginator", isSignal: false, isRequired: false, transformFunction: null }, tableClass: { classPropertyName: "tableClass", publicName: "tableClass", isSignal: true, isRequired: false, transformFunction: null } }, providers: [FilterFormArrayGroupPipe, PaginatorPipe], viewQueries: [{ propertyName: "paginatorComponent", first: true, predicate: PaginatorComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"table-input\">\n @if (filterForms()?.length) {\n <div class=\"mb-3 {{ filterContainerClass() }}\">\n <div class=\"d-flex\">\n <app-btn\n text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n </div>\n <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n <form-generator\n [form]=\"filterForm\"\n [formSchema]=\"filterForms()\"\n [gridLGStyle]=\"3\"\n [showSubmitBtn]=\"false\"\n (mchange)=\"resetPaginator()\" />\n <div class=\"d-flex justify-content-end\">\n <app-btn type=\"danger-outline\" text=\"Clear\" (mclick)=\"filterForm.reset()\" />\n </div>\n </div>\n </div>\n }\n\n <div class=\"bg-white\" [ngClass]=\"{ 'border rounded-10': border() }\">\n <div class=\" \">\n <table class=\" {{ tableClass() }} \" [ngClass]=\"{ 'is-show-form': isShow() }\">\n <thead (click)=\"utilityService.logForm(filteredFormArray())\">\n <tr class=\"text-center\">\n @for (item of formSchema(); track item.label) {\n <th class=\"{{ item.cls }}\" (click)=\"logColumn(item)\">\n {{ item.label | appTranslate | async }}\n {{ item.isRequired ? '*' : '' }}\n </th>\n }\n @if (!isShow()) {\n <th></th>\n <th></th>\n @for (actionBtn of actionBtns(); track actionBtn) {\n <th></th>\n }\n }\n </tr>\n </thead>\n <tbody>\n @for (subForm of paginatedAndFilteredFormArray(); track subForm.id; let i = $index) {\n <tr\n table-input-row\n (onAddRowFunc)=\"addRowClicked(subForm.index)\"\n [isShow]=\"isShow()\"\n [form]=\"subForm.form\"\n [actionBtns]=\"actionBtns()\"\n [formSchema]=\"formSchema()\"\n [childrenFormSchemaMap]=\"childrenFormSchemaMap\"\n (onDeleteRowFunc)=\"\n deleteRowClicked(subForm.index, subForm.form, {\n btn: $event?.btn\n })\n \"\n (onActionButtonClick)=\"\n handleActionButtonClick(subForm.index, subForm.form, $event)\n \"></tr>\n } @empty {\n <tr>\n <td class=\"text-center\" [colSpan]=\"formSchema()?.length\">\n {{ 'There are no items' | appTranslate | async }}\n </td>\n </tr>\n }\n </tbody>\n </table>\n </div>\n\n <div\n class=\"\"\n [hidden]=\"\n !usePaginator() || !filteredFormArrayLength() || filteredFormArrayLength() < pageSize()\n \">\n <paginator\n #paginatorTag\n [arrayLength]=\"filteredFormArrayLength()\"\n (pageChanged)=\"pageChanged($event)\"\n [pageSize]=\"pageSize()\"\n [resetIndexFunc]=\"filterForm.valueChanges\" />\n </div>\n </div>\n</div>\n", styles: ["tr{vertical-align:top}:host ::ng-deep .text-center input{text-align:center}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "component", type: BtnComponent, selector: "app-btn", inputs: ["formSchema", "debug", "centerBtn", "danger", "warning", "verbose", "loading", "icon", "rightIcon", "leftIcon", "type", "group", "actionType", "animate", "excludeLogging", "loggingValue", "badge", "class", "customIcon", "form", "forms", "help", "iconBtn", "mclass", "showHelpIcon", "rightCustomIcon", "leftCustomIcon", "text", "valid", "mini", "onFormInvalid", "disabled"], outputs: ["loadingChange", "leftCustomIconChange", "mclick", "disabledChange"] }, { kind: "component", type: FormGeneratorComponent, selector: "form-generator", inputs: ["keyField", "presetValueForSingleOption", "isCreate", "submitOnEnterKey", "submitFunc", "submitBtnText", "submitBtnTemplate", "submitSuccessText", "showSubmitBtn", "gridStyle", "gridMDStyle", "gridLGStyle", "gridXXLStyle", "formGridClass", "useLoader", "loading", "form", "formSchema", "formSchemaNoForm", "isShow"], outputs: ["onSubmit", "mchange", "saved", "formChange"] }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: MatExpansionModule }, { kind: "ngmodule", type: MatTabsModule }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: PaginatorComponent, selector: "paginator", inputs: ["pageSize", "pageIndex", "arrayLength", "resetIndexFunc", "pageSizeOptions"], outputs: ["pageChanged"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "component", type: TableInputRowComponent, selector: "tr[table-input-row]", inputs: ["isShow", "hideAdd", "actionBtns", "childrenFormSchemaMap"], outputs: ["onDeleteRowFunc", "onAddRowFunc", "onActionButtonClick"] }, { kind: "pipe", type: SDKTranslatePipe, name: "appTranslate" }] }); }
|
|
15406
15406
|
}
|
|
15407
15407
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableInputComponent, decorators: [{
|
|
15408
15408
|
type: Component,
|
|
@@ -15438,7 +15438,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
|
|
|
15438
15438
|
SDKTranslatePipe,
|
|
15439
15439
|
FilterFormArrayGroupPipe,
|
|
15440
15440
|
ValidationMessageComponent,
|
|
15441
|
-
], providers: [FilterFormArrayGroupPipe, PaginatorPipe], template: "<div class=\"table-input\">\n @if (filterForms()?.length) {\n <div class=\"mb-3 {{ filterContainerClass() }}\">\n <div class=\"d-flex\">\n <app-btn\n text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n </div>\n <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n <form-generator
|
|
15441
|
+
], providers: [FilterFormArrayGroupPipe, PaginatorPipe], template: "<div class=\"table-input\">\n @if (filterForms()?.length) {\n <div class=\"mb-3 {{ filterContainerClass() }}\">\n <div class=\"d-flex\">\n <app-btn\n text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n </div>\n <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n <form-generator\n [form]=\"filterForm\"\n [formSchema]=\"filterForms()\"\n [gridLGStyle]=\"3\"\n [showSubmitBtn]=\"false\"\n (mchange)=\"resetPaginator()\" />\n <div class=\"d-flex justify-content-end\">\n <app-btn type=\"danger-outline\" text=\"Clear\" (mclick)=\"filterForm.reset()\" />\n </div>\n </div>\n </div>\n }\n\n <div class=\"bg-white\" [ngClass]=\"{ 'border rounded-10': border() }\">\n <div class=\" \">\n <table class=\" {{ tableClass() }} \" [ngClass]=\"{ 'is-show-form': isShow() }\">\n <thead (click)=\"utilityService.logForm(filteredFormArray())\">\n <tr class=\"text-center\">\n @for (item of formSchema(); track item.label) {\n <th class=\"{{ item.cls }}\" (click)=\"logColumn(item)\">\n {{ item.label | appTranslate | async }}\n {{ item.isRequired ? '*' : '' }}\n </th>\n }\n @if (!isShow()) {\n <th></th>\n <th></th>\n @for (actionBtn of actionBtns(); track actionBtn) {\n <th></th>\n }\n }\n </tr>\n </thead>\n <tbody>\n @for (subForm of paginatedAndFilteredFormArray(); track subForm.id; let i = $index) {\n <tr\n table-input-row\n (onAddRowFunc)=\"addRowClicked(subForm.index)\"\n [isShow]=\"isShow()\"\n [form]=\"subForm.form\"\n [actionBtns]=\"actionBtns()\"\n [formSchema]=\"formSchema()\"\n [childrenFormSchemaMap]=\"childrenFormSchemaMap\"\n (onDeleteRowFunc)=\"\n deleteRowClicked(subForm.index, subForm.form, {\n btn: $event?.btn\n })\n \"\n (onActionButtonClick)=\"\n handleActionButtonClick(subForm.index, subForm.form, $event)\n \"></tr>\n } @empty {\n <tr>\n <td class=\"text-center\" [colSpan]=\"formSchema()?.length\">\n {{ 'There are no items' | appTranslate | async }}\n </td>\n </tr>\n }\n </tbody>\n </table>\n </div>\n\n <div\n class=\"\"\n [hidden]=\"\n !usePaginator() || !filteredFormArrayLength() || filteredFormArrayLength() < pageSize()\n \">\n <paginator\n #paginatorTag\n [arrayLength]=\"filteredFormArrayLength()\"\n (pageChanged)=\"pageChanged($event)\"\n [pageSize]=\"pageSize()\"\n [resetIndexFunc]=\"filterForm.valueChanges\" />\n </div>\n </div>\n</div>\n", styles: ["tr{vertical-align:top}:host ::ng-deep .text-center input{text-align:center}\n"] }]
|
|
15442
15442
|
}], propDecorators: { _pageSize: [{
|
|
15443
15443
|
type: Input,
|
|
15444
15444
|
args: ['pageSize']
|