Dialog = require('views/dialog/dialog'),
canvasElements = require('plugins/core/canvasElements'),
metadataEditor = require('plugins/core/metadataEditor/metadataEditor'),
- edumed = require('plugins/core/edumed/edumed');
+ edumed = require('plugins/core/edumed/edumed'),
+ add_attachments = require('views/attachments/add_attachments');
var exerciseFix = function(newNodes) {
parent.contents().some(function(n) {
return move(n, newNode);
});
+ if(newNodes.second.contents()[0].getText().length === 0) {
+ newNodes.second.detach();
+ newNodes.second = parent;
+ emptyText = newNodes.second.append({text: '\u200b'}); // why? why is ZWS needed here?
+ }
}
return _.extend(newNodes, {emptyText: emptyText});
}
});
return toret;
+ },
+ insertNewNode: function () {
+ var node = this;
+ var newElement = this.document.createDocumentNode({tagName: 'div', attrs: {class: 'p'}});
+ node.after(newElement);
+ newElement.append({text: ''});
+ return newElement;
}
};
});
}
- if(params.fragment instanceof params.fragment.TextRangeFragment && params.fragment.hasSiblingBoundries()) {
+ if(params.fragment instanceof params.fragment.TextRangeFragment && params.fragment.hasSiblingBoundaries()) {
parent = params.fragment.startNode.parent();
if(parent && parent.is(createParams.klass) || parent.isInside(createParams.klass)) {
return _.extend(state, {allowed: false});
var createLinkFromSelection = function(callback, params) {
- var doc = params.fragment.document,
- dialog = Dialog.create({
+ var fragment = params.fragment,
+ doc = fragment.document,
+ text = fragment.startNode.nativeNode.data.substring(fragment.startOffset, fragment.endOffset),
+ url;
+ if (text.indexOf('//') >= 0 && text.indexOf(' ') < 0) {
+ url = text;
+ } else if (text.substr(0, 4) === 'www.' && text.indexOF(' ') < 0) {
+ url = 'http://' + text;
+ }
+ var dialog = Dialog.create({
title: gettext('Create link'),
executeButtonText: gettext('Apply'),
cancelButtonText: gettext('Cancel'),
fields: [
- {label: gettext('Link'), name: 'href', type: 'input',
+ {label: gettext('Link'), name: 'href', type: 'input', initialValue: url || '',
prePasteHandler: function(text) {
return params.fragment.document.getLinkForUrl(text);
}.bind(this)
});
});
dialog.show();
+ add_attachments(dialog);
};
var editLink = function(callback, params) {
}
if(params.fragment instanceof params.fragment.TextRangeFragment) {
- if(!params.fragment.hasSiblingBoundries() || params.fragment.startNode.parent().is('link')) {
+ if(!params.fragment.hasSiblingBoundaries() || params.fragment.startNode.parent().is('link')) {
return {allowed: false};
}
return {