cpee 2.1.20 → 2.1.24

Sign up to get free protection for your applications and to get access to all the features.
Files changed (45) hide show
  1. checksums.yaml +4 -4
  2. data/cockpit/css/ui.css +1 -1
  3. data/cockpit/templates/Coopis 2010.xml +8 -3
  4. data/cockpit/templates/IUPC arXiv:1104.3609 P34 1.xml +15 -8
  5. data/cockpit/templates/IUPC arXiv:1104.3609 P34 2.xml +15 -8
  6. data/cockpit/templates/IUPC arXiv:1104.3609 P34 3.xml +15 -8
  7. data/cockpit/templates/Track Test Local.xml +2 -1
  8. data/cockpit/templates/Track Test.xml +2 -1
  9. data/cockpit/templates/UR-VUE 2020 Manual Adjust.xml +5 -0
  10. data/cockpit/templates/UR-VUE 2020 Solution Baseline.xml +6 -8
  11. data/cockpit/templates/UR-VUE 2020 Solution NN.xml +6 -8
  12. data/cockpit/templates/UR-VUE 2020 Solution View.xml +5 -8
  13. data/cockpit/templates/UR-VUE 2020.xml +1 -8
  14. data/cockpit/templates/Worklist.xml +3 -1
  15. data/cockpit/themes/compact/rngs/call.rng +110 -108
  16. data/cockpit/themes/compact/rngs/callmanipulate.rng +90 -87
  17. data/cockpit/themes/compact/rngs/parallel_branch.rng +1 -7
  18. data/cockpit/themes/compact/theme.js +136 -118
  19. data/cockpit/themes/control/rngs/call.rng +110 -108
  20. data/cockpit/themes/control/rngs/callmanipulate.rng +90 -87
  21. data/cockpit/themes/control/rngs/parallel_branch.rng +1 -7
  22. data/cockpit/themes/control/theme.js +149 -131
  23. data/cockpit/themes/default/rngs/call.rng +110 -108
  24. data/cockpit/themes/default/rngs/callmanipulate.rng +90 -87
  25. data/cockpit/themes/default/rngs/parallel_branch.rng +1 -7
  26. data/cockpit/themes/default/theme.js +136 -118
  27. data/cockpit/themes/extended/rngs/call.rng +110 -108
  28. data/cockpit/themes/extended/rngs/callmanipulate.rng +90 -87
  29. data/cockpit/themes/extended/rngs/parallel_branch.rng +1 -7
  30. data/cockpit/themes/extended/theme.js +136 -118
  31. data/cockpit/themes/model/rngs/call.rng +24 -22
  32. data/cockpit/themes/model/rngs/callmanipulate.rng +28 -26
  33. data/cockpit/themes/model/theme.js +114 -96
  34. data/cockpit/themes/packed/rngs/call.rng +110 -108
  35. data/cockpit/themes/packed/rngs/callmanipulate.rng +90 -87
  36. data/cockpit/themes/packed/rngs/parallel_branch.rng +1 -7
  37. data/cockpit/themes/packed/theme.js +136 -118
  38. data/cockpit/themes/preset/rngs/call.rng +110 -108
  39. data/cockpit/themes/preset/rngs/callmanipulate.rng +90 -87
  40. data/cockpit/themes/preset/rngs/parallel_branch.rng +1 -7
  41. data/cockpit/themes/preset/theme.js +136 -118
  42. data/cpee.gemspec +2 -1
  43. data/server/executionhandlers/ruby/connection.rb +27 -12
  44. data/tools/cpee +13 -6
  45. metadata +16 -2
@@ -25,6 +25,67 @@
25
25
  </element>
26
26
  </zeroOrMore>
27
27
  </element>
