##// END OF EJS Templates
Do not hide context menu when clicking on a folder menu item....
Jean-Philippe Lang -
r8709:daacea11dc2b
parent child
Show More
@@ -1,138 +1,138
1 <ul>
1 <ul>
2 <%= call_hook(:view_issues_context_menu_start, {:issues => @issues, :can => @can, :back => @back }) %>
2 <%= call_hook(:view_issues_context_menu_start, {:issues => @issues, :can => @can, :back => @back }) %>
3
3
4 <% if !@issue.nil? -%>
4 <% if !@issue.nil? -%>
5 <li><%= context_menu_link l(:button_edit), {:controller => 'issues', :action => 'edit', :id => @issue},
5 <li><%= context_menu_link l(:button_edit), {:controller => 'issues', :action => 'edit', :id => @issue},
6 :class => 'icon-edit', :disabled => !@can[:edit] %></li>
6 :class => 'icon-edit', :disabled => !@can[:edit] %></li>
7 <% else %>
7 <% else %>
8 <li><%= context_menu_link l(:button_edit), {:controller => 'issues', :action => 'bulk_edit', :ids => @issues.collect(&:id)},
8 <li><%= context_menu_link l(:button_edit), {:controller => 'issues', :action => 'bulk_edit', :ids => @issues.collect(&:id)},
9 :class => 'icon-edit', :disabled => !@can[:edit] %></li>
9 :class => 'icon-edit', :disabled => !@can[:edit] %></li>
10 <% end %>
10 <% end %>
11
11
12 <% if @allowed_statuses.present? %>
12 <% if @allowed_statuses.present? %>
13 <li class="folder">
13 <li class="folder">
14 <a href="#" class="submenu" onclick="return false;"><%= l(:field_status) %></a>
14 <a href="#" class="submenu"><%= l(:field_status) %></a>
15 <ul>
15 <ul>
16 <% @allowed_statuses.each do |s| -%>
16 <% @allowed_statuses.each do |s| -%>
17 <li><%= context_menu_link h(s.name), {:controller => 'issues', :action => 'bulk_update', :ids => @issues.collect(&:id), :issue => {:status_id => s}, :back_url => @back}, :method => :post,
17 <li><%= context_menu_link h(s.name), {:controller => 'issues', :action => 'bulk_update', :ids => @issues.collect(&:id), :issue => {:status_id => s}, :back_url => @back}, :method => :post,
18 :selected => (@issue && s == @issue.status), :disabled => !@can[:update] %></li>
18 :selected => (@issue && s == @issue.status), :disabled => !@can[:update] %></li>
19 <% end -%>
19 <% end -%>
20 </ul>
20 </ul>
21 </li>
21 </li>
22 <% end %>
22 <% end %>
23
23
24 <% unless @trackers.nil? %>
24 <% unless @trackers.nil? %>
25 <li class="folder">
25 <li class="folder">
26 <a href="#" class="submenu"><%= l(:field_tracker) %></a>
26 <a href="#" class="submenu"><%= l(:field_tracker) %></a>
27 <ul>
27 <ul>
28 <% @trackers.each do |t| -%>
28 <% @trackers.each do |t| -%>
29 <li><%= context_menu_link h(t.name), {:controller => 'issues', :action => 'bulk_update', :ids => @issues.collect(&:id), :issue => {'tracker_id' => t}, :back_url => @back}, :method => :post,
29 <li><%= context_menu_link h(t.name), {:controller => 'issues', :action => 'bulk_update', :ids => @issues.collect(&:id), :issue => {'tracker_id' => t}, :back_url => @back}, :method => :post,
30 :selected => (@issue && t == @issue.tracker), :disabled => !@can[:edit] %></li>
30 :selected => (@issue && t == @issue.tracker), :disabled => !@can[:edit] %></li>
31 <% end -%>
31 <% end -%>
32 </ul>
32 </ul>
33 </li>
33 </li>
34 <% end %>
34 <% end %>
35
35
36 <li class="folder">
36 <li class="folder">
37 <a href="#" class="submenu"><%= l(:field_priority) %></a>
37 <a href="#" class="submenu"><%= l(:field_priority) %></a>
38 <ul>
38 <ul>
39 <% @priorities.each do |p| -%>
39 <% @priorities.each do |p| -%>
40 <li><%= context_menu_link h(p.name), {:controller => 'issues', :action => 'bulk_update', :ids => @issues.collect(&:id), :issue => {'priority_id' => p}, :back_url => @back}, :method => :post,
40 <li><%= context_menu_link h(p.name), {:controller => 'issues', :action => 'bulk_update', :ids => @issues.collect(&:id), :issue => {'priority_id' => p}, :back_url => @back}, :method => :post,
41 :selected => (@issue && p == @issue.priority), :disabled => (!@can[:edit] || @issues.detect {|i| !i.leaf?}) %></li>
41 :selected => (@issue && p == @issue.priority), :disabled => (!@can[:edit] || @issues.detect {|i| !i.leaf?}) %></li>
42 <% end -%>
42 <% end -%>
43 </ul>
43 </ul>
44 </li>
44 </li>
45
45
46 <% #TODO: allow editing versions when multiple projects %>
46 <% #TODO: allow editing versions when multiple projects %>
47 <% unless @project.nil? || @project.shared_versions.open.empty? -%>
47 <% unless @project.nil? || @project.shared_versions.open.empty? -%>
48 <li class="folder">
48 <li class="folder">
49 <a href="#" class="submenu"><%= l(:field_fixed_version) %></a>
49 <a href="#" class="submenu"><%= l(:field_fixed_version) %></a>
50 <ul>
50 <ul>
51 <% @project.shared_versions.open.sort.each do |v| -%>
51 <% @project.shared_versions.open.sort.each do |v| -%>
52 <li><%= context_menu_link format_version_name(v), {:controller => 'issues', :action => 'bulk_update', :ids => @issues.collect(&:id), :issue => {'fixed_version_id' => v}, :back_url => @back}, :method => :post,
52 <li><%= context_menu_link format_version_name(v), {:controller => 'issues', :action => 'bulk_update', :ids => @issues.collect(&:id), :issue => {'fixed_version_id' => v}, :back_url => @back}, :method => :post,
53 :selected => (@issue && v == @issue.fixed_version), :disabled => !@can[:update] %></li>
53 :selected => (@issue && v == @issue.fixed_version), :disabled => !@can[:update] %></li>
54 <% end -%>
54 <% end -%>
55 <li><%= context_menu_link l(:label_none), {:controller => 'issues', :action => 'bulk_update', :ids => @issues.collect(&:id), :issue => {'fixed_version_id' => 'none'}, :back_url => @back}, :method => :post,
55 <li><%= context_menu_link l(:label_none), {:controller => 'issues', :action => 'bulk_update', :ids => @issues.collect(&:id), :issue => {'fixed_version_id' => 'none'}, :back_url => @back}, :method => :post,
56 :selected => (@issue && @issue.fixed_version.nil?), :disabled => !@can[:update] %></li>
56 :selected => (@issue && @issue.fixed_version.nil?), :disabled => !@can[:update] %></li>
57 </ul>
57 </ul>
58 </li>
58 </li>
59 <% end %>
59 <% end %>
60 <% if @assignables.present? -%>
60 <% if @assignables.present? -%>
61 <li class="folder">
61 <li class="folder">
62 <a href="#" class="submenu"><%= l(:field_assigned_to) %></a>
62 <a href="#" class="submenu"><%= l(:field_assigned_to) %></a>
63 <ul>
63 <ul>
64 <% if @assignables.include?(User.current) %>
64 <% if @assignables.include?(User.current) %>
65 <li><%= context_menu_link "<< #{l(:label_me)} >>", {:controller => 'issues', :action => 'bulk_update', :ids => @issues.collect(&:id), :issue => {'assigned_to_id' => User.current}, :back_url => @back}, :method => :post,
65 <li><%= context_menu_link "<< #{l(:label_me)} >>", {:controller => 'issues', :action => 'bulk_update', :ids => @issues.collect(&:id), :issue => {'assigned_to_id' => User.current}, :back_url => @back}, :method => :post,
66 :disabled => !@can[:update] %></li>
66 :disabled => !@can[:update] %></li>
67 <% end %>
67 <% end %>
68 <% @assignables.each do |u| -%>
68 <% @assignables.each do |u| -%>
69 <li><%= context_menu_link h(u.name), {:controller => 'issues', :action => 'bulk_update', :ids => @issues.collect(&:id), :issue => {'assigned_to_id' => u}, :back_url => @back}, :method => :post,
69 <li><%= context_menu_link h(u.name), {:controller => 'issues', :action => 'bulk_update', :ids => @issues.collect(&:id), :issue => {'assigned_to_id' => u}, :back_url => @back}, :method => :post,
70 :selected => (@issue && u == @issue.assigned_to), :disabled => !@can[:update] %></li>
70 :selected => (@issue && u == @issue.assigned_to), :disabled => !@can[:update] %></li>
71 <% end -%>
71 <% end -%>
72 <li><%= context_menu_link l(:label_nobody), {:controller => 'issues', :action => 'bulk_update', :ids => @issues.collect(&:id), :issue => {'assigned_to_id' => 'none'}, :back_url => @back}, :method => :post,
72 <li><%= context_menu_link l(:label_nobody), {:controller => 'issues', :action => 'bulk_update', :ids => @issues.collect(&:id), :issue => {'assigned_to_id' => 'none'}, :back_url => @back}, :method => :post,
73 :selected => (@issue && @issue.assigned_to.nil?), :disabled => !@can[:update] %></li>
73 :selected => (@issue && @issue.assigned_to.nil?), :disabled => !@can[:update] %></li>
74 </ul>
74 </ul>
75 </li>
75 </li>
76 <% end %>
76 <% end %>
77 <% unless @project.nil? || @project.issue_categories.empty? -%>
77 <% unless @project.nil? || @project.issue_categories.empty? -%>
78 <li class="folder">
78 <li class="folder">
79 <a href="#" class="submenu"><%= l(:field_category) %></a>
79 <a href="#" class="submenu"><%= l(:field_category) %></a>
80 <ul>
80 <ul>
81 <% @project.issue_categories.each do |u| -%>
81 <% @project.issue_categories.each do |u| -%>
82 <li><%= context_menu_link h(u.name), {:controller => 'issues', :action => 'bulk_update', :ids => @issues.collect(&:id), :issue => {'category_id' => u}, :back_url => @back}, :method => :post,
82 <li><%= context_menu_link h(u.name), {:controller => 'issues', :action => 'bulk_update', :ids => @issues.collect(&:id), :issue => {'category_id' => u}, :back_url => @back}, :method => :post,
83 :selected => (@issue && u == @issue.category), :disabled => !@can[:update] %></li>
83 :selected => (@issue && u == @issue.category), :disabled => !@can[:update] %></li>
84 <% end -%>
84 <% end -%>
85 <li><%= context_menu_link l(:label_none), {:controller => 'issues', :action => 'bulk_update', :ids => @issues.collect(&:id), :issue => {'category_id' => 'none'}, :back_url => @back}, :method => :post,
85 <li><%= context_menu_link l(:label_none), {:controller => 'issues', :action => 'bulk_update', :ids => @issues.collect(&:id), :issue => {'category_id' => 'none'}, :back_url => @back}, :method => :post,
86 :selected => (@issue && @issue.category.nil?), :disabled => !@can[:update] %></li>
86 :selected => (@issue && @issue.category.nil?), :disabled => !@can[:update] %></li>
87 </ul>
87 </ul>
88 </li>
88 </li>
89 <% end -%>
89 <% end -%>
90
90
91 <% if Issue.use_field_for_done_ratio? %>
91 <% if Issue.use_field_for_done_ratio? %>
92 <li class="folder">
92 <li class="folder">
93 <a href="#" class="submenu"><%= l(:field_done_ratio) %></a>
93 <a href="#" class="submenu"><%= l(:field_done_ratio) %></a>
94 <ul>
94 <ul>
95 <% (0..10).map{|x|x*10}.each do |p| -%>
95 <% (0..10).map{|x|x*10}.each do |p| -%>
96 <li><%= context_menu_link "#{p}%", {:controller => 'issues', :action => 'bulk_update', :ids => @issues.collect(&:id), :issue => {'done_ratio' => p}, :back_url => @back}, :method => :post,
96 <li><%= context_menu_link "#{p}%", {:controller => 'issues', :action => 'bulk_update', :ids => @issues.collect(&:id), :issue => {'done_ratio' => p}, :back_url => @back}, :method => :post,
97 :selected => (@issue && p == @issue.done_ratio), :disabled => (!@can[:edit] || @issues.detect {|i| !i.leaf?}) %></li>
97 :selected => (@issue && p == @issue.done_ratio), :disabled => (!@can[:edit] || @issues.detect {|i| !i.leaf?}) %></li>
98 <% end -%>
98 <% end -%>
99 </ul>
99 </ul>
100 </li>
100 </li>
101 <% end %>
101 <% end %>
102
102
103 <% @options_by_custom_field.each do |field, options| %>
103 <% @options_by_custom_field.each do |field, options| %>
104 <li class="folder">
104 <li class="folder">
105 <a href="#" class="submenu"><%= h(field.name) %></a>
105 <a href="#" class="submenu"><%= h(field.name) %></a>
106 <ul>
106 <ul>
107 <% options.each do |text, value| %>
107 <% options.each do |text, value| %>
108 <li><%= bulk_update_custom_field_context_menu_link(field, text, value || text) %></li>
108 <li><%= bulk_update_custom_field_context_menu_link(field, text, value || text) %></li>
109 <% end %>
109 <% end %>
110 <% unless field.is_required? %>
110 <% unless field.is_required? %>
111 <li><%= bulk_update_custom_field_context_menu_link(field, l(:label_none), '') %></li>
111 <li><%= bulk_update_custom_field_context_menu_link(field, l(:label_none), '') %></li>
112 <% end %>
112 <% end %>
113 </ul>
113 </ul>
114 </li>
114 </li>
115 <% end %>
115 <% end %>
116
116
117 <% if !@issue.nil? %>
117 <% if !@issue.nil? %>
118 <% if @can[:log_time] -%>
118 <% if @can[:log_time] -%>
119 <li><%= context_menu_link l(:button_log_time), {:controller => 'timelog', :action => 'new', :issue_id => @issue},
119 <li><%= context_menu_link l(:button_log_time), {:controller => 'timelog', :action => 'new', :issue_id => @issue},
120 :class => 'icon-time-add' %></li>
120 :class => 'icon-time-add' %></li>
121 <% end %>
121 <% end %>
122 <% if User.current.logged? %>
122 <% if User.current.logged? %>
123 <li><%= watcher_link(@issue, User.current) %></li>
123 <li><%= watcher_link(@issue, User.current) %></li>
124 <% end %>
124 <% end %>
125 <% end %>
125 <% end %>
126
126
127 <% if @issue.present? %>
127 <% if @issue.present? %>
128 <li><%= context_menu_link l(:button_copy), {:controller => 'issues', :action => 'new', :project_id => @project, :copy_from => @issue},
128 <li><%= context_menu_link l(:button_copy), {:controller => 'issues', :action => 'new', :project_id => @project, :copy_from => @issue},
129 :class => 'icon-copy', :disabled => !@can[:copy] %></li>
129 :class => 'icon-copy', :disabled => !@can[:copy] %></li>
130 <% else %>
130 <% else %>
131 <li><%= context_menu_link l(:button_copy), {:controller => 'issues', :action => 'bulk_edit', :ids => @issues.collect(&:id), :copy => '1'},
131 <li><%= context_menu_link l(:button_copy), {:controller => 'issues', :action => 'bulk_edit', :ids => @issues.collect(&:id), :copy => '1'},
132 :class => 'icon-copy', :disabled => !@can[:move] %></li>
132 :class => 'icon-copy', :disabled => !@can[:move] %></li>
133 <% end %>
133 <% end %>
134 <li><%= context_menu_link l(:button_delete), issues_path(:ids => @issues.collect(&:id), :back_url => @back),
134 <li><%= context_menu_link l(:button_delete), issues_path(:ids => @issues.collect(&:id), :back_url => @back),
135 :method => :delete, :confirm => issues_destroy_confirmation_message(@issues), :class => 'icon-del', :disabled => !@can[:delete] %></li>
135 :method => :delete, :confirm => issues_destroy_confirmation_message(@issues), :class => 'icon-del', :disabled => !@can[:delete] %></li>
136
136
137 <%= call_hook(:view_issues_context_menu_end, {:issues => @issues, :can => @can, :back => @back }) %>
137 <%= call_hook(:view_issues_context_menu_end, {:issues => @issues, :can => @can, :back => @back }) %>
138 </ul>
138 </ul>
@@ -1,232 +1,236
1 /* redMine - project management software
1 /* redMine - project management software
2 Copyright (C) 2006-2008 Jean-Philippe Lang */
2 Copyright (C) 2006-2008 Jean-Philippe Lang */
3
3
4 var observingContextMenuClick;
4 var observingContextMenuClick;
5
5
6 ContextMenu = Class.create();
6 ContextMenu = Class.create();
7 ContextMenu.prototype = {
7 ContextMenu.prototype = {
8 initialize: function (url) {
8 initialize: function (url) {
9 this.url = url;
9 this.url = url;
10 this.createMenu();
10 this.createMenu();
11
11
12 if (!observingContextMenuClick) {
12 if (!observingContextMenuClick) {
13 Event.observe(document, 'click', this.Click.bindAsEventListener(this));
13 Event.observe(document, 'click', this.Click.bindAsEventListener(this));
14 Event.observe(document, 'contextmenu', this.RightClick.bindAsEventListener(this));
14 Event.observe(document, 'contextmenu', this.RightClick.bindAsEventListener(this));
15 observingContextMenuClick = true;
15 observingContextMenuClick = true;
16 }
16 }
17
17
18 this.unselectAll();
18 this.unselectAll();
19 this.lastSelected = null;
19 this.lastSelected = null;
20 },
20 },
21
21
22 RightClick: function(e) {
22 RightClick: function(e) {
23 this.hideMenu();
23 this.hideMenu();
24 // do not show the context menu on links
24 // do not show the context menu on links
25 if (Event.element(e).tagName == 'A') { return; }
25 if (Event.element(e).tagName == 'A') { return; }
26 var tr = Event.findElement(e, 'tr');
26 var tr = Event.findElement(e, 'tr');
27 if (tr == document || tr == undefined || !tr.hasClassName('hascontextmenu')) { return; }
27 if (tr == document || tr == undefined || !tr.hasClassName('hascontextmenu')) { return; }
28 Event.stop(e);
28 Event.stop(e);
29 if (!this.isSelected(tr)) {
29 if (!this.isSelected(tr)) {
30 this.unselectAll();
30 this.unselectAll();
31 this.addSelection(tr);
31 this.addSelection(tr);
32 this.lastSelected = tr;
32 this.lastSelected = tr;
33 }
33 }
34 this.showMenu(e);
34 this.showMenu(e);
35 },
35 },
36
36
37 Click: function(e) {
37 Click: function(e) {
38 if (Event.element(e).tagName == 'A' && Event.element(e).hasClassName('submenu')) {
39 Event.stop(e)
40 return;
41 }
38 this.hideMenu();
42 this.hideMenu();
39 if (Event.element(e).tagName == 'A' || Event.element(e).tagName == 'IMG') { return; }
43 if (Event.element(e).tagName == 'A' || Event.element(e).tagName == 'IMG') { return; }
40 if (Event.isLeftClick(e) || (navigator.appVersion.match(/\bMSIE\b/))) {
44 if (Event.isLeftClick(e) || (navigator.appVersion.match(/\bMSIE\b/))) {
41 var tr = Event.findElement(e, 'tr');
45 var tr = Event.findElement(e, 'tr');
42 if (tr!=null && tr!=document && tr.hasClassName('hascontextmenu')) {
46 if (tr!=null && tr!=document && tr.hasClassName('hascontextmenu')) {
43 // a row was clicked, check if the click was on checkbox
47 // a row was clicked, check if the click was on checkbox
44 var box = Event.findElement(e, 'input');
48 var box = Event.findElement(e, 'input');
45 if (box!=document && box!=undefined) {
49 if (box!=document && box!=undefined) {
46 // a checkbox may be clicked
50 // a checkbox may be clicked
47 if (box.checked) {
51 if (box.checked) {
48 tr.addClassName('context-menu-selection');
52 tr.addClassName('context-menu-selection');
49 } else {
53 } else {
50 tr.removeClassName('context-menu-selection');
54 tr.removeClassName('context-menu-selection');
51 }
55 }
52 } else {
56 } else {
53 if (e.ctrlKey || e.metaKey) {
57 if (e.ctrlKey || e.metaKey) {
54 this.toggleSelection(tr);
58 this.toggleSelection(tr);
55 } else if (e.shiftKey) {
59 } else if (e.shiftKey) {
56 if (this.lastSelected != null) {
60 if (this.lastSelected != null) {
57 var toggling = false;
61 var toggling = false;
58 var rows = $$('.hascontextmenu');
62 var rows = $$('.hascontextmenu');
59 for (i=0; i<rows.length; i++) {
63 for (i=0; i<rows.length; i++) {
60 if (toggling || rows[i]==tr) {
64 if (toggling || rows[i]==tr) {
61 this.addSelection(rows[i]);
65 this.addSelection(rows[i]);
62 }
66 }
63 if (rows[i]==tr || rows[i]==this.lastSelected) {
67 if (rows[i]==tr || rows[i]==this.lastSelected) {
64 toggling = !toggling;
68 toggling = !toggling;
65 }
69 }
66 }
70 }
67 } else {
71 } else {
68 this.addSelection(tr);
72 this.addSelection(tr);
69 }
73 }
70 } else {
74 } else {
71 this.unselectAll();
75 this.unselectAll();
72 this.addSelection(tr);
76 this.addSelection(tr);
73 }
77 }
74 this.lastSelected = tr;
78 this.lastSelected = tr;
75 }
79 }
76 } else {
80 } else {
77 // click is outside the rows
81 // click is outside the rows
78 var t = Event.findElement(e, 'a');
82 var t = Event.findElement(e, 'a');
79 if (t == document || t == undefined) {
83 if (t == document || t == undefined) {
80 this.unselectAll();
84 this.unselectAll();
81 } else {
85 } else {
82 if (Element.hasClassName(t, 'disabled') || Element.hasClassName(t, 'submenu')) {
86 if (Element.hasClassName(t, 'disabled') || Element.hasClassName(t, 'submenu')) {
83 Event.stop(e);
87 Event.stop(e);
84 }
88 }
85 }
89 }
86 }
90 }
87 }
91 }
88 },
92 },
89
93
90 createMenu: function() {
94 createMenu: function() {
91 if (!$('context-menu')) {
95 if (!$('context-menu')) {
92 var menu = document.createElement("div");
96 var menu = document.createElement("div");
93 menu.setAttribute("id", "context-menu");
97 menu.setAttribute("id", "context-menu");
94 menu.setAttribute("style", "display:none;");
98 menu.setAttribute("style", "display:none;");
95 document.getElementById("content").appendChild(menu);
99 document.getElementById("content").appendChild(menu);
96 }
100 }
97 },
101 },
98
102
99 showMenu: function(e) {
103 showMenu: function(e) {
100 var mouse_x = Event.pointerX(e);
104 var mouse_x = Event.pointerX(e);
101 var mouse_y = Event.pointerY(e);
105 var mouse_y = Event.pointerY(e);
102 var render_x = mouse_x;
106 var render_x = mouse_x;
103 var render_y = mouse_y;
107 var render_y = mouse_y;
104 var dims;
108 var dims;
105 var menu_width;
109 var menu_width;
106 var menu_height;
110 var menu_height;
107 var window_width;
111 var window_width;
108 var window_height;
112 var window_height;
109 var max_width;
113 var max_width;
110 var max_height;
114 var max_height;
111
115
112 $('context-menu').style['left'] = (render_x + 'px');
116 $('context-menu').style['left'] = (render_x + 'px');
113 $('context-menu').style['top'] = (render_y + 'px');
117 $('context-menu').style['top'] = (render_y + 'px');
114 Element.update('context-menu', '');
118 Element.update('context-menu', '');
115
119
116 new Ajax.Updater({success:'context-menu'}, this.url,
120 new Ajax.Updater({success:'context-menu'}, this.url,
117 {asynchronous:true,
121 {asynchronous:true,
118 method: 'get',
122 method: 'get',
119 evalScripts:true,
123 evalScripts:true,
120 parameters:Form.serialize(Event.findElement(e, 'form')),
124 parameters:Form.serialize(Event.findElement(e, 'form')),
121 onComplete:function(request){
125 onComplete:function(request){
122 dims = $('context-menu').getDimensions();
126 dims = $('context-menu').getDimensions();
123 menu_width = dims.width;
127 menu_width = dims.width;
124 menu_height = dims.height;
128 menu_height = dims.height;
125 max_width = mouse_x + 2*menu_width;
129 max_width = mouse_x + 2*menu_width;
126 max_height = mouse_y + menu_height;
130 max_height = mouse_y + menu_height;
127
131
128 var ws = window_size();
132 var ws = window_size();
129 window_width = ws.width;
133 window_width = ws.width;
130 window_height = ws.height;
134 window_height = ws.height;
131
135
132 /* display the menu above and/or to the left of the click if needed */
136 /* display the menu above and/or to the left of the click if needed */
133 if (max_width > window_width) {
137 if (max_width > window_width) {
134 render_x -= menu_width;
138 render_x -= menu_width;
135 $('context-menu').addClassName('reverse-x');
139 $('context-menu').addClassName('reverse-x');
136 } else {
140 } else {
137 $('context-menu').removeClassName('reverse-x');
141 $('context-menu').removeClassName('reverse-x');
138 }
142 }
139 if (max_height > window_height) {
143 if (max_height > window_height) {
140 render_y -= menu_height;
144 render_y -= menu_height;
141 $('context-menu').addClassName('reverse-y');
145 $('context-menu').addClassName('reverse-y');
142 } else {
146 } else {
143 $('context-menu').removeClassName('reverse-y');
147 $('context-menu').removeClassName('reverse-y');
144 }
148 }
145 if (render_x <= 0) render_x = 1;
149 if (render_x <= 0) render_x = 1;
146 if (render_y <= 0) render_y = 1;
150 if (render_y <= 0) render_y = 1;
147 $('context-menu').style['left'] = (render_x + 'px');
151 $('context-menu').style['left'] = (render_x + 'px');
148 $('context-menu').style['top'] = (render_y + 'px');
152 $('context-menu').style['top'] = (render_y + 'px');
149
153
150 Effect.Appear('context-menu', {duration: 0.20});
154 Effect.Appear('context-menu', {duration: 0.20});
151 if (window.parseStylesheets) { window.parseStylesheets(); } // IE
155 if (window.parseStylesheets) { window.parseStylesheets(); } // IE
152 }})
156 }})
153 },
157 },
154
158
155 hideMenu: function() {
159 hideMenu: function() {
156 Element.hide('context-menu');
160 Element.hide('context-menu');
157 },
161 },
158
162
159 addSelection: function(tr) {
163 addSelection: function(tr) {
160 tr.addClassName('context-menu-selection');
164 tr.addClassName('context-menu-selection');
161 this.checkSelectionBox(tr, true);
165 this.checkSelectionBox(tr, true);
162 this.clearDocumentSelection();
166 this.clearDocumentSelection();
163 },
167 },
164
168
165 toggleSelection: function(tr) {
169 toggleSelection: function(tr) {
166 if (this.isSelected(tr)) {
170 if (this.isSelected(tr)) {
167 this.removeSelection(tr);
171 this.removeSelection(tr);
168 } else {
172 } else {
169 this.addSelection(tr);
173 this.addSelection(tr);
170 }
174 }
171 },
175 },
172
176
173 removeSelection: function(tr) {
177 removeSelection: function(tr) {
174 tr.removeClassName('context-menu-selection');
178 tr.removeClassName('context-menu-selection');
175 this.checkSelectionBox(tr, false);
179 this.checkSelectionBox(tr, false);
176 },
180 },
177
181
178 unselectAll: function() {
182 unselectAll: function() {
179 var rows = $$('.hascontextmenu');
183 var rows = $$('.hascontextmenu');
180 for (i=0; i<rows.length; i++) {
184 for (i=0; i<rows.length; i++) {
181 this.removeSelection(rows[i]);
185 this.removeSelection(rows[i]);
182 }
186 }
183 },
187 },
184
188
185 checkSelectionBox: function(tr, checked) {
189 checkSelectionBox: function(tr, checked) {
186 var inputs = Element.getElementsBySelector(tr, 'input');
190 var inputs = Element.getElementsBySelector(tr, 'input');
187 if (inputs.length > 0) { inputs[0].checked = checked; }
191 if (inputs.length > 0) { inputs[0].checked = checked; }
188 },
192 },
189
193
190 isSelected: function(tr) {
194 isSelected: function(tr) {
191 return Element.hasClassName(tr, 'context-menu-selection');
195 return Element.hasClassName(tr, 'context-menu-selection');
192 },
196 },
193
197
194 clearDocumentSelection: function() {
198 clearDocumentSelection: function() {
195 if (document.selection) {
199 if (document.selection) {
196 document.selection.clear(); // IE
200 document.selection.clear(); // IE
197 } else {
201 } else {
198 window.getSelection().removeAllRanges();
202 window.getSelection().removeAllRanges();
199 }
203 }
200 }
204 }
201 }
205 }
202
206
203 function toggleIssuesSelection(el) {
207 function toggleIssuesSelection(el) {
204 var boxes = el.getElementsBySelector('input[type=checkbox]');
208 var boxes = el.getElementsBySelector('input[type=checkbox]');
205 var all_checked = true;
209 var all_checked = true;
206 for (i = 0; i < boxes.length; i++) { if (boxes[i].checked == false) { all_checked = false; } }
210 for (i = 0; i < boxes.length; i++) { if (boxes[i].checked == false) { all_checked = false; } }
207 for (i = 0; i < boxes.length; i++) {
211 for (i = 0; i < boxes.length; i++) {
208 if (all_checked) {
212 if (all_checked) {
209 boxes[i].checked = false;
213 boxes[i].checked = false;
210 boxes[i].up('tr').removeClassName('context-menu-selection');
214 boxes[i].up('tr').removeClassName('context-menu-selection');
211 } else if (boxes[i].checked == false) {
215 } else if (boxes[i].checked == false) {
212 boxes[i].checked = true;
216 boxes[i].checked = true;
213 boxes[i].up('tr').addClassName('context-menu-selection');
217 boxes[i].up('tr').addClassName('context-menu-selection');
214 }
218 }
215 }
219 }
216 }
220 }
217
221
218 function window_size() {
222 function window_size() {
219 var w;
223 var w;
220 var h;
224 var h;
221 if (window.innerWidth) {
225 if (window.innerWidth) {
222 w = window.innerWidth;
226 w = window.innerWidth;
223 h = window.innerHeight;
227 h = window.innerHeight;
224 } else if (document.documentElement) {
228 } else if (document.documentElement) {
225 w = document.documentElement.clientWidth;
229 w = document.documentElement.clientWidth;
226 h = document.documentElement.clientHeight;
230 h = document.documentElement.clientHeight;
227 } else {
231 } else {
228 w = document.body.clientWidth;
232 w = document.body.clientWidth;
229 h = document.body.clientHeight;
233 h = document.body.clientHeight;
230 }
234 }
231 return {width: w, height: h};
235 return {width: w, height: h};
232 }
236 }
General Comments 0
You need to be logged in to leave comments. Login now