Не удается удалить событие в моем календаре Google с помощью сценариев

Я сделал электронную таблицу, в которой я могу легко управлять своими событиями в календаре Google. В электронной таблице строка 1 содержит даты, строка 2 содержит специфику встречи, а строка 3 сохраняет идентификатор события для события, созданного сценарием. Каждая неделя начинается с нового ряда.

Скрипт работает так, как должен, и выглядит так:

function CalenderUpdate() {

  var calId = "xxxxxxxxxxxxxxxx@group.calendar.google.com";
  var descr = "";
  var date
  var titel
  var sheet = SpreadsheetApp.getActiveSheet();
  var Afspraak = sheet.getRange(2,1,3,5).getValues();
  var cal = CalendarApp.getCalendarById(calId);

  for (j=2;j<9;j=j+3){
    Afspraak = sheet.getRange(j,1,3,5).getValues();

    for (i=0; i<5; i++){
      descr ="";
      date = Afspraak[0][i];
      titel = Afspraak[1][i];

      if (titel == "A"){ descr = "Late 14:00 - 21:00";}
      if (titel == "M"){ descr = "Early 6:00 - 14:00";}
      if (Afspraak[1][i] != ""){
        var event = cal.createAllDayEvent(titel,date,{description:descr});
        sheet.getRange(j+2,i+1).setValue(event.getId());
      }
    }
  }
}

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

function onEdit(e){
  var ss = SpreadsheetApp.getActiveSheet();
  var range = e.range;
  var rij = range.getRow();
  var col = range.getColumn();
  var afspraakId = ss.getRange(rij+1,col).getValue();

  if (rij % 3 == 0) { ss.getRange(1,1).setValue(afspraakId); }

  var calId = "xxxxxxxxxxxxxxx@group.calendar.google.com";
  var cal = CalendarApp.getCalendarById(calId);
  var event = cal.getEventSeriesById(id);
  event.deleteEventSeries();

}

Надеюсь, кто-нибудь может мне помочь?

РЕДАКТИРОВАТЬ:

Я изменил onEdit (e) на onEditInstallable (e), но скрипт никогда не запускался.
Даже если я добавлю триггер по меню

Что я делаю не так?

EDIT2:

Я сделал некоторые изменения в моем сценарии. Это конечный результат:

function test_onEdit() {
  onEditInstallable({
    user : Session.getActiveUser().getEmail(),
    source : SpreadsheetApp.getActiveSpreadsheet(),
    range : SpreadsheetApp.getActiveSpreadsheet().getActiveCell(),
    value : SpreadsheetApp.getActiveSpreadsheet().getActiveCell().getValue(),
    authMode : "LIMITED"
  });
}

function onEditInstallable(e){ 
  var ss = SpreadsheetApp.getActiveSheet();
  var range = e.range;
  var rij = range.getRow();
  var col = range.getColumn();

  if (rij % 3 == 0 && col < 8) {

    var cal = CalendarApp.getCalendarById("xxxxxxxxxxxxxxxxxx@group.calendar.google.com");

    var event
    var geg = ["","",""];
    var descr ="";


    for (i = 0 ; i < 3 ; i++){ geg[i] = ss.getRange(rij-1+i,col).getValue();}

    if (geg[2] != ""){
      event = cal.getEventSeriesById(geg[2]);
      event.deleteEventSeries();
      ss.getRange(rij+1,col).setValue("");
    }

    if (geg[1] != ""){
      event = cal.createAllDayEvent(geg[1],geg[0],{description:descr});
      ss.getRange(rij+1,col).setValue(event.getId());
    }
  } 
}

Скрипт работает, если я запускаю test_OnEdit. Но onEditInstallable не вызывает автоматический? Я любитель программирования и не очень разбираюсь в этой странице. Надеюсь, кто-то может помочь мне разобраться в этом.

2 ответа

Решение

Я использовал этот последний кусок кода и связал скрипт test_onEdit с кнопкой в ​​электронной таблице. При первом тестировании оттуда Google выдал всплывающее окно с просьбой о дополнительных авторизациях. С тех пор все работает как шарм.

Теперь моя таблица автоматически редактирует мою повестку дня, если я что-то изменю в таблице.

Спасибо всем за помощь.

function test_onEdit() {
      onEditInstallable({
        user : Session.getActiveUser().getEmail(),
        source : SpreadsheetApp.getActiveSpreadsheet(),
        range : SpreadsheetApp.getActiveSpreadsheet().getActiveCell(),
        value : SpreadsheetApp.getActiveSpreadsheet().getActiveCell().getValue(),
        authMode : "LIMITED"
      });
    }
    function onEditInstallable(e){ 
      var ss = SpreadsheetApp.getActiveSheet();
      var range = e.range;
      var rij = range.getRow();
      var col = range.getColumn();
      Logger.log('rij = '+rij+'  col = '+col);
      if (rij % 3 == 0 && col < 8) {

        var cal = CalendarApp.getCalendarById("xxxxxxxxxxxxxxxxxx@group.calendar.google.com");

        var event
        var geg = ["","",""];
        var descr ="";


        for (i = 0 ; i < 3 ; i++){ geg[i] = ss.getRange(rij-1+i,col).getValue();}
        Logger.log('geg[2] = '+geg[2]);
        if (geg[2] != ""){
          event = cal.getEventSeriesById(geg[2]);
          event.deleteEventSeries();
          ss.getRange(rij+1,col).setValue("");
        }

        if (geg[1] != ""){
          event = cal.createAllDayEvent(geg[1],geg[0],{description:descr});
          ss.getRange(rij+1,col).setValue(event.getId());
        }
      } 
    }

Попробуй это:

function deleteEvent(event) {
  if (typeof event != 'undefined') {
    Logger.log("Deleting event %s", event.getTitle())
     event.deleteEvent()
  }
}

function deleteEvents(eventCal,startTime,endTime,title){
    //  var oldEvents = eventCal.getEvents(startTime, endTime, {search: title});  
      var oldEvents = eventCal.getEvents(startTime, endTime);
      Logger.log("oldEvents %s", oldEvents);
      for (var j = 0; j < oldEvents.length; j++){  
         Logger.log("oldEvents[j] %s", oldEvents[j]);
         deleteEvent(oldEvents[j]);
      }
  }

Ваше второе редактирование является хорошим подходом, я бы предложил добавить пару журналов в скрипт, чтобы проверить значения условий.

Я предпочел бы использовать комментарии для этого, но это определенно было бы слишком длинным и трудным для чтения, поэтому я использую формат "ответа".

function onEditInstallable(e){ 
  var ss = SpreadsheetApp.getActiveSheet();
  var range = e.range;
  var rij = range.getRow();
  var col = range.getColumn();
  Logger.log('rij = '+rij+'  col = '+col);
  if (rij % 3 == 0 && col < 8) {

    var cal = CalendarApp.getCalendarById("xxxxxxxxxxxxxxxxxx@group.calendar.google.com");

    var event
    var geg = ["","",""];
    var descr ="";


    for (i = 0 ; i < 3 ; i++){ geg[i] = ss.getRange(rij-1+i,col).getValue();}
    Logger.log('geg[2] = '+geg[2]);
    if (geg[2] != ""){
      event = cal.getEventSeriesById(geg[2]);
      event.deleteEventSeries();
      ss.getRange(rij+1,col).setValue("");
    }

    if (geg[1] != ""){
      event = cal.createAllDayEvent(geg[1],geg[0],{description:descr});
      ss.getRange(rij+1,col).setValue(event.getId());
    }
  } 
}