484 lines
11 KiB
JavaScript
484 lines
11 KiB
JavaScript
/* global ajaxurl, wpAjax */
|
|
(function($) {
|
|
var fs = {add:'ajaxAdd',del:'ajaxDel',dim:'ajaxDim',process:'process',recolor:'recolor'}, wpList;
|
|
|
|
wpList = {
|
|
settings: {
|
|
url: ajaxurl, type: 'POST',
|
|
response: 'ajax-response',
|
|
|
|
what: '',
|
|
alt: 'alternate', altOffset: 0,
|
|
addColor: null, delColor: null, dimAddColor: null, dimDelColor: null,
|
|
|
|
confirm: null,
|
|
addBefore: null, addAfter: null,
|
|
delBefore: null, delAfter: null,
|
|
dimBefore: null, dimAfter: null
|
|
},
|
|
|
|
nonce: function(e,s) {
|
|
var url = wpAjax.unserialize(e.attr('href'));
|
|
return s.nonce || url._ajax_nonce || $('#' + s.element + ' input[name="_ajax_nonce"]').val() || url._wpnonce || $('#' + s.element + ' input[name="_wpnonce"]').val() || 0;
|
|
},
|
|
|
|
/**
|
|
* Extract list item data from a DOM element.
|
|
*
|
|
* @param {HTMLElement} e The DOM element.
|
|
* @param {string} t
|
|
* @return {array}
|
|
*/
|
|
parseData: function(e,t) {
|
|
var d = [], wpListsData;
|
|
|
|
try {
|
|
wpListsData = $(e).attr('data-wp-lists') || '';
|
|
wpListsData = wpListsData.match(new RegExp(t+':[\\S]+'));
|
|
|
|
if ( wpListsData )
|
|
d = wpListsData[0].split(':');
|
|
} catch(r) {}
|
|
|
|
return d;
|
|
},
|
|
|
|
pre: function(e,s,a) {
|
|
var bg, r;
|
|
|
|
s = $.extend( {}, this.wpList.settings, {
|
|
element: null,
|
|
nonce: 0,
|
|
target: e.get(0)
|
|
}, s || {} );
|
|
|
|
if ( $.isFunction( s.confirm ) ) {
|
|
if ( 'add' != a ) {
|
|
bg = $('#' + s.element).css('backgroundColor');
|
|
$('#' + s.element).css('backgroundColor', '#FF9966');
|
|
}
|
|
r = s.confirm.call(this, e, s, a, bg);
|
|
|
|
if ( 'add' != a )
|
|
$('#' + s.element).css('backgroundColor', bg );
|
|
|
|
if ( !r )
|
|
return false;
|
|
}
|
|
|
|
return s;
|
|
},
|
|
|
|
ajaxAdd: function( e, s ) {
|
|
e = $(e);
|
|
s = s || {};
|
|
var list = this, data = wpList.parseData(e,'add'), es, valid, formData, res, rres;
|
|
|
|
s = wpList.pre.call( list, e, s, 'add' );
|
|
|
|
s.element = data[2] || e.attr( 'id' ) || s.element || null;
|
|
|
|
if ( data[3] )
|
|
s.addColor = '#' + data[3];
|
|
else
|
|
s.addColor = s.addColor || '#FFFF33';
|
|
|
|
if ( !s )
|
|
return false;
|
|
|
|
if ( !e.is('[id="' + s.element + '-submit"]') )
|
|
return !wpList.add.call( list, e, s );
|
|
|
|
if ( !s.element )
|
|
return true;
|
|
|
|
s.action = 'add-' + s.what;
|
|
|
|
s.nonce = wpList.nonce(e,s);
|
|
|
|
es = $('#' + s.element + ' :input').not('[name="_ajax_nonce"], [name="_wpnonce"], [name="action"]');
|
|
valid = wpAjax.validateForm( '#' + s.element );
|
|
|
|
if ( !valid )
|
|
return false;
|
|
|
|
s.data = $.param( $.extend( { _ajax_nonce: s.nonce, action: s.action }, wpAjax.unserialize( data[4] || '' ) ) );
|
|
formData = $.isFunction(es.fieldSerialize) ? es.fieldSerialize() : es.serialize();
|
|
|
|
if ( formData )
|
|
s.data += '&' + formData;
|
|
|
|
if ( $.isFunction(s.addBefore) ) {
|
|
s = s.addBefore( s );
|
|
if ( !s )
|
|
return true;
|
|
}
|
|
|
|
if ( !s.data.match(/_ajax_nonce=[a-f0-9]+/) )
|
|
return true;
|
|
|
|
s.success = function(r) {
|
|
res = wpAjax.parseAjaxResponse(r, s.response, s.element);
|
|
|
|
rres = r;
|
|
|
|
if ( !res || res.errors )
|
|
return false;
|
|
|
|
if ( true === res )
|
|
return true;
|
|
|
|
jQuery.each( res.responses, function() {
|
|
wpList.add.call( list, this.data, $.extend( {}, s, { // this.firstChild.nodevalue
|
|
pos: this.position || 0,
|
|
id: this.id || 0,
|
|
oldId: this.oldId || null
|
|
} ) );
|
|
} );
|
|
|
|
list.wpList.recolor();
|
|
$(list).trigger( 'wpListAddEnd', [ s, list.wpList ] );
|
|
wpList.clear.call(list,'#' + s.element);
|
|
};
|
|
|
|
s.complete = function(x, st) {
|
|
if ( $.isFunction(s.addAfter) ) {
|
|
var _s = $.extend( { xml: x, status: st, parsed: res }, s );
|
|
s.addAfter( rres, _s );
|
|
}
|
|
};
|
|
|
|
$.ajax( s );
|
|
return false;
|
|
},
|
|
|
|
/**
|
|
* Delete an item in the list via AJAX.
|
|
*
|
|
* @param {HTMLElement} e A DOM element containing item data.
|
|
* @param {Object} s
|
|
* @return {boolean}
|
|
*/
|
|
ajaxDel: function( e, s ) {
|
|
e = $(e);
|
|
s = s || {};
|
|
var list = this, data = wpList.parseData(e,'delete'), element, res, rres;
|
|
|
|
s = wpList.pre.call( list, e, s, 'delete' );
|
|
|
|
s.element = data[2] || s.element || null;
|
|
|
|
if ( data[3] )
|
|
s.delColor = '#' + data[3];
|
|
else
|
|
s.delColor = s.delColor || '#faa';
|
|
|
|
if ( !s || !s.element )
|
|
return false;
|
|
|
|
s.action = 'delete-' + s.what;
|
|
|
|
s.nonce = wpList.nonce(e,s);
|
|
|
|
s.data = $.extend(
|
|
{ action: s.action, id: s.element.split('-').pop(), _ajax_nonce: s.nonce },
|
|
wpAjax.unserialize( data[4] || '' )
|
|
);
|
|
|
|
if ( $.isFunction(s.delBefore) ) {
|
|
s = s.delBefore( s, list );
|
|
if ( !s )
|
|
return true;
|
|
}
|
|
|
|
if ( !s.data._ajax_nonce )
|
|
return true;
|
|
|
|
element = $('#' + s.element);
|
|
|
|
if ( 'none' != s.delColor ) {
|
|
element.css( 'backgroundColor', s.delColor ).fadeOut( 350, function(){
|
|
list.wpList.recolor();
|
|
$(list).trigger( 'wpListDelEnd', [ s, list.wpList ] );
|
|
});
|
|
} else {
|
|
list.wpList.recolor();
|
|
$(list).trigger( 'wpListDelEnd', [ s, list.wpList ] );
|
|
}
|
|
|
|
s.success = function(r) {
|
|
res = wpAjax.parseAjaxResponse(r, s.response, s.element);
|
|
rres = r;
|
|
|
|
if ( !res || res.errors ) {
|
|
element.stop().stop().css( 'backgroundColor', '#faa' ).show().queue( function() { list.wpList.recolor(); $(this).dequeue(); } );
|
|
return false;
|
|
}
|
|
};
|
|
|
|
s.complete = function(x, st) {
|
|
if ( $.isFunction(s.delAfter) ) {
|
|
element.queue( function() {
|
|
var _s = $.extend( { xml: x, status: st, parsed: res }, s );
|
|
s.delAfter( rres, _s );
|
|
}).dequeue();
|
|
}
|
|
};
|
|
|
|
$.ajax( s );
|
|
return false;
|
|
},
|
|
|
|
ajaxDim: function( e, s ) {
|
|
if ( $(e).parent().css('display') == 'none' ) // Prevent hidden links from being clicked by hotkeys
|
|
return false;
|
|
|
|
e = $(e);
|
|
s = s || {};
|
|
|
|
var list = this, data = wpList.parseData(e,'dim'), element, isClass, color, dimColor, res, rres;
|
|
|
|
s = wpList.pre.call( list, e, s, 'dim' );
|
|
|
|
s.element = data[2] || s.element || null;
|
|
s.dimClass = data[3] || s.dimClass || null;
|
|
|
|
if ( data[4] )
|
|
s.dimAddColor = '#' + data[4];
|
|
else
|
|
s.dimAddColor = s.dimAddColor || '#FFFF33';
|
|
|
|
if ( data[5] )
|
|
s.dimDelColor = '#' + data[5];
|
|
else
|
|
s.dimDelColor = s.dimDelColor || '#FF3333';
|
|
|
|
if ( !s || !s.element || !s.dimClass )
|
|
return true;
|
|
|
|
s.action = 'dim-' + s.what;
|
|
|
|
s.nonce = wpList.nonce(e,s);
|
|
|
|
s.data = $.extend(
|
|
{ action: s.action, id: s.element.split('-').pop(), dimClass: s.dimClass, _ajax_nonce : s.nonce },
|
|
wpAjax.unserialize( data[6] || '' )
|
|
);
|
|
|
|
if ( $.isFunction(s.dimBefore) ) {
|
|
s = s.dimBefore( s );
|
|
if ( !s )
|
|
return true;
|
|
}
|
|
|
|
element = $('#' + s.element);
|
|
isClass = element.toggleClass(s.dimClass).is('.' + s.dimClass);
|
|
color = wpList.getColor( element );
|
|
element.toggleClass( s.dimClass );
|
|
dimColor = isClass ? s.dimAddColor : s.dimDelColor;
|
|
|
|
if ( 'none' != dimColor ) {
|
|
element
|
|
.animate( { backgroundColor: dimColor }, 'fast' )
|
|
.queue( function() { element.toggleClass(s.dimClass); $(this).dequeue(); } )
|
|
.animate( { backgroundColor: color }, { complete: function() {
|
|
$(this).css( 'backgroundColor', '' );
|
|
$(list).trigger( 'wpListDimEnd', [ s, list.wpList ] );
|
|
}
|
|
});
|
|
} else {
|
|
$(list).trigger( 'wpListDimEnd', [ s, list.wpList ] );
|
|
}
|
|
|
|
if ( !s.data._ajax_nonce )
|
|
return true;
|
|
|
|
s.success = function(r) {
|
|
res = wpAjax.parseAjaxResponse(r, s.response, s.element);
|
|
rres = r;
|
|
|
|
if ( !res || res.errors ) {
|
|
element.stop().stop().css( 'backgroundColor', '#FF3333' )[isClass?'removeClass':'addClass'](s.dimClass).show().queue( function() { list.wpList.recolor(); $(this).dequeue(); } );
|
|
return false;
|
|
}
|
|
};
|
|
|
|
s.complete = function(x, st) {
|
|
if ( $.isFunction(s.dimAfter) ) {
|
|
element.queue( function() {
|
|
var _s = $.extend( { xml: x, status: st, parsed: res }, s );
|
|
s.dimAfter( rres, _s );
|
|
}).dequeue();
|
|
}
|
|
};
|
|
|
|
$.ajax( s );
|
|
return false;
|
|
},
|
|
|
|
getColor: function( el ) {
|
|
var color = jQuery(el).css('backgroundColor');
|
|
|
|
return color || '#ffffff';
|
|
},
|
|
|
|
add: function( e, s ) {
|
|
if ( 'string' == typeof e ) {
|
|
e = $( $.trim( e ) ); // Trim leading whitespaces
|
|
} else {
|
|
e = $( e );
|
|
}
|
|
|
|
var list = $(this), old = false, _s = { pos: 0, id: 0, oldId: null }, ba, ref, color;
|
|
|
|
if ( 'string' == typeof s )
|
|
s = { what: s };
|
|
|
|
s = $.extend(_s, this.wpList.settings, s);
|
|
|
|
if ( !e.length || !s.what )
|
|
return false;
|
|
|
|
if ( s.oldId )
|
|
old = $('#' + s.what + '-' + s.oldId);
|
|
|
|
if ( s.id && ( s.id != s.oldId || !old || !old.length ) )
|
|
$('#' + s.what + '-' + s.id).remove();
|
|
|
|
if ( old && old.length ) {
|
|
old.before(e);
|
|
old.remove();
|
|
} else if ( isNaN(s.pos) ) {
|
|
ba = 'after';
|
|
|
|
if ( '-' == s.pos.substr(0,1) ) {
|
|
s.pos = s.pos.substr(1);
|
|
ba = 'before';
|
|
}
|
|
|
|
ref = list.find( '#' + s.pos );
|
|
|
|
if ( 1 === ref.length )
|
|
ref[ba](e);
|
|
else
|
|
list.append(e);
|
|
|
|
} else if ( 'comment' != s.what || 0 === $('#' + s.element).length ) {
|
|
if ( s.pos < 0 ) {
|
|
list.prepend(e);
|
|
} else {
|
|
list.append(e);
|
|
}
|
|
}
|
|
|
|
if ( s.alt ) {
|
|
if ( ( list.children(':visible').index( e[0] ) + s.altOffset ) % 2 ) { e.removeClass( s.alt ); }
|
|
else { e.addClass( s.alt ); }
|
|
}
|
|
|
|
if ( 'none' != s.addColor ) {
|
|
color = wpList.getColor( e );
|
|
e.css( 'backgroundColor', s.addColor ).animate( { backgroundColor: color }, { complete: function() { $(this).css( 'backgroundColor', '' ); } } );
|
|
}
|
|
list.each( function() { this.wpList.process( e ); } );
|
|
return e;
|
|
},
|
|
|
|
clear: function(e) {
|
|
var list = this, t, tag;
|
|
|
|
e = $(e);
|
|
|
|
if ( list.wpList && e.parents( '#' + list.id ).length )
|
|
return;
|
|
|
|
e.find(':input').each( function() {
|
|
if ( $(this).parents('.form-no-clear').length )
|
|
return;
|
|
|
|
t = this.type.toLowerCase();
|
|
tag = this.tagName.toLowerCase();
|
|
|
|
if ( 'text' == t || 'password' == t || 'textarea' == tag )
|
|
this.value = '';
|
|
else if ( 'checkbox' == t || 'radio' == t )
|
|
this.checked = false;
|
|
else if ( 'select' == tag )
|
|
this.selectedIndex = null;
|
|
});
|
|
},
|
|
|
|
process: function(el) {
|
|
var list = this,
|
|
$el = $(el || document);
|
|
|
|
$el.delegate( 'form[data-wp-lists^="add:' + list.id + ':"]', 'submit', function(){
|
|
return list.wpList.add(this);
|
|
});
|
|
|
|
$el.delegate( 'a[data-wp-lists^="add:' + list.id + ':"], input[data-wp-lists^="add:' + list.id + ':"]', 'click', function(){
|
|
return list.wpList.add(this);
|
|
});
|
|
|
|
$el.delegate( '[data-wp-lists^="delete:' + list.id + ':"]', 'click', function(){
|
|
return list.wpList.del(this);
|
|
});
|
|
|
|
$el.delegate( '[data-wp-lists^="dim:' + list.id + ':"]', 'click', function(){
|
|
return list.wpList.dim(this);
|
|
});
|
|
},
|
|
|
|
recolor: function() {
|
|
var list = this, items, eo;
|
|
|
|
if ( !list.wpList.settings.alt )
|
|
return;
|
|
|
|
items = $('.list-item:visible', list);
|
|
|
|
if ( !items.length )
|
|
items = $(list).children(':visible');
|
|
|
|
eo = [':even',':odd'];
|
|
|
|
if ( list.wpList.settings.altOffset % 2 )
|
|
eo.reverse();
|
|
|
|
items.filter(eo[0]).addClass(list.wpList.settings.alt).end().filter(eo[1]).removeClass(list.wpList.settings.alt);
|
|
},
|
|
|
|
init: function() {
|
|
var lists = this;
|
|
|
|
lists.wpList.process = function(a) {
|
|
lists.each( function() {
|
|
this.wpList.process(a);
|
|
} );
|
|
};
|
|
|
|
lists.wpList.recolor = function() {
|
|
lists.each( function() {
|
|
this.wpList.recolor();
|
|
} );
|
|
};
|
|
}
|
|
};
|
|
|
|
$.fn.wpList = function( settings ) {
|
|
this.each( function() {
|
|
var _this = this;
|
|
|
|
this.wpList = { settings: $.extend( {}, wpList.settings, { what: wpList.parseData(this,'list')[1] || '' }, settings ) };
|
|
$.each( fs, function(i,f) { _this.wpList[i] = function( e, s ) { return wpList[f].call( _this, e, s ); }; } );
|
|
} );
|
|
|
|
wpList.init.call(this);
|
|
|
|
this.wpList.process();
|
|
|
|
return this;
|
|
};
|
|
|
|
})(jQuery);
|