@manuscripts/article-editor 3.4.4-LEAN-4053.0 → 3.4.6-LEAN-3894.0
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/Inspector.js +14 -10
- package/dist/cjs/components/Inspector.js.map +1 -1
- package/dist/cjs/components/comments/CommentActions.js +11 -7
- package/dist/cjs/components/comments/CommentActions.js.map +1 -1
- package/dist/cjs/components/comments/CommentBody.js +11 -7
- package/dist/cjs/components/comments/CommentBody.js.map +1 -1
- package/dist/cjs/components/comments/CommentCard.js +163 -0
- package/dist/cjs/components/comments/CommentCard.js.map +1 -0
- package/dist/cjs/components/comments/CommentResolveButton.js +1 -1
- package/dist/cjs/components/comments/CommentThread.js +88 -88
- package/dist/cjs/components/comments/CommentThread.js.map +1 -1
- package/dist/cjs/components/comments/CommentsPanel.js +45 -10
- package/dist/cjs/components/comments/CommentsPanel.js.map +1 -1
- package/dist/cjs/components/comments/DeleteCommentConfirmation.js +115 -0
- package/dist/cjs/components/comments/DeleteCommentConfirmation.js.map +1 -0
- package/dist/cjs/components/comments/ReplyBox.js +121 -0
- package/dist/cjs/components/comments/ReplyBox.js.map +1 -0
- package/dist/cjs/components/projects/Inspector.js +1 -1
- package/dist/cjs/components/projects/Inspector.js.map +1 -1
- package/dist/cjs/components/projects/ManuscriptPageContainer.js +0 -1
- package/dist/cjs/components/projects/ManuscriptPageContainer.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 +26 -5
- package/dist/cjs/lib/comments.js.map +1 -1
- package/dist/cjs/lib/node-content-retriever.js +24 -16
- package/dist/cjs/lib/node-content-retriever.js.map +1 -1
- package/dist/es/components/Inspector.js +10 -6
- package/dist/es/components/Inspector.js.map +1 -1
- package/dist/es/components/comments/CommentActions.js +11 -7
- package/dist/es/components/comments/CommentActions.js.map +1 -1
- package/dist/es/components/comments/CommentBody.js +12 -8
- package/dist/es/components/comments/CommentBody.js.map +1 -1
- package/dist/es/components/comments/CommentCard.js +133 -0
- package/dist/es/components/comments/CommentCard.js.map +1 -0
- package/dist/es/components/comments/CommentResolveButton.js +1 -1
- package/dist/es/components/comments/CommentThread.js +91 -91
- package/dist/es/components/comments/CommentThread.js.map +1 -1
- package/dist/es/components/comments/CommentsPanel.js +47 -12
- package/dist/es/components/comments/CommentsPanel.js.map +1 -1
- package/dist/es/components/comments/DeleteCommentConfirmation.js +85 -0
- package/dist/es/components/comments/DeleteCommentConfirmation.js.map +1 -0
- package/dist/es/components/comments/ReplyBox.js +91 -0
- package/dist/es/components/comments/ReplyBox.js.map +1 -0
- package/dist/es/components/projects/Inspector.js +1 -1
- package/dist/es/components/projects/Inspector.js.map +1 -1
- package/dist/es/components/projects/ManuscriptPageContainer.js +0 -1
- package/dist/es/components/projects/ManuscriptPageContainer.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 +23 -3
- package/dist/es/lib/comments.js.map +1 -1
- package/dist/es/lib/node-content-retriever.js +25 -17
- package/dist/es/lib/node-content-retriever.js.map +1 -1
- package/dist/types/components/Inspector.d.ts +12 -7
- package/dist/types/components/comments/CommentBody.d.ts +0 -1
- package/dist/types/components/comments/CommentCard.d.ts +26 -0
- package/dist/types/components/comments/CommentThread.d.ts +3 -2
- package/dist/types/components/comments/DeleteCommentConfirmation.d.ts +19 -0
- package/dist/types/components/comments/ReplyBox.d.ts +18 -0
- package/dist/types/components/projects/ManuscriptPageContainer.d.ts +0 -1
- package/dist/types/lib/comments.d.ts +4 -3
- package/dist/types/lib/node-content-retriever.d.ts +6 -2
- package/package.json +4 -5
@@ -15,7 +15,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
15
15
|
};
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
17
17
|
exports.InspectorTabPanelHeading = exports.InspectorTab = exports.InspectorTabPanel = exports.PaddedInspectorTabPanels = exports.InspectorTabPanels = exports.InspectorPanelTabList = exports.InspectorTabList = exports.InspectorTabs = exports.InspectorContainer = void 0;
|
18
|
-
const
|
18
|
+
const react_1 = require("@headlessui/react");
|
19
19
|
const styled_components_1 = __importDefault(require("styled-components"));
|
20
20
|
exports.InspectorContainer = styled_components_1.default.div `
|
21
21
|
border-left: 1px solid ${(props) => props.theme.colors.border.tertiary};
|
@@ -26,47 +26,51 @@ exports.InspectorContainer = styled_components_1.default.div `
|
|
26
26
|
height: 100%;
|
27
27
|
overflow: hidden;
|
28
28
|
`;
|
29
|
-
exports.InspectorTabs = (0, styled_components_1.default)(
|
29
|
+
exports.InspectorTabs = (0, styled_components_1.default)(react_1.TabGroup) `
|
30
30
|
display: flex;
|
31
31
|
flex-direction: column;
|
32
32
|
height: 100%;
|
33
33
|
overflow: hidden;
|
34
34
|
`;
|
35
|
-
exports.InspectorTabList = (0, styled_components_1.default)(
|
35
|
+
exports.InspectorTabList = (0, styled_components_1.default)(react_1.TabList) `
|
36
36
|
&& {
|
37
37
|
background: none;
|
38
38
|
justify-content: center;
|
39
39
|
font-size: ${(props) => props.theme.font.size.normal};
|
40
40
|
color: ${(props) => props.theme.colors.text.primary};
|
41
41
|
flex-shrink: 0;
|
42
|
+
display: flex;
|
42
43
|
}
|
43
44
|
`;
|
44
45
|
exports.InspectorPanelTabList = (0, styled_components_1.default)(exports.InspectorTabList) `
|
45
46
|
margin-bottom: ${(props) => props.theme.grid.unit * 4}px;
|
46
47
|
`;
|
47
|
-
exports.InspectorTabPanels = (0, styled_components_1.default)(
|
48
|
+
exports.InspectorTabPanels = (0, styled_components_1.default)(react_1.TabPanels) `
|
48
49
|
flex: 1;
|
49
50
|
overflow-y: auto;
|
50
51
|
`;
|
51
52
|
exports.PaddedInspectorTabPanels = (0, styled_components_1.default)(exports.InspectorTabPanels) `
|
52
53
|
padding-bottom: 64px; // allow space for chat button
|
53
54
|
`;
|
54
|
-
exports.InspectorTabPanel = (0, styled_components_1.default)(
|
55
|
+
exports.InspectorTabPanel = (0, styled_components_1.default)(react_1.TabPanel) `
|
55
56
|
font-size: ${(props) => props.theme.font.size.normal};
|
56
57
|
color: ${(props) => props.theme.colors.text.secondary};
|
57
58
|
`;
|
58
|
-
exports.InspectorTab = (0, styled_components_1.default)(
|
59
|
+
exports.InspectorTab = (0, styled_components_1.default)(react_1.Tab) `
|
59
60
|
&& {
|
61
|
+
font-family: inherit;
|
60
62
|
background: none;
|
61
63
|
padding: ${(props) => props.theme.grid.unit * 2}px;
|
62
|
-
border
|
63
|
-
|
64
|
+
border: none;
|
65
|
+
color: inherit;
|
66
|
+
border-bottom: 1px solid transparent;
|
67
|
+
cursor: pointer;
|
64
68
|
&:focus {
|
65
69
|
outline: none;
|
66
70
|
}
|
67
71
|
|
68
|
-
&[
|
69
|
-
border-
|
72
|
+
&[aria-selected='true'] {
|
73
|
+
border-color: ${(props) => props.theme.colors.brand.default};
|
70
74
|
color: ${(props) => props.theme.colors.brand.default};
|
71
75
|
}
|
72
76
|
}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"Inspector.js","sourceRoot":"","sources":["../../../src/components/Inspector.tsx"],"names":[],"mappings":";AAAA;;;;;;;;;;GAUG;;;;;;AAEH,
|
1
|
+
{"version":3,"file":"Inspector.js","sourceRoot":"","sources":["../../../src/components/Inspector.tsx"],"names":[],"mappings":";AAAA;;;;;;;;;;GAUG;;;;;;AAEH,6CAA+E;AAC/E,0EAAsC;AAEzB,QAAA,kBAAkB,GAAG,2BAAM,CAAC,GAAG,CAAA;2BACjB,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ;;;;;;;CAOvE,CAAA;AAEY,QAAA,aAAa,GAAG,IAAA,2BAAM,EAAC,gBAAQ,CAAC,CAAA;;;;;CAK5C,CAAA;AAEY,QAAA,gBAAgB,GAAG,IAAA,2BAAM,EAAC,eAAO,CAAC,CAAA;;;;iBAI9B,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM;aAC3C,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO;;;;CAItD,CAAA;AAEY,QAAA,qBAAqB,GAAG,IAAA,2BAAM,EAAC,wBAAgB,CAAC,CAAA;mBAC1C,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC;CACtD,CAAA;AAEY,QAAA,kBAAkB,GAAG,IAAA,2BAAM,EAAC,iBAAS,CAAC,CAAA;;;CAGlD,CAAA;AAEY,QAAA,wBAAwB,GAAG,IAAA,2BAAM,EAAC,0BAAkB,CAAC,CAAA;;CAEjE,CAAA;AAEY,QAAA,iBAAiB,GAAG,IAAA,2BAAM,EAAC,gBAAQ,CAAC,CAAA;eAClC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM;WAC3C,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS;CACtD,CAAA;AAEY,QAAA,YAAY,GAAG,IAAA,2BAAM,EAAC,WAAG,CAAC,CAAA;;;;eAIxB,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC;;;;;;;;;;sBAU7B,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO;eAClD,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO;;;CAGzD,CAAA;AAEY,QAAA,wBAAwB,GAAG,2BAAM,CAAC,GAAG,CAAA;mBAC/B,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC;CACtD,CAAA"}
|
@@ -35,25 +35,29 @@ exports.ActionsIcon = styled_components_1.default.button `
|
|
35
35
|
exports.CommentAction = styled_components_1.default.div `
|
36
36
|
font-family: ${(props) => props.theme.font.family.Lato};
|
37
37
|
cursor: pointer;
|
38
|
-
font-size:
|
38
|
+
font-size: 14px;
|
39
39
|
line-height: 24px;
|
40
40
|
color: ${(props) => props.theme.colors.text.primary};
|
41
|
-
padding:
|
41
|
+
padding: 6px 0 6px 8px;
|
42
42
|
&:hover,
|
43
43
|
&:focus {
|
44
44
|
background: #f2fbfc;
|
45
45
|
}
|
46
46
|
`;
|
47
|
+
const Container = styled_components_1.default.div `
|
48
|
+
display: flex;
|
49
|
+
align-items: end;
|
50
|
+
`;
|
47
51
|
const CommentActions = ({ comment, isResolveEnabled, isActionsEnabled, onEdit, onDelete, toggleResolve, }) => {
|
48
52
|
const { isOpen, toggleOpen, wrapperRef } = (0, style_guide_1.useDropdown)();
|
49
|
-
return (react_1.default.createElement(
|
50
|
-
isResolveEnabled && (react_1.default.createElement(CommentResolveButton_1.CommentResolveButton, { comment: comment, onClick: toggleResolve })),
|
53
|
+
return (react_1.default.createElement(Container, null,
|
51
54
|
isActionsEnabled && (react_1.default.createElement(style_guide_1.DropdownContainer, { ref: wrapperRef },
|
52
|
-
react_1.default.createElement(exports.ActionsIcon, { "data-cy": "comment-dropdown-trigger", onClick: toggleOpen },
|
55
|
+
react_1.default.createElement(exports.ActionsIcon, { "data-cy": "comment-dropdown-trigger", onClick: toggleOpen, className: "actions-icon" },
|
53
56
|
react_1.default.createElement(style_guide_1.DotsIcon, null)),
|
54
|
-
isOpen && (react_1.default.createElement(style_guide_1.DropdownList, { "data-cy": "comment-dropdown", direction: 'right', width:
|
57
|
+
isOpen && (react_1.default.createElement(style_guide_1.DropdownList, { "data-cy": "comment-dropdown", direction: 'right', width: 82, onClick: toggleOpen },
|
55
58
|
react_1.default.createElement(exports.CommentAction, { "data-cy": "comment-edit", onClick: onEdit }, "Edit"),
|
56
|
-
react_1.default.createElement(exports.CommentAction, { "data-cy": "comment-delete", onClick: onDelete }, "Delete")))))
|
59
|
+
react_1.default.createElement(exports.CommentAction, { className: "delete-button", "data-cy": "comment-delete", onClick: onDelete }, "Delete"))))),
|
60
|
+
isResolveEnabled && (react_1.default.createElement(CommentResolveButton_1.CommentResolveButton, { comment: comment, onClick: toggleResolve }))));
|
57
61
|
};
|
58
62
|
exports.CommentActions = CommentActions;
|
59
63
|
//# sourceMappingURL=CommentActions.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"CommentActions.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentActions.tsx"],"names":[],"mappings":";AAAA;;;;;;;;;;GAUG;;;;;;AAGH,0DAKiC;AACjC,kDAAyB;AACzB,0EAAsC;AAEtC,iEAA6D;AAEhD,QAAA,WAAW,GAAG,2BAAM,CAAC,MAAM,CAAA;;;;;;;;;;;;CAYvC,CAAA;AAEY,QAAA,aAAa,GAAG,2BAAM,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;AAWM,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,IAAA,yBAAW,GAAE,CAAA;IAExD,OAAO,CACL
|
1
|
+
{"version":3,"file":"CommentActions.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentActions.tsx"],"names":[],"mappings":";AAAA;;;;;;;;;;GAUG;;;;;;AAGH,0DAKiC;AACjC,kDAAyB;AACzB,0EAAsC;AAEtC,iEAA6D;AAEhD,QAAA,WAAW,GAAG,2BAAM,CAAC,MAAM,CAAA;;;;;;;;;;;;CAYvC,CAAA;AAEY,QAAA,aAAa,GAAG,2BAAM,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;AAED,MAAM,SAAS,GAAG,2BAAM,CAAC,GAAG,CAAA;;;CAG3B,CAAA;AAWM,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,IAAA,yBAAW,GAAE,CAAA;IAExD,OAAO,CACL,8BAAC,SAAS;QACP,gBAAgB,IAAI,CACnB,8BAAC,+BAAiB,IAAC,GAAG,EAAE,UAAU;YAChC,8BAAC,mBAAW,eACF,0BAA0B,EAClC,OAAO,EAAE,UAAU,EACnB,SAAS,EAAC,cAAc;gBAExB,8BAAC,sBAAQ,OAAG,CACA;YACb,MAAM,IAAI,CACT,8BAAC,0BAAY,eACH,kBAAkB,EAC1B,SAAS,EAAE,OAAO,EAClB,KAAK,EAAE,EAAE,EACT,OAAO,EAAE,UAAU;gBAEnB,8BAAC,qBAAa,eAAS,cAAc,EAAC,OAAO,EAAE,MAAM,WAErC;gBAChB,8BAAC,qBAAa,IACZ,SAAS,EAAC,eAAe,aACjB,gBAAgB,EACxB,OAAO,EAAE,QAAQ,aAGH,CACH,CAChB,CACiB,CACrB;QACA,gBAAgB,IAAI,CACnB,8BAAC,2CAAoB,IAAC,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,aAAa,GAAI,CACnE,CACS,CACb,CAAA;AACH,CAAC,CAAA;AA/CY,QAAA,cAAc,kBA+C1B"}
|
@@ -31,9 +31,6 @@ const style_guide_1 = require("@manuscripts/style-guide");
|
|
31
31
|
const react_1 = __importStar(require("react"));
|
32
32
|
const styled_components_1 = __importDefault(require("styled-components"));
|
33
33
|
const utils_1 = require("../../lib/utils");
|
34
|
-
const CommentContent = styled_components_1.default.div `
|
35
|
-
cursor: pointer;
|
36
|
-
`;
|
37
34
|
const CommentEditor = styled_components_1.default.textarea `
|
38
35
|
cursor: text;
|
39
36
|
font-family: ${(props) => props.theme.font.family.sans};
|
@@ -67,13 +64,21 @@ const CommentViewer = styled_components_1.default.div `
|
|
67
64
|
letter-spacing: -0.2px;
|
68
65
|
color: ${(props) => props.theme.colors.text.primary};
|
69
66
|
margin: ${(props) => props.theme.grid.unit * 2}px 0;
|
67
|
+
word-wrap: break-word;
|
70
68
|
`;
|
71
69
|
const EditorActions = (0, styled_components_1.default)(style_guide_1.ButtonGroup) `
|
72
70
|
& button:not(:last-of-type) {
|
73
71
|
margin-right: 4px;
|
74
72
|
}
|
73
|
+
|
74
|
+
& ${style_guide_1.TertiaryButton} {
|
75
|
+
&:hover {
|
76
|
+
background-color: inherit !important;
|
77
|
+
border-color: transparent !important;
|
78
|
+
}
|
79
|
+
}
|
75
80
|
`;
|
76
|
-
const CommentBody = ({ comment, isEditing, onSave, onCancel,
|
81
|
+
const CommentBody = ({ comment, isEditing, onSave, onCancel, }) => {
|
77
82
|
const editor = (0, react_1.useRef)(null);
|
78
83
|
const handleSave = () => {
|
79
84
|
if (editor.current) {
|
@@ -92,10 +97,9 @@ const CommentBody = ({ comment, isEditing, onSave, onCancel, onSelect, }) => {
|
|
92
97
|
return (react_1.default.createElement(react_1.default.Fragment, null, isEditing ? (react_1.default.createElement(react_1.default.Fragment, null,
|
93
98
|
react_1.default.createElement(CommentEditor, { "data-cy": "comment-editor", ref: ref, defaultValue: comment.node.attrs.contents, onChange: onTextChange, onBlur: (event) => !event.target.value.length && onCancel() }),
|
94
99
|
react_1.default.createElement(EditorActions, { "data-cy": "comment-actions" },
|
95
|
-
react_1.default.createElement(style_guide_1.
|
100
|
+
react_1.default.createElement(style_guide_1.TertiaryButton, { onClick: onCancel }, "Cancel"),
|
96
101
|
react_1.default.createElement(style_guide_1.PrimaryButton, { onClick: handleSave, disabled: disableSaveButton }, "Save")))) : (react_1.default.createElement(react_1.default.Fragment, null,
|
97
|
-
react_1.default.createElement(
|
98
|
-
react_1.default.createElement(CommentViewer, { "data-cy": "comment-text" }, (0, utils_1.decodeHTMLEntities)(comment.node.attrs.contents)))))));
|
102
|
+
react_1.default.createElement(CommentViewer, { "data-cy": "comment-text" }, (0, utils_1.decodeHTMLEntities)(comment.node.attrs.contents))))));
|
99
103
|
};
|
100
104
|
exports.CommentBody = CommentBody;
|
101
105
|
//# sourceMappingURL=CommentBody.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"CommentBody.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentBody.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAYA,0DAIiC;AACjC,+CAMc;AACd,0EAAsC;AAEtC,2CAAoD;AAEpD,MAAM,
|
1
|
+
{"version":3,"file":"CommentBody.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentBody.tsx"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,163 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
3
|
+
if (k2 === undefined) k2 = k;
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
7
|
+
}
|
8
|
+
Object.defineProperty(o, k2, desc);
|
9
|
+
}) : (function(o, m, k, k2) {
|
10
|
+
if (k2 === undefined) k2 = k;
|
11
|
+
o[k2] = m[k];
|
12
|
+
}));
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
15
|
+
}) : function(o, v) {
|
16
|
+
o["default"] = v;
|
17
|
+
});
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
19
|
+
if (mod && mod.__esModule) return mod;
|
20
|
+
var result = {};
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
22
|
+
__setModuleDefault(result, mod);
|
23
|
+
return result;
|
24
|
+
};
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
27
|
+
};
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
29
|
+
exports.CommentCard = void 0;
|
30
|
+
const style_guide_1 = require("@manuscripts/style-guide");
|
31
|
+
const react_1 = __importStar(require("react"));
|
32
|
+
const styled_components_1 = __importDefault(require("styled-components"));
|
33
|
+
const comments_1 = require("../../lib/comments");
|
34
|
+
const store_1 = require("../../store");
|
35
|
+
const CommentActions_1 = require("./CommentActions");
|
36
|
+
const CommentBody_1 = require("./CommentBody");
|
37
|
+
const DeleteCommentConfirmation_1 = require("./DeleteCommentConfirmation");
|
38
|
+
const CommentHeader = styled_components_1.default.div `
|
39
|
+
display: flex;
|
40
|
+
justify-content: space-between;
|
41
|
+
margin-bottom: 8px;
|
42
|
+
`;
|
43
|
+
const CommentMetadata = styled_components_1.default.div `
|
44
|
+
display: flex;
|
45
|
+
align-items: center;
|
46
|
+
padding-right: 8px;
|
47
|
+
`;
|
48
|
+
const AuthorContainer = styled_components_1.default.div `
|
49
|
+
display: flex;
|
50
|
+
color: #353535;
|
51
|
+
font-weight: 400;
|
52
|
+
max-width: 200px;
|
53
|
+
white-space: nowrap;
|
54
|
+
overflow: hidden;
|
55
|
+
flex-grow: 1;
|
56
|
+
text-overflow: ellipsis;
|
57
|
+
margin-right: 8px;
|
58
|
+
|
59
|
+
svg {
|
60
|
+
padding-right: 10px;
|
61
|
+
flex-shrink: 0;
|
62
|
+
}
|
63
|
+
`;
|
64
|
+
const CommentTarget = styled_components_1.default.div `
|
65
|
+
font-size: 14px;
|
66
|
+
color: #353535;
|
67
|
+
background-color: #ffeebf;
|
68
|
+
padding: 4px 8px;
|
69
|
+
margin-top: 16px;
|
70
|
+
margin-bottom: 16px;
|
71
|
+
`;
|
72
|
+
const Timestamp = (0, styled_components_1.default)(style_guide_1.RelativeDate) `
|
73
|
+
font-size: 12px;
|
74
|
+
line-height: 16px;
|
75
|
+
font-weight: 400;
|
76
|
+
color: #6e6e6e;
|
77
|
+
white-space: nowrap;
|
78
|
+
padding-right: 8px;
|
79
|
+
`;
|
80
|
+
const RepliesCount = styled_components_1.default.div `
|
81
|
+
border-radius: 50%;
|
82
|
+
width: 12px;
|
83
|
+
height: 12px;
|
84
|
+
color: #ffffff;
|
85
|
+
background-color: #1a9bc7;
|
86
|
+
text-align: center;
|
87
|
+
font-size: 9px;
|
88
|
+
`;
|
89
|
+
const Card = styled_components_1.default.div `
|
90
|
+
position: relative;
|
91
|
+
`;
|
92
|
+
const CommentCard = ({ comment, isReply, numOfReplies, isNew, isEndOfThread, editingCommentId, setEditingCommentId, onSave, onDelete, }) => {
|
93
|
+
const can = (0, style_guide_1.usePermissions)();
|
94
|
+
const [{ user, collaboratorsById }] = (0, store_1.useStore)((state) => ({
|
95
|
+
user: state.user,
|
96
|
+
collaboratorsById: state.collaboratorsById,
|
97
|
+
}));
|
98
|
+
const authorID = (0, comments_1.getAuthorID)(comment);
|
99
|
+
const authorName = authorID
|
100
|
+
? (0, comments_1.buildAuthorName)(collaboratorsById.get(authorID))
|
101
|
+
: '';
|
102
|
+
const timestamp = comment.node.attrs.contributions?.[0].timestamp;
|
103
|
+
const isOwn = authorID === user._id;
|
104
|
+
const isResolveEnabled = isOwn
|
105
|
+
? can.resolveOwnComment
|
106
|
+
: can.resolveOthersComment;
|
107
|
+
const isActionsEnabled = isOwn
|
108
|
+
? can.handleOwnComments
|
109
|
+
: can.handleOthersComments;
|
110
|
+
const commentID = comment.node.attrs.id;
|
111
|
+
const [showDeleteConfirmation, setShowDeleteConfirmation] = (0, react_1.useState)(false);
|
112
|
+
const handleEdit = () => {
|
113
|
+
setEditingCommentId(commentID);
|
114
|
+
};
|
115
|
+
const handleSave = (contents) => {
|
116
|
+
onSave({
|
117
|
+
...comment.node.attrs,
|
118
|
+
contents,
|
119
|
+
});
|
120
|
+
setEditingCommentId(null);
|
121
|
+
};
|
122
|
+
const handleCancel = () => {
|
123
|
+
setEditingCommentId(null);
|
124
|
+
if (isNew) {
|
125
|
+
onDelete(commentID);
|
126
|
+
}
|
127
|
+
};
|
128
|
+
const handleToggleResolve = () => {
|
129
|
+
onSave({
|
130
|
+
...comment.node.attrs,
|
131
|
+
resolved: !comment.node.attrs.resolved,
|
132
|
+
});
|
133
|
+
};
|
134
|
+
const handleDelete = () => {
|
135
|
+
setShowDeleteConfirmation(true);
|
136
|
+
};
|
137
|
+
const confirmDelete = () => {
|
138
|
+
onDelete(commentID);
|
139
|
+
setShowDeleteConfirmation(false);
|
140
|
+
};
|
141
|
+
const cancelDelete = () => {
|
142
|
+
setShowDeleteConfirmation(false);
|
143
|
+
};
|
144
|
+
return (react_1.default.createElement(Card, null,
|
145
|
+
react_1.default.createElement(CommentHeader, { "data-cy": "comment-header" },
|
146
|
+
react_1.default.createElement(CommentMetadata, null,
|
147
|
+
react_1.default.createElement(AuthorContainer, null, authorName ? (react_1.default.createElement(react_1.default.Fragment, null,
|
148
|
+
react_1.default.createElement(style_guide_1.AvatarIcon, { width: 20, height: 20 }),
|
149
|
+
react_1.default.createElement(react_1.default.Fragment, null, authorName))) : (!isReply && (react_1.default.createElement(react_1.default.Fragment, null,
|
150
|
+
react_1.default.createElement(style_guide_1.SystemUserAvatarIcon, { width: 20, height: 20 }),
|
151
|
+
react_1.default.createElement(react_1.default.Fragment, null, "System"))))),
|
152
|
+
timestamp && react_1.default.createElement(Timestamp, { date: timestamp * 1000 }),
|
153
|
+
numOfReplies !== 0 && react_1.default.createElement(RepliesCount, null,
|
154
|
+
" ",
|
155
|
+
numOfReplies,
|
156
|
+
" ")),
|
157
|
+
react_1.default.createElement(CommentActions_1.CommentActions, { comment: comment, isResolveEnabled: isResolveEnabled && !isReply, isActionsEnabled: isActionsEnabled && isEndOfThread, onDelete: handleDelete, onEdit: handleEdit, toggleResolve: handleToggleResolve })),
|
158
|
+
comment.node.attrs.originalText && (react_1.default.createElement(CommentTarget, null, comment.node.attrs.originalText)),
|
159
|
+
react_1.default.createElement(CommentBody_1.CommentBody, { comment: comment, isEditing: editingCommentId === commentID, onSave: handleSave, onCancel: handleCancel }),
|
160
|
+
showDeleteConfirmation && (react_1.default.createElement(DeleteCommentConfirmation_1.DeleteCommentConfirmation, { isReply: isReply, onCancel: cancelDelete, onConfirm: confirmDelete }))));
|
161
|
+
};
|
162
|
+
exports.CommentCard = CommentCard;
|
163
|
+
//# sourceMappingURL=CommentCard.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"CommentCard.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentCard.tsx"],"names":[],"mappings":"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"}
|
@@ -31,104 +31,104 @@ const style_guide_1 = require("@manuscripts/style-guide");
|
|
31
31
|
const react_1 = __importStar(require("react"));
|
32
32
|
const styled_components_1 = __importDefault(require("styled-components"));
|
33
33
|
const comments_1 = require("../../lib/comments");
|
34
|
-
const
|
35
|
-
const
|
36
|
-
const CommentBody_1 = require("./CommentBody");
|
34
|
+
const CommentCard_1 = require("./CommentCard");
|
35
|
+
const ReplyBox_1 = require("./ReplyBox");
|
37
36
|
const Container = styled_components_1.default.div `
|
38
|
-
padding:
|
39
|
-
background-color: ${(props) => (props.isSelected ? '#
|
40
|
-
border: 1px solid
|
41
|
-
border-left-width: 4px;
|
37
|
+
padding: 8px;
|
38
|
+
background-color: ${(props) => (props.isSelected ? '#fff' : '#fafafa')};
|
39
|
+
border: 1px solid #c9c9c9;
|
40
|
+
${(props) => props.isSelected && 'border-left-width: 4px'};
|
41
|
+
border-radius: 4px;
|
42
42
|
margin-bottom: 16px;
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
`;
|
53
|
-
const CommentAuthor = styled_components_1.default.div `
|
54
|
-
display: flex;
|
55
|
-
color: #353535;
|
56
|
-
font-weight: 400;
|
57
|
-
max-width: 200px;
|
58
|
-
white-space: nowrap;
|
59
|
-
overflow: hidden;
|
60
|
-
text-overflow: ellipsis;
|
61
|
-
width: 100%;
|
43
|
+
margin-left: 12px;
|
44
|
+
margin-right: 12px;
|
45
|
+
cursor: pointer;
|
46
|
+
.actions-icon {
|
47
|
+
visibility: ${(props) => (props.isSelected ? 'visible' : 'hidden')};
|
48
|
+
}
|
49
|
+
|
50
|
+
&:hover {
|
51
|
+
background-color: #fff;
|
62
52
|
|
63
|
-
|
64
|
-
|
53
|
+
.actions-icon {
|
54
|
+
visibility: visible;
|
55
|
+
}
|
65
56
|
}
|
66
57
|
`;
|
67
|
-
const
|
68
|
-
|
69
|
-
color: #
|
70
|
-
|
71
|
-
padding: 4px 8px;
|
72
|
-
margin-top: 16px;
|
73
|
-
margin-bottom: 16px;
|
58
|
+
const SeparatorLine = styled_components_1.default.div `
|
59
|
+
margin-bottom: 8px;
|
60
|
+
background-color: #c9c9c9;
|
61
|
+
height: 1px;
|
74
62
|
`;
|
75
|
-
const
|
76
|
-
|
77
|
-
line-height: 16px;
|
78
|
-
font-weight: 400;
|
79
|
-
color: #6e6e6e;
|
63
|
+
const Indented = styled_components_1.default.div `
|
64
|
+
padding-left: 16px;
|
80
65
|
`;
|
81
66
|
exports.CommentThread = (0, react_1.forwardRef)((props, ref) => {
|
82
|
-
const {
|
67
|
+
const { thread, isSelected, onSelect, onSave, onDelete, insertCommentReply, } = props;
|
83
68
|
const can = (0, style_guide_1.usePermissions)();
|
84
|
-
const
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
const handleSave = (contents) => {
|
103
|
-
onSave({
|
104
|
-
...tree.comment.node.attrs,
|
105
|
-
contents,
|
106
|
-
});
|
107
|
-
setEditing(false);
|
108
|
-
};
|
109
|
-
const handleCancel = () => {
|
110
|
-
setEditing(false);
|
111
|
-
if (tree.isNew) {
|
112
|
-
onDelete(tree.comment.node.attrs.id);
|
69
|
+
const { comment, isNew, replies } = thread;
|
70
|
+
const cardsRef = (0, react_1.useRef)(null);
|
71
|
+
const [showMore, setShowMore] = (0, react_1.useState)(false);
|
72
|
+
const [editingCommentId, setEditingCommentId] = (0, react_1.useState)(isNew ? comment.node.attrs.id : null);
|
73
|
+
(0, react_1.useEffect)(() => {
|
74
|
+
if (!isSelected) {
|
75
|
+
setEditingCommentId(null);
|
76
|
+
}
|
77
|
+
}, [isSelected]);
|
78
|
+
(0, react_1.useEffect)(() => {
|
79
|
+
if (cardsRef.current) {
|
80
|
+
const contentHeight = cardsRef.current.scrollHeight;
|
81
|
+
setShowMore(contentHeight > 280);
|
82
|
+
}
|
83
|
+
}, [comment, replies]);
|
84
|
+
const handleSelect = () => {
|
85
|
+
if (!isSelected) {
|
86
|
+
onSelect();
|
113
87
|
}
|
114
88
|
};
|
115
|
-
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
react_1.default.createElement(CommentActions_1.CommentActions, { comment: tree.comment, isResolveEnabled: isResolveEnabled, isActionsEnabled: isActionsEnabled, onDelete: () => onDelete(tree.comment.node.attrs.id), onEdit: handleEdit, toggleResolve: handleToggleResolve })),
|
131
|
-
tree.comment.node.attrs.originalText && (react_1.default.createElement(CommentTarget, null, tree.comment.node.attrs.originalText)),
|
132
|
-
react_1.default.createElement(CommentBody_1.CommentBody, { comment: tree.comment, isEditing: tree.isNew || isEditing, onSave: handleSave, onCancel: handleCancel, onSelect: onSelect })));
|
89
|
+
return (react_1.default.createElement(Container, { "data-cy": "comment", isSelected: isSelected, ref: ref, onClick: handleSelect },
|
90
|
+
react_1.default.createElement(CardsWrapper, { ref: cardsRef, isSelected: isSelected, showMore: showMore },
|
91
|
+
react_1.default.createElement(CommentCard_1.CommentCard, { comment: comment, isReply: false, numOfReplies: replies.length, isNew: isNew, isEndOfThread: !replies.length, editingCommentId: editingCommentId, setEditingCommentId: setEditingCommentId, onDelete: onDelete, onSave: onSave }),
|
92
|
+
replies.sort(comments_1.commentsByTime).map((reply, index) => {
|
93
|
+
return (react_1.default.createElement("div", { key: reply.node.attrs.id },
|
94
|
+
index === 0 && react_1.default.createElement(SeparatorLine, null),
|
95
|
+
react_1.default.createElement(Indented, null,
|
96
|
+
index !== 0 && react_1.default.createElement(SeparatorLine, null),
|
97
|
+
react_1.default.createElement(CommentCard_1.CommentCard, { comment: reply, isReply: true, numOfReplies: 0, isNew: false, isEndOfThread: index === replies.length - 1, editingCommentId: editingCommentId, setEditingCommentId: setEditingCommentId, onDelete: onDelete, onSave: onSave }))));
|
98
|
+
})),
|
99
|
+
showMore && !isSelected && (react_1.default.createElement(react_1.default.Fragment, null,
|
100
|
+
react_1.default.createElement(SeparatorLine, null),
|
101
|
+
react_1.default.createElement(ButtonContainer, null,
|
102
|
+
react_1.default.createElement(ShowMore, { onClick: onSelect }, "Show more")))),
|
103
|
+
can.createComment && isSelected && editingCommentId === null && (react_1.default.createElement(ReplyBox_1.ReplyBox, { insertCommentReply: insertCommentReply, commentID: comment.node.attrs.id }))));
|
133
104
|
});
|
105
|
+
const ButtonContainer = styled_components_1.default.div `
|
106
|
+
display: flex;
|
107
|
+
justify-content: center;
|
108
|
+
align-items: center;
|
109
|
+
`;
|
110
|
+
const ShowMore = (0, styled_components_1.default)(style_guide_1.TextButton) `
|
111
|
+
cursor: pointer;
|
112
|
+
text-align: center;
|
113
|
+
margin-top: 6px;
|
114
|
+
color: #353535;
|
115
|
+
`;
|
116
|
+
const CardsWrapper = styled_components_1.default.div `
|
117
|
+
max-height: ${({ isSelected }) => (isSelected ? 'none' : '280px')};
|
118
|
+
position: relative;
|
119
|
+
${({ showMore, isSelected }) => showMore &&
|
120
|
+
!isSelected &&
|
121
|
+
`
|
122
|
+
overflow: hidden;
|
123
|
+
&:after {
|
124
|
+
content: '';
|
125
|
+
position: absolute;
|
126
|
+
bottom: 0;
|
127
|
+
left: 0;
|
128
|
+
right: 0;
|
129
|
+
height: 40px;
|
130
|
+
background: linear-gradient(to bottom, rgba(255, 255, 255, 0), rgba(255, 255, 255, 1));
|
131
|
+
}
|
132
|
+
`}
|
133
|
+
`;
|
134
134
|
//# sourceMappingURL=CommentThread.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"CommentThread.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentThread.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAYA,
|
1
|
+
{"version":3,"file":"CommentThread.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentThread.tsx"],"names":[],"mappings":"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"}
|