094c94c0fb
This code also checks for an ad blocker, and adjusts the message accordingly. Fixes #184
109 lines
2.5 KiB
JavaScript
109 lines
2.5 KiB
JavaScript
/**
|
||
* Service which exposes various utility methods.
|
||
*/
|
||
angular.module('quay').factory('UtilService', ['$sanitize', function($sanitize) {
|
||
var utilService = {};
|
||
|
||
var adBlockEnabled = null;
|
||
|
||
utilService.isAdBlockEnabled = function(callback) {
|
||
if (adBlockEnabled !== null) {
|
||
callback(adBlockEnabled);
|
||
return;
|
||
}
|
||
|
||
if(typeof blockAdBlock === 'undefined') {
|
||
callback(true);
|
||
return;
|
||
}
|
||
|
||
var bab = new BlockAdBlock({
|
||
checkOnLoad: false,
|
||
resetOnEnd: true
|
||
});
|
||
|
||
bab.onDetected(function() { adBlockEnabled = true; callback(true); });
|
||
bab.onNotDetected(function() { adBlockEnabled = false; callback(false); });
|
||
bab.check();
|
||
};
|
||
|
||
utilService.isEmailAddress = function(val) {
|
||
var emailRegex = /^[a-zA-Z0-9.!#$%&’*+/=?^_`{|}~-]+@[a-zA-Z0-9-]+(?:\.[a-zA-Z0-9-]+)*$/;
|
||
return emailRegex.test(val);
|
||
};
|
||
|
||
utilService.getMarkedDown = function(string) {
|
||
return html = Markdown.getSanitizingConverter().makeHtml(string || '');
|
||
};
|
||
|
||
utilService.getFirstMarkdownLineAsText = function(commentString, placeholderNeeded) {
|
||
if (!commentString) {
|
||
if (placeholderNeeded) {
|
||
return '<p style="visibility:hidden">placeholder</p>';
|
||
}
|
||
return '';
|
||
}
|
||
|
||
var lines = commentString.split('\n');
|
||
var MARKDOWN_CHARS = {
|
||
'#': true,
|
||
'-': true,
|
||
'>': true,
|
||
'`': true
|
||
};
|
||
|
||
for (var i = 0; i < lines.length; ++i) {
|
||
// Skip code lines.
|
||
if (lines[i].indexOf(' ') == 0) {
|
||
continue;
|
||
}
|
||
|
||
// Skip empty lines.
|
||
if ($.trim(lines[i]).length == 0) {
|
||
continue;
|
||
}
|
||
|
||
// Skip control lines.
|
||
if (MARKDOWN_CHARS[$.trim(lines[i])[0]]) {
|
||
continue;
|
||
}
|
||
|
||
return utilService.getMarkedDown(lines[i]);
|
||
}
|
||
|
||
return '';
|
||
};
|
||
|
||
utilService.escapeHtmlString = function(text) {
|
||
var adjusted = text.replace(/&/g, "&")
|
||
.replace(/</g, "<")
|
||
.replace(/>/g, ">")
|
||
.replace(/"/g, """)
|
||
.replace(/'/g, "'");
|
||
|
||
return adjusted;
|
||
};
|
||
|
||
utilService.stringToHTML = function(text) {
|
||
text = utilService.escapeHtmlString(text);
|
||
text = text.replace(/\n/g, '<br>');
|
||
return text;
|
||
};
|
||
|
||
utilService.getRestUrl = function(args) {
|
||
var url = '';
|
||
for (var i = 0; i < arguments.length; ++i) {
|
||
if (i > 0) {
|
||
url += '/';
|
||
}
|
||
url += encodeURI(arguments[i])
|
||
}
|
||
return url;
|
||
};
|
||
|
||
utilService.textToSafeHtml = function(text) {
|
||
return $sanitize(utilService.escapeHtmlString(text));
|
||
};
|
||
|
||
return utilService;
|
||
}]);
|