From fa5bb9b4f5f7c661993670a86d9135781adb946e Mon Sep 17 00:00:00 2001 From: Jinke Li Date: Fri, 5 Jul 2024 16:05:08 +0800 Subject: [PATCH] =?UTF-8?q?fix:=20=E4=BF=AE=E5=A4=8D=E6=A0=91=E7=8A=B6?= =?UTF-8?q?=E6=A8=A1=E5=BC=8F=E5=BD=93=E4=B8=80=E7=BB=84=E6=95=B0=E6=8D=AE?= =?UTF-8?q?=E5=8F=AA=E6=9C=89=E4=B8=80=E6=9D=A1=E6=95=B0=E6=8D=AE=E6=97=B6?= =?UTF-8?q?,=20=E5=8F=B6=E5=AD=90=E8=8A=82=E7=82=B9=E5=88=A4=E6=96=AD?= =?UTF-8?q?=E9=94=99=E8=AF=AF,=20=E4=B9=9F=E6=B8=B2=E6=9F=93=E4=BA=86?= =?UTF-8?q?=E5=B1=95=E5=BC=80/=E6=94=B6=E8=B5=B7=E5=9B=BE=E6=A0=87=20close?= =?UTF-8?q?=20#2804=20(#2806)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit fix: 修复树状模式下一组数据只有一条数据时, 叶子节点判断错误, 也渲染了展开/收起图标 close #2804 --- .../s2-core/__tests__/bugs/issue-2804-spec.ts | 33 +++++++++++++++++++ .../__tests__/data/data-issue-2804.json | 21 ++++++++++++ .../facet/layout/build-row-tree-hierarchy.ts | 19 +++++++---- 3 files changed, 67 insertions(+), 6 deletions(-) create mode 100644 packages/s2-core/__tests__/bugs/issue-2804-spec.ts create mode 100644 packages/s2-core/__tests__/data/data-issue-2804.json diff --git a/packages/s2-core/__tests__/bugs/issue-2804-spec.ts b/packages/s2-core/__tests__/bugs/issue-2804-spec.ts new file mode 100644 index 0000000000..209152b0eb --- /dev/null +++ b/packages/s2-core/__tests__/bugs/issue-2804-spec.ts @@ -0,0 +1,33 @@ +/* eslint-disable @typescript-eslint/ban-ts-comment */ +/** + * 透视表树状模式当某一组数据只有一条数据时, 叶子节点判断错误, 也渲染了展开/收起图标. + * @description spec for issue #2804 + * https://github.com/antvis/S2/issues/2804 + */ +import { S2Options } from '../../src'; +import * as mockDataConfig from '../data/data-issue-2804.json'; +import { getContainer } from '../util/helpers'; +import { PivotSheet } from '@/sheet-type'; + +const s2Options: S2Options = { + width: 800, + height: 600, + hierarchyType: 'tree', +}; + +describe('Tree Leaf Node Status Tests', () => { + test('should get correctly tree icon and leaf node status', () => { + const s2 = new PivotSheet(getContainer(), mockDataConfig, s2Options); + + s2.render(); + + const [a1, a2] = s2.getRowNodes(); + + expect(a1.isLeaf).toBeTruthy(); + expect(a1.isTotals).toBeFalsy(); + expect(a2.isLeaf).toBeFalsy(); + expect(a2.isTotals).toBeTruthy(); + expect(a1.belongsCell.treeIcon).not.toBeDefined(); + expect(a2.belongsCell.treeIcon).toBeDefined(); + }); +}); diff --git a/packages/s2-core/__tests__/data/data-issue-2804.json b/packages/s2-core/__tests__/data/data-issue-2804.json new file mode 100644 index 0000000000..36479a1da9 --- /dev/null +++ b/packages/s2-core/__tests__/data/data-issue-2804.json @@ -0,0 +1,21 @@ +{ + "fields": { + "rows": ["row0", "row1"], + "columns": ["col0"], + "values": ["cost"], + "valueInCols": true + }, + "data": [ + { + "row0": "a-1", + "col0": "b-1", + "cost": 2 + }, + { + "row0": "a-2", + "row1": "a-2-1", + "col0": "b-2", + "cost": 3 + } + ] +} diff --git a/packages/s2-core/src/facet/layout/build-row-tree-hierarchy.ts b/packages/s2-core/src/facet/layout/build-row-tree-hierarchy.ts index 1dc795ef1b..4cc15df0e6 100644 --- a/packages/s2-core/src/facet/layout/build-row-tree-hierarchy.ts +++ b/packages/s2-core/src/facet/layout/build-row-tree-hierarchy.ts @@ -1,5 +1,5 @@ -import { isNumber } from 'lodash'; -import { i18n } from '../../common'; +import { isEmpty, isNumber } from 'lodash'; +import { i18n, TOTAL_VALUE } from '../../common'; import type { SpreadSheet } from '../../sheet-type'; import { filterOutDetail } from '../../utils/data-set-operate'; import { generateId } from '../../utils/layout/generate-id'; @@ -118,11 +118,18 @@ export const buildRowTreeHierarchy = (params: TreeHeaderParams) => { hierarchy.maxLevel = level; } - const emptyChildren = !pivotMetaValue?.children?.size; - if (emptyChildren || isTotals) { + /** + * 除了虚拟行小计节点外, 如果为空, 说明当前分组只有一条数据, 应该标记为叶子节点. + * https://github.com/antvis/S2/issues/2804 + */ + const children = [...(pivotMetaValue?.children?.keys() || [])].filter( + (child) => child !== TOTAL_VALUE, + ); + const isEmptyChildren = isEmpty(children); + if (isEmptyChildren || isTotals) { node.isLeaf = true; } - if (!emptyChildren) { + if (!isEmptyChildren) { node.isTotals = true; } @@ -133,7 +140,7 @@ export const buildRowTreeHierarchy = (params: TreeHeaderParams) => { hierarchy, ); - if (!emptyChildren && !isCollapse && !isTotals && expandCurrentNode) { + if (!isEmptyChildren && !isCollapse && !isTotals && expandCurrentNode) { buildRowTreeHierarchy({ level: level + 1, currentField: pivotMetaValue.childField,