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

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 (373) hide show
  1. package/CHANGELOG.md +104 -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 +21 -0
  7. package/lib/components/AIAgent/AIAgent.d.ts.map +1 -0
  8. package/lib/components/AIAgent/AIAgent.js +904 -0
  9. package/lib/components/AIAgent/AIAgent.js.map +1 -0
  10. package/lib/components/AIAgent/index.d.ts +2 -0
  11. package/lib/components/AIAgent/index.d.ts.map +1 -0
  12. package/lib/components/InboxMessage/CommonMessage.d.ts +8 -0
  13. package/lib/components/InboxMessage/CommonMessage.d.ts.map +1 -0
  14. package/lib/components/InboxMessage/CommonMessage.js +35 -0
  15. package/lib/components/InboxMessage/CommonMessage.js.map +1 -0
  16. package/lib/components/InboxMessage/ConversationItem.d.ts +14 -0
  17. package/lib/components/InboxMessage/ConversationItem.d.ts.map +1 -0
  18. package/lib/components/InboxMessage/ConversationItem.js +200 -0
  19. package/lib/components/InboxMessage/ConversationItem.js.map +1 -0
  20. package/lib/components/InboxMessage/InputComponent.d.ts +12 -0
  21. package/lib/components/InboxMessage/InputComponent.d.ts.map +1 -0
  22. package/lib/components/InboxMessage/InputComponent.js +359 -0
  23. package/lib/components/InboxMessage/InputComponent.js.map +1 -0
  24. package/lib/components/InboxMessage/LeftSidebar.d.ts +20 -0
  25. package/lib/components/InboxMessage/LeftSidebar.d.ts.map +1 -0
  26. package/lib/components/InboxMessage/LeftSidebar.js +102 -0
  27. package/lib/components/InboxMessage/LeftSidebar.js.map +1 -0
  28. package/lib/components/InboxMessage/MessageInput.d.ts +9 -0
  29. package/lib/components/InboxMessage/MessageInput.d.ts.map +1 -0
  30. package/lib/components/InboxMessage/MessageInput.js +154 -0
  31. package/lib/components/InboxMessage/MessageInput.js.map +1 -0
  32. package/lib/components/InboxMessage/MessageInputComponent.d.ts +9 -0
  33. package/lib/components/InboxMessage/MessageInputComponent.d.ts.map +1 -0
  34. package/lib/components/InboxMessage/Messages.d.ts +17 -0
  35. package/lib/components/InboxMessage/Messages.d.ts.map +1 -0
  36. package/lib/components/InboxMessage/Messages.js +99 -0
  37. package/lib/components/InboxMessage/Messages.js.map +1 -0
  38. package/lib/components/InboxMessage/MessagesBuilderUi.d.ts +17 -0
  39. package/lib/components/InboxMessage/MessagesBuilderUi.d.ts.map +1 -0
  40. package/lib/components/InboxMessage/Popover.d.ts +3 -0
  41. package/lib/components/InboxMessage/Popover.d.ts.map +1 -0
  42. package/lib/components/InboxMessage/Popover.js +31 -0
  43. package/lib/components/InboxMessage/Popover.js.map +1 -0
  44. package/lib/components/InboxMessage/RightSidebar.d.ts +9 -0
  45. package/lib/components/InboxMessage/RightSidebar.d.ts.map +1 -0
  46. package/lib/components/InboxMessage/RightSidebar.js +9 -0
  47. package/lib/components/InboxMessage/RightSidebar.js.map +1 -0
  48. package/lib/components/InboxMessage/RightSidebarAi.d.ts +23 -0
  49. package/lib/components/InboxMessage/RightSidebarAi.d.ts.map +1 -0
  50. package/lib/components/InboxMessage/RightSidebarAi.js +9 -0
  51. package/lib/components/InboxMessage/RightSidebarAi.js.map +1 -0
  52. package/lib/components/InboxMessage/ServiceConversationItem.d.ts +12 -0
  53. package/lib/components/InboxMessage/ServiceConversationItem.d.ts.map +1 -0
  54. package/lib/components/InboxMessage/ServiceConversationItem.js +185 -0
  55. package/lib/components/InboxMessage/ServiceConversationItem.js.map +1 -0
  56. package/lib/components/InboxMessage/ServiceInboxItem.d.ts +12 -0
  57. package/lib/components/InboxMessage/ServiceInboxItem.d.ts.map +1 -0
  58. package/lib/components/InboxMessage/ServiceInboxItem.js +182 -0
  59. package/lib/components/InboxMessage/ServiceInboxItem.js.map +1 -0
  60. package/lib/components/InboxMessage/SubscriptionHandler.d.ts +19 -0
  61. package/lib/components/InboxMessage/SubscriptionHandler.d.ts.map +1 -0
  62. package/lib/components/InboxMessage/SubscriptionHandler.js +41 -0
  63. package/lib/components/InboxMessage/SubscriptionHandler.js.map +1 -0
  64. package/lib/components/InboxMessage/UploadImageButton.d.ts +7 -0
  65. package/lib/components/InboxMessage/UploadImageButton.d.ts.map +1 -0
  66. package/lib/components/InboxMessage/UploadImageButton.js +34 -0
  67. package/lib/components/InboxMessage/UploadImageButton.js.map +1 -0
  68. package/lib/components/InboxMessage/UserModalContent.d.ts +3 -0
  69. package/lib/components/InboxMessage/UserModalContent.d.ts.map +1 -0
  70. package/lib/components/InboxMessage/UserModalContent.js +60 -0
  71. package/lib/components/InboxMessage/UserModalContent.js.map +1 -0
  72. package/lib/components/InboxMessage/index.d.ts +17 -0
  73. package/lib/components/InboxMessage/index.d.ts.map +1 -0
  74. package/lib/components/InboxMessage/message-widgets/CommonMessage.d.ts +11 -0
  75. package/lib/components/InboxMessage/message-widgets/CommonMessage.d.ts.map +1 -0
  76. package/lib/components/InboxMessage/message-widgets/CommonMessage.js +44 -0
  77. package/lib/components/InboxMessage/message-widgets/CommonMessage.js.map +1 -0
  78. package/lib/components/InboxMessage/message-widgets/ErrorFixCard.d.ts +11 -0
  79. package/lib/components/InboxMessage/message-widgets/ErrorFixCard.d.ts.map +1 -0
  80. package/lib/components/InboxMessage/message-widgets/ErrorFixCard.js +194 -0
  81. package/lib/components/InboxMessage/message-widgets/ErrorFixCard.js.map +1 -0
  82. package/lib/components/InboxMessage/message-widgets/MessageCard.d.ts +8 -0
  83. package/lib/components/InboxMessage/message-widgets/MessageCard.d.ts.map +1 -0
  84. package/lib/components/InboxMessage/message-widgets/MessageSliceRenderer.d.ts +12 -0
  85. package/lib/components/InboxMessage/message-widgets/MessageSliceRenderer.d.ts.map +1 -0
  86. package/lib/components/InboxMessage/message-widgets/MessageSliceRenderer.js +37 -0
  87. package/lib/components/InboxMessage/message-widgets/MessageSliceRenderer.js.map +1 -0
  88. package/lib/components/InboxMessage/message-widgets/ModernMessageGroup.d.ts +18 -0
  89. package/lib/components/InboxMessage/message-widgets/ModernMessageGroup.d.ts.map +1 -0
  90. package/lib/components/InboxMessage/message-widgets/ModernMessageGroup.js +1082 -0
  91. package/lib/components/InboxMessage/message-widgets/ModernMessageGroup.js.map +1 -0
  92. package/lib/components/InboxMessage/message-widgets/PlainMessage.d.ts +8 -0
  93. package/lib/components/InboxMessage/message-widgets/PlainMessage.d.ts.map +1 -0
  94. package/lib/components/InboxMessage/message-widgets/PlainMessage.js +14 -0
  95. package/lib/components/InboxMessage/message-widgets/PlainMessage.js.map +1 -0
  96. package/lib/components/InboxMessage/message-widgets/PropertyMessageWidget.d.ts +9 -0
  97. package/lib/components/InboxMessage/message-widgets/PropertyMessageWidget.d.ts.map +1 -0
  98. package/lib/components/InboxMessage/message-widgets/SlackLikeMessageGroup.d.ts +14 -0
  99. package/lib/components/InboxMessage/message-widgets/SlackLikeMessageGroup.d.ts.map +1 -0
  100. package/lib/components/InboxMessage/message-widgets/SlackLikeMessageGroup.js +333 -0
  101. package/lib/components/InboxMessage/message-widgets/SlackLikeMessageGroup.js.map +1 -0
  102. package/lib/components/InboxMessage/message-widgets/index.d.ts +4 -0
  103. package/lib/components/InboxMessage/message-widgets/index.d.ts.map +1 -0
  104. package/lib/components/ModelConfigPanel.d.ts +37 -0
  105. package/lib/components/ModelConfigPanel.d.ts.map +1 -0
  106. package/lib/components/ModelConfigPanel.js +317 -0
  107. package/lib/components/ModelConfigPanel.js.map +1 -0
  108. package/lib/components/filler-components/RightSiderBar.d.ts +24 -0
  109. package/lib/components/filler-components/RightSiderBar.d.ts.map +1 -0
  110. package/lib/components/filler-components/RightSiderBar.js +335 -0
  111. package/lib/components/filler-components/RightSiderBar.js.map +1 -0
  112. package/lib/components/inbox/FilesList.d.ts +20 -0
  113. package/lib/components/inbox/FilesList.d.ts.map +1 -0
  114. package/lib/components/inbox/FilesList.js +68 -0
  115. package/lib/components/inbox/FilesList.js.map +1 -0
  116. package/lib/components/inbox/MessageItem.d.ts +17 -0
  117. package/lib/components/inbox/MessageItem.d.ts.map +1 -0
  118. package/lib/components/inbox/MessageItem.js +50 -0
  119. package/lib/components/inbox/MessageItem.js.map +1 -0
  120. package/lib/components/inbox/ThreadItem.d.ts +11 -0
  121. package/lib/components/inbox/ThreadItem.d.ts.map +1 -0
  122. package/lib/components/inbox/ThreadItem.js +147 -0
  123. package/lib/components/inbox/ThreadItem.js.map +1 -0
  124. package/lib/components/inbox/index.d.ts +4 -0
  125. package/lib/components/inbox/index.d.ts.map +1 -0
  126. package/lib/components/index.d.ts +7 -0
  127. package/lib/components/index.d.ts.map +1 -0
  128. package/lib/components/live-code-editor/hybrid-live-editor.d.ts +20 -0
  129. package/lib/components/live-code-editor/hybrid-live-editor.d.ts.map +1 -0
  130. package/lib/components/live-code-editor/hybrid-live-editor.js +68 -0
  131. package/lib/components/live-code-editor/hybrid-live-editor.js.map +1 -0
  132. package/lib/components/live-code-editor/index.d.ts +4 -0
  133. package/lib/components/live-code-editor/index.d.ts.map +1 -0
  134. package/lib/components/live-code-editor/live-code-editor.d.ts +14 -0
  135. package/lib/components/live-code-editor/live-code-editor.d.ts.map +1 -0
  136. package/lib/components/live-code-editor/live-code-editor.js +207 -0
  137. package/lib/components/live-code-editor/live-code-editor.js.map +1 -0
  138. package/lib/components/slot-fill/chat-message-filler.d.ts +4 -0
  139. package/lib/components/slot-fill/chat-message-filler.d.ts.map +1 -0
  140. package/lib/components/slot-fill/chat-message-filler.js +5 -0
  141. package/lib/components/slot-fill/chat-message-filler.js.map +1 -0
  142. package/lib/components/slot-fill/chat-message-slot.d.ts +11 -0
  143. package/lib/components/slot-fill/chat-message-slot.d.ts.map +1 -0
  144. package/lib/components/slot-fill/chat-message-slot.js +6 -0
  145. package/lib/components/slot-fill/chat-message-slot.js.map +1 -0
  146. package/lib/components/slot-fill/index.d.ts +4 -0
  147. package/lib/components/slot-fill/index.d.ts.map +1 -0
  148. package/lib/components/slot-fill/right-sidebar-filler.d.ts +4 -0
  149. package/lib/components/slot-fill/right-sidebar-filler.d.ts.map +1 -0
  150. package/lib/components/slot-fill/right-sidebar-filler.js +13 -0
  151. package/lib/components/slot-fill/right-sidebar-filler.js.map +1 -0
  152. package/lib/components/ui/button.d.ts +9 -0
  153. package/lib/components/ui/button.d.ts.map +1 -0
  154. package/lib/compute.d.ts +8 -0
  155. package/lib/compute.d.ts.map +1 -0
  156. package/lib/compute.js +137 -0
  157. package/lib/compute.js.map +1 -0
  158. package/lib/config/env-config.d.ts +13 -0
  159. package/lib/config/env-config.d.ts.map +1 -0
  160. package/lib/config/env-config.js +34 -0
  161. package/lib/config/env-config.js.map +1 -0
  162. package/lib/config/index.d.ts +2 -0
  163. package/lib/config/index.d.ts.map +1 -0
  164. package/lib/constants/breakpoints.d.ts +8 -0
  165. package/lib/constants/breakpoints.d.ts.map +1 -0
  166. package/lib/constants/index.d.ts +3 -0
  167. package/lib/constants/index.d.ts.map +1 -0
  168. package/lib/container/AiInbox.d.ts +15 -0
  169. package/lib/container/AiInbox.d.ts.map +1 -0
  170. package/lib/container/AiInboxWithLoader.d.ts +36 -0
  171. package/lib/container/AiInboxWithLoader.d.ts.map +1 -0
  172. package/lib/container/AiLandingInput.d.ts +4 -0
  173. package/lib/container/AiLandingInput.d.ts.map +1 -0
  174. package/lib/container/AiLandingInput.js +101 -0
  175. package/lib/container/AiLandingInput.js.map +1 -0
  176. package/lib/container/Inbox.d.ts +15 -0
  177. package/lib/container/Inbox.d.ts.map +1 -0
  178. package/lib/container/Inbox.js +955 -0
  179. package/lib/container/Inbox.js.map +1 -0
  180. package/lib/container/InboxAiMessagesLoader.d.ts +15 -0
  181. package/lib/container/InboxAiMessagesLoader.d.ts.map +1 -0
  182. package/lib/container/InboxAiMessagesLoader.js +30 -0
  183. package/lib/container/InboxAiMessagesLoader.js.map +1 -0
  184. package/lib/container/InboxContainer.d.ts +12 -0
  185. package/lib/container/InboxContainer.d.ts.map +1 -0
  186. package/lib/container/InboxContainer.js +31 -0
  187. package/lib/container/InboxContainer.js.map +1 -0
  188. package/lib/container/InboxTemplate1.d.ts +15 -0
  189. package/lib/container/InboxTemplate1.d.ts.map +1 -0
  190. package/lib/container/InboxTemplate1WithLoader.d.ts +36 -0
  191. package/lib/container/InboxTemplate1WithLoader.d.ts.map +1 -0
  192. package/lib/container/InboxTemplate2.d.ts +15 -0
  193. package/lib/container/InboxTemplate2.d.ts.map +1 -0
  194. package/lib/container/InboxWithAiLoader.d.ts +15 -0
  195. package/lib/container/InboxWithAiLoader.d.ts.map +1 -0
  196. package/lib/container/InboxWithAiLoader.js +56 -0
  197. package/lib/container/InboxWithAiLoader.js.map +1 -0
  198. package/lib/container/InboxWithLoader.d.ts +36 -0
  199. package/lib/container/InboxWithLoader.d.ts.map +1 -0
  200. package/lib/container/InboxWithLoader.js +277 -0
  201. package/lib/container/InboxWithLoader.js.map +1 -0
  202. package/lib/container/ServiceInbox.d.ts +9 -0
  203. package/lib/container/ServiceInbox.d.ts.map +1 -0
  204. package/lib/container/ServiceInbox.js +144 -0
  205. package/lib/container/ServiceInbox.js.map +1 -0
  206. package/lib/container/ThreadMessages.d.ts +13 -0
  207. package/lib/container/ThreadMessages.d.ts.map +1 -0
  208. package/lib/container/ThreadMessages.js +314 -0
  209. package/lib/container/ThreadMessages.js.map +1 -0
  210. package/lib/container/ThreadMessagesInbox.d.ts +14 -0
  211. package/lib/container/ThreadMessagesInbox.d.ts.map +1 -0
  212. package/lib/container/ThreadMessagesInbox.js +341 -0
  213. package/lib/container/ThreadMessagesInbox.js.map +1 -0
  214. package/lib/container/Threads.d.ts +8 -0
  215. package/lib/container/Threads.d.ts.map +1 -0
  216. package/lib/container/Threads.js +231 -0
  217. package/lib/container/Threads.js.map +1 -0
  218. package/lib/container/ThreadsInbox.d.ts +21 -0
  219. package/lib/container/ThreadsInbox.d.ts.map +1 -0
  220. package/lib/container/ThreadsInbox.js +244 -0
  221. package/lib/container/ThreadsInbox.js.map +1 -0
  222. package/lib/container/apply-footer-styles.d.ts +2 -0
  223. package/lib/container/apply-footer-styles.d.ts.map +1 -0
  224. package/lib/container/apply-footer-styles.js +16 -0
  225. package/lib/container/apply-footer-styles.js.map +1 -0
  226. package/lib/container/index.d.ts +13 -0
  227. package/lib/container/index.d.ts.map +1 -0
  228. package/lib/enums/index.d.ts +2 -0
  229. package/lib/enums/index.d.ts.map +1 -0
  230. package/lib/enums/messenger-slot-fill-name-enum.d.ts +5 -0
  231. package/lib/enums/messenger-slot-fill-name-enum.d.ts.map +1 -0
  232. package/lib/enums/messenger-slot-fill-name-enum.js +5 -0
  233. package/lib/enums/messenger-slot-fill-name-enum.js.map +1 -0
  234. package/lib/hooks/index.d.ts +3 -0
  235. package/lib/hooks/index.d.ts.map +1 -0
  236. package/lib/hooks/use-file-sync.d.ts +16 -0
  237. package/lib/hooks/use-file-sync.d.ts.map +1 -0
  238. package/lib/hooks/use-file-sync.js +63 -0
  239. package/lib/hooks/use-file-sync.js.map +1 -0
  240. package/lib/hooks/usePersistentModelConfig.d.ts +15 -0
  241. package/lib/hooks/usePersistentModelConfig.d.ts.map +1 -0
  242. package/lib/hooks/usePersistentModelConfig.js +46 -0
  243. package/lib/hooks/usePersistentModelConfig.js.map +1 -0
  244. package/lib/index.d.ts +10 -0
  245. package/lib/index.d.ts.map +1 -0
  246. package/lib/index.js +1 -0
  247. package/lib/index.js.map +1 -0
  248. package/lib/interfaces/index.d.ts +2 -0
  249. package/lib/interfaces/index.d.ts.map +1 -0
  250. package/lib/interfaces/message-widgets.interface.d.ts +21 -0
  251. package/lib/interfaces/message-widgets.interface.d.ts.map +1 -0
  252. package/lib/machines/aiAgentMachine.d.ts +3 -0
  253. package/lib/machines/aiAgentMachine.d.ts.map +1 -0
  254. package/lib/machines/aiAgentMachine.js +1083 -0
  255. package/lib/machines/aiAgentMachine.js.map +1 -0
  256. package/lib/machines/aiAgentMachine.simple.d.ts +3 -0
  257. package/lib/machines/aiAgentMachine.simple.d.ts.map +1 -0
  258. package/lib/machines/aiAgentMachine.simple.js +108 -0
  259. package/lib/machines/aiAgentMachine.simple.js.map +1 -0
  260. package/lib/machines/index.d.ts +3 -0
  261. package/lib/machines/index.d.ts.map +1 -0
  262. package/lib/machines/types.d.ts +77 -0
  263. package/lib/machines/types.d.ts.map +1 -0
  264. package/lib/module.d.ts +7 -0
  265. package/lib/module.d.ts.map +1 -0
  266. package/lib/module.js +26 -0
  267. package/lib/module.js.map +1 -0
  268. package/lib/routes.json +98 -0
  269. package/lib/styles/responsive.css +76 -0
  270. package/lib/templates/InboxWithAi.d.ts +15 -0
  271. package/lib/templates/InboxWithAi.d.ts.map +1 -0
  272. package/lib/templates/InboxWithAi.js +440 -0
  273. package/lib/templates/InboxWithAi.js.map +1 -0
  274. package/lib/templates/InboxWithAi.tsx +533 -0
  275. package/lib/templates/index.d.ts +2 -0
  276. package/lib/templates/index.d.ts.map +1 -0
  277. package/lib/templates/index.ts +1 -0
  278. package/lib/utils/utils.d.ts +2 -0
  279. package/lib/utils/utils.d.ts.map +1 -0
  280. package/lib/utils/utils.js +3 -0
  281. package/lib/utils/utils.js.map +1 -0
  282. package/package.json +62 -0
  283. package/rollup.config.mjs +35 -0
  284. package/src/cdm-locales/en/translations.json +31 -0
  285. package/src/cdm-locales/es/translations.json +31 -0
  286. package/src/components/AIAgent/AIAgent.tsx +1103 -0
  287. package/src/components/AIAgent/AIAgent.tsx.bk +1365 -0
  288. package/src/components/AIAgent/README.md +82 -0
  289. package/src/components/AIAgent/index.ts +1 -0
  290. package/src/components/InboxMessage/CommonMessage.tsx +40 -0
  291. package/src/components/InboxMessage/ConversationItem.tsx +255 -0
  292. package/src/components/InboxMessage/InputComponent.tsx +462 -0
  293. package/src/components/InboxMessage/LeftSidebar.tsx +140 -0
  294. package/src/components/InboxMessage/MessageInput.tsx +209 -0
  295. package/src/components/InboxMessage/MessageInputComponent.tsx +245 -0
  296. package/src/components/InboxMessage/Messages.tsx +137 -0
  297. package/src/components/InboxMessage/MessagesBuilderUi.tsx +205 -0
  298. package/src/components/InboxMessage/Popover.tsx +42 -0
  299. package/src/components/InboxMessage/RightSidebar.tsx +22 -0
  300. package/src/components/InboxMessage/RightSidebarAi.tsx +37 -0
  301. package/src/components/InboxMessage/ServiceConversationItem.tsx +234 -0
  302. package/src/components/InboxMessage/ServiceInboxItem.tsx +223 -0
  303. package/src/components/InboxMessage/SubscriptionHandler.tsx +55 -0
  304. package/src/components/InboxMessage/UploadImageButton.tsx +46 -0
  305. package/src/components/InboxMessage/UserModalContent.tsx +60 -0
  306. package/src/components/InboxMessage/index.ts +16 -0
  307. package/src/components/InboxMessage/message-widgets/CommonMessage.tsx +69 -0
  308. package/src/components/InboxMessage/message-widgets/ErrorFixCard.tsx +240 -0
  309. package/src/components/InboxMessage/message-widgets/MessageCard.tsx +127 -0
  310. package/src/components/InboxMessage/message-widgets/MessageSliceRenderer.tsx +40 -0
  311. package/src/components/InboxMessage/message-widgets/ModernMessageGroup.tsx +1295 -0
  312. package/src/components/InboxMessage/message-widgets/PlainMessage.tsx +18 -0
  313. package/src/components/InboxMessage/message-widgets/PropertyMessageWidget.tsx +29 -0
  314. package/src/components/InboxMessage/message-widgets/SlackLikeMessageGroup.tsx +492 -0
  315. package/src/components/InboxMessage/message-widgets/index.ts +3 -0
  316. package/src/components/ModelConfigPanel.tsx +345 -0
  317. package/src/components/filler-components/RightSiderBar.tsx +408 -0
  318. package/src/components/inbox/FilesList.tsx +89 -0
  319. package/src/components/inbox/MessageItem.tsx +50 -0
  320. package/src/components/inbox/ThreadItem.tsx +295 -0
  321. package/src/components/inbox/index.ts +3 -0
  322. package/src/components/index.ts +22 -0
  323. package/src/components/live-code-editor/hybrid-live-editor.tsx +105 -0
  324. package/src/components/live-code-editor/index.ts +3 -0
  325. package/src/components/live-code-editor/live-code-editor.tsx +257 -0
  326. package/src/components/slot-fill/chat-message-filler.tsx +18 -0
  327. package/src/components/slot-fill/chat-message-slot.tsx +18 -0
  328. package/src/components/slot-fill/index.ts +3 -0
  329. package/src/components/slot-fill/right-sidebar-filler.tsx +39 -0
  330. package/src/components/ui/button.tsx +32 -0
  331. package/src/compute.ts +134 -0
  332. package/src/config/env-config.ts +17 -0
  333. package/src/config/index.ts +1 -0
  334. package/src/constants/breakpoints.ts +7 -0
  335. package/src/constants/index.ts +5 -0
  336. package/src/container/AiInbox.tsx +1819 -0
  337. package/src/container/AiInboxWithLoader.tsx +356 -0
  338. package/src/container/AiLandingInput.tsx +221 -0
  339. package/src/container/Inbox.tsx +1092 -0
  340. package/src/container/InboxAiMessagesLoader.tsx +44 -0
  341. package/src/container/InboxContainer.tsx +35 -0
  342. package/src/container/InboxTemplate1.tsx +1542 -0
  343. package/src/container/InboxTemplate1WithLoader.tsx +338 -0
  344. package/src/container/InboxTemplate2.tsx +1606 -0
  345. package/src/container/InboxWithAiLoader.tsx +76 -0
  346. package/src/container/InboxWithLoader.tsx +341 -0
  347. package/src/container/ServiceInbox.tsx +190 -0
  348. package/src/container/ThreadMessages.tsx +371 -0
  349. package/src/container/ThreadMessagesInbox.tsx +450 -0
  350. package/src/container/Threads.tsx +270 -0
  351. package/src/container/ThreadsInbox.tsx +354 -0
  352. package/src/container/apply-footer-styles.ts +17 -0
  353. package/src/container/index.ts +31 -0
  354. package/src/enums/index.ts +1 -0
  355. package/src/enums/messenger-slot-fill-name-enum.ts +4 -0
  356. package/src/hooks/index.ts +2 -0
  357. package/src/hooks/use-file-sync.ts +91 -0
  358. package/src/hooks/usePersistentModelConfig.ts +63 -0
  359. package/src/index.ts +37 -0
  360. package/src/interfaces/index.ts +1 -0
  361. package/src/interfaces/message-widgets.interface.ts +21 -0
  362. package/src/machines/aiAgentMachine.simple.ts +89 -0
  363. package/src/machines/aiAgentMachine.ts +1296 -0
  364. package/src/machines/aiAgentMachine.ts.bk +1296 -0
  365. package/src/machines/index.ts +2 -0
  366. package/src/machines/types.ts +59 -0
  367. package/src/module.tsx +32 -0
  368. package/src/styles/responsive.css +76 -0
  369. package/src/templates/InboxWithAi.tsx +533 -0
  370. package/src/templates/index.ts +1 -0
  371. package/src/utils/utils.ts +3 -0
  372. package/tsconfig.json +14 -0
  373. package/webpack.config.js +92 -0
