@selfcommunity/react-ui 0.7.0-alpha.80 → 0.7.0-alpha.82

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 (226) hide show
  1. package/lib/cjs/components/{MessageEditor → PrivateMessageEditor}/MessageMediaUploader/index.d.ts +0 -0
  2. package/lib/cjs/components/PrivateMessageEditor/MessageMediaUploader/index.d.ts.map +1 -0
  3. package/lib/cjs/components/{MessageEditor → PrivateMessageEditor}/MessageMediaUploader/index.js +6 -51
  4. package/lib/cjs/components/PrivateMessageEditor/MessageMediaUploader/index.js.map +1 -0
  5. package/lib/cjs/components/PrivateMessageEditor/PrivateMessageEditor.d.ts +48 -0
  6. package/lib/cjs/components/PrivateMessageEditor/PrivateMessageEditor.d.ts.map +1 -0
  7. package/lib/cjs/components/{MessageEditor/MessageEditor.js → PrivateMessageEditor/PrivateMessageEditor.js} +41 -64
  8. package/lib/cjs/components/PrivateMessageEditor/PrivateMessageEditor.js.map +1 -0
  9. package/lib/{esm/components/MessageEditor → cjs/components/PrivateMessageEditor}/Skeleton.d.ts +2 -2
  10. package/lib/cjs/components/PrivateMessageEditor/Skeleton.d.ts.map +1 -0
  11. package/lib/cjs/components/{MessageEditor → PrivateMessageEditor}/Skeleton.js +3 -3
  12. package/lib/cjs/components/PrivateMessageEditor/Skeleton.js.map +1 -0
  13. package/lib/cjs/components/PrivateMessageEditor/index.d.ts +5 -0
  14. package/lib/cjs/components/PrivateMessageEditor/index.d.ts.map +1 -0
  15. package/lib/cjs/components/{Message → PrivateMessageEditor}/index.js +4 -4
  16. package/lib/cjs/components/PrivateMessageEditor/index.js.map +1 -0
  17. package/lib/cjs/components/PrivateMessageSnippetItem/PrivateMessageSnippetItem.d.ts +58 -0
  18. package/lib/cjs/components/PrivateMessageSnippetItem/PrivateMessageSnippetItem.d.ts.map +1 -0
  19. package/lib/cjs/components/PrivateMessageSnippetItem/PrivateMessageSnippetItem.js +162 -0
  20. package/lib/cjs/components/PrivateMessageSnippetItem/PrivateMessageSnippetItem.js.map +1 -0
  21. package/lib/cjs/components/PrivateMessageSnippetItem/Skeleton.d.ts +23 -0
  22. package/lib/cjs/components/PrivateMessageSnippetItem/Skeleton.d.ts.map +1 -0
  23. package/lib/cjs/components/PrivateMessageSnippetItem/Skeleton.js +54 -0
  24. package/lib/cjs/components/PrivateMessageSnippetItem/Skeleton.js.map +1 -0
  25. package/lib/cjs/components/PrivateMessageSnippetItem/index.d.ts +5 -0
  26. package/lib/cjs/components/PrivateMessageSnippetItem/index.d.ts.map +1 -0
  27. package/lib/cjs/components/PrivateMessageSnippetItem/index.js +11 -0
  28. package/lib/cjs/components/PrivateMessageSnippetItem/index.js.map +1 -0
  29. package/lib/cjs/components/PrivateMessageSnippets/PrivateMessageSnippets.d.ts +75 -0
  30. package/lib/cjs/components/PrivateMessageSnippets/PrivateMessageSnippets.d.ts.map +1 -0
  31. package/lib/cjs/components/PrivateMessageSnippets/PrivateMessageSnippets.js +281 -0
  32. package/lib/cjs/components/PrivateMessageSnippets/PrivateMessageSnippets.js.map +1 -0
  33. package/lib/cjs/components/PrivateMessageSnippets/Skeleton.d.ts +23 -0
  34. package/lib/cjs/components/PrivateMessageSnippets/Skeleton.d.ts.map +1 -0
  35. package/lib/cjs/components/{Snippets → PrivateMessageSnippets}/Skeleton.js +9 -9
  36. package/lib/cjs/components/PrivateMessageSnippets/Skeleton.js.map +1 -0
  37. package/lib/cjs/components/PrivateMessageSnippets/index.d.ts +5 -0
  38. package/lib/cjs/components/PrivateMessageSnippets/index.d.ts.map +1 -0
  39. package/lib/cjs/components/PrivateMessageSnippets/index.js +11 -0
  40. package/lib/cjs/components/PrivateMessageSnippets/index.js.map +1 -0
  41. package/lib/cjs/components/PrivateMessageThread/PrivateMessageThread.d.ts +84 -0
  42. package/lib/cjs/components/PrivateMessageThread/PrivateMessageThread.d.ts.map +1 -0
  43. package/lib/cjs/components/{Thread/Thread.js → PrivateMessageThread/PrivateMessageThread.js} +102 -193
  44. package/lib/cjs/components/PrivateMessageThread/PrivateMessageThread.js.map +1 -0
  45. package/lib/cjs/components/PrivateMessageThread/Skeleton.d.ts +23 -0
  46. package/lib/cjs/components/PrivateMessageThread/Skeleton.d.ts.map +1 -0
  47. package/lib/cjs/components/{Thread → PrivateMessageThread}/Skeleton.js +8 -8
  48. package/lib/cjs/components/PrivateMessageThread/Skeleton.js.map +1 -0
  49. package/lib/cjs/components/PrivateMessageThread/index.d.ts +5 -0
  50. package/lib/cjs/components/PrivateMessageThread/index.d.ts.map +1 -0
  51. package/lib/cjs/components/{Thread → PrivateMessageThread}/index.js +4 -4
  52. package/lib/cjs/components/PrivateMessageThread/index.js.map +1 -0
  53. package/lib/cjs/components/PrivateMessageThreadItem/PrivateMessageThreadItem.d.ts +76 -0
  54. package/lib/cjs/components/PrivateMessageThreadItem/PrivateMessageThreadItem.d.ts.map +1 -0
  55. package/lib/cjs/components/PrivateMessageThreadItem/PrivateMessageThreadItem.js +169 -0
  56. package/lib/cjs/components/PrivateMessageThreadItem/PrivateMessageThreadItem.js.map +1 -0
  57. package/lib/cjs/components/PrivateMessageThreadItem/Skeleton.d.ts +23 -0
  58. package/lib/cjs/components/PrivateMessageThreadItem/Skeleton.d.ts.map +1 -0
  59. package/lib/cjs/components/{Message → PrivateMessageThreadItem}/Skeleton.js +8 -8
  60. package/lib/cjs/components/PrivateMessageThreadItem/Skeleton.js.map +1 -0
  61. package/lib/cjs/components/PrivateMessageThreadItem/index.d.ts +5 -0
  62. package/lib/cjs/components/PrivateMessageThreadItem/index.d.ts.map +1 -0
  63. package/lib/cjs/components/PrivateMessageThreadItem/index.js +11 -0
  64. package/lib/cjs/components/PrivateMessageThreadItem/index.js.map +1 -0
  65. package/lib/cjs/index.d.ts +6 -5
  66. package/lib/cjs/index.d.ts.map +1 -1
  67. package/lib/cjs/index.js +17 -14
  68. package/lib/cjs/index.js.map +1 -1
  69. package/lib/esm/components/{MessageEditor → PrivateMessageEditor}/MessageMediaUploader/index.d.ts +0 -0
  70. package/lib/esm/components/PrivateMessageEditor/MessageMediaUploader/index.d.ts.map +1 -0
  71. package/lib/esm/components/{MessageEditor → PrivateMessageEditor}/MessageMediaUploader/index.js +6 -51
  72. package/lib/esm/components/PrivateMessageEditor/MessageMediaUploader/index.js.map +1 -0
  73. package/lib/esm/components/PrivateMessageEditor/PrivateMessageEditor.d.ts +48 -0
  74. package/lib/esm/components/PrivateMessageEditor/PrivateMessageEditor.d.ts.map +1 -0
  75. package/lib/esm/components/{MessageEditor/MessageEditor.js → PrivateMessageEditor/PrivateMessageEditor.js} +42 -65
  76. package/lib/esm/components/PrivateMessageEditor/PrivateMessageEditor.js.map +1 -0
  77. package/lib/{cjs/components/MessageEditor → esm/components/PrivateMessageEditor}/Skeleton.d.ts +2 -2
  78. package/lib/esm/components/PrivateMessageEditor/Skeleton.d.ts.map +1 -0
  79. package/lib/esm/components/{MessageEditor → PrivateMessageEditor}/Skeleton.js +2 -2
  80. package/lib/esm/components/PrivateMessageEditor/Skeleton.js.map +1 -0
  81. package/lib/esm/components/PrivateMessageEditor/index.d.ts +5 -0
  82. package/lib/esm/components/PrivateMessageEditor/index.d.ts.map +1 -0
  83. package/lib/esm/components/PrivateMessageEditor/index.js +5 -0
  84. package/lib/esm/components/PrivateMessageEditor/index.js.map +1 -0
  85. package/lib/esm/components/PrivateMessageSnippetItem/PrivateMessageSnippetItem.d.ts +58 -0
  86. package/lib/esm/components/PrivateMessageSnippetItem/PrivateMessageSnippetItem.d.ts.map +1 -0
  87. package/lib/esm/components/PrivateMessageSnippetItem/PrivateMessageSnippetItem.js +133 -0
  88. package/lib/esm/components/PrivateMessageSnippetItem/PrivateMessageSnippetItem.js.map +1 -0
  89. package/lib/esm/components/PrivateMessageSnippetItem/Skeleton.d.ts +23 -0
  90. package/lib/esm/components/PrivateMessageSnippetItem/Skeleton.d.ts.map +1 -0
  91. package/lib/esm/components/PrivateMessageSnippetItem/Skeleton.js +48 -0
  92. package/lib/esm/components/PrivateMessageSnippetItem/Skeleton.js.map +1 -0
  93. package/lib/esm/components/PrivateMessageSnippetItem/index.d.ts +5 -0
  94. package/lib/esm/components/PrivateMessageSnippetItem/index.d.ts.map +1 -0
  95. package/lib/esm/components/PrivateMessageSnippetItem/index.js +5 -0
  96. package/lib/esm/components/PrivateMessageSnippetItem/index.js.map +1 -0
  97. package/lib/esm/components/PrivateMessageSnippets/PrivateMessageSnippets.d.ts +75 -0
  98. package/lib/esm/components/PrivateMessageSnippets/PrivateMessageSnippets.d.ts.map +1 -0
  99. package/lib/esm/components/PrivateMessageSnippets/PrivateMessageSnippets.js +252 -0
  100. package/lib/esm/components/PrivateMessageSnippets/PrivateMessageSnippets.js.map +1 -0
  101. package/lib/esm/components/PrivateMessageSnippets/Skeleton.d.ts +23 -0
  102. package/lib/esm/components/PrivateMessageSnippets/Skeleton.d.ts.map +1 -0
  103. package/lib/esm/components/PrivateMessageSnippets/Skeleton.js +39 -0
  104. package/lib/esm/components/PrivateMessageSnippets/Skeleton.js.map +1 -0
  105. package/lib/esm/components/PrivateMessageSnippets/index.d.ts +5 -0
  106. package/lib/esm/components/PrivateMessageSnippets/index.d.ts.map +1 -0
  107. package/lib/esm/components/PrivateMessageSnippets/index.js +5 -0
  108. package/lib/esm/components/PrivateMessageSnippets/index.js.map +1 -0
  109. package/lib/esm/components/PrivateMessageThread/PrivateMessageThread.d.ts +84 -0
  110. package/lib/esm/components/PrivateMessageThread/PrivateMessageThread.d.ts.map +1 -0
  111. package/lib/esm/components/PrivateMessageThread/PrivateMessageThread.js +388 -0
  112. package/lib/esm/components/PrivateMessageThread/PrivateMessageThread.js.map +1 -0
  113. package/lib/esm/components/PrivateMessageThread/Skeleton.d.ts +23 -0
  114. package/lib/esm/components/PrivateMessageThread/Skeleton.d.ts.map +1 -0
  115. package/lib/esm/components/{Thread → PrivateMessageThread}/Skeleton.js +7 -7
  116. package/lib/esm/components/PrivateMessageThread/Skeleton.js.map +1 -0
  117. package/lib/esm/components/PrivateMessageThread/index.d.ts +5 -0
  118. package/lib/esm/components/PrivateMessageThread/index.d.ts.map +1 -0
  119. package/lib/esm/components/PrivateMessageThread/index.js +5 -0
  120. package/lib/esm/components/PrivateMessageThread/index.js.map +1 -0
  121. package/lib/esm/components/PrivateMessageThreadItem/PrivateMessageThreadItem.d.ts +76 -0
  122. package/lib/esm/components/PrivateMessageThreadItem/PrivateMessageThreadItem.d.ts.map +1 -0
  123. package/lib/esm/components/PrivateMessageThreadItem/PrivateMessageThreadItem.js +163 -0
  124. package/lib/esm/components/PrivateMessageThreadItem/PrivateMessageThreadItem.js.map +1 -0
  125. package/lib/esm/components/PrivateMessageThreadItem/Skeleton.d.ts +23 -0
  126. package/lib/esm/components/PrivateMessageThreadItem/Skeleton.d.ts.map +1 -0
  127. package/lib/esm/components/{Message → PrivateMessageThreadItem}/Skeleton.js +7 -7
  128. package/lib/esm/components/PrivateMessageThreadItem/Skeleton.js.map +1 -0
  129. package/lib/esm/components/PrivateMessageThreadItem/index.d.ts +5 -0
  130. package/lib/esm/components/PrivateMessageThreadItem/index.d.ts.map +1 -0
  131. package/lib/esm/components/PrivateMessageThreadItem/index.js +5 -0
  132. package/lib/esm/components/PrivateMessageThreadItem/index.js.map +1 -0
  133. package/lib/esm/index.d.ts +6 -5
  134. package/lib/esm/index.d.ts.map +1 -1
  135. package/lib/esm/index.js +6 -5
  136. package/lib/esm/index.js.map +1 -1
  137. package/lib/umd/react-ui.js +4 -4
  138. package/lib/umd/react-ui.js.LICENSE.txt +1 -1
  139. package/lib/umd/react-ui.js.map +1 -1
  140. package/package.json +6 -6
  141. package/lib/cjs/components/Message/Message.d.ts +0 -83
  142. package/lib/cjs/components/Message/Message.d.ts.map +0 -1
  143. package/lib/cjs/components/Message/Message.js +0 -223
  144. package/lib/cjs/components/Message/Message.js.map +0 -1
  145. package/lib/cjs/components/Message/Skeleton.d.ts +0 -23
  146. package/lib/cjs/components/Message/Skeleton.d.ts.map +0 -1
  147. package/lib/cjs/components/Message/Skeleton.js.map +0 -1
  148. package/lib/cjs/components/Message/index.d.ts +0 -5
  149. package/lib/cjs/components/Message/index.d.ts.map +0 -1
  150. package/lib/cjs/components/Message/index.js.map +0 -1
  151. package/lib/cjs/components/MessageEditor/MessageEditor.d.ts +0 -48
  152. package/lib/cjs/components/MessageEditor/MessageEditor.d.ts.map +0 -1
  153. package/lib/cjs/components/MessageEditor/MessageEditor.js.map +0 -1
  154. package/lib/cjs/components/MessageEditor/MessageMediaUploader/index.d.ts.map +0 -1
  155. package/lib/cjs/components/MessageEditor/MessageMediaUploader/index.js.map +0 -1
  156. package/lib/cjs/components/MessageEditor/Skeleton.d.ts.map +0 -1
  157. package/lib/cjs/components/MessageEditor/Skeleton.js.map +0 -1
  158. package/lib/cjs/components/MessageEditor/index.d.ts +0 -5
  159. package/lib/cjs/components/MessageEditor/index.d.ts.map +0 -1
  160. package/lib/cjs/components/MessageEditor/index.js +0 -11
  161. package/lib/cjs/components/MessageEditor/index.js.map +0 -1
  162. package/lib/cjs/components/Snippets/Skeleton.d.ts +0 -23
  163. package/lib/cjs/components/Snippets/Skeleton.d.ts.map +0 -1
  164. package/lib/cjs/components/Snippets/Skeleton.js.map +0 -1
  165. package/lib/cjs/components/Snippets/Snippets.d.ts +0 -76
  166. package/lib/cjs/components/Snippets/Snippets.d.ts.map +0 -1
  167. package/lib/cjs/components/Snippets/Snippets.js +0 -231
  168. package/lib/cjs/components/Snippets/Snippets.js.map +0 -1
  169. package/lib/cjs/components/Snippets/index.d.ts +0 -5
  170. package/lib/cjs/components/Snippets/index.d.ts.map +0 -1
  171. package/lib/cjs/components/Snippets/index.js +0 -11
  172. package/lib/cjs/components/Snippets/index.js.map +0 -1
  173. package/lib/cjs/components/Thread/Skeleton.d.ts +0 -23
  174. package/lib/cjs/components/Thread/Skeleton.d.ts.map +0 -1
  175. package/lib/cjs/components/Thread/Skeleton.js.map +0 -1
  176. package/lib/cjs/components/Thread/Thread.d.ts +0 -93
  177. package/lib/cjs/components/Thread/Thread.d.ts.map +0 -1
  178. package/lib/cjs/components/Thread/Thread.js.map +0 -1
  179. package/lib/cjs/components/Thread/index.d.ts +0 -5
  180. package/lib/cjs/components/Thread/index.d.ts.map +0 -1
  181. package/lib/cjs/components/Thread/index.js.map +0 -1
  182. package/lib/esm/components/Message/Message.d.ts +0 -83
  183. package/lib/esm/components/Message/Message.d.ts.map +0 -1
  184. package/lib/esm/components/Message/Message.js +0 -194
  185. package/lib/esm/components/Message/Message.js.map +0 -1
  186. package/lib/esm/components/Message/Skeleton.d.ts +0 -23
  187. package/lib/esm/components/Message/Skeleton.d.ts.map +0 -1
  188. package/lib/esm/components/Message/Skeleton.js.map +0 -1
  189. package/lib/esm/components/Message/index.d.ts +0 -5
  190. package/lib/esm/components/Message/index.d.ts.map +0 -1
  191. package/lib/esm/components/Message/index.js +0 -5
  192. package/lib/esm/components/Message/index.js.map +0 -1
  193. package/lib/esm/components/MessageEditor/MessageEditor.d.ts +0 -48
  194. package/lib/esm/components/MessageEditor/MessageEditor.d.ts.map +0 -1
  195. package/lib/esm/components/MessageEditor/MessageEditor.js.map +0 -1
  196. package/lib/esm/components/MessageEditor/MessageMediaUploader/index.d.ts.map +0 -1
  197. package/lib/esm/components/MessageEditor/MessageMediaUploader/index.js.map +0 -1
  198. package/lib/esm/components/MessageEditor/Skeleton.d.ts.map +0 -1
  199. package/lib/esm/components/MessageEditor/Skeleton.js.map +0 -1
  200. package/lib/esm/components/MessageEditor/index.d.ts +0 -5
  201. package/lib/esm/components/MessageEditor/index.d.ts.map +0 -1
  202. package/lib/esm/components/MessageEditor/index.js +0 -5
  203. package/lib/esm/components/MessageEditor/index.js.map +0 -1
  204. package/lib/esm/components/Snippets/Skeleton.d.ts +0 -23
  205. package/lib/esm/components/Snippets/Skeleton.d.ts.map +0 -1
  206. package/lib/esm/components/Snippets/Skeleton.js +0 -39
  207. package/lib/esm/components/Snippets/Skeleton.js.map +0 -1
  208. package/lib/esm/components/Snippets/Snippets.d.ts +0 -76
  209. package/lib/esm/components/Snippets/Snippets.d.ts.map +0 -1
  210. package/lib/esm/components/Snippets/Snippets.js +0 -202
  211. package/lib/esm/components/Snippets/Snippets.js.map +0 -1
  212. package/lib/esm/components/Snippets/index.d.ts +0 -5
  213. package/lib/esm/components/Snippets/index.d.ts.map +0 -1
  214. package/lib/esm/components/Snippets/index.js +0 -5
  215. package/lib/esm/components/Snippets/index.js.map +0 -1
  216. package/lib/esm/components/Thread/Skeleton.d.ts +0 -23
  217. package/lib/esm/components/Thread/Skeleton.d.ts.map +0 -1
  218. package/lib/esm/components/Thread/Skeleton.js.map +0 -1
  219. package/lib/esm/components/Thread/Thread.d.ts +0 -93
  220. package/lib/esm/components/Thread/Thread.d.ts.map +0 -1
  221. package/lib/esm/components/Thread/Thread.js +0 -479
  222. package/lib/esm/components/Thread/Thread.js.map +0 -1
  223. package/lib/esm/components/Thread/index.d.ts +0 -5
  224. package/lib/esm/components/Thread/index.d.ts.map +0 -1
  225. package/lib/esm/components/Thread/index.js +0 -5
  226. package/lib/esm/components/Thread/index.js.map +0 -1
