@ngx-formly/material
Version:
Formly is a dynamic (JSON powered) form library for Angular that bring unmatched maintainability to your application's forms.
142 lines • 17.1 kB
JavaScript
import { ViewChild, Type, Directive, ViewChildren } from '@angular/core';
import { FieldType as CoreFieldType, ɵobserve as observe } from '@ngx-formly/core';
import { Subject } from 'rxjs';
import { MatFormFieldControl } from '@angular/material/form-field';
import * as i0 from "@angular/core";
export class FieldType extends CoreFieldType {
constructor() {
super(...arguments);
this.errorStateMatcher = { isErrorState: () => this.field && this.showError };
this.stateChanges = new Subject();
this._errorState = false;
this._focused = false;
}
set matPrefix(prefix) {
if (prefix) {
this.props.prefix = prefix;
}
}
set matTextPrefix(textPrefix) {
if (textPrefix) {
this.props.textPrefix = textPrefix;
}
}
set matSuffix(suffix) {
if (suffix) {
this.props.suffix = suffix;
}
}
set matTextSuffix(textSuffix) {
if (textSuffix) {
this.props.textSuffix = textSuffix;
}
}
set _controls(controls) {
this.attachControl(controls.length === 1 ? controls.first : this);
}
ngOnDestroy() {
delete this.formField?._control;
this.stateChanges.complete();
}
setDescribedByIds(_ids) { }
onContainerClick(_event) {
this.field.focus = true;
this.stateChanges.next();
}
get errorState() {
const showError = this.options.showError(this);
if (showError !== this._errorState) {
this._errorState = showError;
this.stateChanges.next();
}
return showError;
}
get controlType() {
if (this.props.type) {
return this.props.type;
}
const type = this.field.type;
return type instanceof Type ? type.prototype.constructor.name : type;
}
get focused() {
const focused = !!this.field.focus && !this.disabled;
if (focused !== this._focused) {
this._focused = focused;
this.stateChanges.next();
}
return focused;
}
get disabled() {
return !!this.props.disabled;
}
get required() {
return !!this.props.required;
}
get placeholder() {
return this.props.placeholder || '';
}
get shouldPlaceholderFloat() {
return this.shouldLabelFloat;
}
get value() {
return this.formControl?.value;
}
set value(value) {
this.formControl?.patchValue(value);
}
get ngControl() {
return this.formControl;
}
get empty() {
return this.value == null || this.value === '';
}
get shouldLabelFloat() {
return this.focused || !this.empty;
}
get formField() {
return this.field?.['_formField'];
}
attachControl(control) {
if (this.formField && control !== this.formField._control) {
this.formField._control = control;
// temporary fix for https://github.com/angular/material2/issues/6728
const ngControl = control?.ngControl;
if (ngControl?.valueAccessor?.hasOwnProperty('_formField')) {
ngControl.valueAccessor['_formField'] = this.formField;
}
if (ngControl?.valueAccessor?.hasOwnProperty('_parentFormField')) {
ngControl.valueAccessor['_parentFormField'] = this.formField;
}
['prefix', 'suffix', 'textPrefix', 'textSuffix'].forEach((type) => observe(this.field, ['props', type], ({ currentValue }) => currentValue &&
Promise.resolve().then(() => {
this.options.detectChanges(this.field);
})));
// https://github.com/angular/components/issues/16209
const setDescribedByIds = control.setDescribedByIds.bind(control);
control.setDescribedByIds = (ids) => {
setTimeout(() => setDescribedByIds(ids));
};
}
}
}
FieldType.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: FieldType, deps: null, target: i0.ɵɵFactoryTarget.Directive });
FieldType.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.12", type: FieldType, viewQueries: [{ propertyName: "matPrefix", first: true, predicate: ["matPrefix"], descendants: true }, { propertyName: "matTextPrefix", first: true, predicate: ["matTextPrefix"], descendants: true }, { propertyName: "matSuffix", first: true, predicate: ["matSuffix"], descendants: true }, { propertyName: "matTextSuffix", first: true, predicate: ["matTextSuffix"], descendants: true }, { propertyName: "_controls", predicate: MatFormFieldControl, descendants: true }], usesInheritance: true, ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: FieldType, decorators: [{
type: Directive
}], propDecorators: { matPrefix: [{
type: ViewChild,
args: ['matPrefix']
}], matTextPrefix: [{
type: ViewChild,
args: ['matTextPrefix']
}], matSuffix: [{
type: ViewChild,
args: ['matSuffix']
}], matTextSuffix: [{
type: ViewChild,
args: ['matTextSuffix']
}], _controls: [{
type: ViewChildren,
args: [MatFormFieldControl]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field.type.js","sourceRoot":"","sources":["../../../../../src/ui/material/form-field/src/field.type.ts"],"names":[],"mappings":"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","sourcesContent":["import { OnDestroy, TemplateRef, ViewChild, Type, Directive, ViewChildren, QueryList } from '@angular/core';\nimport { FieldType as CoreFieldType, FormlyFieldConfig, ɵobserve as observe } from '@ngx-formly/core';\nimport { Subject } from 'rxjs';\nimport { MatFormField, MatFormFieldControl } from '@angular/material/form-field';\nimport { ErrorStateMatcher } from '@angular/material/core';\nimport { FormlyFieldProps } from './form-field.wrapper';\n\n@Directive()\nexport abstract class FieldType<F extends FormlyFieldConfig<FormlyFieldProps>>\n  extends CoreFieldType<F>\n  implements OnDestroy, MatFormFieldControl<any>\n{\n  @ViewChild('matPrefix') set matPrefix(prefix: TemplateRef<any>) {\n    if (prefix) {\n      this.props.prefix = prefix;\n    }\n  }\n  @ViewChild('matTextPrefix') set matTextPrefix(textPrefix: TemplateRef<any>) {\n    if (textPrefix) {\n      this.props.textPrefix = textPrefix;\n    }\n  }\n  @ViewChild('matSuffix') set matSuffix(suffix: TemplateRef<any>) {\n    if (suffix) {\n      this.props.suffix = suffix;\n    }\n  }\n  @ViewChild('matTextSuffix') set matTextSuffix(textSuffix: TemplateRef<any>) {\n    if (textSuffix) {\n      this.props.textSuffix = textSuffix;\n    }\n  }\n\n  @ViewChildren(MatFormFieldControl) set _controls(controls: QueryList<MatFormFieldControl<any>>) {\n    this.attachControl(controls.length === 1 ? controls.first : this);\n  }\n\n  errorStateMatcher: ErrorStateMatcher = { isErrorState: () => this.field && this.showError };\n  stateChanges = new Subject<void>();\n  _errorState = false;\n  _focused = false;\n\n  ngOnDestroy() {\n    delete (this.formField as any)?._control;\n    this.stateChanges.complete();\n  }\n\n  setDescribedByIds(_ids: string[]): void {}\n  onContainerClick(_event: MouseEvent): void {\n    this.field.focus = true;\n    this.stateChanges.next();\n  }\n\n  get errorState() {\n    const showError = this.options!.showError!(this);\n    if (showError !== this._errorState) {\n      this._errorState = showError;\n      this.stateChanges.next();\n    }\n\n    return showError;\n  }\n\n  get controlType() {\n    if (this.props.type) {\n      return this.props.type;\n    }\n\n    const type = this.field.type!;\n    return type instanceof Type ? type.prototype.constructor.name : type;\n  }\n  get focused() {\n    const focused = !!this.field.focus && !this.disabled;\n    if (focused !== this._focused) {\n      this._focused = focused;\n      this.stateChanges.next();\n    }\n    return focused;\n  }\n  get disabled() {\n    return !!this.props.disabled;\n  }\n  get required() {\n    return !!this.props.required;\n  }\n  get placeholder() {\n    return this.props.placeholder || '';\n  }\n  get shouldPlaceholderFloat() {\n    return this.shouldLabelFloat;\n  }\n  get value() {\n    return this.formControl?.value;\n  }\n  set value(value) {\n    this.formControl?.patchValue(value);\n  }\n  get ngControl() {\n    return this.formControl as any;\n  }\n  get empty() {\n    return this.value == null || this.value === '';\n  }\n  get shouldLabelFloat() {\n    return this.focused || !this.empty;\n  }\n  get formField(): MatFormField {\n    return (this.field as any)?.['_formField'];\n  }\n\n  private attachControl(control: MatFormFieldControl<any>) {\n    if (this.formField && control !== this.formField._control) {\n      this.formField._control = control;\n\n      // temporary fix for https://github.com/angular/material2/issues/6728\n      const ngControl = control?.ngControl as any;\n      if (ngControl?.valueAccessor?.hasOwnProperty('_formField')) {\n        ngControl.valueAccessor['_formField'] = this.formField;\n      }\n      if (ngControl?.valueAccessor?.hasOwnProperty('_parentFormField')) {\n        ngControl.valueAccessor['_parentFormField'] = this.formField;\n      }\n\n      ['prefix', 'suffix', 'textPrefix', 'textSuffix'].forEach((type) =>\n        observe<TemplateRef<any>>(\n          this.field,\n          ['props', type],\n          ({ currentValue }) =>\n            currentValue &&\n            Promise.resolve().then(() => {\n              this.options.detectChanges!(this.field);\n            }),\n        ),\n      );\n\n      // https://github.com/angular/components/issues/16209\n      const setDescribedByIds = control.setDescribedByIds.bind(control);\n      control.setDescribedByIds = (ids: string[]) => {\n        setTimeout(() => setDescribedByIds(ids));\n      };\n    }\n  }\n}\n"]}