@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,378 @@
1
+ import React, { useCallback, useMemo, useRef, useState } from 'react';
2
+ import { MessageInput, Messages } from '../components';
3
+ import { BiChevronLeftSquare } from '@react-icons/all-files/bi/BiChevronLeftSquare.js';
4
+ import { IFileInfo, IPostThread } from 'common';
5
+ import {
6
+ OnThreadChatMessageAddedDocument as CHAT_MESSAGE_ADDED,
7
+ useCreatePostThreadMutation,
8
+ useThreadMessagesLazyQuery,
9
+ useGetPostThreadLazyQuery,
10
+ useViewChannelDetailQuery,
11
+ } from 'common/graphql';
12
+ import { useUploadFiles } from '@messenger-box/platform-client';
13
+ import { config } from '../config';
14
+ import { orderBy, uniqBy } from 'lodash-es';
15
+ import { useDispatch, useSelector } from 'react-redux';
16
+ import { userSelector } from '@adminide-stack/user-auth0-client';
17
+ import { useNavigate } from '@remix-run/react';
18
+ import { objectId } from '@messenger-box/core';
19
+
20
+ const { MESSAGES_PER_PAGE, WEB_INBOX_MESSEGE_PATH } = config;
21
+
22
+ interface ThreadMessagesProps {
23
+ channelId: any;
24
+ postParentId: any;
25
+ isPostParentIdThread?: any;
26
+ role: string;
27
+ goBack?: boolean;
28
+ pathPrefix?: string;
29
+ setPostId?: (id: any) => void;
30
+ }
31
+
32
+ // Custom Skeleton component using Tailwind
33
+ const Skeleton = ({ height = '40px' }: { height?: string }) => (
34
+ <div className="animate-pulse bg-gray-200 rounded" style={{ height }} />
35
+ );
36
+
37
+ const ThreadMessages = ({
38
+ channelId,
39
+ postParentId,
40
+ role,
41
+ isPostParentIdThread,
42
+ goBack = false,
43
+ pathPrefix,
44
+ setPostId,
45
+ }: ThreadMessagesProps) => {
46
+ const navigate = useNavigate();
47
+ const currentUser: any = useSelector(userSelector);
48
+ const [parentId, setParentId] = React.useState<any>(postParentId);
49
+ const [channelMessages, setChannelMessages] = React.useState<any>([]);
50
+ const [totalCount, setTotalCount] = React.useState<any>(0);
51
+ const [loadingOldMessages, setLoadingOldMessages] = React.useState<boolean>(false);
52
+ const [loading, setLoading] = React.useState<boolean>(true);
53
+ const dispatch = useDispatch();
54
+ const threadMessageRootRef = React.useRef(null);
55
+ const threadMessageListRef = React.useRef(null);
56
+ const [postThread, setPostThread] = useState<IPostThread>();
57
+ const messageListRef = useRef(null);
58
+ const [channelToTop, setChannelToTop] = React.useState(0);
59
+ const [isScrollToBottom, setIsScrollToBottom] = useState(false);
60
+ const { startUpload } = useUploadFiles();
61
+ const { refetch: refetchChannel } = useViewChannelDetailQuery({
62
+ variables: {
63
+ id: channelId?.toString(),
64
+ },
65
+ });
66
+ const [sendThreadMessage] = useCreatePostThreadMutation();
67
+ const [
68
+ getThreadMessages,
69
+ { data, loading: threadLoading, fetchMore: fetchMoreMessages, refetch: refetchThreadMessages, subscribeToMore },
70
+ ] = useGetPostThreadLazyQuery({ fetchPolicy: 'cache-and-network' });
71
+
72
+ const [selectedPost, setSelectedPost] = useState(null);
73
+
74
+ const onMessageClick = (msg) => {
75
+ setSelectedPost(msg);
76
+ };
77
+
78
+ React.useEffect(() => {
79
+ refetchChannel({ id: channelId?.toString() });
80
+ if (postParentId) {
81
+ refetchThreadMessages({
82
+ channelId: channelId?.toString(),
83
+ role: role?.toString(),
84
+ postParentId: postParentId?.toString(),
85
+ selectedFields: 'id channel post replies replyCount lastReplyAt createdAt updatedAt',
86
+ limit: MESSAGES_PER_PAGE,
87
+ });
88
+ }
89
+ setParentId(postParentId);
90
+ }, [postParentId]);
91
+
92
+ React.useEffect(() => {
93
+ // if (parentId && parentId == 0) {
94
+ setLoading(false);
95
+ if (channelId && parentId) {
96
+ getThreadMessages({
97
+ variables: {
98
+ channelId: channelId?.toString(),
99
+ role: role?.toString(),
100
+ postParentId: !parentId || parentId == 0 ? null : parentId?.toString(),
101
+ selectedFields: 'id channel post replies replyCount lastReplyAt createdAt updatedAt',
102
+ limit: MESSAGES_PER_PAGE,
103
+ },
104
+ });
105
+ }
106
+ }, [channelId, parentId]);
107
+
108
+ React.useEffect(() => {
109
+ if (data?.getPostThread) {
110
+ const threads: any = data.getPostThread;
111
+ const threadPost = threads?.post ?? [];
112
+ const threadReplies = threads?.replies ?? [];
113
+ const messeageTotalCount = threads?.replyCount ?? 0;
114
+ const messages = [threadPost, ...threadReplies];
115
+ if (
116
+ (messages && messages.length > 0 && messeageTotalCount > totalCount) ||
117
+ (messages && messages.length > 0 && channelMessages.length === 0)
118
+ ) {
119
+ setThreadMessages(messages, messeageTotalCount);
120
+ }
121
+ }
122
+ if (isScrollToBottom && channelMessages) scrollToBottom();
123
+ }, [data, channelMessages, loadingOldMessages, totalCount, isPostParentIdThread, isScrollToBottom]);
124
+
125
+ const setThreadMessages = (messages: any, messagesTotalCount: number) => {
126
+ setChannelMessages((oldMessages: any) => uniqBy([...messages, ...oldMessages], ({ id }) => id));
127
+ setTotalCount(messagesTotalCount);
128
+ };
129
+
130
+ const sortedMessages = useMemo(
131
+ () => channelMessages && orderBy(channelMessages, ['createdAt'], ['asc']),
132
+ [channelMessages],
133
+ );
134
+
135
+ const scrollToBottom = React.useCallback(() => {
136
+ if (threadMessageListRef?.current) {
137
+ setIsScrollToBottom(false);
138
+ threadMessageListRef.current.scrollTop = threadMessageListRef.current.scrollHeight;
139
+ }
140
+ }, [threadMessageListRef]);
141
+
142
+ const handleSend = useCallback(
143
+ async (message: string, files: []) => {
144
+ if (!(message && channelId)) {
145
+ return;
146
+ }
147
+ const postId = objectId();
148
+
149
+ if (files && files?.length > 0) {
150
+ const uploadResponse = await startUpload({
151
+ file: files,
152
+ saveUploadedFile: {
153
+ variables: {
154
+ postId,
155
+ },
156
+ },
157
+ createUploadLink: {
158
+ variables: {
159
+ postId,
160
+ },
161
+ },
162
+ });
163
+ if (!uploadResponse || uploadResponse?.error) {
164
+ const errorMsg =
165
+ uploadResponse?.error?.message || 'File upload failed. Please check your S3 configuration.';
166
+ console.error('Upload failed:', errorMsg);
167
+ alert(`Upload failed: ${errorMsg}`);
168
+ setLoading(false);
169
+ return;
170
+ }
171
+ const uploadedFiles = uploadResponse.data as unknown as IFileInfo[];
172
+ if (uploadResponse.data) {
173
+ const files = uploadedFiles?.map((f: any) => f.id) ?? null;
174
+ await sendThreadMessage({
175
+ variables: {
176
+ postId,
177
+ channelId,
178
+ postThreadId: postThread && postThread?.id,
179
+ postParentId: !parentId || parentId == 0 ? null : parentId,
180
+ threadMessageInput: {
181
+ content: message,
182
+ files,
183
+ role,
184
+ },
185
+ },
186
+ update: (cache, { data, errors }) => {
187
+ if (!data || errors) {
188
+ setLoading(false);
189
+ return;
190
+ }
191
+ const responseMessage = data?.createPostThread?.lastMessage;
192
+ setPostThread(data?.createPostThread?.data);
193
+ if (!parentId || parentId == 0) {
194
+ setParentId(data?.createPostThread?.lastMessage?.id);
195
+ setPostId(data?.createPostThread?.lastMessage?.id);
196
+ // dispatch(
197
+ // push(
198
+ // `${pathPrefix ? pathPrefix : ''}/${WEB_INBOX_MESSEGE_PATH}/${channelId}/${
199
+ // data?.createPostThread?.lastMessage?.id
200
+ // }`,
201
+ // ),
202
+ // );
203
+ }
204
+
205
+ setChannelToTop(channelToTop + 1);
206
+ setLoading(false);
207
+
208
+ // scrollToBottom();
209
+ },
210
+ });
211
+ }
212
+ } else {
213
+ await sendThreadMessage({
214
+ variables: {
215
+ channelId,
216
+ postParentId: !parentId || parentId == 0 ? null : parentId,
217
+ postThreadId: postThread && postThread?.id,
218
+ threadMessageInput: {
219
+ content: message,
220
+ role,
221
+ },
222
+ },
223
+ update: (cache, { data, errors }) => {
224
+ if (!data || errors) {
225
+ return;
226
+ }
227
+ setPostThread(data?.createPostThread.data);
228
+ if (!parentId || parentId == 0) {
229
+ setParentId(data?.createPostThread?.lastMessage?.id);
230
+ setPostId(data?.createPostThread?.lastMessage?.id);
231
+ // dispatch(
232
+ // push(
233
+ // `${pathPrefix ? pathPrefix : ''}/${WEB_INBOX_MESSEGE_PATH}/${channelId}/${
234
+ // data?.createPostThread?.lastMessage?.id
235
+ // }`,
236
+ // ),
237
+ // );
238
+ }
239
+ setChannelToTop(channelToTop + 1);
240
+ //scrollToBottom();
241
+ },
242
+ });
243
+ }
244
+ },
245
+ [setChannelMessages, channelId, parentId, channelToTop, postThread],
246
+ );
247
+
248
+ const onFetchOld = useCallback(
249
+ async (skip: number) => {
250
+ if (channelId && parentId) {
251
+ setLoadingOldMessages(true);
252
+ fetchMoreMessages({
253
+ variables: {
254
+ channelId: channelId?.toString(),
255
+ role: role?.toString(),
256
+ postParentId: parentId?.toString(),
257
+ selectedFields: 'id channel post replies replyCount lastReplyAt createdAt updatedAt',
258
+ limit: MESSAGES_PER_PAGE,
259
+ skip: skip - 1,
260
+ },
261
+ })
262
+ .then((res: any) => {
263
+ if (res?.data?.getPostThread) {
264
+ const threads: any = res?.data?.getPostThread;
265
+ const threadReplies = threads?.replies ?? [];
266
+ const messeageTotalCount = threads?.replyCount ?? 0;
267
+ setThreadMessages(threadReplies, messeageTotalCount);
268
+ if (threadMessageRootRef?.current) {
269
+ threadMessageRootRef.current.scrollTop =
270
+ threadMessageRootRef.current.scrollTop +
271
+ threadMessageRootRef.current.clientHeight / 2;
272
+ }
273
+ }
274
+ })
275
+ .finally(() => {
276
+ setLoadingOldMessages(false);
277
+ })
278
+ .catch((error: any) => {
279
+ setLoadingOldMessages(false);
280
+ });
281
+ }
282
+ },
283
+ [parentId, channelId, threadMessageRootRef, channelMessages],
284
+ );
285
+
286
+ const onMessagesScroll = useCallback(
287
+ async (e) => {
288
+ if (threadMessageRootRef.current) {
289
+ const {
290
+ clientHeight: messageContainerClientHeight,
291
+ scrollHeight: messageContainerScrollHeight,
292
+ scrollTop: messageContainerScrollTop,
293
+ offsetTop: messageContainerOffsetTop,
294
+ } = threadMessageRootRef?.current;
295
+ if (
296
+ messageContainerClientHeight - messageContainerScrollTop == messageContainerScrollHeight &&
297
+ !loadingOldMessages &&
298
+ totalCount > channelMessages.length
299
+ ) {
300
+ await onFetchOld(channelMessages?.length);
301
+ }
302
+ }
303
+ },
304
+ [threadMessageRootRef, loadingOldMessages, channelMessages, totalCount],
305
+ );
306
+
307
+ const handleGoBack = useCallback(() => {
308
+ if (channelId) navigate(`${pathPrefix ? pathPrefix : ''}/${WEB_INBOX_MESSEGE_PATH}/${channelId}/1`);
309
+ }, [channelId]);
310
+
311
+ if ((loading || loadingOldMessages) && !parentId) {
312
+ return (
313
+ <div className="flex flex-col space-y-4">
314
+ {Array(10)
315
+ .fill(1)
316
+ .map((x, y) => (
317
+ <Skeleton height="40px" key={y} />
318
+ ))}
319
+ </div>
320
+ );
321
+ }
322
+
323
+ return (
324
+ <>
325
+ {goBack && (
326
+ <button
327
+ className="absolute z-10 m-1.5 w-10 bg-transparent text-gray-400 hover:text-gray-300 focus:outline-none focus:ring-0 transition-colors duration-200"
328
+ onClick={() => navigate(-1)}
329
+ >
330
+ <BiChevronLeftSquare className="text-3xl" />
331
+ </button>
332
+ )}
333
+
334
+ <div
335
+ ref={threadMessageRootRef}
336
+ className="flex flex-col-reverse overflow-y-auto flex-grow flex-shrink p-4 px-2.5 md:px-12 lg:px-20"
337
+ onScroll={onMessagesScroll}
338
+ >
339
+ <Messages
340
+ innerRef={messageListRef}
341
+ channelId={channelId}
342
+ currentUser={currentUser}
343
+ channelMessages={sortedMessages}
344
+ totalCount={totalCount}
345
+ onMessageClick={onMessageClick}
346
+ subscribeToNewMessages={() =>
347
+ subscribeToMore({
348
+ document: CHAT_MESSAGE_ADDED,
349
+ variables: {
350
+ channelId: channelId?.toString(),
351
+ postParentId: !parentId || parentId == 0 ? null : parentId?.toString(),
352
+ },
353
+ updateQuery: (prev, { subscriptionData }: any) => {
354
+ if (!subscriptionData.data) return prev;
355
+ const newMessage: any = subscriptionData?.data?.threadChatMessageAdded;
356
+ const prevReplyCount = prev?.getPostThread?.replyCount;
357
+ const newReplyCount = prevReplyCount + 1;
358
+
359
+ return Object.assign({}, prev, {
360
+ getPostThread: {
361
+ ...prev?.getPostThread,
362
+ lastReplyAt: newMessage.createdAt,
363
+ replies: [newMessage, ...prev?.getPostThread?.replies],
364
+ replyCount: newReplyCount,
365
+ updatedAt: newMessage.createdAt,
366
+ },
367
+ });
368
+ },
369
+ })
370
+ }
371
+ />
372
+ </div>
373
+ <MessageInput channelId={channelId} handleSend={handleSend} placeholder="Message" />
374
+ </>
375
+ );
376
+ };
377
+
378
+ export default React.memo(ThreadMessages);