@manuscripts/article-editor 3.4.3-LEAN-3894.0 → 3.4.3-LEAN-4053.3
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/CommentActions.js +7 -11
- package/dist/cjs/components/comments/CommentActions.js.map +1 -1
- package/dist/cjs/components/comments/CommentBody.js +6 -10
- package/dist/cjs/components/comments/CommentBody.js.map +1 -1
- package/dist/cjs/components/comments/CommentResolveButton.js +1 -1
- package/dist/cjs/components/comments/CommentThread.js +88 -83
- package/dist/cjs/components/comments/CommentThread.js.map +1 -1
- package/dist/cjs/components/comments/CommentsPanel.js +10 -33
- package/dist/cjs/components/comments/CommentsPanel.js.map +1 -1
- package/dist/cjs/lib/change-handlers.js +2 -2
- package/dist/cjs/lib/change-handlers.js.map +1 -1
- package/dist/cjs/lib/comments.js +5 -26
- package/dist/cjs/lib/comments.js.map +1 -1
- package/dist/cjs/lib/node-content-retriever.js +17 -24
- package/dist/cjs/lib/node-content-retriever.js.map +1 -1
- package/dist/es/components/comments/CommentActions.js +7 -11
- package/dist/es/components/comments/CommentActions.js.map +1 -1
- package/dist/es/components/comments/CommentBody.js +7 -11
- package/dist/es/components/comments/CommentBody.js.map +1 -1
- package/dist/es/components/comments/CommentResolveButton.js +1 -1
- package/dist/es/components/comments/CommentThread.js +91 -86
- package/dist/es/components/comments/CommentThread.js.map +1 -1
- package/dist/es/components/comments/CommentsPanel.js +12 -35
- package/dist/es/components/comments/CommentsPanel.js.map +1 -1
- package/dist/es/lib/change-handlers.js +2 -2
- package/dist/es/lib/change-handlers.js.map +1 -1
- package/dist/es/lib/comments.js +3 -23
- package/dist/es/lib/comments.js.map +1 -1
- package/dist/es/lib/node-content-retriever.js +18 -25
- package/dist/es/lib/node-content-retriever.js.map +1 -1
- package/dist/types/components/comments/CommentThread.d.ts +2 -3
- package/dist/types/lib/comments.d.ts +3 -4
- package/dist/types/lib/node-content-retriever.d.ts +2 -6
- package/package.json +5 -5
- package/dist/cjs/components/comments/CommentCard.js +0 -165
- package/dist/cjs/components/comments/CommentCard.js.map +0 -1
- package/dist/cjs/components/comments/DeleteCommentConfirmation.js +0 -115
- package/dist/cjs/components/comments/DeleteCommentConfirmation.js.map +0 -1
- package/dist/cjs/components/comments/ReplyBox.js +0 -121
- package/dist/cjs/components/comments/ReplyBox.js.map +0 -1
- package/dist/es/components/comments/CommentCard.js +0 -135
- package/dist/es/components/comments/CommentCard.js.map +0 -1
- package/dist/es/components/comments/DeleteCommentConfirmation.js +0 -85
- package/dist/es/components/comments/DeleteCommentConfirmation.js.map +0 -1
- package/dist/es/components/comments/ReplyBox.js +0 -91
- package/dist/es/components/comments/ReplyBox.js.map +0 -1
- package/dist/types/components/comments/CommentCard.d.ts +0 -27
- package/dist/types/components/comments/DeleteCommentConfirmation.d.ts +0 -19
- package/dist/types/components/comments/ReplyBox.d.ts +0 -18
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"node-content-retriever.js","sourceRoot":"","sources":["../../../src/lib/node-content-retriever.ts"],"names":[],"mappings":";;;;;;AAAA;;;;;;;;;;GAUG;AACH,
|
1
|
+
{"version":3,"file":"node-content-retriever.js","sourceRoot":"","sources":["../../../src/lib/node-content-retriever.ts"],"names":[],"mappings":"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"}
|
@@ -29,28 +29,24 @@ export const ActionsIcon = styled.button `
|
|
29
29
|
export const CommentAction = styled.div `
|
30
30
|
font-family: ${(props) => props.theme.font.family.Lato};
|
31
31
|
cursor: pointer;
|
32
|
-
font-size:
|
32
|
+
font-size: 16px;
|
33
33
|
line-height: 24px;
|
34
34
|
color: ${(props) => props.theme.colors.text.primary};
|
35
|
-
padding:
|
35
|
+
padding: 16px;
|
36
36
|
&:hover,
|
37
37
|
&:focus {
|
38
38
|
background: #f2fbfc;
|
39
39
|
}
|
40
40
|
`;
|
41
|
-
const Container = styled.div `
|
42
|
-
display: flex;
|
43
|
-
align-items: end;
|
44
|
-
`;
|
45
41
|
export const CommentActions = ({ comment, isResolveEnabled, isActionsEnabled, onEdit, onDelete, toggleResolve, }) => {
|
46
42
|
const { isOpen, toggleOpen, wrapperRef } = useDropdown();
|
47
|
-
return (React.createElement(
|
43
|
+
return (React.createElement(React.Fragment, null,
|
44
|
+
isResolveEnabled && (React.createElement(CommentResolveButton, { comment: comment, onClick: toggleResolve })),
|
48
45
|
isActionsEnabled && (React.createElement(DropdownContainer, { ref: wrapperRef },
|
49
|
-
React.createElement(ActionsIcon, { "data-cy": "comment-dropdown-trigger", onClick: toggleOpen
|
46
|
+
React.createElement(ActionsIcon, { "data-cy": "comment-dropdown-trigger", onClick: toggleOpen },
|
50
47
|
React.createElement(DotsIcon, null)),
|
51
|
-
isOpen && (React.createElement(DropdownList, { "data-cy": "comment-dropdown", direction: 'right', width:
|
48
|
+
isOpen && (React.createElement(DropdownList, { "data-cy": "comment-dropdown", direction: 'right', width: 125, onClick: toggleOpen },
|
52
49
|
React.createElement(CommentAction, { "data-cy": "comment-edit", onClick: onEdit }, "Edit"),
|
53
|
-
React.createElement(CommentAction, {
|
54
|
-
isResolveEnabled && (React.createElement(CommentResolveButton, { comment: comment, onClick: toggleResolve }))));
|
50
|
+
React.createElement(CommentAction, { "data-cy": "comment-delete", onClick: onDelete }, "Delete")))))));
|
55
51
|
};
|
56
52
|
//# sourceMappingURL=CommentActions.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"CommentActions.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentActions.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAGH,OAAO,EACL,QAAQ,EACR,iBAAiB,EACjB,YAAY,EACZ,WAAW,GACZ,MAAM,0BAA0B,CAAA;AACjC,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,MAAM,MAAM,mBAAmB,CAAA;AAEtC,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAA;AAE7D,MAAM,CAAC,MAAM,WAAW,GAAG,MAAM,CAAC,MAAM,CAAA;;;;;;;;;;;;CAYvC,CAAA;AAED,MAAM,CAAC,MAAM,aAAa,GAAG,MAAM,CAAC,GAAG,CAAA;iBACtB,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI;;;;WAI7C,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO;;;;;;CAMpD,CAAA;
|
1
|
+
{"version":3,"file":"CommentActions.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentActions.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAGH,OAAO,EACL,QAAQ,EACR,iBAAiB,EACjB,YAAY,EACZ,WAAW,GACZ,MAAM,0BAA0B,CAAA;AACjC,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,MAAM,MAAM,mBAAmB,CAAA;AAEtC,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAA;AAE7D,MAAM,CAAC,MAAM,WAAW,GAAG,MAAM,CAAC,MAAM,CAAA;;;;;;;;;;;;CAYvC,CAAA;AAED,MAAM,CAAC,MAAM,aAAa,GAAG,MAAM,CAAC,GAAG,CAAA;iBACtB,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI;;;;WAI7C,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO;;;;;;CAMpD,CAAA;AAWD,MAAM,CAAC,MAAM,cAAc,GAAkC,CAAC,EAC5D,OAAO,EACP,gBAAgB,EAChB,gBAAgB,EAChB,MAAM,EACN,QAAQ,EACR,aAAa,GACd,EAAE,EAAE;IACH,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,GAAG,WAAW,EAAE,CAAA;IAExD,OAAO,CACL;QACG,gBAAgB,IAAI,CACnB,oBAAC,oBAAoB,IAAC,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,aAAa,GAAI,CACnE;QACA,gBAAgB,IAAI,CACnB,oBAAC,iBAAiB,IAAC,GAAG,EAAE,UAAU;YAChC,oBAAC,WAAW,eAAS,0BAA0B,EAAC,OAAO,EAAE,UAAU;gBACjE,oBAAC,QAAQ,OAAG,CACA;YACb,MAAM,IAAI,CACT,oBAAC,YAAY,eACH,kBAAkB,EAC1B,SAAS,EAAE,OAAO,EAClB,KAAK,EAAE,GAAG,EACV,OAAO,EAAE,UAAU;gBAEnB,oBAAC,aAAa,eAAS,cAAc,EAAC,OAAO,EAAE,MAAM,WAErC;gBAChB,oBAAC,aAAa,eAAS,gBAAgB,EAAC,OAAO,EAAE,QAAQ,aAEzC,CACH,CAChB,CACiB,CACrB,CACA,CACJ,CAAA;AACH,CAAC,CAAA"}
|
@@ -1,7 +1,10 @@
|
|
1
|
-
import { ButtonGroup, PrimaryButton,
|
1
|
+
import { ButtonGroup, PrimaryButton, SecondaryButton, } from '@manuscripts/style-guide';
|
2
2
|
import React, { useCallback, useMemo, useRef, useState, } from 'react';
|
3
3
|
import styled from 'styled-components';
|
4
4
|
import { decodeHTMLEntities } from '../../lib/utils';
|
5
|
+
const CommentContent = styled.div `
|
6
|
+
cursor: pointer;
|
7
|
+
`;
|
5
8
|
const CommentEditor = styled.textarea `
|
6
9
|
cursor: text;
|
7
10
|
font-family: ${(props) => props.theme.font.family.sans};
|
@@ -35,19 +38,11 @@ const CommentViewer = styled.div `
|
|
35
38
|
letter-spacing: -0.2px;
|
36
39
|
color: ${(props) => props.theme.colors.text.primary};
|
37
40
|
margin: ${(props) => props.theme.grid.unit * 2}px 0;
|
38
|
-
word-wrap: break-word;
|
39
41
|
`;
|
40
42
|
const EditorActions = styled(ButtonGroup) `
|
41
43
|
& button:not(:last-of-type) {
|
42
44
|
margin-right: 4px;
|
43
45
|
}
|
44
|
-
|
45
|
-
& ${TertiaryButton} {
|
46
|
-
&:hover {
|
47
|
-
background-color: inherit !important;
|
48
|
-
border-color: transparent !important;
|
49
|
-
}
|
50
|
-
}
|
51
46
|
`;
|
52
47
|
export const CommentBody = ({ comment, isEditing, onSave, onCancel, onSelect, }) => {
|
53
48
|
const editor = useRef(null);
|
@@ -68,8 +63,9 @@ export const CommentBody = ({ comment, isEditing, onSave, onCancel, onSelect, })
|
|
68
63
|
return (React.createElement(React.Fragment, null, isEditing ? (React.createElement(React.Fragment, null,
|
69
64
|
React.createElement(CommentEditor, { "data-cy": "comment-editor", ref: ref, defaultValue: comment.node.attrs.contents, onChange: onTextChange, onBlur: (event) => !event.target.value.length && onCancel() }),
|
70
65
|
React.createElement(EditorActions, { "data-cy": "comment-actions" },
|
71
|
-
React.createElement(
|
66
|
+
React.createElement(SecondaryButton, { onClick: onCancel }, "Cancel"),
|
72
67
|
React.createElement(PrimaryButton, { onClick: handleSave, disabled: disableSaveButton }, "Save")))) : (React.createElement(React.Fragment, null,
|
73
|
-
React.createElement(
|
68
|
+
React.createElement(CommentContent, { onClick: onSelect },
|
69
|
+
React.createElement(CommentViewer, { "data-cy": "comment-text" }, decodeHTMLEntities(comment.node.attrs.contents)))))));
|
74
70
|
};
|
75
71
|
//# sourceMappingURL=CommentBody.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"CommentBody.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentBody.tsx"],"names":[],"mappings":"AAYA,OAAO,EACL,WAAW,EACX,aAAa,EACb,
|
1
|
+
{"version":3,"file":"CommentBody.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentBody.tsx"],"names":[],"mappings":"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"}
|
@@ -1,100 +1,105 @@
|
|
1
|
-
import {
|
2
|
-
import React, { forwardRef,
|
1
|
+
import { AvatarIcon, RelativeDate, SystemUserAvatarIcon, usePermissions, } from '@manuscripts/style-guide';
|
2
|
+
import React, { forwardRef, useState } from 'react';
|
3
3
|
import styled from 'styled-components';
|
4
|
-
import {
|
5
|
-
import {
|
6
|
-
import {
|
4
|
+
import { buildAuthorName, getAuthorID } from '../../lib/comments';
|
5
|
+
import { useStore } from '../../store';
|
6
|
+
import { CommentActions } from './CommentActions';
|
7
|
+
import { CommentBody } from './CommentBody';
|
7
8
|
const Container = styled.div `
|
8
|
-
padding:
|
9
|
-
background-color: ${(props) => (props.isSelected ? '#
|
10
|
-
border: 1px solid #
|
11
|
-
|
12
|
-
border-radius: 4px;
|
9
|
+
padding: 16px;
|
10
|
+
background-color: ${(props) => (props.isSelected ? '#f2fbfc' : '#ffffff')};
|
11
|
+
border: 1px solid ${(props) => (props.isSelected ? '#bce7f6' : '#e2e2e2')};
|
12
|
+
border-left-width: 4px;
|
13
13
|
margin-bottom: 16px;
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
14
|
+
`;
|
15
|
+
const CommentHeader = styled.div `
|
16
|
+
display: flex;
|
17
|
+
margin-bottom: 16px;
|
18
|
+
`;
|
19
|
+
const CommentMetadata = styled.div `
|
20
|
+
flex: 1;
|
21
|
+
padding-left: 8px;
|
22
|
+
padding-right: 8px;
|
23
|
+
`;
|
24
|
+
const CommentAuthor = styled.div `
|
25
|
+
display: flex;
|
26
|
+
color: #353535;
|
27
|
+
font-weight: 400;
|
28
|
+
max-width: 200px;
|
29
|
+
white-space: nowrap;
|
30
|
+
overflow: hidden;
|
31
|
+
text-overflow: ellipsis;
|
32
|
+
width: 100%;
|
23
33
|
|
24
|
-
|
25
|
-
|
26
|
-
}
|
34
|
+
svg {
|
35
|
+
padding-right: 10px;
|
27
36
|
}
|
28
37
|
`;
|
29
|
-
const
|
30
|
-
|
31
|
-
|
32
|
-
|
38
|
+
const CommentTarget = styled.div `
|
39
|
+
font-size: 14px;
|
40
|
+
color: #353535;
|
41
|
+
background-color: #ffeebf;
|
42
|
+
padding: 4px 8px;
|
43
|
+
margin-top: 16px;
|
44
|
+
margin-bottom: 16px;
|
33
45
|
`;
|
34
|
-
const
|
35
|
-
|
46
|
+
const Timestamp = styled(RelativeDate) `
|
47
|
+
font-size: 12px;
|
48
|
+
line-height: 16px;
|
49
|
+
font-weight: 400;
|
50
|
+
color: #6e6e6e;
|
36
51
|
`;
|
37
52
|
export const CommentThread = forwardRef((props, ref) => {
|
38
|
-
const {
|
53
|
+
const { tree, isSelected, onSelect, onSave, onDelete } = props;
|
39
54
|
const can = usePermissions();
|
40
|
-
const {
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
const
|
51
|
-
|
52
|
-
|
55
|
+
const [{ user, collaboratorsById }] = useStore((state) => ({
|
56
|
+
user: state.user,
|
57
|
+
collaboratorsById: state.collaboratorsById,
|
58
|
+
}));
|
59
|
+
const authorID = getAuthorID(tree.comment);
|
60
|
+
const authorName = authorID
|
61
|
+
? buildAuthorName(collaboratorsById.get(authorID))
|
62
|
+
: '';
|
63
|
+
const timestamp = tree.comment.node.attrs.contributions?.[0].timestamp;
|
64
|
+
const isOwn = authorID === user._id;
|
65
|
+
const isResolveEnabled = isOwn
|
66
|
+
? can.resolveOwnComment
|
67
|
+
: can.resolveOthersComment;
|
68
|
+
const isActionsEnabled = isOwn
|
69
|
+
? can.handleOwnComments
|
70
|
+
: can.handleOthersComments;
|
71
|
+
const [isEditing, setEditing] = useState(tree.isNew);
|
72
|
+
const handleEdit = () => setEditing(true);
|
73
|
+
const handleSave = (contents) => {
|
74
|
+
onSave({
|
75
|
+
...tree.comment.node.attrs,
|
76
|
+
contents,
|
77
|
+
});
|
78
|
+
setEditing(false);
|
79
|
+
};
|
80
|
+
const handleCancel = () => {
|
81
|
+
setEditing(false);
|
82
|
+
if (tree.isNew) {
|
83
|
+
onDelete(tree.comment.node.attrs.id);
|
53
84
|
}
|
54
85
|
};
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
86
|
+
const handleToggleResolve = () => {
|
87
|
+
onSave({
|
88
|
+
...tree.comment.node.attrs,
|
89
|
+
resolved: !tree.comment.node.attrs.resolved,
|
90
|
+
});
|
91
|
+
};
|
92
|
+
return (React.createElement(Container, { "data-cy": "comment", isSelected: isSelected, ref: ref },
|
93
|
+
React.createElement(CommentHeader, { "data-cy": "comment-header" },
|
94
|
+
React.createElement(CommentMetadata, null,
|
95
|
+
React.createElement(CommentAuthor, null, authorName ? (React.createElement(React.Fragment, null,
|
96
|
+
React.createElement(AvatarIcon, { width: 20, height: 20 }),
|
97
|
+
React.createElement(CommentAuthor, null, authorName))) : (React.createElement(React.Fragment, null,
|
98
|
+
React.createElement(SystemUserAvatarIcon, { width: 20, height: 20 }),
|
99
|
+
React.createElement(CommentAuthor, null, "System")))),
|
100
|
+
timestamp && React.createElement(Timestamp, { date: timestamp * 1000 })),
|
101
|
+
React.createElement(CommentActions, { comment: tree.comment, isResolveEnabled: isResolveEnabled, isActionsEnabled: isActionsEnabled, onDelete: () => onDelete(tree.comment.node.attrs.id), onEdit: handleEdit, toggleResolve: handleToggleResolve })),
|
102
|
+
tree.comment.node.attrs.originalText && (React.createElement(CommentTarget, null, tree.comment.node.attrs.originalText)),
|
103
|
+
React.createElement(CommentBody, { comment: tree.comment, isEditing: tree.isNew || isEditing, onSave: handleSave, onCancel: handleCancel, onSelect: onSelect })));
|
70
104
|
});
|
71
|
-
const ButtonContainer = styled.div `
|
72
|
-
display: flex;
|
73
|
-
justify-content: center;
|
74
|
-
align-items: center;
|
75
|
-
`;
|
76
|
-
const ShowMore = styled(TextButton) `
|
77
|
-
cursor: pointer;
|
78
|
-
text-align: center;
|
79
|
-
margin-top: 6px;
|
80
|
-
color: #353535;
|
81
|
-
`;
|
82
|
-
const CardsWrapper = styled.div `
|
83
|
-
max-height: ${({ isSelected }) => (isSelected ? 'none' : '280px')};
|
84
|
-
position: relative;
|
85
|
-
${({ showMore, isSelected }) => showMore &&
|
86
|
-
!isSelected &&
|
87
|
-
`
|
88
|
-
overflow: hidden;
|
89
|
-
&:after {
|
90
|
-
content: '';
|
91
|
-
position: absolute;
|
92
|
-
bottom: 0;
|
93
|
-
left: 0;
|
94
|
-
right: 0;
|
95
|
-
height: 40px;
|
96
|
-
background: linear-gradient(to bottom, rgba(255, 255, 255, 0), rgba(255, 255, 255, 1));
|
97
|
-
}
|
98
|
-
`}
|
99
|
-
`;
|
100
105
|
//# sourceMappingURL=CommentThread.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"CommentThread.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentThread.tsx"],"names":[],"mappings":"AAYA,OAAO,
|
1
|
+
{"version":3,"file":"CommentThread.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentThread.tsx"],"names":[],"mappings":"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"}
|
@@ -9,16 +9,13 @@
|
|
9
9
|
*
|
10
10
|
* All portions of the code written by Atypon Systems LLC are Copyright (c) 2019 Atypon Systems LLC. All Rights Reserved.
|
11
11
|
*/
|
12
|
-
import { commentsKey, isNodeComment, setCommentSelection, } from '@manuscripts/body-editor';
|
13
|
-
import { buildContribution } from '@manuscripts/json-schema';
|
12
|
+
import { clearCommentSelection, commentsKey, isNodeComment, setCommentSelection, } from '@manuscripts/body-editor';
|
14
13
|
import { CheckboxField, CheckboxLabel } from '@manuscripts/style-guide';
|
15
14
|
import { skipTracking } from '@manuscripts/track-changes-plugin';
|
16
|
-
import { generateNodeID, schema } from '@manuscripts/transform';
|
17
15
|
import { NodeSelection, TextSelection } from 'prosemirror-state';
|
18
|
-
import { findChildrenByType } from 'prosemirror-utils';
|
19
16
|
import React, { useCallback, useMemo, useState } from 'react';
|
20
17
|
import styled from 'styled-components';
|
21
|
-
import {
|
18
|
+
import { buildCommentTrees } from '../../lib/comments';
|
22
19
|
import { useStore } from '../../store';
|
23
20
|
import { CommentsPlaceholder } from './CommentsPlaceholder';
|
24
21
|
import { CommentThread } from './CommentThread';
|
@@ -37,17 +34,14 @@ const scrollIntoView = (element) => {
|
|
37
34
|
}
|
38
35
|
};
|
39
36
|
export const CommentsPanel = () => {
|
40
|
-
const [{ view, newCommentID, selectedCommentKey
|
37
|
+
const [{ view, newCommentID, selectedCommentKey }] = useStore((state) => ({
|
41
38
|
view: state.view,
|
42
|
-
doc: state.doc,
|
43
39
|
newCommentID: state.newCommentID,
|
44
40
|
selectedCommentKey: state.selectedCommentKey,
|
45
|
-
user: state.user,
|
46
41
|
}));
|
47
42
|
const [showResolved, setShowResolved] = useState(true);
|
48
|
-
const comments = useMemo(() => view?.state ? commentsKey.getState(view.state)?.comments : undefined, [view?.state
|
49
|
-
);
|
50
|
-
const threads = useMemo(() => (comments ? buildThreads([...comments.values()], newCommentID) : []), [comments, newCommentID]);
|
43
|
+
const comments = useMemo(() => view?.state ? commentsKey.getState(view.state)?.comments : undefined, [view?.state]);
|
44
|
+
const trees = useMemo(() => comments ? buildCommentTrees([...comments.values()], newCommentID) : [], [comments, newCommentID]);
|
51
45
|
const selectedRef = useCallback((e) => {
|
52
46
|
if (e) {
|
53
47
|
scrollIntoView(e);
|
@@ -72,25 +66,6 @@ export const CommentsPanel = () => {
|
|
72
66
|
view.focus();
|
73
67
|
view.dispatch(tr);
|
74
68
|
};
|
75
|
-
const insertCommentReply = (target, contents) => {
|
76
|
-
if (!view) {
|
77
|
-
return;
|
78
|
-
}
|
79
|
-
const attrs = {
|
80
|
-
id: generateNodeID(schema.nodes.comment),
|
81
|
-
contents,
|
82
|
-
target,
|
83
|
-
contributions: [buildContribution(user._id)],
|
84
|
-
resolved: false,
|
85
|
-
};
|
86
|
-
const comment = view.state.schema.nodes.comment.create(attrs);
|
87
|
-
const comments = findChildrenByType(view.state.doc, view.state.schema.nodes.comments)[0];
|
88
|
-
if (comments) {
|
89
|
-
const pos = comments.pos + 1;
|
90
|
-
const tr = view.state.tr.insert(pos, comment);
|
91
|
-
view.dispatch(skipTracking(tr));
|
92
|
-
}
|
93
|
-
};
|
94
69
|
const handleSave = (attrs) => {
|
95
70
|
const comment = comments?.get(attrs.id);
|
96
71
|
if (!comment || !view) {
|
@@ -98,6 +73,7 @@ export const CommentsPanel = () => {
|
|
98
73
|
}
|
99
74
|
const tr = view.state.tr;
|
100
75
|
tr.setNodeMarkup(comment.pos, undefined, attrs);
|
76
|
+
clearCommentSelection(tr);
|
101
77
|
view.dispatch(skipTracking(tr));
|
102
78
|
};
|
103
79
|
const handleDelete = (id) => {
|
@@ -107,15 +83,16 @@ export const CommentsPanel = () => {
|
|
107
83
|
}
|
108
84
|
const tr = view.state.tr;
|
109
85
|
tr.delete(comment.pos, comment.pos + comment.node.nodeSize);
|
86
|
+
clearCommentSelection(tr);
|
110
87
|
view.dispatch(skipTracking(tr));
|
111
88
|
};
|
112
|
-
const isSelected = (
|
113
|
-
return
|
89
|
+
const isSelected = (tree) => {
|
90
|
+
return tree && selectedCommentKey === tree.comment.key;
|
114
91
|
};
|
115
92
|
if (!view) {
|
116
93
|
return null;
|
117
94
|
}
|
118
|
-
if (!
|
95
|
+
if (!trees.length) {
|
119
96
|
return React.createElement(CommentsPlaceholder, null);
|
120
97
|
}
|
121
98
|
return (React.createElement(React.Fragment, null,
|
@@ -123,8 +100,8 @@ export const CommentsPanel = () => {
|
|
123
100
|
React.createElement(CheckboxLabel, null,
|
124
101
|
React.createElement(CheckboxField, { name: 'show-resolved', checked: showResolved, onChange: (e) => setShowResolved(e.target.checked) }),
|
125
102
|
React.createElement(CheckboxLabelText, null, "See resolved"))),
|
126
|
-
|
103
|
+
trees
|
127
104
|
.filter((c) => showResolved || !c.comment.node.attrs.resolved)
|
128
|
-
.map((c, i, a) => (React.createElement(CommentThread, { key: c.comment.node.attrs.id, ref: isSelected(c) && !isSelected(a[i - 1]) ? selectedRef : null,
|
105
|
+
.map((c, i, a) => (React.createElement(CommentThread, { key: c.comment.node.attrs.id, ref: isSelected(c) && !isSelected(a[i - 1]) ? selectedRef : null, tree: c, isSelected: isSelected(c), onSelect: () => setSelectedComment(c.comment), onSave: handleSave, onDelete: handleDelete })))));
|
129
106
|
};
|
130
107
|
//# sourceMappingURL=CommentsPanel.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"CommentsPanel.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentsPanel.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AACH,OAAO,
|
1
|
+
{"version":3,"file":"CommentsPanel.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentsPanel.tsx"],"names":[],"mappings":"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"}
|
@@ -28,14 +28,14 @@ export const handleNodeChange = (suggestion, view, doc, dataTracked) => {
|
|
28
28
|
return {
|
29
29
|
operation,
|
30
30
|
nodeName,
|
31
|
-
content: nodeContentRetriever.getInlineFootnoteContent(
|
31
|
+
content: nodeContentRetriever.getInlineFootnoteContent(view.state, node.attrs),
|
32
32
|
};
|
33
33
|
}
|
34
34
|
case schema.nodes.footnote: {
|
35
35
|
return {
|
36
36
|
operation,
|
37
37
|
nodeName,
|
38
|
-
content: nodeContentRetriever.getFootnoteContent(node),
|
38
|
+
content: nodeContentRetriever.getFootnoteContent(view.state, node),
|
39
39
|
};
|
40
40
|
}
|
41
41
|
case schema.nodes.contributor: {
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"change-handlers.js","sourceRoot":"","sources":["../../../src/lib/change-handlers.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAA;AAE1D,OAAO,EAAE,wBAAwB,EAAE,MAAM,0BAA0B,CAAA;AACnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAA;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,SAAS,CAAA;AASvC,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAC9B,UAAsB,EACtB,IAAS,EACT,WAAgB,EACI,EAAE;IACtB,MAAM,cAAc,GAAG,aAAa,CAAC,IAAI,CAAC,KAAK,EAAE,UAAU,CAAC,IAAI,CAAC,EAAE,IAAI,CAAA;IACvE,IAAI,QAAQ,CAAA;IACZ,IAAI,cAAc,EAAE;QAClB,MAAM,cAAc,GAAG,SAAS,CAAC,GAAG,CAAC,cAAc,CAAC,IAAI,cAAc,EAAE,IAAI,CAAA;QAC5E,QAAQ;YACN,cAAc,KAAK,MAAM,CAAC,KAAK,CAAC,SAAS;gBACvC,CAAC,CAAC,MAAM;gBACR,CAAC,CAAC,cAAc,GAAG,OAAO,CAAA;KAC/B;IAED,OAAO;QACL,SAAS,EAAE,oBAAoB,CAAC,WAAW,CAAC,SAAS,CAAC;QACtD,QAAQ,EAAE,QAAQ,IAAI,UAAU,CAAC,QAAQ,CAAC,IAAI;QAC9C,OAAO,EAAE,UAAU,CAAC,IAAI;KACzB,CAAA;AACH,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAC9B,UAAuC,EACvC,IAAS,EACT,GAAQ,EACR,WAAgB,EACI,EAAE;IACtB,MAAM,oBAAoB,GAAG,IAAI,wBAAwB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IACrE,MAAM,EAAE,IAAI,EAAE,GAAG,UAAU,CAAA;IAC3B,MAAM,SAAS,GAAG,oBAAoB,CAAC,WAAW,CAAC,SAAS,CAAC,CAAA;IAC7D,MAAM,QAAQ,GAAG,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAA;IAE3D,QAAQ,IAAI,CAAC,IAAI,EAAE;QACjB,KAAK,MAAM,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;YACjC,OAAO;gBACL,SAAS;gBACT,QAAQ;gBACR,OAAO,EAAE,oBAAoB,CAAC,wBAAwB,CAAC,
|
1
|
+
{"version":3,"file":"change-handlers.js","sourceRoot":"","sources":["../../../src/lib/change-handlers.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAA;AAE1D,OAAO,EAAE,wBAAwB,EAAE,MAAM,0BAA0B,CAAA;AACnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAA;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,SAAS,CAAA;AASvC,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAC9B,UAAsB,EACtB,IAAS,EACT,WAAgB,EACI,EAAE;IACtB,MAAM,cAAc,GAAG,aAAa,CAAC,IAAI,CAAC,KAAK,EAAE,UAAU,CAAC,IAAI,CAAC,EAAE,IAAI,CAAA;IACvE,IAAI,QAAQ,CAAA;IACZ,IAAI,cAAc,EAAE;QAClB,MAAM,cAAc,GAAG,SAAS,CAAC,GAAG,CAAC,cAAc,CAAC,IAAI,cAAc,EAAE,IAAI,CAAA;QAC5E,QAAQ;YACN,cAAc,KAAK,MAAM,CAAC,KAAK,CAAC,SAAS;gBACvC,CAAC,CAAC,MAAM;gBACR,CAAC,CAAC,cAAc,GAAG,OAAO,CAAA;KAC/B;IAED,OAAO;QACL,SAAS,EAAE,oBAAoB,CAAC,WAAW,CAAC,SAAS,CAAC;QACtD,QAAQ,EAAE,QAAQ,IAAI,UAAU,CAAC,QAAQ,CAAC,IAAI;QAC9C,OAAO,EAAE,UAAU,CAAC,IAAI;KACzB,CAAA;AACH,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAC9B,UAAuC,EACvC,IAAS,EACT,GAAQ,EACR,WAAgB,EACI,EAAE;IACtB,MAAM,oBAAoB,GAAG,IAAI,wBAAwB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IACrE,MAAM,EAAE,IAAI,EAAE,GAAG,UAAU,CAAA;IAC3B,MAAM,SAAS,GAAG,oBAAoB,CAAC,WAAW,CAAC,SAAS,CAAC,CAAA;IAC7D,MAAM,QAAQ,GAAG,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAA;IAE3D,QAAQ,IAAI,CAAC,IAAI,EAAE;QACjB,KAAK,MAAM,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;YACjC,OAAO;gBACL,SAAS;gBACT,QAAQ;gBACR,OAAO,EAAE,oBAAoB,CAAC,wBAAwB,CACpD,IAAI,CAAC,KAAK,EACV,IAAI,CAAC,KAAK,CACX;aACF,CAAA;SACF;QACD,KAAK,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;YAC1B,OAAO;gBACL,SAAS;gBACT,QAAQ;gBACR,OAAO,EAAE,oBAAoB,CAAC,kBAAkB,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC;aACnE,CAAA;SACF;QACD,KAAK,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;YAC7B,MAAM,sBAAsB,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,MAAM,EAAE,CAAA;YAC7G,OAAO;gBACL,SAAS;gBACT,QAAQ;gBACR,OAAO,EAAE,sBAAsB;aAChC,CAAA;SACF;QACD,KAAK,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;YAC7B,MAAM,sBAAsB,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,CAAA;YACrD,OAAO;gBACL,SAAS;gBACT,QAAQ;gBACR,OAAO,EAAE,sBAAsB;aAChC,CAAA;SACF;QACD,KAAK,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;YAC1B,OAAO;gBACL,SAAS;gBACT,QAAQ;gBACR,OAAO,EAAE,oBAAoB,CAAC,0BAA0B,CACtD,IAAI,CAAC,KAAK,CAAC,EAAE,EACb,IAAI,CACL;aACF,CAAA;SACF;QACD,KAAK,MAAM,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC;YACnC,OAAO;gBACL,SAAS;gBACT,QAAQ;gBACR,OAAO,EAAE,oBAAoB,CAAC,0BAA0B,CACtD,IAAI,CAAC,KAAK,CAAC,EAAE,EACb,IAAI,CACL;aACF,CAAA;SACF;QACD,KAAK,MAAM,CAAC,KAAK,CAAC,cAAc,CAAC;QACjC,KAAK,MAAM,CAAC,KAAK,CAAC,aAAa;YAC7B,OAAO;gBACL,SAAS;gBACT,QAAQ;gBACR,OAAO,EAAE,oBAAoB,CAAC,cAAc,CAAC,IAAI,CAAC;aACnD,CAAA;QACH,KAAK,MAAM,CAAC,KAAK,CAAC,eAAe,CAAC;QAClC,KAAK,MAAM,CAAC,KAAK,CAAC,gBAAgB;YAChC,OAAO;gBACL,SAAS;gBACT,QAAQ;gBACR,OAAO,EAAE,oBAAoB,CAAC,kBAAkB,CAAC,IAAI,CAAC;gBACtD,UAAU,EAAE,IAAI;aACjB,CAAA;QACH,KAAK,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YACzB,MAAM,QAAQ,GACZ,IAAI,CAAC,KAAK,CAAC,QAAQ,KAAK,8BAA8B;gBACpD,CAAC,CAAC,YAAY;gBACd,CAAC,CAAC,SAAS,CAAA;YACf,OAAO;gBACL,SAAS;gBACT,QAAQ;gBACR,OAAO,EAAE,oBAAoB,CAAC,oBAAoB,CAAC,IAAI,CAAC;aACzD,CAAA;SACF;QACD,KAAK,MAAM,CAAC,KAAK,CAAC,IAAI;YACpB,OAAO;gBACL,SAAS;gBACT,QAAQ;gBACR,OAAO,EAAE,qCAAqC,oBAAoB,CAAC,oBAAoB,CACrF,IAAI,CACL,SAAS;aACX,CAAA;QACH;YACE,OAAO;gBACL,SAAS;gBACT,QAAQ;gBACR,OAAO,EAAE,oBAAoB,CAAC,kBAAkB,CAAC,IAAI,CAAC;aACvD,CAAA;KACJ;AACH,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,mBAAmB,GAAG,GAAgB,EAAE;IACnD,OAAO;QACL,SAAS,EAAE,EAAE;QACb,QAAQ,EAAE,EAAE;QACZ,OAAO,EAAE,iBAAiB;KAC3B,CAAA;AACH,CAAC,CAAA"}
|
package/dist/es/lib/comments.js
CHANGED
@@ -1,15 +1,3 @@
|
|
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 { isReply } from '@manuscripts/body-editor';
|
13
1
|
export const getAuthorID = (comment) => {
|
14
2
|
const contributions = comment.node.attrs.contributions;
|
15
3
|
if (!contributions?.length) {
|
@@ -17,14 +5,11 @@ export const getAuthorID = (comment) => {
|
|
17
5
|
}
|
18
6
|
return contributions[0].profileID;
|
19
7
|
};
|
20
|
-
export const
|
21
|
-
return comments
|
22
|
-
.filter((c) => !isReply(c)) // Filter out replies
|
23
|
-
.map((c) => ({
|
8
|
+
export const buildCommentTrees = (comments, newCommentID) => {
|
9
|
+
return comments.map((c) => ({
|
24
10
|
comment: c,
|
25
11
|
isNew: newCommentID === c.node.attrs.id,
|
26
|
-
|
27
|
-
),
|
12
|
+
children: [],
|
28
13
|
}));
|
29
14
|
};
|
30
15
|
export const buildAuthorName = (user) => {
|
@@ -35,9 +20,4 @@ export const buildAuthorName = (user) => {
|
|
35
20
|
.filter(Boolean)
|
36
21
|
.join(' ');
|
37
22
|
};
|
38
|
-
export const commentsByTime = (a, b) => {
|
39
|
-
const aTimestamp = a.node.attrs.contributions?.[0].timestamp || 0;
|
40
|
-
const bTimestamp = b.node.attrs.contributions?.[0].timestamp || 0;
|
41
|
-
return aTimestamp - bTimestamp;
|
42
|
-
};
|
43
23
|
//# sourceMappingURL=comments.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"comments.js","sourceRoot":"","sources":["../../../src/lib/comments.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"comments.js","sourceRoot":"","sources":["../../../src/lib/comments.ts"],"names":[],"mappings":"AAoBA,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,OAAgB,EAAE,EAAE;IAC9C,MAAM,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAA;IACtD,IAAI,CAAC,aAAa,EAAE,MAAM,EAAE;QAC1B,OAAO,SAAS,CAAA;KACjB;IACD,OAAO,aAAa,CAAC,CAAC,CAAC,CAAC,SAAS,CAAA;AACnC,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAC/B,QAAmB,EACnB,YAAqB,EACN,EAAE;IACjB,OAAO,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAC1B,OAAO,EAAE,CAAC;QACV,KAAK,EAAE,YAAY,KAAK,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;QACvC,QAAQ,EAAE,EAAE;KACb,CAAC,CAAC,CAAA;AACL,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,IAA6B,EAAE,EAAE;IAC/D,IAAI,CAAC,IAAI,EAAE;QACT,OAAO,EAAE,CAAA;KACV;IACD,OAAO,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC;SACjE,MAAM,CAAC,OAAO,CAAC;SACf,IAAI,CAAC,GAAG,CAAC,CAAA;AACd,CAAC,CAAA"}
|