UNPKG

@lightweightform/theme-common

Version:

Common utilities for Lightweightform themes

128 lines 13.6 kB
import { __decorate } from "tslib"; import { Directive } from '@angular/core'; import { makeObservable } from 'mobx'; import { computed, observable } from 'mobx-angular'; import { TableColumnDirective } from './table-column.directive'; import * as i0 from "@angular/core"; /** * Class that represents a container of columns: super class of both the table * header and of the column (which may have sub-columns as children). */ // tslint:disable-next-line: directive-class-suffix export class TableColumnContainer { constructor(parentTableColumnContainer, elementRef) { Object.defineProperty(this, "parentTableColumnContainer", { enumerable: true, configurable: true, writable: true, value: parentTableColumnContainer }); Object.defineProperty(this, "elementRef", { enumerable: true, configurable: true, writable: true, value: elementRef }); Object.defineProperty(this, "_childrenColumns", { enumerable: true, configurable: true, writable: true, value: observable.array() }); makeObservable(this); } /** * List of column controllers that are direct children of this table column * container. * @returns List of column children. */ get childrenColumns() { return this._childrenColumns.slice(); } /** * Height of a column container (height of the tree represented by the column * container as root, and its columns as children). * @returns Height of the column container. */ get height() { return (this._childrenColumns.reduce((height, column) => Math.max(height, column.height), 0) + 1); } /** * Width of a column container (width of the tree represented by the column * container as root, and its columns as children). * @returns Width of the column container. */ get width() { // Use the `colspan` of a leaf column as its width return this instanceof TableColumnDirective && this.childrenColumns.length === 0 ? this.colspan != null ? +this.colspan : 1 : this._childrenColumns.reduce((sum, column) => sum + column.width, 0); } ngOnInit() { // Register column in parent column container in same order as declared if (this.parentTableColumnContainer) { const childrenColumns = this.parentTableColumnContainer._childrenColumns; // Find the index of the column which has an index in the parent container // greater than this column and insert this column before it; if no such // column is found, insert this column at the end const indexInParentEl = this.columnIndexInParentEl(); let insertionIndex = -1; for (let i = 0, l = childrenColumns.length; i < l; ++i) { if (this.columnIndexInParentEl(childrenColumns[i]) > indexInParentEl) { insertionIndex = i; break; } } if (insertionIndex === -1) { childrenColumns.push(this); } else { childrenColumns.splice(insertionIndex, 0, this); } } } ngOnDestroy() { // Unregister column if (this.parentTableColumnContainer) { this.parentTableColumnContainer._childrenColumns.splice(this.parentTableColumnContainer._childrenColumns.indexOf(this), 1); } } /** * Index of the column's element in the parent container's element. Used to * make sure that we're inserting columns in the order declared in the HTML * file (needed when conditionally rendering columns). * @param column Column for which to get index. * @returns Index of column in parent container's element. */ columnIndexInParentEl(column = this) { return Array.from(column.parentTableColumnContainer.elementRef.nativeElement.children).indexOf(column.elementRef.nativeElement); } } Object.defineProperty(TableColumnContainer, "\u0275fac", { enumerable: true, configurable: true, writable: true, value: i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TableColumnContainer, deps: [{ token: TableColumnContainer }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }) }); Object.defineProperty(TableColumnContainer, "\u0275dir", { enumerable: true, configurable: true, writable: true, value: i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.16", type: TableColumnContainer, ngImport: i0 }) }); __decorate([ computed ], TableColumnContainer.prototype, "childrenColumns", null); __decorate([ computed ], TableColumnContainer.prototype, "height", null); __decorate([ computed ], TableColumnContainer.prototype, "width", null); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TableColumnContainer, decorators: [{ type: Directive }], ctorParameters: function () { return [{ type: TableColumnContainer }, { type: i0.ElementRef }]; }, propDecorators: { childrenColumns: [], height: [], width: [] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-column-container.js","sourceRoot":"","sources":["../../../../src/modules/table-header/table-column-container.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAiC,MAAM,eAAe,CAAC;AACzE,OAAO,EAAE,cAAc,EAAE,MAAM,MAAM,CAAC;AACtC,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAEpD,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;;AAEhE;;;GAGG;AAEH,mDAAmD;AACnD,MAAM,OAAgB,oBAAoB;IAGxC,YACY,0BAAuD,EACvD,UAAsB;;;;;mBADtB;;;;;;mBACA;;QAJZ;;;;mBAAmD,UAAU,CAAC,KAAK,EAAE;WAAC;QAMpE,cAAc,CAAC,IAAI,CAAC,CAAC;IACvB,CAAC;IAED;;;;OAIG;IAEH,IAAW,eAAe;QACxB,OAAO,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;IACvC,CAAC;IAED;;;;OAIG;IAEH,IAAc,MAAM;QAClB,OAAO,CACL,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAC1B,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,EACnD,CAAC,CACF,GAAG,CAAC,CACN,CAAC;IACJ,CAAC;IAED;;;;OAIG;IAEH,IAAc,KAAK;QACjB,kDAAkD;QAClD,OAAO,IAAI,YAAY,oBAAoB;YACzC,IAAI,CAAC,eAAe,CAAC,MAAM,KAAK,CAAC;YACjC,CAAC,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI;gBACpB,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO;gBACf,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE,CAAC,GAAG,GAAG,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;IAC3E,CAAC;IAEM,QAAQ;QACb,uEAAuE;QACvE,IAAI,IAAI,CAAC,0BAA0B,EAAE;YACnC,MAAM,eAAe,GAAG,IAAI,CAAC,0BAA0B,CAAC,gBAAgB,CAAC;YAEzE,0EAA0E;YAC1E,wEAAwE;YACxE,iDAAiD;YACjD,MAAM,eAAe,GAAG,IAAI,CAAC,qBAAqB,EAAE,CAAC;YACrD,IAAI,cAAc,GAAG,CAAC,CAAC,CAAC;YACxB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,eAAe,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE;gBACtD,IAAI,IAAI,CAAC,qBAAqB,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,GAAG,eAAe,EAAE;oBACpE,cAAc,GAAG,CAAC,CAAC;oBACnB,MAAM;iBACP;aACF;YACD,IAAI,cAAc,KAAK,CAAC,CAAC,EAAE;gBACzB,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aAC5B;iBAAM;gBACL,eAAe,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC;aACjD;SACF;IACH,CAAC;IAEM,WAAW;QAChB,oBAAoB;QACpB,IAAI,IAAI,CAAC,0BAA0B,EAAE;YACnC,IAAI,CAAC,0BAA0B,CAAC,gBAAgB,CAAC,MAAM,CACrD,IAAI,CAAC,0BAA0B,CAAC,gBAAgB,CAAC,OAAO,CAAC,IAAI,CAAC,EAC9D,CAAC,CACF,CAAC;SACH;IACH,CAAC;IAED;;;;;;OAMG;IACK,qBAAqB,CAAC,SAA+B,IAAI;QAC/D,OAAO,KAAK,CAAC,IAAI,CACf,MAAM,CAAC,0BAA4B,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ,CACtE,CAAC,OAAO,CAAC,MAAM,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;IAC7C,CAAC;;;;;;iGAhGmB,oBAAoB,kBAIA,oBAAoB;;;;;;qFAJxC,oBAAoB;;AAgBxC;IADC,QAAQ;2DAGR;AAQD;IADC,QAAQ;kDAQR;AAQD;IADC,QAAQ;iDASR;4FAjDmB,oBAAoB;kBAFzC,SAAS;0DAMgC,oBAAoB,mDAYjD,eAAe,MAUZ,MAAM,MAeN,KAAK","sourcesContent":["import { Directive, ElementRef, OnDestroy, OnInit } from '@angular/core';\nimport { makeObservable } from 'mobx';\nimport { computed, observable } from 'mobx-angular';\n\nimport { TableColumnDirective } from './table-column.directive';\n\n/**\n * Class that represents a container of columns: super class of both the table\n * header and of the column (which may have sub-columns as children).\n */\n@Directive()\n// tslint:disable-next-line: directive-class-suffix\nexport abstract class TableColumnContainer implements OnInit, OnDestroy {\n  private _childrenColumns: TableColumnContainer[] = observable.array();\n\n  constructor(\n    protected parentTableColumnContainer: TableColumnContainer | null,\n    protected elementRef: ElementRef\n  ) {\n    makeObservable(this);\n  }\n\n  /**\n   * List of column controllers that are direct children of this table column\n   * container.\n   * @returns List of column children.\n   */\n  @computed\n  public get childrenColumns(): TableColumnContainer[] {\n    return this._childrenColumns.slice();\n  }\n\n  /**\n   * Height of a column container (height of the tree represented by the column\n   * container as root, and its columns as children).\n   * @returns Height of the column container.\n   */\n  @computed\n  protected get height(): number {\n    return (\n      this._childrenColumns.reduce(\n        (height, column) => Math.max(height, column.height),\n        0\n      ) + 1\n    );\n  }\n\n  /**\n   * Width of a column container (width of the tree represented by the column\n   * container as root, and its columns as children).\n   * @returns Width of the column container.\n   */\n  @computed\n  protected get width(): number {\n    // Use the `colspan` of a leaf column as its width\n    return this instanceof TableColumnDirective &&\n      this.childrenColumns.length === 0\n      ? this.colspan != null\n        ? +this.colspan\n        : 1\n      : this._childrenColumns.reduce((sum, column) => sum + column.width, 0);\n  }\n\n  public ngOnInit(): void {\n    // Register column in parent column container in same order as declared\n    if (this.parentTableColumnContainer) {\n      const childrenColumns = this.parentTableColumnContainer._childrenColumns;\n\n      // Find the index of the column which has an index in the parent container\n      // greater than this column and insert this column before it; if no such\n      // column is found, insert this column at the end\n      const indexInParentEl = this.columnIndexInParentEl();\n      let insertionIndex = -1;\n      for (let i = 0, l = childrenColumns.length; i < l; ++i) {\n        if (this.columnIndexInParentEl(childrenColumns[i]) > indexInParentEl) {\n          insertionIndex = i;\n          break;\n        }\n      }\n      if (insertionIndex === -1) {\n        childrenColumns.push(this);\n      } else {\n        childrenColumns.splice(insertionIndex, 0, this);\n      }\n    }\n  }\n\n  public ngOnDestroy(): void {\n    // Unregister column\n    if (this.parentTableColumnContainer) {\n      this.parentTableColumnContainer._childrenColumns.splice(\n        this.parentTableColumnContainer._childrenColumns.indexOf(this),\n        1\n      );\n    }\n  }\n\n  /**\n   * Index of the column's element in the parent container's element. Used to\n   * make sure that we're inserting columns in the order declared in the HTML\n   * file (needed when conditionally rendering columns).\n   * @param column Column for which to get index.\n   * @returns Index of column in parent container's element.\n   */\n  private columnIndexInParentEl(column: TableColumnContainer = this): number {\n    return Array.from(\n      column.parentTableColumnContainer!!.elementRef.nativeElement.children\n    ).indexOf(column.elementRef.nativeElement);\n  }\n}\n"]}