From 286c6c28e5e3f0a40e7ac89bd14c4aa0b7f500cc Mon Sep 17 00:00:00 2001 From: Hunter Miller Date: Fri, 16 Jul 2021 10:55:41 -0500 Subject: [PATCH] embeds: converted to links for better usability --- .../src/views/apps/permalinks/app.tsx | 2 +- .../src/views/apps/permalinks/embed.tsx | 17 ++---- .../src/views/components/GroupLink.tsx | 59 +++++++++++-------- 3 files changed, 38 insertions(+), 40 deletions(-) diff --git a/pkg/interface/src/views/apps/permalinks/app.tsx b/pkg/interface/src/views/apps/permalinks/app.tsx index 8e8d22f04..30763b654 100644 --- a/pkg/interface/src/views/apps/permalinks/app.tsx +++ b/pkg/interface/src/views/apps/permalinks/app.tsx @@ -77,7 +77,7 @@ function GroupRoutes(props: { group: string; url: string }) { return null; } if(!graphKeys.has(`${ship.slice(1)}/${name}`)) { - if(graphKeys.size > 0) { + if(graphKeys.size > 1) { // TODO: Better loading logic see https://github.com/urbit/landscape/issues/1063 return { - e.stopPropagation(); - history.push(`/perma${permalink.slice(16)}`); - }; - const [nodeGroupHost, nodeGroupName] = association?.group.split('/').slice(-2) ?? ['Unknown', 'Unknown']; const [nodeChannelHost, nodeChannelName] = association?.resource .split('/') @@ -141,15 +135,16 @@ function GraphPermalink( return ( { - navigate(e); + e.stopPropagation(); }} > {loading && association && !errored && Placeholder((association.metadata.config as GraphConfig).graph)} @@ -167,7 +162,6 @@ function GraphPermalink( showTransclusion={showTransclusion} icon={getModuleIcon((association.metadata.config as GraphConfig).graph as GraphModule)} title={association.metadata.title} - permalink={permalink} /> )} {association && isInSameResource && transcluded === 2 && !loading && ( @@ -176,7 +170,6 @@ function GraphPermalink( showTransclusion={showTransclusion} icon={getModuleIcon((association.metadata.config as GraphConfig).graph as GraphModule)} title={association.metadata.title} - permalink={permalink} /> )} {isInSameResource && transcluded !== 2 && !loading && } @@ -185,7 +178,6 @@ function GraphPermalink( icon="Groups" showDetails={false} title={graph.slice(5)} - permalink={permalink} /> )} @@ -195,7 +187,6 @@ function GraphPermalink( function PermalinkDetails(props: { title: string; icon: any; - permalink: string; showTransclusion?: boolean; showDetails?: boolean; known?: boolean; diff --git a/pkg/interface/src/views/components/GroupLink.tsx b/pkg/interface/src/views/components/GroupLink.tsx index 998a525ee..88b96e272 100644 --- a/pkg/interface/src/views/components/GroupLink.tsx +++ b/pkg/interface/src/views/components/GroupLink.tsx @@ -1,56 +1,63 @@ import { Box, Col, Icon, Row, Text } from '@tlon/indigo-react'; import React, { ReactElement, useCallback } from 'react'; -import { useHistory } from 'react-router-dom'; +import { Link } from 'react-router-dom'; import { useModal } from '~/logic/lib/useModal'; import useMetadataState, { usePreview } from '~/logic/state/metadata'; import { PropFunc } from '~/types'; import { JoinGroup } from '../landscape/components/JoinGroup'; import { MetadataIcon } from '../landscape/components/MetadataIcon'; -export function GroupLink( - props: { - resource: string; - detailed?: boolean; - } & PropFunc -): ReactElement { - const { resource, ...rest } = props; +type GroupLinkProps = { + resource: string; + detailed?: boolean; +} & PropFunc + +export function GroupLink({ + resource, + borderColor, + ...rest +}: GroupLinkProps): ReactElement { const name = resource.slice(6); const joined = useMetadataState( useCallback(s => resource in s.associations.groups, [resource]) ); - const history = useHistory(); const { modal, showModal } = useModal({ modal: - }); + }); const { preview } = usePreview(resource); return ( - { - e.stopPropagation(); - }} - backgroundColor='white' - borderColor={props.borderColor} - > + <> {modal} ) => { + e.stopPropagation(); + + if (e.metaKey || e.ctrlKey) { + return; + } + + e.preventDefault(); + showModal(); + }} flexShrink={1} alignItems="center" + width="100%" + maxWidth="500px" py={2} pr={2} - onClick={ - joined ? () => history.push(`/~landscape/ship/${name}`) : showModal - } + cursor='pointer' + backgroundColor='white' + borderColor={borderColor} opacity={preview ? '1' : '0.6'} > - + {preview ? preview.metadata.title : name} @@ -70,6 +77,6 @@ export function GroupLink( - + ); }