@visactor/vtable 0.9.2-alpha.0 → 0.9.2-alpha.2

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 (533) hide show
  1. package/cjs/ListTable.d.ts +2 -1
  2. package/cjs/ListTable.js +17 -13
  3. package/cjs/ListTable.js.map +1 -1
  4. package/cjs/PivotChart.d.ts +68 -0
  5. package/cjs/PivotChart.js +427 -0
  6. package/cjs/PivotChart.js.map +1 -0
  7. package/cjs/PivotTable.d.ts +2 -1
  8. package/cjs/PivotTable.js +18 -13
  9. package/cjs/PivotTable.js.map +1 -1
  10. package/cjs/body-helper/style/MultilineTextStyle.js +2 -2
  11. package/cjs/body-helper/style/MultilineTextStyle.js.map +1 -1
  12. package/cjs/body-helper/style/ProgressBarStyle.js +15 -15
  13. package/cjs/body-helper/style/ProgressBarStyle.js.map +1 -1
  14. package/cjs/body-helper/style/Style.d.ts +0 -1
  15. package/cjs/body-helper/style/Style.js +25 -28
  16. package/cjs/body-helper/style/Style.js.map +1 -1
  17. package/cjs/components/axis/axis.d.ts +45 -0
  18. package/cjs/components/axis/axis.js +146 -0
  19. package/cjs/components/axis/axis.js.map +1 -0
  20. package/cjs/components/axis/band-scale.d.ts +18 -0
  21. package/cjs/components/axis/band-scale.js +54 -0
  22. package/cjs/components/axis/band-scale.js.map +1 -0
  23. package/cjs/components/axis/get-axis-attributes.d.ts +136 -0
  24. package/cjs/components/axis/get-axis-attributes.js +169 -0
  25. package/cjs/components/axis/get-axis-attributes.js.map +1 -0
  26. package/cjs/components/axis/label-overlap.d.ts +3 -0
  27. package/cjs/components/axis/label-overlap.js +46 -0
  28. package/cjs/components/axis/label-overlap.js.map +1 -0
  29. package/cjs/components/axis/linear-scale.d.ts +45 -0
  30. package/cjs/components/axis/linear-scale.js +120 -0
  31. package/cjs/components/axis/linear-scale.js.map +1 -0
  32. package/cjs/components/legend/get-legend-attributes.d.ts +5 -0
  33. package/cjs/components/legend/get-legend-attributes.js +90 -0
  34. package/cjs/components/legend/get-legend-attributes.js.map +1 -0
  35. package/cjs/components/legend/legend.d.ts +23 -0
  36. package/cjs/components/legend/legend.js +94 -0
  37. package/cjs/components/legend/legend.js.map +1 -0
  38. package/cjs/{menu → components/menu}/dom/BaseMenu.d.ts +2 -2
  39. package/cjs/components/menu/dom/BaseMenu.js.map +1 -0
  40. package/cjs/components/menu/dom/Menu.js.map +1 -0
  41. package/{es → cjs/components}/menu/dom/MenuHandler.d.ts +2 -2
  42. package/cjs/{menu → components/menu}/dom/MenuHandler.js +1 -1
  43. package/cjs/components/menu/dom/MenuHandler.js.map +1 -0
  44. package/cjs/{menu → components/menu}/dom/logic/MenuContainer.d.ts +2 -2
  45. package/cjs/{menu → components/menu}/dom/logic/MenuContainer.js +2 -2
  46. package/cjs/components/menu/dom/logic/MenuContainer.js.map +1 -0
  47. package/cjs/{menu → components/menu}/dom/logic/MenuElement.d.ts +2 -2
  48. package/cjs/{menu → components/menu}/dom/logic/MenuElement.js +4 -4
  49. package/cjs/components/menu/dom/logic/MenuElement.js.map +1 -0
  50. package/cjs/components/menu/dom/logic/MenuElementStyle.js.map +1 -0
  51. package/cjs/components/title/title.d.ts +12 -0
  52. package/cjs/components/title/title.js +66 -0
  53. package/cjs/components/title/title.js.map +1 -0
  54. package/cjs/{tooltip → components/tooltip}/BaseTooltip.d.ts +3 -3
  55. package/cjs/components/tooltip/BaseTooltip.js.map +1 -0
  56. package/cjs/components/tooltip/Tooltip.js.map +1 -0
  57. package/{es → cjs/components}/tooltip/TooltipHandler.d.ts +4 -4
  58. package/cjs/{tooltip → components/tooltip}/TooltipHandler.js +1 -1
  59. package/cjs/components/tooltip/TooltipHandler.js.map +1 -0
  60. package/cjs/{tooltip → components/tooltip}/logic/BubbleTooltipElement.d.ts +4 -4
  61. package/cjs/{tooltip → components/tooltip}/logic/BubbleTooltipElement.js +1 -1
  62. package/cjs/components/tooltip/logic/BubbleTooltipElement.js.map +1 -0
  63. package/cjs/components/tooltip/logic/BubbleTooltipElementStyle.js.map +1 -0
  64. package/cjs/components/util/orient.d.ts +3 -0
  65. package/cjs/components/util/orient.js +14 -0
  66. package/cjs/components/util/orient.js.map +1 -0
  67. package/cjs/components/util/register.d.ts +3 -0
  68. package/cjs/components/util/register.js +15 -0
  69. package/cjs/components/util/register.js.map +1 -0
  70. package/cjs/components/util/tick-data/config.d.ts +1 -0
  71. package/cjs/components/util/tick-data/config.js +6 -0
  72. package/cjs/components/util/tick-data/config.js.map +1 -0
  73. package/cjs/components/util/tick-data/continuous.d.ts +2 -0
  74. package/cjs/components/util/tick-data/continuous.js +39 -0
  75. package/cjs/components/util/tick-data/continuous.js.map +1 -0
  76. package/cjs/components/util/tick-data/discrete/linear.d.ts +2 -0
  77. package/cjs/components/util/tick-data/discrete/linear.js +66 -0
  78. package/cjs/components/util/tick-data/discrete/linear.js.map +1 -0
  79. package/cjs/components/util/tick-data/discrete/polar-angle.d.ts +2 -0
  80. package/cjs/components/util/tick-data/discrete/polar-angle.js +46 -0
  81. package/cjs/components/util/tick-data/discrete/polar-angle.js.map +1 -0
  82. package/cjs/components/util/tick-data/index.d.ts +2 -0
  83. package/cjs/components/util/tick-data/index.js +17 -0
  84. package/cjs/components/util/tick-data/index.js.map +1 -0
  85. package/cjs/components/util/tick-data/util.d.ts +21 -0
  86. package/cjs/components/util/tick-data/util.js +115 -0
  87. package/cjs/components/util/tick-data/util.js.map +1 -0
  88. package/cjs/components/util/transform.d.ts +5 -0
  89. package/cjs/components/util/transform.js +45 -0
  90. package/cjs/components/util/transform.js.map +1 -0
  91. package/cjs/core/BaseTable.d.ts +18 -5
  92. package/cjs/core/BaseTable.js +99 -39
  93. package/cjs/core/BaseTable.js.map +1 -1
  94. package/cjs/core/TABLE_EVENT_TYPE.d.ts +3 -0
  95. package/cjs/core/TABLE_EVENT_TYPE.js +4 -1
  96. package/cjs/core/TABLE_EVENT_TYPE.js.map +1 -1
  97. package/cjs/core/style.js +1 -1
  98. package/cjs/core/style.js.map +1 -1
  99. package/cjs/core/tableHelper.js +1 -2
  100. package/cjs/data/CachedDataSource.js +2 -1
  101. package/cjs/data/DataSource.js +2 -2
  102. package/cjs/data/DataSource.js.map +1 -1
  103. package/cjs/dataset/dataset.d.ts +12 -19
  104. package/cjs/dataset/dataset.js +168 -196
  105. package/cjs/dataset/dataset.js.map +1 -1
  106. package/cjs/dataset/statistics-helper.d.ts +68 -0
  107. package/cjs/dataset/statistics-helper.js +173 -0
  108. package/cjs/dataset/statistics-helper.js.map +1 -0
  109. package/cjs/dataset/util/zero-align.d.ts +10 -0
  110. package/cjs/dataset/util/zero-align.js +119 -0
  111. package/cjs/dataset/util/zero-align.js.map +1 -0
  112. package/cjs/event/EventHandler.js.map +1 -1
  113. package/cjs/event/EventTarget.d.ts +5 -5
  114. package/cjs/event/EventTarget.js +2 -2
  115. package/cjs/event/EventTarget.js.map +1 -1
  116. package/cjs/event/VChartEventProxy.d.ts +1 -0
  117. package/cjs/event/VChartEventProxy.js +1 -0
  118. package/cjs/event/VChartEventProxy.js.map +1 -0
  119. package/cjs/event/event.js +7 -4
  120. package/cjs/event/event.js.map +1 -1
  121. package/cjs/event/listener/table-group.js +8 -6
  122. package/cjs/event/listener/table-group.js.map +1 -1
  123. package/cjs/event/pivot-chart/axis-click.d.ts +2 -0
  124. package/cjs/event/pivot-chart/axis-click.js +42 -0
  125. package/cjs/event/pivot-chart/axis-click.js.map +1 -0
  126. package/cjs/event/sparkline-event.js.map +1 -1
  127. package/cjs/event/util.js +0 -1
  128. package/cjs/header-helper/header-helper.js +1 -1
  129. package/cjs/header-helper/header-helper.js.map +1 -1
  130. package/cjs/header-helper/style/MultilineTextHeaderStyle.js +2 -2
  131. package/cjs/header-helper/style/MultilineTextHeaderStyle.js.map +1 -1
  132. package/cjs/header-helper/style/Style.d.ts +0 -1
  133. package/cjs/header-helper/style/Style.js +25 -28
  134. package/cjs/header-helper/style/Style.js.map +1 -1
  135. package/cjs/index.d.ts +4 -3
  136. package/cjs/index.js +11 -2
  137. package/cjs/index.js.map +1 -1
  138. package/cjs/layout/index.js +2 -1
  139. package/cjs/layout/pivot-chart/get-axis-config.d.ts +2 -0
  140. package/cjs/layout/pivot-chart/get-axis-config.js +118 -0
  141. package/cjs/layout/pivot-chart/get-axis-config.js.map +1 -0
  142. package/cjs/layout/pivot-chart/get-chart-spec.d.ts +4 -0
  143. package/cjs/layout/pivot-chart/get-chart-spec.js +118 -0
  144. package/cjs/layout/pivot-chart/get-chart-spec.js.map +1 -0
  145. package/cjs/layout/pivot-header-layout.d.ts +11 -5
  146. package/cjs/layout/pivot-header-layout.js +42 -12
  147. package/cjs/layout/pivot-header-layout.js.map +1 -1
  148. package/cjs/layout/pivot-layout.d.ts +53 -8
  149. package/cjs/layout/pivot-layout.js +393 -89
  150. package/cjs/layout/pivot-layout.js.map +1 -1
  151. package/cjs/layout/simple-header-layout.d.ts +8 -0
  152. package/cjs/layout/simple-header-layout.js +34 -0
  153. package/cjs/layout/simple-header-layout.js.map +1 -1
  154. package/cjs/scenegraph/component/table-component.js +3 -3
  155. package/cjs/scenegraph/component/table-component.js.map +1 -1
  156. package/cjs/scenegraph/graphic/chart.d.ts +3 -0
  157. package/cjs/scenegraph/graphic/chart.js +21 -6
  158. package/cjs/scenegraph/graphic/chart.js.map +1 -1
  159. package/cjs/scenegraph/graphic/contributions/chart-render.js +15 -3
  160. package/cjs/scenegraph/graphic/contributions/chart-render.js.map +1 -1
  161. package/cjs/scenegraph/group-creater/cell-helper.js +8 -3
  162. package/cjs/scenegraph/group-creater/cell-helper.js.map +1 -1
  163. package/cjs/scenegraph/group-creater/cell-type/chart-cell.js +2 -1
  164. package/cjs/scenegraph/group-creater/cell-type/chart-cell.js.map +1 -1
  165. package/cjs/scenegraph/group-creater/column.js.map +1 -1
  166. package/cjs/scenegraph/group-creater/progress/create-group-for-first-screen.d.ts +3 -0
  167. package/cjs/scenegraph/group-creater/progress/create-group-for-first-screen.js +71 -0
  168. package/cjs/scenegraph/group-creater/progress/create-group-for-first-screen.js.map +1 -0
  169. package/cjs/scenegraph/group-creater/progress/proxy.d.ts +1 -1
  170. package/cjs/scenegraph/group-creater/progress/proxy.js +29 -35
  171. package/cjs/scenegraph/group-creater/progress/proxy.js.map +1 -1
  172. package/cjs/scenegraph/group-creater/progress/update-position/dynamic-set-y.js +10 -9
  173. package/cjs/scenegraph/group-creater/progress/update-position/dynamic-set-y.js.map +1 -1
  174. package/cjs/scenegraph/layout/compute-col-width.js +23 -15
  175. package/cjs/scenegraph/layout/compute-col-width.js.map +1 -1
  176. package/cjs/scenegraph/layout/compute-row-height.js +20 -9
  177. package/cjs/scenegraph/layout/compute-row-height.js.map +1 -1
  178. package/cjs/scenegraph/layout/move-cell.js +1 -1
  179. package/cjs/scenegraph/layout/move-cell.js.map +1 -1
  180. package/cjs/scenegraph/layout/update-cell.js +3 -2
  181. package/cjs/scenegraph/layout/update-cell.js.map +1 -1
  182. package/cjs/scenegraph/layout/update-height.js +1 -1
  183. package/cjs/scenegraph/layout/update-height.js.map +1 -1
  184. package/cjs/scenegraph/layout/update-row.js +1 -1
  185. package/cjs/scenegraph/layout/update-row.js.map +1 -1
  186. package/cjs/scenegraph/layout/update-width.js +1 -1
  187. package/cjs/scenegraph/layout/update-width.js.map +1 -1
  188. package/cjs/scenegraph/refresh-node/update-chart.d.ts +3 -0
  189. package/cjs/scenegraph/refresh-node/update-chart.js +48 -5
  190. package/cjs/scenegraph/refresh-node/update-chart.js.map +1 -1
  191. package/cjs/scenegraph/scenegraph.d.ts +9 -0
  192. package/cjs/scenegraph/scenegraph.js +144 -18
  193. package/cjs/scenegraph/scenegraph.js.map +1 -1
  194. package/cjs/scenegraph/stick-text/index.js +10 -8
  195. package/cjs/scenegraph/stick-text/index.js.map +1 -1
  196. package/cjs/scenegraph/style/frame-border.js +1 -5
  197. package/cjs/scenegraph/style/frame-border.js.map +1 -1
  198. package/cjs/state/state.js +1 -1
  199. package/cjs/state/state.js.map +1 -1
  200. package/cjs/themes/DEFAULT.js +1 -2
  201. package/cjs/tools/LimitPromiseQueue.js +2 -1
  202. package/cjs/tools/calc.d.ts +3 -0
  203. package/cjs/tools/calc.js +11 -3
  204. package/cjs/tools/calc.js.map +1 -1
  205. package/cjs/tools/diff-cell.js +2 -2
  206. package/cjs/tools/dom.js +1 -1
  207. package/cjs/tools/env.js +1 -1
  208. package/cjs/ts-types/base-table.d.ts +29 -12
  209. package/cjs/ts-types/base-table.js.map +1 -1
  210. package/cjs/ts-types/column/style.d.ts +0 -1
  211. package/cjs/ts-types/column/style.js.map +1 -1
  212. package/cjs/ts-types/component/axis.d.ts +12 -0
  213. package/cjs/ts-types/component/axis.js +6 -0
  214. package/cjs/ts-types/component/axis.js.map +1 -0
  215. package/cjs/ts-types/component/legend.d.ts +5 -0
  216. package/cjs/ts-types/component/legend.js +6 -0
  217. package/cjs/ts-types/component/legend.js.map +1 -0
  218. package/cjs/ts-types/component/title.d.ts +47 -0
  219. package/cjs/ts-types/component/title.js +6 -0
  220. package/cjs/ts-types/component/title.js.map +1 -0
  221. package/cjs/ts-types/component/util.d.ts +1 -0
  222. package/cjs/ts-types/component/util.js +6 -0
  223. package/cjs/ts-types/component/util.js.map +1 -0
  224. package/cjs/ts-types/events.d.ts +100 -83
  225. package/cjs/ts-types/events.js.map +1 -1
  226. package/cjs/ts-types/list-table/layout-map/api.d.ts +2 -0
  227. package/cjs/ts-types/list-table/layout-map/api.js.map +1 -1
  228. package/cjs/ts-types/new-data-set.d.ts +18 -5
  229. package/cjs/ts-types/new-data-set.js +2 -2
  230. package/cjs/ts-types/new-data-set.js.map +1 -1
  231. package/cjs/ts-types/pivot-table/PIVOT_TABLE_EVENT_TYPE.d.ts +4 -0
  232. package/cjs/ts-types/pivot-table/PIVOT_TABLE_EVENT_TYPE.js +3 -1
  233. package/cjs/ts-types/pivot-table/PIVOT_TABLE_EVENT_TYPE.js.map +1 -1
  234. package/cjs/ts-types/pivot-table/corner.d.ts +3 -3
  235. package/cjs/ts-types/pivot-table/corner.js.map +1 -1
  236. package/cjs/ts-types/pivot-table/indicator/index.d.ts +1 -0
  237. package/cjs/ts-types/pivot-table/indicator/index.js.map +1 -1
  238. package/cjs/ts-types/pivot-table/title.d.ts +1 -1
  239. package/cjs/ts-types/pivot-table/title.js.map +1 -1
  240. package/cjs/ts-types/table-engine.d.ts +27 -3
  241. package/cjs/ts-types/table-engine.js.map +1 -1
  242. package/dist/vtable.js +22782 -11928
  243. package/dist/vtable.min.js +4 -2
  244. package/es/ListTable.d.ts +2 -1
  245. package/es/ListTable.js +17 -13
  246. package/es/ListTable.js.map +1 -1
  247. package/es/PivotChart.d.ts +68 -0
  248. package/es/PivotChart.js +437 -0
  249. package/es/PivotChart.js.map +1 -0
  250. package/es/PivotTable.d.ts +2 -1
  251. package/es/PivotTable.js +19 -14
  252. package/es/PivotTable.js.map +1 -1
  253. package/es/body-helper/style/MultilineTextStyle.js +2 -2
  254. package/es/body-helper/style/MultilineTextStyle.js.map +1 -1
  255. package/es/body-helper/style/ProgressBarStyle.js +15 -15
  256. package/es/body-helper/style/ProgressBarStyle.js.map +1 -1
  257. package/es/body-helper/style/Style.d.ts +0 -1
  258. package/es/body-helper/style/Style.js +25 -28
  259. package/es/body-helper/style/Style.js.map +1 -1
  260. package/es/components/axis/axis.d.ts +45 -0
  261. package/es/components/axis/axis.js +155 -0
  262. package/es/components/axis/axis.js.map +1 -0
  263. package/es/components/axis/band-scale.d.ts +18 -0
  264. package/es/components/axis/band-scale.js +46 -0
  265. package/es/components/axis/band-scale.js.map +1 -0
  266. package/es/components/axis/get-axis-attributes.d.ts +136 -0
  267. package/es/components/axis/get-axis-attributes.js +166 -0
  268. package/es/components/axis/get-axis-attributes.js.map +1 -0
  269. package/es/components/axis/label-overlap.d.ts +3 -0
  270. package/es/components/axis/label-overlap.js +39 -0
  271. package/es/components/axis/label-overlap.js.map +1 -0
  272. package/es/components/axis/linear-scale.d.ts +45 -0
  273. package/es/components/axis/linear-scale.js +104 -0
  274. package/es/components/axis/linear-scale.js.map +1 -0
  275. package/es/components/legend/get-legend-attributes.d.ts +5 -0
  276. package/es/components/legend/get-legend-attributes.js +84 -0
  277. package/es/components/legend/get-legend-attributes.js.map +1 -0
  278. package/es/components/legend/legend.d.ts +23 -0
  279. package/es/components/legend/legend.js +93 -0
  280. package/es/components/legend/legend.js.map +1 -0
  281. package/es/{menu → components/menu}/dom/BaseMenu.d.ts +2 -2
  282. package/es/components/menu/dom/BaseMenu.js.map +1 -0
  283. package/es/components/menu/dom/Menu.js.map +1 -0
  284. package/{cjs → es/components}/menu/dom/MenuHandler.d.ts +2 -2
  285. package/es/{menu → components/menu}/dom/MenuHandler.js +2 -2
  286. package/es/components/menu/dom/MenuHandler.js.map +1 -0
  287. package/es/{menu → components/menu}/dom/logic/MenuContainer.d.ts +2 -2
  288. package/es/{menu → components/menu}/dom/logic/MenuContainer.js +4 -4
  289. package/es/components/menu/dom/logic/MenuContainer.js.map +1 -0
  290. package/es/{menu → components/menu}/dom/logic/MenuElement.d.ts +2 -2
  291. package/es/{menu → components/menu}/dom/logic/MenuElement.js +9 -9
  292. package/es/components/menu/dom/logic/MenuElement.js.map +1 -0
  293. package/es/components/menu/dom/logic/MenuElementStyle.js.map +1 -0
  294. package/es/components/title/title.d.ts +12 -0
  295. package/es/components/title/title.js +61 -0
  296. package/es/components/title/title.js.map +1 -0
  297. package/es/{tooltip → components/tooltip}/BaseTooltip.d.ts +3 -3
  298. package/es/components/tooltip/BaseTooltip.js.map +1 -0
  299. package/es/components/tooltip/Tooltip.js.map +1 -0
  300. package/{cjs → es/components}/tooltip/TooltipHandler.d.ts +4 -4
  301. package/es/{tooltip → components/tooltip}/TooltipHandler.js +4 -4
  302. package/es/components/tooltip/TooltipHandler.js.map +1 -0
  303. package/es/{tooltip → components/tooltip}/logic/BubbleTooltipElement.d.ts +4 -4
  304. package/es/{tooltip → components/tooltip}/logic/BubbleTooltipElement.js +4 -4
  305. package/es/components/tooltip/logic/BubbleTooltipElement.js.map +1 -0
  306. package/es/components/tooltip/logic/BubbleTooltipElementStyle.js.map +1 -0
  307. package/es/components/util/orient.d.ts +3 -0
  308. package/es/components/util/orient.js +8 -0
  309. package/es/components/util/orient.js.map +1 -0
  310. package/es/components/util/register.d.ts +3 -0
  311. package/es/components/util/register.js +8 -0
  312. package/es/components/util/register.js.map +1 -0
  313. package/es/components/util/tick-data/config.d.ts +1 -0
  314. package/es/components/util/tick-data/config.js +2 -0
  315. package/es/components/util/tick-data/config.js.map +1 -0
  316. package/es/components/util/tick-data/continuous.d.ts +2 -0
  317. package/es/components/util/tick-data/continuous.js +38 -0
  318. package/es/components/util/tick-data/continuous.js.map +1 -0
  319. package/es/components/util/tick-data/discrete/linear.d.ts +2 -0
  320. package/es/components/util/tick-data/discrete/linear.js +59 -0
  321. package/es/components/util/tick-data/discrete/linear.js.map +1 -0
  322. package/es/components/util/tick-data/discrete/polar-angle.d.ts +2 -0
  323. package/es/components/util/tick-data/discrete/polar-angle.js +39 -0
  324. package/es/components/util/tick-data/discrete/polar-angle.js.map +1 -0
  325. package/es/components/util/tick-data/index.d.ts +2 -0
  326. package/es/components/util/tick-data/index.js +19 -0
  327. package/es/components/util/tick-data/index.js.map +1 -0
  328. package/es/components/util/tick-data/util.d.ts +21 -0
  329. package/es/components/util/tick-data/util.js +104 -0
  330. package/es/components/util/tick-data/util.js.map +1 -0
  331. package/es/components/util/transform.d.ts +5 -0
  332. package/es/components/util/transform.js +34 -0
  333. package/es/components/util/transform.js.map +1 -0
  334. package/es/core/BaseTable.d.ts +18 -5
  335. package/es/core/BaseTable.js +103 -41
  336. package/es/core/BaseTable.js.map +1 -1
  337. package/es/core/TABLE_EVENT_TYPE.d.ts +3 -0
  338. package/es/core/TABLE_EVENT_TYPE.js +4 -1
  339. package/es/core/TABLE_EVENT_TYPE.js.map +1 -1
  340. package/es/core/style.js +1 -1
  341. package/es/core/style.js.map +1 -1
  342. package/es/core/tableHelper.js +1 -2
  343. package/es/data/CachedDataSource.js +2 -1
  344. package/es/data/DataSource.js +2 -2
  345. package/es/data/DataSource.js.map +1 -1
  346. package/es/dataset/dataset.d.ts +12 -19
  347. package/es/dataset/dataset.js +161 -187
  348. package/es/dataset/dataset.js.map +1 -1
  349. package/es/dataset/statistics-helper.d.ts +68 -0
  350. package/es/dataset/statistics-helper.js +152 -0
  351. package/es/dataset/statistics-helper.js.map +1 -0
  352. package/es/dataset/util/zero-align.d.ts +10 -0
  353. package/es/dataset/util/zero-align.js +111 -0
  354. package/es/dataset/util/zero-align.js.map +1 -0
  355. package/es/event/EventHandler.js.map +1 -1
  356. package/es/event/EventTarget.d.ts +5 -5
  357. package/es/event/EventTarget.js +2 -2
  358. package/es/event/EventTarget.js.map +1 -1
  359. package/es/event/VChartEventProxy.d.ts +1 -0
  360. package/es/event/VChartEventProxy.js +1 -0
  361. package/es/event/VChartEventProxy.js.map +1 -0
  362. package/es/event/event.js +8 -3
  363. package/es/event/event.js.map +1 -1
  364. package/es/event/listener/table-group.js +8 -6
  365. package/es/event/listener/table-group.js.map +1 -1
  366. package/es/event/pivot-chart/axis-click.d.ts +2 -0
  367. package/es/event/pivot-chart/axis-click.js +36 -0
  368. package/es/event/pivot-chart/axis-click.js.map +1 -0
  369. package/es/event/sparkline-event.js.map +1 -1
  370. package/es/event/util.js +1 -2
  371. package/es/header-helper/header-helper.js +1 -1
  372. package/es/header-helper/header-helper.js.map +1 -1
  373. package/es/header-helper/style/MultilineTextHeaderStyle.js +2 -2
  374. package/es/header-helper/style/MultilineTextHeaderStyle.js.map +1 -1
  375. package/es/header-helper/style/Style.d.ts +0 -1
  376. package/es/header-helper/style/Style.js +25 -28
  377. package/es/header-helper/style/Style.js.map +1 -1
  378. package/es/index.d.ts +4 -3
  379. package/es/index.js +4 -2
  380. package/es/index.js.map +1 -1
  381. package/es/layout/index.js +2 -1
  382. package/es/layout/pivot-chart/get-axis-config.d.ts +2 -0
  383. package/es/layout/pivot-chart/get-axis-config.js +110 -0
  384. package/es/layout/pivot-chart/get-axis-config.js.map +1 -0
  385. package/es/layout/pivot-chart/get-chart-spec.d.ts +4 -0
  386. package/es/layout/pivot-chart/get-chart-spec.js +109 -0
  387. package/es/layout/pivot-chart/get-chart-spec.js.map +1 -0
  388. package/es/layout/pivot-header-layout.d.ts +11 -5
  389. package/es/layout/pivot-header-layout.js +41 -11
  390. package/es/layout/pivot-header-layout.js.map +1 -1
  391. package/es/layout/pivot-layout.d.ts +53 -8
  392. package/es/layout/pivot-layout.js +396 -87
  393. package/es/layout/pivot-layout.js.map +1 -1
  394. package/es/layout/simple-header-layout.d.ts +8 -0
  395. package/es/layout/simple-header-layout.js +34 -0
  396. package/es/layout/simple-header-layout.js.map +1 -1
  397. package/es/scenegraph/component/table-component.js +3 -3
  398. package/es/scenegraph/component/table-component.js.map +1 -1
  399. package/es/scenegraph/graphic/chart.d.ts +3 -0
  400. package/es/scenegraph/graphic/chart.js +22 -5
  401. package/es/scenegraph/graphic/chart.js.map +1 -1
  402. package/es/scenegraph/graphic/contributions/chart-render.js +15 -3
  403. package/es/scenegraph/graphic/contributions/chart-render.js.map +1 -1
  404. package/es/scenegraph/group-creater/cell-helper.js +9 -2
  405. package/es/scenegraph/group-creater/cell-helper.js.map +1 -1
  406. package/es/scenegraph/group-creater/cell-type/chart-cell.js +2 -1
  407. package/es/scenegraph/group-creater/cell-type/chart-cell.js.map +1 -1
  408. package/es/scenegraph/group-creater/column.js.map +1 -1
  409. package/es/scenegraph/group-creater/progress/create-group-for-first-screen.d.ts +3 -0
  410. package/es/scenegraph/group-creater/progress/create-group-for-first-screen.js +65 -0
  411. package/es/scenegraph/group-creater/progress/create-group-for-first-screen.js.map +1 -0
  412. package/es/scenegraph/group-creater/progress/proxy.d.ts +1 -1
  413. package/es/scenegraph/group-creater/progress/proxy.js +27 -34
  414. package/es/scenegraph/group-creater/progress/proxy.js.map +1 -1
  415. package/es/scenegraph/group-creater/progress/update-position/dynamic-set-y.js +9 -8
  416. package/es/scenegraph/group-creater/progress/update-position/dynamic-set-y.js.map +1 -1
  417. package/es/scenegraph/layout/compute-col-width.js +23 -15
  418. package/es/scenegraph/layout/compute-col-width.js.map +1 -1
  419. package/es/scenegraph/layout/compute-row-height.js +20 -9
  420. package/es/scenegraph/layout/compute-row-height.js.map +1 -1
  421. package/es/scenegraph/layout/move-cell.js +1 -1
  422. package/es/scenegraph/layout/move-cell.js.map +1 -1
  423. package/es/scenegraph/layout/update-cell.js +3 -1
  424. package/es/scenegraph/layout/update-cell.js.map +1 -1
  425. package/es/scenegraph/layout/update-height.js +1 -1
  426. package/es/scenegraph/layout/update-height.js.map +1 -1
  427. package/es/scenegraph/layout/update-row.js +1 -1
  428. package/es/scenegraph/layout/update-row.js.map +1 -1
  429. package/es/scenegraph/layout/update-width.js +1 -1
  430. package/es/scenegraph/layout/update-width.js.map +1 -1
  431. package/es/scenegraph/refresh-node/update-chart.d.ts +3 -0
  432. package/es/scenegraph/refresh-node/update-chart.js +45 -4
  433. package/es/scenegraph/refresh-node/update-chart.js.map +1 -1
  434. package/es/scenegraph/scenegraph.d.ts +9 -0
  435. package/es/scenegraph/scenegraph.js +146 -19
  436. package/es/scenegraph/scenegraph.js.map +1 -1
  437. package/es/scenegraph/stick-text/index.js +10 -8
  438. package/es/scenegraph/stick-text/index.js.map +1 -1
  439. package/es/scenegraph/style/frame-border.js +1 -5
  440. package/es/scenegraph/style/frame-border.js.map +1 -1
  441. package/es/state/state.js +1 -1
  442. package/es/state/state.js.map +1 -1
  443. package/es/themes/DEFAULT.js +1 -2
  444. package/es/tools/LimitPromiseQueue.js +2 -1
  445. package/es/tools/calc.d.ts +3 -0
  446. package/es/tools/calc.js +10 -0
  447. package/es/tools/calc.js.map +1 -1
  448. package/es/tools/diff-cell.js +1 -1
  449. package/es/tools/dom.js +1 -1
  450. package/es/tools/env.js +1 -1
  451. package/es/ts-types/base-table.d.ts +29 -12
  452. package/es/ts-types/base-table.js.map +1 -1
  453. package/es/ts-types/column/style.d.ts +0 -1
  454. package/es/ts-types/column/style.js.map +1 -1
  455. package/es/ts-types/component/axis.d.ts +12 -0
  456. package/es/ts-types/component/axis.js +2 -0
  457. package/es/ts-types/component/axis.js.map +1 -0
  458. package/es/ts-types/component/legend.d.ts +5 -0
  459. package/es/ts-types/component/legend.js +2 -0
  460. package/es/ts-types/component/legend.js.map +1 -0
  461. package/es/ts-types/component/title.d.ts +47 -0
  462. package/es/ts-types/component/title.js +2 -0
  463. package/es/ts-types/component/title.js.map +1 -0
  464. package/es/ts-types/component/util.d.ts +1 -0
  465. package/es/ts-types/component/util.js +2 -0
  466. package/es/ts-types/component/util.js.map +1 -0
  467. package/es/ts-types/events.d.ts +100 -83
  468. package/es/ts-types/events.js.map +1 -1
  469. package/es/ts-types/list-table/layout-map/api.d.ts +2 -0
  470. package/es/ts-types/list-table/layout-map/api.js.map +1 -1
  471. package/es/ts-types/new-data-set.d.ts +18 -5
  472. package/es/ts-types/new-data-set.js +2 -2
  473. package/es/ts-types/new-data-set.js.map +1 -1
  474. package/es/ts-types/pivot-table/PIVOT_TABLE_EVENT_TYPE.d.ts +4 -0
  475. package/es/ts-types/pivot-table/PIVOT_TABLE_EVENT_TYPE.js +4 -0
  476. package/es/ts-types/pivot-table/PIVOT_TABLE_EVENT_TYPE.js.map +1 -1
  477. package/es/ts-types/pivot-table/corner.d.ts +3 -3
  478. package/es/ts-types/pivot-table/corner.js.map +1 -1
  479. package/es/ts-types/pivot-table/indicator/index.d.ts +1 -0
  480. package/es/ts-types/pivot-table/indicator/index.js.map +1 -1
  481. package/es/ts-types/pivot-table/title.d.ts +1 -1
  482. package/es/ts-types/pivot-table/title.js.map +1 -1
  483. package/es/ts-types/table-engine.d.ts +27 -3
  484. package/es/ts-types/table-engine.js.map +1 -1
  485. package/package.json +11 -5
  486. package/cjs/menu/dom/BaseMenu.js.map +0 -1
  487. package/cjs/menu/dom/Menu.js.map +0 -1
  488. package/cjs/menu/dom/MenuHandler.js.map +0 -1
  489. package/cjs/menu/dom/logic/MenuContainer.js.map +0 -1
  490. package/cjs/menu/dom/logic/MenuElement.js.map +0 -1
  491. package/cjs/menu/dom/logic/MenuElementStyle.js.map +0 -1
  492. package/cjs/scenegraph/layout/auto-width.d.ts +0 -2
  493. package/cjs/scenegraph/layout/auto-width.js +0 -85
  494. package/cjs/scenegraph/layout/auto-width.js.map +0 -1
  495. package/cjs/tooltip/BaseTooltip.js.map +0 -1
  496. package/cjs/tooltip/Tooltip.js.map +0 -1
  497. package/cjs/tooltip/TooltipHandler.js.map +0 -1
  498. package/cjs/tooltip/logic/BubbleTooltipElement.js.map +0 -1
  499. package/cjs/tooltip/logic/BubbleTooltipElementStyle.js.map +0 -1
  500. package/es/menu/dom/BaseMenu.js.map +0 -1
  501. package/es/menu/dom/Menu.js.map +0 -1
  502. package/es/menu/dom/MenuHandler.js.map +0 -1
  503. package/es/menu/dom/logic/MenuContainer.js.map +0 -1
  504. package/es/menu/dom/logic/MenuElement.js.map +0 -1
  505. package/es/menu/dom/logic/MenuElementStyle.js.map +0 -1
  506. package/es/scenegraph/layout/auto-width.d.ts +0 -2
  507. package/es/scenegraph/layout/auto-width.js +0 -82
  508. package/es/scenegraph/layout/auto-width.js.map +0 -1
  509. package/es/tooltip/BaseTooltip.js.map +0 -1
  510. package/es/tooltip/Tooltip.js.map +0 -1
  511. package/es/tooltip/TooltipHandler.js.map +0 -1
  512. package/es/tooltip/logic/BubbleTooltipElement.js.map +0 -1
  513. package/es/tooltip/logic/BubbleTooltipElementStyle.js.map +0 -1
  514. /package/cjs/{menu → components/menu}/dom/BaseMenu.js +0 -0
  515. /package/cjs/{menu → components/menu}/dom/Menu.d.ts +0 -0
  516. /package/cjs/{menu → components/menu}/dom/Menu.js +0 -0
  517. /package/cjs/{menu → components/menu}/dom/logic/MenuElementStyle.d.ts +0 -0
  518. /package/cjs/{menu → components/menu}/dom/logic/MenuElementStyle.js +0 -0
  519. /package/cjs/{tooltip → components/tooltip}/BaseTooltip.js +0 -0
  520. /package/cjs/{tooltip → components/tooltip}/Tooltip.d.ts +0 -0
  521. /package/cjs/{tooltip → components/tooltip}/Tooltip.js +0 -0
  522. /package/cjs/{tooltip → components/tooltip}/logic/BubbleTooltipElementStyle.d.ts +0 -0
  523. /package/cjs/{tooltip → components/tooltip}/logic/BubbleTooltipElementStyle.js +0 -0
  524. /package/es/{menu → components/menu}/dom/BaseMenu.js +0 -0
  525. /package/es/{menu → components/menu}/dom/Menu.d.ts +0 -0
  526. /package/es/{menu → components/menu}/dom/Menu.js +0 -0
  527. /package/es/{menu → components/menu}/dom/logic/MenuElementStyle.d.ts +0 -0
  528. /package/es/{menu → components/menu}/dom/logic/MenuElementStyle.js +0 -0
  529. /package/es/{tooltip → components/tooltip}/BaseTooltip.js +0 -0
  530. /package/es/{tooltip → components/tooltip}/Tooltip.d.ts +0 -0
  531. /package/es/{tooltip → components/tooltip}/Tooltip.js +0 -0
  532. /package/es/{tooltip → components/tooltip}/logic/BubbleTooltipElementStyle.d.ts +0 -0
  533. /package/es/{tooltip → components/tooltip}/logic/BubbleTooltipElementStyle.js +0 -0
