Files
Gainsight/Scripts/GoogleScripts/Artera_wowprog/Code.js

68 lines
2.4 KiB
JavaScript
Raw Normal View History

2023-01-16 17:08:32 -05:00
var now = new Date();
var today = Utilities.formatDate(now, 'America/New_York', 'MM/dd/yyyy');
2023-01-17 15:59:28 -05:00
const readSheet = SpreadsheetApp.getActiveSpreadsheet().getSheets()[0];
const writeSheet = SpreadsheetApp.getActiveSpreadsheet().getSheets()[1];
2023-01-16 17:08:32 -05:00
2023-01-17 15:59:28 -05:00
// This function needs to happen every time the script runs.
2023-01-16 17:08:32 -05:00
function writeHeadings() {
// Write the new Column Headings
2023-01-17 15:59:28 -05:00
var lastColumn = writeSheet.getLastColumn()+1;
writeSheet.getRange(1, lastColumn).setValue("Percent Change");
writeSheet.getRange(1, lastColumn+1).setValue("Progress");
writeSheet.getRange(2, lastColumn+1).setValue(today);
addProgress(lastColumn);
2023-01-16 17:08:32 -05:00
}
2023-01-17 15:59:28 -05:00
// This function takes the progress from Column D of Sheet0 and adds it to Sheet1
function addProgress(lastColumn, prevColumn) {
// Process Data from Sheet0
var numRows = readSheet.getLastRow()-1; // Number of rows to process
var dataRange = readSheet.getRange(2, 2, numRows, 3);
// Process First Row from Sheet1
// var numRows = writeSheet.getLastRow()-1; // Number of rows to process
// var dataRange = writeSheet.getRange(3, 1, numRows, 1);
2023-01-16 17:08:32 -05:00
var values = dataRange.getValues();
for (item in values) {
var row = values[item];
var course= row[0];
var avgProgress = row [2];
2023-01-17 15:59:28 -05:00
findRow(course, avgProgress, lastColumn);
2023-01-16 17:08:32 -05:00
}
}
2023-01-17 15:59:28 -05:00
function findRow(course, avgProgress, lastColumn) {
var prevColumn = writeSheet.getLastColumn()-2;
var numRows = writeSheet.getLastRow();
var data = writeSheet.getRange(3,1,numRows,1).getValues();
for(var i = 0; i<data.length;i++){
if(data[i][0] == course){
var row = i+3;
var prevVal = writeSheet.getRange(row, prevColumn).getValues();
writeSheet.getRange(row, lastColumn+1).clearFormat();
writeSheet.getRange(row, lastColumn).clearFormat();
writeSheet.getRange(row, lastColumn+1).setValue(avgProgress);
writeSheet.getRange(row, lastColumn).setValue(percentDiff(prevVal, avgProgress));
}
}
}
function percentDiff(prevVal, avgProgress){
var prevVal = prevVal-0
var avgProgress = avgProgress-0
var percentChange = percentChange-0
// This block will NOT show negative changes. So if a number decreases from one week to the next, it will still show a POSITIVE % change.
// var percentChange =
// (
// (Math.abs(prevVal-avgProgress))/((prevVal+avgProgress)/2)
// )
// return percentChange
// Business Math! This will show negativos.
var percentChange =
(
(avgProgress-prevVal)/(prevVal)
)
return percentChange
}