@ng-simplicity/forms-material
v1.0.1
Published
An integration package containing pre-styled Angular Material inputs, form fields, and error templates. It serves as a visual UI extension of the reactive [@ng-simplicity/forms-core](https://www.npmjs.com/package/@ng-simplicity/forms-core) engine, inherit
Downloads
211
Readme
@ng-simplicity/forms-material
An integration package containing pre-styled Angular Material inputs, form fields, and error templates. It serves as a visual UI extension of the reactive @ng-simplicity/forms-core engine, inheriting its powerful dynamic capabilities. This allows you to construct highly dynamic, complex forms where control properties (such as visibility, enabled/disabled state, select options, and validation rules) reactively adapt in real-time based on the current values inside the form. The package is highly customizable; because it utilizes the core registry system, you can develop and add your own custom form controls to the registry to be used in the form rendering alongside the Material presets.
Installation
Ensure you have @angular/material and the core forms package installed:
npm install @ng-simplicity/forms-core @ng-simplicity/forms-material @angular/material @angular/cdkMake sure your application has active Material theming configured (either via an custom theme file or prebuilt stylesheets in angular.json / styles.scss):
@import "@angular/material/prebuilt-themes/indigo-pink.css";Quick Start & Registration
To render Material fields dynamically, follow these steps:
- Provide the
NgsFormsServiceat the component level to isolate the form state. - Register the Material components in your component constructor using
NgsFormsMaterialModule.registerAllMaterialComponents(registry). - Construct the layout schema (
NgsFormsFormConfig) using Material controls. - Pass the schema to
this.ngsFormsService.setFormConfig(formConfig). - Add
<ngs-form></ngs-form>to your component's template.
Here is a complete usage example:
import { Component, OnInit, inject } from '@angular/core';
import { Validators } from '@angular/forms';
import {
NgsFormComponent,
NgsFormsComponentRegistryService,
NgsFormsService,
NgsFormsFormConfig,
NgsFormsFormGroupComponent,
NgsFormsRowComponent
} from '@ng-simplicity/forms-core';
import {
NgsFormsMaterialModule,
NgsFormsMaterialFormItemInputComponent,
NgsFormsMaterialFormItemTextAreaComponent
} from '@ng-simplicity/forms-material';
@Component({
selector: 'app-material-form-page',
standalone: true,
imports: [NgsFormComponent],
providers: [NgsFormsService],
template: `
<div class="material-form-container">
<h2>Contact Us</h2>
<ngs-form></ngs-form>
<button (click)="onSubmit()">Submit</button>
</div>
`
})
export class MaterialFormPageComponent implements OnInit {
private ngsFormsService = inject(NgsFormsService);
constructor(registry: NgsFormsComponentRegistryService) {
// Registers Material inputs, textareas, checkbox, select, and layouts
NgsFormsMaterialModule.registerAllMaterialComponents(registry);
}
ngOnInit() {
// Construct the form configuration
const formConfig: NgsFormsFormConfig = {
inputUpdateDebounce: 150,
root: NgsFormsFormGroupComponent.create({ name: 'contactForm' }, [
NgsFormsRowComponent.create({
items: [
NgsFormsMaterialFormItemInputComponent.create({
name: 'email',
label: 'Email Address',
placeholder: 'Enter your email...',
type: 'email',
validators: [Validators.required, Validators.email],
errorMessageMap: {
required: 'Email address is required.',
email: 'Please enter a valid email address.'
}
}),
NgsFormsMaterialFormItemTextAreaComponent.create({
name: 'message',
label: 'Your Message',
placeholder: 'Write your message...',
rows: 4
})
]
})
])
};
// Initialize the dynamic form controls
this.ngsFormsService.setFormConfig(formConfig);
}
onSubmit() {
if (this.ngsFormsService.isValid) {
console.log('Form data submitted:', this.ngsFormsService.formValue);
} else {
this.ngsFormsService.setIsSubmitted(true); // Highlights form validation errors
}
}
}Common Properties & Core Integration
This package relies on the main core engine: @ng-simplicity/forms-core. The core package provides all standard layout structures and non-styling-specific form components, including:
- Form Groups:
NgsFormsFormGroupComponent(Key:'form-group') - Sections:
NgsFormsFormSectionComponent(Key:'section') - Row Containers:
NgsFormsRowComponent(Key:'form-row') - Columns:
NgsFormsColumnComponent(Key:'column') - Form Arrays & Support:
NgsFormsFormArrayContainerComponent(Key:'form-array'),NgsFormsFormArrayAddItemComponent(Key:'form-array-add-item'), andNgsFormsFormArrayRemoveItemComponent(Key:'form-array-remove-item') - Static Content:
NgsFormsHtmlContentComponent(Key:'content-html') andNgsFormsTextDivComponent(Key:'text-div')
Please refer to the @ng-simplicity/forms-core README for full details on constructing layouts and managing core form structures.
Common Control Properties
Most controls in this styling library support a standard set of core properties that are managed by the dynamic forms engine. These properties allow passing either a static/basic value or an asynchronous stream (Observable):
Visibility:
visible(boolean): Controls whether the item is mounted in the DOM.visible$(Observable<boolean>): Stream version to dynamically show/hide components.- Note: Visibility is configured at the wrapper component layer (
NgsFormsFormItem).
Disabled Status:
disabled(boolean): Sets the initial disabled state of the form control.disabled$(Observable<boolean>): Stream to toggle disabled state.- Configured at the inner
configlevel.
Validators:
validators(Array<ValidatorFn>): Array of standard/custom Angular Validator functions.validators$(Observable<Array<ValidatorFn>>): Stream of validator functions to change validators dynamically.- Configured at the inner
configlevel.
Options (Only for components with choice selection like
selectandradio):options(Array<NgsFormsFormInputOption>): Static array of choices{ id: string | number, label: string, disabled?: boolean }.options$(Observable<Array<NgsFormsFormInputOption>>): Stream to dynamically populate choices.- Configured at the inner
configlevel.
[!TIP] By supplying Observable streams (such as
visible$,disabled$,validators$, oroptions$), you can build highly dynamic and reactive forms. Because these observables can be piped directly from the form service's value change stream (this.ngsFormsService.formValue$), fields can dynamically enable/disable, appear/disappear, change options, or update validation rules in real-time based on user input in other fields.
Available Components & Schemas
Here is the full list of available Material components along with code examples showing their required and optional configuration parameters:
1. Text Input (input-text)
Uses NgsFormsMaterialFormItemInputComponent.
- Key:
input-text - Config Type:
NgsFormsFormItemConfigBaseTextInput
import { NgsFormsMaterialFormItemInputComponent } from '@ng-simplicity/forms-material';
import { Validators } from '@angular/forms';
const emailField = NgsFormsMaterialFormItemInputComponent.create({
// Required Parameters
name: 'email',
label: 'Email Address',
// Optional Parameters
id: 'custom-email-id',
placeholder: 'Enter your email address...',
type: 'email', // 'text' | 'email' | 'password'
value: '[email protected]', // Initial value
disabled: false,
validators: [Validators.required, Validators.email],
errorMessageMap: {
required: 'Email is required.',
email: 'Must be a valid email format.'
}
});2. Text Area (input-textarea)
Uses NgsFormsMaterialFormItemTextAreaComponent.
- Key:
input-textarea - Config Type:
any
import { NgsFormsMaterialFormItemTextAreaComponent } from '@ng-simplicity/forms-material';
import { Validators } from '@angular/forms';
const commentsField = NgsFormsMaterialFormItemTextAreaComponent.create({
// Required Parameters
name: 'comments',
label: 'Comments',
// Optional Parameters
id: 'custom-comments-id',
placeholder: 'Leave us feedback...',
value: '',
rows: 5, // Custom number of visible rows (default is 3)
disabled: false,
validators: [Validators.required],
errorMessageMap: {
required: 'Comments cannot be blank.'
}
});3. Checkbox (checkbox)
Uses NgsFormsMaterialFormItemCheckboxComponent.
- Key:
checkbox - Config Type:
NgsFormsFormItemConfigBaseInput
import { NgsFormsMaterialFormItemCheckboxComponent } from '@ng-simplicity/forms-material';
import { Validators } from '@angular/forms';
const acceptTermsField = NgsFormsMaterialFormItemCheckboxComponent.create({
// Required Parameters
name: 'agreeTerms',
label: 'I accept the Terms and Conditions',
// Optional Parameters
id: 'terms-checkbox-id',
value: false, // Initial checked state
disabled: false,
validators: [Validators.requiredTrue],
errorMessageMap: {
required: 'You must agree to the terms to proceed.'
}
});4. Select Dropdown (select)
Uses NgsFormsMaterialFormItemSelectInputComponent.
- Key:
select - Config Type:
NgsFormsFormItemConfigMaterialSelectInput
import { NgsFormsMaterialFormItemSelectInputComponent } from '@ng-simplicity/forms-material';
import { Validators } from '@angular/forms';
const roleSelectField = NgsFormsMaterialFormItemSelectInputComponent.create({
// Required Parameters
name: 'role',
label: 'User Role',
// Optional Parameters
id: 'role-select-id',
placeholder: 'Choose a role...', // Disabled placeholder text
placeHolderValue: '', // Custom value for placeholder selection
value: 'member', // Initial selected option ID
disabled: false,
options: [
{ id: 'admin', label: 'Administrator' },
{ id: 'member', label: 'Regular Member', disabled: false },
{ id: 'guest', label: 'Guest User', disabled: true }
],
validators: [Validators.required],
errorMessageMap: {
required: 'Please select a role.'
}
});5. Radio Buttons (radio)
Uses NgsFormsMaterialRadioInputComponent.
- Key:
radio - Config Type:
NgsFormsFormItemConfigMaterialRadio
import { NgsFormsMaterialRadioInputComponent } from '@ng-simplicity/forms-material';
import { Validators } from '@angular/forms';
const genderField = NgsFormsMaterialRadioInputComponent.create({
// Required Parameters
name: 'gender',
label: 'Gender Identity',
// Optional Parameters
id: 'gender-radio-id',
value: 'other', // Initial selected radio option ID
alignment: 'horizontal', // 'horizontal' | 'vertical' (default is 'vertical')
disabled: false,
options: [
{ id: 'female', label: 'Female' },
{ id: 'male', label: 'Male' },
{ id: 'other', label: 'Other/Prefer not to say' }
],
validators: [Validators.required],
errorMessageMap: {
required: 'Please choose one option.'
}
});Unit Testing
Run unit tests for this Material integration package using:
nx test forms-materialTo run with coverage enabled:
nx test forms-material --codeCoverageExample Applications
Fully functional example applications demonstrating the form engine functionality are located in the apps/ folder of this monorepo:
forms-bootstrap-demo: Integrates and showcases the@ng-simplicity/forms-bootstrappackage.forms-material-demo: Integrates and showcases the@ng-simplicity/forms-materialpackage.
Support & Contributions
If you have feature suggestions, need a feature to make @ng-simplicity/forms-material work for your project, or encounter any bugs, please log an issue in the GitHub issue tracker.
