@seafile/seafile-editor 1.0.93-alpha → 1.0.93-alpha1
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.
|
@@ -11,7 +11,7 @@ var _slateReact = require("slate-react");
|
|
|
11
11
|
var _slate = require("slate");
|
|
12
12
|
var _extension = require("../../extension");
|
|
13
13
|
var _eventBus = _interopRequireDefault(require("../../utils/event-bus"));
|
|
14
|
-
var
|
|
14
|
+
var _inlineEventHandel = _interopRequireDefault(require("../../utils/inline-event-handel"));
|
|
15
15
|
var _withPropsEditor = _interopRequireDefault(require("./with-props-editor"));
|
|
16
16
|
var _core = require("../../extension/core");
|
|
17
17
|
var _common = require("../../utils/common");
|
|
@@ -27,7 +27,8 @@ const InlineEditor = _ref => {
|
|
|
27
27
|
onContentChanged,
|
|
28
28
|
isSupportFormula,
|
|
29
29
|
onExpandEditorToggle,
|
|
30
|
-
handelEnableEdit
|
|
30
|
+
handelEnableEdit,
|
|
31
|
+
closeEditor
|
|
31
32
|
} = _ref;
|
|
32
33
|
const [slateValue, setSlateValue] = (0, _react.useState)(value);
|
|
33
34
|
const focusRangeRef = (0, _react.useRef)(null);
|
|
@@ -40,8 +41,8 @@ const InlineEditor = _ref => {
|
|
|
40
41
|
});
|
|
41
42
|
}, [columns, editorApi, onSave]);
|
|
42
43
|
const eventProxy = (0, _react.useMemo)(() => {
|
|
43
|
-
return new
|
|
44
|
-
}, [editor]);
|
|
44
|
+
return new _inlineEventHandel.default(editor, closeEditor);
|
|
45
|
+
}, [editor, closeEditor]);
|
|
45
46
|
const decorate = (0, _extension.useHighlight)(editor);
|
|
46
47
|
const onChange = (0, _react.useCallback)(value => {
|
|
47
48
|
setSlateValue(value);
|
|
@@ -8,7 +8,6 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
8
8
|
exports.default = void 0;
|
|
9
9
|
var _react = _interopRequireWildcard(require("react"));
|
|
10
10
|
var _isHotkey = _interopRequireDefault(require("is-hotkey"));
|
|
11
|
-
var _constants = require("../../constants");
|
|
12
11
|
var _clickOutside = _interopRequireDefault(require("./click-outside"));
|
|
13
12
|
var _fallbackEditor = _interopRequireDefault(require("./fallback-editor"));
|
|
14
13
|
var _normalEditor = _interopRequireDefault(require("./normal-editor"));
|
|
@@ -36,38 +35,29 @@ const LongTextInlineEditor = /*#__PURE__*/(0, _react.forwardRef)((_ref, ref) =>
|
|
|
36
35
|
} = (0, _react.useMemo)(() => {
|
|
37
36
|
return (0, _getBrowserInfo.default)(isCheckBrowser);
|
|
38
37
|
}, [isCheckBrowser]);
|
|
39
|
-
const onHotKey = (0, _react.useCallback)(event => {
|
|
40
|
-
const keyCode = event.keyCode;
|
|
41
|
-
if ((0, _isHotkey.default)('space') || (0, _isHotkey.default)('enter') || [_constants.KeyCodes.PageUp, _constants.KeyCodes.PageDown, _constants.KeyCodes.LeftArrow, _constants.KeyCodes.UpArrow, _constants.KeyCodes.RightArrow, _constants.KeyCodes.DownArrow].includes(keyCode)) {
|
|
42
|
-
event.stopPropagation();
|
|
43
|
-
return;
|
|
44
|
-
}
|
|
45
|
-
const isModP = (0, _isHotkey.default)('mod+p', event);
|
|
46
|
-
if (keyCode === _constants.KeyCodes.Esc || isModP) {
|
|
47
|
-
event.preventDefault();
|
|
48
|
-
!isModP && event.stopPropagation();
|
|
49
|
-
if (longTextValueChangedRef.current) {
|
|
50
|
-
onSaveEditorValue(valueRef.current);
|
|
51
|
-
}
|
|
52
|
-
setEnableEdit(false);
|
|
53
|
-
return;
|
|
54
|
-
}
|
|
55
|
-
}, [onSaveEditorValue]);
|
|
56
38
|
const openEditor = (0, _react.useCallback)(() => {
|
|
57
39
|
setEnableEdit(true);
|
|
58
|
-
|
|
59
|
-
}, [onHotKey]);
|
|
40
|
+
}, []);
|
|
60
41
|
const closeEditor = (0, _react.useCallback)(() => {
|
|
61
42
|
if (longTextValueChangedRef.current) {
|
|
62
43
|
onSaveEditorValue(valueRef.current);
|
|
63
44
|
}
|
|
64
45
|
setEnableEdit(false);
|
|
65
|
-
|
|
66
|
-
}, [longTextValueChangedRef, valueRef, onSaveEditorValue, onHotKey]);
|
|
46
|
+
}, [longTextValueChangedRef, valueRef, onSaveEditorValue]);
|
|
67
47
|
const onEditorValueChanged = (0, _react.useCallback)(value => {
|
|
68
48
|
valueRef.current = value;
|
|
69
49
|
longTextValueChangedRef.current = true;
|
|
70
50
|
}, []);
|
|
51
|
+
const onHotKey = (0, _react.useCallback)(event => {
|
|
52
|
+
const keyCode = event.keyCode;
|
|
53
|
+
const isModP = (0, _isHotkey.default)('mod+p', event);
|
|
54
|
+
if (keyCode === 27 || isModP) {
|
|
55
|
+
event.preventDefault();
|
|
56
|
+
!isModP && event.stopPropagation();
|
|
57
|
+
closeEditor();
|
|
58
|
+
return;
|
|
59
|
+
}
|
|
60
|
+
}, [closeEditor]);
|
|
71
61
|
(0, _react.useImperativeHandle)(ref, () => {
|
|
72
62
|
return {
|
|
73
63
|
openEditor: openEditor,
|
|
@@ -81,7 +71,8 @@ const LongTextInlineEditor = /*#__PURE__*/(0, _react.forwardRef)((_ref, ref) =>
|
|
|
81
71
|
return /*#__PURE__*/_react.default.createElement(_clickOutside.default, {
|
|
82
72
|
onClickOutside: closeEditor
|
|
83
73
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
84
|
-
className: "w-100"
|
|
74
|
+
className: "w-100",
|
|
75
|
+
onKeyDown: onHotKey
|
|
85
76
|
}, isWindowsWechat ? /*#__PURE__*/_react.default.createElement(_fallbackEditor.default, {
|
|
86
77
|
enableEdit: enableEdit,
|
|
87
78
|
value: valueRef.current.text,
|
|
@@ -89,7 +80,6 @@ const LongTextInlineEditor = /*#__PURE__*/(0, _react.forwardRef)((_ref, ref) =>
|
|
|
89
80
|
closeEditor: closeEditor
|
|
90
81
|
}) : /*#__PURE__*/_react.default.createElement(_normalEditor.default, {
|
|
91
82
|
enableEdit: enableEdit,
|
|
92
|
-
handelEnableEdit: handelEnableEdit,
|
|
93
83
|
lang: lang,
|
|
94
84
|
headerName: headerName,
|
|
95
85
|
value: valueRef.current.text,
|
|
@@ -98,7 +88,9 @@ const LongTextInlineEditor = /*#__PURE__*/(0, _react.forwardRef)((_ref, ref) =>
|
|
|
98
88
|
isCheckBrowser: isCheckBrowser,
|
|
99
89
|
editorApi: editorApi,
|
|
100
90
|
onSaveEditorValue: onSaveEditorValue,
|
|
101
|
-
onEditorValueChanged: onEditorValueChanged
|
|
91
|
+
onEditorValueChanged: onEditorValueChanged,
|
|
92
|
+
handelEnableEdit: handelEnableEdit,
|
|
93
|
+
closeEditor: closeEditor
|
|
102
94
|
})));
|
|
103
95
|
});
|
|
104
96
|
var _default = exports.default = LongTextInlineEditor;
|
|
@@ -15,7 +15,6 @@ var _classnames = _interopRequireDefault(require("classnames"));
|
|
|
15
15
|
const NormalEditor = _ref => {
|
|
16
16
|
let {
|
|
17
17
|
enableEdit,
|
|
18
|
-
handelEnableEdit,
|
|
19
18
|
lang,
|
|
20
19
|
headerName,
|
|
21
20
|
value: propsValue,
|
|
@@ -24,7 +23,9 @@ const NormalEditor = _ref => {
|
|
|
24
23
|
isCheckBrowser = false,
|
|
25
24
|
editorApi,
|
|
26
25
|
onSaveEditorValue,
|
|
27
|
-
onEditorValueChanged
|
|
26
|
+
onEditorValueChanged,
|
|
27
|
+
closeEditor,
|
|
28
|
+
handelEnableEdit
|
|
28
29
|
} = _ref;
|
|
29
30
|
const editorContainerRef = (0, _react.useRef)(null);
|
|
30
31
|
const editorRef = (0, _react.useRef)(null);
|
|
@@ -118,6 +119,7 @@ const NormalEditor = _ref => {
|
|
|
118
119
|
isInline: true,
|
|
119
120
|
value: valueRef.current.text,
|
|
120
121
|
handelEnableEdit: handelEnableEdit,
|
|
122
|
+
closeEditor: closeEditor,
|
|
121
123
|
onSave: handelAutoSave,
|
|
122
124
|
editorApi: editorApi,
|
|
123
125
|
onContentChanged: onContentChanged,
|
|
@@ -0,0 +1,51 @@
|
|
|
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 _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/defineProperty"));
|
|
9
|
+
var _isHotkey = _interopRequireDefault(require("is-hotkey"));
|
|
10
|
+
class EventProxy {
|
|
11
|
+
constructor(_editor, closeEditor) {
|
|
12
|
+
(0, _defineProperty2.default)(this, "onKeyDown", event => {
|
|
13
|
+
const editor = this.editor;
|
|
14
|
+
if (editor.onHotKeyDown) {
|
|
15
|
+
const isHandled = editor.onHotKeyDown(event);
|
|
16
|
+
if (isHandled) return;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
// Disable the default 'save page'
|
|
20
|
+
if ((0, _isHotkey.default)('mod+s', event)) {
|
|
21
|
+
event.preventDefault();
|
|
22
|
+
const {
|
|
23
|
+
onSave
|
|
24
|
+
} = this.editor;
|
|
25
|
+
onSave && onSave();
|
|
26
|
+
return;
|
|
27
|
+
}
|
|
28
|
+
if ((0, _isHotkey.default)('esc', event)) {
|
|
29
|
+
this.closeEditor && this.closeEditor();
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
// Disable default 'tab' behavior
|
|
33
|
+
if ((0, _isHotkey.default)('tab', event)) {
|
|
34
|
+
event.preventDefault();
|
|
35
|
+
} else {
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
});
|
|
39
|
+
(0, _defineProperty2.default)(this, "onCopy", event => {
|
|
40
|
+
const editor = this.editor;
|
|
41
|
+
if (editor.onCopy) {
|
|
42
|
+
const isHandled = editor.onCopy(event);
|
|
43
|
+
if (isHandled) return true;
|
|
44
|
+
}
|
|
45
|
+
return false;
|
|
46
|
+
});
|
|
47
|
+
this.editor = _editor;
|
|
48
|
+
this.closeEditor = closeEditor;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
var _default = exports.default = EventProxy;
|