@manuscripts/article-editor 3.4.3-LEAN-4053.2 → 3.4.3-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 (49) hide show
  1. package/dist/cjs/components/comments/CommentActions.js +11 -7
  2. package/dist/cjs/components/comments/CommentActions.js.map +1 -1
  3. package/dist/cjs/components/comments/CommentBody.js +10 -6
  4. package/dist/cjs/components/comments/CommentBody.js.map +1 -1
  5. package/dist/cjs/components/comments/CommentCard.js +165 -0
  6. package/dist/cjs/components/comments/CommentCard.js.map +1 -0
  7. package/dist/cjs/components/comments/CommentResolveButton.js +1 -1
  8. package/dist/cjs/components/comments/CommentThread.js +83 -88
  9. package/dist/cjs/components/comments/CommentThread.js.map +1 -1
  10. package/dist/cjs/components/comments/CommentsPanel.js +33 -10
  11. package/dist/cjs/components/comments/CommentsPanel.js.map +1 -1
  12. package/dist/cjs/components/comments/DeleteCommentConfirmation.js +115 -0
  13. package/dist/cjs/components/comments/DeleteCommentConfirmation.js.map +1 -0
  14. package/dist/cjs/components/comments/ReplyBox.js +121 -0
  15. package/dist/cjs/components/comments/ReplyBox.js.map +1 -0
  16. package/dist/cjs/lib/change-handlers.js +2 -2
  17. package/dist/cjs/lib/change-handlers.js.map +1 -1
  18. package/dist/cjs/lib/comments.js +26 -5
  19. package/dist/cjs/lib/comments.js.map +1 -1
  20. package/dist/cjs/lib/node-content-retriever.js +24 -17
  21. package/dist/cjs/lib/node-content-retriever.js.map +1 -1
  22. package/dist/es/components/comments/CommentActions.js +11 -7
  23. package/dist/es/components/comments/CommentActions.js.map +1 -1
  24. package/dist/es/components/comments/CommentBody.js +11 -7
  25. package/dist/es/components/comments/CommentBody.js.map +1 -1
  26. package/dist/es/components/comments/CommentCard.js +135 -0
  27. package/dist/es/components/comments/CommentCard.js.map +1 -0
  28. package/dist/es/components/comments/CommentResolveButton.js +1 -1
  29. package/dist/es/components/comments/CommentThread.js +86 -91
  30. package/dist/es/components/comments/CommentThread.js.map +1 -1
  31. package/dist/es/components/comments/CommentsPanel.js +35 -12
  32. package/dist/es/components/comments/CommentsPanel.js.map +1 -1
  33. package/dist/es/components/comments/DeleteCommentConfirmation.js +85 -0
  34. package/dist/es/components/comments/DeleteCommentConfirmation.js.map +1 -0
  35. package/dist/es/components/comments/ReplyBox.js +91 -0
  36. package/dist/es/components/comments/ReplyBox.js.map +1 -0
  37. package/dist/es/lib/change-handlers.js +2 -2
  38. package/dist/es/lib/change-handlers.js.map +1 -1
  39. package/dist/es/lib/comments.js +23 -3
  40. package/dist/es/lib/comments.js.map +1 -1
  41. package/dist/es/lib/node-content-retriever.js +25 -18
  42. package/dist/es/lib/node-content-retriever.js.map +1 -1
  43. package/dist/types/components/comments/CommentCard.d.ts +27 -0
  44. package/dist/types/components/comments/CommentThread.d.ts +3 -2
  45. package/dist/types/components/comments/DeleteCommentConfirmation.d.ts +19 -0
  46. package/dist/types/components/comments/ReplyBox.d.ts +18 -0
  47. package/dist/types/lib/comments.d.ts +4 -3
  48. package/dist/types/lib/node-content-retriever.d.ts +6 -2
  49. package/package.json +4 -4
@@ -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: 16px;
38
+ font-size: 14px;
39
39
  line-height: 24px;
40
40
  color: ${(props) => props.theme.colors.text.primary};
