アプリのテーブルから他のアプリのテーブルにデータを移したい

【実現したいこと】

アプリ(案件管理)でレコード更新時、記入されているテーブルの一部のデータを他のアプリ(請求書管理)にコピーしたいと思っております。

その際、請求書管理アプリ内で[請求月]・[取引先コード]を条件に、既に同条件のレコードがあれば、レコードのテーブルを追加してコピー、なければレコード作成しテーブルにコピーできればと考えております。

案件管理のテーブルから請求書管理のテーブルにコピーするデータは[明細行ID]・[行の種類]・[請求明細名]・[数量]・[単位]・[単価]・[金額]の7つです。

【問題点】

①下記コードで実行したところ、既存レコードにおいてはクエリでの検索は問題なく出来ておりましたが、テーブルを追加してコピーはできませんでした。

②下記コードだと新しくレコード作るものははいっていないためどうのように記述すればよろしいでしょうか。

コミュニティ内で参考にできそうなコードをもとに作成してみました。しかし、エラーはでておりませんが、うまくテーブルの値が反映されませんでした。初心者で無知なためご教授いただければ幸いです。

 

  kintone.events.on([“app.record.create.submit”, “app.record.edit.submit”],
  async function(event) {
        const record = event.record;
        const seitable =record.請求書.value;
        const torihikicode = record.取引先コード.value;
        const month = record.請求月.value;

        for (var o = 0; o < seitable.length; o++) {
          
                const mei = seitable[o].value[“明細行ID”].value
                const gyou = seitable[o].value[“行の種類”].value
                const sei = seitable[o].value[“請求明細名”].value
                const suu = seitable[o].value[“数量”].value
                const tani = seitable[o].value[“単位”].value
                const tanka = seitable[o].value[“単価”].value
                const kingaku = seitable[o].value[“金額”].value

 &nbsp; &nbsp; &nbsp; &nbsp;const paramForGetStock1 = {'app': 603,  

       ‘query’: ‘請求月 in ("’ + month + ‘") and 取引先コード= "’ +torihikicode+ ‘"’,}

       const resp = await kintone.api(kintone.api.url(‘/k/v1/records’,true),‘GET’, paramForGetStock1);
                    console.log(resp);
                    if(!resp.records.length) return;

                    resp.records.forEach(async function(record) {
                    const seikyuTable = record[“請求明細行”].value;
        
                    let seikyuTable_ID = [];
                    for (var m = 0; m < seikyuTable.length; m++) {
                      seikyuTable_ID[m] = seikyuTable[m].value[“ID”]}
                    let appended_subtable = [];
                    let subtable = [];
                  
                      if (!seikyuTable_ID.includes(mei)) {
                        for (let m = 0; m < seikyuTable.length; m++) {
                          subtable.push(seikyuTable[m]);
                        }

                    subtable.push({
                            value: {
                            “明細行ID”: {“value”:mei},
                            “行の種類”:{“value”:gyou},
                            “請求明細名”:{“value”:sei},
                            “数量”:{“value”:suu},
                            “単位”:{“value”:tani},
                            “単価”:{“value”:tanka},
                            “金額”: {“value”:kingaku}
                          }});

              const paramForPut1 = {
                    “app”: 603,
                    “id”: resp.records[0].$id.value,
                    “record”: {
                      “明細行ID”: {“value”:mei},
                      “行の種類”:{“value”:gyou},
                      “請求明細名”:{“value”:sei},
                      “数量”:{“value”:suu},
                      “単位”:{“value”:tani},
                      “単価”:{“value”:tanka},
                      “金額”: {“value”:kingaku}
                    }
}

                  console.log(paramForPut1);

                  appended_subtable.push(paramForPut1);
                  subtable = subtable.concat(appended_subtable); 
                  var put_record = {};
                  put_record[“請求明細行”] = {
                  value: subtable
                  }
                  const put_resp = await kintone.api(kintone.api.url(“/k/v1/record.json”, true), “PUT”, paramForPut1);
                    console.log(put_resp);

                 }else {}

            window.alert(“請求書管理に反映しました。”);
            return event;
          })}})

 

 

動作確認等はしておりませんが、おそらく以下のような形で可能かと思います。
PUTで更新するサブテーブルについても行を更新するのか追加するのかの判定が必要なので「明細行ID」が一致する行は更新、一致しない行は追加するようにしています。

