hira
1
現在、Javascriptを用いてKintoneのカスタマイズを検討しております。
カスタマイズ初心者のためエラーの原因と解消方法が分からず困っています。
実行条件は以下です。
契約状況フィールドが「継続」で、契約期限が「今日」より過去の場合、
契約期限に、自動更新年(n年)を足した日付を契約更新日フィールドに自動で計算し出力する
例)フィールド名:値
契約状況:継続(ドロップダウン)
契約期限:2023/7/10(日付)
更新年度:2(年:数値)
→契約更新日:2025/7/10(日付)
★window.alert(‘契約更新しました’);にブレイクポイントを設定し処理実行したところ、
日付の更新処理は反映しているが、Kintone画面上では反映されていない状況です。
エラーは発生しておりませんが、処理が反映されていない場合、どのような問題が考えられますでしょうか。
-------------------------------------------
(() => {
‘use strict’;
kintone.events.on(‘app.record.edit.show’, (event) => {
// メニューの上側の空白部分にボタンを設置
const myIndexButton = document.createElement(‘button’);
myIndexButton.id = ‘my_index_button’;
myIndexButton.innerText = ‘最新契約更新日の更新’;
myIndexButton.onclick = () => {
window.alert('契約更新しますか?');
const situation = event.record.状態.value;
const today = dayjs();
const checkDay = dayjs(event.record.契約期限.value);
const checkValue = event.record.更新年度.value;
const addedDate = checkDay.add(checkValue,‘year’)
//もし「状況」が「継続」かつ最新契約更新日が「今日以前」だったら処理実行する
if (situation === ‘継続’ && checkDay < today){
event.record.契約更新日.value = addedDate;
★ window.alert(‘契約更新しました’);
}
return event;
};
kintone.app.record.getSpaceElement(‘my_space_field’).appendChild(myIndexButton);
})();
myIndexButton.onclick = () => {
// 略
ボタンのクリックイベントでレコードの中身を書き換える場合、レコードの値を取得するとレコードに値をセットするが必要です。
event.recordの変更で値を変えられるのはあくまでイベントが発生した時(今回の場合だとedit.show=編集開始時)で、edit.showで実行しているのはボタンの設置処理だけ、実際にボタンをクリックした時はタイミングが違うから変えられない、と覚えると良いと思います。
「いいね!」 1
hira
3
ご回答ありがとうございます。
ボタンの設置処理とクリックしたときでタイミングが違う、という点
非常に勉強になりました!
以下に修正したところ正常に動作しました。
ありがとうございました。
---------------------------------------------------------------------------------------
(() => {
'use strict';
kintone.events.on('app.record.edit.show', (event) => {
// メニューの上側の空白部分にボタンを設置
const myIndexButton = document.createElement('button');
myIndexButton.id = 'my_index_button';
myIndexButton.innerText = '最新契約更新日の更新';
myIndexButton.onclick = () => {
window.alert('契約更新しますか?');
const current = kintone.app.record.get();
const situation = current.record.状態.value;
const today = dayjs();
const checkDay = dayjs(current.record.契約期限.value);
const checkValue = current.record.更新年度.value;
const addedDate = checkDay.add(checkValue,'year');//.format('YYYY-MM-DD');
//もし「状況」が「継続」かつ最新契約更新日が「今日以前」だったら処理実行する
if (situation === '継続' && checkDay < today){
current.record.契約更新日.value = addedDate.format('YYYY-MM-DD');
kintone.app.record.set(current);
window.alert('契約更新しました');
}
return event;
};
kintone.app.record.getSpaceElement('my_space_field').appendChild(myIndexButton);
});
})();
「いいね!」 1
system
(system)
クローズされました:
4
このトピックはベストアンサーに選ばれた返信から 3 日が経過したので自動的にクローズされました。新たに返信することはできません。