@ckeditor/ckeditor5-table 36.0.1 → 37.0.0-alpha.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 (170) hide show
  1. package/README.md +1 -1
  2. package/build/table.js +1 -1
  3. package/ckeditor5-metadata.json +6 -6
  4. package/package.json +34 -29
  5. package/src/augmentation.d.ts +76 -0
  6. package/src/augmentation.js +5 -0
  7. package/src/commands/insertcolumncommand.d.ts +55 -0
  8. package/src/commands/insertcolumncommand.js +45 -60
  9. package/src/commands/insertrowcommand.d.ts +54 -0
  10. package/src/commands/insertrowcommand.js +44 -59
  11. package/src/commands/inserttablecommand.d.ts +44 -0
  12. package/src/commands/inserttablecommand.js +50 -68
  13. package/src/commands/mergecellcommand.d.ts +68 -0
  14. package/src/commands/mergecellcommand.js +169 -244
  15. package/src/commands/mergecellscommand.d.ts +28 -0
  16. package/src/commands/mergecellscommand.js +72 -101
  17. package/src/commands/removecolumncommand.d.ts +29 -0
  18. package/src/commands/removecolumncommand.js +88 -102
  19. package/src/commands/removerowcommand.d.ts +29 -0
  20. package/src/commands/removerowcommand.js +63 -80
  21. package/src/commands/selectcolumncommand.d.ts +33 -0
  22. package/src/commands/selectcolumncommand.js +41 -54
  23. package/src/commands/selectrowcommand.d.ts +33 -0
  24. package/src/commands/selectrowcommand.js +38 -48
  25. package/src/commands/setheadercolumncommand.d.ts +50 -0
  26. package/src/commands/setheadercolumncommand.js +48 -73
  27. package/src/commands/setheaderrowcommand.d.ts +53 -0
  28. package/src/commands/setheaderrowcommand.js +56 -85
  29. package/src/commands/splitcellcommand.d.ts +43 -0
  30. package/src/commands/splitcellcommand.js +35 -49
  31. package/src/converters/downcast.d.ts +63 -0
  32. package/src/converters/downcast.js +98 -130
  33. package/src/converters/table-caption-post-fixer.d.ts +20 -0
  34. package/src/converters/table-caption-post-fixer.js +36 -52
  35. package/src/converters/table-cell-paragraph-post-fixer.d.ts +32 -0
  36. package/src/converters/table-cell-paragraph-post-fixer.js +88 -119
  37. package/src/converters/table-cell-refresh-handler.d.ts +18 -0
  38. package/src/converters/table-cell-refresh-handler.js +29 -48
  39. package/src/converters/table-headings-refresh-handler.d.ts +17 -0
  40. package/src/converters/table-headings-refresh-handler.js +35 -54
  41. package/src/converters/table-layout-post-fixer.d.ts +226 -0
  42. package/src/converters/table-layout-post-fixer.js +276 -313
  43. package/src/converters/tableproperties.d.ts +54 -0
  44. package/src/converters/tableproperties.js +136 -168
  45. package/src/converters/upcasttable.d.ts +49 -0
  46. package/src/converters/upcasttable.js +199 -251
  47. package/src/index.d.ts +60 -0
  48. package/src/index.js +1 -2
  49. package/src/plaintableoutput.d.ts +25 -0
  50. package/src/plaintableoutput.js +107 -135
  51. package/src/table.d.ts +33 -0
  52. package/src/table.js +12 -88
  53. package/src/tablecaption/tablecaptionediting.d.ts +63 -0
  54. package/src/tablecaption/tablecaptionediting.js +104 -135
  55. package/src/tablecaption/tablecaptionui.d.ts +21 -0
  56. package/src/tablecaption/tablecaptionui.js +42 -58
  57. package/src/tablecaption/toggletablecaptioncommand.d.ts +68 -0
  58. package/src/tablecaption/toggletablecaptioncommand.js +77 -92
  59. package/src/tablecaption/utils.d.ts +42 -0
  60. package/src/tablecaption/utils.js +35 -61
  61. package/src/tablecaption.d.ts +22 -0
  62. package/src/tablecaption.js +12 -19
  63. package/src/tablecellproperties/commands/tablecellbackgroundcolorcommand.d.ts +32 -0
  64. package/src/tablecellproperties/commands/tablecellbackgroundcolorcommand.js +14 -20
  65. package/src/tablecellproperties/commands/tablecellbordercolorcommand.d.ts +37 -0
  66. package/src/tablecellproperties/commands/tablecellbordercolorcommand.js +27 -37
  67. package/src/tablecellproperties/commands/tablecellborderstylecommand.d.ts +37 -0
  68. package/src/tablecellproperties/commands/tablecellborderstylecommand.js +27 -37
  69. package/src/tablecellproperties/commands/tablecellborderwidthcommand.d.ts +51 -0
  70. package/src/tablecellproperties/commands/tablecellborderwidthcommand.js +42 -53
  71. package/src/tablecellproperties/commands/tablecellheightcommand.d.ts +46 -0
  72. package/src/tablecellproperties/commands/tablecellheightcommand.js +29 -36
  73. package/src/tablecellproperties/commands/tablecellhorizontalalignmentcommand.d.ts +32 -0
  74. package/src/tablecellproperties/commands/tablecellhorizontalalignmentcommand.js +14 -20
  75. package/src/tablecellproperties/commands/tablecellpaddingcommand.d.ts +51 -0
  76. package/src/tablecellproperties/commands/tablecellpaddingcommand.js +42 -53
  77. package/src/tablecellproperties/commands/tablecellpropertycommand.d.ts +62 -0
  78. package/src/tablecellproperties/commands/tablecellpropertycommand.js +77 -122
  79. package/src/tablecellproperties/commands/tablecellverticalalignmentcommand.d.ts +40 -0
  80. package/src/tablecellproperties/commands/tablecellverticalalignmentcommand.js +14 -20
  81. package/src/tablecellproperties/tablecellpropertiesediting.d.ts +41 -0
  82. package/src/tablecellproperties/tablecellpropertiesediting.js +193 -236
  83. package/src/tablecellproperties/tablecellpropertiesui.d.ts +111 -0
  84. package/src/tablecellproperties/tablecellpropertiesui.js +302 -456
  85. package/src/tablecellproperties/ui/tablecellpropertiesview.d.ts +227 -0
  86. package/src/tablecellproperties/ui/tablecellpropertiesview.js +509 -844
  87. package/src/tablecellproperties.d.ts +28 -0
  88. package/src/tablecellproperties.js +12 -98
  89. package/src/tablecellwidth/commands/tablecellwidthcommand.d.ts +46 -0
  90. package/src/tablecellwidth/commands/tablecellwidthcommand.js +29 -35
  91. package/src/tablecellwidth/tablecellwidthediting.d.ts +28 -0
  92. package/src/tablecellwidth/tablecellwidthediting.js +25 -38
  93. package/src/tableclipboard.d.ts +63 -0
  94. package/src/tableclipboard.js +429 -568
  95. package/src/tablecolumnresize/constants.d.ts +20 -0
  96. package/src/tablecolumnresize/constants.js +0 -10
  97. package/src/tablecolumnresize/converters.d.ts +18 -0
  98. package/src/tablecolumnresize/converters.js +35 -119
  99. package/src/tablecolumnresize/tablecolumnresizeediting.d.ts +137 -0
  100. package/src/tablecolumnresize/tablecolumnresizeediting.js +545 -711
  101. package/src/tablecolumnresize/tablewidthscommand.d.ts +38 -0
  102. package/src/tablecolumnresize/tablewidthscommand.js +61 -0
  103. package/src/tablecolumnresize/utils.d.ts +141 -0
  104. package/src/tablecolumnresize/utils.js +256 -233
  105. package/src/tablecolumnresize.d.ts +24 -0
  106. package/src/tablecolumnresize.js +12 -19
  107. package/src/tableconfig.d.ts +331 -0
  108. package/src/tableconfig.js +5 -0
  109. package/src/tableediting.d.ts +97 -0
  110. package/src/tableediting.js +157 -176
  111. package/src/tablekeyboard.d.ts +63 -0
  112. package/src/tablekeyboard.js +261 -344
  113. package/src/tablemouse/mouseeventsobserver.d.ts +62 -0
  114. package/src/tablemouse/mouseeventsobserver.js +13 -50
  115. package/src/tablemouse.d.ts +46 -0
  116. package/src/tablemouse.js +154 -202
  117. package/src/tableproperties/commands/tablealignmentcommand.d.ts +32 -0
  118. package/src/tableproperties/commands/tablealignmentcommand.js +14 -20
  119. package/src/tableproperties/commands/tablebackgroundcolorcommand.d.ts +32 -0
  120. package/src/tableproperties/commands/tablebackgroundcolorcommand.js +14 -20
  121. package/src/tableproperties/commands/tablebordercolorcommand.d.ts +37 -0
  122. package/src/tableproperties/commands/tablebordercolorcommand.js +27 -37
  123. package/src/tableproperties/commands/tableborderstylecommand.d.ts +37 -0
  124. package/src/tableproperties/commands/tableborderstylecommand.js +27 -37
  125. package/src/tableproperties/commands/tableborderwidthcommand.d.ts +51 -0
  126. package/src/tableproperties/commands/tableborderwidthcommand.js +42 -53
  127. package/src/tableproperties/commands/tableheightcommand.d.ts +46 -0
  128. package/src/tableproperties/commands/tableheightcommand.js +29 -33
  129. package/src/tableproperties/commands/tablepropertycommand.d.ts +61 -0
  130. package/src/tableproperties/commands/tablepropertycommand.js +68 -112
  131. package/src/tableproperties/commands/tablewidthcommand.d.ts +46 -0
  132. package/src/tableproperties/commands/tablewidthcommand.js +29 -33
  133. package/src/tableproperties/tablepropertiesediting.d.ts +39 -0
  134. package/src/tableproperties/tablepropertiesediting.js +163 -210
  135. package/src/tableproperties/tablepropertiesui.d.ts +113 -0
  136. package/src/tableproperties/tablepropertiesui.js +293 -439
  137. package/src/tableproperties/ui/tablepropertiesview.d.ts +203 -0
  138. package/src/tableproperties/ui/tablepropertiesview.js +427 -718
  139. package/src/tableproperties.d.ts +28 -0
  140. package/src/tableproperties.js +12 -95
  141. package/src/tableselection.d.ts +106 -0
  142. package/src/tableselection.js +279 -376
  143. package/src/tabletoolbar.d.ts +31 -0
  144. package/src/tabletoolbar.js +38 -92
  145. package/src/tableui.d.ts +53 -0
  146. package/src/tableui.js +281 -338
  147. package/src/tableutils.d.ts +448 -0
  148. package/src/tableutils.js +1015 -1229
  149. package/src/tablewalker.d.ts +323 -0
  150. package/src/tablewalker.js +308 -548
  151. package/src/ui/colorinputview.d.ts +143 -0
  152. package/src/ui/colorinputview.js +229 -366
  153. package/src/ui/formrowview.d.ts +61 -0
  154. package/src/ui/formrowview.js +38 -84
  155. package/src/ui/inserttableview.d.ts +77 -0
  156. package/src/ui/inserttableview.js +152 -242
  157. package/src/utils/common.d.ts +42 -0
  158. package/src/utils/common.js +33 -57
  159. package/src/utils/structure.d.ts +245 -0
  160. package/src/utils/structure.js +261 -379
  161. package/src/utils/table-properties.d.ts +67 -0
  162. package/src/utils/table-properties.js +60 -81
  163. package/src/utils/ui/contextualballoon.d.ts +34 -0
  164. package/src/utils/ui/contextualballoon.js +70 -89
  165. package/src/utils/ui/table-properties.d.ts +193 -0
  166. package/src/utils/ui/table-properties.js +259 -319
  167. package/src/utils/ui/widget.d.ts +16 -0
  168. package/src/utils/ui/widget.js +24 -46
  169. package/src/tablecolumnresize/tablecolumnwidthscommand.js +0 -55
  170. package/src/tablecolumnresize/tablewidthresizecommand.js +0 -65
