0

ロジック: 今日のログ エントリが存在しない場合は、プレースホルダーの演習を表示します。今日のログ エントリが存在する場合は、存在してもプレースホルダーの演習を表示しません。

      .log-entries
        - unless exercise.log_entries.for_user(workout.user).blank? || exercise.last_log_date(workout.user) == Time.zone.today.beginning_of_day
          %p Nice job performing this #{timeago exercise.last_log_date(workout.user)}. Try going up in difficulty this time.
          = exercise.last_log_date(workout.user).to_date
          = exercise.last_log_entry(workout.user).created_at.to_date
          %br
          = Time.current.to_date
          %br
          - for log_entry in exercise.placeholder_log_entries!(workout.user)
            = render 'log_entries/form', log_entry: log_entry, exercise: exercise
        - for log_entry in exercise.log_entries.for_today.order("created_at ASC").for_user(workout.user) do
          = render 'log_entries/form', log_entry: log_entry, exercise: exercise
        - if exercise.log_entries.blank?
          %p.hint.not-performed-yet You haven't performed this exercise yet.

      = link_to exercise.render_add_text, user_workout_exercise_log_entries_path(workout, workout.user, exercise), class: "button radius", remote: true, method: :post

私を悩ませているのは...今日のログエントリを記録したにもかかわらず、プレースホルダーの演習がまだ表示されていることです. それで、最初unlessは合格です。

デバッグすると、次のような値が得られます。

exercise last log date: 2013-08-26 00:00:00 -0700 
today: 2013-08-27 00:00:00 -0700 

しかし、そのエクサの最終ログ日付は、実際には今日、まさに今記録されています! なんで1日遅れなの?

 #<LogEntry id: 226, reps: 8, weight: 55, effort: nil, description: nil, loggable_id: 3, loggable_type: "Exercise", created_at: "2013-08-27 06:00:12", updated_at: "2013-08-28 03:06:56", user_id: 1, rest_after_set: nil, difficulty: nil, distance: nil, duration: nil, measurement: nil, placeholder: false> 

2013-08-27 に作成されました!!! ビューで 26 をレンダリングするのはなぜですか? 気がおかしくなりそうだ。

4

1 に答える 1