X-Git-Url: https://git.mdrn.pl/fnpeditor.git/blobdiff_plain/9db0e3facfdcb376b589ea922215bbdb1a3d1787..d6174a70be823dd5772d845b83e11d0b779ab513:/modules/documentCanvas/canvas/documentElement.js
diff --git a/modules/documentCanvas/canvas/documentElement.js b/modules/documentCanvas/canvas/documentElement.js
index ba859fc..94b8422 100644
--- a/modules/documentCanvas/canvas/documentElement.js
+++ b/modules/documentCanvas/canvas/documentElement.js
@@ -1,7 +1,8 @@
define([
'libs/jquery-1.9.1.min',
-'libs/underscore-min'
-], function($, _) {
+'libs/underscore-min',
+'modules/documentCanvas/classAttributes'
+], function($, _, classAttributes) {
'use strict';
@@ -116,6 +117,12 @@ $.extend(DocumentNodeElement, {
.attr('wlxml-tag', params.tag);
if(params.klass)
dom.attr('wlxml-class', params.klass.replace(/\./g, '-'));
+ if(params.meta) {
+ _.keys(params.meta).forEach(function(key) {
+ dom.attr('wlxml-meta-'+key, params.meta[key]);
+ });
+ }
+ dom.data('other-attrs', params.others);
return dom;
},
@@ -142,7 +149,45 @@ var manipulate = function(e, params, action) {
DocumentNodeElement.prototype = new DocumentElement();
$.extend(DocumentNodeElement.prototype, {
+ data: function() {
+ var dom = this.dom(),
+ args = Array.prototype.slice.call(arguments, 0);
+ if(args.length === 2 && args[1] === undefined)
+ return dom.removeData(args[1]);
+ return dom.data.apply(dom, arguments);
+ },
+ toXML: function(level) {
+ var node = $('<' + this.getWlxmlTag() + '>'),
+ toret = $('
');
+ if(this.getWlxmlClass())
+ node.attr('class', this.getWlxmlClass());
+ var meta = this.getWlxmlMetaAttrs();
+ meta.forEach(function(attr) {
+ if(attr.value)
+ node.attr('meta-' + attr.name, attr.value);
+ });
+ _.keys(this.data('other-attrs') || {}).forEach(function(key) {
+ node.attr(key, this.data('other-attrs')[key]);
+ }, this);
+
+ if(this.data('orig-before') !== undefined) {
+ toret.append(document.createTextNode(this.data('orig-before')));
+ } else if(level && this.getWlxmlTag() !== 'span') {
+ toret.append('\n' + (new Array(level * 2 + 1)).join(' '));
+ }
+ if(this.data('orig-append') !== undefined) {
+ node.append(this.data('orig-append'));
+ //toret = toret.prepend(document.createTextNode(this.data('orig-prepend')));
+ } else if(this.getWlxmlTag() !== 'span'){
+ node.append('\n' + (new Array(level * 2 + 1)).join(' '));
+ }
+
+ toret.append(node);
+ return toret.contents();
+ },
append: function(params) {
+ if(params.tag !== 'span')
+ this.data('orig-append', undefined);
return manipulate(this, params, 'append');
},
before: function(params) {
@@ -196,6 +241,11 @@ $.extend(DocumentNodeElement.prototype, {
return undefined;
},
setWlxmlClass: function(klass) {
+ this.getWlxmlMetaAttrs().forEach(function(attr) {
+ if(!classAttributes.hasMetaAttr(klass, attr.name))
+ this.dom().removeAttr('wlxml-meta-' + attr.name);
+ }, this);
+
if(klass)
this.dom().attr('wlxml-class', klass.replace(/\./g, '-'));
else
@@ -205,6 +255,22 @@ $.extend(DocumentNodeElement.prototype, {
if(what === 'list' && _.contains(['list-items', 'list-items-enum'], this.dom().attr('wlxml-class')))
return true;
return false;
+ },
+
+
+ getWlxmlMetaAttr: function(attr) {
+ return this.dom().attr('wlxml-meta-'+attr);
+ },
+ getWlxmlMetaAttrs: function() {
+ var toret = [];
+ var attrList = classAttributes.getMetaAttrsList(this.getWlxmlClass());
+ attrList.all.forEach(function(attr) {
+ toret.push({name: attr.name, value: this.getWlxmlMetaAttr(attr.name) || ''});
+ }, this);
+ return toret;
+ },
+ setWlxmlMetaAttr: function(attr, value) {
+ this.dom().attr('wlxml-meta-'+attr, value);
}
});
@@ -233,6 +299,9 @@ $.extend(DocumentTextElement, {
DocumentTextElement.prototype = new DocumentElement();
$.extend(DocumentTextElement.prototype, {
+ toXML: function() {
+ return this.getText();
+ },
_setupDOMHandler: function(htmlElement) {
var $element = $(htmlElement);
if(htmlElement.nodeType === Node.TEXT_NODE)
@@ -288,8 +357,10 @@ $.extend(DocumentTextElement.prototype, {
}
},
unwrap: function() {
- var parent = this.parent();
+ var parent = this.parent(),
+ toret;
if(parent.children().length === 1) {
+ toret = parent.parent();
var grandParent = parent.parent();
if(grandParent) {
var grandParentChildren = grandParent.children(),
@@ -309,6 +380,7 @@ $.extend(DocumentTextElement.prototype, {
parent.after(this);
}
parent.detach();
+ return toret;
}
},
split: function(params) {