UNPKG

@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
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> @if (props.label && props.hideLabel !== true) { <mat-label> {{ props.label }} @if (props.required && props.hideRequiredMarker !== true) { <span aria-hidden="true" class="mat-form-field-required-marker mat-mdc-form-field-required-marker">*</span> } </mat-label> } @if (props.textPrefix) { <ng-container matTextPrefix [ngTemplateOutlet]="props.textPrefix" [ngTemplateOutletContext]="{ field: field }" ></ng-container> } @if (props.prefix) { <ng-container matPrefix [ngTemplateOutlet]="props.prefix" [ngTemplateOutletContext]="{ field: field }" ></ng-container> } @if (props.textSuffix) { <ng-container matTextSuffix [ngTemplateOutlet]="props.textSuffix" [ngTemplateOutletContext]="{ field: field }" ></ng-container> } @if (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> @if (props.description || props.hintStart; as hint) { <mat-hint> <ng-container [ngTemplateOutlet]="stringOrTemplate" [ngTemplateOutletContext]="{ content: hint }"> </ng-container> </mat-hint> } @if (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"> @if (!content.createEmbeddedView) { <ng-container>{{ content }}</ng-container> } @else { <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> @if (props.label && props.hideLabel !== true) { <mat-label> {{ props.label }} @if (props.required && props.hideRequiredMarker !== true) { <span aria-hidden="true" class="mat-form-field-required-marker mat-mdc-form-field-required-marker">*</span> } </mat-label> } @if (props.textPrefix) { <ng-container matTextPrefix [ngTemplateOutlet]="props.textPrefix" [ngTemplateOutletContext]="{ field: field }" ></ng-container> } @if (props.prefix) { <ng-container matPrefix [ngTemplateOutlet]="props.prefix" [ngTemplateOutletContext]="{ field: field }" ></ng-container> } @if (props.textSuffix) { <ng-container matTextSuffix [ngTemplateOutlet]="props.textSuffix" [ngTemplateOutletContext]="{ field: field }" ></ng-container> } @if (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> @if (props.description || props.hintStart; as hint) { <mat-hint> <ng-container [ngTemplateOutlet]="stringOrTemplate" [ngTemplateOutletContext]="{ content: hint }"> </ng-container> </mat-hint> } @if (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"> @if (!content.createEmbeddedView) { <ng-container>{{ content }}</ng-container> } @else { <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"]}