| 
									
										
										
										
											2010-05-03 16:02:37 +00:00
										 |  |  | class CalendarsController < ApplicationController | 
					
						
							| 
									
										
										
										
											2010-11-07 22:38:10 +00:00
										 |  |  |   menu_item :calendar | 
					
						
							| 
									
										
										
										
											2010-05-03 16:02:37 +00:00
										 |  |  |   before_filter :find_optional_project | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   rescue_from Query::StatementInvalid, :with => :query_statement_invalid | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   helper :issues | 
					
						
							|  |  |  |   helper :projects | 
					
						
							|  |  |  |   helper :queries | 
					
						
							|  |  |  |   include QueriesHelper | 
					
						
							| 
									
										
										
										
											2010-10-10 21:17:10 +00:00
										 |  |  |   helper :sort | 
					
						
							|  |  |  |   include SortHelper | 
					
						
							| 
									
										
										
										
											2010-05-03 16:02:37 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   def show | 
					
						
							|  |  |  |     if params[:year] and params[:year].to_i > 1900
 | 
					
						
							|  |  |  |       @year = params[:year].to_i | 
					
						
							|  |  |  |       if params[:month] and params[:month].to_i > 0 and params[:month].to_i < 13
 | 
					
						
							|  |  |  |         @month = params[:month].to_i | 
					
						
							|  |  |  |       end     | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |     @year ||= Date.today.year | 
					
						
							|  |  |  |     @month ||= Date.today.month | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     @calendar = Redmine::Helpers::Calendar.new(Date.civil(@year, @month, 1), current_language, :month) | 
					
						
							|  |  |  |     retrieve_query | 
					
						
							|  |  |  |     @query.group_by = nil | 
					
						
							|  |  |  |     if @query.valid? | 
					
						
							|  |  |  |       events = [] | 
					
						
							|  |  |  |       events += @query.issues(:include => [:tracker, :assigned_to, :priority], | 
					
						
							|  |  |  |                               :conditions => ["((start_date BETWEEN ? AND ?) OR (due_date BETWEEN ? AND ?))", @calendar.startdt, @calendar.enddt, @calendar.startdt, @calendar.enddt] | 
					
						
							|  |  |  |                               ) | 
					
						
							|  |  |  |       events += @query.versions(:conditions => ["effective_date BETWEEN ? AND ?", @calendar.startdt, @calendar.enddt]) | 
					
						
							|  |  |  |                                       | 
					
						
							|  |  |  |       @calendar.events = events | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2010-08-26 16:36:59 +00:00
										 |  |  |     render :action => 'show', :layout => false if request.xhr? | 
					
						
							| 
									
										
										
										
											2010-05-03 16:02:37 +00:00
										 |  |  |   end | 
					
						
							|  |  |  |    | 
					
						
							| 
									
										
										
										
											2010-08-26 16:36:59 +00:00
										 |  |  |   def update | 
					
						
							|  |  |  |     show | 
					
						
							|  |  |  |   end | 
					
						
							| 
									
										
										
										
											2010-05-03 16:02:37 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | end |