@seafile/sdoc-editor 3.0.197 → 3.0.199

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.
@@ -80,7 +80,7 @@
80
80
  }
81
81
 
82
82
  .sdoc-dropdown-menu .sdoc-dropdown-item-content .sdoc-dropdown-item-content-icon {
83
- margin-right: 12px;
83
+ margin-right: 8px;
84
84
  }
85
85
 
86
86
  .sdoc-dropdown-menu .sdoc-arrow-right {
@@ -168,7 +168,7 @@ var CommentItemContent = function CommentItemContent(_ref) {
168
168
  onClick: markAsResolved
169
169
  }, /*#__PURE__*/_react["default"].createElement("i", {
170
170
  className: "sdocfont sdoc-check-mark"
171
- })), /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
171
+ })), !isDropdownOpen && /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
172
172
  target: "tooltip_".concat(menuId)
173
173
  }, t('Resolved_tip'))), /*#__PURE__*/_react["default"].createElement(_reactstrap.Dropdown, {
174
174
  id: targetId,
@@ -131,7 +131,7 @@ var GlobalCommentHeader = function GlobalCommentHeader(_ref2) {
131
131
  id: "comment-types"
132
132
  }, /*#__PURE__*/_react["default"].createElement("i", {
133
133
  className: "sdocfont sdoc-filter1"
134
- }), isMounted && /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
134
+ }), isMounted && !isDropdownOpen && /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
135
135
  target: "comment-types"
136
136
  }, t('Filter'))), /*#__PURE__*/_react["default"].createElement(_reactstrap.DropdownMenu, {
137
137
  className: "sdoc-dropdown-menu sdoc-comment-filter-dropdown",
@@ -145,7 +145,7 @@ var ColorMenu = function ColorMenu(_ref) {
145
145
  className: "sdoc-color-toggle sdoc-menu-with-dropdown-triangle"
146
146
  }, /*#__PURE__*/_react["default"].createElement("i", {
147
147
  className: "sdoc-menu-with-dropdown-triangle-icon sdocfont sdoc-".concat(isShowMenu ? 'arrow-up' : 'arrow-down')
148
- }))), text && /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
148
+ }))), text && !isShowMenu && /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
149
149
  target: buttonId
150
150
  }, t(text)), !disabled && /*#__PURE__*/_react["default"].createElement(_reactstrap.UncontrolledPopover, {
151
151
  target: id,
@@ -23,7 +23,9 @@ var MenuItem = function MenuItem(_ref) {
23
23
  iconClass = _ref.iconClass,
24
24
  id = _ref.id,
25
25
  text = _ref.text,
26
- ariaLabel = _ref.ariaLabel;
26
+ ariaLabel = _ref.ariaLabel,
27
+ _ref$isShowPopover = _ref.isShowPopover,
28
+ isShowPopover = _ref$isShowPopover === void 0 ? false : _ref$isShowPopover;
27
29
  var _useTranslation = (0, _reactI18next.useTranslation)('sdoc-editor'),
28
30
  t = _useTranslation.t;
29
31
  var onClick = (0, _react.useCallback)(function (event) {
@@ -52,7 +54,7 @@ var MenuItem = function MenuItem(_ref) {
52
54
  className: "sdoc-link-menu-item"
53
55
  }, /*#__PURE__*/_react["default"].createElement("span", null, t(text)), /*#__PURE__*/_react["default"].createElement("i", {
54
56
  className: "sdocfont sdoc-arrow-down"
55
- }))), /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
57
+ }))), !isShowPopover && /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
56
58
  target: id
57
59
  }, t(text)));
58
60
  };
@@ -1,11 +1,13 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard")["default"];
3
4
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault")["default"];
4
5
  Object.defineProperty(exports, "__esModule", {
5
6
  value: true
6
7
  });
7
8
  exports["default"] = void 0;
8
- var _react = _interopRequireDefault(require("react"));
9
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
10
+ var _react = _interopRequireWildcard(require("react"));
9
11
  var _reactI18next = require("react-i18next");
10
12
  var _reactstrap = require("reactstrap");