@@ -0,0 +1,20 @@
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/converters/table-caption-post-fixer
7
+ */
8
+ import type { Model } from 'ckeditor5/src/engine';
9
+ /**
10
+ * Injects a table caption post-fixer into the model.
11
+ *
12
+ * The role of the table caption post-fixer is to ensure that the table with caption have the correct structure
13
+ * after a {@link module:engine/model/model~Model#change `change()`} block was executed.
14
+ *
15
+ * The correct structure means that:
16
+ *
17
+ * * If there are many caption model element, they are merged into one model.
18
+ * * A final, merged caption model is placed at the end of the table.
19
+ */
20
+ export default function injectTableCaptionPostFixer(model: Model): void;
@@ -2,11 +2,6 @@
2
2
  * @license Copyright (c) 2003-2023, CKSource Holding sp. z o.o. All rights reserved.
3
3
  * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
4
  */
5
-
6
- /**
7
- * @module table/converters/table-caption-post-fixer
8
- */
9
-
10
5
  /**
11
6
  * Injects a table caption post-fixer into the model.
12
7
  *
@@ -17,53 +12,42 @@
17
12
  *
18
13
  * * If there are many caption model element, they are merged into one model.
19
14
  * * A final, merged caption model is placed at the end of the table.
20
- *
21
- * @param {module:engine/model/model~Model} model
22
15
  */
