diff options
author | Mark Wells <mark@freeside.biz> | 2015-12-09 17:23:46 -0800 |
---|---|---|
committer | Mark Wells <mark@freeside.biz> | 2015-12-09 17:24:03 -0800 |
commit | 991011f4ffc62b739f123a2124ca93f461d398ce (patch) | |
tree | 6fa9e2926af5f9df9544c7a5177d1eca5179d8e0 | |
parent | d0c5ecc6d52a28f583ec45afc3460dc613b38eba (diff) |
fix strange behavior after inserting a substitution, #38803, fallout from #24331
-rw-r--r-- | httemplate/elements/ckeditor/plugins/blockprotect/plugin.js | 15 | ||||
-rw-r--r-- | httemplate/elements/htmlarea.html | 3 |
2 files changed, 16 insertions, 2 deletions
diff --git a/httemplate/elements/ckeditor/plugins/blockprotect/plugin.js b/httemplate/elements/ckeditor/plugins/blockprotect/plugin.js index e4ef39167..96c0f42b3 100644 --- a/httemplate/elements/ckeditor/plugins/blockprotect/plugin.js +++ b/httemplate/elements/ckeditor/plugins/blockprotect/plugin.js @@ -133,7 +133,20 @@ } // span function } // elements }); - } + + editor.on( 'afterInsertHtml', function( evt ) { + // if this leaves an open SPAN, move the cursor + // to after it + var range = editor.getSelection().getRanges()[0]; + var ec = range.endContainer; + if ( ec.hasClass('cke_blockprotect') ) { + range.setEndAfter(ec); + range.collapse(); + editor.getSelection().selectRanges([ range ]); + } + }); + + } // afterInit }); // plugins.add }) (); diff --git a/httemplate/elements/htmlarea.html b/httemplate/elements/htmlarea.html index c98993d40..0ba417795 100644 --- a/httemplate/elements/htmlarea.html +++ b/httemplate/elements/htmlarea.html @@ -20,7 +20,8 @@ Example: <SCRIPT TYPE="text/javascript"> - CKEDITOR.replace('<% $opt{'field'} %>', + var <% $opt{'field'} %>_editor = + CKEDITOR.replace('<% $opt{'field'} %>', <% encode_json($config) %> ); |