前提・実現したいこと
Googleフォームで申し込みフォームを作成しており、各時間帯満員になったら選択肢から除外する
ということをしたいです。
発生している問題・エラーメッセージ
定員を1名に設定し、申し込みを入れてみましたが、選択肢から除外されません。
該当のソースコード
function endFormCheck() { var LIMIT_COUNT = 1; //ここで席数上限を設定 var ANSWER_LENGTH = 3; //時間帯の数 var answerCount = [0,0,0];//カウント用:時間帯の数分配列を準備します var itemID = 0; var form = FormApp.getActiveForm(); //アクティブフォームを取得 var formResponses = form.getResponses(); // 全回答内容を取得 for (var i = 0; i < formResponses.length; i++) { var formResponse = formResponses[i]; // 回答ひとつ分を取得 var itemResponses = formResponse.getItemResponses(); // 質問項目を取得 for (var j = 0; j < itemResponses.length; j++) { // 回答内容をひとつずつチェック var itemResponse = itemResponses[j]; var question = itemResponse.getItem().getTitle(); var answer = itemResponse.getResponse(); if(question == '時間帯を選択してください。'){ // 申込み数カウント if(answer == '10:10~10:50'){ answerCount[0]++; } else if( answer == '11:20~12:00'){ answerCount[1]++; } else if( answer == '13:30~14:10'){ answerCount[2]++; } } } } // LIMIT_COUNTになっている選択肢があるかチェック var answerCheck = 0; var choiceArray = []; var arrayCount = 0; for(var i = 0; i < ANSWER_LENGTH; i++){ if(answerCount[i] == LIMIT_COUNT){ answerCheck++; } else{ // LIMIT_COUNTになっていない選択肢は残す if ( i == 0 ){ choiceArray[arrayCount] = '10:10~10:50'; arrayCount++; } else if( i== 1 ){choiceArray[arrayCount] = '11:20~12:00'; arrayCount++;} else if( i== 2 ){choiceArray[arrayCount] = '13:30~14:10'; arrayCount++;} } } // 全てLIMIT_COUNTなら申込みフォームを受付終了 if(answerCheck == ANSWER_LENGTH){ form.setAcceptingResponses(false); } // LIMIT_COUNTになっていない選択肢を「参加する時間」の選択肢に設定する if( (answerCheck != ANSWER_LENGTH) && (answerCheck >= 1)){ var items = form.getItems(); for (var i= 0; i< items.length; i++ ){ var item = items[i]; if( item.getTitle() == '時間帯を選択してください。' ){ var choice = item.asMultipleChoiceItem().getChoices(); item.asMultipleChoiceItem().setChoiceValues(choiceArray); } } } }
試したこと
ネットで同じようなプログラムをコピーして組み替えたり、選択肢をプルダウンにしたりラジオボタンにしたりしました。
補足情報(FW/ツールのバージョンなど)
ここにより詳細な情報を記載してください。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。