@manuscripts/article-editor 4.7.4 → 4.7.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/components/comments/CommentBody.js +60 -6
- package/dist/cjs/components/comments/CommentBody.js.map +1 -1
- package/dist/cjs/components/comments/CommentCard.js +8 -5
- package/dist/cjs/components/comments/CommentCard.js.map +1 -1
- package/dist/cjs/components/comments/CommentThread.js +15 -5
- package/dist/cjs/components/comments/CommentThread.js.map +1 -1
- package/dist/cjs/hooks/use-preserved-comments.js +47 -0
- package/dist/cjs/hooks/use-preserved-comments.js.map +1 -0
- package/dist/es/components/comments/CommentBody.js +61 -7
- package/dist/es/components/comments/CommentBody.js.map +1 -1
- package/dist/es/components/comments/CommentCard.js +8 -5
- package/dist/es/components/comments/CommentCard.js.map +1 -1
- package/dist/es/components/comments/CommentThread.js +15 -5
- package/dist/es/components/comments/CommentThread.js.map +1 -1
- package/dist/es/hooks/use-preserved-comments.js +43 -0
- package/dist/es/hooks/use-preserved-comments.js.map +1 -0
- package/dist/types/hooks/use-preserved-comments.d.ts +5 -0
- package/package.json +1 -1
|
@@ -40,6 +40,7 @@ exports.CommentBody = void 0;
|
|
|
40
40
|
const style_guide_1 = require("@manuscripts/style-guide");
|
|
41
41
|
const react_1 = __importStar(require("react"));
|
|
42
42
|
const styled_components_1 = __importDefault(require("styled-components"));
|
|
43
|
+
const use_preserved_comments_1 = require("../../hooks/use-preserved-comments");
|
|
43
44
|
const utils_1 = require("../../lib/utils");
|
|
44
45
|
const CommentEditor = styled_components_1.default.textarea `
|
|
45
46
|
cursor: text;
|
|
@@ -90,24 +91,77 @@ const EditorActions = (0, styled_components_1.default)(style_guide_1.ButtonGroup
|
|
|
90
91
|
`;
|
|
91
92
|
const CommentBody = ({ comment, isEditing, onSave, onCancel, }) => {
|
|
92
93
|
const editor = (0, react_1.useRef)(null);
|
|
94
|
+
const commentId = comment.node.attrs.id;
|
|
95
|
+
const isCancellingRef = (0, react_1.useRef)(false);
|
|
96
|
+
const { get: getPreserved, set: setPreserved, remove: removePreserved, } = (0, use_preserved_comments_1.usePreservedComments)();
|
|
97
|
+
const savedContentsRef = (0, react_1.useRef)(comment.node.attrs.contents || '');
|
|
98
|
+
// Initialize value with preserved content or comment contents
|
|
99
|
+
const [value, setValue] = (0, react_1.useState)(() => {
|
|
100
|
+
const preserved = getPreserved(commentId);
|
|
101
|
+
return preserved !== undefined
|
|
102
|
+
? preserved
|
|
103
|
+
: comment.node.attrs.contents || '';
|
|
104
|
+
});
|
|
105
|
+
(0, react_1.useEffect)(() => {
|
|
106
|
+
if (!isEditing) {
|
|
107
|
+
return;
|
|
108
|
+
}
|
|
109
|
+
const trimmed = value.trim();
|
|
110
|
+
if (!trimmed) {
|
|
111
|
+
return;
|
|
112
|
+
}
|
|
113
|
+
if (trimmed === savedContentsRef.current) {
|
|
114
|
+
return;
|
|
115
|
+
}
|
|
116
|
+
setPreserved(commentId, trimmed);
|
|
117
|
+
}, [value, isEditing, commentId, setPreserved]);
|
|
118
|
+
// Restore preserved content when isEditing becomes true
|
|
119
|
+
(0, react_1.useEffect)(() => {
|
|
120
|
+
if (!isEditing) {
|
|
121
|
+
return;
|
|
122
|
+
}
|
|
123
|
+
const preserved = getPreserved(commentId);
|
|
124
|
+
if (preserved !== undefined) {
|
|
125
|
+
setValue(preserved);
|
|
126
|
+
}
|
|
127
|
+
}, [isEditing, commentId, getPreserved]);
|
|
93
128
|
const handleSave = () => {
|
|
94
|
-
if
|
|
95
|
-
|
|
129
|
+
// Don't save if we're in the middle of cancelling
|
|
130
|
+
if (isCancellingRef.current) {
|
|
131
|
+
return;
|
|
132
|
+
}
|
|
133
|
+
if (value.trim()) {
|
|
134
|
+
onSave(value);
|
|
135
|
+
removePreserved(commentId);
|
|
96
136
|
}
|
|
97
137
|
};
|
|
138
|
+
const handleCancel = () => {
|
|
139
|
+
// Set flag to prevent any saves during cancel
|
|
140
|
+
isCancellingRef.current = true;
|
|
141
|
+
// Clear preserved content from store on cancel
|
|
142
|
+
removePreserved(commentId);
|
|
143
|
+
// Call the parent's onCancel
|
|
144
|
+
onCancel();
|
|
145
|
+
};
|
|
98
146
|
const ref = (0, react_1.useCallback)((e) => {
|
|
99
147
|
if (e && editor.current !== e) {
|
|
100
148
|
e.focus();
|
|
101
149
|
}
|
|
102
150
|
editor.current = e;
|
|
103
151
|
}, []);
|
|
104
|
-
const [value, setValue] = (0, react_1.useState)(editor.current?.value || '');
|
|
105
152
|
const disableSaveButton = (0, react_1.useMemo)(() => !value.length || comment.node.attrs.contents === value, [comment.node.attrs.contents, value]);
|
|
106
|
-
const onTextChange = (e) =>
|
|
153
|
+
const onTextChange = (0, react_1.useCallback)((e) => {
|
|
154
|
+
setValue(e.target.value);
|
|
155
|
+
}, []);
|
|
107
156
|
return (react_1.default.createElement(react_1.default.Fragment, null, isEditing ? (react_1.default.createElement(react_1.default.Fragment, null,
|
|
108
|
-
react_1.default.createElement(CommentEditor, { "data-cy": "comment-editor", ref: ref,
|
|
157
|
+
react_1.default.createElement(CommentEditor, { "data-cy": "comment-editor", ref: ref, value: value, onChange: onTextChange, onBlur: () => {
|
|
158
|
+
// If the comment is empty, automatically cancel/discard it
|
|
159
|
+
if (!value.trim()) {
|
|
160
|
+
handleCancel();
|
|
161
|
+
}
|
|
162
|
+
} }),
|
|
109
163
|
react_1.default.createElement(EditorActions, { "data-cy": "comment-actions" },
|
|
110
|
-
react_1.default.createElement(style_guide_1.TertiaryButton, { onClick:
|
|
164
|
+
react_1.default.createElement(style_guide_1.TertiaryButton, { onClick: handleCancel }, "Cancel"),
|
|
111
165
|
react_1.default.createElement(style_guide_1.PrimaryButton, { onClick: handleSave, disabled: disableSaveButton }, "Save")))) : (react_1.default.createElement(react_1.default.Fragment, null,
|
|
112
166
|
react_1.default.createElement(CommentViewer, { "data-cy": "comment-text" }, (0, utils_1.decodeHTMLEntities)(comment.node.attrs.contents))))));
|
|
113
167
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CommentBody.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentBody.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAYA,0DAIiC;AACjC,+
|
|
1
|
+
{"version":3,"file":"CommentBody.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentBody.tsx"],"names":[],"mappings":"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"}
|
|
@@ -101,15 +101,18 @@ const CommentCard = ({ comment, isReply, numOfReplies, isNew, isEndOfThread, isO
|
|
|
101
101
|
setEditingCommentId(commentID);
|
|
102
102
|
};
|
|
103
103
|
const handleSave = (contents) => {
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
104
|
+
if (contents.trim() && contents !== comment.node.attrs.contents) {
|
|
105
|
+
onSave({
|
|
106
|
+
...comment.node.attrs,
|
|
107
|
+
contents,
|
|
108
|
+
});
|
|
109
|
+
}
|
|
108
110
|
setEditingCommentId(null);
|
|
109
111
|
};
|
|
110
112
|
const handleCancel = () => {
|
|
111
113
|
setEditingCommentId(null);
|
|
112
|
-
if (
|
|
114
|
+
// Delete comment if it's new OR if it has no saved content (empty)
|
|
115
|
+
if (isNew || comment.node.attrs.contents.trim() === '') {
|
|
113
116
|
onDelete(commentID);
|
|
114
117
|
}
|
|
115
118
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CommentCard.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentCard.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAYA,0DAIiC;AACjC,+CAAuC;AACvC,0EAAsC;AAEtC,yDAAuD;AACvD,iDAAiE;AACjE,uCAAsC;AACtC,0FAK2D;AAC3D,qDAAuE;AACvE,+CAA2C;AAC3C,2EAAuE;AAEvE,MAAM,aAAa,GAAG,2BAAM,CAAC,GAAG,CAAA;;;;;;;CAO/B,CAAA;AAED,MAAM,SAAS,GAAG,IAAA,2BAAM,EAAC,0BAAY,CAAC,CAAA;;;;;;;CAOrC,CAAA;AACD,MAAM,YAAY,GAAG,2BAAM,CAAC,GAAG,CAAC,KAAK,CAAC;IACpC,SAAS,EAAE,aAAa;CACzB,CAAC,CAAA;;;;;;;;CAQD,CAAA;AACD,MAAM,IAAI,GAAG,2BAAM,CAAC,GAAG,CAAA;;CAEtB,CAAA;AAeM,MAAM,WAAW,GAA+B,CAAC,EACtD,OAAO,EACP,OAAO,EACP,YAAY,EACZ,KAAK,EACL,aAAa,EACb,eAAe,EACf,gBAAgB,EAChB,mBAAmB,EACnB,MAAM,EACN,QAAQ,GACT,EAAE,EAAE;IACH,MAAM,GAAG,GAAG,IAAA,6BAAc,GAAE,CAAA;IAC5B,MAAM,CAAC,EAAE,IAAI,EAAE,iBAAiB,EAAE,CAAC,GAAG,IAAA,gBAAQ,EAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACzD,IAAI,EAAE,KAAK,CAAC,IAAI;QAChB,iBAAiB,EAAE,KAAK,CAAC,iBAAiB;KAC3C,CAAC,CAAC,CAAA;IAEH,MAAM,QAAQ,GAAG,IAAA,sBAAW,EAAC,OAAO,CAAC,CAAA;IACrC,MAAM,UAAU,GAAG,QAAQ;QACzB,CAAC,CAAC,IAAA,0BAAe,EAAC,iBAAiB,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAClD,CAAC,CAAC,EAAE,CAAA;IAEN,MAAM,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,CAAA;IAEjE,MAAM,KAAK,GAAG,QAAQ,KAAK,IAAI,CAAC,GAAG,CAAA;IAEnC,MAAM,gBAAgB,GAAG,KAAK;QAC5B,CAAC,CAAC,GAAG,CAAC,iBAAiB;QACvB,CAAC,CAAC,GAAG,CAAC,oBAAoB,CAAA;IAE5B,MAAM,gBAAgB,GAAG,KAAK;QAC5B,CAAC,CAAC,GAAG,CAAC,iBAAiB;QACvB,CAAC,CAAC,GAAG,CAAC,oBAAoB,CAAA;IAE5B,MAAM,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAA;IACvC,MAAM,CAAC,sBAAsB,EAAE,yBAAyB,CAAC,GAAG,IAAA,gBAAQ,EAAC,KAAK,CAAC,CAAA;IAE3E,MAAM,UAAU,GAAG,GAAG,EAAE;QACtB,mBAAmB,CAAC,SAAS,CAAC,CAAA;IAChC,CAAC,CAAA;
|
|
1
|
+
{"version":3,"file":"CommentCard.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentCard.tsx"],"names":[],"mappings":"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"}
|
|
@@ -40,6 +40,7 @@ exports.CommentThread = void 0;
|
|
|
40
40
|
const style_guide_1 = require("@manuscripts/style-guide");
|
|
41
41
|
const react_1 = __importStar(require("react"));
|
|
42
42
|
const styled_components_1 = __importDefault(require("styled-components"));
|
|
43
|
+
const use_preserved_comments_1 = require("../../hooks/use-preserved-comments");
|
|
43
44
|
const capabilities_1 = require("../../lib/capabilities");
|
|
44
45
|
const comments_1 = require("../../lib/comments");
|
|
45
46
|
const CommentCard_1 = require("./CommentCard");
|
|
@@ -78,14 +79,23 @@ exports.CommentThread = (0, react_1.forwardRef)((props, ref) => {
|
|
|
78
79
|
const { thread, isSelected, onSelect, onSave, onDelete, insertCommentReply, isOrphanComment, } = props;
|
|
79
80
|
const can = (0, capabilities_1.usePermissions)();
|
|
80
81
|
const { comment, isNew, replies } = thread;
|
|
82
|
+
const { get: getPreserved } = (0, use_preserved_comments_1.usePreservedComments)();
|
|
81
83
|
const cardsRef = (0, react_1.useRef)(null);
|
|
82
84
|
const [showMore, setShowMore] = (0, react_1.useState)(false);
|
|
83
|
-
|
|
84
|
-
(0, react_1.
|
|
85
|
-
|
|
86
|
-
|
|
85
|
+
// Initialize editingCommentId: set to comment ID if it's new OR has UNSAVED preserved content
|
|
86
|
+
const [editingCommentId, setEditingCommentId] = (0, react_1.useState)(() => {
|
|
87
|
+
const commentId = comment.node.attrs.id;
|
|
88
|
+
if (isNew) {
|
|
89
|
+
return commentId;
|
|
90
|
+
}
|
|
91
|
+
// Check if there's preserved content that's different from saved content (unsaved changes)
|
|
92
|
+
const preservedContent = getPreserved(commentId);
|
|
93
|
+
const savedContent = comment.node.attrs.contents;
|
|
94
|
+
if (preservedContent && preservedContent !== savedContent) {
|
|
95
|
+
return commentId;
|
|
87
96
|
}
|
|
88
|
-
|
|
97
|
+
return null;
|
|
98
|
+
});
|
|
89
99
|
(0, react_1.useEffect)(() => {
|
|
90
100
|
if (cardsRef.current) {
|
|
91
101
|
const contentHeight = cardsRef.current.scrollHeight;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CommentThread.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentThread.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAYA,0DAAqD;AACrD,+CAAsE;AACtE,0EAAsC;AAEtC,yDAAuD;AACvD,iDAA2D;AAC3D,+CAA2C;AAC3C,yCAAqC;AAErC,MAAM,SAAS,GAAG,2BAAM,CAAC,GAAG,CAA0B;;sBAEhC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC;;IAEpE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,UAAU,IAAI,wBAAwB;;;;;;;kBAOzC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC;;;;;;;;;;CAUrE,CAAA;AACD,MAAM,aAAa,GAAG,2BAAM,CAAC,GAAG,CAAA;;;;CAI/B,CAAA;AACD,MAAM,QAAQ,GAAG,2BAAM,CAAC,GAAG,CAAA;;CAE1B,CAAA;AAYY,QAAA,aAAa,GAAG,IAAA,kBAAU,EACrC,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;IACb,MAAM,EACJ,MAAM,EACN,UAAU,EACV,QAAQ,EACR,MAAM,EACN,QAAQ,EACR,kBAAkB,EAClB,eAAe,GAChB,GAAG,KAAK,CAAA;IAET,MAAM,GAAG,GAAG,IAAA,6BAAc,GAAE,CAAA;IAE5B,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,MAAM,CAAA;
|
|
1
|
+
{"version":3,"file":"CommentThread.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentThread.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.usePreservedComments = void 0;
|
|
4
|
+
/*!
|
|
5
|
+
* The contents of this file are subject to the Common Public Attribution License Version 1.0 (the “License”); you may not use this file except in compliance with the License. You may obtain a copy of the License at https://mpapp-public.gitlab.io/manuscripts-frontend/LICENSE. The License is based on the Mozilla Public License Version 1.1 but Sections 14 and 15 have been added to cover use of software over a computer network and provide for limited attribution for the Original Developer. In addition, Exhibit A has been modified to be consistent with Exhibit B.
|
|
6
|
+
*
|
|
7
|
+
* Software distributed under the License is distributed on an “AS IS” basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for the specific language governing rights and limitations under the License.
|
|
8
|
+
*
|
|
9
|
+
* The Original Code is manuscripts-frontend.
|
|
10
|
+
*
|
|
11
|
+
* The Original Developer is the Initial Developer. The Initial Developer of the Original Code is Atypon Systems LLC.
|
|
12
|
+
*
|
|
13
|
+
* All portions of the code written by Atypon Systems LLC are Copyright (c) 2024 Atypon Systems LLC. All Rights Reserved.
|
|
14
|
+
*/
|
|
15
|
+
const react_1 = require("react");
|
|
16
|
+
const store_1 = require("../store");
|
|
17
|
+
const usePreservedComments = () => {
|
|
18
|
+
const [, dispatch, getState] = (0, store_1.useStore)((s) => s);
|
|
19
|
+
const get = (0, react_1.useCallback)((id) => {
|
|
20
|
+
const map = getState()?.preservedCommentContent;
|
|
21
|
+
return map?.get(id);
|
|
22
|
+
}, [getState]);
|
|
23
|
+
const set = (0, react_1.useCallback)((id, val) => {
|
|
24
|
+
const currMap = getState()?.preservedCommentContent ||
|
|
25
|
+
new Map();
|
|
26
|
+
const existing = currMap.get(id);
|
|
27
|
+
if (existing === val) {
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
const next = new Map(currMap);
|
|
31
|
+
next.set(id, val);
|
|
32
|
+
dispatch({ preservedCommentContent: next });
|
|
33
|
+
}, [dispatch, getState]);
|
|
34
|
+
const remove = (0, react_1.useCallback)((id) => {
|
|
35
|
+
const currMap = getState()?.preservedCommentContent ||
|
|
36
|
+
new Map();
|
|
37
|
+
if (!currMap.has(id)) {
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
const next = new Map(currMap);
|
|
41
|
+
next.delete(id);
|
|
42
|
+
dispatch({ preservedCommentContent: next });
|
|
43
|
+
}, [dispatch, getState]);
|
|
44
|
+
return { get, set, remove };
|
|
45
|
+
};
|
|
46
|
+
exports.usePreservedComments = usePreservedComments;
|
|
47
|
+
//# sourceMappingURL=use-preserved-comments.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-preserved-comments.js","sourceRoot":"","sources":["../../../src/hooks/use-preserved-comments.ts"],"names":[],"mappings":";;;AAAA;;;;;;;;;;GAUG;AACH,iCAAmC;AAEnC,oCAAmC;AAE5B,MAAM,oBAAoB,GAAG,GAAG,EAAE;IACvC,MAAM,CAAC,EAAE,QAAQ,EAAE,QAAQ,CAAC,GAAG,IAAA,gBAAQ,EAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAQ,CAAQ,CAAA;IAE/D,MAAM,GAAG,GAAG,IAAA,mBAAW,EACrB,CAAC,EAAU,EAAsB,EAAE;QACjC,MAAM,GAAG,GAAG,QAAQ,EAAE,EAAE,uBAA8C,CAAA;QACtE,OAAO,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAA;IACrB,CAAC,EACD,CAAC,QAAQ,CAAC,CACX,CAAA;IAED,MAAM,GAAG,GAAG,IAAA,mBAAW,EACrB,CAAC,EAAU,EAAE,GAAW,EAAE,EAAE;QAC1B,MAAM,OAAO,GACV,QAAQ,EAAE,EAAE,uBAA+C;YAC5D,IAAI,GAAG,EAAE,CAAA;QACX,MAAM,QAAQ,GAAG,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;QAChC,IAAI,QAAQ,KAAK,GAAG,EAAE,CAAC;YACrB,OAAM;QACR,CAAC;QACD,MAAM,IAAI,GAAG,IAAI,GAAG,CAAC,OAAO,CAAC,CAAA;QAC7B,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,GAAG,CAAC,CAAA;QACjB,QAAQ,CAAC,EAAE,uBAAuB,EAAE,IAAI,EAAE,CAAC,CAAA;IAC7C,CAAC,EACD,CAAC,QAAQ,EAAE,QAAQ,CAAC,CACrB,CAAA;IAED,MAAM,MAAM,GAAG,IAAA,mBAAW,EACxB,CAAC,EAAU,EAAE,EAAE;QACb,MAAM,OAAO,GACV,QAAQ,EAAE,EAAE,uBAA+C;YAC5D,IAAI,GAAG,EAAE,CAAA;QACX,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC;YACrB,OAAM;QACR,CAAC;QACD,MAAM,IAAI,GAAG,IAAI,GAAG,CAAC,OAAO,CAAC,CAAA;QAC7B,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAA;QACf,QAAQ,CAAC,EAAE,uBAAuB,EAAE,IAAI,EAAE,CAAC,CAAA;IAC7C,CAAC,EACD,CAAC,QAAQ,EAAE,QAAQ,CAAC,CACrB,CAAA;IAED,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,MAAM,EAAE,CAAA;AAC7B,CAAC,CAAA;AA3CY,QAAA,oBAAoB,wBA2ChC"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { ButtonGroup, PrimaryButton, TertiaryButton, } from '@manuscripts/style-guide';
|
|
2
|
-
import React, { useCallback, useMemo, useRef, useState, } from 'react';
|
|
2
|
+
import React, { useCallback, useEffect, useMemo, useRef, useState, } from 'react';
|
|
3
3
|
import styled from 'styled-components';
|
|
4
|
+
import { usePreservedComments } from '../../hooks/use-preserved-comments';
|
|
4
5
|
import { decodeHTMLEntities } from '../../lib/utils';
|
|
5
6
|
const CommentEditor = styled.textarea `
|
|
6
7
|
cursor: text;
|
|
@@ -51,24 +52,77 @@ const EditorActions = styled(ButtonGroup) `
|
|
|
51
52
|
`;
|
|
52
53
|
export const CommentBody = ({ comment, isEditing, onSave, onCancel, }) => {
|
|
53
54
|
const editor = useRef(null);
|
|
55
|
+
const commentId = comment.node.attrs.id;
|
|
56
|
+
const isCancellingRef = useRef(false);
|
|
57
|
+
const { get: getPreserved, set: setPreserved, remove: removePreserved, } = usePreservedComments();
|
|
58
|
+
const savedContentsRef = useRef(comment.node.attrs.contents || '');
|
|
59
|
+
// Initialize value with preserved content or comment contents
|
|
60
|
+
const [value, setValue] = useState(() => {
|
|
61
|
+
const preserved = getPreserved(commentId);
|
|
62
|
+
return preserved !== undefined
|
|
63
|
+
? preserved
|
|
64
|
+
: comment.node.attrs.contents || '';
|
|
65
|
+
});
|
|
66
|
+
useEffect(() => {
|
|
67
|
+
if (!isEditing) {
|
|
68
|
+
return;
|
|
69
|
+
}
|
|
70
|
+
const trimmed = value.trim();
|
|
71
|
+
if (!trimmed) {
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
if (trimmed === savedContentsRef.current) {
|
|
75
|
+
return;
|
|
76
|
+
}
|
|
77
|
+
setPreserved(commentId, trimmed);
|
|
78
|
+
}, [value, isEditing, commentId, setPreserved]);
|
|
79
|
+
// Restore preserved content when isEditing becomes true
|
|
80
|
+
useEffect(() => {
|
|
81
|
+
if (!isEditing) {
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
const preserved = getPreserved(commentId);
|
|
85
|
+
if (preserved !== undefined) {
|
|
86
|
+
setValue(preserved);
|
|
87
|
+
}
|
|
88
|
+
}, [isEditing, commentId, getPreserved]);
|
|
54
89
|
const handleSave = () => {
|
|
55
|
-
if
|
|
56
|
-
|
|
90
|
+
// Don't save if we're in the middle of cancelling
|
|
91
|
+
if (isCancellingRef.current) {
|
|
92
|
+
return;
|
|
93
|
+
}
|
|
94
|
+
if (value.trim()) {
|
|
95
|
+
onSave(value);
|
|
96
|
+
removePreserved(commentId);
|
|
57
97
|
}
|
|
58
98
|
};
|
|
99
|
+
const handleCancel = () => {
|
|
100
|
+
// Set flag to prevent any saves during cancel
|
|
101
|
+
isCancellingRef.current = true;
|
|
102
|
+
// Clear preserved content from store on cancel
|
|
103
|
+
removePreserved(commentId);
|
|
104
|
+
// Call the parent's onCancel
|
|
105
|
+
onCancel();
|
|
106
|
+
};
|
|
59
107
|
const ref = useCallback((e) => {
|
|
60
108
|
if (e && editor.current !== e) {
|
|
61
109
|
e.focus();
|
|
62
110
|
}
|
|
63
111
|
editor.current = e;
|
|
64
112
|
}, []);
|
|
65
|
-
const [value, setValue] = useState(editor.current?.value || '');
|
|
66
113
|
const disableSaveButton = useMemo(() => !value.length || comment.node.attrs.contents === value, [comment.node.attrs.contents, value]);
|
|
67
|
-
const onTextChange = (e) =>
|
|
114
|
+
const onTextChange = useCallback((e) => {
|
|
115
|
+
setValue(e.target.value);
|
|
116
|
+
}, []);
|
|
68
117
|
return (React.createElement(React.Fragment, null, isEditing ? (React.createElement(React.Fragment, null,
|
|
69
|
-
React.createElement(CommentEditor, { "data-cy": "comment-editor", ref: ref,
|
|
118
|
+
React.createElement(CommentEditor, { "data-cy": "comment-editor", ref: ref, value: value, onChange: onTextChange, onBlur: () => {
|
|
119
|
+
// If the comment is empty, automatically cancel/discard it
|
|
120
|
+
if (!value.trim()) {
|
|
121
|
+
handleCancel();
|
|
122
|
+
}
|
|
123
|
+
} }),
|
|
70
124
|
React.createElement(EditorActions, { "data-cy": "comment-actions" },
|
|
71
|
-
React.createElement(TertiaryButton, { onClick:
|
|
125
|
+
React.createElement(TertiaryButton, { onClick: handleCancel }, "Cancel"),
|
|
72
126
|
React.createElement(PrimaryButton, { onClick: handleSave, disabled: disableSaveButton }, "Save")))) : (React.createElement(React.Fragment, null,
|
|
73
127
|
React.createElement(CommentViewer, { "data-cy": "comment-text" }, decodeHTMLEntities(comment.node.attrs.contents))))));
|
|
74
128
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CommentBody.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentBody.tsx"],"names":[],"mappings":"AAYA,OAAO,EACL,WAAW,EACX,aAAa,EACb,cAAc,GACf,MAAM,0BAA0B,CAAA;AACjC,OAAO,KAAK,EAAE,EAEZ,WAAW,EACX,OAAO,EACP,MAAM,EACN,QAAQ,GACT,MAAM,OAAO,CAAA;AACd,OAAO,MAAM,MAAM,mBAAmB,CAAA;AAEtC,OAAO,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAA;AAEpD,MAAM,aAAa,GAAG,MAAM,CAAC,QAAQ,CAAA;;iBAEpB,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI;WAC7C,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO;YACzC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC;;;;;;;;;;;;;;;;;;;;CAoB/C,CAAA;AAED,MAAM,aAAa,GAAG,MAAM,CAAC,GAAG,CAAA;;;iBAGf,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI;;;WAG7C,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO;YACzC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC;;CAE/C,CAAA;AAED,MAAM,aAAa,GAAG,MAAM,CAAC,WAAW,CAAC,CAAA;;;;;MAKnC,cAAc;;;;;;CAMnB,CAAA;AASD,MAAM,CAAC,MAAM,WAAW,GAA+B,CAAC,EACtD,OAAO,EACP,SAAS,EACT,MAAM,EACN,QAAQ,GACT,EAAE,EAAE;IACH,MAAM,MAAM,GAAG,MAAM,CAA6B,IAAI,CAAC,CAAA;IACvD,MAAM,
|
|
1
|
+
{"version":3,"file":"CommentBody.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentBody.tsx"],"names":[],"mappings":"AAYA,OAAO,EACL,WAAW,EACX,aAAa,EACb,cAAc,GACf,MAAM,0BAA0B,CAAA;AACjC,OAAO,KAAK,EAAE,EAEZ,WAAW,EACX,SAAS,EACT,OAAO,EACP,MAAM,EACN,QAAQ,GACT,MAAM,OAAO,CAAA;AACd,OAAO,MAAM,MAAM,mBAAmB,CAAA;AAEtC,OAAO,EAAE,oBAAoB,EAAE,MAAM,oCAAoC,CAAA;AACzE,OAAO,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAA;AAEpD,MAAM,aAAa,GAAG,MAAM,CAAC,QAAQ,CAAA;;iBAEpB,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI;WAC7C,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO;YACzC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC;;;;;;;;;;;;;;;;;;;;CAoB/C,CAAA;AAED,MAAM,aAAa,GAAG,MAAM,CAAC,GAAG,CAAA;;;iBAGf,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI;;;WAG7C,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO;YACzC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC;;CAE/C,CAAA;AAED,MAAM,aAAa,GAAG,MAAM,CAAC,WAAW,CAAC,CAAA;;;;;MAKnC,cAAc;;;;;;CAMnB,CAAA;AASD,MAAM,CAAC,MAAM,WAAW,GAA+B,CAAC,EACtD,OAAO,EACP,SAAS,EACT,MAAM,EACN,QAAQ,GACT,EAAE,EAAE;IACH,MAAM,MAAM,GAAG,MAAM,CAA6B,IAAI,CAAC,CAAA;IACvD,MAAM,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAA;IACvC,MAAM,eAAe,GAAG,MAAM,CAAC,KAAK,CAAC,CAAA;IACrC,MAAM,EACJ,GAAG,EAAE,YAAY,EACjB,GAAG,EAAE,YAAY,EACjB,MAAM,EAAE,eAAe,GACxB,GAAG,oBAAoB,EAAE,CAAA;IAC1B,MAAM,gBAAgB,GAAG,MAAM,CAAS,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAA;IAE1E,8DAA8D;IAC9D,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAC,GAAG,EAAE;QACtC,MAAM,SAAS,GAAG,YAAY,CAAC,SAAS,CAAC,CAAA;QACzC,OAAO,SAAS,KAAK,SAAS;YAC5B,CAAC,CAAC,SAAS;YACX,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,EAAE,CAAA;IACvC,CAAC,CAAC,CAAA;IAEF,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,OAAM;QACR,CAAC;QACD,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,EAAE,CAAA;QAC5B,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,OAAM;QACR,CAAC;QACD,IAAI,OAAO,KAAK,gBAAgB,CAAC,OAAO,EAAE,CAAC;YACzC,OAAM;QACR,CAAC;QACD,YAAY,CAAC,SAAS,EAAE,OAAO,CAAC,CAAA;IAClC,CAAC,EAAE,CAAC,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,YAAY,CAAC,CAAC,CAAA;IAE/C,wDAAwD;IACxD,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,OAAM;QACR,CAAC;QACD,MAAM,SAAS,GAAG,YAAY,CAAC,SAAS,CAAC,CAAA;QACzC,IAAI,SAAS,KAAK,SAAS,EAAE,CAAC;YAC5B,QAAQ,CAAC,SAAS,CAAC,CAAA;QACrB,CAAC;IACH,CAAC,EAAE,CAAC,SAAS,EAAE,SAAS,EAAE,YAAY,CAAC,CAAC,CAAA;IAExC,MAAM,UAAU,GAAG,GAAG,EAAE;QACtB,kDAAkD;QAClD,IAAI,eAAe,CAAC,OAAO,EAAE,CAAC;YAC5B,OAAM;QACR,CAAC;QAED,IAAI,KAAK,CAAC,IAAI,EAAE,EAAE,CAAC;YACjB,MAAM,CAAC,KAAK,CAAC,CAAA;YACb,eAAe,CAAC,SAAS,CAAC,CAAA;QAC5B,CAAC;IACH,CAAC,CAAA;IAED,MAAM,YAAY,GAAG,GAAG,EAAE;QACxB,8CAA8C;QAC9C,eAAe,CAAC,OAAO,GAAG,IAAI,CAAA;QAE9B,+CAA+C;QAC/C,eAAe,CAAC,SAAS,CAAC,CAAA;QAE1B,6BAA6B;QAC7B,QAAQ,EAAE,CAAA;IACZ,CAAC,CAAA;IAED,MAAM,GAAG,GAAG,WAAW,CAAC,CAAC,CAA6B,EAAE,EAAE;QACxD,IAAI,CAAC,IAAI,MAAM,CAAC,OAAO,KAAK,CAAC,EAAE,CAAC;YAC9B,CAAC,CAAC,KAAK,EAAE,CAAA;QACX,CAAC;QACD,MAAM,CAAC,OAAO,GAAG,CAAC,CAAA;IACpB,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,MAAM,iBAAiB,GAAG,OAAO,CAC/B,GAAG,EAAE,CAAC,CAAC,KAAK,CAAC,MAAM,IAAI,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,KAAK,KAAK,EAC5D,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,CACrC,CAAA;IAED,MAAM,YAAY,GAAG,WAAW,CAAC,CAAC,CAAmC,EAAE,EAAE;QACvE,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;IAC1B,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,OAAO,CACL,0CACG,SAAS,CAAC,CAAC,CAAC,CACX;QACE,oBAAC,aAAa,eACJ,gBAAgB,EACxB,GAAG,EAAE,GAAG,EACR,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,YAAY,EACtB,MAAM,EAAE,GAAG,EAAE;gBACX,2DAA2D;gBAC3D,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,CAAC;oBAClB,YAAY,EAAE,CAAA;gBAChB,CAAC;YACH,CAAC,GACc;QACjB,oBAAC,aAAa,eAAS,iBAAiB;YACtC,oBAAC,cAAc,IAAC,OAAO,EAAE,YAAY,aAAyB;YAC9D,oBAAC,aAAa,IAAC,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,iBAAiB,WAE/C,CACF,CACf,CACJ,CAAC,CAAC,CAAC,CACF;QACE,oBAAC,aAAa,eAAS,cAAc,IAClC,kBAAkB,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAClC,CACf,CACJ,CACA,CACJ,CAAA;AACH,CAAC,CAAA"}
|
|
@@ -62,15 +62,18 @@ export const CommentCard = ({ comment, isReply, numOfReplies, isNew, isEndOfThre
|
|
|
62
62
|
setEditingCommentId(commentID);
|
|
63
63
|
};
|
|
64
64
|
const handleSave = (contents) => {
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
65
|
+
if (contents.trim() && contents !== comment.node.attrs.contents) {
|
|
66
|
+
onSave({
|
|
67
|
+
...comment.node.attrs,
|
|
68
|
+
contents,
|
|
69
|
+
});
|
|
70
|
+
}
|
|
69
71
|
setEditingCommentId(null);
|
|
70
72
|
};
|
|
71
73
|
const handleCancel = () => {
|
|
72
74
|
setEditingCommentId(null);
|
|
73
|
-
if (
|
|
75
|
+
// Delete comment if it's new OR if it has no saved content (empty)
|
|
76
|
+
if (isNew || comment.node.attrs.contents.trim() === '') {
|
|
74
77
|
onDelete(commentID);
|
|
75
78
|
}
|
|
76
79
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CommentCard.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentCard.tsx"],"names":[],"mappings":"AAYA,OAAO,EACL,UAAU,EACV,YAAY,EACZ,oBAAoB,GACrB,MAAM,0BAA0B,CAAA;AACjC,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AACvC,OAAO,MAAM,MAAM,mBAAmB,CAAA;AAEtC,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA;AACvD,OAAO,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAA;AACjE,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAA;AACtC,OAAO,EACL,eAAe,EACf,UAAU,EACV,UAAU,EACV,YAAY,GACb,MAAM,oDAAoD,CAAA;AAC3D,OAAO,EAAE,cAAc,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAA;AACvE,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA;AAC3C,OAAO,EAAE,yBAAyB,EAAE,MAAM,6BAA6B,CAAA;AAEvE,MAAM,aAAa,GAAG,MAAM,CAAC,GAAG,CAAA;;;;;;;CAO/B,CAAA;AAED,MAAM,SAAS,GAAG,MAAM,CAAC,YAAY,CAAC,CAAA;;;;;;;CAOrC,CAAA;AACD,MAAM,YAAY,GAAG,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC;IACpC,SAAS,EAAE,aAAa;CACzB,CAAC,CAAA;;;;;;;;CAQD,CAAA;AACD,MAAM,IAAI,GAAG,MAAM,CAAC,GAAG,CAAA;;CAEtB,CAAA;AAeD,MAAM,CAAC,MAAM,WAAW,GAA+B,CAAC,EACtD,OAAO,EACP,OAAO,EACP,YAAY,EACZ,KAAK,EACL,aAAa,EACb,eAAe,EACf,gBAAgB,EAChB,mBAAmB,EACnB,MAAM,EACN,QAAQ,GACT,EAAE,EAAE;IACH,MAAM,GAAG,GAAG,cAAc,EAAE,CAAA;IAC5B,MAAM,CAAC,EAAE,IAAI,EAAE,iBAAiB,EAAE,CAAC,GAAG,QAAQ,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACzD,IAAI,EAAE,KAAK,CAAC,IAAI;QAChB,iBAAiB,EAAE,KAAK,CAAC,iBAAiB;KAC3C,CAAC,CAAC,CAAA;IAEH,MAAM,QAAQ,GAAG,WAAW,CAAC,OAAO,CAAC,CAAA;IACrC,MAAM,UAAU,GAAG,QAAQ;QACzB,CAAC,CAAC,eAAe,CAAC,iBAAiB,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAClD,CAAC,CAAC,EAAE,CAAA;IAEN,MAAM,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,CAAA;IAEjE,MAAM,KAAK,GAAG,QAAQ,KAAK,IAAI,CAAC,GAAG,CAAA;IAEnC,MAAM,gBAAgB,GAAG,KAAK;QAC5B,CAAC,CAAC,GAAG,CAAC,iBAAiB;QACvB,CAAC,CAAC,GAAG,CAAC,oBAAoB,CAAA;IAE5B,MAAM,gBAAgB,GAAG,KAAK;QAC5B,CAAC,CAAC,GAAG,CAAC,iBAAiB;QACvB,CAAC,CAAC,GAAG,CAAC,oBAAoB,CAAA;IAE5B,MAAM,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAA;IACvC,MAAM,CAAC,sBAAsB,EAAE,yBAAyB,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IAE3E,MAAM,UAAU,GAAG,GAAG,EAAE;QACtB,mBAAmB,CAAC,SAAS,CAAC,CAAA;IAChC,CAAC,CAAA;
|
|
1
|
+
{"version":3,"file":"CommentCard.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentCard.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { TextButton } from '@manuscripts/style-guide';
|
|
2
2
|
import React, { forwardRef, useEffect, useRef, useState } from 'react';
|
|
3
3
|
import styled from 'styled-components';
|
|
4
|
+
import { usePreservedComments } from '../../hooks/use-preserved-comments';
|
|
4
5
|
import { usePermissions } from '../../lib/capabilities';
|
|
5
6
|
import { commentsByTime } from '../../lib/comments';
|
|
6
7
|
import { CommentCard } from './CommentCard';
|
|
@@ -39,14 +40,23 @@ export const CommentThread = forwardRef((props, ref) => {
|
|
|
39
40
|
const { thread, isSelected, onSelect, onSave, onDelete, insertCommentReply, isOrphanComment, } = props;
|
|
40
41
|
const can = usePermissions();
|
|
41
42
|
const { comment, isNew, replies } = thread;
|
|
43
|
+
const { get: getPreserved } = usePreservedComments();
|
|
42
44
|
const cardsRef = useRef(null);
|
|
43
45
|
const [showMore, setShowMore] = useState(false);
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
46
|
+
// Initialize editingCommentId: set to comment ID if it's new OR has UNSAVED preserved content
|
|
47
|
+
const [editingCommentId, setEditingCommentId] = useState(() => {
|
|
48
|
+
const commentId = comment.node.attrs.id;
|
|
49
|
+
if (isNew) {
|
|
50
|
+
return commentId;
|
|
51
|
+
}
|
|
52
|
+
// Check if there's preserved content that's different from saved content (unsaved changes)
|
|
53
|
+
const preservedContent = getPreserved(commentId);
|
|
54
|
+
const savedContent = comment.node.attrs.contents;
|
|
55
|
+
if (preservedContent && preservedContent !== savedContent) {
|
|
56
|
+
return commentId;
|
|
48
57
|
}
|
|
49
|
-
|
|
58
|
+
return null;
|
|
59
|
+
});
|
|
50
60
|
useEffect(() => {
|
|
51
61
|
if (cardsRef.current) {
|
|
52
62
|
const contentHeight = cardsRef.current.scrollHeight;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CommentThread.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentThread.tsx"],"names":[],"mappings":"AAYA,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAA;AACrD,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AACtE,OAAO,MAAM,MAAM,mBAAmB,CAAA;AAEtC,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA;AACvD,OAAO,EAAE,cAAc,EAAU,MAAM,oBAAoB,CAAA;AAC3D,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA;AAC3C,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAErC,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,CAA0B;;sBAEhC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC;;IAEpE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,UAAU,IAAI,wBAAwB;;;;;;;kBAOzC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC;;;;;;;;;;CAUrE,CAAA;AACD,MAAM,aAAa,GAAG,MAAM,CAAC,GAAG,CAAA;;;;CAI/B,CAAA;AACD,MAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAA;;CAE1B,CAAA;AAYD,MAAM,CAAC,MAAM,aAAa,GAAG,UAAU,CACrC,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;IACb,MAAM,EACJ,MAAM,EACN,UAAU,EACV,QAAQ,EACR,MAAM,EACN,QAAQ,EACR,kBAAkB,EAClB,eAAe,GAChB,GAAG,KAAK,CAAA;IAET,MAAM,GAAG,GAAG,cAAc,EAAE,CAAA;IAE5B,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,MAAM,CAAA;
|
|
1
|
+
{"version":3,"file":"CommentThread.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentThread.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* The contents of this file are subject to the Common Public Attribution License Version 1.0 (the “License”); you may not use this file except in compliance with the License. You may obtain a copy of the License at https://mpapp-public.gitlab.io/manuscripts-frontend/LICENSE. The License is based on the Mozilla Public License Version 1.1 but Sections 14 and 15 have been added to cover use of software over a computer network and provide for limited attribution for the Original Developer. In addition, Exhibit A has been modified to be consistent with Exhibit B.
|
|
3
|
+
*
|
|
4
|
+
* Software distributed under the License is distributed on an “AS IS” basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for the specific language governing rights and limitations under the License.
|
|
5
|
+
*
|
|
6
|
+
* The Original Code is manuscripts-frontend.
|
|
7
|
+
*
|
|
8
|
+
* The Original Developer is the Initial Developer. The Initial Developer of the Original Code is Atypon Systems LLC.
|
|
9
|
+
*
|
|
10
|
+
* All portions of the code written by Atypon Systems LLC are Copyright (c) 2024 Atypon Systems LLC. All Rights Reserved.
|
|
11
|
+
*/
|
|
12
|
+
import { useCallback } from 'react';
|
|
13
|
+
import { useStore } from '../store';
|
|
14
|
+
export const usePreservedComments = () => {
|
|
15
|
+
const [, dispatch, getState] = useStore((s) => s);
|
|
16
|
+
const get = useCallback((id) => {
|
|
17
|
+
const map = getState()?.preservedCommentContent;
|
|
18
|
+
return map?.get(id);
|
|
19
|
+
}, [getState]);
|
|
20
|
+
const set = useCallback((id, val) => {
|
|
21
|
+
const currMap = getState()?.preservedCommentContent ||
|
|
22
|
+
new Map();
|
|
23
|
+
const existing = currMap.get(id);
|
|
24
|
+
if (existing === val) {
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
const next = new Map(currMap);
|
|
28
|
+
next.set(id, val);
|
|
29
|
+
dispatch({ preservedCommentContent: next });
|
|
30
|
+
}, [dispatch, getState]);
|
|
31
|
+
const remove = useCallback((id) => {
|
|
32
|
+
const currMap = getState()?.preservedCommentContent ||
|
|
33
|
+
new Map();
|
|
34
|
+
if (!currMap.has(id)) {
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
const next = new Map(currMap);
|
|
38
|
+
next.delete(id);
|
|
39
|
+
dispatch({ preservedCommentContent: next });
|
|
40
|
+
}, [dispatch, getState]);
|
|
41
|
+
return { get, set, remove };
|
|
42
|
+
};
|
|
43
|
+
//# sourceMappingURL=use-preserved-comments.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-preserved-comments.js","sourceRoot":"","sources":["../../../src/hooks/use-preserved-comments.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AACH,OAAO,EAAE,WAAW,EAAE,MAAM,OAAO,CAAA;AAEnC,OAAO,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAA;AAEnC,MAAM,CAAC,MAAM,oBAAoB,GAAG,GAAG,EAAE;IACvC,MAAM,CAAC,EAAE,QAAQ,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAQ,CAAQ,CAAA;IAE/D,MAAM,GAAG,GAAG,WAAW,CACrB,CAAC,EAAU,EAAsB,EAAE;QACjC,MAAM,GAAG,GAAG,QAAQ,EAAE,EAAE,uBAA8C,CAAA;QACtE,OAAO,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAA;IACrB,CAAC,EACD,CAAC,QAAQ,CAAC,CACX,CAAA;IAED,MAAM,GAAG,GAAG,WAAW,CACrB,CAAC,EAAU,EAAE,GAAW,EAAE,EAAE;QAC1B,MAAM,OAAO,GACV,QAAQ,EAAE,EAAE,uBAA+C;YAC5D,IAAI,GAAG,EAAE,CAAA;QACX,MAAM,QAAQ,GAAG,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;QAChC,IAAI,QAAQ,KAAK,GAAG,EAAE,CAAC;YACrB,OAAM;QACR,CAAC;QACD,MAAM,IAAI,GAAG,IAAI,GAAG,CAAC,OAAO,CAAC,CAAA;QAC7B,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,GAAG,CAAC,CAAA;QACjB,QAAQ,CAAC,EAAE,uBAAuB,EAAE,IAAI,EAAE,CAAC,CAAA;IAC7C,CAAC,EACD,CAAC,QAAQ,EAAE,QAAQ,CAAC,CACrB,CAAA;IAED,MAAM,MAAM,GAAG,WAAW,CACxB,CAAC,EAAU,EAAE,EAAE;QACb,MAAM,OAAO,GACV,QAAQ,EAAE,EAAE,uBAA+C;YAC5D,IAAI,GAAG,EAAE,CAAA;QACX,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC;YACrB,OAAM;QACR,CAAC;QACD,MAAM,IAAI,GAAG,IAAI,GAAG,CAAC,OAAO,CAAC,CAAA;QAC7B,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAA;QACf,QAAQ,CAAC,EAAE,uBAAuB,EAAE,IAAI,EAAE,CAAC,CAAA;IAC7C,CAAC,EACD,CAAC,QAAQ,EAAE,QAAQ,CAAC,CACrB,CAAA;IAED,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,MAAM,EAAE,CAAA;AAC7B,CAAC,CAAA"}
|
package/package.json
CHANGED