@visactor/vtable 1.19.9-alpha.3 → 1.20.0-alpha.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.
Files changed (212) hide show
  1. package/cjs/ListTable.d.ts +8 -2
  2. package/cjs/ListTable.js +58 -11
  3. package/cjs/ListTable.js.map +1 -1
  4. package/cjs/PivotChart.d.ts +4 -1
  5. package/cjs/PivotChart.js +8 -3
  6. package/cjs/PivotChart.js.map +1 -1
  7. package/cjs/PivotTable.d.ts +4 -1
  8. package/cjs/PivotTable.js +8 -3
  9. package/cjs/PivotTable.js.map +1 -1
  10. package/cjs/core/BaseTable.d.ts +14 -1
  11. package/cjs/core/BaseTable.js +121 -28
  12. package/cjs/core/BaseTable.js.map +1 -1
  13. package/cjs/core/TABLE_EVENT_TYPE.d.ts +4 -0
  14. package/cjs/core/TABLE_EVENT_TYPE.js +5 -1
  15. package/cjs/core/TABLE_EVENT_TYPE.js.map +1 -1
  16. package/cjs/core/animation.js.map +1 -1
  17. package/cjs/core/group-helper.d.ts +3 -1
  18. package/cjs/core/group-helper.js +8 -4
  19. package/cjs/core/group-helper.js.map +1 -1
  20. package/cjs/core/utils/get-cell-position.js +2 -2
  21. package/cjs/core/utils/get-cell-position.js.map +1 -1
  22. package/cjs/data/DataSource.d.ts +1 -0
  23. package/cjs/data/DataSource.js +21 -12
  24. package/cjs/data/DataSource.js.map +1 -1
  25. package/cjs/edit/edit-manager.js +5 -4
  26. package/cjs/edit/edit-manager.js.map +1 -1
  27. package/cjs/event/drill.js +2 -1
  28. package/cjs/event/event.d.ts +17 -0
  29. package/cjs/event/event.js +238 -4
  30. package/cjs/event/event.js.map +1 -1
  31. package/cjs/event/listener/container-dom.js +8 -153
  32. package/cjs/event/listener/container-dom.js.map +1 -1
  33. package/cjs/event/listener/scroll-bar.js +1 -1
  34. package/cjs/event/listener/scroll-bar.js.map +1 -1
  35. package/cjs/event/listener/table-group.js +27 -25
  36. package/cjs/event/listener/table-group.js.map +1 -1
  37. package/cjs/index.d.ts +1 -1
  38. package/cjs/index.js +1 -1
  39. package/cjs/index.js.map +1 -1
  40. package/cjs/layout/pivot-header-layout.js +1 -1
  41. package/cjs/layout/pivot-layout.js +2 -0
  42. package/cjs/layout/row-height-map.js +1 -1
  43. package/cjs/layout/simple-header-layout.js +1 -1
  44. package/cjs/layout/tree-helper.js +1 -1
  45. package/cjs/plugins/custom-cell-style.js +1 -2
  46. package/cjs/plugins/index.js +1 -1
  47. package/cjs/plugins/interface.js +1 -1
  48. package/cjs/plugins/invert-highlight.js +1 -1
  49. package/cjs/plugins/list-tree-stick-cell.js +1 -1
  50. package/cjs/plugins/plugin-manager.js +1 -1
  51. package/cjs/scenegraph/graphic/contributions/chart-render-helper.js +1 -4
  52. package/cjs/scenegraph/graphic/contributions/chart-render-helper.js.map +1 -1
  53. package/cjs/scenegraph/graphic/contributions/chart-render.js +1 -4
  54. package/cjs/scenegraph/graphic/contributions/chart-render.js.map +1 -1
  55. package/cjs/scenegraph/graphic/contributions/vchart-graphic-picker.js +1 -7
  56. package/cjs/scenegraph/graphic/contributions/vchart-graphic-picker.js.map +1 -1
  57. package/cjs/scenegraph/group-creater/cell-helper.js +2 -1
  58. package/cjs/scenegraph/group-creater/cell-helper.js.map +1 -1
  59. package/cjs/scenegraph/group-creater/progress/proxy.js.map +1 -1
  60. package/cjs/scenegraph/layout/compute-col-width.js +3 -1
  61. package/cjs/scenegraph/layout/compute-col-width.js.map +1 -1
  62. package/cjs/scenegraph/layout/frozen.js +7 -4
  63. package/cjs/scenegraph/layout/frozen.js.map +1 -1
  64. package/cjs/scenegraph/scenegraph.d.ts +6 -2
  65. package/cjs/scenegraph/scenegraph.js +31 -7
  66. package/cjs/scenegraph/scenegraph.js.map +1 -1
  67. package/cjs/scenegraph/select/create-select-border.d.ts +2 -0
  68. package/cjs/scenegraph/select/create-select-border.js +2 -2
  69. package/cjs/scenegraph/select/create-select-border.js.map +1 -1
  70. package/cjs/scenegraph/select/update-custom-select-border.d.ts +6 -0
  71. package/cjs/scenegraph/select/update-custom-select-border.js +69 -0
  72. package/cjs/scenegraph/select/update-custom-select-border.js.map +1 -0
  73. package/cjs/scenegraph/select/update-select-border.js +4 -12
  74. package/cjs/scenegraph/select/update-select-border.js.map +1 -1
  75. package/cjs/scenegraph/utils/cell-pos.d.ts +12 -0
  76. package/cjs/scenegraph/utils/cell-pos.js +26 -1
  77. package/cjs/scenegraph/utils/cell-pos.js.map +1 -1
  78. package/cjs/scenegraph/utils/update-container.d.ts +1 -0
  79. package/cjs/scenegraph/utils/update-container.js +8 -1
  80. package/cjs/scenegraph/utils/update-container.js.map +1 -1
  81. package/cjs/state/select/custom-select.d.ts +2 -2
  82. package/cjs/state/select/custom-select.js +2 -14
  83. package/cjs/state/select/custom-select.js.map +1 -1
  84. package/cjs/state/select/update-position.js +1 -1
  85. package/cjs/state/select/update-position.js.map +1 -1
  86. package/cjs/state/state.d.ts +4 -7
  87. package/cjs/state/state.js +14 -2
  88. package/cjs/state/state.js.map +1 -1
  89. package/cjs/themes/theme-define.js +1 -1
  90. package/cjs/themes/theme-define.js.map +1 -1
  91. package/cjs/tools/style.d.ts +3 -1
  92. package/cjs/tools/style.js +23 -2
  93. package/cjs/tools/style.js.map +1 -1
  94. package/cjs/ts-types/base-table.d.ts +6 -0
  95. package/cjs/ts-types/base-table.js.map +1 -1
  96. package/cjs/ts-types/events.d.ts +21 -1
  97. package/cjs/ts-types/events.js.map +1 -1
  98. package/cjs/ts-types/new-data-set.d.ts +1 -0
  99. package/cjs/ts-types/new-data-set.js.map +1 -1
  100. package/cjs/ts-types/style-define.d.ts +6 -0
  101. package/cjs/ts-types/style-define.js.map +1 -1
  102. package/cjs/ts-types/table-engine.d.ts +3 -0
  103. package/cjs/ts-types/table-engine.js.map +1 -1
  104. package/cjs/vrender.js.map +1 -1
  105. package/dist/vtable.js +2402 -465
  106. package/dist/vtable.min.js +2 -2
  107. package/es/ListTable.d.ts +8 -2
  108. package/es/ListTable.js +59 -9
  109. package/es/ListTable.js.map +1 -1
  110. package/es/PivotChart.d.ts +4 -1
  111. package/es/PivotChart.js +8 -3
  112. package/es/PivotChart.js.map +1 -1
  113. package/es/PivotTable.d.ts +4 -1
  114. package/es/PivotTable.js +8 -3
  115. package/es/PivotTable.js.map +1 -1
  116. package/es/core/BaseTable.d.ts +14 -1
  117. package/es/core/BaseTable.js +116 -24
  118. package/es/core/BaseTable.js.map +1 -1
  119. package/es/core/TABLE_EVENT_TYPE.d.ts +4 -0
  120. package/es/core/TABLE_EVENT_TYPE.js +5 -1
  121. package/es/core/TABLE_EVENT_TYPE.js.map +1 -1
  122. package/es/core/animation.js +1 -1
  123. package/es/core/animation.js.map +1 -1
  124. package/es/core/group-helper.d.ts +3 -1
  125. package/es/core/group-helper.js +8 -4
  126. package/es/core/group-helper.js.map +1 -1
  127. package/es/core/utils/get-cell-position.js +2 -2
  128. package/es/core/utils/get-cell-position.js.map +1 -1
  129. package/es/data/DataSource.d.ts +1 -0
  130. package/es/data/DataSource.js +21 -12
  131. package/es/data/DataSource.js.map +1 -1
  132. package/es/edit/edit-manager.js +5 -4
  133. package/es/edit/edit-manager.js.map +1 -1
  134. package/es/event/drill.js +2 -1
  135. package/es/event/event.d.ts +17 -0
  136. package/es/event/event.js +240 -3
  137. package/es/event/event.js.map +1 -1
  138. package/es/event/listener/container-dom.js +9 -154
  139. package/es/event/listener/container-dom.js.map +1 -1
  140. package/es/event/listener/scroll-bar.js +1 -1
  141. package/es/event/listener/scroll-bar.js.map +1 -1
  142. package/es/event/listener/table-group.js +27 -25
  143. package/es/event/listener/table-group.js.map +1 -1
  144. package/es/index.d.ts +1 -1
  145. package/es/index.js +1 -1
  146. package/es/index.js.map +1 -1
  147. package/es/layout/pivot-header-layout.js +1 -1
  148. package/es/layout/pivot-layout.js +2 -0
  149. package/es/layout/row-height-map.js +1 -1
  150. package/es/layout/simple-header-layout.js +1 -1
  151. package/es/layout/tree-helper.js +1 -1
  152. package/es/plugins/custom-cell-style.js +1 -2
  153. package/es/plugins/index.js +1 -1
  154. package/es/plugins/interface.js +1 -1
  155. package/es/plugins/invert-highlight.js +1 -1
  156. package/es/plugins/list-tree-stick-cell.js +1 -1
  157. package/es/plugins/plugin-manager.js +1 -1
  158. package/es/scenegraph/graphic/contributions/chart-render-helper.js +1 -4
  159. package/es/scenegraph/graphic/contributions/chart-render-helper.js.map +1 -1
  160. package/es/scenegraph/graphic/contributions/chart-render.js +1 -4
  161. package/es/scenegraph/graphic/contributions/chart-render.js.map +1 -1
  162. package/es/scenegraph/graphic/contributions/vchart-graphic-picker.js +1 -7
  163. package/es/scenegraph/graphic/contributions/vchart-graphic-picker.js.map +1 -1
  164. package/es/scenegraph/group-creater/cell-helper.js +2 -1
  165. package/es/scenegraph/group-creater/cell-helper.js.map +1 -1
  166. package/es/scenegraph/group-creater/progress/proxy.js.map +1 -1
  167. package/es/scenegraph/layout/compute-col-width.js +3 -1
  168. package/es/scenegraph/layout/compute-col-width.js.map +1 -1
  169. package/es/scenegraph/layout/frozen.js +7 -4
  170. package/es/scenegraph/layout/frozen.js.map +1 -1
  171. package/es/scenegraph/scenegraph.d.ts +6 -2
  172. package/es/scenegraph/scenegraph.js +29 -8
  173. package/es/scenegraph/scenegraph.js.map +1 -1
  174. package/es/scenegraph/select/create-select-border.d.ts +2 -0
  175. package/es/scenegraph/select/create-select-border.js +1 -1
  176. package/es/scenegraph/select/create-select-border.js.map +1 -1
  177. package/es/scenegraph/select/update-custom-select-border.d.ts +6 -0
  178. package/es/scenegraph/select/update-custom-select-border.js +63 -0
  179. package/es/scenegraph/select/update-custom-select-border.js.map +1 -0
  180. package/es/scenegraph/select/update-select-border.js +4 -11
  181. package/es/scenegraph/select/update-select-border.js.map +1 -1
  182. package/es/scenegraph/utils/cell-pos.d.ts +12 -0
  183. package/es/scenegraph/utils/cell-pos.js +24 -0
  184. package/es/scenegraph/utils/cell-pos.js.map +1 -1
  185. package/es/scenegraph/utils/update-container.d.ts +1 -0
  186. package/es/scenegraph/utils/update-container.js +6 -0
  187. package/es/scenegraph/utils/update-container.js.map +1 -1
  188. package/es/state/select/custom-select.d.ts +2 -2
  189. package/es/state/select/custom-select.js +3 -15
  190. package/es/state/select/custom-select.js.map +1 -1
  191. package/es/state/select/update-position.js +1 -1
  192. package/es/state/select/update-position.js.map +1 -1
  193. package/es/state/state.d.ts +4 -7
  194. package/es/state/state.js +14 -2
  195. package/es/state/state.js.map +1 -1
  196. package/es/themes/theme-define.js +1 -1
  197. package/es/themes/theme-define.js.map +1 -1
  198. package/es/tools/style.d.ts +3 -1
  199. package/es/tools/style.js +20 -0
  200. package/es/tools/style.js.map +1 -1
  201. package/es/ts-types/base-table.d.ts +6 -0
  202. package/es/ts-types/base-table.js.map +1 -1
  203. package/es/ts-types/events.d.ts +21 -1
  204. package/es/ts-types/events.js.map +1 -1
  205. package/es/ts-types/new-data-set.d.ts +1 -0
  206. package/es/ts-types/new-data-set.js.map +1 -1
  207. package/es/ts-types/style-define.d.ts +6 -0
  208. package/es/ts-types/style-define.js.map +1 -1
  209. package/es/ts-types/table-engine.d.ts +3 -0
  210. package/es/ts-types/table-engine.js.map +1 -1
  211. package/es/vrender.js.map +1 -1
  212. package/package.json +8 -8
