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

@@ -8,6 +8,7 @@ import {
Box,
Button,
Group,
Loader,
Paper,
Stack,
Text,
@@ -24,6 +25,7 @@ function EditPencegahanKriminalitas() {
const router = useRouter();
const params = useParams();
const kriminalitasState = useProxy(pencegahanKriminalitasState);
const [isSubmitting, setIsSubmitting] = useState(false);
const [formData, setFormData] = useState({
judul: '',
@@ -32,6 +34,13 @@ function EditPencegahanKriminalitas() {
linkVideo: '',
});
const [originalData, setOriginalData] = useState({
judul: '',
deskripsi: '',
deskripsiSingkat: '',
linkVideo: '',
});
// load data hanya sekali pas id berubah
useEffect(() => {
const loadKriminalitas = async () => {
@@ -47,6 +56,12 @@ function EditPencegahanKriminalitas() {
deskripsiSingkat: data.deskripsiSingkat ?? '',
linkVideo: data.linkVideo ?? '',
});
setOriginalData({
judul: data.judul ?? '',
deskripsi: data.deskripsi ?? '',
deskripsiSingkat: data.deskripsiSingkat ?? '',
linkVideo: data.linkVideo ?? '',
});
}
} catch (error) {
console.error('Error loading pencegahan kriminalitas:', error);
@@ -65,6 +80,16 @@ function EditPencegahanKriminalitas() {
setFormData((prev) => ({ ...prev, [field]: e.target.value }));
};
const handleResetForm = () => {
setFormData({
judul: originalData.judul,
deskripsi: originalData.deskripsi,
deskripsiSingkat: originalData.deskripsiSingkat,
linkVideo: originalData.linkVideo,
});
toast.info("Form dikembalikan ke data awal");
};
const handleSubmit = async () => {
const converted = convertYoutubeUrlToEmbed(formData.linkVideo);
if (!converted) {
@@ -73,6 +98,7 @@ function EditPencegahanKriminalitas() {
}
try {
setIsSubmitting(true);
// update global state saat submit
kriminalitasState.update.form = {
judul: formData.judul,
@@ -88,6 +114,8 @@ function EditPencegahanKriminalitas() {
} catch (error) {
console.error('Error updating pencegahan kriminalitas:', error);
toast.error('Terjadi kesalahan saat memperbarui data');
} finally {
setIsSubmitting(false);
}
};
@@ -177,6 +205,17 @@ function EditPencegahanKriminalitas() {
{/* Action button */}
<Group justify="right">
<Button
variant="outline"
color="gray"
radius="md"
size="md"
onClick={handleResetForm}
>
Batal
</Button>
{/* Tombol Simpan */}
<Button
onClick={handleSubmit}
radius="md"
@@ -187,7 +226,7 @@ function EditPencegahanKriminalitas() {
boxShadow: '0 4px 15px rgba(79, 172, 254, 0.4)',
}}
>
Simpan
{isSubmitting ? <Loader size="sm" color="white" /> : 'Simpan'}
</Button>
</Group>
</Stack>