Skip to content

Commit

Permalink
Merge pull request #208 from 100-hours-a-week/feature/veronica
Browse files Browse the repository at this point in the history
Feat : 거래 swipe 수정
  • Loading branch information
lucy726j authored Sep 23, 2024
2 parents 9c54e9a + 35f6506 commit 648bfa2
Show file tree
Hide file tree
Showing 18 changed files with 1,310 additions and 1,310 deletions.
4 changes: 4 additions & 0 deletions .vscode/settings.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
{
"editor.formatOnSave": true,
"editor.defaultFormatter": "esbenp.prettier-vscode"
}
14 changes: 6 additions & 8 deletions src/App.tsx
Original file line number Diff line number Diff line change
@@ -1,16 +1,14 @@
import "./App.css";
import { GlobalStyle } from "./Styles/GlobalStyles";
import Router from "./Router";
import { useAuth } from "./contexts/authContext";

function App() {
const { user } = useAuth();
return (
<>
<GlobalStyle />
<Router />
</>
);
return (
<>
<GlobalStyle />
<Router />
</>
);
}

export default App;
24 changes: 11 additions & 13 deletions src/Component/Button/button.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,25 +4,23 @@ import { buttonSize, buttonType } from "../../Styles/button";
import { ButtonStyleProps, ButtonProps } from "../../constants/interface";

const ButtonStyle = styled.button<ButtonStyleProps>`
border-radius: 10px;
border-radius: 10px;
${(props) => buttonSize[props.$size]}
${(props) => buttonType[props.$colorType]?.[props.$state]}
${(props) => buttonSize[props.$size]}
${(props) => buttonType[props.$colorType]?.[props.$state]}
`;

const Button = ({ onClick, children, ...styleprops }: ButtonProps) => {
return (
<>
<ButtonStyle {...styleprops} onClick={onClick}>
{children}
</ButtonStyle>
</>
);
return (
<>
<ButtonStyle {...styleprops} onClick={onClick}>
{children}
</ButtonStyle>
</>
);
};

export default Button;

// 버튼 사용 예시
{
/* <Button state="normal" colorType="main" size="small">버튼</Button> */
}
/* <Button state="normal" colorType="main" size="small">버튼</Button> */
278 changes: 151 additions & 127 deletions src/Component/Calculator/calculResult.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,172 +5,196 @@ import Chicken from "../../img/chicken.png";
import Iphone from "../../img/iphone.png";
import styled from "styled-components";
import Skrrr from "../../img/SkerrImg.png";
import { CalculResultProps, UserProps } from "../../constants/interface";
import { CalculResultProps } from "../../constants/interface";
import { ValueProps } from "../../constants/interface";
import { formatPrice } from "../../util/util";

const Container = styled.div`
width: 100%;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
gap: 10px;
padding: 50px;
border-top: 2px solid rgb(0, 0, 0, 0.2);
margin-bottom: 1rem;
/* background-color: yellow; */
width: 100%;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
gap: 10px;
padding: 50px;
border-top: 2px solid rgb(0, 0, 0, 0.2);
margin-bottom: 1rem;
/* background-color: yellow; */
`;

const ResultContainer = styled.div`
display: flex;
flex-direction: column;
gap: 10px;
margin-top: 20px;
position: relative;
display: flex;
flex-direction: column;
gap: 10px;
margin-top: 20px;
position: relative;
`;

const DivContainer = styled.div`
display: flex;
flex-direction: row;
align-items: center;
gap: 15px;
display: flex;
flex-direction: row;
align-items: center;
gap: 15px;
`;

const ImgStyle = styled.img`
width: 25px;
height: 25px;
width: 25px;
height: 25px;
`;

const SpanContainer = styled.div`
display: flex;
flex-direction: row;
gap: 3px;
font-size: 20px;
white-space: nowrap;
display: flex;
flex-direction: row;
gap: 3px;
font-size: 20px;
white-space: nowrap;
`;
const SpanStyle = styled.div<ValueProps>`
font-weight: bold;
color: ${(props) => (props.$isNegative ? "#615EFC" : "#FF5759")};
font-weight: bold;
color: ${(props) => (props.$isNegative ? "#615EFC" : "#FF5759")};
`;

const SkrrrBird = styled.img`
position: absolute;
top: 45px;
left: 115px;
width: 260px;
opacity: 0.5;
z-index: -1;
position: absolute;
top: 45px;
left: 115px;
width: 260px;
opacity: 0.5;
z-index: -1;
`;

const NeverBuySkrrrBird = styled.img`
margin-right: 5rem;
width: 460px;
opacity: 0.5;
margin-right: 5rem;
width: 460px;
opacity: 0.5;
`;

const SkrrrText = styled.div`
position: absolute;
top: 70px;
left: 270px;
z-index: 3;
color: #ff5759;
font-size: 25px;
white-space: nowrap;
position: absolute;
top: 70px;
left: 270px;
z-index: 3;
color: #ff5759;
font-size: 25px;
white-space: nowrap;
`;

const NeverBuyText = styled.div`
/* position: absolute; */
top: 670px;
left: 470px;
z-index: 3;
color: #ff5759;
font-size: 25px;
white-space: nowrap;
/* position: absolute; */
top: 670px;
left: 470px;
z-index: 3;
color: #ff5759;
font-size: 25px;
white-space: nowrap;
`;

