Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix: identity after registration #862

Merged
merged 2 commits into from
Jul 25, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
14 changes: 13 additions & 1 deletion components/identities/identityCard.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ import { debounce } from "../../utils/debounceService";
import { Identity } from "../../utils/apiWrappers/identity";
import CopyContent from "../UI/copyContent";
import AddEvmAction from "./actions/addEvmAction";
import { useSearchParams } from "next/navigation";

type IdentityCardProps = {
identity?: Identity;
Expand All @@ -38,6 +39,8 @@ const IdentityCard: FunctionComponent<IdentityCardProps> = ({
const isMobile = useMediaQuery("(max-width:1124px)");
const handleMouseEnter = debounce(() => setIsHovered(true), 50);
const handleMouseLeave = debounce(() => setIsHovered(false), 50);
const searchParams = useSearchParams();
const minting = searchParams.get("minting") === "true";

return (
<div className={styles.wrapper}>
Expand Down Expand Up @@ -101,6 +104,16 @@ const IdentityCard: FunctionComponent<IdentityCardProps> = ({
</Tooltip>
) : null}
</div>
{minting ? (
<div className="text-left h-full py-2">
<h1 className="text-3xl font-bold font-quickZap">
Minting your identity...
</h1>
<p>This page will refresh automatically</p>
<Skeleton className="mt-3" variant="rounded" height={30} />
<Skeleton className="mt-3" variant="rounded" height={58} />
</div>
) : null}
<div>
<div className="flex flex-row items-center justify-center gap-5 mb-5">
<div className="flex flex-col">
Expand All @@ -126,7 +139,6 @@ const IdentityCard: FunctionComponent<IdentityCardProps> = ({
) : null}
</div>
</div>

<AddEvmAction identity={identity} isOwner={isOwner} />
<SocialMediaActions
identity={identity}
Expand Down
4 changes: 2 additions & 2 deletions components/identities/skeletons/identityActionsSkeleton.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import { Skeleton } from "@mui/material";
import React, { FunctionComponent } from "react";
import styles from "../../../styles/components/identityCard.module.css";

const identityActionsSkeleton: FunctionComponent = () => {
const IdentityActionsSkeleton: FunctionComponent = () => {
return (
<div className={styles.identitiesActionsSkeletonButtons}>
<Skeleton variant="rounded" width={300} height={60} />
Expand All @@ -13,4 +13,4 @@ const identityActionsSkeleton: FunctionComponent = () => {
);
};

export default identityActionsSkeleton;
export default IdentityActionsSkeleton;
2 changes: 1 addition & 1 deletion pages/confirmation.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ const Confirmation: NextPage = () => {
const { copied, copyToClipboard } = useCopyToClipboard();

const redirect = () => {
if (tokenId) router.push(`/identities/${tokenId}`);
if (tokenId) router.push(`/identities/${tokenId}?minting=true`);
else router.push(`/identities`);
};

Expand Down
84 changes: 59 additions & 25 deletions pages/identities/[tokenId].tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import React, { useEffect, useState } from "react";
import React, { useCallback, useEffect, useState } from "react";
import homeStyles from "../../styles/Home.module.css";
import styles from "../../styles/components/identitiesV1.module.css";
import { useRouter } from "next/router";
Expand All @@ -14,6 +14,8 @@ import BackButton from "../../components/UI/backButton";
import { Identity } from "../../utils/apiWrappers/identity";
import { formatHexString } from "../../utils/stringService";
import { getDomainData } from "@/utils/cacheDomainData";
import { useSearchParams } from "next/navigation";
import IdentityActionsSkeleton from "@/components/identities/skeletons/identityActionsSkeleton";

const TokenIdPage: NextPage = () => {
const router = useRouter();
Expand All @@ -29,6 +31,24 @@ const TokenIdPage: NextPage = () => {
const [isTxModalOpen, setIsTxModalOpen] = useState(false);
const [ppTxHash, setPpTxHash] = useState<string>();
const [ppImageUrl, setPpImageUrl] = useState("");
const [minting, setMinting] = useState(false);
const searchParams = useSearchParams();
const mintingInUrl = searchParams.get("minting") === "true";

useEffect(() => {
if (mintingInUrl) setMinting(true);
else setMinting(false);
}, [mintingInUrl]);

const endMinting = useCallback(() => {
router.replace(router.asPath.split("?")[0]);
setMinting(false);
setHideActions(false);
}, [router]);

useEffect(() => {
if (minting && identity) endMinting();
}, [minting, identity, endMinting]);

useEffect(() => {
if (!identity || !address) {
Expand Down Expand Up @@ -64,35 +84,47 @@ const TokenIdPage: NextPage = () => {
}
};

const refreshData = useCallback(
() =>
fetch(`${process.env.NEXT_PUBLIC_SERVER_LINK}/id_to_data?id=${tokenId}`)
.then(async (response) => {
if (!response.ok) {
throw new Error(await response.text());
}
return response.json();
})
.then((data: IdentityData) => {
if (minting) endMinting();
setIdentity(new Identity(data));
setIsIdentityADomain(Boolean(data?.domain));
})
.catch(() => {
// Domain data might not be indexed yet, so we check local storage
const domainData = getDomainData(tokenId);
if (domainData) {
setIdentity(new Identity(domainData));
setIsIdentityADomain(Boolean(domainData?.domain));
} else {
setIsIdentityADomain(false);
}
}),
[tokenId, minting, endMinting]
);

useEffect(() => {
if (minting && tokenId && !identity) {
const interval = setInterval(() => refreshData(), 1000);
return () => clearInterval(interval);
}
}, [minting, tokenId, identity, refreshData]);

useEffect(() => {
if (tokenId) {
const refreshData = () =>
fetch(`${process.env.NEXT_PUBLIC_SERVER_LINK}/id_to_data?id=${tokenId}`)
.then(async (response) => {
if (!response.ok) {
throw new Error(await response.text());
}
return response.json();
})
.then((data: IdentityData) => {
setIdentity(new Identity(data));
setIsIdentityADomain(Boolean(data?.domain));
})
.catch(() => {
// Domain data might not be indexed yet, so we check local storage
const domainData = getDomainData(tokenId);
if (domainData) {
setIdentity(new Identity(domainData));
setIsIdentityADomain(Boolean(domainData?.domain));
} else {
setIsIdentityADomain(false);
}
});
refreshData();
const timer = setInterval(() => refreshData(), 30e3);
return () => clearInterval(timer);
}
}, [tokenId]);
}, [tokenId, refreshData]);

return (
<>
Expand All @@ -114,14 +146,16 @@ const TokenIdPage: NextPage = () => {
onPPClick={() => setIsUpdatingPp(true)}
ppImageUrl={ppImageUrl}
/>
{!hideActions && (
{!hideActions ? (
<IdentityActions
isOwner={isOwner}
tokenId={tokenId}
isIdentityADomain={isIdentityADomain}
identity={identity}
hideActionsHandler={hideActionsHandler}
/>
) : (
minting && <IdentityActionsSkeleton />
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Comme dis dans la video il doit y avoir un problème dans ce code car j'ai eu ça

Capture d’écran 2024-07-22 à 17 29 16

)}
</div>
<IdentityWarnings
Expand Down