0

I have this data structure in Firestore:

enter image description here

Expected output: I will only update the array[1] which is M.

What it currently does: Instead of only updating the array[1] it added another data in the array. So instead of having only indexes 0,1,2 it became 0,1,2,3

 const [category, setCategory] = useState([]);
//useEffect to get all of the categories


const [options, setOptions] = useState([]);
const [edit, setEdit] = useState();



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

const ref = doc(db, "category", state);
await updateDoc(ref, {
  category: edit,
  options: arrayUnion(options),
});

console.log("updated")
 };

Forms:

{category &&
          category.map((category, index) => (
            <form onSubmit={handleSubmit}>
                  <TextField
                    defaultValue={category.cat}
                    type="text"
                    value={categoryEdit}
                    fullWidth
                    onChange={(e) => setCategoryEdit(e.target.value)}
                  />
                      {category.options.map((i) => (
                        <TextField
                          type="text"
                          defaultValue={i}
                          variant="outlined"
                          fullWidth
                          value={options[i]}
                          onChange={(e) => setOptions(e.target.value)}
                        />
                      ))}
         
                  </>
                )}
                <Button type="submit">Submit</Button>
            </form>
          ))}
Frank van Puffelen
  • 565,676
  • 79
  • 828
  • 807
JS3
  • 1,623
  • 3
  • 23
  • 52
  • I also think that this [article](https://medium.com/firebase-tips-tricks/how-to-update-an-array-of-objects-in-firestore-cdb611a56073) might help. – Alex Mamo Feb 20 '22 at 14:08

1 Answers1

1

There is no way to update an item in an array field with either arrayUnion or otherwise. You'll have to:

  1. Read the document into your application
  2. Get the full array
  3. Update the one item in the array
  4. Write the full array back to the document

Also see:

Frank van Puffelen
  • 565,676
  • 79
  • 828
  • 807