handsontable 13.1.0 → 14.0.0-next-e8f87aa-20231030

Sign up to get free protection for your applications and to get access to all the features.
Files changed (691) hide show
  1. package/3rdparty/walkontable/src/calculator/constants.js +3 -6
  2. package/3rdparty/walkontable/src/calculator/viewportColumns.js +1 -2
  3. package/3rdparty/walkontable/src/calculator/viewportRows.js +1 -2
  4. package/3rdparty/walkontable/src/cell/coords.d.ts +8 -1
  5. package/3rdparty/walkontable/src/cell/coords.js +81 -13
  6. package/3rdparty/walkontable/src/cell/coords.mjs +80 -11
  7. package/3rdparty/walkontable/src/cell/range.d.ts +9 -2
  8. package/3rdparty/walkontable/src/cell/range.js +39 -9
  9. package/3rdparty/walkontable/src/cell/range.mjs +38 -7
  10. package/3rdparty/walkontable/src/core/_base.js +9 -3
  11. package/3rdparty/walkontable/src/core/_base.mjs +9 -3
  12. package/3rdparty/walkontable/src/core/clone.js +2 -2
  13. package/3rdparty/walkontable/src/core/clone.mjs +2 -2
  14. package/3rdparty/walkontable/src/core/core.js +3 -2
  15. package/3rdparty/walkontable/src/core/core.mjs +3 -2
  16. package/3rdparty/walkontable/src/event.js +13 -12
  17. package/3rdparty/walkontable/src/event.mjs +12 -10
  18. package/3rdparty/walkontable/src/facade/core.js +2 -2
  19. package/3rdparty/walkontable/src/facade/core.mjs +2 -2
  20. package/3rdparty/walkontable/src/filter/column.js +1 -2
  21. package/3rdparty/walkontable/src/filter/row.js +1 -2
  22. package/3rdparty/walkontable/src/index.js +12 -4
  23. package/3rdparty/walkontable/src/index.mjs +2 -2
  24. package/3rdparty/walkontable/src/overlay/_base.js +13 -2
  25. package/3rdparty/walkontable/src/overlay/_base.mjs +14 -3
  26. package/3rdparty/walkontable/src/overlay/constants.js +7 -14
  27. package/3rdparty/walkontable/src/overlay/inlineStart.js +2 -6
  28. package/3rdparty/walkontable/src/overlay/inlineStart.mjs +2 -6
  29. package/3rdparty/walkontable/src/overlay/top.js +2 -6
  30. package/3rdparty/walkontable/src/overlay/top.mjs +2 -6
  31. package/3rdparty/walkontable/src/overlays.js +1 -2
  32. package/3rdparty/walkontable/src/renderer/cells.js +10 -0
  33. package/3rdparty/walkontable/src/renderer/cells.mjs +11 -1
  34. package/3rdparty/walkontable/src/renderer/columnHeaders.js +13 -0
  35. package/3rdparty/walkontable/src/renderer/columnHeaders.mjs +14 -1
  36. package/3rdparty/walkontable/src/renderer/rowHeaders.js +8 -0
  37. package/3rdparty/walkontable/src/renderer/rowHeaders.mjs +8 -0
  38. package/3rdparty/walkontable/src/renderer/rows.js +13 -0
  39. package/3rdparty/walkontable/src/renderer/rows.mjs +13 -0
  40. package/3rdparty/walkontable/src/renderer/table.js +9 -0
  41. package/3rdparty/walkontable/src/renderer/table.mjs +9 -0
  42. package/3rdparty/walkontable/src/scroll.js +3 -2
  43. package/3rdparty/walkontable/src/scroll.mjs +2 -0
  44. package/3rdparty/walkontable/src/{border.js → selection/border/border.js} +8 -14
  45. package/3rdparty/walkontable/src/{border.mjs → selection/border/border.mjs} +7 -12
  46. package/3rdparty/walkontable/src/selection/border/constants.js +15 -0
  47. package/3rdparty/walkontable/src/selection/border/constants.mjs +12 -0
  48. package/3rdparty/walkontable/src/selection/constants.js +54 -0
  49. package/3rdparty/walkontable/src/selection/constants.mjs +51 -0
  50. package/3rdparty/walkontable/src/selection/index.js +26 -0
  51. package/3rdparty/walkontable/src/selection/index.mjs +5 -0
  52. package/3rdparty/walkontable/src/selection/manager.js +274 -0
  53. package/3rdparty/walkontable/src/selection/manager.mjs +269 -0
  54. package/3rdparty/walkontable/src/selection/scanner.js +270 -0
  55. package/3rdparty/walkontable/src/selection/scanner.mjs +267 -0
  56. package/3rdparty/walkontable/src/selection/selection.js +100 -0
  57. package/3rdparty/walkontable/src/selection/selection.mjs +96 -0
  58. package/3rdparty/walkontable/src/settings.js +13 -4
  59. package/3rdparty/walkontable/src/settings.mjs +13 -4
  60. package/3rdparty/walkontable/src/table/bottom.js +1 -2
  61. package/3rdparty/walkontable/src/table/bottomInlineStartCorner.js +1 -2
  62. package/3rdparty/walkontable/src/table/inlineStart.js +1 -2
  63. package/3rdparty/walkontable/src/table/master.js +3 -6
  64. package/3rdparty/walkontable/src/table/master.mjs +2 -4
  65. package/3rdparty/walkontable/src/table/mixin/calculatedColumns.js +10 -2
  66. package/3rdparty/walkontable/src/table/mixin/calculatedColumns.mjs +9 -0
  67. package/3rdparty/walkontable/src/table/mixin/calculatedRows.js +10 -2
  68. package/3rdparty/walkontable/src/table/mixin/calculatedRows.mjs +9 -0
  69. package/3rdparty/walkontable/src/table/mixin/stickyColumnsStart.js +10 -2
  70. package/3rdparty/walkontable/src/table/mixin/stickyColumnsStart.mjs +9 -0
  71. package/3rdparty/walkontable/src/table/mixin/stickyRowsBottom.js +10 -2
  72. package/3rdparty/walkontable/src/table/mixin/stickyRowsBottom.mjs +9 -0
  73. package/3rdparty/walkontable/src/table/mixin/stickyRowsTop.js +10 -2
  74. package/3rdparty/walkontable/src/table/mixin/stickyRowsTop.mjs +9 -0
  75. package/3rdparty/walkontable/src/table/top.js +1 -2
  76. package/3rdparty/walkontable/src/table/topInlineStartCorner.js +1 -2
  77. package/3rdparty/walkontable/src/table.js +20 -80
  78. package/3rdparty/walkontable/src/table.mjs +20 -79
  79. package/3rdparty/walkontable/src/utils/orderView/constants.js +3 -6
  80. package/3rdparty/walkontable/src/viewport.js +1 -2
  81. package/CHANGELOG.md +51 -0
  82. package/base.js +3 -4
  83. package/base.mjs +2 -2
  84. package/cellTypes/autocompleteType/autocompleteType.js +3 -5
  85. package/cellTypes/checkboxType/checkboxType.js +3 -5
  86. package/cellTypes/dateType/dateType.d.ts +3 -3
  87. package/cellTypes/dateType/dateType.js +5 -7
  88. package/cellTypes/dateType/dateType.mjs +2 -2
  89. package/cellTypes/dropdownType/dropdownType.js +3 -5
  90. package/cellTypes/handsontableType/handsontableType.d.ts +3 -3
  91. package/cellTypes/handsontableType/handsontableType.js +5 -7
  92. package/cellTypes/handsontableType/handsontableType.mjs +2 -2
  93. package/cellTypes/index.d.ts +3 -0
  94. package/cellTypes/index.js +4 -0
  95. package/cellTypes/index.mjs +3 -1
  96. package/cellTypes/numericType/numericType.js +3 -5
  97. package/cellTypes/passwordType/passwordType.js +3 -5
  98. package/cellTypes/selectType/index.d.ts +1 -0
  99. package/cellTypes/selectType/index.js +6 -0
  100. package/cellTypes/selectType/index.mjs +1 -0
  101. package/cellTypes/selectType/selectType.d.ts +14 -0
  102. package/cellTypes/selectType/selectType.js +11 -0
  103. package/cellTypes/selectType/selectType.mjs +8 -0
  104. package/cellTypes/textType/textType.js +3 -5
  105. package/cellTypes/timeType/timeType.js +3 -5
  106. package/common.d.ts +1 -1
  107. package/core/focusCatcher/focusDetector.js +63 -0
  108. package/core/focusCatcher/focusDetector.mjs +59 -0
  109. package/core/focusCatcher/index.js +148 -0
  110. package/core/focusCatcher/index.mjs +144 -0
  111. package/core/index.js +9 -0
  112. package/core/index.mjs +1 -0
  113. package/core.d.ts +10 -5
  114. package/core.js +327 -359
  115. package/core.mjs +327 -359
  116. package/dataMap/dataMap.js +1 -2
  117. package/dataMap/dataSource.js +1 -2
  118. package/dataMap/metaManager/metaSchema.js +65 -0
  119. package/dataMap/metaManager/metaSchema.mjs +65 -0
  120. package/dataMap/metaManager/mods/extendMetaProperties.js +7 -1
  121. package/dataMap/metaManager/mods/extendMetaProperties.mjs +7 -1
  122. package/dataMap/replaceData.js +5 -0
  123. package/dataMap/replaceData.mjs +5 -0
  124. package/dist/handsontable.css +94 -76
  125. package/dist/handsontable.full.css +94 -76
  126. package/dist/handsontable.full.js +23133 -15992
  127. package/dist/handsontable.full.min.css +8 -8
  128. package/dist/handsontable.full.min.js +170 -152
  129. package/dist/handsontable.js +21856 -15085
  130. package/dist/handsontable.min.css +7 -7
  131. package/dist/handsontable.min.js +30 -22
  132. package/dist/languages/all.js +47 -40
  133. package/dist/languages/all.min.js +1 -1
  134. package/dist/languages/ar-AR.js +1 -2
  135. package/dist/languages/cs-CZ.js +1 -2
  136. package/dist/languages/de-CH.js +1 -2
  137. package/dist/languages/de-DE.js +1 -2
  138. package/dist/languages/en-US.js +15 -3
  139. package/dist/languages/en-US.min.js +1 -1
  140. package/dist/languages/es-MX.js +1 -2
  141. package/dist/languages/fr-FR.js +1 -2
  142. package/dist/languages/it-IT.js +1 -2
  143. package/dist/languages/ja-JP.js +1 -2
  144. package/dist/languages/ko-KR.js +1 -2
  145. package/dist/languages/lv-LV.js +1 -2
  146. package/dist/languages/nb-NO.js +1 -2
  147. package/dist/languages/nl-NL.js +1 -2
  148. package/dist/languages/pl-PL.js +15 -3
  149. package/dist/languages/pl-PL.min.js +1 -1
  150. package/dist/languages/pt-BR.js +1 -2
  151. package/dist/languages/ru-RU.js +1 -2
  152. package/dist/languages/sr-SP.js +1 -2
  153. package/dist/languages/zh-CN.js +1 -2
  154. package/dist/languages/zh-TW.js +1 -2
  155. package/editorManager.js +17 -91
  156. package/editorManager.mjs +16 -87
  157. package/editors/autocompleteEditor/autocompleteEditor.js +65 -11
  158. package/editors/autocompleteEditor/autocompleteEditor.mjs +65 -10
  159. package/editors/baseEditor/baseEditor.js +19 -13
  160. package/editors/baseEditor/baseEditor.mjs +16 -7
  161. package/editors/checkboxEditor/checkboxEditor.js +1 -2
  162. package/editors/dateEditor/dateEditor.js +27 -9
  163. package/editors/dateEditor/dateEditor.mjs +27 -8
  164. package/editors/dropdownEditor/dropdownEditor.js +1 -2
  165. package/editors/handsontableEditor/handsontableEditor.js +14 -7
  166. package/editors/handsontableEditor/handsontableEditor.mjs +14 -6
  167. package/editors/numericEditor/numericEditor.js +1 -2
  168. package/editors/passwordEditor/passwordEditor.js +1 -2
  169. package/editors/selectEditor/selectEditor.js +1 -2
  170. package/editors/textEditor/textEditor.js +20 -29
  171. package/editors/textEditor/textEditor.mjs +22 -30
  172. package/editors/timeEditor/timeEditor.js +1 -2
  173. package/eventManager.js +1 -2
  174. package/focusManager.d.ts +12 -0
  175. package/focusManager.js +265 -0
  176. package/focusManager.mjs +261 -0
  177. package/helpers/a11y.js +81 -0
  178. package/helpers/a11y.mjs +39 -0
  179. package/helpers/dom/element.js +224 -12
  180. package/helpers/dom/element.mjs +216 -10
  181. package/helpers/dom/event.d.ts +1 -0
  182. package/helpers/dom/event.js +25 -0
  183. package/helpers/dom/event.mjs +24 -0
  184. package/helpers/mixed.js +2 -2
  185. package/helpers/mixed.mjs +2 -2
  186. package/helpers/number.d.ts +1 -0
  187. package/helpers/number.js +18 -0
  188. package/helpers/number.mjs +17 -0
  189. package/helpers/unicode.js +1 -2
  190. package/i18n/constants.js +97 -160
  191. package/i18n/constants.mjs +17 -1
  192. package/i18n/languages/ar-AR.js +3 -4
  193. package/i18n/languages/cs-CZ.js +3 -4
  194. package/i18n/languages/de-CH.js +3 -4
  195. package/i18n/languages/de-DE.js +3 -4
  196. package/i18n/languages/en-US.js +17 -5
  197. package/i18n/languages/en-US.mjs +14 -1
  198. package/i18n/languages/es-MX.js +3 -4
  199. package/i18n/languages/fr-FR.js +3 -4
  200. package/i18n/languages/it-IT.js +3 -4
  201. package/i18n/languages/ja-JP.js +3 -4
  202. package/i18n/languages/ko-KR.js +3 -4
  203. package/i18n/languages/lv-LV.js +3 -4
  204. package/i18n/languages/nb-NO.js +3 -4
  205. package/i18n/languages/nl-NL.js +3 -4
  206. package/i18n/languages/pl-PL.js +17 -5
  207. package/i18n/languages/pl-PL.mjs +14 -1
  208. package/i18n/languages/pt-BR.js +3 -4
  209. package/i18n/languages/ru-RU.js +3 -4
  210. package/i18n/languages/sr-SP.js +3 -4
  211. package/i18n/languages/zh-CN.js +3 -4
  212. package/i18n/languages/zh-TW.js +3 -4
  213. package/i18n/registry.js +4 -6
  214. package/index.js +3 -4
  215. package/languages/all.js +47 -40
  216. package/languages/ar-AR.js +1 -2
  217. package/languages/cs-CZ.js +1 -2
  218. package/languages/de-CH.js +1 -2
  219. package/languages/de-DE.js +1 -2
  220. package/languages/en-US.js +15 -3
  221. package/languages/en-US.mjs +14 -1
  222. package/languages/es-MX.js +1 -2
  223. package/languages/fr-FR.js +1 -2
  224. package/languages/index.js +47 -40
  225. package/languages/it-IT.js +1 -2
  226. package/languages/ja-JP.js +1 -2
  227. package/languages/ko-KR.js +1 -2
  228. package/languages/lv-LV.js +1 -2
  229. package/languages/nb-NO.js +1 -2
  230. package/languages/nl-NL.js +1 -2
  231. package/languages/pl-PL.js +15 -3
  232. package/languages/pl-PL.mjs +14 -1
  233. package/languages/pt-BR.js +1 -2
  234. package/languages/ru-RU.js +1 -2
  235. package/languages/sr-SP.js +1 -2
  236. package/languages/zh-CN.js +1 -2
  237. package/languages/zh-TW.js +1 -2
  238. package/mixins/hooksRefRegisterer.js +1 -2
  239. package/mixins/localHooks.js +1 -2
  240. package/package.json +119 -96
  241. package/pluginHooks.d.ts +42 -7
  242. package/pluginHooks.js +301 -65
  243. package/pluginHooks.mjs +300 -63
  244. package/plugins/autoColumnSize/autoColumnSize.d.ts +2 -0
  245. package/plugins/autoColumnSize/autoColumnSize.js +2 -4
  246. package/plugins/autoRowSize/autoRowSize.d.ts +2 -0
  247. package/plugins/autoRowSize/autoRowSize.js +15 -10
  248. package/plugins/autoRowSize/autoRowSize.mjs +13 -6
  249. package/plugins/autofill/autofill.js +2 -4
  250. package/plugins/autofill/utils.js +1 -2
  251. package/plugins/base/base.js +1 -2
  252. package/plugins/bindRowsWithHeaders/bindRowsWithHeaders.js +2 -4
  253. package/plugins/bindRowsWithHeaders/maps/looseBindsMap.js +1 -2
  254. package/plugins/bindRowsWithHeaders/maps/strictBindsMap.js +1 -2
  255. package/plugins/collapsibleColumns/collapsibleColumns.js +77 -8
  256. package/plugins/collapsibleColumns/collapsibleColumns.mjs +76 -5
  257. package/plugins/columnSorting/columnSorting.js +71 -6
  258. package/plugins/columnSorting/columnSorting.mjs +70 -3
  259. package/plugins/columnSorting/index.js +3 -1
  260. package/plugins/columnSorting/index.mjs +1 -1
  261. package/plugins/columnSorting/sortFunction/checkbox.js +1 -2
  262. package/plugins/columnSorting/sortFunction/date.js +1 -2
  263. package/plugins/columnSorting/sortFunction/default.js +1 -2
  264. package/plugins/columnSorting/sortFunction/numeric.js +1 -2
  265. package/plugins/columnSorting/sortService/engine.js +3 -6
  266. package/plugins/columnSorting/utils.js +3 -6
  267. package/plugins/columnSummary/columnSummary.js +2 -4
  268. package/plugins/columnSummary/endpoints.js +1 -2
  269. package/plugins/comments/commentEditor.js +2 -2
  270. package/plugins/comments/commentEditor.mjs +1 -0
  271. package/plugins/comments/comments.js +254 -197
  272. package/plugins/comments/comments.mjs +251 -190
  273. package/plugins/comments/contextMenuItem/addEditComment.js +41 -0
  274. package/plugins/comments/contextMenuItem/addEditComment.mjs +35 -0
  275. package/plugins/comments/contextMenuItem/readOnlyComment.js +49 -0
  276. package/plugins/comments/contextMenuItem/readOnlyComment.mjs +43 -0
  277. package/plugins/comments/contextMenuItem/removeComment.js +38 -0
  278. package/plugins/comments/contextMenuItem/removeComment.mjs +32 -0
  279. package/plugins/comments/displaySwitch.js +1 -2
  280. package/plugins/contextMenu/commandExecutor.js +2 -3
  281. package/plugins/contextMenu/commandExecutor.mjs +2 -3
  282. package/plugins/contextMenu/contextMenu.d.ts +1 -1
  283. package/plugins/contextMenu/contextMenu.js +77 -40
  284. package/plugins/contextMenu/contextMenu.mjs +74 -35
  285. package/plugins/contextMenu/itemsFactory.js +2 -3
  286. package/plugins/contextMenu/itemsFactory.mjs +3 -4
  287. package/plugins/contextMenu/{cursor.mjs → menu/cursor.js} +6 -4
  288. package/plugins/contextMenu/{cursor.js → menu/cursor.mjs} +4 -10
  289. package/plugins/contextMenu/menu/defaultShortcutsList.js +88 -0
  290. package/plugins/contextMenu/menu/defaultShortcutsList.mjs +84 -0
  291. package/plugins/contextMenu/menu/index.js +9 -0
  292. package/plugins/contextMenu/menu/index.mjs +1 -0
  293. package/plugins/contextMenu/{menu.js → menu/menu.js} +145 -421
  294. package/plugins/contextMenu/{menu.mjs → menu/menu.mjs} +146 -422
  295. package/plugins/contextMenu/menu/menuItemRenderer.js +70 -0
  296. package/plugins/contextMenu/menu/menuItemRenderer.mjs +66 -0
  297. package/plugins/contextMenu/menu/navigator.js +27 -0
  298. package/plugins/contextMenu/menu/navigator.mjs +23 -0
  299. package/plugins/contextMenu/menu/positioner.js +213 -0
  300. package/plugins/contextMenu/menu/positioner.mjs +209 -0
  301. package/plugins/contextMenu/menu/shortcuts.js +114 -0
  302. package/plugins/contextMenu/menu/shortcuts.mjs +110 -0
  303. package/plugins/contextMenu/menu/utils.js +177 -0
  304. package/plugins/contextMenu/menu/utils.mjs +163 -0
  305. package/plugins/contextMenu/predefinedItems/alignment.js +10 -4
  306. package/plugins/contextMenu/predefinedItems/alignment.mjs +7 -0
  307. package/plugins/contextMenu/predefinedItems/clearColumn.js +8 -7
  308. package/plugins/contextMenu/predefinedItems/clearColumn.mjs +5 -3
  309. package/plugins/contextMenu/predefinedItems/columnLeft.js +8 -7
  310. package/plugins/contextMenu/predefinedItems/columnLeft.mjs +5 -3
  311. package/plugins/contextMenu/predefinedItems/columnRight.js +8 -7
  312. package/plugins/contextMenu/predefinedItems/columnRight.mjs +5 -3
  313. package/plugins/contextMenu/predefinedItems/index.js +75 -0
  314. package/plugins/contextMenu/predefinedItems/index.mjs +68 -0
  315. package/plugins/contextMenu/predefinedItems/noItems.js +1 -2
  316. package/plugins/contextMenu/predefinedItems/readOnly.js +10 -4
  317. package/plugins/contextMenu/predefinedItems/readOnly.mjs +7 -0
  318. package/plugins/contextMenu/predefinedItems/redo.js +3 -4
  319. package/plugins/contextMenu/predefinedItems/removeColumn.js +10 -9
  320. package/plugins/contextMenu/predefinedItems/removeColumn.mjs +5 -3
  321. package/plugins/contextMenu/predefinedItems/removeRow.js +10 -9
  322. package/plugins/contextMenu/predefinedItems/removeRow.mjs +5 -3
  323. package/plugins/contextMenu/predefinedItems/rowAbove.js +8 -7
  324. package/plugins/contextMenu/predefinedItems/rowAbove.mjs +5 -3
  325. package/plugins/contextMenu/predefinedItems/rowBelow.js +8 -7
  326. package/plugins/contextMenu/predefinedItems/rowBelow.mjs +5 -3
  327. package/plugins/contextMenu/predefinedItems/separator.js +1 -2
  328. package/plugins/contextMenu/predefinedItems/undo.js +3 -4
  329. package/plugins/contextMenu/utils.js +35 -151
  330. package/plugins/contextMenu/utils.mjs +35 -144
  331. package/plugins/copyPaste/clipboardData/clipboardData.js +516 -0
  332. package/plugins/copyPaste/clipboardData/clipboardData.mjs +512 -0
  333. package/plugins/copyPaste/clipboardData/copyClipboardData.js +69 -0
  334. package/plugins/copyPaste/clipboardData/copyClipboardData.mjs +65 -0
  335. package/plugins/copyPaste/clipboardData/index.js +9 -0
  336. package/plugins/copyPaste/clipboardData/index.mjs +4 -0
  337. package/plugins/copyPaste/clipboardData/pasteClipboardData.js +81 -0
  338. package/plugins/copyPaste/clipboardData/pasteClipboardData.mjs +77 -0
  339. package/plugins/copyPaste/contextMenuItem/copy.js +7 -0
  340. package/plugins/copyPaste/contextMenuItem/copy.mjs +7 -0
  341. package/plugins/copyPaste/contextMenuItem/copyColumnHeadersOnly.js +9 -1
  342. package/plugins/copyPaste/contextMenuItem/copyColumnHeadersOnly.mjs +9 -1
  343. package/plugins/copyPaste/contextMenuItem/copyWithColumnGroupHeaders.js +9 -1
  344. package/plugins/copyPaste/contextMenuItem/copyWithColumnGroupHeaders.mjs +9 -1
  345. package/plugins/copyPaste/contextMenuItem/copyWithColumnHeaders.js +9 -1
  346. package/plugins/copyPaste/contextMenuItem/copyWithColumnHeaders.mjs +9 -1
  347. package/plugins/copyPaste/contextMenuItem/cut.js +9 -2
  348. package/plugins/copyPaste/contextMenuItem/cut.mjs +7 -0
  349. package/plugins/copyPaste/copyPaste.js +160 -167
  350. package/plugins/copyPaste/copyPaste.mjs +161 -166
  351. package/plugins/customBorders/contextMenuItem/bottom.js +2 -2
  352. package/plugins/customBorders/contextMenuItem/left.js +2 -2
  353. package/plugins/customBorders/contextMenuItem/noBorders.js +2 -2
  354. package/plugins/customBorders/contextMenuItem/right.js +2 -2
  355. package/plugins/customBorders/contextMenuItem/top.js +2 -2
  356. package/plugins/customBorders/customBorders.js +27 -26
  357. package/plugins/customBorders/customBorders.mjs +24 -21
  358. package/plugins/dragToScroll/dragToScroll.js +2 -4
  359. package/plugins/dropdownMenu/dropdownMenu.d.ts +1 -1
  360. package/plugins/dropdownMenu/dropdownMenu.js +130 -44
  361. package/plugins/dropdownMenu/dropdownMenu.mjs +127 -39
  362. package/plugins/exportFile/dataProvider.js +1 -2
  363. package/plugins/exportFile/exportFile.js +4 -6
  364. package/plugins/exportFile/typeFactory.js +5 -8
  365. package/plugins/exportFile/types/_base.js +1 -2
  366. package/plugins/exportFile/types/csv.js +1 -2
  367. package/plugins/filters/component/_base.js +23 -8
  368. package/plugins/filters/component/_base.mjs +23 -8
  369. package/plugins/filters/component/actionBar.js +31 -29
  370. package/plugins/filters/component/actionBar.mjs +26 -23
  371. package/plugins/filters/component/condition.js +48 -61
  372. package/plugins/filters/component/condition.mjs +40 -52
  373. package/plugins/filters/component/operators.js +21 -22
  374. package/plugins/filters/component/operators.mjs +18 -18
  375. package/plugins/filters/component/value.js +37 -28
  376. package/plugins/filters/component/value.mjs +32 -22
  377. package/plugins/filters/condition/beginsWith.js +3 -4
  378. package/plugins/filters/condition/between.js +3 -4
  379. package/plugins/filters/condition/byValue.js +1 -2
  380. package/plugins/filters/condition/contains.js +3 -4
  381. package/plugins/filters/condition/date/after.js +3 -4
  382. package/plugins/filters/condition/date/before.js +3 -4
  383. package/plugins/filters/condition/date/today.js +3 -4
  384. package/plugins/filters/condition/date/tomorrow.js +3 -4
  385. package/plugins/filters/condition/date/yesterday.js +3 -4
  386. package/plugins/filters/condition/empty.js +3 -4
  387. package/plugins/filters/condition/endsWith.js +3 -4
  388. package/plugins/filters/condition/equal.js +3 -4
  389. package/plugins/filters/condition/false.js +1 -2
  390. package/plugins/filters/condition/greaterThan.js +3 -4
  391. package/plugins/filters/condition/greaterThanOrEqual.js +3 -4
  392. package/plugins/filters/condition/lessThan.js +3 -4
  393. package/plugins/filters/condition/lessThanOrEqual.js +3 -4
  394. package/plugins/filters/condition/none.js +3 -4
  395. package/plugins/filters/condition/notBetween.js +3 -4
  396. package/plugins/filters/condition/notContains.js +3 -4
  397. package/plugins/filters/condition/notEmpty.js +3 -4
  398. package/plugins/filters/condition/notEqual.js +3 -4
  399. package/plugins/filters/condition/true.js +1 -2
  400. package/plugins/filters/conditionCollection.d.ts +3 -2
  401. package/plugins/filters/conditionCollection.js +1 -2
  402. package/plugins/filters/conditionRegisterer.js +1 -2
  403. package/plugins/filters/conditionUpdateObserver.js +1 -2
  404. package/plugins/filters/constants.js +4 -8
  405. package/plugins/filters/constants.mjs +1 -1
  406. package/plugins/filters/dataFilter.js +1 -2
  407. package/plugins/filters/filters.d.ts +3 -5
  408. package/plugins/filters/filters.js +118 -67
  409. package/plugins/filters/filters.mjs +109 -56
  410. package/plugins/filters/logicalOperationRegisterer.js +1 -2
  411. package/plugins/filters/logicalOperations/conjunction.js +4 -6
  412. package/plugins/filters/logicalOperations/disjunction.js +4 -6
  413. package/plugins/filters/logicalOperations/disjunctionWithExtraCondition.js +4 -6
  414. package/plugins/filters/menu/focusController.js +123 -0
  415. package/plugins/filters/menu/focusController.mjs +119 -0
  416. package/plugins/filters/menu/focusNavigator.js +30 -0
  417. package/plugins/filters/menu/focusNavigator.mjs +26 -0
  418. package/plugins/filters/ui/_base.js +37 -15
  419. package/plugins/filters/ui/_base.mjs +35 -13
  420. package/plugins/filters/ui/input.js +43 -35
  421. package/plugins/filters/ui/input.mjs +42 -33
  422. package/plugins/filters/ui/link.js +44 -12
  423. package/plugins/filters/ui/link.mjs +44 -11
  424. package/plugins/filters/ui/multipleSelect.js +237 -133
  425. package/plugins/filters/ui/multipleSelect.mjs +232 -127
  426. package/plugins/filters/ui/radioInput.js +42 -18
  427. package/plugins/filters/ui/radioInput.mjs +42 -17
  428. package/plugins/filters/ui/select.js +152 -77
  429. package/plugins/filters/ui/select.mjs +148 -72
  430. package/plugins/formulas/engine/settings.js +2 -4
  431. package/plugins/formulas/formulas.js +3 -6
  432. package/plugins/formulas/indexSyncer/axisSyncer.js +1 -2
  433. package/plugins/formulas/indexSyncer/index.js +1 -2
  434. package/plugins/hiddenColumns/contextMenuItem/hideColumn.js +2 -2
  435. package/plugins/hiddenColumns/contextMenuItem/showColumn.js +2 -2
  436. package/plugins/hiddenColumns/hiddenColumns.d.ts +1 -0
  437. package/plugins/hiddenColumns/hiddenColumns.js +49 -6
  438. package/plugins/hiddenColumns/hiddenColumns.mjs +48 -3
  439. package/plugins/hiddenRows/contextMenuItem/hideRow.js +2 -2
  440. package/plugins/hiddenRows/contextMenuItem/showRow.js +2 -2
  441. package/plugins/hiddenRows/hiddenRows.d.ts +1 -0
  442. package/plugins/hiddenRows/hiddenRows.js +49 -6
  443. package/plugins/hiddenRows/hiddenRows.mjs +48 -3
  444. package/plugins/manualColumnFreeze/contextMenuItem/freezeColumn.js +2 -2
  445. package/plugins/manualColumnFreeze/contextMenuItem/unfreezeColumn.js +2 -2
  446. package/plugins/manualColumnFreeze/manualColumnFreeze.js +2 -4
  447. package/plugins/manualColumnMove/manualColumnMove.js +9 -17
  448. package/plugins/manualColumnMove/manualColumnMove.mjs +7 -13
  449. package/plugins/manualColumnMove/ui/_base.js +1 -2
  450. package/plugins/manualColumnMove/ui/backlight.js +1 -2
  451. package/plugins/manualColumnMove/ui/guideline.js +1 -2
  452. package/plugins/manualColumnResize/manualColumnResize.js +2 -4
  453. package/plugins/manualRowMove/manualRowMove.js +6 -23
  454. package/plugins/manualRowMove/manualRowMove.mjs +4 -19
  455. package/plugins/manualRowMove/ui/_base.js +1 -2
  456. package/plugins/manualRowMove/ui/backlight.js +1 -2
  457. package/plugins/manualRowMove/ui/guideline.js +1 -2
  458. package/plugins/manualRowResize/manualRowResize.js +2 -4
  459. package/plugins/mergeCells/calculations/autofill.js +1 -2
  460. package/plugins/mergeCells/calculations/selection.js +1 -2
  461. package/plugins/mergeCells/cellCoords.js +1 -2
  462. package/plugins/mergeCells/cellsCollection.js +1 -2
  463. package/plugins/mergeCells/contextMenuItem/toggleMerge.js +2 -2
  464. package/plugins/mergeCells/mergeCells.js +7 -20
  465. package/plugins/mergeCells/mergeCells.mjs +5 -16
  466. package/plugins/multiColumnSorting/multiColumnSorting.js +60 -6
  467. package/plugins/multiColumnSorting/multiColumnSorting.mjs +59 -3
  468. package/plugins/multipleSelectionHandles/multipleSelectionHandles.js +2 -4
  469. package/plugins/nestedHeaders/nestedHeaders.js +263 -36
  470. package/plugins/nestedHeaders/nestedHeaders.mjs +262 -33
  471. package/plugins/nestedHeaders/stateManager/index.js +102 -3
  472. package/plugins/nestedHeaders/stateManager/index.mjs +102 -3
  473. package/plugins/nestedHeaders/stateManager/sourceSettings.js +1 -2
  474. package/plugins/nestedHeaders/utils/ghostTable.js +1 -2
  475. package/plugins/nestedRows/data/dataManager.js +1 -2
  476. package/plugins/nestedRows/nestedRows.js +47 -10
  477. package/plugins/nestedRows/nestedRows.mjs +45 -6
  478. package/plugins/nestedRows/ui/_base.js +1 -2
  479. package/plugins/nestedRows/ui/collapsing.js +1 -2
  480. package/plugins/nestedRows/ui/contextMenu.js +3 -4
  481. package/plugins/nestedRows/ui/headers.js +13 -3
  482. package/plugins/nestedRows/ui/headers.mjs +13 -2
  483. package/plugins/persistentState/persistentState.js +2 -4
  484. package/plugins/persistentState/storage.js +1 -2
  485. package/plugins/search/search.js +2 -4
  486. package/plugins/touchScroll/touchScroll.js +2 -4
  487. package/plugins/trimRows/trimRows.js +2 -4
  488. package/plugins/undoRedo/index.js +2 -2
  489. package/plugins/undoRedo/undoRedo.js +2 -4
  490. package/renderers/autocompleteRenderer/autocompleteRenderer.js +9 -2
  491. package/renderers/autocompleteRenderer/autocompleteRenderer.mjs +8 -0
  492. package/renderers/baseRenderer/baseRenderer.js +18 -2
  493. package/renderers/baseRenderer/baseRenderer.mjs +18 -1
  494. package/renderers/checkboxRenderer/checkboxRenderer.js +10 -6
  495. package/renderers/checkboxRenderer/checkboxRenderer.mjs +9 -4
  496. package/renderers/dateRenderer/dateRenderer.d.ts +5 -0
  497. package/renderers/dateRenderer/dateRenderer.js +28 -0
  498. package/renderers/dateRenderer/dateRenderer.mjs +24 -0
  499. package/renderers/dateRenderer/index.d.ts +1 -0
  500. package/renderers/dateRenderer/index.js +6 -0
  501. package/renderers/dateRenderer/index.mjs +1 -0
  502. package/renderers/handsontableRenderer/handsontableRenderer.d.ts +5 -0
  503. package/renderers/handsontableRenderer/handsontableRenderer.js +28 -0
  504. package/renderers/handsontableRenderer/handsontableRenderer.mjs +24 -0
  505. package/renderers/handsontableRenderer/index.d.ts +1 -0
  506. package/renderers/handsontableRenderer/index.js +6 -0
  507. package/renderers/handsontableRenderer/index.mjs +1 -0
  508. package/renderers/htmlRenderer/htmlRenderer.js +1 -2
  509. package/renderers/index.d.ts +9 -0
  510. package/renderers/numericRenderer/numericRenderer.js +1 -2
  511. package/renderers/passwordRenderer/passwordRenderer.js +1 -2
  512. package/renderers/selectRenderer/index.d.ts +1 -0
  513. package/renderers/selectRenderer/index.js +6 -0
  514. package/renderers/selectRenderer/index.mjs +1 -0
  515. package/renderers/selectRenderer/selectRenderer.d.ts +5 -0
  516. package/renderers/selectRenderer/selectRenderer.js +26 -0
  517. package/renderers/selectRenderer/selectRenderer.mjs +22 -0
  518. package/renderers/textRenderer/textRenderer.js +1 -2
  519. package/renderers/timeRenderer/timeRenderer.js +1 -2
  520. package/selection/highlight/highlight.js +257 -73
  521. package/selection/highlight/highlight.mjs +250 -71
  522. package/selection/highlight/types/activeHeader.js +10 -8
  523. package/selection/highlight/types/activeHeader.mjs +10 -8
  524. package/selection/highlight/types/area.js +6 -18
  525. package/selection/highlight/types/area.mjs +6 -18
  526. package/selection/highlight/types/areaLayered.js +31 -0
  527. package/selection/highlight/types/areaLayered.mjs +26 -0
  528. package/selection/highlight/types/column.js +27 -0
  529. package/selection/highlight/types/column.mjs +22 -0
  530. package/selection/highlight/types/customSelection.js +7 -9
  531. package/selection/highlight/types/customSelection.mjs +7 -9
  532. package/selection/highlight/types/fill.js +5 -7
  533. package/selection/highlight/types/fill.mjs +5 -7
  534. package/selection/highlight/types/{cell.js → focus.js} +5 -7
  535. package/selection/highlight/types/{cell.mjs → focus.mjs} +5 -7
  536. package/selection/highlight/types/header.js +9 -18
  537. package/selection/highlight/types/header.mjs +9 -18
  538. package/selection/highlight/types/row.js +27 -0
  539. package/selection/highlight/types/row.mjs +22 -0
  540. package/selection/highlight/visualSelection.js +32 -29
  541. package/selection/highlight/visualSelection.mjs +31 -27
  542. package/selection/index.js +4 -7
  543. package/selection/index.mjs +2 -3
  544. package/selection/mouseEventHandler.js +7 -1
  545. package/selection/mouseEventHandler.mjs +7 -1
  546. package/selection/range.js +9 -10
  547. package/selection/range.mjs +8 -8
  548. package/selection/selection.js +334 -154
  549. package/selection/selection.mjs +330 -151
  550. package/selection/transformation.js +233 -94
  551. package/selection/transformation.mjs +232 -92
  552. package/selection/utils.js +20 -31
  553. package/selection/utils.mjs +16 -21
  554. package/settings.d.ts +4 -0
  555. package/shortcutContexts/commands/editor/closeAndSave.js +11 -0
  556. package/shortcutContexts/commands/editor/closeAndSave.mjs +8 -0
  557. package/shortcutContexts/commands/editor/closeWithoutSaving.js +11 -0
  558. package/shortcutContexts/commands/editor/closeWithoutSaving.mjs +8 -0
  559. package/shortcutContexts/commands/editor/fastOpen.js +15 -0
  560. package/shortcutContexts/commands/editor/fastOpen.mjs +12 -0
  561. package/shortcutContexts/commands/editor/index.js +16 -0
  562. package/shortcutContexts/commands/editor/index.mjs +12 -0
  563. package/shortcutContexts/commands/editor/open.js +26 -0
  564. package/shortcutContexts/commands/editor/open.mjs +23 -0
  565. package/shortcutContexts/commands/emptySelectedCells.js +10 -0
  566. package/shortcutContexts/commands/emptySelectedCells.mjs +7 -0
  567. package/shortcutContexts/commands/extendCellsSelection/down.js +14 -0
  568. package/shortcutContexts/commands/extendCellsSelection/down.mjs +11 -0
  569. package/shortcutContexts/commands/extendCellsSelection/downByViewportHeight.js +24 -0
  570. package/shortcutContexts/commands/extendCellsSelection/downByViewportHeight.mjs +21 -0
  571. package/shortcutContexts/commands/extendCellsSelection/index.js +26 -0
  572. package/shortcutContexts/commands/extendCellsSelection/index.mjs +22 -0
  573. package/shortcutContexts/commands/extendCellsSelection/left.js +14 -0
  574. package/shortcutContexts/commands/extendCellsSelection/left.mjs +11 -0
  575. package/shortcutContexts/commands/extendCellsSelection/right.js +14 -0
  576. package/shortcutContexts/commands/extendCellsSelection/right.mjs +11 -0
  577. package/shortcutContexts/commands/extendCellsSelection/toColumns.js +18 -0
  578. package/shortcutContexts/commands/extendCellsSelection/toColumns.mjs +15 -0
  579. package/shortcutContexts/commands/extendCellsSelection/toMostBottom.js +28 -0
  580. package/shortcutContexts/commands/extendCellsSelection/toMostBottom.mjs +25 -0
  581. package/shortcutContexts/commands/extendCellsSelection/toMostInlineEnd.js +18 -0
  582. package/shortcutContexts/commands/extendCellsSelection/toMostInlineEnd.mjs +15 -0
  583. package/shortcutContexts/commands/extendCellsSelection/toMostInlineStart.js +18 -0
  584. package/shortcutContexts/commands/extendCellsSelection/toMostInlineStart.mjs +15 -0
  585. package/shortcutContexts/commands/extendCellsSelection/toMostLeft.js +28 -0
  586. package/shortcutContexts/commands/extendCellsSelection/toMostLeft.mjs +25 -0
  587. package/shortcutContexts/commands/extendCellsSelection/toMostRight.js +28 -0
  588. package/shortcutContexts/commands/extendCellsSelection/toMostRight.mjs +25 -0
  589. package/shortcutContexts/commands/extendCellsSelection/toMostTop.js +28 -0
  590. package/shortcutContexts/commands/extendCellsSelection/toMostTop.mjs +25 -0
  591. package/shortcutContexts/commands/extendCellsSelection/toRows.js +18 -0
  592. package/shortcutContexts/commands/extendCellsSelection/toRows.mjs +15 -0
  593. package/shortcutContexts/commands/extendCellsSelection/up.js +14 -0
  594. package/shortcutContexts/commands/extendCellsSelection/up.mjs +11 -0
  595. package/shortcutContexts/commands/extendCellsSelection/upByViewportHeight.js +24 -0
  596. package/shortcutContexts/commands/extendCellsSelection/upByViewportHeight.mjs +21 -0
  597. package/shortcutContexts/commands/index.js +35 -0
  598. package/shortcutContexts/commands/index.mjs +31 -0
  599. package/shortcutContexts/commands/moveCellSelection/down.js +12 -0
  600. package/shortcutContexts/commands/moveCellSelection/down.mjs +9 -0
  601. package/shortcutContexts/commands/moveCellSelection/downByViewportHeight.js +32 -0
  602. package/shortcutContexts/commands/moveCellSelection/downByViewportHeight.mjs +29 -0
  603. package/shortcutContexts/commands/moveCellSelection/index.js +28 -0
  604. package/shortcutContexts/commands/moveCellSelection/index.mjs +24 -0
  605. package/shortcutContexts/commands/moveCellSelection/inlineEnd.js +11 -0
  606. package/shortcutContexts/commands/moveCellSelection/inlineEnd.mjs +8 -0
  607. package/shortcutContexts/commands/moveCellSelection/inlineStart.js +11 -0
  608. package/shortcutContexts/commands/moveCellSelection/inlineStart.mjs +8 -0
  609. package/shortcutContexts/commands/moveCellSelection/left.js +9 -0
  610. package/shortcutContexts/commands/moveCellSelection/left.mjs +6 -0
  611. package/shortcutContexts/commands/moveCellSelection/right.js +9 -0
  612. package/shortcutContexts/commands/moveCellSelection/right.mjs +6 -0
  613. package/shortcutContexts/commands/moveCellSelection/toMostBottom.js +16 -0
  614. package/shortcutContexts/commands/moveCellSelection/toMostBottom.mjs +13 -0
  615. package/shortcutContexts/commands/moveCellSelection/toMostBottomInlineEnd.js +17 -0
  616. package/shortcutContexts/commands/moveCellSelection/toMostBottomInlineEnd.mjs +14 -0
  617. package/shortcutContexts/commands/moveCellSelection/toMostInlineEnd.js +13 -0
  618. package/shortcutContexts/commands/moveCellSelection/toMostInlineEnd.mjs +10 -0
  619. package/shortcutContexts/commands/moveCellSelection/toMostInlineStart.js +16 -0
  620. package/shortcutContexts/commands/moveCellSelection/toMostInlineStart.mjs +13 -0
  621. package/shortcutContexts/commands/moveCellSelection/toMostLeft.js +18 -0
  622. package/shortcutContexts/commands/moveCellSelection/toMostLeft.mjs +15 -0
  623. package/shortcutContexts/commands/moveCellSelection/toMostRight.js +20 -0
  624. package/shortcutContexts/commands/moveCellSelection/toMostRight.mjs +17 -0
  625. package/shortcutContexts/commands/moveCellSelection/toMostTop.js +16 -0
  626. package/shortcutContexts/commands/moveCellSelection/toMostTop.mjs +13 -0
  627. package/shortcutContexts/commands/moveCellSelection/toMostTopInlineStart.js +18 -0
  628. package/shortcutContexts/commands/moveCellSelection/toMostTopInlineStart.mjs +15 -0
  629. package/shortcutContexts/commands/moveCellSelection/up.js +12 -0
  630. package/shortcutContexts/commands/moveCellSelection/up.mjs +9 -0
  631. package/shortcutContexts/commands/moveCellSelection/upByViewportHeight.js +32 -0
  632. package/shortcutContexts/commands/moveCellSelection/upByViewportHeight.mjs +29 -0
  633. package/shortcutContexts/commands/populateSelectedCellsData.js +28 -0
  634. package/shortcutContexts/commands/populateSelectedCellsData.mjs +25 -0
  635. package/shortcutContexts/commands/scrollToFocusedCell.js +34 -0
  636. package/shortcutContexts/commands/scrollToFocusedCell.mjs +31 -0
  637. package/shortcutContexts/commands/selectAll.js +11 -0
  638. package/shortcutContexts/commands/selectAll.mjs +8 -0
  639. package/shortcutContexts/constants.js +11 -0
  640. package/shortcutContexts/constants.mjs +8 -0
  641. package/shortcutContexts/editor.js +25 -0
  642. package/shortcutContexts/editor.mjs +21 -0
  643. package/shortcutContexts/grid.js +167 -0
  644. package/shortcutContexts/grid.mjs +163 -0
  645. package/shortcutContexts/index.js +24 -0
  646. package/shortcutContexts/index.mjs +11 -0
  647. package/shortcuts/context.d.ts +1 -0
  648. package/shortcuts/context.js +23 -4
  649. package/shortcuts/context.mjs +23 -5
  650. package/shortcuts/manager.js +31 -7
  651. package/shortcuts/manager.mjs +32 -7
  652. package/shortcuts/recorder.js +30 -14
  653. package/shortcuts/recorder.mjs +30 -14
  654. package/shortcuts/utils.js +19 -5
  655. package/shortcuts/utils.mjs +18 -4
  656. package/tableView.js +113 -16
  657. package/tableView.mjs +113 -15
  658. package/utils/dataStructures/linkedList.js +1 -2
  659. package/utils/dataStructures/priorityMap.js +2 -4
  660. package/utils/dataStructures/queue.js +1 -2
  661. package/utils/dataStructures/stack.js +1 -2
  662. package/utils/dataStructures/tree.js +3 -6
  663. package/utils/ghostTable.js +32 -17
  664. package/utils/ghostTable.mjs +31 -15
  665. package/utils/interval.js +1 -2
  666. package/utils/paginator.js +151 -0
  667. package/utils/paginator.mjs +147 -0
  668. package/utils/parseTable.js +527 -83
  669. package/utils/parseTable.mjs +523 -82
  670. package/utils/rootInstance.js +2 -4
  671. package/utils/samplesGenerator.js +21 -13
  672. package/utils/samplesGenerator.mjs +20 -11
  673. package/utils/staticRegister.js +1 -2
  674. package/validators/autocompleteValidator/autocompleteValidator.js +1 -2
  675. package/validators/dateValidator/dateValidator.js +1 -2
  676. package/validators/numericValidator/numericValidator.js +1 -2
  677. package/validators/timeValidator/timeValidator.js +1 -2
  678. package/3rdparty/walkontable/src/selection.js +0 -295
  679. package/3rdparty/walkontable/src/selection.mjs +0 -290
  680. package/plugins/contextMenu/predefinedItems.js +0 -76
  681. package/plugins/contextMenu/predefinedItems.mjs +0 -68
  682. package/plugins/copyPaste/clipboardData.js +0 -18
  683. package/plugins/copyPaste/clipboardData.mjs +0 -14
  684. package/plugins/copyPaste/focusableElement.js +0 -186
  685. package/plugins/copyPaste/focusableElement.mjs +0 -180
  686. package/plugins/copyPaste/pasteEvent.js +0 -14
  687. package/plugins/copyPaste/pasteEvent.mjs +0 -9
  688. package/selection/highlight/constants.js +0 -15
  689. package/selection/highlight/constants.mjs +0 -6
  690. package/selection/highlight/types/index.js +0 -35
  691. package/selection/highlight/types/index.mjs +0 -31
