"use client"

import type React from "react"
import { useState, useEffect } from "react"
import { Dialog, DialogContent, DialogDescription, DialogHeader, DialogTitle } from "@/components/ui/dialog"
import { Button } from "@/components/ui/button"
import { Input } from "@/components/ui/input"
import { Label } from "@/components/ui/label"
import type { User } from "@/lib/types"

interface EditObserverDialogProps {
  open: boolean
  onOpenChange: (open: boolean) => void
  observer: User
  onEdit: (observer: User) => void
}

export function EditObserverDialog({ open, onOpenChange, observer, onEdit }: EditObserverDialogProps) {
  const [formData, setFormData] = useState({
    name: observer.name,
    email: observer.email,
  })

  useEffect(() => {
    setFormData({
      name: observer.name,
      email: observer.email,
    })
  }, [observer])

  const handleSubmit = (e: React.FormEvent) => {
    e.preventDefault()
    onEdit({
      ...observer,
      ...formData,
    })
  }

  return (
    <Dialog open={open} onOpenChange={onOpenChange}>
      <DialogContent className="max-w-md bg-card">
        <DialogHeader>
          <DialogTitle>Modifier le surveillant</DialogTitle>
          <DialogDescription>Mettre à jour les informations du compte surveillant</DialogDescription>
        </DialogHeader>
        <form onSubmit={handleSubmit} className="space-y-4">
          <div className="space-y-2">
            <Label htmlFor="edit-name">Nom complet *</Label>
            <Input
              id="edit-name"
              value={formData.name}
              onChange={(e) => setFormData({ ...formData, name: e.target.value })}
              required
              className="bg-background"
            />
          </div>

          <div className="space-y-2">
            <Label htmlFor="edit-email">Email *</Label>
            <Input
              id="edit-email"
              type="email"
              value={formData.email}
              onChange={(e) => setFormData({ ...formData, email: e.target.value })}
              required
              className="bg-background"
            />
          </div>

          <div className="flex justify-end gap-2">
            <Button type="button" variant="outline" onClick={() => onOpenChange(false)} className="bg-transparent">
              Annuler
            </Button>
            <Button type="submit">Enregistrer les modifications</Button>
          </div>
        </form>
      </DialogContent>
    </Dialog>
  )
}
