2
0
mirror of https://github.com/frappe/books.git synced 2025-01-24 07:38:25 +00:00

fix formatting

This commit is contained in:
Ankit Singhaniya 2021-08-19 00:08:30 +05:30 committed by 18alantom
parent 47abdb5ae3
commit 62359ba7ae

View File

@ -1,7 +1,7 @@
<template> <template>
<div class="border h-full"> <div class="border h-full">
<div> <div>
<div class="px-6 pt-6" v-if="printSettings && accountingSettings"> <div class="px-6 pt-6" v-if="printSettings">
<div class="flex text-sm text-gray-900 border-b pb-4"> <div class="flex text-sm text-gray-900 border-b pb-4">
<div class="w-1/3"> <div class="w-1/3">
<div v-if="printSettings.displayLogo"> <div v-if="printSettings.displayLogo">
@ -11,7 +11,7 @@
/> />
</div> </div>
<div class="text-xl text-gray-700 font-semibold" v-else> <div class="text-xl text-gray-700 font-semibold" v-else>
{{ accountingSettings.companyName }} {{ frappe.AccountingSettings.companyName }}
</div> </div>
</div> </div>
<div class="w-1/3"> <div class="w-1/3">
@ -19,8 +19,10 @@
<div class="mt-1">{{ printSettings.phone }}</div> <div class="mt-1">{{ printSettings.phone }}</div>
</div> </div>
<div class="w-1/3"> <div class="w-1/3">
<div v-if="address">{{ address.addressDisplay }}</div> <div v-if="companyAddress">{{ companyAddress.addressDisplay }}</div>
<div>GSTIN: {{ gstin }}</div> <div v-if="printSettings && printSettings.gstin">
GSTIN: {{ printSettings.gstin }}
</div>
</div> </div>
</div> </div>
</div> </div>
@ -34,55 +36,47 @@
{{ frappe.format(doc.date, 'Date') }} {{ frappe.format(doc.date, 'Date') }}
</div> </div>
</div> </div>
<div class="w-1/3"> <div class="w-1/3" v-if="party">
<div class="py-1 text-right text-lg font-semibold"> <div class="py-1 text-right text-lg font-semibold">
{{ doc[partyField.fieldname] }} {{ party.name }}
</div>
<div v-if="partyDoc" class="mt-1 text-xs text-gray-600 text-right">
{{ partyDoc.addressDisplay }}
</div> </div>
<div <div
v-if="partyDoc && partyDoc.gstin" v-if="party && party.addressDisplay"
class="mt-1 text-xs text-gray-600 text-right" class="mt-1 text-xs text-gray-600 text-right"
> >
GSTIN: {{ partyDoc.gstin }} {{ party.addressDisplay }}
</div>
<div
v-if="party && party.gstin"
class="mt-1 text-xs text-gray-600 text-right"
>
GSTIN: {{ party.gstin }}
</div> </div>
</div> </div>
</div> </div>
</div> </div>
<div class="mt-2 px-6 text-base"> <div class="mt-2 px-6 text-base">
<div> <div>
<Row class="text-gray-600 w-full" :ratio="ratio"> <div class="text-gray-600 w-full flex border-b">
<div class="py-4"> <div class="py-4 w-5/12">Item</div>
{{ _('No') }} <div class="py-4 text-right w-1/12">Quantity</div>
</div> <div class="py-4 text-right w-3/12">Rate</div>
<div <div class="py-4 text-right w-3/12">Amount</div>
class="py-4" </div>
v-for="df in itemFields" <div
:key="df.fieldname" class="flex py-1 text-gray-900 w-full border-b"
:class="textAlign(df)"
>
{{ df.label }}
</div>
</Row>
<Row
class="text-gray-900 w-full"
v-for="row in doc.items" v-for="row in doc.items"
:key="row.name" :key="row.name"
:ratio="ratio"
> >
<div class="py-4"> <div class="w-5/12 py-4">{{ row.item }}</div>
{{ row.idx + 1 }} <div class="w-1/12 text-right py-4">
{{ format(row, 'quantity') }}
</div> </div>
<div <div class="w-3/12 text-right py-4">{{ format(row, 'rate') }}</div>
class="py-4" <div class="w-3/12 text-right py-4">
v-for="df in itemFields" {{ format(row, 'amount') }}
:key="df.fieldname"
:class="textAlign(df)"
>
{{ frappe.format(row[df.fieldname], df) }}
</div> </div>
</Row> </div>
</div> </div>
</div> </div>
</div> </div>
@ -112,60 +106,11 @@
</template> </template>
<script> <script>
import frappe from 'frappejs'; import Base from './Base';
import Row from '@/components/Row';
export default { export default {
name: 'Default', name: 'Default',
props: ['doc', 'printSettings'], extends: Base,
components: { props: ['doc', 'printSettings']
Row
},
data() {
return {
accountingSettings: null
};
},
computed: {
meta() {
return this.doc && this.doc.meta;
},
address() {
return this.printSettings && this.printSettings.getLink('address');
},
gstin() {
return this.printSettings && this.printSettings.gstin;
},
partyDoc() {
return this.doc.getLink(this.partyField.fieldname);
},
partyField() {
let fieldname = {
SalesInvoice: 'customer',
PurchaseInvoice: 'supplier'
}[this.doc.doctype];
return this.meta.getField(fieldname);
},
itemFields() {
let itemsMeta = frappe.getMeta(`${this.doc.doctype}Item`);
return ['item', 'quantity', 'rate', 'amount'].map(fieldname =>
itemsMeta.getField(fieldname)
);
},
ratio() {
return [0.3].concat(this.itemFields.map(() => 1));
}
},
methods: {
textAlign(df) {
return ['Currency', 'Int', 'Float'].includes(df.fieldtype)
? 'text-right'
: '';
}
},
async mounted() {
this.accountingSettings = await frappe.getSingle('AccountingSettings');
await this.doc.loadLink(this.partyField.fieldname);
}
}; };
</script> </script>