@droppii-org/chat-mobile 0.2.6 → 0.2.8

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 (398) hide show
  1. package/lib/module/components/AttachmentPreview.js +250 -0
  2. package/lib/module/components/AttachmentPreview.js.map +1 -0
  3. package/lib/module/components/MediaViewer/index.js +2 -0
  4. package/lib/module/components/MediaViewer/index.js.map +1 -0
  5. package/lib/module/components/MediaViewerModal.js +57 -0
  6. package/lib/module/components/MediaViewerModal.js.map +1 -0
  7. package/lib/module/components/MergedImageGrid.js +173 -0
  8. package/lib/module/components/MergedImageGrid.js.map +1 -0
  9. package/lib/module/components/ThreadCard/AvatarSection.js +4 -4
  10. package/lib/module/components/ThreadCard/AvatarSection.js.map +1 -1
  11. package/lib/module/components/ThreadCard/NamePrefixIcon.js +13 -16
  12. package/lib/module/components/ThreadCard/NamePrefixIcon.js.map +1 -1
  13. package/lib/module/components/ThreadCard/ThreadCard.js +13 -33
  14. package/lib/module/components/ThreadCard/ThreadCard.js.map +1 -1
  15. package/lib/module/components/ThreadCard/thread-card.utils.js +80 -4
  16. package/lib/module/components/ThreadCard/thread-card.utils.js.map +1 -1
  17. package/lib/module/components/messages/fileMessage/index.js +26 -0
  18. package/lib/module/components/messages/fileMessage/index.js.map +1 -0
  19. package/lib/module/components/messages/imageMessage/index.js +118 -0
  20. package/lib/module/components/messages/imageMessage/index.js.map +1 -0
  21. package/lib/module/components/messages/linkMessage/index.js +122 -0
  22. package/lib/module/components/messages/linkMessage/index.js.map +1 -0
  23. package/lib/module/components/messages/mergedMessage/index.js +37 -0
  24. package/lib/module/components/messages/mergedMessage/index.js.map +1 -0
  25. package/lib/module/components/messages/styles.js +41 -0
  26. package/lib/module/components/messages/styles.js.map +1 -0
  27. package/lib/module/components/messages/textMessage/index.js +38 -0
  28. package/lib/module/components/messages/textMessage/index.js.map +1 -0
  29. package/lib/module/components/messages/types.js +14 -0
  30. package/lib/module/components/messages/types.js.map +1 -0
  31. package/lib/module/components/messages/videoMessage/index.js +110 -0
  32. package/lib/module/components/messages/videoMessage/index.js.map +1 -0
  33. package/lib/module/config/api-endpoints.js +66 -0
  34. package/lib/module/config/api-endpoints.js.map +1 -0
  35. package/lib/module/config/attachment-priority.js +81 -0
  36. package/lib/module/config/attachment-priority.js.map +1 -0
  37. package/lib/module/config/configuration.js +50 -0
  38. package/lib/module/config/configuration.js.map +1 -0
  39. package/lib/module/config/index.js +22 -0
  40. package/lib/module/config/index.js.map +1 -0
  41. package/lib/module/context/ChatContext.js +7 -6
  42. package/lib/module/context/ChatContext.js.map +1 -1
  43. package/lib/module/core/index.js +19 -1
  44. package/lib/module/core/index.js.map +1 -1
  45. package/lib/module/core/useChatListener.js +0 -14
  46. package/lib/module/core/useChatListener.js.map +1 -1
  47. package/lib/module/hooks/message/useSendMessage.js +106 -0
  48. package/lib/module/hooks/message/useSendMessage.js.map +1 -0
  49. package/lib/module/hooks/useChatMessages.js +36 -121
  50. package/lib/module/hooks/useChatMessages.js.map +1 -1
  51. package/lib/module/hooks/useConversationList.js +29 -17
  52. package/lib/module/hooks/useConversationList.js.map +1 -1
  53. package/lib/module/hooks/useImageAttachment.js +263 -0
  54. package/lib/module/hooks/useImageAttachment.js.map +1 -0
  55. package/lib/module/hooks/useLinkPreview/useLinkPreview.js +3 -2
  56. package/lib/module/hooks/useLinkPreview/useLinkPreview.js.map +1 -1
  57. package/lib/module/hooks/useMediaViewer.js +24 -0
  58. package/lib/module/hooks/useMediaViewer.js.map +1 -0
  59. package/lib/module/hooks/useSendAttachment.js +182 -0
  60. package/lib/module/hooks/useSendAttachment.js.map +1 -0
  61. package/lib/module/hooks/useVideoAttachment.js +251 -0
  62. package/lib/module/hooks/useVideoAttachment.js.map +1 -0
  63. package/lib/module/index.js +13 -1
  64. package/lib/module/index.js.map +1 -1
  65. package/lib/module/screens/MediaView/VideoPlayer.js +177 -0
  66. package/lib/module/screens/MediaView/VideoPlayer.js.map +1 -0
  67. package/lib/module/screens/MediaView/index.js +264 -0
  68. package/lib/module/screens/MediaView/index.js.map +1 -0
  69. package/lib/module/screens/chat-detail/ChatComposer.js +190 -196
  70. package/lib/module/screens/chat-detail/ChatComposer.js.map +1 -1
  71. package/lib/module/screens/chat-detail/ChatDetail.js +106 -71
  72. package/lib/module/screens/chat-detail/ChatDetail.js.map +1 -1
  73. package/lib/module/screens/chat-detail/ChatDetailHeader.js +5 -8
  74. package/lib/module/screens/chat-detail/ChatDetailHeader.js.map +1 -1
  75. package/lib/module/screens/chat-detail/ChatLinkPreview.js +1 -1
  76. package/lib/module/screens/chat-detail/ChatLinkPreview.js.map +1 -1
  77. package/lib/module/screens/chat-detail/ChatListLegend.js +5 -15
  78. package/lib/module/screens/chat-detail/ChatListLegend.js.map +1 -1
  79. package/lib/module/screens/chat-detail/components/ChatInputActions.js +51 -0
  80. package/lib/module/screens/chat-detail/components/ChatInputActions.js.map +1 -0
  81. package/lib/module/screens/chat-detail/components/ChatMessageInput.js +93 -0
  82. package/lib/module/screens/chat-detail/components/ChatMessageInput.js.map +1 -0
  83. package/lib/module/screens/chat-detail/conversationHeader.utils.js +7 -9
  84. package/lib/module/screens/chat-detail/conversationHeader.utils.js.map +1 -1
  85. package/lib/module/screens/chat-detail/hooks/useAttachmentSendHandler.js +221 -0
  86. package/lib/module/screens/chat-detail/hooks/useAttachmentSendHandler.js.map +1 -0
  87. package/lib/module/screens/chat-detail/hooks/useChatComposerAnimation.js +114 -0
  88. package/lib/module/screens/chat-detail/hooks/useChatComposerAnimation.js.map +1 -0
  89. package/lib/module/screens/chat-detail/hooks/useChatComposerState.js +26 -0
  90. package/lib/module/screens/chat-detail/hooks/useChatComposerState.js.map +1 -0
  91. package/lib/module/screens/chat-detail/index.js +0 -1
  92. package/lib/module/screens/chat-detail/index.js.map +1 -1
  93. package/lib/module/screens/chat-detail/legend/LegendChatMessage.js +32 -25
  94. package/lib/module/screens/chat-detail/legend/LegendChatMessage.js.map +1 -1
  95. package/lib/module/screens/chat-detail/legend/messageTypes.js +15 -0
  96. package/lib/module/screens/chat-detail/legend/messageTypes.js.map +1 -0
  97. package/lib/module/screens/inbox/MessagesTab.js.map +1 -1
  98. package/lib/module/services/attachmentHandlers/fileAttachmentHandler.js +61 -0
  99. package/lib/module/services/attachmentHandlers/fileAttachmentHandler.js.map +1 -0
  100. package/lib/module/services/attachmentHandlers/imageAttachmentHandler.js +54 -0
  101. package/lib/module/services/attachmentHandlers/imageAttachmentHandler.js.map +1 -0
  102. package/lib/module/services/attachmentHandlers/index.js +12 -0
  103. package/lib/module/services/attachmentHandlers/index.js.map +1 -0
  104. package/lib/module/services/attachmentHandlers/videoAttachmentHandler.js +85 -0
  105. package/lib/module/services/attachmentHandlers/videoAttachmentHandler.js.map +1 -0
  106. package/lib/module/services/attachmentOrchestrator.js +225 -0
  107. package/lib/module/services/attachmentOrchestrator.js.map +1 -0
  108. package/lib/module/services/auth.js +35 -0
  109. package/lib/module/services/auth.js.map +1 -0
  110. package/lib/module/services/endpoints.js +20 -1
  111. package/lib/module/services/endpoints.js.map +1 -1
  112. package/lib/module/services/imageUpload.js +126 -0
  113. package/lib/module/services/imageUpload.js.map +1 -0
  114. package/lib/module/store/conversation.js +1 -1
  115. package/lib/module/store/conversation.js.map +1 -1
  116. package/lib/module/store/message.js +45 -0
  117. package/lib/module/store/message.js.map +1 -0
  118. package/lib/module/translation/resources/i18n.js +22 -2
  119. package/lib/module/translation/resources/i18n.js.map +1 -1
  120. package/lib/module/types/attachment.js +2 -0
  121. package/lib/module/types/attachment.js.map +1 -0
  122. package/lib/module/types/attachmentHandler.js +20 -0
  123. package/lib/module/types/attachmentHandler.js.map +1 -0
  124. package/lib/module/types/chat.js +2 -7
  125. package/lib/module/types/chat.js.map +1 -1
  126. package/lib/module/types/imageUpload.js +2 -0
  127. package/lib/module/types/imageUpload.js.map +1 -0
  128. package/lib/module/types/message.js +1 -0
  129. package/lib/module/types/message.js.map +1 -1
  130. package/lib/module/utils/chatImageDimens.js +148 -0
  131. package/lib/module/utils/chatImageDimens.js.map +1 -0
  132. package/lib/module/utils/conversation.js +34 -13
  133. package/lib/module/utils/conversation.js.map +1 -1
  134. package/lib/module/utils/device.js +65 -0
  135. package/lib/module/utils/device.js.map +1 -0
  136. package/lib/module/utils/imageUrlOptimizer.js +41 -0
  137. package/lib/module/utils/imageUrlOptimizer.js.map +1 -0
  138. package/lib/module/utils/imageUtils.js +69 -0
  139. package/lib/module/utils/imageUtils.js.map +1 -0
  140. package/lib/module/utils/legendListMessage.js +0 -3
  141. package/lib/module/utils/legendListMessage.js.map +1 -1
  142. package/lib/module/utils/message.js +5 -8
  143. package/lib/module/utils/message.js.map +1 -1
  144. package/lib/module/utils/resolveMessageType.js +3 -0
  145. package/lib/module/utils/resolveMessageType.js.map +1 -1
  146. package/lib/module/utils/ui.js +17 -0
  147. package/lib/module/utils/ui.js.map +1 -0
  148. package/lib/module/utils/url.js +3 -3
  149. package/lib/module/utils/url.js.map +1 -1
  150. package/lib/module/utils/videoThumbnail.js +62 -0
  151. package/lib/module/utils/videoThumbnail.js.map +1 -0
  152. package/lib/typescript/src/components/AttachmentPreview.d.ts +28 -0
  153. package/lib/typescript/src/components/AttachmentPreview.d.ts.map +1 -0
  154. package/lib/typescript/src/components/MediaViewer/index.d.ts +1 -0
  155. package/lib/typescript/src/components/MediaViewer/index.d.ts.map +1 -0
  156. package/lib/typescript/src/components/MediaViewerModal.d.ts +10 -0
  157. package/lib/typescript/src/components/MediaViewerModal.d.ts.map +1 -0
  158. package/lib/typescript/src/components/MergedImageGrid.d.ts +16 -0
  159. package/lib/typescript/src/components/MergedImageGrid.d.ts.map +1 -0
  160. package/lib/typescript/src/components/ThreadCard/AvatarSection.d.ts +2 -2
  161. package/lib/typescript/src/components/ThreadCard/AvatarSection.d.ts.map +1 -1
  162. package/lib/typescript/src/components/ThreadCard/NamePrefixIcon.d.ts +3 -4
  163. package/lib/typescript/src/components/ThreadCard/NamePrefixIcon.d.ts.map +1 -1
  164. package/lib/typescript/src/components/ThreadCard/ThreadCard.d.ts.map +1 -1
  165. package/lib/typescript/src/components/ThreadCard/thread-card.utils.d.ts.map +1 -1
  166. package/lib/typescript/src/components/messages/fileMessage/index.d.ts +3 -0
  167. package/lib/typescript/src/components/messages/fileMessage/index.d.ts.map +1 -0
  168. package/lib/typescript/src/components/messages/imageMessage/index.d.ts +3 -0
  169. package/lib/typescript/src/components/messages/imageMessage/index.d.ts.map +1 -0
  170. package/lib/typescript/src/components/messages/linkMessage/index.d.ts +9 -0
  171. package/lib/typescript/src/components/messages/linkMessage/index.d.ts.map +1 -0
  172. package/lib/typescript/src/components/messages/mergedMessage/index.d.ts +3 -0
  173. package/lib/typescript/src/components/messages/mergedMessage/index.d.ts.map +1 -0
  174. package/lib/typescript/src/components/messages/styles.d.ts +36 -0
  175. package/lib/typescript/src/components/messages/styles.d.ts.map +1 -0
  176. package/lib/typescript/src/components/messages/textMessage/index.d.ts +9 -0
  177. package/lib/typescript/src/components/messages/textMessage/index.d.ts.map +1 -0
  178. package/lib/typescript/src/components/messages/types.d.ts +10 -0
  179. package/lib/typescript/src/components/messages/types.d.ts.map +1 -0
  180. package/lib/typescript/src/components/messages/videoMessage/index.d.ts +3 -0
  181. package/lib/typescript/src/components/messages/videoMessage/index.d.ts.map +1 -0
  182. package/lib/typescript/src/config/api-endpoints.d.ts +40 -0
  183. package/lib/typescript/src/config/api-endpoints.d.ts.map +1 -0
  184. package/lib/typescript/src/config/attachment-priority.d.ts +31 -0
  185. package/lib/typescript/src/config/attachment-priority.d.ts.map +1 -0
  186. package/lib/typescript/src/config/configuration.d.ts +30 -0
  187. package/lib/typescript/src/config/configuration.d.ts.map +1 -0
  188. package/lib/typescript/src/config/index.d.ts +15 -0
  189. package/lib/typescript/src/config/index.d.ts.map +1 -0
  190. package/lib/typescript/src/context/ChatContext.d.ts +1 -1
  191. package/lib/typescript/src/context/ChatContext.d.ts.map +1 -1
  192. package/lib/typescript/src/core/index.d.ts +13 -1
  193. package/lib/typescript/src/core/index.d.ts.map +1 -1
  194. package/lib/typescript/src/core/useChatListener.d.ts.map +1 -1
  195. package/lib/typescript/src/hooks/message/useSendMessage.d.ts +12 -0
  196. package/lib/typescript/src/hooks/message/useSendMessage.d.ts.map +1 -0
  197. package/lib/typescript/src/hooks/useChatMessages.d.ts +0 -1
  198. package/lib/typescript/src/hooks/useChatMessages.d.ts.map +1 -1
  199. package/lib/typescript/src/hooks/useConversationList.d.ts +2 -1
  200. package/lib/typescript/src/hooks/useConversationList.d.ts.map +1 -1
  201. package/lib/typescript/src/hooks/useImageAttachment.d.ts +20 -0
  202. package/lib/typescript/src/hooks/useImageAttachment.d.ts.map +1 -0
  203. package/lib/typescript/src/hooks/useLinkPreview/useLinkPreview.d.ts.map +1 -1
  204. package/lib/typescript/src/hooks/useMediaViewer.d.ts +13 -0
  205. package/lib/typescript/src/hooks/useMediaViewer.d.ts.map +1 -0
  206. package/lib/typescript/src/hooks/useSendAttachment.d.ts +59 -0
  207. package/lib/typescript/src/hooks/useSendAttachment.d.ts.map +1 -0
  208. package/lib/typescript/src/hooks/useVideoAttachment.d.ts +29 -0
  209. package/lib/typescript/src/hooks/useVideoAttachment.d.ts.map +1 -0
  210. package/lib/typescript/src/index.d.ts +14 -1
  211. package/lib/typescript/src/index.d.ts.map +1 -1
  212. package/lib/typescript/src/screens/MediaView/VideoPlayer.d.ts +12 -0
  213. package/lib/typescript/src/screens/MediaView/VideoPlayer.d.ts.map +1 -0
  214. package/lib/typescript/src/screens/MediaView/index.d.ts +11 -0
  215. package/lib/typescript/src/screens/MediaView/index.d.ts.map +1 -0
  216. package/lib/typescript/src/screens/chat-detail/ChatComposer.d.ts +1 -1
  217. package/lib/typescript/src/screens/chat-detail/ChatComposer.d.ts.map +1 -1
  218. package/lib/typescript/src/screens/chat-detail/ChatDetail.d.ts +1 -1
  219. package/lib/typescript/src/screens/chat-detail/ChatDetail.d.ts.map +1 -1
  220. package/lib/typescript/src/screens/chat-detail/ChatDetailHeader.d.ts +1 -1
  221. package/lib/typescript/src/screens/chat-detail/ChatDetailHeader.d.ts.map +1 -1
  222. package/lib/typescript/src/screens/chat-detail/ChatListLegend.d.ts +1 -1
  223. package/lib/typescript/src/screens/chat-detail/ChatListLegend.d.ts.map +1 -1
  224. package/lib/typescript/src/screens/chat-detail/components/ChatInputActions.d.ts +8 -0
  225. package/lib/typescript/src/screens/chat-detail/components/ChatInputActions.d.ts.map +1 -0
  226. package/lib/typescript/src/screens/chat-detail/components/ChatMessageInput.d.ts +15 -0
  227. package/lib/typescript/src/screens/chat-detail/components/ChatMessageInput.d.ts.map +1 -0
  228. package/lib/typescript/src/screens/chat-detail/conversationHeader.utils.d.ts +1 -1
  229. package/lib/typescript/src/screens/chat-detail/conversationHeader.utils.d.ts.map +1 -1
  230. package/lib/typescript/src/screens/chat-detail/hooks/useAttachmentSendHandler.d.ts +23 -0
  231. package/lib/typescript/src/screens/chat-detail/hooks/useAttachmentSendHandler.d.ts.map +1 -0
  232. package/lib/typescript/src/screens/chat-detail/hooks/useChatComposerAnimation.d.ts +15 -0
  233. package/lib/typescript/src/screens/chat-detail/hooks/useChatComposerAnimation.d.ts.map +1 -0
  234. package/lib/typescript/src/screens/chat-detail/hooks/useChatComposerState.d.ts +13 -0
  235. package/lib/typescript/src/screens/chat-detail/hooks/useChatComposerState.d.ts.map +1 -0
  236. package/lib/typescript/src/screens/chat-detail/index.d.ts +0 -2
  237. package/lib/typescript/src/screens/chat-detail/index.d.ts.map +1 -1
  238. package/lib/typescript/src/screens/chat-detail/legend/LegendChatMessage.d.ts +3 -3
  239. package/lib/typescript/src/screens/chat-detail/legend/LegendChatMessage.d.ts.map +1 -1
  240. package/lib/typescript/src/screens/chat-detail/legend/messageTypes.d.ts +13 -0
  241. package/lib/typescript/src/screens/chat-detail/legend/messageTypes.d.ts.map +1 -0
  242. package/lib/typescript/src/screens/chat-detail/types.d.ts +10 -8
  243. package/lib/typescript/src/screens/chat-detail/types.d.ts.map +1 -1
  244. package/lib/typescript/src/services/attachmentHandlers/fileAttachmentHandler.d.ts +22 -0
  245. package/lib/typescript/src/services/attachmentHandlers/fileAttachmentHandler.d.ts.map +1 -0
  246. package/lib/typescript/src/services/attachmentHandlers/imageAttachmentHandler.d.ts +3 -0
  247. package/lib/typescript/src/services/attachmentHandlers/imageAttachmentHandler.d.ts.map +1 -0
  248. package/lib/typescript/src/services/attachmentHandlers/index.d.ts +5 -0
  249. package/lib/typescript/src/services/attachmentHandlers/index.d.ts.map +1 -0
  250. package/lib/typescript/src/services/attachmentHandlers/videoAttachmentHandler.d.ts +31 -0
  251. package/lib/typescript/src/services/attachmentHandlers/videoAttachmentHandler.d.ts.map +1 -0
  252. package/lib/typescript/src/services/attachmentOrchestrator.d.ts +5 -0
  253. package/lib/typescript/src/services/attachmentOrchestrator.d.ts.map +1 -0
  254. package/lib/typescript/src/services/auth.d.ts +19 -0
  255. package/lib/typescript/src/services/auth.d.ts.map +1 -0
  256. package/lib/typescript/src/services/endpoints.d.ts +11 -1
  257. package/lib/typescript/src/services/endpoints.d.ts.map +1 -1
  258. package/lib/typescript/src/services/imageUpload.d.ts +7 -0
  259. package/lib/typescript/src/services/imageUpload.d.ts.map +1 -0
  260. package/lib/typescript/src/store/message.d.ts +3 -0
  261. package/lib/typescript/src/store/message.d.ts.map +1 -0
  262. package/lib/typescript/src/translation/resources/i18n.d.ts.map +1 -1
  263. package/lib/typescript/src/types/attachment.d.ts +72 -0
  264. package/lib/typescript/src/types/attachment.d.ts.map +1 -0
  265. package/lib/typescript/src/types/attachmentHandler.d.ts +13 -0
  266. package/lib/typescript/src/types/attachmentHandler.d.ts.map +1 -0
  267. package/lib/typescript/src/types/chat.d.ts +28 -27
  268. package/lib/typescript/src/types/chat.d.ts.map +1 -1
  269. package/lib/typescript/src/types/common.d.ts +1 -0
  270. package/lib/typescript/src/types/common.d.ts.map +1 -1
  271. package/lib/typescript/src/types/imageUpload.d.ts +26 -0
  272. package/lib/typescript/src/types/imageUpload.d.ts.map +1 -0
  273. package/lib/typescript/src/types/message.d.ts +1 -0
  274. package/lib/typescript/src/types/message.d.ts.map +1 -1
  275. package/lib/typescript/src/utils/chatImageDimens.d.ts +34 -0
  276. package/lib/typescript/src/utils/chatImageDimens.d.ts.map +1 -0
  277. package/lib/typescript/src/utils/conversation.d.ts +3 -2
  278. package/lib/typescript/src/utils/conversation.d.ts.map +1 -1
  279. package/lib/typescript/src/utils/device.d.ts +7 -0
  280. package/lib/typescript/src/utils/device.d.ts.map +1 -0
  281. package/lib/typescript/src/utils/imageUrlOptimizer.d.ts +12 -0
  282. package/lib/typescript/src/utils/imageUrlOptimizer.d.ts.map +1 -0
  283. package/lib/typescript/src/utils/imageUtils.d.ts +9 -0
  284. package/lib/typescript/src/utils/imageUtils.d.ts.map +1 -0
  285. package/lib/typescript/src/utils/legendListMessage.d.ts +0 -2
  286. package/lib/typescript/src/utils/legendListMessage.d.ts.map +1 -1
  287. package/lib/typescript/src/utils/message.d.ts.map +1 -1
  288. package/lib/typescript/src/utils/resolveMessageType.d.ts.map +1 -1
  289. package/lib/typescript/src/utils/ui.d.ts +13 -0
  290. package/lib/typescript/src/utils/ui.d.ts.map +1 -0
  291. package/lib/typescript/src/utils/url.d.ts +1 -1
  292. package/lib/typescript/src/utils/url.d.ts.map +1 -1
  293. package/lib/typescript/src/utils/videoThumbnail.d.ts +16 -0
  294. package/lib/typescript/src/utils/videoThumbnail.d.ts.map +1 -0
  295. package/package.json +15 -3
  296. package/src/components/AttachmentPreview.tsx +304 -0
  297. package/src/components/MediaViewer/index.tsx +0 -0
  298. package/src/components/MediaViewerModal.tsx +70 -0
  299. package/src/components/MergedImageGrid.tsx +238 -0
  300. package/src/components/ThreadCard/AvatarSection.tsx +5 -8
  301. package/src/components/ThreadCard/NamePrefixIcon.tsx +27 -38
  302. package/src/components/ThreadCard/ThreadCard.tsx +16 -30
  303. package/src/components/ThreadCard/thread-card.utils.ts +95 -4
  304. package/src/components/messages/fileMessage/index.tsx +30 -0
  305. package/src/components/messages/imageMessage/index.tsx +137 -0
  306. package/src/components/messages/linkMessage/index.tsx +162 -0
  307. package/src/components/messages/mergedMessage/index.tsx +45 -0
  308. package/src/components/messages/styles.ts +39 -0
  309. package/src/components/messages/textMessage/index.tsx +53 -0
  310. package/src/components/messages/types.ts +22 -0
  311. package/src/components/messages/videoMessage/index.tsx +120 -0
  312. package/src/config/api-endpoints.ts +72 -0
  313. package/src/config/attachment-priority.ts +93 -0
  314. package/src/config/configuration.ts +50 -0
  315. package/src/config/index.ts +19 -0
  316. package/src/context/ChatContext.tsx +12 -4
  317. package/src/core/index.ts +25 -1
  318. package/src/core/useChatListener.ts +0 -21
  319. package/src/hooks/message/useSendMessage.ts +143 -0
  320. package/src/hooks/useChatMessages.ts +69 -161
  321. package/src/hooks/useConversationList.ts +34 -16
  322. package/src/hooks/useImageAttachment.ts +348 -0
  323. package/src/hooks/useLinkPreview/useLinkPreview.ts +3 -2
  324. package/src/hooks/useMediaViewer.ts +32 -0
  325. package/src/hooks/useSendAttachment.ts +295 -0
  326. package/src/hooks/useVideoAttachment.ts +334 -0
  327. package/src/index.tsx +13 -1
  328. package/src/screens/MediaView/VideoPlayer.tsx +211 -0
  329. package/src/screens/MediaView/index.tsx +327 -0
  330. package/src/screens/chat-detail/ChatComposer.tsx +206 -271
  331. package/src/screens/chat-detail/ChatDetail.tsx +164 -104
  332. package/src/screens/chat-detail/ChatDetailHeader.tsx +4 -10
  333. package/src/screens/chat-detail/ChatLinkPreview.tsx +1 -1
  334. package/src/screens/chat-detail/ChatListLegend.tsx +10 -13
  335. package/src/screens/chat-detail/components/ChatInputActions.tsx +71 -0
  336. package/src/screens/chat-detail/components/ChatMessageInput.tsx +127 -0
  337. package/src/screens/chat-detail/conversationHeader.utils.ts +11 -14
  338. package/src/screens/chat-detail/hooks/useAttachmentSendHandler.ts +291 -0
  339. package/src/screens/chat-detail/hooks/useChatComposerAnimation.ts +184 -0
  340. package/src/screens/chat-detail/hooks/useChatComposerState.ts +40 -0
  341. package/src/screens/chat-detail/index.ts +0 -2
  342. package/src/screens/chat-detail/legend/LegendChatMessage.tsx +44 -39
  343. package/src/screens/chat-detail/legend/messageTypes.tsx +13 -0
  344. package/src/screens/chat-detail/types.ts +11 -9
  345. package/src/screens/inbox/MessagesTab.tsx +1 -1
  346. package/src/services/attachmentHandlers/fileAttachmentHandler.ts +78 -0
  347. package/src/services/attachmentHandlers/imageAttachmentHandler.ts +54 -0
  348. package/src/services/attachmentHandlers/index.ts +10 -0
  349. package/src/services/attachmentHandlers/videoAttachmentHandler.ts +114 -0
  350. package/src/services/attachmentOrchestrator.ts +300 -0
  351. package/src/services/auth.ts +34 -0
  352. package/src/services/endpoints.ts +24 -1
  353. package/src/services/imageUpload.ts +162 -0
  354. package/src/store/conversation.ts +1 -1
  355. package/src/store/message.ts +44 -0
  356. package/src/translation/resources/i18n.ts +22 -2
  357. package/src/types/attachment.ts +85 -0
  358. package/src/types/attachmentHandler.ts +31 -0
  359. package/src/types/chat.ts +31 -30
  360. package/src/types/common.ts +1 -0
  361. package/src/types/imageUpload.ts +28 -0
  362. package/src/types/message.ts +1 -0
  363. package/src/utils/chatImageDimens.ts +178 -0
  364. package/src/utils/conversation.ts +44 -17
  365. package/src/utils/device.ts +73 -0
  366. package/src/utils/imageUrlOptimizer.ts +56 -0
  367. package/src/utils/imageUtils.ts +76 -0
  368. package/src/utils/legendListMessage.ts +0 -5
  369. package/src/utils/message.ts +10 -12
  370. package/src/utils/resolveMessageType.ts +2 -0
  371. package/src/utils/ui.ts +19 -0
  372. package/src/utils/url.ts +3 -3
  373. package/src/utils/videoThumbnail.ts +85 -0
  374. package/lib/module/screens/chat-detail/ChatList.js +0 -147
  375. package/lib/module/screens/chat-detail/ChatList.js.map +0 -1
  376. package/lib/module/screens/chat-detail/ChatTextBubble.js +0 -62
  377. package/lib/module/screens/chat-detail/ChatTextBubble.js.map +0 -1
  378. package/lib/module/screens/chat-detail/legend/message-types.js +0 -122
  379. package/lib/module/screens/chat-detail/legend/message-types.js.map +0 -1
  380. package/lib/module/screens/chat-detail/messages/ChatMessageBubble.js +0 -24
  381. package/lib/module/screens/chat-detail/messages/ChatMessageBubble.js.map +0 -1
  382. package/lib/module/screens/chat-detail/messages/types.js +0 -4
  383. package/lib/module/screens/chat-detail/messages/types.js.map +0 -1
  384. package/lib/typescript/src/screens/chat-detail/ChatList.d.ts +0 -3
  385. package/lib/typescript/src/screens/chat-detail/ChatList.d.ts.map +0 -1
  386. package/lib/typescript/src/screens/chat-detail/ChatTextBubble.d.ts +0 -3
  387. package/lib/typescript/src/screens/chat-detail/ChatTextBubble.d.ts.map +0 -1
  388. package/lib/typescript/src/screens/chat-detail/legend/message-types.d.ts +0 -12
  389. package/lib/typescript/src/screens/chat-detail/legend/message-types.d.ts.map +0 -1
  390. package/lib/typescript/src/screens/chat-detail/messages/ChatMessageBubble.d.ts +0 -3
  391. package/lib/typescript/src/screens/chat-detail/messages/ChatMessageBubble.d.ts.map +0 -1
  392. package/lib/typescript/src/screens/chat-detail/messages/types.d.ts +0 -13
  393. package/lib/typescript/src/screens/chat-detail/messages/types.d.ts.map +0 -1
  394. package/src/screens/chat-detail/ChatList.tsx +0 -190
  395. package/src/screens/chat-detail/ChatTextBubble.tsx +0 -73
  396. package/src/screens/chat-detail/legend/message-types.tsx +0 -149
  397. package/src/screens/chat-detail/messages/ChatMessageBubble.tsx +0 -23
  398. package/src/screens/chat-detail/messages/types.ts +0 -14
