@zohoim/chat-components 0.0.13 → 0.0.15

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 (387) hide show
  1. package/es/ActionIcon/ActionIcon.js +57 -35
  2. package/es/ActionIcon/css/ActionIcon.module.css +4 -23
  3. package/es/ActionIcon/props/defaultProps.js +4 -2
  4. package/es/ActionIcon/props/propTypes.js +10 -3
  5. package/es/ActionIconWrapper/ActionIconWrapper.js +57 -0
  6. package/es/ActionIconWrapper/css/ActionIconWrapper.module.css +32 -0
  7. package/es/ActionIconWrapper/css/cssJSLogic.js +14 -0
  8. package/es/ActionIconWrapper/index.js +1 -0
  9. package/es/{im/IMDateTime → ActionIconWrapper}/props/defaultProps.js +3 -3
  10. package/es/ActionIconWrapper/props/propTypes.js +11 -0
  11. package/es/AttachmentBubble/AttachmentBubble.js +30 -29
  12. package/es/AttachmentBubble/css/AttachmentBubble.module.css +17 -15
  13. package/es/AttachmentBubble/props/defaultProps.js +2 -2
  14. package/es/AttachmentBubble/props/propTypes.js +10 -5
  15. package/es/AttachmentBubbleInfo/AttachmentBubbleInfo.js +13 -21
  16. package/es/AttachmentBubbleInfo/css/AttachmentBubbleInfo.module.css +19 -16
  17. package/es/AttachmentBubbleInfo/props/defaultProps.js +1 -1
  18. package/es/AttachmentBubbleInfo/props/propTypes.js +3 -3
  19. package/es/AttachmentIcon/AttachmentIcon.js +47 -0
  20. package/es/AttachmentIcon/css/AttachmentIcon.module.css +4 -0
  21. package/es/AttachmentIcon/index.js +1 -0
  22. package/es/{MediaControls → AttachmentIcon}/props/defaultProps.js +3 -3
  23. package/es/AttachmentIcon/props/propTypes.js +11 -0
  24. package/es/AttachmentIcon/utils/getAttachmentIconComponent.js +61 -0
  25. package/es/Audio/Audio.js +14 -36
  26. package/es/Audio/css/Audio.module.css +3 -3
  27. package/es/Audio/props/defaultProps.js +2 -3
  28. package/es/Audio/props/propTypes.js +3 -4
  29. package/es/AudioBubble/AudioBubble.js +32 -36
  30. package/es/AudioBubble/css/AudioBubble.module.css +3 -2
  31. package/es/AudioBubble/props/defaultProps.js +2 -3
  32. package/es/AudioBubble/props/propTypes.js +10 -7
  33. package/es/Fonts/puviFont.module.css +55 -54
  34. package/es/ImageBubble/ImageBubble.js +20 -20
  35. package/es/ImageBubble/css/ImageBubble.module.css +8 -11
  36. package/es/ImageBubble/props/defaultProps.js +1 -1
  37. package/es/ImageBubble/props/propTypes.js +5 -3
  38. package/es/InfoBubble/InfoBubble.js +6 -8
  39. package/es/InfoBubble/props/defaultProps.js +1 -1
  40. package/es/LazyLoadImage/LazyLoadImage.js +6 -16
  41. package/es/LazyLoadImage/css/LazyLoadImage.module.css +1 -0
  42. package/es/LazyLoadImage/props/defaultProps.js +1 -1
  43. package/es/LazyLoadImage/props/propTypes.js +3 -3
  44. package/es/LocationBubble/LocationBubble.js +17 -34
  45. package/es/LocationBubble/css/LocationBubble.module.css +13 -14
  46. package/es/LocationBubble/props/defaultProps.js +1 -1
  47. package/es/LocationBubble/props/propTypes.js +2 -2
  48. package/es/MediaBubbleWrapper/MediaBubbleWrapper.js +59 -0
  49. package/es/MediaBubbleWrapper/css/MediaBubbleWrapper.module.css +7 -0
  50. package/es/MediaBubbleWrapper/index.js +1 -0
  51. package/es/MediaBubbleWrapper/props/defaultProps.js +7 -0
  52. package/es/MediaBubbleWrapper/props/propTypes.js +16 -0
  53. package/es/Message/Message.js +59 -37
  54. package/es/Message/props/defaultProps.js +3 -3
  55. package/es/Message/props/propTypes.js +17 -38
  56. package/es/MessageAction/MessageAction.js +31 -18
  57. package/es/MessageAction/props/defaultProps.js +4 -4
  58. package/es/MessageAction/props/propTypes.js +11 -8
  59. package/es/MessageActions/MessageActions.js +56 -96
  60. package/es/MessageActions/css/MessageActions.module.css +2 -9
  61. package/es/MessageActions/props/defaultProps.js +2 -4
  62. package/es/MessageActions/props/propTypes.js +13 -19
  63. package/es/MessageActionsMore/MessageActionsMore.js +43 -35
  64. package/es/MessageActionsMore/css/MessageActionsMore.module.css +8 -5
  65. package/es/MessageActionsMore/props/defaultProps.js +3 -2
  66. package/es/MessageActionsMore/props/propTypes.js +3 -2
  67. package/es/MessageActionsWrapper/MessageActionsWrapper.js +36 -44
  68. package/es/MessageActionsWrapper/css/MessageActionsWrapper.module.css +1 -1
  69. package/es/MessageActionsWrapper/props/defaultProps.js +4 -5
  70. package/es/MessageActionsWrapper/props/propTypes.js +7 -4
  71. package/es/MessageAvatar/MessageAvatar.js +11 -19
  72. package/es/MessageAvatar/css/MessageAvatar.module.css +3 -3
  73. package/es/MessageAvatar/props/defaultProps.js +2 -6
  74. package/es/MessageAvatar/props/propTypes.js +5 -5
  75. package/es/MessageBox/MessageBox.js +33 -30
  76. package/es/MessageBox/css/MessageBox.module.css +9 -16
  77. package/es/MessageBox/css/cssJSLogic.js +1 -21
  78. package/es/MessageBox/props/defaultProps.js +1 -3
  79. package/es/MessageBox/props/propTypes.js +8 -7
  80. package/es/MessageBubble/MessageBubble.js +64 -38
  81. package/es/MessageBubble/css/MessageBubble.module.css +11 -8
  82. package/es/MessageBubble/css/cssJSLogic.js +10 -26
  83. package/es/MessageBubble/props/defaultProps.js +1 -1
  84. package/es/MessageBubble/props/propTypes.js +7 -7
  85. package/es/MessageStatus/MessageStatus.js +11 -11
  86. package/es/MessageStatus/css/MessageStatus.module.css +1 -1
  87. package/es/MessageStatus/css/cssJSLogic.js +13 -9
  88. package/es/MessageStatus/props/defaultProps.js +1 -1
  89. package/es/MessageStatus/props/propTypes.js +4 -14
  90. package/es/MoreActionItem/MoreActionItem.js +21 -33
  91. package/es/MoreActionItem/css/MoreActionItem.module.css +6 -14
  92. package/es/MoreActionItem/props/defaultProps.js +1 -5
  93. package/es/MoreActionItem/props/propTypes.js +6 -5
  94. package/es/ReplyBubble/ReplyBubble.js +58 -28
  95. package/es/ReplyBubble/css/ReplyBubble.module.css +17 -0
  96. package/es/ReplyBubble/props/defaultProps.js +3 -4
  97. package/es/ReplyBubble/props/propTypes.js +15 -8
  98. package/es/ReplyBubbleContent/ReplyBubbleContent.js +15 -25
  99. package/es/ReplyBubbleContent/css/ReplyBubbleContent.module.css +35 -38
  100. package/es/ReplyBubbleContent/props/defaultProps.js +1 -1
  101. package/es/ReplyBubbleContent/props/propTypes.js +4 -4
  102. package/es/ReplyBubbleHeader/ReplyBubbleHeader.js +27 -33
  103. package/es/ReplyBubbleHeader/css/ReplyBubbleHeader.module.css +25 -9
  104. package/es/ReplyBubbleHeader/props/defaultProps.js +2 -4
  105. package/es/ReplyBubbleHeader/props/propTypes.js +3 -2
  106. package/es/TextBubble/TextBubble.js +12 -30
  107. package/es/TextBubble/css/TextBubble.module.css +15 -9
  108. package/es/TextBubble/props/defaultProps.js +2 -5
  109. package/es/TextBubble/props/propTypes.js +3 -4
  110. package/es/Theme/{DeskAssets.js → ThemeAssets.js} +10 -6
  111. package/es/Theme/ThemeWrapper.js +54 -57
  112. package/es/Theme/{ToolttipWrapper.js → TooltipWrapper.js} +29 -25
  113. package/es/Theme/constants/index.js +1 -4
  114. package/es/Theme/crm/dark/blueFanTheme.js +5 -5
  115. package/es/Theme/crm/dark/blueTheme.js +5 -5
  116. package/es/Theme/crm/dark/commonColorVariable.js +5 -5
  117. package/es/Theme/crm/dark/darkBlueTheme.js +5 -5
  118. package/es/Theme/crm/dark/darkGreyTheme.js +5 -5
  119. package/es/Theme/crm/dark/greenTheme.js +5 -5
  120. package/es/Theme/crm/dark/orangeTheme.js +5 -5
  121. package/es/Theme/crm/dark/pinkTheme.js +5 -5
  122. package/es/Theme/crm/dark/tealTheme.js +5 -5
  123. package/es/Theme/crm/dark/whiteTheme.js +5 -5
  124. package/es/Theme/crm/light/blueFanTheme.js +5 -5
  125. package/es/Theme/crm/light/blueTheme.js +3 -3
  126. package/es/Theme/crm/light/commonColorVariable.js +3 -3
  127. package/es/Theme/crm/light/darkBlueTheme.js +5 -5
  128. package/es/Theme/crm/light/darkGreyTheme.js +5 -5
  129. package/es/Theme/crm/light/greenTheme.js +3 -3
  130. package/es/Theme/crm/light/orangeTheme.js +3 -3
  131. package/es/Theme/crm/light/pinkTheme.js +3 -3
  132. package/es/Theme/crm/light/tealTheme.js +3 -3
  133. package/es/Theme/crm/light/whiteTheme.js +5 -5
  134. package/es/Theme/crm/pureDark/blueFanTheme.js +5 -5
  135. package/es/Theme/crm/pureDark/blueTheme.js +5 -5
  136. package/es/Theme/crm/pureDark/commonColorVariable.js +3 -3
  137. package/es/Theme/crm/pureDark/darkBlueTheme.js +5 -5
  138. package/es/Theme/crm/pureDark/darkGreyTheme.js +5 -5
  139. package/es/Theme/crm/pureDark/greenTheme.js +5 -5
  140. package/es/Theme/crm/pureDark/orangeTheme.js +5 -5
  141. package/es/Theme/crm/pureDark/pinkTheme.js +5 -5
  142. package/es/Theme/crm/pureDark/tealTheme.js +5 -5
  143. package/es/Theme/crm/pureDark/whiteTheme.js +5 -5
  144. package/es/Theme/css/TooltipWrapper.module.css +2 -2
  145. package/es/Theme/props/defaultProps.js +2 -3
  146. package/es/Theme/props/propTypes.js +5 -6
  147. package/es/Theme/{desk/commonDeskColorVariable.js → themeVariables/commonThemeColorVariable.js} +2 -3
  148. package/es/Theme/{desk → themeVariables}/dark/blueTheme.js +11 -11
  149. package/es/Theme/{desk → themeVariables}/dark/commonColorVariable.js +1 -1
  150. package/es/Theme/{desk → themeVariables}/dark/greenTheme.js +8 -8
  151. package/es/Theme/{desk → themeVariables}/dark/orangeTheme.js +8 -8
  152. package/es/Theme/{desk → themeVariables}/dark/redTheme.js +8 -8
  153. package/es/Theme/{desk → themeVariables}/dark/yellowTheme.js +8 -8
  154. package/es/Theme/{desk → themeVariables}/light/blueTheme.js +8 -8
  155. package/es/Theme/{desk → themeVariables}/light/commonColorVariable.js +1 -1
  156. package/es/Theme/{desk → themeVariables}/light/greenTheme.js +8 -8
  157. package/es/Theme/{desk → themeVariables}/light/orangeTheme.js +7 -7
  158. package/es/Theme/{desk → themeVariables}/light/redTheme.js +7 -7
  159. package/es/Theme/{desk → themeVariables}/light/yellowTheme.js +8 -8
  160. package/es/Theme/{desk → themeVariables}/pureDark/blueTheme.js +8 -8
  161. package/es/Theme/{desk → themeVariables}/pureDark/commonColorVariable.js +1 -1
  162. package/es/Theme/{desk → themeVariables}/pureDark/greenTheme.js +8 -8
  163. package/es/Theme/{desk → themeVariables}/pureDark/orangeTheme.js +8 -8
  164. package/es/Theme/{desk → themeVariables}/pureDark/redTheme.js +8 -8
  165. package/es/Theme/{desk → themeVariables}/pureDark/yellowTheme.js +8 -8
  166. package/es/Theme/utils/combineConfigurations.js +17 -0
  167. package/es/Theme/utils/flatVariables.js +12 -0
  168. package/es/Theme/utils/getCustomizedCssVariables.js +19 -0
  169. package/es/Theme/utils/getThemeConfigurations.js +47 -175
  170. package/es/Theme/utils/getWrapperDivProps.js +12 -0
  171. package/es/Video/Video.js +13 -45
  172. package/es/Video/css/Video.module.css +2 -7
  173. package/es/Video/props/defaultProps.js +2 -3
  174. package/es/Video/props/propTypes.js +3 -4
  175. package/es/VideoBubble/VideoBubble.js +32 -35
  176. package/es/VideoBubble/css/VideoBubble.module.css +4 -4
  177. package/es/VideoBubble/props/defaultProps.js +2 -3
  178. package/es/VideoBubble/props/propTypes.js +11 -7
  179. package/es/css/common.module.css +6 -0
  180. package/es/icons/create-icon-components.js +30 -0
  181. package/es/icons/factory/common/article.svg +4 -4
  182. package/es/icons/factory/integrations/chInstagram.svg +2 -2
  183. package/es/icons/factory/integrations/chWhatsApp.svg +2 -2
  184. package/es/icons/factory/integrations/ttASAP.svg +6 -1
  185. package/es/icons/factory/integrations/ttLine.svg +8 -0
  186. package/es/icons/factory/integrations/ttTelegram.svg +4 -1
  187. package/es/icons/factory/integrations/ttTwillio.svg +8 -1
  188. package/es/icons/factory/integrations/ttWechat.svg +9 -1
  189. package/es/icons/icon.template.js +9 -8
  190. package/es/icons/iconSrc/common/Article.js +2 -3
  191. package/es/icons/iconSrc/common/index.js +1 -2
  192. package/es/icons/iconSrc/integrations/ChInstagram.js +2 -3
  193. package/es/icons/iconSrc/integrations/ChWhatsApp.js +2 -3
  194. package/es/icons/iconSrc/integrations/TtASAP.js +11 -15
  195. package/es/icons/iconSrc/integrations/{TtTwitter.js → TtLine.js} +14 -18
  196. package/es/icons/iconSrc/integrations/TtTelegram.js +8 -12
  197. package/es/icons/iconSrc/integrations/TtTwillio.js +15 -19
  198. package/es/icons/iconSrc/integrations/TtWechat.js +19 -20
  199. package/es/icons/iconSrc/integrations/index.js +1 -1
  200. package/es/im/ArticleBubble/ArticleBubble.js +67 -0
  201. package/es/im/ArticleBubble/css/ArticleBubble.module.css +57 -0
  202. package/es/{ArticleBubble → im/ArticleBubble}/props/defaultProps.js +1 -1
  203. package/es/im/ArticleBubble/props/propTypes.js +13 -0
  204. package/es/im/IMAutoMessageInfo/IMAutoMessageInfo.js +10 -20
  205. package/es/im/IMAutoMessageInfo/css/IMAutoMessageInfo.module.css +2 -3
  206. package/es/im/IMAutoMessageInfo/props/defaultProps.js +1 -1
  207. package/es/im/IMAutoMessageInfo/props/propTypes.js +11 -9
  208. package/es/im/IMInfoBubble/IMInfoBubble.js +6 -8
  209. package/es/im/IMInfoBubble/props/defaultProps.js +1 -1
  210. package/es/im/IMIntegrationIcon/IMIntegrationIcon.js +31 -38
  211. package/es/im/IMIntegrationIcon/css/IMIntegrationIcon.module.css +5 -8
  212. package/es/im/IMIntegrationIcon/css/cssJSLogic.js +9 -13
  213. package/es/im/IMIntegrationIcon/index.js +1 -2
  214. package/es/im/IMIntegrationIcon/props/defaultProps.js +6 -4
  215. package/es/im/IMIntegrationIcon/props/propTypes.js +6 -17
  216. package/es/im/IMMessage/IMMessage.js +97 -90
  217. package/es/im/IMMessage/css/IMMessage.module.css +36 -0
  218. package/es/im/IMMessage/css/cssJSLogic.js +16 -3
  219. package/es/im/IMMessage/props/defaultProps.js +3 -11
  220. package/es/im/IMMessage/props/propTypes.js +52 -97
  221. package/es/im/IMMessageContent/IMMessageContent.js +76 -65
  222. package/es/im/IMMessageContent/css/IMMessageContent.module.css +1 -1
  223. package/es/im/IMMessageContent/props/defaultProps.js +2 -3
  224. package/es/im/IMMessageContent/props/propTypes.js +29 -23
  225. package/es/im/IMMessageMeta/IMMessageMeta.js +26 -21
  226. package/es/im/IMMessageMeta/css/IMMessageMeta.module.css +13 -4
  227. package/es/im/IMMessageMeta/css/cssJSLogic.js +11 -3
  228. package/es/im/IMMessageMeta/props/defaultProps.js +1 -1
  229. package/es/im/IMMessageMeta/props/propTypes.js +17 -12
  230. package/es/im/IMPermaLink/IMPermaLink.js +48 -0
  231. package/es/im/IMPermaLink/css/IMPermaLink.module.css +14 -0
  232. package/es/im/{IMTicketLink → IMPermaLink}/css/cssJSLogic.js +3 -3
  233. package/es/im/IMPermaLink/index.js +1 -0
  234. package/es/im/{IMAttachmentIcon → IMPermaLink}/props/defaultProps.js +3 -3
  235. package/es/im/IMPermaLink/props/propTypes.js +11 -0
  236. package/es/im/IMReplyBubble/IMReplyBubble.js +20 -59
  237. package/es/im/IMReplyBubble/props/defaultProps.js +2 -4
  238. package/es/im/IMReplyBubble/props/propTypes.js +16 -14
  239. package/es/im/IMTextBubble/IMTextBubble.js +15 -31
  240. package/es/im/IMTextBubble/props/defaultProps.js +3 -9
  241. package/es/im/IMTextBubble/props/propTypes.js +22 -8
  242. package/es/im/css/common.module.css +6 -0
  243. package/es/im/index.js +2 -10
  244. package/es/index.js +4 -6
  245. package/package.json +32 -14
  246. package/es/ActionIcon/css/cssJSLogic.js +0 -10
  247. package/es/ArticleBubble/ArticleBubble.js +0 -70
  248. package/es/ArticleBubble/css/ArticleBubble.module.css +0 -48
  249. package/es/ArticleBubble/css/cssJSLogic.js +0 -34
  250. package/es/ArticleBubble/props/propTypes.js +0 -10
  251. package/es/AttachmentBubble/css/cssJSLogic.js +0 -18
  252. package/es/AttachmentBubbleInfo/css/cssJSLogic.js +0 -18
  253. package/es/Audio/css/cssJSLogic.js +0 -14
  254. package/es/AudioBubble/css/cssJSLogic.js +0 -20
  255. package/es/ImageBubble/css/cssJSLogic.js +0 -22
  256. package/es/LazyLoadImage/css/cssJSLogic.js +0 -10
  257. package/es/LocationBubble/css/cssJSLogic.js +0 -30
  258. package/es/MediaControls/MediaControls.js +0 -59
  259. package/es/MediaControls/css/MediaControls.module.css +0 -1
  260. package/es/MediaControls/css/cssJSLogic.js +0 -22
  261. package/es/MediaControls/index.js +0 -1
  262. package/es/MediaControls/props/propTypes.js +0 -11
  263. package/es/Message/css/Message.module.css +0 -0
  264. package/es/Message/css/cssJSLogic.js +0 -10
  265. package/es/MessageAction/css/MessageAction.module.css +0 -0
  266. package/es/MessageAction/css/cssJSLogic.js +0 -0
  267. package/es/MessageActions/css/cssJSLogic.js +0 -20
  268. package/es/MessageActionsMore/css/cssJSLogic.js +0 -28
  269. package/es/MessageActionsWrapper/css/cssJSLogic.js +0 -10
  270. package/es/MessageActionsWrapper/props/propConstants.js +0 -7
  271. package/es/MessageAvatar/css/cssJSLogic.js +0 -18
  272. package/es/MessageBubble/props/propConstants.js +0 -6
  273. package/es/MoreActionItem/css/cssJSLogic.js +0 -27
  274. package/es/ReplyBubble/css/cssJSLogic.js +0 -10
  275. package/es/ReplyBubbleContent/css/cssJSLogic.js +0 -22
  276. package/es/ReplyBubbleHeader/css/cssJSLogic.js +0 -18
  277. package/es/TextBubble/css/cssJSLogic.js +0 -18
  278. package/es/Theme/css/cssJSLogic.js +0 -14
  279. package/es/Video/css/cssJSLogic.js +0 -14
  280. package/es/VideoBubble/css/cssJSLogic.js +0 -10
  281. package/es/icons/factory/actions/convertTicket.svg +0 -21
  282. package/es/icons/factory/common/quote.svg +0 -1
  283. package/es/icons/factory/integrations/ttTwitter.svg +0 -1
  284. package/es/icons/iconSrc/actions/ConvertTicket.js +0 -25
  285. package/es/icons/iconSrc/actions/index.js +0 -1
  286. package/es/icons/iconSrc/common/Quote.js +0 -17
  287. package/es/im/IMArticleBubble/IMArticleBubble.js +0 -54
  288. package/es/im/IMArticleBubble/css/IMArticleBubble.module.css +0 -0
  289. package/es/im/IMArticleBubble/css/cssJSLogic.js +0 -10
  290. package/es/im/IMArticleBubble/index.js +0 -1
  291. package/es/im/IMArticleBubble/props/defaultProps.js +0 -8
  292. package/es/im/IMArticleBubble/props/propTypes.js +0 -14
  293. package/es/im/IMAttachmentBubble/IMAttachmentBubble.js +0 -62
  294. package/es/im/IMAttachmentBubble/css/IMAttachmentBubble.module.css +0 -1
  295. package/es/im/IMAttachmentBubble/css/cssJSLogic.js +0 -10
  296. package/es/im/IMAttachmentBubble/index.js +0 -1
  297. package/es/im/IMAttachmentBubble/props/defaultProps.js +0 -10
  298. package/es/im/IMAttachmentBubble/props/propTypes.js +0 -16
  299. package/es/im/IMAttachmentIcon/IMAttachmentIcon.js +0 -85
  300. package/es/im/IMAttachmentIcon/css/IMAttachmentIcon.module.css +0 -4
  301. package/es/im/IMAttachmentIcon/css/cssJSLogic.js +0 -16
  302. package/es/im/IMAttachmentIcon/index.js +0 -1
  303. package/es/im/IMAttachmentIcon/props/propTypes.js +0 -26
  304. package/es/im/IMAudioBubble/IMAudioBubble.js +0 -62
  305. package/es/im/IMAudioBubble/css/IMAudioBubble.module.css +0 -8
  306. package/es/im/IMAudioBubble/css/cssJSLogic.js +0 -20
  307. package/es/im/IMAudioBubble/index.js +0 -1
  308. package/es/im/IMAudioBubble/props/defaultProps.js +0 -11
  309. package/es/im/IMAudioBubble/props/propTypes.js +0 -17
  310. package/es/im/IMAutoMessageInfo/css/cssJSLogic.js +0 -10
  311. package/es/im/IMDateTime/IMDateTime.js +0 -40
  312. package/es/im/IMDateTime/css/IMDateTime.module.css +0 -10
  313. package/es/im/IMDateTime/css/cssJSLogic.js +0 -10
  314. package/es/im/IMDateTime/index.js +0 -1
  315. package/es/im/IMDateTime/props/propTypes.js +0 -6
  316. package/es/im/IMImageBubble/IMImageBubble.js +0 -50
  317. package/es/im/IMImageBubble/css/IMImageBubble.module.css +0 -0
  318. package/es/im/IMImageBubble/css/cssJSLogic.js +0 -10
  319. package/es/im/IMImageBubble/index.js +0 -1
  320. package/es/im/IMImageBubble/props/defaultProps.js +0 -7
  321. package/es/im/IMImageBubble/props/propTypes.js +0 -13
  322. package/es/im/IMIntegrationIcon/props/propConstants.js +0 -8
  323. package/es/im/IMLocationBubble/IMLocationBubble.js +0 -50
  324. package/es/im/IMLocationBubble/css/IMLocationBubble.module.css +0 -0
  325. package/es/im/IMLocationBubble/css/cssJSLogic.js +0 -10
  326. package/es/im/IMLocationBubble/index.js +0 -1
  327. package/es/im/IMLocationBubble/props/defaultProps.js +0 -8
  328. package/es/im/IMLocationBubble/props/propTypes.js +0 -11
  329. package/es/im/IMMessageAvatar/IMMessageAvatar.js +0 -45
  330. package/es/im/IMMessageAvatar/css/IMMessageAvatar.module.css +0 -0
  331. package/es/im/IMMessageAvatar/css/cssJSLogic.js +0 -0
  332. package/es/im/IMMessageAvatar/index.js +0 -1
  333. package/es/im/IMMessageAvatar/props/defaultProps.js +0 -12
  334. package/es/im/IMMessageAvatar/props/propTypes.js +0 -53
  335. package/es/im/IMMessageContent/css/cssJSLogic.js +0 -10
  336. package/es/im/IMReplyBubble/css/IMReplyBubble.module.css +0 -18
  337. package/es/im/IMReplyBubble/css/cssJSLogic.js +0 -10
  338. package/es/im/IMTextBubble/css/IMTextBubble.module.css +0 -1
  339. package/es/im/IMTextBubble/css/cssJSLogic.js +0 -10
  340. package/es/im/IMTicketLink/IMTicketLink.js +0 -46
  341. package/es/im/IMTicketLink/css/IMTicketLink.module.css +0 -27
  342. package/es/im/IMTicketLink/index.js +0 -1
  343. package/es/im/IMTicketLink/props/defaultProps.js +0 -6
  344. package/es/im/IMTicketLink/props/propTypes.js +0 -10
  345. package/es/im/IMVideoBubble/IMVideoBubble.js +0 -61
  346. package/es/im/IMVideoBubble/css/IMVideoBubble.module.css +0 -1
  347. package/es/im/IMVideoBubble/css/cssJSLogic.js +0 -10
  348. package/es/im/IMVideoBubble/index.js +0 -1
  349. package/es/im/IMVideoBubble/props/defaultProps.js +0 -11
  350. package/es/im/IMVideoBubble/props/propTypes.js +0 -17
  351. package/es/unused/AvatarSpace/AvatarSpace.js +0 -40
  352. package/es/unused/AvatarSpace/css/AvatarSpace.module.css +0 -1
  353. package/es/unused/AvatarSpace/css/cssJSLogic.js +0 -15
  354. package/es/unused/AvatarSpace/index.js +0 -1
  355. package/es/unused/AvatarSpace/props/defaultProps.js +0 -10
  356. package/es/unused/AvatarSpace/props/propConstants.js +0 -7
  357. package/es/unused/AvatarSpace/props/propTypes.js +0 -8
  358. package/es/unused/MessageBoxFooter/MessageBoxFooter.js +0 -39
  359. package/es/unused/MessageBoxFooter/css/MessageBoxFooter.module.css +0 -3
  360. package/es/unused/MessageBoxFooter/css/cssJSLogic.js +0 -10
  361. package/es/unused/MessageBoxFooter/index.js +0 -1
  362. package/es/unused/MessageBoxFooter/props/defaultProps.js +0 -5
  363. package/es/unused/MessageBoxFooter/props/propTypes.js +0 -6
  364. package/es/unused/MessageBoxHeader/MessageBoxHeader.js +0 -7
  365. package/es/unused/MessageBoxHeader/css/MessageBoxHeader.module.css +0 -0
  366. package/es/unused/MessageBoxHeader/css/cssJsLogic.js +0 -0
  367. package/es/unused/MessageBoxHeader/index.js +0 -2
  368. package/es/unused/MessageBoxHeader/props/defaultProps.js +0 -0
  369. package/es/unused/MessageBoxHeader/props/propTypes.js +0 -0
  370. package/es/unused/MessageWrapper/MessageWrapper.js +0 -36
  371. package/es/unused/MessageWrapper/css/MessageWrapper.module.css +0 -0
  372. package/es/unused/MessageWrapper/css/cssJSLogic.js +0 -10
  373. package/es/unused/MessageWrapper/index.js +0 -1
  374. package/es/unused/MessageWrapper/props/defaultProps.js +0 -6
  375. package/es/unused/MessageWrapper/props/propTypes.js +0 -6
  376. package/es/unused/TextMessage/DefaultActions.js +0 -60
  377. package/es/unused/TextMessage/TextMessage.js +0 -67
  378. package/es/unused/TextMessage/TextMessage1.js +0 -66
  379. package/es/unused/TextMessage/css/TextMessage.module.css +0 -5
  380. package/es/unused/TextMessage/css/cssJSLogic.js +0 -0
  381. package/es/unused/TextMessage/index.js +0 -1
  382. package/es/unused/TextMessage/props/defaultProps.js +0 -4
  383. package/es/unused/TextMessage/props/propConstants.js +0 -3
  384. package/es/unused/TextMessage/props/propTypes.js +0 -17
  385. package/es/unused/darkTheme.js +0 -9
  386. package/es/unused/defaultTheme.js +0 -33
  387. /package/es/{ArticleBubble → im/ArticleBubble}/index.js +0 -0
