-
Notifications
You must be signed in to change notification settings - Fork 0
/
contaController.js
86 lines (80 loc) · 2.87 KB
/
contaController.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
var Conta = require('./models').Conta,
Fluxo = require('./models').Fluxo,
mongoose = require('mongoose');
function list(req, res) {
Conta.find().sort(req.body.sort + ' ' + req.body.dir).skip(req.body.start).limit(req.body.limit).exec(function (err, contas) {
res.json({success: true, data: contas, inicio: req.body.start, total: Conta.count()});
});
}
function create(req, res) {
var data = JSON.parse(req.body.data);
var conta = Conta({nome: data.nome, flag_tipo: data.flag_tipo});
if (data.conta_id != false)
conta.conta_id = data.conta_id;
conta.save(function(err, conta) {
if (err) {
res.json(200, {success: false, message: 'Erro ao salvar no banco de dados'});
console.log(err);
}
else
res.json(200, {success: true, message: 'Registro salvo', data: conta});
});
}
function update(req, res) {
var data = JSON.parse(req.body.data);
var conta = Conta.findById(data._id, function (err, conta) {
if (err) {
res.json(200, {success: false, message: 'Erro ao obter registro'});
console.log(err);
}
else {
conta.nome = data.nome;
conta.flag_tipo = data.flag_tipo;
if (data.conta_id != false)
conta.conta_id = data.conta_id;
conta.save(function (err, conta) {
if (err) {
res.json(200, {success: false, message: 'Erro ao salvar no banco de dados'});
console.log(err);
}
else
res.json(200, {success: true, message: 'Registro salvo', data: conta});
});
}
});
}
function _delete(req, res) {
var data = JSON.parse(req.body.data);
if (Object.prototype.toString.call(data) === '[object Array]') {
data.forEach(function (item) {
Conta.findByIdAndRemove(item._id).exec();
});
res.json(200, {success: true, message: 'Registro excluido'});
}
else
Conta.findByIdAndRemove(data._id, function (err) {
if (err)
res.json(200, {success: false, message: 'Erro ao excluir'});
else
res.json(200, {success: true, message: 'Registro excluido'});
});
}
function grafico(req, res) {
Conta.find().sort({nome: 'asc'}).exec(function (err, contas) {
var resultado = [];
contas.forEach(function (item, index, array) {
var obj = {conta: item.nome};
Fluxo.count({conta_id: item._id}, function (err, count) {
obj.total = count;
resultado.push(obj);
if (index === array.length - 1)
res.json(200, resultado);
});
});
});
}
exports.list = list;
exports.create = create;
exports.update = update;
exports._delete = _delete;
exports.grafico = grafico;