-
Notifications
You must be signed in to change notification settings - Fork 146
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: add externalLinkPrefixes support #1674
Conversation
✅ Deploy Preview for aquamarine-blini-95325f ready!
To edit notification comments on pull requests, go to your Netlify site configuration. |
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.
Can you write docs about this config and add more unit test for isExternalUrl
function as well as new e2e test for this case with checkDeadLinks
enabled?
@@ -22,7 +20,7 @@ export function checkLinks( | |||
) { | |||
const errorInfos: string[] = []; | |||
links | |||
.filter(link => !IGNORE_REGEXP.test(link)) | |||
.filter(link => !isExternalUrl(link, routeService.externalLinkPrefixes)) |
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.
There are some differences here. #
is missed, #my-anchor
should not be considered as externalUrl but can be ignored in dead links check.
url.startsWith('https://') || | ||
url.startsWith('mailto:') || | ||
url.startsWith('tel:') | ||
/^((https?|mailto|tel):)?\/\//.test(url) || |
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 think this regex is not as same as before, you can see tests failed in CI. And this regex has edge cases like //www.example.com
and for long urls, the performance is not very good for long and complex urls.
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 recommend to keep origin methods to make it more readable and easier to understand for simple checks.
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.
//www.example.com
should not be considered as external?
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 just take an example to show the difference.
Sure, current PR is only basic proposal, I'll update rest part after you agree with this approach. |
@SoonIter Do you have any suggestions for approach to solve this issue? |
Another case is maybe we can support dynamic external link patterns? |
not much, I think |
I'll change to use |
LGTM |
I'd like to close this PR, because I find it would make using https://github.com/search?q=repo%3Aweb-infra-dev%2Frspress%20isExternalUrl&type=code So for external links, we're using a separated component specifically instead now. What do you think? @Timeless0911 @SoonIter |
Good solution. |
Summary
Related Issue
close #1673
Checklist
I'd like to add related tests and document if this proposal is accepted.