class ContextMenusController < ApplicationController helper :watchers helper :issues def issues @issues = Issue.visible.all(:conditions => {:id => params[:ids]}, :include => :project) if (@issues.size == 1) @issue = @issues.first @allowed_statuses = @issue.new_statuses_allowed_to(User.current) else @allowed_statuses = @issues.map do |i| i.new_statuses_allowed_to(User.current) end.inject do |memo,s| memo & s end end @projects = @issues.collect(&:project).compact.uniq @project = @projects.first if @projects.size == 1 @can = {:edit => User.current.allowed_to?(:edit_issues, @projects), :log_time => (@project && User.current.allowed_to?(:log_time, @project)), :update => (User.current.allowed_to?(:edit_issues, @projects) || (User.current.allowed_to?(:change_status, @projects) && !@allowed_statuses.blank?)), :move => (@project && User.current.allowed_to?(:move_issues, @project)), :copy => (@issue && @project.trackers.include?(@issue.tracker) && User.current.allowed_to?(:add_issues, @project)), :delete => User.current.allowed_to?(:delete_issues, @projects) } if @project if @issue @assignables = @issue.assignable_users else @assignables = @project.assignable_users end @trackers = @project.trackers else #when multiple projects, we only keep the intersection of each set @assignables = @projects.map(&:assignable_users).inject{|memo,a| memo & a} @trackers = @projects.map(&:trackers).inject{|memo,t| memo & t} end @priorities = IssuePriority.active.reverse @statuses = IssueStatus.find(:all, :order => 'position') @back = back_url render :layout => false end def time_entries @time_entries = TimeEntry.all( :conditions => {:id => params[:ids]}, :include => :project) @projects = @time_entries.collect(&:project).compact.uniq @project = @projects.first if @projects.size == 1 @activities = TimeEntryActivity.shared.active @can = {:edit => User.current.allowed_to?(:edit_time_entries, @projects), :delete => User.current.allowed_to?(:edit_time_entries, @projects) } @back = back_url render :layout => false end end