-
-
Notifications
You must be signed in to change notification settings - Fork 8.7k
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
feat(v1): add 'slugPreprocessor' config option to allow users customize the hash links #3124
Conversation
Deploy preview for docusaurus-2 ready! Built with commit 159c152 |
Hi, I'm not very familiar with v1, but this looks to me like a non-retrocompatible change that is likely to break some existing anchor-based linking on existing v1 sites right? Even if the behavior is currently not ideal, I'm not sure we want to change the anchor slug generation behavior at this point where we try to focus on v2 and help on v1->v2 migrations |
Hi @slorber, there is a lot of issues with React Native website migration to V2 and solving them will require a lot effort and time on our side (I have been talking about the process with @yangshun). So in a meanwhile we decided to fix most urgent issues that our community is reporting with V1. And yes, this change could be seen as a breaking change for some users. |
As discussed on discord, I'd prefer if you provide a solution to this problem that is not a breaking change for all users, particularly when broken links will likely be unnoticed on v1 site upgrades because it will not crash the build. You can use patch-package to provide custom slug behavior on your site, or try to submit an opt-in way to change the anchor links behavior, which would be non-breaking change by default. |
Thanks, this is retrocompatible so it's safe to merge |
released in https://github.com/facebook/docusaurus/releases/tag/v1.14.5 please let me know if this works, as it's my first v1 release 😅 |
@slorber It looks like there was no NPM publish for |
oh sorry! should be better now |
Motivation
Refs facebook/react-native-website#2081
Currently in V1 HTML content from the headers is a part of hash links which in some cases can make the links non-intuitive or obfuscate them for the users.
This PR fixes the reported issue by replacing all the HTML content (tags and text content inside) using RegExp before the header slug generation.
Have you read the Contributing Guidelines on pull requests?
Yes
Test Plan
I have to update the result of two existing test, but the RegExp works well so the
does not strip tags randomly
test do not need the change.I have also tested the changes locally with the
react-native-website
repository.Examples
Link before the changes:
/docs/next/button#nextfocusforward-div-classlabel-androidandroiddivdiv-classlabel-tvtvdiv
Link after the changes:
/docs/next/button#nextfocusforward
Link before the changes:
/docs/next/button#div-classlabel-required-basicrequireddivonpress
Link after the changes:
/docs/next/button#onpress
Related PRs
WIP - I need to check the V1 docs.I was not able to find the information about slug generation or hash links in the V1 docs. Correct me if I have missed something.After the rewrite as a new feature the additional config documentation entry were required so I have updated the documentation page within this PR.