@@ -7,11 +7,10 @@ import { ChatMessageAPI } from '../services/message';
7
7
  import type { DMessageItem } from '../types/chat';
8
8
  import {
9
9
  belongsToConversation,
10
- getHistoryPaginationAnchor,
11
10
  hasNewHistoryMessages,
12
11
  mergeMessages,
13
- type HistoryPaginationAnchor,
14
12
  } from '../utils/message';
13
+ import { useMessageStore } from '../store/message';
15
14
 
16
15
  type UseChatMessagesOptions = {
17
16
  conversationId: string;
@@ -24,44 +23,24 @@ export function useChatMessages({
24
23
  enabled = true,
25
24
  pageSize = 20,
26
25
  }: UseChatMessagesOptions) {
27
- const [messages, setMessages] = useState<DMessageItem[]>([]);
26
+ const messages = useMessageStore((s) => s.messages);
27
+ const hasMoreEarlier = useMessageStore((s) => s.hasMoreEarlier);
28
+ const hasMoreNewer = useMessageStore((s) => s.hasMoreNewer);
29
+ const setMessages = useMessageStore((s) => s.setMessages);
30
+ const pushNewMessage = useMessageStore((s) => s.pushNewMessage);
31
+ const reset = useMessageStore((s) => s.reset);
32
+
28
33
  const [currentUserId, setCurrentUserId] = useState<string>();
29
34
  const [isLoading, setIsLoading] = useState(false);
30
35
  const [isLoadingEarlier, setIsLoadingEarlier] = useState(false);
31
- const [hasMoreEarlier, setHasMoreEarlier] = useState(false);
32
36
  const [isLoadingNewer, setIsLoadingNewer] = useState(false);
33
- const [hasMoreNewer, setHasMoreNewer] = useState(false);
34
37
  const [error, setError] = useState<Error | null>(null);
35
38
 
36
39
  const conversationIdRef = useRef(conversationId);
37
40
  conversationIdRef.current = conversationId;
38
41
 
39
- const isLoadingEarlierRef = useRef(false);
40
- const isLoadingNewerRef = useRef(false);
41
- const messagesRef = useRef(messages);
42
- const hasMoreEarlierRef = useRef(hasMoreEarlier);
43
- const hasMoreNewerRef = useRef(hasMoreNewer);
44
- const historyAnchorRef = useRef<HistoryPaginationAnchor | null>(null);
45
- const newestAnchorRef = useRef<HistoryPaginationAnchor | null>(null);
46
- messagesRef.current = messages;
47
- hasMoreEarlierRef.current = hasMoreEarlier;
48
- hasMoreNewerRef.current = hasMoreNewer;
49
-
50
- const resetState = useCallback(() => {
51
- setMessages([]);
52
- setHasMoreEarlier(false);
53
- setHasMoreNewer(false);
54
- setError(null);
55
- isLoadingEarlierRef.current = false;
56
- isLoadingNewerRef.current = false;
57
- historyAnchorRef.current = null;
58
- newestAnchorRef.current = null;
59
- }, []);
60
-
61
- const loadInitialMessages = useCallback(async () => {
62
- if (!conversationId) {
63
- return;
64
- }
42
+ const fetchInitial = useCallback(async () => {
43
+ if (!conversationId) return;
65
44
 
66
45
  setIsLoading(true);
67
46
  setError(null);
@@ -75,22 +54,9 @@ export function useChatMessages({
75
54
  ]);
76
55
 
77
56
  const initialMessages = history.messageList as DMessageItem[];
78
- const oldestAnchor = getHistoryPaginationAnchor(initialMessages);
79
57
 
80
58
  setCurrentUserId(userId);
81
- setMessages(mergeMessages([], initialMessages));
82
- historyAnchorRef.current = oldestAnchor
83
- ? {
84
- clientMsgID: oldestAnchor.clientMsgID,
85
- // lastMinSeq: resolveHistoryLastMinSeq(
86
- // history,
87
- // initialMessages.find(
88
- // (message) => message.clientMsgID === oldestAnchor.clientMsgID
89
- // )
90
- // ),
91
- }
92
- : null;
93
- setHasMoreEarlier(!history.isEnd && !!oldestAnchor);
59
+ setMessages(mergeMessages([], initialMessages), !history.isEnd);
94
60
 
95
61
  ChatMessageAPI.markConversationAsRead(conversationId).catch(
96
62
  () => undefined
@@ -100,177 +66,120 @@ export function useChatMessages({
100
66
  } finally {
101
67
  setIsLoading(false);
102
68
  }
103
- }, [conversationId, pageSize]);
69
+ }, [conversationId, pageSize, setMessages]);
104
70
 
105
71
  const onLoadEarlier = useCallback(async () => {
106
- if (
107
- !conversationId ||
108
- isLoadingEarlierRef.current ||
109
- !hasMoreEarlierRef.current ||
110
- !messagesRef.current.length
111
- ) {
112
- return;
113
- }
72
+ if (isLoadingEarlier || !hasMoreEarlier || !messages.length) return;
114
73
 
115
- isLoadingEarlierRef.current = true;
116
74
  setIsLoadingEarlier(true);
117
75
  setError(null);
118
76
 
119
- const anchor = historyAnchorRef.current;
120
- if (!anchor?.clientMsgID) {
121
- isLoadingEarlierRef.current = false;
122
- setIsLoadingEarlier(false);
123
- return;
124
- }
125
-
126
77
  try {
127
78
  const history = await ChatMessageAPI.fetchHistoryMessages(
128
79
  conversationId,
129
80
  {
130
81
  count: pageSize,
131
- startClientMsgID: anchor.clientMsgID,
82
+ startClientMsgID: messages[0]!.clientMsgID,
132
83
  }
133
84
  );
134
- const incoming = history.messageList as DMessageItem[];
135
- const hasNewMessages = hasNewHistoryMessages(
136
- messagesRef.current,
137
- incoming
138
- );
139
85
 
140
- if (hasNewMessages) {
141
- setMessages((current) => mergeMessages(current, incoming));
86
+ const incoming = history.messageList as DMessageItem[];
87
+ const hasNew = hasNewHistoryMessages(messages, incoming);
88
+
89
+ if (hasNew) {
90
+ setMessages(
91
+ mergeMessages(messages, incoming),
92
+ !history.isEnd && hasNew
93
+ );
94
+ } else {
95
+ setMessages(messages, false);
142
96
  }
143
-
144
- const nextAnchor = getHistoryPaginationAnchor(incoming);
145
- historyAnchorRef.current = nextAnchor
146
- ? {
147
- clientMsgID: nextAnchor.clientMsgID,
148
- // lastMinSeq: resolveHistoryLastMinSeq(
149
- // history,
150
- // incoming.find(
151
- // (message) => message.clientMsgID === nextAnchor.clientMsgID
152
- // )
153
- // ),
154
- }
155
- : null;
156
-
157
- setHasMoreEarlier(!history.isEnd && hasNewMessages && !!nextAnchor);
158
97
  } catch (err) {
159
98
  setError(err instanceof Error ? err : new Error(String(err)));
160
99
  } finally {
161
- isLoadingEarlierRef.current = false;
162
100
  setIsLoadingEarlier(false);
163
101
  }
164
- }, [conversationId, pageSize]);
102
+ }, [
103
+ conversationId,
104
+ hasMoreEarlier,
105
+ isLoadingEarlier,
106
+ messages,
107
+ pageSize,
108
+ setMessages,
109
+ ]);
165
110
 
166
111
  const onLoadNewer = useCallback(async () => {
167
- if (
168
- !conversationId ||
169
- isLoadingNewerRef.current ||
170
- !hasMoreNewerRef.current ||
171
- !messagesRef.current.length
172
- ) {
173
- return;
174
- }
112
+ if (isLoadingNewer || !hasMoreNewer || !messages.length) return;
175
113
 
176
- isLoadingNewerRef.current = true;
177
114
  setIsLoadingNewer(true);
178
115
  setError(null);
179
116
 
180
- const anchor = newestAnchorRef.current;
181
- if (!anchor?.clientMsgID && messagesRef.current.length === 0) {
182
- isLoadingNewerRef.current = false;
183
- setIsLoadingNewer(false);
184
- return;
185
- }
186
-
187
117
  try {
188
- // Get the newest message ID to load from
189
- const newestMessage = messagesRef.current[messagesRef.current.length - 1];
190
118
  const history = await ChatMessageAPI.fetchHistoryMessages(
191
119
  conversationId,
192
120
  {
193
121
  count: pageSize,
194
- startClientMsgID: newestMessage?.clientMsgID,
122
+ startClientMsgID: messages[messages.length - 1]!.clientMsgID,
195
123
  }
196
124
  );
197
125
 
198
126
  const incoming = history.messageList as DMessageItem[];
199
- const hasNewMessages = incoming.length > 0;
127
+ const hasNew = incoming.length > 0;
200
128
 
201
- if (hasNewMessages) {
202
- setMessages((current) => mergeMessages(current, incoming));
129
+ if (hasNew) {
130
+ setMessages(
131
+ mergeMessages(messages, incoming),
132
+ !history.isEnd && hasNew
133
+ );
203
134
  }
204
-
205
- setHasMoreNewer(!history.isEnd && hasNewMessages);
206
135
  } catch (err) {
207
136
  setError(err instanceof Error ? err : new Error(String(err)));
208
137
  } finally {
209
- isLoadingNewerRef.current = false;
210
138
  setIsLoadingNewer(false);
211
139
  }
212
- }, [conversationId, pageSize]);
213
-
214
- const sendTextMessage = useCallback(async (text: string) => {
215
- const trimmed = text.trim();
216
- if (!trimmed) {
217
- return;
218
- }
219
-
220
- const sentMessage = await ChatMessageAPI.sendTextMessage({
221
- text: trimmed,
222
- });
223
-
224
- setMessages((current) => mergeMessages(current, [sentMessage]));
225
- }, []);
226
-
227
- const appendIncomingMessages = useCallback((incoming: MessageItem[]) => {
228
- const relevant = incoming.filter((message) =>
229
- belongsToConversation(message, conversationIdRef.current)
230
- );
231
-
232
- if (!relevant.length) {
233
- return;
234
- }
140
+ }, [
141
+ conversationId,
142
+ hasMoreNewer,
143
+ isLoadingNewer,
144
+ messages,
145
+ pageSize,
146
+ setMessages,
147
+ ]);
148
+
149
+ const appendIncomingMessages = useCallback(
150
+ (incoming: MessageItem[]) => {
151
+ const relevant = incoming.filter((message) =>
152
+ belongsToConversation(message, conversationIdRef.current)
153
+ );
235
154
 
236
- setMessages((current) =>
237
- mergeMessages(current, relevant as DMessageItem[])
238
- );
155
+ if (!relevant.length) return;
239
156
 
240
- ChatMessageAPI.markConversationAsRead(conversationIdRef.current).catch(
241
- () => undefined
242
- );
243
- }, []);
157
+ relevant.forEach((msg) => pushNewMessage(msg));
158
+ ChatMessageAPI.markConversationAsRead(conversationIdRef.current).catch(
159
+ () => undefined
160
+ );
161
+ },
162
+ [pushNewMessage]
163
+ );
244
164
 
245
165
  useEffect(() => {
246
- resetState();
166
+ reset();
247
167
 
248
- if (!enabled || !conversationId) {
249
- return;
250
- }
168
+ if (!enabled || !conversationId) return;
251
169
 
252
- loadInitialMessages();
253
- }, [conversationId, enabled, loadInitialMessages, resetState]);
170
+ fetchInitial();
171
+ }, [conversationId, enabled, fetchInitial, reset]);
254
172
 
