@energycap/components 0.32.2 → 0.32.3-ECAP-12658-MasterDetailRow-Updates.20220930-1055

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -39,11 +39,18 @@ export class TableMasterRowComponent {
39
39
  * has no details, remove the detail row
40
40
  */
41
41
  updateDetailRow() {
42
+ console.log(this.hasDetails);
43
+ console.log(this.detailView);
42
44
  if (this.hasDetails) {
43
45
  if (!this.detailTemplate) {
44
46
  console.error(`A value for the [detailTemplate] input is required when 'hasDetails' is true.`);
45
47
  return;
46
48
  }
49
+ // First check to see if the detailView is already present and if so, remove it so we don't get a
50
+ // duplicate detail view
51
+ if (this.detailView !== undefined) {
52
+ this.removeDetailView();
53
+ }
47
54
  this.detailView = this.detailRowTemplate.createEmbeddedView({});
48
55
  this.updateVisibility();
49
56
  }
@@ -147,4 +154,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
147
154
  type: ViewChild,
148
155
  args: ['detailRow', { read: TemplateRef, static: true }]
149
156
  }] } });
150
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-master-row.component.js","sourceRoot":"","sources":["../../../../../../projects/components/src/lib/display/table/table-master-row.component.ts","../../../../../../projects/components/src/lib/display/table/table-master-row.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, TemplateRef, ViewChild, ElementRef, Renderer2, EmbeddedViewRef, SimpleChanges, OnChanges, OnDestroy, OnInit } from '@angular/core';\r\n\r\n@Component({\r\n  selector: '[ecTableMasterRow]',\r\n  templateUrl: './table-master-row.component.html',\r\n  styleUrls: ['./table-master-row.component.scss']\r\n})\r\nexport class TableMasterRowComponent implements OnChanges, OnInit, OnDestroy {\r\n  /**\r\n   * Identifier to pass to the collapsible toggle\r\n   */\r\n  @Input() public id?: string;\r\n\r\n  /**\r\n   * Controls whether the table row has details and shows the collapsible toggle if it does.\r\n   */\r\n  @Input() hasDetails?: boolean;\r\n\r\n  /**\r\n   * Programmatically toggle the visibility of the detail row. Default is false.\r\n   */\r\n  @Input() showDetails = false;\r\n\r\n  /**\r\n   * Template for the detail row content. Generates an [EmbeddedViewRef](https://angular.io/api/core/EmbeddedViewRef)\r\n   * with the 'detailContext'. Required if hasDetails is true.\r\n   */\r\n  @Input() detailTemplate!: TemplateRef<any>;\r\n\r\n  /**\r\n   * Optional context bound to the 'detailTemplate'. Available in the template as the default local template `let` declaration.\r\n   * @example\r\n   * ```html\r\n   * <tr *ngFor=\"let item of items\" ecTableMasterRow [detailTemplate]=\"myDetailTemplate\" [detailContext]=\"item\">\r\n   *  ...\r\n   * </tr>\r\n   *\r\n   * <ng-template #myDetailTemplate let-item>\r\n   *  <p>{{item.comment}}</p>\r\n   * </ng-template>\r\n   */\r\n  @Input() detailContext?: any;\r\n\r\n  /**\r\n   * The number of columns in your table minus the column that is automatically added by the\r\n   * TableMasterRowComponent. Required.\r\n   */\r\n  @Input() detailRowColSpan!: number;\r\n\r\n  /**\r\n   * Space delimited string added to the class attribute of detail row TR.\r\n   */\r\n  @Input() detailRowClass?: string;\r\n\r\n  /**\r\n   * Space delimited string added to the class attribute of the TD that contains the detail row content\r\n   */\r\n  @Input() detailRowContentClass?: string;\r\n\r\n  @Input() detailRowMaxHeight?: string;\r\n\r\n  /**\r\n   * Emits an event when the value of `showDetails` changes.\r\n   */\r\n  @Output() showDetailsChanged: EventEmitter<boolean> = new EventEmitter();\r\n\r\n  /**\r\n   * The template for the detail row, inserted in the DOM after the master row.\r\n   */\r\n  @ViewChild('detailRow', {read: TemplateRef, static: true}) detailRowTemplate!: TemplateRef<any>;\r\n\r\n  /**\r\n   * The view created from the `detailRow` template.\r\n   */\r\n  private detailView?: EmbeddedViewRef<any>;\r\n\r\n  /**\r\n   * The parent node of the host element.\r\n   */\r\n  private parentNode: any;\r\n\r\n  /**\r\n   * The sibling node of the host element.\r\n   */\r\n  private siblingNode: any;\r\n\r\n  constructor(private renderer: Renderer2, private el: ElementRef) { }\r\n\r\n  ngOnInit(): void {\r\n    if (!this.detailRowColSpan) {\r\n      console.error(`A value for [detailRowColSpan] is required to render a detail row correctly. This should be the number of columns TDs placed inside an tr[ecTableMasterRow].`);\r\n    }\r\n\r\n    this.parentNode = this.renderer.parentNode(this.el.nativeElement);\r\n    this.updateDetailRow();\r\n\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes.hasDetails && !changes.hasDetails.firstChange && changes.hasDetails.currentValue !== undefined) {\r\n      this.updateDetailRow();\r\n    }\r\n\r\n    if (changes.showDetails && !changes.showDetails.firstChange && changes.showDetails.currentValue !== undefined) {\r\n      this.updateVisibility();\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.removeDetailView();\r\n  }\r\n\r\n  /**\r\n   * When the master row has details, create the detail row and update it's visibility. If the master\r\n   * has no details, remove the detail row\r\n   */\r\n  updateDetailRow(): void {\r\n    if (this.hasDetails) {\r\n      if (!this.detailTemplate) {\r\n        console.error(`A value for the [detailTemplate] input is required when 'hasDetails' is true.`);\r\n        return;\r\n      }\r\n\r\n      this.detailView = this.detailRowTemplate.createEmbeddedView({});\r\n      this.updateVisibility();\r\n    } else {\r\n      this.removeDetailView();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Show/hide the detail row\r\n   */\r\n  toggleDetails(show: boolean): void {\r\n    this.showDetails = show;\r\n    this.showDetailsChanged.emit(show);\r\n    this.updateVisibility();\r\n  }\r\n\r\n  private updateVisibility(): void {\r\n    if (this.showDetails) {\r\n      this.show();\r\n    } else {\r\n      this.hide();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Attach the detailView the change detection tree and insert the generated html\r\n   * of the detail row to DOM after the host element\r\n   */\r\n  private show() {\r\n    if (this.detailView) {\r\n      //The nextSibling may have changed, so update it. (This could happen if the table is embedded in a searchable table\r\n      //  and a search is performed)\r\n      this.siblingNode = this.renderer.nextSibling(this.el.nativeElement);\r\n      this.detailView.reattach();\r\n      this.detailView.detectChanges();\r\n      this.detailView.rootNodes.forEach(node => {\r\n        this.renderer.insertBefore(this.parentNode, node, this.siblingNode);\r\n      });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Detach the detailView from the change detection tree and remove the generated\r\n   * html of the detail row from the DOM\r\n   */\r\n  private hide() {\r\n    if (this.detailView) {\r\n      this.detailView.detach();\r\n      this.removeDetailNodes();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Destroy the detailView and remove the generated html of the detail row from the DOM\r\n   */\r\n  private removeDetailView() {\r\n    if (this.detailView) {\r\n      this.detailView.destroy();\r\n      this.removeDetailNodes();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Remove the generated html of the detail row from the DOM\r\n   */\r\n  private removeDetailNodes() {\r\n    if (this.detailView) {\r\n      this.detailView.rootNodes.forEach(n => {\r\n        try {\r\n          this.renderer.removeChild(this.parentNode, n);\r\n        } catch(err) {\r\n          // Ignore errors thrown by removing nodes that were never added to the DOM.\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n}\r\n","<td>\r\n  <ec-collapsible-toggle *ngIf=\"hasDetails\"\r\n                         id=\"{{id}}_toggle\"\r\n                         [expanded]=\"showDetails\"\r\n                         (expandedChange)=\"toggleDetails($event)\"></ec-collapsible-toggle>\r\n</td>\r\n<ng-content></ng-content>\r\n\r\n<ng-template #detailRow>\r\n  <tr ecTableDetailRow class=\"{{detailRowClass}}\" [contentClass]=\"detailRowContentClass\" [contentColSpan]=\"detailRowColSpan\" [maxHeight]=\"detailRowMaxHeight\">\r\n      <ng-container *ngTemplateOutlet=\"detailTemplate; context: {$implicit: detailContext}\"></ng-container>\r\n  </tr>\r\n</ng-template>"]}
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-master-row.component.js","sourceRoot":"","sources":["../../../../../../projects/components/src/lib/display/table/table-master-row.component.ts","../../../../../../projects/components/src/lib/display/table/table-master-row.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, TemplateRef, ViewChild, ElementRef, Renderer2, EmbeddedViewRef, SimpleChanges, OnChanges, OnDestroy, OnInit } from '@angular/core';\r\n\r\n@Component({\r\n  selector: '[ecTableMasterRow]',\r\n  templateUrl: './table-master-row.component.html',\r\n  styleUrls: ['./table-master-row.component.scss']\r\n})\r\nexport class TableMasterRowComponent implements OnChanges, OnInit, OnDestroy {\r\n  /**\r\n   * Identifier to pass to the collapsible toggle\r\n   */\r\n  @Input() public id?: string;\r\n\r\n  /**\r\n   * Controls whether the table row has details and shows the collapsible toggle if it does.\r\n   */\r\n  @Input() hasDetails?: boolean;\r\n\r\n  /**\r\n   * Programmatically toggle the visibility of the detail row. Default is false.\r\n   */\r\n  @Input() showDetails = false;\r\n\r\n  /**\r\n   * Template for the detail row content. Generates an [EmbeddedViewRef](https://angular.io/api/core/EmbeddedViewRef)\r\n   * with the 'detailContext'. Required if hasDetails is true.\r\n   */\r\n  @Input() detailTemplate!: TemplateRef<any>;\r\n\r\n  /**\r\n   * Optional context bound to the 'detailTemplate'. Available in the template as the default local template `let` declaration.\r\n   * @example\r\n   * ```html\r\n   * <tr *ngFor=\"let item of items\" ecTableMasterRow [detailTemplate]=\"myDetailTemplate\" [detailContext]=\"item\">\r\n   *  ...\r\n   * </tr>\r\n   *\r\n   * <ng-template #myDetailTemplate let-item>\r\n   *  <p>{{item.comment}}</p>\r\n   * </ng-template>\r\n   */\r\n  @Input() detailContext?: any;\r\n\r\n  /**\r\n   * The number of columns in your table minus the column that is automatically added by the\r\n   * TableMasterRowComponent. Required.\r\n   */\r\n  @Input() detailRowColSpan!: number;\r\n\r\n  /**\r\n   * Space delimited string added to the class attribute of detail row TR.\r\n   */\r\n  @Input() detailRowClass?: string;\r\n\r\n  /**\r\n   * Space delimited string added to the class attribute of the TD that contains the detail row content\r\n   */\r\n  @Input() detailRowContentClass?: string;\r\n\r\n  @Input() detailRowMaxHeight?: string;\r\n\r\n  /**\r\n   * Emits an event when the value of `showDetails` changes.\r\n   */\r\n  @Output() showDetailsChanged: EventEmitter<boolean> = new EventEmitter();\r\n\r\n  /**\r\n   * The template for the detail row, inserted in the DOM after the master row.\r\n   */\r\n  @ViewChild('detailRow', {read: TemplateRef, static: true}) detailRowTemplate!: TemplateRef<any>;\r\n\r\n  /**\r\n   * The view created from the `detailRow` template.\r\n   */\r\n  private detailView?: EmbeddedViewRef<any>;\r\n\r\n  /**\r\n   * The parent node of the host element.\r\n   */\r\n  private parentNode: any;\r\n\r\n  /**\r\n   * The sibling node of the host element.\r\n   */\r\n  private siblingNode: any;\r\n\r\n  constructor(private renderer: Renderer2, private el: ElementRef) { }\r\n\r\n  ngOnInit(): void {\r\n    if (!this.detailRowColSpan) {\r\n      console.error(`A value for [detailRowColSpan] is required to render a detail row correctly. This should be the number of columns TDs placed inside an tr[ecTableMasterRow].`);\r\n    }\r\n\r\n    this.parentNode = this.renderer.parentNode(this.el.nativeElement);\r\n    this.updateDetailRow();\r\n\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes.hasDetails && !changes.hasDetails.firstChange && changes.hasDetails.currentValue !== undefined) {\r\n      this.updateDetailRow();\r\n    }\r\n\r\n    if (changes.showDetails && !changes.showDetails.firstChange && changes.showDetails.currentValue !== undefined) {\r\n      this.updateVisibility();\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.removeDetailView();\r\n  }\r\n\r\n  /**\r\n   * When the master row has details, create the detail row and update it's visibility. If the master\r\n   * has no details, remove the detail row\r\n   */\r\n  updateDetailRow(): void {\r\n    console.log(this.hasDetails);\r\n    console.log(this.detailView);\r\n\r\n    if (this.hasDetails) {\r\n      if (!this.detailTemplate) {\r\n        console.error(`A value for the [detailTemplate] input is required when 'hasDetails' is true.`);\r\n        return;\r\n      }\r\n\r\n      // First check to see if the detailView is already present and if so, remove it so we don't get a \r\n      // duplicate detail view\r\n      if (this.detailView !== undefined) {\r\n        this.removeDetailView();\r\n      }\r\n\r\n      this.detailView = this.detailRowTemplate.createEmbeddedView({});\r\n      this.updateVisibility();\r\n    } else {\r\n      this.removeDetailView();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Show/hide the detail row\r\n   */\r\n  toggleDetails(show: boolean): void {\r\n    this.showDetails = show;\r\n    this.showDetailsChanged.emit(show);\r\n    this.updateVisibility();\r\n  }\r\n\r\n  private updateVisibility(): void {\r\n    if (this.showDetails) {\r\n      this.show();\r\n    } else {\r\n      this.hide();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Attach the detailView the change detection tree and insert the generated html\r\n   * of the detail row to DOM after the host element\r\n   */\r\n  private show() {\r\n    if (this.detailView) {\r\n      //The nextSibling may have changed, so update it. (This could happen if the table is embedded in a searchable table\r\n      //  and a search is performed)\r\n      this.siblingNode = this.renderer.nextSibling(this.el.nativeElement);\r\n      this.detailView.reattach();\r\n      this.detailView.detectChanges();\r\n      this.detailView.rootNodes.forEach(node => {\r\n        this.renderer.insertBefore(this.parentNode, node, this.siblingNode);\r\n      });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Detach the detailView from the change detection tree and remove the generated\r\n   * html of the detail row from the DOM\r\n   */\r\n  private hide() {\r\n    if (this.detailView) {\r\n      this.detailView.detach();\r\n      this.removeDetailNodes();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Destroy the detailView and remove the generated html of the detail row from the DOM\r\n   */\r\n  private removeDetailView() {\r\n    if (this.detailView) {\r\n      this.detailView.destroy();\r\n      this.removeDetailNodes();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Remove the generated html of the detail row from the DOM\r\n   */\r\n  private removeDetailNodes() {\r\n    if (this.detailView) {\r\n      this.detailView.rootNodes.forEach(n => {\r\n        try {\r\n          this.renderer.removeChild(this.parentNode, n);\r\n        } catch(err) {\r\n          // Ignore errors thrown by removing nodes that were never added to the DOM.\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n}\r\n","<td>\r\n  <ec-collapsible-toggle *ngIf=\"hasDetails\"\r\n                         id=\"{{id}}_toggle\"\r\n                         [expanded]=\"showDetails\"\r\n                         (expandedChange)=\"toggleDetails($event)\"></ec-collapsible-toggle>\r\n</td>\r\n<ng-content></ng-content>\r\n\r\n<ng-template #detailRow>\r\n  <tr ecTableDetailRow class=\"{{detailRowClass}}\" [contentClass]=\"detailRowContentClass\" [contentColSpan]=\"detailRowColSpan\" [maxHeight]=\"detailRowMaxHeight\">\r\n      <ng-container *ngTemplateOutlet=\"detailTemplate; context: {$implicit: detailContext}\"></ng-container>\r\n  </tr>\r\n</ng-template>"]}
@@ -6385,11 +6385,18 @@ class TableMasterRowComponent {
6385
6385
  * has no details, remove the detail row
6386
6386
  */
6387
6387
  updateDetailRow() {
6388
+ console.log(this.hasDetails);
6389
+ console.log(this.detailView);
6388
6390
  if (this.hasDetails) {
6389
6391
  if (!this.detailTemplate) {
6390
6392
  console.error(`A value for the [detailTemplate] input is required when 'hasDetails' is true.`);
6391
6393
  return;
6392
6394
  }
6395
+ // First check to see if the detailView is already present and if so, remove it so we don't get a
6396
+ // duplicate detail view
6397
+ if (this.detailView !== undefined) {
6398
+ this.removeDetailView();
6399
+ }
6393
6400
  this.detailView = this.detailRowTemplate.createEmbeddedView({});
6394
6401
  this.updateVisibility();
6395
6402
  }