-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCode.js
More file actions
126 lines (117 loc) · 3.68 KB
/
Code.js
File metadata and controls
126 lines (117 loc) · 3.68 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
//import 'google-apps-script';
var prop_pre = 'ServerStatus_';
function onOpen() {
SpreadsheetApp.getUi()
.createMenu('Server Status')
.addSubMenu(SpreadsheetApp.getUi().createMenu('Settings')
.addItem('Set timeout', 'setTimeout')
.addItem('Set password', 'setPassword')
.addItem('Set active color', 'setActiveColor')
.addItem('Set inactive color', 'setInactiveColor'))
.addToUi();
}
function setTimeout() { setprop('timeout'); }
function setPassword() { setprop('password'); }
function setActiveColor() { setprop('activeColor'); }
function setInactiveColor() { setprop('inactiveColor'); }
function setprop(prop) {
var ui = SpreadsheetApp.getUi();
var old = PropertiesService.getDocumentProperties().getProperty(prop_pre + prop);
var response = ui.prompt('New value', 'Old value: ' + old, ui.ButtonSet.OK_CANCEL);
if (response.getSelectedButton() == ui.Button.OK) {
PropertiesService.getDocumentProperties().setProperty(prop_pre + prop, response.getResponseText());
}
}
function doGet(event) {
try {
var servername = event.parameter.get;
servername = servername.replace(/-/g, "_");
var spreadsheet = SpreadsheetApp.getActiveSpreadsheet();
if (servername == 'all') {
var namedranges = spreadsheet.getNamedRanges();
var retval = {};
for (namedrange of namedranges) {
var cell = namedrange.getRange();
var name = namedrange.getName();
var color = cell.getBackground();
retval[name] = color;
}
retval = JSON.stringify(retval);
retval = retval.replace(/_/g, "-");
return ContentService.createTextOutput(retval);
}
var cell = spreadsheet.getRangeByName(servername);
var color = cell.getBackground();
return ContentService.createTextOutput(color);
} catch (error) {
Logger.log(error);
}
}
function doPost(event) {
try {
var pass = event.parameter.pass;
var prop = PropertiesService.getDocumentProperties();
password = prop.getProperty(prop_pre + 'password');
if (pass == password) {
var date = new Date();
var servername = event.parameter.set;
servername = servername.replace(/-/g, "_");
var spreadsheet = SpreadsheetApp.getActiveSpreadsheet();
var cell = spreadsheet.getRangeByName(servername);
activeColor = prop.getProperty(prop_pre + 'activeColor');
cell.setBackground(activeColor);
cell.setNote(date);
}
else {
Logger.log("wrong password");
}
} catch (error) {
Logger.log(error);
}
}
function timetTriggerTest() {
var date = new Date();
var test = {
'year': date.getFullYear(),
'month': date.getMonth() + 1,
'day-of-month': date.getDate(),
'hour': date.getHours(),
'minute': date.getMinutes(),
'second': date.getSeconds()
};
Logger.log(test);
timeTrigger(test);
}
// TODO: modify trigger interval from UI https://developers.google.com/apps-script/reference/script/clock-trigger-builder
function timeTrigger(event) {
try {
var dateNow = new Date(
event.year,
event.month - 1,
event['day-of-month'],
event.hour + 1,
event.minute,
event.second
);
var spreadsheet = SpreadsheetApp.getActiveSpreadsheet();
var prop = PropertiesService.getDocumentProperties();
timeout = new Number(prop.getProperty(prop_pre + 'timeout'));
activeColor = prop.getProperty(prop_pre + 'activeColor');
inactiveColor = prop.getProperty(prop_pre + 'inactiveColor');
var namedranges = spreadsheet.getNamedRanges();
for (namedrange of namedranges) {
var cell = namedrange.getRange();
var color = cell.getBackground();
if (color == activeColor) {
var cellNote = cell.getNote();
var endDate = new Date(cellNote);
endDate.setSeconds(endDate.getSeconds() + timeout);
if (dateNow > endDate) {
cell.setBackground(inactiveColor);
}
}
}
} catch (error) {
Logger.log(error);
}
}