@@ -0,0 +1,84 @@
1
+ import { SCPrivateMessageThreadType } from '@selfcommunity/types';
2
+ export interface PrivateMessageThreadProps {
3
+ /**
4
+ * User object (thread receiver)
5
+ * default null
6
+ */
7
+ userObj?: SCPrivateMessageThreadType | number;
8
+ /**
9
+ * Overrides or extends the styles applied to the component.
10
+ * @default null
11
+ */
12
+ className?: string;
13
+ /**
14
+ * Hides this component
15
+ * @default false
16
+ */
17
+ autoHide?: boolean;
18
+ /**
19
+ * Opens new message screen
20
+ * @default false
21
+ */
22
+ openNewMessage?: boolean;
23
+ /**
24
+ * Functions called on thread actions
25
+ */
26
+ threadCallbacks?: {
27
+ /**
28
+ * Callback fired when a message is sent
29
+ * @param data
30
+ * @default null
31
+ */
32
+ onMessageSentOrDeleted?: (data: any, reason: string) => void;
33
+ /**
34
+ * Callback fired only when exiting a thread.
35
+ * @default null
36
+ */
37
+ onMessageBack?: (dispatch: any) => void;
38
+ /**
39
+ * Callback fired when deleting a thread.
40
+ * @default null
41
+ */
42
+ onThreadDelete?: (dispatch: any) => void;
43
+ };
44
+ /**
45
+ * Any other properties
46
+ */
47
+ [p: string]: any;
48
+ }
49
+ /**
50
+ *
51
+ > API documentation for the Community-JS PrivateMessage Thread component. Learn about the available props and the CSS API.
52
+
53
+ #### Import
54
+
55
+ ```jsx
56
+ import {PrivateMessageThread} from '@selfcommunity/react-ui';
57
+ ```
58
+
59
+ #### Component Name
60
+
61
+ The name `SCPrivateMessageThread` can be used when providing style overrides in the theme.
62
+
63
+
64
+ #### CSS
65
+
66
+ |Rule Name|Global class|Description|
67
+ |---|---|---|
68
+ |root|.SCPrivateMessageThread-root|Styles applied to the root element.|
69
+ |section|.SCPrivateMessageThread-section|Styles applied to the list section|
70
+ |emptyMessage|.SCPrivateMessageThread-empty-message|Styles applied to the empty message element.|
71
+ |newMessageHeader|.SCPrivateMessageThread-new-message-header|Styles applied to the new message header section.|
72
+ |newMessageHeaderIcon|.SCPrivateMessageThread-new-message-header-icon|Styles applied to the new message header icon element.|
73
+ |newMessageHeaderContent|.SCPrivateMessageThread-new-message-header-content|Styles applied to the new message header content.|
74
+ |subHeader|.SCPrivateMessageThread-subheader|Styles applied to thread list subheader element.|
75
+ |mobileHeader|.SCPrivateMessageThread-mobile-header|Styles applied to mobile header element.|
76
+ |mobileHeaderContent|.SCPrivateMessageThread-mobile-header-content|Styles applied to mobile header content.|
77
+ |sender|.SCPrivateMessageThread-sender|Styles applied to the sender element.|
78
+ |receiver|.SCPrivateMessageThread-receiver|Styles applied to the receiver element.|
79
+ |autocomplete|.SCPrivateMessageThread-autocomplete|Styles applied to new message user insertion autocomplete.|
80
+
81
+ * @param inProps
82
+ */
83
+ export default function PrivateMessageThread(inProps: PrivateMessageThreadProps): JSX.Element;
84
+ //# sourceMappingURL=PrivateMessageThread.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PrivateMessageThread.d.ts","sourceRoot":"","sources":["../../../../src/components/PrivateMessageThread/PrivateMessageThread.tsx"],"names":[],"mappings":"AAcA,OAAO,EAAyE,0BAA0B,EAAC,MAAM,sBAAsB,CAAC;AA8DxI,MAAM,WAAW,yBAAyB;IACxC;;;OAGG;IACH,OAAO,CAAC,EAAE,0BAA0B,GAAG,MAAM,CAAC;IAC9C;;;OAGG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB;;;OAGG;IACH,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB;;;OAGG;IACH,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB;;OAEG;IACH,eAAe,CAAC,EAAE;QAChB;;;;WAIG;QACH,sBAAsB,CAAC,EAAE,CAAC,IAAI,KAAA,EAAE,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;QACxD;;;WAGG;QACH,aAAa,CAAC,EAAE,CAAC,QAAQ,EAAE,GAAG,KAAK,IAAI,CAAC;QACxC;;;WAGG;QACH,cAAc,CAAC,EAAE,CAAC,QAAQ,EAAE,GAAG,KAAK,IAAI,CAAC;KAC1C,CAAC;IACF;;OAEG;IACH,CAAC,CAAC,EAAE,MAAM,GAAG,GAAG,CAAC;CAClB;AACD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAiCG;AACH,MAAM,CAAC,OAAO,UAAU,oBAAoB,CAAC,OAAO,EAAE,yBAAyB,GAAG,GAAG,CAAC,OAAO,CAmZ5F"}
@@ -43,12 +43,12 @@ const Widget_1 = __importDefault(require("../Widget"));
43
43
  const api_services_1 = require("@selfcommunity/api-services");
