@ckeditor/ckeditor5-image 36.0.0 → 37.0.0-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (106) hide show
  1. package/build/image.js +1 -1
  2. package/package.json +40 -35
  3. package/src/autoimage.d.ts +53 -0
  4. package/src/autoimage.js +111 -160
  5. package/src/image/converters.d.ts +66 -0
  6. package/src/image/converters.js +200 -261
  7. package/src/image/imageblockediting.d.ts +57 -0
  8. package/src/image/imageblockediting.js +111 -155
  9. package/src/image/imageediting.d.ts +34 -0
  10. package/src/image/imageediting.js +53 -67
  11. package/src/image/imageinlineediting.d.ts +53 -0
  12. package/src/image/imageinlineediting.js +135 -180
  13. package/src/image/imageloadobserver.d.ts +44 -0
  14. package/src/image/imageloadobserver.js +28 -47
  15. package/src/image/imagetypecommand.d.ts +46 -0
  16. package/src/image/imagetypecommand.js +67 -95
  17. package/src/image/insertimagecommand.d.ts +72 -0
  18. package/src/image/insertimagecommand.js +95 -101
  19. package/src/image/replaceimagesourcecommand.d.ts +39 -0
  20. package/src/image/replaceimagesourcecommand.js +28 -33
  21. package/src/image/ui/utils.d.ts +25 -0
  22. package/src/image/ui/utils.js +25 -35
  23. package/src/image/utils.d.ts +52 -0
  24. package/src/image/utils.js +63 -90
  25. package/src/image.d.ts +38 -0
  26. package/src/image.js +13 -43
  27. package/src/imageblock.d.ts +35 -0
  28. package/src/imageblock.js +12 -21
  29. package/src/imagecaption/imagecaptionediting.d.ts +92 -0
  30. package/src/imagecaption/imagecaptionediting.js +203 -262
  31. package/src/imagecaption/imagecaptionui.d.ts +30 -0
  32. package/src/imagecaption/imagecaptionui.js +46 -63
  33. package/src/imagecaption/imagecaptionutils.d.ts +42 -0
  34. package/src/imagecaption/imagecaptionutils.js +51 -78
  35. package/src/imagecaption/toggleimagecaptioncommand.d.ts +71 -0
  36. package/src/imagecaption/toggleimagecaptioncommand.js +112 -138
  37. package/src/imagecaption.d.ts +29 -0
  38. package/src/imagecaption.js +12 -19
  39. package/src/imageconfig.d.ts +723 -0
  40. package/src/imageconfig.js +5 -0
  41. package/src/imageinline.d.ts +35 -0
  42. package/src/imageinline.js +12 -21
  43. package/src/imageinsert/imageinsertui.d.ts +49 -0
  44. package/src/imageinsert/imageinsertui.js +120 -158
  45. package/src/imageinsert/ui/imageinsertformrowview.d.ts +61 -0
  46. package/src/imageinsert/ui/imageinsertformrowview.js +37 -86
  47. package/src/imageinsert/ui/imageinsertpanelview.d.ts +106 -0
  48. package/src/imageinsert/ui/imageinsertpanelview.js +148 -258
  49. package/src/imageinsert/utils.d.ts +26 -0
  50. package/src/imageinsert/utils.js +42 -58
  51. package/src/imageinsert.d.ts +35 -0
  52. package/src/imageinsert.js +13 -84
  53. package/src/imageinsertviaurl.d.ts +34 -0
  54. package/src/imageinsertviaurl.js +12 -18
  55. package/src/imageresize/imageresizebuttons.d.ts +66 -0
  56. package/src/imageresize/imageresizebuttons.js +190 -255
  57. package/src/imageresize/imageresizeediting.d.ts +42 -0
  58. package/src/imageresize/imageresizeediting.js +100 -125
  59. package/src/imageresize/imageresizehandles.d.ts +30 -0
  60. package/src/imageresize/imageresizehandles.js +91 -123
  61. package/src/imageresize/resizeimagecommand.d.ts +47 -0
  62. package/src/imageresize/resizeimagecommand.js +48 -55
  63. package/src/imageresize.d.ts +29 -0
  64. package/src/imageresize.js +12 -209
  65. package/src/imagestyle/converters.d.ts +24 -0
  66. package/src/imagestyle/converters.js +60 -78
  67. package/src/imagestyle/imagestylecommand.d.ts +70 -0
  68. package/src/imagestyle/imagestylecommand.js +88 -124
  69. package/src/imagestyle/imagestyleediting.d.ts +54 -0
  70. package/src/imagestyle/imagestyleediting.js +90 -137
  71. package/src/imagestyle/imagestyleui.d.ts +60 -0
  72. package/src/imagestyle/imagestyleui.js +169 -277
  73. package/src/imagestyle/utils.d.ts +61 -0
  74. package/src/imagestyle/utils.js +253 -306
  75. package/src/imagestyle.d.ts +35 -0
  76. package/src/imagestyle.js +13 -261
  77. package/src/imagetextalternative/imagetextalternativecommand.d.ts +39 -0
  78. package/src/imagetextalternative/imagetextalternativecommand.js +31 -47
  79. package/src/imagetextalternative/imagetextalternativeediting.d.ts +32 -0
  80. package/src/imagetextalternative/imagetextalternativeediting.js +18 -25
  81. package/src/imagetextalternative/imagetextalternativeui.d.ts +72 -0
  82. package/src/imagetextalternative/imagetextalternativeui.js +156 -219
  83. package/src/imagetextalternative/ui/textalternativeformview.d.ts +72 -0
  84. package/src/imagetextalternative/ui/textalternativeformview.js +103 -192
  85. package/src/imagetextalternative.d.ts +32 -0
  86. package/src/imagetextalternative.js +12 -18
  87. package/src/imagetoolbar.d.ts +38 -0
  88. package/src/imagetoolbar.js +31 -77
  89. package/src/imageupload/imageuploadediting.d.ts +114 -0
  90. package/src/imageupload/imageuploadediting.js +308 -427
  91. package/src/imageupload/imageuploadprogress.d.ts +47 -0
  92. package/src/imageupload/imageuploadprogress.js +180 -261
  93. package/src/imageupload/imageuploadui.d.ts +29 -0
  94. package/src/imageupload/imageuploadui.js +41 -57
  95. package/src/imageupload/uploadimagecommand.d.ts +65 -0
  96. package/src/imageupload/uploadimagecommand.js +73 -87
  97. package/src/imageupload/utils.d.ts +33 -0
  98. package/src/imageupload/utils.js +87 -112
  99. package/src/imageupload.d.ts +34 -0
  100. package/src/imageupload.js +12 -61
  101. package/src/imageutils.d.ts +108 -0
  102. package/src/imageutils.js +233 -329
  103. package/src/index.d.ts +31 -0
  104. package/src/index.js +0 -2
  105. package/src/pictureediting.d.ts +86 -0
  106. package/src/pictureediting.js +101 -120
@@ -0,0 +1,114 @@
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/imageupload/imageuploadediting
7
+ */
8
+ import { Plugin, type PluginDependencies, type Editor } from 'ckeditor5/src/core';
9
+ import { type Element, type Writer, type DataTransfer } from 'ckeditor5/src/engine';
10
+ import { type UploadResponse, type FileLoader } from 'ckeditor5/src/upload';
11
+ import '../imageconfig';
12
+ /**
13
+ * The editing part of the image upload feature. It registers the `'uploadImage'` command
14
+ * and the `imageUpload` command as an aliased name.
15
+ *
16
+ * When an image is uploaded, it fires the {@link ~ImageUploadEditing#event:uploadComplete `uploadComplete`} event
17
+ * that allows adding custom attributes to the {@link module:engine/model/element~Element image element}.
18
+ */
19
+ export default class ImageUploadEditing extends Plugin {
20
+ /**
21
+ * @inheritDoc
22
+ */
23
+ static get requires(): PluginDependencies;
24
+ static get pluginName(): 'ImageUploadEditing';
25
+ /**
26
+ * An internal mapping of {@link module:upload/filerepository~FileLoader#id file loader UIDs} and
27
+ * model elements during the upload.
28
+ *
29
+ * Model element of the uploaded image can change, for instance, when {@link module:image/image/imagetypecommand~ImageTypeCommand}
30
+ * is executed as a result of adding caption or changing image style. As a result, the upload logic must keep track of the model
31
+ * element (reference) and resolve the upload for the correct model element (instead of the one that landed in the `$graveyard`
32
+ * after image type changed).
33
+ */
34
+ private readonly _uploadImageElements;
35
+ /**
36
+ * @inheritDoc
37
+ */
38
+ constructor(editor: Editor);
39
+ /**
40
+ * @inheritDoc
41
+ */
42
+ init(): void;
43
+ /**
44
+ * @inheritDoc
45
+ */
46
+ afterInit(): void;
47
+ /**
48
+ * Reads and uploads an image.
49
+ *
50
+ * The image is read from the disk and as a Base64-encoded string it is set temporarily to
51
+ * `image[src]`. When the image is successfully uploaded, the temporary data is replaced with the target
52
+ * image's URL (the URL to the uploaded image on the server).
53
+ */
54
+ protected _readAndUpload(loader: FileLoader): Promise<void>;
55
+ /**
56
+ * Creates the `srcset` attribute based on a given file upload response and sets it as an attribute to a specific image element.
57
+ *
58
+ * @param data Data object from which `srcset` will be created.
59
+ * @param image The image element on which the `srcset` attribute will be set.
60
+ */
61
+ protected _parseAndSetSrcsetAttributeOnImage(data: Record<string, unknown>, image: Element, writer: Writer): void;
62
+ }
63
+ /**
64
+ * Returns `true` if non-empty `text/html` is included in the data transfer.
65
+ */
66
+ export declare function isHtmlIncluded(dataTransfer: DataTransfer): boolean;
67
+ declare module '@ckeditor/ckeditor5-core' {
68
+ interface PluginsMap {
69
+ [ImageUploadEditing.pluginName]: ImageUploadEditing;
70
+ }
71
+ }
72
+ /**
73
+ * An event fired when an image is uploaded. You can hook into this event to provide
74
+ * custom attributes to the {@link module:engine/model/element~Element image element} based on the data from
75
+ * the server.
76
+ *
77
+ * ```ts
78
+ * const imageUploadEditing = editor.plugins.get( 'ImageUploadEditing' );
79
+ *
80
+ * imageUploadEditing.on( 'uploadComplete', ( evt, { data, imageElement } ) => {
81
+ * editor.model.change( writer => {
82
+ * writer.setAttribute( 'someAttribute', 'foo', imageElement );
83
+ * } );
84
+ * } );
85
+ * ```
86
+ *
87
+ * You can also stop the default handler that sets the `src` and `srcset` attributes
88
+ * if you want to provide custom values for these attributes.
89
+ *
90
+ * ```ts
91
+ * imageUploadEditing.on( 'uploadComplete', ( evt, { data, imageElement } ) => {
92
+ * evt.stop();
93
+ * } );
94
+ * ```
95
+ *
96
+ * **Note**: This event is fired by the {@link module:image/imageupload/imageuploadediting~ImageUploadEditing} plugin.
97
+ *
98
+ * @eventName uploadComplete
99
+ * @param data The `uploadComplete` event data.
100
+ */
101
+ export type ImageUploadCompleteEvent = {
102
+ name: 'uploadComplete';
103
+ args: [data: ImageUploadCompleteData];
104
+ };
105
+ export type ImageUploadCompleteData = {
106
+ /**
107
+ * The data coming from the upload adapter.
108
+ */
109
+ data: UploadResponse;
110
+ /**
111
+ * The model {@link module:engine/model/element~Element image element} that can be customized.
112
+ */
113
+ imageElement: Element;
114
+ };