Skip to content

Commit

Permalink
refactor: header component
Browse files Browse the repository at this point in the history
removed unnecessary transform calculations for scrolling header along with body scroll.
  • Loading branch information
chintankavathia committed Nov 21, 2024
1 parent ab910c3 commit b35a229
Show file tree
Hide file tree
Showing 3 changed files with 23 additions and 73 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,6 @@
[sortType]="sortType"
[scrollbarH]="scrollbarH"
[innerWidth]="_innerWidth"
[offsetX]="_offsetX | async"
[dealsWithGroup]="groupedRows !== undefined"
[columns]="_internalColumns"
[headerHeight]="headerHeight"
Expand Down
10 changes: 8 additions & 2 deletions projects/ngx-datatable/src/lib/components/datatable.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -671,6 +671,9 @@ export class DatatableComponent<TRow = any>
@ViewChild(DataTableHeaderComponent)
headerComponent: DataTableHeaderComponent;

@ViewChild(DataTableHeaderComponent, { read: ElementRef })
headerElement: ElementRef<HTMLElement>;

@ViewChild(DataTableBodyComponent, { read: ElementRef })
private bodyElement: ElementRef<HTMLElement>;
@ContentChild(DatatableRowDefDirective, {
Expand Down Expand Up @@ -947,7 +950,7 @@ export class DatatableComponent<TRow = any>
this.bodyComponent.cd.markForCheck();
}

if (this.headerComponent && this.headerComponent._columnGroupWidths.total !== width) {
if (this.headerComponent && this.headerComponent._columnGroupWidths().total !== width) {
this.headerComponent.columns = [...this._internalColumns];
}

Expand Down Expand Up @@ -1012,7 +1015,10 @@ export class DatatableComponent<TRow = any>
* The body triggered a scroll event.
*/
onBodyScroll(event: ScrollEvent): void {
this._offsetX.next(event.offsetX);
// if horizontal scroll is enabled we update the header scroll position
if (this.headerElement && this.scrollbarH && !isNaN(event.offsetX)) {
this.headerElement.nativeElement.scrollLeft = event.offsetX;
}
this.scroll.emit(event);
this.cd.detectChanges();
}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,15 +1,12 @@
import {
ChangeDetectionStrategy,
ChangeDetectorRef,
Component,
EventEmitter,
HostBinding,
inject,
Input,
OnChanges,
OnDestroy,
Output,
SimpleChanges,
signal,
TemplateRef
} from '@angular/core';
import { columnGroupWidths, columnsByPin, columnsByPinArr } from '../../utils/column';
Expand All @@ -23,10 +20,10 @@ import {
SortPropDir,
SortType
} from '../../types/public.types';
import { NgStyle } from '@angular/common';
import { ScrollbarHelper } from '../../services/scrollbar-helper.service';
import { TableColumn } from '../../types/table-column.type';
import {
ColumnGroupWidth,
OrderableReorderEvent,
PinnedColumns,
TargetChangedEvent
Expand All @@ -45,11 +42,14 @@ import { OrderableDirective } from '../../directives/orderable.directive';
orderable
(reorder)="onColumnReordered($event)"
(targetChanged)="onTargetChanged($event)"
[style.width.px]="_columnGroupWidths.total"
[style.width.px]="_columnGroupWidths().total"
class="datatable-header-inner"
>
@for (colGroup of _columnsByPin; track colGroup.type) {
<div [class]="'datatable-row-' + colGroup.type" [ngStyle]="_styleByGroup[colGroup.type]">
<div
[class]="'datatable-row-' + colGroup.type"
[style.width.px]="_columnGroupWidths()[colGroup.type]"
>
@for (column of colGroup.columns; track column.$$id) {
<datatable-header-cell
role="columnheader"
Expand Down Expand Up @@ -104,8 +104,7 @@ import { OrderableDirective } from '../../directives/orderable.directive';
DraggableDirective
]
})
export class DataTableHeaderComponent implements OnDestroy, OnChanges {
private cd = inject(ChangeDetectorRef);
export class DataTableHeaderComponent {
private scrollbarHelper = inject(ScrollbarHelper);

@Input() sortAscendingIcon: string;
Expand All @@ -121,8 +120,7 @@ export class DataTableHeaderComponent implements OnDestroy, OnChanges {
setTimeout(() => {
if (this._columns) {
const colByPin = columnsByPin(this._columns);
this._columnGroupWidths = columnGroupWidths(colByPin, this._columns);
this.setStylesByGroup();
this._columnGroupWidths.set(columnGroupWidths(colByPin, this._columns));
}
});
}
Expand Down Expand Up @@ -160,24 +158,14 @@ export class DataTableHeaderComponent implements OnDestroy, OnChanges {
const colsByPin = columnsByPin(val);
this._columnsByPin = columnsByPinArr(val);
setTimeout(() => {
this._columnGroupWidths = columnGroupWidths(colsByPin, val);
this.setStylesByGroup();
this._columnGroupWidths.set(columnGroupWidths(colsByPin, val));
});
}

get columns(): any[] {
return this._columns;
}

@Input()
set offsetX(val: number) {
this._offsetX = val;
this.setStylesByGroup();
}
get offsetX() {
return this._offsetX;
}

@Output() sort: EventEmitter<SortEvent> = new EventEmitter();
@Output() reorder: EventEmitter<ReorderEvent> = new EventEmitter();
@Output() resize: EventEmitter<ColumnResizeEvent> = new EventEmitter();
Expand All @@ -186,33 +174,15 @@ export class DataTableHeaderComponent implements OnDestroy, OnChanges {
@Output() columnContextmenu = new EventEmitter<{ event: MouseEvent; column: TableColumn }>(false);

_columnsByPin: PinnedColumns[];
_columnGroupWidths: any = {
_columnGroupWidths = signal<ColumnGroupWidth>({
left: 0,
center: 0,
right: 0,
total: 100
};
});
_innerWidth: number;
_offsetX: number;
_columns: TableColumn[];
_headerHeight: string;
_styleByGroup: {
left: NgStyle['ngStyle'];
center: NgStyle['ngStyle'];
right: NgStyle['ngStyle'];
} = { left: {}, center: {}, right: {} };

private destroyed = false;

ngOnChanges(changes: SimpleChanges): void {
if (changes.verticalScrollVisible) {
this._styleByGroup.right = this.calcStylesByGroup('right');
if (!this.destroyed) {
this.cd.detectChanges();
}
}
}

ngOnDestroy(): void {
this.destroyed = true;
}

onLongPressStart({ event, model }: { event: MouseEvent; model: TableColumn }) {
model.dragging = true;
Expand Down Expand Up @@ -358,29 +328,4 @@ export class DataTableHeaderComponent implements OnDestroy, OnChanges {

return sorts;
}

setStylesByGroup() {
this._styleByGroup.left = this.calcStylesByGroup('left');
this._styleByGroup.center = this.calcStylesByGroup('center');
this._styleByGroup.right = this.calcStylesByGroup('right');
if (!this.destroyed) {
this.cd.detectChanges();
}
}

calcStylesByGroup(group: 'center' | 'right' | 'left'): NgStyle['ngStyle'] {
const widths = this._columnGroupWidths;

if (group === 'center') {
return {
transform: `translateX(${this.offsetX * -1}px)`,
width: `${widths[group]}px`,
willChange: 'transform'
};
}

return {
width: `${widths[group]}px`
};
}
}

0 comments on commit b35a229

Please sign in to comment.