41
- padding: 16px;
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(react_1.default.Fragment, null,
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: 125, onClick: toggleOpen },
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;QACG,gBAAgB,IAAI,CACnB,8BAAC,2CAAoB,IAAC,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,aAAa,GAAI,CACnE;QACA,gBAAgB,IAAI,CACnB,8BAAC,+BAAiB,IAAC,GAAG,EAAE,UAAU;YAChC,8BAAC,mBAAW,eAAS,0BAA0B,EAAC,OAAO,EAAE,UAAU;gBACjE,8BAAC,sBAAQ,OAAG,CACA;YACb,MAAM,IAAI,CACT,8BAAC,0BAAY,eACH,kBAAkB,EAC1B,SAAS,EAAE,OAAO,EAClB,KAAK,EAAE,GAAG,EACV,OAAO,EAAE,UAAU;gBAEnB,8BAAC,qBAAa,eAAS,cAAc,EAAC,OAAO,EAAE,MAAM,WAErC;gBAChB,8BAAC,qBAAa,eAAS,gBAAgB,EAAC,OAAO,EAAE,QAAQ,aAEzC,CACH,CAChB,CACiB,CACrB,CACA,CACJ,CAAA;AACH,CAAC,CAAA;AAvCY,QAAA,cAAc,kBAuC1B"}
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,11 +64,19 @@ 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
81
  const CommentBody = ({ comment, isEditing, onSave, onCancel, onSelect, }) => {
77
82
  const editor = (0, react_1.useRef)(null);
@@ -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.SecondaryButton, { onClick: onCancel }, "Cancel"),
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(CommentContent, { onClick: onSelect },
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,cAAc,GAAG,2BAAM,CAAC,GAAG,CAAA;;CAEhC,CAAA;AAED,MAAM,aAAa,GAAG,2BAAM,CAAC,QAAQ,CAAA;;iBAEpB,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI;WAC7C,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO;YACzC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC;;;;;;;;;;;;;;;;;;;;CAoB/C,CAAA;AAED,MAAM,aAAa,GAAG,2BAAM,CAAC,GAAG,CAAA;;;iBAGf,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI;;;WAG7C,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO;YACzC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC;CAC/C,CAAA;AAED,MAAM,aAAa,GAAG,IAAA,2BAAM,EAAC,yBAAW,CAAC,CAAA;;;;CAIxC,CAAA;AAUM,MAAM,WAAW,GAA+B,CAAC,EACtD,OAAO,EACP,SAAS,EACT,MAAM,EACN,QAAQ,EACR,QAAQ,GACT,EAAE,EAAE;IACH,MAAM,MAAM,GAAG,IAAA,cAAM,EAA6B,IAAI,CAAC,CAAA;IACvD,MAAM,UAAU,GAAG,GAAG,EAAE;QACtB,IAAI,MAAM,CAAC,OAAO,EAAE;YAClB,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;SAC7B;IACH,CAAC,CAAA;IAED,MAAM,GAAG,GAAG,IAAA,mBAAW,EAAC,CAAC,CAA6B,EAAE,EAAE;QACxD,IAAI,CAAC,IAAI,MAAM,CAAC,OAAO,KAAK,CAAC,EAAE;YAC7B,CAAC,CAAC,KAAK,EAAE,CAAA;SACV;QACD,MAAM,CAAC,OAAO,GAAG,CAAC,CAAA;IACpB,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,IAAA,gBAAQ,EAAC,MAAM,CAAC,OAAO,EAAE,KAAK,IAAI,EAAE,CAAC,CAAA;IAE/D,MAAM,iBAAiB,GAAG,IAAA,eAAO,EAC/B,GAAG,EAAE,CAAC,CAAC,KAAK,CAAC,MAAM,IAAI,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,KAAK,KAAK,EAC5D,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,CACrC,CAAA;IACD,MAAM,YAAY,GAAG,CAAC,CAAmC,EAAE,EAAE,CAC3D,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;IAE1B,OAAO,CACL,8DACG,SAAS,CAAC,CAAC,CAAC,CACX;QACE,8BAAC,aAAa,eACJ,gBAAgB,EACxB,GAAG,EAAE,GAAG,EACR,YAAY,EAAE,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,EACzC,QAAQ,EAAE,YAAY,EACtB,MAAM,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,IAAI,QAAQ,EAAE,GAC5C;QACjB,8BAAC,aAAa,eAAS,iBAAiB;YACtC,8BAAC,6BAAe,IAAC,OAAO,EAAE,QAAQ,aAA0B;YAC5D,8BAAC,2BAAa,IAAC,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,iBAAiB,WAE/C,CACF,CACf,CACJ,CAAC,CAAC,CAAC,CACF;QACE,8BAAC,cAAc,IAAC,OAAO,EAAE,QAAQ;YAC/B,8BAAC,aAAa,eAAS,cAAc,IAClC,IAAA,0BAAkB,EAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAClC,CACD,CAChB,CACJ,CACA,CACJ,CAAA;AACH,CAAC,CAAA;AA3DY,QAAA,WAAW,eA2DvB"}
1
+ {"version":3,"file":"CommentBody.js","sourceRoot":"","sources":["../../../../src/components/comments/CommentBody.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,165 @@
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, onSelect, }) => {
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
+ onSelect();
115
+ };
116
+ const handleSave = (contents) => {
117
+ onSave({
118
+ ...comment.node.attrs,
119
+ contents,
120
+ });
121
+ setEditingCommentId(null);
122
+ };
123
+ const handleCancel = () => {
124
+ setEditingCommentId(null);
125
+ if (isNew) {
126
+ onDelete(commentID);
127
+ }
128
+ };
129
+ const handleToggleResolve = () => {
130
+ onSave({
131
+ ...comment.node.attrs,
132
+ resolved: !comment.node.attrs.resolved,
133
+ });
134
+ };
135
+ const handleDelete = () => {
136
+ setShowDeleteConfirmation(true);
137
+ onSelect();
138
+ };
139
+ const confirmDelete = () => {
140
+ onDelete(commentID);
141
+ setShowDeleteConfirmation(false);
142
+ };
143
+ const cancelDelete = () => {
144
+ setShowDeleteConfirmation(false);
145
+ };
146
+ return (react_1.default.createElement(Card, null,
147
+ react_1.default.createElement(CommentHeader, { "data-cy": "comment-header" },
148
+ react_1.default.createElement(CommentMetadata, null,
149
+ react_1.default.createElement(AuthorContainer, null, authorName ? (react_1.default.createElement(react_1.default.Fragment, null,
150
+ react_1.default.createElement(style_guide_1.AvatarIcon, { width: 20, height: 20 }),
151
+ react_1.default.createElement(react_1.default.Fragment, null, authorName))) : (!isReply && (react_1.default.createElement(react_1.default.Fragment, null,
152
+ react_1.default.createElement(style_guide_1.SystemUserAvatarIcon, { width: 20, height: 20 }),
153
+ react_1.default.createElement(react_1.default.Fragment, null, "System"))))),
154
+ timestamp && react_1.default.createElement(Timestamp, { date: timestamp * 1000 }),
155
+ numOfReplies !== 0 && react_1.default.createElement(RepliesCount, null,
156
+ " ",
157
+ numOfReplies,
158
+ " ")),
159
+ react_1.default.createElement(CommentActions_1.CommentActions, { comment: comment, isResolveEnabled: isResolveEnabled && !isReply, isActionsEnabled: isActionsEnabled && isEndOfThread, onDelete: handleDelete, onEdit: handleEdit, toggleResolve: handleToggleResolve })),
160
+ comment.node.attrs.originalText && (react_1.default.createElement(CommentTarget, null, comment.node.attrs.originalText)),
161
+ react_1.default.createElement(CommentBody_1.CommentBody, { comment: comment, isEditing: editingCommentId === commentID, onSave: handleSave, onCancel: handleCancel, onSelect: onSelect }),
162
+ showDeleteConfirmation && (react_1.default.createElement(DeleteCommentConfirmation_1.DeleteCommentConfirmation, { isReply: isReply, onCancel: cancelDelete, onConfirm: confirmDelete }))));
163
+ };
164
+ exports.CommentCard = CommentCard;
165
+ //# 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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"}
@@ -25,7 +25,7 @@ const Button = styled_components_1.default.button `
25
25
  height: 24px;
26
26
  border-radius: 12px;
27
27
  border: none;
28
- background: #ffffff;
28
+ background: none;
29
29
  padding: 0;
30
30
  cursor: pointer;
31
31
 
@@ -31,104 +31,99 @@ 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 store_1 = require("../../store");
35
- const CommentActions_1 = require("./CommentActions");
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: 16px;
39
- background-color: ${(props) => (props.isSelected ? '#f2fbfc' : '#ffffff')};
40
- border: 1px solid ${(props) => (props.isSelected ? '#bce7f6' : '#e2e2e2')};
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
- const CommentHeader = styled_components_1.default.div `
45
- display: flex;
46
- margin-bottom: 16px;
47
- `;
48
- const CommentMetadata = styled_components_1.default.div `
49
- flex: 1;
50
- padding-left: 8px;
51
- padding-right: 8px;
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
- svg {
64
- padding-right: 10px;
53
+ .actions-icon {
54
+ visibility: visible;
55
+ }
65
56
  }
