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>

View File

@@ -5,6 +5,7 @@ import {
Box,
Button,
Group,
Loader,
Paper,
Stack,
Text,
@@ -25,6 +26,7 @@ function CreatePencegahanKriminalitas() {
const kriminalitasState = useProxy(pencegahanKriminalitasState);
const [link, setLink] = useState('');
const embedLink = convertYoutubeUrlToEmbed(link);
const [isSubmitting, setIsSubmitting] = useState(false);
const resetForm = () => {
kriminalitasState.create.form = {
@@ -37,15 +39,23 @@ function CreatePencegahanKriminalitas() {
};
const handleSubmit = async () => {
if (!embedLink) {
toast.error('Link YouTube tidak valid. Pastikan formatnya benar.');
return;
try {
setIsSubmitting(true);
if (!embedLink) {
toast.error('Link YouTube tidak valid. Pastikan formatnya benar.');
return;
}
kriminalitasState.create.form.linkVideo = embedLink;
await kriminalitasState.create.create();
resetForm();
router.push('/admin/keamanan/pencegahan-kriminalitas');
} catch (error) {
console.error('Gagal menambahkan pencegahan kriminalitas:', error);
toast.error('Gagal menambahkan pencegahan kriminalitas');
} finally {
setIsSubmitting(false);
}
kriminalitasState.create.form.linkVideo = embedLink;
await kriminalitasState.create.create();
resetForm();
router.push('/admin/keamanan/pencegahan-kriminalitas');
};
return (
@@ -79,7 +89,7 @@ function CreatePencegahanKriminalitas() {
<TextInput
label="Judul Pencegahan Kriminalitas"
placeholder="Masukkan judul Pencegahan Kriminalitas"
defaultValue={kriminalitasState.create.form.judul}
value={kriminalitasState.create.form.judul}
onChange={(e) => {
kriminalitasState.create.form.judul = e.currentTarget.value;
}}
@@ -116,7 +126,7 @@ function CreatePencegahanKriminalitas() {
<TextInput
label="Link Video YouTube"
placeholder="https://www.youtube.com/watch?v=abc123"
defaultValue={link}
value={link}
onChange={(e) => setLink(e.currentTarget.value)}
required
/>
@@ -140,6 +150,17 @@ function CreatePencegahanKriminalitas() {
{/* Button Submit */}
<Group justify="right">
<Button
variant="outline"
color="gray"
radius="md"
size="md"
onClick={resetForm}
>
Reset
</Button>
{/* Tombol Simpan */}
<Button
onClick={handleSubmit}
radius="md"
@@ -150,7 +171,7 @@ function CreatePencegahanKriminalitas() {
boxShadow: '0 4px 15px rgba(79, 172, 254, 0.4)',
}}
>
Simpan
{isSubmitting ? <Loader size="sm" color="white" /> : 'Simpan'}
</Button>
</Group>
</Stack>