@@ -0,0 +1,104 @@
1
+ import { TextMeasure, degreeToRadian, isValidNumber, AABBBounds, get, polarToCartesian } from "@visactor/vutils";
2
+
3
+ import { getTextBounds } from "@visactor/vrender";
4
+
5
+ const DEFAULT_TEXT_FONT_FAMILY = "PingFang SC,Microsoft Yahei,system-ui,-apple-system,segoe ui,Roboto,Helvetica,Arial,sans-serif, apple color emoji,segoe ui emoji,segoe ui symbol", DEFAULT_TEXT_FONT_SIZE = 14, initTextMeasure = (textSpec, option, useNaiveCanvas) => new TextMeasure(Object.assign({
6
+ defaultFontParams: {
7
+ fontFamily: DEFAULT_TEXT_FONT_FAMILY,
8
+ fontSize: 14
9
+ },
10
+ getTextBounds: useNaiveCanvas ? void 0 : getTextBounds,
11
+ specialCharSet: "-/: .,@%'\"~" + TextMeasure.ALPHABET_CHAR_SET + TextMeasure.ALPHABET_CHAR_SET.toUpperCase()
12
+ }, null != option ? option : {}), textSpec);
13
+
14
+ export const radians = angle => isValidNumber(angle) ? degreeToRadian(angle) : null;
15
+
16
+ export const convertDomainToTickData = (domain, op) => domain.map(((t, index) => ({
17
+ index: index,
18
+ value: t,
19
+ label: op.labelFormatter ? op.labelFormatter(t) : `${t}`
20
+ })));
21
+
22
+ export const labelOverlap = (prevLabel, nextLabel, gap = 0) => {
23
+ const prevBounds = new AABBBounds(prevLabel).expand(gap / 2), nextBounds = new AABBBounds(nextLabel).expand(gap / 2);
24
+ return prevBounds.intersects(nextBounds);
25
+ };
26
+
27
+ export const labelDistance = (prevLabel, nextLabel) => {
28
+ let horizontal = 0;
29
+ prevLabel.x2 < nextLabel.x1 ? horizontal = nextLabel.x1 - prevLabel.x2 : nextLabel.x2 < prevLabel.x1 && (horizontal = prevLabel.x1 - nextLabel.x2);
30
+ let vertical = 0;
31
+ return prevLabel.y2 < nextLabel.y1 ? vertical = nextLabel.y1 - prevLabel.y2 : nextLabel.y2 < prevLabel.y1 && (vertical = prevLabel.y1 - nextLabel.y2),
32
+ [ horizontal, vertical ];
33
+ };
34
+
35
+ export function intersect(a, b, sep) {
36
+ return sep > Math.max(b.x1 - a.x2, a.x1 - b.x2, b.y1 - a.y2, a.y1 - b.y2);
37
+ }
38
+
39
+ export function hasOverlap(items, pad) {
40
+ for (let b, i = 1, n = items.length, a = items[0]; i < n; a = b, ++i) if (b = items[i],
41
+ intersect(a.AABBBounds, b.AABBBounds, pad)) return !0;
42
+ return !1;
43
+ }
44
+
45
+ const MIN_TICK_GAP = 12;
46
+
47
+ export const getCartesianLabelBounds = (scale, domain, op) => {
48
+ var _a;
49
+ const {labelStyle: labelStyle, axisOrientType: axisOrientType, labelFlush: labelFlush, labelFormatter: labelFormatter, startAngle: startAngle = 0} = op, labelAngle = null !== (_a = labelStyle.angle) && void 0 !== _a ? _a : 0, isHorizontal = [ "bottom", "top" ].includes(axisOrientType), isVertical = [ "left", "right" ].includes(axisOrientType);
50
+ let orientAngle = startAngle;
51
+ var angle;
52
+ isHorizontal ? orientAngle = 0 : isVertical && (orientAngle = isValidNumber(angle = -90) ? degreeToRadian(angle) : null);
53
+ const textMeasure = initTextMeasure(labelStyle), labelBoundsList = domain.map(((v, i) => {
54
+ var _a, _b;
55
+ const str = labelFormatter ? labelFormatter(v) : `${v}`, {width: width, height: height} = textMeasure.quickMeasure(str), textWidth = Math.max(width, 12), textHeight = Math.max(height, 12), pos = scale.scale(v);
56
+ let align, baseline, textX = Math.cos(orientAngle) * pos, textY = -Math.sin(orientAngle) * pos;
57
+ align = labelFlush && isHorizontal && 0 === i ? "left" : labelFlush && isHorizontal && i === domain.length - 1 ? "right" : null !== (_a = labelStyle.textAlign) && void 0 !== _a ? _a : "center",
58
+ "right" === align ? textX -= textWidth : "center" === align && (textX -= textWidth / 2),
59
+ baseline = labelFlush && isVertical && 0 === i ? "top" : labelFlush && isVertical && i === domain.length - 1 ? "bottom" : null !== (_b = labelStyle.textBaseline) && void 0 !== _b ? _b : "middle",
60
+ "bottom" === baseline ? textY -= textHeight : "middle" === baseline && (textY -= textHeight / 2);
61
+ return (new AABBBounds).set(textX, textY, textX + textWidth, textY + textHeight).rotate(labelAngle, textX + textWidth / 2, textY + textHeight / 2);
62
+ }));
63
+ return labelBoundsList;
64
+ };
65
+
66
+ export const getPolarAngleLabelBounds = (scale, domain, op) => {
67
+ var _a;
68
+ const {labelStyle: labelStyle, getRadius: getRadius, axisSpec: axisSpec, labelFormatter: labelFormatter} = op, radius = null == getRadius ? void 0 : getRadius(), labelAngle = null !== (_a = labelStyle.angle) && void 0 !== _a ? _a : 0, labelOffset = getAxisLabelOffset(axisSpec), textMeasure = initTextMeasure(labelStyle);
69
+ return domain.map((v => {
70
+ const str = labelFormatter ? labelFormatter(v) : `${v}`, {width: width, height: height} = textMeasure.quickMeasure(str), textWidth = Math.max(width, 12), textHeight = Math.max(height, 12), angle = scale.scale(v);
71
+ let textX = 0, textY = 0;
72
+ const orient = angleLabelOrientAttribute(angle), {x: x, y: y} = polarToCartesian({
73
+ x: 0,
74
+ y: 0
75
+ }, radius + labelOffset, angle);
76
+ textX = x + ("right" === orient.align ? -textWidth : "center" === orient.align ? -textWidth / 2 : 0),
77
+ textY = y + ("bottom" === orient.baseline ? -textHeight : "middle" === orient.baseline ? -textHeight / 2 : 0);
78
+ return (new AABBBounds).set(textX, textY, textX + textWidth, textY + textHeight).rotate(labelAngle, textX + textWidth / 2, textY + textHeight / 2);
79
+ }));
80
+ };
81
+
82
+ export function getAxisLabelOffset(axisSpec) {
83
+ let labelOffset = 0;
84
+ return get(axisSpec, "tick.visible") && (labelOffset += get(axisSpec, "tick.tickSize")),
85
+ get(axisSpec, "label.visible") && (labelOffset += get(axisSpec, "label.space")),
86
+ labelOffset;
87
+ }
88
+
89
+ export function angleLabelOrientAttribute(angle) {
90
+ let align = "center", baseline = "middle";
91
+ return align = (angle = normalizeAngle(angle)) >= Math.PI * (5 / 3) || angle <= Math.PI * (1 / 3) ? "left" : angle >= Math.PI * (2 / 3) && angle <= Math.PI * (4 / 3) ? "right" : "center",
92
+ baseline = angle >= Math.PI * (7 / 6) && angle <= Math.PI * (11 / 6) ? "bottom" : angle >= Math.PI * (1 / 6) && angle <= Math.PI * (5 / 6) ? "top" : "middle",
93
+ {
94
+ align: align,
95
+ baseline: baseline
96
+ };
97
+ }
98
+
99
+ export function normalizeAngle(angle) {
100
+ for (;angle < 0; ) angle += 2 * Math.PI;
101
+ for (;angle >= 2 * Math.PI; ) angle -= 2 * Math.PI;
102
+ return angle;
103
+ }
104
+ //# sourceMappingURL=util.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["components/util/tick-data/util.ts"],"names":[],"mappings":"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","file":"util.js","sourcesContent":["import type { IBaseScale } from '@visactor/vscale';\nimport type { IBoundsLike, ITextMeasureOption } from '@visactor/vutils';\nimport { TextMeasure, degreeToRadian, isValidNumber, AABBBounds, get, polarToCartesian } from '@visactor/vutils';\nimport { getTextBounds, type IGraphic } from '@visactor/vrender';\n\nconst DEFAULT_TEXT_FONT_FAMILY =\n // eslint-disable-next-line max-len\n 'PingFang SC,Microsoft Yahei,system-ui,-apple-system,segoe ui,Roboto,Helvetica,Arial,sans-serif, apple color emoji,segoe ui emoji,segoe ui symbol';\n\nconst DEFAULT_TEXT_FONT_SIZE = 14;\n\nconst initTextMeasure = (\n textSpec?: Partial<any>,\n option?: Partial<ITextMeasureOption>,\n useNaiveCanvas?: boolean\n): TextMeasure<any> => {\n return new TextMeasure<any>(\n {\n defaultFontParams: {\n fontFamily: DEFAULT_TEXT_FONT_FAMILY,\n fontSize: DEFAULT_TEXT_FONT_SIZE\n },\n getTextBounds: useNaiveCanvas ? undefined : getTextBounds,\n specialCharSet: '-/: .,@%\\'\"~' + TextMeasure.ALPHABET_CHAR_SET + TextMeasure.ALPHABET_CHAR_SET.toUpperCase(),\n ...(option ?? {})\n },\n textSpec\n );\n};\n\nexport const radians = (angle?: number) => {\n if (!isValidNumber(angle)) {\n return null;\n }\n return degreeToRadian(angle);\n};\n\nexport const convertDomainToTickData = (domain: any[], op: any): any[] => {\n const ticks = domain.map((t: number, index: number) => {\n return {\n index,\n value: t,\n label: op.labelFormatter ? op.labelFormatter(t) : `${t}`\n };\n });\n return ticks;\n};\n\n/** 判断两个label是否有重叠情况 */\nexport const labelOverlap = (prevLabel: AABBBounds, nextLabel: AABBBounds, gap: number = 0): boolean => {\n const prevBounds = new AABBBounds(prevLabel).expand(gap / 2);\n const nextBounds = new AABBBounds(nextLabel).expand(gap / 2);\n return prevBounds.intersects(nextBounds);\n};\n\n/** 判断两个不相交的label相隔的距离 */\nexport const labelDistance = (prevLabel: AABBBounds, nextLabel: AABBBounds): [number, number] => {\n let horizontal = 0;\n if (prevLabel.x2 < nextLabel.x1) {\n horizontal = nextLabel.x1 - prevLabel.x2;\n } else if (nextLabel.x2 < prevLabel.x1) {\n horizontal = prevLabel.x1 - nextLabel.x2;\n }\n\n let vertical = 0;\n if (prevLabel.y2 < nextLabel.y1) {\n vertical = nextLabel.y1 - prevLabel.y2;\n } else if (nextLabel.y2 < prevLabel.y1) {\n vertical = prevLabel.y1 - nextLabel.y2;\n }\n\n return [horizontal, vertical];\n};\n\nexport function intersect(a: IBoundsLike, b: IBoundsLike, sep: number) {\n return sep > Math.max(b.x1 - a.x2, a.x1 - b.x2, b.y1 - a.y2, a.y1 - b.y2);\n}\n\nexport interface ILabelItem<T> extends Pick<IGraphic, 'AABBBounds'> {\n value?: T;\n}\n\nexport function hasOverlap<T>(items: ILabelItem<T>[], pad: number): boolean {\n for (let i = 1, n = items.length, a = items[0], b; i < n; a = b, ++i) {\n b = items[i];\n if (intersect(a.AABBBounds, b.AABBBounds, pad)) {\n return true;\n }\n }\n return false;\n}\n\nconst MIN_TICK_GAP = 12;\n\nexport const getCartesianLabelBounds = (scale: IBaseScale, domain: any[], op: any): AABBBounds[] => {\n const { labelStyle, axisOrientType, labelFlush, labelFormatter, startAngle = 0 } = op;\n const labelAngle = labelStyle.angle ?? 0;\n const isHorizontal = ['bottom', 'top'].includes(axisOrientType);\n const isVertical = ['left', 'right'].includes(axisOrientType);\n let orientAngle = startAngle;\n if (isHorizontal) {\n orientAngle = 0;\n } else if (isVertical) {\n orientAngle = radians(-90);\n }\n\n const textMeasure = initTextMeasure(labelStyle);\n const labelBoundsList = domain.map((v: any, i: number) => {\n const str = labelFormatter ? labelFormatter(v) : `${v}`;\n\n // 估算文本宽高\n const { width, height } = textMeasure.quickMeasure(str);\n const textWidth = Math.max(width, MIN_TICK_GAP);\n const textHeight = Math.max(height, MIN_TICK_GAP);\n\n // 估算文本位置\n const pos = scale.scale(v);\n let textX = Math.cos(orientAngle) * pos;\n let textY = -Math.sin(orientAngle) * pos;\n\n let align: any;\n if (labelFlush && isHorizontal && i === 0) {\n align = 'left';\n } else if (labelFlush && isHorizontal && i === domain.length - 1) {\n align = 'right';\n } else {\n align = labelStyle.textAlign ?? 'center';\n }\n if (align === 'right') {\n textX -= textWidth;\n } else if (align === 'center') {\n textX -= textWidth / 2;\n }\n\n let baseline: any;\n if (labelFlush && isVertical && i === 0) {\n baseline = 'top';\n } else if (labelFlush && isVertical && i === domain.length - 1) {\n baseline = 'bottom';\n } else {\n baseline = labelStyle.textBaseline ?? 'middle';\n }\n if (baseline === 'bottom') {\n textY -= textHeight;\n } else if (baseline === 'middle') {\n textY -= textHeight / 2;\n }\n\n // 计算 label 包围盒\n const bounds = new AABBBounds()\n .set(textX, textY, textX + textWidth, textY + textHeight)\n .rotate(labelAngle, textX + textWidth / 2, textY + textHeight / 2);\n return bounds;\n });\n\n return labelBoundsList;\n};\n\nexport const getPolarAngleLabelBounds = (scale: IBaseScale, domain: any[], op: any): AABBBounds[] => {\n const { labelStyle, getRadius, axisSpec, labelFormatter } = op;\n const radius = getRadius?.();\n const labelAngle = labelStyle.angle ?? 0;\n\n const labelOffset = getAxisLabelOffset(axisSpec);\n\n const textMeasure = initTextMeasure(labelStyle);\n const labelBoundsList = domain.map((v: any) => {\n const str = labelFormatter ? labelFormatter(v) : `${v}`;\n\n // 估算文本宽高\n const { width, height } = textMeasure.quickMeasure(str);\n const textWidth = Math.max(width, MIN_TICK_GAP);\n const textHeight = Math.max(height, MIN_TICK_GAP);\n\n // 估算文本位置\n const angle = scale.scale(v);\n let textX = 0;\n let textY = 0;\n const orient = angleLabelOrientAttribute(angle);\n const { x, y } = polarToCartesian({ x: 0, y: 0 }, radius + labelOffset, angle);\n textX = x + (orient.align === 'right' ? -textWidth : orient.align === 'center' ? -textWidth / 2 : 0);\n textY = y + (orient.baseline === 'bottom' ? -textHeight : orient.baseline === 'middle' ? -textHeight / 2 : 0);\n\n // 计算 label 包围盒\n const bounds = new AABBBounds()\n .set(textX, textY, textX + textWidth, textY + textHeight)\n .rotate(labelAngle, textX + textWidth / 2, textY + textHeight / 2);\n return bounds;\n });\n\n return labelBoundsList;\n};\n\nexport function getAxisLabelOffset(axisSpec: any) {\n let labelOffset = 0;\n if (get(axisSpec, 'tick.visible')) {\n labelOffset += get(axisSpec, 'tick.tickSize');\n }\n\n if (get(axisSpec, 'label.visible')) {\n labelOffset += get(axisSpec, 'label.space');\n }\n\n return labelOffset;\n}\n\nexport function angleLabelOrientAttribute(angle: number) {\n let align: any = 'center';\n let baseline: any = 'middle';\n\n angle = normalizeAngle(angle);\n\n // left: 5/3 - 1/3; right: 2/3 - 4/3; center: 5/3 - 1/3 & 2/3 - 4/3\n if (angle >= Math.PI * (5 / 3) || angle <= Math.PI * (1 / 3)) {\n align = 'left';\n } else if (angle >= Math.PI * (2 / 3) && angle <= Math.PI * (4 / 3)) {\n align = 'right';\n } else {\n align = 'center';\n }\n\n // bottom: 7/6 - 11/6; top: 1/6 - 5/6; middle: 11/6 - 1/6 & 5/6 - 7/6\n if (angle >= Math.PI * (7 / 6) && angle <= Math.PI * (11 / 6)) {\n baseline = 'bottom';\n } else if (angle >= Math.PI * (1 / 6) && angle <= Math.PI * (5 / 6)) {\n baseline = 'top';\n } else {\n baseline = 'middle';\n }\n\n return { align, baseline };\n}\n\nexport function normalizeAngle(angle: number): number {\n while (angle < 0) {\n angle += Math.PI * 2;\n }\n while (angle >= Math.PI * 2) {\n angle -= Math.PI * 2;\n }\n return angle;\n}\n"]}
@@ -0,0 +1,5 @@
1
+ export declare function transformLegendTitleAttributes(title: any): any;
2
+ export declare function transformToGraphic(style: any): any;
3
+ export declare function transformComponentStyle(cfg?: any): any;
4
+ export declare function transformStateStyle(stateStyle: any): any;
5
+ export declare function transformAxisLineStyle(lineCfg: any): any;
@@ -0,0 +1,34 @@
1
+ import { degreeToRadian, isEmpty, merge } from "@visactor/vutils";
2
+
3
+ export function transformLegendTitleAttributes(title) {
4
+ var _a, _b;
5
+ const transformedTitle = Object.assign({}, title);
6
+ return isEmpty(title.style) || (transformedTitle.textStyle = transformToGraphic(title.style)),
7
+ isEmpty(title.textStyle) || merge(transformedTitle.textStyle, transformToGraphic(title.textStyle)),
8
+ (null === (_a = title.shape) || void 0 === _a ? void 0 : _a.style) && transformToGraphic(transformedTitle.shape.style),
9
+ (null === (_b = title.background) || void 0 === _b ? void 0 : _b.style) && transformToGraphic(transformedTitle.background.style),
10
+ transformedTitle;
11
+ }
12
+
13
+ export function transformToGraphic(style) {
14
+ return isEmpty(style) || style.angle && (style.angle = degreeToRadian(style.angle)),
15
+ style;
16
+ }
17
+
18
+ export function transformComponentStyle(cfg = {}) {
19
+ return isEmpty(cfg.style) || (cfg.style = transformToGraphic(cfg.style)), isEmpty(cfg.state) || Object.keys(cfg.state).forEach((key => {
20
+ isEmpty(cfg.state[key]) || (cfg.state[key] = transformToGraphic(cfg.state[key]));
21
+ })), cfg;
22
+ }
23
+
24
+ export function transformStateStyle(stateStyle) {
25
+ return isEmpty(stateStyle) ? null : (Object.keys(stateStyle).forEach((key => {
26
+ isEmpty(stateStyle[key]) || (stateStyle[key] = transformToGraphic(stateStyle[key]));
27
+ })), stateStyle);
28
+ }
29
+
30
+ export function transformAxisLineStyle(lineCfg) {
31
+ return transformComponentStyle(lineCfg), transformComponentStyle(lineCfg.startSymbol),
32
+ transformComponentStyle(lineCfg.endSymbol), lineCfg;
33
+ }
34
+ //# sourceMappingURL=transform.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["components/util/transform.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AAElE,MAAM,UAAU,8BAA8B,CAAC,KAAU;;IACvD,MAAM,gBAAgB,qBACjB,KAAK,CACT,CAAC;IACF,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE;QACzB,gBAAgB,CAAC,SAAS,GAAG,kBAAkB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;KAC9D;IACD,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE;QAC7B,KAAK,CAAC,gBAAgB,CAAC,SAAS,EAAE,kBAAkB,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC;KACxE;IAED,IAAI,MAAA,KAAK,CAAC,KAAK,0CAAE,KAAK,EAAE;QACtB,kBAAkB,CAAC,gBAAgB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;KAClD;IAED,IAAI,MAAA,KAAK,CAAC,UAAU,0CAAE,KAAK,EAAE;QAC3B,kBAAkB,CAAC,gBAAgB,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;KACvD;IACD,OAAO,gBAAgB,CAAC;AAC1B,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,KAAU;IAC3C,IAAI,OAAO,CAAC,KAAK,CAAC,EAAE;QAClB,OAAO,KAAK,CAAC;KACd;IACD,IAAI,KAAK,CAAC,KAAK,EAAE;QACf,KAAK,CAAC,KAAK,GAAG,cAAc,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;KAC3C;IAED,OAAO,KAAK,CAAC;AACf,CAAC;AAED,MAAM,UAAU,uBAAuB,CAAC,MAAW,EAAE;IACnD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE;QACvB,GAAG,CAAC,KAAK,GAAG,kBAAkB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;KAC3C;IAED,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE;QACvB,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;YACnC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,EAAE;gBAC5B,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,kBAAkB,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;aACrD;QACH,CAAC,CAAC,CAAC;KACJ;IAED,OAAO,GAAG,CAAC;AACb,CAAC;AAED,MAAM,UAAU,mBAAmB,CAAC,UAAe;IACjD,IAAI,OAAO,CAAC,UAAU,CAAC,EAAE;QACvB,OAAO,IAAI,CAAC;KACb;IACD,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;QACpC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,EAAE;YAC7B,UAAU,CAAC,GAAG,CAAC,GAAG,kBAAkB,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC;SACvD;IACH,CAAC,CAAC,CAAC;IAEH,OAAO,UAAU,CAAC;AACpB,CAAC;AAED,MAAM,UAAU,sBAAsB,CAAC,OAAY;IACjD,uBAAuB,CAAC,OAAO,CAAC,CAAC;IACjC,uBAAuB,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;IAC7C,uBAAuB,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IAE3C,OAAO,OAAO,CAAC;AACjB,CAAC","file":"transform.js","sourcesContent":["import { degreeToRadian, isEmpty, merge } from '@visactor/vutils';\n\nexport function transformLegendTitleAttributes(title: any) {\n const transformedTitle = {\n ...title\n };\n if (!isEmpty(title.style)) {\n transformedTitle.textStyle = transformToGraphic(title.style);\n }\n if (!isEmpty(title.textStyle)) {\n merge(transformedTitle.textStyle, transformToGraphic(title.textStyle));\n }\n\n if (title.shape?.style) {\n transformToGraphic(transformedTitle.shape.style);\n }\n\n if (title.background?.style) {\n transformToGraphic(transformedTitle.background.style);\n }\n return transformedTitle;\n}\n\nexport function transformToGraphic(style: any) {\n if (isEmpty(style)) {\n return style;\n }\n if (style.angle) {\n style.angle = degreeToRadian(style.angle);\n }\n\n return style;\n}\n\nexport function transformComponentStyle(cfg: any = {}) {\n if (!isEmpty(cfg.style)) {\n cfg.style = transformToGraphic(cfg.style);\n }\n\n if (!isEmpty(cfg.state)) {\n Object.keys(cfg.state).forEach(key => {\n if (!isEmpty(cfg.state[key])) {\n cfg.state[key] = transformToGraphic(cfg.state[key]);\n }\n });\n }\n\n return cfg;\n}\n\nexport function transformStateStyle(stateStyle: any) {\n if (isEmpty(stateStyle)) {\n return null;\n }\n Object.keys(stateStyle).forEach(key => {\n if (!isEmpty(stateStyle[key])) {\n stateStyle[key] = transformToGraphic(stateStyle[key]);\n }\n });\n\n return stateStyle;\n}\n\nexport function transformAxisLineStyle(lineCfg: any) {\n transformComponentStyle(lineCfg);\n transformComponentStyle(lineCfg.startSymbol);\n transformComponentStyle(lineCfg.endSymbol);\n\n return lineCfg;\n}\n"]}
@@ -1,4 +1,4 @@
1
- import type { CellAddress, CellRange, TableEventHandlersEventArgumentMap, TableEventHandlersReturnMap, TableKeyboardOptions, DropDownMenuHighlightInfo, MenuListItem, WidthModeDef, ICustomRender, ICellHeaderPaths, HeaderData, FullExtendStyle, FieldDef, ColumnTypeOption, SortState, IPagerConf, ICustomLayout, CellInfo, CellStyle, DropDownMenuOptions, FieldFormat, FieldData, MaybePromiseOrUndefined, MousePointerCellEvent, DropDownMenuEventInfo, HierarchyState, FieldKeyDef, CellType, LayoutObjectId } from '../ts-types';
1
+ import type { CellAddress, CellRange, TableEventHandlersEventArgumentMap, TableEventHandlersReturnMap, TableKeyboardOptions, DropDownMenuHighlightInfo, MenuListItem, WidthModeDef, ICustomRender, ICellHeaderPaths, HeaderData, FullExtendStyle, FieldDef, ColumnTypeOption, SortState, IPagerConf, ICustomLayout, CellInfo, CellStyle, DropDownMenuOptions, FieldFormat, FieldData, MaybePromiseOrUndefined, MousePointerCellEvent, DropDownMenuEventInfo, HierarchyState, FieldKeyDef, CellType, LayoutObjectId, HeightModeDef } from '../ts-types';
2
2
  import type { ColumnIconOption } from '../ts-types';
