@ckeditor/ckeditor5-ui 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/CHANGELOG.md +1 -1
  2. package/LICENSE.md +1 -1
  3. package/README.md +4 -4
  4. package/lang/contexts.json +5 -1
  5. package/lang/translations/ar.po +17 -0
  6. package/lang/translations/ast.po +17 -0
  7. package/lang/translations/az.po +17 -0
  8. package/lang/translations/bg.po +17 -0
  9. package/lang/translations/bn.po +17 -0
  10. package/lang/translations/ca.po +17 -0
  11. package/lang/translations/cs.po +17 -0
  12. package/lang/translations/da.po +17 -0
  13. package/lang/translations/de-ch.po +17 -0
  14. package/lang/translations/de.po +17 -0
  15. package/lang/translations/el.po +17 -0
  16. package/lang/translations/en-au.po +17 -0
  17. package/lang/translations/en-gb.po +17 -0
  18. package/lang/translations/en.po +17 -0
  19. package/lang/translations/eo.po +17 -0
  20. package/lang/translations/es.po +17 -0
  21. package/lang/translations/et.po +17 -0
  22. package/lang/translations/eu.po +17 -0
  23. package/lang/translations/fa.po +17 -0
  24. package/lang/translations/fi.po +17 -0
  25. package/lang/translations/fr.po +17 -0
  26. package/lang/translations/gl.po +17 -0
  27. package/lang/translations/he.po +17 -0
  28. package/lang/translations/hi.po +17 -0
  29. package/lang/translations/hr.po +17 -0
  30. package/lang/translations/hu.po +17 -0
  31. package/lang/translations/id.po +17 -0
  32. package/lang/translations/it.po +17 -0
  33. package/lang/translations/ja.po +17 -0
  34. package/lang/translations/km.po +17 -0
  35. package/lang/translations/kn.po +17 -0
  36. package/lang/translations/ko.po +17 -0
  37. package/lang/translations/ku.po +17 -0
  38. package/lang/translations/lt.po +17 -0
  39. package/lang/translations/lv.po +17 -0
  40. package/lang/translations/ms.po +17 -0
  41. package/lang/translations/nb.po +17 -0
  42. package/lang/translations/ne.po +17 -0
  43. package/lang/translations/nl.po +17 -0
  44. package/lang/translations/no.po +17 -0
  45. package/lang/translations/pl.po +17 -0
  46. package/lang/translations/pt-br.po +17 -0
  47. package/lang/translations/pt.po +17 -0
  48. package/lang/translations/ro.po +17 -0
  49. package/lang/translations/ru.po +17 -0
  50. package/lang/translations/sk.po +17 -0
  51. package/lang/translations/sl.po +17 -0
  52. package/lang/translations/sq.po +17 -0
  53. package/lang/translations/sr-latn.po +17 -0
  54. package/lang/translations/sr.po +17 -0
  55. package/lang/translations/sv.po +17 -0
  56. package/lang/translations/th.po +17 -0
  57. package/lang/translations/tk.po +17 -0
  58. package/lang/translations/tr.po +17 -0
  59. package/lang/translations/tt.po +17 -0
  60. package/lang/translations/ug.po +17 -0
  61. package/lang/translations/uk.po +17 -0
  62. package/lang/translations/ur.po +17 -0
  63. package/lang/translations/uz.po +17 -0
  64. package/lang/translations/vi.po +17 -0
  65. package/lang/translations/zh-cn.po +17 -0
  66. package/lang/translations/zh.po +17 -0
  67. package/package.json +3 -7
  68. package/src/augmentation.d.ts +86 -86
  69. package/src/augmentation.js +5 -5
  70. package/src/autocomplete/autocompleteview.d.ts +81 -0
  71. package/src/autocomplete/autocompleteview.js +146 -0
  72. package/src/bindings/addkeyboardhandlingforgrid.d.ts +27 -27
  73. package/src/bindings/addkeyboardhandlingforgrid.js +107 -107
  74. package/src/bindings/clickoutsidehandler.d.ts +28 -28
  75. package/src/bindings/clickoutsidehandler.js +36 -36
  76. package/src/bindings/csstransitiondisablermixin.d.ts +40 -40
  77. package/src/bindings/csstransitiondisablermixin.js +55 -55
  78. package/src/bindings/injectcsstransitiondisabler.d.ts +59 -59
  79. package/src/bindings/injectcsstransitiondisabler.js +71 -71
  80. package/src/bindings/preventdefault.d.ts +33 -33
  81. package/src/bindings/preventdefault.js +34 -34
  82. package/src/bindings/submithandler.d.ts +57 -57
  83. package/src/bindings/submithandler.js +47 -47
  84. package/src/button/button.d.ts +178 -178
  85. package/src/button/button.js +5 -5
  86. package/src/button/buttonlabel.d.ts +34 -0
  87. package/src/button/buttonlabel.js +5 -0
  88. package/src/button/buttonlabelview.d.ts +31 -0
  89. package/src/button/buttonlabelview.js +42 -0
  90. package/src/button/buttonview.d.ts +185 -177
  91. package/src/button/buttonview.js +219 -231
  92. package/src/button/switchbuttonview.d.ts +45 -45
  93. package/src/button/switchbuttonview.js +75 -75
  94. package/src/colorgrid/colorgridview.d.ts +132 -132
  95. package/src/colorgrid/colorgridview.js +124 -124
  96. package/src/colorgrid/colortileview.d.ts +28 -28
  97. package/src/colorgrid/colortileview.js +40 -40
  98. package/src/colorgrid/utils.d.ts +47 -47
  99. package/src/colorgrid/utils.js +84 -84
  100. package/src/colorpicker/colorpickerview.d.ts +137 -137
  101. package/src/colorpicker/colorpickerview.js +270 -270
  102. package/src/colorpicker/utils.d.ts +43 -43
  103. package/src/colorpicker/utils.js +99 -99
  104. package/src/colorselector/colorgridsfragmentview.d.ts +194 -194
  105. package/src/colorselector/colorgridsfragmentview.js +289 -289
  106. package/src/colorselector/colorpickerfragmentview.d.ts +128 -128
  107. package/src/colorselector/colorpickerfragmentview.js +205 -205
  108. package/src/colorselector/colorselectorview.d.ts +242 -242
  109. package/src/colorselector/colorselectorview.js +256 -256
  110. package/src/colorselector/documentcolorcollection.d.ts +70 -70
  111. package/src/colorselector/documentcolorcollection.js +42 -42
  112. package/src/componentfactory.d.ts +81 -81
  113. package/src/componentfactory.js +104 -104
  114. package/src/dropdown/button/dropdownbutton.d.ts +25 -25
  115. package/src/dropdown/button/dropdownbutton.js +5 -5
  116. package/src/dropdown/button/dropdownbuttonview.d.ts +48 -48
  117. package/src/dropdown/button/dropdownbuttonview.js +66 -66
  118. package/src/dropdown/button/splitbuttonview.d.ts +161 -161
  119. package/src/dropdown/button/splitbuttonview.js +152 -152
  120. package/src/dropdown/dropdownpanelfocusable.d.ts +21 -21
  121. package/src/dropdown/dropdownpanelfocusable.js +5 -5
  122. package/src/dropdown/dropdownpanelview.d.ts +62 -62
  123. package/src/dropdown/dropdownpanelview.js +97 -97
  124. package/src/dropdown/dropdownview.d.ts +315 -315
  125. package/src/dropdown/dropdownview.js +379 -378
  126. package/src/dropdown/utils.d.ts +235 -221
  127. package/src/dropdown/utils.js +458 -437
  128. package/src/editableui/editableuiview.d.ts +72 -72
  129. package/src/editableui/editableuiview.js +112 -112
  130. package/src/editableui/inline/inlineeditableuiview.d.ts +40 -40
  131. package/src/editableui/inline/inlineeditableuiview.js +48 -48
  132. package/src/editorui/bodycollection.d.ts +55 -55
  133. package/src/editorui/bodycollection.js +84 -84
  134. package/src/editorui/boxed/boxededitoruiview.d.ts +40 -40
  135. package/src/editorui/boxed/boxededitoruiview.js +81 -81
  136. package/src/editorui/editorui.d.ts +282 -282
  137. package/src/editorui/editorui.js +410 -410
  138. package/src/editorui/editoruiview.d.ts +39 -39
  139. package/src/editorui/editoruiview.js +38 -38
  140. package/src/editorui/poweredby.d.ts +71 -71
  141. package/src/editorui/poweredby.js +276 -299
  142. package/src/focuscycler.d.ts +226 -183
  143. package/src/focuscycler.js +245 -220
  144. package/src/formheader/formheaderview.d.ts +59 -53
  145. package/src/formheader/formheaderview.js +69 -63
  146. package/src/highlightedtext/highlightedtextview.d.ts +38 -0
  147. package/src/highlightedtext/highlightedtextview.js +102 -0
  148. package/src/icon/iconview.d.ts +85 -78
  149. package/src/icon/iconview.js +114 -112
  150. package/src/iframe/iframeview.d.ts +50 -50
  151. package/src/iframe/iframeview.js +63 -63
  152. package/src/index.d.ts +73 -63
  153. package/src/index.js +70 -62
  154. package/src/input/inputbase.d.ts +107 -0
  155. package/src/input/inputbase.js +110 -0
  156. package/src/input/inputview.d.ts +36 -121
  157. package/src/input/inputview.js +24 -106
  158. package/src/inputnumber/inputnumberview.d.ts +49 -49
  159. package/src/inputnumber/inputnumberview.js +40 -40
  160. package/src/inputtext/inputtextview.d.ts +18 -18
  161. package/src/inputtext/inputtextview.js +27 -27
  162. package/src/label/labelview.d.ts +36 -36
  163. package/src/label/labelview.js +41 -41
  164. package/src/labeledfield/labeledfieldview.d.ts +187 -182
  165. package/src/labeledfield/labeledfieldview.js +157 -157
  166. package/src/labeledfield/utils.d.ts +123 -93
  167. package/src/labeledfield/utils.js +176 -131
  168. package/src/labeledinput/labeledinputview.d.ts +125 -125
  169. package/src/labeledinput/labeledinputview.js +125 -125
  170. package/src/list/listitemgroupview.d.ts +51 -0
  171. package/src/list/listitemgroupview.js +75 -0
  172. package/src/list/listitemview.d.ts +36 -35
  173. package/src/list/listitemview.js +42 -40
  174. package/src/list/listseparatorview.d.ts +18 -18
  175. package/src/list/listseparatorview.js +28 -28
  176. package/src/list/listview.d.ts +122 -65
  177. package/src/list/listview.js +187 -90
  178. package/src/model.d.ts +22 -22
  179. package/src/model.js +31 -31
  180. package/src/notification/notification.d.ts +211 -211
  181. package/src/notification/notification.js +187 -187
  182. package/src/panel/balloon/balloonpanelview.d.ts +685 -685
  183. package/src/panel/balloon/balloonpanelview.js +1010 -988
  184. package/src/panel/balloon/contextualballoon.d.ts +299 -299
  185. package/src/panel/balloon/contextualballoon.js +572 -572
  186. package/src/panel/sticky/stickypanelview.d.ts +156 -158
  187. package/src/panel/sticky/stickypanelview.js +234 -231
  188. package/src/search/filteredview.d.ts +31 -0
  189. package/src/search/filteredview.js +5 -0
  190. package/src/search/searchinfoview.d.ts +45 -0
  191. package/src/search/searchinfoview.js +59 -0
  192. package/src/search/searchresultsview.d.ts +54 -0
  193. package/src/search/searchresultsview.js +65 -0
  194. package/src/search/text/searchtextqueryview.d.ts +76 -0
  195. package/src/search/text/searchtextqueryview.js +75 -0
  196. package/src/search/text/searchtextview.d.ts +219 -0
  197. package/src/search/text/searchtextview.js +201 -0
  198. package/src/spinner/spinnerview.d.ts +25 -0
  199. package/src/spinner/spinnerview.js +38 -0
  200. package/src/template.d.ts +942 -942
  201. package/src/template.js +1294 -1294
  202. package/src/textarea/textareaview.d.ts +88 -0
  203. package/src/textarea/textareaview.js +140 -0
  204. package/src/toolbar/balloon/balloontoolbar.d.ts +122 -122
  205. package/src/toolbar/balloon/balloontoolbar.js +300 -300
  206. package/src/toolbar/block/blockbuttonview.d.ts +35 -35
  207. package/src/toolbar/block/blockbuttonview.js +41 -41
  208. package/src/toolbar/block/blocktoolbar.d.ts +161 -161
  209. package/src/toolbar/block/blocktoolbar.js +395 -391
  210. package/src/toolbar/normalizetoolbarconfig.d.ts +40 -39
  211. package/src/toolbar/normalizetoolbarconfig.js +51 -51
  212. package/src/toolbar/toolbarlinebreakview.d.ts +18 -18
  213. package/src/toolbar/toolbarlinebreakview.js +28 -28
  214. package/src/toolbar/toolbarseparatorview.d.ts +18 -18
  215. package/src/toolbar/toolbarseparatorview.js +28 -28
  216. package/src/toolbar/toolbarview.d.ts +266 -265
  217. package/src/toolbar/toolbarview.js +719 -717
  218. package/src/tooltipmanager.d.ts +180 -180
  219. package/src/tooltipmanager.js +353 -353
  220. package/src/view.d.ts +422 -422
  221. package/src/view.js +396 -396
  222. package/src/viewcollection.d.ts +139 -139
  223. package/src/viewcollection.js +206 -206
  224. package/theme/components/autocomplete/autocomplete.css +22 -0
  225. package/theme/components/formheader/formheader.css +8 -0
  226. package/theme/components/highlightedtext/highlightedtext.css +12 -0
  227. package/theme/components/search/search.css +43 -0
  228. package/theme/components/spinner/spinner.css +23 -0
  229. package/theme/components/textarea/textarea.css +10 -0
