Skip to content

Commit

Permalink
Merge pull request #1496 from decentdao/enhancement/1483-chainspacing
Browse files Browse the repository at this point in the history
Enhancement/1483 chainspacing
  • Loading branch information
adamgall authored Mar 29, 2024
2 parents bb5984d + 9396909 commit 785eff5
Show file tree
Hide file tree
Showing 46 changed files with 438 additions and 284 deletions.
6 changes: 5 additions & 1 deletion src/components/DaoCreator/StepWrapper.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ import { useNavigate } from 'react-router-dom';
import { BACKGROUND_SEMI_TRANSPARENT } from '../../constants/common';
import { BASE_ROUTES, DAO_ROUTES } from '../../constants/routes';
import { useFractal } from '../../providers/App/AppProvider';
import { useNetworkConfig } from '../../providers/NetworkConfig/NetworkConfigProvider';
import PageHeader from '../ui/page/Header/PageHeader';
import { DAOCreateMode } from './formComponents/EstablishEssentials';

Expand All @@ -29,6 +30,7 @@ export function StepWrapper({
const {
node: { daoAddress },
} = useFractal();
const { addressPrefix } = useNetworkConfig();
const { t } = useTranslation(['daoCreate']);
const navigate = useNavigate();

Expand Down Expand Up @@ -64,7 +66,9 @@ export function StepWrapper({
isButtonDisabled={isFormSubmitting}
buttonClick={() =>
navigate(
!isSubDAO || !daoAddress ? BASE_ROUTES.landing : DAO_ROUTES.dao.relative(daoAddress),
!isSubDAO || !daoAddress
? BASE_ROUTES.landing
: DAO_ROUTES.dao.relative(addressPrefix, daoAddress),
)
}
/>
Expand Down
6 changes: 4 additions & 2 deletions src/components/ProposalTemplates/ProposalTemplateCard.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import { DAO_ROUTES } from '../../constants/routes';
import useRemoveProposalTemplate from '../../hooks/DAO/proposal/useRemoveProposalTemplate';
import useSubmitProposal from '../../hooks/DAO/proposal/useSubmitProposal';
import { useFractal } from '../../providers/App/AppProvider';
import { useNetworkConfig } from '../../providers/NetworkConfig/NetworkConfigProvider';
import { ProposalTemplate } from '../../types/createProposalTemplate';
import ContentBox from '../ui/containers/ContentBox';
import { OptionMenu } from '../ui/menus/OptionMenu';
Expand All @@ -28,6 +29,7 @@ export default function ProposalTemplateCard({
const {
node: { safe, daoAddress },
} = useFractal();
const { addressPrefix } = useNetworkConfig();

const { prepareRemoveProposalTemplateProposal } = useRemoveProposalTemplate();
const { submitProposal, canUserCreateProposal } = useSubmitProposal();
Expand All @@ -44,9 +46,9 @@ export default function ProposalTemplateCard({
const successCallback = useCallback(() => {
if (daoAddress) {
// Redirecting to proposals page so that user will see Proposal for Proposal Template creation
navigate(DAO_ROUTES.proposals.relative(daoAddress));
navigate(DAO_ROUTES.proposals.relative(addressPrefix, daoAddress));
}
}, [navigate, daoAddress]);
}, [navigate, daoAddress, addressPrefix]);

const nonce = safe?.nonce;
const handleRemoveTemplate = useCallback(async () => {
Expand Down
6 changes: 4 additions & 2 deletions src/components/ProposalTemplates/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import { Link } from 'react-router-dom';
import { DAO_ROUTES } from '../../constants/routes';
import useSubmitProposal from '../../hooks/DAO/proposal/useSubmitProposal';
import { useFractal } from '../../providers/App/AppProvider';
import { useNetworkConfig } from '../../providers/NetworkConfig/NetworkConfigProvider';
import { EmptyBox } from '../ui/containers/EmptyBox';
import { InfoBoxLoader } from '../ui/loaders/InfoBoxLoader';
import ProposalTemplateCard from './ProposalTemplateCard';
Expand All @@ -14,6 +15,7 @@ export default function ProposalTemplates() {
node: { daoAddress },
governance: { proposalTemplates },
} = useFractal();
const { addressPrefix } = useNetworkConfig();
const { canUserCreateProposal } = useSubmitProposal();

return (
Expand All @@ -36,8 +38,8 @@ export default function ProposalTemplates() {
))
) : (
<EmptyBox emptyText={t('emptyProposalTemplates')}>
{canUserCreateProposal && (
<Link to={DAO_ROUTES.proposalTemplateNew.relative(daoAddress)}>
{canUserCreateProposal && daoAddress && (
<Link to={DAO_ROUTES.proposalTemplateNew.relative(addressPrefix, daoAddress)}>
<Button
variant="text"
textStyle="text-xl-mono-bold"
Expand Down
8 changes: 7 additions & 1 deletion src/components/Proposals/ProposalCard/ProposalCard.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import { useTranslation } from 'react-i18next';
import { Link } from 'react-router-dom';
import { DAO_ROUTES } from '../../../constants/routes';
import { useFractal } from '../../../providers/App/AppProvider';
import { useNetworkConfig } from '../../../providers/NetworkConfig/NetworkConfigProvider';
import { ActivityEventType, FractalProposal, SnapshotProposal } from '../../../types';
import { DEFAULT_DATE_FORMAT } from '../../../utils';
import { ActivityDescription } from '../../Activity/ActivityDescription';
Expand All @@ -14,6 +15,7 @@ function ProposalCard({ proposal }: { proposal: FractalProposal }) {
const {
node: { daoAddress },
} = useFractal();
const { addressPrefix } = useNetworkConfig();
const { t } = useTranslation('common');

const eventDateLabel = t(
Expand All @@ -26,8 +28,12 @@ function ProposalCard({ proposal }: { proposal: FractalProposal }) {

const isSnapshotProposal = !!(proposal as SnapshotProposal).snapshotProposalId;

if (!daoAddress) {
return null;
}

return (
<Link to={DAO_ROUTES.proposal.relative(daoAddress, proposal.proposalId)}>
<Link to={DAO_ROUTES.proposal.relative(addressPrefix, daoAddress, proposal.proposalId)}>
<Box
minHeight="6.25rem"
bg="chocolate.900"
Expand Down
6 changes: 4 additions & 2 deletions src/components/Proposals/ProposalsList.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import { Link } from 'react-router-dom';
import { DAO_ROUTES } from '../../constants/routes';
import useSubmitProposal from '../../hooks/DAO/proposal/useSubmitProposal';
import { useFractal } from '../../providers/App/AppProvider';
import { useNetworkConfig } from '../../providers/NetworkConfig/NetworkConfigProvider';
import { FractalProposal } from '../../types';
import { EmptyBox } from '../ui/containers/EmptyBox';
import { InfoBoxLoader } from '../ui/loaders/InfoBoxLoader';
Expand All @@ -13,6 +14,7 @@ export function ProposalsList({ proposals }: { proposals: FractalProposal[] }) {
const {
node: { daoAddress },
} = useFractal();
const { addressPrefix } = useNetworkConfig();
const { canUserCreateProposal } = useSubmitProposal();

const { t } = useTranslation('proposal');
Expand All @@ -34,8 +36,8 @@ export function ProposalsList({ proposals }: { proposals: FractalProposal[] }) {
))
) : (
<EmptyBox emptyText={t('emptyProposals')}>
{canUserCreateProposal && (
<Link to={DAO_ROUTES.proposalNew.relative(daoAddress)}>
{canUserCreateProposal && daoAddress && (
<Link to={DAO_ROUTES.proposalNew.relative(addressPrefix, daoAddress)}>
<Button
variant="text"
textStyle="text-xl-mono-bold"
Expand Down
4 changes: 3 additions & 1 deletion src/components/pages/AppHome/FeaturedDAOCard.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,13 +7,15 @@ interface DAOFeatureProps extends BoxProps {
iconSrc: string;
title: string;
desc: string;
network: string;
address: string;
}

export default function FeaturedDAOCard({
iconSrc,
title,
desc,
network,
address,
...rest
}: DAOFeatureProps) {
Expand Down Expand Up @@ -57,7 +59,7 @@ export default function FeaturedDAOCard({
_hover={{ color: 'gold.500-hover' }}
alignSelf="end"
textStyle="text-lg-mono-bold"
to={DAO_ROUTES.dao.relative(address)}
to={DAO_ROUTES.dao.relative(network, address)}
>
{t('featureLink')}
</Link>
Expand Down
4 changes: 3 additions & 1 deletion src/components/pages/DaoDashboard/Info/ParentLink.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import { useTranslation } from 'react-i18next';
import { Link as RouterLink } from 'react-router-dom';
import { DAO_ROUTES } from '../../../../constants/routes';
import { useFractal } from '../../../../providers/App/AppProvider';
import { useNetworkConfig } from '../../../../providers/NetworkConfig/NetworkConfigProvider';

/**
* Displays a link to the current DAO's parent, if it has one.
Expand All @@ -12,6 +13,7 @@ export function ParentLink() {
node: { nodeHierarchy },
action,
} = useFractal();
const { addressPrefix } = useNetworkConfig();
const { t } = useTranslation('breadcrumbs');

if (!nodeHierarchy.parentAddress) {
Expand All @@ -22,7 +24,7 @@ export function ParentLink() {
<Link
color="gold.500"
_hover={{ textDecoration: 'none', color: 'gold.500-hover' }}
to={DAO_ROUTES.dao.relative(nodeHierarchy.parentAddress)}
to={DAO_ROUTES.dao.relative(addressPrefix, nodeHierarchy.parentAddress)}
onClick={action.resetDAO}
marginBottom="1rem"
as={RouterLink}
Expand Down
6 changes: 4 additions & 2 deletions src/components/pages/DaoDashboard/Info/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import { Box, Flex, Text } from '@chakra-ui/react';
import { DAO_ROUTES } from '../../../../constants/routes';
import useDAOMetadata from '../../../../hooks/DAO/useDAOMetadata';
import { useFractal } from '../../../../providers/App/AppProvider';
import { useNetworkConfig } from '../../../../providers/NetworkConfig/NetworkConfigProvider';
import { InfoBox } from '../../../ui/containers/InfoBox';
import ExternalLink from '../../../ui/links/ExternalLink';
import { InfoDAO } from './InfoDAO';
Expand All @@ -14,6 +15,7 @@ export function Info() {
const {
node: { daoAddress },
} = useFractal();
const { addressPrefix } = useNetworkConfig();
const daoMetadata = useDAOMetadata();

// using this gap method instead of 'gap' to make width percentages more precise, since they
Expand Down Expand Up @@ -135,7 +137,7 @@ export function Info() {
pb={{ sm: PAD, md: NONE }}
pt={{ sm: PAD, lg: NONE }}
>
<InfoBox to={DAO_ROUTES.proposals.relative(daoAddress)}>
<InfoBox to={DAO_ROUTES.proposals.relative(addressPrefix, daoAddress || '')}>
<InfoProposals />
</InfoBox>
</Box>
Expand All @@ -144,7 +146,7 @@ export function Info() {
ps={{ base: NONE, md: PAD }}
pt={{ sm: PAD, lg: NONE }}
>
<InfoBox to={DAO_ROUTES.treasury.relative(daoAddress)}>
<InfoBox to={DAO_ROUTES.treasury.relative(addressPrefix, daoAddress || '')}>
<InfoTreasury />
</InfoBox>
</Box>
Expand Down
2 changes: 1 addition & 1 deletion src/components/pages/DaoHierarchy/DaoNode.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -69,7 +69,7 @@ export function DaoNode({
} else if (errorNode.error === 'errorFailedSearch') {
setNode({
daoName: null,
daoAddress: daoAddress,
daoAddress,
safe: null,
fractalModules: [],
nodeHierarchy: {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import { DAO_ROUTES } from '../../../../../constants/routes';
import useSubmitProposal from '../../../../../hooks/DAO/proposal/useSubmitProposal';
import { createAccountSubstring } from '../../../../../hooks/utils/useDisplayName';
import { useFractal } from '../../../../../providers/App/AppProvider';
import { useNetworkConfig } from '../../../../../providers/NetworkConfig/NetworkConfigProvider';
import { ProposalExecuteData } from '../../../../../types';
import { couldBeENS } from '../../../../../utils/url';
import { InputComponent } from '../../../../ui/forms/InputComponent';
Expand All @@ -27,6 +28,7 @@ export default function MetadataContainer() {
user: { votingWeight },
},
} = useFractal();
const { addressPrefix } = useNetworkConfig();

useEffect(() => {
if (daoName && daoAddress && createAccountSubstring(daoAddress) !== daoName) {
Expand All @@ -50,7 +52,11 @@ export default function MetadataContainer() {

const userHasVotingWeight = votingWeight.gt(0);

const submitProposalSuccessCallback = () => navigate(DAO_ROUTES.proposals.relative(daoAddress));
const submitProposalSuccessCallback = () => {
if (daoAddress) {
navigate(DAO_ROUTES.proposals.relative(addressPrefix, daoAddress));
}
};

const handleEditDAOName = () => {
if (!baseContracts) {
Expand Down
6 changes: 4 additions & 2 deletions src/components/ui/cards/DAOInfoCard.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import { Link as RouterLink } from 'react-router-dom';
import { DAO_ROUTES } from '../../../constants/routes';
import useDisplayName from '../../../hooks/utils/useDisplayName';
import { useFractal } from '../../../providers/App/AppProvider';
import { useNetworkConfig } from '../../../providers/NetworkConfig/NetworkConfigProvider';
import { FreezeGuard, FractalGuardContracts, FractalNode } from '../../../types';
import Snapshot from '../badges/Snapshot';
import FavoriteIcon from '../icons/FavoriteIcon';
Expand Down Expand Up @@ -42,6 +43,7 @@ export function DAOInfoCard({
action,
readOnly: { user },
} = useFractal();
const { addressPrefix } = useNetworkConfig();
// for non Fractal Safes
const { displayName } = useDisplayName(node?.daoAddress);

Expand Down Expand Up @@ -77,7 +79,7 @@ export function DAOInfoCard({
<Link
as={RouterLink}
pointerEvents={isCurrentDAO ? 'none' : undefined}
to={DAO_ROUTES.dao.relative(displayedAddress)}
to={DAO_ROUTES.dao.relative(addressPrefix, displayedAddress)}
_hover={{ textDecoration: 'none' }}
onClick={() => {
// if we're not on the current DAO, reset
Expand All @@ -104,7 +106,7 @@ export function DAOInfoCard({
/>
{childCount && childCount > 0 && (
<Link
to={DAO_ROUTES.hierarchy.relative(displayedAddress)}
to={DAO_ROUTES.hierarchy.relative(addressPrefix, displayedAddress)}
as={RouterLink}
>
<Box
Expand Down
16 changes: 8 additions & 8 deletions src/components/ui/menus/DAOSearch/SearchDisplay.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ import { useNavigate } from 'react-router-dom';
import { DAO_ROUTES } from '../../../../constants/routes';
import useDisplayName from '../../../../hooks/utils/useDisplayName';
import { useFractal } from '../../../../providers/App/AppProvider';
import { useNetworkConfig } from '../../../../providers/NetworkConfig/NetworkConfigProvider';

interface ISearchDisplay {
loading?: boolean;
Expand All @@ -30,6 +31,7 @@ export function SearchDisplay({
}: ISearchDisplay) {
const { t } = useTranslation(['common', 'dashboard']);
const { action, node } = useFractal();
const { addressPrefix } = useNetworkConfig();
const navigate = useNavigate();
const isCurrentSafe = useMemo(() => {
return !!node && !!node.daoAddress && node.daoAddress === address;
Expand All @@ -52,14 +54,6 @@ export function SearchDisplay({
return (
<Flex
py={2}
onClick={() => {
if (!isCurrentSafe) {
onClickView();
if (closeDrawer) closeDrawer();
action.resetDAO();
navigate(DAO_ROUTES.dao.relative(address));
}
}}
cursor={isCurrentSafe ? 'not-allowed' : 'default'}
justifyContent="space-between"
>
Expand All @@ -81,6 +75,12 @@ export function SearchDisplay({
<Button
alignSelf="center"
data-testid="search-viewDAO"
onClick={() => {
onClickView();
if (closeDrawer) closeDrawer();
action.resetDAO();
navigate(DAO_ROUTES.dao.relative(addressPrefix, address));
}}
>
{t('labelViewDAO')}
</Button>
Expand Down
5 changes: 3 additions & 2 deletions src/components/ui/menus/FavoritesMenu/Favorite.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,16 +6,17 @@ import useDAOName from '../../../../hooks/DAO/useDAOName';
import { useFractal } from '../../../../providers/App/AppProvider';

interface IFavorite {
network: string;
address: string;
}
export function Favorite({ address }: IFavorite) {
export function Favorite({ network, address }: IFavorite) {
const { daoRegistryName } = useDAOName({ address });
const { action } = useFractal();
const navigate = useNavigate();

const onClickNav = () => {
action.resetDAO();
navigate(DAO_ROUTES.dao.relative(address));
navigate(DAO_ROUTES.dao.relative(network, address));
};

return (
Expand Down
3 changes: 3 additions & 0 deletions src/components/ui/menus/FavoritesMenu/FavoritesList.tsx
Original file line number Diff line number Diff line change
@@ -1,10 +1,12 @@
import { Box, MenuList } from '@chakra-ui/react';
import { useTranslation } from 'react-i18next';
import { useAccountFavorites } from '../../../../hooks/DAO/loaders/useFavorites';
import { useNetworkConfig } from '../../../../providers/NetworkConfig/NetworkConfigProvider';
import { Favorite } from './Favorite';

export function FavoritesList() {
const { favoritesList } = useAccountFavorites();
const { addressPrefix } = useNetworkConfig();

const { t } = useTranslation('dashboard');
return (
Expand Down Expand Up @@ -45,6 +47,7 @@ export function FavoritesList() {
{favoritesList.map(favorite => (
<Favorite
key={favorite}
network={addressPrefix}
address={favorite}
/>
))}
Expand Down
Loading

0 comments on commit 785eff5

Please sign in to comment.