44
44
  const react_core_1 = require("@selfcommunity/react-core");
45
45
  const types_1 = require("@selfcommunity/types");
46
- const Message_1 = __importDefault(require("../Message"));
46
+ const PrivateMessageThreadItem_1 = __importDefault(require("../PrivateMessageThreadItem"));
47
47
  const lodash_1 = __importDefault(require("lodash"));
48
48
  const react_intl_1 = require("react-intl");
49
49
  const material_1 = require("@mui/material");
50
50
  const ConfirmDialog_1 = __importDefault(require("../../shared/ConfirmDialog/ConfirmDialog"));
51
- const MessageEditor_1 = __importDefault(require("../MessageEditor"));
51
+ const PrivateMessageEditor_1 = __importDefault(require("../PrivateMessageEditor"));
52
52
  const Autocomplete_1 = __importDefault(require("@mui/material/Autocomplete"));
53
53
  const classnames_1 = __importDefault(require("classnames"));
54
54
  const notistack_1 = require("notistack");
@@ -56,159 +56,76 @@ const pubsub_js_1 = __importDefault(require("pubsub-js"));
56
56
  const system_1 = require("@mui/system");
57
57
  const Icon_1 = __importDefault(require("@mui/material/Icon"));
58
58
  const Skeleton_1 = __importDefault(require("./Skeleton"));
