2022-10-27 12:59:19 +00:00
|
|
|
<script setup>
|
|
|
|
import { h, onMounted } from 'vue';
|
|
|
|
import axios from 'axios';
|
|
|
|
|
|
|
|
const $props = defineProps({
|
|
|
|
autoLoad: {
|
|
|
|
type: Boolean,
|
|
|
|
default: false,
|
|
|
|
},
|
|
|
|
url: {
|
|
|
|
type: String,
|
|
|
|
default: '',
|
|
|
|
},
|
|
|
|
filter: {
|
|
|
|
type: Object,
|
|
|
|
default: null,
|
|
|
|
},
|
2022-11-02 10:24:21 +00:00
|
|
|
where: {
|
|
|
|
type: Object,
|
|
|
|
default: null,
|
|
|
|
},
|
|
|
|
sortBy: {
|
|
|
|
type: String,
|
|
|
|
default: '',
|
|
|
|
},
|
|
|
|
limit: {
|
|
|
|
type: String,
|
|
|
|
default: '',
|
|
|
|
},
|
2022-10-27 12:59:19 +00:00
|
|
|
});
|
|
|
|
|
2022-10-31 08:34:01 +00:00
|
|
|
const emit = defineEmits(['onFetch']);
|
2022-11-07 12:15:11 +00:00
|
|
|
defineExpose({ fetch });
|
2022-10-27 12:59:19 +00:00
|
|
|
|
|
|
|
onMounted(async () => {
|
|
|
|
if ($props.autoLoad) {
|
|
|
|
await fetch();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
async function fetch() {
|
2022-11-02 10:24:21 +00:00
|
|
|
const filter = Object.assign({}, $props.filter);
|
|
|
|
if ($props.where) filter.where = $props.where;
|
|
|
|
if ($props.sortBy) filter.order = $props.sortBy;
|
|
|
|
if ($props.limit) filter.limit = $props.limit;
|
|
|
|
|
2022-10-27 12:59:19 +00:00
|
|
|
const { data } = await axios.get($props.url, {
|
2022-11-02 10:24:21 +00:00
|
|
|
params: { filter },
|
2022-10-27 12:59:19 +00:00
|
|
|
});
|
|
|
|
|
2022-10-31 08:34:01 +00:00
|
|
|
emit('onFetch', data);
|
2022-10-27 12:59:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const render = () => {
|
|
|
|
return h('div', []);
|
|
|
|
};
|
|
|
|
</script>
|
|
|
|
<template>
|
|
|
|
<render />
|
|
|
|
</template>
|