@@ -1,56 +1,78 @@
1
- /* eslint-disable react/jsx-no-bind */
2
- /* eslint-disable max-len */
1
+ function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
3
2
 
4
3
  /** ** Libraries *** */
5
- import React from 'react';
4
+ import React, { useCallback, useMemo } from 'react';
5
+ /** ** Components *** */
6
6
 
7
+ import ActionIconWrapper from '../ActionIconWrapper/ActionIconWrapper';
8
+ /** ** Icons *** */
9
+
10
+ import ReplyIcon from '@zohodesk/icon/es/general/Reply';
11
+ import ReloadIcon from '@zohodesk/icon/es/general/Reload';
12
+ import CopyIcon from '@zohodesk/icon/es/general/Copy';
13
+ import DownloadIcon from '@zohodesk/icon/es/general/Cloud';
14
+ import DeleteIcon from '@zohodesk/icon/es/general/Delete';
15
+ import ForwardIcon from '@zohodesk/icon/es/channels/EmailForward';
7
16
  /** ** Hooks *** */
8
- import useMergeStyle from '@zohodesk/hooks/es/utils/useMergeStyle';
9
- import useActionIcon from '@zohoim/chat-components-hooks/es/ActionIcon/useActionIcon';
10
17
 
18
+ import useMergeStyle from '@zohodesk/hooks/es/utils/useMergeStyle';
11
19
  /** ** Constants *** */
