@ckeditor/ckeditor5-image 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.
- package/CHANGELOG.md +1 -1
- package/LICENSE.md +1 -1
- package/README.md +3 -3
- package/build/image.js +1 -1
- package/build/image.js.map +1 -0
- package/build/translations/pt-br.js +1 -1
- package/ckeditor5-metadata.json +12 -0
- package/lang/translations/ar.po +1 -0
- package/lang/translations/ast.po +1 -0
- package/lang/translations/az.po +1 -0
- package/lang/translations/bg.po +1 -0
- package/lang/translations/bn.po +1 -0
- package/lang/translations/bs.po +1 -0
- package/lang/translations/ca.po +1 -0
- package/lang/translations/cs.po +1 -0
- package/lang/translations/da.po +1 -0
- package/lang/translations/de-ch.po +1 -0
- package/lang/translations/de.po +1 -0
- package/lang/translations/el.po +1 -0
- package/lang/translations/en-au.po +1 -0
- package/lang/translations/en-gb.po +1 -0
- package/lang/translations/en.po +1 -0
- package/lang/translations/eo.po +1 -0
- package/lang/translations/es.po +1 -0
- package/lang/translations/et.po +1 -0
- package/lang/translations/eu.po +1 -0
- package/lang/translations/fa.po +1 -0
- package/lang/translations/fi.po +1 -0
- package/lang/translations/fr.po +1 -0
- package/lang/translations/gl.po +1 -0
- package/lang/translations/he.po +1 -0
- package/lang/translations/hi.po +1 -0
- package/lang/translations/hr.po +1 -0
- package/lang/translations/hu.po +1 -0
- package/lang/translations/id.po +1 -0
- package/lang/translations/it.po +1 -0
- package/lang/translations/ja.po +1 -0
- package/lang/translations/jv.po +1 -0
- package/lang/translations/km.po +1 -0
- package/lang/translations/kn.po +1 -0
- package/lang/translations/ko.po +1 -0
- package/lang/translations/ku.po +1 -0
- package/lang/translations/lt.po +1 -0
- package/lang/translations/lv.po +1 -0
- package/lang/translations/ms.po +1 -0
- package/lang/translations/nb.po +1 -0
- package/lang/translations/ne.po +1 -0
- package/lang/translations/nl.po +1 -0
- package/lang/translations/no.po +1 -0
- package/lang/translations/pl.po +1 -0
- package/lang/translations/pt-br.po +2 -1
- package/lang/translations/pt.po +1 -0
- package/lang/translations/ro.po +1 -0
- package/lang/translations/ru.po +1 -0
- package/lang/translations/si.po +1 -0
- package/lang/translations/sk.po +1 -0
- package/lang/translations/sq.po +1 -0
- package/lang/translations/sr-latn.po +1 -0
- package/lang/translations/sr.po +1 -0
- package/lang/translations/sv.po +1 -0
- package/lang/translations/th.po +1 -0
- package/lang/translations/tk.po +1 -0
- package/lang/translations/tr.po +1 -0
- package/lang/translations/tt.po +1 -0
- package/lang/translations/ug.po +1 -0
- package/lang/translations/uk.po +1 -0
- package/lang/translations/ur.po +1 -0
- package/lang/translations/uz.po +1 -0
- package/lang/translations/vi.po +1 -0
- package/lang/translations/zh-cn.po +1 -0
- package/lang/translations/zh.po +1 -0
- package/package.json +3 -7
- package/src/augmentation.d.ts +56 -55
- package/src/augmentation.js +5 -5
- package/src/autoimage.d.ts +52 -52
- package/src/autoimage.js +132 -132
- package/src/image/converters.d.ts +66 -66
- package/src/image/converters.js +232 -242
- package/src/image/imageblockediting.d.ts +58 -55
- package/src/image/imageblockediting.js +152 -136
- package/src/image/imageediting.d.ts +30 -30
- package/src/image/imageediting.js +63 -74
- package/src/image/imageinlineediting.d.ts +59 -56
- package/src/image/imageinlineediting.js +176 -160
- package/src/image/imageloadobserver.d.ts +48 -48
- package/src/image/imageloadobserver.js +52 -52
- package/src/image/imagetypecommand.d.ts +44 -40
- package/src/image/imagetypecommand.js +80 -77
- package/src/image/insertimagecommand.d.ts +66 -66
- package/src/image/insertimagecommand.js +120 -120
- package/src/image/replaceimagesourcecommand.d.ts +34 -34
- package/src/image/replaceimagesourcecommand.js +44 -44
- package/src/image/ui/utils.d.ts +25 -25
- package/src/image/ui/utils.js +44 -44
- package/src/image/utils.d.ts +64 -52
- package/src/image/utils.js +121 -100
- package/src/image.d.ts +34 -34
- package/src/image.js +38 -38
- package/src/imageblock.d.ts +33 -33
- package/src/imageblock.js +37 -37
- package/src/imagecaption/imagecaptionediting.d.ts +89 -89
- package/src/imagecaption/imagecaptionediting.js +225 -225
- package/src/imagecaption/imagecaptionui.d.ts +26 -26
- package/src/imagecaption/imagecaptionui.js +61 -61
- package/src/imagecaption/imagecaptionutils.d.ts +38 -38
- package/src/imagecaption/imagecaptionutils.js +62 -62
- package/src/imagecaption/toggleimagecaptioncommand.d.ts +66 -66
- package/src/imagecaption/toggleimagecaptioncommand.js +138 -138
- package/src/imagecaption.d.ts +26 -26
- package/src/imagecaption.js +30 -30
- package/src/imageconfig.d.ts +713 -713
- package/src/imageconfig.js +5 -5
- package/src/imageinline.d.ts +33 -33
- package/src/imageinline.js +37 -37
- package/src/imageinsert/imageinsertui.d.ts +44 -44
- package/src/imageinsert/imageinsertui.js +141 -141
- package/src/imageinsert/ui/imageinsertformrowview.d.ts +61 -61
- package/src/imageinsert/ui/imageinsertformrowview.js +54 -54
- package/src/imageinsert/ui/imageinsertpanelview.d.ts +106 -106
- package/src/imageinsert/ui/imageinsertpanelview.js +161 -161
- package/src/imageinsert/utils.d.ts +25 -25
- package/src/imageinsert/utils.js +58 -58
- package/src/imageinsert.d.ts +33 -33
- package/src/imageinsert.js +37 -37
- package/src/imageinsertviaurl.d.ts +30 -30
- package/src/imageinsertviaurl.js +34 -34
- package/src/imageresize/imageresizebuttons.d.ts +67 -67
- package/src/imageresize/imageresizebuttons.js +217 -217
- package/src/imageresize/imageresizeediting.d.ts +37 -37
- package/src/imageresize/imageresizeediting.js +165 -114
- package/src/imageresize/imageresizehandles.d.ts +31 -30
- package/src/imageresize/imageresizehandles.js +114 -107
- package/src/imageresize/resizeimagecommand.d.ts +42 -42
- package/src/imageresize/resizeimagecommand.js +63 -61
- package/src/imageresize.d.ts +27 -27
- package/src/imageresize.js +31 -31
- package/src/imagesizeattributes.d.ts +34 -0
- package/src/imagesizeattributes.js +143 -0
- package/src/imagestyle/converters.d.ts +24 -24
- package/src/imagestyle/converters.js +79 -79
- package/src/imagestyle/imagestylecommand.d.ts +68 -65
- package/src/imagestyle/imagestylecommand.js +107 -101
- package/src/imagestyle/imagestyleediting.d.ts +50 -50
- package/src/imagestyle/imagestyleediting.js +108 -108
- package/src/imagestyle/imagestyleui.d.ts +56 -56
- package/src/imagestyle/imagestyleui.js +192 -192
- package/src/imagestyle/utils.d.ts +101 -101
- package/src/imagestyle/utils.js +329 -329
- package/src/imagestyle.d.ts +32 -32
- package/src/imagestyle.js +36 -36
- package/src/imagetextalternative/imagetextalternativecommand.d.ts +34 -34
- package/src/imagetextalternative/imagetextalternativecommand.js +44 -44
- package/src/imagetextalternative/imagetextalternativeediting.d.ts +28 -28
- package/src/imagetextalternative/imagetextalternativeediting.js +35 -35
- package/src/imagetextalternative/imagetextalternativeui.d.ts +68 -68
- package/src/imagetextalternative/imagetextalternativeui.js +173 -173
- package/src/imagetextalternative/ui/textalternativeformview.d.ts +72 -72
- package/src/imagetextalternative/ui/textalternativeformview.js +121 -121
- package/src/imagetextalternative.d.ts +29 -29
- package/src/imagetextalternative.js +33 -33
- package/src/imagetoolbar.d.ts +35 -35
- package/src/imagetoolbar.js +57 -57
- package/src/imageupload/imageuploadediting.d.ts +111 -111
- package/src/imageupload/imageuploadediting.js +337 -335
- package/src/imageupload/imageuploadprogress.d.ts +42 -42
- package/src/imageupload/imageuploadprogress.js +211 -211
- package/src/imageupload/imageuploadui.d.ts +23 -23
- package/src/imageupload/imageuploadui.js +57 -57
- package/src/imageupload/uploadimagecommand.d.ts +60 -60
- package/src/imageupload/uploadimagecommand.js +100 -100
- package/src/imageupload/utils.d.ts +33 -33
- package/src/imageupload/utils.js +112 -112
- package/src/imageupload.d.ts +32 -32
- package/src/imageupload.js +36 -36
- package/src/imageutils.d.ts +125 -102
- package/src/imageutils.js +306 -248
- package/src/index.d.ts +48 -47
- package/src/index.js +39 -38
- package/src/pictureediting.d.ts +88 -88
- package/src/pictureediting.js +130 -130
- package/theme/image.css +38 -11
- package/theme/imageresize.css +5 -0
|
@@ -1,121 +1,121 @@
|
|
|
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 image/imagetextalternative/ui/textalternativeformview
|
|
7
|
-
*/
|
|
8
|
-
import { ButtonView, FocusCycler, LabeledFieldView, View, ViewCollection, createLabeledInputText, submitHandler } from 'ckeditor5/src/ui';
|
|
9
|
-
import { FocusTracker, KeystrokeHandler } from 'ckeditor5/src/utils';
|
|
10
|
-
import { icons } from 'ckeditor5/src/core';
|
|
11
|
-
import '../../../theme/textalternativeform.css';
|
|
12
|
-
// See: #8833.
|
|
13
|
-
// eslint-disable-next-line ckeditor5-rules/ckeditor-imports
|
|
14
|
-
import '@ckeditor/ckeditor5-ui/theme/components/responsive-form/responsiveform.css';
|
|
15
|
-
/**
|
|
16
|
-
* The TextAlternativeFormView class.
|
|
17
|
-
*/
|
|
18
|
-
export default class TextAlternativeFormView extends View {
|
|
19
|
-
/**
|
|
20
|
-
* @inheritDoc
|
|
21
|
-
*/
|
|
22
|
-
constructor(locale) {
|
|
23
|
-
super(locale);
|
|
24
|
-
const t = this.locale.t;
|
|
25
|
-
this.focusTracker = new FocusTracker();
|
|
26
|
-
this.keystrokes = new KeystrokeHandler();
|
|
27
|
-
this.labeledInput = this._createLabeledInputView();
|
|
28
|
-
this.saveButtonView = this._createButton(t('Save'), icons.check, 'ck-button-save');
|
|
29
|
-
this.saveButtonView.type = 'submit';
|
|
30
|
-
this.cancelButtonView = this._createButton(t('Cancel'), icons.cancel, 'ck-button-cancel', 'cancel');
|
|
31
|
-
this._focusables = new ViewCollection();
|
|
32
|
-
this._focusCycler = new FocusCycler({
|
|
33
|
-
focusables: this._focusables,
|
|
34
|
-
focusTracker: this.focusTracker,
|
|
35
|
-
keystrokeHandler: this.keystrokes,
|
|
36
|
-
actions: {
|
|
37
|
-
// Navigate form fields backwards using the Shift + Tab keystroke.
|
|
38
|
-
focusPrevious: 'shift + tab',
|
|
39
|
-
// Navigate form fields forwards using the Tab key.
|
|
40
|
-
focusNext: 'tab'
|
|
41
|
-
}
|
|
42
|
-
});
|
|
43
|
-
this.setTemplate({
|
|
44
|
-
tag: 'form',
|
|
45
|
-
attributes: {
|
|
46
|
-
class: [
|
|
47
|
-
'ck',
|
|
48
|
-
'ck-text-alternative-form',
|
|
49
|
-
'ck-responsive-form'
|
|
50
|
-
],
|
|
51
|
-
// https://github.com/ckeditor/ckeditor5-image/issues/40
|
|
52
|
-
tabindex: '-1'
|
|
53
|
-
},
|
|
54
|
-
children: [
|
|
55
|
-
this.labeledInput,
|
|
56
|
-
this.saveButtonView,
|
|
57
|
-
this.cancelButtonView
|
|
58
|
-
]
|
|
59
|
-
});
|
|
60
|
-
}
|
|
61
|
-
/**
|
|
62
|
-
* @inheritDoc
|
|
63
|
-
*/
|
|
64
|
-
render() {
|
|
65
|
-
super.render();
|
|
66
|
-
this.keystrokes.listenTo(this.element);
|
|
67
|
-
submitHandler({ view: this });
|
|
68
|
-
[this.labeledInput, this.saveButtonView, this.cancelButtonView]
|
|
69
|
-
.forEach(v => {
|
|
70
|
-
// Register the view as focusable.
|
|
71
|
-
this._focusables.add(v);
|
|
72
|
-
// Register the view in the focus tracker.
|
|
73
|
-
this.focusTracker.add(v.element);
|
|
74
|
-
});
|
|
75
|
-
}
|
|
76
|
-
/**
|
|
77
|
-
* @inheritDoc
|
|
78
|
-
*/
|
|
79
|
-
destroy() {
|
|
80
|
-
super.destroy();
|
|
81
|
-
this.focusTracker.destroy();
|
|
82
|
-
this.keystrokes.destroy();
|
|
83
|
-
}
|
|
84
|
-
/**
|
|
85
|
-
* Creates the button view.
|
|
86
|
-
*
|
|
87
|
-
* @param label The button label
|
|
88
|
-
* @param icon The button's icon.
|
|
89
|
-
* @param className The additional button CSS class name.
|
|
90
|
-
* @param eventName The event name that the ButtonView#execute event will be delegated to.
|
|
91
|
-
* @returns The button view instance.
|
|
92
|
-
*/
|
|
93
|
-
_createButton(label, icon, className, eventName) {
|
|
94
|
-
const button = new ButtonView(this.locale);
|
|
95
|
-
button.set({
|
|
96
|
-
label,
|
|
97
|
-
icon,
|
|
98
|
-
tooltip: true
|
|
99
|
-
});
|
|
100
|
-
button.extendTemplate({
|
|
101
|
-
attributes: {
|
|
102
|
-
class: className
|
|
103
|
-
}
|
|
104
|
-
});
|
|
105
|
-
if (eventName) {
|
|
106
|
-
button.delegate('execute').to(this, eventName);
|
|
107
|
-
}
|
|
108
|
-
return button;
|
|
109
|
-
}
|
|
110
|
-
/**
|
|
111
|
-
* Creates an input with a label.
|
|
112
|
-
*
|
|
113
|
-
* @returns Labeled field view instance.
|
|
114
|
-
*/
|
|
115
|
-
_createLabeledInputView() {
|
|
116
|
-
const t = this.locale.t;
|
|
117
|
-
const labeledInput = new LabeledFieldView(this.locale, createLabeledInputText);
|
|
118
|
-
labeledInput.label = t('Text alternative');
|
|
119
|
-
return labeledInput;
|
|
120
|
-
}
|
|
121
|
-
}
|
|
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 image/imagetextalternative/ui/textalternativeformview
|
|
7
|
+
*/
|
|
8
|
+
import { ButtonView, FocusCycler, LabeledFieldView, View, ViewCollection, createLabeledInputText, submitHandler } from 'ckeditor5/src/ui';
|
|
9
|
+
import { FocusTracker, KeystrokeHandler } from 'ckeditor5/src/utils';
|
|
10
|
+
import { icons } from 'ckeditor5/src/core';
|
|
11
|
+
import '../../../theme/textalternativeform.css';
|
|
12
|
+
// See: #8833.
|
|
13
|
+
// eslint-disable-next-line ckeditor5-rules/ckeditor-imports
|
|
14
|
+
import '@ckeditor/ckeditor5-ui/theme/components/responsive-form/responsiveform.css';
|
|
15
|
+
/**
|
|
16
|
+
* The TextAlternativeFormView class.
|
|
17
|
+
*/
|
|
18
|
+
export default class TextAlternativeFormView extends View {
|
|
19
|
+
/**
|
|
20
|
+
* @inheritDoc
|
|
21
|
+
*/
|
|
22
|
+
constructor(locale) {
|
|
23
|
+
super(locale);
|
|
24
|
+
const t = this.locale.t;
|
|
25
|
+
this.focusTracker = new FocusTracker();
|
|
26
|
+
this.keystrokes = new KeystrokeHandler();
|
|
27
|
+
this.labeledInput = this._createLabeledInputView();
|
|
28
|
+
this.saveButtonView = this._createButton(t('Save'), icons.check, 'ck-button-save');
|
|
29
|
+
this.saveButtonView.type = 'submit';
|
|
30
|
+
this.cancelButtonView = this._createButton(t('Cancel'), icons.cancel, 'ck-button-cancel', 'cancel');
|
|
31
|
+
this._focusables = new ViewCollection();
|
|
32
|
+
this._focusCycler = new FocusCycler({
|
|
33
|
+
focusables: this._focusables,
|
|
34
|
+
focusTracker: this.focusTracker,
|
|
35
|
+
keystrokeHandler: this.keystrokes,
|
|
36
|
+
actions: {
|
|
37
|
+
// Navigate form fields backwards using the Shift + Tab keystroke.
|
|
38
|
+
focusPrevious: 'shift + tab',
|
|
39
|
+
// Navigate form fields forwards using the Tab key.
|
|
40
|
+
focusNext: 'tab'
|
|
41
|
+
}
|
|
42
|
+
});
|
|
43
|
+
this.setTemplate({
|
|
44
|
+
tag: 'form',
|
|
45
|
+
attributes: {
|
|
46
|
+
class: [
|
|
47
|
+
'ck',
|
|
48
|
+
'ck-text-alternative-form',
|
|
49
|
+
'ck-responsive-form'
|
|
50
|
+
],
|
|
51
|
+
// https://github.com/ckeditor/ckeditor5-image/issues/40
|
|
52
|
+
tabindex: '-1'
|
|
53
|
+
},
|
|
54
|
+
children: [
|
|
55
|
+
this.labeledInput,
|
|
56
|
+
this.saveButtonView,
|
|
57
|
+
this.cancelButtonView
|
|
58
|
+
]
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* @inheritDoc
|
|
63
|
+
*/
|
|
64
|
+
render() {
|
|
65
|
+
super.render();
|
|
66
|
+
this.keystrokes.listenTo(this.element);
|
|
67
|
+
submitHandler({ view: this });
|
|
68
|
+
[this.labeledInput, this.saveButtonView, this.cancelButtonView]
|
|
69
|
+
.forEach(v => {
|
|
70
|
+
// Register the view as focusable.
|
|
71
|
+
this._focusables.add(v);
|
|
72
|
+
// Register the view in the focus tracker.
|
|
73
|
+
this.focusTracker.add(v.element);
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* @inheritDoc
|
|
78
|
+
*/
|
|
79
|
+
destroy() {
|
|
80
|
+
super.destroy();
|
|
81
|
+
this.focusTracker.destroy();
|
|
82
|
+
this.keystrokes.destroy();
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* Creates the button view.
|
|
86
|
+
*
|
|
87
|
+
* @param label The button label
|
|
88
|
+
* @param icon The button's icon.
|
|
89
|
+
* @param className The additional button CSS class name.
|
|
90
|
+
* @param eventName The event name that the ButtonView#execute event will be delegated to.
|
|
91
|
+
* @returns The button view instance.
|
|
92
|
+
*/
|
|
93
|
+
_createButton(label, icon, className, eventName) {
|
|
94
|
+
const button = new ButtonView(this.locale);
|
|
95
|
+
button.set({
|
|
96
|
+
label,
|
|
97
|
+
icon,
|
|
98
|
+
tooltip: true
|
|
99
|
+
});
|
|
100
|
+
button.extendTemplate({
|
|
101
|
+
attributes: {
|
|
102
|
+
class: className
|
|
103
|
+
}
|
|
104
|
+
});
|
|
105
|
+
if (eventName) {
|
|
106
|
+
button.delegate('execute').to(this, eventName);
|
|
107
|
+
}
|
|
108
|
+
return button;
|
|
109
|
+
}
|
|
110
|
+
/**
|
|
111
|
+
* Creates an input with a label.
|
|
112
|
+
*
|
|
113
|
+
* @returns Labeled field view instance.
|
|
114
|
+
*/
|
|
115
|
+
_createLabeledInputView() {
|
|
116
|
+
const t = this.locale.t;
|
|
117
|
+
const labeledInput = new LabeledFieldView(this.locale, createLabeledInputText);
|
|
118
|
+
labeledInput.label = t('Text alternative');
|
|
119
|
+
return labeledInput;
|
|
120
|
+
}
|
|
121
|
+
}
|
|
@@ -1,29 +1,29 @@
|
|
|
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 image/imagetextalternative
|
|
7
|
-
*/
|
|
8
|
-
import { Plugin } from 'ckeditor5/src/core';
|
|
9
|
-
import ImageTextAlternativeEditing from './imagetextalternative/imagetextalternativeediting';
|
|
10
|
-
import ImageTextAlternativeUI from './imagetextalternative/imagetextalternativeui';
|
|
11
|
-
/**
|
|
12
|
-
* The image text alternative plugin.
|
|
13
|
-
*
|
|
14
|
-
* For a detailed overview, check the {@glink features/images/images-styles image styles} documentation.
|
|
15
|
-
*
|
|
16
|
-
* This is a "glue" plugin which loads the
|
|
17
|
-
* {@link module:image/imagetextalternative/imagetextalternativeediting~ImageTextAlternativeEditing}
|
|
18
|
-
* and {@link module:image/imagetextalternative/imagetextalternativeui~ImageTextAlternativeUI} plugins.
|
|
19
|
-
*/
|
|
20
|
-
export default class ImageTextAlternative extends Plugin {
|
|
21
|
-
/**
|
|
22
|
-
* @inheritDoc
|
|
23
|
-
*/
|
|
24
|
-
static get requires(): readonly [typeof ImageTextAlternativeEditing, typeof ImageTextAlternativeUI];
|
|
25
|
-
/**
|
|
26
|
-
* @inheritDoc
|
|
27
|
-
*/
|
|
28
|
-
static get pluginName(): "ImageTextAlternative";
|
|
29
|
-
}
|
|
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 image/imagetextalternative
|
|
7
|
+
*/
|
|
8
|
+
import { Plugin } from 'ckeditor5/src/core';
|
|
9
|
+
import ImageTextAlternativeEditing from './imagetextalternative/imagetextalternativeediting';
|
|
10
|
+
import ImageTextAlternativeUI from './imagetextalternative/imagetextalternativeui';
|
|
11
|
+
/**
|
|
12
|
+
* The image text alternative plugin.
|
|
13
|
+
*
|
|
14
|
+
* For a detailed overview, check the {@glink features/images/images-styles image styles} documentation.
|
|
15
|
+
*
|
|
16
|
+
* This is a "glue" plugin which loads the
|
|
17
|
+
* {@link module:image/imagetextalternative/imagetextalternativeediting~ImageTextAlternativeEditing}
|
|
18
|
+
* and {@link module:image/imagetextalternative/imagetextalternativeui~ImageTextAlternativeUI} plugins.
|
|
19
|
+
*/
|
|
20
|
+
export default class ImageTextAlternative extends Plugin {
|
|
21
|
+
/**
|
|
22
|
+
* @inheritDoc
|
|
23
|
+
*/
|
|
24
|
+
static get requires(): readonly [typeof ImageTextAlternativeEditing, typeof ImageTextAlternativeUI];
|
|
25
|
+
/**
|
|
26
|
+
* @inheritDoc
|
|
27
|
+
*/
|
|
28
|
+
static get pluginName(): "ImageTextAlternative";
|
|
29
|
+
}
|
|
@@ -1,33 +1,33 @@
|
|
|
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 image/imagetextalternative
|
|
7
|
-
*/
|
|
8
|
-
import { Plugin } from 'ckeditor5/src/core';
|
|
9
|
-
import ImageTextAlternativeEditing from './imagetextalternative/imagetextalternativeediting';
|
|
10
|
-
import ImageTextAlternativeUI from './imagetextalternative/imagetextalternativeui';
|
|
11
|
-
/**
|
|
12
|
-
* The image text alternative plugin.
|
|
13
|
-
*
|
|
14
|
-
* For a detailed overview, check the {@glink features/images/images-styles image styles} documentation.
|
|
15
|
-
*
|
|
16
|
-
* This is a "glue" plugin which loads the
|
|
17
|
-
* {@link module:image/imagetextalternative/imagetextalternativeediting~ImageTextAlternativeEditing}
|
|
18
|
-
* and {@link module:image/imagetextalternative/imagetextalternativeui~ImageTextAlternativeUI} plugins.
|
|
19
|
-
*/
|
|
20
|
-
export default class ImageTextAlternative extends Plugin {
|
|
21
|
-
/**
|
|
22
|
-
* @inheritDoc
|
|
23
|
-
*/
|
|
24
|
-
static get requires() {
|
|
25
|
-
return [ImageTextAlternativeEditing, ImageTextAlternativeUI];
|
|
26
|
-
}
|
|
27
|
-
/**
|
|
28
|
-
* @inheritDoc
|
|
29
|
-
*/
|
|
30
|
-
static get pluginName() {
|
|
31
|
-
return 'ImageTextAlternative';
|
|
32
|
-
}
|
|
33
|
-
}
|
|
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 image/imagetextalternative
|
|
7
|
+
*/
|
|
8
|
+
import { Plugin } from 'ckeditor5/src/core';
|
|
9
|
+
import ImageTextAlternativeEditing from './imagetextalternative/imagetextalternativeediting';
|
|
10
|
+
import ImageTextAlternativeUI from './imagetextalternative/imagetextalternativeui';
|
|
11
|
+
/**
|
|
12
|
+
* The image text alternative plugin.
|
|
13
|
+
*
|
|
14
|
+
* For a detailed overview, check the {@glink features/images/images-styles image styles} documentation.
|
|
15
|
+
*
|
|
16
|
+
* This is a "glue" plugin which loads the
|
|
17
|
+
* {@link module:image/imagetextalternative/imagetextalternativeediting~ImageTextAlternativeEditing}
|
|
18
|
+
* and {@link module:image/imagetextalternative/imagetextalternativeui~ImageTextAlternativeUI} plugins.
|
|
19
|
+
*/
|
|
20
|
+
export default class ImageTextAlternative extends Plugin {
|
|
21
|
+
/**
|
|
22
|
+
* @inheritDoc
|
|
23
|
+
*/
|
|
24
|
+
static get requires() {
|
|
25
|
+
return [ImageTextAlternativeEditing, ImageTextAlternativeUI];
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* @inheritDoc
|
|
29
|
+
*/
|
|
30
|
+
static get pluginName() {
|
|
31
|
+
return 'ImageTextAlternative';
|
|
32
|
+
}
|
|
33
|
+
}
|
package/src/imagetoolbar.d.ts
CHANGED
|
@@ -1,35 +1,35 @@
|
|
|
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 image/imagetoolbar
|
|
7
|
-
*/
|
|
8
|
-
import { Plugin } from 'ckeditor5/src/core';
|
|
9
|
-
import { WidgetToolbarRepository } from 'ckeditor5/src/widget';
|
|
10
|
-
import ImageUtils from './imageutils';
|
|
11
|
-
/**
|
|
12
|
-
* The image toolbar plugin. It creates and manages the image toolbar (the toolbar displayed when an image is selected).
|
|
13
|
-
*
|
|
14
|
-
* For an overview, check the {@glink features/images/images-overview#image-contextual-toolbar image contextual toolbar} documentation.
|
|
15
|
-
*
|
|
16
|
-
* Instances of toolbar components (e.g. buttons) are created using the editor's
|
|
17
|
-
* {@link module:ui/componentfactory~ComponentFactory component factory}
|
|
18
|
-
* based on the {@link module:image/imageconfig~ImageConfig#toolbar `image.toolbar` configuration option}.
|
|
19
|
-
*
|
|
20
|
-
* The toolbar uses the {@link module:ui/panel/balloon/contextualballoon~ContextualBalloon}.
|
|
21
|
-
*/
|
|
22
|
-
export default class ImageToolbar extends Plugin {
|
|
23
|
-
/**
|
|
24
|
-
* @inheritDoc
|
|
25
|
-
*/
|
|
26
|
-
static get requires(): readonly [typeof WidgetToolbarRepository, typeof ImageUtils];
|
|
27
|
-
/**
|
|
28
|
-
* @inheritDoc
|
|
29
|
-
*/
|
|
30
|
-
static get pluginName(): "ImageToolbar";
|
|
31
|
-
/**
|
|
32
|
-
* @inheritDoc
|
|
33
|
-
*/
|
|
34
|
-
afterInit(): void;
|
|
35
|
-
}
|
|
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 image/imagetoolbar
|
|
7
|
+
*/
|
|
8
|
+
import { Plugin } from 'ckeditor5/src/core';
|
|
9
|
+
import { WidgetToolbarRepository } from 'ckeditor5/src/widget';
|
|
10
|
+
import ImageUtils from './imageutils';
|
|
11
|
+
/**
|
|
12
|
+
* The image toolbar plugin. It creates and manages the image toolbar (the toolbar displayed when an image is selected).
|
|
13
|
+
*
|
|
14
|
+
* For an overview, check the {@glink features/images/images-overview#image-contextual-toolbar image contextual toolbar} documentation.
|
|
15
|
+
*
|
|
16
|
+
* Instances of toolbar components (e.g. buttons) are created using the editor's
|
|
17
|
+
* {@link module:ui/componentfactory~ComponentFactory component factory}
|
|
18
|
+
* based on the {@link module:image/imageconfig~ImageConfig#toolbar `image.toolbar` configuration option}.
|
|
19
|
+
*
|
|
20
|
+
* The toolbar uses the {@link module:ui/panel/balloon/contextualballoon~ContextualBalloon}.
|
|
21
|
+
*/
|
|
22
|
+
export default class ImageToolbar extends Plugin {
|
|
23
|
+
/**
|
|
24
|
+
* @inheritDoc
|
|
25
|
+
*/
|
|
26
|
+
static get requires(): readonly [typeof WidgetToolbarRepository, typeof ImageUtils];
|
|
27
|
+
/**
|
|
28
|
+
* @inheritDoc
|
|
29
|
+
*/
|
|
30
|
+
static get pluginName(): "ImageToolbar";
|
|
31
|
+
/**
|
|
32
|
+
* @inheritDoc
|
|
33
|
+
*/
|
|
34
|
+
afterInit(): void;
|
|
35
|
+
}
|
package/src/imagetoolbar.js
CHANGED
|
@@ -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
|
-
/**
|
|
6
|
-
* @module image/imagetoolbar
|
|
7
|
-
*/
|
|
8
|
-
import { Plugin } from 'ckeditor5/src/core';
|
|
9
|
-
import { WidgetToolbarRepository } from 'ckeditor5/src/widget';
|
|
10
|
-
import ImageUtils from './imageutils';
|
|
11
|
-
import { isObject } from 'lodash-es';
|
|
12
|
-
/**
|
|
13
|
-
* The image toolbar plugin. It creates and manages the image toolbar (the toolbar displayed when an image is selected).
|
|
14
|
-
*
|
|
15
|
-
* For an overview, check the {@glink features/images/images-overview#image-contextual-toolbar image contextual toolbar} documentation.
|
|
16
|
-
*
|
|
17
|
-
* Instances of toolbar components (e.g. buttons) are created using the editor's
|
|
18
|
-
* {@link module:ui/componentfactory~ComponentFactory component factory}
|
|
19
|
-
* based on the {@link module:image/imageconfig~ImageConfig#toolbar `image.toolbar` configuration option}.
|
|
20
|
-
*
|
|
21
|
-
* The toolbar uses the {@link module:ui/panel/balloon/contextualballoon~ContextualBalloon}.
|
|
22
|
-
*/
|
|
23
|
-
export default class ImageToolbar extends Plugin {
|
|
24
|
-
/**
|
|
25
|
-
* @inheritDoc
|
|
26
|
-
*/
|
|
27
|
-
static get requires() {
|
|
28
|
-
return [WidgetToolbarRepository, ImageUtils];
|
|
29
|
-
}
|
|
30
|
-
/**
|
|
31
|
-
* @inheritDoc
|
|
32
|
-
*/
|
|
33
|
-
static get pluginName() {
|
|
34
|
-
return 'ImageToolbar';
|
|
35
|
-
}
|
|
36
|
-
/**
|
|
37
|
-
* @inheritDoc
|
|
38
|
-
*/
|
|
39
|
-
afterInit() {
|
|
40
|
-
const editor = this.editor;
|
|
41
|
-
const t = editor.t;
|
|
42
|
-
const widgetToolbarRepository = editor.plugins.get(WidgetToolbarRepository);
|
|
43
|
-
const imageUtils = editor.plugins.get('ImageUtils');
|
|
44
|
-
widgetToolbarRepository.register('image', {
|
|
45
|
-
ariaLabel: t('Image toolbar'),
|
|
46
|
-
items: normalizeDeclarativeConfig(editor.config.get('image.toolbar') || []),
|
|
47
|
-
getRelatedElement: selection => imageUtils.getClosestSelectedImageWidget(selection)
|
|
48
|
-
});
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
/**
|
|
52
|
-
* Convert the dropdown definitions to their keys registered in the ComponentFactory.
|
|
53
|
-
* The registration precess should be handled by the plugin which handles the UI of a particular feature.
|
|
54
|
-
*/
|
|
55
|
-
function normalizeDeclarativeConfig(config) {
|
|
56
|
-
return config.map(item => isObject(item) ? item.name : item);
|
|
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
|
+
/**
|
|
6
|
+
* @module image/imagetoolbar
|
|
7
|
+
*/
|
|
8
|
+
import { Plugin } from 'ckeditor5/src/core';
|
|
9
|
+
import { WidgetToolbarRepository } from 'ckeditor5/src/widget';
|
|
10
|
+
import ImageUtils from './imageutils';
|
|
11
|
+
import { isObject } from 'lodash-es';
|
|
12
|
+
/**
|
|
13
|
+
* The image toolbar plugin. It creates and manages the image toolbar (the toolbar displayed when an image is selected).
|
|
14
|
+
*
|
|
15
|
+
* For an overview, check the {@glink features/images/images-overview#image-contextual-toolbar image contextual toolbar} documentation.
|
|
16
|
+
*
|
|
17
|
+
* Instances of toolbar components (e.g. buttons) are created using the editor's
|
|
18
|
+
* {@link module:ui/componentfactory~ComponentFactory component factory}
|
|
19
|
+
* based on the {@link module:image/imageconfig~ImageConfig#toolbar `image.toolbar` configuration option}.
|
|
20
|
+
*
|
|
21
|
+
* The toolbar uses the {@link module:ui/panel/balloon/contextualballoon~ContextualBalloon}.
|
|
22
|
+
*/
|
|
23
|
+
export default class ImageToolbar extends Plugin {
|
|
24
|
+
/**
|
|
25
|
+
* @inheritDoc
|
|
26
|
+
*/
|
|
27
|
+
static get requires() {
|
|
28
|
+
return [WidgetToolbarRepository, ImageUtils];
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* @inheritDoc
|
|
32
|
+
*/
|
|
33
|
+
static get pluginName() {
|
|
34
|
+
return 'ImageToolbar';
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* @inheritDoc
|
|
38
|
+
*/
|
|
39
|
+
afterInit() {
|
|
40
|
+
const editor = this.editor;
|
|
41
|
+
const t = editor.t;
|
|
42
|
+
const widgetToolbarRepository = editor.plugins.get(WidgetToolbarRepository);
|
|
43
|
+
const imageUtils = editor.plugins.get('ImageUtils');
|
|
44
|
+
widgetToolbarRepository.register('image', {
|
|
45
|
+
ariaLabel: t('Image toolbar'),
|
|
46
|
+
items: normalizeDeclarativeConfig(editor.config.get('image.toolbar') || []),
|
|
47
|
+
getRelatedElement: selection => imageUtils.getClosestSelectedImageWidget(selection)
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Convert the dropdown definitions to their keys registered in the ComponentFactory.
|
|
53
|
+
* The registration precess should be handled by the plugin which handles the UI of a particular feature.
|
|
54
|
+
*/
|
|
55
|
+
function normalizeDeclarativeConfig(config) {
|
|
56
|
+
return config.map(item => isObject(item) ? item.name : item);
|
|
57
|
+
}
|