diff --git a/src/app/core/components/navigation/navigation.model.ts b/src/app/core/components/navigation/navigation.model.ts index 12f51dba..0e04362b 100644 --- a/src/app/core/components/navigation/navigation.model.ts +++ b/src/app/core/components/navigation/navigation.model.ts @@ -252,6 +252,12 @@ export class FuseNavigation } ] },*/ + { + 'title': 'Forms', + 'type' : 'nav-item', + 'icon' : 'web_asset', + 'url' : '/ui/forms' + }, { 'title': 'Icons', 'type' : 'nav-item', diff --git a/src/app/main/content/ui/forms/forms.component.html b/src/app/main/content/ui/forms/forms.component.html new file mode 100644 index 00000000..572dc0b9 --- /dev/null +++ b/src/app/main/content/ui/forms/forms.component.html @@ -0,0 +1,124 @@ +
+ + +
+
+
+ home + chevron_right + User Interface +
+
Forms
+
+
+ + + +
+ +

+ Angular reactive forms facilitate a reactive style of programming that favors explicit management of the + data flowing between a non-UI data model (typically retrieved from a server) and a UI-oriented form model + that retains the states and values of the HTML controls on screen. Reactive forms offer the ease of using + reactive patterns, testing, and validation. +

+ +
+ +
+ +
Reactive Form Example
+ +
+ + + + + +
+ +
+ + + + + Required + + + + + + + Required + + + +
+ +
+ + + + + Required + + + + + + + Required + + + +
+ +
+ + + + + Required + + + + + + + Required + + + + + + {{postalCode.value.length}} / 5 + + Postal Code needs to be max. {{formErrors.postalCode.maxlength.requiredLength}} characters + + + +
+ +
+ +
+ +
Reactive Form Errors Model
+ +
{{formErrors | json}}
+
+ +
+ + +
+ + +
+ + diff --git a/src/app/main/content/ui/forms/forms.component.scss b/src/app/main/content/ui/forms/forms.component.scss new file mode 100644 index 00000000..33c43ccd --- /dev/null +++ b/src/app/main/content/ui/forms/forms.component.scss @@ -0,0 +1,17 @@ +:host { + + .content { + + form { + max-width: 800px !important; + } + + .form-errors-model { + flex: 1; + + code { + background: none !important; + } + } + } +} \ No newline at end of file diff --git a/src/app/main/content/ui/forms/forms.component.ts b/src/app/main/content/ui/forms/forms.component.ts new file mode 100644 index 00000000..c32e110d --- /dev/null +++ b/src/app/main/content/ui/forms/forms.component.ts @@ -0,0 +1,67 @@ +import { Component, OnInit } from '@angular/core'; +import { FormBuilder, FormGroup, Validators } from '@angular/forms'; + +@Component({ + selector : 'fuse-forms', + templateUrl: './forms.component.html', + styleUrls : ['./forms.component.scss'] +}) +export class FuseFormsComponent implements OnInit +{ + form: FormGroup; + formErrors: any; + + constructor(private formBuilder: FormBuilder) + { + this.formErrors = { + company : {}, + firstName : {}, + lastName : {}, + address : {}, + address2 : {}, + city : {}, + state : {}, + postalCode: {} + }; + } + + ngOnInit() + { + this.form = this.formBuilder.group({ + company : [{value: 'Google', disabled: true}, Validators.required], + firstName : ['', Validators.required], + lastName : ['', Validators.required], + address : ['', Validators.required], + address2 : ['', Validators.required], + city : ['', Validators.required], + state : ['', Validators.required], + postalCode: ['', [Validators.required, Validators.maxLength(5)]] + }); + + this.form.valueChanges.subscribe(() => { + this.onFormValuesChanged(); + }); + } + + onFormValuesChanged() + { + for ( const field in this.formErrors ) + { + if ( !this.formErrors.hasOwnProperty(field) ) + { + continue; + } + + // Clear previous errors + this.formErrors[field] = {}; + + // Get the control + const control = this.form.get(field); + + if ( control && control.dirty && !control.valid ) + { + this.formErrors[field] = control.errors; + } + } + } +} diff --git a/src/app/main/content/ui/forms/forms.module.ts b/src/app/main/content/ui/forms/forms.module.ts new file mode 100644 index 00000000..ccbdb13f --- /dev/null +++ b/src/app/main/content/ui/forms/forms.module.ts @@ -0,0 +1,25 @@ +import { NgModule } from '@angular/core'; +import { SharedModule } from '../../../../core/modules/shared.module'; +import { RouterModule, Routes } from '@angular/router'; + +import { FuseFormsComponent } from './forms.component'; + +const routes: Routes = [ + { + path : 'ui/forms', + component: FuseFormsComponent + } +]; + +@NgModule({ + imports : [ + SharedModule, + RouterModule.forChild(routes) + ], + declarations: [ + FuseFormsComponent + ] +}) +export class UIFormsModule +{ +} diff --git a/src/app/main/content/ui/ui.module.ts b/src/app/main/content/ui/ui.module.ts index 20fe5a6d..f5ca2582 100644 --- a/src/app/main/content/ui/ui.module.ts +++ b/src/app/main/content/ui/ui.module.ts @@ -1,5 +1,6 @@ import { NgModule } from '@angular/core'; +import { UIFormsModule } from './forms/forms.module'; import { UIIconsModule } from './icons/icons.module'; import { UITypographyModule } from './typography/typography.module'; import { UIHelperClassesModule } from './helper-classes/helper-classes.module'; @@ -8,6 +9,7 @@ import { UIColorsModule } from './colors/colors.module'; @NgModule({ imports: [ + UIFormsModule, UIIconsModule, UITypographyModule, UIHelperClassesModule,