Voting
Fix: Semua tampilan sudah terintegrasi API ### No Issue
This commit is contained in:
@@ -1,22 +1,76 @@
|
||||
/* eslint-disable react-hooks/exhaustive-deps */
|
||||
import {
|
||||
AvatarUsernameAndOtherComponent,
|
||||
BackButton,
|
||||
DotButton,
|
||||
DrawerCustom,
|
||||
MenuDrawerDynamicGrid,
|
||||
Spacing,
|
||||
ViewWrapper,
|
||||
AvatarUsernameAndOtherComponent,
|
||||
BackButton,
|
||||
DotButton,
|
||||
DrawerCustom,
|
||||
LoaderCustom,
|
||||
MenuDrawerDynamicGrid,
|
||||
Spacing,
|
||||
ViewWrapper,
|
||||
} from "@/components";
|
||||
import { IconContribution } from "@/components/_Icon";
|
||||
import { IMenuDrawerItem } from "@/components/_Interface/types";
|
||||
import { useAuth } from "@/hooks/use-auth";
|
||||
import { Voting_BoxDetailContributionSection } from "@/screens/Voting/BoxDetailContribution";
|
||||
import Voting_BoxDetailHasilVotingSection from "@/screens/Voting/BoxDetailHasilVotingSection";
|
||||
import {
|
||||
apiVotingContribution,
|
||||
apiVotingGetOne,
|
||||
} from "@/service/api-client/api-voting";
|
||||
import { router, Stack, useLocalSearchParams } from "expo-router";
|
||||
import { useState } from "react";
|
||||
import { useEffect, useState } from "react";
|
||||
|
||||
export default function VotingDetailContribution() {
|
||||
const { user } = useAuth();
|
||||
const { id } = useLocalSearchParams();
|
||||
const [openDrawerPublish, setOpenDrawerPublish] = useState(false);
|
||||
const [data, setData] = useState<any>(null);
|
||||
const [loadingGetData, setLoadingGetData] = useState(false);
|
||||
const [nameChoice, setNameChoice] = useState("");
|
||||
|
||||
useEffect(() => {
|
||||
handlerLoadData();
|
||||
}, [id, user?.id]);
|
||||
|
||||
async function handlerLoadData() {
|
||||
try {
|
||||
setLoadingGetData(true);
|
||||
await onLoadData();
|
||||
await onLoadCheckContribution();
|
||||
} catch (error) {
|
||||
console.log("[ERROR]", error);
|
||||
} finally {
|
||||
setLoadingGetData(false);
|
||||
}
|
||||
}
|
||||
|
||||
const onLoadData = async () => {
|
||||
try {
|
||||
const response = await apiVotingGetOne({ id: id as string });
|
||||
if (response.success) {
|
||||
setData(response.data);
|
||||
}
|
||||
} catch (error) {
|
||||
console.log("[ERROR]", error);
|
||||
}
|
||||
};
|
||||
|
||||
const onLoadCheckContribution = async () => {
|
||||
try {
|
||||
const response = await apiVotingContribution({
|
||||
id: id as string,
|
||||
authorId: user?.id as string,
|
||||
category: "checked",
|
||||
});
|
||||
|
||||
if (response.success) {
|
||||
setNameChoice(response.data.nameChoice);
|
||||
}
|
||||
} catch (error) {
|
||||
console.log("[ERROR]", error);
|
||||
}
|
||||
};
|
||||
|
||||
const handlePressPublish = (item: IMenuDrawerItem) => {
|
||||
router.navigate(item.path as any);
|
||||
@@ -36,11 +90,27 @@ export default function VotingDetailContribution() {
|
||||
/>
|
||||
|
||||
<ViewWrapper>
|
||||
<Voting_BoxDetailContributionSection
|
||||
headerAvatar={<AvatarUsernameAndOtherComponent />}
|
||||
/>
|
||||
<Voting_BoxDetailHasilVotingSection />
|
||||
<Spacing />
|
||||
{loadingGetData ? (
|
||||
<LoaderCustom />
|
||||
) : (
|
||||
<>
|
||||
<Voting_BoxDetailContributionSection
|
||||
data={data}
|
||||
nameChoice={nameChoice}
|
||||
headerAvatar={
|
||||
<AvatarUsernameAndOtherComponent
|
||||
avatar={data?.Author?.Profile?.imageId || ""}
|
||||
name={data?.Author?.username || "Username"}
|
||||
avatarHref={`/profile/${data?.Author?.Profile?.id}`}
|
||||
/>
|
||||
}
|
||||
/>
|
||||
<Voting_BoxDetailHasilVotingSection
|
||||
listData={data?.Voting_DaftarNamaVote}
|
||||
/>
|
||||
<Spacing />
|
||||
</>
|
||||
)}
|
||||
</ViewWrapper>
|
||||
|
||||
{/* ========= Publish Drawer ========= */}
|
||||
|
||||
Reference in New Issue
Block a user