0

我想为商店实现营业时间模式。

目前我有

Class Store
  has_one :opening_table

  #return opening_times as an array
  def opening_times
    self.build_opening_table unless opening_table
    (0..6).collect{ |i| 
      [opening_table.read_attribute("open_#{i}"),opening_table.read_attribute("close_#{i}") ]
    }      
  end

  def opening_times=(attr)
    self.build_opening_table unless opening_table
    i=0
    attr.each do |el|
      opening_table.attributes= {"open_#{i}".to_sym => el[0]}
      opening_table.attributes= {"close_#{i}".to_sym => el[1]}
      i=i+1
    end
 end

并且OpeningTable 有字段open_0、close_0 表示周一开盘和收盘时间

 create_table :opening_tables do |t|
  t.references :advertisement, :null=>false
  (0..6).each do |i|
    t.integer "open_#{i}"
    t.integer "close_#{i}"
  end
  t.timestamps
end

我对这个解决方案感到不舒服和灵活,但我不知道以更好的方式实施它

4

1 回答 1

1

你可以制作另一个名为Schedule

create_table :schedules do |t|
   t.integer 'open'
   t.integer 'close'
   t.integer store_id
   t.timestamps
end

然后做店铺has _many :schedules

所以你可以Store.first.schedules[0].open访问等等。

编辑:对于嵌套属性,您只需通过store.schedules[0]

或者您可以添加到schedules表中:

t.string :week_day

然后做store.schedules.find_by_week_day("monday")

至于验证,将其添加到您的 models/store.rb

validate :has_seven_schedules
...
def has_seven_schedules
   self.schedules.count == 7 ? true : false
end

编辑2:

如果您愿意,可以将其find_by_week_day("monday")放在 store.rb 模型中的方法上,例如:

def opening_time(day)
   schedule = self.schedules.find_by_week_day(day)
   unless schedule.nil?
       return schedule.open
   end
end

关闭时间也是如此。

于 2013-01-10T20:37:21.860 回答