Skip to content

Commit

Permalink
Truncate proxy entries
Browse files Browse the repository at this point in the history
  • Loading branch information
Wolmin committed Nov 14, 2024
1 parent c9bc4b1 commit 62f5736
Show file tree
Hide file tree
Showing 3 changed files with 16 additions and 3 deletions.
13 changes: 11 additions & 2 deletions ui/shared/entities/address/AddressEntityContentProxy.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -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();
}, []);
Expand All @@ -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 (
<Popover trigger="hover" isLazy gutter={ 8 }>
<PopoverTrigger>
<Box display="inline-flex" w="100%">
<EntityBase.Content
{ ...props }
truncation={ nameTag || implementationName || props.address.name ? 'tail' : props.truncation }
text={ nameTag || implementationName || props.address.name || props.address.hash }
truncation={ upTruncation }
text={ displayedText }
isTooltipDisabled
/>
</Box>
Expand Down
5 changes: 5 additions & 0 deletions ui/shared/entities/address/IdenticonUniversalProfileQuery.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -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;
Expand All @@ -14,6 +15,10 @@ interface Props {

const profiles = create({
fetcher: async(addresses: Array<string>) => {
if (!isUniversalProfileEnabled()) {
return [] as Array<SearchProfileQueryResponse>;
}

const resp = await graphClient.getProfiles(JSON.stringify(addresses));
if (resp === null) {
return [] as Array<SearchProfileQueryResponse>;
Expand Down
1 change: 0 additions & 1 deletion ui/shared/entities/base/components.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -117,7 +117,6 @@ export interface ContentBaseProps extends Pick<EntityBaseProps, 'className' | 'i
}

const Content = chakra(({ className, isLoading, asProp, text, truncation = 'dynamic', tailLength, isTooltipDisabled }: ContentBaseProps) => {

const children = (() => {
switch (truncation) {
case 'constant_long':
Expand Down

0 comments on commit 62f5736

Please sign in to comment.