Skip to content

Commit

Permalink
fix : 修复点击行列头无法整行高亮的问题 (#2025)
Browse files Browse the repository at this point in the history
* fix: 修复点击行列头无法整行高亮的问题

* test: 添加修复点击行列头无法整行高亮的问题的单测

* docs: 完善 selectedCellHighlight 相关文档

* docs: 完善 selectedCellHighlight 相关文档

Co-authored-by: zishang <[email protected]>
  • Loading branch information
stone-lyl and zishang authored Jan 3, 2023
1 parent 9f952fd commit 84558ca
Show file tree
Hide file tree
Showing 6 changed files with 113 additions and 15 deletions.
85 changes: 84 additions & 1 deletion packages/s2-core/__tests__/unit/cell/data-cell-spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,15 @@ import { find, get } from 'lodash';
import { createPivotSheet, createTableSheet } from 'tests/util/helpers';
import { renderText } from '@/utils/g-renders';
import { DataCell } from '@/cell';
import { GuiIcon, type Formatter, type ViewMeta } from '@/common';
import {
GuiIcon,
type Formatter,
type ViewMeta,
S2Event,
type OriginalEvent,
type S2CellType,
CellTypes,
} from '@/common';
import { EXTRA_FIELD, VALUE_FIELD } from '@/common/constant/basic';
import {
DEFAULT_FONT_COLOR,
Expand Down Expand Up @@ -368,4 +376,79 @@ describe('Data Cell Tests', () => {
table.render();
});
});

