feat(admin): implement edit and delete functionality for UMKM and Produk modules

- Added update and del methods to UMKM Valtio state
- Wired up edit and delete buttons in UMKM and Produk list pages
- Integrated ModalKonfirmasiHapus for deletion safety
- Created UMKM and Produk edit pages with data loading and image previews
- Cleaned up unused imports and fixed useEffect dependencies
- Bumped version to 0.1.21
This commit is contained in:
2026-04-24 11:46:08 +08:00
parent b9d43eb723
commit b1916ca3a3
6 changed files with 646 additions and 8 deletions

View File

@@ -1,5 +1,4 @@
'use client'
import colors from '@/con/colors';
import {
Box,
Button,
@@ -15,7 +14,6 @@ import {
TableTh,
TableThead,
TableTr,
Text,
Title,
TextInput
} from '@mantine/core';
@@ -25,6 +23,7 @@ import { useRouter } from 'next/navigation';
import { useState } from 'react';
import { useProxy } from 'valtio/utils';
import umkmState from '../../../_state/ekonomi/umkm/umkm';
import { ModalKonfirmasiHapus } from '@/app/admin/(dashboard)/_com/modalKonfirmasiHapus';
function DataUmkm() {
const router = useRouter();
@@ -32,10 +31,23 @@ function DataUmkm() {
const state = useProxy(umkmState.umkm.findMany);
const [debouncedSearch] = useDebouncedValue(search, 1000);
const [modalHapus, setModalHapus] = useState(false);
const [selectedId, setSelectedId] = useState<string | null>(null);
useShallowEffect(() => {
state.load(state.page, 10, debouncedSearch);
}, [state.page, debouncedSearch]);
const handleHapus = async () => {
if (selectedId) {
const success = await umkmState.umkm.del.submit(selectedId);
if (success) {
setModalHapus(false);
setSelectedId(null);
}
}
};
return (
<Stack gap="lg">
<Group justify="space-between">
@@ -81,10 +93,23 @@ function DataUmkm() {
<TableTd>{item.kontak || '-'}</TableTd>
<TableTd>
<Group gap="xs">
<Button variant="subtle" color="blue" size="xs">
<Button
variant="subtle"
color="blue"
size="xs"
onClick={() => router.push(`/admin/ekonomi/umkm/data-umkm/${item.id}/edit`)}
>
<IconEdit size={16} />
</Button>
<Button variant="subtle" color="red" size="xs">
<Button
variant="subtle"
color="red"
size="xs"
onClick={() => {
setSelectedId(item.id);
setModalHapus(true);
}}
>
<IconTrash size={16} />
</Button>
</Group>
@@ -104,6 +129,13 @@ function DataUmkm() {
/>
</Center>
</Paper>
<ModalKonfirmasiHapus
opened={modalHapus}
onClose={() => setModalHapus(false)}
onConfirm={handleHapus}
text="Apakah Anda yakin ingin menghapus UMKM ini? Menghapus UMKM juga akan berdampak pada produk dan penjualan yang terkait."
/>
</Stack>
);
}