@seafile/sdoc-editor 2.0.75 → 2.0.76
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/basic-sdk/comment/components/comment-context-menu/index.css +1 -1
- package/dist/basic-sdk/comment/components/comment-participants-editor/index.js +2 -2
- package/dist/basic-sdk/comment/components/global-comment/global-comment-header.js +4 -5
- package/dist/basic-sdk/comment/components/global-comment/index.js +2 -2
- package/dist/basic-sdk/comment/hooks/comment-hooks/use-comment-mount.js +2 -2
- package/dist/basic-sdk/comment/hooks/notification-hooks/use-notification-mount.js +9 -10
- package/dist/basic-sdk/comment/provider/participants-content-provider.js +4 -4
- package/dist/basic-sdk/comment/reducer/notification-reducer.js +10 -11
- package/dist/basic-sdk/constants/index.js +16 -1
- package/dist/basic-sdk/editor/sdoc-comment-editor.js +4 -15
- package/dist/basic-sdk/editor/sdoc-editor.js +5 -6
- package/dist/basic-sdk/editor/wiki-editor.js +4 -5
- package/dist/basic-sdk/extension/commons/file-insert-dialog/index.js +6 -7
- package/dist/basic-sdk/extension/commons/insert-element-dialog/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/ai/ai-menu/style.css +1 -1
- package/dist/basic-sdk/extension/plugins/image/helpers.js +17 -4
- package/dist/basic-sdk/extension/plugins/image/render-elem.js +9 -10
- package/dist/basic-sdk/extension/plugins/mention/render-elem/participant-popover.js +2 -2
- package/dist/basic-sdk/extension/plugins/text-style/menu/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/text-style/render-elem.js +1 -1
- package/dist/{hooks → basic-sdk/hooks}/use-collaborators.js +1 -1
- package/dist/{hooks → basic-sdk/hooks}/use-plugins.js +3 -3
- package/dist/basic-sdk/index.js +26 -0
- package/dist/basic-sdk/layout/editor-content.js +2 -2
- package/dist/basic-sdk/model/index.js +20 -0
- package/dist/{model → basic-sdk/model}/notification.js +1 -1
- package/dist/basic-sdk/right-panel/index.js +2 -2
- package/dist/basic-sdk/socket/socket-manager.js +10 -10
- package/dist/basic-sdk/views/sdoc-viewer.js +4 -3
- package/dist/components/doc-operations/plugins-operations.js +1 -2
- package/dist/components/doc-operations/revision-operations/index.js +21 -20
- package/dist/components/doc-operations/revision-operations/more-revision-operations/index.js +1 -1
- package/dist/components/doc-operations/revision-operations/revisions/index.js +1 -1
- package/dist/constants/index.js +12 -21
- package/dist/context.js +1 -1
- package/dist/hooks/index.js +1 -27
- package/dist/model/index.js +1 -15
- package/dist/pages/simple-editor.js +2 -2
- package/dist/plugin-module/editor/plugin-editor.js +2 -3
- package/dist/plugin-module/index.js +2 -2
- package/dist/plugin-module/plugins/seatable-column/helpers.js +1 -9
- package/dist/plugin-module/views/plugin-viewer.js +3 -3
- package/package.json +1 -1
- package/dist/pages/document-plugin-editor.js +0 -111
- /package/dist/{model → basic-sdk/model}/user.js +0 -0
|
@@ -37,7 +37,7 @@ const renderText = props => {
|
|
|
37
37
|
|
|
38
38
|
// Add temporary marks for selection in AI or context comment
|
|
39
39
|
if ((leaf.sdoc_ai || leaf.comment) && leaf.text.trim()) {
|
|
40
|
-
style['padding'] = '
|
|
40
|
+
style['padding'] = '3px 0';
|
|
41
41
|
style['backgroundColor'] = '#a9c9ed';
|
|
42
42
|
}
|
|
43
43
|
|
|
@@ -7,7 +7,7 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
7
7
|
});
|
|
8
8
|
exports.useCollaborators = exports.CollaboratorsProvider = void 0;
|
|
9
9
|
var _react = _interopRequireWildcard(require("react"));
|
|
10
|
-
var _context = _interopRequireDefault(require("
|
|
10
|
+
var _context = _interopRequireDefault(require("../../context"));
|
|
11
11
|
var _model = require("../model");
|
|
12
12
|
const CollaboratorsContext = /*#__PURE__*/_react.default.createContext(null);
|
|
13
13
|
const CollaboratorsProvider = _ref => {
|
|
@@ -7,9 +7,9 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
7
7
|
});
|
|
8
8
|
exports.usePlugins = exports.PluginsProvider = void 0;
|
|
9
9
|
var _react = _interopRequireWildcard(require("react"));
|
|
10
|
-
var _comment = _interopRequireDefault(require("../
|
|
11
|
-
var _commentOperation = _interopRequireDefault(require("../
|
|
12
|
-
var _constants = require("../
|
|
10
|
+
var _comment = _interopRequireDefault(require("../comment"));
|
|
11
|
+
var _commentOperation = _interopRequireDefault(require("../comment/components/comment-operation"));
|
|
12
|
+
var _constants = require("../constants");
|
|
13
13
|
const PluginsContext = /*#__PURE__*/_react.default.createContext(null);
|
|
14
14
|
const PluginsProvider = _ref => {
|
|
15
15
|
let {
|
package/dist/basic-sdk/index.js
CHANGED
|
@@ -4,6 +4,12 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
|
|
|
4
4
|
Object.defineProperty(exports, "__esModule", {
|
|
5
5
|
value: true
|
|
6
6
|
});
|
|
7
|
+
Object.defineProperty(exports, "CollaboratorsProvider", {
|
|
8
|
+
enumerable: true,
|
|
9
|
+
get: function () {
|
|
10
|
+
return _useCollaborators.CollaboratorsProvider;
|
|
11
|
+
}
|
|
12
|
+
});
|
|
7
13
|
Object.defineProperty(exports, "DiffViewer", {
|
|
8
14
|
enumerable: true,
|
|
9
15
|
get: function () {
|
|
@@ -28,6 +34,12 @@ Object.defineProperty(exports, "Loading", {
|
|
|
28
34
|
return _loading.default;
|
|
29
35
|
}
|
|
30
36
|
});
|
|
37
|
+
Object.defineProperty(exports, "PluginsProvider", {
|
|
38
|
+
enumerable: true,
|
|
39
|
+
get: function () {
|
|
40
|
+
return _usePlugins.PluginsProvider;
|
|
41
|
+
}
|
|
42
|
+
});
|
|
31
43
|
Object.defineProperty(exports, "PublishedRevisionDiffViewer", {
|
|
32
44
|
enumerable: true,
|
|
33
45
|
get: function () {
|
|
@@ -112,12 +124,26 @@ Object.defineProperty(exports, "toaster", {
|
|
|
112
124
|
return _toast.default;
|
|
113
125
|
}
|
|
114
126
|
});
|
|
127
|
+
Object.defineProperty(exports, "useCollaborators", {
|
|
128
|
+
enumerable: true,
|
|
129
|
+
get: function () {
|
|
130
|
+
return _useCollaborators.useCollaborators;
|
|
131
|
+
}
|
|
132
|
+
});
|
|
133
|
+
Object.defineProperty(exports, "usePlugins", {
|
|
134
|
+
enumerable: true,
|
|
135
|
+
get: function () {
|
|
136
|
+
return _usePlugins.usePlugins;
|
|
137
|
+
}
|
|
138
|
+
});
|
|
115
139
|
var _fileLoading = _interopRequireDefault(require("./components/file-loading"));
|
|
116
140
|
var _loading = _interopRequireDefault(require("./components/loading"));
|
|
117
141
|
var _toast = _interopRequireDefault(require("./components/toast"));
|
|
118
142
|
var _tooltip = _interopRequireDefault(require("./components/tooltip"));
|
|
119
143
|
var _revisionEditor = _interopRequireDefault(require("./editor/revision-editor"));
|
|
120
144
|
var _sdocEditor = _interopRequireDefault(require("./editor/sdoc-editor"));
|
|
145
|
+
var _useCollaborators = require("./hooks/use-collaborators");
|
|
146
|
+
var _usePlugins = require("./hooks/use-plugins");
|
|
121
147
|
var _outline = _interopRequireDefault(require("./outline"));
|
|
122
148
|
var _slateConvert = require("./slate-convert");
|
|
123
149
|
var _commonUtils = require("./utils/common-utils");
|
|
@@ -52,8 +52,8 @@ const EditorContent = _ref => {
|
|
|
52
52
|
});
|
|
53
53
|
|
|
54
54
|
// If you don't display comment, use Fragment to replace CommentProvider
|
|
55
|
-
const
|
|
56
|
-
return /*#__PURE__*/_react.default.createElement(
|
|
55
|
+
const WithCommentProvider = showComment ? _provider.default : _react.Fragment;
|
|
56
|
+
return /*#__PURE__*/_react.default.createElement(WithCommentProvider, showComment && {
|
|
57
57
|
editor
|
|
58
58
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
59
59
|
className: "sdoc-content-wrapper"
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
Object.defineProperty(exports, "Notification", {
|
|
8
|
+
enumerable: true,
|
|
9
|
+
get: function () {
|
|
10
|
+
return _notification.default;
|
|
11
|
+
}
|
|
12
|
+
});
|
|
13
|
+
Object.defineProperty(exports, "User", {
|
|
14
|
+
enumerable: true,
|
|
15
|
+
get: function () {
|
|
16
|
+
return _user.default;
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
var _user = _interopRequireDefault(require("./user"));
|
|
20
|
+
var _notification = _interopRequireDefault(require("./notification"));
|
|
@@ -4,7 +4,7 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
|
-
var _utils = require("../
|
|
7
|
+
var _utils = require("../comment/utils");
|
|
8
8
|
class Notification {
|
|
9
9
|
constructor(options) {
|
|
10
10
|
var _options$detail, _options$detail2, _options$detail3;
|
|
@@ -7,8 +7,8 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
7
7
|
});
|
|
8
8
|
exports.default = void 0;
|
|
9
9
|
var _react = _interopRequireWildcard(require("react"));
|
|
10
|
-
var _hooks = require("../../hooks");
|
|
11
10
|
var _constants = require("../constants");
|
|
11
|
+
var _usePlugins = require("../hooks/use-plugins");
|
|
12
12
|
var _eventBus = _interopRequireDefault(require("../utils/event-bus"));
|
|
13
13
|
var _localStorageUtils = _interopRequireDefault(require("../utils/local-storage-utils"));
|
|
14
14
|
var _resizeWidth = _interopRequireDefault(require("./resize-width"));
|
|
@@ -23,7 +23,7 @@ const RightPanel = _ref => {
|
|
|
23
23
|
plugins,
|
|
24
24
|
displayPluginName,
|
|
25
25
|
closePlugin
|
|
26
|
-
} = (0,
|
|
26
|
+
} = (0, _usePlugins.usePlugins)();
|
|
27
27
|
const [width, setWidth] = (0, _react.useState)(MIN_PANEL_WIDTH);
|
|
28
28
|
const panelWrapperStyle = (0, _react.useMemo)(() => {
|
|
29
29
|
if (!displayPluginName) return null;
|
|
@@ -6,7 +6,7 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
});
|
|
7
7
|
exports.default = void 0;
|
|
8
8
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/defineProperty"));
|
|
9
|
-
var _constants = require("
|
|
9
|
+
var _constants = require("../constants");
|
|
10
10
|
var _helper = require("../cursor/helper");
|
|
11
11
|
var _debug = require("../utils/debug");
|
|
12
12
|
var _eventBus = _interopRequireDefault(require("../utils/event-bus"));
|
|
@@ -36,25 +36,25 @@ class SocketManager {
|
|
|
36
36
|
this.document['version'] = document.version;
|
|
37
37
|
});
|
|
38
38
|
(0, _defineProperty2.default)(this, "receivePublishDocument", () => {
|
|
39
|
-
this.eventBus.dispatch(_constants.
|
|
39
|
+
this.eventBus.dispatch(_constants.INTERNAL_EVENT.PUBLISH_DOCUMENT);
|
|
40
40
|
});
|
|
41
41
|
(0, _defineProperty2.default)(this, "receivePublishDocumentError", () => {
|
|
42
|
-
this.eventBus.dispatch(_constants.
|
|
42
|
+
this.eventBus.dispatch(_constants.INTERNAL_EVENT.PUBLISH_DOCUMENT_ERROR);
|
|
43
43
|
});
|
|
44
44
|
(0, _defineProperty2.default)(this, "receiveRemoveDocument", () => {
|
|
45
|
-
this.eventBus.dispatch(_constants.
|
|
45
|
+
this.eventBus.dispatch(_constants.INTERNAL_EVENT.REMOVE_DOCUMENT);
|
|
46
46
|
});
|
|
47
47
|
(0, _defineProperty2.default)(this, "receiveRemoveDocumentError", () => {
|
|
48
|
-
this.eventBus.dispatch(_constants.
|
|
48
|
+
this.eventBus.dispatch(_constants.INTERNAL_EVENT.REMOVE_DOCUMENT_ERROR);
|
|
49
49
|
});
|
|
50
50
|
(0, _defineProperty2.default)(this, "receiveDocumentReplaced", () => {
|
|
51
|
-
this.eventBus.dispatch(_constants.
|
|
51
|
+
this.eventBus.dispatch(_constants.INTERNAL_EVENT.DOCUMENT_REPLACED);
|
|
52
52
|
});
|
|
53
53
|
(0, _defineProperty2.default)(this, "receiveDocumentReplacedError", () => {
|
|
54
|
-
this.eventBus.dispatch(_constants.
|
|
54
|
+
this.eventBus.dispatch(_constants.INTERNAL_EVENT.DOCUMENT_REPLACED_ERROR);
|
|
55
55
|
});
|
|
56
56
|
(0, _defineProperty2.default)(this, "receiveNewNotification", notification => {
|
|
57
|
-
this.eventBus.dispatch(_constants.
|
|
57
|
+
this.eventBus.dispatch(_constants.INTERNAL_EVENT.NEW_NOTIFICATION, notification);
|
|
58
58
|
});
|
|
59
59
|
(0, _defineProperty2.default)(this, "onReceiveLocalOperations", operations => {
|
|
60
60
|
if (this.editor.readonly) return;
|
|
@@ -353,10 +353,10 @@ class SocketManager {
|
|
|
353
353
|
this.socketClient.disconnectWithServer();
|
|
354
354
|
});
|
|
355
355
|
(0, _defineProperty2.default)(this, "receiveParticipantAdded", uses => {
|
|
356
|
-
this.eventBus.dispatch(_constants.
|
|
356
|
+
this.eventBus.dispatch(_constants.INTERNAL_EVENT.PARTICIPANT_ADDED, uses);
|
|
357
357
|
});
|
|
358
358
|
(0, _defineProperty2.default)(this, "receiveParticipantRemoved", email => {
|
|
359
|
-
this.eventBus.dispatch(_constants.
|
|
359
|
+
this.eventBus.dispatch(_constants.INTERNAL_EVENT.PARTICIPANT_REMOVED, email);
|
|
360
360
|
});
|
|
361
361
|
this.editor = editor;
|
|
362
362
|
this.document = _document;
|
|
@@ -8,11 +8,12 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
8
8
|
exports.default = void 0;
|
|
9
9
|
var _react = _interopRequireWildcard(require("react"));
|
|
10
10
|
var _context = _interopRequireDefault(require("../../context"));
|
|
11
|
-
var _hooks = require("../../hooks");
|
|
12
11
|
var _jsBridge = _interopRequireDefault(require("../android/js-bridge"));
|
|
13
12
|
var _outlineModule = require("../android/outline-module");
|
|
14
13
|
var _extension = require("../extension");
|
|
14
|
+
var _useCollaborators = require("../hooks/use-collaborators");
|
|
15
15
|
var _useColorContext = require("../hooks/use-color-context");
|
|
16
|
+
var _usePlugins = require("../hooks/use-plugins");
|
|
16
17
|
var _layout = require("../layout");
|
|
17
18
|
var _nodeId = _interopRequireDefault(require("../node-id"));
|
|
18
19
|
var _documentUtils = require("../utils/document-utils");
|
|
@@ -32,7 +33,7 @@ const SDocViewer = _ref => {
|
|
|
32
33
|
}
|
|
33
34
|
const validEditor = editor || (0, _nodeId.default)((0, _extension.createDefaultEditor)());
|
|
34
35
|
const slateValue = (document || (0, _documentUtils.generateDefaultDocContent)()).elements;
|
|
35
|
-
const Provider = showComment ?
|
|
36
|
+
const Provider = showComment ? _useCollaborators.CollaboratorsProvider : _react.Fragment;
|
|
36
37
|
(0, _react.useEffect)(() => {
|
|
37
38
|
const mobileLogin = _context.default.getSetting('mobileLogin');
|
|
38
39
|
if (mobileLogin) {
|
|
@@ -45,7 +46,7 @@ const SDocViewer = _ref => {
|
|
|
45
46
|
};
|
|
46
47
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
47
48
|
}, []);
|
|
48
|
-
return /*#__PURE__*/_react.default.createElement(Provider, null, /*#__PURE__*/_react.default.createElement(
|
|
49
|
+
return /*#__PURE__*/_react.default.createElement(Provider, null, /*#__PURE__*/_react.default.createElement(_usePlugins.PluginsProvider, {
|
|
49
50
|
plugins: plugins,
|
|
50
51
|
showComment: showComment
|
|
51
52
|
}, /*#__PURE__*/_react.default.createElement(_layout.EditorContainer, {
|
|
@@ -12,12 +12,11 @@ var _classnames = _interopRequireDefault(require("classnames"));
|
|
|
12
12
|
var _basicSdk = require("../../basic-sdk");
|
|
13
13
|
var _constants = require("../../basic-sdk/constants");
|
|
14
14
|
var _mouseEvent = require("../../basic-sdk/utils/mouse-event");
|
|
15
|
-
var _hooks = require("../../hooks");
|
|
16
15
|
const PluginsOperations = () => {
|
|
17
16
|
const {
|
|
18
17
|
plugins,
|
|
19
18
|
updateDisplayPlugin
|
|
20
|
-
} = (0,
|
|
19
|
+
} = (0, _basicSdk.usePlugins)();
|
|
21
20
|
const {
|
|
22
21
|
t
|
|
23
22
|
} = (0, _reactI18next.useTranslation)('sdoc-editor');
|
|
@@ -9,8 +9,9 @@ exports.default = void 0;
|
|
|
9
9
|
var _react = _interopRequireWildcard(require("react"));
|
|
10
10
|
var _reactI18next = require("react-i18next");
|
|
11
11
|
var _basicSdk = require("../../../basic-sdk");
|
|
12
|
+
var _constants = require("../../../basic-sdk/constants");
|
|
12
13
|
var _rebase = require("../../../basic-sdk/utils/rebase");
|
|
13
|
-
var
|
|
14
|
+
var _constants2 = require("../../../constants");
|
|
14
15
|
var _context = _interopRequireDefault(require("../../../context"));
|
|
15
16
|
var _hooks = require("../../../hooks");
|
|
16
17
|
var _tipDialog = _interopRequireDefault(require("../../tip-dialog"));
|
|
@@ -58,7 +59,7 @@ const RevisionOperations = _ref => {
|
|
|
58
59
|
value
|
|
59
60
|
} = (0, _rebase.getRebase)(masterContent, baseContent, revisionContent);
|
|
60
61
|
setMergeValue(value);
|
|
61
|
-
setTipType(
|
|
62
|
+
setTipType(_constants2.TIP_TYPE.SOURCE_DOCUMENT_CHANGED);
|
|
62
63
|
}).catch(error => {
|
|
63
64
|
if (typeof error === 'string') {
|
|
64
65
|
_basicSdk.toaster.danger(t(error));
|
|
@@ -72,16 +73,16 @@ const RevisionOperations = _ref => {
|
|
|
72
73
|
}, []);
|
|
73
74
|
const onDocumentReplaced = (0, _react.useCallback)(() => {
|
|
74
75
|
if (isShowTip) return;
|
|
75
|
-
setTipType(
|
|
76
|
+
setTipType(_constants2.TIP_TYPE.HAS_BEEN_REPLACED);
|
|
76
77
|
setShowTip(true);
|
|
77
78
|
}, [isShowTip]);
|
|
78
79
|
const hasPublishRevision = (0, _react.useCallback)(() => {
|
|
79
80
|
handleRevisionPublished();
|
|
80
|
-
_basicSdk.toaster.success(t(
|
|
81
|
+
_basicSdk.toaster.success(t(_constants2.TIP_CONTENT[_constants2.TIP_TYPE.HAS_BEEN_PUBLISHED]));
|
|
81
82
|
}, [handleRevisionPublished, t]);
|
|
82
83
|
const onDocumentRemoved = (0, _react.useCallback)(() => {
|
|
83
84
|
if (isShowTip) return;
|
|
84
|
-
setTipType(
|
|
85
|
+
setTipType(_constants2.TIP_TYPE.HAS_BEEN_REMOVED);
|
|
85
86
|
setShowTip(true);
|
|
86
87
|
}, [isShowTip]);
|
|
87
88
|
const onError = (0, _react.useCallback)(() => {
|
|
@@ -91,12 +92,12 @@ const RevisionOperations = _ref => {
|
|
|
91
92
|
}, []);
|
|
92
93
|
(0, _react.useEffect)(() => {
|
|
93
94
|
const eventBus = _basicSdk.EventBus.getInstance();
|
|
94
|
-
const unsubscribeMergeDocument = eventBus.subscribe(_constants.
|
|
95
|
-
const unsubscribeMergeDocumentError = eventBus.subscribe(_constants.
|
|
96
|
-
const unsubscribePublishDocument = eventBus.subscribe(_constants.
|
|
97
|
-
const unsubscribePublishDocumentError = eventBus.subscribe(_constants.
|
|
98
|
-
const unsubscribeRemoveDocument = eventBus.subscribe(_constants.
|
|
99
|
-
const unsubscribeRemoveDocumentError = eventBus.subscribe(_constants.
|
|
95
|
+
const unsubscribeMergeDocument = eventBus.subscribe(_constants.INTERNAL_EVENT.DOCUMENT_REPLACED, onDocumentReplaced);
|
|
96
|
+
const unsubscribeMergeDocumentError = eventBus.subscribe(_constants.INTERNAL_EVENT.DOCUMENT_REPLACED_ERROR, onError);
|
|
97
|
+
const unsubscribePublishDocument = eventBus.subscribe(_constants.INTERNAL_EVENT.PUBLISH_DOCUMENT, hasPublishRevision);
|
|
98
|
+
const unsubscribePublishDocumentError = eventBus.subscribe(_constants.INTERNAL_EVENT.PUBLISH_DOCUMENT_ERROR, onError);
|
|
99
|
+
const unsubscribeRemoveDocument = eventBus.subscribe(_constants.INTERNAL_EVENT.REMOVE_DOCUMENT, onDocumentRemoved);
|
|
100
|
+
const unsubscribeRemoveDocumentError = eventBus.subscribe(_constants.INTERNAL_EVENT.REMOVE_DOCUMENT_ERROR, onError);
|
|
100
101
|
return () => {
|
|
101
102
|
unsubscribeMergeDocument();
|
|
102
103
|
unsubscribeMergeDocumentError();
|
|
@@ -118,7 +119,7 @@ const RevisionOperations = _ref => {
|
|
|
118
119
|
loadDocument().then(revisionContent => {
|
|
119
120
|
// Prevent users from switching if document contains conflicting content
|
|
120
121
|
if ((0, _rebase.hasConflict)(revisionContent.elements)) {
|
|
121
|
-
setTipType(
|
|
122
|
+
setTipType(_constants2.TIP_TYPE.HAS_CONFLICT_BEFORE_VIEW_CHANGES);
|
|
122
123
|
setShowTip(true);
|
|
123
124
|
} else {
|
|
124
125
|
handleViewChangesToggle(isShowChanges);
|
|
@@ -137,7 +138,7 @@ const RevisionOperations = _ref => {
|
|
|
137
138
|
// publish revision
|
|
138
139
|
const publishRevision = (0, _react.useCallback)(() => {
|
|
139
140
|
setShowTip(true);
|
|
140
|
-
setTipType(
|
|
141
|
+
setTipType(_constants2.TIP_TYPE.CHECKING);
|
|
141
142
|
const revisionPromise = loadDocument();
|
|
142
143
|
const baseVersionPromise = _context.default.getRevisionBaseVersionContent();
|
|
143
144
|
const originVersionPromise = _context.default.getSeadocOriginFileContent();
|
|
@@ -146,7 +147,7 @@ const RevisionOperations = _ref => {
|
|
|
146
147
|
const baseContent = JSON.parse(baseRes.data.content);
|
|
147
148
|
const masterContent = JSON.parse(masterRes.data.content);
|
|
148
149
|
if ((0, _rebase.hasConflict)(revisionContent.elements)) {
|
|
149
|
-
setTipType(
|
|
150
|
+
setTipType(_constants2.TIP_TYPE.HAS_CONFLICT_BEFORE_PUBLISH);
|
|
150
151
|
return;
|
|
151
152
|
}
|
|
152
153
|
const {
|
|
@@ -156,7 +157,7 @@ const RevisionOperations = _ref => {
|
|
|
156
157
|
} = (0, _rebase.getRebase)(masterContent, baseContent, revisionContent);
|
|
157
158
|
// change to HAS_BEEN_PUBLISHED
|
|
158
159
|
if (canMerge && isNeedReplaceMaster) {
|
|
159
|
-
setTipType(
|
|
160
|
+
setTipType(_constants2.TIP_TYPE.PUBLISHING);
|
|
160
161
|
_context.default.publishRevision().then(res => {
|
|
161
162
|
setShowTip(false);
|
|
162
163
|
setTipType('');
|
|
@@ -168,13 +169,13 @@ const RevisionOperations = _ref => {
|
|
|
168
169
|
|
|
169
170
|
// change to DELETE_NO_CHANGES_REVISION
|
|
170
171
|
if (canMerge && !isNeedReplaceMaster) {
|
|
171
|
-
setTipType(
|
|
172
|
+
setTipType(_constants2.TIP_TYPE.DELETE_NO_CHANGES_REVISION);
|
|
172
173
|
return;
|
|
173
174
|
}
|
|
174
175
|
|
|
175
176
|
// change to MERGE
|
|
176
177
|
setMergeValue(value);
|
|
177
|
-
setTipType(
|
|
178
|
+
setTipType(_constants2.TIP_TYPE.MERGE);
|
|
178
179
|
}).catch(error => {
|
|
179
180
|
if (typeof error === 'string') {
|
|
180
181
|
_basicSdk.toaster.danger(t(error));
|
|
@@ -186,11 +187,11 @@ const RevisionOperations = _ref => {
|
|
|
186
187
|
|
|
187
188
|
// confirm publish
|
|
188
189
|
const onSubmit = (0, _react.useCallback)(() => {
|
|
189
|
-
if (tipType ===
|
|
190
|
+
if (tipType === _constants2.TIP_TYPE.HAS_BEEN_PUBLISHED) {
|
|
190
191
|
// nothing todo
|
|
191
192
|
return;
|
|
192
193
|
}
|
|
193
|
-
if (tipType ===
|
|
194
|
+
if (tipType === _constants2.TIP_TYPE.DELETE_NO_CHANGES_REVISION) {
|
|
194
195
|
_context.default.deleteSdocRevision().then(res => {
|
|
195
196
|
// update current location
|
|
196
197
|
const originFileURL = _context.default.getSetting('originFileURL');
|
|
@@ -200,7 +201,7 @@ const RevisionOperations = _ref => {
|
|
|
200
201
|
});
|
|
201
202
|
return;
|
|
202
203
|
}
|
|
203
|
-
if (tipType ===
|
|
204
|
+
if (tipType === _constants2.TIP_TYPE.MERGE || tipType === _constants2.TIP_TYPE.SOURCE_DOCUMENT_CHANGED) {
|
|
204
205
|
const {
|
|
205
206
|
username
|
|
206
207
|
} = _context.default.getUserInfo();
|
package/dist/components/doc-operations/revision-operations/more-revision-operations/index.js
CHANGED
|
@@ -29,7 +29,7 @@ const MoreRevisionOperations = _ref => {
|
|
|
29
29
|
const siteRoot = _context.default.getSetting('siteRoot');
|
|
30
30
|
const revisionURL = `${siteRoot}lib/${repoID}/revisions/${res.data.revision_id}/`;
|
|
31
31
|
window.open(revisionURL, '_blank');
|
|
32
|
-
eventBus.dispatch(_constants.
|
|
32
|
+
eventBus.dispatch(_constants.NEW_REVISION);
|
|
33
33
|
}).catch(error => {
|
|
34
34
|
_basicSdk.toaster.danger(t('Error'));
|
|
35
35
|
});
|
|
@@ -38,7 +38,7 @@ const Revisions = () => {
|
|
|
38
38
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
39
39
|
}, []);
|
|
40
40
|
(0, _react.useEffect)(() => {
|
|
41
|
-
const autoIncrementRevisionSubscribe = eventBus.subscribe(_constants.
|
|
41
|
+
const autoIncrementRevisionSubscribe = eventBus.subscribe(_constants.NEW_REVISION, autoIncrementRevisionsCount);
|
|
42
42
|
return () => {
|
|
43
43
|
autoIncrementRevisionSubscribe();
|
|
44
44
|
};
|
package/dist/constants/index.js
CHANGED
|
@@ -3,7 +3,8 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports.TIP_TYPE = exports.TIP_TITLE = exports.TIP_CONTENT = exports.EXTERNAL_EVENT = void 0;
|
|
6
|
+
exports.TIP_TYPE = exports.TIP_TITLE = exports.TIP_CONTENT = exports.NEW_REVISION = exports.EXTERNAL_EVENT = void 0;
|
|
7
|
+
var _constants = require("../basic-sdk/constants");
|
|
7
8
|
const EXTERNAL_EVENT = exports.EXTERNAL_EVENT = {
|
|
8
9
|
INTERNAL_LINK_CLICK: 'internal_link_click',
|
|
9
10
|
TOGGLE_STAR: 'toggle_star',
|
|
@@ -11,30 +12,20 @@ const EXTERNAL_EVENT = exports.EXTERNAL_EVENT = {
|
|
|
11
12
|
SHARE_SDOC: 'share_sdoc',
|
|
12
13
|
FREEZE_DOCUMENT: 'freeze_document',
|
|
13
14
|
UNFREEZE: 'unfreeze',
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
REMOVE_DOCUMENT: 'remove_document',
|
|
20
|
-
REMOVE_DOCUMENT_ERROR: 'remove_document_error',
|
|
21
|
-
NEW_NOTIFICATION: 'new_notification',
|
|
22
|
-
CLEAR_NOTIFICATION: 'clear_notification',
|
|
23
|
-
PARTICIPANT_ADDED: 'participant-added',
|
|
24
|
-
PARTICIPANT_REMOVED: 'participant-removed',
|
|
25
|
-
CREATE_SDOC_FILE: 'create_sdoc_file',
|
|
26
|
-
CREATE_WIKI_PAGE: 'create_wiki_page',
|
|
27
|
-
ADD_VIDEO_LINK: 'add_video_link',
|
|
28
|
-
CHANGE_HEADER_WIDTH: 'change_header_width',
|
|
29
|
-
TOGGLE_PRESENTATION_MODE: 'toggle_presentation_mode',
|
|
15
|
+
// change internal event to external event
|
|
16
|
+
// editor
|
|
17
|
+
REFRESH_DOCUMENT: _constants.INTERNAL_EVENT.REFRESH_DOCUMENT,
|
|
18
|
+
NEW_NOTIFICATION: _constants.INTERNAL_EVENT.NEW_NOTIFICATION,
|
|
19
|
+
CLEAR_NOTIFICATION: _constants.INTERNAL_EVENT.CLEAR_NOTIFICATION,
|
|
30
20
|
// wiki
|
|
31
|
-
|
|
21
|
+
CREATE_SDOC_FILE: _constants.INTERNAL_EVENT.CREATE_SDOC_FILE,
|
|
22
|
+
CREATE_WIKI_PAGE: _constants.INTERNAL_EVENT.CREATE_WIKI_PAGE,
|
|
32
23
|
// document
|
|
24
|
+
IMAGE_COLUMN_TOGGLE: _constants.INTERNAL_EVENT.IMAGE_COLUMN_TOGGLE,
|
|
33
25
|
COLLABORATORS_UPDATED: 'collaborators_updated',
|
|
34
|
-
|
|
35
|
-
// revise
|
|
36
|
-
NEW_REVISION: 'new_revision'
|
|
26
|
+
CHANGE_HEADER_WIDTH: 'change_header_width'
|
|
37
27
|
};
|
|
28
|
+
const NEW_REVISION = exports.NEW_REVISION = 'new_revision';
|
|
38
29
|
const TIP_TYPE = exports.TIP_TYPE = {
|
|
39
30
|
DELETE_NO_CHANGES_REVISION: 'delete_no_changes_revision',
|
|
40
31
|
MERGE: 'merge',
|
package/dist/context.js
CHANGED
|
@@ -24,7 +24,7 @@ class Context {
|
|
|
24
24
|
username,
|
|
25
25
|
avatar_url: avatarURL
|
|
26
26
|
};
|
|
27
|
-
this.user =
|
|
27
|
+
this.user = userInfo;
|
|
28
28
|
if (this.settings['isSdocRevision']) {
|
|
29
29
|
const repoID = this.getSetting('repoID');
|
|
30
30
|
const siteRoot = this.getSetting('siteRoot');
|
package/dist/hooks/index.js
CHANGED
|
@@ -3,36 +3,10 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
Object.defineProperty(exports, "CollaboratorsProvider", {
|
|
7
|
-
enumerable: true,
|
|
8
|
-
get: function () {
|
|
9
|
-
return _useCollaborators.CollaboratorsProvider;
|
|
10
|
-
}
|
|
11
|
-
});
|
|
12
|
-
Object.defineProperty(exports, "PluginsProvider", {
|
|
13
|
-
enumerable: true,
|
|
14
|
-
get: function () {
|
|
15
|
-
return _usePlugins.PluginsProvider;
|
|
16
|
-
}
|
|
17
|
-
});
|
|
18
|
-
Object.defineProperty(exports, "useCollaborators", {
|
|
19
|
-
enumerable: true,
|
|
20
|
-
get: function () {
|
|
21
|
-
return _useCollaborators.useCollaborators;
|
|
22
|
-
}
|
|
23
|
-
});
|
|
24
6
|
Object.defineProperty(exports, "useDocument", {
|
|
25
7
|
enumerable: true,
|
|
26
8
|
get: function () {
|
|
27
9
|
return _useDocument.useDocument;
|
|
28
10
|
}
|
|
29
11
|
});
|
|
30
|
-
|
|
31
|
-
enumerable: true,
|
|
32
|
-
get: function () {
|
|
33
|
-
return _usePlugins.usePlugins;
|
|
34
|
-
}
|
|
35
|
-
});
|
|
36
|
-
var _useCollaborators = require("./use-collaborators");
|
|
37
|
-
var _useDocument = require("./use-document");
|
|
38
|
-
var _usePlugins = require("./use-plugins");
|
|
12
|
+
var _useDocument = require("./use-document");
|
package/dist/model/index.js
CHANGED
|
@@ -4,24 +4,10 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
|
|
|
4
4
|
Object.defineProperty(exports, "__esModule", {
|
|
5
5
|
value: true
|
|
6
6
|
});
|
|
7
|
-
Object.defineProperty(exports, "Notification", {
|
|
8
|
-
enumerable: true,
|
|
9
|
-
get: function () {
|
|
10
|
-
return _notification.default;
|
|
11
|
-
}
|
|
12
|
-
});
|
|
13
7
|
Object.defineProperty(exports, "Revision", {
|
|
14
8
|
enumerable: true,
|
|
15
9
|
get: function () {
|
|
16
10
|
return _revision.default;
|
|
17
11
|
}
|
|
18
12
|
});
|
|
19
|
-
|
|
20
|
-
enumerable: true,
|
|
21
|
-
get: function () {
|
|
22
|
-
return _user.default;
|
|
23
|
-
}
|
|
24
|
-
});
|
|
25
|
-
var _notification = _interopRequireDefault(require("./notification"));
|
|
26
|
-
var _revision = _interopRequireDefault(require("./revision"));
|
|
27
|
-
var _user = _interopRequireDefault(require("./user"));
|
|
13
|
+
var _revision = _interopRequireDefault(require("./revision"));
|
|
@@ -124,9 +124,9 @@ const SimpleEditor = _ref => {
|
|
|
124
124
|
className: "error-tip"
|
|
125
125
|
}, t(errorMessage)));
|
|
126
126
|
}
|
|
127
|
-
return /*#__PURE__*/_react.default.createElement(_errorBoundary.default, null, /*#__PURE__*/_react.default.createElement(
|
|
127
|
+
return /*#__PURE__*/_react.default.createElement(_errorBoundary.default, null, /*#__PURE__*/_react.default.createElement(_basicSdk.CollaboratorsProvider, {
|
|
128
128
|
collaborators: collaborators
|
|
129
|
-
}, /*#__PURE__*/_react.default.createElement(
|
|
129
|
+
}, /*#__PURE__*/_react.default.createElement(_basicSdk.PluginsProvider, {
|
|
130
130
|
plugins: plugins,
|
|
131
131
|
showComment: showComment
|
|
132
132
|
}, /*#__PURE__*/_react.default.createElement(_layout.default, null, /*#__PURE__*/_react.default.createElement(_layout.Header, null, /*#__PURE__*/_react.default.createElement(_docInfo.default, {
|
|
@@ -19,7 +19,6 @@ var _useColorContext = require("../../basic-sdk/hooks/use-color-context");
|
|
|
19
19
|
var _nodeId = _interopRequireDefault(require("../../basic-sdk/node-id"));
|
|
20
20
|
var _socket = require("../../basic-sdk/socket");
|
|
21
21
|
var _context = _interopRequireDefault(require("../../context"));
|
|
22
|
-
var _constants2 = require("../../constants");
|
|
23
22
|
var _insertElementDialog = _interopRequireDefault(require("../gloable-ui/insert-element-dialog"));
|
|
24
23
|
var _layout = require("../layout");
|
|
25
24
|
var _headerToolbar = _interopRequireDefault(require("../toolbar/header-toolbar"));
|
|
@@ -105,7 +104,7 @@ const PluginEditor = /*#__PURE__*/(0, _react.forwardRef)((_ref, ref) => {
|
|
|
105
104
|
// useMount: refresh document
|
|
106
105
|
(0, _react.useEffect)(() => {
|
|
107
106
|
const eventBus = _basicSdk.EventBus.getInstance();
|
|
108
|
-
eventBus.subscribe(
|
|
107
|
+
eventBus.subscribe(_constants.INTERNAL_EVENT.REFRESH_DOCUMENT, onRefreshDocument);
|
|
109
108
|
|
|
110
109
|
// Remove aiMarks on special conditions like unexpected exit or refresh page using AI
|
|
111
110
|
const hasAIMark = !_slate.Editor.nodes(validEditor, {
|
|
@@ -129,7 +128,7 @@ const PluginEditor = /*#__PURE__*/(0, _react.forwardRef)((_ref, ref) => {
|
|
|
129
128
|
}, []);
|
|
130
129
|
(0, _react.useEffect)(() => {
|
|
131
130
|
const eventBus = _basicSdk.EventBus.getInstance();
|
|
132
|
-
const unsubscribePresentationFullScreen = eventBus.subscribe(
|
|
131
|
+
const unsubscribePresentationFullScreen = eventBus.subscribe(_constants.INTERNAL_EVENT.TOGGLE_PRESENTATION_MODE, handleFullScreenPresentation);
|
|
133
132
|
return () => {
|
|
134
133
|
unsubscribePresentationFullScreen();
|
|
135
134
|
};
|
|
@@ -8,13 +8,13 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
8
8
|
exports.default = void 0;
|
|
9
9
|
var _react = _interopRequireWildcard(require("react"));
|
|
10
10
|
var _reactI18next = require("react-i18next");
|
|
11
|
+
var _basicSdk = require("../basic-sdk");
|
|
11
12
|
var _constants = require("../basic-sdk/constants");
|
|
12
13
|
var _extension = require("../basic-sdk/extension");
|
|
13
14
|
var _useForceUpdate = _interopRequireDefault(require("../basic-sdk/hooks/use-force-update"));
|
|
14
15
|
var _nodeId = _interopRequireDefault(require("../basic-sdk/node-id"));
|
|
15
16
|
var _socket = require("../basic-sdk/socket");
|
|
16
17
|
var _context = _interopRequireDefault(require("../context"));
|
|
17
|
-
var _hooks = require("../hooks");
|
|
18
18
|
var _pluginEditor = _interopRequireDefault(require("./editor/plugin-editor"));
|
|
19
19
|
var _errorBoundary = _interopRequireDefault(require("./error-boundary"));
|
|
20
20
|
var _plugins = require("./plugins");
|
|
@@ -93,7 +93,7 @@ const DocumentPluginEditor = _ref => {
|
|
|
93
93
|
validEditor.currentRowIdx = currentRowIdx;
|
|
94
94
|
forceUpdate();
|
|
95
95
|
}, [forceUpdate, getColumnCellValue, getArticleStyle, validEditor, currentRowIdx]);
|
|
96
|
-
return /*#__PURE__*/_react.default.createElement(_errorBoundary.default, null, !isReadOnly && /*#__PURE__*/_react.default.createElement(
|
|
96
|
+
return /*#__PURE__*/_react.default.createElement(_errorBoundary.default, null, !isReadOnly && /*#__PURE__*/_react.default.createElement(_basicSdk.PluginsProvider, {
|
|
97
97
|
plugins: [],
|
|
98
98
|
showComment: false
|
|
99
99
|
}, /*#__PURE__*/_react.default.createElement(_pluginEditor.default, {
|
|
@@ -5,7 +5,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
|
|
|
5
5
|
Object.defineProperty(exports, "__esModule", {
|
|
6
6
|
value: true
|
|
7
7
|
});
|
|
8
|
-
exports.setSeaTableColumn = exports.isMenuDisabled = exports.insertSeaTableColumn = exports.
|
|
8
|
+
exports.setSeaTableColumn = exports.isMenuDisabled = exports.insertSeaTableColumn = exports.getColumnWidth = exports.getColumnType = exports.getColumnByKey = void 0;
|
|
9
9
|
var _slate = require("@seafile/slate");
|
|
10
10
|
var _slugid = _interopRequireDefault(require("slugid"));
|
|
11
11
|
var _constants = require("../../../basic-sdk/extension/constants");
|
|
@@ -59,14 +59,6 @@ const getColumnType = editor => {
|
|
|
59
59
|
return (0, _core.getNodeType)(n);
|
|
60
60
|
};
|
|
61
61
|
exports.getColumnType = getColumnType;
|
|
62
|
-
const getDigitalSignImgUrl = partUrl => {
|
|
63
|
-
const server = _context.default.getSetting('serviceUrl');
|
|
64
|
-
const workspaceID = _context.default.getSetting('workspaceID');
|
|
65
|
-
const dtableUuid = _context.default.getSetting('dtableUuid');
|
|
66
|
-
if (!partUrl || typeof partUrl !== 'string') return '';
|
|
67
|
-
return `${server}/workspace/${workspaceID}/asset/${dtableUuid}${partUrl}`;
|
|
68
|
-
};
|
|
69
|
-
exports.getDigitalSignImgUrl = getDigitalSignImgUrl;
|
|
70
62
|
const getColumnByKey = (columns, key) => {
|
|
71
63
|
const column = columns.find(item => item.key === key);
|
|
72
64
|
return column || null;
|