mirror of
https://github.com/Litlyx/litlyx
synced 2025-12-10 15:58:38 +01:00
59 lines
1.7 KiB
Vue
59 lines
1.7 KiB
Vue
<script lang="ts" setup>
|
|
|
|
import type { IconProvider } from '../BarCard/Base.vue';
|
|
|
|
function iconProvider(e: { _id: string, flag: string, count: number }): ReturnType<IconProvider> {
|
|
if (!e.flag) return ['icon', 'far fa-question']
|
|
return [
|
|
'img',
|
|
`https://raw.githubusercontent.com/hampusborgos/country-flags/main/png250px/${e.flag.toLowerCase()}.png`
|
|
]
|
|
}
|
|
|
|
const customIconStyle = `width: 2rem; padding: 1px;`
|
|
|
|
const geolocationData = useFetch('/api/data/countries', {
|
|
headers: useComputedHeaders({ limit: 10, }), lazy: true,
|
|
transform: (e) => {
|
|
if (!e) return e;
|
|
return e.map(k => {
|
|
return { ...k, flag: k._id, _id: getCountryName(k._id) ?? k._id }
|
|
})
|
|
}
|
|
});
|
|
|
|
|
|
const { showDialog, dialogBarData, isDataLoading } = useBarCardDialog();
|
|
|
|
async function showMore() {
|
|
dialogBarData.value = [];
|
|
showDialog.value = true;
|
|
isDataLoading.value = true;
|
|
|
|
const res = await $fetch('/api/data/countries', {
|
|
headers: useComputedHeaders({ limit: 1000 }).value
|
|
});
|
|
|
|
dialogBarData.value = res?.map(k => {
|
|
return { ...k, flag: k._id, _id: getCountryName(k._id) ?? k._id }
|
|
}).map(e => {
|
|
return { ...e, icon: iconProvider(e) }
|
|
}) || [];
|
|
|
|
isDataLoading.value = false;
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
|
|
<template>
|
|
<div class="flex flex-col gap-2">
|
|
<BarCardBase @showMore="showMore()" @dataReload="geolocationData.refresh()"
|
|
:data="geolocationData.data.value || []" :dataIcons="false" :loading="geolocationData.pending.value"
|
|
label="Countries" sub-label="Countries" :iconProvider="iconProvider" :customIconStyle="customIconStyle"
|
|
desc=" Lists the countries where users access your website.">
|
|
</BarCardBase>
|
|
</div>
|
|
</template>
|