lms/resources/js/pages/dashboard/newsletters/partials/newsletter-form.tsx
2025-12-15 12:26:23 +01:00

118 lines
4.1 KiB
TypeScript

import InputError from '@/components/input-error';
import LoadingButton from '@/components/loading-button';
import { Button } from '@/components/ui/button';
import { Dialog, DialogClose, DialogContent, DialogFooter, DialogHeader, DialogTitle, DialogTrigger } from '@/components/ui/dialog';
import { Input } from '@/components/ui/input';
import { Label } from '@/components/ui/label';
import { ScrollArea } from '@/components/ui/scroll-area';
import { onHandleChange } from '@/lib/inertia';
import { useForm } from '@inertiajs/react';
import { useState } from 'react';
import { Editor } from 'richtor';
import 'richtor/styles';
interface Props {
title: string;
handler: React.ReactNode;
newsletter?: Newsletter;
translate?: LanguageTranslations;
}
const NewsletterForm = ({ title, newsletter, handler, translate }: Props) => {
const [open, setOpen] = useState(false);
// Get translations with fallback
const { input, button } = translate || {
input: {
subject: 'Subject',
subject_placeholder: 'Enter your subject',
newsletter_description: 'Description',
type_content_here: 'Type your content here...',
type_caption_optional: 'Type caption for image (optional)',
},
button: { close: 'Close', submit: 'Submit' },
};
const { data, setData, post, put, errors, processing } = useForm({
subject: newsletter ? newsletter.subject : '',
description: newsletter ? newsletter.description : '',
});
const handleSubmit = (e: React.FormEvent) => {
e.preventDefault();
if (newsletter) {
put(route('newsletters.update', { id: newsletter.id }), {
onSuccess: () => setOpen(false),
});
} else {
post(route('newsletters.store'), {
onSuccess: () => setOpen(false),
});
}
};
return (
<Dialog open={open} onOpenChange={setOpen}>
<DialogTrigger>{handler}</DialogTrigger>
<DialogContent className="p-0">
<ScrollArea className="max-h-[90vh] p-6">
<DialogHeader className="mb-6">
<DialogTitle>{title}</DialogTitle>
</DialogHeader>
<form onSubmit={handleSubmit} className="space-y-4 p-0.5">
<div>
<Label>{input.subject}</Label>
<Input
required
type="text"
name="subject"
value={data.subject}
placeholder={input.subject}
onChange={(e) => onHandleChange(e, setData)}
/>
<InputError message={errors.subject} />
</div>
<div>
<Label>{input.description}</Label>
<Editor
ssr={true}
output="html"
placeholder={{
paragraph: input.description_placeholder,
imageCaption: input.image_url_placeholder,
}}
contentMinHeight={256}
contentMaxHeight={640}
initialContent={data.description}
onContentChange={(value) =>
setData((prev) => ({
...prev,
description: value as string,
}))
}
/>
<InputError message={errors.description} />
</div>
<DialogFooter className="flex justify-end space-x-2 pt-4">
<DialogClose asChild>
<Button type="button" variant="outline">
{button.close}
</Button>
</DialogClose>
<LoadingButton loading={processing}>{button.submit}</LoadingButton>
</DialogFooter>
</form>
</ScrollArea>
</DialogContent>
</Dialog>
);
};
export default NewsletterForm;