Skip to content

Commit

Permalink
feat: add zustand store
Browse files Browse the repository at this point in the history
  • Loading branch information
eun-hak committed May 17, 2024
1 parent 0eaa027 commit d710ed6
Show file tree
Hide file tree
Showing 4 changed files with 39 additions and 17 deletions.
4 changes: 2 additions & 2 deletions src/api/auth/auth.get.api.ts
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
// import { ICommon } from '../types/common';
import { getRequest } from '../request';
import { IUpdateProfile } from '../types/auth';
import { UserInfoType } from '../types/auth';

/* 회원 상세정보 */

export const userinfo = async () => {
const response = await getRequest<IUpdateProfile>('members');
const response = await getRequest<UserInfoType>('members');
return response;
};
4 changes: 2 additions & 2 deletions src/api/types/auth.ts
Original file line number Diff line number Diff line change
Expand Up @@ -31,8 +31,8 @@ export interface IUserInfo {
memberEmail: string;
memberName: string;
memberJob: string;
memberPhone: string;
memberBirthDate: string;
memberNickName: string;
memberSmsAgree: string;
}

export interface IWithdraw {
Expand Down
24 changes: 18 additions & 6 deletions src/pages/index.tsx
Original file line number Diff line number Diff line change
@@ -1,16 +1,24 @@
// import { Inter } from 'next/font/google';
// import { userinfo } from '@/api/auth/auth.get.api';
import { userinfo } from '@/api/auth/auth.get.api';
// import Layout from '@/components/layout/Layout';
import { useMember, useSetMember } from '@/stores/user';
import Image from 'next/image';
// import { useEffect } from 'react';
import { useEffect } from 'react';
import { useQuery } from 'react-query';

// const inter = Inter({ subsets: ['latin'] });

export default function Home() {
// useEffect(() => {
// userinfo();
// }, []);

////////////// zustand 테스트 부분//////////////////
const member = useMember();
const { data: memberData } = useQuery('userinfo', userinfo);
const setmember = useSetMember();
useEffect(() => {
console.log(memberData);
setmember(memberData?.data);
}, [memberData, setmember]);
console.log(member);
/////////////////////////////////////////////////////
return (
<main className={`flex min-h-screen flex-col items-center justify-between p-24 `}>
<div className=" z-10 max-w-5xl w-full items-center justify-between font-mono text-sm lg:flex">
Expand All @@ -30,6 +38,10 @@ export default function Home() {
height={24}
priority
/>
{/*
*/}
{/* 여기서 test */}
{member?.memberEmail}
</a>
</div>
</div>
Expand Down
24 changes: 17 additions & 7 deletions src/stores/user.ts
Original file line number Diff line number Diff line change
@@ -1,28 +1,38 @@
import { IUserInfo } from '@/api/types/auth';
import { create } from 'zustand';
import { persist } from 'zustand/middleware';

/* eslint-disable no-unused-vars */

interface IMember {
member: object;
setmember: (payload: string) => void;
member: IUserInfo;
setmember: (payload: IUserInfo | undefined) => void;
}

export const useMemberStore = create(
const useMemberStore = create(
persist<IMember>(
(set) => ({
member: { job: '' },
setmember: (payload: string) =>
member: {
memberEmail: '',
memberName: '',
memberNickName: '',
memberJob: '',
memberSmsAgree: ''
},
setmember: (payload: IUserInfo | undefined) =>
set((state) => ({
...state,
member: {
...state.member,
job: payload
...payload
}
}))
}),
{
name: 'job'
name: 'member'
}
)
);

export const useMember = () => useMemberStore((state) => state.member);
export const useSetMember = () => useMemberStore((state) => state.setmember);

0 comments on commit d710ed6

Please sign in to comment.