X-Git-Url: https://git.mdrn.pl/fnpeditor.git/blobdiff_plain/bec14a088e45d21ac12f9c5e852dd0b7e559d680..926f304f00fd207bb24cf5c354cf4533abdcac48:/src/editor/plugins/core/lists.js diff --git a/src/editor/plugins/core/lists.js b/src/editor/plugins/core/lists.js index 911a1f2..c6de730 100644 --- a/src/editor/plugins/core/lists.js +++ b/src/editor/plugins/core/lists.js @@ -12,6 +12,10 @@ var getBoundriesForAList = function(fragment) { } if(fragment instanceof fragment.NodeFragment) { node = fragment.node.getNearestElementNode(); + if(node.isContextRoot()) { + node = fragment.node; + } + return { node1: node, node2: node @@ -41,10 +45,17 @@ var toggleListAction = function(type) { listParams.node1 = boundries.node1; listParams.node2 = boundries.node2; boundries.node1.document.transaction(function() { - boundries.node1.document.createList(listParams); + var list = boundries.node1.document.createList(listParams), + item1 = list.object.getItem(0), + text = item1 ? item1.contents()[0] : undefined, // + doc = boundries.node1.document; + if(text) { + return doc.createFragment(doc.CaretFragment, {node: text, offset:0}); + } }, { metadata: { - description: action.getState().description + description: action.getState().description, + fragment: params.fragment }, success: callback }); @@ -62,10 +73,18 @@ var toggleListAction = function(type) { toSearch.some(function(node) { if(node.is('list')) { node.document.transaction(function() { - node.object.extractListItems(); + var firstItem = node.object.extractListItems(), + toret; + if(params.fragment.isValid()) { + toret = params.fragment; + } else { + toret = node.document.createFragment(node.document.NodeFragment, {node: firstItem}); + } + return toret; }, { metadata: { - description: action.getState().description + description: action.getState().description, + fragment: params.fragment }, success: callback }); @@ -78,10 +97,17 @@ var toggleListAction = function(type) { var node = params.fragment.node, action = this; node.document.transaction(function() { - node.getParent('list').setClass(type === 'Bullet' ? 'list' : 'list.enum'); + var list = node.getParent('list'); + list.setClass(type === 'Bullet' ? 'list' : 'list.enum'); + if(params.fragment.isValid()) { + return params.fragment; + } else { + return node.document.createFragment(node.document.NodeFragment, {node: list.contents()[0]}); + } }, { metadata: { - description: action.getState().description + description: action.getState().description, + fragment: params.fragment }, success: callback }); @@ -96,6 +122,7 @@ var toggleListAction = function(type) { return false; }; + var label = type === 'Bullet' ? gettext('bull. list') : gettext('num. list'); return { name: 'toggle' + type + 'List', @@ -104,7 +131,7 @@ var toggleListAction = function(type) { fragment: {type: 'context', name: 'fragment'} }, stateDefaults: { - label: type === 'Bullet' ? gettext('bull. list') : gettext('num. list') + label: label }, getState: function(params) { if(!params.fragment || !params.fragment.isValid()) { @@ -116,7 +143,7 @@ var toggleListAction = function(type) { if((list.getClass() === 'list' && type === 'Enum') || (list.getClass() === 'list.enum' && type === 'Bullet')) { return { allowed: true, - description: interpolate(gettext('Change list type to %s'), [type]), + description: interpolate(gettext('Change list type to %s'), [label]), execute: execute.changeType }; }