@@ -0,0 +1,359 @@
1
+ import React__default,{useState,useRef,useEffect,useCallback,useMemo}from'react';import {useTranslation}from'react-i18next';import {config}from'../../config/env-config.js';import {UploadImageButton}from'./UploadImageButton.js';import {FilesList}from'../inbox/FilesList.js';import'../inbox/MessageItem.js';import'../inbox/ThreadItem.js';import {getAllModels,templateOptions}from'../ModelConfigPanel.js';const InputComponent = ({
2
+ handleSend: handleSendProp,
3
+ placeholder,
4
+ modelConfig,
5
+ onModelConfigChange
6
+ }) => {
7
+ const [message, setMessage] = useState('');
8
+ const [sending, setSending] = useState(false);
9
+ const [files, setFiles] = useState([]);
10
+ const [showToast, setShowToast] = useState(false);
11
+ const [toastMessage, setToastMessage] = useState('');
12
+ const [isFocused, setIsFocused] = useState(false);
13
+ const [showModelDropdown, setShowModelDropdown] = useState(false);
14
+ const [showTemplateDropdown, setShowTemplateDropdown] = useState(false);
15
+ const [showSettingsModal, setShowSettingsModal] = useState(false);
16
+ const textareaRef = useRef(null);
17
+ const modelDropdownRef = useRef(null);
18
+ const templateDropdownRef = useRef(null);
19
+ const {
20
+ t
21
+ } = useTranslation('translations');
22
+ // Auto-focus the textarea when component mounts
23
+ useEffect(() => {
24
+ if (textareaRef.current) {
25
+ textareaRef.current.focus();
26
+ }
27
+ }, []);
28
+ // Handle click outside for dropdowns
29
+ useEffect(() => {
30
+ const handleClickOutside = event => {
31
+ if (modelDropdownRef.current && !modelDropdownRef.current.contains(event.target)) {
32
+ setShowModelDropdown(false);
33
+ }
34
+ if (templateDropdownRef.current && !templateDropdownRef.current.contains(event.target)) {
35
+ setShowTemplateDropdown(false);
36
+ }
37
+ };
38
+ document.addEventListener('mousedown', handleClickOutside);
39
+ return () => document.removeEventListener('mousedown', handleClickOutside);
40
+ }, []);
41
+ const showToastMessage = useCallback(message => {
42
+ setToastMessage(message);
43
+ setShowToast(true);
44
+ setTimeout(() => setShowToast(false), 3000);
45
+ }, []);
46
+ const handleSend = useCallback(() => {
47
+ if (!message.trim() && files.length === 0) return;
48
+ setSending(true);
49
+ handleSendProp(message, files).then(() => {
50
+ setMessage('');
51
+ setFiles([]);
52
+ // Auto-focus the textarea after sending a message
53
+ setTimeout(() => {
54
+ if (textareaRef.current) {
55
+ textareaRef.current.focus();
56
+ }
57
+ }, 100);
58
+ }).finally(() => setSending(false));
59
+ }, [files, handleSendProp, message]);
60
+ const handleKeyDown = useCallback(e => {
61
+ const keyCode = e.which || e.keyCode;
62
+ if (keyCode == 13 && !e.shiftKey) {
63
+ e.preventDefault();
64
+ handleSend();
65
+ }
66
+ }, [handleSend]);
67
+ const inputHeight = useMemo(() => {
68
+ const lines = message.split('\n').length;
69
+ return Math.max(120, Math.min(200, 120 + (lines - 1) * 20));
70
+ }, [message]);
71
+ const onUploadImageChange = useCallback(({
72
+ target
73
+ }) => {
74
+ let fileList = [];
75
+ let index = 0;
76
+ if (files.length + target.files.length > config.FILES_PER_MESSAGE) {
77
+ showToastMessage(t('tailwind_ui_inbox.you_can_not_upload_more_than_files', {
78
+ files_per_message: config.FILES_PER_MESSAGE
79
+ }));
80
+ return;
81
+ }
82
+ while (target.files[index]) {
83
+ fileList.push(target.files[index]);
84
+ index += 1;
85
+ }
86
+ setFiles(oldFiles => [...oldFiles, ...fileList]);
87
+ }, [setFiles, files, showToastMessage, t]);
88
+ const canSend = message.trim() || files.length > 0;
89
+ message.trim().length > 0;
90
+ // Get models and templates from ModelConfigPanel
91
+ const allModelOptions = useMemo(() => {
92
+ return getAllModels();
93
+ }, []);
94
+ const templateOptionsList = useMemo(() => {
95
+ return templateOptions.map(t => ({
96
+ value: t.value,
97
+ label: t.label,
98
+ icon: t.icon
99
+ }));
100
+ }, []);
101
+ const handleModelSelect = useCallback(modelValue => {
102
+ if (onModelConfigChange && modelConfig) {
103
+ onModelConfigChange({
104
+ ...modelConfig,
105
+ model: modelValue
106
+ });
107
+ }
108
+ setShowModelDropdown(false);
109
+ }, [modelConfig, onModelConfigChange]);
110
+ const handleTemplateSelect = useCallback(templateValue => {
111
+ if (onModelConfigChange && modelConfig) {
112
+ onModelConfigChange({
113
+ ...modelConfig,
114
+ template: templateValue
115
+ });
116
+ }
117
+ setShowTemplateDropdown(false);
118
+ }, [modelConfig, onModelConfigChange]);
119
+ return (
120
+ // <div className="bg-gray-50 border-t border-gray-200">
121
+ React__default.createElement("div", {
122
+ className: "bg-gray-50 border border-gray-200"
123
+ }, showToast && React__default.createElement("div", {
124
+ className: "fixed top-4 right-4 z-50 bg-orange-50 border border-orange-200 text-orange-800 px-4 py-3 rounded-lg shadow-lg animate-bounce"
125
+ }, React__default.createElement("div", {
126
+ className: "flex items-center"
127
+ }, React__default.createElement("svg", {
128
+ className: "w-5 h-5 mr-2",
129
+ fill: "currentColor",
130
+ viewBox: "0 0 20 20"
131
+ }, React__default.createElement("path", {
132
+ fillRule: "evenodd",
133
+ d: "M8.257 3.099c.765-1.36 2.722-1.36 3.486 0l5.58 9.92c.75 1.334-.213 2.98-1.742 2.98H4.42c-1.53 0-2.493-1.646-1.743-2.98l5.58-9.92zM11 13a1 1 0 11-2 0 1 1 0 012 0zm-1-8a1 1 0 00-1 1v3a1 1 0 002 0V6a1 1 0 00-1-1z",
134
+ clipRule: "evenodd"
135
+ })), toastMessage)), files?.length > 0 && !sending && React__default.createElement("div", {
136
+ className: "px-4 py-3 border-b border-gray-200"
137
+ }, React__default.createElement(FilesList, {
138
+ files: files
139
+ })), React__default.createElement("div", {
140
+ className: "px-4 py-3"
141
+ }, React__default.createElement("div", {
142
+ className: "relative mb-3"
143
+ }, React__default.createElement("textarea", {
144
+ ref: textareaRef,
145
+ className: `w-full text-base bg-white border-2 rounded-2xl pl-4 pr-4 py-3 resize-none focus:outline-none placeholder-gray-500 transition-all duration-200 ${isFocused ? 'border-blue-500 ring-2 ring-blue-200' : 'border-gray-300'}`,
146
+ style: {
147
+ height: `${inputHeight}px`,
148
+ minHeight: '120px',
149
+ maxHeight: '200px'
150
+ },
151
+ placeholder: placeholder || 'Message',
152
+ value: sending ? '' : message,
153
+ onKeyDown: handleKeyDown,
154
+ onChange: e => setMessage(e.target.value),
155
+ onFocus: () => setIsFocused(true),
156
+ onBlur: () => setIsFocused(false),
157
+ disabled: sending,
158
+ rows: 1
159
+ })), React__default.createElement("div", {
160
+ className: "flex items-center gap-2"
161
+ }, React__default.createElement(UploadImageButton, {
162
+ onChange: onUploadImageChange
163
+ }, React__default.createElement("div", {
164
+ className: "flex items-center justify-center w-8 h-8 rounded-lg border border-gray-300 bg-white hover:bg-gray-50 transition-colors"
165
+ }, React__default.createElement("svg", {
166
+ className: "w-4 h-4 text-gray-600",
167
+ fill: "none",
168
+ stroke: "currentColor",
169
+ viewBox: "0 0 24 24"
170
+ }, React__default.createElement("path", {
171
+ strokeLinecap: "round",
172
+ strokeLinejoin: "round",
173
+ strokeWidth: 2,
174
+ d: "M12 4v16m8-8H4"
175
+ })))), React__default.createElement("div", {
176
+ className: "relative",
177
+ ref: templateDropdownRef
178
+ }, React__default.createElement("button", {
179
+ onClick: () => setShowTemplateDropdown(!showTemplateDropdown),
180
+ className: "flex items-center gap-2 px-3 py-1.5 text-sm rounded-lg border border-gray-300 bg-white hover:bg-gray-50 transition-colors min-w-[120px]"
181
+ }, (() => {
182
+ if (modelConfig && modelConfig.template) {
183
+ const currentTemplate = templateOptionsList.find(option => option.value === modelConfig.template);
184
+ return currentTemplate ? React__default.createElement(React__default.Fragment, null, React__default.createElement("span", {
185
+ className: "text-lg"
186
+ }, currentTemplate.icon), React__default.createElement("span", {
187
+ className: "text-gray-700"
188
+ }, currentTemplate.label)) : React__default.createElement(React__default.Fragment, null, React__default.createElement("span", {
189
+ className: "text-lg"
190
+ }, "\uD83D\uDCDD"), React__default.createElement("span", {
191
+ className: "text-gray-500"
192
+ }, "Template"));
193
+ }
194
+ return React__default.createElement(React__default.Fragment, null, React__default.createElement("span", {
195
+ className: "text-lg"
196
+ }, "\uD83D\uDCDD"), React__default.createElement("span", {
197
+ className: "text-gray-500"
198
+ }, "Template"));
199
+ })(), React__default.createElement("svg", {
200
+ className: "w-4 h-4 text-gray-500 ml-auto",
201
+ fill: "none",
202
+ stroke: "currentColor",
203
+ viewBox: "0 0 24 24"
204
+ }, React__default.createElement("path", {
205
+ strokeLinecap: "round",
206
+ strokeLinejoin: "round",
207
+ strokeWidth: 2,
208
+ d: "M19 9l-7 7-7-7"
209
+ }))), showTemplateDropdown && React__default.createElement("div", {
210
+ className: "absolute bottom-full left-0 mb-2 w-48 bg-white border border-gray-200 rounded-lg shadow-lg z-50"
211
+ }, React__default.createElement("div", {
212
+ className: "py-1"
213
+ }, templateOptionsList.map(option => React__default.createElement("button", {
214
+ key: option.value,
215
+ onClick: () => handleTemplateSelect(option.value),
216
+ className: `w-full px-3 py-2 text-left hover:bg-gray-50 transition-colors flex items-center gap-2 ${modelConfig?.template === option.value ? 'bg-blue-50' : ''}`
217
+ }, React__default.createElement("span", {
218
+ className: "text-lg"
219
+ }, option.icon), React__default.createElement("span", {
220
+ className: "font-medium text-gray-900"
221
+ }, option.label)))))), React__default.createElement("div", {
222
+ className: "relative",
223
+ ref: modelDropdownRef
224
+ }, React__default.createElement("button", {
225
+ onClick: () => setShowModelDropdown(!showModelDropdown),
226
+ className: "flex items-center gap-2 px-3 py-1.5 text-sm rounded-lg border border-gray-300 bg-white hover:bg-gray-50 transition-colors min-w-[140px]"
227
+ }, (() => {
228
+ if (modelConfig && modelConfig.model) {
229
+ const currentModel = allModelOptions.find(option => option.value === modelConfig.model);
230
+ return currentModel ? React__default.createElement("span", {
231
+ className: "text-gray-700"
232
+ }, currentModel.label) : React__default.createElement("span", {
233
+ className: "text-gray-500"
234
+ }, "Model");
235
+ }
236
+ return React__default.createElement("span", {
237
+ className: "text-gray-500"
238
+ }, "Model");
239
+ })(), React__default.createElement("svg", {
240
+ className: "w-4 h-4 text-gray-500 ml-auto",
241
+ fill: "none",
242
+ stroke: "currentColor",
243
+ viewBox: "0 0 24 24"
244
+ }, React__default.createElement("path", {
245
+ strokeLinecap: "round",
246
+ strokeLinejoin: "round",
247
+ strokeWidth: 2,
248
+ d: "M19 9l-7 7-7-7"
249
+ }))), showModelDropdown && React__default.createElement("div", {
250
+ className: "absolute bottom-full left-0 mb-2 w-64 bg-white border border-gray-200 rounded-lg shadow-lg z-50 max-h-60 overflow-y-auto"
251
+ }, React__default.createElement("div", {
252
+ className: "py-1"
253
+ }, allModelOptions.map(option => React__default.createElement("button", {
254
+ key: option.value,
255
+ onClick: () => handleModelSelect(option.value),
256
+ className: `w-full px-3 py-2 text-left hover:bg-gray-50 transition-colors ${modelConfig?.model === option.value ? 'bg-blue-50' : ''}`
257
+ }, React__default.createElement("div", {
258
+ className: "font-medium text-gray-900"
259
+ }, option.label)))))), React__default.createElement("div", {
260
+ className: "flex-1"
261
+ }), React__default.createElement("button", {
262
+ onClick: () => setShowSettingsModal(true),
263
+ className: "flex items-center justify-center w-8 h-8 rounded-lg border border-gray-300 bg-white hover:bg-gray-50 transition-colors"
264
+ }, React__default.createElement("svg", {
265
+ className: "w-4 h-4 text-gray-600",
266
+ fill: "none",
267
+ stroke: "currentColor",
268
+ viewBox: "0 0 24 24"
269
+ }, React__default.createElement("path", {
270
+ strokeLinecap: "round",
271
+ strokeLinejoin: "round",
272
+ strokeWidth: 2,
273
+ d: "M10.325 4.317c.426-1.756 2.924-1.756 3.35 0a1.724 1.724 0 002.573 1.066c1.543-.94 3.31.826 2.37 2.37a1.724 1.724 0 001.065 2.572c1.756.426 1.756 2.924 0 3.35a1.724 1.724 0 00-1.066 2.573c.94 1.543-.826 3.31-2.37 2.37a1.724 1.724 0 00-2.572 1.065c-.426 1.756-2.924 1.756-3.35 0a1.724 1.724 0 00-2.573-1.066c-1.543.94-3.31-.826-2.37-2.37a1.724 1.724 0 00-1.065-2.572c-1.756-.426-1.756-2.924 0-3.35a1.724 1.724 0 001.066-2.573c-.94-1.543.826-3.31 2.37-2.37.996.608 2.296.07 2.572-1.065z"
274
+ }), React__default.createElement("path", {
275
+ strokeLinecap: "round",
276
+ strokeLinejoin: "round",
277
+ strokeWidth: 2,
278
+ d: "M15 12a3 3 0 11-6 0 3 3 0 016 0z"
279
+ }))), React__default.createElement("button", {
280
+ className: `flex items-center justify-center w-8 h-8 rounded-lg border transition-colors ${canSend && !sending ? 'border-blue-500 bg-blue-500 hover:bg-blue-600 text-white' : 'border-gray-300 bg-gray-100 text-gray-400 cursor-not-allowed'}`,
281
+ onClick: handleSend,
282
+ disabled: !canSend || sending,
283
+ type: "button"
284
+ }, sending ? React__default.createElement("svg", {
285
+ className: "w-4 h-4 animate-spin",
286
+ fill: "none",
287
+ viewBox: "0 0 24 24"
288
+ }, React__default.createElement("circle", {
289
+ className: "opacity-25",
290
+ cx: "12",
291
+ cy: "12",
292
+ r: "10",
293
+ stroke: "currentColor",
294
+ strokeWidth: "4"
295
+ }), React__default.createElement("path", {
296
+ className: "opacity-75",
297
+ fill: "currentColor",
298
+ d: "M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"
299
+ })) : React__default.createElement("svg", {
300
+ className: "w-4 h-4",
301
+ fill: "none",
302
+ stroke: "currentColor",
303
+ viewBox: "0 0 24 24"
304
+ }, React__default.createElement("path", {
305
+ strokeLinecap: "round",
306
+ strokeLinejoin: "round",
307
+ strokeWidth: 2,
308
+ d: "M12 19l9 2-9-18-9 18 9-2zm0 0v-8"
309
+ }))))), showSettingsModal && React__default.createElement("div", {
310
+ className: "fixed inset-0 z-50 flex items-center justify-center bg-black bg-opacity-50"
311
+ }, React__default.createElement("div", {
312
+ className: "bg-white rounded-lg shadow-xl max-w-md w-full mx-4"
313
+ }, React__default.createElement("div", {
314
+ className: "p-6 mb-4"
315
+ }, React__default.createElement("div", {
316
+ className: "flex items-center justify-between mb-4"
317
+ }, React__default.createElement("h3", {
318
+ className: "text-lg font-semibold text-gray-900"
319
+ }, "Project Settings"), React__default.createElement("button", {
320
+ onClick: () => setShowSettingsModal(false),
321
+ className: "text-gray-400 hover:text-gray-600 transition-colors"
322
+ }, React__default.createElement("svg", {
323
+ className: "w-6 h-6",
324
+ fill: "none",
325
+ stroke: "currentColor",
326
+ viewBox: "0 0 24 24"
327
+ }, React__default.createElement("path", {
328
+ strokeLinecap: "round",
329
+ strokeLinejoin: "round",
330
+ strokeWidth: 2,
331
+ d: "M6 18L18 6M6 6l12 12"
332
+ })))), modelConfig && onModelConfigChange && React__default.createElement("div", {
333
+ className: "space-y-4"
334
+ }, React__default.createElement("div", null, React__default.createElement("label", {
335
+ className: "block text-sm font-medium text-gray-700 mb-2"
336
+ }, "API Key"), React__default.createElement("input", {
337
+ type: "password",
338
+ value: modelConfig.apiKey,
339
+ onChange: e => onModelConfigChange({
340
+ ...modelConfig,
341
+ apiKey: e.target.value
342
+ }),
343
+ className: "w-full px-3 py-2 border border-gray-300 rounded-lg focus:ring-2 focus:ring-blue-500 focus:border-blue-500",
344
+ placeholder: "Enter your API key"
345
+ })), React__default.createElement("div", null, React__default.createElement("label", {
346
+ className: "block text-sm font-medium text-gray-700 mb-2"
347
+ }, "Model"), React__default.createElement("select", {
348
+ value: modelConfig.model,
349
+ onChange: e => onModelConfigChange({
350
+ ...modelConfig,
351
+ model: e.target.value
352
+ }),
353
+ className: "w-full px-3 py-2 border border-gray-300 rounded-lg focus:ring-2 focus:ring-blue-500 focus:border-blue-500"
354
+ }, allModelOptions.map(option => React__default.createElement("option", {
355
+ key: option.value,
356
+ value: option.value
357
+ }, option.label)))))))))
358
+ );
359
+ };export{InputComponent};//# sourceMappingURL=InputComponent.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"InputComponent.js","sources":["../../../src/components/InboxMessage/InputComponent.tsx"],"sourcesContent":[null],"names":["React"],"mappings":"kZAgBO,MAAM,cAAc,GAAG,CAAC;YAMpB,EAAA,cAAS;aACT;aACA;;MAEP;QACA,CAAA,OAAO,EAAA,UAAW,CAAA,GAAA,QAAgB,CAAA,EAAA,CAAA;QAClC,CAAA,OAAO,EAAA,UAAiB,CAAA,GAAE,QAAA,CAAA,KAAA,CAAA;QAC1B,CAAA,KAAO,EAAA,QAAA,CAAA,GAAA,QAAsB,CAAA,EAAA,CAAA;QAC7B,CAAA,SAAO,EAAA,YAAmB,CAAA,GAAA,QAAA,CAAA,KAAoB,CAAC;AAC/C,EAAA,MAAA,CAAA,YAAiB,EAAA,eAAqC,CAAA,GAAA,QAAA,CAAA,EAAA,CAAA;AACtD,EAAA,MAAA,CAAA,uBAAyB,CAAA,GAAuB,QAAM,CAAA,KAAA,CAAA;AACtD,EAAA,MAAA,CAAA,uCAAyD,CAAA,GAAA,QAAA,CAAA,KAAA,CAAA;QACzD,CAAA,6CAA6C,CAAA,GAAA,QAAA,CAAA,KAAA,CAAA;QAE7C,CAAA,iBAAA,EAAA,oBAAA,CAAA,GAAgD,QAAA,CAAA,KAAA,CAAA;QAChD,WAAe,GAAA,MAAA,CAAA,IAAA,CAAA;AACX,EAAA,MAAA,gBAAgB,GAAA,MAAS,CAAC,IAAA,CAAA;AACtB,EAAA,MAAA,mBAAY,GAAA,MAAQ,CAAK,IAAG,CAAA;QAChC;IACJ;MAEA,cAAA,CAAA,cAAA,CAAA;;AAEI,EAAA,SAAA,CAAA,MAAM;AACF,IAAA,IAAA;iBACI,CAAA,OAAA,CAAA,KAAA,EAAA;;AAEJ,EAAA,CAAA,EAAA,EAAA,CAAA;;YAEA,MAAC;AACL,IAAA,MAAE,kBAAA,GAAA,KAAA,IAAA;AACF,MAAA,IAAA,gBAAS,CAAA,OAAiB,qBAAa,CAAA,OAAA,CAAA,QAAoB,CAAA,KAAA,CAAA,MAAA,CAAA,EAAA;QAC3D,oBAAa,CAAQ,KAAC,CAAA;MACzB;AAED,MAAA,IAAM,mBAAmB,CAAA,OAAA,IAAY,CAAC,mBAAmB,CAAA,OAAA,CAAA,QAAA,CAAA,KAAA,CAAA,MAAA,CAAA,EAAA;QACrD,uBAAuB,CAAC,KAAC,CAAA;;;IAG7B,QAAO,CAAA,gBAAA,CAAA,WAAA,EAAA,kBAAA,CAAA;AAEP,IAAA,OAAM,MAAA,QAAa,CAAA,mBAAiB,CAAA,WAAA,EAAA,kBAAA,CAAA;QAChC;wBAAkD,GAAA,WAAA,CAAA,OAAA,IAAA;mBAEvC,CAAA,OAAM,CAAA;AACjB,IAAA,YAAA,CAAA,IAAA,CAAc;cACT,CAAA,MAAQ,YAAE,CAAA,KAAA,CAAA,EAAA,IAAA,CAAA;;kBAEP,GAAS,WAAI,CAAA,MAAA;gBACb,CAAA,IAAA,EAAA,IAAA,KAAA,CAAA,MAAA,KAAA,CAAA,EAAA;cACA,CAAA,IAAA,CAAA;AACI,IAAA,cAAA,CAAA,OAAI,EAAA,KAAY,CAAA,CAAA,IAAO,CAAA,MAAG;AACtB,MAAA,UAAA,CAAA,EAAA,CAAA;iBACH,CAAA;;AAET,MAAA,UAAE,CAAA,MAAA;wBACU;UAChB,mBAAqB,CAAA,KAAE,EAAA;AAE3B,QAAA;SAEQ,GAAA,CAAA;cACI,CAAA,gBAAmB,CAAC,KAAA,CAAA,CAAA;aACnB,cAAC,EAAc,OAAG,CAAA,CAAA;AACnB,EAAA,MAAA,aAAA,GAAY,WAAC,CAAA,CAAA,IAAA;UAChB,OAAA,GAAA,CAAA,CAAA,KAAA,IAAA,CAAA,CAAA,OAAA;AACL,IAAA,IACC,OAAA,IAAW,EACd,IAAA,CAAA,CAAA,CAAA,QAAA,EAAA;AAEF,MAAA,CAAA,CAAA,cAAiB,EAAG;gBACV,EAAA;;AAEV,EAAA,CAAA,EAAC,CAAA,UAAW,CAAC,CAAC;QAEd,WAAM,GAAA,OAAmB,OAAG;UAEpB,KAAI,GAAA,OAAa,CAAC,KAAA,CAAA,IAAA,CAAA,CAAA,MAAA;WAClB,IAAI,CAAA,GAAK,CAAG,GAAE,EAAA,IAAA,CAAA,GAAA,CAAA,GAAA,EAAA,GAAA,GAAA,CAAA,KAAA,GAAA,CAAA,IAAA,EAAA,CAAA,CAAA;AACd,EAAA,CAAA,EAAA,CAAA,OAAI,CAAA,CAAA;AACA,EAAA,MAAA,mBAAA,GACK,WAAC,CAAA,CAAA;;AAED,GAAA,KAAA;gBAEL,GAAO,EAAA;QACX,KAAC,GAAA,CAAA;AACD,IAAA,IAAA,KAAA,CAAA,SAAc,MAAM,CAAA,MAAQ,MAAC,GAAA,MAAA,CAAA,iBAAA,EAAA;sBAChB,CAAA,CAAA,CAAI,sDAAsB,EAAA;yBACxB,EAAA,MAAA,CAAA;QACf,CAAC;AACD,MAAA;IACJ;AAIJ,IAAA,OAAM,MAAO,CAAA,KAAG,CAAA,KAAQ,CAAA,EAAI;MAC5B,QAAM,CAAA,IAAA,CAAU,MAAG,CAAA,KAAQ,CAAA,KAAO,CAAA,CAAA;MAElC,KAAA,IAAA,CAAA;AACA,IAAA;YACI,CAAA,QAAO,IAAA,CAAA,GAAc,QAAC,EAAA,GAAA,QAAA,CAAA,CAAA;KACzB,CAAA,QAAM,EAAA,KAAA,EAAA,gBAAA,EAAA,CAAA,CAAA,CAAA;AAEP,EAAA,MAAA,OAAM,GAAA,OAAA,CAAA,IAAmB,EAAG,IAAA,YAAa,GAAA,CAAA;AACrC,EAAO,OAAA,CAAA,IAAgB,EAAI,CAAC,MAAM,GAAG;;AAGzC,EAAA,MAAA,yBAA0B,CAAA,MAAA;AAElB,IAAA,OAAA,YAAI,EAAA;;QAEJ,mBAAC,GAAA,OAAA,CAAA,MAAA;WACD,eAAA,CAAA,GAAqB,CAAA,CAAA,KAAO;AAChC,WACC,EAAA,CAAA,CAAA;AAGL,MAAA;AAEQ,MAAA,IAAA,EAAI,CAAA,CAAA;;QAEJ;QACA,iBAAA,GAAA,WAA+B,CAAA,UAAA,IAAA;AACnC,IAAA,IACC,mBAAa,IAAA,WACjB,EAAC;MAEF,mBAAO,CAAA;QACH,GAAA,WAAA;QACA,KAAA,EAAA;AAEK,OAAA,CAAA;;wBAGW,CAAA,KAAA,CAAA;AACI,EAAA,CAAA,EAAA,CAAA,WAAA,EAAA,mBAAA,CAAA,CAAA;4BAMS,GAGxB,WAAA,CAAA,aAAA,IAAA;AAGA,IAAA,IAAA,mBAAiB,IAAK,WACnB,EAAA;AACI,MAAA,mBAAA,CAAA;QAKR,GAAA,WAAA;gBAEI,EAAA;AACI,OAAA,CAAA;;AAOQ,IAAA,uBAAA,CAAA,KAAS;AACT,EAAA,CAAA,EAAA,CAAA,WAAA,EAAA,mBAAW,CAAA,CAAA;AACd,EAAA;;AAcL,IAAAA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;;AAEQ,KAAA,EAAA,SAAA,IAAAA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AAMI,MAAA,SAAA,EAAA;AAKZ,KAAA,EAAAA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AACI,MAAA,SAAA,EAAA;AAIK,KAAA,EAAAA,cAAA,CAAA,mBAAM,EAAA;AACH,MAAA,SAAA,EAAA,cAAA;AACI,MAAA,IAAA,EAAA,cAAA;AAGA,MAAA,OAAA,EAAA;AAEQ,KAAA,EAAAA,cAAA,CAAA,aAAA,CAAA,MAAA,EAAA;AACA,MAAA,QAAA,EAAA,SAAA;4NAImC;AACnC,MAAA,QAAA,EAAA;8BAGX,EAAA,MAAA,GAAA,CAAA,IAAA,CAAA,OAAA,IAAAA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AACD,MAAA,SAAA,EAAA;6CAEQ,EAAA;AACA,MAAA,KAAA,EAAA;AAGZ,KAAA,CAAA,CAAA,EAAAA,cAAA,CAAA,aAAI,CAAA,KAAA,EAAA;AACJ,MAAA,SAAA,EAAA;AAMI,KAAA,EAAAA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AAIP,MAAA,SAAA,EAAA;mCAEO,CAAA,UAAA,EAAA;AASY,MAAA,GAAA,EAAA,WAAA;AACA,MAAA,SAAA,EAAA,CAAA,8IAMlB,EAAA,SAAA,GAAA,sCAAA,GAAA,iBAAA,CAAA,CAAA;AAGN,MAAA,KAAA,EAAA;AACI,QAAA,MAAA,EAAA,CAAA,EAAA,WAAA,CAAA,EAAA,CAAA;AAIK,QAAA,SAAA,EAAA;AACG,QAAA,SAAA,EAAA;AACI,OAAA;kCAGA,SAAO;4BAKX,OAAC;AACD,MAAA,SAAA,EAAA,aAAA;AACJ,MAAA,QAAA,EAAA,CAAA,IAAA,UAAI,CAAA,CAAA,CAAA,MAAA,CAAA,KAAA,CAAA;AACJ,MAAA,OAAA,EAAA,MAAA,YAAA,CAAA,IAAA,CAAA;AAMI,MAAA,MAAA,EAAA,MAAA,YAAA,CAAA,KAAA,CAAA;AAIP,MAAA,QAAA,EAAA,OAAA;;AAWmB,KAAA,CAAA,CAAA,EAAAA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;iBAQxB;AAKA,KAAA,EAAAA,cAAA,CAAA,aAAA,CAAA,iBAAA,EAAA;AAII,MAAA,QAAA,EAAA;AACI,KAAA,EAAAA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AAMA,MAAA,SAAA,EAAA;AAUR,KAAA,EAAAA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AAGY,MAAA,SAAA,EAAA,uBAAE;AACF,MAAA,IAAA,EAAA,MAAA;4BAQA;AAQA,MAAA,OAAA,EAAA;mCAQA,CAAA,MAAA,EAAA;AAanB,MAAA,aAAA,EAAA,OAAiB;oBAEV,EAAA,OAAA;iBACI,EAAA,CAAA;;uCAEQ,CAAA,KAAA,EAAA;AACA,MAAA,SAAA,EAAA,UAAA;AAII,MAAA,GAAA,EAAA;AACI,KAAA,EAAAA,cAAA,CAAA,aAAA,CAAA,QAAA,EAAA;AAUX,MAAA,OAAA,EAAA,MAAA,uBAAe,CAAA,CAAA,oBACZ,CAAA;AAEI,MAAA,SAAA,EAAA;;AAEI,MAAA,IAAA,WAAA,IAAA,WAAA,CAAA,QAAA,EAAA;AAYJ,QAAA,MAAA,eAAA,GAAA,mBAAA,CAAA,IAAA,CAAA,MAAA,IAAA,MAAA,CAAA,KAAA,KAAA,WAAA,CAAA,QAAA,CAAA;8BACI,GAAAA,cAAA,CAAA,aAAA,CAAAA,cAAA,CAAO,QAAA,EAAS,IAAC,EAAAA,cAAA,CAAA,aAAA,CAAA,MAAA,EAAA;AACjB,UAAA,SAAA,EAAA;AA+BxC,SAAE,EAAA,eAAA,CAAA,IAAA,CAAA,EAAAA,cAAA,CAAA,aAAA,CAAA,MAAA,EAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,20 @@
1
+ import React from 'react';
2
+ type LeftSidebarProps = {
3
+ userChannels: any;
4
+ userChannelsLoading: boolean;
5
+ currentUser: any;
6
+ users?: any[];
7
+ handleSelectChannel: (channel: any, postId?: any) => void;
8
+ clearMessages?: () => void;
9
+ selectedChannelId?: any;
10
+ channelToTop: number;
11
+ getChannelsRefetch: any;
12
+ supportServices?: any;
13
+ role?: any;
14
+ messagesQuery?: any;
15
+ windowHeight?: number;
16
+ windowWidth?: number;
17
+ };
18
+ export declare const LeftSidebar: React.MemoExoticComponent<(props: LeftSidebarProps) => React.JSX.Element>;
19
+ export {};
20
+ //# sourceMappingURL=LeftSidebar.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LeftSidebar.d.ts","sourceRoot":"","sources":["../../../src/components/InboxMessage/LeftSidebar.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAuC,MAAM,OAAO,CAAC;AAO5D,KAAK,gBAAgB,GAAG;IACpB,YAAY,EAAE,GAAG,CAAC;IAClB,mBAAmB,EAAE,OAAO,CAAC;IAC7B,WAAW,EAAE,GAAG,CAAC;IACjB,KAAK,CAAC,EAAE,GAAG,EAAE,CAAC;IACd,mBAAmB,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE,MAAM,CAAC,EAAE,GAAG,KAAK,IAAI,CAAC;IAC1D,aAAa,CAAC,EAAE,MAAM,IAAI,CAAC;IAC3B,iBAAiB,CAAC,EAAE,GAAG,CAAC;IACxB,YAAY,EAAE,MAAM,CAAC;IACrB,kBAAkB,EAAE,GAAG,CAAC;IACxB,eAAe,CAAC,EAAE,GAAG,CAAC;IACtB,IAAI,CAAC,EAAE,GAAG,CAAC;IACX,aAAa,CAAC,EAAE,GAAG,CAAC;IACpB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;CACxB,CAAC;AAEF,eAAO,MAAM,WAAW,oCAAsB,gBAAgB,uBA6F5D,CAAC"}
@@ -0,0 +1,102 @@
1
+ import {GoSearch}from'@react-icons/all-files/go/GoSearch.js';import React__default,{useState,useMemo}from'react';import {useTranslation}from'react-i18next';import {orderBy,uniqBy}from'lodash-es';import {ConversationItem}from'./ConversationItem.js';import {ServiceConversationItem}from'./ServiceConversationItem.js';import {RoomType}from'common';const LeftSidebar = React__default.memo(props => {
2
+ const {
3
+ currentUser,
4
+ handleSelectChannel,
5
+ users,
6
+ userChannels,
7
+ userChannelsLoading,
8
+ selectedChannelId,
9
+ supportServices,
10
+ role,
11
+ messagesQuery,
12
+ windowHeight = 768,
13
+ windowWidth = 1024
14
+ } = props;
15
+ const [keyword, setKeyword] = useState('');
16
+ const {
17
+ t
18
+ } = useTranslation('translations');
19
+ // Memoize the sorted channels to prevent unnecessary re-renders
20
+ const sortedChannels = useMemo(() => {
21
+ if (!userChannels?.length) return [];
22
+ return orderBy(uniqBy([...userChannels], ({
23
+ id
24
+ }) => id), ['updatedAt'], ['desc']);
25
+ }, [userChannels]);
26
+ if (userChannelsLoading) {
27
+ return React__default.createElement("div", {
28
+ className: "space-y-4"
29
+ }, Array(10).fill(1).map((x, y) => React__default.createElement("div", {
30
+ key: y,
31
+ className: "h-10 bg-gray-200 rounded animate-pulse"
32
+ })));
33
+ }
34
+ return React__default.createElement("div", {
35
+ className: "w-full flex flex-col bg-white",
36
+ style: {
37
+ height: `${windowHeight}px`,
38
+ maxHeight: '100vh'
39
+ }
40
+ }, React__default.createElement("div", {
41
+ className: "flex-shrink-0 p-3 sm:p-4 border-b border-gray-200"
42
+ }, React__default.createElement(SearchInput, {
43
+ keyword: keyword,
44
+ setKeyword: setKeyword
45
+ })), React__default.createElement("div", {
46
+ className: "flex-1 min-h-0 overflow-hidden"
47
+ }, React__default.createElement("div", {
48
+ className: "overflow-y-auto p-2 sm:p-4 space-y-1",
49
+ style: {
50
+ height: `${windowHeight - 80}px`,
51
+ // Subtract header height
52
+ minHeight: 0
53
+ }
54
+ }, React__default.createElement(React__default.Fragment, null, supportServices ? supportServices : React__default.createElement(React__default.Fragment, null), sortedChannels.length > 0 ? sortedChannels.map((channel, index) => channel?.type === RoomType.Service ? React__default.createElement(ServiceConversationItem, {
55
+ key: `service_channel_${channel.id}`,
56
+ filter: keyword,
57
+ channel: channel,
58
+ currentUser: currentUser,
59
+ handleSelectChannel: handleSelectChannel,
60
+ users: users,
61
+ selectedChannelId: selectedChannelId,
62
+ showBorder: index != sortedChannels.length - 1,
63
+ role: role || null
64
+ }) : React__default.createElement(ConversationItem, {
65
+ key: `conv_channel_${channel.id}`,
66
+ filter: keyword,
67
+ channel: channel,
68
+ currentUser: currentUser,
69
+ handleSelectChannel: handleSelectChannel,
70
+ users: users,
71
+ selectedChannelId: selectedChannelId,
72
+ showBorder: index != sortedChannels.length - 1,
73
+ messagesQuery: messagesQuery
74
+ })) : React__default.createElement("div", {
75
+ className: "text-center py-8 text-gray-500"
76
+ }, React__default.createElement("div", {
77
+ className: "text-3xl mb-2"
78
+ }, "\uD83D\uDCAC"), React__default.createElement("p", null, "No conversations yet"))))));
79
+ });
80
+ const SearchInput = ({
81
+ keyword,
82
+ setKeyword
83
+ }) => {
84
+ const {
85
+ t
86
+ } = useTranslation('translations');
87
+ return React__default.createElement("div", {
88
+ className: "w-full"
89
+ }, React__default.createElement("div", {
90
+ className: "relative"
91
+ }, React__default.createElement("input", {
92
+ type: "text",
93
+ placeholder: t('tailwind_ui_inbox.search_inbox') || 'Search Inbox',
94
+ className: "w-full pl-10 sm:pl-12 pr-4 py-2 sm:py-2.5 bg-gray-50 border border-gray-200 rounded-lg text-gray-900 placeholder-gray-400 focus:outline-none focus:ring-1 focus:ring-blue-400 focus:border-blue-400 focus:bg-white transition-all duration-200 text-sm",
95
+ value: keyword,
96
+ onChange: e => setKeyword(e.target.value)
97
+ }), React__default.createElement("div", {
98
+ className: "absolute left-3 sm:left-4 top-1/2 transform -translate-y-1/2"
99
+ }, React__default.createElement(GoSearch, {
100
+ className: "w-4 h-4 text-gray-400"
101
+ }))));
102
+ };export{LeftSidebar};//# sourceMappingURL=LeftSidebar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LeftSidebar.js","sources":["../../../src/components/InboxMessage/LeftSidebar.tsx"],"sourcesContent":[null],"names":["React"],"mappings":"yVA0BO,MAAM,WAAW,GAAGA,cAAK,CAAC,IAAI,CAAC,KAAC,IAAyB;AAC5D,EAAA,MAAA;IAaA,WAAO;IACP;IAEA,KAAA;AACA,IAAA,YAAM;uBACG;AAAsB,IAAA,iBAAS;mBAC7B;AAKX,IAAA,IAAI;IAEJ,aAAI;gBAEI;eAES,GAAK;;QAMrB,CAAA,OAAA,EAAA,UAAA,CAAA,GAAA,QAAA,CAAA,EAAA,CAAA;AACD,EAAA,MAAA;;oBAGY,CAAA,cAAC,CAAA;;AAGD,EAAA,MAAA,cAAA,GAAA,OAAA,CAAA,MAAA;AAGQ,IAAA,IAAA,CAAA,YAAA,EAAA,MAAQ,EAAG,OAAA,EAAA;AACX,IAAA,OAAA,OAAA,CAAA,MAAA,CAAA,CAAA,eAAY,CAAA,EAAA,CAAA;AACf,MAAA;AAED,KAAA,KAAA,EAAA,CAAA,EAAA,CAAA,WAAA,CAAA,EAAA,CAAA,MAAA,CAAA,CAAA;AACK,EAAA,CAAA,EAAA,CAAA,YAAA,CAAA,CAAA;AAEA,EAAA,IAAA,mBAAA,EAAA;uCA8BO,CAAA,KAAA,EAAA;AACA,MAAA,SAAA,EAAA;AAQhC,KAAG,EAAA,KAAA,CAAA,EAAA,CAAA,CAAA,IAAA,CAAA,CAAA,CAAA,CAAA,GAAA,CAAA,CAAA,CAAA,EAAA,CAAA,KAAAA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AAEH,MAAM,GAAA,EAAA,CAAA;MACF,SAAW,EAAA;AACX,KAAA,CAAA,CAAA,CAAA;;AAGY,EAAA,OAAAA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;aAOA,EAAA,+BAAK;;AAMrB,MAAE,MAAA,EAAA,CAAA,EAAA,YAAA,CAAA,EAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,9 @@
1
+ import React from 'react';
2
+ type MessageInputProps = {
3
+ channelId?: string;
4
+ handleSend: (message: string, files: File[]) => Promise<void>;
5
+ placeholder?: string;
6
+ };
7
+ export declare const MessageInput: ({ handleSend: handleSendProp, placeholder }: MessageInputProps) => React.JSX.Element;
8
+ export {};
9
+ //# sourceMappingURL=MessageInput.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MessageInput.d.ts","sourceRoot":"","sources":["../../../src/components/InboxMessage/MessageInput.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA4D,MAAM,OAAO,CAAC;AAMjF,KAAK,iBAAiB,GAAG;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAC9D,WAAW,CAAC,EAAE,MAAM,CAAC;CACxB,CAAC;AAEF,eAAO,MAAM,YAAY,GAAI,6CAA6C,iBAAiB,sBAoM1F,CAAC"}