const BirdContainer = styled.div`
display: flex;
height: 400px;
justify-content: center;
align-items: center;
align-content: center;
flex-direction: column;
display: flex;
height: 400px;
justify-content: center;
align-items: center;
align-content: center;
flex-direction: column;
`;

const CalculResult: React.FC<CalculResultProps> = ({
price,
slave,
candy,
soul,
chicken,
iphone,
price,
slave,
candy,
soul,
chicken,
iphone,
}) => {
let userName: string = "사용자";
let userName: string = "사용자";

const userData = localStorage.getItem("user");
if (userData) {
userName = JSON.parse(userData).name;
}
const userData = localStorage.getItem("user");
if (userData) {
userName = JSON.parse(userData).name;
}

return (
<>
{price !== 0 ? (
<Container>
<SpanContainer>
<SpanStyle $isNegative={true}>{userName}</SpanStyle>
님은
<SpanStyle $isNegative={price < 0}>
{formatPrice(Math.abs(price))}
</SpanStyle>
원을 <span>{price >= 0 ? "벌었습니다." : "잃었습니다.."}</span>
</SpanContainer>
<ResultContainer>
<DivContainer>
<ImgStyle src={Salary} alt="" />
<SpanContainer>
2024년 최저시급 기준{" "}
<SpanStyle $isNegative={price < 0}>{slave}</SpanStyle>시간
</SpanContainer>
</DivContainer>
<DivContainer>
<ImgStyle src={Candy} alt="" />
<SpanContainer>
새콤달콤 <SpanStyle $isNegative={price < 0}>{candy}</SpanStyle>
</SpanContainer>
</DivContainer>
<DivContainer>
<ImgStyle src={Soul} alt="" />
<SpanContainer>
국밥<SpanStyle $isNegative={price < 0}>{soul}</SpanStyle>그릇
</SpanContainer>
</DivContainer>
<DivContainer>
<ImgStyle src={Chicken} alt="" />
<SpanContainer>
치킨 <SpanStyle $isNegative={price < 0}>{chicken}</SpanStyle>
마리
</SpanContainer>
</DivContainer>
<DivContainer>
<ImgStyle src={Iphone} alt="" />
<SpanContainer>
아이폰 <SpanStyle $isNegative={price < 0}>{iphone}</SpanStyle>
</SpanContainer>
</DivContainer>
<SkrrrBird src={Skrrr} alt="" />
<SkrrrText>{price >= 0 ? "살껄!@" : "팔껄!@"}</SkrrrText>
</ResultContainer>
</Container>
) : (
<BirdContainer>
<NeverBuyText>그 돈으론 1주도 사지 못했~스껄~,,,@</NeverBuyText>
<NeverBuySkrrrBird src={Skrrr} alt="" />
</BirdContainer>
)}
</>
);
return (
<>
{price !== 0 ? (
<Container>
<SpanContainer>
<SpanStyle $isNegative={true}>{userName}</SpanStyle>
님은
<SpanStyle $isNegative={price < 0}>
{formatPrice(Math.abs(price))}
</SpanStyle>
원을{" "}
<span>
{price >= 0 ? "벌었습니다." : "잃었습니다.."}
</span>
</SpanContainer>
<ResultContainer>
<DivContainer>
<ImgStyle src={Salary} alt="" />
<SpanContainer>
2024년 최저시급 기준{" "}
<SpanStyle $isNegative={price < 0}>
{slave}
</SpanStyle>
시간
</SpanContainer>
</DivContainer>
<DivContainer>
<ImgStyle src={Candy} alt="" />
<SpanContainer>
새콤달콤{" "}
<SpanStyle $isNegative={price < 0}>
{candy}
</SpanStyle>
</SpanContainer>
</DivContainer>
<DivContainer>
<ImgStyle src={Soul} alt="" />
<SpanContainer>
국밥
<SpanStyle $isNegative={price < 0}>
{soul}
</SpanStyle>
그릇
</SpanContainer>
</DivContainer>
<DivContainer>
<ImgStyle src={Chicken} alt="" />
<SpanContainer>
치킨{" "}
<SpanStyle $isNegative={price < 0}>
{chicken}
</SpanStyle>
마리
</SpanContainer>
</DivContainer>
<DivContainer>
<ImgStyle src={Iphone} alt="" />
<SpanContainer>
아이폰{" "}
<SpanStyle $isNegative={price < 0}>
{iphone}
</SpanStyle>
</SpanContainer>
</DivContainer>
<SkrrrBird src={Skrrr} alt="" />
<SkrrrText>
{price >= 0 ? "살껄!@" : "팔껄!@"}
</SkrrrText>
</ResultContainer>
</Container>
) : (
<BirdContainer>
<NeverBuyText>
그 돈으론 1주도 사지 못했~스껄~,,,@
</NeverBuyText>
<NeverBuySkrrrBird src={Skrrr} alt="" />
</BirdContainer>
)}
</>
);
};

export default CalculResult;
Loading

0 comments on commit 648bfa2

Please sign in to comment.