Намерете и прочетете календари с ресурси в Административната директория

Контекст
По време на формуляр POST за резервация на хотел, първо искам да проверя дали имаме свободни стаи в нашите апартаменти. Създадох календари с ресурси (със сгради и т.н.) чрез административния панел на GSuite.

Сега тествам малко с някакъв код, който намерих на този сайт. Той намира календарите на ресурсите и аз просто ги филтрирам по име (за да се отърва от всички зали за срещи). Но сега бих искал да "прочета" самия календар. Но изглежда resourceId не е идентификаторът на съответния ресурсен календар.

Как мога да проверя наличността в календара на ресурсите?

do {
  var arguments = {
    maxResults: 200,
    pageToken: pageToken
  }; 
  calendars = AdminDirectory.Resources.Calendars.list("my_customer", arguments);
  if (calendars.items && calendars.items.length > 0) {
    for (var i = 0; i < calendars.items.length; i++) {
      var calendar = calendars.items[i];
      if (calendar.buildingId.substr(0, 9).toUpperCase() === "APARTMENT" ) {
        Logger.log('YES %s (ID: %s) (%s),', calendar.resourceId, calendar.resourceName, calendar.buildingId);  

        // 
        // The code below doesn't work (null reference). But I would to do something like this.
        //
        var resourceCalendar = CalendarApp.getCalendarById(calendar.resourceId);
        Logger.log("I found the following calendar %s ", resourceCalendar.getName() );

      }
    }
  } else {
    Logger.log('No calendars found.');
  }
  pageToken2 = calendars.nextPageToken;
} while (pageToken); 

person Jeroen    schedule 22.08.2018    source източник
comment
Имахте предвид да настроите pageToken да бъде calendars.nextPageToken? или pageToken2, което иначе никога не се използва (в този код)?   -  person tehhowch    schedule 22.08.2018
comment
Мисля, че не трябва да смесвате API на Календар и функцията CalendarApp, те не използват една и съща ID структура. И също IMHO, че не ви трябва, тъй като API е способен на всичко.   -  person Serge insas    schedule 22.08.2018


Отговори (1)


Опитах този код и работи.

Обърнете внимание, че използвах имейл ресурс като ID за CalendarApp

function myFunction() {
  var pageToken;
  do {
    var arguments = {
      maxResults: 200,
      pageToken: pageToken
    }; 
    calendars = AdminDirectory.Resources.Calendars.list("my_customer", arguments);
    if (calendars.items && calendars.items.length > 0) {
      for (var i = 0; i < calendars.items.length; i++) {
        var calendar = calendars.items[i];
        Logger.log('ressource name : '+calendar.resourceName);  

        //Logger.log('ressource data : '+JSON.stringify(calendar)+'\n');// this is useful to see what we get  

        var resourceCalendar = CalendarApp.getCalendarById(calendar.resourceEmail);
        if(resourceCalendar){
          Logger.log("I found the following calendar %s \n", resourceCalendar.getName() );
        }else{
          Logger.log('ressource skipped- undefined ----------------');
        }
      }
    }
  } while (pageToken); 
}
person Serge insas    schedule 22.08.2018
comment
Благодаря. Това проработи. Добър съвет. И намерих друга причина. Ресурсите бяха нови и все още няма създадени събития. След като създадох събитие, resourceCalendar беше върнат. - person Jeroen; 22.08.2018