forked from fdnd-task/proof-of-concept
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
110 lines (82 loc) · 3.46 KB
/
server.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
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
console.log('Hier komt je server voor Sprint 12.')
// Importeer het npm pakket express uit de node_modules map
import express from 'express'
// Importeer de zelfgemaakte functie fetchJson uit de ./helpers map
import fetchJson from './helpers/fetch-json.js'
// Maak een nieuwe express app aan
const app = express()
const baseUrl = 'https://fdnd-agency.directus.app/'
const apiUrl = 'https://fdnd-agency.directus.app/items/frd_site'
// Endpoints
// New 13-06
// const fetchSites = await fetchJson('https://fdnd-agency.directus.app/items/frd_site')
// const fetchAllScans = await fetchJson('https://fdnd-agency.directus.app/items/frd_scans')
const nieuwekijkScans = await fetchJson('https://fdnd-agency.directus.app/items/frd_site?filter[scans][_eq]=11&fields=id,title,scans.*')
const fetchAllScans = async () => {
return await fetchJson('https://fdnd-agency.directus.app/items/frd_scans');
};
const fetchSites = async () => {
return await fetchJson('https://fdnd-agency.directus.app/items/frd_site');
};
// Stel ejs in als template engine
app.set('view engine', 'ejs')
// Stel de map met ejs templates in
app.set('views', './views')
// Gebruik de map 'public' voor statische resources, zoals stylesheets, afbeeldingen en client-side JavaScript
app.use(express.static('public'))
// Zorg dat werken met request data makkelijker wordt
app.use(express.urlencoded({extended: true}))
// 🗺️ ROUTES > AANMAKEN VOOR DE ACCESDASH
// Home route
app.get('/', async function (request, response) {
try {
const sitesResponse = await fetchSites();
const sites = sitesResponse.data; // Haal de 'data' eigenschap eruit
console.log('Fetched sites:', sites); // Log de opgehaalde sites
response.render('index', {
sites: sites
});
} catch (error) {
response.status(500).send('Er is een fout opgetreden');
}
});
// Define the formatDate function
function formatDate(dateString) {
const date = new Date(dateString);
const monthNames = ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"];
return monthNames[date.getMonth()];
}
// Detail route
app.get('/site/:id', async function (request, response) {
try {
const siteId = parseInt(request.params.id);
console.log('Site id:', siteId);
const allScansResponse = await fetchAllScans();
const allScans = allScansResponse.data;
const sitesResponse = await fetchSites();
const sites = sitesResponse.data;
// Vind de site met de gegeven id
const site = sites.find(s => s.id === siteId);
if (!site) {
return response.status(404).send('Site not found');
}
// Filter de scans die bij deze site horen
const siteScans = allScans.filter(scan => site.scans.includes(scan.id));
console.log('Fetched site scans:', siteScans);
response.render('detail', {
site: site,
scans: siteScans,
formatDate
});
} catch (error) {
response.status(500).send('Er is een fout opgetreden');
}
});
// 🚧 POST > AANMAKEN ALS DIE ER MOET KOMEN
// Stel het poortnummer in waar express op moet gaan luisteren
app.set('port', process.env.PORT || 8000)
// Start express op, haal daarbij het zojuist ingestelde poortnummer op
app.listen(app.get('port'), function() {
// Toon een bericht in de console en geef het poortnummer door
console.log(`Application started on http://localhost:${app.get('port')}`)
})