Skip to content

Commit

Permalink
chore: zoneless working (#917)
Browse files Browse the repository at this point in the history
Co-authored-by: banned007 <[email protected]>
  • Loading branch information
tiberiuzuld and banned007 authored Jun 17, 2024
1 parent f82c37c commit b1b2d3d
Show file tree
Hide file tree
Showing 8 changed files with 84 additions and 134 deletions.
11 changes: 0 additions & 11 deletions angular.json
Original file line number Diff line number Diff line change
Expand Up @@ -19,9 +19,6 @@
"options": {
"outputPath": "dist/demo",
"index": "src/index.html",
"polyfills": [
"zone.js"
],
"tsConfig": "tsconfig.app.json",
"assets": [
"src/assets"
Expand Down Expand Up @@ -78,10 +75,6 @@
"test": {
"builder": "@angular-devkit/build-angular:karma",
"options": {
"polyfills": [
"zone.js",
"zone.js/testing"
],
"tsConfig": "tsconfig.spec.json",
"assets": [
"src/assets"
Expand Down Expand Up @@ -141,10 +134,6 @@
"builder": "@angular-devkit/build-angular:karma",
"options": {
"tsConfig": "projects/angular-gridster2/tsconfig.spec.json",
"polyfills": [
"zone.js",
"zone.js/testing"
]
}
},
"lint": {
Expand Down
4 changes: 1 addition & 3 deletions projects/angular-gridster2/src/lib/gridster.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@ import {
EventEmitter,
Inject,
Input,
NgZone,
OnChanges,
OnDestroy,
OnInit,
Expand Down Expand Up @@ -72,8 +71,7 @@ export class GridsterComponent
constructor(
@Inject(ElementRef) el: ElementRef,
@Inject(Renderer2) public renderer: Renderer2,
@Inject(ChangeDetectorRef) public cdRef: ChangeDetectorRef,
@Inject(NgZone) public zone: NgZone
@Inject(ChangeDetectorRef) public cdRef: ChangeDetectorRef
) {
this.el = el.nativeElement;
this.$options = JSON.parse(JSON.stringify(GridsterConfigService));
Expand Down
3 changes: 1 addition & 2 deletions projects/angular-gridster2/src/lib/gridster.interface.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { GridsterConfigS } from './gridsterConfigS.interface';
import { ChangeDetectorRef, NgZone, Renderer2 } from '@angular/core';
import { ChangeDetectorRef, Renderer2 } from '@angular/core';
import { Subject } from 'rxjs';
import { GridsterEmptyCell } from './gridsterEmptyCell.service';
import { GridsterCompact } from './gridsterCompact.service';
Expand Down Expand Up @@ -63,7 +63,6 @@ export abstract class GridsterComponentInterface {
dragInProgress: boolean;
emptyCell: GridsterEmptyCell;
compact: GridsterCompact;
zone: NgZone;
gridRows: Array<number>;
gridColumns: Array<number>;
}
36 changes: 18 additions & 18 deletions projects/angular-gridster2/src/lib/gridsterDraggable.service.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { NgZone } from '@angular/core';
import { ChangeDetectorRef } from '@angular/core';
import { GridsterComponentInterface } from './gridster.interface';
import { DirTypes } from './gridsterConfig.interface';
import { GridsterItemComponentInterface } from './gridsterItem.interface';
Expand All @@ -20,6 +20,7 @@ enum Direction {
export class GridsterDraggable {
gridsterItem: GridsterItemComponentInterface;
gridster: GridsterComponentInterface;
cdRef: ChangeDetectorRef;
lastMouse: {
clientX: number;
clientY: number;
Expand Down Expand Up @@ -61,10 +62,11 @@ export class GridsterDraggable {
constructor(
gridsterItem: GridsterItemComponentInterface,
gridster: GridsterComponentInterface,
private zone: NgZone
cdRef: ChangeDetectorRef
) {
this.gridsterItem = gridsterItem;
this.gridster = gridster;
this.cdRef = cdRef;
this.lastMouse = {
clientX: 0,
clientY: 0
Expand Down Expand Up @@ -102,18 +104,16 @@ export class GridsterDraggable {
e.stopPropagation();
e.preventDefault();

this.zone.runOutsideAngular(() => {
this.mousemove = this.gridsterItem.renderer.listen(
'document',
'mousemove',
this.dragMove
);
this.touchmove = this.gridster.renderer.listen(
this.gridster.el,
'touchmove',
this.dragMove
);
});
this.mousemove = this.gridsterItem.renderer.listen(
'document',
'mousemove',
this.dragMove
);
this.touchmove = this.gridster.renderer.listen(
this.gridster.el,
'touchmove',
this.dragMove
);
this.mouseup = this.gridsterItem.renderer.listen(
'document',
'mouseup',
Expand Down Expand Up @@ -231,7 +231,7 @@ export class GridsterDraggable {
if (
directions.includes(Direction.DOWN) &&
this.gridsterItem.el.getBoundingClientRect().bottom >
this.gridster.el.getBoundingClientRect().bottom -
this.gridster.el.getBoundingClientRect().bottom -
(this.outerMarginBottom ?? this.margin)
) {
directions = directions.filter(
Expand Down Expand Up @@ -273,9 +273,7 @@ export class GridsterDraggable {
this.calculateItemPosition();
this.lastMouse.clientX = e.clientX;
this.lastMouse.clientY = e.clientY;
this.zone.run(() => {
this.gridster.updateGrid();
});
this.gridster.updateGrid();
};

calculateItemPositionWithScale(e: MouseEvent, scale: number): void {
Expand Down Expand Up @@ -346,6 +344,7 @@ export class GridsterDraggable {
if (this.gridster) {
this.gridster.movingItem = null;
this.gridster.previewStyle(true);
this.cdRef.markForCheck();
}
});
};
Expand Down Expand Up @@ -509,6 +508,7 @@ export class GridsterDraggable {
const timeout = setTimeout(() => {
this.dragStart(e);
cancelDrag();
this.cdRef.markForCheck();
}, this.gridster.$options.draggable.delayStart);
const cancelMouse = this.gridsterItem.renderer.listen(
'document',
Expand Down
34 changes: 15 additions & 19 deletions projects/angular-gridster2/src/lib/gridsterEmptyCell.service.ts
Original file line number Diff line number Diff line change
Expand Up @@ -84,13 +84,11 @@ export class GridsterEmptyCell {
'drop',
this.emptyCellDragDrop
);
this.gridster.zone.runOutsideAngular(() => {
this.removeEmptyCellDragoverListenerFn = this.gridster.renderer.listen(
this.gridster.el,
'dragover',
this.emptyCellDragOver
);
});
this.removeEmptyCellDragoverListenerFn = this.gridster.renderer.listen(
this.gridster.el,
'dragover',
this.emptyCellDragOver
);
this.removeDocumentDragendListenerFn = this.gridster.renderer.listen(
'document',
'dragend',
Expand Down Expand Up @@ -224,18 +222,16 @@ export class GridsterEmptyCell {
this.initialItem = item;
this.gridster.movingItem = item;
this.gridster.previewStyle();
this.gridster.zone.runOutsideAngular(() => {
this.removeWindowMousemoveListenerFn = this.gridster.renderer.listen(
'window',
'mousemove',
this.emptyCellMouseMove
);
this.removeWindowTouchmoveListenerFn = this.gridster.renderer.listen(
'window',
'touchmove',
this.emptyCellMouseMove
);
});
this.removeWindowMousemoveListenerFn = this.gridster.renderer.listen(
'window',
'mousemove',
this.emptyCellMouseMove
);
this.removeWindowTouchmoveListenerFn = this.gridster.renderer.listen(
'window',
'touchmove',
this.emptyCellMouseMove
);
this.removeWindowMouseupListenerFn = this.gridster.renderer.listen(
'window',
'mouseup',
Expand Down
8 changes: 4 additions & 4 deletions projects/angular-gridster2/src/lib/gridsterItem.component.ts
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
import {
ChangeDetectorRef,
Component,
ElementRef,
EventEmitter,
HostBinding,
Inject,
Input,
NgZone,
OnChanges,
OnDestroy,
OnInit,
Expand Down Expand Up @@ -68,7 +68,7 @@ export class GridsterItemComponent
@Inject(ElementRef) el: ElementRef,
gridster: GridsterComponent,
@Inject(Renderer2) public renderer: Renderer2,
@Inject(NgZone) private zone: NgZone
@Inject(ChangeDetectorRef) public cdRef: ChangeDetectorRef
) {
this.el = el.nativeElement;
this.$item = {
Expand All @@ -78,8 +78,8 @@ export class GridsterItemComponent
y: -1
};
this.gridster = gridster;
this.drag = new GridsterDraggable(this, gridster, this.zone);
this.resize = new GridsterResizable(this, gridster, this.zone);
this.drag = new GridsterDraggable(this, gridster, this.cdRef);
this.resize = new GridsterResizable(this, gridster);
}

ngOnInit(): void {
Expand Down
117 changes: 43 additions & 74 deletions projects/angular-gridster2/src/lib/gridsterResizable.service.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
import { NgZone } from '@angular/core';
import { GridsterComponentInterface } from './gridster.interface';
import { DirTypes } from './gridsterConfig.interface';
import { GridsterItemComponentInterface } from './gridsterItem.interface';
Expand Down Expand Up @@ -73,8 +72,7 @@ export class GridsterResizable {

constructor(
gridsterItem: GridsterItemComponentInterface,
gridster: GridsterComponentInterface,
private zone: NgZone
gridster: GridsterComponentInterface
) {
this.gridsterItem = gridsterItem;
this.gridster = gridster;
Expand Down Expand Up @@ -113,18 +111,16 @@ export class GridsterResizable {
e.stopPropagation();
e.preventDefault();

this.zone.runOutsideAngular(() => {
this.mousemove = this.gridsterItem.renderer.listen(
'document',
'mousemove',
this.dragMove
);
this.touchmove = this.gridster.renderer.listen(
this.gridster.el,
'touchmove',
this.dragMove
);
});
this.mousemove = this.gridsterItem.renderer.listen(
'document',
'mousemove',
this.dragMove
);
this.touchmove = this.gridster.renderer.listen(
this.gridster.el,
'touchmove',
this.dragMove
);
this.mouseup = this.gridsterItem.renderer.listen(
'document',
'mouseup',
Expand Down Expand Up @@ -294,9 +290,7 @@ export class GridsterResizable {

this.lastMouse.clientX = e.clientX;
this.lastMouse.clientY = e.clientY;
this.zone.run(() => {
this.gridster.updateGrid();
});
this.gridster.updateGrid();
};

dragStop = (e: MouseEvent): void => {
Expand Down Expand Up @@ -476,10 +470,7 @@ export class GridsterResizable {
if (this.gridster.options.enableBoundaryControl) {
const margin = this.outerMarginBottom ?? this.margin;
const box = this.gridster.el.getBoundingClientRect();
this.bottom = Math.min(
this.bottom,
box.bottom - box.top - 2 * margin
);
this.bottom = Math.min(this.bottom, box.bottom - box.top - 2 * margin);
this.height = this.bottom - this.top;
}
const marginBottom = this.gridster.options.pushItems ? 0 : this.margin;
Expand Down Expand Up @@ -603,58 +594,36 @@ export class GridsterResizable {
cancelDrag();
}, this.gridster.$options.resizable.delayStart);

const {
cancelMouse,
cancelMouseLeave,
cancelOnBlur,
cancelTouchMove,
cancelTouchEnd,
cancelTouchCancel
} = this.zone.runOutsideAngular(() => {
// Note: all of these events are being added within the `<root>` zone since they all
// don't do any view updates and don't require Angular running change detection.
// All event listeners call `cancelDrag` once the event is dispatched, the `cancelDrag`
// is responsible only for removing event listeners.

const cancelMouse = this.gridsterItem.renderer.listen(
'document',
'mouseup',
cancelDrag
);
const cancelMouseLeave = this.gridsterItem.renderer.listen(
'document',
'mouseleave',
cancelDrag
);
const cancelOnBlur = this.gridsterItem.renderer.listen(
'window',
'blur',
cancelDrag
);
const cancelTouchMove = this.gridsterItem.renderer.listen(
'document',
'touchmove',
cancelMove
);
const cancelTouchEnd = this.gridsterItem.renderer.listen(
'document',
'touchend',
cancelDrag
);
const cancelTouchCancel = this.gridsterItem.renderer.listen(
'document',
'touchcancel',
cancelDrag
);
return {
cancelMouse,
cancelMouseLeave,
cancelOnBlur,
cancelTouchMove,
cancelTouchEnd,
cancelTouchCancel
};
});
const cancelMouse = this.gridsterItem.renderer.listen(
'document',
'mouseup',
cancelDrag
);
const cancelMouseLeave = this.gridsterItem.renderer.listen(
'document',
'mouseleave',
cancelDrag
);
const cancelOnBlur = this.gridsterItem.renderer.listen(
'window',
'blur',
cancelDrag
);
const cancelTouchMove = this.gridsterItem.renderer.listen(
'document',
'touchmove',
cancelMove
);
const cancelTouchEnd = this.gridsterItem.renderer.listen(
'document',
'touchend',
cancelDrag
);
const cancelTouchCancel = this.gridsterItem.renderer.listen(
'document',
'touchcancel',
cancelDrag
);

function cancelMove(eventMove: MouseEvent): void {
GridsterUtils.checkTouchEvent(eventMove);
Expand Down
Loading

0 comments on commit b1b2d3d

Please sign in to comment.