Skip to content

Commit

Permalink
#5 feat: 통계 모달 필터 API 연결
Browse files Browse the repository at this point in the history
  • Loading branch information
qwerty00ui88 committed Mar 6, 2024
1 parent 9be3d12 commit fec670f
Show file tree
Hide file tree
Showing 18 changed files with 9,361 additions and 81 deletions.
2 changes: 1 addition & 1 deletion src/assets/cancel.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
6 changes: 4 additions & 2 deletions src/components/FloatingBar.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -62,10 +62,12 @@ function FloatingBar({ isOpen, isScrolledDown }: FloatingBarProps) {
<FloatingBarWrapper $isScrolledDown={isScrolledDown} $isOpen={isOpen}>
<Text>
<li>
👉포트폴리오라는거시다~~~!!!👉포트폴리오라는거시다~~~!!!👉포트폴리오라는거시다~~~!!!👉포트폴리오라는거시다~~~!!!
👉추천을 가장 많이 받은 컨텐츠는? 👉비추천을 가장 많이 받은
컨텐츠는? 👉다른 사람의 인생 컨텐츠가 궁금하다면?
</li>
<li>
👉포트폴리오라는거시다~~~!!!👉포트폴리오라는거시다~~~!!!👉포트폴리오라는거시다~~~!!!👉포트폴리오라는거시다~~~!!!
👉추천을 가장 많이 받은 컨텐츠는? 👉비추천을 가장 많이 받은
컨텐츠는? 👉다른 사람의 인생 컨텐츠가 궁금하다면?
</li>
</Text>
</FloatingBarWrapper>
Expand Down
15 changes: 1 addition & 14 deletions src/components/Footer.tsx
Original file line number Diff line number Diff line change
@@ -1,10 +1,9 @@
import React from 'react'
import { styled } from 'styled-components'
import { mediumWeight, xsmallSize } from '../style/font'
import { xsmallSize } from '../style/font'
import { ReactComponent as Velog } from '../assets/velog.svg'
import { ReactComponent as GitHub } from '../assets/github.svg'
import { ReactComponent as Gmail } from '../assets/gmail.svg'
import { xsmallRadius } from '../style/border'

const FooterWrapper = styled.div`
display: flex;
Expand Down Expand Up @@ -45,14 +44,6 @@ const FooterLeftUl = styled.ul`
}
`

const FooterRightSelect = styled.select`
width: 7rem;
padding: 3px 0 3px 3px;
font-weight: ${mediumWeight};
color: black;
border-radius: ${xsmallRadius};
`

const FooterLinks = styled.ul`
flex: 1;
display: flex;
Expand Down Expand Up @@ -95,10 +86,6 @@ function Footer() {
})}
</FooterLeft>
<FooterRight>
<FooterRightSelect name="language">
<option>한국어</option>
<option>영어</option>
</FooterRightSelect>
<FooterLinks>
<Gmail width="24" fill="#848485" />
<GitHub width="24" fill="#848485" />
Expand Down
2 changes: 0 additions & 2 deletions src/components/Header.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -164,8 +164,6 @@ function Header() {
'http://localhost:3000'
})
}}
width="4.5rem"
height="2.4rem"
/>
</Menu>
) : (
Expand Down
3 changes: 1 addition & 2 deletions src/components/Outline.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -89,8 +89,7 @@ function Outline({
const releaseDate =
(data as MovieDetail).release_date || (data as TVDetail).first_air_date
const { runtime } = data as MovieDetail
// eslint-disable-next-line no-console
console.log(myComment)

return (
data && (
<OutlineWrapper $backdrop={data.backdrop_path}>
Expand Down
4 changes: 2 additions & 2 deletions src/components/SearchBar.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@ const SearchBarWrapper = styled.div<{ $isOpen: boolean }>`
}
`

const CancelButton = styled.button`
export const CancelButton = styled.button`
position: absolute;
top: 20px;
right: 20px;
Expand Down Expand Up @@ -128,7 +128,7 @@ function SearchBar({ isOpen, handleSetIsOpen }: SearchBarProps) {
{isOpen ? (
<>
<CancelButton type="button" onClick={handleCancelButton}>
<Cancel width={20} height={20} />
<Cancel />
</CancelButton>
<InputContainer>
<label htmlFor="search">
Expand Down
7 changes: 1 addition & 6 deletions src/components/SignUp1.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -31,12 +31,7 @@ function SignUp1({
}}
name="nickname"
/>
<Button
name="닉네임중복"
onClick={() => {}}
width="20rem"
height="3rem"
/>
<Button name="닉네임 중복" onClick={() => {}} />
<label htmlFor="email">이메일</label>
<Input
id="email"
Expand Down
54 changes: 24 additions & 30 deletions src/components/StatModal.tsx
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
import React, { useState } from 'react'
import styled from 'styled-components'
import { ReactComponent as Good } from '../assets/good.svg'
import { ReactComponent as Bad } from '../assets/bad.svg'
import { ReactComponent as Favorite } from '../assets/favorite.svg'
import Map from './Map'
import { TrendingWrapper } from './Trending'
import StatModal1 from './StatModal1'
import { ReactComponent as Cancel } from '../assets/cancel.svg'
import StatModal2 from './StatModal2'
import IconButton from './commons/IconButton'

const StatModalWrapper = styled(TrendingWrapper)`
display: flex;
Expand All @@ -20,38 +20,32 @@ const StatModalWrapper = styled(TrendingWrapper)`
z-index: 3;
`

declare global {
interface Window {
// eslint-disable-next-line @typescript-eslint/no-explicit-any
kakao: any
}
}

const MapSection = styled.div`
width: 100%;
flex: 1;
.overlaybox {
background-color: black;
}
const CancelIconButton = styled.div`
position: absolute;
top: 20px;
right: 20px;
`

function StatModal({ handleClose }: { handleClose: () => void }) {
const [mapPosition] = useState([37.5172, 127.0473])
const [page, setPage] = useState(1)
const [mapPosition] = useState([36.5, 128])

const handlePage = () => {
setPage(page === 1 ? 2 : 1)
}

return (
<StatModalWrapper>
<div>
<Good fill="#019e74" />
<Bad fill="rgb(229, 9, 20)" />
<Favorite fill="#FFD700" />
<button type="button" onClick={handleClose}>
X
</button>
</div>
<MapSection>
<Map mapPosition={mapPosition} />
</MapSection>
<CancelIconButton>
<IconButton onClick={handleClose}>
<Cancel />
</IconButton>
</CancelIconButton>
{page === 1 ? (
<StatModal1 mapPosition={mapPosition} handlePage={handlePage} />
) : (
<StatModal2 handlePage={handlePage} />
)}
</StatModalWrapper>
)
}
Expand Down
66 changes: 66 additions & 0 deletions src/components/StatModal1.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
import React from 'react'
import styled from 'styled-components'
import { ReactComponent as Good } from '../assets/good.svg'
import { ReactComponent as Bad } from '../assets/bad.svg'
import { ReactComponent as Favorite } from '../assets/favorite.svg'
import Map from './Map'
import Button from './commons/Button'
import IconButton from './commons/IconButton'

declare global {
interface Window {
// eslint-disable-next-line @typescript-eslint/no-explicit-any
kakao: any
}
}

const MapSection = styled.div`
width: 100%;
flex: 1;
.overlaybox {
background-color: black;
}
`

const IconButtonSection = styled.div`
display: flex;
gap: 1rem;
`

const ButtonSection = styled.div`
display: flex;
justify-content: space-between;
margin: 1rem 0;
`

function StatModal1({
mapPosition,
handlePage,
}: {
mapPosition: number[]
handlePage: () => void
}) {
return (
<>
<ButtonSection>
<IconButtonSection>
<IconButton onClick={() => {}}>
<Good fill="#019e74" />
</IconButton>
<IconButton onClick={() => {}}>
<Bad fill="rgb(229, 9, 20)" />
</IconButton>
<IconButton onClick={() => {}}>
<Favorite fill="#FFD700" />
</IconButton>
</IconButtonSection>
<Button name="필터로 검색하기" onClick={handlePage} />
</ButtonSection>
<MapSection>
<Map mapPosition={mapPosition} />
</MapSection>
</>
)
}
export default StatModal1
104 changes: 104 additions & 0 deletions src/components/StatModal2.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,104 @@
import React, { useEffect, useState } from 'react'
import styled from 'styled-components'
import axios from 'axios'
import Button from './commons/Button'
import DropDown from './commons/DropDown'

const TopSection = styled.div`
display: flex;
justify-content: space-between;
margin: 1rem 0;
`

const FilterSection = styled.div`
select {
margin-right: 1rem;
}
`

function StatModal2({ handlePage }: { handlePage: () => void }) {
const [region1, setRegion1] = useState<string>('서울특별시')
const [region2, setRegion2] = useState<string>('강남구')
const [gender, setGender] = useState<string>('male')
const [ageGroup, setAgeGroup] = useState<string>('20')

useEffect(() => {}, [])

return (
<TopSection>
<FilterSection>
<DropDown
selectId="region1"
onChange={(e) => {
setRegion1(e.target.value)
}}
options={[
{ value: '서울특별시', name: '서울특별시' },
{ value: '경기도', name: '경기도' },
]}
/>
<DropDown
selectId="region2"
onChange={(e) => {
setRegion2(e.target.value)
}}
options={[
{ value: '강남구', name: '강남구' },
{ value: '화성시', name: '화성시' },
]}
/>
<DropDown
selectId="gender"
onChange={(e) => {
setGender(e.target.value)
}}
options={[
{ value: 'male', name: '남성' },
{ value: 'female', name: '여성' },
]}
/>
<DropDown
selectId="ageGroup"
onChange={(e) => {
setAgeGroup(e.target.value)
// eslint-disable-next-line no-console
console.log(e.target.value)
}}
options={[
{ value: '10', name: '10대' },
{ value: '20', name: '20대' },
{ value: '30', name: '30대' },
{ value: '40', name: '40대' },
{ value: '50', name: '50대' },
{ value: '60', name: '60대' },
{ value: '70', name: '70대' },
{ value: '80', name: '80대' },
]}
/>
<Button
name="검색"
onClick={() => {
axios
.get(
'http://localhost/statistics/by-region-gender-ageGroup',
{
params: {
region: `${region1} ${region2}`,
gender,
ageGroup: Number(ageGroup),
},
withCredentials: true,
}
)
.then((response) => {
// eslint-disable-next-line no-console
console.log(response)
})
}}
/>
</FilterSection>
<Button name="지도로 보기" onClick={handlePage} />
</TopSection>
)
}
export default StatModal2
12 changes: 4 additions & 8 deletions src/components/commons/Button.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import { xsmallRadius } from '../../style/border'
import { semiboldWeight } from '../../style/font'

export interface ButtonWrapperProps {
$width: string
$width: string | null
$height: string | null
}

Expand All @@ -15,20 +15,16 @@ export const ButtonWrapper = styled.button<ButtonWrapperProps>`
border-radius: ${xsmallRadius};
background-color: rgb(229, 9, 20);
font-weight: ${semiboldWeight};
padding: 0.5rem;
`
interface ButtonProps {
name: string
onClick: (e?: MouseEvent<HTMLButtonElement>) => void
width?: string
width?: string | null
height?: string | null
}

function Button({
name,
onClick,
width = '4.5rem',
height = null,
}: ButtonProps) {
function Button({ name, onClick, width = null, height = null }: ButtonProps) {
return (
<ButtonWrapper
type="button"
Expand Down
2 changes: 1 addition & 1 deletion src/components/commons/CommentModal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -90,7 +90,7 @@ function Modal({
'http://localhost/comment/create',
{
mediaType,
tmdbId,
tmdbId: Number(tmdbId),
text: comment,
},
{ withCredentials: true }
Expand Down
Loading

0 comments on commit fec670f

Please sign in to comment.