Improve url detection in comments
Signed-off-by: Joas Schilling <coding@schilljs.com>
This commit is contained in:
parent
e8af003b41
commit
f879ea142d
|
@ -21,8 +21,7 @@
|
||||||
* The downside: anything not ascii is excluded. Not sure how common it is in areas using different
|
* The downside: anything not ascii is excluded. Not sure how common it is in areas using different
|
||||||
* alphabets… the upside: fake domains with similar looking characters won't be formatted as links
|
* alphabets… the upside: fake domains with similar looking characters won't be formatted as links
|
||||||
*/
|
*/
|
||||||
urlRegex: /((\s|^)(https?:\/\/|([-A-Z0-9+_])*\.([-A-Z])+)[-A-Z0-9+&@#\/%?=~_|!:,.;()]*[-A-Z0-9+&@#\/%=~_|()])/ig,
|
urlRegex: /(\s|^)(https?:\/\/)?((?:[-A-Z0-9+_]*\.)+[-A-Z]+(?:\/[-A-Z0-9+&@#%?=~_|!:,.;()]*)*)(\s|$)/ig,
|
||||||
protocolRegex: /^https:\/\//,
|
|
||||||
|
|
||||||
plainToRich: function(content) {
|
plainToRich: function(content) {
|
||||||
content = this.formatLinksRich(content);
|
content = this.formatLinksRich(content);
|
||||||
|
@ -35,15 +34,15 @@
|
||||||
},
|
},
|
||||||
|
|
||||||
formatLinksRich: function(content) {
|
formatLinksRich: function(content) {
|
||||||
var self = this;
|
return content.replace(this.urlRegex, function(_, leadingSpace, protocol, url, trailingSpace) {
|
||||||
return content.replace(this.urlRegex, function(url) {
|
var linkText = url;
|
||||||
var hasProtocol = (url.indexOf('https://') !== -1) || (url.indexOf('http://') !== -1);
|
if(!protocol) {
|
||||||
if(!hasProtocol) {
|
protocol = 'https://';
|
||||||
url = 'https://' + url.trim();
|
} else if (protocol === 'http://'){
|
||||||
|
linkText = protocol + url;
|
||||||
}
|
}
|
||||||
|
|
||||||
var linkText = url.replace(self.protocolRegex, '');
|
return leadingSpace + '<a class="external" target="_blank" rel="noopener noreferrer" href="' + protocol + url + '">' + linkText + '</a>' + trailingSpace;
|
||||||
return '<a class="external" target="_blank" rel="noopener noreferrer" href="' + url + '">' + linkText + '</a>';
|
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,50 @@
|
||||||
|
/**
|
||||||
|
* @copyright 2018 Joas Schilling <nickvergessen@owncloud.com>
|
||||||
|
*
|
||||||
|
* This library is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
|
||||||
|
* License as published by the Free Software Foundation; either
|
||||||
|
* version 3 of the License, or any later version.
|
||||||
|
*
|
||||||
|
* This library is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU AFFERO GENERAL PUBLIC LICENSE for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public
|
||||||
|
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
describe('OCP.Comments tests', function() {
|
||||||
|
function dataProvider() {
|
||||||
|
return [
|
||||||
|
{input: 'nextcloud.com', expected: '<a class="external" target="_blank" rel="noopener noreferrer" href="https://nextcloud.com">nextcloud.com</a>'},
|
||||||
|
{input: 'http://nextcloud.com', expected: '<a class="external" target="_blank" rel="noopener noreferrer" href="http://nextcloud.com">http://nextcloud.com</a>'},
|
||||||
|
{input: 'https://nextcloud.com', expected: '<a class="external" target="_blank" rel="noopener noreferrer" href="https://nextcloud.com">nextcloud.com</a>'},
|
||||||
|
{input: 'hi nextcloud.com', expected: 'hi <a class="external" target="_blank" rel="noopener noreferrer" href="https://nextcloud.com">nextcloud.com</a>'},
|
||||||
|
{input: 'hi http://nextcloud.com', expected: 'hi <a class="external" target="_blank" rel="noopener noreferrer" href="http://nextcloud.com">http://nextcloud.com</a>'},
|
||||||
|
{input: 'hi https://nextcloud.com', expected: 'hi <a class="external" target="_blank" rel="noopener noreferrer" href="https://nextcloud.com">nextcloud.com</a>'},
|
||||||
|
{input: 'nextcloud.com foobar', expected: '<a class="external" target="_blank" rel="noopener noreferrer" href="https://nextcloud.com">nextcloud.com</a> foobar'},
|
||||||
|
{input: 'http://nextcloud.com foobar', expected: '<a class="external" target="_blank" rel="noopener noreferrer" href="http://nextcloud.com">http://nextcloud.com</a> foobar'},
|
||||||
|
{input: 'https://nextcloud.com foobar', expected: '<a class="external" target="_blank" rel="noopener noreferrer" href="https://nextcloud.com">nextcloud.com</a> foobar'},
|
||||||
|
{input: 'hi nextcloud.com foobar', expected: 'hi <a class="external" target="_blank" rel="noopener noreferrer" href="https://nextcloud.com">nextcloud.com</a> foobar'},
|
||||||
|
{input: 'hi http://nextcloud.com foobar', expected: 'hi <a class="external" target="_blank" rel="noopener noreferrer" href="http://nextcloud.com">http://nextcloud.com</a> foobar'},
|
||||||
|
{input: 'hi https://nextcloud.com foobar', expected: 'hi <a class="external" target="_blank" rel="noopener noreferrer" href="https://nextcloud.com">nextcloud.com</a> foobar'},
|
||||||
|
{input: 'hi help.nextcloud.com/category/topic foobar', expected: 'hi <a class="external" target="_blank" rel="noopener noreferrer" href="https://help.nextcloud.com/category/topic">help.nextcloud.com/category/topic</a> foobar'},
|
||||||
|
{input: 'hi http://help.nextcloud.com/category/topic foobar', expected: 'hi <a class="external" target="_blank" rel="noopener noreferrer" href="http://help.nextcloud.com/category/topic">http://help.nextcloud.com/category/topic</a> foobar'},
|
||||||
|
{input: 'hi https://help.nextcloud.com/category/topic foobar', expected: 'hi <a class="external" target="_blank" rel="noopener noreferrer" href="https://help.nextcloud.com/category/topic">help.nextcloud.com/category/topic</a> foobar'},
|
||||||
|
{input: 'noreply@nextcloud.com', expected: 'noreply@nextcloud.com'},
|
||||||
|
{input: 'hi noreply@nextcloud.com', expected: 'hi noreply@nextcloud.com'},
|
||||||
|
{input: 'hi <noreply@nextcloud.com>', expected: 'hi <noreply@nextcloud.com>'},
|
||||||
|
{input: 'FirebaseInstanceId.getInstance().deleteInstanceId()', expected: 'FirebaseInstanceId.getInstance().deleteInstanceId()'},
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
it('should parse URLs only', function () {
|
||||||
|
dataProvider().forEach(function(data) {
|
||||||
|
var result = OCP.Comments.plainToRich(data.input);
|
||||||
|
expect(result).toEqual(data.expected);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
Loading…
Reference in New Issue