contentoh-components-library 21.4.22 → 21.4.24
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 +2 -5
- package/.env.production +1 -3
- package/dist/components/atoms/Avatar/index.js +2 -3
- package/dist/components/atoms/Card/index.js +5 -46
- package/dist/components/atoms/Card/styles.js +1 -3
- package/dist/components/atoms/CheckBox/index.js +2 -7
- package/dist/components/atoms/CheckBox/styles.js +1 -1
- package/dist/components/atoms/InputFormatter/styles.js +1 -1
- package/dist/components/atoms/SliderToolTip/styles.js +1 -1
- package/dist/components/molecules/CarouselImagesLogin/index.js +1 -1
- package/dist/components/molecules/HeaderTop/index.js +11 -68
- package/dist/components/molecules/TagAndInput/index.js +1 -1
- package/dist/components/organisms/Chat/Chat.stories.js +8 -27
- 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 +197 -350
- package/dist/components/organisms/Chat/Footer/index.js +39 -48
- package/dist/components/organisms/Chat/index.js +4 -49
- package/dist/components/organisms/FullProductNameHeader/index.js +2 -2
- package/dist/components/organisms/Modal/styles.js +1 -1
- package/dist/components/pages/ProviderProductEdition/ProviderProductEdition.stories.js +116 -60
- package/dist/components/pages/ProviderProductEdition/index.js +142 -117
- package/dist/components/pages/ProviderProductEdition/styles.js +1 -1
- package/dist/components/pages/RetailerProductEdition/RetailerProductEdition.stories.js +4 -8
- package/dist/components/pages/RetailerProductEdition/index.js +308 -316
- package/dist/components/pages/RetailerProductEdition/styles.js +1 -1
- package/dist/components/pages/RetailerProductEdition/utils.js +2 -61
- package/dist/index.js +52 -247
- package/package.json +1 -4
- package/src/components/atoms/Avatar/index.js +2 -8
- package/src/components/atoms/Card/index.js +2 -35
- package/src/components/atoms/Card/styles.js +5 -41
- package/src/components/atoms/CheckBox/index.js +1 -4
- package/src/components/atoms/CheckBox/styles.js +0 -2
- package/src/components/atoms/InputFormatter/styles.js +1 -2
- package/src/components/atoms/SliderToolTip/styles.js +1 -1
- package/src/components/molecules/CarouselImagesLogin/index.js +1 -1
- package/src/components/molecules/HeaderTop/index.js +6 -52
- package/src/components/molecules/TagAndInput/index.js +8 -10
- package/src/components/organisms/Chat/Chat.stories.js +7 -27
- 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 +12 -88
- package/src/components/organisms/Chat/Footer/index.js +0 -11
- package/src/components/organisms/Chat/index.js +4 -46
- package/src/components/organisms/FullProductNameHeader/index.js +1 -1
- package/src/components/organisms/Modal/styles.js +1 -4
- package/src/components/organisms/OrderDetail/utils/Table/utils.js +16 -6
- package/src/components/pages/ProviderProductEdition/ProviderProductEdition.stories.js +116 -66
- package/src/components/pages/ProviderProductEdition/index.js +129 -97
- package/src/components/pages/ProviderProductEdition/styles.js +1 -5
- package/src/components/pages/RetailerProductEdition/RetailerProductEdition.stories.js +3 -7
- package/src/components/pages/RetailerProductEdition/index.js +184 -158
- package/src/components/pages/RetailerProductEdition/styles.js +0 -4
- package/src/components/pages/RetailerProductEdition/utils.js +0 -37
- package/src/index.js +0 -16
- package/dist/components/atoms/ImageCarousel/ImgeSlider.stories.js +0 -90
- package/dist/components/atoms/ImageCarousel/index.js +0 -120
- package/dist/components/atoms/ImageCarousel/styles.js +0 -18
- package/dist/components/atoms/PercentTag/PercentTag.stories.js +0 -31
- package/dist/components/atoms/PercentTag/index.js +0 -23
- package/dist/components/atoms/PercentTag/styles.js +0 -22
- package/dist/components/atoms/RatingStars/RatingStars.stories.js +0 -30
- package/dist/components/atoms/RatingStars/index.js +0 -53
- package/dist/components/atoms/RatingStars/styles.js +0 -18
- package/dist/components/atoms/RetailerCatalog/RetailerCatalog.stories.js +0 -48
- package/dist/components/atoms/RetailerCatalog/index.js +0 -69
- package/dist/components/atoms/RetailerCatalog/styles.js +0 -20
- package/dist/components/atoms/RetailerOption/RetailerOption.stories.js +0 -33
- package/dist/components/atoms/RetailerOption/index.js +0 -62
- package/dist/components/atoms/RetailerOption/styles.js +0 -20
- package/dist/components/atoms/RetailersList/RetailersList.stories.js +0 -45
- package/dist/components/atoms/RetailersList/index.js +0 -46
- package/dist/components/atoms/RetailersList/styles.js +0 -18
- package/dist/components/atoms/UserCatalog/UserCatalog.stories.js +0 -73
- package/dist/components/atoms/UserCatalog/index.js +0 -101
- package/dist/components/atoms/UserCatalog/styles.js +0 -18
- package/dist/components/atoms/UserOption/UserOption.stories.js +0 -40
- package/dist/components/atoms/UserOption/index.js +0 -130
- package/dist/components/atoms/UserOption/styles.js +0 -20
- package/dist/components/atoms/UserSelector/UserSelector.stories.js +0 -40
- package/dist/components/atoms/UserSelector/index.js +0 -98
- package/dist/components/atoms/UserSelector/styles.js +0 -32
- package/dist/components/molecules/GridItem/GridItem.stories.js +0 -123
- package/dist/components/molecules/GridItem/index.js +0 -152
- package/dist/components/molecules/GridItem/styles.js +0 -20
- package/dist/components/molecules/HeaderItem/ColumnItem.js +0 -23
- package/dist/components/molecules/HeaderItem/HeaderItem.stories.js +0 -70
- package/dist/components/molecules/HeaderItem/index.js +0 -42
- package/dist/components/molecules/HeaderItem/styles.js +0 -30
- package/dist/components/molecules/RowItem/ColumnItem.js +0 -23
- package/dist/components/molecules/RowItem/RowItem.stories.js +0 -5242
- package/dist/components/molecules/RowItem/index.js +0 -58
- package/dist/components/molecules/RowItem/styles.js +0 -30
- package/dist/components/molecules/StripeCardForm/StripeCardForm.stories.js +0 -31
- package/dist/components/molecules/StripeCardForm/index.js +0 -87
- package/dist/components/molecules/StripeCardForm/paymentForm.js +0 -191
- package/dist/components/molecules/StripeCardForm/styles.js +0 -24
- package/dist/components/molecules/StripeCardSelector/CardSelector.stories.js +0 -30
- package/dist/components/molecules/StripeCardSelector/index.js +0 -107
- package/dist/components/molecules/StripeCardSelector/styles.js +0 -19
- package/dist/components/molecules/StripeCardSelector/utils.js +0 -56
- package/dist/components/organisms/GridProducts/GridProducts.stories.js +0 -5097
- package/dist/components/organisms/GridProducts/index.js +0 -63
- package/dist/components/organisms/GridProducts/styles.js +0 -18
- package/dist/components/organisms/GridProducts/utils.js +0 -149
- package/dist/components/organisms/PanelLayout/PanelLayout.stories.js +0 -87
- package/dist/components/organisms/PanelLayout/index.js +0 -29
- package/dist/components/organisms/PanelLayout/styles.js +0 -32
- package/dist/components/organisms/SideModal/SideModal.stories.js +0 -42
- package/dist/components/organisms/SideModal/index.js +0 -72
- package/dist/components/organisms/SideModal/styles.js +0 -18
- package/src/components/atoms/ImageCarousel/ImgeSlider.stories.js +0 -76
- package/src/components/atoms/ImageCarousel/index.js +0 -103
- package/src/components/atoms/ImageCarousel/styles.js +0 -79
- package/src/components/atoms/PercentTag/PercentTag.stories.js +0 -7
- package/src/components/atoms/PercentTag/index.js +0 -9
- package/src/components/atoms/PercentTag/styles.js +0 -69
- package/src/components/atoms/RatingStars/RatingStars.stories.js +0 -10
- package/src/components/atoms/RatingStars/index.js +0 -31
- package/src/components/atoms/RatingStars/styles.js +0 -28
- package/src/components/atoms/RetailerCatalog/RetailerCatalog.stories.js +0 -36
- package/src/components/atoms/RetailerCatalog/index.js +0 -49
- package/src/components/atoms/RetailerCatalog/styles.js +0 -30
- package/src/components/atoms/RetailerOption/RetailerOption.stories.js +0 -15
- package/src/components/atoms/RetailerOption/index.js +0 -53
- package/src/components/atoms/RetailerOption/styles.js +0 -41
- package/src/components/atoms/RetailersList/RetailersList.stories.js +0 -33
- package/src/components/atoms/RetailersList/index.js +0 -20
- package/src/components/atoms/RetailersList/styles.js +0 -19
- package/src/components/atoms/UserCatalog/UserCatalog.stories.js +0 -67
- package/src/components/atoms/UserCatalog/index.js +0 -100
- package/src/components/atoms/UserCatalog/styles.js +0 -24
- package/src/components/atoms/UserOption/UserOption.stories.js +0 -25
- package/src/components/atoms/UserOption/index.js +0 -95
- package/src/components/atoms/UserOption/styles.js +0 -61
- package/src/components/atoms/UserSelector/UserSelector.stories.js +0 -25
- package/src/components/atoms/UserSelector/index.js +0 -86
- package/src/components/atoms/UserSelector/styles.js +0 -55
- package/src/components/molecules/GridItem/GridItem.stories.js +0 -126
- package/src/components/molecules/GridItem/index.js +0 -105
- package/src/components/molecules/GridItem/styles.js +0 -104
- package/src/components/molecules/HeaderItem/ColumnItem.js +0 -9
- package/src/components/molecules/HeaderItem/HeaderItem.stories.js +0 -24
- package/src/components/molecules/HeaderItem/index.js +0 -26
- package/src/components/molecules/HeaderItem/styles.js +0 -27
- package/src/components/molecules/RowItem/ColumnItem.js +0 -9
- package/src/components/molecules/RowItem/RowItem.stories.js +0 -5660
- package/src/components/molecules/RowItem/index.js +0 -45
- package/src/components/molecules/RowItem/styles.js +0 -40
- package/src/components/molecules/StripeCardForm/StripeCardForm.stories.js +0 -13
- package/src/components/molecules/StripeCardForm/index.js +0 -42
- package/src/components/molecules/StripeCardForm/paymentForm.js +0 -124
- package/src/components/molecules/StripeCardForm/styles.js +0 -73
- package/src/components/molecules/StripeCardSelector/CardSelector.stories.js +0 -12
- package/src/components/molecules/StripeCardSelector/index.js +0 -44
- package/src/components/molecules/StripeCardSelector/styles.js +0 -4
- package/src/components/molecules/StripeCardSelector/utils.js +0 -17
- package/src/components/organisms/GridProducts/GridProducts.stories.js +0 -5485
- package/src/components/organisms/GridProducts/index.js +0 -50
- package/src/components/organisms/GridProducts/styles.js +0 -14
- package/src/components/organisms/GridProducts/utils.js +0 -111
- package/src/components/organisms/PanelLayout/PanelLayout.stories.js +0 -63
- package/src/components/organisms/PanelLayout/index.js +0 -11
- package/src/components/organisms/PanelLayout/styles.js +0 -39
- package/src/components/organisms/SideModal/SideModal.stories.js +0 -23
- package/src/components/organisms/SideModal/index.js +0 -50
- package/src/components/organisms/SideModal/styles.js +0 -30
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "contentoh-components-library",
|
|
3
|
-
"version": "21.4.
|
|
3
|
+
"version": "21.4.24",
|
|
4
4
|
"dependencies": {
|
|
5
5
|
"@aws-amplify/auth": "^4.5.3",
|
|
6
6
|
"@aws-amplify/datastore": "^3.11.0",
|
|
@@ -16,8 +16,6 @@
|
|
|
16
16
|
"@mui/material": "^5.12.0",
|
|
17
17
|
"@mui/styled-engine-sc": "^5.12.0",
|
|
18
18
|
"@storybook/addon-postcss": "^2.0.0",
|
|
19
|
-
"@stripe/react-stripe-js": "^2.1.1",
|
|
20
|
-
"@stripe/stripe-js": "^1.54.1",
|
|
21
19
|
"@testing-library/jest-dom": "^5.11.4",
|
|
22
20
|
"@testing-library/react": "^11.1.0",
|
|
23
21
|
"@testing-library/user-event": "^12.1.10",
|
|
@@ -30,7 +28,6 @@
|
|
|
30
28
|
"contentoh-components-library": "^21.0.18",
|
|
31
29
|
"draft-js": "^0.11.7",
|
|
32
30
|
"file-saver": "^2.0.5",
|
|
33
|
-
"infinite-react-carousel": "^1.2.11",
|
|
34
31
|
"js-base64": "^3.7.2",
|
|
35
32
|
"moment": "^2.29.4",
|
|
36
33
|
"prop-types": "^15.7.2",
|
|
@@ -2,18 +2,12 @@ import { Container } from "./styles";
|
|
|
2
2
|
import ReactImageFallback from "react-image-fallback";
|
|
3
3
|
import defaultProfile from "../../../assets/images/defaultImages/defaultProfileImage.svg";
|
|
4
4
|
|
|
5
|
-
export const Avatar = ({
|
|
6
|
-
image,
|
|
7
|
-
altText,
|
|
8
|
-
imageType,
|
|
9
|
-
onClick,
|
|
10
|
-
fallbackImage,
|
|
11
|
-
}) => {
|
|
5
|
+
export const Avatar = ({ image, altText, imageType, onClick }) => {
|
|
12
6
|
return (
|
|
13
7
|
<Container className={imageType}>
|
|
14
8
|
<ReactImageFallback
|
|
15
9
|
src={image}
|
|
16
|
-
fallbackImage={
|
|
10
|
+
fallbackImage={defaultProfile}
|
|
17
11
|
alt={altText}
|
|
18
12
|
onClick={onClick}
|
|
19
13
|
/>
|
|
@@ -1,42 +1,9 @@
|
|
|
1
1
|
import { Container } from "./styles";
|
|
2
|
-
import { CheckBox } from "../CheckBox";
|
|
3
|
-
import { CardCvcElement, useStripe } from "@stripe/react-stripe-js";
|
|
4
|
-
|
|
5
|
-
export const Card = ({
|
|
6
|
-
card = {},
|
|
7
|
-
selectedCard,
|
|
8
|
-
setSelectedCard,
|
|
9
|
-
setCard,
|
|
10
|
-
setStripe,
|
|
11
|
-
}) => {
|
|
12
|
-
const stripe = useStripe();
|
|
13
|
-
|
|
14
|
-
const handleOnChange = (e, cardId) => {
|
|
15
|
-
if (e.target.checked) {
|
|
16
|
-
setCard && setCard({ ...card, isNew: 0 });
|
|
17
|
-
setStripe && setStripe(stripe);
|
|
18
|
-
setSelectedCard && setSelectedCard(cardId);
|
|
19
|
-
} else {
|
|
20
|
-
setSelectedCard && setSelectedCard("");
|
|
21
|
-
setCard && setCard(null);
|
|
22
|
-
}
|
|
23
|
-
};
|
|
24
2
|
|
|
3
|
+
export const Card = ({ cardIcon, altText }) => {
|
|
25
4
|
return (
|
|
26
5
|
<Container>
|
|
27
|
-
<
|
|
28
|
-
<CheckBox
|
|
29
|
-
id={card.id}
|
|
30
|
-
label={
|
|
31
|
-
<>
|
|
32
|
-
<span className="brand-card">{card.brand}</span>
|
|
33
|
-
<span>{`**** **** **** ${card.last4}`}</span>
|
|
34
|
-
</>
|
|
35
|
-
}
|
|
36
|
-
checked={selectedCard === card.id}
|
|
37
|
-
onChange={(e) => handleOnChange(e, card.id)}
|
|
38
|
-
/>
|
|
39
|
-
</div>
|
|
6
|
+
<img src={cardIcon} alt={altText} />
|
|
40
7
|
</Container>
|
|
41
8
|
);
|
|
42
9
|
};
|
|
@@ -1,44 +1,8 @@
|
|
|
1
1
|
import styled from "styled-components";
|
|
2
|
-
import { FontFamily, GlobalColors } from "../../../global-files/variables";
|
|
3
2
|
|
|
4
3
|
export const Container = styled.div`
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
cursor: pointer;
|
|
11
|
-
height: 25px;
|
|
12
|
-
p {
|
|
13
|
-
margin-left: 40px;
|
|
14
|
-
span {
|
|
15
|
-
& + * {
|
|
16
|
-
margin-left: 20px;
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
& + * {
|
|
22
|
-
margin-left: 20px;
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
.cvc-input {
|
|
27
|
-
display: flex;
|
|
28
|
-
align-items: center;
|
|
29
|
-
color: ${GlobalColors.s4};
|
|
30
|
-
font-family: ${FontFamily.AvenirNext};
|
|
31
|
-
font-size: 13px;
|
|
32
|
-
|
|
33
|
-
.card-input {
|
|
34
|
-
border: 1px solid #f0f0f0 !important;
|
|
35
|
-
border-radius: 5px;
|
|
36
|
-
padding: 3px;
|
|
37
|
-
width: 50px;
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
& + * {
|
|
42
|
-
margin-top: 15px;
|
|
43
|
-
}
|
|
44
|
-
`;
|
|
4
|
+
img {
|
|
5
|
+
width: 100%;
|
|
6
|
+
margin:auto;
|
|
7
|
+
}
|
|
8
|
+
`;
|
|
@@ -7,11 +7,9 @@ export const CheckBox = ({
|
|
|
7
7
|
isFilter,
|
|
8
8
|
defaultChecked,
|
|
9
9
|
disabled = false,
|
|
10
|
-
checked,
|
|
11
|
-
className = "",
|
|
12
10
|
}) => {
|
|
13
11
|
return (
|
|
14
|
-
<Container key={`check-${id}`}
|
|
12
|
+
<Container key={`check-${id}`}>
|
|
15
13
|
<input
|
|
16
14
|
type="checkbox"
|
|
17
15
|
name={id}
|
|
@@ -19,7 +17,6 @@ export const CheckBox = ({
|
|
|
19
17
|
onChange={onChange}
|
|
20
18
|
defaultChecked={defaultChecked}
|
|
21
19
|
disabled={disabled}
|
|
22
|
-
checked={checked}
|
|
23
20
|
/>
|
|
24
21
|
<label htmlFor={id}>
|
|
25
22
|
{label && <p className={isFilter && "filter-text"}>{label}</p>}
|
|
@@ -27,7 +27,7 @@ export const CarouselImagesLogin = ({
|
|
|
27
27
|
img2.src = images[i];
|
|
28
28
|
const circulo_actual = Array.from(circulos).find((el) => el.id === i);
|
|
29
29
|
Array.from(circulos).forEach((cir) => cir.classList.remove("resaltado"));
|
|
30
|
-
circulo_actual
|
|
30
|
+
circulo_actual.classList.add("resaltado");
|
|
31
31
|
img1.classList.add("right");
|
|
32
32
|
img2.classList.add("active");
|
|
33
33
|
i++;
|
|
@@ -4,13 +4,10 @@ import { Button } from "../../atoms/GeneralButton/index";
|
|
|
4
4
|
import { useEffect, useRef } from "react";
|
|
5
5
|
import { Chat } from "../../organisms/Chat";
|
|
6
6
|
import auditIcon from "../../../../src/assets/images/generalButton/Icono AB.svg";
|
|
7
|
-
import { useState } from "react";
|
|
8
|
-
import { render } from "@testing-library/react";
|
|
9
7
|
|
|
10
8
|
export const HeaderTop = ({
|
|
11
9
|
setHeaderTop,
|
|
12
10
|
withChat,
|
|
13
|
-
chatType,
|
|
14
11
|
productSelected,
|
|
15
12
|
token,
|
|
16
13
|
auditableVersion,
|
|
@@ -19,51 +16,16 @@ export const HeaderTop = ({
|
|
|
19
16
|
activeRetailer,
|
|
20
17
|
}) => {
|
|
21
18
|
const headerTop = useRef();
|
|
22
|
-
const [chat, setChat] = useState(null);
|
|
23
|
-
const [chatData, setChatData] = useState(null);
|
|
24
|
-
|
|
25
|
-
useEffect(() => {
|
|
26
|
-
if (activeRetailer.id && productSelected && token.length) {
|
|
27
|
-
setChatData({
|
|
28
|
-
id: productSelected?.article?.id_article || productSelected?.id_article,
|
|
29
|
-
version: productSelected?.version,
|
|
30
|
-
retailerId: activeRetailer?.id,
|
|
31
|
-
status: productSelected?.status,
|
|
32
|
-
userToken: token,
|
|
33
|
-
});
|
|
34
|
-
}
|
|
35
|
-
}, [activeRetailer, productSelected, token]);
|
|
36
|
-
|
|
37
|
-
useEffect(() => {
|
|
38
|
-
if (chatType) renderChat(chatType);
|
|
39
|
-
}, [chatData, chatType]);
|
|
40
19
|
|
|
41
20
|
useEffect(() => {
|
|
42
21
|
setHeaderTop && setHeaderTop(headerTop.current.clientHeight);
|
|
43
22
|
}, []);
|
|
44
23
|
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
<Chat
|
|
51
|
-
chatType="product_status"
|
|
52
|
-
chatContainerType="popUp"
|
|
53
|
-
chatData={{
|
|
54
|
-
id: chatData?.id,
|
|
55
|
-
version: chatData?.version,
|
|
56
|
-
retailerId: chatData?.retailerId,
|
|
57
|
-
status: chatData?.status,
|
|
58
|
-
userToken: chatData?.userToken,
|
|
59
|
-
}}
|
|
60
|
-
size={18}
|
|
61
|
-
activeRetailer={activeRetailer}
|
|
62
|
-
/>
|
|
63
|
-
);
|
|
64
|
-
break;
|
|
65
|
-
default:
|
|
66
|
-
setChat(
|
|
24
|
+
return (
|
|
25
|
+
<Container ref={headerTop}>
|
|
26
|
+
<ScreenHeader text="Edición de producto" />
|
|
27
|
+
<div className="buttons-container">
|
|
28
|
+
{withChat && (
|
|
67
29
|
<Chat
|
|
68
30
|
chatType="merchant_product"
|
|
69
31
|
chatContainerType="popUp"
|
|
@@ -75,16 +37,8 @@ export const HeaderTop = ({
|
|
|
75
37
|
size={18}
|
|
76
38
|
activeRetailer={activeRetailer}
|
|
77
39
|
/>
|
|
78
|
-
)
|
|
79
|
-
break;
|
|
80
|
-
}
|
|
81
|
-
};
|
|
40
|
+
)}
|
|
82
41
|
|
|
83
|
-
return (
|
|
84
|
-
<Container ref={headerTop}>
|
|
85
|
-
<ScreenHeader text="Edición de producto" />
|
|
86
|
-
<div className="buttons-container">
|
|
87
|
-
{withChat && chat}
|
|
88
42
|
{isAuditor && auditableVersion && (
|
|
89
43
|
<Button
|
|
90
44
|
buttonType="general-white-button circular-button"
|
|
@@ -36,16 +36,14 @@ export const TagAndInput = ({
|
|
|
36
36
|
className={"input-container"}
|
|
37
37
|
key={`generalTagInput-${inputType}`}
|
|
38
38
|
>
|
|
39
|
-
|
|
40
|
-
<
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
</div>
|
|
48
|
-
)}
|
|
39
|
+
<div className="title-container">
|
|
40
|
+
<ScreenHeader
|
|
41
|
+
text={label}
|
|
42
|
+
headerType={"input-name-header"}
|
|
43
|
+
color={color}
|
|
44
|
+
/>
|
|
45
|
+
{showTooltip && <span className="tooltip">{label}</span>}
|
|
46
|
+
</div>
|
|
49
47
|
<GeneralInput
|
|
50
48
|
inputId={inputId}
|
|
51
49
|
inputType={inputType}
|
|
@@ -148,37 +148,17 @@ chatTicket_userTECH.args = {
|
|
|
148
148
|
chatType: "ticket",
|
|
149
149
|
chatContainerType: "fixed",
|
|
150
150
|
chatData: {
|
|
151
|
-
id:
|
|
152
|
-
ticketOwnerUserId:
|
|
153
|
-
|
|
151
|
+
id: 130,
|
|
152
|
+
ticketOwnerUserId: 194,
|
|
153
|
+
ticketCompany: undefined,
|
|
154
|
+
statusTicket: "PENDING",
|
|
154
155
|
currentUser: {
|
|
155
156
|
token:
|
|
156
|
-
"eyJraWQiOiJkQWJkZCtlclwvTlwveVRQUWNvUlVyOCtrNUd2M1hMM2N1MWUzQ09zWExVRnc9IiwiYWxnIjoiUlMyNTYifQ.
|
|
157
|
-
id:
|
|
158
|
-
companyId:
|
|
157
|
+
"eyJraWQiOiJkQWJkZCtlclwvTlwveVRQUWNvUlVyOCtrNUd2M1hMM2N1MWUzQ09zWExVRnc9IiwiYWxnIjoiUlMyNTYifQ.eyJzdWIiOiJmNTkyN2Y4ZS1jYmY3LTQ5MjItOWUwOS1lNjllYzBiMjczMWEiLCJjb2duaXRvOmdyb3VwcyI6WyJ1c3VhcmlvX2NvbnRlbnRvaCJdLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwiaXNzIjoiaHR0cHM6XC9cL2NvZ25pdG8taWRwLnVzLWVhc3QtMS5hbWF6b25hd3MuY29tXC91cy1lYXN0LTFfWE1aUWRxa0dqIiwicGhvbmVfbnVtYmVyX3ZlcmlmaWVkIjpmYWxzZSwiY29nbml0bzp1c2VybmFtZSI6ImY1OTI3ZjhlLWNiZjctNDkyMi05ZTA5LWU2OWVjMGIyNzMxYSIsImNvZ25pdG86cm9sZXMiOlsiYXJuOmF3czppYW06Ojg5ODY3MDIzMjgwNzpyb2xlXC9jb250ZW50b2gtZGV2LXVzLWVhc3QtMS1sYW1iZGFSb2xlIl0sImF1ZCI6IjVhYzh0cGdzNmdic3ExM2ZydnJwaWVlcDQwIiwiZXZlbnRfaWQiOiJlYTRlZmQ1Zi1mYTg4LTRjNDEtYTM3Ny02MWVkNmY0YTMyOTciLCJ0b2tlbl91c2UiOiJpZCIsImF1dGhfdGltZSI6MTY4MDA1Njg2NSwibmFtZSI6IklzbWFlbCBMb3BleiIsInBob25lX251bWJlciI6Iis1MjMxMTEzNjYzMzYiLCJleHAiOjE2ODAwNjA0NjUsImlhdCI6MTY4MDA1Njg2NSwiZW1haWwiOiJpbG9wZXpAY29udGVudG9oLmNvbSJ9.oRuv3LkdvctEMUjmeGw0-XefzV_Aoh1O2hFMik4RxpkkCUeP1O7AjA7lJI6sgoqa9Nwa2fCPRXk6ufi84UbgxGEgkupQmAvXTHQCw_uwCUVAZitlNGXSBl-VSisMuXSnckxdZQ1MvLV5BgLmiw4mu6HxKDN-Uw0xc7yL_yDtGu3NWxoO0Cm2zbej8jYLE9DV9wG297bjfzVQ7hzpEfEcB52I5Tg6nF2VDTx-8_m4mVVrpisbV5uBoYokbFyyOFVLZzUU7Je5uHukscHS5dje9IMTY8DE5S8xUWJubHjf_ktcy7Y2-F2cG5dI5oSdrBNU-wNNW5-OtRLgclSJLmbPCw",
|
|
158
|
+
id: 28,
|
|
159
|
+
companyId: 1,
|
|
159
160
|
isUserTech: true,
|
|
160
161
|
},
|
|
161
162
|
},
|
|
162
163
|
classNameContainerFixed: "chatTicket",
|
|
163
164
|
};
|
|
164
|
-
|
|
165
|
-
// ejemplo del chat para los cambios de status del producto.
|
|
166
|
-
export const chatProduct_status = Template.bind({});
|
|
167
|
-
chatProduct_status.args = {
|
|
168
|
-
chatType: "product_status",
|
|
169
|
-
chatContainerType: "popUp",
|
|
170
|
-
chatData: {
|
|
171
|
-
id: 37414,
|
|
172
|
-
version: 7,
|
|
173
|
-
retailerId: 70,
|
|
174
|
-
status: "AA",
|
|
175
|
-
orderId: 15189,
|
|
176
|
-
userToken:
|
|
177
|
-
"eyJraWQiOiJkQWJkZCtlclwvTlwveVRQUWNvUlVyOCtrNUd2M1hMM2N1MWUzQ09zWExVRnc9IiwiYWxnIjoiUlMyNTYifQ.eyJzdWIiOiI5YTIxMzEyOC02NDgyLTRjMTYtYTRiNi02ZTY0ZjIyNWIxYmQiLCJjb2duaXRvOmdyb3VwcyI6WyJjb2xhYm9yYWRvcmVzX2NvbnRlbnRvaCJdLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwiaXNzIjoiaHR0cHM6XC9cL2NvZ25pdG8taWRwLnVzLWVhc3QtMS5hbWF6b25hd3MuY29tXC91cy1lYXN0LTFfWE1aUWRxa0dqIiwiY29nbml0bzp1c2VybmFtZSI6IjlhMjEzMTI4LTY0ODItNGMxNi1hNGI2LTZlNjRmMjI1YjFiZCIsImNvZ25pdG86cm9sZXMiOlsiYXJuOmF3czppYW06Ojg5ODY3MDIzMjgwNzpyb2xlXC9jb250ZW50b2gtZGV2LXVzLWVhc3QtMS1sYW1iZGFSb2xlIl0sImF1ZCI6IjVhYzh0cGdzNmdic3ExM2ZydnJwaWVlcDQwIiwiZXZlbnRfaWQiOiJhOWFhMDQ4Zi05YzRjLTQxODMtYWUzMS03OWVjNjBhY2NjZGYiLCJ0b2tlbl91c2UiOiJpZCIsImF1dGhfdGltZSI6MTY4MzU4ODM4OSwibmFtZSI6IkNvbGFib3JhZG9yIiwicGhvbmVfbnVtYmVyIjoiKzUyMTExMSIsImV4cCI6MTY4MzU5MTk4OSwiaWF0IjoxNjgzNTg4Mzg5LCJlbWFpbCI6ImlzbWFlbDk3bG9wZXpAZ21haWwuY29tIn0.k9FQfRR02XC3WWfOzWhrbJGmp69AmCHJEIrgtXKhIwC69trdphSm1AKkZnDJMsEdkpUgjF_zAOsa_xYRxO6goXy7WXVc_p7N-yFHlkhZrRyn3LEFKaLzD8vVqlWx4kgfSERm7KhI1AxPmrA-lw8eF6Axvqn3PvuszAw89_WhPOcnOt8vU0MxAVhLgS8oM6vyHFmHEHWQ2FnSYYed9sEvAxGh_B44aIgWeDteQGeGdYhsm6rUcxgkrskywZJp9FW5VgYXuDcC5NpvomMMRy_v95UV897JzCHl__sK2Z9ahm0eczVN3tAc0GbKnlN96ZrGTQ_nmNHbuMDPQBPXH5HXZQ",
|
|
178
|
-
currentUser: {
|
|
179
|
-
id: 37,
|
|
180
|
-
companyId: 2,
|
|
181
|
-
isUserTech: false,
|
|
182
|
-
},
|
|
183
|
-
},
|
|
184
|
-
};
|
|
@@ -22,7 +22,6 @@ import { Tooltip } from "../../../atoms/Tooltip";
|
|
|
22
22
|
import { Slide, Zoom } from "@mui/material";
|
|
23
23
|
import { useRef } from "react";
|
|
24
24
|
import { ImagePreview } from "../../../atoms/ImagePreview";
|
|
25
|
-
import { Status } from "../../../atoms/Status";
|
|
26
25
|
import { isUserTech } from "../../../../global-files/handle_userTech";
|
|
27
26
|
import { container } from "aws-amplify";
|
|
28
27
|
|
|
@@ -56,10 +55,7 @@ export const ContainerItems = (props) => {
|
|
|
56
55
|
|
|
57
56
|
useEffect(() => {
|
|
58
57
|
if (!items) return;
|
|
59
|
-
if (
|
|
60
|
-
["merchant_product", "order_product", "product_status"].includes(chatType)
|
|
61
|
-
)
|
|
62
|
-
renderItems();
|
|
58
|
+
if (["merchant_product", "order_product"].includes(chatType)) renderItems();
|
|
63
59
|
else if (chatType === "ticket") renderItemsTicket();
|
|
64
60
|
else setCustomItems([]);
|
|
65
61
|
}, [items]);
|
|
@@ -134,16 +130,6 @@ export const ContainerItems = (props) => {
|
|
|
134
130
|
return <label className="item-statusTicket">{item.value}</label>;
|
|
135
131
|
};
|
|
136
132
|
|
|
137
|
-
const renderStatusItem = (item) => {
|
|
138
|
-
const splitText = item.value.split("|");
|
|
139
|
-
let message = [];
|
|
140
|
-
splitText.forEach((text, i) => {
|
|
141
|
-
if (i === 1 || i === 3) message.push(<Status statusType={text} />);
|
|
142
|
-
else message.push(text);
|
|
143
|
-
});
|
|
144
|
-
return <label className="item-statusItem">{message}</label>;
|
|
145
|
-
};
|
|
146
|
-
|
|
147
133
|
const renderStatusTicketNeutral = (item) => {
|
|
148
134
|
return (
|
|
149
135
|
<Tooltip
|
|
@@ -318,7 +304,7 @@ export const ContainerItems = (props) => {
|
|
|
318
304
|
>
|
|
319
305
|
<li
|
|
320
306
|
className={
|
|
321
|
-
(ownMessage
|
|
307
|
+
(ownMessage ? "own-message " : "") +
|
|
322
308
|
(lastUserId === item.userId ? "sameUser" : "")
|
|
323
309
|
}
|
|
324
310
|
>
|
|
@@ -353,8 +339,6 @@ export const ContainerItems = (props) => {
|
|
|
353
339
|
? renderComment(item)
|
|
354
340
|
: item.type === "img"
|
|
355
341
|
? renderImg(item)
|
|
356
|
-
: item.type === "status"
|
|
357
|
-
? renderStatusItem(item)
|
|
358
342
|
: item.type === "file"
|
|
359
343
|
? renderFile(item, ownMessage)
|
|
360
344
|
: item.type === "statusTicket" &&
|
|
@@ -158,8 +158,7 @@ export const Container = styled.div`
|
|
|
158
158
|
.item-message,
|
|
159
159
|
.item-comment,
|
|
160
160
|
.item-file,
|
|
161
|
-
.item-statusTicket
|
|
162
|
-
.item-statusItem {
|
|
161
|
+
.item-statusTicket {
|
|
163
162
|
border-radius: 10px;
|
|
164
163
|
padding: 10px;
|
|
165
164
|
font-family: ${FontFamily.RobotoRegular}, sans-serif;
|
|
@@ -174,17 +173,10 @@ export const Container = styled.div`
|
|
|
174
173
|
.item-file {
|
|
175
174
|
background-color: #8386ee;
|
|
176
175
|
}
|
|
177
|
-
.item-statusTicket
|
|
178
|
-
.item-statusItem {
|
|
176
|
+
.item-statusTicket {
|
|
179
177
|
background-color: #85bc5b;
|
|
180
178
|
}
|
|
181
179
|
|
|
182
|
-
.item-statusItem {
|
|
183
|
-
display: flex;
|
|
184
|
-
gap: 3px;
|
|
185
|
-
align-items: center;
|
|
186
|
-
}
|
|
187
|
-
|
|
188
180
|
.item-message {
|
|
189
181
|
&.different-company {
|
|
190
182
|
border: 1px solid #e33aa9;
|
|
@@ -86,8 +86,7 @@ export const ContentChat = (props) => {
|
|
|
86
86
|
|
|
87
87
|
// al cargar el componente
|
|
88
88
|
useEffect(() => {
|
|
89
|
-
|
|
90
|
-
if (Object.keys(dataChat || {}).length) {
|
|
89
|
+
if (dataChat && showPopUpChat) {
|
|
91
90
|
stopUpdate();
|
|
92
91
|
if (dataChat.code) {
|
|
93
92
|
setErrorChat({
|
|
@@ -101,7 +100,6 @@ export const ContentChat = (props) => {
|
|
|
101
100
|
}
|
|
102
101
|
if (chatType === "merchant_product") getInitialMerchantProduct();
|
|
103
102
|
else if (chatType === "order_product") getInitialOrderProduct();
|
|
104
|
-
else if (chatType === "product_status") getInitialProductStatus();
|
|
105
103
|
else getInitialTicket();
|
|
106
104
|
}
|
|
107
105
|
if (!showPopUpChat) {
|
|
@@ -128,8 +126,6 @@ export const ContentChat = (props) => {
|
|
|
128
126
|
} else if (chatType === "order_product") {
|
|
129
127
|
if (companies) getUpdateLatestOrderProduct(true);
|
|
130
128
|
else getInitialOrderProduct();
|
|
131
|
-
} else if (chatType === "product_status") {
|
|
132
|
-
getInitialProductStatus();
|
|
133
129
|
} else {
|
|
134
130
|
if (singleChat.items) getUpdateLatestTicket(true);
|
|
135
131
|
else getInitialTicket();
|
|
@@ -139,47 +135,6 @@ export const ContentChat = (props) => {
|
|
|
139
135
|
/*=======================================================================
|
|
140
136
|
PETICION GET INICIAL SEGUN EL TIPO DE CHAT
|
|
141
137
|
======================================================================= */
|
|
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
138
|
const getInitialMerchantProduct = async () => {
|
|
184
139
|
const paramsQuery = {
|
|
185
140
|
getType: "initial",
|
|
@@ -613,14 +568,14 @@ export const ContentChat = (props) => {
|
|
|
613
568
|
};
|
|
614
569
|
|
|
615
570
|
/*=======================================================================
|
|
616
|
-
FUNCION QUE EJECUTA EL MICROSERVICIO CREATE-ITEM
|
|
571
|
+
FUNCION QUE EJECUTA EL MICROSERVICIO CREATE-ITEM
|
|
617
572
|
Este metodo recibe los items que queremos agregar al chat.
|
|
618
573
|
requiere:
|
|
619
|
-
=> items: [ { type , value } , ... ]
|
|
574
|
+
=> items: [ { type , value } , ... ]
|
|
620
575
|
NOTA: si se quiere agregar un mensaje mandar un array con un object
|
|
621
|
-
example: [ {
|
|
622
|
-
type: "message" ,
|
|
623
|
-
value: "mi mensaje"
|
|
576
|
+
example: [ {
|
|
577
|
+
type: "message" ,
|
|
578
|
+
value: "mi mensaje"
|
|
624
579
|
} ]
|
|
625
580
|
======================================================================= */
|
|
626
581
|
const createItemsChat = async (items = []) => {
|
|
@@ -656,14 +611,12 @@ export const ContentChat = (props) => {
|
|
|
656
611
|
// enviar items a la BD
|
|
657
612
|
if (chatType === "merchant_product") {
|
|
658
613
|
errorCreate = await createItemsMerchantProduct(items);
|
|
659
|
-
} else if (chatType === "product_status") {
|
|
660
|
-
errorCreate = await createItemsProductStatus(items);
|
|
661
614
|
} else if (chatType === "order_product") {
|
|
662
615
|
errorCreate = await createItemsOrderProduct(items);
|
|
663
616
|
} else errorCreate = await createItemsTicket(items);
|
|
664
617
|
|
|
665
618
|
// actualizar chat para que aparezcan los items enviados
|
|
666
|
-
if (
|
|
619
|
+
if (chatType === "merchant_product") {
|
|
667
620
|
await getUpdateLatestMerchantProduct();
|
|
668
621
|
} else if (chatType === "order_product") {
|
|
669
622
|
await getUpdateLatestOrderProduct();
|
|
@@ -676,10 +629,9 @@ export const ContentChat = (props) => {
|
|
|
676
629
|
};
|
|
677
630
|
|
|
678
631
|
const createItemsMerchantProduct = async (items = []) => {
|
|
679
|
-
const { id, version
|
|
632
|
+
const { id, version } = dataChat;
|
|
680
633
|
const { id: retailerId } = activeRetailer;
|
|
681
634
|
const paramsBody = { id, version, items, retailerId };
|
|
682
|
-
if (chatType === "product_status") paramsBody["orderId"] = orderId;
|
|
683
635
|
const paramsHeaders = { Authorization: dataChat.userToken };
|
|
684
636
|
const response = await fetchPOST(
|
|
685
637
|
process.env.REACT_APP_PRODUCTS_CHAT_ENDPOINT,
|
|
@@ -693,23 +645,6 @@ export const ContentChat = (props) => {
|
|
|
693
645
|
};
|
|
694
646
|
}
|
|
695
647
|
};
|
|
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
648
|
|
|
714
649
|
const createItemsOrderProduct = async (items = []) => {
|
|
715
650
|
const paramsBody = {
|
|
@@ -757,11 +692,7 @@ export const ContentChat = (props) => {
|
|
|
757
692
|
SECCION DE FUNCIONES
|
|
758
693
|
======================================================================= */
|
|
759
694
|
const isSingleChat = () => {
|
|
760
|
-
if (
|
|
761
|
-
chatType === "merchant_product" ||
|
|
762
|
-
chatType === "ticket" ||
|
|
763
|
-
chatType === "product_status"
|
|
764
|
-
) {
|
|
695
|
+
if (chatType === "merchant_product" || chatType === "ticket") {
|
|
765
696
|
return true;
|
|
766
697
|
}
|
|
767
698
|
if (companies && Object.keys(companies).length < 2) return true;
|
|
@@ -876,7 +807,7 @@ export const ContentChat = (props) => {
|
|
|
876
807
|
// mostrar chat?
|
|
877
808
|
let items;
|
|
878
809
|
let enabledLoadMore;
|
|
879
|
-
if (["merchant_product", "ticket"
|
|
810
|
+
if (["merchant_product", "ticket"].includes(chatType)) {
|
|
880
811
|
items = singleChat.items;
|
|
881
812
|
enabledLoadMore = singleChat.enabledLoadMore;
|
|
882
813
|
}
|
|
@@ -918,9 +849,7 @@ export const ContentChat = (props) => {
|
|
|
918
849
|
activeCompanyId={activeCompanyId}
|
|
919
850
|
ticketCompany={ticketCompany}
|
|
920
851
|
currentUser={
|
|
921
|
-
["merchant_product", "order_product"
|
|
922
|
-
chatType
|
|
923
|
-
)
|
|
852
|
+
["merchant_product", "order_product"].includes(chatType)
|
|
924
853
|
? currentUser
|
|
925
854
|
: dataChat.currentUser
|
|
926
855
|
}
|
|
@@ -959,12 +888,6 @@ export const ContentChat = (props) => {
|
|
|
959
888
|
? { id: dataChat.id, version: currentArticle.version }
|
|
960
889
|
: chatType === "ticket"
|
|
961
890
|
? { id: dataChat.id }
|
|
962
|
-
: chatType === "product_status"
|
|
963
|
-
? {
|
|
964
|
-
id: dataChat.id,
|
|
965
|
-
version: dataChat.version,
|
|
966
|
-
retailerId: dataChat.retailerId,
|
|
967
|
-
}
|
|
968
891
|
: undefined
|
|
969
892
|
}
|
|
970
893
|
chatCompany={getChatCompany()}
|
|
@@ -1007,6 +930,7 @@ export const ContentChat = (props) => {
|
|
|
1007
930
|
}}
|
|
1008
931
|
/>
|
|
1009
932
|
)}
|
|
933
|
+
|
|
1010
934
|
{/* body */}
|
|
1011
935
|
{renderBodyChat()}
|
|
1012
936
|
</Container>
|
|
@@ -169,17 +169,6 @@ export const Footer = (props) => {
|
|
|
169
169
|
errorMessage = "El ID del ticket no es valido";
|
|
170
170
|
}
|
|
171
171
|
break;
|
|
172
|
-
case "product_status":
|
|
173
|
-
if (
|
|
174
|
-
isValidNaturalNumber(dataChat?.id) &&
|
|
175
|
-
isValidNaturalNumber(dataChat?.version) &&
|
|
176
|
-
isValidNaturalNumber(dataChat?.retailerId)
|
|
177
|
-
) {
|
|
178
|
-
fileKey += `productStatus/${dataChat.id}-${dataChat?.version}-${dataChat?.retailerId}/`;
|
|
179
|
-
} else {
|
|
180
|
-
errorMessage = "El ID del ticket no es valido";
|
|
181
|
-
}
|
|
182
|
-
break;
|
|
183
172
|
|
|
184
173
|
default:
|
|
185
174
|
errorMessage =
|