28
+ </element>
29
+ <element name="code" rngui:header="Output Handling">
30
+ <element name="prepare" rngui:header="Prepare" rngui:label="Code" rngui:fold="closed_conditional">
31
+ <text rngui:label="Script that is executed, before a service call"/>
32
+ </element>
33
+ <element name="finalize" rngui:header="Finalize" rngui:label="Code" rngui:fold="closed_conditional">
34
+ <attribute name="output" rngui:label="Access Variable" rngui:default="result">
35
+ <data type="string" rngui:readonly="true"/>
36
+ </attribute>
37
+ <text rngui:label="Script that is executed, when a service returns data"/>
38
+ </element>
39
+ <element name="update" rngui:header="Update" rngui:label="Code" rngui:fold="closed_conditional">
40
+ <attribute name="output" rngui:label="Access Variable" rngui:default="result">
41
+ <data type="string" rngui:readonly="true"/>
42
+ </attribute>
43
+ <text rngui:label="Script that is executed, when a service sends intermediate data"/>
44
+ </element>
45
+ <element name="rescue" rngui:header="Rescue" rngui:label="Code" rngui:fold="closed_conditional">
46
+ <attribute name="output" rngui:label="Access Variable" rngui:default="result">
47
+ <data type="string" rngui:readonly="true"/>
48
+ </attribute>
49
+ <text rngui:label="Script that is executed, if a service call fails"/>
50
+ </element>
51
+ </element>
52
+ <element name="annotations" rngui:header="Annotations">
53
+ <element name="_timing" rngui:header="Timing" rngui:fold="closed">
54
+ <element name="_timing_weight" rngui:label="&#x3C9; - Weight">
55
+ <data type="float" rngui:label="[0,1]"/>
56
+ </element>
57
+ <element name="_timing_avg" rngui:label="Avg in min">
58
+ <data type="float" rngui:label="Minutes"/>
59
+ </element>
60
+ <element name="explanations" rngui:header="Explanations">
61
+ <zeroOrMore rngui:label="Add Explanation">
62
+ <element name="explanation">
63
+ <element name="type" rngui:label="Type">
64
+ <choice>
65
+ <value>&gt;</value>
66
+ <value>&lt;</value>
67
+ </choice>
68
+ </element>
69
+ <element name="deviation" rngui:label="Deviation">
70
+ <data type="float" rngui:label="Minutes"/>
71
+ </element>
72
+ <element name="behaviour" rngui:label="Behaviour">
73
+ <choice>
74
+ <value>Immediately</value>
75
+ <value>Wait until next</value>
76
+ <value>Use grace period value</value>
77
+ </choice>
78
+ </element>
79
+ <element name="grace" rngui:label="Grace Period" rngui:default="0.0">
80
+ <data type="float" rngui:label="Minutes"/>
81
+ </element>
82
+ <element name="text" rngui:label="Explanation">
83
+ <data type="string" rngui:label="Patterns"/>
84
+ </element>
85
+ </element>
86
+ </zeroOrMore>
87
+ </element>
88
+ </element>
28
89
  <element name="_context_data_analysis" rngui:header="Context Data Analysis" rngui:hint="All data returned from the endpoint implementing this task as well as arbitray external data streams can be consumed and transformed in data probes. All probes can be the basis for impact factors. Please go to start to define instance data probes.">
29
90
 
30
91
  <element name="probes" rngui:header="Data Probes - Context Data Extraction" rngui:fold="closed">
@@ -127,101 +188,43 @@
127
188
  <data type="string" rngui:label="url to report snippet"/>
128
189
  </element>
129
190
  </element>
130
- </element>
131
- <element name="code" rngui:header="Output Handling">
132
- <element name="prepare" rngui:header="Prepare" rngui:label="Code" rngui:fold="closed_conditional">
133
- <text rngui:label="Script that is executed, before a service call"/>
134
- </element>
135
- <element name="finalize" rngui:header="Finalize" rngui:label="Code" rngui:fold="closed_conditional">
136
- <attribute name="output" rngui:label="Access Variable" rngui:default="result">
137
- <data type="string" rngui:readonly="true"/>
138
- </attribute>
139
- <text rngui:label="Script that is executed, when a service returns data"/>
140
- </element>
141
- <element name="update" rngui:header="Update" rngui:label="Code" rngui:fold="closed_conditional">
142
- <attribute name="output" rngui:label="Access Variable" rngui:default="result">
143
- <data type="string" rngui:readonly="true"/>
144
- </attribute>
145
- <text rngui:label="Script that is executed, when a service sends intermediate data"/>
146
- </element>
147
- <element name="rescue" rngui:header="Rescue" rngui:label="Code" rngui:fold="closed_conditional">
148
- <attribute name="output" rngui:label="Access Variable" rngui:default="result">
149
- <data type="string" rngui:readonly="true"/>
150
- </attribute>
151
- <text rngui:label="Script that is executed, if a service call fails"/>
152
- </element>
153
- </element>
154
- <element name="annotations" rngui:header="Annotations">
155
- <element name="_timing" rngui:header="Timing" rngui:fold="closed">
156
- <element name="_timing_weight" rngui:label="&#x3C9; - Weight">
157
- <data type="float" rngui:label="[0,1]"/>
158
- </element>
159
- <element name="_timing_avg" rngui:label="Avg in min">
160
- <data type="float" rngui:label="Minutes"/>
161
- </element>
162
- <element name="explanations" rngui:header="Explanations">
163
- <zeroOrMore rngui:label="Add Explanation">
164
- <element name="explanation">
165
- <element name="type" rngui:label="Type">
166
- <choice>
167
- <value>&gt;</value>
168
- <value>&lt;</value>
169
- </choice>
170
- </element>
171
- <element name="deviation" rngui:label="Deviation">
172
- <data type="float" rngui:label="Minutes"/>
173
- </element>
174
- <element name="behaviour" rngui:label="Behaviour">
175
- <choice>
176
- <value>Immediately</value>
177
- <value>Wait until next</value>
178
- <value>Use grace period value</value>
179
- </choice>
180
- </element>
181
- <element name="grace" rngui:label="Grace Period" rngui:default="0.0">
182
- <data type="float" rngui:label="Minutes"/>
183
- </element>
184
- <element name="text" rngui:label="Explanation">
185
- <data type="string" rngui:label="Patterns"/>
186
- </element>
187
- </element>
188
- </zeroOrMore>
189
- </element>
190
- </element>
191
191
  <element name="_notes" rngui:header="Notes" rngui:fold="closed">
