tracks/tracks/app/controllers/todo_controller.rb
bsag e0b9ba0182 Added first patch contributed by Jim Ray: adds a host of fixes and bits of cleaning up, including a position column for contexts and projects to allow custom sorting, and changes to the links for pages to make them more human-readable.
I also added a pop-up calendar to set the due date. This is entirely lifted from Michele's excellent tutorial on pxl8.com (<http://www.pxl8.com/calendar_date_picker.html>). It works well, but I need to make sure it doesn't break in postgresql or sqlite.


git-svn-id: http://www.rousette.org.uk/svn/tracks-repos/trunk@49 a4c988fc-2ded-0310-b66e-134b36920a42
2005-03-27 17:45:49 +00:00

133 lines
4.2 KiB
Ruby

class TodoController < ApplicationController
helper :todo
model :context, :project
before_filter :login_required
caches_action :list, :completed, :completed_archive
layout "standard"
# Main method for listing tasks
# Set page title, and fill variables with contexts and done and not-done tasks
#
def index
list
render_action "list"
end
def list
@page_title = "List tasks"
@projects = Project.find_all
@places = Context.find_all
@shown_places = Context.find_all_by_hide( 0, "position ASC")
@hidden_places = Context.find_all_by_hide( 1, "position ASC" )
@done = Todo.find_all_by_done( 1, "completed DESC", 5 )
# Set count badge to number of not-done, not hidden context items
@count = count_shown_items(@hidden_places)
end
# List the completed tasks, sorted by completion date
#
# Use days declaration? 1.day.ago?
def completed
@page_title = "Completed tasks"
today_query = "DATE_SUB(CURDATE(),INTERVAL 1 DAY) <= completed"
week_query = "DATE_SUB(CURDATE(),INTERVAL 2 DAY) >= completed
AND DATE_SUB(CURDATE(),INTERVAL 7 DAY) <= completed"
month_query = "DATE_SUB(CURDATE(),INTERVAL 8 DAY) >= completed
AND DATE_SUB(CURDATE(),INTERVAL 31 DAY) <= completed"
@done_today = Todo.find_by_sql( "SELECT * FROM todos WHERE done = 1 AND #{today_query}
ORDER BY completed DESC;" )
@done_this_week = Todo.find_by_sql( "SELECT * FROM todos WHERE done = 1 AND #{week_query}
ORDER BY completed DESC;" )
@done_this_month = Todo.find_by_sql( "SELECT * FROM todos WHERE done = 1 AND #{month_query}
ORDER BY completed DESC;" )
end
# Archived completed items, older than 31 days
#
def completed_archive
@page_title = "Archived completed tasks"
archive_query = "DATE_SUB(CURDATE(),INTERVAL 32 DAY) >= completed"
@done_archive = Todo.find_by_sql( "SELECT * FROM todos WHERE done = 1 AND #{archive_query}
ORDER BY completed DESC;" )
end
# Called by a form button
# Parameters from form fields should be passed to create new item
#
def add_item
expire_action(:controller => "todo", :action => "list")
@item = Todo.new
@item.attributes = @params["item"]
if @item.save
flash["confirmation"] = "Next action \"#{@item.description}\" was successfully added"
redirect_to( :action => "list" )
else
flash["warning"] = "Couldn't add the action \"#{@item.description}\""
redirect_to( :action => "list" )
end
end
def edit
expire_action(:controller => "todo", :action => "list")
@item = Todo.find(@params['id'])
@belongs = @item.project_id
@projects = Project.find_all
@places = Context.find_all
@page_title = "Edit task: #{@item.description}"
end
def update
expire_action(:controller => "todo", :action => "list")
@item = Todo.find(@params['item']['id'])
@item.attributes = @params['item']
if @item.save
flash["confirmation"] = "Next action \"#{@item.description}\" was successfully updated"
redirect_to :action => 'list'
else
flash["warning"] = "Next action \"#{@item.description}\" could not be updated"
redirect_to :action => 'list'
end
end
def destroy
expire_action(:controller => "todo", :action => "list")
item = Todo.find(@params['id'])
if item.destroy
flash["confirmation"] = "Next action \"#{item.description}\" was successfully deleted"
redirect_to :action => "list"
else
flash["warning"] = "Couldn't delete next action \"#{item.description}\""
redirect_to :action => "list"
end
end
# Toggles the 'done' status of the action
#
def toggle_check
expire_action(:controller => "todo", :action => "list")
expire_action(:controller => "todo", :action => "completed")
expire_action(:controller => "todo", :action => "completed_archive")
item = Todo.find(@params['id'])
item.toggle!('done')
if item.save
#flash["confirmation"] = "Next action \"#{item.description}\" marked as completed"
#redirect_to( :action => "list" )
else
flash["warning"] = "Couldn't mark action \"#{item.description}\" as completed"
redirect_to( :action => "list" )
end
end
end