@manuscripts/article-editor 3.2.16 → 3.2.17-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.
Files changed (36) hide show
  1. package/dist/cjs/components/comments/CommentActions.js +6 -2
  2. package/dist/cjs/components/comments/CommentActions.js.map +1 -1
  3. package/dist/cjs/components/comments/CommentCard.js +162 -0
  4. package/dist/cjs/components/comments/CommentCard.js.map +1 -0
  5. package/dist/cjs/components/comments/CommentResolveButton.js +1 -1
  6. package/dist/cjs/components/comments/CommentThread.js +77 -89
  7. package/dist/cjs/components/comments/CommentThread.js.map +1 -1
  8. package/dist/cjs/components/comments/CommentsPanel.js +31 -7
  9. package/dist/cjs/components/comments/CommentsPanel.js.map +1 -1
  10. package/dist/cjs/components/comments/DeleteCommentConfirmation.js +69 -0
  11. package/dist/cjs/components/comments/DeleteCommentConfirmation.js.map +1 -0
  12. package/dist/cjs/components/comments/ReplyBox.js +119 -0
  13. package/dist/cjs/components/comments/ReplyBox.js.map +1 -0
  14. package/dist/cjs/lib/comments.js +14 -5
  15. package/dist/cjs/lib/comments.js.map +1 -1
  16. package/dist/es/components/comments/CommentActions.js +6 -2
  17. package/dist/es/components/comments/CommentActions.js.map +1 -1
  18. package/dist/es/components/comments/CommentCard.js +132 -0
  19. package/dist/es/components/comments/CommentCard.js.map +1 -0
  20. package/dist/es/components/comments/CommentResolveButton.js +1 -1
  21. package/dist/es/components/comments/CommentThread.js +80 -92
  22. package/dist/es/components/comments/CommentThread.js.map +1 -1
  23. package/dist/es/components/comments/CommentsPanel.js +32 -8
  24. package/dist/es/components/comments/CommentsPanel.js.map +1 -1
  25. package/dist/es/components/comments/DeleteCommentConfirmation.js +62 -0
  26. package/dist/es/components/comments/DeleteCommentConfirmation.js.map +1 -0
  27. package/dist/es/components/comments/ReplyBox.js +89 -0
  28. package/dist/es/components/comments/ReplyBox.js.map +1 -0
  29. package/dist/es/lib/comments.js +11 -3
  30. package/dist/es/lib/comments.js.map +1 -1
  31. package/dist/types/components/comments/CommentCard.d.ts +25 -0
  32. package/dist/types/components/comments/CommentThread.d.ts +3 -2
  33. package/dist/types/components/comments/DeleteCommentConfirmation.d.ts +18 -0
  34. package/dist/types/components/comments/ReplyBox.d.ts +18 -0
  35. package/dist/types/lib/comments.d.ts +4 -3
  36. package/package.json +2 -2
