AFileForm.tsx 1013 Bytes
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
import React, { useState } from "react";
import { FileType, AnswerType } from "../types";

type Props = {
  element: FileType;
  response: AnswerType;
  handleAnswer: () => void;
  addFiles: (oneFile: { questionId: string; file: File }) => void;
};

export const AFileForm = ({
  element,
  response,
  handleAnswer,
  addFiles,
}: Props) => {
  const handleChange = (event: React.ChangeEvent<HTMLInputElement>) => {
    if (event.currentTarget.files) {
      const uploadFile = event.currentTarget.files[0];
      addFiles({ questionId: element._id, file: uploadFile });
      response.answers.map((a) => {
        if (a.questionId === element._id) {
          a.answer = uploadFile.name;
        }
      });
      handleAnswer();
    }
  };
  return (
    <div id="content" className="flex mt-4 w-full justify-center">
      <input
        type="file"
        name="file"
        className=" w-11/12 h-16"
        onChange={handleChange}
Jiwon Yoon's avatar
Jiwon Yoon committed
36
        required={element.isRequired}
37
38
39
40
      ></input>
    </div>
  );
};