4 /* globals gettext, interpolate */
7 var getBoundriesForAList = function(fragment) {
10 if(fragment instanceof fragment.RangeFragment && fragment.hasSiblingBoundries()) {
11 return fragment.boundriesSiblingParents();
13 if(fragment instanceof fragment.NodeFragment) {
14 node = fragment.node.getNearestElementNode();
22 var countItems = function(boundries) {
23 var ptr = boundries.node1,
25 while(ptr && !ptr.sameNode(boundries.node2)) {
32 var toggleListAction = function(type) {
35 add: function(callback, params) {
36 var boundries = getBoundriesForAList(params.fragment),
37 listParams = {klass: type === 'Bullet' ? 'list' : 'list.enum'},
40 if(boundries && boundries.node1) {
41 listParams.node1 = boundries.node1;
42 listParams.node2 = boundries.node2;
43 boundries.node1.document.transaction(function() {
44 var list = boundries.node1.document.createList(listParams),
45 item1 = list.object.getItem(0),
46 text = item1 ? item1.contents()[0] : undefined, //
47 doc = boundries.node1.document;
49 return doc.createFragment(doc.CaretFragment, {node: text, offset:0});
52 description: action.getState().description
57 throw new Error('Invalid boundries');
60 remove: function(callback, params) {
62 var current = params.fragment.node,
65 var toSearch = current.nodeType === Node.ELEMENT_NODE ? [current] : [];
66 toSearch = toSearch.concat(current.parents());
67 toSearch.some(function(node) {
69 node.document.transaction(function() {
70 var firstItem = node.object.extractListItems(),
72 if(params.fragment.isValid()) {
73 toret = params.fragment;
75 toret = node.document.createFragment(node.document.NodeFragment, {node: firstItem});
80 description: action.getState().description
89 changeType: function(callback, params) {
90 var node = params.fragment.node,
92 node.document.transaction(function() {
93 var list = node.getParent('list');
94 list.setClass(type === 'Bullet' ? 'list' : 'list.enum');
95 if(params.fragment.isValid()) {
96 return params.fragment;
98 return node.document.createFragment(node.document.NodeFragment, {node: list.contents()[0]});
102 description: action.getState().description
109 var isToggled = function(params) {
110 if(params.fragment && params.fragment.node && params.fragment.node.isInside('list')) {
111 var list = params.fragment.node.getParent('list');
112 return list.getClass() === (type === 'Bullet' ? 'list' : 'list.enum');
117 var label = type === 'Bullet' ? gettext('bull. list') : gettext('num. list');
120 name: 'toggle' + type + 'List',
121 context: ['fragment'],
123 fragment: {type: 'context', name: 'fragment'}
128 getState: function(params) {
129 if(!params.fragment || !params.fragment.isValid()) {
133 if(params.fragment instanceof params.fragment.CaretFragment && params.fragment.node.isInside('list')) {
134 var list = params.fragment.node.getParent('list');
135 if((list.getClass() === 'list' && type === 'Enum') || (list.getClass() === 'list.enum' && type === 'Bullet')) {
138 description: interpolate(gettext('Change list type to %s'), [label]),
139 execute: execute.changeType
144 toggled: isToggled(params),
145 description: gettext('Remove list'),
146 execute: execute.remove
150 var boundries = getBoundriesForAList(params.fragment);
154 description: interpolate(gettext('Make %s fragment(s) into list'), [countItems(getBoundriesForAList(params.fragment))]),
164 actions: [toggleListAction('Bullet'), toggleListAction('Enum')]