@@ -0,0 +1,119 @@
1
+ "use strict";
2
+ /*!
3
+ * 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.
4
+ *
5
+ * 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.
6
+ *
7
+ * The Original Code is manuscripts-frontend.
8
+ *
9
+ * The Original Developer is the Initial Developer. The Initial Developer of the Original Code is Atypon Systems LLC.
10
+ *
11
+ * All portions of the code written by Atypon Systems LLC are Copyright (c) 2024 Atypon Systems LLC. All Rights Reserved.
12
+ */
13
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
14
+ if (k2 === undefined) k2 = k;
15
+ var desc = Object.getOwnPropertyDescriptor(m, k);
16
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
17
+ desc = { enumerable: true, get: function() { return m[k]; } };
18
+ }
19
+ Object.defineProperty(o, k2, desc);
20
+ }) : (function(o, m, k, k2) {
21
+ if (k2 === undefined) k2 = k;
22
+ o[k2] = m[k];
23
+ }));
24
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
25
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
26
+ }) : function(o, v) {
27
+ o["default"] = v;
28
+ });
29
+ var __importStar = (this && this.__importStar) || function (mod) {
30
+ if (mod && mod.__esModule) return mod;
31
+ var result = {};
32
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
33
+ __setModuleDefault(result, mod);
34
+ return result;
35
+ };
36
+ var __importDefault = (this && this.__importDefault) || function (mod) {
37
+ return (mod && mod.__esModule) ? mod : { "default": mod };
38
+ };
39
+ Object.defineProperty(exports, "__esModule", { value: true });
40
+ exports.ReplyBox = void 0;
41
+ const style_guide_1 = require("@manuscripts/style-guide");
42
+ const react_1 = __importStar(require("react"));
43
+ const styled_components_1 = __importDefault(require("styled-components"));
44
+ const ReplyBox = ({ insertCommentReply, commentId, }) => {
45
+ const [isTextBoxFocused, setIsTextBoxFocused] = (0, react_1.useState)(false);
46
+ const [value, setValue] = (0, react_1.useState)('');
47
+ const replyRef = (0, react_1.useRef)(null);
48
+ const handleFocus = () => setIsTextBoxFocused(true);
49
+ const handleBlur = (event) => {
50
+ if (!event.target.value.length) {
51
+ setIsTextBoxFocused(false);
52
+ }
53
+ };
54
+ const reply = () => {
55
+ if (replyRef.current) {
56
+ insertCommentReply(commentId, replyRef.current.value);
57
+ setIsTextBoxFocused(false);
58
+ setValue('');
59
+ replyRef.current.value = '';
60
+ replyRef.current.style.height = '30px'; // Reset the height
61
+ }
62
+ };
63
+ const disableSaveButton = (0, react_1.useMemo)(() => !value.length, [value]);
64
+ const onTextChange = (e) => {
65
+ setValue(e.target.value);
66
+ if (replyRef.current) {
67
+ replyRef.current.style.height = '30px'; // Reset the height
68
+ replyRef.current.style.height = `${Math.min(replyRef.current.scrollHeight, 55)}px`; // Set the height based on content
69
+ }
70
+ };
71
+ return (react_1.default.createElement(react_1.default.Fragment, null,
72
+ react_1.default.createElement(TextBox, { "data-cy": "reply", placeholder: "Reply...", ref: replyRef, onChange: onTextChange, onFocus: handleFocus, onBlur: handleBlur }),
73
+ isTextBoxFocused && (react_1.default.createElement(Actions, { "data-cy": "reply-actions" },
74
+ react_1.default.createElement(style_guide_1.SecondaryButton, { onClick: () => {
75
+ setIsTextBoxFocused(false);
76
+ setValue('');
77
+ if (replyRef.current) {
78
+ replyRef.current.value = '';
79
+ replyRef.current.style.height = '30px'; // Reset the height
80
+ }
81
+ } }, "Cancel"),
82
+ react_1.default.createElement(style_guide_1.PrimaryButton, { onClick: reply, disabled: disableSaveButton }, "Reply")))));
83
+ };
84
+ exports.ReplyBox = ReplyBox;
85
+ const TextBox = styled_components_1.default.textarea `
86
+ cursor: text;
87
+ font-family: ${(props) => props.theme.font.family.sans};
88
+ color: ${(props) => props.theme.colors.text.primary};
89
+ margin: ${(props) => props.theme.grid.unit * 2}px 0;
90
+ resize: none;
91
+
92
+ width: 100%;
93
+
94
+ height: 30px;
95
+ max-height: 55px;
96
+
97
+ outline: 0;
98
+ border: 1px solid #e2e2e2;
99
+ border-radius: 6px;
100
+
101
+ &:focus {
102
+ background: #f2fbfc;
103
+ border: 1px solid #bce7f6;
104
+ border-radius: 6px;
105
+ }
106
+
107
+ box-sizing: border-box;
108
+ padding: 3px 16px 3px 16px;
109
+ font-style: normal;
110
+ font-weight: 400;
111
+ font-size: 14px;
112
+ line-height: 24px;
113
+ `;
114
+ const Actions = (0, styled_components_1.default)(style_guide_1.ButtonGroup) `
115
+ & button:not(:last-of-type) {
116
+ margin-right: 4px;
117
+ }
118
+ `;
119
+ //# sourceMappingURL=ReplyBox.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ReplyBox.js","sourceRoot":"","sources":["../../../../src/components/comments/ReplyBox.tsx"],"names":[],"mappings":";AAAA;;;;;;;;;;GAUG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEH,0DAIiC;AACjC,+CAAqE;AACrE,0EAAsC;AAO/B,MAAM,QAAQ,GAA4B,CAAC,EAChD,kBAAkB,EAClB,SAAS,GACV,EAAE,EAAE;IACH,MAAM,CAAC,gBAAgB,EAAE,mBAAmB,CAAC,GAAG,IAAA,gBAAQ,EAAC,KAAK,CAAC,CAAA;IAC/D,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,IAAA,gBAAQ,EAAC,EAAE,CAAC,CAAA;IACtC,MAAM,QAAQ,GAAG,IAAA,cAAM,EAA6B,IAAI,CAAC,CAAA;IAEzD,MAAM,WAAW,GAAG,GAAG,EAAE,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAA;IACnD,MAAM,UAAU,GAAG,CAAC,KAAuC,EAAE,EAAE;QAC7D,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,EAAE;YAC9B,mBAAmB,CAAC,KAAK,CAAC,CAAA;SAC3B;IACH,CAAC,CAAA;IAED,MAAM,KAAK,GAAG,GAAG,EAAE;QACjB,IAAI,QAAQ,CAAC,OAAO,EAAE;YACpB,kBAAkB,CAAC,SAAS,EAAE,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;YACrD,mBAAmB,CAAC,KAAK,CAAC,CAAA;YAC1B,QAAQ,CAAC,EAAE,CAAC,CAAA;YACZ,QAAQ,CAAC,OAAO,CAAC,KAAK,GAAG,EAAE,CAAA;YAC3B,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAA,CAAC,mBAAmB;SAC3D;IACH,CAAC,CAAA;IAED,MAAM,iBAAiB,GAAG,IAAA,eAAO,EAAC,GAAG,EAAE,CAAC,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,KAAK,CAAC,CAAC,CAAA;IAC/D,MAAM,YAAY,GAAG,CAAC,CAAmC,EAAE,EAAE;QAC3D,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;QACxB,IAAI,QAAQ,CAAC,OAAO,EAAE;YACpB,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAA,CAAC,mBAAmB;YAC1D,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CACzC,QAAQ,CAAC,OAAO,CAAC,YAAY,EAC7B,EAAE,CACH,IAAI,CAAA,CAAC,kCAAkC;SACzC;IACH,CAAC,CAAA;IAED,OAAO,CACL;QACE,8BAAC,OAAO,eACE,OAAO,EACf,WAAW,EAAC,UAAU,EACtB,GAAG,EAAE,QAAQ,EACb,QAAQ,EAAE,YAAY,EACtB,OAAO,EAAE,WAAW,EACpB,MAAM,EAAE,UAAU,GAClB;QACD,gBAAgB,IAAI,CACnB,8BAAC,OAAO,eAAS,eAAe;YAC9B,8BAAC,6BAAe,IACd,OAAO,EAAE,GAAG,EAAE;oBACZ,mBAAmB,CAAC,KAAK,CAAC,CAAA;oBAC1B,QAAQ,CAAC,EAAE,CAAC,CAAA;oBACZ,IAAI,QAAQ,CAAC,OAAO,EAAE;wBACpB,QAAQ,CAAC,OAAO,CAAC,KAAK,GAAG,EAAE,CAAA;wBAC3B,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAA,CAAC,mBAAmB;qBAC3D;gBACH,CAAC,aAGe;YAClB,8BAAC,2BAAa,IAAC,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,iBAAiB,YAE1C,CACR,CACX,CACA,CACJ,CAAA;AACH,CAAC,CAAA;AApEY,QAAA,QAAQ,YAoEpB;AACD,MAAM,OAAO,GAAG,2BAAM,CAAC,QAAQ,CAAA;;iBAEd,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;;;;;;;;;;;;;;;;;;;;;;;;CAwB/C,CAAA;AAED,MAAM,OAAO,GAAG,IAAA,2BAAM,EAAC,yBAAW,CAAC,CAAA;;;;CAIlC,CAAA"}
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.buildAuthorName = exports.buildCommentTrees = exports.getAuthorID = void 0;
3
+ exports.commentsByTime = exports.buildAuthorName = exports.buildThreads = exports.getAuthorID = void 0;
4
4
  const getAuthorID = (comment) => {
5
5
  const contributions = comment.node.attrs.contributions;
6
6
  if (!contributions?.length) {
@@ -9,14 +9,17 @@ const getAuthorID = (comment) => {
9
9
  return contributions[0].profileID;
10
10
  };
11
11
  exports.getAuthorID = getAuthorID;
12
- const buildCommentTrees = (comments, newCommentID) => {
13
- return comments.map((c) => ({
12
+ const buildThreads = (comments, newCommentID) => {
13
+ return comments
14
+ .filter((c) => !c.node.attrs.target.includes('MPCommentAnnotation')) // Filter out replies
15
+ .map((c) => ({
14
16
  comment: c,
15
17
  isNew: newCommentID === c.node.attrs.id,
16
- children: [],
18
+ replies: comments.filter((reply) => reply.node.attrs.target === c.node.attrs.id // Find replies for each comment
19
+ ),
17
20
  }));
18
21
  };
19
- exports.buildCommentTrees = buildCommentTrees;
22
+ exports.buildThreads = buildThreads;
20
23
  const buildAuthorName = (user) => {
21
24
  if (!user) {
22
25
  return '';
@@ -26,4 +29,10 @@ const buildAuthorName = (user) => {
26
29
  .join(' ');
27
30
  };
28
31
  exports.buildAuthorName = buildAuthorName;
32
+ const commentsByTime = (a, b) => {
33
+ const aTimestamp = a.node.attrs.contributions?.[0].timestamp || 0;
34
+ const bTimestamp = b.node.attrs.contributions?.[0].timestamp || 0;
35
+ return aTimestamp - bTimestamp;
36
+ };
37
+ exports.commentsByTime = commentsByTime;
29
38
  //# sourceMappingURL=comments.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"comments.js","sourceRoot":"","sources":["../../../src/lib/comments.ts"],"names":[],"mappings":";;;AAoBO,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;AANY,QAAA,WAAW,eAMvB;AAEM,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;AATY,QAAA,iBAAiB,qBAS7B;AAEM,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;AAPY,QAAA,eAAe,mBAO3B"}
1
+ {"version":3,"file":"comments.js","sourceRoot":"","sources":["../../../src/lib/comments.ts"],"names":[],"mappings":";;;AAoBO,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;AANY,QAAA,WAAW,eAMvB;AAEM,MAAM,YAAY,GAAG,CAC1B,QAAmB,EACnB,YAAqB,EACX,EAAE;IACZ,OAAO,QAAQ;SACZ,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,qBAAqB,CAAC,CAAC,CAAC,qBAAqB;SACzF,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QACX,OAAO,EAAE,CAAC;QACV,KAAK,EAAE,YAAY,KAAK,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;QACvC,OAAO,EAAE,QAAQ,CAAC,MAAM,CACtB,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,gCAAgC;SACxF;KACF,CAAC,CAAC,CAAA;AACP,CAAC,CAAA;AAbY,QAAA,YAAY,gBAaxB;AAEM,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;AAPY,QAAA,eAAe,mBAO3B;AAEM,MAAM,cAAc,GAAG,CAAC,CAAU,EAAE,CAAU,EAAE,EAAE;IACvD,MAAM,UAAU,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,IAAI,CAAC,CAAA;IACjE,MAAM,UAAU,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,IAAI,CAAC,CAAA;IACjE,OAAO,UAAU,GAAG,UAAU,CAAA;AAChC,CAAC,CAAA;AAJY,QAAA,cAAc,kBAI1B"}
@@ -38,12 +38,16 @@ export const CommentAction = styled.div `
38
38
  background: #f2fbfc;
39
39
  }
40
40
  `;
41
+ const Container = styled.div `
42
+ display: flex;
43
+ align-items: end;
44
+ `;
41
45
  export const CommentActions = ({ comment, isResolveEnabled, isActionsEnabled, onEdit, onDelete, toggleResolve, }) => {
42
46
  const { isOpen, toggleOpen, wrapperRef } = useDropdown();
43
- return (React.createElement(React.Fragment, null,
47
+ return (React.createElement(Container, null,
44
48
  isResolveEnabled && (React.createElement(CommentResolveButton, { comment: comment, onClick: toggleResolve })),
45
49
  isActionsEnabled && (React.createElement(DropdownContainer, { ref: wrapperRef },
46
- React.createElement(ActionsIcon, { "data-cy": "comment-dropdown-trigger", onClick: toggleOpen },
50
+ React.createElement(ActionsIcon, { "data-cy": "comment-dropdown-trigger", onClick: toggleOpen, className: "actions-icon" },
47
51
  React.createElement(DotsIcon, null)),
48
52
  isOpen && (React.createElement(DropdownList, { "data-cy": "comment-dropdown", direction: 'right', width: 125, onClick: toggleOpen },
49
53
  React.createElement(CommentAction, { "data-cy": "comment-edit", onClick: onEdit }, "Edit"),
@@ -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;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
+ {"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;AAED,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,CAAA;;;CAG3B,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,oBAAC,SAAS;QACP,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,eACF,0BAA0B,EAClC,OAAO,EAAE,UAAU,EACnB,SAAS,EAAC,cAAc;gBAExB,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,CACS,CACb,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,132 @@
1
+ import { AvatarIcon, RelativeDate, SystemUserAvatarIcon, usePermissions, } from '@manuscripts/style-guide';
2
+ import React, { useState } from 'react';
3
+ import styled from 'styled-components';
4
+ import { buildAuthorName, getAuthorID } from '../../lib/comments';
5
+ import { useStore } from '../../store';
6
+ import { CommentActions } from './CommentActions';
7
+ import { CommentBody } from './CommentBody';
8
+ import { DeleteCommentConfirmation } from './DeleteCommentConfirmation';
9
+ const CommentHeader = styled.div `
10
+ display: flex;
11
+ justify-content: space-between;
12
+ margin-bottom: 8px;
13
+ `;
14
+ const CommentMetadata = styled.div `
15
+ display: flex;
16
+ align-items: center;
17
+ padding-right: 8px;
18
+ `;
19
+ const CommentAuthor = styled.div `
20
+ display: flex;
21
+ color: #353535;
22
+ font-weight: 400;
23
+ max-width: 200px;
24
+ white-space: nowrap;
25
+ overflow: hidden;
26
+ text-overflow: ellipsis;
27
+ width: 100%;
28
+
29
+ svg {
30
+ padding-right: 10px;
31
+ }
32
+ `;
33
+ const CommentTarget = styled.div `
34
+ font-size: 14px;
35
+ color: #353535;
36
+ background-color: #ffeebf;
37
+ padding: 4px 8px;
38
+ margin-top: 16px;
39
+ margin-bottom: 16px;
40
+ `;
41
+ const Timestamp = styled(RelativeDate) `
42
+ font-size: 12px;
43
+ line-height: 16px;
44
+ font-weight: 400;
45
+ color: #6e6e6e;
46
+ white-space: nowrap;
47
+ padding-right: 8px;
48
+ `;
49
+ const RepliesCount = styled.div `
50
+ border-radius: 50%;
51
+ width: 20px;
52
+ height: 12px;
53
+ color: #ffffff;
54
+ background-color: #1a9bc7;
55
+ text-align: center;
56
+ font-size: 9px;
57
+ `;
58
+ const Card = styled.div `
59
+ position: relative;
60
+ `;
61
+ export const CommentCard = ({ comment, isReply, numOfReplies, isNew, isEndOfThread, onSave, onDelete, onSelect, }) => {
62
+ const can = usePermissions();
63
+ const [{ user, collaboratorsById }] = useStore((state) => ({
64
+ user: state.user,
65
+ collaboratorsById: state.collaboratorsById,
66
+ }));
67
+ const authorID = getAuthorID(comment);
68
+ const authorName = authorID
69
+ ? buildAuthorName(collaboratorsById.get(authorID))
70
+ : '';
71
+ const timestamp = comment.node.attrs.contributions?.[0].timestamp;
72
+ const isOwn = authorID === user._id;
73
+ const isResolveEnabled = isOwn
74
+ ? can.resolveOwnComment
75
+ : can.resolveOthersComment;
76
+ const isActionsEnabled = isOwn
77
+ ? can.handleOwnComments
78
+ : can.handleOthersComments;
79
+ const [isEditing, setEditing] = useState(isNew);
80
+ const [showDeleteConfirmation, setShowDeleteConfirmation] = useState(false);
81
+ const handleEdit = () => {
82
+ setEditing(true);
83
+ onSelect();
84
+ };
85
+ const handleSave = (contents) => {
86
+ onSave({
87
+ ...comment.node.attrs,
88
+ contents,
89
+ });
90
+ setEditing(false);
91
+ };
92
+ const handleCancel = () => {
93
+ setEditing(false);
94
+ if (isNew) {
95
+ onDelete(comment.node.attrs.id);
96
+ }
97
+ };
98
+ const handleToggleResolve = () => {
99
+ onSave({
100
+ ...comment.node.attrs,
101
+ resolved: !comment.node.attrs.resolved,
102
+ });
103
+ };
104
+ const handleDelete = () => {
105
+ setShowDeleteConfirmation(true);
106
+ };
107
+ const confirmDelete = () => {
108
+ onDelete(comment.node.attrs.id);
109
+ setShowDeleteConfirmation(false);
110
+ };
111
+ const cancelDelete = () => {
112
+ setShowDeleteConfirmation(false);
113
+ };
114
+ return (React.createElement(Card, null,
115
+ React.createElement(CommentHeader, { "data-cy": "comment-header" },
116
+ React.createElement(CommentMetadata, null,
117
+ React.createElement(CommentAuthor, null, authorName ? (React.createElement(React.Fragment, null,
118
+ React.createElement(AvatarIcon, { width: 20, height: 20 }),
119
+ React.createElement(CommentAuthor, null, authorName))) : (!isReply && (React.createElement(React.Fragment, null,
120
+ React.createElement(SystemUserAvatarIcon, { width: 20, height: 20 }),
121
+ React.createElement(CommentAuthor, null, "System"))))),
122
+ timestamp && React.createElement(Timestamp, { date: timestamp * 1000 }),
123
+ numOfReplies !== 0 && React.createElement(RepliesCount, null,
124
+ " ",
125
+ numOfReplies,
126
+ " ")),
127
+ React.createElement(CommentActions, { comment: comment, isResolveEnabled: isResolveEnabled && !isReply, isActionsEnabled: isActionsEnabled && isEndOfThread, onDelete: handleDelete, onEdit: handleEdit, toggleResolve: handleToggleResolve })),
128
+ comment.node.attrs.originalText && (React.createElement(CommentTarget, null, comment.node.attrs.originalText)),
129
+ React.createElement(CommentBody, { comment: comment, isEditing: isNew || isEditing, onSave: handleSave, onCancel: handleCancel, onSelect: onSelect }),
130
+ showDeleteConfirmation && (React.createElement(DeleteCommentConfirmation, { onCancel: cancelDelete, onConfirm: confirmDelete }))));
131
+ };
132
+ //# 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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"}
@@ -19,7 +19,7 @@ const Button = styled.button `
19
19
  height: 24px;
20
20
  border-radius: 12px;
21
21
  border: none;
22
- background: #ffffff;
22
+ background: none;
23
23
  padding: 0;
24
24
  cursor: pointer;
25
25
 
@@ -1,105 +1,93 @@
1
- import { AvatarIcon, RelativeDate, SystemUserAvatarIcon, usePermissions, } from '@manuscripts/style-guide';
2
- import React, { forwardRef, useState } from 'react';
1
+ import { TextButton } from '@manuscripts/style-guide';
2
+ import React, { forwardRef, useEffect, useRef, useState } from 'react';
3
3
  import styled from 'styled-components';
4
- import { buildAuthorName, getAuthorID } from '../../lib/comments';
5
- import { useStore } from '../../store';
6
- import { CommentActions } from './CommentActions';
7
- import { CommentBody } from './CommentBody';
4
+ import { commentsByTime } from '../../lib/comments';
5
+ import { CommentCard } from './CommentCard';
6
+ import { ReplyBox } from './ReplyBox';
8
7
  const Container = styled.div `
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;
8
+ padding: 8px;
9
+ background-color: ${(props) => (props.isSelected ? '#fff' : '#fafafa')};
10
+ border: 1px solid #c9c9c9;
11
+ ${(props) => props.isSelected && 'border-left-width: 4px'};
12
+ border-radius: 4px;
13
13
  margin-bottom: 16px;
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%;
14
+ margin-left: 12px;
15
+ margin-right: 12px;
33
16
 
34
- svg {
35
- padding-right: 10px;
17
+ .actions-icon {
18
+ visibility: ${(props) => (props.isSelected ? 'visible' : 'hidden')};
19
+ }
20
+
21
+ &:hover {
22
+ background-color: #fff;
23
+
24
+ .actions-icon {
25
+ visibility: visible;
26
+ }
36
27
  }
37
28
  `;
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;
29
+ const SeparatorLine = styled.div `
30
+ margin-bottom: 8px;
31
+ background-color: #c9c9c9;
32
+ height: 1px;
45
33
  `;
46
- const Timestamp = styled(RelativeDate) `
47
- font-size: 12px;
48
- line-height: 16px;
49
- font-weight: 400;
50
- color: #6e6e6e;
34
+ const Indented = styled.div `
35
+ padding-left: 16px;
51
36
  `;
52
37
  export const CommentThread = forwardRef((props, ref) => {
53
- const { tree, isSelected, onSelect, onSave, onDelete } = props;
54
- const can = usePermissions();
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);
38
+ const { thread, isSelected, onSelect, onSave, onDelete, insertCommentReply, } = props;
39
+ const { comment, isNew, replies } = thread;
40
+ const cardsRef = useRef(null);
41
+ const [showMore, setShowMore] = useState(false);
42
+ useEffect(() => {
43
+ if (cardsRef.current) {
44
+ const contentHeight = cardsRef.current.scrollHeight;
45
+ setShowMore(contentHeight > 280);
84
46
  }
85
- };
86
- const handleToggleResolve = () => {
87
- onSave({
88
- ...tree.comment.node.attrs,
89
- resolved: !tree.comment.node.attrs.resolved,
90
- });
91
- };
47
+ }, [comment, replies]);
92
48
  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 })));
49
+ React.createElement(CardsWrapper, { ref: cardsRef, isSelected: isSelected, showMore: showMore },
50
+ React.createElement(CommentCard, { comment: comment, isReply: false, numOfReplies: replies.length, isNew: isNew, isEndOfThread: !replies.length, onDelete: onDelete, onSave: onSave, onSelect: onSelect }),
51
+ replies.sort(commentsByTime).map((reply, index) => {
52
+ return (React.createElement("div", { key: reply.node.attrs.id },
53
+ index === 0 && React.createElement(SeparatorLine, null),
54
+ React.createElement(Indented, null,
55
+ index !== 0 && React.createElement(SeparatorLine, null),
56
+ React.createElement(CommentCard, { comment: reply, isReply: true, numOfReplies: 0, isNew: false, isEndOfThread: index === replies.length - 1, onDelete: onDelete, onSave: onSave, onSelect: onSelect }))));
57
+ })),
58
+ showMore && !isSelected && (React.createElement(React.Fragment, null,
59
+ React.createElement(SeparatorLine, null),
60
+ React.createElement(ButtonContainer, null,
61
+ React.createElement(ShowMore, { onClick: onSelect }, "Show more")))),
62
+ isSelected && !isNew && (React.createElement(ReplyBox, { insertCommentReply: insertCommentReply, commentId: comment.node.attrs.id }))));
104
63
  });
64
+ const ButtonContainer = styled.div `
65
+ display: flex;
66
+ justify-content: center;
67
+ align-items: center;
68
+ `;
69
+ const ShowMore = styled(TextButton) `
70
+ cursor: pointer;
71
+ text-align: center;
72
+ margin-top: 6px;
73
+ color: #353535;
74
+ `;
75
+ const CardsWrapper = styled.div `
76
+ max-height: ${({ isSelected }) => (isSelected ? 'none' : '280px')};
77
+ position: relative;
78
+ ${({ showMore, isSelected }) => showMore &&
79
+ !isSelected &&
80
+ `
81
+ overflow: hidden;
82
+ &:after {
83
+ content: '';
84
+ position: absolute;
85
+ bottom: 0;
86
+ left: 0;
87
+ right: 0;
88
+ height: 40px;
89
+ background: linear-gradient(to bottom, rgba(255, 255, 255, 0), rgba(255, 255, 255, 1));
90
+ }
91
+ `}
92
+ `;
105
93
  //# sourceMappingURL=CommentThread.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"CommentThread.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentThread.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"CommentThread.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentThread.tsx"],"names":[],"mappings":"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"}