@messenger-box/tailwind-ui-inbox 10.0.3-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (415) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/LICENSE +21 -0
  3. package/jest.config.js +9 -0
  4. package/lib/cdm-locales/en/translations.json +31 -0
  5. package/lib/cdm-locales/es/translations.json +31 -0
  6. package/lib/components/AIAgent/AIAgent.d.ts +32 -0
  7. package/lib/components/AIAgent/AIAgent.d.ts.map +1 -0
  8. package/lib/components/AIAgent/AIAgent.js +1135 -0
  9. package/lib/components/AIAgent/AIAgent.js.map +1 -0
  10. package/lib/components/AIAgent/InputComponent.d.ts +84 -0
  11. package/lib/components/AIAgent/InputComponent.d.ts.map +1 -0
  12. package/lib/components/AIAgent/InputComponent.js +417 -0
  13. package/lib/components/AIAgent/InputComponent.js.map +1 -0
  14. package/lib/components/AIAgent/index.d.ts +2 -0
  15. package/lib/components/AIAgent/index.d.ts.map +1 -0
  16. package/lib/components/InboxMessage/CommonMessage.d.ts +8 -0
  17. package/lib/components/InboxMessage/CommonMessage.d.ts.map +1 -0
  18. package/lib/components/InboxMessage/CommonMessage.js +35 -0
  19. package/lib/components/InboxMessage/CommonMessage.js.map +1 -0
  20. package/lib/components/InboxMessage/ConversationItem.d.ts +14 -0
  21. package/lib/components/InboxMessage/ConversationItem.d.ts.map +1 -0
  22. package/lib/components/InboxMessage/ConversationItem.js +200 -0
  23. package/lib/components/InboxMessage/ConversationItem.js.map +1 -0
  24. package/lib/components/InboxMessage/InputComponent.d.ts +20 -0
  25. package/lib/components/InboxMessage/InputComponent.d.ts.map +1 -0
  26. package/lib/components/InboxMessage/InputComponent.js +148 -0
  27. package/lib/components/InboxMessage/InputComponent.js.map +1 -0
  28. package/lib/components/InboxMessage/LeftSidebar.d.ts +20 -0
  29. package/lib/components/InboxMessage/LeftSidebar.d.ts.map +1 -0
  30. package/lib/components/InboxMessage/LeftSidebar.js +102 -0
  31. package/lib/components/InboxMessage/LeftSidebar.js.map +1 -0
  32. package/lib/components/InboxMessage/MessageInput.d.ts +9 -0
  33. package/lib/components/InboxMessage/MessageInput.d.ts.map +1 -0
  34. package/lib/components/InboxMessage/MessageInput.js +154 -0
  35. package/lib/components/InboxMessage/MessageInput.js.map +1 -0
  36. package/lib/components/InboxMessage/MessageInputComponent.d.ts +9 -0
  37. package/lib/components/InboxMessage/MessageInputComponent.d.ts.map +1 -0
  38. package/lib/components/InboxMessage/Messages.d.ts +17 -0
  39. package/lib/components/InboxMessage/Messages.d.ts.map +1 -0
  40. package/lib/components/InboxMessage/Messages.js +99 -0
  41. package/lib/components/InboxMessage/Messages.js.map +1 -0
  42. package/lib/components/InboxMessage/MessagesBuilderUi.d.ts +17 -0
  43. package/lib/components/InboxMessage/MessagesBuilderUi.d.ts.map +1 -0
  44. package/lib/components/InboxMessage/Popover.d.ts +3 -0
  45. package/lib/components/InboxMessage/Popover.d.ts.map +1 -0
  46. package/lib/components/InboxMessage/Popover.js +31 -0
  47. package/lib/components/InboxMessage/Popover.js.map +1 -0
  48. package/lib/components/InboxMessage/RightSidebar.d.ts +9 -0
  49. package/lib/components/InboxMessage/RightSidebar.d.ts.map +1 -0
  50. package/lib/components/InboxMessage/RightSidebar.js +9 -0
  51. package/lib/components/InboxMessage/RightSidebar.js.map +1 -0
  52. package/lib/components/InboxMessage/RightSidebarAi.d.ts +37 -0
  53. package/lib/components/InboxMessage/RightSidebarAi.d.ts.map +1 -0
  54. package/lib/components/InboxMessage/RightSidebarAi.js +9 -0
  55. package/lib/components/InboxMessage/RightSidebarAi.js.map +1 -0
  56. package/lib/components/InboxMessage/ServiceConversationItem.d.ts +12 -0
  57. package/lib/components/InboxMessage/ServiceConversationItem.d.ts.map +1 -0
  58. package/lib/components/InboxMessage/ServiceConversationItem.js +185 -0
  59. package/lib/components/InboxMessage/ServiceConversationItem.js.map +1 -0
  60. package/lib/components/InboxMessage/ServiceInboxItem.d.ts +12 -0
  61. package/lib/components/InboxMessage/ServiceInboxItem.d.ts.map +1 -0
  62. package/lib/components/InboxMessage/ServiceInboxItem.js +182 -0
  63. package/lib/components/InboxMessage/ServiceInboxItem.js.map +1 -0
  64. package/lib/components/InboxMessage/StreamingMessageBubble.d.ts +18 -0
  65. package/lib/components/InboxMessage/StreamingMessageBubble.d.ts.map +1 -0
  66. package/lib/components/InboxMessage/SubscriptionHandler.d.ts +19 -0
  67. package/lib/components/InboxMessage/SubscriptionHandler.d.ts.map +1 -0
  68. package/lib/components/InboxMessage/SubscriptionHandler.js +41 -0
  69. package/lib/components/InboxMessage/SubscriptionHandler.js.map +1 -0
  70. package/lib/components/InboxMessage/TypingIndicator.d.ts +11 -0
  71. package/lib/components/InboxMessage/TypingIndicator.d.ts.map +1 -0
  72. package/lib/components/InboxMessage/UploadImageButton.d.ts +7 -0
  73. package/lib/components/InboxMessage/UploadImageButton.d.ts.map +1 -0
  74. package/lib/components/InboxMessage/UploadImageButton.js +30 -0
  75. package/lib/components/InboxMessage/UploadImageButton.js.map +1 -0
  76. package/lib/components/InboxMessage/UserModalContent.d.ts +3 -0
  77. package/lib/components/InboxMessage/UserModalContent.d.ts.map +1 -0
  78. package/lib/components/InboxMessage/UserModalContent.js +60 -0
  79. package/lib/components/InboxMessage/UserModalContent.js.map +1 -0
  80. package/lib/components/InboxMessage/index.d.ts +19 -0
  81. package/lib/components/InboxMessage/index.d.ts.map +1 -0
  82. package/lib/components/InboxMessage/message-widgets/CommonMessage.d.ts +11 -0
  83. package/lib/components/InboxMessage/message-widgets/CommonMessage.d.ts.map +1 -0
  84. package/lib/components/InboxMessage/message-widgets/CommonMessage.js +44 -0
  85. package/lib/components/InboxMessage/message-widgets/CommonMessage.js.map +1 -0
  86. package/lib/components/InboxMessage/message-widgets/ErrorFixCard.d.ts +10 -0
  87. package/lib/components/InboxMessage/message-widgets/ErrorFixCard.d.ts.map +1 -0
  88. package/lib/components/InboxMessage/message-widgets/ErrorFixCard.js +194 -0
  89. package/lib/components/InboxMessage/message-widgets/ErrorFixCard.js.map +1 -0
  90. package/lib/components/InboxMessage/message-widgets/MessageCard.d.ts +8 -0
  91. package/lib/components/InboxMessage/message-widgets/MessageCard.d.ts.map +1 -0
  92. package/lib/components/InboxMessage/message-widgets/MessageSliceRenderer.d.ts +12 -0
  93. package/lib/components/InboxMessage/message-widgets/MessageSliceRenderer.d.ts.map +1 -0
  94. package/lib/components/InboxMessage/message-widgets/MessageSliceRenderer.js +37 -0
  95. package/lib/components/InboxMessage/message-widgets/MessageSliceRenderer.js.map +1 -0
  96. package/lib/components/InboxMessage/message-widgets/ModernMessageGroup.d.ts +42 -0
  97. package/lib/components/InboxMessage/message-widgets/ModernMessageGroup.d.ts.map +1 -0
  98. package/lib/components/InboxMessage/message-widgets/ModernMessageGroup.js +1339 -0
  99. package/lib/components/InboxMessage/message-widgets/ModernMessageGroup.js.map +1 -0
  100. package/lib/components/InboxMessage/message-widgets/PlainMessage.d.ts +8 -0
  101. package/lib/components/InboxMessage/message-widgets/PlainMessage.d.ts.map +1 -0
  102. package/lib/components/InboxMessage/message-widgets/PlainMessage.js +14 -0
  103. package/lib/components/InboxMessage/message-widgets/PlainMessage.js.map +1 -0
  104. package/lib/components/InboxMessage/message-widgets/PropertyMessageWidget.d.ts +9 -0
  105. package/lib/components/InboxMessage/message-widgets/PropertyMessageWidget.d.ts.map +1 -0
  106. package/lib/components/InboxMessage/message-widgets/SlackLikeMessageGroup.d.ts +14 -0
  107. package/lib/components/InboxMessage/message-widgets/SlackLikeMessageGroup.d.ts.map +1 -0
  108. package/lib/components/InboxMessage/message-widgets/SlackLikeMessageGroup.js +333 -0
  109. package/lib/components/InboxMessage/message-widgets/SlackLikeMessageGroup.js.map +1 -0
  110. package/lib/components/InboxMessage/message-widgets/index.d.ts +4 -0
  111. package/lib/components/InboxMessage/message-widgets/index.d.ts.map +1 -0
  112. package/lib/components/ModelConfigPanel.d.ts +74 -0
  113. package/lib/components/ModelConfigPanel.d.ts.map +1 -0
  114. package/lib/components/ModelConfigPanel.js +1152 -0
  115. package/lib/components/ModelConfigPanel.js.map +1 -0
  116. package/lib/components/filler-components/RightSiderBar.d.ts +3 -0
  117. package/lib/components/filler-components/RightSiderBar.d.ts.map +1 -0
  118. package/lib/components/filler-components/RightSiderBar.js +532 -0
  119. package/lib/components/filler-components/RightSiderBar.js.map +1 -0
  120. package/lib/components/inbox/FilesList.d.ts +20 -0
  121. package/lib/components/inbox/FilesList.d.ts.map +1 -0
  122. package/lib/components/inbox/FilesList.js +68 -0
  123. package/lib/components/inbox/FilesList.js.map +1 -0
  124. package/lib/components/inbox/MessageItem.d.ts +17 -0
  125. package/lib/components/inbox/MessageItem.d.ts.map +1 -0
  126. package/lib/components/inbox/MessageItem.js +50 -0
  127. package/lib/components/inbox/MessageItem.js.map +1 -0
  128. package/lib/components/inbox/ThreadItem.d.ts +11 -0
  129. package/lib/components/inbox/ThreadItem.d.ts.map +1 -0
  130. package/lib/components/inbox/ThreadItem.js +147 -0
  131. package/lib/components/inbox/ThreadItem.js.map +1 -0
  132. package/lib/components/inbox/index.d.ts +4 -0
  133. package/lib/components/inbox/index.d.ts.map +1 -0
  134. package/lib/components/index.d.ts +10 -0
  135. package/lib/components/index.d.ts.map +1 -0
  136. package/lib/components/live-code-editor/hybrid-live-editor.d.ts +20 -0
  137. package/lib/components/live-code-editor/hybrid-live-editor.d.ts.map +1 -0
  138. package/lib/components/live-code-editor/index.d.ts +4 -0
  139. package/lib/components/live-code-editor/index.d.ts.map +1 -0
  140. package/lib/components/live-code-editor/live-code-editor.d.ts +14 -0
  141. package/lib/components/live-code-editor/live-code-editor.d.ts.map +1 -0
  142. package/lib/components/messages-container-ui/MessagesContainerUI.d.ts +81 -0
  143. package/lib/components/messages-container-ui/MessagesContainerUI.d.ts.map +1 -0
  144. package/lib/components/messages-container-ui/MessagesContainerUI.js +77 -0
  145. package/lib/components/messages-container-ui/MessagesContainerUI.js.map +1 -0
  146. package/lib/components/messages-container-ui/PlanModeView.d.ts +82 -0
  147. package/lib/components/messages-container-ui/PlanModeView.d.ts.map +1 -0
  148. package/lib/components/messages-container-ui/PlanModeView.js +267 -0
  149. package/lib/components/messages-container-ui/PlanModeView.js.map +1 -0
  150. package/lib/components/messages-container-ui/index.d.ts +6 -0
  151. package/lib/components/messages-container-ui/index.d.ts.map +1 -0
  152. package/lib/components/messages-container-ui/types.d.ts +38 -0
  153. package/lib/components/messages-container-ui/types.d.ts.map +1 -0
  154. package/lib/components/slot-fill/chat-message-filler.d.ts +4 -0
  155. package/lib/components/slot-fill/chat-message-filler.d.ts.map +1 -0
  156. package/lib/components/slot-fill/chat-message-filler.js +5 -0
  157. package/lib/components/slot-fill/chat-message-filler.js.map +1 -0
  158. package/lib/components/slot-fill/chat-message-slot.d.ts +11 -0
  159. package/lib/components/slot-fill/chat-message-slot.d.ts.map +1 -0
  160. package/lib/components/slot-fill/chat-message-slot.js +6 -0
  161. package/lib/components/slot-fill/chat-message-slot.js.map +1 -0
  162. package/lib/components/slot-fill/index.d.ts +4 -0
  163. package/lib/components/slot-fill/index.d.ts.map +1 -0
  164. package/lib/components/slot-fill/right-sidebar-filler.d.ts +4 -0
  165. package/lib/components/slot-fill/right-sidebar-filler.d.ts.map +1 -0
  166. package/lib/components/slot-fill/right-sidebar-filler.js +13 -0
  167. package/lib/components/slot-fill/right-sidebar-filler.js.map +1 -0
  168. package/lib/components/ui/button.d.ts +9 -0
  169. package/lib/components/ui/button.d.ts.map +1 -0
  170. package/lib/compute.d.ts +8 -0
  171. package/lib/compute.d.ts.map +1 -0
  172. package/lib/compute.js +264 -0
  173. package/lib/compute.js.map +1 -0
  174. package/lib/config/env-config.d.ts +20 -0
  175. package/lib/config/env-config.d.ts.map +1 -0
  176. package/lib/config/env-config.js +55 -0
  177. package/lib/config/env-config.js.map +1 -0
  178. package/lib/config/index.d.ts +2 -0
  179. package/lib/config/index.d.ts.map +1 -0
  180. package/lib/constants/breakpoints.d.ts +8 -0
  181. package/lib/constants/breakpoints.d.ts.map +1 -0
  182. package/lib/constants/index.d.ts +3 -0
  183. package/lib/constants/index.d.ts.map +1 -0
  184. package/lib/container/AiInbox.d.ts +15 -0
  185. package/lib/container/AiInbox.d.ts.map +1 -0
  186. package/lib/container/AiInboxWithLoader.d.ts +36 -0
  187. package/lib/container/AiInboxWithLoader.d.ts.map +1 -0
  188. package/lib/container/AiLandingInput.d.ts +27 -0
  189. package/lib/container/AiLandingInput.d.ts.map +1 -0
  190. package/lib/container/AiLandingInput.js +149 -0
  191. package/lib/container/AiLandingInput.js.map +1 -0
  192. package/lib/container/Inbox.d.ts +15 -0
  193. package/lib/container/Inbox.d.ts.map +1 -0
  194. package/lib/container/Inbox.js +964 -0
  195. package/lib/container/Inbox.js.map +1 -0
  196. package/lib/container/InboxAiMessagesLoader.d.ts +45 -0
  197. package/lib/container/InboxAiMessagesLoader.d.ts.map +1 -0
  198. package/lib/container/InboxAiMessagesLoader.js +80 -0
  199. package/lib/container/InboxAiMessagesLoader.js.map +1 -0
  200. package/lib/container/InboxContainer.d.ts +41 -0
  201. package/lib/container/InboxContainer.d.ts.map +1 -0
  202. package/lib/container/InboxContainer.js +27 -0
  203. package/lib/container/InboxContainer.js.map +1 -0
  204. package/lib/container/InboxTemplate1.d.ts +15 -0
  205. package/lib/container/InboxTemplate1.d.ts.map +1 -0
  206. package/lib/container/InboxTemplate1WithLoader.d.ts +36 -0
  207. package/lib/container/InboxTemplate1WithLoader.d.ts.map +1 -0
  208. package/lib/container/InboxTemplate2.d.ts +15 -0
  209. package/lib/container/InboxTemplate2.d.ts.map +1 -0
  210. package/lib/container/InboxWithAiLoader.d.ts +47 -0
  211. package/lib/container/InboxWithAiLoader.d.ts.map +1 -0
  212. package/lib/container/InboxWithAiLoader.js +118 -0
  213. package/lib/container/InboxWithAiLoader.js.map +1 -0
  214. package/lib/container/InboxWithLoader.d.ts +36 -0
  215. package/lib/container/InboxWithLoader.d.ts.map +1 -0
  216. package/lib/container/InboxWithLoader.js +277 -0
  217. package/lib/container/InboxWithLoader.js.map +1 -0
  218. package/lib/container/ServiceInbox.d.ts +9 -0
  219. package/lib/container/ServiceInbox.d.ts.map +1 -0
  220. package/lib/container/ServiceInbox.js +141 -0
  221. package/lib/container/ServiceInbox.js.map +1 -0
  222. package/lib/container/TestInboxWithAiLoader.d.ts +7 -0
  223. package/lib/container/TestInboxWithAiLoader.d.ts.map +1 -0
  224. package/lib/container/TestInboxWithAiLoader.js +135 -0
  225. package/lib/container/TestInboxWithAiLoader.js.map +1 -0
  226. package/lib/container/ThreadMessages.d.ts +13 -0
  227. package/lib/container/ThreadMessages.d.ts.map +1 -0
  228. package/lib/container/ThreadMessages.js +320 -0
  229. package/lib/container/ThreadMessages.js.map +1 -0
  230. package/lib/container/ThreadMessagesInbox.d.ts +14 -0
  231. package/lib/container/ThreadMessagesInbox.d.ts.map +1 -0
  232. package/lib/container/ThreadMessagesInbox.js +347 -0
  233. package/lib/container/ThreadMessagesInbox.js.map +1 -0
  234. package/lib/container/Threads.d.ts +8 -0
  235. package/lib/container/Threads.d.ts.map +1 -0
  236. package/lib/container/Threads.js +231 -0
  237. package/lib/container/Threads.js.map +1 -0
  238. package/lib/container/ThreadsInbox.d.ts +21 -0
  239. package/lib/container/ThreadsInbox.d.ts.map +1 -0
  240. package/lib/container/ThreadsInbox.js +243 -0
  241. package/lib/container/ThreadsInbox.js.map +1 -0
  242. package/lib/container/apply-footer-styles.d.ts +2 -0
  243. package/lib/container/apply-footer-styles.d.ts.map +1 -0
  244. package/lib/container/apply-footer-styles.js +16 -0
  245. package/lib/container/apply-footer-styles.js.map +1 -0
  246. package/lib/container/index.d.ts +13 -0
  247. package/lib/container/index.d.ts.map +1 -0
  248. package/lib/enums/index.d.ts +2 -0
  249. package/lib/enums/index.d.ts.map +1 -0
  250. package/lib/enums/messenger-slot-fill-name-enum.d.ts +11 -0
  251. package/lib/enums/messenger-slot-fill-name-enum.d.ts.map +1 -0
  252. package/lib/enums/messenger-slot-fill-name-enum.js +11 -0
  253. package/lib/enums/messenger-slot-fill-name-enum.js.map +1 -0
  254. package/lib/hooks/index.d.ts +4 -0
  255. package/lib/hooks/index.d.ts.map +1 -0
  256. package/lib/hooks/usePersistentModelConfig.d.ts +33 -0
  257. package/lib/hooks/usePersistentModelConfig.d.ts.map +1 -0
  258. package/lib/hooks/usePersistentModelConfig.js +123 -0
  259. package/lib/hooks/usePersistentModelConfig.js.map +1 -0
  260. package/lib/hooks/useStreamAssembler.d.ts +8 -0
  261. package/lib/hooks/useStreamAssembler.d.ts.map +1 -0
  262. package/lib/hooks/useTemplates.d.ts +14 -0
  263. package/lib/hooks/useTemplates.d.ts.map +1 -0
  264. package/lib/hooks/useTemplates.js +59 -0
  265. package/lib/hooks/useTemplates.js.map +1 -0
  266. package/lib/index.d.ts +14 -0
  267. package/lib/index.d.ts.map +1 -0
  268. package/lib/index.js +1 -0
  269. package/lib/index.js.map +1 -0
  270. package/lib/interfaces/index.d.ts +2 -0
  271. package/lib/interfaces/index.d.ts.map +1 -0
  272. package/lib/interfaces/message-widgets.interface.d.ts +21 -0
  273. package/lib/interfaces/message-widgets.interface.d.ts.map +1 -0
  274. package/lib/machines/aiAgentMachine.d.ts +3 -0
  275. package/lib/machines/aiAgentMachine.d.ts.map +1 -0
  276. package/lib/machines/aiAgentMachine.js +1083 -0
  277. package/lib/machines/aiAgentMachine.js.map +1 -0
  278. package/lib/machines/aiAgentMachine.simple.d.ts +3 -0
  279. package/lib/machines/aiAgentMachine.simple.d.ts.map +1 -0
  280. package/lib/machines/aiAgentMachine.simple.js +108 -0
  281. package/lib/machines/aiAgentMachine.simple.js.map +1 -0
  282. package/lib/machines/index.d.ts +3 -0
  283. package/lib/machines/index.d.ts.map +1 -0
  284. package/lib/machines/types.d.ts +77 -0
  285. package/lib/machines/types.d.ts.map +1 -0
  286. package/lib/module.d.ts +7 -0
  287. package/lib/module.d.ts.map +1 -0
  288. package/lib/module.js +26 -0
  289. package/lib/module.js.map +1 -0
  290. package/lib/routes.json +251 -0
  291. package/lib/styles/responsive.css +76 -0
  292. package/lib/templates/InboxWithAi.d.ts +44 -0
  293. package/lib/templates/InboxWithAi.d.ts.map +1 -0
  294. package/lib/templates/InboxWithAi.js +651 -0
  295. package/lib/templates/InboxWithAi.js.map +1 -0
  296. package/lib/templates/InboxWithAi.tsx +844 -0
  297. package/lib/templates/index.d.ts +2 -0
  298. package/lib/templates/index.d.ts.map +1 -0
  299. package/lib/templates/index.ts +1 -0
  300. package/lib/types/templates.d.ts +35 -0
  301. package/lib/types/templates.d.ts.map +1 -0
  302. package/lib/utils/utils.d.ts +2 -0
  303. package/lib/utils/utils.d.ts.map +1 -0
  304. package/lib/xstate/index.d.ts +3 -0
  305. package/lib/xstate/index.d.ts.map +1 -0
  306. package/lib/xstate/rightSidebar.machine.d.ts +4 -0
  307. package/lib/xstate/rightSidebar.machine.d.ts.map +1 -0
  308. package/lib/xstate/rightSidebar.types.d.ts +57 -0
  309. package/lib/xstate/rightSidebar.types.d.ts.map +1 -0
  310. package/package.json +69 -0
  311. package/rollup.config.mjs +47 -0
  312. package/src/cdm-locales/en/translations.json +31 -0
  313. package/src/cdm-locales/es/translations.json +31 -0
  314. package/src/components/AIAgent/AIAgent.tsx +1468 -0
  315. package/src/components/AIAgent/AIAgent.tsx.bk +1365 -0
  316. package/src/components/AIAgent/InputComponent.tsx +608 -0
  317. package/src/components/AIAgent/README.md +174 -0
  318. package/src/components/AIAgent/index.ts +1 -0
  319. package/src/components/InboxMessage/CommonMessage.tsx +40 -0
  320. package/src/components/InboxMessage/ConversationItem.tsx +255 -0
  321. package/src/components/InboxMessage/InputComponent.tsx +198 -0
  322. package/src/components/InboxMessage/LeftSidebar.tsx +140 -0
  323. package/src/components/InboxMessage/MessageInput.tsx +209 -0
  324. package/src/components/InboxMessage/MessageInputComponent.tsx +245 -0
  325. package/src/components/InboxMessage/Messages.tsx +137 -0
  326. package/src/components/InboxMessage/MessagesBuilderUi.tsx +205 -0
  327. package/src/components/InboxMessage/Popover.tsx +42 -0
  328. package/src/components/InboxMessage/RightSidebar.tsx +22 -0
  329. package/src/components/InboxMessage/RightSidebarAi.tsx +47 -0
  330. package/src/components/InboxMessage/ServiceConversationItem.tsx +234 -0
  331. package/src/components/InboxMessage/ServiceInboxItem.tsx +223 -0
  332. package/src/components/InboxMessage/StreamingMessageBubble.tsx +270 -0
  333. package/src/components/InboxMessage/SubscriptionHandler.tsx +55 -0
  334. package/src/components/InboxMessage/TypingIndicator.tsx +38 -0
  335. package/src/components/InboxMessage/UploadImageButton.tsx +46 -0
  336. package/src/components/InboxMessage/UserModalContent.tsx +60 -0
  337. package/src/components/InboxMessage/index.ts +18 -0
  338. package/src/components/InboxMessage/message-widgets/CommonMessage.tsx +69 -0
  339. package/src/components/InboxMessage/message-widgets/ErrorFixCard.tsx +239 -0
  340. package/src/components/InboxMessage/message-widgets/MessageCard.tsx +127 -0
  341. package/src/components/InboxMessage/message-widgets/MessageSliceRenderer.tsx +40 -0
  342. package/src/components/InboxMessage/message-widgets/ModernMessageGroup.tsx +1733 -0
  343. package/src/components/InboxMessage/message-widgets/PlainMessage.tsx +18 -0
  344. package/src/components/InboxMessage/message-widgets/PropertyMessageWidget.tsx +29 -0
  345. package/src/components/InboxMessage/message-widgets/SlackLikeMessageGroup.tsx +492 -0
  346. package/src/components/InboxMessage/message-widgets/index.ts +8 -0
  347. package/src/components/ModelConfigPanel.tsx +1357 -0
  348. package/src/components/filler-components/RightSiderBar.tsx +572 -0
  349. package/src/components/inbox/FilesList.tsx +89 -0
  350. package/src/components/inbox/MessageItem.tsx +50 -0
  351. package/src/components/inbox/ThreadItem.tsx +295 -0
  352. package/src/components/inbox/index.ts +3 -0
  353. package/src/components/index.ts +29 -0
  354. package/src/components/live-code-editor/hybrid-live-editor.tsx +105 -0
  355. package/src/components/live-code-editor/index.ts +3 -0
  356. package/src/components/live-code-editor/live-code-editor.tsx +257 -0
  357. package/src/components/messages-container-ui/MessagesContainerUI.tsx +151 -0
  358. package/src/components/messages-container-ui/PlanModeView.tsx +426 -0
  359. package/src/components/messages-container-ui/README.md +91 -0
  360. package/src/components/messages-container-ui/index.ts +5 -0
  361. package/src/components/messages-container-ui/types.ts +40 -0
  362. package/src/components/slot-fill/chat-message-filler.tsx +18 -0
  363. package/src/components/slot-fill/chat-message-slot.tsx +18 -0
  364. package/src/components/slot-fill/index.ts +3 -0
  365. package/src/components/slot-fill/right-sidebar-filler.tsx +48 -0
  366. package/src/components/ui/button.tsx +32 -0
  367. package/src/compute.ts +271 -0
  368. package/src/config/env-config.ts +24 -0
  369. package/src/config/index.ts +1 -0
  370. package/src/constants/breakpoints.ts +7 -0
  371. package/src/constants/index.ts +5 -0
  372. package/src/container/AiInbox.tsx +1879 -0
  373. package/src/container/AiInboxWithLoader.tsx +356 -0
  374. package/src/container/AiLandingInput.tsx +200 -0
  375. package/src/container/Inbox.tsx +1095 -0
  376. package/src/container/InboxAiMessagesLoader.tsx +129 -0
  377. package/src/container/InboxContainer.tsx +61 -0
  378. package/src/container/InboxTemplate1.tsx +1553 -0
  379. package/src/container/InboxTemplate1WithLoader.tsx +338 -0
  380. package/src/container/InboxTemplate2.tsx +1617 -0
  381. package/src/container/InboxWithAiLoader.tsx +177 -0
  382. package/src/container/InboxWithLoader.tsx +341 -0
  383. package/src/container/ServiceInbox.tsx +188 -0
  384. package/src/container/TestInboxWithAiLoader.tsx +147 -0
  385. package/src/container/ThreadMessages.tsx +378 -0
  386. package/src/container/ThreadMessagesInbox.tsx +457 -0
  387. package/src/container/Threads.tsx +270 -0
  388. package/src/container/ThreadsInbox.tsx +351 -0
  389. package/src/container/apply-footer-styles.ts +17 -0
  390. package/src/container/index.ts +31 -0
  391. package/src/enums/index.ts +1 -0
  392. package/src/enums/messenger-slot-fill-name-enum.ts +10 -0
  393. package/src/hooks/index.ts +3 -0
  394. package/src/hooks/usePersistentModelConfig.ts +166 -0
  395. package/src/hooks/useStreamAssembler.ts +7 -0
  396. package/src/hooks/useTemplates.ts +75 -0
  397. package/src/index.ts +49 -0
  398. package/src/interfaces/index.ts +1 -0
  399. package/src/interfaces/message-widgets.interface.ts +21 -0
  400. package/src/machines/aiAgentMachine.simple.ts +89 -0
  401. package/src/machines/aiAgentMachine.ts +1296 -0
  402. package/src/machines/aiAgentMachine.ts.bk +1296 -0
  403. package/src/machines/index.ts +2 -0
  404. package/src/machines/types.ts +59 -0
  405. package/src/module.tsx +32 -0
  406. package/src/styles/responsive.css +76 -0
  407. package/src/templates/InboxWithAi.tsx +844 -0
  408. package/src/templates/index.ts +1 -0
  409. package/src/types/templates.ts +35 -0
  410. package/src/utils/utils.ts +3 -0
  411. package/src/xstate/index.ts +2 -0
  412. package/src/xstate/rightSidebar.machine.ts +304 -0
  413. package/src/xstate/rightSidebar.types.ts +58 -0
  414. package/tsconfig.json +14 -0
  415. package/webpack.config.js +92 -0