20
+
12
21
  import actionIconDefaultProps from './props/defaultProps';
13
22
  import actionIconPropTypes from './props/propTypes';
14
-
15
- /** ** Methods *** */
16
- import cssJSLogic from './css/cssJSLogic';
17
-
23
+ import { dummyObject } from '@zohoim/chat-components-utils/es/constants/emptyConstants';
24
+ import { defaultMessageActions } from '@zohoim/chat-components-utils/es/constants/messageActionConstants';
18
25
  /** ** Styles *** */
26
+
19
27
  import style from './css/ActionIcon.module.css';
28
+ const {
29
+ REPLY,
30
+ COPY,
31
+ DOWNLOAD,
32
+ RESEND,
33
+ DELETE,
34
+ FORWARD
35
+ } = defaultMessageActions;
20
36
  export default function ActionIcon(props) {
21
37
  const {
22
- renderIcon: propRenderIcon,
23
38
  customStyle,
24
- onClick: propOnClick,
39
+ customProps,
40
+ onClick,
25
41
  id,
26
- title
42
+ title,
43
+ isDisabled,
44
+ needIconOnly
27
45
  } = props;
28
46
  const {
29
- onClick,
30
- renderIcon
31
- } = useActionIcon({
32
- renderIcon: propRenderIcon,
33
- onClick: propOnClick,
34
- id
35
- });
36
-
47
+ actionIconWrapperProps = dummyObject
48
+ } = customProps;
37
49
  /* External customization */
