This repository was archived by the owner on Sep 8, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcheck_confirmation_email.js
79 lines (66 loc) · 3.1 KB
/
check_confirmation_email.js
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
function checkGmailUsingChron () { // eslint-disable-line
updateSheetIfConfirmationEmailIn(getUnReadEmails())
}
function getUnReadEmails () {
return GmailApp.search('is:unread') // eslint-disable-line
}
function updateSheetIfConfirmationEmailIn (unreadEmails) {
const nutriaNewSubject = 'Nutria Interview'
const nutriaUpdateSubject = 'Updates'
const nutriaSymbol = '>'
for (var unreadIndex = 0; unreadIndex < unreadEmails.length; unreadIndex++) {
var currentEmail = unreadEmails[unreadIndex]
var emailSubject = currentEmail.getFirstMessageSubject()
if (emailSubject.includes(nutriaNewSubject) || emailSubject.includes(nutriaUpdateSubject)) {
var discordUser = ''
var interviewDay = ''
var confirmation = false
var allMessages = currentEmail.getMessages()
var lastMessage = allMessages[allMessages.length - 1]
var bodyOfTheEmailSplittedByLine = lastMessage.getPlainBody().split('\r\n')
for (var lineIndex = 0; lineIndex < bodyOfTheEmailSplittedByLine.length; lineIndex++) {
var currentLine = bodyOfTheEmailSplittedByLine[lineIndex]
if (currentLine !== '') {
if (!currentLine.includes(nutriaSymbol)) {
if (currentLine.toLowerCase().includes('confirm')) confirmation = true
} else if (currentLine.includes(nutriaSymbol)) {
if (currentLine.toLowerCase().includes('hi')) discordUser = currentLine.split(' ')[2]
if (currentLine.toLowerCase().includes('scheduled')) interviewDay = currentLine.split('for')[1].split(',')[0]
if (currentLine.toLowerCase().includes('reschedule')) interviewDay = currentLine.split('to')[1].split(',')[0]
}
}
if (confirmation === true && discordUser !== '' && interviewDay !== '') break
}
if (confirmation === false || discordUser === '' || interviewDay === '') return
if (interviewDay !== '' && discordUser !== '') {
var sheetSearch = DriveApp.getFilesByName('Schedule for Mock Interviews') // eslint-disable-line
currentEmail.markRead()
if (sheetSearch.hasNext()) {
var scheduleSheet = SpreadsheetApp.open(sheetSearch.next()).getSheets()[0] // eslint-disable-line
for (var column = 2; column < 16; column++) {
var dayOfSchedule = scheduleSheet.getRange(3, column).getValue()
if (interviewDay.includes(dayOfSchedule)) {
var rowOfDiscordUser = findRowOfDiscordUser(scheduleSheet, discordUser)
if (rowOfDiscordUser !== -1) {
const numberOfElementsToPaint = 4
scheduleSheet
.getRange(rowOfDiscordUser + 1, column, numberOfElementsToPaint)
.setBackgroundRGB('100', '221', '23')
}
}
}
}
}
}
}
}
function findRowOfDiscordUser (scheduleSheet, discordUser) {
const discordUserColumn = 16
var currentRow = 4
while (true) {
var currentUser = scheduleSheet.getRange(currentRow, discordUserColumn).getValue()
if (currentUser === '') return -1
if (currentUser === discordUser) return currentRow
currentRow += 5
}
}