@seafile/sdoc-editor 0.1.146 → 0.1.148-beta

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 (35) hide show
  1. package/dist/api/sdoc-server-api.js +10 -0
  2. package/dist/api/seafile-api.js +27 -5
  3. package/dist/basic-sdk/comment/comment/comment-editor.js +4 -4
  4. package/dist/basic-sdk/constants/index.js +14 -1
  5. package/dist/basic-sdk/editor/common-editor.js +50 -0
  6. package/dist/basic-sdk/editor/index.css +29 -0
  7. package/dist/basic-sdk/editor/index.js +129 -0
  8. package/dist/basic-sdk/{slate-editor.js → editor/slate-editor.js} +21 -16
  9. package/dist/basic-sdk/extension/constants/element-type.js +4 -1
  10. package/dist/basic-sdk/extension/core/transforms/replace-node-children.js +26 -0
  11. package/dist/basic-sdk/extension/plugins/font/helpers.js +1 -1
  12. package/dist/basic-sdk/extension/plugins/link/hover/index.js +6 -2
  13. package/dist/basic-sdk/extension/plugins/table/render/render-cell.js +4 -2
  14. package/dist/basic-sdk/extension/render/render-element.js +209 -1
  15. package/dist/basic-sdk/socket/helpers.js +2 -0
  16. package/dist/basic-sdk/socket/socket-client.js +38 -0
  17. package/dist/basic-sdk/socket/socket-manager.js +34 -4
  18. package/dist/basic-sdk/socket/with-socket-io.js +35 -12
  19. package/dist/basic-sdk/utils/diff.js +2 -2
  20. package/dist/basic-sdk/utils/rebase.js +197 -0
  21. package/dist/basic-sdk/views/diff-viewer.js +3 -1
  22. package/dist/basic-sdk/views/viewer.js +8 -11
  23. package/dist/components/doc-operations/index.js +4 -2
  24. package/dist/components/doc-operations/revision-operations/index.js +5 -2
  25. package/dist/components/doc-operations/revision-operations/publish-button.js +6 -13
  26. package/dist/components/tip-dialog/index.css +0 -0
  27. package/dist/components/tip-dialog/index.js +49 -0
  28. package/dist/components/tip-dialog/tip-content.js +56 -0
  29. package/dist/constants/index.js +23 -2
  30. package/dist/context.js +35 -4
  31. package/dist/pages/simple-editor.js +247 -83
  32. package/package.json +1 -1
  33. package/public/locales/en/sdoc-editor.json +11 -1
  34. package/public/locales/zh_CN/sdoc-editor.json +10 -1
  35. package/dist/basic-sdk/editor.js +0 -105
@@ -1,9 +1,8 @@
1
- import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
1
+ import _asyncToGenerator from "@babel/runtime/helpers/esm/asyncToGenerator";
2
2
  import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
