@seafile/sdoc-editor 1.0.196 → 1.0.198-test0.1
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/assets/css/sdoc-editor-plugins.css +4 -0
- package/dist/basic-sdk/comment/components/comment-all-participants/index.js +1 -1
- package/dist/basic-sdk/comment/components/comment-delete-popover.js +1 -1
- package/dist/basic-sdk/comment/components/comment-editor.js +1 -1
- package/dist/basic-sdk/comment/components/comment-participants-editor/index.js +1 -1
- package/dist/basic-sdk/comment/components/comment-participants-editor/searched-collaborators.js +1 -1
- package/dist/basic-sdk/comment/components/comment-participants-editor/selected-participants.js +1 -1
- package/dist/basic-sdk/comment/components/global-comment/global-comment-body-header.js +2 -2
- package/dist/basic-sdk/comment/components/global-comment/global-comment-header.js +1 -1
- package/dist/basic-sdk/comment/hooks/notification-hooks/use-notification-mount.js +1 -1
- package/dist/basic-sdk/comment/provider/participants-content-provider.js +1 -1
- package/dist/basic-sdk/extension/commons/dropdown-menu-item/index.js +1 -1
- package/dist/basic-sdk/extension/commons/file-insert-dialog/index.js +1 -1
- package/dist/basic-sdk/extension/commons/insert-element-dialog/index.js +15 -1
- package/dist/basic-sdk/extension/commons/menu/menu-item.js +1 -1
- package/dist/basic-sdk/extension/commons/select-file-dialog/index.js +31 -4
- package/dist/basic-sdk/extension/commons/select-file-dialog/local-files/index.js +2 -1
- package/dist/basic-sdk/extension/commons/wiki-file-insert-dialog/index.js +1 -1
- package/dist/basic-sdk/extension/constants/element-type.js +2 -1
- package/dist/basic-sdk/extension/constants/index.js +10 -3
- package/dist/basic-sdk/extension/constants/menus-config.js +5 -0
- package/dist/basic-sdk/extension/core/utils/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/ai/ai-menu/menu-item.js +1 -1
- package/dist/basic-sdk/extension/plugins/callout/menu/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/callout/render-elem/callout-hover-menu/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/callout/render-elem/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/code-block/hover-menu/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/font/menu/font-family/font-item.js +1 -1
- package/dist/basic-sdk/extension/plugins/font/menu/font-family/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/font/menu/font-size/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/image/menu/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/link/dialog/add-link-dialog/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/link/hover/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/search-replace/popover/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/search-replace/popover/replace-all-confirm-modal.js +1 -1
- package/dist/basic-sdk/extension/plugins/seatable-tables/op-menu/index.js +3 -3
- package/dist/basic-sdk/extension/plugins/seatable-tables/render-element/seatable-table.js +1 -1
- package/dist/basic-sdk/extension/plugins/seatable-tables/seatable-settings/filter-setter/filter-popover-widgets/department-filter/department-multiple-select-filter.js +1 -1
- package/dist/basic-sdk/extension/plugins/seatable-tables/seatable-settings/filter-setter/filter-popover-widgets/department-filter/department-multiple-select.js +1 -1
- package/dist/basic-sdk/extension/plugins/seatable-tables/seatable-settings/filter-setter/filter-popover-widgets/department-filter/department-single-select-filter.js +1 -1
- package/dist/basic-sdk/extension/plugins/seatable-tables/seatable-settings/filter-setter/filter-popover-widgets/department-filter/selected-departments.js +1 -1
- package/dist/basic-sdk/extension/plugins/seatable-tables/seatable-settings/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/table/dialogs/custom-table-size-dialog/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/table/dialogs/split-cell-setting-dialog.js +1 -1
- package/dist/basic-sdk/extension/plugins/table/menu/color-selector-popover/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/table/menu/horizontal-align-popover/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/table/menu/vertical-align-popover/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/table/popover/table-size-popover/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/table/render/table-header/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/text-align/menu/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/video/menu/index.js +2 -2
- package/dist/basic-sdk/extension/plugins/whiteboard/helpers.js +60 -0
- package/dist/basic-sdk/extension/plugins/whiteboard/index.css +5 -0
- package/dist/basic-sdk/extension/plugins/whiteboard/index.js +20 -0
- package/dist/basic-sdk/extension/plugins/whiteboard/menu/index.js +63 -0
- package/dist/basic-sdk/extension/plugins/whiteboard/plugin.js +28 -0
- package/dist/basic-sdk/extension/plugins/whiteboard/render-elem.js +39 -0
- package/dist/basic-sdk/extension/render/custom-element.js +7 -0
- package/dist/basic-sdk/extension/render/element-decorate/rebase-decorate/rebase-delete-modify-decorate.js +1 -1
- package/dist/basic-sdk/extension/render/element-decorate/rebase-decorate/rebase-modify-delete-decorate.js +1 -1
- package/dist/basic-sdk/extension/render/element-decorate/rebase-decorate/rebase-modify-modify-decorate.js +1 -1
- package/dist/basic-sdk/extension/render/render-comment-editor-element.js +9 -0
- package/dist/basic-sdk/extension/toolbar/header-toolbar/insert-toolbar/index.js +3 -2
- package/dist/basic-sdk/extension/toolbar/insert-element-toolbar/index.js +1 -1
- package/dist/basic-sdk/extension/toolbar/side-toolbar/helpers.js +1 -1
- package/dist/basic-sdk/extension/toolbar/side-toolbar/insert-block-menu.js +4 -3
- package/dist/basic-sdk/extension/toolbar/side-toolbar/side-menu.css +5 -0
- package/dist/basic-sdk/extension/toolbar/side-toolbar/side-menu.js +4 -2
- package/dist/basic-sdk/wiki-outline/index.js +1 -1
- package/dist/components/doc-operations/revision-operations/changes-count/index.js +1 -1
- package/dist/components/doc-operations/revision-operations/index.js +1 -1
- package/dist/components/doc-operations/revision-operations/publish-revision/index.js +1 -1
- package/dist/components/doc-operations/revision-operations/revisions/index.js +1 -1
- package/dist/components/doc-operations/revision-operations/revisions/revisions-dialog/index.js +1 -1
- package/dist/components/doc-operations/revision-operations/view-changes/index.js +1 -1
- package/dist/components/tip-dialog/index.js +1 -1
- package/dist/constants/index.js +2 -0
- package/dist/pages/published-revision-viewer.js +1 -1
- package/package.json +1 -1
|
@@ -24,7 +24,7 @@ const VerticalAlignPopover = _ref => {
|
|
|
24
24
|
} = _ref;
|
|
25
25
|
const {
|
|
26
26
|
t
|
|
27
|
-
} = (0, _reactI18next.useTranslation)();
|
|
27
|
+
} = (0, _reactI18next.useTranslation)('sdoc-editor');
|
|
28
28
|
const setVerticalAlignStyle = (0, _react.useCallback)(position => {
|
|
29
29
|
if (readonly) return;
|
|
30
30
|
const alignItems = (0, _KebabToCamel.default)(_constants.TABLE_CELL_STYLE.ALIGN_ITEMS);
|
|
@@ -253,7 +253,7 @@ const MenuItem = _ref2 => {
|
|
|
253
253
|
} = _ref2;
|
|
254
254
|
const {
|
|
255
255
|
t
|
|
256
|
-
} = (0, _reactI18next.useTranslation)();
|
|
256
|
+
} = (0, _reactI18next.useTranslation)('sdoc-editor');
|
|
257
257
|
return /*#__PURE__*/_react.default.createElement("div", {
|
|
258
258
|
id: id,
|
|
259
259
|
className: (0, _classnames.default)('sdoc-selected-table-size-custom', {
|
|
@@ -25,7 +25,7 @@ const TableHeader = _ref => {
|
|
|
25
25
|
} = _ref;
|
|
26
26
|
const {
|
|
27
27
|
t
|
|
28
|
-
} = (0, _reactI18next.useTranslation)();
|
|
28
|
+
} = (0, _reactI18next.useTranslation)('sdoc-editor');
|
|
29
29
|
const columns = (0, _hooks.useResizeHandlersContext)();
|
|
30
30
|
const selectedRange = (0, _hooks.useTableSelectedRangeContext)() || _constants.EMPTY_SELECTED_RANGE;
|
|
31
31
|
const selectColumn = (0, _react.useCallback)(columnIndex => {
|
|
@@ -27,7 +27,7 @@ const TextAlignMenu = _ref => {
|
|
|
27
27
|
const buttonId = 'sdoc-button-text-align';
|
|
28
28
|
const {
|
|
29
29
|
t
|
|
30
|
-
} = (0, _reactI18next.useTranslation)();
|
|
30
|
+
} = (0, _reactI18next.useTranslation)('sdoc-editor');
|
|
31
31
|
const toggle = (0, _react.useCallback)(event => {
|
|
32
32
|
popoverRef.current.toggle();
|
|
33
33
|
setMenuShow(!isShowMenu);
|
|
@@ -23,7 +23,7 @@ const VideoMenu = _ref => {
|
|
|
23
23
|
const menuConfig = _constants.MENUS_CONFIG_MAP[_constants.VIDEO];
|
|
24
24
|
const {
|
|
25
25
|
t
|
|
26
|
-
} = (0, _reactI18next.useTranslation)();
|
|
26
|
+
} = (0, _reactI18next.useTranslation)('sdoc-editor');
|
|
27
27
|
const openLocalVideoDialog = (0, _react.useCallback)(() => {
|
|
28
28
|
eventBus.dispatch(_constants2.INTERNAL_EVENT.INSERT_ELEMENT, {
|
|
29
29
|
type: _constants.LOCAL_VIDEO,
|
|
@@ -44,7 +44,7 @@ const VideoMenu = _ref => {
|
|
|
44
44
|
hideArrow: true,
|
|
45
45
|
fade: false
|
|
46
46
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
47
|
-
className: "sdoc-insert-video-menu-popover-container sdoc-dropdown-menu-container
|
|
47
|
+
className: "sdoc-insert-video-menu-popover-container sdoc-dropdown-menu-container"
|
|
48
48
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
49
49
|
className: "sdoc-dropdown-menu-item",
|
|
50
50
|
onClick: openLocalVideoDialog
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.onCreateWhiteboardFile = exports.isInsertWhiteboardMenuDisabled = exports.insertWhiteboard = void 0;
|
|
8
|
+
var _slate = require("@seafile/slate");
|
|
9
|
+
var _core = require("../../core");
|
|
10
|
+
var _constants = require("../../constants");
|
|
11
|
+
var _eventBus = _interopRequireDefault(require("../../../utils/event-bus"));
|
|
12
|
+
var _constants2 = require("../../../../constants");
|
|
13
|
+
const isInsertWhiteboardMenuDisabled = (editor, readonly) => {
|
|
14
|
+
if (readonly) return true;
|
|
15
|
+
const {
|
|
16
|
+
selection
|
|
17
|
+
} = editor;
|
|
18
|
+
if (selection === null) return true;
|
|
19
|
+
if (!_slate.Range.isCollapsed(selection)) return true;
|
|
20
|
+
const [match] = _slate.Editor.nodes(editor, {
|
|
21
|
+
match: n => {
|
|
22
|
+
let type = (0, _core.getNodeType)(n);
|
|
23
|
+
if (!type && (0, _core.isTextNode)(n) && n.id) {
|
|
24
|
+
const parentNode = (0, _core.getParentNode)(editor.children, n.id);
|
|
25
|
+
type = (0, _core.getNodeType)(parentNode);
|
|
26
|
+
}
|
|
27
|
+
if (type === _constants.CODE_BLOCK) return true;
|
|
28
|
+
if (type.startsWith('header')) return true;
|
|
29
|
+
if (type === _constants.TITLE) return true;
|
|
30
|
+
if (type === _constants.SUBTITLE) return true;
|
|
31
|
+
if (type === _constants.LIST_ITEM) return true;
|
|
32
|
+
if (type === _constants.CHECK_LIST_ITEM) return true;
|
|
33
|
+
if (type === _constants.MULTI_COLUMN) return true;
|
|
34
|
+
if (type === _constants.BLOCKQUOTE) return true;
|
|
35
|
+
if (type === _constants.CALL_OUT) return true;
|
|
36
|
+
if (_slate.Editor.isVoid(editor, n)) return true;
|
|
37
|
+
return false;
|
|
38
|
+
},
|
|
39
|
+
universal: true
|
|
40
|
+
});
|
|
41
|
+
if (match) return true;
|
|
42
|
+
return false;
|
|
43
|
+
};
|
|
44
|
+
exports.isInsertWhiteboardMenuDisabled = isInsertWhiteboardMenuDisabled;
|
|
45
|
+
const insertWhiteboard = () => {};
|
|
46
|
+
exports.insertWhiteboard = insertWhiteboard;
|
|
47
|
+
const onCreateWhiteboardFile = editor => {
|
|
48
|
+
// e.stopPropagation();
|
|
49
|
+
const eventBus = _eventBus.default.getInstance();
|
|
50
|
+
const external_props = {
|
|
51
|
+
insertWhiteboard,
|
|
52
|
+
fileType: 'draw',
|
|
53
|
+
editor
|
|
54
|
+
};
|
|
55
|
+
console.log(2, external_props.insertWhiteboard);
|
|
56
|
+
eventBus.dispatch(_constants2.EXTERNAL_EVENT.CREATE_WHITEBOARD_FILE, {
|
|
57
|
+
...external_props
|
|
58
|
+
});
|
|
59
|
+
};
|
|
60
|
+
exports.onCreateWhiteboardFile = onCreateWhiteboardFile;
|
|
@@ -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
|
+
exports.default = void 0;
|
|
8
|
+
var _constants = require("../../constants");
|
|
9
|
+
var _plugin = _interopRequireDefault(require("./plugin"));
|
|
10
|
+
var _menu = _interopRequireDefault(require("./menu"));
|
|
11
|
+
var _renderElem = require("./render-elem");
|
|
12
|
+
require("./index.css");
|
|
13
|
+
const WhiteboardPlugin = {
|
|
14
|
+
type: _constants.WHITEBOARD,
|
|
15
|
+
nodeType: 'element',
|
|
16
|
+
editorMenus: [_menu.default],
|
|
17
|
+
editorPlugin: _plugin.default,
|
|
18
|
+
renderElements: [_renderElem.renderWhiteboard]
|
|
19
|
+
};
|
|
20
|
+
var _default = exports.default = WhiteboardPlugin;
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.default = void 0;
|
|
9
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
10
|
+
var _reactI18next = require("react-i18next");
|
|
11
|
+
var _reactstrap = require("reactstrap");
|
|
12
|
+
var _dropdownMenuItem = _interopRequireDefault(require("../../../commons/dropdown-menu-item"));
|
|
13
|
+
var _helpers = require("../helpers");
|
|
14
|
+
var _constants = require("../../../constants");
|
|
15
|
+
var _constants2 = require("../../../../constants");
|
|
16
|
+
const WhiteboardMenu = _ref => {
|
|
17
|
+
let {
|
|
18
|
+
editor,
|
|
19
|
+
readonly,
|
|
20
|
+
eventBus,
|
|
21
|
+
toggle
|
|
22
|
+
} = _ref;
|
|
23
|
+
const disabled = (0, _helpers.isInsertWhiteboardMenuDisabled)(editor, readonly);
|
|
24
|
+
const menuConfig = _constants.MENUS_CONFIG_MAP[_constants.WHITEBOARD];
|
|
25
|
+
const {
|
|
26
|
+
t
|
|
27
|
+
} = (0, _reactI18next.useTranslation)();
|
|
28
|
+
const onCreateFile = () => {
|
|
29
|
+
(0, _helpers.onCreateWhiteboardFile)(editor);
|
|
30
|
+
};
|
|
31
|
+
const openSelectSdocFileDialog = (0, _react.useCallback)(() => {
|
|
32
|
+
eventBus.dispatch(_constants2.INTERNAL_EVENT.INSERT_ELEMENT, {
|
|
33
|
+
type: _constants.ELEMENT_TYPE.WHITEBOARD,
|
|
34
|
+
insertWhiteboard: _helpers.insertWhiteboard
|
|
35
|
+
});
|
|
36
|
+
toggle && toggle();
|
|
37
|
+
|
|
38
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
39
|
+
}, [toggle, eventBus]);
|
|
40
|
+
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_dropdownMenuItem.default, {
|
|
41
|
+
disabled: disabled,
|
|
42
|
+
menuConfig: menuConfig,
|
|
43
|
+
className: "pr-2"
|
|
44
|
+
}, !disabled && /*#__PURE__*/_react.default.createElement("i", {
|
|
45
|
+
className: "sdocfont sdoc-right-slide sdoc-dropdown-item-right-icon"
|
|
46
|
+
})), !disabled && /*#__PURE__*/_react.default.createElement(_reactstrap.UncontrolledPopover, {
|
|
47
|
+
target: menuConfig.id,
|
|
48
|
+
trigger: "hover",
|
|
49
|
+
className: "sdoc-menu-popover sdoc-dropdown-menu sdoc-sub-dropdown-menu sdoc-insert-whiteboard-menu-popover",
|
|
50
|
+
placement: "right-start",
|
|
51
|
+
hideArrow: true,
|
|
52
|
+
fade: false
|
|
53
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
54
|
+
className: "sdoc-insert-whiteboard-menu-popover-container sdoc-dropdown-menu-container"
|
|
55
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
56
|
+
className: "sdoc-dropdown-menu-item",
|
|
57
|
+
onClick: openSelectSdocFileDialog
|
|
58
|
+
}, t('Upload_local_whiteboard')), /*#__PURE__*/_react.default.createElement("div", {
|
|
59
|
+
className: "sdoc-dropdown-menu-item",
|
|
60
|
+
onClick: onCreateFile
|
|
61
|
+
}, t('Create_new_whiteboard')))));
|
|
62
|
+
};
|
|
63
|
+
var _default = exports.default = WhiteboardMenu;
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.default = void 0;
|
|
8
|
+
var _react = _interopRequireDefault(require("react"));
|
|
9
|
+
var _constants = require("../../constants");
|
|
10
|
+
const withWhiteboard = editor => {
|
|
11
|
+
const {
|
|
12
|
+
isVoid
|
|
13
|
+
} = editor;
|
|
14
|
+
const newEditor = editor;
|
|
15
|
+
|
|
16
|
+
// Make whiteboard as void node
|
|
17
|
+
newEditor.isVoid = elem => {
|
|
18
|
+
const {
|
|
19
|
+
type
|
|
20
|
+
} = elem;
|
|
21
|
+
if (type === _constants.WHITEBOARD) {
|
|
22
|
+
return true;
|
|
23
|
+
}
|
|
24
|
+
return isVoid(elem);
|
|
25
|
+
};
|
|
26
|
+
return newEditor;
|
|
27
|
+
};
|
|
28
|
+
var _default = exports.default = withWhiteboard;
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.renderWhiteboard = renderWhiteboard;
|
|
9
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
10
|
+
var _eventBus = _interopRequireDefault(require("../../../utils/event-bus"));
|
|
11
|
+
var _constants = require("../../../../constants");
|
|
12
|
+
require("./index.css");
|
|
13
|
+
const Whiteboard = _ref => {
|
|
14
|
+
let {
|
|
15
|
+
editor
|
|
16
|
+
} = _ref;
|
|
17
|
+
// const whiteboardContainer = document.getElementById('sdoc-whiteboard-container');
|
|
18
|
+
const [tldraw, setTldraw] = (0, _react.useState)(null);
|
|
19
|
+
const renderWhiteboardEditor = Tldraw => {
|
|
20
|
+
console.log(4, Tldraw);
|
|
21
|
+
setTldraw( /*#__PURE__*/_react.default.createElement(Tldraw, null));
|
|
22
|
+
};
|
|
23
|
+
(0, _react.useEffect)(() => {
|
|
24
|
+
const eventBus = _eventBus.default.getInstance();
|
|
25
|
+
const unsubscribeWhiteboardEditor = eventBus.subscribe(_constants.EXTERNAL_EVENT.TLDRAW_EDITOR, renderWhiteboardEditor);
|
|
26
|
+
console.log(3, renderWhiteboardEditor);
|
|
27
|
+
return () => {
|
|
28
|
+
unsubscribeWhiteboardEditor();
|
|
29
|
+
};
|
|
30
|
+
}, []);
|
|
31
|
+
return /*#__PURE__*/_react.default.createElement("div", {
|
|
32
|
+
id: "sdoc-whiteboard-container"
|
|
33
|
+
}, tldraw);
|
|
34
|
+
};
|
|
35
|
+
function renderWhiteboard(props, editor) {
|
|
36
|
+
return /*#__PURE__*/_react.default.createElement(Whiteboard, Object.assign({}, props, {
|
|
37
|
+
editor: editor
|
|
38
|
+
}));
|
|
39
|
+
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
3
4
|
Object.defineProperty(exports, "__esModule", {
|
|
4
5
|
value: true
|
|
5
6
|
});
|
|
@@ -12,6 +13,7 @@ var _core = require("../core");
|
|
|
12
13
|
var _helper = require("./helper");
|
|
13
14
|
var _elementType = require("../constants/element-type");
|
|
14
15
|
var _constants2 = require("../../constants");
|
|
16
|
+
var _whiteboard = _interopRequireDefault(require("../plugins/whiteboard"));
|
|
15
17
|
const CustomRenderElement = props => {
|
|
16
18
|
const editor = (0, _slateReact.useSlateStatic)();
|
|
17
19
|
const readonly = (0, _slateReact.useReadOnly)();
|
|
@@ -210,6 +212,11 @@ const CustomRenderElement = props => {
|
|
|
210
212
|
const [renderSeaTableTable] = _plugins.SeaTableViewsPlugin.renderElements;
|
|
211
213
|
return renderSeaTableTable(props, editor);
|
|
212
214
|
}
|
|
215
|
+
case _elementType.WHITEBOARD:
|
|
216
|
+
{
|
|
217
|
+
const [renderWhiteboard] = _whiteboard.default.renderElements;
|
|
218
|
+
return renderWhiteboard(props, editor);
|
|
219
|
+
}
|
|
213
220
|
default:
|
|
214
221
|
{
|
|
215
222
|
const [renderParagraph] = _plugins.ParagraphPlugin.renderElements;
|
|
@@ -19,7 +19,7 @@ const RebaseDeleteModifyDecorate = _ref => {
|
|
|
19
19
|
} = _ref;
|
|
20
20
|
const {
|
|
21
21
|
t
|
|
22
|
-
} = (0, _reactI18next.useTranslation)();
|
|
22
|
+
} = (0, _reactI18next.useTranslation)('sdoc-editor');
|
|
23
23
|
const editor = (0, _slateReact.useSlateStatic)();
|
|
24
24
|
const deleteElement = (0, _react.useCallback)(() => {
|
|
25
25
|
const path = (0, _core.findPath)(editor, element);
|
|
@@ -19,7 +19,7 @@ const RebaseModifyDeleteDecorate = _ref => {
|
|
|
19
19
|
} = _ref;
|
|
20
20
|
const {
|
|
21
21
|
t
|
|
22
|
-
} = (0, _reactI18next.useTranslation)();
|
|
22
|
+
} = (0, _reactI18next.useTranslation)('sdoc-editor');
|
|
23
23
|
const editor = (0, _slateReact.useSlateStatic)();
|
|
24
24
|
const deleteElement = (0, _react.useCallback)(() => {
|
|
25
25
|
const path = (0, _core.findPath)(editor, element);
|
|
@@ -21,7 +21,7 @@ const RebaseModifyModifyDecorate = _ref => {
|
|
|
21
21
|
} = _ref;
|
|
22
22
|
const {
|
|
23
23
|
t
|
|
24
|
-
} = (0, _reactI18next.useTranslation)();
|
|
24
|
+
} = (0, _reactI18next.useTranslation)('sdoc-editor');
|
|
25
25
|
const editor = (0, _slateReact.useSlateStatic)();
|
|
26
26
|
const useMasterChanges = (0, _react.useCallback)(() => {
|
|
27
27
|
const path = (0, _core.findPath)(editor, element);
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
3
4
|
Object.defineProperty(exports, "__esModule", {
|
|
4
5
|
value: true
|
|
5
6
|
});
|
|
@@ -8,6 +9,7 @@ var _slateReact = require("@seafile/slate-react");
|
|
|
8
9
|
var _constants = require("../constants");
|
|
9
10
|
var _plugins = require("../plugins");
|
|
10
11
|
var _core = require("../core");
|
|
12
|
+
var _whiteboard = _interopRequireDefault(require("../plugins/whiteboard"));
|
|
11
13
|
const RenderCommentEditorCustomRenderElement = props => {
|
|
12
14
|
const editor = (0, _slateReact.useSlateStatic)();
|
|
13
15
|
const readonly = (0, _slateReact.useReadOnly)();
|
|
@@ -95,6 +97,13 @@ const RenderCommentEditorCustomRenderElement = props => {
|
|
|
95
97
|
const [renderBlockquote] = _plugins.BlockquotePlugin.renderElements;
|
|
96
98
|
return renderBlockquote(props, editor);
|
|
97
99
|
}
|
|
100
|
+
case _constants.WHITEBOARD:
|
|
101
|
+
{
|
|
102
|
+
const [renderWhiteboard] = _whiteboard.default.renderElements;
|
|
103
|
+
return renderWhiteboard({
|
|
104
|
+
...props
|
|
105
|
+
}, editor);
|
|
106
|
+
}
|
|
98
107
|
default:
|
|
99
108
|
{
|
|
100
109
|
const [renderParagraph] = _plugins.ParagraphPlugin.renderElements;
|
|
@@ -19,6 +19,7 @@ var _menu5 = _interopRequireDefault(require("../../../plugins/sdoc-link/menu"));
|
|
|
19
19
|
var _menu6 = _interopRequireDefault(require("../../../plugins/file-link/menu"));
|
|
20
20
|
var _menu7 = _interopRequireDefault(require("../../../plugins/seatable-column/menu"));
|
|
21
21
|
var _menu8 = _interopRequireDefault(require("../../../plugins/seatable-tables/menu"));
|
|
22
|
+
var _menu9 = _interopRequireDefault(require("../../../plugins/whiteboard/menu"));
|
|
22
23
|
var _eventBus = _interopRequireDefault(require("../../../../utils/event-bus"));
|
|
23
24
|
var _constants = require("../../../../constants");
|
|
24
25
|
require("./index.css");
|
|
@@ -32,7 +33,7 @@ const InsertToolbar = _ref => {
|
|
|
32
33
|
const [isShowMenu, setMenuShow] = (0, _react.useState)(false);
|
|
33
34
|
const {
|
|
34
35
|
t
|
|
35
|
-
} = (0, _reactI18next.useTranslation)();
|
|
36
|
+
} = (0, _reactI18next.useTranslation)('sdoc-editor');
|
|
36
37
|
const popoverRef = (0, _react.useRef)(null);
|
|
37
38
|
const disabled = readonly;
|
|
38
39
|
const insertButtonRef = (0, _react.useRef)(null);
|
|
@@ -95,7 +96,7 @@ const InsertToolbar = _ref => {
|
|
|
95
96
|
style: {
|
|
96
97
|
maxHeight: window.innerHeight - bottom - 100
|
|
97
98
|
}
|
|
98
|
-
}, /*#__PURE__*/_react.default.createElement(_menu.default, props), /*#__PURE__*/_react.default.createElement(_tableMenu.default, props), (editor === null || editor === void 0 ? void 0 : editor.editorType) !== _constants.DOCUMENT_PLUGIN_EDITOR && /*#__PURE__*/_react.default.createElement(_menu2.default, props), /*#__PURE__*/_react.default.createElement(_menu3.default, props), /*#__PURE__*/_react.default.createElement(_menu4.default, props), /*#__PURE__*/_react.default.createElement("div", {
|
|
99
|
+
}, /*#__PURE__*/_react.default.createElement(_menu.default, props), /*#__PURE__*/_react.default.createElement(_tableMenu.default, props), (editor === null || editor === void 0 ? void 0 : editor.editorType) !== _constants.DOCUMENT_PLUGIN_EDITOR && /*#__PURE__*/_react.default.createElement(_menu2.default, props), /*#__PURE__*/_react.default.createElement(_menu9.default, props), /*#__PURE__*/_react.default.createElement(_menu3.default, props), /*#__PURE__*/_react.default.createElement(_menu4.default, props), /*#__PURE__*/_react.default.createElement("div", {
|
|
99
100
|
className: "sdoc-dropdown-menu-divider"
|
|
100
101
|
}), editor.columns && /*#__PURE__*/_react.default.createElement(_menu7.default, props), editor.tables && /*#__PURE__*/_react.default.createElement(_menu8.default, props), !editor.tables && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_menu5.default, props), /*#__PURE__*/_react.default.createElement(_menu6.default, props)))));
|
|
101
102
|
};
|
|
@@ -168,7 +168,7 @@ const QuickInsertBlockMenu = _ref => {
|
|
|
168
168
|
// eslint-disable-next-line react/jsx-indent
|
|
169
169
|
_react.default.createElement(_dropdownMenuItem.default, {
|
|
170
170
|
isHidden: !quickInsertMenuSearchMap[_constants.TABLE],
|
|
171
|
-
key: "sdoc-insert-menu-
|
|
171
|
+
key: "sdoc-insert-menu-table",
|
|
172
172
|
menuConfig: {
|
|
173
173
|
..._constants.SIDE_INSERT_MENUS_CONFIG[_constants.ELEMENT_TYPE.TABLE]
|
|
174
174
|
},
|
|
@@ -138,7 +138,7 @@ const isVoidNode = node => {
|
|
|
138
138
|
};
|
|
139
139
|
exports.isVoidNode = isVoidNode;
|
|
140
140
|
const isNotSupportTransform = node => {
|
|
141
|
-
if (node.type && [_constants.CODE_BLOCK, _constants.TABLE, _constants.CALL_OUT, _constants.VIDEO, _constants.SEATABLE_TABLE].includes(node.type)) {
|
|
141
|
+
if (node.type && [_constants.CODE_BLOCK, _constants.TABLE, _constants.CALL_OUT, _constants.VIDEO, _constants.SEATABLE_TABLE, _constants.WHITEBOARD].includes(node.type)) {
|
|
142
142
|
return true;
|
|
143
143
|
}
|
|
144
144
|
return false;
|
|
@@ -34,7 +34,7 @@ const InsertBlockMenu = _ref => {
|
|
|
34
34
|
const editor = (0, _slateReact.useSlateStatic)();
|
|
35
35
|
const {
|
|
36
36
|
t
|
|
37
|
-
} = (0, _reactI18next.useTranslation)();
|
|
37
|
+
} = (0, _reactI18next.useTranslation)('sdoc-editor');
|
|
38
38
|
const onInsertImageToggle = (0, _react.useCallback)(() => {
|
|
39
39
|
const eventBus = _eventBus.default.getInstance();
|
|
40
40
|
if (insertPosition === _constants.INSERT_POSITION.CURRENT) {
|
|
@@ -150,6 +150,7 @@ const InsertBlockMenu = _ref => {
|
|
|
150
150
|
onClick: onInsertVideoToggle
|
|
151
151
|
}), /*#__PURE__*/_react.default.createElement(_dropdownMenuItem.default, {
|
|
152
152
|
isHidden: !insertMenuSearchMap[_constants.ELEMENT_TYPE.TABLE],
|
|
153
|
+
key: "sdoc-insert-menu-table",
|
|
153
154
|
menuConfig: {
|
|
154
155
|
..._constants.SIDE_INSERT_MENUS_CONFIG[_constants.ELEMENT_TYPE.TABLE]
|
|
155
156
|
},
|
|
@@ -160,8 +161,8 @@ const InsertBlockMenu = _ref => {
|
|
|
160
161
|
editor: editor,
|
|
161
162
|
target: "sdoc-side-menu-item-table",
|
|
162
163
|
trigger: "hover",
|
|
163
|
-
placement: "
|
|
164
|
-
popperClassName: "sdoc-side-menu-table-size",
|
|
164
|
+
placement: "left-start",
|
|
165
|
+
popperClassName: "sdoc-side-menu-table-size sdoc-insert-element-table-size-wrapper",
|
|
165
166
|
createTable: createTable
|
|
166
167
|
})), /*#__PURE__*/_react.default.createElement(_dropdownMenuItem.default, {
|
|
167
168
|
isHidden: !insertMenuSearchMap[_constants.ELEMENT_TYPE.LINK],
|
|
@@ -150,11 +150,13 @@ const SideMenu = (_ref, ref) => {
|
|
|
150
150
|
onChange: onChange,
|
|
151
151
|
onCompositionStart: onCompositionStart,
|
|
152
152
|
onCompositionEnd: onCompositionEnd
|
|
153
|
-
})), isNodeEmpty && /*#__PURE__*/_react.default.createElement(
|
|
153
|
+
})), isNodeEmpty && /*#__PURE__*/_react.default.createElement("div", {
|
|
154
|
+
className: "sdoc-side-menu-insert-wrapper"
|
|
155
|
+
}, /*#__PURE__*/_react.default.createElement(_insertBlockMenu.default, {
|
|
154
156
|
isNodeEmpty: isNodeEmpty,
|
|
155
157
|
slateNode: slateNode,
|
|
156
158
|
insertMenuSearchMap: insertMenuSearchMap
|
|
157
|
-
}), !isNodeEmpty && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, transformMenuSearchMap['searching'] && isDisplayCategoryTitle(transformMenuSearchMap, insertBelowMenuSearchMap) && /*#__PURE__*/_react.default.createElement(_dropdownMenuItem.default, {
|
|
159
|
+
})), !isNodeEmpty && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, transformMenuSearchMap['searching'] && isDisplayCategoryTitle(transformMenuSearchMap, insertBelowMenuSearchMap) && /*#__PURE__*/_react.default.createElement(_dropdownMenuItem.default, {
|
|
158
160
|
menuConfig: {
|
|
159
161
|
text: 'Transform_to'
|
|
160
162
|
},
|
|
@@ -26,7 +26,7 @@ const Outline = _ref => {
|
|
|
26
26
|
} = _ref;
|
|
27
27
|
const {
|
|
28
28
|
t
|
|
29
|
-
} = (0, _reactI18next.useTranslation)();
|
|
29
|
+
} = (0, _reactI18next.useTranslation)('sdoc-editor');
|
|
30
30
|
const scrollRef = (0, _useScrollContext.useScrollContext)();
|
|
31
31
|
const [headerList, setHeaderList] = (0, _react.useState)([]);
|
|
32
32
|
const [activeId, setActiveId] = (0, _react.useState)('');
|
|
@@ -17,7 +17,7 @@ const ChangesCount = _ref => {
|
|
|
17
17
|
} = _ref;
|
|
18
18
|
const {
|
|
19
19
|
t
|
|
20
|
-
} = (0, _reactI18next.useTranslation)();
|
|
20
|
+
} = (0, _reactI18next.useTranslation)('sdoc-editor');
|
|
21
21
|
const [currentDiffIndex, setDiffIndex] = (0, _react.useState)(0);
|
|
22
22
|
const [changes, setChanges] = (0, _react.useState)([]);
|
|
23
23
|
const intervalRef = (0, _react.useRef)();
|
|
@@ -32,7 +32,7 @@ const RevisionOperations = _ref => {
|
|
|
32
32
|
const isSdocRevision = _context.default.getSetting('isSdocRevision');
|
|
33
33
|
const {
|
|
34
34
|
t
|
|
35
|
-
} = (0, _reactI18next.useTranslation)();
|
|
35
|
+
} = (0, _reactI18next.useTranslation)('sdoc-editor');
|
|
36
36
|
const [isShowTip, setShowTip] = (0, _react.useState)(false);
|
|
37
37
|
const [tipType, setTipType] = (0, _react.useState)('');
|
|
38
38
|
const [mergeValue, setMergeValue] = (0, _react.useState)(null);
|
|
@@ -14,7 +14,7 @@ const PublishRevision = _ref => {
|
|
|
14
14
|
} = _ref;
|
|
15
15
|
const {
|
|
16
16
|
t
|
|
17
|
-
} = (0, _reactI18next.useTranslation)();
|
|
17
|
+
} = (0, _reactI18next.useTranslation)('sdoc-editor');
|
|
18
18
|
const onPublishRevision = (0, _react.useCallback)(event => {
|
|
19
19
|
event.stopPropagation();
|
|
20
20
|
event.nativeEvent.stopImmediatePropagation();
|
|
@@ -19,7 +19,7 @@ const Revisions = () => {
|
|
|
19
19
|
const eventBus = _basicSdk.EventBus.getInstance();
|
|
20
20
|
const {
|
|
21
21
|
t
|
|
22
|
-
} = (0, _reactI18next.useTranslation)();
|
|
22
|
+
} = (0, _reactI18next.useTranslation)('sdoc-editor');
|
|
23
23
|
const [revisionsCount, setRevisionsCount] = (0, _react.useState)(0);
|
|
24
24
|
const [isShowRevisions, setShowRevisions] = (0, _react.useState)(false);
|
|
25
25
|
const autoIncrementRevisionsCount = (0, _react.useCallback)(() => {
|
package/dist/components/doc-operations/revision-operations/revisions/revisions-dialog/index.js
CHANGED
|
@@ -29,7 +29,7 @@ const RevisionsDialog = _ref => {
|
|
|
29
29
|
const revisionListRef = (0, _react.useRef)(null);
|
|
30
30
|
const {
|
|
31
31
|
t
|
|
32
|
-
} = (0, _reactI18next.useTranslation)();
|
|
32
|
+
} = (0, _reactI18next.useTranslation)('sdoc-editor');
|
|
33
33
|
const [isLoading, setLoading] = (0, _react.useState)(true);
|
|
34
34
|
const [revisions, setRevisions] = (0, _react.useState)([]);
|
|
35
35
|
const [page, setPage] = (0, _react.useState)(1);
|
|
@@ -19,7 +19,7 @@ const ViewChanges = _ref => {
|
|
|
19
19
|
} = _ref;
|
|
20
20
|
const {
|
|
21
21
|
t
|
|
22
|
-
} = (0, _reactI18next.useTranslation)();
|
|
22
|
+
} = (0, _reactI18next.useTranslation)('sdoc-editor');
|
|
23
23
|
(0, _react.useEffect)(() => {
|
|
24
24
|
const url = new URL(window.location.href);
|
|
25
25
|
const searchParams = new URLSearchParams(url.search);
|
|
@@ -26,7 +26,7 @@ const TipDialog = _ref => {
|
|
|
26
26
|
} = _ref;
|
|
27
27
|
const {
|
|
28
28
|
t
|
|
29
|
-
} = (0, _reactI18next.useTranslation)();
|
|
29
|
+
} = (0, _reactI18next.useTranslation)('sdoc-editor');
|
|
30
30
|
const [isSubmitting, setSubmitting] = (0, _react.useState)();
|
|
31
31
|
const closeDialog = (0, _react.useCallback)(() => {
|
|
32
32
|
if (NOT_CLOSE_DIALOG_TIP_TYPE.includes(tipType)) return;
|
package/dist/constants/index.js
CHANGED
|
@@ -36,6 +36,8 @@ const EXTERNAL_EVENT = exports.EXTERNAL_EVENT = {
|
|
|
36
36
|
PARTICIPANT_REMOVED: 'participant-removed',
|
|
37
37
|
CREATE_SDOC_FILE: 'create_sdoc_file',
|
|
38
38
|
CREATE_WIKI_PAGE: 'create_wiki_page',
|
|
39
|
+
CREATE_WHITEBOARD_FILE: 'create_whiteboard_file',
|
|
40
|
+
TLDRAW_EDITOR: 'tldraw_editor',
|
|
39
41
|
// wiki
|
|
40
42
|
INSERT_LINK: 'insert_link',
|
|
41
43
|
// document
|
|
@@ -22,7 +22,7 @@ const PublishedRevisionViewer = () => {
|
|
|
22
22
|
_context.default.initApi();
|
|
23
23
|
const {
|
|
24
24
|
t
|
|
25
|
-
} = (0, _reactI18next.useTranslation)();
|
|
25
|
+
} = (0, _reactI18next.useTranslation)('sdoc-editor');
|
|
26
26
|
const [isFirstLoading, setIsFirstLoading] = (0, _react.useState)(true);
|
|
27
27
|
const [errorMessage, setErrorMessage] = (0, _react.useState)('');
|
|
28
28
|
const [isShowChanges, setShowChanges] = (0, _react.useState)(false);
|