Google App Script не срабатывает каждый раз, когда используется триггер onedit - PullRequest
0 голосов
/ 04 июля 2018

Скрипт Google App не запускает все всплывающие окна JavaScript, используя триггер редактирования. Не срабатывает при внесении изменений в лист для нескольких пользователей. Также работает только тогда, когда это нравится. Я установил триггер на OnEdit (). Мой код:

function Error() {
  
  var sheet = SpreadsheetApp.getActiveSheet();
  
  if (sheet.getName() == "Protocal  Check List 2"){
  var ui = SpreadsheetApp.getUi(); // Same variations.
  var ss = SpreadsheetApp.getActiveSpreadsheet();
  var active = ss.getActiveCell();
  var getactive = ss.getActiveCell().getDisplayValue();
  var column = ss.getActiveRange().getColumn();
  var row = ss.getActiveRange().getRow();
  var msg = '';
  var section = sheet.getRange('C'+ row);
    
  switch (column) {
    case 9:
        var msg = "error 1";
        break;
    case 10:
        var msg = "Error 2";
        break;
    default: 
        msg = "Error";
        break;
        }
   if(getactive == "TRUE"){
 
  if(column >= 9 && column <= 60
    ){ 
  var result = ui.alert(
      "pika  Says",
      msg,
      ui.ButtonSet.YES_NO);

  // Process the user's response.
  if (result == ui.Button.YES) {
    // User clicked "Yes".
    window.alert('Task Complete: \n\n' + msg);
    active.setValue('True');
  } else {
    
      var i = 0;
      
      while (i < 1) {
      var result = ui.prompt(
      'Please detail cause of the problem:',
      ui.ButtonSet.OK);

      
      var text = result.getResponseText();
      
      var textcount = text.length;
      
      if(textcount > 0) {
      i++;
      }}
    
    var cell = "H" + row;
      
      var emailAddress = "email@gmail.com";
      var d = new Date();
      var n = d.toDateString();
      var t = d.toTimeString();
      var staffname = ss.getRange(cell).getValues();
      
      var message = "Date: " + n +"\n\nTime: " + t +"\n\nStaff: " + staffname + "\n\nError: " + msg + "\n\nProblem: " + text;
      var subject = msg;
      
      var thedate = n + " / " + t;
      
      ss.getRange('A1').setValue(thedate);
      ss.getRange('B1').setValue(staffname);
      ss.getRange('C1').setValue(msg);
      ss.getRange('D1').setValue(text);
     
      var s1 = ss.getRange('A1:D1'); //assign the range you want to copy

      var s1v = s1.getValues();
      
      var tss = SpreadsheetApp.openById('1mOzdRgKxiP5iB9j7PqUWKKo5oymWuAeQZ1jJ1s6qL9E'); //replace with destination ID

      var ts = tss.getSheetByName('AB Protocal'); //replace with destination Sheet tab name
      
      ts.getRange(ts.getLastRow()+1, 1, 1,4).setValues(s1v); //you will need to define the size of the copied data see getRange()
      
      MailApp.sendEmail(emailAddress, subject, message);
  
      // User clicked "No" or X in the title bar.
      //ui.alert("The following note has been sent to the Duty Manager: \n\n" + text);
      active.setValue('FALSE');
    
  }}}}
  
}

Любая помощь будет оценена. Мне нужно, чтобы он запускался каждый раз для пользователей, имеющих доступ к листу.

1 Ответ

0 голосов
/ 05 июля 2018

Тебе придется Предположим, что триггеры onEdit являются лучшими, но могут не охватить все изменения, внесенные в электронную таблицу.

Ошибка темы здесь .

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...