UNPKG

angular-gridster2

Version:
84 lines 16 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); var core_1 = require("@angular/core"); var gridster_component_1 = require("./gridster.component"); var GridsterGridComponent = (function () { function GridsterGridComponent(el, gridster, renderer, cdRef) { this.renderer = renderer; this.cdRef = cdRef; this.el = el.nativeElement; this.gridster = gridster; this.gridster.gridLines = this; this.columns = []; this.rows = []; this.height = 0; this.width = 0; this.columnsHeight = 0; this.rowsWidth = 0; } GridsterGridComponent.prototype.ngOnDestroy = function () { delete this.el; delete this.gridster.gridLines; delete this.gridster; }; GridsterGridComponent.prototype.updateGrid = function () { if (this.gridster.$options.displayGrid === 'always' && !this.gridster.mobile) { this.renderer.setStyle(this.el, 'display', 'block'); } else if (this.gridster.$options.displayGrid === 'onDrag&Resize' && this.gridster.dragInProgress) { this.renderer.setStyle(this.el, 'display', 'block'); } else if (this.gridster.$options.displayGrid === 'none' || !this.gridster.dragInProgress || this.gridster.mobile) { this.renderer.setStyle(this.el, 'display', 'none'); } this.gridster.setGridDimensions(); this.height = this.gridster.curRowHeight - this.gridster.$options.margin; this.width = this.gridster.curColWidth - this.gridster.$options.margin; this.columns.length = Math.max(this.gridster.columns, Math.floor(this.gridster.curWidth / this.gridster.curColWidth)) || 0; this.rows.length = Math.max(this.gridster.rows, Math.floor(this.gridster.curHeight / this.gridster.curRowHeight)) || 0; this.columnsHeight = this.gridster.curRowHeight * this.rows.length + this.getMarginTop(true) - this.gridster.$options.margin; this.rowsWidth = this.gridster.curColWidth * this.columns.length + this.getMarginLeft(true) - this.gridster.$options.margin; this.cdRef.markForCheck(); }; GridsterGridComponent.prototype.getMarginTop = function (isFirst) { if (isFirst && !this.gridster.$options.outerMargin) { return 0; } else if (isFirst && this.gridster.$options.outerMargin && this.gridster.$options.outerMarginTop !== null) { return this.gridster.$options.outerMarginTop; } else { return this.gridster.$options.margin; } }; GridsterGridComponent.prototype.getMarginLeft = function (isFirst) { if (isFirst && !this.gridster.$options.outerMargin) { return 0; } else if (isFirst && this.gridster.$options.outerMargin && this.gridster.$options.outerMarginLeft !== null) { return this.gridster.$options.outerMarginLeft; } else { return this.gridster.$options.margin; } }; return GridsterGridComponent; }()); GridsterGridComponent.decorators = [ { type: core_1.Component, args: [{ selector: 'gridster-grid', template: "<div class=\"columns\" [style.height.px]=\"columnsHeight\"> <div class=\"column\" *ngFor=\"let column of columns; let isFirst = first;\" [style.min-width.px]=\"width\" [style.margin-left.px]=\"getMarginLeft(isFirst)\"></div> </div> <div class=\"rows\" [style.width.px]=\"rowsWidth\"> <div class=\"row\" *ngFor=\"let row of rows; let isFirst = first;\" [style.height.px]=\"height\" [style.margin-top.px]=\"getMarginTop(isFirst)\"></div> </div>", styles: ["gridster-grid { display: none; position: absolute; } gridster-grid .rows, gridster-grid .columns { position: absolute; } gridster-grid .columns { display: flex; flex-direction: row; } gridster-grid .column, gridster-grid .row { transition: .3s; box-sizing: border-box; } gridster-grid .column { height: 100%; border-left: 1px solid white; border-right: 1px solid white; } gridster-grid .row { width: 100%; border-top: 1px solid white; border-bottom: 1px solid white; }"], changeDetection: core_1.ChangeDetectionStrategy.OnPush, encapsulation: core_1.ViewEncapsulation.None },] }, ]; /** @nocollapse */ GridsterGridComponent.ctorParameters = function () { return [ { type: core_1.ElementRef, }, { type: gridster_component_1.GridsterComponent, decorators: [{ type: core_1.Host },] }, { type: core_1.Renderer2, }, { type: core_1.ChangeDetectorRef, }, ]; }; exports.GridsterGridComponent = GridsterGridComponent; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../.tmp/gridsterGrid.component.ts"],"names":[],"mappings":"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","file":"gridsterGrid.component.js","sourceRoot":"","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Host,\n  OnDestroy,\n  Renderer2,\n  ViewEncapsulation\n} from '@angular/core';\n\nimport {GridsterComponent} from './gridster.component';\n\n\n\nexport class GridsterGridComponent implements OnDestroy {\n  el: any;\n  gridster: GridsterComponent;\n  columns: Array<any>;\n  rows: Array<any>;\n  height: number;\n  width: number;\n  columnsHeight: number;\n  rowsWidth: number;\n\n  constructor(el: ElementRef,  gridster: GridsterComponent, public renderer: Renderer2,\n              private cdRef: ChangeDetectorRef) {\n    this.el = el.nativeElement;\n    this.gridster = gridster;\n    this.gridster.gridLines = this;\n    this.columns = [];\n    this.rows = [];\n    this.height = 0;\n    this.width = 0;\n    this.columnsHeight = 0;\n    this.rowsWidth = 0;\n  }\n\n  ngOnDestroy(): void {\n    delete this.el;\n    delete this.gridster.gridLines;\n    delete this.gridster;\n  }\n\n  updateGrid(): void {\n    if (this.gridster.$options.displayGrid === 'always' && !this.gridster.mobile) {\n      this.renderer.setStyle(this.el, 'display', 'block');\n    } else if (this.gridster.$options.displayGrid === 'onDrag&Resize' && this.gridster.dragInProgress) {\n      this.renderer.setStyle(this.el, 'display', 'block');\n    } else if (this.gridster.$options.displayGrid === 'none' || !this.gridster.dragInProgress || this.gridster.mobile) {\n      this.renderer.setStyle(this.el, 'display', 'none');\n    }\n    this.gridster.setGridDimensions();\n    this.height = this.gridster.curRowHeight - this.gridster.$options.margin;\n    this.width = this.gridster.curColWidth - this.gridster.$options.margin;\n    this.columns.length = Math.max(this.gridster.columns, Math.floor(this.gridster.curWidth / this.gridster.curColWidth)) || 0;\n    this.rows.length = Math.max(this.gridster.rows, Math.floor(this.gridster.curHeight / this.gridster.curRowHeight)) || 0;\n    this.columnsHeight = this.gridster.curRowHeight * this.rows.length + this.getMarginTop(true) - this.gridster.$options.margin;\n    this.rowsWidth = this.gridster.curColWidth * this.columns.length + this.getMarginLeft(true) - this.gridster.$options.margin;\n    this.cdRef.markForCheck();\n  }\n\n  getMarginTop(isFirst: boolean): number {\n    if (isFirst && !this.gridster.$options.outerMargin) {\n      return 0;\n    } else if (isFirst && this.gridster.$options.outerMargin && this.gridster.$options.outerMarginTop !== null) {\n      return this.gridster.$options.outerMarginTop;\n    } else {\n      return this.gridster.$options.margin;\n    }\n  }\n\n  getMarginLeft(isFirst: boolean): number {\n    if (isFirst && !this.gridster.$options.outerMargin) {\n      return 0;\n    } else if (isFirst && this.gridster.$options.outerMargin && this.gridster.$options.outerMarginLeft !== null) {\n      return this.gridster.$options.outerMarginLeft;\n    } else {\n      return this.gridster.$options.margin;\n    }\n  }\nstatic decorators: DecoratorInvocation[] = [\n{ type: Component, args: [{\n  selector: 'gridster-grid',\n  template: `<div class=\"columns\" [style.height.px]=\"columnsHeight\">   <div class=\"column\" *ngFor=\"let column of columns; let isFirst = first;\" [style.min-width.px]=\"width\"        [style.margin-left.px]=\"getMarginLeft(isFirst)\"></div> </div> <div class=\"rows\" [style.width.px]=\"rowsWidth\">   <div class=\"row\" *ngFor=\"let row of rows; let isFirst = first;\" [style.height.px]=\"height\"        [style.margin-top.px]=\"getMarginTop(isFirst)\"></div> </div>`,\n  styles: [`gridster-grid {   display: none;   position: absolute; }  gridster-grid .rows, gridster-grid .columns {   position: absolute; }  gridster-grid .columns {   display: flex;   flex-direction: row; }  gridster-grid .column, gridster-grid .row {   transition: .3s;   box-sizing: border-box; }  gridster-grid .column {   height: 100%;   border-left: 1px solid white;   border-right: 1px solid white; }  gridster-grid .row {   width: 100%;   border-top: 1px solid white;   border-bottom: 1px solid white; }`],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None\n}, ] },\n];\n/** @nocollapse */\nstatic ctorParameters: () => ({type: any, decorators?: DecoratorInvocation[]}|null)[] = () => [\n{type: ElementRef, },\n{type: GridsterComponent, decorators: [{ type: Host }, ]},\n{type: Renderer2, },\n{type: ChangeDetectorRef, },\n];\n}\n\ninterface DecoratorInvocation {\n  type: Function;\n  args?: any[];\n}\n"]}