calendars_controller.rb
44 lines
| 1.4 KiB
| text/x-ruby
|
RubyLexer
|
r3618 | class CalendarsController < ApplicationController | ||
|
r3830 | menu_item :calendar | ||
|
r3618 | before_filter :find_optional_project | ||
rescue_from Query::StatementInvalid, :with => :query_statement_invalid | ||||
helper :issues | ||||
helper :projects | ||||
helper :queries | ||||
include QueriesHelper | ||||
|
r4131 | helper :sort | ||
include SortHelper | ||||
|
r3618 | |||
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 | ||||
|
r3927 | render :action => 'show', :layout => false if request.xhr? | ||
|
r3618 | end | ||
|
r3927 | def update | ||
show | ||||
end | ||||
|
r3618 | |||
end | ||||