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

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 (225) 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 +7 -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} +103 -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 +7 -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 +389 -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 +2 -2
  138. package/lib/umd/react-ui.js.map +1 -1
  139. package/package.json +6 -6
  140. package/lib/cjs/components/Message/Message.d.ts +0 -83
  141. package/lib/cjs/components/Message/Message.d.ts.map +0 -1
  142. package/lib/cjs/components/Message/Message.js +0 -223
  143. package/lib/cjs/components/Message/Message.js.map +0 -1
  144. package/lib/cjs/components/Message/Skeleton.d.ts +0 -23
  145. package/lib/cjs/components/Message/Skeleton.d.ts.map +0 -1
  146. package/lib/cjs/components/Message/Skeleton.js.map +0 -1
  147. package/lib/cjs/components/Message/index.d.ts +0 -5
  148. package/lib/cjs/components/Message/index.d.ts.map +0 -1
  149. package/lib/cjs/components/Message/index.js.map +0 -1
  150. package/lib/cjs/components/MessageEditor/MessageEditor.d.ts +0 -48
  151. package/lib/cjs/components/MessageEditor/MessageEditor.d.ts.map +0 -1
  152. package/lib/cjs/components/MessageEditor/MessageEditor.js.map +0 -1
  153. package/lib/cjs/components/MessageEditor/MessageMediaUploader/index.d.ts.map +0 -1
  154. package/lib/cjs/components/MessageEditor/MessageMediaUploader/index.js.map +0 -1
  155. package/lib/cjs/components/MessageEditor/Skeleton.d.ts.map +0 -1
  156. package/lib/cjs/components/MessageEditor/Skeleton.js.map +0 -1
  157. package/lib/cjs/components/MessageEditor/index.d.ts +0 -5
  158. package/lib/cjs/components/MessageEditor/index.d.ts.map +0 -1
  159. package/lib/cjs/components/MessageEditor/index.js +0 -11
  160. package/lib/cjs/components/MessageEditor/index.js.map +0 -1
  161. package/lib/cjs/components/Snippets/Skeleton.d.ts +0 -23
  162. package/lib/cjs/components/Snippets/Skeleton.d.ts.map +0 -1
  163. package/lib/cjs/components/Snippets/Skeleton.js.map +0 -1
  164. package/lib/cjs/components/Snippets/Snippets.d.ts +0 -76
  165. package/lib/cjs/components/Snippets/Snippets.d.ts.map +0 -1
  166. package/lib/cjs/components/Snippets/Snippets.js +0 -231
  167. package/lib/cjs/components/Snippets/Snippets.js.map +0 -1
  168. package/lib/cjs/components/Snippets/index.d.ts +0 -5
  169. package/lib/cjs/components/Snippets/index.d.ts.map +0 -1
  170. package/lib/cjs/components/Snippets/index.js +0 -11
  171. package/lib/cjs/components/Snippets/index.js.map +0 -1
  172. package/lib/cjs/components/Thread/Skeleton.d.ts +0 -23
  173. package/lib/cjs/components/Thread/Skeleton.d.ts.map +0 -1
  174. package/lib/cjs/components/Thread/Skeleton.js.map +0 -1
  175. package/lib/cjs/components/Thread/Thread.d.ts +0 -93
  176. package/lib/cjs/components/Thread/Thread.d.ts.map +0 -1
  177. package/lib/cjs/components/Thread/Thread.js.map +0 -1
  178. package/lib/cjs/components/Thread/index.d.ts +0 -5
  179. package/lib/cjs/components/Thread/index.d.ts.map +0 -1
  180. package/lib/cjs/components/Thread/index.js.map +0 -1
  181. package/lib/esm/components/Message/Message.d.ts +0 -83
  182. package/lib/esm/components/Message/Message.d.ts.map +0 -1
  183. package/lib/esm/components/Message/Message.js +0 -194
  184. package/lib/esm/components/Message/Message.js.map +0 -1
  185. package/lib/esm/components/Message/Skeleton.d.ts +0 -23
  186. package/lib/esm/components/Message/Skeleton.d.ts.map +0 -1
  187. package/lib/esm/components/Message/Skeleton.js.map +0 -1
  188. package/lib/esm/components/Message/index.d.ts +0 -5
  189. package/lib/esm/components/Message/index.d.ts.map +0 -1
  190. package/lib/esm/components/Message/index.js +0 -5
  191. package/lib/esm/components/Message/index.js.map +0 -1
  192. package/lib/esm/components/MessageEditor/MessageEditor.d.ts +0 -48
  193. package/lib/esm/components/MessageEditor/MessageEditor.d.ts.map +0 -1
  194. package/lib/esm/components/MessageEditor/MessageEditor.js.map +0 -1
  195. package/lib/esm/components/MessageEditor/MessageMediaUploader/index.d.ts.map +0 -1
  196. package/lib/esm/components/MessageEditor/MessageMediaUploader/index.js.map +0 -1
  197. package/lib/esm/components/MessageEditor/Skeleton.d.ts.map +0 -1
  198. package/lib/esm/components/MessageEditor/Skeleton.js.map +0 -1
  199. package/lib/esm/components/MessageEditor/index.d.ts +0 -5
  200. package/lib/esm/components/MessageEditor/index.d.ts.map +0 -1
  201. package/lib/esm/components/MessageEditor/index.js +0 -5
  202. package/lib/esm/components/MessageEditor/index.js.map +0 -1
  203. package/lib/esm/components/Snippets/Skeleton.d.ts +0 -23
  204. package/lib/esm/components/Snippets/Skeleton.d.ts.map +0 -1
  205. package/lib/esm/components/Snippets/Skeleton.js +0 -39
  206. package/lib/esm/components/Snippets/Skeleton.js.map +0 -1
  207. package/lib/esm/components/Snippets/Snippets.d.ts +0 -76
  208. package/lib/esm/components/Snippets/Snippets.d.ts.map +0 -1
  209. package/lib/esm/components/Snippets/Snippets.js +0 -202
  210. package/lib/esm/components/Snippets/Snippets.js.map +0 -1
  211. package/lib/esm/components/Snippets/index.d.ts +0 -5
  212. package/lib/esm/components/Snippets/index.d.ts.map +0 -1
  213. package/lib/esm/components/Snippets/index.js +0 -5
  214. package/lib/esm/components/Snippets/index.js.map +0 -1
  215. package/lib/esm/components/Thread/Skeleton.d.ts +0 -23
  216. package/lib/esm/components/Thread/Skeleton.d.ts.map +0 -1
  217. package/lib/esm/components/Thread/Skeleton.js.map +0 -1
  218. package/lib/esm/components/Thread/Thread.d.ts +0 -93
  219. package/lib/esm/components/Thread/Thread.d.ts.map +0 -1
  220. package/lib/esm/components/Thread/Thread.js +0 -479
  221. package/lib/esm/components/Thread/Thread.js.map +0 -1
  222. package/lib/esm/components/Thread/index.d.ts +0 -5
  223. package/lib/esm/components/Thread/index.d.ts.map +0 -1
  224. package/lib/esm/components/Thread/index.js +0 -5
  225. 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,26 @@ 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