11
13
  var _classnames = _interopRequireDefault(require("classnames"));
@@ -17,6 +19,7 @@ var MoreDropdown = function MoreDropdown(_ref) {
17
19
  className = _ref$className === void 0 ? 'menu-group-item' : _ref$className,
18
20
  disabled = _ref.disabled,
19
21
  children = _ref.children;
22
+ var popoverRef = (0, _react.useRef)(null);
20
23
  var validClassName = (0, _classnames["default"])(className, 'sdoc-more-text-button', {
21
24
  'disabled': disabled,
22
25
  'rich-icon-btn': isRichEditor,
@@ -27,6 +30,16 @@ var MoreDropdown = function MoreDropdown(_ref) {
27
30
  var buttonId = 'sdoc-more-text-operations';
28
31
  var _useTranslation = (0, _reactI18next.useTranslation)('sdoc-editor'),
29
32
  t = _useTranslation.t;
33
+ var _useState = (0, _react.useState)(false),
34
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
35
+ isShowMenu = _useState2[0],
36
+ setIsShowMenu = _useState2[1];
37
+ var toggle = (0, _react.useCallback)(function (event) {
38
+ popoverRef.current.toggle();
39
+ setIsShowMenu(!isShowMenu);
40
+
41
+ // eslint-disable-next-line react-hooks/exhaustive-deps
42
+ }, [isShowMenu]);
30
43
  return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement("button", {
31
44
  className: validClassName,
32
45
  type: "button",
@@ -34,7 +47,7 @@ var MoreDropdown = function MoreDropdown(_ref) {
34
47
  id: buttonId
35
48
  }, /*#__PURE__*/_react["default"].createElement("i", {
36
49
  className: "sdocfont sdoc-more"
37
- }), /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
50
+ }), !isShowMenu && /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
38
51
  target: buttonId
39
52
  }, t('More_operation'))), /*#__PURE__*/_react["default"].createElement(_reactstrap.UncontrolledPopover, {
40
53
  target: buttonId,
@@ -43,7 +56,9 @@ var MoreDropdown = function MoreDropdown(_ref) {
43
56
  trigger: "legacy",
44
57
  placement: "bottom-end",
45
58
  hideArrow: true,
46
- fade: false
59
+ toggle: toggle,
60
+ fade: false,
61
+ ref: popoverRef
47
62
  }, /*#__PURE__*/_react["default"].createElement("div", {
48
63
  className: "menu-group"
49
64
  }, children)));
@@ -77,7 +77,7 @@ function CalloutHoverMenu(_ref) {
77
77
  className: "sdocfont sdoc-callout-color mr-1"
78
78
  }), /*#__PURE__*/_react["default"].createElement("span", {
79
79
  className: "sdocfont sdoc-arrow-down"
80
- })), isShowTooltip && /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
80
+ })), isShowTooltip && !isShowColorSelector && /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
81
81
  target: "select_callout_color",
82
82
  placement: "top",
83
83
  fade: true
@@ -91,7 +91,7 @@ function CalloutHoverMenu(_ref) {
91
91
  className: "sdocfont sdoc-callout-icon mr-1"
92
92
  }), /*#__PURE__*/_react["default"].createElement("span", {
93
93
  className: "sdocfont sdoc-arrow-down"
94
- })), isShowTooltip && /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
94
+ })), isShowTooltip && !isShowIcon && /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
95
95
  target: "select_callout_icon",
96
96
  placement: "top",
97
97
  fade: true
@@ -80,14 +80,23 @@
80
80
  position: absolute;
81
81
  top: 32px;
82
82
  left: 0px;
83
- padding: 8px 0;
84
83
  background-color: #fff;
85
- border: 1px solid #e5e6e8;
86
- border-radius: 2px;
87
- box-shadow: 0 0 10px #ccc;
84
+ border: 1px solid #eee;
85
+ border-radius: 8px;
86
+ box-shadow: 0 6px 14px 0 rgba(0, 0, 0, 0.1);
88
87
  display: flex;
89
88
  flex-direction: column;
90
89
  align-items: flex-start;
91
90
  z-index: 101;
