31 lines
1.2 KiB
JavaScript
31 lines
1.2 KiB
JavaScript
const _ = require('lodash/fp')
|
|
const pgp = require('pg-promise')()
|
|
|
|
const db = require('../../db')
|
|
|
|
const getBills = filters => {
|
|
const deviceStatement = !_.isNil(filters.deviceId) ? `WHERE device_id = ${pgp.as.text(filters.deviceId)}` : ``
|
|
const batchStatement = filter => {
|
|
switch (filter) {
|
|
case 'none':
|
|
return `WHERE b.cashbox_batch_id IS NULL`
|
|
case 'any':
|
|
return `WHERE b.cashbox_batch_id IS NOT NULL`
|
|
default:
|
|
return _.isNil(filter) ? `` : `WHERE b.cashbox_batch_id = ${pgp.as.text(filter)}`
|
|
}
|
|
}
|
|
|
|
const sql = `SELECT b.id, b.fiat, b.fiat_code, b.created, b.cashbox_batch_id, cit.device_id AS device_id FROM bills b LEFT OUTER JOIN (
|
|
SELECT id, device_id FROM cash_in_txs ${deviceStatement}
|
|
) AS cit ON cit.id = b.cash_in_txs_id ${batchStatement(filters.batch)}`
|
|
|
|
const sql2 = `SELECT b.id, b.fiat, b.fiat_code, b.created, b.cashbox_batch_id, b.device_id FROM empty_unit_bills b ${deviceStatement} ${!_.isNil(filters.deviceId) && !_.isNil(filters.batch) ? `AND` : ``} ${batchStatement(filters.batch)}`
|
|
|
|
return Promise.all([db.any(sql), db.any(sql2)])
|
|
.then(([bills, operationalBills]) => _.map(_.mapKeys(_.camelCase), _.concat(bills, operationalBills)))
|
|
}
|
|
|
|
module.exports = {
|
|
getBills
|
|
}
|