mirror of
https://github.com/Litlyx/litlyx
synced 2025-12-10 07:48:37 +01:00
add csv for visits
This commit is contained in:
@@ -12,10 +12,11 @@ const columns = [
|
|||||||
{ key: 'website', label: 'Website', sortable: true },
|
{ key: 'website', label: 'Website', sortable: true },
|
||||||
{ key: 'page', label: 'Page', sortable: true },
|
{ key: 'page', label: 'Page', sortable: true },
|
||||||
{ key: 'referrer', label: 'Referrer', sortable: true },
|
{ key: 'referrer', label: 'Referrer', sortable: true },
|
||||||
{ key: 'session', label: 'Session', sortable: true },
|
|
||||||
{ key: 'browser', label: 'Browser', sortable: true },
|
{ key: 'browser', label: 'Browser', sortable: true },
|
||||||
{ key: 'os', label: 'OS', sortable: true },
|
{ key: 'os', label: 'OS', sortable: true },
|
||||||
{ key: 'screen', label: 'Screen', sortable: true },
|
{ key: 'continent', label: 'Continent', sortable: true },
|
||||||
|
{ key: 'country', label: 'Country', sortable: true },
|
||||||
|
{ key: 'device', label: 'Device', sortable: true },
|
||||||
{ key: 'created_at', label: 'Date', sortable: true }
|
{ key: 'created_at', label: 'Date', sortable: true }
|
||||||
]
|
]
|
||||||
|
|
||||||
@@ -42,6 +43,23 @@ onMounted(async () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
const creatingCsv = ref<boolean>(false);
|
||||||
|
|
||||||
|
async function downloadCSV() {
|
||||||
|
creatingCsv.value = true;
|
||||||
|
const result = await $fetch(`/api/project/generate_csv?mode=visits`, signHeaders());
|
||||||
|
const blob = new Blob([result], { type: 'text/csv' });
|
||||||
|
const url = window.URL.createObjectURL(blob);
|
||||||
|
const a = document.createElement('a');
|
||||||
|
a.href = url;
|
||||||
|
a.download = 'ReportVisits.csv';
|
||||||
|
document.body.appendChild(a);
|
||||||
|
a.click();
|
||||||
|
document.body.removeChild(a);
|
||||||
|
window.URL.revokeObjectURL(url);
|
||||||
|
creatingCsv.value = false;
|
||||||
|
}
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
|
||||||
@@ -50,8 +68,15 @@ onMounted(async () => {
|
|||||||
|
|
||||||
<div class="w-full h-dvh flex flex-col">
|
<div class="w-full h-dvh flex flex-col">
|
||||||
|
|
||||||
|
<div v-if="creatingCsv"
|
||||||
|
class="fixed z-[100] flex items-center justify-center left-0 top-0 w-full h-full bg-black/60 backdrop-blur-[4px]">
|
||||||
|
<div class="poppins text-[2rem]">
|
||||||
|
Creating csv...
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="flex justify-end px-12 py-3">
|
<div class="flex justify-end px-12 py-3">
|
||||||
<div
|
<div @click="downloadCSV()"
|
||||||
class="bg-[#57c78fc0] hover:bg-[#57c78fab] cursor-pointer text-text poppins font-semibold px-8 py-2 rounded-lg">
|
class="bg-[#57c78fc0] hover:bg-[#57c78fab] cursor-pointer text-text poppins font-semibold px-8 py-2 rounded-lg">
|
||||||
Download CSV
|
Download CSV
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
import { ProjectModel } from "@schema/ProjectSchema";
|
import { ProjectModel } from "@schema/ProjectSchema";
|
||||||
import { UserSettingsModel } from "@schema/UserSettings";
|
import { UserSettingsModel } from "@schema/UserSettings";
|
||||||
import { EventModel } from '@schema/metrics/EventSchema';
|
import { EventModel } from '@schema/metrics/EventSchema';
|
||||||
|
import { VisitModel } from "@schema/metrics/VisitSchema";
|
||||||
|
|
||||||
|
|
||||||
export default defineEventHandler(async event => {
|
export default defineEventHandler(async event => {
|
||||||
@@ -17,20 +18,45 @@ export default defineEventHandler(async event => {
|
|||||||
const project = await ProjectModel.findById(project_id);
|
const project = await ProjectModel.findById(project_id);
|
||||||
if (!project) return setResponseStatus(event, 400, 'Project not found');
|
if (!project) return setResponseStatus(event, 400, 'Project not found');
|
||||||
|
|
||||||
|
const { mode } = getQuery(event);
|
||||||
|
|
||||||
const eventsReportData = await EventModel.find({
|
if (mode === 'visits') {
|
||||||
project_id: project._id,
|
|
||||||
created_at: { $gt: Date.now() - 1000 * 60 * 60 * 24 * 7 + 30 }
|
const visistsReportData = await VisitModel.find({
|
||||||
|
project_id,
|
||||||
|
created_at: {
|
||||||
|
$gt: Date.now() - 1000 * 60 * 60 * 24 * 7
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
const csvLines: string[][] = [['name']];
|
const csvHeader = [
|
||||||
eventsReportData.forEach(e => {
|
"browser",
|
||||||
csvLines.push([e.name])
|
"os",
|
||||||
});
|
"continent",
|
||||||
|
"country",
|
||||||
|
"device",
|
||||||
|
"website",
|
||||||
|
"page",
|
||||||
|
"referrer",
|
||||||
|
"created_at",
|
||||||
|
];
|
||||||
|
|
||||||
return csvLines.map(row => {
|
|
||||||
return row.join(',');
|
const lines: any[] = [];
|
||||||
|
visistsReportData.forEach(line => lines.push(line.toJSON()));
|
||||||
|
|
||||||
|
const result = csvHeader.join(',') + '\n' + lines.map(element => {
|
||||||
|
const content: string[] = [];
|
||||||
|
for (const key of csvHeader) {
|
||||||
|
content.push(element[key]);
|
||||||
|
}
|
||||||
|
return content.join(',');
|
||||||
}).join('\n');
|
}).join('\n');
|
||||||
|
|
||||||
|
return result;
|
||||||
|
} else {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
});
|
});
|
||||||
Reference in New Issue
Block a user