annotate db/migrate/072_add_enumerations_position.rb @ 774:58410c63bb84 feature_334

Force a Google search box rudely into the middle of the search view, just to see how it looks. It can be styled reasonably well -- but the adverts, when they appear, are atrocious.
author Chris Cannam <chris.cannam@soundsoftware.ac.uk>
date Thu, 17 Nov 2011 14:56:55 +0000
parents 513646585e45
children 622f24f53b42
rev   line source
Chris@0 1 class AddEnumerationsPosition < ActiveRecord::Migration
Chris@0 2 def self.up
Chris@0 3 add_column(:enumerations, :position, :integer, :default => 1) unless Enumeration.column_names.include?('position')
Chris@0 4 Enumeration.find(:all).group_by(&:opt).each do |opt, enums|
Chris@0 5 enums.each_with_index do |enum, i|
Chris@0 6 # do not call model callbacks
Chris@0 7 Enumeration.update_all "position = #{i+1}", {:id => enum.id}
Chris@0 8 end
Chris@0 9 end
Chris@0 10 end
Chris@0 11
Chris@0 12 def self.down
Chris@0 13 remove_column :enumerations, :position
Chris@0 14 end
Chris@0 15 end