192
192
  <element name="_notes_general" rngui:label="General">
193
193
  <text rngui:wrap="true" rngui:label="Notes"/>
194
194
  </element>
195
195
  </element>
196
196
  </element>
197
- <element name="input" rngui:header="Input Arguments Documentation" rngui:fold="closed">
198
- <zeroOrMore rngui:label="Create Argument">
199
- <element name="item" rngui:label="Description">
200
- <attribute name="label" rngui:label="Name">
201
- <data type="string"/>
202
- </attribute>
203
- <text rngui:wrap="true" rngui:label="What does it do?"/>
204
- </element>
205
- </zeroOrMore>
206
- </element>
207
- <element name="output" rngui:header="Output Elements Documentation" rngui:fold="closed">
208
- <zeroOrMore rngui:label="Create Element">
209
- <element name="item" rngui:label="Description">
210
- <attribute name="label" rngui:label="Name">
211
- <data type="string"/>
212
- </attribute>
213
- <text rngui:wrap="true" rngui:label="What does it do?"/>
197
+
198
+ <element name="input" rngui:header="Documentation">
199
+ <element name="input" rngui:header="Input Arguments" rngui:fold="closed">
200
+ <zeroOrMore rngui:label="Create Argument">
201
+ <element name="item" rngui:label="Description">
202
+ <attribute name="label" rngui:label="Name">
203
+ <data type="string"/>
204
+ </attribute>
205
+ <text rngui:wrap="true" rngui:label="What does it do?"/>
206
+ </element>
207
+ </zeroOrMore>
208
+ </element>
209
+ <element name="output" rngui:header="Output Elements" rngui:fold="closed">
210
+ <zeroOrMore rngui:label="Create Element">
211
+ <element name="item" rngui:label="Description">
212
+ <attribute name="label" rngui:label="Name">
213
+ <data type="string"/>
214
+ </attribute>
215
+ <text rngui:wrap="true" rngui:label="What does it do?"/>
216
+ </element>
217
+ </zeroOrMore>
218
+ </element>
219
+ <element name="implementation" rngui:header="Implementation" rngui:fold="closed">
220
+ <element name="description" rngui:label="Description">
221
+ <text rngui:wrap="true" rngui:label="What is supposed to happen?"/>
214
222
  </element>
215
- </zeroOrMore>
216
- </element>
217
- <element name="implementation" rngui:header="Implementation Documentation" rngui:fold="closed">
218
- <element name="description" rngui:label="Description">
219
- <text rngui:wrap="true" rngui:label="What is supposed to happen?"/>
220
223
  </element>
221
- </element>
222
- <element name="code" rngui:header="Output Handling Documentation" rngui:fold="closed">
223
- <element name="description" rngui:label="Description">
224
- <text rngui:wrap="true" rngui:label="Which output elements are important? How to transform and save them?"/>
224
+ <element name="code" rngui:header="Output Handling" rngui:fold="closed">
225
+ <element name="description" rngui:label="Description">
226
+ <text rngui:wrap="true" rngui:label="Which output elements are important? How to transform and save them?"/>
227
+ </element>
225
228
  </element>
226
229
  </element>
227
230
  </element>
