@fileverse-dev/fortune-core 1.0.26 → 2.0.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 (346) hide show
  1. package/dist/index.esm.js +80254 -0
  2. package/dist/index.js +80600 -0
  3. package/{es → dist/packages/core/src}/api/cell.d.ts +10 -10
  4. package/{lib → dist/packages/core/src}/api/common.d.ts +66 -71
  5. package/{es → dist/packages/core/src}/api/errors.d.ts +2 -2
  6. package/{es → dist/packages/core/src}/api/index.d.ts +9 -9
  7. package/{es → dist/packages/core/src}/api/merge.d.ts +5 -5
  8. package/{lib → dist/packages/core/src}/api/range.d.ts +22 -22
  9. package/{lib → dist/packages/core/src}/api/rowcol.d.ts +14 -14
  10. package/{lib → dist/packages/core/src}/api/sheet.d.ts +10 -10
  11. package/{lib → dist/packages/core/src}/api/workbook.d.ts +15 -15
  12. package/{lib → dist/packages/core/src}/canvas.d.ts +46 -46
  13. package/{es → dist/packages/core/src}/context.d.ts +197 -198
  14. package/{es → dist/packages/core/src}/events/copy.d.ts +2 -2
  15. package/{lib → dist/packages/core/src}/events/index.d.ts +4 -4
  16. package/{lib → dist/packages/core/src}/events/keyboard.d.ts +6 -6
  17. package/{es → dist/packages/core/src}/events/mouse.d.ts +22 -22
  18. package/{es → dist/packages/core/src}/events/paste.d.ts +3 -3
  19. package/{lib → dist/packages/core/src}/index.d.ts +10 -10
  20. package/{lib → dist/packages/core/src}/locale/en.d.ts +992 -992
  21. package/{lib → dist/packages/core/src}/locale/es.d.ts +1134 -1134
  22. package/{lib → dist/packages/core/src}/locale/hi.d.ts +1030 -1030
  23. package/{lib → dist/packages/core/src}/locale/index.d.ts +1049 -1049
  24. package/{es → dist/packages/core/src}/locale/zh.d.ts +1048 -1048
  25. package/{lib → dist/packages/core/src}/locale/zh_tw.d.ts +1187 -1187
  26. package/{lib → dist/packages/core/src}/modules/ConditionFormat.d.ts +17 -17
  27. package/{lib → dist/packages/core/src}/modules/border.d.ts +3 -3
  28. package/{lib → dist/packages/core/src}/modules/cell.d.ts +32 -32
  29. package/{es → dist/packages/core/src}/modules/clipboard.d.ts +3 -3
  30. package/{es → dist/packages/core/src}/modules/color.d.ts +1 -1
  31. package/{lib → dist/packages/core/src}/modules/comment.d.ts +97 -97
  32. package/{es → dist/packages/core/src}/modules/conditionalFormat.d.ts +2 -2
  33. package/{es → dist/packages/core/src}/modules/cursor.d.ts +3 -3
  34. package/{es → dist/packages/core/src}/modules/dataVerification.d.ts +11 -11
  35. package/{es → dist/packages/core/src}/modules/dropCell.d.ts +10 -10
  36. package/{lib → dist/packages/core/src}/modules/filter.d.ts +45 -45
  37. package/{es → dist/packages/core/src}/modules/format.d.ts +6 -6
  38. package/{lib → dist/packages/core/src}/modules/formula.d.ts +54 -54
  39. package/{es → dist/packages/core/src}/modules/freeze.d.ts +5 -5
  40. package/{es → dist/packages/core/src}/modules/hyperlink.d.ts +21 -21
  41. package/{lib → dist/packages/core/src}/modules/iframe.d.ts +12 -12
  42. package/{es → dist/packages/core/src}/modules/image.d.ts +31 -31
  43. package/{es → dist/packages/core/src}/modules/index.d.ts +36 -36
  44. package/{lib → dist/packages/core/src}/modules/inline-string.d.ts +36 -36
  45. package/{es → dist/packages/core/src}/modules/location.d.ts +6 -6
  46. package/{es → dist/packages/core/src}/modules/locationCondition.d.ts +21 -21
  47. package/{es → dist/packages/core/src}/modules/merge.d.ts +3 -3
  48. package/{es → dist/packages/core/src}/modules/mobile.d.ts +5 -5
  49. package/{lib → dist/packages/core/src}/modules/moveCells.d.ts +5 -5
  50. package/{lib → dist/packages/core/src}/modules/protection.d.ts +5 -5
  51. package/{lib → dist/packages/core/src}/modules/refresh.d.ts +3 -3
  52. package/{es → dist/packages/core/src}/modules/rowcol.d.ts +19 -19
  53. package/{lib → dist/packages/core/src}/modules/screenshot.d.ts +2 -2
  54. package/{es → dist/packages/core/src}/modules/searchReplace.d.ts +36 -36
  55. package/{lib → dist/packages/core/src}/modules/selection.d.ts +46 -46
  56. package/{es → dist/packages/core/src}/modules/sheet.d.ts +10 -10
  57. package/{es → dist/packages/core/src}/modules/sort.d.ts +7 -7
  58. package/{es → dist/packages/core/src}/modules/splitColumn.d.ts +5 -5
  59. package/{es → dist/packages/core/src}/modules/text.d.ts +10 -10
  60. package/{lib → dist/packages/core/src}/modules/toolbar.d.ts +32 -32
  61. package/{es → dist/packages/core/src}/modules/validation.d.ts +19 -19
  62. package/{es → dist/packages/core/src}/modules/zoom.d.ts +3 -3
  63. package/{es → dist/packages/core/src}/settings.d.ts +100 -100
  64. package/{es → dist/packages/core/src}/types.d.ts +371 -376
  65. package/{es → dist/packages/core/src}/utils/freeze.d.ts +7 -7
  66. package/{es → dist/packages/core/src}/utils/index.d.ts +18 -19
  67. package/{lib → dist/packages/core/src}/utils/patch.d.ts +37 -37
  68. package/dist/packages/react/src/components/ChangeColor/index.d.ts +7 -0
  69. package/dist/packages/react/src/components/ConditionFormat/ConditionRules.d.ts +6 -0
  70. package/dist/packages/react/src/components/ConditionFormat/index.d.ts +7 -0
  71. package/dist/packages/react/src/components/ContextMenu/Divider.d.ts +3 -0
  72. package/dist/packages/react/src/components/ContextMenu/FilterMenu.d.ts +3 -0
  73. package/dist/packages/react/src/components/ContextMenu/Menu.d.ts +8 -0
  74. package/dist/packages/react/src/components/ContextMenu/SheetTab.d.ts +4 -0
  75. package/dist/packages/react/src/components/ContextMenu/index.d.ts +5 -0
  76. package/dist/packages/react/src/components/CustomSort/index.d.ts +4 -0
  77. package/dist/packages/react/src/components/DataVerification/DropdownList.d.ts +4 -0
  78. package/dist/packages/react/src/components/DataVerification/RangeDialog.d.ts +4 -0
  79. package/dist/packages/react/src/components/DataVerification/getDisplayedRangeTxt.d.ts +2 -0
  80. package/dist/packages/react/src/components/DataVerification/index.d.ts +4 -0
  81. package/dist/packages/react/src/components/Dialog/index.d.ts +15 -0
  82. package/dist/packages/react/src/components/DuneChartsInputModal/DuneChartsInputModal.d.ts +11 -0
  83. package/dist/packages/react/src/components/DunePreview/DunePreview.d.ts +13 -0
  84. package/dist/packages/react/src/components/FilterOption/index.d.ts +5 -0
  85. package/dist/packages/react/src/components/FormatSearch/index.d.ts +6 -0
  86. package/dist/packages/react/src/components/FormulaSearch/index.d.ts +5 -0
  87. package/dist/packages/react/src/components/FxEditor/NameBox.d.ts +3 -0
  88. package/dist/packages/react/src/components/FxEditor/index.d.ts +4 -0
  89. package/dist/packages/react/src/components/IFrameBoxs/iFrameBoxs.d.ts +4 -0
  90. package/dist/packages/react/src/components/ImgBoxs/index.d.ts +3 -0
  91. package/dist/packages/react/src/components/LinkEidtCard/index.d.ts +5 -0
  92. package/dist/packages/react/src/components/LocationCondition/index.d.ts +3 -0
  93. package/dist/packages/react/src/components/MessageBox/index.d.ts +9 -0
  94. package/dist/packages/react/src/components/NotationBoxes/index.d.ts +3 -0
  95. package/dist/packages/react/src/components/ResetColumnWidth/index.d.ts +2 -0
  96. package/dist/packages/react/src/components/SVGDefines.d.ts +5 -0
  97. package/dist/packages/react/src/components/SVGIcon.d.ts +9 -0
  98. package/dist/packages/react/src/components/SearchReplace/index.d.ts +6 -0
  99. package/dist/packages/react/src/components/Sheet/index.d.ts +8 -0
  100. package/dist/packages/react/src/components/SheetList/SheetHiddenButton.d.ts +8 -0
  101. package/dist/packages/react/src/components/SheetList/SheetListItem.d.ts +9 -0
  102. package/dist/packages/react/src/components/SheetList/index.d.ts +4 -0
  103. package/dist/packages/react/src/components/SheetOverlay/ColumnHeader.d.ts +3 -0
  104. package/dist/packages/react/src/components/SheetOverlay/ContentEditable.d.ts +11 -0
  105. package/dist/packages/react/src/components/SheetOverlay/FormulaHint/index.d.ts +4 -0
  106. package/dist/packages/react/src/components/SheetOverlay/FormulaSearch/constant.d.ts +63 -0
  107. package/dist/packages/react/src/components/SheetOverlay/FormulaSearch/index.d.ts +4 -0
  108. package/dist/packages/react/src/components/SheetOverlay/InputBox.d.ts +3 -0
  109. package/dist/packages/react/src/components/SheetOverlay/RowHeader.d.ts +3 -0
  110. package/dist/packages/react/src/components/SheetOverlay/ScrollBar/index.d.ts +7 -0
  111. package/dist/packages/react/src/components/SheetOverlay/index.d.ts +4 -0
  112. package/dist/packages/react/src/components/SheetTab/SheetItem.d.ts +8 -0
  113. package/dist/packages/react/src/components/SheetTab/index.d.ts +4 -0
  114. package/dist/packages/react/src/components/SplitColumn/index.d.ts +3 -0
  115. package/dist/packages/react/src/components/Toolbar/Button.d.ts +12 -0
  116. package/dist/packages/react/src/components/Toolbar/ColorPicker.d.ts +6 -0
  117. package/dist/packages/react/src/components/Toolbar/Combo.d.ts +12 -0
  118. package/dist/packages/react/src/components/Toolbar/CustomBorder.d.ts +7 -0
  119. package/dist/packages/react/src/components/Toolbar/CustomButton.d.ts +11 -0
  120. package/dist/packages/react/src/components/Toolbar/CustomColor.d.ts +8 -0
  121. package/dist/packages/react/src/components/Toolbar/CustomIcon.d.ts +9 -0
  122. package/dist/packages/react/src/components/Toolbar/Divider.d.ts +4 -0
  123. package/dist/packages/react/src/components/Toolbar/MoreItemsContainer.d.ts +6 -0
  124. package/dist/packages/react/src/components/Toolbar/Select.d.ts +14 -0
  125. package/dist/packages/react/src/components/Toolbar/index.d.ts +10 -0
  126. package/dist/packages/react/src/components/Workbook/api.d.ts +1177 -0
  127. package/dist/packages/react/src/components/Workbook/index.d.ts +1185 -0
  128. package/dist/packages/react/src/components/ZoomControl/index.d.ts +4 -0
  129. package/dist/packages/react/src/components/index.d.ts +4 -0
  130. package/dist/packages/react/src/constants.d.ts +1 -0
  131. package/dist/packages/react/src/context/index.d.ts +25 -0
  132. package/dist/packages/react/src/context/modal.d.ts +10 -0
  133. package/dist/packages/react/src/hooks/useAlert.d.ts +4 -0
  134. package/dist/packages/react/src/hooks/useDialog.d.ts +5 -0
  135. package/dist/packages/react/src/hooks/useOutsideClick.d.ts +2 -0
  136. package/dist/packages/react/src/hooks/usePrevious.d.ts +2 -0
  137. package/dist/packages/react/src/index.d.ts +1 -0
  138. package/dist/packages/react/src/utils/datepickerStyles.d.ts +2 -0
  139. package/dist/stories/API.stories.d.ts +1210 -0
  140. package/dist/stories/Collabration.stories.d.ts +2359 -0
  141. package/dist/stories/Features.stories.d.ts +9430 -0
  142. package/dist/stories/data/cell.d.ts +983 -0
  143. package/dist/stories/data/dataVerification.d.ts +131 -0
  144. package/dist/stories/data/empty.d.ts +10 -0
  145. package/dist/stories/data/formula.d.ts +362 -0
  146. package/dist/stories/data/freeze.d.ts +34 -0
  147. package/dist/stories/data/protected.d.ts +40 -0
  148. package/dist/stories/utils.d.ts +1 -0
  149. package/package.json +6 -7
  150. package/es/api/cell.js +0 -204
  151. package/es/api/common.d.ts +0 -71
  152. package/es/api/common.js +0 -79
  153. package/es/api/errors.js +0 -2
  154. package/es/api/index.js +0 -8
  155. package/es/api/merge.js +0 -15
  156. package/es/api/range.d.ts +0 -22
  157. package/es/api/range.js +0 -123
  158. package/es/api/rowcol.d.ts +0 -14
  159. package/es/api/rowcol.js +0 -207
  160. package/es/api/sheet.d.ts +0 -10
  161. package/es/api/sheet.js +0 -128
  162. package/es/api/workbook.d.ts +0 -15
  163. package/es/api/workbook.js +0 -85
  164. package/es/canvas.d.ts +0 -46
  165. package/es/canvas.js +0 -1350
  166. package/es/context.js +0 -381
  167. package/es/events/copy.js +0 -78
  168. package/es/events/index.d.ts +0 -4
  169. package/es/events/index.js +0 -4
  170. package/es/events/keyboard.d.ts +0 -6
  171. package/es/events/keyboard.js +0 -332
  172. package/es/events/mouse.js +0 -1725
  173. package/es/events/paste.js +0 -1378
  174. package/es/index.d.ts +0 -10
  175. package/es/index.js +0 -10
  176. package/es/locale/en.d.ts +0 -992
  177. package/es/locale/en.js +0 -10564
  178. package/es/locale/es.d.ts +0 -1134
  179. package/es/locale/es.js +0 -10010
  180. package/es/locale/hi.d.ts +0 -1030
  181. package/es/locale/hi.js +0 -10550
  182. package/es/locale/index.d.ts +0 -1049
  183. package/es/locale/index.js +0 -23
  184. package/es/locale/zh.js +0 -10568
  185. package/es/locale/zh_tw.d.ts +0 -1187
  186. package/es/locale/zh_tw.js +0 -10072
  187. package/es/modules/ConditionFormat.d.ts +0 -17
  188. package/es/modules/ConditionFormat.js +0 -1258
  189. package/es/modules/border.d.ts +0 -3
  190. package/es/modules/border.js +0 -1240
  191. package/es/modules/cell.d.ts +0 -32
  192. package/es/modules/cell.js +0 -1055
  193. package/es/modules/clipboard.js +0 -36
  194. package/es/modules/color.js +0 -1
  195. package/es/modules/comment.d.ts +0 -97
  196. package/es/modules/comment.js +0 -597
  197. package/es/modules/conditionalFormat.js +0 -441
  198. package/es/modules/cursor.js +0 -62
  199. package/es/modules/dataVerification.js +0 -701
  200. package/es/modules/dropCell.js +0 -2267
  201. package/es/modules/filter.d.ts +0 -45
  202. package/es/modules/filter.js +0 -434
  203. package/es/modules/format.js +0 -323
  204. package/es/modules/formula.d.ts +0 -54
  205. package/es/modules/formula.js +0 -2301
  206. package/es/modules/freeze.js +0 -148
  207. package/es/modules/hyperlink.js +0 -216
  208. package/es/modules/iframe.d.ts +0 -12
  209. package/es/modules/iframe.js +0 -220
  210. package/es/modules/image.js +0 -253
  211. package/es/modules/index.js +0 -36
  212. package/es/modules/inline-string.d.ts +0 -36
  213. package/es/modules/inline-string.js +0 -437
  214. package/es/modules/location.js +0 -46
  215. package/es/modules/locationCondition.js +0 -218
  216. package/es/modules/merge.js +0 -216
  217. package/es/modules/mobile.js +0 -33
  218. package/es/modules/moveCells.d.ts +0 -5
  219. package/es/modules/moveCells.js +0 -348
  220. package/es/modules/protection.d.ts +0 -5
  221. package/es/modules/protection.js +0 -96
  222. package/es/modules/refresh.d.ts +0 -3
  223. package/es/modules/refresh.js +0 -34
  224. package/es/modules/rowcol.js +0 -1922
  225. package/es/modules/screenshot.d.ts +0 -2
  226. package/es/modules/screenshot.js +0 -90
  227. package/es/modules/searchReplace.js +0 -388
  228. package/es/modules/selection.d.ts +0 -46
  229. package/es/modules/selection.js +0 -1674
  230. package/es/modules/sheet.js +0 -237
  231. package/es/modules/sort.js +0 -134
  232. package/es/modules/splitColumn.js +0 -126
  233. package/es/modules/ssf.js +0 -1533
  234. package/es/modules/text.js +0 -1207
  235. package/es/modules/toolbar.d.ts +0 -32
  236. package/es/modules/toolbar.js +0 -970
  237. package/es/modules/validation.js +0 -190
  238. package/es/modules/zoom.js +0 -29
  239. package/es/settings.js +0 -36
  240. package/es/types.js +0 -1
  241. package/es/utils/freeze.js +0 -86
  242. package/es/utils/index.js +0 -198
  243. package/es/utils/patch.d.ts +0 -37
  244. package/es/utils/patch.js +0 -381
  245. package/lib/api/cell.d.ts +0 -10
  246. package/lib/api/cell.js +0 -215
  247. package/lib/api/common.js +0 -88
  248. package/lib/api/errors.d.ts +0 -2
  249. package/lib/api/errors.js +0 -8
  250. package/lib/api/index.d.ts +0 -9
  251. package/lib/api/index.js +0 -101
  252. package/lib/api/merge.d.ts +0 -5
  253. package/lib/api/merge.js +0 -22
  254. package/lib/api/range.js +0 -138
  255. package/lib/api/rowcol.js +0 -222
  256. package/lib/api/sheet.js +0 -145
  257. package/lib/api/workbook.js +0 -98
  258. package/lib/canvas.js +0 -1356
  259. package/lib/context.d.ts +0 -198
  260. package/lib/context.js +0 -393
  261. package/lib/events/copy.d.ts +0 -2
  262. package/lib/events/copy.js +0 -85
  263. package/lib/events/index.js +0 -49
  264. package/lib/events/keyboard.js +0 -342
  265. package/lib/events/mouse.d.ts +0 -22
  266. package/lib/events/mouse.js +0 -1744
  267. package/lib/events/paste.d.ts +0 -3
  268. package/lib/events/paste.js +0 -1386
  269. package/lib/index.js +0 -109
  270. package/lib/locale/en.js +0 -10570
  271. package/lib/locale/es.js +0 -10016
  272. package/lib/locale/hi.js +0 -10556
  273. package/lib/locale/index.js +0 -29
  274. package/lib/locale/zh.d.ts +0 -1048
  275. package/lib/locale/zh.js +0 -10574
  276. package/lib/locale/zh_tw.js +0 -10078
  277. package/lib/modules/ConditionFormat.js +0 -1273
  278. package/lib/modules/border.js +0 -1248
  279. package/lib/modules/cell.js +0 -1085
  280. package/lib/modules/clipboard.d.ts +0 -3
  281. package/lib/modules/clipboard.js +0 -42
  282. package/lib/modules/color.d.ts +0 -1
  283. package/lib/modules/color.js +0 -7
  284. package/lib/modules/comment.js +0 -625
  285. package/lib/modules/conditionalFormat.d.ts +0 -2
  286. package/lib/modules/conditionalFormat.js +0 -447
  287. package/lib/modules/cursor.d.ts +0 -3
  288. package/lib/modules/cursor.js +0 -70
  289. package/lib/modules/dataVerification.d.ts +0 -11
  290. package/lib/modules/dataVerification.js +0 -716
  291. package/lib/modules/dropCell.d.ts +0 -10
  292. package/lib/modules/dropCell.js +0 -2283
  293. package/lib/modules/filter.js +0 -448
  294. package/lib/modules/format.d.ts +0 -6
  295. package/lib/modules/format.js +0 -334
  296. package/lib/modules/formula.js +0 -2330
  297. package/lib/modules/freeze.d.ts +0 -5
  298. package/lib/modules/freeze.js +0 -158
  299. package/lib/modules/hyperlink.d.ts +0 -21
  300. package/lib/modules/hyperlink.js +0 -232
  301. package/lib/modules/iframe.js +0 -236
  302. package/lib/modules/image.d.ts +0 -31
  303. package/lib/modules/image.js +0 -272
  304. package/lib/modules/index.d.ts +0 -36
  305. package/lib/modules/index.js +0 -401
  306. package/lib/modules/inline-string.js +0 -452
  307. package/lib/modules/location.d.ts +0 -6
  308. package/lib/modules/location.js +0 -57
  309. package/lib/modules/locationCondition.d.ts +0 -21
  310. package/lib/modules/locationCondition.js +0 -229
  311. package/lib/modules/merge.d.ts +0 -3
  312. package/lib/modules/merge.js +0 -223
  313. package/lib/modules/mobile.d.ts +0 -5
  314. package/lib/modules/mobile.js +0 -41
  315. package/lib/modules/moveCells.js +0 -357
  316. package/lib/modules/protection.js +0 -106
  317. package/lib/modules/refresh.js +0 -40
  318. package/lib/modules/rowcol.d.ts +0 -19
  319. package/lib/modules/rowcol.js +0 -1935
  320. package/lib/modules/screenshot.js +0 -96
  321. package/lib/modules/searchReplace.d.ts +0 -36
  322. package/lib/modules/searchReplace.js +0 -402
  323. package/lib/modules/selection.js +0 -1703
  324. package/lib/modules/sheet.d.ts +0 -10
  325. package/lib/modules/sheet.js +0 -250
  326. package/lib/modules/sort.d.ts +0 -7
  327. package/lib/modules/sort.js +0 -143
  328. package/lib/modules/splitColumn.d.ts +0 -5
  329. package/lib/modules/splitColumn.js +0 -136
  330. package/lib/modules/ssf.js +0 -1539
  331. package/lib/modules/text.d.ts +0 -10
  332. package/lib/modules/text.js +0 -1221
  333. package/lib/modules/toolbar.js +0 -1003
  334. package/lib/modules/validation.d.ts +0 -19
  335. package/lib/modules/validation.js +0 -205
  336. package/lib/modules/zoom.d.ts +0 -3
  337. package/lib/modules/zoom.js +0 -36
  338. package/lib/settings.d.ts +0 -100
  339. package/lib/settings.js +0 -42
  340. package/lib/types.d.ts +0 -376
  341. package/lib/types.js +0 -5
  342. package/lib/utils/freeze.d.ts +0 -7
  343. package/lib/utils/freeze.js +0 -92
  344. package/lib/utils/index.d.ts +0 -19
  345. package/lib/utils/index.js +0 -258
  346. package/lib/utils/patch.js +0 -392
