contentoh-components-library 21.3.60 → 21.3.61
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.
- package/.env.development +0 -2
- package/dist/components/molecules/CarouselImagesLogin/index.js +1 -1
- package/dist/components/molecules/HeaderTop/index.js +11 -68
- package/dist/components/organisms/Chat/Chat.stories.js +1 -21
- package/dist/components/organisms/Chat/ContainerItems/index.js +3 -19
- package/dist/components/organisms/Chat/ContainerItems/styles.js +1 -1
- package/dist/components/organisms/Chat/ContentChat/index.js +191 -343
- package/dist/components/organisms/Chat/Footer/index.js +39 -48
- package/dist/components/organisms/Chat/index.js +3 -48
- package/dist/components/organisms/FullProductNameHeader/index.js +2 -2
- package/dist/components/pages/ProviderProductEdition/ProviderProductEdition.stories.js +127 -172
- package/dist/components/pages/ProviderProductEdition/index.js +129 -188
- package/dist/components/pages/ProviderProductEdition/styles.js +1 -1
- package/dist/components/pages/RetailerProductEdition/RetailerProductEdition.stories.js +28 -40
- package/dist/components/pages/RetailerProductEdition/index.js +281 -292
- package/dist/components/pages/RetailerProductEdition/styles.js +1 -1
- package/dist/components/pages/RetailerProductEdition/utils.js +2 -61
- package/package.json +1 -1
- package/src/components/molecules/CarouselImagesLogin/index.js +1 -1
- package/src/components/molecules/HeaderTop/index.js +6 -52
- package/src/components/organisms/Chat/Chat.stories.js +0 -21
- package/src/components/organisms/Chat/ContainerItems/index.js +2 -18
- package/src/components/organisms/Chat/ContainerItems/styles.js +2 -10
- package/src/components/organisms/Chat/ContentChat/index.js +6 -81
- package/src/components/organisms/Chat/Footer/index.js +0 -11
- package/src/components/organisms/Chat/index.js +3 -47
- package/src/components/organisms/FullProductNameHeader/index.js +1 -1
- package/src/components/pages/ProviderProductEdition/ProviderProductEdition.stories.js +130 -177
- package/src/components/pages/ProviderProductEdition/index.js +55 -105
- package/src/components/pages/ProviderProductEdition/styles.js +1 -5
- package/src/components/pages/RetailerProductEdition/RetailerProductEdition.stories.js +26 -38
- package/src/components/pages/RetailerProductEdition/index.js +135 -130
- package/src/components/pages/RetailerProductEdition/styles.js +0 -4
- package/src/components/pages/RetailerProductEdition/utils.js +0 -37
- package/dist/components/organisms/SideModal/SideModal.stories.js +0 -42
- package/dist/components/organisms/SideModal/index.js +0 -61
- package/dist/components/organisms/SideModal/styles.js +0 -18
- package/src/components/organisms/SideModal/SideModal.stories.js +0 -23
- package/src/components/organisms/SideModal/index.js +0 -41
- package/src/components/organisms/SideModal/styles.js +0 -21
|
@@ -16,194 +16,120 @@ ProviderProductEditionDefault.args = {
|
|
|
16
16
|
Imágenes: false,
|
|
17
17
|
},
|
|
18
18
|
token:
|
|
19
|
-
"eyJraWQiOiJkQWJkZCtlclwvTlwveVRQUWNvUlVyOCtrNUd2M1hMM2N1MWUzQ09zWExVRnc9IiwiYWxnIjoiUlMyNTYifQ.
|
|
19
|
+
"eyJraWQiOiJkQWJkZCtlclwvTlwveVRQUWNvUlVyOCtrNUd2M1hMM2N1MWUzQ09zWExVRnc9IiwiYWxnIjoiUlMyNTYifQ.eyJzdWIiOiI1ODg0YWUzNC01OWQ2LTQ0NTQtYjk4ZS04MjE1MThiY2MzYTciLCJjb2duaXRvOmdyb3VwcyI6WyJ1c3VhcmlvX2NvbnRlbnRvaCJdLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwiaXNzIjoiaHR0cHM6XC9cL2NvZ25pdG8taWRwLnVzLWVhc3QtMS5hbWF6b25hd3MuY29tXC91cy1lYXN0LTFfWE1aUWRxa0dqIiwicGhvbmVfbnVtYmVyX3ZlcmlmaWVkIjpmYWxzZSwiY29nbml0bzp1c2VybmFtZSI6IjU4ODRhZTM0LTU5ZDYtNDQ1NC1iOThlLTgyMTUxOGJjYzNhNyIsImNvZ25pdG86cm9sZXMiOlsiYXJuOmF3czppYW06Ojg5ODY3MDIzMjgwNzpyb2xlXC9jb250ZW50b2gtZGV2LXVzLWVhc3QtMS1sYW1iZGFSb2xlIl0sImF1ZCI6IjVhYzh0cGdzNmdic3ExM2ZydnJwaWVlcDQwIiwiZXZlbnRfaWQiOiJjOWRjOWE1OS0xNTAxLTQyOTgtODRjMi03MDM4NzRhNzIxMTEiLCJ0b2tlbl91c2UiOiJpZCIsImF1dGhfdGltZSI6MTY4MjQ2Mjc4NCwibmFtZSI6IkNhZGVuYSBJc21hZWwiLCJwaG9uZV9udW1iZXIiOiIrNTIzMTExMzY2MzM2IiwiZXhwIjoxNjgyNDY2Mzg0LCJpYXQiOjE2ODI0NjI3ODQsImVtYWlsIjoiY2FkZW5hLmlzbWFlbEBhbGxmcmVlbWFpbC5uZXQifQ.ebKSsnTxKoNfWDoKGFJRlLWgNulGj4KrDe0EgsqLEIVx3Qu0lgmg43UY5tZ3FUlRE8XO2UGq0XxEgdbGOe_4nbTRYigdvxP3bh3cPQ0s68hlTDfhPRvxVJYlaO4s0rhk9rt_VVteTyLfhPHFCymrkFYYDB8bVvKnxUUCX_nJvqGQkl48JiYgvYVLpuus5FvRkGwi1u-jTtMoKiUK-jw9MxI18hD0FWXVnJr-q9ftf2d0bv4JRv4XJ_tRh1N6jps5n3c_KKZswqRfGLU-8MS2X3DU6pDqEP2BZAGXksiFYXYH_uHE6BKJAl7EEhkDTqZsx_jWtVSXTdDg_QDKrOw0Kg",
|
|
20
20
|
articleId: 238,
|
|
21
21
|
category: 846,
|
|
22
22
|
version: 2,
|
|
23
23
|
productSelected: {
|
|
24
|
-
orderId:
|
|
25
|
-
|
|
26
|
-
datasheet_status: "
|
|
24
|
+
orderId: 15165,
|
|
25
|
+
article_status: "AAC",
|
|
26
|
+
datasheet_status: "AAC",
|
|
27
|
+
description_status: "FAP",
|
|
28
|
+
images_status: "FAP",
|
|
27
29
|
prio: "none",
|
|
28
30
|
version: 3,
|
|
29
|
-
|
|
30
|
-
images_status: "AA",
|
|
31
|
-
brand: "Garnier",
|
|
32
|
-
retailerOrder: 0,
|
|
33
|
-
missing: {
|
|
34
|
-
datasheet: null,
|
|
35
|
-
descriptions: null,
|
|
36
|
-
images: null,
|
|
37
|
-
},
|
|
38
|
-
services: {
|
|
39
|
-
datasheets: 1,
|
|
40
|
-
descriptions: 1,
|
|
41
|
-
images: 1,
|
|
42
|
-
},
|
|
31
|
+
brand: null,
|
|
43
32
|
article: {
|
|
44
|
-
category:
|
|
45
|
-
|
|
46
|
-
|
|
33
|
+
category: "Puertas y Ventanas|Molduras|Molduras Madera Blanda",
|
|
34
|
+
company_name: "Demo",
|
|
35
|
+
id_company: 923,
|
|
47
36
|
country: "México",
|
|
48
|
-
id_category: "
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
id_description_facilitator: 52,
|
|
53
|
-
id_images_especialist: 55,
|
|
54
|
-
id_images_facilitator: 53,
|
|
55
|
-
id_order: 15142,
|
|
56
|
-
id_article: 39270,
|
|
57
|
-
id_auditor: 37,
|
|
58
|
-
name: "Acondicionador Garnier Fructis 650 ml",
|
|
59
|
-
timestamp: "2023-03-27T18:37:48.000Z",
|
|
60
|
-
upc: "750955287656712",
|
|
37
|
+
id_category: "2366",
|
|
38
|
+
id_article: 39336,
|
|
39
|
+
name: "Prueba Auditoria",
|
|
40
|
+
upc: "100030124",
|
|
61
41
|
},
|
|
62
42
|
retailers: [
|
|
63
43
|
{
|
|
64
|
-
id:
|
|
65
|
-
name: "
|
|
44
|
+
id: 58,
|
|
45
|
+
name: "The Home Depot Golden",
|
|
66
46
|
},
|
|
67
47
|
{
|
|
68
|
-
id:
|
|
69
|
-
name: "
|
|
70
|
-
},
|
|
71
|
-
{
|
|
72
|
-
id: 63,
|
|
73
|
-
name: "DAX",
|
|
48
|
+
id: 68,
|
|
49
|
+
name: "The Home Depot Dropship",
|
|
74
50
|
},
|
|
75
51
|
],
|
|
52
|
+
services: {
|
|
53
|
+
datasheets: 1,
|
|
54
|
+
descriptions: 1,
|
|
55
|
+
images: 1,
|
|
56
|
+
},
|
|
76
57
|
statusByRetailer: {
|
|
77
|
-
|
|
78
|
-
datasheet: "
|
|
79
|
-
description: "
|
|
80
|
-
images: "
|
|
81
|
-
},
|
|
82
|
-
29: {
|
|
83
|
-
datasheet: "AA",
|
|
84
|
-
description: "AA",
|
|
85
|
-
images: "AA",
|
|
86
|
-
},
|
|
87
|
-
63: {
|
|
88
|
-
datasheet: "AA",
|
|
89
|
-
description: "AA",
|
|
90
|
-
images: "AA",
|
|
58
|
+
58: {
|
|
59
|
+
datasheet: "AAC",
|
|
60
|
+
description: "FAP",
|
|
61
|
+
images: "FAP",
|
|
91
62
|
},
|
|
92
63
|
},
|
|
93
|
-
|
|
64
|
+
retailersWithService: ["58"],
|
|
65
|
+
id_article: 39336,
|
|
94
66
|
retailersAvailable: [
|
|
95
67
|
{
|
|
96
|
-
id:
|
|
97
|
-
name: "
|
|
98
|
-
},
|
|
99
|
-
{
|
|
100
|
-
id: 29,
|
|
101
|
-
name: "Farmacias del Ahorro",
|
|
68
|
+
id: 58,
|
|
69
|
+
name: "The Home Depot Golden",
|
|
102
70
|
},
|
|
103
71
|
{
|
|
104
|
-
id:
|
|
105
|
-
name: "
|
|
72
|
+
id: 68,
|
|
73
|
+
name: "The Home Depot Dropship",
|
|
106
74
|
},
|
|
107
75
|
],
|
|
108
|
-
categoryName:
|
|
109
|
-
"Salud y Belleza|Cuidado del Cabello|Shampoos y Acondicionadores",
|
|
110
|
-
upc: "750955287656712",
|
|
111
|
-
id_article: 39270,
|
|
112
|
-
id_order: 15142,
|
|
113
76
|
},
|
|
114
77
|
productToEdit: {
|
|
115
|
-
ArticleId:
|
|
116
|
-
idCategory: "
|
|
78
|
+
ArticleId: 39336,
|
|
79
|
+
idCategory: "2366",
|
|
117
80
|
product: {
|
|
118
|
-
orderId:
|
|
119
|
-
|
|
120
|
-
datasheet_status: "
|
|
81
|
+
orderId: 15165,
|
|
82
|
+
article_status: "AAC",
|
|
83
|
+
datasheet_status: "AAC",
|
|
84
|
+
description_status: "FAP",
|
|
85
|
+
images_status: "FAP",
|
|
121
86
|
prio: "none",
|
|
122
87
|
version: 3,
|
|
123
|
-
|
|
124
|
-
images_status: "AA",
|
|
125
|
-
brand: "Garnier",
|
|
126
|
-
retailerOrder: 0,
|
|
127
|
-
missing: {
|
|
128
|
-
datasheet: null,
|
|
129
|
-
descriptions: null,
|
|
130
|
-
images: null,
|
|
131
|
-
},
|
|
132
|
-
services: {
|
|
133
|
-
datasheets: 1,
|
|
134
|
-
descriptions: 1,
|
|
135
|
-
images: 1,
|
|
136
|
-
},
|
|
88
|
+
brand: null,
|
|
137
89
|
article: {
|
|
138
|
-
category:
|
|
139
|
-
|
|
140
|
-
|
|
90
|
+
category: "Puertas y Ventanas|Molduras|Molduras Madera Blanda",
|
|
91
|
+
company_name: "Demo",
|
|
92
|
+
id_company: 923,
|
|
141
93
|
country: "México",
|
|
142
|
-
id_category: "
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
id_description_facilitator: 52,
|
|
147
|
-
id_images_especialist: 55,
|
|
148
|
-
id_images_facilitator: 53,
|
|
149
|
-
id_order: 15142,
|
|
150
|
-
id_article: 39270,
|
|
151
|
-
id_auditor: 37,
|
|
152
|
-
name: "Acondicionador Garnier Fructis 650 ml",
|
|
153
|
-
timestamp: "2023-03-27T18:37:48.000Z",
|
|
154
|
-
upc: "750955287656712",
|
|
94
|
+
id_category: "2366",
|
|
95
|
+
id_article: 39336,
|
|
96
|
+
name: "Prueba Auditoria",
|
|
97
|
+
upc: "100030124",
|
|
155
98
|
},
|
|
156
99
|
retailers: [
|
|
157
100
|
{
|
|
158
|
-
id:
|
|
159
|
-
name: "
|
|
101
|
+
id: 58,
|
|
102
|
+
name: "The Home Depot Golden",
|
|
160
103
|
},
|
|
161
104
|
{
|
|
162
|
-
id:
|
|
163
|
-
name: "
|
|
164
|
-
},
|
|
165
|
-
{
|
|
166
|
-
id: 63,
|
|
167
|
-
name: "DAX",
|
|
105
|
+
id: 68,
|
|
106
|
+
name: "The Home Depot Dropship",
|
|
168
107
|
},
|
|
169
108
|
],
|
|
109
|
+
services: {
|
|
110
|
+
datasheets: 1,
|
|
111
|
+
descriptions: 1,
|
|
112
|
+
images: 1,
|
|
113
|
+
},
|
|
170
114
|
statusByRetailer: {
|
|
171
|
-
|
|
172
|
-
datasheet: "
|
|
173
|
-
description: "
|
|
174
|
-
images: "
|
|
175
|
-
},
|
|
176
|
-
29: {
|
|
177
|
-
datasheet: "AA",
|
|
178
|
-
description: "AA",
|
|
179
|
-
images: "AA",
|
|
180
|
-
},
|
|
181
|
-
63: {
|
|
182
|
-
datasheet: "AA",
|
|
183
|
-
description: "AA",
|
|
184
|
-
images: "AA",
|
|
115
|
+
58: {
|
|
116
|
+
datasheet: "AAC",
|
|
117
|
+
description: "FAP",
|
|
118
|
+
images: "FAP",
|
|
185
119
|
},
|
|
186
120
|
},
|
|
187
|
-
|
|
121
|
+
retailersWithService: ["58"],
|
|
122
|
+
id_article: 39336,
|
|
188
123
|
retailersAvailable: [
|
|
189
124
|
{
|
|
190
|
-
id:
|
|
191
|
-
name: "
|
|
125
|
+
id: 58,
|
|
126
|
+
name: "The Home Depot Golden",
|
|
192
127
|
},
|
|
193
128
|
{
|
|
194
|
-
id:
|
|
195
|
-
name: "
|
|
196
|
-
},
|
|
197
|
-
{
|
|
198
|
-
id: 63,
|
|
199
|
-
name: "DAX",
|
|
129
|
+
id: 68,
|
|
130
|
+
name: "The Home Depot Dropship",
|
|
200
131
|
},
|
|
201
132
|
],
|
|
202
|
-
categoryName:
|
|
203
|
-
"Salud y Belleza|Cuidado del Cabello|Shampoos y Acondicionadores",
|
|
204
|
-
upc: "750955287656712",
|
|
205
|
-
id_article: 39270,
|
|
206
|
-
id_order: 15142,
|
|
207
133
|
},
|
|
208
134
|
},
|
|
209
135
|
location: {
|
|
@@ -212,63 +138,90 @@ ProviderProductEditionDefault.args = {
|
|
|
212
138
|
hash: "",
|
|
213
139
|
state: {
|
|
214
140
|
withChat: true,
|
|
215
|
-
chatType: "product_status",
|
|
216
|
-
origin: "RequestWithContentoh",
|
|
217
141
|
},
|
|
218
142
|
key: "24vwut",
|
|
219
143
|
},
|
|
220
144
|
user: {
|
|
221
|
-
id_user:
|
|
222
|
-
name: "
|
|
223
|
-
last_name: "
|
|
224
|
-
email: "
|
|
225
|
-
position: "
|
|
145
|
+
id_user: 59,
|
|
146
|
+
name: "Cadena",
|
|
147
|
+
last_name: "Comercial",
|
|
148
|
+
email: "cadena.ismael@allfreemail.net",
|
|
149
|
+
position: "Admin",
|
|
226
150
|
telephone: "+523111366336",
|
|
227
151
|
country: "México",
|
|
228
|
-
id_company:
|
|
229
|
-
id_cognito: "
|
|
152
|
+
id_company: 817,
|
|
153
|
+
id_cognito: "5884ae34-59d6-4454-b98e-821518bcc3a7",
|
|
230
154
|
birth_Date: null,
|
|
231
155
|
about_me: "",
|
|
232
156
|
zip_code: "",
|
|
233
157
|
address: "",
|
|
234
158
|
job: "",
|
|
235
|
-
id_stripe: "
|
|
159
|
+
id_stripe: "",
|
|
236
160
|
id_role: 0,
|
|
237
161
|
active: 1,
|
|
238
|
-
is_retailer:
|
|
239
|
-
email_notify:
|
|
240
|
-
is_user_tech:
|
|
162
|
+
is_retailer: 1,
|
|
163
|
+
email_notify: 0,
|
|
164
|
+
is_user_tech: null,
|
|
241
165
|
membership: {
|
|
242
|
-
id:
|
|
243
|
-
start_date: "2022-
|
|
244
|
-
end_date: "2023-
|
|
245
|
-
planID:
|
|
246
|
-
plan: "
|
|
166
|
+
id: 47,
|
|
167
|
+
start_date: "2022-05-25T14:31:12.000Z",
|
|
168
|
+
end_date: "2023-05-25T14:31:12.000Z",
|
|
169
|
+
planID: 5,
|
|
170
|
+
plan: "prod_Ktl6B5Ou2gqTB2",
|
|
247
171
|
name: "Plan Pro",
|
|
248
|
-
user_limit: "
|
|
249
|
-
products_limit: "
|
|
250
|
-
type: "
|
|
172
|
+
user_limit: "5",
|
|
173
|
+
products_limit: "500",
|
|
174
|
+
type: "PyMES",
|
|
251
175
|
},
|
|
252
|
-
src: "https://content-management-profile.s3.amazonaws.com/id-
|
|
176
|
+
src: "https://content-management-profile.s3.amazonaws.com/id-59/59.png?1682462786497",
|
|
253
177
|
},
|
|
254
178
|
company: {
|
|
255
|
-
id_company:
|
|
256
|
-
trade_name: "
|
|
257
|
-
company_name: "
|
|
258
|
-
rfc: "
|
|
259
|
-
adress: "
|
|
260
|
-
about_company:
|
|
261
|
-
telephone:
|
|
262
|
-
web_site:
|
|
263
|
-
zip_code:
|
|
179
|
+
id_company: 817,
|
|
180
|
+
trade_name: "Retailer acc",
|
|
181
|
+
company_name: "Retailer acc",
|
|
182
|
+
rfc: "ASER12345",
|
|
183
|
+
adress: "Av. Insurgentes",
|
|
184
|
+
about_company: null,
|
|
185
|
+
telephone: null,
|
|
186
|
+
web_site: null,
|
|
187
|
+
zip_code: null,
|
|
264
188
|
email: null,
|
|
265
|
-
social_link:
|
|
266
|
-
is_retailer:
|
|
189
|
+
social_link: null,
|
|
190
|
+
is_retailer: 1,
|
|
191
|
+
financedRetailers: [
|
|
192
|
+
{
|
|
193
|
+
id: 68,
|
|
194
|
+
name: "The Home Depot Dropship",
|
|
195
|
+
country: "México",
|
|
196
|
+
id_region: 1,
|
|
197
|
+
active: 1,
|
|
198
|
+
},
|
|
199
|
+
],
|
|
267
200
|
retailers: [
|
|
268
201
|
{
|
|
269
|
-
id:
|
|
270
|
-
name:
|
|
271
|
-
country:
|
|
202
|
+
id: 59,
|
|
203
|
+
name: "The Home Depot Platinum",
|
|
204
|
+
country: "México",
|
|
205
|
+
},
|
|
206
|
+
{
|
|
207
|
+
id: 60,
|
|
208
|
+
name: "The Home Depot Resizing",
|
|
209
|
+
country: "México",
|
|
210
|
+
},
|
|
211
|
+
{
|
|
212
|
+
id: 61,
|
|
213
|
+
name: "Home Depot TAB",
|
|
214
|
+
country: "México",
|
|
215
|
+
},
|
|
216
|
+
{
|
|
217
|
+
id: 68,
|
|
218
|
+
name: "The Home Depot Dropship",
|
|
219
|
+
country: "México",
|
|
220
|
+
},
|
|
221
|
+
{
|
|
222
|
+
id: 58,
|
|
223
|
+
name: "The Home Depot Golden",
|
|
224
|
+
country: "México",
|
|
272
225
|
},
|
|
273
226
|
],
|
|
274
227
|
},
|
|
@@ -39,9 +39,6 @@ import Slide1_4 from "../../../assets/images/sliderToolTip/slide4.svg";
|
|
|
39
39
|
import Slide1_5 from "../../../assets/images/sliderToolTip/slide5.svg";
|
|
40
40
|
import { VersionSelector } from "../../organisms/VersionSelector";
|
|
41
41
|
import { useCloseModal } from "../../../global-files/customHooks";
|
|
42
|
-
import { createMessage, sendMessage } from "../RetailerProductEdition/utils";
|
|
43
|
-
import { Modal } from "../../organisms/Modal";
|
|
44
|
-
import { ButtonV2 } from "../../atoms/ButtonV2";
|
|
45
42
|
|
|
46
43
|
const reducerImages = (state, action) => {
|
|
47
44
|
let { values, attrForImgs, inputsByRetailer } = state;
|
|
@@ -217,7 +214,6 @@ export const ProviderProductEdition = ({
|
|
|
217
214
|
const isRetailer = user?.is_retailer;
|
|
218
215
|
const [loading, setLoading] = useState(true);
|
|
219
216
|
const [validatedAll, setValidatedAll] = useState(false);
|
|
220
|
-
const [showRejectModal, setShowRejectModal] = useState(false);
|
|
221
217
|
|
|
222
218
|
const originProp = location?.state?.origin;
|
|
223
219
|
const [origin, setOrigin] = useState({
|
|
@@ -347,6 +343,28 @@ export const ProviderProductEdition = ({
|
|
|
347
343
|
(type) => {
|
|
348
344
|
const formatter = new Intl.ListFormat("es", { type: "conjunction" });
|
|
349
345
|
switch (type) {
|
|
346
|
+
case "error":
|
|
347
|
+
setGlobalModal({
|
|
348
|
+
message: `${activeTab} rechazada`,
|
|
349
|
+
detail: "Agrega tu comentarios para enviar el rechazo",
|
|
350
|
+
img: errorModal,
|
|
351
|
+
textArea: true,
|
|
352
|
+
button1: {
|
|
353
|
+
name: "Enviar",
|
|
354
|
+
action: (e) => {
|
|
355
|
+
const textArea = document.querySelector("#area");
|
|
356
|
+
if (textArea.value) {
|
|
357
|
+
textArea.style.border = "none";
|
|
358
|
+
createComment(e, textArea.value);
|
|
359
|
+
showGlobalModal("commentsSent");
|
|
360
|
+
validatedAll ? validateAll("R") : sendEvaluation("R");
|
|
361
|
+
} else {
|
|
362
|
+
textArea.style.border = "2px solid red";
|
|
363
|
+
}
|
|
364
|
+
},
|
|
365
|
+
},
|
|
366
|
+
});
|
|
367
|
+
break;
|
|
350
368
|
case "generic":
|
|
351
369
|
setGlobalModal(dataGenericModal);
|
|
352
370
|
break;
|
|
@@ -498,9 +516,7 @@ export const ProviderProductEdition = ({
|
|
|
498
516
|
);
|
|
499
517
|
setServicesData(parsedResponse);
|
|
500
518
|
}
|
|
501
|
-
|
|
502
|
-
!activeRetailer.id &&
|
|
503
|
-
setActiveRetailer(active ? active : retailers[0]);
|
|
519
|
+
!activeRetailer.id && setActiveRetailer(active ? active : retailers[0]);
|
|
504
520
|
};
|
|
505
521
|
|
|
506
522
|
const isRevision = () => {
|
|
@@ -576,7 +592,7 @@ export const ProviderProductEdition = ({
|
|
|
576
592
|
});
|
|
577
593
|
}
|
|
578
594
|
setProduct(productTemp);
|
|
579
|
-
|
|
595
|
+
setActivePercentage(retailers[0]?.percentage);
|
|
580
596
|
}, [percentages]);
|
|
581
597
|
|
|
582
598
|
const loadInputs = () => {
|
|
@@ -817,19 +833,32 @@ export const ProviderProductEdition = ({
|
|
|
817
833
|
}
|
|
818
834
|
};
|
|
819
835
|
|
|
820
|
-
const createComment = async (
|
|
836
|
+
const createComment = async (e, body, tab) => {
|
|
837
|
+
let concept = "";
|
|
838
|
+
switch (activeTab) {
|
|
839
|
+
case "Ficha técnica":
|
|
840
|
+
concept = "datasheet";
|
|
841
|
+
break;
|
|
842
|
+
case "Imágenes":
|
|
843
|
+
concept = "images";
|
|
844
|
+
break;
|
|
845
|
+
|
|
846
|
+
default:
|
|
847
|
+
concept = "description";
|
|
848
|
+
break;
|
|
849
|
+
}
|
|
821
850
|
const data = {
|
|
822
|
-
|
|
823
|
-
|
|
824
|
-
|
|
825
|
-
|
|
826
|
-
|
|
827
|
-
status: product.status || productEdit.product.status,
|
|
828
|
-
},
|
|
829
|
-
paramsHeader: { Authorization: token },
|
|
851
|
+
articleId: product?.id_article,
|
|
852
|
+
orderId: product?.orderId,
|
|
853
|
+
message: body,
|
|
854
|
+
concept: concept,
|
|
855
|
+
version: version,
|
|
830
856
|
};
|
|
831
|
-
|
|
832
|
-
|
|
857
|
+
await axios.post(`${process.env.REACT_APP_COMMENTS_ENDPOINT}`, data, {
|
|
858
|
+
headers: {
|
|
859
|
+
Authorization: token,
|
|
860
|
+
},
|
|
861
|
+
});
|
|
833
862
|
};
|
|
834
863
|
|
|
835
864
|
useEffect(() => {
|
|
@@ -1029,27 +1058,6 @@ export const ProviderProductEdition = ({
|
|
|
1029
1058
|
const { newArticleStatus, newServiceStatus, newStatus } = JSON.parse(
|
|
1030
1059
|
res.data.body
|
|
1031
1060
|
);
|
|
1032
|
-
|
|
1033
|
-
const message = createMessage(
|
|
1034
|
-
product.retailers || product.retailersAvailable,
|
|
1035
|
-
activeRetailer.id,
|
|
1036
|
-
product[sectionStatusKey],
|
|
1037
|
-
newStatus,
|
|
1038
|
-
activeTab
|
|
1039
|
-
);
|
|
1040
|
-
|
|
1041
|
-
const messageData = {
|
|
1042
|
-
paramsBody: {
|
|
1043
|
-
id: product.article.id_article || productEdit.ArticleId,
|
|
1044
|
-
version: version,
|
|
1045
|
-
items: [{ type: "status", value: message }],
|
|
1046
|
-
retailerId: activeRetailer.id,
|
|
1047
|
-
status: product.status || productEdit.product.status,
|
|
1048
|
-
},
|
|
1049
|
-
paramsHeader: { Authorization: token },
|
|
1050
|
-
};
|
|
1051
|
-
await sendMessage(messageData);
|
|
1052
|
-
|
|
1053
1061
|
if (newArticleStatus) productTemp.status = newArticleStatus[articleId];
|
|
1054
1062
|
const retailerStatusCopy = { ...retailerStatus };
|
|
1055
1063
|
retailerStatusCopy[activeRetailer.id][concept] = newStatus;
|
|
@@ -1081,7 +1089,6 @@ export const ProviderProductEdition = ({
|
|
|
1081
1089
|
result,
|
|
1082
1090
|
isAproved: result === "A",
|
|
1083
1091
|
};
|
|
1084
|
-
const messages = [];
|
|
1085
1092
|
servicesData?.forEach((ret) => {
|
|
1086
1093
|
const { service, id_retailer } = ret;
|
|
1087
1094
|
let data = {};
|
|
@@ -1098,18 +1105,6 @@ export const ProviderProductEdition = ({
|
|
|
1098
1105
|
},
|
|
1099
1106
|
})
|
|
1100
1107
|
);
|
|
1101
|
-
if (product[`${ret.service}_status`] !== "NS") {
|
|
1102
|
-
const message = createMessage(
|
|
1103
|
-
product.retailers,
|
|
1104
|
-
ret.id_retailer,
|
|
1105
|
-
product[`${ret.service}_status`],
|
|
1106
|
-
`${result}A`,
|
|
1107
|
-
ret.service
|
|
1108
|
-
);
|
|
1109
|
-
messages.push(
|
|
1110
|
-
createComment([{ type: "status", value: message }], ret.id_retailer)
|
|
1111
|
-
);
|
|
1112
|
-
}
|
|
1113
1108
|
});
|
|
1114
1109
|
await Promise.all(evaluationArray);
|
|
1115
1110
|
const userType = user.is_retailer === 1 ? "CA" : "P";
|
|
@@ -1149,7 +1144,6 @@ export const ProviderProductEdition = ({
|
|
|
1149
1144
|
product: productTemp,
|
|
1150
1145
|
})
|
|
1151
1146
|
);
|
|
1152
|
-
await Promise.all(messages);
|
|
1153
1147
|
|
|
1154
1148
|
await loadData();
|
|
1155
1149
|
} catch (error) {
|
|
@@ -1277,7 +1271,8 @@ export const ProviderProductEdition = ({
|
|
|
1277
1271
|
return;
|
|
1278
1272
|
} else if (user.is_retailer) {
|
|
1279
1273
|
if (product.id_order || product.orderId) {
|
|
1280
|
-
|
|
1274
|
+
setValidatedAll(true);
|
|
1275
|
+
showGlobalModal("error");
|
|
1281
1276
|
} else {
|
|
1282
1277
|
setDataGenericModal((prev) => ({
|
|
1283
1278
|
...prev,
|
|
@@ -1289,7 +1284,8 @@ export const ProviderProductEdition = ({
|
|
|
1289
1284
|
showGlobalModal("generic");
|
|
1290
1285
|
}
|
|
1291
1286
|
} else {
|
|
1292
|
-
|
|
1287
|
+
setValidatedAll(true);
|
|
1288
|
+
showGlobalModal("error");
|
|
1293
1289
|
}
|
|
1294
1290
|
}
|
|
1295
1291
|
};
|
|
@@ -1298,7 +1294,6 @@ export const ProviderProductEdition = ({
|
|
|
1298
1294
|
<HeaderTop
|
|
1299
1295
|
setHeaderTop={setHeaderTop}
|
|
1300
1296
|
withChat={location?.state?.withChat}
|
|
1301
|
-
chatType={location?.state?.chatType}
|
|
1302
1297
|
productSelected={productSelected}
|
|
1303
1298
|
token={token}
|
|
1304
1299
|
activeRetailer={activeRetailer}
|
|
@@ -1377,7 +1372,7 @@ export const ProviderProductEdition = ({
|
|
|
1377
1372
|
} else if (user.is_retailer) {
|
|
1378
1373
|
if (product.id_order || product.orderId) {
|
|
1379
1374
|
setValidatedAll(true);
|
|
1380
|
-
|
|
1375
|
+
showGlobalModal("error");
|
|
1381
1376
|
} else {
|
|
1382
1377
|
setDataGenericModal((prev) => ({
|
|
1383
1378
|
...prev,
|
|
@@ -1389,14 +1384,12 @@ export const ProviderProductEdition = ({
|
|
|
1389
1384
|
showGlobalModal("generic");
|
|
1390
1385
|
}
|
|
1391
1386
|
} else {
|
|
1392
|
-
setShowRejectModal(true);
|
|
1393
1387
|
setValidatedAll(true);
|
|
1388
|
+
showGlobalModal("error");
|
|
1394
1389
|
}
|
|
1395
1390
|
}}
|
|
1396
1391
|
approve={() => sendToEvaluation("A")}
|
|
1397
|
-
reject={() =>
|
|
1398
|
-
setShowRejectModal(true);
|
|
1399
|
-
}}
|
|
1392
|
+
reject={() => sendToEvaluation("R")}
|
|
1400
1393
|
/>
|
|
1401
1394
|
<FullTabsMenu
|
|
1402
1395
|
tabsSections={tabsSections}
|
|
@@ -1631,49 +1624,6 @@ export const ProviderProductEdition = ({
|
|
|
1631
1624
|
jwt={token}
|
|
1632
1625
|
/>
|
|
1633
1626
|
)}
|
|
1634
|
-
{showRejectModal && (
|
|
1635
|
-
<Modal
|
|
1636
|
-
title={"Agregar mensaje de rechazo"}
|
|
1637
|
-
show={showRejectModal}
|
|
1638
|
-
customComponent={
|
|
1639
|
-
<TagAndInput
|
|
1640
|
-
label={"Caja de Comentario"}
|
|
1641
|
-
inputType={"textarea"}
|
|
1642
|
-
inputId={"modal-message-box"}
|
|
1643
|
-
index={0}
|
|
1644
|
-
color={"white"}
|
|
1645
|
-
/>
|
|
1646
|
-
}
|
|
1647
|
-
buttons={[
|
|
1648
|
-
<ButtonV2
|
|
1649
|
-
key={"btn-Cancelar"}
|
|
1650
|
-
type={"white"}
|
|
1651
|
-
label={"Cancelar"}
|
|
1652
|
-
size={12}
|
|
1653
|
-
onClick={() => {
|
|
1654
|
-
setShowRejectModal(false);
|
|
1655
|
-
}}
|
|
1656
|
-
/>,
|
|
1657
|
-
<ButtonV2
|
|
1658
|
-
key={"btn-Aceptar"}
|
|
1659
|
-
type={"pink"}
|
|
1660
|
-
label={"Aceptar"}
|
|
1661
|
-
size={12}
|
|
1662
|
-
onClick={async () => {
|
|
1663
|
-
const body = document.querySelector(
|
|
1664
|
-
"#modal-message-box .ql-container .ql-editor > p"
|
|
1665
|
-
).innerHTML;
|
|
1666
|
-
const messages = [
|
|
1667
|
-
{ type: "message", value: body?.replace(/<.*?\/?>/gm, "") },
|
|
1668
|
-
];
|
|
1669
|
-
await createComment(messages, activeRetailer.id);
|
|
1670
|
-
validatedAll ? validateAll("R") : sendToEvaluation("R");
|
|
1671
|
-
setShowRejectModal(false);
|
|
1672
|
-
}}
|
|
1673
|
-
/>,
|
|
1674
|
-
]}
|
|
1675
|
-
/>
|
|
1676
|
-
)}
|
|
1677
1627
|
</Container>
|
|
1678
1628
|
);
|
|
1679
1629
|
};
|
|
@@ -107,10 +107,6 @@ export const Container = styled.div`
|
|
|
107
107
|
}
|
|
108
108
|
}
|
|
109
109
|
}
|
|
110
|
-
#modal-message-box {
|
|
111
|
-
width: 400px;
|
|
112
|
-
height: 100px;
|
|
113
|
-
}
|
|
114
110
|
.container {
|
|
115
111
|
width: 100%;
|
|
116
112
|
height: 100%;
|
|
@@ -119,4 +115,4 @@ export const Container = styled.div`
|
|
|
119
115
|
width: 100%;
|
|
120
116
|
}
|
|
121
117
|
}
|
|
122
|
-
`;
|
|
118
|
+
`;
|