23
- export default function injectTableCaptionPostFixer( model ) {
24
- model.document.registerPostFixer( writer => tableCaptionPostFixer( writer, model ) );
16
+ export default function injectTableCaptionPostFixer(model) {
17
+ model.document.registerPostFixer(writer => tableCaptionPostFixer(writer, model));
25
18
  }
26
-
27
- // The table caption post-fixer.
28
- //
29
- // @param {module:engine/model/writer~Writer} writer
30
- // @param {module:engine/model/model~Model} model
31
- function tableCaptionPostFixer( writer, model ) {
32
- const changes = model.document.differ.getChanges();
33
- let wasFixed = false;
34
-
35
- for ( const entry of changes ) {
36
- if ( entry.type != 'insert' ) {
37
- continue;
38
- }
39
-
40
- const positionParent = entry.position.parent;
41
-
42
- if ( positionParent.is( 'element', 'table' ) || entry.name == 'table' ) {
43
- const table = entry.name == 'table' ? entry.position.nodeAfter : entry.position.parent;
44
- const captionsToMerge = Array.from( table.getChildren() ).filter( child => child.is( 'element', 'caption' ) );
45
- const firstCaption = captionsToMerge.shift();
46
-
47
- if ( !firstCaption ) {
48
- continue;
49
- }
50
-
51
- // Move all the contents of the captions to the first one.
52
- for ( const caption of captionsToMerge ) {
53
- writer.move( writer.createRangeIn( caption ), firstCaption, 'end' );
54
- writer.remove( caption );
55
- }
56
-
57
- // Make sure the final caption is at the end of the table.
58
- if ( firstCaption.nextSibling ) {
59
- writer.move( writer.createRangeOn( firstCaption ), table, 'end' );
60
- wasFixed = true;
61
- }
62
-
63
- // Do we merged captions and/or moved the single caption to the end of the table?
64
- wasFixed = !!captionsToMerge.length || wasFixed;
65
- }
66
- }
67
-
68
- return wasFixed;
19
+ /**
20
+ * The table caption post-fixer.
21
+ */
22
+ function tableCaptionPostFixer(writer, model) {
23
+ const changes = model.document.differ.getChanges();
24
+ let wasFixed = false;
25
+ for (const entry of changes) {
26
+ if (entry.type != 'insert') {
27
+ continue;
28
+ }
29
+ const positionParent = entry.position.parent;
30
+ if (positionParent.is('element', 'table') || entry.name == 'table') {
31
+ const table = (entry.name == 'table' ? entry.position.nodeAfter : positionParent);
32
+ const captionsToMerge = Array.from(table.getChildren())
33
+ .filter((child) => child.is('element', 'caption'));
34
+ const firstCaption = captionsToMerge.shift();
35
+ if (!firstCaption) {
36
+ continue;
37
+ }
38
+ // Move all the contents of the captions to the first one.
39
+ for (const caption of captionsToMerge) {
40
+ writer.move(writer.createRangeIn(caption), firstCaption, 'end');
41
+ writer.remove(caption);
42
+ }
43
+ // Make sure the final caption is at the end of the table.
44
+ if (firstCaption.nextSibling) {
45
+ writer.move(writer.createRangeOn(firstCaption), table, 'end');
46
+ wasFixed = true;
47
+ }
48
+ // Do we merged captions and/or moved the single caption to the end of the table?
49
+ wasFixed = !!captionsToMerge.length || wasFixed;
50
+ }
51
+ }
52
+ return wasFixed;
69
53
  }
@@ -0,0 +1,32 @@
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/converters/table-cell-paragraph-post-fixer
7
+ */
8
+ import type { Model } from 'ckeditor5/src/engine';
9
+ /**
10
+ * Injects a table cell post-fixer into the model which inserts a `paragraph` element into empty table cells.
11
+ *
12
+ * A table cell must contain at least one block element as a child. An empty table cell will have an empty `paragraph` as a child.
13
+ *
14
+ * ```xml
15
+ * <table>
16
+ * <tableRow>
17
+ * <tableCell></tableCell>
18
+ * </tableRow>
19
+ * </table>
20
+ * ```
21
+ *
22
+ * Will be fixed to:
23
+ *
24
+ * ```xml
25
+ * <table>
26
+ * <tableRow>
27
+ * <tableCell><paragraph></paragraph></tableCell>
28
+ * </tableRow>
29
+ * </table>
30
+ * ```
31
+ */
32
+ export default function injectTableCellParagraphPostFixer(model: Model): void;
@@ -2,137 +2,106 @@
2
2
  * @license Copyright (c) 2003-2023, CKSource Holding sp. z o.o. All rights reserved.
3
3
  * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
4
  */
5
-
6
- /**
7
- * @module table/converters/table-cell-paragraph-post-fixer
8
- */
9
-
10
5
  /**
11
6
  * Injects a table cell post-fixer into the model which inserts a `paragraph` element into empty table cells.
12
7
  *
13
8
  * A table cell must contain at least one block element as a child. An empty table cell will have an empty `paragraph` as a child.
14
9
  *
15
- * <table>
16
- * <tableRow>
17
- * <tableCell></tableCell>
18
- * </tableRow>
19
- * </table>
10
+ * ```xml
11
+ * <table>
12
+ * <tableRow>
13
+ * <tableCell></tableCell>
14
+ * </tableRow>
15
+ * </table>
16
+ * ```
20
17
  *
21
18
  * Will be fixed to:
22
19
  *
23
- * <table>
24
- * <tableRow>
25
- * <tableCell><paragraph></paragraph></tableCell>
26
- * </tableRow>
27
- * </table>
28
- *
29
- * @param {module:engine/model/model~Model} model
20
+ * ```xml
21
+ * <table>
22
+ * <tableRow>
23
+ * <tableCell><paragraph></paragraph></tableCell>
24
+ * </tableRow>
25
+ * </table>
26
+ * ```
30
27
  */
31
- export default function injectTableCellParagraphPostFixer( model ) {
32
- model.document.registerPostFixer( writer => tableCellContentsPostFixer( writer, model ) );
28
+ export default function injectTableCellParagraphPostFixer(model) {
29
+ model.document.registerPostFixer(writer => tableCellContentsPostFixer(writer, model));
33
30
  }
34
-
35
- // The table cell contents post-fixer.
36
- //
37
- // @param {module:engine/model/writer~Writer} writer
38
- // @param {module:engine/model/model~Model} model
39
- function tableCellContentsPostFixer( writer, model ) {
40
- const changes = model.document.differ.getChanges();
41
-
42
- let wasFixed = false;
43
-
44
- for ( const entry of changes ) {
45
- if ( entry.type == 'insert' && entry.name == 'table' ) {
46
- wasFixed = fixTable( entry.position.nodeAfter, writer ) || wasFixed;
47
- }
48
-
49
- if ( entry.type == 'insert' && entry.name == 'tableRow' ) {
50
- wasFixed = fixTableRow( entry.position.nodeAfter, writer ) || wasFixed;
51
- }
52
-
53
- if ( entry.type == 'insert' && entry.name == 'tableCell' ) {
54
- wasFixed = fixTableCellContent( entry.position.nodeAfter, writer ) || wasFixed;
55
- }
56
-
57
- if ( checkTableCellChange( entry ) ) {
58
- wasFixed = fixTableCellContent( entry.position.parent, writer ) || wasFixed;
59
- }
60
- }
61
-
62
- return wasFixed;
31
+ /**
32
+ * The table cell contents post-fixer.
33
+ */
34
+ function tableCellContentsPostFixer(writer, model) {
35
+ const changes = model.document.differ.getChanges();
36
+ let wasFixed = false;
37
+ for (const entry of changes) {
38
+ if (entry.type == 'insert' && entry.name == 'table') {
39
+ wasFixed = fixTable(entry.position.nodeAfter, writer) || wasFixed;
40
+ }
41
+ if (entry.type == 'insert' && entry.name == 'tableRow') {
42
+ wasFixed = fixTableRow(entry.position.nodeAfter, writer) || wasFixed;
43
+ }
44
+ if (entry.type == 'insert' && entry.name == 'tableCell') {
45
+ wasFixed = fixTableCellContent(entry.position.nodeAfter, writer) || wasFixed;
46
+ }
47
+ if ((entry.type == 'remove' || entry.type == 'insert') && checkTableCellChange(entry)) {
48
+ wasFixed = fixTableCellContent(entry.position.parent, writer) || wasFixed;
49
+ }
50
+ }
51
+ return wasFixed;
63
52
  }
64
-
65
- // Fixes all table cells in a table.
66
- //
67
- // @param {module:engine/model/element~Element} table
68
- // @param {module:engine/model/writer~Writer} writer
69
- function fixTable( table, writer ) {
70
- let wasFixed = false;
71
-
72
- for ( const row of table.getChildren() ) {
73
- if ( row.is( 'element', 'tableRow' ) ) {
74
- wasFixed = fixTableRow( row, writer ) || wasFixed;
75
- }
76
- }
77
-
78
- return wasFixed;
53
+ /**
54
+ * Fixes all table cells in a table.
55
+ */
56
+ function fixTable(table, writer) {
57
+ let wasFixed = false;
58
+ for (const row of table.getChildren()) {
59
+ if (row.is('element', 'tableRow')) {
60
+ wasFixed = fixTableRow(row, writer) || wasFixed;
61
+ }
62
+ }
63
+ return wasFixed;
79
64
  }
80
-
81
- // Fixes all table cells in a table row.
82
- //
83
- // @param {module:engine/model/element~Element} tableRow
84
- // @param {module:engine/model/writer~Writer} writer
85
- function fixTableRow( tableRow, writer ) {
86
- let wasFixed = false;
87
-
88
- for ( const tableCell of tableRow.getChildren() ) {
89
- wasFixed = fixTableCellContent( tableCell, writer ) || wasFixed;
90
- }
91
-
92
- return wasFixed;
65
+ /**
66
+ * Fixes all table cells in a table row.
67
+ */
68
+ function fixTableRow(tableRow, writer) {
69
+ let wasFixed = false;
70
+ for (const tableCell of tableRow.getChildren()) {
71
+ wasFixed = fixTableCellContent(tableCell, writer) || wasFixed;
72
+ }
73
+ return wasFixed;
93
74
  }
94
-
95
- // Fixes all table cell content by:
96
- // - Adding a paragraph to a table cell without any child.
97
- // - Wrapping direct $text in a `<paragraph>`.
98
- //
99
- // @param {module:engine/model/element~Element} table
100
- // @param {module:engine/model/writer~Writer} writer
101
- // @returns {Boolean}
102
- function fixTableCellContent( tableCell, writer ) {
103
- // Insert paragraph to an empty table cell.
104
- if ( tableCell.childCount == 0 ) {
105
- // @if CK_DEBUG_TABLE // console.log( 'Post-fixing table: insert paragraph in empty cell.' );
106
-
107
- writer.insertElement( 'paragraph', tableCell );
108
-
109
- return true;
110
- }
111
-
112
- // Check table cell children for directly placed text nodes.
113
- // Temporary solution. See https://github.com/ckeditor/ckeditor5/issues/1464.
114
- const textNodes = Array.from( tableCell.getChildren() ).filter( child => child.is( '$text' ) );
115
-
116
- // @if CK_DEBUG_TABLE // textNodes.length && console.log( 'Post-fixing table: wrap cell content with paragraph.' );
117
-
118
- for ( const child of textNodes ) {
119
- writer.wrap( writer.createRangeOn( child ), 'paragraph' );
120
- }
121
-
122
- // Return true when there were text nodes to fix.
123
- return !!textNodes.length;
75
+ /**
76
+ * Fixes all table cell content by:
77
+ * - Adding a paragraph to a table cell without any child.
78
+ * - Wrapping direct $text in a `<paragraph>`.
79
+ */
80
+ function fixTableCellContent(tableCell, writer) {
81
+ // Insert paragraph to an empty table cell.
82
+ if (tableCell.childCount == 0) {
83
+ // @if CK_DEBUG_TABLE // console.log( 'Post-fixing table: insert paragraph in empty cell.' );
84
+ writer.insertElement('paragraph', tableCell);
85
+ return true;
86
+ }
87
+ // Check table cell children for directly placed text nodes.
88
+ // Temporary solution. See https://github.com/ckeditor/ckeditor5/issues/1464.
89
+ const textNodes = Array.from(tableCell.getChildren()).filter(child => child.is('$text'));
90
+ // @if CK_DEBUG_TABLE // textNodes.length && console.log( 'Post-fixing table: wrap cell content with paragraph.' );
91
+ for (const child of textNodes) {
92
+ writer.wrap(writer.createRangeOn(child), 'paragraph');
93
+ }
94
+ // Return true when there were text nodes to fix.
95
+ return !!textNodes.length;
124
96
  }
125
-
126
- // Checks if a differ change should fix the table cell. This happens on:
127
- // - Removing content from the table cell (i.e. `tableCell` can be left empty).
128
- // - Adding a text node directly into a table cell.
129
- //
130
- // @param {Object} differ change entry
131
- // @returns {Boolean}
132
- function checkTableCellChange( entry ) {
133
- if ( !entry.position || !entry.position.parent.is( 'element', 'tableCell' ) ) {
134
- return false;
135
- }
136
-
137
- return entry.type == 'insert' && entry.name == '$text' || entry.type == 'remove';
97
+ /**
98
+ * Checks if a differ change should fix the table cell. This happens on:
99
+ * - Removing content from the table cell (i.e. `tableCell` can be left empty).
100
+ * - Adding a text node directly into a table cell.
101
+ */
102
+ function checkTableCellChange(entry) {
103
+ if (!entry.position.parent.is('element', 'tableCell')) {
104
+ return false;
105
+ }
106
+ return entry.type == 'insert' && entry.name == '$text' || entry.type == 'remove';
138
107
  }
@@ -0,0 +1,18 @@
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/converters/table-cell-refresh-handler
7
+ */
8
+ import type { EditingController, Model } from 'ckeditor5/src/engine';
9
+ /**
10
+ * A table cell refresh handler which marks the table cell in the differ to have it re-rendered.
11
+ *
12
+ * Model `paragraph` inside a table cell can be rendered as `<span>` or `<p>`. It is rendered as `<span>` if this is the only block
13
+ * element in that table cell and it does not have any attributes. It is rendered as `<p>` otherwise.
14
+ *
15
+ * When table cell content changes, for example a second `paragraph` element is added, we need to ensure that the first `paragraph` is
16
+ * re-rendered so it changes from `<span>` to `<p>`. The easiest way to do it is to re-render the entire table cell.
17
+ */
18
+ export default function tableCellRefreshHandler(model: Model, editing: EditingController): void;
@@ -2,13 +2,7 @@
2
2
  * @license Copyright (c) 2003-2023, CKSource Holding sp. z o.o. All rights reserved.
3
3
  * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
4
  */
5
-
6
- /**
7
- * @module table/converters/table-cell-refresh-post-fixer
8
- */
9
-
10
5
  import { isSingleParagraphWithoutAttributes } from './downcast';
11
-
12
6
  /**
13
7
  * A table cell refresh handler which marks the table cell in the differ to have it re-rendered.
14
8
  *
@@ -17,48 +11,35 @@ import { isSingleParagraphWithoutAttributes } from './downcast';
17
11
  *
18
12
  * When table cell content changes, for example a second `paragraph` element is added, we need to ensure that the first `paragraph` is
19
13
  * re-rendered so it changes from `<span>` to `<p>`. The easiest way to do it is to re-render the entire table cell.
20
- *
21
- * @param {module:engine/model/model~Model} model
22
- * @param {module:engine/controller/editingcontroller~EditingController} editing
23
14
  */
24
- export default function tableCellRefreshHandler( model, editing ) {
25
- const differ = model.document.differ;
26
-
27
- // Stores cells to be refreshed, so the table cell will be refreshed once for multiple changes.
28
- const cellsToCheck = new Set();
29
-
30
- for ( const change of differ.getChanges() ) {
31
- const parent = change.type == 'attribute' ? change.range.start.parent : change.position.parent;
32
-
33
- if ( parent.is( 'element', 'tableCell' ) ) {
34
- cellsToCheck.add( parent );
35
- }
36
- }
37
-
38
- for ( const tableCell of cellsToCheck.values() ) {
39
- const paragraphsToRefresh = Array.from( tableCell.getChildren() ).filter( child => shouldRefresh( child, editing.mapper ) );
40
-
41
- for ( const paragraph of paragraphsToRefresh ) {
42
- editing.reconvertItem( paragraph );
43
- }
44
- }
15
+ export default function tableCellRefreshHandler(model, editing) {
16
+ const differ = model.document.differ;
17
+ // Stores cells to be refreshed, so the table cell will be refreshed once for multiple changes.
18
+ const cellsToCheck = new Set();
19
+ for (const change of differ.getChanges()) {
20
+ const parent = change.type == 'attribute' ? change.range.start.parent : change.position.parent;
21
+ if (parent.is('element', 'tableCell')) {
22
+ cellsToCheck.add(parent);
23
+ }
24
+ }
25
+ for (const tableCell of cellsToCheck.values()) {
26
+ const paragraphsToRefresh = Array.from(tableCell.getChildren())
27
+ .filter(child => shouldRefresh(child, editing.mapper));
28
+ for (const paragraph of paragraphsToRefresh) {
29
+ editing.reconvertItem(paragraph);
30
+ }
31
+ }
45
32
  }
46
-
47
- // Check if given model element needs refreshing.
48
- //
49
- // @param {module:engine/model/element~Element} modelElement
50
- // @param {module:engine/conversion/mapper~Mapper} mapper
51
- // @returns {Boolean}
52
- function shouldRefresh( child, mapper ) {
53
- if ( !child.is( 'element', 'paragraph' ) ) {
54
- return false;
55
- }
56
-
57
- const viewElement = mapper.toViewElement( child );
58
-
59
- if ( !viewElement ) {
60
- return false;
61
- }
62
-
63
- return isSingleParagraphWithoutAttributes( child ) !== viewElement.is( 'element', 'span' );
33
+ /**
34
+ * Check if given model element needs refreshing.
35
+ */
36
+ function shouldRefresh(child, mapper) {
37
+ if (!child.is('element', 'paragraph')) {
38
+ return false;
39
+ }
40
+ const viewElement = mapper.toViewElement(child);
41
+ if (!viewElement) {
42
+ return false;
43
+ }
44
+ return isSingleParagraphWithoutAttributes(child) !== viewElement.is('element', 'span');
64
45
  }
@@ -0,0 +1,17 @@
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/converters/table-headings-refresh-handler
7
+ */
8
+ import type { EditingController, Model } from 'ckeditor5/src/engine';
9
+ /**
10
+ * A table headings refresh handler which marks the table cells or rows in the differ to have it re-rendered
11
+ * if the headings attribute changed.
12
+ *
13
+ * Table heading rows and heading columns are represented in the model by a `headingRows` and `headingColumns` attributes.
14
+ *
15
+ * When table headings attribute changes, all the cells/rows are marked to re-render to change between `<td>` and `<th>`.
16
+ */
17
+ export default function tableHeadingsRefreshHandler(model: Model, editing: EditingController): void;
@@ -2,13 +2,7 @@
2
2
  * @license Copyright (c) 2003-2023, CKSource Holding sp. z o.o. All rights reserved.
3
3
  * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
4
  */
5
-
6
- /**
7
- * @module table/converters/table-heading-rows-refresh-post-fixer
8
- */
9
-
10
5
  import TableWalker from '../tablewalker';
11
-
12
6
  /**
13
7
  * A table headings refresh handler which marks the table cells or rows in the differ to have it re-rendered
14
8
  * if the headings attribute changed.
@@ -16,53 +10,40 @@ import TableWalker from '../tablewalker';
16
10
  * Table heading rows and heading columns are represented in the model by a `headingRows` and `headingColumns` attributes.
17
11
  *
18
12
  * When table headings attribute changes, all the cells/rows are marked to re-render to change between `<td>` and `<th>`.
19
- *
20
- * @param {module:engine/model/model~Model} model
21
- * @param {module:engine/controller/editingcontroller~EditingController} editing
22
13
  */
23
- export default function tableHeadingsRefreshHandler( model, editing ) {
24
- const differ = model.document.differ;
25
-
26
- for ( const change of differ.getChanges() ) {
27
- let table;
28
- let isRowChange = false;
29
-
30
- if ( change.type == 'attribute' ) {
31
- const element = change.range.start.nodeAfter;
32
-
33
- if ( !element || !element.is( 'element', 'table' ) ) {
34
- continue;
35
- }
36
-
37
- if ( change.attributeKey != 'headingRows' && change.attributeKey != 'headingColumns' ) {
38
- continue;
39
- }
40
-
41
- table = element;
42
- isRowChange = change.attributeKey == 'headingRows';
43
- } else if ( change.name == 'tableRow' || change.name == 'tableCell' ) {
44
- table = change.position.findAncestor( 'table' );
45
- isRowChange = change.name == 'tableRow';
46
- }
47
-
48
- if ( !table ) {
49
- continue;
50
- }
51
-
52
- const headingRows = table.getAttribute( 'headingRows' ) || 0;
53
- const headingColumns = table.getAttribute( 'headingColumns' ) || 0;
54
-
55
- const tableWalker = new TableWalker( table );
56
-
57
- for ( const tableSlot of tableWalker ) {
58
- const isHeading = tableSlot.row < headingRows || tableSlot.column < headingColumns;
59
- const expectedElementName = isHeading ? 'th' : 'td';
60
-
61
- const viewElement = editing.mapper.toViewElement( tableSlot.cell );
62
-
63
- if ( viewElement && viewElement.is( 'element' ) && viewElement.name != expectedElementName ) {
64
- editing.reconvertItem( isRowChange ? tableSlot.cell.parent : tableSlot.cell );
65
- }
66
- }
67
- }
14
+ export default function tableHeadingsRefreshHandler(model, editing) {
15
+ const differ = model.document.differ;
16
+ for (const change of differ.getChanges()) {
17
+ let table;
18
+ let isRowChange = false;
19
+ if (change.type == 'attribute') {
20
+ const element = change.range.start.nodeAfter;
21
+ if (!element || !element.is('element', 'table')) {
22
+ continue;
23
+ }
24
+ if (change.attributeKey != 'headingRows' && change.attributeKey != 'headingColumns') {
25
+ continue;
26
+ }
27
+ table = element;
28
+ isRowChange = change.attributeKey == 'headingRows';
29
+ }
30
+ else if (change.name == 'tableRow' || change.name == 'tableCell') {
31
+ table = change.position.findAncestor('table');
32
+ isRowChange = change.name == 'tableRow';
33
+ }
34
+ if (!table) {
35
+ continue;
36
+ }
37
+ const headingRows = table.getAttribute('headingRows') || 0;
38
+ const headingColumns = table.getAttribute('headingColumns') || 0;
39
+ const tableWalker = new TableWalker(table);
40
+ for (const tableSlot of tableWalker) {
41
+ const isHeading = tableSlot.row < headingRows || tableSlot.column < headingColumns;
42
+ const expectedElementName = isHeading ? 'th' : 'td';
43
+ const viewElement = editing.mapper.toViewElement(tableSlot.cell);
44
+ if (viewElement && viewElement.is('element') && viewElement.name != expectedElementName) {
45
+ editing.reconvertItem((isRowChange ? tableSlot.cell.parent : tableSlot.cell));
46
+ }
47
+ }
48
+ }
68
49
  }