@visactor/vtable-sheet 1.21.1 → 1.22.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/cjs/core/WorkSheet.d.ts +2 -1
- package/cjs/core/WorkSheet.js +46 -9
- package/cjs/core/WorkSheet.js.map +1 -1
- package/cjs/formula/formula-engine.d.ts +13 -0
- package/cjs/formula/formula-engine.js +206 -3
- package/cjs/formula/formula-engine.js.map +1 -1
- package/cjs/index.d.ts +1 -1
- package/cjs/index.js +1 -1
- package/cjs/index.js.map +1 -1
- package/cjs/managers/formula-manager.d.ts +6 -6
- package/cjs/managers/formula-manager.js +61 -8
- package/cjs/managers/formula-manager.js.map +1 -1
- package/cjs/ts-types/sheet.d.ts +0 -1
- package/cjs/ts-types/sheet.js.map +1 -1
- package/dist/vtable-sheet.js +796 -187
- package/dist/vtable-sheet.min.js +1 -1
- package/es/core/WorkSheet.d.ts +2 -1
- package/es/core/WorkSheet.js +46 -9
- package/es/core/WorkSheet.js.map +1 -1
- package/es/formula/formula-engine.d.ts +13 -0
- package/es/formula/formula-engine.js +206 -3
- package/es/formula/formula-engine.js.map +1 -1
- package/es/index.d.ts +1 -1
- package/es/index.js +1 -1
- package/es/index.js.map +1 -1
- package/es/managers/formula-manager.d.ts +6 -6
- package/es/managers/formula-manager.js +61 -8
- package/es/managers/formula-manager.js.map +1 -1
- package/es/ts-types/sheet.d.ts +0 -1
- package/es/ts-types/sheet.js.map +1 -1
- package/package.json +6 -6
package/cjs/core/WorkSheet.d.ts
CHANGED
|
@@ -39,6 +39,8 @@ export declare class WorkSheet extends EventTarget implements IWorkSheetAPI {
|
|
|
39
39
|
private handleSelectionChanged;
|
|
40
40
|
private handleDragSelectEnd;
|
|
41
41
|
private handleCellValueChanged;
|
|
42
|
+
private handleDataRecordsChanged;
|
|
43
|
+
private handleColumnsChanged;
|
|
42
44
|
protected fireEvent(eventName: string, eventData: any): void;
|
|
43
45
|
on(eventName: string, handler: (...args: any[]) => void): this;
|
|
44
46
|
private resizeTimer;
|
|
@@ -53,7 +55,6 @@ export declare class WorkSheet extends EventTarget implements IWorkSheetAPI {
|
|
|
53
55
|
getColumns(): ColumnDefine[];
|
|
54
56
|
getData(): any[][];
|
|
55
57
|
getCopiedData(): any[][];
|
|
56
|
-
setData(data: any[][]): void;
|
|
57
58
|
getCellValue(row: number, col: number): any;
|
|
58
59
|
setCellValue(row: number, col: number, value: any): void;
|
|
59
60
|
getCellByAddress(address: string): {
|
package/cjs/core/WorkSheet.js
CHANGED
|
@@ -114,6 +114,14 @@ class WorkSheet extends event_target_1.EventTarget {
|
|
|
114
114
|
this.handleDragSelectEnd(event);
|
|
115
115
|
})), this.tableInstance.on("change_cell_value", (event => {
|
|
116
116
|
this.handleCellValueChanged(event);
|
|
117
|
+
})), this.tableInstance.on("add_record", (event => {
|
|
118
|
+
this.handleDataRecordsChanged("add", event);
|
|
119
|
+
})), this.tableInstance.on("delete_record", (event => {
|
|
120
|
+
this.handleDataRecordsChanged("delete", event);
|
|
121
|
+
})), this.tableInstance.on("add_column", (event => {
|
|
122
|
+
this.handleColumnsChanged("add", event);
|
|
123
|
+
})), this.tableInstance.on("delete_column", (event => {
|
|
124
|
+
this.handleColumnsChanged("delete", event);
|
|
117
125
|
})), this.tableInstance.on("click_cell", (() => {
|
|
118
126
|
this.element.classList.add("vtable-excel-cursor");
|
|
119
127
|
})));
|
|
@@ -183,6 +191,44 @@ class WorkSheet extends event_target_1.EventTarget {
|
|
|
183
191
|
};
|
|
184
192
|
this.fire(ts_types_1.WorkSheetEventType.CELL_VALUE_CHANGED, cellValueChangedEvent);
|
|
185
193
|
}
|
|
194
|
+
handleDataRecordsChanged(type, event) {
|
|
195
|
+
try {
|
|
196
|
+
const sheetKey = this.getKey(), normalizedData = this.vtableSheet.formulaManager.normalizeSheetData(this.tableInstance.records, this.tableInstance);
|
|
197
|
+
if (this.vtableSheet.formulaManager.formulaEngine.updateSheetData(sheetKey, normalizedData),
|
|
198
|
+
"add" === type) {
|
|
199
|
+
const {recordIndex: recordIndex, recordCount: recordCount} = event;
|
|
200
|
+
if (void 0 !== recordIndex && recordCount > 0) this.vtableSheet.formulaManager.addRows(sheetKey, recordIndex, recordCount); else {
|
|
201
|
+
const currentRowCount = this.getRowCount();
|
|
202
|
+
this.vtableSheet.formulaManager.addRows(sheetKey, currentRowCount, recordCount);
|
|
203
|
+
}
|
|
204
|
+
} else if ("delete" === type) {
|
|
205
|
+
const {rowIndexs: rowIndexs, deletedCount: deletedCount} = event;
|
|
206
|
+
if (rowIndexs && rowIndexs.length > 0) {
|
|
207
|
+
const minIndex = Math.min(...rowIndexs.flat());
|
|
208
|
+
this.vtableSheet.formulaManager.removeRows(sheetKey, minIndex, deletedCount);
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
} catch (error) {}
|
|
212
|
+
}
|
|
213
|
+
handleColumnsChanged(type, event) {
|
|
214
|
+
try {
|
|
215
|
+
const sheetKey = this.getKey(), normalizedData = this.vtableSheet.formulaManager.normalizeSheetData(this.tableInstance.records, this.tableInstance);
|
|
216
|
+
if (this.vtableSheet.formulaManager.formulaEngine.updateSheetData(sheetKey, normalizedData),
|
|
217
|
+
"add" === type) {
|
|
218
|
+
const {columnIndex: columnIndex, columnCount: columnCount} = event;
|
|
219
|
+
if (void 0 !== columnIndex && columnCount > 0) this.vtableSheet.formulaManager.addColumns(sheetKey, columnIndex, columnCount); else {
|
|
220
|
+
const currentColumnCount = this.getColumnCount();
|
|
221
|
+
this.vtableSheet.formulaManager.addColumns(sheetKey, currentColumnCount, columnCount);
|
|
222
|
+
}
|
|
223
|
+
} else if ("delete" === type) {
|
|
224
|
+
const {deleteColIndexs: deleteColIndexs} = event;
|
|
225
|
+
if (deleteColIndexs && deleteColIndexs.length > 0) {
|
|
226
|
+
const minIndex = Math.min(...deleteColIndexs.flat()), deletedCount = deleteColIndexs.length;
|
|
227
|
+
this.vtableSheet.formulaManager.removeColumns(sheetKey, minIndex, deletedCount);
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
} catch (error) {}
|
|
231
|
+
}
|
|
186
232
|
fireEvent(eventName, eventData) {
|
|
187
233
|
this.fire(eventName, eventData);
|
|
188
234
|
}
|
|
@@ -229,15 +275,6 @@ class WorkSheet extends event_target_1.EventTarget {
|
|
|
229
275
|
getCopiedData() {
|
|
230
276
|
return this.getData().map((row => Array.isArray(row) ? row.slice() : []));
|
|
231
277
|
}
|
|
232
|
-
setData(data) {
|
|
233
|
-
var _a;
|
|
234
|
-
if (this.options.data = data, this.tableInstance && (this.tableInstance.updateOption({
|
|
235
|
-
records: data
|
|
236
|
-
}), null === (_a = this.vtableSheet) || void 0 === _a ? void 0 : _a.formulaManager)) try {
|
|
237
|
-
const normalizedData = this.vtableSheet.formulaManager.normalizeSheetData(data, this.tableInstance);
|
|
238
|
-
this.vtableSheet.formulaManager.setSheetContent(this.sheetKey, normalizedData);
|
|
239
|
-
} catch (e) {}
|
|
240
|
-
}
|
|
241
278
|
getCellValue(row, col) {
|
|
242
279
|
if (this.tableInstance) try {
|
|
243
280
|
return this.tableInstance.getCellValue(col, row);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/core/WorkSheet.ts"],"names":[],"mappings":"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","file":"WorkSheet.js","sourcesContent":["import type { ColumnDefine, ListTableConstructorOptions } from '@visactor/vtable';\nimport { ListTable } from '@visactor/vtable';\nimport { isValid, type EventEmitter } from '@visactor/vutils';\nimport { EventTarget } from '../event/event-target';\nimport type {\n IWorkSheetOptions,\n IWorkSheetAPI,\n CellCoord,\n CellRange,\n CellValue,\n CellValueChangedEvent,\n CellClickEvent,\n SelectionChangedEvent,\n IFormulaManagerOptions\n} from '../ts-types';\nimport { WorkSheetEventType } from '../ts-types';\nimport type { TYPES, VTableSheet } from '..';\nimport { isPropertyWritable } from '../tools';\nimport { VTableThemes } from '../ts-types';\nimport { detectFunctionParameterPosition } from '../formula/formula-helper';\n\n/**\n * Sheet constructor options. 内部类型Sheet的构造函数参数类型\n */\nexport type WorkSheetConstructorOptions = {\n /** 表格数据 */\n data?: any[][];\n /** 公式计算选项 */\n formula?: IFormulaManagerOptions;\n /** Sheet 唯一标识 */\n sheetKey: string;\n /** Sheet 标题 */\n sheetTitle: string;\n} & Omit<ListTableConstructorOptions, 'records'>;\n\nexport class WorkSheet extends EventTarget implements IWorkSheetAPI {\n /** 选项 */\n options: IWorkSheetOptions;\n /** 容器 */\n container: HTMLElement;\n /** 表格实例 */\n tableInstance?: ListTable;\n /** 元素 */\n element: HTMLElement;\n /** 选择范围 */\n private selection: CellRange | null = null;\n /** Sheet 唯一标识 */\n private sheetKey: string;\n /** Sheet 标题 */\n private sheetTitle: string;\n\n /** 事件总线 */\n private eventBus: EventEmitter;\n\n private vtableSheet: VTableSheet;\n\n editingCell: { sheet: string; row: number; col: number } | null = null;\n\n constructor(sheet: VTableSheet, options: IWorkSheetOptions) {\n super();\n this.options = options;\n this.container = options.container;\n\n // 初始化基本属性\n this.sheetKey = options.sheetKey;\n this.sheetTitle = options.sheetTitle;\n this.vtableSheet = sheet;\n\n // 创建表格元素\n this.element = this._createRootElement();\n this.container.appendChild(this.element);\n\n // 初始化表格\n this._initializeTable();\n\n // 设置事件监听\n this._setupEventListeners();\n }\n\n /**\n * 获取行数\n */\n get rowCount(): number {\n const data = this.getData();\n return data ? data.length : 0;\n }\n\n /**\n * 获取列数\n */\n get colCount(): number {\n const data = this.getData();\n return data && data.length > 0 ? data[0].length : 0;\n }\n\n /**\n * 获取行数\n */\n getRowCount(): number {\n return this.tableInstance.rowCount;\n }\n\n /**\n * 获取列数\n */\n getColumnCount(): number {\n return this.tableInstance.colCount;\n }\n\n /**\n * 获取表格数据\n */\n get records(): any {\n return this.getData();\n }\n\n /**\n * 获取列定义\n */\n get columns(): any {\n return this.options.columns || [];\n }\n\n /**\n * 创建根元素\n */\n private _createRootElement(): HTMLElement {\n const element = document.createElement('div');\n element.setAttribute('sheet-key', `${this.sheetKey}`);\n element.classList.add('vtable-sheet');\n element.style.outline = 'none';\n element.style.position = 'relative';\n\n const width = this.container.clientWidth || 800;\n const height = this.container.clientHeight || 600;\n\n element.style.width = `${width}px`;\n element.style.height = `${height}px`;\n\n return element;\n }\n\n /**\n * 初始化表格实例\n */\n private _initializeTable(): void {\n // 这里应该是实际的表格初始化逻辑\n const tableOptions = this._generateTableOptions();\n this.tableInstance = new ListTable(tableOptions);\n this.element.classList.add('vtable-excel-cursor');\n // 获取事件总线\n this.eventBus = (this.tableInstance as any).eventBus;\n }\n\n /**\n * 生成VTable选项\n */\n private _generateTableOptions(): ListTableConstructorOptions {\n let isShowTableHeader = this.options.showHeader;\n // 转换为ListTable的选项\n if (!this.options.columns) {\n isShowTableHeader = isValid(isShowTableHeader) ? isShowTableHeader : false;\n this.options.columns = [];\n } else {\n for (let i = 0; i < this.options.columns.length; i++) {\n this.options.columns[i].field = i;\n }\n }\n if (!this.options.data) {\n this.options.data = [];\n } else if (this.options.columns.length === 0 && this.options.firstRowAsHeader) {\n const data = this.options.data;\n if (data && data.length > 0) {\n for (let i = 0; i < data[0].length; i++) {\n this.options.columns[i] = {\n field: i,\n title: data[0][i],\n filter: !!this.options.filter\n };\n }\n }\n data.shift();\n isShowTableHeader = true;\n }\n const keyboardOptions = {\n ...this.options.keyboardOptions,\n copySelected: true,\n pasteValueToCell: true,\n showCopyCellBorder: true,\n cutSelected: true\n };\n\n //更改theme 的frameStyle\n let changedTheme: TYPES.VTableThemes.ITableThemeDefine;\n if (!this.options?.theme) {\n this.options.theme = VTableThemes.DEFAULT;\n }\n this.options.theme = this.options.theme;\n if (this.options.theme.bodyStyle && !isPropertyWritable(this.options.theme, 'bodyStyle')) {\n //测试是否使用了主题 使用了主题配置项不可写。\n changedTheme = (this.options.theme as TYPES.VTableThemes.TableTheme).extends(\n (this.options.theme as TYPES.VTableThemes.TableTheme).getExtendTheme()\n ); //防止将原主题如DARK ARCO的属性改掉\n const extendThemeOption = (changedTheme as TYPES.VTableThemes.TableTheme).getExtendTheme();\n\n extendThemeOption.frameStyle = Object.assign({}, extendThemeOption.frameStyle, {\n shadowBlur: 0,\n cornerRadius: 0,\n borderLineWidth: 0\n });\n } else {\n changedTheme = this.options.theme;\n changedTheme.frameStyle = Object.assign({}, this.options.theme.frameStyle, {\n shadowBlur: 0,\n cornerRadius: 0,\n borderLineWidth: 0\n });\n }\n return {\n ...this.options,\n addRecordRule: 'Array',\n defaultCursor: 'cell',\n records: this.options.data,\n sortState: this.options.sortState,\n container: this.element,\n showHeader: isShowTableHeader,\n keyboardOptions,\n theme: changedTheme,\n excelOptions: {\n fillHandle: true\n },\n customConfig: {\n selectCellWhenCellEditorNotExists: true\n }\n // maintainedColumnCount: 120\n // 其他特定配置\n };\n }\n\n /**\n * 设置事件监听\n */\n private _setupEventListeners(): void {\n if (this.tableInstance) {\n // 监听单元格选择事件 - 优化:移除console.log调试代码\n this.tableInstance.on('mousedown_cell', (event: any) => {\n if (this.vtableSheet.formulaManager.formulaWorkingOnCell) {\n //防止公式输入状态下,原本的input元素blur掉,导致公式输入框无法输入\n event.event.preventDefault();\n }\n });\n\n // 监听选择变化事件(多选时)\n this.tableInstance.on('selected_changed' as any, (event: any) => {\n // 判断是drag过程中的选中单元格变化\n if (!this.tableInstance.eventManager.isDraging) {\n if (!this.vtableSheet.formulaManager.formulaWorkingOnCell) {\n this.editingCell = {\n sheet: this.getKey(),\n row: event.row,\n col: event.col\n };\n }\n this.handleCellSelected(event);\n }\n this.handleSelectionChanged(event);\n });\n\n // 监听拖拽选择结束事件 - 优化:移除console.log和debugger调试代码\n this.tableInstance.on('drag_select_end' as any, (event: any) => {\n this.handleDragSelectEnd(event);\n });\n\n // 监听单元格值变更事件\n this.tableInstance.on('change_cell_value', (event: any) => {\n this.handleCellValueChanged(event);\n });\n\n // 监听编辑结束事件,恢复十字光标\n this.tableInstance.on('click_cell', () => {\n this.element.classList.add('vtable-excel-cursor');\n });\n }\n }\n\n /**\n * 处理单元格选择事件\n * @param event 选择事件\n */\n private handleCellSelected(event: any): void {\n // 更新选择范围\n this.selection = {\n startRow: event.row,\n startCol: event.col,\n endRow: event.row,\n endCol: event.col\n };\n\n // 使用事件类型枚举触发事件给父组件\n const cellSelectedEvent: CellClickEvent = {\n row: event.row,\n col: event.col,\n value: event.value,\n cellElement: event.cellElement,\n originalEvent: event.originalEvent\n };\n this.fire(WorkSheetEventType.CELL_CLICK, cellSelectedEvent);\n }\n\n /**\n * 处理选择变化事件\n * @param event 选择变化事件\n */\n private handleSelectionChanged(event: any): void {\n if (event?.ranges?.length) {\n const r = event.ranges[event.ranges.length - 1];\n this.selection = {\n startRow: r.start.row,\n startCol: r.start.col,\n endRow: r.end.row,\n endCol: r.end.col\n };\n }\n // 保持原始事件结构,同时确保类型符合定义\n const selectionChangedEvent: SelectionChangedEvent = {\n row: event.row,\n col: event.col,\n ranges: event.ranges,\n cells: event.cells,\n originalEvent: event.originalEvent\n };\n this.fire(WorkSheetEventType.SELECTION_CHANGED, selectionChangedEvent);\n }\n\n /**\n * 处理拖拽选择结束事件\n * @param event 拖拽选择结束事件\n */\n private handleDragSelectEnd(event: any): void {\n if (event?.cells?.length) {\n const first = event.cells[0][0];\n const lastRow = event.cells[event.cells.length - 1];\n const last = lastRow[lastRow.length - 1];\n this.selection = {\n startRow: first.row,\n startCol: first.col,\n endRow: last.row,\n endCol: last.col\n };\n }\n // 保持原始事件结构,同时确保类型符合定义\n const selectionEndEvent: SelectionChangedEvent = {\n row: event.row,\n col: event.col,\n ranges: event.ranges,\n cells: event.cells,\n originalEvent: event.originalEvent\n };\n this.fire(WorkSheetEventType.SELECTION_END, selectionEndEvent);\n }\n\n /**\n * 处理单元格值变更事件\n * @param event 值变更事件\n */\n private handleCellValueChanged(event: any): void {\n const cellValueChangedEvent: CellValueChangedEvent = {\n row: event.row,\n col: event.col,\n oldValue: event.rawValue,\n newValue: event.changedValue\n };\n this.fire(WorkSheetEventType.CELL_VALUE_CHANGED, cellValueChangedEvent);\n }\n\n /**\n * 触发事件\n * @param eventName 事件名称\n * @param eventData 事件数据\n */\n protected fireEvent(eventName: string, eventData: any): void {\n this.fire(eventName, eventData);\n }\n\n /**\n * 监听事件\n * @param eventName 事件名称\n * @param handler 事件处理函数\n */\n on(eventName: string, handler: (...args: any[]) => void): this {\n return super.on(eventName, handler);\n }\n\n // 用于防止短时间内多次调用resize的节流变量\n private resizeTimer: number | null = null;\n private isResizing = false;\n\n /**\n * 更新Sheet大小\n * 使用节流方式避免频繁调用resize\n */\n resize(): void {\n if (!this.element) {\n return;\n }\n\n // 如果正在进行调整,清除之前的定时器\n if (this.resizeTimer !== null) {\n window.clearTimeout(this.resizeTimer);\n this.resizeTimer = null;\n }\n\n // 如果已经在执行resize,设置一个短期延迟\n if (this.isResizing) {\n this.resizeTimer = window.setTimeout(() => {\n this.doResize();\n this.resizeTimer = null;\n }, 50);\n return;\n }\n\n // 否则直接执行resize\n this.doResize();\n }\n\n /**\n * 实际执行调整大小的操作\n * @private\n */\n private doResize(): void {\n try {\n this.isResizing = true;\n\n const width = this.container.clientWidth || 800;\n const height = this.container.clientHeight || 600;\n\n // 只有尺寸确实变化时才更新样式和触发表格实例的resize\n if (parseInt(this.element.style.width, 10) !== width || parseInt(this.element.style.height, 10) !== height) {\n this.element.style.width = `${width}px`;\n this.element.style.height = `${height}px`;\n\n // 更新表格实例大小\n if (this.tableInstance) {\n // 触发VTable的resize\n this.tableInstance.resize();\n }\n }\n } catch (error) {\n console.error('Error during resize:', error);\n } finally {\n this.isResizing = false;\n }\n }\n\n /**\n * 获取Sheet元素\n */\n getElement(): HTMLElement {\n return this.element;\n }\n\n /**\n * 获取Sheet容器\n */\n getContainer(): HTMLElement {\n return this.container;\n }\n\n /**\n * 获取Sheet的key\n */\n getKey(): string {\n return this.sheetKey;\n }\n\n /**\n * 获取Sheet的标题\n */\n getTitle(): string {\n return this.sheetTitle;\n }\n\n /**\n * 设置Sheet的标题\n */\n setTitle(title: string): void {\n this.sheetTitle = title;\n this.options.sheetTitle = title;\n }\n\n /**\n * 获取列定义\n */\n getColumns(): ColumnDefine[] {\n return this.options.columns || [];\n }\n\n /**\n * 获取表格数据\n */\n getData(): any[][] {\n // 从表格实例获取数据\n return this.options.data || [];\n }\n\n getCopiedData(): any[][] {\n // 为了避免影响当前数据,所以需要复制一份数据\n return this.getData().map(row => (Array.isArray(row) ? row.slice() : []));\n }\n\n /**\n * 设置表格数据\n * @param data 表格数据\n */\n setData(data: any[][]): void {\n this.options.data = data;\n // 更新表格实例数据\n if (this.tableInstance) {\n this.tableInstance.updateOption({\n records: data\n });\n // 更新公式引擎中的数据\n if (this.vtableSheet?.formulaManager) {\n try {\n const normalizedData = this.vtableSheet.formulaManager.normalizeSheetData(data, this.tableInstance);\n this.vtableSheet.formulaManager.setSheetContent(this.sheetKey, normalizedData);\n } catch (e) {\n console.warn('Failed to update formula data:', e);\n }\n }\n }\n }\n /**\n * 获取指定坐标的单元格值\n * @param row 行索引\n * @param col 列索引\n */\n getCellValue(row: number, col: number): any {\n if (this.tableInstance) {\n try {\n const value = this.tableInstance.getCellValue(col, row);\n return value;\n } catch (error) {\n console.warn('Failed to get cell value from VTable:', error);\n }\n }\n\n const data = this.getData();\n if (data && data[row] && data[row][col] !== undefined) {\n return data[row][col];\n }\n return null;\n }\n\n /**\n * 设置指定坐标的单元格值\n * @param row 行索引\n * @param col 列索引\n * @param value 新值\n */\n setCellValue(row: number, col: number, value: any): void {\n const data = this.getData();\n if (data && data[row]) {\n const oldValue = data[row][col];\n data[row][col] = value;\n\n // 更新表格实例\n if (this.tableInstance) {\n this.tableInstance.changeCellValue(col, row, value);\n }\n\n // 触发事件\n const event: CellValueChangedEvent = {\n row,\n col,\n oldValue,\n newValue: value\n };\n\n this.fire('cellValueChanged', event);\n }\n }\n\n /**\n * 根据A1地址获取单元格信息\n * @param address A1地址\n */\n getCellByAddress(address: string): { coord: CellCoord; value: CellValue } {\n const coord = this.coordFromAddress(address);\n return {\n coord,\n value: this.getCellValue(coord.row, coord.col)\n };\n }\n\n /**\n * 将行/列坐标转换为A1格式\n * @param coord 坐标\n */\n addressFromCoord(coord: CellCoord): string;\n addressFromCoord(row: number, col: number): string;\n addressFromCoord(coordOrRow: CellCoord | number, col?: number): string {\n let row: number;\n let colNum: number;\n\n if (typeof coordOrRow === 'object') {\n row = coordOrRow.row;\n colNum = coordOrRow.col;\n } else {\n row = coordOrRow;\n colNum = col!;\n }\n\n let colStr = '';\n let tempCol = colNum + 1;\n\n do {\n tempCol -= 1;\n colStr = String.fromCharCode(65 + (tempCol % 26)) + colStr;\n tempCol = Math.floor(tempCol / 26);\n } while (tempCol > 0);\n\n return `${colStr}${row + 1}`;\n }\n\n /**\n * 将A1格式转换为行/列坐标\n * @param address A1地址\n */\n coordFromAddress(address: string): CellCoord {\n const match = address.match(/^([A-Z]+)([0-9]+)$/);\n if (!match) {\n throw new Error(`Invalid cell address: ${address}`);\n }\n\n const colStr = match[1];\n const rowStr = match[2];\n\n let col = 0;\n for (let i = 0; i < colStr.length; i++) {\n col = col * 26 + (colStr.charCodeAt(i) - 64);\n }\n\n return {\n row: parseInt(rowStr, 10) - 1,\n col: col - 1\n };\n }\n\n /**\n * 获取当前选择\n */\n getSelection(): CellRange | null {\n return this.selection;\n }\n\n /**\n * 获取多个选择范围(支持Ctrl/Cmd多选)\n */\n getMultipleSelections(): CellRange[] {\n if (!this.tableInstance) {\n return this.selection ? [this.selection] : [];\n }\n\n // 从底层VTable获取所有选择范围\n const vtableRanges = this.tableInstance.getSelectedCellRanges();\n\n if (vtableRanges.length === 0) {\n return this.selection ? [this.selection] : [];\n }\n\n // 转换VTable的坐标格式到WorkSheet格式\n return vtableRanges.map(range => ({\n startRow: range.start.row,\n startCol: range.start.col,\n endRow: range.end.row,\n endCol: range.end.col\n }));\n }\n\n /**\n * 将第一行设置为表头\n */\n setFirstRowAsHeader(): void {\n const data = this.getData();\n if (data && data.length > 0) {\n for (let i = 0; i < data[0].length; i++) {\n if (!this.options.columns[i]) {\n this.options.columns[i] = {\n field: i,\n title: data[0][i]\n };\n } else {\n this.options.columns[i].title = data[0][i];\n this.options.columns[i].field = i;\n }\n }\n }\n data.shift();\n this.tableInstance.updateOption({\n ...this.options,\n columns: this.options.columns,\n showHeader: true,\n records: data\n });\n }\n\n /**\n * 释放资源\n */\n release(): void {\n // 清理事件监听器\n\n // 释放表格实例\n if (this.tableInstance) {\n this.tableInstance.release();\n }\n\n // 从DOM中移除元素\n if (this.element && this.element.parentNode) {\n this.element.parentNode.removeChild(this.element);\n }\n\n // 清除引用\n this.tableInstance?.release();\n }\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/core/WorkSheet.ts"],"names":[],"mappings":"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","file":"WorkSheet.js","sourcesContent":["import type { ColumnDefine, ListTableConstructorOptions } from '@visactor/vtable';\nimport { ListTable } from '@visactor/vtable';\nimport { isValid, type EventEmitter } from '@visactor/vutils';\nimport { EventTarget } from '../event/event-target';\nimport type {\n IWorkSheetOptions,\n IWorkSheetAPI,\n CellCoord,\n CellRange,\n CellValue,\n CellValueChangedEvent,\n CellClickEvent,\n SelectionChangedEvent,\n IFormulaManagerOptions\n} from '../ts-types';\nimport { WorkSheetEventType } from '../ts-types';\nimport type { TYPES, VTableSheet } from '..';\nimport { isPropertyWritable } from '../tools';\nimport { VTableThemes } from '../ts-types';\nimport { detectFunctionParameterPosition } from '../formula/formula-helper';\n\n/**\n * Sheet constructor options. 内部类型Sheet的构造函数参数类型\n */\nexport type WorkSheetConstructorOptions = {\n /** 表格数据 */\n data?: any[][];\n /** 公式计算选项 */\n formula?: IFormulaManagerOptions;\n /** Sheet 唯一标识 */\n sheetKey: string;\n /** Sheet 标题 */\n sheetTitle: string;\n} & Omit<ListTableConstructorOptions, 'records'>;\n\nexport class WorkSheet extends EventTarget implements IWorkSheetAPI {\n /** 选项 */\n options: IWorkSheetOptions;\n /** 容器 */\n container: HTMLElement;\n /** 表格实例 */\n tableInstance?: ListTable;\n /** 元素 */\n element: HTMLElement;\n /** 选择范围 */\n private selection: CellRange | null = null;\n /** Sheet 唯一标识 */\n private sheetKey: string;\n /** Sheet 标题 */\n private sheetTitle: string;\n\n /** 事件总线 */\n private eventBus: EventEmitter;\n\n private vtableSheet: VTableSheet;\n\n editingCell: { sheet: string; row: number; col: number } | null = null;\n\n constructor(sheet: VTableSheet, options: IWorkSheetOptions) {\n super();\n this.options = options;\n this.container = options.container;\n\n // 初始化基本属性\n this.sheetKey = options.sheetKey;\n this.sheetTitle = options.sheetTitle;\n this.vtableSheet = sheet;\n\n // 创建表格元素\n this.element = this._createRootElement();\n this.container.appendChild(this.element);\n\n // 初始化表格\n this._initializeTable();\n\n // 设置事件监听\n this._setupEventListeners();\n }\n\n /**\n * 获取行数\n */\n get rowCount(): number {\n const data = this.getData();\n return data ? data.length : 0;\n }\n\n /**\n * 获取列数\n */\n get colCount(): number {\n const data = this.getData();\n return data && data.length > 0 ? data[0].length : 0;\n }\n\n /**\n * 获取行数\n */\n getRowCount(): number {\n return this.tableInstance.rowCount;\n }\n\n /**\n * 获取列数\n */\n getColumnCount(): number {\n return this.tableInstance.colCount;\n }\n\n /**\n * 获取表格数据\n */\n get records(): any {\n return this.getData();\n }\n\n /**\n * 获取列定义\n */\n get columns(): any {\n return this.options.columns || [];\n }\n\n /**\n * 创建根元素\n */\n private _createRootElement(): HTMLElement {\n const element = document.createElement('div');\n element.setAttribute('sheet-key', `${this.sheetKey}`);\n element.classList.add('vtable-sheet');\n element.style.outline = 'none';\n element.style.position = 'relative';\n\n const width = this.container.clientWidth || 800;\n const height = this.container.clientHeight || 600;\n\n element.style.width = `${width}px`;\n element.style.height = `${height}px`;\n\n return element;\n }\n\n /**\n * 初始化表格实例\n */\n private _initializeTable(): void {\n // 这里应该是实际的表格初始化逻辑\n const tableOptions = this._generateTableOptions();\n this.tableInstance = new ListTable(tableOptions);\n this.element.classList.add('vtable-excel-cursor');\n // 获取事件总线\n this.eventBus = (this.tableInstance as any).eventBus;\n }\n\n /**\n * 生成VTable选项\n */\n private _generateTableOptions(): ListTableConstructorOptions {\n let isShowTableHeader = this.options.showHeader;\n // 转换为ListTable的选项\n if (!this.options.columns) {\n isShowTableHeader = isValid(isShowTableHeader) ? isShowTableHeader : false;\n this.options.columns = [];\n } else {\n for (let i = 0; i < this.options.columns.length; i++) {\n this.options.columns[i].field = i;\n }\n }\n if (!this.options.data) {\n this.options.data = [];\n } else if (this.options.columns.length === 0 && this.options.firstRowAsHeader) {\n const data = this.options.data;\n if (data && data.length > 0) {\n for (let i = 0; i < data[0].length; i++) {\n this.options.columns[i] = {\n field: i,\n title: data[0][i],\n filter: !!this.options.filter\n };\n }\n }\n data.shift();\n isShowTableHeader = true;\n }\n const keyboardOptions = {\n ...this.options.keyboardOptions,\n copySelected: true,\n pasteValueToCell: true,\n showCopyCellBorder: true,\n cutSelected: true\n };\n\n //更改theme 的frameStyle\n let changedTheme: TYPES.VTableThemes.ITableThemeDefine;\n if (!this.options?.theme) {\n this.options.theme = VTableThemes.DEFAULT;\n }\n this.options.theme = this.options.theme;\n if (this.options.theme.bodyStyle && !isPropertyWritable(this.options.theme, 'bodyStyle')) {\n //测试是否使用了主题 使用了主题配置项不可写。\n changedTheme = (this.options.theme as TYPES.VTableThemes.TableTheme).extends(\n (this.options.theme as TYPES.VTableThemes.TableTheme).getExtendTheme()\n ); //防止将原主题如DARK ARCO的属性改掉\n const extendThemeOption = (changedTheme as TYPES.VTableThemes.TableTheme).getExtendTheme();\n\n extendThemeOption.frameStyle = Object.assign({}, extendThemeOption.frameStyle, {\n shadowBlur: 0,\n cornerRadius: 0,\n borderLineWidth: 0\n });\n } else {\n changedTheme = this.options.theme;\n changedTheme.frameStyle = Object.assign({}, this.options.theme.frameStyle, {\n shadowBlur: 0,\n cornerRadius: 0,\n borderLineWidth: 0\n });\n }\n return {\n ...this.options,\n addRecordRule: 'Array',\n defaultCursor: 'cell',\n records: this.options.data,\n sortState: this.options.sortState,\n container: this.element,\n showHeader: isShowTableHeader,\n keyboardOptions,\n theme: changedTheme,\n excelOptions: {\n fillHandle: true\n },\n customConfig: {\n selectCellWhenCellEditorNotExists: true\n }\n // maintainedColumnCount: 120\n // 其他特定配置\n };\n }\n\n /**\n * 设置事件监听\n */\n private _setupEventListeners(): void {\n if (this.tableInstance) {\n // 监听单元格选择事件 - 优化:移除console.log调试代码\n this.tableInstance.on('mousedown_cell', (event: any) => {\n if (this.vtableSheet.formulaManager.formulaWorkingOnCell) {\n //防止公式输入状态下,原本的input元素blur掉,导致公式输入框无法输入\n event.event.preventDefault();\n }\n });\n\n // 监听选择变化事件(多选时)\n this.tableInstance.on('selected_changed' as any, (event: any) => {\n // 判断是drag过程中的选中单元格变化\n if (!this.tableInstance.eventManager.isDraging) {\n if (!this.vtableSheet.formulaManager.formulaWorkingOnCell) {\n this.editingCell = {\n sheet: this.getKey(),\n row: event.row,\n col: event.col\n };\n }\n this.handleCellSelected(event);\n }\n this.handleSelectionChanged(event);\n });\n\n // 监听拖拽选择结束事件 - 优化:移除console.log和debugger调试代码\n this.tableInstance.on('drag_select_end' as any, (event: any) => {\n this.handleDragSelectEnd(event);\n });\n\n // 监听单元格值变更事件\n this.tableInstance.on('change_cell_value', (event: any) => {\n this.handleCellValueChanged(event);\n });\n\n // 监听数据记录变更事件 - 用于调整公式引用\n // 注意:'add_record' 事件类型需要使用 as any 绕过类型检查\n (this.tableInstance as any).on('add_record', (event: any) => {\n this.handleDataRecordsChanged('add', event);\n });\n\n // 注意:'delete_record' 事件类型需要使用 as any 绕过类型检查\n (this.tableInstance as any).on('delete_record', (event: any) => {\n this.handleDataRecordsChanged('delete', event);\n });\n // 注意:'add_column' 事件类型尚未在 VTable 中定义,这里使用 as any 绕过类型检查\n (this.tableInstance as any).on('add_column', (event: any) => {\n this.handleColumnsChanged('add', event);\n });\n\n // 注意:'delete_column' 事件类型需要使用 as any 绕过类型检查\n (this.tableInstance as any).on('delete_column', (event: any) => {\n this.handleColumnsChanged('delete', event);\n });\n\n // 监听编辑结束事件,恢复十字光标\n this.tableInstance.on('click_cell', () => {\n this.element.classList.add('vtable-excel-cursor');\n });\n }\n }\n\n /**\n * 处理单元格选择事件\n * @param event 选择事件\n */\n private handleCellSelected(event: any): void {\n // 更新选择范围\n this.selection = {\n startRow: event.row,\n startCol: event.col,\n endRow: event.row,\n endCol: event.col\n };\n\n // 使用事件类型枚举触发事件给父组件\n const cellSelectedEvent: CellClickEvent = {\n row: event.row,\n col: event.col,\n value: event.value,\n cellElement: event.cellElement,\n originalEvent: event.originalEvent\n };\n this.fire(WorkSheetEventType.CELL_CLICK, cellSelectedEvent);\n }\n\n /**\n * 处理选择变化事件\n * @param event 选择变化事件\n */\n private handleSelectionChanged(event: any): void {\n if (event?.ranges?.length) {\n const r = event.ranges[event.ranges.length - 1];\n this.selection = {\n startRow: r.start.row,\n startCol: r.start.col,\n endRow: r.end.row,\n endCol: r.end.col\n };\n }\n // 保持原始事件结构,同时确保类型符合定义\n const selectionChangedEvent: SelectionChangedEvent = {\n row: event.row,\n col: event.col,\n ranges: event.ranges,\n cells: event.cells,\n originalEvent: event.originalEvent\n };\n this.fire(WorkSheetEventType.SELECTION_CHANGED, selectionChangedEvent);\n }\n\n /**\n * 处理拖拽选择结束事件\n * @param event 拖拽选择结束事件\n */\n private handleDragSelectEnd(event: any): void {\n if (event?.cells?.length) {\n const first = event.cells[0][0];\n const lastRow = event.cells[event.cells.length - 1];\n const last = lastRow[lastRow.length - 1];\n this.selection = {\n startRow: first.row,\n startCol: first.col,\n endRow: last.row,\n endCol: last.col\n };\n }\n // 保持原始事件结构,同时确保类型符合定义\n const selectionEndEvent: SelectionChangedEvent = {\n row: event.row,\n col: event.col,\n ranges: event.ranges,\n cells: event.cells,\n originalEvent: event.originalEvent\n };\n this.fire(WorkSheetEventType.SELECTION_END, selectionEndEvent);\n }\n\n /**\n * 处理单元格值变更事件\n * @param event 值变更事件\n */\n private handleCellValueChanged(event: any): void {\n const cellValueChangedEvent: CellValueChangedEvent = {\n row: event.row,\n col: event.col,\n oldValue: event.rawValue,\n newValue: event.changedValue\n };\n this.fire(WorkSheetEventType.CELL_VALUE_CHANGED, cellValueChangedEvent);\n }\n\n /**\n * 处理数据记录变更事件 - 用于调整公式引用\n * @param type 变更类型 ('add' | 'delete')\n * @param event 数据变更事件\n */\n private handleDataRecordsChanged(type: 'add' | 'delete', event: any): void {\n try {\n const sheetKey = this.getKey();\n //#region 处理数据变化后,公式引擎中的数据也需要更新\n const normalizedData = this.vtableSheet.formulaManager.normalizeSheetData(\n this.tableInstance.records,\n this.tableInstance\n );\n this.vtableSheet.formulaManager.formulaEngine.updateSheetData(sheetKey, normalizedData);\n //#endregion\n if (type === 'add') {\n // 处理添加记录事件\n const { recordIndex, recordCount } = event;\n if (recordIndex !== undefined && recordCount > 0) {\n // 在指定位置插入行,需要调整该位置之后的公式引用\n this.vtableSheet.formulaManager.addRows(sheetKey, recordIndex, recordCount);\n } else {\n // 默认在末尾添加\n const currentRowCount = this.getRowCount();\n this.vtableSheet.formulaManager.addRows(sheetKey, currentRowCount, recordCount);\n }\n } else if (type === 'delete') {\n // 处理删除记录事件\n const { rowIndexs, deletedCount } = event;\n if (rowIndexs && rowIndexs.length > 0) {\n // 为了简化,我们假设删除的是连续的行,从最小的索引开始\n const minIndex = Math.min(...rowIndexs.flat());\n this.vtableSheet.formulaManager.removeRows(sheetKey, minIndex, deletedCount);\n }\n }\n // update 事件不需要调整引用,因为只是数据内容变更\n } catch (error) {\n console.error(`Failed to handle data records changed (${type}):`, error);\n }\n }\n /**\n * 处理列变更事件 - 用于调整公式引用\n * @param type 变更类型 ('add' | 'delete')\n * @param event 列变更事件\n */\n private handleColumnsChanged(type: 'add' | 'delete', event: any): void {\n try {\n const sheetKey = this.getKey();\n //#region 处理数据变化后,公式引擎中的数据也需要更新\n const normalizedData = this.vtableSheet.formulaManager.normalizeSheetData(\n this.tableInstance.records,\n this.tableInstance\n );\n this.vtableSheet.formulaManager.formulaEngine.updateSheetData(sheetKey, normalizedData);\n //#endregion\n if (type === 'add') {\n // 处理添加列事件\n const { columnIndex, columnCount } = event;\n if (columnIndex !== undefined && columnCount > 0) {\n // 在指定位置插入列,需要调整该位置之后的公式引用\n this.vtableSheet.formulaManager.addColumns(sheetKey, columnIndex, columnCount);\n } else {\n // 默认在末尾添加\n const currentColumnCount = this.getColumnCount();\n this.vtableSheet.formulaManager.addColumns(sheetKey, currentColumnCount, columnCount);\n }\n } else if (type === 'delete') {\n // 处理删除列事件\n const { deleteColIndexs } = event;\n if (deleteColIndexs && deleteColIndexs.length > 0) {\n // 为了简化,我们假设删除的是连续的列,从最小的索引开始\n const minIndex = Math.min(...deleteColIndexs.flat());\n const deletedCount = deleteColIndexs.length;\n this.vtableSheet.formulaManager.removeColumns(sheetKey, minIndex, deletedCount);\n }\n }\n // update 事件不需要调整引用,因为只是数据内容变更\n } catch (error) {\n console.error(`Failed to handle columns changed (${type}):`, error);\n }\n }\n\n /**\n * 触发事件\n * @param eventName 事件名称\n * @param eventData 事件数据\n */\n protected fireEvent(eventName: string, eventData: any): void {\n this.fire(eventName, eventData);\n }\n\n /**\n * 监听事件\n * @param eventName 事件名称\n * @param handler 事件处理函数\n */\n on(eventName: string, handler: (...args: any[]) => void): this {\n return super.on(eventName, handler);\n }\n\n // 用于防止短时间内多次调用resize的节流变量\n private resizeTimer: number | null = null;\n private isResizing = false;\n\n /**\n * 更新Sheet大小\n * 使用节流方式避免频繁调用resize\n */\n resize(): void {\n if (!this.element) {\n return;\n }\n\n // 如果正在进行调整,清除之前的定时器\n if (this.resizeTimer !== null) {\n window.clearTimeout(this.resizeTimer);\n this.resizeTimer = null;\n }\n\n // 如果已经在执行resize,设置一个短期延迟\n if (this.isResizing) {\n this.resizeTimer = window.setTimeout(() => {\n this.doResize();\n this.resizeTimer = null;\n }, 50);\n return;\n }\n\n // 否则直接执行resize\n this.doResize();\n }\n\n /**\n * 实际执行调整大小的操作\n * @private\n */\n private doResize(): void {\n try {\n this.isResizing = true;\n\n const width = this.container.clientWidth || 800;\n const height = this.container.clientHeight || 600;\n\n // 只有尺寸确实变化时才更新样式和触发表格实例的resize\n if (parseInt(this.element.style.width, 10) !== width || parseInt(this.element.style.height, 10) !== height) {\n this.element.style.width = `${width}px`;\n this.element.style.height = `${height}px`;\n\n // 更新表格实例大小\n if (this.tableInstance) {\n // 触发VTable的resize\n this.tableInstance.resize();\n }\n }\n } catch (error) {\n console.error('Error during resize:', error);\n } finally {\n this.isResizing = false;\n }\n }\n\n /**\n * 获取Sheet元素\n */\n getElement(): HTMLElement {\n return this.element;\n }\n\n /**\n * 获取Sheet容器\n */\n getContainer(): HTMLElement {\n return this.container;\n }\n\n /**\n * 获取Sheet的key\n */\n getKey(): string {\n return this.sheetKey;\n }\n\n /**\n * 获取Sheet的标题\n */\n getTitle(): string {\n return this.sheetTitle;\n }\n\n /**\n * 设置Sheet的标题\n */\n setTitle(title: string): void {\n this.sheetTitle = title;\n this.options.sheetTitle = title;\n }\n\n /**\n * 获取列定义\n */\n getColumns(): ColumnDefine[] {\n return this.options.columns || [];\n }\n\n /**\n * 获取表格数据\n */\n getData(): any[][] {\n // 从表格实例获取数据\n return this.options.data || [];\n }\n\n getCopiedData(): any[][] {\n // 为了避免影响当前数据,所以需要复制一份数据\n return this.getData().map(row => (Array.isArray(row) ? row.slice() : []));\n }\n /**\n * 获取指定坐标的单元格值\n * @param row 行索引\n * @param col 列索引\n */\n getCellValue(row: number, col: number): any {\n if (this.tableInstance) {\n try {\n const value = this.tableInstance.getCellValue(col, row);\n return value;\n } catch (error) {\n console.warn('Failed to get cell value from VTable:', error);\n }\n }\n\n const data = this.getData();\n if (data && data[row] && data[row][col] !== undefined) {\n return data[row][col];\n }\n return null;\n }\n\n /**\n * 设置指定坐标的单元格值\n * @param row 行索引\n * @param col 列索引\n * @param value 新值\n */\n setCellValue(row: number, col: number, value: any): void {\n const data = this.getData();\n if (data && data[row]) {\n const oldValue = data[row][col];\n data[row][col] = value;\n\n // 更新表格实例\n if (this.tableInstance) {\n this.tableInstance.changeCellValue(col, row, value);\n }\n\n // 触发事件\n const event: CellValueChangedEvent = {\n row,\n col,\n oldValue,\n newValue: value\n };\n\n this.fire('cellValueChanged', event);\n }\n }\n\n /**\n * 根据A1地址获取单元格信息\n * @param address A1地址\n */\n getCellByAddress(address: string): { coord: CellCoord; value: CellValue } {\n const coord = this.coordFromAddress(address);\n return {\n coord,\n value: this.getCellValue(coord.row, coord.col)\n };\n }\n\n /**\n * 将行/列坐标转换为A1格式\n * @param coord 坐标\n */\n addressFromCoord(coord: CellCoord): string;\n addressFromCoord(row: number, col: number): string;\n addressFromCoord(coordOrRow: CellCoord | number, col?: number): string {\n let row: number;\n let colNum: number;\n\n if (typeof coordOrRow === 'object') {\n row = coordOrRow.row;\n colNum = coordOrRow.col;\n } else {\n row = coordOrRow;\n colNum = col!;\n }\n\n let colStr = '';\n let tempCol = colNum + 1;\n\n do {\n tempCol -= 1;\n colStr = String.fromCharCode(65 + (tempCol % 26)) + colStr;\n tempCol = Math.floor(tempCol / 26);\n } while (tempCol > 0);\n\n return `${colStr}${row + 1}`;\n }\n\n /**\n * 将A1格式转换为行/列坐标\n * @param address A1地址\n */\n coordFromAddress(address: string): CellCoord {\n const match = address.match(/^([A-Z]+)([0-9]+)$/);\n if (!match) {\n throw new Error(`Invalid cell address: ${address}`);\n }\n\n const colStr = match[1];\n const rowStr = match[2];\n\n let col = 0;\n for (let i = 0; i < colStr.length; i++) {\n col = col * 26 + (colStr.charCodeAt(i) - 64);\n }\n\n return {\n row: parseInt(rowStr, 10) - 1,\n col: col - 1\n };\n }\n\n /**\n * 获取当前选择\n */\n getSelection(): CellRange | null {\n return this.selection;\n }\n\n /**\n * 获取多个选择范围(支持Ctrl/Cmd多选)\n */\n getMultipleSelections(): CellRange[] {\n if (!this.tableInstance) {\n return this.selection ? [this.selection] : [];\n }\n\n // 从底层VTable获取所有选择范围\n const vtableRanges = this.tableInstance.getSelectedCellRanges();\n\n if (vtableRanges.length === 0) {\n return this.selection ? [this.selection] : [];\n }\n\n // 转换VTable的坐标格式到WorkSheet格式\n return vtableRanges.map(range => ({\n startRow: range.start.row,\n startCol: range.start.col,\n endRow: range.end.row,\n endCol: range.end.col\n }));\n }\n\n /**\n * 将第一行设置为表头\n */\n setFirstRowAsHeader(): void {\n const data = this.getData();\n if (data && data.length > 0) {\n for (let i = 0; i < data[0].length; i++) {\n if (!this.options.columns[i]) {\n this.options.columns[i] = {\n field: i,\n title: data[0][i]\n };\n } else {\n this.options.columns[i].title = data[0][i];\n this.options.columns[i].field = i;\n }\n }\n }\n data.shift();\n this.tableInstance.updateOption({\n ...this.options,\n columns: this.options.columns,\n showHeader: true,\n records: data\n });\n }\n\n /**\n * 释放资源\n */\n release(): void {\n // 清理事件监听器\n\n // 释放表格实例\n if (this.tableInstance) {\n this.tableInstance.release();\n }\n\n // 从DOM中移除元素\n if (this.element && this.element.parentNode) {\n this.element.parentNode.removeChild(this.element);\n }\n\n // 清除引用\n this.tableInstance?.release();\n }\n}\n"]}
|
|
@@ -24,8 +24,12 @@ export declare class FormulaEngine {
|
|
|
24
24
|
setActiveSheet(sheetKey: string): void;
|
|
25
25
|
getActiveSheet(): string | null;
|
|
26
26
|
addSheet(sheetKey: string, data?: unknown[][]): number;
|
|
27
|
+
updateSheetData(sheetKey: string, data: unknown[][]): void;
|
|
27
28
|
private normalizeData;
|
|
28
29
|
getSheetId(sheetKey: string): number;
|
|
30
|
+
getFormulaString(cell: FormulaCell): string | null;
|
|
31
|
+
private clearDependencies;
|
|
32
|
+
private setCellContentWithoutDependencyUpdate;
|
|
29
33
|
setCellContent(cell: FormulaCell, value: unknown): void;
|
|
30
34
|
private getCellKey;
|
|
31
35
|
private getA1Notation;
|
|
@@ -99,4 +103,13 @@ export declare class FormulaEngine {
|
|
|
99
103
|
private recalculateDependentsWithTracking;
|
|
100
104
|
private recalculateSingleCellWithTracking;
|
|
101
105
|
private sortCellsByDependency;
|
|
106
|
+
adjustFormulaReferences(sheetKey: string, type: 'insert' | 'delete', dimension: 'row' | 'column', index: number, count: number, totalColCount: number, totalRowCount: number): {
|
|
107
|
+
adjustedCells: FormulaCell[];
|
|
108
|
+
movedCells: FormulaCell[];
|
|
109
|
+
};
|
|
110
|
+
private adjustFormulaReference;
|
|
111
|
+
private columnLettersToIndex;
|
|
112
|
+
private indexToColumnLetters;
|
|
113
|
+
private rangeContainsDeletedCells;
|
|
114
|
+
private adjustRangeForDeletion;
|
|
102
115
|
}
|
|
@@ -22,7 +22,11 @@ class FormulaEngine {
|
|
|
22
22
|
const sheetId = this.nextSheetId++;
|
|
23
23
|
this.sheets.set(sheetKey, sheetId), this.reverseSheets.set(sheetId, sheetKey);
|
|
24
24
|
const sheetData = data || [ [ "" ] ];
|
|
25
|
-
return this.sheetData.set(sheetId,
|
|
25
|
+
return this.sheetData.set(sheetId, sheetData), sheetId;
|
|
26
|
+
}
|
|
27
|
+
updateSheetData(sheetKey, data) {
|
|
28
|
+
const sheetId = this.sheets.get(sheetKey);
|
|
29
|
+
null != sheetId && this.sheetData.set(sheetId, data);
|
|
26
30
|
}
|
|
27
31
|
normalizeData(data) {
|
|
28
32
|
if (!Array.isArray(data) || 0 === data.length) return [ [ "" ] ];
|
|
@@ -45,6 +49,34 @@ class FormulaEngine {
|
|
|
45
49
|
const sheetId = this.sheets.get(sheetKey);
|
|
46
50
|
return void 0 === sheetId ? this.addSheet(sheetKey) : sheetId;
|
|
47
51
|
}
|
|
52
|
+
getFormulaString(cell) {
|
|
53
|
+
const cellKey = this.getCellKey(cell);
|
|
54
|
+
return this.formulaCells.get(cellKey) || null;
|
|
55
|
+
}
|
|
56
|
+
clearDependencies(cellKey) {
|
|
57
|
+
const oldDeps = this.dependencies.get(cellKey) || new Set;
|
|
58
|
+
for (const dep of oldDeps) {
|
|
59
|
+
const depDependents = this.dependents.get(dep) || new Set;
|
|
60
|
+
depDependents.delete(cellKey), 0 === depDependents.size ? this.dependents.delete(dep) : this.dependents.set(dep, depDependents);
|
|
61
|
+
}
|
|
62
|
+
this.dependencies.delete(cellKey);
|
|
63
|
+
}
|
|
64
|
+
setCellContentWithoutDependencyUpdate(cell, value) {
|
|
65
|
+
if (!cell || void 0 === cell.sheet || void 0 === cell.row || void 0 === cell.col) throw new Error("Invalid cell parameter");
|
|
66
|
+
if (cell.row < 0 || cell.col < 0) throw new Error(`Cell coordinates out of bounds: row=${cell.row}, col=${cell.col}`);
|
|
67
|
+
const sheetId = this.getSheetId(cell.sheet);
|
|
68
|
+
this.sheetData.has(sheetId) || this.sheetData.set(sheetId, [ [ "" ] ]);
|
|
69
|
+
const sheet = this.sheetData.get(sheetId);
|
|
70
|
+
if (!sheet) throw new Error(`Sheet data not found for ID: ${sheetId}`);
|
|
71
|
+
for (;sheet.length <= cell.row; ) sheet.push([]);
|
|
72
|
+
for (;sheet[cell.row].length <= cell.col; ) sheet[cell.row].push("");
|
|
73
|
+
let processedValue = value;
|
|
74
|
+
if (null == processedValue && (processedValue = ""), "string" == typeof processedValue && !processedValue.startsWith("=")) {
|
|
75
|
+
const numericValue = Number(processedValue);
|
|
76
|
+
isNaN(numericValue) || "" === processedValue.trim() || (processedValue = numericValue);
|
|
77
|
+
}
|
|
78
|
+
sheet[cell.row][cell.col] = processedValue;
|
|
79
|
+
}
|
|
48
80
|
setCellContent(cell, value) {
|
|
49
81
|
if (!cell || void 0 === cell.sheet || void 0 === cell.row || void 0 === cell.col) throw new Error("Invalid cell parameter");
|
|
50
82
|
if (cell.row < 0 || cell.col < 0) throw new Error(`Cell coordinates out of bounds: row=${cell.row}, col=${cell.col}`);
|
|
@@ -108,6 +140,10 @@ class FormulaEngine {
|
|
|
108
140
|
error: void 0
|
|
109
141
|
};
|
|
110
142
|
const expression = formula.substring(1).trim();
|
|
143
|
+
if (expression.includes("#REF!")) return {
|
|
144
|
+
value: "#REF!",
|
|
145
|
+
error: void 0
|
|
146
|
+
};
|
|
111
147
|
return this.parseExpression(expression);
|
|
112
148
|
} catch (error) {
|
|
113
149
|
return {
|
|
@@ -1016,13 +1052,180 @@ class FormulaEngine {
|
|
|
1016
1052
|
for (const cell of cells) visited.has(cell) || visit(cell);
|
|
1017
1053
|
return result;
|
|
1018
1054
|
}
|
|
1055
|
+
adjustFormulaReferences(sheetKey, type, dimension, index, count, totalColCount, totalRowCount) {
|
|
1056
|
+
try {
|
|
1057
|
+
const adjustedFormulas = [], movedFormulas = [], deletedCells = new Set;
|
|
1058
|
+
if ("delete" === type) for (let i = 0; i < count; i++) if ("row" === dimension) for (let col = 0; col < totalColCount; col++) {
|
|
1059
|
+
const deletedCell = {
|
|
1060
|
+
sheet: sheetKey,
|
|
1061
|
+
row: index + i,
|
|
1062
|
+
col: col
|
|
1063
|
+
}, deletedCellKey = this.getCellKey(deletedCell);
|
|
1064
|
+
deletedCells.add(deletedCellKey);
|
|
1065
|
+
} else if ("column" === dimension) for (let row = 0; row < totalRowCount; row++) {
|
|
1066
|
+
const deletedCell = {
|
|
1067
|
+
sheet: sheetKey,
|
|
1068
|
+
row: row,
|
|
1069
|
+
col: index + i
|
|
1070
|
+
}, deletedCellKey = this.getCellKey(deletedCell);
|
|
1071
|
+
deletedCells.add(deletedCellKey);
|
|
1072
|
+
}
|
|
1073
|
+
for (const [cellKey, formula] of Array.from(this.formulaCells.entries())) {
|
|
1074
|
+
const cell = this.parseCellKey(cellKey);
|
|
1075
|
+
if (!cell || cell.sheet !== sheetKey) continue;
|
|
1076
|
+
const newCell = Object.assign({}, cell);
|
|
1077
|
+
let cellNeedsMove = !1;
|
|
1078
|
+
if ("row" === dimension) {
|
|
1079
|
+
if ("insert" === type && cell.row >= index) newCell.row = cell.row + count, cellNeedsMove = !0; else if ("delete" === type && cell.row > index) newCell.row = cell.row - count,
|
|
1080
|
+
cellNeedsMove = !0; else if ("delete" === type && cell.row >= index && cell.row < index + count) {
|
|
1081
|
+
this.formulaCells.delete(cellKey);
|
|
1082
|
+
continue;
|
|
1083
|
+
}
|
|
1084
|
+
} else if ("column" === dimension) if ("insert" === type && cell.col >= index) newCell.col = cell.col + count,
|
|
1085
|
+
cellNeedsMove = !0; else if ("delete" === type && cell.col > index) newCell.col = cell.col - count,
|
|
1086
|
+
cellNeedsMove = !0; else if ("delete" === type && cell.col >= index && cell.col < index + count) {
|
|
1087
|
+
this.formulaCells.delete(cellKey);
|
|
1088
|
+
continue;
|
|
1089
|
+
}
|
|
1090
|
+
const newFormula = this.adjustFormulaReference(formula, type, dimension, index, count);
|
|
1091
|
+
cellNeedsMove ? (movedFormulas.push({
|
|
1092
|
+
oldCellKey: cellKey,
|
|
1093
|
+
newCell: newCell,
|
|
1094
|
+
formula: newFormula
|
|
1095
|
+
}), this.formulaCells.delete(cellKey), this.clearDependencies(cellKey)) : newFormula !== formula && (adjustedFormulas.push({
|
|
1096
|
+
cell: cell,
|
|
1097
|
+
oldFormula: formula,
|
|
1098
|
+
newFormula: newFormula
|
|
1099
|
+
}), this.clearDependencies(cellKey));
|
|
1100
|
+
}
|
|
1101
|
+
for (const {newCell: newCell, formula: formula} of movedFormulas) {
|
|
1102
|
+
const newCellKey = this.getCellKey(newCell);
|
|
1103
|
+
this.formulaCells.set(newCellKey, formula), this.updateDependencies(newCellKey, formula),
|
|
1104
|
+
this.setCellContentWithoutDependencyUpdate(newCell, formula);
|
|
1105
|
+
}
|
|
1106
|
+
for (const {cell: cell, newFormula: newFormula} of adjustedFormulas) {
|
|
1107
|
+
const cellKey = this.getCellKey(cell);
|
|
1108
|
+
this.formulaCells.set(cellKey, newFormula), this.updateDependencies(cellKey, newFormula),
|
|
1109
|
+
this.setCellContentWithoutDependencyUpdate(cell, newFormula);
|
|
1110
|
+
}
|
|
1111
|
+
adjustedFormulas.length, movedFormulas.length;
|
|
1112
|
+
const adjustedCells = adjustedFormulas.map((item => item.cell));
|
|
1113
|
+
return {
|
|
1114
|
+
adjustedCells: adjustedCells,
|
|
1115
|
+
movedCells: movedFormulas.map((item => item.newCell))
|
|
1116
|
+
};
|
|
1117
|
+
} catch (error) {
|
|
1118
|
+
return {
|
|
1119
|
+
adjustedCells: [],
|
|
1120
|
+
movedCells: []
|
|
1121
|
+
};
|
|
1122
|
+
}
|
|
1123
|
+
}
|
|
1124
|
+
adjustFormulaReference(formula, type, dimension, index, count) {
|
|
1125
|
+
if (!formula || !formula.startsWith("=")) return formula;
|
|
1126
|
+
const expression = formula.substring(1), cellRefRegex = /([A-Z]+)([0-9]+)/g, rangeRefRegex = /([A-Z]+[0-9]+):([A-Z]+[0-9]+)/g;
|
|
1127
|
+
let match, newExpression = expression;
|
|
1128
|
+
const replacements = [];
|
|
1129
|
+
for (;null !== (match = rangeRefRegex.exec(expression)); ) {
|
|
1130
|
+
const fullRangeMatch = match[0], startCell = match[1], endCell = match[2];
|
|
1131
|
+
if ("delete" === type) {
|
|
1132
|
+
if (this.rangeContainsDeletedCells(startCell, endCell, dimension, index, count)) {
|
|
1133
|
+
const newRange = this.adjustRangeForDeletion(startCell, endCell, dimension, index, count);
|
|
1134
|
+
newRange !== fullRangeMatch && replacements.push({
|
|
1135
|
+
start: match.index,
|
|
1136
|
+
end: match.index + fullRangeMatch.length,
|
|
1137
|
+
replacement: newRange
|
|
1138
|
+
});
|
|
1139
|
+
}
|
|
1140
|
+
}
|
|
1141
|
+
}
|
|
1142
|
+
for (cellRefRegex.lastIndex = 0; null !== (match = cellRefRegex.exec(expression)); ) {
|
|
1143
|
+
const fullMatch = match[0], colLetters = match[1], rowNumber = parseInt(match[2], 10), currentMatchIndex = match.index;
|
|
1144
|
+
if (replacements.some((replacement => currentMatchIndex >= replacement.start && currentMatchIndex < replacement.end))) continue;
|
|
1145
|
+
let needsAdjustment = !1, newRowNumber = rowNumber, newColLetters = colLetters;
|
|
1146
|
+
if ("row" === dimension) {
|
|
1147
|
+
const zeroBasedRowNumber = rowNumber - 1;
|
|
1148
|
+
"insert" === type && zeroBasedRowNumber >= index ? (newRowNumber = rowNumber + count,
|
|
1149
|
+
needsAdjustment = !0) : "delete" === type && zeroBasedRowNumber >= index && (zeroBasedRowNumber >= index + count ? (newRowNumber = rowNumber - count,
|
|
1150
|
+
needsAdjustment = !0) : zeroBasedRowNumber >= index && zeroBasedRowNumber < index + count && (newRowNumber = index,
|
|
1151
|
+
needsAdjustment = !0));
|
|
1152
|
+
} else if ("column" === dimension) {
|
|
1153
|
+
const colIndex = this.columnLettersToIndex(colLetters);
|
|
1154
|
+
"insert" === type && colIndex >= index ? (newColLetters = this.indexToColumnLetters(colIndex + count),
|
|
1155
|
+
needsAdjustment = !0) : "delete" === type && colIndex >= index && (colIndex >= index + count ? (newColLetters = this.indexToColumnLetters(colIndex - count),
|
|
1156
|
+
needsAdjustment = !0) : colIndex >= index && colIndex < index + count && (newColLetters = this.indexToColumnLetters(index),
|
|
1157
|
+
needsAdjustment = !0));
|
|
1158
|
+
}
|
|
1159
|
+
if (needsAdjustment) {
|
|
1160
|
+
let replacement;
|
|
1161
|
+
replacement = "row" === dimension && newRowNumber === index || "column" === dimension && this.indexToColumnLetters(this.columnLettersToIndex(newColLetters)) === this.indexToColumnLetters(index) ? "#REF!" : newColLetters + newRowNumber,
|
|
1162
|
+
replacements.push({
|
|
1163
|
+
start: match.index,
|
|
1164
|
+
end: match.index + fullMatch.length,
|
|
1165
|
+
replacement: replacement
|
|
1166
|
+
});
|
|
1167
|
+
}
|
|
1168
|
+
}
|
|
1169
|
+
replacements.sort(((a, b) => b.start - a.start));
|
|
1170
|
+
for (const {start: start, end: end, replacement: replacement} of replacements) newExpression = newExpression.substring(0, start) + replacement + newExpression.substring(end);
|
|
1171
|
+
return "=" + newExpression;
|
|
1172
|
+
}
|
|
1173
|
+
columnLettersToIndex(letters) {
|
|
1174
|
+
let index = 0;
|
|
1175
|
+
for (let i = 0; i < letters.length; i++) index = 26 * index + (letters.charCodeAt(i) - 64);
|
|
1176
|
+
return index - 1;
|
|
1177
|
+
}
|
|
1178
|
+
indexToColumnLetters(index) {
|
|
1179
|
+
let letters = "";
|
|
1180
|
+
do {
|
|
1181
|
+
letters = String.fromCharCode(65 + index % 26) + letters, index = Math.floor(index / 26) - 1;
|
|
1182
|
+
} while (index >= 0);
|
|
1183
|
+
return letters;
|
|
1184
|
+
}
|
|
1185
|
+
rangeContainsDeletedCells(startCell, endCell, dimension, index, count) {
|
|
1186
|
+
try {
|
|
1187
|
+
const start = this.parseA1Notation(startCell), end = this.parseA1Notation(endCell), minRow = Math.min(start.row, end.row), maxRow = Math.max(start.row, end.row), minCol = Math.min(start.col, end.col), maxCol = Math.max(start.col, end.col);
|
|
1188
|
+
if ("row" === dimension) {
|
|
1189
|
+
if (index + count - 1 >= minRow && index <= maxRow) return !0;
|
|
1190
|
+
} else if ("column" === dimension) {
|
|
1191
|
+
if (index + count - 1 >= minCol && index <= maxCol) return !0;
|
|
1192
|
+
}
|
|
1193
|
+
return !1;
|
|
1194
|
+
} catch (_a) {
|
|
1195
|
+
return !1;
|
|
1196
|
+
}
|
|
1197
|
+
}
|
|
1198
|
+
adjustRangeForDeletion(startCell, endCell, dimension, index, count) {
|
|
1199
|
+
try {
|
|
1200
|
+
const start = this.parseA1Notation(startCell), end = this.parseA1Notation(endCell), minRow = Math.min(start.row, end.row), maxRow = Math.max(start.row, end.row), minCol = Math.min(start.col, end.col), maxCol = Math.max(start.col, end.col);
|
|
1201
|
+
let newStartCell, newEndCell, newMinRow = minRow, newMaxRow = maxRow, newMinCol = minCol, newMaxCol = maxCol;
|
|
1202
|
+
if ("row" === dimension) {
|
|
1203
|
+
const deleteEndRow = index + count - 1;
|
|
1204
|
+
if (minRow >= index && minRow <= deleteEndRow ? newMinRow = index > 0 ? index - 1 : 0 : minRow > deleteEndRow && (newMinRow = minRow - count,
|
|
1205
|
+
newMinRow < 0 && (newMinRow = 0)), maxRow >= index && maxRow <= deleteEndRow ? newMaxRow = index > 0 ? index - 1 : 0 : maxRow > deleteEndRow && (newMaxRow = maxRow - count,
|
|
1206
|
+
newMaxRow < 0 && (newMaxRow = 0)), newMinRow > newMaxRow) return "#REF!";
|
|
1207
|
+
} else if ("column" === dimension) {
|
|
1208
|
+
const deleteEndCol = index + count - 1;
|
|
1209
|
+
if (minCol >= index && minCol <= deleteEndCol ? newMinCol = index > 0 ? index - 1 : 0 : minCol > deleteEndCol && (newMinCol = minCol - count,
|
|
1210
|
+
newMinCol < 0 && (newMinCol = 0)), maxCol >= index && maxCol <= deleteEndCol ? newMaxCol = index > 0 ? index - 1 : 0 : maxCol > deleteEndCol && (newMaxCol = maxCol - count,
|
|
1211
|
+
newMaxCol < 0 && (newMaxCol = 0)), newMinCol > newMaxCol) return "#REF!";
|
|
1212
|
+
if (-1 === newMinCol || -1 === newMaxCol) return "#REF!";
|
|
1213
|
+
}
|
|
1214
|
+
return "row" === dimension && -1 === newMinRow && -1 === newMaxRow || "column" === dimension && -1 === newMinCol && -1 === newMaxCol ? "#REF!" : ("row" === dimension ? (newStartCell = -1 === newMinRow ? "#REF!" : this.getA1Notation(newMinRow, newMinCol),
|
|
1215
|
+
newEndCell = -1 === newMaxRow ? "#REF!" : this.getA1Notation(newMaxRow, newMaxCol)) : (newStartCell = -1 === newMinCol ? "#REF!" : this.getA1Notation(newMinRow, newMinCol),
|
|
1216
|
+
newEndCell = -1 === newMaxCol ? "#REF!" : this.getA1Notation(newMaxRow, newMaxCol)),
|
|
1217
|
+
newStartCell === newEndCell ? newStartCell : `${newStartCell}:${newEndCell}`);
|
|
1218
|
+
} catch (_a) {
|
|
1219
|
+
return "#REF!";
|
|
1220
|
+
}
|
|
1221
|
+
}
|
|
1019
1222
|
}
|
|
1020
1223
|
|
|
1021
1224
|
exports.FormulaEngine = FormulaEngine;
|
|
1022
1225
|
|
|
1023
1226
|
class FormulaError {
|
|
1024
|
-
constructor(message) {
|
|
1025
|
-
this.message = message;
|
|
1227
|
+
constructor(message, type = "VALUE") {
|
|
1228
|
+
this.message = message, this.type = type;
|
|
1026
1229
|
}
|
|
1027
1230
|
}
|
|
1028
1231
|
//# sourceMappingURL=formula-engine.js.map
|