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
|
const EventEmitter = require('events')
const leftPad = require('left-pad')
const search = require('./search')
const self = new EventEmitter()
self._nodes = {
schedule: document.querySelector('#schedule')
}
self._parseMeetingpointHTML = function (htmlStr) {
const html = document.createElement('html')
html.innerHTML = htmlStr
const centerNode = html.querySelector('center')
return centerNode
}
self._handleLoad = function (event) {
const request = event.target
if (request.status < 200 || request.status >= 400) {
self._handleError(event)
return
}
const document = self._parseMeetingpointHTML(request.response)
self._nodes.schedule.appendChild(document)
self._nodes.schedule.classList.remove('error')
self.emit('load')
}
self._handleError = function (event) {
const request = event.target
let error
if (request.status === 404) {
error = 'Sorry, er is (nog) geen rooster voor deze week.'
} else {
error = 'Sorry, er is iets mis gegaan tijdens het laden van deze week.'
}
self._nodes.schedule.textContent = error
self._nodes.schedule.classList.add('error')
self.emit('load')
}
self._getURLOfUsers = function (week, type, index) {
const id = index + 1
return `//${window.location.host}/meetingpointProxy/Roosters-AL%2Fdoc%2Fdagroosters%2F` +
`${(week)}%2F${type}%2F${type}${leftPad(id, 5, '0')}.htm`
}
self.viewItem = function (week, selectedUser) {
const url = self._getURLOfUsers(week, selectedUser.type, selectedUser.index)
while (self._nodes.schedule.firstChild) {
self._nodes.schedule.removeChild(self._nodes.schedule.firstChild)
}
const request = new window.XMLHttpRequest()
request.addEventListener('load', self._handleLoad)
request.addEventListener('error', self._handleError)
request.open('GET', url, true)
request.send()
search.updateDom(selectedUser)
}
module.exports = self
|