-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
114 lines (100 loc) · 2.85 KB
/
index.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
111
112
113
114
//Requires
var express = require("express");
var bodyParser = require("body-parser");
var ejsLayouts = require("express-ejs-layouts")
var path = require('path');
var moment = require('moment');
//App variables
var app = express();
var db = require("./models");
//Set use statements
app.set("view engine", "ejs");
app.use(ejsLayouts);
app.use(bodyParser.urlencoded({extended: false}));
app.use(express.static(path.join(__dirname, 'static')));
//Define routes
//GET Home page
app.get("/", function(req, res) {
res.render("site/home");
});
//GET About page
app.get("/about", function(req, res) {
db.disaster.findAll({
order: [
['date', 'ASC']
]
}).then(function(disasters){
res.render("site/about", {disasters: disasters, moment: moment});
});
});
//GET all disasters
app.get('/disasters', function(req,res){
db.disaster.findAll({
order: [
['date', 'ASC']
]
}).then(function(disasters){
res.render('disasters/index', {disasters: disasters, moment: moment});
});
});
//Get new disaster form
app.get("/disasters/new", function(req, res){
db.disaster.findAll({
order: [
['date', 'ASC']
]
}).then(function(disasters){
res.render("disasters/new", {disasters: disasters, moment: moment});
});
});
//POST create new disaster in database from form data
app.post("/disasters/new", function(req, res){
console.log(req.body);
console.log(req.body.date + " " + req.body.time);
var dbTime = req.body.date + " " + req.body.time;
req.body.date = new Date(dbTime);
console.log(req.body.date);
db.disaster.create(req.body).then(function(article){
res.redirect("/disasters");
});
});
//GET saved disaster and create edit form
app.get("/disasters/:id/edit", function(req, res){
db.disaster.findById(req.params.id).then(function(disaster){
res.render("disasters/edit", {disaster: disaster, moment: moment, disasters: []});
});
});
//PUT edit existing disaster with new information and update database
app.put("/disasters/:id", function(req, res){
var disasterToUpdate = req.params.id;
console.log("Im trying to get updated:", req.params.id)
var dbTime = req.body.date + " " + req.body.time;
req.body.date = new Date(dbTime);
db.disaster.update({
country: req.body.country,
disaster_type: req.body.disaster_type,
casualties: req.body.casualties,
date: req.body.date,
}, {
where: { id: disasterToUpdate }
}).then(function(){
res.send();
});
});
//DELETE delete existing article
app.delete("/disasters/:id", function(req, res) {
var disasterToErase = req.params.id;
db.disaster.destroy({
where: { id: disasterToErase }
}).then(function(){
res.send();
});
});
//GET one disaster by id
app.get("/disasters/:id", function(req, res){
console.log(req.params.id);
db.disaster.findById(req.params.id).then(function(disaster){
res.send();
});
});
app.listen(3000);