@droppii-org/chat-mobile 0.2.7 → 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 (323) 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/thread-card.utils.js +80 -4
  10. package/lib/module/components/ThreadCard/thread-card.utils.js.map +1 -1
  11. package/lib/module/components/messages/fileMessage/index.js +26 -0
  12. package/lib/module/components/messages/fileMessage/index.js.map +1 -0
  13. package/lib/module/components/messages/imageMessage/index.js +118 -0
  14. package/lib/module/components/messages/imageMessage/index.js.map +1 -0
  15. package/lib/module/components/messages/linkMessage/index.js +122 -0
  16. package/lib/module/components/messages/linkMessage/index.js.map +1 -0
  17. package/lib/module/components/messages/mergedMessage/index.js +37 -0
  18. package/lib/module/components/messages/mergedMessage/index.js.map +1 -0
  19. package/lib/module/components/messages/styles.js +41 -0
  20. package/lib/module/components/messages/styles.js.map +1 -0
  21. package/lib/module/components/messages/textMessage/index.js +38 -0
  22. package/lib/module/components/messages/textMessage/index.js.map +1 -0
  23. package/lib/module/components/messages/types.js +14 -0
  24. package/lib/module/components/messages/types.js.map +1 -0
  25. package/lib/module/components/messages/videoMessage/index.js +110 -0
  26. package/lib/module/components/messages/videoMessage/index.js.map +1 -0
  27. package/lib/module/config/api-endpoints.js +66 -0
  28. package/lib/module/config/api-endpoints.js.map +1 -0
  29. package/lib/module/config/attachment-priority.js +81 -0
  30. package/lib/module/config/attachment-priority.js.map +1 -0
  31. package/lib/module/config/configuration.js +50 -0
  32. package/lib/module/config/configuration.js.map +1 -0
  33. package/lib/module/config/index.js +22 -0
  34. package/lib/module/config/index.js.map +1 -0
  35. package/lib/module/core/index.js +19 -1
  36. package/lib/module/core/index.js.map +1 -1
  37. package/lib/module/core/useChatListener.js +0 -14
  38. package/lib/module/core/useChatListener.js.map +1 -1
  39. package/lib/module/hooks/message/useSendMessage.js +10 -5
  40. package/lib/module/hooks/message/useSendMessage.js.map +1 -1
  41. package/lib/module/hooks/useChatMessages.js +0 -3
  42. package/lib/module/hooks/useChatMessages.js.map +1 -1
  43. package/lib/module/hooks/useImageAttachment.js +263 -0
  44. package/lib/module/hooks/useImageAttachment.js.map +1 -0
  45. package/lib/module/hooks/useMediaViewer.js +24 -0
  46. package/lib/module/hooks/useMediaViewer.js.map +1 -0
  47. package/lib/module/hooks/useSendAttachment.js +182 -0
  48. package/lib/module/hooks/useSendAttachment.js.map +1 -0
  49. package/lib/module/hooks/useVideoAttachment.js +251 -0
  50. package/lib/module/hooks/useVideoAttachment.js.map +1 -0
  51. package/lib/module/index.js +13 -1
  52. package/lib/module/index.js.map +1 -1
  53. package/lib/module/screens/MediaView/VideoPlayer.js +177 -0
  54. package/lib/module/screens/MediaView/VideoPlayer.js.map +1 -0
  55. package/lib/module/screens/MediaView/index.js +264 -0
  56. package/lib/module/screens/MediaView/index.js.map +1 -0
  57. package/lib/module/screens/chat-detail/ChatComposer.js +190 -196
  58. package/lib/module/screens/chat-detail/ChatComposer.js.map +1 -1
  59. package/lib/module/screens/chat-detail/ChatDetail.js +94 -63
  60. package/lib/module/screens/chat-detail/ChatDetail.js.map +1 -1
  61. package/lib/module/screens/chat-detail/ChatListLegend.js +5 -13
  62. package/lib/module/screens/chat-detail/ChatListLegend.js.map +1 -1
  63. package/lib/module/screens/chat-detail/components/ChatInputActions.js +51 -0
  64. package/lib/module/screens/chat-detail/components/ChatInputActions.js.map +1 -0
  65. package/lib/module/screens/chat-detail/components/ChatMessageInput.js +93 -0
  66. package/lib/module/screens/chat-detail/components/ChatMessageInput.js.map +1 -0
  67. package/lib/module/screens/chat-detail/hooks/useAttachmentSendHandler.js +221 -0
  68. package/lib/module/screens/chat-detail/hooks/useAttachmentSendHandler.js.map +1 -0
  69. package/lib/module/screens/chat-detail/hooks/useChatComposerAnimation.js +114 -0
  70. package/lib/module/screens/chat-detail/hooks/useChatComposerAnimation.js.map +1 -0
  71. package/lib/module/screens/chat-detail/hooks/useChatComposerState.js +26 -0
  72. package/lib/module/screens/chat-detail/hooks/useChatComposerState.js.map +1 -0
  73. package/lib/module/screens/chat-detail/index.js +0 -1
  74. package/lib/module/screens/chat-detail/index.js.map +1 -1
  75. package/lib/module/screens/chat-detail/legend/LegendChatMessage.js +33 -13
  76. package/lib/module/screens/chat-detail/legend/LegendChatMessage.js.map +1 -1
  77. package/lib/module/screens/chat-detail/legend/messageTypes.js +15 -0
  78. package/lib/module/screens/chat-detail/legend/messageTypes.js.map +1 -0
  79. package/lib/module/screens/inbox/MessagesTab.js.map +1 -1
  80. package/lib/module/services/attachmentHandlers/fileAttachmentHandler.js +61 -0
  81. package/lib/module/services/attachmentHandlers/fileAttachmentHandler.js.map +1 -0
  82. package/lib/module/services/attachmentHandlers/imageAttachmentHandler.js +54 -0
  83. package/lib/module/services/attachmentHandlers/imageAttachmentHandler.js.map +1 -0
  84. package/lib/module/services/attachmentHandlers/index.js +12 -0
  85. package/lib/module/services/attachmentHandlers/index.js.map +1 -0
  86. package/lib/module/services/attachmentHandlers/videoAttachmentHandler.js +85 -0
  87. package/lib/module/services/attachmentHandlers/videoAttachmentHandler.js.map +1 -0
  88. package/lib/module/services/attachmentOrchestrator.js +225 -0
  89. package/lib/module/services/attachmentOrchestrator.js.map +1 -0
  90. package/lib/module/services/auth.js +35 -0
  91. package/lib/module/services/auth.js.map +1 -0
  92. package/lib/module/services/endpoints.js +20 -1
  93. package/lib/module/services/endpoints.js.map +1 -1
  94. package/lib/module/services/imageUpload.js +126 -0
  95. package/lib/module/services/imageUpload.js.map +1 -0
  96. package/lib/module/translation/resources/i18n.js +22 -8
  97. package/lib/module/translation/resources/i18n.js.map +1 -1
  98. package/lib/module/types/attachment.js +2 -0
  99. package/lib/module/types/attachment.js.map +1 -0
  100. package/lib/module/types/attachmentHandler.js +20 -0
  101. package/lib/module/types/attachmentHandler.js.map +1 -0
  102. package/lib/module/types/imageUpload.js +2 -0
  103. package/lib/module/types/imageUpload.js.map +1 -0
  104. package/lib/module/types/message.js +1 -0
  105. package/lib/module/types/message.js.map +1 -1
  106. package/lib/module/utils/chatImageDimens.js +148 -0
  107. package/lib/module/utils/chatImageDimens.js.map +1 -0
  108. package/lib/module/utils/device.js +65 -0
  109. package/lib/module/utils/device.js.map +1 -0
  110. package/lib/module/utils/imageUrlOptimizer.js +41 -0
  111. package/lib/module/utils/imageUrlOptimizer.js.map +1 -0
  112. package/lib/module/utils/imageUtils.js +69 -0
  113. package/lib/module/utils/imageUtils.js.map +1 -0
  114. package/lib/module/utils/resolveMessageType.js +3 -0
  115. package/lib/module/utils/resolveMessageType.js.map +1 -1
  116. package/lib/module/utils/ui.js +17 -0
  117. package/lib/module/utils/ui.js.map +1 -0
  118. package/lib/module/utils/url.js +1 -1
  119. package/lib/module/utils/url.js.map +1 -1
  120. package/lib/module/utils/videoThumbnail.js +62 -0
  121. package/lib/module/utils/videoThumbnail.js.map +1 -0
  122. package/lib/typescript/src/components/AttachmentPreview.d.ts +28 -0
  123. package/lib/typescript/src/components/AttachmentPreview.d.ts.map +1 -0
  124. package/lib/typescript/src/components/MediaViewer/index.d.ts +1 -0
  125. package/lib/typescript/src/components/MediaViewer/index.d.ts.map +1 -0
  126. package/lib/typescript/src/components/MediaViewerModal.d.ts +10 -0
  127. package/lib/typescript/src/components/MediaViewerModal.d.ts.map +1 -0
  128. package/lib/typescript/src/components/MergedImageGrid.d.ts +16 -0
  129. package/lib/typescript/src/components/MergedImageGrid.d.ts.map +1 -0
  130. package/lib/typescript/src/components/ThreadCard/thread-card.utils.d.ts.map +1 -1
  131. package/lib/typescript/src/components/messages/fileMessage/index.d.ts +3 -0
  132. package/lib/typescript/src/components/messages/fileMessage/index.d.ts.map +1 -0
  133. package/lib/typescript/src/components/messages/imageMessage/index.d.ts +3 -0
  134. package/lib/typescript/src/components/messages/imageMessage/index.d.ts.map +1 -0
  135. package/lib/typescript/src/components/messages/linkMessage/index.d.ts +9 -0
  136. package/lib/typescript/src/components/messages/linkMessage/index.d.ts.map +1 -0
  137. package/lib/typescript/src/components/messages/mergedMessage/index.d.ts +3 -0
  138. package/lib/typescript/src/components/messages/mergedMessage/index.d.ts.map +1 -0
  139. package/lib/typescript/src/components/messages/styles.d.ts +36 -0
  140. package/lib/typescript/src/components/messages/styles.d.ts.map +1 -0
  141. package/lib/typescript/src/components/messages/textMessage/index.d.ts +9 -0
  142. package/lib/typescript/src/components/messages/textMessage/index.d.ts.map +1 -0
  143. package/lib/typescript/src/components/messages/types.d.ts +10 -0
  144. package/lib/typescript/src/components/messages/types.d.ts.map +1 -0
  145. package/lib/typescript/src/components/messages/videoMessage/index.d.ts +3 -0
  146. package/lib/typescript/src/components/messages/videoMessage/index.d.ts.map +1 -0
  147. package/lib/typescript/src/config/api-endpoints.d.ts +40 -0
  148. package/lib/typescript/src/config/api-endpoints.d.ts.map +1 -0
  149. package/lib/typescript/src/config/attachment-priority.d.ts +31 -0
  150. package/lib/typescript/src/config/attachment-priority.d.ts.map +1 -0
  151. package/lib/typescript/src/config/configuration.d.ts +30 -0
  152. package/lib/typescript/src/config/configuration.d.ts.map +1 -0
  153. package/lib/typescript/src/config/index.d.ts +15 -0
  154. package/lib/typescript/src/config/index.d.ts.map +1 -0
  155. package/lib/typescript/src/core/index.d.ts +13 -1
  156. package/lib/typescript/src/core/index.d.ts.map +1 -1
  157. package/lib/typescript/src/core/useChatListener.d.ts.map +1 -1
  158. package/lib/typescript/src/hooks/message/useSendMessage.d.ts.map +1 -1
  159. package/lib/typescript/src/hooks/useChatMessages.d.ts.map +1 -1
  160. package/lib/typescript/src/hooks/useImageAttachment.d.ts +20 -0
  161. package/lib/typescript/src/hooks/useImageAttachment.d.ts.map +1 -0
  162. package/lib/typescript/src/hooks/useMediaViewer.d.ts +13 -0
  163. package/lib/typescript/src/hooks/useMediaViewer.d.ts.map +1 -0
  164. package/lib/typescript/src/hooks/useSendAttachment.d.ts +59 -0
  165. package/lib/typescript/src/hooks/useSendAttachment.d.ts.map +1 -0
  166. package/lib/typescript/src/hooks/useVideoAttachment.d.ts +29 -0
  167. package/lib/typescript/src/hooks/useVideoAttachment.d.ts.map +1 -0
  168. package/lib/typescript/src/index.d.ts +14 -1
  169. package/lib/typescript/src/index.d.ts.map +1 -1
  170. package/lib/typescript/src/screens/MediaView/VideoPlayer.d.ts +12 -0
  171. package/lib/typescript/src/screens/MediaView/VideoPlayer.d.ts.map +1 -0
  172. package/lib/typescript/src/screens/MediaView/index.d.ts +11 -0
  173. package/lib/typescript/src/screens/MediaView/index.d.ts.map +1 -0
  174. package/lib/typescript/src/screens/chat-detail/ChatComposer.d.ts +1 -1
  175. package/lib/typescript/src/screens/chat-detail/ChatComposer.d.ts.map +1 -1
  176. package/lib/typescript/src/screens/chat-detail/ChatDetail.d.ts +1 -1
  177. package/lib/typescript/src/screens/chat-detail/ChatDetail.d.ts.map +1 -1
  178. package/lib/typescript/src/screens/chat-detail/ChatListLegend.d.ts +1 -1
  179. package/lib/typescript/src/screens/chat-detail/ChatListLegend.d.ts.map +1 -1
  180. package/lib/typescript/src/screens/chat-detail/components/ChatInputActions.d.ts +8 -0
  181. package/lib/typescript/src/screens/chat-detail/components/ChatInputActions.d.ts.map +1 -0
  182. package/lib/typescript/src/screens/chat-detail/components/ChatMessageInput.d.ts +15 -0
  183. package/lib/typescript/src/screens/chat-detail/components/ChatMessageInput.d.ts.map +1 -0
  184. package/lib/typescript/src/screens/chat-detail/hooks/useAttachmentSendHandler.d.ts +23 -0
  185. package/lib/typescript/src/screens/chat-detail/hooks/useAttachmentSendHandler.d.ts.map +1 -0
  186. package/lib/typescript/src/screens/chat-detail/hooks/useChatComposerAnimation.d.ts +15 -0
  187. package/lib/typescript/src/screens/chat-detail/hooks/useChatComposerAnimation.d.ts.map +1 -0
  188. package/lib/typescript/src/screens/chat-detail/hooks/useChatComposerState.d.ts +13 -0
  189. package/lib/typescript/src/screens/chat-detail/hooks/useChatComposerState.d.ts.map +1 -0
  190. package/lib/typescript/src/screens/chat-detail/index.d.ts +0 -2
  191. package/lib/typescript/src/screens/chat-detail/index.d.ts.map +1 -1
  192. package/lib/typescript/src/screens/chat-detail/legend/LegendChatMessage.d.ts +3 -1
  193. package/lib/typescript/src/screens/chat-detail/legend/LegendChatMessage.d.ts.map +1 -1
  194. package/lib/typescript/src/screens/chat-detail/legend/messageTypes.d.ts +13 -0
  195. package/lib/typescript/src/screens/chat-detail/legend/messageTypes.d.ts.map +1 -0
  196. package/lib/typescript/src/screens/chat-detail/types.d.ts +4 -1
  197. package/lib/typescript/src/screens/chat-detail/types.d.ts.map +1 -1
  198. package/lib/typescript/src/services/attachmentHandlers/fileAttachmentHandler.d.ts +22 -0
  199. package/lib/typescript/src/services/attachmentHandlers/fileAttachmentHandler.d.ts.map +1 -0
  200. package/lib/typescript/src/services/attachmentHandlers/imageAttachmentHandler.d.ts +3 -0
  201. package/lib/typescript/src/services/attachmentHandlers/imageAttachmentHandler.d.ts.map +1 -0
  202. package/lib/typescript/src/services/attachmentHandlers/index.d.ts +5 -0
  203. package/lib/typescript/src/services/attachmentHandlers/index.d.ts.map +1 -0
  204. package/lib/typescript/src/services/attachmentHandlers/videoAttachmentHandler.d.ts +31 -0
  205. package/lib/typescript/src/services/attachmentHandlers/videoAttachmentHandler.d.ts.map +1 -0
  206. package/lib/typescript/src/services/attachmentOrchestrator.d.ts +5 -0
  207. package/lib/typescript/src/services/attachmentOrchestrator.d.ts.map +1 -0
  208. package/lib/typescript/src/services/auth.d.ts +19 -0
  209. package/lib/typescript/src/services/auth.d.ts.map +1 -0
  210. package/lib/typescript/src/services/endpoints.d.ts +11 -1
  211. package/lib/typescript/src/services/endpoints.d.ts.map +1 -1
  212. package/lib/typescript/src/services/imageUpload.d.ts +7 -0
  213. package/lib/typescript/src/services/imageUpload.d.ts.map +1 -0
  214. package/lib/typescript/src/translation/resources/i18n.d.ts.map +1 -1
  215. package/lib/typescript/src/types/attachment.d.ts +72 -0
  216. package/lib/typescript/src/types/attachment.d.ts.map +1 -0
  217. package/lib/typescript/src/types/attachmentHandler.d.ts +13 -0
  218. package/lib/typescript/src/types/attachmentHandler.d.ts.map +1 -0
  219. package/lib/typescript/src/types/imageUpload.d.ts +26 -0
  220. package/lib/typescript/src/types/imageUpload.d.ts.map +1 -0
  221. package/lib/typescript/src/types/message.d.ts +1 -0
  222. package/lib/typescript/src/types/message.d.ts.map +1 -1
  223. package/lib/typescript/src/utils/chatImageDimens.d.ts +34 -0
  224. package/lib/typescript/src/utils/chatImageDimens.d.ts.map +1 -0
  225. package/lib/typescript/src/utils/device.d.ts +7 -0
  226. package/lib/typescript/src/utils/device.d.ts.map +1 -0
  227. package/lib/typescript/src/utils/imageUrlOptimizer.d.ts +12 -0
  228. package/lib/typescript/src/utils/imageUrlOptimizer.d.ts.map +1 -0
  229. package/lib/typescript/src/utils/imageUtils.d.ts +9 -0
  230. package/lib/typescript/src/utils/imageUtils.d.ts.map +1 -0
  231. package/lib/typescript/src/utils/resolveMessageType.d.ts.map +1 -1
  232. package/lib/typescript/src/utils/ui.d.ts +13 -0
  233. package/lib/typescript/src/utils/ui.d.ts.map +1 -0
  234. package/lib/typescript/src/utils/videoThumbnail.d.ts +16 -0
  235. package/lib/typescript/src/utils/videoThumbnail.d.ts.map +1 -0
  236. package/package.json +15 -3
  237. package/src/components/AttachmentPreview.tsx +304 -0
  238. package/src/components/MediaViewer/index.tsx +0 -0
  239. package/src/components/MediaViewerModal.tsx +70 -0
  240. package/src/components/MergedImageGrid.tsx +238 -0
  241. package/src/components/ThreadCard/thread-card.utils.ts +95 -4
  242. package/src/components/messages/fileMessage/index.tsx +30 -0
  243. package/src/components/messages/imageMessage/index.tsx +137 -0
  244. package/src/components/messages/linkMessage/index.tsx +162 -0
  245. package/src/components/messages/mergedMessage/index.tsx +45 -0
  246. package/src/components/messages/styles.ts +39 -0
  247. package/src/components/messages/textMessage/index.tsx +53 -0
  248. package/src/components/messages/types.ts +22 -0
  249. package/src/components/messages/videoMessage/index.tsx +120 -0
  250. package/src/config/api-endpoints.ts +72 -0
  251. package/src/config/attachment-priority.ts +93 -0
  252. package/src/config/configuration.ts +50 -0
  253. package/src/config/index.ts +19 -0
  254. package/src/core/index.ts +25 -1
  255. package/src/core/useChatListener.ts +0 -21
  256. package/src/hooks/message/useSendMessage.ts +12 -5
  257. package/src/hooks/useChatMessages.ts +0 -4
  258. package/src/hooks/useImageAttachment.ts +348 -0
  259. package/src/hooks/useMediaViewer.ts +32 -0
  260. package/src/hooks/useSendAttachment.ts +295 -0
  261. package/src/hooks/useVideoAttachment.ts +334 -0
  262. package/src/index.tsx +13 -1
  263. package/src/screens/MediaView/VideoPlayer.tsx +211 -0
  264. package/src/screens/MediaView/index.tsx +327 -0
  265. package/src/screens/chat-detail/ChatComposer.tsx +206 -271
  266. package/src/screens/chat-detail/ChatDetail.tsx +142 -89
  267. package/src/screens/chat-detail/ChatListLegend.tsx +9 -11
  268. package/src/screens/chat-detail/components/ChatInputActions.tsx +71 -0
  269. package/src/screens/chat-detail/components/ChatMessageInput.tsx +127 -0
  270. package/src/screens/chat-detail/hooks/useAttachmentSendHandler.ts +291 -0
  271. package/src/screens/chat-detail/hooks/useChatComposerAnimation.ts +184 -0
  272. package/src/screens/chat-detail/hooks/useChatComposerState.ts +40 -0
  273. package/src/screens/chat-detail/index.ts +0 -2
  274. package/src/screens/chat-detail/legend/LegendChatMessage.tsx +47 -24
  275. package/src/screens/chat-detail/legend/messageTypes.tsx +13 -0
  276. package/src/screens/chat-detail/types.ts +5 -1
  277. package/src/screens/inbox/MessagesTab.tsx +1 -1
  278. package/src/services/attachmentHandlers/fileAttachmentHandler.ts +78 -0
  279. package/src/services/attachmentHandlers/imageAttachmentHandler.ts +54 -0
  280. package/src/services/attachmentHandlers/index.ts +10 -0
  281. package/src/services/attachmentHandlers/videoAttachmentHandler.ts +114 -0
  282. package/src/services/attachmentOrchestrator.ts +300 -0
  283. package/src/services/auth.ts +34 -0
  284. package/src/services/endpoints.ts +24 -1
  285. package/src/services/imageUpload.ts +162 -0
  286. package/src/translation/resources/i18n.ts +22 -8
  287. package/src/types/attachment.ts +85 -0
  288. package/src/types/attachmentHandler.ts +31 -0
  289. package/src/types/imageUpload.ts +28 -0
  290. package/src/types/message.ts +1 -0
  291. package/src/utils/chatImageDimens.ts +178 -0
  292. package/src/utils/device.ts +73 -0
  293. package/src/utils/imageUrlOptimizer.ts +56 -0
  294. package/src/utils/imageUtils.ts +76 -0
  295. package/src/utils/resolveMessageType.ts +2 -0
  296. package/src/utils/ui.ts +19 -0
  297. package/src/utils/url.ts +1 -1
  298. package/src/utils/videoThumbnail.ts +85 -0
  299. package/lib/module/screens/chat-detail/ChatList.js +0 -147
  300. package/lib/module/screens/chat-detail/ChatList.js.map +0 -1
  301. package/lib/module/screens/chat-detail/ChatTextBubble.js +0 -62
  302. package/lib/module/screens/chat-detail/ChatTextBubble.js.map +0 -1
  303. package/lib/module/screens/chat-detail/legend/message-types.js +0 -244
  304. package/lib/module/screens/chat-detail/legend/message-types.js.map +0 -1
  305. package/lib/module/screens/chat-detail/messages/ChatMessageBubble.js +0 -24
  306. package/lib/module/screens/chat-detail/messages/ChatMessageBubble.js.map +0 -1
  307. package/lib/module/screens/chat-detail/messages/types.js +0 -4
  308. package/lib/module/screens/chat-detail/messages/types.js.map +0 -1
  309. package/lib/typescript/src/screens/chat-detail/ChatList.d.ts +0 -3
  310. package/lib/typescript/src/screens/chat-detail/ChatList.d.ts.map +0 -1
  311. package/lib/typescript/src/screens/chat-detail/ChatTextBubble.d.ts +0 -3
  312. package/lib/typescript/src/screens/chat-detail/ChatTextBubble.d.ts.map +0 -1
  313. package/lib/typescript/src/screens/chat-detail/legend/message-types.d.ts +0 -13
  314. package/lib/typescript/src/screens/chat-detail/legend/message-types.d.ts.map +0 -1
  315. package/lib/typescript/src/screens/chat-detail/messages/ChatMessageBubble.d.ts +0 -3
  316. package/lib/typescript/src/screens/chat-detail/messages/ChatMessageBubble.d.ts.map +0 -1
  317. package/lib/typescript/src/screens/chat-detail/messages/types.d.ts +0 -13
  318. package/lib/typescript/src/screens/chat-detail/messages/types.d.ts.map +0 -1
  319. package/src/screens/chat-detail/ChatList.tsx +0 -190
  320. package/src/screens/chat-detail/ChatTextBubble.tsx +0 -73
  321. package/src/screens/chat-detail/legend/message-types.tsx +0 -304
  322. package/src/screens/chat-detail/messages/ChatMessageBubble.tsx +0 -23
  323. package/src/screens/chat-detail/messages/types.ts +0 -14
