Fix: - app/(application)/(user)/forum/[id]/index.tsx - app/(application)/(user)/home.tsx - screens/Forum/ListPage.tsx - screens/Forum/MenuDrawerSection.tsx/MenuBeranda.tsx - service/api-client/api-master.ts - service/api-client/api-user.ts ### No Issue
125 lines
3.5 KiB
TypeScript
125 lines
3.5 KiB
TypeScript
import { IMenuDrawerItem } from "@/components/_Interface/types";
|
|
import MenuDrawerDynamicGrid from "@/components/Drawer/MenuDrawerDynamicGird";
|
|
import { router } from "expo-router";
|
|
import { AlertDefaultSystem } from "@/components";
|
|
import {
|
|
drawerItemsForumBerandaForAuthor,
|
|
drawerItemsForumBerandaForNonAuthor,
|
|
} from "../ListPage";
|
|
import { useAuth } from "@/hooks/use-auth";
|
|
import { apiForumDelete } from "@/service/api-client/api-forum";
|
|
import Toast from "react-native-toast-message";
|
|
import { apiForumBlockUser } from "@/service/api-client/api-user";
|
|
|
|
export default function Forum_MenuDrawerBerandaSection({
|
|
id,
|
|
authorUsername,
|
|
status,
|
|
setIsDrawerOpen,
|
|
authorId,
|
|
handlerUpdateStatus,
|
|
}: {
|
|
id: string;
|
|
authorUsername: string;
|
|
status: string;
|
|
setIsDrawerOpen: (value: boolean) => void;
|
|
authorId: string;
|
|
handlerUpdateStatus?: (value: string) => void;
|
|
}) {
|
|
const { user } = useAuth();
|
|
const handlePress = (item: IMenuDrawerItem) => {
|
|
if (item.value === "delete") {
|
|
AlertDefaultSystem({
|
|
title: "Hapus diskusi",
|
|
message: "Apakah Anda yakin ingin menghapus diskusi ini?",
|
|
textLeft: "Batal",
|
|
textRight: "Hapus",
|
|
onPressRight: async () => {
|
|
try {
|
|
const response = await apiForumDelete({ id });
|
|
|
|
if (response.success) {
|
|
Toast.show({
|
|
type: "success",
|
|
text1: "Berhasil dihapus",
|
|
});
|
|
router.back();
|
|
} else {
|
|
Toast.show({
|
|
type: "error",
|
|
text1: response.message,
|
|
});
|
|
}
|
|
} catch (error) {
|
|
console.log("[ERROR]", error);
|
|
}
|
|
},
|
|
});
|
|
} else if (item.value === "status") {
|
|
AlertDefaultSystem({
|
|
title: "Ubah Status",
|
|
message: "Apakah Anda yakin ingin mengubah status forum ini?",
|
|
textLeft: "Batal",
|
|
textRight: "Ubah",
|
|
onPressRight: () => {
|
|
handlerUpdateStatus?.(
|
|
item.label === "Buka forum" ? "Open" : "Closed"
|
|
);
|
|
},
|
|
});
|
|
} else if (item.value === "block") {
|
|
AlertDefaultSystem({
|
|
title: "Blockir user",
|
|
message: `Apakah anda yakin ingin blockir user @${authorUsername}?`,
|
|
textLeft: "Batal",
|
|
textRight: "Blockir",
|
|
onPressRight: async () => {
|
|
console.log("Blockir");
|
|
const response = await apiForumBlockUser({
|
|
data: {
|
|
menuFeature: "Forum",
|
|
blockedId: authorId,
|
|
blockerId: user?.id || "",
|
|
},
|
|
});
|
|
|
|
if (response.success) {
|
|
Toast.show({
|
|
type: "success",
|
|
text1: "Berhasil blokir",
|
|
});
|
|
router.back();
|
|
} else {
|
|
Toast.show({
|
|
type: "error",
|
|
text1: response.message,
|
|
});
|
|
}
|
|
},
|
|
});
|
|
} else {
|
|
router.push(item.path as any);
|
|
}
|
|
|
|
setIsDrawerOpen(false);
|
|
};
|
|
|
|
return (
|
|
<>
|
|
{/* Menu Items */}
|
|
<MenuDrawerDynamicGrid
|
|
data={
|
|
authorId === user?.id
|
|
? drawerItemsForumBerandaForAuthor({ id, status })
|
|
: drawerItemsForumBerandaForNonAuthor({
|
|
id,
|
|
username: authorUsername,
|
|
})
|
|
}
|
|
columns={authorId === user?.id ? 4 : 2} // Ubah ke 2 jika ingin 2 kolom per baris
|
|
onPressItem={handlePress as any}
|
|
/>
|
|
</>
|
|
);
|
|
}
|