From ccfd146a4e89879aaea3874263fab677dea217fc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=9D=A8=E9=AA=A5?= Date: Fri, 2 Dec 2022 20:29:19 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20=E6=9A=B4=E9=9C=B2afterRealCellRender?= =?UTF-8?q?=EF=BC=8C=E8=BF=99=E6=A0=B7=E8=83=BD=E5=A4=9F=E6=9B=B4=E7=81=B5?= =?UTF-8?q?=E6=B4=BB=E7=9A=84=E4=BD=BF=E7=94=A8datacell?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../s2-core/__tests__/spreadsheet/spread-sheet-spec.ts | 8 +++++++- packages/s2-core/src/cell/data-cell.ts | 4 +--- packages/s2-core/src/common/constant/events/basic.ts | 1 + packages/s2-core/src/common/interface/emitter.ts | 6 ++++++ packages/s2-core/src/common/interface/s2Options.ts | 1 + packages/s2-core/src/facet/base-facet.ts | 5 +++++ packages/s2-react/src/hooks/useEvents.ts | 5 +++++ packages/s2-shared/src/interface.ts | 1 + packages/s2-vue/src/hooks/useEvents.ts | 6 ++++++ packages/s2-vue/src/utils/initPropAndEmits.ts | 1 + s2-site/docs/api/general/S2Event.zh.md | 1 + 11 files changed, 35 insertions(+), 4 deletions(-) diff --git a/packages/s2-core/__tests__/spreadsheet/spread-sheet-spec.ts b/packages/s2-core/__tests__/spreadsheet/spread-sheet-spec.ts index c72503f983..ce63b63bdb 100644 --- a/packages/s2-core/__tests__/spreadsheet/spread-sheet-spec.ts +++ b/packages/s2-core/__tests__/spreadsheet/spread-sheet-spec.ts @@ -1,6 +1,6 @@ import * as mockDataConfig from 'tests/data/simple-data.json'; import { getContainer, sleep } from 'tests/util/helpers'; -import { pick } from 'lodash'; +import { after, pick } from 'lodash'; import { PivotSheet, TableSheet } from '@/sheet-type'; import { DEFAULT_OPTIONS, @@ -240,6 +240,7 @@ describe('SpreadSheet Tests', () => { const beforeRender = jest.fn(); const afterRender = jest.fn(); + const afterRealDataCellRender = jest.fn(); const clearDrillDownDataSpy = jest .spyOn(s2, 'clearDrillDownData') @@ -247,6 +248,10 @@ describe('SpreadSheet Tests', () => { s2.on(S2Event.LAYOUT_BEFORE_RENDER, beforeRender); s2.on(S2Event.LAYOUT_AFTER_RENDER, afterRender); + s2.on( + S2Event.LAYOUT_AFTER_REAL_DATA_CELL_RENDER, + afterRealDataCellRender, + ); s2.destroy(); Array.from({ length: 10 }).forEach(() => { @@ -255,6 +260,7 @@ describe('SpreadSheet Tests', () => { expect(beforeRender).toHaveBeenCalledTimes(0); expect(afterRender).toHaveBeenCalledTimes(0); + expect(afterRealDataCellRender).toHaveBeenCalledTimes(0); expect(clearDrillDownDataSpy).toHaveBeenCalledTimes(0); }, ); diff --git a/packages/s2-core/src/cell/data-cell.ts b/packages/s2-core/src/cell/data-cell.ts index 1d8f03cce7..00afa3eb01 100644 --- a/packages/s2-core/src/cell/data-cell.ts +++ b/packages/s2-core/src/cell/data-cell.ts @@ -178,9 +178,7 @@ export class DataCell extends BaseCell { this.drawTextShape(); this.drawConditionIconShapes(); } - if (this.meta.isFrozenCorner) { - this.drawBorderShape(); - } + this.drawBorderShape(); this.update(); } diff --git a/packages/s2-core/src/common/constant/events/basic.ts b/packages/s2-core/src/common/constant/events/basic.ts index 8ebe8587eb..d2a1ee26f5 100644 --- a/packages/s2-core/src/common/constant/events/basic.ts +++ b/packages/s2-core/src/common/constant/events/basic.ts @@ -66,6 +66,7 @@ export enum S2Event { LAYOUT_PAGINATION = 'layout:pagination', LAYOUT_COLLAPSE_ROWS = 'layout:collapsed-rows', LAYOUT_AFTER_COLLAPSE_ROWS = 'layout:after-collapsed-rows', + LAYOUT_AFTER_REAL_DATA_CELL_RENDER = 'layout:after-real-data-cell-render', LAYOUT_TREE_ROWS_COLLAPSE_ALL = 'layout:toggle-collapse-all', LAYOUT_COLS_EXPANDED = 'layout:table-col-expanded', LAYOUT_COLS_HIDDEN = 'layout:table-col-hidden', diff --git a/packages/s2-core/src/common/interface/emitter.ts b/packages/s2-core/src/common/interface/emitter.ts index dd045ccd75..623e79e59d 100644 --- a/packages/s2-core/src/common/interface/emitter.ts +++ b/packages/s2-core/src/common/interface/emitter.ts @@ -1,4 +1,5 @@ import type { Event as CanvasEvent } from '@antv/g-canvas'; +import type { SpreadSheet } from '../../sheet-type'; import type { DataCell } from '../../cell/data-cell'; import type { RowCell } from '../../cell/row-cell'; import type { ColCell } from '../../cell/col-cell'; @@ -145,6 +146,11 @@ export interface EmitterType { current: number; }) => void; [S2Event.LAYOUT_AFTER_HEADER_LAYOUT]: (data: LayoutResult) => void; + [S2Event.LAYOUT_AFTER_REAL_DATA_CELL_RENDER]: (options: { + add: [number, number][]; + remove: [number, number][]; + spreadsheet: SpreadSheet; + }) => void; /** @deprecated 请使用 S2Event.GLOBAL_SCROLL 代替 */ [S2Event.LAYOUT_CELL_SCROLL]: (position: CellScrollPosition) => void; [S2Event.LAYOUT_COLS_EXPANDED]: (expandedNode: Node) => void; diff --git a/packages/s2-core/src/common/interface/s2Options.ts b/packages/s2-core/src/common/interface/s2Options.ts index 1729e80677..4c3c1edc3b 100644 --- a/packages/s2-core/src/common/interface/s2Options.ts +++ b/packages/s2-core/src/common/interface/s2Options.ts @@ -125,6 +125,7 @@ export interface S2Options S2PivotSheetOptions { // custom data set dataSet?: (spreadsheet: SpreadSheet) => BaseDataSet; + afterRealCellRender?: (spreadsheet: SpreadSheet) => void; } export interface S2RenderOptions { diff --git a/packages/s2-core/src/facet/base-facet.ts b/packages/s2-core/src/facet/base-facet.ts index fa605b817a..c62734f65a 100644 --- a/packages/s2-core/src/facet/base-facet.ts +++ b/packages/s2-core/src/facet/base-facet.ts @@ -1066,6 +1066,11 @@ export abstract class BaseFacet { ); }); this.preCellIndexes = indexes; + this.spreadsheet.emit(S2Event.LAYOUT_AFTER_REAL_DATA_CELL_RENDER, { + add, + remove, + spreadsheet: this.spreadsheet, + }); }; protected init() { diff --git a/packages/s2-react/src/hooks/useEvents.ts b/packages/s2-react/src/hooks/useEvents.ts index 13e32d9773..25139e09b7 100644 --- a/packages/s2-react/src/hooks/useEvents.ts +++ b/packages/s2-react/src/hooks/useEvents.ts @@ -220,6 +220,11 @@ export function useEvents(props: SheetComponentsProps, s2: SpreadSheet) { useS2Event(S2Event.GLOBAL_LINK_FIELD_JUMP, props.onLinkFieldJump, s2); useS2Event(S2Event.GLOBAL_SCROLL, props.onScroll, s2); // ============== Auto 自动生成的 ================ + useS2Event( + S2Event.LAYOUT_AFTER_REAL_DATA_CELL_RENDER, + props.onLayoutAfterRealDataCellRender, + s2, + ); useS2Event( S2Event.ROW_CELL_BRUSH_SELECTION, props.onRowCellBrushSelection, diff --git a/packages/s2-shared/src/interface.ts b/packages/s2-shared/src/interface.ts index 6030b77da5..a58251fa34 100644 --- a/packages/s2-shared/src/interface.ts +++ b/packages/s2-shared/src/interface.ts @@ -204,6 +204,7 @@ export interface BaseSheetComponentProps< onScroll?: (position: CellScrollPosition) => void; // ============== Auto 自动生成的 ================ + onLayoutAfterRealDataCellRender?: (event: GEvent) => void; onRowCellBrushSelection?: (event: GEvent) => void; onColCellBrushSelection?: (event: GEvent) => void; } diff --git a/packages/s2-vue/src/hooks/useEvents.ts b/packages/s2-vue/src/hooks/useEvents.ts index 7977d33436..6847b4f596 100644 --- a/packages/s2-vue/src/hooks/useEvents.ts +++ b/packages/s2-vue/src/hooks/useEvents.ts @@ -316,6 +316,12 @@ export const useEvents = ( useS2Event(s2Ref, emit, S2Event.GLOBAL_SCROLL, 'scroll'); // ============== Auto 自动生成的 ================ + useS2Event( + s2Ref, + emit, + S2Event.LAYOUT_AFTER_REAL_DATA_CELL_RENDER, + 'layoutAfterRealDataCellRender', + ); useS2Event( s2Ref, emit, diff --git a/packages/s2-vue/src/utils/initPropAndEmits.ts b/packages/s2-vue/src/utils/initPropAndEmits.ts index cf0a44df7f..75e0af8db9 100644 --- a/packages/s2-vue/src/utils/initPropAndEmits.ts +++ b/packages/s2-vue/src/utils/initPropAndEmits.ts @@ -180,6 +180,7 @@ export const initBaseSheetEmits = () => { 'scroll', 'hover', // ============== Auto 自动生成的 ================ + 'layoutAfterRealDataCellRender', 'rowCellBrushSelection', 'colCellBrushSelection', ]; diff --git a/s2-site/docs/api/general/S2Event.zh.md b/s2-site/docs/api/general/S2Event.zh.md index 2c1223c259..dd05f27967 100644 --- a/s2-site/docs/api/general/S2Event.zh.md +++ b/s2-site/docs/api/general/S2Event.zh.md @@ -91,6 +91,7 @@ s2.on(S2Event.ROW_CELL_CLICK, (event) => { | 名称 | 事件名 | 描述 | | ----------------------- | --------------------------------- | ------------------------------------------ | | 表头布局完成 | `S2Event.LAYOUT_AFTER_HEADER_LAYOUT` | 行头和列头布局完成后触发 | +| 单元格布局完成 | `LAYOUT_AFTER_REAL_DATA_CELL_RENDER` | 单元格渲染完成后触发 | | 单元格虚拟滚动 | `S2Event.LAYOUT_CELL_SCROLL` | 已废弃,请使用 `S2Event.GLOBAL_SCROLL` 替代 | | 分页 | `S2Event.LAYOUT_PAGINATION` | 分页事件 | | 收起行头 | `S2Event.LAYOUT_COLLAPSE_ROWS` | 树状模式下收起行头的事件回调 |