3
3
  import { TABLE_EVENT_TYPE } from './TABLE_EVENT_TYPE';
4
4
  import { EventTarget } from '../event/EventTarget';
@@ -14,6 +14,7 @@ import { type ITextSize } from '@visactor/vutils';
14
14
  import type { ColumnData, ColumnDefine, ColumnsDefine, IndicatorData } from '../ts-types/list-table/layout-map/api';
15
15
  import type { TooltipOptions } from '../ts-types/tooltip';
16
16
  import type { BaseTableAPI, BaseTableConstructorOptions, IBaseTableProtected } from '../ts-types/base-table';
17
+ import { DataSet } from '@visactor/vdataset';
17
18
  export declare abstract class BaseTable extends EventTarget implements BaseTableAPI {
18
19
  internalProps: IBaseTableProtected;
19
20
  showFrozenIcon: boolean;
@@ -30,15 +31,18 @@ export declare abstract class BaseTable extends EventTarget implements BaseTable
30
31
  tableX: number;
31
32
  tableY: number;
32
33
  _widthMode: WidthModeDef;
34
+ _heightMode: HeightModeDef;
35
+ _autoFillWidth: boolean;
33
36
  customRender?: ICustomRender;
34
37
  canvasWidth?: number;
35
38
  canvasHeight?: number;
39
+ dataSet: DataSet;
36
40
  scenegraph: Scenegraph;
37
41
  stateManeger?: StateManeger;
38
42
  eventManeger?: EventManeger;
39
43
  _pixelRatio: number;
40
- _cellToBeInvalidatedNextFrame: Set<string>;
41
- _willNextFrameInvalidate: boolean;
44
+ bottomFrozenRowCount: number;
45
+ rightFrozenColCount: number;
42
46
  static get EVENT_TYPE(): typeof TABLE_EVENT_TYPE;
43
47
  readonly options: BaseTableConstructorOptions;
44
48
  version: string;
@@ -97,6 +101,10 @@ export declare abstract class BaseTable extends EventTarget implements BaseTable
97
101
  set keyboardOptions(keyboardOptions: TableKeyboardOptions | null);
98
102
  get widthMode(): WidthModeDef;
99
103
  set widthMode(widthMode: WidthModeDef);
104
+ get heightMode(): HeightModeDef;
105
+ set heightMode(heightMode: HeightModeDef);
106
+ get autoFillWidth(): boolean;
107
+ set autoFillWidth(autoFillWidth: boolean);
100
108
  private _colWidthDefineToPxWidth;
101
109
  private _calculateAutoColWidthExpr;
102
110
  private _getColWidthLimits;
@@ -170,10 +178,12 @@ export declare abstract class BaseTable extends EventTarget implements BaseTable
170
178
  dispose: () => void;
171
179
  }): void;