255
173
  useEffect(() => {
256
- if (!enabled || !conversationId) {
257
- return;
258
- }
174
+ if (!enabled || !conversationId) return;
259
175
 
260
- const handleNewMessages = (incoming: MessageItem[]) => {
176
+ const handleNewMessages = (incoming: MessageItem[]) =>
261
177
  appendIncomingMessages(incoming);
262
- };
263
-
264
- const handleNewMessage = (incoming: MessageItem) => {
265
- appendIncomingMessages([incoming]);
266
- };
267
178
 
268
179
  OpenIMSDK.on(OpenIMEvent.OnRecvNewMessages, handleNewMessages);
269
- OpenIMSDK.on(OpenIMEvent.OnRecvNewMessage, handleNewMessage);
270
180
 
271
181
  return () => {
272
182
  OpenIMSDK.off(OpenIMEvent.OnRecvNewMessages, handleNewMessages);
273
- OpenIMSDK.off(OpenIMEvent.OnRecvNewMessage, handleNewMessage);
274
183
  };
275
184
  }, [appendIncomingMessages, conversationId, enabled]);
276
185
 
@@ -285,7 +194,6 @@ export function useChatMessages({
285
194
  error,
286
195
  onLoadEarlier,
287
196
  onLoadNewer,
288
- sendTextMessage,
289
- refresh: loadInitialMessages,
197
+ refresh: fetchInitial,
290
198
  };
291
199
  }
