@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,185 @@
1
+ import React__default,{useMemo}from'react';import {useThreadMessagesQuery,OnThreadCreatedUpdatedDocument}from'common/graphql';import {isToday,isYesterday,format}from'date-fns';import {useLocation}from'@remix-run/react';const createdAtText = value => {
2
+ if (!value) return '';
3
+ let date = new Date(value);
4
+ if (isToday(date)) return 'Today';
5
+ if (isYesterday(date)) return 'Yesterday';
6
+ return format(new Date(value), 'MMM dd, yyyy');
7
+ };
8
+ // Custom Skeleton component using Tailwind
9
+ const Skeleton = () => React__default.createElement("div", {
10
+ className: "animate-pulse"
11
+ }, React__default.createElement("div", {
12
+ className: "h-4 bg-gray-200 dark:bg-gray-700 rounded mb-2"
13
+ }), React__default.createElement("div", {
14
+ className: "h-4 bg-gray-200 dark:bg-gray-700 rounded w-3/4 mb-2"
15
+ }), React__default.createElement("div", {
16
+ className: "h-4 bg-gray-200 dark:bg-gray-700 rounded w-1/2"
17
+ }));
18
+ const ServiceLastMessageComponent = ({
19
+ subscribeToNewMessages,
20
+ channel,
21
+ channelType,
22
+ lastMessage
23
+ }) => {
24
+ React__default.useEffect(() => subscribeToNewMessages(), []);
25
+ return React__default.createElement("div", {
26
+ className: "flex flex-col w-full"
27
+ }, React__default.createElement("div", {
28
+ className: "w-full flex justify-between items-center"
29
+ }, React__default.createElement("span", {
30
+ className: "text-xs text-green-500 truncate"
31
+ }, channelType), React__default.createElement("span", {
32
+ className: "text-xs text-gray-500"
33
+ }, lastMessage ? createdAtText(lastMessage?.createdAt) : '')), React__default.createElement("p", {
34
+ className: "text-sm text-gray-600 dark:text-gray-300 font-bold mt-1"
35
+ }, channel?.title), React__default.createElement("p", {
36
+ className: "text-sm text-gray-600 dark:text-gray-400 truncate w-4/5 mt-1"
37
+ }, lastMessage?.message));
38
+ };
39
+ const ServiceConversationItemComponent = ({
40
+ showBorder,
41
+ currentUser,
42
+ filter,
43
+ channel,
44
+ handleSelectChannel,
45
+ users,
46
+ selectedChannelId,
47
+ role
48
+ }) => {
49
+ const [parentId, setParentId] = React__default.useState(null);
50
+ const [messages, setMessages] = React__default.useState([]);
51
+ const [servicePostParentId, setServicePostParentId] = React__default.useState(null);
52
+ const {
53
+ pathname
54
+ } = useLocation();
55
+ const {
56
+ data: threadMessages,
57
+ loading: threadMessageLoading,
58
+ fetchMore: fetchMoreMessages,
59
+ refetch: refetchThreadMessages,
60
+ subscribeToMore
61
+ } = useThreadMessagesQuery({
62
+ variables: {
63
+ channelId: channel?.id?.toString(),
64
+ role,
65
+ limit: 10
66
+ },
67
+ fetchPolicy: 'cache-and-network'
68
+ });
69
+ React__default.useEffect(() => {
70
+ if (channel) refetchThreadMessages({
71
+ channelId: channel?.id?.toString(),
72
+ role,
73
+ limit: 10
74
+ });
75
+ }, [channel]);
76
+ // }, [selectedChannelId, channel, role]);
77
+ React__default.useEffect(() => {
78
+ if (threadMessages?.threadMessages?.data?.length) {
79
+ const {
80
+ data
81
+ } = threadMessages.threadMessages;
82
+ const replies = data?.map(t => t?.replies)?.flat(1)?.filter(p => p?.message !== '') ?? [];
83
+ const posts = data?.map(t => t?.post)?.flat(1)?.filter(p => p?.message !== '') ?? [];
84
+ // const post =
85
+ // data?.find((t: any) => {
86
+ // return t?.post?.message !== '';
87
+ // }) ??
88
+ // data?.find((t: any) => {
89
+ // return t?.post;
90
+ // }) ??
91
+ // null;
92
+ if (replies?.length) {
93
+ setMessages(pre => [...pre, ...replies]);
94
+ } else if (posts?.length) {
95
+ setMessages(pre => [...pre, ...posts]);
96
+ }
97
+ }
98
+ }, [threadMessages]);
99
+ const lastMessage = useMemo(() => {
100
+ const threadMessagesData = messages?.flat(1);
101
+ if (!threadMessagesData?.length) {
102
+ return null;
103
+ }
104
+ let filteredLastMessage = threadMessagesData && threadMessagesData?.length > 1 ? threadMessagesData?.reduce((a, b) => {
105
+ return new Date(a?.updatedAt) > new Date(b?.updatedAt) ? a : b;
106
+ }, []) ?? null : threadMessagesData?.length <= 1 ? threadMessagesData?.[0] ?? [] : null;
107
+ return filteredLastMessage;
108
+ // //return data[data.length - 1];
109
+ }, [messages]);
110
+ React__default.useEffect(() => {
111
+ if (lastMessage) {
112
+ const sParentId = lastMessage?.parentId ? lastMessage?.parentId : lastMessage?.id;
113
+ setServicePostParentId(sParentId);
114
+ }
115
+ }, [lastMessage]);
116
+ const creatorAndMembersId = React__default.useMemo(() => {
117
+ if (!channel?.members) return null;
118
+ const membersIds = channel?.members?.filter(m => m?.user?.id !== currentUser?.id)?.map(mu => mu?.user?.id) ?? [];
119
+ const creatorId = channel?.creator?.id;
120
+ const mergedIds = [].concat(membersIds, creatorId) ?? [];
121
+ return mergedIds?.filter((m, pos) => mergedIds?.indexOf(m) === pos) ?? [];
122
+ }, [channel]);
123
+ const postParentId = React__default.useMemo(() => {
124
+ if (!creatorAndMembersId?.length) return null;
125
+ return creatorAndMembersId?.length && creatorAndMembersId?.includes(currentUser?.id) ? 1 : lastMessage?.parentId ? lastMessage?.parentId : lastMessage?.id ?? 0;
126
+ }, [creatorAndMembersId, lastMessage]);
127
+ React__default.useEffect(() => {
128
+ if (postParentId) {
129
+ setParentId(postParentId);
130
+ }
131
+ }, [postParentId]);
132
+ const channelType = useMemo(() => {
133
+ return channel?.type;
134
+ }, [channel]);
135
+ // const servicePostParentId = lastMessage?.parentId ? lastMessage?.parentId : lastMessage?.id;
136
+ return React__default.createElement("div", {
137
+ key: `services_channel_${channel.id}`,
138
+ className: `cursor-pointer flex items-center border-b p-3 ${showBorder ? 'border-gray-300' : 'border-transparent'} ${channel.id == selectedChannelId ? 'bg-gray-300 dark:bg-gray-500' : ''}`,
139
+ onClick: () => handleSelectChannel(channel.id, postParentId)
140
+ }, React__default.createElement("div", {
141
+ className: "w-10 h-10 rounded-full bg-gray-400 flex-shrink-0 overflow-hidden"
142
+ }, channel?.creator?.picture ? React__default.createElement("img", {
143
+ src: channel.creator.picture,
144
+ alt: "Creator avatar",
145
+ className: "w-full h-full object-cover"
146
+ }) : React__default.createElement("div", {
147
+ className: "w-full h-full bg-gray-400"
148
+ })), React__default.createElement("div", {
149
+ className: "ml-2 flex-grow min-w-10 max-w-96"
150
+ }, threadMessageLoading && React__default.createElement(Skeleton, null), !threadMessageLoading && React__default.createElement(ServiceLastMessageComponent, {
151
+ channel: channel,
152
+ channelType: channelType,
153
+ lastMessage: lastMessage,
154
+ subscribeToNewMessages: () => subscribeToMore({
155
+ document: OnThreadCreatedUpdatedDocument,
156
+ variables: {
157
+ channelId: channel?.id?.toString(),
158
+ postParentId: postParentId && postParentId == 1 ? null : servicePostParentId
159
+ },
160
+ updateQuery: (prev, {
161
+ subscriptionData
162
+ }) => {
163
+ if (!subscriptionData.data) return prev;
164
+ const newPostThreadData = subscriptionData?.data?.threadCreatedUpdated?.data;
165
+ const newMessage = subscriptionData?.data?.threadCreatedUpdated?.lastMessage;
166
+ const updatedData = prev?.threadMessages?.data?.map(t => t.id === newPostThreadData?.id ? {
167
+ ...t,
168
+ replies: [...t?.replies, newMessage],
169
+ replyCount: newPostThreadData?.replyCount,
170
+ lastReplyAt: newPostThreadData?.lastReplyAt,
171
+ updatedAt: newPostThreadData?.updatedAt
172
+ } : t) ?? [];
173
+ return Object.assign({}, prev, {
174
+ threadMessages: {
175
+ ...prev?.threadMessages,
176
+ totalCount: newPostThreadData?.totalCount ?? 0,
177
+ // totalCount: prev?.threadMessages?.totalCount + 1,
178
+ data: updatedData?.length > 0 ? updatedData : [newPostThreadData]
179
+ }
180
+ });
181
+ }
182
+ })
183
+ })));
184
+ };
185
+ const ServiceConversationItem = React__default.memo(ServiceConversationItemComponent);export{ServiceConversationItem};//# sourceMappingURL=ServiceConversationItem.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ServiceConversationItem.js","sources":["../../../src/components/InboxMessage/ServiceConversationItem.tsx"],"sourcesContent":[null],"names":["React"],"mappings":"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"}
@@ -0,0 +1,12 @@
1
+ import React from 'react';
2
+ export declare const ServiceInboxItem: React.MemoExoticComponent<({ showBorder, currentUser, filter, channel, handleSelectChannel, users, selectedChannelId, role, }: {
3
+ showBorder: any;
4
+ currentUser: any;
5
+ filter: any;
6
+ channel: any;
7
+ handleSelectChannel: any;
8
+ users: any;
9
+ selectedChannelId: any;
10
+ role: any;
11
+ }) => React.JSX.Element>;
12
+ //# sourceMappingURL=ServiceInboxItem.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ServiceInboxItem.d.ts","sourceRoot":"","sources":["../../../src/components/InboxMessage/ServiceInboxItem.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAkB,MAAM,OAAO,CAAC;AA8MvC,eAAO,MAAM,gBAAgB;;;;;;;;;wBAAwC,CAAC"}
@@ -0,0 +1,182 @@
1
+ import React__default,{useMemo}from'react';import {useLocation}from'@remix-run/react';import {useThreadMessagesQuery,OnThreadCreatedUpdatedDocument}from'common/graphql';import {isToday,isYesterday,format}from'date-fns';const createdAtText = value => {
2
+ if (!value) return '';
3
+ let date = new Date(value);
4
+ if (isToday(date)) return 'Today';
5
+ if (isYesterday(date)) return 'Yesterday';
6
+ return format(new Date(value), 'MMM dd, yyyy');
7
+ };
8
+ const ServiceInboxItemComponent = ({
9
+ showBorder,
10
+ currentUser,
11
+ filter,
12
+ channel,
13
+ handleSelectChannel,
14
+ users,
15
+ selectedChannelId,
16
+ role
17
+ }) => {
18
+ const [parentId, setParentId] = React__default.useState(null);
19
+ const [messages, setMessages] = React__default.useState([]);
20
+ const [servicePostParentId, setServicePostParentId] = React__default.useState(null);
21
+ const {
22
+ pathname
23
+ } = useLocation();
24
+ const {
25
+ data: threadMessages,
26
+ loading: threadMessageLoading,
27
+ fetchMore: fetchMoreMessages,
28
+ refetch: refetchThreadMessages,
29
+ subscribeToMore
30
+ } = useThreadMessagesQuery({
31
+ variables: {
32
+ channelId: channel?.id?.toString(),
33
+ role,
34
+ limit: 10
35
+ },
36
+ fetchPolicy: 'cache-and-network'
37
+ });
38
+ React__default.useEffect(() => {
39
+ if (channel) refetchThreadMessages({
40
+ channelId: channel?.id?.toString(),
41
+ role,
42
+ limit: 10
43
+ });
44
+ }, [channel, pathname]);
45
+ React__default.useEffect(() => {
46
+ if (threadMessages?.threadMessages?.data?.length) {
47
+ const {
48
+ data
49
+ } = threadMessages.threadMessages;
50
+ const replies = data?.map(t => t?.replies)?.flat(1)?.filter(p => p?.message !== '') ?? [];
51
+ const post = data?.find(t => {
52
+ return t?.post?.message !== '';
53
+ }) ?? data?.find(t => {
54
+ return t?.post;
55
+ }) ?? null;
56
+ if (replies?.length) {
57
+ setMessages(pre => [...pre, ...replies]);
58
+ } else if (post) {
59
+ setMessages(pre => [...pre, ...[post]]);
60
+ }
61
+ }
62
+ }, [threadMessages]);
63
+ const lastMessage = useMemo(() => {
64
+ if (!messages?.length) {
65
+ return null;
66
+ }
67
+ let filteredLastMessage = messages && messages?.length ? messages?.reduce((a, b) => {
68
+ return new Date(a?.updatedAt) > new Date(b?.updatedAt) ? a : b;
69
+ }, []) ?? null : null;
70
+ return filteredLastMessage;
71
+ }, [messages]);
72
+ React__default.useEffect(() => {
73
+ if (lastMessage) {
74
+ const sParentId = lastMessage?.parentId ? lastMessage?.parentId : lastMessage?.id;
75
+ setServicePostParentId(sParentId);
76
+ }
77
+ }, [lastMessage]);
78
+ const creatorAndMembersId = React__default.useMemo(() => {
79
+ if (!channel?.members) return null;
80
+ const membersIds = channel?.members?.filter(m => m?.user?.id !== currentUser?.id)?.map(mu => mu?.user?.id) ?? [];
81
+ const creatorId = channel?.creator?.id;
82
+ const mergedIds = [].concat(membersIds, creatorId) ?? [];
83
+ return mergedIds?.filter((m, pos) => mergedIds?.indexOf(m) === pos) ?? [];
84
+ }, [channel]);
85
+ const postParentId = React__default.useMemo(() => {
86
+ if (!creatorAndMembersId?.length) return null;
87
+ return creatorAndMembersId?.length && creatorAndMembersId?.includes(currentUser?.id) ? 1 : lastMessage?.parentId ? lastMessage?.parentId : lastMessage?.id ?? 0;
88
+ }, [creatorAndMembersId, lastMessage]);
89
+ React__default.useEffect(() => {
90
+ if (postParentId) {
91
+ setParentId(postParentId);
92
+ }
93
+ }, [postParentId]);
94
+ const channelType = useMemo(() => {
95
+ return channel?.type;
96
+ }, [channel]);
97
+ return React__default.createElement("div", {
98
+ key: `services_channel_${channel.id}`,
99
+ className: `
100
+ cursor-pointer flex items-center p-3
101
+ border-b border-solid
102
+ ${showBorder ? 'border-gray-300' : 'border-transparent'}
103
+ ${channel.id == selectedChannelId ? 'bg-gray-300 dark:bg-gray-500' : ''}
104
+ hover:bg-gray-100 dark:hover:bg-gray-600 transition-colors
105
+ `,
106
+ onClick: () => handleSelectChannel(channel.id, postParentId)
107
+ }, React__default.createElement("img", {
108
+ className: "w-10 h-10 rounded-full bg-gray-400",
109
+ src: channel?.creator?.picture || '/default-avatar.svg',
110
+ alt: "Avatar",
111
+ onError: e => {
112
+ if (e.currentTarget.src.includes('default-avatar.svg')) {
113
+ e.currentTarget.src = 'data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNDAiIGhlaWdodD0iNDAiIHZpZXdCb3g9IjAgMCA0MCA0MCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICA8Y2lyY2xlIGN4PSIyMCIgY3k9IjIwIiByPSIyMCIgZmlsbD0iI0U1RTdFQiIvPgogIDxjaXJjbGUgY3g9IjIwIiBjeT0iMTYiIHI9IjYiIGZpbGw9IiM5Q0EzQUYiLz4KICA8cGF0aCBkPSJNOCAzMmMwLTYuNjI3IDUuMzczLTEyIDEyLTEyczEyIDUuMzczIDEyIDEyIiBmaWxsPSIjOUNBM0FGIi8+Cjwvc3ZnPgo=';
114
+ } else {
115
+ e.currentTarget.src = '/default-avatar.svg';
116
+ }
117
+ }
118
+ }), React__default.createElement("div", {
119
+ className: "ml-2 flex-grow min-w-10 max-w-96"
120
+ }, threadMessageLoading && React__default.createElement("div", {
121
+ className: "animate-pulse"
122
+ }, React__default.createElement("div", {
123
+ className: "h-4 bg-gray-300 rounded mb-2"
124
+ }), React__default.createElement("div", {
125
+ className: "h-3 bg-gray-300 rounded w-3/4 mb-2"
126
+ }), React__default.createElement("div", {
127
+ className: "h-3 bg-gray-300 rounded w-1/2"
128
+ })), !threadMessageLoading && React__default.createElement(ServiceLastMessageComponent, {
129
+ channel: channel,
130
+ channelType: channelType,
131
+ lastMessage: lastMessage,
132
+ subscribeToNewMessages: () => subscribeToMore({
133
+ document: OnThreadCreatedUpdatedDocument,
134
+ variables: {
135
+ channelId: channel?.id?.toString(),
136
+ postParentId: postParentId && postParentId == 1 ? null : servicePostParentId
137
+ },
138
+ updateQuery: (prev, {
139
+ subscriptionData
140
+ }) => {
141
+ if (!subscriptionData.data) return prev;
142
+ const newPostThreadData = subscriptionData?.data?.threadCreatedUpdated?.data;
143
+ const newMessage = subscriptionData?.data?.threadCreatedUpdated?.lastMessage;
144
+ const data = prev?.threadMessages?.data?.map(t => t.id === newPostThreadData?.id ? {
145
+ ...t,
146
+ replies: [...t?.replies, newMessage],
147
+ replyCount: newPostThreadData?.replyCount,
148
+ lastReplyAt: newPostThreadData?.lastReplyAt,
149
+ updatedAt: newPostThreadData?.updatedAt
150
+ } : t);
151
+ return Object.assign({}, prev, {
152
+ threadMessages: {
153
+ ...prev?.threadMessages,
154
+ data: data
155
+ }
156
+ });
157
+ }
158
+ })
159
+ })));
160
+ };
161
+ const ServiceInboxItem = React__default.memo(ServiceInboxItemComponent);
162
+ const ServiceLastMessageComponent = ({
163
+ subscribeToNewMessages,
164
+ channel,
165
+ channelType,
166
+ lastMessage
167
+ }) => {
168
+ React__default.useEffect(() => subscribeToNewMessages(), []);
169
+ return React__default.createElement("div", {
170
+ className: "flex flex-col w-full"
171
+ }, React__default.createElement("div", {
172
+ className: "w-full flex justify-between items-center"
173
+ }, React__default.createElement("span", {
174
+ className: "text-xs text-green-500 truncate"
175
+ }, channelType), React__default.createElement("span", {
176
+ className: "text-xs text-gray-500"
177
+ }, lastMessage ? createdAtText(lastMessage?.createdAt) : '')), React__default.createElement("h3", {
178
+ className: "text-sm text-gray-600 dark:text-gray-300 font-bold mt-1"
179
+ }, channel?.title), React__default.createElement("p", {
180
+ className: "text-sm text-gray-600 dark:text-gray-400 truncate w-4/5 mt-1"
181
+ }, lastMessage?.message));
182
+ };export{ServiceInboxItem};//# sourceMappingURL=ServiceInboxItem.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ServiceInboxItem.js","sources":["../../../src/components/InboxMessage/ServiceInboxItem.tsx"],"sourcesContent":[null],"names":["React","THREAD_CHAT_ADDED"],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ import React from 'react';
2
+ import { ActiveStream } from '../../hooks/useStreamAssembler';
3
+ /**
4
+ * Renders a message bubble for an active (in-progress) stream.
5
+ * Shows:
6
+ * - The author name
7
+ * - The accumulated text so far (with basic markdown rendering)
8
+ * - A blinking cursor at the end
9
+ * - A "thinking" state with animated dots when status is 'thinking'
10
+ * - Chunk counter for transparency
11
+ */
12
+ export declare const StreamingMessageBubble: React.FC<{
13
+ stream: ActiveStream;
14
+ isDesktopView?: boolean;
15
+ isSmallScreen?: boolean;
16
+ }>;
17
+ export default StreamingMessageBubble;
18
+ //# sourceMappingURL=StreamingMessageBubble.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StreamingMessageBubble.d.ts","sourceRoot":"","sources":["../../../src/components/InboxMessage/StreamingMessageBubble.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAkB,MAAM,OAAO,CAAC;AACvC,OAAO,EAAE,YAAY,EAAE,MAAM,gCAAgC,CAAC;AAE9D;;;;;;;;GAQG;AACH,eAAO,MAAM,sBAAsB,EAAE,KAAK,CAAC,EAAE,CAAC;IAC1C,MAAM,EAAE,YAAY,CAAC;IACrB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,aAAa,CAAC,EAAE,OAAO,CAAC;CAC3B,CAqGA,CAAC;AAwJF,eAAe,sBAAsB,CAAC"}
@@ -0,0 +1,19 @@
1
+ /**
2
+ * Shared SubscriptionHandler for Apollo subscribeToMore
3
+ *
4
+ * @param subscribeToMore - Apollo subscribeToMore function
5
+ * @param document - GraphQL subscription document
6
+ * @param variables - Variables for the subscription
7
+ * @param updateQuery - Apollo updateQuery function
8
+ * @param onError - Optional error handler
9
+ * @param enabled - If false, disables the subscription
10
+ */
11
+ export declare function SubscriptionHandler({ subscribeToMore, document, variables, updateQuery, onError, enabled, }: {
12
+ subscribeToMore: Function;
13
+ document: any;
14
+ variables: Record<string, any>;
15
+ updateQuery: (prev: any, { subscriptionData }: any) => any;
16
+ onError?: (error: any) => void;
17
+ enabled?: boolean;
18
+ }): any;
19
+ //# sourceMappingURL=SubscriptionHandler.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SubscriptionHandler.d.ts","sourceRoot":"","sources":["../../../src/components/InboxMessage/SubscriptionHandler.tsx"],"names":[],"mappings":"AAEA;;;;;;;;;GASG;AACH,wBAAgB,mBAAmB,CAAC,EAChC,eAAe,EACf,QAAQ,EACR,SAAS,EACT,WAAW,EACX,OAAO,EACP,OAAc,GACjB,EAAE;IACC,eAAe,EAAE,QAAQ,CAAC;IAC1B,QAAQ,EAAE,GAAG,CAAC;IACd,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC/B,WAAW,EAAE,CAAC,IAAI,EAAE,GAAG,EAAE,EAAE,gBAAgB,EAAE,EAAE,GAAG,KAAK,GAAG,CAAC;IAC3D,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG,KAAK,IAAI,CAAC;IAC/B,OAAO,CAAC,EAAE,OAAO,CAAC;CACrB,OA4BA"}
@@ -0,0 +1,41 @@
1
+ import {useEffect}from'react';/**
2
+ * Shared SubscriptionHandler for Apollo subscribeToMore
3
+ *
4
+ * @param subscribeToMore - Apollo subscribeToMore function
5
+ * @param document - GraphQL subscription document
6
+ * @param variables - Variables for the subscription
7
+ * @param updateQuery - Apollo updateQuery function
8
+ * @param onError - Optional error handler
9
+ * @param enabled - If false, disables the subscription
10
+ */
11
+ function SubscriptionHandler({
12
+ subscribeToMore,
13
+ document,
14
+ variables,
15
+ updateQuery,
16
+ onError,
17
+ enabled = true
18
+ }) {
19
+ useEffect(() => {
20
+ if (!enabled) return;
21
+ console.log('SubscriptionHandler: Setting up subscription with variables:', variables);
22
+ const unsubscribe = subscribeToMore({
23
+ document,
24
+ variables,
25
+ updateQuery,
26
+ onError
27
+ });
28
+ console.log('SubscriptionHandler: Subscription setup successful, unsubscribe function:', unsubscribe);
29
+ return () => {
30
+ console.log('SubscriptionHandler: Cleaning up subscription');
31
+ if (unsubscribe && typeof unsubscribe === 'function') {
32
+ try {
33
+ unsubscribe();
34
+ } catch (error) {
35
+ console.error('Error unsubscribing:', error);
36
+ }
37
+ }
38
+ };
39
+ }, [subscribeToMore, document, variables, updateQuery, onError, enabled]);
40
+ return null;
41
+ }export{SubscriptionHandler};//# sourceMappingURL=SubscriptionHandler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SubscriptionHandler.js","sources":["../../../src/components/InboxMessage/SubscriptionHandler.tsx"],"sourcesContent":[null],"names":[],"mappings":"8BAEA;;;;;;;;;AASG;SACa,mBAAmB,CAAC;iBAenB;AACT,EAAA,QAAA;;AAEA,EAAA,WAAA;SAEA;YACI;;YAEA,MAAA;gBACA,EAAA;AACH,IAAA,OAAE,CAAA,GAAA,CAAA,8DAAA,EAAA,SAAA,CAAA;AAEH,IAAA,MAAA;AAEA,MAAA,QAAA;AACI,MAAA,SAAA;AACA,MAAA;AACI,MAAA;AACI,KAAA,CAAA;gBACJ,2EAAC,EAAA,WAAA,CAAA;iBAAC;AACE,MAAA,OAAA,CAAA,GAAA,CAAA,+CAA6C,CAAA;qBAChD,IAAA,OAAA,WAAA,KAAA,UAAA,EAAA;YACL;AACJ,UAAE,WAAA,EAAA;AACN,QAAI,CAAA,CAAA,OAAA,KAAA,EAAe;AAEnB,UAAA,OAAY,CAAA,KAAA,CAAA,sBAAA,EAAA,KAAA,CAAA;AAChB,QAAC;;;;;"}
@@ -0,0 +1,11 @@
1
+ import React from 'react';
2
+ /**
3
+ * Animated typing indicator — three bouncing dots, similar to iMessage / Slack.
4
+ */
5
+ export declare const TypingIndicator: React.FC<{
6
+ authorName?: string;
7
+ /** Extra CSS classes on container */
8
+ className?: string;
9
+ }>;
10
+ export default TypingIndicator;
11
+ //# sourceMappingURL=TypingIndicator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TypingIndicator.d.ts","sourceRoot":"","sources":["../../../src/components/InboxMessage/TypingIndicator.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B;;GAEG;AACH,eAAO,MAAM,eAAe,EAAE,KAAK,CAAC,EAAE,CAAC;IACnC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,qCAAqC;IACrC,SAAS,CAAC,EAAE,MAAM,CAAC;CACtB,CA0BA,CAAC;AAEF,eAAe,eAAe,CAAC"}
@@ -0,0 +1,7 @@
1
+ import React, { ChangeEventHandler } from 'react';
2
+ export interface IUploadImageButtonProps {
3
+ onChange: ChangeEventHandler<HTMLInputElement>;
4
+ children?: React.ReactNode;
5
+ }
6
+ export declare const UploadImageButton: (props: IUploadImageButtonProps) => React.JSX.Element;
7
+ //# sourceMappingURL=UploadImageButton.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UploadImageButton.d.ts","sourceRoot":"","sources":["../../../src/components/InboxMessage/UploadImageButton.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,kBAAkB,EAAuB,MAAM,OAAO,CAAC;AAIvE,MAAM,WAAW,uBAAuB;IACpC,QAAQ,EAAE,kBAAkB,CAAC,gBAAgB,CAAC,CAAC;IAC/C,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CAC9B;AAED,eAAO,MAAM,iBAAiB,GAAI,OAAO,uBAAuB,sBAoC/D,CAAC"}
@@ -0,0 +1,30 @@
1
+ import React__default,{useRef,useCallback}from'react';import {useTranslation}from'react-i18next';import {BiImage}from'@react-icons/all-files/bi/BiImage.js';const UploadImageButton = props => {
2
+ const fileInput = useRef();
3
+ const {
4
+ t
5
+ } = useTranslation('translations');
6
+ const selectFile = useCallback(() => {
7
+ if (fileInput?.current) {
8
+ fileInput?.current?.click();
9
+ }
10
+ }, [fileInput]);
11
+ return React__default.createElement("div", {
12
+ className: "relative group"
13
+ }, React__default.createElement("input", {
14
+ multiple: true,
15
+ accept: "image/apng, image/avif, image/gif, image/jpeg, image/png, image/svg+xml, image/webp",
16
+ type: "file",
17
+ style: {
18
+ display: 'none'
19
+ },
20
+ ref: fileInput,
21
+ onChange: props.onChange
22
+ }), React__default.createElement("button", {
23
+ type: "button",
24
+ className: "flex items-center justify-center w-8 h-8 bg-transparent hover:bg-gray-100 rounded-md focus:outline-none focus:ring-opacity-50 transition-all duration-200 ease-in-out",
25
+ onClick: selectFile,
26
+ "aria-label": t('tailwind_ui_inbox.upload_image')
27
+ }, props.children || React__default.createElement(BiImage, {
28
+ className: "w-5 h-5 text-gray-500 hover:text-gray-700"
29
+ })));
30
+ };export{UploadImageButton};//# sourceMappingURL=UploadImageButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UploadImageButton.js","sources":["../../../src/components/InboxMessage/UploadImageButton.tsx"],"sourcesContent":[null],"names":["React"],"mappings":"4JASO,MAAM,iBAAiB,GAAG,KAAC,IAAgC;AAC9D,EAAA,MAAA,SAAM,GAAS,MAAG,EAAM;QACxB;AAEA,IAAA;AACI,GAAA,GAAA,cAAI,CAAS,cAAY,CAAA;AACrB,EAAA,MAAA,UAAA,GAAS,WAAW,CAAA,MAAO;QAC/B,SAAC,EAAA,OAAA,EAAA;AACL,MAAC,SAAG,EAAS,OAAG,EAAA,KAAA,EAAA;AAEhB,IAAA;AAEQ,EAAA,CAAA,EAAA,CAAA,SAAA,CAAA,CAAA;AAcA,EAAA,OAAAA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AAUZ,IAAE,SAAA,EAAA;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,3 @@
1
+ import React from 'react';
2
+ export declare const UserModalContent: ({ username, imageUrl }: any) => React.JSX.Element;
3
+ //# sourceMappingURL=UserModalContent.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UserModalContent.d.ts","sourceRoot":"","sources":["../../../src/components/InboxMessage/UserModalContent.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAM1B,eAAO,MAAM,gBAAgB,GAAI,wBAAwB,GAAG,sBAqD3D,CAAC"}
@@ -0,0 +1,60 @@
1
+ import React__default from'react';import {useTranslation}from'react-i18next';import {AiOutlineSecurityScan}from'@react-icons/all-files/ai/AiOutlineSecurityScan.js';import {FiCheck}from'@react-icons/all-files/fi/FiCheck.js';import {BsFillStarFill}from'@react-icons/all-files/bs/BsFillStarFill.js';const UserModalContent = ({
2
+ username,
3
+ imageUrl
4
+ }) => {
5
+ const {
6
+ t
7
+ } = useTranslation('translations');
8
+ return React__default.createElement("div", null, React__default.createElement("div", null, React__default.createElement("img", {
9
+ src: imageUrl !== '' ? imageUrl : '',
10
+ alt: "User avatar",
11
+ className: "w-50 h-50 rounded-full bg-gray-400 object-cover",
12
+ style: {
13
+ width: '200px',
14
+ height: '200px'
15
+ }
16
+ }), React__default.createElement("a", {
17
+ href: "#",
18
+ className: "text-blue-600 hover:text-blue-800 underline"
19
+ }, t('tailwind_ui_inbox.update_photo')), React__default.createElement(AiOutlineSecurityScan, {
20
+ className: "w-6 h-6 text-black"
21
+ }), React__default.createElement("div", null, React__default.createElement("span", {
22
+ className: "text-black font-medium"
23
+ }, t('tailwind_ui_inbox.identity_verification')), React__default.createElement("p", {
24
+ className: "text-black"
25
+ }, t('tailwind_ui_inbox.show_others_you_are_really_you')), React__default.createElement("button", {
26
+ className: "get-badge-btn text-black bg-transparent border border-gray-300 px-4 py-2 rounded hover:bg-gray-50 transition-colors"
27
+ }, t('tailwind_ui_inbox.get_the_badge'))), React__default.createElement("div", null, React__default.createElement("span", {
28
+ className: "text-black font-medium"
29
+ }, t('tailwind_ui_inbox.username_confirmed', {
30
+ username: username
31
+ })), React__default.createElement("div", {
32
+ className: "flex items-center gap-2"
33
+ }, React__default.createElement(FiCheck, {
34
+ className: "text-black"
35
+ }), React__default.createElement("p", {
36
+ className: "text-black"
37
+ }, t('tailwind_ui_inbox.email_address'))))), React__default.createElement("div", null, React__default.createElement("div", {
38
+ className: "flex flex-col gap-2"
39
+ }, React__default.createElement("span", {
40
+ className: "text-black font-medium"
41
+ }, t('tailwind_ui_inbox.hi_im_username', {
42
+ username: username
43
+ })), React__default.createElement("p", {
44
+ className: "text-gray-600"
45
+ }, t('tailwind_ui_inbox.joined_in_date', {
46
+ date: '2021'
47
+ })), React__default.createElement("a", {
48
+ href: "#",
49
+ className: "text-blue-600 hover:text-blue-800 underline"
50
+ }, t('tailwind_ui_inbox.edit_profile')), React__default.createElement("div", {
51
+ className: "flex items-center gap-1"
52
+ }, React__default.createElement(BsFillStarFill, {
53
+ className: "text-black text-base"
54
+ }), React__default.createElement("span", {
55
+ className: "text-black"
56
+ }, t('tailwind_ui_inbox.reviews')))), React__default.createElement("a", {
57
+ href: "",
58
+ className: "text-blue-600 hover:text-blue-800 underline"
59
+ }, t('tailwind_ui_inbox.reviews_by_you'))));
60
+ };export{UserModalContent};//# sourceMappingURL=UserModalContent.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UserModalContent.js","sources":["../../../src/components/InboxMessage/UserModalContent.tsx"],"sourcesContent":[null],"names":["React"],"mappings":"wSAMO,MAAM,gBAAgB,GAAG,CAAC;UACvB;AAEN,EAAA;AAEQ,CAAA,KAAA;AACI,EAAA,MAAA;AAMA,IAAA;AAGA,GAAA,GAAA,cAAA,CAAA,cAAC,CAAA;AACD,EAAA,OAAAA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA,IAAA,EAAAA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA,IAAA,EAAAA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;iBACI,KAAA,EAAA,GAAA,QAAA,GAAA,EAAA;sBACA;gEACkB;AAItB,IAAA,KAAA,EAAA;AACI,MAAA,KAAA,EAAA,OAAA;;AAII;kCACA,CAAA,GAAA,EAAA;AAIZ,IAAA,IAAA,EAAA,GAAA;aACI,EAAA;AACI,GAAA,EAAA,CAAA,CAAA,gCAAA,CAAA,CAAA,EAAAA,cAAM,CAAA,aAAU,CAAA,qBAAwB,EAClC;AAEN,IAAA,SAAA,EAAA;AACA,GAAA,CAAA,EAAAA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA,IAAA,EAAAA,cAAG,CAAA,aAAS,CAAA,MAAU,EAAA;;AAIlB,GAAA,EAAA,CAAA,CAAA,yCAAC,CAAA,CAAA,EAAAA,cAAc,CAAC;;AAIxB,GAAA,EAAA,CAAA,CAAA,kDAAW,CAAS,GAACA,cAAA,CAAA,aAAA,CAAA,QAAA,EAAA;AAMrC,IAAE,SAAA,EAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}