UNPKG

angular-dynamic-forms-lite

Version:
160 lines 15.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { DynamicGroupController } from "./dynamic-group-controller"; export class GroupFieldFactory { /** * @param {?} parentFieldFactory * @param {?} formBuilder */ constructor(parentFieldFactory, formBuilder) { this.parentFieldFactory = parentFieldFactory; this.formBuilder = formBuilder; } /** * @template M * @param {?} options * @return {?} */ create(options) { const { setting, settings } = options; const [formControl, children] = this.createChildContexts(options); /** @type {?} */ const dynamicController = new DynamicGroupController(formControl, this.parentFieldFactory, setting, settings); /** @type {?} */ const groupFormContext = Object.assign({}, this.parentFieldFactory.resolveComponent(formControl, setting, options.initialValue, dynamicController), { children }); /** @type {?} */ const groupComponent = (/** @type {?} */ (groupFormContext.componentRef.instance)); if (!groupComponent.formRoot) { throw new Error(`Group component ${setting.name} is not a group component. It is missing the 'formRoot' directive.`); } dynamicController.onInit(groupFormContext); return groupFormContext; } /** * @param {?} formRoot * @param {?} root * @return {?} */ render(formRoot, root) { /** @type {?} */ const viewRef = formRoot.viewContainerRef.insert(root.componentRef.hostView); viewRef.detectChanges(); /** @type {?} */ const entries = Object.entries(root.children); entries.forEach((/** * @param {?} __0 * @return {?} */ ([_id, context]) => { /** @type {?} */ const component = (/** @type {?} */ (root.componentRef.instance)); this.parentFieldFactory.render(component.formRoot, context); })); return viewRef; } /** * @param {?} context * @return {?} */ updateChildren(context) { /** @type {?} */ const controlEntires = Object.entries(context.formControl.controls); /** @type {?} */ const entries = Object.entries(context.children); entries.forEach((/** * @param {?} __0 * @return {?} */ ([_id, child]) => { /** @type {?} */ const missingFormControl = controlEntires.find((/** * @param {?} entry * @return {?} */ entry => child.formControl === entry[1])); if (missingFormControl) { context.formControl.setControl(missingFormControl[0], missingFormControl[1]); } })); } /** * @private * @template M * @param {?} options * @return {?} */ createChildContexts(options) { const { setting, settings } = options; if (options.formControl) { /** @type {?} */ const controlEntires = Object.entries(options.formControl.controls); /** @type {?} */ const children = {}; controlEntires.forEach((/** * @param {?} __0 * @return {?} */ ([id, formControl]) => { children[id] = this.parentFieldFactory.create({ formControl, setting: this.getSetting(id, settings), settings }); })); return [options.formControl, children]; } const { initialValue: value } = options; if (typeof value !== "object") { throw new Error(`Value of group ${setting.name} is not an object`); } /** @type {?} */ const children = {}; /** @type {?} */ const formChildren = {}; Object.entries(value).forEach((/** * @param {?} __0 * @return {?} */ ([id, child]) => { children[id] = this.parentFieldFactory.create({ initialValue: child, setting: this.getSetting(id, settings), settings }); formChildren[id] = children[id].formControl; })); /** @type {?} */ const formControl = this.formBuilder.group(formChildren); return [formControl, children]; } /** * @private * @template M * @param {?} id * @param {?} settings * @return {?} */ getSetting(id, settings) { /** @type {?} */ const childSetting = (/** @type {?} */ (settings.get(id))); if (!childSetting) { throw new Error(`Form field '${id}' has no assigned form field setting.`); } return childSetting; } } if (false) { /** * @type {?} * @private */ GroupFieldFactory.prototype.parentFieldFactory; /** * @type {?} * @private */ GroupFieldFactory.prototype.formBuilder; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"group-field-factory.js","sourceRoot":"ng://angular-dynamic-forms-lite/","sources":["lib/form-field/group/group-field-factory.ts"],"names":[],"mappings":"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","sourcesContent":["import { FormGroup, FormBuilder, AbstractControl } from \"@angular/forms\";\nimport { FieldFactory, ParentFieldFactory, CreateFormContextOptions } from \"../field-factory\";\nimport { FormContext } from \"../../form/form-context\";\nimport { FormRootDirective } from \"../../form/form-root.directive\";\nimport { DynamicGroupController } from \"./dynamic-group-controller\";\nimport { GroupFormFieldSetting } from \"./group-form-field-setting\";\nimport { FormFieldGroupComponent } from \"./form-field-group-component\";\nimport { ViewRef } from \"@angular/core\";\nimport { FormFieldSetting } from \"../../form-settings/form-field-setting\";\nimport { FormFieldSettings } from \"../../form-settings/form-field-settings\";\n\nexport class GroupFieldFactory implements FieldFactory<FormGroup, GroupFormFieldSetting<any>> {\n  constructor(private parentFieldFactory: ParentFieldFactory, private formBuilder: FormBuilder) {}\n\n  public create<M>(\n    options: CreateFormContextOptions<M, FormGroup, GroupFormFieldSetting<M>>\n  ): FormContext<M, FormGroup> {\n    const { setting, settings } = options;\n    const [formControl, children] = this.createChildContexts(options);\n\n    const dynamicController = new DynamicGroupController(formControl, this.parentFieldFactory, setting, settings);\n\n    const groupFormContext: FormContext<M, FormGroup> = {\n      ...this.parentFieldFactory.resolveComponent<M, FormGroup>(\n        formControl,\n        setting,\n        options.initialValue,\n        dynamicController\n      ),\n      children\n    };\n\n    const groupComponent = groupFormContext.componentRef.instance as FormFieldGroupComponent;\n\n    if (!groupComponent.formRoot) {\n      throw new Error(\n        `Group component ${setting.name} is not a group component. It is missing the 'formRoot' directive.`\n      );\n    }\n\n    dynamicController.onInit(groupFormContext);\n\n    return groupFormContext;\n  }\n\n  public render(formRoot: FormRootDirective, root: FormContext<any, FormGroup>): ViewRef {\n    const viewRef = formRoot.viewContainerRef.insert(root.componentRef.hostView);\n    viewRef.detectChanges();\n\n    const entries = Object.entries(root.children);\n    entries.forEach(([_id, context]) => {\n      const component = root.componentRef.instance as FormFieldGroupComponent;\n      this.parentFieldFactory.render(component.formRoot, context);\n    });\n\n    return viewRef;\n  }\n\n  updateChildren(context: FormContext<any, FormGroup>): void {\n    const controlEntires = Object.entries(context.formControl.controls);\n\n    const entries = Object.entries(context.children);\n    entries.forEach(([_id, child]) => {\n      const missingFormControl = controlEntires.find(entry => child.formControl === entry[1]);\n      if (missingFormControl) {\n        context.formControl.setControl(missingFormControl[0], missingFormControl[1]);\n      }\n    });\n  }\n\n  private createChildContexts<M>(\n    options: CreateFormContextOptions<M, FormGroup, GroupFormFieldSetting<M>>\n  ): [FormGroup, { [id: string]: FormContext<M> }] {\n    const { setting, settings } = options;\n\n    if (options.formControl) {\n      const controlEntires = Object.entries(options.formControl.controls);\n      const children: { [id: string]: FormContext<M, AbstractControl> } = {};\n\n      controlEntires.forEach(([id, formControl]) => {\n        children[id] = this.parentFieldFactory.create<any>({\n          formControl,\n          setting: this.getSetting(id, settings),\n          settings\n        });\n      });\n\n      return [options.formControl, children];\n    }\n\n    const { initialValue: value } = options;\n\n    if (typeof value !== \"object\") {\n      throw new Error(`Value of group ${setting.name} is not an object`);\n    }\n\n    const children: { [id: string]: FormContext<M, AbstractControl> } = {};\n    const formChildren: { [id: string]: AbstractControl } = {};\n    Object.entries(value).forEach(([id, child]) => {\n      children[id] = this.parentFieldFactory.create<M>({\n        initialValue: child,\n        setting: this.getSetting(id, settings),\n        settings\n      });\n      formChildren[id] = children[id].formControl;\n    });\n\n    const formControl = this.formBuilder.group(formChildren);\n\n    return [formControl, children];\n  }\n\n  private getSetting<M>(id: string, settings: FormFieldSettings): FormFieldSetting<M> {\n    const childSetting = settings.get(id) as FormFieldSetting<M>;\n    if (!childSetting) {\n      throw new Error(`Form field '${id}' has no assigned form field setting.`);\n    }\n\n    return childSetting;\n  }\n}\n"]}