+};
+
+var getElementForElementRootNode = function(node, mirrors, canvasContainer) {
+ if(canvasContainer) {
+ var candidates = [node.getData('canvasElement')].concat(node.getData('mirrorElements')),
+ toret;
+ candidates.some(function(c) {
+ // @@
+ if(c.dom.parents().index(canvasContainer.dom) !== -1) {
+ toret = c;
+ return true;
+ }
+ });
+ return toret;
+ }
+ return node.getData(mirrors ? 'mirrorElements' : 'canvasElement');
+};
+
+var getElementForNode = function(node, mirrors) {
+ while(!node.getData('canvasElement')) {
+ node = node.parent();
+ }
+ return node.getData(mirrors ? 'mirrorElements' : 'canvasElement');
+};
+
+var getElementForDetachedNode = function(node, originalParent, mirrors) {
+ var ptr = originalParent;
+ if(ptr === null) {
+ return node.getData(mirrors ? 'mirrorElements' : 'canvasElement');
+ }
+ while(!ptr.getData('canvasElement')) {
+ ptr = ptr.parent();
+ }
+ return ptr.getData(mirrors ? 'mirrorElements' : 'canvasElement');
+};
+
+var caretPositionFromPoint = function(x, y) {
+ /* globals document */
+ var range, textNode, offset;
+ if(document.caretPositionFromPoint) {
+ range = document.caretPositionFromPoint(x, y);
+ textNode = range.offsetNode;
+ offset = range.offset;
+ } else if(document.caretRangeFromPoint) {
+ range = document.caretRangeFromPoint(x, y);
+ textNode = range.startContainer;
+ offset = range.startOffset;
+ }
+ return {
+ textNode: textNode,
+ offset: offset
+ };
+};
+