59
+ const Errors_1 = require("../../constants/Errors");
60
+ const utils_1 = require("@selfcommunity/utils");
61
+ const HiddenPlaceholder_1 = __importDefault(require("../../shared/HiddenPlaceholder"));
59
62
  const messages = (0, react_intl_1.defineMessages)({
60
63
  placeholder: {
61
- id: 'ui.thread.newMessage.autocomplete.placeholder',
62
- defaultMessage: 'ui.thread.newMessage.autocomplete.placeholder'
64
+ id: 'ui.privateMessage.thread.newMessage.autocomplete.placeholder',
65
+ defaultMessage: 'ui.privateMessage.thread.newMessage.autocomplete.placeholder'
63
66
  }
64
67
  });
65
- const PREFIX = 'SCThread';
68
+ const PREFIX = 'SCPrivateMessageThread';
66
69
  const classes = {
67
70
  root: `${PREFIX}-root`,
68
- threadBox: `${PREFIX}-thread-box`,
69
- emptyBox: `${PREFIX}-empty-box`,
70
- newMessageBox: `${PREFIX}-new-message-box`,
71
- newMessageEditor: `${PREFIX}-new-message-editor`,
72
- newMessageEmptyBox: `${PREFIX}-new-message-empty-box`,
71
+ subHeader: `${PREFIX}-subheader`,
72
+ section: `${PREFIX}-section`,
73
+ mobileHeader: `${PREFIX}-mobile-header`,
74
+ mobileHeaderContent: `${PREFIX}-mobile-header-content`,
75
+ emptyMessage: `${PREFIX}-empty-message`,
73
76
  newMessageHeader: `${PREFIX}-new-message-header`,
77
+ newMessageHeaderContent: `${PREFIX}-new-message-header-content`,
78
+ newMessageHeaderIcon: `${PREFIX}-new-message-header-icon`,
74
79
  sender: `${PREFIX}-sender`,
75
80
  receiver: `${PREFIX}-receiver`,
76
- center: `${PREFIX}-center`,
77
- autocomplete: `${PREFIX}-autocomplete`,
78
- toolBar: `${PREFIX}-tool-bar`
81
+ autocomplete: `${PREFIX}-autocomplete`
79
82
  };
