import React, { useState, useEffect, Fragment } from 'react';
import styled from 'styled-components';
import { Title, ButtonGroupWrapper, } from '../../styles/Components';
import Modal from '../common/modal/Modal';
import { MenuBannerModify } from '../../apis';
import { authList } from '../../store/authList';
import { useRecoilValue } from 'recoil';
import { authType, commonStatus } from '../../assets/data';
import { convertKTCDate } from '../../utils';
import { useLoading } from '../../context/LoadingProvider';
import { useAlert } from '../../context/AlertProvider';
import { alertTypes, languageNames } from '../../assets/data/types';
import { Image as AntImage } from 'antd';
import { AntButton, DetailLayout } from '../common';
function renderImageContent(imageData) {
if (!imageData) {
return 이미지가 없습니다;
}
return (
<>
}
// preview={{
// mask: '미리보기',
// maskClassName: 'custom-mask',
// }}
fallback=""
/>
{imageData.content &&
{imageData.content}
}
>
);
}
const MenuBannerDetailModal = ({ detailView, handleDetailView, content, setDetailData }) => {
const userInfo = useRecoilValue(authList);
const token = sessionStorage.getItem('token');
const {withLoading} = useLoading();
const {showModal, showToast} = useAlert();
const id = content && content.id;
const updateAuth = userInfo.auth_list && userInfo.auth_list.some(auth => auth.id === authType.menuBannerUpdate);
const [time, setTime] = useState({
start_hour: '00',
start_min: '00',
end_hour: '00',
end_min: '00',
}); //시간 정보
const [resultData, setResultData] = useState(initData);
const [activeLanguage, setActiveLanguage] = useState('KO');
const [tabItems, setTabItems] = useState([]);
useEffect(() => {
if(content){
// console.log(content);
const start_dt_KTC = convertKTCDate(content.start_dt);
const end_dt_KTC = convertKTCDate(content.end_dt);
setResultData({
id: content.id,
title: content.title,
start_dt: start_dt_KTC,
end_dt: end_dt_KTC,
status: content.status,
order_id: content.order_id,
is_link: content.is_link,
image_list: content.image_list,
});
setTime({ ...time,
start_hour: String(start_dt_KTC.getHours()).padStart(2, '0'),
start_min: String(start_dt_KTC.getMinutes()).padStart(2, '0'),
end_hour: String(end_dt_KTC.getHours()).padStart(2, '0'),
end_min: String(end_dt_KTC.getMinutes()).padStart(2, '0')
});
}
}, [content]);
useEffect(() => {
if (content && content.image_list) {
// 첫 번째 언어를 활성 언어로 설정
if (content.image_list && content.image_list.length > 0) {
setActiveLanguage(content.image_list[0].language);
}
// 동적으로 탭 아이템 생성
const newTabItems = content.image_list ? content.image_list.map(imageData => ({
key: imageData.language,
label: languageNames[imageData.language] || imageData.language,
children: (
{renderImageContent(imageData)}
)
})) : [];
setTabItems(newTabItems);
}
}, [content]);
// 확인 버튼 후 다 초기화
const handleReset = () => {
};
const checkCondition = () => {
return (
(resultData.start_dt.length !== 0) &&
(resultData.end_dt.length !== 0) &&
resultData.title !== '' &&
resultData.order_id !== ''
);
};
// 탭 변경 핸들러
const handleTabChange = (key) => {
setActiveLanguage(key);
};
const handleSubmit = async (type, param = null) => {
switch (type) {
case "submit":
if (!checkCondition()) return;
// console.log(resultData);
showModal('MENU_BANNER_UPDATE_SAVE', {
type: alertTypes.confirm,
onConfirm: () => handleSubmit('updateConfirm')
});
break;
case "updateConfirm":
withLoading( async () => {
return await MenuBannerModify(token, id, resultData);
}).then(result => {
if(result.result === 'ERROR'){
showToast(result.data.message, {
type: alertTypes.error
});
}else if(result.result === 'SUCCESS'){
showToast('UPDATE_COMPLETED', {type: alertTypes.success, duration: 4000});
}
}).catch(error => {
showToast('API_FAIL', {type: alertTypes.error});
}).finally(() => {
handleDetailView();
});
break;
}
}
const isView = (fieldName) => {
if (fieldName === 'editButton') {
// updateAuth가 없거나 FINISH 상태면 수정 버튼 숨김
return !updateAuth || content?.status === commonStatus.finish;
}
if (!updateAuth) return false;
if(content.status === commonStatus.wait){
return true;
}else if(content.status === commonStatus.running){
switch(fieldName){
case 'order_id':
case 'end_dt':
return true;
default:
return false;
}
}else{
return false;
}
}
const itemGroups = [
{
items: [
{
row: 0,
col: 0,
colSpan: 2,
type: 'text',
key: 'title',
label: '제목',
disabled: !isView('title'),
width: '250px',
},
{
row: 0,
col: 2,
colSpan: 2,
type: 'number',
key: 'order_id',
label: '순서',
disabled: !isView('order_id'),
width: '100px',
min: 0,
},
{
row: 1,
col: 0,
colSpan: 2,
type: 'status',
key: 'status',
label: '상태',
value: resultData.status,
},
{
row: 2,
col: 0,
colSpan: 2,
type: 'date',
key: 'start_dt',
label: '시작일',
disabled: !isView('start_dt'),
format: 'YYYY-MM-DD HH:mm',
width: '250px',
showTime: true
},
{
row: 2,
col: 2,
colSpan: 2,
type: 'date',
key: 'end_dt',
label: '종료일',
disabled: !isView('end_dt'),
format: 'YYYY-MM-DD HH:mm',
width: '250px',
showTime: true
},
{
row: 3,
col: 0,
colSpan: 4,
type: 'tab',
key: 'languageTabs',
tabItems: tabItems,
activeKey: activeLanguage,
onTabChange: handleTabChange
},
]
}
];
return (
<>
배너 상세 정보
{
handleDetailView();
handleReset();
setDetailData('');
}}
/>
{!isView('editButton') && (
handleSubmit('submit')}
/>
)}
>
);
};
export default MenuBannerDetailModal;
const initData = {
title: '',
is_link: false,
start_dt: '',
end_dt: '',
image_list: [
{ language: 'KO', content: '', title: '' },
{ language: 'EN', content: '', title: '' },
{ language: 'JA', content: '', title: '' },
]
}
const ImageContainer = styled.div`
padding: 16px;
display: flex;
flex-direction: column;
align-items: center;
gap: 16px;
width: 100%;
max-width: 700px;
margin: 0 auto;
`;
const ImageWrapper = styled.div`
position: relative;
border-radius: 8px;
overflow: hidden;
border: 1px solid #f0f0f0;
width: 100%;
text-align: center;
`;
const ImageUrlInfo = styled.div`
margin-top: 16px;
padding: 12px;
background-color: #f5f5f5;
border-radius: 6px;
font-size: 14px;
word-break: break-all;
width: 100%;
`;
const UrlLink = styled.a`
color: #1890ff;
text-decoration: underline;
cursor: pointer;
&:hover {
opacity: 0.8;
}
`;
const NoImagePlaceholder = styled.div`
width: 100%;
height: 200px;
display: flex;
align-items: center;
justify-content: center;
background-color: #f0f2f5;
color: #8c8c8c;
border-radius: 8px;
`;