UNPKG

@formql/core

Version:

FormQL - A framework for building dynamic forms

128 lines 16.3 kB
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"]}