Ticket #50699: 50699.diff
File 50699.diff, 27.4 KB (added by , 4 years ago) |
---|
-
src/js/_enqueues/admin/postbox.js
9 9 10 10 /* global ajaxurl, postboxes */ 11 11 12 ( function($) {12 ( function( $ ) { 13 13 var $document = $( document ), 14 $body = $( 'body' ), 14 15 __ = wp.i18n.__; 15 16 16 17 /** … … 63 64 } 64 65 65 66 if ( postboxes.page !== 'press-this' ) { 66 postboxes.save_state( postboxes.page);67 postboxes.save_state(); 67 68 } 68 69 69 70 if ( id ) { … … 118 119 return; 119 120 } 120 121 121 // Move a postbox up.122 122 if ( button.hasClass( 'handle-order-higher' ) ) { 123 // Move a postbox up. 123 124 // If the box is first within a sortable area, move it to the previous sortable area. 124 125 if ( 0 === postboxWithinSortablesIndex ) { 125 126 postboxes.handleOrderBetweenSortables( 'previous', button, postbox ); … … 129 130 postbox.prevAll( '.postbox:visible' ).eq( 0 ).before( postbox ); 130 131 button.focus(); 131 132 postboxes.updateOrderButtonsProperties(); 132 postboxes.save_order( postboxes.page ); 133 } 134 135 // Move a postbox down. 136 if ( button.hasClass( 'handle-order-lower' ) ) { 133 postboxes.save_order(); 134 } else if ( button.hasClass( 'handle-order-lower' ) ) { 135 // Move a postbox down. 137 136 // If the box is last within a sortable area, move it to the next sortable area. 138 137 if ( postboxWithinSortablesIndex + 1 === postboxesWithinSortablesCount ) { 139 138 postboxes.handleOrderBetweenSortables( 'next', button, postbox ); … … 143 142 postbox.nextAll( '.postbox:visible' ).eq( 0 ).after( postbox ); 144 143 button.focus(); 145 144 postboxes.updateOrderButtonsProperties(); 146 postboxes.save_order( postboxes.page);145 postboxes.save_order(); 147 146 } 148 149 147 }, 150 148 151 149 /** … … 191 189 192 190 postboxes._mark_area(); 193 191 button.focus(); 194 postboxes.updateOrderButtonsProperties(); 195 postboxes.save_order( postboxes.page ); 192 postboxes.save_order(); 196 193 }, 197 194 195 showArrangeArrows: function() { 196 $( '.postbox-arrange-arrow' ) 197 .attr( 'aria-disabled', 'false' ) 198 .removeClass( 'hidden' ); 199 200 postboxes._mark_area(); 201 }, 202 203 hideArrangeArrows: function() { 204 $( '.postbox-arrange-arrow' ) 205 .attr( 'aria-disabled', 'true' ) 206 .addClass( 'hidden' ); 207 208 postboxes._mark_area(); 209 }, 210 198 211 /** 199 212 * Update the move buttons properties depending on the postbox position. 200 213 * … … 203 216 * @return {void} 204 217 */ 205 218 updateOrderButtonsProperties: function() { 206 var firstSortablesId = $( '.meta-box-sortables:visible:first' ).attr( 'id' ), 207 lastSortablesId = $( '.meta-box-sortables:visible:last' ).attr( 'id' ), 208 firstPostbox = $( '.postbox:visible:first' ), 209 lastPostbox = $( '.postbox:visible:last' ), 210 firstPostboxId = firstPostbox.attr( 'id' ), 211 lastPostboxId = lastPostbox.attr( 'id' ), 212 firstPostboxSortablesId = firstPostbox.closest( '.meta-box-sortables' ).attr( 'id' ), 213 lastPostboxSortablesId = lastPostbox.closest( '.meta-box-sortables' ).attr( 'id' ), 214 moveUpButtons = $( '.handle-order-higher' ), 215 moveDownButtons = $( '.handle-order-lower' ); 219 var elements = $( '.postbox:visible' ), 220 containers = $( '.meta-box-sortables:visible' ) 221 .not( '.unused-container' ) 222 .filter( function( i, container ) { 223 if ( i > 0 && container.clientHeight === 0 ) { 224 return false; 225 } 216 226 217 // Enable all buttons as a reset first. 218 moveUpButtons 219 .attr( 'aria-disabled', 'false' ) 220 .removeClass( 'hidden' ); 221 moveDownButtons 222 .attr( 'aria-disabled', 'false' ) 223 .removeClass( 'hidden' ); 227 return true; 228 } ); 224 229 225 // When there's only one "sortables" area (e.g. in the block editor) and only one visible postbox, hide the buttons. 226 if ( firstSortablesId === lastSortablesId && firstPostboxId === lastPostboxId ) { 227 moveUpButtons.addClass( 'hidden' ); 228 moveDownButtons.addClass( 'hidden' ); 230 // When there's only one "sortables" area (e.g. in the block editor) 231 // and only one visible postbox, hide the buttons. 232 if ( containers.length === 1 && elements.length === 1 ) { 233 $( '.postbox-arrange-arrow' ).addClass( 'hidden' ).attr( 'aria-disabled', 'true' ); 234 return; 229 235 } 230 236 231 // Set an aria-disabled=true attribute on the first visible "move" buttons.232 if ( firstSortablesId === firstPostboxSortablesId) {233 $( firstPostbox ).find( '.handle-order-higher' ).attr( 'aria-disabled', 'true' );237 // Reset. 238 if ( $body.hasClass( 'screen-options-open' ) ) { 239 $( '.postbox-arrange-arrow' ).removeClass( 'hidden' ).attr( 'aria-disabled', 'false' ); 234 240 } 235 241 236 // Set an aria-disabled=true attribute on the last visible "move" buttons.237 if ( lastSortablesId === lastPostboxSortablesId ) {238 $( '.postbox:visible .handle-order-lower' ).last().attr( 'aria-disabled', 'true' );242 if ( elements.first().parent()[0] === containers.first()[0] ) { 243 // Set an aria-disabled=true attribute on the first visible "move higher" buttons. 244 elements.first().find( '.handle-order-higher' ).attr( 'aria-disabled', 'true' ); 239 245 } 246 247 if ( elements.last().parent()[0] === containers.last()[0] ) { 248 // Set an aria-disabled=true attribute on the last visible "move lower" buttons. 249 elements.last().find( '.handle-order-lower' ).attr( 'aria-disabled', 'true' ); 250 } 240 251 }, 241 252 242 253 /** … … 252 263 * @param {Function} args.pbhide A callback that is called when a postbox closes. 253 264 * @return {void} 254 265 */ 255 add_postbox_toggles : function (page, args) {266 add_postbox_toggles: function ( page, args ) { 256 267 var $handles = $( '.postbox .hndle, .postbox .handlediv' ), 257 $orderButtons = $( '.postbox . handle-order-higher, .postbox .handle-order-lower' );268 $orderButtons = $( '.postbox .postbox-arrange-arrow' ); 258 269 259 270 this.page = page; 260 271 this.init( page, args ); … … 267 278 /** 268 279 * @since 2.7.0 269 280 */ 270 $( '.postbox .hndle a').click( function(e) {271 e .stopPropagation();281 $( '.postbox .hndle a' ).on( 'click', function( event ) { 282 event.stopPropagation(); 272 283 }); 273 284 274 285 /** … … 283 294 * 284 295 * @return {void} 285 296 */ 286 $( '.postbox a.dismiss' ).on( 'click.postboxes', function( e ) { 287 var hide_id = $(this).parents('.postbox').attr('id') + '-hide'; 288 e.preventDefault(); 289 $( '#' + hide_id ).prop('checked', false).triggerHandler('click'); 297 $( '.postbox a.dismiss' ).on( 'click.postboxes', function( event ) { 298 var hide_id = $( this ).parents( '.postbox' ).attr( 'id' ) + '-hide'; 299 300 event.preventDefault(); 301 $( '#' + hide_id ).prop( 'checked', false ).triggerHandler( 'click' ); 290 302 }); 291 303 292 304 /** … … 302 314 * 303 315 * @return {void} 304 316 */ 305 $( '.hide-postbox-tog').bind('click.postboxes', function() {306 var $el = $( this),317 $( '.hide-postbox-tog' ).on( 'click.postboxes', function() { 318 var $el = $( this ), 307 319 boxId = $el.val(), 308 320 $postbox = $( '#' + boxId ); 309 321 310 322 if ( $el.prop( 'checked' ) ) { 311 323 $postbox.show(); 324 312 325 if ( $.isFunction( postboxes.pbshow ) ) { 313 326 postboxes.pbshow( boxId ); 314 327 } 315 328 } else { 316 329 $postbox.hide(); 330 317 331 if ( $.isFunction( postboxes.pbhide ) ) { 318 332 postboxes.pbhide( boxId ); 319 333 } 320 334 } 321 335 322 postboxes.save_state( page);336 postboxes.save_state(); 323 337 postboxes._mark_area(); 324 338 325 339 /** … … 336 350 * 337 351 * @return {void} 338 352 */ 339 $( '.columns-prefs input[type="radio"]').bind('click.postboxes', function(){340 var n = parseInt($(this).val(), 10);353 $( '.columns-prefs input[type="radio"]' ).on( 'click.postboxes', function() { 354 var number = parseInt( $( this ).val(), 10 ); 341 355 342 if ( n ) {343 postboxes._pb_edit( n);344 postboxes.save_order( page);356 if ( number ) { 357 postboxes._pb_edit( number ); 358 postboxes.save_order(); 345 359 } 346 360 }); 361 362 // Enable dragging/arranging of postboxes and show drop placeholders when Screen Options tab is open. 363 // If there is no Screen Options tab on the screen, dragging/arranging is enabled on page load. 364 $document.on( 'screen:options:open', function() { 365 $body.addClass( 'screen-options-open' ); 366 postboxes.initializeSortable(); 367 postboxes.showArrangeArrows(); 368 } ).on( 'screen:options:close', function() { 369 $body.removeClass( 'screen-options-open' ); 370 $( '.meta-box-sortables' ).sortable( 'destroy' ); 371 postboxes.hideArrangeArrows() 372 } ); 347 373 }, 348 374 349 /** 350 * Initializes all the postboxes, mainly their sortable behaviour. 351 * 352 * @since 2.7.0 353 * 354 * @memberof postboxes 355 * 356 * @param {string} page The page we are currently on. 357 * @param {Object} [args={}] The arguments for the postbox initializer. 358 * @param {Function} args.pbshow A callback that is called when a postbox opens. 359 * @param {Function} args.pbhide A callback that is called when a postbox 360 * closes. 361 * 362 * @return {void} 363 */ 364 init : function(page, args) { 365 var isMobile = $( document.body ).hasClass( 'mobile' ), 366 $handleButtons = $( '.postbox .handlediv' ); 375 initializeSortable: function() { 376 var hasScreenOptions = $document.find( '#screen-options-wrap' ).length > 0; 367 377 368 $.extend( this, args || {} ); 369 $('.meta-box-sortables').sortable({ 378 $( '.meta-box-sortables' ).sortable( { 370 379 placeholder: 'sortable-placeholder', 371 380 connectWith: '.meta-box-sortables', 372 381 items: '.postbox', 373 382 handle: '.hndle', 374 383 cursor: 'move', 375 delay: ( isMobile? 200 : 0 ),384 delay: ( $body.hasClass( 'mobile' ) ? 200 : 0 ), 376 385 distance: 2, 377 386 tolerance: 'pointer', 387 opacity: 0.65, 378 388 forcePlaceholderSize: true, 389 containment: '#wpwrap', 390 379 391 helper: function( event, element ) { 380 392 /* `helper: 'clone'` is equivalent to `return element.clone();` 381 393 * Cloning a checked radio and then inserting that clone next to the original … … 386 398 */ 387 399 return element.clone() 388 400 .find( ':input' ) 389 390 391 401 .attr( 'name', function( i, currentName ) { 402 return 'sort_' + parseInt( Math.random() * 100000, 10 ).toString() + '_' + currentName; 403 } ) 392 404 .end(); 393 405 }, 394 opacity: 0.65,395 406 start: function() { 396 $( 'body' ).addClass( 'is-dragging-metaboxes' ); 407 // Pretend the Screen Options tab exists. 408 if ( ! hasScreenOptions ) { 409 $body.addClass( 'screen-options-open' ); 410 } 411 397 412 // Refresh the cached positions of all the sortable items so that the min-height set while dragging works. 398 413 $( '.meta-box-sortables' ).sortable( 'refreshPositions' ); 399 414 }, … … 400 415 stop: function() { 401 416 var $el = $( this ); 402 417 403 $( 'body' ).removeClass( 'is-dragging-metaboxes' ); 418 if ( ! hasScreenOptions ) { 419 $body.removeClass( 'screen-options-open' ); 420 } 404 421 405 422 if ( $el.find( '#dashboard_browser_nag' ).is( ':visible' ) && 'dashboard_browser_nag' != this.firstChild.id ) { 406 $el.sortable( 'cancel');423 $el.sortable( 'cancel' ); 407 424 return; 408 425 } 409 426 410 postboxes. updateOrderButtonsProperties();411 postboxes.save_order( page);427 postboxes._mark_area(); 428 postboxes.save_order(); 412 429 }, 413 receive: function(e,ui) { 414 if ( 'dashboard_browser_nag' == ui.item[0].id ) 415 $(ui.sender).sortable('cancel'); 430 receive: function( event, ui ) { 431 if ( 'dashboard_browser_nag' == ui.item[0].id ) { 432 $( ui.sender ).sortable( 'cancel' ); 433 } 416 434 417 postboxes._mark_area();418 435 $document.trigger( 'postbox-moved', ui.item ); 419 436 } 420 437 }); 438 }, 421 439 422 if ( isMobile ) { 423 $(document.body).bind('orientationchange.postboxes', function(){ postboxes._pb_change(); }); 440 /** 441 * Initializes the postboxes, mainly their sortable behaviour. 442 * 443 * @since 2.7.0 444 * 445 * @memberof postboxes 446 * 447 * @param {string} page The page we are currently on. Not used, here for back-compat. 448 * @param {Object} [args={}] The arguments for the postbox initializer. 449 * @param {Function} args.pbshow A callback that is called when a postbox opens. 450 * @param {Function} args.pbhide A callback that is called when a postbox 451 * closes. 452 * 453 * @return {void} 454 */ 455 init: function( page, args ) { 456 $.extend( this, args || {} ); 457 458 if ( $body.hasClass( 'mobile' ) ) { 459 $body.on( 'orientationchange.postboxes', function() { postboxes._pb_change(); } ); 424 460 this._pb_change(); 425 461 } 426 462 427 this._mark_area(); 428 429 // Update the "move" buttons properties. 463 // Set the "arrange" (up/down) buttons properties on page load... 430 464 this.updateOrderButtonsProperties(); 431 $document.on( 'postbox-toggled', this.updateOrderButtonsProperties );432 465 466 // ...and keep updating it when postboxes are added or removed by using the checkboxes in Screen Options. 467 $document.on( 'postbox-toggled', this._mark_area ); 468 433 469 // Set the handle buttons `aria-expanded` attribute initial value on page load. 434 $ handleButtons.each( function () {470 $( '.postbox .handlediv' ).each( function () { 435 471 var $el = $( this ); 436 472 $el.attr( 'aria-expanded', ! $el.closest( '.postbox' ).hasClass( 'closed' ) ); 437 473 }); 474 475 // Init sortables now if there is no Screen Options tab. 476 // Otherwise init when Screen Options are open. 477 if ( ! $document.find( '#screen-options-wrap' ).length ) { 478 this.initializeSortable(); 479 this.showArrangeArrows(); 480 } 438 481 }, 439 482 440 483 /** … … 450 493 * @param {string} page The page we are currently on. 451 494 * @return {void} 452 495 */ 453 save_state : function( page) {496 save_state : function() { 454 497 var closed, hidden; 455 498 456 499 // Return on the nav-menus.php screen, see #35112. 457 if ( 'nav-menus' === p age ) {500 if ( 'nav-menus' === postboxes.page ) { 458 501 return; 459 502 } 460 503 … … 461 504 closed = $( '.postbox' ).filter( '.closed' ).map( function() { return this.id; } ).get().join( ',' ); 462 505 hidden = $( '.postbox' ).filter( ':hidden' ).map( function() { return this.id; } ).get().join( ',' ); 463 506 464 $.post( ajaxurl, {507 $.post( ajaxurl, { 465 508 action: 'closed-postboxes', 466 509 closed: closed, 467 510 hidden: hidden, 468 closedpostboxesnonce: jQuery('#closedpostboxesnonce').val(),469 page: p age511 closedpostboxesnonce: $( '#closedpostboxesnonce' ).val(), 512 page: postboxes.page 470 513 }); 471 514 }, 472 515 … … 479 522 * 480 523 * @memberof postboxes 481 524 * 482 * @param {string} page The page we are currently on.483 525 * @return {void} 484 526 */ 485 save_order : function(page) { 486 var postVars, page_columns = $('.columns-prefs input:checked').val() || 0; 487 488 postVars = { 527 save_order : function() { 528 var postVars = { 489 529 action: 'meta-box-order', 490 _ajax_nonce: $( '#meta-box-order-nonce').val(),491 page_columns: page_columns,492 page: p age530 _ajax_nonce: $( '#meta-box-order-nonce' ).val(), 531 page_columns: $( '.columns-prefs input:checked' ).val() || 0, 532 page: postboxes.page 493 533 }; 494 534 495 $( '.meta-box-sortables').each( function() {535 $( '.meta-box-sortables' ).each( function() { 496 536 postVars[ 'order[' + this.id.split( '-' )[0] + ']' ] = $( this ).sortable( 'toArray' ).join( ',' ); 497 537 } ); 498 538 … … 522 562 * @return {void} 523 563 */ 524 564 _mark_area : function() { 525 var visible = $( 'div.postbox:visible' ).length, 526 visibleSortables = $( '#dashboard-widgets .meta-box-sortables:visible, #post-body .meta-box-sortables:visible' ), 527 areAllVisibleSortablesEmpty = true; 565 var elements = $( '.postbox:visible' ), 566 containers = $( '.meta-box-sortables:visible' ); 528 567 529 visibleSortables.each( function() {530 var t = $(this);568 containers.each( function( index, element ) { 569 var container = $( element ); 531 570 532 if ( visible == 1 || t.children( '.postbox:visible' ).length ) { 533 t.removeClass('empty-container'); 534 areAllVisibleSortablesEmpty = false; 535 } 536 else { 537 t.addClass('empty-container'); 538 } 539 }); 571 if ( container.children( '.postbox:visible' ).length ) { 572 container 573 .removeClass( 'empty-container unused-container' ) 574 .removeAttr( 'data-emptystring' ); 575 } else { 576 container.addClass( 'empty-container' ); 540 577 541 postboxes.updateEmptySortablesText( visibleSortables, areAllVisibleSortablesEmpty ); 542 }, 578 if ( elements.length < 1 ) { 579 // Edge case: all postboxes are disabled. 580 // Mark the first container as empty, the rest as unused. 581 if ( index === 0 ) { 582 container.attr( 'data-emptystring', __( 'Enable screen elements from the Screen Options menu' ) ); 583 } else { 584 container.addClass( 'unused-container' ); 585 } 543 586 544 /** 545 * Updates the text for the empty sortable areas on the Dashboard. 546 * 547 * @since 5.5.0 548 * 549 * @param {Object} visibleSortables The jQuery object representing the visible sortable areas. 550 * @param {boolean} areAllVisibleSortablesEmpty Whether all the visible sortable areas are "empty". 551 * 552 * @return {void} 553 */ 554 updateEmptySortablesText: function( visibleSortables, areAllVisibleSortablesEmpty ) { 555 var isDashboard = $( '#dashboard-widgets' ).length, 556 emptySortableText = areAllVisibleSortablesEmpty ? __( 'Add boxes from the Screen Options menu' ) : __( 'Drag boxes here' ); 587 // Break the loop. 588 return false; 589 } 557 590 558 if ( ! isDashboard ) { 559 return; 560 } 591 container.attr( 'data-emptystring', __( 'Drag screen elements here' ) ); 561 592 562 visibleSortables.each( function() { 563 if ( $( this ).hasClass( 'empty-container' ) ) { 564 $( this ).attr( 'data-emptyString', emptySortableText ); 593 if ( elements.length <= index ) { 594 // If there are not enough elements (postboxes) to add to all containers, 595 // (and this container is empty, as tested above) 596 // mark it as "unused". 597 container.addClass( 'unused-container' ); 598 } else { 599 container.removeClass( 'unused-container' ); 600 } 565 601 } 566 } ); 602 }); 603 604 // Refresh up/down arrows attributes. 605 if ( $body.hasClass( 'screen-options-open' ) ) { 606 postboxes.updateOrderButtonsProperties(); 607 } 567 608 }, 568 609 569 610 /** … … 579 620 * @param {number} n The amount of columns to divide the post edit page in. 580 621 * @return {void} 581 622 */ 582 _pb_edit : function( n) {583 var el = $( '.metabox-holder').get(0);623 _pb_edit : function( n ) { 624 var el = $( '.metabox-holder' ).get( 0 ); 584 625 585 626 if ( el ) { 586 el.className = el.className.replace( /columns-\d+/, 'columns-' + n);627 el.className = el.className.replace( /columns-\d+/, 'columns-' + n ); 587 628 } 588 629 589 630 /** … … 614 655 switch ( window.orientation ) { 615 656 case 90: 616 657 case -90: 617 if ( !check.length || !check.is(':checked') ) 618 this._pb_edit(2); 658 if ( ! check.length || ! check.is( ':checked' ) ) { 659 this._pb_edit( 2 ); 660 } 619 661 break; 620 662 case 0: 621 663 case 180: 622 664 if ( $( '#poststuff' ).length ) { 623 this._pb_edit(1); 624 } else { 625 if ( !check.length || !check.is(':checked') ) 626 this._pb_edit(2); 665 this._pb_edit( 1 ); 666 } else if ( ! check.length || ! check.is( ':checked' ) ) { 667 this._pb_edit( 2 ); 627 668 } 628 669 break; 629 670 } … … 651 692 pbhide : false 652 693 }; 653 694 654 }( jQuery));695 }( jQuery )); -
src/js/_enqueues/wp/dashboard.js
179 179 180 180 autoResizeTextarea(); 181 181 }; 182 182 183 window.quickPressLoad(); 183 184 184 // Enable the dragging functionality of the widgets.185 $( '.meta-box-sortables' ).sortable( 'option', 'containment', '#wpwrap' );186 187 185 /** 188 186 * Adjust the height of the textarea based on the content. 189 187 * -
src/wp-admin/css/common.css
1985 1985 padding-top: 10px; 1986 1986 } 1987 1987 1988 . metabox-holder .postbox-container .meta-box-sortables {1988 .postbox-container .meta-box-sortables { 1989 1989 /* The jQuery UI Sortables need some initial height to work properly. */ 1990 1990 min-height: 1px; 1991 1991 position: relative; … … 2014 2014 height: 0; 2015 2015 min-height: 0; 2016 2016 } 2017 2018 #wpbody-content .metabox-holder .postbox-container .empty-container:after { 2019 display: none; 2020 } 2017 2021 } 2018 2022 2019 2023 .js .widget .widget-top, 2020 .js .postbox .hndle {2024 .js.screen-options-open .postbox .hndle { 2021 2025 cursor: move; 2022 2026 } 2023 2027 -
src/wp-admin/css/dashboard.css
49 49 50 50 #dashboard-widgets .meta-box-sortables { 51 51 display: flow-root; /* avoid margin collapsing between parent and first/last child elements */ 52 /* Required min-height to make the jQuery UI Sortable drop zone work. */53 min-height: 100px;54 52 margin: 0 8px 20px; 55 53 } 56 54 57 #dashboard-widgets .postbox-container .empty-container { 58 outline: 3px dashed #b4b9be; 59 height: 250px; 55 /* The following four selectors also apply on the Edit Post screen. */ 56 .screen-options-open .meta-box-sortables { 57 outline: 3px dashed #606a73; 58 min-height: 250px; 60 59 } 61 60 62 /* Only highlight drop zones when dragging and only in the 2 columns layout. */ 63 .is-dragging-metaboxes #dashboard-widgets .meta-box-sortables { 64 outline: 3px dashed #606a73; 65 /* Prevent margin on the child from collapsing with margin on the parent. */ 66 display: flow-root; 61 .screen-options-open .postbox-container .empty-container { 62 outline-color: #b4b9be; 67 63 } 68 64 69 #dashboard-widgets.postbox-container .empty-container:after {65 .postbox-container .empty-container:after { 70 66 content: attr(data-emptystring); 71 67 margin: auto; 72 68 position: absolute; … … 82 78 display: none; 83 79 } 84 80 81 .screen-options-open .postbox-container .empty-container:after { 82 display: block; 83 } 85 84 86 85 /* @todo: this was originally in this section, but likely belongs elsewhere */ 87 86 #the-comment-list td.comment p.comment-author { … … 1118 1117 min-height: 0; 1119 1118 } 1120 1119 1121 . is-dragging-metaboxes#dashboard-widgets .meta-box-sortables {1120 .screen-options-open #dashboard-widgets .meta-box-sortables { 1122 1121 min-height: 100px; 1123 1122 } 1124 1123 … … 1174 1173 .columns-prefs .columns-prefs-4 { 1175 1174 display: none; 1176 1175 } 1177 1176 /* 1178 1177 #dashboard-widgets .postbox-container .empty-container:after { 1179 1178 display: block; 1180 1179 } 1180 */ 1181 1181 } 1182 1182 1183 1183 /* three columns on the dash */ … … 1205 1205 #dashboard-widgets #postbox-container-4 .empty-container:after { 1206 1206 display: none; 1207 1207 } 1208 1208 /* 1209 1209 #dashboard-widgets .postbox-container .empty-container:after { 1210 1210 display: block; 1211 1211 } 1212 */ 1212 1213 } 1213 1214 1214 /* Always show the "Drag boxes here" CSS generated content on large screens. */1215 /* Always show the "Drag boxes here" CSS generated content on large screens. 1215 1216 @media only screen and (min-width: 1801px) { 1216 1217 #dashboard-widgets .postbox-container .empty-container:after { 1217 1218 display: block; 1218 1219 } 1219 1220 } 1220 1221 */ 1221 1222 @media screen and (max-width: 870px) { 1222 1223 .welcome-panel .welcome-panel-column, 1223 1224 .welcome-panel .welcome-panel-column:first-child { -
src/wp-admin/css/edit.css
148 148 149 149 /* Post Screen */ 150 150 151 /* Only highlight drop zones when dragging and only in the 2 columns layout. */ 152 .is-dragging-metaboxes .metabox-holder .postbox-container .meta-box-sortables { 153 outline: 3px dashed #606a73; 154 /* Prevent margin on the child from collapsing with margin on the parent. */ 155 display: flow-root; 156 /* 157 * This min-height is meant to limit jumpiness while dragging. It's equivalent 158 * to the minimum height of the sortable-placeholder which is given by the height 159 * of a collapsed post box (36px + 1px top and bottom borders) + the placeholder 160 * bottom margin (20px) + 2 additional pixels to compensate browsers rounding. 161 */ 162 min-height: 60px; 151 .screen-options-open .metabox-holder .postbox-container .meta-box-sortables { 163 152 margin-bottom: 20px; 164 153 } 165 154 155 .screen-options-open #postbox-container-2 #advanced-sortables.empty-container { 156 height: 0; 157 min-height: 0; 158 outline: none; 159 } 160 161 .screen-options-open #postbox-container-2 #advanced-sortables.empty-container:after { 162 display: none; 163 } 164 166 165 .postbox { 167 166 position: relative; 168 167 min-width: 255px; … … 1495 1494 width: auto; 1496 1495 } 1497 1496 1498 . is-dragging-metaboxes.post-type-attachment #post-body .meta-box-sortables {1497 .screen-options-open.post-type-attachment #post-body .meta-box-sortables { 1499 1498 outline: none; 1500 1499 min-height: 0; 1501 1500 margin-bottom: 0; … … 1535 1534 } 1536 1535 1537 1536 /* Increase min-height while dragging for the #side-sortables and any potential sortables area with custom ID. */ 1538 . is-dragging-metaboxes#poststuff #postbox-container-1 .empty-container,1539 . is-dragging-metaboxes#poststuff #postbox-container-1 #side-sortables:empty,1540 . is-dragging-metaboxes#poststuff #post-body.columns-2 #side-sortables,1541 . is-dragging-metaboxes#poststuff #post-body.columns-2 .meta-box-sortables {1537 .screen-options-open #poststuff #postbox-container-1 .empty-container, 1538 .screen-options-open #poststuff #postbox-container-1 #side-sortables:empty, 1539 .screen-options-open #poststuff #post-body.columns-2 #side-sortables, 1540 .screen-options-open #poststuff #post-body.columns-2 .meta-box-sortables { 1542 1541 height: auto; 1543 1542 min-height: 60px; 1544 1543 } -
src/wp-admin/includes/class-wp-screen.php
1113 1113 } 1114 1114 ?> 1115 1115 <fieldset class="metabox-prefs"> 1116 <legend><?php _e( 'Boxes' ); ?></legend> 1116 <legend><?php _e( 'Screen elements' ); ?></legend> 1117 <p> 1118 <?php _e( 'Some screen elements can be shown or hidden by using the checkboxes.' ); ?> 1119 <?php _e( 'They can be expanded and collapsed by clickling on their headings, and arranged by dragging their headings or by clicking on the up and down arrows.' ); ?> 1120 </p> 1117 1121 <?php 1118 meta_box_prefs( $this );1119 1122 1123 meta_box_prefs( $this ); 1124 1120 1125 if ( 'dashboard' === $this->id && has_action( 'welcome_panel' ) && current_user_can( 'edit_theme_options' ) ) { 1121 1126 if ( isset( $_GET['welcome'] ) ) { 1122 1127 $welcome_checked = empty( $_GET['welcome'] ) ? 0 : 1; -
src/wp-admin/includes/template.php
1335 1335 1336 1336 echo '<div class="handle-actions hide-if-no-js">'; 1337 1337 1338 echo '<button type="button" class="handle-order-higher " aria-disabled="false" aria-describedby="' . $box['id'] . '-handle-order-higher-description">';1338 echo '<button type="button" class="handle-order-higher postbox-arrange-arrow hidden" aria-disabled="true" aria-describedby="' . $box['id'] . '-handle-order-higher-description">'; 1339 1339 echo '<span class="screen-reader-text">' . __( 'Move up' ) . '</span>'; 1340 1340 echo '<span class="order-higher-indicator" aria-hidden="true"></span>'; 1341 1341 echo '</button>'; … … 1345 1345 $widget_title 1346 1346 ) . '</span>'; 1347 1347 1348 echo '<button type="button" class="handle-order-lower " aria-disabled="false" aria-describedby="' . $box['id'] . '-handle-order-lower-description">';1348 echo '<button type="button" class="handle-order-lower postbox-arrange-arrow hidden" aria-disabled="true" aria-describedby="' . $box['id'] . '-handle-order-lower-description">'; 1349 1349 echo '<span class="screen-reader-text">' . __( 'Move down' ) . '</span>'; 1350 1350 echo '<span class="order-lower-indicator" aria-hidden="true"></span>'; 1351 1351 echo '</button>';