package/lib/canvas.js DELETED
@@ -1,1356 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.defaultStyle = exports.Canvas = void 0;
7
- var _lodash = _interopRequireDefault(require("lodash"));
8
- var _context = require("./context");
9
- var _cell = require("./modules/cell");
10
- var _text = require("./modules/text");
11
- var _inlineString = require("./modules/inline-string");
12
- var _utils = require("./utils");
13
- var _border = require("./modules/border");
14
- var _modules = require("./modules");
15
- function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
16
- var defaultStyle = exports.defaultStyle = {
17
- fillStyle: "#000000",
18
- textBaseline: "middle",
19
- strokeStyle: "#dfdfdf",
20
- rowFillStyle: "#5e5e5e",
21
- textAlign: "center"
22
- };
23
- function isRealNum(val) {
24
- return !Number.isNaN(Number(val));
25
- }
26
- var cfIconsImg;
27
- function getCfIconsImg() {
28
- if (cfIconsImg) return cfIconsImg;
29
- cfIconsImg = new Image();
30
- cfIconsImg.src = "";
31
- return cfIconsImg;
32
- }
33
- function getBorderFix() {
34
- return [-1, 0, 0, -1];
35
- }
36
- function setLineDash(canvasborder, type, hv, moveX, moveY, toX, toY) {
37
- var borderType = {
38
- "0": "none",
39
- "1": "Thin",
40
- "2": "Hair",
41
- "3": "Dotted",
42
- "4": "Dashed",
43
- "5": "DashDot",
44
- "6": "DashDotDot",
45
- "7": "Double",
46
- "8": "Medium",
47
- "9": "MediumDashed",
48
- "10": "MediumDashDot",
49
- "11": "MediumDashDotDot",
50
- "12": "SlantedDashDot",
51
- "13": "Thick"
52
- };
53
- type = borderType[type.toString()];
54
- try {
55
- if (type === "Hair") {
56
- canvasborder.setLineDash([1, 2]);
57
- } else if (type.indexOf("DashDotDot") > -1) {
58
- canvasborder.setLineDash([2, 2, 5, 2, 2]);
59
- } else if (type.indexOf("DashDot") > -1) {
60
- canvasborder.setLineDash([2, 5, 2]);
61
- } else if (type.indexOf("Dotted") > -1) {
62
- canvasborder.setLineDash([2]);
63
- } else if (type.indexOf("Dashed") > -1) {
64
- canvasborder.setLineDash([3]);
65
- } else {
66
- canvasborder.setLineDash([0]);
67
- }
68
- } catch (e) {
69
- console.error(e);
70
- }
71
- canvasborder.beginPath();
72
- if (type.indexOf("Medium") > -1) {
73
- if (hv === "h") {
74
- canvasborder.moveTo(moveX, moveY - 0.5);
75
- canvasborder.lineTo(toX, toY - 0.5);
76
- } else {
77
- canvasborder.moveTo(moveX - 0.5, moveY);
78
- canvasborder.lineTo(toX - 0.5, toY);
79
- }
80
- canvasborder.lineWidth = 2;
81
- } else if (type === "Thick") {
82
- canvasborder.moveTo(moveX, moveY);
83
- canvasborder.lineTo(toX, toY);
84
- canvasborder.lineWidth = 3;
85
- } else {
86
- canvasborder.moveTo(moveX, moveY);
87
- canvasborder.lineTo(toX, toY);
88
- canvasborder.lineWidth = 1;
89
- }
90
- }
91
- var Canvas = exports.Canvas = function () {
92
- function Canvas(canvasElement, ctx) {
93
- this.canvasElement = canvasElement;
94
- this.sheetCtx = ctx;
95
- this.cellOverflowMapCache = {};
96
- }
97
- Canvas.prototype.drawRowHeader = function (scrollHeight, drawHeight, offsetTop) {
98
- var _a;
99
- var _b, _c, _d, _e, _f, _g, _h, _j;
100
- if (_lodash.default.isNil(drawHeight)) {
101
- _a = this.sheetCtx.luckysheetTableContentHW, drawHeight = _a[1];
102
- }
103
- if (_lodash.default.isNil(offsetTop)) {
104
- offsetTop = this.sheetCtx.columnHeaderHeight;
105
- }
106
- var renderCtx = this.canvasElement.getContext("2d");
107
- if (!renderCtx) return;
108
- renderCtx.save();
109
- renderCtx.scale(this.sheetCtx.devicePixelRatio, this.sheetCtx.devicePixelRatio);
110
- renderCtx.clearRect(0, offsetTop, this.sheetCtx.rowHeaderWidth - 1, drawHeight);
111
- renderCtx.font = (0, _text.defaultFont)(this.sheetCtx.defaultFontSize);
112
- renderCtx.textBaseline = defaultStyle.textBaseline;
113
- renderCtx.fillStyle = defaultStyle.fillStyle;
114
- var dataset_row_st;
115
- var dataset_row_ed;
116
- dataset_row_st = _lodash.default.sortedIndex(this.sheetCtx.visibledatarow, scrollHeight);
117
- dataset_row_ed = _lodash.default.sortedIndex(this.sheetCtx.visibledatarow, scrollHeight + drawHeight);
118
- if (dataset_row_st === -1) {
119
- dataset_row_st = 0;
120
- }
121
- if (dataset_row_ed === -1) {
122
- dataset_row_ed = this.sheetCtx.visibledatarow.length - 1;
123
- }
124
- renderCtx.save();
125
- renderCtx.beginPath();
126
- renderCtx.rect(0, offsetTop - 1, this.sheetCtx.rowHeaderWidth - 1, drawHeight - 2);
127
- renderCtx.clip();
128
- var end_r;
129
- var start_r;
130
- var bodrder05 = 0.5;
131
- var preEndR;
132
- for (var r = dataset_row_st; r <= dataset_row_ed; r += 1) {
133
- if (r === 0) {
134
- start_r = -scrollHeight - 1;
135
- } else {
136
- start_r = this.sheetCtx.visibledatarow[r - 1] - scrollHeight - 1;
137
- }
138
- end_r = this.sheetCtx.visibledatarow[r] - scrollHeight;
139
- var firstOffset = dataset_row_st === r ? -2 : 0;
140
- var lastOffset = dataset_row_ed === r ? -2 : 0;
141
- if (((_c = (_b = this.sheetCtx.hooks).beforeRenderRowHeaderCell) === null || _c === void 0 ? void 0 : _c.call(_b, "".concat(r + 1), r, start_r + offsetTop + firstOffset, this.sheetCtx.rowHeaderWidth - 1, end_r - start_r + 1 + lastOffset - firstOffset, renderCtx)) === false) {
142
- continue;
143
- }
144
- if (((_e = (_d = this.sheetCtx.config) === null || _d === void 0 ? void 0 : _d.rowhidden) === null || _e === void 0 ? void 0 : _e[r]) == null) {
145
- renderCtx.fillStyle = "#F8F9FA";
146
- renderCtx.fillRect(0, start_r + offsetTop + firstOffset, this.sheetCtx.rowHeaderWidth - 1, end_r - start_r + 1 + lastOffset - firstOffset);
147
- renderCtx.fillStyle = "#000000";
148
- renderCtx.save();
149
- renderCtx.scale(this.sheetCtx.zoomRatio, this.sheetCtx.zoomRatio);
150
- var textMetrics = (0, _text.getMeasureText)(r + 1, renderCtx, this.sheetCtx);
151
- var horizonAlignPos = (this.sheetCtx.rowHeaderWidth - textMetrics.width) / 2;
152
- var verticalAlignPos = start_r + (end_r - start_r) / 2 + offsetTop;
153
- renderCtx.fillText("".concat(r + 1), horizonAlignPos / this.sheetCtx.zoomRatio, verticalAlignPos / this.sheetCtx.zoomRatio);
154
- renderCtx.restore();
155
- }
156
- renderCtx.beginPath();
157
- renderCtx.moveTo(this.sheetCtx.rowHeaderWidth - 2 + bodrder05, start_r + offsetTop - 2);
158
- renderCtx.lineTo(this.sheetCtx.rowHeaderWidth - 2 + bodrder05, end_r + offsetTop - 2);
159
- renderCtx.lineWidth = 1;
160
- renderCtx.strokeStyle = defaultStyle.strokeStyle;
161
- renderCtx.stroke();
162
- renderCtx.closePath();
163
- if (this.sheetCtx.config.rowhidden && this.sheetCtx.config.rowhidden[r] == null && this.sheetCtx.config.rowhidden[r + 1] != null) {
164
- renderCtx.beginPath();
165
- renderCtx.moveTo(-1, end_r + offsetTop - 4 + bodrder05);
166
- renderCtx.lineTo(this.sheetCtx.rowHeaderWidth - 1, end_r + offsetTop - 4 + bodrder05);
167
- renderCtx.closePath();
168
- renderCtx.stroke();
169
- } else if (this.sheetCtx.config.rowhidden == null || this.sheetCtx.config.rowhidden[r] == null) {
170
- renderCtx.beginPath();
171
- renderCtx.moveTo(-1, end_r + offsetTop - 2 + bodrder05);
172
- renderCtx.lineTo(this.sheetCtx.rowHeaderWidth - 1, end_r + offsetTop - 2 + bodrder05);
173
- renderCtx.closePath();
174
- renderCtx.stroke();
175
- }
176
- if (((_g = (_f = this.sheetCtx.config) === null || _f === void 0 ? void 0 : _f.rowhidden) === null || _g === void 0 ? void 0 : _g[r - 1]) != null && preEndR !== undefined) {
177
- renderCtx.beginPath();
178
- renderCtx.moveTo(-1, preEndR + offsetTop + bodrder05);
179
- renderCtx.lineTo(this.sheetCtx.rowHeaderWidth - 1, preEndR + offsetTop + bodrder05);
180
- renderCtx.closePath();
181
- renderCtx.stroke();
182
- }
183
- preEndR = end_r;
184
- (_j = (_h = this.sheetCtx.hooks).afterRenderRowHeaderCell) === null || _j === void 0 ? void 0 : _j.call(_h, "".concat(r + 1), r, start_r + offsetTop + firstOffset, this.sheetCtx.rowHeaderWidth - 1, end_r - start_r + 1 + lastOffset - firstOffset, renderCtx);
185
- }
186
- renderCtx.restore();
187
- renderCtx.restore();
188
- };
189
- Canvas.prototype.drawColumnHeader = function (scrollWidth, drawWidth, offsetLeft) {
190
- var _a, _b, _c, _d, _e, _f, _g, _h;
191
- if (drawWidth === undefined) {
192
- drawWidth = this.sheetCtx.luckysheetTableContentHW[0];
193
- }
194
- if (offsetLeft === undefined) {
195
- offsetLeft = this.sheetCtx.rowHeaderWidth;
196
- }
197
- var renderCtx = this.canvasElement.getContext("2d");
198
- if (!renderCtx) return;
199
- renderCtx.save();
200
- renderCtx.scale(this.sheetCtx.devicePixelRatio, this.sheetCtx.devicePixelRatio);
201
- renderCtx.clearRect(offsetLeft, 0, drawWidth, this.sheetCtx.columnHeaderHeight - 1);
202
- renderCtx.font = (0, _text.defaultFont)(this.sheetCtx.defaultFontSize);
203
- renderCtx.textBaseline = defaultStyle.textBaseline;
204
- renderCtx.fillStyle = defaultStyle.fillStyle;
205
- var dataset_col_st;
206
- var dataset_col_ed;
207
- dataset_col_st = _lodash.default.sortedIndex(this.sheetCtx.visibledatacolumn, scrollWidth);
208
- dataset_col_ed = _lodash.default.sortedIndex(this.sheetCtx.visibledatacolumn, scrollWidth + drawWidth);
209
- if (dataset_col_st === -1) {
210
- dataset_col_st = 0;
211
- }
212
- if (dataset_col_ed === -1) {
213
- dataset_col_ed = this.sheetCtx.visibledatacolumn.length - 1;
214
- }
215
- renderCtx.save();
216
- renderCtx.beginPath();
217
- renderCtx.rect(offsetLeft - 1, 0, drawWidth, this.sheetCtx.columnHeaderHeight - 1);
218
- renderCtx.clip();
219
- var end_c;
220
- var start_c;
221
- var bodrder05 = 0.5;
222
- var preEndC;
223
- for (var c = dataset_col_st; c <= dataset_col_ed; c += 1) {
224
- if (c === 0) {
225
- start_c = -scrollWidth;
226
- } else {
227
- start_c = this.sheetCtx.visibledatacolumn[c - 1] - scrollWidth;
228
- }
229
- end_c = this.sheetCtx.visibledatacolumn[c] - scrollWidth;
230
- var abc = (0, _utils.indexToColumnChar)(c);
231
- if (((_b = (_a = this.sheetCtx.hooks).beforeRenderColumnHeaderCell) === null || _b === void 0 ? void 0 : _b.call(_a, abc, c, start_c + offsetLeft - 1, end_c - start_c, this.sheetCtx.columnHeaderHeight - 1, renderCtx)) === false) {
232
- continue;
233
- }
234
- if (((_d = (_c = this.sheetCtx.config) === null || _c === void 0 ? void 0 : _c.colhidden) === null || _d === void 0 ? void 0 : _d[c]) == null) {
235
- renderCtx.fillStyle = "#F8F9FA";
236
- renderCtx.fillRect(start_c + offsetLeft - 1, 0, end_c - start_c, this.sheetCtx.columnHeaderHeight - 1);
237
- renderCtx.fillStyle = "#000000";
238
- renderCtx.save();
239
- renderCtx.scale(this.sheetCtx.zoomRatio, this.sheetCtx.zoomRatio);
240
- var textMetrics = (0, _text.getMeasureText)(abc, renderCtx, this.sheetCtx);
241
- var horizonAlignPos = Math.round(start_c + (end_c - start_c) / 2 + offsetLeft - textMetrics.width / 2);
242
- var verticalAlignPos = Math.round(this.sheetCtx.columnHeaderHeight / 2);
243
- renderCtx.fillText(abc, horizonAlignPos / this.sheetCtx.zoomRatio, verticalAlignPos / this.sheetCtx.zoomRatio);
244
- renderCtx.restore();
245
- }
246
- if (this.sheetCtx.config.colhidden && this.sheetCtx.config.colhidden[c] != null && this.sheetCtx.config.colhidden[c + 1] != null) {
247
- renderCtx.beginPath();
248
- renderCtx.moveTo(end_c + offsetLeft - 4 + bodrder05, 0);
249
- renderCtx.lineTo(end_c + offsetLeft - 4 + bodrder05, this.sheetCtx.columnHeaderHeight - 2);
250
- renderCtx.lineWidth = 1;
251
- renderCtx.strokeStyle = defaultStyle.strokeStyle;
252
- renderCtx.closePath();
253
- renderCtx.stroke();
254
- } else if (this.sheetCtx.config.colhidden == null || this.sheetCtx.config.colhidden[c] == null) {
255
- renderCtx.beginPath();
256
- renderCtx.moveTo(end_c + offsetLeft - 2 + bodrder05, 0);
257
- renderCtx.lineTo(end_c + offsetLeft - 2 + bodrder05, this.sheetCtx.columnHeaderHeight - 2);
258
- renderCtx.lineWidth = 1;
259
- renderCtx.strokeStyle = defaultStyle.strokeStyle;
260
- renderCtx.closePath();
261
- renderCtx.stroke();
262
- }
263
- if (((_f = (_e = this.sheetCtx.config) === null || _e === void 0 ? void 0 : _e.colhidden) === null || _f === void 0 ? void 0 : _f[c - 1]) != null && preEndC !== undefined) {
264
- renderCtx.beginPath();
265
- renderCtx.moveTo(preEndC + offsetLeft + bodrder05, 0);
266
- renderCtx.lineTo(preEndC + offsetLeft + bodrder05, this.sheetCtx.columnHeaderHeight - 2);
267
- renderCtx.closePath();
268
- renderCtx.stroke();
269
- }
270
- renderCtx.beginPath();
271
- renderCtx.moveTo(start_c + offsetLeft - 1, this.sheetCtx.columnHeaderHeight - 2 + bodrder05);
272
- renderCtx.lineTo(end_c + offsetLeft - 1, this.sheetCtx.columnHeaderHeight - 2 + bodrder05);
273
- renderCtx.stroke();
274
- renderCtx.closePath();
275
- preEndC = end_c;
276
- (_h = (_g = this.sheetCtx.hooks).afterRenderColumnHeaderCell) === null || _h === void 0 ? void 0 : _h.call(_g, abc, c, start_c + offsetLeft - 1, end_c - start_c, this.sheetCtx.columnHeaderHeight - 1, renderCtx);
277
- }
278
- renderCtx.restore();
279
- renderCtx.restore();
280
- };
281
- Canvas.prototype.drawMain = function (_a) {
282
- var _b;
283
- var _this = this;
284
- var _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r;
285
- var scrollWidth = _a.scrollWidth,
286
- scrollHeight = _a.scrollHeight,
287
- drawWidth = _a.drawWidth,
288
- drawHeight = _a.drawHeight,
289
- offsetLeft = _a.offsetLeft,
290
- offsetTop = _a.offsetTop,
291
- columnOffsetCell = _a.columnOffsetCell,
292
- rowOffsetCell = _a.rowOffsetCell,
293
- clear = _a.clear;
294
- var flowdata = (0, _context.getFlowdata)(this.sheetCtx);
295
- if (_lodash.default.isNil(flowdata)) {
296
- return;
297
- }
298
- clearTimeout(this.measureTextCacheTimeOut);
299
- if (drawWidth === undefined) {
300
- drawWidth = this.sheetCtx.luckysheetTableContentHW[0];
301
- }
302
- if (drawHeight === undefined) {
303
- _b = this.sheetCtx.luckysheetTableContentHW, drawHeight = _b[1];
304
- }
305
- if (offsetLeft === undefined) {
306
- offsetLeft = this.sheetCtx.rowHeaderWidth;
307
- }
308
- if (offsetTop === undefined) {
309
- offsetTop = this.sheetCtx.columnHeaderHeight;
310
- }
311
- if (columnOffsetCell === undefined) {
312
- columnOffsetCell = 0;
313
- }
314
- if (rowOffsetCell === undefined) {
315
- rowOffsetCell = 0;
316
- }
317
- var renderCtx = this.canvasElement.getContext("2d");
318
- if (!renderCtx) return;
319
- renderCtx.save();
320
- renderCtx.scale(this.sheetCtx.devicePixelRatio, this.sheetCtx.devicePixelRatio);
321
- if (clear) {
322
- renderCtx.clearRect(0, 0, this.sheetCtx.luckysheetTableContentHW[0], this.sheetCtx.luckysheetTableContentHW[1]);
323
- }
324
- var rowStart;
325
- var rowEnd;
326
- var colStart;
327
- var colEnd;
328
- rowStart = _lodash.default.sortedIndex(this.sheetCtx.visibledatarow, scrollHeight);
329
- rowEnd = _lodash.default.sortedIndex(this.sheetCtx.visibledatarow, scrollHeight + drawHeight);
330
- if (rowStart === -1) {
331
- rowStart = 0;
332
- }
333
- rowStart += rowOffsetCell;
334
- if (rowEnd === -1) {
335
- rowEnd = this.sheetCtx.visibledatarow.length - 1;
336
- }
337
- rowEnd += rowOffsetCell;
338
- if (rowEnd >= this.sheetCtx.visibledatarow.length) {
339
- rowEnd = this.sheetCtx.visibledatarow.length - 1;
340
- }
341
- colStart = _lodash.default.sortedIndex(this.sheetCtx.visibledatacolumn, scrollWidth);
342
- colEnd = _lodash.default.sortedIndex(this.sheetCtx.visibledatacolumn, scrollWidth + drawWidth);
343
- if (colStart === -1) {
344
- colStart = 0;
345
- }
346
- colStart += columnOffsetCell;
347
- if (colEnd === -1) {
348
- colEnd = this.sheetCtx.visibledatacolumn.length - 1;
349
- }
350
- colEnd += columnOffsetCell;
351
- if (colEnd >= this.sheetCtx.visibledatacolumn.length) {
352
- colEnd = this.sheetCtx.visibledatacolumn.length - 1;
353
- }
354
- var rowEndY = this.sheetCtx.visibledatarow[rowEnd];
355
- var colEndX = this.sheetCtx.visibledatacolumn[colEnd];
356
- renderCtx.fillStyle = "#ffffff";
357
- renderCtx.fillRect(offsetLeft - 1, offsetTop - 1, colEndX - scrollWidth, rowEndY - scrollHeight);
358
- renderCtx.font = (0, _text.defaultFont)(this.sheetCtx.defaultFontSize);
359
- renderCtx.fillStyle = defaultStyle.fillStyle;
360
- var cellupdate = [];
361
- var mergeCache = {};
362
- var borderOffset = {};
363
- var bodrder05 = 0.5;
364
- (_d = (_c = this.sheetCtx.hooks).beforeRenderCellArea) === null || _d === void 0 ? void 0 : _d.call(_c, flowdata, renderCtx);
365
- for (var r = rowStart; r <= rowEnd; r += 1) {
366
- var startY = void 0;
367
- if (r === 0) {
368
- startY = -scrollHeight - 1;
369
- } else {
370
- startY = this.sheetCtx.visibledatarow[r - 1] - scrollHeight - 1;
371
- }
372
- var endY = this.sheetCtx.visibledatarow[r] - scrollHeight;
373
- if (((_f = (_e = this.sheetCtx.config) === null || _e === void 0 ? void 0 : _e.rowhidden) === null || _f === void 0 ? void 0 : _f[r]) != null) {
374
- continue;
375
- }
376
- for (var c = colStart; c <= colEnd; c += 1) {
377
- var startX = void 0;
378
- if (c === 0) {
379
- startX = -scrollWidth;
380
- } else {
381
- startX = this.sheetCtx.visibledatacolumn[c - 1] - scrollWidth;
382
- }
383
- var endX = this.sheetCtx.visibledatacolumn[c] - scrollWidth;
384
- if (((_h = (_g = this.sheetCtx.config) === null || _g === void 0 ? void 0 : _g.colhidden) === null || _h === void 0 ? void 0 : _h[c]) != null) {
385
- continue;
386
- }
387
- var firstcolumnlen = this.sheetCtx.defaultcollen;
388
- if ((_k = (_j = this.sheetCtx.config) === null || _j === void 0 ? void 0 : _j.columnlen) === null || _k === void 0 ? void 0 : _k[c]) {
389
- firstcolumnlen = this.sheetCtx.config.columnlen[c];
390
- }
391
- if ((_l = flowdata === null || flowdata === void 0 ? void 0 : flowdata[r]) === null || _l === void 0 ? void 0 : _l[c]) {
392
- var value = flowdata[r][c];
393
- if (value === null || value === void 0 ? void 0 : value.mc) {
394
- borderOffset["".concat(r, "_").concat(c)] = {
395
- startY: startY,
396
- startX: startX,
397
- endY: endY,
398
- endX: endX
399
- };
400
- if ("rs" in value.mc) {
401
- var key = "r".concat(r, "c").concat(c);
402
- mergeCache[key] = cellupdate.length;
403
- } else {
404
- var key = "r".concat(value.mc.r, "c").concat(value.mc.c);
405
- var margeMain = cellupdate[mergeCache[key]];
406
- if (_lodash.default.isNil(margeMain)) {
407
- mergeCache[key] = cellupdate.length;
408
- cellupdate.push({
409
- r: r,
410
- c: c,
411
- startX: startX,
412
- startY: startY,
413
- endY: endY,
414
- endX: endX,
415
- firstcolumnlen: firstcolumnlen
416
- });
417
- } else {
418
- if (margeMain.c === c) {
419
- margeMain.endY += endY - startY - 1;
420
- }
421
- if (margeMain.r === r) {
422
- margeMain.endX += endX - startX;
423
- margeMain.firstcolumnlen += firstcolumnlen;
424
- }
425
- }
426
- continue;
427
- }
428
- }
429
- }
430
- cellupdate.push({
431
- r: r,
432
- c: c,
433
- startY: startY,
434
- startX: startX,
435
- endY: endY,
436
- endX: endX,
437
- firstcolumnlen: firstcolumnlen
438
- });
439
- borderOffset["".concat(r, "_").concat(c)] = {
440
- startY: startY,
441
- startX: startX,
442
- endY: endY,
443
- endX: endX
444
- };
445
- }
446
- }
447
- var dynamicArrayCompute = {};
448
- var afCompute = {};
449
- var cfCompute = (0, _modules.getComputeMap)(this.sheetCtx);
450
- var cellOverflowMap = this.getCellOverflowMap(renderCtx, colStart, colEnd, rowStart, rowEnd);
451
- var mcArr = [];
452
- for (var cud = 0; cud < cellupdate.length; cud += 1) {
453
- var item = cellupdate[cud];
454
- var r = item.r;
455
- var c = item.c;
456
- var startY = item.startY;
457
- var startX = item.startX;
458
- var endY = item.endY;
459
- var endX = item.endX;
460
- if (_lodash.default.isNil(flowdata[r])) {
461
- continue;
462
- }
463
- if (_lodash.default.isNil(flowdata[r][c])) {
464
- this.nullCellRender(r, c, startY, startX, endY, endX, renderCtx, afCompute, cfCompute, offsetLeft, offsetTop, dynamicArrayCompute, cellOverflowMap, colStart, colEnd, scrollHeight, scrollWidth, bodrder05);
465
- } else {
466
- var cell = flowdata[r][c];
467
- var value = null;
468
- if (cell === null || cell === void 0 ? void 0 : cell.mc) {
469
- mcArr.push(cellupdate[cud]);
470
- } else {
471
- value = (0, _cell.getRealCellValue)(r, c, flowdata);
472
- }
473
- if (_lodash.default.isNil(value) || value.toString().length === 0) {
474
- this.nullCellRender(r, c, startY, startX, endY, endX, renderCtx, afCompute, cfCompute, offsetLeft, offsetTop, dynamicArrayCompute, cellOverflowMap, colStart, colEnd, scrollHeight, scrollWidth, bodrder05);
475
- } else {
476
- if ("".concat(r, "_").concat(c) in dynamicArrayCompute) {
477
- value = dynamicArrayCompute["".concat(r, "_").concat(c)].v;
478
- }
479
- this.cellRender(r, c, startY, startX, endY, endX, value, renderCtx, afCompute, cfCompute, offsetLeft, offsetTop, dynamicArrayCompute, cellOverflowMap, colStart, colEnd, scrollHeight, scrollWidth, bodrder05);
480
- }
481
- }
482
- }
483
- for (var m = 0; m < mcArr.length; m += 1) {
484
- var item = mcArr[m];
485
- var r = item.r;
486
- var c = item.c;
487
- var startY = item.startY;
488
- var startX = item.startX;
489
- var endY = item.endY - 1;
490
- var endX = item.endX - 1;
491
- var cell = flowdata[r][c];
492
- if (!cell) continue;
493
- var value = null;
494
- var mergeMaindata = cell.mc;
495
- if (!mergeMaindata) continue;
496
- value = (0, _cell.getRealCellValue)(mergeMaindata.r, mergeMaindata.c, flowdata);
497
- r = mergeMaindata.r;
498
- c = mergeMaindata.c;
499
- var mainCell = flowdata[r][c];
500
- if (!((_m = mainCell === null || mainCell === void 0 ? void 0 : mainCell.mc) === null || _m === void 0 ? void 0 : _m.rs) || !((_o = mainCell.mc) === null || _o === void 0 ? void 0 : _o.cs)) {
501
- continue;
502
- }
503
- if (c === 0) {
504
- startX = -scrollWidth;
505
- } else {
506
- startX = this.sheetCtx.visibledatacolumn[c - 1] - scrollWidth;
507
- }
508
- if (r === 0) {
509
- startY = -scrollHeight - 1;
510
- } else {
511
- startY = this.sheetCtx.visibledatarow[r - 1] - scrollHeight - 1;
512
- }
513
- endY = this.sheetCtx.visibledatarow[r + mainCell.mc.rs - 1] - scrollHeight;
514
- endX = this.sheetCtx.visibledatacolumn[c + mainCell.mc.cs - 1] - scrollWidth;
515
- if (_lodash.default.isNil(value) || value.toString().length === 0) {
516
- this.nullCellRender(r, c, startY, startX, endY, endX, renderCtx, afCompute, cfCompute, offsetLeft, offsetTop, dynamicArrayCompute, cellOverflowMap, colStart, colEnd, scrollHeight, scrollWidth, bodrder05, true);
517
- } else {
518
- if ("".concat(r, "_").concat(c) in dynamicArrayCompute) {
519
- value = dynamicArrayCompute["".concat(r, "_").concat(c)].v;
520
- }
521
- this.cellRender(r, c, startY, startX, endY, endX, value, renderCtx, afCompute, cfCompute, offsetLeft, offsetTop, dynamicArrayCompute, cellOverflowMap, colStart, colEnd, scrollHeight, scrollWidth, bodrder05, true);
522
- }
523
- }
524
- if (((_r = (_q = (_p = this.sheetCtx.config) === null || _p === void 0 ? void 0 : _p.borderInfo) === null || _q === void 0 ? void 0 : _q.length) !== null && _r !== void 0 ? _r : 0) > 0) {
525
- var borderSlashRender_1 = function borderSlashRender_1(style, color, startY, startX, endY, endX, _offsetLeft, _offsetTop, canvas) {
526
- var linetype = style;
527
- var moveX = startX - 2 + bodrder05 + _offsetLeft;
528
- var moveY = startY + _offsetTop;
529
- var toX = endX - 2 + bodrder05 + _offsetLeft;
530
- var toY = endY - 2 + bodrder05 + _offsetTop;
531
- canvas.save();
532
- setLineDash(canvas, linetype, "v", moveX, moveY, toX, toY);
533
- canvas.strokeStyle = color;
534
- canvas.stroke();
535
- canvas.closePath();
536
- canvas.restore();
537
- };
538
- var borderLeftRender_1 = function borderLeftRender_1(style, color, startY, startX, endY, endX, _offsetLeft, _offsetTop, canvas) {
539
- var linetype = style;
540
- var moveX = startX - 2 + bodrder05 + _offsetLeft;
541
- var moveY = startY + _offsetTop - 1;
542
- var toX = startX - 2 + bodrder05 + _offsetLeft;
543
- var toY = endY - 2 + bodrder05 + _offsetTop;
544
- canvas.save();
545
- setLineDash(canvas, linetype, "v", moveX, moveY, toX, toY);
546
- canvas.strokeStyle = color;
547
- canvas.stroke();
548
- canvas.closePath();
549
- canvas.restore();
550
- };
551
- var borderRightRender_1 = function borderRightRender_1(style, color, startY, startX, endY, endX, _offsetLeft, _offsetTop, canvas) {
552
- var linetype = style;
553
- var moveX = endX - 2 + bodrder05 + _offsetLeft;
554
- var moveY = startY + _offsetTop - 1;
555
- var toX = endX - 2 + bodrder05 + _offsetLeft;
556
- var toY = endY - 2 + bodrder05 + _offsetTop;
557
- canvas.save();
558
- setLineDash(canvas, linetype, "v", moveX, moveY, toX, toY);
559
- canvas.strokeStyle = color;
560
- canvas.stroke();
561
- canvas.closePath();
562
- canvas.restore();
563
- };
564
- var borderBottomRender_1 = function borderBottomRender_1(style, color, startY, startX, endY, endX, _offsetLeft, _offsetTop, canvas) {
565
- var linetype = style;
566
- var moveX = startX - 2 + bodrder05 + _offsetLeft;
567
- var moveY = endY - 2 + bodrder05 + _offsetTop;
568
- var toX = endX - 2 + bodrder05 + _offsetLeft;
569
- var toY = endY - 2 + bodrder05 + _offsetTop;
570
- canvas.save();
571
- setLineDash(canvas, linetype, "h", moveX, moveY, toX, toY);
572
- canvas.strokeStyle = color;
573
- canvas.stroke();
574
- canvas.closePath();
575
- canvas.restore();
576
- };
577
- var borderTopRender_1 = function borderTopRender_1(style, color, startY, startX, endY, endX, _offsetLeft, _offsetTop, canvas) {
578
- var linetype = style;
579
- var moveX = startX - 2 + bodrder05 + _offsetLeft;
580
- var moveY = startY - 1 + bodrder05 + _offsetTop;
581
- var toX = endX - 2 + bodrder05 + _offsetLeft;
582
- var toY = startY - 1 + bodrder05 + _offsetTop;
583
- canvas.save();
584
- setLineDash(canvas, linetype, "h", moveX, moveY, toX, toY);
585
- canvas.strokeStyle = color;
586
- canvas.stroke();
587
- canvas.closePath();
588
- canvas.restore();
589
- };
590
- var borderInfoCompute_1 = (0, _border.getBorderInfoComputeRange)(this.sheetCtx, rowStart, rowEnd, colStart, colEnd);
591
- Object.keys(borderInfoCompute_1).forEach(function (x) {
592
- var bdRow = Number(x.substring(0, x.indexOf("_")));
593
- var bdCol = Number(x.substring(x.indexOf("_") + 1));
594
- if (borderOffset["".concat(bdRow, "_").concat(bdCol)]) {
595
- var startY = borderOffset["".concat(bdRow, "_").concat(bdCol)].startY;
596
- var startX = borderOffset["".concat(bdRow, "_").concat(bdCol)].startX;
597
- var endY = borderOffset["".concat(bdRow, "_").concat(bdCol)].endY;
598
- var endX = borderOffset["".concat(bdRow, "_").concat(bdCol)].endX;
599
- var cellOverflow_colInObj = _this.cellOverflow_colIn(cellOverflowMap, bdRow, bdCol, colStart, colEnd);
600
- var borderSlash = borderInfoCompute_1[x].s;
601
- if (borderSlash && (!cellOverflow_colInObj.colIn || cellOverflow_colInObj.stc === bdCol)) {
602
- var mergeMap = _this.sheetCtx.config.merge;
603
- var mergeCell = mergeMap === null || mergeMap === void 0 ? void 0 : mergeMap["".concat(bdRow, "_").concat(bdCol)];
604
- var mergeCellEndX = void 0;
605
- var mergeCellEndY = void 0;
606
- if (mergeCell) {
607
- var mergeCellOffset = borderOffset["".concat(bdRow + mergeCell.rs - 1, "_").concat(bdCol + mergeCell.cs - 1)];
608
- mergeCellEndX = mergeCellOffset.endX;
609
- mergeCellEndY = mergeCellOffset.endY;
610
- }
611
- borderSlashRender_1(borderSlash.style, borderSlash.color, startY, startX, mergeCellEndY !== null && mergeCellEndY !== void 0 ? mergeCellEndY : endY, mergeCellEndX !== null && mergeCellEndX !== void 0 ? mergeCellEndX : endX, offsetLeft, offsetTop, renderCtx);
612
- }
613
- var borderLeft = borderInfoCompute_1[x].l;
614
- if (borderLeft && (!cellOverflow_colInObj.colIn || cellOverflow_colInObj.stc === bdCol)) {
615
- borderLeftRender_1(borderLeft.style, borderLeft.color, startY, startX, endY, endX, offsetLeft, offsetTop, renderCtx);
616
- }
617
- var borderRight = borderInfoCompute_1[x].r;
618
- if (borderRight && (!cellOverflow_colInObj.colIn || cellOverflow_colInObj.colLast)) {
619
- borderRightRender_1(borderRight.style, borderRight.color, startY, startX, endY, endX, offsetLeft, offsetTop, renderCtx);
620
- }
621
- var borderTop = borderInfoCompute_1[x].t;
622
- if (borderTop) {
623
- borderTopRender_1(borderTop.style, borderTop.color, startY, startX, endY, endX, offsetLeft, offsetTop, renderCtx);
624
- }
625
- var borderBottom = borderInfoCompute_1[x].b;
626
- if (borderBottom) {
627
- borderBottomRender_1(borderBottom.style, borderBottom.color, startY, startX, endY, endX, offsetLeft, offsetTop, renderCtx);
628
- }
629
- }
630
- });
631
- }
632
- if (colEnd === this.sheetCtx.visibledatacolumn.length - 1) {
633
- renderCtx.clearRect(colEndX - scrollWidth + offsetLeft - 1, offsetTop - 1, this.sheetCtx.ch_width - this.sheetCtx.visibledatacolumn[colEnd], rowEndY - scrollHeight);
634
- }
635
- renderCtx.restore();
636
- this.measureTextCacheTimeOut = setTimeout(function () {
637
- (0, _text.clearMeasureTextCache)();
638
- _this.cellOverflowMapCache = {};
639
- }, 100);
640
- };
641
- Canvas.prototype.getCellOverflowMap = function (canvas, colStart, colEnd, rowStart, rowEnd) {
642
- var _a, _b;
643
- var flowdata = (0, _context.getFlowdata)(this.sheetCtx);
644
- var map = {};
645
- var data = flowdata;
646
- if (!data) {
647
- return map;
648
- }
649
- for (var r = rowStart; r <= rowEnd; r += 1) {
650
- if (_lodash.default.isNil(data[r])) {
651
- continue;
652
- }
653
- if (this.cellOverflowMapCache[r]) {
654
- map[r] = this.cellOverflowMapCache[r];
655
- continue;
656
- }
657
- var hasCellOver = false;
658
- for (var c = 0; c < data[r].length; c += 1) {
659
- var cell = data[r][c];
660
- if (((_b = (_a = this.sheetCtx.config) === null || _a === void 0 ? void 0 : _a.colhidden) === null || _b === void 0 ? void 0 : _b[c]) != null) {
661
- continue;
662
- }
663
- if (cell && (!_lodash.default.isEmpty(cell.v) || (0, _inlineString.isInlineStringCell)(cell)) && _lodash.default.isNil(cell.mc) && cell.tb === "1") {
664
- var horizonAlign = (0, _cell.normalizedAttr)(data, r, c, "ht");
665
- var textMetricsObj = (0, _text.getCellTextInfo)(cell, canvas, this.sheetCtx, {
666
- r: r,
667
- c: c
668
- });
669
- var textMetrics = 0;
670
- if (textMetricsObj) {
671
- textMetrics = textMetricsObj.textWidthAll;
672
- }
673
- var startX = c - 1 < 0 ? 0 : this.sheetCtx.visibledatacolumn[c - 1];
674
- var endX = this.sheetCtx.visibledatacolumn[c];
675
- var stc = void 0;
676
- var edc = void 0;
677
- if (endX - startX < textMetrics) {
678
- if (horizonAlign === "0") {
679
- var trace_forward = this.cellOverflow_trace(r, c, c - 1, "forward", horizonAlign, textMetrics);
680
- var trace_backward = this.cellOverflow_trace(r, c, c + 1, "backward", horizonAlign, textMetrics);
681
- if (trace_forward.success) {
682
- stc = trace_forward.c;
683
- } else {
684
- stc = trace_forward.c + 1;
685
- }
686
- if (trace_backward.success) {
687
- edc = trace_backward.c;
688
- } else {
689
- edc = trace_backward.c - 1;
690
- }
691
- } else if (horizonAlign === "1") {
692
- var trace = this.cellOverflow_trace(r, c, c + 1, "backward", horizonAlign, textMetrics);
693
- stc = c;
694
- if (trace.success) {
695
- edc = trace.c;
696
- } else {
697
- edc = trace.c - 1;
698
- }
699
- } else if (horizonAlign === "2") {
700
- var trace = this.cellOverflow_trace(r, c, c - 1, "forward", horizonAlign, textMetrics);
701
- edc = c;
702
- if (trace.success) {
703
- stc = trace.c;
704
- } else {
705
- stc = trace.c + 1;
706
- }
707
- }
708
- } else {
709
- stc = c;
710
- edc = c;
711
- }
712
- if ((stc <= colEnd || edc >= colStart) && stc < edc) {
713
- var item = {
714
- r: r,
715
- stc: stc,
716
- edc: edc
717
- };
718
- if (_lodash.default.isNil(map[r])) {
719
- map[r] = {};
720
- }
721
- map[r][c] = item;
722
- hasCellOver = true;
723
- }
724
- }
725
- }
726
- if (hasCellOver) {
727
- this.cellOverflowMapCache[r] = map[r];
728
- }
729
- }
730
- return map;
731
- };
732
- Canvas.prototype.nullCellRender = function (r, c, startY, startX, endY, endX, renderCtx, afCompute, cfCompute, offsetLeft, offsetTop, dynamicArrayCompute, cellOverflowMap, colStart, colEnd, scrollHeight, scrollWidth, bodrder05, isMerge) {
733
- var _a, _b, _c, _d, _e, _f;
734
- if (isMerge === void 0) {
735
- isMerge = false;
736
- }
737
- var checksCF = (0, _modules.checkCF)(r, c, cfCompute);
738
- var flowdata = (0, _context.getFlowdata)(this.sheetCtx);
739
- if (!flowdata) return;
740
- var borderfix = getBorderFix();
741
- var fillStyle = (0, _cell.normalizedAttr)(flowdata, r, c, "bg");
742
- if (!_lodash.default.isNil(checksCF) && !_lodash.default.isNil(checksCF.cellColor)) {
743
- fillStyle = checksCF.cellColor;
744
- }
745
- if (!fillStyle) {
746
- renderCtx.fillStyle = "#FFFFFF";
747
- } else {
748
- renderCtx.fillStyle = fillStyle;
749
- }
750
- var cellsize = [startX + offsetLeft + borderfix[0], startY + offsetTop + borderfix[1], endX - startX + borderfix[2] - (isMerge ? 1 : 0), endY - startY + borderfix[3]];
751
- if (((_b = (_a = this.sheetCtx.hooks).beforeRenderCell) === null || _b === void 0 ? void 0 : _b.call(_a, flowdata[r][c], {
752
- row: r,
753
- column: c,
754
- startX: cellsize[0],
755
- startY: cellsize[1],
756
- endX: cellsize[2] + cellsize[0],
757
- endY: cellsize[3] + cellsize[1]
758
- }, renderCtx)) === false) {
759
- return;
760
- }
761
- renderCtx.fillRect(cellsize[0], cellsize[1], cellsize[2], cellsize[3]);
762
- if ("".concat(r, "_").concat(c) in dynamicArrayCompute) {
763
- var value = dynamicArrayCompute["".concat(r, "_").concat(c)].v;
764
- renderCtx.fillStyle = "#000000";
765
- var fontset = (0, _text.defaultFont)(this.sheetCtx.defaultFontSize);
766
- renderCtx.font = fontset;
767
- var horizonAlignPos = startX + 4 + offsetLeft;
768
- var verticalAlignPos = endY + offsetTop - 2;
769
- renderCtx.textBaseline = "bottom";
770
- renderCtx.fillText(_lodash.default.isNil(value) ? "" : value, horizonAlignPos, verticalAlignPos);
771
- }
772
- if ((_d = (_c = flowdata === null || flowdata === void 0 ? void 0 : flowdata[r]) === null || _c === void 0 ? void 0 : _c[c]) === null || _d === void 0 ? void 0 : _d.ps) {
773
- var ps_w = 12 * this.sheetCtx.zoomRatio;
774
- var ps_h = 12 * this.sheetCtx.zoomRatio;
775
- renderCtx.beginPath();
776
- renderCtx.moveTo(endX + offsetLeft - 1 - ps_w, startY + offsetTop);
777
- renderCtx.lineTo(endX + offsetLeft - 1, startY + offsetTop);
778
- renderCtx.lineTo(endX + offsetLeft - 1, startY + offsetTop + ps_h);
779
- renderCtx.fillStyle = "#EFC703";
780
- renderCtx.fill();
781
- renderCtx.closePath();
782
- }
783
- var cellOverflow_colInObj = this.cellOverflow_colIn(cellOverflowMap, r, c, colStart, colEnd);
784
- if (cellOverflow_colInObj.colLast && !_lodash.default.isNil(cellOverflow_colInObj.rowIndex) && !_lodash.default.isNil(cellOverflow_colInObj.colIndex) && !_lodash.default.isNil(cellOverflow_colInObj.stc) && !_lodash.default.isNil(cellOverflow_colInObj.edc)) {
785
- this.cellOverflowRender(cellOverflow_colInObj.rowIndex, cellOverflow_colInObj.colIndex, cellOverflow_colInObj.stc, cellOverflow_colInObj.edc, renderCtx, scrollHeight, scrollWidth, offsetLeft, offsetTop, afCompute, cfCompute);
786
- }
787
- if (!cellOverflow_colInObj.colIn || cellOverflow_colInObj.colLast) {
788
- if (!this.sheetCtx.luckysheetcurrentisPivotTable && this.sheetCtx.showGridLines) {
789
- renderCtx.beginPath();
790
- renderCtx.moveTo(endX + offsetLeft - 2 + bodrder05, startY + offsetTop);
791
- renderCtx.lineTo(endX + offsetLeft - 2 + bodrder05, endY + offsetTop);
792
- renderCtx.lineWidth = 1;
793
- renderCtx.strokeStyle = defaultStyle.strokeStyle;
794
- renderCtx.stroke();
795
- renderCtx.closePath();
796
- }
797
- }
798
- if (!this.sheetCtx.luckysheetcurrentisPivotTable && this.sheetCtx.showGridLines) {
799
- renderCtx.beginPath();
800
- renderCtx.moveTo(startX + offsetLeft - 1, endY + offsetTop - 2 + bodrder05);
801
- renderCtx.lineTo(endX + offsetLeft - 1, endY + offsetTop - 2 + bodrder05);
802
- renderCtx.lineWidth = 1;
803
- renderCtx.strokeStyle = defaultStyle.strokeStyle;
804
- renderCtx.stroke();
805
- renderCtx.closePath();
806
- }
807
- (_f = (_e = this.sheetCtx.hooks).afterRenderCell) === null || _f === void 0 ? void 0 : _f.call(_e, flowdata[r][c], {
808
- row: r,
809
- column: c,
810
- startY: cellsize[1],
811
- startX: cellsize[0],
812
- endY: cellsize[3] + cellsize[1],
813
- endX: cellsize[2] + cellsize[0]
814
- }, renderCtx);
815
- };
816
- Canvas.prototype.cellRender = function (r, c, startY, startX, endY, endX, value, renderCtx, afCompute, cfCompute, offsetLeft, offsetTop, dynamicArrayCompute, cellOverflowMap, colStart, colEnd, scrollHeight, scrollWidth, bodrder05, isMerge) {
817
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
818
- if (isMerge === void 0) {
819
- isMerge = false;
820
- }
821
- var flowdata = (0, _context.getFlowdata)(this.sheetCtx);
822
- if (!flowdata) {
823
- return;
824
- }
825
- var cell = flowdata[r][c];
826
- var cellWidth = endX - startX - 2;
827
- var cellHeight = endY - startY - 2;
828
- var space_width = 2;
829
- var space_height = 2;
830
- var horizonAlign = Number((0, _cell.normalizedAttr)(flowdata, r, c, "ht"));
831
- var verticalAlign = Number((0, _cell.normalizedAttr)(flowdata, r, c, "vt"));
832
- var checksAF = {};
833
- var checksCF = (0, _modules.checkCF)(r, c, cfCompute);
834
- var fillStyle = (0, _cell.normalizedAttr)(flowdata, r, c, "bg");
835
- if (!_lodash.default.isNil(checksCF) && !_lodash.default.isNil(checksCF.cellColor)) {
836
- fillStyle = checksCF.cellColor;
837
- }
838
- if (!fillStyle) {
839
- renderCtx.fillStyle = "#FFFFFF";
840
- } else {
841
- renderCtx.fillStyle = fillStyle;
842
- }
843
- var borderfix = getBorderFix();
844
- var cellsize = [startX + offsetLeft + borderfix[0], startY + offsetTop + borderfix[1], endX - startX + borderfix[2] - (isMerge ? 1 : 0), endY - startY + borderfix[3]];
845
- if (((_b = (_a = this.sheetCtx.hooks).beforeRenderCell) === null || _b === void 0 ? void 0 : _b.call(_a, flowdata[r][c], {
846
- row: r,
847
- column: c,
848
- startY: cellsize[1],
849
- startX: cellsize[0],
850
- endY: cellsize[3] + cellsize[1],
851
- endX: cellsize[2] + cellsize[0]
852
- }, renderCtx)) === false) {
853
- return;
854
- }
855
- renderCtx.fillRect(cellsize[0], cellsize[1], cellsize[2], cellsize[3]);
856
- var index = (0, _utils.getSheetIndex)(this.sheetCtx, this.sheetCtx.currentSheetId);
857
- var dataVerification = this.sheetCtx.luckysheetfile[index].dataVerification;
858
- if ((dataVerification === null || dataVerification === void 0 ? void 0 : dataVerification["".concat(r, "_").concat(c)]) && !(0, _modules.validateCellData)(this.sheetCtx, dataVerification["".concat(r, "_").concat(c)], value)) {
859
- var dv_w = 9 * this.sheetCtx.zoomRatio;
860
- var dv_h = 9 * this.sheetCtx.zoomRatio;
861
- renderCtx.beginPath();
862
- renderCtx.moveTo(startX + offsetLeft, startY + offsetTop);
863
- renderCtx.lineTo(startX + offsetLeft + dv_w, startY + offsetTop);
864
- renderCtx.lineTo(startX + offsetLeft, startY + offsetTop + dv_h);
865
- renderCtx.fillStyle = "#EFC703";
866
- renderCtx.fill();
867
- renderCtx.closePath();
868
- }
869
- if (cell === null || cell === void 0 ? void 0 : cell.ps) {
870
- var ps_w = 12 * this.sheetCtx.zoomRatio;
871
- var ps_h = 12 * this.sheetCtx.zoomRatio;
872
- renderCtx.beginPath();
873
- renderCtx.moveTo(endX + offsetLeft - ps_w, startY + offsetTop);
874
- renderCtx.lineTo(endX + offsetLeft, startY + offsetTop);
875
- renderCtx.lineTo(endX + offsetLeft, startY + offsetTop + ps_h);
876
- renderCtx.fillStyle = "#EFC703";
877
- renderCtx.fill();
878
- renderCtx.closePath();
879
- }
880
- if ((cell === null || cell === void 0 ? void 0 : cell.qp) === 1 && isRealNum(cell === null || cell === void 0 ? void 0 : cell.v)) {
881
- var ps_w = 10 * this.sheetCtx.zoomRatio;
882
- var ps_h = 10 * this.sheetCtx.zoomRatio;
883
- renderCtx.beginPath();
884
- renderCtx.moveTo(startX + offsetLeft + ps_w - 1, startY + offsetTop);
885
- renderCtx.lineTo(startX + offsetLeft - 1, startY + offsetTop);
886
- renderCtx.lineTo(startX + offsetLeft - 1, startY + offsetTop + ps_h);
887
- renderCtx.fillStyle = "#487f1e";
888
- renderCtx.fill();
889
- renderCtx.closePath();
890
- }
891
- var cellOverflow_bd_r_render = true;
892
- var cellOverflow_colInObj = this.cellOverflow_colIn(cellOverflowMap, r, c, colStart, colEnd);
893
- if ((cell === null || cell === void 0 ? void 0 : cell.tb) === "1" && cellOverflow_colInObj.colIn) {
894
- if (cellOverflow_colInObj.colLast && !_lodash.default.isNil(cellOverflow_colInObj.rowIndex) && !_lodash.default.isNil(cellOverflow_colInObj.colIndex) && !_lodash.default.isNil(cellOverflow_colInObj.stc) && !_lodash.default.isNil(cellOverflow_colInObj.edc)) {
895
- this.cellOverflowRender(cellOverflow_colInObj.rowIndex, cellOverflow_colInObj.colIndex, cellOverflow_colInObj.stc, cellOverflow_colInObj.edc, renderCtx, scrollHeight, scrollWidth, offsetLeft, offsetTop, afCompute, cfCompute);
896
- } else {
897
- cellOverflow_bd_r_render = false;
898
- }
899
- } else if (((_c = dataVerification === null || dataVerification === void 0 ? void 0 : dataVerification["".concat(r, "_").concat(c)]) === null || _c === void 0 ? void 0 : _c.type) === "checkbox") {
900
- var pos_x = startX + offsetLeft;
901
- var pos_y = startY + offsetTop + 1;
902
- renderCtx.save();
903
- renderCtx.beginPath();
904
- renderCtx.rect(pos_x, pos_y, cellWidth, cellHeight);
905
- renderCtx.clip();
906
- renderCtx.scale(this.sheetCtx.zoomRatio, this.sheetCtx.zoomRatio);
907
- var measureText = (0, _text.getMeasureText)(value, renderCtx, this.sheetCtx);
908
- var textMetrics = measureText.width + 14;
909
- var oneLineTextHeight = measureText.actualBoundingBoxDescent + measureText.actualBoundingBoxAscent;
910
- var horizonAlignPos = pos_x + space_width;
911
- if (horizonAlign === 0) {
912
- horizonAlignPos = pos_x + cellWidth / 2 - textMetrics / 2;
913
- } else if (horizonAlign === 2) {
914
- horizonAlignPos = pos_x + cellWidth - space_width - textMetrics;
915
- }
916
- var verticalCellHeight = cellHeight > oneLineTextHeight ? cellHeight : oneLineTextHeight;
917
- var verticalAlignPos_text = pos_y + verticalCellHeight - space_height;
918
- renderCtx.textBaseline = "bottom";
919
- var verticalAlignPos_checkbox = verticalAlignPos_text - 13 * this.sheetCtx.zoomRatio;
920
- if (verticalAlign === 0) {
921
- verticalAlignPos_text = pos_y + verticalCellHeight / 2;
922
- renderCtx.textBaseline = "middle";
923
- verticalAlignPos_checkbox = verticalAlignPos_text - 6 * this.sheetCtx.zoomRatio;
924
- } else if (verticalAlign === 1) {
925
- verticalAlignPos_text = pos_y + space_height;
926
- renderCtx.textBaseline = "top";
927
- verticalAlignPos_checkbox = verticalAlignPos_text + 1 * this.sheetCtx.zoomRatio;
928
- }
929
- horizonAlignPos /= this.sheetCtx.zoomRatio;
930
- verticalAlignPos_text /= this.sheetCtx.zoomRatio;
931
- verticalAlignPos_checkbox /= this.sheetCtx.zoomRatio;
932
- renderCtx.lineWidth = 2;
933
- renderCtx.strokeStyle = "#000";
934
- renderCtx.beginPath();
935
- renderCtx.roundRect(horizonAlignPos, verticalAlignPos_checkbox, 12, 12, 2);
936
- renderCtx.stroke();
937
- if (dataVerification["".concat(r, "_").concat(c)].checked) {
938
- renderCtx.save();
939
- renderCtx.beginPath();
940
- renderCtx.roundRect(horizonAlignPos, verticalAlignPos_checkbox, 12, 12, 2);
941
- renderCtx.fillStyle = "#000";
942
- renderCtx.fill();
943
- renderCtx.restore();
944
- renderCtx.save();
945
- renderCtx.beginPath();
946
- renderCtx.strokeStyle = "#fff";
947
- renderCtx.lineWidth = 2;
948
- renderCtx.lineJoin = "round";
949
- renderCtx.moveTo(horizonAlignPos + 3, verticalAlignPos_checkbox + 6);
950
- renderCtx.lineTo(horizonAlignPos + 5.5, verticalAlignPos_checkbox + 9);
951
- renderCtx.lineTo(horizonAlignPos + 9, verticalAlignPos_checkbox + 3.5);
952
- renderCtx.stroke();
953
- renderCtx.closePath();
954
- renderCtx.restore();
955
- }
956
- renderCtx.fillStyle = (0, _cell.normalizedAttr)(flowdata, r, c, "fc");
957
- renderCtx.fillText(_lodash.default.isNil(value) ? "" : value, horizonAlignPos + 18, verticalAlignPos_text);
958
- renderCtx.restore();
959
- } else {
960
- if (((_d = checksCF === null || checksCF === void 0 ? void 0 : checksCF.dataBar) === null || _d === void 0 ? void 0 : _d.valueLen) && ((_f = (_e = checksCF === null || checksCF === void 0 ? void 0 : checksCF.dataBar) === null || _e === void 0 ? void 0 : _e.valueLen) === null || _f === void 0 ? void 0 : _f.toString()) !== "NaN") {
961
- var x = startX + offsetLeft + space_width;
962
- var y = startY + offsetTop + space_height;
963
- var w = cellWidth - space_width * 2;
964
- var h = cellHeight - space_height * 2;
965
- var valueType = checksCF.dataBar.valueType;
966
- var valueLen = checksCF.dataBar.valueLen;
967
- var format = checksCF.dataBar.format;
968
- if (valueType === "minus") {
969
- var minusLen = checksCF.dataBar.minusLen;
970
- if (format.length > 1) {
971
- var my_gradient = renderCtx.createLinearGradient(x + w * minusLen * (1 - valueLen), y, x + w * minusLen, y);
972
- my_gradient.addColorStop(0, "#ffffff");
973
- my_gradient.addColorStop(1, "#ff0000");
974
- renderCtx.fillStyle = my_gradient;
975
- } else {
976
- renderCtx.fillStyle = "#ff0000";
977
- }
978
- renderCtx.fillRect(x + w * minusLen * (1 - valueLen), y, w * minusLen * valueLen, h);
979
- renderCtx.beginPath();
980
- renderCtx.moveTo(x + w * minusLen * (1 - valueLen), y);
981
- renderCtx.lineTo(x + w * minusLen * (1 - valueLen), y + h);
982
- renderCtx.lineTo(x + w * minusLen, y + h);
983
- renderCtx.lineTo(x + w * minusLen, y);
984
- renderCtx.lineTo(x + w * minusLen * (1 - valueLen), y);
985
- renderCtx.lineWidth = 1;
986
- renderCtx.strokeStyle = "#ff0000";
987
- renderCtx.stroke();
988
- renderCtx.closePath();
989
- } else if (valueType === "plus") {
990
- var plusLen = checksCF.dataBar.plusLen;
991
- if (plusLen === 1) {
992
- if (format.length > 1) {
993
- var my_gradient = renderCtx.createLinearGradient(x, y, x + w * valueLen, y);
994
- my_gradient.addColorStop(0, format[0]);
995
- my_gradient.addColorStop(1, format[1]);
996
- renderCtx.fillStyle = my_gradient;
997
- } else {
998
- renderCtx.fillStyle = format[0];
999
- }
1000
- renderCtx.fillRect(x, y, w * valueLen, h);
1001
- renderCtx.beginPath();
1002
- renderCtx.moveTo(x, y);
1003
- renderCtx.lineTo(x, y + h);
1004
- renderCtx.lineTo(x + w * valueLen, y + h);
1005
- renderCtx.lineTo(x + w * valueLen, y);
1006
- renderCtx.lineTo(x, y);
1007
- renderCtx.lineWidth = 1;
1008
- renderCtx.strokeStyle = format[0];
1009
- renderCtx.stroke();
1010
- renderCtx.closePath();
1011
- } else {
1012
- var minusLen = checksCF.dataBar.minusLen;
1013
- if (format.length > 1) {
1014
- var my_gradient = renderCtx.createLinearGradient(x + w * minusLen, y, x + w * minusLen + w * plusLen * valueLen, y);
1015
- my_gradient.addColorStop(0, format[0]);
1016
- my_gradient.addColorStop(1, format[1]);
1017
- renderCtx.fillStyle = my_gradient;
1018
- } else {
1019
- renderCtx.fillStyle = format[0];
1020
- }
1021
- renderCtx.fillRect(x + w * minusLen, y, w * plusLen * valueLen, h);
1022
- renderCtx.beginPath();
1023
- renderCtx.moveTo(x + w * minusLen, y);
1024
- renderCtx.lineTo(x + w * minusLen, y + h);
1025
- renderCtx.lineTo(x + w * minusLen + w * plusLen * valueLen, y + h);
1026
- renderCtx.lineTo(x + w * minusLen + w * plusLen * valueLen, y);
1027
- renderCtx.lineTo(x + w * minusLen, y);
1028
- renderCtx.lineWidth = 1;
1029
- renderCtx.strokeStyle = format[0];
1030
- renderCtx.stroke();
1031
- renderCtx.closePath();
1032
- }
1033
- }
1034
- }
1035
- var pos_x = startX + offsetLeft;
1036
- var pos_y = startY + offsetTop + 1;
1037
- renderCtx.save();
1038
- renderCtx.beginPath();
1039
- renderCtx.rect(pos_x, pos_y, cellWidth, cellHeight);
1040
- renderCtx.clip();
1041
- renderCtx.scale(this.sheetCtx.zoomRatio, this.sheetCtx.zoomRatio);
1042
- var textInfo = cell ? (0, _text.getCellTextInfo)(cell, renderCtx, this.sheetCtx, {
1043
- cellWidth: cellWidth,
1044
- cellHeight: cellHeight,
1045
- space_width: space_width,
1046
- space_height: space_height,
1047
- r: r,
1048
- c: c
1049
- }, this.sheetCtx) : undefined;
1050
- if ((checksCF === null || checksCF === void 0 ? void 0 : checksCF.icons) && textInfo.type === "plain") {
1051
- var l = checksCF.icons.left;
1052
- var t = checksCF.icons.top;
1053
- var _value = textInfo.values[0];
1054
- var verticalAlignPos = pos_y + _value.top - textInfo.textHeightAll;
1055
- if (verticalAlign === 0) {
1056
- verticalAlignPos = pos_y + cellHeight / 2 - textInfo.textHeightAll / 2;
1057
- } else if (verticalAlign === 1) {
1058
- verticalAlignPos = pos_y;
1059
- } else if (verticalAlign === 2) {
1060
- verticalAlignPos -= textInfo.desc;
1061
- }
1062
- verticalAlignPos /= this.sheetCtx.zoomRatio;
1063
- renderCtx.drawImage(getCfIconsImg(), l * 42, t * 32, 32, 32, pos_x / this.sheetCtx.zoomRatio, verticalAlignPos, textInfo.textHeightAll / this.sheetCtx.zoomRatio, textInfo.textHeightAll / this.sheetCtx.zoomRatio);
1064
- }
1065
- renderCtx.fillStyle = (0, _cell.normalizedAttr)(flowdata, r, c, "fc");
1066
- if (checksAF === null || checksAF === void 0 ? void 0 : checksAF[0]) {
1067
- renderCtx.fillStyle = checksAF[0];
1068
- }
1069
- if (checksCF === null || checksCF === void 0 ? void 0 : checksCF.textColor) {
1070
- renderCtx.fillStyle = checksCF.textColor;
1071
- }
1072
- if (((_j = (_h = (_g = cell === null || cell === void 0 ? void 0 : cell.ct) === null || _g === void 0 ? void 0 : _g.fa) === null || _h === void 0 ? void 0 : _h.indexOf("[Red]")) !== null && _j !== void 0 ? _j : -1) > -1 && ((_k = cell === null || cell === void 0 ? void 0 : cell.ct) === null || _k === void 0 ? void 0 : _k.t) === "n" && (cell === null || cell === void 0 ? void 0 : cell.v) < 0) {
1073
- renderCtx.fillStyle = "#ff0000";
1074
- }
1075
- this.cellTextRender(textInfo, renderCtx, {
1076
- pos_x: pos_x,
1077
- pos_y: pos_y
1078
- });
1079
- renderCtx.restore();
1080
- }
1081
- if (cellOverflow_bd_r_render) {
1082
- if (!this.sheetCtx.luckysheetcurrentisPivotTable && this.sheetCtx.showGridLines) {
1083
- renderCtx.beginPath();
1084
- renderCtx.moveTo(endX + offsetLeft - 2 + bodrder05, startY + offsetTop);
1085
- renderCtx.lineTo(endX + offsetLeft - 2 + bodrder05, endY + offsetTop);
1086
- renderCtx.lineWidth = 1;
1087
- renderCtx.strokeStyle = defaultStyle.strokeStyle;
1088
- renderCtx.stroke();
1089
- renderCtx.closePath();
1090
- }
1091
- }
1092
- if (!this.sheetCtx.luckysheetcurrentisPivotTable && this.sheetCtx.showGridLines) {
1093
- renderCtx.beginPath();
1094
- renderCtx.moveTo(startX + offsetLeft - 1, endY + offsetTop - 2 + bodrder05);
1095
- renderCtx.lineTo(endX + offsetLeft - 1, endY + offsetTop - 2 + bodrder05);
1096
- renderCtx.lineWidth = 1;
1097
- renderCtx.strokeStyle = defaultStyle.strokeStyle;
1098
- renderCtx.stroke();
1099
- renderCtx.closePath();
1100
- }
1101
- (_m = (_l = this.sheetCtx.hooks).afterRenderCell) === null || _m === void 0 ? void 0 : _m.call(_l, (_o = flowdata[r]) === null || _o === void 0 ? void 0 : _o[c], {
1102
- row: r,
1103
- column: c,
1104
- startX: cellsize[0],
1105
- startY: cellsize[1],
1106
- endX: cellsize[2] + cellsize[0],
1107
- endY: cellsize[3] + cellsize[1]
1108
- }, renderCtx);
1109
- };
1110
- Canvas.prototype.cellOverflowRender = function (r, c, stc, edc, renderCtx, scrollHeight, scrollWidth, offsetLeft, offsetTop, afCompute, cfCompute) {
1111
- var startY;
1112
- if (r === 0) {
1113
- startY = -scrollHeight - 1;
1114
- } else {
1115
- startY = this.sheetCtx.visibledatarow[r - 1] - scrollHeight - 1;
1116
- }
1117
- var endY = this.sheetCtx.visibledatarow[r] - scrollHeight;
1118
- var startX;
1119
- if (stc === 0) {
1120
- startX = -scrollWidth;
1121
- } else {
1122
- startX = this.sheetCtx.visibledatacolumn[stc - 1] - scrollWidth;
1123
- }
1124
- var endX = this.sheetCtx.visibledatacolumn[edc] - scrollWidth;
1125
- var flowdata = (0, _context.getFlowdata)(this.sheetCtx);
1126
- if (!flowdata) {
1127
- return;
1128
- }
1129
- var cell = flowdata[r][c];
1130
- var cellWidth = endX - startX - 2;
1131
- var cellHeight = endY - startY - 2;
1132
- var space_width = 2;
1133
- var space_height = 2;
1134
- var pos_x = startX + offsetLeft;
1135
- var pos_y = startY + offsetTop + 1;
1136
- var fontset = (0, _text.getFontSet)(cell, this.sheetCtx.defaultFontSize, this.sheetCtx);
1137
- renderCtx.font = fontset;
1138
- renderCtx.save();
1139
- renderCtx.beginPath();
1140
- renderCtx.rect(pos_x, pos_y, cellWidth, cellHeight);
1141
- renderCtx.clip();
1142
- renderCtx.scale(this.sheetCtx.zoomRatio, this.sheetCtx.zoomRatio);
1143
- var textInfo = cell ? (0, _text.getCellTextInfo)(cell, renderCtx, this.sheetCtx, {
1144
- cellWidth: cellWidth,
1145
- cellHeight: cellHeight,
1146
- space_width: space_width,
1147
- space_height: space_height,
1148
- r: r,
1149
- c: c
1150
- }, this.sheetCtx) : undefined;
1151
- var checksAF = {};
1152
- var checksCF = (0, _modules.checkCF)(r, c, cfCompute);
1153
- renderCtx.fillStyle = (0, _cell.normalizedAttr)(flowdata, r, c, "fc");
1154
- if (checksAF === null || checksAF === void 0 ? void 0 : checksAF[0]) {
1155
- renderCtx.fillStyle = checksAF[0];
1156
- }
1157
- if (checksCF === null || checksCF === void 0 ? void 0 : checksCF.textColor) {
1158
- renderCtx.fillStyle = checksCF.textColor;
1159
- }
1160
- this.cellTextRender(textInfo, renderCtx, {
1161
- pos_x: pos_x,
1162
- pos_y: pos_y
1163
- });
1164
- renderCtx.restore();
1165
- };
1166
- Canvas.prototype.cellOverflow_trace = function (r, curC, traceC, traceDir, horizonAlign, textMetrics) {
1167
- var flowdata = (0, _context.getFlowdata)(this.sheetCtx);
1168
- if (!flowdata) return {};
1169
- var data = flowdata;
1170
- if (traceDir === "forward" && traceC < 0) {
1171
- return {
1172
- success: false,
1173
- r: r,
1174
- c: traceC
1175
- };
1176
- }
1177
- if (traceDir === "backward" && traceC > data[r].length - 1) {
1178
- return {
1179
- success: false,
1180
- r: r,
1181
- c: traceC
1182
- };
1183
- }
1184
- var cell = data[r][traceC];
1185
- if (cell && (!_lodash.default.isEmpty(cell.v) || cell.mc)) {
1186
- return {
1187
- success: false,
1188
- r: r,
1189
- c: traceC
1190
- };
1191
- }
1192
- var start_curC = curC - 1 < 0 ? 0 : this.sheetCtx.visibledatacolumn[curC - 1];
1193
- var end_curC = this.sheetCtx.visibledatacolumn[curC];
1194
- var w = textMetrics - (end_curC - start_curC);
1195
- if (horizonAlign === "0") {
1196
- start_curC -= w / 2;
1197
- end_curC += w / 2;
1198
- } else if (horizonAlign === "1") {
1199
- end_curC += w;
1200
- } else if (horizonAlign === "2") {
1201
- start_curC -= w;
1202
- }
1203
- var start_traceC = traceC - 1 < 0 ? 0 : this.sheetCtx.visibledatacolumn[traceC - 1];
1204
- var end_traceC = this.sheetCtx.visibledatacolumn[traceC];
1205
- if (traceDir === "forward") {
1206
- if (start_curC < start_traceC) {
1207
- return this.cellOverflow_trace(r, curC, traceC - 1, traceDir, horizonAlign, textMetrics);
1208
- }
1209
- if (start_curC < end_traceC) {
1210
- return {
1211
- success: true,
1212
- r: r,
1213
- c: traceC
1214
- };
1215
- }
1216
- return {
1217
- success: false,
1218
- r: r,
1219
- c: traceC
1220
- };
1221
- }
1222
- if (traceDir === "backward") {
1223
- if (end_curC > end_traceC) {
1224
- return this.cellOverflow_trace(r, curC, traceC + 1, traceDir, horizonAlign, textMetrics);
1225
- }
1226
- if (end_curC > start_traceC) {
1227
- return {
1228
- success: true,
1229
- r: r,
1230
- c: traceC
1231
- };
1232
- }
1233
- return {
1234
- success: false,
1235
- r: r,
1236
- c: traceC
1237
- };
1238
- }
1239
- return null;
1240
- };
1241
- Canvas.prototype.cellOverflow_colIn = function (map, r, c, col_st, col_ed) {
1242
- var colIn = false;
1243
- var colLast = false;
1244
- var rowIndex;
1245
- var colIndex;
1246
- var stc;
1247
- var edc;
1248
- _lodash.default.forEach(map, function (row, rkey) {
1249
- _lodash.default.forEach(row, function (mapItem, ckey) {
1250
- rowIndex = Number(rkey);
1251
- colIndex = Number(ckey);
1252
- stc = mapItem.stc;
1253
- edc = mapItem.edc;
1254
- if (rowIndex === r) {
1255
- if (c >= stc && c <= edc) {
1256
- colIn = true;
1257
- if (c === edc || c === col_ed) {
1258
- colLast = true;
1259
- return false;
1260
- }
1261
- }
1262
- }
1263
- return true;
1264
- });
1265
- return !colLast;
1266
- });
1267
- return {
1268
- colIn: colIn,
1269
- colLast: colLast,
1270
- rowIndex: rowIndex,
1271
- colIndex: colIndex,
1272
- stc: stc,
1273
- edc: edc
1274
- };
1275
- };
1276
- Canvas.prototype.cellTextRender = function (textInfo, ctx, option) {
1277
- if (!textInfo) {
1278
- return;
1279
- }
1280
- var values = textInfo.values;
1281
- var pos_x = option.pos_x;
1282
- var pos_y = option.pos_y;
1283
- if (!values) {
1284
- return;
1285
- }
1286
- if (textInfo.rotate !== 0 && textInfo.type !== "verticalWrap") {
1287
- ctx.save();
1288
- ctx.translate((pos_x + textInfo.textLeftAll) / this.sheetCtx.zoomRatio, (pos_y + textInfo.textTopAll) / this.sheetCtx.zoomRatio);
1289
- ctx.rotate(-textInfo.rotate * Math.PI / 180);
1290
- ctx.translate(-(textInfo.textLeftAll + pos_x) / this.sheetCtx.zoomRatio, -(pos_y + textInfo.textTopAll) / this.sheetCtx.zoomRatio);
1291
- }
1292
- for (var i = 0; i < values.length; i += 1) {
1293
- var word = values[i];
1294
- if (word.inline === true && word.style) {
1295
- ctx.font = word.style.fontset;
1296
- ctx.fillStyle = word.style.fc;
1297
- } else {
1298
- ctx.font = word.style;
1299
- }
1300
- var txt = _lodash.default.isPlainObject(word.content) ? word.content.m : word.content;
1301
- ctx.fillText(txt, (pos_x + word.left) / this.sheetCtx.zoomRatio, (pos_y + word.top) / this.sheetCtx.zoomRatio);
1302
- if (word.cancelLine) {
1303
- var c = word.cancelLine;
1304
- ctx.beginPath();
1305
- ctx.moveTo(Math.floor((pos_x + c.startX) / this.sheetCtx.zoomRatio) + 0.5, Math.floor((pos_y + c.startY) / this.sheetCtx.zoomRatio) + 0.5);
1306
- ctx.lineTo(Math.floor((pos_x + c.endX) / this.sheetCtx.zoomRatio) + 0.5, Math.floor((pos_y + c.endY) / this.sheetCtx.zoomRatio) + 0.5);
1307
- ctx.lineWidth = Math.floor(c.fs / 9);
1308
- ctx.strokeStyle = ctx.fillStyle;
1309
- ctx.stroke();
1310
- ctx.closePath();
1311
- }
1312
- if (word.underLine) {
1313
- var underLines = word.underLine;
1314
- for (var a = 0; a < underLines.length; a += 1) {
1315
- var item = underLines[a];
1316
- ctx.beginPath();
1317
- ctx.moveTo(Math.floor((pos_x + item.startX) / this.sheetCtx.zoomRatio) + 0.5, Math.floor((pos_y + item.startY) / this.sheetCtx.zoomRatio));
1318
- ctx.lineTo(Math.floor((pos_x + item.endX) / this.sheetCtx.zoomRatio) + 0.5, Math.floor((pos_y + item.endY) / this.sheetCtx.zoomRatio) + 0.5);
1319
- ctx.lineWidth = Math.floor(item.fs / 9);
1320
- ctx.strokeStyle = ctx.fillStyle;
1321
- ctx.stroke();
1322
- ctx.closePath();
1323
- }
1324
- }
1325
- }
1326
- if (textInfo.rotate !== 0 && textInfo.type !== "verticalWrap") {
1327
- ctx.restore();
1328
- }
1329
- };
1330
- Canvas.prototype.drawFreezeLine = function (_a) {
1331
- var horizontalTop = _a.horizontalTop,
1332
- verticalLeft = _a.verticalLeft;
1333
- var renderCtx = this.canvasElement.getContext("2d");
1334
- if (!renderCtx) return;
1335
- renderCtx.save();
1336
- renderCtx.scale(this.sheetCtx.devicePixelRatio, this.sheetCtx.devicePixelRatio);
1337
- renderCtx.strokeStyle = "#ccc";
1338
- renderCtx.lineWidth = 2;
1339
- if (horizontalTop) {
1340
- renderCtx.beginPath();
1341
- renderCtx.moveTo(0, horizontalTop);
1342
- renderCtx.lineTo(this.canvasElement.width, horizontalTop);
1343
- renderCtx.stroke();
1344
- renderCtx.closePath();
1345
- }
1346
- if (verticalLeft) {
1347
- renderCtx.beginPath();
1348
- renderCtx.moveTo(verticalLeft, 0);
1349
- renderCtx.lineTo(verticalLeft, this.canvasElement.height);
1350
- renderCtx.stroke();
1351
- renderCtx.closePath();
1352
- }
1353
- renderCtx.restore();
1354
- };
1355
- return Canvas;
1356
- }();