@ckeditor/ckeditor5-table 39.0.1 → 40.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (229) hide show
  1. package/LICENSE.md +1 -1
  2. package/README.md +3 -3
  3. package/build/table.js +1 -1
  4. package/build/table.js.map +1 -0
  5. package/build/translations/hy.js +1 -0
  6. package/lang/translations/ar.po +1 -0
  7. package/lang/translations/az.po +1 -0
  8. package/lang/translations/bg.po +1 -0
  9. package/lang/translations/bn.po +1 -0
  10. package/lang/translations/ca.po +1 -0
  11. package/lang/translations/cs.po +1 -0
  12. package/lang/translations/da.po +1 -0
  13. package/lang/translations/de-ch.po +1 -0
  14. package/lang/translations/de.po +1 -0
  15. package/lang/translations/el.po +1 -0
  16. package/lang/translations/en-au.po +1 -0
  17. package/lang/translations/en-gb.po +1 -0
  18. package/lang/translations/en.po +1 -0
  19. package/lang/translations/es.po +1 -0
  20. package/lang/translations/et.po +1 -0
  21. package/lang/translations/fa.po +1 -0
  22. package/lang/translations/fi.po +1 -0
  23. package/lang/translations/fr.po +1 -0
  24. package/lang/translations/gl.po +1 -0
  25. package/lang/translations/he.po +1 -0
  26. package/lang/translations/hi.po +1 -0
  27. package/lang/translations/hr.po +1 -0
  28. package/lang/translations/hu.po +1 -0
  29. package/lang/translations/hy.po +262 -0
  30. package/lang/translations/id.po +1 -0
  31. package/lang/translations/it.po +1 -0
  32. package/lang/translations/ja.po +1 -0
  33. package/lang/translations/ko.po +1 -0
  34. package/lang/translations/ku.po +1 -0
  35. package/lang/translations/lt.po +1 -0
  36. package/lang/translations/lv.po +1 -0
  37. package/lang/translations/ms.po +1 -0
  38. package/lang/translations/nb.po +1 -0
  39. package/lang/translations/ne.po +1 -0
  40. package/lang/translations/nl.po +1 -0
  41. package/lang/translations/no.po +1 -0
  42. package/lang/translations/pl.po +1 -0
  43. package/lang/translations/pt-br.po +1 -0
  44. package/lang/translations/pt.po +1 -0
  45. package/lang/translations/ro.po +1 -0
  46. package/lang/translations/ru.po +1 -0
  47. package/lang/translations/sk.po +1 -0
  48. package/lang/translations/sl.po +1 -0
  49. package/lang/translations/sq.po +1 -0
  50. package/lang/translations/sr-latn.po +1 -0
  51. package/lang/translations/sr.po +1 -0
  52. package/lang/translations/sv.po +1 -0
  53. package/lang/translations/th.po +1 -0
  54. package/lang/translations/tk.po +1 -0
  55. package/lang/translations/tr.po +1 -0
  56. package/lang/translations/tt.po +1 -0
  57. package/lang/translations/ug.po +1 -0
  58. package/lang/translations/uk.po +1 -0
  59. package/lang/translations/ur.po +1 -0
  60. package/lang/translations/uz.po +1 -0
  61. package/lang/translations/vi.po +1 -0
  62. package/lang/translations/zh-cn.po +1 -0
  63. package/lang/translations/zh.po +1 -0
  64. package/package.json +2 -6
  65. package/src/augmentation.d.ts +76 -76
  66. package/src/augmentation.js +5 -5
  67. package/src/commands/insertcolumncommand.d.ts +55 -55
  68. package/src/commands/insertcolumncommand.js +67 -67
  69. package/src/commands/insertrowcommand.d.ts +54 -54
  70. package/src/commands/insertrowcommand.js +66 -66
  71. package/src/commands/inserttablecommand.d.ts +44 -44
  72. package/src/commands/inserttablecommand.js +69 -69
  73. package/src/commands/mergecellcommand.d.ts +68 -68
  74. package/src/commands/mergecellcommand.js +198 -198
  75. package/src/commands/mergecellscommand.d.ts +28 -28
  76. package/src/commands/mergecellscommand.js +94 -94
  77. package/src/commands/removecolumncommand.d.ts +29 -29
  78. package/src/commands/removecolumncommand.js +109 -109
  79. package/src/commands/removerowcommand.d.ts +29 -29
  80. package/src/commands/removerowcommand.js +82 -82
  81. package/src/commands/selectcolumncommand.d.ts +33 -33
  82. package/src/commands/selectcolumncommand.js +60 -60
  83. package/src/commands/selectrowcommand.d.ts +33 -33
  84. package/src/commands/selectrowcommand.js +56 -56
  85. package/src/commands/setheadercolumncommand.d.ts +50 -50
  86. package/src/commands/setheadercolumncommand.js +71 -71
  87. package/src/commands/setheaderrowcommand.d.ts +53 -53
  88. package/src/commands/setheaderrowcommand.js +79 -79
  89. package/src/commands/splitcellcommand.d.ts +43 -43
  90. package/src/commands/splitcellcommand.js +54 -54
  91. package/src/converters/downcast.d.ts +63 -63
  92. package/src/converters/downcast.js +146 -146
  93. package/src/converters/table-caption-post-fixer.d.ts +20 -20
  94. package/src/converters/table-caption-post-fixer.js +53 -53
  95. package/src/converters/table-cell-paragraph-post-fixer.d.ts +32 -32
  96. package/src/converters/table-cell-paragraph-post-fixer.js +107 -107
  97. package/src/converters/table-cell-refresh-handler.d.ts +18 -18
  98. package/src/converters/table-cell-refresh-handler.js +45 -45
  99. package/src/converters/table-headings-refresh-handler.d.ts +17 -17
  100. package/src/converters/table-headings-refresh-handler.js +49 -49
  101. package/src/converters/table-layout-post-fixer.d.ts +226 -226
  102. package/src/converters/table-layout-post-fixer.js +367 -367
  103. package/src/converters/tableproperties.d.ts +54 -54
  104. package/src/converters/tableproperties.js +159 -159
  105. package/src/converters/upcasttable.d.ts +49 -49
  106. package/src/converters/upcasttable.js +243 -243
  107. package/src/index.d.ts +60 -60
  108. package/src/index.js +30 -30
  109. package/src/plaintableoutput.d.ts +26 -26
  110. package/src/plaintableoutput.js +123 -123
  111. package/src/table.d.ts +40 -40
  112. package/src/table.js +44 -44
  113. package/src/tablecaption/tablecaptionediting.d.ts +63 -63
  114. package/src/tablecaption/tablecaptionediting.js +122 -122
  115. package/src/tablecaption/tablecaptionui.d.ts +21 -21
  116. package/src/tablecaption/tablecaptionui.js +57 -57
  117. package/src/tablecaption/toggletablecaptioncommand.d.ts +68 -68
  118. package/src/tablecaption/toggletablecaptioncommand.js +104 -104
  119. package/src/tablecaption/utils.d.ts +42 -42
  120. package/src/tablecaption/utils.js +67 -67
  121. package/src/tablecaption.d.ts +24 -24
  122. package/src/tablecaption.js +28 -28
  123. package/src/tablecellproperties/commands/tablecellbackgroundcolorcommand.d.ts +32 -32
  124. package/src/tablecellproperties/commands/tablecellbackgroundcolorcommand.js +30 -30
  125. package/src/tablecellproperties/commands/tablecellbordercolorcommand.d.ts +37 -37
  126. package/src/tablecellproperties/commands/tablecellbordercolorcommand.js +44 -44
  127. package/src/tablecellproperties/commands/tablecellborderstylecommand.d.ts +37 -37
  128. package/src/tablecellproperties/commands/tablecellborderstylecommand.js +44 -44
  129. package/src/tablecellproperties/commands/tablecellborderwidthcommand.d.ts +51 -51
  130. package/src/tablecellproperties/commands/tablecellborderwidthcommand.js +64 -64
  131. package/src/tablecellproperties/commands/tablecellheightcommand.d.ts +46 -46
  132. package/src/tablecellproperties/commands/tablecellheightcommand.js +51 -51
  133. package/src/tablecellproperties/commands/tablecellhorizontalalignmentcommand.d.ts +32 -32
  134. package/src/tablecellproperties/commands/tablecellhorizontalalignmentcommand.js +30 -30
  135. package/src/tablecellproperties/commands/tablecellpaddingcommand.d.ts +51 -51
  136. package/src/tablecellproperties/commands/tablecellpaddingcommand.js +64 -64
  137. package/src/tablecellproperties/commands/tablecellpropertycommand.d.ts +62 -62
  138. package/src/tablecellproperties/commands/tablecellpropertycommand.js +92 -92
  139. package/src/tablecellproperties/commands/tablecellverticalalignmentcommand.d.ts +40 -40
  140. package/src/tablecellproperties/commands/tablecellverticalalignmentcommand.js +38 -38
  141. package/src/tablecellproperties/tablecellpropertiesediting.d.ts +43 -43
  142. package/src/tablecellproperties/tablecellpropertiesediting.js +241 -241
  143. package/src/tablecellproperties/tablecellpropertiesui.d.ts +112 -112
  144. package/src/tablecellproperties/tablecellpropertiesui.js +330 -330
  145. package/src/tablecellproperties/ui/tablecellpropertiesview.d.ts +228 -228
  146. package/src/tablecellproperties/ui/tablecellpropertiesview.js +548 -539
  147. package/src/tablecellproperties.d.ts +30 -30
  148. package/src/tablecellproperties.js +34 -34
  149. package/src/tablecellwidth/commands/tablecellwidthcommand.d.ts +46 -46
  150. package/src/tablecellwidth/commands/tablecellwidthcommand.js +51 -51
  151. package/src/tablecellwidth/tablecellwidthediting.d.ts +29 -29
  152. package/src/tablecellwidth/tablecellwidthediting.js +45 -45
  153. package/src/tableclipboard.d.ts +65 -65
  154. package/src/tableclipboard.js +450 -450
  155. package/src/tablecolumnresize/constants.d.ts +20 -20
  156. package/src/tablecolumnresize/constants.js +20 -20
  157. package/src/tablecolumnresize/converters.d.ts +18 -18
  158. package/src/tablecolumnresize/converters.js +46 -45
  159. package/src/tablecolumnresize/tablecolumnresizeediting.d.ts +139 -139
  160. package/src/tablecolumnresize/tablecolumnresizeediting.js +583 -571
  161. package/src/tablecolumnresize/tablewidthscommand.d.ts +38 -38
  162. package/src/tablecolumnresize/tablewidthscommand.js +61 -61
  163. package/src/tablecolumnresize/utils.d.ts +148 -141
  164. package/src/tablecolumnresize/utils.js +358 -330
  165. package/src/tablecolumnresize.d.ts +26 -26
  166. package/src/tablecolumnresize.js +30 -30
  167. package/src/tableconfig.d.ts +343 -343
  168. package/src/tableconfig.js +5 -5
  169. package/src/tableediting.d.ts +98 -98
  170. package/src/tableediting.js +191 -191
  171. package/src/tablekeyboard.d.ts +68 -68
  172. package/src/tablekeyboard.js +279 -279
  173. package/src/tablemouse/mouseeventsobserver.d.ts +62 -62
  174. package/src/tablemouse/mouseeventsobserver.js +35 -35
  175. package/src/tablemouse.d.ts +48 -48
  176. package/src/tablemouse.js +172 -172
  177. package/src/tableproperties/commands/tablealignmentcommand.d.ts +32 -32
  178. package/src/tableproperties/commands/tablealignmentcommand.js +30 -30
  179. package/src/tableproperties/commands/tablebackgroundcolorcommand.d.ts +32 -32
  180. package/src/tableproperties/commands/tablebackgroundcolorcommand.js +30 -30
  181. package/src/tableproperties/commands/tablebordercolorcommand.d.ts +37 -37
  182. package/src/tableproperties/commands/tablebordercolorcommand.js +44 -44
  183. package/src/tableproperties/commands/tableborderstylecommand.d.ts +37 -37
  184. package/src/tableproperties/commands/tableborderstylecommand.js +44 -44
  185. package/src/tableproperties/commands/tableborderwidthcommand.d.ts +51 -51
  186. package/src/tableproperties/commands/tableborderwidthcommand.js +64 -64
  187. package/src/tableproperties/commands/tableheightcommand.d.ts +46 -46
  188. package/src/tableproperties/commands/tableheightcommand.js +54 -54
  189. package/src/tableproperties/commands/tablepropertycommand.d.ts +61 -61
  190. package/src/tableproperties/commands/tablepropertycommand.js +80 -80
  191. package/src/tableproperties/commands/tablewidthcommand.d.ts +46 -46
  192. package/src/tableproperties/commands/tablewidthcommand.js +54 -54
  193. package/src/tableproperties/tablepropertiesediting.d.ts +40 -40
  194. package/src/tableproperties/tablepropertiesediting.js +206 -206
  195. package/src/tableproperties/tablepropertiesui.d.ts +114 -114
  196. package/src/tableproperties/tablepropertiesui.js +321 -321
  197. package/src/tableproperties/ui/tablepropertiesview.d.ts +207 -207
  198. package/src/tableproperties/ui/tablepropertiesview.js +466 -457
  199. package/src/tableproperties.d.ts +30 -30
  200. package/src/tableproperties.js +34 -34
  201. package/src/tableselection.d.ts +107 -107
  202. package/src/tableselection.js +297 -297
  203. package/src/tabletoolbar.d.ts +32 -32
  204. package/src/tabletoolbar.js +57 -57
  205. package/src/tableui.d.ts +53 -53
  206. package/src/tableui.js +309 -309
  207. package/src/tableutils.d.ts +448 -448
  208. package/src/tableutils.js +1055 -1041
  209. package/src/tablewalker.d.ts +362 -323
  210. package/src/tablewalker.js +393 -333
  211. package/src/ui/colorinputview.d.ts +140 -140
  212. package/src/ui/colorinputview.js +271 -265
  213. package/src/ui/formrowview.d.ts +61 -61
  214. package/src/ui/formrowview.js +57 -57
  215. package/src/ui/inserttableview.d.ts +77 -77
  216. package/src/ui/inserttableview.js +169 -169
  217. package/src/utils/common.d.ts +42 -42
  218. package/src/utils/common.js +57 -57
  219. package/src/utils/structure.d.ts +245 -245
  220. package/src/utils/structure.js +426 -426
  221. package/src/utils/table-properties.d.ts +67 -67
  222. package/src/utils/table-properties.js +86 -86
  223. package/src/utils/ui/contextualballoon.d.ts +34 -34
  224. package/src/utils/ui/contextualballoon.js +106 -106
  225. package/src/utils/ui/table-properties.d.ts +195 -195
  226. package/src/utils/ui/table-properties.js +362 -362
  227. package/src/utils/ui/widget.d.ts +16 -16
  228. package/src/utils/ui/widget.js +38 -38
  229. package/theme/tablecolumnresize.css +8 -6
