Fix QC Kak Inno Admin, Fix QC Keano UI User, Fix QC Pak jun tabel apbdes

This commit is contained in:
2025-11-12 17:42:31 +08:00
parent 417a8937f5
commit 9622eb5a9a
354 changed files with 11444 additions and 4012 deletions

View File

@@ -7,6 +7,7 @@ import {
Box,
Button,
Group,
Loader,
Paper,
Select,
Stack,
@@ -29,10 +30,15 @@ function EditPengajar() {
const params = useParams();
const router = useRouter();
const [isSubmitting, setIsSubmitting] = useState(false);
const [formData, setFormData] = useState<FormPengajar>({
nama: '',
lembagaId: ''
});
const [originalData, setOriginalData] = useState<FormPengajar>({
nama: '',
lembagaId: ''
});
useEffect(() => {
const loadData = async () => {
@@ -47,6 +53,10 @@ function EditPengajar() {
nama: data.nama || '',
lembagaId: data.lembagaId || '',
});
setOriginalData({
nama: data.nama || '',
lembagaId: data.lembagaId || '',
});
}
} catch (err) {
console.error(err);
@@ -57,12 +67,21 @@ function EditPengajar() {
loadData();
}, [params?.id]);
const handleResetForm = () => {
setFormData({
nama: originalData.nama,
lembagaId: originalData.lembagaId,
});
toast.info('Form dikembalikan ke data awal');
};
const handleChange = (field: keyof FormPengajar, value: string) => {
setFormData(prev => ({ ...prev, [field]: value }));
};
const handleSubmit = async () => {
try {
setIsSubmitting(true);
// update global state hanya saat submit
pengajarState.edit.form = {
...pengajarState.edit.form,
@@ -75,6 +94,8 @@ function EditPengajar() {
} catch (err) {
console.error(err);
toast.error("Terjadi kesalahan saat memperbarui pengajar");
} finally {
setIsSubmitting(false);
}
};
@@ -121,6 +142,17 @@ function EditPengajar() {
/>
<Group justify="right">
<Button
variant="outline"
color="gray"
radius="md"
size="md"
onClick={handleResetForm}
>
Batal
</Button>
{/* Tombol Simpan */}
<Button
onClick={handleSubmit}
radius="md"
@@ -131,7 +163,7 @@ function EditPengajar() {
boxShadow: '0 4px 15px rgba(79, 172, 254, 0.4)',
}}
>
Simpan
{isSubmitting ? <Loader size="sm" color="white" /> : 'Simpan'}
</Button>
</Group>
</Stack>

View File

@@ -6,6 +6,7 @@ import {
Box,
Button,
Group,
Loader,
Paper,
Select,
Stack,
@@ -15,13 +16,14 @@ import {
} from '@mantine/core';
import { IconArrowBack } from '@tabler/icons-react';
import { useRouter } from 'next/navigation';
import { useEffect } from 'react';
import { useEffect, useState } from 'react';
import { toast } from 'react-toastify';
import { useProxy } from 'valtio/utils';
function CreatePengajar() {
const router = useRouter();
const stateCreate = useProxy(infoSekolahPaud.pengajar);
const [isSubmitting, setIsSubmitting] = useState(false);
useEffect(() => {
stateCreate.findMany.load();
@@ -36,14 +38,22 @@ function CreatePengajar() {
};
const handleSubmit = async () => {
if (!stateCreate.create.form.nama || !stateCreate.create.form.lembagaId) {
return toast.warn('Nama dan Lembaga wajib diisi!');
try {
setIsSubmitting(true);
if (!stateCreate.create.form.nama || !stateCreate.create.form.lembagaId) {
return toast.warn('Nama dan Lembaga wajib diisi!');
}
await stateCreate.create.create();
resetForm();
router.push('/admin/pendidikan/info-sekolah/pengajar');
} catch (error) {
console.error('Error creating pengajar:', error);
toast.error('Terjadi kesalahan saat menambahkan pengajar');
} finally {
setIsSubmitting(false);
}
await stateCreate.create.create();
resetForm();
router.push('/admin/pendidikan/info-sekolah/pengajar');
};
return (
@@ -71,7 +81,7 @@ function CreatePengajar() {
<TextInput
label={<Text fw="bold" fz="sm">Nama</Text>}
placeholder="Masukkan nama pengajar"
defaultValue={stateCreate.create.form.nama}
value={stateCreate.create.form.nama}
onChange={(e) => (stateCreate.create.form.nama = e.target.value)}
required
/>
@@ -91,6 +101,17 @@ function CreatePengajar() {
/>
<Group justify="right">
<Button
variant="outline"
color="gray"
radius="md"
size="md"
onClick={resetForm}
>
Reset
</Button>
{/* Tombol Simpan */}
<Button
onClick={handleSubmit}
radius="md"
@@ -101,7 +122,7 @@ function CreatePengajar() {
boxShadow: '0 4px 15px rgba(79, 172, 254, 0.4)',
}}
>
Simpan
{isSubmitting ? <Loader size="sm" color="white" /> : 'Simpan'}
</Button>
</Group>
</Stack>