38
- const newStyle = useMergeStyle(style, customStyle);
39
50
 
40
- /* CSS classnames added based on logic */
41
- const {
42
- actionIconClass
43
- } = cssJSLogic(props, newStyle);
44
-
45
- /* Render Icon */
46
- const icon = renderIcon({
47
- id
48
- });
49
- return icon ? /*#__PURE__*/React.createElement("div", {
50
- className: actionIconClass,
51
- "data-title": title,
52
- onClick: onClick
53
- }, icon) : null;
51
+ const newStyle = useMergeStyle(style, customStyle);
52
+ const iconStyle = useMemo(() => ({
53
+ base: newStyle.icon
54
+ }), [newStyle.icon]);
55
+ const renderIcon = useCallback(() => {
56
+ const iconMapping = {
57
+ [REPLY]: ReplyIcon,
58
+ [COPY]: CopyIcon,
59
+ [DOWNLOAD]: DownloadIcon,
60
+ [RESEND]: ReloadIcon,
61
+ [DELETE]: DeleteIcon,
62
+ [FORWARD]: ForwardIcon
63
+ };
64
+ const IconComponent = iconMapping[id];
65
+ return IconComponent ? /*#__PURE__*/React.createElement(IconComponent, {
66
+ customStyle: iconStyle
67
+ }) : null;
68
+ }, [iconStyle, id]);
69
+ return needIconOnly ? renderIcon() : /*#__PURE__*/React.createElement(ActionIconWrapper, _extends({
70
+ id: id,
71
+ isDisabled: isDisabled,
72
+ onClick: onClick,
73
+ renderIcon: renderIcon,
74
+ title: title
75
+ }, actionIconWrapperProps));
54
76
  }