@@ -1,20 +1,34 @@
1
1
  import "core-js/modules/es.error.cause.js";
2
2
  import "core-js/modules/es.array.push.js";
3
+ function _classPrivateFieldInitSpec(obj, privateMap, value) { _checkPrivateRedeclaration(obj, privateMap); privateMap.set(obj, value); }
4
+ function _checkPrivateRedeclaration(obj, privateCollection) { if (privateCollection.has(obj)) { throw new TypeError("Cannot initialize the same private elements twice on an object"); } }
5
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
6
+ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
7
+ function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
8
+ function _classPrivateFieldSet(receiver, privateMap, value) { var descriptor = _classExtractFieldDescriptor(receiver, privateMap, "set"); _classApplyDescriptorSet(receiver, descriptor, value); return value; }
9
+ function _classApplyDescriptorSet(receiver, descriptor, value) { if (descriptor.set) { descriptor.set.call(receiver, value); } else { if (!descriptor.writable) { throw new TypeError("attempted to set read only private field"); } descriptor.value = value; } }
10
+ function _classPrivateFieldGet(receiver, privateMap) { var descriptor = _classExtractFieldDescriptor(receiver, privateMap, "get"); return _classApplyDescriptorGet(receiver, descriptor); }
11
+ function _classExtractFieldDescriptor(receiver, privateMap, action) { if (!privateMap.has(receiver)) { throw new TypeError("attempted to " + action + " private field on non-instance"); } return privateMap.get(receiver); }
12
+ function _classApplyDescriptorGet(receiver, descriptor) { if (descriptor.get) { return descriptor.get.call(receiver); } return descriptor.value; }
3
13
  import { addClass, closest, isChildOf, hasClass, outerWidth, outerHeight } from "../../helpers/dom/element.mjs";
