@ng-dynamic-forms/core
Version:
A rapid form development library for Angular
100 lines • 15 kB
JavaScript
import { Injectable, QueryList } from "@angular/core";
import { DynamicFormArrayGroupModel } from "../model/form-array/dynamic-form-array.model";
import { DYNAMIC_TEMPLATE_DIRECTIVE_ALIGNMENT } from "../directive/dynamic-template.directive";
import { isObject, isString } from "../utils/core.utils";
import * as i0 from "@angular/core";
export class DynamicFormLayoutService {
findById(id, formLayout) {
if (isObject(formLayout)) {
for (const key of Object.keys(formLayout)) {
if (key === id) {
return formLayout[key];
}
}
}
return null;
}
findByModel(model, formLayout) {
let controlLayout = null;
if (isObject(formLayout)) {
for (const key of Object.keys(formLayout)) {
key.split(",").forEach(substring => {
const selector = substring.trim();
if (selector === model.id || selector === model.type) {
controlLayout = formLayout[key];
}
});
}
}
return controlLayout;
}
filterTemplatesByModel(model, templates) {
const filterCallback = (template) => {
return template.modelId === model.id || template.modelType === model.type;
};
if (templates instanceof QueryList) {
return templates.filter(filterCallback);
}
else if (Array.isArray(templates)) {
return templates.filter(filterCallback);
}
return [];
}
getAlignedTemplate(model, templates, alignment) {
return this.filterTemplatesByModel(model, templates)
.find(template => template.as === null && template.align === alignment);
}
/*
getIndexedTemplates(model: DynamicFormControlModel, templates: DynamicFormControlTemplates): DynamicTemplateDirective[] | undefined {
return this.filterTemplatesByModel(model, templates).filter(template => template.as === null);
}
*/
getStartTemplate(model, templates) {
return this.getAlignedTemplate(model, templates, DYNAMIC_TEMPLATE_DIRECTIVE_ALIGNMENT.Start);
}
getEndTemplate(model, templates) {
return this.getAlignedTemplate(model, templates, DYNAMIC_TEMPLATE_DIRECTIVE_ALIGNMENT.End);
}
getClass(layout, context, place) {
if (isObject(layout) && layout.hasOwnProperty(context)) {
const config = layout[context];
if (config.hasOwnProperty(place)) {
return config[place];
}
}
return "";
}
getHostClass(layout) {
const keys = ["element", "grid"];
let cls = "";
if (isObject(layout)) {
keys.forEach(key => {
if (isObject(layout[key]) && isString(layout[key]?.host)) {
cls = cls + ` ${layout[key]?.host}`;
}
});
}
return cls;
}
getElementId(model) {
let id = model.id;
let parent = model.parent;
while (parent !== null) {
if (parent instanceof DynamicFormArrayGroupModel) {
id = `${parent.context.id}-${parent.index}-${model.id}`;
break;
}
parent = parent.parent;
}
return id;
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: DynamicFormLayoutService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: DynamicFormLayoutService, providedIn: "root" }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: DynamicFormLayoutService, decorators: [{
type: Injectable,
args: [{
providedIn: "root"
}]
}] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form-layout.service.js","sourceRoot":"","sources":["../../../../../../projects/ng-dynamic-forms/core/src/lib/service/dynamic-form-layout.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, QueryList } from \"@angular/core\";\nimport {\n    DynamicFormControlLayout,\n    DynamicFormControlLayoutConfig,\n    DynamicFormControlLayoutContext,\n    DynamicFormControlLayoutPlace\n} from \"../model/misc/dynamic-form-control-layout.model\";\nimport { DynamicFormControlModel } from \"../model/dynamic-form-control.model\";\nimport { DynamicFormArrayGroupModel } from \"../model/form-array/dynamic-form-array.model\";\nimport { DynamicTemplateDirective, DYNAMIC_TEMPLATE_DIRECTIVE_ALIGNMENT } from \"../directive/dynamic-template.directive\";\nimport { isObject, isString } from \"../utils/core.utils\";\n\nexport type DynamicFormLayout = { [id: string]: DynamicFormControlLayout };\n\nexport type DynamicFormControlTemplates = QueryList<DynamicTemplateDirective> | DynamicTemplateDirective[] | undefined;\n\n@Injectable({\n    providedIn: \"root\"\n})\nexport class DynamicFormLayoutService {\n\n    findById(id: string, formLayout: DynamicFormLayout | null): DynamicFormControlLayout | null {\n        if (isObject(formLayout)) {\n            for (const key of Object.keys(formLayout)) {\n                if (key === id) {\n                    return formLayout[key];\n                }\n            }\n        }\n\n        return null;\n    }\n\n    findByModel(model: DynamicFormControlModel, formLayout: DynamicFormLayout | null | undefined): DynamicFormControlLayout | null {\n        let controlLayout: DynamicFormControlLayout | null = null;\n\n        if (isObject(formLayout)) {\n            for (const key of Object.keys(formLayout)) {\n                key.split(\",\").forEach(substring => {\n                    const selector = substring.trim();\n\n                    if (selector === model.id || selector === model.type) {\n                        controlLayout = formLayout[key];\n                    }\n                });\n            }\n        }\n\n        return controlLayout;\n    }\n\n    filterTemplatesByModel(model: DynamicFormControlModel, templates: DynamicFormControlTemplates): DynamicTemplateDirective[] {\n        const filterCallback: (template: DynamicTemplateDirective) => boolean = (template: DynamicTemplateDirective) => {\n            return template.modelId === model.id || template.modelType === model.type;\n        };\n\n        if (templates instanceof QueryList) {\n            return templates.filter(filterCallback);\n\n        } else if (Array.isArray(templates)) {\n            return templates.filter(filterCallback);\n        }\n\n        return [];\n    }\n\n    getAlignedTemplate(model: DynamicFormControlModel, templates: DynamicFormControlTemplates,\n                       alignment: DYNAMIC_TEMPLATE_DIRECTIVE_ALIGNMENT): DynamicTemplateDirective | undefined {\n\n        return this.filterTemplatesByModel(model, templates)\n            .find(template => template.as === null && template.align === alignment);\n    }\n\n    /*\n    getIndexedTemplates(model: DynamicFormControlModel, templates: DynamicFormControlTemplates): DynamicTemplateDirective[] | undefined {\n        return this.filterTemplatesByModel(model, templates).filter(template => template.as === null);\n    }\n    */\n    getStartTemplate(model: DynamicFormControlModel, templates: DynamicFormControlTemplates): DynamicTemplateDirective | undefined {\n        return this.getAlignedTemplate(model, templates, DYNAMIC_TEMPLATE_DIRECTIVE_ALIGNMENT.Start);\n    }\n\n    getEndTemplate(model: DynamicFormControlModel, templates: DynamicFormControlTemplates): DynamicTemplateDirective | undefined {\n        return this.getAlignedTemplate(model, templates, DYNAMIC_TEMPLATE_DIRECTIVE_ALIGNMENT.End);\n    }\n\n    getClass(layout: DynamicFormControlLayout | null | undefined, context: DynamicFormControlLayoutContext,\n             place: DynamicFormControlLayoutPlace): string {\n\n        if (isObject(layout) && layout.hasOwnProperty(context)) {\n            const config = layout[context] as DynamicFormControlLayoutConfig;\n            if (config.hasOwnProperty(place)) {\n                return config[place] as string;\n            }\n        }\n\n        return \"\";\n    }\n\n    getHostClass(layout: DynamicFormControlLayout | null | undefined): string {\n        const keys: (keyof DynamicFormControlLayout)[] = [\"element\", \"grid\"];\n        let cls = \"\";\n\n        if (isObject(layout)) {\n            keys.forEach(key => {\n                if (isObject(layout[key]) && isString(layout[key]?.host)) {\n                    cls = cls + ` ${layout[key]?.host}`;\n                }\n            });\n        }\n\n        return cls;\n    }\n\n    getElementId(model: DynamicFormControlModel): string {\n        let id = model.id;\n        let parent = model.parent;\n\n        while (parent !== null) {\n            if (parent instanceof DynamicFormArrayGroupModel) {\n                id = `${parent.context.id}-${parent.index}-${model.id}`;\n                break;\n            }\n\n            parent = parent.parent;\n        }\n\n        return id;\n    }\n}\n"]}