UNPKG

@alauda-fe/common

Version:

Alauda frontend team common codes.

85 lines 14.7 kB
import { Injectable } from '@angular/core'; import { cloneDeep } from 'lodash-es'; import { map, of, ReplaySubject, startWith, Subject, switchMap, } from 'rxjs'; import { getClientRectSnapshot } from './utils/client-rect.utils'; import { getGridHeight, gridItemDragging, gridItemResizing, layoutToRenderItems, } from './utils/grid.utils'; import { getScrollTotalRelativeDifference$ } from './utils/scroll.utils'; import * as i0 from "@angular/core"; export class GridLayoutService { constructor() { this.gridRenderHeight$$ = new ReplaySubject(1); this.gridRenderItemsData$$ = new Subject(); } get gridConfig() { return this.gridComponent?.config; } registerGridComponent(gridComponent) { this.gridComponent = gridComponent; this.scrollDifference$ = gridComponent.scrollableParent$.pipe(map(scrollableParent => typeof scrollableParent === 'string' ? document.querySelector(scrollableParent) : scrollableParent), switchMap(scrollableParent => scrollableParent ? getScrollTotalRelativeDifference$(scrollableParent).pipe(startWith({ top: 0, left: 0 })) : of({ top: 0, left: 0 }))); } calculateRenderData(_updateLayout) { const { rowHeight, gutter, layout } = this.gridConfig; const clientRect = getClientRectSnapshot(this.gridComponent.hostElement); this.lastLayout = layout; this.gridItemsRenderData = layoutToRenderItems(this.gridConfig, clientRect.width, this.lastLayout); this.gridHeight = getGridHeight(layout, rowHeight, gutter); } flushRenderItemsData(animation = true) { this.gridRenderItemsData$$.next({ data: this.gridItemsRenderData, animation, }); } flushRenderData(animation = true) { this.flushRenderItemsData(animation); requestAnimationFrame(() => { this.gridRenderHeight$$.next(this.gridHeight); }); } // use this to handle remove grid item setLastLayout(layout) { this.lastLayout = layout; } layoutWhenAction(gridItem, type, { pointerDownEvent, pointerDragEvent, }, scrollDifference, dragElemClientRect, gridElemClientRect) { const { rowHeight, gutter, cols, preventCollision, layout: rawLayout, } = this.gridConfig; const calcNewStateFunc = type === 'drag' ? gridItemDragging : gridItemResizing; const currentLayout = cloneDeep(this.lastLayout || rawLayout); const { layout: newLayout, draggedItemPos } = calcNewStateFunc(gridItem, { ...this.gridConfig, layout: currentLayout, }, this.gridComponent.compactType, { pointerDownEvent, pointerDragEvent, gridElemClientRect, dragElemClientRect, scrollDifference, }); this.lastLayout = newLayout; const itemsLayoutData = layoutToRenderItems({ cols, rowHeight, layout: newLayout, preventCollision, gutter, }, gridElemClientRect.width); this.gridHeight = getGridHeight(newLayout, rowHeight, gutter); // itemsLayoutData and this.gridItemsRenderData will be different, because this.gridItemsRenderData will be used to render on-flight item position. bud itemsLayoutData is normalized position by grid this.gridItemsRenderData = cloneDeep(itemsLayoutData); // modify the position of the dragged item to be the once we want this.gridItemsRenderData[gridItem.id] = { ...draggedItemPos, id: gridItem.id, }; return { gridData: itemsLayoutData, layout: newLayout }; } static { this.ɵfac = function GridLayoutService_Factory(t) { return new (t || GridLayoutService)(); }; } static { this.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: GridLayoutService, factory: GridLayoutService.ɵfac }); } } (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(GridLayoutService, [{ type: Injectable }], null, null); })(); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-layout.service.js","sourceRoot":"","sources":["../../../../../libs/common/src/grid-layout/grid-layout.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { cloneDeep } from 'lodash-es';\nimport {\n  map,\n  Observable,\n  of,\n  ReplaySubject,\n  startWith,\n  Subject,\n  switchMap,\n} from 'rxjs';\n\nimport { Dictionary } from '../core/public-api';\n\nimport { GridLayoutComponent } from './components/grid/component';\nimport { GridItemComponent } from './components/grid-items/component';\nimport {\n  DragActionType,\n  GridItemClientRect,\n  GridItemRenderData,\n  GridLayout,\n  GridLayoutItem,\n} from './public-api';\nimport { getClientRectSnapshot } from './utils/client-rect.utils';\nimport {\n  getGridHeight,\n  gridItemDragging,\n  gridItemResizing,\n  layoutToRenderItems,\n} from './utils/grid.utils';\nimport { getScrollTotalRelativeDifference$ } from './utils/scroll.utils';\n\n@Injectable()\nexport class GridLayoutService {\n  gridComponent: GridLayoutComponent;\n\n  get gridConfig() {\n    return this.gridComponent?.config;\n  }\n\n  gridItemsRenderData: Dictionary<GridItemRenderData>;\n  gridHeight: number;\n\n  scrollDifference$: Observable<{ top: number; left: number }>;\n\n  registerGridComponent(gridComponent: GridLayoutComponent) {\n    this.gridComponent = gridComponent;\n\n    this.scrollDifference$ = gridComponent.scrollableParent$.pipe(\n      map(scrollableParent =>\n        typeof scrollableParent === 'string'\n          ? document.querySelector(scrollableParent)\n          : scrollableParent,\n      ),\n      switchMap(scrollableParent =>\n        scrollableParent\n          ? getScrollTotalRelativeDifference$(scrollableParent).pipe(\n              startWith({ top: 0, left: 0 }),\n            )\n          : of({ top: 0, left: 0 }),\n      ),\n    );\n  }\n\n  calculateRenderData(_updateLayout?: GridLayoutItem[]) {\n    const { rowHeight, gutter, layout } = this.gridConfig;\n    const clientRect = getClientRectSnapshot(this.gridComponent.hostElement);\n    this.lastLayout = layout;\n    this.gridItemsRenderData = layoutToRenderItems(\n      this.gridConfig,\n      clientRect.width,\n      this.lastLayout,\n    );\n    this.gridHeight = getGridHeight(layout, rowHeight, gutter);\n  }\n\n  gridRenderHeight$$ = new ReplaySubject<number>(1);\n  gridRenderItemsData$$ = new Subject<{\n    data: Dictionary<GridItemRenderData>;\n    animation: boolean;\n  }>();\n\n  flushRenderItemsData(animation = true) {\n    this.gridRenderItemsData$$.next({\n      data: this.gridItemsRenderData,\n      animation,\n    });\n  }\n\n  flushRenderData(animation = true) {\n    this.flushRenderItemsData(animation);\n    requestAnimationFrame(() => {\n      this.gridRenderHeight$$.next(this.gridHeight);\n    });\n  }\n\n  lastLayout: GridLayout;\n\n  // use this to handle remove grid item\n  setLastLayout(layout: GridLayout) {\n    this.lastLayout = layout;\n  }\n\n  layoutWhenAction(\n    gridItem: GridItemComponent,\n    type: DragActionType,\n    {\n      pointerDownEvent,\n      pointerDragEvent,\n    }: {\n      pointerDownEvent: MouseEvent;\n      pointerDragEvent: MouseEvent;\n    },\n    scrollDifference: { top: number; left: number },\n    dragElemClientRect: GridItemClientRect,\n    gridElemClientRect: GridItemClientRect,\n  ) {\n    const {\n      rowHeight,\n      gutter,\n      cols,\n      preventCollision,\n      layout: rawLayout,\n    } = this.gridConfig;\n\n    const calcNewStateFunc =\n      type === 'drag' ? gridItemDragging : gridItemResizing;\n    const currentLayout: GridLayout = cloneDeep(this.lastLayout || rawLayout);\n    const { layout: newLayout, draggedItemPos } = calcNewStateFunc(\n      gridItem,\n      {\n        ...this.gridConfig,\n        layout: currentLayout,\n      },\n      this.gridComponent.compactType,\n      {\n        pointerDownEvent,\n        pointerDragEvent,\n        gridElemClientRect,\n        dragElemClientRect,\n        scrollDifference,\n      },\n    );\n\n    this.lastLayout = newLayout;\n\n    const itemsLayoutData = layoutToRenderItems(\n      {\n        cols,\n        rowHeight,\n        layout: newLayout,\n        preventCollision,\n        gutter,\n      },\n      gridElemClientRect.width,\n    );\n    this.gridHeight = getGridHeight(newLayout, rowHeight, gutter);\n\n    // itemsLayoutData and this.gridItemsRenderData will be different, because this.gridItemsRenderData will be used to render on-flight item position. bud itemsLayoutData is normalized position by grid\n    this.gridItemsRenderData = cloneDeep(itemsLayoutData);\n\n    // modify the position of the dragged item to be the once we want\n    this.gridItemsRenderData[gridItem.id] = {\n      ...draggedItemPos,\n      id: gridItem.id,\n    } as GridItemRenderData;\n    return { gridData: itemsLayoutData, layout: newLayout };\n  }\n}\n"]}