lms/resources/js/pages/dashboard/courses/partials/pricing.tsx
2025-12-15 12:26:23 +01:00

154 lines
6.6 KiB
TypeScript

import Combobox from '@/components/combobox';
import InputError from '@/components/input-error';
import LoadingButton from '@/components/loading-button';
import { Accordion, AccordionContent, AccordionItem } from '@/components/ui/accordion';
import { Card } from '@/components/ui/card';
import { Checkbox } from '@/components/ui/checkbox';
import { Input } from '@/components/ui/input';
import { Label } from '@/components/ui/label';
import { RadioGroup, RadioGroupItem } from '@/components/ui/radio-group';
import courseDurations from '@/data/course-durations';
import DashboardLayout from '@/layouts/dashboard/layout';
import { onHandleChange } from '@/lib/inertia';
import { useForm, usePage } from '@inertiajs/react';
import { ReactNode } from 'react';
import { CourseUpdateProps } from '../update';
const Pricing = () => {
const { props } = usePage<CourseUpdateProps>();
const { translate } = props;
const { dashboard, input, button } = translate;
const { tab, prices, expiries, course } = props;
const { data, setData, post, errors, processing } = useForm({
tab: tab,
pricing_type: course.pricing_type || '',
price: course.price || '',
discount: Boolean(course.discount) || false,
discount_price: course.discount_price || '',
expiry_type: course.expiry_type || '',
expiry_duration: course.expiry_duration || '',
});
// Handle form submission
const handleSubmit = (e: React.FormEvent) => {
e.preventDefault();
post(route('courses.update', { id: course.id }));
};
return (
<Card className="container p-4 sm:p-6">
<form onSubmit={handleSubmit} className="space-y-4">
<Accordion collapsible type="single" value={data.pricing_type as string}>
<div>
<Label>{input.pricing_type} *</Label>
<RadioGroup
defaultValue={data.pricing_type as string}
className="flex items-center space-x-4 pt-2 pb-1"
onValueChange={(value) => setData('pricing_type', value)}
>
{prices.map((price) => (
<div key={price} className="flex items-center space-x-2">
<RadioGroupItem className="cursor-pointer" id={price} value={price} />
<Label htmlFor={price} className="capitalize">
{price}
</Label>
</div>
))}
</RadioGroup>
<InputError message={errors.pricing_type} />
</div>
<AccordionItem value={prices[1]} className="border-none">
<AccordionContent className="space-y-4 p-0.5">
<div className="pt-3">
<Label>{dashboard.price} *</Label>
<Input
type="number"
name="price"
value={data.price}
onChange={(e) => onHandleChange(e, setData)}
placeholder={input.course_price_placeholder}
/>
<InputError message={errors.price} />
</div>
<div className="space-y-2">
<div className="flex items-center space-x-2">
<Checkbox
id="discount"
name="discount"
checked={data.discount as any}
onCheckedChange={(checked: boolean) => {
setData('discount', checked as any);
}}
/>
<Label htmlFor="discount">{dashboard.check_course_discount}</Label>
</div>
{data.discount && (
<div>
<Input
type="number"
name="discount_price"
value={data.discount_price}
onChange={(e) => onHandleChange(e, setData)}
placeholder={input.discount_price_placeholder}
/>
<InputError message={errors.discount_price} />
</div>
)}
</div>
</AccordionContent>
</AccordionItem>
</Accordion>
<Accordion collapsible type="single" value={data.expiry_type}>
<div>
<Label>Expiry period type</Label>
<RadioGroup
defaultValue={data.expiry_type}
className="flex items-center space-x-4 pt-2 pb-1"
onValueChange={(value) => setData('expiry_type', value)}
>
{expiries.map((expiry) => (
<div key={expiry} className="flex items-center space-x-2">
<RadioGroupItem className="cursor-pointer" id={expiry} value={expiry} />
<Label htmlFor={expiry} className="capitalize">
{expiry.replace('_', ' ')}
</Label>
</div>
))}
</RadioGroup>
<InputError message={errors.expiry_type} />
</div>
<AccordionItem value={expiries[1]} className="border-none">
<AccordionContent className="space-y-4 p-0.5">
<div className="pt-3">
<Label>{input.expiry_duration}</Label>
<Combobox
defaultValue={data.expiry_duration as string}
data={courseDurations}
placeholder={input.expiry_duration_placeholder || 'Select duration'}
onSelect={(selected) => setData('expiry_duration', selected.value)}
/>
<InputError message={errors.expiry_duration} />
</div>
</AccordionContent>
</AccordionItem>
</Accordion>
<div className="mt-8">
<LoadingButton loading={processing}>{button.save_changes}</LoadingButton>
</div>
</form>
</Card>
);
};
Pricing.layout = (page: ReactNode) => <DashboardLayout children={page} />;
export default Pricing;