guardian/scribe

Scribe transactionManager assumes that selection is always inside an editor

Open

#153 opened on May 2, 2014

View on GitHub
 (10 comments) (0 reactions) (0 assignees)JavaScript (3,516 stars) (265 forks)batch import
bughelp wanted

Description

Scribe transactionManager assumes that selection is always inside an editor, but this can be wrong. I discovered issues because Scribe was modifying DOM outside editor.

We have the following scenario. User selects text outside the editor and based on that selection we prepopulate editor's content (I simply call jQuery .html(...) on the editor to set the content – should I use something else?). The issue is that as I prepopulate editor's content, mutation observer is triggered which calls transactionManager. And transaction manager calls:

var selection = new this.api.Selection();
selection.placeMarkers();

This places <em/> tags where selection is. But selection is outside the editor, not inside.

I think that code should check if selection is inside the editor element our outside.

Contributor guide