@@ -1,304 +0,0 @@
1
- import { memo } from 'react';
2
- import { Linking, StyleSheet, Text } from 'react-native';
3
- import {
4
- KContainer,
5
- KImage,
6
- KLabel,
7
- KColors,
8
- KSpacingValue,
9
- } from '@droppii/libs';
10
- import type { DMessageItem, IMessageItemEx } from '../../../types/chat';
11
- import type { IUrlMetadata } from '../../../types/common';
12
- import { getMessageText } from '../../../utils/legendListMessage';
13
- import { CHAT_BUBBLE_COLORS } from '../constants';
14
-
15
- interface BaseLegendMessageProps {
16
- message: DMessageItem;
17
- isOutgoing: boolean;
18
- createdAtTime: number;
19
- }
20
-
21
- const formatMessageTime = (createdAt: number) => {
22
- const date = new Date(createdAt);
23
- if (Number.isNaN(date.getTime())) return '';
24
- return date.toLocaleTimeString('vi-VN', {
25
- hour: '2-digit',
26
- minute: '2-digit',
27
- hour12: false,
28
- });
29
- };
30
-
31
- // Text Message Component
32
- export const LegendTextMessage = memo(
33
- ({ message, isOutgoing, createdAtTime }: BaseLegendMessageProps) => {
34
- const messageText = getMessageText(message);
35
- const timeLabel = formatMessageTime(createdAtTime);
36
-
37
- if (!messageText?.trim()) {
38
- return null;
39
- }
40
-
41
- return (
42
- <KContainer.View style={styles.wrapper}>
43
- <KContainer.View
44
- style={[
45
- styles.bubble,
46
- isOutgoing ? styles.bubbleSent : styles.bubbleReceived,
47
- ]}
48
- >
49
- <KLabel.Text typo="TextMdNormal" color={CHAT_BUBBLE_COLORS.text}>
50
- {messageText}
51
- </KLabel.Text>
52
- </KContainer.View>
53
-
54
- {!isOutgoing && timeLabel ? (
55
- <KLabel.Text
56
- typo="TextXsNormal"
57
- color={CHAT_BUBBLE_COLORS.timestamp}
58
- marginL="0.25rem"
59
- >
60
- {timeLabel}
61
- </KLabel.Text>
62
- ) : null}
63
- </KContainer.View>
64
- );
65
- }
66
- );
67
- LegendTextMessage.displayName = 'LegendTextMessage';
68
-
69
- // Image Message Component (placeholder)
70
- export const LegendImageMessage = memo(
71
- ({ isOutgoing }: BaseLegendMessageProps) => {
72
- return (
73
- <KContainer.View style={styles.wrapper}>
74
- <KContainer.View
75
- style={[
76
- styles.bubble,
77
- isOutgoing ? styles.bubbleSent : styles.bubbleReceived,
78
- ]}
79
- >
80
- <KLabel.Text typo="TextSmNormal" color={CHAT_BUBBLE_COLORS.text}>
81
- [Image]
82
- </KLabel.Text>
83
- </KContainer.View>
84
- </KContainer.View>
85
- );
86
- }
87
- );
88
- LegendImageMessage.displayName = 'LegendImageMessage';
89
-
90
- // Video Message Component (placeholder)
91
- export const LegendVideoMessage = memo(
92
- ({ isOutgoing }: BaseLegendMessageProps) => {
93
- return (
94
- <KContainer.View style={styles.wrapper}>
95
- <KContainer.View
96
- style={[
97
- styles.bubble,
98
- isOutgoing ? styles.bubbleSent : styles.bubbleReceived,
99
- ]}
100
- >
101
- <KLabel.Text typo="TextSmNormal" color={CHAT_BUBBLE_COLORS.text}>
102
- [Video]
103
- </KLabel.Text>
104
- </KContainer.View>
105
- </KContainer.View>
106
- );
107
- }
108
- );
109
- LegendVideoMessage.displayName = 'LegendVideoMessage';
110
-
111
- // File Message Component
112
- export const LegendFileMessage = memo(
113
- ({ message, isOutgoing }: BaseLegendMessageProps) => {
114
- const fileName = message.fileElem?.fileName || message.content || '[File]';
115
-
116
- return (
117
- <KContainer.View style={styles.wrapper}>
118
- <KContainer.View
119
- style={[
120
- styles.bubble,
121
- isOutgoing ? styles.bubbleSent : styles.bubbleReceived,
122
- ]}
123
- >
124
- <KLabel.Text typo="TextSmNormal" color={CHAT_BUBBLE_COLORS.text}>
125
- 📎 {fileName}
126
- </KLabel.Text>
127
- </KContainer.View>
128
- </KContainer.View>
129
- );
130
- }
131
- );
132
- LegendFileMessage.displayName = 'LegendFileMessage';
133
-
134
- // Link Message Component
135
- const parseUrlMetadata = (ex?: string): IUrlMetadata | undefined => {
136
- if (!ex) return undefined;
137
- try {
138
- return (JSON.parse(ex) as IMessageItemEx).urlMetadata;
139
- } catch {
140
- return undefined;
141
- }
142
- };
143
-
144
- const renderTextWithLinks = (content: string, urls: string[]) => {
145
- if (!urls.length) {
146
- return (
147
- <KLabel.Text typo="TextMdNormal" color={CHAT_BUBBLE_COLORS.text}>
148
- {content}
149
- </KLabel.Text>
150
- );
151
- }
152
-
153
- const parts: { text: string; isUrl: boolean }[] = [];
154
- let remaining = content;
155
-
156
- for (const url of urls) {
157
- const idx = remaining.indexOf(url);
158
- if (idx === -1) continue;
159
- if (idx > 0) parts.push({ text: remaining.slice(0, idx), isUrl: false });
160
- parts.push({ text: url, isUrl: true });
161
- remaining = remaining.slice(idx + url.length);
162
- }
163
-
164
- if (remaining) parts.push({ text: remaining, isUrl: false });
165
-
166
- return (
167
- <KLabel.Text typo="TextMdNormal" color={CHAT_BUBBLE_COLORS.text}>
168
- {parts.map((part, i) =>
169
- part.isUrl ? (
170
- <Text
171
- key={i}
172
- style={styles.urlText}
173
- onPress={() => Linking.openURL(part.text)}
174
- >
175
- {part.text}
176
- </Text>
177
- ) : (
178
- <Text key={i}>{part.text}</Text>
179
- )
180
- )}
181
- </KLabel.Text>
182
- );
183
- };
184
-
185
- export const LegendLinkMessage = memo(
186
- ({ message, isOutgoing, createdAtTime }: BaseLegendMessageProps) => {
187
- const content = message?.urlTextElem?.content;
188
- const urls = message?.urlTextElem?.urls ?? [];
189
- const metadata = parseUrlMetadata(message.ex);
190
- const timeLabel = formatMessageTime(createdAtTime);
191
-
192
- return (
193
- <KContainer.View style={styles.wrapper}>
194
- <KContainer.View
195
- style={[
196
- styles.bubble,
197
- isOutgoing ? styles.bubbleSent : styles.bubbleReceived,
198
- ]}
199
- >
200
- {!!content?.trim() && (
201
- <KContainer.View style={styles.textRow}>
202
- {renderTextWithLinks(content, urls)}
203
- </KContainer.View>
204
- )}
205
-
206
- {metadata && (
207
- <KContainer.Touchable
208
- style={styles.card}
209
- onPress={() => metadata.url && Linking.openURL(metadata.url)}
210
- >
211
- {!!metadata.image && (
212
- <KImage.Base
213
- uri={metadata.image}
214
- style={styles.cardThumb}
215
- resizeMode="cover"
216
- />
217
- )}
218
- <KContainer.View style={styles.cardBody}>
219
- {!!metadata.title && (
220
- <KLabel.Text
221
- typo="TextNmMedium"
222
- color={KColors.palette.gray.w900}
223
- numberOfLines={1}
224
- >
225
- {metadata.title}
226
- </KLabel.Text>
227
- )}
228
- {!!metadata.url && (
229
- <KLabel.Text
230
- typo="TextXsMedium"
231
- color={KColors.palette.primary.w400}
232
- numberOfLines={1}
233
- >
234
- {metadata.url}
235
- </KLabel.Text>
236
- )}
237
- {!!metadata.description && (
238
- <KLabel.Text
239
- typo="TextXsNormal"
240
- color={KColors.gray.normal}
241
- numberOfLines={2}
242
- >
243
- {metadata.description}
244
- </KLabel.Text>
245
- )}
246
- </KContainer.View>
247
- </KContainer.Touchable>
248
- )}
249
- </KContainer.View>
250
-
251
- {!isOutgoing && timeLabel ? (
252
- <KLabel.Text
253
- typo="TextXsNormal"
254
- color={CHAT_BUBBLE_COLORS.timestamp}
255
- marginL="0.25rem"
256
- >
257
- {timeLabel}
258
- </KLabel.Text>
259
- ) : null}
260
- </KContainer.View>
261
- );
262
- }
263
- );
264
- LegendLinkMessage.displayName = 'LegendLinkMessage';
265
-
266
- const styles = StyleSheet.create({
267
- wrapper: {
268
- maxWidth: '80%',
269
- },
270
- bubble: {
271
- paddingHorizontal: KSpacingValue['0.75rem'],
272
- paddingVertical: KSpacingValue['0.5rem'],
273
- borderRadius: KSpacingValue['1.25rem'],
274
- },
275
- bubbleReceived: {
276
- backgroundColor: CHAT_BUBBLE_COLORS.received,
277
- },
278
- bubbleSent: {
279
- backgroundColor: CHAT_BUBBLE_COLORS.sent,
280
- },
281
- textRow: {
282
- paddingHorizontal: KSpacingValue['0.25rem'],
283
- },
284
- urlText: {
285
- color: KColors.palette.primary.w400,
286
- fontWeight: '500',
287
- },
288
- card: {
289
- borderRadius: KSpacingValue['0.75rem'],
290
- borderWidth: 1,
291
- borderColor: 'rgba(57,62,64,0.1)',
292
- backgroundColor: KColors.white,
293
- overflow: 'hidden',
294
- },
295
- cardThumb: {
296
- width: '100%',
297
- aspectRatio: 16 / 9,
298
- },
299
- cardBody: {
300
- paddingHorizontal: KSpacingValue['0.75rem'],
301
- paddingVertical: KSpacingValue['0.5rem'],
302
- gap: 2,
303
- },
304
- });
@@ -1,23 +0,0 @@
1
- import { memo } from 'react';
2
- import { DChatMessageType } from '../../../types/message';
3
- import { ChatTextBubble } from '../ChatTextBubble';
4
- import type { ChatMessageBubbleProps, ChatMessageRenderer } from './types';
5
-
6
- const getMessageRenderers = (): Partial<
7
- Record<DChatMessageType, ChatMessageRenderer>
8
- > => ({
9
- [DChatMessageType.Text]: ChatTextBubble,
10
- });
11
-
12
- export const ChatMessageBubble = memo(
13
- ({ message, position }: ChatMessageBubbleProps) => {
14
- const Renderer = getMessageRenderers()[message.messageType];
15
- if (!Renderer) {
16
- return null;
17
- }
18
-
19
- return <Renderer message={message} position={position} />;
20
- }
21
- );
22
-
23
- ChatMessageBubble.displayName = 'ChatMessageBubble';
@@ -1,14 +0,0 @@
1
- import type { ComponentType } from 'react';
2
- import type { IMessage } from 'react-native-gifted-chat';
3
- import type { DMessageItem } from '../../../types/chat';
4
- import type { DChatMessageType } from '../../../types/message';
5
-
6
- export type ChatMessageBubbleProps = {
7
- message: IMessage & {
8
- openIMMessage: DMessageItem;
9
- messageType: DChatMessageType;
10
- };
11
- position: 'left' | 'right';
12
- };
13
-
14
- export type ChatMessageRenderer = ComponentType<ChatMessageBubbleProps>;