@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,169 +1,169 @@
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/ui/inserttableview
7
- */
8
- import { View, ButtonView, addKeyboardHandlingForGrid } from 'ckeditor5/src/ui';
9
- import { KeystrokeHandler, FocusTracker } from 'ckeditor5/src/utils';
10
- import './../../theme/inserttable.css';
11
- /**
12
- * The table size view.
13
- *
14
- * It renders a 10x10 grid to choose the inserted table size.
15
- */
16
- export default class InsertTableView extends View {
17
- /**
18
- * @inheritDoc
19
- */
20
- constructor(locale) {
21
- super(locale);
22
- const bind = this.bindTemplate;
23
- this.items = this._createGridCollection();
24
- this.keystrokes = new KeystrokeHandler();
25
- this.focusTracker = new FocusTracker();
26
- this.set('rows', 0);
27
- this.set('columns', 0);
28
- this.bind('label').to(this, 'columns', this, 'rows', (columns, rows) => `${rows} × ${columns}`);
29
- this.setTemplate({
30
- tag: 'div',
31
- attributes: {
32
- class: ['ck']
33
- },
34
- children: [
35
- {
36
- tag: 'div',
37
- attributes: {
38
- class: ['ck-insert-table-dropdown__grid']
39
- },
40
- on: {
41
- 'mouseover@.ck-insert-table-dropdown-grid-box': bind.to('boxover')
42
- },
43
- children: this.items
44
- },
45
- {
46
- tag: 'div',
47
- attributes: {
48
- class: [
49
- 'ck',
50
- 'ck-insert-table-dropdown__label'
51
- ],
52
- 'aria-hidden': true
53
- },
54
- children: [
55
- {
56
- text: bind.to('label')
57
- }
58
- ]
59
- }
60
- ],
61
- on: {
62
- mousedown: bind.to(evt => {
63
- evt.preventDefault();
64
- }),
65
- click: bind.to(() => {
66
- this.fire('execute');
67
- })
68
- }
69
- });
70
- // #rows and #columns are set via changes to #focusTracker on mouse over.
71
- this.on('boxover', (evt, domEvt) => {
72
- const { row, column } = domEvt.target.dataset;
73
- this.items.get((parseInt(row, 10) - 1) * 10 + (parseInt(column, 10) - 1)).focus();
74
- });
75
- // This allows the #rows and #columns to be updated when:
76
- // * the user navigates the grid using the keyboard,
77
- // * the user moves the mouse over grid items.
78
- this.focusTracker.on('change:focusedElement', (evt, name, focusedElement) => {
79
- if (!focusedElement) {
80
- return;
81
- }
82
- const { row, column } = focusedElement.dataset;
83
- // As row & column indexes are zero-based transform it to number of selected rows & columns.
84
- this.set({
85
- rows: parseInt(row),
86
- columns: parseInt(column)
87
- });
88
- });
89
- this.on('change:columns', () => this._highlightGridBoxes());
90
- this.on('change:rows', () => this._highlightGridBoxes());
91
- }
92
- render() {
93
- super.render();
94
- addKeyboardHandlingForGrid({
95
- keystrokeHandler: this.keystrokes,
96
- focusTracker: this.focusTracker,
97
- gridItems: this.items,
98
- numberOfColumns: 10,
99
- uiLanguageDirection: this.locale && this.locale.uiLanguageDirection
100
- });
101
- for (const item of this.items) {
102
- this.focusTracker.add(item.element);
103
- }
104
- this.keystrokes.listenTo(this.element);
105
- }
106
- /**
107
- * @inheritDoc
108
- */
109
- focus() {
110
- this.items.get(0).focus();
111
- }
112
- /**
113
- * @inheritDoc
114
- */
115
- focusLast() {
116
- this.items.get(0).focus();
117
- }
118
- /**
119
- * Highlights grid boxes depending on rows and columns selected.
120
- */
121
- _highlightGridBoxes() {
122
- const rows = this.rows;
123
- const columns = this.columns;
124
- this.items.map((boxView, index) => {
125
- // Translate box index to the row & column index.
126
- const itemRow = Math.floor(index / 10);
127
- const itemColumn = index % 10;
128
- // Grid box is highlighted when its row & column index belongs to selected number of rows & columns.
129
- const isOn = itemRow < rows && itemColumn < columns;
130
- boxView.set('isOn', isOn);
131
- });
132
- }
133
- /**
134
- * Creates a new Button for the grid.
135
- *
136
- * @param locale The locale instance.
137
- * @param row Row number.
138
- * @param column Column number.
139
- * @param label The grid button label.
140
- */
141
- _createGridButton(locale, row, column, label) {
142
- const button = new ButtonView(locale);
143
- button.set({
144
- label,
145
- class: 'ck-insert-table-dropdown-grid-box'
146
- });
147
- button.extendTemplate({
148
- attributes: {
149
- 'data-row': row,
150
- 'data-column': column
151
- }
152
- });
153
- return button;
154
- }
155
- /**
156
- * @returns A view collection containing boxes to be placed in a table grid.
157
- */
158
- _createGridCollection() {
159
- const boxes = [];
160
- // Add grid boxes to table selection view.
161
- for (let index = 0; index < 100; index++) {
162
- const row = Math.floor(index / 10);
163
- const column = index % 10;
164
- const label = `${row + 1} × ${column + 1}`;
165
- boxes.push(this._createGridButton(this.locale, row + 1, column + 1, label));
166
- }
167
- return this.createCollection(boxes);
168
- }
169
- }
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/ui/inserttableview
7
+ */
8
+ import { View, ButtonView, addKeyboardHandlingForGrid } from 'ckeditor5/src/ui';
9
+ import { KeystrokeHandler, FocusTracker } from 'ckeditor5/src/utils';
10
+ import './../../theme/inserttable.css';
11
+ /**
12
+ * The table size view.
13
+ *
14
+ * It renders a 10x10 grid to choose the inserted table size.
15
+ */
16
+ export default class InsertTableView extends View {
17
+ /**
18
+ * @inheritDoc
19
+ */
20
+ constructor(locale) {
21
+ super(locale);
22
+ const bind = this.bindTemplate;
23
+ this.items = this._createGridCollection();
24
+ this.keystrokes = new KeystrokeHandler();
25
+ this.focusTracker = new FocusTracker();
26
+ this.set('rows', 0);
27
+ this.set('columns', 0);
28
+ this.bind('label').to(this, 'columns', this, 'rows', (columns, rows) => `${rows} × ${columns}`);
29
+ this.setTemplate({
30
+ tag: 'div',
31
+ attributes: {
32
+ class: ['ck']
33
+ },
34
+ children: [
35
+ {
36
+ tag: 'div',
37
+ attributes: {
38
+ class: ['ck-insert-table-dropdown__grid']
39
+ },
40
+ on: {
41
+ 'mouseover@.ck-insert-table-dropdown-grid-box': bind.to('boxover')
42
+ },
43
+ children: this.items
44
+ },
45
+ {
46
+ tag: 'div',
47
+ attributes: {
48
+ class: [
49
+ 'ck',
50
+ 'ck-insert-table-dropdown__label'
51
+ ],
52
+ 'aria-hidden': true
53
+ },
54
+ children: [
55
+ {
56
+ text: bind.to('label')
57
+ }
58
+ ]
59
+ }
60
+ ],
61
+ on: {
62
+ mousedown: bind.to(evt => {
63
+ evt.preventDefault();
64
+ }),
65
+ click: bind.to(() => {
66
+ this.fire('execute');
67
+ })
68
+ }
69
+ });
70
+ // #rows and #columns are set via changes to #focusTracker on mouse over.
71
+ this.on('boxover', (evt, domEvt) => {
72
+ const { row, column } = domEvt.target.dataset;
73
+ this.items.get((parseInt(row, 10) - 1) * 10 + (parseInt(column, 10) - 1)).focus();
74
+ });
75
+ // This allows the #rows and #columns to be updated when:
76
+ // * the user navigates the grid using the keyboard,
77
+ // * the user moves the mouse over grid items.
78
+ this.focusTracker.on('change:focusedElement', (evt, name, focusedElement) => {
79
+ if (!focusedElement) {
80
+ return;
81
+ }
82
+ const { row, column } = focusedElement.dataset;
83
+ // As row & column indexes are zero-based transform it to number of selected rows & columns.
84
+ this.set({
85
+ rows: parseInt(row),
86
+ columns: parseInt(column)
87
+ });
88
+ });
89
+ this.on('change:columns', () => this._highlightGridBoxes());
90
+ this.on('change:rows', () => this._highlightGridBoxes());
91
+ }
92
+ render() {
93
+ super.render();
94
+ addKeyboardHandlingForGrid({
95
+ keystrokeHandler: this.keystrokes,
96
+ focusTracker: this.focusTracker,
97
+ gridItems: this.items,
98
+ numberOfColumns: 10,
99
+ uiLanguageDirection: this.locale && this.locale.uiLanguageDirection
100
+ });
101
+ for (const item of this.items) {
102
+ this.focusTracker.add(item.element);
103
+ }
104
+ this.keystrokes.listenTo(this.element);
105
+ }
106
+ /**
107
+ * @inheritDoc
108
+ */
109
+ focus() {
110
+ this.items.get(0).focus();
111
+ }
112
+ /**
113
+ * @inheritDoc
114
+ */
115
+ focusLast() {
116
+ this.items.get(0).focus();
117
+ }
118
+ /**
119
+ * Highlights grid boxes depending on rows and columns selected.
120
+ */
121
+ _highlightGridBoxes() {
122
+ const rows = this.rows;
123
+ const columns = this.columns;
124
+ this.items.map((boxView, index) => {
125
+ // Translate box index to the row & column index.
126
+ const itemRow = Math.floor(index / 10);
127
+ const itemColumn = index % 10;
128
+ // Grid box is highlighted when its row & column index belongs to selected number of rows & columns.
129
+ const isOn = itemRow < rows && itemColumn < columns;
130
+ boxView.set('isOn', isOn);
131
+ });
132
+ }
133
+ /**
134
+ * Creates a new Button for the grid.
135
+ *
136
+ * @param locale The locale instance.
137
+ * @param row Row number.
138
+ * @param column Column number.
139
+ * @param label The grid button label.
140
+ */
141
+ _createGridButton(locale, row, column, label) {
142
+ const button = new ButtonView(locale);
143
+ button.set({
144
+ label,
145
+ class: 'ck-insert-table-dropdown-grid-box'
146
+ });
147
+ button.extendTemplate({
148
+ attributes: {
149
+ 'data-row': row,
150
+ 'data-column': column
151
+ }
152
+ });
153
+ return button;
154
+ }
155
+ /**
156
+ * @returns A view collection containing boxes to be placed in a table grid.
157
+ */
158
+ _createGridCollection() {
159
+ const boxes = [];
160
+ // Add grid boxes to table selection view.
161
+ for (let index = 0; index < 100; index++) {
162
+ const row = Math.floor(index / 10);
163
+ const column = index % 10;
164
+ const label = `${row + 1} × ${column + 1}`;
165
+ boxes.push(this._createGridButton(this.locale, row + 1, column + 1, label));
166
+ }
167
+ return this.createCollection(boxes);
168
+ }
169
+ }
@@ -1,42 +1,42 @@
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/utils/common
7
- */
8
- import type { Conversion, Element, Item, Position, Schema, Writer } from 'ckeditor5/src/engine';
9
- import type TableUtils from '../tableutils';
10
- /**
11
- * A common method to update the numeric value. If a value is the default one, it will be unset.
12
- *
13
- * @param key An attribute key.
14
- * @param value The new attribute value.
15
- * @param item A model item on which the attribute will be set.
16
- * @param defaultValue The default attribute value. If a value is lower or equal, it will be unset.
17
- */
18
- export declare function updateNumericAttribute(key: string, value: unknown, item: Item, writer: Writer, defaultValue?: unknown): void;
19
- /**
20
- * A common method to create an empty table cell. It creates a proper model structure as a table cell must have at least one block inside.
21
- *
22
- * @param writer The model writer.
23
- * @param insertPosition The position at which the table cell should be inserted.
24
- * @param attributes The element attributes.
25
- * @returns Created table cell.
26
- */
27
- export declare function createEmptyTableCell(writer: Writer, insertPosition: Position, attributes?: Record<string, unknown>): Element;
28
- /**
29
- * Checks if a table cell belongs to the heading column section.
30
- */
31
- export declare function isHeadingColumnCell(tableUtils: TableUtils, tableCell: Element): boolean;
32
- /**
33
- * Enables conversion for an attribute for simple view-model mappings.
34
- *
35
- * @param options.defaultValue The default value for the specified `modelAttribute`.
36
- */
37
- export declare function enableProperty(schema: Schema, conversion: Conversion, options: {
38
- modelAttribute: string;
39
- styleName: string;
40
- defaultValue: string;
41
- reduceBoxSides?: boolean;
42
- }): void;
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/utils/common
7
+ */
8
+ import type { Conversion, Element, Item, Position, Schema, Writer } from 'ckeditor5/src/engine';
9
+ import type TableUtils from '../tableutils';
10
+ /**
11
+ * A common method to update the numeric value. If a value is the default one, it will be unset.
12
+ *
13
+ * @param key An attribute key.
14
+ * @param value The new attribute value.
15
+ * @param item A model item on which the attribute will be set.
16
+ * @param defaultValue The default attribute value. If a value is lower or equal, it will be unset.
17
+ */
18
+ export declare function updateNumericAttribute(key: string, value: unknown, item: Item, writer: Writer, defaultValue?: unknown): void;
19
+ /**
20
+ * A common method to create an empty table cell. It creates a proper model structure as a table cell must have at least one block inside.
21
+ *
22
+ * @param writer The model writer.
23
+ * @param insertPosition The position at which the table cell should be inserted.
24
+ * @param attributes The element attributes.
25
+ * @returns Created table cell.
26
+ */
27
+ export declare function createEmptyTableCell(writer: Writer, insertPosition: Position, attributes?: Record<string, unknown>): Element;
28
+ /**
29
+ * Checks if a table cell belongs to the heading column section.
30
+ */
31
+ export declare function isHeadingColumnCell(tableUtils: TableUtils, tableCell: Element): boolean;
32
+ /**
33
+ * Enables conversion for an attribute for simple view-model mappings.
34
+ *
35
+ * @param options.defaultValue The default value for the specified `modelAttribute`.
36
+ */
37
+ export declare function enableProperty(schema: Schema, conversion: Conversion, options: {
38
+ modelAttribute: string;
39
+ styleName: string;
40
+ defaultValue: string;
41
+ reduceBoxSides?: boolean;
42
+ }): void;
@@ -1,57 +1,57 @@
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
- import { downcastAttributeToStyle, upcastStyleToAttribute } from './../converters/tableproperties';
6
- /**
7
- * A common method to update the numeric value. If a value is the default one, it will be unset.
8
- *
9
- * @param key An attribute key.
10
- * @param value The new attribute value.
11
- * @param item A model item on which the attribute will be set.
12
- * @param defaultValue The default attribute value. If a value is lower or equal, it will be unset.
13
- */
14
- export function updateNumericAttribute(key, value, item, writer, defaultValue = 1) {
15
- if (value !== undefined && value !== null && defaultValue !== undefined && defaultValue !== null && value > defaultValue) {
16
- writer.setAttribute(key, value, item);
17
- }
18
- else {
19
- writer.removeAttribute(key, item);
20
- }
21
- }
22
- /**
23
- * A common method to create an empty table cell. It creates a proper model structure as a table cell must have at least one block inside.
24
- *
25
- * @param writer The model writer.
26
- * @param insertPosition The position at which the table cell should be inserted.
27
- * @param attributes The element attributes.
28
- * @returns Created table cell.
29
- */
30
- export function createEmptyTableCell(writer, insertPosition, attributes = {}) {
31
- const tableCell = writer.createElement('tableCell', attributes);
32
- writer.insertElement('paragraph', tableCell);
33
- writer.insert(tableCell, insertPosition);
34
- return tableCell;
35
- }
36
- /**
37
- * Checks if a table cell belongs to the heading column section.
38
- */
39
- export function isHeadingColumnCell(tableUtils, tableCell) {
40
- const table = tableCell.parent.parent;
41
- const headingColumns = parseInt(table.getAttribute('headingColumns') || '0');
42
- const { column } = tableUtils.getCellLocation(tableCell);
43
- return !!headingColumns && column < headingColumns;
44
- }
45
- /**
46
- * Enables conversion for an attribute for simple view-model mappings.
47
- *
48
- * @param options.defaultValue The default value for the specified `modelAttribute`.
49
- */
50
- export function enableProperty(schema, conversion, options) {
51
- const { modelAttribute } = options;
52
- schema.extend('tableCell', {
53
- allowAttributes: [modelAttribute]
54
- });
55
- upcastStyleToAttribute(conversion, { viewElement: /^(td|th)$/, ...options });
56
- downcastAttributeToStyle(conversion, { modelElement: 'tableCell', ...options });
57
- }
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
+ import { downcastAttributeToStyle, upcastStyleToAttribute } from './../converters/tableproperties';
6
+ /**
7
+ * A common method to update the numeric value. If a value is the default one, it will be unset.
8
+ *
9
+ * @param key An attribute key.
10
+ * @param value The new attribute value.
11
+ * @param item A model item on which the attribute will be set.
12
+ * @param defaultValue The default attribute value. If a value is lower or equal, it will be unset.
13
+ */
14
+ export function updateNumericAttribute(key, value, item, writer, defaultValue = 1) {
15
+ if (value !== undefined && value !== null && defaultValue !== undefined && defaultValue !== null && value > defaultValue) {
16
+ writer.setAttribute(key, value, item);
17
+ }
18
+ else {
19
+ writer.removeAttribute(key, item);
20
+ }
21
+ }
22
+ /**
23
+ * A common method to create an empty table cell. It creates a proper model structure as a table cell must have at least one block inside.
24
+ *
25
+ * @param writer The model writer.
26
+ * @param insertPosition The position at which the table cell should be inserted.
27
+ * @param attributes The element attributes.
28
+ * @returns Created table cell.
29
+ */
30
+ export function createEmptyTableCell(writer, insertPosition, attributes = {}) {
31
+ const tableCell = writer.createElement('tableCell', attributes);
32
+ writer.insertElement('paragraph', tableCell);
33
+ writer.insert(tableCell, insertPosition);
34
+ return tableCell;
35
+ }
36
+ /**
37
+ * Checks if a table cell belongs to the heading column section.
38
+ */
39
+ export function isHeadingColumnCell(tableUtils, tableCell) {
40
+ const table = tableCell.parent.parent;
41
+ const headingColumns = parseInt(table.getAttribute('headingColumns') || '0');
42
+ const { column } = tableUtils.getCellLocation(tableCell);
43
+ return !!headingColumns && column < headingColumns;
44
+ }
45
+ /**
46
+ * Enables conversion for an attribute for simple view-model mappings.
47
+ *
48
+ * @param options.defaultValue The default value for the specified `modelAttribute`.
49
+ */
50
+ export function enableProperty(schema, conversion, options) {
51
+ const { modelAttribute } = options;
52
+ schema.extend('tableCell', {
53
+ allowAttributes: [modelAttribute]
54
+ });
55
+ upcastStyleToAttribute(conversion, { viewElement: /^(td|th)$/, ...options });
56
+ downcastAttributeToStyle(conversion, { modelElement: 'tableCell', ...options });
57
+ }