@ckeditor/ckeditor5-ui 39.0.2 → 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 (226) hide show
  1. package/lang/contexts.json +5 -1
  2. package/lang/translations/ar.po +16 -0
  3. package/lang/translations/ast.po +16 -0
  4. package/lang/translations/az.po +16 -0
  5. package/lang/translations/bg.po +16 -0
  6. package/lang/translations/bn.po +16 -0
  7. package/lang/translations/ca.po +16 -0
  8. package/lang/translations/cs.po +16 -0
  9. package/lang/translations/da.po +16 -0
  10. package/lang/translations/de-ch.po +16 -0
  11. package/lang/translations/de.po +16 -0
  12. package/lang/translations/el.po +16 -0
  13. package/lang/translations/en-au.po +16 -0
  14. package/lang/translations/en-gb.po +16 -0
  15. package/lang/translations/en.po +16 -0
  16. package/lang/translations/eo.po +16 -0
  17. package/lang/translations/es.po +16 -0
  18. package/lang/translations/et.po +16 -0
  19. package/lang/translations/eu.po +16 -0
  20. package/lang/translations/fa.po +16 -0
  21. package/lang/translations/fi.po +16 -0
  22. package/lang/translations/fr.po +16 -0
  23. package/lang/translations/gl.po +16 -0
  24. package/lang/translations/he.po +16 -0
  25. package/lang/translations/hi.po +16 -0
  26. package/lang/translations/hr.po +16 -0
  27. package/lang/translations/hu.po +16 -0
  28. package/lang/translations/id.po +16 -0
  29. package/lang/translations/it.po +16 -0
  30. package/lang/translations/ja.po +16 -0
  31. package/lang/translations/km.po +16 -0
  32. package/lang/translations/kn.po +16 -0
  33. package/lang/translations/ko.po +16 -0
  34. package/lang/translations/ku.po +16 -0
  35. package/lang/translations/lt.po +16 -0
  36. package/lang/translations/lv.po +16 -0
  37. package/lang/translations/ms.po +16 -0
  38. package/lang/translations/nb.po +16 -0
  39. package/lang/translations/ne.po +16 -0
  40. package/lang/translations/nl.po +16 -0
  41. package/lang/translations/no.po +16 -0
  42. package/lang/translations/pl.po +16 -0
  43. package/lang/translations/pt-br.po +16 -0
  44. package/lang/translations/pt.po +16 -0
  45. package/lang/translations/ro.po +16 -0
  46. package/lang/translations/ru.po +16 -0
  47. package/lang/translations/sk.po +16 -0
  48. package/lang/translations/sl.po +16 -0
  49. package/lang/translations/sq.po +16 -0
  50. package/lang/translations/sr-latn.po +16 -0
  51. package/lang/translations/sr.po +16 -0
  52. package/lang/translations/sv.po +16 -0
  53. package/lang/translations/th.po +16 -0
  54. package/lang/translations/tk.po +16 -0
  55. package/lang/translations/tr.po +16 -0
  56. package/lang/translations/tt.po +16 -0
  57. package/lang/translations/ug.po +16 -0
  58. package/lang/translations/uk.po +16 -0
  59. package/lang/translations/ur.po +16 -0
  60. package/lang/translations/uz.po +16 -0
  61. package/lang/translations/vi.po +16 -0
  62. package/lang/translations/zh-cn.po +16 -0
  63. package/lang/translations/zh.po +16 -0
  64. package/package.json +3 -3
  65. package/src/augmentation.d.ts +86 -86
  66. package/src/augmentation.js +5 -5
  67. package/src/autocomplete/autocompleteview.d.ts +81 -0
  68. package/src/autocomplete/autocompleteview.js +146 -0
  69. package/src/bindings/addkeyboardhandlingforgrid.d.ts +27 -27
  70. package/src/bindings/addkeyboardhandlingforgrid.js +107 -107
  71. package/src/bindings/clickoutsidehandler.d.ts +28 -28
  72. package/src/bindings/clickoutsidehandler.js +36 -36
  73. package/src/bindings/csstransitiondisablermixin.d.ts +40 -40
  74. package/src/bindings/csstransitiondisablermixin.js +55 -55
  75. package/src/bindings/injectcsstransitiondisabler.d.ts +59 -59
  76. package/src/bindings/injectcsstransitiondisabler.js +71 -71
  77. package/src/bindings/preventdefault.d.ts +33 -33
  78. package/src/bindings/preventdefault.js +34 -34
  79. package/src/bindings/submithandler.d.ts +57 -57
  80. package/src/bindings/submithandler.js +47 -47
  81. package/src/button/button.d.ts +178 -178
  82. package/src/button/button.js +5 -5
  83. package/src/button/buttonlabel.d.ts +34 -0
  84. package/src/button/buttonlabel.js +5 -0
  85. package/src/button/buttonlabelview.d.ts +31 -0
  86. package/src/button/buttonlabelview.js +42 -0
  87. package/src/button/buttonview.d.ts +185 -177
  88. package/src/button/buttonview.js +219 -231
  89. package/src/button/switchbuttonview.d.ts +45 -45
  90. package/src/button/switchbuttonview.js +75 -75
  91. package/src/colorgrid/colorgridview.d.ts +132 -132
  92. package/src/colorgrid/colorgridview.js +124 -124
  93. package/src/colorgrid/colortileview.d.ts +28 -28
  94. package/src/colorgrid/colortileview.js +40 -40
  95. package/src/colorgrid/utils.d.ts +47 -47
  96. package/src/colorgrid/utils.js +84 -84
  97. package/src/colorpicker/colorpickerview.d.ts +137 -137
  98. package/src/colorpicker/colorpickerview.js +270 -270
  99. package/src/colorpicker/utils.d.ts +43 -43
  100. package/src/colorpicker/utils.js +99 -99
  101. package/src/colorselector/colorgridsfragmentview.d.ts +194 -194
  102. package/src/colorselector/colorgridsfragmentview.js +289 -289
  103. package/src/colorselector/colorpickerfragmentview.d.ts +128 -128
  104. package/src/colorselector/colorpickerfragmentview.js +205 -205
  105. package/src/colorselector/colorselectorview.d.ts +242 -242
  106. package/src/colorselector/colorselectorview.js +256 -256
  107. package/src/colorselector/documentcolorcollection.d.ts +70 -70
  108. package/src/colorselector/documentcolorcollection.js +42 -42
  109. package/src/componentfactory.d.ts +81 -81
  110. package/src/componentfactory.js +104 -104
  111. package/src/dropdown/button/dropdownbutton.d.ts +25 -25
  112. package/src/dropdown/button/dropdownbutton.js +5 -5
  113. package/src/dropdown/button/dropdownbuttonview.d.ts +48 -48
  114. package/src/dropdown/button/dropdownbuttonview.js +66 -66
  115. package/src/dropdown/button/splitbuttonview.d.ts +161 -161
  116. package/src/dropdown/button/splitbuttonview.js +152 -152
  117. package/src/dropdown/dropdownpanelfocusable.d.ts +21 -21
  118. package/src/dropdown/dropdownpanelfocusable.js +5 -5
  119. package/src/dropdown/dropdownpanelview.d.ts +62 -62
  120. package/src/dropdown/dropdownpanelview.js +97 -97
  121. package/src/dropdown/dropdownview.d.ts +315 -315
  122. package/src/dropdown/dropdownview.js +379 -378
  123. package/src/dropdown/utils.d.ts +235 -221
  124. package/src/dropdown/utils.js +458 -437
  125. package/src/editableui/editableuiview.d.ts +72 -72
  126. package/src/editableui/editableuiview.js +112 -112
  127. package/src/editableui/inline/inlineeditableuiview.d.ts +40 -40
  128. package/src/editableui/inline/inlineeditableuiview.js +48 -48
  129. package/src/editorui/bodycollection.d.ts +55 -55
  130. package/src/editorui/bodycollection.js +84 -84
  131. package/src/editorui/boxed/boxededitoruiview.d.ts +40 -40
  132. package/src/editorui/boxed/boxededitoruiview.js +81 -81
  133. package/src/editorui/editorui.d.ts +282 -282
  134. package/src/editorui/editorui.js +410 -410
  135. package/src/editorui/editoruiview.d.ts +39 -39
  136. package/src/editorui/editoruiview.js +38 -38
  137. package/src/editorui/poweredby.d.ts +71 -71
  138. package/src/editorui/poweredby.js +276 -299
  139. package/src/focuscycler.d.ts +226 -183
  140. package/src/focuscycler.js +245 -220
  141. package/src/formheader/formheaderview.d.ts +59 -53
  142. package/src/formheader/formheaderview.js +69 -63
  143. package/src/highlightedtext/highlightedtextview.d.ts +38 -0
  144. package/src/highlightedtext/highlightedtextview.js +102 -0
  145. package/src/icon/iconview.d.ts +85 -78
  146. package/src/icon/iconview.js +114 -112
  147. package/src/iframe/iframeview.d.ts +50 -50
  148. package/src/iframe/iframeview.js +63 -63
  149. package/src/index.d.ts +73 -63
  150. package/src/index.js +70 -62
  151. package/src/input/inputbase.d.ts +107 -0
  152. package/src/input/inputbase.js +110 -0
  153. package/src/input/inputview.d.ts +36 -121
  154. package/src/input/inputview.js +24 -106
  155. package/src/inputnumber/inputnumberview.d.ts +49 -49
  156. package/src/inputnumber/inputnumberview.js +40 -40
  157. package/src/inputtext/inputtextview.d.ts +18 -18
  158. package/src/inputtext/inputtextview.js +27 -27
  159. package/src/label/labelview.d.ts +36 -36
  160. package/src/label/labelview.js +41 -41
  161. package/src/labeledfield/labeledfieldview.d.ts +187 -182
  162. package/src/labeledfield/labeledfieldview.js +157 -157
  163. package/src/labeledfield/utils.d.ts +123 -93
  164. package/src/labeledfield/utils.js +176 -131
  165. package/src/labeledinput/labeledinputview.d.ts +125 -125
  166. package/src/labeledinput/labeledinputview.js +125 -125
  167. package/src/list/listitemgroupview.d.ts +51 -0
  168. package/src/list/listitemgroupview.js +75 -0
  169. package/src/list/listitemview.d.ts +36 -35
  170. package/src/list/listitemview.js +42 -40
  171. package/src/list/listseparatorview.d.ts +18 -18
  172. package/src/list/listseparatorview.js +28 -28
  173. package/src/list/listview.d.ts +122 -65
  174. package/src/list/listview.js +187 -90
  175. package/src/model.d.ts +22 -22
  176. package/src/model.js +31 -31
  177. package/src/notification/notification.d.ts +211 -211
  178. package/src/notification/notification.js +187 -187
  179. package/src/panel/balloon/balloonpanelview.d.ts +685 -685
  180. package/src/panel/balloon/balloonpanelview.js +1010 -988
  181. package/src/panel/balloon/contextualballoon.d.ts +299 -299
  182. package/src/panel/balloon/contextualballoon.js +572 -572
  183. package/src/panel/sticky/stickypanelview.d.ts +156 -158
  184. package/src/panel/sticky/stickypanelview.js +234 -231
  185. package/src/search/filteredview.d.ts +31 -0
  186. package/src/search/filteredview.js +5 -0
  187. package/src/search/searchinfoview.d.ts +45 -0
  188. package/src/search/searchinfoview.js +59 -0
  189. package/src/search/searchresultsview.d.ts +54 -0
  190. package/src/search/searchresultsview.js +65 -0
  191. package/src/search/text/searchtextqueryview.d.ts +76 -0
  192. package/src/search/text/searchtextqueryview.js +75 -0
  193. package/src/search/text/searchtextview.d.ts +219 -0
  194. package/src/search/text/searchtextview.js +201 -0
  195. package/src/spinner/spinnerview.d.ts +25 -0
  196. package/src/spinner/spinnerview.js +38 -0
  197. package/src/template.d.ts +942 -942
  198. package/src/template.js +1294 -1294
  199. package/src/textarea/textareaview.d.ts +88 -0
  200. package/src/textarea/textareaview.js +140 -0
  201. package/src/toolbar/balloon/balloontoolbar.d.ts +122 -122
  202. package/src/toolbar/balloon/balloontoolbar.js +300 -300
  203. package/src/toolbar/block/blockbuttonview.d.ts +35 -35
  204. package/src/toolbar/block/blockbuttonview.js +41 -41
  205. package/src/toolbar/block/blocktoolbar.d.ts +161 -161
  206. package/src/toolbar/block/blocktoolbar.js +395 -391
  207. package/src/toolbar/normalizetoolbarconfig.d.ts +40 -39
  208. package/src/toolbar/normalizetoolbarconfig.js +51 -51
  209. package/src/toolbar/toolbarlinebreakview.d.ts +18 -18
  210. package/src/toolbar/toolbarlinebreakview.js +28 -28
  211. package/src/toolbar/toolbarseparatorview.d.ts +18 -18
  212. package/src/toolbar/toolbarseparatorview.js +28 -28
  213. package/src/toolbar/toolbarview.d.ts +266 -265
  214. package/src/toolbar/toolbarview.js +719 -717
  215. package/src/tooltipmanager.d.ts +180 -180
  216. package/src/tooltipmanager.js +353 -353
  217. package/src/view.d.ts +422 -422
  218. package/src/view.js +396 -396
  219. package/src/viewcollection.d.ts +139 -139
  220. package/src/viewcollection.js +206 -206
  221. package/theme/components/autocomplete/autocomplete.css +22 -0
  222. package/theme/components/formheader/formheader.css +8 -0
  223. package/theme/components/highlightedtext/highlightedtext.css +12 -0
  224. package/theme/components/search/search.css +43 -0
  225. package/theme/components/spinner/spinner.css +23 -0
  226. 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
+ };