@@ -1,10 +1,11 @@
1
1
  import { useEffect } from 'react';
2
2
  import { useQuery } from '@tanstack/react-query';
3
- import OpenIMSDK from '@droppii/openim-rn-client-sdk';
4
- import { ChatAPI } from '../services';
3
+ import OpenIMSDK, {
4
+ type ConversationItem,
5
+ } from '@droppii/openim-rn-client-sdk';
5
6
  import { conversationQueryKeys } from './query-keys';
6
7
  import { useConversationStore } from '../store';
7
- import { mergeOpenIMIntoConversation } from '../utils/conversation';
8
+ import type { DConversationItem, DMessageItem } from '../types/chat';
8
9
 
9
10
  type Params = {
10
11
  applicationType: string;
@@ -12,6 +13,29 @@ type Params = {
12
13
  enabled?: boolean;
13
14
  };
14
15
 
16
+ function toConversationItem(raw: ConversationItem): DConversationItem {
17
+ let lastMessage: DMessageItem | undefined;
18
+ if (raw.latestMsg) {
19
+ try {
20
+ lastMessage = JSON.parse(raw.latestMsg) as DMessageItem;
21
+ } catch {
22
+ // leave undefined
23
+ }
24
+ }
25
+
26
+ let applicationType: string | undefined;
27
+ if (raw.ex) {
28
+ try {
29
+ applicationType = (JSON.parse(raw.ex) as { applicationType?: string })
30
+ .applicationType;
31
+ } catch {
32
+ // leave undefined
33
+ }
34
+ }
35
+
36
+ return { ...(raw as DConversationItem), lastMessage, applicationType };
37
+ }
38
+
15
39
  export function useConversationList({
16
40
  applicationType,
17
41
  page = 1,
@@ -26,21 +50,15 @@ export function useConversationList({
26
50
  enabled: enabled !== false,
27
51
  queryFn: async () => {
28
52
  const offset = (page - 1) * 20;
29
- const [{ data: droppiiList }, openimList] = await Promise.all([
30
- ChatAPI.queryConversations({ applicationType, page, pageSize: 20 }),
31
- OpenIMSDK.getConversationListSplit({ offset, count: 20 }),
32
- ]);
33
- const openimMap = new Map(openimList.map((c) => [c.conversationID, c]));
34
-
35
- const merged = droppiiList.map((conv) => {
36
- const openimConv = openimMap.get(conv.conversationId);
37
- return openimConv
38
- ? mergeOpenIMIntoConversation(conv, openimConv)
39
- : conv;
53
+ const rawList = await OpenIMSDK.getConversationListSplitApp({
54
+ offset,
55
+ count: 20,
56
+ applicationType,
40
57
  });
41
58
 
42
- useConversationStore.getState().updateConversations(merged);
43
- return merged;
59
+ const conversations = rawList.map(toConversationItem);
60
+ useConversationStore.getState().updateConversations(conversations);
61
+ return conversations;
44
62
  },
45
63
  });
46
64