stats loading

This commit is contained in:
Elijah McMorris 2024-02-18 04:19:28 -08:00
parent f9afa2501d
commit e4b6b9b86a
Signed by: NexVeridian
SSH key fingerprint: SHA256:bsA1SKZxuEcEVHAy3gY1HUeM5ykRJl0U0kQHQn0hMg8
7 changed files with 30 additions and 20 deletions

View file

@ -9,8 +9,12 @@ export async function querydb() {
order by clicks desc
limit 50;
`);
// @ts-ignore
stats = stats[0];
return stats;
} catch (e) {
return;
return [];
}
}

View file

@ -6,11 +6,7 @@ import {
CardTitle
} from "@/components/ui/card";
export default function GlobalError({
error,
}: {
error: Error & { digest?: string }
}) {
export default function Loading() {
return (
<CardGrid max_rows={1}>
<Card>

View file

@ -1,16 +1,26 @@
"use server";
"use client";
import CardGrid from "@/components/card-grid";
import { Card } from "@/components/ui/card";
import { useEffect, useState } from "react";
import { columns } from "./columns";
import { DataTable } from "./data-table";
import { querydb } from "./db";
import Loading from "./loading";
export default async function StatsPage() {
let data = await querydb();
// @ts-ignore
data = data[0];
export default function StatsPage() {
let [data, setData] = useState([]);
if (data !== undefined) {
useEffect(() => {
const fetchData = async () => {
const result = await querydb();
console.log(result);
// @ts-ignore
setData(result);
};
fetchData();
}, []);
if (data.length !== 0 && data !== undefined && data !== null) {
const formatDate = (dateString: string | number | Date) => {
const date = new Date(dateString);
const day = String(date.getDate()).padStart(2, '0');
@ -19,6 +29,7 @@ export default async function StatsPage() {
return `${month}/${day}/${year}`;
};
// @ts-ignore
data = data.map(item => ({
// @ts-ignore
...item,
@ -31,7 +42,9 @@ export default async function StatsPage() {
}));
}
return (
return data.length === 0 ? (
<Loading />
) : (
<CardGrid max_rows={1}>
<Card>
{/* @ts-ignore */}