/** * Service which exposes various utility methods. */ angular.module('quay').factory('UtilService', ['$sanitize', 'markdownConverterFactory', function($sanitize, markdownConverterFactory) { 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 markdownConverterFactory().makeHtml(string || ''); }; utilService.getFirstMarkdownLineAsText = function(commentString, placeholderNeeded) { if (!commentString) { if (placeholderNeeded) { return '

placeholder

'; } 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 textStr = (text || '').toString(); var adjusted = textStr.replace(/&/g, "&") .replace(//g, ">") .replace(/"/g, """) .replace(/'/g, "'"); return adjusted; }; utilService.stringToHTML = function(text) { text = utilService.escapeHtmlString(text); text = text.replace(/\n/g, '
'); 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; }]);