149
  const [newMessageUser, setNewMessageUser] = (0, react_1.useState)('');
233
150
  // REFS
234
151
  const refreshSubscription = (0, react_1.useRef)(null);
152
+ const authUserId = scUserContext.user ? scUserContext.user.id : null;
235
153
  // INTL
236
154
  const intl = (0, react_intl_1.useIntl)();
237
155
  // UTILS
238
156
  const format = (item) => intl.formatDate(item.created_at, {
239
- weekday: 'long',
157
+ year: 'numeric',
240
158
  day: 'numeric',
241
159
  month: 'long'
242
160
  });
@@ -257,16 +175,19 @@ function Thread(inProps) {
257
175
  return Object.assign(Object.assign({}, prevState), { [index]: false });
258
176
  });
259
177
  };
260
- const handleClose = () => {
178
+ const handleCloseDeleteDialog = () => {
261
179
  setOpenDeleteMessageDialog(false);
262
180
  };
263
- function handleDeleteDialog(msg) {
181
+ const handleOpenDeleteDialog = (msg) => {
264
182
  setOpenDeleteMessageDialog(true);
265
183
  setDeletingMsg(msg);
266
- }
184
+ };
267
185
  const selectRecipients = (event, recipient) => {
268
186
  setRecipients(recipient);
269
187
  };
188
+ /**
189
+ * Memoized message recipients ids
190
+ */
270
191
  const ids = (0, react_1.useMemo)(() => {
271
192
  if (recipients !== null && openNewMessage) {
272
193
  return recipients.map((u) => {
@@ -278,15 +199,15 @@ function Thread(inProps) {
278
199
  }
279
200
  }, [recipients]);
280
201
  /**
281
- * Handles deletion of a single message
202
+ * Handles the deletion of a single message
282
203
  */
283
204
  function handleDelete() {
284
205
  api_services_1.PrivateMessageService.deleteAMessage(deletingMsg.id)
285
206
  .then(() => {
286
207
  const result = messageObjs.filter((m) => m.id !== deletingMsg.id);
287
208
  setMessageObjs(result);
288
- shouldUpdate(true);
289
- handleClose();
209
+ threadCallbacks.onMessageSentOrDeleted(result.length > 1 ? result.slice(-1)[0] : deletingMsg, 'deleted');
210
+ handleCloseDeleteDialog();
290
211
  })
291
212
  .catch((error) => {
292
213
  console.log(error);
@@ -298,6 +219,11 @@ function Thread(inProps) {
298
219
  });
299
220
  });
300
221
  }
222
+ /**
223
+ * Sends a message
224
+ * @param m
225
+ * @param f
226
+ */
301
227
  function sendMessage(m, f) {
302
228
  if (react_core_1.UserUtils.isBlocked(scUserContext.user)) {
303
229
  enqueueSnackbar(react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.common.userBlocked", defaultMessage: "ui.common.userBlocked" }), {
@@ -318,10 +244,8 @@ function Thread(inProps) {
318
244
  })
319
245
  .then((res) => {
320
246
  setMessageObjs((prev) => [...prev, res.data]);
321
- onMessageSent(res.data);
247
+ threadCallbacks.onMessageSentOrDeleted(res.data, 'sent');
322
248
  if (openNewMessage || newMessageThread) {
323
- onNewMessageSent(res.data);
324
- shouldUpdate(true);
325
249
  setNewMessageThread(false);
326
250
  setRecipients([]);
327
251
  }
@@ -338,40 +262,27 @@ function Thread(inProps) {
338
262
  }
339
263
  }
340
264
  /**
341
- * Fetches user followers/connections
265
+ * Memoized fetchFollowers
342
266
  */
343
- function fetchFollowers() {
267
+ const fetchFollowers = (0, react_1.useMemo)(() => () => {
344
268
  let fetch;
345
269
  if (followEnabled) {
346
- fetch = api_services_1.UserService.getUserFollowers(scUserContext['user'].id);
270
+ fetch = api_services_1.UserService.getUserFollowers(authUserId);
347
271
  }
348
272
  else {
349
- fetch = api_services_1.UserService.getUserConnections(scUserContext['user'].id);
273
+ fetch = api_services_1.UserService.getUserConnections(authUserId);
350
274
  }
351
- fetch
275
+ return fetch
352
276
  .then((data) => {
353
277
  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
278
  setLoading(false);
370
279
  })
371
280
  .catch((error) => {
281
+ setLoading(false);
372
282
  console.log(error);
283
+ utils_1.Logger.error(Errors_1.SCOPE_SC_UI, { error });
373
284
  });
374
- }
285
+ }, []);
375
286
  /**
376
287
  * Fetches thread
377
288
  */
@@ -395,7 +306,7 @@ function Thread(inProps) {
395
306
  const data = res.data;
396
307
  setMessageObjs(data.results);
397
308
  if (data.results.length) {
398
- if (data.results[0].receiver.id !== loggedUser) {
309
+ if (data.results[0].receiver.id !== scUserContext.user.id) {
399
310
  setReceiver(data.results[0].receiver);
400
311
  }
401
312
  else {
@@ -404,13 +315,15 @@ function Thread(inProps) {
404
315
  setNewMessageThread(false);
405
316
  }
406
317
  else {
407
- setNewMessageThread(true);
318
+ // setNewMessageThread(true);
408
319
  setRecipients(u);
409
320
  }
410
321
  setLoading(false);
411
322
  })
412
323
  .catch((error) => {
324
+ setLoading(false);
413
325
  console.log(error);
326
+ utils_1.Logger.error(Errors_1.SCOPE_SC_UI, { error });
414
327
  });
415
328
  }
416
329
  /**
@@ -418,14 +331,17 @@ function Thread(inProps) {
418
331
  * if openNewMessage is true, fetches user followers too.
419
332
  */
420
333
  (0, react_1.useEffect)(() => {
421
- if (userObj) {
422
- fetchThread();
423
- fetchFollowers();
424
- }
425
- if (openNewMessage) {
426
- fetchFollowers();
334
+ userObj && fetchThread();
335
+ openNewMessage && fetchFollowers();
336
+ }, [userObj, openNewMessage, authUserId]);
337
+ /**
338
+ * Checks is thread receiver is a user follower
339
+ */
340
+ (0, react_1.useEffect)(() => {
341
+ if (receiver) {
342
+ setIsFollower(scFollowersManager.isFollower(receiver));
427
343
  }
428
- }, [userObj, openNewMessage]);
344
+ });
429
345
  /**
430
346
  * When a ws notification arrives, update data
431
347
  */
@@ -451,47 +367,41 @@ function Thread(inProps) {
451
367
  * @return {JSX.Element}
452
368
  */
453
369
  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 })));
370
+ return (react_1.default.createElement(material_1.CardContent, null,
371
+ isMobile && receiver && (react_1.default.createElement(material_1.Box, { className: classes.mobileHeader },
372
+ react_1.default.createElement(material_1.Box, { className: classes.mobileHeaderContent },
373
+ react_1.default.createElement(Icon_1.default, { onClick: () => threadCallbacks.onMessageBack('default') }, "chevron_left"),
374
+ react_1.default.createElement(material_1.Avatar, { alt: receiver.username, src: receiver.avatar }),
375
+ react_1.default.createElement(material_1.Typography, { variant: "body1", color: "inherit" }, receiver.username)),
376
+ react_1.default.createElement(Icon_1.default, { fontSize: "medium", onClick: threadCallbacks.onThreadDelete }, "delete"))),
377
+ 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 })),
378
+ 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 },
379
+ react_1.default.createElement("ul", null,
380
+ react_1.default.createElement(material_1.ListSubheader, null,
381
+ react_1.default.createElement(material_1.Typography, { align: "center", className: classes.subHeader }, key)),
382
+ 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) })))))))),
383
+ react_1.default.createElement(PrivateMessageEditor_1.default, { send: (m, f) => sendMessage(m, f), autoHide: !isFollower, onThreadChangeId: userObj })));
470
384
  }
