Global: Add editor eslint & fix issues

This commit is contained in:
Rob Garrison 2018-03-17 15:30:25 -05:00
parent aa113834db
commit 03eeb2e819
134 changed files with 823 additions and 792 deletions

5
.eslintignore Normal file
View File

@ -0,0 +1,5 @@
_test*.js
*.min.js
*mod.js
*.metadata.js
semver.js

31
.eslintrc Normal file
View File

@ -0,0 +1,31 @@
{
"env": {
"browser": true,
"jquery": true
},
"rules": {
"curly": 1,
"dot-location": [2, "property"],
"eqeqeq": 1,
"linebreak-style": [2, "unix"],
"no-else-return": 0,
"no-eval": 2,
"no-octal": 2,
"no-with": 2,
"radix": 2,
"brace-style": 0,
"camelcase": 0,
"indent": 0,
"no-array-constructor": 2,
"quotes": [2, "single", {
"allowTemplateLiterals": true,
"avoidEscape": true
}],
"spaced-comment": 0,
"space-before-blocks": 1,
"keyword-spacing": 1,
"arrow-spacing": 2,
"no-var": 0,
"no-unused-vars": 1
}
}

View File

@ -4,8 +4,6 @@ module.exports = function( grunt ) {
var pkg = grunt.file.readJSON( 'package.json' ),
tasks,
widgetFilePrefix,
widgetFileSuffix,
defaults = {
dependencies : {
@ -428,7 +426,7 @@ module.exports = function( grunt ) {
});
function escapeRegExp(str) {
return str.replace(/[$()*+\-.\/?[\\\]^{|}]/g, "\\$&");
return str.replace(/[$()*+\-.\/?[\\\]^{|}]/g, '\\$&');
}
// update tablesorter.jquery.json file version numbers to match the package.json version

View File

@ -52,7 +52,7 @@
// ],
// [ "header1", "header2", ... "headerN" ] // optional
// ]
ajaxProcessing: function(ajax){ return [ 0, [], null ]; },
ajaxProcessing: function( /* ajax */ ) { return [ 0, [], null ]; },
// output default: '{page}/{totalPages}'
// possible variables: {size}, {page}, {totalPages}, {filteredPages}, {startRow},
@ -424,9 +424,7 @@
c = table.config,
$table = c.$table,
tds = '',
result = p.ajaxProcessing(data, table, xhr) || [ 0, [] ],
hl = $table.find('thead th').length;
result = p.ajaxProcessing(data, table, xhr) || [ 0, [] ];
// Clean up any previous error.
ts.showError( table );
@ -943,7 +941,7 @@
},
init = function(table, settings) {
var t, ctrls, fxn, size, $el,
var t, ctrls, fxn, $el,
c = table.config,
wo = c.widgetOptions,
p = c.pager = $.extend( true, {}, $.tablesorterPager.defaults, settings ),
@ -1187,8 +1185,7 @@
// see #486
ts.showError = function( table, xhr, settings, exception ) {
var $row,
$table = $( table ),
var $table = $( table ),
c = $table[0].config,
wo = c && c.widgetOptions,
errorRow = c.pager && c.pager.cssErrorRow ||
@ -1243,7 +1240,7 @@
}
// allow message to include entire row HTML!
$row = ( /tr\>/.test(message) ? $(message) : $('<tr><td colspan="' + c.columns + '">' + message + '</td></tr>') )
$( /tr\>/.test(message) ? message : '<tr><td colspan="' + c.columns + '">' + message + '</td></tr>' )
.click( function() {
$( this ).remove();
})

View File

@ -5,7 +5,7 @@
/*jshint browser:true, jquery:true, unused:false */
/*global jQuery: false */
;(function($) {
"use strict";
'use strict';
$.tablesorter.addWidget({
id: 'reorder',
@ -22,14 +22,13 @@ $.tablesorter.addWidget({
init: function(table, thisWidget, c, wo) {
var i, timer, $helper, $bar, clickOffset,
lastIndx = -1,
ts = $.tablesorter,
endIndex = -1,
startIndex = -1,
t = wo.reorder_blocked.split(' '),
noReorderLeft = t[0] || 'reorder-block-left',
noReorderLast = t[1] || 'reorder-block-end',
lastOffset = c.$headers.not('.' + noReorderLeft).first(),
offsets = c.$headers.map(function(i){
offsets = c.$headers.map(function() {
var s, $t = $(this);
if ($t.hasClass(noReorderLeft)) {
s = lastOffset;
@ -95,7 +94,7 @@ $.tablesorter.addWidget({
rows = c.$table.find('tr'),
cols;
startIndex = -1; // stop mousemove updates
if ( s > -1 && endIndex > -1 && s != endIndex && s + 1 !== endIndex ) {
if ( s > -1 && endIndex > -1 && s !== endIndex && s + 1 !== endIndex ) {
adj = endIndex !== 0;
if (c.debug) {
console.log( 'Inserting column ' + s + (adj ? ' after' : ' before') + ' column ' + (endIndex - adj ? 1 : 0) );

View File

@ -25,7 +25,7 @@
<script id="js">$(function() {
// NOTE: $.tablesorter.theme.bootstrap is ALREADY INCLUDED in the jquery.tablesorter.widgets.js
// NOTE: $.tablesorter.themes.bootstrap is ALREADY INCLUDED in the jquery.tablesorter.widgets.js
// file for Bootstrap v3.x; it is included here because of class name differences in Bootstrap v2
// for version 2.x (the iconSortAsc & iconSortDesc use different classes)
$.tablesorter.themes.bootstrap = {
@ -297,7 +297,7 @@
<div class="next-up">
<hr />
Next up: <a href="example-widget-resizable.html">Resizable Columns widget &rsaquo;&rsaquo;</a>
Next up: <a href="example-widget-vertical-group.html">Vertical group widget &rsaquo;&rsaquo;</a>
</div>
</div>

View File

@ -25,7 +25,7 @@
<script id="js">$(function() {
// NOTE: $.tablesorter.theme.bootstrap is ALREADY INCLUDED in the jquery.tablesorter.widgets.js
// NOTE: $.tablesorter.themes.bootstrap is ALREADY INCLUDED in the jquery.tablesorter.widgets.js
// file; it is included here to show how you can modify the default classes
$.tablesorter.themes.bootstrap = {
// these classes are added to the table. To see other table classes available,

View File

@ -686,8 +686,7 @@ $(function(){
pager_output: 'Showing {startRow} to {endRow} of {filteredRows} results',
pager_size: 5,
chart_incRows: 'f',
chart_useSelector: true,
chart_hideTable: false
chart_useSelector: true
}
});

View File

@ -764,7 +764,7 @@
},
getParserById : function( name ) {
/*jshint eqeqeq:false */
/*jshint eqeqeq:false */ // eslint-disable-next-line eqeqeq
if ( name == 'false' ) { return false; }
var indx,
len = ts.parsers.length;
@ -2697,7 +2697,7 @@
is : function( str ) {
return ts.regex.isoDate.test( str );
},
format : function( str, table ) {
format : function( str ) {
var date = str ? new Date( str.replace( ts.regex.dash, '/' ) ) : str;
return date instanceof Date && isFinite( date ) ? date.getTime() : str;
},
@ -2740,7 +2740,7 @@
// Jan 01, 2013 12:34:56 PM or 01 Jan 2013
return ts.regex.usLongDateTest1.test( str ) || ts.regex.usLongDateTest2.test( str );
},
format : function( str, table ) {
format : function( str ) {
var date = str ? new Date( str.replace( ts.regex.dateReplace, '$1 $2' ) ) : str;
return date instanceof Date && isFinite( date ) ? date.getTime() : str;
},
@ -2801,7 +2801,7 @@
is : function( str ) {
return ts.regex.timeTest.test( str );
},
format : function( str, table ) {
format : function( str ) {
// isolate time... ignore month, day and year
var temp,
timePart = ( str || '' ).match( ts.regex.timeMatch ),

View File

@ -6,7 +6,7 @@
;( function( $ ) {
'use strict';
var updateServer = function( event, $table, $input ) {
var updateServer = function( /* event, $table, $input */ ) {
// do something here to update your server, if needed
// event = change event object
// $table = jQuery object of the table that was just updated

View File

@ -18,6 +18,7 @@
str = number.toString();
if (
!isNaN( number ) &&
// eslint-disable-next-line eqeqeq
number == val && // jshint ignore:line
val.length !== str.length
) {

View File

@ -53,7 +53,7 @@
address = address.replace( ts.regex.ipv4Extract, t );
}
if (address.indexOf('::') == -1) {
if (address.indexOf('::') === -1) {
// All eight groups are present
fullAddress = address;
} else {
@ -74,7 +74,7 @@
// it's fastest & easiest for tablesorter to sort decimal values (vs hex)
groups[i] = hex ? ('0000' + groups[i]).slice(-4) :
('00000' + (parseInt(groups[i], 16) || 0)).slice(-5);
expandedAddress += ( i != validGroupCount - 1) ? groups[i] + ':' : groups[i];
expandedAddress += ( i !== validGroupCount - 1) ? groups[i] + ':' : groups[i];
}
return expandedAddress;
},

View File

@ -86,7 +86,7 @@
format: function(s) {
var val,
// find roman numerals
roman = $.grep(s.split(/\b/), function(v, i){
roman = $.grep(s.split(/\b/), function(v) {
return validator.test(v) ? v : '';
}).join('').match(matcher),

View File

@ -208,10 +208,12 @@
// hidden input changes may include compare symbols
v = ( typeof v === 'undefined' ? $input.val() : v ).toString().replace(/[<>=]/g, '') || o.value;
var compare = ($.isArray(o.compare) ? $cell.find(compareSelect).val() || o.compare[ o.selected || 0] : o.compare) || '',
// eslint-disable-next-line eqeqeq
t = ' (' + (compare ? compare + v : v == o.min ? o.allText : v) + ')',
searchType = c.$table[0].hasInitialized ? (delayed ? delayed : o.delayed) || '' : true;
$cell.find('input[type=hidden]')
// add equal to the beginning, so we filter exact numbers
// eslint-disable-next-line eqeqeq
.val( ( compare ? compare + v : ( v == o.min ? '' : ( o.exactMatch ? '=' : '' ) + v ) ) )
// ( val == o.min ? '' : val + (o.exactMatch ? '=' : ''))
.trigger( notrigger ? '' : 'search', searchType ).end()
@ -242,6 +244,7 @@
var v = this.value,
compare = ($.isArray(o.compare) ? $cell.find(compareSelect).val() || o.compare[ o.selected || 0] : o.compare) || '';
if (v !== this.lastValue) {
// eslint-disable-next-line eqeqeq
this.lastValue = ( compare ? compare + v : ( v == o.min ? '' : ( o.exactMatch ? '=' : '' ) + v ) );
this.value = this.lastValue;
updateRange( v );

View File

@ -280,6 +280,7 @@
if ( tsfRegex.exact.test( data.iFilter ) ) {
var txt = data.iFilter.replace( tsfRegex.exact, '' ),
filter = tsf.parseFilter( c, txt, data ) || '';
// eslint-disable-next-line eqeqeq
return data.anyMatch ? $.inArray( filter, data.rowArray ) >= 0 : filter == data.iExact;
}
return null;

View File

@ -12,7 +12,7 @@
types : {
number : function(c, $column, txt, num) {
var word, result,
var result,
ascSort = $column.hasClass( ts.css.sortAsc );
if ( num > 1 && txt !== '' ) {
if ( ascSort ) {
@ -43,7 +43,7 @@
letter : function(c, $column, txt, num) {
return txt ? (txt + ' ').substring(0, num) : '';
},
date : function(c, $column, txt, part, group) {
date : function(c, $column, txt, part) {
var year, month,
wo = c.widgetOptions,
time = new Date(txt || '');
@ -203,7 +203,7 @@
return savedGroup;
},
findColumnGroups : function( c, wo, data ) {
var tbodyIndex, norm_rows, $row, rowIndex, end, undef,
var tbodyIndex, norm_rows, rowIndex, end, undef,
hasPager = ts.hasWidget( c.table, 'pager' ),
p = c.pager || {};
data.groupIndex = 0;
@ -259,7 +259,7 @@
event.stopPropagation();
// pressing enter will toggle the group
if (event.type === 'keyup' && event.which !== 13) { return; }
var isCollapsed, $groups, indx,
var isCollapsed, indx,
$this = $(this),
name = $this.find('.group-name').text().toLowerCase() + $this.attr('data-group-index');
// use shift-click to toggle ALL groups
@ -276,7 +276,6 @@
}
// save collapsed groups
if (wo.group_saveGroups && ts.storage) {
$groups = c.$table.find('.group-header');
if (!wo.group_collapsedGroups[wo.group_collapsedGroup]) {
wo.group_collapsedGroups[wo.group_collapsedGroup] = [];
}
@ -347,10 +346,10 @@
init: function(table, thisWidget, c, wo) {
tsg.bindEvents(table, c, wo);
},
format: function(table, c, wo) {
format: function(table) {
tsg.update(table);
},
remove : function(table, c, wo){
remove : function(table, c) {
c.$table
.off('click', 'tr.group-header')
.off('pagerChange.tsgrouping')

View File

@ -52,8 +52,7 @@
format: function (table, c, wo) {
var txt;
c.$headers.each(function() {
var t = this,
$this = $(this),
var $this = $(this),
col = parseInt( $this.attr( 'data-column' ), 10 ),
sortType = wo.headerTitle_type[ col ] || c.parsers[ col ].type || 'text',
sortDirection = $this.hasClass(ts.css.sortAsc) ? 0 : $this.hasClass(ts.css.sortDesc) ? 1 : 2,

View File

@ -51,7 +51,7 @@
$(window).scroll();
}, 1);
},
remove : function( c, wo ) {
remove : function( c ) {
c.$table.off( c.namespace + 'lazyload' );
}
};
@ -200,26 +200,26 @@
var settings = {
threshold : 0,
failure_limit : 0,
event : "scroll",
effect : "show",
event : 'scroll',
effect : 'show',
container : window,
data_attribute : "original",
data_attribute : 'original',
skip_invisible : false,
appear : null,
load : null,
placeholder : ""
placeholder : ''
};
function update() {
var counter = 0;
elements.each(function() {
var $this = $(this);
if (settings.skip_invisible && !$this.is(":visible")) {
if (settings.skip_invisible && !$this.is(':visible')) {
return;
}
if ($.abovethetop(this, settings) || $.leftofbegin(this, settings)) {
/* Nothing. */
} else if (!$.belowthefold(this, settings) && !$.rightoffold(this, settings)) {
$this.trigger("appear");
$this.trigger('appear');
/* if we found an image we'll load, reset the counter */
counter = 0;
} else {
@ -245,7 +245,7 @@
$container = (settings.container === undefined ||
settings.container === window) ? $window : $(settings.container);
/* Fire one scroll event per scroll. Not one scroll event per image. */
if (0 === settings.event.indexOf("scroll")) {
if (0 === settings.event.indexOf('scroll')) {
$container.bind(settings.event, function() {
return update();
});
@ -255,26 +255,26 @@
var $self = $(self);
self.loaded = false;
/* If no src attribute given use data:uri. */
if ($self.attr("src") === undefined || $self.attr("src") === false) {
if ($self.is("img")) {
$self.attr("src", settings.placeholder);
if ($self.attr('src') === undefined || $self.attr('src') === false) {
if ($self.is('img')) {
$self.attr('src', settings.placeholder);
}
}
/* When appear is triggered load original image. */
$self.one("appear", function() {
$self.one('appear', function() {
if (!this.loaded) {
if (settings.appear) {
var elements_left = elements.length;
settings.appear.call(self, elements_left, settings);
}
$("<img />")
.bind("load", function() {
var original = $self.attr("data-" + settings.data_attribute);
$('<img />')
.bind('load', function() {
var original = $self.attr('data-' + settings.data_attribute);
$self.hide();
if ($self.is("img")) {
$self.attr("src", original);
if ($self.is('img')) {
$self.attr('src', original);
} else {
$self.css("background-image", "url('" + original + "')");
$self.css('background-image', 'url("' + original + '")');
}
$self[settings.effect](settings.effect_speed);
self.loaded = true;
@ -288,30 +288,30 @@
settings.load.call(self, elements_left, settings);
}
})
.attr("src", $self.attr("data-" + settings.data_attribute));
.attr('src', $self.attr('data-' + settings.data_attribute));
}
});
/* When wanted event is triggered load original image */
/* by triggering appear. */
if (0 !== settings.event.indexOf("scroll")) {
if (0 !== settings.event.indexOf('scroll')) {
$self.bind(settings.event, function() {
if (!self.loaded) {
$self.trigger("appear");
$self.trigger('appear');
}
});
}
});
/* Check if something appears when window is resized. */
$window.bind("resize", function() {
$window.bind('resize', function() {
update();
});
/* With IOS5 force loading images when navigating with back button. */
/* Non optimal workaround. */
if ((/(?:iphone|ipod|ipad).*os 5/gi).test(navigator.appVersion)) {
$window.bind("pageshow", function(event) {
$window.bind('pageshow', function(event) {
if (event.originalEvent && event.originalEvent.persisted) {
elements.each(function() {
$(this).trigger("appear");
$(this).trigger('appear');
});
}
});
@ -365,17 +365,17 @@
!$.belowthefold(element, settings) && !$.abovethetop(element, settings);
};
/* Custom selectors for your convenience. */
/* Use as $("img:below-the-fold").something() or */
/* $("img").filter(":below-the-fold").something() which is faster */
$.extend($.expr[":"], {
"below-the-fold" : function(a) { return $.belowthefold(a, {threshold : 0}); },
"above-the-top" : function(a) { return !$.belowthefold(a, {threshold : 0}); },
"right-of-screen": function(a) { return $.rightoffold(a, {threshold : 0}); },
"left-of-screen" : function(a) { return !$.rightoffold(a, {threshold : 0}); },
"in-viewport" : function(a) { return $.inviewport(a, {threshold : 0}); },
/* Use as $('img:below-the-fold').something() or */
/* $('img').filter(':below-the-fold').something() which is faster */
$.extend($.expr[':'], {
'below-the-fold' : function(a) { return $.belowthefold(a, {threshold : 0}); },
'above-the-top' : function(a) { return !$.belowthefold(a, {threshold : 0}); },
'right-of-screen': function(a) { return $.rightoffold(a, {threshold : 0}); },
'left-of-screen' : function(a) { return !$.rightoffold(a, {threshold : 0}); },
'in-viewport' : function(a) { return $.inviewport(a, {threshold : 0}); },
/* Maintain BC for couple of versions. */
"above-the-fold" : function(a) { return !$.belowthefold(a, {threshold : 0}); },
"right-of-fold" : function(a) { return $.rightoffold(a, {threshold : 0}); },
"left-of-fold" : function(a) { return !$.rightoffold(a, {threshold : 0}); }
'above-the-fold' : function(a) { return !$.belowthefold(a, {threshold : 0}); },
'right-of-fold' : function(a) { return $.rightoffold(a, {threshold : 0}); },
'left-of-fold' : function(a) { return !$.rightoffold(a, {threshold : 0}); }
});
})(jQuery, window, document);

View File

@ -171,7 +171,6 @@
if ( hasFilter || !$row.hasClass( filtered ) ) {
$cells = $row.children().not( mathIgnore );
cellLen = $cells.length;
// $row.children().each(function(){
for ( cellIndex = 0; cellIndex < cellLen; cellIndex++ ) {
$t = $cells.eq( cellIndex );
col = math.getCellIndex( $t );
@ -221,7 +220,7 @@
recalculate : function(c, wo, init) {
if ( c && ( !wo.math_isUpdating || init ) ) {
var undef, time, mathAttr, $mathCells, indx, len,
var time, mathAttr, $mathCells, indx, len,
changed = false,
filters = {};
if ( c.debug || wo.math_debug ) {
@ -435,7 +434,7 @@
mask = mask.substring( start, index );
// convert any string to number according to formation sign.
val = mask.charAt( 0 ) == '-' ? -val : +val;
val = mask.charAt( 0 ) === '-' ? -val : +val;
isNegative = val < 0 ? val = -val : 0; // process only abs(), and turn on flag.
// search for separator for grp & decimal, anything not digit, not +/- sign, not #.
@ -606,7 +605,7 @@
// complete executed after each fucntion
math_complete : null, // function($cell, wo, result, value, arry) { return result; },
// math_completed called after all math calculations have completed
math_completed: function( config ) {},
math_completed: function( /* config */ ) {},
// order of calculation; 'all' is last
math_priority : [ 'row', 'above', 'below', 'col' ],
// template for or just prepend the mask prefix & suffix with this HTML

View File

@ -164,8 +164,9 @@
headers = output.processRow(c, $this, true, outputJSON);
// all tbody rows - do not include widget added rows (e.g. grouping widget headers)
if ( !$rows )
if ( !$rows ) {
$rows = $el.children('tbody').children('tr').not(c.selectorRemove);
}
// check for a filter callback function first! because
// /^f/.test(function() { console.log('test'); }) is TRUE! (function is converted to a string)
@ -414,7 +415,7 @@
// callback executed when processing completes
// return true to continue download/output
// return false to stop delivery & do something else with the data
output_callback : function(config, data){ return true; },
output_callback : function(/* config, data */) { return true; },
// JSON callback executed when a colspan is encountered in the header
output_callbackJSON : function($cell, txt, cellIndex) { return txt + '(' + (cellIndex) + ')'; },
// the need to modify this for Excel no longer exists

View File

@ -1352,9 +1352,10 @@
}
// allow message to include entire row HTML!
$row = ( /tr\>/.test( message ) ?
$( message ) :
$( '<tr><td colspan="' + c.columns + '">' + message + '</td></tr>' ) )
$( /tr\>/.test( message ) ?
message :
'<tr><td colspan="' + c.columns + '">' + message + '</td></tr>'
)
.click( function() {
$( this ).remove();
})

View File

@ -188,7 +188,7 @@
},
setup : function( c, wo ) {
var tbHt, $hdr, $t, $hCells, $fCells, $tableWrap, events, tmp, detectedWidth,
var tbHt, $hdr, $t, $hCells, $tableWrap, events, tmp, detectedWidth,
$win = $( window ),
tsScroller = ts.scroller,
namespace = c.namespace + 'tsscroller',
@ -228,7 +228,6 @@
// maintain any bindings on the tfoot cells
.append( $t.clone( true ) )
.wrap( '<div class="' + tscss.scrollerFooter + '"/>' );
$fCells = $foot.children( 'tfoot' ).eq( 0 ).children( 'tr' ).children();
}
wo.scroller_$footer = $foot;

View File

@ -237,7 +237,7 @@
var baseUrl = window.location.href.split(hashChar)[0];
// Ensure that there is a leading hash character
var firstChar = newHash[0];
if (firstChar != hashChar) {
if (firstChar !== hashChar) {
newHash = hashChar + newHash;
}
// Update URL in browser

View File

@ -230,7 +230,7 @@
init : function( table, thisWidget, c, wo ) {
ts.sortTbodies.init( c, wo );
},
remove : function( table, c, wo, refreshing ) {
remove : function( table, c, wo ) {
c.$table.unbind( 'sortBegin updateComplete '.split( ' ' ).join( c.namespace + 'sortTbody ' ) );
c.serverSideSorting = wo.sortTbody_original_serverSideSorting;
c.cssInfoBlock = wo.sortTbody_original_cssInfoBlock;

View File

@ -37,7 +37,7 @@
.addClass( wo.zebra[ indx % 2] );
}
function verticalGroup( table, c, wo, init ) {
function verticalGroup( table, c, wo ) {
// -------------------------------------------------------------------------
// loop thru the header row,
// - look for .vertical-group
@ -69,10 +69,8 @@
// - the border-color needs to be the same
//
// ------------------------------------------------------------------------------------------------
var tmp,
zebra_index = -1, // increments at start of loop
var zebra_index = -1, // increments at start of loop
rows = table.tBodies[0].rows,
header = table.tHead.rows,
has_zebra = ts.hasWidget( table, 'zebra'),
is_vertical_group_col = [],
last_row = [];

View File

@ -31,7 +31,7 @@
$.each(wo.view_layouts, function(k, v) {
var classes = wo.view_switcher_class;
if (k == wo.view_layout) {
if (k === wo.view_layout) {
classes += ' active';
}
@ -108,7 +108,7 @@
var $tmpl = $(tmpl);
$.each(data.$row[0].attributes, function(idx, attr) {
if (attr.nodeName == 'class') {
if (attr.nodeName === 'class') {
$tmpl.attr(attr.nodeName, $tmpl.attr(attr.nodeName) + ' ' + attr.nodeValue);
} else {
$tmpl.attr(attr.nodeName, attr.nodeValue);
@ -125,7 +125,7 @@
$(wo.view_container).empty();
},
hideTable: function(c, wo) {
hideTable: function(c) {
tpos = c.$table.css('position');
ttop = c.$table.css('bottom');
tleft = c.$table.css('left');

View File

@ -39,7 +39,8 @@
"url": "git://github.com/Mottie/tablesorter.git"
},
"scripts": {
"authors": "bash testing/authors.sh"
"authors": "bash testing/authors.sh",
"eslint": "eslint --color Gruntfile.js js/jquery.tablesorter.js js/parsers/* js/widgets/*"
},
"npmName": "tablesorter",
"npmFileMap": [