UNPKG

angular-dynamic-forms-lite

Version:
142 lines 15 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { DynamicArrayController } from "./dynamic-array-controller"; import { ArrayRenderer } from "./array-renderer"; export class ArrayFieldFactory { /** * @param {?} parentFieldFactory * @param {?} formBuilder */ constructor(parentFieldFactory, formBuilder) { this.parentFieldFactory = parentFieldFactory; this.formBuilder = formBuilder; } /** * @template M * @param {?} options * @return {?} */ create(options) { const { setting } = options; if (!setting.childSetting) { throw new Error(`Array ${options.setting.name} needs 'childSetting' as part of its setting.`); } const [formControl, children] = this.createChildContexts(options); /** @type {?} */ const dynamicController = new DynamicArrayController(this.parentFieldFactory); /** @type {?} */ const arrayComponentContext = Object.assign({}, this.parentFieldFactory.resolveComponent(formControl, setting, options.initialValue, dynamicController), { children }); /** @type {?} */ const arrayComponent = (/** @type {?} */ (arrayComponentContext.componentRef.instance)); if (!arrayComponent.formRoot) { throw new Error(`Array component ${setting.name} is not an array component. It is missing the 'formRoot' directive.`); } // initialize controller after all values and children are resolved dynamicController.onInit(arrayComponentContext); return arrayComponentContext; } /** * @param {?} arrayContext * @return {?} */ updateChildren(arrayContext) { /** @type {?} */ const unchecked = [...arrayContext.formControl.controls]; ((/** @type {?} */ (arrayContext.children))).forEach((/** * @param {?} child * @param {?} i * @return {?} */ (child, i) => { if (arrayContext.formControl.controls.indexOf(child.formControl) === -1) { arrayContext.formControl.insert(i, child.formControl); } else { unchecked.splice(unchecked.indexOf(child.formControl), 1); } })); unchecked.forEach((/** * @param {?} control * @return {?} */ control => arrayContext.formControl.removeAt(arrayContext.formControl.controls.indexOf(control)))); } /** * @param {?} formRoot * @param {?} arrayContext * @return {?} */ render(formRoot, arrayContext) { /** @type {?} */ const viewRef = formRoot.viewContainerRef.insert(arrayContext.componentRef.hostView); viewRef.detectChanges(); /** @type {?} */ const arrayComponent = (/** @type {?} */ (arrayContext.componentRef.instance)); /** @type {?} */ const paginator = ((/** @type {?} */ (arrayContext.setting))).renderStrategy.paginator; /** @type {?} */ const pageEvent = { pageIndex: paginator.pageIndex, pageSize: paginator.pageSize }; /** @type {?} */ const renderer = new ArrayRenderer(this.parentFieldFactory, arrayComponent.formRoot); renderer.render(arrayContext, pageEvent); return viewRef; } /** * @private * @template M * @param {?} options * @return {?} */ createChildContexts(options) { if (options.formControl) { /** @type {?} */ const children = options.formControl.controls.map((/** * @param {?} formControl * @return {?} */ formControl => this.parentFieldFactory.create({ formControl, setting: options.setting.childSetting, settings: options.settings }))); return [options.formControl, children]; } /** @type {?} */ const values = options.initialValue ? options.initialValue : []; if (!Array.isArray(values)) { throw new Error(`Value of ${options.setting.name} is not an array.`); } /** @type {?} */ const children = values.map((/** * @param {?} value * @return {?} */ value => this.parentFieldFactory.create({ initialValue: value, setting: options.setting.childSetting, settings: options.settings }))); /** @type {?} */ const formControl = this.formBuilder.array(children.map((/** * @param {?} context * @return {?} */ context => context.formControl))); return [formControl, children]; } } if (false) { /** * @type {?} * @private */ ArrayFieldFactory.prototype.parentFieldFactory; /** * @type {?} * @private */ ArrayFieldFactory.prototype.formBuilder; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"array-field-factory.js","sourceRoot":"ng://angular-dynamic-forms-lite/","sources":["lib/form-field/array/array-field-factory.ts"],"names":[],"mappings":"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","sourcesContent":["import { FormBuilder, FormArray } from \"@angular/forms\";\nimport { FieldFactory, ParentFieldFactory, CreateFormContextOptions } from \"../field-factory\";\nimport { DynamicArrayController } from \"./dynamic-array-controller\";\nimport { ArrayFormFieldSetting } from \"./array-form-field-setting\";\nimport { FormContext } from \"../../form/form-context\";\nimport { FormRootDirective } from \"../../form/form-root.directive\";\nimport { FormFieldArrayComponent } from \"./form-field-array-component\";\nimport { ViewRef } from \"@angular/core\";\nimport { ArrayRenderer } from \"./array-renderer\";\n\nexport class ArrayFieldFactory implements FieldFactory<FormArray, ArrayFormFieldSetting<any, any>> {\n  constructor(private parentFieldFactory: ParentFieldFactory, private formBuilder: FormBuilder) {}\n\n  public create<M>(\n    options: CreateFormContextOptions<M, FormArray, ArrayFormFieldSetting<M>>\n  ): FormContext<M, FormArray> {\n    const { setting } = options;\n\n    if (!setting.childSetting) {\n      throw new Error(`Array ${options.setting.name} needs 'childSetting' as part of its setting.`);\n    }\n\n    const [formControl, children] = this.createChildContexts(options);\n\n    const dynamicController = new DynamicArrayController(this.parentFieldFactory);\n\n    const arrayComponentContext = {\n      ...this.parentFieldFactory.resolveComponent<M, FormArray>(\n        formControl,\n        setting,\n        options.initialValue,\n        dynamicController\n      ),\n      children\n    };\n\n    const arrayComponent = arrayComponentContext.componentRef.instance as FormFieldArrayComponent;\n\n    if (!arrayComponent.formRoot) {\n      throw new Error(\n        `Array component ${setting.name} is not an array component. It is missing the 'formRoot' directive.`\n      );\n    }\n\n    // initialize controller after all values and children are resolved\n    dynamicController.onInit(arrayComponentContext);\n\n    return arrayComponentContext;\n  }\n\n  public updateChildren(arrayContext: FormContext<any, FormArray>) {\n    const unchecked = [...arrayContext.formControl.controls];\n    (arrayContext.children as FormContext<any>[]).forEach((child, i) => {\n      if (arrayContext.formControl.controls.indexOf(child.formControl) === -1) {\n        arrayContext.formControl.insert(i, child.formControl);\n      } else {\n        unchecked.splice(unchecked.indexOf(child.formControl), 1);\n      }\n    });\n\n    unchecked.forEach(control => arrayContext.formControl.removeAt(arrayContext.formControl.controls.indexOf(control)));\n  }\n\n  public render(formRoot: FormRootDirective, arrayContext: FormContext<any, FormArray>): ViewRef {\n    const viewRef = formRoot.viewContainerRef.insert(arrayContext.componentRef.hostView);\n    viewRef.detectChanges();\n\n    const arrayComponent = arrayContext.componentRef.instance as FormFieldArrayComponent;\n    const paginator = (arrayContext.setting as ArrayFormFieldSetting).renderStrategy.paginator;\n    const pageEvent = { pageIndex: paginator.pageIndex, pageSize: paginator.pageSize };\n\n    const renderer = new ArrayRenderer(this.parentFieldFactory, arrayComponent.formRoot);\n    renderer.render(arrayContext, pageEvent);\n\n    return viewRef;\n  }\n\n  private createChildContexts<M>(\n    options: CreateFormContextOptions<M, FormArray, ArrayFormFieldSetting<M>>\n  ): [FormArray, FormContext<M>[]] {\n    if (options.formControl) {\n      const children = options.formControl.controls.map(formControl =>\n        this.parentFieldFactory.create<any>({\n          formControl,\n          setting: options.setting.childSetting,\n          settings: options.settings\n        })\n      );\n\n      return [options.formControl, children];\n    }\n\n    const values = options.initialValue ? options.initialValue : [];\n\n    if (!Array.isArray(values)) {\n      throw new Error(`Value of ${options.setting.name} is not an array.`);\n    }\n\n    const children = values.map(value =>\n      this.parentFieldFactory.create<any>({\n        initialValue: value,\n        setting: options.setting.childSetting,\n        settings: options.settings\n      })\n    );\n\n    const formControl = this.formBuilder.array(children.map(context => context.formControl));\n\n    return [formControl, children];\n  }\n}\n"]}