special-forms 0.0.1
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/README.md +24 -0
- package/esm2020/lib/components/index.mjs +22 -0
- package/esm2020/lib/components/special-autocomplete/special-autocomplete.component.mjs +61 -0
- package/esm2020/lib/components/special-autocomplete/special-autocomplete.interface.mjs +2 -0
- package/esm2020/lib/components/special-autocomplete/special-autocomplete.module.mjs +47 -0
- package/esm2020/lib/components/special-checkbox/special-checkbox.component.mjs +20 -0
- package/esm2020/lib/components/special-checkbox/special-checkbox.interface.mjs +2 -0
- package/esm2020/lib/components/special-checkbox/special-checkbox.module.mjs +47 -0
- package/esm2020/lib/components/special-datepicker/special-datepicker.component.mjs +24 -0
- package/esm2020/lib/components/special-datepicker/special-datepicker.interface.mjs +2 -0
- package/esm2020/lib/components/special-datepicker/special-datepicker.module.mjs +48 -0
- package/esm2020/lib/components/special-dropdown/special-dropdown.component.mjs +35 -0
- package/esm2020/lib/components/special-dropdown/special-dropdown.interface.mjs +2 -0
- package/esm2020/lib/components/special-dropdown/special-dropdown.module.mjs +43 -0
- package/esm2020/lib/components/special-form/special-form.component.mjs +97 -0
- package/esm2020/lib/components/special-form/special-form.module.mjs +68 -0
- package/esm2020/lib/components/special-input/special-input.component.mjs +42 -0
- package/esm2020/lib/components/special-input/special-input.interface.mjs +2 -0
- package/esm2020/lib/components/special-input/special-input.module.mjs +44 -0
- package/esm2020/lib/components/special-label/special-label.component.mjs +25 -0
- package/esm2020/lib/components/special-label/special-label.interface.mjs +2 -0
- package/esm2020/lib/components/special-label/special-label.module.mjs +47 -0
- package/esm2020/lib/components/special-multiple-autocomplete/special-multiple-autocomplete.component.mjs +82 -0
- package/esm2020/lib/components/special-multiple-autocomplete/special-multiple-autocomplete.interface.mjs +2 -0
- package/esm2020/lib/components/special-multiple-autocomplete/special-multiple-autocomplete.module.mjs +51 -0
- package/esm2020/lib/components/special-text-area/special-text-area.component.mjs +30 -0
- package/esm2020/lib/components/special-text-area/special-text-area.interface.mjs +2 -0
- package/esm2020/lib/components/special-text-area/special-text-area.module.mjs +44 -0
- package/esm2020/lib/components/special-upload/special-upload.component.mjs +69 -0
- package/esm2020/lib/components/special-upload/special-upload.interface.mjs +2 -0
- package/esm2020/lib/components/special-upload/special-upload.module.mjs +43 -0
- package/esm2020/lib/core/aux-data/control-types.enum.mjs +18 -0
- package/esm2020/lib/core/forms/special-forms.mjs +238 -0
- package/esm2020/lib/core/interfaces/field-basics.interfaces.mjs +2 -0
- package/esm2020/lib/core/interfaces/form.interfaces.mjs +2 -0
- package/esm2020/lib/core/services/index.mjs +3 -0
- package/esm2020/lib/core/services/special-form-builder/special-form-builder.service.mjs +156 -0
- package/esm2020/lib/pipes/controls-list-pipe/controls-list.pipe.mjs +18 -0
- package/esm2020/lib/pipes/controls-list-pipe/controls-list.pipe.module.mjs +18 -0
- package/esm2020/lib/pipes/error-message-pipe/error.pipe.mjs +22 -0
- package/esm2020/lib/pipes/error-message-pipe/error.pipe.module.mjs +20 -0
- package/esm2020/lib/pipes/index.mjs +3 -0
- package/esm2020/lib/pipes/text-by-function/text-by-function.pipe.mjs +22 -0
- package/esm2020/lib/pipes/text-by-function/text-by-function.pipe.module.mjs +20 -0
- package/esm2020/public-api.mjs +6 -0
- package/esm2020/special-forms.mjs +5 -0
- package/fesm2015/special-forms.mjs +1292 -0
- package/fesm2015/special-forms.mjs.map +1 -0
- package/fesm2020/special-forms.mjs +1319 -0
- package/fesm2020/special-forms.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/components/index.d.ts +21 -0
- package/lib/components/special-autocomplete/special-autocomplete.component.d.ts +19 -0
- package/lib/components/special-autocomplete/special-autocomplete.interface.d.ts +18 -0
- package/lib/components/special-autocomplete/special-autocomplete.module.d.ts +15 -0
- package/lib/components/special-checkbox/special-checkbox.component.d.ts +11 -0
- package/lib/components/special-checkbox/special-checkbox.interface.d.ts +10 -0
- package/lib/components/special-checkbox/special-checkbox.module.d.ts +14 -0
- package/lib/components/special-datepicker/special-datepicker.component.d.ts +12 -0
- package/lib/components/special-datepicker/special-datepicker.interface.d.ts +11 -0
- package/lib/components/special-datepicker/special-datepicker.module.d.ts +15 -0
- package/lib/components/special-dropdown/special-dropdown.component.d.ts +11 -0
- package/lib/components/special-dropdown/special-dropdown.interface.d.ts +16 -0
- package/lib/components/special-dropdown/special-dropdown.module.d.ts +14 -0
- package/lib/components/special-form/special-form.component.d.ts +31 -0
- package/lib/components/special-form/special-form.module.d.ts +19 -0
- package/lib/components/special-input/special-input.component.d.ts +15 -0
- package/lib/components/special-input/special-input.interface.d.ts +15 -0
- package/lib/components/special-input/special-input.module.d.ts +14 -0
- package/lib/components/special-label/special-label.component.d.ts +13 -0
- package/lib/components/special-label/special-label.interface.d.ts +12 -0
- package/lib/components/special-label/special-label.module.d.ts +15 -0
- package/lib/components/special-multiple-autocomplete/special-multiple-autocomplete.component.d.ts +22 -0
- package/lib/components/special-multiple-autocomplete/special-multiple-autocomplete.interface.d.ts +18 -0
- package/lib/components/special-multiple-autocomplete/special-multiple-autocomplete.module.d.ts +16 -0
- package/lib/components/special-text-area/special-text-area.component.d.ts +13 -0
- package/lib/components/special-text-area/special-text-area.interface.d.ts +7 -0
- package/lib/components/special-text-area/special-text-area.module.d.ts +14 -0
- package/lib/components/special-upload/special-upload.component.d.ts +21 -0
- package/lib/components/special-upload/special-upload.interface.d.ts +10 -0
- package/lib/components/special-upload/special-upload.module.d.ts +13 -0
- package/lib/core/aux-data/control-types.enum.d.ts +16 -0
- package/lib/core/forms/special-forms.d.ts +110 -0
- package/lib/core/interfaces/field-basics.interfaces.d.ts +22 -0
- package/lib/core/interfaces/form.interfaces.d.ts +51 -0
- package/lib/core/services/index.d.ts +2 -0
- package/lib/core/services/special-form-builder/special-form-builder.service.d.ts +25 -0
- package/lib/pipes/controls-list-pipe/controls-list.pipe.d.ts +11 -0
- package/lib/pipes/controls-list-pipe/controls-list.pipe.module.d.ts +8 -0
- package/lib/pipes/error-message-pipe/error.pipe.d.ts +12 -0
- package/lib/pipes/error-message-pipe/error.pipe.module.d.ts +8 -0
- package/lib/pipes/index.d.ts +2 -0
- package/lib/pipes/text-by-function/text-by-function.pipe.d.ts +7 -0
- package/lib/pipes/text-by-function/text-by-function.pipe.module.d.ts +8 -0
- package/package.json +31 -0
- package/public-api.d.ts +2 -0
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { MatAutocompleteModule } from '@angular/material/autocomplete';
|
|
4
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
5
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
6
|
+
import { ReactiveFormsModule } from '@angular/forms';
|
|
7
|
+
import { ErrorMessagePipeModule, TextByFunctionPipeModule } from '../../pipes';
|
|
8
|
+
import { MatInputModule } from '@angular/material/input';
|
|
9
|
+
import { MatChipsModule } from '@angular/material/chips';
|
|
10
|
+
import { SpecialMultipleAutocompleteComponent } from './special-multiple-autocomplete.component';
|
|
11
|
+
import * as i0 from "@angular/core";
|
|
12
|
+
export class SpecialMultipleAutocompleteModule {
|
|
13
|
+
}
|
|
14
|
+
SpecialMultipleAutocompleteModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: SpecialMultipleAutocompleteModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
15
|
+
SpecialMultipleAutocompleteModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.1.3", ngImport: i0, type: SpecialMultipleAutocompleteModule, declarations: [SpecialMultipleAutocompleteComponent], imports: [MatInputModule,
|
|
16
|
+
CommonModule,
|
|
17
|
+
MatAutocompleteModule,
|
|
18
|
+
MatIconModule,
|
|
19
|
+
ReactiveFormsModule,
|
|
20
|
+
MatButtonModule,
|
|
21
|
+
ErrorMessagePipeModule,
|
|
22
|
+
TextByFunctionPipeModule,
|
|
23
|
+
MatChipsModule], exports: [SpecialMultipleAutocompleteComponent] });
|
|
24
|
+
SpecialMultipleAutocompleteModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: SpecialMultipleAutocompleteModule, imports: [MatInputModule,
|
|
25
|
+
CommonModule,
|
|
26
|
+
MatAutocompleteModule,
|
|
27
|
+
MatIconModule,
|
|
28
|
+
ReactiveFormsModule,
|
|
29
|
+
MatButtonModule,
|
|
30
|
+
ErrorMessagePipeModule,
|
|
31
|
+
TextByFunctionPipeModule,
|
|
32
|
+
MatChipsModule] });
|
|
33
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: SpecialMultipleAutocompleteModule, decorators: [{
|
|
34
|
+
type: NgModule,
|
|
35
|
+
args: [{
|
|
36
|
+
declarations: [SpecialMultipleAutocompleteComponent],
|
|
37
|
+
imports: [
|
|
38
|
+
MatInputModule,
|
|
39
|
+
CommonModule,
|
|
40
|
+
MatAutocompleteModule,
|
|
41
|
+
MatIconModule,
|
|
42
|
+
ReactiveFormsModule,
|
|
43
|
+
MatButtonModule,
|
|
44
|
+
ErrorMessagePipeModule,
|
|
45
|
+
TextByFunctionPipeModule,
|
|
46
|
+
MatChipsModule,
|
|
47
|
+
],
|
|
48
|
+
exports: [SpecialMultipleAutocompleteComponent],
|
|
49
|
+
}]
|
|
50
|
+
}] });
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3BlY2lhbC1tdWx0aXBsZS1hdXRvY29tcGxldGUubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlY2lhbC1mb3Jtcy9zcmMvbGliL2NvbXBvbmVudHMvc3BlY2lhbC1tdWx0aXBsZS1hdXRvY29tcGxldGUvc3BlY2lhbC1tdWx0aXBsZS1hdXRvY29tcGxldGUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDckQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLHdCQUF3QixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQy9FLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLG9DQUFvQyxFQUFFLE1BQU0sMkNBQTJDLENBQUM7O0FBa0JqRyxNQUFNLE9BQU8saUNBQWlDOzs4SEFBakMsaUNBQWlDOytIQUFqQyxpQ0FBaUMsaUJBZjdCLG9DQUFvQyxhQUVqRCxjQUFjO1FBQ2QsWUFBWTtRQUNaLHFCQUFxQjtRQUNyQixhQUFhO1FBQ2IsbUJBQW1CO1FBQ25CLGVBQWU7UUFDZixzQkFBc0I7UUFDdEIsd0JBQXdCO1FBQ3hCLGNBQWMsYUFHTixvQ0FBb0M7K0hBRW5DLGlDQUFpQyxZQWIxQyxjQUFjO1FBQ2QsWUFBWTtRQUNaLHFCQUFxQjtRQUNyQixhQUFhO1FBQ2IsbUJBQW1CO1FBQ25CLGVBQWU7UUFDZixzQkFBc0I7UUFDdEIsd0JBQXdCO1FBQ3hCLGNBQWM7MkZBS0wsaUNBQWlDO2tCQWhCN0MsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxvQ0FBb0MsQ0FBQztvQkFDcEQsT0FBTyxFQUFFO3dCQUNQLGNBQWM7d0JBQ2QsWUFBWTt3QkFDWixxQkFBcUI7d0JBQ3JCLGFBQWE7d0JBQ2IsbUJBQW1CO3dCQUNuQixlQUFlO3dCQUNmLHNCQUFzQjt3QkFDdEIsd0JBQXdCO3dCQUN4QixjQUFjO3FCQUVmO29CQUNELE9BQU8sRUFBRSxDQUFDLG9DQUFvQyxDQUFDO2lCQUNoRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTWF0QXV0b2NvbXBsZXRlTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYXV0b2NvbXBsZXRlJztcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQgeyBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgRXJyb3JNZXNzYWdlUGlwZU1vZHVsZSwgVGV4dEJ5RnVuY3Rpb25QaXBlTW9kdWxlIH0gZnJvbSAnLi4vLi4vcGlwZXMnO1xuaW1wb3J0IHsgTWF0SW5wdXRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pbnB1dCc7XG5pbXBvcnQgeyBNYXRDaGlwc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NoaXBzJztcbmltcG9ydCB7IFNwZWNpYWxNdWx0aXBsZUF1dG9jb21wbGV0ZUNvbXBvbmVudCB9IGZyb20gJy4vc3BlY2lhbC1tdWx0aXBsZS1hdXRvY29tcGxldGUuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbU3BlY2lhbE11bHRpcGxlQXV0b2NvbXBsZXRlQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW1xuICAgIE1hdElucHV0TW9kdWxlLFxuICAgIENvbW1vbk1vZHVsZSxcbiAgICBNYXRBdXRvY29tcGxldGVNb2R1bGUsXG4gICAgTWF0SWNvbk1vZHVsZSxcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxuICAgIE1hdEJ1dHRvbk1vZHVsZSxcbiAgICBFcnJvck1lc3NhZ2VQaXBlTW9kdWxlLFxuICAgIFRleHRCeUZ1bmN0aW9uUGlwZU1vZHVsZSxcbiAgICBNYXRDaGlwc01vZHVsZSxcblxuICBdLFxuICBleHBvcnRzOiBbU3BlY2lhbE11bHRpcGxlQXV0b2NvbXBsZXRlQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgU3BlY2lhbE11bHRpcGxlQXV0b2NvbXBsZXRlTW9kdWxlIHt9XG4iXX0=
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy } from '@angular/core';
|
|
2
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
import * as i2 from "@angular/cdk/text-field";
|
|
6
|
+
import * as i3 from "@angular/material/form-field";
|
|
7
|
+
import * as i4 from "@angular/material/input";
|
|
8
|
+
import * as i5 from "@angular/material/icon";
|
|
9
|
+
import * as i6 from "@angular/forms";
|
|
10
|
+
import * as i7 from "../../pipes/error-message-pipe/error.pipe";
|
|
11
|
+
export class SpecialTextAreaComponent {
|
|
12
|
+
constructor() {
|
|
13
|
+
this.onBlur = new EventEmitter();
|
|
14
|
+
this.onEnter = new EventEmitter();
|
|
15
|
+
}
|
|
16
|
+
ngOnInit() { }
|
|
17
|
+
}
|
|
18
|
+
SpecialTextAreaComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: SpecialTextAreaComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
19
|
+
SpecialTextAreaComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.3", type: SpecialTextAreaComponent, selector: "sp-text-area", inputs: { control: "control" }, outputs: { onBlur: "onBlur", onEnter: "onEnter" }, ngImport: i0, template: "<mat-form-field\n *ngIf=\"control\"\n [id]=\"control.elementId\"\n class=\"w-full {{ control.styleClasses }}\"\n [appearance]=\"control.label ? 'outline' : 'standard'\"\n>\n <mat-label *ngIf=\"control.label\">{{ control.label }}</mat-label>\n <textarea\n cdkTextareaAutosize\n #autosize=\"cdkTextareaAutosize\"\n cdkAutosizeMinRows=\"1\"\n cdkAutosizeMaxRows=\"5\"\n matInput\n (blur)=\"onBlur.emit(control.value)\"\n (keydown.enter)=\"onEnter.emit(control.value)\"\n [type]=\"control.settings?.type || 'text'\"\n [readonly]=\"control.readOnly\"\n [required]=\"control.required\"\n [placeholder]=\"control.placeholder\"\n [formControl]=\"control\"\n ></textarea>\n <mat-icon *ngIf=\"control.icon\" matPrefix>{{ control.icon }} </mat-icon>\n <mat-hint>\n {{ control.tooltip }}\n </mat-hint>\n <mat-error>\n {{ control.errors | errorMessage: control.errorMessages }}\n </mat-error>\n</mat-form-field>\n", styles: [":host{display:contents}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.CdkTextareaAutosize, selector: "textarea[cdkTextareaAutosize]", inputs: ["cdkAutosizeMinRows", "cdkAutosizeMaxRows", "cdkTextareaAutosize", "placeholder"], exportAs: ["cdkTextareaAutosize"] }, { kind: "directive", type: i3.MatError, selector: "mat-error", inputs: ["id"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatPrefix, selector: "[matPrefix]" }, { kind: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i6.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "pipe", type: i7.ErrorMessagePipe, name: "errorMessage" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
20
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: SpecialTextAreaComponent, decorators: [{
|
|
21
|
+
type: Component,
|
|
22
|
+
args: [{ selector: 'sp-text-area', changeDetection: ChangeDetectionStrategy.OnPush, template: "<mat-form-field\n *ngIf=\"control\"\n [id]=\"control.elementId\"\n class=\"w-full {{ control.styleClasses }}\"\n [appearance]=\"control.label ? 'outline' : 'standard'\"\n>\n <mat-label *ngIf=\"control.label\">{{ control.label }}</mat-label>\n <textarea\n cdkTextareaAutosize\n #autosize=\"cdkTextareaAutosize\"\n cdkAutosizeMinRows=\"1\"\n cdkAutosizeMaxRows=\"5\"\n matInput\n (blur)=\"onBlur.emit(control.value)\"\n (keydown.enter)=\"onEnter.emit(control.value)\"\n [type]=\"control.settings?.type || 'text'\"\n [readonly]=\"control.readOnly\"\n [required]=\"control.required\"\n [placeholder]=\"control.placeholder\"\n [formControl]=\"control\"\n ></textarea>\n <mat-icon *ngIf=\"control.icon\" matPrefix>{{ control.icon }} </mat-icon>\n <mat-hint>\n {{ control.tooltip }}\n </mat-hint>\n <mat-error>\n {{ control.errors | errorMessage: control.errorMessages }}\n </mat-error>\n</mat-form-field>\n", styles: [":host{display:contents}\n"] }]
|
|
23
|
+
}], ctorParameters: function () { return []; }, propDecorators: { control: [{
|
|
24
|
+
type: Input
|
|
25
|
+
}], onBlur: [{
|
|
26
|
+
type: Output
|
|
27
|
+
}], onEnter: [{
|
|
28
|
+
type: Output
|
|
29
|
+
}] } });
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3BlY2lhbC10ZXh0LWFyZWEuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlY2lhbC1mb3Jtcy9zcmMvbGliL2NvbXBvbmVudHMvc3BlY2lhbC10ZXh0LWFyZWEvc3BlY2lhbC10ZXh0LWFyZWEuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlY2lhbC1mb3Jtcy9zcmMvbGliL2NvbXBvbmVudHMvc3BlY2lhbC10ZXh0LWFyZWEvc3BlY2lhbC10ZXh0LWFyZWEuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3hELE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7Ozs7OztBQVMvRSxNQUFNLE9BQU8sd0JBQXdCO0lBTW5DO1FBSFUsV0FBTSxHQUFzQixJQUFJLFlBQVksRUFBRSxDQUFDO1FBQy9DLFlBQU8sR0FBc0IsSUFBSSxZQUFZLEVBQUUsQ0FBQztJQUUzQyxDQUFDO0lBRWhCLFFBQVEsS0FBVSxDQUFDOztxSEFSUix3QkFBd0I7eUdBQXhCLHdCQUF3Qix1SUNWckMsNDdCQTZCQTsyRkRuQmEsd0JBQXdCO2tCQU5wQyxTQUFTOytCQUNFLGNBQWMsbUJBR1AsdUJBQXVCLENBQUMsTUFBTTswRUFHdEMsT0FBTztzQkFBZixLQUFLO2dCQUVJLE1BQU07c0JBQWYsTUFBTTtnQkFDRyxPQUFPO3NCQUFoQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFNwZWNpYWxGb3JtQ29udHJvbCB9IGZyb20gJy4uLy4uL2NvcmUvZm9ybXMvc3BlY2lhbC1mb3Jtcyc7XG5pbXBvcnQgeyBJVGV4dEFyZWFGaWVsZCB9IGZyb20gJy4vc3BlY2lhbC10ZXh0LWFyZWEuaW50ZXJmYWNlJztcbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NwLXRleHQtYXJlYScsXG4gIHRlbXBsYXRlVXJsOiAnLi9zcGVjaWFsLXRleHQtYXJlYS5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3NwZWNpYWwtdGV4dC1hcmVhLmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBTcGVjaWFsVGV4dEFyZWFDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKSBjb250cm9sOiBTcGVjaWFsRm9ybUNvbnRyb2w8SVRleHRBcmVhRmllbGQ+O1xuXG4gIEBPdXRwdXQoKSBvbkJsdXI6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuICBAT3V0cHV0KCkgb25FbnRlcjogRXZlbnRFbWl0dGVyPGFueT4gPSBuZXcgRXZlbnRFbWl0dGVyKCk7XG5cbiAgY29uc3RydWN0b3IoKSB7fVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge31cbn1cbiIsIjxtYXQtZm9ybS1maWVsZFxuICAqbmdJZj1cImNvbnRyb2xcIlxuICBbaWRdPVwiY29udHJvbC5lbGVtZW50SWRcIlxuICBjbGFzcz1cInctZnVsbCB7eyBjb250cm9sLnN0eWxlQ2xhc3NlcyB9fVwiXG4gIFthcHBlYXJhbmNlXT1cImNvbnRyb2wubGFiZWwgPyAnb3V0bGluZScgOiAnc3RhbmRhcmQnXCJcbj5cbiAgPG1hdC1sYWJlbCAqbmdJZj1cImNvbnRyb2wubGFiZWxcIj57eyBjb250cm9sLmxhYmVsIH19PC9tYXQtbGFiZWw+XG4gIDx0ZXh0YXJlYVxuICAgIGNka1RleHRhcmVhQXV0b3NpemVcbiAgICAjYXV0b3NpemU9XCJjZGtUZXh0YXJlYUF1dG9zaXplXCJcbiAgICBjZGtBdXRvc2l6ZU1pblJvd3M9XCIxXCJcbiAgICBjZGtBdXRvc2l6ZU1heFJvd3M9XCI1XCJcbiAgICBtYXRJbnB1dFxuICAgIChibHVyKT1cIm9uQmx1ci5lbWl0KGNvbnRyb2wudmFsdWUpXCJcbiAgICAoa2V5ZG93bi5lbnRlcik9XCJvbkVudGVyLmVtaXQoY29udHJvbC52YWx1ZSlcIlxuICAgIFt0eXBlXT1cImNvbnRyb2wuc2V0dGluZ3M/LnR5cGUgfHwgJ3RleHQnXCJcbiAgICBbcmVhZG9ubHldPVwiY29udHJvbC5yZWFkT25seVwiXG4gICAgW3JlcXVpcmVkXT1cImNvbnRyb2wucmVxdWlyZWRcIlxuICAgIFtwbGFjZWhvbGRlcl09XCJjb250cm9sLnBsYWNlaG9sZGVyXCJcbiAgICBbZm9ybUNvbnRyb2xdPVwiY29udHJvbFwiXG4gID48L3RleHRhcmVhPlxuICA8bWF0LWljb24gKm5nSWY9XCJjb250cm9sLmljb25cIiBtYXRQcmVmaXg+e3sgY29udHJvbC5pY29uIH19IDwvbWF0LWljb24+XG4gIDxtYXQtaGludD5cbiAgICB7eyBjb250cm9sLnRvb2x0aXAgfX1cbiAgPC9tYXQtaGludD5cbiAgPG1hdC1lcnJvcj5cbiAgICB7eyBjb250cm9sLmVycm9ycyB8IGVycm9yTWVzc2FnZTogY29udHJvbC5lcnJvck1lc3NhZ2VzIH19XG4gIDwvbWF0LWVycm9yPlxuPC9tYXQtZm9ybS1maWVsZD5cbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3BlY2lhbC10ZXh0LWFyZWEuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlY2lhbC1mb3Jtcy9zcmMvbGliL2NvbXBvbmVudHMvc3BlY2lhbC10ZXh0LWFyZWEvc3BlY2lhbC10ZXh0LWFyZWEuaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFQ29udHJvbFR5cGVzIH0gZnJvbSAnLi4vLi4vY29yZS9hdXgtZGF0YS9jb250cm9sLXR5cGVzLmVudW0nO1xyXG5pbXBvcnQgeyBJRmllbGREYXRhIH0gZnJvbSAnLi4vLi4vY29yZS9pbnRlcmZhY2VzL2ZpZWxkLWJhc2ljcy5pbnRlcmZhY2VzJztcclxuXHJcbmV4cG9ydCB0eXBlIElUZXh0QXJlYVNldHRpbmdzID0ge307XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIElUZXh0QXJlYUZpZWxkIGV4dGVuZHMgSUZpZWxkRGF0YSB7XHJcbiAgc2V0dGluZ3M6IElUZXh0QXJlYVNldHRpbmdzO1xyXG4gIHR5cGU6IEVDb250cm9sVHlwZXMudGV4dEFyZWE7XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { SpecialTextAreaComponent } from './special-text-area.component';
|
|
4
|
+
import { MatInputModule } from '@angular/material/input';
|
|
5
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
6
|
+
import { InputMaskModule } from '@ngneat/input-mask';
|
|
7
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
8
|
+
import { ReactiveFormsModule } from '@angular/forms';
|
|
9
|
+
import { ErrorMessagePipeModule } from '../../pipes';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
export class SpecialTextAreaModule {
|
|
12
|
+
}
|
|
13
|
+
SpecialTextAreaModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: SpecialTextAreaModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
14
|
+
SpecialTextAreaModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.1.3", ngImport: i0, type: SpecialTextAreaModule, declarations: [SpecialTextAreaComponent], imports: [InputMaskModule,
|
|
15
|
+
CommonModule,
|
|
16
|
+
MatInputModule,
|
|
17
|
+
MatIconModule,
|
|
18
|
+
ReactiveFormsModule,
|
|
19
|
+
MatButtonModule,
|
|
20
|
+
ErrorMessagePipeModule], exports: [SpecialTextAreaComponent] });
|
|
21
|
+
SpecialTextAreaModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: SpecialTextAreaModule, imports: [InputMaskModule,
|
|
22
|
+
CommonModule,
|
|
23
|
+
MatInputModule,
|
|
24
|
+
MatIconModule,
|
|
25
|
+
ReactiveFormsModule,
|
|
26
|
+
MatButtonModule,
|
|
27
|
+
ErrorMessagePipeModule] });
|
|
28
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: SpecialTextAreaModule, decorators: [{
|
|
29
|
+
type: NgModule,
|
|
30
|
+
args: [{
|
|
31
|
+
declarations: [SpecialTextAreaComponent],
|
|
32
|
+
imports: [
|
|
33
|
+
InputMaskModule,
|
|
34
|
+
CommonModule,
|
|
35
|
+
MatInputModule,
|
|
36
|
+
MatIconModule,
|
|
37
|
+
ReactiveFormsModule,
|
|
38
|
+
MatButtonModule,
|
|
39
|
+
ErrorMessagePipeModule,
|
|
40
|
+
],
|
|
41
|
+
exports: [SpecialTextAreaComponent],
|
|
42
|
+
}]
|
|
43
|
+
}] });
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3BlY2lhbC10ZXh0LWFyZWEubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlY2lhbC1mb3Jtcy9zcmMvbGliL2NvbXBvbmVudHMvc3BlY2lhbC10ZXh0LWFyZWEvc3BlY2lhbC10ZXh0LWFyZWEubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ3pFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxhQUFhLENBQUM7O0FBZXJELE1BQU0sT0FBTyxxQkFBcUI7O2tIQUFyQixxQkFBcUI7bUhBQXJCLHFCQUFxQixpQkFaakIsd0JBQXdCLGFBRXJDLGVBQWU7UUFDZixZQUFZO1FBQ1osY0FBYztRQUNkLGFBQWE7UUFDYixtQkFBbUI7UUFDbkIsZUFBZTtRQUNmLHNCQUFzQixhQUVkLHdCQUF3QjttSEFFdkIscUJBQXFCLFlBVjlCLGVBQWU7UUFDZixZQUFZO1FBQ1osY0FBYztRQUNkLGFBQWE7UUFDYixtQkFBbUI7UUFDbkIsZUFBZTtRQUNmLHNCQUFzQjsyRkFJYixxQkFBcUI7a0JBYmpDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsd0JBQXdCLENBQUM7b0JBQ3hDLE9BQU8sRUFBRTt3QkFDUCxlQUFlO3dCQUNmLFlBQVk7d0JBQ1osY0FBYzt3QkFDZCxhQUFhO3dCQUNiLG1CQUFtQjt3QkFDbkIsZUFBZTt3QkFDZixzQkFBc0I7cUJBQ3ZCO29CQUNELE9BQU8sRUFBRSxDQUFDLHdCQUF3QixDQUFDO2lCQUNwQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgU3BlY2lhbFRleHRBcmVhQ29tcG9uZW50IH0gZnJvbSAnLi9zcGVjaWFsLXRleHQtYXJlYS5jb21wb25lbnQnO1xuaW1wb3J0IHsgTWF0SW5wdXRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pbnB1dCc7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgSW5wdXRNYXNrTW9kdWxlIH0gZnJvbSAnQG5nbmVhdC9pbnB1dC1tYXNrJztcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcbmltcG9ydCB7IFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBFcnJvck1lc3NhZ2VQaXBlTW9kdWxlIH0gZnJvbSAnLi4vLi4vcGlwZXMnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtTcGVjaWFsVGV4dEFyZWFDb21wb25lbnRdLFxuICBpbXBvcnRzOiBbXG4gICAgSW5wdXRNYXNrTW9kdWxlLFxuICAgIENvbW1vbk1vZHVsZSxcbiAgICBNYXRJbnB1dE1vZHVsZSxcbiAgICBNYXRJY29uTW9kdWxlLFxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gICAgTWF0QnV0dG9uTW9kdWxlLFxuICAgIEVycm9yTWVzc2FnZVBpcGVNb2R1bGUsXG4gIF0sXG4gIGV4cG9ydHM6IFtTcGVjaWFsVGV4dEFyZWFDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBTcGVjaWFsVGV4dEFyZWFNb2R1bGUge31cbiJdfQ==
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { ChangeDetectionStrategy } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/platform-browser";
|
|
5
|
+
import * as i2 from "ngx-dropzone";
|
|
6
|
+
import * as i3 from "@angular/common";
|
|
7
|
+
import * as i4 from "@angular/material/icon";
|
|
8
|
+
import * as i5 from "../../pipes/error-message-pipe/error.pipe";
|
|
9
|
+
export class SpecialUploadComponent {
|
|
10
|
+
constructor(sanitizer) {
|
|
11
|
+
this.sanitizer = sanitizer;
|
|
12
|
+
this.onSelect = new EventEmitter();
|
|
13
|
+
this.previewImages = [];
|
|
14
|
+
}
|
|
15
|
+
set controlSetter(control) {
|
|
16
|
+
this.control = control;
|
|
17
|
+
this.previewImages = control.value;
|
|
18
|
+
}
|
|
19
|
+
ngOnInit() { }
|
|
20
|
+
onSelectMultiple(event) {
|
|
21
|
+
this.previewImages = [
|
|
22
|
+
...this.previewImages,
|
|
23
|
+
...event.addedFiles.map(file => ({
|
|
24
|
+
lastModified: file.lastModified,
|
|
25
|
+
url: this.sanitizer.bypassSecurityTrustUrl(URL.createObjectURL(file))
|
|
26
|
+
}))
|
|
27
|
+
];
|
|
28
|
+
this.control.setValue([
|
|
29
|
+
...this.control.value,
|
|
30
|
+
...event.addedFiles.map(this.fixFileName)
|
|
31
|
+
]);
|
|
32
|
+
this.onSelect.emit(this.control.value);
|
|
33
|
+
this.control.markAsDirty();
|
|
34
|
+
}
|
|
35
|
+
onSelectOne(event) {
|
|
36
|
+
this.previewImages = event.addedFiles.map(file => ({
|
|
37
|
+
lastModified: file.lastModified,
|
|
38
|
+
url: this.sanitizer.bypassSecurityTrustUrl(URL.createObjectURL(file))
|
|
39
|
+
}));
|
|
40
|
+
this.control.setValue(event.addedFiles.map(this.fixFileName));
|
|
41
|
+
this.onSelect.emit(this.control.value);
|
|
42
|
+
this.control.markAsDirty();
|
|
43
|
+
}
|
|
44
|
+
fixFileName(file) {
|
|
45
|
+
return Object.defineProperty(file, 'name', {
|
|
46
|
+
writable: true,
|
|
47
|
+
value: file.name.normalize("NFD").replace(/[\u0300-\u036f]/g, "")
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
clean() {
|
|
51
|
+
this.previewImages = [];
|
|
52
|
+
}
|
|
53
|
+
onRemove(file) {
|
|
54
|
+
this.control.setValue(this.control.value.filter(fl => fl.lastModified !== file.lastModified));
|
|
55
|
+
this.previewImages = this.previewImages.filter(fl => fl.lastModified !== file.lastModified);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
SpecialUploadComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: SpecialUploadComponent, deps: [{ token: i1.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component });
|
|
59
|
+
SpecialUploadComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.3", type: SpecialUploadComponent, selector: "sp-upload", inputs: { controlSetter: ["control", "controlSetter"] }, outputs: { onSelect: "onSelect" }, ngImport: i0, template: "<div class=\"special_upload mb-2\">\n <ngx-dropzone\n class=\"special_upload__dropzone\"\n [ngClass]=\"{\n 'special_upload--error-dashed':\n !!control.errors && (control.dirty || control.touched)\n }\"\n [multiple]=\"control.settings?.multiple\"\n [accept]=\"\n control.settings?.accept\n ? control.settings?.accept\n : 'image/png, .jpeg, .jpg, image/gif'\n \"\n (change)=\"\n control.settings?.multiple\n ? onSelectMultiple($event)\n : onSelectOne($event)\n \"\n >\n <ngx-dropzone-label\n [ngClass]=\"{\n 'special_upload--error':\n !!control.errors && (control.dirty || control.touched)\n }\"\n >\n <mat-icon class=\"special_upload__icon\"*ngIf=\"control.icon\">{{ control.icon }} </mat-icon>\n <h2 class=\"text-base font-bold\">\n {{ control.label }}\n </h2>\n <h3 class=\"text-base\">\n {{ control.placeholder }}\n </h3>\n </ngx-dropzone-label>\n <ngx-dropzone-preview\n *ngFor=\"let file of previewImages\"\n [removable]=\"true\"\n (removed)=\"onRemove(file)\"\n >\n <ngx-dropzone-label class=\"special_upload__card\">\n <img class=\"special_upload__card--image\" [src]=\"file?.url\" alt=\"\" />\n </ngx-dropzone-label>\n </ngx-dropzone-preview>\n </ngx-dropzone>\n <div\n class=\"special_upload--error mt-2\"\n *ngIf=\"!!control.errors && (control.dirty || control.touched)\"\n >\n {{ control.errors | errorMessage: control.errorMessages }}\n </div>\n</div>\n", styles: [":host{display:contents}:host .special-upload{margin-bottom:2rem}:host .special-upload__icon{height:64px;width:64px;font-size:64px}:host .special-upload__card{width:100%;height:100%;margin:0;box-sizing:border-box;display:flex;align-items:center;flex-direction:column}:host .special-upload__card--image{width:100%;height:100%;object-fit:cover}\n"], dependencies: [{ kind: "component", type: i2.NgxDropzoneComponent, selector: "ngx-dropzone, [ngx-dropzone]", inputs: ["accept", "disabled", "multiple", "maxFileSize", "expandable", "disableClick", "processDirectoryDrop", "id", "aria-label", "aria-labelledby", "aria-describedby"], outputs: ["change"] }, { kind: "directive", type: i2.NgxDropzoneLabelDirective, selector: "ngx-dropzone-label" }, { kind: "component", type: i2.NgxDropzonePreviewComponent, selector: "ngx-dropzone-preview", inputs: ["file", "removable"], outputs: ["removed"] }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "pipe", type: i5.ErrorMessagePipe, name: "errorMessage" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
60
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: SpecialUploadComponent, decorators: [{
|
|
61
|
+
type: Component,
|
|
62
|
+
args: [{ selector: 'sp-upload', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"special_upload mb-2\">\n <ngx-dropzone\n class=\"special_upload__dropzone\"\n [ngClass]=\"{\n 'special_upload--error-dashed':\n !!control.errors && (control.dirty || control.touched)\n }\"\n [multiple]=\"control.settings?.multiple\"\n [accept]=\"\n control.settings?.accept\n ? control.settings?.accept\n : 'image/png, .jpeg, .jpg, image/gif'\n \"\n (change)=\"\n control.settings?.multiple\n ? onSelectMultiple($event)\n : onSelectOne($event)\n \"\n >\n <ngx-dropzone-label\n [ngClass]=\"{\n 'special_upload--error':\n !!control.errors && (control.dirty || control.touched)\n }\"\n >\n <mat-icon class=\"special_upload__icon\"*ngIf=\"control.icon\">{{ control.icon }} </mat-icon>\n <h2 class=\"text-base font-bold\">\n {{ control.label }}\n </h2>\n <h3 class=\"text-base\">\n {{ control.placeholder }}\n </h3>\n </ngx-dropzone-label>\n <ngx-dropzone-preview\n *ngFor=\"let file of previewImages\"\n [removable]=\"true\"\n (removed)=\"onRemove(file)\"\n >\n <ngx-dropzone-label class=\"special_upload__card\">\n <img class=\"special_upload__card--image\" [src]=\"file?.url\" alt=\"\" />\n </ngx-dropzone-label>\n </ngx-dropzone-preview>\n </ngx-dropzone>\n <div\n class=\"special_upload--error mt-2\"\n *ngIf=\"!!control.errors && (control.dirty || control.touched)\"\n >\n {{ control.errors | errorMessage: control.errorMessages }}\n </div>\n</div>\n", styles: [":host{display:contents}:host .special-upload{margin-bottom:2rem}:host .special-upload__icon{height:64px;width:64px;font-size:64px}:host .special-upload__card{width:100%;height:100%;margin:0;box-sizing:border-box;display:flex;align-items:center;flex-direction:column}:host .special-upload__card--image{width:100%;height:100%;object-fit:cover}\n"] }]
|
|
63
|
+
}], ctorParameters: function () { return [{ type: i1.DomSanitizer }]; }, propDecorators: { controlSetter: [{
|
|
64
|
+
type: Input,
|
|
65
|
+
args: ['control']
|
|
66
|
+
}], onSelect: [{
|
|
67
|
+
type: Output
|
|
68
|
+
}] } });
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"special-upload.component.js","sourceRoot":"","sources":["../../../../../../projects/special-forms/src/lib/components/special-upload/special-upload.component.ts","../../../../../../projects/special-forms/src/lib/components/special-upload/special-upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { SpecialFormControl } from '../../core/forms/special-forms';\nimport { IUploadSettings } from './special-upload.interface';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { ChangeDetectionStrategy } from '@angular/core';\n\n@Component({\n  selector: 'sp-upload',\n  templateUrl: './special-upload.component.html',\n  styleUrls: ['./special-upload.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SpecialUploadComponent implements OnInit {\n  control: SpecialFormControl<IUploadSettings>;\n\n  @Input('control') set controlSetter(control) {\n    this.control = control;\n    this.previewImages = control.value;\n  }\n\n  @Output() onSelect: EventEmitter<any> = new EventEmitter();\n\n  previewImages = [];\n\n  constructor( private sanitizer: DomSanitizer) {}\n\n  ngOnInit(): void {}\n\n  onSelectMultiple(event) {\n    this.previewImages = [\n      ...this.previewImages,\n      ...event.addedFiles.map(file =>\n      ({\n        lastModified: file.lastModified,\n        url: this.sanitizer.bypassSecurityTrustUrl(URL.createObjectURL(file))\n      }\n      ))\n    ];\n\n    this.control.setValue(\n      [\n        ...this.control.value,\n        ...event.addedFiles.map(this.fixFileName)\n      ]\n    );\n    this.onSelect.emit(this.control.value)\n    this.control.markAsDirty();\n  }\n\n  onSelectOne(event) {\n    this.previewImages = event.addedFiles.map(file =>\n    ({\n      lastModified: file.lastModified,\n      url: this.sanitizer.bypassSecurityTrustUrl(URL.createObjectURL(file))\n    }))\n\n    this.control.setValue(\n      event.addedFiles.map(this.fixFileName)\n    );\n    this.onSelect.emit(this.control.value)\n    this.control.markAsDirty();\n  }\n\n  fixFileName(file: File) {\n    return Object.defineProperty(file, 'name', {\n      writable: true,\n      value: file.name.normalize(\"NFD\").replace(/[\\u0300-\\u036f]/g, \"\")\n    });\n  }\n\n  clean() {\n    this.previewImages = [];\n  }\n  onRemove(file) {\n    this.control.setValue(this.control.value.filter(fl => fl.lastModified !== file.lastModified));\n    this.previewImages = this.previewImages.filter(fl => fl.lastModified !== file.lastModified)\n  }\n\n}\n","<div class=\"special_upload mb-2\">\n  <ngx-dropzone\n    class=\"special_upload__dropzone\"\n    [ngClass]=\"{\n      'special_upload--error-dashed':\n        !!control.errors && (control.dirty || control.touched)\n    }\"\n    [multiple]=\"control.settings?.multiple\"\n    [accept]=\"\n      control.settings?.accept\n        ? control.settings?.accept\n        : 'image/png, .jpeg, .jpg, image/gif'\n    \"\n    (change)=\"\n      control.settings?.multiple\n        ? onSelectMultiple($event)\n        : onSelectOne($event)\n    \"\n  >\n    <ngx-dropzone-label\n      [ngClass]=\"{\n        'special_upload--error':\n          !!control.errors && (control.dirty || control.touched)\n      }\"\n    >\n      <mat-icon class=\"special_upload__icon\"*ngIf=\"control.icon\">{{ control.icon }} </mat-icon>\n      <h2 class=\"text-base font-bold\">\n        {{ control.label }}\n      </h2>\n      <h3 class=\"text-base\">\n        {{ control.placeholder }}\n      </h3>\n    </ngx-dropzone-label>\n    <ngx-dropzone-preview\n      *ngFor=\"let file of previewImages\"\n      [removable]=\"true\"\n      (removed)=\"onRemove(file)\"\n    >\n      <ngx-dropzone-label class=\"special_upload__card\">\n        <img class=\"special_upload__card--image\" [src]=\"file?.url\" alt=\"\" />\n      </ngx-dropzone-label>\n    </ngx-dropzone-preview>\n  </ngx-dropzone>\n  <div\n    class=\"special_upload--error mt-2\"\n    *ngIf=\"!!control.errors && (control.dirty || control.touched)\"\n  >\n    {{ control.errors | errorMessage: control.errorMessages }}\n  </div>\n</div>\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3BlY2lhbC11cGxvYWQuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlY2lhbC1mb3Jtcy9zcmMvbGliL2NvbXBvbmVudHMvc3BlY2lhbC11cGxvYWQvc3BlY2lhbC11cGxvYWQuaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFQ29udHJvbFR5cGVzIH0gZnJvbSAnLi4vLi4vY29yZS9hdXgtZGF0YS9jb250cm9sLXR5cGVzLmVudW0nO1xyXG5pbXBvcnQgeyBJRmllbGREYXRhIH0gZnJvbSAnLi4vLi4vY29yZS9pbnRlcmZhY2VzL2ZpZWxkLWJhc2ljcy5pbnRlcmZhY2VzJztcclxuXHJcbmV4cG9ydCB0eXBlIElVcGxvYWRTZXR0aW5ncyA9IHtcclxuICBhY2NlcHQ/OiBzdHJpbmcsXHJcbiAgbXVsdGlwbGU/OiBib29sZWFuXHJcbn07XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIElVcGxvYWRGaWVsZCBleHRlbmRzIElGaWVsZERhdGEge1xyXG4gIHNldHRpbmdzOiBJVXBsb2FkU2V0dGluZ3M7XHJcbiAgdHlwZTogRUNvbnRyb2xUeXBlcy51cGxvYWQ7XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { SpecialUploadComponent } from './special-upload.component';
|
|
4
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
5
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
6
|
+
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
7
|
+
import { ErrorMessagePipeModule } from '../../pipes';
|
|
8
|
+
import { NgxDropzoneModule } from 'ngx-dropzone';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
export class SpecialUploadModule {
|
|
11
|
+
}
|
|
12
|
+
SpecialUploadModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: SpecialUploadModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
13
|
+
SpecialUploadModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.1.3", ngImport: i0, type: SpecialUploadModule, declarations: [SpecialUploadComponent], imports: [FormsModule,
|
|
14
|
+
NgxDropzoneModule,
|
|
15
|
+
CommonModule,
|
|
16
|
+
MatIconModule,
|
|
17
|
+
ReactiveFormsModule,
|
|
18
|
+
MatButtonModule,
|
|
19
|
+
ErrorMessagePipeModule], exports: [SpecialUploadComponent] });
|
|
20
|
+
SpecialUploadModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: SpecialUploadModule, imports: [FormsModule,
|
|
21
|
+
NgxDropzoneModule,
|
|
22
|
+
CommonModule,
|
|
23
|
+
MatIconModule,
|
|
24
|
+
ReactiveFormsModule,
|
|
25
|
+
MatButtonModule,
|
|
26
|
+
ErrorMessagePipeModule] });
|
|
27
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: SpecialUploadModule, decorators: [{
|
|
28
|
+
type: NgModule,
|
|
29
|
+
args: [{
|
|
30
|
+
declarations: [SpecialUploadComponent],
|
|
31
|
+
imports: [
|
|
32
|
+
FormsModule,
|
|
33
|
+
NgxDropzoneModule,
|
|
34
|
+
CommonModule,
|
|
35
|
+
MatIconModule,
|
|
36
|
+
ReactiveFormsModule,
|
|
37
|
+
MatButtonModule,
|
|
38
|
+
ErrorMessagePipeModule
|
|
39
|
+
],
|
|
40
|
+
exports: [SpecialUploadComponent],
|
|
41
|
+
}]
|
|
42
|
+
}] });
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3BlY2lhbC11cGxvYWQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlY2lhbC1mb3Jtcy9zcmMvbGliL2NvbXBvbmVudHMvc3BlY2lhbC11cGxvYWQvc3BlY2lhbC11cGxvYWQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ3BFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUNyRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxjQUFjLENBQUM7O0FBZWpELE1BQU0sT0FBTyxtQkFBbUI7O2dIQUFuQixtQkFBbUI7aUhBQW5CLG1CQUFtQixpQkFaZixzQkFBc0IsYUFFbkMsV0FBVztRQUNYLGlCQUFpQjtRQUNqQixZQUFZO1FBQ1osYUFBYTtRQUNiLG1CQUFtQjtRQUNuQixlQUFlO1FBQ2Ysc0JBQXNCLGFBRWQsc0JBQXNCO2lIQUVyQixtQkFBbUIsWUFWNUIsV0FBVztRQUNYLGlCQUFpQjtRQUNqQixZQUFZO1FBQ1osYUFBYTtRQUNiLG1CQUFtQjtRQUNuQixlQUFlO1FBQ2Ysc0JBQXNCOzJGQUliLG1CQUFtQjtrQkFiL0IsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztvQkFDdEMsT0FBTyxFQUFFO3dCQUNQLFdBQVc7d0JBQ1gsaUJBQWlCO3dCQUNqQixZQUFZO3dCQUNaLGFBQWE7d0JBQ2IsbUJBQW1CO3dCQUNuQixlQUFlO3dCQUNmLHNCQUFzQjtxQkFDdkI7b0JBQ0QsT0FBTyxFQUFFLENBQUMsc0JBQXNCLENBQUM7aUJBQ2xDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBTcGVjaWFsVXBsb2FkQ29tcG9uZW50IH0gZnJvbSAnLi9zcGVjaWFsLXVwbG9hZC5jb21wb25lbnQnO1xuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgRXJyb3JNZXNzYWdlUGlwZU1vZHVsZSB9IGZyb20gJy4uLy4uL3BpcGVzJztcbmltcG9ydCB7IE5neERyb3B6b25lTW9kdWxlIH0gZnJvbSAnbmd4LWRyb3B6b25lJztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbU3BlY2lhbFVwbG9hZENvbXBvbmVudF0sXG4gIGltcG9ydHM6IFtcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBOZ3hEcm9wem9uZU1vZHVsZSxcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgTWF0SWNvbk1vZHVsZSxcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxuICAgIE1hdEJ1dHRvbk1vZHVsZSxcbiAgICBFcnJvck1lc3NhZ2VQaXBlTW9kdWxlXG4gIF0sXG4gIGV4cG9ydHM6IFtTcGVjaWFsVXBsb2FkQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgU3BlY2lhbFVwbG9hZE1vZHVsZSB7fVxuIl19
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export var EControlTypes;
|
|
2
|
+
(function (EControlTypes) {
|
|
3
|
+
EControlTypes["pkey"] = "PRIMARY-KEY";
|
|
4
|
+
EControlTypes["input"] = "INPUT";
|
|
5
|
+
EControlTypes["textArea"] = "TEXT-AREA";
|
|
6
|
+
EControlTypes["dropdown"] = "DROPDOWN";
|
|
7
|
+
EControlTypes["date"] = "DATE";
|
|
8
|
+
EControlTypes["time"] = "TIME";
|
|
9
|
+
EControlTypes["checkbox"] = "CHECKBOX";
|
|
10
|
+
EControlTypes["upload"] = "UPLOAD";
|
|
11
|
+
EControlTypes["autocomplete"] = "AUTOCOMPLETE";
|
|
12
|
+
EControlTypes["multiple"] = "MULTIPLE-AUTOCOMPLETE";
|
|
13
|
+
EControlTypes["array"] = "ARRAY";
|
|
14
|
+
EControlTypes["form"] = "FORM";
|
|
15
|
+
EControlTypes["label"] = "LABEL";
|
|
16
|
+
EControlTypes["default"] = "DEFAULT";
|
|
17
|
+
})(EControlTypes || (EControlTypes = {}));
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udHJvbC10eXBlcy5lbnVtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlY2lhbC1mb3Jtcy9zcmMvbGliL2NvcmUvYXV4LWRhdGEvY29udHJvbC10eXBlcy5lbnVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLGFBZVg7QUFmRCxXQUFZLGFBQWE7SUFDdkIscUNBQW9CLENBQUE7SUFDcEIsZ0NBQWUsQ0FBQTtJQUNmLHVDQUFzQixDQUFBO0lBQ3RCLHNDQUFxQixDQUFBO0lBQ3JCLDhCQUFhLENBQUE7SUFDYiw4QkFBYSxDQUFBO0lBQ2Isc0NBQXFCLENBQUE7SUFDckIsa0NBQWlCLENBQUE7SUFDakIsOENBQTZCLENBQUE7SUFDN0IsbURBQWtDLENBQUE7SUFDbEMsZ0NBQWUsQ0FBQTtJQUNmLDhCQUFhLENBQUE7SUFDYixnQ0FBZSxDQUFBO0lBQ2Ysb0NBQW1CLENBQUE7QUFDckIsQ0FBQyxFQWZXLGFBQWEsS0FBYixhQUFhLFFBZXhCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gRUNvbnRyb2xUeXBlcyB7XHJcbiAgcGtleSA9ICdQUklNQVJZLUtFWScsXHJcbiAgaW5wdXQgPSAnSU5QVVQnLFxyXG4gIHRleHRBcmVhID0gJ1RFWFQtQVJFQScsXHJcbiAgZHJvcGRvd24gPSAnRFJPUERPV04nLFxyXG4gIGRhdGUgPSAnREFURScsXHJcbiAgdGltZSA9ICdUSU1FJyxcclxuICBjaGVja2JveCA9ICdDSEVDS0JPWCcsXHJcbiAgdXBsb2FkID0gJ1VQTE9BRCcsXHJcbiAgYXV0b2NvbXBsZXRlID0gJ0FVVE9DT01QTEVURScsXHJcbiAgbXVsdGlwbGUgPSAnTVVMVElQTEUtQVVUT0NPTVBMRVRFJyxcclxuICBhcnJheSA9ICdBUlJBWScsXHJcbiAgZm9ybSA9ICdGT1JNJyxcclxuICBsYWJlbCA9ICdMQUJFTCcsXHJcbiAgZGVmYXVsdCA9ICdERUZBVUxUJyxcclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,238 @@
|
|
|
1
|
+
import { FormArray, FormControl, FormGroup, } from '@angular/forms';
|
|
2
|
+
export class SpecialFormControl extends FormControl {
|
|
3
|
+
constructor({ name, settings, type, validators, asyncValidators, elementId, styleClasses, defaultValue, hidden, icon, label, length, placeholder, readOnly, required, tooltip, errorMessages, disabled, }) {
|
|
4
|
+
super(defaultValue, validators, asyncValidators);
|
|
5
|
+
this.name = name;
|
|
6
|
+
this.placeholder = placeholder;
|
|
7
|
+
this.label = label;
|
|
8
|
+
this.tooltip = tooltip;
|
|
9
|
+
this.icon = icon;
|
|
10
|
+
this.elementId = elementId;
|
|
11
|
+
this.settings = settings;
|
|
12
|
+
this.type = type;
|
|
13
|
+
this.styleClasses = styleClasses;
|
|
14
|
+
this.hidden = hidden;
|
|
15
|
+
this.length = length;
|
|
16
|
+
this.readOnly = readOnly;
|
|
17
|
+
this.required = required;
|
|
18
|
+
this.errorMessages = errorMessages;
|
|
19
|
+
disabled ? this.disable() : this.enable();
|
|
20
|
+
}
|
|
21
|
+
setReadOnly(status = true) {
|
|
22
|
+
this.readOnly = status;
|
|
23
|
+
}
|
|
24
|
+
setDisabled(status = true) {
|
|
25
|
+
status ? this.disable() : this.enable();
|
|
26
|
+
}
|
|
27
|
+
setHidden(status = true) {
|
|
28
|
+
this.hidden = status;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
export class SpecialFormGroup extends FormGroup {
|
|
32
|
+
constructor({ name, settings, type, validators, asyncValidators, elementId, styleClasses, defaultValue, hidden, icon, label, length, placeholder, readOnly, required, tooltip, disabled, }, controls) {
|
|
33
|
+
super(controls, validators, asyncValidators);
|
|
34
|
+
this.name = name;
|
|
35
|
+
this.placeholder = placeholder;
|
|
36
|
+
this.label = label;
|
|
37
|
+
this.tooltip = tooltip;
|
|
38
|
+
this.icon = icon;
|
|
39
|
+
this.elementId = elementId;
|
|
40
|
+
this.settings = settings;
|
|
41
|
+
this.type = type;
|
|
42
|
+
this.styleClasses = styleClasses;
|
|
43
|
+
this.hidden = hidden;
|
|
44
|
+
this.length = length;
|
|
45
|
+
this.readOnly = readOnly;
|
|
46
|
+
this.required = required;
|
|
47
|
+
this.defaultValue = defaultValue;
|
|
48
|
+
disabled ? this.disable() : this.enable();
|
|
49
|
+
}
|
|
50
|
+
unpristineRequired() {
|
|
51
|
+
Object.values(this.controls).forEach((control) => {
|
|
52
|
+
if (control instanceof SpecialFormControl) {
|
|
53
|
+
control.markAsDirty();
|
|
54
|
+
}
|
|
55
|
+
else if (control instanceof SpecialFormGroup) {
|
|
56
|
+
control.unpristineRequired();
|
|
57
|
+
}
|
|
58
|
+
else if (control instanceof SpecialFormArray) {
|
|
59
|
+
control.unpristineRequired();
|
|
60
|
+
}
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
specialReset(value = {}) {
|
|
64
|
+
const aux = {};
|
|
65
|
+
Object.entries(this.controls).map(([key, control]) => {
|
|
66
|
+
if (control instanceof SpecialFormControl) {
|
|
67
|
+
aux[key] = control.defaultValue;
|
|
68
|
+
}
|
|
69
|
+
else if (control instanceof SpecialFormArray) {
|
|
70
|
+
control.clear();
|
|
71
|
+
}
|
|
72
|
+
});
|
|
73
|
+
this.reset({ ...aux, ...value });
|
|
74
|
+
}
|
|
75
|
+
setReadOnly(status = true) {
|
|
76
|
+
Object.values(this.controls).map((value) => {
|
|
77
|
+
if (value instanceof SpecialFormControl ||
|
|
78
|
+
value instanceof SpecialFormArray ||
|
|
79
|
+
value instanceof SpecialFormGroup) {
|
|
80
|
+
value.setReadOnly(status);
|
|
81
|
+
}
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
setReadOnlyByFields(fieldsObject) {
|
|
85
|
+
Object.entries(fieldsObject).map(([key, value]) => {
|
|
86
|
+
const control = this.controls[key];
|
|
87
|
+
if (control instanceof SpecialFormControl) {
|
|
88
|
+
control.readOnly = value;
|
|
89
|
+
}
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
setHiddenByFields(fields) {
|
|
93
|
+
Object.entries(fields).map(([key, value]) => {
|
|
94
|
+
const control = this.controls[key];
|
|
95
|
+
if (control instanceof SpecialFormControl) {
|
|
96
|
+
control.hidden = value;
|
|
97
|
+
}
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
setDisabled(status) {
|
|
101
|
+
Object.values(this.controls).map((value) => {
|
|
102
|
+
if (value instanceof SpecialFormControl ||
|
|
103
|
+
value instanceof SpecialFormArray ||
|
|
104
|
+
value instanceof SpecialFormGroup) {
|
|
105
|
+
value.setDisabled(status);
|
|
106
|
+
}
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
setDisabledByFields(fieldsObject) {
|
|
110
|
+
Object.entries(fieldsObject).map((entries) => {
|
|
111
|
+
if (this.controls[entries[0]] instanceof SpecialFormControl) {
|
|
112
|
+
entries[1]
|
|
113
|
+
? this.controls[entries[0]].enable()
|
|
114
|
+
: this.controls[entries[0]].disable();
|
|
115
|
+
}
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
/**
|
|
119
|
+
* donde value es el objeto semilla y detailForm es un arreglo de form key para dar un marco al formarray
|
|
120
|
+
*/
|
|
121
|
+
setFormValue(value) {
|
|
122
|
+
this.specialReset(value);
|
|
123
|
+
Object.entries(this.controls)
|
|
124
|
+
.filter(([_key, control]) => control instanceof SpecialFormArray)
|
|
125
|
+
.map(([key, control]) => {
|
|
126
|
+
control.fillFormArray(value[key]);
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* Método que retorna
|
|
131
|
+
*/
|
|
132
|
+
getIdPkey() {
|
|
133
|
+
return Object.values(this.controls).find((control) => control instanceof SpecialFormControl && control.type === 'PRIMARY-KEY');
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
export class SpecialFormArray extends FormArray {
|
|
137
|
+
constructor({ name, settings, type, validators, asyncValidators, elementId, styleClasses, defaultValue, hidden, icon, label, placeholder, readOnly, required, tooltip, errorMessages, disabled, }, formCreation, controls) {
|
|
138
|
+
super(controls, validators, asyncValidators);
|
|
139
|
+
this.formCreation = formCreation;
|
|
140
|
+
this.form = this.formCreation();
|
|
141
|
+
this.name = name;
|
|
142
|
+
this.placeholder = placeholder;
|
|
143
|
+
this.label = label;
|
|
144
|
+
this.tooltip = tooltip;
|
|
145
|
+
this.icon = icon;
|
|
146
|
+
this.elementId = elementId;
|
|
147
|
+
this.settings = settings;
|
|
148
|
+
this.type = type;
|
|
149
|
+
this.styleClasses = styleClasses;
|
|
150
|
+
this.hidden = hidden;
|
|
151
|
+
this.readOnly = readOnly;
|
|
152
|
+
this.required = required;
|
|
153
|
+
this.defaultValue = defaultValue;
|
|
154
|
+
this.errorMessages = errorMessages;
|
|
155
|
+
disabled ? this.disable() : this.enable();
|
|
156
|
+
}
|
|
157
|
+
fillFormArray(data) {
|
|
158
|
+
this.form.reset();
|
|
159
|
+
this.clear();
|
|
160
|
+
data.forEach((item) => {
|
|
161
|
+
const form = this.formCreation(item);
|
|
162
|
+
this.push(form);
|
|
163
|
+
});
|
|
164
|
+
}
|
|
165
|
+
addItem() {
|
|
166
|
+
const form = this.formCreation(this.form.value);
|
|
167
|
+
this.form.specialReset();
|
|
168
|
+
this.push(form);
|
|
169
|
+
this.markAsDirty();
|
|
170
|
+
}
|
|
171
|
+
specialPush(index) {
|
|
172
|
+
const form = this.formCreation(this.form.value);
|
|
173
|
+
if (!index)
|
|
174
|
+
this.push(form);
|
|
175
|
+
else
|
|
176
|
+
this.controls[index].reset(this.form.value);
|
|
177
|
+
}
|
|
178
|
+
specialInsert(index = 0) {
|
|
179
|
+
const form = this.formCreation(this.form.value);
|
|
180
|
+
this.insert(index, form);
|
|
181
|
+
}
|
|
182
|
+
specialEdit(index, newValue) {
|
|
183
|
+
this.controls[index].reset({ ...this.controls[index].value, ...newValue });
|
|
184
|
+
this.markAsDirty();
|
|
185
|
+
}
|
|
186
|
+
/**
|
|
187
|
+
* Vuelve todos los controles del formArray de lectura o de sololectura
|
|
188
|
+
* @param status
|
|
189
|
+
*/
|
|
190
|
+
setReadOnly(status) {
|
|
191
|
+
this.readOnly = status;
|
|
192
|
+
this.controls.forEach((control) => {
|
|
193
|
+
if (control instanceof SpecialFormGroup) {
|
|
194
|
+
control.setReadOnly(status);
|
|
195
|
+
}
|
|
196
|
+
});
|
|
197
|
+
}
|
|
198
|
+
/**
|
|
199
|
+
* Vuelve todos los controles del formArray habilitados o deshabilitados
|
|
200
|
+
* @param status
|
|
201
|
+
*/
|
|
202
|
+
setDisabled(status) {
|
|
203
|
+
status ? this.disable() : this.enable();
|
|
204
|
+
this.controls.forEach((control) => {
|
|
205
|
+
if (control instanceof SpecialFormGroup) {
|
|
206
|
+
control.setDisabled(status);
|
|
207
|
+
}
|
|
208
|
+
});
|
|
209
|
+
}
|
|
210
|
+
/**
|
|
211
|
+
* Permite editar un control especifico.
|
|
212
|
+
* @param index
|
|
213
|
+
*/
|
|
214
|
+
editControl(index) {
|
|
215
|
+
this.form.reset(this.controls[index].value);
|
|
216
|
+
}
|
|
217
|
+
unpristineRequired() {
|
|
218
|
+
this.markAsDirty();
|
|
219
|
+
this.controls.forEach((item) => {
|
|
220
|
+
item.unpristineRequired();
|
|
221
|
+
});
|
|
222
|
+
}
|
|
223
|
+
recursiveFillForm(form, data) {
|
|
224
|
+
Object.entries(form.controls).map(([key, control]) => {
|
|
225
|
+
if (control instanceof FormControl) {
|
|
226
|
+
control.setValue(data[key]);
|
|
227
|
+
}
|
|
228
|
+
else if (control instanceof FormArray) {
|
|
229
|
+
data[key].forEach(() => { });
|
|
230
|
+
}
|
|
231
|
+
else if (control instanceof FormGroup) {
|
|
232
|
+
control.reset(data[key]);
|
|
233
|
+
}
|
|
234
|
+
});
|
|
235
|
+
return form;
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"special-forms.js","sourceRoot":"","sources":["../../../../../../projects/special-forms/src/lib/core/forms/special-forms.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AbstractControl,\r\n  FormArray,\r\n  FormControl,\r\n  FormGroup,\r\n} from '@angular/forms';\r\nimport { EControlTypes } from '../aux-data/control-types.enum';\r\nimport { IFieldBasicData } from '../interfaces/field-basics.interfaces';\r\nimport {\r\n  IArraySettings,\r\n  IFormSettings,\r\n  TSpecialFields,\r\n  TSpecialForm,\r\n  TSpecialArray,\r\n} from '../interfaces/form.interfaces';\r\nexport class SpecialFormControl<T>\r\n  extends FormControl\r\n  implements IFieldBasicData\r\n{\r\n  public name: string;\r\n  public placeholder: string;\r\n  public label: string;\r\n  public tooltip: string;\r\n  public icon: string;\r\n  public elementId: string;\r\n  public styleClasses: string;\r\n  public length: number;\r\n  public required: boolean;\r\n  public hidden: boolean;\r\n  public readOnly: boolean;\r\n  public settings: T;\r\n  public type: EControlTypes;\r\n  public errorMessages: { [key: string]: string };\r\n\r\n  constructor({\r\n    name,\r\n    settings,\r\n    type,\r\n    validators,\r\n    asyncValidators,\r\n    elementId,\r\n    styleClasses,\r\n    defaultValue,\r\n    hidden,\r\n    icon,\r\n    label,\r\n    length,\r\n    placeholder,\r\n    readOnly,\r\n    required,\r\n    tooltip,\r\n    errorMessages,\r\n    disabled,\r\n  }: TSpecialFields) {\r\n    super(defaultValue, validators, asyncValidators);\r\n\r\n    this.name = name;\r\n    this.placeholder = placeholder;\r\n    this.label = label;\r\n    this.tooltip = tooltip;\r\n    this.icon = icon;\r\n    this.elementId = elementId;\r\n    this.settings = settings as T;\r\n    this.type = type;\r\n    this.styleClasses = styleClasses;\r\n    this.hidden = hidden;\r\n    this.length = length;\r\n    this.readOnly = readOnly;\r\n    this.required = required;\r\n    this.errorMessages = errorMessages;\r\n    disabled ? this.disable() : this.enable();\r\n  }\r\n\r\n  setReadOnly(status: boolean = true) {\r\n    this.readOnly = status;\r\n  }\r\n\r\n  setDisabled(status: boolean = true) {\r\n    status ? this.disable() : this.enable();\r\n  }\r\n\r\n  setHidden(status = true) {\r\n    this.hidden = status;\r\n  }\r\n}\r\nexport class SpecialFormGroup extends FormGroup implements IFieldBasicData {\r\n  public name: string;\r\n  public placeholder: string;\r\n  public label: string;\r\n  public tooltip: string;\r\n  public icon: string;\r\n  public elementId: string;\r\n  public styleClasses: string;\r\n  public length: number;\r\n  public required: boolean;\r\n  public hidden: boolean;\r\n  public readOnly: boolean;\r\n  public settings: IFormSettings;\r\n  public type: EControlTypes.form;\r\n  public defaultValue: any;\r\n  public errorMessages: { [key: string]: string };\r\n\r\n  constructor(\r\n    {\r\n      name,\r\n      settings,\r\n      type,\r\n      validators,\r\n      asyncValidators,\r\n      elementId,\r\n      styleClasses,\r\n      defaultValue,\r\n      hidden,\r\n      icon,\r\n      label,\r\n      length,\r\n      placeholder,\r\n      readOnly,\r\n      required,\r\n      tooltip,\r\n      disabled,\r\n    }: TSpecialForm,\r\n    controls: {\r\n      [key: string]: SpecialFormControl<any>;\r\n    },\r\n  ) {\r\n    super(controls, validators, asyncValidators);\r\n\r\n    this.name = name;\r\n    this.placeholder = placeholder;\r\n    this.label = label;\r\n    this.tooltip = tooltip;\r\n    this.icon = icon;\r\n    this.elementId = elementId;\r\n    this.settings = settings;\r\n    this.type = type;\r\n    this.styleClasses = styleClasses;\r\n    this.hidden = hidden;\r\n    this.length = length;\r\n    this.readOnly = readOnly;\r\n    this.required = required;\r\n    this.defaultValue = defaultValue;\r\n    disabled ? this.disable() : this.enable();\r\n  }\r\n\r\n  unpristineRequired() {\r\n    Object.values(this.controls).forEach((control) => {\r\n      if (control instanceof SpecialFormControl) {\r\n        control.markAsDirty();\r\n      } else if (control instanceof SpecialFormGroup) {\r\n        control.unpristineRequired();\r\n      } else if (control instanceof SpecialFormArray) {\r\n        control.unpristineRequired();\r\n      }\r\n    });\r\n  }\r\n\r\n  specialReset(value = {}) {\r\n    const aux: any = {};\r\n    Object.entries(this.controls).map(([key, control]) => {\r\n      if (control instanceof SpecialFormControl) {\r\n        aux[key] = control.defaultValue;\r\n      } else if (control instanceof SpecialFormArray) {\r\n        control.clear();\r\n      }\r\n    });\r\n\r\n    this.reset({ ...aux, ...value });\r\n  }\r\n  setReadOnly(status: boolean = true) {\r\n    Object.values(this.controls).map((value) => {\r\n      if (\r\n        value instanceof SpecialFormControl ||\r\n        value instanceof SpecialFormArray ||\r\n        value instanceof SpecialFormGroup\r\n      ) {\r\n        value.setReadOnly(status);\r\n      }\r\n    });\r\n  }\r\n  setReadOnlyByFields(fieldsObject: { [key: string]: boolean }) {\r\n    Object.entries(fieldsObject).map(([key, value]) => {\r\n      const control = this.controls[key];\r\n      if (control instanceof SpecialFormControl) {\r\n        control.readOnly = value;\r\n      }\r\n    });\r\n  }\r\n\r\n  setHiddenByFields(fields: { [key: string]: boolean }) {\r\n    Object.entries(fields).map(([key, value]) => {\r\n      const control = this.controls[key];\r\n      if (control instanceof SpecialFormControl) {\r\n        control.hidden = value;\r\n      }\r\n    });\r\n  }\r\n  setDisabled(status: boolean) {\r\n    Object.values(this.controls).map((value) => {\r\n      if (\r\n        value instanceof SpecialFormControl ||\r\n        value instanceof SpecialFormArray ||\r\n        value instanceof SpecialFormGroup\r\n      ) {\r\n        value.setDisabled(status);\r\n      }\r\n    });\r\n  }\r\n\r\n  setDisabledByFields(fieldsObject: any) {\r\n    Object.entries(fieldsObject).map((entries) => {\r\n      if (this.controls[entries[0]] instanceof SpecialFormControl) {\r\n        entries[1]\r\n          ? this.controls[entries[0]].enable()\r\n          : this.controls[entries[0]].disable();\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * donde value es el objeto semilla y detailForm es un arreglo de form key para dar un marco al formarray\r\n   */\r\n\r\n  setFormValue(value: any) {\r\n    this.specialReset(value);\r\n    Object.entries(this.controls)\r\n      .filter(([_key, control]) => control instanceof SpecialFormArray)\r\n      .map(([key, control]) => {\r\n        (control as SpecialFormArray).fillFormArray(value[key]);\r\n      });\r\n  }\r\n\r\n  /**\r\n   * Método que retorna\r\n   */\r\n\r\n  getIdPkey(): SpecialFormControl<any> | undefined {\r\n    return Object.values(this.controls).find(\r\n      (control) =>\r\n        control instanceof SpecialFormControl && control.type === 'PRIMARY-KEY'\r\n    ) as SpecialFormControl<any> | undefined;\r\n  }\r\n}\r\n\r\nexport class SpecialFormArray extends FormArray implements IFieldBasicData {\r\n  public name: string;\r\n  public placeholder: string;\r\n  public label: string;\r\n  public tooltip: string;\r\n  public icon: string;\r\n  public elementId: string;\r\n  public styleClasses: string;\r\n  public required: boolean;\r\n  public hidden: boolean;\r\n  public readOnly: boolean;\r\n  public settings: IArraySettings;\r\n  public type: EControlTypes;\r\n  public defaultValue: any;\r\n  public form: SpecialFormGroup;\r\n  private formCreation: (value?: any) => SpecialFormGroup;\r\n  public errorMessages: { [key: string]: string };\r\n\r\n  constructor(\r\n    {\r\n      name,\r\n      settings,\r\n      type,\r\n      validators,\r\n      asyncValidators,\r\n      elementId,\r\n      styleClasses,\r\n      defaultValue,\r\n      hidden,\r\n      icon,\r\n      label,\r\n      placeholder,\r\n      readOnly,\r\n      required,\r\n      tooltip,\r\n      errorMessages,\r\n      disabled,\r\n    }: TSpecialArray,\r\n    formCreation: () => SpecialFormGroup,\r\n    controls: AbstractControl[]\r\n  ) {\r\n    super(controls, validators, asyncValidators);\r\n    this.formCreation = formCreation;\r\n    this.form = this.formCreation();\r\n    this.name = name;\r\n    this.placeholder = placeholder;\r\n    this.label = label;\r\n    this.tooltip = tooltip;\r\n    this.icon = icon;\r\n    this.elementId = elementId;\r\n    this.settings = settings;\r\n    this.type = type;\r\n    this.styleClasses = styleClasses;\r\n    this.hidden = hidden;\r\n    this.readOnly = readOnly;\r\n    this.required = required;\r\n    this.defaultValue = defaultValue;\r\n    this.errorMessages = errorMessages;\r\n    disabled ? this.disable() : this.enable();\r\n  }\r\n\r\n  fillFormArray(data: any[]) {\r\n    this.form.reset();\r\n    this.clear();\r\n    data.forEach((item) => {\r\n      const form = this.formCreation(item);\r\n      this.push(form);\r\n    });\r\n  }\r\n\r\n  addItem() {\r\n    const form = this.formCreation(this.form.value);\r\n\r\n    this.form.specialReset();\r\n    this.push(form);\r\n    this.markAsDirty();\r\n  }\r\n\r\n  specialPush(index?: number) {\r\n    const form = this.formCreation(this.form.value);\r\n    if (!index) this.push(form);\r\n    else this.controls[index].reset(this.form.value);\r\n  }\r\n\r\n  specialInsert(index = 0) {\r\n    const form = this.formCreation(this.form.value);\r\n    this.insert(index, form);\r\n  }\r\n\r\n  specialEdit(index: number, newValue: Object) {\r\n    this.controls[index].reset({ ...this.controls[index].value, ...newValue });\r\n    this.markAsDirty();\r\n  }\r\n\r\n  /**\r\n   * Vuelve todos los controles del formArray de lectura o de sololectura\r\n   * @param status\r\n   */\r\n\r\n  setReadOnly(status: boolean) {\r\n    this.readOnly = status;\r\n    this.controls.forEach((control) => {\r\n      if (control instanceof SpecialFormGroup) {\r\n        control.setReadOnly(status);\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Vuelve todos los controles del formArray habilitados o deshabilitados\r\n   * @param status\r\n   */\r\n\r\n  setDisabled(status: boolean) {\r\n    status ? this.disable() : this.enable();\r\n    this.controls.forEach((control) => {\r\n      if (control instanceof SpecialFormGroup) {\r\n        control.setDisabled(status);\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Permite editar un control especifico.\r\n   * @param index\r\n   */\r\n\r\n  editControl(index: number) {\r\n    this.form.reset(this.controls[index].value);\r\n  }\r\n\r\n  unpristineRequired() {\r\n    this.markAsDirty();\r\n    this.controls.forEach((item) => {\r\n      (<SpecialFormGroup>item).unpristineRequired();\r\n    });\r\n  }\r\n\r\n  recursiveFillForm(form: FormGroup, data: any): FormGroup {\r\n    Object.entries(form.controls).map(([key, control]) => {\r\n      if (control instanceof FormControl) {\r\n        control.setValue(data[key]);\r\n      } else if (control instanceof FormArray) {\r\n        data[key].forEach(() => {});\r\n      } else if (control instanceof FormGroup) {\r\n        control.reset(data[key]);\r\n      }\r\n    });\r\n    return form;\r\n  }\r\n}\r\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQtYmFzaWNzLmludGVyZmFjZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zcGVjaWFsLWZvcm1zL3NyYy9saWIvY29yZS9pbnRlcmZhY2VzL2ZpZWxkLWJhc2ljcy5pbnRlcmZhY2VzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBc3luY1ZhbGlkYXRvckZuLCBWYWxpZGF0b3JGbiB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSUZpZWxkQmFzaWNEYXRhIHtcclxuICBwbGFjZWhvbGRlcjogc3RyaW5nO1xyXG4gIGxhYmVsOiBzdHJpbmc7XHJcbiAgdG9vbHRpcDogc3RyaW5nO1xyXG4gIGljb246IHN0cmluZztcclxuICBlbGVtZW50SWQ6IHN0cmluZztcclxuICBzdHlsZUNsYXNzZXM6IHN0cmluZztcclxuICBsZW5ndGg6IG51bWJlcjtcclxuICByZXF1aXJlZDogYm9vbGVhbjtcclxuICBoaWRkZW46IGJvb2xlYW47XHJcbiAgcmVhZE9ubHk6IGJvb2xlYW47XHJcbiAgZGlzYWJsZWQ6Ym9vbGVhbjtcclxuICBlcnJvck1lc3NhZ2VzOiB7IFtrZXk6IHN0cmluZ106IHN0cmluZyB9O1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIElGaWVsZERhdGEgZXh0ZW5kcyBJRmllbGRCYXNpY0RhdGEge1xyXG4gIHZhbGlkYXRvcnM6IFZhbGlkYXRvckZuIHwgVmFsaWRhdG9yRm5bXSB8IG51bGw7XHJcbiAgYXN5bmNWYWxpZGF0b3JzOiBBc3luY1ZhbGlkYXRvckZuIHwgQXN5bmNWYWxpZGF0b3JGbltdIHwgbnVsbDtcclxuICBkZWZhdWx0VmFsdWU6IGFueTtcclxufVxyXG4iXX0=
|