@seafile/sea-email-editor 0.0.1

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.
Files changed (266) hide show
  1. package/README.md +1 -0
  2. package/dist/assets/icons/align-center.svg +1 -0
  3. package/dist/assets/icons/align-left.svg +1 -0
  4. package/dist/assets/icons/align-right.svg +1 -0
  5. package/dist/assets/icons/arrow-down.svg +1 -0
  6. package/dist/assets/icons/arrow-right.svg +1 -0
  7. package/dist/assets/icons/arrow-up.svg +1 -0
  8. package/dist/assets/icons/bold.svg +1 -0
  9. package/dist/assets/icons/callout-color.svg +1 -0
  10. package/dist/assets/icons/check-mark-option.svg +3 -0
  11. package/dist/assets/icons/check-square.svg +1 -0
  12. package/dist/assets/icons/clear-format.svg +1 -0
  13. package/dist/assets/icons/close.svg +3 -0
  14. package/dist/assets/icons/code-block.svg +1 -0
  15. package/dist/assets/icons/image.svg +1 -0
  16. package/dist/assets/icons/inline-code.svg +1 -0
  17. package/dist/assets/icons/insert.svg +1 -0
  18. package/dist/assets/icons/italic.svg +1 -0
  19. package/dist/assets/icons/link.svg +1 -0
  20. package/dist/assets/icons/more.svg +1 -0
  21. package/dist/assets/icons/ol.svg +1 -0
  22. package/dist/assets/icons/quote.svg +1 -0
  23. package/dist/assets/icons/rename.svg +4 -0
  24. package/dist/assets/icons/strikethrough.svg +1 -0
  25. package/dist/assets/icons/table.svg +1 -0
  26. package/dist/assets/icons/ul.svg +1 -0
  27. package/dist/assets/icons/underline.svg +1 -0
  28. package/dist/assets/icons/unlink.svg +1 -0
  29. package/dist/components/browser-tip/index.css +18 -0
  30. package/dist/components/browser-tip/index.js +28 -0
  31. package/dist/components/centered-loading.js +23 -0
  32. package/dist/components/icon/index.css +7 -0
  33. package/dist/components/icon/index.js +30 -0
  34. package/dist/components/icon-button/index.css +33 -0
  35. package/dist/components/icon-button/index.js +71 -0
  36. package/dist/components/index.js +92 -0
  37. package/dist/components/loading/index.css +54 -0
  38. package/dist/components/loading/index.js +15 -0
  39. package/dist/components/modal/index.css +0 -0
  40. package/dist/components/modal/index.js +27 -0
  41. package/dist/components/modal-header/index.css +22 -0
  42. package/dist/components/modal-header/index.js +36 -0
  43. package/dist/components/option/index.css +20 -0
  44. package/dist/components/option/index.js +39 -0
  45. package/dist/components/options-editor/container/index.css +49 -0
  46. package/dist/components/options-editor/container/index.js +122 -0
  47. package/dist/components/options-editor/index.css +26 -0
  48. package/dist/components/options-editor/index.js +70 -0
  49. package/dist/components/options-editor/options/index.css +5 -0
  50. package/dist/components/options-editor/options/index.js +138 -0
  51. package/dist/components/options-editor/options/option/index.css +54 -0
  52. package/dist/components/options-editor/options/option/index.js +138 -0
  53. package/dist/components/popover/index.js +85 -0
  54. package/dist/components/popover/utils.js +76 -0
  55. package/dist/components/search-input/index.css +52 -0
  56. package/dist/components/search-input/index.js +148 -0
  57. package/dist/components/selector-display/index.css +86 -0
  58. package/dist/components/selector-display/index.js +66 -0
  59. package/dist/components/toolbar/index.js +20 -0
  60. package/dist/components/toolbar/toolbar-group/index.css +13 -0
  61. package/dist/components/toolbar/toolbar-group/index.js +22 -0
  62. package/dist/components/toolbar/toolbar-item/index.css +3 -0
  63. package/dist/components/toolbar/toolbar-item/index.js +53 -0
  64. package/dist/components/tooltip/index.css +68 -0
  65. package/dist/components/tooltip/index.js +46 -0
  66. package/dist/components/tooltip/shortcut-key/index.css +7 -0
  67. package/dist/components/tooltip/shortcut-key/index.js +20 -0
  68. package/dist/constants/event-types.js +25 -0
  69. package/dist/constants/index.js +40 -0
  70. package/dist/constants/key-codes.js +104 -0
  71. package/dist/editor/index.css +44 -0
  72. package/dist/editor/index.js +50 -0
  73. package/dist/editor/main/index.css +19 -0
  74. package/dist/editor/main/index.js +166 -0
  75. package/dist/editor/with-props-editor.js +20 -0
  76. package/dist/extension/commons/dropdown-menu-item/index.css +52 -0
  77. package/dist/extension/commons/dropdown-menu-item/index.js +62 -0
  78. package/dist/extension/commons/index.js +5 -0
  79. package/dist/extension/commons/insert-element-dialog/index.js +91 -0
  80. package/dist/extension/commons/menu/index.js +3 -0
  81. package/dist/extension/commons/menu/menu-drop-down.js +98 -0
  82. package/dist/extension/commons/menu-shortcut-indicator/index.js +24 -0
  83. package/dist/extension/commons/menu-shortcut-indicator/style.css +18 -0
  84. package/dist/extension/constants/element-default-style.js +78 -0
  85. package/dist/extension/constants/element-types.js +33 -0
  86. package/dist/extension/constants/index.js +63 -0
  87. package/dist/extension/constants/keyboard.js +33 -0
  88. package/dist/extension/constants/menus-config.js +142 -0
  89. package/dist/extension/core/index.js +38 -0
  90. package/dist/extension/core/queries/index.js +507 -0
  91. package/dist/extension/core/transforms/focus-editor.js +18 -0
  92. package/dist/extension/core/transforms/index.js +49 -0
  93. package/dist/extension/core/transforms/move-children.js +35 -0
  94. package/dist/extension/core/transforms/remove-node-children.js +19 -0
  95. package/dist/extension/core/transforms/replace-node-children.js +24 -0
  96. package/dist/extension/core/utils/index.js +120 -0
  97. package/dist/extension/event-transfer/get-event-transfer.js +38 -0
  98. package/dist/extension/event-transfer/set-event-transfer.js +36 -0
  99. package/dist/extension/highlight/index.js +20 -0
  100. package/dist/extension/highlight/normalize-tokens.js +94 -0
  101. package/dist/extension/highlight/prismjs.js +27 -0
  102. package/dist/extension/highlight/set-node-decorations.js +81 -0
  103. package/dist/extension/highlight/use-highlight.js +20 -0
  104. package/dist/extension/index.js +67 -0
  105. package/dist/extension/plugins/blockquote/helpers.js +68 -0
  106. package/dist/extension/plugins/blockquote/index.js +18 -0
  107. package/dist/extension/plugins/blockquote/menu/index.js +35 -0
  108. package/dist/extension/plugins/blockquote/plugin.js +154 -0
  109. package/dist/extension/plugins/blockquote/render-elem.js +29 -0
  110. package/dist/extension/plugins/check-list/helper.js +34 -0
  111. package/dist/extension/plugins/check-list/index.js +19 -0
  112. package/dist/extension/plugins/check-list/menu/index.js +39 -0
  113. package/dist/extension/plugins/check-list/plugin.js +92 -0
  114. package/dist/extension/plugins/check-list/render-elem.js +61 -0
  115. package/dist/extension/plugins/clear-format/helpers.js +51 -0
  116. package/dist/extension/plugins/clear-format/menu/index.js +35 -0
  117. package/dist/extension/plugins/code-block/helpers.js +140 -0
  118. package/dist/extension/plugins/code-block/index.js +20 -0
  119. package/dist/extension/plugins/code-block/menu/index.js +59 -0
  120. package/dist/extension/plugins/code-block/plugin.js +288 -0
  121. package/dist/extension/plugins/code-block/render-elem/constant.js +22 -0
  122. package/dist/extension/plugins/code-block/render-elem/index.js +89 -0
  123. package/dist/extension/plugins/code-block/render-elem/language-selector/index.css +18 -0
  124. package/dist/extension/plugins/code-block/render-elem/language-selector/index.js +38 -0
  125. package/dist/extension/plugins/formula/formula.css +22 -0
  126. package/dist/extension/plugins/formula/helper.js +80 -0
  127. package/dist/extension/plugins/formula/index.js +19 -0
  128. package/dist/extension/plugins/formula/menu/formula-modal.js +98 -0
  129. package/dist/extension/plugins/formula/menu/index.js +35 -0
  130. package/dist/extension/plugins/formula/plugin.js +22 -0
  131. package/dist/extension/plugins/formula/render-elem.js +64 -0
  132. package/dist/extension/plugins/header/helper.js +55 -0
  133. package/dist/extension/plugins/header/index.js +19 -0
  134. package/dist/extension/plugins/header/menu/index.js +72 -0
  135. package/dist/extension/plugins/header/plugin.js +155 -0
  136. package/dist/extension/plugins/header/render-elem.js +39 -0
  137. package/dist/extension/plugins/html/index.js +13 -0
  138. package/dist/extension/plugins/html/plugin.js +69 -0
  139. package/dist/extension/plugins/image/helper.js +131 -0
  140. package/dist/extension/plugins/image/index.js +19 -0
  141. package/dist/extension/plugins/image/menu/image-menu-dialog.js +92 -0
  142. package/dist/extension/plugins/image/menu/index.css +3 -0
  143. package/dist/extension/plugins/image/menu/index.js +103 -0
  144. package/dist/extension/plugins/image/plugin.js +56 -0
  145. package/dist/extension/plugins/image/render-element/image-previewer.js +89 -0
  146. package/dist/extension/plugins/image/render-element/index.js +141 -0
  147. package/dist/extension/plugins/image/render-element/style.css +68 -0
  148. package/dist/extension/plugins/index.js +116 -0
  149. package/dist/extension/plugins/link/helper.js +258 -0
  150. package/dist/extension/plugins/link/index.js +19 -0
  151. package/dist/extension/plugins/link/menu/index.js +92 -0
  152. package/dist/extension/plugins/link/menu/link-modal.js +169 -0
  153. package/dist/extension/plugins/link/plugin.js +172 -0
  154. package/dist/extension/plugins/link/render-elem/index.css +12 -0
  155. package/dist/extension/plugins/link/render-elem/index.js +103 -0
  156. package/dist/extension/plugins/link/render-elem/link-op-menu/index.css +33 -0
  157. package/dist/extension/plugins/link/render-elem/link-op-menu/index.js +89 -0
  158. package/dist/extension/plugins/list/constant.js +8 -0
  159. package/dist/extension/plugins/list/helpers.js +102 -0
  160. package/dist/extension/plugins/list/index.js +19 -0
  161. package/dist/extension/plugins/list/menu/index.js +41 -0
  162. package/dist/extension/plugins/list/plugin/index.js +80 -0
  163. package/dist/extension/plugins/list/plugin/insert-break-list.js +29 -0
  164. package/dist/extension/plugins/list/plugin/insert-fragment-list.js +179 -0
  165. package/dist/extension/plugins/list/plugin/normalize-list.js +79 -0
  166. package/dist/extension/plugins/list/plugin/on-tab-handle.js +63 -0
  167. package/dist/extension/plugins/list/plugin/shortcut.js +69 -0
  168. package/dist/extension/plugins/list/queries/index.js +52 -0
  169. package/dist/extension/plugins/list/render-elem/index.js +68 -0
  170. package/dist/extension/plugins/list/transforms/index.js +75 -0
  171. package/dist/extension/plugins/list/transforms/insert-list-item.js +98 -0
  172. package/dist/extension/plugins/list/transforms/move-list-item-down.js +50 -0
  173. package/dist/extension/plugins/list/transforms/move-list-item-up.js +124 -0
  174. package/dist/extension/plugins/list/transforms/move-list-items-to-list.js +63 -0
  175. package/dist/extension/plugins/list/transforms/move-list-items.js +73 -0
  176. package/dist/extension/plugins/list/transforms/normalize-list-item.js +110 -0
  177. package/dist/extension/plugins/list/transforms/normalize-nested-list.js +38 -0
  178. package/dist/extension/plugins/list/transforms/remove-first-list-item.js +24 -0
  179. package/dist/extension/plugins/list/transforms/transforms-to-list.js +131 -0
  180. package/dist/extension/plugins/list/transforms/unwrap-list.js +48 -0
  181. package/dist/extension/plugins/markdown/index.js +12 -0
  182. package/dist/extension/plugins/markdown/plugin.js +257 -0
  183. package/dist/extension/plugins/node-id/constants.js +24 -0
  184. package/dist/extension/plugins/node-id/helpers.js +78 -0
  185. package/dist/extension/plugins/node-id/index.js +12 -0
  186. package/dist/extension/plugins/node-id/with-node-id.js +37 -0
  187. package/dist/extension/plugins/p/helper.js +17 -0
  188. package/dist/extension/plugins/p/index.js +17 -0
  189. package/dist/extension/plugins/p/plugin.js +141 -0
  190. package/dist/extension/plugins/p/render-elem.js +29 -0
  191. package/dist/extension/plugins/paragraph/helper.js +17 -0
  192. package/dist/extension/plugins/paragraph/index.js +17 -0
  193. package/dist/extension/plugins/paragraph/plugin.js +141 -0
  194. package/dist/extension/plugins/paragraph/render-elem.js +29 -0
  195. package/dist/extension/plugins/table/constant.js +24 -0
  196. package/dist/extension/plugins/table/context-menu/horizontal-align-popover/index.css +3 -0
  197. package/dist/extension/plugins/table/context-menu/horizontal-align-popover/index.js +64 -0
  198. package/dist/extension/plugins/table/context-menu/index.css +13 -0
  199. package/dist/extension/plugins/table/context-menu/index.js +152 -0
  200. package/dist/extension/plugins/table/context-menu/insert-table-element/index.css +27 -0
  201. package/dist/extension/plugins/table/context-menu/insert-table-element/index.js +113 -0
  202. package/dist/extension/plugins/table/helper.js +333 -0
  203. package/dist/extension/plugins/table/index.js +21 -0
  204. package/dist/extension/plugins/table/menu/index.js +61 -0
  205. package/dist/extension/plugins/table/menu/table-operator.js +97 -0
  206. package/dist/extension/plugins/table/menu/table-size-selector/index.css +27 -0
  207. package/dist/extension/plugins/table/menu/table-size-selector/index.js +98 -0
  208. package/dist/extension/plugins/table/model.js +102 -0
  209. package/dist/extension/plugins/table/plugin.js +351 -0
  210. package/dist/extension/plugins/table/render-elem/index.css +64 -0
  211. package/dist/extension/plugins/table/render-elem/index.js +252 -0
  212. package/dist/extension/plugins/table/table-operations.js +323 -0
  213. package/dist/extension/plugins/text-style/helpers.js +57 -0
  214. package/dist/extension/plugins/text-style/index.js +17 -0
  215. package/dist/extension/plugins/text-style/menu/index.js +37 -0
  216. package/dist/extension/plugins/text-style/plugin.js +38 -0
  217. package/dist/extension/plugins/text-style/render-elem.js +63 -0
  218. package/dist/extension/render/render-element.js +115 -0
  219. package/dist/extension/render/render-leaf.js +22 -0
  220. package/dist/extension/toolbar/index.css +16 -0
  221. package/dist/extension/toolbar/index.js +89 -0
  222. package/dist/extension/toolbar/insert-toolbar.js +78 -0
  223. package/dist/hooks/use-attachments.js +38 -0
  224. package/dist/hooks/use-container-style.js +50 -0
  225. package/dist/hooks/use-mathjax.js +46 -0
  226. package/dist/hooks/use-scroll-context.js +20 -0
  227. package/dist/hooks/use-selection-update.js +20 -0
  228. package/dist/hooks/user-link-click.js +52 -0
  229. package/dist/index.js +9 -0
  230. package/dist/intl/ReactIntlUniversal.js +310 -0
  231. package/dist/intl/constants.js +21 -0
  232. package/dist/intl/index.js +33 -0
  233. package/dist/locale/index.js +11 -0
  234. package/dist/locale/lang/en.json +83 -0
  235. package/dist/slate-convert/html-to-slate/constants.js +146 -0
  236. package/dist/slate-convert/html-to-slate/helper.js +106 -0
  237. package/dist/slate-convert/html-to-slate/index.js +138 -0
  238. package/dist/slate-convert/html-to-slate/rules/blockquote.js +26 -0
  239. package/dist/slate-convert/html-to-slate/rules/br.js +29 -0
  240. package/dist/slate-convert/html-to-slate/rules/check-list.js +29 -0
  241. package/dist/slate-convert/html-to-slate/rules/code-block.js +95 -0
  242. package/dist/slate-convert/html-to-slate/rules/header.js +26 -0
  243. package/dist/slate-convert/html-to-slate/rules/image.js +31 -0
  244. package/dist/slate-convert/html-to-slate/rules/index.js +20 -0
  245. package/dist/slate-convert/html-to-slate/rules/link.js +31 -0
  246. package/dist/slate-convert/html-to-slate/rules/list.js +74 -0
  247. package/dist/slate-convert/html-to-slate/rules/p.js +37 -0
  248. package/dist/slate-convert/html-to-slate/rules/paragraph.js +37 -0
  249. package/dist/slate-convert/html-to-slate/rules/table.js +64 -0
  250. package/dist/slate-convert/html-to-slate/rules/text.js +71 -0
  251. package/dist/slate-convert/index.js +20 -0
  252. package/dist/slate-convert/slate-to-html/index.js +143 -0
  253. package/dist/utils/common.js +46 -0
  254. package/dist/utils/deserialize-html.js +219 -0
  255. package/dist/utils/dom-utils.js +57 -0
  256. package/dist/utils/dom.js +133 -0
  257. package/dist/utils/event-bus.js +40 -0
  258. package/dist/utils/event-handler.js +44 -0
  259. package/dist/utils/get-browser-Info.js +35 -0
  260. package/dist/utils/hotkey.js +45 -0
  261. package/dist/utils/is-punctuation-mark.js +50 -0
  262. package/dist/utils/object-utils.js +56 -0
  263. package/dist/utils/search.js +20 -0
  264. package/dist/utils/translate.js +18 -0
  265. package/dist/utils/type-detection.js +42 -0
  266. package/package.json +177 -0
