一覧画面でブルダウンで選択した条件で背景色を変更する

一覧画面でブルダウンで選択した条件で背景色を変更するプログラムを作りましたが、うまく動作しません

プルダウンの入力は複数あり、一覧上でAという文字を入力すると背景色がかわり、他のプルダウンでもAを入力すると同じ背景色になり、ガントチャートのようにしていきたいと考えています。
プルダウンの入力候補はいまのところ2つで、今後状況よっては候補が増えたり、内容が変わる可能性があります。

他のトピックなどを参考にしてみましたが、なかなかうまくいかず相談させていただきました

入力方法はプルダウンで行っています。
入力されているマス(セル)の要素の判別などが分からず相談した次第です

Chromeでエラーは表示されていませんが、判定がうまくできていないように思えます

以下のトピックを参考にしましたが、うまくいきませんでした。
色々修正を繰り返して、以下のプログラムを掲載しました。

(function() {
“use strict”;

kintone.events.on(‘app.record.index.show’, function(event) {
// 特定の文字列
var targetString = ‘判定する文字列’;
console.log(“targetString =”,targetString);

// 特定の文字列の要素を指定
var line = document.getElementsByClassName(“recordlist-cell-gaia”);

// 一覧の表示されているセルを取得
var records = event.records;
console.log(“records =”,records);

// セルの数だけループ
for (var i = 0; i < records.length; i++) {
var record = records[i];
console.log(“record =”,record);

// レコードのフィールドを取得
var fields = Object.keys(record);
console.log("fields =",fields);

// フィールドの数だけループ
for (var j = 0; j < fields.length; j++) {
  var field = fields[j];
  console.log("field =",field);

  // フィールドの値が特定の文字列と一致する場合、セルの背景色を変更
  if(records[i].value === targetString){
    line[i].style.backgroundColor = "#0000ff";	// 背景色
  }
}

}
});
})();

このif文の中に入ってきているかconsole.logを設置してみるとかいかがでしょうか:eyes:??

入れてみましたが、初めの判定する文字列のみコンソールで表示できました。
if文の中のものは表示されていないので、if文の中に入っていないかもしれません。

他にプログラムの内容はありますでしょうか。

1 Like

以下のプログラムで完成できました。
現状特定の一覧で動作する仕様ですので、一覧によってはデベロッパーツールでエラーが表示されますが、問題ないとしました。

(function() {
“use strict”;

kintone.events.on('app.record.index.show', function(event) {
    // 文字列と対応する背景色と文字色のリスト
    var textStyles = {
        '文字列1': { backgroundColor: 'yellow', textColor: 'red' },
        '文字列2': { backgroundColor: 'lightblue', textColor: 'darkgreen' },
        '文字列3': { backgroundColor: 'pink', textColor: 'purple' }
    };

    // 一覧の各行を取得
    var records = event.records;
    console.log("records =",records);

    // 各行に対して処理を実行
    for (var i = 0; i < records.length; i++) {
        var record = records[i];
        var recordFields = Object.keys(record);
        console.log("record =",records);
        console.log("recordFields =",recordFields);

        // 各フィールドに対して処理を実行
        recordFields.forEach(function(fieldCode) {
            // フィールドが存在し、値が文字列であるか確認
            if (record[fieldCode] && typeof record[fieldCode].value === 'string') {
                // 特定のフィールドの値を取得
                var fieldValue = record[fieldCode].value;
                console.log("fieldValue =",fieldValue);

                // 対応するスタイルが存在する場合は背景色と文字色を変更
                if (textStyles[fieldValue]) {
                    var style = textStyles[fieldValue];
                    console.log("style =",style);

                    // 背景色を変更するためのCSSスタイル
                    var customBackgroundColor = 'background-color: ' + style.backgroundColor + ';';
                    console.log("customBackgroundColor =",customBackgroundColor);

                    // 文字色を変更するためのCSSスタイル
                    var customTextColor = 'color: ' + style.textColor + ';';
                    console.log("customTextColor =",customTextColor);

                    // 背景色と文字色を変更したいセルにスタイルを適用
                    var cellElement = kintone.app.getFieldElements(fieldCode)[i];
                    console.log("cellElement =",cellElement);
                    cellElement.style = customBackgroundColor + customTextColor;
                }
            }
        });
    }

    return event;
});

})();

1 Like

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