Editor scrolling:

* Reduce the starting height of the editor to better match the height at which the top toolbar unpins.
* Pin the side metaboxes so they do not get lost when the editor content is long.
* Turn magic numbers into variables.

props stephdau, azaozz. see #28328.


Built from https://develop.svn.wordpress.org/trunk@29495


git-svn-id: http://core.svn.wordpress.org/trunk@29273 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
Helen Hou-Sandí 2014-08-15 03:17:15 +00:00
parent 81815c4d03
commit da2d975668
6 changed files with 148 additions and 28 deletions

View File

@ -405,6 +405,10 @@ td.plugin-title p {
} }
/* end editor-expand.js override */ /* end editor-expand.js override */
#poststuff #post-body.columns-2 #side-sortables {
width: 280px;
}
#timestampdiv select { #timestampdiv select {
height: 21px; height: 21px;
line-height: 14px; line-height: 14px;
@ -1229,6 +1233,7 @@ table.links-table {
#poststuff #post-body.columns-2 #side-sortables { #poststuff #post-body.columns-2 #side-sortables {
min-height: 0; min-height: 0;
width: auto;
} }
/* hide the radio buttons for column prefs */ /* hide the radio buttons for column prefs */

View File

@ -405,6 +405,10 @@ td.plugin-title p {
} }
/* end editor-expand.js override */ /* end editor-expand.js override */
#poststuff #post-body.columns-2 #side-sortables {
width: 280px;
}
#timestampdiv select { #timestampdiv select {
height: 21px; height: 21px;
line-height: 14px; line-height: 14px;
@ -1229,6 +1233,7 @@ table.links-table {
#poststuff #post-body.columns-2 #side-sortables { #poststuff #post-body.columns-2 #side-sortables {
min-height: 0; min-height: 0;
width: auto;
} }
/* hide the radio buttons for column prefs */ /* hide the radio buttons for column prefs */

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View File

