-
Notifications
You must be signed in to change notification settings - Fork 4.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
Link UI too open as to what it considers a valid URL #38497
Comments
2 cents: the trend I noticed is that links get auto created if the string contains a dot. |
I do not think it is practical to force validation on what users can enter as a URL, there are probably too many edge cases. The ideall path would be to offer the possibility to create a page directly, as mentioned in #38493 |
I think it's fine to update the component so that it treats these as URLS:
We should try to optimise for the most common use cases. It is very uncommon that a user needs to link to http://Example. If a user really needs to do that, they can enter the |
The good news is there already lots of URL validation utilities in the codebase (in the Validation is pretty complicated, and there a lot of edge cases! It's not just urls that have to be supported, but also hrefs like |
Yeh the validation thing is why I think we ended up going for a pretty broad spec. Perhaps what @mrfoxtalbot suggests will help mitigate this issue. |
Was just testing how it works now, looks like the changes previously introduced in #11286 are no longer present. Users can enter any value for an href and not know anything is wrong. I think there should at least be a warning shown for invalid hrefs, especially considering the code is already written and it just need to be reimplemented. Having said that, what's described in the issue here doesn't seem like validation, more about determining user intent. It might be an idea to split this into two two tasks, the first about implementing some loose rules to determine user intent (are they adding a URL? Are they adding an internal link? Is it the name of a page?). The second task would be about showing a warning if the URL or internal link doesn't pass more strict checks (reimplementing #11286 for LinkControl, and hopefully showing a visible error this time as well as the red colored text). |
That's really interesting. Thank you.
Good suggestion.
Yes that's the key thing. So it's less "is this a URL" more "does the user possibly intend that this is a URL" (and similar for Pages...etc). The first step is defining the heuristic and criteria to determine which is which. I'll start looking at that.
Yes and here is where we can provide validation of the any custom links. |
Fixed by #51011 |
What problem does this address?
When the Link UI
<LinkControl>
was created we decided to take a very broad definition as to what is considered a valid URL. Therefore you can type in a simple string with no spaces likeProjects
and (assuming you have no Posts/Pages with that name) the link UI will "detect" it as a URL and show an option below.Unfortunately this is potentially very confusing UX. Indeed I've seen users assuming this means they either:
...even though nothing of the sort is happening. Instead what happens is an anchor tag is created with the
href="Projects"
which is clearly invalid.Why does this happen? Well the rules around what is considered a URL are very broad. This allows strings such as the above to slip through the net.
What is your proposed solution?
I recommend we make the rules around what is considered a valid entry into the Link UI stricter. For example we could require inclusion of any of the follow to be considered a URL:
.somethinghere
using regex). For example.com
or.org
.www.
prefixhttp(s)
prefix.Obviously we'd also need to include other protocols such as
mailto
andtel
and internal links - many of which are already handled.If none of those are matched then we could flag the entry as invalid.
I do think however it would be risky to disable the ability of the user to add it. This is because there is a very wide range of URI formats available and it would be quite hard to accomodate them all. Therefore we should simply flag any entry that appears to be outside of the typical URI a user might enter.
We could display a inline error message and ask the user are they sure they want to insert....etc
The text was updated successfully, but these errors were encountered: