一覧画面で年齢と勤続年数を計算したい

レコードの更新

経過年数を表示する

上記を参考に一覧画面で更新ボタンを押すと、今日現在の年齢と勤続年数を計算したくコードを組みましたが、更新ボタンを押した後、年齢と勤続年数が計算されずページ更新のみ行われる状態です。

開発者ツールのコンソールを確認してもエラーが表示されず、どこを修正すべきか困っています。

初心者で大変恐縮ではございますが、修正点をご教示いただけないでしょうか。

【フィールドについて】

・生年月日(日付)

・入社日(日付)

・年齢(文字列)

・勤続年数(文字列)

【コード】

(function() {
  "use strict";
  kintone.events.on('app.record.index.show', function(event){
    var button = document.createElement('button');
    button.innerText = 'update';
    kintone.app.getHeaderMenuSpaceElement().appendChild(button);
    button.addEventListener('click', function(){

//ここに更新処理をかく
    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 birthDayFieldCode = record['生年月日'].value;
  var joiningDayFieldCode = record['入社日'].value;
/**
     * 経過年月日を計算する
     * @param {string} dateStr 日付文字列
     * @returns {object} 計算結果のオブジェクト
     */
var calculateDuration = function(dateStr) {
      var currentDate = luxon.DateTime.local().startOf('day');
      var date = luxon.DateTime.fromISO(dateStr).startOf('day');
      // 経過期間を計算する
      var duration = currentDate.diff(date, ['years', 'months', 'days']);
      return duration.toObject();
    };

// 年齢を計算する
    var birthDayValue = record['生年月日'].value;
    var birthDayDuration = calculateDuration(birthDayValue);
    record['年齢'].value = (birthDayDuration.years + '歳' + birthDayDuration.months + 'ヶ月');

// 入社からの経過年月を計算する
    var joiningDayValue = record['入社日'].value;
    var joiningDayDuration = calculateDuration(joiningDayValue);
    record['勤続年数'].value = (joiningDayDuration.years + '年' + joiningDayDuration.months + 'ヶ月');

// リクエストパラメータ作成
            var putBody = ({
              "id": record.$id.value,
              "records": {
                "勤続年数": {
                "value": record.勤続年数.value
},
                  "年齢": {
                  "value": record.年齢.value
                  },
                }
            });
            });

kintone.api(kintone.api.url('/k/v1/records', true), 'PUT', putBody, function(resp){
         // success
        alert("更新成功");
        location.reload(); // 成功したら画面を更新
        }, function(resp) {
        // error
         alert("更新失敗");
          });  
          });
});
  });
})();

見た限り、13行目で宣言されたputBodyの配列が空になっているのと、45行目で恐らく配列内のパラメータにしたかったリクエストボディがputBodyとして再宣言されています。

// リクエストパラメータ作成
              var putBody = ({
                "id": record.$id.value,
              "records": {
                  "勤続年数": {
                  "value": record.勤続年数.value
                 },
                    "年齢": {
                    "value": record.年齢.value
                    },
                  }
              });

これを

// リクエストパラメータ作成
            putBody.records.push({
                "id": record.$id.value,
              "record": {
                  "勤続年数": {
                  "value": record.勤続年数.value
                 },
                    "年齢": {
                    "value": record.年齢.value
                    },
                  }
              });

こちらに変更すれば良いかと思います。

mls-hashimotoさま

無事意図した動きができました!

いろんな方の投稿を拝見して頭が混乱していたので大変助かりました。

再宣言しても大丈夫だと思っていたのでまだまだ勉強不足ですね。

この度は本当にありがとうございました。

このトピックはベストアンサーに選ばれた返信から 3 日が経過したので自動的にクローズされました。新たに返信することはできません。