我正在尝试打开一个 UI,它向用户询问两个变量,然后在“ok”上,关闭 ui,并以这两个变量作为参数执行一个函数......
我的问题是 ui 保持打开状态,并且来自 serverhandler 的代码正在循环执行,直到 ui 打开。如果我在我的代码中看不到任何循环,如果我在没有 ui 的情况下直接执行相同的函数,它运行良好......我错过了我的处理程序上的一些东西?
function doGet() {
var app = UiApp.createApplication();
var mygrid = app.createGrid(3, 2);
mygrid.setWidget(0, 0, app.createLabel('Date de début:'));
mygrid.setWidget(0, 1, app.createDateBox().setId('dateA'));
mygrid.setWidget(1, 0, app.createLabel('Date de fin:'));
mygrid.setWidget(1, 1, app.createDateBox().setId('dateB'));
var mybutton = app.createButton('OK');
mybutton.setId("mybutton");
var mypanel = app.createVerticalPanel();
mypanel.setId('mypanel');
mypanel.add(mygrid);
mypanel.add(mybutton);
app.add(mypanel);
var handler = app.createServerHandler('summaryOnDemand');
handler.addCallbackElement(mypanel);
mybutton.addClickHandler(handler);
return app;
}
function summaryOnDemand(e) {
var app = UiApp.getActiveApplication();
var dateA = e.parameter.dateA;
var dateB = e.parameter.dateB;
var panel = app.getElementById('mypanel');
panel.setVisible(false);
app.close();
// var mydoc = SpreadsheetApp.openById("0AiK_IybPWcGcdEV5V2JQUHhtUHp1dEhEN3NuQjdrVWc");
var file = summary(dateA,dateB,true);
var folder = DocsList.getFolderById("0ByK_IybPWcGcX1lUTlRET0dQVXc");
file.addToFolder(folder);
MailApp.sendEmail(Session.getActiveUser().getEmail(),"Rapport réclamation à la demande","Le document ce trouve dans google drive à présent, pour y accéder directement : " + file.getUrl())
return app;
}