wip: experiments with Canvas support for exercise.assign
[fnpeditor.git] / src / editor / modules / documentCanvas / canvas / utils.js
index 89ed192..3efc450 100644 (file)
@@ -20,68 +20,68 @@ var nearestInDocumentOrder = function(selector, direction, element) {
     return null;
 };
 
     return null;
 };
 
-var findCanvasElement = function(node, childOf) {
-    if(node.nodeType === Node.ELEMENT_NODE) {
-        return node.getData('canvasElement');
-    }
-    if(node.nodeType === Node.TEXT_NODE) {
-        return findCanvasElementInParent(node, childOf || node.parent());
-    }
-};
-
-/**
- * We take child and its parent as arguments separatly to
- * handle situation where child was removed from WLXMLDocument
- * and it lost reference to its parent (but we may still have it on canvas).
-*/
-var findCanvasElementInParent = function(wlxmlChildNode, wlxmlParentNode) {
-    var parentElement, toret;
-
-    if(wlxmlParentNode === null) {
-        toret = wlxmlChildNode.getData('canvasElement');
-        if(toret.parent()) {
-            throw new Error('This should never happen: root canvas element doesn\'t render root document node!');
-        }
-    } else {
-        parentElement = findCanvasElement(wlxmlParentNode);
-        parentElement.children().forEach(function(child) {
-            if(child.wlxmlNode.sameNode(wlxmlChildNode)) { // czemu tu, przy drugim undo child nie mial data?
-                toret = child;
+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 toret;
+    return node.getData(mirrors ? 'mirrorElements' : 'canvasElement');
 };
 
 };
 
-var getElementForNode = function(node) {
-
-    var ptr = node.nodeType === Node.TEXT_NODE ? node.parent() : node;
-    while(!ptr.getData('canvasElement')) {
-        ptr = ptr.parent();
+var getElementForNode = function(node, mirrors) {
+    while(!node.getData('canvasElement')) {
+        node = node.parent();
     }
     }
-    return ptr.getData('canvasElement');
+    return node.getData(mirrors ? 'mirrorElements' : 'canvasElement');
 };
 
 };
 
-var getElementForDetachedNode = function(node, originalParent) {
+var getElementForDetachedNode = function(node, originalParent, mirrors) {
     var ptr = originalParent;
     if(ptr === null) {
     var ptr = originalParent;
     if(ptr === null) {
-        return node.getData('canvasElement');
+        return node.getData(mirrors ? 'mirrorElements' : 'canvasElement');
     }
     while(!ptr.getData('canvasElement')) {
         ptr = ptr.parent();
     }
     }
     while(!ptr.getData('canvasElement')) {
         ptr = ptr.parent();
     }
-    return ptr.getData('canvasElement');
+    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
+    };
 };
 
 };
 
+
 return {
     nearestInDocumentOrder: nearestInDocumentOrder,
 return {
     nearestInDocumentOrder: nearestInDocumentOrder,
-    findCanvasElement: findCanvasElement,
-    findCanvasElementInParent: findCanvasElementInParent,
     unicode: {
         ZWS: '\u200B'
     },
     getElementForNode: getElementForNode,
     unicode: {
         ZWS: '\u200B'
     },
     getElementForNode: getElementForNode,
-    getElementForDetachedNode: getElementForDetachedNode
+    getElementForDetachedNode: getElementForDetachedNode,
+    getElementForElementRootNode: getElementForElementRootNode,
+    caretPositionFromPoint: caretPositionFromPoint
 };
 
 });
 };
 
 });