@seafile/seafile-editor 1.0.2 → 1.0.4
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 -8
- package/dist/constants/hot-keys.js +1 -7
- package/dist/containers/article-info/index.js +24 -34
- package/dist/containers/custom/get-event-transfer.js +10 -16
- package/dist/containers/custom/set-event-transfer.js +10 -16
- package/dist/containers/hotkeys-helper/classify-hotkeys.js +20 -25
- package/dist/containers/hotkeys-helper/index.js +32 -35
- package/dist/containers/loading/index.js +11 -32
- package/dist/containers/outline/index.js +41 -51
- package/dist/containers/outline/outline-item.js +15 -21
- package/dist/editors/plain-markdown-editor/code-mirror.js +51 -75
- package/dist/editors/plain-markdown-editor/index.js +90 -107
- package/dist/editors/simple-slate-editor /index.js +43 -57
- package/dist/editors/simple-slate-editor /with-props-editor.js +4 -10
- package/dist/editors/slate-editor/editor-help/index.js +24 -37
- package/dist/editors/slate-editor/index.js +50 -64
- package/dist/editors/slate-editor/with-props-editor.js +4 -10
- package/dist/editors/slate-viewer/index.js +25 -31
- package/dist/extension/commons/element-popover/index.js +30 -55
- package/dist/extension/commons/index.js +3 -26
- package/dist/extension/commons/menu/index.js +4 -21
- package/dist/extension/commons/menu/menu-drop-down.js +50 -63
- package/dist/extension/commons/menu/menu-group.js +4 -11
- package/dist/extension/commons/menu/menu-item.js +25 -30
- package/dist/extension/commons/tooltip/index.js +14 -19
- package/dist/extension/constants/element-types.js +22 -28
- package/dist/extension/constants/index.js +15 -37
- package/dist/extension/constants/keyboard.js +3 -9
- package/dist/extension/constants/menus-config.js +118 -105
- package/dist/extension/core/index.js +3 -38
- package/dist/extension/core/queries/index.js +209 -304
- package/dist/extension/core/transforms/focus-editor.js +7 -13
- package/dist/extension/core/transforms/index.js +4 -49
- package/dist/extension/core/transforms/move-children.js +18 -25
- package/dist/extension/core/transforms/remove-node-children.js +8 -27
- package/dist/extension/core/transforms/replace-node-children.js +14 -19
- package/dist/extension/core/utils/index.js +36 -44
- package/dist/extension/editor.js +8 -15
- package/dist/extension/index.js +7 -48
- package/dist/extension/plugins/blockquote/helpers.js +38 -57
- package/dist/extension/plugins/blockquote/index.js +8 -15
- package/dist/extension/plugins/blockquote/menu/index.js +20 -25
- package/dist/extension/plugins/blockquote/plugin.js +35 -41
- package/dist/extension/plugins/blockquote/render-elem.js +9 -14
- package/dist/extension/plugins/check-list/helper.js +14 -24
- package/dist/extension/plugins/check-list/index.js +10 -17
- package/dist/extension/plugins/check-list/menu/index.js +21 -29
- package/dist/extension/plugins/check-list/plugin.js +24 -26
- package/dist/extension/plugins/check-list/render-elem.js +22 -28
- package/dist/extension/plugins/clear-format/helpers.js +25 -47
- package/dist/extension/plugins/clear-format/menu/index.js +22 -29
- package/dist/extension/plugins/code-block/helpers.js +74 -126
- package/dist/extension/plugins/code-block/index.js +10 -18
- package/dist/extension/plugins/code-block/menu/index.js +20 -27
- package/dist/extension/plugins/code-block/plugin.js +123 -144
- package/dist/extension/plugins/code-block/render-elem/constant.js +15 -11
- package/dist/extension/plugins/code-block/render-elem/index.js +30 -39
- package/dist/extension/plugins/code-block/render-elem/language-selector.js +19 -27
- package/dist/extension/plugins/formula/helper.js +39 -45
- package/dist/extension/plugins/formula/index.js +10 -17
- package/dist/extension/plugins/formula/menu/formula-modal.js +37 -52
- package/dist/extension/plugins/formula/menu/index.js +34 -50
- package/dist/extension/plugins/formula/plugin.js +12 -14
- package/dist/extension/plugins/formula/render-elem.js +27 -33
- package/dist/extension/plugins/header/helper.js +35 -48
- package/dist/extension/plugins/header/index.js +10 -17
- package/dist/extension/plugins/header/menu/index.js +52 -66
- package/dist/extension/plugins/header/plugin.js +72 -83
- package/dist/extension/plugins/header/render-elem.js +15 -20
- package/dist/extension/plugins/image/helper.js +28 -37
- package/dist/extension/plugins/image/index.js +10 -17
- package/dist/extension/plugins/image/menu/image-menu-dialog.js +31 -42
- package/dist/extension/plugins/image/menu/image-menu-popover.js +35 -67
- package/dist/extension/plugins/image/menu/index.js +24 -34
- package/dist/extension/plugins/image/plugin.js +18 -18
- package/dist/extension/plugins/image/render-element/image-previewer.js +32 -42
- package/dist/extension/plugins/image/render-element/index.js +58 -74
- package/dist/extension/plugins/index.js +18 -94
- package/dist/extension/plugins/link/helper.js +102 -139
- package/dist/extension/plugins/link/index.js +10 -17
- package/dist/extension/plugins/link/menu/index.js +46 -62
- package/dist/extension/plugins/link/menu/link-modal.js +67 -87
- package/dist/extension/plugins/link/plugin.js +52 -56
- package/dist/extension/plugins/link/render-elem/index.js +39 -54
- package/dist/extension/plugins/link/render-elem/link-popover.js +38 -42
- package/dist/extension/plugins/list/constant.js +2 -8
- package/dist/extension/plugins/list/helpers.js +40 -54
- package/dist/extension/plugins/list/index.js +10 -17
- package/dist/extension/plugins/list/menu/index.js +23 -33
- package/dist/extension/plugins/list/plugin/index.js +28 -31
- package/dist/extension/plugins/list/plugin/insert-break-list.js +9 -15
- package/dist/extension/plugins/list/plugin/insert-fragment-list.js +86 -109
- package/dist/extension/plugins/list/plugin/normalize-list.js +31 -42
- package/dist/extension/plugins/list/plugin/on-tab-handle.js +35 -34
- package/dist/extension/plugins/list/queries/index.js +22 -30
- package/dist/extension/plugins/list/render-elem/index.js +27 -27
- package/dist/extension/plugins/list/transforms/index.js +11 -75
- package/dist/extension/plugins/list/transforms/insert-list-item.js +38 -47
- package/dist/extension/plugins/list/transforms/move-list-item-down.js +22 -32
- package/dist/extension/plugins/list/transforms/move-list-item-up.js +45 -56
- package/dist/extension/plugins/list/transforms/move-list-items-to-list.js +25 -31
- package/dist/extension/plugins/list/transforms/move-list-items.js +37 -44
- package/dist/extension/plugins/list/transforms/normalize-list-item.js +57 -81
- package/dist/extension/plugins/list/transforms/normalize-nested-list.js +17 -26
- package/dist/extension/plugins/list/transforms/remove-first-list-item.js +12 -19
- package/dist/extension/plugins/list/transforms/transforms-to-list.js +60 -84
- package/dist/extension/plugins/list/transforms/unwrap-list.js +20 -29
- package/dist/extension/plugins/node-id/constants.js +9 -15
- package/dist/extension/plugins/node-id/helpers.js +33 -35
- package/dist/extension/plugins/node-id/index.js +4 -11
- package/dist/extension/plugins/node-id/with-node-id.js +18 -26
- package/dist/extension/plugins/paragraph/helper.js +7 -13
- package/dist/extension/plugins/paragraph/index.js +8 -15
- package/dist/extension/plugins/paragraph/plugin.js +25 -27
- package/dist/extension/plugins/paragraph/render-elem.js +9 -14
- package/dist/extension/plugins/table/constant.js +3 -9
- package/dist/extension/plugins/table/helper.js +133 -154
- package/dist/extension/plugins/table/index.js +11 -19
- package/dist/extension/plugins/table/menu/index.js +26 -38
- package/dist/extension/plugins/table/menu/table-operator.js +62 -77
- package/dist/extension/plugins/table/menu/table-size-selector.js +41 -62
- package/dist/extension/plugins/table/model.js +39 -41
- package/dist/extension/plugins/table/plugin.js +95 -102
- package/dist/extension/plugins/table/render-elem/context-menu.js +42 -65
- package/dist/extension/plugins/table/render-elem/index.js +85 -93
- package/dist/extension/plugins/table/table-operations.js +101 -118
- package/dist/extension/plugins/text-style/helpers.js +18 -28
- package/dist/extension/plugins/text-style/index.js +8 -15
- package/dist/extension/plugins/text-style/menu/index.js +19 -25
- package/dist/extension/plugins/text-style/plugin.js +16 -21
- package/dist/extension/plugins/text-style/render-elem.js +28 -33
- package/dist/extension/render/render-element.js +26 -47
- package/dist/extension/render/render-leaf.js +9 -18
- package/dist/extension/toolbar/header-toolbar/index.js +66 -84
- package/dist/extension/toolbar/index.js +2 -13
- package/dist/extension/toolbar/user-help/shortcut-dialog.js +108 -131
- package/dist/hooks/use-mathjax.js +9 -20
- package/dist/hooks/use-scroll-context.js +7 -12
- package/dist/hooks/use-selection-update.js +9 -21
- package/dist/index.js +9 -80
- package/dist/pages/markdown-editor.js +30 -43
- package/dist/pages/markdown-view.js +25 -37
- package/dist/pages/rich-markdown-editor.js +54 -67
- package/dist/pages/simple-editor.js +29 -42
- package/dist/slate-convert/html-to-slate/constants.js +26 -32
- package/dist/slate-convert/html-to-slate/helper.js +1 -7
- package/dist/slate-convert/html-to-slate/index.js +44 -51
- package/dist/slate-convert/html-to-slate/rules/blockquote.js +10 -15
- package/dist/slate-convert/html-to-slate/rules/check-list.js +10 -15
- package/dist/slate-convert/html-to-slate/rules/code-block.js +40 -51
- package/dist/slate-convert/html-to-slate/rules/header.js +11 -16
- package/dist/slate-convert/html-to-slate/rules/image.js +10 -15
- package/dist/slate-convert/html-to-slate/rules/index.js +11 -18
- package/dist/slate-convert/html-to-slate/rules/link.js +11 -16
- package/dist/slate-convert/html-to-slate/rules/list.js +21 -26
- package/dist/slate-convert/html-to-slate/rules/paragraph.js +10 -15
- package/dist/slate-convert/html-to-slate/rules/table.js +14 -19
- package/dist/slate-convert/html-to-slate/rules/text.js +14 -19
- package/dist/slate-convert/index.js +8 -34
- package/dist/slate-convert/md-to-html/index.js +26 -31
- package/dist/slate-convert/md-to-html/sanitize-schema.js +5 -12
- package/dist/slate-convert/md-to-slate/index.js +17 -23
- package/dist/slate-convert/md-to-slate/transform.js +183 -175
- package/dist/slate-convert/slate-to-md/index.js +14 -20
- package/dist/slate-convert/slate-to-md/transform.js +76 -87
- package/dist/utils/common.js +8 -15
- package/dist/utils/deserialize-html.js +118 -166
- package/dist/utils/dom-utils.js +18 -22
- package/dist/utils/event-bus.js +27 -47
- package/dist/utils/event-handler.js +29 -38
- package/dist/utils/object-utils.js +39 -62
- package/package.json +5 -4
|
@@ -1,174 +1,122 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
Object.defineProperty(exports, "__esModule", {
|
|
5
|
-
value: true
|
|
6
|
-
});
|
|
7
|
-
exports.unwrapCodeBlock = exports.transformToCodeBlock = exports.setCodeBlockLanguage = exports.isMenuDisabled = exports.isInCodeBlock = exports.getCodeBlockNodeEntry = void 0;
|
|
8
|
-
var _createForOfIteratorHelper2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/createForOfIteratorHelper"));
|
|
9
|
-
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
|
|
10
|
-
var _slate = require("slate");
|
|
11
|
-
var _elementTypes = require("../../constants/element-types");
|
|
12
|
-
var _core = require("../../core");
|
|
13
|
-
var _constant = require("./render-elem/constant");
|
|
1
|
+
import { Editor, Element, Node, Point, Range, Transforms, isBlock } from 'slate';
|
|
2
|
+
import { CODE_BLOCK, CODE_LINE, PARAGRAPH } from '../../constants/element-types';
|
|
3
|
+
import { focusEditor, generateElement, getSelectedElems, getSelectedNodeEntryByType } from '../../core';
|
|
14
4
|
// eslint-disable-next-line no-unused-vars
|
|
15
|
-
|
|
16
|
-
|
|
5
|
+
import { EXPLAIN_TEXT, LANGUAGE_MAP } from './render-elem/constant';
|
|
6
|
+
export const isMenuDisabled = (editor, readonly) => {
|
|
17
7
|
if (readonly) return true;
|
|
18
|
-
|
|
8
|
+
const {
|
|
9
|
+
selection
|
|
10
|
+
} = editor;
|
|
19
11
|
if (!selection) return true;
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
return editor.isVoid(node);
|
|
23
|
-
});
|
|
12
|
+
const selectedElements = getSelectedElems(editor);
|
|
13
|
+
const isSelectedVoid = selectedElements.find(node => editor.isVoid(node));
|
|
24
14
|
if (isSelectedVoid) return true;
|
|
25
15
|
// Disable the menu when selection is not in the paragraph or code block
|
|
26
|
-
|
|
27
|
-
return [_elementTypes.CODE_BLOCK, _elementTypes.PARAGRAPH, _elementTypes.CODE_LINE].includes(node.type);
|
|
28
|
-
});
|
|
16
|
+
const isEnable = selectedElements.every(node => [CODE_BLOCK, PARAGRAPH, CODE_LINE].includes(node.type));
|
|
29
17
|
return !isEnable;
|
|
30
18
|
};
|
|
31
|
-
|
|
19
|
+
export const getCodeBlockNodeEntry = editor => {
|
|
32
20
|
if (!editor.selection) return;
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
mode: 'highest'
|
|
38
|
-
}),
|
|
39
|
-
_Editor$nodes2 = (0, _slicedToArray2.default)(_Editor$nodes, 1),
|
|
40
|
-
codeBlock = _Editor$nodes2[0];
|
|
21
|
+
const [codeBlock] = Editor.nodes(editor, {
|
|
22
|
+
match: node => node.type === CODE_BLOCK,
|
|
23
|
+
mode: 'highest'
|
|
24
|
+
});
|
|
41
25
|
return codeBlock;
|
|
42
26
|
};
|
|
43
|
-
|
|
27
|
+
export const isInCodeBlock = editor => {
|
|
44
28
|
if (!editor.selection) return false;
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
},
|
|
49
|
-
mode: 'highest'
|
|
50
|
-
}),
|
|
51
|
-
_Editor$nodes4 = (0, _slicedToArray2.default)(_Editor$nodes3, 1),
|
|
52
|
-
codeBlock = _Editor$nodes4[0];
|
|
53
|
-
if (!codeBlock) return false;
|
|
54
|
-
var selectedElements = (0, _core.getSelectedElems)(editor);
|
|
55
|
-
var isInCodeBlock = !selectedElements.find(function (element) {
|
|
56
|
-
return ![_elementTypes.CODE_BLOCK, _elementTypes.CODE_LINE].includes(element.type);
|
|
29
|
+
const [codeBlock] = Editor.nodes(editor, {
|
|
30
|
+
match: node => node.type === CODE_BLOCK,
|
|
31
|
+
mode: 'highest'
|
|
57
32
|
});
|
|
33
|
+
if (!codeBlock) return false;
|
|
34
|
+
const selectedElements = getSelectedElems(editor);
|
|
35
|
+
const isInCodeBlock = !selectedElements.find(element => ![CODE_BLOCK, CODE_LINE].includes(element.type));
|
|
58
36
|
return isInCodeBlock;
|
|
59
37
|
};
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
return node.type === _elementTypes.CODE_BLOCK ? ++codeBlockNum : codeBlockNum;
|
|
64
|
-
}, 0);
|
|
38
|
+
export const transformToCodeBlock = editor => {
|
|
39
|
+
const selectedElements = getSelectedElems(editor);
|
|
40
|
+
const selectedCodeBlockNum = selectedElements.reduce((codeBlockNum, node) => node.type === CODE_BLOCK ? ++codeBlockNum : codeBlockNum, 0);
|
|
65
41
|
if (selectedCodeBlockNum > 0) return;
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
42
|
+
const originSelection = editor.selection;
|
|
43
|
+
const {
|
|
44
|
+
anchor: originAnchor,
|
|
45
|
+
focus: originFocus
|
|
46
|
+
} = originSelection;
|
|
47
|
+
const textList = [];
|
|
48
|
+
const nodeEntries = Editor.nodes(editor, {
|
|
49
|
+
match: node => editor.children.includes(node),
|
|
74
50
|
// Match the highest level node that custom selected
|
|
75
51
|
universal: true
|
|
76
52
|
});
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
var nodeEntry = _step.value;
|
|
82
|
-
var _nodeEntry = (0, _slicedToArray2.default)(nodeEntry, 1),
|
|
83
|
-
node = _nodeEntry[0];
|
|
84
|
-
if (node) {
|
|
85
|
-
textList.push(_slate.Node.string(node));
|
|
86
|
-
}
|
|
53
|
+
for (let nodeEntry of nodeEntries) {
|
|
54
|
+
const [node] = nodeEntry;
|
|
55
|
+
if (node) {
|
|
56
|
+
textList.push(Node.string(node));
|
|
87
57
|
}
|
|
88
|
-
// Generate code block
|
|
89
|
-
} catch (err) {
|
|
90
|
-
_iterator.e(err);
|
|
91
|
-
} finally {
|
|
92
|
-
_iterator.f();
|
|
93
58
|
}
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
var codeBlock = (0, _core.generateElement)(_elementTypes.CODE_BLOCK, {
|
|
59
|
+
// Generate code block
|
|
60
|
+
const codeBlockChildren = textList.map(text => generateElement(CODE_LINE, {
|
|
61
|
+
childrenOrText: text
|
|
62
|
+
}));
|
|
63
|
+
const codeBlock = generateElement(CODE_BLOCK, {
|
|
100
64
|
childrenOrText: codeBlockChildren,
|
|
101
65
|
props: {
|
|
102
|
-
lang:
|
|
66
|
+
lang: EXPLAIN_TEXT
|
|
103
67
|
}
|
|
104
68
|
});
|
|
105
|
-
|
|
69
|
+
Transforms.removeNodes(editor, {
|
|
106
70
|
at: editor.selection,
|
|
107
71
|
mode: 'highest',
|
|
108
|
-
match:
|
|
109
|
-
return _slate.Element.isElement(node) && (0, _slate.isBlock)(editor, node);
|
|
110
|
-
}
|
|
72
|
+
match: node => Element.isElement(node) && isBlock(editor, node)
|
|
111
73
|
});
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
74
|
+
const selectedPath = Editor.path(editor, originSelection);
|
|
75
|
+
const isCollapsed = editor.selection && Range.isCollapsed(editor.selection);
|
|
76
|
+
const beginPath = Point.isBefore(originAnchor, originFocus) ? originAnchor.path : originFocus.path;
|
|
77
|
+
const focusPoint = Point.isAfter(originFocus, originAnchor) ? originFocus : originAnchor;
|
|
78
|
+
const insertPath = selectedPath && Object.keys(selectedPath).length ? [selectedPath[0]] : [beginPath[0]];
|
|
79
|
+
Transforms.insertNodes(editor, codeBlock, {
|
|
118
80
|
at: insertPath
|
|
119
81
|
});
|
|
120
|
-
|
|
82
|
+
focusEditor(editor, isCollapsed ? Editor.end(editor, insertPath) : focusPoint);
|
|
121
83
|
};
|
|
122
|
-
|
|
123
|
-
|
|
84
|
+
export const unwrapCodeBlock = editor => {
|
|
85
|
+
const selectedCodeBlock = getSelectedNodeEntryByType(editor, CODE_BLOCK);
|
|
124
86
|
if (!selectedCodeBlock) return;
|
|
125
|
-
|
|
126
|
-
|
|
87
|
+
const selectedCodeBlockPath = selectedCodeBlock[1];
|
|
88
|
+
const codeLineEntries = Editor.nodes(editor, {
|
|
127
89
|
at: selectedCodeBlockPath,
|
|
128
|
-
match:
|
|
129
|
-
return node.type === _elementTypes.CODE_LINE;
|
|
130
|
-
}
|
|
90
|
+
match: node => node.type === CODE_LINE
|
|
131
91
|
});
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
codeLineNode = _codeLineEntry[0];
|
|
140
|
-
var paragraph = (0, _core.generateElement)(_elementTypes.PARAGRAPH, {
|
|
141
|
-
childrenOrText: _slate.Node.string(codeLineNode)
|
|
142
|
-
});
|
|
143
|
-
paragraphNodes.push(paragraph);
|
|
144
|
-
}
|
|
145
|
-
} catch (err) {
|
|
146
|
-
_iterator2.e(err);
|
|
147
|
-
} finally {
|
|
148
|
-
_iterator2.f();
|
|
92
|
+
const paragraphNodes = [];
|
|
93
|
+
for (const codeLineEntry of codeLineEntries) {
|
|
94
|
+
const [codeLineNode] = codeLineEntry;
|
|
95
|
+
const paragraph = generateElement(PARAGRAPH, {
|
|
96
|
+
childrenOrText: Node.string(codeLineNode)
|
|
97
|
+
});
|
|
98
|
+
paragraphNodes.push(paragraph);
|
|
149
99
|
}
|
|
150
|
-
|
|
100
|
+
Transforms.removeNodes(editor, {
|
|
151
101
|
at: selectedCodeBlockPath,
|
|
152
|
-
match:
|
|
153
|
-
return node.type === _elementTypes.CODE_BLOCK;
|
|
154
|
-
},
|
|
102
|
+
match: node => node.type === CODE_BLOCK,
|
|
155
103
|
mode: 'highest'
|
|
156
104
|
});
|
|
157
|
-
|
|
105
|
+
Transforms.insertNodes(editor, paragraphNodes, {
|
|
158
106
|
at: selectedCodeBlockPath
|
|
159
107
|
});
|
|
160
|
-
|
|
161
|
-
|
|
108
|
+
const focusPath = [selectedCodeBlockPath[0] + paragraphNodes.length - 1];
|
|
109
|
+
focusEditor(editor, Editor.end(editor, focusPath));
|
|
162
110
|
};
|
|
163
111
|
|
|
164
112
|
/**
|
|
165
113
|
* @param {object} editor
|
|
166
114
|
* @param {keyof LANGUAGE_MAP} [lang = EXPLAIN_TEXT] by default is 'none'
|
|
167
115
|
*/
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
lang
|
|
116
|
+
export const setCodeBlockLanguage = (editor, lang) => {
|
|
117
|
+
const selectedNode = getSelectedNodeEntryByType(editor, CODE_BLOCK);
|
|
118
|
+
Transforms.setNodes(editor, {
|
|
119
|
+
lang
|
|
172
120
|
}, {
|
|
173
121
|
at: selectedNode[1]
|
|
174
122
|
});
|
|
@@ -1,20 +1,12 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
});
|
|
8
|
-
exports.default = void 0;
|
|
9
|
-
var _elementTypes = require("../../constants/element-types");
|
|
10
|
-
var _menu = _interopRequireDefault(require("./menu"));
|
|
11
|
-
var _plugin = _interopRequireDefault(require("./plugin"));
|
|
12
|
-
var _renderElem = _interopRequireWildcard(require("./render-elem"));
|
|
13
|
-
var CodeBlockPlugin = {
|
|
14
|
-
type: _elementTypes.CODE_BLOCK,
|
|
1
|
+
import { CODE_BLOCK } from '../../constants/element-types';
|
|
2
|
+
import CodeBlockMenu from './menu';
|
|
3
|
+
import withCodeBlock from './plugin';
|
|
4
|
+
import renderCodeBlock, { renderCodeLine } from './render-elem';
|
|
5
|
+
const CodeBlockPlugin = {
|
|
6
|
+
type: CODE_BLOCK,
|
|
15
7
|
nodeType: 'element',
|
|
16
|
-
editorMenus: [
|
|
17
|
-
editorPlugin:
|
|
18
|
-
renderElements: [
|
|
8
|
+
editorMenus: [CodeBlockMenu],
|
|
9
|
+
editorPlugin: withCodeBlock,
|
|
10
|
+
renderElements: [renderCodeBlock, renderCodeLine]
|
|
19
11
|
};
|
|
20
|
-
|
|
12
|
+
export default CodeBlockPlugin;
|
|
@@ -1,37 +1,30 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
var CodeBlockMenu = function CodeBlockMenu(_ref) {
|
|
15
|
-
var isRichEditor = _ref.isRichEditor,
|
|
16
|
-
className = _ref.className,
|
|
17
|
-
readonly = _ref.readonly,
|
|
18
|
-
editor = _ref.editor;
|
|
1
|
+
import React, { useCallback, useMemo } from 'react';
|
|
2
|
+
import { MenuItem } from '../../../commons';
|
|
3
|
+
import { CODE_BLOCK } from '../../../constants/element-types';
|
|
4
|
+
import { isInCodeBlock, isMenuDisabled, transformToCodeBlock, unwrapCodeBlock } from '../helpers';
|
|
5
|
+
import { MENUS_CONFIG_MAP } from '../../../constants';
|
|
6
|
+
const menuConfig = MENUS_CONFIG_MAP[CODE_BLOCK];
|
|
7
|
+
const CodeBlockMenu = _ref => {
|
|
8
|
+
let {
|
|
9
|
+
isRichEditor,
|
|
10
|
+
className,
|
|
11
|
+
readonly,
|
|
12
|
+
editor
|
|
13
|
+
} = _ref;
|
|
19
14
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
}, [editor.selection]);
|
|
23
|
-
var onMousedown = (0, _react.useCallback)(function (e) {
|
|
15
|
+
const isActive = useMemo(() => isInCodeBlock(editor), [editor.selection]);
|
|
16
|
+
const onMousedown = useCallback(e => {
|
|
24
17
|
e.preventDefault();
|
|
25
|
-
isActive ?
|
|
18
|
+
isActive ? unwrapCodeBlock(editor) : transformToCodeBlock(editor);
|
|
26
19
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
27
20
|
}, [isActive]);
|
|
28
|
-
return /*#__PURE__*/
|
|
29
|
-
type:
|
|
21
|
+
return /*#__PURE__*/React.createElement(MenuItem, Object.assign({
|
|
22
|
+
type: CODE_BLOCK,
|
|
30
23
|
isRichEditor: isRichEditor,
|
|
31
24
|
className: className,
|
|
32
|
-
disabled:
|
|
25
|
+
disabled: isMenuDisabled(editor, readonly),
|
|
33
26
|
isActive: isActive,
|
|
34
27
|
onMouseDown: onMousedown
|
|
35
28
|
}, menuConfig));
|
|
36
29
|
};
|
|
37
|
-
|
|
30
|
+
export default CodeBlockMenu;
|