@ckeditor/ckeditor5-image 40.0.0 → 40.2.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 +25 -25
- package/LICENSE.md +3 -3
- package/build/image.js +2 -2
- package/build/translations/ar.js +1 -1
- package/build/translations/ast.js +1 -1
- package/build/translations/az.js +1 -1
- package/build/translations/bg.js +1 -1
- package/build/translations/bn.js +1 -1
- package/build/translations/bs.js +1 -1
- package/build/translations/ca.js +1 -1
- package/build/translations/cs.js +1 -1
- package/build/translations/da.js +1 -1
- package/build/translations/de-ch.js +1 -1
- package/build/translations/de.js +1 -1
- package/build/translations/el.js +1 -1
- package/build/translations/en-au.js +1 -1
- package/build/translations/en-gb.js +1 -1
- package/build/translations/eo.js +1 -1
- package/build/translations/es.js +1 -1
- package/build/translations/et.js +1 -1
- package/build/translations/eu.js +1 -1
- package/build/translations/fa.js +1 -1
- package/build/translations/fi.js +1 -1
- package/build/translations/fr.js +1 -1
- package/build/translations/gl.js +1 -1
- package/build/translations/he.js +1 -1
- package/build/translations/hi.js +1 -1
- package/build/translations/hr.js +1 -1
- package/build/translations/hu.js +1 -1
- package/build/translations/id.js +1 -1
- package/build/translations/it.js +1 -1
- package/build/translations/ja.js +1 -1
- package/build/translations/jv.js +1 -1
- package/build/translations/km.js +1 -1
- package/build/translations/kn.js +1 -1
- package/build/translations/ko.js +1 -1
- package/build/translations/ku.js +1 -1
- package/build/translations/lt.js +1 -1
- package/build/translations/lv.js +1 -1
- package/build/translations/ms.js +1 -1
- package/build/translations/nb.js +1 -1
- package/build/translations/ne.js +1 -1
- package/build/translations/nl.js +1 -1
- package/build/translations/no.js +1 -1
- package/build/translations/pl.js +1 -1
- package/build/translations/pt-br.js +1 -1
- package/build/translations/pt.js +1 -1
- package/build/translations/ro.js +1 -1
- package/build/translations/ru.js +1 -1
- package/build/translations/si.js +1 -1
- package/build/translations/sk.js +1 -1
- package/build/translations/sq.js +1 -1
- package/build/translations/sr-latn.js +1 -1
- package/build/translations/sr.js +1 -1
- package/build/translations/sv.js +1 -1
- package/build/translations/th.js +1 -1
- package/build/translations/tk.js +1 -1
- package/build/translations/tr.js +1 -1
- package/build/translations/tt.js +1 -1
- package/build/translations/ug.js +1 -1
- package/build/translations/uk.js +1 -1
- package/build/translations/ur.js +1 -1
- package/build/translations/uz.js +1 -1
- package/build/translations/vi.js +1 -1
- package/build/translations/zh-cn.js +1 -1
- package/build/translations/zh.js +1 -1
- package/ckeditor5-metadata.json +3 -3
- package/lang/contexts.json +5 -0
- package/lang/translations/ar.po +20 -0
- package/lang/translations/ast.po +20 -0
- package/lang/translations/az.po +20 -0
- package/lang/translations/bg.po +20 -0
- package/lang/translations/bn.po +20 -0
- package/lang/translations/bs.po +20 -0
- package/lang/translations/ca.po +20 -0
- package/lang/translations/cs.po +20 -0
- package/lang/translations/da.po +20 -0
- package/lang/translations/de-ch.po +20 -0
- package/lang/translations/de.po +20 -0
- package/lang/translations/el.po +20 -0
- package/lang/translations/en-au.po +20 -0
- package/lang/translations/en-gb.po +20 -0
- package/lang/translations/en.po +20 -0
- package/lang/translations/eo.po +20 -0
- package/lang/translations/es.po +20 -0
- package/lang/translations/et.po +20 -0
- package/lang/translations/eu.po +20 -0
- package/lang/translations/fa.po +20 -0
- package/lang/translations/fi.po +20 -0
- package/lang/translations/fr.po +20 -0
- package/lang/translations/gl.po +20 -0
- package/lang/translations/he.po +20 -0
- package/lang/translations/hi.po +20 -0
- package/lang/translations/hr.po +20 -0
- package/lang/translations/hu.po +20 -0
- package/lang/translations/id.po +20 -0
- package/lang/translations/it.po +20 -0
- package/lang/translations/ja.po +20 -0
- package/lang/translations/jv.po +20 -0
- package/lang/translations/km.po +20 -0
- package/lang/translations/kn.po +20 -0
- package/lang/translations/ko.po +20 -0
- package/lang/translations/ku.po +20 -0
- package/lang/translations/lt.po +20 -0
- package/lang/translations/lv.po +20 -0
- package/lang/translations/ms.po +20 -0
- package/lang/translations/nb.po +20 -0
- package/lang/translations/ne.po +20 -0
- package/lang/translations/nl.po +20 -0
- package/lang/translations/no.po +20 -0
- package/lang/translations/pl.po +20 -0
- package/lang/translations/pt-br.po +20 -0
- package/lang/translations/pt.po +20 -0
- package/lang/translations/ro.po +20 -0
- package/lang/translations/ru.po +20 -0
- package/lang/translations/si.po +20 -0
- package/lang/translations/sk.po +20 -0
- package/lang/translations/sq.po +20 -0
- package/lang/translations/sr-latn.po +20 -0
- package/lang/translations/sr.po +20 -0
- package/lang/translations/sv.po +20 -0
- package/lang/translations/th.po +20 -0
- package/lang/translations/tk.po +20 -0
- package/lang/translations/tr.po +20 -0
- package/lang/translations/tt.po +20 -0
- package/lang/translations/ug.po +21 -1
- package/lang/translations/uk.po +20 -0
- package/lang/translations/ur.po +20 -0
- package/lang/translations/uz.po +20 -0
- package/lang/translations/vi.po +20 -0
- package/lang/translations/zh-cn.po +20 -0
- package/lang/translations/zh.po +20 -0
- package/package.json +3 -3
- package/src/augmentation.d.ts +56 -56
- 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 -232
- package/src/image/imageblockediting.d.ts +59 -58
- package/src/image/imageblockediting.js +153 -152
- package/src/image/imageediting.d.ts +30 -30
- package/src/image/imageediting.js +63 -63
- package/src/image/imageinlineediting.d.ts +60 -59
- package/src/image/imageinlineediting.js +177 -176
- package/src/image/imageloadobserver.d.ts +48 -48
- package/src/image/imageloadobserver.js +52 -52
- package/src/image/imageplaceholder.d.ts +39 -0
- package/src/image/imageplaceholder.js +113 -0
- package/src/image/imagetypecommand.d.ts +44 -44
- package/src/image/imagetypecommand.js +80 -80
- package/src/image/insertimagecommand.d.ts +66 -66
- package/src/image/insertimagecommand.js +120 -120
- package/src/image/replaceimagesourcecommand.d.ts +51 -34
- package/src/image/replaceimagesourcecommand.js +75 -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 -64
- package/src/image/utils.js +121 -121
- package/src/image.d.ts +34 -34
- package/src/image.js +38 -38
- package/src/imageblock.d.ts +34 -33
- package/src/imageblock.js +38 -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 +712 -713
- package/src/imageconfig.js +5 -5
- package/src/imageinline.d.ts +34 -33
- package/src/imageinline.js +38 -37
- package/src/imageinsert/imageinsertui.d.ts +72 -44
- package/src/imageinsert/imageinsertui.js +174 -141
- package/src/imageinsert/imageinsertviaurlui.d.ts +44 -0
- package/src/imageinsert/imageinsertviaurlui.js +122 -0
- package/src/imageinsert/ui/imageinsertformview.d.ts +56 -0
- package/src/imageinsert/ui/imageinsertformview.js +112 -0
- package/src/imageinsert/ui/imageinserturlview.d.ts +107 -0
- package/src/imageinsert/ui/imageinserturlview.js +156 -0
- package/src/imageinsert.d.ts +33 -33
- package/src/imageinsert.js +37 -37
- package/src/imageinsertviaurl.d.ts +31 -30
- package/src/imageinsertviaurl.js +35 -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 -165
- package/src/imageresize/imageresizehandles.d.ts +31 -31
- package/src/imageresize/imageresizehandles.js +114 -114
- package/src/imageresize/resizeimagecommand.d.ts +42 -42
- package/src/imageresize/resizeimagecommand.js +63 -63
- package/src/imageresize.d.ts +27 -27
- package/src/imageresize.js +31 -31
- package/src/imagesizeattributes.d.ts +34 -34
- package/src/imagesizeattributes.js +142 -143
- package/src/imagestyle/converters.d.ts +24 -24
- package/src/imagestyle/converters.js +79 -79
- package/src/imagestyle/imagestylecommand.d.ts +68 -68
- package/src/imagestyle/imagestylecommand.js +107 -107
- 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 +90 -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 -337
- 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 +81 -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 -125
- package/src/imageutils.js +306 -306
- package/src/index.d.ts +48 -48
- package/src/index.js +39 -39
- package/src/pictureediting.d.ts +88 -88
- package/src/pictureediting.js +130 -130
- package/theme/imageinsert.css +5 -17
- package/theme/imageplaceholder.css +10 -0
- package/build/image.js.map +0 -1
- package/src/imageinsert/ui/imageinsertformrowview.d.ts +0 -61
- package/src/imageinsert/ui/imageinsertformrowview.js +0 -54
- package/src/imageinsert/ui/imageinsertpanelview.d.ts +0 -106
- package/src/imageinsert/ui/imageinsertpanelview.js +0 -161
- package/src/imageinsert/utils.d.ts +0 -25
- package/src/imageinsert/utils.js +0 -58
- package/theme/imageinsertformrowview.css +0 -36
package/src/imageconfig.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
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
|
-
export {};
|
|
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
|
+
export {};
|
package/src/imageinline.d.ts
CHANGED
|
@@ -1,33 +1,34 @@
|
|
|
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/imageinline
|
|
7
|
-
*/
|
|
8
|
-
import { Plugin } from 'ckeditor5/src/core';
|
|
9
|
-
import { Widget } from 'ckeditor5/src/widget';
|
|
10
|
-
import ImageTextAlternative from './imagetextalternative';
|
|
11
|
-
import ImageInlineEditing from './image/imageinlineediting';
|
|
12
|
-
import '
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
*
|
|
16
|
-
*
|
|
17
|
-
*
|
|
18
|
-
*
|
|
19
|
-
* * {@link module:image/
|
|
20
|
-
*
|
|
21
|
-
*
|
|
22
|
-
*
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
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/imageinline
|
|
7
|
+
*/
|
|
8
|
+
import { Plugin } from 'ckeditor5/src/core';
|
|
9
|
+
import { Widget } from 'ckeditor5/src/widget';
|
|
10
|
+
import ImageTextAlternative from './imagetextalternative';
|
|
11
|
+
import ImageInlineEditing from './image/imageinlineediting';
|
|
12
|
+
import ImageInsertUI from './imageinsert/imageinsertui';
|
|
13
|
+
import '../theme/image.css';
|
|
14
|
+
/**
|
|
15
|
+
* The image inline plugin.
|
|
16
|
+
*
|
|
17
|
+
* This is a "glue" plugin which loads the following plugins:
|
|
18
|
+
*
|
|
19
|
+
* * {@link module:image/image/imageinlineediting~ImageInlineEditing},
|
|
20
|
+
* * {@link module:image/imagetextalternative~ImageTextAlternative}.
|
|
21
|
+
*
|
|
22
|
+
* Usually, it is used in conjunction with other plugins from this package. See the {@glink api/image package page}
|
|
23
|
+
* for more information.
|
|
24
|
+
*/
|
|
25
|
+
export default class ImageInline extends Plugin {
|
|
26
|
+
/**
|
|
27
|
+
* @inheritDoc
|
|
28
|
+
*/
|
|
29
|
+
static get requires(): readonly [typeof ImageInlineEditing, typeof Widget, typeof ImageTextAlternative, typeof ImageInsertUI];
|
|
30
|
+
/**
|
|
31
|
+
* @inheritDoc
|
|
32
|
+
*/
|
|
33
|
+
static get pluginName(): "ImageInline";
|
|
34
|
+
}
|
package/src/imageinline.js
CHANGED
|
@@ -1,37 +1,38 @@
|
|
|
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/imageinline
|
|
7
|
-
*/
|
|
8
|
-
import { Plugin } from 'ckeditor5/src/core';
|
|
9
|
-
import { Widget } from 'ckeditor5/src/widget';
|
|
10
|
-
import ImageTextAlternative from './imagetextalternative';
|
|
11
|
-
import ImageInlineEditing from './image/imageinlineediting';
|
|
12
|
-
import '
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
*
|
|
16
|
-
*
|
|
17
|
-
*
|
|
18
|
-
*
|
|
19
|
-
* * {@link module:image/
|
|
20
|
-
*
|
|
21
|
-
*
|
|
22
|
-
*
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
}
|
|
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/imageinline
|
|
7
|
+
*/
|
|
8
|
+
import { Plugin } from 'ckeditor5/src/core';
|
|
9
|
+
import { Widget } from 'ckeditor5/src/widget';
|
|
10
|
+
import ImageTextAlternative from './imagetextalternative';
|
|
11
|
+
import ImageInlineEditing from './image/imageinlineediting';
|
|
12
|
+
import ImageInsertUI from './imageinsert/imageinsertui';
|
|
13
|
+
import '../theme/image.css';
|
|
14
|
+
/**
|
|
15
|
+
* The image inline plugin.
|
|
16
|
+
*
|
|
17
|
+
* This is a "glue" plugin which loads the following plugins:
|
|
18
|
+
*
|
|
19
|
+
* * {@link module:image/image/imageinlineediting~ImageInlineEditing},
|
|
20
|
+
* * {@link module:image/imagetextalternative~ImageTextAlternative}.
|
|
21
|
+
*
|
|
22
|
+
* Usually, it is used in conjunction with other plugins from this package. See the {@glink api/image package page}
|
|
23
|
+
* for more information.
|
|
24
|
+
*/
|
|
25
|
+
export default class ImageInline extends Plugin {
|
|
26
|
+
/**
|
|
27
|
+
* @inheritDoc
|
|
28
|
+
*/
|
|
29
|
+
static get requires() {
|
|
30
|
+
return [ImageInlineEditing, Widget, ImageTextAlternative, ImageInsertUI];
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* @inheritDoc
|
|
34
|
+
*/
|
|
35
|
+
static get pluginName() {
|
|
36
|
+
return 'ImageInline';
|
|
37
|
+
}
|
|
38
|
+
}
|
|
@@ -1,44 +1,72 @@
|
|
|
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/imageinsert/imageinsertui
|
|
7
|
-
*/
|
|
8
|
-
import { Plugin } from 'ckeditor5/src/core';
|
|
9
|
-
import { type
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
*
|
|
14
|
-
*
|
|
15
|
-
*
|
|
16
|
-
*
|
|
17
|
-
*
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
*
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
*
|
|
42
|
-
*/
|
|
43
|
-
private
|
|
44
|
-
|
|
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/imageinsert/imageinsertui
|
|
7
|
+
*/
|
|
8
|
+
import { Plugin, type Editor } from 'ckeditor5/src/core';
|
|
9
|
+
import { type Observable } from 'ckeditor5/src/utils';
|
|
10
|
+
import { type ButtonView, type DropdownView, type FocusableView } from 'ckeditor5/src/ui';
|
|
11
|
+
import ImageUtils from '../imageutils';
|
|
12
|
+
/**
|
|
13
|
+
* The image insert dropdown plugin.
|
|
14
|
+
*
|
|
15
|
+
* For a detailed overview, check the {@glink features/images/image-upload/image-upload Image upload feature}
|
|
16
|
+
* and {@glink features/images/images-inserting Insert images via source URL} documentation.
|
|
17
|
+
*
|
|
18
|
+
* Adds the `'insertImage'` dropdown to the {@link module:ui/componentfactory~ComponentFactory UI component factory}
|
|
19
|
+
* and also the `imageInsert` dropdown as an alias for backward compatibility.
|
|
20
|
+
*/
|
|
21
|
+
export default class ImageInsertUI extends Plugin {
|
|
22
|
+
/**
|
|
23
|
+
* @inheritDoc
|
|
24
|
+
*/
|
|
25
|
+
static get pluginName(): "ImageInsertUI";
|
|
26
|
+
/**
|
|
27
|
+
* @inheritDoc
|
|
28
|
+
*/
|
|
29
|
+
static get requires(): readonly [typeof ImageUtils];
|
|
30
|
+
/**
|
|
31
|
+
* The dropdown view responsible for displaying the image insert UI.
|
|
32
|
+
*/
|
|
33
|
+
dropdownView?: DropdownView;
|
|
34
|
+
/**
|
|
35
|
+
* Observable property used to alter labels while some image is selected and when it is not.
|
|
36
|
+
*
|
|
37
|
+
* @observable
|
|
38
|
+
*/
|
|
39
|
+
isImageSelected: boolean;
|
|
40
|
+
/**
|
|
41
|
+
* Registered integrations map.
|
|
42
|
+
*/
|
|
43
|
+
private _integrations;
|
|
44
|
+
/**
|
|
45
|
+
* @inheritDoc
|
|
46
|
+
*/
|
|
47
|
+
constructor(editor: Editor);
|
|
48
|
+
/**
|
|
49
|
+
* @inheritDoc
|
|
50
|
+
*/
|
|
51
|
+
init(): void;
|
|
52
|
+
/**
|
|
53
|
+
* Registers the insert image dropdown integration.
|
|
54
|
+
*/
|
|
55
|
+
registerIntegration({ name, observable, buttonViewCreator, formViewCreator, requiresForm }: {
|
|
56
|
+
name: string;
|
|
57
|
+
observable: Observable & {
|
|
58
|
+
isEnabled: boolean;
|
|
59
|
+
};
|
|
60
|
+
buttonViewCreator: (isOnlyOne: boolean) => ButtonView;
|
|
61
|
+
formViewCreator: (isOnlyOne: boolean) => FocusableView;
|
|
62
|
+
requiresForm?: boolean;
|
|
63
|
+
}): void;
|
|
64
|
+
/**
|
|
65
|
+
* Creates the toolbar component.
|
|
66
|
+
*/
|
|
67
|
+
private _createToolbarComponent;
|
|
68
|
+
/**
|
|
69
|
+
* Validates the integrations list.
|
|
70
|
+
*/
|
|
71
|
+
private _prepareIntegrations;
|
|
72
|
+
}
|
|
@@ -1,141 +1,174 @@
|
|
|
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/imageinsert/imageinsertui
|
|
7
|
-
*/
|
|
8
|
-
import { Plugin
|
|
9
|
-
import {
|
|
10
|
-
import
|
|
11
|
-
import
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
*
|
|
15
|
-
*
|
|
16
|
-
*
|
|
17
|
-
*
|
|
18
|
-
*
|
|
19
|
-
*
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
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/imageinsert/imageinsertui
|
|
7
|
+
*/
|
|
8
|
+
import { Plugin } from 'ckeditor5/src/core';
|
|
9
|
+
import { logWarning } from 'ckeditor5/src/utils';
|
|
10
|
+
import { createDropdown, SplitButtonView } from 'ckeditor5/src/ui';
|
|
11
|
+
import ImageInsertFormView from './ui/imageinsertformview';
|
|
12
|
+
import ImageUtils from '../imageutils';
|
|
13
|
+
/**
|
|
14
|
+
* The image insert dropdown plugin.
|
|
15
|
+
*
|
|
16
|
+
* For a detailed overview, check the {@glink features/images/image-upload/image-upload Image upload feature}
|
|
17
|
+
* and {@glink features/images/images-inserting Insert images via source URL} documentation.
|
|
18
|
+
*
|
|
19
|
+
* Adds the `'insertImage'` dropdown to the {@link module:ui/componentfactory~ComponentFactory UI component factory}
|
|
20
|
+
* and also the `imageInsert` dropdown as an alias for backward compatibility.
|
|
21
|
+
*/
|
|
22
|
+
export default class ImageInsertUI extends Plugin {
|
|
23
|
+
/**
|
|
24
|
+
* @inheritDoc
|
|
25
|
+
*/
|
|
26
|
+
static get pluginName() {
|
|
27
|
+
return 'ImageInsertUI';
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* @inheritDoc
|
|
31
|
+
*/
|
|
32
|
+
static get requires() {
|
|
33
|
+
return [ImageUtils];
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* @inheritDoc
|
|
37
|
+
*/
|
|
38
|
+
constructor(editor) {
|
|
39
|
+
super(editor);
|
|
40
|
+
/**
|
|
41
|
+
* Registered integrations map.
|
|
42
|
+
*/
|
|
43
|
+
this._integrations = new Map();
|
|
44
|
+
editor.config.define('image.insert.integrations', [
|
|
45
|
+
'upload',
|
|
46
|
+
'assetManager',
|
|
47
|
+
'url'
|
|
48
|
+
]);
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* @inheritDoc
|
|
52
|
+
*/
|
|
53
|
+
init() {
|
|
54
|
+
const editor = this.editor;
|
|
55
|
+
const selection = editor.model.document.selection;
|
|
56
|
+
const imageUtils = editor.plugins.get('ImageUtils');
|
|
57
|
+
this.set('isImageSelected', false);
|
|
58
|
+
this.listenTo(editor.model.document, 'change', () => {
|
|
59
|
+
this.isImageSelected = imageUtils.isImage(selection.getSelectedElement());
|
|
60
|
+
});
|
|
61
|
+
const componentCreator = (locale) => this._createToolbarComponent(locale);
|
|
62
|
+
// Register `insertImage` dropdown and add `imageInsert` dropdown as an alias for backward compatibility.
|
|
63
|
+
editor.ui.componentFactory.add('insertImage', componentCreator);
|
|
64
|
+
editor.ui.componentFactory.add('imageInsert', componentCreator);
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Registers the insert image dropdown integration.
|
|
68
|
+
*/
|
|
69
|
+
registerIntegration({ name, observable, buttonViewCreator, formViewCreator, requiresForm }) {
|
|
70
|
+
if (this._integrations.has(name)) {
|
|
71
|
+
/**
|
|
72
|
+
* There are two insert-image integrations registered with the same name.
|
|
73
|
+
*
|
|
74
|
+
* Make sure that you do not load multiple asset manager plugins.
|
|
75
|
+
*
|
|
76
|
+
* @error image-insert-integration-exists
|
|
77
|
+
*/
|
|
78
|
+
logWarning('image-insert-integration-exists', { name });
|
|
79
|
+
}
|
|
80
|
+
this._integrations.set(name, {
|
|
81
|
+
observable,
|
|
82
|
+
buttonViewCreator,
|
|
83
|
+
formViewCreator,
|
|
84
|
+
requiresForm: !!requiresForm
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Creates the toolbar component.
|
|
89
|
+
*/
|
|
90
|
+
_createToolbarComponent(locale) {
|
|
91
|
+
const editor = this.editor;
|
|
92
|
+
const t = locale.t;
|
|
93
|
+
const integrations = this._prepareIntegrations();
|
|
94
|
+
if (!integrations.length) {
|
|
95
|
+
return null;
|
|
96
|
+
}
|
|
97
|
+
let dropdownButton;
|
|
98
|
+
const firstIntegration = integrations[0];
|
|
99
|
+
if (integrations.length == 1) {
|
|
100
|
+
// Do not use dropdown for a single integration button (integration that does not require form view).
|
|
101
|
+
if (!firstIntegration.requiresForm) {
|
|
102
|
+
return firstIntegration.buttonViewCreator(true);
|
|
103
|
+
}
|
|
104
|
+
dropdownButton = firstIntegration.buttonViewCreator(true);
|
|
105
|
+
}
|
|
106
|
+
else {
|
|
107
|
+
const actionButton = firstIntegration.buttonViewCreator(false);
|
|
108
|
+
dropdownButton = new SplitButtonView(locale, actionButton);
|
|
109
|
+
dropdownButton.tooltip = true;
|
|
110
|
+
dropdownButton.bind('label').to(this, 'isImageSelected', isImageSelected => isImageSelected ?
|
|
111
|
+
t('Replace image') :
|
|
112
|
+
t('Insert image'));
|
|
113
|
+
}
|
|
114
|
+
const dropdownView = this.dropdownView = createDropdown(locale, dropdownButton);
|
|
115
|
+
const observables = integrations.map(({ observable }) => observable);
|
|
116
|
+
dropdownView.bind('isEnabled').toMany(observables, 'isEnabled', (...isEnabled) => (isEnabled.some(isEnabled => isEnabled)));
|
|
117
|
+
dropdownView.once('change:isOpen', () => {
|
|
118
|
+
const integrationViews = integrations.map(({ formViewCreator }) => formViewCreator(integrations.length == 1));
|
|
119
|
+
const imageInsertFormView = new ImageInsertFormView(editor.locale, integrationViews);
|
|
120
|
+
dropdownView.panelView.children.add(imageInsertFormView);
|
|
121
|
+
});
|
|
122
|
+
return dropdownView;
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* Validates the integrations list.
|
|
126
|
+
*/
|
|
127
|
+
_prepareIntegrations() {
|
|
128
|
+
const editor = this.editor;
|
|
129
|
+
const items = editor.config.get('image.insert.integrations');
|
|
130
|
+
const result = [];
|
|
131
|
+
if (!items.length) {
|
|
132
|
+
/**
|
|
133
|
+
* The insert image feature requires a list of integrations to be provided in the editor configuration.
|
|
134
|
+
*
|
|
135
|
+
* The default list of integrations is `upload`, `assetManager`, `url`. Those integrations are included
|
|
136
|
+
* in the insert image dropdown if the given feature plugin is loaded. You should omit the `integrations`
|
|
137
|
+
* configuration key to use the default set or provide a selected list of integrations that should be used.
|
|
138
|
+
*
|
|
139
|
+
* @error image-insert-integrations-not-specified
|
|
140
|
+
*/
|
|
141
|
+
logWarning('image-insert-integrations-not-specified');
|
|
142
|
+
return result;
|
|
143
|
+
}
|
|
144
|
+
for (const item of items) {
|
|
145
|
+
if (!this._integrations.has(item)) {
|
|
146
|
+
if (!['upload', 'assetManager', 'url'].includes(item)) {
|
|
147
|
+
/**
|
|
148
|
+
* The specified insert image integration name is unknown or the providing plugin is not loaded in the editor.
|
|
149
|
+
*
|
|
150
|
+
* @error image-insert-unknown-integration
|
|
151
|
+
*/
|
|
152
|
+
logWarning('image-insert-unknown-integration', { item });
|
|
153
|
+
}
|
|
154
|
+
continue;
|
|
155
|
+
}
|
|
156
|
+
result.push(this._integrations.get(item));
|
|
157
|
+
}
|
|
158
|
+
if (!result.length) {
|
|
159
|
+
/**
|
|
160
|
+
* The image insert feature requires integrations to be registered by separate features.
|
|
161
|
+
*
|
|
162
|
+
* The `insertImage` toolbar button requires integrations to be registered by other features.
|
|
163
|
+
* For example {@link module:image/imageupload~ImageUpload ImageUpload},
|
|
164
|
+
* {@link module:image/imageinsert~ImageInsert ImageInsert},
|
|
165
|
+
* {@link module:image/imageinsertviaurl~ImageInsertViaUrl ImageInsertViaUrl},
|
|
166
|
+
* {@link module:ckbox/ckbox~CKBox CKBox}
|
|
167
|
+
*
|
|
168
|
+
* @error image-insert-integrations-not-registered
|
|
169
|
+
*/
|
|
170
|
+
logWarning('image-insert-integrations-not-registered');
|
|
171
|
+
}
|
|
172
|
+
return result;
|
|
173
|
+
}
|
|
174
|
+
}
|
|
@@ -0,0 +1,44 @@
|
|
|
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/imageinsert/imageinsertviaurlui
|
|
7
|
+
*/
|
|
8
|
+
import { Plugin } from 'ckeditor5/src/core';
|
|
9
|
+
import ImageInsertUI from './imageinsertui';
|
|
10
|
+
/**
|
|
11
|
+
* The image insert via URL plugin (UI part).
|
|
12
|
+
*
|
|
13
|
+
* For a detailed overview, check the {@glink features/images/images-inserting
|
|
14
|
+
* Insert images via source URL} documentation.
|
|
15
|
+
*
|
|
16
|
+
* This plugin registers the {@link module:image/imageinsert/imageinsertui~ImageInsertUI} integration for `url`.
|
|
17
|
+
*/
|
|
18
|
+
export default class ImageInsertViaUrlUI extends Plugin {
|
|
19
|
+
private _imageInsertUI;
|
|
20
|
+
/**
|
|
21
|
+
* @inheritDoc
|
|
22
|
+
*/
|
|
23
|
+
static get pluginName(): "ImageInsertViaUrlUI";
|
|
24
|
+
/**
|
|
25
|
+
* @inheritDoc
|
|
26
|
+
*/
|
|
27
|
+
static get requires(): readonly [typeof ImageInsertUI];
|
|
28
|
+
/**
|
|
29
|
+
* @inheritDoc
|
|
30
|
+
*/
|
|
31
|
+
init(): void;
|
|
32
|
+
/**
|
|
33
|
+
* Creates the view displayed in the dropdown.
|
|
34
|
+
*/
|
|
35
|
+
private _createInsertUrlView;
|
|
36
|
+
/**
|
|
37
|
+
* Creates the toolbar button.
|
|
38
|
+
*/
|
|
39
|
+
private _createInsertUrlButton;
|
|
40
|
+
/**
|
|
41
|
+
* Closes the dropdown.
|
|
42
|
+
*/
|
|
43
|
+
private _closePanel;
|
|
44
|
+
}
|