ipsos-components
Version:
Material Design components for Angular
66 lines (56 loc) • 2.02 kB
text/typescript
/**
* @license
* Copyright Google LLC All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.io/license
*/
import {Constructor} from './constructor';
import {ErrorStateMatcher} from '../error/error-options';
import {FormControl, FormGroupDirective, NgControl, NgForm} from '@angular/forms';
import {Subject} from 'rxjs/Subject';
/** @docs-private */
export interface CanUpdateErrorState {
updateErrorState();
stateChanges: Subject<void>;
errorState: boolean;
errorStateMatcher: ErrorStateMatcher;
}
/** @docs-private */
export interface HasErrorState {
_parentFormGroup: FormGroupDirective;
_parentForm: NgForm;
_defaultErrorStateMatcher: ErrorStateMatcher;
ngControl: NgControl;
}
/**
* Mixin to augment a directive with updateErrorState method.
* For component with `errorState` and need to update `errorState`.
*/
export function mixinErrorState<T extends Constructor<HasErrorState>>(base: T)
: Constructor<CanUpdateErrorState> & T {
return class extends base {
/** Whether the component is in an error state. */
errorState: boolean = false;
/**
* Stream that emits whenever the state of the input changes such that the wrapping
* `MatFormField needs to run change detection.
*/
stateChanges = new Subject<void>();
errorStateMatcher: ErrorStateMatcher;
updateErrorState() {
const oldState = this.errorState;
const parent = this._parentFormGroup || this._parentForm;
const matcher = this.errorStateMatcher || this._defaultErrorStateMatcher;
const control = this.ngControl ? this.ngControl.control as FormControl : null;
const newState = matcher.isErrorState(control, parent);
if (newState !== oldState) {
this.errorState = newState;
this.stateChanges.next();
}
}
constructor(...args: any[]) {
super(...args);
}
};
}