contentoh-components-library 21.5.3 → 21.5.4

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 (294) hide show
  1. package/dist/components/organisms/InputGroup/index.js +1 -1
  2. package/dist/components/organisms/Table/styles.js +1 -1
  3. package/dist/components/pages/MultipleEdition/saveData.js +9 -19
  4. package/dist/components/pages/MultipleEdition/styles.js +1 -1
  5. package/dist/components/pages/MultipleEdition/utils.js +86 -153
  6. package/package.json +4 -1
  7. package/src/assets/images/Icons/addv2.svg +8 -0
  8. package/src/assets/images/Icons/beenhere.svg +9 -0
  9. package/src/assets/images/Icons/checkv2.svg +8 -0
  10. package/src/assets/images/Icons/close-magenta.svg +9 -0
  11. package/src/assets/images/Icons/close.svg +8 -0
  12. package/src/assets/images/Icons/closeCircle.svg +8 -0
  13. package/src/assets/images/Icons/delete-forever-red.svg +9 -0
  14. package/src/assets/images/Icons/delete-forever-white.svg +10 -0
  15. package/src/assets/images/Icons/edit.svg +8 -0
  16. package/src/assets/images/Icons/fullscreen.svg +3 -0
  17. package/src/assets/images/Icons/infoNR.svg +8 -0
  18. package/src/assets/images/Icons/options.svg +3 -0
  19. package/src/assets/images/Icons/save-white-gray.svg +9 -0
  20. package/src/assets/images/Icons/save-white.svg +9 -0
  21. package/src/assets/images/Icons/save.svg +8 -0
  22. package/src/assets/images/Icons/search.svg +3 -0
  23. package/src/assets/images/Icons/settings.svg +8 -0
  24. package/src/assets/images/Icons/trash.svg +8 -0
  25. package/src/assets/images/Icons/undo.svg +8 -0
  26. package/src/assets/images/Icons/upload-file-white.svg +4 -0
  27. package/src/assets/images/Icons/upload-file.svg +10 -0
  28. package/src/assets/images/Icons/upload_file.svg +10 -0
  29. package/src/assets/images/Icons/warningv2.svg +3 -0
  30. package/src/assets/images/checkBox/checkrosa.svg +3 -0
  31. package/src/assets/images/checkBox/checkverde.svg +3 -0
  32. package/src/assets/images/flagsv2/highPriority.svg +3 -0
  33. package/src/assets/images/flagsv2/lowPriority.svg +3 -0
  34. package/src/assets/images/flagsv2/mediumPriority.svg +3 -0
  35. package/src/assets/images/flagsv2/noPriority.svg +3 -0
  36. package/src/assets/images/generalButton/closeIconWhite.svg +4 -0
  37. package/src/assets/images/generalButton/closeIconv2.svg +4 -0
  38. package/src/assets/images/generalButton/saveIconpink.svg +3 -0
  39. package/src/components/atoms/Avatar/index.js +8 -2
  40. package/src/components/atoms/ButtonV2/ButtonV2.stories.js +1 -0
  41. package/src/components/atoms/ButtonV2/index.js +1 -0
  42. package/src/components/atoms/ButtonV2/styles.js +16 -0
  43. package/src/components/atoms/CharsMissing/Wysiwyg.stories.js +12 -0
  44. package/src/components/atoms/CharsMissing/index.js +60 -0
  45. package/src/components/atoms/CharsMissing/styles.js +44 -0
  46. package/src/components/atoms/CheckBox/CheckBox.stories.js +5 -0
  47. package/src/components/atoms/CheckBox/index.js +5 -1
  48. package/src/components/atoms/CheckBox/styles.js +9 -3
  49. package/src/components/atoms/CustomChip/CustomChip.stories.js +16 -0
  50. package/src/components/atoms/CustomChip/index.js +34 -0
  51. package/src/components/atoms/CustomChip/styles.js +6 -0
  52. package/src/components/atoms/FeatureTagv2/FeatureTagv2.stories.js +16 -0
  53. package/src/components/atoms/FeatureTagv2/index.js +10 -0
  54. package/src/components/atoms/FeatureTagv2/styles.js +56 -0
  55. package/src/components/atoms/GeneralButton/styles.js +46 -0
  56. package/src/components/atoms/GeneralInput/index.js +3 -0
  57. package/src/components/atoms/GeneralInput/styles.js +19 -1
  58. package/src/components/atoms/GeneralInputv2/GeneralInputv2.stories.js +33 -0
  59. package/src/components/atoms/GeneralInputv2/index.js +155 -0
  60. package/src/components/atoms/GeneralInputv2/styles.js +67 -0
  61. package/src/components/atoms/InputFormatter/index.js +2 -1
  62. package/src/components/atoms/InputFormatter/styles.js +9 -4
  63. package/src/components/atoms/InputFormatterv2/Wysiwyg.stories.js +12 -0
  64. package/src/components/atoms/InputFormatterv2/index.js +148 -0
  65. package/src/components/atoms/InputFormatterv2/styles.js +39 -0
  66. package/src/components/atoms/InputImages/InputImages.stories.js +19 -0
  67. package/src/components/atoms/InputImages/index.js +25 -0
  68. package/src/components/atoms/InputImages/styles.js +17 -0
  69. package/src/components/atoms/Multiselect/Multiselect.stories.js +364 -0
  70. package/src/components/atoms/Multiselect/index.js +351 -0
  71. package/src/components/atoms/Multiselect/styles.js +33 -0
  72. package/src/components/atoms/NumberMandatory/NumberMandatory.stories.js +19 -0
  73. package/src/components/atoms/NumberMandatory/index.js +16 -0
  74. package/src/components/atoms/NumberMandatory/styles.js +11 -0
  75. package/src/components/atoms/ObservationFlag/ObservationFlag.stories.js +20 -0
  76. package/src/components/atoms/ObservationFlag/index.js +167 -0
  77. package/src/components/atoms/ObservationFlag/styles.js +104 -0
  78. package/src/components/atoms/PriorityFlagv2/PriorityFlagv2.stories.js +20 -0
  79. package/src/components/atoms/PriorityFlagv2/index.js +20 -0
  80. package/src/components/atoms/PriorityFlagv2/styles.js +6 -0
  81. package/src/components/atoms/ProductImage/index.js +24 -11
  82. package/src/components/atoms/ProductImage/styles.js +7 -0
  83. package/src/components/atoms/ProductImagev2/ProductImagev2.stories.js +28 -0
  84. package/src/components/atoms/ProductImagev2/index.js +16 -0
  85. package/src/components/atoms/ProductImagev2/styles.js +62 -0
  86. package/src/components/atoms/Progress/Progress.stories.js +25 -0
  87. package/src/components/atoms/Progress/index.js +74 -0
  88. package/src/components/atoms/Progress/styles.js +98 -0
  89. package/src/components/atoms/ScreenHeaderv2/ScreenHeaderv2.stories.js +53 -0
  90. package/src/components/atoms/ScreenHeaderv2/index.js +134 -0
  91. package/src/components/atoms/ScreenHeaderv2/styles.js +103 -0
  92. package/src/components/atoms/Selectv2/VersionSelect.js +27 -0
  93. package/src/components/atoms/Selectv2/index.js +35 -0
  94. package/src/components/atoms/Selectv2/style.js +93 -0
  95. package/src/components/atoms/SliderToolTip/styles.js +1 -1
  96. package/src/components/atoms/TabSection/index.js +1 -1
  97. package/src/components/atoms/TabSection/styles.js +0 -3
  98. package/src/components/atoms/TabSectionv2/TabSection.stories.js +25 -0
  99. package/src/components/atoms/TabSectionv2/index.js +9 -0
  100. package/src/components/atoms/TabSectionv2/styles.js +20 -0
  101. package/src/components/atoms/TooltipLight/Tooltip.stories.js +20 -0
  102. package/src/components/atoms/TooltipLight/index.js +46 -0
  103. package/src/components/atoms/TooltipLight/styles.js +65 -0
  104. package/src/components/atoms/WordsMissing/Wysiwyg.stories.js +12 -0
  105. package/src/components/atoms/WordsMissing/index.js +60 -0
  106. package/src/components/atoms/WordsMissing/styles.js +10 -0
  107. package/src/components/molecules/AddGroup/AddGroup.stories.js +15 -0
  108. package/src/components/molecules/AddGroup/index.js +84 -0
  109. package/src/components/molecules/AddGroup/styles.js +141 -0
  110. package/src/components/molecules/AsignationInfo/AsignationInfo.stories.js +17 -0
  111. package/src/components/molecules/AsignationInfo/index.js +108 -0
  112. package/src/components/molecules/AsignationInfo/styles.js +86 -0
  113. package/src/components/molecules/BoxAttribute/index.js +32 -25
  114. package/src/components/molecules/BoxAttribute/styles.js +1 -1
  115. package/src/components/molecules/BoxButtons/index.js +23 -22
  116. package/src/components/molecules/CarouselImagesLogin/index.js +1 -1
  117. package/src/components/molecules/EditionActiveImagev2/EditionActiveImagev2.stories.js +12 -0
  118. package/src/components/molecules/EditionActiveImagev2/index.js +15 -0
  119. package/src/components/molecules/EditionActiveImagev2/styles.js +7 -0
  120. package/src/components/molecules/EditionTabs/EditionTabs.stories.js +12 -0
  121. package/src/components/molecules/EditionTabs/index.js +33 -0
  122. package/src/components/molecules/EditionTabs/styles.js +24 -0
  123. package/src/components/molecules/FeaturesBarv2/FeaturesBarv2.stories.js +20 -0
  124. package/src/components/molecules/FeaturesBarv2/index.js +32 -0
  125. package/src/components/molecules/FeaturesBarv2/styles.js +17 -0
  126. package/src/components/molecules/GalleryElement/index.js +76 -1
  127. package/src/components/molecules/GalleryElementv2/GalleryElementv2.stories.js +30 -0
  128. package/src/components/molecules/GalleryElementv2/index.js +142 -0
  129. package/src/components/molecules/GalleryElementv2/styles.js +119 -0
  130. package/src/components/molecules/GalleryHeader/index.js +1 -0
  131. package/src/components/molecules/GalleryHeaderv2/GalleryHeaderv2.stories.js +10 -0
  132. package/src/components/molecules/GalleryHeaderv2/index.js +25 -0
  133. package/src/components/molecules/GalleryHeaderv2/styles.js +47 -0
  134. package/src/components/molecules/GroupSelect/GroupSelect.stories.js +35 -0
  135. package/src/components/molecules/GroupSelect/SelectItem.js +105 -0
  136. package/src/components/molecules/GroupSelect/index.js +190 -0
  137. package/src/components/molecules/GroupSelect/styles.js +124 -0
  138. package/src/components/molecules/HeaderTop/index.js +52 -6
  139. package/src/components/molecules/HeaderTopv2/HeaderTopv2.stories.js +10 -0
  140. package/src/components/molecules/HeaderTopv2/index.js +100 -0
  141. package/src/components/molecules/HeaderTopv2/styles.js +33 -0
  142. package/src/components/molecules/ImageSelectorv2/ImageSelectorv2.stories.js +46 -0
  143. package/src/components/molecules/ImageSelectorv2/index.js +22 -0
  144. package/src/components/molecules/ImageSelectorv2/styles.js +15 -0
  145. package/src/components/molecules/Phase/Phase.stories.js +107 -0
  146. package/src/components/molecules/Phase/index.js +391 -0
  147. package/src/components/molecules/Phase/styles.js +97 -0
  148. package/src/components/molecules/ProductNameHeader/index.js +19 -1
  149. package/src/components/molecules/ProductNameHeaderv2/ProductNameHeaderv2.stories.js +37 -0
  150. package/src/components/molecules/ProductNameHeaderv2/index.js +12 -0
  151. package/src/components/molecules/ProductNameHeaderv2/styles.js +10 -0
  152. package/src/components/molecules/ProductSkuStatus/ProductSkuStatus.stories.js +37 -0
  153. package/src/components/molecules/ProductSkuStatus/index.js +26 -0
  154. package/src/components/molecules/ProductSkuStatus/styles.js +7 -0
  155. package/src/components/molecules/RetailerSelectorv2/RetailerSelectorv2.stories.js +35 -0
  156. package/src/components/molecules/RetailerSelectorv2/index.js +80 -0
  157. package/src/components/molecules/RetailerSelectorv2/styles.js +21 -0
  158. package/src/components/molecules/ServiceDataValidator/ServiceDataValidator.stories.js +90 -0
  159. package/src/components/molecules/ServiceDataValidator/index.js +49 -0
  160. package/src/components/molecules/ServiceDataValidator/styles.js +36 -0
  161. package/src/components/molecules/SignInLogin/index.js +11 -11
  162. package/src/components/molecules/StatusAsignationInfo/FinancedCompanies.js +501 -63
  163. package/src/components/molecules/StatusAsignationInfo/index.js +1 -1
  164. package/src/components/molecules/StatusRetailer/StatusAsignationInfo.stories.js +17 -0
  165. package/src/components/molecules/StatusRetailer/index.js +55 -0
  166. package/src/components/molecules/StatusRetailer/styles.js +85 -0
  167. package/src/components/molecules/StripeCardSelector/CardSelector.stories.js +1 -2
  168. package/src/components/molecules/TabsMenuv2/TabsMenuv2.stories.js +19 -0
  169. package/src/components/molecules/TabsMenuv2/index.js +112 -0
  170. package/src/components/molecules/TabsMenuv2/styles.js +19 -0
  171. package/src/components/molecules/TagAndInput/index.js +8 -6
  172. package/src/components/molecules/TagAndInputv2/TagAndInputv2.stories.js +24 -0
  173. package/src/components/molecules/TagAndInputv2/index.js +86 -0
  174. package/src/components/molecules/TagAndInputv2/styles.js +35 -0
  175. package/src/components/molecules/Validation/Validation.stories.js +12 -0
  176. package/src/components/molecules/Validation/index.js +77 -0
  177. package/src/components/molecules/Validation/styles.js +19 -0
  178. package/src/components/molecules/VersionItemv2/VersionItemv2.stories.js +14 -0
  179. package/src/components/molecules/VersionItemv2/index.js +59 -0
  180. package/src/components/molecules/VersionItemv2/styles.js +47 -0
  181. package/src/components/organisms/BarButtons/BarButtons.stories.js +13 -0
  182. package/src/components/organisms/BarButtons/index.js +150 -0
  183. package/src/components/organisms/BarButtons/styles.js +54 -0
  184. package/src/components/organisms/Chat/Chat.stories.js +27 -7
  185. package/src/components/organisms/Chat/ContainerItems/index.js +18 -2
  186. package/src/components/organisms/Chat/ContainerItems/styles.js +14 -2
  187. package/src/components/organisms/Chat/ContentChat/index.js +88 -12
  188. package/src/components/organisms/Chat/Footer/index.js +11 -0
  189. package/src/components/organisms/Chat/index.js +46 -4
  190. package/src/components/organisms/Chat/styles.js +4 -0
  191. package/src/components/organisms/Chatv2/ChatLists/ChatLists.stories.js +65 -0
  192. package/src/components/organisms/Chatv2/ChatLists/Rotoplas.jpeg +0 -0
  193. package/src/components/organisms/Chatv2/ChatLists/THD.png +0 -0
  194. package/src/components/organisms/Chatv2/ChatLists/index.js +141 -0
  195. package/src/components/organisms/Chatv2/ChatLists/styles.js +162 -0
  196. package/src/components/organisms/Chatv2/Chatv2.stories.js +184 -0
  197. package/src/components/organisms/Chatv2/ContainerItems/ContainerItems.stories.js +142 -0
  198. package/src/components/organisms/Chatv2/ContainerItems/index.js +538 -0
  199. package/src/components/organisms/Chatv2/ContainerItems/styles.js +360 -0
  200. package/src/components/organisms/Chatv2/ContentChat/ContentChat.stories.js +102 -0
  201. package/src/components/organisms/Chatv2/ContentChat/Rotoplas.jpeg +0 -0
  202. package/src/components/organisms/Chatv2/ContentChat/THD.png +0 -0
  203. package/src/components/organisms/Chatv2/ContentChat/index.js +1016 -0
  204. package/src/components/organisms/Chatv2/ContentChat/styles.js +44 -0
  205. package/src/components/organisms/Chatv2/Footer/Footer.stories.js +22 -0
  206. package/src/components/organisms/Chatv2/Footer/index.js +668 -0
  207. package/src/components/organisms/Chatv2/Footer/styles.js +290 -0
  208. package/src/components/organisms/Chatv2/Header/Header.stories.js +66 -0
  209. package/src/components/organisms/Chatv2/Header/index.js +93 -0
  210. package/src/components/organisms/Chatv2/Header/styles.js +49 -0
  211. package/src/components/organisms/Chatv2/index.js +281 -0
  212. package/src/components/organisms/Chatv2/styles.js +85 -0
  213. package/src/components/organisms/CompleteServices/CompleteServices.stories.js +91 -0
  214. package/src/components/organisms/CompleteServices/index.js +82 -0
  215. package/src/components/organisms/CompleteServices/styles.js +35 -0
  216. package/src/components/organisms/DashboardMetric/index.js +6 -3
  217. package/src/components/organisms/DragAndDropPhases/DragAndDropPhases.stories.js +13 -0
  218. package/src/components/organisms/DragAndDropPhases/index.js +336 -0
  219. package/src/components/organisms/DragAndDropPhases/styles.js +107 -0
  220. package/src/components/organisms/DragPrueba/DragPrueba.stories.js +12 -0
  221. package/src/components/organisms/DragPrueba/index.js +57 -0
  222. package/src/components/organisms/DragPrueba/styles.js +8 -0
  223. package/src/components/organisms/EditGroup/EditGroup.stories.js +20 -0
  224. package/src/components/organisms/EditGroup/index.js +321 -0
  225. package/src/components/organisms/EditGroup/styles.js +207 -0
  226. package/src/components/organisms/FullProductNameHeader/index.js +13 -1
  227. package/src/components/organisms/FullProductNamev2/FullProductNamev2.stories.js +28 -0
  228. package/src/components/organisms/FullProductNamev2/index.js +101 -0
  229. package/src/components/organisms/FullProductNamev2/styles.js +49 -0
  230. package/src/components/organisms/FullTabsMenuv2/FullTabsMenuv2.stories.js +22 -0
  231. package/src/components/organisms/FullTabsMenuv2/index.js +142 -0
  232. package/src/components/organisms/FullTabsMenuv2/styles.js +47 -0
  233. package/src/components/organisms/GridProducts/GridProducts.stories.js +682 -107
  234. package/src/components/organisms/ImageDataTablev2/ImageDataTablev2.stories.js +24 -0
  235. package/src/components/organisms/ImageDataTablev2/index.js +124 -0
  236. package/src/components/organisms/ImageDataTablev2/styles.js +18 -0
  237. package/src/components/organisms/ImagePreviewerv2/ImagePreviewerv2.stories.js +38 -0
  238. package/src/components/organisms/ImagePreviewerv2/index.js +22 -0
  239. package/src/components/organisms/ImagePreviewerv2/styles.js +7 -0
  240. package/src/components/organisms/ImageUploader/ImageUploader.stories.js +15 -0
  241. package/src/components/organisms/ImageUploader/index.js +62 -0
  242. package/src/components/organisms/ImageUploader/styles.js +29 -0
  243. package/src/components/organisms/ImageVisor/ImageVisor.stories.js +15 -0
  244. package/src/components/organisms/ImageVisor/index.js +143 -0
  245. package/src/components/organisms/ImageVisor/styles.js +106 -0
  246. package/src/components/organisms/InputGroup/index.js +292 -144
  247. package/src/components/organisms/InputGroup/styles.js +31 -0
  248. package/src/components/organisms/InputGroupv2/InputGroupv2.stories.js +31 -0
  249. package/src/components/organisms/InputGroupv2/index.js +296 -0
  250. package/src/components/organisms/InputGroupv2/styles.js +90 -0
  251. package/src/components/organisms/MandatoryBar/MandatoryBar.stories.js +18 -0
  252. package/src/components/organisms/MandatoryBar/index.js +31 -0
  253. package/src/components/organisms/MandatoryBar/styles.js +12 -0
  254. package/src/components/organisms/Modal/Modal.stories.js +2 -1
  255. package/src/components/organisms/Modal/index.js +9 -2
  256. package/src/components/organisms/Modal/styles.js +8 -1
  257. package/src/components/organisms/OrderDetail/utils/Table/utils.js +6 -16
  258. package/src/components/organisms/ProductImageModalv2/ProductImageModalv2.stories.js +90 -0
  259. package/src/components/organisms/ProductImageModalv2/index.js +105 -0
  260. package/src/components/organisms/ProductImageModalv2/styles.js +71 -0
  261. package/src/components/organisms/RenameImagesBar/RenameImagesBar.stories.js +18 -0
  262. package/src/components/organisms/RenameImagesBar/index.js +30 -0
  263. package/src/components/organisms/RenameImagesBar/styles.js +12 -0
  264. package/src/components/organisms/Table/Table.stories.js +609 -0
  265. package/src/components/organisms/Table/index.js +84 -0
  266. package/src/components/organisms/Table/styles.js +114 -0
  267. package/src/components/organisms/VersionSelectorv2/VersionSelectorv2.stories.js +15 -0
  268. package/src/components/organisms/VersionSelectorv2/index.js +105 -0
  269. package/src/components/organisms/VersionSelectorv2/styles.js +45 -0
  270. package/src/components/pages/Dashboard/Dashboard.stories.js +33 -38
  271. package/src/components/pages/Dashboard/index.js +36 -7
  272. package/src/components/pages/MultipleEdition/MultipleEdition.stories.js +17 -0
  273. package/src/components/pages/MultipleEdition/components/ImageUploader.js +62 -0
  274. package/src/components/pages/MultipleEdition/components/ImageUploaderStyles.js +29 -0
  275. package/src/components/pages/MultipleEdition/components/ImageVisor.js +143 -0
  276. package/src/components/pages/MultipleEdition/components/styles.js +106 -0
  277. package/src/components/pages/MultipleEdition/index.js +248 -0
  278. package/src/components/pages/MultipleEdition/saveData.js +92 -0
  279. package/src/components/pages/MultipleEdition/styles.js +201 -0
  280. package/src/components/pages/MultipleEdition/utils.js +1073 -0
  281. package/src/components/pages/ProductEditionv2/ProductEditionv2.stories.js +213 -0
  282. package/src/components/pages/ProductEditionv2/index.js +1758 -0
  283. package/src/components/pages/ProductEditionv2/styles.js +154 -0
  284. package/src/components/pages/ProviderProductEdition/ProviderProductEdition.stories.js +56 -60
  285. package/src/components/pages/ProviderProductEdition/index.js +148 -133
  286. package/src/components/pages/ProviderProductEdition/styles.js +5 -1
  287. package/src/components/pages/RetailerProductEdition/RetailerProductEdition.stories.js +4 -0
  288. package/src/components/pages/RetailerProductEdition/generateThumnail.js +21 -0
  289. package/src/components/pages/RetailerProductEdition/index.js +293 -300
  290. package/src/components/pages/RetailerProductEdition/styles.js +4 -0
  291. package/src/components/pages/RetailerProductEdition/utils.js +37 -0
  292. package/src/global-files/data.js +6 -10
  293. package/src/global-files/variables.js +6 -0
  294. package/src/index.js +12 -0
