2
0
mirror of https://github.com/frappe/books.git synced 2025-01-10 10:16:22 +00:00

fix: minor fixes

This commit is contained in:
akshayitzme 2023-09-06 16:29:38 +05:30 committed by akshayitzme
parent 7e7e3ed3cd
commit ffbce23f03
7 changed files with 55 additions and 73 deletions
backend/database
fyo/core
models/inventory/Point of Sale/tests
src

View File

@ -394,7 +394,8 @@ export class BespokeQueries {
static async getPOSTransactedAmount( static async getPOSTransactedAmount(
db: DatabaseCore, db: DatabaseCore,
fromDate: Date fromDate: Date,
toDate: Date
): Promise<Record<string, Money> | undefined> { ): Promise<Record<string, Money> | undefined> {
const sinvNames = ( const sinvNames = (
await db.knex!(ModelNameEnum.SalesInvoice) await db.knex!(ModelNameEnum.SalesInvoice)
@ -403,7 +404,9 @@ export class BespokeQueries {
.andWhereRaw('datetime(date) > datetime(?)', [ .andWhereRaw('datetime(date) > datetime(?)', [
new Date(fromDate.setHours(0, 0, 0)).toISOString(), new Date(fromDate.setHours(0, 0, 0)).toISOString(),
]) ])
.andWhereRaw('datetime(date) < datetime(?)', [new Date().toISOString()]) .andWhereRaw('datetime(date) < datetime(?)', [
new Date(toDate.setHours(0, 0, 0)).toISOString(),
])
).map((row: { name: string }) => row.name); ).map((row: { name: string }) => row.name);
if (!sinvNames.length) { if (!sinvNames.length) {

View File

@ -344,11 +344,13 @@ export class DatabaseHandler extends DatabaseBase {
} }
async getPOSTransactedAmount( async getPOSTransactedAmount(
fromDate: Date fromDate: Date,
toDate: Date
): Promise<Record<string, Money> | undefined> { ): Promise<Record<string, Money> | undefined> {
return (await this.#demux.callBespoke( return (await this.#demux.callBespoke(
'getPOSTransactedAmount', 'getPOSTransactedAmount',
fromDate fromDate,
toDate
)) as Promise<Record<string, Money> | undefined>; )) as Promise<Record<string, Money> | undefined>;
} }

View File

@ -31,14 +31,15 @@ let sinvDocOne: SalesInvoice | undefined;
test('check pos transacted amount', async (t) => { test('check pos transacted amount', async (t) => {
const transactedAmountBeforeTxn = await fyo.db.getPOSTransactedAmount( const transactedAmountBeforeTxn = await fyo.db.getPOSTransactedAmount(
new Date('2022-01-01') new Date('2023-01-01'),
new Date('2023-01-02')
); );
t.equals(transactedAmountBeforeTxn, undefined); t.equals(transactedAmountBeforeTxn, undefined);
sinvDocOne = fyo.doc.getNewDoc(ModelNameEnum.SalesInvoice, { sinvDocOne = fyo.doc.getNewDoc(ModelNameEnum.SalesInvoice, {
isPOS: true, isPOS: true,
date: new Date('2022-01-02'), date: new Date('2023-01-01'),
account: 'Debtors', account: 'Debtors',
party: customer.name, party: customer.name,
}) as SalesInvoice; }) as SalesInvoice;
@ -56,7 +57,7 @@ test('check pos transacted amount', async (t) => {
const sinvDocTwo = fyo.doc.getNewDoc(ModelNameEnum.SalesInvoice, { const sinvDocTwo = fyo.doc.getNewDoc(ModelNameEnum.SalesInvoice, {
isPOS: true, isPOS: true,
date: new Date('2022-01-02'), date: new Date('2023-01-01'),
account: 'Debtors', account: 'Debtors',
party: customer.name, party: customer.name,
}) as SalesInvoice; }) as SalesInvoice;
@ -72,14 +73,17 @@ test('check pos transacted amount', async (t) => {
await paymentDocTwo.setMultiple({ await paymentDocTwo.setMultiple({
paymentMethod: 'Transfer', paymentMethod: 'Transfer',
clearanceDate: new Date(), clearanceDate: new Date('2023-01-01'),
referenceId: 'xxxxxxxx', referenceId: 'xxxxxxxx',
}); });
await paymentDocTwo.sync(); await paymentDocTwo.sync();
const transactedAmountAfterTxn: Record<string, Money> | undefined = const transactedAmountAfterTxn: Record<string, Money> | undefined =
await fyo.db.getPOSTransactedAmount(new Date('2022-01-02')); await fyo.db.getPOSTransactedAmount(
new Date('2023-01-01'),
new Date('2023-01-02')
);
t.true(transactedAmountAfterTxn); t.true(transactedAmountAfterTxn);

View File

@ -194,7 +194,7 @@
<div class=""></div> <div class=""></div>
<div <div
v-if="row.links && row.links?.item.hasBatch" v-if="row.links?.item && row.links?.item.hasBatch"
class="pl-6 px-4 pt-6 col-span-2" class="pl-6 px-4 pt-6 col-span-2"
> >
<Link <Link
@ -213,7 +213,7 @@
</div> </div>
<div <div
v-if="row.links && row.links?.item.hasBatch" v-if="row.links?.item && row.links?.item.hasBatch"
class="px-2 pt-6 col-span-2" class="px-2 pt-6 col-span-2"
> >
<Float <Float
@ -233,7 +233,7 @@
</div> </div>
<div <div
v-if="row.links && row.links?.item.hasSerialNumber" v-if="row.links?.item && row.links?.item.hasSerialNumber"
class="px-2 pt-8 col-span-2" class="px-2 pt-8 col-span-2"
> >
<Text <Text

View File

@ -109,7 +109,10 @@ export default defineComponent({
return; return;
} }
const fromDate = fyo.singles.POSShift?.openingDate; const fromDate = fyo.singles.POSShift?.openingDate;
this.transactedAmount = await fyo.db.getPOSTransactedAmount(fromDate); this.transactedAmount = await fyo.db.getPOSTransactedAmount(
fromDate,
new Date()
);
}, },
seedClosingCash() { seedClosingCash() {
if (!this.posShiftDoc) { if (!this.posShiftDoc) {

View File

@ -26,6 +26,7 @@
@set-cash-amount="setCashAmount" @set-cash-amount="setCashAmount"
@set-transfer-amount="setTransferAmount" @set-transfer-amount="setTransferAmount"
@set-transfer-ref-no="setTransferRefNo" @set-transfer-ref-no="setTransferRefNo"
@set-transfer-clearance-date="setTransferClearanceDate"
/> />
<div <div
@ -58,8 +59,8 @@
<div class="flex flex-col gap-3" style="height: calc(100vh - 6rem)"> <div class="flex flex-col gap-3" style="height: calc(100vh - 6rem)">
<div class="bg-white border grow h-full p-4 rounded-md"> <div class="bg-white border grow h-full p-4 rounded-md">
<!-- Customer Search --> <!-- Customer Search -->
<Link <Link
v-if="sinvDoc.fieldMap"
class="flex-shrink-0" class="flex-shrink-0"
:border="true" :border="true"
:value="sinvDoc.party" :value="sinvDoc.party"
@ -116,11 +117,8 @@
:text-right="true" :text-right="true"
/> />
<FloatingLabelCurrencyInput <FloatingLabelCurrencyInput
:df="{ v-if="sinvDoc.fieldMap"
label: t`Total`, :df="sinvDoc.fieldMap.grandTotal"
fieldtype: 'Currency',
fieldname: 'total',
}"
size="large" size="large"
:value="sinvDoc.grandTotal" :value="sinvDoc.grandTotal"
:read-only="true" :read-only="true"
@ -212,8 +210,8 @@ export default defineComponent({
}, },
provide() { provide() {
return { return {
doc: computed(() => this.sinvDoc),
cashAmount: computed(() => this.cashAmount), cashAmount: computed(() => this.cashAmount),
doc: computed(() => this.sinvDoc),
isDiscountingEnabled: computed(() => this.isDiscountingEnabled), isDiscountingEnabled: computed(() => this.isDiscountingEnabled),
itemDiscounts: computed(() => this.itemDiscounts), itemDiscounts: computed(() => this.itemDiscounts),
itemQtyMap: computed(() => this.itemQtyMap), itemQtyMap: computed(() => this.itemQtyMap),
@ -221,6 +219,7 @@ export default defineComponent({
sinvDoc: computed(() => this.sinvDoc), sinvDoc: computed(() => this.sinvDoc),
totalTaxedAmount: computed(() => this.totalTaxedAmount), totalTaxedAmount: computed(() => this.totalTaxedAmount),
transferAmount: computed(() => this.transferAmount), transferAmount: computed(() => this.transferAmount),
transferClearanceDate: computed(() => this.transferClearanceDate),
transferRefNo: computed(() => this.transferRefNo), transferRefNo: computed(() => this.transferRefNo),
}; };
}, },

View File

@ -1,13 +1,9 @@
<template> <template>
<Modal class="w-2/6 ml-auto mr-3.5" :set-close-listener="false"> <Modal class="w-2/6 ml-auto mr-3.5" :set-close-listener="false">
<div class="px-4 py-6 grid" style="height: 95vh"> <div v-if="sinvDoc.fieldMap" class="px-4 py-6 grid" style="height: 95vh">
<div class="grid grid-cols-2 gap-6"> <div class="grid grid-cols-2 gap-6">
<Currency <Currency
:df="{ :df="fyo.fieldMap.PaymentFor.amount"
label: t`Cash`,
fieldtype: 'Currency',
fieldname: 'cash',
}"
:read-only="!transferAmount.isZero()" :read-only="!transferAmount.isZero()"
:border="true" :border="true"
:text-right="true" :text-right="true"
@ -27,11 +23,7 @@
</Button> </Button>
<Currency <Currency
:df="{ :df="fyo.fieldMap.PaymentFor.amount"
label: t`Transfer`,
fieldtype: 'Currency',
fieldname: 'transfer',
}"
:read-only="!cashAmount.isZero()" :read-only="!cashAmount.isZero()"
:border="true" :border="true"
:text-right="true" :text-right="true"
@ -54,11 +46,7 @@
<div class="mt-8 grid grid-cols-2 gap-6"> <div class="mt-8 grid grid-cols-2 gap-6">
<Data <Data
v-show="!transferAmount.isZero()" v-show="!transferAmount.isZero()"
:df="{ :df="fyo.fieldMap.Payment.referenceId"
label: t`Transfer Ref No.`,
fieldtype: 'Data',
fieldname: 'transferRefNo',
}"
:show-label="true" :show-label="true"
:border="true" :border="true"
:required="!transferAmount.isZero()" :required="!transferAmount.isZero()"
@ -68,14 +56,11 @@
<Date <Date
v-show="!transferAmount.isZero()" v-show="!transferAmount.isZero()"
:df="{ :df="fyo.fieldMap.Payment.clearanceDate"
label: t`Clearance Date`,
fieldtype: 'Date',
fieldname: 'transferClearanceDate',
}"
:show-label="true" :show-label="true"
:border="true" :border="true"
:required="!transferAmount.isZero()" :required="!transferAmount.isZero()"
:value="transferClearanceDate"
@change="(value:Date) => $emit('setTransferClearanceDate', value)" @change="(value:Date) => $emit('setTransferClearanceDate', value)"
/> />
</div> </div>
@ -114,11 +99,7 @@
class="mb-14 row-start-4 row-span-2 grid grid-cols-2 gap-x-6 gap-y-11" class="mb-14 row-start-4 row-span-2 grid grid-cols-2 gap-x-6 gap-y-11"
> >
<Currency <Currency
:df="{ :df="sinvDoc.fieldMap.netTotal"
label: t`Net Total`,
fieldtype: 'Currency',
fieldname: 'netTotal',
}"
:read-only="true" :read-only="true"
:show-label="true" :show-label="true"
:border="true" :border="true"
@ -140,11 +121,7 @@
/> />
<Currency <Currency
:df="{ :df="sinvDoc.fieldMap.baseGrandTotal"
label: t`Total Amount`,
fieldtype: 'Currency',
fieldname: 'totalAmount',
}"
:read-only="true" :read-only="true"
:show-label="true" :show-label="true"
:border="true" :border="true"
@ -154,11 +131,7 @@
<Currency <Currency
v-if="isDiscountingEnabled" v-if="isDiscountingEnabled"
:df="{ :df="sinvDoc.fieldMap.discountAmount"
label: t`Discount Amount`,
fieldtype: 'Currency',
fieldname: 'discountAmount',
}"
:read-only="true" :read-only="true"
:show-label="true" :show-label="true"
:border="true" :border="true"
@ -167,11 +140,7 @@
/> />
<Currency <Currency
:df="{ :df="sinvDoc.fieldMap.grandTotal"
label: t`Grand Total`,
fieldtype: 'Currency',
fieldname: 'grandTotal',
}"
:read-only="true" :read-only="true"
:show-label="true" :show-label="true"
:border="true" :border="true"
@ -262,6 +231,7 @@ export default defineComponent({
transferAmount: inject('transferAmount') as Money, transferAmount: inject('transferAmount') as Money,
sinvDoc: inject('sinvDoc') as SalesInvoice, sinvDoc: inject('sinvDoc') as SalesInvoice,
transferRefNo: inject('transferRefNo') as string, transferRefNo: inject('transferRefNo') as string,
transferClearanceDate: inject('transferClearanceDate') as Date,
totalTaxedAmount: inject('totalTaxedAmount') as Money, totalTaxedAmount: inject('totalTaxedAmount') as Money,
}; };
}, },
@ -273,15 +243,16 @@ export default defineComponent({
return grandTotal.sub(this.transferAmount); return grandTotal.sub(this.transferAmount);
} }
if (this.transferAmount.isZero()) { return grandTotal.sub(this.cashAmount);
return grandTotal.sub(this.cashAmount);
}
const totalPaidAmount = this.cashAmount.add(this.transferAmount);
return grandTotal.sub(totalPaidAmount);
}, },
paidChange(): Money { paidChange(): Money {
return this.cashAmount.sub(this.sinvDoc?.grandTotal ?? fyo.pesa(0)); const grandTotal = this.sinvDoc?.grandTotal ?? fyo.pesa(0);
if (this.cashAmount.isZero()) {
return this.transferAmount.sub(grandTotal);
}
return this.cashAmount.sub(grandTotal);
}, },
showBalanceAmount(): boolean { showBalanceAmount(): boolean {
if ( if (
@ -309,15 +280,15 @@ export default defineComponent({
return false; return false;
} }
if (this.cashAmount.lt(this.sinvDoc?.grandTotal ?? fyo.pesa(0))) { if (this.cashAmount.gt(this.sinvDoc?.grandTotal ?? fyo.pesa(0))) {
return false; return true;
} }
if (this.transferAmount.gte(this.sinvDoc?.grandTotal ?? fyo.pesa(0))) { if (this.transferAmount.gt(this.sinvDoc?.grandTotal ?? fyo.pesa(0))) {
return false; return true;
} }
return true; return false;
}, },
}, },
methods: { methods: {