Statement Sync

This commit is contained in:
2026-01-01 15:52:05 +01:00
parent 8db4ad2203
commit fb746b4d59

View File

@@ -1,11 +1,12 @@
<script setup> <script setup>
import dayjs from "dayjs"; import dayjs from "dayjs";
// Zugriff auf $api und Toast Notification
const { $api } = useNuxtApp()
const toast = useToast()
defineShortcuts({ defineShortcuts({
'/': () => { '/': () => {
//console.log(searchinput)
//searchinput.value.focus()
document.getElementById("searchinput").focus() document.getElementById("searchinput").focus()
} }
}) })
@@ -18,6 +19,8 @@ const bankstatements = ref([])
const bankaccounts = ref([]) const bankaccounts = ref([])
const filterAccount = ref([]) const filterAccount = ref([])
// Status für den Lade-Button
const isSyncing = ref(false)
const setupPage = async () => { const setupPage = async () => {
bankstatements.value = (await useEntities("bankstatements").select("*, statementallocations(*)", "date", false)) bankstatements.value = (await useEntities("bankstatements").select("*, statementallocations(*)", "date", false))
@@ -25,6 +28,34 @@ const setupPage = async () => {
if(bankaccounts.value.length > 0) filterAccount.value = bankaccounts.value if(bankaccounts.value.length > 0) filterAccount.value = bankaccounts.value
} }
// Funktion für den Bankabruf
const syncBankStatements = async () => {
isSyncing.value = true
try {
await $api('/api/functions/services/bankstatementsync', { method: 'POST' })
toast.add({
title: 'Erfolg',
description: 'Bankdaten wurden erfolgreich synchronisiert.',
icon: 'i-heroicons-check-circle',
color: 'green'
})
// Wichtig: Daten neu laden, damit die neuen Buchungen direkt sichtbar sind
await setupPage()
} catch (error) {
console.error(error)
toast.add({
title: 'Fehler',
description: 'Beim Abrufen der Bankdaten ist ein Fehler aufgetreten.',
icon: 'i-heroicons-exclamation-circle',
color: 'red'
})
} finally {
isSyncing.value = false
}
}
const templateColumns = [ const templateColumns = [
{ {
key: "account", key: "account",
@@ -100,9 +131,6 @@ const filteredRows = computed(() => {
} }
} }
return useSearch(searchString.value, temp.filter(i => filterAccount.value.find(x => x.id === i.account))) return useSearch(searchString.value, temp.filter(i => filterAccount.value.find(x => x.id === i.account)))
}) })
@@ -112,6 +140,17 @@ setupPage()
<template> <template>
<UDashboardNavbar title="Bankbuchungen" :badge="filteredRows.length"> <UDashboardNavbar title="Bankbuchungen" :badge="filteredRows.length">
<template #right> <template #right>
<UButton
label="Bankabruf"
icon="i-heroicons-arrow-path"
color="primary"
variant="solid"
:loading="isSyncing"
@click="syncBankStatements"
class="mr-2"
/>
<UInput <UInput
id="searchinput" id="searchinput"
name="searchinput" name="searchinput"
@@ -152,19 +191,6 @@ setupPage()
</USelectMenu> </USelectMenu>
</template> </template>
<template #right> <template #right>
<!-- <USelectMenu
v-model="selectedColumns"
icon="i-heroicons-adjustments-horizontal-solid"
:options="templateColumns"
multiple
class="hidden lg:block"
by="key"
:ui-menu="{ width: 'min-w-max' }"
>
<template #label>
Spalten
</template>
</USelectMenu>-->
<USelectMenu <USelectMenu
icon="i-heroicons-adjustments-horizontal-solid" icon="i-heroicons-adjustments-horizontal-solid"
multiple multiple
@@ -221,12 +247,8 @@ setupPage()
</span> </span>
</template> </template>
</UTable> </UTable>
</template> </template>
<style scoped> <style scoped>
</style> </style>