describe('Data Cell Interaction', () => {
let s2: SpreadSheet;

beforeEach(() => {
s2 = createPivotSheet({
showSeriesNumber: true,
interaction: {
enableCopy: true,
},
});
s2.render();
});
const emitEvent = (type: S2Event, event: Partial<OriginalEvent>) => {
s2.emit(type, {
originalEvent: event,
preventDefault() {},
stopPropagation() {},
...event,
} as any);
};

test('should be highlight entire row data cells when the row header is clicked', () => {
const allRowCells = s2.interaction.getAllRowHeaderCells();
const mockCell = allRowCells[0];
s2.getCell = jest.fn().mockReturnValue(mockCell);

emitEvent(S2Event.ROW_CELL_CLICK, {
x: 2,
y: 2,
});

const interactedCells = s2.interaction.getInteractedCells();
const firstRowCell = find(interactedCells, (cell: S2CellType) => {
return cell.cellType === CellTypes.ROW_CELL;
});
expect(interactedCells.length).toBe(7);
expect(firstRowCell.getMeta().id).toBe(mockCell.getMeta().id);
});

test('should be highlight entire column data cells when the column header is clicked', () => {
const allColumnCells = s2.interaction.getAllColHeaderCells();
const mockCell = allColumnCells[0];
s2.getCell = jest.fn().mockReturnValue(mockCell);

emitEvent(S2Event.COL_CELL_CLICK, {
x: mockCell.getMeta().x + 5,
y: mockCell.getMeta().y + 5,
});

const interactedCells = s2.interaction.getInteractedCells();
const firstColCell = find(interactedCells, (cell: S2CellType) => {
return cell.cellType === CellTypes.COL_CELL;
});
expect(interactedCells.length).toBe(8);
expect(firstColCell.getMeta().id).toBe(mockCell.getMeta().id);
});

test('should be highlight data cell when the data cell is clicked', () => {
const allDataCells = s2.interaction.getAllCells();
const mockCell = allDataCells[0];
s2.getCell = jest.fn().mockReturnValue(mockCell);

emitEvent(S2Event.DATA_CELL_CLICK, {
x: mockCell.getMeta().x + 5,
y: mockCell.getMeta().y + 5,
});

const activeCells = s2.interaction.getInteractedCells();

expect(activeCells.length).toBe(1);
expect(activeCells[0].getActualText()).toBe('1');
expect(activeCells[0].getMeta().id).toBe(mockCell.getMeta().id);
});
});
});
3 changes: 2 additions & 1 deletion packages/s2-core/src/cell/data-cell.ts
Original file line number Diff line number Diff line change
Expand Up @@ -141,7 +141,8 @@ export class DataCell extends BaseCell<ViewMeta> {

public update() {
const stateName = this.spreadsheet.interaction.getCurrentStateName();
const cells = this.spreadsheet.interaction.getCells([CellTypes.DATA_CELL]);
// 获取当前 interaction 记录的 Cells 元信息列表,不仅仅是数据单元格,也可能是行头或者列头。
const cells = this.spreadsheet.interaction.getCells();

if (stateName === InteractionStateName.ALL_SELECTED) {
this.updateByState(InteractionStateName.SELECTED);
Expand Down
3 changes: 1 addition & 2 deletions packages/s2-core/src/cell/header-cell.ts
Original file line number Diff line number Diff line change
Expand Up @@ -325,7 +325,7 @@ export abstract class HeaderCell extends BaseCell<Node> {
}
}

protected handleSelect(cells: Array<CellMeta>, nodes: Node[]) {
protected handleSelect(cells: CellMeta[], nodes: Node[]) {
if (includeCell(cells, this)) {
this.updateByState(InteractionStateName.SELECTED);
}
Expand Down Expand Up @@ -387,7 +387,6 @@ export abstract class HeaderCell extends BaseCell<Node> {
CellTypes.COL_CELL,
CellTypes.ROW_CELL,
]);

if (!first(cells)) {
return;
}
Expand Down
1 change: 1 addition & 0 deletions packages/s2-core/src/utils/cell/data-cell.ts
Original file line number Diff line number Diff line change
Expand Up @@ -113,6 +113,7 @@ export const updateBySelectedCellsHighlight = (
s2.interaction.getSelectedCellHighlight();

const isRowCell = dataCell.cellType === CellTypes.ROW_CELL;
// 高亮序号
const showSNWhenRowHeaderHighlight =
s2.isTableMode() && s2.options.showSeriesNumber && rowHeader && isRowCell;

Expand Down
20 changes: 10 additions & 10 deletions s2-site/docs/common/interaction.zh.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,27 +5,27 @@ order: 5

## Interaction

| 参数 | 说明 | 类型 | 默认值 | 必选 |
| -------- | ----------- | -------------- | -------- | ---------------- |
| linkFields | 标记字段为链接样式,用于外链跳转 | `string[]` \| (meta: [Node](/docs/api/basic-class/node) \| ViewMeta) => boolean | | |
| selectedCellsSpotlight | 是否开启选中高亮聚光灯效果 | `boolean` | `false` | |
| 参数 | 说明 | 类型 | 默认值 | 必选 |
| -------- | ----------- |-------------------------------------------| -------- | ---------------- |
| linkFields | 标记字段为链接样式,用于外链跳转 | `string[]` \ | (meta: [Node](/docs/api/basic-class/node) \| ViewMeta) => boolean | | |
| selectedCellsSpotlight | 是否开启选中高亮聚光灯效果 | `boolean` | `false` | |
| hoverHighlight | 鼠标悬停时高亮当前单元格,以及所对应的行头,列头 | `boolean` | `true` | |
| hoverFocus | 鼠标悬停在当前单元格超过默认 800ms 后,保持当前高亮,显示 tooltip,悬停时间通过设置 `duration` 来控制 | `boolean \| {duration: number}` | `true` | |
| hoverFocus | 鼠标悬停在当前单元格超过默认 800ms 后,保持当前高亮,显示 tooltip,悬停时间通过设置 `duration` 来控制 | `boolean \ | {duration: number}` | `true` | |
| hiddenColumnFields | 用于配置默认隐藏的列,透视表需要配置列头唯一 id, 明细表配置列头 field 字段即可 | `string[]` | | |
| enableCopy | 是否允许复制 | `boolean` | `false` | |
| copyWithHeader | 复制数据是否带表头信息 | `boolean` | `false` | |
| copyWithFormat | 是否使用 field format 格式复制 | `boolean` | `false` | |
| customInteractions | 自定义交互 [详情](/docs/manual/advanced/interaction/custom) | [CustomInteraction[]](#custominteraction) | | |
| scrollSpeedRatio | 用于控制滚动速率,分水平和垂直两个方向,默认为 1 | [ScrollSpeedRatio](#scrollspeedratio) | | |
| autoResetSheetStyle | 用于控制点击表格外区域和按下 esc 键时是否重置交互状态 | `boolean` | `true` | |
| resize | 用于控制 resize 热区是否显示 | `boolean` \| [ResizeInteractionOptions](#resizeinteractionoptions) | `true` | |
| brushSelection | 是否允许单元格(包含行头,列头,数值单元格)刷选。行头,列头刷选只支持透视表 | `boolean` \| [BrushSelection](#brushSelection) | `true` | | 1.29.0 后支持 [BrushSelection](#brushSelection) |
| resize | 用于控制 resize 热区是否显示 | `boolean` \ | [ResizeInteractionOptions](#resizeinteractionoptions) | `true` | |
| brushSelection | 是否允许单元格(包含行头,列头,数值单元格)刷选。行头,列头刷选只支持透视表 | `boolean` \ | [BrushSelection](#brushSelection) | `true` | | 1.29.0 后支持 [BrushSelection](#brushSelection) |
| multiSelection | 是否允许多选 (包含行头,列头,数值单元格) | `boolean` | `true` | |
| rangeSelection | 是否允许区间快捷多选 | `boolean` | `true` | |
| scrollbarPosition | 用于控制滚动条展示在内容区边缘还是画布边缘 | `content \| canvas` | `content` | |
| scrollbarPosition | 用于控制滚动条展示在内容区边缘还是画布边缘 | `content \ | canvas` | `content` | |
| eventListenerOptions | 事件监听函数 `addEventListener`[可选项配置](https://developer.mozilla.org/zh-CN/docs/Web/API/EventTarget/addEventListener), 可控制事件从冒泡阶段还是捕获阶段触发 | `false` | |
| selectedCellHighlight | 选中格子后的高亮行为<br/>rowHeader:是否高亮选中格子所在行头<br/>colHeader:是否高亮选中格子所在列头<br/>rowCells:是否高亮选中格子所在行<br/>colCells:是否高亮选中格子所在列<br/>true:同{rowHeader: true, colHeader: true} | `boolean | { rowHeader?: boolean, colHeader?: boolean, rowCells?: boolean, colCells?: boolean }` | | `false` | |
| overscrollBehavior | 控制滚动至边界的行为,可禁用浏览器的默认滚动行为。[详情](/docs/manual/advanced/interaction/basic/#修改滚动至边界行为) | `auto \| contain \| none \| null` | `auto` |
| selectedCellHighlight | 选中格子后的高亮行为<br/>rowHeader:是否高亮选中格子所在行头<br/>colHeader:是否高亮选中格子所在列头<br/>rowCells:是否高亮选中格子所在行<br/>colCells:是否高亮选中格子所在列<br/>true:同{rowHeader: true, colHeader: true} | `boolean \| { rowHeader?: boolean, colHeader?: boolean, rowCells?: boolean, colCells?: boolean }` | | `false` | |
| overscrollBehavior | 控制滚动至边界的行为,可禁用浏览器的默认滚动行为。[详情](/docs/manual/advanced/interaction/basic/#修改滚动至边界行为) | `auto \ | contain \| none \| null` | `auto` |

### CustomInteraction

Expand Down
16 changes: 15 additions & 1 deletion s2-site/docs/manual/advanced/interaction/basic.zh.md
Original file line number Diff line number Diff line change
Expand Up @@ -185,11 +185,25 @@ const s2Options = {
<img src="https://gw.alipayobjects.com/mdn/rms_28a65c/afts/img/A*bqsoRpdz8mgAAAAAAAAAAAAAARQnAQ" alt="preview" width="600" />

```ts
// selectedCellHighlight 的类型为 boolean | { rowHeader: boolean, colHeader: boolean, rowCells: boolean, colCells: boolean }
// 当 selectedCellHighlight 为 boolean 时
const s2Options = {
interaction: {
selectedCellHighlight: true // 默认 false
selectedCellHighlight: true // 默认 false, 当 selectedCellsSpotlight 为 true 时,会高亮 rowHeader 和 colHeader (兼容未拓展类型前的设计)
}
};
// 同时还可以分别配置 selectedCellHighlight 中 header 和 cells 的高亮
const S2Options = {
interaction: {
selectedCellHighlight: {
rowHeader: true, // 选中单元格时,高亮行头
colHeader: true, // 选中单元格时,高亮列头
rowCells: false, // 选中单元格时,高亮当前行
colCells: false, // 选中单元格时,高亮当前列
},
},
};
```

### 悬停聚焦
Expand Down

0 comments on commit 84558ca

Please sign in to comment.