Skip to content

Commit

Permalink
♿️ Use our own skip to content component #2152
Browse files Browse the repository at this point in the history
  • Loading branch information
millianapia committed Mar 4, 2024
1 parent aae7189 commit eaed9ef
Show file tree
Hide file tree
Showing 3 changed files with 32 additions and 19 deletions.
1 change: 1 addition & 0 deletions web/components/src/Heading/Heading.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,7 @@ export const Heading = forwardRef<HTMLDivElement, HeadingProps>(function Heading
) {
return (
<StyledHeading
id="maincontent"
variant={level}
ref={ref}
center={center}
Expand Down
28 changes: 28 additions & 0 deletions web/components/src/Link/ButtonLink.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -43,3 +43,31 @@ export const ButtonLink = forwardRef<HTMLAnchorElement, ButtonLinkProps>(functio
</StyledButtonLink>
)
})

export const StyledSkipLink = styled(ButtonLink)`
user-select: none;
border: 0;
margin: -1px;
padding: 0;
outline: 0;
overflow: hidden;
position: absolute;
clip: rect(0 0 0 0);
&:focus {
clip: auto;
width: auto;
height: auto;
background: white;
border: 1px solid black;
margin: var(--space-medium);
border-radius: 7px;
padding: var(--space-medium);
}
&:hover {
color: var(--button-text-hover);
background-color: var(--button-background-hover);
border-color: var(--button-border-color-hover);
}
`
22 changes: 3 additions & 19 deletions web/pages/_app.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -14,14 +14,13 @@ import useConsentState from '../lib/hooks/useConsentState'
import { loadSiteImproveScript, cleanUpSiteImproveScript } from '../pageComponents/SiteImprove'
import { enableDynatrace, disableDynatrace } from '../pageComponents/Dynatrace'
import { SWRConfig } from 'swr'
import { SkipNavLink, SkipNavContent } from '@chakra-ui/skip-nav'
import styled from 'styled-components'

// import archivedStyles from '@equinor/energyvision-legacy-css'
// import { AppInsightsContext, AppInsightsErrorBoundary } from '@microsoft/applicationinsights-react-js'
// import { reactPlugin } from '../common'
import { PreviewContextProvider } from '../lib/contexts/PreviewContext'
import { defaultLanguage } from '../languages'
import { StyledSkipLink } from '@components'

/**
* TODO:
Expand Down Expand Up @@ -66,19 +65,6 @@ const HandleBoundaryError = (error: Error, info: { componentStack: string }) =>
console.error('ErrorBoundary caught error: ', error, info)
}

const StyledSkipLink = styled(SkipNavLink)`
&:focus {
background: white;
padding: var(--space-medium);
border: 1px solid black;
position: sticky;
border-radius: 7px;
margin: var(--space-medium);
top: 10%;
z-index: 10;
}
`

function MyApp({ Component, pageProps }: CustomAppProps): JSX.Element {
const router = useRouter()
const getLayout = Component.getLayout || ((page: ReactNode): ReactNode => page)
Expand Down Expand Up @@ -133,17 +119,15 @@ function MyApp({ Component, pageProps }: CustomAppProps): JSX.Element {
return (
<SWRConfig>
<ErrorBoundary FallbackComponent={ErrorFallback} onError={HandleBoundaryError}>
<StyledSkipLink>Skip to Content</StyledSkipLink>
<>
<Head>
<meta key="viewport" name="viewport" content="width=device-width, initial-scale=1" />
{GTM_ID && <GoogleTagManagerHead />}
</Head>
<GlobalStyle />
{IS_LIVE && <CookieBot locale={router.locale} />}
<PreviewContextProvider>
<SkipNavContent>{getLayout(<Component {...pageProps} />)}</SkipNavContent>
</PreviewContextProvider>
<StyledSkipLink href="#maincontent">Skip to content</StyledSkipLink>
<PreviewContextProvider>{getLayout(<Component {...pageProps} />)}</PreviewContextProvider>
</>
</ErrorBoundary>
</SWRConfig>
Expand Down

0 comments on commit eaed9ef

Please sign in to comment.