+ return this.dom().text().replace(utils.unicode.ZWS, '');
+ },
+ isEmpty: function() {
+ // Having at least Zero Width Space is guaranteed be Content Observer
+ return this.dom().contents()[0].data === utils.unicode.ZWS;
+ },
+ after: function(params) {
+ if(params instanceof DocumentTextElement || params.text)
+ return false;
+ var element;
+ if(params instanceof DocumentNodeElement) {
+ element = params;
+ } else {
+ element = DocumentNodeElement.create(params, this.canvas);
+ }
+ this.dom().wrap('<div>');
+ this.dom().parent().after(element.dom());
+ this.dom().unwrap();
+ return element;
+ },
+ before: function(params) {
+ if(params instanceof DocumentTextElement || params.text)
+ return false;
+ var element;
+ if(params instanceof DocumentNodeElement) {
+ element = params;
+ } else {
+ element = DocumentNodeElement.create(params, this.canvas);
+ }
+ this.dom().wrap('<div>');
+ this.dom().parent().before(element.dom());
+ this.dom().unwrap();
+ return element;
+ },
+ wrapWithNodeElement: function(wlxmlNode) {
+ if(typeof wlxmlNode.start === 'number' && typeof wlxmlNode.end === 'number') {
+ return this.canvas.wrapText({
+ inside: this.parent(),
+ textNodeIdx: this.parent().childIndex(this),
+ offsetStart: Math.min(wlxmlNode.start, wlxmlNode.end),
+ offsetEnd: Math.max(wlxmlNode.start, wlxmlNode.end),
+ _with: {tag: wlxmlNode.tag, klass: wlxmlNode.klass}
+ });
+ } else {
+ return DocumentElement.prototype.wrapWithNodeElement.call(this, wlxmlNode);
+ }
+ },
+ unwrap: function() {
+ var parent = this.parent(),
+ toret;
+ if(parent.children().length === 1) {
+ toret = parent.parent();
+ var grandParent = parent.parent();
+ if(grandParent) {
+ var grandParentChildren = grandParent.children(),
+ idx = grandParent.childIndex(parent),
+ prev = idx - 1 > -1 ? grandParentChildren[idx-1] : null,
+ next = idx + 1 < grandParentChildren.length ? grandParentChildren[idx+1] : null;
+
+ prev = (prev instanceof DocumentTextElement) ? prev : null;
+ next = (next instanceof DocumentTextElement) ? next : null;
+
+ if(prev && next) {
+ prev.setText(prev.getText() + this.getText() + next.getText());
+ next.detach();
+ } else if (prev || next) {
+ var target = prev ? prev : next,
+ newText = prev ? target.getText() + this.getText() : this.getText() + target.getText();
+ target.setText(newText);
+ } else {
+ parent.after(this);
+ }
+ } else {
+ parent.after(this);
+ }
+ parent.detach();
+ return toret;
+ }
+ },
+ split: function(params) {
+ var parentElement = this.parent(),
+ myIdx = parentElement.childIndex(this),
+ myCanvas = this.canvas,
+ passed = false,
+ succeedingChildren = [],
+ thisElement = this,
+ prefix = this.getText().substr(0, params.offset),
+ suffix = this.getText().substr(params.offset);
+
+ parentElement.children().forEach(function(child) {
+ if(passed)
+ succeedingChildren.push(child);
+ if(child.sameNode(thisElement))
+ passed = true;
+ });
+
+ if(prefix.length > 0)
+ this.setText(prefix);
+ else
+ this.detach();
+
+ var newElement = DocumentNodeElement.create({tag: parentElement.getWlxmlTag(), klass: parentElement.getWlxmlClass()}, myCanvas);
+ parentElement.after(newElement);
+
+ if(suffix.length > 0)
+ newElement.append({text: suffix});
+ succeedingChildren.forEach(function(child) {
+ newElement.append(child);
+ });
+
+ return {first: parentElement, second: newElement};
+ },
+ divide: function(params) {
+ var myText = this.getText();
+
+ if(params.offset === myText.length)
+ return this.after(params);
+ if(params.offset === 0)
+ return this.before(params);
+
+ var lhsText = myText.substr(0, params.offset),
+ rhsText = myText.substr(params.offset),
+ newElement = DocumentNodeElement.create({tag: params.tag, klass: params.klass}, this.canvas),
+ rhsTextElement = DocumentTextElement.create({text: rhsText});
+
+ this.setText(lhsText);
+ this.after(newElement);
+ newElement.after(rhsTextElement);
+ return newElement;
+ },
+
+ toggleHighlight: function() {
+ // do nothing for now