@@ -0,0 +1,88 @@
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 ui/textarea/textareaview
7
+ */
8
+ import { type Locale } from '@ckeditor/ckeditor5-utils';
9
+ import InputBase from '../input/inputbase';
10
+ import '../../theme/components/input/input.css';
11
+ import '../../theme/components/textarea/textarea.css';
12
+ /**
13
+ * The textarea view class.
14
+ *
15
+ * ```ts
16
+ * const textareaView = new TextareaView();
17
+ *
18
+ * textareaView.minRows = 2;
19
+ * textareaView.maxRows = 10;
20
+ *
21
+ * textareaView.render();
22
+ *
23
+ * document.body.append( textareaView.element );
24
+ * ```
25
+ */
26
+ export default class TextareaView extends InputBase<HTMLTextAreaElement> {
27
+ /**
28
+ * Specifies the visible height of a text area, in lines.
29
+ *
30
+ * @observable
31
+ * @default 2
32
+ */
33
+ minRows: number;
34
+ /**
35
+ * Specifies the maximum number of rows.
36
+ *
37
+ * @observable
38
+ * @default 5
39
+ */
40
+ maxRows: number;
41
+ /**
42
+ * Specifies the value of HTML attribute that indicates whether the user can resize the element.
43
+ *
44
+ * @observable
45
+ * @default 'none'
46
+ */
47
+ resize: 'both' | 'horizontal' | 'vertical' | 'none';
48
+ /**
49
+ * An internal property that stores the current height of the textarea. Used for the DOM binding.
50
+ *
51
+ * @observable
52
+ * @default null
53
+ * @internal
54
+ */
55
+ _height: number | null;
56
+ /**
57
+ * @inheritDoc
58
+ */
59
+ constructor(locale?: Locale);
60
+ /**
61
+ * @inheritDoc
62
+ */
63
+ render(): void;
64
+ /**
65
+ * @inheritDoc
66
+ */
67
+ reset(): void;
68
+ /**
69
+ * Updates the {@link #_height} of the view depending on {@link #minRows}, {@link #maxRows}, and the current content size.
70
+ *
71
+ * **Note**: This method overrides manual resize done by the user using a handle. It's a known bug.
72
+ */
73
+ private _updateAutoGrowHeight;
74
+ /**
75
+ * Validates the {@link #minRows} and {@link #maxRows} properties and warns in the console if the configuration is incorrect.
76
+ */
77
+ private _validateMinMaxRows;
78
+ }
79
+ /**
80
+ * Fired every time the layout of the {@link module:ui/textarea/textareaview~TextareaView} possibly changed as a result
81
+ * of the user input or the value change via {@link module:ui/textarea/textareaview~TextareaView#value}.
82
+ *
83
+ * @eventName ~TextareaView#update
84
+ */
85
+ export type TextareaViewUpdateEvent = {
86
+ name: 'update';
87
+ args: [];
88
+ };
@@ -0,0 +1,140 @@
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 ui/textarea/textareaview
7
+ */
8
+ import { Rect, toUnit, getBorderWidths, global, CKEditorError } from '@ckeditor/ckeditor5-utils';
9
+ import InputBase from '../input/inputbase';
10
+ import '../../theme/components/input/input.css';
11
+ import '../../theme/components/textarea/textarea.css';
12
+ /**
13
+ * The textarea view class.
14
+ *
15
+ * ```ts
16
+ * const textareaView = new TextareaView();
17
+ *
18
+ * textareaView.minRows = 2;
19
+ * textareaView.maxRows = 10;
20
+ *
21
+ * textareaView.render();
22
+ *
23
+ * document.body.append( textareaView.element );
24
+ * ```
25
+ */
26
+ export default class TextareaView extends InputBase {
27
+ /**
28
+ * @inheritDoc
29
+ */
30
+ constructor(locale) {
31
+ super(locale);
32
+ const toPx = toUnit('px');
33
+ this.set('minRows', 2);
34
+ this.set('maxRows', 5);
35
+ this.set('_height', null);
36
+ this.set('resize', 'none');
37
+ this.on('change:minRows', this._validateMinMaxRows.bind(this));
38
+ this.on('change:maxRows', this._validateMinMaxRows.bind(this));
39
+ const bind = this.bindTemplate;
40
+ this.template.tag = 'textarea';
41
+ this.extendTemplate({
42
+ attributes: {
43
+ class: ['ck-textarea'],
44
+ style: {
45
+ height: bind.to('_height', height => height ? toPx(height) : null),
46
+ resize: bind.to('resize')
47
+ },
48
+ rows: bind.to('minRows')
49
+ }
50
+ });
51
+ }
52
+ /**
53
+ * @inheritDoc
54
+ */
55
+ render() {
56
+ super.render();
57
+ this.on('input', () => {
58
+ this._updateAutoGrowHeight(true);
59
+ this.fire('update');
60
+ });
61
+ this.on('change:value', () => {
62
+ // The content needs to be updated by the browser after the value is changed. It takes a few ms.
63
+ global.window.requestAnimationFrame(() => {
64
+ this._updateAutoGrowHeight();
65
+ this.fire('update');
66
+ });
67
+ });
68
+ }
69
+ /**
70
+ * @inheritDoc
71
+ */
72
+ reset() {
73
+ super.reset();
74
+ this._updateAutoGrowHeight();
75
+ this.fire('update');
76
+ }
77
+ /**
78
+ * Updates the {@link #_height} of the view depending on {@link #minRows}, {@link #maxRows}, and the current content size.
79
+ *
80
+ * **Note**: This method overrides manual resize done by the user using a handle. It's a known bug.
81
+ */
82
+ _updateAutoGrowHeight(shouldScroll) {
83
+ const viewElement = this.element;
84
+ const singleLineContentClone = getTextareaElementClone(viewElement, '1');
85
+ const fullTextValueClone = getTextareaElementClone(viewElement, viewElement.value);
86
+ const singleLineContentStyles = singleLineContentClone.ownerDocument.defaultView.getComputedStyle(singleLineContentClone);
87
+ const verticalPaddings = parseFloat(singleLineContentStyles.paddingTop) + parseFloat(singleLineContentStyles.paddingBottom);
88
+ const borders = getBorderWidths(singleLineContentClone);
89
+ const lineHeight = parseFloat(singleLineContentStyles.lineHeight);
90
+ const verticalBorder = borders.top + borders.bottom;
91
+ const singleLineAreaDefaultHeight = new Rect(singleLineContentClone).height;
92
+ const numberOfLines = Math.round((fullTextValueClone.scrollHeight - verticalPaddings) / lineHeight);
93
+ const maxHeight = this.maxRows * lineHeight + verticalPaddings + verticalBorder;
94
+ // There's a --ck-ui-component-min-height CSS custom property that enforces min height of the component.
95
+ // This min-height is relevant only when there's one line of text. Other than that, we can rely on line-height.
96
+ const minHeight = numberOfLines === 1 ? singleLineAreaDefaultHeight : this.minRows * lineHeight + verticalPaddings + verticalBorder;
97
+ // The size of textarea is controlled by height style instead of rows attribute because event though it is
98
+ // a more complex solution, it is immune to the layout textarea has been rendered in (gird, flex).
99
+ this._height = Math.min(Math.max(Math.max(numberOfLines, this.minRows) * lineHeight + verticalPaddings + verticalBorder, minHeight), maxHeight);
100
+ if (shouldScroll) {
101
+ viewElement.scrollTop = viewElement.scrollHeight;
102
+ }
103
+ singleLineContentClone.remove();
104
+ fullTextValueClone.remove();
105
+ }
106
+ /**
107
+ * Validates the {@link #minRows} and {@link #maxRows} properties and warns in the console if the configuration is incorrect.
108
+ */
109
+ _validateMinMaxRows() {
110
+ if (this.minRows > this.maxRows) {
111
+ /**
112
+ * The minimum number of rows is greater than the maximum number of rows.
113
+ *
114
+ * @error ui-textarea-view-min-rows-greater-than-max-rows
115
+ * @param textareaView The misconfigured textarea view instance.
116
+ * @param minRows The value of `minRows` property.
117
+ * @param maxRows The value of `maxRows` property.
118
+ */
119
+ throw new CKEditorError('ui-textarea-view-min-rows-greater-than-max-rows', {
120
+ textareaView: this,
121
+ minRows: this.minRows,
122
+ maxRows: this.maxRows
123
+ });
124
+ }
125
+ }
126
+ }
127
+ function getTextareaElementClone(element, value) {
128
+ const clone = element.cloneNode();
129
+ clone.style.position = 'absolute';
130
+ clone.style.top = '-99999px';
131
+ clone.style.left = '-99999px';
132
+ clone.style.height = 'auto';
133
+ clone.style.overflow = 'hidden';
134
+ clone.style.width = element.ownerDocument.defaultView.getComputedStyle(element).width;
135
+ clone.tabIndex = -1;
136
+ clone.rows = 1;
137
+ clone.value = value;
138
+ element.parentNode.insertBefore(clone, element);
139
+ return clone;
140
+ }
@@ -1,122 +1,122 @@
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 ui/toolbar/balloon/balloontoolbar
7
- */
8
- import ContextualBalloon from '../../panel/balloon/contextualballoon';
9
- import ToolbarView from '../toolbarview';
10
- import { Plugin, type Editor } from '@ckeditor/ckeditor5-core';
11
- import { FocusTracker } from '@ckeditor/ckeditor5-utils';
12
- /**
13
- * The contextual toolbar.
14
- *
15
- * It uses the {@link module:ui/panel/balloon/contextualballoon~ContextualBalloon contextual balloon plugin}.
16
- */
17
- export default class BalloonToolbar extends Plugin {
18
- /**
19
- * The toolbar view displayed in the balloon.
20
- */
21
- readonly toolbarView: ToolbarView;
22
- /**
23
- * Tracks the focus of the {@link module:ui/editorui/editorui~EditorUI#getEditableElement editable element}
24
- * and the {@link #toolbarView}. When both are blurred then the toolbar should hide.
25
- */
26
- readonly focusTracker: FocusTracker;
27
- /**
28
- * A cached and normalized `config.balloonToolbar` object.
29
- */
30
- private _balloonConfig;
31
- /**
32
- * An instance of the resize observer that allows to respond to changes in editable's geometry
33
- * so the toolbar can stay within its boundaries (and group toolbar items that do not fit).
34
- *
35
- * **Note**: Used only when `shouldNotGroupWhenFull` was **not** set in the
36
- * {@link module:core/editor/editorconfig~EditorConfig#balloonToolbar configuration}.
37
- *
38
- * **Note:** Created in {@link #init}.
39
- */
40
- private _resizeObserver;
41
- /**
42
- * The contextual balloon plugin instance.
43
- */
44
- private readonly _balloon;
45
- /**
46
- * Fires `_selectionChangeDebounced` event using `lodash#debounce`.
47
- *
48
- * This event is an internal plugin event which is fired 200 ms after model selection last change.
49
- * This is to makes easy test debounced action without need to use `setTimeout`.
50
- *
51
- * This function is stored as a plugin property to make possible to cancel
52
- * trailing debounced invocation on destroy.
53
- */
54
- private readonly _fireSelectionChangeDebounced;
55
- /**
56
- * @inheritDoc
57
- */
58
- static get pluginName(): "BalloonToolbar";
59
- /**
60
- * @inheritDoc
61
- */
62
- static get requires(): readonly [typeof ContextualBalloon];
63
- /**
64
- * @inheritDoc
65
- */
66
- constructor(editor: Editor);
67
- /**
68
- * @inheritDoc
69
- */
70
- init(): void;
71
- /**
72
- * Creates toolbar components based on given configuration.
73
- * This needs to be done when all plugins are ready.
74
- */
75
- afterInit(): void;
76
- /**
77
- * Creates the toolbar view instance.
78
- */
79
- private _createToolbarView;
80
- /**
81
- * Shows the toolbar and attaches it to the selection.
82
- *
83
- * Fires {@link #event:show} event which can be stopped to prevent the toolbar from showing up.
84
- *
85
- * @param showForCollapsedSelection When set `true`, the toolbar will show despite collapsed selection in the
86
- * editing view.
87
- */
88
- show(showForCollapsedSelection?: boolean): void;
89
- /**
90
- * Hides the toolbar.
91
- */
92
- hide(): void;
93
- /**
94
- * Returns positioning options for the {@link #_balloon}. They control the way balloon is attached
95
- * to the selection.
96
- */
97
- private _getBalloonPositionData;
98
- /**
99
- * Updates the position of the {@link #_balloon} to make up for changes:
100
- *
101
- * * in the geometry of the selection it is attached to (e.g. the selection moved in the viewport or expanded or shrunk),
102
- * * or the geometry of the balloon toolbar itself (e.g. the toolbar has grouped or ungrouped some items and it is shorter or longer).
103
- */
104
- private _updatePosition;
105
- /**
106
- * @inheritDoc
107
- */
108
- destroy(): void;
109
- /**
110
- * Returns toolbar positions for the given direction of the selection.
111
- */
112
- private _getBalloonPositions;
113
- }
114
- /**
115
- * This event is fired just before the toolbar shows up. Stopping this event will prevent this.
116
- *
117
- * @eventName ~BalloonToolbar#show
118
- */
119
- export type BalloonToolbarShowEvent = {
120
- name: 'show';
121
- args: [];
122
- };
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 ui/toolbar/balloon/balloontoolbar
7
+ */
8
+ import ContextualBalloon from '../../panel/balloon/contextualballoon';
9
+ import ToolbarView from '../toolbarview';
10
+ import { Plugin, type Editor } from '@ckeditor/ckeditor5-core';
11
+ import { FocusTracker } from '@ckeditor/ckeditor5-utils';
12
+ /**
13
+ * The contextual toolbar.
14
+ *
15
+ * It uses the {@link module:ui/panel/balloon/contextualballoon~ContextualBalloon contextual balloon plugin}.
16
+ */
17
+ export default class BalloonToolbar extends Plugin {
18
+ /**
19
+ * The toolbar view displayed in the balloon.
20
+ */
21
+ readonly toolbarView: ToolbarView;
22
+ /**
23
+ * Tracks the focus of the {@link module:ui/editorui/editorui~EditorUI#getEditableElement editable element}
24
+ * and the {@link #toolbarView}. When both are blurred then the toolbar should hide.
25
+ */
26
+ readonly focusTracker: FocusTracker;
27
+ /**
28
+ * A cached and normalized `config.balloonToolbar` object.
29
+ */
30
+ private _balloonConfig;
31
+ /**
32
+ * An instance of the resize observer that allows to respond to changes in editable's geometry
33
+ * so the toolbar can stay within its boundaries (and group toolbar items that do not fit).
34
+ *
35
+ * **Note**: Used only when `shouldNotGroupWhenFull` was **not** set in the
36
+ * {@link module:core/editor/editorconfig~EditorConfig#balloonToolbar configuration}.
37
+ *
38
+ * **Note:** Created in {@link #init}.
39
+ */
40
+ private _resizeObserver;
41
+ /**
42
+ * The contextual balloon plugin instance.
43
+ */
44
+ private readonly _balloon;
45
+ /**
46
+ * Fires `_selectionChangeDebounced` event using `lodash#debounce`.
47
+ *
48
+ * This event is an internal plugin event which is fired 200 ms after model selection last change.
49
+ * This is to makes easy test debounced action without need to use `setTimeout`.
50
+ *
51
+ * This function is stored as a plugin property to make possible to cancel
52
+ * trailing debounced invocation on destroy.
53
+ */
54
+ private readonly _fireSelectionChangeDebounced;
55
+ /**
56
+ * @inheritDoc
57
+ */
58
+ static get pluginName(): "BalloonToolbar";
59
+ /**
60
+ * @inheritDoc
61
+ */
62
+ static get requires(): readonly [typeof ContextualBalloon];
63
+ /**
64
+ * @inheritDoc
65
+ */
66
+ constructor(editor: Editor);
67
+ /**
68
+ * @inheritDoc
69
+ */
70
+ init(): void;
71
+ /**
72
+ * Creates toolbar components based on given configuration.
73
+ * This needs to be done when all plugins are ready.
74
+ */
75
+ afterInit(): void;
76
+ /**
77
+ * Creates the toolbar view instance.
78
+ */
79
+ private _createToolbarView;
80
+ /**
81
+ * Shows the toolbar and attaches it to the selection.
82
+ *
83
+ * Fires {@link #event:show} event which can be stopped to prevent the toolbar from showing up.
84
+ *
85
+ * @param showForCollapsedSelection When set `true`, the toolbar will show despite collapsed selection in the
86
+ * editing view.
87
+ */
88
+ show(showForCollapsedSelection?: boolean): void;
89
+ /**
90
+ * Hides the toolbar.
91
+ */
92
+ hide(): void;
93
+ /**
94
+ * Returns positioning options for the {@link #_balloon}. They control the way balloon is attached
95
+ * to the selection.
96
+ */
97
+ private _getBalloonPositionData;
98
+ /**
99
+ * Updates the position of the {@link #_balloon} to make up for changes:
100
+ *
101
+ * * in the geometry of the selection it is attached to (e.g. the selection moved in the viewport or expanded or shrunk),
102
+ * * or the geometry of the balloon toolbar itself (e.g. the toolbar has grouped or ungrouped some items and it is shorter or longer).
103
+ */
104
+ private _updatePosition;
105
+ /**
106
+ * @inheritDoc
107
+ */
108
+ destroy(): void;
109
+ /**
110
+ * Returns toolbar positions for the given direction of the selection.
111
+ */
112
+ private _getBalloonPositions;
113
+ }
114
+ /**
115
+ * This event is fired just before the toolbar shows up. Stopping this event will prevent this.
116
+ *
117
+ * @eventName ~BalloonToolbar#show
118
+ */
119
+ export type BalloonToolbarShowEvent = {
120
+ name: 'show';
121
+ args: [];
122
+ };