@ngx-formly/material
Version:
Formly is a dynamic (JSON powered) form library for Angular that bring unmatched maintainability to your application's forms.
199 lines (183 loc) • 18 kB
JavaScript
import { Component, ViewChild, ViewEncapsulation, } from '@angular/core';
import { ɵdefineHiddenProp as defineHiddenProp, FieldWrapper, } from '@ngx-formly/core';
import { MatFormField } from '@angular/material/form-field';
import * as i0 from "@angular/core";
import * as i1 from "@angular/cdk/a11y";
import * as i2 from "@angular/common";
import * as i3 from "@angular/material/form-field";
import * as i4 from "@ngx-formly/core";
export class FormlyWrapperFormField extends FieldWrapper {
constructor(renderer, elementRef, focusMonitor) {
super();
this.renderer = renderer;
this.elementRef = elementRef;
this.focusMonitor = focusMonitor;
}
ngOnInit() {
defineHiddenProp(this.field, '_formField', this.formField);
this.focusMonitor.monitor(this.elementRef, true).subscribe((origin) => {
if (!origin && this.field.focus) {
this.field.focus = false;
}
});
}
ngAfterViewInit() {
// temporary fix for https://github.com/angular/material2/issues/7891
if (this.formField.appearance !== 'outline' && this.props.hideFieldUnderline === true) {
const underlineElement = this.formField._elementRef.nativeElement.querySelector('.mat-form-field-underline');
underlineElement && this.renderer.removeChild(underlineElement.parentNode, underlineElement);
}
}
ngOnDestroy() {
delete this.field._formField;
this.focusMonitor.stopMonitoring(this.elementRef);
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormlyWrapperFormField, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i1.FocusMonitor }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: FormlyWrapperFormField, selector: "formly-wrapper-mat-form-field", viewQueries: [{ propertyName: "formField", first: true, predicate: MatFormField, descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: `
<!-- fix https://github.com/angular/material2/pull/7083 by setting width to 100% -->
<mat-form-field
[hideRequiredMarker]="true"
[floatLabel]="props.floatLabel"
[appearance]="props.appearance"
[subscriptSizing]="props.subscriptSizing"
[color]="props.color ?? 'primary'"
>
<ng-container #fieldComponent></ng-container>
(props.label && props.hideLabel !== true) {
<mat-label>
{{ props.label }}
(props.required && props.hideRequiredMarker !== true) {
<span aria-hidden="true" class="mat-form-field-required-marker mat-mdc-form-field-required-marker">*</span>
}
</mat-label>
}
(props.textPrefix) {
<ng-container
matTextPrefix
[ngTemplateOutlet]="props.textPrefix"
[ngTemplateOutletContext]="{ field: field }"
></ng-container>
}
(props.prefix) {
<ng-container
matPrefix
[ngTemplateOutlet]="props.prefix"
[ngTemplateOutletContext]="{ field: field }"
></ng-container>
}
(props.textSuffix) {
<ng-container
matTextSuffix
[ngTemplateOutlet]="props.textSuffix"
[ngTemplateOutletContext]="{ field: field }"
></ng-container>
}
(props.suffix) {
<ng-container
matSuffix
[ngTemplateOutlet]="props.suffix"
[ngTemplateOutletContext]="{ field: field }"
></ng-container>
}
<mat-error>
<formly-validation-message [field]="field"></formly-validation-message>
</mat-error>
(props.description || props.hintStart; as hint) {
<mat-hint>
<ng-container [ngTemplateOutlet]="stringOrTemplate" [ngTemplateOutletContext]="{ content: hint }">
</ng-container>
</mat-hint>
}
(props.hintEnd; as hintEnd) {
<mat-hint align="end">
<ng-container [ngTemplateOutlet]="stringOrTemplate" [ngTemplateOutletContext]="{ content: hintEnd }">
</ng-container>
</mat-hint>
}
</mat-form-field>
<ng-template #stringOrTemplate let-content="content">
(!content.createEmbeddedView) {
<ng-container>{{ content }}</ng-container>
} {
<ng-container [ngTemplateOutlet]="content" [ngTemplateOutletContext]="{ field: field }"></ng-container>
}
</ng-template>
`, isInline: true, styles: ["formly-wrapper-mat-form-field .mat-mdc-form-field,formly-wrapper-mat-form-field .mat-form-field{width:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i3.MatPrefix, selector: "[matPrefix], [matIconPrefix], [matTextPrefix]", inputs: ["matTextPrefix"] }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i4.LegacyFormlyValidationMessage, selector: "formly-validation-message" }], encapsulation: i0.ViewEncapsulation.None }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormlyWrapperFormField, decorators: [{
type: Component,
args: [{ selector: 'formly-wrapper-mat-form-field', template: `
<!-- fix https://github.com/angular/material2/pull/7083 by setting width to 100% -->
<mat-form-field
[hideRequiredMarker]="true"
[floatLabel]="props.floatLabel"
[appearance]="props.appearance"
[subscriptSizing]="props.subscriptSizing"
[color]="props.color ?? 'primary'"
>
<ng-container #fieldComponent></ng-container>
(props.label && props.hideLabel !== true) {
<mat-label>
{{ props.label }}
(props.required && props.hideRequiredMarker !== true) {
<span aria-hidden="true" class="mat-form-field-required-marker mat-mdc-form-field-required-marker">*</span>
}
</mat-label>
}
(props.textPrefix) {
<ng-container
matTextPrefix
[ngTemplateOutlet]="props.textPrefix"
[ngTemplateOutletContext]="{ field: field }"
></ng-container>
}
(props.prefix) {
<ng-container
matPrefix
[ngTemplateOutlet]="props.prefix"
[ngTemplateOutletContext]="{ field: field }"
></ng-container>
}
(props.textSuffix) {
<ng-container
matTextSuffix
[ngTemplateOutlet]="props.textSuffix"
[ngTemplateOutletContext]="{ field: field }"
></ng-container>
}
(props.suffix) {
<ng-container
matSuffix
[ngTemplateOutlet]="props.suffix"
[ngTemplateOutletContext]="{ field: field }"
></ng-container>
}
<mat-error>
<formly-validation-message [field]="field"></formly-validation-message>
</mat-error>
(props.description || props.hintStart; as hint) {
<mat-hint>
<ng-container [ngTemplateOutlet]="stringOrTemplate" [ngTemplateOutletContext]="{ content: hint }">
</ng-container>
</mat-hint>
}
(props.hintEnd; as hintEnd) {
<mat-hint align="end">
<ng-container [ngTemplateOutlet]="stringOrTemplate" [ngTemplateOutletContext]="{ content: hintEnd }">
</ng-container>
</mat-hint>
}
</mat-form-field>
<ng-template #stringOrTemplate let-content="content">
(!content.createEmbeddedView) {
<ng-container>{{ content }}</ng-container>
} {
<ng-container [ngTemplateOutlet]="content" [ngTemplateOutletContext]="{ field: field }"></ng-container>
}
</ng-template>
`, encapsulation: ViewEncapsulation.None, styles: ["formly-wrapper-mat-form-field .mat-mdc-form-field,formly-wrapper-mat-form-field .mat-form-field{width:100%}\n"] }]
}], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i1.FocusMonitor }], propDecorators: { formField: [{
type: ViewChild,
args: [MatFormField, { static: true }]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field.wrapper.js","sourceRoot":"","sources":["../../../../../src/ui/material/form-field/src/form-field.wrapper.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,SAAS,EAMT,iBAAiB,GAElB,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,iBAAiB,IAAI,gBAAgB,EAGrC,YAAY,GACb,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;;;;;;AA4G5D,MAAM,OAAO,sBACX,SAAQ,YAAkC;IAK1C,YACU,QAAmB,EACnB,UAAsB,EACtB,YAA0B;QAElC,KAAK,EAAE,CAAC;QAJA,aAAQ,GAAR,QAAQ,CAAW;QACnB,eAAU,GAAV,UAAU,CAAY;QACtB,iBAAY,GAAZ,YAAY,CAAc;IAGpC,CAAC;IAED,QAAQ;QACN,gBAAgB,CAAC,IAAI,CAAC,KAAK,EAAE,YAAY,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;QAC3D,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YACpE,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;gBAChC,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;YAC3B,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,eAAe;QACb,qEAAqE;QACrE,IAAI,IAAI,CAAC,SAAS,CAAC,UAAU,KAAK,SAAS,IAAI,IAAI,CAAC,KAAK,CAAC,kBAAkB,KAAK,IAAI,EAAE,CAAC;YACtF,MAAM,gBAAgB,GAAG,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,aAAa,CAAC,aAAa,CAAC,2BAA2B,CAAC,CAAC;YAC7G,gBAAgB,IAAI,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,gBAAgB,CAAC,UAAU,EAAE,gBAAgB,CAAC,CAAC;QAC/F,CAAC;IACH,CAAC;IAED,WAAW;QACT,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC;QAC7B,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACpD,CAAC;+GAlCU,sBAAsB;mGAAtB,sBAAsB,gHAItB,YAAY,qFArFb;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6ET;;4FAIU,sBAAsB;kBAnFlC,SAAS;+BACE,+BAA+B,YAC/B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6ET,iBAEc,iBAAiB,CAAC,IAAI;kIAMM,SAAS;sBAAnD,SAAS;uBAAC,YAAY,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import {\n  Component,\n  ViewChild,\n  OnInit,\n  OnDestroy,\n  Renderer2,\n  AfterViewInit,\n  ElementRef,\n  ViewEncapsulation,\n  TemplateRef,\n} from '@angular/core';\nimport {\n  ɵdefineHiddenProp as defineHiddenProp,\n  FormlyFieldConfig,\n  FormlyFieldProps as CoreFormlyFieldProps,\n  FieldWrapper,\n} from '@ngx-formly/core';\nimport { MatFormField } from '@angular/material/form-field';\nimport { FocusMonitor } from '@angular/cdk/a11y';\nimport { FloatLabelType, MatFormFieldAppearance } from '@angular/material/form-field';\nimport { ThemePalette } from '@angular/material/core';\n\ninterface MatFormlyFieldConfig extends FormlyFieldConfig<FormlyFieldProps> {\n  _formField?: FormlyWrapperFormField;\n}\n\nexport interface FormlyFieldProps extends CoreFormlyFieldProps {\n  prefix?: TemplateRef<any>;\n  suffix?: TemplateRef<any>;\n  textPrefix?: TemplateRef<any>;\n  textSuffix?: TemplateRef<any>;\n  hideLabel?: boolean;\n  hideRequiredMarker?: boolean;\n  hideFieldUnderline?: boolean;\n  floatLabel?: FloatLabelType;\n  appearance?: MatFormFieldAppearance;\n  subscriptSizing?: 'fixed' | 'dynamic';\n  color?: ThemePalette;\n  hintStart?: TemplateRef<any> | string;\n  hintEnd?: TemplateRef<any> | string;\n}\n\n@Component({\n  selector: 'formly-wrapper-mat-form-field',\n  template: `\n    <!-- fix https://github.com/angular/material2/pull/7083 by setting width to 100% -->\n    <mat-form-field\n      [hideRequiredMarker]=\"true\"\n      [floatLabel]=\"props.floatLabel\"\n      [appearance]=\"props.appearance\"\n      [subscriptSizing]=\"props.subscriptSizing\"\n      [color]=\"props.color ?? 'primary'\"\n    >\n      <ng-container #fieldComponent></ng-container>\n      @if (props.label && props.hideLabel !== true) {\n        <mat-label>\n          {{ props.label }}\n          @if (props.required && props.hideRequiredMarker !== true) {\n            <span aria-hidden=\"true\" class=\"mat-form-field-required-marker mat-mdc-form-field-required-marker\">*</span>\n          }\n        </mat-label>\n      }\n\n      @if (props.textPrefix) {\n        <ng-container\n          matTextPrefix\n          [ngTemplateOutlet]=\"props.textPrefix\"\n          [ngTemplateOutletContext]=\"{ field: field }\"\n        ></ng-container>\n      }\n\n      @if (props.prefix) {\n        <ng-container\n          matPrefix\n          [ngTemplateOutlet]=\"props.prefix\"\n          [ngTemplateOutletContext]=\"{ field: field }\"\n        ></ng-container>\n      }\n\n      @if (props.textSuffix) {\n        <ng-container\n          matTextSuffix\n          [ngTemplateOutlet]=\"props.textSuffix\"\n          [ngTemplateOutletContext]=\"{ field: field }\"\n        ></ng-container>\n      }\n\n      @if (props.suffix) {\n        <ng-container\n          matSuffix\n          [ngTemplateOutlet]=\"props.suffix\"\n          [ngTemplateOutletContext]=\"{ field: field }\"\n        ></ng-container>\n      }\n\n      <mat-error>\n        <formly-validation-message [field]=\"field\"></formly-validation-message>\n      </mat-error>\n\n      @if (props.description || props.hintStart; as hint) {\n        <mat-hint>\n          <ng-container [ngTemplateOutlet]=\"stringOrTemplate\" [ngTemplateOutletContext]=\"{ content: hint }\">\n          </ng-container>\n        </mat-hint>\n      }\n\n      @if (props.hintEnd; as hintEnd) {\n        <mat-hint align=\"end\">\n          <ng-container [ngTemplateOutlet]=\"stringOrTemplate\" [ngTemplateOutletContext]=\"{ content: hintEnd }\">\n          </ng-container>\n        </mat-hint>\n      }\n    </mat-form-field>\n\n    <ng-template #stringOrTemplate let-content=\"content\">\n      @if (!content.createEmbeddedView) {\n        <ng-container>{{ content }}</ng-container>\n      } @else {\n        <ng-container [ngTemplateOutlet]=\"content\" [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\n      }\n    </ng-template>\n  `,\n  styleUrls: ['./form-field.wrapper.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class FormlyWrapperFormField\n  extends FieldWrapper<MatFormlyFieldConfig>\n  implements OnInit, OnDestroy, AfterViewInit\n{\n  @ViewChild(MatFormField, { static: true }) formField!: MatFormField;\n\n  constructor(\n    private renderer: Renderer2,\n    private elementRef: ElementRef,\n    private focusMonitor: FocusMonitor,\n  ) {\n    super();\n  }\n\n  ngOnInit() {\n    defineHiddenProp(this.field, '_formField', this.formField);\n    this.focusMonitor.monitor(this.elementRef, true).subscribe((origin) => {\n      if (!origin && this.field.focus) {\n        this.field.focus = false;\n      }\n    });\n  }\n\n  ngAfterViewInit() {\n    // temporary fix for https://github.com/angular/material2/issues/7891\n    if (this.formField.appearance !== 'outline' && this.props.hideFieldUnderline === true) {\n      const underlineElement = this.formField._elementRef.nativeElement.querySelector('.mat-form-field-underline');\n      underlineElement && this.renderer.removeChild(underlineElement.parentNode, underlineElement);\n    }\n  }\n\n  ngOnDestroy() {\n    delete this.field._formField;\n    this.focusMonitor.stopMonitoring(this.elementRef);\n  }\n}\n"]}