@formql/core
Version:
FormQL - A framework for building dynamic forms
128 lines • 16.3 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { Directive, ElementRef, Input, ViewContainerRef, TemplateRef, Renderer2, Output, EventEmitter } from '@angular/core';
var LayoutDirective = /** @class */ (function () {
function LayoutDirective(view, el, renderer, template) {
this.view = view;
this.el = el;
this.renderer = renderer;
this.template = template;
this.resetItems = new EventEmitter();
}
Object.defineProperty(LayoutDirective.prototype, "formqlGdConfigOf", {
set: function (config) {
var _this = this;
this.view.clear();
this.setParentAttributes(config);
var list = this.getGridStyleList(config);
if (list) {
this.resetItems.emit(true);
list.forEach(function (item, index) {
_this.view.createEmbeddedView(_this.template, {
$implicit: item,
index: index
});
});
}
},
enumerable: true,
configurable: true
});
/**
* Get a list with the grid styling
*
* @param style: style configuration
*/
LayoutDirective.prototype.getGridStyleList = function (config) {
if (config) {
var divList = [];
var rowsDefArr = config.gridTemplateAreas.split('" "');
var 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'];
}
var idList = [];
for (var i = 0; i < rowsDefArr.length; i++) {
var rowArr = rowsDefArr[i].split(' ');
var _loop_1 = function (y) {
var cell = rowArr[y].replace(/\"/g, '');
var existingCell = divList.find(function (x) { return 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']++;
};
for (var y = 0; y < rowArr.length; y++) {
_loop_1(y);
}
}
return divList;
}
return null;
};
/**
* Set the appropiate css grid attributes for the parent object
*
* @param style
*/
LayoutDirective.prototype.setParentAttributes = function (config) {
var parentElement = this.el.nativeElement.parentElement;
if (!parentElement)
parentElement = this.el.nativeElement.parentNode;
var 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) {
var array = Object.keys(config.style);
for (var 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);
return 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"]}