[balance] fix sort in overview

This commit is contained in:
Tim Gröger 2021-04-17 20:37:21 +02:00
parent a8a6cd8814
commit a83ba72cfa
5 changed files with 30 additions and 38 deletions

View File

@ -1,5 +1,5 @@
<template> <template>
<q-card-section class="fit row justify-left content-center items-center q-col-gutter-sm"> <q-card-section class="fit row justify-between content-center items-center q-col-gutter-sm">
<div class="col-5"> <div class="col-5">
<div v-if="balance" class="text-h6"> <div v-if="balance" class="text-h6">
Aktueller Stand: {{ balance.balance.toFixed(2) }} Aktueller Stand: {{ balance.balance.toFixed(2) }}
@ -10,7 +10,7 @@
<div v-if="showSelector" class="col-6"> <div v-if="showSelector" class="col-6">
<UserSelector v-model="user" /> <UserSelector v-model="user" />
</div> </div>
<div class="col-1 justify-end"> <div class="col-1 justify-end text-right">
<q-btn round flat icon="mdi-format-list-checks" @click="openHistory" /> <q-btn round flat icon="mdi-format-list-checks" @click="openHistory" />
</div> </div>
</q-card-section> </q-card-section>

View File

@ -16,7 +16,7 @@
<q-btn <q-btn
:color="isReversed ? 'positive' : 'negative'" :color="isReversed ? 'positive' : 'negative'"
aria-label="Reverse transaction" aria-label="Reverse transaction"
:icon="!isReversed ? 'mdi-trash-can' : 'mdi-check-bold'" :icon="!isReversed ? 'mdi-delete' : 'mdi-check-bold'"
size="sm" size="sm"
round round
:disable="!canReverse" :disable="!canReverse"

View File

@ -32,28 +32,28 @@ export default defineComponent({
field: 'userid', field: 'userid',
required: true, required: true,
align: 'left', align: 'left',
sortable: true sortable: true,
}, },
{ {
name: 'credit', name: 'credit',
label: 'Haben', label: 'Haben',
field: 'credit', field: 'credit',
format: (val: number) => val.toFixed(2) format: (val: number) => val.toFixed(2),
}, },
{ {
name: 'debit', name: 'debit',
label: 'Soll', label: 'Soll',
field: 'debit', field: 'debit',
format: (val: number) => val.toFixed(2) format: (val: number) => val.toFixed(2),
}, },
{ {
name: 'balance', name: 'balance',
label: 'Kontostand', label: 'Kontostand',
format: (_: undefined, row: { debit: number; credit: number }) => format: (_: undefined, row: { debit: number; credit: number }) =>
(row.credit - row.debit).toFixed(2) (row.credit - row.debit).toFixed(2),
} },
]; ];
return { rows, columns }; return { rows, columns };
} },
}); });
</script> </script>

View File

@ -1,6 +1,6 @@
<template> <template>
<q-page padding> <q-page>
<q-card> <q-card flat>
<q-card-section class="text-center"> <q-card-section class="text-center">
<div class="text-h4">Aktueller Stand</div> <div class="text-h4">Aktueller Stand</div>
<div style="font-size: 2em">{{ balance.toFixed(2) }}&#8239;</div> <div style="font-size: 2em">{{ balance.toFixed(2) }}&#8239;</div>
@ -17,8 +17,12 @@
binary-state-sort binary-state-sort
@request="onRequest" @request="onRequest"
> >
<template #top> <template #top="props">
<q-toggle v-model="showCancelled" label="Stornierte einblenden" /> <q-toggle
v-model="showCancelled"
label="Stornierte einblenden"
@update:model-value="onRequest({ pagination: props.pagination })"
/>
</template> </template>
<template #body-cell="props"> <template #body-cell="props">
<q-td :props="props" :class="{ 'bg-grey': props.row.reversal_id != null }"> <q-td :props="props" :class="{ 'bg-grey': props.row.reversal_id != null }">
@ -50,7 +54,7 @@ export default defineComponent({
void userStore.getUsers().then(() => void userStore.getUsers().then(() =>
onRequest({ onRequest({
pagination: pagination.value, pagination: pagination.value,
filter: undefined filter: undefined,
}) })
); );
}); });
@ -60,10 +64,10 @@ export default defineComponent({
const loading = ref(false); const loading = ref(false);
const pagination = ref({ const pagination = ref({
sortBy: 'time', sortBy: 'time',
descending: false, descending: true,
page: 1, page: 1,
rowsPerPage: 3, rowsPerPage: 10,
rowsNumber: 10 rowsNumber: 10,
}); });
interface PaginationInterface { interface PaginationInterface {
@ -87,7 +91,8 @@ export default defineComponent({
offset: startRow, offset: startRow,
limit: fetchCount, limit: fetchCount,
showCancelled: showCancelled.value, showCancelled: showCancelled.value,
showReversals: false showReversals: false,
descending,
}); });
// clear out existing data and add new // clear out existing data and add new
data.value.splice(0, data.value.length, ...result.transactions); data.value.splice(0, data.value.length, ...result.transactions);
@ -112,7 +117,7 @@ export default defineComponent({
field: 'time', field: 'time',
required: true, required: true,
sortable: true, sortable: true,
format: (val: Date) => formatDateTime(new Date(val), true, true, true) format: (val: Date) => formatDateTime(new Date(val), true, true, true),
}, },
{ {
name: 'type', name: 'type',
@ -126,27 +131,13 @@ export default defineComponent({
else return 'Gesendet an X'; else return 'Gesendet an X';
} }
} }
} },
},
{
name: 'text',
label: 'Text',
format: (_: undefined, row: FG.Transaction) => {
if (row.sender_id == null) return 'Gutschrift';
else {
if (row.receiver_id == null) return 'Angeschrieben';
else {
if (row.receiver_id === mainStore.currentUser.userid) return 'Bekommen von X';
else return 'Gesendet an X';
}
}
}
}, },
{ {
name: 'amount', name: 'amount',
label: 'Betrag', label: 'Betrag',
field: 'amount', field: 'amount',
format: (val: number) => `${val.toFixed(2)}` format: (val: number) => `${val.toFixed(2)}`,
}, },
{ {
name: 'author_id', name: 'author_id',
@ -156,11 +147,11 @@ export default defineComponent({
const user = userStore.users.filter((x) => x.userid == val); const user = userStore.users.filter((x) => x.userid == val);
if (user.length > 0) return user[0].display_name; if (user.length > 0) return user[0].display_name;
else return val; else return val;
} },
} },
]; ];
return { data, pagination, onRequest, loading, balance, columns, showCancelled }; return { data, pagination, onRequest, loading, balance, columns, showCancelled };
} },
}); });
</script> </script>

View File

@ -136,6 +136,7 @@ export const useBalanceStore = defineStore({
to?: Date; to?: Date;
showReversals?: boolean; showReversals?: boolean;
showCancelled?: boolean; showCancelled?: boolean;
descending?: boolean;
} }
| undefined = undefined | undefined = undefined
) { ) {