55
77
  ActionIcon.propTypes = actionIconPropTypes;
56
78
  ActionIcon.defaultProps = actionIconDefaultProps;
@@ -1,28 +1,9 @@
1
1
  .varClass {
2
- --actionIcon-height: var(--imlib_size_26);
3
- --actionIcon-width: var(--imlib_size_26);
4
- --actionIcon-border: var(--imlib_size_1);
5
- --actionIcon-border_radius: var(--imlib_size_4);
2
+ --actionIcon_icon_size: var(--zd_size15);
6
3
  }
7
4
 
8
- .actionIcon {
5
+ .icon {
9
6
  composes: varClass;
10
-
11
- display: inline-flex;
12
- display: -webkit-inline-flex;
13
- display: -ms-inline-flexbox;
14
- color: var(--imlib_chat_components_actionIcon_color);
15
- position: relative;
16
- width: var(--actionIcon-width);
17
- height: var(--actionIcon-height);
18
- align-items: center;
19
- justify-content: center;
20
- cursor: pointer;
21
- border: var(--actionIcon-border) solid transparent;
22
- border-radius: var(--actionIcon-border_radius);
23
- }
24
-
25
- .actionIcon:hover {
26
- background-color: var(--imlib_chat_components_actionIcon_bg_color);
27
- border-color: var(--imlib_chat_components_actionIcon_border_color);
7
+ width: var(--actionIcon_icon_size);
8
+ height: var(--actionIcon_icon_size);
28
9
  }
@@ -1,6 +1,8 @@
1
1
  /** ** Constants *** */
2
- import { dummyObject } from '@zohoim/chat-components-utils/es/constants';
2
+ import { dummyObject } from '@zohoim/chat-components-utils/es/constants/emptyConstants';
3
3
  const actionIconDefaultProps = {
4
- customStyle: dummyObject
4
+ customStyle: dummyObject,
5
+ customProps: dummyObject,
6
+ needIconOnly: false
5
7
  };
6
8
  export default actionIconDefaultProps;
@@ -1,10 +1,17 @@
1
1
  /** ** Libraries *** */
2
2
  import PropTypes from 'prop-types';
3
+ /** ** Constants *** */
4
+
5
+ import { defaultMessageActions } from '@zohoim/chat-components-utils/es/constants/messageActionConstants';
3
6
  const actionIconPropTypes = {
7
+ id: PropTypes.oneOf(Object.values(defaultMessageActions)).isRequired,
8
+ onClick: PropTypes.func.isRequired,
9
+ customProps: PropTypes.shape({
10
+ actionIconWrapperProps: PropTypes.object
11
+ }),
4
12
  customStyle: PropTypes.object,
5
- renderIcon: PropTypes.func.isRequired,
6
- onClick: PropTypes.func,
7
- id: PropTypes.string,
13
+ isDisabled: PropTypes.bool,
14
+ needIconOnly: PropTypes.bool,
8
15
  title: PropTypes.string
9
16
  };
10
17
  export default actionIconPropTypes;
@@ -0,0 +1,57 @@
1
+ /** ** Libraries *** */
2
+ import React from 'react';
3
+ /** ** Hooks *** */
4
+
5
+ import useMergeStyle from '@zohodesk/hooks/es/utils/useMergeStyle';
6
+ import useActionIconWrapper from '@zohoim/chat-components-hooks/es/ActionIconWrapper/useActionIconWrapper';
7
+ /** ** Constants *** */
8
+
9
+ import actionIconWrapperDefaultProps from './props/defaultProps';
10
+ import actionIconWrapperPropTypes from './props/propTypes';
11
+ /** ** Methods *** */
12
+
13
+ import renderHandler from '@zohoim/chat-components-utils/es/common/renderHandler';
14
+ import cssJSLogic from './css/cssJSLogic';
15
+ /** ** Styles *** */
16
+
17
+ import style from './css/ActionIconWrapper.module.css';
18
+ export default function ActionIconWrapper(props) {
19
+ const {
20
+ renderIcon,
21
+ customStyle,
22
+ onClick: propOnClick,
23
+ id,
24
+ title,
25
+ isDisabled
26
+ } = props;
27
+ const {
28
+ onClick
29
+ } = useActionIconWrapper({
30
+ onClick: propOnClick,
31
+ id,
32
+ isDisabled
33
+ });
34
+ /* External CSS Customization */
35
+
36
+ const newStyle = useMergeStyle(style, customStyle);
37
+ /* css classnames added based on logic */
38
+
39
+ const {
40
+ actionIconWrapperClass
41
+ } = cssJSLogic({
42
+ isDisabled
43
+ }, newStyle);
44
+ /* Render Icon */
45
+
46
+ const icon = renderHandler(renderIcon)({
47
+ id
48
+ });
49
+ return icon ? /*#__PURE__*/React.createElement("div", {
50
+ className: actionIconWrapperClass,
51
+ "data-title": title,
52
+ onClick: onClick
53
+ }, icon) : null;
54
+ }
55
+ ActionIconWrapper.propTypes = actionIconWrapperPropTypes;
56
+ ActionIconWrapper.defaultProps = actionIconWrapperDefaultProps;
57
+ ActionIconWrapper.displayName = 'ActionIconWrapper';
@@ -0,0 +1,32 @@
1
+ .varClass {
2
+ --actionIconWrapper-height: var(--zd_size26);
3
+ --actionIconWrapper-width: var(--zd_size26);
4
+ --actionIconWrapper-border: 1px;
5
+ --actionIconWrapper-border_radius: 4px;
6
+ }
7
+
8
+ .actionIconWrapper {
9
+ composes: varClass;
10
+ display: inline-flex;
11
+ display: -webkit-inline-flex;
12
+ display: -ms-inline-flexbox;
13
+ color: var(--imlib_chat_components_actionIconWrapper_color);
14
+ position: relative;
15
+ width: var(--actionIconWrapper-width);
16
+ height: var(--actionIconWrapper-height);
17
+ align-items: center;
18
+ justify-content: center;
19
+ cursor: pointer;
20
+ border: var(--actionIconWrapper-border) solid transparent;
21
+ border-radius: var(--actionIconWrapper-border_radius);
22
+ }
23
+
24
+ .actionIconWrapper:hover {
25
+ background-color: var(--imlib_chat_components_actionIconWrapper_bg_color);
26
+ border-color: var(--imlib_chat_components_actionIconWrapper_border_color);
27
+ }
28
+
29
+ .disabled {
30
+ pointer-events: none;
31
+ opacity: 0.4;
32
+ }
@@ -0,0 +1,14 @@
1
+ /** ** Methods *** */
2
+ import { compileClassNames } from '@zohodesk/utils';
3
+ export default function cssJSLogic(props, style) {
4
+ const {
5
+ isDisabled
6
+ } = props;
7
+ const actionIconWrapperClass = compileClassNames({
8
+ [style.actionIconWrapper]: true,
9
+ [style.disabled]: isDisabled
10
+ });
11
+ return {
12
+ actionIconWrapperClass
13
+ };
14
+ }
@@ -0,0 +1 @@
1
+ export { default as ActionIconWrapper } from './ActionIconWrapper';
@@ -1,6 +1,6 @@
1
1
  /** ** Constants *** */
2
- import { dummyObject } from '@zohoim/chat-components-utils/es/constants';
3
- const imDateTimeDefaultProps = {
2
+ import { dummyObject } from '@zohoim/chat-components-utils/es/constants/emptyConstants';
3
+ const actionIconWrapperDefaultProps = {
4
4
  customStyle: dummyObject
5
5
  };
6
- export default imDateTimeDefaultProps;
6
+ export default actionIconWrapperDefaultProps;
@@ -0,0 +1,11 @@
1
+ /** ** Libraries *** */
2
+ import PropTypes from 'prop-types';
3
+ const actionIconWrapperPropTypes = {
4
+ id: PropTypes.string.isRequired,
5
+ onClick: PropTypes.func.isRequired,
6
+ renderIcon: PropTypes.func.isRequired,
7
+ customStyle: PropTypes.object,
8
+ isDisabled: PropTypes.bool,
9
+ title: PropTypes.string
10
+ };
11
+ export default actionIconWrapperPropTypes;
@@ -1,57 +1,58 @@
1
- /* eslint-disable react/jsx-no-bind */
2
- /* eslint-disable max-len */
1
+ function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
3
2
 
4
3
  /** ** Libraries *** */
5
4
  import React from 'react';
6
-
7
5
  /** ** Hooks *** */
8
- import useMergeStyle from '@zohodesk/hooks/es/utils/useMergeStyle';
9
6
 
7
+ import useMergeStyle from '@zohodesk/hooks/es/utils/useMergeStyle';
8
+ import useAttachmentBubble from '@zohoim/chat-components-hooks/es/AttachmentBubble/useAttachmentBubble';
10
9
  /** ** Constants *** */
10
+
11
11
  import attachmentBubbleDefaultProps from './props/defaultProps';
12
12
  import attachmentBubblePropTypes from './props/propTypes';
13
-
14
- /** ** Methods *** */
15
- import renderHandler from '@zohoim/chat-components-utils/es/common/renderHandler';
16
- import cssJSLogic from './css/cssJSLogic';
17
-
18
13
  /** ** Styles *** */
19
- import style from './css/AttachmentBubble.module.css';
20
14
 
15
+ import style from './css/AttachmentBubble.module.css';
21
16
  /** ** Components *** */
17
+
22
18
  import AttachmentBubbleInfo from '../AttachmentBubbleInfo/AttachmentBubbleInfo';
19
+ import AttachmentIcon from '../AttachmentIcon/AttachmentIcon';
23
20
  import { Container, Box } from '@zohodesk/components/es/Layout';
24
21
  export default function AttachmentBubble(props) {
25
22
  const {
26
23
  customStyle,
27
- renderFileTypeIcon,
28
- fileName,
29
- fileSize,
30
- bubbleInfoCustomStyle
24
+ customProps,
25
+ attachmentDetails
31
26
  } = props;
27
+ const {
28
+ attachmentBubbleInfoProps,
29
+ attachmentIconProps
30
+ } = customProps;
31
+ /* External CSS Customization */
32
32
 
33
- /* External customization */
34
33
  const newStyle = useMergeStyle(style, customStyle);
35
- /* CSS classnames added based on logic */
36
34
  const {
37
- attachmentBubbleClass,
38
- attachmentBubbleIconClass,
39
- attachmentBubbleContentClass
40
- } = cssJSLogic(props, newStyle);
41
- const fileIcon = renderHandler(renderFileTypeIcon)();
35
+ formattedFileSize: fileSize,
36
+ fileName,
37
+ fileFormat
38
+ } = useAttachmentBubble({
39
+ attachmentDetails
40
+ });
42
41
  return /*#__PURE__*/React.createElement(Container, {
43
42
  alignBox: "row",
44
- className: attachmentBubbleClass
45
- }, /*#__PURE__*/React.createElement("div", {
46
- className: attachmentBubbleIconClass
47
- }, fileIcon), /*#__PURE__*/React.createElement(Box, {
48
- className: attachmentBubbleContentClass,
43
+ className: newStyle.attachmentBubble,
44
+ isCover: false
45
+ }, /*#__PURE__*/React.createElement(Box, {
46
+ className: newStyle.attachmentBubbleIcon
47
+ }, /*#__PURE__*/React.createElement(AttachmentIcon, _extends({
48
+ fileFormat: fileFormat
49
+ }, attachmentIconProps))), /*#__PURE__*/React.createElement(Box, {
50
+ className: newStyle.attachmentBubbleContent,
49
51
  flexible: true
50
- }, /*#__PURE__*/React.createElement(AttachmentBubbleInfo, {
51
- customStyle: bubbleInfoCustomStyle,
52
+ }, /*#__PURE__*/React.createElement(AttachmentBubbleInfo, _extends({
52
53
  fileName: fileName,
53
54
  fileSize: fileSize
54
- })));
55
+ }, attachmentBubbleInfoProps))));
55
56
  }
