forked from ubc/canvas-discussion
-
Notifications
You must be signed in to change notification settings - Fork 0
/
writeToCSV.js
61 lines (52 loc) · 1.79 KB
/
writeToCSV.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
const fs = require('fs')
const path = require('path')
const fswrite = fs.writeFileSync
const fsappend = fs.appendFileSync
const writeHeader = (pathToFile, header) => fswrite(pathToFile, header + '\r\n')
const append = (pathToFile, row) => fsappend(pathToFile, row + '\r\n')
const escapeComment = comment => comment ? '"' + comment.replace(/"/g, "'") + '"' : ''
const stripHTML = comment => comment ? comment.replace(/(<([^>]+)>)/gi, "").replaceAll(' ', " ") : ''
const writeToCSV = (courseId, data) => {
const csv = path.join(__dirname, `output/${courseId}-discussion.csv`)
const header = [
'author_id',
'author_name',
'post_id',
'post_parent_id',
'discussion_topic_title',
'discussion_topic_message',
'post_message',
'count_of_likes',
'timestamp'
]
writeHeader(csv, header)
data.forEach(discussion => {
append(csv, [ // write discussion to CSV
discussion.authorId,
escapeComment(discussion.authorName),
discussion.id,
'', // discussion topics cannot have a parent ID
escapeComment(discussion.topicTitle),
escapeComment(discussion.topicMessage),
'',
'',
discussion.timestamp
])
discussion.replies.forEach(reply =>
reply.forEach(response => {
append(csv, [ // write replies to CSV
response.authorId,
escapeComment(response.authorName),
response.id,
response.parentId,
stripHTML(escapeComment(discussion.topicTitle)),
stripHTML(escapeComment(discussion.topicMessage)),
stripHTML(escapeComment(response.message)),
response.likes,
response.timestamp
])
})
)
})
}
module.exports = writeToCSV