@@ -55,6 +55,8 @@ export declare abstract class BaseTable extends EventTarget implements BaseTable
55
55
  customRender?: ICustomRender;
56
56
  canvasWidth?: number;
57
57
  canvasHeight?: number;
58
+ contentOffsetX?: number;
59
+ contentOffsetY?: number;
58
60
  _vDataSet?: DataSet;
59
61
  scenegraph: Scenegraph;
60
62
  stateManager: StateManager;
@@ -91,6 +93,7 @@ export declare abstract class BaseTable extends EventTarget implements BaseTable
91
93
  getElement(): HTMLElement;
92
94
  get canvas(): HTMLCanvasElement;
93
95
  setCanvasSize(canvasWidth: number, canvasHeight: number): void;
96
+ setContentInsetXY(contentOffsetX: number, contentOffsetY: number): void;
94
97
  resize(): void;
95
98
  get rowCount(): number;
96
99
  set rowCount(rowCount: number);
@@ -256,7 +259,10 @@ export declare abstract class BaseTable extends EventTarget implements BaseTable
256
259
  private dispose;
257
260
  release(): void;
258
261
  fireListeners<TYPE extends keyof TableEventHandlersEventArgumentMap>(type: TYPE, event: TableEventHandlersEventArgumentMap[TYPE]): TableEventHandlersReturnMap[TYPE][];
