3

当新项目添加到 Google 网站列表页面模板中的列表时,我需要一个通知事件。像 Page.listUpdated(e) 这样的东西会很棒,其中 e.Item 可以是新的 ListItem。

最初它是在新项目上启用条件格式,但我可以想到更多用途。

任何人都可以为此提出解决方法吗?

4

1 回答 1

0

我有一个在电子表格中运行的脚本,我用它来跟踪日历中的变化,并且我稍微修改了一下以检查 SitePage 列表......它需要一些“美容增强”,但它可以工作。例如,您可以设置一个时间触发器,让它每 30 分钟运行一次,如果您选择的任何页面发生任何更改,它都会向您发送一封邮件。

您唯一需要做的就是在“主表”上添加您要检查的页面的 url,并在尝试之前运行一次“init”函数。记录器表也将跟踪更改。

测试表可在此处获得(请复制运行它),脚本如下所示(将其视为“正在进行的工作”):

  var email = 'test@gmail.com';
  var ss = SpreadsheetApp.getActiveSpreadsheet();// this spreadsheet
  var sh = ss.getSheetByName('master');
  var pageList = sh.getDataRange().getValues();
  var logsheet = ss.getSheetByName('logger');
  var last = logsheet.getLastRow();
  var FUS1=new Date().toString().substr(25,6)+":00";

function onOpen() {
  var menuEntries = [ {name: "initialize", functionName: "init"},
                      {name: "Lauch autoTest", functionName: "autoCheckAllPages"},
                     ];
    var sheet = SpreadsheetApp.getActiveSpreadsheet();
    sheet.addMenu("Tracking utilities",menuEntries);//
    SpreadsheetApp.setActiveSheet(sheet.getSheetByName('logger'));// start on logger page  
}

function init(){
   ScriptProperties.setProperties({'lastTest': 'empty'}, true); 
}


function autoCheckAllPages(){
    var message = ScriptProperties.getProperty('lastTest')
    var newVal = ''
    ss.setActiveSheet(logsheet)
  for(nn=0;nn<pageList.length;++nn){
    var pageName = pageList[nn][0];
    var pageUrl = pageList[nn][1];   
    var items = SitesApp.getPageByUrl(pageUrl).getListItems()
      for (var i = 0; i < items.length; i++) {
        Logger.log(items[i].getDatePublished()+'    '+items[i].getValueByIndex(1))
        newVal+= pageName+','+items[i].getDatePublished()+','+items[i].getValueByIndex(1)+'|'
        }
      }
    ScriptProperties.setProperties({'lastTest': newVal}, true);    // write to script properties       
    logsheet.insertRowAfter(last)
    logsheet.getRange(last+1,1).setValue('Autotest on '+ Utilities.formatDate(new Date(),FUS1,"MMM-dd-yy @ hh:mm"))
      if(message != newVal){
        var addedItem = sendMail_(message,newVal)
        logsheet.getRange(last+1,2).setValue('new list Item : '+addedItem)
        }
}


function sendMail_(message,newVal){
  Logger.log('send mail')
  var newItem=''
  var old=message
  var newI = newVal.split('|');
  for(n=0;n<newI.length;++n){
    if(message.match(newI[n])!=newI[n]){ newItem += newI[n] + '|'
    }
}
//MailApp.sendEmail(email,'new listItem Added',newItem);// this should be developped with HTML body to show date in a table for example...
return newItem
}
于 2013-01-20T09:57:59.850 回答