This commit is contained in:
Carlos Jimenez Ruiz 2019-02-07 09:01:18 +01:00
commit 01c130fc52
15 changed files with 146 additions and 61 deletions

View File

@ -2,6 +2,10 @@
text-transform: uppercase text-transform: uppercase
} }
.justified {
text-align: justify
}
.centered { .centered {
text-align: center text-align: center
} }

View File

@ -106,6 +106,9 @@ module.exports = {
const options = { const options = {
format: 'A4', format: 'A4',
border: '1.5cm', border: '1.5cm',
header: {
height: '80px',
},
footer: { footer: {
height: '60px', height: '60px',
} }

View File

@ -16,8 +16,8 @@ module.exports = app => {
app.get(`/api/report/${name}`, (request, response, next) => { app.get(`/api/report/${name}`, (request, response, next) => {
reportEngine.toPdf(name, request).then(stream => { reportEngine.toPdf(name, request).then(stream => {
// response.setHeader('Content-Disposition', `attachment; filename="${name}.pdf"`); response.setHeader('Content-Disposition', `attachment; filename="${name}.pdf"`);
// response.setHeader('Content-type', 'application/pdf'); response.setHeader('Content-type', 'application/pdf');
stream.pipe(response); stream.pipe(response);
}).catch(e => { }).catch(e => {
next(e); next(e);

View File

@ -1,13 +1,14 @@
header { header {
font-family: "Roboto", "Helvetica", "Arial", sans-serif;
border-bottom: 1px solid #DDD; border-bottom: 1px solid #DDD;
padding-bottom: 10px; padding-bottom: 10px;
margin-bottom: 40px;
text-align: center; text-align: center;
font-size: 0.65em; font-size: 0.60em;
color: #555 color: #555;
zoom: 0.65
} }
header img { header img {
margin-bottom: 10px; margin-bottom: 10px;
width: 350px width: 350px
} }

View File

@ -3,7 +3,9 @@
<body> <body>
<section class="container"> <section class="container">
<!-- Header component --> <!-- Header component -->
<report-header :locale="locale"></report-header> <report-header id="pageHeader-first"
:locale="locale">
</report-header>
<!-- End header component --> <!-- End header component -->
<section class="main"> <section class="main">
<section class="columns"> <section class="columns">

View File

@ -3,7 +3,9 @@
<body> <body>
<section class="container" id="report"> <section class="container" id="report">
<!-- Header component --> <!-- Header component -->
<report-header :locale="locale"></report-header> <report-header id="pageHeader-first"
:locale="locale">
</report-header>
<!-- End header component --> <!-- End header component -->
<section class="main"> <section class="main">
<section class="columns"> <section class="columns">
@ -50,19 +52,24 @@
<table class="column-oriented"> <table class="column-oriented">
<thead> <thead>
<tr> <tr>
<th>{{$t('date')}}</th> <th>{{$t('reference')}}</th>
<th>{{$t('quantity')}}</th>
<th>{{$t('concept')}}</th> <th>{{$t('concept')}}</th>
<th class="number">{{$t('invoiced')}}</th> <th class="number">{{$t('size')}}</th>
<th class="number">{{$t('payed')}}</th> <th>{{$t('cat')}}</th>
<th class="number">{{$t('balance')}}</th> <th>{{$t('col')}}</th>
<th>{{$t('VAT')}}</th>
<th>{{$t('price')}}</th>
<th>{{$t('%')}}</th>
<th>{{$t('amount')}}</th>
</tr> </tr>
</thead> </thead>
<tbody> <tbody>
<tr v-for="sale in sales" :key="sale.id"> <tr v-for="sale in sales" :key="sale.id">
<td>{{toISOString(sale.issued)}}</td> <td>{{sale.ref</td>
<td>{{sale.ref}}</td> <td>{{sale}}</td>
<td class="number">{{sale.debtOut}}</td> <td class="number">{{sale}}</td>
<td class="number">{{sale.debtIn}}</td> <td class="number">{{sale}}</td>
<td class="number">{{a}}</td> <td class="number">{{a}}</td>
</tr> </tr>
</tbody> </tbody>

View File

@ -12,16 +12,16 @@ module.exports = {
throw new UserException('No ticket id specified'); throw new UserException('No ticket id specified');
promises.push(this.methods.fetchClient(params.ticketFk)); promises.push(this.methods.fetchClient(params.ticketFk));
// promises.push(this.methods.fetchSales(params.ticketFk)); promises.push(this.methods.fetchSales(params.ticketFk));
return Promise.all(promises).then(result => { return Promise.all(promises).then(result => {
const [[client]] = result[0]; const [[client]] = result[0];
// const [[sales]] = result[1]; const [sales] = result[1];
if (!client) if (!client)
throw new UserException('No client data found'); throw new UserException('No client data found');
Object.assign(data, client); Object.assign(data, client, {sales});
return data; return data;
}); });
@ -64,16 +64,60 @@ module.exports = {
LEFT JOIN dms d ON d.id = dt.dmsFk LEFT JOIN dms d ON d.id = dt.dmsFk
WHERE t.id = ?`, [ticketFk]); WHERE t.id = ?`, [ticketFk]);
}, },
fetchSales(clientFk, companyFk) { fetchSales(ticketFk) {
return database.pool.query( return database.pool.query(
`CALL vn.clientGetDebtDiary(?, ?)`, [clientFk, companyFk]); `SELECT
s.id,
s.itemFk,
s.concept,
s.quantity,
s.price,
s.price - SUM(IF(ctr.id = 6,
sc.value,
0)) netPrice,
s.discount,
i.size,
i.stems,
ic.type taxType,
i.category,
it.id itemTypeId,
o.code AS origin,
i.inkFk,
s.ticketFk,
ita.tag1,
ita.val1,
ita.tag2,
ita.val2,
ita.tag3,
ita.val3
FROM sale s
LEFT JOIN saleComponent sc ON sc.saleFk = s.id
LEFT JOIN componentRate cr ON cr.id = sc.componentFk
LEFT JOIN componentTypeRate ctr ON ctr.id = cr.componentTypeRate
LEFT JOIN item i ON i.id = s.itemFk
LEFT JOIN ticket t ON t.id = s.ticketFk
LEFT JOIN origin o ON o.id = i.originFk
INNER JOIN supplier sp ON sp.id = t.companyFk
INNER JOIN itemType it ON it.id = i.typeFk
LEFT JOIN
(SELECT *
FROM
(SELECT tt.countryFk, tcc.taxClassFk, tc.type
FROM taxClassCode tcc
JOIN taxCode tc ON tc.id = tcc.taxCodeFk
JOIN taxType tt ON tt.id = tc.taxTypeFk
WHERE tcc.effectived <= '2019-01-29 13:00:00'
ORDER BY tcc.effectived DESC) tx
GROUP BY tx.countryFk, tx.taxClassFk) ic ON ic.countryFk = sp.countryFk
AND ic.taxClassFk = i.taxClassFk
JOIN vn.itemTagArranged ita ON ita.itemFk = s.itemFk
WHERE s.ticketFk = ?
GROUP BY s.id
ORDER BY (it.isPackaging), s.concept, s.itemFk`, [ticketFk]);
}, },
dated: () => { dated: () => {
return strftime('%d-%m-%Y', new Date()); return strftime('%d-%m-%Y', new Date());
}, },
toISOString: date => {
return strftime('%d-%m-%Y', date);
},
}, },
components: { components: {
'report-header': require('../report-header'), 'report-header': require('../report-header'),

View File

@ -1,3 +1,25 @@
table.column-oriented { p {
margin-top: 50px !important font-size: 1.2em;
margin: 0
}
.main {
position: relative;
height: 100%
}
.content {
position: absolute;
margin-top: -200px;
height: 400px;
top: 50%
}
.signature {
text-align: center;
margin-top: 150px
}
.signature img {
width: 400px
} }

Binary file not shown.

After

Width:  |  Height:  |  Size: 101 KiB

View File

@ -3,28 +3,24 @@
<body> <body>
<section class="container" id="report"> <section class="container" id="report">
<!-- Header component --> <!-- Header component -->
<report-header :locale="locale"></report-header> <report-header id="pageHeader-first"
:locale="locale">
</report-header>
<!-- End header component --> <!-- End header component -->
<section class="main"> <section class="main">
<!-- Report start --> <!-- Report start -->
<h1 class="title">{{$t('title')}}</h1> <section class="content">
<p>{{$t('date')}} {{dated()}}</p> <h1 class="title centered uppercase">{{$t('title')}}</h1>
<table class="column-oriented"> <p class="centered">
<thead> Recibo de <strong class="uppercase">LEON LLORENS LUIS ENRIQUE</strong>,
<tr> la cantidad de <strong>259,96 €</strong> en concepto de 'entrega a cuenta', quedando pendiente en la cuenta del cliente
<th>Id</th> un saldo de <strong>0,00 €</strong>.
<th>{{$t('concept')}}</th> </p>
<th>{{$t('quantity')}}</th> <section class="signature">
</tr> <img :src="embeded['/assets/images/signature.png']">
</thead> <p class="centered">{{$t('dated', ['Silla', '20', 'enero', '2019'])}}</p>
<tbody> </section>
<tr v-for="sale in sales" :key="sale.id"> </section>
<td class="font gray">{{sale.id}}</td>
<td>{{sale.concept}}</td>
<td>{{sale.quantity}}</td>
</tr>
</tbody>
</table>
<!-- Report end --> <!-- Report end -->
</section> </section>
<!-- Footer component --> <!-- Footer component -->

View File

@ -5,25 +5,26 @@ module.exports = {
created() { created() {
if (this.locale) if (this.locale)
this.$i18n.locale = this.locale; this.$i18n.locale = this.locale;
const embeded = [];
this.files.map(file => {
embeded[file] = `file://${__dirname + file}`;
});
this.embeded = embeded;
}, },
data() { data() {
return { return {
client: { client: {
id: 10252, id: 101,
name: 'Batman', name: 'Batman'
}, },
sales: [ files: ['/assets/images/signature.png'],
{id: 1, concept: 'My item 1', quantity: 25},
{id: 2, concept: 'My item 2', quantity: 50},
{id: 3, concept: 'My item 3', quantity: 150}
],
locale: 'es'
}; };
}, },
methods: { methods: {
dated: () => { /* dated: () => {
return strftime('%d-%m-%Y', new Date()); return strftime('%d-%m-%Y', new Date());
}, }, */
}, },
components: { components: {
'report-header': require('../report-header'), 'report-header': require('../report-header'),

View File

@ -1,10 +1,9 @@
module.exports = { module.exports = {
messages: { messages: {
es: { es: {
title: 'Sample report', title: 'Recibo',
date: 'Fecha', date: 'Fecha',
quantity: 'Cantidad', dated: 'En {0}, a {1} de {2} de {3}',
concept: 'Concepto',
client: 'Cliente {0}', client: 'Cliente {0}',
}, },
}, },

View File

@ -3,7 +3,9 @@
<body> <body>
<section class="container"> <section class="container">
<!-- Header component --> <!-- Header component -->
<report-header :locale="locale"></report-header> <report-header id="pageHeader-first"
:locale="locale">
</report-header>
<!-- End header component --> <!-- End header component -->
<section class="main"> <section class="main">
<section class="columns"> <section class="columns">

View File

@ -3,7 +3,9 @@
<body> <body>
<section class="container"> <section class="container">
<!-- Header component --> <!-- Header component -->
<report-header :locale="locale"></report-header> <report-header id="pageHeader-first"
:locale="locale">
</report-header>
<!-- End header component --> <!-- End header component -->
<section class="main"> <section class="main">
<h1 class="title centered">{{$t('title')}}</h1> <h1 class="title centered">{{$t('title')}}</h1>

View File

@ -3,7 +3,9 @@
<body> <body>
<section class="container" id="report"> <section class="container" id="report">
<!-- Header component --> <!-- Header component -->
<report-header :locale="locale"></report-header> <report-header id="pageHeader-first"
:locale="locale">
</report-header>
<!-- End header component --> <!-- End header component -->
<section class="main"> <section class="main">
<!-- Report start --> <!-- Report start -->