ModifySurveyView.tsx 5.12 KB
Newer Older
1
2
3
4
5
6
7
import React, { ChangeEvent, FormEvent, useState } from "react";
import { useNavigate } from "react-router-dom";
import { catchErrors } from "../helpers";
import { SpinnerIcon } from "../icons";
import { CreateQuestionData, ISurvey } from "../types";
import { QuestionsList } from "./QuestionsList";
import { SurveyTitle } from "./SurveyTitle";
8
import { SurveyTitleAndComment } from "./SurveyTitleAndComment";
9
10
11
12
13
14
15

type Props = {
  questions: CreateQuestionData[];
  survey: ISurvey;
  addQuestion: () => void;
  deleteQuestion: (id: string) => void;
  handleQuestion: (question: CreateQuestionData) => void;
16
  handleTitleComment: Function;
Yoon, Daeki's avatar
Yoon, Daeki committed
17
  // callApi: (surveyData: ISurvey) => Promise<any>;
18
19
20
21
22
23
24
25
};

export const ModifySurveyView = ({
  questions,
  survey,
  addQuestion,
  deleteQuestion,
  handleQuestion,
26
  handleTitleComment,
Yoon, Daeki's avatar
Yoon, Daeki committed
27
28
}: // callApi,
Props) => {
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
  const [error, setError] = useState("");
  const [loading, setLoading] = useState(false);
  // const [survey, setSurvey] = useState<ISurvey>(surveyData);
  // const [questions, setQuestions] = useState<CreateQuestionData[]>(() => {
  //   const questions = survey.questions;
  //   return questions.map((question) => ({ ...question, isEditing: false }));
  // });
  // const navigate = useNavigate();

  const handleChange = (e: ChangeEvent<HTMLInputElement>) => {
    const { name, value } = e.target;
    // setSurvey({ ...survey, [name]: value });
  };

  // const hasIncompleteEditing = () => {
  // if (questions.length <= 0) {
  //   return true;
  // }
  // const incompleted = questions.some((question) => question.isEditing);
  // return incompleted;
  // };

  // /**
  //  * 수정된 질문을 입력받아 기존 질문을 대체합니다.
  //  * @param question 수정할 질문
  //  * @returns 없음
  //  */
  // const handleQuestion = (question: CreateQuestionData) => {
  //   const index = questions.findIndex((q) => q._id === question._id);
  //   if (index < 0) {
  //     return;
  //   }
  //   questions[index] = question;
  //   console.log("handle question questions:", questions);
  //   setQuestions([...questions]);
  // };

  // const addQuestion = () => {
  //   const question: CreateQuestionData = {
  //     _id: Math.random().toString(),
  //     order: questions.length,
  //     type: "singletext",
  //     title: "",
  //     comment: "",
  //     isRequired: false,
  //     content: { choices: [] },
  //     isEditing: true,
  //   };
  //   setQuestions([...questions, question]);
  // };

  // async function deleteQuestion(id: string) {
  //   const delQuestions = questions.filter((question) => question._id !== id);
  //   setQuestions(delQuestions);
  // }

  // const handleSubmit = async (e: FormEvent) => {
  //   e.preventDefault();
  //   // survey.questions = questions;
  //   try {
  //     setLoading(true);
  //     const result = await callApi(survey);
  //     console.log("result:", result);
  //     navigate(-1);
  //   } catch (error) {
  //     setLoading(false);
  //     catchErrors(error, setError);
  //   }
  // };

  // const disabled = hasIncompleteEditing();

  return (
    <>
      {loading && (
        <SpinnerIcon className="animate-spin h-5 w-5 mr-1 text-slate" />
      )}
      <form>
        <div className="flex flex-col place-items-center">
108
109
110
111
112
113
114
          {/* <SurveyTitle text={survey.title} handleTitle={handleTitle} /> */}
          <SurveyTitleAndComment
            title={survey.title}
            comment={survey.comment}
            handleTitleComment={handleTitleComment}
          />
          {/* <div className="flex flex-col container place-items-center mt-4">
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
            <input
              type="text"
              name="title"
              className="font-bold text-4xl text-center m-2 border-b-2"
              placeholder="설문지 제목"
              autoComplete="on"
              value={survey.title}
              onChange={handleChange}
            ></input>
            <input
              type="text"
              name="comment"
              className="font-bold text-1xl text-center m-2 border-b-2 resize-none"
              placeholder="설문조사에 대한 설명을 입력해주세요"
              autoComplete="on"
              size={50}
              value={survey.comment}
              onChange={handleChange}
            ></input>
134
          </div> */}
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
          <QuestionsList
            questions={questions}
            handleQuestion={handleQuestion}
            deleteQuestion={deleteQuestion}
          />
          <button
            type="button"
            onClick={addQuestion}
            className="flex w-4/5 content-center justify-center border-2 border-black h-8 mt-3"
          >
            질문 추가
          </button>
          {error && (
            <div className="text-red-500 text-sm mt-3">
              <p>{error}</p>
            </div>
          )}
          {/* <button
            type="submit"
            disabled={disabled}
            title={`${disabled ? "완성되지 않은 부분이 존재합니다" : ""}`}
            className="border bg-themeColor my-5 py-2 px-3 disabled:opacity-60 font-bold text-white"
          >
            저장
          </button> */}
        </div>
      </form>
    </>
  );
};