From 45463c16f16ba813480b5afe8a106a235ead2bef Mon Sep 17 00:00:00 2001 From: yzooop Date: Fri, 11 Oct 2024 14:14:22 +0900 Subject: [PATCH] =?UTF-8?q?Fix=20:=20fontSize=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/Component/Game/GameMoney.tsx | 298 ++++----- src/Component/Game/StocksTable.tsx | 123 ++-- src/Component/Game/gameHoldingsView.tsx | 3 +- src/Game/Main/mainStyle.css | 782 ++++++++++++------------ src/Game/Main/styleMain.ts | 21 +- src/Pages/game/playPage.tsx | 1 - 6 files changed, 623 insertions(+), 605 deletions(-) diff --git a/src/Component/Game/GameMoney.tsx b/src/Component/Game/GameMoney.tsx index c0bdb9a..1d89224 100644 --- a/src/Component/Game/GameMoney.tsx +++ b/src/Component/Game/GameMoney.tsx @@ -10,175 +10,175 @@ import GameViewTab from "./gameViewTab"; import { useSwipeStore } from "../../store/useSwipeStore"; const GameMoney = ({ - setBudget, - budget, + setBudget, + budget, }: { - setBudget: (budget: number) => void; - budget: number; + setBudget: (budget: number) => void; + budget: number; }) => { - const nav = useNavigate(); - - const [nickname, setNickname] = useState(""); // 닉네임 - const [total, setTotal] = useState(0); // 총 평가금액 - const [changeFromLast, setChangeFromLast] = useState(0); // 작년 대비 금액 - const [changeFromStart, setChangeFromStart] = useState(0); // 전체 대비 금액 - const [changeRateFromLast, setChangeRateFromLast] = useState(0); // 작년 대비 변동률 - const [changeRateFromStart, setChangeRateFromStart] = useState(0); // 전체 대비 변동률 - // const [holdingList, setHoldingList] = useState([]); // 20xx년 주식가격 - const [showTable, setShowTable] = useState(true); - const { holdingList, setHoldingList } = useSwipeStore(); // 내가 산거 - - const check = usePortfolioStore((state) => state.check); - - // 페이지 유효성 검사 - const setCheckYear = useGameStore((state) => state.setCheckYear); - - const { currentRank } = useGameStore((state) => ({ - currentRank: state.currentRank, - })); - - useEffect(() => { - axios - .get(`${process.env.REACT_APP_API_URL}/v1/game/user`, { - withCredentials: true, - headers: { - "Content-Type": "application/json", - }, - }) - .then((res) => { - if (res.status === 200) { - setCheckYear(res.data.year); - setNickname(res.data.nickname); - setBudget(res.data.budget); - setTotal(res.data.total); - setChangeFromLast(res.data.changeFromLast); - setChangeFromStart(res.data.changeFromStart); - setChangeRateFromLast(res.data.changeRateFromLast); - setChangeRateFromStart(res.data.changeRateFromStart); - setHoldingList(res.data.holdingList); - } else if (res.status === 401) { - alert("401"); - } - }) - .catch((e) => { - nav("/error"); - }); - }, [check, currentRank]); - - const handleShowTable = () => { - setShowTable((prev) => !prev); - }; - - const { fetchRank } = useGameStore((state) => ({ - fetchRank: state.fetchRank, - })); - - useEffect(() => { - fetchRank(); - }, []); - - return ( - - - {nickname} 님의 계좌잔고 💰 - - - 거래가능금액 -
{formatPrice(budget)} 원
-
-
- - 총 평가금액 -
{formatPrice(total)} 원
-
- - 작년 대비 -
0 - ? "red" - : changeRateFromLast < 0 - ? "blue" - : "black", - }} - > - {formatPrice(changeFromLast)} 원 ({changeRateFromLast}%) -
-
- - 전체 대비 -
0 - ? "red" - : changeRateFromStart < 0 - ? "blue" - : "black", - }} - > - {formatPrice(changeFromStart)} 원 ({changeRateFromStart}%) -
-
- - - -
나는 현재 {currentRank} 등!
- {showTable && } -
- ); + const nav = useNavigate(); + + const [nickname, setNickname] = useState(""); // 닉네임 + const [total, setTotal] = useState(0); // 총 평가금액 + const [changeFromLast, setChangeFromLast] = useState(0); // 작년 대비 금액 + const [changeFromStart, setChangeFromStart] = useState(0); // 전체 대비 금액 + const [changeRateFromLast, setChangeRateFromLast] = useState(0); // 작년 대비 변동률 + const [changeRateFromStart, setChangeRateFromStart] = useState(0); // 전체 대비 변동률 + // const [holdingList, setHoldingList] = useState([]); // 20xx년 주식가격 + const [showTable, setShowTable] = useState(true); + const { holdingList, setHoldingList } = useSwipeStore(); // 내가 산거 + + const check = usePortfolioStore((state) => state.check); + + // 페이지 유효성 검사 + const setCheckYear = useGameStore((state) => state.setCheckYear); + + const { currentRank } = useGameStore((state) => ({ + currentRank: state.currentRank, + })); + + useEffect(() => { + axios + .get(`${process.env.REACT_APP_API_URL}/v1/game/user`, { + withCredentials: true, + headers: { + "Content-Type": "application/json", + }, + }) + .then((res) => { + if (res.status === 200) { + setCheckYear(res.data.year); + setNickname(res.data.nickname); + setBudget(res.data.budget); + setTotal(res.data.total); + setChangeFromLast(res.data.changeFromLast); + setChangeFromStart(res.data.changeFromStart); + setChangeRateFromLast(res.data.changeRateFromLast); + setChangeRateFromStart(res.data.changeRateFromStart); + setHoldingList(res.data.holdingList); + } else if (res.status === 401) { + alert("401"); + } + }) + .catch((e) => { + nav("/error"); + }); + }, [check, currentRank]); + + const handleShowTable = () => { + setShowTable((prev) => !prev); + }; + + const { fetchRank } = useGameStore((state) => ({ + fetchRank: state.fetchRank, + })); + + useEffect(() => { + fetchRank(); + }, []); + + return ( + + + {nickname} 님의 계좌잔고 💰 + + + 거래가능금액 +
{formatPrice(budget)} 원
+
+
+ + 총 평가금액 +
{formatPrice(total)} 원
+
+ + 작년 대비 +
0 + ? "red" + : changeRateFromLast < 0 + ? "blue" + : "black", + }} + > + {formatPrice(changeFromLast)} 원 ({changeRateFromLast}%) +
+
+ + 전체 대비 +
0 + ? "red" + : changeRateFromStart < 0 + ? "blue" + : "black", + }} + > + {formatPrice(changeFromStart)} 원 ({changeRateFromStart}%) +
+
+ + + +
나는 현재 {currentRank} 등!
+ {showTable && } +
+ ); }; const GameMoneyContainer = styled.div` - width: 85%; - height: auto; - border-radius: 20px; - box-shadow: 0px 0px 17px rgb(213, 213, 213); - padding: 20px 10px; - position: relative; - margin-top: 20px; - margin-bottom: 20px; + width: 85%; + height: auto; + border-radius: 20px; + box-shadow: 0px 0px 17px rgb(213, 213, 213); + padding: 20px 10px; + position: relative; + margin-top: 20px; + margin-bottom: 20px; `; const GameMoneyTitle = styled.div` - margin-bottom: 30px; + margin-bottom: 30px; `; const GameMoneyBalance = styled.div` - display: flex; - margin: 15px 0; - flex-direction: row; + display: flex; + margin: 15px 0; + flex-direction: row; `; const BalanceDetailButton = styled.div` - position: absolute; - top: 118px; - right: 20px; + position: absolute; + top: 60px; + right: 20px; `; const BalanceTitle = styled.div` - color: #6c6c6c; - width: 110px; + color: #6c6c6c; + width: 110px; `; const Button = styled.button` - width: 78px; - height: 40px; - border-radius: 50px; - border: none; - background-color: #f1f1f1; - cursor: pointer; - - &:hover { - background-color: #615efc; - color: white; - font-weight: 600; - } + width: 78px; + height: 40px; + border-radius: 50px; + border: none; + background-color: #f1f1f1; + cursor: pointer; + + &:hover { + background-color: #615efc; + color: white; + font-weight: 600; + } `; export default GameMoney; diff --git a/src/Component/Game/StocksTable.tsx b/src/Component/Game/StocksTable.tsx index 53f7002..5784342 100644 --- a/src/Component/Game/StocksTable.tsx +++ b/src/Component/Game/StocksTable.tsx @@ -5,67 +5,66 @@ import "./StocksTableStyle.css"; import styled, { keyframes } from "styled-components"; const StocksTable: React.FC = ({ stocks, year }) => { - const header = ["번호", "종목", "전년", "올해", "등락"]; - console.log(stocks); - - return ( -
- - - - {header.map((item, index) => ( - - ))} - - - - {stocks && - stocks.map((stock, index) => ( - - - - - - - - ))} - -
{item}
{index + 1}{stock.name} - {formatPriceWithYear(stock.prev, year)} - 0 - ? "red" - : stock.changeRate < 0 - ? "blue" - : "black", - textAlign: "right", - }} - > - {formatPriceWithYear(stock.current, year)} - 0 - ? "red" - : stock.changeRate < 0 - ? "blue" - : "black", - }} - > - {formatChangeRate(stock.changeRate)} -
-
- ); + return ( +
+ + + + {header.map((item, index) => ( + + ))} + + + + {stocks && + stocks.map((stock, index) => ( + + + + + + + + ))} + +
{item}
{index + 1}{stock.name} + {formatPriceWithYear(stock.prev, year)} + 0 + ? "red" + : stock.changeRate < 0 + ? "blue" + : "black", + textAlign: "right", + }} + > + {formatPriceWithYear(stock.current, year)} + 0 + ? "red" + : stock.changeRate < 0 + ? "blue" + : "black", + }} + > + {formatChangeRate(stock.changeRate)} +
+
+ ); }; // 부드럽게 나타나는 애니메이션 정의 @@ -81,9 +80,9 @@ const fadeIn = keyframes` `; const TableRow = styled.tr<{ index: number }>` - animation: ${fadeIn} 0.5s ease-out forwards; - animation-delay: ${({ index }) => index * 0.1}s; - opacity: 0; + animation: ${fadeIn} 0.5s ease-out forwards; + animation-delay: ${({ index }) => index * 0.1}s; + opacity: 0; `; export default StocksTable; diff --git a/src/Component/Game/gameHoldingsView.tsx b/src/Component/Game/gameHoldingsView.tsx index d300122..226f5c6 100644 --- a/src/Component/Game/gameHoldingsView.tsx +++ b/src/Component/Game/gameHoldingsView.tsx @@ -28,7 +28,7 @@ const GameHoldingsView = ({ holdingList }: any) => { ) : ( <> - + {header.map((item, index) => ( {item} ))} @@ -43,6 +43,7 @@ const GameHoldingsView = ({ holdingList }: any) => { index % 2 === 0 ? "#ededed" : "white", + fontSize: "11px", }} > {holding.stockName} diff --git a/src/Game/Main/mainStyle.css b/src/Game/Main/mainStyle.css index 9a922d6..c6959d3 100644 --- a/src/Game/Main/mainStyle.css +++ b/src/Game/Main/mainStyle.css @@ -1,512 +1,528 @@ .container { - display: flex; - justify-content: center; - align-items: center; - width: 100%; - height: 100vh; + display: flex; + justify-content: center; + align-items: center; + width: 100%; + height: 100vh; } + +@media (max-width: 768px) { + .container { + flex-direction: column; /* 세로 방향으로 정렬 */ + height: auto; /* 높이를 자동으로 조정 */ + padding: 20px; /* 여백 추가 */ + position: absolute; + left: 50%; + top: 50%; + transform: translate(-50%, -50%); + } +} + .macbook { - position: relative; - width: 228px; - height: 260px; + position: relative; + width: 228px; + height: 260px; } .macbook__topBord { - position: absolute; - z-index: 0; - top: 34px; - left: 0; - width: 128px; - height: 116px; - border-radius: 6px; - transform-origin: center; - background: linear-gradient(-135deg, #c8c9c9 52%, #8c8c8c 56%); - transform: scale(0) skewY(-30deg); - animation: topbord 0.4s 1.7s ease-out; - animation-fill-mode: forwards; + position: absolute; + z-index: 0; + top: 34px; + left: 0; + width: 128px; + height: 116px; + border-radius: 6px; + transform-origin: center; + background: linear-gradient(-135deg, #c8c9c9 52%, #8c8c8c 56%); + transform: scale(0) skewY(-30deg); + animation: topbord 0.4s 1.7s ease-out; + animation-fill-mode: forwards; } .macbook__topBord::before { - content: ""; - position: absolute; - z-index: 2; - top: 8px; - left: 6px; - width: 100%; - height: 100%; - border-radius: 6px; - background: #000; + content: ""; + position: absolute; + z-index: 2; + top: 8px; + left: 6px; + width: 100%; + height: 100%; + border-radius: 6px; + background: #000; } .macbook__topBord::after { - content: ""; - position: absolute; - z-index: 1; - bottom: -7px; - left: 8px; - width: 168px; - height: 12px; - transform-origin: left bottom; - transform: rotate(-42deg) skew(-4deg); - background: linear-gradient(-135deg, #c8c9c9 52%, #8c8c8c 56%); + content: ""; + position: absolute; + z-index: 1; + bottom: -7px; + left: 8px; + width: 168px; + height: 12px; + transform-origin: left bottom; + transform: rotate(-42deg) skew(-4deg); + background: linear-gradient(-135deg, #c8c9c9 52%, #8c8c8c 56%); } .macbook__display { - position: absolute; - z-index: 10; - top: 17px; - left: 12px; - z-index: 2; - width: calc(100% - 12px); - height: calc(100% - 18px); - background: linear-gradient(45deg, #3ba9ff, #c82aff); + position: absolute; + z-index: 10; + top: 17px; + left: 12px; + z-index: 2; + width: calc(100% - 12px); + height: calc(100% - 18px); + background: linear-gradient(45deg, #3ba9ff, #c82aff); } .macbook__display::before { - content: ""; - position: absolute; - z-index: 5; - top: -9px; - left: -6px; - width: calc(100% + 12px); - height: calc(100% + 18px); - border-radius: 6px; - background: linear-gradient( - 60deg, - rgba(255, 255, 255, 0) 60%, - rgba(255, 255, 255, 0.3) 60% - ); + content: ""; + position: absolute; + z-index: 5; + top: -9px; + left: -6px; + width: calc(100% + 12px); + height: calc(100% + 18px); + border-radius: 6px; + background: linear-gradient( + 60deg, + rgba(255, 255, 255, 0) 60%, + rgba(255, 255, 255, 0.3) 60% + ); } .macbook__load { - position: relative; - width: 100%; - height: 100%; - background: #222; - animation: display 0.4s 4.3s ease; - opacity: 1; - animation-fill-mode: forwards; + position: relative; + width: 100%; + height: 100%; + background: #222; + animation: display 0.4s 4.3s ease; + opacity: 1; + animation-fill-mode: forwards; } .macbook__load:before { - content: ""; - position: absolute; - top: 0; - left: 0; - right: 0; - bottom: 0; - margin: auto; - width: 80px; - height: 6px; - border-radius: 3px; - box-sizing: border-box; - border: solid 1px #fff; + content: ""; + position: absolute; + top: 0; + left: 0; + right: 0; + bottom: 0; + margin: auto; + width: 80px; + height: 6px; + border-radius: 3px; + box-sizing: border-box; + border: solid 1px #fff; } .macbook__load:after { - content: ""; - position: absolute; - top: 0; - left: 18px; - bottom: 0; - margin: auto; - width: 0; - height: 6px; - border-radius: 3px; - background: #fff; - animation: load 2s 2s ease-out; - animation-fill-mode: forwards; + content: ""; + position: absolute; + top: 0; + left: 18px; + bottom: 0; + margin: auto; + width: 0; + height: 6px; + border-radius: 3px; + background: #fff; + animation: load 2s 2s ease-out; + animation-fill-mode: forwards; } .macbook__image { - position: absolute; - top: 0; - left: 0; - right: 0; - bottom: 0; - margin: auto; - width: 100px; - height: auto; - opacity: 0; - /* visibility: hidden; */ - transition: opacity 0.5s ease-in-out; + position: absolute; + top: 0; + left: 0; + right: 0; + bottom: 0; + margin: auto; + width: 100px; + height: auto; + opacity: 0; + /* visibility: hidden; */ + transition: opacity 0.5s ease-in-out; } .macbook__image.visible { - /* visibility: hidden; */ - opacity: 1; + /* visibility: hidden; */ + opacity: 1; } .macbook__underBord { - position: relative; - left: 42px; - bottom: -145px; - width: 150px; - height: 90px; - border-radius: 6px; - transform-origin: center; - transform: rotate(-30deg) skew(30deg); - background: linear-gradient(-45deg, #c8c9c9 61%, #8c8c8c 66%); - animation: modal 0.5s 1s ease-out; - opacity: 0; - animation-fill-mode: forwards; + position: relative; + left: 42px; + bottom: -145px; + width: 150px; + height: 90px; + border-radius: 6px; + transform-origin: center; + transform: rotate(-30deg) skew(30deg); + background: linear-gradient(-45deg, #c8c9c9 61%, #8c8c8c 66%); + animation: modal 0.5s 1s ease-out; + opacity: 0; + animation-fill-mode: forwards; } .macbook__underBord::before { - content: ""; - position: absolute; - z-index: 3; - top: -8px; - left: 8px; - width: 100%; - height: 100%; - border-radius: 6px; - background: #dcdede; + content: ""; + position: absolute; + z-index: 3; + top: -8px; + left: 8px; + width: 100%; + height: 100%; + border-radius: 6px; + background: #dcdede; } .macbook__underBord::after { - content: ""; - position: absolute; - z-index: 2; - top: -8px; - left: 12px; - width: 170px; - height: 15px; - transform-origin: top left; - background: linear-gradient(-45deg, #c8c9c9 61%, #8c8c8c 66%); - transform: rotate(31deg) skew(-16deg); + content: ""; + position: absolute; + z-index: 2; + top: -8px; + left: 12px; + width: 170px; + height: 15px; + transform-origin: top left; + background: linear-gradient(-45deg, #c8c9c9 61%, #8c8c8c 66%); + transform: rotate(31deg) skew(-16deg); } .macbook__keybord { - position: relative; - top: 0; - left: 16px; - z-index: 3; - border-radius: 3px; - width: calc(100% - 16px); - height: 45px; - background: #c8c9c9; + position: relative; + top: 0; + left: 16px; + z-index: 3; + border-radius: 3px; + width: calc(100% - 16px); + height: 45px; + background: #c8c9c9; } .macbook__keybord::before { - content: ""; - position: absolute; - bottom: -30px; - left: 0; - right: 0; - margin: 0 auto; - width: 40px; - height: 25px; - border-radius: 3px; - background: #c8c9c9; + content: ""; + position: absolute; + bottom: -30px; + left: 0; + right: 0; + margin: 0 auto; + width: 40px; + height: 25px; + border-radius: 3px; + background: #c8c9c9; } .keybord { - position: relative; - top: 2px; - left: 2px; - display: flex; - flex-direction: column; - width: calc(100% - 3px); - height: calc(100% - 4px); + position: relative; + top: 2px; + left: 2px; + display: flex; + flex-direction: column; + width: calc(100% - 3px); + height: calc(100% - 4px); } .keybord__touchbar { - width: 100%; - height: 6px; - border-radius: 3px; - background: #000; + width: 100%; + height: 6px; + border-radius: 3px; + background: #000; } .keybord__keyBox { - display: grid; - grid-template-rows: 3fr 1fr; - grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr; - width: 100%; - height: 24px; - margin: 1px 0 0 0; - padding: 0 0 0 1px; - box-sizing: border-box; - list-style: none; + display: grid; + grid-template-rows: 3fr 1fr; + grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr; + width: 100%; + height: 24px; + margin: 1px 0 0 0; + padding: 0 0 0 1px; + box-sizing: border-box; + list-style: none; } .keybord__key { - position: relative; - width: 8px; - height: 7px; - margin: 1px; - background: #000; + position: relative; + width: 8px; + height: 7px; + margin: 1px; + background: #000; } .keybord__keyBox .keybord__key { - transform: translate(60px, -60px); - animation: key 0.2s 1.4s ease-out; - animation-fill-mode: forwards; - opacity: 0; + transform: translate(60px, -60px); + animation: key 0.2s 1.4s ease-out; + animation-fill-mode: forwards; + opacity: 0; } .keybord__keyBox .keybord__key::before, .keybord__keyBox .keybord__key::after { - content: ""; - position: absolute; - left: 0; - width: 100%; - height: 100%; - background: #000; + content: ""; + position: absolute; + left: 0; + width: 100%; + height: 100%; + background: #000; } .keybord__key::before { - top: 8px; - transform: translate(20px, -20px); - animation: key1 0.2s 1.5s ease-out; - animation-fill-mode: forwards; + top: 8px; + transform: translate(20px, -20px); + animation: key1 0.2s 1.5s ease-out; + animation-fill-mode: forwards; } .keybord__key::after { - top: 16px; - transform: translate(40px, -40px); - animation: key2 0.2s 1.6s ease-out; - animation-fill-mode: forwards; + top: 16px; + transform: translate(40px, -40px); + animation: key2 0.2s 1.6s ease-out; + animation-fill-mode: forwards; } .keybord__keyBox .key--12::before { - width: 10px; + width: 10px; } .keybord__keyBox .key--13::before { - height: 10px; + height: 10px; } .key--01 { - grid-row: 1 / 2; - grid-column: 1 / 2; + grid-row: 1 / 2; + grid-column: 1 / 2; } .key--02 { - grid-row: 1 / 2; - grid-column: 2 / 3; + grid-row: 1 / 2; + grid-column: 2 / 3; } .key--03 { - grid-row: 1 / 2; - grid-column: 3 / 4; + grid-row: 1 / 2; + grid-column: 3 / 4; } .key--04 { - grid-row: 1 / 2; - grid-column: 4 / 5; + grid-row: 1 / 2; + grid-column: 4 / 5; } .key--05 { - grid-row: 1 / 2; - grid-column: 5 / 6; + grid-row: 1 / 2; + grid-column: 5 / 6; } .key--06 { - grid-row: 1 / 2; - grid-column: 6 / 7; + grid-row: 1 / 2; + grid-column: 6 / 7; } .key--07 { - grid-row: 1 / 2; - grid-column: 7 / 8; + grid-row: 1 / 2; + grid-column: 7 / 8; } .key--08 { - grid-row: 1 / 2; - grid-column: 8 / 9; + grid-row: 1 / 2; + grid-column: 8 / 9; } .key--09 { - grid-row: 1 / 2; - grid-column: 9 / 10; + grid-row: 1 / 2; + grid-column: 9 / 10; } .key--10 { - grid-row: 1 / 2; - grid-column: 10 / 11; + grid-row: 1 / 2; + grid-column: 10 / 11; } .key--11 { - grid-row: 1 / 2; - grid-column: 11 / 12; + grid-row: 1 / 2; + grid-column: 11 / 12; } .key--12 { - grid-row: 1 / 2; - grid-column: 12 / 13; + grid-row: 1 / 2; + grid-column: 12 / 13; } .key--13 { - grid-row: 1 / 2; - grid-column: 13 / 14; + grid-row: 1 / 2; + grid-column: 13 / 14; } .keybord__keyBox--under { - margin: 0; - padding: 0 0 0 1px; - box-sizing: border-box; - list-style: none; - display: flex; + margin: 0; + padding: 0 0 0 1px; + box-sizing: border-box; + list-style: none; + display: flex; } .keybord__keyBox--under .keybord__key { - transform: translate(80px, -80px); - animation: key3 0.3s 1.6s linear; - animation-fill-mode: forwards; - opacity: 0; + transform: translate(80px, -80px); + animation: key3 0.3s 1.6s linear; + animation-fill-mode: forwards; + opacity: 0; } .key--19 { - width: 28px; + width: 28px; } @keyframes topbord { - 0% { - transform: scale(0) skewY(-30deg); - } - 30% { - transform: scale(1.1) skewY(-30deg); - } - 45% { - transform: scale(0.9) skewY(-30deg); - } - 60% { - transform: scale(1.05) skewY(-30deg); - } - 75% { - transform: scale(0.95) skewY(-30deg); - } - 90% { - transform: scale(1.02) skewY(-30deg); - } - 100% { - transform: scale(1) skewY(-30deg); - } + 0% { + transform: scale(0) skewY(-30deg); + } + 30% { + transform: scale(1.1) skewY(-30deg); + } + 45% { + transform: scale(0.9) skewY(-30deg); + } + 60% { + transform: scale(1.05) skewY(-30deg); + } + 75% { + transform: scale(0.95) skewY(-30deg); + } + 90% { + transform: scale(1.02) skewY(-30deg); + } + 100% { + transform: scale(1) skewY(-30deg); + } } @keyframes display { - 0% { - opacity: 1; - } - 100% { - opacity: 0; - } + 0% { + opacity: 1; + } + 100% { + opacity: 0; + } } @keyframes load { - 0% { - width: 0; - } - 20% { - width: 40px; - } - 30% { - width: 40px; - } - 60% { - width: 60px; - } - 90% { - width: 60px; - } - 100% { - width: 80px; - } + 0% { + width: 0; + } + 20% { + width: 40px; + } + 30% { + width: 40px; + } + 60% { + width: 60px; + } + 90% { + width: 60px; + } + 100% { + width: 80px; + } } @keyframes modal { - 0% { - transform: scale(0) rotate(-30deg) skew(30deg); - opacity: 0; - } - 30% { - transform: scale(1.1) rotate(-30deg) skew(30deg); - opacity: 1; - } - 45% { - transform: scale(0.9) rotate(-30deg) skew(30deg); - opacity: 1; - } - 60% { - transform: scale(1.05) rotate(-30deg) skew(30deg); - opacity: 1; - } - 75% { - transform: scale(0.95) rotate(-30deg) skew(30deg); - opacity: 1; - } - 90% { - transform: scale(1.02) rotate(-30deg) skew(30deg); - opacity: 1; - } - 100% { - transform: scale(1) rotate(-30deg) skew(30deg); - opacity: 1; - } + 0% { + transform: scale(0) rotate(-30deg) skew(30deg); + opacity: 0; + } + 30% { + transform: scale(1.1) rotate(-30deg) skew(30deg); + opacity: 1; + } + 45% { + transform: scale(0.9) rotate(-30deg) skew(30deg); + opacity: 1; + } + 60% { + transform: scale(1.05) rotate(-30deg) skew(30deg); + opacity: 1; + } + 75% { + transform: scale(0.95) rotate(-30deg) skew(30deg); + opacity: 1; + } + 90% { + transform: scale(1.02) rotate(-30deg) skew(30deg); + opacity: 1; + } + 100% { + transform: scale(1) rotate(-30deg) skew(30deg); + opacity: 1; + } } @keyframes key { - 0% { - transform: translate(60px, -60px); - opacity: 0; - } - 100% { - transform: translate(0px, 0px); - opacity: 1; - } + 0% { + transform: translate(60px, -60px); + opacity: 0; + } + 100% { + transform: translate(0px, 0px); + opacity: 1; + } } @keyframes key1 { - 0% { - transform: translate(20px, -20px); - opacity: 0; - } - 100% { - transform: translate(0px, 0px); - opacity: 1; - } + 0% { + transform: translate(20px, -20px); + opacity: 0; + } + 100% { + transform: translate(0px, 0px); + opacity: 1; + } } @keyframes key2 { - 0% { - transform: translate(40px, -40px); - opacity: 0; - } - 100% { - transform: translate(0px, 0px); - opacity: 1; - } + 0% { + transform: translate(40px, -40px); + opacity: 0; + } + 100% { + transform: translate(0px, 0px); + opacity: 1; + } } @keyframes key3 { - 0% { - transform: translate(80px, -80px); - opacity: 0; - } - 100% { - transform: translate(0px, 0px); - opacity: 1; - } + 0% { + transform: translate(80px, -80px); + opacity: 0; + } + 100% { + transform: translate(0px, 0px); + opacity: 1; + } } @keyframes load { - 0% { - width: 0; - } - 100% { - width: 80px; - } + 0% { + width: 0; + } + 100% { + width: 80px; + } } @keyframes flyOut { - 0% { - transform: translate(0, 0) scale(1); - opacity: 1; - } - 50% { - transform: translate(250px, -150px) scale(1.5); /* Increase size halfway */ - opacity: 1; - } - 100% { - transform: translate(500px, -300px); /* Adjust the flight path as needed */ - opacity: 0; - } + 0% { + transform: translate(0, 0) scale(1); + opacity: 1; + } + 50% { + transform: translate(250px, -150px) scale(1.5); /* Increase size halfway */ + opacity: 1; + } + 100% { + transform: translate( + 500px, + -300px + ); /* Adjust the flight path as needed */ + opacity: 0; + } } .macbook__image { - visibility: hidden; - opacity: 0; - transition: opacity 1s ease-in; - position: absolute; - top: 50%; - left: 50%; - transform: translate(-50%, -50%); + visibility: hidden; + opacity: 0; + transition: opacity 1s ease-in; + position: absolute; + top: 50%; + left: 50%; + transform: translate(-50%, -50%); } .macbook__image.visible { - visibility: visible; - opacity: 1; + visibility: visible; + opacity: 1; } .macbook__image.fly { - animation: flyOut 2s ease-out forwards; /* Adjust animation duration */ + animation: flyOut 2s ease-out forwards; /* Adjust animation duration */ } .macbook__game { - position: absolute; - top: 50%; - left: 50%; - transform: translate(-50%, -50%); - font-size: 24px; - color: white; - text-align: center; - opacity: 0; - animation: fadeIn 1s forwards; - width: 100%; + position: absolute; + top: 50%; + left: 50%; + transform: translate(-50%, -50%); + font-size: 24px; + color: white; + text-align: center; + opacity: 0; + animation: fadeIn 1s forwards; + width: 100%; } @keyframes fadeIn { - from { - opacity: 0; - } - to { - opacity: 1; - } + from { + opacity: 0; + } + to { + opacity: 1; + } } diff --git a/src/Game/Main/styleMain.ts b/src/Game/Main/styleMain.ts index 4075f42..e803f5f 100644 --- a/src/Game/Main/styleMain.ts +++ b/src/Game/Main/styleMain.ts @@ -1,16 +1,19 @@ import { styled } from "styled-components"; export const ButtonDiv = styled.div` - display: flex; - margin-top: 2rem; - margin-left: 2rem; + display: flex; + margin-top: 2rem; + margin-left: 2rem; + @media (max-width: 768px) { + margin-left: 0; + } `; export const GameTitle = styled.p` - display: flex; - align-items: center; - justify-content: center; - font-size: 25px; - font-weight: 900; - margin-bottom: 1rem; + display: flex; + align-items: center; + justify-content: center; + font-size: 25px; + font-weight: 900; + margin-bottom: 1rem; `; diff --git a/src/Pages/game/playPage.tsx b/src/Pages/game/playPage.tsx index 5954f48..4dc5d58 100644 --- a/src/Pages/game/playPage.tsx +++ b/src/Pages/game/playPage.tsx @@ -30,7 +30,6 @@ const Container = styled.div` const PlayPage = () => { const { year } = useParams<{ year?: string }>(); const { stockData, setStockData } = useStock(); - console.log(stockData); const nav = useNavigate(); const yearValue = year || "2014"; // 페이지 유효성 검사를 위한 변수