259
- updateOption(options: BaseTableConstructorOptions): void;
262
+ updateOption(options: BaseTableConstructorOptions, updateConfig?: {
263
+ clearColWidthCache?: boolean;
264
+ clearRowHeightCache?: boolean;
265
+ }): void;
260
266
  renderWithRecreateCells(): void;
261
267
  getFrozenRowsHeight(): number;
262
268
  getFrozenColsWidth(): number;
@@ -276,6 +282,13 @@ export declare abstract class BaseTable extends EventTarget implements BaseTable
276
282
  clearSelected(): void;
277
283
  selectCell(col: number, row: number, isShift?: boolean, isCtrl?: boolean, makeSelectCellVisible?: boolean, skipBodyMerge?: boolean): void;
278
284
  selectCells(cellRanges: CellRange[]): void;
285
+ selectRow(rowIndex: number, isCtrl?: boolean, isShift?: boolean): void;
286
+ selectCol(colIndex: number, isCtrl?: boolean, isShift?: boolean): void;
287
+ startDragSelectCol(colIndex: number, isCtrl?: boolean, isShift?: boolean): void;
288
+ dragSelectCol(colIndex: number, isCtrl?: boolean): void;
289
+ endDragSelect(): void;
290
+ startDragSelectRow(rowIndex: number, isCtrl?: boolean, isShift?: boolean): void;
291
+ dragSelectRow(rowIndex: number, isCtrl?: boolean): void;
279
292
  abstract isListTable(): boolean;
280
293
  abstract isPivotTable(): boolean;
281
294
  abstract isPivotChart(): boolean;
@@ -43,7 +43,7 @@ class BaseTable extends EventTarget_1.EventTarget {
43
43
  }
