Skip to content

Commit

Permalink
feature-078: alert->createToast로 모두 변경
Browse files Browse the repository at this point in the history
  • Loading branch information
gs0428 committed Feb 19, 2024
1 parent 5dd5aa4 commit d3b9eb2
Show file tree
Hide file tree
Showing 13 changed files with 185 additions and 177 deletions.
279 changes: 136 additions & 143 deletions src/components/NicknameModal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,115 +6,108 @@ import nameImg from '@/assets/name.png';
import { BlurBackground } from '@/styles/modals/common.style';
import { userInfoState } from '@/stores/user';
import { useSetRecoilState } from 'recoil';
import useCreateToast from '@/hooks/useCreateToast';

const NicknameModal = () => {
const [inputCount, setInputCount] = useState(0);
const [name, setName] = useState<string>("");

const setUserInfo = useSetRecoilState(userInfoState);
const [inputCount, setInputCount] = useState(0);
const [name, setName] = useState<string>('');
const { createToast } = useCreateToast();

const refreshMyInfo = async () => {
const setUserInfo = useSetRecoilState(userInfoState);

const refreshMyInfo = async () => {
try {
const { result } = (await getMyInfoAPI()).data;

setUserInfo(result);
} catch (e) {
console.error(e);
}
}
};

const onChangeName = (e: React.ChangeEvent<HTMLInputElement>) => {
const target = e.currentTarget;
if (target.value.length > 7) {
target.value = target.value.slice(0, 7);
}
setName(target.value);
setInputCount(
target.value.replace(/[\0-\x7f]|([0-\u07ff]|(.))/g, "$&$1$2").length
);
setInputCount(target.value.length);
};

const onApply = () => {
if (name) {
// 서버에 데이터 전송
onRegisterNicknameInfo();
} else {
alert('입력값을 확인해주세요.');
}
};

const onRegisterNicknameInfo = async () => {
try {
const response = (await nickNameAPI({
nick_name : name,
})).data
refreshMyInfo();
console.log(response);
} catch (err) {
console.log(err);
}
};

return (
<BlurBackground>
<ModalDiv>

<div
style={{
display: 'flex',
flexDirection: 'column',
alignItems: 'center',
gap: 12
}}
>
<img src={nameImg} alt="signup" width={56} height={56} />
<h1 className="title">어떤 이름으로 불러드릴까요?</h1>
<span className="description">
vino에 오신걸 환영합니다! 원하시는 이름으로 불러드릴게요
</span>
</div>

<TextDiv
className="text_box">
<InputBox
type="text"
id="name"
name="name"
value={name}
placeholder="원하시는 닉네임을 작성해주세요"
onChange={onChangeName}
maxLength={7}
>
</InputBox>
<InputNickNameMessage>
<InputNickNameLength>
{inputCount}
</InputNickNameLength>
/7(공백포함)
</InputNickNameMessage>
</TextDiv>
{name ? (
<SucButton
type="submit"
onClick={onApply}
style={{ marginTop: 12 }}
>
등록하기
</SucButton>) : (
<Button
style={{ marginTop: 12 }}>
등록하기
</Button>)
}
</ModalDiv>
</BlurBackground>
const onChangeName = (e: React.ChangeEvent<HTMLInputElement>) => {
const target = e.currentTarget;
if (target.value.length > 7) {
target.value = target.value.slice(0, 7);
}
setName(target.value);
setInputCount(
target.value.replace(/[\0-\x7f]|([0-\u07ff]|(.))/g, '$&$1$2').length,
);
setInputCount(target.value.length);
};

const onApply = () => {
if (name) {
// 서버에 데이터 전송
onRegisterNicknameInfo();
} else {
createToast('입력값을 확인해주세요.');
}
};

const onRegisterNicknameInfo = async () => {
try {
const response = (
await nickNameAPI({
nick_name: name,
})
).data;
refreshMyInfo();
console.log(response);
} catch (err) {
console.log(err);
}
};

export default NicknameModal;

const ModalDiv = styled.div`
return (
<BlurBackground>
<ModalDiv>
<div
style={{
display: 'flex',
flexDirection: 'column',
alignItems: 'center',
gap: 12,
}}
>
<img src={nameImg} alt="signup" width={56} height={56} />
<h1 className="title">어떤 이름으로 불러드릴까요?</h1>
<span className="description">
vino에 오신걸 환영합니다! 원하시는 이름으로 불러드릴게요
</span>
</div>

<TextDiv className="text_box">
<InputBox
type="text"
id="name"
name="name"
value={name}
placeholder="원하시는 닉네임을 작성해주세요"
onChange={onChangeName}
maxLength={7}
></InputBox>
<InputNickNameMessage>
<InputNickNameLength>{inputCount}</InputNickNameLength>
/7(공백포함)
</InputNickNameMessage>
</TextDiv>
{name ? (
<SucButton type="submit" onClick={onApply} style={{ marginTop: 12 }}>
등록하기
</SucButton>
) : (
<Button style={{ marginTop: 12 }}>등록하기</Button>
)}
</ModalDiv>
</BlurBackground>
);
};

export default NicknameModal;

const ModalDiv = styled.div`
padding: 40px 50px;
display: flex;
flex-direction: column;
Expand All @@ -136,52 +129,52 @@ const NicknameModal = () => {
`;

const InputBox = styled.input`
width: 202px;
height: 56px;
background-color: #F3F3F3;
padding: 0px 0px 0px 20px;
display: flex;
align-items: center;
justify-content: center;
gap: 20px;
flex: 1 0 0;
font-style: normal;
border: none;
border-radius: 12px;
color: var(--Main, #1E1E1E);
font-family: Pretendard;
${theme.typography.Body1};
&:focus {
outline: none;
}
&::placeholder {
width: 202px;
height: 56px;
background-color: #f3f3f3;
padding: 0px 0px 0px 20px;
display: flex;
align-items: center;
justify-content: center;
gap: 20px;
flex: 1 0 0;
font-style: normal;
border: none;
border-radius: 12px;
color: var(--Main, #1e1e1e);
font-family: Pretendard;
${theme.typography.Body1};
&:focus {
outline: none;
}
&::placeholder {
color: #bbb;
${theme.typography.Body1};
}
`;

const SucButton = styled.button`
width: 100%;
height: 56px;
border: none;
border-radius: 12px;
background-color : #1E1E1E;
color: #fff;
text-align: center;
${theme.typography.Body1};
cursor: pointer;
width: 100%;
height: 56px;
border: none;
border-radius: 12px;
background-color: #1e1e1e;
color: #fff;
text-align: center;
${theme.typography.Body1};
cursor: pointer;
`;

const Button = styled.button`
width: 100%;
height: 56px;
border: none;
border-radius: 12px;
background-color : #F3F3F3;
color: #BBBBBB;
text-align: center;
${theme.typography.Body1};
width: 100%;
height: 56px;
border: none;
border-radius: 12px;
background-color: #f3f3f3;
color: #bbbbbb;
text-align: center;
${theme.typography.Body1};
`;

const InputNickNameMessage = styled.span`
Expand All @@ -195,14 +188,14 @@ const InputNickNameLength = styled.span`
`;

const TextDiv = styled.div`
position : relative;
width : 600px;
height : 56px;
align-items: center;
justify-content: center;
background-color: #F3F3F3;
display: flex;
flex-direction: row;
border-radius: 12px;
margin-top: 48px;
`
position: relative;
width: 600px;
height: 56px;
align-items: center;
justify-content: center;
background-color: #f3f3f3;
display: flex;
flex-direction: row;
border-radius: 12px;
margin-top: 48px;
`;
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,6 @@ import {
summaryVideoState,
summaryVideoTimeState,
} from '@/stores/summary';
import { toastListState } from '@/stores/toast';

import { DetailBox } from '@/styles/SummaryPage';

Expand All @@ -21,6 +20,7 @@ import { formatDate } from '@/utils/date';
import { CategorySelectBox } from './CategorySelectBox';
import { NoteBox } from './NoteBox';
import { DescriptionBox } from './DescriptionBox';
import useCreateToast from '@/hooks/useCreateToast';

type Props = {
onRefresh: () => void;
Expand All @@ -29,23 +29,19 @@ type Props = {
const SummaryDetailBox = ({ onRefresh }: Props) => {
const player = useRef<YT.Player>();

const { createToast } = useCreateToast();
const summaryVideo = useRecoilValue(summaryVideoState) as IVideo;
const summaryUpdateVideo = useRecoilValue(summaryUpdateVideoState);
const setSummaryVideoTime = useSetRecoilState(summaryVideoTimeState);
const isEditingView = useRecoilValue(summaryIsEditingViewState);
const [playSubHeadingId, setPlaySubHeadingId] = useRecoilState(
summaryPlaySubHeadingIdState,
);
const [toastList, setToastList] = useRecoilState(toastListState);

const subHeading = isEditingView
? summaryUpdateVideo?.subHeading || []
: summaryVideo.subHeading;

const createToast = (content: string) => {
setToastList([...toastList, { id: Date.now(), content }]);
};

const handleSelectCategory = async (category_id: number, name?: string) => {
try {
await updateVideoCategoryIdAPI(category_id, {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,11 +13,11 @@ import {
summaryUpdateVideoState,
summaryVideoState,
} from '@/stores/summary';
import { toastListState } from '@/stores/toast';

import Indicator from './Indicator';
import { SearchKeyword } from './SearchKeyword';
import { ChangeKeyword } from './ChangeKeyword';
import useCreateToast from '@/hooks/useCreateToast';

type Props = {
onRefresh: () => void;
Expand All @@ -33,14 +33,10 @@ const ToolBox = ({ onRefresh, onChangeKeyword }: Props) => {
const [isEditingView, setIsEditingView] = useRecoilState(
summaryIsEditingViewState,
);
const [toastList, setToastList] = useRecoilState(toastListState);
const { createToast } = useCreateToast();

const [originalSummary, setOriginalSummary] = useState<IVideo | null>(null);

const createToast = (content: string) => {
setToastList([...toastList, { id: Date.now(), content }]);
};

const handleClickModifyIcon = () => {
setPlaySubHeadingId(-1);
setIsEditingView(true);
Expand Down
Loading

0 comments on commit d3b9eb2

Please sign in to comment.