UNPKG

@formql/core

Version:

FormQL - A framework for building dynamic forms

119 lines 15.6 kB
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"]}