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;