Internal Server error (500) in POST to MongoDB react

I am making a form that must POST to the Mongo database.

So I have the following code to make the change of the states in the Front:

const [project, setProject] = useState({
    project_start: null,
    project_end: null,
    project_name: "",
    usersId: [],
    partnerId: "",
    categoryId: "",
  });

  const handleChange = (name, newVal) => {
    setProject({ ...project, [name]: newVal });
  };

and the POST looks like this:

const handleSubmit = async (e) => {
    e.preventDefault();

    const res = await fetch("http://localhost:5001/client/projects", {
      method: "POST",
      body: JSON.stringify(project),
      headers: { "Content-Type": "application/json" },
    });

    const data = await res.json(project);
    console.log(data);
    console.log(project);
  };

And this would be a summary of what my form consists of:

<form onSubmit={handleSubmit}>
<Box width="50%">
                <LocalizationProvider dateAdapter={AdapterDayjs}>
                  <DatePicker
                    id="project_start"
                    name="project_start"
                    value={project.project_start}
                    onChange={handleChange.bind(null, "project_start")}
                    slotProps={{
                      textField: {
                        size: "small",
                        margin: "dense",
                      },
                    }}
                  />
                </LocalizationProvider>
                <TextField
                  id="nombreP"
                  name="project_name"
                  value={project.project_name}
                  onChange={handleChange}
                  margin="dense"
                  size="small"
                />
                <FormControl size="small" sx={{ m: 1 }}>
                  <Select
                    id="encargadoP"
                    multiple
                    name="usersId"
                    value={project.usersId}
                    onChange={(e) =>
                      handleChange(
                        "usersId",
                        typeof e.target.value === "string"
                          ? e.target.value.split(",")
                          : e.target.value
                      )
                    }
                    MenuProps={MenuProps}
                    renderValue={(selected) => (
                      <Box sx={{ display: "flex", flexWrap: "wrap", gap: 0.5 }}>
                        {selected.map((value) => (
                          <Chip key={value} label={value} />
                        ))}
                      </Box>
                    )}
                    sx={{ width: 205 }}
                  >
                    {data?.map(({ _id, name }) => (
                      <MenuItem key={_id} value={name}>
                        {name}
                      </MenuItem>
                    ))}
                  </Select>
                </FormControl>
              </Box>
            </Box>
            <Button
              type="submit"
              variant={"outlined"}
              size={"large"}
              sx={{
                width: 420,
                border: "1px solid white",
                m: "3rem 0 0 0",
                color: "white",
                borderRadius: "30px",
              }}
            >
              Agregar proyecto
            </Button>
          </Box>
        </form>

Here is my schema

import mongoose from "mongoose";

const ProjectSchema = new mongoose.Schema(
  {
    project_start: Date,
    project_end: Date,
    project_name: {
      type: String,
      required: true,
      min: 2,
      max: 100,
    },
    usersId: {
      type: [mongoose.Types.ObjectId],
      of: Number,
    },
    partnerId: {
      type: [mongoose.Types.ObjectId],
      of: Number,
    },
    categoryId: {
      type: [mongoose.Types.ObjectId],
      of: Number,
    },
  },
  { timestamps: true }
);

const Project = mongoose.model("Project", ProjectSchema);
export default Project;

In the Routes I have this:

import express from "express";
import {
  getAllUsers,
  getPartner,
  getCategory,
  addProject,
} from "../controllers/client.js";

const router = express.Router();

router.get("/users", getAllUsers);
router.get("/partners", getPartner);
router.get("/categories", getCategory);
router.post("/projects", addProject);

export default router;

In the controller this (in short):

import Project from "../models/Projects.js";
export const addProject = async (req, res) => {
  try {
    const {
      project_start,
      project_end,
      project_name,
      usersId,
      partnerId,
      categoryId,
    } = req.body;

    const newProject = new Project({
      project_start,
      project_end,
      project_name,
      usersId,
      partnerId,
      categoryId,
    });
    const savedProjecct = await newProject.save();
    res.status(201).json(savedProjecct);
  } catch (err) {
    res.status(500).json({ error: err.message });
  }
};

At the moment I get a 500 error when making the POST, I guess it is because of the schema I made with Mongoose, my questions are:

  • Is that the problem?
  • How can I take the id of the user, partner and category instead of the string (name) shown in the front end?

I am very grateful to people who can help me 🙂