contentoh-components-library 21.4.68 → 21.4.70

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 (493) hide show
  1. package/dist/assets/images/Icons/infoNR.svg +8 -0
  2. package/dist/assets/images/flagsv2/highPriority.svg +3 -0
  3. package/dist/assets/images/flagsv2/lowPriority.svg +3 -0
  4. package/dist/assets/images/flagsv2/mediumPriority.svg +3 -0
  5. package/dist/assets/images/flagsv2/noPriority.svg +3 -0
  6. package/dist/assets/images/generalButton/closeIconWhite.svg +4 -0
  7. package/dist/assets/images/generalButton/closeIconv2.svg +4 -0
  8. package/dist/components/atoms/Avatar/index.js +3 -2
  9. package/dist/components/atoms/CharsMissing/Wysiwyg.stories.js +30 -0
  10. package/dist/components/atoms/CharsMissing/index.js +89 -0
  11. package/dist/components/atoms/CharsMissing/styles.js +33 -0
  12. package/dist/components/atoms/CheckBox/styles.js +1 -1
  13. package/dist/components/atoms/FeatureTagv2/FeatureTagv2.stories.js +32 -0
  14. package/dist/components/atoms/FeatureTagv2/index.js +29 -0
  15. package/dist/components/atoms/FeatureTagv2/styles.js +22 -0
  16. package/dist/components/atoms/GeneralButton/styles.js +6 -2
  17. package/dist/components/atoms/GeneralInputv2/GeneralInputv2.stories.js +50 -0
  18. package/dist/components/atoms/GeneralInputv2/index.js +188 -0
  19. package/dist/components/atoms/GeneralInputv2/styles.js +29 -0
  20. package/dist/components/atoms/ImageCarousel/ImgeSlider.stories.js +90 -0
  21. package/dist/components/atoms/ImageCarousel/index.js +120 -0
  22. package/dist/components/atoms/ImageCarousel/styles.js +18 -0
  23. package/dist/components/atoms/InputFormatter/styles.js +3 -3
  24. package/dist/components/atoms/InputFormatterv2/Wysiwyg.stories.js +30 -0
  25. package/dist/components/atoms/InputFormatterv2/index.js +182 -0
  26. package/dist/components/atoms/InputFormatterv2/styles.js +33 -0
  27. package/dist/components/atoms/InputImages/InputImages.stories.js +34 -0
  28. package/dist/components/atoms/InputImages/index.js +46 -0
  29. package/dist/components/atoms/InputImages/styles.js +20 -0
  30. package/dist/components/atoms/NumberMandatory/NumberMandatory.stories.js +34 -0
  31. package/dist/components/atoms/NumberMandatory/index.js +35 -0
  32. package/dist/components/atoms/NumberMandatory/styles.js +20 -0
  33. package/dist/components/atoms/PercentTag/PercentTag.stories.js +31 -0
  34. package/dist/components/atoms/PercentTag/index.js +23 -0
  35. package/dist/components/atoms/PercentTag/styles.js +22 -0
  36. package/dist/components/atoms/PriorityFlagv2/PriorityFlagv2.stories.js +38 -0
  37. package/dist/components/atoms/PriorityFlagv2/index.js +37 -0
  38. package/dist/components/atoms/PriorityFlagv2/styles.js +18 -0
  39. package/dist/components/atoms/ProductImagev2/ProductImagev2.stories.js +39 -0
  40. package/dist/components/atoms/ProductImagev2/index.js +34 -0
  41. package/dist/components/atoms/ProductImagev2/styles.js +18 -0
  42. package/dist/components/atoms/Progress/Progress.stories.js +49 -0
  43. package/dist/components/atoms/Progress/index.js +74 -0
  44. package/dist/components/atoms/Progress/styles.js +30 -0
  45. package/dist/components/atoms/RatingStars/RatingStars.stories.js +30 -0
  46. package/dist/components/atoms/RatingStars/index.js +53 -0
  47. package/dist/components/atoms/RatingStars/styles.js +18 -0
  48. package/dist/components/atoms/RetailerCatalog/RetailerCatalog.stories.js +48 -0
  49. package/dist/components/atoms/RetailerCatalog/index.js +69 -0
  50. package/dist/components/atoms/RetailerCatalog/styles.js +20 -0
  51. package/dist/components/atoms/RetailerOption/RetailerOption.stories.js +33 -0
  52. package/dist/components/atoms/RetailerOption/index.js +62 -0
  53. package/dist/components/atoms/RetailerOption/styles.js +20 -0
  54. package/dist/components/atoms/RetailersList/RetailersList.stories.js +45 -0
  55. package/dist/components/atoms/RetailersList/index.js +46 -0
  56. package/dist/components/atoms/RetailersList/styles.js +18 -0
  57. package/dist/components/atoms/ScreenHeaderv2/ScreenHeaderv2.stories.js +67 -0
  58. package/dist/components/atoms/ScreenHeaderv2/index.js +169 -0
  59. package/dist/components/atoms/ScreenHeaderv2/styles.js +40 -0
  60. package/dist/components/atoms/Selectv2/VersionSelect.js +38 -0
  61. package/dist/components/atoms/Selectv2/index.js +40 -0
  62. package/dist/components/atoms/Selectv2/style.js +38 -0
  63. package/dist/components/atoms/SliderToolTip/styles.js +1 -1
  64. package/dist/components/atoms/TabSectionv2/TabSection.stories.js +39 -0
  65. package/dist/components/atoms/TabSectionv2/index.js +26 -0
  66. package/dist/components/atoms/TabSectionv2/styles.js +20 -0
  67. package/dist/components/atoms/TooltipLight/Tooltip.stories.js +36 -0
  68. package/dist/components/atoms/TooltipLight/index.js +117 -0
  69. package/dist/components/atoms/TooltipLight/styles.js +23 -0
  70. package/dist/components/atoms/UserCatalog/UserCatalog.stories.js +73 -0
  71. package/dist/components/atoms/UserCatalog/index.js +101 -0
  72. package/dist/components/atoms/UserCatalog/styles.js +18 -0
  73. package/dist/components/atoms/UserOption/UserOption.stories.js +40 -0
  74. package/dist/components/atoms/UserOption/index.js +130 -0
  75. package/dist/components/atoms/UserOption/styles.js +20 -0
  76. package/dist/components/atoms/UserSelector/UserSelector.stories.js +40 -0
  77. package/dist/components/atoms/UserSelector/index.js +98 -0
  78. package/dist/components/atoms/UserSelector/styles.js +32 -0
  79. package/dist/components/atoms/WordsMissing/Wysiwyg.stories.js +30 -0
  80. package/dist/components/atoms/WordsMissing/index.js +89 -0
  81. package/dist/components/atoms/WordsMissing/styles.js +20 -0
  82. package/dist/components/molecules/AsignationInfo/AsignationInfo.stories.js +34 -0
  83. package/dist/components/molecules/AsignationInfo/index.js +137 -0
  84. package/dist/components/molecules/AsignationInfo/styles.js +20 -0
  85. package/dist/components/molecules/BoxAttribute/index.js +3 -3
  86. package/dist/components/molecules/BoxAttribute/styles.js +1 -1
  87. package/dist/components/molecules/BoxButtons/index.js +0 -1
  88. package/dist/components/molecules/CarouselImagesLogin/index.js +1 -1
  89. package/dist/components/molecules/EditionActiveImagev2/EditionActiveImagev2.stories.js +28 -0
  90. package/dist/components/molecules/EditionActiveImagev2/index.js +34 -0
  91. package/dist/components/molecules/EditionActiveImagev2/styles.js +18 -0
  92. package/dist/components/molecules/FeaturesBarv2/FeaturesBarv2.stories.js +45 -0
  93. package/dist/components/molecules/FeaturesBarv2/index.js +49 -0
  94. package/dist/components/molecules/FeaturesBarv2/styles.js +18 -0
  95. package/dist/components/molecules/GalleryElement/index.js +16 -12
  96. package/dist/components/molecules/GalleryElement/styles.js +1 -1
  97. package/dist/components/molecules/GalleryElementv2/GalleryElementv2.stories.js +45 -0
  98. package/dist/components/molecules/GalleryElementv2/index.js +164 -0
  99. package/dist/components/molecules/GalleryElementv2/styles.js +20 -0
  100. package/dist/components/molecules/GalleryHeader/index.js +3 -0
  101. package/dist/components/molecules/GalleryHeader/styles.js +1 -1
  102. package/dist/components/molecules/GalleryHeaderv2/GalleryHeaderv2.stories.js +28 -0
  103. package/dist/components/molecules/GalleryHeaderv2/index.js +61 -0
  104. package/dist/components/molecules/GalleryHeaderv2/styles.js +20 -0
  105. package/dist/components/molecules/GridItem/GridItem.stories.js +123 -0
  106. package/dist/components/molecules/GridItem/index.js +152 -0
  107. package/dist/components/molecules/GridItem/styles.js +20 -0
  108. package/dist/components/molecules/HeaderItem/ColumnItem.js +23 -0
  109. package/dist/components/molecules/HeaderItem/HeaderItem.stories.js +70 -0
  110. package/dist/components/molecules/HeaderItem/index.js +42 -0
  111. package/dist/components/molecules/HeaderItem/styles.js +30 -0
  112. package/dist/components/molecules/HeaderTop/index.js +68 -11
  113. package/dist/components/molecules/HeaderTopv2/HeaderTopv2.stories.js +27 -0
  114. package/dist/components/molecules/HeaderTopv2/index.js +123 -0
  115. package/dist/components/molecules/HeaderTopv2/styles.js +18 -0
  116. package/dist/components/molecules/ImageSelectorv2/ImageSelectorv2.stories.js +55 -0
  117. package/dist/components/molecules/ImageSelectorv2/index.js +36 -0
  118. package/dist/components/molecules/ImageSelectorv2/styles.js +18 -0
  119. package/dist/components/molecules/Phase/Phase.stories.js +65 -0
  120. package/dist/components/molecules/Phase/index.js +104 -0
  121. package/dist/components/molecules/Phase/styles.js +24 -0
  122. package/dist/components/molecules/ProductNameHeaderv2/ProductNameHeaderv2.stories.js +65 -0
  123. package/dist/components/molecules/ProductNameHeaderv2/index.js +24 -0
  124. package/dist/components/molecules/ProductNameHeaderv2/styles.js +18 -0
  125. package/dist/components/molecules/ProductSkuStatus/ProductSkuStatus.stories.js +65 -0
  126. package/dist/components/molecules/ProductSkuStatus/index.js +36 -0
  127. package/dist/components/molecules/ProductSkuStatus/styles.js +18 -0
  128. package/dist/components/molecules/RetailerSelectorv2/RetailerSelectorv2.stories.js +48 -0
  129. package/dist/components/molecules/RetailerSelectorv2/index.js +109 -0
  130. package/dist/components/molecules/RetailerSelectorv2/styles.js +20 -0
  131. package/dist/components/molecules/RowItem/ColumnItem.js +23 -0
  132. package/dist/components/molecules/RowItem/RowItem.stories.js +5242 -0
  133. package/dist/components/molecules/RowItem/index.js +58 -0
  134. package/dist/components/molecules/RowItem/styles.js +30 -0
  135. package/dist/components/molecules/ServiceDataValidator/ServiceDataValidator.stories.js +99 -0
  136. package/dist/components/molecules/ServiceDataValidator/index.js +57 -0
  137. package/dist/components/molecules/ServiceDataValidator/styles.js +20 -0
  138. package/dist/components/molecules/SignInLogin/index.js +36 -28
  139. package/dist/components/molecules/StatusRetailer/StatusAsignationInfo.stories.js +34 -0
  140. package/dist/components/molecules/StatusRetailer/index.js +74 -0
  141. package/dist/components/molecules/StatusRetailer/styles.js +20 -0
  142. package/dist/components/molecules/StripeCardSelector/CardSelector.stories.js +1 -2
  143. package/dist/components/molecules/TabsMenuv2/TabsMenuv2.stories.js +35 -0
  144. package/dist/components/molecules/TabsMenuv2/index.js +145 -0
  145. package/dist/components/molecules/TabsMenuv2/styles.js +18 -0
  146. package/dist/components/molecules/TagAndInputv2/TagAndInputv2.stories.js +41 -0
  147. package/dist/components/molecules/TagAndInputv2/index.js +92 -0
  148. package/dist/components/molecules/TagAndInputv2/styles.js +29 -0
  149. package/dist/components/molecules/Validation/Validation.stories.js +28 -0
  150. package/dist/components/molecules/Validation/index.js +89 -0
  151. package/dist/components/molecules/Validation/styles.js +18 -0
  152. package/dist/components/molecules/VersionItemv2/VersionItemv2.stories.js +28 -0
  153. package/dist/components/molecules/VersionItemv2/index.js +74 -0
  154. package/dist/components/molecules/VersionItemv2/styles.js +20 -0
  155. package/dist/components/organisms/BarButtons/BarButtons.stories.js +30 -0
  156. package/dist/components/organisms/BarButtons/index.js +186 -0
  157. package/dist/components/organisms/BarButtons/styles.js +24 -0
  158. package/dist/components/organisms/Chat/Chat.stories.js +27 -8
  159. package/dist/components/organisms/Chat/ContainerItems/index.js +19 -3
  160. package/dist/components/organisms/Chat/ContainerItems/styles.js +1 -1
  161. package/dist/components/organisms/Chat/ContentChat/index.js +350 -197
  162. package/dist/components/organisms/Chat/Footer/index.js +48 -39
  163. package/dist/components/organisms/Chat/index.js +49 -4
  164. package/dist/components/organisms/Chat/styles.js +1 -1
  165. package/dist/components/organisms/Chatv2/ChatLists/ChatLists.stories.js +83 -0
  166. package/dist/components/organisms/Chatv2/ChatLists/index.js +160 -0
  167. package/dist/components/organisms/Chatv2/ChatLists/styles.js +29 -0
  168. package/dist/components/organisms/Chatv2/Chatv2.stories.js +194 -0
  169. package/dist/components/organisms/Chatv2/ContainerItems/ContainerItems.stories.js +176 -0
  170. package/dist/components/organisms/Chatv2/ContainerItems/index.js +556 -0
  171. package/dist/components/organisms/Chatv2/ContainerItems/styles.js +20 -0
  172. package/dist/components/organisms/Chatv2/ContentChat/ContentChat.stories.js +142 -0
  173. package/dist/components/organisms/Chatv2/ContentChat/index.js +1679 -0
  174. package/dist/components/organisms/Chatv2/ContentChat/styles.js +20 -0
  175. package/dist/components/organisms/Chatv2/Footer/Footer.stories.js +43 -0
  176. package/dist/components/organisms/Chatv2/Footer/index.js +984 -0
  177. package/dist/components/organisms/Chatv2/Footer/styles.js +32 -0
  178. package/dist/components/organisms/Chatv2/Header/Header.stories.js +96 -0
  179. package/dist/components/organisms/Chatv2/Header/index.js +83 -0
  180. package/dist/components/organisms/Chatv2/Header/styles.js +20 -0
  181. package/dist/components/organisms/Chatv2/index.js +306 -0
  182. package/dist/components/organisms/Chatv2/styles.js +34 -0
  183. package/dist/components/organisms/CompleteServices/CompleteServices.stories.js +100 -0
  184. package/dist/components/organisms/CompleteServices/index.js +93 -0
  185. package/dist/components/organisms/CompleteServices/styles.js +20 -0
  186. package/dist/components/organisms/DashboardMetric/index.js +12 -6
  187. package/dist/components/organisms/DragAndDropPhases/DragAndDropPhases.stories.js +28 -0
  188. package/dist/components/organisms/DragAndDropPhases/index.js +110 -0
  189. package/dist/components/organisms/DragAndDropPhases/styles.js +20 -0
  190. package/dist/components/organisms/DragPrueba/DragPrueba.stories.js +28 -0
  191. package/dist/components/organisms/DragPrueba/index.js +95 -0
  192. package/dist/components/organisms/DragPrueba/styles.js +20 -0
  193. package/dist/components/organisms/FullProductNameHeader/index.js +2 -2
  194. package/dist/components/organisms/FullProductNamev2/FullProductNamev2.stories.js +54 -0
  195. package/dist/components/organisms/FullProductNamev2/index.js +112 -0
  196. package/dist/components/organisms/FullProductNamev2/styles.js +20 -0
  197. package/dist/components/organisms/FullTabsMenuv2/FullTabsMenuv2.stories.js +39 -0
  198. package/dist/components/organisms/FullTabsMenuv2/index.js +168 -0
  199. package/dist/components/organisms/FullTabsMenuv2/styles.js +18 -0
  200. package/dist/components/organisms/GridProducts/GridProducts.stories.js +5097 -0
  201. package/dist/components/organisms/GridProducts/index.js +63 -0
  202. package/dist/components/organisms/GridProducts/styles.js +18 -0
  203. package/dist/components/organisms/GridProducts/utils.js +149 -0
  204. package/dist/components/organisms/ImageDataTablev2/ImageDataTablev2.stories.js +50 -0
  205. package/dist/components/organisms/ImageDataTablev2/index.js +128 -0
  206. package/dist/components/organisms/ImageDataTablev2/styles.js +26 -0
  207. package/dist/components/organisms/ImagePreviewerv2/ImagePreviewerv2.stories.js +48 -0
  208. package/dist/components/organisms/ImagePreviewerv2/index.js +36 -0
  209. package/dist/components/organisms/ImagePreviewerv2/styles.js +18 -0
  210. package/dist/components/organisms/InputGroup/index.js +1 -10
  211. package/dist/components/organisms/InputGroupv2/InputGroupv2.stories.js +73 -0
  212. package/dist/components/organisms/InputGroupv2/index.js +228 -0
  213. package/dist/components/organisms/InputGroupv2/styles.js +28 -0
  214. package/dist/components/organisms/MandatoryBar/MandatoryBar.stories.js +31 -0
  215. package/dist/components/organisms/MandatoryBar/index.js +38 -0
  216. package/dist/components/organisms/MandatoryBar/styles.js +20 -0
  217. package/dist/components/organisms/Modal/styles.js +1 -1
  218. package/dist/components/organisms/ProductImageModalv2/ProductImageModalv2.stories.js +153 -0
  219. package/dist/components/organisms/ProductImageModalv2/index.js +106 -0
  220. package/dist/components/organisms/ProductImageModalv2/styles.js +20 -0
  221. package/dist/components/organisms/RenameImagesBar/RenameImagesBar.stories.js +31 -0
  222. package/dist/components/organisms/RenameImagesBar/index.js +38 -0
  223. package/dist/components/organisms/RenameImagesBar/styles.js +20 -0
  224. package/dist/components/organisms/VersionSelector/index.js +2 -4
  225. package/dist/components/organisms/VersionSelectorv2/VersionSelectorv2.stories.js +32 -0
  226. package/dist/components/organisms/VersionSelectorv2/index.js +166 -0
  227. package/dist/components/organisms/VersionSelectorv2/styles.js +20 -0
  228. package/dist/components/pages/Dashboard/Dashboard.stories.js +33 -36
  229. package/dist/components/pages/Dashboard/index.js +37 -9
  230. package/dist/components/pages/ProductEditionv2/ProductEditionv2.stories.js +222 -0
  231. package/dist/components/pages/ProductEditionv2/index.js +2495 -0
  232. package/dist/components/pages/ProductEditionv2/styles.js +23 -0
  233. package/dist/components/pages/ProviderProductEdition/ProviderProductEdition.stories.js +3 -3
  234. package/dist/components/pages/ProviderProductEdition/index.js +120 -144
  235. package/dist/components/pages/ProviderProductEdition/styles.js +1 -1
  236. package/dist/components/pages/RetailerProductEdition/RetailerProductEdition.stories.js +7 -3
  237. package/dist/components/pages/RetailerProductEdition/index.js +279 -274
  238. package/dist/components/pages/RetailerProductEdition/styles.js +1 -1
  239. package/dist/components/pages/RetailerProductEdition/utils.js +61 -2
  240. package/dist/global-files/data.js +11 -3
  241. package/dist/global-files/variables.js +7 -1
  242. package/dist/index.js +201 -58
  243. package/package.json +2 -3
  244. package/src/assets/images/Icons/infoNR.svg +8 -0
  245. package/src/assets/images/flagsv2/highPriority.svg +3 -0
  246. package/src/assets/images/flagsv2/lowPriority.svg +3 -0
  247. package/src/assets/images/flagsv2/mediumPriority.svg +3 -0
  248. package/src/assets/images/flagsv2/noPriority.svg +3 -0
  249. package/src/assets/images/generalButton/closeIconWhite.svg +4 -0
  250. package/src/assets/images/generalButton/closeIconv2.svg +4 -0
  251. package/src/components/atoms/Avatar/index.js +8 -2
  252. package/src/components/atoms/CharsMissing/Wysiwyg.stories.js +12 -0
  253. package/src/components/atoms/CharsMissing/index.js +60 -0
  254. package/src/components/atoms/CharsMissing/styles.js +44 -0
  255. package/src/components/atoms/CheckBox/styles.js +2 -0
  256. package/src/components/atoms/FeatureTagv2/FeatureTagv2.stories.js +16 -0
  257. package/src/components/atoms/FeatureTagv2/index.js +10 -0
  258. package/src/components/atoms/FeatureTagv2/styles.js +56 -0
  259. package/src/components/atoms/GeneralButton/styles.js +46 -0
  260. package/src/components/atoms/GeneralInputv2/GeneralInputv2.stories.js +33 -0
  261. package/src/components/atoms/GeneralInputv2/index.js +155 -0
  262. package/src/components/atoms/GeneralInputv2/styles.js +67 -0
  263. package/src/components/atoms/ImageCarousel/ImgeSlider.stories.js +76 -0
  264. package/src/components/atoms/ImageCarousel/index.js +103 -0
  265. package/src/components/atoms/ImageCarousel/styles.js +79 -0
  266. package/src/components/atoms/InputFormatter/styles.js +9 -4
  267. package/src/components/atoms/InputFormatterv2/Wysiwyg.stories.js +12 -0
  268. package/src/components/atoms/InputFormatterv2/index.js +148 -0
  269. package/src/components/atoms/InputFormatterv2/styles.js +39 -0
  270. package/src/components/atoms/InputImages/InputImages.stories.js +19 -0
  271. package/src/components/atoms/InputImages/index.js +25 -0
  272. package/src/components/atoms/InputImages/styles.js +17 -0
  273. package/src/components/atoms/NumberMandatory/NumberMandatory.stories.js +19 -0
  274. package/src/components/atoms/NumberMandatory/index.js +16 -0
  275. package/src/components/atoms/NumberMandatory/styles.js +11 -0
  276. package/src/components/atoms/PercentTag/PercentTag.stories.js +7 -0
  277. package/src/components/atoms/PercentTag/index.js +9 -0
  278. package/src/components/atoms/PercentTag/styles.js +69 -0
  279. package/src/components/atoms/PriorityFlagv2/PriorityFlagv2.stories.js +20 -0
  280. package/src/components/atoms/PriorityFlagv2/index.js +20 -0
  281. package/src/components/atoms/PriorityFlagv2/styles.js +6 -0
  282. package/src/components/atoms/ProductImagev2/ProductImagev2.stories.js +28 -0
  283. package/src/components/atoms/ProductImagev2/index.js +16 -0
  284. package/src/components/atoms/ProductImagev2/styles.js +62 -0
  285. package/src/components/atoms/Progress/Progress.stories.js +25 -0
  286. package/src/components/atoms/Progress/index.js +74 -0
  287. package/src/components/atoms/Progress/styles.js +98 -0
  288. package/src/components/atoms/RatingStars/RatingStars.stories.js +10 -0
  289. package/src/components/atoms/RatingStars/index.js +31 -0
  290. package/src/components/atoms/RatingStars/styles.js +28 -0
  291. package/src/components/atoms/RetailerCatalog/RetailerCatalog.stories.js +36 -0
  292. package/src/components/atoms/RetailerCatalog/index.js +49 -0
  293. package/src/components/atoms/RetailerCatalog/styles.js +30 -0
  294. package/src/components/atoms/RetailerOption/RetailerOption.stories.js +15 -0
  295. package/src/components/atoms/RetailerOption/index.js +53 -0
  296. package/src/components/atoms/RetailerOption/styles.js +41 -0
  297. package/src/components/atoms/RetailersList/RetailersList.stories.js +33 -0
  298. package/src/components/atoms/RetailersList/index.js +20 -0
  299. package/src/components/atoms/RetailersList/styles.js +19 -0
  300. package/src/components/atoms/ScreenHeaderv2/ScreenHeaderv2.stories.js +53 -0
  301. package/src/components/atoms/ScreenHeaderv2/index.js +134 -0
  302. package/src/components/atoms/ScreenHeaderv2/styles.js +103 -0
  303. package/src/components/atoms/Selectv2/VersionSelect.js +27 -0
  304. package/src/components/atoms/Selectv2/index.js +35 -0
  305. package/src/components/atoms/Selectv2/style.js +93 -0
  306. package/src/components/atoms/SliderToolTip/styles.js +1 -1
  307. package/src/components/atoms/TabSection/index.js +1 -1
  308. package/src/components/atoms/TabSection/styles.js +1 -1
  309. package/src/components/atoms/TabSectionv2/TabSection.stories.js +25 -0
  310. package/src/components/atoms/TabSectionv2/index.js +9 -0
  311. package/src/components/atoms/TabSectionv2/styles.js +20 -0
  312. package/src/components/atoms/TooltipLight/Tooltip.stories.js +20 -0
  313. package/src/components/atoms/TooltipLight/index.js +46 -0
  314. package/src/components/atoms/TooltipLight/styles.js +65 -0
  315. package/src/components/atoms/UserCatalog/UserCatalog.stories.js +67 -0
  316. package/src/components/atoms/UserCatalog/index.js +100 -0
  317. package/src/components/atoms/UserCatalog/styles.js +24 -0
  318. package/src/components/atoms/UserOption/UserOption.stories.js +25 -0
  319. package/src/components/atoms/UserOption/index.js +95 -0
  320. package/src/components/atoms/UserOption/styles.js +61 -0
  321. package/src/components/atoms/UserSelector/UserSelector.stories.js +25 -0
  322. package/src/components/atoms/UserSelector/index.js +86 -0
  323. package/src/components/atoms/UserSelector/styles.js +55 -0
  324. package/src/components/atoms/WordsMissing/Wysiwyg.stories.js +12 -0
  325. package/src/components/atoms/WordsMissing/index.js +60 -0
  326. package/src/components/atoms/WordsMissing/styles.js +10 -0
  327. package/src/components/molecules/AsignationInfo/AsignationInfo.stories.js +17 -0
  328. package/src/components/molecules/AsignationInfo/index.js +108 -0
  329. package/src/components/molecules/AsignationInfo/styles.js +86 -0
  330. package/src/components/molecules/BoxAttribute/index.js +32 -25
  331. package/src/components/molecules/BoxAttribute/styles.js +1 -1
  332. package/src/components/molecules/BoxButtons/index.js +23 -22
  333. package/src/components/molecules/CarouselImagesLogin/index.js +1 -1
  334. package/src/components/molecules/EditionActiveImagev2/EditionActiveImagev2.stories.js +12 -0
  335. package/src/components/molecules/EditionActiveImagev2/index.js +15 -0
  336. package/src/components/molecules/EditionActiveImagev2/styles.js +7 -0
  337. package/src/components/molecules/FeaturesBarv2/FeaturesBarv2.stories.js +20 -0
  338. package/src/components/molecules/FeaturesBarv2/index.js +32 -0
  339. package/src/components/molecules/FeaturesBarv2/styles.js +17 -0
  340. package/src/components/molecules/GalleryElement/index.js +14 -8
  341. package/src/components/molecules/GalleryElement/styles.js +7 -0
  342. package/src/components/molecules/GalleryElementv2/GalleryElementv2.stories.js +30 -0
  343. package/src/components/molecules/GalleryElementv2/index.js +142 -0
  344. package/src/components/molecules/GalleryElementv2/styles.js +119 -0
  345. package/src/components/molecules/GalleryHeader/index.js +1 -0
  346. package/src/components/molecules/GalleryHeader/styles.js +4 -0
  347. package/src/components/molecules/GalleryHeaderv2/GalleryHeaderv2.stories.js +10 -0
  348. package/src/components/molecules/GalleryHeaderv2/index.js +25 -0
  349. package/src/components/molecules/GalleryHeaderv2/styles.js +47 -0
  350. package/src/components/molecules/GridItem/GridItem.stories.js +126 -0
  351. package/src/components/molecules/GridItem/index.js +105 -0
  352. package/src/components/molecules/GridItem/styles.js +104 -0
  353. package/src/components/molecules/HeaderItem/ColumnItem.js +9 -0
  354. package/src/components/molecules/HeaderItem/HeaderItem.stories.js +24 -0
  355. package/src/components/molecules/HeaderItem/index.js +26 -0
  356. package/src/components/molecules/HeaderItem/styles.js +27 -0
  357. package/src/components/molecules/HeaderTop/index.js +52 -6
  358. package/src/components/molecules/HeaderTopv2/HeaderTopv2.stories.js +10 -0
  359. package/src/components/molecules/HeaderTopv2/index.js +100 -0
  360. package/src/components/molecules/HeaderTopv2/styles.js +33 -0
  361. package/src/components/molecules/ImageSelectorv2/ImageSelectorv2.stories.js +46 -0
  362. package/src/components/molecules/ImageSelectorv2/index.js +22 -0
  363. package/src/components/molecules/ImageSelectorv2/styles.js +15 -0
  364. package/src/components/molecules/Phase/Phase.stories.js +37 -0
  365. package/src/components/molecules/Phase/index.js +56 -0
  366. package/src/components/molecules/Phase/styles.js +82 -0
  367. package/src/components/molecules/ProductNameHeaderv2/ProductNameHeaderv2.stories.js +37 -0
  368. package/src/components/molecules/ProductNameHeaderv2/index.js +12 -0
  369. package/src/components/molecules/ProductNameHeaderv2/styles.js +10 -0
  370. package/src/components/molecules/ProductSkuStatus/ProductSkuStatus.stories.js +37 -0
  371. package/src/components/molecules/ProductSkuStatus/index.js +26 -0
  372. package/src/components/molecules/ProductSkuStatus/styles.js +7 -0
  373. package/src/components/molecules/RetailerSelectorv2/RetailerSelectorv2.stories.js +35 -0
  374. package/src/components/molecules/RetailerSelectorv2/index.js +80 -0
  375. package/src/components/molecules/RetailerSelectorv2/styles.js +21 -0
  376. package/src/components/molecules/RowItem/ColumnItem.js +9 -0
  377. package/src/components/molecules/RowItem/RowItem.stories.js +5660 -0
  378. package/src/components/molecules/RowItem/index.js +45 -0
  379. package/src/components/molecules/RowItem/styles.js +40 -0
  380. package/src/components/molecules/ServiceDataValidator/ServiceDataValidator.stories.js +90 -0
  381. package/src/components/molecules/ServiceDataValidator/index.js +49 -0
  382. package/src/components/molecules/ServiceDataValidator/styles.js +36 -0
  383. package/src/components/molecules/SignInLogin/index.js +11 -11
  384. package/src/components/molecules/StatusRetailer/StatusAsignationInfo.stories.js +17 -0
  385. package/src/components/molecules/StatusRetailer/index.js +55 -0
  386. package/src/components/molecules/StatusRetailer/styles.js +85 -0
  387. package/src/components/molecules/StripeCardSelector/CardSelector.stories.js +1 -2
  388. package/src/components/molecules/TabsMenuv2/TabsMenuv2.stories.js +19 -0
  389. package/src/components/molecules/TabsMenuv2/index.js +112 -0
  390. package/src/components/molecules/TabsMenuv2/styles.js +19 -0
  391. package/src/components/molecules/TagAndInput/index.js +6 -5
  392. package/src/components/molecules/TagAndInputv2/TagAndInputv2.stories.js +24 -0
  393. package/src/components/molecules/TagAndInputv2/index.js +86 -0
  394. package/src/components/molecules/TagAndInputv2/styles.js +35 -0
  395. package/src/components/molecules/Validation/Validation.stories.js +12 -0
  396. package/src/components/molecules/Validation/index.js +77 -0
  397. package/src/components/molecules/Validation/styles.js +19 -0
  398. package/src/components/molecules/VersionItemv2/VersionItemv2.stories.js +14 -0
  399. package/src/components/molecules/VersionItemv2/index.js +59 -0
  400. package/src/components/molecules/VersionItemv2/styles.js +47 -0
  401. package/src/components/organisms/BarButtons/BarButtons.stories.js +13 -0
  402. package/src/components/organisms/BarButtons/index.js +150 -0
  403. package/src/components/organisms/BarButtons/styles.js +54 -0
  404. package/src/components/organisms/Chat/Chat.stories.js +27 -7
  405. package/src/components/organisms/Chat/ContainerItems/index.js +18 -2
  406. package/src/components/organisms/Chat/ContainerItems/styles.js +14 -2
  407. package/src/components/organisms/Chat/ContentChat/index.js +88 -12
  408. package/src/components/organisms/Chat/Footer/index.js +11 -0
  409. package/src/components/organisms/Chat/index.js +46 -4
  410. package/src/components/organisms/Chat/styles.js +4 -0
  411. package/src/components/organisms/Chatv2/ChatLists/ChatLists.stories.js +65 -0
  412. package/src/components/organisms/Chatv2/ChatLists/Rotoplas.jpeg +0 -0
  413. package/src/components/organisms/Chatv2/ChatLists/THD.png +0 -0
  414. package/src/components/organisms/Chatv2/ChatLists/index.js +141 -0
  415. package/src/components/organisms/Chatv2/ChatLists/styles.js +162 -0
  416. package/src/components/organisms/Chatv2/Chatv2.stories.js +184 -0
  417. package/src/components/organisms/Chatv2/ContainerItems/ContainerItems.stories.js +142 -0
  418. package/src/components/organisms/Chatv2/ContainerItems/index.js +538 -0
  419. package/src/components/organisms/Chatv2/ContainerItems/styles.js +360 -0
  420. package/src/components/organisms/Chatv2/ContentChat/ContentChat.stories.js +102 -0
  421. package/src/components/organisms/Chatv2/ContentChat/Rotoplas.jpeg +0 -0
  422. package/src/components/organisms/Chatv2/ContentChat/THD.png +0 -0
  423. package/src/components/organisms/Chatv2/ContentChat/index.js +1016 -0
  424. package/src/components/organisms/Chatv2/ContentChat/styles.js +44 -0
  425. package/src/components/organisms/Chatv2/Footer/Footer.stories.js +22 -0
  426. package/src/components/organisms/Chatv2/Footer/index.js +668 -0
  427. package/src/components/organisms/Chatv2/Footer/styles.js +290 -0
  428. package/src/components/organisms/Chatv2/Header/Header.stories.js +66 -0
  429. package/src/components/organisms/Chatv2/Header/index.js +93 -0
  430. package/src/components/organisms/Chatv2/Header/styles.js +49 -0
  431. package/src/components/organisms/Chatv2/index.js +281 -0
  432. package/src/components/organisms/Chatv2/styles.js +85 -0
  433. package/src/components/organisms/CompleteServices/CompleteServices.stories.js +91 -0
  434. package/src/components/organisms/CompleteServices/index.js +82 -0
  435. package/src/components/organisms/CompleteServices/styles.js +35 -0
  436. package/src/components/organisms/DashboardMetric/index.js +6 -3
  437. package/src/components/organisms/DragAndDropPhases/DragAndDropPhases.stories.js +12 -0
  438. package/src/components/organisms/DragAndDropPhases/index.js +67 -0
  439. package/src/components/organisms/DragAndDropPhases/styles.js +20 -0
  440. package/src/components/organisms/DragPrueba/DragPrueba.stories.js +12 -0
  441. package/src/components/organisms/DragPrueba/index.js +57 -0
  442. package/src/components/organisms/DragPrueba/styles.js +8 -0
  443. package/src/components/organisms/FullProductNameHeader/index.js +1 -1
  444. package/src/components/organisms/FullProductNamev2/FullProductNamev2.stories.js +28 -0
  445. package/src/components/organisms/FullProductNamev2/index.js +101 -0
  446. package/src/components/organisms/FullProductNamev2/styles.js +49 -0
  447. package/src/components/organisms/FullTabsMenuv2/FullTabsMenuv2.stories.js +22 -0
  448. package/src/components/organisms/FullTabsMenuv2/index.js +142 -0
  449. package/src/components/organisms/FullTabsMenuv2/styles.js +47 -0
  450. package/src/components/organisms/GridProducts/GridProducts.stories.js +5485 -0
  451. package/src/components/organisms/GridProducts/index.js +50 -0
  452. package/src/components/organisms/GridProducts/styles.js +14 -0
  453. package/src/components/organisms/GridProducts/utils.js +111 -0
  454. package/src/components/organisms/ImageDataTablev2/ImageDataTablev2.stories.js +24 -0
  455. package/src/components/organisms/ImageDataTablev2/index.js +124 -0
  456. package/src/components/organisms/ImageDataTablev2/styles.js +18 -0
  457. package/src/components/organisms/ImagePreviewerv2/ImagePreviewerv2.stories.js +38 -0
  458. package/src/components/organisms/ImagePreviewerv2/index.js +22 -0
  459. package/src/components/organisms/ImagePreviewerv2/styles.js +7 -0
  460. package/src/components/organisms/InputGroup/index.js +131 -119
  461. package/src/components/organisms/InputGroupv2/InputGroupv2.stories.js +31 -0
  462. package/src/components/organisms/InputGroupv2/index.js +296 -0
  463. package/src/components/organisms/InputGroupv2/styles.js +90 -0
  464. package/src/components/organisms/MandatoryBar/MandatoryBar.stories.js +18 -0
  465. package/src/components/organisms/MandatoryBar/index.js +31 -0
  466. package/src/components/organisms/MandatoryBar/styles.js +12 -0
  467. package/src/components/organisms/Modal/styles.js +4 -1
  468. package/src/components/organisms/OrderDetail/utils/Table/utils.js +6 -16
  469. package/src/components/organisms/ProductImageModalv2/ProductImageModalv2.stories.js +90 -0
  470. package/src/components/organisms/ProductImageModalv2/index.js +105 -0
  471. package/src/components/organisms/ProductImageModalv2/styles.js +71 -0
  472. package/src/components/organisms/RenameImagesBar/RenameImagesBar.stories.js +18 -0
  473. package/src/components/organisms/RenameImagesBar/index.js +30 -0
  474. package/src/components/organisms/RenameImagesBar/styles.js +12 -0
  475. package/src/components/organisms/VersionSelector/index.js +1 -2
  476. package/src/components/organisms/VersionSelectorv2/VersionSelectorv2.stories.js +15 -0
  477. package/src/components/organisms/VersionSelectorv2/index.js +105 -0
  478. package/src/components/organisms/VersionSelectorv2/styles.js +45 -0
  479. package/src/components/pages/Dashboard/Dashboard.stories.js +33 -38
  480. package/src/components/pages/Dashboard/index.js +36 -7
  481. package/src/components/pages/ProductEditionv2/ProductEditionv2.stories.js +213 -0
  482. package/src/components/pages/ProductEditionv2/index.js +1758 -0
  483. package/src/components/pages/ProductEditionv2/styles.js +154 -0
  484. package/src/components/pages/ProviderProductEdition/ProviderProductEdition.stories.js +100 -83
  485. package/src/components/pages/ProviderProductEdition/index.js +100 -131
  486. package/src/components/pages/ProviderProductEdition/styles.js +5 -1
  487. package/src/components/pages/RetailerProductEdition/RetailerProductEdition.stories.js +6 -2
  488. package/src/components/pages/RetailerProductEdition/index.js +107 -137
  489. package/src/components/pages/RetailerProductEdition/styles.js +4 -0
  490. package/src/components/pages/RetailerProductEdition/utils.js +37 -0
  491. package/src/global-files/data.js +7 -13
  492. package/src/global-files/variables.js +6 -0
  493. package/src/index.js +11 -0