@@ -8,6 +8,5 @@ export default {
8
8
  const Template = (args) => <CardSelector {...args} />;
9
9
  export const CardSelectorDefault = Template.bind({});
10
10
  CardSelectorDefault.args = {
11
- jwt: "eyJraWQiOiJkQWJkZCtlclwvTlwveVRQUWNvUlVyOCtrNUd2M1hMM2N1MWUzQ09zWExVRnc9IiwiYWxnIjoiUlMyNTYifQ.eyJzdWIiOiJmNTkyN2Y4ZS1jYmY3LTQ5MjItOWUwOS1lNjllYzBiMjczMWEiLCJjb2duaXRvOmdyb3VwcyI6WyJ1c3VhcmlvX2NvbnRlbnRvaCJdLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwiaXNzIjoiaHR0cHM6XC9cL2NvZ25pdG8taWRwLnVzLWVhc3QtMS5hbWF6b25hd3MuY29tXC91cy1lYXN0LTFfWE1aUWRxa0dqIiwicGhvbmVfbnVtYmVyX3ZlcmlmaWVkIjpmYWxzZSwiY29nbml0bzp1c2VybmFtZSI6ImY1OTI3ZjhlLWNiZjctNDkyMi05ZTA5LWU2OWVjMGIyNzMxYSIsImNvZ25pdG86cm9sZXMiOlsiYXJuOmF3czppYW06Ojg5ODY3MDIzMjgwNzpyb2xlXC9jb250ZW50b2gtZGV2LXVzLWVhc3QtMS1sYW1iZGFSb2xlIl0sImF1ZCI6IjVhYzh0cGdzNmdic3ExM2ZydnJwaWVlcDQwIiwiZXZlbnRfaWQiOiIxMTAyNWQzMi1kMTM5LTQ0MzctYmZlYy1hNWY1Njg0NDdjODciLCJ0b2tlbl91c2UiOiJpZCIsImF1dGhfdGltZSI6MTY5NDQ3ODQ2NSwibmFtZSI6IklzbWFlbCBMb3BleiIsInBob25lX251bWJlciI6Iis1MjMxMTEzNjYzMzYiLCJleHAiOjE2OTQ0ODIwNjUsImlhdCI6MTY5NDQ3ODQ2NSwiZW1haWwiOiJpbG9wZXpAY29udGVudG9oLmNvbSJ9.Fia8x4aahTvCOdt2GohSNoe_9XgBcVuF4bXGWvuNTJ7-_YTe9t1vxGlhw7AG0WC2-tqFiAdx8_UojxqX-UW4lE6vI3pGLmkF7hEfV4XCWq6I3pF5aXYDkRD4YBPyQfzBgwQsx4bR_rm5oRfHPItfc_zJwObV9rQgTYLEQ9u-SL2t0bdx2yOmAjCAtGHp83w5highRkcZx0huKGJnRQ4Wmt5HlgAvsnkzqAimC9E6NH-IDLMAXq8T2f9INPzcdMR403Ybpy3Zrqphw5ITHK1tkUUZxcVsaAnRM7g1-q0OA5S0vRFbcw2lRgaZ_DVJbk0Lzba5NK4nDZ4U97Nw_zXqLA",
12
- isSelected: true,
11
+ jwt: "eyJraWQiOiJkQWJkZCtlclwvTlwveVRQUWNvUlVyOCtrNUd2M1hMM2N1MWUzQ09zWExVRnc9IiwiYWxnIjoiUlMyNTYifQ.eyJzdWIiOiJmNTkyN2Y4ZS1jYmY3LTQ5MjItOWUwOS1lNjllYzBiMjczMWEiLCJjb2duaXRvOmdyb3VwcyI6WyJ1c3VhcmlvX2NvbnRlbnRvaCJdLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwiaXNzIjoiaHR0cHM6XC9cL2NvZ25pdG8taWRwLnVzLWVhc3QtMS5hbWF6b25hd3MuY29tXC91cy1lYXN0LTFfWE1aUWRxa0dqIiwicGhvbmVfbnVtYmVyX3ZlcmlmaWVkIjpmYWxzZSwiY29nbml0bzp1c2VybmFtZSI6ImY1OTI3ZjhlLWNiZjctNDkyMi05ZTA5LWU2OWVjMGIyNzMxYSIsImNvZ25pdG86cm9sZXMiOlsiYXJuOmF3czppYW06Ojg5ODY3MDIzMjgwNzpyb2xlXC9jb250ZW50b2gtZGV2LXVzLWVhc3QtMS1sYW1iZGFSb2xlIl0sImF1ZCI6IjVhYzh0cGdzNmdic3ExM2ZydnJwaWVlcDQwIiwiZXZlbnRfaWQiOiI5ZjQzNjAwMC0wYzgyLTRjNzYtYWEzNi1kM2Q1NGJjZTZiMTMiLCJ0b2tlbl91c2UiOiJpZCIsImF1dGhfdGltZSI6MTY4NTU2OTUyMywibmFtZSI6IklzbWFlbCBMb3BleiIsInBob25lX251bWJlciI6Iis1MjMxMTEzNjYzMzYiLCJleHAiOjE2ODU1NzMxMjMsImlhdCI6MTY4NTU2OTUyMywiZW1haWwiOiJpbG9wZXpAY29udGVudG9oLmNvbSJ9.EotcxmtkUpBxwlXa3bo25iLAmRcT0kj1G3PVITVB_0ZtF8UC19rJIMTNSc1hYkl8cbfCuB_vkjYCAxi4b2SOru5MdMTRhgNjcQTVbiwIYww-QdUWq0WSv84nW_HaRoxCJ8ezm-wBZgUTpcD3VFuynUICbODKKHUfxVdKdVoAM6GGE6ymSbO7-0C7ZumoWEqaZ22BF4G1H-JvLkR-tL5iqXa2N-QCnNoteFmHstBfH6Sp5UZhPav1VBEGRmwdFfUnC-Xc-aNeIFwgWCXMsOXFWbbmWeh0uNF-Btu-QEJ7VkCu4pbElqHWJKBYLCx1zqDBrKrsrNxyvQlxsJ9NSOae8Q",
13
12
  };
@@ -0,0 +1,19 @@
1
+ import { TabsMenuv2 } from "./index";
2
+
3
+ export default {
4
+ title: "Components/molecules/TabsMenuv2",
5
+ component: TabsMenuv2,
6
+ };
7
+
8
+ const Template = (args) => <TabsMenuv2 {...args} />;
9
+
10
+ export const TabsMenuv2Default = Template.bind({});
11
+
12
+ TabsMenuv2Default.args = {
13
+ tabsSections: {
14
+ Descripción: true,
15
+ "Ficha técnica": false,
16
+ Imágenes: false,
17
+ "Golden SKU": false,
18
+ },
19
+ };
@@ -0,0 +1,112 @@
1
+ import { Container } from "./styles";
2
+ import { useEffect, useState } from "react";
3
+
4
+ import { Modal } from "../../organisms/Modal";
5
+ import { ButtonV2 } from "../../atoms/ButtonV2";
6
+ import { TabSectionv2 } from "../../atoms/TabSectionv2";
7
+
8
+ export const TabsMenuv2 = ({
9
+ tabsSections = {},
10
+ setImagesSection,
11
+ setActiveTab,
12
+ activeTab,
13
+ updatedDescriptions,
14
+ updatedDatasheets,
15
+ images,
16
+ setUpdatedDescriptions,
17
+ setUpdatedDatasheets,
18
+ setImages,
19
+ className
20
+ }) => {
21
+ const [sections, setSections] = useState(tabsSections);
22
+
23
+ const [modal, setModal] = useState(false);
24
+ const [cancelAccept, setCancelAccept] = useState("");
25
+ const [llave, setLlave] = useState("");
26
+ const [objeto, setObjeto] = useState();
27
+
28
+ const activeSection = (key, array = {}) => {
29
+ let tempArray = {};
30
+ setImagesSection(key === "Imágenes");
31
+ Object.keys(array).forEach((section) => {
32
+ tempArray[section] = section === key;
33
+ if (section === key) return setActiveTab(key);
34
+ });
35
+ setSections(tempArray);
36
+ };
37
+
38
+ useEffect(() => {
39
+ if (cancelAccept === "Aceptar" && llave !== "") {
40
+ setCancelAccept("");
41
+ setModal(false);
42
+ activeSection(llave, objeto);
43
+ setUpdatedDescriptions([]);
44
+ setUpdatedDatasheets([]);
45
+ setImages({});
46
+ } else if (cancelAccept === "Cancelar" && llave !== "") {
47
+ setModal(false);
48
+ setCancelAccept("");
49
+ }
50
+ }, [cancelAccept]);
51
+
52
+ const detectClickFunction = (e, key, sections) => {
53
+ const targetIsTheCurrentTab = e.target.innerHTML === activeTab;
54
+ const descriptionsWereUpdated = updatedDescriptions.length > 0;
55
+ const datasheetWereUpdated = updatedDatasheets.length > 0;
56
+ const imagesWereUpdated = images?.values?.filter((f) => !f.id)?.length > 0;
57
+ const dataWereUpdated =
58
+ descriptionsWereUpdated || datasheetWereUpdated || imagesWereUpdated;
59
+
60
+ if (!targetIsTheCurrentTab && !dataWereUpdated) {
61
+ setLlave(key);
62
+ setObjeto(sections);
63
+ activeSection(key, sections);
64
+ } else if (!targetIsTheCurrentTab && dataWereUpdated) {
65
+ setModal(true);
66
+ setLlave(key);
67
+ setObjeto(sections);
68
+ }
69
+ };
70
+
71
+ return (
72
+ <>
73
+ {activeTab && (
74
+ <Modal
75
+ show={modal}
76
+ title="Cambios sin Guardar"
77
+ message="Estás cambiando de vista y aun no guardas cambios ¿Estás seguro?"
78
+ buttons={[
79
+ <ButtonV2
80
+ key="btn-Cancelar"
81
+ type="white"
82
+ label="Cancelar"
83
+ size={12}
84
+ onClick={() => setCancelAccept("Cancelar")}
85
+ />,
86
+ <ButtonV2
87
+ key="btn-Aceptar"
88
+ type="pink"
89
+ label="Aceptar"
90
+ size={12}
91
+ onClick={() => setCancelAccept("Aceptar")}
92
+ />,
93
+ ]}
94
+ />
95
+ )}
96
+
97
+ <Container>
98
+ {Object.keys(sections).map((key, index) => (
99
+ <TabSectionv2
100
+ key={index}
101
+ label={key}
102
+ className={`tab ${className}`}
103
+ active={sections[key]}
104
+ onClick={(e) => {
105
+ detectClickFunction(e, key, sections);
106
+ }}
107
+ />
108
+ ))}
109
+ </Container>
110
+ </>
111
+ );
112
+ };
@@ -0,0 +1,19 @@
1
+ import styled from "styled-components";
2
+
3
+ export const Container = styled.div`
4
+ display: flex;
5
+ height: 34px;
6
+ align-items: center;
7
+ div {
8
+ font-family: Raleway-500;
9
+ color: #262626;
10
+ font-size: 12px;
11
+ line-height: 21px;
12
+ border-bottom: none;
13
+ width: 104px;
14
+ padding-bottom: 0px;
15
+ -webkit-transition: 0.1s all;
16
+ transition: 0.1s all;
17
+ cursor: pointer;
18
+ }
19
+ `;
@@ -2,7 +2,8 @@ import { Container } from "./styles";
2
2
  import { ScreenHeader } from "../../atoms/ScreenHeader/index";
3
3
  import { GeneralInput } from "../../atoms/GeneralInput/index";
4
4
  import { useState, useEffect } from "react";
5
-
5
+ import acceptIcon from "../../../assets/images/generalButton/acceptIcon.svg";
6
+ import rejectIcon from "../../../assets/images/generalButton/rejectIcon.svg";
6
7
  export const TagAndInput = ({
7
8
  inputType,
8
9
  label,
@@ -30,12 +31,14 @@ export const TagAndInput = ({
30
31
  onKeyDown,
31
32
  showTooltip,
32
33
  auditClass,
33
- onChange,
34
+ onChange,
34
35
  dataInputs,
35
36
  inputGroup,
36
37
  boxOnboardingData,
37
38
  }) => {
38
- const [boxOnboardingList, setBoxOnboardingList] = useState(boxOnboardingData || []);
39
+ const [boxOnboardingList, setBoxOnboardingList] = useState(
40
+ boxOnboardingData || []
41
+ );
39
42
 
40
43
  useEffect(() => {
41
44
  const temp = {};
@@ -52,12 +55,11 @@ export const TagAndInput = ({
52
55
  if (tempList.length > 0) {
53
56
  setBoxOnboardingList(
54
57
  tempList.map((value, index) =>
55
- index === tempList.length - 1 ? {value } : { value }
58
+ index === tempList.length - 1 ? { value } : { value }
56
59
  )
57
60
  );
58
61
  }
59
62
  }, []);
60
-
61
63
  useEffect(() => {
62
64
  onChange && onChange(boxOnboardingList);
63
65
  }, [boxOnboardingList]);
@@ -68,7 +70,7 @@ export const TagAndInput = ({
68
70
  className={"input-container"}
69
71
  key={`generalTagInput-${inputType}`}
70
72
  >
71
- {label?.length && (
73
+ {label?.length && (
72
74
  <div className="title-container">
73
75
  <ScreenHeader
74
76
  text={label}
@@ -0,0 +1,24 @@
1
+ import { TagAndInputv2 } from "./index";
2
+
3
+ export default {
4
+ title: "Components/molecules/TagAndInputv2",
5
+ component: TagAndInputv2,
6
+ };
7
+
8
+ const Template = (args) => <TagAndInputv2 {...args} />;
9
+
10
+ export const InputType = Template.bind({});
11
+ InputType.args = {
12
+ label: "Default text label",
13
+ inputType: "text",
14
+ value: "default text",
15
+ inputPlaceHolder: "default placeholder",
16
+ };
17
+
18
+ export const TextAreaType = Template.bind({});
19
+ TextAreaType.args = {
20
+ label: "Default textarea label",
21
+ inputType: "textarea",
22
+ value: "default textarea text",
23
+ inputPlaceHolder: "default textarea placeholder",
24
+ };
@@ -0,0 +1,86 @@
1
+ import { Container } from "./styles";
2
+ import { GeneralInputv2 } from "../../atoms/GeneralInputv2";
3
+ import { ScreenHeaderv2 } from "../../atoms/ScreenHeaderv2";
4
+
5
+ export const TagAndInputv2 = ({
6
+ inputType,
7
+ label,
8
+ value,
9
+ inputPlaceHolder,
10
+ inputId,
11
+ updatedDescriptions,
12
+ setUpdatedDescriptions,
13
+ updatedDatasheets,
14
+ setUpdatedDatasheets,
15
+ articleId,
16
+ version,
17
+ index,
18
+ isRequired,
19
+ dinamicHeight,
20
+ inputCols,
21
+ inputRows,
22
+ minChar,
23
+ maxChar,
24
+ minWords,
25
+ maxWords,
26
+ required,
27
+ optionList,
28
+ description,
29
+ inputOnChange,
30
+ color,
31
+ disabled,
32
+ onKeyDown,
33
+ showTooltip,
34
+ auditClass,
35
+ showMissingChars,
36
+ }) => {
37
+ return (
38
+ <Container
39
+ inputType={inputType}
40
+ className={"input-container"}
41
+ key={`generalTagInput-${inputType}`}
42
+ >
43
+ {label?.length && (
44
+ <div className="title-container">
45
+ <ScreenHeaderv2
46
+ text={label}
47
+ headerType={"input-name-header"}
48
+ color={color}
49
+ showInfoTool={true}
50
+ minChar={minChar}
51
+ maxChar={maxChar}
52
+ minWords={minWords}
53
+ maxWords={maxWords}
54
+ required={required}
55
+ description={description}
56
+ showMissingChars={showMissingChars}
57
+ />
58
+ </div>
59
+ )}
60
+ <GeneralInputv2
61
+ inputId={inputId}
62
+ inputType={inputType}
63
+ inputValue={value}
64
+ index={index}
65
+ disabled={disabled}
66
+ isRequired={isRequired}
67
+ inputPlaceholder={inputPlaceHolder}
68
+ updatedDescriptions={updatedDescriptions}
69
+ setUpdatedDescriptions={setUpdatedDescriptions}
70
+ updatedDatasheets={updatedDatasheets}
71
+ setUpdatedDatasheets={setUpdatedDatasheets}
72
+ articleId={articleId}
73
+ version={version}
74
+ dinamicHeight={dinamicHeight}
75
+ inputCols={inputCols}
76
+ inputRows={inputRows}
77
+ maxChar={maxChar}
78
+ optionList={optionList}
79
+ description={description}
80
+ inputOnChange={inputOnChange}
81
+ onKeyDown={onKeyDown}
82
+ auditClass={auditClass}
83
+ />
84
+ </Container>
85
+ );
86
+ };
@@ -0,0 +1,35 @@
1
+ import styled from "styled-components";
2
+ import { FontFamily, GlobalColors } from "../../../global-files/variables";
3
+
4
+ export const Container = styled.div`
5
+ .title-container {
6
+ position: relative;
7
+ .tooltip {
8
+ display: none;
9
+ position: absolute;
10
+ background-color: ${GlobalColors.white};
11
+ color: ${({ color }) => (color ? color : GlobalColors.s5)};
12
+ font-family: ${FontFamily.Raleway};
13
+ font-size: 12px;
14
+ line-height: 19px;
15
+ left: 0;
16
+ top: 0;
17
+ height: fit-content;
18
+ }
19
+
20
+ // &:hover {
21
+ // .tooltip {
22
+ // display: block;
23
+ // }
24
+ // }
25
+ }
26
+
27
+ // & > :first-child {
28
+ // & + * {
29
+ // margin-top: ${({ inputType }) => (inputType !== "textarea" ? 4 : 15)}px;
30
+ // }
31
+ // }
32
+ & + * {
33
+ margin-top: ${({ inputType }) => (inputType !== "textarea" ? 0 : 10)}px;
34
+ }
35
+ `;
@@ -0,0 +1,12 @@
1
+ import { AvatarAndValidation } from "./index";
2
+
3
+ export default {
4
+ title: "Components/molecules/AvatarAndValidation",
5
+ component: AvatarAndValidation,
6
+ };
7
+
8
+ const Template = (args) => <AvatarAndValidation {...args} />;
9
+
10
+ export const AvatarAndValidationDefault = Template.bind({});
11
+
12
+ AvatarAndValidationDefault.args = {};
@@ -0,0 +1,77 @@
1
+ import { useState } from "react";
2
+
3
+ //Components
4
+ import { Container } from "./styles";
5
+ import { Button } from "../../atoms/GeneralButton";
6
+ import { ValidationPanel } from "../../atoms/ValidationPanel";
7
+ import { useEffect } from "react";
8
+ import { RetailerSelector } from "../RetailerSelector";
9
+ import { ButtonV2 } from "../../atoms/ButtonV2";
10
+
11
+ export const Validation = ({
12
+ retailers,
13
+ validation,
14
+ activeRetailer,
15
+ setActiveRetailer,
16
+ showValidationButtons,
17
+ approve,
18
+ reject,
19
+ approveAll,
20
+ rejectAll,
21
+ showApproveRejectAll,
22
+ }) => {
23
+ const [showValidationPanel, setShowValidationPanel] = useState(false);
24
+ const [buttonType, setButtonType] = useState(
25
+ validation ? validation : "null-button"
26
+ );
27
+
28
+ const closeValidationPanel = (e) => {
29
+ if (
30
+ !e.target.closest("#validation-panel") ||
31
+ (e.target.closest(".validation-option") && showValidationPanel)
32
+ ) {
33
+ document.removeEventListener("click", closeValidationPanel, false);
34
+ setShowValidationPanel(false);
35
+ }
36
+ };
37
+
38
+ useEffect(() => {
39
+ if (showValidationPanel) {
40
+ document.addEventListener("click", closeValidationPanel, false);
41
+ }
42
+ }, [showValidationPanel]);
43
+
44
+ return (
45
+ <Container>
46
+ <div className="buttons-container">
47
+ {showValidationButtons && (
48
+ <ButtonV2
49
+ id={"btn-validar-info"}
50
+ key={"btn-validar-info"}
51
+ type={"pink"}
52
+ className="button-height"
53
+ borderType={"oval"}
54
+ label={"Validar información"}
55
+ size={10}
56
+ onClick={(e) => {
57
+ e.stopPropagation();
58
+ setShowValidationPanel(true);
59
+ }}
60
+ />
61
+ )}
62
+ </div>
63
+ {showValidationPanel && (
64
+ <ValidationPanel
65
+ id="validation-panel"
66
+ setOptionClicked={setButtonType}
67
+ setShowValidationPanel={setShowValidationPanel}
68
+ approve={approve}
69
+ reject={reject}
70
+ approveAll={approveAll}
71
+ rejectAll={rejectAll}
72
+ showApproveRejectAll={showApproveRejectAll}
73
+ />
74
+ )}
75
+ </Container>
76
+ );
77
+ };
@@ -0,0 +1,19 @@
1
+ import styled from "styled-components";
2
+
3
+ export const Container = styled.div`
4
+ position: relative;
5
+ width: fit-content;
6
+
7
+ .buttons-container {
8
+ display: flex;
9
+ align-items: center;
10
+
11
+ > * + * {
12
+ margin-left: 3px;
13
+ }
14
+ }
15
+ #btn-validar-info button{
16
+ height:20px;
17
+ padding:4px 10px;
18
+ }
19
+ `;
@@ -0,0 +1,14 @@
1
+ import { VersionItemv2 } from "./index";
2
+
3
+ export default {
4
+ title: "Components/molecules/VersionItemv2",
5
+ component: VersionItemv2,
6
+ };
7
+
8
+ const Template = (args) => <VersionItemv2 {...args} />;
9
+
10
+ export const VersionItemv2Default = Template.bind({});
11
+
12
+ VersionItemv2Default.args = {
13
+
14
+ };
@@ -0,0 +1,59 @@
1
+ import { Avatar } from "../../atoms/Avatar/index";
2
+ import { Container } from "./styles";
3
+ import nullIcon from "../../../assets/images/versionSelector/nullIcon.svg";
4
+ import acceptIcon from "../../../assets/images/versionSelector/acceptIcon.svg";
5
+ import versionSelected from "../../../assets/images/versionSelector/versionSelected.svg";
6
+ import { Button } from "../../atoms/GeneralButton";
7
+ import { ScreenHeader } from "../../atoms/ScreenHeader";
8
+ import { FontFamily, GlobalColors } from "../../../global-files/variables";
9
+
10
+ export const VersionItemv2 = ({
11
+ version = "",
12
+ articleStatus,
13
+ currentVersion,
14
+ productOwner = "owner test",
15
+ setVersion,
16
+ timestamp,
17
+ }) => {
18
+ let textExportedDate = "";
19
+ if (timestamp !== null) {
20
+ const exportedDate = new Date(timestamp).toLocaleDateString();
21
+ textExportedDate = `Última vez exportado: ${exportedDate}`;
22
+ }
23
+
24
+ return (
25
+ <Container className={(currentVersion ? "active" : "disabled")} onClick={() => setVersion && setVersion(version)}>
26
+ <div className="header">
27
+ {/* <Button
28
+ buttonType={"circular-button" + (currentVersion ? " disabled" : "")}
29
+ image={versionSelected}
30
+
31
+ /> */}
32
+
33
+ </div>
34
+ <div className="version-info">
35
+ <div className="version-title">
36
+ <ScreenHeader
37
+ text={"Versión " + version}
38
+ headerType={"input-name-header"}
39
+ color={GlobalColors.black}
40
+ />
41
+ <img
42
+ src={articleStatus ? acceptIcon : nullIcon}
43
+ alt={articleStatus ? "Validated version" : "Unvalidated version"}
44
+ />
45
+ </div>
46
+
47
+ <p>{textExportedDate}</p>
48
+ <p>
49
+ {currentVersion
50
+ ? "Versión actual"
51
+ : articleStatus
52
+ ? "Edición Content-Oh!"
53
+ : "Versión de " + productOwner}
54
+ </p>
55
+ <p>{articleStatus ? "Content-Oh! digital" : productOwner}</p>
56
+ </div>
57
+ </Container>
58
+ );
59
+ };
@@ -0,0 +1,47 @@
1
+ import { FontFamily, GlobalColors } from "../../../global-files/variables";
2
+ import styled from "styled-components";
3
+
4
+ export const Container = styled.div`
5
+ background-color: ${GlobalColors.white};
6
+ padding: 5px 10px;
7
+ border-radius:10px;
8
+ &.disabled {
9
+ border: 1px solid ${GlobalColors.gray_light};
10
+ }
11
+ &.active {
12
+ border: 1px solid ${GlobalColors.purple};
13
+ background:rgba(138,108,170,0.2);
14
+ }
15
+ .header {
16
+ display: flex;
17
+ justify-content: space-between;
18
+ align-items: center;
19
+ }
20
+ .version-title {
21
+ display:flex;
22
+ justify-content:space-between;
23
+ align-items: center;
24
+ }
25
+ .version-info {
26
+ text-align: left;
27
+ h2{
28
+ font-size: 12px;
29
+ font-family: ${FontFamily.RobotoMedium}, sans-serif;
30
+ }
31
+ p {
32
+ & + * {
33
+ margin-top: 5px;
34
+ }
35
+ }
36
+
37
+ p {
38
+ font-size: 12px;
39
+ font-family: ${FontFamily.RobotoRegular}, sans-serif;
40
+ color: ${GlobalColors.gray};
41
+ }
42
+ }
43
+
44
+ & + * {
45
+ margin-top: 10px;
46
+ }
47
+ `;
@@ -0,0 +1,13 @@
1
+ import { BarButtons } from "./index";
2
+
3
+ export default {
4
+ title: "Components/organisms/BarButtons",
5
+ component: BarButtons,
6
+ };
7
+
8
+ const Template = (args) => <BarButtons {...args} />;
9
+
10
+ export const BarButtonsDefault = Template.bind({});
11
+ BarButtonsDefault.args = {
12
+ panelText:"Elige la plataforma que conecta proovedores y retailers",
13
+ };