From f340f7c10bc6d4173e0c907eadcc21ce5b879091 Mon Sep 17 00:00:00 2001 From: Stanislav Date: Tue, 22 Oct 2024 11:07:49 +0100 Subject: [PATCH] feat(explorer): As a user, I want to see indication that I am currently looking at a filtered view of Attestations (#766) Co-authored-by: Alain Nicolas --- .../components/TitleAndSwitcher/index.tsx | 4 +- explorer/src/pages/Attestations/index.tsx | 51 +++++++++++++++++-- 2 files changed, 49 insertions(+), 6 deletions(-) diff --git a/explorer/src/pages/Attestations/components/TitleAndSwitcher/index.tsx b/explorer/src/pages/Attestations/components/TitleAndSwitcher/index.tsx index 915055a2..650a0b6c 100644 --- a/explorer/src/pages/Attestations/components/TitleAndSwitcher/index.tsx +++ b/explorer/src/pages/Attestations/components/TitleAndSwitcher/index.tsx @@ -3,12 +3,12 @@ import { PropsWithChildren } from "react"; import { ListSwitcher } from "../ListSwitcher"; -export const TitleAndSwitcher = ({ children }: PropsWithChildren) => { +export const TitleAndSwitcher = ({ children, title }: PropsWithChildren & { title?: string }) => { return (

- {t("attestation.list.title")} + {title || t("attestation.list.title")}

diff --git a/explorer/src/pages/Attestations/index.tsx b/explorer/src/pages/Attestations/index.tsx index b36c08cf..3b0a3b2d 100644 --- a/explorer/src/pages/Attestations/index.tsx +++ b/explorer/src/pages/Attestations/index.tsx @@ -1,17 +1,19 @@ import { Attestation_filter, OrderDirection } from "@verax-attestation-registry/verax-sdk/lib/types/.graphclient"; -import { useRef, useState } from "react"; +import { useCallback, useRef, useState } from "react"; import { useSearchParams } from "react-router-dom"; import useSWR from "swr"; import { DataTable } from "@/components/DataTable"; import { Pagination } from "@/components/Pagination"; import { BasicPagination } from "@/components/Pagination/Basic"; -import { ITEMS_PER_PAGE_DEFAULT, ZERO } from "@/constants"; +import { EMPTY_STRING, ITEMS_PER_PAGE_DEFAULT, ZERO } from "@/constants"; import { attestationColumnsOption, columns, skeletonAttestations } from "@/constants/columns/attestation"; import { columnsSkeleton } from "@/constants/columns/skeleton"; +import { regexEthAddress } from "@/constants/regex"; import { EQueryParams } from "@/enums/queryParams"; import { ETableSorting } from "@/enums/tableSorting"; import { SWRKeys } from "@/interfaces/swr/enum"; +import { issuersData } from "@/pages/Home/data"; import { useNetworkContext } from "@/providers/network-provider/context"; import { APP_ROUTES } from "@/routes/constants"; import { buildAttestationId } from "@/utils/attestationIdUtils.ts"; @@ -36,9 +38,50 @@ export const Attestations: React.FC = () => { const where = searchParams.get(EQueryParams.WHERE) ? (JSON.parse(searchParams.get(EQueryParams.WHERE) ?? "") as Attestation_filter) : undefined; - const [lastID, setLastID] = useState(getItemsByPage(page, itemsPerPage)); + const findIssuerBySchema = () => + issuersData.find((issuer) => + issuer.attestationDefinitions.some( + (definition) => definition.schema === where?.schema_?.id && definition.portal === where?.portal_?.id, + ), + ); + + const findIssuerByPortal = () => + issuersData.find((issuer) => + issuer.attestationDefinitions.some((definition) => where?.portal_in?.includes(definition.portal)), + ); + + const findAttestation = () => + attestationDefinitions?.filter((definition) => definition.schema === where?.schema_?.id)[0]; + + const isByAttestationType = "schema_" in (where || {}); + const isFilteredByWhere = where && (isByAttestationType || where.portal_in?.length); + const { name, attestationDefinitions } = isByAttestationType + ? findIssuerBySchema() || {} + : findIssuerByPortal() || {}; + const { name: attestationName, portal: attestationPortal } = findAttestation() || {}; + const portalId = isByAttestationType ? where?.portal_?.id : where?.portal_in?.[0]; + const schemaId = where?.schema_?.id; + const isPortalMatch = portalId === attestationPortal; + + const { data: portal } = useSWR(isPortalMatch ? null : `${SWRKeys.GET_PORTAL_LIST}`, async () => { + if (portalId && regexEthAddress.byNumberOfChar[42].test(portalId)) + return sdk.portal.findOneById(portalId || EMPTY_STRING); + }); + + const { data: schema } = useSWR(`${SWRKeys.GET_SCHEMA_BY_ID}/${schemaId}/${network.chain.id}`, async () => { + if (schemaId && regexEthAddress.byNumberOfChar[64].test(schemaId)) return sdk.schema.findOneById(schemaId); + }); + + const generateTitle = useCallback(() => { + const titleByAttestationType = isPortalMatch + ? `${name} - ${attestationName}` + : `Attestations matching Portal ${portal?.name} for Schema ${schema?.name}`; + const titleByIssuer = `Attestations from ${name || portal?.ownerName}`; + return isByAttestationType ? titleByAttestationType : titleByIssuer; + }, [isPortalMatch, portal, schema, name, attestationName, isByAttestationType]); + const { data: attestationsList, isLoading } = useSWR( totalItems > 0 ? `${SWRKeys.GET_ATTESTATION_LIST}/${itemsPerPage}/${lastID}/${sortByDateDirection}/${network.chain.id}` @@ -82,7 +125,7 @@ export const Attestations: React.FC = () => { }; return ( - + {renderPagination()}