@ruc-lib/metaform 2.0.0
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 +135 -0
- package/components/ruc-meta-checkbox-group/ruc-meta-checkbox-group.component.d.ts +18 -0
- package/components/ruc-meta-inputs/ruc-meta-inputs.component.d.ts +23 -0
- package/components/ruc-meta-radio-group/ruc-meta-radio-group.component.d.ts +20 -0
- package/components/ruc-meta-select/ruc-meta-select.component.d.ts +17 -0
- package/components/ruc-text-area/ruc-text-area.component.d.ts +19 -0
- package/esm2020/components/ruc-meta-checkbox-group/ruc-meta-checkbox-group.component.mjs +42 -0
- package/esm2020/components/ruc-meta-inputs/ruc-meta-inputs.component.mjs +54 -0
- package/esm2020/components/ruc-meta-radio-group/ruc-meta-radio-group.component.mjs +38 -0
- package/esm2020/components/ruc-meta-select/ruc-meta-select.component.mjs +56 -0
- package/esm2020/components/ruc-text-area/ruc-text-area.component.mjs +39 -0
- package/esm2020/index.mjs +3 -0
- package/esm2020/interfaces/metaFormsDefault.mjs +2 -0
- package/esm2020/lib/ruclib-metaform/ruclib-metaform.component.mjs +105 -0
- package/esm2020/lib/ruclib-metaform.module.mjs +100 -0
- package/esm2020/ruc-lib-metaform.mjs +5 -0
- package/esm2020/services/ruc-meta-form-validation.service.mjs +29 -0
- package/esm2020/services/ruc-meta-form.service.mjs +23 -0
- package/fesm2015/ruc-lib-metaform.mjs +432 -0
- package/fesm2015/ruc-lib-metaform.mjs.map +1 -0
- package/fesm2020/ruc-lib-metaform.mjs +432 -0
- package/fesm2020/ruc-lib-metaform.mjs.map +1 -0
- package/index.d.ts +2 -0
- package/interfaces/metaFormsDefault.d.ts +72 -0
- package/lib/ruclib-metaform/ruclib-metaform.component.d.ts +45 -0
- package/lib/ruclib-metaform.module.d.ts +27 -0
- package/package.json +38 -0
- package/services/ruc-meta-form-validation.service.d.ts +12 -0
- package/services/ruc-meta-form.service.d.ts +14 -0
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import { Component, Input, Output, EventEmitter } from '@angular/core';
|
|
2
|
+
import { RucMetaFormService } from "../../services/ruc-meta-form.service";
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../../services/ruc-meta-form.service";
|
|
5
|
+
import * as i2 from "@angular/common";
|
|
6
|
+
import * as i3 from "@angular/forms";
|
|
7
|
+
import * as i4 from "@angular/material/button";
|
|
8
|
+
import * as i5 from "@angular/material/stepper";
|
|
9
|
+
import * as i6 from "@ruc-lib/multi-select";
|
|
10
|
+
import * as i7 from "@ruc-lib/multi-file-upload";
|
|
11
|
+
import * as i8 from "../../components/ruc-meta-inputs/ruc-meta-inputs.component";
|
|
12
|
+
import * as i9 from "../../components/ruc-meta-radio-group/ruc-meta-radio-group.component";
|
|
13
|
+
import * as i10 from "../../components/ruc-meta-checkbox-group/ruc-meta-checkbox-group.component";
|
|
14
|
+
import * as i11 from "../../components/ruc-meta-select/ruc-meta-select.component";
|
|
15
|
+
import * as i12 from "../../components/ruc-text-area/ruc-text-area.component";
|
|
16
|
+
export class RuclibMetaformComponent {
|
|
17
|
+
constructor(service) {
|
|
18
|
+
this.service = service;
|
|
19
|
+
this.rucEvent = new EventEmitter();
|
|
20
|
+
this.childRucEvent = new EventEmitter();
|
|
21
|
+
this.rucInputData = [];
|
|
22
|
+
}
|
|
23
|
+
ngOnInit() {
|
|
24
|
+
if (!this.isChild) {
|
|
25
|
+
this.service.getFormJson(this.rucInputData);
|
|
26
|
+
this.getFormJson();
|
|
27
|
+
}
|
|
28
|
+
else {
|
|
29
|
+
this.formData = this.childForm;
|
|
30
|
+
}
|
|
31
|
+
this.inputObjectDataMultiFileUpload = {
|
|
32
|
+
multifileSelection: true,
|
|
33
|
+
displayThumbnail: true,
|
|
34
|
+
label: 'Choose File',
|
|
35
|
+
uploadUrl: '/api/upload',
|
|
36
|
+
deleteUrl: '/api/delete',
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* The purpose of this function to pass data from dependentFields to parent field
|
|
41
|
+
* @param getObject
|
|
42
|
+
* @param j
|
|
43
|
+
*/
|
|
44
|
+
passEvent(getObject, formElement) {
|
|
45
|
+
const eventOutput = getObject?.eventOutput ? getObject.eventOutput : this.service.currentFormElement;
|
|
46
|
+
if (getObject?.eventName == "onUploading") {
|
|
47
|
+
formElement.value = getObject?.eventOutput.name ? getObject?.eventOutput.name : getObject?.eventOutput[0].name;
|
|
48
|
+
}
|
|
49
|
+
this.rucEvent.emit({ 'eventName': 'metaFormData', 'eventOutput': eventOutput, 'formData': this.formData, 'rucComponentEvent': getObject?.eventName });
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Initial function to load for data
|
|
53
|
+
*/
|
|
54
|
+
getFormJson() {
|
|
55
|
+
this.metaFormSubscribeInputs = this.service.formData.asObservable()
|
|
56
|
+
.subscribe((formData) => {
|
|
57
|
+
this.formData = formData;
|
|
58
|
+
this.service.metaFormData = this.formData;
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* This function is to emit form data
|
|
63
|
+
* @param event
|
|
64
|
+
*/
|
|
65
|
+
getMetaFormData(event) {
|
|
66
|
+
this.rucEvent.emit({ 'eventName': 'metaFormData', 'eventOutput': event, 'formData': this.formData });
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* Clear form data
|
|
70
|
+
*/
|
|
71
|
+
clearForm() {
|
|
72
|
+
this.formData.map((x) => {
|
|
73
|
+
x.value = '';
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* Destroy the subscriber
|
|
78
|
+
*/
|
|
79
|
+
ngOnDestroy() {
|
|
80
|
+
if (this.metaFormSubscribeInputs) {
|
|
81
|
+
this.metaFormSubscribeInputs.unsubscribe();
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
RuclibMetaformComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: RuclibMetaformComponent, deps: [{ token: i1.RucMetaFormService }], target: i0.ɵɵFactoryTarget.Component });
|
|
86
|
+
RuclibMetaformComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: RuclibMetaformComponent, selector: "uxp-ruclib-metaform", inputs: { rucInputData: "rucInputData", childForm: "childForm", customTheme: "customTheme", isChild: "isChild", selectedParentId: "selectedParentId" }, outputs: { rucEvent: "rucEvent", childRucEvent: "childRucEvent" }, ngImport: i0, template: "<form novalidate>\r\n <ng-container *ngFor=\"let dynamicField of formData; let j = index;\" [ngSwitch]=\"dynamicField?.fieldType\">\r\n <div [ngStyle] = \"{ 'width.%': dynamicField.sameRowColumnWidth - 2 }\" [ngClass]=\"dynamicField.sameRow === true ? 'margin-5 column-in-same-row' : 'margin-5 column-in-new-row'\" \r\n *ngIf=\"dynamicField.formType != 'stepper'\">\r\n \r\n <ng-template [ngSwitchCase]=\"'input'\">\r\n <div *ngIf=\"(!selectedParentId && !dynamicField.hasDependentFields) || (selectedParentId && selectedParentId == dynamicField.dependentFieldParentId)\">\r\n <ruc-meta-inputs [customTheme] = \"customTheme\" [rucInputData]=\"dynamicField\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-inputs>\r\n </div>\r\n </ng-template>\r\n <ng-template [ngSwitchCase]=\"'radio'\">\r\n <div *ngIf=\"(!selectedParentId && !dynamicField.dependentFields) || (selectedParentId && selectedParentId == dynamicField.dependentFieldParentId) || (!selectedParentId && dynamicField.dependentFields && !isChild)\">\r\n <ruc-meta-radio-group [customTheme] = \"customTheme\" [rucInputData]=\"dynamicField\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-radio-group>\r\n </div>\r\n </ng-template>\r\n <ng-template [ngSwitchCase]=\"'checkbox'\">\r\n <div *ngIf=\"(!selectedParentId && !dynamicField.dependentFields) || (selectedParentId && selectedParentId == dynamicField.dependentFieldParentId) || (!selectedParentId && dynamicField.dependentFields && !isChild)\">\r\n <ruc-meta-checkbox-group [rucInputData]=\"dynamicField\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-checkbox-group>\r\n </div>\r\n </ng-template>\r\n <ng-template class=\"\" [ngSwitchCase]=\"'select'\">\r\n <div *ngIf=\"(!selectedParentId && !dynamicField.dependentFields) || (selectedParentId && selectedParentId == dynamicField.dependentFieldParentId) || (!selectedParentId && dynamicField.dependentFields && !isChild)\">\r\n <ruc-meta-select [rucInputData]=\"dynamicField\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-select>\r\n </div>\r\n </ng-template>\r\n <ng-template class=\"\" [ngSwitchCase]=\"'textarea'\">\r\n <ruc-text-area [rucInputData]=\"dynamicField\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-text-area>\r\n </ng-template>\r\n <ng-template [ngSwitchCase]=\"'rucMultiSelect'\">\r\n <uxp-ruclib-multi-select [rucInputData]=\"dynamicField?.rucMultiselectInput?.rucInputData\"\r\n [dataSource]=\"dynamicField?.rucMultiselectInput?.dataSource\" [customTheme]=\"customTheme\"\r\n (rucEvent)=\"passEvent($event)\"></uxp-ruclib-multi-select>\r\n </ng-template>\r\n <ng-template [ngSwitchCase]=\"'rucMultiFileUpload'\">\r\n <uxp-ruclib-multi-file-upload\r\n [rucInputData]=\"dynamicField?.rucMultiFileUploadInput?.rucInputData\" [customTheme]=\"customTheme\"\r\n (rucEvent)=\"passEvent($event,dynamicField)\"></uxp-ruclib-multi-file-upload>\r\n </ng-template>\r\n <div *ngIf=\"dynamicField.hasDependentFields && dynamicField.value\">\r\n <uxp-ruclib-metaform #dynamicField.id [rucInputData]=\"formData\" [childForm] =\"dynamicField.dependentFields\"\r\n [isChild]=\"true\" [selectedParentId] = \"dynamicField.selectedParentId\" (rucEvent)=\"passEvent($event,dynamicField.id)\"></uxp-ruclib-metaform>\r\n </div>\r\n \r\n </div>\r\n <div *ngIf=\"dynamicField.formType == 'stepper'\">\r\n <mat-stepper linear #stepper>\r\n <div *ngFor=\"let stapperField of dynamicField.stepper; let s = index;\" [ngSwitch]=\"stapperField?.fieldType\">\r\n <mat-step [stepControl]=\"stapperField.stepControl\" *ngIf=\"stapperField.stepControl != 'done'\">\r\n <ng-template matStepLabel>{{stapperField.stepperlabel}}</ng-template>\r\n <ng-container *ngFor=\"let stepperFormData of stapperField.stepperFormData; let j = index;\" [ngSwitch]=\"stepperFormData?.fieldType\">\r\n <div [ngStyle] = \"{ 'width.%': dynamicField.sameRowColumnWidth - 2 }\" [ngClass]=\"dynamicField.sameRow === true ? 'margin-5 column-in-same-row' : 'margin-5 column-in-new-row'\" \r\n >\r\n <ng-template [ngSwitchCase]=\"'input'\">\r\n <div>\r\n <ruc-meta-inputs [customTheme] = \"customTheme\" [rucInputData]=\"stepperFormData\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-inputs>\r\n </div>\r\n </ng-template>\r\n <ng-template class=\"\" [ngSwitchCase]=\"'textarea'\">\r\n <ruc-text-area [rucInputData]=\"stepperFormData\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-text-area>\r\n </ng-template>\r\n <ng-template [ngSwitchCase]=\"'radio'\">\r\n <div>\r\n <ruc-meta-radio-group [customTheme] = \"customTheme\" [rucInputData]=\"stepperFormData\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-radio-group>\r\n </div>\r\n </ng-template>\r\n <ng-template [ngSwitchCase]=\"'checkbox'\">\r\n <div >\r\n <ruc-meta-checkbox-group [rucInputData]=\"stepperFormData\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-checkbox-group>\r\n </div>\r\n </ng-template>\r\n <ng-template class=\"\" [ngSwitchCase]=\"'select'\">\r\n <div *ngIf=\"(!selectedParentId && !dynamicField.dependentFields) || (selectedParentId && selectedParentId == dynamicField.dependentFieldParentId) || (!selectedParentId && dynamicField.dependentFields && !isChild)\">\r\n <ruc-meta-select [rucInputData]=\"dynamicField\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-select>\r\n </div>\r\n </ng-template>\r\n </div>\r\n </ng-container>\r\n <div>\r\n <button mat-button matStepperPrevious *ngIf=\"s > 0\">Back</button>\r\n <button mat-button matStepperNext *ngIf=\"s< dynamicField.stepper.length\">Next</button>\r\n </div>\r\n </mat-step>\r\n <mat-step *ngIf=\"stapperField.stepControl == 'done'\">\r\n <ng-template matStepLabel>{{stapperField.stepControl}}</ng-template>\r\n <p>{{stapperField.stepperlabel}}</p>\r\n <div>\r\n <button mat-button matStepperPrevious>Back</button>\r\n <button mat-button (click)=\"stepper.reset()\">Reset</button>\r\n </div>\r\n </mat-step>\r\n </div>\r\n </mat-stepper>\r\n </div>\r\n </ng-container>\r\n <ng-container>\r\n <button mat-raised-button color=\"primary\" (click)=\"clearForm()\" *ngIf=\"!isChild\">Clear Form</button>\r\n </ng-container>\r\n \r\n</form>", styles: [".form-error{color:red}.column-in-same-row{float:left}.column-in-new-row{clear:left}.margin-5{margin:1%}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i4.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i5.MatStep, selector: "mat-step", inputs: ["color"], exportAs: ["matStep"] }, { kind: "directive", type: i5.MatStepLabel, selector: "[matStepLabel]" }, { kind: "component", type: i5.MatStepper, selector: "mat-stepper, mat-vertical-stepper, mat-horizontal-stepper, [matStepper]", inputs: ["selectedIndex", "disableRipple", "color", "labelPosition", "headerPosition", "animationDuration"], outputs: ["animationDone"], exportAs: ["matStepper", "matVerticalStepper", "matHorizontalStepper"] }, { kind: "directive", type: i5.MatStepperNext, selector: "button[matStepperNext]", inputs: ["type"] }, { kind: "directive", type: i5.MatStepperPrevious, selector: "button[matStepperPrevious]", inputs: ["type"] }, { kind: "component", type: i6.RuclibMultiSelectComponent, selector: "uxp-ruclib-multi-select", inputs: ["rucInputData", "customTheme", "dataSource"], outputs: ["rucEvent"] }, { kind: "component", type: i7.RuclibMultiFileUploadComponent, selector: "uxp-ruclib-multi-file-upload", inputs: ["rucInputData", "customTheme"], outputs: ["rucEvent"] }, { kind: "component", type: RuclibMetaformComponent, selector: "uxp-ruclib-metaform", inputs: ["rucInputData", "childForm", "customTheme", "isChild", "selectedParentId"], outputs: ["rucEvent", "childRucEvent"] }, { kind: "component", type: i8.RucMetaInputsComponent, selector: "ruc-meta-inputs", inputs: ["rucInputData", "selectedParentId", "customTheme"], outputs: ["transferUserInput"] }, { kind: "component", type: i9.RucMetaRadioGroupComponent, selector: "ruc-meta-radio-group", inputs: ["rucInputData", "customTheme"], outputs: ["transferUserInput"] }, { kind: "component", type: i10.RucMetaCheckboxGroupComponent, selector: "ruc-meta-checkbox-group", inputs: ["rucInputData"], outputs: ["transferUserInput"] }, { kind: "component", type: i11.RucMetaSelectComponent, selector: "ruc-meta-select", inputs: ["rucInputData"], outputs: ["transferUserInput"] }, { kind: "component", type: i12.RucTextAreaComponent, selector: "ruc-text-area", inputs: ["rucInputData", "customTheme"], outputs: ["transferUserInput"] }] });
|
|
87
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: RuclibMetaformComponent, decorators: [{
|
|
88
|
+
type: Component,
|
|
89
|
+
args: [{ selector: 'uxp-ruclib-metaform', template: "<form novalidate>\r\n <ng-container *ngFor=\"let dynamicField of formData; let j = index;\" [ngSwitch]=\"dynamicField?.fieldType\">\r\n <div [ngStyle] = \"{ 'width.%': dynamicField.sameRowColumnWidth - 2 }\" [ngClass]=\"dynamicField.sameRow === true ? 'margin-5 column-in-same-row' : 'margin-5 column-in-new-row'\" \r\n *ngIf=\"dynamicField.formType != 'stepper'\">\r\n \r\n <ng-template [ngSwitchCase]=\"'input'\">\r\n <div *ngIf=\"(!selectedParentId && !dynamicField.hasDependentFields) || (selectedParentId && selectedParentId == dynamicField.dependentFieldParentId)\">\r\n <ruc-meta-inputs [customTheme] = \"customTheme\" [rucInputData]=\"dynamicField\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-inputs>\r\n </div>\r\n </ng-template>\r\n <ng-template [ngSwitchCase]=\"'radio'\">\r\n <div *ngIf=\"(!selectedParentId && !dynamicField.dependentFields) || (selectedParentId && selectedParentId == dynamicField.dependentFieldParentId) || (!selectedParentId && dynamicField.dependentFields && !isChild)\">\r\n <ruc-meta-radio-group [customTheme] = \"customTheme\" [rucInputData]=\"dynamicField\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-radio-group>\r\n </div>\r\n </ng-template>\r\n <ng-template [ngSwitchCase]=\"'checkbox'\">\r\n <div *ngIf=\"(!selectedParentId && !dynamicField.dependentFields) || (selectedParentId && selectedParentId == dynamicField.dependentFieldParentId) || (!selectedParentId && dynamicField.dependentFields && !isChild)\">\r\n <ruc-meta-checkbox-group [rucInputData]=\"dynamicField\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-checkbox-group>\r\n </div>\r\n </ng-template>\r\n <ng-template class=\"\" [ngSwitchCase]=\"'select'\">\r\n <div *ngIf=\"(!selectedParentId && !dynamicField.dependentFields) || (selectedParentId && selectedParentId == dynamicField.dependentFieldParentId) || (!selectedParentId && dynamicField.dependentFields && !isChild)\">\r\n <ruc-meta-select [rucInputData]=\"dynamicField\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-select>\r\n </div>\r\n </ng-template>\r\n <ng-template class=\"\" [ngSwitchCase]=\"'textarea'\">\r\n <ruc-text-area [rucInputData]=\"dynamicField\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-text-area>\r\n </ng-template>\r\n <ng-template [ngSwitchCase]=\"'rucMultiSelect'\">\r\n <uxp-ruclib-multi-select [rucInputData]=\"dynamicField?.rucMultiselectInput?.rucInputData\"\r\n [dataSource]=\"dynamicField?.rucMultiselectInput?.dataSource\" [customTheme]=\"customTheme\"\r\n (rucEvent)=\"passEvent($event)\"></uxp-ruclib-multi-select>\r\n </ng-template>\r\n <ng-template [ngSwitchCase]=\"'rucMultiFileUpload'\">\r\n <uxp-ruclib-multi-file-upload\r\n [rucInputData]=\"dynamicField?.rucMultiFileUploadInput?.rucInputData\" [customTheme]=\"customTheme\"\r\n (rucEvent)=\"passEvent($event,dynamicField)\"></uxp-ruclib-multi-file-upload>\r\n </ng-template>\r\n <div *ngIf=\"dynamicField.hasDependentFields && dynamicField.value\">\r\n <uxp-ruclib-metaform #dynamicField.id [rucInputData]=\"formData\" [childForm] =\"dynamicField.dependentFields\"\r\n [isChild]=\"true\" [selectedParentId] = \"dynamicField.selectedParentId\" (rucEvent)=\"passEvent($event,dynamicField.id)\"></uxp-ruclib-metaform>\r\n </div>\r\n \r\n </div>\r\n <div *ngIf=\"dynamicField.formType == 'stepper'\">\r\n <mat-stepper linear #stepper>\r\n <div *ngFor=\"let stapperField of dynamicField.stepper; let s = index;\" [ngSwitch]=\"stapperField?.fieldType\">\r\n <mat-step [stepControl]=\"stapperField.stepControl\" *ngIf=\"stapperField.stepControl != 'done'\">\r\n <ng-template matStepLabel>{{stapperField.stepperlabel}}</ng-template>\r\n <ng-container *ngFor=\"let stepperFormData of stapperField.stepperFormData; let j = index;\" [ngSwitch]=\"stepperFormData?.fieldType\">\r\n <div [ngStyle] = \"{ 'width.%': dynamicField.sameRowColumnWidth - 2 }\" [ngClass]=\"dynamicField.sameRow === true ? 'margin-5 column-in-same-row' : 'margin-5 column-in-new-row'\" \r\n >\r\n <ng-template [ngSwitchCase]=\"'input'\">\r\n <div>\r\n <ruc-meta-inputs [customTheme] = \"customTheme\" [rucInputData]=\"stepperFormData\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-inputs>\r\n </div>\r\n </ng-template>\r\n <ng-template class=\"\" [ngSwitchCase]=\"'textarea'\">\r\n <ruc-text-area [rucInputData]=\"stepperFormData\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-text-area>\r\n </ng-template>\r\n <ng-template [ngSwitchCase]=\"'radio'\">\r\n <div>\r\n <ruc-meta-radio-group [customTheme] = \"customTheme\" [rucInputData]=\"stepperFormData\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-radio-group>\r\n </div>\r\n </ng-template>\r\n <ng-template [ngSwitchCase]=\"'checkbox'\">\r\n <div >\r\n <ruc-meta-checkbox-group [rucInputData]=\"stepperFormData\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-checkbox-group>\r\n </div>\r\n </ng-template>\r\n <ng-template class=\"\" [ngSwitchCase]=\"'select'\">\r\n <div *ngIf=\"(!selectedParentId && !dynamicField.dependentFields) || (selectedParentId && selectedParentId == dynamicField.dependentFieldParentId) || (!selectedParentId && dynamicField.dependentFields && !isChild)\">\r\n <ruc-meta-select [rucInputData]=\"dynamicField\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-select>\r\n </div>\r\n </ng-template>\r\n </div>\r\n </ng-container>\r\n <div>\r\n <button mat-button matStepperPrevious *ngIf=\"s > 0\">Back</button>\r\n <button mat-button matStepperNext *ngIf=\"s< dynamicField.stepper.length\">Next</button>\r\n </div>\r\n </mat-step>\r\n <mat-step *ngIf=\"stapperField.stepControl == 'done'\">\r\n <ng-template matStepLabel>{{stapperField.stepControl}}</ng-template>\r\n <p>{{stapperField.stepperlabel}}</p>\r\n <div>\r\n <button mat-button matStepperPrevious>Back</button>\r\n <button mat-button (click)=\"stepper.reset()\">Reset</button>\r\n </div>\r\n </mat-step>\r\n </div>\r\n </mat-stepper>\r\n </div>\r\n </ng-container>\r\n <ng-container>\r\n <button mat-raised-button color=\"primary\" (click)=\"clearForm()\" *ngIf=\"!isChild\">Clear Form</button>\r\n </ng-container>\r\n \r\n</form>", styles: [".form-error{color:red}.column-in-same-row{float:left}.column-in-new-row{clear:left}.margin-5{margin:1%}\n"] }]
|
|
90
|
+
}], ctorParameters: function () { return [{ type: i1.RucMetaFormService }]; }, propDecorators: { rucEvent: [{
|
|
91
|
+
type: Output
|
|
92
|
+
}], childRucEvent: [{
|
|
93
|
+
type: Output
|
|
94
|
+
}], rucInputData: [{
|
|
95
|
+
type: Input
|
|
96
|
+
}], childForm: [{
|
|
97
|
+
type: Input
|
|
98
|
+
}], customTheme: [{
|
|
99
|
+
type: Input
|
|
100
|
+
}], isChild: [{
|
|
101
|
+
type: Input
|
|
102
|
+
}], selectedParentId: [{
|
|
103
|
+
type: Input
|
|
104
|
+
}] } });
|
|
105
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ruclib-metaform.component.js","sourceRoot":"","sources":["../../../../src/lib/ruclib-metaform/ruclib-metaform.component.ts","../../../../src/lib/ruclib-metaform/ruclib-metaform.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAU,YAAY,EAAa,MAAM,eAAe,CAAC;AAE1F,OAAO,EAAE,kBAAkB,EAAE,MAAM,sCAAsC,CAAA;;;;;;;;;;;;;;AAOzE,MAAM,OAAO,uBAAuB;IAYlC,YAAmB,OAA2B;QAA3B,YAAO,GAAP,OAAO,CAAoB;QAXpC,aAAQ,GAAI,IAAI,YAAY,EAAO,CAAC;QACpC,kBAAa,GAAI,IAAI,YAAY,EAAO,CAAC;QAC1C,iBAAY,GAAqB,EAAE,CAAA;IASM,CAAC;IAEnD,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YACjB,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YAC5C,IAAI,CAAC,WAAW,EAAE,CAAC;SACpB;aAAM;YACL,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC;SAChC;QACD,IAAI,CAAC,8BAA8B,GAAG;YACpC,kBAAkB,EAAE,IAAI;YACxB,gBAAgB,EAAE,IAAI;YACtB,KAAK,EAAE,aAAa;YACpB,SAAS,EAAE,aAAa;YACxB,SAAS,EAAE,aAAa;SACzB,CAAC;IACJ,CAAC;IAED;;;;OAIG;IACH,SAAS,CAAC,SAAc,EAAE,WAAiB;QACzC,MAAM,WAAW,GAAG,SAAS,EAAE,WAAW,CAAC,CAAC,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC;QACrG,IAAG,SAAS,EAAE,SAAS,IAAI,aAAa,EAAC;YACvC,WAAW,CAAC,KAAK,GAAG,SAAS,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;SAChH;QACD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,WAAW,EAAE,cAAc,EAAE,aAAa,EAAE,WAAW,EAAE,UAAU,EAAE,IAAI,CAAC,QAAQ,EAAE,mBAAmB,EAAE,SAAS,EAAE,SAAS,EAAE,CAAC,CAAC;IACxJ,CAAC;IAED;;OAEG;IACH,WAAW;QACR,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,YAAY,EAAE;aAClE,SAAS,CACP,CAAC,QAAQ,EAAC,EAAE;YACV,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;YACzB,IAAI,CAAC,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC5C,CAAC,CACF,CAAC;IACN,CAAC;IAED;;;OAGG;IACH,eAAe,CAAC,KAAU;QACxB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,WAAW,EAAE,cAAc,EAAE,aAAa,EAAE,KAAK,EAAE,UAAU,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;IACvG,CAAC;IAED;;OAEG;IACH,SAAS;QACP,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAgB,EAAC,EAAE;YACpC,CAAC,CAAC,KAAK,GAAG,EAAE,CAAC;QACf,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,IAAI,CAAC,uBAAuB,EAAE;YAChC,IAAI,CAAC,uBAAuB,CAAC,WAAW,EAAE,CAAC;SAC5C;IACH,CAAC;;qHAhFU,uBAAuB;yGAAvB,uBAAuB,sRCTpC,ulPAkGO,28EDzFM,uBAAuB;4FAAvB,uBAAuB;kBALnC,SAAS;+BACE,qBAAqB;yGAKrB,QAAQ;sBAAjB,MAAM;gBACG,aAAa;sBAAtB,MAAM;gBACE,YAAY;sBAApB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBAEN,WAAW;sBADV,KAAK;gBAEG,OAAO;sBAAf,KAAK;gBACG,gBAAgB;sBAAxB,KAAK","sourcesContent":["import { Component, Input, Output, OnInit, EventEmitter, OnDestroy } from '@angular/core';\r\nimport {MetaFormConfig} from '../../interfaces/metaFormsDefault';\r\nimport { RucMetaFormService } from \"../../services/ruc-meta-form.service\"\r\nimport { Subscription } from 'rxjs';\r\n@Component({\r\n  selector: 'uxp-ruclib-metaform',\r\n  templateUrl: './ruclib-metaform.component.html',\r\n  styleUrls: ['./ruclib-metaform.component.scss']\r\n})\r\nexport class RuclibMetaformComponent implements OnInit,OnDestroy{\r\n  @Output() rucEvent  = new EventEmitter<any>();\r\n  @Output() childRucEvent  = new EventEmitter<any>();\r\n  @Input() rucInputData: MetaFormConfig[] = []\r\n  @Input() childForm?: MetaFormConfig[]\r\n  @Input()\r\n  customTheme!: string;\r\n  @Input() isChild?: boolean;\r\n  @Input() selectedParentId: any;\r\n  inputObjectDataMultiFileUpload?:any;\r\n  metaFormSubscribeInputs: Subscription | undefined;\r\n  formData: any\r\n  constructor(public service: RucMetaFormService) { }\r\n  \r\n  ngOnInit(): void {\r\n    if (!this.isChild) {\r\n      this.service.getFormJson(this.rucInputData);\r\n      this.getFormJson();\r\n    } else {\r\n      this.formData = this.childForm;\r\n    }\r\n    this.inputObjectDataMultiFileUpload = {\r\n      multifileSelection: true,\r\n      displayThumbnail: true,\r\n      label: 'Choose File',\r\n      uploadUrl: '/api/upload',\r\n      deleteUrl: '/api/delete',\r\n    };\r\n  }\r\n  \r\n  /**\r\n   * The purpose of this function to pass data from dependentFields to parent field\r\n   * @param getObject \r\n   * @param j \r\n   */\r\n  passEvent(getObject: any, formElement?: any) {\r\n    const eventOutput = getObject?.eventOutput ? getObject.eventOutput : this.service.currentFormElement;\r\n    if(getObject?.eventName == \"onUploading\"){\r\n      formElement.value = getObject?.eventOutput.name ? getObject?.eventOutput.name : getObject?.eventOutput[0].name;\r\n    }\r\n    this.rucEvent.emit({ 'eventName': 'metaFormData', 'eventOutput': eventOutput, 'formData': this.formData, 'rucComponentEvent': getObject?.eventName });\r\n  }\r\n\r\n  /**\r\n   * Initial function to load for data\r\n   */\r\n  getFormJson() {\r\n     this.metaFormSubscribeInputs = this.service.formData.asObservable()\r\n     .subscribe(\r\n        (formData)=>{\r\n          this.formData = formData;\r\n          this.service.metaFormData = this.formData;\r\n        }    \r\n      );\r\n  }\r\n\r\n  /**\r\n   *  This function is to emit form data\r\n   * @param event \r\n   */\r\n  getMetaFormData(event: any) {\r\n    this.rucEvent.emit({ 'eventName': 'metaFormData', 'eventOutput': event, 'formData': this.formData });\r\n  }\r\n\r\n  /**\r\n   * Clear form data\r\n   */\r\n  clearForm(){\r\n    this.formData.map((x:MetaFormConfig)=>{\r\n      x.value = '';\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Destroy the subscriber\r\n   */\r\n  ngOnDestroy() {\r\n    if (this.metaFormSubscribeInputs) {\r\n      this.metaFormSubscribeInputs.unsubscribe();\r\n    }\r\n  }\r\n}\r\n","<form novalidate>\r\n    <ng-container *ngFor=\"let dynamicField of formData; let j = index;\" [ngSwitch]=\"dynamicField?.fieldType\">\r\n        <div [ngStyle] = \"{ 'width.%': dynamicField.sameRowColumnWidth - 2 }\"  [ngClass]=\"dynamicField.sameRow === true ? 'margin-5 column-in-same-row' : 'margin-5 column-in-new-row'\" \r\n        *ngIf=\"dynamicField.formType != 'stepper'\">\r\n       \r\n        <ng-template [ngSwitchCase]=\"'input'\">\r\n            <div *ngIf=\"(!selectedParentId && !dynamicField.hasDependentFields) || (selectedParentId && selectedParentId == dynamicField.dependentFieldParentId)\">\r\n                <ruc-meta-inputs [customTheme] = \"customTheme\" [rucInputData]=\"dynamicField\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-inputs>\r\n            </div>\r\n        </ng-template>\r\n        <ng-template [ngSwitchCase]=\"'radio'\">\r\n            <div *ngIf=\"(!selectedParentId && !dynamicField.dependentFields) || (selectedParentId && selectedParentId == dynamicField.dependentFieldParentId) || (!selectedParentId && dynamicField.dependentFields && !isChild)\">\r\n                <ruc-meta-radio-group [customTheme] = \"customTheme\" [rucInputData]=\"dynamicField\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-radio-group>\r\n            </div>\r\n        </ng-template>\r\n        <ng-template [ngSwitchCase]=\"'checkbox'\">\r\n            <div *ngIf=\"(!selectedParentId && !dynamicField.dependentFields) || (selectedParentId && selectedParentId == dynamicField.dependentFieldParentId) || (!selectedParentId && dynamicField.dependentFields && !isChild)\">\r\n                <ruc-meta-checkbox-group [rucInputData]=\"dynamicField\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-checkbox-group>\r\n            </div>\r\n        </ng-template>\r\n        <ng-template class=\"\" [ngSwitchCase]=\"'select'\">\r\n            <div *ngIf=\"(!selectedParentId && !dynamicField.dependentFields) || (selectedParentId && selectedParentId == dynamicField.dependentFieldParentId) || (!selectedParentId && dynamicField.dependentFields && !isChild)\">\r\n                <ruc-meta-select [rucInputData]=\"dynamicField\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-select>\r\n            </div>\r\n        </ng-template>\r\n        <ng-template class=\"\" [ngSwitchCase]=\"'textarea'\">\r\n            <ruc-text-area [rucInputData]=\"dynamicField\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-text-area>\r\n        </ng-template>\r\n        <ng-template [ngSwitchCase]=\"'rucMultiSelect'\">\r\n            <uxp-ruclib-multi-select [rucInputData]=\"dynamicField?.rucMultiselectInput?.rucInputData\"\r\n            [dataSource]=\"dynamicField?.rucMultiselectInput?.dataSource\" [customTheme]=\"customTheme\"\r\n                (rucEvent)=\"passEvent($event)\"></uxp-ruclib-multi-select>\r\n        </ng-template>\r\n        <ng-template [ngSwitchCase]=\"'rucMultiFileUpload'\">\r\n            <uxp-ruclib-multi-file-upload\r\n                [rucInputData]=\"dynamicField?.rucMultiFileUploadInput?.rucInputData\" [customTheme]=\"customTheme\"\r\n                (rucEvent)=\"passEvent($event,dynamicField)\"></uxp-ruclib-multi-file-upload>\r\n        </ng-template>\r\n        <div *ngIf=\"dynamicField.hasDependentFields && dynamicField.value\">\r\n            <uxp-ruclib-metaform #dynamicField.id [rucInputData]=\"formData\" [childForm] =\"dynamicField.dependentFields\"\r\n                     [isChild]=\"true\" [selectedParentId] = \"dynamicField.selectedParentId\" (rucEvent)=\"passEvent($event,dynamicField.id)\"></uxp-ruclib-metaform>\r\n        </div>\r\n        \r\n    </div>\r\n    <div *ngIf=\"dynamicField.formType == 'stepper'\">\r\n            <mat-stepper linear #stepper>\r\n                <div *ngFor=\"let stapperField of dynamicField.stepper; let s = index;\"  [ngSwitch]=\"stapperField?.fieldType\">\r\n                    <mat-step [stepControl]=\"stapperField.stepControl\" *ngIf=\"stapperField.stepControl != 'done'\">\r\n                        <ng-template matStepLabel>{{stapperField.stepperlabel}}</ng-template>\r\n                        <ng-container *ngFor=\"let stepperFormData of stapperField.stepperFormData; let j = index;\" [ngSwitch]=\"stepperFormData?.fieldType\">\r\n                            <div [ngStyle] = \"{ 'width.%': dynamicField.sameRowColumnWidth - 2 }\"  [ngClass]=\"dynamicField.sameRow === true ? 'margin-5 column-in-same-row' : 'margin-5 column-in-new-row'\" \r\n                            >\r\n                            <ng-template [ngSwitchCase]=\"'input'\">\r\n                                <div>\r\n                                    <ruc-meta-inputs [customTheme] = \"customTheme\" [rucInputData]=\"stepperFormData\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-inputs>\r\n                                </div>\r\n                            </ng-template>\r\n                            <ng-template class=\"\" [ngSwitchCase]=\"'textarea'\">\r\n                                <ruc-text-area [rucInputData]=\"stepperFormData\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-text-area>\r\n                            </ng-template>\r\n                            <ng-template [ngSwitchCase]=\"'radio'\">\r\n                                <div>\r\n                                    <ruc-meta-radio-group [customTheme] = \"customTheme\" [rucInputData]=\"stepperFormData\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-radio-group>\r\n                                </div>\r\n                            </ng-template>\r\n                            <ng-template [ngSwitchCase]=\"'checkbox'\">\r\n                                <div >\r\n                                    <ruc-meta-checkbox-group [rucInputData]=\"stepperFormData\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-checkbox-group>\r\n                                </div>\r\n                            </ng-template>\r\n                            <ng-template class=\"\" [ngSwitchCase]=\"'select'\">\r\n                                <div *ngIf=\"(!selectedParentId && !dynamicField.dependentFields) || (selectedParentId && selectedParentId == dynamicField.dependentFieldParentId) || (!selectedParentId && dynamicField.dependentFields && !isChild)\">\r\n                                    <ruc-meta-select [rucInputData]=\"dynamicField\" (transferUserInput)=\"getMetaFormData($event)\"></ruc-meta-select>\r\n                                </div>\r\n                            </ng-template>\r\n                        </div>\r\n                        </ng-container>\r\n                        <div>\r\n                            <button mat-button matStepperPrevious *ngIf=\"s > 0\">Back</button>\r\n                            <button mat-button matStepperNext *ngIf=\"s< dynamicField.stepper.length\">Next</button>\r\n                          </div>\r\n                    </mat-step>\r\n                    <mat-step *ngIf=\"stapperField.stepControl == 'done'\">\r\n                        <ng-template matStepLabel>{{stapperField.stepControl}}</ng-template>\r\n                        <p>{{stapperField.stepperlabel}}</p>\r\n                        <div>\r\n                          <button mat-button matStepperPrevious>Back</button>\r\n                          <button mat-button (click)=\"stepper.reset()\">Reset</button>\r\n                        </div>\r\n                    </mat-step>\r\n                </div>\r\n            </mat-stepper>\r\n        </div>\r\n    </ng-container>\r\n    <ng-container>\r\n        <button mat-raised-button color=\"primary\" (click)=\"clearForm()\" *ngIf=\"!isChild\">Clear Form</button>\r\n    </ng-container>\r\n    \r\n</form>"]}
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { RuclibMetaformComponent } from './ruclib-metaform/ruclib-metaform.component';
|
|
4
|
+
import { HttpClientModule } from '@angular/common/http';
|
|
5
|
+
import { FormsModule } from '@angular/forms';
|
|
6
|
+
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
7
|
+
import { MatInputModule } from '@angular/material/input';
|
|
8
|
+
import { MatRadioModule } from '@angular/material/radio';
|
|
9
|
+
import { MatCheckboxModule } from '@angular/material/checkbox';
|
|
10
|
+
import { MatSelectModule } from '@angular/material/select';
|
|
11
|
+
import { MatAutocompleteModule } from '@angular/material/autocomplete';
|
|
12
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
13
|
+
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
14
|
+
import { MatStepperModule } from '@angular/material/stepper';
|
|
15
|
+
import { TextFieldModule } from '@angular/cdk/text-field';
|
|
16
|
+
import { RucMetaFormService } from '../services/ruc-meta-form.service';
|
|
17
|
+
import { RucMetaInputsComponent } from '../components/ruc-meta-inputs/ruc-meta-inputs.component';
|
|
18
|
+
import { RucMetaRadioGroupComponent } from '../components/ruc-meta-radio-group/ruc-meta-radio-group.component';
|
|
19
|
+
import { RucMetaCheckboxGroupComponent } from '../components/ruc-meta-checkbox-group/ruc-meta-checkbox-group.component';
|
|
20
|
+
import { RucMetaSelectComponent } from '../components/ruc-meta-select/ruc-meta-select.component';
|
|
21
|
+
import { RucTextAreaComponent } from '../components/ruc-text-area/ruc-text-area.component';
|
|
22
|
+
import { RuclibMultiSelectModule } from '@ruc-lib/multi-select';
|
|
23
|
+
import { RuclibMultiFileUploadModule } from '@ruc-lib/multi-file-upload';
|
|
24
|
+
import * as i0 from "@angular/core";
|
|
25
|
+
export class RuclibMetaformModule {
|
|
26
|
+
}
|
|
27
|
+
RuclibMetaformModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: RuclibMetaformModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
28
|
+
RuclibMetaformModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: RuclibMetaformModule, declarations: [RuclibMetaformComponent,
|
|
29
|
+
RucMetaInputsComponent,
|
|
30
|
+
RucMetaRadioGroupComponent,
|
|
31
|
+
RucMetaCheckboxGroupComponent,
|
|
32
|
+
RucMetaSelectComponent,
|
|
33
|
+
RucTextAreaComponent], imports: [CommonModule,
|
|
34
|
+
HttpClientModule,
|
|
35
|
+
FormsModule,
|
|
36
|
+
MatFormFieldModule,
|
|
37
|
+
MatInputModule,
|
|
38
|
+
MatRadioModule,
|
|
39
|
+
MatCheckboxModule,
|
|
40
|
+
MatSelectModule,
|
|
41
|
+
MatAutocompleteModule,
|
|
42
|
+
MatButtonModule,
|
|
43
|
+
MatTooltipModule,
|
|
44
|
+
TextFieldModule,
|
|
45
|
+
MatStepperModule,
|
|
46
|
+
RuclibMultiSelectModule,
|
|
47
|
+
RuclibMultiFileUploadModule], exports: [RuclibMetaformComponent] });
|
|
48
|
+
RuclibMetaformModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: RuclibMetaformModule, providers: [
|
|
49
|
+
RucMetaFormService
|
|
50
|
+
], imports: [CommonModule,
|
|
51
|
+
HttpClientModule,
|
|
52
|
+
FormsModule,
|
|
53
|
+
MatFormFieldModule,
|
|
54
|
+
MatInputModule,
|
|
55
|
+
MatRadioModule,
|
|
56
|
+
MatCheckboxModule,
|
|
57
|
+
MatSelectModule,
|
|
58
|
+
MatAutocompleteModule,
|
|
59
|
+
MatButtonModule,
|
|
60
|
+
MatTooltipModule,
|
|
61
|
+
TextFieldModule,
|
|
62
|
+
MatStepperModule,
|
|
63
|
+
RuclibMultiSelectModule,
|
|
64
|
+
RuclibMultiFileUploadModule] });
|
|
65
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: RuclibMetaformModule, decorators: [{
|
|
66
|
+
type: NgModule,
|
|
67
|
+
args: [{
|
|
68
|
+
imports: [CommonModule,
|
|
69
|
+
HttpClientModule,
|
|
70
|
+
FormsModule,
|
|
71
|
+
MatFormFieldModule,
|
|
72
|
+
MatInputModule,
|
|
73
|
+
MatRadioModule,
|
|
74
|
+
MatCheckboxModule,
|
|
75
|
+
MatSelectModule,
|
|
76
|
+
MatAutocompleteModule,
|
|
77
|
+
MatButtonModule,
|
|
78
|
+
MatTooltipModule,
|
|
79
|
+
TextFieldModule,
|
|
80
|
+
MatStepperModule,
|
|
81
|
+
RuclibMultiSelectModule,
|
|
82
|
+
RuclibMultiFileUploadModule
|
|
83
|
+
],
|
|
84
|
+
declarations: [
|
|
85
|
+
RuclibMetaformComponent,
|
|
86
|
+
RucMetaInputsComponent,
|
|
87
|
+
RucMetaRadioGroupComponent,
|
|
88
|
+
RucMetaCheckboxGroupComponent,
|
|
89
|
+
RucMetaSelectComponent,
|
|
90
|
+
RucTextAreaComponent
|
|
91
|
+
],
|
|
92
|
+
exports: [
|
|
93
|
+
RuclibMetaformComponent
|
|
94
|
+
],
|
|
95
|
+
providers: [
|
|
96
|
+
RucMetaFormService
|
|
97
|
+
]
|
|
98
|
+
}]
|
|
99
|
+
}] });
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVjbGliLW1ldGFmb3JtLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvcnVjbGliLW1ldGFmb3JtLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw2Q0FBNkMsQ0FBQztBQUN0RixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUMvRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDdkUsT0FBTyxFQUFFLGVBQWUsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBQzFELE9BQU8sRUFBRSxnQkFBZ0IsRUFBQyxNQUFNLDJCQUEyQixDQUFDO0FBQzVELE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLDJCQUEyQixDQUFDO0FBQzNELE9BQU8sRUFBRSxlQUFlLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUN2RSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSx5REFBeUQsQ0FBQztBQUNqRyxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxtRUFBbUUsQ0FBQztBQUMvRyxPQUFPLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSx5RUFBeUUsQ0FBQztBQUN4SCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSx5REFBeUQsQ0FBQztBQUNqRyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxxREFBcUQsQ0FBQztBQUUzRixPQUFPLEVBQUMsdUJBQXVCLEVBQUMsTUFBTSx1QkFBdUIsQ0FBQztBQUM5RCxPQUFPLEVBQUMsMkJBQTJCLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQzs7QUFtQ3ZFLE1BQU0sT0FBTyxvQkFBb0I7O2tIQUFwQixvQkFBb0I7bUhBQXBCLG9CQUFvQixpQkFkN0IsdUJBQXVCO1FBQ3ZCLHNCQUFzQjtRQUN0QiwwQkFBMEI7UUFDMUIsNkJBQTZCO1FBQzdCLHNCQUFzQjtRQUN0QixvQkFBb0IsYUF0QlosWUFBWTtRQUNwQixnQkFBZ0I7UUFDaEIsV0FBVztRQUNYLGtCQUFrQjtRQUNsQixjQUFjO1FBQ2QsY0FBYztRQUNkLGlCQUFpQjtRQUNqQixlQUFlO1FBQ2YscUJBQXFCO1FBQ3JCLGVBQWU7UUFDZixnQkFBZ0I7UUFDaEIsZUFBZTtRQUNmLGdCQUFnQjtRQUNoQix1QkFBdUI7UUFDdkIsMkJBQTJCLGFBVzNCLHVCQUF1QjttSEFNZCxvQkFBb0IsYUFKcEI7UUFDVCxrQkFBa0I7S0FDbkIsWUE3QlMsWUFBWTtRQUNwQixnQkFBZ0I7UUFDaEIsV0FBVztRQUNYLGtCQUFrQjtRQUNsQixjQUFjO1FBQ2QsY0FBYztRQUNkLGlCQUFpQjtRQUNqQixlQUFlO1FBQ2YscUJBQXFCO1FBQ3JCLGVBQWU7UUFDZixnQkFBZ0I7UUFDaEIsZUFBZTtRQUNmLGdCQUFnQjtRQUNoQix1QkFBdUI7UUFDdkIsMkJBQTJCOzRGQWlCbEIsb0JBQW9CO2tCQWhDaEMsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyxZQUFZO3dCQUNwQixnQkFBZ0I7d0JBQ2hCLFdBQVc7d0JBQ1gsa0JBQWtCO3dCQUNsQixjQUFjO3dCQUNkLGNBQWM7d0JBQ2QsaUJBQWlCO3dCQUNqQixlQUFlO3dCQUNmLHFCQUFxQjt3QkFDckIsZUFBZTt3QkFDZixnQkFBZ0I7d0JBQ2hCLGVBQWU7d0JBQ2YsZ0JBQWdCO3dCQUNoQix1QkFBdUI7d0JBQ3ZCLDJCQUEyQjtxQkFDNUI7b0JBQ0QsWUFBWSxFQUFFO3dCQUNaLHVCQUF1Qjt3QkFDdkIsc0JBQXNCO3dCQUN0QiwwQkFBMEI7d0JBQzFCLDZCQUE2Qjt3QkFDN0Isc0JBQXNCO3dCQUN0QixvQkFBb0I7cUJBQ3JCO29CQUNELE9BQU8sRUFBRTt3QkFDUCx1QkFBdUI7cUJBQ3hCO29CQUNELFNBQVMsRUFBRTt3QkFDVCxrQkFBa0I7cUJBQ25CO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgUnVjbGliTWV0YWZvcm1Db21wb25lbnQgfSBmcm9tICcuL3J1Y2xpYi1tZXRhZm9ybS9ydWNsaWItbWV0YWZvcm0uY29tcG9uZW50JztcclxuaW1wb3J0IHsgSHR0cENsaWVudE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IE1hdEZvcm1GaWVsZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGQnO1xyXG5pbXBvcnQgeyBNYXRJbnB1dE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2lucHV0JztcclxuaW1wb3J0IHsgTWF0UmFkaW9Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9yYWRpbyc7XHJcbmltcG9ydCB7IE1hdENoZWNrYm94TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY2hlY2tib3gnO1xyXG5pbXBvcnQgeyBNYXRTZWxlY3RNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9zZWxlY3QnO1xyXG5pbXBvcnQgeyBNYXRBdXRvY29tcGxldGVNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9hdXRvY29tcGxldGUnO1xyXG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XHJcbmltcG9ydCB7IE1hdFRvb2x0aXBNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Rvb2x0aXAnO1xyXG5pbXBvcnQge01hdFN0ZXBwZXJNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3N0ZXBwZXInO1xyXG5pbXBvcnQgeyBUZXh0RmllbGRNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2Nkay90ZXh0LWZpZWxkJztcclxuaW1wb3J0IHsgUnVjTWV0YUZvcm1TZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvcnVjLW1ldGEtZm9ybS5zZXJ2aWNlJztcclxuaW1wb3J0IHsgUnVjTWV0YUlucHV0c0NvbXBvbmVudCB9IGZyb20gJy4uL2NvbXBvbmVudHMvcnVjLW1ldGEtaW5wdXRzL3J1Yy1tZXRhLWlucHV0cy5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBSdWNNZXRhUmFkaW9Hcm91cENvbXBvbmVudCB9IGZyb20gJy4uL2NvbXBvbmVudHMvcnVjLW1ldGEtcmFkaW8tZ3JvdXAvcnVjLW1ldGEtcmFkaW8tZ3JvdXAuY29tcG9uZW50JztcclxuaW1wb3J0IHsgUnVjTWV0YUNoZWNrYm94R3JvdXBDb21wb25lbnQgfSBmcm9tICcuLi9jb21wb25lbnRzL3J1Yy1tZXRhLWNoZWNrYm94LWdyb3VwL3J1Yy1tZXRhLWNoZWNrYm94LWdyb3VwLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IFJ1Y01ldGFTZWxlY3RDb21wb25lbnQgfSBmcm9tICcuLi9jb21wb25lbnRzL3J1Yy1tZXRhLXNlbGVjdC9ydWMtbWV0YS1zZWxlY3QuY29tcG9uZW50JztcclxuaW1wb3J0IHsgUnVjVGV4dEFyZWFDb21wb25lbnQgfSBmcm9tICcuLi9jb21wb25lbnRzL3J1Yy10ZXh0LWFyZWEvcnVjLXRleHQtYXJlYS5jb21wb25lbnQnO1xyXG5cclxuaW1wb3J0IHtSdWNsaWJNdWx0aVNlbGVjdE1vZHVsZX0gZnJvbSAnQHJ1Yy1saWIvbXVsdGktc2VsZWN0JztcclxuaW1wb3J0IHtSdWNsaWJNdWx0aUZpbGVVcGxvYWRNb2R1bGV9IGZyb20gJ0BydWMtbGliL211bHRpLWZpbGUtdXBsb2FkJztcclxuXHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsXHJcbiAgICBIdHRwQ2xpZW50TW9kdWxlLFxyXG4gICAgRm9ybXNNb2R1bGUsXHJcbiAgICBNYXRGb3JtRmllbGRNb2R1bGUsXHJcbiAgICBNYXRJbnB1dE1vZHVsZSxcclxuICAgIE1hdFJhZGlvTW9kdWxlLFxyXG4gICAgTWF0Q2hlY2tib3hNb2R1bGUsXHJcbiAgICBNYXRTZWxlY3RNb2R1bGUsXHJcbiAgICBNYXRBdXRvY29tcGxldGVNb2R1bGUsXHJcbiAgICBNYXRCdXR0b25Nb2R1bGUsICAgIFxyXG4gICAgTWF0VG9vbHRpcE1vZHVsZSxcclxuICAgIFRleHRGaWVsZE1vZHVsZSxcclxuICAgIE1hdFN0ZXBwZXJNb2R1bGUsXHJcbiAgICBSdWNsaWJNdWx0aVNlbGVjdE1vZHVsZSxcclxuICAgIFJ1Y2xpYk11bHRpRmlsZVVwbG9hZE1vZHVsZVxyXG4gIF0sXHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBSdWNsaWJNZXRhZm9ybUNvbXBvbmVudCxcclxuICAgIFJ1Y01ldGFJbnB1dHNDb21wb25lbnQsXHJcbiAgICBSdWNNZXRhUmFkaW9Hcm91cENvbXBvbmVudCxcclxuICAgIFJ1Y01ldGFDaGVja2JveEdyb3VwQ29tcG9uZW50LFxyXG4gICAgUnVjTWV0YVNlbGVjdENvbXBvbmVudCxcclxuICAgIFJ1Y1RleHRBcmVhQ29tcG9uZW50XHJcbiAgXSxcclxuICBleHBvcnRzOiBbXHJcbiAgICBSdWNsaWJNZXRhZm9ybUNvbXBvbmVudFxyXG4gIF0sXHJcbiAgcHJvdmlkZXJzOiBbXHJcbiAgICBSdWNNZXRhRm9ybVNlcnZpY2VcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBSdWNsaWJNZXRhZm9ybU1vZHVsZSB7fVxyXG4iXX0=
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './index';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVjLWxpYi1tZXRhZm9ybS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9ydWMtbGliLW1ldGFmb3JtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class RucMetaFormValidationService {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.defaultErrorMessage = 'Invalid Input';
|
|
6
|
+
}
|
|
7
|
+
nospaceValidator(formData) {
|
|
8
|
+
const re = / /;
|
|
9
|
+
if (formData.value.match(re)) {
|
|
10
|
+
return { nullTable: true };
|
|
11
|
+
}
|
|
12
|
+
else {
|
|
13
|
+
return false;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
alphaNumericValidator(formData) {
|
|
17
|
+
const re = '^[a-zA-Z0-9_]+$';
|
|
18
|
+
return formData.value ? !formData.value.match(re) : false;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
RucMetaFormValidationService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: RucMetaFormValidationService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
22
|
+
RucMetaFormValidationService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: RucMetaFormValidationService, providedIn: 'root' });
|
|
23
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: RucMetaFormValidationService, decorators: [{
|
|
24
|
+
type: Injectable,
|
|
25
|
+
args: [{
|
|
26
|
+
providedIn: 'root'
|
|
27
|
+
}]
|
|
28
|
+
}], ctorParameters: function () { return []; } });
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVjLW1ldGEtZm9ybS12YWxpZGF0aW9uLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvc2VydmljZXMvcnVjLW1ldGEtZm9ybS12YWxpZGF0aW9uLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFPM0MsTUFBTSxPQUFPLDRCQUE0QjtJQUl2QztRQUZPLHdCQUFtQixHQUFHLGVBQWUsQ0FBQztJQUc3QyxDQUFDO0lBRUQsZ0JBQWdCLENBQUMsUUFBdUI7UUFDdEMsTUFBTSxFQUFFLEdBQUcsR0FBRyxDQUFDO1FBQ2YsSUFBRyxRQUFRLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsRUFBQztZQUMxQixPQUFPLEVBQUUsU0FBUyxFQUFFLElBQUksRUFBRSxDQUFBO1NBQzNCO2FBQUk7WUFDSCxPQUFPLEtBQUssQ0FBQztTQUNkO0lBQ0gsQ0FBQztJQUVELHFCQUFxQixDQUFDLFFBQXVCO1FBQzNDLE1BQU0sRUFBRSxHQUFHLGlCQUFpQixDQUFBO1FBQzVCLE9BQU8sUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDO0lBQzVELENBQUM7OzBIQW5CVSw0QkFBNEI7OEhBQTVCLDRCQUE0QixjQUYzQixNQUFNOzRGQUVQLDRCQUE0QjtrQkFIeEMsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7TWV0YUZvcm1Db25maWd9IGZyb20gJy4uL2ludGVyZmFjZXMvbWV0YUZvcm1zRGVmYXVsdCc7XHJcblxyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290J1xyXG59KVxyXG5leHBvcnQgY2xhc3MgUnVjTWV0YUZvcm1WYWxpZGF0aW9uU2VydmljZSB7XHJcblxyXG4gIHB1YmxpYyBkZWZhdWx0RXJyb3JNZXNzYWdlID0gJ0ludmFsaWQgSW5wdXQnO1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHsgXHJcbiAgfVxyXG5cclxuICBub3NwYWNlVmFsaWRhdG9yKGZvcm1EYXRhOk1ldGFGb3JtQ29uZmlnKXtcclxuICAgIGNvbnN0IHJlID0gLyAvO1xyXG4gICAgaWYoZm9ybURhdGEudmFsdWUubWF0Y2gocmUpKXtcclxuICAgICAgcmV0dXJuIHsgbnVsbFRhYmxlOiB0cnVlIH1cclxuICAgIH1lbHNle1xyXG4gICAgICByZXR1cm4gZmFsc2U7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBhbHBoYU51bWVyaWNWYWxpZGF0b3IoZm9ybURhdGE6TWV0YUZvcm1Db25maWcpe1xyXG4gICAgY29uc3QgcmUgPSAnXlthLXpBLVowLTlfXSskJ1xyXG4gICAgcmV0dXJuIGZvcm1EYXRhLnZhbHVlID8gIWZvcm1EYXRhLnZhbHVlLm1hdGNoKHJlKSA6IGZhbHNlO1xyXG4gIH1cclxuXHJcbiAgXHJcbn1cclxuIl19
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { BehaviorSubject } from 'rxjs';
|
|
3
|
+
import { HttpClient } from '@angular/common/http';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common/http";
|
|
6
|
+
export class RucMetaFormService {
|
|
7
|
+
constructor(http) {
|
|
8
|
+
this.http = http;
|
|
9
|
+
this.formData = new BehaviorSubject([]);
|
|
10
|
+
}
|
|
11
|
+
getFormJson(form) {
|
|
12
|
+
this.formData.next(form);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
RucMetaFormService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: RucMetaFormService, deps: [{ token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
16
|
+
RucMetaFormService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: RucMetaFormService, providedIn: 'root' });
|
|
17
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: RucMetaFormService, decorators: [{
|
|
18
|
+
type: Injectable,
|
|
19
|
+
args: [{
|
|
20
|
+
providedIn: 'root'
|
|
21
|
+
}]
|
|
22
|
+
}], ctorParameters: function () { return [{ type: i1.HttpClient }]; } });
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVjLW1ldGEtZm9ybS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3NlcnZpY2VzL3J1Yy1tZXRhLWZvcm0uc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBc0IsZUFBZSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzNELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7O0FBS2xELE1BQU0sT0FBTyxrQkFBa0I7SUFLN0IsWUFBb0IsSUFBZ0I7UUFBaEIsU0FBSSxHQUFKLElBQUksQ0FBWTtRQUU3QixhQUFRLEdBQXlCLElBQUksZUFBZSxDQUFDLEVBQVMsQ0FBQyxDQUFDO0lBRi9CLENBQUM7SUFJekMsV0FBVyxDQUFDLElBQVM7UUFDbkIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDM0IsQ0FBQzs7Z0hBWFUsa0JBQWtCO29IQUFsQixrQkFBa0IsY0FGakIsTUFBTTs0RkFFUCxrQkFBa0I7a0JBSDlCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBPYnNlcnZhYmxlLFN1YmplY3QsIEJlaGF2aW9yU3ViamVjdCB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xyXG5pbXBvcnQge01ldGFGb3JtQ29uZmlnfSBmcm9tICcuLi9pbnRlcmZhY2VzL21ldGFGb3Jtc0RlZmF1bHQnO1xyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBSdWNNZXRhRm9ybVNlcnZpY2Uge1xyXG5cclxuICBwdWJsaWMgbWV0YUZvcm1EYXRhOk1ldGFGb3JtQ29uZmlnIHwgdW5kZWZpbmVkO1xyXG4gIHB1YmxpYyBjdXJyZW50Rm9ybUVsZW1lbnQ6IE1ldGFGb3JtQ29uZmlnIHwgdW5kZWZpbmVkO1xyXG5cclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGh0dHA6IEh0dHBDbGllbnQpIHsgfVxyXG5cclxuICBwdWJsaWMgZm9ybURhdGE6IEJlaGF2aW9yU3ViamVjdDxhbnk+ID0gbmV3IEJlaGF2aW9yU3ViamVjdChbXSBhcyBhbnkpO1xyXG5cclxuICBnZXRGb3JtSnNvbihmb3JtOiBhbnkpe1xyXG4gICAgdGhpcy5mb3JtRGF0YS5uZXh0KGZvcm0pO1xyXG4gIH1cclxufVxyXG4iXX0=
|