yunyun_engineer
@yunyun_engineer (yunyun)

Are you sure you want to delete the question?

Leaving a resolved question undeleted may help others!

現在の日付と連動して賞味期限の残り日数を1日ずつ減らしいく表示をさせたいです

解決したいこと

プログラミング初学者です。Ruby on Railsで賞味期限の残り日数を現在の日付に連動する1日ずつ減っていく表示にさせるアプリを作りたいです。
1日経つと残り●日が1日ずつ減るイメージです。時間までは表示せず日付だけを考えてます。現在、残り日数は購入日と賞味期限の差分です。
賞味期限から現在の日付の差分を1ずつ減らすイメージでしょうか?
railsでの一からの作り直しも検討してます。

8c8423496c0ad34b099b0858500e02ee.png

該当するソースコード

window.addEventListener('load', () => {
  const arrjsonInput = document.getElementById("arr_json");
  for (let i = 0; i < arrjsonInput.value ; i++) {
    const purchaseInput = document.getElementById("purchase-date"+i);
    const expirationInput = document.getElementById("expiration-date"+i);
    const purchaseDate = new Date(purchaseInput.innerHTML);
    const expirationDate = new Date(expirationInput.innerHTML);
    const daysLeft = document.getElementById("days-left"+i);
    daysLeft.innerHTML = (Math.floor( (expirationDate.getTime() - purchaseDate.getTime()) / ( 1000 * 60 * 60 * 24 )));
  }  
});
<main class="main">
  <div class="inner">
    <div class="card__wrapper">
    <input id="arr_json" type="hidden" value="<%= @items.length %>" class='arr_json'/>
      <% @items.each_with_index do |item, i| %>
        <div class="content">
          <div class="image-content">
            <%= link_to image_tag(item.image.variant(resize: '200x200'), class: :card__img ), item_path(item) %>
          </div>  
          <div class="sub-content">
            <span>購入日</span>
            <div id="purchase-date<%=i %>"> <%= item.purchase_date %></div>

          </div>
          <div class="sub-content">
            <span>賞味期限</span>
            <div id="expiration-date<%=i %>"><%= item.expiration_date %></div>
          </div>
          <div class="daysleft-content">
              <span>残り<span id="days-left<%=i %>"></span>日</span>
          </div>
          <div class="nickname-content">
          <%= link_to "by #{item.user.nickname}", root_path, class: :card__user %>
          </div>
        </div>
      <% end %>
    </div>
  </div>
</main>

自分で試したこと

どのような解決法があるか検討もつきません。
railsだとdowntoとDateクラスを組み合わせるのでしょうか?
なにかヒントになるような事があれば宜しくおねがいします!

0

2Answer

RailsのDateクラスならこれで日付の差分は取れると思います。

exp = 3.days.from_now.to_date # 賞味期限の日に変える item.expiration_date かな?
today = Date.today

(exp - today).to_i
1Like

Comments

  1. 回答ありがとうございました
    比較するのは現在と賞味期限ですね
    根本的な間違いをしていました。
    ありがとうございます!勉強になります

ページを表示している間リアルタイムにカウントが減っていくようにするなら JavaScript で書く必要があります。ページを読み込んだ時点のカウントでいいなら Rails で書いた方が簡単だと思います。


Ruby では日時オブジェクト同士を引き算すると差の日数が分数で得られます。

current_date = DateTime.new(2021, 4, 28, 9) # 2021年4月28日9時
expiration_date = DateTime.new(2021, 4, 30, 12) # 2021年4月30日12時
p expiration_date - current_date # => (17/8)

時分秒の差を無視するために日時オブジェクトの beginning_of_day メソッドで時間を午前0時に合わせ、差を整数に変換すると残り日数が得られます。

p expiration_date.beginning_of_day - current_date.beginning_of_day # => (2/1)
p (expiration_date.beginning_of_day - current_date.beginning_of_day).to_i # => 2

それをビューに書けば残り日数を表示できます。

<div class="daysleft-content">
  <span>残り<span id="days-left<%=i %>"><%= (item.expiration_date.beginning_of_day - DateTime.current.beginning_of_day).to_i  %></span></span>
</div>
0Like

Comments

  1. 回答ありがとうございました
    比較するのは現在と賞味期限ですね
    根本的な間違いをしていました。
    ありがとうございます!勉強になります

Your answer might help someone💌