summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorcbojar <chris@cbojar.net>2014-04-14 22:44:24 -0400
committercbojar <chris@cbojar.net>2014-04-16 22:51:09 -0400
commit4a541e38e0b67ab251dd40aa74eafd299e9cdcda (patch)
tree00f46735e30ab27d70708f02d5161a8dd182ad44
parent5a1a056c6d163be9bc8f1e62eb10231bc644c210 (diff)
downloadnextcloud-server-4a541e38e0b67ab251dd40aa74eafd299e9cdcda.tar.gz
nextcloud-server-4a541e38e0b67ab251dd40aa74eafd299e9cdcda.zip
Clean up js.js along suggestions from scrutinizer-ci, fixes #8204.
Also used JSHint.com to find a few other issues. -Strict comparisons (===) -Fixed regex escaping errors -Refactored OC.buildQueryString to use jQuery.map -Missing semicolons -Braces around if block Left some of the mixed spaces/tabs as they are for alignment in comments.
-rw-r--r--core/js/js.js46
1 files changed, 20 insertions, 26 deletions
diff --git a/core/js/js.js b/core/js/js.js
index f10c7163092..4a51cfeac50 100644
--- a/core/js/js.js
+++ b/core/js/js.js
@@ -1,7 +1,7 @@
/**
* Disable console output unless DEBUG mode is enabled.
* Add
- * define('DEBUG', true);
+ * define('DEBUG', true);
* To the end of config/config.php to enable debug mode.
* The undefined checks fix the broken ie8 console
*/
@@ -27,9 +27,10 @@ if (oc_debug !== true || typeof console === "undefined" || typeof console.log ==
if (!window.console) {
window.console = {};
}
+ var noOp = function() { };
var methods = ['log', 'debug', 'warn', 'info', 'error', 'assert', 'time', 'timeEnd'];
for (var i = 0; i < methods.length; i++) {
- console[methods[i]] = function () { };
+ console[methods[i]] = noOp;
}
}
@@ -50,9 +51,9 @@ function initL10N(app) {
t.cache[app] = [];
}
}
- if (typeof t.plural_function[app] == 'undefined') {
+ if (typeof t.plural_function[app] === 'undefined') {
t.plural_function[app] = function (n) {
- var p = (n != 1) ? 1 : 0;
+ var p = (n !== 1) ? 1 : 0;
return { 'nplural' : 2, 'plural' : p };
};
@@ -61,14 +62,16 @@ function initL10N(app) {
* https://developer.berlios.de/projects/jsgettext/
* http://cvs.berlios.de/cgi-bin/viewcvs.cgi/jsgettext/jsgettext/lib/Gettext.js
*/
- var pf_re = new RegExp('^(\\s*nplurals\\s*=\\s*[0-9]+\\s*;\\s*plural\\s*=\\s*(?:\\s|[-\\?\\|&=!<>+*/%:;a-zA-Z0-9_\(\)])+)', 'm');
+ var pf_re = new RegExp('^(\\s*nplurals\\s*=\\s*[0-9]+\\s*;\\s*plural\\s*=\\s*(?:\\s|[-\\?\\|&=!<>+*/%:;a-zA-Z0-9_\\(\\)])+)', 'm');
if (pf_re.test(t.plural_form)) {
//ex english: "Plural-Forms: nplurals=2; plural=(n != 1);\n"
//pf = "nplurals=2; plural=(n != 1);";
//ex russian: nplurals=3; plural=(n%10==1 && n%100!=11 ? 0 : n%10>=2 && n%10< =4 && (n%100<10 or n%100>=20) ? 1 : 2)
//pf = "nplurals=3; plural=(n%10==1 && n%100!=11 ? 0 : n%10>=2 && n%10<=4 && (n%100<10 || n%100>=20) ? 1 : 2)";
var pf = t.plural_form;
- if (! /;\s*$/.test(pf)) pf = pf.concat(';');
+ if (! /;\s*$/.test(pf)) {
+ pf = pf.concat(';');
+ }
/* We used to use eval, but it seems IE has issues with it.
* We now use "new Function", though it carries a slightly
* bigger performance hit.
@@ -387,13 +390,13 @@ var OC={
parts = queryString.replace(/\+/g, '%20').split('&');
for (var i = 0; i < parts.length; i++){
// split on first equal sign
- var part = parts[i]
+ var part = parts[i];
pos = part.indexOf('=');
if (pos >= 0) {
components = [
part.substr(0, pos),
part.substr(pos + 1)
- ]
+ ];
}
else {
// key only
@@ -424,25 +427,16 @@ var OC={
* @return string containing a URL query (without question) mark
*/
buildQueryString: function(params) {
- var s = '';
- var first = true;
if (!params) {
- return s;
+ return '';
}
- for (var key in params) {
- var value = params[key];
- if (first) {
- first = false;
- }
- else {
- s += '&';
- }
- s += encodeURIComponent(key);
+ return $.map(params, function(value, key) {
+ var s = encodeURIComponent(key);
if (value !== null && typeof(value) !== 'undefined') {
s += '=' + encodeURIComponent(value);
}
- }
- return s;
+ return s;
+ }).join('&');
},
/**
@@ -461,11 +455,11 @@ var OC={
var props = {scriptName:'settings.php', cache:true};
$.extend(props, args);
var settings = $('#appsettings');
- if(settings.length == 0) {
+ if(settings.length === 0) {
throw { name: 'MissingDOMElement', message: 'There has be be an element with id "appsettings" for the popup to show.' };
}
var popup = $('#appsettings_popup');
- if(popup.length == 0) {
+ if(popup.length === 0) {
$('body').prepend('<div class="popup hidden" id="appsettings_popup"></div>');
popup = $('#appsettings_popup');
popup.addClass(settings.hasClass('topright') ? 'topright' : 'bottomleft');
@@ -524,7 +518,7 @@ var OC={
$menuEl.show();
OC._currentMenu = $menuEl;
OC._currentMenuToggle = $toggle;
- return false
+ return false;
});
},
@@ -959,7 +953,7 @@ function initCore() {
// user menu
$('#settings #expand').keydown(function(event) {
if (event.which === 13 || event.which === 32) {
- $('#expand').click()
+ $('#expand').click();
}
});
$('#settings #expand').click(function(event) {