@seafile/sdoc-editor 2.0.164 → 2.0.166

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.
@@ -4,7 +4,7 @@
4
4
  position: absolute;
5
5
  width: 400px;
6
6
  max-width: 400px;
7
- max-height: 350px;
7
+ max-height: 300px;
8
8
  /* The same as hierarchy of comment drawer */
9
9
  z-index: 103;
10
10
  box-shadow: 0 1px 3px rgba(0, 0, 0, .15), 0 4px 8px 3px rgba(0, 0, 0, .15);
@@ -4,7 +4,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
4
4
  Object.defineProperty(exports, "__esModule", {
5
5
  value: true
6
6
  });
7
- exports.setHeaderType = exports.isSelectionInHeader = exports.isMenuDisabled = exports.getHeaderType = void 0;
7
+ exports.setHeaderType = exports.isSelectionInHeader = exports.isNextChildIsImage = exports.isMenuDisabled = exports.getHeaderType = void 0;
8
8
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
9
9
  var _slate = require("@seafile/slate");
10
10
  var _constants = require("../../constants");
@@ -71,4 +71,22 @@ var setHeaderType = exports.setHeaderType = function setHeaderType(editor, type)
71
71
  _slate.Transforms.setNodes(editor, {
72
72
  type: type
73
73
  });
74
+ };
75
+ var isNextChildIsImage = exports.isNextChildIsImage = function isNextChildIsImage(editor, headerNode) {
76
+ var selection = editor.selection;
77
+ var children = headerNode.children;
78
+ if (children.length === 1) return false;
79
+ var _selection$anchor = selection.anchor,
80
+ path = _selection$anchor.path,
81
+ offset = _selection$anchor.offset;
82
+ var _path$slice = path.slice(-1),
83
+ _path$slice2 = (0, _slicedToArray2["default"])(_path$slice, 1),
84
+ nodeIndex = _path$slice2[0];
85
+ if (nodeIndex + 1 > children.length) return false;
86
+ var beforeText = children[nodeIndex].text ? children[nodeIndex].text : '';
87
+ if (beforeText.length === 0) return false;
88
+ if (beforeText.length !== offset) return false;
89
+ var nextNode = children[nodeIndex + 1];
90
+ if (nextNode.type === 'image' && _slate.Node.string(headerNode).length === offset) return true;
91
+ return false;
74
92
  };
@@ -57,10 +57,10 @@ var withHeader = function withHeader(editor) {
57
57
  if ((0, _core.isCursorAtBlockStart)(newEditor)) {
58
58
  var _match = (0, _slicedToArray2["default"])(match, 2),
59
59
  currentNode = _match[0],
60
- path = _match[1];
60
+ _path = _match[1];
61
61
  var newNode = (0, _core.generateEmptyElement)(currentNode.type);
62
62
  _slate.Transforms.insertNodes(editor, newNode, {
63
- at: path
63
+ at: _path
64
64
  });
65
65
  return;
66
66
  }
@@ -68,12 +68,25 @@ var withHeader = function withHeader(editor) {
68
68
  var nextNode = _slate.Editor.next(editor, {
69
69
  at: match[1]
70
70
  });
71
+ var _match2 = (0, _slicedToArray2["default"])(match, 2),
72
+ headerNode = _match2[0],
73
+ path = _match2[1];
74
+ if ((0, _helpers2.isNextChildIsImage)(editor, headerNode)) {
75
+ insertBreak();
76
+ var nextPath = _slate.Path.next(path);
77
+ _slate.Transforms.setNodes(editor, {
78
+ type: _constants.PARAGRAPH
79
+ }, {
80
+ at: nextPath
81
+ });
82
+ return;
83
+ }
71
84
  if (isAtLineEnd && nextNode && editor.children.length === 2) {
72
85
  var _nextNode = (0, _slicedToArray2["default"])(nextNode, 2),
73
86
  node = _nextNode[0],
74
- _path = _nextNode[1];
87
+ _path2 = _nextNode[1];
75
88
  if (node && node.children[0].text === '') {
76
- _slate.Transforms.select(editor, _path);
89
+ _slate.Transforms.select(editor, _path2);
77
90
  return;
78
91
  }
79
92
  }
@@ -161,9 +161,13 @@ var insertFragmentList = exports.insertFragmentList = function insertFragmentLis
161
161
  }
162
162
  var nodes = fragment;
163
163
  if (isListRoot(fragment[0]) && !isEmptySelection) {
164
- nodes = [{
165
- text: ''
166
- }].concat((0, _toConsumableArray2["default"])(fragment));
164
+ if ((0, _core.isSelectionAtBlockEnd)(editor)) {
165
+ nodes = [(0, _core.generateDefaultText)()].concat((0, _toConsumableArray2["default"])(fragment));
166
+ } else if ((0, _core.isSelectionAtBlockStart)(editor)) {
167
+ nodes = [].concat((0, _toConsumableArray2["default"])(fragment), [(0, _core.generateDefaultText)()]);
168
+ } else {
169
+ nodes = [(0, _core.generateDefaultText)()].concat((0, _toConsumableArray2["default"])(fragment), [(0, _core.generateDefaultText)()]);
170
+ }
167
171
  }
168
172
  return _insertFragment(nodes);
169
173
  }
@@ -64,5 +64,5 @@
64
64
  }
65
65
 
66
66
  .sdoc-file-name-insert-collector {
67
- padding: 0 .25em;
67
+ padding: 0;
68
68
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@seafile/sdoc-editor",
3
- "version": "2.0.164",
3
+ "version": "2.0.166",
4
4
  "main": "dist/index.js",
5
5
  "scripts": {
6
6
  "test": "jest",
@@ -71,5 +71,5 @@
71
71
  "publishConfig": {
72
72
  "access": "public"
73
73
  },
74
- "gitHead": "7c190264fb16c94c25e82ccdf780b7513b6d5fd4"
74
+ "gitHead": "6dc46fa6f9dd24cf662a49a9704ff1df8179bf17"
75
75
  }