source: trip-planner-front/node_modules/@angular/forms/esm2015/src/form_builder.js

Last change on this file was 6a3a178, checked in by Ema <ema_spirova@…>, 3 years ago

initial commit

  • Property mode set to 100644
File size: 18.8 KB
Line 
1/**
2 * @license
3 * Copyright Google LLC All Rights Reserved.
4 *
5 * Use of this source code is governed by an MIT-style license that can be
6 * found in the LICENSE file at https://angular.io/license
7 */
8import { Injectable } from '@angular/core';
9import { ReactiveFormsModule } from './form_providers';
10import { FormArray, FormControl, FormGroup } from './model';
11import * as i0 from "@angular/core";
12import * as i1 from "./form_providers";
13function isAbstractControlOptions(options) {
14 return options.asyncValidators !== undefined ||
15 options.validators !== undefined ||
16 options.updateOn !== undefined;
17}
18/**
19 * @description
20 * Creates an `AbstractControl` from a user-specified configuration.
21 *
22 * The `FormBuilder` provides syntactic sugar that shortens creating instances of a `FormControl`,
23 * `FormGroup`, or `FormArray`. It reduces the amount of boilerplate needed to build complex
24 * forms.
25 *
26 * @see [Reactive Forms Guide](/guide/reactive-forms)
27 *
28 * @publicApi
29 */
30export class FormBuilder {
31 group(controlsConfig, options = null) {
32 const controls = this._reduceControls(controlsConfig);
33 let validators = null;
34 let asyncValidators = null;
35 let updateOn = undefined;
36 if (options != null) {
37 if (isAbstractControlOptions(options)) {
38 // `options` are `AbstractControlOptions`
39 validators = options.validators != null ? options.validators : null;
40 asyncValidators = options.asyncValidators != null ? options.asyncValidators : null;
41 updateOn = options.updateOn != null ? options.updateOn : undefined;
42 }
43 else {
44 // `options` are legacy form group options
45 validators = options['validator'] != null ? options['validator'] : null;
46 asyncValidators = options['asyncValidator'] != null ? options['asyncValidator'] : null;
47 }
48 }
49 return new FormGroup(controls, { asyncValidators, updateOn, validators });
50 }
51 /**
52 * @description
53 * Construct a new `FormControl` with the given state, validators and options.
54 *
55 * @param formState Initializes the control with an initial state value, or
56 * with an object that contains both a value and a disabled status.
57 *
58 * @param validatorOrOpts A synchronous validator function, or an array of
59 * such functions, or an `AbstractControlOptions` object that contains
60 * validation functions and a validation trigger.
61 *
62 * @param asyncValidator A single async validator or array of async validator
63 * functions.
64 *
65 * @usageNotes
66 *
67 * ### Initialize a control as disabled
68 *
69 * The following example returns a control with an initial value in a disabled state.
70 *
71 * <code-example path="forms/ts/formBuilder/form_builder_example.ts" region="disabled-control">
72 * </code-example>
73 */
74 control(formState, validatorOrOpts, asyncValidator) {
75 return new FormControl(formState, validatorOrOpts, asyncValidator);
76 }
77 /**
78 * Constructs a new `FormArray` from the given array of configurations,
79 * validators and options.
80 *
81 * @param controlsConfig An array of child controls or control configs. Each
82 * child control is given an index when it is registered.
83 *
84 * @param validatorOrOpts A synchronous validator function, or an array of
85 * such functions, or an `AbstractControlOptions` object that contains
86 * validation functions and a validation trigger.
87 *
88 * @param asyncValidator A single async validator or array of async validator
89 * functions.
90 */
91 array(controlsConfig, validatorOrOpts, asyncValidator) {
92 const controls = controlsConfig.map(c => this._createControl(c));
93 return new FormArray(controls, validatorOrOpts, asyncValidator);
94 }
95 /** @internal */
96 _reduceControls(controlsConfig) {
97 const controls = {};
98 Object.keys(controlsConfig).forEach(controlName => {
99 controls[controlName] = this._createControl(controlsConfig[controlName]);
100 });
101 return controls;
102 }
103 /** @internal */
104 _createControl(controlConfig) {
105 if (controlConfig instanceof FormControl || controlConfig instanceof FormGroup ||
106 controlConfig instanceof FormArray) {
107 return controlConfig;
108 }
109 else if (Array.isArray(controlConfig)) {
110 const value = controlConfig[0];
111 const validator = controlConfig.length > 1 ? controlConfig[1] : null;
112 const asyncValidator = controlConfig.length > 2 ? controlConfig[2] : null;
113 return this.control(value, validator, asyncValidator);
114 }
115 else {
116 return this.control(controlConfig);
117 }
118 }
119}
120FormBuilder.ɵprov = i0.ɵɵdefineInjectable({ factory: function FormBuilder_Factory() { return new FormBuilder(); }, token: FormBuilder, providedIn: i1.ReactiveFormsModule });
121FormBuilder.decorators = [
122 { type: Injectable, args: [{ providedIn: ReactiveFormsModule },] }
123];
124//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form_builder.js","sourceRoot":"","sources":["../../../../../../packages/forms/src/form_builder.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {Injectable} from '@angular/core';\n\nimport {AsyncValidatorFn, ValidatorFn} from './directives/validators';\nimport {ReactiveFormsModule} from './form_providers';\nimport {AbstractControl, AbstractControlOptions, FormArray, FormControl, FormGroup, FormHooks} from './model';\n\nfunction isAbstractControlOptions(options: AbstractControlOptions|\n                                  {[key: string]: any}): options is AbstractControlOptions {\n  return (<AbstractControlOptions>options).asyncValidators !== undefined ||\n      (<AbstractControlOptions>options).validators !== undefined ||\n      (<AbstractControlOptions>options).updateOn !== undefined;\n}\n\n/**\n * @description\n * Creates an `AbstractControl` from a user-specified configuration.\n *\n * The `FormBuilder` provides syntactic sugar that shortens creating instances of a `FormControl`,\n * `FormGroup`, or `FormArray`. It reduces the amount of boilerplate needed to build complex\n * forms.\n *\n * @see [Reactive Forms Guide](/guide/reactive-forms)\n *\n * @publicApi\n */\n@Injectable({providedIn: ReactiveFormsModule})\nexport class FormBuilder {\n  /**\n   * @description\n   * Construct a new `FormGroup` instance.\n   *\n   * @param controlsConfig A collection of child controls. The key for each child is the name\n   * under which it is registered.\n   *\n   * @param options Configuration options object for the `FormGroup`. The object should have the\n   * the `AbstractControlOptions` type and might contain the following fields:\n   * * `validators`: A synchronous validator function, or an array of validator functions\n   * * `asyncValidators`: A single async validator or array of async validator functions\n   * * `updateOn`: The event upon which the control should be updated (options: 'change' | 'blur' |\n   * submit')\n   */\n  group(\n      controlsConfig: {[key: string]: any},\n      options?: AbstractControlOptions|null,\n      ): FormGroup;\n  /**\n   * @description\n   * Construct a new `FormGroup` instance.\n   *\n   * @deprecated This API is not typesafe and can result in issues with Closure Compiler renaming.\n   * Use the `FormBuilder#group` overload with `AbstractControlOptions` instead.\n   * Note that `AbstractControlOptions` expects `validators` and `asyncValidators` to be valid\n   * validators. If you have custom validators, make sure their validation function parameter is\n   * `AbstractControl` and not a sub-class, such as `FormGroup`. These functions will be called with\n   * an object of type `AbstractControl` and that cannot be automatically downcast to a subclass, so\n   * TypeScript sees this as an error. For example, change the `(group: FormGroup) =>\n   * ValidationErrors|null` signature to be `(group: AbstractControl) => ValidationErrors|null`.\n   *\n   * @param controlsConfig A collection of child controls. The key for each child is the name\n   * under which it is registered.\n   *\n   * @param options Configuration options object for the `FormGroup`. The legacy configuration\n   * object consists of:\n   * * `validator`: A synchronous validator function, or an array of validator functions\n   * * `asyncValidator`: A single async validator or array of async validator functions\n   * Note: the legacy format is deprecated and might be removed in one of the next major versions\n   * of Angular.\n   */\n  group(\n      controlsConfig: {[key: string]: any},\n      options: {[key: string]: any},\n      ): FormGroup;\n  group(\n      controlsConfig: {[key: string]: any},\n      options: AbstractControlOptions|{[key: string]: any}|null = null): FormGroup {\n    const controls = this._reduceControls(controlsConfig);\n\n    let validators: ValidatorFn|ValidatorFn[]|null = null;\n    let asyncValidators: AsyncValidatorFn|AsyncValidatorFn[]|null = null;\n    let updateOn: FormHooks|undefined = undefined;\n\n    if (options != null) {\n      if (isAbstractControlOptions(options)) {\n        // `options` are `AbstractControlOptions`\n        validators = options.validators != null ? options.validators : null;\n        asyncValidators = options.asyncValidators != null ? options.asyncValidators : null;\n        updateOn = options.updateOn != null ? options.updateOn : undefined;\n      } else {\n        // `options` are legacy form group options\n        validators = options['validator'] != null ? options['validator'] : null;\n        asyncValidators = options['asyncValidator'] != null ? options['asyncValidator'] : null;\n      }\n    }\n\n    return new FormGroup(controls, {asyncValidators, updateOn, validators});\n  }\n\n  /**\n   * @description\n   * Construct a new `FormControl` with the given state, validators and options.\n   *\n   * @param formState Initializes the control with an initial state value, or\n   * with an object that contains both a value and a disabled status.\n   *\n   * @param validatorOrOpts A synchronous validator function, or an array of\n   * such functions, or an `AbstractControlOptions` object that contains\n   * validation functions and a validation trigger.\n   *\n   * @param asyncValidator A single async validator or array of async validator\n   * functions.\n   *\n   * @usageNotes\n   *\n   * ### Initialize a control as disabled\n   *\n   * The following example returns a control with an initial value in a disabled state.\n   *\n   * <code-example path=\"forms/ts/formBuilder/form_builder_example.ts\" region=\"disabled-control\">\n   * </code-example>\n   */\n  control(\n      formState: any, validatorOrOpts?: ValidatorFn|ValidatorFn[]|AbstractControlOptions|null,\n      asyncValidator?: AsyncValidatorFn|AsyncValidatorFn[]|null): FormControl {\n    return new FormControl(formState, validatorOrOpts, asyncValidator);\n  }\n\n  /**\n   * Constructs a new `FormArray` from the given array of configurations,\n   * validators and options.\n   *\n   * @param controlsConfig An array of child controls or control configs. Each\n   * child control is given an index when it is registered.\n   *\n   * @param validatorOrOpts A synchronous validator function, or an array of\n   * such functions, or an `AbstractControlOptions` object that contains\n   * validation functions and a validation trigger.\n   *\n   * @param asyncValidator A single async validator or array of async validator\n   * functions.\n   */\n  array(\n      controlsConfig: any[],\n      validatorOrOpts?: ValidatorFn|ValidatorFn[]|AbstractControlOptions|null,\n      asyncValidator?: AsyncValidatorFn|AsyncValidatorFn[]|null): FormArray {\n    const controls = controlsConfig.map(c => this._createControl(c));\n    return new FormArray(controls, validatorOrOpts, asyncValidator);\n  }\n\n  /** @internal */\n  _reduceControls(controlsConfig: {[k: string]: any}): {[key: string]: AbstractControl} {\n    const controls: {[key: string]: AbstractControl} = {};\n    Object.keys(controlsConfig).forEach(controlName => {\n      controls[controlName] = this._createControl(controlsConfig[controlName]);\n    });\n    return controls;\n  }\n\n  /** @internal */\n  _createControl(controlConfig: any): AbstractControl {\n    if (controlConfig instanceof FormControl || controlConfig instanceof FormGroup ||\n        controlConfig instanceof FormArray) {\n      return controlConfig;\n\n    } else if (Array.isArray(controlConfig)) {\n      const value = controlConfig[0];\n      const validator: ValidatorFn = controlConfig.length > 1 ? controlConfig[1] : null;\n      const asyncValidator: AsyncValidatorFn = controlConfig.length > 2 ? controlConfig[2] : null;\n      return this.control(value, validator, asyncValidator);\n\n    } else {\n      return this.control(controlConfig);\n    }\n  }\n}\n"]}
Note: See TracBrowser for help on using the repository browser.