'use client';

import {
  Dialog,
  DialogContent,
  DialogHeader,
  DialogTitle,
  DialogFooter,
  DialogDescription
} from '@/components/ui/dialog';
import { Button } from '@/components/ui/button';
import { useForm, Controller, useWatch } from 'react-hook-form';
import { zodResolver } from '@hookform/resolvers/zod';
import z from 'zod';
import { useEffect } from 'react';
import { PostPicker } from '@/components/dashboard/post/post-picker';
import { Label } from '@/components/ui/label';
import { toast } from 'sonner';

const schema = z.object({
  postId: z.string().min(1)
});

type ArticleSettingsForm = z.infer<typeof schema>;

const defaultValues: ArticleSettingsForm = {
  postId: ''
};

type Props = {
  open: boolean;
  onOpenChange: (v: boolean) => void;
  initialValues: ArticleSettingsForm;
  onSubmit: (data: ArticleSettingsForm) => void;
};

export default function ArticleSettingsDialog({
  open,
  onOpenChange,
  initialValues,
  onSubmit
}: Props) {
  const { handleSubmit, reset, control } = useForm<ArticleSettingsForm>({
    resolver: zodResolver(schema),
    defaultValues: initialValues ?? defaultValues,
    mode: 'onChange'
  });

  const postId = useWatch({
    control,
    name: 'postId'
  });

  useEffect(() => {
    if (open) {
      reset(initialValues ?? defaultValues);
    }
  }, [open, initialValues, reset]);

  return (
    <Dialog open={open} onOpenChange={onOpenChange}>
      <DialogContent>
        <DialogHeader>
          <DialogTitle>Article settings</DialogTitle>
          <DialogDescription>Configure article appearance</DialogDescription>
        </DialogHeader>
        <div className='flex flex-wrap items-center justify-between gap-2'>
          <Label>
            {postId ? (
              <span>
                Post has been chosen{' '}
                <span className='text-sm text-green-700'>✓</span>
              </span>
            ) : (
              <span>
                Choose post for setting widget{' '}
                <span className='text-client-red text-lg'>*</span>
              </span>
            )}
          </Label>
          <Controller
            control={control}
            name='postId'
            render={({ field }) => (
              <PostPicker
                selected={field.value ? [field.value] : []}
                onSelect={(ids: string[]) => {
                  field.onChange(ids[0] ?? '');
                }}
              />
            )}
          />
        </div>
        <DialogFooter>
          <Button
            type='button'
            variant='outline'
            onClick={() => reset(defaultValues)}
          >
            Reset
          </Button>
          <Button
            type='button'
            onClick={handleSubmit(onSubmit, () => {
              toast.error('Please choose post for setting widget');
            })}
          >
            Save
          </Button>
        </DialogFooter>
      </DialogContent>
    </Dialog>
  );
}
