[ Index ] |
PHP Cross Reference of WordPress |
[Summary view] [Print] [Text view]
1 /** 2 * @output wp-includes/js/wp-lists.js 3 */ 4 5 /* global ajaxurl, wpAjax */ 6 7 /** 8 * @param {jQuery} $ jQuery object. 9 */ 10 ( function( $ ) { 11 var functions = { 12 add: 'ajaxAdd', 13 del: 'ajaxDel', 14 dim: 'ajaxDim', 15 process: 'process', 16 recolor: 'recolor' 17 }, wpList; 18 19 /** 20 * @namespace 21 */ 22 wpList = { 23 24 /** 25 * @member {object} 26 */ 27 settings: { 28 29 /** 30 * URL for Ajax requests. 31 * 32 * @member {string} 33 */ 34 url: ajaxurl, 35 36 /** 37 * The HTTP method to use for Ajax requests. 38 * 39 * @member {string} 40 */ 41 type: 'POST', 42 43 /** 44 * ID of the element the parsed Ajax response will be stored in. 45 * 46 * @member {string} 47 */ 48 response: 'ajax-response', 49 50 /** 51 * The type of list. 52 * 53 * @member {string} 54 */ 55 what: '', 56 57 /** 58 * CSS class name for alternate styling. 59 * 60 * @member {string} 61 */ 62 alt: 'alternate', 63 64 /** 65 * Offset to start alternate styling from. 66 * 67 * @member {number} 68 */ 69 altOffset: 0, 70 71 /** 72 * Color used in animation when adding an element. 73 * 74 * Can be 'none' to disable the animation. 75 * 76 * @member {string} 77 */ 78 addColor: '#ffff33', 79 80 /** 81 * Color used in animation when deleting an element. 82 * 83 * Can be 'none' to disable the animation. 84 * 85 * @member {string} 86 */ 87 delColor: '#faafaa', 88 89 /** 90 * Color used in dim add animation. 91 * 92 * Can be 'none' to disable the animation. 93 * 94 * @member {string} 95 */ 96 dimAddColor: '#ffff33', 97 98 /** 99 * Color used in dim delete animation. 100 * 101 * Can be 'none' to disable the animation. 102 * 103 * @member {string} 104 */ 105 dimDelColor: '#ff3333', 106 107 /** 108 * Callback that's run before a request is made. 109 * 110 * @callback wpList~confirm 111 * @param {object} this 112 * @param {HTMLElement} list The list DOM element. 113 * @param {object} settings Settings for the current list. 114 * @param {string} action The type of action to perform: 'add', 'delete', or 'dim'. 115 * @param {string} backgroundColor Background color of the list's DOM element. 116 * @return {boolean} Whether to proceed with the action or not. 117 */ 118 confirm: null, 119 120 /** 121 * Callback that's run before an item gets added to the list. 122 * 123 * Allows to cancel the request. 124 * 125 * @callback wpList~addBefore 126 * @param {object} settings Settings for the Ajax request. 127 * @return {object|boolean} Settings for the Ajax request or false to abort. 128 */ 129 addBefore: null, 130 131 /** 132 * Callback that's run after an item got added to the list. 133 * 134 * @callback wpList~addAfter 135 * @param {XML} returnedResponse Raw response returned from the server. 136 * @param {object} settings Settings for the Ajax request. 137 * @param {jqXHR} settings.xml jQuery XMLHttpRequest object. 138 * @param {string} settings.status Status of the request: 'success', 'notmodified', 'nocontent', 'error', 139 * 'timeout', 'abort', or 'parsererror'. 140 * @param {object} settings.parsed Parsed response object. 141 */ 142 addAfter: null, 143 144 /** 145 * Callback that's run before an item gets deleted from the list. 146 * 147 * Allows to cancel the request. 148 * 149 * @callback wpList~delBefore 150 * @param {object} settings Settings for the Ajax request. 151 * @param {HTMLElement} list The list DOM element. 152 * @return {object|boolean} Settings for the Ajax request or false to abort. 153 */ 154 delBefore: null, 155 156 /** 157 * Callback that's run after an item got deleted from the list. 158 * 159 * @callback wpList~delAfter 160 * @param {XML} returnedResponse Raw response returned from the server. 161 * @param {object} settings Settings for the Ajax request. 162 * @param {jqXHR} settings.xml jQuery XMLHttpRequest object. 163 * @param {string} settings.status Status of the request: 'success', 'notmodified', 'nocontent', 'error', 164 * 'timeout', 'abort', or 'parsererror'. 165 * @param {object} settings.parsed Parsed response object. 166 */ 167 delAfter: null, 168 169 /** 170 * Callback that's run before an item gets dim'd. 171 * 172 * Allows to cancel the request. 173 * 174 * @callback wpList~dimBefore 175 * @param {object} settings Settings for the Ajax request. 176 * @return {object|boolean} Settings for the Ajax request or false to abort. 177 */ 178 dimBefore: null, 179 180 /** 181 * Callback that's run after an item got dim'd. 182 * 183 * @callback wpList~dimAfter 184 * @param {XML} returnedResponse Raw response returned from the server. 185 * @param {object} settings Settings for the Ajax request. 186 * @param {jqXHR} settings.xml jQuery XMLHttpRequest object. 187 * @param {string} settings.status Status of the request: 'success', 'notmodified', 'nocontent', 'error', 188 * 'timeout', 'abort', or 'parsererror'. 189 * @param {object} settings.parsed Parsed response object. 190 */ 191 dimAfter: null 192 }, 193 194 /** 195 * Finds a nonce. 196 * 197 * 1. Nonce in settings. 198 * 2. `_ajax_nonce` value in element's href attribute. 199 * 3. `_ajax_nonce` input field that is a descendant of element. 200 * 4. `_wpnonce` value in element's href attribute. 201 * 5. `_wpnonce` input field that is a descendant of element. 202 * 6. 0 if none can be found. 203 * 204 * @param {jQuery} element Element that triggered the request. 205 * @param {Object} settings Settings for the Ajax request. 206 * @return {string|number} Nonce 207 */ 208 nonce: function( element, settings ) { 209 var url = wpAjax.unserialize( element.attr( 'href' ) ), 210 $element = $( '#' + settings.element ); 211 212 return settings.nonce || url._ajax_nonce || $element.find( 'input[name="_ajax_nonce"]' ).val() || url._wpnonce || $element.find( 'input[name="_wpnonce"]' ).val() || 0; 213 }, 214 215 /** 216 * Extract list item data from a DOM element. 217 * 218 * Example 1: data-wp-lists="delete:the-comment-list:comment-{comment_ID}:66cc66:unspam=1" 219 * Example 2: data-wp-lists="dim:the-comment-list:comment-{comment_ID}:unapproved:e7e7d3:e7e7d3:new=approved" 220 * 221 * Returns an unassociative array with the following data: 222 * data[0] - Data identifier: 'list', 'add', 'delete', or 'dim'. 223 * data[1] - ID of the corresponding list. If data[0] is 'list', the type of list ('comment', 'category', etc). 224 * data[2] - ID of the parent element of all inputs necessary for the request. 225 * data[3] - Hex color to be used in this request. If data[0] is 'dim', dim class. 226 * data[4] - Additional arguments in query syntax that are added to the request. Example: 'post_id=1234'. 227 * If data[0] is 'dim', dim add color. 228 * data[5] - Only available if data[0] is 'dim', dim delete color. 229 * data[6] - Only available if data[0] is 'dim', additional arguments in query syntax that are added to the request. 230 * 231 * Result for Example 1: 232 * data[0] - delete 233 * data[1] - the-comment-list 234 * data[2] - comment-{comment_ID} 235 * data[3] - 66cc66 236 * data[4] - unspam=1 237 * 238 * @param {HTMLElement} element The DOM element. 239 * @param {string} type The type of data to look for: 'list', 'add', 'delete', or 'dim'. 240 * @return {Array} Extracted list item data. 241 */ 242 parseData: function( element, type ) { 243 var data = [], wpListsData; 244 245 try { 246 wpListsData = $( element ).data( 'wp-lists' ) || ''; 247 wpListsData = wpListsData.match( new RegExp( type + ':[\\S]+' ) ); 248 249 if ( wpListsData ) { 250 data = wpListsData[0].split( ':' ); 251 } 252 } catch ( error ) {} 253 254 return data; 255 }, 256 257 /** 258 * Calls a confirm callback to verify the action that is about to be performed. 259 * 260 * @param {HTMLElement} list The DOM element. 261 * @param {Object} settings Settings for this list. 262 * @param {string} action The type of action to perform: 'add', 'delete', or 'dim'. 263 * @return {Object|boolean} Settings if confirmed, false if not. 264 */ 265 pre: function( list, settings, action ) { 266 var $element, backgroundColor, confirmed; 267 268 settings = $.extend( {}, this.wpList.settings, { 269 element: null, 270 nonce: 0, 271 target: list.get( 0 ) 272 }, settings || {} ); 273 274 if ( typeof settings.confirm === 'function' ) { 275 $element = $( '#' + settings.element ); 276 277 if ( 'add' !== action ) { 278 backgroundColor = $element.css( 'backgroundColor' ); 279 $element.css( 'backgroundColor', '#ff9966' ); 280 } 281 282 confirmed = settings.confirm.call( this, list, settings, action, backgroundColor ); 283 284 if ( 'add' !== action ) { 285 $element.css( 'backgroundColor', backgroundColor ); 286 } 287 288 if ( ! confirmed ) { 289 return false; 290 } 291 } 292 293 return settings; 294 }, 295 296 /** 297 * Adds an item to the list via Ajax. 298 * 299 * @param {HTMLElement} element The DOM element. 300 * @param {Object} settings Settings for this list. 301 * @return {boolean} Whether the item was added. 302 */ 303 ajaxAdd: function( element, settings ) { 304 var list = this, 305 $element = $( element ), 306 data = wpList.parseData( $element, 'add' ), 307 formValues, formData, parsedResponse, returnedResponse; 308 309 settings = settings || {}; 310 settings = wpList.pre.call( list, $element, settings, 'add' ); 311 312 settings.element = data[2] || $element.prop( 'id' ) || settings.element || null; 313 settings.addColor = data[3] ? '#' + data[3] : settings.addColor; 314 315 if ( ! settings ) { 316 return false; 317 } 318 319 if ( ! $element.is( '[id="' + settings.element + '-submit"]' ) ) { 320 return ! wpList.add.call( list, $element, settings ); 321 } 322 323 if ( ! settings.element ) { 324 return true; 325 } 326 327 settings.action = 'add-' + settings.what; 328 settings.nonce = wpList.nonce( $element, settings ); 329 330 if ( ! wpAjax.validateForm( '#' + settings.element ) ) { 331 return false; 332 } 333 334 settings.data = $.param( $.extend( { 335 _ajax_nonce: settings.nonce, 336 action: settings.action 337 }, wpAjax.unserialize( data[4] || '' ) ) ); 338 339 formValues = $( '#' + settings.element + ' :input' ).not( '[name="_ajax_nonce"], [name="_wpnonce"], [name="action"]' ); 340 formData = typeof formValues.fieldSerialize === 'function' ? formValues.fieldSerialize() : formValues.serialize(); 341 342 if ( formData ) { 343 settings.data += '&' + formData; 344 } 345 346 if ( typeof settings.addBefore === 'function' ) { 347 settings = settings.addBefore( settings ); 348 349 if ( ! settings ) { 350 return true; 351 } 352 } 353 354 if ( ! settings.data.match( /_ajax_nonce=[a-f0-9]+/ ) ) { 355 return true; 356 } 357 358 settings.success = function( response ) { 359 parsedResponse = wpAjax.parseAjaxResponse( response, settings.response, settings.element ); 360 returnedResponse = response; 361 362 if ( ! parsedResponse || parsedResponse.errors ) { 363 return false; 364 } 365 366 if ( true === parsedResponse ) { 367 return true; 368 } 369 370 $.each( parsedResponse.responses, function() { 371 wpList.add.call( list, this.data, $.extend( {}, settings, { // this.firstChild.nodevalue 372 position: this.position || 0, 373 id: this.id || 0, 374 oldId: this.oldId || null 375 } ) ); 376 } ); 377 378 list.wpList.recolor(); 379 $( list ).trigger( 'wpListAddEnd', [ settings, list.wpList ] ); 380 wpList.clear.call( list, '#' + settings.element ); 381 }; 382 383 settings.complete = function( jqXHR, status ) { 384 if ( typeof settings.addAfter === 'function' ) { 385 settings.addAfter( returnedResponse, $.extend( { 386 xml: jqXHR, 387 status: status, 388 parsed: parsedResponse 389 }, settings ) ); 390 } 391 }; 392 393 $.ajax( settings ); 394 395 return false; 396 }, 397 398 /** 399 * Delete an item in the list via Ajax. 400 * 401 * @param {HTMLElement} element A DOM element containing item data. 402 * @param {Object} settings Settings for this list. 403 * @return {boolean} Whether the item was deleted. 404 */ 405 ajaxDel: function( element, settings ) { 406 var list = this, 407 $element = $( element ), 408 data = wpList.parseData( $element, 'delete' ), 409 $eventTarget, parsedResponse, returnedResponse; 410 411 settings = settings || {}; 412 settings = wpList.pre.call( list, $element, settings, 'delete' ); 413 414 settings.element = data[2] || settings.element || null; 415 settings.delColor = data[3] ? '#' + data[3] : settings.delColor; 416 417 if ( ! settings || ! settings.element ) { 418 return false; 419 } 420 421 settings.action = 'delete-' + settings.what; 422 settings.nonce = wpList.nonce( $element, settings ); 423 424 settings.data = $.extend( { 425 _ajax_nonce: settings.nonce, 426 action: settings.action, 427 id: settings.element.split( '-' ).pop() 428 }, wpAjax.unserialize( data[4] || '' ) ); 429 430 if ( typeof settings.delBefore === 'function' ) { 431 settings = settings.delBefore( settings, list ); 432 433 if ( ! settings ) { 434 return true; 435 } 436 } 437 438 if ( ! settings.data._ajax_nonce ) { 439 return true; 440 } 441 442 $eventTarget = $( '#' + settings.element ); 443 444 if ( 'none' !== settings.delColor ) { 445 $eventTarget.css( 'backgroundColor', settings.delColor ).fadeOut( 350, function() { 446 list.wpList.recolor(); 447 $( list ).trigger( 'wpListDelEnd', [ settings, list.wpList ] ); 448 } ); 449 } else { 450 list.wpList.recolor(); 451 $( list ).trigger( 'wpListDelEnd', [ settings, list.wpList ] ); 452 } 453 454 settings.success = function( response ) { 455 parsedResponse = wpAjax.parseAjaxResponse( response, settings.response, settings.element ); 456 returnedResponse = response; 457 458 if ( ! parsedResponse || parsedResponse.errors ) { 459 $eventTarget.stop().stop().css( 'backgroundColor', '#faa' ).show().queue( function() { 460 list.wpList.recolor(); 461 $( this ).dequeue(); 462 } ); 463 464 return false; 465 } 466 }; 467 468 settings.complete = function( jqXHR, status ) { 469 if ( typeof settings.delAfter === 'function' ) { 470 $eventTarget.queue( function() { 471 settings.delAfter( returnedResponse, $.extend( { 472 xml: jqXHR, 473 status: status, 474 parsed: parsedResponse 475 }, settings ) ); 476 } ).dequeue(); 477 } 478 }; 479 480 $.ajax( settings ); 481 482 return false; 483 }, 484 485 /** 486 * Dim an item in the list via Ajax. 487 * 488 * @param {HTMLElement} element A DOM element containing item data. 489 * @param {Object} settings Settings for this list. 490 * @return {boolean} Whether the item was dim'ed. 491 */ 492 ajaxDim: function( element, settings ) { 493 var list = this, 494 $element = $( element ), 495 data = wpList.parseData( $element, 'dim' ), 496 $eventTarget, isClass, color, dimColor, parsedResponse, returnedResponse; 497 498 // Prevent hidden links from being clicked by hotkeys. 499 if ( 'none' === $element.parent().css( 'display' ) ) { 500 return false; 501 } 502 503 settings = settings || {}; 504 settings = wpList.pre.call( list, $element, settings, 'dim' ); 505 506 settings.element = data[2] || settings.element || null; 507 settings.dimClass = data[3] || settings.dimClass || null; 508 settings.dimAddColor = data[4] ? '#' + data[4] : settings.dimAddColor; 509 settings.dimDelColor = data[5] ? '#' + data[5] : settings.dimDelColor; 510 511 if ( ! settings || ! settings.element || ! settings.dimClass ) { 512 return true; 513 } 514 515 settings.action = 'dim-' + settings.what; 516 settings.nonce = wpList.nonce( $element, settings ); 517 518 settings.data = $.extend( { 519 _ajax_nonce: settings.nonce, 520 action: settings.action, 521 id: settings.element.split( '-' ).pop(), 522 dimClass: settings.dimClass 523 }, wpAjax.unserialize( data[6] || '' ) ); 524 525 if ( typeof settings.dimBefore === 'function' ) { 526 settings = settings.dimBefore( settings ); 527 528 if ( ! settings ) { 529 return true; 530 } 531 } 532 533 $eventTarget = $( '#' + settings.element ); 534 isClass = $eventTarget.toggleClass( settings.dimClass ).is( '.' + settings.dimClass ); 535 color = wpList.getColor( $eventTarget ); 536 dimColor = isClass ? settings.dimAddColor : settings.dimDelColor; 537 $eventTarget.toggleClass( settings.dimClass ); 538 539 if ( 'none' !== dimColor ) { 540 $eventTarget 541 .animate( { backgroundColor: dimColor }, 'fast' ) 542 .queue( function() { 543 $eventTarget.toggleClass( settings.dimClass ); 544 $( this ).dequeue(); 545 } ) 546 .animate( { backgroundColor: color }, { 547 complete: function() { 548 $( this ).css( 'backgroundColor', '' ); 549 $( list ).trigger( 'wpListDimEnd', [ settings, list.wpList ] ); 550 } 551 } ); 552 } else { 553 $( list ).trigger( 'wpListDimEnd', [ settings, list.wpList ] ); 554 } 555 556 if ( ! settings.data._ajax_nonce ) { 557 return true; 558 } 559 560 settings.success = function( response ) { 561 parsedResponse = wpAjax.parseAjaxResponse( response, settings.response, settings.element ); 562 returnedResponse = response; 563 564 if ( true === parsedResponse ) { 565 return true; 566 } 567 568 if ( ! parsedResponse || parsedResponse.errors ) { 569 $eventTarget.stop().stop().css( 'backgroundColor', '#ff3333' )[isClass ? 'removeClass' : 'addClass']( settings.dimClass ).show().queue( function() { 570 list.wpList.recolor(); 571 $( this ).dequeue(); 572 } ); 573 574 return false; 575 } 576 577 /** @property {string} comment_link Link of the comment to be dimmed. */ 578 if ( 'undefined' !== typeof parsedResponse.responses[0].supplemental.comment_link ) { 579 var $submittedOn = $element.find( '.submitted-on' ), 580 $commentLink = $submittedOn.find( 'a' ); 581 582 // Comment is approved; link the date field. 583 if ( '' !== parsedResponse.responses[0].supplemental.comment_link ) { 584 $submittedOn.html( $('<a></a>').text( $submittedOn.text() ).prop( 'href', parsedResponse.responses[0].supplemental.comment_link ) ); 585 586 // Comment is not approved; unlink the date field. 587 } else if ( $commentLink.length ) { 588 $submittedOn.text( $commentLink.text() ); 589 } 590 } 591 }; 592 593 settings.complete = function( jqXHR, status ) { 594 if ( typeof settings.dimAfter === 'function' ) { 595 $eventTarget.queue( function() { 596 settings.dimAfter( returnedResponse, $.extend( { 597 xml: jqXHR, 598 status: status, 599 parsed: parsedResponse 600 }, settings ) ); 601 } ).dequeue(); 602 } 603 }; 604 605 $.ajax( settings ); 606 607 return false; 608 }, 609 610 /** 611 * Returns the background color of the passed element. 612 * 613 * @param {jQuery|string} element Element to check. 614 * @return {string} Background color value in HEX. Default: '#ffffff'. 615 */ 616 getColor: function( element ) { 617 return $( element ).css( 'backgroundColor' ) || '#ffffff'; 618 }, 619 620 /** 621 * Adds something. 622 * 623 * @param {HTMLElement} element A DOM element containing item data. 624 * @param {Object} settings Settings for this list. 625 * @return {boolean} Whether the item was added. 626 */ 627 add: function( element, settings ) { 628 var $list = $( this ), 629 $element = $( element ), 630 old = false, 631 position, reference; 632 633 if ( 'string' === typeof settings ) { 634 settings = { what: settings }; 635 } 636 637 settings = $.extend( { position: 0, id: 0, oldId: null }, this.wpList.settings, settings ); 638 639 if ( ! $element.length || ! settings.what ) { 640 return false; 641 } 642 643 if ( settings.oldId ) { 644 old = $( '#' + settings.what + '-' + settings.oldId ); 645 } 646 647 if ( settings.id && ( settings.id !== settings.oldId || ! old || ! old.length ) ) { 648 $( '#' + settings.what + '-' + settings.id ).remove(); 649 } 650 651 if ( old && old.length ) { 652 old.before( $element ); 653 old.remove(); 654 655 } else if ( isNaN( settings.position ) ) { 656 position = 'after'; 657 658 if ( '-' === settings.position.substr( 0, 1 ) ) { 659 settings.position = settings.position.substr( 1 ); 660 position = 'before'; 661 } 662 663 reference = $list.find( '#' + settings.position ); 664 665 if ( 1 === reference.length ) { 666 reference[position]( $element ); 667 } else { 668 $list.append( $element ); 669 } 670 671 } else if ( 'comment' !== settings.what || 0 === $( '#' + settings.element ).length ) { 672 if ( settings.position < 0 ) { 673 $list.prepend( $element ); 674 } else { 675 $list.append( $element ); 676 } 677 } 678 679 if ( settings.alt ) { 680 $element.toggleClass( settings.alt, ( $list.children( ':visible' ).index( $element[0] ) + settings.altOffset ) % 2 ); 681 } 682 683 if ( 'none' !== settings.addColor ) { 684 $element.css( 'backgroundColor', settings.addColor ).animate( { backgroundColor: wpList.getColor( $element ) }, { 685 complete: function() { 686 $( this ).css( 'backgroundColor', '' ); 687 } 688 } ); 689 } 690 691 // Add event handlers. 692 $list.each( function( index, list ) { 693 list.wpList.process( $element ); 694 } ); 695 696 return $element; 697 }, 698 699 /** 700 * Clears all input fields within the element passed. 701 * 702 * @param {string} elementId ID of the element to check, including leading #. 703 */ 704 clear: function( elementId ) { 705 var list = this, 706 $element = $( elementId ), 707 type, tagName; 708 709 // Bail if we're within the list. 710 if ( list.wpList && $element.parents( '#' + list.id ).length ) { 711 return; 712 } 713 714 // Check each input field. 715 $element.find( ':input' ).each( function( index, input ) { 716 717 // Bail if the form was marked to not to be cleared. 718 if ( $( input ).parents( '.form-no-clear' ).length ) { 719 return; 720 } 721 722 type = input.type.toLowerCase(); 723 tagName = input.tagName.toLowerCase(); 724 725 if ( 'text' === type || 'password' === type || 'textarea' === tagName ) { 726 input.value = ''; 727 728 } else if ( 'checkbox' === type || 'radio' === type ) { 729 input.checked = false; 730 731 } else if ( 'select' === tagName ) { 732 input.selectedIndex = null; 733 } 734 } ); 735 }, 736 737 /** 738 * Registers event handlers to add, delete, and dim items. 739 * 740 * @param {string} elementId 741 */ 742 process: function( elementId ) { 743 var list = this, 744 $element = $( elementId || document ); 745 746 $element.on( 'submit', 'form[data-wp-lists^="add:' + list.id + ':"]', function() { 747 return list.wpList.add( this ); 748 } ); 749 750 $element.on( 'click', 'a[data-wp-lists^="add:' + list.id + ':"], input[data-wp-lists^="add:' + list.id + ':"]', function() { 751 return list.wpList.add( this ); 752 } ); 753 754 $element.on( 'click', '[data-wp-lists^="delete:' + list.id + ':"]', function() { 755 return list.wpList.del( this ); 756 } ); 757 758 $element.on( 'click', '[data-wp-lists^="dim:' + list.id + ':"]', function() { 759 return list.wpList.dim( this ); 760 } ); 761 }, 762 763 /** 764 * Updates list item background colors. 765 */ 766 recolor: function() { 767 var list = this, 768 evenOdd = [':even', ':odd'], 769 items; 770 771 // Bail if there is no alternate class name specified. 772 if ( ! list.wpList.settings.alt ) { 773 return; 774 } 775 776 items = $( '.list-item:visible', list ); 777 778 if ( ! items.length ) { 779 items = $( list ).children( ':visible' ); 780 } 781 782 if ( list.wpList.settings.altOffset % 2 ) { 783 evenOdd.reverse(); 784 } 785 786 items.filter( evenOdd[0] ).addClass( list.wpList.settings.alt ).end(); 787 items.filter( evenOdd[1] ).removeClass( list.wpList.settings.alt ); 788 }, 789 790 /** 791 * Sets up `process()` and `recolor()` functions. 792 */ 793 init: function() { 794 var $list = this; 795 796 $list.wpList.process = function( element ) { 797 $list.each( function() { 798 this.wpList.process( element ); 799 } ); 800 }; 801 802 $list.wpList.recolor = function() { 803 $list.each( function() { 804 this.wpList.recolor(); 805 } ); 806 }; 807 } 808 }; 809 810 /** 811 * Initializes wpList object. 812 * 813 * @param {Object} settings 814 * @param {string} settings.url URL for ajax calls. Default: ajaxurl. 815 * @param {string} settings.type The HTTP method to use for Ajax requests. Default: 'POST'. 816 * @param {string} settings.response ID of the element the parsed ajax response will be stored in. 817 * Default: 'ajax-response'. 818 * 819 * @param {string} settings.what Default: ''. 820 * @param {string} settings.alt CSS class name for alternate styling. Default: 'alternate'. 821 * @param {number} settings.altOffset Offset to start alternate styling from. Default: 0. 822 * @param {string} settings.addColor Hex code or 'none' to disable animation. Default: '#ffff33'. 823 * @param {string} settings.delColor Hex code or 'none' to disable animation. Default: '#faafaa'. 824 * @param {string} settings.dimAddColor Hex code or 'none' to disable animation. Default: '#ffff33'. 825 * @param {string} settings.dimDelColor Hex code or 'none' to disable animation. Default: '#ff3333'. 826 * 827 * @param {wpList~confirm} settings.confirm Callback that's run before a request is made. Default: null. 828 * @param {wpList~addBefore} settings.addBefore Callback that's run before an item gets added to the list. 829 * Default: null. 830 * @param {wpList~addAfter} settings.addAfter Callback that's run after an item got added to the list. 831 * Default: null. 832 * @param {wpList~delBefore} settings.delBefore Callback that's run before an item gets deleted from the list. 833 * Default: null. 834 * @param {wpList~delAfter} settings.delAfter Callback that's run after an item got deleted from the list. 835 * Default: null. 836 * @param {wpList~dimBefore} settings.dimBefore Callback that's run before an item gets dim'd. Default: null. 837 * @param {wpList~dimAfter} settings.dimAfter Callback that's run after an item got dim'd. Default: null. 838 * @return {$.fn} wpList API function. 839 */ 840 $.fn.wpList = function( settings ) { 841 this.each( function( index, list ) { 842 list.wpList = { 843 settings: $.extend( {}, wpList.settings, { what: wpList.parseData( list, 'list' )[1] || '' }, settings ) 844 }; 845 846 $.each( functions, function( func, callback ) { 847 list.wpList[func] = function( element, setting ) { 848 return wpList[callback].call( list, element, setting ); 849 }; 850 } ); 851 } ); 852 853 wpList.init.call( this ); 854 this.wpList.process(); 855 856 return this; 857 }; 858 } ) ( jQuery );
title
Description
Body
title
Description
Body
title
Description
Body
title
Body
Generated: Fri Jan 24 01:00:03 2025 | Cross-referenced by PHPXref 0.7.1 |