mirror of
https://github.com/neynarxyz/create-farcaster-mini-app.git
synced 2025-11-16 08:08:56 -05:00
86 lines
2.9 KiB
TypeScript
86 lines
2.9 KiB
TypeScript
"use client";
|
|
|
|
import { useState } from "react";
|
|
import { APP_NAME } from "~/lib/constants";
|
|
import sdk from "@farcaster/frame-sdk";
|
|
import { useMiniApp } from "@neynar/react";
|
|
|
|
type HeaderProps = {
|
|
neynarUser?: {
|
|
fid: number;
|
|
score: number;
|
|
} | null;
|
|
};
|
|
|
|
export function Header({ neynarUser }: HeaderProps) {
|
|
const { context } = useMiniApp();
|
|
const [isUserDropdownOpen, setIsUserDropdownOpen] = useState(false);
|
|
const [hasClickedPfp, setHasClickedPfp] = useState(false);
|
|
|
|
return (
|
|
<div className="relative">
|
|
<div
|
|
className="mb-1 py-2 px-3 bg-gray-100 dark:bg-gray-800 rounded-lg flex items-center justify-between border-[3px] border-double border-purple-500"
|
|
>
|
|
<div className="text-lg font-light">
|
|
Welcome to {APP_NAME}!
|
|
</div>
|
|
{context?.user && (
|
|
<div
|
|
className="cursor-pointer"
|
|
onClick={() => {
|
|
setIsUserDropdownOpen(!isUserDropdownOpen);
|
|
setHasClickedPfp(true);
|
|
}}
|
|
>
|
|
{context.user.pfpUrl && (
|
|
<img
|
|
src={context.user.pfpUrl}
|
|
alt="Profile"
|
|
className="w-10 h-10 rounded-full border-2 border-purple-500"
|
|
/>
|
|
)}
|
|
</div>
|
|
)}
|
|
</div>
|
|
{context?.user && (
|
|
<>
|
|
{!hasClickedPfp && (
|
|
<div className="absolute right-0 -bottom-6 text-xs text-purple-500 flex items-center justify-end gap-1 pr-2">
|
|
<span className="text-[10px]">↑</span> Click PFP! <span className="text-[10px]">↑</span>
|
|
</div>
|
|
)}
|
|
|
|
{isUserDropdownOpen && (
|
|
<div className="absolute top-full right-0 z-50 w-fit mt-1 bg-white dark:bg-gray-800 rounded-lg shadow-lg border border-gray-200 dark:border-gray-700">
|
|
<div className="p-3 space-y-2">
|
|
<div className="text-right">
|
|
<h3
|
|
className="font-bold text-sm hover:underline cursor-pointer inline-block"
|
|
onClick={() => sdk.actions.viewProfile({ fid: context.user.fid })}
|
|
>
|
|
{context.user.displayName || context.user.username}
|
|
</h3>
|
|
<p className="text-xs text-gray-600 dark:text-gray-400">
|
|
@{context.user.username}
|
|
</p>
|
|
<p className="text-xs text-gray-500 dark:text-gray-500">
|
|
FID: {context.user.fid}
|
|
</p>
|
|
{neynarUser && (
|
|
<>
|
|
<p className="text-xs text-gray-500 dark:text-gray-500">
|
|
Neynar Score: {neynarUser.score}
|
|
</p>
|
|
</>
|
|
)}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
)}
|
|
</>
|
|
)}
|
|
</div>
|
|
);
|
|
}
|