@@ -0,0 +1,113 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.default = void 0;
9
+ var _react = _interopRequireWildcard(require("react"));
10
+ var _reactstrap = require("reactstrap");
11
+ var _isHotkey = _interopRequireDefault(require("is-hotkey"));
12
+ var _constant = require("../../constant");
13
+ var _constants = require("@/constants");
14
+ var _option = _interopRequireDefault(require("../../../../../components/options-editor/options/option"));
15
+ require("./index.css");
16
+ var _jsxRuntime = require("react/jsx-runtime");
17
+ class InsertTableElement extends _react.Component {
18
+ constructor(props) {
19
+ super(props);
20
+ this.insertTableElement = event => {
21
+ if (event) {
22
+ event.stopPropagation();
23
+ event.nativeEvent.stopImmediatePropagation();
24
+ }
25
+ const {
26
+ type,
27
+ position
28
+ } = this.props;
29
+ const {
30
+ count
31
+ } = this.state;
32
+ this.props.insertTableElement(type, position, count);
33
+ };
34
+ this.getTip = () => {
35
+ const {
36
+ type,
37
+ position
38
+ } = this.props;
39
+ if (type === _constant.TABLE_ELEMENT.ROW) {
40
+ return position === _constant.TABLE_ELEMENT_POSITION.AFTER ? (0, _constants.gettext)('Insert below') : (0, _constants.gettext)('Insert above');
41
+ }
42
+ return position === _constant.TABLE_ELEMENT_POSITION.AFTER ? (0, _constants.gettext)('Insert on the right') : (0, _constants.gettext)('Insert on the left');
43
+ };
44
+ this.onClick = event => {
45
+ event.stopPropagation();
46
+ event.nativeEvent.stopImmediatePropagation();
47
+ };
48
+ this.onKeyDown = event => {
49
+ if ((0, _isHotkey.default)('enter', event)) {
50
+ event.preventDefault();
51
+ this.insertTableElement();
52
+ return;
53
+ }
54
+ };
55
+ this.onChange = event => {
56
+ const value = event.target.value || '0';
57
+ const newValue = value ? value.replace(/[^\d,]/g, '') : value;
58
+ if (newValue === this.state.count) return;
59
+ const {
60
+ currentCount
61
+ } = this.props;
62
+ const numberValue = parseInt(newValue);
63
+ if (currentCount + numberValue > this.maxCount) {
64
+ this.setState({
65
+ count: this.maxCount - currentCount
66
+ });
67
+ return;
68
+ }
69
+ this.setState({
70
+ count: numberValue
71
+ });
72
+ };
73
+ this.state = {
74
+ count: props.count || 1
75
+ };
76
+ this.maxCount = props.type === _constant.TABLE_ELEMENT.ROW ? _constant.TABLE_MAX_ROWS : _constant.TABLE_MAX_COLUMNS;
77
+ }
78
+ render() {
79
+ const {
80
+ count
81
+ } = this.state;
82
+ const {
83
+ type,
84
+ currentCount
85
+ } = this.props;
86
+ const disabled = currentCount >= this.maxCount;
87
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)(_option.default, {
88
+ disabled: disabled,
89
+ className: "sea-email-insert-table-element-option",
90
+ isShowSelectedStatus: false,
91
+ onChange: this.insertTableElement,
92
+ option: {
93
+ value: '',
94
+ label: /*#__PURE__*/(0, _jsxRuntime.jsxs)(_jsxRuntime.Fragment, {
95
+ children: [this.getTip(), /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
96
+ className: "sea-email-insert-table-element-count-container",
97
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(_reactstrap.Input, {
98
+ className: "sea-email-insert-table-element-count-input",
99
+ value: count,
100
+ disabled: disabled,
101
+ onClick: this.onClick,
102
+ onKeyDown: this.onKeyDown,
103
+ onChange: this.onChange
104
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
105
+ children: type === _constant.TABLE_ELEMENT.ROW ? (0, _constants.gettext)('Row(s)') : (0, _constants.gettext)('Column(s)')
106
+ })]
107
+ })]
108
+ })
109
+ }
110
+ });
111
+ }
112
+ }
113
+ var _default = exports.default = InsertTableElement;
@@ -0,0 +1,333 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.selectCellByGrid = exports.pasteContentIntoTable = exports.jumpOutTableInEditor = exports.isSelectingMultipleTables = exports.isInTable = exports.isDisabled = exports.insertTable = exports.getTableFocusingInfos = exports.getTableEntry = exports.getSelectedTableCells = exports.getSelectGrid = exports.getContextMenuPosition = void 0;
8
+ var _slate = require("slate");
9
+ var _slateReact = require("slate-react");
10
+ var _isUrl = _interopRequireDefault(require("is-url"));
11
+ var _model = require("./model");
12
+ var _elementTypes = require("../../constants/element-types");
13
+ var _core = require("../../core");
14
+ var _getEventTransfer = _interopRequireDefault(require("../../event-transfer/get-event-transfer"));
15
+ var _deserializeHtml = require("../../../utils/deserialize-html");
16
+ var _common = require("../../../utils/common");
17
+ var _helper = require("../link/helper");
18
+ var _helper2 = require("../image/helper");
19
+ const isDisabled = (editor, readonly) => {
20
+ const {
21
+ selection
22
+ } = editor;
23
+ if (readonly || !selection) return true;
24
+ const disableTypes = [_elementTypes.TABLE, _elementTypes.TABLE_ROW, _elementTypes.TABLE_CELL, _elementTypes.FORMULA, _elementTypes.CODE_BLOCK, _elementTypes.BLOCKQUOTE, _elementTypes.UNORDERED_LIST, _elementTypes.ORDERED_LIST, _elementTypes.LIST_ITEM];
25
+ const [nodeEntry] = _slate.Editor.nodes(editor, {
26
+ match: n => disableTypes.includes(n.type),
27
+ mode: 'highest'
28
+ });
29
+ if (nodeEntry) return true;
30
+ return false;
31
+ };
32
+ exports.isDisabled = isDisabled;
33
+ const isInTable = editor => {
34
+ const {
35
+ selection
36
+ } = editor;
37
+ if (!selection) return false;
38
+ const [nodeEntry] = getTableEntry(editor);
39
+ if (!nodeEntry) return false;
40
+ return true;
41
+ };
42
+ exports.isInTable = isInTable;
43
+ const insertTable = (editor, rowNum, columnNum) => {
44
+ const table = (0, _model.generateTable)({
45
+ rowNum,
46
+ columnNum
47
+ });
48
+ console.log(table);
49
+ const {
50
+ selection
51
+ } = editor;
52
+ _slate.Editor.insertNode(editor, table, {
53
+ select: false
54
+ });
55
+ if (_slate.Range.isCollapsed(selection)) {
56
+ const [paragraphNodeEntry] = _slate.Editor.nodes(editor, {
57
+ at: selection.anchor.path,
58
+ match: n => (n.type === _elementTypes.PARAGRAPH || n.type === _elementTypes.P) && _slate.Node.string(n).length === 0
59
+ });
60
+ if (paragraphNodeEntry) {
61
+ const paragraphPath = paragraphNodeEntry[1];
62
+ if (paragraphPath.length === 1 && paragraphPath[0] !== 0) {
63
+ _slate.Transforms.removeNodes(editor, {
64
+ at: paragraphPath
65
+ });
66
+ }
67
+ }
68
+ }
69
+
70
+ // Auto focus at the first cell in table
71
+ const [nodeEntry] = _slate.Editor.nodes(editor, {
72
+ match: node => node.id === table.id,
73
+ mode: 'highest'
74
+ });
75
+ const focusPoint = _slate.Editor.start(editor, nodeEntry[1]);
76
+ (0, _core.focusEditor)(editor, focusPoint);
77
+ };
78
+ exports.insertTable = insertTable;
79
+ const getTableFocusingInfos = editor => {
80
+ if (!isInTable(editor)) return null;
81
+ const nodeEntries = _slate.Editor.nodes(editor, {
82
+ match: n => [_elementTypes.TABLE, _elementTypes.TABLE_ROW, _elementTypes.TABLE_CELL].includes(n.type)
83
+ });
84
+ const nodeEntryList = Array.from(nodeEntries);
85
+ const [tableEntry, rowEntry, cellEntry] = nodeEntryList;
86
+ const columnIndex = cellEntry[1].at(-1);
87
+ const rowIndex = cellEntry[1].at(-2);
88
+ return {
89
+ cellEntry,
90
+ tableEntry,
91
+ rowEntry,
92
+ columnIndex,
93
+ rowIndex
94
+ };
95
+ };
96
+ exports.getTableFocusingInfos = getTableFocusingInfos;
97
+ const selectCellByGrid = (editor, rowIndex, colIndex) => {
98
+ const {
99
+ tableEntry: [, tablePath]
100
+ } = getTableFocusingInfos(editor);
101
+ const selectRange = _slate.Editor.range(editor, tablePath.concat(rowIndex, colIndex));
102
+ (0, _core.focusEditor)(editor, selectRange);
103
+ };
104
+ exports.selectCellByGrid = selectCellByGrid;
105
+ const getSelectedTableCells = editor => {
106
+ const [tableEntry] = getTableEntry(editor);
107
+ if (!tableEntry) return null;
108
+ const [tableNode] = tableEntry;
109
+ const tableRows = tableNode.children;
110
+ const selectGrid = getSelectGrid(editor);
111
+ if (!selectGrid) return null;
112
+ const {
113
+ startRowIndex,
114
+ endRowIndex,
115
+ startColIndex,
116
+ endColIndex
117
+ } = selectGrid;
118
+ const selectedTableRows = [];
119
+ for (let rowIndex = startRowIndex; rowIndex <= endRowIndex; rowIndex++) {
120
+ const currentRow = tableRows[rowIndex];
121
+ let selectedTableCells = [];
122
+ for (let colIndex = startColIndex; colIndex <= endColIndex; colIndex++) {
123
+ const currentCell = currentRow.children[colIndex];
124
+ selectedTableCells.push(currentCell);
125
+ }
126
+ selectedTableRows.push((0, _model.generateTableRow)({
127
+ childrenOrText: selectedTableCells
128
+ }));
129
+ selectedTableCells = [];
130
+ }
131
+ return [(0, _model.generateTable)({
132
+ childrenOrText: selectedTableRows
133
+ })];
134
+ };
135
+ exports.getSelectedTableCells = getSelectedTableCells;
136
+ const getSelectGrid = editor => {
137
+ const [tableEntry] = getTableEntry(editor);
138
+ if (!tableEntry) return null;
139
+ const selectedTableCells = document.querySelectorAll('.selected-cell');
140
+ if (selectedTableCells.length === 0) return null;
141
+ const node = _slateReact.ReactEditor.toSlateNode(editor, selectedTableCells[0]);
142
+ const nodePath = _slateReact.ReactEditor.findPath(editor, node);
143
+ if (!_slate.Path.isAncestor(tableEntry[1], nodePath)) return null;
144
+ const selectGrid = Array.from(selectedTableCells).reduce((grid, cell) => {
145
+ const {
146
+ startRowIndex,
147
+ endRowIndex,
148
+ startColIndex,
149
+ endColIndex
150
+ } = grid;
151
+ const {
152
+ cellIndex: colIndex
153
+ } = cell;
154
+ const {
155
+ rowIndex
156
+ } = cell.parentNode;
157
+ if (endRowIndex === -1 || rowIndex > endRowIndex) grid.endRowIndex = rowIndex;
158
+ if (startRowIndex === -1 || rowIndex < startRowIndex) grid.startRowIndex = rowIndex;
159
+ if (endColIndex === -1 || colIndex > endColIndex) grid.endColIndex = colIndex;
160
+ if (startColIndex === -1 || colIndex < startColIndex) grid.startColIndex = colIndex;
161
+ return {
162
+ ...grid
163
+ };
164
+ }, {
165
+ startRowIndex: -1,
166
+ endRowIndex: -1,
167
+ startColIndex: -1,
168
+ endColIndex: -1
169
+ });
170
+ return selectGrid;
171
+ };
172
+ exports.getSelectGrid = getSelectGrid;
173
+ const pasteContentIntoTable = (editor, content) => {
174
+ const data = content;
175
+ let {
176
+ fragment,
177
+ text,
178
+ type,
179
+ html
180
+ } = (0, _getEventTransfer.default)(data);
181
+ const newText = text.replace(/\r\n|\n/g, ' ');
182
+ if (!fragment && type === 'text') {
183
+ if ((0, _isUrl.default)(text) && !(0, _common.isImage)(text)) {
184
+ const link = (0, _helper.generateLinkNode)(text, text);
185
+ _slate.Editor.insertFragment(editor, [link], {
186
+ select: true
187
+ });
188
+ return;
189
+ } else if ((0, _isUrl.default)(text) && (0, _common.isImage)(text)) {
190
+ (0, _helper2.insertImage)(editor, text);
191
+ return;
192
+ }
193
+ _slate.Transforms.insertText(editor, newText);
194
+ return;
195
+ }
196
+ if (type === 'html') {
197
+ fragment = (0, _deserializeHtml.htmlDeserializer)(html);
198
+ }
199
+ if (fragment.length === 1) {
200
+ if (fragment[0].type === _elementTypes.TABLE) {
201
+ const clipboardTable = fragment[0];
202
+ const {
203
+ tableEntry: [tableNode, tablePath],
204
+ rowEntry: [rowNode],
205
+ rowIndex,
206
+ columnIndex
207
+ } = getTableFocusingInfos(editor);
208
+ const tableWidth = rowNode.children.length;
209
+ const tableHeight = tableNode.children.length;
210
+ clipboardTable.children.some((clipRow, clipRowIndex) => {
211
+ const currentInsertPath = tablePath.concat(rowIndex + clipRowIndex + rowIndex);
212
+ // Out of table
213
+ if (rowIndex + clipRowIndex >= tableHeight + 1) return true;
214
+ clipRow.children.some((clipCol, clipColIndex) => {
215
+ // Out of table
216
+ if (columnIndex + clipColIndex >= tableWidth + 1) return true;
217
+ const currentCellPath = currentInsertPath.concat(columnIndex + clipColIndex);
218
+ const currentCellChildPath = currentCellPath.concat(0);
219
+ _slate.Transforms.removeNodes(editor, {
220
+ at: currentCellChildPath
221
+ });
222
+ if (clipCol.children.type !== _elementTypes.PARAGRAPH) {
223
+ const text = _slate.Node.string(clipCol);
224
+ const newChild = (0, _core.generateElement)(_elementTypes.PARAGRAPH, {
225
+ childrenOrText: text
226
+ });
227
+ _slate.Transforms.insertNodes(editor, newChild, {
228
+ at: currentCellChildPath
229
+ });
230
+ } else {
231
+ _slate.Transforms.insertNodes(editor, clipCol.children, {
232
+ at: currentCellChildPath
233
+ });
234
+ }
235
+ return false;
236
+ });
237
+ return false;
238
+ });
239
+ } else if (fragment[0].type === _elementTypes.PARAGRAPH) {
240
+ (0, _slate.insertFragment)(editor, fragment);
241
+ } else {
242
+ _slate.Transforms.insertText(editor, text.replace(/\r\n|\n/g, ' '));
243
+ }
244
+ }
245
+ };
246
+ exports.pasteContentIntoTable = pasteContentIntoTable;
247
+ const jumpOutTableInEditor = editor => {
248
+ const [tableEntry] = getTableEntry(editor);
249
+ if (!tableEntry) return;
250
+ const [, tablePath] = tableEntry;
251
+ const tableParentPath = _slate.Path.parent(tablePath);
252
+ const insertPath = tableParentPath.concat(tablePath.at(-1) + 1);
253
+ _slate.Transforms.insertNodes(editor, (0, _core.generateElement)(_elementTypes.PARAGRAPH), {
254
+ at: insertPath
255
+ });
256
+ _slate.Transforms.select(editor, {
257
+ path: insertPath.concat(0),
258
+ offset: 0
259
+ });
260
+ };
261
+ exports.jumpOutTableInEditor = jumpOutTableInEditor;
262
+ const getTableEntry = editor => {
263
+ return _slate.Editor.nodes(editor, {
264
+ match: n => n.type === _elementTypes.TABLE,
265
+ mode: 'highest'
266
+ });
267
+ };
268
+ exports.getTableEntry = getTableEntry;
269
+ const isSelectingMultipleTables = editor => {
270
+ let selectedTableCount = 0;
271
+ const selectedElems = (0, _core.getSelectedElems)(editor);
272
+ const isSelectedMultiple = selectedElems.some(elem => {
273
+ if (elem.type === _elementTypes.TABLE) selectedTableCount++;
274
+ if (selectedTableCount > 1) return true;
275
+ return false;
276
+ });
277
+ return isSelectedMultiple;
278
+ };
279
+ exports.isSelectingMultipleTables = isSelectingMultipleTables;
280
+ const getContextMenuPosition = (event, tableRef) => {
281
+ const menuHeight = 240;
282
+ const menuWidth = 350;
283
+ const {
284
+ clientHeight,
285
+ clientWidth
286
+ } = document.body; // page
287
+ const {
288
+ x,
289
+ y
290
+ } = tableRef.current.getBoundingClientRect(); // table
291
+ const {
292
+ clientY,
293
+ clientX
294
+ } = event; // cursor
295
+
296
+ const isBeyondBottom = clientY + menuHeight > clientHeight;
297
+ const isBeyondRight = clientX + menuWidth > clientWidth;
298
+ const defaultTop = clientY - y;
299
+ const defaultLeft = clientX - x;
300
+ let top = 0;
301
+ let left = 0;
302
+ if (isBeyondBottom) {
303
+ const hiddenHeight = menuHeight - (clientHeight - clientY);
304
+ top = defaultTop - hiddenHeight;
305
+ }
306
+ if (isBeyondRight) {
307
+ const hiddenWidth = menuWidth - (clientWidth - clientX);
308
+ left = defaultLeft - hiddenWidth;
309
+ }
310
+ if (!isBeyondBottom && !isBeyondRight) {
311
+ return {
312
+ top: defaultTop,
313
+ left: defaultLeft
314
+ };
315
+ }
316
+ if (isBeyondBottom && isBeyondRight) {
317
+ return {
318
+ top,
319
+ left
320
+ };
321
+ }
322
+ if (isBeyondBottom) {
323
+ return {
324
+ top,
325
+ left: defaultLeft
326
+ };
327
+ }
328
+ return {
329
+ top: defaultTop,
330
+ left
331
+ };
332
+ };
333
+ exports.getContextMenuPosition = getContextMenuPosition;
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+
3
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
4
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.default = void 0;
9
+ var _elementTypes = require("../../constants/element-types");
10
+ var _menu = _interopRequireDefault(require("./menu"));
11
+ var _tableOperator = require("./menu/table-operator");
12
+ var _plugin = _interopRequireDefault(require("./plugin"));
13
+ var _renderElem = _interopRequireWildcard(require("./render-elem"));
14
+ const TablePlugin = {
15
+ type: _elementTypes.TABLE,
16
+ nodeType: 'element',
17
+ editorMenus: [_menu.default, _tableOperator.AlignmentDropDown, _tableOperator.ColumnOperationDropDownList, _tableOperator.RowOperationDropDownList, _tableOperator.RemoveTableMenu],
18
+ editorPlugin: _plugin.default,
19
+ renderElements: [_renderElem.RenderTableCell, _renderElem.RenderTableRow, _renderElem.default]
20
+ };
21
+ var _default = exports.default = TablePlugin;
@@ -0,0 +1,61 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.default = void 0;
9
+ var _react = _interopRequireWildcard(require("react"));
10
+ var _constants = require("../../../constants");
11
+ var _elementTypes = require("../../../constants/element-types");
12
+ var _helper = require("../helper");
13
+ var _tableSizeSelector = _interopRequireDefault(require("./table-size-selector"));
14
+ var _classnames = _interopRequireDefault(require("classnames"));
15
+ var _constants2 = require("@/constants");
16
+ var _components = require("@/components");
17
+ var _jsxRuntime = require("react/jsx-runtime");
18
+ const menuConfig = _constants.MENUS_CONFIG_MAP[_elementTypes.TABLE];
19
+ const TableMenu = _ref => {
20
+ let {
21
+ editor,
22
+ readonly,
23
+ toggle
24
+ } = _ref;
25
+ // eslint-disable-next-line react-hooks/exhaustive-deps
26
+ const disabled = (0, _react.useMemo)(() => (0, _helper.isDisabled)(editor, readonly), [editor.selection, readonly]);
27
+ const domRef = (0, _react.useRef)(null);
28
+ return /*#__PURE__*/(0, _jsxRuntime.jsxs)(_jsxRuntime.Fragment, {
29
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
30
+ className: (0, _classnames.default)('sea-email-option-editor-option', {
31
+ 'disabled': disabled
32
+ }),
33
+ ref: domRef,
34
+ id: menuConfig.id,
35
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(_components.IconButton, {
36
+ icon: menuConfig.icon,
37
+ className: "no-hover-bg sea-email-option-editor-option-icon",
38
+ style: {
39
+ marginLeft: 0,
40
+ marginRight: 8
41
+ },
42
+ size: 16
43
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
44
+ className: "text-truncate",
45
+ title: (0, _constants2.gettext)(menuConfig.text),
46
+ children: (0, _constants2.gettext)(menuConfig.text)
47
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)(_components.IconButton, {
48
+ icon: disabled ? '' : 'arrow-right',
49
+ className: "sea-email-option-editor-option-check-btn no-hover-bg",
50
+ style: {
51
+ marginLeft: 12
52
+ }
53
+ })]
54
+ }), !disabled && /*#__PURE__*/(0, _jsxRuntime.jsx)(_tableSizeSelector.default, {
55
+ target: domRef,
56
+ editor: editor,
57
+ onHideSelector: toggle
58
+ })]
59
+ });
60
+ };
61
+ var _default = exports.default = TableMenu;
@@ -0,0 +1,97 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.RowOperationDropDownList = exports.RemoveTableMenu = exports.ColumnOperationDropDownList = exports.AlignmentDropDown = void 0;
9
+ var _react = _interopRequireWildcard(require("react"));
10
+ var _menuDropDown = _interopRequireDefault(require("../../../commons/menu/menu-drop-down"));
11
+ var _constants = require("../../../constants");
12
+ var _components = require("../../../../components");
13
+ var _tableOperations = require("../table-operations");
14
+ var _jsxRuntime = require("react/jsx-runtime");
15
+ const AlignmentDropDown = _ref => {
16
+ let {
17
+ editor,
18
+ readonly
19
+ } = _ref;
20
+ const alignmentOperationDropDownList = (0, _react.useMemo)(() => [{
21
+ ..._constants.MENUS_CONFIG_MAP[_constants.TABLE_SUBMENU_MAP.TABLE_ALIGN_LEFT],
22
+ handleClick: item => (0, _tableOperations.changeColumnAlign)(editor, _constants.TEXT_ALIGN.LEFT)
23
+ }, {
24
+ ..._constants.MENUS_CONFIG_MAP[_constants.TABLE_SUBMENU_MAP.TABLE_ALIGN_CENTER],
25
+ handleClick: item => (0, _tableOperations.changeColumnAlign)(editor, _constants.TEXT_ALIGN.CENTER)
26
+ }, {
27
+ ..._constants.MENUS_CONFIG_MAP[_constants.TABLE_SUBMENU_MAP.TABLE_ALIGN_RIGHT],
28
+ handleClick: item => (0, _tableOperations.changeColumnAlign)(editor, _constants.TEXT_ALIGN.RIGHT)
29
+ }], [editor]);
30
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)(_menuDropDown.default, {
31
+ editor: editor,
32
+ readonly: readonly,
33
+ isDisabled: false,
34
+ dropDownList: alignmentOperationDropDownList,
35
+ isShowListItemIcon: true,
36
+ ..._constants.MENUS_CONFIG_MAP[_constants.TABLE_SUBMENU_MAP.TABLE_ALIGN_LEFT]
37
+ });
38
+ };
39
+ exports.AlignmentDropDown = AlignmentDropDown;
40
+ const ColumnOperationDropDownList = _ref2 => {
41
+ let {
42
+ editor,
43
+ readonly
44
+ } = _ref2;
45
+ const columnOperationDropDownList = (0, _react.useMemo)(() => [{
46
+ ..._constants.MENUS_CONFIG_MAP[_constants.TABLE_SUBMENU_MAP.TABLE_INSERT_COLUMN],
47
+ handleClick: item => (0, _tableOperations.insertColumn)(editor)
48
+ }, {
49
+ ..._constants.MENUS_CONFIG_MAP[_constants.TABLE_SUBMENU_MAP.TABLE_DELETE_COLUMN],
50
+ handleClick: item => (0, _tableOperations.removeColumn)(editor)
51
+ }], [editor]);
52
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)(_menuDropDown.default, {
53
+ editor: editor,
54
+ readonly: readonly,
55
+ isDisabled: false,
56
+ dropDownList: columnOperationDropDownList,
57
+ ..._constants.MENUS_CONFIG_MAP[_constants.TABLE_SUBMENU_MAP.TABLE_INSERT_COLUMN]
58
+ });
59
+ };
60
+ exports.ColumnOperationDropDownList = ColumnOperationDropDownList;
61
+ const RowOperationDropDownList = _ref3 => {
62
+ let {
63
+ editor,
64
+ readonly
65
+ } = _ref3;
66
+ const rowOperationDropDownList = (0, _react.useMemo)(() => [{
67
+ ..._constants.MENUS_CONFIG_MAP[_constants.TABLE_SUBMENU_MAP.TABLE_INSERT_ROW],
68
+ handleClick: item => (0, _tableOperations.insertRow)(editor)
69
+ }, {
70
+ ..._constants.MENUS_CONFIG_MAP[_constants.TABLE_SUBMENU_MAP.TABLE_DELETE_ROW],
71
+ handleClick: item => (0, _tableOperations.removeRow)(editor)
72
+ }], [editor]);
73
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)(_menuDropDown.default, {
74
+ editor: editor,
75
+ readonly: readonly,
76
+ isDisabled: false,
77
+ dropDownList: rowOperationDropDownList,
78
+ ..._constants.MENUS_CONFIG_MAP[_constants.TABLE_SUBMENU_MAP.TABLE_INSERT_ROW]
79
+ });
80
+ };
81
+ exports.RowOperationDropDownList = RowOperationDropDownList;
82
+ const RemoveTableMenu = _ref4 => {
83
+ let {
84
+ editor,
85
+ readonly,
86
+ className
87
+ } = _ref4;
88
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)(_components.ToolbarItem, {
89
+ className: className,
90
+ disabled: false,
91
+ isActive: false,
92
+ onClick: () => (0, _tableOperations.removeTable)(editor),
93
+ editor: editor,
94
+ ..._constants.MENUS_CONFIG_MAP[_constants.TABLE_SUBMENU_MAP.TABLE_DELETE_TABLE]
95
+ });
96
+ };
97
+ exports.RemoveTableMenu = RemoveTableMenu;
@@ -0,0 +1,27 @@
1
+ .sea-email-table-size-selector-popover .popover {
2
+ margin-left: -10px;
3
+ }
4
+
5
+ .sea-email-table-size-selector-card {
6
+ padding: 8px;
7
+ }
8
+
9
+ .sea-email-table-size-selector-card .sea-email-table-grid-info {
10
+ margin-bottom: 5px;
11
+ width: 100%;
12
+ text-align: center;
13
+ }
14
+
15
+ .sea-email-table-size-selector-card .sea-email-table-cell {
16
+ height: 15px;
17
+ width: 20px;
18
+ border: 1px solid #ccc;
19
+ }
20
+
21
+ .sea-email-table-size-selector-card .sea-email-table-row {
22
+ display: flex;
23
+ }
24
+
25
+ .sea-email-table-size-selector-card .sea-email-table-cell.selected {
26
+ background-color: #ffa94d;
27
+ }