@@ -1,8 +1,2 @@
1
1
  <element xmlns="http://relaxng.org/ns/structure/1.0" xmlns:rngui="http://rngui.org" rngui:version="1.2" name="parallel_branch" datatypeLibrary="http://www.w3.org/2001/XMLSchema-datatypes" ns="http://cpee.org/ns/description/1.0">
2
- <attribute name="pass" rngui:label="Pass to branch">
3
- <data type="string" rngui:label="Data element passed to the local scope, thus not affected by global changes ..."/>
4
- </attribute>
5
- <attribute name="local" rngui:label="Local scope">
6
- <data type="string" rngui:label="Name of the passed data element in the local scope ..."/>
7
- </attribute>
8
- </element>
2
+ </element>
@@ -8,6 +8,7 @@ function WFAdaptorManifestation(adaptor) {
8
8
  this.compact = false;
9
9
  this.striped = true;
10
10
  this.endpoints = {};
11
+ this.presstimer;
11
12
 
12
13
  //{{{ transform the details data to description parts based on rng
13
14
  this.source = function(base,opts) {
@@ -137,93 +138,104 @@ function WFAdaptorManifestation(adaptor) {
137
138
  }
138
139
  } //}}}
139
140
 
140
- // Events
141
- this.events.mousedown = function(svgid, e, child, sibling) { // {{{
142
- if(e.button == 0) { // left-click
143
- } else if(e.button == 1) { // middle-click
144
- } else if(e.button == 2) { // right-click
145
- if (save['state'] != "ready" && save['state'] != "stopped") { return false; }
141
+ function contextMenuHandling(svgid,e,child,sibling) { //{{{
142
+ if (save['state'] != "ready" && save['state'] != "stopped") { return false; }
146
143
 
147
- var xml_node = self.adaptor.description.get_node_by_svg_id(svgid);
148
- var group = null;
149
- var menu = {};
144
+ var xml_node = self.adaptor.description.get_node_by_svg_id(svgid);
145
+ var group = null;
146
+ var menu = {};
150
147
 
151
- if (child) {
152
- group = self.elements[xml_node.get(0).tagName].permissible_children(xml_node,'into');
148
+ if (child) {
149
+ group = self.elements[xml_node.get(0).tagName].permissible_children(xml_node,'into');
150
+ if(group.length > 0) {
151
+ menu['Insert into'] = group;
152
+ copyOrMove(menu['Insert into'],group,xml_node,self.adaptor.description.insert_first_into);
153
+ }
154
+ if (self.elements[xml_node.get(0).tagName].permissible_children_expert) {
155
+ group = self.elements[xml_node.get(0).tagName].permissible_children_expert(xml_node,'into');
153
156
  if(group.length > 0) {
154
- menu['Insert into'] = group;
155
- copyOrMove(menu['Insert into'],group,xml_node,self.adaptor.description.insert_first_into);
156
- }
157
- if (self.elements[xml_node.get(0).tagName].permissible_children_expert) {
158
- group = self.elements[xml_node.get(0).tagName].permissible_children_expert(xml_node,'into');
159
- if(group.length > 0) {
160
- menu['Insert into (Experts Only!)'] = group;
161
- copyOrMove(menu['Insert into (Experts Only!)'],group,xml_node,self.adaptor.description.insert_first_into);
162
- }
157
+ menu['Insert into (Experts Only!)'] = group;
158
+ copyOrMove(menu['Insert into (Experts Only!)'],group,xml_node,self.adaptor.description.insert_first_into);
163
159
  }
164
160
  }
165
- if (sibling) {
166
- group = self.elements[xml_node.parent().get(0).tagName].permissible_children(xml_node,'after');
161
+ }
162
+ if (sibling) {
163
+ group = self.elements[xml_node.parent().get(0).tagName].permissible_children(xml_node,'after');
164
+ if(group.length > 0) {
165
+ menu['Insert after'] = group;
166
+ copyOrMove(menu['Insert after'],group,xml_node,self.adaptor.description.insert_after);
167
+ }
168
+ if (self.elements[xml_node.parent().get(0).tagName].permissible_children_expert) {
169
+ group = self.elements[xml_node.parent().get(0).tagName].permissible_children_expert(xml_node,'after');
167
170
  if(group.length > 0) {
168
- menu['Insert after'] = group;
169
- copyOrMove(menu['Insert after'],group,xml_node,self.adaptor.description.insert_after);
170
- }
171
- if (self.elements[xml_node.parent().get(0).tagName].permissible_children_expert) {
172
- group = self.elements[xml_node.parent().get(0).tagName].permissible_children_expert(xml_node,'after');
173
- if(group.length > 0) {
174
- menu['Insert after (Experts Only!)'] = group;
175
- copyOrMove(menu['Insert after (Experts Only!)'],group,xml_node,self.adaptor.description.insert_after);
176
- }
171
+ menu['Insert after (Experts Only!)'] = group;
172
+ copyOrMove(menu['Insert after (Experts Only!)'],group,xml_node,self.adaptor.description.insert_after);
177
173
  }
178
174
  }
175
+ }
179
176
 
180
- if(xml_node.get(0).tagName != 'description' && !self.elements[xml_node.get(0).tagName].neverdelete) {
181
- var icon = self.elements[xml_node.get(0).tagName].illustrator.svg.clone();
182
- icon.children('.rfill').addClass('menu');
183
- menu['Delete'] = [{
184
- 'label': 'Remove Element',
185
- 'function_call': function(selector,target,selected){ self.adaptor.description.remove(selector,target); self.adaptor.illustrator.get_label_by_svg_id(selected).addClass('selected'); },
186
- 'menu_icon': icon,
187
- 'type': undefined,
188
- 'params': [null, xml_node, self.selected()]
189
- }];
190
- }
191
- if($('> code', xml_node).length > 0 && xml_node.get(0).tagName == 'call') {
192
- var icon = self.elements.callmanipulate.illustrator.svg.clone();
193
- icon.children('.rfill:last').addClass('menu');
194
- menu['Delete'].push({
195
- 'label': 'Remove Scripts',
196
- 'function_call': self.adaptor.description.remove,
197
- 'menu_icon': icon,
198
- 'type': undefined,
199
- 'params': ['> code', xml_node]
200
- });
201
- }
202
- if (xml_node.get(0).tagName == "call" || xml_node.get(0).tagName == "manipulate" || xml_node.get(0).tagName == "stop") {
203
- var icon = self.elements.call.illustrator.svg.clone();
204
- icon.children('g.replace').addClass('active');
205
- var vtarget = self.adaptor.illustrator.get_node_by_svg_id(svgid);
206
- if (vtarget.length > 0) {
207
- if (vtarget.parents('g.activities.passive, g.activities.active').length > 0) {
208
- menu['Position'] = [{
209
- 'label': 'No Execution from here',
210
- 'function_call': del_ui_pos,
211
- 'menu_icon': icon,
212
- 'type': undefined,
213
- 'params': xml_node
214
- }];
215
- } else {
216
- menu['Position'] = [{
217
- 'label': 'Execute from here',
218
- 'function_call': add_ui_pos,
219
- 'menu_icon': icon,
220
- 'type': undefined,
221
- 'params': xml_node
222
- }];
223
- }
177
+ if(xml_node.get(0).tagName != 'description' && !self.elements[xml_node.get(0).tagName].neverdelete) {
178
+ var icon = self.elements[xml_node.get(0).tagName].illustrator.svg.clone();
179
+ icon.children('.rfill').addClass('menu');
180
+ menu['Delete'] = [{
181
+ 'label': 'Remove Element',
182
+ 'function_call': function(selector,target,selected){ self.adaptor.description.remove(selector,target); self.adaptor.illustrator.get_label_by_svg_id(selected).addClass('selected'); },
183
+ 'menu_icon': icon,
184
+ 'type': undefined,
185
+ 'params': [null, xml_node, self.selected()]
186
+ }];
187
+ }
188
+ if($('> code', xml_node).length > 0 && xml_node.get(0).tagName == 'call') {
189
+ var icon = self.elements.callmanipulate.illustrator.svg.clone();
190
+ icon.children('.rfill:last').addClass('menu');
191
+ menu['Delete'].push({
192
+ 'label': 'Remove Scripts',
193
+ 'function_call': self.adaptor.description.remove,
194
+ 'menu_icon': icon,
195
+ 'type': undefined,
196
+ 'params': ['> code', xml_node]
197
+ });
198
+ }
199
+ if (xml_node.get(0).tagName == "call" || xml_node.get(0).tagName == "manipulate" || xml_node.get(0).tagName == "stop") {
200
+ var icon = self.elements.call.illustrator.svg.clone();
201
+ icon.children('g.replace').addClass('active');
202
+ var vtarget = self.adaptor.illustrator.get_node_by_svg_id(svgid);
203
+ if (vtarget.length > 0) {
204
+ if (vtarget.parents('g.activities.passive, g.activities.active').length > 0) {
205
+ menu['Position'] = [{
206
+ 'label': 'No Execution from here',
207
+ 'function_call': del_ui_pos,
208
+ 'menu_icon': icon,
209
+ 'type': undefined,
210
+ 'params': xml_node
211
+ }];
212
+ } else {
213
+ menu['Position'] = [{
214
+ 'label': 'Execute from here',
215
+ 'function_call': add_ui_pos,
216
+ 'menu_icon': icon,
217
+ 'type': undefined,
218
+ 'params': xml_node
219
+ }];
224
220
  }
225
221
  }
226
- new CustomMenu(e).contextmenu(menu);
222
+ }
223
+ new CustomMenu(e).contextmenu(menu);
224
+ } //}}}
225
+
226
+ // Events
227
+ this.events.touchend = function(svgid, e) { // {{{
228
+ clearTimeout(self.presstimer);
229
+ } // }}}
230
+ this.events.touchstart = function(svgid, e, child, sibling) { // {{{
231
+ self.presstimer = window.setTimeout(function() { contextMenuHandling(svgid,e,child,sibling); },1000);
232
+ return false;
233
+ } // }}}
234
+ this.events.mousedown = function(svgid, e, child, sibling) { // {{{
235
+ if(e.button == 0) { // left-click
236
+ } else if(e.button == 1) { // middle-click
237
+ } else if(e.button == 2) { // right-click
238
+ contextMenuHandling(svgid,e,child,sibling);
227
239
  }
228
240
  return false;
229
241
  } // }}}
@@ -339,6 +351,8 @@ function WFAdaptorManifestation(adaptor) {
339
351
  }, //}}}
340
352
  'adaptor': {//{{{
341
353
  'mousedown': function (node,e) { self.events.mousedown(node,e,true,true); },
354
+ 'touchstart': function (node,e) { self.events.touchstart(node,e,true,true); },
355
+ 'touchend': self.events.touchend,
342
356
  'click': self.events.click,
343
357
  'dragstart': self.events.dragstart,
344
358
  'mouseover': self.events.mouseover,
@@ -365,6 +379,8 @@ function WFAdaptorManifestation(adaptor) {
365
379
  }, //}}}
366
380
  'adaptor': {//{{{
367
381
  'mousedown': function (node,e) { self.events.mousedown(node,e,false,true); },
382
+ 'touchstart': function (node,e) { self.events.touchstart(node,e,false,true); },
383
+ 'touchend': self.events.touchend,
368
384
  'click': self.events.click,
369
385
  'mouseover': self.events.mouseover,
370
386
  'mouseout': self.events.mouseout
@@ -382,6 +398,8 @@ function WFAdaptorManifestation(adaptor) {
382
398
  }, //}}}
383
399
  'adaptor': {//{{{
384
400
  'mousedown': function (node,e) { self.events.mousedown(node,e,false,true); },
401
+ 'touchstart': function (node,e) { self.events.touchstart(node,e,false,true); },
402
+ 'touchend': self.events.touchend,
385
403
  'click': self.events.click,
386
404
  'mouseover': self.events.mouseover,
387
405
  'mouseout': self.events.mouseout
@@ -402,6 +420,8 @@ function WFAdaptorManifestation(adaptor) {
402
420
  }, //}}}
403
421
  'adaptor': {//{{{
404
422
  'mousedown': function (node,e) { self.events.mousedown(node,e,false,true); },
423
+ 'touchstart': function (node,e) { self.events.touchstart(node,e,false,true); },
424
+ 'touchend': self.events.touchend,
405
425
  'click': self.events.click,
406
426
  'mouseover': self.events.mouseover,
407
427
  'mouseout': self.events.mouseout
@@ -420,6 +440,8 @@ function WFAdaptorManifestation(adaptor) {
420
440
  }, //}}}
421
441
  'adaptor': {//{{{
422
442
  'mousedown': function (node,e) { self.events.mousedown(node,e,false,false); },
443
+ 'touchstart': function (node,e) { self.events.touchstart(node,e,false,false); },
444
+ 'touchend': self.events.touchend,
423
445
  'mouseover': self.events.mouseover,
424
446
  'mouseout': self.events.mouseout
425
447
  }//}}}
@@ -431,9 +453,7 @@ function WFAdaptorManifestation(adaptor) {
431
453
  'svg': self.adaptor.theme_dir + 'symbols/end.svg'
432
454
  }, //}}}
433
455
  'adaptor': {//{{{
434
- 'mousedown': function (node,e) {
435
- self.events.suppress();
436
- }
456
+ 'mousedown': function (node,e) { self.events.suppress(); }
437
457
  }//}}}
438
458
  }; /*}}}*/
439
459
  this.elements.event_end = { /*{{{*/
@@ -443,9 +463,7 @@ function WFAdaptorManifestation(adaptor) {
443
463
  'svg': self.adaptor.theme_dir + 'symbols/event_end.svg'
444
464
  }, //}}}
445
465
  'adaptor': {//{{{
446
- 'mousedown': function (node,e) {
447
- self.events.suppress();
448
- },
466
+ 'mousedown': function (node,e) { self.events.suppress(); },
449
467
  'click': self.events.click,
450
468
  'dblclick': self.events.dblclick,
451
469
  'mouseover': self.events.mouseover,
@@ -466,9 +484,9 @@ function WFAdaptorManifestation(adaptor) {
466
484
  },
467
485
  }, //}}}
468
486
  'adaptor': {//{{{
469
- 'mousedown': function (node,e) {
470
- self.events.mousedown(node,e,true,true);
471
- },
487
+ 'mousedown': function (node,e) { self.events.mousedown(node,e,true,true); },
488
+ 'touchstart': function (node,e) { self.events.touchstart(node,e,true,true); },
489
+ 'touchend': self.events.touchend,
472
490
  'click': self.events.click,
473
491
  'dblclick': self.events.dblclick,
474
492
  'mouseover': self.events.mouseover,
@@ -491,9 +509,9 @@ function WFAdaptorManifestation(adaptor) {
491
509
  'svg': self.adaptor.theme_dir + 'symbols/choose_exclusive.svg',
492
510
  }, //}}}
493
511
  'adaptor': {//{{{
494
- 'mousedown': function (node,e) {
495
- self.events.mousedown(node,e,true,true);
496
- },
512
+ 'mousedown': function (node,e) { self.events.mousedown(node,e,true,true); },
513
+ 'touchstart': function (node,e) { self.events.touchstart(node,e,true,true); },
514
+ 'touchend': self.events.touchend,
497
515
  'click': self.events.click,
498
516
  'dblclick': self.events.dblclick,
499
517
  'mouseover': self.events.mouseover,
@@ -518,9 +536,9 @@ function WFAdaptorManifestation(adaptor) {
518
536
  },
519
537
  }, //}}}
520
538
  'adaptor': {//{{{
521
- 'mousedown': function (node,e) {
522
- self.events.mousedown(node,e,true,true);
523
- },
539
+ 'mousedown': function (node,e) { self.events.mousedown(node,e,true,true); },
540
+ 'touchstart': function (node,e) { self.events.touchstart(node,e,true,true); },
541
+ 'touchend': self.events.touchend,
524
542
  'click': self.events.click,
525
543
  'dblclick': self.events.dblclick,
526
544
  'mouseover': self.events.mouseover,
@@ -583,9 +601,9 @@ function WFAdaptorManifestation(adaptor) {
583
601
  return childs;
584
602
  }, //}}}
585
603
  'adaptor': {//{{{
586
- 'mousedown': function (node,e) {
587
- self.events.mousedown(node,e,true,true);
588
- },
604
+ 'mousedown': function (node,e) { self.events.mousedown(node,e,true,true); },
605
+ 'touchstart': function (node,e) { self.events.touchstart(node,e,true,true); },
606
+ 'touchend': self.events.touchend,
589
607
  'click': self.events.click,
590
608
  'dblclick': self.events.dblclick,
591
609
  'mouseover': self.events.mouseover,
@@ -671,9 +689,9 @@ function WFAdaptorManifestation(adaptor) {
671
689
  return childs;
672
690
  }, //}}}
673
691
  'adaptor': {//{{{
674
- 'mousedown': function (node,e) {
675
- self.events.mousedown(node,e,true,false);
676
- },
692
+ 'mousedown': function (node,e) { self.events.mousedown(node,e,true,false); },
693
+ 'touchstart': function (node,e) { self.events.touchstart(node,e,true,false); },
694
+ 'touchend': self.events.touchend,
677
695
  'click': self.events.click,
678
696
  'dblclick': self.events.dblclick,
679
697
  'mouseover': self.events.mouseover,
@@ -767,9 +785,9 @@ function WFAdaptorManifestation(adaptor) {
767
785
  return childs;
768
786
  }, //}}}
769
787
  'adaptor': {//{{{
770
- 'mousedown': function (node,e) {
771
- self.events.mousedown(node,e,true,true);
772
- },
788
+ 'mousedown': function (node,e) { self.events.mousedown(node,e,true,true); },
789
+ 'touchstart': function (node,e) { self.events.touchstart(node,e,true,true); },
790
+ 'touchend': self.events.touchend,
773
791
  'click': self.events.click,
774
792
  'dblclick': self.events.dblclick,
775
793
  'mouseover': self.events.mouseover,
@@ -863,9 +881,9 @@ function WFAdaptorManifestation(adaptor) {
863
881
  return childs;
864
882
  }, //}}}
865
883
  'adaptor': {//{{{
866
- 'mousedown': function (node,e) {
867
- self.events.mousedown(node,e,true,true);
868
- },
884
+ 'mousedown': function (node,e) { self.events.mousedown(node,e,true,true); },
885
+ 'touchstart': function (node,e) { self.events.touchstart(node,e,true,true); },
886
+ 'touchend': self.events.touchend,
869
887
  'click': self.events.click,
870
888
  'dblclick': self.events.dblclick,
871
889
  'mouseover': self.events.mouseover,
@@ -956,9 +974,9 @@ function WFAdaptorManifestation(adaptor) {
956
974
  return childs;
957
975
  }, //}}}
958
976
  'adaptor': {//{{{
959
- 'mousedown': function (node,e) {
960
- self.events.mousedown(node,e,true,true);
961
- },
977
+ 'mousedown': function (node,e) { self.events.mousedown(node,e,true,true); },
978
+ 'touchstart': function (node,e) { self.events.touchstart(node,e,true,true); },
979
+ 'touchend': self.events.touchend,
962
980
  'click': self.events.click,
963
981
  'dblclick': self.events.dblclick,
964
982
  'mouseover': self.events.mouseover,
@@ -1050,9 +1068,9 @@ function WFAdaptorManifestation(adaptor) {
1050
1068
  return childs;
1051
1069
  }, //}}}
1052
1070
  'adaptor': {//{{{
1053
- 'mousedown': function (node,e) {
1054
- self.events.mousedown(node,e,true,true);
1055
- },
1071
+ 'mousedown': function (node,e) { self.events.mousedown(node,e,true,true); },
1072
+ 'touchstart': function (node,e) { self.events.touchstart(node,e,true,true); },
1073
+ 'touchend': self.events.touchend,
1056
1074
  'click': self.events.click,
1057
1075
  'dblclick': self.events.dblclick,
1058
1076
  'mouseover': self.events.mouseover,
@@ -1132,9 +1150,9 @@ function WFAdaptorManifestation(adaptor) {
1132
1150
  return childs;
1133
1151
  }, //}}}
1134
1152
  'adaptor': {//{{{
1135
- 'mousedown': function (node,e) {
1136
- self.events.mousedown(node,e,true,true);
1137
- },
1153
+ 'mousedown': function (node,e) { self.events.mousedown(node,e,true,true); },
1154
+ 'touchstart': function (node,e) { self.events.touchstart(node,e,true,true); },
1155
+ 'touchend': self.events.touchend,
1138
1156
  'click': self.events.click,
1139
1157
  'dblclick': self.events.dblclick,
1140
1158
  'mouseover': self.events.mouseover,
@@ -1164,9 +1182,9 @@ function WFAdaptorManifestation(adaptor) {
1164
1182
  ];
1165
1183
  }, //}}}
1166
1184
  'adaptor': {//{{{
1167
- 'mousedown': function (node,e) {
1168
- self.events.mousedown(node,e,true,true);
1169
- },
1185
+ 'mousedown': function (node,e) { self.events.mousedown(node,e,true,true); },
1186
+ 'touchstart': function (node,e) { self.events.touchstart(node,e,true,true); },
1187
+ 'touchend': self.events.touchend,
1170
1188
  'click': self.events.click,
1171
1189
  'dblclick': self.events.dblclick,
1172
1190
  'mouseover': self.events.mouseover,
@@ -1243,9 +1261,9 @@ function WFAdaptorManifestation(adaptor) {
1243
1261
  return childs;
1244
1262
  }, //}}}
1245
1263
  'adaptor': {//{{{
1246
- 'mousedown': function (node,e) {
1247
- self.events.mousedown(node,e,true,false);
1248
- },
1264
+ 'mousedown': function (node,e) { self.events.mousedown(node,e,true,false); },
1265
+ 'touchstart': function (node,e) { self.events.touchstart(node,e,true,false); },
1266
+ 'touchend': self.events.touchend,
1249
1267
  'click': self.events.click,
1250
1268
  'dblclick': self.events.dblclick,
1251
1269
  'mouseover': self.events.mouseover,