]> scripts.mit.edu Git - autoinstallsdev/wordpress.git/blobdiff - wp-admin/js/common.dev.js
WordPress 3.3.2
[autoinstallsdev/wordpress.git] / wp-admin / js / common.dev.js
index 4a54c59053030a3460f0f9d742beed074596e033..4918f1f77bda71c06e8cfdeef6d7f8322243a807 100644 (file)
-var showNotice, adminMenu, columns;
+var showNotice, adminMenu, columns, validateForm, screenMeta, autofold_menu;
 (function($){
-// sidebar admin menu
+// Removed in 3.3.
+// (perhaps) needed for back-compat
 adminMenu = {
+       init : function() {},
+       fold : function() {},
+       restoreMenuState : function() {},
+       toggle : function() {},
+       favorites : function() {}
+};
 
+// show/hide/save table columns
+columns = {
        init : function() {
-               $('#adminmenu div.wp-menu-toggle').each( function() {
-                       if ( $(this).siblings('.wp-submenu').length )
-                               $(this).click(function(){ adminMenu.toggle( $(this).siblings('.wp-submenu') ); });
+               var that = this;
+               $('.hide-column-tog', '#adv-settings').click( function() {
+                       var $t = $(this), column = $t.val();
+                       if ( $t.prop('checked') )
+                               that.checked(column);
                        else
-                               $(this).hide();
-               });
+                               that.unchecked(column);
 
-               this.favorites();
-
-               $('a.separator').click(function(){
-                       if ( $('body').hasClass('folded') ) {
-                               adminMenu.fold(1);
-                               deleteUserSetting( 'mfold' );
-                       } else {
-                               adminMenu.fold();
-                               setUserSetting( 'mfold', 'f' );
-                       }
-                       return false;
+                       columns.saveManageColumnsState();
                });
-
-               if ( $('body').hasClass('folded') ) {
-                       this.fold();
-               }
-               this.restoreMenuState();
        },
 
-       restoreMenuState : function() {
-               $('#adminmenu li.wp-has-submenu').each(function(i, e) {
-                       var v = getUserSetting( 'm'+i );
-                       if ( $(e).hasClass('wp-has-current-submenu') ) return true; // leave the current parent open
-
-                       if ( 'o' == v ) $(e).addClass('wp-menu-open');
-                       else if ( 'c' == v ) $(e).removeClass('wp-menu-open');
+       saveManageColumnsState : function() {
+               var hidden = this.hidden();
+               $.post(ajaxurl, {
+                       action: 'hidden-columns',
+                       hidden: hidden,
+                       screenoptionnonce: $('#screenoptionnonce').val(),
+                       page: pagenow
                });
        },
 
-       toggle : function(el) {
-
-               el['slideToggle'](150, function(){el.css('display','');}).parent().toggleClass( 'wp-menu-open' );
-
-               $('#adminmenu li.wp-has-submenu').each(function(i, e) {
-                       var v = $(e).hasClass('wp-menu-open') ? 'o' : 'c';
-                       setUserSetting( 'm'+i, v );
-               });
-
-               return false;
+       checked : function(column) {
+               $('.column-' + column).show();
+               this.colSpanChange(+1);
        },
 
-       fold : function(off) {
-               if (off) {
-                       $('body').removeClass('folded');
-                       $('#adminmenu li.wp-has-submenu').unbind();
-               } else {
-                       $('body').addClass('folded');
-                       $('#adminmenu li.wp-has-submenu').hoverIntent({
-                               over: function(e){
-                                       var m, b, h, o, f;
-                                       m = $(this).find('.wp-submenu');
-                                       b = m.parent().offset().top + m.height() + 1; // Bottom offset of the menu
-                                       h = $('#wpwrap').height(); // Height of the entire page
-                                       o = 60 + b - h;
-                                       f = $(window).height() + $('body').scrollTop() - 15; // The fold
-                                       if (f < (b - o)) {
-                                               o = b - f;
-                                       }
-                                       if (o > 1) {
-                                               m.css({'marginTop':'-'+o+'px'});
-                                       } else if ( m.css('marginTop') ) {
-                                               m.css({'marginTop':''});
-                                       }
-                                       m.addClass('sub-open');
-                               },
-                               out: function(){ $(this).find('.wp-submenu').removeClass('sub-open').css({'marginTop':''}); },
-                               timeout: 220,
-                               sensitivity: 8,
-                               interval: 100
-                       });
-
-               }
+       unchecked : function(column) {
+               $('.column-' + column).hide();
+               this.colSpanChange(-1);
        },
 
-       favorites : function() {
-               $('#favorite-inside').width($('#favorite-actions').width()-4);
-               $('#favorite-toggle, #favorite-inside').bind( 'mouseenter', function(){$('#favorite-inside').removeClass('slideUp').addClass('slideDown'); setTimeout(function(){if ( $('#favorite-inside').hasClass('slideDown') ) { $('#favorite-inside').slideDown(100); $('#favorite-first').addClass('slide-down'); }}, 200) } );
-
-               $('#favorite-toggle, #favorite-inside').bind( 'mouseleave', function(){$('#favorite-inside').removeClass('slideDown').addClass('slideUp'); setTimeout(function(){if ( $('#favorite-inside').hasClass('slideUp') ) { $('#favorite-inside').slideUp(100, function(){ $('#favorite-first').removeClass('slide-down'); } ); }}, 300) } );
-       }
-};
-
-$(document).ready(function(){adminMenu.init();});
+       hidden : function() {
+               return $('.manage-column').filter(':hidden').map(function() { return this.id; }).get().join(',');
+       },
 
-// show/hide/save table columns
-columns = {
-       init : function() {
-               $('.hide-column-tog').click( function() {
-                       var column = $(this).val(), show = $(this).attr('checked');
-                       if ( show ) {
-                               $('.column-' + column).show();
-                       } else {
-                               $('.column-' + column).hide();
-                       }
-                       columns.save_manage_columns_state();
-               } );
+       useCheckboxesForHidden : function() {
+               this.hidden = function(){
+                       return $('.hide-column-tog').not(':checked').map(function() {
+                               var id = this.id;
+                               return id.substring( id, id.length - 5 );
+                       }).get().join(',');
+               };
        },
 
-       save_manage_columns_state : function() {
-               var hidden = $('.manage-column').filter(':hidden').map(function() { return this.id; }).get().join(',');
-               $.post(ajaxurl, {
-                       action: 'hidden-columns',
-                       hidden: hidden,
-                       screenoptionnonce: $('#screenoptionnonce').val(),
-                       page: pagenow
-               });
+       colSpanChange : function(diff) {
+               var $t = $('table').find('.colspanchange'), n;
+               if ( !$t.length )
+                       return;
+               n = parseInt( $t.attr('colspan'), 10 ) + diff;
+               $t.attr('colspan', n.toString());
        }
 }
 
 $(document).ready(function(){columns.init();});
 
-})(jQuery);
+validateForm = function( form ) {
+       return !$( form ).find('.form-required').filter( function() { return $('input:visible', this).val() == ''; } ).addClass( 'form-invalid' ).find('input:visible').change( function() { $(this).closest('.form-invalid').removeClass( 'form-invalid' ); } ).size();
+}
 
 // stub for doing better warnings
 showNotice = {
@@ -140,128 +89,301 @@ showNotice = {
        }
 };
 
-jQuery(document).ready( function($) {
-       var lastClicked = false, checks, first, last, checked;
+screenMeta = {
+       element: null, // #screen-meta
+       toggles: null, // .screen-meta-toggle
+       page:    null, // #wpcontent
 
-       // pulse
-       $('.fade').animate( { backgroundColor: '#ffffe0' }, 300).animate( { backgroundColor: '#fffbcc' }, 300).animate( { backgroundColor: '#ffffe0' }, 300).animate( { backgroundColor: '#fffbcc' }, 300);
+       init: function() {
+               this.element = $('#screen-meta');
+               this.toggles = $('.screen-meta-toggle a');
+               this.page    = $('#wpcontent');
 
-       // Move .updated and .error alert boxes
-       $('div.wrap h2 ~ div.updated, div.wrap h2 ~ div.error').addClass('below-h2');
-       $('div.updated, div.error').not('.below-h2').insertAfter('div.wrap h2:first');
+               this.toggles.click( this.toggleEvent );
+       },
 
-       // show warnings
-       $('#doaction, #doaction2').click(function(){
-               if ( $('select[name="action"]').val() == 'delete' || $('select[name="action2"]').val() == 'delete' ) {
-                       return showNotice.warn();
-               }
-       });
+       toggleEvent: function( e ) {
+               var panel = $( this.href.replace(/.+#/, '#') );
+               e.preventDefault();
 
-       // screen settings tab
-       $('#show-settings-link').click(function () {
-               if ( ! $('#screen-options-wrap').hasClass('screen-options-open') ) {
-                       $('#contextual-help-link-wrap').css('visibility', 'hidden');
-               }
-               $('#screen-options-wrap').slideToggle('fast', function(){
-                       if ( $(this).hasClass('screen-options-open') ) {
-                               $('#show-settings-link').css({'backgroundImage':'url("images/screen-options-right.gif")'});
-                               $('#contextual-help-link-wrap').css('visibility', '');
-                               $(this).removeClass('screen-options-open');
-                       } else {
-                               $('#show-settings-link').css({'backgroundImage':'url("images/screen-options-right-up.gif")'});
-                               $(this).addClass('screen-options-open');
-                       }
+               if ( !panel.length )
+                       return;
+
+               if ( panel.is(':visible') )
+                       screenMeta.close( panel, $(this) );
+               else
+                       screenMeta.open( panel, $(this) );
+       },
+
+       open: function( panel, link ) {
+
+               $('.screen-meta-toggle').not( link.parent() ).css('visibility', 'hidden');
+
+               panel.parent().show();
+               panel.slideDown( 'fast', function() {
+                       link.addClass('screen-meta-active');
                });
+       },
+
+       close: function( panel, link ) {
+               panel.slideUp( 'fast', function() {
+                       link.removeClass('screen-meta-active');
+                       $('.screen-meta-toggle').css('visibility', '');
+                       panel.parent().hide();
+               });
+       }
+};
+
+/**
+ * Help tabs.
+ */
+$('.contextual-help-tabs').delegate('a', 'click focus', function(e) {
+       var link = $(this),
+               panel;
+
+       e.preventDefault();
+
+       // Don't do anything if the click is for the tab already showing.
+       if ( link.is('.active a') )
                return false;
-       });
 
-       // help tab
-       $('#contextual-help-link').click(function () {
-               if ( ! $('#contextual-help-wrap').hasClass('contextual-help-open') ) {
-                       $('#screen-options-link-wrap').css('visibility', 'hidden');
+       // Links
+       $('.contextual-help-tabs .active').removeClass('active');
+       link.parent('li').addClass('active');
+
+       panel = $( link.attr('href') );
+
+       // Panels
+       $('.help-tab-content').not( panel ).removeClass('active').hide();
+       panel.addClass('active').show();
+});
+
+$(document).ready( function() {
+       var lastClicked = false, checks, first, last, checked, menu = $('#adminmenu'),
+               pageInput = $('input.current-page'), currentPage = pageInput.val(), folded, refresh;
+
+       // admin menu
+       refresh = function(i, el){ // force the browser to refresh the tabbing index
+               var node = $(el), tab = node.attr('tabindex');
+               if ( tab )
+                       node.attr('tabindex', '0').attr('tabindex', tab);
+       };
+
+       $('#collapse-menu', menu).click(function(){
+               var body = $(document.body);
+
+               if ( body.hasClass('folded') ) {
+                       body.removeClass('folded');
+                       setUserSetting('mfold', 'o');
+               } else {
+                       body.addClass('folded');
+                       setUserSetting('mfold', 'f');
                }
-               $('#contextual-help-wrap').slideToggle('fast', function(){
-                       if ( $(this).hasClass('contextual-help-open') ) {
-                               $('#contextual-help-link').css({'backgroundImage':'url("images/screen-options-right.gif")'});
-                               $('#screen-options-link-wrap').css('visibility', '');
-                               $(this).removeClass('contextual-help-open');
-                       } else {
-                               $('#contextual-help-link').css({'backgroundImage':'url("images/screen-options-right-up.gif")'});
-                               $(this).addClass('contextual-help-open');
-                       }
-               });
                return false;
        });
-       $('#contextual-help-link-wrap, #screen-options-link-wrap').show();
+
+       $('li.wp-has-submenu', menu).hoverIntent({
+               over: function(e){
+                       var b, h, o, f, m = $(this).find('.wp-submenu'), menutop, wintop, maxtop;
+
+                       if ( !$(document.body).hasClass('folded') && $(this).hasClass('wp-menu-open') )
+                               return;
+
+                       menutop = $(this).offset().top;
+                       wintop = $(window).scrollTop();
+                       maxtop = menutop - wintop - 30; // max = make the top of the sub almost touch admin bar
+
+                       b = menutop + m.height() + 1; // Bottom offset of the menu
+                       h = $('#wpwrap').height(); // Height of the entire page
+                       o = 60 + b - h;
+                       f = $(window).height() + wintop - 15; // The fold
+
+                       if ( f < (b - o) )
+                               o = b - f;
+
+                       if ( o > maxtop )
+                               o = maxtop;
+
+                       if ( o > 1 )
+                               m.css({'marginTop':'-'+o+'px'});
+                       else if ( m.css('marginTop') )
+                               m.css({'marginTop':''});
+
+                       menu.find('.wp-submenu').removeClass('sub-open');
+                       m.addClass('sub-open');
+               },
+               out: function(){
+                       $(this).find('.wp-submenu').removeClass('sub-open');
+               },
+               timeout: 200,
+               sensitivity: 7,
+               interval: 90
+       });
+
+       // Tab to select, Enter to open sub, Esc to close sub and focus the top menu
+       $('li.wp-has-submenu > a.wp-not-current-submenu', menu).bind('keydown.adminmenu', function(e){
+               if ( e.which != 13 )
+                       return;
+
+               var target = $(e.target);
+
+               e.stopPropagation();
+               e.preventDefault();
+
+               menu.find('.wp-submenu').removeClass('sub-open');
+               target.siblings('.wp-submenu').toggleClass('sub-open').find('a[role="menuitem"]').each(refresh);
+       }).each(refresh);
+
+       $('a[role="menuitem"]', menu).bind('keydown.adminmenu', function(e){
+               if ( e.which != 27 )
+                       return;
+
+               var target = $(e.target);
+
+               e.stopPropagation();
+               e.preventDefault();
+
+               target.add( target.siblings() ).closest('.sub-open').removeClass('sub-open').siblings('a.wp-not-current-submenu').focus();
+       });
+
+       // Move .updated and .error alert boxes. Don't move boxes designed to be inline.
+       $('div.wrap h2:first').nextAll('div.updated, div.error').addClass('below-h2');
+       $('div.updated, div.error').not('.below-h2, .inline').insertAfter( $('div.wrap h2:first') );
+
+       // Init screen meta
+       screenMeta.init();
 
        // check all checkboxes
-       $( 'table:visible tbody .check-column :checkbox' ).click( function(e) {
+       $('tbody').children().children('.check-column').find(':checkbox').click( function(e) {
                if ( 'undefined' == e.shiftKey ) { return true; }
                if ( e.shiftKey ) {
                        if ( !lastClicked ) { return true; }
-                       checks = $( lastClicked ).parents( 'form:first' ).find( ':checkbox' );
+                       checks = $( lastClicked ).closest( 'form' ).find( ':checkbox' );
                        first = checks.index( lastClicked );
                        last = checks.index( this );
-                       checked = $(this).attr('checked');
+                       checked = $(this).prop('checked');
                        if ( 0 < first && 0 < last && first != last ) {
-                               checks.slice( first, last ).attr( 'checked', function(){
-                                       if ( $(this).parents('tr').is(':visible') )
-                                               return checked ? 'checked' : '';
+                               checks.slice( first, last ).prop( 'checked', function(){
+                                       if ( $(this).closest('tr').is(':visible') )
+                                               return checked;
 
-                                       return '';
+                                       return false;
                                });
                        }
                }
                lastClicked = this;
                return true;
-       } );
-       $( 'thead :checkbox, tfoot :checkbox' ).click( function(e) {
-               var c = $(this).attr('checked'), kbtoggle = 'undefined' == typeof toggleWithKeyboard ? false : toggleWithKeyboard, toggle = e.shiftKey || kbtoggle;
+       });
 
+       $('thead, tfoot').find('.check-column :checkbox').click( function(e) {
+               var c = $(this).prop('checked'),
+                       kbtoggle = 'undefined' == typeof toggleWithKeyboard ? false : toggleWithKeyboard,
+                       toggle = e.shiftKey || kbtoggle;
 
-               $(this).parents( 'form:first' ).find( 'table tbody:visible' ).find( '.check-column :checkbox' ).attr( 'checked', function() {
-                       if ( $(this).parents('tr').is(':hidden') )
-                               return '';
+               $(this).closest( 'table' ).children( 'tbody' ).filter(':visible')
+               .children().children('.check-column').find(':checkbox')
+               .prop('checked', function() {
+                       if ( $(this).closest('tr').is(':hidden') )
+                               return false;
                        if ( toggle )
-                               return $(this).attr( 'checked' ) ? '' : 'checked';
+                               return $(this).prop( 'checked' );
                        else if (c)
-                               return 'checked';
-                       return '';
+                               return true;
+                       return false;
                });
-               $(this).parents( 'form:first' ).find( 'table thead:visible, table tfoot:visible').find( '.check-column :checkbox' ).attr( 'checked', function() {
+
+               $(this).closest('table').children('thead,  tfoot').filter(':visible')
+               .children().children('.check-column').find(':checkbox')
+               .prop('checked', function() {
                        if ( toggle )
-                               return '';
+                               return false;
                        else if (c)
-                               return 'checked';
-                       return '';
+                               return true;
+                       return false;
                });
        });
+
        $('#default-password-nag-no').click( function() {
                setUserSetting('default_password_nag', 'hide');
                $('div.default-password-nag').hide();
                return false;
        });
-       
-       
-});
 
-jQuery(document).ready( function($){
-       var turboNag = $('.turbo-nag');
+       // tab in textareas
+       $('#newcontent').bind('keydown.wpevent_InsertTab', function(e) {
+               if ( e.keyCode != 9 )
+                       return true;
 
-       if ( !turboNag.length || ('undefined' != typeof(google) && google.gears) )
-               return;
+               var el = e.target, selStart = el.selectionStart, selEnd = el.selectionEnd, val = el.value, scroll, sel;
 
-       if ( 'undefined' != typeof GearsFactory ) {
-               return;
-       } else {
                try {
-                       if ( ( 'undefined' != typeof window.ActiveXObject && ActiveXObject('Gears.Factory') ) ||
-                               ( 'undefined' != typeof navigator.mimeTypes && navigator.mimeTypes['application/x-googlegears'] ) ) {
-                                       return;
-                       }
-               } catch(e){}
+                       this.lastKey = 9; // not a standard DOM property, lastKey is to help stop Opera tab event.  See blur handler below.
+               } catch(err) {}
+
+               if ( document.selection ) {
+                       el.focus();
+                       sel = document.selection.createRange();
+                       sel.text = '\t';
+               } else if ( selStart >= 0 ) {
+                       scroll = this.scrollTop;
+                       el.value = val.substring(0, selStart).concat('\t', val.substring(selEnd) );
+                       el.selectionStart = el.selectionEnd = selStart + 1;
+                       this.scrollTop = scroll;
+               }
+
+               if ( e.stopPropagation )
+                       e.stopPropagation();
+               if ( e.preventDefault )
+                       e.preventDefault();
+       });
+
+       $('#newcontent').bind('blur.wpevent_InsertTab', function(e) {
+               if ( this.lastKey && 9 == this.lastKey )
+                       this.focus();
+       });
+
+       if ( pageInput.length ) {
+               pageInput.closest('form').submit( function(e){
+
+                       // Reset paging var for new filters/searches but not for bulk actions. See #17685.
+                       if ( $('select[name="action"]').val() == -1 && $('select[name="action2"]').val() == -1 && pageInput.val() == currentPage )
+                               pageInput.val('1');
+               });
        }
 
-       turboNag.show();
+       // auto-fold the menu when screen is under 800px
+       $(window).bind('resize.autofold', function(){
+               if ( getUserSetting('mfold') == 'f' )
+                       return;
+
+               var width = $(window).width();
+
+               // fold admin menu
+               if ( width <= 800 ) {
+                       if ( !folded ) {
+                               $(document.body).addClass('folded');
+                               folded = true;
+                       }
+               } else {
+                       if ( folded ) {
+                               $(document.body).removeClass('folded');
+                               folded = false;
+                       }
+               }
+
+       }).triggerHandler('resize');
 
 });
+
+// internal use
+$(document).bind( 'wp_CloseOnEscape', function( e, data ) {
+       if ( typeof(data.cb) != 'function' )
+               return;
+
+       if ( typeof(data.condition) != 'function' || data.condition() )
+               data.cb();
+
+       return true;
+});
+
+})(jQuery);