guardian/scribe
GitHub で見るScribe transactionManager assumes that selection is always inside an editor
Open
#153 opened on 2014年5月2日
bughelp wanted
説明
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.