2008-09-13 13:33:48 -07:00
|
|
|
class ChangeDatesToDatetimes < ActiveRecord::Migration
|
|
|
|
|
def self.up
|
|
|
|
|
change_column :todos, :show_from, :datetime
|
|
|
|
|
change_column :todos, :due, :datetime
|
|
|
|
|
change_column :recurring_todos, :start_from, :datetime
|
|
|
|
|
change_column :recurring_todos, :end_date, :datetime
|
2008-09-20 17:34:22 -07:00
|
|
|
|
2008-09-13 13:33:48 -07:00
|
|
|
User.all(:include => [:todos, :recurring_todos]).each do |user|
|
2008-10-04 13:41:37 -04:00
|
|
|
if user.prefs
|
|
|
|
|
user.todos.each do |todo|
|
|
|
|
|
todo.update_attribute(:show_from, user.at_midnight(todo.show_from)) unless todo.show_from.nil?
|
|
|
|
|
todo.update_attribute(:due, user.at_midnight(todo.due)) unless todo.due.nil?
|
|
|
|
|
end
|
2008-09-20 17:34:22 -07:00
|
|
|
|
2008-10-04 13:41:37 -04:00
|
|
|
user.recurring_todos.each do |todo|
|
|
|
|
|
todo.update_attribute(:start_from, user.at_midnight(todo.start_from)) unless todo.start_from.nil?
|
|
|
|
|
todo.update_attribute(:end_date, user.at_midnight(todo.end_date)) unless todo.end_date.nil?
|
|
|
|
|
end
|
|
|
|
|
else # weird...no preferences for this user
|
|
|
|
|
user.todos.each do |todo|
|
|
|
|
|
todo.update_attribute(:show_from, at_midnight(todo.show_from)) unless todo.show_from.nil?
|
|
|
|
|
todo.update_attribute(:due, at_midnight(todo.due)) unless todo.due.nil?
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
user.recurring_todos.each do |todo|
|
|
|
|
|
todo.update_attribute(:start_from, at_midnight(todo.start_from)) unless todo.start_from.nil?
|
|
|
|
|
todo.update_attribute(:end_date, at_midnight(todo.end_date)) unless todo.end_date.nil?
|
|
|
|
|
end
|
2008-09-13 13:33:48 -07:00
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2008-10-04 13:41:37 -04:00
|
|
|
def at_midnight(date)
|
|
|
|
|
return Time.zone.local(date.year, date.month, date.day, 0, 0, 0)
|
|
|
|
|
end
|
|
|
|
|
|
2008-09-13 13:33:48 -07:00
|
|
|
def self.down
|
|
|
|
|
change_column :todos, :show_from, :date
|
|
|
|
|
change_column :todos, :due, :date
|
|
|
|
|
change_column :recurring_todos, :start_from, :date
|
|
|
|
|
change_column :recurring_todos, :end_date, :date
|
|
|
|
|
end
|
|
|
|
|
end
|