(() => {
  'use strict';

  kintone.events.on([
  'app.record.create.submit', 'app.record.edit.submit'
], async (event) => {
  let record= event.record;
  let copyFields = ['明細行ID', '行の種類', '請求明細名', '数量', '単位', '単価', '金額'];
  let subTableValue = [];

    record['請求書'].value.forEach((row) => {
    let subTableRow = {value: {}};

    copyFields.forEach((field) => {
      subTableRow.value[field] = {
        value: row.value[field].value
      };
    });

      subTableValue.push(subTableRow);
  });

    let paramForGetStock1 = {
    app: 603,
    query: `請求月 in ("${record['請求月'].value}") and 取引先コード = "${record['取引先コード'].value}"`
  };

    let resp = await kintone.api(kintone.api.url('/k/v1/records', true), 'GET', paramForGetStock1);

  if (resp.records.length) {
    subTableValue.forEach((row) => {
      let matchIndex = resp.records[0]['請求明細行'].value.findIndex((respRow) => respRow.value['明細行ID'].value === row.value['明細行ID'].value);

        if (matchIndex >= 0) {
        resp.records[0]['請求明細行'].value[matchIndex].value = row.value;
      } else {
        resp.records[0]['請求明細行'].value.push({
value: row.value
});
      }
    });

      let putRecord = {
      app: 603,
      id: resp.records[0]['$id'].value,
      record: {
        '請求明細行': {
          value: resp.records[0]['請求明細行'].value
        }
      }
    };

      await kintone.api(kintone.api.url('/k/v1/record', true), 'PUT', putRecord);
  } else {
    let postRecord = {
      app: 603,
      record: {
        '請求明細行': {
          value: subTableValue
        }
      }
    };

      await kintone.api(kintone.api.url('/k/v1/record', true), 'POST', postRecord);
  }

    return event;
});
})();

mls-hashimoto様

コードのお手本、まことにありがとうございます。

頂いたコードをもとにやってみます!

大変お手数ですが、わからないことがあれば再度ご質問させて頂ければと思います。

mls-hashimoto様

教えて頂いたコードを実行してみたのですが、画像のようなエラーが出てしまいます。

自力で原因を探してみたのですが、うまくできずご意見頂ければと思います。

izumi keisuke さま

クエリ文字列の「請求月 in (…)」 が「 請求月 = (…)」になっています。提示されたコードから請求書管理アプリの請求月フィールドはドロップダウン、チェックボックスまたはラジオボタンという認識でしたが、違っていたでしょうか?

フィールドごとに使用できる演算子に違いがあり、ドロップダウンやラジオボタンでは「in (…)」文字列フィールド等では「 = …(括弧は使用しない)」と使い分ける必要があるので「請求月 in (“8”)」か「請求月 = “8”」となるのが正しいクエリ文字列です。

このあたり で詳しく解説されています。

動作確認して不具合のあった部分を直しました。

(() => {
  'use strict';

kintone.events.on([
    'app.record.create.submit', 'app.record.edit.submit'
], async (event) => {
  let record = event.record;
    let copyFields = ['明細行ID', '行の種類', '請求明細名', '数量', '単位', '単価', '金額'];
  let subTableValue = [];

    record['請求書'].value.forEach((row) => {
    let subTableRow = {value: {}};

    copyFields.forEach((field) => {
      subTableRow.value[field] = {
        value: row.value[field].value
      };
    });

      subTableValue.push(subTableRow);
  });

    let paramForGetStock1 = {
    app: 603,
    query: `請求月 in ("${record['請求月'].value}") and 取引先コード = "${record['取引先コード'].value}"`
  };

    let resp = await kintone.api(kintone.api.url('/k/v1/records', true), 'GET', paramForGetStock1);

    if (resp.records.length) {
    subTableValue.forEach((row) => {
      let matchIndex = resp.records[0]['請求明細行'].value.findIndex((respRow) => respRow.value['明細行ID'].value === row.value['明細行ID'].value);

        if (matchIndex >= 0) {
        resp.records[0]['請求明細行'].value[matchIndex].value = row.value;
      } else {
        resp.records[0]['請求明細行'].value.push(row);
      }
    });

      let putRecord = {
      app: 603,
      id: resp.records[0]['$id'].value,
      record: {
        '請求明細行': {
          value: resp.records[0]['請求明細行'].value
        }
      }
    };

      await kintone.api(kintone.api.url('/k/v1/record', true), 'PUT', putRecord);
  } else {
    let postRecord = {
      app: 603,
        record: {
        '請求月': {
          value: record['請求月'].value
        },
        '取引先コード': {
          value: record['取引先コード'].value
        },
        '請求明細行': {
          value: subTableValue
        }/* 他に初期登録しておきたいフィールドがあれば追加 */
      }
      };

      await kintone.api(kintone.api.url('/k/v1/record', true), 'POST', postRecord);
  }

    return event;
});
})();

mls-hashimoto様

ご指摘いただきありがとうございます。

教えて頂いたコードで無事実装でき動作確認できました。

誠にありがとうございます。

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