ff-admin/src/views/admin/club/query/Builder.vue

75 lines
2.2 KiB
Vue
Raw Normal View History

2024-12-12 16:34:03 +01:00
<template>
2025-05-16 13:32:40 +02:00
<MainTemplate title="Query Builder">
<template #main>
<BuilderHost
v-model="query"
allow-predefined-select
@query:run="sendQuery"
@query:save="triggerSave"
@results:clear="clearResults"
@results:export="exportData"
/>
<p>Ergebnisse:</p>
<div
v-if="loadingData == 'failed'"
class="flex flex-col p-2 border border-red-600 bg-red-200 rounded-md select-none"
>
<p v-if="typeof queryError == 'string'">
{{ queryError }}
</p>
<div v-else>
<p>
CODE: <br />
{{ queryError.code }}
</p>
<br />
<p>
MSG: <br />
{{ queryError.msg }}
</p>
<br />
<p>
RESULTING SQL: <br />
{{ queryError.sql }}
2024-12-16 17:49:18 +01:00
</p>
</div>
2024-12-12 16:34:03 +01:00
</div>
2025-05-16 13:32:40 +02:00
<Pagination
v-else
:items="data"
:totalCount="totalLength"
:indicateLoading="loadingData == 'loading'"
@load-data="(offset, count) => sendQuery(offset, count)"
>
<template #pageRow="{ row }: { row: { id: FieldType; [key: string]: FieldType } }">
<p>{{ row }}</p>
</template>
</Pagination>
2024-12-12 16:34:03 +01:00
</template>
</MainTemplate>
</template>
<script setup lang="ts">
import { defineComponent } from "vue";
2024-12-16 13:56:06 +01:00
import { mapActions, mapState, mapWritableState } from "pinia";
2024-12-12 16:34:03 +01:00
import MainTemplate from "@/templates/Main.vue";
import Pagination from "@/components/Pagination.vue";
2025-01-02 18:28:13 +01:00
import { useQueryBuilderStore } from "@/stores/admin/club/queryBuilder";
2024-12-26 12:34:36 +01:00
import BuilderHost from "@/components/queryBuilder/BuilderHost.vue";
import type { DynamicQueryStructure, FieldType } from "@/types/dynamicQueries";
2025-02-15 11:08:09 +01:00
import { useQueryStoreStore } from "@/stores/admin/configuration/queryStore";
2024-12-12 16:34:03 +01:00
</script>
<script lang="ts">
export default defineComponent({
computed: {
2025-04-16 16:11:10 +02:00
...mapState(useQueryBuilderStore, ["loading", "loadingData", "data", "totalLength", "queryError"]),
2024-12-16 13:56:06 +01:00
...mapWritableState(useQueryBuilderStore, ["query"]),
2024-12-12 16:34:03 +01:00
},
methods: {
2025-04-16 16:11:10 +02:00
...mapActions(useQueryBuilderStore, ["sendQuery", "clearResults", "exportData"]),
2024-12-18 22:27:44 +01:00
...mapActions(useQueryStoreStore, ["triggerSave"]),
2024-12-12 16:34:03 +01:00
},
});
</script>