@@ -0,0 +1,1016 @@
1
+ import ReactHowler from "react-howler";
2
+ import { Container } from "./styles";
3
+ import { useEffect, useState } from "react";
4
+ import { NotFound } from "../../../atoms/NotFound";
5
+ import { Header } from "../Header";
6
+ import { faComments as IconChat } from "@fortawesome/free-solid-svg-icons";
7
+ import { Loading } from "../../../atoms/Loading";
8
+ import { ContainerItems } from "../ContainerItems";
9
+ import { Footer } from "../Footer";
10
+ import { ChatLists } from "../ChatLists";
11
+ import { CustomIcon } from "../../../atoms/CustomIcon";
12
+ import { fetchGET, fetchPOST } from "../../../../global-files/handle_http";
13
+ import {
14
+ encodeUriJson,
15
+ isStringEmpty,
16
+ isValidNaturalNumber,
17
+ } from "../../../../global-files/utils";
18
+ import newMessage from "../../../../assets/sounds/newMessage.mp3";
19
+
20
+ export const ContentChat = (props) => {
21
+ const {
22
+ chatType, // "merchant_product" | "order_product" | "ticket"
23
+ chatContainerType, // "fixed" | "popUp"
24
+ dataChat, // { data | error }
25
+ showBtnClose, // boolean
26
+ onClickBtnClose, // () => {}
27
+ showPopUpChat, // boolean
28
+ ticketCompany, // id de la compañía que creó el ticket
29
+ activeRetailer, // object retailer
30
+ } = props;
31
+ const [companies, setCompanies] = useState({}); /* {
32
+ companyId: {
33
+ name: string,
34
+ statusChat: string => current | open | closed
35
+ items: [{..}] ,
36
+ enabledLoadMore: boolean
37
+ },
38
+ ...
39
+ } chat orderProduct */
40
+ const [singleChat, setSingleChat] = useState({
41
+ items: undefined,
42
+ enabledLoadMore: false,
43
+ statusChat: undefined,
44
+ }); // chat merchantProduct o ticket
45
+ const [activeCompanyId, setActiveCompanyId] = useState(); // number
46
+ const [allUsers, setAllUsers] = useState({}); // {...}
47
+ const [currentUser, setCurrentUser] = useState({
48
+ id: undefined,
49
+ companyId: undefined,
50
+ });
51
+ const [currentArticle, setCurrentArticle] = useState({
52
+ status: undefined,
53
+ version: undefined,
54
+ });
55
+ const [lastUpdateDate, setLastUpdateDate] = useState(); // string
56
+ const [isLoading, setIsLoading] = useState(true); // boolean
57
+ const [showChatsList, setShowChatsList] = useState(false); // boolean
58
+ const [processUpdateID, setProcessUpdateID] = useState(); // number
59
+ const [startUpdate, setStartUpdate] = useState(0); // number
60
+ const [runUpdate, setRunUpdate] = useState(0); // number
61
+ const [errorChat, setErrorChat] = useState({
62
+ existError: false,
63
+ code: undefined,
64
+ message: undefined,
65
+ errorDetail: undefined,
66
+ });
67
+ const [errorUpdate, setErrorUpdate] = useState({
68
+ startDate: undefined, // Date()
69
+ lastDate: undefined, // Date()
70
+ });
71
+ const [playSound, setPlaySound] = useState(false);
72
+
73
+ // matar update al desmontar el componente del chat
74
+ useEffect(() => {
75
+ return () => {
76
+ if (processUpdateID !== undefined) clearTimeout(processUpdateID);
77
+ };
78
+ }, []);
79
+
80
+ const stopUpdate = () => {
81
+ if (processUpdateID !== undefined) {
82
+ clearTimeout(processUpdateID);
83
+ setProcessUpdateID(undefined);
84
+ }
85
+ };
86
+
87
+ // al cargar el componente
88
+ useEffect(() => {
89
+ //if (dataChat && showPopUpChat) {
90
+ if (Object.keys(dataChat || {}).length) {
91
+ stopUpdate();
92
+ if (dataChat.code) {
93
+ setErrorChat({
94
+ existError: true,
95
+ code: dataChat.code,
96
+ message: dataChat.message,
97
+ errorDetail: dataChat.errorDetail,
98
+ });
99
+ setIsLoading(false);
100
+ return;
101
+ }
102
+ if (chatType === "merchant_product") getInitialMerchantProduct();
103
+ else if (chatType === "order_product") getInitialOrderProduct();
104
+ else if (chatType === "product_status") getInitialProductStatus();
105
+ else getInitialTicket();
106
+ }
107
+ if (!showPopUpChat) {
108
+ stopUpdate();
109
+ }
110
+ }, [dataChat, showPopUpChat]);
111
+
112
+ // comenzar temporizador del update de 20s
113
+ useEffect(() => {
114
+ // return; // -- descomentarizar para hacer pruebas sin update
115
+ if (startUpdate === 0) return;
116
+ const processID = setTimeout(() => {
117
+ setRunUpdate((prev) => prev + 1);
118
+ }, 15000);
119
+ setProcessUpdateID(processID);
120
+ return () => clearTimeout(processID);
121
+ }, [startUpdate]);
122
+
123
+ // ejecutar update
124
+ useEffect(() => {
125
+ if (chatType === "merchant_product") {
126
+ if (singleChat.items) getUpdateLatestMerchantProduct(true);
127
+ else getInitialMerchantProduct();
128
+ } else if (chatType === "order_product") {
129
+ if (companies) getUpdateLatestOrderProduct(true);
130
+ else getInitialOrderProduct();
131
+ } else if (chatType === "product_status") {
132
+ getInitialProductStatus();
133
+ } else {
134
+ if (singleChat.items) getUpdateLatestTicket(true);
135
+ else getInitialTicket();
136
+ }
137
+ }, [runUpdate]);
138
+
139
+ /*=======================================================================
140
+ PETICION GET INICIAL SEGUN EL TIPO DE CHAT
141
+ ======================================================================= */
142
+ const getInitialProductStatus = async () => {
143
+ const paramsQuery = {
144
+ articleData: JSON.stringify({
145
+ articleId: JSON.stringify(dataChat.id),
146
+ version: JSON.stringify(dataChat.version),
147
+ retailerId: JSON.stringify(dataChat.retailerId),
148
+ status: dataChat.status,
149
+ })
150
+ };
151
+ const paramsHeaders = { Authorization: dataChat.userToken };
152
+ const response = await fetchGET(
153
+ process.env.REACT_APP_READ_MESSAGES,
154
+ paramsQuery,
155
+ paramsHeaders
156
+ );
157
+ if (!response.body) {
158
+ setErrorChat({
159
+ existError: true,
160
+ code: 400,
161
+ message: response.message,
162
+ errorDetail: response.errorDetail,
163
+ });
164
+ setIsLoading(false);
165
+ return;
166
+ }
167
+ // success
168
+ setStartUpdate((prev) => prev + 1);
169
+ setCurrentUser({
170
+ id: response.body.data.currentUserId,
171
+ companyId: response.body.data.currentCompanyId,
172
+ });
173
+ setLastUpdateDate(response.body.data.lastUpdateDate);
174
+ setAllUsers(response.body.users);
175
+ setSingleChat({
176
+ items: response.body.items,
177
+ enabledLoadMore: response.body.items.length === 50,
178
+ });
179
+ setErrorChat({ existError: false });
180
+ setIsLoading(false);
181
+ };
182
+
183
+ const getInitialMerchantProduct = async () => {
184
+ const paramsQuery = {
185
+ getType: "initial",
186
+ id: JSON.stringify(dataChat.id),
187
+ version: JSON.stringify(dataChat.version),
188
+ };
189
+ const paramsHeaders = { Authorization: dataChat.userToken };
190
+ const response = await fetchGET(
191
+ process.env.REACT_APP_PRODUCTS_CHAT_ENDPOINT,
192
+ paramsQuery,
193
+ paramsHeaders
194
+ );
195
+ if (!response.body) {
196
+ setErrorChat({
197
+ existError: true,
198
+ code: 400,
199
+ message: response.message,
200
+ errorDetail: response.errorDetail,
201
+ });
202
+ setIsLoading(false);
203
+ return;
204
+ }
205
+ // success
206
+ setStartUpdate((prev) => prev + 1);
207
+ setCurrentUser({
208
+ id: response.body.data.currentUserId,
209
+ companyId: response.body.data.currentCompanyId,
210
+ });
211
+ setLastUpdateDate(response.body.data.lastUpdateDate);
212
+ setAllUsers(response.body.users);
213
+ setSingleChat({
214
+ items: response.body.items,
215
+ enabledLoadMore: response.body.items.length === 50,
216
+ });
217
+ setErrorChat({ existError: false });
218
+ setIsLoading(false);
219
+ };
220
+
221
+ const getInitialOrderProduct = async () => {
222
+ clearTimeout(processUpdateID); // finalizamos el temporizador
223
+ const paramsQuery = {
224
+ getType: "initial",
225
+ id: JSON.stringify(dataChat.id),
226
+ orderId: JSON.stringify(dataChat.orderId),
227
+ retailerId: JSON.stringify(dataChat.retailerId),
228
+ };
229
+ const paramsHeaders = { Authorization: dataChat.userToken };
230
+ const response = await fetchGET(
231
+ process.env.REACT_APP_PRODUCTS_CHAT_ENDPOINT,
232
+ paramsQuery,
233
+ paramsHeaders
234
+ );
235
+ setStartUpdate((prev) => prev + 1); // TEMPORAL
236
+ if (!response.body) {
237
+ setErrorChat({
238
+ existError: true,
239
+ code: 400,
240
+ message: response.message,
241
+ errorDetail: response.errorDetail,
242
+ });
243
+ setIsLoading(false);
244
+ return;
245
+ }
246
+ // success
247
+ setCurrentUser({
248
+ id: response.body.data.currentUserId,
249
+ companyId: response.body.data.currentCompanyId,
250
+ });
251
+ setLastUpdateDate(response.body.data.lastUpdateDate);
252
+ setCurrentArticle({
253
+ status: response.body.data.status,
254
+ version: response.body.data.version,
255
+ });
256
+ setAllUsers(response.body.users);
257
+ const companiesList = response.body.companies;
258
+ const companiesIdList = Object.keys(companiesList);
259
+ let companyActive;
260
+ // encontrar el chat inicial a cargar y si se debe permitir cargar mas
261
+ for (const companyId of companiesIdList) {
262
+ if (companiesList[companyId].items.length < 50) {
263
+ companiesList[companyId].enabledLoadMore = false;
264
+ } else {
265
+ companiesList[companyId].enabledLoadMore = true;
266
+ }
267
+
268
+ if (companiesList[companyId].statusChat === "current") {
269
+ companyActive = Number(companyId);
270
+ }
271
+ }
272
+ if (!companyActive && companiesIdList.length) {
273
+ companyActive = Number(companiesIdList[0]);
274
+ }
275
+ setCompanies(companiesList);
276
+ if (companyActive) setActiveCompanyId(companyActive);
277
+ setErrorChat({ existError: false });
278
+ setIsLoading(false);
279
+ };
280
+
281
+ const getInitialTicket = async () => {
282
+ stopUpdate(); // finalizamos el temporizador
283
+ const dataUser = {
284
+ id: dataChat.currentUser?.id,
285
+ companyId: dataChat.currentUser?.companyId,
286
+ isUserTech: dataChat.currentUser?.isUserTech,
287
+ };
288
+ const paramsQuery = {
289
+ //id: JSON.stringify(dataChat.id),
290
+ id: dataChat.id,
291
+ getType: "initial",
292
+ //currentUser: encodeUriJson(dataUser),
293
+ currentUser: encodeURIComponent(JSON.stringify(dataUser)),
294
+ currentItemsFront: encodeUriJson(getItemsIdSingleChat()),
295
+ };
296
+ const response = await fetchGET(
297
+ process.env.REACT_APP_TICKETS_CHAT_ENDPOINT,
298
+ paramsQuery,
299
+ { Authorization: dataChat.currentUser?.token }
300
+ );
301
+ // programar update en 20s
302
+ setStartUpdate((prev) => prev + 1);
303
+ if (!response.body) {
304
+ setErrorChat({
305
+ existError: true,
306
+ code: 400,
307
+ message: response.message,
308
+ errorDetail: response.errorDetail,
309
+ });
310
+ setIsLoading(false);
311
+ return;
312
+ }
313
+ // success
314
+ setLastUpdateDate(response.body.data.lastUpdateDate);
315
+ setAllUsers(response.body.users);
316
+ setSingleChat({
317
+ items: response.body.items,
318
+ enabledLoadMore: response.body.items.length === 50,
319
+ statusChat: dataChat.statusChat,
320
+ });
321
+ setErrorChat({ existError: false });
322
+ setIsLoading(false);
323
+ };
324
+
325
+ /*=======================================================================
326
+ PETICION GET LOAD_MORE SEGUN EL TIPO DE CHAT
327
+ ======================================================================= */
328
+ const getLoadMoreMerchantProduct = async () => {
329
+ clearTimeout(processUpdateID); // finalizamos el temporizador
330
+ let date = singleChat.items[singleChat.items.length - 1].date;
331
+ const paramsQuery = {
332
+ getType: "loadMore",
333
+ id: JSON.stringify(dataChat.id),
334
+ version: JSON.stringify(dataChat.version),
335
+ date: encodeURIComponent(date),
336
+ };
337
+ const response = await fetchGET(
338
+ process.env.REACT_APP_PRODUCTS_CHAT_ENDPOINT,
339
+ paramsQuery
340
+ );
341
+ //setStartUpdate((prev) => prev + 1); // comendar un nuevo temporizador
342
+ if (!response.body) {
343
+ return {
344
+ title: response.message,
345
+ message: response.errorDetail,
346
+ };
347
+ }
348
+ // success
349
+ // actualizar la lista de los users
350
+ updateAllUsers(response.body.users);
351
+ // actualizar los items del chat
352
+ let newSingleChat = { ...singleChat };
353
+ newSingleChat.items = addOldItemsChat(
354
+ newSingleChat.items,
355
+ response.body.items
356
+ );
357
+ newSingleChat.enabledLoadMore = response.body.items.length === 50;
358
+ setSingleChat(newSingleChat);
359
+ };
360
+
361
+ const getLoadMoreOrderProduct = async () => {
362
+ clearTimeout(processUpdateID); // finalizamos el temporizador
363
+ let company = companies[activeCompanyId];
364
+ let date = company.items[company.items.length - 1].date;
365
+ const paramsQuery = {
366
+ getType: "loadMore",
367
+ id: JSON.stringify(dataChat.id),
368
+ orderId: JSON.stringify(dataChat.orderId),
369
+ version: JSON.stringify(currentArticle.version),
370
+ currentCompanyId: JSON.stringify(currentUser.companyId),
371
+ date: encodeURIComponent(date),
372
+ othersCompanyId: JSON.stringify([activeCompanyId]),
373
+ };
374
+ const response = await fetchGET(
375
+ process.env.REACT_APP_PRODUCTS_CHAT_ENDPOINT,
376
+ paramsQuery
377
+ );
378
+ //setStartUpdate((prev) => prev + 1); // comendar un nuevo temporizador
379
+ if (!response.body) {
380
+ return {
381
+ title: response.message,
382
+ message: response.errorDetail,
383
+ };
384
+ }
385
+ // success
386
+ // actualizar la lista de los users
387
+ updateAllUsers(response.body.users);
388
+ // actualizar los items del chat y la lista de users
389
+ company.items = addOldItemsChat(company.items, response.body.items);
390
+ company.enabledLoadMore = response.body.items.length === 50;
391
+ setCompanies((prev) => ({
392
+ ...prev,
393
+ [activeCompanyId]: company,
394
+ }));
395
+ };
396
+
397
+ // este GET obtiene la lista de compañoas con las que se puede chatear
398
+ const getLoadMoreTicket = async () => {
399
+ stopUpdate(); // finalizamos el temporizador
400
+ let date = singleChat.items[singleChat.items.length - 1].date;
401
+ const dataUser = {
402
+ id: dataChat.currentUser?.id,
403
+ companyId: dataChat.currentUser?.companyId,
404
+ isUserTech: dataChat.currentUser?.isUserTech,
405
+ };
406
+ const paramsQuery = {
407
+ id: JSON.stringify(dataChat.id),
408
+ getType: "loadMore",
409
+ date: encodeURIComponent(date),
410
+ currentUser: encodeUriJson(dataUser),
411
+ currentItemsFront: encodeUriJson(getItemsIdSingleChat()),
412
+ };
413
+ const response = await fetchGET(
414
+ process.env.REACT_APP_TICKETS_CHAT_ENDPOINT,
415
+ paramsQuery,
416
+ { Authorization: dataChat.currentUser?.token }
417
+ );
418
+ //programar update en 20s
419
+ setStartUpdate((prev) => prev + 1);
420
+ if (!response.body) {
421
+ return {
422
+ title: response.message,
423
+ message: response.errorDetail,
424
+ };
425
+ }
426
+ // success
427
+ // actualizar la lista de los users
428
+ updateAllUsers(response.body.users);
429
+ // actualizar los items del chat
430
+ let newSingleChat = { ...singleChat };
431
+ newSingleChat.items = addOldItemsChat(
432
+ newSingleChat.items,
433
+ response.body.items
434
+ );
435
+ newSingleChat.enabledLoadMore = response.body.items.length === 50;
436
+ setSingleChat(newSingleChat);
437
+ };
438
+
439
+ /*=======================================================================
440
+ PETICION GET UPDATE_LATEST SEGUN EL TIPO DE CHAT
441
+ ======================================================================= */
442
+ const getUpdateLatestMerchantProduct = async (fromUpdate = false) => {
443
+ const paramsQuery = {
444
+ getType: "updateLatest",
445
+ id: JSON.stringify(dataChat.id),
446
+ version: JSON.stringify(dataChat.version),
447
+ date: encodeURIComponent(lastUpdateDate),
448
+ };
449
+ const paramsHeaders = { Authorization: dataChat.userToken };
450
+ const response = await fetchGET(
451
+ process.env.REACT_APP_PRODUCTS_CHAT_ENDPOINT,
452
+ paramsQuery,
453
+ paramsHeaders
454
+ );
455
+ if (!response.body) {
456
+ console.log("ERROR updateLatest:", {
457
+ message: response.message,
458
+ errorDetail: response.errorDetail,
459
+ });
460
+ return;
461
+ }
462
+ // success
463
+ setStartUpdate((prev) => prev + 1);
464
+ setLastUpdateDate(response.body.data.lastUpdateDate);
465
+ // actualizar la lista de los users
466
+ updateAllUsers(response.body.users);
467
+ // actualizar los items del chat
468
+ let newSingleChat = { ...singleChat };
469
+ newSingleChat.items = addNewItemsChat(
470
+ newSingleChat.items,
471
+ response.body.items,
472
+ fromUpdate
473
+ );
474
+ setSingleChat(newSingleChat);
475
+ };
476
+
477
+ const getUpdateLatestOrderProduct = async (fromUpdate = false) => {
478
+ const paramsQuery = {
479
+ getType: "updateLatest",
480
+ id: JSON.stringify(dataChat.id),
481
+ orderId: JSON.stringify(dataChat.orderId),
482
+ retailerId: JSON.stringify(dataChat.retailerId),
483
+ version: JSON.stringify(currentArticle.version),
484
+ status: currentArticle.status,
485
+ currentCompanyId: JSON.stringify(currentUser.companyId),
486
+ othersCompanyId: encodeURIComponent(
487
+ JSON.stringify(Object.keys(companies))
488
+ ),
489
+ date: encodeURIComponent(lastUpdateDate),
490
+ };
491
+ const response = await fetchGET(
492
+ process.env.REACT_APP_PRODUCTS_CHAT_ENDPOINT,
493
+ paramsQuery
494
+ );
495
+ if (!response.body) {
496
+ console.log("ERROR update: ", {
497
+ message: response.message,
498
+ errorDetail: response.errorDetail,
499
+ });
500
+ return;
501
+ }
502
+ // success
503
+ setStartUpdate((prev) => prev + 1);
504
+ // cuando cambie la lista de chats por un cambio de version o estatus
505
+ if (response.body.data.status) {
506
+ setIsLoading(true);
507
+ setTimeout(() => {
508
+ setLastUpdateDate(response.body.data.lastUpdateDate);
509
+ setCurrentArticle({
510
+ status: response.body.data.status,
511
+ version: response.body.data.version,
512
+ });
513
+ setAllUsers(response.body.users);
514
+ const companiesList = response.body.companies;
515
+ const companiesIdList = Object.keys(companiesList);
516
+ let companyActive;
517
+ // encontrar el chat inicial a cargar y si se debe permitir cargar mas
518
+ for (const companyId of companiesIdList) {
519
+ if (companiesList[companyId].items.length < 50) {
520
+ companiesList[companyId].enabledLoadMore = false;
521
+ } else {
522
+ companiesList[companyId].enabledLoadMore = true;
523
+ }
524
+
525
+ if (companiesList[companyId].statusChat === "current") {
526
+ companyActive = Number(companyId);
527
+ }
528
+ }
529
+ if (!companyActive && companiesIdList.length) {
530
+ companyActive = Number(companiesIdList[0]);
531
+ }
532
+ setCompanies(companiesList);
533
+ if (companyActive) setActiveCompanyId(companyActive);
534
+ setErrorChat({ existError: false });
535
+ setIsLoading(false);
536
+ }, 2000);
537
+ }
538
+ // cuando se hizo un update de los mismos chats
539
+ else {
540
+ setLastUpdateDate(response.body.data.lastUpdateDate);
541
+ // actualizar la lista de los users
542
+ updateAllUsers(response.body.users);
543
+ // actualizar los items de los chats
544
+ let companiesList = { ...companies };
545
+ Object.keys(response.body.companies).forEach((companyId) => {
546
+ companiesList[companyId].items = addNewItemsChat(
547
+ companiesList[companyId].items,
548
+ response.body.companies[companyId].items,
549
+ fromUpdate
550
+ );
551
+ });
552
+ setCompanies(companiesList);
553
+ }
554
+ };
555
+
556
+ const getUpdateLatestTicket = async (fromUpdate = false) => {
557
+ if (singleChat.statusChat === "closed") return;
558
+ const dataUser = {
559
+ id: dataChat.currentUser?.id,
560
+ companyId: dataChat.currentUser?.companyId,
561
+ isUserTech: dataChat.currentUser?.isUserTech,
562
+ };
563
+ const paramsQuery = {
564
+ id: JSON.stringify(dataChat.id),
565
+ getType: "updateLatest",
566
+ date: encodeURIComponent(lastUpdateDate),
567
+ currentUser: encodeUriJson(dataUser),
568
+ currentItemsFront: encodeUriJson(getItemsIdSingleChat()),
569
+ };
570
+ const response = await fetchGET(
571
+ process.env.REACT_APP_TICKETS_CHAT_ENDPOINT,
572
+ paramsQuery,
573
+ { Authorization: dataChat.currentUser?.token }
574
+ );
575
+ //programar update en 20s
576
+ setStartUpdate((prev) => prev + 1);
577
+ if (!response.body) {
578
+ if (errorUpdate.startDate) {
579
+ setErrorUpdate((prev) => ({
580
+ ...prev,
581
+ lastDate: new Date(),
582
+ }));
583
+ } else {
584
+ setErrorUpdate((prev) => ({
585
+ startDate: new Date(),
586
+ }));
587
+ }
588
+ console.log("ERROR updateLatest:", {
589
+ message: response.message,
590
+ errorDetail: response.errorDetail,
591
+ });
592
+ return;
593
+ }
594
+ // limpiar error update
595
+ if (errorUpdate.startDate) {
596
+ setErrorUpdate({});
597
+ }
598
+ // success
599
+ setLastUpdateDate(response.body.data.lastUpdateDate);
600
+ // actualizar la lista de los users
601
+ updateAllUsers(response.body.users);
602
+ // actualizar los items del chat
603
+ if (response.body.items.length === 0) return;
604
+ let newSingleChat = { ...singleChat };
605
+ newSingleChat.items = addNewItemsChat(
606
+ newSingleChat.items,
607
+ response.body.items,
608
+ fromUpdate
609
+ );
610
+ newSingleChat.statusChat = response.body.data.statusChat;
611
+
612
+ setSingleChat(newSingleChat);
613
+ };
614
+
615
+ /*=======================================================================
616
+ FUNCION QUE EJECUTA EL MICROSERVICIO CREATE-ITEM
617
+ Este metodo recibe los items que queremos agregar al chat.
618
+ requiere:
619
+ => items: [ { type , value } , ... ]
620
+ NOTA: si se quiere agregar un mensaje mandar un array con un object
621
+ example: [ {
622
+ type: "message" ,
623
+ value: "mi mensaje"
624
+ } ]
625
+ ======================================================================= */
626
+ const createItemsChat = async (items = []) => {
627
+ if (items.length === 0) {
628
+ return {
629
+ message:
630
+ "No se especifico ningun mensaje, imagen o archivo nuevo " +
631
+ "que se quiera enviar al chat",
632
+ errorDetail: "Reporta esto a TI",
633
+ };
634
+ }
635
+ for (const item of items) {
636
+ if (!["message", "img", "file"].includes(item.type)) {
637
+ return {
638
+ message:
639
+ "Uno de los elementos que se quiere enviar al chat " +
640
+ `no es un tipo valido "${item.type}"`,
641
+ errorDetail: "Reporta esto a TI",
642
+ };
643
+ }
644
+ if (isStringEmpty(item.value)) {
645
+ return {
646
+ message:
647
+ "Uno de los elementos que se quiere enviar al chat " +
648
+ `contiene un valor vacio`,
649
+ errorDetail: "Reporta esto a TI",
650
+ };
651
+ }
652
+ }
653
+ let errorCreate;
654
+ stopUpdate(); // finalizamos el temporizador
655
+
656
+ // enviar items a la BD
657
+ if (chatType === "merchant_product") {
658
+ errorCreate = await createItemsMerchantProduct(items);
659
+ } else if (chatType === "product_status") {
660
+ errorCreate = await createItemsProductStatus(items);
661
+ } else if (chatType === "order_product") {
662
+ errorCreate = await createItemsOrderProduct(items);
663
+ } else errorCreate = await createItemsTicket(items);
664
+
665
+ // actualizar chat para que aparezcan los items enviados
666
+ if (["merchant_product", "product_status"].includes(chatType)) {
667
+ await getUpdateLatestMerchantProduct();
668
+ } else if (chatType === "order_product") {
669
+ await getUpdateLatestOrderProduct();
670
+ } else await getUpdateLatestTicket();
671
+
672
+ // cuando no se pudieron guardar los items
673
+ if (errorCreate) {
674
+ return errorCreate;
675
+ }
676
+ };
677
+
678
+ const createItemsMerchantProduct = async (items = []) => {
679
+ const { id, version, orderId } = dataChat;
680
+ const { id: retailerId } = activeRetailer;
681
+ const paramsBody = { id, version, items, retailerId };
682
+ if (chatType === "product_status") paramsBody["orderId"] = orderId;
683
+ const paramsHeaders = { Authorization: dataChat.userToken };
684
+ const response = await fetchPOST(
685
+ process.env.REACT_APP_PRODUCTS_CHAT_ENDPOINT,
686
+ paramsBody,
687
+ paramsHeaders
688
+ );
689
+ if (!response.body) {
690
+ return {
691
+ message: response.message,
692
+ errorDetail: response.errorDetail,
693
+ };
694
+ }
695
+ };
696
+ const createItemsProductStatus = async (items = []) => {
697
+ const { id, version, orderId, status } = dataChat;
698
+ const { id: retailerId } = activeRetailer;
699
+ const paramsBody = { id, version, items, retailerId, orderId, status };
700
+ const paramsHeaders = { Authorization: dataChat.userToken };
701
+ const response = await fetchPOST(
702
+ process.env.REACT_APP_CREATE_MESSAGES,
703
+ paramsBody,
704
+ paramsHeaders
705
+ );
706
+ if (!response.body) {
707
+ return {
708
+ message: response.message,
709
+ errorDetail: response.errorDetail,
710
+ };
711
+ }
712
+ };
713
+
714
+ const createItemsOrderProduct = async (items = []) => {
715
+ const paramsBody = {
716
+ id: dataChat.id,
717
+ version: currentArticle.version,
718
+ items,
719
+ orderId: dataChat.orderId,
720
+ retailerId: activeRetailer?.id,
721
+ };
722
+ const paramsHeaders = { Authorization: dataChat.userToken };
723
+ const response = await fetchPOST(
724
+ process.env.REACT_APP_PRODUCTS_CHAT_ENDPOINT,
725
+ paramsBody,
726
+ paramsHeaders
727
+ );
728
+ if (!response.body) {
729
+ return {
730
+ message: response.message,
731
+ errorDetail: response.errorDetail,
732
+ };
733
+ }
734
+ };
735
+
736
+ const createItemsTicket = async (items = []) => {
737
+ const paramsBody = {
738
+ id: JSON.stringify(dataChat.id),
739
+ userId: JSON.stringify(dataChat.currentUser.id),
740
+ items: JSON.stringify(items),
741
+ };
742
+ const paramsHeaders = { Authorization: dataChat.userToken };
743
+ const response = await fetchPOST(
744
+ process.env.REACT_APP_TICKETS_CHAT_ENDPOINT,
745
+ paramsBody,
746
+ paramsHeaders
747
+ );
748
+ if (!response.body) {
749
+ return {
750
+ message: response.message,
751
+ errorDetail: response.errorDetail,
752
+ };
753
+ }
754
+ };
755
+
756
+ /*=======================================================================
757
+ SECCION DE FUNCIONES
758
+ ======================================================================= */
759
+ const isSingleChat = () => {
760
+ if (
761
+ chatType === "merchant_product" ||
762
+ chatType === "ticket" ||
763
+ chatType === "product_status"
764
+ ) {
765
+ return true;
766
+ }
767
+ if (companies && Object.keys(companies).length < 2) return true;
768
+ else return false;
769
+ };
770
+
771
+ const getItemsIdSingleChat = () => {
772
+ const itemsId = {};
773
+ if (Array.isArray(singleChat.items)) {
774
+ singleChat.items.forEach((item) => {
775
+ if (isValidNaturalNumber(item.id)) itemsId[item.id] = true;
776
+ });
777
+ }
778
+ return itemsId;
779
+ };
780
+
781
+ const getChatCompany = () => {
782
+ if (chatType === "merchant_product" || chatType === "ticket") {
783
+ return undefined;
784
+ }
785
+ if (companies && companies[activeCompanyId]) {
786
+ return {
787
+ ...companies[activeCompanyId],
788
+ id: activeCompanyId,
789
+ };
790
+ }
791
+ return undefined;
792
+ };
793
+
794
+ const addOldItemsChat = (currentItems = [], newItems = []) => {
795
+ let items = currentItems.slice();
796
+ let itemsId = {};
797
+ items.forEach((item) => {
798
+ itemsId[item.id] = true;
799
+ });
800
+ newItems.forEach((item) => {
801
+ if (!itemsId[item.id]) {
802
+ items.push(item);
803
+ itemsId[item.id] = true;
804
+ }
805
+ });
806
+ return items;
807
+ };
808
+
809
+ const addNewItemsChat = (
810
+ currentItems = [],
811
+ newItems = [],
812
+ fromUpdate = false
813
+ ) => {
814
+ let itemsId = {};
815
+ currentItems.forEach((item) => {
816
+ itemsId[item.id] = item;
817
+ });
818
+ let thereAreNewItems = false;
819
+ newItems.forEach((newitem) => {
820
+ if (!itemsId[newitem.id]) {
821
+ itemsId[newitem.id] = newitem;
822
+ thereAreNewItems = true;
823
+ }
824
+ });
825
+ if (thereAreNewItems && fromUpdate) {
826
+ setPlaySound(true);
827
+ setTimeout(() => {
828
+ setPlaySound(false);
829
+ }, 5000);
830
+ }
831
+ if (chatType !== "ticket") {
832
+ return Object.values(itemsId).sort((a, b) => {
833
+ if (a.id > b.id) return 1;
834
+ if (a.id < b.id) return -1;
835
+ return 0;
836
+ });
837
+ } else {
838
+ return Object.values(itemsId).reverse();
839
+ }
840
+ };
841
+
842
+ const updateAllUsers = (newUsers = {}) => {
843
+ let currentUsers = { ...allUsers };
844
+ Object.keys(newUsers).forEach((userId) => {
845
+ if (!currentUsers[userId]) {
846
+ currentUsers[userId] = newUsers[userId];
847
+ }
848
+ });
849
+ setAllUsers(currentUsers);
850
+ };
851
+
852
+ const renderBodyChat = () => {
853
+ if (isLoading) return <Loading />;
854
+ if (errorChat.existError) {
855
+ return (
856
+ <NotFound
857
+ code={errorChat.code}
858
+ message={errorChat.message}
859
+ details={errorChat.errorDetail}
860
+ />
861
+ );
862
+ }
863
+ // cuando se quiere ver la lista de chats
864
+ if (showChatsList) {
865
+ return (
866
+ <ChatLists
867
+ companies={companies}
868
+ currentCompanyId={currentUser?.companyId}
869
+ onClickCompany={(companyIdSelected) => {
870
+ setActiveCompanyId(Number(companyIdSelected));
871
+ setShowChatsList(false);
872
+ }}
873
+ />
874
+ );
875
+ }
876
+ // mostrar chat?
877
+ let items;
878
+ let enabledLoadMore;
879
+ if (["merchant_product", "ticket", "product_status"].includes(chatType)) {
880
+ items = singleChat.items;
881
+ enabledLoadMore = singleChat.enabledLoadMore;
882
+ }
883
+ // ORDER_PRODUCT
884
+ else if (companies) {
885
+ // caso 0 chats
886
+ if (Object.keys(companies).length === 0) {
887
+ return (
888
+ <div className="container-chatEmpty">
889
+ <CustomIcon
890
+ className="icon-chat"
891
+ transparent
892
+ size={35}
893
+ icon={IconChat}
894
+ type={"gray"}
895
+ />
896
+ <label>
897
+ De acuerdo al estatus del producto, tu compañia no tiene
898
+ disponible ningun chat abierto o cerrado
899
+ </label>
900
+ </div>
901
+ );
902
+ }
903
+ // caso 1 o mas chats
904
+ if (companies[activeCompanyId]) {
905
+ items = companies[activeCompanyId].items;
906
+ enabledLoadMore = companies[activeCompanyId].enabledLoadMore;
907
+ }
908
+ }
909
+ if (items) {
910
+ let containerItems = null;
911
+ if (items.length) {
912
+ containerItems = (
913
+ <ContainerItems
914
+ items={items}
915
+ users={allUsers}
916
+ showBtnLoadMore={enabledLoadMore}
917
+ chatType={chatType}
918
+ activeCompanyId={activeCompanyId}
919
+ ticketCompany={ticketCompany}
920
+ currentUser={
921
+ ["merchant_product", "order_product", "product_status"].includes(
922
+ chatType
923
+ )
924
+ ? currentUser
925
+ : dataChat.currentUser
926
+ }
927
+ onClickBtnLoadMore={
928
+ chatType === "merchant_product"
929
+ ? getLoadMoreMerchantProduct
930
+ : chatType === "order_product"
931
+ ? getLoadMoreOrderProduct
932
+ : getLoadMoreTicket
933
+ }
934
+ />
935
+ );
936
+ } else {
937
+ containerItems = (
938
+ <div className="container-chatEmpty">
939
+ <CustomIcon
940
+ className="icon-chat"
941
+ size={35}
942
+ icon={IconChat}
943
+ type={"gray"}
944
+ transparent
945
+ />
946
+ <label>Este chat no tiene mensajes</label>
947
+ </div>
948
+ );
949
+ }
950
+ return (
951
+ <>
952
+ {containerItems}
953
+ <Footer
954
+ chatType={chatType}
955
+ dataChat={
956
+ chatType === "merchant_product"
957
+ ? { id: dataChat.id, version: dataChat.version }
958
+ : chatType === "order_product"
959
+ ? { id: dataChat.id, version: currentArticle.version }
960
+ : chatType === "ticket"
961
+ ? { id: dataChat.id }
962
+ : chatType === "product_status"
963
+ ? {
964
+ id: dataChat.id,
965
+ version: dataChat.version,
966
+ retailerId: dataChat.retailerId,
967
+ }
968
+ : undefined
969
+ }
970
+ chatCompany={getChatCompany()}
971
+ statusChat={
972
+ chatType === "order_product"
973
+ ? getChatCompany()?.statusChat
974
+ : chatType === "ticket"
975
+ ? singleChat.statusChat
976
+ : undefined
977
+ }
978
+ messageDisabled={
979
+ chatType === "order_product"
980
+ ? `La conversación con ${getChatCompany()?.name} ha finalizado`
981
+ : chatType === "ticket"
982
+ ? "Ticket cerrado"
983
+ : `La conversación ha finalizado`
984
+ }
985
+ createItemsChat={createItemsChat}
986
+ errorUpdate={errorUpdate}
987
+ />
988
+ </>
989
+ );
990
+ }
991
+ return <Loading />;
992
+ };
993
+
994
+ return (
995
+ <>
996
+ <Container>
997
+ {/* header */}
998
+ {(chatContainerType !== "fixed" || !isSingleChat()) && (
999
+ <Header
1000
+ showBtnClose={showBtnClose}
1001
+ onClickBtnClose={onClickBtnClose}
1002
+ showChatsList={showChatsList}
1003
+ chatCompany={getChatCompany()}
1004
+ multipleCompanies={!isSingleChat()}
1005
+ onClickBtnChooseChat={() => {
1006
+ setShowChatsList(true);
1007
+ }}
1008
+ />
1009
+ )}
1010
+ {/* body */}
1011
+ {renderBodyChat()}
1012
+ </Container>
1013
+ <ReactHowler src={newMessage} playing={playSound} />
1014
+ </>
1015
+ );
1016
+ };