80
83
  const Root = (0, styles_1.styled)(Widget_1.default, {
81
84
  name: PREFIX,
82
85
  slot: 'Root',
83
86
  overridesResolver: (props, styles) => styles.root
84
- })(({ theme }) => ({
85
- width: '600px',
86
- height: '100%',
87
- position: 'relative',
88
- [theme.breakpoints.down('md')]: {
89
- width: '100%',
90
- boxShadow: 'none'
91
- //overflow: 'auto'
92
- //maxWidth: '345px'
93
- },
94
- [`& .${classes.threadBox}`]: {
95
- [theme.breakpoints.up('sm')]: {
96
- maxHeight: '540px',
97
- overflow: 'auto'
98
- // width: 'inherit',
99
- }
100
- },
101
- [`& .${classes.emptyBox}`]: {
102
- display: 'flex',
103
- height: '100%',
104
- background: theme.palette.grey['A200'],
105
- justifyContent: 'center',
106
- alignItems: 'center',
107
- '& .MuiTypography-root': {
108
- fontSize: '1.5rem'
109
- },
110
- minHeight: '550px',
111
- [theme.breakpoints.down('md')]: {
112
- maxHeight: '450px'
113
- }
114
- },
115
- [`& .${classes.newMessageBox}`]: {
116
- display: 'flex',
117
- flexFlow: 'column',
118
- height: '100%'
119
- },
120
- [`& .${classes.newMessageEditor}`]: {
121
- flexGrow: 0,
122
- flexShrink: 1,
123
- flexBasis: '40px'
124
- },
125
- [`& .${classes.newMessageEmptyBox}`]: {
126
- flexGrow: 1,
127
- flexShrink: 1,
128
- flexBasis: 'auto',
129
- minHeight: '550px',
130
- [theme.breakpoints.down('md')]: {
131
- height: '450px'
132
- }
133
- },
134
- [`& .${classes.sender}`]: {
135
- display: 'flex',
136
- justifyContent: 'flex-end',
137
- '& .SCMessage-message-box': {
138
- backgroundColor: theme.palette.grey[400]
139
- }
140
- },
141
- [`& .${classes.receiver}`]: {
142
- display: 'flex',
143
- justifyContent: 'flex-start',
144
- '& .SCMessage-message-box': {
145
- backgroundColor: theme.palette.grey['A200']
146
- },
147
- '& .SCMessage-message-time': {
148
- display: 'flex',
149
- justifyContent: 'flex-start'
150
- }
151
- },
152
- [`& .${classes.center}`]: {
153
- display: 'flex',
154
- justifyContent: 'center'
155
- },
156
- [`& .${classes.newMessageHeader}`]: {
157
- marginLeft: theme.spacing(1),
158
- marginTop: theme.spacing(1)
159
- },
160
- [`& .${classes.autocomplete}`]: {
161
- marginRight: theme.spacing(1)
162
- },
163
- [`& .${classes.toolBar}`]: {
164
- alignItems: 'center',
165
- paddingLeft: '8px',
166
- paddingRight: '8px',
167
- justifyContent: 'space-between',
168
- backgroundColor: theme.palette.primary.main
169
- }
170
- }));
87
+ })(({ theme }) => ({}));
171
88
  /**
172
89
  *
173
- > API documentation for the Community-JS Thread component. Learn about the available props and the CSS API.
90
+ > API documentation for the Community-JS PrivateMessage Thread component. Learn about the available props and the CSS API.
174
91
 
175
92
  #### Import
176
93
 
177
94
  ```jsx
178
- import {Thread} from '@selfcommunity/react-ui';
95
+ import {PrivateMessageThread} from '@selfcommunity/react-ui';
179
96
  ```
180
97
 
181
98
  #### Component Name
182
99
 
183
- The name `SCThread` can be used when providing style overrides in the theme.
100
+ The name `SCPrivateMessageThread` can be used when providing style overrides in the theme.
184
101
 
185
102
 
186
103
  #### CSS
187
104
 
188
105
  |Rule Name|Global class|Description|
189
106
  |---|---|---|
190
- |root|.SCThread-root|Styles applied to the root element.|
191
- |threadBox|.SCThread-thread-box|Styles applied to the thread box element.|
192
- |emptyBox|.SCThread-empty-box|Styles applied to the empty box element.|
193
- |newMessageBox|.SCThread-new-message-box|Styles applied to the new message box element.|
194
- |newMessageEditor|.SCThread-new-message-editor|Styles applied to the new message editor.|
195
- |newMessageEmptyBox|.SCThread-new-message-empty-box|Styles applied to the new message empty box element.|
196
- |newMessageHeader|.SCThread-new-message-header|Styles applied to the new message header section.|
197
- |sender|.SCThread-sender|Styles applied to the sender element.|
198
- |receiver|.SCThread-receiver|Styles applied to the receiver element.|
199
- |center|.SCThread-center|Styles applied to the center section.|
200
- |autocomplete|.SCThread-autocomplete|Styles applied to new message user insertion autocomplete.|
201
- |toolBar|.SCThread-toolBar|Styles applied to the toolBar element.|
107
+ |root|.SCPrivateMessageThread-root|Styles applied to the root element.|
108
+ |section|.SCPrivateMessageThread-section|Styles applied to the list section|
109
+ |emptyMessage|.SCPrivateMessageThread-empty-message|Styles applied to the empty message element.|
110
+ |newMessageHeader|.SCPrivateMessageThread-new-message-header|Styles applied to the new message header section.|
111
+ |newMessageHeaderIcon|.SCPrivateMessageThread-new-message-header-icon|Styles applied to the new message header icon element.|
112
+ |newMessageHeaderContent|.SCPrivateMessageThread-new-message-header-content|Styles applied to the new message header content.|
113
+ |subHeader|.SCPrivateMessageThread-subheader|Styles applied to thread list subheader element.|
114
+ |mobileHeader|.SCPrivateMessageThread-mobile-header|Styles applied to mobile header element.|
115
+ |mobileHeaderContent|.SCPrivateMessageThread-mobile-header-content|Styles applied to mobile header content.|
116
+ |sender|.SCPrivateMessageThread-sender|Styles applied to the sender element.|
117
+ |receiver|.SCPrivateMessageThread-receiver|Styles applied to the receiver element.|
118
+ |autocomplete|.SCPrivateMessageThread-autocomplete|Styles applied to new message user insertion autocomplete.|
202
119
 
203
120
  * @param inProps
204
121
  */