14
+ import { stopImmediatePropagation } from "../../helpers/dom/event.mjs";
4
15
  import { deepClone, deepExtend, isObject } from "../../helpers/object.mjs";
5
16
  import EventManager from "../../eventManager.mjs";
6
17
  import { BasePlugin } from "../base/index.mjs";
7
18
  import CommentEditor from "./commentEditor.mjs";
8
- import { checkSelectionConsistency, markLabelAsSelected } from "../contextMenu/utils.mjs";
9
19
  import DisplaySwitch from "./displaySwitch.mjs";
10
- import * as C from "../../i18n/constants.mjs";
20
+ import { SEPARATOR } from "../contextMenu/predefinedItems/index.mjs";
21
+ import addEditCommentItem from "./contextMenuItem/addEditComment.mjs";
22
+ import removeCommentItem from "./contextMenuItem/removeComment.mjs";
23
+ import readOnlyCommentItem from "./contextMenuItem/readOnlyComment.mjs";
11
24
  export const PLUGIN_KEY = 'comments';
12
25
  export const PLUGIN_PRIORITY = 60;
13
- const privatePool = new WeakMap();
14
- const META_COMMENT = 'comment';
15
- const META_COMMENT_VALUE = 'value';
16
- const META_STYLE = 'style';
17
- const META_READONLY = 'readOnly';
26
+ export const META_COMMENT = 'comment';
27
+ export const META_COMMENT_VALUE = 'value';
28
+ export const META_STYLE = 'style';
29
+ export const META_READONLY = 'readOnly';
30
+ const SHORTCUTS_GROUP = PLUGIN_KEY;
31
+ const SHORTCUTS_CONTEXT_NAME = `plugin:${PLUGIN_KEY}`;
18
32
 
