@seafile/sdoc-editor 1.0.177 → 1.0.179
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/dist/api/seafile-api.js +12 -0
- package/dist/basic-sdk/assets/images/sdoc-ask-ai.png +0 -0
- package/dist/basic-sdk/constants/index.js +2 -1
- package/dist/basic-sdk/extension/commons/file-insert-dialog/index.js +28 -18
- package/dist/basic-sdk/extension/commons/file-insert-dialog/style.css +12 -9
- package/dist/basic-sdk/extension/commons/insert-element-dialog/index.js +10 -0
- package/dist/basic-sdk/extension/commons/select-file-dialog/helpers.js +9 -2
- package/dist/basic-sdk/extension/commons/select-file-dialog/index.css +115 -0
- package/dist/basic-sdk/extension/commons/select-file-dialog/index.js +68 -5
- package/dist/basic-sdk/extension/commons/select-file-dialog/local-files/index.css +42 -0
- package/dist/basic-sdk/extension/commons/select-file-dialog/local-files/index.js +49 -12
- package/dist/basic-sdk/extension/constants/element-type.js +2 -1
- package/dist/basic-sdk/extension/constants/menus-config.js +10 -2
- package/dist/basic-sdk/extension/core/queries/index.js +12 -1
- package/dist/basic-sdk/extension/plugins/ai/ai-icon/index.js +26 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-icon/style.css +22 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-menu/ai-context-menu.js +39 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-menu/ai-dropdown-menu.js +35 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-menu/index.js +20 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-menu/menu-item.js +62 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-menu/style.css +3 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-module/adjust-sub-menu.js +40 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-module/index.js +452 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-module/lang-sub-menu.js +55 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-module/style.css +104 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-module/tip-dialog.js +32 -0
- package/dist/basic-sdk/extension/plugins/ai/constants/index.js +128 -0
- package/dist/basic-sdk/extension/plugins/ai/index.js +1 -0
- package/dist/basic-sdk/extension/plugins/blockquote/plugin.js +2 -2
- package/dist/basic-sdk/extension/plugins/image/helpers.js +25 -16
- package/dist/basic-sdk/extension/plugins/image/hover-menu/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/link/helpers.js +14 -5
- package/dist/basic-sdk/extension/plugins/sdoc-link/helpers.js +7 -2
- package/dist/basic-sdk/extension/plugins/sdoc-link/render/render-elem.css +19 -3
- package/dist/basic-sdk/extension/plugins/sdoc-link/render/render-elem.js +8 -3
- package/dist/basic-sdk/extension/plugins/text-style/helpers.js +4 -0
- package/dist/basic-sdk/extension/plugins/text-style/menu/index.js +27 -8
- package/dist/basic-sdk/extension/plugins/video/helpers.js +1 -0
- package/dist/basic-sdk/extension/plugins/video/plugin.js +26 -1
- package/dist/basic-sdk/extension/toolbar/side-toolbar/index.js +7 -0
- package/dist/basic-sdk/extension/toolbar/side-toolbar/side-menu.js +4 -1
- package/dist/context.js +8 -0
- package/package.json +1 -1
- package/public/locales/cs/sdoc-editor.json +23 -1
- package/public/locales/de/sdoc-editor.json +23 -1
- package/public/locales/en/sdoc-editor.json +23 -1
- package/public/locales/es/sdoc-editor.json +23 -1
- package/public/locales/es_AR/sdoc-editor.json +23 -1
- package/public/locales/es_MX/sdoc-editor.json +23 -1
- package/public/locales/fr/sdoc-editor.json +23 -1
- package/public/locales/it/sdoc-editor.json +23 -1
- package/public/locales/ru/sdoc-editor.json +24 -2
- package/public/locales/zh_CN/sdoc-editor.json +23 -1
- package/public/media/sdoc-editor-font/iconfont.css +14 -8
- package/public/media/sdoc-editor-font/iconfont.eot +0 -0
- package/public/media/sdoc-editor-font/iconfont.svg +4 -2
- package/public/media/sdoc-editor-font/iconfont.ttf +0 -0
- package/public/media/sdoc-editor-font/iconfont.woff +0 -0
- package/public/media/sdoc-editor-font/iconfont.woff2 +0 -0
- package/public/media/sdoc-editor-font.css +14 -10
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.OPERATION_TYPES = exports.OPERATION_MENUS_CONFIG = exports.LANG_MENU_CONFIG = exports.AI_RESULT_TYPES = exports.AI_MIN_HEIGHT = void 0;
|
|
7
|
+
const OPERATION_TYPES = exports.OPERATION_TYPES = {
|
|
8
|
+
DEFAULT: 'default',
|
|
9
|
+
CONTINUATION: 'continuation',
|
|
10
|
+
MORE_DETAILS: 'more_details',
|
|
11
|
+
MORE_CONCISE: 'more_concise',
|
|
12
|
+
MORE_VIVID: 'more_vivid',
|
|
13
|
+
TRANSLATE: 'translate'
|
|
14
|
+
};
|
|
15
|
+
const OPERATION_MENUS_CONFIG = exports.OPERATION_MENUS_CONFIG = {
|
|
16
|
+
CONTINUATION: {
|
|
17
|
+
id: 'CONTINUATION',
|
|
18
|
+
text: 'Continuation',
|
|
19
|
+
iconClass: 'sdocfont sdoc-continue-writing',
|
|
20
|
+
type: 'continuation'
|
|
21
|
+
},
|
|
22
|
+
MORE_DETAILS: {
|
|
23
|
+
id: 'MORE_DETAILS',
|
|
24
|
+
text: 'More_details',
|
|
25
|
+
iconClass: 'sdocfont sdoc-adjust',
|
|
26
|
+
type: 'more_details'
|
|
27
|
+
},
|
|
28
|
+
MORE_CONCISE: {
|
|
29
|
+
id: 'MORE_CONCISE',
|
|
30
|
+
text: 'More_concise',
|
|
31
|
+
iconClass: 'sdocfont sdoc-adjust',
|
|
32
|
+
type: 'more_concise'
|
|
33
|
+
},
|
|
34
|
+
MORE_VIVID: {
|
|
35
|
+
id: 'MORE_VIVID',
|
|
36
|
+
text: 'More_vivid',
|
|
37
|
+
iconClass: 'sdocfont sdoc-adjust',
|
|
38
|
+
type: 'more_vivid'
|
|
39
|
+
},
|
|
40
|
+
TRANSLATE: {
|
|
41
|
+
id: 'TRANSLATE',
|
|
42
|
+
text: 'Translate',
|
|
43
|
+
iconClass: 'sdocfont sdoc-ai-translate',
|
|
44
|
+
type: 'translate'
|
|
45
|
+
},
|
|
46
|
+
ADJUSTMENT: {
|
|
47
|
+
id: 'ADJUSTMENT',
|
|
48
|
+
text: 'Adjustment',
|
|
49
|
+
iconClass: 'sdocfont sdoc-adjust',
|
|
50
|
+
type: 'adjustment'
|
|
51
|
+
},
|
|
52
|
+
INSERT_BELOW: {
|
|
53
|
+
id: 'INSERT_BELOW',
|
|
54
|
+
text: 'Insert_below',
|
|
55
|
+
iconClass: 'sdocfont sdoc-insert-below',
|
|
56
|
+
type: 'insert_below'
|
|
57
|
+
},
|
|
58
|
+
REPLACE: {
|
|
59
|
+
id: 'REPLACE',
|
|
60
|
+
text: 'Replace',
|
|
61
|
+
iconClass: 'sdocfont sdoc-replace',
|
|
62
|
+
type: 'replace'
|
|
63
|
+
},
|
|
64
|
+
TRY_AGAIN: {
|
|
65
|
+
id: 'TRY_AGAIN',
|
|
66
|
+
text: 'Try_again',
|
|
67
|
+
iconClass: 'sdocfont sdoc-try-again',
|
|
68
|
+
type: 'try_again'
|
|
69
|
+
},
|
|
70
|
+
COPY: {
|
|
71
|
+
id: 'COPY',
|
|
72
|
+
text: 'Copy',
|
|
73
|
+
iconClass: 'sdocfont sdoc-copy',
|
|
74
|
+
type: 'copy'
|
|
75
|
+
},
|
|
76
|
+
DEPRECATION: {
|
|
77
|
+
id: 'DEPRECATION',
|
|
78
|
+
text: 'Deprecation',
|
|
79
|
+
iconClass: 'sdocfont sdoc-delete',
|
|
80
|
+
type: 'deprecation'
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
const AI_RESULT_TYPES = exports.AI_RESULT_TYPES = {
|
|
84
|
+
continuation: true,
|
|
85
|
+
mode_details: true,
|
|
86
|
+
more_concise: true,
|
|
87
|
+
MORE_VIVID: true,
|
|
88
|
+
TRANSLATE: true
|
|
89
|
+
};
|
|
90
|
+
const LANG_MENU_CONFIG = exports.LANG_MENU_CONFIG = {
|
|
91
|
+
EN: {
|
|
92
|
+
id: 'en',
|
|
93
|
+
type: 'en',
|
|
94
|
+
text: 'English',
|
|
95
|
+
iconClass: 'sdocfont sdoc-ai-translate'
|
|
96
|
+
},
|
|
97
|
+
ZH_CN: {
|
|
98
|
+
id: 'zh-cn',
|
|
99
|
+
type: 'zh-cn',
|
|
100
|
+
text: 'Chinese',
|
|
101
|
+
iconClass: 'sdocfont sdoc-ai-translate'
|
|
102
|
+
},
|
|
103
|
+
'ZH-CN': {
|
|
104
|
+
id: 'zh-cn',
|
|
105
|
+
type: 'en',
|
|
106
|
+
text: 'Chinese',
|
|
107
|
+
iconClass: 'sdocfont sdoc-ai-translate'
|
|
108
|
+
},
|
|
109
|
+
DE: {
|
|
110
|
+
id: 'de',
|
|
111
|
+
type: 'de',
|
|
112
|
+
text: 'German',
|
|
113
|
+
iconClass: 'sdocfont sdoc-ai-translate'
|
|
114
|
+
},
|
|
115
|
+
FR: {
|
|
116
|
+
id: 'fr',
|
|
117
|
+
type: 'fr',
|
|
118
|
+
text: 'French',
|
|
119
|
+
iconClass: 'sdocfont sdoc-ai-translate'
|
|
120
|
+
},
|
|
121
|
+
RU: {
|
|
122
|
+
id: 'ru',
|
|
123
|
+
type: 'ru',
|
|
124
|
+
text: 'Russian',
|
|
125
|
+
iconClass: 'sdocfont sdoc-ai-translate'
|
|
126
|
+
}
|
|
127
|
+
};
|
|
128
|
+
const AI_MIN_HEIGHT = exports.AI_MIN_HEIGHT = 474;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";
|
|
@@ -26,13 +26,13 @@ const withBlockquote = editor => {
|
|
|
26
26
|
});
|
|
27
27
|
if (!quoteBlockEntry) return insertBreak();
|
|
28
28
|
const [currentLineEntry] = _slate.Editor.nodes(newEditor, {
|
|
29
|
-
match: n => _slate.Element.isElement(n) &&
|
|
29
|
+
match: n => _slate.Element.isElement(n) && [_constants.PARAGRAPH, _constants.HEADER1, _constants.HEADER2, _constants.HEADER3, _constants.HEADER4, _constants.HEADER5, _constants.HEADER6, _constants.TITLE, _constants.SUBTITLE].includes(n.type),
|
|
30
30
|
mode: 'lowest'
|
|
31
31
|
});
|
|
32
32
|
// Exit blockquote when current line is empty
|
|
33
33
|
const isAtEnd = currentLineEntry[1].slice(-1)[0] === quoteBlockEntry[0].children.length - 1;
|
|
34
34
|
if (isAtEnd) {
|
|
35
|
-
const isEmptyLine = !(currentLineEntry && _slate.Editor.string(newEditor, currentLineEntry[1]).length);
|
|
35
|
+
const isEmptyLine = !(currentLineEntry && _slate.Editor.string(newEditor, currentLineEntry[1]).length) && !(0, _core.isContainsVoidElement)(currentLineEntry[0]);
|
|
36
36
|
if (isEmptyLine) {
|
|
37
37
|
const nextPath = _slate.Path.next(quoteBlockEntry[1]);
|
|
38
38
|
_slate.Transforms.moveNodes(newEditor, {
|
|
@@ -89,22 +89,31 @@ const insertImage = function (editor, srcList, selection) {
|
|
|
89
89
|
_slate.Transforms.insertNodes(editor, imageNode, {
|
|
90
90
|
at: validSelection
|
|
91
91
|
});
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
92
|
+
|
|
93
|
+
// BLOCKQUOTE and CALL_OUT use inline images
|
|
94
|
+
let imageType = _constants2.IMAGE_BLOCK;
|
|
95
|
+
const [topNode] = _slate.Editor.node(editor, [aboveNodeEntry[1][0]]);
|
|
96
|
+
if ([_constants2.BLOCKQUOTE, _constants2.CALL_OUT].includes(topNode === null || topNode === void 0 ? void 0 : topNode.type)) {
|
|
97
|
+
imageType = '';
|
|
98
|
+
}
|
|
99
|
+
if (imageType === _constants2.IMAGE_BLOCK) {
|
|
100
|
+
_slate.Transforms.setNodes(editor, {
|
|
101
|
+
type: imageType
|
|
102
|
+
}, {
|
|
103
|
+
at: validSelection
|
|
104
|
+
});
|
|
105
|
+
const nodePath = [aboveNodeEntry[1][0]];
|
|
106
|
+
const nextPath = _slate.Path.next(nodePath);
|
|
107
|
+
_slate.Transforms.insertNodes(editor, (0, _core.generateDefaultParagraph)(), {
|
|
108
|
+
at: nextPath
|
|
109
|
+
});
|
|
110
|
+
const endOfFirstNode = _slate.Editor.start(editor, nextPath);
|
|
111
|
+
const range = {
|
|
112
|
+
anchor: endOfFirstNode,
|
|
113
|
+
focus: endOfFirstNode
|
|
114
|
+
};
|
|
115
|
+
(0, _core.focusEditor)(editor, range);
|
|
116
|
+
}
|
|
108
117
|
return;
|
|
109
118
|
}
|
|
110
119
|
_slate.Transforms.insertNodes(editor, imageNodes, {
|
|
@@ -165,7 +165,7 @@ const ImageHoverMenu = _ref => {
|
|
|
165
165
|
style: menuPosition
|
|
166
166
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
167
167
|
className: "hover-menu-container"
|
|
168
|
-
},
|
|
168
|
+
}, ![_constants2.TABLE, _constants2.BLOCKQUOTE, _constants2.CALL_OUT].includes(type) && !readonly && /*#__PURE__*/_react.default.createElement("span", {
|
|
169
169
|
className: "op-group-item"
|
|
170
170
|
}, /*#__PURE__*/_react.default.createElement("span", {
|
|
171
171
|
role: "button",
|
|
@@ -4,7 +4,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
|
|
|
4
4
|
Object.defineProperty(exports, "__esModule", {
|
|
5
5
|
value: true
|
|
6
6
|
});
|
|
7
|
-
exports.upsertLinkText = exports.updateLink = exports.unWrapLinkNode = exports.isWeChat = exports.isSdocFile = exports.isMenuDisabled = exports.insertLink = exports.getMenuPosition = exports.getLinkType = exports.genLinkNode = exports.checkLink = void 0;
|
|
7
|
+
exports.upsertLinkText = exports.updateLink = exports.unWrapLinkNode = exports.isWeChat = exports.isSdocFile = exports.isMenuDisabled = exports.isLinkToolBarActive = exports.insertLink = exports.getMenuPosition = exports.getLinkType = exports.genLinkNode = exports.checkLink = void 0;
|
|
8
8
|
var _slate = require("@seafile/slate");
|
|
9
9
|
var _slateReact = require("@seafile/slate-react");
|
|
10
10
|
var _slugid = _interopRequireDefault(require("slugid"));
|
|
@@ -167,15 +167,15 @@ exports.upsertLinkText = upsertLinkText;
|
|
|
167
167
|
const unWrapLinkNode = editor => {
|
|
168
168
|
if (editor.selection == null) return;
|
|
169
169
|
const [nodeEntry] = _slate.Editor.nodes(editor, {
|
|
170
|
-
match: n => (0, _core.getNodeType)(n) ===
|
|
171
|
-
universal: true
|
|
170
|
+
match: n => (0, _core.getNodeType)(n) === _constants.LINK
|
|
172
171
|
});
|
|
172
|
+
|
|
173
173
|
// If the selection is not in a link node, it is disabled
|
|
174
174
|
if (nodeEntry == null || nodeEntry[0] == null) return;
|
|
175
175
|
|
|
176
176
|
// unlink
|
|
177
177
|
_slate.Transforms.unwrapNodes(editor, {
|
|
178
|
-
match: n => (0, _core.getNodeType)(n) ===
|
|
178
|
+
match: n => (0, _core.getNodeType)(n) === _constants.LINK
|
|
179
179
|
});
|
|
180
180
|
};
|
|
181
181
|
exports.unWrapLinkNode = unWrapLinkNode;
|
|
@@ -216,4 +216,13 @@ const getMenuPosition = element => {
|
|
|
216
216
|
left: menuLeft
|
|
217
217
|
};
|
|
218
218
|
};
|
|
219
|
-
exports.getMenuPosition = getMenuPosition;
|
|
219
|
+
exports.getMenuPosition = getMenuPosition;
|
|
220
|
+
const isLinkToolBarActive = editor => {
|
|
221
|
+
if (!editor.selection) return false;
|
|
222
|
+
const [nodeEntry] = _slate.Editor.nodes(editor, {
|
|
223
|
+
match: n => (0, _core.getNodeType)(n) === _constants.LINK
|
|
224
|
+
});
|
|
225
|
+
if (nodeEntry) return true;
|
|
226
|
+
return false;
|
|
227
|
+
};
|
|
228
|
+
exports.isLinkToolBarActive = isLinkToolBarActive;
|
|
@@ -4,7 +4,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
|
|
|
4
4
|
Object.defineProperty(exports, "__esModule", {
|
|
5
5
|
value: true
|
|
6
6
|
});
|
|
7
|
-
exports.unwrapLinkNode = exports.removeTempInput = exports.removeShortCutSymbol = exports.onCopySdocLinkNode = exports.isTriggeredByShortcut = exports.isMenuDisabled = exports.insertTextWhenRemoveFileNameCollector = exports.insertTempInput = exports.insertSdocFileLink = exports.getUrl = exports.getType = exports.getNewFileListData = exports.getFileSearchInputEntry = exports.getBeforeText = exports.generateSdocFileNode = void 0;
|
|
7
|
+
exports.unwrapLinkNode = exports.sdocFileIcon = exports.removeTempInput = exports.removeShortCutSymbol = exports.onCopySdocLinkNode = exports.isTriggeredByShortcut = exports.isMenuDisabled = exports.insertTextWhenRemoveFileNameCollector = exports.insertTempInput = exports.insertSdocFileLink = exports.getUrl = exports.getType = exports.getNewFileListData = exports.getFileSearchInputEntry = exports.getBeforeText = exports.generateSdocFileNode = void 0;
|
|
8
8
|
var _slateReact = require("@seafile/slate-react");
|
|
9
9
|
var _slate = require("@seafile/slate");
|
|
10
10
|
var _slugid = _interopRequireDefault(require("slugid"));
|
|
@@ -273,4 +273,9 @@ const insertTextWhenRemoveFileNameCollector = (editor, searchInputNode) => {
|
|
|
273
273
|
});
|
|
274
274
|
removeTempInput(editor, searchInputNode);
|
|
275
275
|
};
|
|
276
|
-
exports.insertTextWhenRemoveFileNameCollector = insertTextWhenRemoveFileNameCollector;
|
|
276
|
+
exports.insertTextWhenRemoveFileNameCollector = insertTextWhenRemoveFileNameCollector;
|
|
277
|
+
const sdocFileIcon = () => {
|
|
278
|
+
const server = _context.default.getSetting('serviceUrl');
|
|
279
|
+
return `${server}/media/img/file/256/sdoc.png`;
|
|
280
|
+
};
|
|
281
|
+
exports.sdocFileIcon = sdocFileIcon;
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
.sdoc-file-render:hover {
|
|
2
|
-
background-color: #e5e5e5
|
|
2
|
+
background-color: #e5e5e5;
|
|
3
|
+
padding: 3px 0;
|
|
3
4
|
}
|
|
4
5
|
|
|
5
6
|
.sdoc-file-card-link {
|
|
@@ -25,13 +26,28 @@
|
|
|
25
26
|
|
|
26
27
|
.sdoc-file-card-link .sdoc-file-link-icon {
|
|
27
28
|
position: absolute;
|
|
28
|
-
top:
|
|
29
|
+
top: 12px;
|
|
29
30
|
left: 12px;
|
|
30
31
|
}
|
|
31
32
|
|
|
33
|
+
.sdoc-file-render:not(.sdoc-file-card-link) .sdoc-file-link-icon .file-link-img {
|
|
34
|
+
width: 21.6px;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
.sdoc-file-card-link .sdoc-file-link-icon .file-link-img {
|
|
38
|
+
width: 26px;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
.sdoc-file-render .sdoc-file-text-link.sdoc-no-file-link-icon a {
|
|
42
|
+
font-weight: bold;
|
|
43
|
+
text-decoration: underline;
|
|
44
|
+
text-decoration-thickness: 2px;
|
|
45
|
+
color: #ff9800;
|
|
46
|
+
}
|
|
47
|
+
|
|
32
48
|
.sdoc-file-card-link .sdoc-file-text-link {
|
|
33
49
|
position: absolute;
|
|
34
|
-
top:
|
|
50
|
+
top: 14px;
|
|
35
51
|
left: 42px;
|
|
36
52
|
}
|
|
37
53
|
|
|
@@ -9,6 +9,7 @@ exports.default = void 0;
|
|
|
9
9
|
var _react = _interopRequireWildcard(require("react"));
|
|
10
10
|
var _slate = require("@seafile/slate");
|
|
11
11
|
var _slateReact = require("@seafile/slate-react");
|
|
12
|
+
var _classnames = _interopRequireDefault(require("classnames"));
|
|
12
13
|
var _useScrollContext = require("../../../../hooks/use-scroll-context");
|
|
13
14
|
var _helpers = require("../helpers");
|
|
14
15
|
var _hoverMenu = _interopRequireDefault(require("../hover-menu"));
|
|
@@ -138,14 +139,18 @@ const SdocFileLink = _ref => {
|
|
|
138
139
|
}, [_constants2.SDOC_LINK_TYPE.ICON_LINK, _constants2.SDOC_LINK_TYPE.CARD_LINK].includes(element.display_type) && /*#__PURE__*/_react.default.createElement("span", {
|
|
139
140
|
className: "sdoc-file-link-icon",
|
|
140
141
|
style: style
|
|
141
|
-
}, element.type !== _elementType.WIKI_LINK && /*#__PURE__*/_react.default.createElement("
|
|
142
|
-
className: "
|
|
142
|
+
}, element.type !== _elementType.WIKI_LINK && /*#__PURE__*/_react.default.createElement("img", {
|
|
143
|
+
className: "file-link-img",
|
|
144
|
+
src: (0, _helpers.sdocFileIcon)(),
|
|
145
|
+
alt: ""
|
|
143
146
|
}), element.type === _elementType.WIKI_LINK && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, icon && /*#__PURE__*/_react.default.createElement("span", null, icon), !icon && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, isDir ? /*#__PURE__*/_react.default.createElement("span", {
|
|
144
147
|
className: "sf3-font sf3-font-files2"
|
|
145
148
|
}) : /*#__PURE__*/_react.default.createElement("span", {
|
|
146
149
|
className: "sf3-font sf3-font-file"
|
|
147
150
|
})))), /*#__PURE__*/_react.default.createElement("span", {
|
|
148
|
-
className: 'sdoc-file-text-link',
|
|
151
|
+
className: (0, _classnames.default)('sdoc-file-text-link', {
|
|
152
|
+
'sdoc-no-file-link-icon': ![_constants2.SDOC_LINK_TYPE.ICON_LINK, _constants2.SDOC_LINK_TYPE.CARD_LINK].includes(element.display_type)
|
|
153
|
+
}),
|
|
149
154
|
style: style
|
|
150
155
|
}, /*#__PURE__*/_react.default.createElement("a", {
|
|
151
156
|
href: url,
|
|
@@ -8,6 +8,7 @@ var _slate = require("@seafile/slate");
|
|
|
8
8
|
var _core = require("../../core");
|
|
9
9
|
var _elementType = require("../../constants/element-type");
|
|
10
10
|
var _menusConfig = require("../../constants/menus-config");
|
|
11
|
+
var _helpers = require("../link/helpers");
|
|
11
12
|
const isMenuDisabled = (editor, readonly) => {
|
|
12
13
|
if (readonly) return true;
|
|
13
14
|
if (editor.selection == null) return true;
|
|
@@ -43,6 +44,9 @@ const removeMark = (editor, type) => {
|
|
|
43
44
|
// Whether mark is included
|
|
44
45
|
exports.removeMark = removeMark;
|
|
45
46
|
const getValue = (editor, mark) => {
|
|
47
|
+
if (mark === _elementType.LINK && editor.selection && !_slate.Range.isCollapsed(editor.selection)) {
|
|
48
|
+
return (0, _helpers.isLinkToolBarActive)(editor);
|
|
49
|
+
}
|
|
46
50
|
const curMarks = _slate.Editor.marks(editor);
|
|
47
51
|
|
|
48
52
|
// If curMarks exists, you need to set this parameter manually. curMarks prevails
|
|
@@ -9,14 +9,18 @@ exports.default = void 0;
|
|
|
9
9
|
var _react = _interopRequireWildcard(require("react"));
|
|
10
10
|
var _reactI18next = require("react-i18next");
|
|
11
11
|
var _slate = require("@seafile/slate");
|
|
12
|
-
var
|
|
13
|
-
var _core = require("../../../core");
|
|
12
|
+
var _eventBus = _interopRequireDefault(require("../../../../utils/event-bus"));
|
|
14
13
|
var _commons = require("../../../commons");
|
|
15
|
-
var _helpers = require("../../font/helpers");
|
|
16
14
|
var _fontSizeScale = _interopRequireDefault(require("../../font/menu/font-size/font-size-scale"));
|
|
15
|
+
var _mouseEvent = require("../../../../utils/mouse-event");
|
|
16
|
+
var _aiMenu = require("../../ai/ai-menu");
|
|
17
|
+
var _core = require("../../../core");
|
|
18
|
+
var _helpers = require("../../font/helpers");
|
|
17
19
|
var _helpers2 = require("../helpers");
|
|
20
|
+
var _helpers3 = require("../../link/helpers");
|
|
18
21
|
var _useColorContext = require("../../../../hooks/use-color-context");
|
|
19
|
-
var
|
|
22
|
+
var _constants = require("../../../constants");
|
|
23
|
+
var _constants2 = require("../../../../../basic-sdk/constants");
|
|
20
24
|
const TextStyleMenuList = _ref => {
|
|
21
25
|
let {
|
|
22
26
|
editor,
|
|
@@ -37,26 +41,38 @@ const TextStyleMenuList = _ref => {
|
|
|
37
41
|
const isActive = (0, _react.useCallback)(type => {
|
|
38
42
|
const isMark = (0, _helpers2.getValue)(editor, type);
|
|
39
43
|
return !!isMark;
|
|
40
|
-
|
|
41
44
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
42
45
|
}, [editor]);
|
|
43
46
|
const isDisabled = (0, _react.useCallback)(() => {
|
|
44
47
|
return (0, _helpers2.isMenuDisabled)(editor, readonly);
|
|
45
|
-
|
|
46
48
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
47
49
|
}, [editor, readonly]);
|
|
50
|
+
const openLinkDialog = (0, _react.useCallback)(() => {
|
|
51
|
+
const eventBus = _eventBus.default.getInstance();
|
|
52
|
+
eventBus.dispatch(_constants2.INTERNAL_EVENT.INSERT_ELEMENT, {
|
|
53
|
+
type: _constants.ELEMENT_TYPE.LINK,
|
|
54
|
+
editor
|
|
55
|
+
});
|
|
56
|
+
}, [editor]);
|
|
48
57
|
const onMouseDown = (0, _react.useCallback)((event, type) => {
|
|
49
58
|
event.preventDefault();
|
|
50
59
|
event.stopPropagation();
|
|
51
60
|
if (isDisabled()) return;
|
|
52
61
|
const active = isActive(type);
|
|
62
|
+
if (type === _constants.LINK) {
|
|
63
|
+
if (active) {
|
|
64
|
+
(0, _helpers3.unWrapLinkNode)(editor);
|
|
65
|
+
} else {
|
|
66
|
+
openLinkDialog();
|
|
67
|
+
}
|
|
68
|
+
return;
|
|
69
|
+
}
|
|
53
70
|
if (active) {
|
|
54
71
|
(0, _helpers2.removeMark)(editor, type);
|
|
55
72
|
} else {
|
|
56
73
|
(0, _helpers2.addMark)(editor, type);
|
|
57
74
|
}
|
|
58
75
|
(0, _core.focusEditor)(editor);
|
|
59
|
-
|
|
60
76
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
61
77
|
}, [editor]);
|
|
62
78
|
const setColor = (0, _react.useCallback)((type, color) => {
|
|
@@ -107,6 +123,7 @@ const TextStyleMenuList = _ref => {
|
|
|
107
123
|
let list = getTextStyleList(_constants.TEXT_STYLE);
|
|
108
124
|
const dropdownList = getTextStyleList(_constants.TEXT_STYLE_MORE);
|
|
109
125
|
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, list.map((itemProps, index) => {
|
|
126
|
+
if (itemProps.type === _constants.LINK && editor.editorType !== _constants2.WIKI_EDITOR) return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
|
|
110
127
|
const Component = itemProps.isColor ? _commons.ColorMenu : _commons.MenuItem;
|
|
111
128
|
return /*#__PURE__*/_react.default.createElement(Component, Object.assign({
|
|
112
129
|
key: index
|
|
@@ -127,6 +144,8 @@ const TextStyleMenuList = _ref => {
|
|
|
127
144
|
tipMessage: t('Reduce_font_size')
|
|
128
145
|
}, /*#__PURE__*/_react.default.createElement("i", {
|
|
129
146
|
className: "sdocfont sdoc-reduce-font-size"
|
|
130
|
-
})))
|
|
147
|
+
}))), idPrefix && /*#__PURE__*/_react.default.createElement(_aiMenu.AIContextMenu, {
|
|
148
|
+
isRichEditor: isRichEditor
|
|
149
|
+
}));
|
|
131
150
|
};
|
|
132
151
|
var _default = exports.default = (0, _reactI18next.withTranslation)('sdoc-editor')(TextStyleMenuList);
|
|
@@ -31,6 +31,7 @@ const isInsertVideoMenuDisabled = (editor, readonly) => {
|
|
|
31
31
|
if (type === _constants.SUBTITLE) return true;
|
|
32
32
|
if (type === _constants.LIST_ITEM) return true;
|
|
33
33
|
if (type === _constants.CHECK_LIST_ITEM) return true;
|
|
34
|
+
if (type === _constants.MULTI_COLUMN) return true;
|
|
34
35
|
if (_slate.Editor.isVoid(editor, n)) return true;
|
|
35
36
|
return false;
|
|
36
37
|
},
|
|
@@ -6,10 +6,15 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
});
|
|
7
7
|
exports.default = void 0;
|
|
8
8
|
var _react = _interopRequireDefault(require("react"));
|
|
9
|
+
var _slate = require("@seafile/slate");
|
|
10
|
+
var _isHotkey = _interopRequireDefault(require("is-hotkey"));
|
|
11
|
+
var _core = require("../../core");
|
|
9
12
|
var _constants = require("../../constants");
|
|
13
|
+
var _helpers = require("../../toolbar/side-toolbar/helpers");
|
|
10
14
|
const withVideo = editor => {
|
|
11
15
|
const {
|
|
12
|
-
isVoid
|
|
16
|
+
isVoid,
|
|
17
|
+
onHotKeyDown
|
|
13
18
|
} = editor;
|
|
14
19
|
const newEditor = editor;
|
|
15
20
|
|
|
@@ -23,6 +28,26 @@ const withVideo = editor => {
|
|
|
23
28
|
}
|
|
24
29
|
return isVoid(elem);
|
|
25
30
|
};
|
|
31
|
+
newEditor.onHotKeyDown = event => {
|
|
32
|
+
const [videoNode, path] = (0, _core.getSelectedNodeEntryByType)(editor, _constants.VIDEO);
|
|
33
|
+
if (path) {
|
|
34
|
+
// Insert empty paragraph node after video when clicking 'enter' on selected video
|
|
35
|
+
if ((0, _isHotkey.default)('enter', event)) {
|
|
36
|
+
event.preventDefault();
|
|
37
|
+
const emptyParagraph = (0, _core.generateEmptyElement)(_constants.PARAGRAPH);
|
|
38
|
+
_slate.Transforms.insertNodes(editor, emptyParagraph, {
|
|
39
|
+
at: _slate.Path.next(path)
|
|
40
|
+
});
|
|
41
|
+
const focusPoint = _slate.Editor.end(editor, _slate.Path.next(path));
|
|
42
|
+
(0, _core.focusEditor)(newEditor, focusPoint);
|
|
43
|
+
}
|
|
44
|
+
if ((0, _isHotkey.default)('mod+c', event)) {
|
|
45
|
+
(0, _helpers.onCopyNode)(editor, videoNode);
|
|
46
|
+
}
|
|
47
|
+
return true;
|
|
48
|
+
}
|
|
49
|
+
return onHotKeyDown && onHotKeyDown(event);
|
|
50
|
+
};
|
|
26
51
|
return newEditor;
|
|
27
52
|
};
|
|
28
53
|
var _default = exports.default = withVideo;
|
|
@@ -47,6 +47,13 @@ const SideToolbar = () => {
|
|
|
47
47
|
const handleClick = (0, _react.useCallback)(e => {
|
|
48
48
|
if (!isShowSideMenu || !menuRef.current) return;
|
|
49
49
|
const isClickSideTool = menuRef.current.contains(e.target);
|
|
50
|
+
const sideAskAI = document.querySelector('#side-toolbar-ai');
|
|
51
|
+
if (sideAskAI && sideAskAI.contains(e.target)) {
|
|
52
|
+
setTimeout(() => {
|
|
53
|
+
setShowSideMenu(!isShowSideMenu);
|
|
54
|
+
}, 0);
|
|
55
|
+
return;
|
|
56
|
+
}
|
|
50
57
|
if (isClickSideTool || !sideMenuRef.current) return;
|
|
51
58
|
const {
|
|
52
59
|
sideMenuDom
|
|
@@ -21,6 +21,7 @@ var _transformMenus = _interopRequireDefault(require("./transform-menus"));
|
|
|
21
21
|
var _dropdownMenuItem = _interopRequireDefault(require("../../commons/dropdown-menu-item"));
|
|
22
22
|
var _toast = _interopRequireDefault(require("../../../../components/toast"));
|
|
23
23
|
var _constants = require("../../constants");
|
|
24
|
+
var _aiMenu = require("../../plugins/ai/ai-menu");
|
|
24
25
|
require("./side-menu.css");
|
|
25
26
|
const SideMenu = (_ref, ref) => {
|
|
26
27
|
let {
|
|
@@ -211,7 +212,9 @@ const SideMenu = (_ref, ref) => {
|
|
|
211
212
|
isHidden: !otherOperatonsMenuSearchMap['COPY_LINK_OF_SECTION']
|
|
212
213
|
}), !otherOperatonsMenuSearchMap['searching'] && /*#__PURE__*/_react.default.createElement("div", {
|
|
213
214
|
className: "sdoc-dropdown-menu-divider"
|
|
214
|
-
})), /*#__PURE__*/_react.default.createElement(
|
|
215
|
+
})), /*#__PURE__*/_react.default.createElement(_aiMenu.AIDropdownMenu, {
|
|
216
|
+
slateNode: slateNode
|
|
217
|
+
}), /*#__PURE__*/_react.default.createElement(_dropdownMenuItem.default, {
|
|
215
218
|
menuConfig: {
|
|
216
219
|
text: 'Copy',
|
|
217
220
|
iconClass: 'sdocfont sdoc-copy'
|
package/dist/context.js
CHANGED
|
@@ -223,6 +223,10 @@ class Context {
|
|
|
223
223
|
const docUuid = this.getSetting('docUuid');
|
|
224
224
|
return this.api.searchSdocFiles(docUuid, query, page, per_page);
|
|
225
225
|
}
|
|
226
|
+
getSearchFilesByFilename(query, page, per_page, search_type) {
|
|
227
|
+
const docUuid = this.getSetting('docUuid');
|
|
228
|
+
return this.api.searchFilesByFilename(docUuid, query, page, per_page, search_type);
|
|
229
|
+
}
|
|
226
230
|
|
|
227
231
|
// participants
|
|
228
232
|
listParticipants() {
|
|
@@ -255,6 +259,10 @@ class Context {
|
|
|
255
259
|
const docUuid = this.getDocUuid();
|
|
256
260
|
return this.api.readAllNotifications(docUuid);
|
|
257
261
|
}
|
|
262
|
+
aiTranslate(text, lang) {
|
|
263
|
+
const docUuid = this.getDocUuid();
|
|
264
|
+
return this.api.aiTranslate(docUuid, text, lang);
|
|
265
|
+
}
|
|
258
266
|
updateConfigUuid(docUuid) {
|
|
259
267
|
if (!this.config) return;
|
|
260
268
|
this.config['docUuid'] = docUuid;
|
package/package.json
CHANGED
|
@@ -581,5 +581,27 @@
|
|
|
581
581
|
"Page": "Page",
|
|
582
582
|
"Share_1": "Sdílet",
|
|
583
583
|
"Collect": "Collect",
|
|
584
|
-
"Collected": "Collected"
|
|
584
|
+
"Collected": "Collected",
|
|
585
|
+
"Link_to_file": "Link to file",
|
|
586
|
+
"Create_a_new_file": "Create a new file",
|
|
587
|
+
"Suggestion": "Návrh",
|
|
588
|
+
"Continuation": "Continuation",
|
|
589
|
+
"More_details": "More details",
|
|
590
|
+
"More_concise": "More concise",
|
|
591
|
+
"More_vivid": "More vivid",
|
|
592
|
+
"Translate": "Translate",
|
|
593
|
+
"Adjustment": "Adjustment",
|
|
594
|
+
"Try_again": "Try again",
|
|
595
|
+
"Deprecation": "Deprecation",
|
|
596
|
+
"Generated_content_x_words": "Generated content {{count}} words",
|
|
597
|
+
"Ask_AI_anything": "Ask AI anything...",
|
|
598
|
+
"Thinking": "Thinking...",
|
|
599
|
+
"Translation_error_message": "Translation error, please try again.",
|
|
600
|
+
"The_translation_content_cannot_be_empty": "The translation content cannot be empty",
|
|
601
|
+
"Processing_message": "Processing, please wait...",
|
|
602
|
+
"AI_tip_content": "Discard current content?",
|
|
603
|
+
"Discard": "Zrušit změny",
|
|
604
|
+
"English": "English",
|
|
605
|
+
"Chinese": "Chinese",
|
|
606
|
+
"Ask_AI": "Ask AI"
|
|
585
607
|
}
|
|
@@ -581,5 +581,27 @@
|
|
|
581
581
|
"Page": "Page",
|
|
582
582
|
"Share_1": "Freigeben",
|
|
583
583
|
"Collect": "Collect",
|
|
584
|
-
"Collected": "Collected"
|
|
584
|
+
"Collected": "Collected",
|
|
585
|
+
"Link_to_file": "Link to file",
|
|
586
|
+
"Create_a_new_file": "Create a new file",
|
|
587
|
+
"Suggestion": "Vorschlag",
|
|
588
|
+
"Continuation": "Continuation",
|
|
589
|
+
"More_details": "More details",
|
|
590
|
+
"More_concise": "More concise",
|
|
591
|
+
"More_vivid": "More vivid",
|
|
592
|
+
"Translate": "Translate",
|
|
593
|
+
"Adjustment": "Adjustment",
|
|
594
|
+
"Try_again": "Try again",
|
|
595
|
+
"Deprecation": "Deprecation",
|
|
596
|
+
"Generated_content_x_words": "Generated content {{count}} words",
|
|
597
|
+
"Ask_AI_anything": "Ask AI anything...",
|
|
598
|
+
"Thinking": "Thinking...",
|
|
599
|
+
"Translation_error_message": "Translation error, please try again.",
|
|
600
|
+
"The_translation_content_cannot_be_empty": "The translation content cannot be empty",
|
|
601
|
+
"Processing_message": "Processing, please wait...",
|
|
602
|
+
"AI_tip_content": "Discard current content?",
|
|
603
|
+
"Discard": "Verwerfen",
|
|
604
|
+
"English": "English",
|
|
605
|
+
"Chinese": "Chinese",
|
|
606
|
+
"Ask_AI": "KI fragen"
|
|
585
607
|
}
|
|
@@ -581,5 +581,27 @@
|
|
|
581
581
|
"Page": "Page",
|
|
582
582
|
"Share_1": "Share",
|
|
583
583
|
"Collect": "Collect",
|
|
584
|
-
"Collected": "Collected"
|
|
584
|
+
"Collected": "Collected",
|
|
585
|
+
"Link_to_file": "Link to file",
|
|
586
|
+
"Create_a_new_file": "Create a new file",
|
|
587
|
+
"Suggestion": "Suggestion",
|
|
588
|
+
"Continuation": "Continuation",
|
|
589
|
+
"More_details": "More details",
|
|
590
|
+
"More_concise": "More concise",
|
|
591
|
+
"More_vivid": "More vivid",
|
|
592
|
+
"Translate": "Translate",
|
|
593
|
+
"Adjustment": "Adjustment",
|
|
594
|
+
"Try_again": "Try again",
|
|
595
|
+
"Deprecation": "Deprecation",
|
|
596
|
+
"Generated_content_x_words": "Generated content {{count}} words",
|
|
597
|
+
"Ask_AI_anything": "Ask AI anything...",
|
|
598
|
+
"Thinking": "Thinking...",
|
|
599
|
+
"Translation_error_message": "Translation error, please try again.",
|
|
600
|
+
"The_translation_content_cannot_be_empty": "The translation content cannot be empty",
|
|
601
|
+
"Processing_message": "Processing, please wait...",
|
|
602
|
+
"AI_tip_content": "Discard current content?",
|
|
603
|
+
"Discard": "Discard",
|
|
604
|
+
"English": "English",
|
|
605
|
+
"Chinese": "Chinese",
|
|
606
|
+
"Ask_AI": "Ask AI"
|
|
585
607
|
}
|