From ca20abfc4c1233bf588fecac98b3e1891e8201dd Mon Sep 17 00:00:00 2001 From: huanhuanwa <2323666215@qq.com> Date: Mon, 15 Apr 2024 11:38:35 +0800 Subject: [PATCH 1/4] fix: optimize code --- .changeset/great-suns-drum.md | 5 + .../draw/src/generators/table.generator.ts | 5 +- packages/draw/src/plugins/with-table.ts | 27 +++- packages/draw/src/table.component.ts | 20 ++- packages/draw/src/transforms/index.ts | 4 +- packages/draw/src/transforms/table-text.ts | 45 ++++++ packages/draw/src/utils/table.ts | 16 +- src/app/editor/mock-data.ts | 150 ++++++++++++++++-- 8 files changed, 250 insertions(+), 22 deletions(-) create mode 100644 .changeset/great-suns-drum.md create mode 100644 packages/draw/src/transforms/table-text.ts diff --git a/.changeset/great-suns-drum.md b/.changeset/great-suns-drum.md new file mode 100644 index 000000000..442409454 --- /dev/null +++ b/.changeset/great-suns-drum.md @@ -0,0 +1,5 @@ +--- +'@plait/draw': patch +--- + +support text edit in cell diff --git a/packages/draw/src/generators/table.generator.ts b/packages/draw/src/generators/table.generator.ts index 791d221ee..f046e0f89 100644 --- a/packages/draw/src/generators/table.generator.ts +++ b/packages/draw/src/generators/table.generator.ts @@ -3,6 +3,7 @@ import { Generator } from '@plait/common'; import { RectangleClient } from '@plait/core'; import { PlaitTable } from '../interfaces/table'; import { getEngine } from '../engines'; +import { getDrawDefaultStrokeColor } from '../utils'; export interface TableData {} @@ -17,8 +18,8 @@ export class TableGenerator extends Generator { this.board, rectangle, { - strokeWidth: 1, - stroke: '#333' + strokeWidth: 2, + stroke: getDrawDefaultStrokeColor(this.board.theme.themeColorMode), }, { element: element diff --git a/packages/draw/src/plugins/with-table.ts b/packages/draw/src/plugins/with-table.ts index cf05eb013..dae614c6e 100644 --- a/packages/draw/src/plugins/with-table.ts +++ b/packages/draw/src/plugins/with-table.ts @@ -7,11 +7,16 @@ import { RectangleClient, Selection, isPolylineHitRectangle, - getSelectedElements + getSelectedElements, + toViewBoxPoint, + toHostPoint, + getHitElementByPoint } from '@plait/core'; +import { getTextManages } from '@plait/common'; +import { getHitCell } from '../utils/table'; export const withTable = (board: PlaitBoard) => { - const { drawElement, getRectangle, isRectangleHit, isHit, isMovable, getDeletedFragment } = board; + const { drawElement, getRectangle, isRectangleHit, isHit, isMovable, getDeletedFragment, dblClick } = board; board.drawElement = (context: PlaitPluginElementContext) => { if (PlaitTableElement.isTable(context.element)) { return TableComponent; @@ -58,5 +63,23 @@ export const withTable = (board: PlaitBoard) => { } return isRectangleHit(element, selection); }; + + board.dblClick = (event: MouseEvent) => { + event.preventDefault(); + if (!PlaitBoard.isReadonly(board)) { + const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y)); + const hitElement = getHitElementByPoint(board, point); + if (PlaitTableElement.isTable(hitElement)) { + const hitCell = getHitCell(hitElement, point); + if (hitCell && hitCell.text && hitCell.textHeight) { + const cellIndex = hitElement.cells.indexOf(hitCell); + const textManages = getTextManages(hitElement); + textManages[cellIndex]?.edit(); + } + } + } + dblClick(event); + }; + return board; }; diff --git a/packages/draw/src/table.component.ts b/packages/draw/src/table.component.ts index b8e90c2de..fdee90716 100644 --- a/packages/draw/src/table.component.ts +++ b/packages/draw/src/table.component.ts @@ -5,6 +5,9 @@ import { PlaitTable, PlaitTableCell } from './interfaces/table'; import { PlaitDrawShapeText, TextGenerator } from './generators/text.generator'; import { TableGenerator } from './generators/table.generator'; import { TextManageRef } from '@plait/text'; +import { DrawTransforms } from './transforms'; +import { getCellsWithPoints } from './utils/table'; +import { memorizeLatestText } from './utils'; @Component({ selector: 'plait-draw-table', @@ -63,7 +66,22 @@ export class TableComponent extends CommonPluginElement initializeTextManage() { const texts = this.getDrawShapeTexts(this.element.cells); this.textGenerator = new TextGenerator(this.board, this.element, texts, this.viewContainerRef, { - onValueChangeHandle: (textChangeRef: TextManageRef, text: PlaitDrawShapeText) => {} + onValueChangeHandle: (textManageRef: TextManageRef, text: PlaitDrawShapeText) => { + const cells = getCellsWithPoints(this.element); + const height = textManageRef.height / this.board.viewport.zoom; + const width = textManageRef.width / this.board.viewport.zoom; + if (textManageRef.newValue) { + DrawTransforms.setTableText( + this.board, + this.element, + cells.find(item => item.id === text.key)!, + textManageRef.newValue, + width, + height + ); + } + textManageRef.operations && memorizeLatestText(this.element, textManageRef.operations); + } }); this.textGenerator.initialize(); this.initializeTextManages(this.textGenerator.textManages); diff --git a/packages/draw/src/transforms/index.ts b/packages/draw/src/transforms/index.ts index a0d5d48bf..fa0d141d0 100644 --- a/packages/draw/src/transforms/index.ts +++ b/packages/draw/src/transforms/index.ts @@ -2,6 +2,7 @@ import { insertText, insertGeometry, resizeGeometry, switchGeometryShape, insert import { setText, setTextSize } from './geometry-text'; import { insertImage } from './image'; import { connectLineToGeometry, removeLineText, resizeLine, setLineMark, setLineShape, setLineTexts } from './line'; +import { setTableText } from './table-text'; export const DrawTransforms = { setText, @@ -17,5 +18,6 @@ export const DrawTransforms = { insertImage, switchGeometryShape, connectLineToGeometry, - insertGeometryByVector + insertGeometryByVector, + setTableText }; diff --git a/packages/draw/src/transforms/table-text.ts b/packages/draw/src/transforms/table-text.ts new file mode 100644 index 000000000..6c965fb94 --- /dev/null +++ b/packages/draw/src/transforms/table-text.ts @@ -0,0 +1,45 @@ +import { PlaitBoard, RectangleClient, Transforms } from '@plait/core'; +import { ShapeDefaultSpace } from '../constants'; +import { Element } from 'slate'; +import { PlaitTable, PlaitTableCellParagraph, PlaitTableCellWithPoints } from '../interfaces/table'; + +export const setTableText = ( + board: PlaitBoard, + table: PlaitTable, + cell: PlaitTableCellWithPoints, + text: Element, + textWidth: number, + textHeight: number +) => { + const cellIndex = table.cells.findIndex(item => item.id === cell.id); + let rows = [...table.rows]; + let cells = [...table.cells]; + let points = [...table.points]; + const { height: cellHeight } = RectangleClient.getRectangleByPoints(cell.points); + if (cell.text!.writingMode === 'vertical-lr') { + // 文字高度发生改变,修改该列的宽度 + // update table width + } else { + const rowIdx = table.rows.findIndex(row => row.id === cell.rowId); + const tableRow = table.rows[rowIdx]; + const compareHeight = tableRow.height ?? Math.max(cellHeight, cell.textHeight || 0); + if (textHeight > compareHeight) { + const defaultSpace = ShapeDefaultSpace.rectangleAndText; + const newRowHeight = textHeight + defaultSpace * 2; + rows[rowIdx] = { + ...tableRow, + height: newRowHeight + }; + // update table height + const offset = newRowHeight - compareHeight; + points = [points[0], [points[1][0], points[1][1] + offset]]; + } + } + cells[cellIndex] = { + ...cell, + textHeight: textHeight, + text: text as PlaitTableCellParagraph + }; + const path = board.children.findIndex(child => child === table); + Transforms.setNode(board, { rows, cells, points }, [path]); +}; diff --git a/packages/draw/src/utils/table.ts b/packages/draw/src/utils/table.ts index 9636ee98c..2eceaf31c 100644 --- a/packages/draw/src/utils/table.ts +++ b/packages/draw/src/utils/table.ts @@ -1,4 +1,4 @@ -import { RectangleClient } from '@plait/core'; +import { Point, RectangleClient } from '@plait/core'; import { PlaitTable, PlaitTableCell, PlaitTableCellWithPoints } from '../interfaces/table'; export function getCellsWithPoints(table: PlaitTable): PlaitTableCellWithPoints[] { @@ -74,3 +74,17 @@ function calculateCellSize(cell: PlaitTableCell, sizes: number[], index: number, } return size; } + + +export function getHitCell(table: PlaitTable, point: Point) { + const cells = getCellsWithPoints(table); + const rectangle = RectangleClient.getRectangleByPoints([point, point]); + const cellIndex = cells.findIndex(item => { + const cellRectangle = RectangleClient.getRectangleByPoints(item.points); + return RectangleClient.isHit(rectangle, cellRectangle); + }); + if (cellIndex > -1) { + return table.cells[cellIndex]; + } + return null; +} \ No newline at end of file diff --git a/src/app/editor/mock-data.ts b/src/app/editor/mock-data.ts index 3aea3a6a2..6055f02b3 100644 --- a/src/app/editor/mock-data.ts +++ b/src/app/editor/mock-data.ts @@ -428,49 +428,113 @@ export const mockTableData: PlaitDrawElement[] = [ id: 'cell-2-2', rowId: 'row-2', textHeight: 20, - columnId: 'column-2' + columnId: 'column-2', + text: { + children: [ + { + text: '' + } + ], + align: 'center' + } }, { id: 'cell-2-3', rowId: 'row-2', textHeight: 20, - columnId: 'column-3' + columnId: 'column-3', + text: { + children: [ + { + text: '' + } + ], + align: 'center' + } }, { id: 'cell-3-1', rowId: 'row-3', textHeight: 20, - columnId: 'column-1' + columnId: 'column-1', + text: { + children: [ + { + text: '' + } + ], + align: 'center' + } }, { id: 'cell-3-2', rowId: 'row-3', textHeight: 20, - columnId: 'column-2' + columnId: 'column-2', + text: { + children: [ + { + text: '' + } + ], + align: 'center' + } }, { id: 'cell-3-3', rowId: 'row-3', textHeight: 20, - columnId: 'column-3' + columnId: 'column-3', + text: { + children: [ + { + text: '' + } + ], + align: 'center' + } }, { id: 'cell-4-1', rowId: 'row-4', textHeight: 20, - columnId: 'column-1' + columnId: 'column-1', + text: { + children: [ + { + text: '' + } + ], + align: 'center' + } }, { id: 'cell-4-2', rowId: 'row-4', textHeight: 20, - columnId: 'column-2' + columnId: 'column-2', + text: { + children: [ + { + text: '' + } + ], + align: 'center' + } }, { id: 'cell-4-3', rowId: 'row-4', textHeight: 20, - columnId: 'column-3' + columnId: 'column-3', + text: { + children: [ + { + text: '' + } + ], + align: 'center' + } } ] }, @@ -528,31 +592,71 @@ export const mockTableData: PlaitDrawElement[] = [ id: 'cell-1-2', rowId: 'row-1', textHeight: 20, - columnId: 'column-2' + columnId: 'column-2', + text: { + children: [ + { + text: '' + } + ], + align: 'center' + } }, { id: 'cell-1-3', rowId: 'row-1', textHeight: 20, - columnId: 'column-3' + columnId: 'column-3', + text: { + children: [ + { + text: '' + } + ], + align: 'center' + } }, { id: 'cell-2-2', rowId: 'row-2', textHeight: 20, - columnId: 'column-2' + columnId: 'column-2', + text: { + children: [ + { + text: '' + } + ], + align: 'center' + } }, { id: 'cell-2-3', rowId: 'row-2', textHeight: 20, - columnId: 'column-3' + columnId: 'column-3', + text: { + children: [ + { + text: '' + } + ], + align: 'center' + } }, { id: 'cell-3-2', rowId: 'row-3', textHeight: 20, - columnId: 'column-2' + columnId: 'column-2', + text: { + children: [ + { + text: '' + } + ], + align: 'center' + } }, { id: 'cell-3-3', @@ -572,13 +676,29 @@ export const mockTableData: PlaitDrawElement[] = [ id: 'cell-4-2', rowId: 'row-4', textHeight: 20, - columnId: 'column-2' + columnId: 'column-2', + text: { + children: [ + { + text: '' + } + ], + align: 'center' + } }, { id: 'cell-4-3', rowId: 'row-4', textHeight: 20, - columnId: 'column-3' + columnId: 'column-3', + text: { + children: [ + { + text: '' + } + ], + align: 'center' + } } ] } From 8a326035f52c8553d9dffb5b187b86d1d7a88760 Mon Sep 17 00:00:00 2001 From: huanhuanwa <2323666215@qq.com> Date: Wed, 15 May 2024 10:54:27 +0800 Subject: [PATCH 2/4] feat: add KEY_TO_TEXT_MANAGE Map #WIK-15346 --- .changeset/great-suns-drum.md | 2 + .../src/generators/single-text.generator.ts | 4 +- .../draw/src/generators/text.generator.ts | 33 ++++++++++++---- packages/draw/src/plugins/with-table.ts | 7 +--- packages/draw/src/table.component.ts | 8 ---- packages/draw/src/utils/table.ts | 19 +++++++--- src/app/editor/mock-data.ts | 38 +++++++++---------- 7 files changed, 65 insertions(+), 46 deletions(-) diff --git a/.changeset/great-suns-drum.md b/.changeset/great-suns-drum.md index 442409454..9e97f3b59 100644 --- a/.changeset/great-suns-drum.md +++ b/.changeset/great-suns-drum.md @@ -3,3 +3,5 @@ --- support text edit in cell + +add KEY_TO_TEXT_MANAGE Map diff --git a/packages/draw/src/generators/single-text.generator.ts b/packages/draw/src/generators/single-text.generator.ts index 7d309e727..325d6bc2b 100644 --- a/packages/draw/src/generators/single-text.generator.ts +++ b/packages/draw/src/generators/single-text.generator.ts @@ -30,8 +30,8 @@ export class SingleTextGenerator extends if (!isMultipleTextGeometry((element as unknown) as PlaitCommonGeometry)) { super.update( element, - [{ text: previousText as ParagraphElement, key: element.shape, textHeight: element.textHeight }], - [{ text: currentText as ParagraphElement, key: element.shape, textHeight: element.textHeight }], + [{ text: previousText as ParagraphElement, key: element.id, textHeight: element.textHeight }], + [{ text: currentText as ParagraphElement, key: element.id, textHeight: element.textHeight }], elementG ); } diff --git a/packages/draw/src/generators/text.generator.ts b/packages/draw/src/generators/text.generator.ts index 8fb3f63c9..81bc2116f 100644 --- a/packages/draw/src/generators/text.generator.ts +++ b/packages/draw/src/generators/text.generator.ts @@ -16,6 +16,20 @@ export interface TextGeneratorOptions { onValueChangeHandle: (textChangeRef: TextManageRef, text: PlaitDrawShapeText) => void; } +export const KEY_TO_TEXT_MANAGE: Map = new Map(); + +export const setTextManage = (key: string, textManage: TextManage) => { + return KEY_TO_TEXT_MANAGE.set(key, textManage); +}; + +export const getTextManage = (key: string) => { + return KEY_TO_TEXT_MANAGE.get(key); +}; + +export const deleteTextManage = (key: string) => { + return KEY_TO_TEXT_MANAGE.delete(key); +}; + export class TextGenerator { protected board: PlaitBoard; @@ -50,15 +64,18 @@ export class TextGenerator { initialize() { const textPlugins = ((this.board as PlaitOptionsBoard).getPluginOptions(WithTextPluginKey) || {}).textPlugins; this.textManages = this.texts.map(text => { - return this.createTextManage(text, textPlugins); + const textManage = this.createTextManage(text, textPlugins); + setTextManage(text.key, textManage); + return textManage; }); + ELEMENT_TO_TEXT_MANAGES.set(this.element, this.textManages); } draw(elementG: SVGElement) { const centerPoint = RectangleClient.getCenterPoint(this.board.getRectangle(this.element)!); - this.texts.forEach((drawShapeText, index) => { - const textManage = this.textManages[index]; - if (drawShapeText.text) { + this.texts.forEach(drawShapeText => { + const textManage = getTextManage(drawShapeText.key); + if (drawShapeText.text && textManage) { textManage.draw(drawShapeText.text); elementG.append(textManage.g); this.element.angle && textManage.updateAngle(centerPoint, this.element.angle); @@ -68,10 +85,11 @@ export class TextGenerator { update(element: T, previousDrawShapeTexts: PlaitDrawShapeText[], currentDrawShapeTexts: PlaitDrawShapeText[], elementG: SVGElement) { this.element = element; + ELEMENT_TO_TEXT_MANAGES.set(this.element, this.textManages); const centerPoint = RectangleClient.getCenterPoint(this.board.getRectangle(this.element)!); - currentDrawShapeTexts.forEach((drawShapeText, index) => { - const textManage = this.textManages[index]; - if (drawShapeText.text) { + currentDrawShapeTexts.forEach(drawShapeText => { + const textManage = getTextManage(drawShapeText.key); + if (drawShapeText.text && textManage) { textManage.updateText(drawShapeText.text); textManage.updateRectangle(); this.element.angle && textManage.updateAngle(centerPoint, this.element.angle); @@ -117,5 +135,6 @@ export class TextGenerator { }); this.textManages = []; ELEMENT_TO_TEXT_MANAGES.delete(this.element); + ID_TO_TEXT_MANAGE.clear(); } } diff --git a/packages/draw/src/plugins/with-table.ts b/packages/draw/src/plugins/with-table.ts index dae614c6e..48310add7 100644 --- a/packages/draw/src/plugins/with-table.ts +++ b/packages/draw/src/plugins/with-table.ts @@ -12,8 +12,7 @@ import { toHostPoint, getHitElementByPoint } from '@plait/core'; -import { getTextManages } from '@plait/common'; -import { getHitCell } from '../utils/table'; +import { editCell, getHitCell } from '../utils/table'; export const withTable = (board: PlaitBoard) => { const { drawElement, getRectangle, isRectangleHit, isHit, isMovable, getDeletedFragment, dblClick } = board; @@ -72,9 +71,7 @@ export const withTable = (board: PlaitBoard) => { if (PlaitTableElement.isTable(hitElement)) { const hitCell = getHitCell(hitElement, point); if (hitCell && hitCell.text && hitCell.textHeight) { - const cellIndex = hitElement.cells.indexOf(hitCell); - const textManages = getTextManages(hitElement); - textManages[cellIndex]?.edit(); + editCell(hitCell); } } } diff --git a/packages/draw/src/table.component.ts b/packages/draw/src/table.component.ts index fdee90716..3d0889e5b 100644 --- a/packages/draw/src/table.component.ts +++ b/packages/draw/src/table.component.ts @@ -84,20 +84,12 @@ export class TableComponent extends CommonPluginElement } }); this.textGenerator.initialize(); - this.initializeTextManages(this.textGenerator.textManages); - } - - updateText(previousTable: PlaitTable, currentTable: PlaitTable) { - const previousTexts = this.getDrawShapeTexts(previousTable.cells); - const currentTexts = this.getDrawShapeTexts(currentTable.cells); - this.textGenerator.update(this.element, previousTexts, currentTexts, this.getElementG()); } onContextChanged( value: PlaitPluginElementContext, previous: PlaitPluginElementContext ) { - this.initializeWeakMap(); if (value.element !== previous.element) { this.tableGenerator.processDrawing(this.element, this.getElementG()); this.activeGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), { selected: this.selected }); diff --git a/packages/draw/src/utils/table.ts b/packages/draw/src/utils/table.ts index 2eceaf31c..89ac8494d 100644 --- a/packages/draw/src/utils/table.ts +++ b/packages/draw/src/utils/table.ts @@ -1,5 +1,6 @@ import { Point, RectangleClient } from '@plait/core'; import { PlaitTable, PlaitTableCell, PlaitTableCellWithPoints } from '../interfaces/table'; +import { getTextManage } from '../generators/text.generator'; export function getCellsWithPoints(table: PlaitTable): PlaitTableCellWithPoints[] { const rectangle = RectangleClient.getRectangleByPoints(table.points); @@ -75,16 +76,24 @@ function calculateCellSize(cell: PlaitTableCell, sizes: number[], index: number, return size; } - export function getHitCell(table: PlaitTable, point: Point) { const cells = getCellsWithPoints(table); const rectangle = RectangleClient.getRectangleByPoints([point, point]); - const cellIndex = cells.findIndex(item => { + const cell = cells.find(item => { const cellRectangle = RectangleClient.getRectangleByPoints(item.points); return RectangleClient.isHit(rectangle, cellRectangle); }); - if (cellIndex > -1) { - return table.cells[cellIndex]; + if (cell) { + return table.cells.find(item => item.id === cell.id); } return null; -} \ No newline at end of file +} + +export function editCell(cell: PlaitTableCell) { + const textManage = getTextManageByCell(cell); + textManage && textManage.edit(); +} + +export function getTextManageByCell(cell: PlaitTableCell) { + return getTextManage(cell.id); +} diff --git a/src/app/editor/mock-data.ts b/src/app/editor/mock-data.ts index 6055f02b3..8e87eda00 100644 --- a/src/app/editor/mock-data.ts +++ b/src/app/editor/mock-data.ts @@ -396,7 +396,7 @@ export const mockTableData: PlaitDrawElement[] = [ ], cells: [ { - id: 'cell-1-1', + id: 'v-cell-1-1', rowId: 'row-1', columnId: 'column-1', colspan: 3, @@ -411,7 +411,7 @@ export const mockTableData: PlaitDrawElement[] = [ } }, { - id: 'cell-2-1', + id: 'v-cell-2-1', rowId: 'row-2', textHeight: 20, columnId: 'column-1', @@ -425,7 +425,7 @@ export const mockTableData: PlaitDrawElement[] = [ } }, { - id: 'cell-2-2', + id: 'v-cell-2-2', rowId: 'row-2', textHeight: 20, columnId: 'column-2', @@ -439,7 +439,7 @@ export const mockTableData: PlaitDrawElement[] = [ } }, { - id: 'cell-2-3', + id: 'v-cell-2-3', rowId: 'row-2', textHeight: 20, columnId: 'column-3', @@ -453,7 +453,7 @@ export const mockTableData: PlaitDrawElement[] = [ } }, { - id: 'cell-3-1', + id: 'v-cell-3-1', rowId: 'row-3', textHeight: 20, columnId: 'column-1', @@ -467,7 +467,7 @@ export const mockTableData: PlaitDrawElement[] = [ } }, { - id: 'cell-3-2', + id: 'v-cell-3-2', rowId: 'row-3', textHeight: 20, columnId: 'column-2', @@ -481,7 +481,7 @@ export const mockTableData: PlaitDrawElement[] = [ } }, { - id: 'cell-3-3', + id: 'v-cell-3-3', rowId: 'row-3', textHeight: 20, columnId: 'column-3', @@ -495,7 +495,7 @@ export const mockTableData: PlaitDrawElement[] = [ } }, { - id: 'cell-4-1', + id: 'v-cell-4-1', rowId: 'row-4', textHeight: 20, columnId: 'column-1', @@ -509,7 +509,7 @@ export const mockTableData: PlaitDrawElement[] = [ } }, { - id: 'cell-4-2', + id: 'v-cell-4-2', rowId: 'row-4', textHeight: 20, columnId: 'column-2', @@ -523,7 +523,7 @@ export const mockTableData: PlaitDrawElement[] = [ } }, { - id: 'cell-4-3', + id: 'v-cell-4-3', rowId: 'row-4', textHeight: 20, columnId: 'column-3', @@ -574,7 +574,7 @@ export const mockTableData: PlaitDrawElement[] = [ ], cells: [ { - id: 'cell-1-1', + id: 'h-cell-1-1', rowId: 'row-1', columnId: 'column-1', textHeight: 20, @@ -589,7 +589,7 @@ export const mockTableData: PlaitDrawElement[] = [ } }, { - id: 'cell-1-2', + id: 'h-cell-1-2', rowId: 'row-1', textHeight: 20, columnId: 'column-2', @@ -603,7 +603,7 @@ export const mockTableData: PlaitDrawElement[] = [ } }, { - id: 'cell-1-3', + id: 'h-cell-1-3', rowId: 'row-1', textHeight: 20, columnId: 'column-3', @@ -617,7 +617,7 @@ export const mockTableData: PlaitDrawElement[] = [ } }, { - id: 'cell-2-2', + id: 'h-cell-2-2', rowId: 'row-2', textHeight: 20, columnId: 'column-2', @@ -631,7 +631,7 @@ export const mockTableData: PlaitDrawElement[] = [ } }, { - id: 'cell-2-3', + id: 'h-cell-2-3', rowId: 'row-2', textHeight: 20, columnId: 'column-3', @@ -645,7 +645,7 @@ export const mockTableData: PlaitDrawElement[] = [ } }, { - id: 'cell-3-2', + id: 'h-cell-3-2', rowId: 'row-3', textHeight: 20, columnId: 'column-2', @@ -659,7 +659,7 @@ export const mockTableData: PlaitDrawElement[] = [ } }, { - id: 'cell-3-3', + id: 'h-cell-3-3', rowId: 'row-3', textHeight: 20, columnId: 'column-3', @@ -673,7 +673,7 @@ export const mockTableData: PlaitDrawElement[] = [ } }, { - id: 'cell-4-2', + id: 'h-cell-4-2', rowId: 'row-4', textHeight: 20, columnId: 'column-2', @@ -687,7 +687,7 @@ export const mockTableData: PlaitDrawElement[] = [ } }, { - id: 'cell-4-3', + id: 'h-cell-4-3', rowId: 'row-4', textHeight: 20, columnId: 'column-3', From 2a6a17367dbeabacbd51af0e9840f2f7e248365f Mon Sep 17 00:00:00 2001 From: huanhuanwa <2323666215@qq.com> Date: Wed, 15 May 2024 10:54:52 +0800 Subject: [PATCH 3/4] fix: rename --- packages/draw/src/generators/text.generator.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/draw/src/generators/text.generator.ts b/packages/draw/src/generators/text.generator.ts index 81bc2116f..e0daa6c87 100644 --- a/packages/draw/src/generators/text.generator.ts +++ b/packages/draw/src/generators/text.generator.ts @@ -135,6 +135,6 @@ export class TextGenerator { }); this.textManages = []; ELEMENT_TO_TEXT_MANAGES.delete(this.element); - ID_TO_TEXT_MANAGE.clear(); + KEY_TO_TEXT_MANAGE.clear(); } } From 6a2ef3fd7f2338852a8446d1f29fb2047f6388e1 Mon Sep 17 00:00:00 2001 From: huanhuanwa <2323666215@qq.com> Date: Wed, 15 May 2024 11:02:07 +0800 Subject: [PATCH 4/4] fix: optimize code --- packages/draw/src/geometry.component.ts | 4 ---- packages/draw/src/plugins/with-table.ts | 2 +- 2 files changed, 1 insertion(+), 5 deletions(-) diff --git a/packages/draw/src/geometry.component.ts b/packages/draw/src/geometry.component.ts index 45b1c313c..874a98b9d 100644 --- a/packages/draw/src/geometry.component.ts +++ b/packages/draw/src/geometry.component.ts @@ -90,7 +90,6 @@ export class GeometryComponent extends CommonPluginElement, previous: PlaitPluginElementContext ) { - this.initializeWeakMap(); const isChangeTheme = this.board.operations.find(op => op.type === 'set_theme'); if (value.element !== previous.element || isChangeTheme) { this.shapeGenerator.processDrawing(this.element as PlaitGeometry, this.getElementG()); @@ -162,9 +161,7 @@ export class GeometryComponent extends CommonPluginElement { if (!PlaitBoard.isReadonly(board)) { const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y)); const hitElement = getHitElementByPoint(board, point); - if (PlaitTableElement.isTable(hitElement)) { + if (hitElement && PlaitTableElement.isTable(hitElement)) { const hitCell = getHitCell(hitElement, point); if (hitCell && hitCell.text && hitCell.textHeight) { editCell(hitCell);