summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/components/RsvpForm.tsx20
1 files changed, 12 insertions, 8 deletions
diff --git a/src/components/RsvpForm.tsx b/src/components/RsvpForm.tsx
index a1e4fa8..a6e7036 100644
--- a/src/components/RsvpForm.tsx
+++ b/src/components/RsvpForm.tsx
@@ -12,7 +12,7 @@ import {
import { useForm, Controller, useFieldArray } from 'react-hook-form';
import { useOutletContext } from 'react-router-dom';
import { useUpdateGuestMutation, Guest } from '../apiSlice';
-import { useState } from 'react';
+import { useRef } from 'react';
type FormValues = {
id: number;
@@ -31,7 +31,7 @@ type FormValues = {
function RsvpForm() {
const [updateGuest] = useUpdateGuestMutation();
const guest: Guest = useOutletContext();
- const [previousPartySize, setPreviousPartySize] = useState(1);
+ const previousPartySize = useRef(0);
const {
register,
@@ -62,21 +62,25 @@ function RsvpForm() {
const handleParty = () => {
const partySize = Number(watch('partySize'));
- if (partySize > previousPartySize && partySize > 1 && partySize < 10) {
+ if (
+ partySize > previousPartySize.current &&
+ partySize > 1 &&
+ partySize < 10
+ ) {
append(
- new Array(partySize - previousPartySize).fill({
+ new Array(partySize - previousPartySize.current).fill({
firstName: '',
lastName: '',
})
);
- setPreviousPartySize(partySize);
- } else if (partySize < previousPartySize && partySize > 0) {
+ previousPartySize.current = partySize;
+ } else if (partySize < previousPartySize.current && partySize > 0) {
remove(
- [...Array(previousPartySize - partySize).keys()].map(
+ [...Array(previousPartySize.current - partySize).keys()].map(
(_, i) => partySize - 1 + i
)
);
- setPreviousPartySize(partySize);
+ previousPartySize.current = partySize;
}
};