当新项目添加到 Google 网站列表页面模板中的列表时,我需要一个通知事件。像 Page.listUpdated(e) 这样的东西会很棒,其中 e.Item 可以是新的 ListItem。
最初它是在新项目上启用条件格式,但我可以想到更多用途。
任何人都可以为此提出解决方法吗?
当新项目添加到 Google 网站列表页面模板中的列表时,我需要一个通知事件。像 Page.listUpdated(e) 这样的东西会很棒,其中 e.Item 可以是新的 ListItem。
最初它是在新项目上启用条件格式,但我可以想到更多用途。
任何人都可以为此提出解决方法吗?
我有一个在电子表格中运行的脚本,我用它来跟踪日历中的变化,并且我稍微修改了一下以检查 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
}