@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.
- package/lang/contexts.json +5 -1
- package/lang/translations/ar.po +16 -0
- package/lang/translations/ast.po +16 -0
- package/lang/translations/az.po +16 -0
- package/lang/translations/bg.po +16 -0
- package/lang/translations/bn.po +16 -0
- package/lang/translations/ca.po +16 -0
- package/lang/translations/cs.po +16 -0
- package/lang/translations/da.po +16 -0
- package/lang/translations/de-ch.po +16 -0
- package/lang/translations/de.po +16 -0
- package/lang/translations/el.po +16 -0
- package/lang/translations/en-au.po +16 -0
- package/lang/translations/en-gb.po +16 -0
- package/lang/translations/en.po +16 -0
- package/lang/translations/eo.po +16 -0
- package/lang/translations/es.po +16 -0
- package/lang/translations/et.po +16 -0
- package/lang/translations/eu.po +16 -0
- package/lang/translations/fa.po +16 -0
- package/lang/translations/fi.po +16 -0
- package/lang/translations/fr.po +16 -0
- package/lang/translations/gl.po +16 -0
- package/lang/translations/he.po +16 -0
- package/lang/translations/hi.po +16 -0
- package/lang/translations/hr.po +16 -0
- package/lang/translations/hu.po +16 -0
- package/lang/translations/id.po +16 -0
- package/lang/translations/it.po +16 -0
- package/lang/translations/ja.po +16 -0
- package/lang/translations/km.po +16 -0
- package/lang/translations/kn.po +16 -0
- package/lang/translations/ko.po +16 -0
- package/lang/translations/ku.po +16 -0
- package/lang/translations/lt.po +16 -0
- package/lang/translations/lv.po +16 -0
- package/lang/translations/ms.po +16 -0
- package/lang/translations/nb.po +16 -0
- package/lang/translations/ne.po +16 -0
- package/lang/translations/nl.po +16 -0
- package/lang/translations/no.po +16 -0
- package/lang/translations/pl.po +16 -0
- package/lang/translations/pt-br.po +16 -0
- package/lang/translations/pt.po +16 -0
- package/lang/translations/ro.po +16 -0
- package/lang/translations/ru.po +16 -0
- package/lang/translations/sk.po +16 -0
- package/lang/translations/sl.po +16 -0
- package/lang/translations/sq.po +16 -0
- package/lang/translations/sr-latn.po +16 -0
- package/lang/translations/sr.po +16 -0
- package/lang/translations/sv.po +16 -0
- package/lang/translations/th.po +16 -0
- package/lang/translations/tk.po +16 -0
- package/lang/translations/tr.po +16 -0
- package/lang/translations/tt.po +16 -0
- package/lang/translations/ug.po +16 -0
- package/lang/translations/uk.po +16 -0
- package/lang/translations/ur.po +16 -0
- package/lang/translations/uz.po +16 -0
- package/lang/translations/vi.po +16 -0
- package/lang/translations/zh-cn.po +16 -0
- package/lang/translations/zh.po +16 -0
- package/package.json +3 -3
- package/src/augmentation.d.ts +86 -86
- package/src/augmentation.js +5 -5
- package/src/autocomplete/autocompleteview.d.ts +81 -0
- package/src/autocomplete/autocompleteview.js +146 -0
- package/src/bindings/addkeyboardhandlingforgrid.d.ts +27 -27
- package/src/bindings/addkeyboardhandlingforgrid.js +107 -107
- package/src/bindings/clickoutsidehandler.d.ts +28 -28
- package/src/bindings/clickoutsidehandler.js +36 -36
- package/src/bindings/csstransitiondisablermixin.d.ts +40 -40
- package/src/bindings/csstransitiondisablermixin.js +55 -55
- package/src/bindings/injectcsstransitiondisabler.d.ts +59 -59
- package/src/bindings/injectcsstransitiondisabler.js +71 -71
- package/src/bindings/preventdefault.d.ts +33 -33
- package/src/bindings/preventdefault.js +34 -34
- package/src/bindings/submithandler.d.ts +57 -57
- package/src/bindings/submithandler.js +47 -47
- package/src/button/button.d.ts +178 -178
- package/src/button/button.js +5 -5
- package/src/button/buttonlabel.d.ts +34 -0
- package/src/button/buttonlabel.js +5 -0
- package/src/button/buttonlabelview.d.ts +31 -0
- package/src/button/buttonlabelview.js +42 -0
- package/src/button/buttonview.d.ts +185 -177
- package/src/button/buttonview.js +219 -231
- package/src/button/switchbuttonview.d.ts +45 -45
- package/src/button/switchbuttonview.js +75 -75
- package/src/colorgrid/colorgridview.d.ts +132 -132
- package/src/colorgrid/colorgridview.js +124 -124
- package/src/colorgrid/colortileview.d.ts +28 -28
- package/src/colorgrid/colortileview.js +40 -40
- package/src/colorgrid/utils.d.ts +47 -47
- package/src/colorgrid/utils.js +84 -84
- package/src/colorpicker/colorpickerview.d.ts +137 -137
- package/src/colorpicker/colorpickerview.js +270 -270
- package/src/colorpicker/utils.d.ts +43 -43
- package/src/colorpicker/utils.js +99 -99
- package/src/colorselector/colorgridsfragmentview.d.ts +194 -194
- package/src/colorselector/colorgridsfragmentview.js +289 -289
- package/src/colorselector/colorpickerfragmentview.d.ts +128 -128
- package/src/colorselector/colorpickerfragmentview.js +205 -205
- package/src/colorselector/colorselectorview.d.ts +242 -242
- package/src/colorselector/colorselectorview.js +256 -256
- package/src/colorselector/documentcolorcollection.d.ts +70 -70
- package/src/colorselector/documentcolorcollection.js +42 -42
- package/src/componentfactory.d.ts +81 -81
- package/src/componentfactory.js +104 -104
- package/src/dropdown/button/dropdownbutton.d.ts +25 -25
- package/src/dropdown/button/dropdownbutton.js +5 -5
- package/src/dropdown/button/dropdownbuttonview.d.ts +48 -48
- package/src/dropdown/button/dropdownbuttonview.js +66 -66
- package/src/dropdown/button/splitbuttonview.d.ts +161 -161
- package/src/dropdown/button/splitbuttonview.js +152 -152
- package/src/dropdown/dropdownpanelfocusable.d.ts +21 -21
- package/src/dropdown/dropdownpanelfocusable.js +5 -5
- package/src/dropdown/dropdownpanelview.d.ts +62 -62
- package/src/dropdown/dropdownpanelview.js +97 -97
- package/src/dropdown/dropdownview.d.ts +315 -315
- package/src/dropdown/dropdownview.js +379 -378
- package/src/dropdown/utils.d.ts +235 -221
- package/src/dropdown/utils.js +458 -437
- package/src/editableui/editableuiview.d.ts +72 -72
- package/src/editableui/editableuiview.js +112 -112
- package/src/editableui/inline/inlineeditableuiview.d.ts +40 -40
- package/src/editableui/inline/inlineeditableuiview.js +48 -48
- package/src/editorui/bodycollection.d.ts +55 -55
- package/src/editorui/bodycollection.js +84 -84
- package/src/editorui/boxed/boxededitoruiview.d.ts +40 -40
- package/src/editorui/boxed/boxededitoruiview.js +81 -81
- package/src/editorui/editorui.d.ts +282 -282
- package/src/editorui/editorui.js +410 -410
- package/src/editorui/editoruiview.d.ts +39 -39
- package/src/editorui/editoruiview.js +38 -38
- package/src/editorui/poweredby.d.ts +71 -71
- package/src/editorui/poweredby.js +276 -299
- package/src/focuscycler.d.ts +226 -183
- package/src/focuscycler.js +245 -220
- package/src/formheader/formheaderview.d.ts +59 -53
- package/src/formheader/formheaderview.js +69 -63
- package/src/highlightedtext/highlightedtextview.d.ts +38 -0
- package/src/highlightedtext/highlightedtextview.js +102 -0
- package/src/icon/iconview.d.ts +85 -78
- package/src/icon/iconview.js +114 -112
- package/src/iframe/iframeview.d.ts +50 -50
- package/src/iframe/iframeview.js +63 -63
- package/src/index.d.ts +73 -63
- package/src/index.js +70 -62
- package/src/input/inputbase.d.ts +107 -0
- package/src/input/inputbase.js +110 -0
- package/src/input/inputview.d.ts +36 -121
- package/src/input/inputview.js +24 -106
- package/src/inputnumber/inputnumberview.d.ts +49 -49
- package/src/inputnumber/inputnumberview.js +40 -40
- package/src/inputtext/inputtextview.d.ts +18 -18
- package/src/inputtext/inputtextview.js +27 -27
- package/src/label/labelview.d.ts +36 -36
- package/src/label/labelview.js +41 -41
- package/src/labeledfield/labeledfieldview.d.ts +187 -182
- package/src/labeledfield/labeledfieldview.js +157 -157
- package/src/labeledfield/utils.d.ts +123 -93
- package/src/labeledfield/utils.js +176 -131
- package/src/labeledinput/labeledinputview.d.ts +125 -125
- package/src/labeledinput/labeledinputview.js +125 -125
- package/src/list/listitemgroupview.d.ts +51 -0
- package/src/list/listitemgroupview.js +75 -0
- package/src/list/listitemview.d.ts +36 -35
- package/src/list/listitemview.js +42 -40
- package/src/list/listseparatorview.d.ts +18 -18
- package/src/list/listseparatorview.js +28 -28
- package/src/list/listview.d.ts +122 -65
- package/src/list/listview.js +187 -90
- package/src/model.d.ts +22 -22
- package/src/model.js +31 -31
- package/src/notification/notification.d.ts +211 -211
- package/src/notification/notification.js +187 -187
- package/src/panel/balloon/balloonpanelview.d.ts +685 -685
- package/src/panel/balloon/balloonpanelview.js +1010 -988
- package/src/panel/balloon/contextualballoon.d.ts +299 -299
- package/src/panel/balloon/contextualballoon.js +572 -572
- package/src/panel/sticky/stickypanelview.d.ts +156 -158
- package/src/panel/sticky/stickypanelview.js +234 -231
- package/src/search/filteredview.d.ts +31 -0
- package/src/search/filteredview.js +5 -0
- package/src/search/searchinfoview.d.ts +45 -0
- package/src/search/searchinfoview.js +59 -0
- package/src/search/searchresultsview.d.ts +54 -0
- package/src/search/searchresultsview.js +65 -0
- package/src/search/text/searchtextqueryview.d.ts +76 -0
- package/src/search/text/searchtextqueryview.js +75 -0
- package/src/search/text/searchtextview.d.ts +219 -0
- package/src/search/text/searchtextview.js +201 -0
- package/src/spinner/spinnerview.d.ts +25 -0
- package/src/spinner/spinnerview.js +38 -0
- package/src/template.d.ts +942 -942
- package/src/template.js +1294 -1294
- package/src/textarea/textareaview.d.ts +88 -0
- package/src/textarea/textareaview.js +140 -0
- package/src/toolbar/balloon/balloontoolbar.d.ts +122 -122
- package/src/toolbar/balloon/balloontoolbar.js +300 -300
- package/src/toolbar/block/blockbuttonview.d.ts +35 -35
- package/src/toolbar/block/blockbuttonview.js +41 -41
- package/src/toolbar/block/blocktoolbar.d.ts +161 -161
- package/src/toolbar/block/blocktoolbar.js +395 -391
- package/src/toolbar/normalizetoolbarconfig.d.ts +40 -39
- package/src/toolbar/normalizetoolbarconfig.js +51 -51
- package/src/toolbar/toolbarlinebreakview.d.ts +18 -18
- package/src/toolbar/toolbarlinebreakview.js +28 -28
- package/src/toolbar/toolbarseparatorview.d.ts +18 -18
- package/src/toolbar/toolbarseparatorview.js +28 -28
- package/src/toolbar/toolbarview.d.ts +266 -265
- package/src/toolbar/toolbarview.js +719 -717
- package/src/tooltipmanager.d.ts +180 -180
- package/src/tooltipmanager.js +353 -353
- package/src/view.d.ts +422 -422
- package/src/view.js +396 -396
- package/src/viewcollection.d.ts +139 -139
- package/src/viewcollection.js +206 -206
- package/theme/components/autocomplete/autocomplete.css +22 -0
- package/theme/components/formheader/formheader.css +8 -0
- package/theme/components/highlightedtext/highlightedtext.css +12 -0
- package/theme/components/search/search.css +43 -0
- package/theme/components/spinner/spinner.css +23 -0
- 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
|
+
};
|