92
91
  white-space: nowrap;
93
92
  }
93
+
94
+ .sdoc-file-link-hover-menu-container .sdoc-file-display-style-popover .sdoc-dropdown-menu-item {
95
+ padding: 0 12px 0 38px;
96
+ position: relative;
97
+ }
98
+
99
+ .sdoc-file-link-hover-menu-container .sdoc-file-display-style-popover .sdoc-dropdown-menu-item .sdoc-check-mark {
100
+ position: absolute;
101
+ left: 12px;
102
+ }
@@ -50,8 +50,8 @@ var FileLinkHoverMenu = function FileLinkHoverMenu(_ref) {
50
50
  // eslint-disable-next-line react-hooks/exhaustive-deps
51
51
  }, []);
52
52
  var onShowProver = (0, _react.useCallback)(function (e) {
53
- setIsShowDisplayStylePopover(true);
54
- }, []);
53
+ setIsShowDisplayStylePopover(!isShowDisplayStylePopover);
54
+ }, [isShowDisplayStylePopover]);
55
55
  var onSelect = (0, _react.useCallback)(function (event, value) {
56
56
  event.stopPropagation();
57
57
  var path = _slateReact.ReactEditor.findPath(editor, element);
@@ -117,7 +117,7 @@ var FileLinkHoverMenu = function FileLinkHoverMenu(_ref) {
117
117
  return /*#__PURE__*/_react["default"].createElement("div", {
118
118
  key: fileLinkType,
119
119
  "date-type": fileLinkType,
120
- className: "sdoc-dropdown-menu-item sdoc-dropdown-item-with-left-icon pr-2",
120
+ className: "sdoc-dropdown-menu-item",
121
121
  onClick: function onClick(event) {
122
122
  return onSelect(event, fileLinkType);
123
123
  }
@@ -128,7 +128,7 @@ var FileLinkHoverMenu = function FileLinkHoverMenu(_ref) {
128
128
  }), /*#__PURE__*/_react["default"].createElement("span", null, t(_constants2.FILE_LINK_TYPE_CONFIG[fileLinkType].text))), selectedType === fileLinkType && /*#__PURE__*/_react["default"].createElement("i", {
129
129
  className: "sdocfont sdoc-check-mark sdoc-dropdown-item-right-icon"
130
130
  }));
131
- }))), isShowTooltip && /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
131
+ }))), isShowTooltip && !isShowDisplayStylePopover && /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
132
132
  target: "select_style",
133
133
  placement: "top",
134
134
  fade: true
@@ -115,7 +115,7 @@ var FontFamily = function FontFamily(_ref) {
115
115
  className: "sdoc-menu-with-dropdown-triangle"
116
116
  }, /*#__PURE__*/_react["default"].createElement("span", {
117
117
  className: caretIconClass
118
- }))), /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
118
+ }))), !isShowMenu && /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
119
119
  target: fontSizeButtonId
120
120
  }, t('Font')), !disabled && /*#__PURE__*/_react["default"].createElement(_reactstrap.UncontrolledPopover, {
121
121
  target: fontSizeButtonId,
@@ -73,7 +73,7 @@ var FontSize = function FontSize(_ref) {
73
73
  className: "sdoc-menu-with-dropdown-triangle"
74
74
  }, /*#__PURE__*/_react["default"].createElement("span", {
75
75
  className: caretIconClass
76
- }))), /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
76
+ }))), !isShowMenu && /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
77
77
  target: fontSizeButtonId
