required validation
This commit is contained in:
parent
693dfc5bb0
commit
cb6d46256c
|
@ -52,7 +52,10 @@
|
||||||
|
|
||||||
|
|
||||||
<div [hidden]="isValid">
|
<div [hidden]="isValid">
|
||||||
<div class="invalid-feedbackCustom" *ngIf="isValidRequired">The field "{{field.label}}" is required</div>
|
<mat-error *ngIf="isValidRequired">
|
||||||
|
The field "{{field.title}}" <strong>required</strong>
|
||||||
|
</mat-error>
|
||||||
|
<!-- <div class="invalid-feedbackCustom" *ngIf="isValidRequired">The field "{{field.label}}" is required</div> -->
|
||||||
<div class="invalid-feedbackCustom" *ngIf="isValidPattern">The field {{field.label}} must match a regular expression {{field.regex}}</div>
|
<div class="invalid-feedbackCustom" *ngIf="isValidPattern">The field {{field.label}} must match a regular expression {{field.regex}}</div>
|
||||||
<div class="invalid-feedbackCustom" *ngIf="isValidCustom">The field {{field.label}} custom Validation</div>
|
<div class="invalid-feedbackCustom" *ngIf="isValidCustom">The field {{field.label}} custom Validation</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -31,6 +31,9 @@ export class DynamicFormFieldComponent {
|
||||||
ngOnChanges(changeRecord) {
|
ngOnChanges(changeRecord) {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
ngOnInit(){
|
||||||
|
debugger;
|
||||||
|
}
|
||||||
|
|
||||||
clearInput(){
|
clearInput(){
|
||||||
debugger;
|
debugger;
|
||||||
|
|
|
@ -22,13 +22,13 @@ export class DynamicFormCompositeFieldComponent implements OnInit {
|
||||||
constructor(private visibilityRulesService: VisibilityRulesService) { }
|
constructor(private visibilityRulesService: VisibilityRulesService) { }
|
||||||
|
|
||||||
ngOnInit() {
|
ngOnInit() {
|
||||||
debugger;
|
|
||||||
console.log(this.form);
|
console.log(this.form);
|
||||||
if (this.compositeField.hasCommentField == true) {
|
if (this.compositeField.hasCommentField == true) {
|
||||||
let newfield: Field = new Field();
|
let newfield: Field = new Field();
|
||||||
newfield.id = 'comment_' + this.compositeField.id;
|
newfield.id = 'comment_' + this.compositeField.id;
|
||||||
newfield.data = {label: "Comments"};
|
newfield.data = {label: "Comments"};
|
||||||
newfield.viewStyle = {renderStyle: 'freetext', cssClass: ''};
|
newfield.viewStyle = {renderStyle: 'freetext', cssClass: ''};
|
||||||
|
newfield.validations = ["None"]
|
||||||
|
|
||||||
this.compositeField.fields.push(newfield);
|
this.compositeField.fields.push(newfield);
|
||||||
(<FormArray>this.form.get("fields")).push(newfield.buildForm());
|
(<FormArray>this.form.get("fields")).push(newfield.buildForm());
|
||||||
|
|
|
@ -89,6 +89,9 @@ export class DynamicFormComponent implements OnInit {
|
||||||
submit() {
|
submit() {
|
||||||
//this.serverService.updateDataset(this.datasetId, this.form.value).subscribe()
|
//this.serverService.updateDataset(this.datasetId, this.form.value).subscribe()
|
||||||
}
|
}
|
||||||
|
save(){
|
||||||
|
debugger;
|
||||||
|
}
|
||||||
|
|
||||||
toggleSidebar() {
|
toggleSidebar() {
|
||||||
this.visibleSidebar = !this.visibleSidebar;
|
this.visibleSidebar = !this.visibleSidebar;
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
import { BaseModel } from './BaseModel';
|
import { BaseModel } from './BaseModel';
|
||||||
import { FormGroup } from '@angular/forms';
|
import { FormGroup, Validators } from '@angular/forms';
|
||||||
import { FormGenerator } from './interfaces/FormGenerator';
|
import { FormGenerator } from './interfaces/FormGenerator';
|
||||||
import { JsonSerializer } from '../utilities/JsonSerializer';
|
import { JsonSerializer } from '../utilities/JsonSerializer';
|
||||||
import { Serializable } from './interfaces/Serializable';
|
import { Serializable } from './interfaces/Serializable';
|
||||||
|
@ -21,7 +21,7 @@ export class Field extends BaseModel implements Serializable<Field>, FormGenerat
|
||||||
public multiplicity: Multiplicity;
|
public multiplicity: Multiplicity;
|
||||||
public multiplicityItems: Array<Field> = new Array<Field>();
|
public multiplicityItems: Array<Field> = new Array<Field>();
|
||||||
public data: any;
|
public data: any;
|
||||||
public validations: Array<ValidationTypes>;
|
public validations: Array<any>;//Array<ValidationTypes>
|
||||||
|
|
||||||
fromJSONObject(item: any): Field {
|
fromJSONObject(item: any): Field {
|
||||||
this.id = item.id;
|
this.id = item.id;
|
||||||
|
@ -43,12 +43,22 @@ export class Field extends BaseModel implements Serializable<Field>, FormGenerat
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
buildForm(): FormGroup {
|
buildForm(): FormGroup {
|
||||||
|
let validationRequired = "false";
|
||||||
|
if(this.validations)
|
||||||
|
this.validations.forEach(validation => {
|
||||||
|
if (validation == "REQUIRED")
|
||||||
|
{validationRequired = "true";}
|
||||||
|
});
|
||||||
|
|
||||||
let formGroup = this.formBuilder.group({
|
let formGroup = this.formBuilder.group({
|
||||||
id: [this.id],
|
id: [this.id],
|
||||||
data:[this.data],
|
data:[this.data],
|
||||||
/* title: [this.title], */
|
/* title: [this.title], */
|
||||||
value: [this.value]/* ,
|
value: [this.value, validationRequired == "true"? Validators.required:null]/* ,
|
||||||
description: [this.description],
|
description: [this.description],
|
||||||
extendedDescription:[this.extendedDescription],
|
extendedDescription:[this.extendedDescription],
|
||||||
viewStyle: [this.viewStyle],
|
viewStyle: [this.viewStyle],
|
||||||
|
|
Loading…
Reference in New Issue