From 92484730511dd5a15466fb2897d6804a14c2488f Mon Sep 17 00:00:00 2001
From: ohinhyuk <8156217@naver.com>
Date: Wed, 6 Sep 2023 23:04:06 +0900
Subject: [PATCH] =?UTF-8?q?Fix:=20edit=EB=95=8C=20=EC=82=AC=EC=9A=A9?=
=?UTF-8?q?=EB=90=98=EB=8A=94=20=EA=B8=B0=EC=A1=B4=20=EB=8D=B0=EC=9D=B4?=
=?UTF-8?q?=ED=84=B0=EB=A5=BC=20=EC=A0=84=EB=8B=AC=ED=95=98=EB=8A=94=20bef?=
=?UTF-8?q?oreData=EB=A5=BC=20=EC=A0=84=EC=97=AD=EC=A0=81=EC=9C=BC?=
=?UTF-8?q?=EB=A1=9C=20=EA=B4=80=EB=A6=AC=ED=95=98=EC=97=AC=20=EA=B8=B0?=
=?UTF-8?q?=EC=A1=B4=EC=9D=98=20=EC=A0=84=EB=8B=AC=EB=90=98=EC=A7=80=20?=
=?UTF-8?q?=EC=95=8A=EB=8D=98=20=EC=98=A4=EB=A5=98=20=EC=88=98=EC=A0=95(#2?=
=?UTF-8?q?9)?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/common/CustomTable.tsx | 1 -
.../common/modal/ModalIconButton.tsx | 13 ++-
src/components/common/modal/SWModal.tsx | 26 ++---
src/components/modalForm/CategoryForm.tsx | 4 +-
src/components/modalForm/GlobalItemForm.tsx | 49 ++++----
.../modalForm/MileageRegisterForm.tsx | 4 +-
src/components/modalForm/SemesterItemForm.tsx | 3 +-
src/components/modalForm/StudentForm.tsx | 3 +-
src/pages/mileage/category/index.tsx | 15 ++-
src/pages/mileage/item/global/index.tsx | 110 +++++++++++-------
src/redux/slices/modal.js | 6 +-
11 files changed, 132 insertions(+), 102 deletions(-)
diff --git a/src/components/common/CustomTable.tsx b/src/components/common/CustomTable.tsx
index ac51bf3..97992d8 100644
--- a/src/components/common/CustomTable.tsx
+++ b/src/components/common/CustomTable.tsx
@@ -316,7 +316,6 @@ export default function EnhancedTable({ originalRows, headCells, type }) {
* @field 필터링을 거치고 보여주는 값들 (rows)
*/
const [rows, setRows] = React.useState(originalRows);
- console.log('debug', rows, originalRows);
/**
* @brief 필터링 요소
diff --git a/src/components/common/modal/ModalIconButton.tsx b/src/components/common/modal/ModalIconButton.tsx
index aa26136..7a4a38b 100644
--- a/src/components/common/modal/ModalIconButton.tsx
+++ b/src/components/common/modal/ModalIconButton.tsx
@@ -2,11 +2,16 @@ import { IconButton } from '@mui/material';
import AddIcon from '@mui/icons-material/Add';
import EditIcon from '@mui/icons-material/Edit';
import DeleteIcon from '@mui/icons-material/Delete';
-import { dispatch } from 'src/redux/store';
-import { openModal } from 'src/redux/slices/modal';
+import { openModal, setBeforeData } from 'src/redux/slices/modal';
+import { useDispatch } from 'react-redux';
-export default function ModalIconButton({ type }) {
- const handleOpen = () => dispatch(openModal(type));
+export default function ModalIconButton({ type, beforeData }) {
+ const dispatch = useDispatch();
+
+ const handleOpen = () => {
+ dispatch(openModal(type));
+ dispatch(setBeforeData(beforeData));
+ };
const IconConverter = (type) => {
const slicedType = type?.slice(0, 3);
diff --git a/src/components/common/modal/SWModal.tsx b/src/components/common/modal/SWModal.tsx
index cc038b1..07246e4 100644
--- a/src/components/common/modal/SWModal.tsx
+++ b/src/components/common/modal/SWModal.tsx
@@ -78,7 +78,7 @@ import { styled } from '@mui/styles';
import CategoryForm from 'src/components/modalForm/CategoryForm';
import ModalIconButton from './ModalIconButton';
import ModalTitle from './ModalTitle';
-import { values } from 'lodash';
+import { before, values } from 'lodash';
import ItemForm from 'src/components/modalForm/GlobalItemForm';
import GlobalItemForm from 'src/components/modalForm/GlobalItemForm';
import SemesterItemForm from 'src/components/modalForm/SemesterItemForm';
@@ -112,25 +112,25 @@ const style = {
const modalForm = (modalType, beforeData) => {
switch (modalType) {
case ADDCATEGORY:
- return ;
+ return ;
case EDITCATEGORY:
- return ;
+ return ;
case ADDITEM:
- return ;
+ return ;
case EDITITEM:
- return ;
+ return ;
case ADDGLOBALITEM:
- return ;
+ return ;
case EDITGLOBALITEM:
- return ;
+ return ;
case ADDSTUDENT:
- return ;
+ return ;
case EDITSTUDENT:
- return ;
+ return ;
case ADDMILEAGEREGISTER:
- return ;
+ return ;
case EDITMILEAGEREGISTER:
- return ;
+ return ;
default:
return
default
;
@@ -209,8 +209,6 @@ export const engToKor = (eng) => {
};
export default function SWModal({ type, beforeData }) {
- console.log('debug', beforeData);
-
const dispatch = useDispatch();
const open = useSelector((state) => state.modal.isOpen);
const modalType = useSelector((state) => state.modal.modalType);
@@ -219,7 +217,7 @@ export default function SWModal({ type, beforeData }) {
return (
-
+
state.modal.beforeData);
+
const modalType = useSelector((state) => state.modal.modalType);
const router = useRouter();
diff --git a/src/components/modalForm/GlobalItemForm.tsx b/src/components/modalForm/GlobalItemForm.tsx
index dfb9ce9..00433ba 100644
--- a/src/components/modalForm/GlobalItemForm.tsx
+++ b/src/components/modalForm/GlobalItemForm.tsx
@@ -19,7 +19,6 @@ import {
MILEAGE,
DESCRIPTION1,
DESCRIPTION2,
- FILE_DESCRIPTION,
ISVISIBLE,
ISVISIBLE_STUDENT,
ISINPUT_STUDENT,
@@ -28,7 +27,7 @@ import {
ISEVALUATE_PORTFOLIO,
ISEVALUATE_FUSION,
MAX_MAILEAGE,
- NUM,
+ ID,
} from 'src/assets/data/fields';
import { useSelector } from 'react-redux';
import { ADDGLOBALITEM, EDITGLOBALITEM, EDITITEM } from 'src/assets/data/modal/modals';
@@ -63,10 +62,12 @@ const StyleFieldForm = styled(Form)({
gap: '20px',
});
-export default function GlobalItemForm({ beforeData }) {
+export default function GlobalItemForm() {
const modalType = useSelector((state) => state.modal.modalType);
- console.log(modalType, beforeData);
+ // console.log('dbug', modalType, beforeData);
+ const beforeData = useSelector((state) => state.modal.beforeData);
+ console.log('d', beforeData);
const router = useRouter();
const handleSubmit = (values, { setSubmitting, resetForm }) => {
@@ -92,7 +93,7 @@ export default function GlobalItemForm({ beforeData }) {
}
};
const newData = {
- categoryId: 1,
+ categoryId: 106,
itemName: values[ITEM],
[DESCRIPTION1]: values[DESCRIPTION1],
[DESCRIPTION2]: values[DESCRIPTION2],
@@ -106,6 +107,8 @@ export default function GlobalItemForm({ beforeData }) {
},
};
+ console.log('!', newData);
+
switch (modalType) {
case ADDGLOBALITEM:
axiosInstance
@@ -122,25 +125,23 @@ export default function GlobalItemForm({ beforeData }) {
case EDITGLOBALITEM:
axiosInstance
- .patch(`/api/mileage/items/${beforeData[NUM]}`, newData)
+ .patch(`/api/mileage/items/${beforeData[ID]}`, newData)
.then((res) => {
- alert(`글로벌 항목 ${beforeData[NUM]}번이 수정되었습니다.`);
+ alert(`글로벌 항목 ${beforeData[ID]}번이 수정되었습니다.`);
router.reload();
})
.catch((err) => alert('글로벌 항목 수정에 실패했습니다.'));
break;
}
};
+
return (
- {[CATEGORY, ITEM, DESCRIPTION1, DESCRIPTION2, FILE_DESCRIPTION].map(
- (field: string, index: number) => (
-
-
-
-
- )
- )}
+ {[CATEGORY, ITEM, DESCRIPTION1, DESCRIPTION2].map((field: string, index: number) => (
+
+
+
+
+ ))}
{[
diff --git a/src/components/modalForm/MileageRegisterForm.tsx b/src/components/modalForm/MileageRegisterForm.tsx
index 934e8f8..415f487 100644
--- a/src/components/modalForm/MileageRegisterForm.tsx
+++ b/src/components/modalForm/MileageRegisterForm.tsx
@@ -23,7 +23,9 @@ import {
import { STUDENT_ID } from 'src/assets/data/fields';
import { ADDMILEAGEREGISTER, EDITMILEAGEREGISTER } from 'src/assets/data/modal/modals';
-export default function MileageRegisterForm({ beforeData }) {
+export default function MileageRegisterForm() {
+ const beforeData = useSelector((state) => state.modal.beforeData);
+
const modalType = useSelector((state) => state.modal.modalType);
const router = useRouter();
console.log('beforeData', beforeData);
diff --git a/src/components/modalForm/SemesterItemForm.tsx b/src/components/modalForm/SemesterItemForm.tsx
index 21ef69c..2eed782 100644
--- a/src/components/modalForm/SemesterItemForm.tsx
+++ b/src/components/modalForm/SemesterItemForm.tsx
@@ -23,7 +23,8 @@ import SubmitButton from '../common/modal/SubmitButton';
import axiosInstance from 'src/utils/axios';
import { useRouter } from 'next/router';
-export default function SemesterItemForm({ beforeData }) {
+export default function SemesterItemForm() {
+ const beforeData = useSelector((state) => state.modal.beforeData);
const modalType = useSelector((state) => state.modal.modalType);
const router = useRouter();
diff --git a/src/components/modalForm/StudentForm.tsx b/src/components/modalForm/StudentForm.tsx
index a843033..2238e86 100644
--- a/src/components/modalForm/StudentForm.tsx
+++ b/src/components/modalForm/StudentForm.tsx
@@ -80,7 +80,8 @@ const StyleFieldForm = styled(Form)({
gap: '20px',
});
-export default function StudentForm({ beforeData }) {
+export default function StudentForm() {
+ const beforeData = useSelector((state) => state.modal.beforeData);
const modalType = useSelector((state) => state.modal.modalType);
console.log('debug2', modalType, beforeData);
diff --git a/src/pages/mileage/category/index.tsx b/src/pages/mileage/category/index.tsx
index 3607f95..44ef656 100644
--- a/src/pages/mileage/category/index.tsx
+++ b/src/pages/mileage/category/index.tsx
@@ -3,7 +3,6 @@ import {
MAX_MILEAGE,
MANAGE,
CHECK_BOX,
- NUM,
DESCRIPTION,
NAME,
ID,
@@ -22,7 +21,7 @@ import { setMileageCategoryList } from 'src/redux/slices/data';
*/
export enum MileageCategoryBoard {
- 'ID' = ID,
+ 'NUM' = NUM,
'CATEGORY' = CATEGORY,
'DESCRIPTION1' = DESCRIPTION1,
'DESCRIPTION2' = DESCRIPTION2,
@@ -35,7 +34,7 @@ export enum MileageCategoryBoard {
*/
interface Data {
- [MileageCategoryBoard.ID]: number;
+ [MileageCategoryBoard.NUM]: number;
[MileageCategoryBoard.CATEGORY]: string;
[MileageCategoryBoard.DESCRIPTION1]: string;
[MileageCategoryBoard.DESCRIPTION2]: string;
@@ -49,14 +48,14 @@ interface Data {
* */
function createData(
- ID: number,
+ NUM: number,
CATEGORY: string,
DESCRIPTION1: string,
DESCRIPTION2: string,
MANAGE: ReactNode
): Data {
return {
- [MileageCategoryBoard.ID]: ID,
+ [MileageCategoryBoard.NUM]: NUM,
[MileageCategoryBoard.CATEGORY]: CATEGORY,
[MileageCategoryBoard.DESCRIPTION1]: DESCRIPTION1,
[MileageCategoryBoard.DESCRIPTION2]: DESCRIPTION2,
@@ -70,7 +69,7 @@ function createData(
*/
const headCells = [
{
- id: [MileageCategoryBoard.ID],
+ id: [MileageCategoryBoard.NUM],
numeric: false,
disablePadding: true,
label: '번호',
@@ -106,7 +105,7 @@ const headCells = [
* 더미 객체
*/
const IParams = {
- [ID]: 1,
+ [NUM]: 1,
[CATEGORY]: '카테고리테스트',
[DESCRIPTION1]: '설명 테스트',
[DESCRIPTION2]: '설명 테스트',
@@ -120,7 +119,7 @@ import axiosInstance from 'src/utils/axios';
import { InferGetServerSidePropsType, GetServerSideProps } from 'next';
import MileageCategory from 'src/components/board/MileageCategory';
import { setCategoryList } from 'src/redux/slices/filter';
-import { DESCRIPTION1, CATEGORY, DESCRIPTION2 } from '../../../assets/data/fields';
+import { DESCRIPTION1, CATEGORY, DESCRIPTION2, NUM } from '../../../assets/data/fields';
interface IList {
id: number;
diff --git a/src/pages/mileage/item/global/index.tsx b/src/pages/mileage/item/global/index.tsx
index 9179193..0214168 100644
--- a/src/pages/mileage/item/global/index.tsx
+++ b/src/pages/mileage/item/global/index.tsx
@@ -2,14 +2,11 @@ import { StarIcon } from 'src/theme/overrides/CustomIcons';
import EnhancedTable from 'src/components/common/CustomTable';
import {
MILEAGE,
- ISVISIBLE,
REGISTERED_DATE,
MANAGE,
CHECK_BOX,
NUM,
- CATEGORY,
SEMESTER,
- ITEM,
DESCRIPTION,
DESCRIPTION1,
DESCRIPTION2,
@@ -21,6 +18,7 @@ import {
ISEVALUATE_PORTFOLIO,
ISEVALUATE_FUSION,
MAX_MAILEAGE,
+ NAME,
} from 'src/assets/data/fields';
import SWModal from 'src/components/common/modal/SWModal';
import { EDITGLOBALITEM, EDITITEM } from 'src/assets/data/modal/modals';
@@ -39,13 +37,13 @@ import { useEffect } from 'react';
*/
export enum MileageGlobalItemBoard {
- 'NUM' = NUM,
+ 'ID' = ID,
'CATEGORY' = CATEGORY,
-
'ITEM' = ITEM,
+ 'DESCRIPTION1' = DESCRIPTION1,
+ 'DESCRIPTION2' = DESCRIPTION2,
'ISVISIBLE' = ISVISIBLE,
- 'REGISTERED_DATE' = REGISTERED_DATE,
'MANAGE' = MANAGE,
}
@@ -55,11 +53,11 @@ export enum MileageGlobalItemBoard {
*/
interface Data {
[MileageGlobalItemBoard.CATEGORY]: string;
-
[MileageGlobalItemBoard.ITEM]: string;
+ [MileageGlobalItemBoard.DESCRIPTION1]: string;
+ [MileageGlobalItemBoard.DESCRIPTION2]: string;
[MileageGlobalItemBoard.ISVISIBLE]: boolean;
- [MileageGlobalItemBoard.REGISTERED_DATE]: string;
[MileageGlobalItemBoard.MANAGE]: string;
}
@@ -69,24 +67,26 @@ interface Data {
*
* */
function createData(
- num: number,
- category: string,
-
- item: string,
-
- isVisible: boolean,
- registeredDate: string,
- manage: string
+ ID: number,
+ CATEGORY: string,
+ ITEM: string,
+ DESCRIPTION1: string,
+ DESCRIPTION2: string,
+
+ ISVISIBLE: boolean,
+ MANAGE: string
): Data {
return {
- [MileageGlobalItemBoard.NUM]: num,
- [MileageGlobalItemBoard.CATEGORY]: category,
+ [MileageGlobalItemBoard.NUM]: ID,
+ [MileageGlobalItemBoard.CATEGORY]: CATEGORY,
- [MileageGlobalItemBoard.ITEM]: item,
+ [MileageGlobalItemBoard.ITEM]: ITEM,
- [MileageGlobalItemBoard.ISVISIBLE]: isVisible,
- [MileageGlobalItemBoard.REGISTERED_DATE]: registeredDate,
- [MileageGlobalItemBoard.MANAGE]: manage,
+ [MileageGlobalItemBoard.DESCRIPTION1]: DESCRIPTION1,
+ [MileageGlobalItemBoard.DESCRIPTION2]: DESCRIPTION2,
+
+ [MileageGlobalItemBoard.ISVISIBLE]: ISVISIBLE,
+ [MileageGlobalItemBoard.MANAGE]: MANAGE,
};
}
@@ -114,16 +114,22 @@ const headCells = [
label: '항목명',
},
{
- id: [MileageGlobalItemBoard.ISVISIBLE],
+ id: [MileageGlobalItemBoard.DESCRIPTION1],
numeric: true,
disablePadding: false,
- label: '보이기',
+ label: '설명1',
},
{
- id: [MileageGlobalItemBoard.REGISTERED_DATE],
+ id: [MileageGlobalItemBoard.DESCRIPTION2],
numeric: true,
disablePadding: false,
- label: '등록일',
+ label: '설명2',
+ },
+ {
+ id: [MileageGlobalItemBoard.ISVISIBLE],
+ numeric: true,
+ disablePadding: false,
+ label: '보이기',
},
{
id: [MileageGlobalItemBoard.MANAGE],
@@ -227,6 +233,7 @@ import axiosInstance from 'src/utils/axios';
import { InferGetServerSidePropsType, GetServerSideProps } from 'next';
import MileageCategory from 'src/components/board/MileageCategory';
import { setItemList, setSemesterList } from 'src/redux/slices/filter';
+import { ID, CATEGORY, ITEM, ISVISIBLE } from '../../../../assets/data/fields';
interface ICategory {
id: number;
@@ -262,30 +269,43 @@ export default function MileageCategory({
fetchData,
}: InferGetServerSidePropsType) {
const dispatch = useDispatch();
+ console.log('Check', fetchData);
+ const convertedFetchList = fetchData.list?.map((item, index) => {
+ const {
+ id,
+ category: { name: categoryName },
+ name: itemName,
+ description1,
+ description2,
+ isVisible,
+ isStudentVisible,
+ isMulti,
+ stuType,
+ isPortfolio,
+ } = item;
- const convertedFetchList = fetchData.items?.map((item) => {
const beforeData = {
- [NUM]: item.id,
- [CATEGORY]: item.category.name,
- [ITEM]: item.name,
- [DESCRIPTION1]: item.description1,
- [DESCRIPTION2]: item.description2,
- [FILE_DESCRIPTION]: '첨부파일 설명', // 업서야 되는 듯
- [ISVISIBLE]: true,
- [ISVISIBLE_STUDENT]: false,
+ [ID]: id,
+ [CATEGORY]: categoryName,
+ [ITEM]: itemName,
+ [DESCRIPTION1]: description1,
+ [DESCRIPTION2]: description2,
+ [ISVISIBLE]: isVisible,
+ [ISVISIBLE_STUDENT]: isStudentVisible,
[ISINPUT_STUDENT]: false,
- [ISDUPLICATE_RECORD]: false,
- [ISEVALUATE_CSEE]: item.stuType === 'F' ? false : true,
- [ISEVALUATE_PORTFOLIO]: item.isPortfolio,
- [ISEVALUATE_FUSION]: item.stuType === 'C' ? false : true,
+ [ISDUPLICATE_RECORD]: isMulti,
+ [ISEVALUATE_CSEE]: stuType === 'F' ? false : true,
+ [ISEVALUATE_PORTFOLIO]: isPortfolio,
+ [ISEVALUATE_FUSION]: stuType === 'C' ? false : true,
};
- return createData(
- item.id,
- item.category.name,
- item.name,
- true,
- '2023-08-21',
+ return createData(
+ item[ID],
+ item[CATEGORY][NAME],
+ item[NAME],
+ item[DESCRIPTION1],
+ item[DESCRIPTION2],
+ item[ISVISIBLE],
);
});
diff --git a/src/redux/slices/modal.js b/src/redux/slices/modal.js
index 9c7de37..84cbb3e 100644
--- a/src/redux/slices/modal.js
+++ b/src/redux/slices/modal.js
@@ -3,6 +3,7 @@ import { createSlice } from '@reduxjs/toolkit';
const initialState = {
isOpen: false,
modalType: null,
+ beforeData: null,
};
const slice = createSlice({
@@ -17,9 +18,12 @@ const slice = createSlice({
state.isOpen = false;
state.modalType = action.payload;
},
+ setBeforeData: (state, action) => {
+ state.beforeData = action.payload;
+ },
},
});
// Reducer
-export const { openModal, closeModal } = slice.actions;
+export const { openModal, closeModal, setBeforeData } = slice.actions;
export default slice.reducer;