Rails:按日期查找条目

时间:2013-10-22 13:22:40

标签: ruby-on-rails ruby ruby-on-rails-4

我正在运行Ruby 2和Rails 4。

我正在创建一个应用程序,您可以在其中跟踪特定日期输入的每餐的卡路里和常量营养素,但我希望能够回顾前几天。

我有一张表格,通过我的模型中的范围显示今天在我的索引页面上输入了哪些餐点。我如何实现回顾Rails其他日子的能力?

我应该添加日期模型还是给每顿饭一个日期时间?这种事情有没有宝石?

用餐模型

class Meal < ActiveRecord::Base

  scope :today, lambda { 
    where("created_at > ?", Time.now.beginning_of_day)
    .where("created_at < ?", Time.now.end_of_day) 
  }

  scope :previous, lambda {
    where("created_at < ?", Time.now.beginning_of_day) 
  }

  validates :name, presence: true
  validates :calories, presence: true, numericality: { only
  validates :protein, numericality: { only_integer: true }
  validates :carbohydrates, numericality: { only_integer: t
  validates :fats, numericality: { only_integer: true }

  belongs_to :user

end

用餐控制器

  def index
    if user_signed_in?
      @todays_meals = current_user.meals.today
      unless current_user.bmr.blank? || current_user.weight.blank? || current_user.protein_intake.blank? || current_user.fat_percentage.blank?
        @remaining_calories = (current_user.bmr) - @todays_meals.sum(:calories)
        @remaining_protein = current_user.protein_intake - @todays_meals.sum(:protein)
        @remaining_fats = (current_user.bmr * current_user.fat_percentage / 900).to_i - @todays_meals.sum(:fats)
        @remaining_carbs = carbs_calculator
        @fat_grams = current_user.fat_percentage * current_user.bmr / 900
        @carb_grams = (carbs_calculator + @todays_meals.sum(:carbohydrates))
      end
    else
      @no_header = true
    end
  end

谢谢!

1 个答案:

答案 0 :(得分:4)

首先,您可以简化today范围,因为除了您手动更新created_at日期之外,实际上没有办法在今天结束之前创建某些内容(使用标准的Rails方法)。

scope :today, -> { 
  where("created_at > ?", Time.now.beginning_of_day)
}

与前几天一样,您可以使用以下范围来抓取它们并在当天将它们分组

scope :in_the_past_x_days, -> (x) {
  where('meals.created_at > ?', x.days.ago)
  .group("DATE(meals.created_at)")
}

如果您要查找特定日期,可以使用以下内容:

scope :for_date, -> (date) { 
  where("created_at > ?", date.beginning_of_day)
  .where("created_at < ?", date.end_of_day) 
}

作为被调用方法的示例:current_user.meals.for_date(6.days.ago)