@atlaskit/editor-plugin-table 0.0.0 → 0.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (617) hide show
  1. package/CHANGELOG.md +23 -0
  2. package/dist/cjs/plugins/table/commands/clear.js +64 -0
  3. package/dist/cjs/plugins/table/commands/collapse.js +24 -0
  4. package/dist/cjs/plugins/table/commands/go-to-next-cell.js +66 -0
  5. package/dist/cjs/plugins/table/commands/hover.js +183 -0
  6. package/dist/cjs/plugins/table/commands/index.js +235 -0
  7. package/dist/cjs/plugins/table/commands/insert.js +186 -0
  8. package/dist/cjs/plugins/table/commands/misc.js +509 -0
  9. package/dist/cjs/plugins/table/commands/selection.js +419 -0
  10. package/dist/cjs/plugins/table/commands/sort.js +94 -0
  11. package/dist/cjs/plugins/table/commands/split-cell.js +38 -0
  12. package/dist/cjs/plugins/table/commands/toggle.js +124 -0
  13. package/dist/cjs/plugins/table/commands-with-analytics.js +543 -0
  14. package/dist/cjs/plugins/table/create-plugin-config.js +31 -0
  15. package/dist/cjs/plugins/table/event-handlers.js +441 -0
  16. package/dist/cjs/plugins/table/handlers.js +155 -0
  17. package/dist/cjs/plugins/table/index.js +374 -0
  18. package/dist/cjs/plugins/table/nodeviews/OverflowShadowsObserver.js +182 -0
  19. package/dist/cjs/plugins/table/nodeviews/TableComponent.js +610 -0
  20. package/dist/cjs/plugins/table/nodeviews/table.js +261 -0
  21. package/dist/cjs/plugins/table/nodeviews/tableCell.js +123 -0
  22. package/dist/cjs/plugins/table/nodeviews/types.js +5 -0
  23. package/dist/cjs/plugins/table/nodeviews/update-overflow-shadows.js +67 -0
  24. package/dist/cjs/plugins/table/pm-plugins/decorations/plugin.js +81 -0
  25. package/dist/cjs/plugins/table/pm-plugins/decorations/utils/column-controls.js +88 -0
  26. package/dist/cjs/plugins/table/pm-plugins/decorations/utils/column-resizing.js +55 -0
  27. package/dist/cjs/plugins/table/pm-plugins/decorations/utils/compose-decorations.js +21 -0
  28. package/dist/cjs/plugins/table/pm-plugins/decorations/utils/index.js +35 -0
  29. package/dist/cjs/plugins/table/pm-plugins/decorations/utils/types.js +5 -0
  30. package/dist/cjs/plugins/table/pm-plugins/default-table-selection.js +12 -0
  31. package/dist/cjs/plugins/table/pm-plugins/keymap.js +59 -0
  32. package/dist/cjs/plugins/table/pm-plugins/main.js +308 -0
  33. package/dist/cjs/plugins/table/pm-plugins/plugin-factory.js +65 -0
  34. package/dist/cjs/plugins/table/pm-plugins/plugin-key.js +11 -0
  35. package/dist/cjs/plugins/table/pm-plugins/safari-delayed-dom-selection-syncing-workaround.js +79 -0
  36. package/dist/cjs/plugins/table/pm-plugins/safari-delete-composition-text-issue-workaround.js +118 -0
  37. package/dist/cjs/plugins/table/pm-plugins/sticky-headers/commands.js +30 -0
  38. package/dist/cjs/plugins/table/pm-plugins/sticky-headers/index.js +51 -0
  39. package/dist/cjs/plugins/table/pm-plugins/sticky-headers/nodeviews/dom.js +46 -0
  40. package/dist/cjs/plugins/table/pm-plugins/sticky-headers/nodeviews/tableRow.js +590 -0
  41. package/dist/cjs/plugins/table/pm-plugins/sticky-headers/plugin-key.js +11 -0
  42. package/dist/cjs/plugins/table/pm-plugins/sticky-headers/plugin-state.js +68 -0
  43. package/dist/cjs/plugins/table/pm-plugins/sticky-headers/plugin.js +34 -0
  44. package/dist/cjs/plugins/table/pm-plugins/sticky-headers/types.js +5 -0
  45. package/dist/cjs/plugins/table/pm-plugins/sticky-headers/util.js +25 -0
  46. package/dist/cjs/plugins/table/pm-plugins/table-local-id.js +205 -0
  47. package/dist/cjs/plugins/table/pm-plugins/table-resizing/commands.js +158 -0
  48. package/dist/cjs/plugins/table/pm-plugins/table-resizing/event-handlers.js +182 -0
  49. package/dist/cjs/plugins/table/pm-plugins/table-resizing/index.js +29 -0
  50. package/dist/cjs/plugins/table/pm-plugins/table-resizing/plugin-factory.js +40 -0
  51. package/dist/cjs/plugins/table/pm-plugins/table-resizing/plugin-key.js +11 -0
  52. package/dist/cjs/plugins/table/pm-plugins/table-resizing/plugin.js +70 -0
  53. package/dist/cjs/plugins/table/pm-plugins/table-resizing/reducer.js +46 -0
  54. package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/colgroup.js +71 -0
  55. package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/column-state.js +107 -0
  56. package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/content-width.js +112 -0
  57. package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/dom.js +158 -0
  58. package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/index.js +209 -0
  59. package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/misc.js +115 -0
  60. package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/resize-column.js +19 -0
  61. package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/resize-logic.js +279 -0
  62. package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/resize-state.js +364 -0
  63. package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/scale-table.js +132 -0
  64. package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/types.js +5 -0
  65. package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/unit-to-number.js +12 -0
  66. package/dist/cjs/plugins/table/pm-plugins/table-selection-keymap.js +23 -0
  67. package/dist/cjs/plugins/table/reducer.js +107 -0
  68. package/dist/cjs/plugins/table/todo-stubs.js +10 -0
  69. package/dist/cjs/plugins/table/toolbar.js +325 -0
  70. package/dist/cjs/plugins/table/transforms/column-width.js +196 -0
  71. package/dist/cjs/plugins/table/transforms/delete-columns.js +293 -0
  72. package/dist/cjs/plugins/table/transforms/delete-rows.js +176 -0
  73. package/dist/cjs/plugins/table/transforms/fix-tables.js +250 -0
  74. package/dist/cjs/plugins/table/transforms/index.js +85 -0
  75. package/dist/cjs/plugins/table/transforms/merge.js +349 -0
  76. package/dist/cjs/plugins/table/transforms/metadata.js +23 -0
  77. package/dist/cjs/plugins/table/transforms/replace-table.js +48 -0
  78. package/dist/cjs/plugins/table/transforms/split.js +92 -0
  79. package/dist/cjs/plugins/table/types.js +106 -0
  80. package/dist/cjs/plugins/table/ui/FloatingContextualButton/index.js +194 -0
  81. package/dist/cjs/plugins/table/ui/FloatingContextualButton/styles.js +26 -0
  82. package/dist/cjs/plugins/table/ui/FloatingContextualMenu/ContextualMenu.js +529 -0
  83. package/dist/cjs/plugins/table/ui/FloatingContextualMenu/index.js +116 -0
  84. package/dist/cjs/plugins/table/ui/FloatingContextualMenu/styles.js +34 -0
  85. package/dist/cjs/plugins/table/ui/FloatingDeleteButton/DeleteButton.js +49 -0
  86. package/dist/cjs/plugins/table/ui/FloatingDeleteButton/getPopUpOptions.js +71 -0
  87. package/dist/cjs/plugins/table/ui/FloatingDeleteButton/index.js +365 -0
  88. package/dist/cjs/plugins/table/ui/FloatingDeleteButton/types.js +5 -0
  89. package/dist/cjs/plugins/table/ui/FloatingInsertButton/InsertButton.js +118 -0
  90. package/dist/cjs/plugins/table/ui/FloatingInsertButton/getPopupOptions.js +108 -0
  91. package/dist/cjs/plugins/table/ui/FloatingInsertButton/index.js +244 -0
  92. package/dist/cjs/plugins/table/ui/LayoutButton/index.js +255 -0
  93. package/dist/cjs/plugins/table/ui/TableFloatingControls/CornerControls/index.js +140 -0
  94. package/dist/cjs/plugins/table/ui/TableFloatingControls/NumberColumn/index.js +146 -0
  95. package/dist/cjs/plugins/table/ui/TableFloatingControls/RowControls/index.js +135 -0
  96. package/dist/cjs/plugins/table/ui/TableFloatingControls/index.js +229 -0
  97. package/dist/cjs/plugins/table/ui/common-styles.js +48 -0
  98. package/dist/cjs/plugins/table/ui/consts.js +109 -0
  99. package/dist/cjs/plugins/table/ui/messages.js +48 -0
  100. package/dist/cjs/plugins/table/ui/ui-styles.js +116 -0
  101. package/dist/cjs/plugins/table/utils/analytics.js +86 -0
  102. package/dist/cjs/plugins/table/utils/collapse.js +98 -0
  103. package/dist/cjs/plugins/table/utils/column-controls.js +234 -0
  104. package/dist/cjs/plugins/table/utils/decoration.js +405 -0
  105. package/dist/cjs/plugins/table/utils/dom.js +224 -0
  106. package/dist/cjs/plugins/table/utils/get-allow-add-column-custom-step.js +13 -0
  107. package/dist/cjs/plugins/table/utils/index.js +355 -0
  108. package/dist/cjs/plugins/table/utils/nodes.js +159 -0
  109. package/dist/cjs/plugins/table/utils/paste.js +148 -0
  110. package/dist/cjs/plugins/table/utils/referentiality.js +29 -0
  111. package/dist/cjs/plugins/table/utils/row-controls.js +254 -0
  112. package/dist/cjs/plugins/table/utils/selection.js +116 -0
  113. package/dist/cjs/plugins/table/utils/table.js +48 -0
  114. package/dist/cjs/plugins/table/utils/update-plugin-state-decorations.js +16 -0
  115. package/dist/cjs/plugins/table-plugin.js +4 -45
  116. package/dist/cjs/version.json +1 -1
  117. package/dist/es2019/plugins/table/commands/clear.js +48 -0
  118. package/dist/es2019/plugins/table/commands/collapse.js +14 -0
  119. package/dist/es2019/plugins/table/commands/go-to-next-cell.js +47 -0
  120. package/dist/es2019/plugins/table/commands/hover.js +117 -0
  121. package/dist/es2019/plugins/table/commands/index.js +7 -0
  122. package/dist/es2019/plugins/table/commands/insert.js +141 -0
  123. package/dist/es2019/plugins/table/commands/misc.js +405 -0
  124. package/dist/es2019/plugins/table/commands/selection.js +369 -0
  125. package/dist/es2019/plugins/table/commands/sort.js +74 -0
  126. package/dist/es2019/plugins/table/commands/split-cell.js +29 -0
  127. package/dist/es2019/plugins/table/commands/toggle.js +76 -0
  128. package/dist/es2019/plugins/table/commands-with-analytics.js +409 -0
  129. package/dist/es2019/plugins/table/create-plugin-config.js +14 -0
  130. package/dist/es2019/plugins/table/event-handlers.js +387 -0
  131. package/dist/es2019/plugins/table/handlers.js +123 -0
  132. package/dist/es2019/plugins/table/index.js +340 -0
  133. package/dist/es2019/plugins/table/nodeviews/OverflowShadowsObserver.js +159 -0
  134. package/dist/es2019/plugins/table/nodeviews/TableComponent.js +578 -0
  135. package/dist/es2019/plugins/table/nodeviews/table.js +200 -0
  136. package/dist/es2019/plugins/table/nodeviews/tableCell.js +77 -0
  137. package/dist/es2019/plugins/table/nodeviews/types.js +1 -0
  138. package/dist/es2019/plugins/table/nodeviews/update-overflow-shadows.js +52 -0
  139. package/dist/es2019/plugins/table/pm-plugins/decorations/plugin.js +52 -0
  140. package/dist/es2019/plugins/table/pm-plugins/decorations/utils/column-controls.js +67 -0
  141. package/dist/es2019/plugins/table/pm-plugins/decorations/utils/column-resizing.js +27 -0
  142. package/dist/es2019/plugins/table/pm-plugins/decorations/utils/compose-decorations.js +7 -0
  143. package/dist/es2019/plugins/table/pm-plugins/decorations/utils/index.js +3 -0
  144. package/dist/es2019/plugins/table/pm-plugins/decorations/utils/types.js +1 -0
  145. package/dist/es2019/plugins/table/pm-plugins/default-table-selection.js +5 -0
  146. package/dist/es2019/plugins/table/pm-plugins/keymap.js +34 -0
  147. package/dist/es2019/plugins/table/pm-plugins/main.js +274 -0
  148. package/dist/es2019/plugins/table/pm-plugins/plugin-factory.js +46 -0
  149. package/dist/es2019/plugins/table/pm-plugins/plugin-key.js +2 -0
  150. package/dist/es2019/plugins/table/pm-plugins/safari-delayed-dom-selection-syncing-workaround.js +66 -0
  151. package/dist/es2019/plugins/table/pm-plugins/safari-delete-composition-text-issue-workaround.js +106 -0
  152. package/dist/es2019/plugins/table/pm-plugins/sticky-headers/commands.js +9 -0
  153. package/dist/es2019/plugins/table/pm-plugins/sticky-headers/index.js +5 -0
  154. package/dist/es2019/plugins/table/pm-plugins/sticky-headers/nodeviews/dom.js +34 -0
  155. package/dist/es2019/plugins/table/pm-plugins/sticky-headers/nodeviews/tableRow.js +546 -0
  156. package/dist/es2019/plugins/table/pm-plugins/sticky-headers/plugin-key.js +2 -0
  157. package/dist/es2019/plugins/table/pm-plugins/sticky-headers/plugin-state.js +47 -0
  158. package/dist/es2019/plugins/table/pm-plugins/sticky-headers/plugin.js +17 -0
  159. package/dist/es2019/plugins/table/pm-plugins/sticky-headers/types.js +1 -0
  160. package/dist/es2019/plugins/table/pm-plugins/sticky-headers/util.js +14 -0
  161. package/dist/es2019/plugins/table/pm-plugins/table-local-id.js +203 -0
  162. package/dist/es2019/plugins/table/pm-plugins/table-resizing/commands.js +109 -0
  163. package/dist/es2019/plugins/table/pm-plugins/table-resizing/event-handlers.js +173 -0
  164. package/dist/es2019/plugins/table/pm-plugins/table-resizing/index.js +3 -0
  165. package/dist/es2019/plugins/table/pm-plugins/table-resizing/plugin-factory.js +20 -0
  166. package/dist/es2019/plugins/table/pm-plugins/table-resizing/plugin-key.js +2 -0
  167. package/dist/es2019/plugins/table/pm-plugins/table-resizing/plugin.js +58 -0
  168. package/dist/es2019/plugins/table/pm-plugins/table-resizing/reducer.js +31 -0
  169. package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/colgroup.js +45 -0
  170. package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/column-state.js +78 -0
  171. package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/content-width.js +97 -0
  172. package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/dom.js +124 -0
  173. package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/index.js +9 -0
  174. package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/misc.js +90 -0
  175. package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/resize-column.js +8 -0
  176. package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/resize-logic.js +221 -0
  177. package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/resize-state.js +276 -0
  178. package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/scale-table.js +105 -0
  179. package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/types.js +1 -0
  180. package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/unit-to-number.js +1 -0
  181. package/dist/es2019/plugins/table/pm-plugins/table-selection-keymap.js +10 -0
  182. package/dist/es2019/plugins/table/reducer.js +103 -0
  183. package/dist/es2019/plugins/table/todo-stubs.js +1 -0
  184. package/dist/es2019/plugins/table/toolbar.js +287 -0
  185. package/dist/es2019/plugins/table/transforms/column-width.js +163 -0
  186. package/dist/es2019/plugins/table/transforms/delete-columns.js +247 -0
  187. package/dist/es2019/plugins/table/transforms/delete-rows.js +135 -0
  188. package/dist/es2019/plugins/table/transforms/fix-tables.js +218 -0
  189. package/dist/es2019/plugins/table/transforms/index.js +7 -0
  190. package/dist/es2019/plugins/table/transforms/merge.js +312 -0
  191. package/dist/es2019/plugins/table/transforms/metadata.js +11 -0
  192. package/dist/es2019/plugins/table/transforms/replace-table.js +33 -0
  193. package/dist/es2019/plugins/table/transforms/split.js +72 -0
  194. package/dist/es2019/plugins/table/types.js +84 -0
  195. package/dist/es2019/plugins/table/ui/FloatingContextualButton/index.js +142 -0
  196. package/dist/es2019/plugins/table/ui/FloatingContextualButton/styles.js +28 -0
  197. package/dist/es2019/plugins/table/ui/FloatingContextualMenu/ContextualMenu.js +482 -0
  198. package/dist/es2019/plugins/table/ui/FloatingContextualMenu/index.js +99 -0
  199. package/dist/es2019/plugins/table/ui/FloatingContextualMenu/styles.js +48 -0
  200. package/dist/es2019/plugins/table/ui/FloatingDeleteButton/DeleteButton.js +36 -0
  201. package/dist/es2019/plugins/table/ui/FloatingDeleteButton/getPopUpOptions.js +59 -0
  202. package/dist/es2019/plugins/table/ui/FloatingDeleteButton/index.js +302 -0
  203. package/dist/es2019/plugins/table/ui/FloatingDeleteButton/types.js +1 -0
  204. package/dist/es2019/plugins/table/ui/FloatingInsertButton/InsertButton.js +96 -0
  205. package/dist/es2019/plugins/table/ui/FloatingInsertButton/getPopupOptions.js +96 -0
  206. package/dist/es2019/plugins/table/ui/FloatingInsertButton/index.js +199 -0
  207. package/dist/es2019/plugins/table/ui/LayoutButton/index.js +195 -0
  208. package/dist/es2019/plugins/table/ui/TableFloatingControls/CornerControls/index.js +95 -0
  209. package/dist/es2019/plugins/table/ui/TableFloatingControls/NumberColumn/index.js +91 -0
  210. package/dist/es2019/plugins/table/ui/TableFloatingControls/RowControls/index.js +82 -0
  211. package/dist/es2019/plugins/table/ui/TableFloatingControls/index.js +158 -0
  212. package/dist/es2019/plugins/table/ui/common-styles.js +647 -0
  213. package/dist/es2019/plugins/table/ui/consts.js +61 -0
  214. package/dist/es2019/plugins/table/ui/messages.js +38 -0
  215. package/dist/es2019/plugins/table/ui/ui-styles.js +398 -0
  216. package/dist/es2019/plugins/table/utils/analytics.js +65 -0
  217. package/dist/es2019/plugins/table/utils/collapse.js +84 -0
  218. package/dist/es2019/plugins/table/utils/column-controls.js +178 -0
  219. package/dist/es2019/plugins/table/utils/decoration.js +346 -0
  220. package/dist/es2019/plugins/table/utils/dom.js +160 -0
  221. package/dist/es2019/plugins/table/utils/get-allow-add-column-custom-step.js +5 -0
  222. package/dist/es2019/plugins/table/utils/index.js +10 -0
  223. package/dist/es2019/plugins/table/utils/nodes.js +104 -0
  224. package/dist/es2019/plugins/table/utils/paste.js +117 -0
  225. package/dist/es2019/plugins/table/utils/referentiality.js +18 -0
  226. package/dist/es2019/plugins/table/utils/row-controls.js +210 -0
  227. package/dist/es2019/plugins/table/utils/selection.js +95 -0
  228. package/dist/es2019/plugins/table/utils/table.js +27 -0
  229. package/dist/es2019/plugins/table/utils/update-plugin-state-decorations.js +3 -0
  230. package/dist/es2019/plugins/table-plugin.js +1 -44
  231. package/dist/es2019/version.json +1 -1
  232. package/dist/esm/plugins/table/commands/clear.js +48 -0
  233. package/dist/esm/plugins/table/commands/collapse.js +14 -0
  234. package/dist/esm/plugins/table/commands/go-to-next-cell.js +50 -0
  235. package/dist/esm/plugins/table/commands/hover.js +149 -0
  236. package/dist/esm/plugins/table/commands/index.js +7 -0
  237. package/dist/esm/plugins/table/commands/insert.js +153 -0
  238. package/dist/esm/plugins/table/commands/misc.js +427 -0
  239. package/dist/esm/plugins/table/commands/selection.js +401 -0
  240. package/dist/esm/plugins/table/commands/sort.js +79 -0
  241. package/dist/esm/plugins/table/commands/split-cell.js +28 -0
  242. package/dist/esm/plugins/table/commands/toggle.js +97 -0
  243. package/dist/esm/plugins/table/commands-with-analytics.js +464 -0
  244. package/dist/esm/plugins/table/create-plugin-config.js +20 -0
  245. package/dist/esm/plugins/table/event-handlers.js +387 -0
  246. package/dist/esm/plugins/table/handlers.js +140 -0
  247. package/dist/esm/plugins/table/index.js +338 -0
  248. package/dist/esm/plugins/table/nodeviews/OverflowShadowsObserver.js +177 -0
  249. package/dist/esm/plugins/table/nodeviews/TableComponent.js +596 -0
  250. package/dist/esm/plugins/table/nodeviews/table.js +235 -0
  251. package/dist/esm/plugins/table/nodeviews/tableCell.js +111 -0
  252. package/dist/esm/plugins/table/nodeviews/types.js +1 -0
  253. package/dist/esm/plugins/table/nodeviews/update-overflow-shadows.js +54 -0
  254. package/dist/esm/plugins/table/pm-plugins/decorations/plugin.js +58 -0
  255. package/dist/esm/plugins/table/pm-plugins/decorations/utils/column-controls.js +71 -0
  256. package/dist/esm/plugins/table/pm-plugins/decorations/utils/column-resizing.js +40 -0
  257. package/dist/esm/plugins/table/pm-plugins/decorations/utils/compose-decorations.js +12 -0
  258. package/dist/esm/plugins/table/pm-plugins/decorations/utils/index.js +3 -0
  259. package/dist/esm/plugins/table/pm-plugins/decorations/utils/types.js +1 -0
  260. package/dist/esm/plugins/table/pm-plugins/default-table-selection.js +5 -0
  261. package/dist/esm/plugins/table/pm-plugins/keymap.js +36 -0
  262. package/dist/esm/plugins/table/pm-plugins/main.js +278 -0
  263. package/dist/esm/plugins/table/pm-plugins/plugin-factory.js +51 -0
  264. package/dist/esm/plugins/table/pm-plugins/plugin-key.js +2 -0
  265. package/dist/esm/plugins/table/pm-plugins/safari-delayed-dom-selection-syncing-workaround.js +66 -0
  266. package/dist/esm/plugins/table/pm-plugins/safari-delete-composition-text-issue-workaround.js +102 -0
  267. package/dist/esm/plugins/table/pm-plugins/sticky-headers/commands.js +17 -0
  268. package/dist/esm/plugins/table/pm-plugins/sticky-headers/index.js +5 -0
  269. package/dist/esm/plugins/table/pm-plugins/sticky-headers/nodeviews/dom.js +34 -0
  270. package/dist/esm/plugins/table/pm-plugins/sticky-headers/nodeviews/tableRow.js +588 -0
  271. package/dist/esm/plugins/table/pm-plugins/sticky-headers/plugin-key.js +2 -0
  272. package/dist/esm/plugins/table/pm-plugins/sticky-headers/plugin-state.js +57 -0
  273. package/dist/esm/plugins/table/pm-plugins/sticky-headers/plugin.js +21 -0
  274. package/dist/esm/plugins/table/pm-plugins/sticky-headers/types.js +1 -0
  275. package/dist/esm/plugins/table/pm-plugins/sticky-headers/util.js +16 -0
  276. package/dist/esm/plugins/table/pm-plugins/table-local-id.js +205 -0
  277. package/dist/esm/plugins/table/pm-plugins/table-resizing/commands.js +127 -0
  278. package/dist/esm/plugins/table/pm-plugins/table-resizing/event-handlers.js +159 -0
  279. package/dist/esm/plugins/table/pm-plugins/table-resizing/index.js +3 -0
  280. package/dist/esm/plugins/table/pm-plugins/table-resizing/plugin-factory.js +26 -0
  281. package/dist/esm/plugins/table/pm-plugins/table-resizing/plugin-key.js +2 -0
  282. package/dist/esm/plugins/table/pm-plugins/table-resizing/plugin.js +52 -0
  283. package/dist/esm/plugins/table/pm-plugins/table-resizing/reducer.js +35 -0
  284. package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/colgroup.js +50 -0
  285. package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/column-state.js +80 -0
  286. package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/content-width.js +104 -0
  287. package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/dom.js +125 -0
  288. package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/index.js +9 -0
  289. package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/misc.js +88 -0
  290. package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/resize-column.js +8 -0
  291. package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/resize-logic.js +257 -0
  292. package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/resize-state.js +320 -0
  293. package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/scale-table.js +109 -0
  294. package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/types.js +1 -0
  295. package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/unit-to-number.js +3 -0
  296. package/dist/esm/plugins/table/pm-plugins/table-selection-keymap.js +10 -0
  297. package/dist/esm/plugins/table/reducer.js +95 -0
  298. package/dist/esm/plugins/table/todo-stubs.js +1 -0
  299. package/dist/esm/plugins/table/toolbar.js +290 -0
  300. package/dist/esm/plugins/table/transforms/column-width.js +175 -0
  301. package/dist/esm/plugins/table/transforms/delete-columns.js +271 -0
  302. package/dist/esm/plugins/table/transforms/delete-rows.js +156 -0
  303. package/dist/esm/plugins/table/transforms/fix-tables.js +229 -0
  304. package/dist/esm/plugins/table/transforms/index.js +7 -0
  305. package/dist/esm/plugins/table/transforms/merge.js +324 -0
  306. package/dist/esm/plugins/table/transforms/metadata.js +13 -0
  307. package/dist/esm/plugins/table/transforms/replace-table.js +34 -0
  308. package/dist/esm/plugins/table/transforms/split.js +82 -0
  309. package/dist/esm/plugins/table/types.js +90 -0
  310. package/dist/esm/plugins/table/ui/FloatingContextualButton/index.js +167 -0
  311. package/dist/esm/plugins/table/ui/FloatingContextualButton/styles.js +11 -0
  312. package/dist/esm/plugins/table/ui/FloatingContextualMenu/ContextualMenu.js +501 -0
  313. package/dist/esm/plugins/table/ui/FloatingContextualMenu/index.js +96 -0
  314. package/dist/esm/plugins/table/ui/FloatingContextualMenu/styles.js +15 -0
  315. package/dist/esm/plugins/table/ui/FloatingDeleteButton/DeleteButton.js +37 -0
  316. package/dist/esm/plugins/table/ui/FloatingDeleteButton/getPopUpOptions.js +61 -0
  317. package/dist/esm/plugins/table/ui/FloatingDeleteButton/index.js +333 -0
  318. package/dist/esm/plugins/table/ui/FloatingDeleteButton/types.js +1 -0
  319. package/dist/esm/plugins/table/ui/FloatingInsertButton/InsertButton.js +90 -0
  320. package/dist/esm/plugins/table/ui/FloatingInsertButton/getPopupOptions.js +96 -0
  321. package/dist/esm/plugins/table/ui/FloatingInsertButton/index.js +214 -0
  322. package/dist/esm/plugins/table/ui/LayoutButton/index.js +227 -0
  323. package/dist/esm/plugins/table/ui/TableFloatingControls/CornerControls/index.js +120 -0
  324. package/dist/esm/plugins/table/ui/TableFloatingControls/NumberColumn/index.js +126 -0
  325. package/dist/esm/plugins/table/ui/TableFloatingControls/RowControls/index.js +113 -0
  326. package/dist/esm/plugins/table/ui/TableFloatingControls/index.js +207 -0
  327. package/dist/esm/plugins/table/ui/common-styles.js +25 -0
  328. package/dist/esm/plugins/table/ui/consts.js +61 -0
  329. package/dist/esm/plugins/table/ui/messages.js +38 -0
  330. package/dist/esm/plugins/table/ui/ui-styles.js +73 -0
  331. package/dist/esm/plugins/table/utils/analytics.js +71 -0
  332. package/dist/esm/plugins/table/utils/collapse.js +84 -0
  333. package/dist/esm/plugins/table/utils/column-controls.js +202 -0
  334. package/dist/esm/plugins/table/utils/decoration.js +366 -0
  335. package/dist/esm/plugins/table/utils/dom.js +175 -0
  336. package/dist/esm/plugins/table/utils/get-allow-add-column-custom-step.js +5 -0
  337. package/dist/esm/plugins/table/utils/index.js +10 -0
  338. package/dist/esm/plugins/table/utils/nodes.js +112 -0
  339. package/dist/esm/plugins/table/utils/paste.js +115 -0
  340. package/dist/esm/plugins/table/utils/referentiality.js +20 -0
  341. package/dist/esm/plugins/table/utils/row-controls.js +221 -0
  342. package/dist/esm/plugins/table/utils/selection.js +96 -0
  343. package/dist/esm/plugins/table/utils/table.js +30 -0
  344. package/dist/esm/plugins/table/utils/update-plugin-state-decorations.js +5 -0
  345. package/dist/esm/plugins/table-plugin.js +1 -42
  346. package/dist/esm/version.json +1 -1
  347. package/dist/types/plugins/table/commands/clear.d.ts +3 -0
  348. package/dist/types/plugins/table/commands/collapse.d.ts +2 -0
  349. package/dist/types/plugins/table/commands/go-to-next-cell.d.ts +4 -0
  350. package/dist/types/plugins/table/commands/hover.d.ts +8 -0
  351. package/dist/types/plugins/table/commands/index.d.ts +7 -0
  352. package/dist/types/plugins/table/commands/insert.d.ts +10 -0
  353. package/dist/types/plugins/table/commands/misc.d.ts +27 -0
  354. package/dist/types/plugins/table/commands/selection.d.ts +8 -0
  355. package/dist/types/plugins/table/commands/sort.d.ts +3 -0
  356. package/dist/types/plugins/table/commands/split-cell.d.ts +6 -0
  357. package/dist/types/plugins/table/commands/toggle.d.ts +12 -0
  358. package/dist/types/plugins/table/commands-with-analytics.d.ts +26 -0
  359. package/dist/types/plugins/table/create-plugin-config.d.ts +2 -0
  360. package/dist/types/plugins/table/event-handlers.d.ts +16 -0
  361. package/dist/types/plugins/table/handlers.d.ts +3 -0
  362. package/dist/types/plugins/table/index.d.ts +17 -0
  363. package/dist/types/plugins/table/nodeviews/OverflowShadowsObserver.d.ts +26 -0
  364. package/dist/types/plugins/table/nodeviews/TableComponent.d.ts +72 -0
  365. package/dist/types/plugins/table/nodeviews/__mocks__/OverflowShadowsObserver.d.ts +9 -0
  366. package/dist/types/plugins/table/nodeviews/__mocks__/OverridableMock.d.ts +9 -0
  367. package/dist/types/plugins/table/nodeviews/table.d.ts +31 -0
  368. package/dist/types/plugins/table/nodeviews/tableCell.d.ts +19 -0
  369. package/dist/types/plugins/table/nodeviews/types.d.ts +23 -0
  370. package/dist/types/plugins/table/nodeviews/update-overflow-shadows.d.ts +8 -0
  371. package/dist/types/plugins/table/pm-plugins/decorations/plugin.d.ts +7 -0
  372. package/dist/types/plugins/table/pm-plugins/decorations/utils/column-controls.d.ts +3 -0
  373. package/dist/types/plugins/table/pm-plugins/decorations/utils/column-resizing.d.ts +2 -0
  374. package/dist/types/plugins/table/pm-plugins/decorations/utils/compose-decorations.d.ts +2 -0
  375. package/dist/types/plugins/table/pm-plugins/decorations/utils/index.d.ts +3 -0
  376. package/dist/types/plugins/table/pm-plugins/decorations/utils/types.d.ts +6 -0
  377. package/dist/types/plugins/table/pm-plugins/default-table-selection.d.ts +5 -0
  378. package/dist/types/plugins/table/pm-plugins/keymap.d.ts +5 -0
  379. package/dist/types/plugins/table/pm-plugins/main.d.ts +8 -0
  380. package/dist/types/plugins/table/pm-plugins/plugin-factory.d.ts +1 -0
  381. package/dist/types/plugins/table/pm-plugins/plugin-key.d.ts +3 -0
  382. package/dist/types/plugins/table/pm-plugins/safari-delayed-dom-selection-syncing-workaround.d.ts +4 -0
  383. package/dist/types/plugins/table/pm-plugins/safari-delete-composition-text-issue-workaround.d.ts +15 -0
  384. package/dist/types/plugins/table/pm-plugins/sticky-headers/commands.d.ts +3 -0
  385. package/dist/types/plugins/table/pm-plugins/sticky-headers/index.d.ts +6 -0
  386. package/dist/types/plugins/table/pm-plugins/sticky-headers/nodeviews/dom.d.ts +6 -0
  387. package/dist/types/plugins/table/pm-plugins/sticky-headers/nodeviews/tableRow.d.ts +65 -0
  388. package/dist/types/plugins/table/pm-plugins/sticky-headers/plugin-key.d.ts +3 -0
  389. package/dist/types/plugins/table/pm-plugins/sticky-headers/plugin-state.d.ts +3 -0
  390. package/dist/types/plugins/table/pm-plugins/sticky-headers/plugin.d.ts +4 -0
  391. package/dist/types/plugins/table/pm-plugins/sticky-headers/types.d.ts +16 -0
  392. package/dist/types/plugins/table/pm-plugins/sticky-headers/util.d.ts +2 -0
  393. package/dist/types/plugins/table/pm-plugins/table-local-id.d.ts +22 -0
  394. package/dist/types/plugins/table/pm-plugins/table-resizing/commands.d.ts +25 -0
  395. package/dist/types/plugins/table/pm-plugins/table-resizing/event-handlers.d.ts +4 -0
  396. package/dist/types/plugins/table/pm-plugins/table-resizing/index.d.ts +3 -0
  397. package/dist/types/plugins/table/pm-plugins/table-resizing/plugin-factory.d.ts +4 -0
  398. package/dist/types/plugins/table/pm-plugins/table-resizing/plugin-key.d.ts +3 -0
  399. package/dist/types/plugins/table/pm-plugins/table-resizing/plugin.d.ts +6 -0
  400. package/dist/types/plugins/table/pm-plugins/table-resizing/reducer.d.ts +3 -0
  401. package/dist/types/plugins/table/pm-plugins/table-resizing/utils/colgroup.d.ts +8 -0
  402. package/dist/types/plugins/table/pm-plugins/table-resizing/utils/column-state.d.ts +14 -0
  403. package/dist/types/plugins/table/pm-plugins/table-resizing/utils/content-width.d.ts +4 -0
  404. package/dist/types/plugins/table/pm-plugins/table-resizing/utils/dom.d.ts +13 -0
  405. package/dist/types/plugins/table/pm-plugins/table-resizing/utils/index.d.ts +12 -0
  406. package/dist/types/plugins/table/pm-plugins/table-resizing/utils/misc.d.ts +22 -0
  407. package/dist/types/plugins/table/pm-plugins/table-resizing/utils/resize-column.d.ts +2 -0
  408. package/dist/types/plugins/table/pm-plugins/table-resizing/utils/resize-logic.d.ts +4 -0
  409. package/dist/types/plugins/table/pm-plugins/table-resizing/utils/resize-state.d.ts +29 -0
  410. package/dist/types/plugins/table/pm-plugins/table-resizing/utils/scale-table.d.ts +17 -0
  411. package/dist/types/plugins/table/pm-plugins/table-resizing/utils/types.d.ts +22 -0
  412. package/dist/types/plugins/table/pm-plugins/table-resizing/utils/unit-to-number.d.ts +1 -0
  413. package/dist/types/plugins/table/pm-plugins/table-selection-keymap.d.ts +4 -0
  414. package/dist/types/plugins/table/reducer.d.ts +3 -0
  415. package/dist/types/plugins/table/todo-stubs.d.ts +1 -0
  416. package/dist/types/plugins/table/toolbar.d.ts +36 -0
  417. package/dist/types/plugins/table/transforms/column-width.d.ts +18 -0
  418. package/dist/types/plugins/table/transforms/delete-columns.d.ts +3 -0
  419. package/dist/types/plugins/table/transforms/delete-rows.d.ts +3 -0
  420. package/dist/types/plugins/table/transforms/fix-tables.d.ts +10 -0
  421. package/dist/types/plugins/table/transforms/index.d.ts +7 -0
  422. package/dist/types/plugins/table/transforms/merge.d.ts +5 -0
  423. package/dist/types/plugins/table/transforms/metadata.d.ts +21 -0
  424. package/dist/types/plugins/table/transforms/replace-table.d.ts +5 -0
  425. package/dist/types/plugins/table/transforms/split.d.ts +9 -0
  426. package/dist/types/plugins/table/types.d.ts +328 -0
  427. package/dist/types/plugins/table/ui/FloatingContextualButton/index.d.ts +29 -0
  428. package/dist/types/plugins/table/ui/FloatingContextualButton/styles.d.ts +1 -0
  429. package/dist/types/plugins/table/ui/FloatingContextualMenu/ContextualMenu.d.ts +87 -0
  430. package/dist/types/plugins/table/ui/FloatingContextualMenu/index.d.ts +22 -0
  431. package/dist/types/plugins/table/ui/FloatingContextualMenu/styles.d.ts +2 -0
  432. package/dist/types/plugins/table/ui/FloatingDeleteButton/DeleteButton.d.ts +14 -0
  433. package/dist/types/plugins/table/ui/FloatingDeleteButton/getPopUpOptions.d.ts +10 -0
  434. package/dist/types/plugins/table/ui/FloatingDeleteButton/index.d.ts +54 -0
  435. package/dist/types/plugins/table/ui/FloatingDeleteButton/types.d.ts +1 -0
  436. package/dist/types/plugins/table/ui/FloatingInsertButton/InsertButton.d.ts +12 -0
  437. package/dist/types/plugins/table/ui/FloatingInsertButton/getPopupOptions.d.ts +3 -0
  438. package/dist/types/plugins/table/ui/FloatingInsertButton/index.d.ts +35 -0
  439. package/dist/types/plugins/table/ui/LayoutButton/index.d.ts +21 -0
  440. package/dist/types/plugins/table/ui/TableFloatingControls/CornerControls/index.d.ts +19 -0
  441. package/dist/types/plugins/table/ui/TableFloatingControls/NumberColumn/index.d.ts +21 -0
  442. package/dist/types/plugins/table/ui/TableFloatingControls/RowControls/index.d.ts +17 -0
  443. package/dist/types/plugins/table/ui/TableFloatingControls/index.d.ts +40 -0
  444. package/dist/types/plugins/table/ui/common-styles.d.ts +4 -0
  445. package/dist/types/plugins/table/ui/consts.d.ts +39 -0
  446. package/dist/types/plugins/table/ui/messages.d.ts +38 -0
  447. package/dist/types/plugins/table/ui/ui-styles.d.ts +15 -0
  448. package/dist/types/plugins/table/utils/analytics.d.ts +18 -0
  449. package/dist/types/plugins/table/utils/collapse.d.ts +29 -0
  450. package/dist/types/plugins/table/utils/column-controls.d.ts +10 -0
  451. package/dist/types/plugins/table/utils/decoration.d.ts +13 -0
  452. package/dist/types/plugins/table/utils/dom.d.ts +17 -0
  453. package/dist/types/plugins/table/utils/get-allow-add-column-custom-step.d.ts +2 -0
  454. package/dist/types/plugins/table/utils/index.d.ts +11 -0
  455. package/dist/types/plugins/table/utils/nodes.d.ts +12 -0
  456. package/dist/types/plugins/table/utils/paste.d.ts +14 -0
  457. package/dist/types/plugins/table/utils/referentiality.d.ts +2 -0
  458. package/dist/types/plugins/table/utils/row-controls.d.ts +16 -0
  459. package/dist/types/plugins/table/utils/selection.d.ts +6 -0
  460. package/dist/types/plugins/table/utils/table.d.ts +4 -0
  461. package/dist/types/plugins/table/utils/update-plugin-state-decorations.d.ts +4 -0
  462. package/dist/types/plugins/table-plugin.d.ts +1 -1
  463. package/package.json +27 -5
  464. package/report.api.md +90 -4
  465. package/src/plugins/table/__tests__/integration/block-node-selection.ts +164 -0
  466. package/src/plugins/table/__tests__/unit/commands/go-to-next-cell.ts +155 -0
  467. package/src/plugins/table/__tests__/unit/commands/insert.ts +115 -0
  468. package/src/plugins/table/__tests__/unit/commands/misc.ts +165 -0
  469. package/src/plugins/table/__tests__/unit/commands.ts +982 -0
  470. package/src/plugins/table/__tests__/unit/event-handlers.ts +130 -0
  471. package/src/plugins/table/__tests__/unit/get-toolbar-config.ts +140 -0
  472. package/src/plugins/table/__tests__/unit/nodeviews/OverflowShadowsObserver.ts +153 -0
  473. package/src/plugins/table/__tests__/unit/nodeviews/TableComponent.tsx +388 -0
  474. package/src/plugins/table/__tests__/unit/nodeviews/table.ts +121 -0
  475. package/src/plugins/table/__tests__/unit/pm-plugins/decorations/column-controls.ts +34 -0
  476. package/src/plugins/table/__tests__/unit/pm-plugins/decorations/column-resizing.ts +152 -0
  477. package/src/plugins/table/__tests__/unit/pm-plugins/decorations/plugin.ts +140 -0
  478. package/src/plugins/table/__tests__/unit/pm-plugins/main-with-allow-collapse.ts +100 -0
  479. package/src/plugins/table/__tests__/unit/pm-plugins/main.ts +187 -0
  480. package/src/plugins/table/__tests__/unit/pm-plugins/safari-delete-composition-text-issue-workaround.ts +83 -0
  481. package/src/plugins/table/__tests__/unit/pm-plugins/sticky-headers/tableRow.tsx +603 -0
  482. package/src/plugins/table/__tests__/unit/pm-plugins/table-local-id.ts +515 -0
  483. package/src/plugins/table/__tests__/unit/pm-plugins/table-resizing/colgroup.ts +86 -0
  484. package/src/plugins/table/__tests__/unit/pm-plugins/table-resizing/event-handlers.ts +134 -0
  485. package/src/plugins/table/__tests__/unit/pm-plugins/table-selection-keymap.ts +564 -0
  486. package/src/plugins/table/__tests__/unit/toolbar.ts +240 -0
  487. package/src/plugins/table/__tests__/unit/utils/collapse.ts +74 -0
  488. package/src/plugins/table/__tests__/unit/utils/column-controls.ts +61 -0
  489. package/src/plugins/table/__tests__/visual-regression/__fixtures__/table-with-100-numbered-list-items.json +20272 -0
  490. package/src/plugins/table/__tests__/visual-regression/__image_snapshots__/cell-options-menu-ts-table-cell-options-menu-delete-column-menu-item-should-remove-the-table-column-on-click-1-snap.png +3 -0
  491. package/src/plugins/table/__tests__/visual-regression/__image_snapshots__/cell-options-menu-ts-table-cell-options-menu-delete-column-menu-item-visual-hints-should-be-added-to-the-table-column-on-hover-1-snap.png +3 -0
  492. package/src/plugins/table/__tests__/visual-regression/__image_snapshots__/cell-options-menu-ts-table-cell-options-menu-delete-row-menu-item-should-remove-the-table-row-on-click-1-snap.png +3 -0
  493. package/src/plugins/table/__tests__/visual-regression/__image_snapshots__/cell-options-menu-ts-table-cell-options-menu-delete-row-menu-item-visual-hints-should-be-added-to-the-table-row-on-hover-1-snap.png +3 -0
  494. package/src/plugins/table/__tests__/visual-regression/__image_snapshots__/copy-button-ts-floating-toolbar-copy-button-table-target-node-displays-blue-border-when-copy-button-is-hovered-1-snap.png +3 -0
  495. package/src/plugins/table/__tests__/visual-regression/__image_snapshots__/index-ts-snapshot-test-table-numbered-list-should-not-overflow-table-cell-when-there-are-more-than-100-ordered-list-items-1-snap.png +3 -0
  496. package/src/plugins/table/__tests__/visual-regression/__image_snapshots__/index-ts-snapshot-test-table-numbered-list-should-not-overflow-table-cell-when-there-are-more-than-100-ordered-list-items-2-snap.png +3 -0
  497. package/src/plugins/table/__tests__/visual-regression/__image_snapshots__/index-ts-snapshot-test-table-numbered-list-should-not-overflow-table-cell-when-there-are-more-than-100-ordered-list-items-3-snap.png +3 -0
  498. package/src/plugins/table/__tests__/visual-regression/cell-options-menu.ts +97 -0
  499. package/src/plugins/table/__tests__/visual-regression/index.ts +42 -0
  500. package/src/plugins/table/commands/clear.ts +58 -0
  501. package/src/plugins/table/commands/collapse.ts +16 -0
  502. package/src/plugins/table/commands/go-to-next-cell.ts +56 -0
  503. package/src/plugins/table/commands/hover.ts +192 -0
  504. package/src/plugins/table/commands/index.ts +40 -0
  505. package/src/plugins/table/commands/insert.ts +174 -0
  506. package/src/plugins/table/commands/misc.ts +506 -0
  507. package/src/plugins/table/commands/selection.ts +406 -0
  508. package/src/plugins/table/commands/sort.ts +109 -0
  509. package/src/plugins/table/commands/split-cell.ts +28 -0
  510. package/src/plugins/table/commands/toggle.ts +93 -0
  511. package/src/plugins/table/commands-with-analytics.ts +523 -0
  512. package/src/plugins/table/create-plugin-config.ts +18 -0
  513. package/src/plugins/table/event-handlers.ts +514 -0
  514. package/src/plugins/table/handlers.ts +169 -0
  515. package/src/plugins/table/index.tsx +440 -0
  516. package/src/plugins/table/nodeviews/OverflowShadowsObserver.ts +189 -0
  517. package/src/plugins/table/nodeviews/TableComponent.tsx +693 -0
  518. package/src/plugins/table/nodeviews/__mocks__/OverflowShadowsObserver.ts +13 -0
  519. package/src/plugins/table/nodeviews/__mocks__/OverridableMock.ts +21 -0
  520. package/src/plugins/table/nodeviews/table.tsx +241 -0
  521. package/src/plugins/table/nodeviews/tableCell.tsx +110 -0
  522. package/src/plugins/table/nodeviews/types.ts +29 -0
  523. package/src/plugins/table/nodeviews/update-overflow-shadows.ts +72 -0
  524. package/src/plugins/table/pm-plugins/decorations/plugin.ts +74 -0
  525. package/src/plugins/table/pm-plugins/decorations/utils/column-controls.ts +89 -0
  526. package/src/plugins/table/pm-plugins/decorations/utils/column-resizing.ts +46 -0
  527. package/src/plugins/table/pm-plugins/decorations/utils/compose-decorations.ts +11 -0
  528. package/src/plugins/table/pm-plugins/decorations/utils/index.ts +6 -0
  529. package/src/plugins/table/pm-plugins/decorations/utils/types.ts +10 -0
  530. package/src/plugins/table/pm-plugins/default-table-selection.ts +5 -0
  531. package/src/plugins/table/pm-plugins/keymap.ts +108 -0
  532. package/src/plugins/table/pm-plugins/main.ts +399 -0
  533. package/src/plugins/table/pm-plugins/plugin-factory.ts +43 -0
  534. package/src/plugins/table/pm-plugins/plugin-key.ts +4 -0
  535. package/src/plugins/table/pm-plugins/safari-delayed-dom-selection-syncing-workaround.ts +78 -0
  536. package/src/plugins/table/pm-plugins/safari-delete-composition-text-issue-workaround.ts +118 -0
  537. package/src/plugins/table/pm-plugins/sticky-headers/commands.ts +12 -0
  538. package/src/plugins/table/pm-plugins/sticky-headers/index.ts +7 -0
  539. package/src/plugins/table/pm-plugins/sticky-headers/nodeviews/dom.ts +37 -0
  540. package/src/plugins/table/pm-plugins/sticky-headers/nodeviews/tableRow.ts +658 -0
  541. package/src/plugins/table/pm-plugins/sticky-headers/plugin-key.ts +6 -0
  542. package/src/plugins/table/pm-plugins/sticky-headers/plugin-state.ts +55 -0
  543. package/src/plugins/table/pm-plugins/sticky-headers/plugin.ts +36 -0
  544. package/src/plugins/table/pm-plugins/sticky-headers/types.ts +20 -0
  545. package/src/plugins/table/pm-plugins/sticky-headers/util.ts +18 -0
  546. package/src/plugins/table/pm-plugins/table-local-id.ts +203 -0
  547. package/src/plugins/table/pm-plugins/table-resizing/commands.ts +168 -0
  548. package/src/plugins/table/pm-plugins/table-resizing/event-handlers.ts +218 -0
  549. package/src/plugins/table/pm-plugins/table-resizing/index.ts +3 -0
  550. package/src/plugins/table/pm-plugins/table-resizing/plugin-factory.ts +28 -0
  551. package/src/plugins/table/pm-plugins/table-resizing/plugin-key.ts +6 -0
  552. package/src/plugins/table/pm-plugins/table-resizing/plugin.ts +79 -0
  553. package/src/plugins/table/pm-plugins/table-resizing/reducer.ts +40 -0
  554. package/src/plugins/table/pm-plugins/table-resizing/utils/colgroup.ts +58 -0
  555. package/src/plugins/table/pm-plugins/table-resizing/utils/column-state.ts +122 -0
  556. package/src/plugins/table/pm-plugins/table-resizing/utils/content-width.ts +130 -0
  557. package/src/plugins/table/pm-plugins/table-resizing/utils/dom.ts +176 -0
  558. package/src/plugins/table/pm-plugins/table-resizing/utils/index.ts +37 -0
  559. package/src/plugins/table/pm-plugins/table-resizing/utils/misc.ts +136 -0
  560. package/src/plugins/table/pm-plugins/table-resizing/utils/resize-column.ts +23 -0
  561. package/src/plugins/table/pm-plugins/table-resizing/utils/resize-logic.ts +275 -0
  562. package/src/plugins/table/pm-plugins/table-resizing/utils/resize-state.ts +348 -0
  563. package/src/plugins/table/pm-plugins/table-resizing/utils/scale-table.ts +142 -0
  564. package/src/plugins/table/pm-plugins/table-resizing/utils/types.ts +23 -0
  565. package/src/plugins/table/pm-plugins/table-resizing/utils/unit-to-number.ts +2 -0
  566. package/src/plugins/table/pm-plugins/table-selection-keymap.ts +32 -0
  567. package/src/plugins/table/reducer.ts +106 -0
  568. package/src/plugins/table/todo-stubs.ts +1 -0
  569. package/src/plugins/table/toolbar.ts +401 -0
  570. package/src/plugins/table/transforms/column-width.ts +187 -0
  571. package/src/plugins/table/transforms/delete-columns.ts +251 -0
  572. package/src/plugins/table/transforms/delete-rows.ts +150 -0
  573. package/src/plugins/table/transforms/fix-tables.ts +296 -0
  574. package/src/plugins/table/transforms/index.ts +7 -0
  575. package/src/plugins/table/transforms/merge.ts +312 -0
  576. package/src/plugins/table/transforms/metadata.ts +35 -0
  577. package/src/plugins/table/transforms/replace-table.ts +48 -0
  578. package/src/plugins/table/transforms/split.ts +99 -0
  579. package/src/plugins/table/types.ts +345 -0
  580. package/src/plugins/table/ui/FloatingContextualButton/index.tsx +196 -0
  581. package/src/plugins/table/ui/FloatingContextualButton/styles.ts +29 -0
  582. package/src/plugins/table/ui/FloatingContextualMenu/ContextualMenu.tsx +524 -0
  583. package/src/plugins/table/ui/FloatingContextualMenu/__tests__/ContextualMenu.tsx +55 -0
  584. package/src/plugins/table/ui/FloatingContextualMenu/__tests__/FloatingContextualMenu.tsx +49 -0
  585. package/src/plugins/table/ui/FloatingContextualMenu/index.tsx +131 -0
  586. package/src/plugins/table/ui/FloatingContextualMenu/styles.ts +53 -0
  587. package/src/plugins/table/ui/FloatingDeleteButton/DeleteButton.tsx +49 -0
  588. package/src/plugins/table/ui/FloatingDeleteButton/getPopUpOptions.ts +75 -0
  589. package/src/plugins/table/ui/FloatingDeleteButton/index.tsx +384 -0
  590. package/src/plugins/table/ui/FloatingDeleteButton/types.ts +1 -0
  591. package/src/plugins/table/ui/FloatingInsertButton/InsertButton.tsx +132 -0
  592. package/src/plugins/table/ui/FloatingInsertButton/getPopupOptions.ts +122 -0
  593. package/src/plugins/table/ui/FloatingInsertButton/index.tsx +268 -0
  594. package/src/plugins/table/ui/LayoutButton/index.tsx +220 -0
  595. package/src/plugins/table/ui/TableFloatingControls/CornerControls/index.tsx +105 -0
  596. package/src/plugins/table/ui/TableFloatingControls/NumberColumn/index.tsx +108 -0
  597. package/src/plugins/table/ui/TableFloatingControls/RowControls/index.tsx +119 -0
  598. package/src/plugins/table/ui/TableFloatingControls/index.tsx +202 -0
  599. package/src/plugins/table/ui/common-styles.ts +726 -0
  600. package/src/plugins/table/ui/consts.ts +100 -0
  601. package/src/plugins/table/ui/messages.ts +43 -0
  602. package/src/plugins/table/ui/ui-styles.ts +459 -0
  603. package/src/plugins/table/utils/analytics.ts +81 -0
  604. package/src/plugins/table/utils/collapse.ts +99 -0
  605. package/src/plugins/table/utils/column-controls.ts +225 -0
  606. package/src/plugins/table/utils/decoration.ts +456 -0
  607. package/src/plugins/table/utils/dom.ts +211 -0
  608. package/src/plugins/table/utils/get-allow-add-column-custom-step.ts +11 -0
  609. package/src/plugins/table/utils/index.ts +69 -0
  610. package/src/plugins/table/utils/nodes.ts +140 -0
  611. package/src/plugins/table/utils/paste.ts +164 -0
  612. package/src/plugins/table/utils/referentiality.ts +24 -0
  613. package/src/plugins/table/utils/row-controls.ts +238 -0
  614. package/src/plugins/table/utils/selection.ts +107 -0
  615. package/src/plugins/table/utils/table.ts +31 -0
  616. package/src/plugins/table/utils/update-plugin-state-decorations.ts +14 -0
  617. package/src/plugins/table-plugin.ts +1 -38
