Commit e8191140 authored by tom's avatar tom

review fixes

parent 5dd0d773
<svg width="40" height="40" fill="none" xmlns="http://www.w3.org/2000/svg">
<rect width="10" height="5" x="7" y="7" fill="#48A9A6"/>
<rect width="10" height="5" x="22" y="7" fill="#48A9A6"/>
<rect width="10" height="5" x="7" y="27" fill="#48A9A6"/>
<rect width="10" height="5" x="22" y="27" fill="#48A9A6"/>
<rect width="5" height="10" x="7" y="22" fill="#48A9A6"/>
<rect width="5" height="10" x="27" y="22" fill="#48A9A6"/>
<path fill-rule="evenodd" clip-rule="evenodd" d="M17 7H7v6h10V7Zm16 0H23v6h10V7Zm0 14.5h-6v5h-4v6h10v-11Zm-20 0H7v11h10v-6h-4v-5Z" fill="currentColor"/>
</svg>
\ No newline at end of file
<svg width="40" height="40" fill="none" xmlns="http://www.w3.org/2000/svg">
<path d="M11 21.338c3.264 1.733 6.669 3.547 9.299 4.95l9.223-4.95c-3.34 4.96-6.122 9.091-9.223 13.662-3.107-4.56-6.537-9.593-9.299-13.662Zm.355-1.369 8.954-4.778 8.838 4.743-8.833 4.784-8.96-4.749Zm8.944-6.309L11 18.556 20.258 5l9.264 13.586-9.223-4.926Z" fill="#3AB83A"/>
<path d="m20.299 26.289 9.223-4.951C26.182 26.298 20.299 35 20.299 35v-8.711Zm.01-11.098 8.838 4.743-8.833 4.784-.005-9.527Zm-.01-1.53L20.259 5l9.263 13.586-9.223-4.925Z" fill="#0B8311"/>
<path d="m11.355 19.97 8.955.734 8.838-.765-8.834 4.784-8.959-4.754Z" fill="#0B8311"/>
<path d="m20.31 20.704 8.838-.765-8.833 4.784-.005-4.019Z" fill="#146714"/>
<path d="M11 21.338c3.264 1.733 6.669 3.547 9.299 4.95l9.223-4.95c-3.34 4.96-6.122 9.091-9.223 13.662-3.107-4.56-6.537-9.593-9.299-13.662Zm.355-1.369 8.954-4.778 8.838 4.743-8.833 4.784-8.96-4.749Zm8.944-6.309L11 18.556 20.258 5l9.264 13.586-9.223-4.926Z" fill="currentColor" fill-opacity=".48"/>
<path d="m20.299 26.289 9.223-4.951C26.182 26.298 20.299 35 20.299 35v-8.711Zm.01-11.098 8.838 4.743-8.833 4.784-.005-9.527Zm-.01-1.53L20.259 5l9.263 13.586-9.223-4.925Z" fill="currentColor" fill-opacity=".48"/>
<path d="m11.355 19.97 8.955.734 8.838-.765-8.834 4.784-8.959-4.754Z" fill="currentColor" fill-opacity=".48"/>
<path d="m20.31 20.704 8.838-.765-8.833 4.784-.005-4.019Z" fill="currentColor" fill-opacity=".48"/>
</svg>
\ No newline at end of file
<svg width="40" height="40" fill="none" xmlns="http://www.w3.org/2000/svg">
<g clip-path="url(#a)">
<path d="m20.471 5-.207.683v19.833l.207.2 9.47-5.441L20.472 5Z" fill="#343434"/>
<path d="M20.47 5 11 20.275l9.47 5.442V5Z" fill="#8C8C8C"/>
<path d="m20.47 27.46-.116.138v7.064l.117.331 9.476-12.972-9.476 5.438Z" fill="#3C3C3B"/>
<path d="M20.47 34.993V27.46L11 22.02l9.47 12.973Z" fill="#8C8C8C"/>
<path d="m20.47 25.716 9.471-5.441-9.47-4.184v9.625Z" fill="#141414"/>
<path d="m11 20.275 9.47 5.441V16.09L11 20.275Z" fill="#393939"/>
<g clip-path="url(#ethereum-a)" fill="currentColor" fill-opacity=".48">
<path d="m20.471 5-.207.683v19.833l.207.2 9.47-5.441L20.472 5Z"/>
<path d="M20.47 5 11 20.275l9.47 5.442V5ZM20.47 27.46l-.116.138v7.064l.117.331 9.476-12.972-9.476 5.438Z"/>
<path d="M20.47 34.993V27.46L11 22.02l9.47 12.973ZM20.47 25.716l9.471-5.441-9.47-4.184v9.625ZM11 20.275l9.47 5.441V16.09L11 20.275Z"/>
</g>
<defs>
<clipPath id="a">
<path fill="#fff" transform="translate(11 5)" d="M0 0h18.947v30H0z"/>
<clipPath id="ethereum-a">
<path transform="translate(11 5)" d="M0 0h18.947v30H0z"/>
</clipPath>
</defs>
</svg>
\ No newline at end of file
<svg width="40" height="40" viewBox="0 0 40 40" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<rect x="6" y="5" width="27" height="30" fill="url(#rsk-pattern0)"/>
<defs>
<pattern id="rsk-pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image0_2038_38465" transform="scale(0.0277778 0.025)"/>
</pattern>
<image id="image0_2038_38465" width="85" height="40" xlink:href=""/>
</defs>
</svg>
<svg width="40" height="40" fill="none" xmlns="http://www.w3.org/2000/svg">
<path fill-rule="evenodd" clip-rule="evenodd" d="M19.393 10a2 2 0 1 0-1.835-1.202l.073.125-.01.006A2 2 0 0 0 19.393 10Zm-3-1.979V8a3 3 0 1 1 6 0v.006l5.887 3.399.005-.003a3 3 0 1 1 2.308 5.488v6.22a3 3 0 1 1-2.299 5.493l-5.901 3.41a3 3 0 0 1-6-.013v-.005l-5.888-3.4-.005.003a3 3 0 1 1-2.308-5.488v-6.22a3 3 0 1 1 2.308-5.488l.02.012 5.873-3.393Zm-4.835 4.41 5.196-3.002a3.007 3.007 0 0 0 1.839 1.463v5.027c-.78.25-1.446.88-1.875 1.728l-4.84-2.794a3.006 3.006 0 0 0-.32-2.422Zm4.7 6.682-5.153-2.974a3 3 0 0 1-1.513.802v6.118c.596.12 1.153.42 1.585.876l5.132-2.963a5.282 5.282 0 0 1-.051-1.859Zm.59 3.28-4.943 2.854c.208.8.072 1.646-.355 2.335l5.198 3.001a3.007 3.007 0 0 1 1.845-1.475V23.88c-.705-.226-1.316-.761-1.744-1.489Zm3.245 1.5v-.008c.722-.227 1.348-.779 1.78-1.53l5.008 2.892c-.21.805-.07 1.655.362 2.347l-5.198 3.002a3.006 3.006 0 0 0-1.952-1.514v-5.19Zm2.307-2.965 5.208 3.007a2.998 2.998 0 0 1 1.584-.876v-6.118a3 3 0 0 1-1.512-.802l-5.232 3.02a5.334 5.334 0 0 1-.048 1.769Zm-.399-3.242 4.907-2.834a3.006 3.006 0 0 1 .327-2.434l-5.198-3c-.399.743-1.103 1.299-1.944 1.5v4.997c.798.25 1.477.897 1.908 1.77ZM19.393 30a2 2 0 0 0-1.779 1.084l.007.003-.052.09A2 2 0 1 0 19.392 30Zm8.726-2.892-.009-.016A2 2 0 0 1 29.75 24h.073a2 2 0 1 1-1.704 3.108Zm.002-14.178-.019-.011A2 2 0 0 0 29.75 16h.074a2 2 0 1 0-1.596-3.255l-.107.185ZM8.96 16h.075A1.999 1.999 0 0 0 10 12.268 2 2 0 1 0 8.96 16Zm.074 8h-.072a2 2 0 1 0 .072 0Zm11.75-1.81c.424-.553.715-1.359.715-2.29s-.291-1.737-.716-2.29c-.424-.552-.94-.81-1.434-.81-.495 0-1.01.258-1.435.81-.424.553-.715 1.359-.715 2.29s.29 1.737.715 2.29c.209.27.439.47.678.604V20h1.5v2.802c.244-.133.48-.336.691-.612Z" fill="currentColor"/>
</svg>
\ No newline at end of file
......@@ -12,7 +12,7 @@ interface Props {
const NetworkMenu = ({ isCollapsed }: Props) => {
return (
<Popover trigger="hover" openDelay={ 0 } placement="right-start" gutter={ 22 }>
<Popover openDelay={ 0 } placement="right-start" gutter={ 22 }>
<PopoverTrigger>
<Box display="inline-flex" alignSelf="stretch" alignItems="center">
<Icon
......@@ -20,6 +20,7 @@ const NetworkMenu = ({ isCollapsed }: Props) => {
width="16px"
height="16px"
color={ useColorModeValue('gray.500', 'white') }
_hover={{ color: 'blue.400' }}
marginLeft={ isCollapsed ? '0px' : '27px' }
cursor="pointer"
{ ...getDefaultTransitionProps({ transitionProperty: 'margin' }) }
......
......@@ -5,16 +5,18 @@ import React from 'react';
import type { NetworkLink } from './types';
import checkIcon from 'icons/check.svg';
import placeholderIcon from 'icons/networks/placeholder.svg';
import useColors from '../useColors';
import useColors from './useColors';
interface Props extends NetworkLink {
isActive: boolean;
}
const NetworkMenuLink = ({ name, pathname, icon, iconColor, isActive, isNewUi }: Props) => {
const colors = useColors();
const NetworkMenuLink = ({ name, pathname, icon, isActive, isNewUi }: Props) => {
const href = isNewUi ? pathname : 'https://blockscout.com' + pathname;
const hasIcon = Boolean(icon);
const colors = useColors({ hasIcon });
return (
<Box as="li" listStyleType="none">
......@@ -30,12 +32,17 @@ const NetworkMenuLink = ({ name, pathname, icon, iconColor, isActive, isNewUi }:
borderRadius="base"
color={ isActive ? colors.text.active : colors.text.default }
bgColor={ isActive ? colors.bg.active : colors.bg.default }
_hover={{ color: isActive ? colors.text.active : colors.text.hover }}
_hover={{
color: isActive ? colors.text.active : colors.text.hover,
svg: {
color: isActive ? colors.icon.active : colors.icon.hover,
},
}}
>
<Icon
as={ icon }
as={ hasIcon ? icon : placeholderIcon }
boxSize="40px"
color={ iconColor || 'inherit' }
color={ isActive ? colors.icon.active : colors.icon.default }
/>
<Text
marginLeft={ 3 }
......
import { PopoverContent, PopoverBody, Text, Tabs, TabList, TabPanels, TabPanel, Tab, VStack, useColorModeValue } from '@chakra-ui/react';
import { PopoverContent, PopoverBody, Text, Tabs, TabList, TabPanels, TabPanel, Tab, VStack } from '@chakra-ui/react';
import React from 'react';
import type { NetworkLink } from './types';
......@@ -9,7 +9,6 @@ import ethereumClassicIcon from 'icons/networks/ethereum-classic.svg';
import ethereumIcon from 'icons/networks/ethereum.svg';
import gnosisIcon from 'icons/networks/gnosis.svg';
import poaSokolIcon from 'icons/networks/poa-sokol.svg';
import poaIcon from 'icons/networks/poa.svg';
import rskIcon from 'icons/networks/rsk.svg';
import useBasePath from 'lib/hooks/useBasePath';
......@@ -20,19 +19,16 @@ type PopupTab = 'mainnets' | 'testnets' | 'other';
const TABS: Array<PopupTab> = [ 'mainnets', 'testnets', 'other' ];
const NetworkMenuPopup = () => {
const gnosisChainIconColor = useColorModeValue('black', 'white');
const poaChainIconColor = useColorModeValue('gray.100', 'gray.100');
const basePath = useBasePath();
const LINKS: Record<PopupTab, Array<NetworkLink>> = {
mainnets: [
{ name: 'Gnosis Chain', pathname: '/xdai/mainnet', icon: gnosisIcon, iconColor: gnosisChainIconColor, isNewUi: true },
{ name: 'Optimism on Gnosis Chain', pathname: '/xdai/optimism', icon: gnosisIcon, iconColor: gnosisChainIconColor },
{ name: 'Gnosis Chain', pathname: '/xdai/mainnet', icon: gnosisIcon, isNewUi: true },
{ name: 'Optimism on Gnosis Chain', pathname: '/xdai/optimism', icon: gnosisIcon },
{ name: 'Arbitrum on xDai', pathname: '/xdai/aox', icon: arbitrumIcon },
{ name: 'Ethereum', pathname: '/eth/mainnet', icon: ethereumIcon },
{ name: 'Ethereum Classic', pathname: '/etc/mainnet', icon: ethereumClassicIcon },
{ name: 'POA', pathname: '/poa/core', icon: poaIcon, iconColor: poaChainIconColor },
{ name: 'POA', pathname: '/poa/core' },
{ name: 'RSK', pathname: '/rsk/mainnet', icon: rskIcon },
],
testnets: [
......@@ -41,7 +37,7 @@ const NetworkMenuPopup = () => {
],
other: [
{ name: 'ARTIS Σ1', pathname: '/artis/sigma1', icon: artisIcon },
{ name: 'LUKSO L14', pathname: '/lukso/l14', icon: poaIcon, iconColor: poaChainIconColor },
{ name: 'LUKSO L14', pathname: '/lukso/l14' },
],
};
......
......@@ -3,7 +3,7 @@ import type { FunctionComponent, SVGAttributes } from 'react';
export interface NetworkLink {
pathname: string;
name: string;
icon: FunctionComponent<SVGAttributes<SVGElement>>;
icon?: FunctionComponent<SVGAttributes<SVGElement>>;
iconColor?: string;
isNewUi?: boolean;
}
import { useColorModeValue } from '@chakra-ui/react';
export default function useColors({ hasIcon }: {hasIcon: boolean}) {
const iconDefaultColor = useColorModeValue('blackAlpha.600', 'whiteAlpha.600');
const iconPlaceholderDefaultColor = useColorModeValue('blackAlpha.100', 'whiteAlpha.100');
return {
text: {
'default': useColorModeValue('gray.700', 'gray.400'),
active: useColorModeValue('gray.700', 'gray.50'),
hover: 'blue.400',
},
icon: {
'default': hasIcon ? iconDefaultColor : iconPlaceholderDefaultColor,
active: useColorModeValue('blackAlpha.900', 'whiteAlpha.900'),
hover: 'blue.400',
},
bg: {
'default': 'transparent',
active: useColorModeValue('blue.50', 'gray.800'),
},
border: {
'default': useColorModeValue('gray.200', 'whiteAlpha.200'),
active: useColorModeValue('blue.50', 'gray.800'),
},
};
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment