-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfunc_pessoa.js
65 lines (54 loc) · 1.65 KB
/
func_pessoa.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
const func_pessoa = function(app) {
// Models
const tb_pessoa = require('./models/pessoa')
// Rotas
app.get('/pessoas/cadastrar', function(req, res) {
res.render('pages/pessoa_cadastro')
})
app.post('/pessoas/cadastrar', function(req, res) {
tb_pessoa.create({
nome: req.body.nome,
apelido: req.body.apelido
}).then(function() {
res.redirect('/pessoas/listar')
})
})
app.get('/pessoas/editar/:id', function(req, res) {
tb_pessoa.findByPk(req.params.id).then((dado) => {
if (dado)
res.render('pages/pessoa_editar', { pessoa : dado })
else
res.redirect('/pessoas/listar')
})
})
app.post('/pessoas/editar/:id', function(req, res) {
tb_pessoa.update({
nome: req.body.nome,
apelido: req.body.apelido
}, { where: { id: req.params.id }}).then(function() {
res.redirect('/pessoas/listar')
})
})
app.get('/pessoas/listar', function(req, res) {
tb_pessoa.findAll({ order: [['nome', 'ASC']]}).then(function (dados) {
n_paginas = {
por_pagina: dados.length,
total: dados.length,
}
res.render('pages/pessoa_listar', { pessoas: dados, n_paginas: n_paginas })
})
})
app.get('/pessoas/apagar/:id', function(req, res) {
tb_pessoa.findByPk(req.params.id).then((dado) => {
if (dado)
res.render('pages/pessoa_apagar', { pessoa : dado })
else
res.redirect('/pessoas/listar')
})
})
app.post('/pessoas/apagar/:id', function(req, res) {
tb_pessoa.destroy({ where: { id: req.params.id }}).then(() => res.redirect('/pessoas/listar'))
})
}
// Exports
module.exports = func_pessoa