@@ -0,0 +1,456 @@
1
+ import { Node as PmNode } from 'prosemirror-model';
2
+ import { Selection, Transaction, ReadonlyTransaction } from 'prosemirror-state';
3
+ import { TableMap } from '@atlaskit/editor-tables/table-map';
4
+ import { ContentNodeWithPos } from 'prosemirror-utils';
5
+ import {
6
+ findTable,
7
+ getCellsInRow,
8
+ getSelectionRect,
9
+ } from '@atlaskit/editor-tables/utils';
10
+
11
+ import { Decoration, DecorationSet } from 'prosemirror-view';
12
+
13
+ import { CellAttributes } from '@atlaskit/adf-schema';
14
+
15
+ // import { nonNullable } from '@atlaskit/editor-core/src/utils';
16
+ import { nonNullable } from '@atlaskit/editor-common/utils';
17
+ import {
18
+ Cell,
19
+ CellColumnPositioning,
20
+ TableCssClassName as ClassName,
21
+ TableDecorations,
22
+ } from '../types';
23
+
24
+ const filterDecorationByKey = (
25
+ key: TableDecorations,
26
+ decorationSet: DecorationSet,
27
+ ): Decoration[] =>
28
+ decorationSet.find(
29
+ undefined,
30
+ undefined,
31
+ (spec) => spec.key.indexOf(key) > -1,
32
+ );
33
+
34
+ export const findColumnControlSelectedDecoration = (
35
+ decorationSet: DecorationSet,
36
+ ): Decoration[] =>
37
+ filterDecorationByKey(TableDecorations.COLUMN_SELECTED, decorationSet);
38
+
39
+ export const findControlsHoverDecoration = (
40
+ decorationSet: DecorationSet,
41
+ ): Decoration[] =>
42
+ filterDecorationByKey(TableDecorations.ALL_CONTROLS_HOVER, decorationSet);
43
+
44
+ export const createCellHoverDecoration = (
45
+ cells: Cell[],
46
+ type: 'warning',
47
+ ): Decoration[] =>
48
+ cells.map((cell) =>
49
+ Decoration.node(
50
+ cell.pos,
51
+ cell.pos + cell.node.nodeSize,
52
+ {
53
+ class: ClassName.HOVERED_CELL_WARNING,
54
+ },
55
+ {
56
+ key: TableDecorations.CELL_CONTROLS_HOVER,
57
+ },
58
+ ),
59
+ );
60
+
61
+ export const createControlsHoverDecoration = (
62
+ cells: Cell[],
63
+ type: 'row' | 'column' | 'table',
64
+ danger?: boolean,
65
+ selected?: boolean,
66
+ ): Decoration[] =>
67
+ cells.map((cell) => {
68
+ const classes = [ClassName.HOVERED_CELL];
69
+ if (danger) {
70
+ classes.push(ClassName.HOVERED_CELL_IN_DANGER);
71
+ }
72
+ if (selected) {
73
+ classes.push(ClassName.SELECTED_CELL);
74
+ }
75
+
76
+ classes.push(
77
+ type === 'column'
78
+ ? ClassName.HOVERED_COLUMN
79
+ : type === 'row'
80
+ ? ClassName.HOVERED_ROW
81
+ : ClassName.HOVERED_TABLE,
82
+ );
83
+
84
+ let key: TableDecorations;
85
+ switch (type) {
86
+ case 'row':
87
+ key = TableDecorations.ROW_CONTROLS_HOVER;
88
+ break;
89
+
90
+ case 'column':
91
+ key = TableDecorations.COLUMN_CONTROLS_HOVER;
92
+ break;
93
+
94
+ default:
95
+ key = TableDecorations.TABLE_CONTROLS_HOVER;
96
+ break;
97
+ }
98
+
99
+ return Decoration.node(
100
+ cell.pos,
101
+ cell.pos + cell.node.nodeSize,
102
+ {
103
+ class: classes.join(' '),
104
+ },
105
+ { key },
106
+ );
107
+ });
108
+
109
+ export const createColumnSelectedDecoration = (
110
+ tr: Transaction | ReadonlyTransaction,
111
+ ): Decoration[] => {
112
+ const { selection, doc } = tr;
113
+ const table = findTable(selection);
114
+ const rect = getSelectionRect(selection);
115
+
116
+ if (!table || !rect) {
117
+ return [];
118
+ }
119
+
120
+ const map = TableMap.get(table.node);
121
+ const cellPositions = map.cellsInRect(rect);
122
+
123
+ return cellPositions.map((pos, index) => {
124
+ const cell = doc.nodeAt(pos + table.start);
125
+
126
+ return Decoration.node(
127
+ pos + table.start,
128
+ pos + table.start + cell!.nodeSize,
129
+ {
130
+ class: ClassName.COLUMN_SELECTED,
131
+ },
132
+ {
133
+ key: `${TableDecorations.COLUMN_SELECTED}_${index}`,
134
+ },
135
+ );
136
+ });
137
+ };
138
+
139
+ export const createColumnControlsDecoration = (
140
+ selection: Selection,
141
+ ): Decoration[] => {
142
+ const cells: ContentNodeWithPos[] = getCellsInRow(0)(selection) || [];
143
+ let index = 0;
144
+ return cells.map((cell) => {
145
+ const colspan = (cell.node.attrs as CellAttributes).colspan || 1;
146
+ const element = document.createElement('div');
147
+ element.classList.add(ClassName.COLUMN_CONTROLS_DECORATIONS);
148
+ element.dataset.startIndex = `${index}`;
149
+ index += colspan;
150
+ element.dataset.endIndex = `${index}`;
151
+
152
+ return Decoration.widget(cell.pos + 1, () => element, {
153
+ key: `${TableDecorations.COLUMN_CONTROLS_DECORATIONS}_${index}`,
154
+ // this decoration should be the first one, even before gap cursor.
155
+ side: -100,
156
+ });
157
+ });
158
+ };
159
+
160
+ export const updateDecorations = (
161
+ node: PmNode,
162
+ decorationSet: DecorationSet,
163
+ decorations: Decoration[],
164
+ key: TableDecorations,
165
+ ): DecorationSet => {
166
+ const filteredDecorations = filterDecorationByKey(key, decorationSet);
167
+ const decorationSetFiltered = decorationSet.remove(filteredDecorations);
168
+
169
+ return decorationSetFiltered.add(node, decorations);
170
+ };
171
+
172
+ const makeArray = (n: number) => Array.from(Array(n).keys());
173
+
174
+ /*
175
+ * This function will create two specific decorations for each cell in a column index target,
176
+ * for example given that table:
177
+ *
178
+ * ```
179
+ * 0 1 2 3
180
+ * _____________________ _______
181
+ * | | | |
182
+ * | B1 | C1 | A1 |
183
+ * |______|______ ______|______|
184
+ * | | | |
185
+ * | B2 | | A2 |
186
+ * |______ ______| |______|
187
+ * | | | D1 | |
188
+ * | B3 | C2 | | A3 |
189
+ * |______|______|______|______|
190
+ * ^ ^ ^ ^
191
+ * | | | |
192
+ * | | | |
193
+ * | | | |
194
+ * 0 1 3 4
195
+ * \ | | /
196
+ * \ | | /
197
+ * \ | | /
198
+ * \ | | /
199
+ * \ | | /
200
+ * columnEndIndexTarget === CellColumnPositioning.right
201
+ * ```
202
+ *
203
+ * When a user wants to resize a cell,
204
+ * they need to grab and hold the end of that column,
205
+ * and this will be the `columnEndIndexTarget` using
206
+ * the CellColumnPositioning interface.
207
+ *
208
+ * Let's say the `columnEndIndexTarget.right` is 3,
209
+ * so this function will return two types of decorations for each cell on that column,
210
+ * that means 2 `resizerHandle` and 2 `lastCellElement`,
211
+ * here is the explanation for each one of them :
212
+ *
213
+ * - resizerHandle:
214
+ *
215
+ * Given the cell C1, this decoration will add a div to create this area
216
+ * ```
217
+ * ▁▁▁▁▁▁▁▁▁▁▁▁▁
218
+ * | ▒▒|
219
+ * | C1 ▒▒|
220
+ * | ▒▒|
221
+ * ▔▔▔▔▔▔▔▔▔▔▔▔▔
222
+ * ```
223
+ * This ▒ represents the area where table resizing will start,
224
+ * and you can follow that using checking the class name `ClassName.RESIZE_HANDLE_DECORATION` on the code
225
+ *
226
+ * - lastCellElementDecoration
227
+ *
228
+ * Given the content of the cell C1
229
+ * ▁▁▁▁▁▁▁▁▁▁▁▁▁▁▁▁▁▁▁
230
+ * | |
231
+ * | _____________ |
232
+ * | | | |
233
+ * | | <p> | |
234
+ * | |_____________| |
235
+ * | |
236
+ * | _____________ |
237
+ * | | | |
238
+ * | | <media> | |
239
+ * | |_____________| |
240
+ * | |
241
+ * | _____________ |
242
+ * | | | |
243
+ * | | <media> | |
244
+ * | |_____________| |
245
+ * | |
246
+ * ▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
247
+ * Currently, we are removing the margin-bottom from the last media using this kind of CSS rule:
248
+ * `div:last-of-type`; This is quite unstable, and after we create the `resizerHandle` div,
249
+ * that logic will apply the margin in the wrong element, to avoid that,
250
+ * we will add a new class on the last item for each cell,
251
+ * hence the second media will receive this class `ClassName.LAST_ITEM_IN_CELL`
252
+ */
253
+ export const createResizeHandleDecoration = (
254
+ tr: Transaction | ReadonlyTransaction,
255
+ columnEndIndexTarget: Omit<CellColumnPositioning, 'left'>,
256
+ ): [Decoration[], Decoration[]] => {
257
+ const emptyResult: [Decoration[], Decoration[]] = [[], []];
258
+ const table = findTable(tr.selection);
259
+ if (!table || !table.node) {
260
+ return emptyResult;
261
+ }
262
+
263
+ const map = TableMap.get(table.node);
264
+ if (!map.width) {
265
+ return emptyResult;
266
+ }
267
+
268
+ const createResizerHandleDecoration = (
269
+ cellColumnPositioning: CellColumnPositioning,
270
+ columnIndex: number,
271
+ rowIndex: number,
272
+ cellPos: number,
273
+ cellNode: PmNode,
274
+ ): Decoration => {
275
+ const element = document.createElement('div');
276
+ element.classList.add(ClassName.RESIZE_HANDLE_DECORATION);
277
+
278
+ element.dataset.startIndex = `${cellColumnPositioning.left}`;
279
+ element.dataset.endIndex = `${cellColumnPositioning.right}`;
280
+ const position = cellPos + cellNode.nodeSize - 1;
281
+
282
+ return Decoration.widget(position, element, {
283
+ key: `${TableDecorations.COLUMN_RESIZING_HANDLE}_${rowIndex}_${columnIndex}`,
284
+ });
285
+ };
286
+
287
+ const createLastCellElementDecoration = (
288
+ cellColumnPositioning: CellColumnPositioning,
289
+ cellPos: number,
290
+ cellNode: PmNode,
291
+ ): Decoration | null => {
292
+ let lastItemPositions: { from: number; to: number } | undefined;
293
+ cellNode.forEach((childNode, offset, index) => {
294
+ if (index === cellNode.childCount - 1) {
295
+ const from = offset + cellPos + 1;
296
+ lastItemPositions = {
297
+ from,
298
+ to: from + childNode.nodeSize,
299
+ };
300
+ }
301
+ });
302
+
303
+ if (!lastItemPositions) {
304
+ return null;
305
+ }
306
+
307
+ return Decoration.node(
308
+ lastItemPositions.from,
309
+ lastItemPositions.to,
310
+ {
311
+ class: ClassName.LAST_ITEM_IN_CELL,
312
+ },
313
+ {
314
+ key: `${TableDecorations.LAST_CELL_ELEMENT}_${cellColumnPositioning.left}_${cellColumnPositioning.right}`,
315
+ },
316
+ );
317
+ };
318
+
319
+ const resizeHandleCellDecorations: Decoration[] = [];
320
+ const lastCellElementsDecorations: Array<Decoration | null> = [];
321
+
322
+ for (let rowIndex = 0; rowIndex < map.height; rowIndex++) {
323
+ const seen: { [key: number]: boolean } = {};
324
+
325
+ for (let columnIndex = 0; columnIndex < map.width; columnIndex++) {
326
+ const cellPosition = map.map[map.width * rowIndex + columnIndex];
327
+ if (seen[cellPosition]) {
328
+ continue;
329
+ }
330
+
331
+ seen[cellPosition] = true;
332
+ const cellPos = table.start + cellPosition;
333
+ const cell = tr.doc.nodeAt(cellPos);
334
+ if (!cell) {
335
+ continue;
336
+ }
337
+ const colspan = (cell.attrs as CellAttributes).colspan || 1;
338
+ const startIndex = columnIndex;
339
+ const endIndex = colspan + startIndex;
340
+
341
+ if (endIndex !== columnEndIndexTarget.right) {
342
+ continue;
343
+ }
344
+
345
+ const resizerHandleDec = createResizerHandleDecoration(
346
+ { left: startIndex, right: endIndex },
347
+ columnIndex,
348
+ rowIndex,
349
+ cellPos,
350
+ cell,
351
+ );
352
+ const lastCellDec = createLastCellElementDecoration(
353
+ { left: startIndex, right: endIndex },
354
+ cellPos,
355
+ cell,
356
+ );
357
+
358
+ resizeHandleCellDecorations.push(resizerHandleDec);
359
+ lastCellElementsDecorations.push(lastCellDec);
360
+ }
361
+ }
362
+
363
+ return [
364
+ resizeHandleCellDecorations,
365
+ lastCellElementsDecorations.filter(nonNullable),
366
+ ];
367
+ };
368
+
369
+ /*
370
+ * This function will create a decoration for each cell using the right position on the CellColumnPositioning
371
+ * for example given that table:
372
+ *
373
+ * ```
374
+ * 0 1 2 3 <--- column indexes
375
+ * _____________________ _______
376
+ * | | | |
377
+ * | B1 | C1 | A1 |
378
+ * |______|______ ______|______|
379
+ * | | | |
380
+ * | B2 | D1 | A2 |
381
+ * |______ ______|______|______|
382
+ * | | | |
383
+ * | B3 | C2 | D2 |
384
+ * |______|______|_____________|
385
+ * ```
386
+ *
387
+ * and given the left and right represents the C1 cell:
388
+ *
389
+ * ```
390
+ * left right
391
+ * 1 3
392
+ * | |
393
+ * | |
394
+ * | |
395
+ * _______∨_____________∨_______
396
+ * | | | |
397
+ * | B1 | C1 | A1 |
398
+ * |______|______ ______|______|
399
+ * | | | |
400
+ * | B2 | D1 | A2 |
401
+ * |______ ______|______|______|
402
+ * | | | |
403
+ * | B3 | C2 | D2 |
404
+ * |______|______|_____________|
405
+ * ```
406
+ *
407
+ * Taking that table, and the right as parameters,
408
+ * this function will return two decorations applying a new class `ClassName.WITH_RESIZE_LINE`
409
+ * only on the cells: `C1` and `D1`.
410
+ */
411
+ export const createColumnLineResize = (
412
+ selection: Selection,
413
+ cellColumnPositioning: Omit<CellColumnPositioning, 'left'>,
414
+ ): Decoration[] => {
415
+ const table = findTable(selection);
416
+ if (!table || cellColumnPositioning.right === null) {
417
+ return [];
418
+ }
419
+
420
+ const columnIndex = cellColumnPositioning.right - 1;
421
+ const map = TableMap.get(table.node);
422
+
423
+ const cellPositions = makeArray(map.height)
424
+ .map((rowIndex) => map.map[map.width * rowIndex + columnIndex])
425
+ .filter((cellPosition, rowIndex) => {
426
+ if (columnIndex === map.width) {
427
+ return true; // If is the last column no filter applied
428
+ }
429
+ const nextPosition = map.map[map.width * rowIndex + columnIndex + 1];
430
+ return cellPosition !== nextPosition; // Removed it if next position is merged
431
+ });
432
+
433
+ const cells = cellPositions.map((pos) => ({
434
+ pos: pos + table.start,
435
+ node: table.node.nodeAt(pos),
436
+ }));
437
+
438
+ return cells
439
+ .map((cell, index) => {
440
+ if (!cell || !cell.node) {
441
+ return;
442
+ }
443
+
444
+ return Decoration.node(
445
+ cell.pos,
446
+ cell.pos + cell.node.nodeSize,
447
+ {
448
+ class: ClassName.WITH_RESIZE_LINE,
449
+ },
450
+ {
451
+ key: `${TableDecorations.COLUMN_RESIZING_HANDLE_LINE}_${cellColumnPositioning.right}_${index}`,
452
+ },
453
+ );
454
+ })
455
+ .filter(nonNullable);
456
+ };
@@ -0,0 +1,211 @@
1
+ // import { containsClassName } from '@atlaskit/editor-core/src/utils';
2
+ // import { closestElement } from '@atlaskit/editor-core/src/utils/dom';
3
+ import {
4
+ closestElement,
5
+ containsClassName,
6
+ } from '@atlaskit/editor-common/utils';
7
+ import { TableCssClassName as ClassName, ElementContentRects } from '../types';
8
+ import { tableToolbarSize } from '../ui/consts';
9
+
10
+ const SELECTOR_TABLE_LEAFS = `.${ClassName.TABLE_CELL}, .${ClassName.TABLE_HEADER_CELL}`;
11
+
12
+ export const isCell = (node: HTMLElement | null): boolean => {
13
+ return Boolean(
14
+ node &&
15
+ (['TH', 'TD'].indexOf(node.tagName) > -1 ||
16
+ !!closestElement(node, `.${ClassName.TABLE_HEADER_CELL}`) ||
17
+ !!closestElement(node, `.${ClassName.TABLE_CELL}`)),
18
+ );
19
+ };
20
+
21
+ export const isCornerButton = (node: HTMLElement | null): boolean =>
22
+ containsClassName(node, ClassName.CONTROLS_CORNER_BUTTON);
23
+
24
+ export const isInsertRowButton = (node: HTMLElement | null) =>
25
+ containsClassName(node, ClassName.CONTROLS_INSERT_ROW) ||
26
+ closestElement(node, `.${ClassName.CONTROLS_INSERT_ROW}`) ||
27
+ (containsClassName(node, ClassName.CONTROLS_BUTTON_OVERLAY) &&
28
+ closestElement(node, `.${ClassName.ROW_CONTROLS}`));
29
+
30
+ export const getColumnOrRowIndex = (target: HTMLElement): [number, number] => [
31
+ parseInt(target.getAttribute('data-start-index') || '-1', 10),
32
+ parseInt(target.getAttribute('data-end-index') || '-1', 10),
33
+ ];
34
+
35
+ export const isColumnControlsDecorations = (
36
+ node: HTMLElement | null,
37
+ ): boolean => containsClassName(node, ClassName.COLUMN_CONTROLS_DECORATIONS);
38
+
39
+ export const isRowControlsButton = (node: HTMLElement | null): boolean =>
40
+ containsClassName(node, ClassName.ROW_CONTROLS_BUTTON) ||
41
+ containsClassName(node, ClassName.NUMBERED_COLUMN_BUTTON);
42
+
43
+ export const isResizeHandleDecoration = (node: HTMLElement | null): boolean =>
44
+ containsClassName(node, ClassName.RESIZE_HANDLE_DECORATION);
45
+
46
+ export const isTableControlsButton = (node: HTMLElement | null): boolean =>
47
+ containsClassName(node, ClassName.CONTROLS_BUTTON) ||
48
+ containsClassName(node, ClassName.ROW_CONTROLS_BUTTON_WRAP);
49
+
50
+ export const isTableContainerOrWrapper = (node: HTMLElement | null): boolean =>
51
+ containsClassName(node, ClassName.TABLE_CONTAINER) ||
52
+ containsClassName(node, ClassName.TABLE_NODE_WRAPPER);
53
+
54
+ /*
55
+ * This function returns which side of a given element the mouse cursor is,
56
+ * using as a base the half of the width by default, for example:
57
+ *
58
+ * legend
59
+ * ⌖ = mouse pointer
60
+ * ▒ = gap
61
+ *
62
+ * given this box:
63
+ * ┏━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━┓
64
+ * ┃ ┊ ┃
65
+ * ┃ left ┊ right ┃
66
+ * ┃ ┊ ┃
67
+ * ┗━━━━━━━━━━━━━━━━━━━━┻━━━━━━━━━━━━━━━━━━━━━┛
68
+ *
69
+ * if the mouse is on the left, it will return `left`,
70
+ * if it is on the right it will return `right`.
71
+ *
72
+ * You can extend this behavior using the parameter `gapInPixels`
73
+ * to determinate if the mouse is inside of a gap for each side,
74
+ * for example:
75
+ *
76
+ * given `gapInPixels` is `5`
77
+ * and given this box:
78
+ * ┏━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━┓
79
+ * ┃▒▒▒▒▒ ┊ ▒▒▒▒▒┃
80
+ * ┃▒▒▒▒▒ left ┊ right ▒▒▒▒▒┃
81
+ * ┃▒▒▒▒▒ ┊ ▒▒▒▒▒┃
82
+ * ┗━━━━━━━━━━━━━━━━━━━━┻━━━━━━━━━━━━━━━━━━━━━┛
83
+ *
84
+ * if the mouse cursor is inside of the gap like that:
85
+ *
86
+ * ┏━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━┓
87
+ * ┃▒▒▒▒▒ ┊ ▒▒▒▒▒┃
88
+ * ┃▒▒⌖▒▒ left ┊ right ▒▒▒▒▒┃
89
+ * ┃▒▒▒▒▒ ┊ ▒▒▒▒▒┃
90
+ * ┗━━━━━━━━━━━━━━━━━━━━┻━━━━━━━━━━━━━━━━━━━━━┛
91
+ *
92
+ * the function will return `left` because the mouse is inside of the gap on the left side.
93
+ *
94
+ * if the mouse cursor is outside of the gap like that:
95
+ *
96
+ * ┏━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━┓
97
+ * ┃▒▒▒▒▒ ┊ ▒▒▒▒▒┃
98
+ * ┃▒▒▒▒▒ left ⌖ ┊ right ▒▒▒▒▒┃
99
+ * ┃▒▒▒▒▒ ┊ ▒▒▒▒▒┃
100
+ * ┗━━━━━━━━━━━━━━━━━━━━┻━━━━━━━━━━━━━━━━━━━━━┛
101
+ *
102
+ * the function will return `null` because the mouse is inside of left
103
+ * but is outside of the gap.
104
+ *
105
+ * the same is valid to the right side.
106
+ */
107
+
108
+ export const getMousePositionHorizontalRelativeByElement = (
109
+ mouseEvent: MouseEvent,
110
+ mouseMoveOptimization?: boolean,
111
+ elementContentRects?: ElementContentRects,
112
+ gapInPixels?: number,
113
+ ): 'left' | 'right' | null => {
114
+ const element = mouseEvent.target;
115
+
116
+ if (element instanceof HTMLElement) {
117
+ let width, x;
118
+ const closestCell = element.closest(SELECTOR_TABLE_LEAFS);
119
+
120
+ if (mouseMoveOptimization) {
121
+ const id = closestCell?.id ?? '';
122
+ width = elementContentRects?.[id]?.width ?? 0;
123
+ x = mouseEvent.offsetX;
124
+ } else {
125
+ const elementRect = element.getBoundingClientRect();
126
+ width = elementRect.width;
127
+ const left = elementRect.left;
128
+ x = mouseEvent.clientX - left;
129
+ }
130
+
131
+ if (width <= 0) {
132
+ return null;
133
+ }
134
+
135
+ if (!gapInPixels) {
136
+ return x / width > 0.5 ? 'right' : 'left';
137
+ } else {
138
+ if (x <= gapInPixels) {
139
+ return 'left';
140
+ } else if (x >= width - gapInPixels) {
141
+ return 'right';
142
+ }
143
+ }
144
+ }
145
+
146
+ return null;
147
+ };
148
+
149
+ export const getMousePositionVerticalRelativeByElement = (
150
+ mouseEvent: MouseEvent,
151
+ ): 'top' | 'bottom' | null => {
152
+ const element = mouseEvent.target;
153
+ if (element instanceof HTMLElement) {
154
+ const elementRect = element.getBoundingClientRect();
155
+ if (elementRect.height <= 0) {
156
+ return null;
157
+ }
158
+
159
+ const y = mouseEvent.clientY - elementRect.top;
160
+ return y / elementRect.height > 0.5 ? 'bottom' : 'top';
161
+ }
162
+
163
+ return null;
164
+ };
165
+
166
+ export const updateResizeHandles = (tableRef?: HTMLElement) => {
167
+ if (!tableRef) {
168
+ return;
169
+ }
170
+ const height = tableRef.offsetHeight + tableToolbarSize;
171
+ // see ED-7600
172
+ const nodes = Array.from(
173
+ tableRef.querySelectorAll(`.${ClassName.RESIZE_HANDLE}`) as NodeListOf<
174
+ HTMLElement
175
+ >,
176
+ );
177
+ if (!nodes || !nodes.length) {
178
+ return;
179
+ }
180
+
181
+ nodes.forEach((node) => {
182
+ node.style.height = `${height}px`;
183
+ });
184
+ };
185
+
186
+ export const hasResizeHandler = ({
187
+ columnEndIndexTarget,
188
+ target,
189
+ }: {
190
+ columnEndIndexTarget: number;
191
+ target: HTMLElement;
192
+ }): boolean => {
193
+ const tableElement = closestElement(target, 'table');
194
+
195
+ if (!tableElement) {
196
+ return false;
197
+ }
198
+
199
+ const query = [
200
+ `.${ClassName.RESIZE_HANDLE_DECORATION}`,
201
+ `[data-end-index="${columnEndIndexTarget}"]`,
202
+ ];
203
+
204
+ const decorationElement = tableElement.querySelectorAll(query.join(''));
205
+
206
+ if (!decorationElement || decorationElement.length === 0) {
207
+ return false;
208
+ }
209
+
210
+ return true;
211
+ };
@@ -0,0 +1,11 @@
1
+ import { EditorState } from 'prosemirror-state';
2
+
3
+ import { getPluginState } from '../pm-plugins/plugin-factory';
4
+
5
+ export function getAllowAddColumnCustomStep(state: EditorState): boolean {
6
+ const tablePluginState = getPluginState(state);
7
+ return (
8
+ Boolean(tablePluginState) &&
9
+ Boolean(tablePluginState.pluginConfig.allowAddColumnWithCustomStep)
10
+ );
11
+ }