172
180
  dispose(): void;
173
- fireListeners<TYPE extends keyof TableEventHandlersEventArgumentMap>(type: TYPE, ...event: TableEventHandlersEventArgumentMap[TYPE]): TableEventHandlersReturnMap[TYPE][];
181
+ fireListeners<TYPE extends keyof TableEventHandlersEventArgumentMap>(type: TYPE, event: TableEventHandlersEventArgumentMap[TYPE]): TableEventHandlersReturnMap[TYPE][];
174
182
  updateOption(options: BaseTableConstructorOptions): void;
175
183
  getFrozenRowsHeight(): number;
176
184
  getFrozenColsWidth(): number;
185
+ getBottomFrozenRowsHeight(): number;
186
+ getRightFrozenColsWidth(): number;
177
187
  getDrawRange(): Rect;
178
188
  _getMouseAbstractPoint(evt: TouchEvent | MouseEvent | undefined, isAddScroll?: boolean): {
179
189
  x: number;
@@ -209,7 +219,8 @@ export declare abstract class BaseTable extends EventTarget implements BaseTable
209
219
  selectCell(col: number, row: number): void;
210
220
  abstract isListTable(): boolean;
211
221
  abstract isPivotTable(): boolean;
212
- protected abstract getSortFuncFromHeaderOption(columns: ColumnsDefine | undefined, field: FieldDef, fieldKey?: FieldKeyDef): ((v1: any, v2: any, order: string) => 0 | 1 | -1) | undefined;
222
+ abstract isPivotChart(): boolean;
223
+ protected abstract _getSortFuncFromHeaderOption(columns: ColumnsDefine | undefined, field: FieldDef, fieldKey?: FieldKeyDef): ((v1: any, v2: any, order: string) => 0 | 1 | -1) | undefined;
213
224
  abstract refreshHeader(): void;
214
225
  abstract refreshRowColCount(): void;
215
226
  abstract getHierarchyState(col: number, row: number): HierarchyState | null;
@@ -260,6 +271,8 @@ export declare abstract class BaseTable extends EventTarget implements BaseTable
260
271
  isColumnHeader(col: number, row: number): boolean;
261
272
  isRowHeader(col: number, row: number): boolean;
262
273
  isCornerHeader(col: number, row: number): boolean;
274
+ isRightFrozenColumn(col: number, row: number): boolean;
275
+ isBottomFrozenRow(col: number, row: number): boolean;
263
276
  getCellInfo(col: number, row: number): MousePointerCellEvent;
264
277
  _hasField(field: FieldDef, col: number, row: number): boolean;
265
278
  _getCellStyle(col: number, row: number): FullExtendStyle;
@@ -34,7 +34,7 @@ import { BodyHelper } from "../body-helper/body-helper";
34
34
 
35
35
  import { HeaderHelper } from "../header-helper/header-helper";
36
36
 
37
- import { TooltipHandler } from "../tooltip/TooltipHandler";
37
+ import { TooltipHandler } from "../components/tooltip/TooltipHandler";
38
38
 
39
39
  import { isBoolean } from "@visactor/vutils";
40
40
 
@@ -48,27 +48,36 @@ import { IconCache } from "../plugins/icons";
48
48
 
49
49
  import { _applyColWidthLimits, _getScrollableVisibleRect, _getTargetFrozenColAt, _getTargetFrozenRowAt, _setDataSource, _setRecords, _toPxWidth, createRootElement, getStyleTheme, isAutoDefine, updateRootElementPadding } from "./tableHelper";
50
50
 
51
- import { MenuHandler } from "../menu/dom/MenuHandler";
51
+ import { MenuHandler } from "../components/menu/dom/MenuHandler";
52
52
 
53
53
  import { FocusInput } from "./FouseInput";
54
54
 
55
55
  import { defaultPixelRatio } from "../tools/pixel-ratio";
56
56
 
57
+ import { TableLegend } from "../components/legend/legend";
58
+
59
+ import { DataSet } from "@visactor/vdataset";
60
+
61
+ import { Title } from "../components/title/title";
62
+
57
63
  const {toBoxArray: toBoxArray} = utilStyle, {isTouchEvent: isTouchEvent} = event, rangeReg = /^\$(\d+)\$(\d+)$/;
58
64
 
59
65
  importStyle();
60
66
 
67
+ const EMPTY_STYLE = {};
68
+
61
69
  export class BaseTable extends EventTarget {
62
70
  static get EVENT_TYPE() {
63
71
  return TABLE_EVENT_TYPE;
64
72
  }
65
73
  constructor(options = {}) {
66
- var _a, _b, _c, _d, _e, _f, _g, _h;
67
- super(), this.showFrozenIcon = !0, this.showSort = !0, this.version = "0.9.2-alpha.0",
68
- this.id = `VTable${Date.now()}`, this.throttleInvalidate = throttle2(this.invalidate.bind(this), 200);
69
- const {frozenColCount: frozenColCount = 0, defaultRowHeight: defaultRowHeight = 40, defaultHeaderRowHeight: defaultHeaderRowHeight, defaultColWidth: defaultColWidth = 80, defaultHeaderColWidth: defaultHeaderColWidth, widthMode: widthMode = "standard", keyboardOptions: keyboardOptions, parentElement: parentElement, columnResizeMode: columnResizeMode, dragHeaderMode: dragHeaderMode, showFrozenIcon: showFrozenIcon, allowFrozenColCount: allowFrozenColCount, padding: padding, hover: hover, menu: menu, select: click, customRender: customRender, pixelRatio: pixelRatio = defaultPixelRatio} = options;
70
- this.options = options, this._widthMode = widthMode, this.customRender = customRender,
71
- this.padding = {
74
+ var _a, _b, _c, _d, _e, _f, _g;
75
+ super(), this.showFrozenIcon = !0, this.showSort = !0, this.bottomFrozenRowCount = 0,
76
+ this.rightFrozenColCount = 0, this.version = "0.9.2-alpha.2", this.id = `VTable${Date.now()}`,
77
+ this.throttleInvalidate = throttle2(this.invalidate.bind(this), 200);
78
+ const {frozenColCount: frozenColCount = 0, defaultRowHeight: defaultRowHeight = 40, defaultHeaderRowHeight: defaultHeaderRowHeight, defaultColWidth: defaultColWidth = 80, defaultHeaderColWidth: defaultHeaderColWidth, widthMode: widthMode = "standard", heightMode: heightMode = "standard", autoFillWidth: autoFillWidth = !1, keyboardOptions: keyboardOptions, parentElement: parentElement, columnResizeMode: columnResizeMode, dragHeaderMode: dragHeaderMode, showFrozenIcon: showFrozenIcon, allowFrozenColCount: allowFrozenColCount, padding: padding, hover: hover, menu: menu, select: click, customRender: customRender, pixelRatio: pixelRatio = defaultPixelRatio} = options;
79
+ this.options = options, this._widthMode = widthMode, this._heightMode = heightMode,
80
+ this._autoFillWidth = autoFillWidth, this.customRender = customRender, this.padding = {
72
81
  top: 0,
73
82
  right: 0,
74
83
  left: 0,
@@ -80,7 +89,6 @@ export class BaseTable extends EventTarget {
80
89
  this.tableNoFrameHeight = 0;
81
90
  const internalProps = this.internalProps = {};
82
91
  void 0 !== showFrozenIcon && (this.showFrozenIcon = showFrozenIcon), "number" == typeof allowFrozenColCount && allowFrozenColCount <= 0 && (this.showFrozenIcon = !1),
83
- internalProps.autoRowHeight = null !== (_a = options.autoRowHeight) && void 0 !== _a && _a,
84
92
  internalProps.handler = new EventHandler, internalProps.element = createRootElement(this.padding),
85
93
  internalProps.focusControl = new FocusInput(this, internalProps.element), internalProps.pixelRatio = pixelRatio,
86
94
  internalProps.canvas = document.createElement("canvas"), internalProps.element.appendChild(internalProps.canvas),
@@ -97,23 +105,29 @@ export class BaseTable extends EventTarget {
97
105
  var _a;
98
106
  return this._.canvas.width / (null !== (_a = this._.context.pixelRatio) && void 0 !== _a ? _a : window.devicePixelRatio);
99
107
  }
100
- }, internalProps.cellTextOverflows = {}, internalProps.focusedTable = !1, internalProps.theme = themes.of(null !== (_b = options.theme) && void 0 !== _b ? _b : themes.DEFAULT),
108
+ }, internalProps.cellTextOverflows = {}, internalProps.focusedTable = !1, internalProps.theme = themes.of(null !== (_a = options.theme) && void 0 !== _a ? _a : themes.DEFAULT),
101
109
  parentElement ? (parentElement.innerHTML = "", parentElement.appendChild(internalProps.element),
102
- this._updateSize()) : this._updateSize(), this._cellToBeInvalidatedNextFrame = new Set,
103
- this._willNextFrameInvalidate = !1, this.options = options, internalProps.theme = themes.of(null !== (_c = options.theme) && void 0 !== _c ? _c : themes.DEFAULT),
110
+ this._updateSize()) : this._updateSize(), this.options = options, internalProps.theme = themes.of(null !== (_b = options.theme) && void 0 !== _b ? _b : themes.DEFAULT),
104
111
  internalProps.bodyHelper = new BodyHelper(this), internalProps.headerHelper = new HeaderHelper(this),
105
- internalProps.autoWrapText = options.autoWrapText, internalProps.allowFrozenColCount = null !== (_d = options.allowFrozenColCount) && void 0 !== _d ? _d : internalProps.colCount,
106
- internalProps.limitMaxAutoWidth = null !== (_e = options.limitMaxAutoWidth) && void 0 !== _e ? _e : 450,
107
- this.scenegraph = new Scenegraph(this), this.stateManeger = new StateManeger(this),
108
- this.eventManeger = new EventManeger(this), internalProps.tooltip = Object.assign({
112
+ internalProps.autoWrapText = options.autoWrapText, internalProps.allowFrozenColCount = null !== (_c = options.allowFrozenColCount) && void 0 !== _c ? _c : internalProps.colCount,
113
+ internalProps.limitMaxAutoWidth = null !== (_d = options.limitMaxAutoWidth) && void 0 !== _d ? _d : 450,
114
+ this.dataSet = new DataSet, this.scenegraph = new Scenegraph(this), this.stateManeger = new StateManeger(this),
115
+ this.eventManeger = new EventManeger(this), options.legends && (internalProps.legends = new TableLegend(options.legends, this),
116
+ this.scenegraph.tableGroup.setAttributes({
117
+ x: this.tableX,
118
+ y: this.tableY
119
+ })), options.title && (internalProps.title = new Title(options.title, this), this.scenegraph.tableGroup.setAttributes({
120
+ x: this.tableX,
121
+ y: this.tableY
122
+ })), internalProps.tooltip = Object.assign({
109
123
  renderMode: "html",
110
124
  isShowOverflowTextTooltip: !1,
111
125
  confine: !0
112
126
  }, options.tooltip), "html" === internalProps.tooltip.renderMode && (internalProps.tooltipHandler = new TooltipHandler(this, internalProps.tooltip.confine)),
113
127
  internalProps.menu = Object.assign({
114
128
  renderMode: "html"
115
- }, options.menu), Array.isArray(null === (_f = options.menu) || void 0 === _f ? void 0 : _f.dropDownMenuHighlight) && this.setDropDownMenuHighlight(null === (_g = options.menu) || void 0 === _g ? void 0 : _g.dropDownMenuHighlight),
116
- Array.isArray(null === (_h = options.menu) || void 0 === _h ? void 0 : _h.defaultHeaderMenuItems) && (this.globalDropDownMenu = options.menu.defaultHeaderMenuItems),
129
+ }, options.menu), Array.isArray(null === (_e = options.menu) || void 0 === _e ? void 0 : _e.dropDownMenuHighlight) && this.setDropDownMenuHighlight(null === (_f = options.menu) || void 0 === _f ? void 0 : _f.dropDownMenuHighlight),
130
+ Array.isArray(null === (_g = options.menu) || void 0 === _g ? void 0 : _g.defaultHeaderMenuItems) && (this.globalDropDownMenu = options.menu.defaultHeaderMenuItems),
117
131
  "html" === internalProps.menu.renderMode && (internalProps.menuHandler = new MenuHandler(this)),
118
132
  this.headerStyleCache = new Map, this.bodyStyleCache = new Map;
119
133
  }
@@ -242,6 +256,18 @@ export class BaseTable extends EventTarget {
242
256
  set widthMode(widthMode) {
243
257
  widthMode !== this._widthMode && (this._widthMode = widthMode);
244
258
  }
259
+ get heightMode() {
260
+ return this._heightMode;
261
+ }
262
+ set heightMode(heightMode) {
263
+ heightMode !== this._heightMode && (this._heightMode = heightMode);
264
+ }
265
+ get autoFillWidth() {
266
+ return this._autoFillWidth;
267
+ }
268
+ set autoFillWidth(autoFillWidth) {
269
+ autoFillWidth !== this._autoFillWidth && (this._autoFillWidth = autoFillWidth);
270
+ }
245
271
  _colWidthDefineToPxWidth(width) {
246
272
  return isAutoDefine(width) ? _toPxWidth(this, this._calculateAutoColWidthExpr()) : _toPxWidth(this, width);
247
273
  }
@@ -326,7 +352,7 @@ export class BaseTable extends EventTarget {
326
352
  widths.forEach(((value, index) => this.setColWidth(index, value)));
327
353
  }
328
354
  getColsWidth(startCol, endCol) {
329
- var _a;
355
+ var _a, _b;
330
356
  endCol = Math.min(endCol, this.colCount - 1);
331
357
  const cachedColWidth = this._colRangeWidthsMap.get(`$${startCol}$${endCol}`);
332
358
  if (null != cachedColWidth) return cachedColWidth;
@@ -334,13 +360,13 @@ export class BaseTable extends EventTarget {
334
360
  if (null != cachedLowerColWidth) {
335
361
  const width = this.colWidthsMap.get(endCol);
336
362
  let adjustW;
337
- adjustW = width ? "adaptive" === this.widthMode || this.transpose ? Number(width) : this._adjustColWidth(endCol, this._colWidthDefineToPxWidth(width)) : 0;
363
+ adjustW = width ? "adaptive" === this.widthMode || this.transpose ? Number(width) : this._adjustColWidth(endCol, this._colWidthDefineToPxWidth(width)) : this.isRowHeader(endCol, 0) || this.isCornerHeader(endCol, 0) ? Array.isArray(this.defaultHeaderColWidth) ? null !== (_a = this.defaultHeaderColWidth[endCol]) && void 0 !== _a ? _a : this.internalProps.defaultColWidth : this.defaultHeaderColWidth : this.internalProps.defaultColWidth;
338
364
  const addWidth = cachedLowerColWidth + adjustW;
339
365
  return startCol >= 0 && endCol >= 0 && !Number.isNaN(addWidth) && this._colRangeWidthsMap.set(`$${startCol}$${endCol}`, Math.round(addWidth)),
340
366
  Math.round(addWidth);
341
367
  }
342
368
  let w = 0;
343
- for (let col = startCol; col <= endCol; col++) w += this.isRowHeader(col, 0) || this.isCornerHeader(col, 0) ? Array.isArray(this.defaultHeaderColWidth) ? null !== (_a = this.defaultHeaderColWidth[col]) && void 0 !== _a ? _a : this.internalProps.defaultColWidth : this.defaultHeaderColWidth : this.internalProps.defaultColWidth;
369
+ for (let col = startCol; col <= endCol; col++) w += this.isRowHeader(col, 0) || this.isCornerHeader(col, 0) ? Array.isArray(this.defaultHeaderColWidth) ? null !== (_b = this.defaultHeaderColWidth[col]) && void 0 !== _b ? _b : this.internalProps.defaultColWidth : this.defaultHeaderColWidth : this.internalProps.defaultColWidth;
344
370
  this.colWidthsMap.each(startCol, endCol, ((width, col) => {
345
371
  var _a;
346
372
  w += ("adaptive" === this.widthMode || this.transpose ? Number(width) : this._adjustColWidth(col, this._colWidthDefineToPxWidth(width))) - (this.isRowHeader(col, 0) || this.isCornerHeader(col, 0) ? Array.isArray(this.defaultHeaderColWidth) ? null !== (_a = this.defaultHeaderColWidth[col]) && void 0 !== _a ? _a : this.internalProps.defaultColWidth : this.defaultHeaderColWidth : this.internalProps.defaultColWidth);
@@ -354,8 +380,8 @@ export class BaseTable extends EventTarget {
354
380
  Math.round(w);
355
381
  }
356
382
  getRowHeight(row) {
357
- var _a;
358
- return this.rowHeightsMap.get(row) || (this.isColumnHeader(0, row) || this.isCornerHeader(0, row) ? Array.isArray(this.defaultHeaderRowHeight) ? null !== (_a = this.defaultHeaderRowHeight[row]) && void 0 !== _a ? _a : this.internalProps.defaultRowHeight : this.defaultHeaderRowHeight : this.internalProps.defaultRowHeight);
383
+ var _a, _b;
384
+ return this.rowHeightsMap.get(row) ? this.rowHeightsMap.get(row) : this.isColumnHeader(0, row) || this.isCornerHeader(0, row) ? Array.isArray(this.defaultHeaderRowHeight) ? null !== (_a = this.defaultHeaderRowHeight[row]) && void 0 !== _a ? _a : this.internalProps.defaultRowHeight : this.defaultHeaderRowHeight : this.isBottomFrozenRow(this.rowHeaderLevelCount, row) ? Array.isArray(this.defaultHeaderRowHeight) ? null !== (_b = this.defaultHeaderRowHeight[row]) && void 0 !== _b ? _b : this.internalProps.defaultRowHeight : this.defaultHeaderRowHeight : this.internalProps.defaultRowHeight;
359
385
  }
360
386
  setRowHeight(row, height, clearCache) {
361
387
  this.rowHeightsMap.put(row, Math.round(height)), clearCache && this._clearRowRangeHeightsMap(row);
@@ -366,7 +392,7 @@ export class BaseTable extends EventTarget {
366
392
  this._rowRangeHeightsMap.set(`$0$${row}`, Math.round((null !== (_a = this._rowRangeHeightsMap.get("$0$" + (row - 1))) && void 0 !== _a ? _a : 0) + rowHeight));
367
393
  }
368
394
  getRowsHeight(startRow, endRow) {
369
- var _a, _b, _c;
395
+ var _a, _b;
370
396
  const cachedRowHeight = this._rowRangeHeightsMap.get(`$${startRow}$${endRow}`);
371
397
  if (null != cachedRowHeight) return cachedRowHeight;
372
398
  const cachedLowerRowHeight = this._rowRangeHeightsMap.get(`$${startRow}$${endRow - 1}`);
@@ -376,14 +402,17 @@ export class BaseTable extends EventTarget {
376
402
  height;
377
403
  }
378
404
  let h = 0;
379
- for (let i = startRow; i <= endRow; i++) h += this.rowHeightsMap.get(i) || (this.isColumnHeader(0, i) || this.isCornerHeader(0, i) ? Array.isArray(this.defaultHeaderRowHeight) ? null !== (_c = this.defaultHeaderRowHeight[i]) && void 0 !== _c ? _c : this.internalProps.defaultRowHeight : this.defaultHeaderRowHeight : this.internalProps.defaultRowHeight);
405
+ if ("autoHeight" !== this.heightMode && this.internalProps.layoutMap && endRow >= this.columnHeaderLevelCount) {
406
+ for (let i = startRow; i < this.columnHeaderLevelCount; i++) h += this.getRowHeight(i);
407
+ h += this.defaultRowHeight * (endRow - Math.max(this.columnHeaderLevelCount, startRow) + 1);
408
+ } else for (let i = startRow; i <= endRow; i++) h += this.getRowHeight(i);
380
409
  return startRow >= 0 && endRow >= 0 && h > 0 && this._rowRangeHeightsMap.set(`$${startRow}$${endRow}`, Math.round(h)),
381
410
  Math.round(h);
382
411
  }
383
412
  getColWidthDefine(col) {
384
- var _a;
413
+ var _a, _b;
385
414
  const width = this.colWidthsMap.get(col);
386
- return "number" == typeof width && width <= 0 ? 0 : width || (this.isRowHeader(col, 0) || this.isCornerHeader(col, 0) ? Array.isArray(this.defaultHeaderColWidth) ? null !== (_a = this.defaultHeaderColWidth[col]) && void 0 !== _a ? _a : this.defaultColWidth : this.defaultHeaderColWidth : this.defaultColWidth);
415
+ return "number" == typeof width && width <= 0 ? 0 : width || (this.isRowHeader(col, 0) || this.isCornerHeader(col, 0) ? Array.isArray(this.defaultHeaderColWidth) ? null !== (_a = this.defaultHeaderColWidth[col]) && void 0 !== _a ? _a : this.defaultColWidth : this.defaultHeaderColWidth : this.isRightFrozenColumn(col, this.columnHeaderLevelCount) ? Array.isArray(this.defaultHeaderColWidth) ? null !== (_b = this.defaultHeaderColWidth[col]) && void 0 !== _b ? _b : this.defaultColWidth : this.defaultHeaderColWidth : this.defaultColWidth);
387
416
  }
388
417
  getColWidth(col) {
389
418
  const width = this.getColWidthDefine(col);
@@ -517,7 +546,7 @@ export class BaseTable extends EventTarget {
517
546
  return this.getCellsRectWidth(cellRange.start.col, cellRange.start.row, cellRange.end.col, cellRange.end.row);
518
547
  }
519
548
  isFrozenCell(col, row) {
520
- const {frozenRowCount: frozenRowCount, frozenColCount: frozenColCount} = this.internalProps, isFrozenRow = frozenRowCount > 0 && row < frozenRowCount, isFrozenCol = frozenColCount > 0 && col < frozenColCount;
549
+ const {frozenRowCount: frozenRowCount, frozenColCount: frozenColCount} = this.internalProps, isFrozenRow = frozenRowCount > 0 && row < frozenRowCount || this.isBottomFrozenRow(col, row), isFrozenCol = frozenColCount > 0 && col < frozenColCount || this.isRightFrozenColumn(col, row);
521
550
  return isFrozenRow || isFrozenCol ? {
522
551
  row: isFrozenRow,
523
552
  col: isFrozenCol
@@ -656,20 +685,21 @@ export class BaseTable extends EventTarget {
656
685
  const {parentElement: parentElement} = internalProps.element;
657
686
  parentElement && parentElement.removeChild(internalProps.element);
658
687
  }
659
- fireListeners(type, ...event) {
660
- return super.fireListeners(type, ...event);
688
+ fireListeners(type, event) {
689
+ return super.fireListeners(type, event);
661
690
  }
662
691
  updateOption(options) {
663
- var _a, _b, _c, _d;
692
+ var _a, _b, _c;
664
693
  this.options = options;
665
- const {frozenColCount: frozenColCount = 0, defaultRowHeight: defaultRowHeight = 40, defaultHeaderRowHeight: defaultHeaderRowHeight, defaultColWidth: defaultColWidth = 80, defaultHeaderColWidth: defaultHeaderColWidth = 80, keyboardOptions: keyboardOptions, columnResizeMode: columnResizeMode, dragHeaderMode: dragHeaderMode, showFrozenIcon: showFrozenIcon, allowFrozenColCount: allowFrozenColCount, padding: padding, hover: hover, menu: menu, select: click, pixelRatio: pixelRatio, widthMode: widthMode} = options;
694
+ const {frozenColCount: frozenColCount = 0, defaultRowHeight: defaultRowHeight = 40, defaultHeaderRowHeight: defaultHeaderRowHeight, defaultColWidth: defaultColWidth = 80, defaultHeaderColWidth: defaultHeaderColWidth = 80, keyboardOptions: keyboardOptions, columnResizeMode: columnResizeMode, dragHeaderMode: dragHeaderMode, showFrozenIcon: showFrozenIcon, allowFrozenColCount: allowFrozenColCount, padding: padding, hover: hover, menu: menu, select: click, pixelRatio: pixelRatio, widthMode: widthMode, heightMode: heightMode, autoFillWidth: autoFillWidth, customRender: customRender} = options;
666
695
  pixelRatio && pixelRatio !== this.internalProps.pixelRatio && (this.internalProps.pixelRatio = pixelRatio),
667
696
  padding && ("number" == typeof padding ? (this.padding.top = padding, this.padding.left = padding,
668
697
  this.padding.bottom = padding, this.padding.right = padding) : (padding.top && (this.padding.top = padding.top),
669
698
  padding.bottom && (this.padding.bottom = padding.bottom), padding.left && (this.padding.left = padding.left),
670
699
  padding.right && (this.padding.right = padding.right))), this.showFrozenIcon = "boolean" != typeof showFrozenIcon || showFrozenIcon,
671
700
  "number" == typeof allowFrozenColCount && allowFrozenColCount <= 0 && (this.showFrozenIcon = !1),
672
- this.widthMode = null != widthMode ? widthMode : "standard";
701
+ this.widthMode = null != widthMode ? widthMode : "standard", this.heightMode = null != heightMode ? heightMode : "standard",
702
+ this.autoFillWidth = null != autoFillWidth && autoFillWidth, this.customRender = customRender;
673
703
  const internalProps = this.internalProps;
674
704
  "node" !== Env.mode && updateRootElementPadding(internalProps.element, this.padding),
675
705
  internalProps.frozenColCount = frozenColCount, internalProps.defaultRowHeight = defaultRowHeight,
@@ -677,18 +707,28 @@ export class BaseTable extends EventTarget {
677
707
  internalProps.defaultColWidth = defaultColWidth, internalProps.defaultHeaderColWidth = null != defaultHeaderColWidth ? defaultHeaderColWidth : defaultColWidth,
678
708
  internalProps.keyboardOptions = keyboardOptions, internalProps.columnResizeMode = columnResizeMode,
679
709
  internalProps.dragHeaderMode = dragHeaderMode, internalProps.cellTextOverflows = {},
680
- internalProps.theme = themes.of(null !== (_a = options.theme) && void 0 !== _a ? _a : themes.DEFAULT),
681
- internalProps.autoRowHeight = null !== (_b = options.autoRowHeight) && void 0 !== _b && _b,
682
- internalProps.autoWrapText = options.autoWrapText, internalProps.allowFrozenColCount = null !== (_c = options.allowFrozenColCount) && void 0 !== _c ? _c : internalProps.colCount,
683
- internalProps.limitMaxAutoWidth = null !== (_d = options.limitMaxAutoWidth) && void 0 !== _d ? _d : 450,
684
- internalProps.tooltip = Object.assign({
710
+ internalProps._rowHeightsMap = new NumberMap, internalProps._rowRangeHeightsMap = new Map,
711
+ internalProps._colRangeWidthsMap = new Map, this.colWidthsMap = new NumberMap, this.colContentWidthsMap = new NumberMap,
712
+ this.colWidthsLimit = {}, internalProps.theme = themes.of(null !== (_a = options.theme) && void 0 !== _a ? _a : themes.DEFAULT),
713
+ internalProps.autoWrapText = options.autoWrapText, internalProps.allowFrozenColCount = null !== (_b = options.allowFrozenColCount) && void 0 !== _b ? _b : internalProps.colCount,
714
+ internalProps.limitMaxAutoWidth = null !== (_c = options.limitMaxAutoWidth) && void 0 !== _c ? _c : 450,
715
+ this.dataSet = new DataSet, this.scenegraph.clearCells(), this.stateManeger.initState(),
716
+ options.legends && (internalProps.legends = new TableLegend(options.legends, this),
717
+ this.scenegraph.tableGroup.setAttributes({
718
+ x: this.tableX,
719
+ y: this.tableY
720
+ })), options.title && (internalProps.title = new Title(options.title, this), this.scenegraph.tableGroup.setAttributes({
721
+ x: this.tableX,
722
+ y: this.tableY
723
+ })), internalProps.tooltip = Object.assign({
685
724
  renderMode: "html",
686
725
  isShowOverflowTextTooltip: !1,
687
726
  confine: !0
688
727
  }, options.tooltip), "html" !== internalProps.tooltip.renderMode || internalProps.tooltipHandler || (internalProps.tooltipHandler = new TooltipHandler(this, internalProps.tooltip.confine)),
689
728
  internalProps.menu = Object.assign({
690
729
  renderMode: "html"
691
- }, options.menu), "html" !== internalProps.menu.renderMode || internalProps.menuHandler || (internalProps.menuHandler = new MenuHandler(this));
730
+ }, options.menu), "html" !== internalProps.menu.renderMode || internalProps.menuHandler || (internalProps.menuHandler = new MenuHandler(this)),
731
+ this.headerStyleCache = new Map, this.bodyStyleCache = new Map;
692
732
  }
693
733
  getFrozenRowsHeight() {
694
734
  return this.getRowsHeight(0, this.frozenRowCount - 1);
@@ -696,6 +736,18 @@ export class BaseTable extends EventTarget {
696
736
  getFrozenColsWidth() {
697
737
  return this.getColsWidth(0, this.frozenColCount - 1);
698
738
  }
739
+ getBottomFrozenRowsHeight() {
740
+ if (this.bottomFrozenRowCount > 0) {
741
+ return this.getRowsHeight(this.rowCount - this.bottomFrozenRowCount, this.rowCount - 1);
742
+ }
743
+ return 0;
744
+ }
745
+ getRightFrozenColsWidth() {
746
+ if (this.rightFrozenColCount > 0) {
747
+ return this.getColsWidth(this.colCount - this.rightFrozenColCount, this.colCount - 1);
748
+ }
749
+ return 0;
750
+ }
699
751
  getDrawRange() {
700
752
  const width = Math.min(this.tableNoFrameWidth, this.getAllColsWidth()), height = Math.min(this.tableNoFrameHeight, this.getAllRowsHeight());
701
753
  return new Rect(this.tableX, this.tableY, width, height);
@@ -973,7 +1025,7 @@ export class BaseTable extends EventTarget {
973
1025
  let order, field, fieldKey;
974
1026
  if (Array.isArray(this.sortState) ? 0 !== this.sortState.length && ({order: order, field: field, fieldKey: fieldKey} = null === (_a = this.sortState) || void 0 === _a ? void 0 : _a[0]) : ({order: order, field: field, fieldKey: fieldKey} = this.sortState),
975
1027
  order && field && "normal" !== order) {
976
- const sortFunc = this.getSortFuncFromHeaderOption(void 0, field, fieldKey);
1028
+ const sortFunc = this._getSortFuncFromHeaderOption(void 0, field, fieldKey);
977
1029
  let hd;
978
1030
  hd = fieldKey ? this.internalProps.layoutMap.headerObjects.find((col => col && col.fieldKey === fieldKey)) : this.internalProps.layoutMap.headerObjects.find((col => col && col.field === field)),
979
1031
  (null === (_b = null == hd ? void 0 : hd.define) || void 0 === _b ? void 0 : _b.sort) && this.dataSource.sort(hd.field, order, null != sortFunc ? sortFunc : defaultOrderFn);
@@ -1008,6 +1060,14 @@ export class BaseTable extends EventTarget {
1008
1060
  var _a;
1009
1061
  return null === (_a = this.internalProps.layoutMap) || void 0 === _a ? void 0 : _a.isCornerHeader(col, row);
1010
1062
  }
1063
+ isRightFrozenColumn(col, row) {
1064
+ var _a;
1065
+ return null === (_a = this.internalProps.layoutMap) || void 0 === _a ? void 0 : _a.isRightFrozenColumn(col, row);
1066
+ }
1067
+ isBottomFrozenRow(col, row) {
1068
+ var _a;
1069
+ return null === (_a = this.internalProps.layoutMap) || void 0 === _a ? void 0 : _a.isBottomFrozenRow(col, row);
1070
+ }
1011
1071
  getCellInfo(col, row) {
1012
1072
  const colDef = this.isHeader(col, row) ? this.getHeaderDefine(col, row) : this.getBodyColumnDefine(col, row);
1013
1073
  return {
@@ -1039,7 +1099,9 @@ export class BaseTable extends EventTarget {
1039
1099
  if (layoutMap.isHeader(col, row)) {
1040
1100
  let cacheStyle = this.headerStyleCache.get(`${col}-${row}`);
1041
1101
  if (cacheStyle) return cacheStyle;
1042
- const hd = layoutMap.getHeader(col, row), styleClass = this.internalProps.headerHelper.getStyleClass(hd.headerType), {style: style} = hd;
1102
+ const hd = layoutMap.getHeader(col, row);
1103
+ if (!hd || hd.isEmpty) return EMPTY_STYLE;
1104
+ const styleClass = this.internalProps.headerHelper.getStyleClass(hd.headerType), {style: style} = hd;
1043
1105
  return cacheStyle = headerStyleContents.of(style, layoutMap.isColumnHeader(col, row) ? this.theme.headerStyle : layoutMap.isRowHeader(col, row) ? this.theme.rowHeaderStyle : this.theme.cornerHeaderStyle, {
1044
1106
  col: col,
1045
1107
  row: row,