66
57
  `;
67
- const CommentTarget = styled_components_1.default.div `
68
- font-size: 14px;
69
- color: #353535;
70
- background-color: #ffeebf;
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 Timestamp = (0, styled_components_1.default)(style_guide_1.RelativeDate) `
76
- font-size: 12px;
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 { tree, isSelected, onSelect, onSave, onDelete } = props;
67
+ const { thread, isSelected, onSelect, onSave, onDelete, insertCommentReply, } = props;
83
68
  const can = (0, style_guide_1.usePermissions)();
84
- const [{ user, collaboratorsById }] = (0, store_1.useStore)((state) => ({
85
- user: state.user,
86
- collaboratorsById: state.collaboratorsById,
87
- }));
88
- const authorID = (0, comments_1.getAuthorID)(tree.comment);
89
- const authorName = authorID
90
- ? (0, comments_1.buildAuthorName)(collaboratorsById.get(authorID))
91
- : '';
92
- const timestamp = tree.comment.node.attrs.contributions?.[0].timestamp;
93
- const isOwn = authorID === user._id;
94
- const isResolveEnabled = isOwn
95
- ? can.resolveOwnComment
96
- : can.resolveOthersComment;
97
- const isActionsEnabled = isOwn
98
- ? can.handleOwnComments
99
- : can.handleOthersComments;
100
- const [isEditing, setEditing] = (0, react_1.useState)(tree.isNew);
101
- const handleEdit = () => setEditing(true);
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 (cardsRef.current) {
75
+ const contentHeight = cardsRef.current.scrollHeight;
76
+ setShowMore(contentHeight > 280);
77
+ }
78
+ }, [comment, replies]);
79
+ const handleSelect = () => {
80
+ if (!isSelected) {
81
+ onSelect();
113
82
  }
114
83
  };
115
- const handleToggleResolve = () => {
116
- onSave({
117
- ...tree.comment.node.attrs,
118
- resolved: !tree.comment.node.attrs.resolved,
119
- });
120
- };
121
- return (react_1.default.createElement(Container, { "data-cy": "comment", isSelected: isSelected, ref: ref },
122
- react_1.default.createElement(CommentHeader, { "data-cy": "comment-header" },
123
- react_1.default.createElement(CommentMetadata, null,
124
- react_1.default.createElement(CommentAuthor, null, authorName ? (react_1.default.createElement(react_1.default.Fragment, null,
125
- react_1.default.createElement(style_guide_1.AvatarIcon, { width: 20, height: 20 }),
126
- react_1.default.createElement(CommentAuthor, null, authorName))) : (react_1.default.createElement(react_1.default.Fragment, null,
127
- react_1.default.createElement(style_guide_1.SystemUserAvatarIcon, { width: 20, height: 20 }),
128
- react_1.default.createElement(CommentAuthor, null, "System")))),
129
- timestamp && react_1.default.createElement(Timestamp, { date: timestamp * 1000 })),
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 })));
84
+ return (react_1.default.createElement(Container, { "data-cy": "comment", isSelected: isSelected, ref: ref, onClick: handleSelect },
85
+ react_1.default.createElement(CardsWrapper, { ref: cardsRef, isSelected: isSelected, showMore: showMore },
86
+ 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, onSelect: onSelect }),
87
+ replies.sort(comments_1.commentsByTime).map((reply, index) => {
88
+ return (react_1.default.createElement("div", { key: reply.node.attrs.id },
89
+ index === 0 && react_1.default.createElement(SeparatorLine, null),
90
+ react_1.default.createElement(Indented, null,
91
+ index !== 0 && react_1.default.createElement(SeparatorLine, null),
92
+ 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, onSelect: onSelect }))));
93
+ })),
94
+ showMore && !isSelected && (react_1.default.createElement(react_1.default.Fragment, null,
95
+ react_1.default.createElement(SeparatorLine, null),
96
+ react_1.default.createElement(ButtonContainer, null,
97
+ react_1.default.createElement(ShowMore, { onClick: onSelect }, "Show more")))),
98
+ can.createComment && isSelected && editingCommentId === null && (react_1.default.createElement(ReplyBox_1.ReplyBox, { insertCommentReply: insertCommentReply, commentID: comment.node.attrs.id }))));
133
99
  });
100
+ const ButtonContainer = styled_components_1.default.div `
101
+ display: flex;
102
+ justify-content: center;
103
+ align-items: center;
104
+ `;
105
+ const ShowMore = (0, styled_components_1.default)(style_guide_1.TextButton) `
106
+ cursor: pointer;
107
+ text-align: center;
108
+ margin-top: 6px;
109
+ color: #353535;
110
+ `;
111
+ const CardsWrapper = styled_components_1.default.div `
112
+ max-height: ${({ isSelected }) => (isSelected ? 'none' : '280px')};
113
+ position: relative;
114
+ ${({ showMore, isSelected }) => showMore &&
115
+ !isSelected &&
116
+ `
117
+ overflow: hidden;
118
+ &:after {
119
+ content: '';
120
+ position: absolute;
121
+ bottom: 0;
122
+ left: 0;
123
+ right: 0;
124
+ height: 40px;
125
+ background: linear-gradient(to bottom, rgba(255, 255, 255, 0), rgba(255, 255, 255, 1));
126
+ }
127
+ `}
128
+ `;
134
129
  //# 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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"}
@@ -39,9 +39,12 @@ exports.CommentsPanel = void 0;
39
39
  * All portions of the code written by Atypon Systems LLC are Copyright (c) 2019 Atypon Systems LLC. All Rights Reserved.
40
40
  */
41
41
  const body_editor_1 = require("@manuscripts/body-editor");
42
+ const json_schema_1 = require("@manuscripts/json-schema");
42
43
  const style_guide_1 = require("@manuscripts/style-guide");
43
44
  const track_changes_plugin_1 = require("@manuscripts/track-changes-plugin");
45
+ const transform_1 = require("@manuscripts/transform");
44
46
  const prosemirror_state_1 = require("prosemirror-state");
47
+ const prosemirror_utils_1 = require("prosemirror-utils");
45
48
  const react_1 = __importStar(require("react"));
46
49
  const styled_components_1 = __importDefault(require("styled-components"));
47
50
  const comments_1 = require("../../lib/comments");
@@ -63,14 +66,17 @@ const scrollIntoView = (element) => {
63
66
  }
64
67
  };
65
68
  const CommentsPanel = () => {
66
- const [{ view, newCommentID, selectedCommentKey }] = (0, store_1.useStore)((state) => ({
69
+ const [{ view, newCommentID, selectedCommentKey, user, doc }] = (0, store_1.useStore)((state) => ({
67
70
  view: state.view,
71
+ doc: state.doc,
68
72
  newCommentID: state.newCommentID,
69
73
  selectedCommentKey: state.selectedCommentKey,
74
+ user: state.user,
70
75
  }));
71
76
  const [showResolved, setShowResolved] = (0, react_1.useState)(true);
72
- const comments = (0, react_1.useMemo)(() => view?.state ? body_editor_1.commentsKey.getState(view.state)?.comments : undefined, [view?.state]);
73
- const trees = (0, react_1.useMemo)(() => comments ? (0, comments_1.buildCommentTrees)([...comments.values()], newCommentID) : [], [comments, newCommentID]);
77
+ const comments = (0, react_1.useMemo)(() => view?.state ? body_editor_1.commentsKey.getState(view.state)?.comments : undefined, [view?.state, doc] // eslint-disable-line react-hooks/exhaustive-deps
78
+ );
79
+ const threads = (0, react_1.useMemo)(() => (comments ? (0, comments_1.buildThreads)([...comments.values()], newCommentID) : []), [comments, newCommentID]);
74
80
  const selectedRef = (0, react_1.useCallback)((e) => {
75
81
  if (e) {
76
82
  scrollIntoView(e);
@@ -95,6 +101,25 @@ const CommentsPanel = () => {
95
101
  view.focus();
96
102
  view.dispatch(tr);
97
103
  };
104
+ const insertCommentReply = (target, contents) => {
105
+ if (!view) {
106
+ return;
107
+ }
108
+ const attrs = {
109
+ id: (0, transform_1.generateNodeID)(transform_1.schema.nodes.comment),
110
+ contents,
111
+ target,
112
+ contributions: [(0, json_schema_1.buildContribution)(user._id)],
113
+ resolved: false,
114
+ };
115
+ const comment = view.state.schema.nodes.comment.create(attrs);
116
+ const comments = (0, prosemirror_utils_1.findChildrenByType)(view.state.doc, view.state.schema.nodes.comments)[0];
117
+ if (comments) {
118
+ const pos = comments.pos + 1;
119
+ const tr = view.state.tr.insert(pos, comment);
120
+ view.dispatch((0, track_changes_plugin_1.skipTracking)(tr));
121
+ }
122
+ };
98
123
  const handleSave = (attrs) => {
99
124
  const comment = comments?.get(attrs.id);
100
125
  if (!comment || !view) {
@@ -102,7 +127,6 @@ const CommentsPanel = () => {
102
127
  }
103
128
  const tr = view.state.tr;
104
129
  tr.setNodeMarkup(comment.pos, undefined, attrs);
105
- (0, body_editor_1.clearCommentSelection)(tr);
106
130
  view.dispatch((0, track_changes_plugin_1.skipTracking)(tr));
107
131
  };
108
132
  const handleDelete = (id) => {
@@ -112,16 +136,15 @@ const CommentsPanel = () => {
112
136
  }
113
137
  const tr = view.state.tr;
114
138
  tr.delete(comment.pos, comment.pos + comment.node.nodeSize);
115
- (0, body_editor_1.clearCommentSelection)(tr);
116
139
  view.dispatch((0, track_changes_plugin_1.skipTracking)(tr));
117
140
  };
118
- const isSelected = (tree) => {
119
- return tree && selectedCommentKey === tree.comment.key;
141
+ const isSelected = (thread) => {
142
+ return thread && selectedCommentKey === thread.comment.key;
120
143
  };
121
144
  if (!view) {
122
145
  return null;
123
146
  }
124
- if (!trees.length) {
147
+ if (!threads.length) {
125
148
  return react_1.default.createElement(CommentsPlaceholder_1.CommentsPlaceholder, null);
126
149
  }
127
150
  return (react_1.default.createElement(react_1.default.Fragment, null,
@@ -129,9 +152,9 @@ const CommentsPanel = () => {
129
152
  react_1.default.createElement(style_guide_1.CheckboxLabel, null,
130
153
  react_1.default.createElement(style_guide_1.CheckboxField, { name: 'show-resolved', checked: showResolved, onChange: (e) => setShowResolved(e.target.checked) }),
131
154
  react_1.default.createElement(CheckboxLabelText, null, "See resolved"))),
132
- trees
155
+ threads
133
156
  .filter((c) => showResolved || !c.comment.node.attrs.resolved)
134
- .map((c, i, a) => (react_1.default.createElement(CommentThread_1.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 })))));
157
+ .map((c, i, a) => (react_1.default.createElement(CommentThread_1.CommentThread, { key: c.comment.node.attrs.id, ref: isSelected(c) && !isSelected(a[i - 1]) ? selectedRef : null, thread: c, isSelected: isSelected(c), onSelect: () => setSelectedComment(c.comment), onSave: handleSave, onDelete: handleDelete, insertCommentReply: insertCommentReply })))));
135
158
  };
136
159
  exports.CommentsPanel = CommentsPanel;
137
160
  //# sourceMappingURL=CommentsPanel.js.map