205
- function Thread(inProps) {
122
+ function PrivateMessageThread(inProps) {
206
123
  // PROPS
207
124
  const props = (0, system_1.useThemeProps)({
208
125
  props: inProps,
209
126
  name: PREFIX
210
127
  });
211
- const { userObj, autoHide, className, openNewMessage, onNewMessageSent, onMessageSent, shouldUpdate, onMessageBack, onMessageDelete } = props, rest = __rest(props, ["userObj", "autoHide", "className", "openNewMessage", "onNewMessageSent", "onMessageSent", "shouldUpdate", "onMessageBack", "onMessageDelete"]);
128
+ const { userObj, autoHide, className, openNewMessage, threadCallbacks } = props, rest = __rest(props, ["userObj", "autoHide", "className", "openNewMessage", "threadCallbacks"]);
212
129
  // CONTEXT
213
130
  const scUserContext = (0, react_1.useContext)(react_core_1.SCUserContext);
214
131
  const { enqueueSnackbar, closeSnackbar } = (0, notistack_1.useSnackbar)();
@@ -218,25 +135,25 @@ function Thread(inProps) {
218
135
  // STATE
219
136
  const theme = (0, material_1.useTheme)();
220
137
  const isMobile = (0, material_1.useMediaQuery)(theme.breakpoints.down('md'));
138
+ const scFollowersManager = scUserContext.managers.followers;
221
139
  const [loading, setLoading] = (0, react_1.useState)(true);
222
140
  const [messageObjs, setMessageObjs] = (0, react_1.useState)([]);
223
- const loggedUser = scUserContext.user && scUserContext.user.id;
224
141
  const [isHovered, setIsHovered] = (0, react_1.useState)({});
225
142
  const [openDeleteMessageDialog, setOpenDeleteMessageDialog] = (0, react_1.useState)(false);
226
143
  const [deletingMsg, setDeletingMsg] = (0, react_1.useState)(null);
227
144
  const [followers, setFollowers] = (0, react_1.useState)([]);
228
145
  const [recipients, setRecipients] = (0, react_1.useState)([]);
229
- const [isFollowed, setIsFollowed] = (0, react_1.useState)(false);
146
+ const [isFollower, setIsFollower] = (0, react_1.useState)(false);
230
147
  const [receiver, setReceiver] = (0, react_1.useState)(null);
231
148
  const [newMessageThread, setNewMessageThread] = (0, react_1.useState)(false);
232
- const [newMessageUser, setNewMessageUser] = (0, react_1.useState)('');
233
149
  // REFS
234
150
  const refreshSubscription = (0, react_1.useRef)(null);
151
+ const authUserId = scUserContext.user ? scUserContext.user.id : null;
235
152
  // INTL
236
153
  const intl = (0, react_intl_1.useIntl)();
237
154
  // UTILS
238
155
  const format = (item) => intl.formatDate(item.created_at, {
239
- weekday: 'long',
156
+ year: 'numeric',
240
157
  day: 'numeric',
241
158
  month: 'long'
242
159
  });
@@ -257,16 +174,19 @@ function Thread(inProps) {
257
174
  return Object.assign(Object.assign({}, prevState), { [index]: false });
258
175
  });
259
176
  };
260
- const handleClose = () => {
177
+ const handleCloseDeleteDialog = () => {
261
178
  setOpenDeleteMessageDialog(false);
262
179
  };
263
- function handleDeleteDialog(msg) {
180
+ const handleOpenDeleteDialog = (msg) => {
264
181
  setOpenDeleteMessageDialog(true);
265
182
  setDeletingMsg(msg);
266
- }
183
+ };
267
184
  const selectRecipients = (event, recipient) => {
268
185
  setRecipients(recipient);
269
186
  };
187
+ /**
188
+ * Memoized message recipients ids
189
+ */
270
190
  const ids = (0, react_1.useMemo)(() => {
271
191
  if (recipients !== null && openNewMessage) {
272
192
  return recipients.map((u) => {
@@ -278,15 +198,15 @@ function Thread(inProps) {
278
198
  }
279
199
  }, [recipients]);
280
200
  /**
281
- * Handles deletion of a single message
201
+ * Handles the deletion of a single message
282
202
  */
283
203
  function handleDelete() {
284
204
  api_services_1.PrivateMessageService.deleteAMessage(deletingMsg.id)
285
205
  .then(() => {
286
206
  const result = messageObjs.filter((m) => m.id !== deletingMsg.id);
287
207
  setMessageObjs(result);
288
- shouldUpdate(true);
289
- handleClose();
208
+ threadCallbacks.onMessageSentOrDeleted(result.length > 1 ? result.slice(-1)[0] : deletingMsg, 'deleted');
209
+ handleCloseDeleteDialog();
290
210
  })
291
211
  .catch((error) => {
292
212
  console.log(error);
@@ -298,6 +218,11 @@ function Thread(inProps) {
298
218
  });
299
219
  });
300
220
  }
221
+ /**
222
+ * Sends a message
223
+ * @param m
224
+ * @param f
225
+ */
301
226
  function sendMessage(m, f) {
302
227
  if (react_core_1.UserUtils.isBlocked(scUserContext.user)) {
303
228
  enqueueSnackbar(react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.common.userBlocked", defaultMessage: "ui.common.userBlocked" }), {
@@ -318,10 +243,8 @@ function Thread(inProps) {
318
243
  })
319
244
  .then((res) => {
320
245
  setMessageObjs((prev) => [...prev, res.data]);
321
- onMessageSent(res.data);
246
+ threadCallbacks.onMessageSentOrDeleted(res.data, 'sent');
322
247
  if (openNewMessage || newMessageThread) {
323
- onNewMessageSent(res.data);
324
- shouldUpdate(true);
325
248
  setNewMessageThread(false);
326
249
  setRecipients([]);
327
250
  }
@@ -338,40 +261,27 @@ function Thread(inProps) {
338
261
  }
339
262
  }
340
263
  /**
341
- * Fetches user followers/connections
264
+ * Memoized fetchFollowers
342
265
  */
343
- function fetchFollowers() {
266
+ const fetchFollowers = (0, react_1.useMemo)(() => () => {
344
267
  let fetch;
345
268
  if (followEnabled) {
346
- fetch = api_services_1.UserService.getUserFollowers(scUserContext['user'].id);
269
+ fetch = api_services_1.UserService.getUserFollowers(authUserId);
347
270
  }
348
271
  else {
349
- fetch = api_services_1.UserService.getUserConnections(scUserContext['user'].id);
272
+ fetch = api_services_1.UserService.getUserConnections(authUserId);
350
273
  }
351
- fetch
274
+ return fetch
352
275
  .then((data) => {
353
276
  setFollowers(data.results);
354
- if (data.results && userObj) {
355
- let u;
356
- if (typeof userObj === 'number') {
357
- u = userObj;
358
- }
359
- else {
360
- u = userObj.receiver.id;
361
- }
362
- setIsFollowed(data.results.some((f) => f.id === u));
363
- const r = data.results.filter((o) => o.id === userObj);
364
- setNewMessageUser(r[0]);
365
- }
366
- if (openNewMessage || newMessageThread || react_core_1.UserUtils.isStaff(scUserContext.user)) {
367
- setIsFollowed(true);
368
- }
369
277
  setLoading(false);
370
278
  })
371
279
  .catch((error) => {
280
+ setLoading(false);
372
281
  console.log(error);
282
+ utils_1.Logger.error(Errors_1.SCOPE_SC_UI, { error });
373
283
  });
374
- }
284
+ }, []);
375
285
  /**
376
286
  * Fetches thread
377
287
  */
@@ -395,7 +305,7 @@ function Thread(inProps) {
395
305
  const data = res.data;
396
306
  setMessageObjs(data.results);
397
307
  if (data.results.length) {
398
- if (data.results[0].receiver.id !== loggedUser) {
308
+ if (data.results[0].receiver.id !== scUserContext.user.id) {
399
309
  setReceiver(data.results[0].receiver);
400
310
  }
401
311
  else {
@@ -410,7 +320,9 @@ function Thread(inProps) {
410
320
  setLoading(false);
411
321
  })
412
322
  .catch((error) => {
323
+ setLoading(false);
413
324
  console.log(error);
325
+ utils_1.Logger.error(Errors_1.SCOPE_SC_UI, { error });
414
326
  });
415
327
  }
416
328
  /**
@@ -418,14 +330,17 @@ function Thread(inProps) {
418
330
  * if openNewMessage is true, fetches user followers too.
419
331
  */
420
332
  (0, react_1.useEffect)(() => {
421
- if (userObj) {
422
- fetchThread();
423
- fetchFollowers();
424
- }
425
- if (openNewMessage) {
426
- fetchFollowers();
333
+ userObj && fetchThread();
334
+ openNewMessage && fetchFollowers();
335
+ }, [userObj, openNewMessage, authUserId]);
336
+ /**
337
+ * Checks is thread receiver is a user follower
338
+ */
339
+ (0, react_1.useEffect)(() => {
340
+ if (receiver) {
341
+ setIsFollower(scFollowersManager.isFollower(receiver));
427
342
  }
428
- }, [userObj, openNewMessage]);
343
+ });
429
344
  /**
430
345
  * When a ws notification arrives, update data
431
346
  */
@@ -451,47 +366,41 @@ function Thread(inProps) {
451
366
  * @return {JSX.Element}
452
367
  */
453
368
  function renderThread() {
454
- return (react_1.default.createElement(react_1.default.Fragment, null,
455
- isMobile && receiver && (react_1.default.createElement(material_1.AppBar, { position: "fixed" },
456
- react_1.default.createElement(material_1.Toolbar, { className: classes.toolBar },
457
- react_1.default.createElement(material_1.Box, { sx: { display: 'flex', justifyContent: 'flex-start', alignItems: 'center' } },
458
- react_1.default.createElement(Icon_1.default, { onClick: onMessageBack }, "chevron_left"),
459
- react_1.default.createElement(material_1.Avatar, { alt: receiver.username, src: receiver.avatar, sx: { marginRight: '8px' } }),
460
- react_1.default.createElement(material_1.Typography, { variant: "h6", color: "inherit", component: "div" }, receiver.username)),
461
- react_1.default.createElement(material_1.Box, { sx: { display: 'flex', justifyContent: 'flex-end', alignItems: 'center' } },
462
- react_1.default.createElement(Icon_1.default, { onClick: onMessageDelete }, "delete"))))),
463
- react_1.default.createElement(material_1.Box, { className: classes.threadBox },
464
- openDeleteMessageDialog && (react_1.default.createElement(ConfirmDialog_1.default, { open: openDeleteMessageDialog, title: react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.thread.message.dialog.msg", defaultMessage: "ui.thread.message.dialog.msg" }), btnConfirm: react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.thread.message.dialog.confirm", defaultMessage: "ui.thread.message.dialog.confirm" }), onConfirm: () => handleDelete(), onClose: handleClose })),
465
- Object.keys(formattedMessages).map((key, index) => (react_1.default.createElement(react_1.default.Fragment, { key: index },
466
- react_1.default.createElement(material_1.ListSubheader, { className: classes.center }, key),
467
- formattedMessages[key].map((msg, index) => (react_1.default.createElement(material_1.Box, { key: index, className: loggedUser === msg.sender.id ? classes.sender : classes.receiver },
468
- react_1.default.createElement(Message_1.default, { elevation: 0, message: msg, key: msg.id, snippetType: false, onMouseEnter: () => handleMouseEnter(msg.id), onMouseLeave: () => handleMouseLeave(msg.id), isHovering: isHovered[msg.id], showDeleteIcon: loggedUser === msg.sender.id, onDeleteIconClick: () => handleDeleteDialog(msg) })))))))),
469
- react_1.default.createElement(MessageEditor_1.default, { send: (m, f) => sendMessage(m, f), autoHide: !isFollowed, onThreadChangeId: userObj })));
369
+ return (react_1.default.createElement(material_1.CardContent, null,
370
+ isMobile && receiver && (react_1.default.createElement(material_1.Box, { className: classes.mobileHeader },
371
+ react_1.default.createElement(material_1.Box, { className: classes.mobileHeaderContent },
372
+ react_1.default.createElement(Icon_1.default, { onClick: () => threadCallbacks.onMessageBack('default') }, "chevron_left"),
373
+ react_1.default.createElement(material_1.Avatar, { alt: receiver.username, src: receiver.avatar }),
374
+ react_1.default.createElement(material_1.Typography, { variant: "body1", color: "inherit" }, receiver.username)),
375
+ react_1.default.createElement(Icon_1.default, { fontSize: "medium", onClick: threadCallbacks.onThreadDelete }, "delete"))),
376
+ openDeleteMessageDialog && (react_1.default.createElement(ConfirmDialog_1.default, { open: openDeleteMessageDialog, title: react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.privateMessage.thread.message.dialog.msg", defaultMessage: "ui.privateMessage.thread.message.dialog.msg" }), btnConfirm: react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.privateMessage.thread.message.dialog.confirm", defaultMessage: "ui.privateMessage.thread.message.dialog.confirm" }), onConfirm: () => handleDelete(), onClose: handleCloseDeleteDialog })),
377
+ react_1.default.createElement(material_1.List, { subheader: react_1.default.createElement("li", null) }, Object.keys(formattedMessages).map((key, index) => (react_1.default.createElement("li", { key: key, className: classes.section },
378
+ react_1.default.createElement("ul", null,
379
+ react_1.default.createElement(material_1.ListSubheader, null,
380
+ react_1.default.createElement(material_1.Typography, { align: "center", className: classes.subHeader }, key)),
381
+ formattedMessages[key].map((msg, index) => (react_1.default.createElement(PrivateMessageThreadItem_1.default, { className: scUserContext['user'].id === msg.sender.id ? classes.sender : classes.receiver, message: msg, key: msg.id, mouseEvents: { onMouseEnter: () => handleMouseEnter(msg.id), onMouseLeave: () => handleMouseLeave(msg.id) }, isHovering: isHovered[msg.id], showMenuIcon: scUserContext['user'].id === msg.sender.id, onMenuIconClick: () => handleOpenDeleteDialog(msg) })))))))),
382
+ react_1.default.createElement(PrivateMessageEditor_1.default, { send: (m, f) => sendMessage(m, f), autoHide: !isFollower, onThreadChangeId: userObj })));
470
383
  }
471
384
  /**
472
385
  * Renders empty box (when there is no thread open) or new message box
473
386
  * @return {JSX.Element}
474
387
  */
475
388
  function renderNewOrNoMessageBox() {
476
- return (react_1.default.createElement(react_1.default.Fragment, null, openNewMessage || newMessageThread ? (react_1.default.createElement(material_1.Box, { className: classes.newMessageBox },
477
- react_1.default.createElement(material_1.Box, { sx: { flexGrow: 0, flexShrink: 1, flexBasis: 'auto' } },
478
- react_1.default.createElement(material_1.Grid, { container: true, className: classes.newMessageHeader },
479
- react_1.default.createElement(material_1.Grid, { item: true, xs: 4, sx: { display: 'flex', alignItems: 'center' } },
480
- isMobile && react_1.default.createElement(Icon_1.default, { onClick: () => onMessageBack('default') }, "chevron_left"),
481
- react_1.default.createElement(Icon_1.default, { sx: { marginRight: '8px' }, fontSize: "small" }, "person"),
482
- react_1.default.createElement(material_1.Typography, { sx: { fontWeight: 'bold' } },
483
- react_1.default.createElement(react_intl_1.FormattedMessage, { defaultMessage: "ui.thread.newMessage.to", id: "ui.thread.newMessage.to" }))),
484
- react_1.default.createElement(material_1.Grid, { item: true, xs: 8 },
485
- react_1.default.createElement(Autocomplete_1.default, { className: classes.autocomplete, multiple: !newMessageThread, freeSolo: true, options: followers, value: newMessageThread ? newMessageUser : recipients, getOptionLabel: (option) => (option ? option.username : '...'), renderInput: (params) => (react_1.default.createElement(material_1.TextField, Object.assign({}, params, { placeholder: `${intl.formatMessage(messages.placeholder)}`, variant: "standard", InputProps: Object.assign(Object.assign({}, params.InputProps), { disableUnderline: true }) }))), onChange: selectRecipients, disabled: !followers })))),
486
- react_1.default.createElement(material_1.Box, { className: classes.newMessageEmptyBox }),
487
- react_1.default.createElement(material_1.Box, { className: classes.newMessageEditor },
488
- react_1.default.createElement(MessageEditor_1.default, { send: (m, f) => sendMessage(m, f), autoHide: !followers })))) : (react_1.default.createElement(material_1.Box, { className: classes.emptyBox },
489
- react_1.default.createElement(material_1.Typography, { component: "h3" },
490
- react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.thread.emptyBox.message", defaultMessage: "ui.thread.emptyBox.message" }))))));
389
+ return (react_1.default.createElement(material_1.CardContent, null, openNewMessage || newMessageThread ? (react_1.default.createElement(react_1.default.Fragment, null,
390
+ react_1.default.createElement(material_1.Box, { className: classes.newMessageHeader },
391
+ react_1.default.createElement(material_1.Box, { className: classes.newMessageHeaderContent },
392
+ react_1.default.createElement(Icon_1.default, { className: classes.newMessageHeaderIcon }, "person"),
393
+ react_1.default.createElement(material_1.Typography, null,
394
+ react_1.default.createElement(react_intl_1.FormattedMessage, { defaultMessage: "ui.privateMessage.thread.newMessage.to", id: "ui.privateMessage.thread.newMessage.to" })),
395
+ react_1.default.createElement(Autocomplete_1.default, { className: classes.autocomplete, multiple: !newMessageThread, limitTags: 3, freeSolo: true, options: followers, value: newMessageThread ? userObj : recipients, getOptionLabel: (option) => (option ? option.username : '...'), renderInput: (params) => (react_1.default.createElement(material_1.TextField, Object.assign({}, params, { placeholder: `${intl.formatMessage(messages.placeholder)}`, variant: "standard", InputProps: Object.assign(Object.assign({}, params.InputProps), { disableUnderline: true }) }))), onChange: selectRecipients, disabled: !followers })),
396
+ react_1.default.createElement(material_1.IconButton, { size: "small", onClick: threadCallbacks.onMessageBack },
397
+ react_1.default.createElement(Icon_1.default, { fontSize: "small" }, "close"))),
398
+ react_1.default.createElement(PrivateMessageEditor_1.default, { send: (m, f) => sendMessage(m, f), autoHide: !followers }))) : (react_1.default.createElement(material_1.Typography, { component: "span", className: classes.emptyMessage },
399
+ react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.privateMessage.thread.emptyBox.message", defaultMessage: "ui.privateMessage.thread.emptyBox.message" })))));
491
400
  }
492
401
  // Anonymous
493
402
  if (!scUserContext.user) {
494
- return null;
403
+ return react_1.default.createElement(HiddenPlaceholder_1.default, null);
495
404
  }
496
405
  if (loading && userObj) {
497
406
  return react_1.default.createElement(Skeleton_1.default, null);
@@ -504,5 +413,5 @@ function Thread(inProps) {
504
413
  }
505
414
  return null;
506
415
  }
507
- exports.default = Thread;
508
- //# sourceMappingURL=Thread.js.map
416
+ exports.default = PrivateMessageThread;
417
+ //# sourceMappingURL=PrivateMessageThread.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PrivateMessageThread.js","sourceRoot":"","sources":["../../../../src/components/PrivateMessageThread/PrivateMessageThread.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,23 @@
1
+ /**
2
+ * > API documentation for the Community-JS PrivateMessage Thread Skeleton component. Learn about the available props and the CSS API.
3
+
4
+ #### Import
5
+
6
+ ```jsx
7
+ import {PrivateMessageThreadSkeleton} from '@selfcommunity/react-ui';
8
+ ```
9
+
10
+ #### Component Name
11
+
12
+ The name `SCPrivateMessageThreadSkeleton` can be used when providing style overrides in the theme.
13
+
14
+ #### CSS
15
+
16
+ |Rule Name|Global class|Description|
17
+ |---|---|---|
18
+ |root|.SCPrivateMessageThreadSkeleton-root|Styles applied to the root element.|
19
+ |list|.SCPrivateMessageThreadSkeleton-list|Styles applied to the list element.|
20
+ *
21
+ */
22
+ export default function PrivateMessageThreadSkeleton(props: any): JSX.Element;
23
+ //# sourceMappingURL=Skeleton.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Skeleton.d.ts","sourceRoot":"","sources":["../../../../src/components/PrivateMessageThread/Skeleton.tsx"],"names":[],"mappings":"AA8BA;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,MAAM,CAAC,OAAO,UAAU,4BAA4B,CAAC,KAAK,KAAA,GAAG,GAAG,CAAC,OAAO,CAsBvE"}