78
78
  }, t('Font_size')), !disabled && /*#__PURE__*/_react["default"].createElement(_reactstrap.UncontrolledPopover, {
79
79
  target: fontSizeButtonId,
@@ -36,6 +36,9 @@ var HeaderMenu = /*#__PURE__*/function (_React$Component) {
36
36
  var menu = _this.menu;
37
37
  var clickIsInMenu = menu && menu.contains(e.target) && menu !== e.target;
38
38
  if (clickIsInMenu) return;
39
+
40
+ // in menu toggle
41
+ if (_this.menuToggle && _this.menuToggle.contains(e.target)) return;
39
42
  _this.setState({
40
43
  isShowHeaderPopover: false
41
44
  }, function () {
@@ -90,6 +93,9 @@ var HeaderMenu = /*#__PURE__*/function (_React$Component) {
90
93
  (0, _defineProperty2["default"])(_this, "setMenuRef", function (ref) {
91
94
  _this.menu = ref;
92
95
  });
96
+ (0, _defineProperty2["default"])(_this, "setMenuToggle", function (ref) {
97
+ _this.menuToggle = ref;
98
+ });
93
99
  (0, _defineProperty2["default"])(_this, "getToolTip", function (type) {
94
100
  return (0, _commonUtils.isMac)() ? _constants.MAC_HOTKEYS[type] : _constants.WIN_HOTKEYS[type];
95
101
  });
@@ -112,6 +118,7 @@ var HeaderMenu = /*#__PURE__*/function (_React$Component) {
112
118
  return /*#__PURE__*/_react["default"].createElement("div", {
113
119
  className: "header-menu"
114
120
  }, /*#__PURE__*/_react["default"].createElement("div", {
121
+ ref: this.setMenuToggle,
115
122
  className: (0, _classnames["default"])('header-toggle', {
116
123
  'header-toggle-disabled': disabled
117
124
  }),
@@ -232,7 +232,7 @@ var ImageHoverMenu = function ImageHoverMenu(_ref) {
232
232
  }), align === item.type && /*#__PURE__*/_react["default"].createElement("i", {
233
233
  className: "sdocfont sdoc-check-mark"
234
234
  }));
235
- })), isShowTooltip && /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
235
+ })), isShowTooltip && !popoverState.alignPopover && /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
236
236
  target: "sdoc_image_alignment",
237
237
  placement: "top",
238
238
  fade: true
@@ -270,7 +270,7 @@ var ImageHoverMenu = function ImageHoverMenu(_ref) {
270
270
  }), border_type === item.type && /*#__PURE__*/_react["default"].createElement("i", {
271
271
  className: "sdocfont sdoc-check-mark sdoc-dropdown-item-right-icon"
272
272
  })));
273
- })), isShowTooltip && /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
273
+ })), isShowTooltip && !popoverState.borderPopover && /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
274
274
  target: "sdoc_image_border",
275
275
  placement: "top",
276
276
  fade: true
@@ -80,14 +80,23 @@
80
80
  position: absolute;
81
81
  top: 32px;
82
82
  left: 0px;
83
- padding: 8px 0;
84
83
  background-color: #fff;
85
- border: 1px solid #e5e6e8;
86
- border-radius: 2px;
87
- box-shadow: 0 0 10px #ccc;
84
+ border: 1px solid #eee;
85
+ border-radius: 8px;
86
+ box-shadow: 0 6px 14px 0 rgba(0, 0, 0, 0.1);
88
87
  display: flex;
89
88
  flex-direction: column;
90
89
  align-items: flex-start;
91
90
  z-index: 101;
92
91
  white-space: nowrap;
93
92
  }
93
+
94
+ .sdoc-file-link-hover-menu-container .sdoc-file-display-style-popover .sdoc-dropdown-item {
95
+ padding: 0 12px 0 38px;
96
+ position: relative;
97
+ }
98
+
99
+ .sdoc-file-link-hover-menu-container .sdoc-file-display-style-popover .sdoc-dropdown-menu-item .sdoc-check-mark {
100
+ position: absolute;
101
+ left: 12px;
102
+ }
@@ -56,8 +56,8 @@ var SdocLinkHoverMenu = function SdocLinkHoverMenu(_ref) {
56
56
  }, []);