3
+ function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return e; }; var t, e = {}, r = Object.prototype, n = r.hasOwnProperty, o = Object.defineProperty || function (t, e, r) { t[e] = r.value; }, i = "function" == typeof Symbol ? Symbol : {}, a = i.iterator || "@@iterator", c = i.asyncIterator || "@@asyncIterator", u = i.toStringTag || "@@toStringTag"; function define(t, e, r) { return Object.defineProperty(t, e, { value: r, enumerable: !0, configurable: !0, writable: !0 }), t[e]; } try { define({}, ""); } catch (t) { define = function define(t, e, r) { return t[e] = r; }; } function wrap(t, e, r, n) { var i = e && e.prototype instanceof Generator ? e : Generator, a = Object.create(i.prototype), c = new Context(n || []); return o(a, "_invoke", { value: makeInvokeMethod(t, r, c) }), a; } function tryCatch(t, e, r) { try { return { type: "normal", arg: t.call(e, r) }; } catch (t) { return { type: "throw", arg: t }; } } e.wrap = wrap; var h = "suspendedStart", l = "suspendedYield", f = "executing", s = "completed", y = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var p = {}; define(p, a, function () { return this; }); var d = Object.getPrototypeOf, v = d && d(d(values([]))); v && v !== r && n.call(v, a) && (p = v); var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p); function defineIteratorMethods(t) { ["next", "throw", "return"].forEach(function (e) { define(t, e, function (t) { return this._invoke(e, t); }); }); } function AsyncIterator(t, e) { function invoke(r, o, i, a) { var c = tryCatch(t[r], t, o); if ("throw" !== c.type) { var u = c.arg, h = u.value; return h && "object" == typeof h && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) { invoke("next", t, i, a); }, function (t) { invoke("throw", t, i, a); }) : e.resolve(h).then(function (t) { u.value = t, i(u); }, function (t) { return invoke("throw", t, i, a); }); } a(c.arg); } var r; o(this, "_invoke", { value: function value(t, n) { function callInvokeWithMethodAndArg() { return new e(function (e, r) { invoke(t, n, e, r); }); } return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(e, r, n) { var o = h; return function (i, a) { if (o === f) throw new Error("Generator is already running"); if (o === s) { if ("throw" === i) throw a; return { value: t, done: !0 }; } for (n.method = i, n.arg = a;;) { var c = n.delegate; if (c) { var u = maybeInvokeDelegate(c, n); if (u) { if (u === y) continue; return u; } } if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) { if (o === h) throw o = s, n.arg; n.dispatchException(n.arg); } else "return" === n.method && n.abrupt("return", n.arg); o = f; var p = tryCatch(e, r, n); if ("normal" === p.type) { if (o = n.done ? s : l, p.arg === y) continue; return { value: p.arg, done: n.done }; } "throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg); } }; } function maybeInvokeDelegate(e, r) { var n = r.method, o = e.iterator[n]; if (o === t) return r.delegate = null, "throw" === n && e.iterator.return && (r.method = "return", r.arg = t, maybeInvokeDelegate(e, r), "throw" === r.method) || "return" !== n && (r.method = "throw", r.arg = new TypeError("The iterator does not provide a '" + n + "' method")), y; var i = tryCatch(o, e.iterator, r.arg); if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y; var a = i.arg; return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, "return" !== r.method && (r.method = "next", r.arg = t), r.delegate = null, y) : a : (r.method = "throw", r.arg = new TypeError("iterator result is not an object"), r.delegate = null, y); } function pushTryEntry(t) { var e = { tryLoc: t[0] }; 1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e); } function resetTryEntry(t) { var e = t.completion || {}; e.type = "normal", delete e.arg, t.completion = e; } function Context(t) { this.tryEntries = [{ tryLoc: "root" }], t.forEach(pushTryEntry, this), this.reset(!0); } function values(e) { if (e || "" === e) { var r = e[a]; if (r) return r.call(e); if ("function" == typeof e.next) return e; if (!isNaN(e.length)) { var o = -1, i = function next() { for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next; return next.value = t, next.done = !0, next; }; return i.next = i; } } throw new TypeError(typeof e + " is not iterable"); } return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), o(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) { var e = "function" == typeof t && t.constructor; return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name)); }, e.mark = function (t) { return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t; }, e.awrap = function (t) { return { __await: t }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () { return this; }), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) { void 0 === i && (i = Promise); var a = new AsyncIterator(wrap(t, r, n, o), i); return e.isGeneratorFunction(r) ? a : a.next().then(function (t) { return t.done ? t.value : a.next(); }); }, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () { return this; }), define(g, "toString", function () { return "[object Generator]"; }), e.keys = function (t) { var e = Object(t), r = []; for (var n in e) r.push(n); return r.reverse(), function next() { for (; r.length;) { var t = r.pop(); if (t in e) return next.value = t, next.done = !1, next; } return next.done = !0, next; }; }, e.values = values, Context.prototype = { constructor: Context, reset: function reset(e) { if (this.prev = 0, this.next = 0, this.sent = this._sent = t, this.done = !1, this.delegate = null, this.method = "next", this.arg = t, this.tryEntries.forEach(resetTryEntry), !e) for (var r in this) "t" === r.charAt(0) && n.call(this, r) && !isNaN(+r.slice(1)) && (this[r] = t); }, stop: function stop() { this.done = !0; var t = this.tryEntries[0].completion; if ("throw" === t.type) throw t.arg; return this.rval; }, dispatchException: function dispatchException(e) { if (this.done) throw e; var r = this; function handle(n, o) { return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o; } for (var o = this.tryEntries.length - 1; o >= 0; --o) { var i = this.tryEntries[o], a = i.completion; if ("root" === i.tryLoc) return handle("end"); if (i.tryLoc <= this.prev) { var c = n.call(i, "catchLoc"), u = n.call(i, "finallyLoc"); if (c && u) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } else if (c) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); } else { if (!u) throw new Error("try statement without catch or finally"); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } } } }, abrupt: function abrupt(t, e) { for (var r = this.tryEntries.length - 1; r >= 0; --r) { var o = this.tryEntries[r]; if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) { var i = o; break; } } i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null); var a = i ? i.completion : {}; return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a); }, complete: function complete(t, e) { if ("throw" === t.type) throw t.arg; return "break" === t.type || "continue" === t.type ? this.next = t.arg : "return" === t.type ? (this.rval = this.arg = t.arg, this.method = "return", this.next = "end") : "normal" === t.type && e && (this.next = e), y; }, finish: function finish(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y; } }, catch: function _catch(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.tryLoc === t) { var n = r.completion; if ("throw" === n.type) { var o = n.arg; resetTryEntry(r); } return o; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(e, r, n) { return this.delegate = { iterator: values(e), resultName: r, nextLoc: n }, "next" === this.method && (this.arg = t), y; } }, e; }
3
4
  import React, { useCallback, useEffect, useRef, useState } from 'react';
4
5
  import { withTranslation } from 'react-i18next';
5
- import deepCopy from 'deep-copy';
6
- import { SDocEditor, DiffViewer } from '../basic-sdk';
7
6
  import Loading from '../components/loading';
8
7
  import DocInfo from '../components/doc-info';
9
8
  import DocOperations from '../components/doc-operations';
@@ -11,49 +10,117 @@ import Layout, { Header, Content } from '../layout';
11
10
  import { generateDefaultDocContent } from '../utils';
12
11
  import context from '../context';
13
12
  import ErrorBoundary from './error-boundary';
13
+ import TipDialog from '../components/tip-dialog';
14
+ import { EXTERNAL_EVENT, MODE, TIP_TYPE } from '../constants';
15
+ import { getRebase } from '../basic-sdk/utils/rebase';
16
+ import toaster from '../components/toast';
17
+ import { EventBus, SDocEditor } from '../basic-sdk';
14
18
  import '../assets/css/simple-editor.css';
15
19
  var SimpleEditor = function SimpleEditor(_ref) {
16
20
  var isStarred = _ref.isStarred,
17
21
  isDraft = _ref.isDraft,
18
22
  t = _ref.t;
23
+ context.initApi();
24
+ var repoID = context.getSetting('repoID');
25
+ var siteRoot = context.getSetting('siteRoot');
26
+ var originFilePath = context.getSetting('originFilePath');
27
+ var isRevision = context.getSetting('isSdocRevision');
28
+ var originFileURL = isRevision ? "".concat(siteRoot, "lib/").concat(repoID, "/file").concat(originFilePath) : '';
29
+ var originDocName = isRevision ? context.getSetting('originFilename') : '';
30
+ var originDocUuid = isRevision ? context.getSetting('originDocUuid') : '';
19
31
  var editorRef = useRef(null);
20
32
  var _useState = useState(true),
21
33
  _useState2 = _slicedToArray(_useState, 2),
22
- isFirstLoad = _useState2[0],
23
- setFirstLoad = _useState2[1];
24
- var _useState3 = useState(true),
34
+ isLoadingSdoc = _useState2[0],
35
+ setLoadingSdoc = _useState2[1];
36
+ var _useState3 = useState(''),
25
37
  _useState4 = _slicedToArray(_useState3, 2),
26
- isLoadingSdoc = _useState4[0],
27
- setLoadingSdoc = _useState4[1];
28
- var _useState5 = useState(''),
38
+ errorMessage = _useState4[0],
39
+ setErrorMessage = _useState4[1];
40
+ var _useState5 = useState(false),
29
41
  _useState6 = _slicedToArray(_useState5, 2),
30
- errorMessage = _useState6[0],
31
- setErrorMessage = _useState6[1];
32
- var _useState7 = useState(false),
42
+ isShowChanges = _useState6[0],
43
+ setShowChanges = _useState6[1];
44
+ var _useState7 = useState(null),
33
45
  _useState8 = _slicedToArray(_useState7, 2),
34
- isShowChanges = _useState8[0],
35
- setShowChanges = _useState8[1];
36
- var _useState9 = useState(null),
46
+ document = _useState8[0],
47
+ setDocument = _useState8[1];
48
+ var _useState9 = useState(MODE.EDITOR),
37
49
  _useState10 = _slicedToArray(_useState9, 2),
38
- document = _useState10[0],
39
- setDocument = _useState10[1];
40
- var _useState11 = useState(null),
50
+ mode = _useState10[0],
51
+ setMode = _useState10[1];
52
+ var _useState11 = useState([]),
41
53
  _useState12 = _slicedToArray(_useState11, 2),
42
- currentContent = _useState12[0],
43
- setCurrentContent = _useState12[1];
44
- var _useState13 = useState(null),
54
+ changes = _useState12[0],
55
+ setChanges = _useState12[1];
56
+ var _useState13 = useState(false),
45
57
  _useState14 = _slicedToArray(_useState13, 2),
46
- lastContent = _useState14[0],
47
- setLastContent = _useState14[1];
58
+ showTip = _useState14[0],
59
+ setShowTip = _useState14[1];
60
+ var _useState15 = useState(''),
61
+ _useState16 = _slicedToArray(_useState15, 2),
62
+ tipType = _useState16[0],
63
+ setTipType = _useState16[1];
64
+ var _useState17 = useState([]),
65
+ _useState18 = _slicedToArray(_useState17, 2),
66
+ mergeValue = _useState18[0],
67
+ setMergeValue = _useState18[1];
68
+ useEffect(function () {
69
+ loadDocument(function (document) {
70
+ setDocument(document);
71
+ setLoadingSdoc(false);
72
+ }, function (errorMessage) {
73
+ setErrorMessage(errorMessage);
74
+ setDocument(null);
75
+ setLoadingSdoc(false);
76
+ }, function () {
77
+ setLoadingSdoc(true);
78
+ });
79
+
80
+ // eslint-disable-next-line react-hooks/exhaustive-deps
81
+ }, []);
82
+
83
+ // useMount: reset title
48
84
  useEffect(function () {
49
- context.initApi();
50
- initDocumentData(true);
85
+ var isSdocRevision = context.getSetting('isSdocRevision');
86
+ var originFilename = context.getSetting('originFilename');
87
+ if (isSdocRevision) {
88
+ window.document.getElementsByTagName('title')[0].innerText = "".concat(t('Revision'), " - ").concat(originFilename);
89
+ }
51
90
 
52
91
  // eslint-disable-next-line react-hooks/exhaustive-deps
53
92
  }, []);
54
- var initDocumentData = useCallback(function (isFirstLoad) {
55
- setShowChanges(false);
56
- setLoadingSdoc(true);
93
+ var onDocumentReplaced = useCallback(function () {
94
+ setTipType(TIP_TYPE.HAS_BEEN_REPLACED);
95
+ setShowTip(true);
96
+
97
+ // eslint-disable-next-line react-hooks/exhaustive-deps
98
+ }, [editorRef]);
99
+ var hasPublishRevision = useCallback(function () {
100
+ setTipType(TIP_TYPE.HAS_BEEN_PUBLISHED);
101
+ setShowTip(true);
102
+
103
+ // eslint-disable-next-line react-hooks/exhaustive-deps
104
+ }, [editorRef]);
105
+ var onDocumentReplacedError = useCallback(function () {}, []);
106
+ var publishDocumentError = useCallback(function () {}, []);
107
+ useEffect(function () {
108
+ var eventBus = EventBus.getInstance();
109
+ var mergeDocumentSubscribe = eventBus.subscribe(EXTERNAL_EVENT.DOCUMENT_REPLACED, onDocumentReplaced);
110
+ var publishDocumentSubscribe = eventBus.subscribe(EXTERNAL_EVENT.PUBLISH_DOCUMENT, hasPublishRevision);
111
+ var mergeDocumentErrorSubscribe = eventBus.subscribe(EXTERNAL_EVENT.DOCUMENT_REPLACED_ERROR, onDocumentReplacedError);
112
+ var publishDocumentErrorSubscribe = eventBus.subscribe(EXTERNAL_EVENT.PUBLISH_DOCUMENT_ERROR, publishDocumentError);
113
+ return function () {
114
+ mergeDocumentSubscribe();
115
+ publishDocumentSubscribe();
116
+ mergeDocumentErrorSubscribe();
117
+ publishDocumentErrorSubscribe();
118
+ };
119
+
120
+ // eslint-disable-next-line react-hooks/exhaustive-deps
121
+ }, []);
122
+ var loadDocument = useCallback(function (successCallback, errorCallback, callback) {
123
+ callback && callback();
57
124
  context.getFileContent().then(function (res) {
58
125
  var result = res.data || generateDefaultDocContent();
59
126
  if (result && !result.children) {
@@ -63,74 +130,178 @@ var SimpleEditor = function SimpleEditor(_ref) {
63
130
  cursors: result.cursors || {}
64
131
  };
65
132
  }
66
- setDocument(result);
67
- setLoadingSdoc(false);
68
- isFirstLoad && setFirstLoad(false);
133
+ successCallback && successCallback(result);
69
134
  }).catch(function (error) {
70
135
  // eslint-disable-next-line
71
136
  console.log(error);
72
- setErrorMessage('Load_doc_content_error');
137
+ var errorMessage = 'Load_doc_content_error';
73
138
  if (error && error.response) {
74
139
  var _ref2 = error.response.data || {},
75
140
  error_type = _ref2.error_type;
76
141
  if (error_type === 'content_invalid') {
77
- setErrorMessage('Sdoc_format_invalid');
142
+ errorMessage = 'Sdoc_format_invalid';
78
143
  }
79
144
  }
80
- setDocument(null);
81
- setLoadingSdoc(false);
145
+ errorCallback && errorCallback(errorMessage);
82
146
  });
83
-
84
- // eslint-disable-next-line react-hooks/exhaustive-deps
85
147
  }, []);
86
- var initChangesData = useCallback(function () {
87
- setShowChanges(true);
88
- setLoadingSdoc(true);
89
- context.getSeadocRevisionDownloadLinks().then(function (res) {
148
+ var setDiffContent = useCallback(function () {
149
+ context.getSeadocOriginFileDownloadLink().then(function (res) {
90
150
  var originFileDownloadLink = res.data.origin_file_download_link;
91
151
  return fetch(originFileDownloadLink);
92
152
  }).then(function (res) {
93
153
  return res.json();
94
154
  }).then(function (originContent) {
95
- setLastContent(originContent);
96
- setErrorMessage(null);
97
- setLoadingSdoc(false);
155
+ editorRef.current.setDiffContent(originContent);
156
+ editorRef.current.setLoading(false);
98
157
  }).catch(function (error) {
99
- setErrorMessage('Load_doc_content_error');
100
- setLoadingSdoc(false);
158
+ console.log('error');
101
159
  });
102
-
103
- // eslint-disable-next-line react-hooks/exhaustive-deps
104
- }, [document]);
160
+ }, []);
105
161
  var toggleViewChanges = useCallback(function (isShowChanges) {
106
- if (isShowChanges) {
107
- var newestValue = editorRef.current.getValue();
108
- setCurrentContent(deepCopy(_objectSpread(_objectSpread({}, document), {}, {
109
- children: newestValue
110
- })));
162
+ var revisionCurrentContent = editorRef.current.getSlateValue();
163
+ if (isShowChanges && revisionCurrentContent.children.filter(function (item) {
164
+ return item.rebaseType;
165
+ }).length !== 0) {
166
+ setTipType(TIP_TYPE.HAS_CONFLICT_BEFORE_VIEW_CHANGES);
167
+ setShowTip(true);
168
+ return;
111
169
  }
112
- if (isShowChanges) {
113
- initChangesData();
170
+ editorRef.current.setLoading(true);
171
+ setShowChanges(isShowChanges);
172
+ var mode = isShowChanges ? MODE.DIFF_VIEWER : MODE.EDITOR;
173
+ setMode(mode);
174
+ editorRef.current.setEditorMode(mode);
175
+ if (!isShowChanges) {
176
+ loadDocument(function (document) {
177
+ setDocument(document);
178
+ editorRef.current.setSlateValue(document);
179
+ editorRef.current.setLoading(false);
180
+ }, function (errorMessage) {
181
+ setErrorMessage(errorMessage);
182
+ editorRef.current.setLoading(false);
183
+ });
114
184
  return;
115
185
  }
116
- setChanges([]);
117
- initDocumentData(false);
186
+ setDiffContent();
118
187
 
119
188
  // eslint-disable-next-line react-hooks/exhaustive-deps
120
- }, [document]);
121
- var _useState15 = useState([]),
122
- _useState16 = _slicedToArray(_useState15, 2),
123
- changes = _useState16[0],
124
- setChanges = _useState16[1];
189
+ }, [document, editorRef.current]);
190
+ var publishRevision = useCallback( /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
191
+ return _regeneratorRuntime().wrap(function _callee$(_context) {
192
+ while (1) switch (_context.prev = _context.next) {
193
+ case 0:
194
+ loadDocument(function (document) {
195
+ var revisionCurrentContent = document;
196
+ if (revisionCurrentContent.children.filter(function (item) {
197
+ return item.rebaseType;
198
+ }).length !== 0) {
199
+ setTipType(TIP_TYPE.HAS_CONFLICT_BEFORE_PUBLISH);
200
+ setShowTip(true);
201
+ return;
202
+ }
203
+ var originFileVersion = context.getSetting('originFileVersion'); // changing
204
+ var revisionMasterContent;
205
+ var masterContent;
206
+ context.getFileHistoryVersion(originFileVersion, originFilePath).then(function (res) {
207
+ var fileHistoryRevisionContent = res.data.content; // commit content
208
+ revisionMasterContent = JSON.parse(fileHistoryRevisionContent);
209
+ return context.getSeadocOriginFileDownloadLink();
210
+ }).then(function (res) {
211
+ var originFileDownloadLink = res.data.origin_file_download_link;
212
+ return fetch(originFileDownloadLink);
213
+ }).then(function (res) {
214
+ return res.json();
215
+ }).then(function (content) {
216
+ masterContent = content;
217
+ var _getRebase = getRebase(masterContent, revisionMasterContent, revisionCurrentContent),
218
+ canMerge = _getRebase.canMerge,
219
+ isNeedReplaceMaster = _getRebase.isNeedReplaceMaster,
220
+ value = _getRebase.value;
221
+ if (canMerge && isNeedReplaceMaster) {
222
+ context.publishSdocRevision().then(function (res) {
223
+ editorRef.current.publishDocument(originDocUuid, originDocName, true);
224
+ setTipType(TIP_TYPE.HAS_BEEN_PUBLISHED);
225
+ setShowTip(true);
226
+ }).catch(function (error) {
227
+ toaster.danger(t('Error'));
228
+ });
229
+ return;
230
+ }
231
+ if (canMerge && !isNeedReplaceMaster) {
232
+ setTipType(TIP_TYPE.DELETE_NO_CHANGES_REVISION);
233
+ setShowTip(true);
234
+ return;
235
+ }
236
+ setMergeValue(value);
237
+ setTipType(TIP_TYPE.MERGE);
238
+ setShowTip(true);
239
+ }).catch(function (error) {
240
+ toaster.danger(t('Error'));
241
+ });
242
+ }, function (errorMessage) {
243
+ toaster.danger(t(errorMessage));
244
+ });
245
+
246
+ // eslint-disable-next-line react-hooks/exhaustive-deps
247
+ case 1:
248
+ case "end":
249
+ return _context.stop();
250
+ }
251
+ }, _callee);
252
+ })), [isShowChanges, mode, originDocUuid, originDocName, originFilePath]);
125
253
  var setDiffChanges = useCallback(function (diff) {
126
254
  setChanges(diff.changes);
127
255
 
128
256
  // eslint-disable-next-line react-hooks/exhaustive-deps
129
257
  }, [isShowChanges]);
130
- if (isFirstLoad && !errorMessage) {
258
+ var jumpToURL = useCallback(function (url) {
259
+ window.location.href = url;
260
+ }, []);
261
+ var closeTip = useCallback(function () {
262
+ setShowTip(false);
263
+
264
+ // eslint-disable-next-line react-hooks/exhaustive-deps
265
+ }, [tipType]);
266
+ var tipSubmit = useCallback(function () {
267
+ if (tipType === TIP_TYPE.DELETE_NO_CHANGES_REVISION) {
268
+ context.deleteSdocRevision().then(function (res) {
269
+ if (res.data.success) {
270
+ editorRef.current.publishDocument(originDocUuid, originDocName, false);
271
+ setShowTip(false);
272
+ jumpToURL(originFileURL);
273
+ }
274
+ }).catch(function (error) {
275
+ toaster.danger(t('Error'));
276
+ });
277
+ return;
278
+ }
279
+ if (tipType === TIP_TYPE.MERGE) {
280
+ context.updateSdocRevision().then(function (res) {
281
+ var origin_file_version = res.data.origin_file_version;
282
+ context.updateSettings({
283
+ 'originFileVersion': origin_file_version
284
+ });
285
+ editorRef.current.replaceDocument(mergeValue);
286
+ editorRef.current.setLoading(true);
287
+ editorRef.current.setSlateValue(mergeValue);
288
+ setMode(MODE.EDITOR);
289
+ editorRef.current.setEditorMode(MODE.EDITOR);
290
+ editorRef.current.setLoading(false);
291
+ setShowTip(false);
292
+ }).catch(function (error) {
293
+ toaster.danger(t('Error'));
294
+ });
295
+ return;
296
+ }
297
+ setShowTip(false);
298
+
299
+ // eslint-disable-next-line react-hooks/exhaustive-deps
300
+ }, [tipType, originFileURL, mergeValue, editorRef.current, originDocUuid, originDocName]);
301
+ if (isLoadingSdoc) {
131
302
  return /*#__PURE__*/React.createElement(Loading, null);
132
303
  }
133
- if (isFirstLoad && errorMessage) {
304
+ if (errorMessage) {
134
305
  return /*#__PURE__*/React.createElement("div", {
135
306
  className: "error-page"
136
307
  }, /*#__PURE__*/React.createElement("div", {
@@ -144,24 +315,17 @@ var SimpleEditor = function SimpleEditor(_ref) {
144
315
  }), /*#__PURE__*/React.createElement(DocOperations, {
145
316
  isShowChanges: isShowChanges,
146
317
  changes: changes,
147
- toggleViewChanges: toggleViewChanges
148
- })), /*#__PURE__*/React.createElement(Content, null, isLoadingSdoc && /*#__PURE__*/React.createElement("div", {
149
- className: "w-100 h-100 d-flex align-items-center justify-content-center"
150
- }, /*#__PURE__*/React.createElement(Loading, null)), !isLoadingSdoc && errorMessage && /*#__PURE__*/React.createElement("div", {
151
- className: "error-page"
152
- }, /*#__PURE__*/React.createElement("div", {
153
- className: "error-tip"
154
- }, t(errorMessage))), !isLoadingSdoc && !errorMessage && /*#__PURE__*/React.createElement(React.Fragment, null, isShowChanges ? /*#__PURE__*/React.createElement(DiffViewer, {
155
- showToolbar: true,
156
- showOutline: true,
157
- currentContent: currentContent,
158
- lastContent: lastContent,
159
- didMountCallback: setDiffChanges
160
- }) : /*#__PURE__*/React.createElement(SDocEditor, {
161
- config: context.getEditorConfig(),
162
- document: document,
318
+ toggleViewChanges: toggleViewChanges,
319
+ publishRevision: publishRevision
320
+ })), /*#__PURE__*/React.createElement(Content, null, /*#__PURE__*/React.createElement(SDocEditor, {
163
321
  ref: editorRef,
164
- isOpenSocket: context.getSetting('isOpenSocket')
165
- })))));
322
+ document: document,
323
+ mode: mode,
324
+ setDiffChanges: setDiffChanges
325
+ }))), showTip && /*#__PURE__*/React.createElement(TipDialog, {
326
+ toggle: closeTip,
327
+ submit: tipSubmit,
328
+ tipType: tipType
329
+ }));
166
330
  };
167
331
  export default withTranslation('sdoc-editor')(SimpleEditor);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@seafile/sdoc-editor",
3
- "version": "0.1.146",
3
+ "version": "0.1.148beta",
4
4
  "private": false,
5
5
  "description": "This is a sdoc editor",
6
6
  "main": "dist/index.js",
@@ -362,5 +362,15 @@
362
362
  "No_changes": "No changes",
363
363
  "Title": "Title",
364
364
  "Subtitle": "Subtitle",
365
- "Link_sdoc": "Link sdoc"
365
+ "Link_sdoc": "Link sdoc",
366
+ "Keep_my_modification": "Keep my modification",
367
+ "Keep_other_modification": "Keep other's modification",
368
+ "Keep_both_modification": "Keep my modification",
369
+ "Tip": "Tip",
370
+ "Rebase_delete_no_change_revision_tip": "Revision has not made any change compared to original document. Do you want to delete this revision?",
371
+ "Has_been_replaced_tip": "Document content has been replaced. Please refresh the page.",
372
+ "Has_been_published_tip": "Revision has been published, Automatically jump to source content after {{ time }} seconds.",
373
+ "Has_conflict_before_publish_tip": "There are conflicts in the document, please resolve it before publishing!",
374
+ "Merge_tip": "There are conflicts in the documents. Do you want to merge them?",
375
+ "Has_conflict_before_view_changes_tip": "There are conflicts in the document. Please resolve the conflict before viewing the changes!"
366
376
  }
@@ -362,5 +362,14 @@
362
362
  "No_changes": "没有变化",
363
363
  "Title": "标题",
364
364
  "Subtitle": "副标题",
365
- "Link_sdoc": "链接 sdoc"
365
+ "Link_sdoc": "链接 sdoc",
366
+ "Keep_my_modification": "保留我的更改",
367
+ "Keep_other_modification": "保留其他的更改",
368
+ "Keep_both_modification": "保留两个更改",
369
+ "Rebase_delete_no_change_revision_tip": "修订改没有更改,是否删除修订稿?",
370
+ "Has_been_replaced_tip": "文档内容已经被替换,请刷新页面。",
371
+ "Has_been_published_tip": "修订稿已经发布了,{{ time }} 秒后自动跳转到源文件。",
372
+ "Has_conflict_before_publish_tip": "文档有冲突,请解决冲突后再发布!",
373
+ "Merge_tip": "文档有冲突,是否合并?",
374
+ "Has_conflict_before_view_changes_tip": "文档有冲突,请解决冲突后再查看更改!"
366
375
  }
@@ -1,105 +0,0 @@
1
- import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
2
- import React, { useEffect, useMemo, useState, forwardRef, useImperativeHandle } from 'react';
3
- import { Editor } from '@seafile/slate';
4
- import { useTranslation } from 'react-i18next';
5
- import { createDefaultEditor } from './extension';
6
- import { focusEditor } from './extension/core';
7
- import { withSocketIO } from './socket';
8
- import withNodeId from './node-id';
9
- import { PAGE_EDIT_AREA_WIDTH } from './constants';
10
- import context from '../context';
11
- import { EditorContainer, EditorContent } from './layout';
12
- import SlateEditor from './slate-editor';
13
- import InsertElementDialog from './extension/commons/insert-element-dialog';
14
- var SDocEditor = forwardRef(function (_ref, ref) {
15
- var document = _ref.document,
16
- config = _ref.config;
17
- var _useTranslation = useTranslation(),
18
- t = _useTranslation.t;
19
-
20
- // init editor
21
- var editor = useMemo(function () {
22
- var defaultEditor = createDefaultEditor();
23
- var newEditor = withNodeId(withSocketIO(defaultEditor, {
24
- document: document,
25
- config: config
26
- }));
27
- var cursors = document.cursors;
28
- newEditor.cursors = cursors || {};
29
- newEditor.width = PAGE_EDIT_AREA_WIDTH; // default width
30
- newEditor.readonly = false;
31
- return newEditor;
32
- // eslint-disable-next-line react-hooks/exhaustive-deps
33
- }, []);
34
- var _useState = useState(document.children),
35
- _useState2 = _slicedToArray(_useState, 2),
36
- slateValue = _useState2[0],
37
- setSlateValue = _useState2[1];
38
-
39
- // The parent component can call the method of this component through ref
40
- useImperativeHandle(ref, function () {
41
- return {
42
- // get latest value
43
- getValue: function getValue() {
44
- return slateValue;
45
- }
46
- };
47
- }, [slateValue]);
48
-
49
- // useMount: init socket connection
50
- useEffect(function () {
51
- editor.openConnection();
52
- return function () {
53
- editor.closeConnection();
54
- };
55
- // eslint-disable-next-line react-hooks/exhaustive-deps
56
- }, []);
57
-
58
- // useMount: focus editor
59
- useEffect(function () {
60
- var timer = setTimeout(function () {
61
- var _editor$children = _slicedToArray(editor.children, 1),
62
- firstNode = _editor$children[0];
63
- if (firstNode) {
64
- var _firstNode$children = _slicedToArray(firstNode.children, 1),
65
- firstNodeFirstChild = _firstNode$children[0];
66
- if (firstNodeFirstChild) {
67
- var endOfFirstNode = Editor.end(editor, [0, 0]);
68
- var range = {
69
- anchor: endOfFirstNode,
70
- focus: endOfFirstNode
71
- };
72
- focusEditor(editor, range);
73
- }
74
- }
75
- }, 300);
76
- return function () {
77
- clearTimeout(timer);
78
- };
79
- // eslint-disable-next-line react-hooks/exhaustive-deps
80
- }, []);
81
-
82
- // useMount: reset title
83
- useEffect(function () {
84
- var isSdocRevision = context.getSetting('isSdocRevision');
85
- var originFilename = context.getSetting('originFilename');
86
- if (isSdocRevision) {
87
- window.document.getElementsByTagName('title')[0].innerText = "".concat(t('Revision'), " - ").concat(originFilename);
88
- }
89
-
90
- // eslint-disable-next-line react-hooks/exhaustive-deps
91
- }, []);
92
- return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(EditorContainer, {
93
- editor: editor
94
- }, /*#__PURE__*/React.createElement(EditorContent, {
95
- docValue: slateValue,
96
- showOutline: true
97
- }, /*#__PURE__*/React.createElement(SlateEditor, {
98
- editor: editor,
99
- slateValue: slateValue,
100
- setSlateValue: setSlateValue
101
- }))), /*#__PURE__*/React.createElement(InsertElementDialog, {
102
- editor: editor
103
- }));
104
- });
105
- export default SDocEditor;