2 'libs/jquery-1.9.1.min',
\r 
   3 'libs/underscore-min',
\r 
   4 'modules/documentCanvas/transformations',
\r 
   5 'modules/documentCanvas/wlxmlNode',
\r 
   6 'libs/text!./template.html'
\r 
   7 ], function($, _, transformations, wlxmlNode, template) {
\r 
  11 var Canvas = function(xml) {
\r 
  12     this.dom = $(template);
\r 
  13     this.content = this.dom.find('#rng-module-documentCanvas-content');
\r 
  17 Canvas.prototype.setXML = function(xml) {
\r 
  19     this.content.html(transformations.fromXML.getHTMLTree(xml));  
\r 
  22 Canvas.prototype.toXML = function() {
\r 
  23     return transformations.toXML.getXML(this.content.html());
\r 
  26 Canvas.prototype.getNode = function(desc) {
\r 
  29         selector += '[wlxml-class=' + desc.klass + ']';
\r 
  31         selector += '[wlxml-tag=' + desc.tag + ']';
\r 
  33     this.content.find(selector).each(function() {
\r 
  34         toret.push(new wlxmlNode.Node($(this)));
\r 
  39 Canvas.prototype._createNode = function(wlxmlTag, wlxmlClass) {
\r 
  40             var toBlock = ['div', 'document', 'section', 'header'];
\r 
  41             var htmlTag = _.contains(toBlock, wlxmlTag) ? 'div' : 'span';
\r 
  42             var toret = $('<' + htmlTag + '>');
\r 
  43             toret.attr('wlxml-tag', wlxmlTag);
\r 
  45                 toret.attr('wlxml-class', wlxmlClass);
\r 
  46             toret.attr('id', 'xxxxxxxx-xxxx-xxxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function(c) {var r = Math.random()*16|0,v=c=='x'?r:r&0x3|0x8;return v.toString(16);}));
\r 
  50 Canvas.prototype.insertNode = function(options) {
\r 
  51     var element = $(this.content.find('#' + options.context.id).get(0));
\r 
  52     if(options.place == 'after')
\r 
  53         element[options.place](this._createNode(options.tag, options.klass));
\r 
  54     else if(options.place == 'wrapText') {
\r 
  55         var elementContents = element.contents();
\r 
  56         if(elementContents.length !== 1 || elementContents.get(0).nodeType != 3)
\r 
  58         var textElement = elementContents.get(0);
\r 
  60         var prefix = textElement.data.substr(0, options.offsetStart);
\r 
  61         var suffix = textElement.data.substr(options.offsetEnd);
\r 
  62         var core = textElement.data.substr(options.offsetStart, options.offsetEnd - options.offsetStart);
\r 
  63         var newNode = this._createNode(options.tag, options.klass);
\r 
  65         $(textElement).replaceWith(newNode);
\r 
  66         newNode.before(prefix);
\r 
  67         newNode.after(suffix);
\r 
  71 Canvas.prototype.splitNode = function(options) {
\r 
  72     options = _.extend({textNodeIdx: 0}, options);
\r 
  74     var nodeToSplit = $(this.content.find('#' + options.node.id).get(0));
\r 
  76     var nodeContents = nodeToSplit.contents();
\r 
  77     if(nodeContents.length === 0 || 
\r 
  78        nodeContents.length - 1 < options.textNodeIdx || 
\r 
  79        nodeContents.get(options.textNodeIdx).nodeType != 3)
\r 
  82     var textNode = $(nodeContents.get(options.textNodeIdx));
\r 
  84     var succeedingNodes = [];
\r 
  86     nodeContents.each(function() {
\r 
  89             succeedingNodes.push(node);
\r 
  90         if(node.isSameNode(textNode.get(0)))
\r 
  94     var prefix = textNode.text().substr(0, options.offset);
\r 
  95     var suffix = textNode.text().substr(options.offset);
\r 
  97     textNode.before(prefix);
\r 
 100     var newNode = this._createNode(nodeToSplit.attr('wlxml-tag'), nodeToSplit.attr('wlxml-class'));
\r 
 101     newNode.append(suffix);
\r 
 102     succeedingNodes.forEach(function(node) {
\r 
 103         newNode.append(node)
\r 
 105     nodeToSplit.after(newNode);
\r 
 109 Canvas.prototype.removeNode = function(options) {
\r 
 110     var toRemove = $(this.content.find('#' + options.node.id).get(0));
\r 
 115 Canvas.prototype.createList = function(options) {
\r 
 116     var element1 = $(this.content.find('#' + options.start.id).get(0));
\r 
 117     var element2 = $(this.content.find('#' + options.end.id).get(0));
\r 
 118     if(!element1.parent().get(0).isSameNode(element2.parent().get(0)))
\r 
 121     var parent = element1.parent();
\r 
 122     var nodesToWrap = [];
\r 
 124     var place = 'before';
\r 
 126     parent.contents().each(function() {
\r 
 128         if(node.isSameNode(element1.get(0)))
\r 
 130         if(place === 'inside') {
\r 
 132             if(node.nodeType === 3) {
\r 
 133                 $node = canvas._createNode('div').text(node.data);
\r 
 139             $node.attr('wlxml-class', 'list.item');
\r 
 140             nodesToWrap.push($node);
\r 
 142         if(node.isSameNode(element2.get(0)))
\r 
 146     var list = this._createNode('div', 'list');
\r 
 147     element1.before(list);
\r 
 149     nodesToWrap.forEach(function(node) {
\r 
 159 return {Canvas: Canvas, Node: Node};
\r