19
33
  /* eslint-disable jsdoc/require-description-complete-sentence */
20
34
  /**
@@ -106,55 +120,107 @@ const META_READONLY = 'readOnly';
106
120
  * ```
107
121
  * :::
108
122
  */
123
+ var _editor = /*#__PURE__*/new WeakMap();
124
+ var _displaySwitch = /*#__PURE__*/new WeakMap();
125
+ var _preventEditorAutoSwitch = /*#__PURE__*/new WeakMap();
126
+ var _preventEditorHiding = /*#__PURE__*/new WeakMap();
127
+ var _tempEditorDimensions = /*#__PURE__*/new WeakMap();
128
+ var _cellBelowCursor = /*#__PURE__*/new WeakMap();
129
+ var _commentValueBeforeSave = /*#__PURE__*/new WeakMap();
109
130
  export class Comments extends BasePlugin {
110
- static get PLUGIN_KEY() {
111
- return PLUGIN_KEY;
112
- }
113
- static get PLUGIN_PRIORITY() {
114
- return PLUGIN_PRIORITY;
115
- }
116
- constructor(hotInstance) {
117
- super(hotInstance);
131
+ constructor() {
132
+ super(...arguments);
133
+ /**
134
+ * Current cell range, an object with `from` property, with `row` and `col` properties (e.q. `{from: {row: 1, col: 6}}`).
135
+ *
136
+ * @type {object}
137
+ */
138
+ _defineProperty(this, "range", {});
139
+ /**
140
+ * Instance of {@link EventManager}.
141
+ *
142
+ * @protected
143
+ * @type {EventManager}
144
+ */
145
+ _defineProperty(this, "eventManager", null);
118
146
  /**
119
147
  * Instance of {@link CommentEditor}.
120
148
  *
121
149
  * @private
122
150
  * @type {CommentEditor}
123
151
  */
124
- this.editor = null;
152
+ _classPrivateFieldInitSpec(this, _editor, {
153
+ writable: true,
154
+ value: null
155
+ });
125
156
  /**
126
157
  * Instance of {@link DisplaySwitch}.
127
158
  *
128
159
  * @private
129
160
  * @type {DisplaySwitch}
130
161
  */
131
- this.displaySwitch = null;
162
+ _classPrivateFieldInitSpec(this, _displaySwitch, {
163
+ writable: true,
164
+ value: null
165
+ });
132
166
  /**
133
- * Instance of {@link EventManager}.
167
+ * Prevents showing/hiding editor that reacts on the logic triggered by the "mouseover" events.
134
168
  *
135
169
  * @private
136
- * @type {EventManager}
170
+ * @type {boolean}
137
171
  */
138
- this.eventManager = null;
172
+ _classPrivateFieldInitSpec(this, _preventEditorAutoSwitch, {
173
+ writable: true,
174
+ value: false
175
+ });
139
176
  /**
140
- * Current cell range, an object with `from` property, with `row` and `col` properties (e.q. `{from: {row: 1, col: 6}}`).
177
+ * Prevents hiding editor when the table viewport is scrolled and that scroll is triggered by the
178
+ * keyboard shortcut that insert or edits the comment.
141
179
  *
180
+ * @private
181
+ * @type {boolean}
182
+ */
183
+ _classPrivateFieldInitSpec(this, _preventEditorHiding, {
184
+ writable: true,
185
+ value: false
186
+ });
187
+ /**
188
+ * The property for holding editor dimensions for further processing.
189
+ *
190
+ * @private
142
191
  * @type {object}
143
192
  */
144
- this.range = {};
193
+ _classPrivateFieldInitSpec(this, _tempEditorDimensions, {
194
+ writable: true,
195
+ value: {}
196
+ });
145
197
  /**
146
- * Prevents showing/hiding editor that reacts on the logic triggered by the "mouseover" events.
198
+ * The flag that allows processing mousedown event correctly when comments editor is triggered.
147
199
  *
148
200
  * @private
149
201
  * @type {boolean}
150
202
  */
151
- this.preventEditorAutoSwitch = false;
152
- privatePool.set(this, {
153
- tempEditorDimensions: {},
154
- cellBelowCursor: null
203
+ _classPrivateFieldInitSpec(this, _cellBelowCursor, {
204
+ writable: true,
205
+ value: null
206
+ });
207
+ /**
208
+ * Holds the comment value before it's actually saved to the cell meta.
209
+ *
210
+ * @private
211
+ * @type {string}
212
+ */
213
+ _classPrivateFieldInitSpec(this, _commentValueBeforeSave, {
214
+ writable: true,
215
+ value: ''
155
216
  });
156
217
  }
157
-
218
+ static get PLUGIN_KEY() {
219
+ return PLUGIN_KEY;
220
+ }
221
+ static get PLUGIN_PRIORITY() {
222
+ return PLUGIN_PRIORITY;
223
+ }
158
224
  /**
159
225
  * Checks if the plugin is enabled in the handsontable settings. This method is executed in {@link Hooks#beforeInit}
160
226
  * hook and if it returns `true` then the {@link Comments#enablePlugin} method is called.
@@ -172,22 +238,23 @@ export class Comments extends BasePlugin {
172
238
  if (this.enabled) {
173
239
  return;
174
240
  }
175
- if (!this.editor) {
176
- this.editor = new CommentEditor(this.hot.rootDocument, this.hot.isRtl());
241
+ if (!_classPrivateFieldGet(this, _editor)) {
242
+ _classPrivateFieldSet(this, _editor, new CommentEditor(this.hot.rootDocument, this.hot.isRtl()));
177
243
  }
178
244
  if (!this.eventManager) {
179
245
  this.eventManager = new EventManager(this);
180
246
  }
181
- if (!this.displaySwitch) {
182
- this.displaySwitch = new DisplaySwitch(this.getDisplayDelaySetting());
247
+ if (!_classPrivateFieldGet(this, _displaySwitch)) {
248
+ _classPrivateFieldSet(this, _displaySwitch, new DisplaySwitch(this.getDisplayDelaySetting()));
183
249
  }
184
250
  this.addHook('afterContextMenuDefaultOptions', options => this.addToContextMenu(options));
185
251
  this.addHook('afterRenderer', (TD, row, col, prop, value, cellProperties) => this.onAfterRenderer(TD, cellProperties));
186
- this.addHook('afterScrollHorizontally', () => this.hide());
187
- this.addHook('afterScrollVertically', () => this.hide());
252
+ this.addHook('afterScroll', () => this.onAfterScroll());
188
253
  this.addHook('afterBeginEditing', () => this.hide());
189
- this.displaySwitch.addLocalHook('hide', () => this.hide());
190
- this.displaySwitch.addLocalHook('show', (row, col) => this.showAtCell(row, col));
254
+ this.addHook('afterDocumentKeyDown', event => this.onAfterDocumentKeyDown(event));
255
+ _classPrivateFieldGet(this, _displaySwitch).addLocalHook('hide', () => this.hide());
256
+ _classPrivateFieldGet(this, _displaySwitch).addLocalHook('show', (row, col) => this.showAtCell(row, col));
257
+ this.registerShortcuts();
191
258
  this.registerListeners();
192
259
  super.enablePlugin();
193
260
  }
@@ -199,19 +266,85 @@ export class Comments extends BasePlugin {
199
266
  * - [`comments`](@/api/options.md#comments)
200
267
  */
201
268
  updatePlugin() {
202
- this.disablePlugin();
203
- this.enablePlugin();
269
+ _classPrivateFieldGet(this, _displaySwitch).updateDelay(this.getDisplayDelaySetting());
204
270
  super.updatePlugin();
205
- this.displaySwitch.updateDelay(this.getDisplayDelaySetting());
206
271
  }
207
272
 
208
273
  /**
209
274
  * Disables the plugin functionality for this Handsontable instance.
210
275
  */
211
276
  disablePlugin() {
277
+ this.unregisterShortcuts();
212
278
  super.disablePlugin();
213
279
  }
214
280
 
281
+ /**
282
+ * Register shortcuts responsible for toggling context menu.
283
+ *
284
+ * @private
285
+ */
286
+ registerShortcuts() {
287
+ const manager = this.hot.getShortcutManager();
288
+ const gridContext = manager.getContext('grid');
289
+ const pluginContext = manager.addContext(SHORTCUTS_CONTEXT_NAME);
290
+ gridContext.addShortcut({
291
+ keys: [['Control', 'Alt', 'M']],
292
+ callback: () => {
293
+ const range = this.hot.getSelectedRangeLast();
294
+ _classPrivateFieldSet(this, _preventEditorHiding, true);
295
+ this.hot.scrollToFocusedCell(() => {
296
+ this.setRange(range);
297
+ this.show();
298
+ this.focusEditor();
299
+ manager.setActiveContextName(SHORTCUTS_CONTEXT_NAME);
300
+ this.hot._registerTimeout(() => {
301
+ _classPrivateFieldSet(this, _preventEditorHiding, false);
302
+ });
303
+ });
304
+ },
305
+ stopPropagation: true,
306
+ runOnlyIf: () => {
307
+ var _this$hot$getSelected;
308
+ return ((_this$hot$getSelected = this.hot.getSelectedRangeLast()) === null || _this$hot$getSelected === void 0 ? void 0 : _this$hot$getSelected.highlight.isCell()) && !_classPrivateFieldGet(this, _editor).isVisible();
309
+ },
310
+ group: SHORTCUTS_GROUP
311
+ });
312
+ pluginContext.addShortcut({
313
+ keys: [['Escape']],
314
+ callback: () => {
315
+ _classPrivateFieldGet(this, _editor).setValue(_classPrivateFieldGet(this, _commentValueBeforeSave));
316
+ this.hide();
317
+ manager.setActiveContextName('grid');
318
+ },
319
+ runOnlyIf: () => {
320
+ var _this$hot$getSelected2;
321
+ return ((_this$hot$getSelected2 = this.hot.getSelectedRangeLast()) === null || _this$hot$getSelected2 === void 0 ? void 0 : _this$hot$getSelected2.highlight.isCell()) && _classPrivateFieldGet(this, _editor).isVisible();
322
+ },
323
+ group: SHORTCUTS_GROUP
324
+ });
325
+ pluginContext.addShortcut({
326
+ keys: [['Control/Meta', 'Enter']],
327
+ callback: () => {
328
+ this.hide();
329
+ manager.setActiveContextName('grid');
330
+ },
331
+ runOnlyIf: () => {
332
+ var _this$hot$getSelected3;
333
+ return ((_this$hot$getSelected3 = this.hot.getSelectedRangeLast()) === null || _this$hot$getSelected3 === void 0 ? void 0 : _this$hot$getSelected3.highlight.isCell()) && _classPrivateFieldGet(this, _editor).isVisible();
334
+ },
335
+ group: SHORTCUTS_GROUP
336
+ });
337
+ }
338
+
339
+ /**
340
+ * Unregister shortcuts responsible for toggling context menu.
341
+ *
342
+ * @private
343
+ */
344
+ unregisterShortcuts() {
345
+ this.hot.getShortcutManager().getContext('grid').removeShortcutsByGroup(SHORTCUTS_GROUP);
346
+ }
347
+
215
348
  /**
216
349
  * Registers all necessary DOM listeners.
217
350
  *
@@ -221,12 +354,14 @@ export class Comments extends BasePlugin {
221
354
  const {
222
355
  rootDocument
223
356
  } = this.hot;
357
+ const editorElement = this.getEditorInputElement();
224
358
  this.eventManager.addEventListener(rootDocument, 'mouseover', event => this.onMouseOver(event));
225
359
  this.eventManager.addEventListener(rootDocument, 'mousedown', event => this.onMouseDown(event));
226
360
  this.eventManager.addEventListener(rootDocument, 'mouseup', () => this.onMouseUp());
227
- this.eventManager.addEventListener(this.editor.getInputElement(), 'blur', () => this.onEditorBlur());
228
- this.eventManager.addEventListener(this.editor.getInputElement(), 'mousedown', event => this.onEditorMouseDown(event));
229
- this.eventManager.addEventListener(this.editor.getInputElement(), 'mouseup', event => this.onEditorMouseUp(event));
361
+ this.eventManager.addEventListener(editorElement, 'focus', () => this.onEditorFocus());
362
+ this.eventManager.addEventListener(editorElement, 'blur', () => this.onEditorBlur());
363
+ this.eventManager.addEventListener(editorElement, 'mousedown', event => this.onEditorMouseDown(event));
364
+ this.eventManager.addEventListener(editorElement, 'mouseup', event => this.onEditorMouseUp(event));
230
365
  }
231
366
 
232
367
  /**
@@ -265,7 +400,7 @@ export class Comments extends BasePlugin {
265
400
  * @returns {boolean}
266
401
  */
267
402
  targetIsCommentTextArea(event) {
268
- return this.editor.getInputElement() === event.target;
403
+ return this.getEditorInputElement() === event.target;
269
404
  }
270
405
 
271
406
  /**
@@ -277,7 +412,7 @@ export class Comments extends BasePlugin {
277
412
  if (!this.range.from) {
278
413
  throw new Error('Before using this method, first set cell range (hot.getPlugin("comment").setRange())');
279
414
  }
280
- const editorValue = this.editor.getValue();
415
+ const editorValue = _classPrivateFieldGet(this, _editor).getValue();
281
416
  let comment = '';
282
417
  if (value !== null && value !== void 0) {
283
418
  comment = value;
@@ -366,6 +501,7 @@ export class Comments extends BasePlugin {
366
501
  * @returns {boolean} Returns `true` if comment editor was shown.
367
502
  */
368
503
  show() {
504
+ var _ref;
369
505
  if (!this.range.from) {
370
506
  throw new Error('Before using this method, first set cell range (hot.getPlugin("comment").setRange())');
371
507
  }
@@ -379,8 +515,9 @@ export class Comments extends BasePlugin {
379
515
  return false;
380
516
  }
381
517
  const meta = this.hot.getCellMeta(this.range.from.row, this.range.from.col);
382
- this.editor.setValue(meta[META_COMMENT] ? meta[META_COMMENT][META_COMMENT_VALUE] : null || '');
383
- this.editor.show();
518
+ _classPrivateFieldGet(this, _displaySwitch).cancelHiding();
519
+ _classPrivateFieldGet(this, _editor).setValue((_ref = meta[META_COMMENT] ? meta[META_COMMENT][META_COMMENT_VALUE] : null) !== null && _ref !== void 0 ? _ref : '');
520
+ _classPrivateFieldGet(this, _editor).show();
384
521
  this.refreshEditor(true);
385
522
  return true;
386
523
  }
@@ -403,7 +540,7 @@ export class Comments extends BasePlugin {
403
540
  * Hides the comment editor.
404
541
  */
405
542
  hide() {
406
- this.editor.hide();
543
+ _classPrivateFieldGet(this, _editor).hide();
407
544
  }
408
545
 
409
546
  /**
@@ -414,7 +551,7 @@ export class Comments extends BasePlugin {
414
551
  refreshEditor() {
415
552
  var _renderableRow, _renderableColumn;
416
553
  let force = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
417
- if (!force && (!this.range.from || !this.editor.isVisible())) {
554
+ if (!force && (!this.range.from || !_classPrivateFieldGet(this, _editor).isVisible())) {
418
555
  return;
419
556
  }
420
557
  const {
@@ -432,7 +569,7 @@ export class Comments extends BasePlugin {
432
569
 
433
570
  // Reset the editor position to (0, 0) so the opening direction calculation wouldn't be influenced by its
434
571
  // previous position
435
- this.editor.setPosition(0, 0);
572
+ _classPrivateFieldGet(this, _editor).setPosition(0, 0);
436
573
  if (renderableRow === null) {
437
574
  renderableRow = rowIndexMapper.getRenderableFromVisualIndex(rowIndexMapper.getNearestNotHiddenIndex(visualRow, -1));
438
575
  }
@@ -460,9 +597,9 @@ export class Comments extends BasePlugin {
460
597
  }, true);
461
598
  const commentStyle = this.getCommentMeta(visualRow, visualColumn, META_STYLE);
462
599
  if (commentStyle) {
463
- this.editor.setSize(commentStyle.width, commentStyle.height);
600
+ _classPrivateFieldGet(this, _editor).setSize(commentStyle.width, commentStyle.height);
464
601
  } else {
465
- this.editor.resetSize();
602
+ _classPrivateFieldGet(this, _editor).resetSize();
466
603
  }
467
604
  const lastColWidth = isBeforeRenderedColumns ? 0 : wtTable.getStretchedColumnWidth(renderableColumn);
468
605
  const lastRowHeight = targetingPreviousRow && !isBeforeRenderedRows ? outerHeight(TD) : 0;
@@ -475,7 +612,7 @@ export class Comments extends BasePlugin {
475
612
  const {
476
613
  width: editorWidth,
477
614
  height: editorHeight
478
- } = this.editor.getSize();
615
+ } = _classPrivateFieldGet(this, _editor).getSize();
479
616
  const {
480
617
  innerWidth,
481
618
  innerHeight
@@ -496,28 +633,15 @@ export class Comments extends BasePlugin {
496
633
  if (top + editorHeight > innerHeight) {
497
634
  y -= editorHeight - cellHeight + 1;
498
635
  }
499
- this.editor.setPosition(x, y);
500
- this.editor.setReadOnlyState(this.getCommentMeta(visualRow, visualColumn, META_READONLY));
636
+ _classPrivateFieldGet(this, _editor).setPosition(x, y);
637
+ _classPrivateFieldGet(this, _editor).setReadOnlyState(this.getCommentMeta(visualRow, visualColumn, META_READONLY));
501
638
  }
502
639
 
503
640
  /**
504
- * Checks if there is a comment for selected range.
505
- *
506
- * @private
507
- * @returns {boolean}
641
+ * Focuses the comments editor element.
508
642
  */
509
- checkSelectionCommentsConsistency() {
510
- const selected = this.hot.getSelectedRangeLast();
511
- if (!selected) {
512
- return false;
513
- }
514
- let hasComment = false;
515
- const cell = selected.getTopStartCorner(); // IN EXCEL THERE IS COMMENT ONLY FOR TOP LEFT CELL IN SELECTION
516
-
517
- if (this.getCommentMeta(cell.row, cell.col, META_COMMENT_VALUE)) {
518
- hasComment = true;
519
- }
520
- return hasComment;
643
+ focusEditor() {
644
+ _classPrivateFieldGet(this, _editor).focus();
521
645
  }
522
646
 
523
647
  /**
@@ -565,7 +689,7 @@ export class Comments extends BasePlugin {
565
689
  if (!this.hot.view || !this.hot.view._wt) {
566
690
  return;
567
691
  }
568
- if (!this.preventEditorAutoSwitch && !this.targetIsCommentTextArea(event)) {
692
+ if (!_classPrivateFieldGet(this, _preventEditorAutoSwitch) && !this.targetIsCommentTextArea(event)) {
569
693
  const eventCell = closest(event.target, 'TD', 'TBODY');
570
694
  let coordinates = null;
571
695
  if (eventCell) {
@@ -584,19 +708,18 @@ export class Comments extends BasePlugin {
584
708
  * @param {MouseEvent} event The `mouseover` event.
585
709
  */
586
710
  onMouseOver(event) {
587
- const priv = privatePool.get(this);
588
711
  const {
589
712
  rootDocument
590
713
  } = this.hot;
591
- if (this.preventEditorAutoSwitch || this.editor.isFocused() || hasClass(event.target, 'wtBorder') || priv.cellBelowCursor === event.target || !this.editor) {
714
+ if (_classPrivateFieldGet(this, _preventEditorAutoSwitch) || _classPrivateFieldGet(this, _editor).isFocused() || hasClass(event.target, 'wtBorder') || _classPrivateFieldGet(this, _cellBelowCursor) === event.target || !_classPrivateFieldGet(this, _editor)) {
592
715
  return;
593
716
  }
594
- priv.cellBelowCursor = rootDocument.elementFromPoint(event.clientX, event.clientY);
717
+ _classPrivateFieldSet(this, _cellBelowCursor, rootDocument.elementFromPoint(event.clientX, event.clientY));
595
718
  if (this.targetIsCellWithComment(event)) {
596
719
  const range = this.hot._createCellRange(this.hot.getCoords(event.target));
597
- this.displaySwitch.show(range);
720
+ _classPrivateFieldGet(this, _displaySwitch).show(range);
598
721
  } else if (isChildOf(event.target, rootDocument) && !this.targetIsCommentTextArea(event)) {
599
- this.displaySwitch.hide();
722
+ _classPrivateFieldGet(this, _displaySwitch).hide();
600
723
  }
601
724
  }
602
725
 
@@ -606,7 +729,7 @@ export class Comments extends BasePlugin {
606
729
  * @private
607
730
  */
608
731
  onMouseUp() {
609
- this.preventEditorAutoSwitch = false;
732
+ _classPrivateFieldSet(this, _preventEditorAutoSwitch, false);
610
733
  }
611
734
 
612
735
  /**
@@ -623,14 +746,29 @@ export class Comments extends BasePlugin {
623
746
  }
624
747
 
625
748
  /**
626
- * `blur` event callback for the comment editor.
749
+ * Hook observer the "blur" event from the comments editor element. The hook clears the
750
+ * editor content and gives back the keyboard shortcuts control by switching to the "grid" context.
627
751
  *
628
752
  * @private
629
753
  */
630
754
  onEditorBlur() {
755
+ _classPrivateFieldSet(this, _commentValueBeforeSave, '');
756
+ this.hot.getShortcutManager().setActiveContextName('grid');
631
757
  this.setComment();
632
758
  }
633
759
 
760
+ /**
761
+ * Hook observer the "focus" event from the comments editor element. The hook takes the control of
762
+ * the keyboard shortcuts by switching the context to plugins one.
763
+ *
764
+ * @private
765
+ */
766
+ onEditorFocus() {
767
+ _classPrivateFieldSet(this, _commentValueBeforeSave, this.getComment());
768
+ this.hot.listen();
769
+ this.hot.getShortcutManager().setActiveContextName(SHORTCUTS_CONTEXT_NAME);
770
+ }
771
+
634
772
  /**
635
773
  * `mousedown` hook. Along with `onEditorMouseUp` used to simulate the textarea resizing event.
636
774
  *
@@ -638,11 +776,10 @@ export class Comments extends BasePlugin {
638
776
  * @param {MouseEvent} event The `mousedown` event.
639
777
  */
640
778
  onEditorMouseDown(event) {
641
- const priv = privatePool.get(this);
642
- priv.tempEditorDimensions = {
779
+ _classPrivateFieldSet(this, _tempEditorDimensions, {
643
780
  width: outerWidth(event.target),
644
781
  height: outerHeight(event.target)
645
- };
782
+ });
646
783
  }
647
784
 
648
785
  /**
@@ -652,10 +789,9 @@ export class Comments extends BasePlugin {
652
789
  * @param {MouseEvent} event The `mouseup` event.
653
790
  */
654
791
  onEditorMouseUp(event) {
655
- const priv = privatePool.get(this);
656
792
  const currentWidth = outerWidth(event.target);
657
793
  const currentHeight = outerHeight(event.target);
658
- if (currentWidth !== priv.tempEditorDimensions.width + 1 || currentHeight !== priv.tempEditorDimensions.height + 2) {
794
+ if (currentWidth !== _classPrivateFieldGet(this, _tempEditorDimensions).width + 1 || currentHeight !== _classPrivateFieldGet(this, _tempEditorDimensions).height + 2) {
659
795
  this.updateCommentMeta(this.range.from.row, this.range.from.col, {
660
796
  [META_STYLE]: {
661
797
  width: currentWidth,
@@ -666,121 +802,36 @@ export class Comments extends BasePlugin {
666
802
  }
667
803
 
668
804
  /**
669
- * Context Menu's "Add comment" callback. Results in showing the comment editor.
805
+ * Observes the pressed keys and if there is already opened the comment editor prevents open
806
+ * the table editor into the fast edit mode.
670
807
  *
671
- * @private
672
- */
673
- onContextMenuAddComment() {
674
- const coords = this.hot.getSelectedRangeLast();
675
- this.preventEditorAutoSwitch = true;
676
- this.displaySwitch.cancelHiding();
677
- this.setRange({
678
- from: coords.highlight
679
- });
680
- this.show();
681
- this.hot.deselectCell();
682
- this.editor.focus();
683
- }
684
-
685
- /**
686
- * Context Menu's "remove comment" callback.
687
- *
688
- * @private
808
+ * @param {Event} event The keydown event.
689
809
  */
690
- onContextMenuRemoveComment() {
691
- const coords = this.hot.getSelectedRangeLast();
692
- this.preventEditorAutoSwitch = true;
693
- coords.forAll((row, column) => {
694
- if (row >= 0 && column >= 0) {
695
- this.removeCommentAtCell(row, column, false);
696
- }
697
- });
698
- this.hot.render();
810
+ onAfterDocumentKeyDown(event) {
811
+ if (_classPrivateFieldGet(this, _editor).isVisible()) {
812
+ stopImmediatePropagation(event);
813
+ }
699
814
  }
700
815
 
701
816
  /**
702
- * Context Menu's "make comment read-only" callback.
703
- *
704
- * @private
817
+ * Observes the changes in the scroll position if triggered it hides the comment editor.
705
818
  */
706
- onContextMenuMakeReadOnly() {
707
- const coords = this.hot.getSelectedRangeLast();
708
- this.preventEditorAutoSwitch = true;
709
- coords.forAll((row, column) => {
710
- if (row >= 0 && column >= 0) {
711
- const currentState = !!this.getCommentMeta(row, column, META_READONLY);
712
- this.updateCommentMeta(row, column, {
713
- [META_READONLY]: !currentState
714
- });
715
- }
716
- });
819
+ onAfterScroll() {
820
+ if (!_classPrivateFieldGet(this, _preventEditorHiding)) {
821
+ this.hide();
822
+ }
717
823
  }
718
824
 
719
825
  /**
720
826
  * Add Comments plugin options to the Context Menu.
721
827
  *
722
828
  * @private
723
- * @param {object} defaultOptions The menu options.
724
- */
725
- addToContextMenu(defaultOptions) {
726
- const isThereAnyCellRendered = () => {
727
- return this.hot.rowIndexMapper.getRenderableIndexesLength() > 0 && this.hot.columnIndexMapper.getRenderableIndexesLength() > 0;
728
- };
729
- defaultOptions.items.push({
730
- name: '---------'
731
- }, {
732
- key: 'commentsAddEdit',
733
- name: () => {
734
- if (this.checkSelectionCommentsConsistency()) {
735
- return this.hot.getTranslatedPhrase(C.CONTEXTMENU_ITEMS_EDIT_COMMENT);
736
- }
737
- return this.hot.getTranslatedPhrase(C.CONTEXTMENU_ITEMS_ADD_COMMENT);
738
- },
739
- callback: () => this.onContextMenuAddComment(),
740
- disabled: () => {
741
- if (!isThereAnyCellRendered()) {
742
- return true;
743
- }
744
- return !(this.hot.getSelectedLast() && !this.hot.selection.isSelectedByCorner());
745
- }
746
- }, {
747
- key: 'commentsRemove',
748
- name() {
749
- return this.getTranslatedPhrase(C.CONTEXTMENU_ITEMS_REMOVE_COMMENT);
750
- },
751
- callback: () => this.onContextMenuRemoveComment(),
752
- disabled: () => {
753
- if (!isThereAnyCellRendered()) {
754
- return true;
755
- }
756
- return !(this.hot.getSelectedLast() && !this.hot.selection.isSelectedByCorner());
757
- }
758
- }, {
759
- key: 'commentsReadOnly',
760
- name() {
761
- let label = this.getTranslatedPhrase(C.CONTEXTMENU_ITEMS_READ_ONLY_COMMENT);
762
- const hasProperty = checkSelectionConsistency(this.getSelectedRangeLast(), (row, col) => {
763
- let readOnlyProperty = this.getCellMeta(row, col)[META_COMMENT];
764
- if (readOnlyProperty) {
765
- readOnlyProperty = readOnlyProperty[META_READONLY];
766
- }
767
- if (readOnlyProperty) {
768
- return true;
769
- }
770
- });
771
- if (hasProperty) {
772
- label = markLabelAsSelected(label);
773
- }
774
- return label;
775
- },
776
- callback: () => this.onContextMenuMakeReadOnly(),
777
- disabled: () => {
778
- if (!isThereAnyCellRendered()) {
779
- return true;
780
- }
781
- return !(this.hot.getSelectedLast() && !this.hot.selection.isSelectedByCorner()) || !this.checkSelectionCommentsConsistency();
782
- }
783
- });
829
+ * @param {object} options The menu options.
830
+ */
831
+ addToContextMenu(options) {
832
+ options.items.push({
833
+ name: SEPARATOR
834
+ }, addEditCommentItem(this), removeCommentItem(this), readOnlyCommentItem(this));
784
835
  }
785
836
 
786
837
  /**
@@ -796,15 +847,25 @@ export class Comments extends BasePlugin {
796
847
  }
797
848
  }
798
849
 
850
+ /**
851
+ * Gets the editors input element.
852
+ *
853
+ * @private
854
+ * @returns {HTMLTextAreaElement}
855
+ */
856
+ getEditorInputElement() {
857
+ return _classPrivateFieldGet(this, _editor).getInputElement();
858
+ }
859
+
799
860
  /**
800
861
  * Destroys the plugin instance.
801
862
  */
802
863
  destroy() {
803
- if (this.editor) {
804
- this.editor.destroy();
864
+ if (_classPrivateFieldGet(this, _editor)) {
865
+ _classPrivateFieldGet(this, _editor).destroy();
805
866
  }
806
- if (this.displaySwitch) {
807
- this.displaySwitch.destroy();
867
+ if (_classPrivateFieldGet(this, _displaySwitch)) {
868
+ _classPrivateFieldGet(this, _displaySwitch).destroy();
808
869
  }
809
870
  super.destroy();
810
871
  }