onshore-forms 0.0.7 → 0.0.9
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/esm2020/lib/components/form-autocomplete-item/form-autocomplete-item.component.mjs +11 -0
- package/esm2020/lib/components/form-checkbox-item/form-checkbox-item.component.mjs +62 -0
- package/esm2020/lib/components/form-colorpicker-item/form-colorpicker-item.component.mjs +69 -0
- package/esm2020/lib/components/form-dropdown-item/form-dropdown-item.component.mjs +65 -0
- package/esm2020/lib/components/form-image-item/form-image-item.component.mjs +160 -0
- package/esm2020/lib/components/form-input-item/form-input-item.component.mjs +63 -0
- package/esm2020/lib/components/form-switch-item/form-switch-item.component.mjs +65 -0
- package/esm2020/lib/components/form-textarea-item/form-textarea-item.component.mjs +61 -0
- package/esm2020/lib/components/form-validation-output/form-validation-output.component.mjs +41 -0
- package/esm2020/lib/enums/form.enums.mjs +26 -0
- package/esm2020/lib/models/form.models.mjs +2 -0
- package/esm2020/lib/onshore-forms.component.mjs +22 -0
- package/esm2020/lib/onshore-forms.module.mjs +134 -0
- package/esm2020/lib/onshore-forms.service.mjs +151 -0
- package/esm2020/onshore-forms.mjs +5 -0
- package/esm2020/public-api.mjs +18 -0
- package/fesm2015/onshore-forms.mjs +921 -0
- package/fesm2015/onshore-forms.mjs.map +1 -0
- package/fesm2020/onshore-forms.mjs +877 -0
- package/fesm2020/onshore-forms.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/components/form-autocomplete-item/form-autocomplete-item.component.d.ts +5 -0
- package/lib/components/form-checkbox-item/form-checkbox-item.component.d.ts +21 -0
- package/lib/components/form-colorpicker-item/form-colorpicker-item.component.d.ts +23 -0
- package/lib/components/form-dropdown-item/form-dropdown-item.component.d.ts +22 -0
- package/lib/components/form-image-item/form-image-item.component.d.ts +40 -0
- package/lib/components/form-input-item/form-input-item.component.d.ts +23 -0
- package/lib/components/form-switch-item/form-switch-item.component.d.ts +21 -0
- package/lib/components/form-textarea-item/form-textarea-item.component.d.ts +22 -0
- package/lib/components/form-validation-output/form-validation-output.component.d.ts +17 -0
- package/lib/enums/form.enums.d.ts +23 -0
- package/lib/models/form.models.d.ts +61 -0
- package/lib/onshore-forms.component.d.ts +8 -0
- package/lib/onshore-forms.module.d.ts +31 -0
- package/lib/onshore-forms.service.d.ts +32 -0
- package/package.json +21 -10
- package/{src/public-api.ts → public-api.d.ts} +0 -4
- package/karma.conf.js +0 -44
- package/ng-package.json +0 -11
- package/src/lib/components/form-autocomplete-item/form-autocomplete-item.component.html +0 -46
- package/src/lib/components/form-autocomplete-item/form-autocomplete-item.component.scss +0 -0
- package/src/lib/components/form-autocomplete-item/form-autocomplete-item.component.ts +0 -133
- package/src/lib/components/form-checkbox-item/form-checkbox-item.component.html +0 -23
- package/src/lib/components/form-checkbox-item/form-checkbox-item.component.scss +0 -0
- package/src/lib/components/form-checkbox-item/form-checkbox-item.component.ts +0 -65
- package/src/lib/components/form-colorpicker-item/form-colorpicker-item.component.html +0 -30
- package/src/lib/components/form-colorpicker-item/form-colorpicker-item.component.scss +0 -0
- package/src/lib/components/form-colorpicker-item/form-colorpicker-item.component.ts +0 -71
- package/src/lib/components/form-dropdown-item/form-dropdown-item.component.html +0 -44
- package/src/lib/components/form-dropdown-item/form-dropdown-item.component.scss +0 -0
- package/src/lib/components/form-dropdown-item/form-dropdown-item.component.ts +0 -68
- package/src/lib/components/form-image-item/form-image-item.component.html +0 -79
- package/src/lib/components/form-image-item/form-image-item.component.scss +0 -3
- package/src/lib/components/form-image-item/form-image-item.component.ts +0 -155
- package/src/lib/components/form-input-item/form-input-item.component.html +0 -81
- package/src/lib/components/form-input-item/form-input-item.component.scss +0 -3
- package/src/lib/components/form-input-item/form-input-item.component.ts +0 -66
- package/src/lib/components/form-switch-item/form-switch-item.component.html +0 -8
- package/src/lib/components/form-switch-item/form-switch-item.component.scss +0 -0
- package/src/lib/components/form-switch-item/form-switch-item.component.ts +0 -72
- package/src/lib/components/form-textarea-item/form-textarea-item.component.html +0 -39
- package/src/lib/components/form-textarea-item/form-textarea-item.component.scss +0 -0
- package/src/lib/components/form-textarea-item/form-textarea-item.component.ts +0 -64
- package/src/lib/components/form-validation-output/form-validation-output.component.html +0 -2
- package/src/lib/components/form-validation-output/form-validation-output.component.scss +0 -1
- package/src/lib/components/form-validation-output/form-validation-output.component.ts +0 -43
- package/src/lib/enums/form.enums.ts +0 -24
- package/src/lib/models/form.models.ts +0 -70
- package/src/lib/onshore-forms.component.ts +0 -20
- package/src/lib/onshore-forms.module.ts +0 -78
- package/src/lib/onshore-forms.service.ts +0 -172
- package/src/test.ts +0 -27
- package/styles/css/main.css +0 -1
- package/styles/css/theme1.css +0 -1
- package/tsconfig.lib.json +0 -24
- package/tsconfig.lib.prod.json +0 -20
- package/tsconfig.spec.json +0 -17
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { FormArray, FormControl, FormGroup } from '@angular/forms';
|
|
3
|
+
import { Subject } from 'rxjs';
|
|
4
|
+
import { OnshoreFormTemplateType } from './enums/form.enums';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class OnshoreFormsService {
|
|
7
|
+
constructor() {
|
|
8
|
+
this._formValidations = [];
|
|
9
|
+
this.subscriptions = [];
|
|
10
|
+
this.isLoading$ = new Subject();
|
|
11
|
+
this._form = new FormGroup({}, { updateOn: 'change' });
|
|
12
|
+
this._formTemplate = [];
|
|
13
|
+
}
|
|
14
|
+
get form() {
|
|
15
|
+
return this._form;
|
|
16
|
+
}
|
|
17
|
+
get formValues() {
|
|
18
|
+
return this._form?.value;
|
|
19
|
+
}
|
|
20
|
+
patchForm(value) {
|
|
21
|
+
this._form?.patchValue(value);
|
|
22
|
+
}
|
|
23
|
+
resetForm() {
|
|
24
|
+
this._form?.reset();
|
|
25
|
+
this._form?.updateValueAndValidity({ onlySelf: false, emitEvent: true });
|
|
26
|
+
this.subscriptions.forEach((subscription) => {
|
|
27
|
+
subscription.unsubscribe();
|
|
28
|
+
});
|
|
29
|
+
this._form = null;
|
|
30
|
+
this._formTemplate = null;
|
|
31
|
+
}
|
|
32
|
+
generateForm(formTemplate) {
|
|
33
|
+
this._formTemplate = formTemplate;
|
|
34
|
+
this._form = new FormGroup({}, { updateOn: 'change' });
|
|
35
|
+
this._form = this.iterateNestedForm(this._form, formTemplate);
|
|
36
|
+
return this._form;
|
|
37
|
+
}
|
|
38
|
+
formTemplate(name, formTemplate = this._formTemplate) {
|
|
39
|
+
let template;
|
|
40
|
+
if (formTemplate) {
|
|
41
|
+
for (let i = 0; i < formTemplate?.length; i++) {
|
|
42
|
+
const item = formTemplate[i];
|
|
43
|
+
if (item.name === name) {
|
|
44
|
+
template = item;
|
|
45
|
+
i = formTemplate.length;
|
|
46
|
+
}
|
|
47
|
+
else if (item.subformArray) {
|
|
48
|
+
const arrayTemplate = this.formTemplate(name, item.subformArray);
|
|
49
|
+
if (arrayTemplate)
|
|
50
|
+
template = arrayTemplate;
|
|
51
|
+
}
|
|
52
|
+
else if (item.subformObject) {
|
|
53
|
+
const objectTemplate = this.formTemplate(name, item.subformObject);
|
|
54
|
+
if (objectTemplate)
|
|
55
|
+
template = objectTemplate;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
return template;
|
|
60
|
+
}
|
|
61
|
+
formControl(name, formGroup = this._form) {
|
|
62
|
+
return formGroup?.get(name);
|
|
63
|
+
}
|
|
64
|
+
formArray(name) {
|
|
65
|
+
return this._form?.get(name);
|
|
66
|
+
}
|
|
67
|
+
formGroup(form, name) {
|
|
68
|
+
return form.get(name);
|
|
69
|
+
}
|
|
70
|
+
addFormArrayItem(name, item) {
|
|
71
|
+
let formControls = {};
|
|
72
|
+
if (item) {
|
|
73
|
+
item.subformArray?.forEach((subitem) => {
|
|
74
|
+
formControls[subitem.name] = new FormControl(subitem.default !== undefined ? subitem.default : '', {
|
|
75
|
+
validators: subitem.validators || [],
|
|
76
|
+
updateOn: 'change'
|
|
77
|
+
});
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
const formGroup = new FormGroup(formControls);
|
|
81
|
+
formGroup.setParent(this.formArray(name));
|
|
82
|
+
this.formArray(name).push(formGroup);
|
|
83
|
+
this.subscribeNestedFormGroup(formGroup);
|
|
84
|
+
}
|
|
85
|
+
removeFormArrayItem(form, index) {
|
|
86
|
+
form.removeAt(index);
|
|
87
|
+
}
|
|
88
|
+
setFormValidations(validations = []) {
|
|
89
|
+
this._formValidations = validations;
|
|
90
|
+
}
|
|
91
|
+
enable() {
|
|
92
|
+
setTimeout(() => {
|
|
93
|
+
this._form?.enable({ onlySelf: true, emitEvent: false });
|
|
94
|
+
}, 100);
|
|
95
|
+
}
|
|
96
|
+
disable() {
|
|
97
|
+
setTimeout(() => {
|
|
98
|
+
this._form?.disable({ onlySelf: true, emitEvent: false });
|
|
99
|
+
}, 100);
|
|
100
|
+
}
|
|
101
|
+
setError(control, error) {
|
|
102
|
+
this.formControl(control).setErrors(error);
|
|
103
|
+
}
|
|
104
|
+
setLoader(loaders$) {
|
|
105
|
+
loaders$.forEach($loader => {
|
|
106
|
+
this.subscriptions.push($loader.subscribe(isLoading => {
|
|
107
|
+
isLoading ? this.disable() : this.enable();
|
|
108
|
+
this.isLoading$.next(isLoading);
|
|
109
|
+
}));
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
iterateNestedForm(form, formTemplate) {
|
|
113
|
+
formTemplate.forEach((item) => {
|
|
114
|
+
if (item.type === OnshoreFormTemplateType.subform) {
|
|
115
|
+
if (item.subformArray) {
|
|
116
|
+
form.controls[item.name] = new FormArray([]);
|
|
117
|
+
form.controls[item.name].setParent(form);
|
|
118
|
+
}
|
|
119
|
+
if (item.subformObject) {
|
|
120
|
+
form.controls[item.name] = new FormGroup({});
|
|
121
|
+
form.controls[item.name] = this.iterateNestedForm(form.controls[item.name], item.subformObject);
|
|
122
|
+
this.subscribeNestedFormGroup(form.controls[item.name]);
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
else {
|
|
126
|
+
form.addControl(item.name, new FormControl(item.default !== undefined ? item.default : '', {
|
|
127
|
+
validators: item.validators || [],
|
|
128
|
+
updateOn: 'change'
|
|
129
|
+
}));
|
|
130
|
+
}
|
|
131
|
+
});
|
|
132
|
+
return form;
|
|
133
|
+
}
|
|
134
|
+
subscribeNestedFormGroup(nestedFormItem) {
|
|
135
|
+
this.subscriptions.push(nestedFormItem.valueChanges.subscribe(() => {
|
|
136
|
+
this.form?.updateValueAndValidity({ onlySelf: true, emitEvent: false });
|
|
137
|
+
}));
|
|
138
|
+
this.subscriptions.push(nestedFormItem.statusChanges.subscribe(() => {
|
|
139
|
+
this.form?.updateValueAndValidity({ onlySelf: true, emitEvent: false });
|
|
140
|
+
}));
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
OnshoreFormsService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: OnshoreFormsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
144
|
+
OnshoreFormsService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: OnshoreFormsService, providedIn: 'root' });
|
|
145
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: OnshoreFormsService, decorators: [{
|
|
146
|
+
type: Injectable,
|
|
147
|
+
args: [{
|
|
148
|
+
providedIn: 'root'
|
|
149
|
+
}]
|
|
150
|
+
}], ctorParameters: function () { return []; } });
|
|
151
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"onshore-forms.service.js","sourceRoot":"","sources":["../../../../projects/onshore-forms/src/lib/onshore-forms.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACnE,OAAO,EAAE,OAAO,EAAgB,MAAM,MAAM,CAAC;AAC7C,OAAO,EAAE,uBAAuB,EAAE,MAAM,oBAAoB,CAAC;;AAK7D,MAAM,OAAO,mBAAmB;IAU9B;QANA,qBAAgB,GAAgC,EAAE,CAAC;QAEnD,kBAAa,GAAwB,EAAE,CAAC;QAEjC,eAAU,GAAqB,IAAI,OAAO,EAAW,CAAC;QAG3D,IAAI,CAAC,KAAK,GAAG,IAAI,SAAS,CAAC,EAAE,EAAE,EAAC,QAAQ,EAAE,QAAQ,EAAC,CAAC,CAAC;QACrD,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;IAC1B,CAAC;IAED,IAAW,IAAI;QACb,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,KAAK,EAAE,KAAK,CAAC;IAC3B,CAAC;IAEM,SAAS,CAAC,KAAU;QACzB,IAAI,CAAC,KAAK,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAEM,SAAS;QACd,IAAI,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC;QACpB,IAAI,CAAC,KAAK,EAAE,sBAAsB,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QACzE,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,YAA0B,EAAE,EAAE;YACxD,YAAY,CAAC,WAAW,EAAE,CAAC;QAC7B,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,GAAG,IAAK,CAAC;QACnB,IAAI,CAAC,aAAa,GAAG,IAAK,CAAC;IAC7B,CAAC;IAEM,YAAY,CAAC,YAAuC;QACzD,IAAI,CAAC,aAAa,GAAG,YAAY,CAAC;QAClC,IAAI,CAAC,KAAK,GAAG,IAAI,SAAS,CAAC,EAAE,EAAE,EAAC,QAAQ,EAAE,QAAQ,EAAC,CAAC,CAAC;QACrD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC;QAC9D,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAEM,YAAY,CAAC,IAAY,EAAE,eAA0C,IAAI,CAAC,aAAa;QAC5F,IAAI,QAAiC,CAAC;QAEtC,IAAG,YAAY,EAAE;YACf,KAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,YAAY,EAAE,MAAM,EAAE,CAAC,EAAE,EAAE;gBAC5C,MAAM,IAAI,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;gBAC7B,IAAG,IAAI,CAAC,IAAI,KAAK,IAAI,EAAE;oBACrB,QAAQ,GAAG,IAAI,CAAC;oBAChB,CAAC,GAAG,YAAY,CAAC,MAAM,CAAC;iBACzB;qBAAK,IAAG,IAAI,CAAC,YAAY,EAAE;oBAC1B,MAAM,aAAa,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;oBACjE,IAAG,aAAa;wBAAE,QAAQ,GAAG,aAAa,CAAC;iBAC5C;qBAAK,IAAG,IAAI,CAAC,aAAa,EAAE;oBAC3B,MAAM,cAAc,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;oBACnE,IAAG,cAAc;wBAAE,QAAQ,GAAG,cAAc,CAAC;iBAC9C;aACF;SACF;QAED,OAAO,QAAS,CAAC;IACnB,CAAC;IAEM,WAAW,CAAC,IAAY,EAAE,YAA8B,IAAI,CAAC,KAAK;QACvE,OAAO,SAAS,EAAE,GAAG,CAAC,IAAI,CAAgB,CAAC;IAC7C,CAAC;IAEM,SAAS,CAAC,IAAY;QAC3B,OAAO,IAAI,CAAC,KAAK,EAAE,GAAG,CAAC,IAAI,CAAc,CAAC;IAC5C,CAAC;IAEM,SAAS,CAAC,IAAe,EAAE,IAAY;QAC5C,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAc,CAAC;IACrC,CAAC;IAEM,gBAAgB,CAAC,IAAY,EAAE,IAA6B;QACjE,IAAI,YAAY,GAAQ,EAAE,CAAC;QAE3B,IAAG,IAAI,EAAE;YACP,IAAI,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC,OAAgC,EAAE,EAAE;gBAC9D,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,WAAW,CAAC,OAAO,CAAC,OAAO,KAAK,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;oBACjG,UAAU,EAAE,OAAO,CAAC,UAAU,IAAI,EAAE;oBACpC,QAAQ,EAAE,QAAQ;iBACnB,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;SACJ;QAED,MAAM,SAAS,GAAG,IAAI,SAAS,CAAC,YAAY,CAAC,CAAC;QAC9C,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC;QAE1C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAErC,IAAI,CAAC,wBAAwB,CAAC,SAAS,CAAC,CAAC;IAC3C,CAAC;IAEM,mBAAmB,CAAC,IAAe,EAAE,KAAa;QACvD,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC;IAEM,kBAAkB,CAAC,cAA2C,EAAE;QACrE,IAAI,CAAC,gBAAgB,GAAG,WAAW,CAAC;IACtC,CAAC;IAEM,MAAM;QACX,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,KAAK,EAAE,MAAM,CAAC,EAAC,QAAQ,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAC,CAAC,CAAC;QACzD,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;IAEM,OAAO;QACZ,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC,EAAC,QAAQ,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAC,CAAC,CAAC;QAC1D,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;IAEM,QAAQ,CAAC,OAAe,EAAE,KAAa;QAC5C,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC7C,CAAC;IAEM,SAAS,CAAC,QAA4B;QAC3C,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;YACzB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE;gBACpD,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;gBAC3C,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAClC,CAAC,CAAC,CAAC,CAAC;QACN,CAAC,CAAC,CAAC;IACL,CAAC;IAED,iBAAiB,CAAC,IAAe,EAAE,YAAuC;QACxE,YAAY,CAAC,OAAO,CAAC,CAAC,IAA6B,EAAE,EAAE;YACrD,IAAG,IAAI,CAAC,IAAI,KAAK,uBAAuB,CAAC,OAAO,EAAE;gBAChD,IAAG,IAAI,CAAC,YAAY,EAAE;oBACpB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,SAAS,CAAC,EAAE,CAAC,CAAC;oBAC7C,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;iBAC1C;gBACD,IAAG,IAAI,CAAC,aAAa,EAAE;oBACrB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,SAAS,CAAC,EAAE,CAAC,CAAC;oBAC7C,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAc,EAAE,IAAI,CAAC,aAAa,CAAc,CAAC;oBAC1H,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAc,CAAC,CAAC;iBACtE;aACF;iBAAM;gBACL,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,WAAW,CAAC,IAAI,CAAC,OAAO,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;oBACzF,UAAU,EAAE,IAAI,CAAC,UAAU,IAAI,EAAE;oBACjC,QAAQ,EAAE,QAAQ;iBACnB,CAAC,CAAC,CAAC;aACL;QACH,CAAC,CAAC,CAAC;QACH,OAAO,IAAI,CAAC;IACd,CAAC;IAED,wBAAwB,CAAC,cAAyB;QAChD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,EAAE;YACjE,IAAI,CAAC,IAAI,EAAE,sBAAsB,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;QAC1E,CAAC,CAAC,CAAC,CAAC;QACJ,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,EAAE;YAClE,IAAI,CAAC,IAAI,EAAE,sBAAsB,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;QAC1E,CAAC,CAAC,CAAC,CAAC;IACN,CAAC;;gHAjKU,mBAAmB;oHAAnB,mBAAmB,cAFlB,MAAM;2FAEP,mBAAmB;kBAH/B,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["import { Injectable } from '@angular/core';\nimport { FormArray, FormControl, FormGroup } from '@angular/forms';\nimport { Subject, Subscription } from 'rxjs';\nimport { OnshoreFormTemplateType } from './enums/form.enums';\nimport { OnshoreFormTemplateItem, OnshoreFormValidationItem } from './models/form.models';\n@Injectable({\n  providedIn: 'root'\n})\nexport class OnshoreFormsService {\n\n  _form: FormGroup;\n  _formTemplate: OnshoreFormTemplateItem[];\n  _formValidations: OnshoreFormValidationItem[] = [];\n\n  subscriptions: Array<Subscription> = [];\n\n  public isLoading$: Subject<boolean> = new Subject<boolean>();\n\n  constructor() {\n    this._form = new FormGroup({}, {updateOn: 'change'});\n    this._formTemplate = [];\n  }\n\n  public get form(): FormGroup {\n    return this._form;\n  }\n\n  public get formValues() {\n    return this._form?.value;\n  }\n\n  public patchForm(value: any) {\n    this._form?.patchValue(value);\n  }\n\n  public resetForm() {\n    this._form?.reset();\n    this._form?.updateValueAndValidity({ onlySelf: false, emitEvent: true });\n    this.subscriptions.forEach((subscription: Subscription) => {\n      subscription.unsubscribe();\n    });\n\n    this._form = null!;\n    this._formTemplate = null!;\n  }\n\n  public generateForm(formTemplate: OnshoreFormTemplateItem[]): FormGroup | null {\n    this._formTemplate = formTemplate;\n    this._form = new FormGroup({}, {updateOn: 'change'});\n    this._form = this.iterateNestedForm(this._form, formTemplate);\n    return this._form;\n  }\n\n  public formTemplate(name: string, formTemplate: OnshoreFormTemplateItem[] = this._formTemplate): OnshoreFormTemplateItem {\n    let template: OnshoreFormTemplateItem;\n\n    if(formTemplate) {\n      for(let i = 0; i < formTemplate?.length; i++) {\n        const item = formTemplate[i];\n        if(item.name === name) {\n          template = item;\n          i = formTemplate.length;\n        }else if(item.subformArray) {\n          const arrayTemplate = this.formTemplate(name, item.subformArray);\n          if(arrayTemplate) template = arrayTemplate;\n        }else if(item.subformObject) {\n          const objectTemplate = this.formTemplate(name, item.subformObject);\n          if(objectTemplate) template = objectTemplate;\n        }\n      }\n    }\n\n    return template!;\n  }\n\n  public formControl(name: string, formGroup: FormGroup | null = this._form): FormControl {\n    return formGroup?.get(name) as FormControl;\n  }\n\n  public formArray(name: string): FormArray {\n    return this._form?.get(name) as FormArray;\n  }\n\n  public formGroup(form: FormGroup, name: string): FormGroup  {\n    return form.get(name) as FormGroup;\n  }\n\n  public addFormArrayItem(name: string, item: OnshoreFormTemplateItem) {\n    let formControls = <any>{};\n\n    if(item) {\n      item.subformArray?.forEach((subitem: OnshoreFormTemplateItem) => {\n        formControls[subitem.name] = new FormControl(subitem.default !== undefined ? subitem.default : '', {\n          validators: subitem.validators || [],\n          updateOn: 'change'\n        });\n      });\n    }\n\n    const formGroup = new FormGroup(formControls);\n    formGroup.setParent(this.formArray(name));\n\n    this.formArray(name).push(formGroup);\n\n    this.subscribeNestedFormGroup(formGroup);\n  }\n\n  public removeFormArrayItem(form: FormArray, index: number) {\n    form.removeAt(index);\n  }\n\n  public setFormValidations(validations: OnshoreFormValidationItem[] = []) {\n    this._formValidations = validations;\n  }\n\n  public enable() {\n    setTimeout(() => {\n      this._form?.enable({onlySelf: true, emitEvent: false});\n    }, 100);\n  }\n\n  public disable() {\n    setTimeout(() => {\n      this._form?.disable({onlySelf: true, emitEvent: false});\n    }, 100);\n  }\n\n  public setError(control: string, error: Object) {\n    this.formControl(control).setErrors(error);\n  }\n\n  public setLoader(loaders$: Subject<boolean>[]) {\n    loaders$.forEach($loader => {\n      this.subscriptions.push($loader.subscribe(isLoading => {\n        isLoading ? this.disable() : this.enable();\n        this.isLoading$.next(isLoading);\n      }));\n    });\n  }\n\n  iterateNestedForm(form: FormGroup, formTemplate: OnshoreFormTemplateItem[]): any {\n    formTemplate.forEach((item: OnshoreFormTemplateItem) => {\n      if(item.type === OnshoreFormTemplateType.subform) {\n        if(item.subformArray) {\n          form.controls[item.name] = new FormArray([]);\n          form.controls[item.name].setParent(form);\n        }\n        if(item.subformObject) {\n          form.controls[item.name] = new FormGroup({});\n          form.controls[item.name] = this.iterateNestedForm(form.controls[item.name] as FormGroup, item.subformObject) as FormGroup;\n          this.subscribeNestedFormGroup(form.controls[item.name] as FormGroup);\n        }\n      } else {\n        form.addControl(item.name, new FormControl(item.default !== undefined ? item.default : '', {\n          validators: item.validators || [],\n          updateOn: 'change'\n        }));\n      }\n    });\n    return form;\n  }\n\n  subscribeNestedFormGroup(nestedFormItem: FormGroup) {\n    this.subscriptions.push(nestedFormItem.valueChanges.subscribe(() => {\n      this.form?.updateValueAndValidity({ onlySelf: true, emitEvent: false });\n    }));\n    this.subscriptions.push(nestedFormItem.statusChanges.subscribe(() => {\n      this.form?.updateValueAndValidity({ onlySelf: true, emitEvent: false });\n    }));\n  }\n\n}\n"]}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public-api';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib25zaG9yZS1mb3Jtcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL29uc2hvcmUtZm9ybXMvc3JjL29uc2hvcmUtZm9ybXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Public API Surface of onshore-forms
|
|
3
|
+
*/
|
|
4
|
+
export * from './lib/onshore-forms.service';
|
|
5
|
+
export * from './lib/onshore-forms.component';
|
|
6
|
+
export * from './lib/onshore-forms.module';
|
|
7
|
+
export * from './lib/enums/form.enums';
|
|
8
|
+
export * from './lib/models/form.models';
|
|
9
|
+
export * from './lib/components/form-autocomplete-item/form-autocomplete-item.component';
|
|
10
|
+
export * from './lib/components/form-checkbox-item/form-checkbox-item.component';
|
|
11
|
+
export * from './lib/components/form-colorpicker-item/form-colorpicker-item.component';
|
|
12
|
+
export * from './lib/components/form-dropdown-item/form-dropdown-item.component';
|
|
13
|
+
export * from './lib/components/form-image-item/form-image-item.component';
|
|
14
|
+
export * from './lib/components/form-input-item/form-input-item.component';
|
|
15
|
+
export * from './lib/components/form-switch-item/form-switch-item.component';
|
|
16
|
+
export * from './lib/components/form-textarea-item/form-textarea-item.component';
|
|
17
|
+
export * from './lib/components/form-validation-output/form-validation-output.component';
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL29uc2hvcmUtZm9ybXMvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYywwRUFBMEUsQ0FBQztBQUN6RixjQUFjLGtFQUFrRSxDQUFDO0FBQ2pGLGNBQWMsd0VBQXdFLENBQUM7QUFDdkYsY0FBYyxrRUFBa0UsQ0FBQztBQUNqRixjQUFjLDREQUE0RCxDQUFDO0FBQzNFLGNBQWMsNERBQTRELENBQUM7QUFDM0UsY0FBYyw4REFBOEQsQ0FBQztBQUM3RSxjQUFjLGtFQUFrRSxDQUFDO0FBQ2pGLGNBQWMsMEVBQTBFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIG9uc2hvcmUtZm9ybXNcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9vbnNob3JlLWZvcm1zLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvb25zaG9yZS1mb3Jtcy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvb25zaG9yZS1mb3Jtcy5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZW51bXMvZm9ybS5lbnVtcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RlbHMvZm9ybS5tb2RlbHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9mb3JtLWF1dG9jb21wbGV0ZS1pdGVtL2Zvcm0tYXV0b2NvbXBsZXRlLWl0ZW0uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvZm9ybS1jaGVja2JveC1pdGVtL2Zvcm0tY2hlY2tib3gtaXRlbS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9mb3JtLWNvbG9ycGlja2VyLWl0ZW0vZm9ybS1jb2xvcnBpY2tlci1pdGVtLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Zvcm0tZHJvcGRvd24taXRlbS9mb3JtLWRyb3Bkb3duLWl0ZW0uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvZm9ybS1pbWFnZS1pdGVtL2Zvcm0taW1hZ2UtaXRlbS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9mb3JtLWlucHV0LWl0ZW0vZm9ybS1pbnB1dC1pdGVtLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Zvcm0tc3dpdGNoLWl0ZW0vZm9ybS1zd2l0Y2gtaXRlbS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9mb3JtLXRleHRhcmVhLWl0ZW0vZm9ybS10ZXh0YXJlYS1pdGVtLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Zvcm0tdmFsaWRhdGlvbi1vdXRwdXQvZm9ybS12YWxpZGF0aW9uLW91dHB1dC5jb21wb25lbnQnO1xuIl19
|