44
44
  constructor(container, options = {}) {
45
45
  var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z;
46
- if (super(), this.showFrozenIcon = !0, this.version = "1.19.9-alpha.3", this.id = `VTable${Date.now()}`,
46
+ if (super(), this.showFrozenIcon = !0, this.version = "1.20.0-alpha.0", this.id = `VTable${Date.now()}`,
47
47
  this.isReleased = !1, this._chartEventMap = {}, this.throttleInvalidate = (0, util_1.throttle2)(this.render.bind(this), 200),
48
48
  "node" === env_1.Env.mode ? (options = container, container = null) : container instanceof HTMLElement || (options = container,
49
49
  container = container.container ? container.container : null), !container && "node" !== options.mode && !options.canvas) throw new Error("vtable's container is undefined");
@@ -55,7 +55,7 @@ class BaseTable extends EventTarget_1.EventTarget {
55
55
  const {frozenColCount: frozenColCount = 0, unfreezeAllOnExceedsMaxWidth: unfreezeAllOnExceedsMaxWidth, frozenRowCount: frozenRowCount, defaultRowHeight: defaultRowHeight = 40, defaultHeaderRowHeight: defaultHeaderRowHeight, defaultColWidth: defaultColWidth = 80, defaultHeaderColWidth: defaultHeaderColWidth, widthMode: widthMode = "standard", heightMode: heightMode = "standard", autoFillWidth: autoFillWidth = !1, autoFillHeight: autoFillHeight = !1, containerFit: containerFit = {
56
56
  width: !1,
57
57
  height: !1
58
- }, widthAdaptiveMode: widthAdaptiveMode = "only-body", heightAdaptiveMode: heightAdaptiveMode = "only-body", keyboardOptions: keyboardOptions, eventOptions: eventOptions, rowSeriesNumber: rowSeriesNumber, enableCheckboxCascade: enableCheckboxCascade, enableHeaderCheckboxCascade: enableHeaderCheckboxCascade, columnResizeMode: columnResizeMode, rowResizeMode: rowResizeMode = "none", resize: resize, dragHeaderMode: dragHeaderMode, dragOrder: dragOrder, showFrozenIcon: showFrozenIcon, allowFrozenColCount: allowFrozenColCount, padding: padding, hover: hover, menu: menu, select: click, customRender: customRender, pixelRatio: pixelRatio = pixel_ratio_1.defaultPixelRatio, renderChartAsync: renderChartAsync, renderChartAsyncBatchCount: renderChartAsyncBatchCount, mode: mode, modeParams: modeParams, canvasWidth: canvasWidth, canvasHeight: canvasHeight, overscrollBehavior: overscrollBehavior, limitMinWidth: limitMinWidth, limitMinHeight: limitMinHeight, clearDOM: clearDOM = !0} = options, {groupConfig: groupConfig, groupBy: groupBy, groupTitleFieldFormat: groupTitleFieldFormat, groupTitleCustomLayout: groupTitleCustomLayout, enableTreeStickCell: enableTreeStickCell} = options;
58
+ }, widthAdaptiveMode: widthAdaptiveMode = "only-body", heightAdaptiveMode: heightAdaptiveMode = "only-body", keyboardOptions: keyboardOptions, eventOptions: eventOptions, rowSeriesNumber: rowSeriesNumber, enableCheckboxCascade: enableCheckboxCascade, enableHeaderCheckboxCascade: enableHeaderCheckboxCascade, columnResizeMode: columnResizeMode, rowResizeMode: rowResizeMode = "none", resize: resize, dragHeaderMode: dragHeaderMode, dragOrder: dragOrder, showFrozenIcon: showFrozenIcon, allowFrozenColCount: allowFrozenColCount, padding: padding, hover: hover, menu: menu, select: click, customRender: customRender, pixelRatio: pixelRatio = pixel_ratio_1.defaultPixelRatio, renderChartAsync: renderChartAsync, renderChartAsyncBatchCount: renderChartAsyncBatchCount, mode: mode, modeParams: modeParams, canvasWidth: canvasWidth, canvasHeight: canvasHeight, contentOffsetX: translateX, contentOffsetY: translateY, overscrollBehavior: overscrollBehavior, limitMinWidth: limitMinWidth, limitMinHeight: limitMinHeight, clearDOM: clearDOM = !0} = options, {groupConfig: groupConfig, groupBy: groupBy, groupTitleFieldFormat: groupTitleFieldFormat, groupTitleCustomLayout: groupTitleCustomLayout, enableTreeStickCell: enableTreeStickCell} = options;
59
59
  this.container = container, this.options = options, this._widthMode = widthMode,
60
60
  this._heightMode = heightMode, this._widthAdaptiveMode = widthAdaptiveMode, this._heightAdaptiveMode = heightAdaptiveMode,
61
61
  this._autoFillWidth = autoFillWidth, this._autoFillHeight = autoFillHeight, void 0 !== containerFit && (this._containerFit = "boolean" == typeof containerFit ? {
@@ -77,9 +77,10 @@ class BaseTable extends EventTarget_1.EventTarget {
77
77
  padding.bottom && (this.padding.bottom = padding.bottom), padding.left && (this.padding.left = padding.left),
78
78
  padding.right && (this.padding.right = padding.right))), ((0, vutils_1.isValid)(canvasHeight) || (0,
79
79
  vutils_1.isValid)(canvasWidth)) && (this.canvasSizeSeted = !0), this.tableNoFrameWidth = 0,
80
- this.tableNoFrameHeight = 0, this.canvasWidth = (0, vutils_1.isNumber)(canvasWidth) ? canvasWidth : void 0,
81
- this.canvasHeight = (0, vutils_1.isNumber)(canvasHeight) ? canvasHeight : void 0,
82
- this.columnWidthComputeMode = null !== (_d = options.columnWidthComputeMode) && void 0 !== _d ? _d : "normal";
80
+ this.tableNoFrameHeight = 0, this.contentOffsetX = null != translateX ? translateX : 0,
81
+ this.contentOffsetY = null != translateY ? translateY : 0, this.canvasWidth = (0,
82
+ vutils_1.isNumber)(canvasWidth) ? canvasWidth : void 0, this.canvasHeight = (0,
83
+ vutils_1.isNumber)(canvasHeight) ? canvasHeight : void 0, this.columnWidthComputeMode = null !== (_d = options.columnWidthComputeMode) && void 0 !== _d ? _d : "normal";
83
84
  const internalProps = this.internalProps = {};
84
85
  void 0 !== showFrozenIcon && (this.showFrozenIcon = showFrozenIcon), "number" == typeof allowFrozenColCount && allowFrozenColCount <= 0 && (this.showFrozenIcon = !1),
85
86
  this.options.canvas ? ("node" !== env_1.Env.mode && (internalProps.element = this.options.canvas.parentElement,
@@ -210,6 +211,10 @@ class BaseTable extends EventTarget_1.EventTarget {
210
211
  this.canvasWidth = canvasWidth, this.canvasHeight = canvasHeight, this.options.canvasHeight = canvasHeight,
211
212
  this.options.canvasWidth = canvasWidth, this.resize();
212
213
  }
214
+ setContentInsetXY(contentOffsetX, contentOffsetY) {
215
+ this.contentOffsetX = contentOffsetX, this.contentOffsetY = contentOffsetY, this.options.contentOffsetX = contentOffsetX,
216
+ this.options.contentOffsetY = contentOffsetY, this.resize();
217
+ }
213
218
  resize() {
214
219
  var _a;
215
220
  this._updateSize(), null === (_a = this.internalProps.legends) || void 0 === _a || _a.forEach((legend => {
@@ -265,7 +270,8 @@ class BaseTable extends EventTarget_1.EventTarget {
265
270
  return null !== (_e = null !== (_c = null === (_b = null === (_a = this.internalProps) || void 0 === _a ? void 0 : _a.layoutMap) || void 0 === _b ? void 0 : _b.frozenRowCount) && void 0 !== _c ? _c : null === (_d = this.internalProps) || void 0 === _d ? void 0 : _d.frozenRowCount) && void 0 !== _e ? _e : 0;
266
271
  }
267
272
  set frozenRowCount(frozenRowCount) {
268
- this.internalProps.frozenRowCount = frozenRowCount, this.stateManager.setFrozenRow(this.internalProps.frozenRowCount);
273
+ this.internalProps.frozenRowCount = frozenRowCount, this.options.frozenRowCount = frozenRowCount,
274
+ this.stateManager.setFrozenRow(this.internalProps.frozenRowCount);
269
275
  }
270
276
  get rightFrozenColCount() {
271
277
  var _a, _b, _c, _d, _e;
@@ -439,7 +445,7 @@ class BaseTable extends EventTarget_1.EventTarget {
439
445
  var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _0, _1, _2, _3, _4, _5;
440
446
  const {padding: padding} = this;
441
447
  let widthP = 0, heightP = 0;
442
- if (this.tableX = 0, this.tableY = 0, this.options.canvas && this.options.viewBox) widthP = this.options.viewBox.x2 - this.options.viewBox.x1,
448
+ if (this.tableX = this.contentOffsetX, this.tableY = this.contentOffsetY, this.options.canvas && this.options.viewBox) widthP = this.options.viewBox.x2 - this.options.viewBox.x1,
443
449
  heightP = this.options.viewBox.y2 - this.options.viewBox.y1, (null === (_a = null == this ? void 0 : this.scenegraph) || void 0 === _a ? void 0 : _a.stage) && (this.options.viewBox ? this.scenegraph.stage.setViewBox(this.options.viewBox, !1) : this.scenegraph.stage.resize(widthP, heightP)); else if ("browser" === env_1.Env.mode) {
444
450
  const element = this.getElement();
445
451
  let widthWithoutPadding = 0, heightWithoutPadding = 0;
@@ -470,15 +476,15 @@ class BaseTable extends EventTarget_1.EventTarget {
470
476
  const width = Math.floor(widthP - vScrollBarWidth), height = Math.floor(heightP - hScrollBarWidth);
471
477
  if (null === (_l = this.internalProps.theme) || void 0 === _l ? void 0 : _l.frameStyle) {
472
478
  const lineWidths = toBoxArray(null !== (_o = null === (_m = this.internalProps.theme.frameStyle) || void 0 === _m ? void 0 : _m.borderLineWidth) && void 0 !== _o ? _o : [ null ]), shadowWidths = toBoxArray(null !== (_q = null === (_p = this.internalProps.theme.frameStyle) || void 0 === _p ? void 0 : _p.shadowBlur) && void 0 !== _q ? _q : [ 0 ]);
473
- if (null === (_r = this.theme.frameStyle) || void 0 === _r ? void 0 : _r.innerBorder) this.tableX = 0,
474
- this.tableY = 0, this.tableNoFrameWidth = width - (null !== (_s = shadowWidths[1]) && void 0 !== _s ? _s : 0),
475
- this.tableNoFrameHeight = height - (null !== (_t = shadowWidths[2]) && void 0 !== _t ? _t : 0); else {
476
- this.tableX = (null !== (_u = lineWidths[3]) && void 0 !== _u ? _u : 0) + (null !== (_v = shadowWidths[3]) && void 0 !== _v ? _v : 0),
477
- this.tableY = (null !== (_w = lineWidths[0]) && void 0 !== _w ? _w : 0) + (null !== (_x = shadowWidths[0]) && void 0 !== _x ? _x : 0);
479
+ if (null === (_r = this.theme.frameStyle) || void 0 === _r ? void 0 : _r.innerBorder) this.tableX += this.contentOffsetX,
480
+ this.tableY += this.contentOffsetY, this.tableNoFrameWidth = width - (null !== (_s = shadowWidths[1]) && void 0 !== _s ? _s : 0) - this.contentOffsetX,
481
+ this.tableNoFrameHeight = height - (null !== (_t = shadowWidths[2]) && void 0 !== _t ? _t : 0) - this.contentOffsetY; else {
482
+ this.tableX += (null !== (_u = lineWidths[3]) && void 0 !== _u ? _u : 0) + (null !== (_v = shadowWidths[3]) && void 0 !== _v ? _v : 0),
483
+ this.tableY += (null !== (_w = lineWidths[0]) && void 0 !== _w ? _w : 0) + (null !== (_x = shadowWidths[0]) && void 0 !== _x ? _x : 0);
478
484
  const rightBorder = (null !== (_y = lineWidths[1]) && void 0 !== _y ? _y : 0) + (null !== (_z = shadowWidths[1]) && void 0 !== _z ? _z : 0);
479
- this.tableNoFrameWidth = width - (rightBorder > vScrollBarWidth ? rightBorder - vScrollBarWidth : 0) - ((null !== (_0 = lineWidths[3]) && void 0 !== _0 ? _0 : 0) + (null !== (_1 = shadowWidths[3]) && void 0 !== _1 ? _1 : 0));
485
+ this.tableNoFrameWidth = width - (rightBorder > vScrollBarWidth ? rightBorder - vScrollBarWidth : 0) - ((null !== (_0 = lineWidths[3]) && void 0 !== _0 ? _0 : 0) + (null !== (_1 = shadowWidths[3]) && void 0 !== _1 ? _1 : 0)) - this.contentOffsetX;
480
486
  const bottomBorder = (null !== (_2 = lineWidths[2]) && void 0 !== _2 ? _2 : 0) + (null !== (_3 = shadowWidths[2]) && void 0 !== _3 ? _3 : 0);
481
- this.tableNoFrameHeight = height - (bottomBorder > hScrollBarWidth ? bottomBorder - hScrollBarWidth : 0) - ((null !== (_4 = lineWidths[0]) && void 0 !== _4 ? _4 : 0) + (null !== (_5 = shadowWidths[0]) && void 0 !== _5 ? _5 : 0));
487
+ this.tableNoFrameHeight = height - (bottomBorder > hScrollBarWidth ? bottomBorder - hScrollBarWidth : 0) - ((null !== (_4 = lineWidths[0]) && void 0 !== _4 ? _4 : 0) + (null !== (_5 = shadowWidths[0]) && void 0 !== _5 ? _5 : 0)) - this.contentOffsetY;
482
488
  }
483
489
  }
484
490
  this._clearColRangeWidthsMap(), this._clearRowRangeHeightsMap();
@@ -920,7 +926,8 @@ class BaseTable extends EventTarget_1.EventTarget {
920
926
  if (this.isReleased) return;
921
927
  null === (_b = null === (_a = internalProps.tooltipHandler) || void 0 === _a ? void 0 : _a.release) || void 0 === _b || _b.call(_a),
922
928
  null === (_d = null === (_c = internalProps.menuHandler) || void 0 === _c ? void 0 : _c.release) || void 0 === _d || _d.call(_c),
923
- null === (_e = super.release) || void 0 === _e || _e.call(this), null === (_g = null === (_f = internalProps.handler) || void 0 === _f ? void 0 : _f.release) || void 0 === _g || _g.call(_f),
929
+ null === (_e = super.release) || void 0 === _e || _e.call(this), this.pluginManager.release(),
930
+ null === (_g = null === (_f = internalProps.handler) || void 0 === _f ? void 0 : _f.release) || void 0 === _g || _g.call(_f),
924
931
  this.eventManager.release(), null === (_j = null === (_h = internalProps.focusControl) || void 0 === _h ? void 0 : _h.release) || void 0 === _j || _j.call(_h),
925
932
  null === (_k = internalProps.legends) || void 0 === _k || _k.forEach((legend => {
926
933
  null == legend || legend.release();
@@ -935,16 +942,22 @@ class BaseTable extends EventTarget_1.EventTarget {
935
942
  parentElement && !this.options.canvas && parentElement.removeChild(internalProps.element),
936
943
  null === (_q = null === (_p = null === (_o = this.editorManager) || void 0 === _o ? void 0 : _o.editingEditor) || void 0 === _p ? void 0 : _p.onEnd) || void 0 === _q || _q.call(_p),
937
944
  this.isReleased = !0, this.scenegraph = null, this.internalProps = null, null === (_r = this.reactCustomLayout) || void 0 === _r || _r.clearCache(),
938
- this.pluginManager.release(), (0, chart_render_helper_1.clearChartRenderQueue)();
945
+ (0, chart_render_helper_1.clearChartRenderQueue)();
939
946
  }
940
947
  fireListeners(type, event) {
941
948
  return super.fireListeners(type, event);
942
949
  }
943
- updateOption(options) {
950
+ updateOption(options, updateConfig = {
951
+ clearColWidthCache: !0,
952
+ clearRowHeightCache: !0
953
+ }) {
944
954
  var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _0, _1;
945
- null === (_a = this.editorManager) || void 0 === _a || _a.cancelEdit(), this.options = options,
955
+ this.fireListeners(TABLE_EVENT_TYPE_1.TABLE_EVENT_TYPE.BEFORE_UPDATE_OPTION, {
956
+ options: options,
957
+ container: this.container
958
+ }), null === (_a = this.editorManager) || void 0 === _a || _a.cancelEdit(), this.options = options,
946
959
  this._hasAutoImageColumn = void 0;
947
- const {frozenColCount: frozenColCount = 0, unfreezeAllOnExceedsMaxWidth: unfreezeAllOnExceedsMaxWidth, defaultRowHeight: defaultRowHeight = 40, defaultHeaderRowHeight: defaultHeaderRowHeight, defaultColWidth: defaultColWidth = 80, defaultHeaderColWidth: defaultHeaderColWidth = 80, keyboardOptions: keyboardOptions, eventOptions: eventOptions, rowSeriesNumber: rowSeriesNumber, enableCheckboxCascade: enableCheckboxCascade, enableHeaderCheckboxCascade: enableHeaderCheckboxCascade, columnResizeMode: columnResizeMode, rowResizeMode: rowResizeMode = "none", resize: resize, dragHeaderMode: dragHeaderMode, dragOrder: dragOrder, showFrozenIcon: showFrozenIcon, allowFrozenColCount: allowFrozenColCount, padding: padding, hover: hover, menu: menu, select: click, pixelRatio: pixelRatio, widthMode: widthMode, heightMode: heightMode, autoFillWidth: autoFillWidth, autoFillHeight: autoFillHeight, containerFit: containerFit, widthAdaptiveMode: widthAdaptiveMode, heightAdaptiveMode: heightAdaptiveMode, customRender: customRender, renderChartAsync: renderChartAsync, renderChartAsyncBatchCount: renderChartAsyncBatchCount, canvasWidth: canvasWidth, canvasHeight: canvasHeight, overscrollBehavior: overscrollBehavior, limitMinWidth: limitMinWidth, limitMinHeight: limitMinHeight} = options, {groupConfig: groupConfig, groupBy: groupBy, groupTitleFieldFormat: groupTitleFieldFormat, groupTitleCustomLayout: groupTitleCustomLayout, enableTreeStickCell: enableTreeStickCell} = options;
960
+ const {frozenColCount: frozenColCount = 0, unfreezeAllOnExceedsMaxWidth: unfreezeAllOnExceedsMaxWidth, defaultRowHeight: defaultRowHeight = 40, defaultHeaderRowHeight: defaultHeaderRowHeight, defaultColWidth: defaultColWidth = 80, defaultHeaderColWidth: defaultHeaderColWidth = 80, keyboardOptions: keyboardOptions, eventOptions: eventOptions, rowSeriesNumber: rowSeriesNumber, enableCheckboxCascade: enableCheckboxCascade, enableHeaderCheckboxCascade: enableHeaderCheckboxCascade, columnResizeMode: columnResizeMode, rowResizeMode: rowResizeMode = "none", resize: resize, dragHeaderMode: dragHeaderMode, dragOrder: dragOrder, showFrozenIcon: showFrozenIcon, allowFrozenColCount: allowFrozenColCount, padding: padding, hover: hover, menu: menu, select: click, pixelRatio: pixelRatio, widthMode: widthMode, heightMode: heightMode, autoFillWidth: autoFillWidth, autoFillHeight: autoFillHeight, containerFit: containerFit, widthAdaptiveMode: widthAdaptiveMode, heightAdaptiveMode: heightAdaptiveMode, customRender: customRender, renderChartAsync: renderChartAsync, renderChartAsyncBatchCount: renderChartAsyncBatchCount, canvasWidth: canvasWidth, canvasHeight: canvasHeight, contentOffsetX: translateX = 0, contentOffsetY: translateY = 0, overscrollBehavior: overscrollBehavior, limitMinWidth: limitMinWidth, limitMinHeight: limitMinHeight} = options, {groupConfig: groupConfig, groupBy: groupBy, groupTitleFieldFormat: groupTitleFieldFormat, groupTitleCustomLayout: groupTitleCustomLayout, enableTreeStickCell: enableTreeStickCell} = options;
948
961
  pixelRatio && pixelRatio !== this.internalProps.pixelRatio && (this.internalProps.pixelRatio = pixelRatio),
949
962
  padding && ("number" == typeof padding ? (this.padding.top = padding, this.padding.left = padding,
950
963
  this.padding.bottom = padding, this.padding.right = padding) : (padding.top && (this.padding.top = padding.top),
@@ -964,8 +977,10 @@ class BaseTable extends EventTarget_1.EventTarget {
964
977
  } : {
965
978
  width: !1,
966
979
  height: !1
967
- }), this.customRender = customRender, this.canvasWidth = (0, vutils_1.isNumber)(canvasWidth) ? canvasWidth : void 0,
968
- this.canvasHeight = (0, vutils_1.isNumber)(canvasHeight) ? canvasHeight : void 0;
980
+ }), this.customRender = customRender, this.contentOffsetX = null != translateX ? translateX : 0,
981
+ this.contentOffsetY = null != translateY ? translateY : 0, this.canvasWidth = (0,
982
+ vutils_1.isNumber)(canvasWidth) ? canvasWidth : void 0, this.canvasHeight = (0,
983
+ vutils_1.isNumber)(canvasHeight) ? canvasHeight : void 0;
969
984
  const internalProps = this.internalProps;
970
985
  if ("node" === env_1.Env.mode || options.canvas || (0, tableHelper_1.updateRootElementPadding)(internalProps.element, this.padding),
971
986
  this.columnWidthComputeMode = null !== (_d = options.columnWidthComputeMode) && void 0 !== _d ? _d : "normal",
@@ -985,11 +1000,12 @@ class BaseTable extends EventTarget_1.EventTarget {
985
1000
  internalProps.groupTitleFieldFormat = null !== (_l = null == groupConfig ? void 0 : groupConfig.titleFieldFormat) && void 0 !== _l ? _l : groupTitleFieldFormat,
986
1001
  internalProps.groupTitleCustomLayout = null !== (_m = null == groupConfig ? void 0 : groupConfig.titleCustomLayout) && void 0 !== _m ? _m : groupTitleCustomLayout,
987
1002
  internalProps.enableTreeStickCell = null !== (_o = null == groupConfig ? void 0 : groupConfig.enableTreeStickCell) && void 0 !== _o ? _o : enableTreeStickCell,
1003
+ (null == updateConfig ? void 0 : updateConfig.clearColWidthCache) && (internalProps._widthResizedColMap.clear(),
1004
+ this.colWidthsMap = new NumberMap_1.NumberMap, this.colContentWidthsMap = new NumberMap_1.NumberMap,
1005
+ this.colWidthsLimit = {}), (null == updateConfig ? void 0 : updateConfig.clearRowHeightCache) && (internalProps._heightResizedRowMap.clear(),
988
1006
  internalProps._rowHeightsMap = new row_height_map_1.NumberRangeMap(this), internalProps._rowRangeHeightsMap = new Map,
989
- internalProps._colRangeWidthsMap = new Map, internalProps._widthResizedColMap = new Set,
990
- internalProps._heightResizedRowMap = new Set, this.colWidthsMap = new NumberMap_1.NumberMap,
991
- this.colContentWidthsMap = new NumberMap_1.NumberMap, this.colWidthsLimit = {},
992
- internalProps.stick.changedCells.clear(), internalProps.theme = themes_1.default.of(null !== (_p = options.theme) && void 0 !== _p ? _p : themes_1.default.DEFAULT),
1007
+ internalProps._colRangeWidthsMap = new Map), internalProps.stick.changedCells.clear(),
1008
+ internalProps.theme = themes_1.default.of(null !== (_p = options.theme) && void 0 !== _p ? _p : themes_1.default.DEFAULT),
993
1009
  internalProps.theme.isPivot = this.isPivotTable(), (0, icons_1.setIconColor)(internalProps.theme.functionalIconsStyle),
994
1010
  this.scenegraph.updateStageBackground(), internalProps.autoWrapText = options.autoWrapText,
995
1011
  internalProps.enableLineBreak = options.enableLineBreak, internalProps.allowFrozenColCount = null !== (_q = options.allowFrozenColCount) && void 0 !== _q ? _q : 0,
@@ -1034,7 +1050,8 @@ class BaseTable extends EventTarget_1.EventTarget {
1034
1050
  const MenuHandler = factory_1.Factory.getComponent("menuHandler");
1035
1051
  internalProps.menuHandler = new MenuHandler(this);
1036
1052
  }
1037
- this.clearCellStyleCache(), this.clearColWidthCache(), this.clearRowHeightCache(),
1053
+ this.clearCellStyleCache(), (null == updateConfig ? void 0 : updateConfig.clearColWidthCache) && this.clearColWidthCache(),
1054
+ (null == updateConfig ? void 0 : updateConfig.clearRowHeightCache) && this.clearRowHeightCache(),
1038
1055
  internalProps.customMergeCell = (0, get_custom_merge_cell_func_1.getCustomMergeCellFunc)(options.customMergeCell),
1039
1056
  null === (_z = this.customCellStylePlugin) || void 0 === _z || _z.updateCustomCell(null !== (_0 = options.customCellStyle) && void 0 !== _0 ? _0 : [], null !== (_1 = options.customCellStyleArrangement) && void 0 !== _1 ? _1 : []),
1040
1057
  this._adjustCanvasSizeByOption();
@@ -1138,11 +1155,87 @@ class BaseTable extends EventTarget_1.EventTarget {
1138
1155
  const {scrollLeft: scrollLeft, scrollTop: scrollTop} = this;
1139
1156
  cellRanges.forEach(((cellRange, index) => {
1140
1157
  var _a, _b, _c, _d, _e, _f;
1141
- cellRange.start.col === cellRange.end.col && cellRange.start.row === cellRange.end.row ? this.stateManager.updateSelectPos(cellRange.start.col, cellRange.start.row, !1, index >= 1, !1, null === (_b = null === (_a = this.options.select) || void 0 === _a ? void 0 : _a.makeSelectCellVisible) || void 0 === _b || _b, !0) : (this.stateManager.updateSelectPos(cellRange.start.col, cellRange.start.row, !1, index >= 1, !1, null === (_d = null === (_c = this.options.select) || void 0 === _c ? void 0 : _c.makeSelectCellVisible) || void 0 === _d || _d, !0),
1142
- this.stateManager.updateInteractionState(ts_types_1.InteractionState.grabing), this.stateManager.updateSelectPos(cellRange.end.col, cellRange.end.row, !1, index >= 1, !1, null === (_f = null === (_e = this.options.select) || void 0 === _e ? void 0 : _e.makeSelectCellVisible) || void 0 === _f || _f, !0)),
1158
+ const startRow = cellRange.start.row, startCol = cellRange.start.col, endRow = cellRange.end.row, endCol = cellRange.end.col;
1159
+ startCol === endCol && startRow === endRow ? this.stateManager.updateSelectPos(startCol, startRow, !1, index >= 1, !1, null === (_b = null === (_a = this.options.select) || void 0 === _a ? void 0 : _a.makeSelectCellVisible) || void 0 === _b || _b, !0) : (this.stateManager.updateSelectPos(startCol, startRow, !1, index >= 1, !1, null === (_d = null === (_c = this.options.select) || void 0 === _c ? void 0 : _c.makeSelectCellVisible) || void 0 === _d || _d, !0),
1160
+ this.stateManager.updateInteractionState(ts_types_1.InteractionState.grabing), this.stateManager.updateSelectPos(endCol, endRow, !1, index >= 1, !1, null === (_f = null === (_e = this.options.select) || void 0 === _e ? void 0 : _e.makeSelectCellVisible) || void 0 === _f || _f, !0)),
1143
1161
  this.stateManager.endSelectCells(!1, !1), this.stateManager.updateInteractionState(ts_types_1.InteractionState.default);
1144
1162
  })), this.setScrollTop(scrollTop), this.setScrollLeft(scrollLeft);
1145
1163
  }
1164
+ selectRow(rowIndex, isCtrl, isShift) {
1165
+ const currentSelectRanges = this.stateManager.select.ranges;
1166
+ if (isCtrl) currentSelectRanges.push({
1167
+ start: {
1168
+ col: 0,
1169
+ row: rowIndex
1170
+ },
1171
+ end: {
1172
+ col: this.colCount - 1,
1173
+ row: rowIndex
1174
+ }
1175
+ }), this.selectCells(currentSelectRanges); else if (isShift) {
1176
+ const lastSelectRange = currentSelectRanges[currentSelectRanges.length - 1];
1177
+ lastSelectRange && (lastSelectRange.end.row = rowIndex), this.selectCells(currentSelectRanges);
1178
+ } else this.selectCells([ {
1179
+ start: {
1180
+ col: 0,
1181
+ row: rowIndex
1182
+ },
1183
+ end: {
1184
+ col: this.colCount - 1,
1185
+ row: rowIndex
1186
+ }
1187
+ } ]);
1188
+ }
1189
+ selectCol(colIndex, isCtrl, isShift) {
1190
+ const currentSelectRanges = this.stateManager.select.ranges;
1191
+ if (isCtrl) currentSelectRanges.push({
1192
+ start: {
1193
+ col: colIndex,
1194
+ row: 0
1195
+ },
1196
+ end: {
1197
+ col: colIndex,
1198
+ row: this.rowCount - 1
1199
+ }
1200
+ }), this.selectCells(currentSelectRanges); else if (isShift) {
1201
+ const lastSelectRange = currentSelectRanges[currentSelectRanges.length - 1];
1202
+ lastSelectRange && (lastSelectRange.end.col = colIndex), this.selectCells(currentSelectRanges);
1203
+ } else this.selectCells([ {
1204
+ start: {
1205
+ col: colIndex,
1206
+ row: 0
1207
+ },
1208
+ end: {
1209
+ col: colIndex,
1210
+ row: this.rowCount - 1
1211
+ }
1212
+ } ]);
1213
+ }
1214
+ startDragSelectCol(colIndex, isCtrl, isShift) {
1215
+ var _a, _b, _c, _d, _e, _f;
1216
+ const lastSelectRange = this.stateManager.select.ranges[this.stateManager.select.ranges.length - 1], startCol = isShift && (null === (_a = null == lastSelectRange ? void 0 : lastSelectRange.start) || void 0 === _a ? void 0 : _a.col) ? null === (_b = null == lastSelectRange ? void 0 : lastSelectRange.start) || void 0 === _b ? void 0 : _b.col : colIndex, endCol = colIndex, endRow = this.rowCount - 1;
1217
+ this.stateManager.updateSelectPos(startCol, 0, isShift, isCtrl, !1, null === (_d = null === (_c = this.options.select) || void 0 === _c ? void 0 : _c.makeSelectCellVisible) || void 0 === _d || _d, !0),
1218
+ this.stateManager.updateInteractionState(ts_types_1.InteractionState.grabing), this.stateManager.updateSelectPos(endCol, endRow, isShift, isCtrl, !1, null === (_f = null === (_e = this.options.select) || void 0 === _e ? void 0 : _e.makeSelectCellVisible) || void 0 === _f || _f, !0);
1219
+ }
1220
+ dragSelectCol(colIndex, isCtrl) {
1221
+ var _a, _b;
1222
+ const currentSelectRanges = this.stateManager.select.ranges, lastSelectRange = currentSelectRanges[currentSelectRanges.length - 1];
1223
+ lastSelectRange && (lastSelectRange.end.col = colIndex), this.stateManager.updateSelectPos(colIndex, this.rowCount - 1, !1, isCtrl, !1, null === (_b = null === (_a = this.options.select) || void 0 === _a ? void 0 : _a.makeSelectCellVisible) || void 0 === _b || _b, !0);
1224
+ }
1225
+ endDragSelect() {
1226
+ this.stateManager.updateInteractionState(ts_types_1.InteractionState.default), this.stateManager.endSelectCells(!1, !1);
1227
+ }
1228
+ startDragSelectRow(rowIndex, isCtrl, isShift) {
1229
+ var _a, _b, _c, _d, _e, _f;
1230
+ const lastSelectRange = this.stateManager.select.ranges[this.stateManager.select.ranges.length - 1], startRow = isShift && (null === (_a = null == lastSelectRange ? void 0 : lastSelectRange.start) || void 0 === _a ? void 0 : _a.row) ? null === (_b = null == lastSelectRange ? void 0 : lastSelectRange.start) || void 0 === _b ? void 0 : _b.row : rowIndex, endCol = this.colCount - 1, endRow = rowIndex;
1231
+ this.stateManager.updateSelectPos(0, startRow, isShift, isCtrl, !1, null === (_d = null === (_c = this.options.select) || void 0 === _c ? void 0 : _c.makeSelectCellVisible) || void 0 === _d || _d, !0),
1232
+ this.stateManager.updateInteractionState(ts_types_1.InteractionState.grabing), this.stateManager.updateSelectPos(endCol, endRow, isShift, isCtrl, !1, null === (_f = null === (_e = this.options.select) || void 0 === _e ? void 0 : _e.makeSelectCellVisible) || void 0 === _f || _f, !0);
1233
+ }
1234
+ dragSelectRow(rowIndex, isCtrl) {
1235
+ var _a, _b;
1236
+ const currentSelectRanges = this.stateManager.select.ranges, lastSelectRange = currentSelectRanges[currentSelectRanges.length - 1];
1237
+ lastSelectRange && (lastSelectRange.end.row = rowIndex), this.stateManager.updateSelectPos(this.colCount - 1, rowIndex, !1, isCtrl, !1, null === (_b = null === (_a = this.options.select) || void 0 === _a ? void 0 : _a.makeSelectCellVisible) || void 0 === _b || _b, !0);
1238
+ }
1146
1239
  get recordsCount() {
1147
1240
  var _a;
1148
1241
  return null === (_a = this.records) || void 0 === _a ? void 0 : _a.length;