@siemens/ngx-datatable
Version:
ngx-datatable is an Angular table grid component for presenting large and complex data.
225 lines • 24.3 kB
JavaScript
import { ChangeDetectionStrategy, Component, EventEmitter, HostListener, inject, Input, Output, ViewChild } from '@angular/core';
import { BehaviorSubject } from 'rxjs';
import { DatatableComponentToken } from '../../utils/table-token';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
export class DataTableRowWrapperComponent {
set rowIndex(val) {
this._rowIndex = val;
this.rowContext.rowIndex = val;
this.groupContext.rowIndex = val;
this.cd.markForCheck();
}
get rowIndex() {
return this._rowIndex;
}
set expanded(val) {
this._expanded = val;
this.groupContext.expanded = val;
this.rowContext.expanded = val;
this.cd.markForCheck();
}
get expanded() {
return this._expanded;
}
constructor(cd, differs, iterableDiffers) {
this.cd = cd;
this.differs = differs;
this.iterableDiffers = iterableDiffers;
this.rowContextmenu = new EventEmitter(false);
this.selectedGroupRows = [];
this._expanded = false;
this.tableComponent = inject(DatatableComponentToken);
this.groupContext = {
group: this.row,
expanded: this.expanded,
rowIndex: this.rowIndex
};
this.rowContext = {
row: this.row,
expanded: this.expanded,
rowIndex: this.rowIndex
};
this.rowDiffer = differs.find({}).create();
this.selectedRowsDiffer = this.iterableDiffers.find(this.selected ?? []).create();
}
ngOnInit() {
if (this.disableCheck) {
const isRowDisabled = this.disableCheck(this.row);
this.disable$ = new BehaviorSubject(isRowDisabled);
}
this.rowContext.disableRow$ = this.disable$;
}
ngDoCheck() {
if (this.disableCheck) {
const isRowDisabled = this.disableCheck(this.row);
this.disable$.next(isRowDisabled);
this.cd.markForCheck();
}
if (this.rowDiffer.diff(this.row)) {
this.rowContext.row = this.row;
this.groupContext.group = this.row;
this.cd.markForCheck();
}
// When groupheader is used with chechbox we use iterableDiffer
// on currently selected rows to check if it is modified
// if any of the row of this group is not present in `selected` rows array
// mark group header checkbox state as indeterminate
if (this.groupHeader?.checkboxable && this.selectedRowsDiffer.diff(this.selected)) {
const selectedRows = this.selected.filter(row => this.row.value.find(item => item === row));
if (this.checkBoxInput) {
if (selectedRows.length && selectedRows.length !== this.row.value.length) {
this.checkBoxInput.nativeElement.indeterminate = true;
}
else {
this.checkBoxInput.nativeElement.indeterminate = false;
}
}
this.selectedGroupRows = selectedRows;
}
}
onContextmenu($event) {
this.rowContextmenu.emit({ event: $event, row: this.row });
}
getGroupHeaderStyle() {
const styles = {};
styles.transform = 'translate3d(' + this.offsetX + 'px, 0px, 0px)';
styles['backface-visibility'] = 'hidden';
styles.width = this.innerWidth + 'px';
return styles;
}
onCheckboxChange(groupSelected) {
// First remove all rows of this group from `selected`
this.selected = [...this.selected.filter(row => !this.row.value.find(item => item === row))];
// If checkbox is checked then add all rows of this group in `selected`
if (groupSelected) {
this.selected = [...this.selected, ...this.row.value];
}
// Update `selected` of DatatableComponent with newly evaluated `selected`
this.tableComponent.selected = [...this.selected];
// Emit select event with updated values
this.tableComponent.onBodySelect({
selected: this.selected
});
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.6", ngImport: i0, type: DataTableRowWrapperComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.KeyValueDiffers }, { token: i0.IterableDiffers }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.6", type: DataTableRowWrapperComponent, selector: "datatable-row-wrapper", inputs: { innerWidth: "innerWidth", rowDetail: "rowDetail", groupHeader: "groupHeader", offsetX: "offsetX", detailRowHeight: "detailRowHeight", groupHeaderRowHeight: "groupHeaderRowHeight", row: "row", groupedRows: "groupedRows", disableCheck: "disableCheck", selected: "selected", rowIndex: "rowIndex", expanded: "expanded" }, outputs: { rowContextmenu: "rowContextmenu" }, host: { listeners: { "contextmenu": "onContextmenu($event)" }, classAttribute: "datatable-row-wrapper" }, viewQueries: [{ propertyName: "checkBoxInput", first: true, predicate: ["select"], descendants: true }], ngImport: i0, template: `
<div
*ngIf="groupHeader && groupHeader.template"
[style.height.px]="groupHeaderRowHeight"
class="datatable-group-header"
[ngStyle]="getGroupHeaderStyle()"
>
<div class="datatable-group-cell">
<div *ngIf="groupHeader.checkboxable">
<label
class="datatable-checkbox"
>
<input #select type="checkbox" [checked]="selectedGroupRows.length === row.value.length" (change)="onCheckboxChange(select.checked)" />
</label>
</div>
<ng-template
*ngIf="groupHeader && groupHeader.template"
[ngTemplateOutlet]="groupHeader.template"
[ngTemplateOutletContext]="groupContext"
>
</ng-template>
</div>
</div>
<ng-content *ngIf="(groupHeader && groupHeader.template && expanded) || !groupHeader || !groupHeader.template">
</ng-content>
<div
*ngIf="rowDetail && rowDetail.template && expanded"
[style.height.px]="detailRowHeight"
class="datatable-row-detail"
>
<ng-template
*ngIf="rowDetail && rowDetail.template"
[ngTemplateOutlet]="rowDetail.template"
[ngTemplateOutletContext]="rowContext"
>
</ng-template>
</div>
`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.6", ngImport: i0, type: DataTableRowWrapperComponent, decorators: [{
type: Component,
args: [{
selector: 'datatable-row-wrapper',
changeDetection: ChangeDetectionStrategy.OnPush,
template: `
<div
*ngIf="groupHeader && groupHeader.template"
[style.height.px]="groupHeaderRowHeight"
class="datatable-group-header"
[ngStyle]="getGroupHeaderStyle()"
>
<div class="datatable-group-cell">
<div *ngIf="groupHeader.checkboxable">
<label
class="datatable-checkbox"
>
<input #select type="checkbox" [checked]="selectedGroupRows.length === row.value.length" (change)="onCheckboxChange(select.checked)" />
</label>
</div>
<ng-template
*ngIf="groupHeader && groupHeader.template"
[ngTemplateOutlet]="groupHeader.template"
[ngTemplateOutletContext]="groupContext"
>
</ng-template>
</div>
</div>
<ng-content *ngIf="(groupHeader && groupHeader.template && expanded) || !groupHeader || !groupHeader.template">
</ng-content>
<div
*ngIf="rowDetail && rowDetail.template && expanded"
[style.height.px]="detailRowHeight"
class="datatable-row-detail"
>
<ng-template
*ngIf="rowDetail && rowDetail.template"
[ngTemplateOutlet]="rowDetail.template"
[ngTemplateOutletContext]="rowContext"
>
</ng-template>
</div>
`,
host: {
class: 'datatable-row-wrapper'
}
}]
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i0.KeyValueDiffers }, { type: i0.IterableDiffers }], propDecorators: { checkBoxInput: [{
type: ViewChild,
args: ['select']
}], innerWidth: [{
type: Input
}], rowDetail: [{
type: Input
}], groupHeader: [{
type: Input
}], offsetX: [{
type: Input
}], detailRowHeight: [{
type: Input
}], groupHeaderRowHeight: [{
type: Input
}], row: [{
type: Input
}], groupedRows: [{
type: Input
}], disableCheck: [{
type: Input
}], selected: [{
type: Input
}], rowContextmenu: [{
type: Output
}], rowIndex: [{
type: Input
}], expanded: [{
type: Input
}], onContextmenu: [{
type: HostListener,
args: ['contextmenu', ['$event']]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"body-row-wrapper.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-datatable/src/lib/components/body/body-row-wrapper.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  inject,\n  Input,\n  IterableDiffer,\n  IterableDiffers,\n  KeyValueDiffer,\n  KeyValueDiffers,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport { BehaviorSubject } from 'rxjs';\nimport { DatatableComponentToken } from '../../utils/table-token';\n\n@Component({\n  selector: 'datatable-row-wrapper',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  template: `\n    <div\n      *ngIf=\"groupHeader && groupHeader.template\"\n      [style.height.px]=\"groupHeaderRowHeight\"\n      class=\"datatable-group-header\"\n      [ngStyle]=\"getGroupHeaderStyle()\"\n    >\n      <div class=\"datatable-group-cell\">\n        <div *ngIf=\"groupHeader.checkboxable\">\n          <label\n            class=\"datatable-checkbox\"\n          >\n            <input #select type=\"checkbox\" [checked]=\"selectedGroupRows.length === row.value.length\" (change)=\"onCheckboxChange(select.checked)\" />\n          </label>\n        </div>\n        <ng-template\n          *ngIf=\"groupHeader && groupHeader.template\"\n          [ngTemplateOutlet]=\"groupHeader.template\"\n          [ngTemplateOutletContext]=\"groupContext\"\n        >\n        </ng-template>\n      </div>\n    </div>\n    <ng-content *ngIf=\"(groupHeader && groupHeader.template && expanded) || !groupHeader || !groupHeader.template\">\n    </ng-content>\n    <div\n      *ngIf=\"rowDetail && rowDetail.template && expanded\"\n      [style.height.px]=\"detailRowHeight\"\n      class=\"datatable-row-detail\"\n    >\n      <ng-template\n        *ngIf=\"rowDetail && rowDetail.template\"\n        [ngTemplateOutlet]=\"rowDetail.template\"\n        [ngTemplateOutletContext]=\"rowContext\"\n      >\n      </ng-template>\n    </div>\n  `,\n  host: {\n    class: 'datatable-row-wrapper'\n  }\n})\nexport class DataTableRowWrapperComponent implements DoCheck, OnInit {\n  @ViewChild('select') checkBoxInput!: ElementRef<HTMLInputElement>;\n  @Input() innerWidth: number;\n  @Input() rowDetail: any;\n  @Input() groupHeader: any;\n  @Input() offsetX: number;\n  @Input() detailRowHeight: any;\n  @Input() groupHeaderRowHeight: number;\n  @Input() row: any;\n  @Input() groupedRows: any;\n  @Input() disableCheck: (row: any) => boolean;\n  @Input() selected: any[];\n  @Output() rowContextmenu = new EventEmitter<{ event: MouseEvent; row: any }>(false);\n\n  @Input() set rowIndex(val: number) {\n    this._rowIndex = val;\n    this.rowContext.rowIndex = val;\n    this.groupContext.rowIndex = val;\n    this.cd.markForCheck();\n  }\n\n  get rowIndex(): number {\n    return this._rowIndex;\n  }\n\n  selectedGroupRows = [];\n\n  @Input() set expanded(val: boolean) {\n    this._expanded = val;\n    this.groupContext.expanded = val;\n    this.rowContext.expanded = val;\n    this.cd.markForCheck();\n  }\n\n  get expanded(): boolean {\n    return this._expanded;\n  }\n\n  groupContext: any;\n  rowContext: any;\n  disable$: BehaviorSubject<boolean>;\n\n\n  private rowDiffer: KeyValueDiffer<unknown, unknown>;\n  private selectedRowsDiffer: IterableDiffer<unknown[]>;\n  private _expanded = false;\n  private _rowIndex: number;\n  private tableComponent = inject(DatatableComponentToken);\n\n  constructor(private cd: ChangeDetectorRef, private differs: KeyValueDiffers, private iterableDiffers: IterableDiffers) {\n    this.groupContext = {\n      group: this.row,\n      expanded: this.expanded,\n      rowIndex: this.rowIndex\n    };\n\n    this.rowContext = {\n      row: this.row,\n      expanded: this.expanded,\n      rowIndex: this.rowIndex\n    };\n\n    this.rowDiffer = differs.find({}).create();\n    this.selectedRowsDiffer = this.iterableDiffers.find(this.selected ?? []).create();\n  }\n\n  ngOnInit(): void {\n    if (this.disableCheck) {\n      const isRowDisabled = this.disableCheck(this.row);\n      this.disable$ = new BehaviorSubject(isRowDisabled);\n    }\n    this.rowContext.disableRow$ = this.disable$;\n  }\n\n  ngDoCheck(): void {\n    if (this.disableCheck) {\n      const isRowDisabled = this.disableCheck(this.row);\n      this.disable$.next(isRowDisabled);\n      this.cd.markForCheck();\n    }\n    if (this.rowDiffer.diff(this.row)) {\n      this.rowContext.row = this.row;\n      this.groupContext.group = this.row;\n      this.cd.markForCheck();\n    }\n    // When groupheader is used with chechbox we use iterableDiffer\n    // on currently selected rows to check if it is modified\n    // if any of the row of this group is not present in `selected` rows array\n    // mark group header checkbox state as indeterminate\n    if (this.groupHeader?.checkboxable && this.selectedRowsDiffer.diff(this.selected)) {\n      const selectedRows = this.selected.filter(row => this.row.value.find(item => item === row));\n      if (this.checkBoxInput) {\n        if (selectedRows.length && selectedRows.length !== this.row.value.length) {\n          this.checkBoxInput.nativeElement.indeterminate = true;\n        } else {\n          this.checkBoxInput.nativeElement.indeterminate = false;\n        }\n      }\n      this.selectedGroupRows = selectedRows;\n    }\n  }\n\n  @HostListener('contextmenu', ['$event'])\n  onContextmenu($event: MouseEvent): void {\n    this.rowContextmenu.emit({ event: $event, row: this.row });\n  }\n\n  getGroupHeaderStyle(): any {\n    const styles = {} as any;\n\n    styles.transform = 'translate3d(' + this.offsetX + 'px, 0px, 0px)';\n    styles['backface-visibility'] = 'hidden';\n    styles.width = this.innerWidth + 'px';\n    return styles;\n  }\n\n  onCheckboxChange(groupSelected: boolean): void {\n    // First remove all rows of this group from `selected`\n    this.selected = [...this.selected.filter(row => !this.row.value.find(item => item === row))];\n    // If checkbox is checked then add all rows of this group in `selected`\n    if (groupSelected) {\n      this.selected = [...this.selected, ...this.row.value];\n    }\n    // Update `selected` of DatatableComponent with newly evaluated `selected`\n    this.tableComponent.selected = [...this.selected];\n    // Emit select event with updated values\n    this.tableComponent.onBodySelect({\n      selected: this.selected\n    });\n  }\n}\n"]}