src/app/shared/components/submit-button/submit-button.component.ts
This component will render a submit button with the given label.
The button will disabled itself and show a loading icon when the user clicks it, usually initiating a request to the server, and it will stay in that state until the request is finished.
To indicate that the request failed, returning the button to the enable state, you need to insert an error in the form with the 'cdSubmitButton' key. p.e.: this.rbdForm.setErrors({'cdSubmitButton': true});
It will also check if the form is valid, when clicking the button, and will focus on the first invalid input.
selector | cd-submit-button |
styleUrls | ./submit-button.component.scss |
templateUrl | ./submit-button.component.html |
Properties |
Methods |
Inputs |
Outputs |
constructor(elRef: ElementRef)
|
||||||
Parameters :
|
disabled | |
Default value : false
|
|
form | |
Type : FormGroup | NgForm
|
|
type | |
Default value : 'submit'
|
|
submitAction | |
Type : EventEmitter
|
|
focusButton |
focusButton()
|
Returns :
void
|
focusInvalid |
focusInvalid()
|
Returns :
void
|
ngOnInit |
ngOnInit()
|
Returns :
void
|
submit | ||||
submit($event)
|
||||
Parameters :
Returns :
void
|
loading |
Default value : false
|
import { Component, ElementRef, EventEmitter, Input, OnInit, Output } from '@angular/core';
import { AbstractControl, FormGroup, FormGroupDirective, NgForm } from '@angular/forms';
import * as _ from 'lodash';
/**
* This component will render a submit button with the given label.
*
* The button will disabled itself and show a loading icon when the user clicks
* it, usually initiating a request to the server, and it will stay in that
* state until the request is finished.
*
* To indicate that the request failed, returning the button to the enable
* state, you need to insert an error in the form with the 'cdSubmitButton' key.
* p.e.: this.rbdForm.setErrors({'cdSubmitButton': true});
*
* It will also check if the form is valid, when clicking the button, and will
* focus on the first invalid input.
*
* @export
* @class SubmitButtonComponent
* @implements {OnInit}
*/
@Component({
selector: 'cd-submit-button',
templateUrl: './submit-button.component.html',
styleUrls: ['./submit-button.component.scss']
})
export class SubmitButtonComponent implements OnInit {
@Input()
form: FormGroup | NgForm;
@Input()
type = 'submit';
@Output()
submitAction = new EventEmitter();
@Input()
disabled = false;
loading = false;
constructor(private elRef: ElementRef) {}
ngOnInit() {
this.form.statusChanges.subscribe(() => {
if (_.has(this.form.errors, 'cdSubmitButton')) {
this.loading = false;
_.unset(this.form.errors, 'cdSubmitButton');
// Handle Reactive forms.
if (this.form instanceof AbstractControl) {
(<AbstractControl>this.form).updateValueAndValidity();
}
}
});
}
submit($event) {
this.focusButton();
// Special handling for Template driven forms.
if (this.form instanceof FormGroupDirective) {
(<FormGroupDirective>this.form).onSubmit($event);
}
if (this.form.invalid) {
this.focusInvalid();
return;
}
this.loading = true;
this.submitAction.emit();
}
focusButton() {
this.elRef.nativeElement.offsetParent.querySelector(`button[type="${this.type}"]`).focus();
}
focusInvalid() {
const target = this.elRef.nativeElement.offsetParent.querySelector(
'input.ng-invalid, select.ng-invalid'
);
if (target) {
target.focus();
}
}
}
<button [type]="type"
class="btn btn-sm btn-primary tc_submitButton"
[disabled]="loading || disabled"
(click)="submit($event)">
<ng-content></ng-content>
<span *ngIf="loading">
<i class="fa fa-spinner fa-spin fa-fw"></i>
</span>
</button>
./submit-button.component.scss