@atlaskit/editor-plugin-table 0.0.0 → 0.0.1

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 +17 -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 +347 -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 +308 -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 +312 -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 +18 -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 +50 -1
  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 +116 -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 +132 -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 +413 -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,658 @@
1
+ import { Node as PmNode } from 'prosemirror-model';
2
+ import { EditorView, NodeView } from 'prosemirror-view';
3
+
4
+ import { findOverflowScrollParent } from '@atlaskit/editor-common/ui';
5
+
6
+ import { EventDispatcher } from '@atlaskit/editor-common/event-dispatcher';
7
+
8
+ import { mapChildren } from '@atlaskit/editor-common/utils';
9
+ import {
10
+ TableCssClassName as ClassName,
11
+ TableCssClassName,
12
+ TablePluginState,
13
+ } from '../../../types';
14
+ import {
15
+ stickyHeaderBorderBottomWidth,
16
+ stickyRowOffsetTop,
17
+ tableControlsSpacing,
18
+ tableScrollbarOffset,
19
+ } from '../../../ui/consts';
20
+ import { pluginKey as tablePluginKey } from '../../plugin-key';
21
+ import {
22
+ syncStickyRowToTable,
23
+ updateStickyMargins as updateTableMargin,
24
+ } from '../../table-resizing/utils/dom';
25
+ import { updateStickyState } from '../commands';
26
+ import { getTop, getTree, TableDOMElements } from './dom';
27
+ import type { GetEditorFeatureFlags } from '@atlaskit/editor-common/types';
28
+
29
+ import debounce from 'lodash/debounce';
30
+ import throttle from 'lodash/throttle';
31
+
32
+ // limit scroll event calls
33
+ const HEADER_ROW_SCROLL_THROTTLE_TIMEOUT = 200;
34
+
35
+ // timeout for resetting the scroll class - if it’s too long then users won’t be able to click on the header cells,
36
+ // if too short it would trigger too many dom udpates.
37
+ const HEADER_ROW_SCROLL_RESET_DEBOUNCE_TIMEOUT = 400;
38
+
39
+ export const supportedHeaderRow = (node: PmNode) => {
40
+ const allHeaders = mapChildren(
41
+ node,
42
+ (child) => child.type.name === 'tableHeader',
43
+ ).every(Boolean);
44
+
45
+ const someMerged = mapChildren(
46
+ node,
47
+ (child) => child.attrs.rowspan || 0,
48
+ ).some((rowspan) => rowspan > 1);
49
+
50
+ return allHeaders && !someMerged;
51
+ };
52
+
53
+ export class TableRowNodeView implements NodeView {
54
+ view: EditorView;
55
+ node: PmNode;
56
+ getPos: () => number;
57
+ eventDispatcher: EventDispatcher;
58
+
59
+ dom: HTMLTableRowElement; // this is the sticky header table row
60
+ contentDOM: HTMLElement;
61
+
62
+ isHeaderRow: boolean;
63
+ editorScrollableElement?: HTMLElement | Window;
64
+ colControlsOffset = 0;
65
+ focused = false;
66
+ topPosEditorElement = 0;
67
+ isSticky: boolean;
68
+ isTableInit: boolean;
69
+ lastTimePainted: number;
70
+
71
+ private intersectionObserver?: IntersectionObserver;
72
+ private resizeObserver?: ResizeObserver;
73
+ private stickyHeadersOptimization = false;
74
+ private sentinels: {
75
+ top?: HTMLElement | null;
76
+ bottom?: HTMLElement | null;
77
+ } = {};
78
+ private stickyRowHeight?: number;
79
+
80
+ get tree(): TableDOMElements | null | undefined {
81
+ return getTree(this.dom);
82
+ }
83
+
84
+ constructor(
85
+ node: PmNode,
86
+ view: EditorView,
87
+ getPos: any,
88
+ eventDispatcher: EventDispatcher,
89
+ getEditorFeatureFlags: GetEditorFeatureFlags,
90
+ ) {
91
+ this.view = view;
92
+ this.node = node;
93
+ this.getPos = getPos;
94
+ this.eventDispatcher = eventDispatcher;
95
+
96
+ this.dom = document.createElement('tr');
97
+ this.contentDOM = this.dom;
98
+
99
+ const featureFlags = getEditorFeatureFlags();
100
+ const { stickyHeadersOptimization } = featureFlags;
101
+ this.stickyHeadersOptimization = !!stickyHeadersOptimization;
102
+ this.lastTimePainted = 0;
103
+ this.isHeaderRow = supportedHeaderRow(node);
104
+ this.isSticky = false;
105
+ this.isTableInit = false;
106
+
107
+ if (this.isHeaderRow) {
108
+ this.dom.setAttribute('data-header-row', 'true');
109
+ this.subscribe();
110
+ }
111
+ }
112
+
113
+ /* external events */
114
+ listening = false;
115
+
116
+ headerRowMouseScrollEnd = debounce(() => {
117
+ this.dom.classList.remove('no-pointer-events');
118
+ }, HEADER_ROW_SCROLL_RESET_DEBOUNCE_TIMEOUT);
119
+
120
+ // When the header is sticky, the header row is set to position: fixed
121
+ // This prevents mouse wheel scrolling on the scroll-parent div when user's mouse is hovering the header row.
122
+ // This fix sets pointer-events: none on the header row briefly to avoid this behaviour
123
+ headerRowMouseScroll = throttle(() => {
124
+ if (this.isSticky) {
125
+ this.dom.classList.add('no-pointer-events');
126
+ this.headerRowMouseScrollEnd();
127
+ }
128
+ }, HEADER_ROW_SCROLL_THROTTLE_TIMEOUT);
129
+
130
+ subscribe() {
131
+ this.editorScrollableElement =
132
+ findOverflowScrollParent(this.view.dom as HTMLElement) || window;
133
+
134
+ if (this.editorScrollableElement) {
135
+ if (this.stickyHeadersOptimization) {
136
+ this.initObservers();
137
+ } else {
138
+ this.editorScrollableElement.addEventListener('scroll', this.onScroll);
139
+ }
140
+ this.topPosEditorElement = getTop(this.editorScrollableElement);
141
+ }
142
+
143
+ this.eventDispatcher.on('widthPlugin', this.onWidthPluginState);
144
+
145
+ this.eventDispatcher.on(
146
+ (tablePluginKey as any).key,
147
+ this.onTablePluginState,
148
+ );
149
+
150
+ this.listening = true;
151
+
152
+ this.dom.addEventListener('wheel', this.headerRowMouseScroll.bind(this));
153
+ this.dom.addEventListener(
154
+ 'touchmove',
155
+ this.headerRowMouseScroll.bind(this),
156
+ );
157
+ }
158
+
159
+ unsubscribe() {
160
+ if (!this.listening) {
161
+ return;
162
+ }
163
+
164
+ if (this.intersectionObserver) {
165
+ this.intersectionObserver.disconnect();
166
+ }
167
+
168
+ if (this.resizeObserver) {
169
+ this.resizeObserver.disconnect();
170
+ }
171
+
172
+ if (this.editorScrollableElement && !this.stickyHeadersOptimization) {
173
+ this.editorScrollableElement.removeEventListener('scroll', this.onScroll);
174
+ }
175
+
176
+ this.eventDispatcher.off('widthPlugin', this.onWidthPluginState);
177
+ this.eventDispatcher.off(
178
+ (tablePluginKey as any).key,
179
+ this.onTablePluginState,
180
+ );
181
+
182
+ this.listening = false;
183
+
184
+ this.dom.removeEventListener('wheel', this.headerRowMouseScroll);
185
+ this.dom.removeEventListener('touchmove', this.headerRowMouseScroll);
186
+ }
187
+
188
+ // initialize intersection observer to track if table is within scroll area
189
+ private initObservers() {
190
+ if (!this.dom || this.dom.dataset.isObserved) {
191
+ return;
192
+ }
193
+ this.dom.dataset.isObserved = 'true';
194
+ this.createIntersectionObserver();
195
+ this.createResizeObserver();
196
+
197
+ if (!this.intersectionObserver || !this.resizeObserver) {
198
+ return;
199
+ }
200
+
201
+ this.resizeObserver.observe(this.dom);
202
+
203
+ window.requestAnimationFrame(() => {
204
+ // we expect tree to be defined after animation frame
205
+ const tableContainer = this.tree?.wrapper.closest(
206
+ `.${TableCssClassName.NODEVIEW_WRAPPER}`,
207
+ );
208
+ if (tableContainer) {
209
+ this.sentinels.top = tableContainer
210
+ .getElementsByClassName(ClassName.TABLE_STICKY_SENTINEL_TOP)
211
+ .item(0) as HTMLElement;
212
+ this.sentinels.bottom = tableContainer
213
+ .getElementsByClassName(ClassName.TABLE_STICKY_SENTINEL_BOTTOM)
214
+ .item(0) as HTMLElement;
215
+ [this.sentinels.top, this.sentinels.bottom].forEach((el) => {
216
+ // skip if already observed for another row on this table
217
+ if (el && !el.dataset.isObserved) {
218
+ el.dataset.isObserved = 'true';
219
+ this.intersectionObserver!.observe(el);
220
+ }
221
+ });
222
+ }
223
+ });
224
+ }
225
+
226
+ // updating bottom sentinel position if sticky header height changes
227
+ // to allocate for new header height
228
+ private createResizeObserver() {
229
+ this.resizeObserver = new ResizeObserver((entries) => {
230
+ if (!this.tree) {
231
+ return;
232
+ }
233
+ const { table } = this.tree;
234
+ entries.forEach((entry) => {
235
+ const newHeight = entry.contentRect
236
+ ? entry.contentRect.height
237
+ : (entry.target as HTMLElement).offsetHeight;
238
+
239
+ if (
240
+ this.sentinels.bottom &&
241
+ // When the table header is sticky, it would be taller by a 1px (border-bottom),
242
+ // So we adding this check to allow a 1px difference.
243
+ Math.abs(newHeight - (this.stickyRowHeight || 0)) >
244
+ stickyHeaderBorderBottomWidth
245
+ ) {
246
+ this.stickyRowHeight = newHeight;
247
+ this.sentinels.bottom.style.bottom = `${
248
+ tableScrollbarOffset + stickyRowOffsetTop + newHeight
249
+ }px`;
250
+ updateTableMargin(table);
251
+ }
252
+ });
253
+ });
254
+ }
255
+
256
+ private createIntersectionObserver() {
257
+ this.intersectionObserver = new IntersectionObserver(
258
+ (entries: IntersectionObserverEntry[], _: IntersectionObserver) => {
259
+ if (!this.tree) {
260
+ return;
261
+ }
262
+ const { table } = this.tree;
263
+ entries.forEach((entry) => {
264
+ const target = entry.target as HTMLElement;
265
+
266
+ // if the rootBounds has 0 height, e.g. confluence preview mode, we do nothing.
267
+ if (entry.rootBounds?.height === 0) {
268
+ return;
269
+ }
270
+
271
+ if (target.classList.contains(ClassName.TABLE_STICKY_SENTINEL_TOP)) {
272
+ const sentinelIsBelowScrollArea =
273
+ (entry.rootBounds?.bottom || 0) < entry.boundingClientRect.bottom;
274
+
275
+ if (!entry.isIntersecting && !sentinelIsBelowScrollArea) {
276
+ this.tree && this.makeHeaderRowSticky(this.tree);
277
+ } else {
278
+ table && this.makeRowHeaderNotSticky(table);
279
+ }
280
+ }
281
+
282
+ if (
283
+ target.classList.contains(ClassName.TABLE_STICKY_SENTINEL_BOTTOM)
284
+ ) {
285
+ const sentinelIsAboveScrollArea =
286
+ entry.boundingClientRect.top - this.dom.offsetHeight <
287
+ (entry.rootBounds?.top || 0);
288
+
289
+ if (table && !entry.isIntersecting && sentinelIsAboveScrollArea) {
290
+ this.makeRowHeaderNotSticky(table);
291
+ } else if (entry.isIntersecting && sentinelIsAboveScrollArea) {
292
+ this.tree && this.makeHeaderRowSticky(this.tree);
293
+ }
294
+ }
295
+ });
296
+ },
297
+ { root: this.editorScrollableElement as Element },
298
+ );
299
+ }
300
+ /* paint/update loop */
301
+
302
+ previousDomTop: number | undefined;
303
+ previousPadding: number | undefined;
304
+
305
+ latestDomTop: number | undefined;
306
+
307
+ nextFrame: number | undefined;
308
+
309
+ onScroll = () => {
310
+ if (!this.tree) {
311
+ return;
312
+ }
313
+
314
+ this.latestDomTop = getTop(this.tree.wrapper);
315
+
316
+ // kick off rAF loop again if it hasn't already happened
317
+ if (!this.nextFrame) {
318
+ this.loop();
319
+ }
320
+ };
321
+
322
+ loop = () => {
323
+ this.nextFrame = window.requestAnimationFrame(() => {
324
+ if (
325
+ this.previousDomTop === this.latestDomTop &&
326
+ this.previousPadding === this.padding
327
+ ) {
328
+ this.nextFrame = undefined;
329
+ return;
330
+ }
331
+
332
+ // can't store these since React might re-render at any time
333
+ const tree = this.tree;
334
+ if (!tree) {
335
+ this.nextFrame = undefined;
336
+ return;
337
+ }
338
+
339
+ this.paint(tree);
340
+
341
+ // run again on next frame
342
+ this.previousPadding = this.padding;
343
+ this.previousDomTop = this.latestDomTop;
344
+ this.loop();
345
+ });
346
+ };
347
+
348
+ paint = (tree: TableDOMElements) => {
349
+ const { table, wrapper } = tree;
350
+
351
+ // If the previous refresh is less than 10ms then don't do anything.
352
+ // The jumpiness happen under that time and this is to avoid it.
353
+ const timelapse = Math.abs(performance.now() - this.lastTimePainted);
354
+ if (timelapse < 10) {
355
+ return;
356
+ }
357
+
358
+ if (this.shouldHeaderStick(tree)) {
359
+ this.makeHeaderRowSticky(tree);
360
+ } else {
361
+ this.makeRowHeaderNotSticky(table);
362
+ }
363
+
364
+ // ensure scroll positions are locked
365
+ this.dom.scrollLeft = wrapper.scrollLeft;
366
+ this.lastTimePainted = performance.now();
367
+ };
368
+
369
+ /* nodeview lifecycle */
370
+
371
+ update(node: PmNode, ..._args: any[]) {
372
+ // do nothing if nodes were identical
373
+ if (node === this.node) {
374
+ return true;
375
+ }
376
+
377
+ // see if we're changing into a header row or
378
+ // changing away from one
379
+ const newNodeisHeaderRow = supportedHeaderRow(node);
380
+ if (this.isHeaderRow !== newNodeisHeaderRow) {
381
+ return false; // re-create nodeview
382
+ }
383
+
384
+ // node is different but no need to re-create nodeview
385
+ this.node = node;
386
+
387
+ // don't do anything if we're just a regular tr
388
+ if (!this.isHeaderRow) {
389
+ return true;
390
+ }
391
+
392
+ // something changed, sync widths
393
+ const tbody = this.dom.parentElement;
394
+ const table = tbody && tbody.parentElement;
395
+ syncStickyRowToTable(table);
396
+
397
+ return true;
398
+ }
399
+
400
+ destroy() {
401
+ this.unsubscribe();
402
+
403
+ if (this.tree) {
404
+ this.makeRowHeaderNotSticky(this.tree.table, true);
405
+ }
406
+
407
+ this.emitOff(true);
408
+ }
409
+
410
+ ignoreMutation(
411
+ mutationRecord: MutationRecord | { type: 'selection'; target: Element },
412
+ ) {
413
+ /* tableRows are not directly editable by the user
414
+ * so it should be safe to ignore mutations that we cause
415
+ * by updating styles and classnames on this DOM element
416
+ *
417
+ * Update: should not ignore mutations for row selection to avoid known issue with table selection highlight in firefox
418
+ * Related bug report: https://bugzilla.mozilla.org/show_bug.cgi?id=1289673
419
+ * */
420
+ const isTableSelection =
421
+ mutationRecord.type === 'selection' &&
422
+ mutationRecord.target.nodeName === 'TR';
423
+ /**
424
+ * Update: should not ignore mutations when an node is added, as this interferes with
425
+ * prosemirrors handling of some language inputs in Safari (ie. Pinyin, Hiragana).
426
+ *
427
+ * In paticular, when a composition occurs at the start of the first node inside a table cell, if the resulting mutation
428
+ * from the composition end is ignored than prosemirror will end up with; invalid table markup nesting and a misplaced
429
+ * selection and insertion.
430
+ */
431
+ const isNodeInsertion =
432
+ mutationRecord.type === 'childList' &&
433
+ mutationRecord.target.nodeName === 'TR' &&
434
+ mutationRecord.addedNodes.length;
435
+
436
+ if (isTableSelection || isNodeInsertion) {
437
+ return false;
438
+ }
439
+
440
+ return true;
441
+ }
442
+
443
+ /* receive external events */
444
+
445
+ onTablePluginState = (state: TablePluginState) => {
446
+ const tableRef = state.tableRef;
447
+ let focusChanged = false;
448
+
449
+ const tree = this.tree;
450
+ if (!tree) {
451
+ return;
452
+ }
453
+
454
+ // make it non-sticky initially to avoid making it look separated
455
+ if (!this.isTableInit) {
456
+ if (this.tree) {
457
+ this.makeRowHeaderNotSticky(this.tree.table);
458
+ this.isTableInit = true;
459
+ }
460
+ }
461
+
462
+ // when header rows are toggled off - mark sentinels as unobserved
463
+ if (!state.isHeaderRowEnabled) {
464
+ [this.sentinels.top, this.sentinels.bottom].forEach((el) => {
465
+ if (el) {
466
+ delete el.dataset.isObserved;
467
+ }
468
+ });
469
+ }
470
+
471
+ const isCurrentTableSelected = tableRef === tree.table;
472
+ if (isCurrentTableSelected !== this.focused) {
473
+ focusChanged = true;
474
+ }
475
+ this.focused = isCurrentTableSelected;
476
+
477
+ const { wrapper } = tree;
478
+
479
+ const tableContainer = wrapper.parentElement!;
480
+ const tableContentWrapper = tableContainer.parentElement;
481
+
482
+ const layoutContainer =
483
+ tableContentWrapper && tableContentWrapper.parentElement;
484
+
485
+ if (isCurrentTableSelected) {
486
+ this.colControlsOffset = tableControlsSpacing;
487
+
488
+ if (
489
+ layoutContainer &&
490
+ layoutContainer.getAttribute('data-layout-content')
491
+ ) {
492
+ // move table a little out of the way
493
+ // to provide spacing for table controls
494
+ tableContentWrapper!.style.paddingLeft = '11px';
495
+ }
496
+ } else {
497
+ this.colControlsOffset = 0;
498
+ if (
499
+ layoutContainer &&
500
+ layoutContainer.getAttribute('data-layout-content')
501
+ ) {
502
+ tableContentWrapper!.style.removeProperty('padding-left');
503
+ }
504
+ }
505
+
506
+ // run after table style changes have been committed
507
+ setTimeout(() => {
508
+ // if focus changed while header is sticky - still repaint the positions will shift
509
+ if (!this.stickyHeadersOptimization || (focusChanged && this.isSticky)) {
510
+ this.paint(tree);
511
+ }
512
+ syncStickyRowToTable(tree.table);
513
+ }, 0);
514
+ };
515
+
516
+ onWidthPluginState = () => {
517
+ // table width might have changed, sync that back to sticky row
518
+ const tree = this.tree;
519
+ if (!tree) {
520
+ return;
521
+ }
522
+
523
+ syncStickyRowToTable(tree.table);
524
+ };
525
+
526
+ shouldHeaderStick = (tree: TableDOMElements): boolean => {
527
+ const { wrapper } = tree;
528
+ const tableWrapperRect = wrapper.getBoundingClientRect();
529
+ const editorAreaRect = (this
530
+ .editorScrollableElement as HTMLElement).getBoundingClientRect();
531
+
532
+ const stickyHeaderRect = this.contentDOM.getBoundingClientRect();
533
+ const firstHeaderRow = !this.dom.previousElementSibling;
534
+ const subsequentRows = !!this.dom.nextElementSibling;
535
+ const isHeaderValid = firstHeaderRow && subsequentRows;
536
+
537
+ // if the table wrapper is less than the editor top pos then make it sticky
538
+ // Make header sticky if table wrapper top is outside viewport
539
+ // but bottom is still in the viewport.
540
+ if (
541
+ tableWrapperRect.top < editorAreaRect.top &&
542
+ tableWrapperRect.bottom > editorAreaRect.top &&
543
+ isHeaderValid
544
+ ) {
545
+ return true;
546
+ }
547
+
548
+ // if the sticky header is below the editor area make it non-sticky
549
+ if (stickyHeaderRect.top > editorAreaRect.top) {
550
+ return false;
551
+ }
552
+
553
+ // otherwise make it non-sticky
554
+ return false;
555
+ };
556
+
557
+ makeHeaderRowSticky = (tree: TableDOMElements) => {
558
+ // If header row height is more than 50% of viewport height don't do this
559
+ if (this.stickyRowHeight && this.stickyRowHeight > window.innerHeight / 2) {
560
+ return;
561
+ }
562
+
563
+ const { table } = tree;
564
+
565
+ const currentTableTop = this.getCurrentTableTop(tree);
566
+ const domTop =
567
+ currentTableTop > 0
568
+ ? this.topPosEditorElement
569
+ : this.topPosEditorElement + currentTableTop;
570
+
571
+ if (!this.isSticky) {
572
+ syncStickyRowToTable(table);
573
+ this.dom.classList.add('sticky');
574
+ table.classList.add(ClassName.TABLE_STICKY);
575
+
576
+ this.isSticky = true;
577
+ }
578
+
579
+ this.dom.style.top = `${domTop}px`;
580
+ updateTableMargin(table);
581
+
582
+ this.emitOn(domTop, this.colControlsOffset);
583
+ };
584
+
585
+ makeRowHeaderNotSticky = (
586
+ table: HTMLElement,
587
+ isEditorDestroyed: boolean = false,
588
+ ) => {
589
+ if (!this.isSticky || !table || !this.dom) {
590
+ return;
591
+ }
592
+
593
+ this.dom.style.removeProperty('width');
594
+ this.dom.classList.remove('sticky');
595
+ table.classList.remove(ClassName.TABLE_STICKY);
596
+
597
+ this.isSticky = false;
598
+
599
+ this.dom.style.top = '';
600
+ table.style.removeProperty('margin-top');
601
+
602
+ this.emitOff(isEditorDestroyed);
603
+ };
604
+
605
+ getWrapperoffset = (inverse: boolean = false): number => {
606
+ const focusValue = inverse ? !this.focused : this.focused;
607
+ return focusValue ? 0 : tableControlsSpacing;
608
+ };
609
+
610
+ getWrapperRefTop = (wrapper: HTMLElement): number =>
611
+ Math.round(getTop(wrapper)) + this.getWrapperoffset();
612
+
613
+ // TODO: rename!
614
+ getScrolledTableTop = (wrapper: HTMLElement): number =>
615
+ this.getWrapperRefTop(wrapper) - this.topPosEditorElement;
616
+
617
+ getCurrentTableTop = (tree: TableDOMElements): number =>
618
+ this.getScrolledTableTop(tree.wrapper) + tree.table.clientHeight;
619
+
620
+ /* emit external events */
621
+
622
+ padding = 0;
623
+ top = 0;
624
+
625
+ emitOn = (top: number, padding: number) => {
626
+ if (top === this.top && padding === this.padding) {
627
+ return;
628
+ }
629
+
630
+ this.top = top;
631
+ this.padding = padding;
632
+
633
+ updateStickyState({
634
+ pos: this.getPos(),
635
+ top,
636
+ sticky: true,
637
+ padding,
638
+ })(this.view.state, this.view.dispatch, this.view);
639
+ };
640
+
641
+ emitOff = (isEditorDestroyed: boolean) => {
642
+ if (this.top === 0 && this.padding === 0) {
643
+ return;
644
+ }
645
+
646
+ this.top = 0;
647
+ this.padding = 0;
648
+
649
+ if (!isEditorDestroyed) {
650
+ updateStickyState({
651
+ pos: this.getPos(),
652
+ sticky: false,
653
+ top: this.top,
654
+ padding: this.padding,
655
+ })(this.view.state, this.view.dispatch, this.view);
656
+ }
657
+ };
658
+ }
@@ -0,0 +1,6 @@
1
+ import { PluginKey } from 'prosemirror-state';
2
+ import { StickyPluginState } from './types';
3
+
4
+ export const pluginKey = new PluginKey<StickyPluginState>(
5
+ 'stickyHeadersPlugin',
6
+ );
@@ -0,0 +1,55 @@
1
+ import { pluginFactory } from '@atlaskit/editor-common/utils';
2
+
3
+ import { pluginKey } from './plugin-key';
4
+ import { StickyPluginAction, StickyPluginState } from './types';
5
+
6
+ const reducer = (
7
+ pluginState: StickyPluginState,
8
+ action: StickyPluginAction,
9
+ ): StickyPluginState => {
10
+ if (action.name === 'UPDATE') {
11
+ let updated = false;
12
+ const updatedState = pluginState.map((oldTableState) => {
13
+ const replace = oldTableState.pos === action.state.pos;
14
+
15
+ if (replace) {
16
+ updated = true;
17
+ }
18
+
19
+ return replace ? action.state : oldTableState;
20
+ });
21
+
22
+ if (!updated) {
23
+ // new, add it
24
+ updatedState.push(action.state);
25
+ }
26
+
27
+ return updatedState;
28
+ } else if (action.name === 'REMOVE') {
29
+ return pluginState.filter((rowState) => rowState.pos !== action.pos);
30
+ }
31
+
32
+ return pluginState;
33
+ };
34
+
35
+ const { createPluginState, createCommand } = pluginFactory(pluginKey, reducer, {
36
+ mapping: (tr, pluginState) => {
37
+ if (tr.docChanged) {
38
+ return pluginState
39
+ .map((rowInfo) => {
40
+ const remapped = tr.mapping.mapResult(rowInfo.pos);
41
+ return remapped
42
+ ? {
43
+ ...rowInfo,
44
+ pos: remapped.pos,
45
+ }
46
+ : undefined;
47
+ })
48
+ .filter((f) => f !== undefined) as StickyPluginState;
49
+ }
50
+
51
+ return pluginState;
52
+ },
53
+ });
54
+
55
+ export { createPluginState, createCommand };