Update DogForm with litter selection support

This commit is contained in:
2026-03-09 00:09:44 -05:00
parent dd26fa00bf
commit f076286b15

View File

@@ -13,14 +13,18 @@ function DogForm({ dog, onClose, onSave }) {
microchip: '', microchip: '',
notes: '', notes: '',
sire_id: '', sire_id: '',
dam_id: '' dam_id: '',
litter_id: ''
}) })
const [dogs, setDogs] = useState([]) const [dogs, setDogs] = useState([])
const [litters, setLitters] = useState([])
const [loading, setLoading] = useState(false) const [loading, setLoading] = useState(false)
const [error, setError] = useState('') const [error, setError] = useState('')
const [useManualParents, setUseManualParents] = useState(false)
useEffect(() => { useEffect(() => {
fetchDogs() fetchDogs()
fetchLitters()
if (dog) { if (dog) {
setFormData({ setFormData({
name: dog.name || '', name: dog.name || '',
@@ -32,8 +36,10 @@ function DogForm({ dog, onClose, onSave }) {
microchip: dog.microchip || '', microchip: dog.microchip || '',
notes: dog.notes || '', notes: dog.notes || '',
sire_id: dog.sire?.id || '', sire_id: dog.sire?.id || '',
dam_id: dog.dam?.id || '' dam_id: dog.dam?.id || '',
litter_id: dog.litter_id || ''
}) })
setUseManualParents(!dog.litter_id)
} }
}, [dog]) }, [dog])
@@ -46,9 +52,31 @@ function DogForm({ dog, onClose, onSave }) {
} }
} }
const fetchLitters = async () => {
try {
const res = await axios.get('/api/litters')
setLitters(res.data)
} catch (error) {
console.error('Error fetching litters:', error)
}
}
const handleChange = (e) => { const handleChange = (e) => {
const { name, value } = e.target const { name, value } = e.target
setFormData(prev => ({ ...prev, [name]: value })) setFormData(prev => ({ ...prev, [name]: value }))
// If litter is selected, auto-populate parents
if (name === 'litter_id' && value) {
const selectedLitter = litters.find(l => l.id === parseInt(value))
if (selectedLitter) {
setFormData(prev => ({
...prev,
sire_id: selectedLitter.sire_id,
dam_id: selectedLitter.dam_id,
breed: prev.breed || selectedLitter.sire_name?.split(' ')[0] || ''
}))
}
}
} }
const handleSubmit = async (e) => { const handleSubmit = async (e) => {
@@ -57,12 +85,19 @@ function DogForm({ dog, onClose, onSave }) {
setLoading(true) setLoading(true)
try { try {
const submitData = { ...formData }
// Clear litter_id if using manual parent selection
if (useManualParents) {
submitData.litter_id = null
}
if (dog) { if (dog) {
// Update existing dog // Update existing dog
await axios.put(`/api/dogs/${dog.id}`, formData) await axios.put(`/api/dogs/${dog.id}`, submitData)
} else { } else {
// Create new dog // Create new dog
await axios.post('/api/dogs', formData) await axios.post('/api/dogs', submitData)
} }
onSave() onSave()
onClose() onClose()
@@ -170,36 +205,84 @@ function DogForm({ dog, onClose, onSave }) {
onChange={handleChange} onChange={handleChange}
/> />
</div> </div>
</div>
<div className="form-group"> {/* Litter or Manual Parent Selection */}
<label className="label">Sire (Father)</label> <div style={{ marginTop: '1.5rem', padding: '1rem', background: '#f8fafc', borderRadius: '8px' }}>
<select <div style={{ display: 'flex', gap: '1rem', marginBottom: '1rem' }}>
name="sire_id" <label style={{ display: 'flex', alignItems: 'center', gap: '0.5rem', cursor: 'pointer' }}>
className="input" <input
value={formData.sire_id} type="radio"
onChange={handleChange} checked={!useManualParents}
> onChange={() => setUseManualParents(false)}
<option value="">Unknown</option> />
{males.map(d => ( <span>Link to Litter</span>
<option key={d.id} value={d.id}>{d.name}</option> </label>
))} <label style={{ display: 'flex', alignItems: 'center', gap: '0.5rem', cursor: 'pointer' }}>
</select> <input
type="radio"
checked={useManualParents}
onChange={() => setUseManualParents(true)}
/>
<span>Manual Parent Selection</span>
</label>
</div> </div>
<div className="form-group"> {!useManualParents ? (
<label className="label">Dam (Mother)</label> <div className="form-group">
<select <label className="label">Litter</label>
name="dam_id" <select
className="input" name="litter_id"
value={formData.dam_id} className="input"
onChange={handleChange} value={formData.litter_id}
> onChange={handleChange}
<option value="">Unknown</option> >
{females.map(d => ( <option value="">No Litter</option>
<option key={d.id} value={d.id}>{d.name}</option> {litters.map(l => (
))} <option key={l.id} value={l.id}>
</select> {l.sire_name} x {l.dam_name} - {new Date(l.breeding_date).toLocaleDateString()}
</div> </option>
))}
</select>
{formData.litter_id && (
<div style={{ marginTop: '0.5rem', fontSize: '0.875rem', color: '#64748b' }}>
Parents will be automatically set from the selected litter
</div>
)}
</div>
) : (
<div className="form-grid">
<div className="form-group">
<label className="label">Sire (Father)</label>
<select
name="sire_id"
className="input"
value={formData.sire_id}
onChange={handleChange}
>
<option value="">Unknown</option>
{males.map(d => (
<option key={d.id} value={d.id}>{d.name}</option>
))}
</select>
</div>
<div className="form-group">
<label className="label">Dam (Mother)</label>
<select
name="dam_id"
className="input"
value={formData.dam_id}
onChange={handleChange}
>
<option value="">Unknown</option>
{females.map(d => (
<option key={d.id} value={d.id}>{d.name}</option>
))}
</select>
</div>
</div>
)}
</div> </div>
<div className="form-group" style={{ marginTop: '1rem' }}> <div className="form-group" style={{ marginTop: '1rem' }}>
@@ -227,4 +310,4 @@ function DogForm({ dog, onClose, onSave }) {
) )
} }
export default DogForm export default DogForm