nas-denar/routes/razmerje.js
2017-09-14 20:06:51 +02:00

185 lines
6.5 KiB
JavaScript

var express = require('express');
var router = express.Router();
var options = require('./dbconfig');
//
// Postgresql
//
var Pool = require('pg').Pool;
var config = {
user: 'matjaz',
password: 'mesnjak',
database: 'supervizor',
host: 'server.dev',
port: 5432,
max: 10,
idleTimeoutMillis: 30000,
};
var pool = new Pool(config);
router.get('/:sifrapu/:davcna/:id?', function (req, res, next) {
if(!req.params.id) req.params.id = 0;
var odgovor = {
title: 'Naš denar',
stran: req.params.id,
next: parseInt(req.params.id) + 1,
prev: parseInt(req.params.id) - 1,
obdobje: "vse",
sifrapu: req.params.sifrapu,
davcna: req.params.davcna,
grafEvidence: -1,
tecajnica: -1,
narociladelez_organ: -1,
narociladelez_podj: -1,
rtr: {},
};
var stevec = 0;
var vseZahteve = 11;
pool.query('SELECT organ, maticna, davcna, sifra_pu, naslov, posta, tip_omejitve, ps_naziv, drzava, ps_maticna, ps_davcna, mid, ps_naslov, ps_posta, (extract(day FROM datum_od) || \'.\' || extract(month FROM datum_od) || \'.\' || extract(year FROM datum_od)) DATUM_OD, (extract(day FROM datum_do) || \'.\' || extract(month FROM datum_do) || \'.\' || extract(year FROM datum_do)) DATUM_DO FROM omejitve WHERE sifra_pu = $1 and ps_davcna = $2', [req.params.sifrapu, req.params.davcna], function (err, omejitve) {
if(err) {
throw err;
}
odgovor.omejitve = omejitve.rows;
stevec++;
console.log('1');
if(stevec == vseZahteve) {
res.render('razmerje', odgovor);
}
})
pool.query('SELECT * FROM lokacija WHERE davcna_stevilka = $1 LIMIT 1', [req.params.davcna], function (err, lokacijaZS) {
if(err) {
throw err;
}
odgovor.lokacijaZS = lokacijaZS.rows;
stevec++;
console.log('2');
if(stevec == vseZahteve) {
res.render('razmerje', odgovor);
}
})
pool.query('SELECT organ, ps_naziv, (extract(day FROM ujp.datum_transakcije) || \'.\' || extract(month FROM ujp.datum_transakcije) || \'.\' || extract(year FROM ujp.datum_transakcije)) DATUM_TR, (extract(day FROM datum_od) || \'.\' || extract(month FROM datum_od) || \'.\' || extract(year FROM datum_od)) DATUM_OD, (extract(day FROM datum_do) || \'.\' || extract(month FROM datum_do) || \'.\' || extract(year FROM datum_do)) DATUM_DO, znesek_transakcije FROM omejitve, ujp WHERE (omejitve.sifra_pu = $1 AND ujp.sifra_pu = $2) and (omejitve.ps_davcna = $3 and ujp.davcna_stevilka = $4) and (datum_od < datum_transakcije) AND (datum_transakcije < datum_do) AND (extract(year FROM datum_transakcije) >= 2014)', [req.params.sifrapu, req.params.sifrapu, req.params.davcna, req.params.davcna], function (err, krsitveomejitev) {
if(err) {
throw err;
}
odgovor.krsitveOmejitev = krsitveomejitev.rows;
stevec++;
console.log('3');
if(stevec == vseZahteve) {
res.render('razmerje', odgovor);
}
})
pool.query('SELECT * FROM lokacija WHERE davcna_stevilka = (SELECT davcna FROM rpu WHERE sifra_pu = $1 LIMIT 1) LIMIT 1', [req.params.sifrapu], function (err, lokacija_JS) {
if(err) {
throw err;
}
odgovor.lokacijaJS = lokacija_JS.rows;
stevec++;
console.log('4');
if(stevec == vseZahteve) {
res.render('razmerje', odgovor);
}
})
pool.query('SELECT * FROM rpu WHERE sifra_pu = $1 LIMIT 1', [req.params.sifrapu], function (err, subjResult) {
if(err) {
throw err;
}
odgovor.subjekt = subjResult.rows;
stevec++;
console.log('5');
if(stevec == vseZahteve) {
res.render('razmerje', odgovor);
}
})
pool.query('SELECT * FROM furs WHERE zavezanec = $1', [req.params.davcna], function (err, neplacniki) {
if(err) {
throw err;
}
odgovor.neplacniki = neplacniki.rows;
stevec++;
console.log('6')
if(stevec == vseZahteve) {
res.render('razmerje', odgovor);
}
})
pool.query('SELECT sum(vsota_prejemkov) STOLPIC, leto, mesec FROM dupu WHERE sifra_pu = $1 AND davcna_stevilka = $2 GROUP BY leto, mesec', [req.params.sifrapu, req.params.davcna], function (err, transResult) {
if(err) {
throw err;
}
var date = new Date();
var mesec = date.getMonth() + 1;
var leto = date.getFullYear();
var vsehMesecev = (leto - 2003) * 12 + mesec;
var stolpci = [];
for (var i = 0; i < vsehMesecev; i++) {
stolpci.push(0);
}
for (var j = 0; j < transResult.rows.length; j++) {
stolpci[((transResult.rows[j].leto - 2003) * 12 + transResult.rows[j].mesec) - 1] = transResult.rows[j].stolpic;
}
odgovor.transakcije = stolpci;
stevec++;
console.log('7');
if(stevec == vseZahteve) {
res.render('razmerje', odgovor);
}
})
pool.query('SELECT kreditojemalec_naziv, kreditojemalec_sedez, davcna, posta, postna_st, kreditodajalec, st_pogodbe, znesek_eur, vrsta_posla, (extract(day FROM datum_pogodbe) || \'.\' || extract(month from datum_pogodbe) || \'.\' || extract(year from datum_pogodbe)) DATUM, zavarovanje_vrsta, zavarovanje_predmet FROM dutb WHERE davcna = $1 ORDER BY datum_pogodbe', [req.params.davcna], function (err, dutbResult) {
if(err) {
throw err;
}
odgovor.dutb = dutbResult.rows;
stevec++;
console.log('8');
if(stevec == vseZahteve) {
res.render('razmerje', odgovor);
}
})
pool.query('SELECT kreditodajalec, sum(znesek_eur) ZNESEK FROM dutb WHERE davcna = $1 GROUP BY kreditodajalec', [req.params.davcna], function (err, dutbDelezi) {
if(err) {
throw err;
}
odgovor.dutbdelez = dutbDelezi.rows;
stevec++;
console.log('9');
if(stevec == vseZahteve) {
res.render('razmerje', odgovor);
}
})
pool.query('SELECT * FROM prs WHERE davcna = $1 LIMIT 1', [req.params.davcna], function (err, subjekt_ZS) {
if(err){
throw err;
}
odgovor.subjektZS = subjekt_ZS.rows;
stevec++;
console.log('10');
if(stevec == vseZahteve) {
res.render('razmerje', odgovor);
}
})
pool.query('SELECT *, (extract(day FROM datum_objave) || \'.\' || extract(month FROM datum_objave) || \'.\' || extract(year FROM datum_objave)) datum FROM narocila WHERE sifra_pu_narocnika = $1 and davcna_ponudnika = $2 ORDER BY datum_objave DESC', [req.params.sifrapu, req.params.davcna], function (err, narocila) {
if(err) {
throw err
}
odgovor.narocila = narocila.rows
stevec++
console.log("11")
if(stevec == vseZahteve) {
res.render('razmerje', odgovor)
}
})
});
module.exports = router;