@@ -1,29 +1,29 @@
1
- /**
2
- * @license Copyright (c) 2003-2023, CKSource Holding sp. z o.o. All rights reserved.
3
- * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
- */
5
- /**
6
- * @module table/commands/removecolumncommand
7
- */
8
- import { Command } from 'ckeditor5/src/core';
9
- /**
10
- * The remove column command.
11
- *
12
- * The command is registered by {@link module:table/tableediting~TableEditing} as the `'removeTableColumn'` editor command.
13
- *
14
- * To remove the column containing the selected cell, execute the command:
15
- *
16
- * ```ts
17
- * editor.execute( 'removeTableColumn' );
18
- * ```
19
- */
20
- export default class RemoveColumnCommand extends Command {
21
- /**
22
- * @inheritDoc
23
- */
24
- refresh(): void;
25
- /**
26
- * @inheritDoc
27
- */
28
- execute(): void;
29
- }
1
+ /**
2
+ * @license Copyright (c) 2003-2023, CKSource Holding sp. z o.o. All rights reserved.
3
+ * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
+ */
5
+ /**
6
+ * @module table/commands/removecolumncommand
7
+ */
8
+ import { Command } from 'ckeditor5/src/core';
9
+ /**
10
+ * The remove column command.
11
+ *
12
+ * The command is registered by {@link module:table/tableediting~TableEditing} as the `'removeTableColumn'` editor command.
13
+ *
14
+ * To remove the column containing the selected cell, execute the command:
15
+ *
16
+ * ```ts
17
+ * editor.execute( 'removeTableColumn' );
18
+ * ```
19
+ */
20
+ export default class RemoveColumnCommand extends Command {
21
+ /**
22
+ * @inheritDoc
23
+ */
24
+ refresh(): void;
25
+ /**
26
+ * @inheritDoc
27
+ */
28
+ execute(): void;
29
+ }
@@ -1,109 +1,109 @@
1
- /**
2
- * @license Copyright (c) 2003-2023, CKSource Holding sp. z o.o. All rights reserved.
3
- * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
- */
5
- /**
6
- * @module table/commands/removecolumncommand
7
- */
8
- import { Command } from 'ckeditor5/src/core';
9
- import TableWalker from '../tablewalker';
10
- /**
11
- * The remove column command.
12
- *
13
- * The command is registered by {@link module:table/tableediting~TableEditing} as the `'removeTableColumn'` editor command.
14
- *
15
- * To remove the column containing the selected cell, execute the command:
16
- *
17
- * ```ts
18
- * editor.execute( 'removeTableColumn' );
19
- * ```
20
- */
21
- export default class RemoveColumnCommand extends Command {
22
- /**
23
- * @inheritDoc
24
- */
25
- refresh() {
26
- const tableUtils = this.editor.plugins.get('TableUtils');
27
- const selectedCells = tableUtils.getSelectionAffectedTableCells(this.editor.model.document.selection);
28
- const firstCell = selectedCells[0];
29
- if (firstCell) {
30
- const table = firstCell.findAncestor('table');
31
- const tableColumnCount = tableUtils.getColumns(table);
32
- const { first, last } = tableUtils.getColumnIndexes(selectedCells);
33
- this.isEnabled = last - first < (tableColumnCount - 1);
34
- }
35
- else {
36
- this.isEnabled = false;
37
- }
38
- }
39
- /**
40
- * @inheritDoc
41
- */
42
- execute() {
43
- const tableUtils = this.editor.plugins.get('TableUtils');
44
- const [firstCell, lastCell] = getBoundaryCells(this.editor.model.document.selection, tableUtils);
45
- const table = firstCell.parent.parent;
46
- // Cache the table before removing or updating colspans.
47
- const tableMap = [...new TableWalker(table)];
48
- // Store column indexes of removed columns.
49
- const removedColumnIndexes = {
50
- first: tableMap.find(value => value.cell === firstCell).column,
51
- last: tableMap.find(value => value.cell === lastCell).column
52
- };
53
- const cellToFocus = getCellToFocus(tableMap, firstCell, lastCell, removedColumnIndexes);
54
- this.editor.model.change(writer => {
55
- const columnsToRemove = removedColumnIndexes.last - removedColumnIndexes.first + 1;
56
- tableUtils.removeColumns(table, {
57
- at: removedColumnIndexes.first,
58
- columns: columnsToRemove
59
- });
60
- writer.setSelection(writer.createPositionAt(cellToFocus, 0));
61
- });
62
- }
63
- }
64
- /**
65
- * Returns a proper table cell to focus after removing a column.
66
- * - selection is on last table cell it will return previous cell.
67
- */
68
- function getCellToFocus(tableMap, firstCell, lastCell, removedColumnIndexes) {
69
- const colspan = parseInt(lastCell.getAttribute('colspan') || '1');
70
- // If the table cell is spanned over 2+ columns - it will be truncated so the selection should
71
- // stay in that cell.
72
- if (colspan > 1) {
73
- return lastCell;
74
- }
75
- // Normally, look for the cell in the same row that precedes the first cell to put selection there ("column on the left").
76
- // If the deleted column is the first column of the table, there will be no predecessor: use the cell
77
- // from the column that follows then (also in the same row).
78
- else if (firstCell.previousSibling || lastCell.nextSibling) {
79
- return lastCell.nextSibling || firstCell.previousSibling;
80
- }
81
- // It can happen that table cells have no siblings in a row, for instance, when there are row spans
82
- // in the table (in the previous row). Then just look for the closest cell that is in a column
83
- // that will not be removed to put the selection there.
84
- else {
85
- // Look for any cell in a column that precedes the first removed column.
86
- if (removedColumnIndexes.first) {
87
- return tableMap.reverse().find(({ column }) => {
88
- return column < removedColumnIndexes.first;
89
- }).cell;
90
- }
91
- // If the first removed column is the first column of the table, then
92
- // look for any cell that is in a column that follows the last removed column.
93
- else {
94
- return tableMap.reverse().find(({ column }) => {
95
- return column > removedColumnIndexes.last;
96
- }).cell;
97
- }
98
- }
99
- }
100
- /**
101
- * Returns helper object returning the first and the last cell contained in given selection, based on DOM order.
102
- */
103
- function getBoundaryCells(selection, tableUtils) {
104
- const referenceCells = tableUtils.getSelectionAffectedTableCells(selection);
105
- const firstCell = referenceCells[0];
106
- const lastCell = referenceCells.pop();
107
- const returnValue = [firstCell, lastCell];
108
- return firstCell.isBefore(lastCell) ? returnValue : returnValue.reverse();
109
- }
1
+ /**
2
+ * @license Copyright (c) 2003-2023, CKSource Holding sp. z o.o. All rights reserved.
3
+ * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
+ */
5
+ /**
6
+ * @module table/commands/removecolumncommand
7
+ */
8
+ import { Command } from 'ckeditor5/src/core';
9
+ import TableWalker from '../tablewalker';
10
+ /**
11
+ * The remove column command.
12
+ *
13
+ * The command is registered by {@link module:table/tableediting~TableEditing} as the `'removeTableColumn'` editor command.
14
+ *
15
+ * To remove the column containing the selected cell, execute the command:
16
+ *
17
+ * ```ts
18
+ * editor.execute( 'removeTableColumn' );
19
+ * ```
20
+ */
21
+ export default class RemoveColumnCommand extends Command {
22
+ /**
23
+ * @inheritDoc
24
+ */
25
+ refresh() {
26
+ const tableUtils = this.editor.plugins.get('TableUtils');
27
+ const selectedCells = tableUtils.getSelectionAffectedTableCells(this.editor.model.document.selection);
28
+ const firstCell = selectedCells[0];
29
+ if (firstCell) {
30
+ const table = firstCell.findAncestor('table');
31
+ const tableColumnCount = tableUtils.getColumns(table);
32
+ const { first, last } = tableUtils.getColumnIndexes(selectedCells);
33
+ this.isEnabled = last - first < (tableColumnCount - 1);
34
+ }
35
+ else {
36
+ this.isEnabled = false;
37
+ }
38
+ }
39
+ /**
40
+ * @inheritDoc
41
+ */
42
+ execute() {
43
+ const tableUtils = this.editor.plugins.get('TableUtils');
44
+ const [firstCell, lastCell] = getBoundaryCells(this.editor.model.document.selection, tableUtils);
45
+ const table = firstCell.parent.parent;
46
+ // Cache the table before removing or updating colspans.
47
+ const tableMap = [...new TableWalker(table)];
48
+ // Store column indexes of removed columns.
49
+ const removedColumnIndexes = {
50
+ first: tableMap.find(value => value.cell === firstCell).column,
51
+ last: tableMap.find(value => value.cell === lastCell).column
52
+ };
53
+ const cellToFocus = getCellToFocus(tableMap, firstCell, lastCell, removedColumnIndexes);
54
+ this.editor.model.change(writer => {
55
+ const columnsToRemove = removedColumnIndexes.last - removedColumnIndexes.first + 1;
56
+ tableUtils.removeColumns(table, {
57
+ at: removedColumnIndexes.first,
58
+ columns: columnsToRemove
59
+ });
60
+ writer.setSelection(writer.createPositionAt(cellToFocus, 0));
61
+ });
62
+ }
63
+ }
64
+ /**
65
+ * Returns a proper table cell to focus after removing a column.
66
+ * - selection is on last table cell it will return previous cell.
67
+ */
68
+ function getCellToFocus(tableMap, firstCell, lastCell, removedColumnIndexes) {
69
+ const colspan = parseInt(lastCell.getAttribute('colspan') || '1');
70
+ // If the table cell is spanned over 2+ columns - it will be truncated so the selection should
71
+ // stay in that cell.
72
+ if (colspan > 1) {
73
+ return lastCell;
74
+ }
75
+ // Normally, look for the cell in the same row that precedes the first cell to put selection there ("column on the left").
76
+ // If the deleted column is the first column of the table, there will be no predecessor: use the cell
77
+ // from the column that follows then (also in the same row).
78
+ else if (firstCell.previousSibling || lastCell.nextSibling) {
79
+ return lastCell.nextSibling || firstCell.previousSibling;
80
+ }
81
+ // It can happen that table cells have no siblings in a row, for instance, when there are row spans
82
+ // in the table (in the previous row). Then just look for the closest cell that is in a column
83
+ // that will not be removed to put the selection there.
84
+ else {
85
+ // Look for any cell in a column that precedes the first removed column.
86
+ if (removedColumnIndexes.first) {
87
+ return tableMap.reverse().find(({ column }) => {
88
+ return column < removedColumnIndexes.first;
89
+ }).cell;
90
+ }
91
+ // If the first removed column is the first column of the table, then
92
+ // look for any cell that is in a column that follows the last removed column.
93
+ else {
94
+ return tableMap.reverse().find(({ column }) => {
95
+ return column > removedColumnIndexes.last;
96
+ }).cell;
97
+ }
98
+ }
99
+ }
100
+ /**
101
+ * Returns helper object returning the first and the last cell contained in given selection, based on DOM order.
102
+ */
103
+ function getBoundaryCells(selection, tableUtils) {
104
+ const referenceCells = tableUtils.getSelectionAffectedTableCells(selection);
105
+ const firstCell = referenceCells[0];
106
+ const lastCell = referenceCells.pop();
107
+ const returnValue = [firstCell, lastCell];
108
+ return firstCell.isBefore(lastCell) ? returnValue : returnValue.reverse();
109
+ }
@@ -1,29 +1,29 @@
1
- /**
2
- * @license Copyright (c) 2003-2023, CKSource Holding sp. z o.o. All rights reserved.
3
- * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
- */
5
- /**
6
- * @module table/commands/removerowcommand
7
- */
8
- import { Command } from 'ckeditor5/src/core';
9
- /**
10
- * The remove row command.
11
- *
12
- * The command is registered by {@link module:table/tableediting~TableEditing} as the `'removeTableRow'` editor command.
13
- *
14
- * To remove the row containing the selected cell, execute the command:
15
- *
16
- * ```ts
17
- * editor.execute( 'removeTableRow' );
18
- * ```
19
- */
20
- export default class RemoveRowCommand extends Command {
21
- /**
22
- * @inheritDoc
23
- */
24
- refresh(): void;
25
- /**
26
- * @inheritDoc
27
- */
28
- execute(): void;
29
- }
1
+ /**
2
+ * @license Copyright (c) 2003-2023, CKSource Holding sp. z o.o. All rights reserved.
3
+ * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
+ */
5
+ /**
6
+ * @module table/commands/removerowcommand
7
+ */
8
+ import { Command } from 'ckeditor5/src/core';
9
+ /**
10
+ * The remove row command.
11
+ *
12
+ * The command is registered by {@link module:table/tableediting~TableEditing} as the `'removeTableRow'` editor command.
13
+ *
14
+ * To remove the row containing the selected cell, execute the command:
15
+ *
16
+ * ```ts
17
+ * editor.execute( 'removeTableRow' );
18
+ * ```
19
+ */
20
+ export default class RemoveRowCommand extends Command {
21
+ /**
22
+ * @inheritDoc
23
+ */
24
+ refresh(): void;
25
+ /**
26
+ * @inheritDoc
27
+ */
28
+ execute(): void;
29
+ }
@@ -1,82 +1,82 @@
1
- /**
2
- * @license Copyright (c) 2003-2023, CKSource Holding sp. z o.o. All rights reserved.
3
- * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
- */
5
- /**
6
- * @module table/commands/removerowcommand
7
- */
8
- import { Command } from 'ckeditor5/src/core';
9
- /**
10
- * The remove row command.
11
- *
12
- * The command is registered by {@link module:table/tableediting~TableEditing} as the `'removeTableRow'` editor command.
13
- *
14
- * To remove the row containing the selected cell, execute the command:
15
- *
16
- * ```ts
17
- * editor.execute( 'removeTableRow' );
18
- * ```
19
- */
20
- export default class RemoveRowCommand extends Command {
21
- /**
22
- * @inheritDoc
23
- */
24
- refresh() {
25
- const tableUtils = this.editor.plugins.get('TableUtils');
26
- const selectedCells = tableUtils.getSelectionAffectedTableCells(this.editor.model.document.selection);
27
- const firstCell = selectedCells[0];
28
- if (firstCell) {
29
- const table = firstCell.findAncestor('table');
30
- const tableRowCount = tableUtils.getRows(table);
31
- const lastRowIndex = tableRowCount - 1;
32
- const selectedRowIndexes = tableUtils.getRowIndexes(selectedCells);
33
- const areAllRowsSelected = selectedRowIndexes.first === 0 && selectedRowIndexes.last === lastRowIndex;
34
- // Disallow selecting whole table -> delete whole table should be used instead.
35
- this.isEnabled = !areAllRowsSelected;
36
- }
37
- else {
38
- this.isEnabled = false;
39
- }
40
- }
41
- /**
42
- * @inheritDoc
43
- */
44
- execute() {
45
- const model = this.editor.model;
46
- const tableUtils = this.editor.plugins.get('TableUtils');
47
- const referenceCells = tableUtils.getSelectionAffectedTableCells(model.document.selection);
48
- const removedRowIndexes = tableUtils.getRowIndexes(referenceCells);
49
- const firstCell = referenceCells[0];
50
- const table = firstCell.findAncestor('table');
51
- const columnIndexToFocus = tableUtils.getCellLocation(firstCell).column;
52
- model.change(writer => {
53
- const rowsToRemove = removedRowIndexes.last - removedRowIndexes.first + 1;
54
- tableUtils.removeRows(table, {
55
- at: removedRowIndexes.first,
56
- rows: rowsToRemove
57
- });
58
- const cellToFocus = getCellToFocus(table, removedRowIndexes.first, columnIndexToFocus, tableUtils.getRows(table));
59
- writer.setSelection(writer.createPositionAt(cellToFocus, 0));
60
- });
61
- }
62
- }
63
- /**
64
- * Returns a cell that should be focused before removing the row, belonging to the same column as the currently focused cell.
65
- * - If the row was not the last one, the cell to focus will be in the row that followed it (before removal).
66
- * - If the row was the last one, the cell to focus will be in the row that preceded it (before removal).
67
- */
68
- function getCellToFocus(table, removedRowIndex, columnToFocus, tableRowCount) {
69
- // Don't go beyond last row's index.
70
- const row = table.getChild(Math.min(removedRowIndex, tableRowCount - 1));
71
- // Default to first table cell.
72
- let cellToFocus = row.getChild(0);
73
- let column = 0;
74
- for (const tableCell of row.getChildren()) {
75
- if (column > columnToFocus) {
76
- return cellToFocus;
77
- }
78
- cellToFocus = tableCell;
79
- column += parseInt(tableCell.getAttribute('colspan') || '1');
80
- }
81
- return cellToFocus;
82
- }
1
+ /**
2
+ * @license Copyright (c) 2003-2023, CKSource Holding sp. z o.o. All rights reserved.
3
+ * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
+ */
5
+ /**
6
+ * @module table/commands/removerowcommand
7
+ */
8
+ import { Command } from 'ckeditor5/src/core';
9
+ /**
10
+ * The remove row command.
11
+ *
12
+ * The command is registered by {@link module:table/tableediting~TableEditing} as the `'removeTableRow'` editor command.
13
+ *
14
+ * To remove the row containing the selected cell, execute the command:
15
+ *
16
+ * ```ts
17
+ * editor.execute( 'removeTableRow' );
18
+ * ```
19
+ */
20
+ export default class RemoveRowCommand extends Command {
21
+ /**
22
+ * @inheritDoc
23
+ */
24
+ refresh() {
25
+ const tableUtils = this.editor.plugins.get('TableUtils');
26
+ const selectedCells = tableUtils.getSelectionAffectedTableCells(this.editor.model.document.selection);
27
+ const firstCell = selectedCells[0];
28
+ if (firstCell) {
29
+ const table = firstCell.findAncestor('table');
30
+ const tableRowCount = tableUtils.getRows(table);
31
+ const lastRowIndex = tableRowCount - 1;
32
+ const selectedRowIndexes = tableUtils.getRowIndexes(selectedCells);
33
+ const areAllRowsSelected = selectedRowIndexes.first === 0 && selectedRowIndexes.last === lastRowIndex;
34
+ // Disallow selecting whole table -> delete whole table should be used instead.
35
+ this.isEnabled = !areAllRowsSelected;
36
+ }
37
+ else {
38
+ this.isEnabled = false;
39
+ }
40
+ }
41
+ /**
42
+ * @inheritDoc
43
+ */
44
+ execute() {
45
+ const model = this.editor.model;
46
+ const tableUtils = this.editor.plugins.get('TableUtils');
47
+ const referenceCells = tableUtils.getSelectionAffectedTableCells(model.document.selection);
48
+ const removedRowIndexes = tableUtils.getRowIndexes(referenceCells);
49
+ const firstCell = referenceCells[0];
50
+ const table = firstCell.findAncestor('table');
51
+ const columnIndexToFocus = tableUtils.getCellLocation(firstCell).column;
52
+ model.change(writer => {
53
+ const rowsToRemove = removedRowIndexes.last - removedRowIndexes.first + 1;
54
+ tableUtils.removeRows(table, {
55
+ at: removedRowIndexes.first,
56
+ rows: rowsToRemove
57
+ });
58
+ const cellToFocus = getCellToFocus(table, removedRowIndexes.first, columnIndexToFocus, tableUtils.getRows(table));
59
+ writer.setSelection(writer.createPositionAt(cellToFocus, 0));
60
+ });
61
+ }
62
+ }
63
+ /**
64
+ * Returns a cell that should be focused before removing the row, belonging to the same column as the currently focused cell.
65
+ * - If the row was not the last one, the cell to focus will be in the row that followed it (before removal).
66
+ * - If the row was the last one, the cell to focus will be in the row that preceded it (before removal).
67
+ */
68
+ function getCellToFocus(table, removedRowIndex, columnToFocus, tableRowCount) {
69
+ // Don't go beyond last row's index.
70
+ const row = table.getChild(Math.min(removedRowIndex, tableRowCount - 1));
71
+ // Default to first table cell.
72
+ let cellToFocus = row.getChild(0);
73
+ let column = 0;
74
+ for (const tableCell of row.getChildren()) {
75
+ if (column > columnToFocus) {
76
+ return cellToFocus;
77
+ }
78
+ cellToFocus = tableCell;
79
+ column += parseInt(tableCell.getAttribute('colspan') || '1');
80
+ }
81
+ return cellToFocus;
82
+ }
@@ -1,33 +1,33 @@
1
- /**
2
- * @license Copyright (c) 2003-2023, CKSource Holding sp. z o.o. All rights reserved.
3
- * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
- */
5
- /**
6
- * @module table/commands/selectcolumncommand
7
- */
8
- import { Command, type Editor } from 'ckeditor5/src/core';
9
- /**
10
- * The select column command.
11
- *
12
- * The command is registered by {@link module:table/tableediting~TableEditing} as the `'selectTableColumn'` editor command.
13
- *
14
- * To select the columns containing the selected cells, execute the command:
15
- *
16
- * ```ts
17
- * editor.execute( 'selectTableColumn' );
18
- * ```
19
- */
20
- export default class SelectColumnCommand extends Command {
21
- /**
22
- * @inheritDoc
23
- */
24
- constructor(editor: Editor);
25
- /**
26
- * @inheritDoc
27
- */
28
- refresh(): void;
29
- /**
30
- * @inheritDoc
31
- */
32
- execute(): void;
33
- }
1
+ /**
2
+ * @license Copyright (c) 2003-2023, CKSource Holding sp. z o.o. All rights reserved.
3
+ * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
+ */
5
+ /**
6
+ * @module table/commands/selectcolumncommand
7
+ */
8
+ import { Command, type Editor } from 'ckeditor5/src/core';
9
+ /**
10
+ * The select column command.
11
+ *
12
+ * The command is registered by {@link module:table/tableediting~TableEditing} as the `'selectTableColumn'` editor command.
13
+ *
14
+ * To select the columns containing the selected cells, execute the command:
15
+ *
16
+ * ```ts
17
+ * editor.execute( 'selectTableColumn' );
18
+ * ```
19
+ */
20
+ export default class SelectColumnCommand extends Command {
21
+ /**
22
+ * @inheritDoc
23
+ */
24
+ constructor(editor: Editor);
25
+ /**
26
+ * @inheritDoc
27
+ */
28
+ refresh(): void;
29
+ /**
30
+ * @inheritDoc
31
+ */
32
+ execute(): void;
33
+ }