sendou.ink/hooks/plus.ts
2021-02-25 20:57:42 +02:00

46 lines
1.2 KiB
TypeScript

import { useState } from "react";
import { PlusStatus, Suggestions } from "services/plus";
import useSWR from "swr";
import { useUser } from "./common";
export function usePlus(initialData: Suggestions) {
const [user] = useUser();
const [suggestionsFilter, setSuggestionsFilter] = useState<
number | undefined
>(undefined);
const { data: plusStatusData } = useSWR<PlusStatus>(
user ? "/api/plus" : null
);
const { data: suggestionsData } = useSWR<Suggestions>(
"/api/plus/suggestions",
{ initialData }
);
const suggestions = suggestionsData ?? [];
return {
plusStatusData: plusStatusData?.status,
suggestionsData: suggestions.filter(
(suggestion) =>
!suggestionsFilter || suggestion.tier === suggestionsFilter
),
suggestionsLoading: !suggestionsData,
suggestionCounts: suggestions.reduce(
(counts, suggestion) => {
const tierString = [null, "ONE", "TWO", "THREE"][
suggestion.tier
] as keyof typeof counts;
counts[tierString]++;
return counts;
},
{ ONE: 0, TWO: 0, THREE: 0 }
),
ownSuggestion: suggestions.find(
(suggestion) => suggestion.suggesterUser.id === user?.id
),
setSuggestionsFilter,
};
}