Customize: Restore ability to add Custom Link nav menu items for jump links and other URLs that were previously allowed.
Simplify regular expression for checking URL validity to just do basic checks to confirm the value looks like a URL. Leave the complete validation to the server-side logic in `WP_Customize_Nav_Menu_Item_Setting::sanitize()` to avoid having to maintain two separate codebases for validating URLs. Props westonruter, SergeyBiryukov for testing. Amends [41697]. See #32816. Fixes #42506 for trunk. git-svn-id: https://develop.svn.wordpress.org/trunk@42153 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
b4c66ad91b
commit
138ffd49a9
@ -537,33 +537,37 @@
|
|||||||
var menuItem,
|
var menuItem,
|
||||||
itemName = $( '#custom-menu-item-name' ),
|
itemName = $( '#custom-menu-item-name' ),
|
||||||
itemUrl = $( '#custom-menu-item-url' ),
|
itemUrl = $( '#custom-menu-item-url' ),
|
||||||
urlRegex,
|
urlRegex;
|
||||||
urlValue;
|
|
||||||
|
|
||||||
if ( ! this.currentMenuControl ) {
|
if ( ! this.currentMenuControl ) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2010-2013 Diego Perini, MIT licensed
|
* Allow URLs including:
|
||||||
* https://gist.github.com/dperini/729294
|
* - http://example.com/
|
||||||
* see also https://mathiasbynens.be/demo/url-regex
|
* - //example.com
|
||||||
* modified to allow protocol-relative URLs
|
* - /directory/
|
||||||
|
* - ?query-param
|
||||||
|
* - #target
|
||||||
|
* - mailto:foo@example.com
|
||||||
|
*
|
||||||
|
* Any further validation will be handled on the server when the setting is attempted to be saved,
|
||||||
|
* so this pattern does not need to be complete.
|
||||||
*/
|
*/
|
||||||
urlRegex = /^(?:(?:(?:https?|ftp):)?\/\/)(?:\S+(?::\S*)?@)?(?:(?!(?:10|127)(?:\.\d{1,3}){3})(?!(?:169\.254|192\.168)(?:\.\d{1,3}){2})(?!172\.(?:1[6-9]|2\d|3[0-1])(?:\.\d{1,3}){2})(?:[1-9]\d?|1\d\d|2[01]\d|22[0-3])(?:\.(?:1?\d{1,2}|2[0-4]\d|25[0-5])){2}(?:\.(?:[1-9]\d?|1\d\d|2[0-4]\d|25[0-4]))|(?:(?:[a-z\u00a1-\uffff0-9]-*)*[a-z\u00a1-\uffff0-9]+)(?:\.(?:[a-z\u00a1-\uffff0-9]-*)*[a-z\u00a1-\uffff0-9]+)*(?:\.(?:[a-z\u00a1-\uffff]{2,})).?)(?::\d{2,5})?(?:[/?#]\S*)?$/i;
|
urlRegex = /^((\w+:)?\/\/\w.*|\w+:(?!\/\/$)|\/|\?|#)/;
|
||||||
|
|
||||||
urlValue = itemUrl.val();
|
|
||||||
if ( '' === itemName.val() ) {
|
if ( '' === itemName.val() ) {
|
||||||
itemName.addClass( 'invalid' );
|
itemName.addClass( 'invalid' );
|
||||||
return;
|
return;
|
||||||
} else if ( '' === urlValue || 'http://' === urlValue || ! ( '/' === urlValue[0] || urlRegex.test( urlValue ) ) ) {
|
} else if ( ! urlRegex.test( itemUrl.val() ) ) {
|
||||||
itemUrl.addClass( 'invalid' );
|
itemUrl.addClass( 'invalid' );
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
menuItem = {
|
menuItem = {
|
||||||
'title': itemName.val(),
|
'title': itemName.val(),
|
||||||
'url': urlValue,
|
'url': itemUrl.val(),
|
||||||
'type': 'custom',
|
'type': 'custom',
|
||||||
'type_label': api.Menus.data.l10n.custom_label,
|
'type_label': api.Menus.data.l10n.custom_label,
|
||||||
'object': 'custom'
|
'object': 'custom'
|
||||||
|
Loading…
Reference in New Issue
Block a user