angular-dynamic-forms-lite
Version:
Efficient dynamic and customizable Angular 7+ forms.
200 lines • 18.8 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { ensureDefaultFormComponents } from "../../form-settings/form-field-settings";
import { isDynamicFieldType, DynamicFormType } from "../../form-field/form-field-type";
import { SubType } from "../../form-settings/sub-type";
import { ArrayRenderStrategy } from "../../form-field/array/array-render-strategy";
/** @type {?} */
const MissingSettingResolver = (/**
* @param {?} __0
* @return {?}
*/
([setting]) => {
throw new Error(`Unssuported form field for ${setting.name}`);
});
const ɵ0 = MissingSettingResolver;
/** @type {?} */
const ComponentSettingResolver = (/**
* @param {?} __0
* @return {?}
*/
([setting, form]) => {
if (typeof form !== "function") {
return {
match: false
};
}
setting.component = form;
return {
match: true,
value: [[setting.name, (/** @type {?} */ (setting))]]
};
});
const ɵ1 = ComponentSettingResolver;
/** @type {?} */
const DynamicTypeSettingResolver = (/**
* @param {?} __0
* @param {?} componentResolver
* @return {?}
*/
([setting, form, optionalComponent], componentResolver) => {
if (!isDynamicFieldType(form) && !(form instanceof SubType)) {
return {
match: false
};
}
if (form !== DynamicFormType.HIDDEN && !(form instanceof SubType && form.type === DynamicFormType.HIDDEN)) {
setting.component = componentResolver(setting, optionalComponent);
}
setting.type = form;
return {
match: true,
value: [[setting.name, (/** @type {?} */ (setting))]]
};
});
const ɵ2 = DynamicTypeSettingResolver;
/** @type {?} */
const ArraySettingResolver = (/**
* @param {?} __0
* @param {?} componentResolver
* @param {?} factory
* @return {?}
*/
([setting, form, optionalComponent], componentResolver, factory) => {
if (!Array.isArray(form)) {
return {
match: false
};
}
setting.type = DynamicFormType.ARRAY;
setting.component = (/** @type {?} */ (componentResolver(setting, optionalComponent)));
setting.renderStrategy = setting.renderStrategy || ArrayRenderStrategy.withFullRender();
const [[, childSetting], ...indirectChildren] = factory(form);
setting.childSetting = childSetting;
return {
match: true,
value: [[setting.name, (/** @type {?} */ (setting))], ...indirectChildren]
};
});
const ɵ3 = ArraySettingResolver;
/** @type {?} */
const GroupSettingResolver = (/**
* @param {?} __0
* @param {?} componentResolver
* @param {?} factory
* @return {?}
*/
([setting, form, optionalComponent], componentResolver, factory) => {
if (typeof form !== "object") {
return {
match: false
};
}
/** @type {?} */
const children = Object.entries(form).reduce((/**
* @param {?} settings
* @param {?} __1
* @return {?}
*/
(settings, [id, options]) => {
const [[, childSetting], ...indirectChildren] = factory(options);
return [...settings, [id, childSetting], ...indirectChildren];
}), []);
// form root does not have a name
if (!setting.name) {
return {
match: true,
value: children
};
}
setting.type = DynamicFormType.GROUP;
setting.component = componentResolver(setting, optionalComponent);
return {
match: true,
value: [[setting.name, (/** @type {?} */ (setting))], ...children]
};
});
const ɵ4 = GroupSettingResolver;
export class InlineSettingsResolver {
/**
* @param {?=} defaultFormComponents
*/
constructor(defaultFormComponents) {
this.defaultFormComponents = defaultFormComponents;
this.resolvers = [
DynamicTypeSettingResolver,
ComponentSettingResolver,
ArraySettingResolver,
GroupSettingResolver,
MissingSettingResolver
];
}
/**
* @param {?} inlineForm
* @return {?}
*/
resolve(inlineForm) {
return new Map(this.resolveSettings([null, inlineForm]));
}
/**
* @private
* @param {?} __0
* @return {?}
*/
resolveSettings([nameOrSetting, form, optionalComponent]) {
/** @type {?} */
let setting = this.createPartialSetting(nameOrSetting);
return this.resolvers.reduce((/**
* @param {?} prev
* @param {?} curr
* @return {?}
*/
(prev, curr) => prev.match
? prev
: curr([setting, form, optionalComponent], this.componentResolver.bind(this), this.resolveSettings.bind(this))), {
match: false,
value: []
}).value;
}
/**
* @private
* @param {?} nameOrSetting
* @return {?}
*/
createPartialSetting(nameOrSetting) {
/** @type {?} */
let setting = {};
if (typeof nameOrSetting === "string") {
setting.name = nameOrSetting;
}
else {
setting = nameOrSetting || {};
}
return setting;
}
/**
* @private
* @param {?} setting
* @param {?} optionalComponent
* @return {?}
*/
componentResolver(setting, optionalComponent) {
return optionalComponent || ensureDefaultFormComponents(this.defaultFormComponents, setting.name, setting.type);
}
}
if (false) {
/**
* @type {?}
* @private
*/
InlineSettingsResolver.prototype.resolvers;
/**
* @type {?}
* @private
*/
InlineSettingsResolver.prototype.defaultFormComponents;
}
export { ɵ0, ɵ1, ɵ2, ɵ3, ɵ4 };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inline-form-setting-resolver.js","sourceRoot":"ng://angular-dynamic-forms-lite/","sources":["lib/form/inline/inline-form-setting-resolver.ts"],"names":[],"mappings":";;;;AACA,OAAO,EAGL,2BAA2B,EAC5B,MAAM,yCAAyC,CAAC;AACjD,OAAO,EAAwB,kBAAkB,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AAE7G,OAAO,EAAE,OAAO,EAAE,MAAM,8BAA8B,CAAC;AAEvD,OAAO,EAAE,mBAAmB,EAAE,MAAM,8CAA8C,CAAC;;MAe7E,sBAAsB;;;;AAAoB,CAAC,CAAC,OAAO,CAAuB,EAAE,EAAE;IAClF,MAAM,IAAI,KAAK,CAAC,8BAA8B,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;AAChE,CAAC,CAAA;;;MAEK,wBAAwB;;;;AAAoB,CAAC,CAAC,OAAO,EAAE,IAAI,CAAuB,EAAE,EAAE;IAC1F,IAAI,OAAO,IAAI,KAAK,UAAU,EAAE;QAC9B,OAAO;YACL,KAAK,EAAE,KAAK;SACb,CAAC;KACH;IACD,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC;IAEzB,OAAO;QACL,KAAK,EAAE,IAAI;QACX,KAAK,EAAE,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,mBAAA,OAAO,EAA4B,CAAC,CAAC;KAC7D,CAAC;AACJ,CAAC,CAAA;;;MAEK,0BAA0B;;;;;AAAoB,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,iBAAiB,CAAC,EAAE,iBAAiB,EAAE,EAAE;IAC5G,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,YAAY,OAAO,CAAC,EAAE;QAC3D,OAAO;YACL,KAAK,EAAE,KAAK;SACb,CAAC;KACH;IAED,IAAI,IAAI,KAAK,eAAe,CAAC,MAAM,IAAI,CAAC,CAAC,IAAI,YAAY,OAAO,IAAI,IAAI,CAAC,IAAI,KAAK,eAAe,CAAC,MAAM,CAAC,EAAE;QACzG,OAAO,CAAC,SAAS,GAAG,iBAAiB,CAAC,OAAO,EAAE,iBAAiB,CAAC,CAAC;KACnE;IAED,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC;IAEpB,OAAO;QACL,KAAK,EAAE,IAAI;QACX,KAAK,EAAE,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,mBAAA,OAAO,EAA4B,CAAC,CAAC;KAC7D,CAAC;AACJ,CAAC,CAAA;;;MAEK,oBAAoB;;;;;;AAAoB,CAC5C,CAAC,OAAO,EAAE,IAAI,EAAE,iBAAiB,CAA8C,EAC/E,iBAAiB,EACjB,OAAO,EACP,EAAE;IACF,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;QACxB,OAAO;YACL,KAAK,EAAE,KAAK;SACb,CAAC;KACH;IAED,OAAO,CAAC,IAAI,GAAG,eAAe,CAAC,KAAK,CAAC;IACrC,OAAO,CAAC,SAAS,GAAG,mBAAA,iBAAiB,CAAC,OAAO,EAAE,iBAAiB,CAAC,EAAiC,CAAC;IACnG,OAAO,CAAC,cAAc,GAAG,OAAO,CAAC,cAAc,IAAI,mBAAmB,CAAC,cAAc,EAAE,CAAC;UAElF,CAAC,CAAC,EAAE,YAAY,CAAC,EAAE,GAAG,gBAAgB,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAC7D,OAAO,CAAC,YAAY,GAAG,YAAY,CAAC;IAEpC,OAAO;QACL,KAAK,EAAE,IAAI;QACX,KAAK,EAAE,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,mBAAA,OAAO,EAA4B,CAAC,EAAE,GAAG,gBAAgB,CAAC;KAClF,CAAC;AACJ,CAAC,CAAA;;;MAEK,oBAAoB;;;;;;AAAoB,CAC5C,CAAC,OAAO,EAAE,IAAI,EAAE,iBAAiB,CAAuB,EACxD,iBAAiB,EACjB,OAAO,EACP,EAAE;IACF,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;QAC5B,OAAO;YACL,KAAK,EAAE,KAAK;SACb,CAAC;KACH;;UAEK,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM;;;;;IAAoB,CAAC,QAAQ,EAAE,CAAC,EAAE,EAAE,OAAO,CAAC,EAAE,EAAE;cACpF,CAAC,CAAC,EAAE,YAAY,CAAC,EAAE,GAAG,gBAAgB,CAAC,GAAG,OAAO,CAAC,OAAO,CAAC;QAChE,OAAO,CAAC,GAAG,QAAQ,EAAE,CAAC,EAAE,EAAE,YAAY,CAAC,EAAE,GAAG,gBAAgB,CAAC,CAAC;IAChE,CAAC,GAAE,EAAE,CAAC;IAEN,iCAAiC;IACjC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE;QACjB,OAAO;YACL,KAAK,EAAE,IAAI;YACX,KAAK,EAAE,QAAQ;SAChB,CAAC;KACH;IAED,OAAO,CAAC,IAAI,GAAG,eAAe,CAAC,KAAK,CAAC;IACrC,OAAO,CAAC,SAAS,GAAG,iBAAiB,CAAC,OAAO,EAAE,iBAAiB,CAAC,CAAC;IAElE,OAAO;QACL,KAAK,EAAE,IAAI;QACX,KAAK,EAAE,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,mBAAA,OAAO,EAA4B,CAAC,EAAE,GAAG,QAAQ,CAAC;KAC1E,CAAC;AACJ,CAAC,CAAA;;AAED,MAAM,OAAO,sBAAsB;;;;IAQjC,YAAoB,qBAA4C;QAA5C,0BAAqB,GAArB,qBAAqB,CAAuB;QAP/C,cAAS,GAAsB;YAC9C,0BAA0B;YAC1B,wBAAwB;YACxB,oBAAoB;YACpB,oBAAoB;YACpB,sBAAsB;SACvB,CAAC;IACiE,CAAC;;;;;IAE7D,OAAO,CAAC,UAAsB;QACnC,OAAO,IAAI,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC;IAC3D,CAAC;;;;;;IAEO,eAAe,CAAC,CAAC,aAAa,EAAE,IAAI,EAAE,iBAAiB,CAAgB;;YACzE,OAAO,GAA8B,IAAI,CAAC,oBAAoB,CAAC,aAAa,CAAC;QACjF,OAAO,IAAI,CAAC,SAAS,CAAC,MAAM;;;;;QAC1B,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,CACb,IAAI,CAAC,KAAK;YACR,CAAC,CAAC,IAAI;YACN,CAAC,CAAC,IAAI,CACF,CAAC,OAAO,EAAE,IAAI,EAAE,iBAAiB,CAAC,EAClC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,EACjC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAChC,GACP;YACE,KAAK,EAAE,KAAK;YACZ,KAAK,EAAE,EAAE;SACV,CACF,CAAC,KAAK,CAAC;IACV,CAAC;;;;;;IAEO,oBAAoB,CAAC,aAA0C;;YACjE,OAAO,GAA8B,EAAE;QAC3C,IAAI,OAAO,aAAa,KAAK,QAAQ,EAAE;YACrC,OAAO,CAAC,IAAI,GAAG,aAAa,CAAC;SAC9B;aAAM;YACL,OAAO,GAAG,aAAa,IAAI,EAAE,CAAC;SAC/B;QAED,OAAO,OAAO,CAAC;IACjB,CAAC;;;;;;;IAEO,iBAAiB,CAAC,OAAkC,EAAE,iBAAyC;QACrG,OAAO,iBAAiB,IAAI,2BAA2B,CAAC,IAAI,CAAC,qBAAqB,EAAE,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;IAClH,CAAC;CACF;;;;;;IA7CC,2CAME;;;;;IACU,uDAAoD","sourcesContent":["import { InlineForm, InlineOptions, InlineValueOrType } from \"./inline-form\";\nimport {\n  FormFieldSettings,\n  CombinedFormFieldSetting,\n  ensureDefaultFormComponents\n} from \"../../form-settings/form-field-settings\";\nimport { FormComponentsByType, isDynamicFieldType, DynamicFormType } from \"../../form-field/form-field-type\";\nimport { FormFieldSetting } from \"../../form-settings/form-field-setting\";\nimport { SubType } from \"../../form-settings/sub-type\";\nimport { ArrayFormFieldSetting } from \"../../form-field/array/array-form-field-setting\";\nimport { ArrayRenderStrategy } from \"../../form-field/array/array-render-strategy\";\nimport { InlineSetting } from \"../../form-settings/inline-setting\";\nimport { FormFieldComponentType } from \"../../form-field/form-field-component\";\nimport { FormFieldArrayComponent } from \"../../form-field/array/form-field-array-component\";\nimport { Type } from \"@angular/core\";\n\ntype PartialInlineOptions<S = FormFieldSetting> = [Partial<S>, InlineValueOrType, FormFieldComponentType?];\ntype SettingMapEntry = [string, CombinedFormFieldSetting];\ntype SettingResolverResult = { match: boolean; value?: SettingMapEntry[] };\ntype SettingResolver = (\n  options: PartialInlineOptions,\n  componentResolver: (setting: Partial<FormFieldSetting>, comp: FormFieldComponentType) => FormFieldComponentType,\n  factory: (options: any) => SettingMapEntry[]\n) => SettingResolverResult;\n\nconst MissingSettingResolver: SettingResolver = ([setting]: PartialInlineOptions) => {\n  throw new Error(`Unssuported form field for ${setting.name}`);\n};\n\nconst ComponentSettingResolver: SettingResolver = ([setting, form]: PartialInlineOptions) => {\n  if (typeof form !== \"function\") {\n    return {\n      match: false\n    };\n  }\n  setting.component = form;\n\n  return {\n    match: true,\n    value: [[setting.name, setting as CombinedFormFieldSetting]]\n  };\n};\n\nconst DynamicTypeSettingResolver: SettingResolver = ([setting, form, optionalComponent], componentResolver) => {\n  if (!isDynamicFieldType(form) && !(form instanceof SubType)) {\n    return {\n      match: false\n    };\n  }\n\n  if (form !== DynamicFormType.HIDDEN && !(form instanceof SubType && form.type === DynamicFormType.HIDDEN)) {\n    setting.component = componentResolver(setting, optionalComponent);\n  }\n\n  setting.type = form;\n\n  return {\n    match: true,\n    value: [[setting.name, setting as CombinedFormFieldSetting]]\n  };\n};\n\nconst ArraySettingResolver: SettingResolver = (\n  [setting, form, optionalComponent]: PartialInlineOptions<ArrayFormFieldSetting>,\n  componentResolver,\n  factory\n) => {\n  if (!Array.isArray(form)) {\n    return {\n      match: false\n    };\n  }\n\n  setting.type = DynamicFormType.ARRAY;\n  setting.component = componentResolver(setting, optionalComponent) as Type<FormFieldArrayComponent>;\n  setting.renderStrategy = setting.renderStrategy || ArrayRenderStrategy.withFullRender();\n\n  const [[, childSetting], ...indirectChildren] = factory(form);\n  setting.childSetting = childSetting;\n\n  return {\n    match: true,\n    value: [[setting.name, setting as CombinedFormFieldSetting], ...indirectChildren]\n  };\n};\n\nconst GroupSettingResolver: SettingResolver = (\n  [setting, form, optionalComponent]: PartialInlineOptions,\n  componentResolver,\n  factory\n) => {\n  if (typeof form !== \"object\") {\n    return {\n      match: false\n    };\n  }\n\n  const children = Object.entries(form).reduce<SettingMapEntry[]>((settings, [id, options]) => {\n    const [[, childSetting], ...indirectChildren] = factory(options);\n    return [...settings, [id, childSetting], ...indirectChildren];\n  }, []);\n\n  // form root does not have a name\n  if (!setting.name) {\n    return {\n      match: true,\n      value: children\n    };\n  }\n\n  setting.type = DynamicFormType.GROUP;\n  setting.component = componentResolver(setting, optionalComponent);\n\n  return {\n    match: true,\n    value: [[setting.name, setting as CombinedFormFieldSetting], ...children]\n  };\n};\n\nexport class InlineSettingsResolver {\n  private readonly resolvers: SettingResolver[] = [\n    DynamicTypeSettingResolver,\n    ComponentSettingResolver,\n    ArraySettingResolver,\n    GroupSettingResolver,\n    MissingSettingResolver\n  ];\n  constructor(private defaultFormComponents?: FormComponentsByType) {}\n\n  public resolve(inlineForm: InlineForm): FormFieldSettings {\n    return new Map(this.resolveSettings([null, inlineForm]));\n  }\n\n  private resolveSettings([nameOrSetting, form, optionalComponent]: InlineOptions): SettingMapEntry[] {\n    let setting: Partial<FormFieldSetting> = this.createPartialSetting(nameOrSetting);\n    return this.resolvers.reduce<SettingResolverResult>(\n      (prev, curr) =>\n        prev.match\n          ? prev\n          : curr(\n              [setting, form, optionalComponent],\n              this.componentResolver.bind(this),\n              this.resolveSettings.bind(this)\n            ),\n      {\n        match: false,\n        value: []\n      }\n    ).value;\n  }\n\n  private createPartialSetting(nameOrSetting: string | InlineSetting<any>): Partial<FormFieldSetting> {\n    let setting: Partial<FormFieldSetting> = {};\n    if (typeof nameOrSetting === \"string\") {\n      setting.name = nameOrSetting;\n    } else {\n      setting = nameOrSetting || {};\n    }\n\n    return setting;\n  }\n\n  private componentResolver(setting: Partial<FormFieldSetting>, optionalComponent: FormFieldComponentType) {\n    return optionalComponent || ensureDefaultFormComponents(this.defaultFormComponents, setting.name, setting.type);\n  }\n}\n"]}