@seafile/seafile-editor 1.0.88 → 1.0.90
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/constants/event-types.js +2 -1
- package/dist/extension/commons/more-menu/index.js +23 -2
- package/dist/extension/plugins/image/helper.js +1 -0
- package/dist/extension/plugins/image/menu/image-menu-popover.js +0 -2
- package/dist/extension/plugins/image/menu/index.js +8 -0
- package/dist/extension/plugins/image/plugin.js +0 -2
- package/dist/pages/longtext-inline-editor/index.css +29 -0
- package/package.json +1 -1
|
@@ -10,7 +10,8 @@ const INTERNAL_EVENTS = exports.INTERNAL_EVENTS = {
|
|
|
10
10
|
ON_OPEN_LINK_MODAL: 'on_open_link_modal',
|
|
11
11
|
ON_CLOSE_LINK_POPOVER: 'on_close_link_popover',
|
|
12
12
|
ON_OPEN_FORMULA_DIALOG: 'on_open_formula_dialog',
|
|
13
|
-
ON_SELECT_ALL_CELL: 'on_select_all_cell'
|
|
13
|
+
ON_SELECT_ALL_CELL: 'on_select_all_cell',
|
|
14
|
+
ON_TOGGLE_IMAGE_POPOVER: 'on_toggle_image_popover'
|
|
14
15
|
};
|
|
15
16
|
const EXTERNAL_EVENTS = exports.EXTERNAL_EVENTS = {
|
|
16
17
|
ON_HELP_INFO_TOGGLE: 'on_help_info_toggle',
|
|
@@ -1,14 +1,17 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
4
5
|
Object.defineProperty(exports, "__esModule", {
|
|
5
6
|
value: true
|
|
6
7
|
});
|
|
7
8
|
exports.default = void 0;
|
|
8
|
-
var _react =
|
|
9
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
9
10
|
var _classnames = _interopRequireDefault(require("classnames"));
|
|
10
11
|
var _reactstrap = require("reactstrap");
|
|
11
12
|
var _constants = require("../../constants");
|
|
13
|
+
var _eventBus = _interopRequireDefault(require("../../../utils/event-bus"));
|
|
14
|
+
var _eventTypes = require("../../../constants/event-types");
|
|
12
15
|
require("./index.css");
|
|
13
16
|
const MoreMenu = _ref => {
|
|
14
17
|
let {
|
|
@@ -17,6 +20,8 @@ const MoreMenu = _ref => {
|
|
|
17
20
|
isRichEditor,
|
|
18
21
|
children
|
|
19
22
|
} = _ref;
|
|
23
|
+
const popoverRef = (0, _react.useRef)(null);
|
|
24
|
+
const imagePopoverRef = (0, _react.useRef)(false);
|
|
20
25
|
const validClassName = (0, _classnames.default)(className, {
|
|
21
26
|
'sf-rich-editor': isRichEditor,
|
|
22
27
|
'sf-icon-btn': true,
|
|
@@ -24,6 +29,20 @@ const MoreMenu = _ref => {
|
|
|
24
29
|
'sf-icon-btn-hover': !disabled
|
|
25
30
|
});
|
|
26
31
|
const config = _constants.MENUS_CONFIG_MAP[_constants.MORE_OPERATION];
|
|
32
|
+
const toggle = (0, _react.useCallback)(() => {
|
|
33
|
+
if (imagePopoverRef.current) return;
|
|
34
|
+
popoverRef.current.toggle();
|
|
35
|
+
}, []);
|
|
36
|
+
const toggleImagePopover = (0, _react.useCallback)(isPopoverShow => {
|
|
37
|
+
imagePopoverRef.current = isPopoverShow;
|
|
38
|
+
}, []);
|
|
39
|
+
(0, _react.useEffect)(() => {
|
|
40
|
+
const eventBus = _eventBus.default.getInstance();
|
|
41
|
+
const unsubscribe = eventBus.subscribe(_eventTypes.INTERNAL_EVENTS.ON_TOGGLE_IMAGE_POPOVER, toggleImagePopover);
|
|
42
|
+
return () => unsubscribe();
|
|
43
|
+
|
|
44
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
45
|
+
}, []);
|
|
27
46
|
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("button", {
|
|
28
47
|
className: validClassName,
|
|
29
48
|
type: "button",
|
|
@@ -36,7 +55,9 @@ const MoreMenu = _ref => {
|
|
|
36
55
|
trigger: "legacy",
|
|
37
56
|
placement: "bottom-end",
|
|
38
57
|
hideArrow: true,
|
|
39
|
-
fade: false
|
|
58
|
+
fade: false,
|
|
59
|
+
toggle: toggle,
|
|
60
|
+
ref: popoverRef
|
|
40
61
|
}, children));
|
|
41
62
|
};
|
|
42
63
|
MoreMenu.defaultProps = {
|
|
@@ -12,7 +12,6 @@ var _imageMenuDialog = _interopRequireDefault(require("./image-menu-dialog"));
|
|
|
12
12
|
var _eventBus = _interopRequireDefault(require("../../../../utils/event-bus"));
|
|
13
13
|
var _eventTypes = require("../../../../constants/event-types");
|
|
14
14
|
var _helper = require("../helper");
|
|
15
|
-
var _core = require("../../../core");
|
|
16
15
|
var _constants = require("../../../../constants");
|
|
17
16
|
require("./style.css");
|
|
18
17
|
const ImageMenuPopover = /*#__PURE__*/_react.default.forwardRef((_ref, ref) => {
|
|
@@ -39,7 +38,6 @@ const ImageMenuPopover = /*#__PURE__*/_react.default.forwardRef((_ref, ref) => {
|
|
|
39
38
|
const file = e.target.files[0];
|
|
40
39
|
(0, _helper.handleUpdateImage)(editor, file);
|
|
41
40
|
handelClosePopover();
|
|
42
|
-
(0, _core.focusEditor)(editor);
|
|
43
41
|
}, [editor, handelClosePopover]);
|
|
44
42
|
const onToggleImageDialog = (0, _react.useCallback)(() => {
|
|
45
43
|
setIsShowInternetImageModal(false);
|
|
@@ -9,6 +9,8 @@ exports.default = void 0;
|
|
|
9
9
|
var _react = _interopRequireWildcard(require("react"));
|
|
10
10
|
var _elementTypes = require("../../../constants/element-types");
|
|
11
11
|
var _menusConfig = require("../../../constants/menus-config");
|
|
12
|
+
var _eventBus = _interopRequireDefault(require("../../../../utils/event-bus"));
|
|
13
|
+
var _eventTypes = require("../../../../constants/event-types");
|
|
12
14
|
var _helper = require("../helper");
|
|
13
15
|
var _commons = require("../../../commons");
|
|
14
16
|
var _imageMenuPopover = _interopRequireDefault(require("./image-menu-popover"));
|
|
@@ -31,6 +33,10 @@ const ImageMenu = _ref => {
|
|
|
31
33
|
}
|
|
32
34
|
setIsShowImagePopover(false);
|
|
33
35
|
unregisterEventHandler();
|
|
36
|
+
setTimeout(() => {
|
|
37
|
+
const eventBus = _eventBus.default.getInstance();
|
|
38
|
+
eventBus.dispatch(_eventTypes.INTERNAL_EVENTS.ON_TOGGLE_IMAGE_POPOVER, false);
|
|
39
|
+
}, 150);
|
|
34
40
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
35
41
|
}, []);
|
|
36
42
|
const registerEventHandler = (0, _react.useCallback)(() => {
|
|
@@ -43,6 +49,7 @@ const ImageMenu = _ref => {
|
|
|
43
49
|
e.stopPropagation();
|
|
44
50
|
e.nativeEvent.stopImmediatePropagation();
|
|
45
51
|
const state = !isShowImagePopover;
|
|
52
|
+
const eventBus = _eventBus.default.getInstance();
|
|
46
53
|
if (state) {
|
|
47
54
|
setIsShowImagePopover(state);
|
|
48
55
|
registerEventHandler();
|
|
@@ -50,6 +57,7 @@ const ImageMenu = _ref => {
|
|
|
50
57
|
setIsShowImagePopover(state);
|
|
51
58
|
unregisterEventHandler();
|
|
52
59
|
}
|
|
60
|
+
eventBus.dispatch(_eventTypes.INTERNAL_EVENTS.ON_TOGGLE_IMAGE_POPOVER, state);
|
|
53
61
|
}, [isShowImagePopover, registerEventHandler, unregisterEventHandler]);
|
|
54
62
|
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_commons.MenuItem, Object.assign({
|
|
55
63
|
type: Image,
|
|
@@ -6,7 +6,6 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
exports.default = void 0;
|
|
7
7
|
var _constants = require("../../constants");
|
|
8
8
|
var _elementTypes = require("../../constants/element-types");
|
|
9
|
-
var _core = require("../../core");
|
|
10
9
|
var _helper = require("./helper");
|
|
11
10
|
const withImages = editor => {
|
|
12
11
|
const {
|
|
@@ -33,7 +32,6 @@ const withImages = editor => {
|
|
|
33
32
|
if (data.types && data.types.includes('Files') && data.files[0].type.includes(_elementTypes.IMAGE)) {
|
|
34
33
|
const file = data.files[0];
|
|
35
34
|
(0, _helper.handleUpdateImage)(newEditor, file);
|
|
36
|
-
(0, _core.focusEditor)(newEditor);
|
|
37
35
|
return;
|
|
38
36
|
}
|
|
39
37
|
return insertData(data);
|
|
@@ -64,3 +64,32 @@
|
|
|
64
64
|
.sf-long-text-inline-editor-container .article>div>:first-child {
|
|
65
65
|
margin-top: 0;
|
|
66
66
|
}
|
|
67
|
+
|
|
68
|
+
.sf-long-text-inline-editor-container .sf-image-wrapper .full-screen {
|
|
69
|
+
align-items: center;
|
|
70
|
+
background-color: #00000080;
|
|
71
|
+
border: none;
|
|
72
|
+
border-radius: 3px;
|
|
73
|
+
box-shadow: none;
|
|
74
|
+
display: flex;
|
|
75
|
+
height: 28px;
|
|
76
|
+
justify-content: center;
|
|
77
|
+
line-height: 28px;
|
|
78
|
+
padding: 0;
|
|
79
|
+
position: absolute;
|
|
80
|
+
right: 10px;
|
|
81
|
+
top: 10px;
|
|
82
|
+
-webkit-user-select: none !important;
|
|
83
|
+
user-select: none !important;
|
|
84
|
+
width: 28px;
|
|
85
|
+
z-index: 1000;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
.sf-long-text-inline-editor-container .sf-image-wrapper .full-screen:hover {
|
|
89
|
+
background-color: #00000080;
|
|
90
|
+
display: flex;
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
.sf-long-text-inline-editor-container .sf-image-wrapper .full-screen .iconfont {
|
|
94
|
+
color: #fff;
|
|
95
|
+
}
|