Commit 1257468b authored by Kim, Subin's avatar Kim, Subin
Browse files

Merge branch 'master' into kimpen

parents 4a0d5496 b81942c2
...@@ -17,6 +17,7 @@ const INIT_CINEMAINFO = { ...@@ -17,6 +17,7 @@ const INIT_CINEMAINFO = {
const CinemaEdit = () => { const CinemaEdit = () => {
const [cinemaInfo, setCinemaInfo] = useState(INIT_CINEMAINFO) const [cinemaInfo, setCinemaInfo] = useState(INIT_CINEMAINFO)
const [theaterTypeList, setTheaterTypeList] = useState([]) const [theaterTypeList, setTheaterTypeList] = useState([])
const [theaterInfo, setTheaterInfo] = useState({ theaterCount: 0, seatCount: 0 })
const [selectTheater, setSelectTheater] = useState(0) const [selectTheater, setSelectTheater] = useState(0)
const [ticketFee, setTicketFee] = useState({}) const [ticketFee, setTicketFee] = useState({})
const [error, setError] = useState("") const [error, setError] = useState("")
...@@ -25,6 +26,7 @@ const CinemaEdit = () => { ...@@ -25,6 +26,7 @@ const CinemaEdit = () => {
useEffect(() => { useEffect(() => {
getInfo() getInfo()
getTicketFeeInfo() getTicketFeeInfo()
getTheaterInfo()
}, []) }, [])
function handleChange(e) { function handleChange(e) {
...@@ -63,13 +65,27 @@ const CinemaEdit = () => { ...@@ -63,13 +65,27 @@ const CinemaEdit = () => {
} }
} }
async function getTheaterInfo() {
try {
const theaterInfo = await theaterApi.getAll()
if (theaterInfo) {
const theaterCount = theaterInfo.length
const seatCount = theaterInfo.map(el=>el.rows*el.columns).reduce((acc, cur, idx) => { return acc += cur }, 0)
console.log(seatCount)
setTheaterInfo({ theaterCount: theaterCount, seatCount: seatCount })
}
} catch (error) {
catchErrors(error, setError)
}
}
return ( return (
<> <>
<h2 className="border-bottom border-2 text-center pb-2 me-2">현재 영화관 정보</h2> <h2 className="border-bottom border-2 text-center pb-2 me-2">현재 영화관 정보</h2>
<div className="mb-3"> <div className="mb-3">
<label htmlfor="cinemaName" className="form-label">영화관 이름</label> <label htmlfor="cinemaName" className="form-label">영화관 이름</label>
<input type="text" className={`form-control mb-2 ${styles.shadowNone}`} id="cinemaName" name="cinemaName" value={cinemaInfo.cinemaName} onChange={handleChange} /> <input type="text" className={`form-control mb-2 ${styles.shadowNone}`} id="cinemaName" name="cinemaName" value={cinemaInfo.cinemaName} onChange={handleChange} />
<p> 상영관 : 8개관 | 좌석 : 1,282</p> <p> 상영관 : {theaterInfo.theaterCount}개관 | 좌석 : {theaterInfo.seatCount}</p>
</div> </div>
<div className="mb-3"> <div className="mb-3">
<label htmlfor="transportation" className="form-label">대중교통 안내</label> <label htmlfor="transportation" className="form-label">대중교통 안내</label>
...@@ -89,9 +105,9 @@ const CinemaEdit = () => { ...@@ -89,9 +105,9 @@ const CinemaEdit = () => {
<TicketEditForm editFee={ticketFee} formRef={formRef} /> <TicketEditForm editFee={ticketFee} formRef={formRef} />
<label className="form-label">영화관람료 안내</label> <label className="form-label">영화관람료 안내</label>
<nav aria-label="breadcrumb"> <nav aria-label="breadcrumb">
<ol className={"breadcrumb" + (theaterTypeList.length === 0 ? " d-flex justify-content-center" : "" )}> <ol className={"breadcrumb" + (theaterTypeList.length === 0 ? " d-flex justify-content-center" : "")}>
{theaterTypeList.length !== 0 ? theaterTypeList.map(theater => <li className={`breadcrumb-item ${styles.cursor}`} key={theater.id} onClick={() => setSelectTheater(theater.id)}>{theater.theaterTypeName}</li>) {theaterTypeList.length !== 0 ? theaterTypeList.map(theater => <li className={`breadcrumb-item ${styles.cursor}`} key={theater.id} onClick={() => setSelectTheater(theater.id)}>{theater.theaterTypeName}</li>)
: <li>등록된 관람료 관련 정보가 없습니다.</li>} : <li>등록된 관람료 관련 정보가 없습니다.</li>}
</ol> </ol>
</nav> </nav>
<TicketFeeTable selectTheater={selectTheater} setEditFee={setTicketFee} formRef={formRef} /> <TicketFeeTable selectTheater={selectTheater} setEditFee={setTicketFee} formRef={formRef} />
......
...@@ -192,7 +192,7 @@ const MyInfo = () => { ...@@ -192,7 +192,7 @@ const MyInfo = () => {
<div className={`d-flex justify-content-around`}> <div className={`d-flex justify-content-around`}>
<div className={`${styles.box}`}> <div className={`${styles.box}`}>
<p className={`${styles.hoverTxt}`}>프로필 변경</p> <p className={`${styles.hoverTxt}`}>프로필 변경</p>
<img src={`/upload/${profile}`} className={`figure-img img-fluid rounded-circle ${styles.img} ${styles.profile}`} role="button" data-bs-toggle="modal" data-bs-target="#staticBackdrop" /> <img src={profile?`/upload/${profile}`:'/images/icons8-customer-100.png'} style={{backgroundColor:'white'}} className={`figure-img img-fluid rounded-circle ${styles.img} ${styles.profile}`} role="button" data-bs-toggle="modal" data-bs-target="#staticBackdrop" />
</div> </div>
<div className="d-flex flex-column py-2 mx-3 justify-content-around"> <div className="d-flex flex-column py-2 mx-3 justify-content-around">
<span className={`${styles.userName}`}>{`${userNickName}`} 반갑습니다!</span> <span className={`${styles.userName}`}>{`${userNickName}`} 반갑습니다!</span>
......
...@@ -32,7 +32,9 @@ const TheaterPage = () => { ...@@ -32,7 +32,9 @@ const TheaterPage = () => {
try { try {
setError("") setError("")
const res = await cinemaApi.getCinemaInfo() const res = await cinemaApi.getCinemaInfo()
setTicketFeeInfo(res.moreFeeInfo) if (res) {
setTicketFeeInfo(res.moreFeeInfo)
}
} catch (error) { } catch (error) {
catchErrors(error, setError) catchErrors(error, setError)
} }
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment