-
Notifications
You must be signed in to change notification settings - Fork 6.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
init: add skip-to-main-content shortcut #7390
base: main
Are you sure you want to change the base?
Conversation
Signed-off-by: Yaten Dhingra <[email protected]>
The latest updates on your projects. Learn more about Vercel for Git ↗︎
|
I think currently on pressing Edit: Sorry, will not ping 👍 |
WOW stop pinging everyone ! we (website team) receive notification when there are changes on repo. |
Signed-off-by: Yaten Dhingra <[email protected]>
Signed-off-by: Yaten Dhingra <[email protected]>
apps/site/components/withNavBar.tsx
Outdated
const handleTabPress = (event: KeyboardEvent<HTMLInputElement>) => { | ||
if (event.key === 'Tab') { | ||
setTabPressed(prev => !prev); | ||
} | ||
}; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That's very wrong, we should not rely on keyboard event, it's arbitrary restrictive. In fact we shouldn't be using JS at all, there's no reason this couldn't be CSS-only
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Got your point, I'll make it CSS-only and remove all the JS 👍
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I've made the change CSS-only, but I've a doubt that what should be the bg-color of the button? I wasn't able to find it in the component. Currently I've set it to black, for testing purposes only!!
Signed-off-by: Yaten Dhingra <[email protected]>
|
||
const toggleCurrentTheme = () => | ||
setTheme(resolvedTheme === 'dark' ? 'light' : 'dark'); | ||
|
||
return ( | ||
<div> | ||
<a className={classNameOnTabPress} href="#main"> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Anchor href is not working, main element is missing the id attribute.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This href won't work as of now, because I just set it randomly to #main
, I wanted to clarify that to what section the user must be directed to on clicking this button?
@@ -16,13 +17,23 @@ const WithNavBar: FC = () => { | |||
const { replace } = useRouter(); | |||
const pathname = usePathname(); | |||
|
|||
const classNameOnTabPress = classNames( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I believe that creating a SkipToContentButton
component would make this cleaner.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
And I feel that WithLayout is a better place to put this component.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should I change classNameOnTabPress
to SkipToContentButton
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
And I feel that WithLayout is a better place to put this component.
All these changes have to be shifted to the withLayout
, am I right?
Description
This PR adds a
skip to main content
button (initially hidden), when the user pressesTab
(for windows), the button is visible and the user can then move directly to the main content of the page.Related Issues
Fixes #7220
Check List
npm run format
to ensure the code follows the style guide.npm run test
to check if all tests are passing.npx turbo build
to check if the website builds without errors.