ロジック: 今日のログ エントリが存在しない場合は、プレースホルダーの演習を表示します。今日のログ エントリが存在する場合は、存在してもプレースホルダーの演習を表示しません。
.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 をレンダリングするのはなぜですか? 気がおかしくなりそうだ。