@visactor/vtable-sheet 1.22.8-alpha.13 → 1.22.8
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/components/vtable-sheet.d.ts +9 -3
- package/cjs/components/vtable-sheet.js +41 -4
- package/cjs/components/vtable-sheet.js.map +1 -1
- package/cjs/core/WorkSheet.js +1 -1
- package/cjs/core/WorkSheet.js.map +1 -1
- package/cjs/formula/cross-sheet-formula-manager.js +1 -2
- package/cjs/formula/formula-engine.js +2 -1
- package/cjs/index.d.ts +1 -1
- package/cjs/index.js +1 -1
- package/cjs/index.js.map +1 -1
- package/cjs/managers/menu-manager.js +6 -1
- package/cjs/managers/menu-manager.js.map +1 -1
- package/cjs/styles/formula-bar.js +1 -2
- package/cjs/styles/sheet-tab.js +2 -1
- package/cjs/ts-types/base.d.ts +2 -1
- package/cjs/ts-types/base.js +1 -1
- package/cjs/ts-types/base.js.map +1 -1
- package/dist/vtable-sheet.js +71 -16
- package/dist/vtable-sheet.min.js +1 -1
- package/es/components/vtable-sheet.d.ts +9 -3
- package/es/components/vtable-sheet.js +41 -4
- package/es/components/vtable-sheet.js.map +1 -1
- package/es/core/WorkSheet.js +1 -1
- package/es/core/WorkSheet.js.map +1 -1
- package/es/formula/cross-sheet-formula-manager.js +1 -2
- package/es/formula/formula-engine.js +2 -1
- package/es/index.d.ts +1 -1
- package/es/index.js +1 -1
- package/es/index.js.map +1 -1
- package/es/managers/menu-manager.js +6 -1
- package/es/managers/menu-manager.js.map +1 -1
- package/es/styles/formula-bar.js +1 -2
- package/es/styles/sheet-tab.js +2 -1
- package/es/ts-types/base.d.ts +2 -1
- package/es/ts-types/base.js +1 -1
- package/es/ts-types/base.js.map +1 -1
- package/package.json +7 -7
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { FormulaManager } from '../managers/formula-manager';
|
|
2
2
|
import SheetManager from '../managers/sheet-manager';
|
|
3
3
|
import { WorkSheet } from '../core/WorkSheet';
|
|
4
|
-
import type { IVTableSheetOptions, ISheetDefine
|
|
4
|
+
import type { IVTableSheetOptions, ISheetDefine } from '../ts-types';
|
|
5
|
+
import type { MultiSheetImportResult } from '@visactor/vtable-plugins/src/excel-import/types';
|
|
5
6
|
import { FormulaUIManager } from '../formula/formula-ui-manager';
|
|
6
7
|
export default class VTableSheet {
|
|
7
8
|
private container;
|
|
@@ -33,6 +34,7 @@ export default class VTableSheet {
|
|
|
33
34
|
private initSheets;
|
|
34
35
|
activateSheet(sheetKey: string): void;
|
|
35
36
|
addSheet(sheet: ISheetDefine): void;
|
|
37
|
+
private _selectExcelFile;
|
|
36
38
|
removeSheet(sheetKey: string): void;
|
|
37
39
|
getSheetCount(): number;
|
|
38
40
|
getSheet(sheetKey: string): ISheetDefine | null;
|
|
@@ -48,8 +50,12 @@ export default class VTableSheet {
|
|
|
48
50
|
getActiveSheet(): WorkSheet | null;
|
|
49
51
|
getSheetByName(sheetName: string): WorkSheet | null;
|
|
50
52
|
saveToConfig(): IVTableSheetOptions;
|
|
51
|
-
exportSheetToFile(fileType: 'csv' | 'xlsx'): void;
|
|
52
|
-
|
|
53
|
+
exportSheetToFile(fileType: 'csv' | 'xlsx', allSheets?: boolean): void;
|
|
54
|
+
exportAllSheetsToExcel(): void;
|
|
55
|
+
initAllSheetInstances(): void;
|
|
56
|
+
importFileToSheet(options?: {
|
|
57
|
+
clearExisting?: boolean;
|
|
58
|
+
}): Promise<MultiSheetImportResult | void>;
|
|
53
59
|
getContainer(): HTMLElement;
|
|
54
60
|
getRootElement(): HTMLElement;
|
|
55
61
|
getOptions(): IVTableSheetOptions;
|
|
@@ -203,6 +203,19 @@ class VTableSheet {
|
|
|
203
203
|
addSheet(sheet) {
|
|
204
204
|
this.sheetManager.addSheet(sheet), this.updateSheetTabs(), this.updateSheetMenu();
|
|
205
205
|
}
|
|
206
|
+
_selectExcelFile() {
|
|
207
|
+
return new Promise((resolve => {
|
|
208
|
+
const input = document.createElement("input");
|
|
209
|
+
input.type = "file", input.accept = ".xlsx,.xls", input.style.display = "none",
|
|
210
|
+
document.body.appendChild(input), input.addEventListener("change", (e => {
|
|
211
|
+
var _a;
|
|
212
|
+
const file = null === (_a = e.target.files) || void 0 === _a ? void 0 : _a[0];
|
|
213
|
+
document.body.removeChild(input), resolve(file || null);
|
|
214
|
+
})), input.addEventListener("cancel", (() => {
|
|
215
|
+
document.body.removeChild(input), resolve(null);
|
|
216
|
+
})), input.click();
|
|
217
|
+
}));
|
|
218
|
+
}
|
|
206
219
|
removeSheet(sheetKey) {
|
|
207
220
|
if (this.sheetManager.getSheetCount() <= 1) return void (0, snackbar_1.showSnackbar)("至少保留一个工作表", 1300);
|
|
208
221
|
const instance = this.workSheetInstances.get(sheetKey);
|
|
@@ -377,16 +390,40 @@ class VTableSheet {
|
|
|
377
390
|
sheets: sheets
|
|
378
391
|
});
|
|
379
392
|
}
|
|
380
|
-
exportSheetToFile(fileType) {
|
|
393
|
+
exportSheetToFile(fileType, allSheets = !0) {
|
|
381
394
|
var _a, _b;
|
|
382
395
|
const sheet = this.getActiveSheet();
|
|
383
|
-
sheet && ("csv" === fileType ? (null === (_a = sheet.tableInstance) || void 0 === _a ? void 0 : _a.exportToCsv) && sheet.tableInstance.exportToCsv() : (null === (_b = sheet.tableInstance) || void 0 === _b ? void 0 : _b.exportToExcel) && sheet.tableInstance.exportToExcel());
|
|
396
|
+
sheet && ("csv" === fileType ? (null === (_a = sheet.tableInstance) || void 0 === _a ? void 0 : _a.exportToCsv) && sheet.tableInstance.exportToCsv() : allSheets ? this.exportAllSheetsToExcel() : (null === (_b = sheet.tableInstance) || void 0 === _b ? void 0 : _b.exportToExcel) && sheet.tableInstance.exportToExcel());
|
|
397
|
+
}
|
|
398
|
+
exportAllSheetsToExcel() {
|
|
399
|
+
var _b;
|
|
400
|
+
this.initAllSheetInstances();
|
|
401
|
+
const tables = this.sheetManager.getAllSheets().map((def => ({
|
|
402
|
+
table: this.workSheetInstances.get(def.sheetKey).tableInstance,
|
|
403
|
+
name: def.sheetTitle || def.sheetKey
|
|
404
|
+
})));
|
|
405
|
+
null === (_b = this._exportMutipleTablesToExcel) || void 0 === _b || _b.call(this, tables);
|
|
406
|
+
}
|
|
407
|
+
initAllSheetInstances() {
|
|
408
|
+
this.sheetManager.getAllSheets().forEach((def => {
|
|
409
|
+
if (!this.workSheetInstances.has(def.sheetKey)) {
|
|
410
|
+
const instance = this.createWorkSheetInstance(def);
|
|
411
|
+
this.workSheetInstances.set(def.sheetKey, instance);
|
|
412
|
+
}
|
|
413
|
+
}));
|
|
384
414
|
}
|
|
385
|
-
importFileToSheet(
|
|
415
|
+
importFileToSheet(options = {
|
|
416
|
+
clearExisting: !0
|
|
417
|
+
}) {
|
|
386
418
|
var _a;
|
|
387
419
|
return __awaiter(this, void 0, void 0, (function*() {
|
|
420
|
+
if (null == this ? void 0 : this._importFile) return yield this._importFile({
|
|
421
|
+
clearExisting: !1 !== (null == options ? void 0 : options.clearExisting)
|
|
422
|
+
});
|
|
388
423
|
const sheet = this.getActiveSheet();
|
|
389
|
-
|
|
424
|
+
return sheet && (null === (_a = sheet.tableInstance) || void 0 === _a ? void 0 : _a.importFile) ? yield sheet.tableInstance.importFile({
|
|
425
|
+
clearExisting: !1 !== (null == options ? void 0 : options.clearExisting)
|
|
426
|
+
}) : void 0;
|
|
390
427
|
}));
|
|
391
428
|
}
|
|
392
429
|
getContainer() {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/components/vtable-sheet.ts"],"names":[],"mappings":"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","file":"vtable-sheet.js","sourcesContent":["import { FormulaManager } from '../managers/formula-manager';\nimport SheetManager from '../managers/sheet-manager';\nimport { WorkSheet } from '../core/WorkSheet';\nimport * as VTable from '@visactor/vtable';\nimport { getTablePlugins } from '../core/table-plugins';\nimport { EventManager } from '../event/event-manager';\nimport { showSnackbar } from '../tools/ui/snackbar';\nimport type { IVTableSheetOptions, ISheetDefine, CellValueChangedEvent, ImportResult } from '../ts-types';\nimport { WorkSheetEventType } from '../ts-types';\nimport SheetTabDragManager from '../managers/tab-drag-manager';\nimport { checkTabTitle } from '../tools';\nimport { FormulaAutocomplete } from '../formula/formula-autocomplete';\nimport { formulaEditor } from '../formula/formula-editor';\nimport { CellHighlightManager } from '../formula/cell-highlight-manager';\nimport type { TYPES } from '@visactor/vtable';\nimport { MenuManager } from '../managers/menu-manager';\nimport { FormulaUIManager } from '../formula/formula-ui-manager';\nimport { SheetTabEventHandler } from './sheet-tab-event-handler';\n\n// 注册公式编辑器\nVTable.register.editor('formula', formulaEditor);\nexport default class VTableSheet {\n /** DOM容器 */\n private container: HTMLElement;\n /** 配置选项 */\n private options: IVTableSheetOptions;\n /** sheet管理器 */\n private sheetManager: SheetManager;\n /** 公式管理器 */\n formulaManager: FormulaManager;\n /** 事件管理器 */\n private eventManager: EventManager;\n\n /** 菜单管理 */\n private menuManager: MenuManager;\n /** 当前活动sheet实例 */\n private activeWorkSheet: WorkSheet | null = null;\n /** 所有sheet实例 */\n workSheetInstances: Map<string, WorkSheet> = new Map();\n /** 公式自动补全 */\n private formulaAutocomplete: FormulaAutocomplete | null = null;\n\n /** 公式UI管理器 */\n formulaUIManager: FormulaUIManager;\n\n /** UI组件 */\n private rootElement: HTMLElement;\n private formulaBarElement: HTMLElement | null = null;\n private sheetTabElement: HTMLElement | null = null;\n private mainMenuElement: HTMLElement | null = null;\n private contentElement: HTMLElement;\n\n // tab拖拽管理器\n private dragManager: SheetTabDragManager;\n /** sheet标签事件处理器 */\n private sheetTabEventHandler: SheetTabEventHandler;\n\n /**\n * 构造函数\n * @param options 配置选项\n */\n constructor(container: HTMLElement, options: IVTableSheetOptions) {\n this.container = container;\n this.options = this.mergeDefaultOptions(options);\n\n // 创建管理器\n this.sheetManager = new SheetManager();\n this.formulaManager = new FormulaManager(this);\n this.eventManager = new EventManager(this);\n this.dragManager = new SheetTabDragManager(this);\n this.menuManager = new MenuManager(this);\n this.formulaUIManager = new FormulaUIManager(this);\n this.sheetTabEventHandler = new SheetTabEventHandler(this);\n\n // 初始化UI\n this.initUI();\n\n // 初始化sheets\n this.initSheets();\n\n this.resize();\n }\n\n /**\n * 合并默认配置\n */\n private mergeDefaultOptions(options: IVTableSheetOptions): IVTableSheetOptions {\n return {\n showFormulaBar: true,\n showSheetTab: true,\n defaultRowHeight: 25,\n defaultColWidth: 100,\n ...options\n };\n }\n\n /**\n * 初始化公式自动补全\n */\n private initFormulaAutocomplete(): void {\n if (!this.formulaBarElement) {\n return;\n }\n\n const formulaInput = this.formulaUIManager.formulaInput;\n if (formulaInput) {\n this.formulaAutocomplete = new FormulaAutocomplete(this.rootElement, this);\n this.formulaAutocomplete.attachTo(formulaInput);\n }\n }\n\n /**\n * 初始化UI\n */\n private initUI(): void {\n // 创建根元素\n this.rootElement = document.createElement('div');\n this.rootElement.className = 'vtable-sheet-container';\n // this.rootElement.style.width = `${this.options.width}px`;\n // this.rootElement.style.height = `${this.options.height}px`;\n this.container.appendChild(this.rootElement);\n //创建顶部菜单和公式的容器\n const topContainer = document.createElement('div');\n topContainer.className = 'vtable-sheet-top-container';\n this.rootElement.appendChild(topContainer);\n\n // 创建主菜单\n if (this.options.mainMenu?.show) {\n this.mainMenuElement = this.menuManager.createMainMenu();\n topContainer.appendChild(this.mainMenuElement);\n }\n // 创建公式栏\n if (this.options.showFormulaBar) {\n this.formulaBarElement = this.formulaUIManager.createFormulaBar();\n topContainer.appendChild(this.formulaBarElement);\n\n this.initFormulaAutocomplete();\n }\n\n // 创建内容区域\n this.contentElement = document.createElement('div');\n this.contentElement.className = 'vtable-sheet-content';\n this.rootElement.appendChild(this.contentElement);\n\n // 创建sheet切换栏\n if (this.options.showSheetTab) {\n this.sheetTabElement = this.createSheetTab();\n this.rootElement.appendChild(this.sheetTabElement);\n }\n }\n\n /**\n * 创建sheet切换栏\n */\n private createSheetTab(): HTMLElement {\n // SVG图标常量\n const addIcon =\n '<svg viewBox=\"0 0 24 24\" width=\"16\" height=\"16\">' +\n '<path fill=\"currentColor\" d=\"M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6z\"/>' +\n '</svg>';\n const leftIcon =\n '<svg viewBox=\"0 0 24 24\" width=\"16\" height=\"16\">' +\n '<path fill=\"currentColor\" d=\"M15.41 7.41L14 6l-6 6 6 6 1.41-1.41L10.83 12z\"/>' +\n '</svg>';\n const rightIcon =\n '<svg viewBox=\"0 0 24 24\" width=\"16\" height=\"16\">' +\n '<path fill=\"currentColor\" d=\"M10 6L8.59 7.41 13.17 12l-4.58 4.59L10 18l6-6z\"/>' +\n '</svg>';\n const menuIcon =\n '<svg viewBox=\"0 0 24 24\" width=\"16\" height=\"16\">' +\n '<path fill=\"currentColor\" d=\"M12 8c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm0 2c-1.1 0-2 ' +\n '.9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0 6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z\"/>' +\n '</svg>';\n\n const sheetTab = document.createElement('div');\n sheetTab.className = 'vtable-sheet-tab-bar';\n\n // 创建左侧渐变效果\n const fadeLeft = document.createElement('div');\n fadeLeft.className = 'vtable-sheet-fade-left';\n fadeLeft.style.display = 'none';\n sheetTab.appendChild(fadeLeft);\n\n // 创建中间的tabs容器\n const tabsContainer = document.createElement('div');\n tabsContainer.className = 'vtable-sheet-tabs-container';\n tabsContainer.addEventListener('scroll', () =>\n this.sheetTabEventHandler.updateFadeEffects(tabsContainer, fadeLeft, fadeRight)\n );\n sheetTab.appendChild(tabsContainer);\n\n // 创建插入指示器\n const insertIndicator = document.createElement('div');\n insertIndicator.className = 'vtable-sheet-insert-indicator';\n insertIndicator.style.display = 'none';\n tabsContainer.appendChild(insertIndicator);\n\n // 创建右侧渐变效果\n const fadeRight = document.createElement('div');\n fadeRight.className = 'vtable-sheet-fade-right';\n sheetTab.appendChild(fadeRight);\n\n // 添加新增sheet按钮\n const addButton = document.createElement('button');\n addButton.className = 'vtable-sheet-add-button';\n addButton.innerHTML = addIcon;\n addButton.title = '添加工作表';\n addButton.addEventListener('click', () => this._addNewSheet());\n sheetTab.appendChild(addButton);\n\n // 创建导航按钮容器\n const navButtons = document.createElement('div');\n navButtons.className = 'vtable-sheet-nav-buttons';\n\n // 创建左侧滚动按钮\n const leftScrollBtn = document.createElement('button');\n leftScrollBtn.className = 'vtable-sheet-scroll-button';\n leftScrollBtn.innerHTML = leftIcon;\n leftScrollBtn.title = '向左滚动';\n leftScrollBtn.addEventListener('click', () => this.sheetTabEventHandler.scrollSheetTabs('left', tabsContainer));\n navButtons.appendChild(leftScrollBtn);\n\n // 创建右侧滚动按钮\n const rightScrollBtn = document.createElement('button');\n rightScrollBtn.className = 'vtable-sheet-scroll-button';\n rightScrollBtn.innerHTML = rightIcon;\n rightScrollBtn.title = '向右滚动';\n rightScrollBtn.addEventListener('click', () => this.sheetTabEventHandler.scrollSheetTabs('right', tabsContainer));\n navButtons.appendChild(rightScrollBtn);\n\n // 创建sheet菜单按钮\n const menuButton = document.createElement('button');\n menuButton.className = 'vtable-sheet-menu-button';\n menuButton.innerHTML = menuIcon;\n menuButton.title = '工作表选项';\n menuButton.addEventListener('click', e => this.sheetTabEventHandler.toggleSheetMenu(e));\n navButtons.appendChild(menuButton);\n\n // 创建菜单容器\n const menuContainer = document.createElement('ul');\n menuContainer.className = 'vtable-sheet-menu-list';\n sheetTab.appendChild(menuContainer);\n\n sheetTab.appendChild(navButtons);\n // 初始化渐变效果\n setTimeout(() => {\n this.sheetTabEventHandler.updateFadeEffects(tabsContainer, fadeLeft, fadeRight);\n }, 100);\n\n return sheetTab;\n }\n\n /**\n * 激活sheet标签并滚动到可见区域\n */\n private _activeSheetTab(): void {\n this.sheetTabEventHandler.activeSheetTab();\n }\n /**\n * 更新sheet切换标签\n * @param tabsContainer 标签容器\n */\n updateSheetTabs(\n tabsContainer: HTMLElement = this.sheetTabElement?.querySelector('.vtable-sheet-tabs-container')\n ): void {\n if (!tabsContainer) {\n return;\n }\n // 清除现有标签\n const tabs = tabsContainer.querySelectorAll('.vtable-sheet-tab');\n tabs.forEach(tab => {\n tab.remove();\n });\n // 添加sheet标签\n const sheets = this.sheetManager.getAllSheets();\n sheets.forEach((sheet, index) => {\n tabsContainer.appendChild(this.createSheetTabItem(sheet, index));\n });\n // 激活sheet标签并滚动到可见区域\n this._activeSheetTab();\n }\n /**\n * 创建tab栏标签项\n */\n private createSheetTabItem(sheet: ISheetDefine, index: number): HTMLElement {\n const tab = document.createElement('div');\n tab.className = 'vtable-sheet-tab';\n tab.dataset.key = sheet.sheetKey;\n tab.textContent = sheet.sheetTitle;\n tab.title = sheet.sheetTitle;\n tab.addEventListener('click', () => this.activateSheet(sheet.sheetKey));\n tab.addEventListener('dblclick', () =>\n this.sheetTabEventHandler.handleSheetTabDblClick(sheet.sheetKey, sheet.sheetTitle)\n );\n // 拖拽事件\n tab.addEventListener('mousedown', e => this.dragManager.handleTabMouseDown(e, sheet.sheetKey));\n\n return tab;\n }\n\n /**\n * 更新sheet列表\n */\n updateSheetMenu(): void {\n this.sheetTabEventHandler.updateSheetMenu();\n }\n\n /**\n * 初始化sheets\n */\n private initSheets(): void {\n if (this.options.sheets && this.options.sheets.length > 0) {\n // 添加所有sheet\n this.options.sheets.forEach((sheetDefine: ISheetDefine) => {\n this.sheetManager.addSheet(sheetDefine);\n });\n\n // 找到active的sheet\n let activeSheetKey = '';\n const activeSheet = this.options.sheets.find((sheet: ISheetDefine) => sheet.active);\n if (activeSheet) {\n activeSheetKey = activeSheet.sheetKey;\n } else {\n activeSheetKey = this.options.sheets[0].sheetKey;\n }\n\n // 激活sheet\n this.activateSheet(activeSheetKey);\n } else {\n // 如果没有提供sheets,创建一个默认的\n this._addNewSheet();\n }\n }\n\n /**\n * 激活指定sheet\n * @param sheetKey sheet的key\n */\n activateSheet(sheetKey: string): void {\n // 设置活动sheet\n this.sheetManager.setActiveSheet(sheetKey);\n\n // 获取sheet定义\n const sheetDefine = this.sheetManager.getSheet(sheetKey);\n if (!sheetDefine) {\n return;\n }\n\n // 隐藏所有sheet实例\n this.workSheetInstances.forEach(instance => {\n instance.getElement().style.display = 'none';\n });\n\n // 如果已经存在实例,则显示并激活对应tab和menu\n if (this.workSheetInstances.has(sheetKey)) {\n const instance = this.workSheetInstances.get(sheetKey)!;\n instance.getElement().style.display = 'block';\n this.activeWorkSheet = instance;\n\n // 更新公式管理器中的活动工作表(在实例激活后)\n this.formulaManager.setActiveSheet(sheetKey);\n\n // sheet标签和菜单项激活样式\n this._activeSheetTab();\n this.sheetTabEventHandler.activeSheetMenuItem();\n\n // 恢复筛选状态\n this.restoreFilterState(instance, sheetDefine);\n } else {\n // 创建新的sheet实例\n const instance = this.createWorkSheetInstance(sheetDefine);\n this.workSheetInstances.set(sheetKey, instance);\n this.activeWorkSheet = instance;\n\n // 更新公式管理器中的活动工作表(在实例创建后)\n this.formulaManager.setActiveSheet(sheetKey);\n\n // 刷新sheet标签和菜单\n this.updateSheetTabs();\n this.updateSheetMenu();\n\n // 恢复筛选状态\n this.restoreFilterState(instance, sheetDefine);\n }\n\n this.updateFormulaBar();\n }\n\n addSheet(sheet: ISheetDefine): void {\n this.sheetManager.addSheet(sheet);\n this.updateSheetTabs();\n this.updateSheetMenu();\n }\n\n /**\n * 删除sheet\n * @param sheetKey 工作表key\n */\n removeSheet(sheetKey: string): void {\n if (this.sheetManager.getSheetCount() <= 1) {\n showSnackbar('至少保留一个工作表', 1300);\n return;\n }\n // 删除实例对应的dom元素\n const instance = this.workSheetInstances.get(sheetKey);\n if (instance) {\n instance.getElement().remove();\n this.workSheetInstances.delete(sheetKey);\n }\n // 删除sheet定义\n const newActiveSheetKey = this.sheetManager.removeSheet(sheetKey);\n // 激活新的sheet(如果有)\n if (newActiveSheetKey) {\n this.activateSheet(newActiveSheetKey);\n }\n this.updateSheetTabs();\n this.updateSheetMenu();\n }\n getSheetCount(): number {\n return this.sheetManager.getSheetCount();\n }\n getSheet(sheetKey: string): ISheetDefine | null {\n return this.sheetManager.getSheet(sheetKey);\n }\n getAllSheets(): ISheetDefine[] {\n return this.sheetManager.getAllSheets();\n }\n\n /**\n * 创建sheet实例\n * @param sheetDefine sheet的定义\n */\n createWorkSheetInstance(sheetDefine: ISheetDefine): WorkSheet {\n formulaEditor.setSheet(this);\n // 计算内容区域大小\n const contentWidth = this.contentElement.clientWidth;\n const contentHeight = this.contentElement.clientHeight;\n sheetDefine.dragOrder = sheetDefine.dragOrder ?? this.options.dragOrder;\n // 创建sheet实例\n const sheet = new WorkSheet(this, {\n ...sheetDefine,\n container: this.contentElement,\n width: contentWidth,\n height: contentHeight,\n defaultRowHeight: this.options.defaultRowHeight,\n defaultColWidth: this.options.defaultColWidth,\n dragOrder: sheetDefine.dragOrder,\n plugins: getTablePlugins(sheetDefine, this.options, this),\n headerEditor: 'formula',\n editor: 'formula',\n select: {\n makeSelectCellVisible: false\n },\n style: {\n borderColor: ['#E1E4E8', '#E1E4E8', '#E1E4E8', '#E1E4E8'],\n borderLineWidth: [1, 1, 1, 1],\n borderLineDash: [null, null, null, null],\n padding: [8, 8, 8, 8]\n },\n editCellTrigger: ['api', 'keydown', 'doubleclick'],\n customMergeCell: sheetDefine.cellMerge,\n theme: sheetDefine.theme?.tableTheme || this.options.theme?.tableTheme\n } as any);\n\n // 注册事件 - 使用预先绑定的事件处理方法和WorkSheetEventType枚举\n sheet.on(WorkSheetEventType.CELL_CLICK, this.eventManager.handleCellClickBind);\n sheet.on(WorkSheetEventType.CELL_VALUE_CHANGED, this.eventManager.handleCellValueChangedBind);\n sheet.on(WorkSheetEventType.SELECTION_CHANGED, this.eventManager.handleSelectionChangedForRangeModeBind);\n sheet.on(WorkSheetEventType.SELECTION_END, this.eventManager.handleSelectionChangedForRangeModeBind);\n\n // 在公式管理器中添加这个sheet\n try {\n const normalizedData = this.formulaManager.normalizeSheetData(sheetDefine.data, sheet.tableInstance);\n this.formulaManager.addSheet(sheetDefine.sheetKey, normalizedData, sheetDefine.sheetTitle);\n // 加载保存的公式数据(如果有)\n if (sheetDefine.formulas && Object.keys(sheetDefine.formulas).length > 0) {\n this.loadFormulas(sheetDefine.sheetKey, sheetDefine.formulas);\n }\n } catch (error) {\n console.warn(`Sheet ${sheetDefine.sheetKey} may already exist in formula manager:`, error);\n // 如果添加失败(可能已存在),继续执行\n }\n\n return sheet;\n }\n /**\n * 加载指定工作表的公式数据\n * @param sheetKey 工作表键\n * @param formulas 公式数据 (A1表示法的单元格引用 -> 公式内容)\n */\n private loadFormulas(sheetKey: string, formulas: Record<string, string>): void {\n if (!formulas || Object.keys(formulas).length === 0) {\n return;\n }\n\n try {\n // 优化公式计算顺序\n const sortedFormulas = this.formulaManager.sortFormulasByDependency(sheetKey, formulas);\n // 按照优化后的顺序设置公式\n for (const [cellRef, formula] of sortedFormulas) {\n // 解析单元格引用 (如 A1, B2) 到行列索引\n const { row, col } = this.parseCellKey(cellRef);\n // 设置单元格公式\n this.formulaManager.setCellContent({ sheet: sheetKey, row, col }, formula);\n }\n\n // 刷新计算\n this.formulaManager.rebuildAndRecalculate();\n } catch (error) {\n console.error(`Failed to load formulas for sheet ${sheetKey}:`, error);\n }\n }\n\n /**\n * 将单元格引用(A1表示法)解析为行列索引\n * @param cellKey 单元格引用 (如 A1, B2)\n * @returns 行列索引 (0-based)\n */\n private parseCellKey(cellKey: string): { row: number; col: number } {\n // 匹配列引用(字母部分)和行引用(数字部分)\n const match = cellKey.match(/^([A-Za-z]+)(\\d+)$/);\n if (!match) {\n throw new Error(`Invalid cell reference: ${cellKey}`);\n }\n const [, colStr, rowStr] = match;\n // 解析行索引 (1-based -> 0-based)\n const row = parseInt(rowStr, 10) - 1;\n // 解析列索引 (A -> 0, B -> 1, ..., Z -> 25, AA -> 26, etc.)\n let col = 0;\n for (let i = 0; i < colStr.length; i++) {\n const charCode = colStr.toUpperCase().charCodeAt(i) - 65; // 65 is ASCII for 'A'\n col = col * 26 + charCode;\n }\n return { row, col };\n }\n\n /**\n * 恢复筛选状态\n */\n private restoreFilterState(sheet: WorkSheet, sheetDefine: ISheetDefine): void {\n // 如果没有保存的筛选状态,直接返回\n if (!sheetDefine.filterState) {\n return;\n }\n\n // console.log(`恢复 Sheet ${sheetDefine.sheetKey} 的筛选状态:`, sheetDefine.filterState);\n\n // 等待表格初始化完成\n setTimeout(() => {\n if (sheet.tableInstance && sheet.tableInstance.pluginManager) {\n const filterPlugin = sheet.tableInstance.pluginManager.getPluginByName('Filter') as any;\n if (filterPlugin) {\n filterPlugin.setFilterState(sheetDefine.filterState);\n } else {\n console.warn(`Sheet ${sheetDefine.sheetKey} 未找到筛选插件或插件不支持 setFilterState 方法`);\n }\n } else {\n console.warn(`Sheet ${sheetDefine.sheetKey} 表格实例或插件管理器未初始化`);\n }\n }, 0);\n }\n\n /**\n * 添加新sheet\n */\n private _addNewSheet(): void {\n // 生成新sheet的key和title\n const sheetCount = this.sheetManager.getSheetCount();\n const baseKey = `sheet${sheetCount + 1}`;\n const baseTitle = `Sheet ${sheetCount + 1}`;\n let key = baseKey;\n let title = baseTitle;\n let index = sheetCount + 1;\n // 检查key和title是否被占用,递增直到唯一\n const existingKeys = new Set(this.sheetManager.getAllSheets().map(s => s.sheetKey));\n const existingTitles = new Set(this.sheetManager.getAllSheets().map(s => s.sheetTitle));\n while (existingKeys.has(key) || existingTitles.has(title)) {\n index += 1;\n key = `sheet${index}`;\n title = `Sheet ${index}`;\n }\n\n // 创建新sheet配置\n const newSheet: ISheetDefine = {\n sheetKey: key,\n sheetTitle: title,\n columnCount: 20,\n rowCount: 100,\n data: []\n };\n\n // 添加到管理器\n this.sheetManager.addSheet(newSheet);\n\n // 激活新sheet\n this.activateSheet(key);\n }\n\n /**\n * 更新公式栏\n */\n private updateFormulaBar(): void {\n this.formulaUIManager.updateFormulaBar();\n }\n\n /**\n * 获取公式管理器\n */\n getFormulaManager(): FormulaManager {\n return this.formulaManager;\n }\n /**\n * 获取Sheet管理器\n */\n getSheetManager(): SheetManager {\n return this.sheetManager;\n }\n\n /**\n * 获取活动Sheet实例\n */\n getActiveSheet(): WorkSheet | null {\n return this.activeWorkSheet;\n }\n\n /**\n * 根据名称获取Sheet实例\n */\n getSheetByName(sheetName: string): WorkSheet | null {\n // 遍历所有sheet实例,找到匹配的sheet\n for (const [sheetKey, workSheet] of this.workSheetInstances) {\n const sheetDefine = this.sheetManager.getSheet(sheetKey);\n if (sheetDefine && sheetDefine.sheetTitle === sheetName) {\n return workSheet;\n }\n }\n return null;\n }\n\n /**\n * 保存所有数据为配置\n */\n saveToConfig(): IVTableSheetOptions {\n // 收集所有sheet的数据\n const sheets: ISheetDefine[] = [];\n\n this.sheetManager.getAllSheets().forEach(sheetDefine => {\n const instance = this.workSheetInstances.get(sheetDefine.sheetKey);\n if (instance) {\n const data = instance.getCopiedData();\n //#region 组织columns\n //column中去除field字段 (field字段会在columns.map中被使用)\n const columns = instance.getColumns().map(column => {\n // 解构时省略field属性\n const { ...rest } = column;\n // 删除field属性\n delete rest.field;\n return rest;\n });\n // 找到最后一个有title的列的索引\n const lastTitleIndex = columns.reduce((lastIndex, column, index) => (column.title ? index : lastIndex), -1);\n\n // 从最后一个有title的列之后删除所有列\n if (lastTitleIndex === -1) {\n columns.length = 0; // 清空数组\n } else {\n columns.splice(lastTitleIndex + 1);\n }\n //#endregion\n\n //#region 组织data\n // 找到最后一个有非空值的行\n const lastDataIndex = data.reduce((lastIndex, rowData, index) => (rowData ? index : lastIndex), -1);\n // 保留到最后一个有值的行,删除之后的空行\n if (lastDataIndex === -1) {\n data.length = 0; // 清空数组\n } else {\n data.splice(lastDataIndex + 1);\n }\n //#endregion\n // 获取筛选状态\n let filterState = null;\n const filterPlugin = instance.tableInstance.pluginManager.getPluginByName('Filter') as any;\n if (filterPlugin) {\n filterState = filterPlugin.getFilterState();\n }\n\n // 获取排序状态\n let sortState = instance.tableInstance.internalProps.sortState;\n let currentSortState;\n if (sortState) {\n sortState = Array.isArray(sortState) ? sortState : [sortState];\n currentSortState = sortState.map(item => ({\n field: item.field,\n order: item.order,\n ...(item.orderFn != null && { orderFn: item.orderFn })\n }));\n }\n\n // 使用FormulaManager的导出方法获取所有公式\n const formulas = this.formulaManager.exportFormulas(sheetDefine.sheetKey);\n\n //#region 从tableInstance.internalProps._widthResizedColMap对应到columns的key 组织columnWidthConfig\n const columnWidthConfig = Array.from(instance.tableInstance.internalProps._widthResizedColMap).map(key => {\n return {\n key: key,\n width: instance.tableInstance.getColWidth(key as number)\n };\n });\n //#endregion\n //#region 从tableInstance.internalProps._heightResizedRowMap对应到columns的key 组织rowHeightConfig\n const rowHeightConfig = Array.from(instance.tableInstance.internalProps._heightResizedRowMap).map(key => {\n return {\n key: key,\n height: instance.tableInstance.getRowHeight(key)\n };\n });\n //#endregion\n\n sheets.push({\n ...sheetDefine,\n data,\n columns,\n cellMerge: instance.tableInstance.options.customMergeCell as TYPES.CustomMergeCellArray,\n showHeader: instance.tableInstance.options.showHeader,\n frozenRowCount: instance.tableInstance.frozenRowCount,\n frozenColCount: instance.tableInstance.frozenColCount,\n active: sheetDefine.sheetKey === this.sheetManager.getActiveSheet().sheetKey,\n filterState: filterState,\n sortState: currentSortState,\n formulas: Object.keys(formulas).length > 0 ? formulas : undefined,\n columnWidthConfig,\n rowHeightConfig\n });\n } else {\n sheets.push(sheetDefine);\n }\n });\n\n return {\n ...this.options,\n sheets\n };\n }\n\n /** 导出当前sheet到文件 */\n exportSheetToFile(fileType: 'csv' | 'xlsx'): void {\n const sheet = this.getActiveSheet();\n if (!sheet) {\n return;\n }\n if (fileType === 'csv') {\n if ((sheet.tableInstance as any)?.exportToCsv) {\n (sheet.tableInstance as any).exportToCsv();\n } else {\n console.warn('Please configure TableExportPlugin in VTablePluginModules');\n }\n } else {\n if ((sheet.tableInstance as any)?.exportToExcel) {\n (sheet.tableInstance as any).exportToExcel();\n } else {\n console.warn('Please configure TableExportPlugin in VTablePluginModules');\n }\n }\n }\n /** 导入文件到当前sheet */\n async importFileToSheet(): Promise<ImportResult | void> {\n const sheet = this.getActiveSheet();\n if (!sheet) {\n return;\n }\n if ((sheet.tableInstance as any)?.importFile) {\n return await (sheet.tableInstance as any).importFile();\n }\n console.warn('Please configure ExcelImportPlugin in VTablePluginModules');\n }\n /**\n * 获取容器元素\n */\n getContainer(): HTMLElement {\n return this.container;\n }\n\n /**\n * 获取根元素\n */\n getRootElement(): HTMLElement {\n return this.rootElement;\n }\n\n /**\n * 获取选项\n */\n getOptions(): IVTableSheetOptions {\n return this.options;\n }\n\n /**\n * 获取公式栏元素\n */\n getFormulaBarElement(): HTMLElement | null {\n return this.formulaBarElement;\n }\n\n /**\n * 获取sheet标签栏元素\n */\n getSheetTabElement(): HTMLElement | null {\n return this.sheetTabElement;\n }\n\n /**\n * 获取内容区域元素\n */\n getContentElement(): HTMLElement {\n return this.contentElement;\n }\n\n /**\n * 销毁实例\n */\n release(): void {\n // 释放事件管理器\n this.eventManager.release();\n this.formulaManager.release();\n this.formulaUIManager.release();\n // 移除点击外部监听器\n this.sheetTabEventHandler.removeClickOutsideListener();\n // 销毁所有sheet实例\n this.workSheetInstances.forEach(instance => {\n instance.release();\n });\n // 清空容器\n if (this.rootElement && this.rootElement.parentNode) {\n this.rootElement.parentNode.removeChild(this.rootElement);\n }\n\n if (this.formulaAutocomplete) {\n this.formulaAutocomplete.release();\n }\n if (this.formulaManager.cellHighlightManager) {\n this.formulaManager.cellHighlightManager.release();\n }\n }\n\n /**\n * 导出指定sheet的数据\n * @param sheetKey sheet的key\n * @returns 数据\n */\n exportData(sheetKey: string): any[][] {\n const sheet = this.workSheetInstances.get(sheetKey);\n if (!sheet) {\n return [];\n }\n return sheet.getData();\n }\n\n /**\n * 导出所有sheet的数据\n * @returns 数据\n */\n exportAllData(): any[][] {\n const sheets = Array.from(this.workSheetInstances.values());\n return sheets.map(sheet => sheet.getData());\n }\n\n /**\n * resize\n */\n resize(): void {\n // const containerWidth = this.getContainer().clientWidth;\n // const containerHeight = this.getContainer().clientHeight;\n // this.rootElement.style.width = `${this.getOptions().width || containerWidth}px`;\n // this.rootElement.style.height = `${this.getOptions().height || containerHeight}px`;\n this.getActiveSheet()?.resize();\n }\n\n /**\n * 若所选范围包含当前正在编辑的单元格,自动排除该单元格以避免 #CYCLE!\n */\n excludeEditCellFromSelection(\n range: { startRow: number; startCol: number; endRow: number; endCol: number },\n editRow: number,\n editCol: number\n ) {\n const r = { ...range };\n const withinRow = r.startRow <= editRow && editRow <= r.endRow;\n const withinCol = r.startCol <= editCol && editCol <= r.endCol;\n if (!withinRow || !withinCol) {\n return r;\n }\n\n const rowSpan = r.endRow - r.startRow;\n const colSpan = r.endCol - r.startCol;\n\n // 如果选择范围就是编辑单元格本身,返回空范围(表示无效选择)\n if (rowSpan === 0 && colSpan === 0 && r.startRow === editRow && r.startCol === editCol) {\n return { startRow: -1, startCol: -1, endRow: -1, endCol: -1 };\n }\n\n if (rowSpan >= colSpan) {\n // 优先在行方向上排除编辑单元格\n if (editRow === r.startRow && r.startRow < r.endRow) {\n r.startRow += 1;\n } else if (editRow === r.endRow && r.startRow < r.endRow) {\n r.endRow -= 1;\n } else if (r.startRow < r.endRow) {\n r.startRow += 1;\n } // 中间,默认从起点缩一格\n } else {\n // 优先在列方向上排除编辑单元格\n if (editCol === r.startCol && r.startCol < r.endCol) {\n r.startCol += 1;\n } else if (editCol === r.endCol && r.startCol < r.endCol) {\n r.endCol -= 1;\n } else if (r.startCol < r.endCol) {\n r.startCol += 1;\n }\n }\n return r;\n }\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/components/vtable-sheet.ts"],"names":[],"mappings":"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","file":"vtable-sheet.js","sourcesContent":["import { FormulaManager } from '../managers/formula-manager';\nimport SheetManager from '../managers/sheet-manager';\nimport { WorkSheet } from '../core/WorkSheet';\nimport * as VTable from '@visactor/vtable';\nimport { getTablePlugins } from '../core/table-plugins';\nimport { EventManager } from '../event/event-manager';\nimport { showSnackbar } from '../tools/ui/snackbar';\nimport type { IVTableSheetOptions, ISheetDefine, CellValueChangedEvent, ImportResult } from '../ts-types';\nimport type { MultiSheetImportResult } from '@visactor/vtable-plugins/src/excel-import/types';\nimport { WorkSheetEventType } from '../ts-types';\nimport SheetTabDragManager from '../managers/tab-drag-manager';\nimport { checkTabTitle } from '../tools';\nimport { FormulaAutocomplete } from '../formula/formula-autocomplete';\nimport { formulaEditor } from '../formula/formula-editor';\nimport { CellHighlightManager } from '../formula/cell-highlight-manager';\nimport type { TYPES } from '@visactor/vtable';\nimport { MenuManager } from '../managers/menu-manager';\nimport { FormulaUIManager } from '../formula/formula-ui-manager';\nimport { SheetTabEventHandler } from './sheet-tab-event-handler';\n\n// 注册公式编辑器\nVTable.register.editor('formula', formulaEditor);\nexport default class VTableSheet {\n /** DOM容器 */\n private container: HTMLElement;\n /** 配置选项 */\n private options: IVTableSheetOptions;\n /** sheet管理器 */\n private sheetManager: SheetManager;\n /** 公式管理器 */\n formulaManager: FormulaManager;\n /** 事件管理器 */\n private eventManager: EventManager;\n\n /** 菜单管理 */\n private menuManager: MenuManager;\n /** 当前活动sheet实例 */\n private activeWorkSheet: WorkSheet | null = null;\n /** 所有sheet实例 */\n workSheetInstances: Map<string, WorkSheet> = new Map();\n /** 公式自动补全 */\n private formulaAutocomplete: FormulaAutocomplete | null = null;\n\n /** 公式UI管理器 */\n formulaUIManager: FormulaUIManager;\n\n /** UI组件 */\n private rootElement: HTMLElement;\n private formulaBarElement: HTMLElement | null = null;\n private sheetTabElement: HTMLElement | null = null;\n private mainMenuElement: HTMLElement | null = null;\n private contentElement: HTMLElement;\n\n // tab拖拽管理器\n private dragManager: SheetTabDragManager;\n /** sheet标签事件处理器 */\n private sheetTabEventHandler: SheetTabEventHandler;\n\n /**\n * 构造函数\n * @param options 配置选项\n */\n constructor(container: HTMLElement, options: IVTableSheetOptions) {\n this.container = container;\n this.options = this.mergeDefaultOptions(options);\n\n // 创建管理器\n this.sheetManager = new SheetManager();\n this.formulaManager = new FormulaManager(this);\n this.eventManager = new EventManager(this);\n this.dragManager = new SheetTabDragManager(this);\n this.menuManager = new MenuManager(this);\n this.formulaUIManager = new FormulaUIManager(this);\n this.sheetTabEventHandler = new SheetTabEventHandler(this);\n\n // 初始化UI\n this.initUI();\n\n // 初始化sheets\n this.initSheets();\n\n this.resize();\n }\n\n /**\n * 合并默认配置\n */\n private mergeDefaultOptions(options: IVTableSheetOptions): IVTableSheetOptions {\n return {\n showFormulaBar: true,\n showSheetTab: true,\n defaultRowHeight: 25,\n defaultColWidth: 100,\n ...options\n };\n }\n\n /**\n * 初始化公式自动补全\n */\n private initFormulaAutocomplete(): void {\n if (!this.formulaBarElement) {\n return;\n }\n\n const formulaInput = this.formulaUIManager.formulaInput;\n if (formulaInput) {\n this.formulaAutocomplete = new FormulaAutocomplete(this.rootElement, this);\n this.formulaAutocomplete.attachTo(formulaInput);\n }\n }\n\n /**\n * 初始化UI\n */\n private initUI(): void {\n // 创建根元素\n this.rootElement = document.createElement('div');\n this.rootElement.className = 'vtable-sheet-container';\n // this.rootElement.style.width = `${this.options.width}px`;\n // this.rootElement.style.height = `${this.options.height}px`;\n this.container.appendChild(this.rootElement);\n //创建顶部菜单和公式的容器\n const topContainer = document.createElement('div');\n topContainer.className = 'vtable-sheet-top-container';\n this.rootElement.appendChild(topContainer);\n\n // 创建主菜单\n if (this.options.mainMenu?.show) {\n this.mainMenuElement = this.menuManager.createMainMenu();\n topContainer.appendChild(this.mainMenuElement);\n }\n // 创建公式栏\n if (this.options.showFormulaBar) {\n this.formulaBarElement = this.formulaUIManager.createFormulaBar();\n topContainer.appendChild(this.formulaBarElement);\n\n this.initFormulaAutocomplete();\n }\n\n // 创建内容区域\n this.contentElement = document.createElement('div');\n this.contentElement.className = 'vtable-sheet-content';\n this.rootElement.appendChild(this.contentElement);\n\n // 创建sheet切换栏\n if (this.options.showSheetTab) {\n this.sheetTabElement = this.createSheetTab();\n this.rootElement.appendChild(this.sheetTabElement);\n }\n }\n\n /**\n * 创建sheet切换栏\n */\n private createSheetTab(): HTMLElement {\n // SVG图标常量\n const addIcon =\n '<svg viewBox=\"0 0 24 24\" width=\"16\" height=\"16\">' +\n '<path fill=\"currentColor\" d=\"M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6z\"/>' +\n '</svg>';\n const leftIcon =\n '<svg viewBox=\"0 0 24 24\" width=\"16\" height=\"16\">' +\n '<path fill=\"currentColor\" d=\"M15.41 7.41L14 6l-6 6 6 6 1.41-1.41L10.83 12z\"/>' +\n '</svg>';\n const rightIcon =\n '<svg viewBox=\"0 0 24 24\" width=\"16\" height=\"16\">' +\n '<path fill=\"currentColor\" d=\"M10 6L8.59 7.41 13.17 12l-4.58 4.59L10 18l6-6z\"/>' +\n '</svg>';\n const menuIcon =\n '<svg viewBox=\"0 0 24 24\" width=\"16\" height=\"16\">' +\n '<path fill=\"currentColor\" d=\"M12 8c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm0 2c-1.1 0-2 ' +\n '.9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0 6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z\"/>' +\n '</svg>';\n\n const sheetTab = document.createElement('div');\n sheetTab.className = 'vtable-sheet-tab-bar';\n\n // 创建左侧渐变效果\n const fadeLeft = document.createElement('div');\n fadeLeft.className = 'vtable-sheet-fade-left';\n fadeLeft.style.display = 'none';\n sheetTab.appendChild(fadeLeft);\n\n // 创建中间的tabs容器\n const tabsContainer = document.createElement('div');\n tabsContainer.className = 'vtable-sheet-tabs-container';\n tabsContainer.addEventListener('scroll', () =>\n this.sheetTabEventHandler.updateFadeEffects(tabsContainer, fadeLeft, fadeRight)\n );\n sheetTab.appendChild(tabsContainer);\n\n // 创建插入指示器\n const insertIndicator = document.createElement('div');\n insertIndicator.className = 'vtable-sheet-insert-indicator';\n insertIndicator.style.display = 'none';\n tabsContainer.appendChild(insertIndicator);\n\n // 创建右侧渐变效果\n const fadeRight = document.createElement('div');\n fadeRight.className = 'vtable-sheet-fade-right';\n sheetTab.appendChild(fadeRight);\n\n // 添加新增sheet按钮\n const addButton = document.createElement('button');\n addButton.className = 'vtable-sheet-add-button';\n addButton.innerHTML = addIcon;\n addButton.title = '添加工作表';\n addButton.addEventListener('click', () => this._addNewSheet());\n sheetTab.appendChild(addButton);\n\n // 创建导航按钮容器\n const navButtons = document.createElement('div');\n navButtons.className = 'vtable-sheet-nav-buttons';\n\n // 创建左侧滚动按钮\n const leftScrollBtn = document.createElement('button');\n leftScrollBtn.className = 'vtable-sheet-scroll-button';\n leftScrollBtn.innerHTML = leftIcon;\n leftScrollBtn.title = '向左滚动';\n leftScrollBtn.addEventListener('click', () => this.sheetTabEventHandler.scrollSheetTabs('left', tabsContainer));\n navButtons.appendChild(leftScrollBtn);\n\n // 创建右侧滚动按钮\n const rightScrollBtn = document.createElement('button');\n rightScrollBtn.className = 'vtable-sheet-scroll-button';\n rightScrollBtn.innerHTML = rightIcon;\n rightScrollBtn.title = '向右滚动';\n rightScrollBtn.addEventListener('click', () => this.sheetTabEventHandler.scrollSheetTabs('right', tabsContainer));\n navButtons.appendChild(rightScrollBtn);\n\n // 创建sheet菜单按钮\n const menuButton = document.createElement('button');\n menuButton.className = 'vtable-sheet-menu-button';\n menuButton.innerHTML = menuIcon;\n menuButton.title = '工作表选项';\n menuButton.addEventListener('click', e => this.sheetTabEventHandler.toggleSheetMenu(e));\n navButtons.appendChild(menuButton);\n\n // 创建菜单容器\n const menuContainer = document.createElement('ul');\n menuContainer.className = 'vtable-sheet-menu-list';\n sheetTab.appendChild(menuContainer);\n\n sheetTab.appendChild(navButtons);\n // 初始化渐变效果\n setTimeout(() => {\n this.sheetTabEventHandler.updateFadeEffects(tabsContainer, fadeLeft, fadeRight);\n }, 100);\n\n return sheetTab;\n }\n\n /**\n * 激活sheet标签并滚动到可见区域\n */\n private _activeSheetTab(): void {\n this.sheetTabEventHandler.activeSheetTab();\n }\n /**\n * 更新sheet切换标签\n * @param tabsContainer 标签容器\n */\n updateSheetTabs(\n tabsContainer: HTMLElement = this.sheetTabElement?.querySelector('.vtable-sheet-tabs-container')\n ): void {\n if (!tabsContainer) {\n return;\n }\n // 清除现有标签\n const tabs = tabsContainer.querySelectorAll('.vtable-sheet-tab');\n tabs.forEach(tab => {\n tab.remove();\n });\n // 添加sheet标签\n const sheets = this.sheetManager.getAllSheets();\n sheets.forEach((sheet, index) => {\n tabsContainer.appendChild(this.createSheetTabItem(sheet, index));\n });\n // 激活sheet标签并滚动到可见区域\n this._activeSheetTab();\n }\n /**\n * 创建tab栏标签项\n */\n private createSheetTabItem(sheet: ISheetDefine, index: number): HTMLElement {\n const tab = document.createElement('div');\n tab.className = 'vtable-sheet-tab';\n tab.dataset.key = sheet.sheetKey;\n tab.textContent = sheet.sheetTitle;\n tab.title = sheet.sheetTitle;\n tab.addEventListener('click', () => this.activateSheet(sheet.sheetKey));\n tab.addEventListener('dblclick', () =>\n this.sheetTabEventHandler.handleSheetTabDblClick(sheet.sheetKey, sheet.sheetTitle)\n );\n // 拖拽事件\n tab.addEventListener('mousedown', e => this.dragManager.handleTabMouseDown(e, sheet.sheetKey));\n\n return tab;\n }\n\n /**\n * 更新sheet列表\n */\n updateSheetMenu(): void {\n this.sheetTabEventHandler.updateSheetMenu();\n }\n\n /**\n * 初始化sheets\n */\n private initSheets(): void {\n if (this.options.sheets && this.options.sheets.length > 0) {\n // 添加所有sheet\n this.options.sheets.forEach((sheetDefine: ISheetDefine) => {\n this.sheetManager.addSheet(sheetDefine);\n });\n\n // 找到active的sheet\n let activeSheetKey = '';\n const activeSheet = this.options.sheets.find((sheet: ISheetDefine) => sheet.active);\n if (activeSheet) {\n activeSheetKey = activeSheet.sheetKey;\n } else {\n activeSheetKey = this.options.sheets[0].sheetKey;\n }\n\n // 激活sheet\n this.activateSheet(activeSheetKey);\n } else {\n // 如果没有提供sheets,创建一个默认的\n this._addNewSheet();\n }\n }\n\n /**\n * 激活指定sheet\n * @param sheetKey sheet的key\n */\n activateSheet(sheetKey: string): void {\n // 设置活动sheet\n this.sheetManager.setActiveSheet(sheetKey);\n\n // 获取sheet定义\n const sheetDefine = this.sheetManager.getSheet(sheetKey);\n if (!sheetDefine) {\n return;\n }\n\n // 隐藏所有sheet实例\n this.workSheetInstances.forEach(instance => {\n instance.getElement().style.display = 'none';\n });\n\n // 如果已经存在实例,则显示并激活对应tab和menu\n if (this.workSheetInstances.has(sheetKey)) {\n const instance = this.workSheetInstances.get(sheetKey)!;\n instance.getElement().style.display = 'block';\n this.activeWorkSheet = instance;\n\n // 更新公式管理器中的活动工作表(在实例激活后)\n this.formulaManager.setActiveSheet(sheetKey);\n\n // sheet标签和菜单项激活样式\n this._activeSheetTab();\n this.sheetTabEventHandler.activeSheetMenuItem();\n\n // 恢复筛选状态\n this.restoreFilterState(instance, sheetDefine);\n } else {\n // 创建新的sheet实例\n const instance = this.createWorkSheetInstance(sheetDefine);\n this.workSheetInstances.set(sheetKey, instance);\n this.activeWorkSheet = instance;\n\n // 更新公式管理器中的活动工作表(在实例创建后)\n this.formulaManager.setActiveSheet(sheetKey);\n\n // 刷新sheet标签和菜单\n this.updateSheetTabs();\n this.updateSheetMenu();\n\n // 恢复筛选状态\n this.restoreFilterState(instance, sheetDefine);\n }\n\n this.updateFormulaBar();\n }\n\n addSheet(sheet: ISheetDefine): void {\n this.sheetManager.addSheet(sheet);\n this.updateSheetTabs();\n this.updateSheetMenu();\n }\n\n /**\n * 选择 Excel 文件\n * @returns Promise<File | null>\n */\n private _selectExcelFile(): Promise<File | null> {\n return new Promise(resolve => {\n const input = document.createElement('input');\n input.type = 'file';\n input.accept = '.xlsx,.xls';\n input.style.display = 'none';\n document.body.appendChild(input);\n\n input.addEventListener('change', e => {\n const file = (e.target as HTMLInputElement).files?.[0];\n document.body.removeChild(input);\n resolve(file || null);\n });\n\n // 如果用户取消选择\n input.addEventListener('cancel', () => {\n document.body.removeChild(input);\n resolve(null);\n });\n\n input.click();\n });\n }\n\n /**\n * 删除sheet\n * @param sheetKey 工作表key\n */\n removeSheet(sheetKey: string): void {\n if (this.sheetManager.getSheetCount() <= 1) {\n showSnackbar('至少保留一个工作表', 1300);\n return;\n }\n // 删除实例对应的dom元素\n const instance = this.workSheetInstances.get(sheetKey);\n if (instance) {\n instance.getElement().remove();\n this.workSheetInstances.delete(sheetKey);\n }\n // 删除sheet定义\n const newActiveSheetKey = this.sheetManager.removeSheet(sheetKey);\n // 激活新的sheet(如果有)\n if (newActiveSheetKey) {\n this.activateSheet(newActiveSheetKey);\n }\n this.updateSheetTabs();\n this.updateSheetMenu();\n }\n getSheetCount(): number {\n return this.sheetManager.getSheetCount();\n }\n getSheet(sheetKey: string): ISheetDefine | null {\n return this.sheetManager.getSheet(sheetKey);\n }\n getAllSheets(): ISheetDefine[] {\n return this.sheetManager.getAllSheets();\n }\n\n /**\n * 创建sheet实例\n * @param sheetDefine sheet的定义\n */\n createWorkSheetInstance(sheetDefine: ISheetDefine): WorkSheet {\n formulaEditor.setSheet(this);\n // 计算内容区域大小\n const contentWidth = this.contentElement.clientWidth;\n const contentHeight = this.contentElement.clientHeight;\n sheetDefine.dragOrder = sheetDefine.dragOrder ?? this.options.dragOrder;\n // 创建sheet实例\n const sheet = new WorkSheet(this, {\n ...sheetDefine,\n container: this.contentElement,\n width: contentWidth,\n height: contentHeight,\n defaultRowHeight: this.options.defaultRowHeight,\n defaultColWidth: this.options.defaultColWidth,\n dragOrder: sheetDefine.dragOrder,\n plugins: getTablePlugins(sheetDefine, this.options, this),\n headerEditor: 'formula',\n editor: 'formula',\n select: {\n makeSelectCellVisible: false\n },\n style: {\n borderColor: ['#E1E4E8', '#E1E4E8', '#E1E4E8', '#E1E4E8'],\n borderLineWidth: [1, 1, 1, 1],\n borderLineDash: [null, null, null, null],\n padding: [8, 8, 8, 8]\n },\n editCellTrigger: ['api', 'keydown', 'doubleclick'],\n customMergeCell: sheetDefine.cellMerge,\n theme: sheetDefine.theme?.tableTheme || this.options.theme?.tableTheme\n } as any);\n\n // 注册事件 - 使用预先绑定的事件处理方法和WorkSheetEventType枚举\n sheet.on(WorkSheetEventType.CELL_CLICK, this.eventManager.handleCellClickBind);\n sheet.on(WorkSheetEventType.CELL_VALUE_CHANGED, this.eventManager.handleCellValueChangedBind);\n sheet.on(WorkSheetEventType.SELECTION_CHANGED, this.eventManager.handleSelectionChangedForRangeModeBind);\n sheet.on(WorkSheetEventType.SELECTION_END, this.eventManager.handleSelectionChangedForRangeModeBind);\n\n // 在公式管理器中添加这个sheet\n try {\n const normalizedData = this.formulaManager.normalizeSheetData(sheetDefine.data, sheet.tableInstance);\n this.formulaManager.addSheet(sheetDefine.sheetKey, normalizedData, sheetDefine.sheetTitle);\n // 加载保存的公式数据(如果有)\n if (sheetDefine.formulas && Object.keys(sheetDefine.formulas).length > 0) {\n this.loadFormulas(sheetDefine.sheetKey, sheetDefine.formulas);\n }\n } catch (error) {\n console.warn(`Sheet ${sheetDefine.sheetKey} may already exist in formula manager:`, error);\n // 如果添加失败(可能已存在),继续执行\n }\n\n return sheet;\n }\n /**\n * 加载指定工作表的公式数据\n * @param sheetKey 工作表键\n * @param formulas 公式数据 (A1表示法的单元格引用 -> 公式内容)\n */\n private loadFormulas(sheetKey: string, formulas: Record<string, string>): void {\n if (!formulas || Object.keys(formulas).length === 0) {\n return;\n }\n\n try {\n // 优化公式计算顺序\n const sortedFormulas = this.formulaManager.sortFormulasByDependency(sheetKey, formulas);\n // 按照优化后的顺序设置公式\n for (const [cellRef, formula] of sortedFormulas) {\n // 解析单元格引用 (如 A1, B2) 到行列索引\n const { row, col } = this.parseCellKey(cellRef);\n // 设置单元格公式\n this.formulaManager.setCellContent({ sheet: sheetKey, row, col }, formula);\n }\n\n // 刷新计算\n this.formulaManager.rebuildAndRecalculate();\n } catch (error) {\n console.error(`Failed to load formulas for sheet ${sheetKey}:`, error);\n }\n }\n\n /**\n * 将单元格引用(A1表示法)解析为行列索引\n * @param cellKey 单元格引用 (如 A1, B2)\n * @returns 行列索引 (0-based)\n */\n private parseCellKey(cellKey: string): { row: number; col: number } {\n // 匹配列引用(字母部分)和行引用(数字部分)\n const match = cellKey.match(/^([A-Za-z]+)(\\d+)$/);\n if (!match) {\n throw new Error(`Invalid cell reference: ${cellKey}`);\n }\n const [, colStr, rowStr] = match;\n // 解析行索引 (1-based -> 0-based)\n const row = parseInt(rowStr, 10) - 1;\n // 解析列索引 (A -> 0, B -> 1, ..., Z -> 25, AA -> 26, etc.)\n let col = 0;\n for (let i = 0; i < colStr.length; i++) {\n const charCode = colStr.toUpperCase().charCodeAt(i) - 65; // 65 is ASCII for 'A'\n col = col * 26 + charCode;\n }\n return { row, col };\n }\n\n /**\n * 恢复筛选状态\n */\n private restoreFilterState(sheet: WorkSheet, sheetDefine: ISheetDefine): void {\n // 如果没有保存的筛选状态,直接返回\n if (!sheetDefine.filterState) {\n return;\n }\n\n // console.log(`恢复 Sheet ${sheetDefine.sheetKey} 的筛选状态:`, sheetDefine.filterState);\n\n // 等待表格初始化完成\n setTimeout(() => {\n if (sheet.tableInstance && sheet.tableInstance.pluginManager) {\n const filterPlugin = sheet.tableInstance.pluginManager.getPluginByName('Filter') as any;\n if (filterPlugin) {\n filterPlugin.setFilterState(sheetDefine.filterState);\n } else {\n console.warn(`Sheet ${sheetDefine.sheetKey} 未找到筛选插件或插件不支持 setFilterState 方法`);\n }\n } else {\n console.warn(`Sheet ${sheetDefine.sheetKey} 表格实例或插件管理器未初始化`);\n }\n }, 0);\n }\n\n /**\n * 添加新sheet\n */\n private _addNewSheet(): void {\n // 生成新sheet的key和title\n const sheetCount = this.sheetManager.getSheetCount();\n const baseKey = `sheet${sheetCount + 1}`;\n const baseTitle = `Sheet ${sheetCount + 1}`;\n let key = baseKey;\n let title = baseTitle;\n let index = sheetCount + 1;\n // 检查key和title是否被占用,递增直到唯一\n const existingKeys = new Set(this.sheetManager.getAllSheets().map(s => s.sheetKey));\n const existingTitles = new Set(this.sheetManager.getAllSheets().map(s => s.sheetTitle));\n while (existingKeys.has(key) || existingTitles.has(title)) {\n index += 1;\n key = `sheet${index}`;\n title = `Sheet ${index}`;\n }\n\n // 创建新sheet配置\n const newSheet: ISheetDefine = {\n sheetKey: key,\n sheetTitle: title,\n columnCount: 20,\n rowCount: 100,\n data: []\n };\n\n // 添加到管理器\n this.sheetManager.addSheet(newSheet);\n\n // 激活新sheet\n this.activateSheet(key);\n }\n\n /**\n * 更新公式栏\n */\n private updateFormulaBar(): void {\n this.formulaUIManager.updateFormulaBar();\n }\n\n /**\n * 获取公式管理器\n */\n getFormulaManager(): FormulaManager {\n return this.formulaManager;\n }\n /**\n * 获取Sheet管理器\n */\n getSheetManager(): SheetManager {\n return this.sheetManager;\n }\n\n /**\n * 获取活动Sheet实例\n */\n getActiveSheet(): WorkSheet | null {\n return this.activeWorkSheet;\n }\n\n /**\n * 根据名称获取Sheet实例\n */\n getSheetByName(sheetName: string): WorkSheet | null {\n // 遍历所有sheet实例,找到匹配的sheet\n for (const [sheetKey, workSheet] of this.workSheetInstances) {\n const sheetDefine = this.sheetManager.getSheet(sheetKey);\n if (sheetDefine && sheetDefine.sheetTitle === sheetName) {\n return workSheet;\n }\n }\n return null;\n }\n\n /**\n * 保存所有数据为配置\n */\n saveToConfig(): IVTableSheetOptions {\n // 收集所有sheet的数据\n const sheets: ISheetDefine[] = [];\n\n this.sheetManager.getAllSheets().forEach(sheetDefine => {\n const instance = this.workSheetInstances.get(sheetDefine.sheetKey);\n if (instance) {\n const data = instance.getCopiedData();\n //#region 组织columns\n //column中去除field字段 (field字段会在columns.map中被使用)\n const columns = instance.getColumns().map(column => {\n // 解构时省略field属性\n const { ...rest } = column;\n // 删除field属性\n delete rest.field;\n return rest;\n });\n // 找到最后一个有title的列的索引\n const lastTitleIndex = columns.reduce((lastIndex, column, index) => (column.title ? index : lastIndex), -1);\n\n // 从最后一个有title的列之后删除所有列\n if (lastTitleIndex === -1) {\n columns.length = 0; // 清空数组\n } else {\n columns.splice(lastTitleIndex + 1);\n }\n //#endregion\n\n //#region 组织data\n // 找到最后一个有非空值的行\n const lastDataIndex = data.reduce((lastIndex, rowData, index) => (rowData ? index : lastIndex), -1);\n // 保留到最后一个有值的行,删除之后的空行\n if (lastDataIndex === -1) {\n data.length = 0; // 清空数组\n } else {\n data.splice(lastDataIndex + 1);\n }\n //#endregion\n // 获取筛选状态\n let filterState = null;\n const filterPlugin = instance.tableInstance.pluginManager.getPluginByName('Filter') as any;\n if (filterPlugin) {\n filterState = filterPlugin.getFilterState();\n }\n\n // 获取排序状态\n let sortState = instance.tableInstance.internalProps.sortState;\n let currentSortState;\n if (sortState) {\n sortState = Array.isArray(sortState) ? sortState : [sortState];\n currentSortState = sortState.map(item => ({\n field: item.field,\n order: item.order,\n ...(item.orderFn != null && { orderFn: item.orderFn })\n }));\n }\n\n // 使用FormulaManager的导出方法获取所有公式\n const formulas = this.formulaManager.exportFormulas(sheetDefine.sheetKey);\n\n //#region 从tableInstance.internalProps._widthResizedColMap对应到columns的key 组织columnWidthConfig\n const columnWidthConfig = Array.from(instance.tableInstance.internalProps._widthResizedColMap).map(key => {\n return {\n key: key,\n width: instance.tableInstance.getColWidth(key as number)\n };\n });\n //#endregion\n //#region 从tableInstance.internalProps._heightResizedRowMap对应到columns的key 组织rowHeightConfig\n const rowHeightConfig = Array.from(instance.tableInstance.internalProps._heightResizedRowMap).map(key => {\n return {\n key: key,\n height: instance.tableInstance.getRowHeight(key)\n };\n });\n //#endregion\n\n sheets.push({\n ...sheetDefine,\n data,\n columns,\n cellMerge: instance.tableInstance.options.customMergeCell as TYPES.CustomMergeCellArray,\n showHeader: instance.tableInstance.options.showHeader,\n frozenRowCount: instance.tableInstance.frozenRowCount,\n frozenColCount: instance.tableInstance.frozenColCount,\n active: sheetDefine.sheetKey === this.sheetManager.getActiveSheet().sheetKey,\n filterState: filterState,\n sortState: currentSortState,\n formulas: Object.keys(formulas).length > 0 ? formulas : undefined,\n columnWidthConfig,\n rowHeightConfig\n });\n } else {\n sheets.push(sheetDefine);\n }\n });\n\n return {\n ...this.options,\n sheets\n };\n }\n\n /** 导出当前sheet到文件 */\n exportSheetToFile(fileType: 'csv' | 'xlsx', allSheets: boolean = true): void {\n const sheet = this.getActiveSheet();\n if (!sheet) {\n return;\n }\n if (fileType === 'csv') {\n if ((sheet.tableInstance as any)?.exportToCsv) {\n (sheet.tableInstance as any).exportToCsv();\n } else {\n console.warn('Please configure TableExportPlugin in VTablePluginModules');\n }\n } else {\n if (allSheets) {\n this.exportAllSheetsToExcel();\n } else {\n if ((sheet.tableInstance as any)?.exportToExcel) {\n (sheet.tableInstance as any).exportToExcel();\n } else {\n console.warn('Please configure TableExportPlugin in VTablePluginModules');\n }\n }\n }\n }\n exportAllSheetsToExcel(): void {\n this.initAllSheetInstances();\n const allDefines = this.sheetManager.getAllSheets();\n const tables = allDefines.map(def => {\n const inst = this.workSheetInstances.get(def.sheetKey)!;\n return { table: inst.tableInstance as any, name: def.sheetTitle || def.sheetKey };\n });\n (this as any)._exportMutipleTablesToExcel?.(tables); //这个方法是在vtable-plugins中添加的,table-export插件在VTableSheet实例上添加了导出所有sheet到Excel的方法\n }\n initAllSheetInstances(): void {\n const allDefines = this.sheetManager.getAllSheets();\n allDefines.forEach(def => {\n if (!this.workSheetInstances.has(def.sheetKey)) {\n const instance = this.createWorkSheetInstance(def);\n this.workSheetInstances.set(def.sheetKey, instance);\n }\n });\n }\n /**\n * 导入文件(支持 Excel 多 sheet 和 CSV)\n * @param options 导入选项,包括 clearExisting(是否清除现有 sheets,默认 true 表示替换模式)\n * @returns Promise<MultiSheetImportResult | void>\n */\n async importFileToSheet(\n options: { clearExisting?: boolean } = { clearExisting: true }\n ): Promise<MultiSheetImportResult | void> {\n // 使用绑定到 VTableSheet 实例的导入方法(插件内部会处理文件选择)\n if ((this as any)?._importFile) {\n return await (this as any)._importFile({\n clearExisting: options?.clearExisting !== false\n });\n }\n\n // 回退到 tableInstance 的 importFile 方法\n const sheet = this.getActiveSheet();\n if (!sheet) {\n return;\n }\n if ((sheet.tableInstance as any)?.importFile) {\n return await (sheet.tableInstance as any).importFile({\n clearExisting: options?.clearExisting !== false\n });\n }\n console.warn('Please configure ExcelImportPlugin in VTablePluginModules');\n }\n /**\n * 获取容器元素\n */\n getContainer(): HTMLElement {\n return this.container;\n }\n\n /**\n * 获取根元素\n */\n getRootElement(): HTMLElement {\n return this.rootElement;\n }\n\n /**\n * 获取选项\n */\n getOptions(): IVTableSheetOptions {\n return this.options;\n }\n\n /**\n * 获取公式栏元素\n */\n getFormulaBarElement(): HTMLElement | null {\n return this.formulaBarElement;\n }\n\n /**\n * 获取sheet标签栏元素\n */\n getSheetTabElement(): HTMLElement | null {\n return this.sheetTabElement;\n }\n\n /**\n * 获取内容区域元素\n */\n getContentElement(): HTMLElement {\n return this.contentElement;\n }\n\n /**\n * 销毁实例\n */\n release(): void {\n // 释放事件管理器\n this.eventManager.release();\n this.formulaManager.release();\n this.formulaUIManager.release();\n // 移除点击外部监听器\n this.sheetTabEventHandler.removeClickOutsideListener();\n // 销毁所有sheet实例\n this.workSheetInstances.forEach(instance => {\n instance.release();\n });\n // 清空容器\n if (this.rootElement && this.rootElement.parentNode) {\n this.rootElement.parentNode.removeChild(this.rootElement);\n }\n\n if (this.formulaAutocomplete) {\n this.formulaAutocomplete.release();\n }\n if (this.formulaManager.cellHighlightManager) {\n this.formulaManager.cellHighlightManager.release();\n }\n }\n\n /**\n * 导出指定sheet的数据\n * @param sheetKey sheet的key\n * @returns 数据\n */\n exportData(sheetKey: string): any[][] {\n const sheet = this.workSheetInstances.get(sheetKey);\n if (!sheet) {\n return [];\n }\n return sheet.getData();\n }\n\n /**\n * 导出所有sheet的数据\n * @returns 数据\n */\n exportAllData(): any[][] {\n const sheets = Array.from(this.workSheetInstances.values());\n return sheets.map(sheet => sheet.getData());\n }\n\n /**\n * resize\n */\n resize(): void {\n // const containerWidth = this.getContainer().clientWidth;\n // const containerHeight = this.getContainer().clientHeight;\n // this.rootElement.style.width = `${this.getOptions().width || containerWidth}px`;\n // this.rootElement.style.height = `${this.getOptions().height || containerHeight}px`;\n this.getActiveSheet()?.resize();\n }\n\n /**\n * 若所选范围包含当前正在编辑的单元格,自动排除该单元格以避免 #CYCLE!\n */\n excludeEditCellFromSelection(\n range: { startRow: number; startCol: number; endRow: number; endCol: number },\n editRow: number,\n editCol: number\n ) {\n const r = { ...range };\n const withinRow = r.startRow <= editRow && editRow <= r.endRow;\n const withinCol = r.startCol <= editCol && editCol <= r.endCol;\n if (!withinRow || !withinCol) {\n return r;\n }\n\n const rowSpan = r.endRow - r.startRow;\n const colSpan = r.endCol - r.startCol;\n\n // 如果选择范围就是编辑单元格本身,返回空范围(表示无效选择)\n if (rowSpan === 0 && colSpan === 0 && r.startRow === editRow && r.startCol === editCol) {\n return { startRow: -1, startCol: -1, endRow: -1, endCol: -1 };\n }\n\n if (rowSpan >= colSpan) {\n // 优先在行方向上排除编辑单元格\n if (editRow === r.startRow && r.startRow < r.endRow) {\n r.startRow += 1;\n } else if (editRow === r.endRow && r.startRow < r.endRow) {\n r.endRow -= 1;\n } else if (r.startRow < r.endRow) {\n r.startRow += 1;\n } // 中间,默认从起点缩一格\n } else {\n // 优先在列方向上排除编辑单元格\n if (editCol === r.startCol && r.startCol < r.endCol) {\n r.startCol += 1;\n } else if (editCol === r.endCol && r.startCol < r.endCol) {\n r.endCol -= 1;\n } else if (r.startCol < r.endCol) {\n r.startCol += 1;\n }\n }\n return r;\n }\n}\n"]}
|
package/cjs/core/WorkSheet.js
CHANGED
|
@@ -45,7 +45,7 @@ class WorkSheet extends event_target_1.EventTarget {
|
|
|
45
45
|
_initializeTable() {
|
|
46
46
|
const tableOptions = this._generateTableOptions();
|
|
47
47
|
this.tableInstance = new vtable_1.ListTable(tableOptions), this.element.classList.add("vtable-excel-cursor"),
|
|
48
|
-
this.eventBus = this.tableInstance.eventBus;
|
|
48
|
+
this.eventBus = this.tableInstance.eventBus, this.tableInstance.__vtableSheet = this.vtableSheet;
|
|
49
49
|
}
|
|
50
50
|
_generateTableOptions() {
|
|
51
51
|
var _a;
|