Skip to content

Commit

Permalink
Add hover line + drag. See #249. Props @mimo84.
Browse files Browse the repository at this point in the history
  • Loading branch information
ellatrix committed Mar 13, 2017
1 parent 98b7161 commit 93c6e57
Show file tree
Hide file tree
Showing 3 changed files with 87 additions and 30 deletions.
14 changes: 14 additions & 0 deletions tinymce-single/blocks.js
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,20 @@
getControls: function() {
return _controls;
},
getParentBlock: function( node ) {
var editor = window.tinyMCE.activeEditor;
var rootNode = editor.getBody();

if ( node === rootNode || ! editor.getBody().contains( node ) ) {
return null;
}

while ( node.parentNode !== rootNode ) {
node = node.parentNode;
}

return node;
},
getSelectedBlocks: function() {
var editor = window.tinyMCE.activeEditor;
var selection = window.getSelection();
Expand Down
5 changes: 5 additions & 0 deletions tinymce-single/tinymce/block.css
Original file line number Diff line number Diff line change
Expand Up @@ -265,6 +265,11 @@ div.mce-inline-toolbar-grp.block-toolbar > div.mce-stack-layout {
border: 2px solid #e0e5e9;
}

.block-outline-hover:before {
border: none;
border-left: 2px solid #e0e5e9;
}

.block-outline-handle {
position: absolute;
width: 20px;
Expand Down
98 changes: 68 additions & 30 deletions tinymce-single/tinymce/block.js
Original file line number Diff line number Diff line change
Expand Up @@ -178,6 +178,9 @@
editor.on( 'preinit', function() {
var DOM = tinymce.DOM;
var hidden = true;
var hoverTarget;
var dragTarget;
var isDragging = false;

editor.addButton( 'block', {
icon: 'gridicons-posts',
Expand Down Expand Up @@ -310,64 +313,73 @@

var blockToolbarWidth = 0;

function createBlockOutline() {
function createBlockOutline( hover ) {
var outline = document.createElement( 'div' );
var handleLeft = document.createElement( 'div' );
var handleRight = document.createElement( 'div' );

outline.className = 'block-outline';
if ( hover ) {
outline.className = 'block-outline block-outline-hover';
} else {
outline.className = 'block-outline';
}

handleLeft.className = 'block-outline-handle block-outline-handle-right';
handleRight.className = 'block-outline-handle block-outline-handle-left';
outline.appendChild( handleLeft );
outline.appendChild( handleRight );
document.body.appendChild( outline );

var target;

DOM.bind( outline, 'mousedown', function( event ) {
var newEvent = Object.assign( {}, event );

target = getSelectedBlock();
if ( hover ) {
dragTarget = hoverTarget;
} else {
dragTarget = getSelectedBlock();
}

if ( target.getAttribute( 'contenteditable' ) !== 'false' ) {
target.setAttribute( 'contenteditable', 'false' );
if ( dragTarget.getAttribute( 'contenteditable' ) !== 'false' ) {
dragTarget.setAttribute( 'contenteditable', 'false' );
}

newEvent.target = target;
newEvent.target = dragTarget;

editor.fire( 'mousedown', newEvent );
} );

editor.on( 'dragstart', function( event ) {
if ( ! target ) {
event.preventDefault();
return;
}
return outline;
}

hidden = true;
editor.on( 'dragstart', function( event ) {
if ( ! dragTarget ) {
event.preventDefault();
return;
}

hideBlockUI();
isDragging = true;
hidden = true;

target.setAttribute( 'data-wp-block-dragging', 'true' );
hideBlockUI();

function end( event ) {
DOM.unbind( editor.getDoc(), 'mouseup', end );
dragTarget.setAttribute( 'data-wp-block-dragging', 'true' );

target = null;
function end( event ) {
DOM.unbind( editor.getDoc(), 'mouseup', end );

setTimeout( function() {
editor.$( '*[data-wp-block-dragging]' )
.attr( 'data-wp-block-dragging', null )
.attr( 'contenteditable', null );
editor.nodeChanged();
} );
}
isDragging = false;
dragTarget = null;

DOM.bind( editor.getDoc(), 'mouseup', end );
} );
setTimeout( function() {
editor.$( '*[data-wp-block-dragging]' )
.attr( 'data-wp-block-dragging', null )
.attr( 'contenteditable', null );
editor.nodeChanged();
} );
}

return outline;
}
DOM.bind( editor.getDoc(), 'mouseup', end );
} );

function createInsertToolbar() {
var insert = editor.wp._createToolbar( [ 'add' ] );
Expand Down Expand Up @@ -590,13 +602,39 @@

var UI = {
outline: createBlockOutline(),
hoverOutline: createBlockOutline( true ),
insert: createInsertToolbar(),
insertMenu: createInsertMenu(),
inline: createInlineToolbar(),
navigation: createBlockNavigation(),
blocks: createBlockToolbars()
};

editor.on( 'mouseover', function( event ) {
var target = wp.blocks.getParentBlock( event.target );

if ( target && target !== hoverTarget ) {
if ( isDragging || wp.blocks.getSelectedBlock() === hoverTarget ) {
DOM.setStyles( UI.hoverOutline, {
display: 'none'
} );
} else {
var rect = target.getBoundingClientRect();

DOM.setStyles( UI.hoverOutline, {
display: 'block',
position: 'absolute',
left: rect.left + 'px',
top: rect.top + window.pageYOffset + 'px',
height: rect.height + 'px',
width: rect.width + 'px'
} );
}

hoverTarget = target;
}
} );

var range;

editor.on( 'blur', function() {
Expand Down

0 comments on commit 93c6e57

Please sign in to comment.