0
Fork 0
mirror of https://github.com/fastmail/Squire.git synced 2025-01-03 05:00:13 -05:00

Strip HTML surrounding copied fragment added by Edge.

Fixes #181
This commit is contained in:
Neil Jenkins 2016-05-26 13:09:19 +10:00
parent 7ecf75f246
commit 6deae3c188
3 changed files with 42 additions and 14 deletions

View file

@ -3837,9 +3837,23 @@ var addLinks = function ( frag, root, self ) {
// insertTreeFragmentIntoRange will delete the selection so that it is replaced // insertTreeFragmentIntoRange will delete the selection so that it is replaced
// by the html being inserted. // by the html being inserted.
proto.insertHTML = function ( html, isPaste ) { proto.insertHTML = function ( html, isPaste ) {
var range = this.getSelection(), var range = this.getSelection();
frag = this._doc.createDocumentFragment(), var frag = this._doc.createDocumentFragment();
div = this.createElement( 'DIV' ); var div = this.createElement( 'DIV' );
var startFragmentIndex, endFragmentIndex;
var root, node, event;
// Edge doesn't just copy the fragment, but includes the surrounding guff
// including the full <head> of the page. Need to strip this out. In the
// future should probably run all pastes through DOMPurify, but this will
// do for now
if ( isPaste ) {
startFragmentIndex = html.indexOf( '<!--StartFragment-->' );
endFragmentIndex = html.lastIndexOf( '<!--EndFragment-->' );
if ( startFragmentIndex > -1 && endFragmentIndex > -1 ) {
html = html.slice( startFragmentIndex + 20, endFragmentIndex );
}
}
// Parse HTML into DOM tree // Parse HTML into DOM tree
div.innerHTML = html; div.innerHTML = html;
@ -3849,9 +3863,9 @@ proto.insertHTML = function ( html, isPaste ) {
this.saveUndoState( range ); this.saveUndoState( range );
try { try {
var root = this._root; root = this._root;
var node = frag; node = frag;
var event = { event = {
fragment: frag, fragment: frag,
preventDefault: function () { preventDefault: function () {
this.defaultPrevented = true; this.defaultPrevented = true;

File diff suppressed because one or more lines are too long

View file

@ -1609,9 +1609,23 @@ var addLinks = function ( frag, root, self ) {
// insertTreeFragmentIntoRange will delete the selection so that it is replaced // insertTreeFragmentIntoRange will delete the selection so that it is replaced
// by the html being inserted. // by the html being inserted.
proto.insertHTML = function ( html, isPaste ) { proto.insertHTML = function ( html, isPaste ) {
var range = this.getSelection(), var range = this.getSelection();
frag = this._doc.createDocumentFragment(), var frag = this._doc.createDocumentFragment();
div = this.createElement( 'DIV' ); var div = this.createElement( 'DIV' );
var startFragmentIndex, endFragmentIndex;
var root, node, event;
// Edge doesn't just copy the fragment, but includes the surrounding guff
// including the full <head> of the page. Need to strip this out. In the
// future should probably run all pastes through DOMPurify, but this will
// do for now
if ( isPaste ) {
startFragmentIndex = html.indexOf( '<!--StartFragment-->' );
endFragmentIndex = html.lastIndexOf( '<!--EndFragment-->' );
if ( startFragmentIndex > -1 && endFragmentIndex > -1 ) {
html = html.slice( startFragmentIndex + 20, endFragmentIndex );
}
}
// Parse HTML into DOM tree // Parse HTML into DOM tree
div.innerHTML = html; div.innerHTML = html;
@ -1621,9 +1635,9 @@ proto.insertHTML = function ( html, isPaste ) {
this.saveUndoState( range ); this.saveUndoState( range );
try { try {
var root = this._root; root = this._root;
var node = frag; node = frag;
var event = { event = {
fragment: frag, fragment: frag,
preventDefault: function () { preventDefault: function () {
this.defaultPrevented = true; this.defaultPrevented = true;