56
57
  AttachmentBubble.propTypes = attachmentBubblePropTypes;
57
58
  AttachmentBubble.defaultProps = attachmentBubbleDefaultProps;
@@ -1,24 +1,26 @@
1
1
  .attachmentBubble {
2
- background-color: var(--imlib_chat_components_attachmentBubble_bg_color);
3
- border-radius: var(--imlib_size_3);
4
- border: var(--imlib_size_1) solid var(--imlib_chat_components_attachmentBubble_border_color);
2
+ width: 100% ;
3
+ background-color: var(--imlib_chat_components_attachmentBubble_bg_color);
4
+ border-radius: 3px;
5
+ border: 1px solid var(--imlib_chat_components_attachmentBubble_border_color);
5
6
  }
6
7
 
7
- .attachmentBubbleIcon{
8
- width: var(--imlib_size_60);
9
- display: flex;
10
- align-items: center;
11
- justify-content: center;
8
+ .attachmentBubbleIcon {
9
+ width: var(--zd_size60) ;
10
+ display: flex;
11
+ align-items: center;
12
+ justify-content: center;
12
13
  }
13
14
 
14
- [dir=ltr] .attachmentBubbleIcon{
15
- border-right: var(--imlib_size_1) solid var(--imlib_chat_components_attachmentBubble_border_color);
15
+ [dir=ltr] .attachmentBubbleIcon {
16
+ border-right: 1px solid
17
+ var(--imlib_chat_components_attachmentBubble_border_color);
16
18
  }
17
19
 
18
- [dir=rtl] .attachmentBubbleIcon{
19
- border-left: var(--imlib_size_1) solid var(--imlib_chat_components_attachmentBubble_border_color);
20
+ [dir=rtl] .attachmentBubbleIcon {
21
+ border-left: 1px solid var(--imlib_chat_components_attachmentBubble_border_color);
20
22
  }
21
23
 
22
- .attachmentBubbleIcon, .attachmentBubbleContent{
23
- padding: var(--imlib_size_10);
24
- }
24
+ .attachmentBubbleIcon, .attachmentBubbleContent {
25
+ padding: var(--zd_size10) ;
26
+ }
@@ -1,7 +1,7 @@
1
1
  /** ** Constants *** */
2
- import { dummyObject } from '@zohoim/chat-components-utils/es/constants';
2
+ import { dummyObject } from '@zohoim/chat-components-utils/es/constants/emptyConstants';
3
3
  const attachmentBubbleDefaultProps = {
4
4
  customStyle: dummyObject,
5
- bubbleInfoCustomStyle: dummyObject
5
+ customProps: dummyObject
6
6
  };
7
7
  export default attachmentBubbleDefaultProps;
@@ -1,10 +1,15 @@
1
1
  /** ** Libraries *** */
2
2
  import PropTypes from 'prop-types';
3
3
  const attachmentBubblePropTypes = {
4
- customStyle: PropTypes.object,
5
- bubbleInfoCustomStyle: PropTypes.object,
6
- renderFileTypeIcon: PropTypes.func,
7
- fileName: PropTypes.string,
8
- fileSize: PropTypes.string
4
+ attachmentDetails: PropTypes.shape({
5
+ name: PropTypes.string.isRequired,
6
+ size: PropTypes.string.isRequired,
7
+ type: PropTypes.string.isRequired
8
+ }).isRequired,
9
+ customProps: PropTypes.shape({
10
+ attachmentBubbleInfoProps: PropTypes.object,
11
+ attachmentIconProps: PropTypes.object
12
+ }),
13
+ customStyle: PropTypes.object
9
14
  };
10
15
  export default attachmentBubblePropTypes;
@@ -1,20 +1,17 @@
1
- /* eslint-disable react/jsx-no-bind */
2
- /* eslint-disable max-len */
3
-
4
1
  /** ** Libraries *** */
5
2
  import React from 'react';
6
-
7
3
  /** ** Hooks *** */
8
- import useMergeStyle from '@zohodesk/hooks/es/utils/useMergeStyle';
9
4
 
5
+ import useMergeStyle from '@zohodesk/hooks/es/utils/useMergeStyle';
10
6
  /** ** Constants *** */
7
+
11
8
  import attachmentBubbleInfoDefaultProps from './props/defaultProps';
12
9
  import attachmentBubbleInfoPropTypes from './props/propTypes';
10
+ /** ** Components *** */
13
11
 
14
- /** ** Methods *** */
15
- import cssJSLogic from './css/cssJSLogic';
16
-
12
+ import { Container, Box } from '@zohodesk/components/es/Layout';
17
13
  /** ** Styles *** */
14
+
18
15
  import style from './css/AttachmentBubbleInfo.module.css';
19
16
  export default function AttachmentBubbleInfo(props) {
20
17
  const {
@@ -22,21 +19,16 @@ export default function AttachmentBubbleInfo(props) {
22
19
  fileName,
23
20
  fileSize
24
21
  } = props;
22
+ /* External css customization */
25
23
 
26
- /* External customization */
27
24
  const newStyle = useMergeStyle(style, customStyle);
28
- /* CSS classnames added based on logic */
29
- const {
30
- attachmentBubbleInfoClass,
31
- fileNameClass,
32
- fileSizeClass
33
- } = cssJSLogic(props, newStyle);
34
- return /*#__PURE__*/React.createElement("div", {
35
- className: attachmentBubbleInfoClass
36
- }, /*#__PURE__*/React.createElement("div", {
37
- className: fileNameClass
38
- }, fileName), /*#__PURE__*/React.createElement("div", {
39
- className: fileSizeClass
25
+ return /*#__PURE__*/React.createElement(Container, {
26
+ className: newStyle.attachmentBubbleInfo,
27
+ isCover: false
28
+ }, /*#__PURE__*/React.createElement(Box, {
29
+ className: newStyle.fileName
30
+ }, fileName), /*#__PURE__*/React.createElement(Box, {
31
+ className: newStyle.fileSize
40
32
  }, fileSize));
41
33
  }
42
34
  AttachmentBubbleInfo.propTypes = attachmentBubbleInfoPropTypes;
@@ -1,26 +1,29 @@
1
- .varClass{
2
- --attachmentBubbleInfo-fileName_font_size: var(--imlib_size_15);
3
- --attachmentBubbleInfo-fileName_font_family: var(--zd_semibold);
4
- --attachmentBubbleInfo-fileSize_font_size: var(--imlib_size_13);
1
+ .varClass {
2
+ --attachmentBubbleInfo-fileName_font_size: var(--zd_font_size15);
3
+ --attachmentBubbleInfo-fileName_font_family: var(--zd_semibold);
4
+ --attachmentBubbleInfo-fileSize_font_size: var(--zd_font_size13);
5
5
  }
6
6
 
7
7
  .fileName {
8
- composes: varClass;
9
- font-size: var(--attachmentBubbleInfo-fileName_font_size);
10
- font-family: var(--attachmentBubbleInfo-fileName_font_family);
11
- color: var(--imlib_chat_components_attachmentBubbleInfo_fileName_color);
12
- margin-bottom: var(--imlib_size_5);
8
+ composes: varClass;
9
+ font-size: var(--attachmentBubbleInfo-fileName_font_size);
10
+ font-family: var(--attachmentBubbleInfo-fileName_font_family);
11
+ color: var(--imlib_chat_components_attachmentBubbleInfo_fileName_color);
12
+ margin-bottom: var(--zd_size5) ;
13
13
  }
14
14
 
15
15
  .fileSize {
16
- composes: varClass;
17
- font-size: var(--attachmentBubbleInfo-fileSize_font_size);
18
- color: var(--imlib_chat_components_attachmentBubbleInfo_fileSize_color);
16
+ composes: varClass;
17
+ font-size: var(--attachmentBubbleInfo-fileSize_font_size);
18
+ color: var(--imlib_chat_components_attachmentBubbleInfo_fileSize_color);
19
19
  }
20
20
 
21
21
  .fileName,
22
- .fileSize{
23
- white-space: nowrap;
24
- overflow: hidden;
25
- text-overflow: ellipsis;
22
+ .fileSize {
23
+ composes: dotted from "../../css/common.module.css";
24
+ }
25
+
26
+ .attachmentBubbleInfo {
27
+ width: 100% ;
28
+ /* Use this class name for css customization */
26
29
  }
@@ -1,5 +1,5 @@
1
1
  /** ** Constants *** */
2
- import { dummyObject } from '@zohoim/chat-components-utils/es/constants';
2
+ import { dummyObject } from '@zohoim/chat-components-utils/es/constants/emptyConstants';
3
3
  const attachmentBubbleInfoDefaultProps = {
4
4
  customStyle: dummyObject
5
5
  };
@@ -1,8 +1,8 @@
1
1
  /** ** Libraries *** */
2
2
  import PropTypes from 'prop-types';
3
3
  const attachmentBubbleInfoPropTypes = {
4
- customStyle: PropTypes.object,
5
- fileName: PropTypes.string,
6
- fileSize: PropTypes.string
4
+ fileName: PropTypes.string.isRequired,
5
+ fileSize: PropTypes.string.isRequired,
6
+ customStyle: PropTypes.object
7
7
  };
8
8
  export default attachmentBubbleInfoPropTypes;
@@ -0,0 +1,47 @@
1
+ /** ** Libraries *** */
2
+ import React, { useMemo } from 'react';
3
+ /** ** Hooks *** */
4
+
5
+ import useMergeStyle from '@zohodesk/hooks/es/utils/useMergeStyle';
6
+ /** ** Constants *** */
7
+
8
+ import attachmentIconDefaultProps from './props/defaultProps';
9
+ import attachmentIconPropTypes from './props/propTypes';
10
+ /** ** Methods *** */
11
+
12
+ import getAttachmentIconComponent from './utils/getAttachmentIconComponent';
13
+ import renderHandler from '@zohoim/chat-components-utils/es/common/renderHandler';
14
+ /** ** Styles *** */
15
+
16
+ import style from './css/AttachmentIcon.module.css';
17
+ export default function AttachmentIcon(props) {
18
+ const {
19
+ customStyle,
20
+ fileFormat,
21
+ renderCustomIcon
22
+ } = props;
23
+ /* External CSS Customization */
24
+
25
+ const newStyle = useMergeStyle(style, customStyle);
26
+ const iconCustomStyle = useMemo(() => ({
27
+ base: newStyle.icon
28
+ }), [newStyle.icon]);
29
+ /* Custom Icon Renderer */
30
+
31
+ if (renderCustomIcon) {
32
+ const fileIcon = renderHandler(renderCustomIcon)();
33
+ return fileIcon;
34
+ }
35
+
36
+ const {
37
+ IconComponent
38
+ } = getAttachmentIconComponent({
39
+ fileFormat
40
+ });
41
+ return IconComponent ? /*#__PURE__*/React.createElement(IconComponent, {
42
+ customStyle: iconCustomStyle
43
+ }) : null;
44
+ }
45
+ AttachmentIcon.propTypes = attachmentIconPropTypes;
46
+ AttachmentIcon.defaultProps = attachmentIconDefaultProps;
47
+ AttachmentIcon.displayName = 'AttachmentIcon';
@@ -0,0 +1,4 @@
1
+ .icon {
2
+ width: var(--zd_size20) ;
3
+ height: var(--zd_size20) ;
4
+ }
@@ -0,0 +1 @@
1
+ export { default as AttachmentIcon } from './AttachmentIcon';