@@ -0,0 +1,457 @@
1
+ import React, { ReactNode, useCallback, useEffect, useMemo, useRef, useState } from 'react';
2
+ import { orderBy, uniqBy, startCase } from 'lodash-es';
3
+ import {
4
+ OnThreadChatMessageAddedDocument as CHAT_MESSAGE_ADDED,
5
+ useGetPostThreadQuery,
6
+ useCreatePostThreadMutation,
7
+ } from 'common/graphql';
8
+ import { useUploadFiles } from '@messenger-box/platform-client';
9
+ import { IFileInfo, RoomType, IPostThread } from 'common';
10
+ import { useSelector } from 'react-redux';
11
+ import { MessageInput, Messages } from '../components';
12
+ import { userSelector } from '@adminide-stack/user-auth0-client';
13
+ import { config } from '../config';
14
+ import { BiChevronLeftSquare } from '@react-icons/all-files/bi/BiChevronLeftSquare.js';
15
+ import { objectId } from '@messenger-box/core';
16
+
17
+ const { MESSAGES_PER_PAGE, WEB_INBOX_MESSEGE_PATH } = config;
18
+
19
+ export interface ThreadMessageInboxProps {
20
+ channelId: any;
21
+ postId?: any;
22
+ role?: string;
23
+ isPostParentIdThread?: boolean;
24
+ goBack?: boolean;
25
+ pathPrefix?: string;
26
+ setChannelId?: (channelId: any) => void;
27
+ setPostId?: (postId?: any) => void;
28
+ onMessageClick: (reservationId) => void;
29
+ }
30
+
31
+ export const ThreadMessagesInbox = React.memo((props: ThreadMessageInboxProps) => {
32
+ const {
33
+ channelId,
34
+ postId,
35
+ role,
36
+ isPostParentIdThread,
37
+ goBack = false,
38
+ pathPrefix,
39
+ setPostId,
40
+ setChannelId,
41
+ onMessageClick,
42
+ } = props;
43
+ const threadMessageRootRef = React.useRef(null);
44
+ const messageListRef = useRef(null);
45
+ const currentUser: any = useSelector(userSelector);
46
+ const [channelToTop, setChannelToTop] = useState(0);
47
+ const [postThread, setPostThread] = useState<IPostThread>();
48
+ const [channelMessages, setChannelMessages] = React.useState<any>([]);
49
+ const [totalCount, setTotalCount] = React.useState<any>(0);
50
+ const [loadingOldMessages, setLoadingOldMessages] = React.useState<boolean>(false);
51
+ const [loading, setLoading] = React.useState<boolean>(true);
52
+ const [isScrollToBottom, setIsScrollToBottom] = useState(false);
53
+ const { startUpload } = useUploadFiles();
54
+ const [sendThreadMessage] = useCreatePostThreadMutation();
55
+
56
+ const {
57
+ data,
58
+ loading: threadLoading,
59
+ fetchMore: fetchMoreMessages,
60
+ refetch: refetchThreadMessages,
61
+ subscribeToMore,
62
+ } = useGetPostThreadQuery({
63
+ variables: {
64
+ channelId: channelId?.toString(),
65
+ role: role?.toString(),
66
+ postParentId: postId?.toString(),
67
+ limit: MESSAGES_PER_PAGE,
68
+ },
69
+ fetchPolicy: 'cache-and-network',
70
+ });
71
+
72
+ React.useEffect(() => {
73
+ if (postId) {
74
+ refetchThreadMessages({
75
+ channelId: channelId?.toString(),
76
+ role: role?.toString(),
77
+ postParentId: postId?.toString(),
78
+ limit: MESSAGES_PER_PAGE,
79
+ });
80
+ }
81
+ }, [postId]);
82
+
83
+ // React.useEffect(() => {
84
+ // if (data?.threadMessages) {
85
+ // const threads = data?.threadMessages ?? null;
86
+ // const threadsData = threads?.data ?? [];
87
+ // const messeageTotalCount = threadsData?.reduce((accumulator, thread) => {
88
+ // return accumulator + thread?.replyCount;
89
+ // }, 0);
90
+ // const replies = threadsData?.map((t: any) => t?.replies)?.flat(1) ?? [];
91
+ // const posts = threadsData?.map((t: any) => t?.post)?.flat(1) ?? [];
92
+ // const messages = [...posts, ...replies];
93
+
94
+ // if (
95
+ // (messages && messages.length > 0 && messages?.length > totalCount) ||
96
+ // (messages && messages.length > 0 && channelMessages.length === 0)
97
+ // ) {
98
+ // setThreadMessages(messages, messages?.length);
99
+ // }
100
+ // }
101
+ // if (isScrollToBottom && channelMessages) scrollToBottom();
102
+ // }, [data, channelMessages, loadingOldMessages, totalCount, isPostParentIdThread, isScrollToBottom]);
103
+
104
+ React.useEffect(() => {
105
+ if (data?.getPostThread) {
106
+ const threads: any = data.getPostThread;
107
+ const threadPost = threads?.post ?? {};
108
+ const threadReplies = threads?.replies ?? [];
109
+ const messeageTotalCount = threads?.replyCount ?? 0;
110
+ const messages = [threadPost, ...threadReplies];
111
+ if (
112
+ (messages && messages.length > 0 && messeageTotalCount > totalCount) ||
113
+ (messages && messages.length > 0 && channelMessages.length === 0)
114
+ ) {
115
+ setThreadMessages(messages, messeageTotalCount);
116
+ }
117
+ }
118
+ if (isScrollToBottom && channelMessages) scrollToBottom();
119
+ }, [data, channelMessages, loadingOldMessages, totalCount, isPostParentIdThread, isScrollToBottom]);
120
+
121
+ const lastMessage = useMemo(() => {
122
+ const threads: any = data?.getPostThread ?? null;
123
+ const threadPost = threads?.post ?? {};
124
+ const threadReplies = threads?.replies ?? [];
125
+
126
+ if (!threads) {
127
+ return null;
128
+ }
129
+ let threadMessagesData;
130
+ if (threadReplies?.length) {
131
+ threadMessagesData = [...threadReplies];
132
+ } else if (threadPost && Object.keys(threadPost).length) {
133
+ threadMessagesData = [threadPost];
134
+ }
135
+
136
+ let filteredLastMessage =
137
+ threadMessagesData && threadMessagesData?.length > 1
138
+ ? threadMessagesData?.reduce((a, b) => {
139
+ return new Date(a?.updatedAt) > new Date(b?.updatedAt) ? a : b;
140
+ }, []) ?? null
141
+ : threadMessagesData?.length <= 1
142
+ ? threadMessagesData?.[0] ?? []
143
+ : null;
144
+
145
+ return filteredLastMessage;
146
+ }, [data?.getPostThread]);
147
+
148
+ // const lastMessage = useMemo(() => {
149
+ // const threads = data?.threadMessages ?? null;
150
+ // const threadsData = threads?.data ?? [];
151
+ // const replies = threadsData?.map((t: any) => t?.replies)?.flat(1) ?? [];
152
+ // const posts = threadsData?.map((t: any) => t?.post)?.flat(1) ?? [];
153
+ // if (!threadsData?.length) {
154
+ // return null;
155
+ // }
156
+ // let threadMessagesData;
157
+ // if (replies?.length) {
158
+ // threadMessagesData = [...replies];
159
+ // } else if (posts?.length) {
160
+ // threadMessagesData = [...posts];
161
+ // }
162
+
163
+ // let filteredLastMessage =
164
+ // threadMessagesData && threadMessagesData?.length > 1
165
+ // ? threadMessagesData?.reduce((a, b) => {
166
+ // return new Date(a?.updatedAt) > new Date(b?.updatedAt) ? a : b;
167
+ // }, []) ?? null
168
+ // : threadMessagesData?.length <= 1
169
+ // ? threadMessagesData?.[0] ?? []
170
+ // : null;
171
+
172
+ // return filteredLastMessage;
173
+ // // //return data[data.length - 1];
174
+ // }, [data?.threadMessages]);
175
+
176
+ React.useEffect(() => {
177
+ if (lastMessage && (!postId || postId == 0)) {
178
+ const sParentId = lastMessage?.parentId ? lastMessage?.parentId : lastMessage?.id;
179
+ setPostId?.(sParentId);
180
+ }
181
+ }, [lastMessage, postId]);
182
+
183
+ const setThreadMessages = useCallback((messages: any, messagesTotalCount: number) => {
184
+ setChannelMessages((oldMessages: any) => uniqBy([...messages, ...oldMessages], ({ id }) => id));
185
+ setTotalCount(messagesTotalCount);
186
+ }, []);
187
+
188
+ const scrollToBottom = React.useCallback(() => {
189
+ if (threadMessageRootRef?.current) {
190
+ setIsScrollToBottom(false);
191
+ threadMessageRootRef.current.scrollTop = threadMessageRootRef.current.scrollHeight;
192
+ }
193
+ }, [threadMessageRootRef]);
194
+
195
+ const handleSend = useCallback(
196
+ async (message: string, files: []) => {
197
+ if (!(message && channelId)) {
198
+ return;
199
+ }
200
+ const newPostId = objectId();
201
+
202
+ if (files && files?.length > 0) {
203
+ const uploadResponse = await startUpload({
204
+ file: files,
205
+ saveUploadedFile: {
206
+ variables: {
207
+ newPostId,
208
+ },
209
+ },
210
+ createUploadLink: {
211
+ variables: {
212
+ newPostId,
213
+ },
214
+ },
215
+ });
216
+ if (!uploadResponse || uploadResponse?.error) {
217
+ const errorMsg =
218
+ uploadResponse?.error?.message || 'File upload failed. Please check your S3 configuration.';
219
+ console.error('Upload failed:', errorMsg);
220
+ alert(`Upload failed: ${errorMsg}`);
221
+ setLoading(false);
222
+ return;
223
+ }
224
+ const uploadedFiles = uploadResponse.data as unknown as IFileInfo[];
225
+ if (uploadResponse.data) {
226
+ const files = uploadedFiles?.map((f: any) => f.id) ?? null;
227
+ await sendThreadMessage({
228
+ variables: {
229
+ postId: newPostId,
230
+ channelId,
231
+ postThreadId: postThread && postThread?.id,
232
+ postParentId: !postId || postId == 0 ? null : postId,
233
+ threadMessageInput: {
234
+ content: message,
235
+ files,
236
+ role,
237
+ },
238
+ },
239
+ update: (cache, { data, errors }) => {
240
+ if (!data || errors) {
241
+ setLoading(false);
242
+ return;
243
+ }
244
+ const responseMessage = data?.createPostThread?.lastMessage;
245
+ // setPostThread(data?.createPostThread?.data);
246
+ // if (!postId || postId == 0) {
247
+ // setPostId(data?.createPostThread?.lastMessage?.id);
248
+ // }
249
+
250
+ setChannelToTop(channelToTop + 1);
251
+ setLoading(false);
252
+
253
+ // scrollToBottom();
254
+ },
255
+ });
256
+ }
257
+ } else {
258
+ await sendThreadMessage({
259
+ variables: {
260
+ channelId,
261
+ postParentId: !postId || postId == 0 ? null : postId,
262
+ postThreadId: postThread && postThread?.id,
263
+ threadMessageInput: {
264
+ content: message,
265
+ role,
266
+ },
267
+ },
268
+ update: (cache, { data, errors }) => {
269
+ if (!data || errors) {
270
+ return;
271
+ }
272
+ // setPostThread(data?.createPostThread.data);
273
+ // if (!postId || postId == 0) {
274
+ // setPostId(data?.createPostThread?.lastMessage?.id);
275
+ // }
276
+ setChannelToTop(channelToTop + 1);
277
+ //scrollToBottom();
278
+ },
279
+ });
280
+ }
281
+ },
282
+ [setChannelMessages, channelId, postId, channelToTop, postThread],
283
+ );
284
+
285
+ const onFetchOld = useCallback(
286
+ async (skip: number) => {
287
+ if (channelId && postId) {
288
+ setLoadingOldMessages(true);
289
+ fetchMoreMessages({
290
+ variables: {
291
+ channelId: channelId?.toString(),
292
+ role: role?.toString(),
293
+ postParentId: postId?.toString(),
294
+ // selectedFields: 'id channel post replies replyCount lastReplyAt createdAt updatedAt',
295
+ limit: MESSAGES_PER_PAGE,
296
+ skip: skip - 1,
297
+ },
298
+ })
299
+ .then((res: any) => {
300
+ if (res?.data?.getPostThread) {
301
+ const threads: any = res?.data?.getPostThread;
302
+ const threadReplies = threads?.replies ?? [];
303
+ const messeageTotalCount = threads?.replyCount ?? 0;
304
+ setThreadMessages(threadReplies, messeageTotalCount);
305
+ if (threadMessageRootRef?.current) {
306
+ threadMessageRootRef.current.scrollTop =
307
+ threadMessageRootRef.current.scrollTop +
308
+ threadMessageRootRef.current.clientHeight / 2;
309
+ }
310
+ }
311
+ })
312
+ // .then((res) => {
313
+ // if (res?.data?.threadMessages?.data) {
314
+ // const threads = res?.data?.threadMessages ?? null;
315
+ // const threadsData = threads?.data ?? [];
316
+ // const threadReplies = threadsData?.map((t: any) => t?.replies)?.flat(1) ?? [];
317
+ // const messeageTotalCount = threadsData?.reduce((accumulator, thread) => {
318
+ // return accumulator + thread?.replyCount;
319
+ // }, 0);
320
+ // const posts = threadsData?.map((t: any) => t?.post)?.flat(1) ?? [];
321
+ // const messages = [...posts, ...threadReplies];
322
+ // setThreadMessages(threadReplies, messages?.length);
323
+ // if (threadMessageRootRef?.current) {
324
+ // threadMessageRootRef.current.scrollTop =
325
+ // threadMessageRootRef.current.scrollTop +
326
+ // threadMessageRootRef.current.clientHeight / 2;
327
+ // }
328
+ // }
329
+ // })
330
+ .finally(() => {
331
+ setLoadingOldMessages(false);
332
+ })
333
+ .catch((error: any) => {
334
+ setLoadingOldMessages(false);
335
+ });
336
+ }
337
+ },
338
+ [postId, channelId, threadMessageRootRef, channelMessages],
339
+ );
340
+
341
+ const onMessagesScroll = useCallback(
342
+ async (e) => {
343
+ if (threadMessageRootRef.current) {
344
+ const {
345
+ clientHeight: messageContainerClientHeight,
346
+ scrollHeight: messageContainerScrollHeight,
347
+ scrollTop: messageContainerScrollTop,
348
+ offsetTop: messageContainerOffsetTop,
349
+ } = threadMessageRootRef?.current;
350
+ if (
351
+ messageContainerClientHeight - messageContainerScrollTop == messageContainerScrollHeight &&
352
+ !loadingOldMessages &&
353
+ totalCount > channelMessages.length
354
+ ) {
355
+ await onFetchOld(channelMessages?.length);
356
+ }
357
+ }
358
+ },
359
+ [threadMessageRootRef, loadingOldMessages, channelMessages, totalCount],
360
+ );
361
+
362
+ const sortedMessages = useMemo(
363
+ () => channelMessages && orderBy(channelMessages, ['createdAt'], ['asc']),
364
+ [channelMessages],
365
+ );
366
+
367
+ return (
368
+ <React.Fragment>
369
+ {goBack && (
370
+ <button
371
+ className="absolute m-1.5 w-10 bg-transparent text-gray-300 z-10 text-xs hover:border-none hover:shadow-none focus:border-none focus:shadow-none focus:outline-none"
372
+ onClick={() => {
373
+ setChannelId?.(channelId);
374
+ setPostId?.(1);
375
+ }}
376
+ >
377
+ <BiChevronLeftSquare fontSize="32" />
378
+ </button>
379
+ )}
380
+ <div
381
+ ref={threadMessageRootRef}
382
+ className="flex flex-col-reverse overflow-y-auto flex-grow flex-shrink p-4 px-2.5 md:px-12 lg:px-20"
383
+ onScroll={onMessagesScroll}
384
+ >
385
+ <Messages
386
+ innerRef={messageListRef}
387
+ channelId={channelId}
388
+ currentUser={currentUser}
389
+ channelMessages={sortedMessages}
390
+ totalCount={totalCount}
391
+ onMessageClick={onMessageClick}
392
+ subscribeToNewMessages={() =>
393
+ subscribeToMore({
394
+ document: CHAT_MESSAGE_ADDED,
395
+ variables: {
396
+ channelId: channelId?.toString(),
397
+ postParentId: !postId || postId == 0 ? null : postId?.toString(),
398
+ },
399
+ updateQuery: (prev, { subscriptionData }: any) => {
400
+ if (!subscriptionData.data) return prev;
401
+ const newMessage: any = subscriptionData?.data?.threadChatMessageAdded;
402
+ const prevReplyCount = prev?.getPostThread?.replyCount;
403
+ const newReplyCount = prevReplyCount + 1;
404
+
405
+ return Object.assign({}, prev, {
406
+ getPostThread: {
407
+ ...prev?.getPostThread,
408
+ lastReplyAt: newMessage.createdAt,
409
+ replies: [newMessage, ...prev?.getPostThread?.replies],
410
+ replyCount: newReplyCount,
411
+ updatedAt: newMessage.createdAt,
412
+ },
413
+ });
414
+ },
415
+ })
416
+ }
417
+ // subscribeToNewServiceMessages={() =>
418
+ // subscribeToMore({
419
+ // document: THREAD_CHAT_ADDED,
420
+ // variables: {
421
+ // channelId: channelId?.toString(),
422
+ // postParentId: !postId || postId == 0 ? null : postId?.toString(),
423
+ // },
424
+ // updateQuery: (prev, { subscriptionData }: any) => {
425
+ // if (!subscriptionData.data) return prev;
426
+
427
+ // const newPostThreadData: any = subscriptionData?.data?.threadCreatedUpdated?.data;
428
+ // const newMessage: any = subscriptionData?.data?.threadCreatedUpdated?.lastMessage;
429
+ // const updatedData = prev?.threadMessages?.data?.map((t: any) =>
430
+ // t.id === newPostThreadData?.id
431
+ // ? {
432
+ // ...t,
433
+ // replies: [...t?.replies, newMessage],
434
+ // replyCount: newPostThreadData?.replyCount,
435
+ // lastReplyAt: newPostThreadData?.lastReplyAt,
436
+ // updatedAt: newPostThreadData?.updatedAt,
437
+ // }
438
+ // : t,
439
+ // );
440
+
441
+ // return Object.assign({}, prev, {
442
+ // threadMessages: {
443
+ // ...prev?.threadMessages,
444
+ // totalCount: newPostThreadData?.totalCount ?? 0,
445
+ // // totalCount: prev?.threadMessages?.totalCount + 1,
446
+ // data: updatedData?.length > 0 ? updatedData : [newPostThreadData],
447
+ // },
448
+ // });
449
+ // },
450
+ // })
451
+ // }
452
+ />
453
+ </div>
454
+ <MessageInput channelId={channelId} handleSend={handleSend} placeholder="Message" />
455
+ </React.Fragment>
456
+ );
457
+ });