57
57
  var onShowProver = (0, _react.useCallback)(function (e) {
58
58
  e.stopPropagation();
59
- setIsShowDisplayStylePopover(true);
60
- }, []);
59
+ setIsShowDisplayStylePopover(!isShowDisplayStylePopover);
60
+ }, [isShowDisplayStylePopover]);
61
61
  var onSelect = (0, _react.useCallback)(function (event, value) {
62
62
  event.stopPropagation();
63
63
  var path = _slateReact.ReactEditor.findPath(editor, element);
@@ -152,7 +152,7 @@ var SdocLinkHoverMenu = function SdocLinkHoverMenu(_ref) {
152
152
  return /*#__PURE__*/_react["default"].createElement("div", {
153
153
  key: sdocLinkType,
154
154
  "date-type": sdocLinkType,
155
- className: "sdoc-dropdown-menu-item sdoc-dropdown-item-with-left-icon pr-2",
155
+ className: "sdoc-dropdown-menu-item",
156
156
  onClick: function onClick(event) {
157
157
  return onSelect(event, sdocLinkType);
158
158
  }
@@ -163,7 +163,7 @@ var SdocLinkHoverMenu = function SdocLinkHoverMenu(_ref) {
163
163
  }), /*#__PURE__*/_react["default"].createElement("span", null, t(_constants2.SDOC_LINK_TYPE_CONFIG[sdocLinkType].text))), selectedType === sdocLinkType && /*#__PURE__*/_react["default"].createElement("i", {
164
164
  className: "sdocfont sdoc-check-mark sdoc-dropdown-item-right-icon"
165
165
  }));
166
- }))), isShowTooltip && /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
166
+ }))), isShowTooltip && !isShowDisplayStylePopover && /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
167
167
  target: "display_sdoc_link",
168
168
  placement: "top",
169
169
  fade: true
@@ -77,6 +77,7 @@ var SearchReplaceMenu = function SearchReplaceMenu(_ref) {
77
77
  ariaLabel: "search",
78
78
  disabled: false,
79
79
  isActive: isOpenPopover,
80
+ isShowPopover: isOpenPopover,
80
81
  onMouseDown: onMouseDown
81
82
  }, menuConfig)), isOpenPopover && /*#__PURE__*/_react["default"].createElement(_popover["default"], {
82
83
  editor: editor,
@@ -74,7 +74,7 @@ var TextAlignMenu = function TextAlignMenu(_ref) {
74
74
  className: "sdoc-menu-with-dropdown-triangle"
75
75
  }, /*#__PURE__*/_react["default"].createElement("span", {
76
76
  className: caretIconClass
77
- }))), /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
77
+ }))), !isShowMenu && /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
78
78
  target: buttonId
79
79
  }, t('Alignment_type')), !disabled && /*#__PURE__*/_react["default"].createElement(_reactstrap.UncontrolledPopover, {
80
80
  target: buttonId,
@@ -88,7 +88,7 @@ var InsertToolbar = function InsertToolbar(_ref) {
88
88
  className: "sdoc-menu-with-dropdown-triangle"
89
89
  }, /*#__PURE__*/_react["default"].createElement("span", {
90
90
  className: caretIconClass
91
- }))), /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
91
+ }))), !isShowMenu && /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
92
92
  target: insertToolbarId
93
93
  }, t('Insert')), !disabled && /*#__PURE__*/_react["default"].createElement(_reactstrap.UncontrolledPopover, {
94
94
  target: insertToolbarId,
@@ -108,10 +108,16 @@
108
108
  .sdoc-outline-header__close {
109
109
  cursor: pointer;
110
110
  font-size: 14px;
111
+ width: 24px;
112
+ height: 24px;
113
+ line-height: 24px;
114
+ text-align: center;
115
+ color: #666;
111
116
  }
112
117
 
113
118
  .sdoc-outline-header__close:hover {
114
- color: #666;
119
+ background-color: #EFEFEF;
120
+ border-radius: 2px;
115
121
  }
116
122
 
117
123
  .sdoc-outline-list-container {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@seafile/sdoc-editor",
3
- "version": "3.0.197",
3
+ "version": "3.0.199",
4
4
  "main": "dist/index.js",
5
5
  "scripts": {
6
6
  "test": "jest",
@@ -72,5 +72,5 @@
72
72
  "publishConfig": {
73
73
  "access": "public"
74
74
  },
75
- "gitHead": "883ff8d09d29e0cbe27254150e1a815f895d7700"
75
+ "gitHead": "6962052b1367ce837cb6e322b56425c5000d059f"
76
76
  }