, , , . , Google Spreadsheet . , , , . , . .
function docReport() {
try {
splashScreen("Generando informe...");
var activeSheet = SpreadsheetApp.getActiveSheet();
var numberOfColumns = activeSheet.getLastColumn();
var numberOfRows = activeSheet.getLastRow();
var activeRow, rowRange;
var titleRow = activeSheet.getRange(1, 1, 1, numberOfColumns).getValues();
activeSheet.setActiveSelection("2:" + activeSheet.getLastRow()).setBackground("#fffff9");
var docReport = DocumentApp.create(REPORT_FILE_NAME);
var bodyReport = docReport.getBody();
bodyReport.setAttributes(stylePage);
for (var row = 2; row <= numberOfRows; row++) {
rowRange = activeSheet.getRange(row, 1, 1, numberOfColumns);
if (rowRange.getBackground() == "#fffff9") {
activeSheet.setActiveSelection(row + ":" + row).setBackground("#ffffff");
activeRow = rowRange.getValues();
if (!isEmpty(activeRow[0], numberOfColumns)) {
var image = UrlFetchApp.fetch(IMG_BBVA);
bodyReport.appendParagraph("").addPositionedImage(image).setHeight(100).setWidth(98).setLayout(DocumentApp.PositionedLayout.WRAP_TEXT);
bodyReport.appendParagraph(" S.J.").setAttributes(styleTextBlue);
bodyReport.appendParagraph(DATE_REPORT + "\r\n\r\n").setAttributes(styleDate);
for (var col = 1; col < numberOfColumns; col++) {
if (activeRow[0][col] != "") {
if (col == COLUMN_NORMA)
bodyReport.appendParagraph(String(activeRow[0][col]).trim()).setAttributes(styleTextNorma);
else {
bodyReport.appendParagraph(titleRow[0][col]).setAttributes(styleTitle);
bodyReport.appendParagraph(String(activeRow[0][col]).trim()).setAttributes(styleText);
}
bodyReport.appendParagraph("");
}
}
bodyReport.appendPageBreak();
}
}
}
activeSheet.setActiveSelection("2:" + activeSheet.getLastRow()).setBackground("#ffffff");
bodyReport.appendPageBreak();
docReport.saveAndClose();
MailApp.sendEmail(Session.getActiveUser().getEmail(), "Informe " + REPORT_FILE_NAME + " generado",
'Se ha creado un nuevo informe "' + REPORT_FILE_NAME + '" en su unidad Google Drive: \n\r' + docReport.getUrl());
SpreadsheetApp.flush();
SpreadsheetApp.getUi().alert('Se ha creado un nuevo informe "' + REPORT_FILE_NAME + '" en su unidad Google Drive \r\n');
} catch(e) {
Logger.log("ERROR in function createPdf \r\nMessage: " + e.message + "\r\nFile gs: " + e.fileName + "\r\nLine: " + e.lineNumber)
Logger.log("\r\nUser: " + Session.getActiveUser().getEmail() + ", Date: " + Utilities.formatDate(new Date(), "GMT+1", "yyyyMMdd'_'HH:mm:ss"));
MailApp.sendEmail(EMAIL_DEV, SUBJECT_MAIL, Logger.getLog());
}
}