@formql/core
Version:
FormQL - A framework for building dynamic forms
119 lines • 15.6 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { Directive, ElementRef, Input, ViewContainerRef, TemplateRef, Renderer2, Output, EventEmitter } from '@angular/core';
let LayoutDirective = class LayoutDirective {
constructor(view, el, renderer, template) {
this.view = view;
this.el = el;
this.renderer = renderer;
this.template = template;
this.resetItems = new EventEmitter();
}
set formqlGdConfigOf(config) {
this.view.clear();
this.setParentAttributes(config);
const list = this.getGridStyleList(config);
if (list) {
this.resetItems.emit(true);
list.forEach((item, index) => {
this.view.createEmbeddedView(this.template, {
$implicit: item,
index
});
});
}
}
/**
* Get a list with the grid styling
*
* @param style: style configuration
*/
getGridStyleList(config) {
if (config) {
const divList = [];
const rowsDefArr = config.gridTemplateAreas.split('" "');
const style = {};
if (config.gridTemplateColumns) {
style['grid-template-columns'] = config.gridTemplateColumns;
style['-ms-grid-columns'] = style['grid-template-columns'];
}
if (config.gridTemplateRows) {
style['grid-template-rows'] = config.gridTemplateRows;
style['-ms-grid-rows'] = style['grid-template-rows'];
}
const idList = [];
for (let i = 0; i < rowsDefArr.length; i++) {
const rowArr = rowsDefArr[i].split(' ');
for (let y = 0; y < rowArr.length; y++) {
const cell = rowArr[y].replace(/\"/g, '');
const existingCell = divList.find(x => x.id === cell);
if (!existingCell) {
idList.push(cell);
divList.push({
id: cell,
style: { 'grid-area': cell,
'-ms-grid-row': i + 1,
'-ms-grid-row-span': 1,
'-ms-grid-column': y + 1,
'-ms-grid-column-span': 1
}
});
}
else
existingCell.style['-ms-grid-row'] - 1 === i ?
existingCell.style['-ms-grid-column-span']++ :
existingCell.style['-ms-grid-row-span']++;
}
}
return divList;
}
return null;
}
/**
* Set the appropiate css grid attributes for the parent object
*
* @param style
*/
setParentAttributes(config) {
let parentElement = this.el.nativeElement.parentElement;
if (!parentElement)
parentElement = this.el.nativeElement.parentNode;
let styleAttrValue = '';
if (config.gridTemplateAreas)
styleAttrValue += `grid-template-areas:${config.gridTemplateAreas};`;
if (config.gridTemplateColumns) {
styleAttrValue += `grid-template-columns:${config.gridTemplateColumns};`;
styleAttrValue += `-ms-grid-columns:${config.gridTemplateColumns};`;
}
if (config.gridTemplateRows) {
styleAttrValue += `grid-template-rows:${config.gridTemplateRows};`;
styleAttrValue += `-ms-grid-rows:${config.gridTemplateRows};`;
}
if (config.style) {
const array = Object.keys(config.style);
for (let i = 0; i < array.length; i++)
styleAttrValue += array[i] + ':' + config.style[array[i]] + ';';
}
if (styleAttrValue)
this.renderer.setAttribute(parentElement, 'style', styleAttrValue);
}
};
__decorate([
Output(),
__metadata("design:type", EventEmitter)
], LayoutDirective.prototype, "resetItems", void 0);
__decorate([
Input(),
__metadata("design:type", Object),
__metadata("design:paramtypes", [Object])
], LayoutDirective.prototype, "formqlGdConfigOf", null);
LayoutDirective = __decorate([
Directive({
selector: '[formqlGdConfig][formqlGdConfigOf]'
}),
__metadata("design:paramtypes", [ViewContainerRef,
ElementRef,
Renderer2,
TemplateRef])
], LayoutDirective);
export { LayoutDirective };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"layout.directive.js","sourceRoot":"ng://@formql/core/","sources":["directives/layout.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, ViewContainerRef, TemplateRef, Renderer2, Output, EventEmitter } from '@angular/core';\r\nimport { GridStyle } from '../models/style.model';\r\n\r\n@Directive({\r\n    selector: '[formqlGdConfig][formqlGdConfigOf]'\r\n})\r\nexport class LayoutDirective {\r\n    constructor(private view: ViewContainerRef,\r\n        private el: ElementRef,\r\n        private renderer: Renderer2,\r\n        private template: TemplateRef<any>) { }\r\n\r\n    @Output() resetItems: EventEmitter<boolean> = new EventEmitter();\r\n\r\n    @Input()\r\n    set formqlGdConfigOf(config: GridStyle) {\r\n        this.view.clear();\r\n\r\n        this.setParentAttributes(config);\r\n\r\n        const list = this.getGridStyleList(config);\r\n        if (list) {\r\n          this.resetItems.emit(true);\r\n          list.forEach((item, index) => {\r\n              this.view.createEmbeddedView(this.template, {\r\n                  $implicit: item,\r\n                  index\r\n              });\r\n          });\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Get a list with the grid styling\r\n     *\r\n     * @param style: style configuration\r\n     */\r\n    getGridStyleList(config: GridStyle) {\r\n        if (config) {\r\n            const divList = [];\r\n            const rowsDefArr = config.gridTemplateAreas.split('\" \"');\r\n            const style = {};\r\n            if (config.gridTemplateColumns) {\r\n                style['grid-template-columns'] = config.gridTemplateColumns;\r\n                style['-ms-grid-columns'] = style['grid-template-columns'];\r\n            }\r\n            if (config.gridTemplateRows) {\r\n                style['grid-template-rows'] = config.gridTemplateRows;\r\n                style['-ms-grid-rows'] = style['grid-template-rows'];\r\n            }\r\n            const idList = [];\r\n\r\n            for (let i = 0; i < rowsDefArr.length; i++) {\r\n                const rowArr = rowsDefArr[i].split(' ');\r\n                for (let y = 0; y < rowArr.length; y++) {\r\n                    const cell = rowArr[y].replace(/\\\"/g, '');\r\n                    const existingCell = divList.find(x => x.id === cell);\r\n                    if (!existingCell) {\r\n                        idList.push(cell);\r\n                        divList.push(\r\n                            {\r\n                                id: cell,\r\n                                style:  { 'grid-area': cell,\r\n                                          '-ms-grid-row': i + 1,\r\n                                          '-ms-grid-row-span': 1,\r\n                                          '-ms-grid-column': y + 1,\r\n                                          '-ms-grid-column-span': 1\r\n                                        }\r\n                            });\r\n                    } else\r\n                        existingCell.style['-ms-grid-row'] - 1 === i ?\r\n                                existingCell.style['-ms-grid-column-span']++ :\r\n                                existingCell.style['-ms-grid-row-span']++;\r\n                }\r\n            }\r\n            return divList;\r\n        }\r\n        return null;\r\n    }\r\n\r\n    /**\r\n     * Set the appropiate css grid attributes for the parent object\r\n     *\r\n     * @param style\r\n     */\r\n    setParentAttributes(config: GridStyle) {\r\n        let parentElement = <HTMLElement>this.el.nativeElement.parentElement;\r\n        if (!parentElement)\r\n            parentElement = <HTMLElement>this.el.nativeElement.parentNode;\r\n\r\n        let styleAttrValue = '';\r\n        if (config.gridTemplateAreas)\r\n            styleAttrValue += `grid-template-areas:${config.gridTemplateAreas};`;\r\n\r\n        if (config.gridTemplateColumns) {\r\n            styleAttrValue += `grid-template-columns:${config.gridTemplateColumns};`;\r\n            styleAttrValue += `-ms-grid-columns:${config.gridTemplateColumns};`;\r\n        }\r\n\r\n        if (config.gridTemplateRows) {\r\n            styleAttrValue += `grid-template-rows:${config.gridTemplateRows};`;\r\n            styleAttrValue += `-ms-grid-rows:${config.gridTemplateRows};`;\r\n        }\r\n\r\n        if (config.style) {\r\n            const array = Object.keys(config.style);\r\n            for (let i = 0; i < array.length; i++)\r\n                styleAttrValue += array[i] + ':' + config.style[array[i]] + ';';\r\n        }\r\n\r\n        if (styleAttrValue)\r\n            this.renderer.setAttribute(parentElement, 'style', styleAttrValue);\r\n\r\n    }\r\n}\r\n"]}