@ -6,6 +6,7 @@ jQuery( document ).ready( function($) {
var $window = $( window ), var $window = $( window ),
$document = $( document ), $document = $( document ),
$adminBar = $( '#wpadminbar' ), $adminBar = $( '#wpadminbar' ),
$footer = $( '#wpfooter' ),
$wrap = $( '#postdivrich' ), $wrap = $( '#postdivrich' ),
$contentWrap = $( '#wp-content-wrap' ), $contentWrap = $( '#wp-content-wrap' ),
$tools = $( '#wp-content-editor-tools' ), $tools = $( '#wp-content-editor-tools' ),
@ -16,13 +17,23 @@ jQuery( document ).ready( function($) {
$textEditorClone = $( '<div id="content-textarea-clone"></div>' ), $textEditorClone = $( '<div id="content-textarea-clone"></div>' ),
$bottom = $( '#post-status-info' ), $bottom = $( '#post-status-info' ),
$statusBar, $statusBar,
$sideSortables = $( '#side-sortables' ),
$postboxContainer = $( '#postbox-container-1' ),
$postBody = $('#post-body'),
fullscreen = window.wp.editor && window.wp.editor.fullscreen, fullscreen = window.wp.editor && window.wp.editor.fullscreen,
mceEditor, mceEditor,
mceBind = function(){}, mceBind = function(){},
mceUnbind = function(){}, mceUnbind = function(){},
fixedTop = false, fixedTop = false,
fixedBottom = false, fixedBottom = false,
scrollTimer; fixedSideTop = false,
fixedSideBottom = false,
scrollTimer,
lastScrollPosition = 0,
pageYOffsetAtTop = 130,
pinnedToolsTop = 56, // also used in CSS for the "#poststuff #post-body #postbox-container-1.pinned" selector
textEditorClonePaddingTop = 37,
autoresizeMinHeight = 300; // $window.height() - 310;
$textEditorClone.insertAfter( $textEditor ); $textEditorClone.insertAfter( $textEditor );
@ -31,7 +42,7 @@ jQuery( document ).ready( function($) {
'font-size': $textEditor.css( 'font-size' ), 'font-size': $textEditor.css( 'font-size' ),
'line-height': $textEditor.css( 'line-height' ), 'line-height': $textEditor.css( 'line-height' ),
'padding': $textEditor.css( 'padding' ), 'padding': $textEditor.css( 'padding' ),
'padding-top': 37, 'padding-top': textEditorClonePaddingTop,
'white-space': 'pre-wrap', 'white-space': 'pre-wrap',
'word-wrap': 'break-word' 'word-wrap': 'break-word'
} ); } );
@ -88,8 +99,8 @@ jQuery( document ).ready( function($) {
hiddenHeight = $textEditorClone.height(); hiddenHeight = $textEditorClone.height();
if ( hiddenHeight < 300 ) { if ( hiddenHeight < autoresizeMinHeight ) {
hiddenHeight = 300; hiddenHeight = autoresizeMinHeight;
} }
if ( hiddenHeight === textEditorHeight ) { if ( hiddenHeight === textEditorHeight ) {
@ -112,7 +123,7 @@ jQuery( document ).ready( function($) {
mceEditor = editor; mceEditor = editor;
// Set the minimum height to the initial viewport height. // Set the minimum height to the initial viewport height.
editor.settings.autoresize_min_height = 300; editor.settings.autoresize_min_height = autoresizeMinHeight;
// Get the necessary UI elements. // Get the necessary UI elements.
$visualTop = $contentWrap.find( '.mce-toolbar-grp' ); $visualTop = $contentWrap.find( '.mce-toolbar-grp' );
@ -218,8 +229,12 @@ jQuery( document ).ready( function($) {
adminBarHeight = windowWidth > 600 ? $adminBar.height() : 0, adminBarHeight = windowWidth > 600 ? $adminBar.height() : 0,
resize = type !== 'scroll', resize = type !== 'scroll',
visual = ( mceEditor && ! mceEditor.isHidden() ), visual = ( mceEditor && ! mceEditor.isHidden() ),
buffer = 200, buffer = autoresizeMinHeight + adminBarHeight,
$top, $editor, postBodyTop = $postBody.offset().top,
borderWidth = 1,
contentWrapWidth = $contentWrap.width(),
sideSortablesHeight = $sideSortables.height(),
$top, $editor, sidebarTop, footerTop,
toolsHeight, topPos, topHeight, editorPos, editorHeight, editorWidth, statusBarHeight; toolsHeight, topPos, topHeight, editorPos, editorHeight, editorWidth, statusBarHeight;
if ( visual ) { if ( visual ) {
@ -238,25 +253,27 @@ jQuery( document ).ready( function($) {
editorWidth = $editor.outerWidth(); editorWidth = $editor.outerWidth();
statusBarHeight = visual ? $statusBar.outerHeight() : 0; statusBarHeight = visual ? $statusBar.outerHeight() : 0;
// Maybe pin the top. // Maybe pin the top.
if ( ( ! fixedTop || resize ) && if ( ( ! fixedTop || resize ) &&
// Handle scrolling down. // Handle scrolling down.
( windowPos >= ( topPos - toolsHeight - adminBarHeight ) && ( windowPos >= ( topPos - toolsHeight - adminBarHeight ) &&
// Handle scrolling up. // Handle scrolling up.
windowPos <= ( topPos - toolsHeight - adminBarHeight + editorHeight - buffer ) ) ) { windowPos <= ( topPos - toolsHeight - adminBarHeight + editorHeight - buffer ) ) ) {
fixedTop = true; fixedTop = true;
$top.css( { $top.css( {
position: 'fixed', position: 'fixed',
top: adminBarHeight + toolsHeight, top: adminBarHeight + toolsHeight,
width: $editor.parent().width() - ( $top.outerWidth() - $top.width() ), width: contentWrapWidth - ( borderWidth * 2 ) - ( visual ? 0 : ( $top.outerWidth() - $top.width() ) ),
borderTop: '1px solid #e5e5e5' borderTop: '1px solid #e5e5e5'
} ); } );
$tools.css( { $tools.css( {
position: 'fixed', position: 'fixed',
top: adminBarHeight, top: adminBarHeight,
width: editorWidth + 2 width: contentWrapWidth
} ); } );
// Maybe unpin the top. // Maybe unpin the top.
} else if ( fixedTop || resize ) { } else if ( fixedTop || resize ) {
@ -268,13 +285,13 @@ jQuery( document ).ready( function($) {
position: 'absolute', position: 'absolute',
top: 0, top: 0,
borderTop: 'none', borderTop: 'none',
width: $editor.parent().width() - ( $top.outerWidth() - $top.width() ) width: contentWrapWidth - ( borderWidth * 2 ) - ( visual ? 0 : ( $top.outerWidth() - $top.width() ) )
} ); } );
$tools.css( { $tools.css( {
position: 'absolute', position: 'absolute',
top: 0, top: 0,
width: $contentWrap.width() width: contentWrapWidth
} ); } );
// Handle scrolling down. // Handle scrolling down.
} else if ( windowPos >= ( topPos - toolsHeight - adminBarHeight + editorHeight - buffer ) ) { } else if ( windowPos >= ( topPos - toolsHeight - adminBarHeight + editorHeight - buffer ) ) {
@ -282,31 +299,33 @@ jQuery( document ).ready( function($) {
$top.css( { $top.css( {
position: 'absolute', position: 'absolute',
top: editorHeight - buffer top: editorHeight - buffer,
width: contentWrapWidth - ( borderWidth * 2 ) - ( visual ? 0 : ( $top.outerWidth() - $top.width() ) )
} ); } );
$tools.css( { $tools.css( {
position: 'absolute', position: 'absolute',
top: editorHeight - buffer + 1, // border top: editorHeight - buffer + borderWidth, // border
width: $contentWrap.width() width: contentWrapWidth
} ); } );
} }
} }
// Maybe adjust the bottom bar. // Maybe adjust the bottom bar.
if ( ( ! fixedBottom || resize ) && if ( ( ! fixedBottom || resize ) &&
// + 1 for the border around the .wp-editor-container. // +[n] for the border around the .wp-editor-container.
( windowPos + windowHeight ) <= ( editorPos + editorHeight + bottomHeight + statusBarHeight + 1 ) ) { ( windowPos + windowHeight ) <= ( editorPos + editorHeight + bottomHeight + statusBarHeight + borderWidth ) ) {
fixedBottom = true; fixedBottom = true;
$bottom.css( { $bottom.css( {
position: 'fixed', position: 'fixed',
bottom: 0, bottom: 0,
width: editorWidth + 2, width: editorWidth + ( borderWidth * 2 ),
borderTop: '1px solid #dedede' borderTop: '1px solid #dedede'
} ); } );
} else if ( ( fixedBottom || resize ) && } else if ( ( fixedBottom || resize ) &&
( windowPos + windowHeight ) > ( editorPos + editorHeight + bottomHeight + statusBarHeight - 1 ) ) { ( windowPos + windowHeight ) > ( editorPos + editorHeight + bottomHeight + statusBarHeight - borderWidth ) ) {
fixedBottom = false; fixedBottom = false;
$bottom.css( { $bottom.css( {
@ -317,6 +336,95 @@ jQuery( document ).ready( function($) {
} ); } );
} }
// Sidebar pinning
if ( $postboxContainer.width() < 300 && windowWidth > 600 && // sidebar position is changed with @media from CSS, make sure it is on the side
$document.height() > ( $sideSortables.height() + postBodyTop + 120 ) && // the sidebar is not the tallest element
windowHeight < editorHeight * 0.7 ) { // the editor is taller than the viewport
if ( sideSortablesHeight > windowHeight || fixedSideTop || fixedSideBottom ) {
// Reset when scrolling to the top
if ( windowPos + pinnedToolsTop <= postBodyTop ) {
$sideSortables.attr( 'style', '' );
fixedSideTop = fixedSideBottom = false;
} else {
if ( windowPos > lastScrollPosition ) {
// Scrolling down
if ( fixedSideTop ) {
// let it scroll
fixedSideTop = false;
sidebarTop = $sideSortables.offset().top - adminBarHeight;
footerTop = $footer.offset().top;
// don't get over the footer
if ( footerTop < sidebarTop + sideSortablesHeight + 20 ) {
sidebarTop = footerTop - sideSortablesHeight - 20;
}
$sideSortables.css({
position: 'absolute',
top: sidebarTop,
bottom: ''
});
} else if ( ! fixedSideBottom && sideSortablesHeight + $sideSortables.offset().top + 20 < windowPos + windowHeight ) {
// pin the bottom
fixedSideBottom = true;
$sideSortables.css({
position: 'fixed',
top: 'auto',
bottom: '20px'
});
}
} else if ( windowPos < lastScrollPosition ) {
// Scrolling up
if ( fixedSideBottom ) {
// let it scroll
fixedSideBottom = false;
sidebarTop = $sideSortables.offset().top - 20;
footerTop = $footer.offset().top;
// don't get over the footer
if ( footerTop < sidebarTop + sideSortablesHeight + 20 ) {
sidebarTop = footerTop - sideSortablesHeight - 20;
}
$sideSortables.css({
position: 'absolute',
top: sidebarTop,
bottom: ''
});
} else if ( ! fixedSideTop && $sideSortables.offset().top >= windowPos + pinnedToolsTop ) {
// pin the top
fixedSideTop = true;
$sideSortables.css({
position: 'fixed',
top: pinnedToolsTop,
bottom: ''
});
}
}
}
} else {
// if the sidebar container is smaller than the viewport, then pin/unpin the top when scrolling
if ( windowPos >= ( postBodyTop - pinnedToolsTop ) ) {
$sideSortables.css( {
position: 'fixed',
top: pinnedToolsTop
} );
} else {
$sideSortables.attr( 'style', '' );
}
fixedSideTop = fixedSideBottom = false;
}
lastScrollPosition = windowPos;
} else {
$sideSortables.attr( 'style', '' );
fixedSideTop = fixedSideBottom = false;
}
if ( resize ) { if ( resize ) {
$contentWrap.css( { $contentWrap.css( {
paddingTop: $tools.outerHeight() paddingTop: $tools.outerHeight()
@ -354,7 +462,7 @@ jQuery( document ).ready( function($) {
function on() { function on() {
// Scroll to the top when triggering this from JS. // Scroll to the top when triggering this from JS.
// Ensures toolbars are pinned properly. // Ensures toolbars are pinned properly.
if ( window.pageYOffset && window.pageYOffset > 130 ) { if ( window.pageYOffset && window.pageYOffset > pageYOffsetAtTop ) {
window.scrollTo( window.pageXOffset, 0 ); window.scrollTo( window.pageXOffset, 0 );
} }
@ -397,7 +505,7 @@ jQuery( document ).ready( function($) {
// Scroll to the top when triggering this from JS. // Scroll to the top when triggering this from JS.
// Ensures toolbars are reset properly. // Ensures toolbars are reset properly.
if ( window.pageYOffset && window.pageYOffset > 130 ) { if ( window.pageYOffset && window.pageYOffset > pageYOffsetAtTop ) {
window.scrollTo( window.pageXOffset, 0 ); window.scrollTo( window.pageXOffset, 0 );
} }
@ -417,10 +525,12 @@ jQuery( document ).ready( function($) {
fullscreen && fullscreen.pubsub.unsubscribe( 'hidden', fullscreenHide ); fullscreen && fullscreen.pubsub.unsubscribe( 'hidden', fullscreenHide );
// Reset all css // Reset all css
$.each( [ $visualTop, $textTop, $tools, $bottom, $contentWrap, $visualEditor, $textEditor ], function( i, element ) { $.each( [ $visualTop, $textTop, $tools, $bottom, $contentWrap, $visualEditor, $textEditor, $sideSortables ], function( i, element ) {
element && element.attr( 'style', '' ); element && element.attr( 'style', '' );
}); });
fixedTop = fixedBottom = fixedSideTop = fixedSideBottom = false;
if ( mceEditor ) { if ( mceEditor ) {
mceEditor.settings.wp_autoresize_on = false; mceEditor.settings.wp_autoresize_on = false;
mceEditor.execCommand( 'wpAutoResizeOff' ); mceEditor.execCommand( 'wpAutoResizeOff' );

File diff suppressed because one or more lines are too long