fix(frontend): initialize follow state from server-side following list on remote actor profile
This commit is contained in:
@@ -1,7 +1,7 @@
|
|||||||
import type { Metadata } from "next";
|
import type { Metadata } from "next";
|
||||||
import { notFound } from "next/navigation";
|
import { notFound } from "next/navigation";
|
||||||
import { cookies } from "next/headers";
|
import { cookies } from "next/headers";
|
||||||
import { getMe, lookupRemoteActor, getRemoteActorPosts, Me } from "@/lib/api";
|
import { getMe, getRemoteFollowing, lookupRemoteActor, getRemoteActorPosts, Me } from "@/lib/api";
|
||||||
import { RemoteUserProfile } from "@/components/remote-user-profile";
|
import { RemoteUserProfile } from "@/components/remote-user-profile";
|
||||||
|
|
||||||
interface RemoteActorPageProps {
|
interface RemoteActorPageProps {
|
||||||
@@ -53,10 +53,11 @@ export default async function RemoteActorPage({
|
|||||||
|
|
||||||
const token = (await cookies()).get("auth_token")?.value ?? null;
|
const token = (await cookies()).get("auth_token")?.value ?? null;
|
||||||
|
|
||||||
const [actorResult, postsResult, meResult] = await Promise.allSettled([
|
const [actorResult, postsResult, meResult, followingResult] = await Promise.allSettled([
|
||||||
lookupRemoteActor(handle, token),
|
lookupRemoteActor(handle, token),
|
||||||
getRemoteActorPosts(handle, 1, token),
|
getRemoteActorPosts(handle, 1, token),
|
||||||
token ? getMe(token) : Promise.resolve(null),
|
token ? getMe(token) : Promise.resolve(null),
|
||||||
|
token ? getRemoteFollowing(token) : Promise.resolve([]),
|
||||||
]);
|
]);
|
||||||
|
|
||||||
if (actorResult.status === "rejected") {
|
if (actorResult.status === "rejected") {
|
||||||
@@ -68,6 +69,16 @@ export default async function RemoteActorPage({
|
|||||||
postsResult.status === "fulfilled" ? postsResult.value.items : [];
|
postsResult.status === "fulfilled" ? postsResult.value.items : [];
|
||||||
const me =
|
const me =
|
||||||
meResult.status === "fulfilled" ? (meResult.value as Me | null) : null;
|
meResult.status === "fulfilled" ? (meResult.value as Me | null) : null;
|
||||||
|
const following =
|
||||||
|
followingResult.status === "fulfilled" ? followingResult.value : [];
|
||||||
|
const initialFollowed = following.some((f) => f.url === actor.url);
|
||||||
|
|
||||||
return <RemoteUserProfile actor={actor} initialPosts={posts} me={me} />;
|
return (
|
||||||
|
<RemoteUserProfile
|
||||||
|
actor={actor}
|
||||||
|
initialPosts={posts}
|
||||||
|
me={me}
|
||||||
|
initialFollowed={initialFollowed}
|
||||||
|
/>
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -17,14 +17,16 @@ interface RemoteUserProfileProps {
|
|||||||
actor: RemoteActor;
|
actor: RemoteActor;
|
||||||
initialPosts: Thought[];
|
initialPosts: Thought[];
|
||||||
me: Me | null;
|
me: Me | null;
|
||||||
|
initialFollowed?: boolean;
|
||||||
}
|
}
|
||||||
|
|
||||||
export function RemoteUserProfile({
|
export function RemoteUserProfile({
|
||||||
actor,
|
actor,
|
||||||
initialPosts,
|
initialPosts,
|
||||||
me,
|
me,
|
||||||
|
initialFollowed = false,
|
||||||
}: RemoteUserProfileProps) {
|
}: RemoteUserProfileProps) {
|
||||||
const [followed, setFollowed] = useState(false);
|
const [followed, setFollowed] = useState(initialFollowed);
|
||||||
const [loading, setLoading] = useState(false);
|
const [loading, setLoading] = useState(false);
|
||||||
const { token } = useAuth();
|
const { token } = useAuth();
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user