471
385
  /**
472
386
  * Renders empty box (when there is no thread open) or new message box
473
387
  * @return {JSX.Element}
474
388
  */
475
389
  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" }))))));
390
+ return (react_1.default.createElement(material_1.CardContent, null, openNewMessage || newMessageThread ? (react_1.default.createElement(react_1.default.Fragment, null,
391
+ react_1.default.createElement(material_1.Box, { className: classes.newMessageHeader },
392
+ react_1.default.createElement(material_1.Box, { className: classes.newMessageHeaderContent },
393
+ react_1.default.createElement(Icon_1.default, { className: classes.newMessageHeaderIcon }, "person"),
394
+ react_1.default.createElement(material_1.Typography, null,
395
+ react_1.default.createElement(react_intl_1.FormattedMessage, { defaultMessage: "ui.privateMessage.thread.newMessage.to", id: "ui.privateMessage.thread.newMessage.to" })),
396
+ react_1.default.createElement(Autocomplete_1.default, { className: classes.autocomplete, multiple: !newMessageThread, limitTags: 3, 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 })),
397
+ react_1.default.createElement(material_1.IconButton, { size: "small", onClick: threadCallbacks.onMessageBack },
398
+ react_1.default.createElement(Icon_1.default, { fontSize: "small" }, "close"))),
399
+ 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 },
400
+ react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.privateMessage.thread.emptyBox.message", defaultMessage: "ui.privateMessage.thread.emptyBox.message" })))));
491
401
  }
492
402
  // Anonymous
493
403
  if (!scUserContext.user) {
494
- return null;
404
+ return react_1.default.createElement(HiddenPlaceholder_1.default, null);
495
405
  }
496
406
  if (loading && userObj) {
497
407
  return react_1.default.createElement(Skeleton_1.default, null);
@@ -504,5 +414,5 @@ function Thread(inProps) {
504
414
  }
505
415
  return null;
506
416
  }
507
- exports.default = Thread;
508
- //# sourceMappingURL=Thread.js.map
417
+ exports.default = PrivateMessageThread;
418
+ //# 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"}