残日数の自動更新について

お世話になっております。

タイトルの件について、日付フィールドから今日の日付との差分を計算して文字列に「○○日」と表示したいと考えております。

現在、追加、編集画面のchangeイベントでの計算表示は出来ていますが、これを自動で(※一覧画面を開いたタイミング等)で一括更新する方法はありますでしょうか。

現在のコード

(function() {
    'use strict';
    var events = [
        'app.record.create.show',
        'app.record.edit.show',
        'app.record.create.change.日付',
        'app.record.edit.change.日付'
    ];
    kintone.events.on(events, function(event) {
        var record = event.record;
        var date1 = new Date();
        var date2 = new Date(record['日付']['value']);
        var Diff = date2.getTime() - date1.getTime();
        var days = Math.floor(Diff / (1000 * 60 * 60 *24) + 1);
        record['残日']['disabled'] = true;
        record['残日']['value'] = days + '日';
        return event;
    });
})();

お手数でございますが、ご教授いただければ幸いでございます。

宜しくお願い致します。

Nao様

お世話になっております。

cstapの江田と申します。

以下のようなコードで実装できるかと思います。

(function() {
"use strict";
kintone.events.on('app.record.index.show', function(event){
var changed = false;
var getBody = {
"app": kintone.app.getId(),
};
kintone.api(kintone.api.url('/k/v1/records', true), 'GET', getBody, function(resp) {
var records = resp["records"];
var putBody = {
"app": kintone.app.getId(),
"records":[]
};
records.forEach(function(record){
var date1 = new Date();
var date2 = new Date(record.日付.value);
var Diff = date2.getTime() - date1.getTime();
var days = Math.floor(Diff / (1000 * 60 * 60 *24) + 1);
putBody.records.push({
"id": record.$id.value,
"record": {
"残り日数": {
"value":days
}
}
});
if(days != record.残り日数.value){
changed = true;
}
});
if(changed){
kintone.api(kintone.api.url('/k/v1/records', true), 'PUT', putBody, function(){
location.reload();
});
}
});
});
})();

江田篤史様

ご返信ありがとうございます。

ご教授いただいたコードで設定ができました。

ありがとうございます。

 

江田様

お世話になっています

この件に関して追加で確認したいことがあり問い合わせしてみます

まだ初心者なので、簡単なことかもしれませんがご容赦いただきたいです

日付フィールドAから今日の日付との差分を計算して残日数文字列フィールドAに表示

日付フィールドBから今日の日付との差分を計算して残日数文字列フィールドBに表示

日付フィールドCから今日の日付との差分を計算して残日数文字列フィールドCに表示

と複数ある場合、江田様のコードのどの部分にどう付け加えたらよいでしょうか?

一応フィールドコードを変えて同じようなコードを3つ作ると動きましたが、jsファイルが3つできてしまうためもっとすっきり一つにまとめたいと思います。よろしくご教授の程お願いいたします