Merge pull request #141 from ethereum/buttons-hover-color
Buttons hover color
This commit is contained in:
commit
a66cffef76
|
@ -29,7 +29,9 @@ export const Header: FC = () => {
|
|||
>
|
||||
<NextLink href={'/'} passHref>
|
||||
<Link _hover={{ textDecoration: 'none' }}>
|
||||
<Text textStyle='header-font' whiteSpace='nowrap'>go-ethereum</Text>
|
||||
<Text textStyle='header-font' whiteSpace='nowrap'>
|
||||
go-ethereum
|
||||
</Text>
|
||||
</Link>
|
||||
</NextLink>
|
||||
</Stack>
|
||||
|
|
|
@ -9,7 +9,7 @@ import {
|
|||
Stack,
|
||||
Text
|
||||
} from '@chakra-ui/react';
|
||||
import { AddIcon, MinusIcon } from '../svgs/'
|
||||
import { AddIcon, MinusIcon } from '../svgs/';
|
||||
import NextLink from 'next/link';
|
||||
import { useRouter } from 'next/router';
|
||||
|
||||
|
@ -27,7 +27,7 @@ export const DocsLinks: FC<Props> = ({ navLinks }) => {
|
|||
return (
|
||||
<Stack border='2px' borderColor='primary'>
|
||||
{navLinks.map(({ id, to, items }, idx) => {
|
||||
const split = to?.split('/')
|
||||
const split = to?.split('/');
|
||||
const isActive = slug && split && split[split.length - 1] === slug[slug.length - 1];
|
||||
return (
|
||||
<Accordion key={id} allowToggle mt='0 !important' defaultIndex={[0]}>
|
||||
|
@ -62,7 +62,7 @@ export const DocsLinks: FC<Props> = ({ navLinks }) => {
|
|||
verticalAlign: '-1.25px',
|
||||
marginInlineEnd: 2,
|
||||
fontSize: 'lg',
|
||||
display: isActive ? 'unset' : 'none',
|
||||
display: isActive ? 'unset' : 'none'
|
||||
}}
|
||||
_groupHover={{ color: 'bg' }}
|
||||
>
|
||||
|
@ -100,4 +100,4 @@ export const DocsLinks: FC<Props> = ({ navLinks }) => {
|
|||
})}
|
||||
</Stack>
|
||||
);
|
||||
}
|
||||
};
|
||||
|
|
|
@ -36,19 +36,19 @@ export const DocumentNav: FC<Props> = ({ content }) => {
|
|||
_hover={{
|
||||
background: 'primary',
|
||||
boxShadow: '0 0 0 6px var(--chakra-colors-primary)',
|
||||
color: 'bg',
|
||||
color: 'bg'
|
||||
}}
|
||||
_focus={{
|
||||
background: 'primary',
|
||||
boxShadow: '0 0 0 6px var(--chakra-colors-primary) !important',
|
||||
color: 'bg',
|
||||
outline: '2px solid var(--chakra-colors-secondary) !important',
|
||||
outlineOffset: '4px',
|
||||
outlineOffset: '4px'
|
||||
}}
|
||||
_active={{
|
||||
background: 'secondary',
|
||||
boxShadow: '0 0 0 6px var(--chakra-colors-secondary)',
|
||||
color: 'bg',
|
||||
color: 'bg'
|
||||
}}
|
||||
>
|
||||
{heading?.title}
|
||||
|
|
|
@ -15,10 +15,15 @@ export const LinksList: FC<LinksListProps> = ({ links }) => {
|
|||
return (
|
||||
<Stack px={4}>
|
||||
{links.map(({ id, to, items }) => {
|
||||
const split = to?.split('/')
|
||||
const split = to?.split('/');
|
||||
const isActive = slug && split && split[split.length - 1] === slug[slug.length - 1];
|
||||
return to ? (
|
||||
<Stack key={id} pb={items ? 6 : 0} _hover={{ background: 'primary', color: 'bg' }} data-group>
|
||||
<Stack
|
||||
key={id}
|
||||
pb={items ? 6 : 0}
|
||||
_hover={{ background: 'primary', color: 'bg' }}
|
||||
data-group
|
||||
>
|
||||
<NextLink href={to} passHref key={id}>
|
||||
<Link textDecoration='none !important'>
|
||||
<Text
|
||||
|
@ -29,12 +34,11 @@ export const LinksList: FC<LinksListProps> = ({ links }) => {
|
|||
verticalAlign: '-1.25px',
|
||||
marginInlineEnd: 2,
|
||||
fontSize: 'lg',
|
||||
display: isActive ? 'unset' : 'none',
|
||||
display: isActive ? 'unset' : 'none'
|
||||
}}
|
||||
_groupHover={{
|
||||
color: 'bg',
|
||||
boxShadow: '0 0 0 var(--chakra-space-2) var(--chakra-colors-primary)',
|
||||
|
||||
boxShadow: '0 0 0 var(--chakra-space-2) var(--chakra-colors-primary)'
|
||||
}}
|
||||
>
|
||||
{id}
|
||||
|
|
|
@ -42,7 +42,7 @@ const MDComponents = {
|
|||
},
|
||||
// headings
|
||||
h1: ({ children }: any) => {
|
||||
const { children: parsedChildren, headingId} = parseHeadingId(children);
|
||||
const { children: parsedChildren, headingId } = parseHeadingId(children);
|
||||
|
||||
return (
|
||||
<Heading as='h1' textAlign='start' mb='5 !important' {...header1} id={headingId}>
|
||||
|
@ -51,16 +51,23 @@ const MDComponents = {
|
|||
);
|
||||
},
|
||||
h2: ({ children }: any) => {
|
||||
const { children: parsedChildren, headingId} = parseHeadingId(children);
|
||||
const { children: parsedChildren, headingId } = parseHeadingId(children);
|
||||
|
||||
return (
|
||||
<Heading as='h2' textAlign='start' mt={{ base: '12 !important' , md: '16 !important'}} mb='4 !important' {...header2} id={headingId}>
|
||||
<Heading
|
||||
as='h2'
|
||||
textAlign='start'
|
||||
mt={{ base: '12 !important', md: '16 !important' }}
|
||||
mb='4 !important'
|
||||
{...header2}
|
||||
id={headingId}
|
||||
>
|
||||
{parsedChildren}
|
||||
</Heading>
|
||||
);
|
||||
},
|
||||
h3: ({ children }: any) => {
|
||||
const { children: parsedChildren, headingId} = parseHeadingId(children);
|
||||
const { children: parsedChildren, headingId } = parseHeadingId(children);
|
||||
return (
|
||||
<Heading as='h3' mt='5 !important' mb='2.5 !important' {...header3} id={headingId}>
|
||||
{parsedChildren}
|
||||
|
@ -68,7 +75,7 @@ const MDComponents = {
|
|||
);
|
||||
},
|
||||
h4: ({ children }: any) => {
|
||||
const { children: parsedChildren, headingId} = parseHeadingId(children);
|
||||
const { children: parsedChildren, headingId } = parseHeadingId(children);
|
||||
|
||||
return (
|
||||
<Heading as='h4' mb='2.5 !important' {...header4} id={headingId}>
|
||||
|
|
|
@ -80,12 +80,17 @@ export const DownloadsHero: FC<DownloadsHero> = ({
|
|||
<Grid templateColumns={{ base: 'repeat(1, 1fr)', md: 'repeat(2, 1fr)' }} gap={4}>
|
||||
{Object.keys(DOWNLOAD_HEADER_BUTTONS).map((key: string) => {
|
||||
const { name, buildURL, Svg, ariaLabel } = DOWNLOAD_HEADER_BUTTONS[key];
|
||||
|
||||
return (
|
||||
<NextLink key={key} href={buildURL} passHref>
|
||||
<Button as='a' variant='downloadsHeader' width={{ base: '100%' }} h={16}>
|
||||
<Button as='a' variant='downloadsHeader' width={{ base: '100%' }} h={16} data-group>
|
||||
<HStack spacing={4}>
|
||||
<Stack alignItems='center'>
|
||||
<Svg aria-label={ariaLabel} maxH='44px' />
|
||||
<Svg
|
||||
aria-label={ariaLabel}
|
||||
maxH='44px'
|
||||
_groupHover={{ color: 'yellow.50' }}
|
||||
/>
|
||||
</Stack>
|
||||
<Box>
|
||||
<Text textStyle='downloads-button-label'>For {name}</Text>
|
||||
|
|
|
@ -37,7 +37,7 @@ export const HomeHero: FC = () => {
|
|||
>
|
||||
<Flex direction='column' alignItems='center' mr={{ md: 6 }}>
|
||||
<NextLink href={DOWNLOADS_PAGE} passHref>
|
||||
<Button variant='primary' as='a' mb={1}>
|
||||
<Button variant='primary' as='a' mb={1} data-group>
|
||||
<Text textStyle='homepage-primary-label'>Download</Text>
|
||||
</Button>
|
||||
</NextLink>
|
||||
|
@ -49,7 +49,7 @@ export const HomeHero: FC = () => {
|
|||
|
||||
<Flex direction='column' alignItems='center'>
|
||||
<NextLink href={DOCS_PAGE} passHref>
|
||||
<Button variant='primary' as='a' mb={1}>
|
||||
<Button variant='primary' as='a' mb={1} data-group>
|
||||
<Text textStyle='homepage-primary-label'>Documentation</Text>
|
||||
</Button>
|
||||
</NextLink>
|
||||
|
|
|
@ -8,9 +8,9 @@ const Icon = createIcon({
|
|||
viewBox: `0 0 ${w} ${h}`,
|
||||
path: (
|
||||
<svg width={w} height={h} fill='none' xmlns='http://www.w3.org/2000/svg'>
|
||||
<g fill="currentColor">
|
||||
<rect height="2" width="20" x="2" y="11"></rect>
|
||||
<rect height="20" width="2" x="11" y="2"></rect>
|
||||
<g fill='currentColor'>
|
||||
<rect height='2' width='20' x='2' y='11'></rect>
|
||||
<rect height='20' width='2' x='11' y='2'></rect>
|
||||
</g>
|
||||
</svg>
|
||||
)
|
||||
|
|
|
@ -8,8 +8,8 @@ const Icon = createIcon({
|
|||
viewBox: `0 0 ${w} ${h}`,
|
||||
path: (
|
||||
<svg width={w} height={h} fill='none' xmlns='http://www.w3.org/2000/svg'>
|
||||
<g fill="currentColor">
|
||||
<rect height="2" width="20" x="2" y="11"></rect>
|
||||
<g fill='currentColor'>
|
||||
<rect height='2' width='20' x='2' y='11'></rect>
|
||||
</g>
|
||||
</svg>
|
||||
)
|
||||
|
|
|
@ -116,7 +116,10 @@ const DocPage: NextPage<Props> = ({ frontmatter, content, navLinks, lastModified
|
|||
</Stack>
|
||||
|
||||
<Flex width='100%' placeContent='space-between' gap={8}>
|
||||
<Box maxW='min(100%, 768px)' sx={{ '*:first-of-type': { marginTop: '0 !important' } }}>
|
||||
<Box
|
||||
maxW='min(100%, 768px)'
|
||||
sx={{ '*:first-of-type': { marginTop: '0 !important' } }}
|
||||
>
|
||||
<ReactMarkdown
|
||||
remarkPlugins={[gfm]}
|
||||
rehypePlugins={[rehypeRaw]}
|
||||
|
|
|
@ -77,7 +77,8 @@ export const textStyles = {
|
|||
fontFamily: 'heading',
|
||||
color: 'bg',
|
||||
fontWeight: 700,
|
||||
textTransform: 'uppercase'
|
||||
textTransform: 'uppercase',
|
||||
_groupHover: { color: 'yellow.50' }
|
||||
},
|
||||
'home-section-link-label': {
|
||||
fontFamily: 'heading',
|
||||
|
@ -124,13 +125,15 @@ export const textStyles = {
|
|||
fontFamily: 'heading',
|
||||
color: 'bg',
|
||||
fontSize: { base: 'md', lg: 'xl' },
|
||||
textTransform: 'uppercase'
|
||||
textTransform: 'uppercase',
|
||||
_groupHover: { color: 'yellow.50' }
|
||||
},
|
||||
'downloads-button-sublabel': {
|
||||
fontFamily: 'heading',
|
||||
color: 'bg',
|
||||
fontSize: { base: 'xs', lg: 'sm' },
|
||||
textTransform: 'uppercase'
|
||||
textTransform: 'uppercase',
|
||||
_groupHover: { color: 'yellow.50' }
|
||||
},
|
||||
'download-tab-label': {
|
||||
fontFamily: 'heading',
|
||||
|
@ -190,7 +193,7 @@ export const textStyles = {
|
|||
fontWeight: 400,
|
||||
fontSize: '13px',
|
||||
lineHeight: 5,
|
||||
letterSpacing: '1%',
|
||||
letterSpacing: '1%'
|
||||
},
|
||||
'note-text': {
|
||||
fontFamily: 'body',
|
||||
|
|
Loading…
Reference in New Issue