@ckeditor/ckeditor5-ckbox 42.0.2 → 43.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.
- package/CHANGELOG.md +1 -1
- package/build/ckbox.js +2 -2
- package/build/translations/ar.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/ca.js +1 -1
- package/build/translations/cs.js +1 -1
- package/build/translations/da.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/es-co.js +1 -1
- package/build/translations/es.js +1 -1
- package/build/translations/et.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/ko.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/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/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/tr.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/dist/ckboxcommand.d.ts +13 -1
- package/dist/ckboxconfig.d.ts +105 -0
- package/dist/ckboxediting.d.ts +7 -4
- package/dist/ckboxutils.d.ts +3 -3
- package/dist/index.js +90 -25
- package/dist/index.js.map +1 -1
- package/dist/translations/ar.js +1 -1
- package/dist/translations/ar.umd.js +1 -1
- package/dist/translations/az.js +1 -1
- package/dist/translations/az.umd.js +1 -1
- package/dist/translations/bg.js +1 -1
- package/dist/translations/bg.umd.js +1 -1
- package/dist/translations/bn.js +1 -1
- package/dist/translations/bn.umd.js +1 -1
- package/dist/translations/ca.js +1 -1
- package/dist/translations/ca.umd.js +1 -1
- package/dist/translations/cs.js +1 -1
- package/dist/translations/cs.umd.js +1 -1
- package/dist/translations/da.js +1 -1
- package/dist/translations/da.umd.js +1 -1
- package/dist/translations/de.js +1 -1
- package/dist/translations/de.umd.js +1 -1
- package/dist/translations/el.js +1 -1
- package/dist/translations/el.umd.js +1 -1
- package/dist/translations/en-au.js +1 -1
- package/dist/translations/en-au.umd.js +1 -1
- package/dist/translations/en.js +1 -1
- package/dist/translations/en.umd.js +1 -1
- package/dist/translations/es-co.js +1 -1
- package/dist/translations/es-co.umd.js +1 -1
- package/dist/translations/es.js +1 -1
- package/dist/translations/es.umd.js +1 -1
- package/dist/translations/et.js +1 -1
- package/dist/translations/et.umd.js +1 -1
- package/dist/translations/fa.js +1 -1
- package/dist/translations/fa.umd.js +1 -1
- package/dist/translations/fi.js +1 -1
- package/dist/translations/fi.umd.js +1 -1
- package/dist/translations/fr.js +1 -1
- package/dist/translations/fr.umd.js +1 -1
- package/dist/translations/gl.js +1 -1
- package/dist/translations/gl.umd.js +1 -1
- package/dist/translations/he.js +1 -1
- package/dist/translations/he.umd.js +1 -1
- package/dist/translations/hi.js +1 -1
- package/dist/translations/hi.umd.js +1 -1
- package/dist/translations/hr.js +1 -1
- package/dist/translations/hr.umd.js +1 -1
- package/dist/translations/hu.js +1 -1
- package/dist/translations/hu.umd.js +1 -1
- package/dist/translations/id.js +1 -1
- package/dist/translations/id.umd.js +1 -1
- package/dist/translations/it.js +1 -1
- package/dist/translations/it.umd.js +1 -1
- package/dist/translations/ja.js +1 -1
- package/dist/translations/ja.umd.js +1 -1
- package/dist/translations/ko.js +1 -1
- package/dist/translations/ko.umd.js +1 -1
- package/dist/translations/lt.js +1 -1
- package/dist/translations/lt.umd.js +1 -1
- package/dist/translations/lv.js +1 -1
- package/dist/translations/lv.umd.js +1 -1
- package/dist/translations/ms.js +1 -1
- package/dist/translations/ms.umd.js +1 -1
- package/dist/translations/nl.js +1 -1
- package/dist/translations/nl.umd.js +1 -1
- package/dist/translations/no.js +1 -1
- package/dist/translations/no.umd.js +1 -1
- package/dist/translations/pl.js +1 -1
- package/dist/translations/pl.umd.js +1 -1
- package/dist/translations/pt-br.js +1 -1
- package/dist/translations/pt-br.umd.js +1 -1
- package/dist/translations/pt.js +1 -1
- package/dist/translations/pt.umd.js +1 -1
- package/dist/translations/ro.js +1 -1
- package/dist/translations/ro.umd.js +1 -1
- package/dist/translations/ru.js +1 -1
- package/dist/translations/ru.umd.js +1 -1
- package/dist/translations/sk.js +1 -1
- package/dist/translations/sk.umd.js +1 -1
- package/dist/translations/sq.js +1 -1
- package/dist/translations/sq.umd.js +1 -1
- package/dist/translations/sr-latn.js +1 -1
- package/dist/translations/sr-latn.umd.js +1 -1
- package/dist/translations/sr.js +1 -1
- package/dist/translations/sr.umd.js +1 -1
- package/dist/translations/sv.js +1 -1
- package/dist/translations/sv.umd.js +1 -1
- package/dist/translations/th.js +1 -1
- package/dist/translations/th.umd.js +1 -1
- package/dist/translations/tr.js +1 -1
- package/dist/translations/tr.umd.js +1 -1
- package/dist/translations/ug.js +1 -1
- package/dist/translations/ug.umd.js +1 -1
- package/dist/translations/uk.js +1 -1
- package/dist/translations/uk.umd.js +1 -1
- package/dist/translations/ur.js +1 -1
- package/dist/translations/ur.umd.js +1 -1
- package/dist/translations/uz.js +1 -1
- package/dist/translations/uz.umd.js +1 -1
- package/dist/translations/vi.js +1 -1
- package/dist/translations/vi.umd.js +1 -1
- package/dist/translations/zh-cn.js +1 -1
- package/dist/translations/zh-cn.umd.js +1 -1
- package/dist/translations/zh.js +1 -1
- package/dist/translations/zh.umd.js +1 -1
- package/lang/contexts.json +1 -0
- package/lang/translations/ar.po +4 -0
- package/lang/translations/az.po +4 -0
- package/lang/translations/bg.po +4 -0
- package/lang/translations/bn.po +4 -0
- package/lang/translations/ca.po +4 -0
- package/lang/translations/cs.po +4 -0
- package/lang/translations/da.po +4 -0
- package/lang/translations/de.po +4 -0
- package/lang/translations/el.po +4 -0
- package/lang/translations/en-au.po +4 -0
- package/lang/translations/en.po +4 -0
- package/lang/translations/es-co.po +4 -0
- package/lang/translations/es.po +4 -0
- package/lang/translations/et.po +4 -0
- package/lang/translations/fa.po +4 -0
- package/lang/translations/fi.po +4 -0
- package/lang/translations/fr.po +4 -0
- package/lang/translations/gl.po +4 -0
- package/lang/translations/he.po +4 -0
- package/lang/translations/hi.po +4 -0
- package/lang/translations/hr.po +4 -0
- package/lang/translations/hu.po +4 -0
- package/lang/translations/id.po +4 -0
- package/lang/translations/it.po +4 -0
- package/lang/translations/ja.po +4 -0
- package/lang/translations/ko.po +4 -0
- package/lang/translations/lt.po +4 -0
- package/lang/translations/lv.po +4 -0
- package/lang/translations/ms.po +4 -0
- package/lang/translations/nl.po +4 -0
- package/lang/translations/no.po +4 -0
- package/lang/translations/pl.po +4 -0
- package/lang/translations/pt-br.po +4 -0
- package/lang/translations/pt.po +4 -0
- package/lang/translations/ro.po +4 -0
- package/lang/translations/ru.po +4 -0
- package/lang/translations/sk.po +4 -0
- package/lang/translations/sq.po +4 -0
- package/lang/translations/sr-latn.po +8 -4
- package/lang/translations/sr.po +4 -0
- package/lang/translations/sv.po +4 -0
- package/lang/translations/th.po +4 -0
- package/lang/translations/tr.po +4 -0
- package/lang/translations/ug.po +4 -0
- package/lang/translations/uk.po +4 -0
- package/lang/translations/ur.po +4 -0
- package/lang/translations/uz.po +4 -0
- package/lang/translations/vi.po +4 -0
- package/lang/translations/zh-cn.po +4 -0
- package/lang/translations/zh.po +4 -0
- package/package.json +7 -7
- package/src/ckboxcommand.d.ts +13 -1
- package/src/ckboxcommand.js +36 -4
- package/src/ckboxconfig.d.ts +105 -0
- package/src/ckboxediting.d.ts +7 -4
- package/src/ckboxediting.js +46 -4
- package/src/ckboximageedit/ckboximageeditcommand.js +1 -1
- package/src/ckboximageedit/ckboximageeditui.js +4 -1
- package/src/ckboxuploadadapter.js +2 -2
- package/src/ckboxutils.d.ts +3 -3
- package/src/ckboxutils.js +10 -10
package/lang/translations/ur.po
CHANGED
|
@@ -29,6 +29,10 @@ msgctxt "A message is displayed when the user is not authorised to access the CK
|
|
|
29
29
|
msgid "Cannot access default workspace."
|
|
30
30
|
msgstr ""
|
|
31
31
|
|
|
32
|
+
msgctxt "The title of the notification displayed when there is no permission to edit assets."
|
|
33
|
+
msgid "No permission for image editing. Try using the file manager or contact your administrator."
|
|
34
|
+
msgstr ""
|
|
35
|
+
|
|
32
36
|
msgctxt "Image toolbar button tooltip for opening a dialog to manipulate the image."
|
|
33
37
|
msgid "Edit image"
|
|
34
38
|
msgstr ""
|
package/lang/translations/uz.po
CHANGED
|
@@ -29,6 +29,10 @@ msgctxt "A message is displayed when the user is not authorised to access the CK
|
|
|
29
29
|
msgid "Cannot access default workspace."
|
|
30
30
|
msgstr ""
|
|
31
31
|
|
|
32
|
+
msgctxt "The title of the notification displayed when there is no permission to edit assets."
|
|
33
|
+
msgid "No permission for image editing. Try using the file manager or contact your administrator."
|
|
34
|
+
msgstr ""
|
|
35
|
+
|
|
32
36
|
msgctxt "Image toolbar button tooltip for opening a dialog to manipulate the image."
|
|
33
37
|
msgid "Edit image"
|
|
34
38
|
msgstr ""
|
package/lang/translations/vi.po
CHANGED
|
@@ -29,6 +29,10 @@ msgctxt "A message is displayed when the user is not authorised to access the CK
|
|
|
29
29
|
msgid "Cannot access default workspace."
|
|
30
30
|
msgstr "Không thể truy cập vào không gian làm việc mặc định."
|
|
31
31
|
|
|
32
|
+
msgctxt "The title of the notification displayed when there is no permission to edit assets."
|
|
33
|
+
msgid "No permission for image editing. Try using the file manager or contact your administrator."
|
|
34
|
+
msgstr ""
|
|
35
|
+
|
|
32
36
|
msgctxt "Image toolbar button tooltip for opening a dialog to manipulate the image."
|
|
33
37
|
msgid "Edit image"
|
|
34
38
|
msgstr "Chỉnh sửa hình ảnh"
|
|
@@ -29,6 +29,10 @@ msgctxt "A message is displayed when the user is not authorised to access the CK
|
|
|
29
29
|
msgid "Cannot access default workspace."
|
|
30
30
|
msgstr "无法访问默认工作区"
|
|
31
31
|
|
|
32
|
+
msgctxt "The title of the notification displayed when there is no permission to edit assets."
|
|
33
|
+
msgid "No permission for image editing. Try using the file manager or contact your administrator."
|
|
34
|
+
msgstr ""
|
|
35
|
+
|
|
32
36
|
msgctxt "Image toolbar button tooltip for opening a dialog to manipulate the image."
|
|
33
37
|
msgid "Edit image"
|
|
34
38
|
msgstr "编辑图片"
|
package/lang/translations/zh.po
CHANGED
|
@@ -29,6 +29,10 @@ msgctxt "A message is displayed when the user is not authorised to access the CK
|
|
|
29
29
|
msgid "Cannot access default workspace."
|
|
30
30
|
msgstr "無法存取預設工作區。"
|
|
31
31
|
|
|
32
|
+
msgctxt "The title of the notification displayed when there is no permission to edit assets."
|
|
33
|
+
msgid "No permission for image editing. Try using the file manager or contact your administrator."
|
|
34
|
+
msgstr ""
|
|
35
|
+
|
|
32
36
|
msgctxt "Image toolbar button tooltip for opening a dialog to manipulate the image."
|
|
33
37
|
msgid "Edit image"
|
|
34
38
|
msgstr "編輯圖片"
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ckeditor/ckeditor5-ckbox",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "43.0.0-alpha.0",
|
|
4
4
|
"description": "CKBox integration for CKEditor 5.",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"ckeditor",
|
|
@@ -13,12 +13,12 @@
|
|
|
13
13
|
"type": "module",
|
|
14
14
|
"main": "src/index.js",
|
|
15
15
|
"dependencies": {
|
|
16
|
-
"@ckeditor/ckeditor5-core": "
|
|
17
|
-
"@ckeditor/ckeditor5-engine": "
|
|
18
|
-
"@ckeditor/ckeditor5-ui": "
|
|
19
|
-
"@ckeditor/ckeditor5-upload": "
|
|
20
|
-
"@ckeditor/ckeditor5-utils": "
|
|
21
|
-
"ckeditor5": "
|
|
16
|
+
"@ckeditor/ckeditor5-core": "43.0.0-alpha.0",
|
|
17
|
+
"@ckeditor/ckeditor5-engine": "43.0.0-alpha.0",
|
|
18
|
+
"@ckeditor/ckeditor5-ui": "43.0.0-alpha.0",
|
|
19
|
+
"@ckeditor/ckeditor5-upload": "43.0.0-alpha.0",
|
|
20
|
+
"@ckeditor/ckeditor5-utils": "43.0.0-alpha.0",
|
|
21
|
+
"ckeditor5": "43.0.0-alpha.0",
|
|
22
22
|
"blurhash": "2.0.5",
|
|
23
23
|
"lodash-es": "4.17.21"
|
|
24
24
|
},
|
package/src/ckboxcommand.d.ts
CHANGED
|
@@ -74,8 +74,20 @@ export default class CKBoxCommand extends Command {
|
|
|
74
74
|
* - tokenUrl The token endpoint URL.
|
|
75
75
|
* - serviceOrigin The base URL of the API service.
|
|
76
76
|
* - forceDemoLabel Whether to force "Powered by CKBox" link.
|
|
77
|
-
* - dialog.onClose The callback function invoked after closing the CKBox dialog.
|
|
78
77
|
* - assets.onChoose The callback function invoked after choosing the assets.
|
|
78
|
+
* - dialog.onClose The callback function invoked after closing the CKBox dialog.
|
|
79
|
+
* - dialog.width The dialog width in pixels.
|
|
80
|
+
* - dialog.height The dialog height in pixels.
|
|
81
|
+
* - categories.icons Allows setting custom icons for categories.
|
|
82
|
+
* - view.openLastView Sets if the last view visited by the user will be reopened
|
|
83
|
+
* on the next startup.
|
|
84
|
+
* - view.startupFolderId Sets the ID of the folder that will be opened on startup.
|
|
85
|
+
* - view.startupCategoryId Sets the ID of the category that will be opened on startup.
|
|
86
|
+
* - view.hideMaximizeButton Sets whether to hide the ‘Maximize’ button.
|
|
87
|
+
* - view.componentsHideTimeout Sets timeout after which upload components are hidden
|
|
88
|
+
* after completed upload.
|
|
89
|
+
* - view.dialogMinimizeTimeout Sets timeout after which upload dialog is minimized
|
|
90
|
+
* after completed upload.
|
|
79
91
|
*/
|
|
80
92
|
private _prepareOptions;
|
|
81
93
|
/**
|
package/src/ckboxcommand.js
CHANGED
|
@@ -95,23 +95,55 @@ export default class CKBoxCommand extends Command {
|
|
|
95
95
|
* - tokenUrl The token endpoint URL.
|
|
96
96
|
* - serviceOrigin The base URL of the API service.
|
|
97
97
|
* - forceDemoLabel Whether to force "Powered by CKBox" link.
|
|
98
|
-
* - dialog.onClose The callback function invoked after closing the CKBox dialog.
|
|
99
98
|
* - assets.onChoose The callback function invoked after choosing the assets.
|
|
99
|
+
* - dialog.onClose The callback function invoked after closing the CKBox dialog.
|
|
100
|
+
* - dialog.width The dialog width in pixels.
|
|
101
|
+
* - dialog.height The dialog height in pixels.
|
|
102
|
+
* - categories.icons Allows setting custom icons for categories.
|
|
103
|
+
* - view.openLastView Sets if the last view visited by the user will be reopened
|
|
104
|
+
* on the next startup.
|
|
105
|
+
* - view.startupFolderId Sets the ID of the folder that will be opened on startup.
|
|
106
|
+
* - view.startupCategoryId Sets the ID of the category that will be opened on startup.
|
|
107
|
+
* - view.hideMaximizeButton Sets whether to hide the ‘Maximize’ button.
|
|
108
|
+
* - view.componentsHideTimeout Sets timeout after which upload components are hidden
|
|
109
|
+
* after completed upload.
|
|
110
|
+
* - view.dialogMinimizeTimeout Sets timeout after which upload dialog is minimized
|
|
111
|
+
* after completed upload.
|
|
100
112
|
*/
|
|
101
113
|
_prepareOptions() {
|
|
102
114
|
const editor = this.editor;
|
|
103
115
|
const ckboxConfig = editor.config.get('ckbox');
|
|
116
|
+
const dialog = ckboxConfig.dialog;
|
|
117
|
+
const categories = ckboxConfig.categories;
|
|
118
|
+
const view = ckboxConfig.view;
|
|
119
|
+
const upload = ckboxConfig.upload;
|
|
104
120
|
return {
|
|
105
121
|
theme: ckboxConfig.theme,
|
|
106
122
|
language: ckboxConfig.language,
|
|
107
123
|
tokenUrl: ckboxConfig.tokenUrl,
|
|
108
124
|
serviceOrigin: ckboxConfig.serviceOrigin,
|
|
109
125
|
forceDemoLabel: ckboxConfig.forceDemoLabel,
|
|
110
|
-
|
|
111
|
-
onClose: () => this.fire('ckbox:close')
|
|
112
|
-
},
|
|
126
|
+
choosableFileExtensions: ckboxConfig.choosableFileExtensions,
|
|
113
127
|
assets: {
|
|
114
128
|
onChoose: (assets) => this.fire('ckbox:choose', assets)
|
|
129
|
+
},
|
|
130
|
+
dialog: {
|
|
131
|
+
onClose: () => this.fire('ckbox:close'),
|
|
132
|
+
width: dialog && dialog.width,
|
|
133
|
+
height: dialog && dialog.height
|
|
134
|
+
},
|
|
135
|
+
categories: categories && {
|
|
136
|
+
icons: categories.icons
|
|
137
|
+
},
|
|
138
|
+
view: view && {
|
|
139
|
+
openLastView: view.openLastView,
|
|
140
|
+
startupFolderId: view.startupFolderId,
|
|
141
|
+
startupCategoryId: view.startupCategoryId,
|
|
142
|
+
hideMaximizeButton: view.hideMaximizeButton
|
|
143
|
+
},
|
|
144
|
+
upload: upload && {
|
|
145
|
+
componentsHideTimeout: upload.componentsHideTimeout,
|
|
146
|
+
dialogMinimizeTimeout: upload.dialogMinimizeTimeout
|
|
115
147
|
}
|
|
116
148
|
};
|
|
117
149
|
}
|
package/src/ckboxconfig.d.ts
CHANGED
|
@@ -125,6 +125,111 @@ export interface CKBoxConfig {
|
|
|
125
125
|
* Defaults to {@link module:utils/locale~Locale#uiLanguage `Locale#uiLanguage`}
|
|
126
126
|
*/
|
|
127
127
|
language?: string;
|
|
128
|
+
/**
|
|
129
|
+
* This option allows opening CKBox in dialog mode. It takes a configuration object with
|
|
130
|
+
* the width and height attributes.
|
|
131
|
+
*/
|
|
132
|
+
dialog?: CKBoxDialogConfig;
|
|
133
|
+
/**
|
|
134
|
+
* Allows setting custom icons for categories.
|
|
135
|
+
*/
|
|
136
|
+
categories?: CKBoxCategoriesConfig;
|
|
137
|
+
/**
|
|
138
|
+
* Configures the view of CKBox.
|
|
139
|
+
*/
|
|
140
|
+
view?: CKBoxViewConfig;
|
|
141
|
+
/**
|
|
142
|
+
* Configures when dialog should be minimized and hidden.
|
|
143
|
+
*/
|
|
144
|
+
upload?: CKBoxUploadConfig;
|
|
145
|
+
/**
|
|
146
|
+
* Specifies the file extensions considered valid for user interaction. Whith this
|
|
147
|
+
* option developers can restrict user interaction to only those assets whose file
|
|
148
|
+
* extensions match those listed in the array. Assets whose file
|
|
149
|
+
* extensions are not listed in the `choosableFileExtensions` array are
|
|
150
|
+
* automatically disabled within the CKBox interface.
|
|
151
|
+
*
|
|
152
|
+
* ```ts
|
|
153
|
+
* const ckboxConfig = {
|
|
154
|
+
* choosableFileExtensions: ['jpg', 'png']
|
|
155
|
+
* };
|
|
156
|
+
* ```
|
|
157
|
+
*/
|
|
158
|
+
choosableFileExtensions?: Array<string>;
|
|
159
|
+
}
|
|
160
|
+
export interface CKBoxDialogConfig {
|
|
161
|
+
/**
|
|
162
|
+
* The dialog width in pixels.
|
|
163
|
+
*/
|
|
164
|
+
width: number;
|
|
165
|
+
/**
|
|
166
|
+
* The dialog height in pixels.
|
|
167
|
+
*/
|
|
168
|
+
height: number;
|
|
169
|
+
}
|
|
170
|
+
export interface CKBoxCategoriesConfig {
|
|
171
|
+
/**
|
|
172
|
+
* This option takes an object with categories and icons that should be used instead
|
|
173
|
+
* of the default ones. Categories can be defined using either their name or id.
|
|
174
|
+
* Icons should be defined as strings containing the SVG images, or as React components.
|
|
175
|
+
*
|
|
176
|
+
* ```ts
|
|
177
|
+
* const ckboxConfig = {
|
|
178
|
+
* categories: {
|
|
179
|
+
* icons: {
|
|
180
|
+
* Images: '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path ... /></svg>',
|
|
181
|
+
* // Category can be referenced by ID
|
|
182
|
+
* // 'fdf2a647-b67f-4a6c-b692-5ba1dc1ed87b': '<svg...'
|
|
183
|
+
* }
|
|
184
|
+
* }
|
|
185
|
+
* }
|
|
186
|
+
* ```
|
|
187
|
+
*/
|
|
188
|
+
icons?: {
|
|
189
|
+
[key: string]: string;
|
|
190
|
+
};
|
|
191
|
+
}
|
|
192
|
+
export interface CKBoxViewConfig {
|
|
193
|
+
/**
|
|
194
|
+
* If it is set to `false` the last view visited by the user will not be reopened on
|
|
195
|
+
* the next startup.
|
|
196
|
+
*/
|
|
197
|
+
openLastView?: boolean;
|
|
198
|
+
/**
|
|
199
|
+
* Sets the ID of the folder that will be opened on startup. This option can be paired
|
|
200
|
+
* with setting `view.openLastView` to `false` to enforce CKBox to always open in a given
|
|
201
|
+
* folder at startup.
|
|
202
|
+
*/
|
|
203
|
+
startupFolderId?: string;
|
|
204
|
+
/**
|
|
205
|
+
* Sets the ID of the category that will be opened on startup. This option can be paired
|
|
206
|
+
* with setting `view.openLastView` to `false` to enforce CKBox to always open in a given
|
|
207
|
+
* category at startup. If `view.startupCategoryId` is passed along with the
|
|
208
|
+
* `view.startupFolderId` option, CKBox will prioritize opening category view on the startup.
|
|
209
|
+
*/
|
|
210
|
+
startupCategoryId?: string;
|
|
211
|
+
/**
|
|
212
|
+
* Sets whether to hide the ‘Maximize’ button. By default, the button is shown and enabling
|
|
213
|
+
* this option will hide it.
|
|
214
|
+
*/
|
|
215
|
+
hideMaximizeButton?: boolean;
|
|
216
|
+
}
|
|
217
|
+
export interface CKBoxUploadConfig {
|
|
218
|
+
/**
|
|
219
|
+
* Sets timeout (in milliseconds) after which upload components (dialog and indicator) are
|
|
220
|
+
* hidden. By default, these components hide automatically after 10 seconds.
|
|
221
|
+
*
|
|
222
|
+
* Read more: https://ckeditor.com/docs/ckbox/latest/guides/configuration/configuration-options.html#uploadcomponentshidetimeout
|
|
223
|
+
*/
|
|
224
|
+
componentsHideTimeout?: number;
|
|
225
|
+
/**
|
|
226
|
+
* Sets timeout (in milliseconds) after which upload dialog is minimized once upload is
|
|
227
|
+
* finished and all uploads were successful. By default, upload dialog is never minimized
|
|
228
|
+
* automatically.
|
|
229
|
+
*
|
|
230
|
+
* Read more: https://ckeditor.com/docs/ckbox/latest/guides/configuration/configuration-options.html#uploaddialogminimizetimeout
|
|
231
|
+
*/
|
|
232
|
+
dialogMinimizeTimeout?: number;
|
|
128
233
|
}
|
|
129
234
|
/**
|
|
130
235
|
* Asset definition.
|
package/src/ckboxediting.d.ts
CHANGED
|
@@ -2,6 +2,9 @@
|
|
|
2
2
|
* @license Copyright (c) 2003-2024, CKSource Holding sp. z o.o. All rights reserved.
|
|
3
3
|
* For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
|
|
4
4
|
*/
|
|
5
|
+
/**
|
|
6
|
+
* @module ckbox/ckboxediting
|
|
7
|
+
*/
|
|
5
8
|
import { Plugin } from 'ckeditor5/src/core.js';
|
|
6
9
|
import CKBoxUploadAdapter from './ckboxuploadadapter.js';
|
|
7
10
|
import CKBoxUtils from './ckboxutils.js';
|
|
@@ -10,10 +13,6 @@ import CKBoxUtils from './ckboxutils.js';
|
|
|
10
13
|
* {@link module:ckbox/ckboxuploadadapter~CKBoxUploadAdapter CKBox upload adapter}.
|
|
11
14
|
*/
|
|
12
15
|
export default class CKBoxEditing extends Plugin {
|
|
13
|
-
/**
|
|
14
|
-
* CKEditor Cloud Services access token.
|
|
15
|
-
*/
|
|
16
|
-
private _token;
|
|
17
16
|
/**
|
|
18
17
|
* @inheritDoc
|
|
19
18
|
*/
|
|
@@ -35,6 +34,10 @@ export default class CKBoxEditing extends Plugin {
|
|
|
35
34
|
* the CKBox JavaScript library is loaded.
|
|
36
35
|
*/
|
|
37
36
|
private _shouldBeInitialised;
|
|
37
|
+
/**
|
|
38
|
+
* Blocks `uploadImage` and `ckboxImageEdit` commands.
|
|
39
|
+
*/
|
|
40
|
+
private _blockImageCommands;
|
|
38
41
|
/**
|
|
39
42
|
* Checks if at least one image plugin is loaded.
|
|
40
43
|
*/
|
package/src/ckboxediting.js
CHANGED
|
@@ -2,12 +2,18 @@
|
|
|
2
2
|
* @license Copyright (c) 2003-2024, CKSource Holding sp. z o.o. All rights reserved.
|
|
3
3
|
* For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
|
|
4
4
|
*/
|
|
5
|
+
/* globals window */
|
|
6
|
+
/**
|
|
7
|
+
* @module ckbox/ckboxediting
|
|
8
|
+
*/
|
|
5
9
|
import { Plugin } from 'ckeditor5/src/core.js';
|
|
6
10
|
import { Range } from 'ckeditor5/src/engine.js';
|
|
7
11
|
import { logError } from 'ckeditor5/src/utils.js';
|
|
8
12
|
import CKBoxCommand from './ckboxcommand.js';
|
|
9
13
|
import CKBoxUploadAdapter from './ckboxuploadadapter.js';
|
|
10
14
|
import CKBoxUtils from './ckboxutils.js';
|
|
15
|
+
import { sendHttpRequest } from './utils.js';
|
|
16
|
+
const COMMAND_FORCE_DISABLE_ID = 'NoPermission';
|
|
11
17
|
/**
|
|
12
18
|
* The CKBox editing feature. It introduces the {@link module:ckbox/ckboxcommand~CKBoxCommand CKBox command} and
|
|
13
19
|
* {@link module:ckbox/ckboxuploadadapter~CKBoxUploadAdapter CKBox upload adapter}.
|
|
@@ -38,6 +44,12 @@ export default class CKBoxEditing extends Plugin {
|
|
|
38
44
|
if (isLibraryLoaded()) {
|
|
39
45
|
editor.commands.add('ckbox', new CKBoxCommand(editor));
|
|
40
46
|
}
|
|
47
|
+
// Promise is not handled intentionally. Errors should be displayed in console if there are so.
|
|
48
|
+
isUploadPermissionGranted(editor).then(isCreateAssetAllowed => {
|
|
49
|
+
if (!isCreateAssetAllowed) {
|
|
50
|
+
this._blockImageCommands();
|
|
51
|
+
}
|
|
52
|
+
});
|
|
41
53
|
}
|
|
42
54
|
/**
|
|
43
55
|
* @inheritDoc
|
|
@@ -64,6 +76,21 @@ export default class CKBoxEditing extends Plugin {
|
|
|
64
76
|
const hasConfiguration = !!editor.config.get('ckbox');
|
|
65
77
|
return hasConfiguration || isLibraryLoaded();
|
|
66
78
|
}
|
|
79
|
+
/**
|
|
80
|
+
* Blocks `uploadImage` and `ckboxImageEdit` commands.
|
|
81
|
+
*/
|
|
82
|
+
_blockImageCommands() {
|
|
83
|
+
const editor = this.editor;
|
|
84
|
+
const uploadImageCommand = editor.commands.get('uploadImage');
|
|
85
|
+
const imageEditingCommand = editor.commands.get('ckboxImageEdit');
|
|
86
|
+
if (uploadImageCommand) {
|
|
87
|
+
uploadImageCommand.isAccessAllowed = false;
|
|
88
|
+
uploadImageCommand.forceDisabled(COMMAND_FORCE_DISABLE_ID);
|
|
89
|
+
}
|
|
90
|
+
if (imageEditingCommand) {
|
|
91
|
+
imageEditingCommand.forceDisabled(COMMAND_FORCE_DISABLE_ID);
|
|
92
|
+
}
|
|
93
|
+
}
|
|
67
94
|
/**
|
|
68
95
|
* Checks if at least one image plugin is loaded.
|
|
69
96
|
*/
|
|
@@ -98,12 +125,12 @@ export default class CKBoxEditing extends Plugin {
|
|
|
98
125
|
if (schema.isRegistered('imageInline')) {
|
|
99
126
|
schema.extend('imageInline', { allowAttributes: ['ckboxImageId', 'ckboxLinkId'] });
|
|
100
127
|
}
|
|
101
|
-
schema.addAttributeCheck(
|
|
102
|
-
|
|
103
|
-
if (!
|
|
128
|
+
schema.addAttributeCheck(context => {
|
|
129
|
+
// Don't allow `ckboxLinkId` on elements which do not have `linkHref` attribute.
|
|
130
|
+
if (!context.last.getAttribute('linkHref')) {
|
|
104
131
|
return false;
|
|
105
132
|
}
|
|
106
|
-
});
|
|
133
|
+
}, 'ckboxLinkId');
|
|
107
134
|
}
|
|
108
135
|
/**
|
|
109
136
|
* Configures the upcast and downcast conversions for the `ckboxImageId` and `ckboxLinkId` attributes.
|
|
@@ -339,3 +366,18 @@ function shouldUpcastAttributeForNode(node) {
|
|
|
339
366
|
function isLibraryLoaded() {
|
|
340
367
|
return !!window.CKBox;
|
|
341
368
|
}
|
|
369
|
+
/**
|
|
370
|
+
* Checks is access allowed to upload assets.
|
|
371
|
+
*/
|
|
372
|
+
async function isUploadPermissionGranted(editor) {
|
|
373
|
+
const ckboxUtils = editor.plugins.get(CKBoxUtils);
|
|
374
|
+
const origin = editor.config.get('ckbox.serviceOrigin');
|
|
375
|
+
const url = new URL('permissions', origin);
|
|
376
|
+
const { value } = await ckboxUtils.getToken();
|
|
377
|
+
const response = (await sendHttpRequest({
|
|
378
|
+
url,
|
|
379
|
+
authorization: value,
|
|
380
|
+
signal: (new AbortController()).signal // Aborting is unnecessary.
|
|
381
|
+
}));
|
|
382
|
+
return Object.values(response).some(category => category['asset:create']);
|
|
383
|
+
}
|
|
@@ -227,7 +227,7 @@ export default class CKBoxImageEditCommand extends Command {
|
|
|
227
227
|
const response = await sendHttpRequest({
|
|
228
228
|
url,
|
|
229
229
|
signal,
|
|
230
|
-
authorization: ckboxUtils.getToken().value
|
|
230
|
+
authorization: (await ckboxUtils.getToken()).value
|
|
231
231
|
});
|
|
232
232
|
const status = response.metadata.metadataProcessingStatus;
|
|
233
233
|
if (!status || status == 'queued') {
|
|
@@ -28,13 +28,16 @@ export default class CKBoxImageEditUI extends Plugin {
|
|
|
28
28
|
const editor = this.editor;
|
|
29
29
|
editor.ui.componentFactory.add('ckboxImageEdit', locale => {
|
|
30
30
|
const command = editor.commands.get('ckboxImageEdit');
|
|
31
|
+
const uploadImageCommand = editor.commands.get('uploadImage');
|
|
31
32
|
const view = new ButtonView(locale);
|
|
32
33
|
const t = locale.t;
|
|
33
34
|
view.set({
|
|
34
|
-
label: t('Edit image'),
|
|
35
35
|
icon: ckboxImageEditIcon,
|
|
36
36
|
tooltip: true
|
|
37
37
|
});
|
|
38
|
+
view.bind('label').to(uploadImageCommand, 'isAccessAllowed', isAccessAllowed => isAccessAllowed ?
|
|
39
|
+
t('Edit image') :
|
|
40
|
+
t('No permission for image editing. Try using the file manager or contact your administrator.'));
|
|
38
41
|
view.bind('isOn').to(command, 'value', command, 'isEnabled', (value, isEnabled) => value && isEnabled);
|
|
39
42
|
view.bind('isEnabled').to(command);
|
|
40
43
|
// Execute the command.
|
|
@@ -88,7 +88,7 @@ class Adapter {
|
|
|
88
88
|
const category = await ckboxUtils.getCategoryIdForFile(file, { signal: this.controller.signal });
|
|
89
89
|
const uploadUrl = new URL('assets', this.serviceOrigin);
|
|
90
90
|
const formData = new FormData();
|
|
91
|
-
uploadUrl.searchParams.set('workspaceId', ckboxUtils.getWorkspaceId());
|
|
91
|
+
uploadUrl.searchParams.set('workspaceId', await ckboxUtils.getWorkspaceId());
|
|
92
92
|
formData.append('categoryId', category);
|
|
93
93
|
formData.append('file', file);
|
|
94
94
|
const requestConfig = {
|
|
@@ -103,7 +103,7 @@ class Adapter {
|
|
|
103
103
|
}
|
|
104
104
|
},
|
|
105
105
|
signal: this.controller.signal,
|
|
106
|
-
authorization: this.token.value
|
|
106
|
+
authorization: (await this.token).value
|
|
107
107
|
};
|
|
108
108
|
return sendHttpRequest(requestConfig)
|
|
109
109
|
.then(async (data) => {
|
package/src/ckboxutils.d.ts
CHANGED
|
@@ -26,15 +26,15 @@ export default class CKBoxUtils extends Plugin {
|
|
|
26
26
|
/**
|
|
27
27
|
* @inheritDoc
|
|
28
28
|
*/
|
|
29
|
-
init():
|
|
29
|
+
init(): void;
|
|
30
30
|
/**
|
|
31
31
|
* Returns a token used by the CKBox plugin for communication with the CKBox service.
|
|
32
32
|
*/
|
|
33
|
-
getToken(): InitializedToken
|
|
33
|
+
getToken(): Promise<InitializedToken>;
|
|
34
34
|
/**
|
|
35
35
|
* The ID of workspace to use when uploading an image.
|
|
36
36
|
*/
|
|
37
|
-
getWorkspaceId(): string
|
|
37
|
+
getWorkspaceId(): Promise<string>;
|
|
38
38
|
/**
|
|
39
39
|
* Resolves a promise with an object containing a category with which the uploaded file is associated or an error code.
|
|
40
40
|
*/
|
package/src/ckboxutils.js
CHANGED
|
@@ -25,7 +25,7 @@ export default class CKBoxUtils extends Plugin {
|
|
|
25
25
|
/**
|
|
26
26
|
* @inheritDoc
|
|
27
27
|
*/
|
|
28
|
-
|
|
28
|
+
init() {
|
|
29
29
|
const editor = this.editor;
|
|
30
30
|
const hasConfiguration = !!editor.config.get('ckbox');
|
|
31
31
|
const isLibraryLoaded = !!window.CKBox;
|
|
@@ -66,10 +66,10 @@ export default class CKBoxUtils extends Plugin {
|
|
|
66
66
|
throw new CKEditorError('ckbox-plugin-missing-token-url', this);
|
|
67
67
|
}
|
|
68
68
|
if (ckboxTokenUrl == cloudServicesTokenUrl) {
|
|
69
|
-
this._token = cloudServices.token;
|
|
69
|
+
this._token = Promise.resolve(cloudServices.token);
|
|
70
70
|
}
|
|
71
71
|
else {
|
|
72
|
-
this._token =
|
|
72
|
+
this._token = cloudServices.registerTokenUrl(ckboxTokenUrl);
|
|
73
73
|
}
|
|
74
74
|
}
|
|
75
75
|
/**
|
|
@@ -81,11 +81,11 @@ export default class CKBoxUtils extends Plugin {
|
|
|
81
81
|
/**
|
|
82
82
|
* The ID of workspace to use when uploading an image.
|
|
83
83
|
*/
|
|
84
|
-
getWorkspaceId() {
|
|
84
|
+
async getWorkspaceId() {
|
|
85
85
|
const t = this.editor.t;
|
|
86
86
|
const cannotAccessDefaultWorkspaceError = t('Cannot access default workspace.');
|
|
87
87
|
const defaultWorkspaceId = this.editor.config.get('ckbox.defaultUploadWorkspaceId');
|
|
88
|
-
const workspaceId = getWorkspaceId(this._token, defaultWorkspaceId);
|
|
88
|
+
const workspaceId = getWorkspaceId(await this._token, defaultWorkspaceId);
|
|
89
89
|
if (workspaceId == null) {
|
|
90
90
|
/**
|
|
91
91
|
* The user is not authorized to access the workspace defined in the`ckbox.defaultUploadWorkspaceId` configuration.
|
|
@@ -145,7 +145,7 @@ export default class CKBoxUtils extends Plugin {
|
|
|
145
145
|
const token = this._token;
|
|
146
146
|
const { signal } = options;
|
|
147
147
|
const serviceOrigin = editor.config.get('ckbox.serviceOrigin');
|
|
148
|
-
const workspaceId = this.getWorkspaceId();
|
|
148
|
+
const workspaceId = await this.getWorkspaceId();
|
|
149
149
|
try {
|
|
150
150
|
const result = [];
|
|
151
151
|
let offset = 0;
|
|
@@ -168,15 +168,15 @@ export default class CKBoxUtils extends Plugin {
|
|
|
168
168
|
logError('ckbox-fetch-category-http-error');
|
|
169
169
|
return undefined;
|
|
170
170
|
}
|
|
171
|
-
function fetchCategories(offset) {
|
|
171
|
+
async function fetchCategories(offset) {
|
|
172
172
|
const categoryUrl = new URL('categories', serviceOrigin);
|
|
173
|
-
categoryUrl.searchParams.set('limit', ITEMS_PER_REQUEST
|
|
174
|
-
categoryUrl.searchParams.set('offset', offset
|
|
173
|
+
categoryUrl.searchParams.set('limit', String(ITEMS_PER_REQUEST));
|
|
174
|
+
categoryUrl.searchParams.set('offset', String(offset));
|
|
175
175
|
categoryUrl.searchParams.set('workspaceId', workspaceId);
|
|
176
176
|
return sendHttpRequest({
|
|
177
177
|
url: categoryUrl,
|
|
178
178
|
signal,
|
|
179
|
-
authorization: token.value
|
|
179
|
+
authorization: (await token).value
|
|
180
180
|
});
|
|
181
181
|
}
|
|
182
182
|
}
|