diff --git a/ui/shared/entities/address/AddressEntityContentProxy.tsx b/ui/shared/entities/address/AddressEntityContentProxy.tsx index 66fbb4146f..fd778b5dfa 100644 --- a/ui/shared/entities/address/AddressEntityContentProxy.tsx +++ b/ui/shared/entities/address/AddressEntityContentProxy.tsx @@ -6,12 +6,16 @@ import * as EntityBase from 'ui/shared/entities/base/components'; import type { ContentProps } from './AddressEntity'; import AddressEntity from './AddressEntity'; +import { formattedLuksoName, useUniversalProfile } from './IdenticonUniversalProfileQuery'; const AddressEntityContentProxy = (props: ContentProps) => { const bgColor = useColorModeValue('gray.700', 'gray.900'); const implementations = props.address.implementations; + const { data: upData, isLoading: upIsLoading } = useUniversalProfile(props.address.hash); + const upName = upIsLoading ? '' : upData?.name ?? ''; + const handleClick = React.useCallback((event: React.MouseEvent) => { event.stopPropagation(); }, []); @@ -25,14 +29,19 @@ const AddressEntityContentProxy = (props: ContentProps) => { const implementationName = implementations.length === 1 && implementations[0].name ? implementations[0].name : undefined; + const fallback = nameTag || implementationName || props.address.name || props.address.hash; + const displayedText = upName !== '' ? formattedLuksoName(props.address.hash, upName) : fallback; + const truncation = nameTag || implementationName || props.address.name ? 'tail' : props.truncation; + const upTruncation = upName !== '' ? 'dynamic' : truncation; + return ( diff --git a/ui/shared/entities/address/IdenticonUniversalProfileQuery.tsx b/ui/shared/entities/address/IdenticonUniversalProfileQuery.tsx index 91b61845fe..73ae839ced 100644 --- a/ui/shared/entities/address/IdenticonUniversalProfileQuery.tsx +++ b/ui/shared/entities/address/IdenticonUniversalProfileQuery.tsx @@ -6,6 +6,7 @@ import React from 'react'; import { graphClient } from 'lib/api/graphClient'; import type { SearchProfileQueryResponse } from 'lib/api/graphTypes'; +import { isUniversalProfileEnabled } from 'lib/api/isUniversalProfileEnabled'; interface Props { address: string; @@ -14,6 +15,10 @@ interface Props { const profiles = create({ fetcher: async(addresses: Array) => { + if (!isUniversalProfileEnabled()) { + return [] as Array; + } + const resp = await graphClient.getProfiles(JSON.stringify(addresses)); if (resp === null) { return [] as Array; diff --git a/ui/shared/entities/base/components.tsx b/ui/shared/entities/base/components.tsx index b754365c28..ec6590b8ac 100644 --- a/ui/shared/entities/base/components.tsx +++ b/ui/shared/entities/base/components.tsx @@ -117,7 +117,6 @@ export interface ContentBaseProps extends Pick { - const children = (() => { switch (truncation) { case 'constant_long':