el.xwx.moe/pages/links/[id].tsx

43 lines
1.2 KiB
TypeScript
Raw Normal View History

2024-08-18 01:55:59 -05:00
import LinkDetails from "@/components/LinkDetails";
import { useGetLink } from "@/hooks/store/links";
import { useRouter } from "next/router";
import { useEffect, useState } from "react";
import getServerSideProps from "@/lib/client/getServerSideProps";
const Index = () => {
const router = useRouter();
const { id } = router.query;
useState;
const getLink = useGetLink();
useEffect(() => {
getLink.mutate({ id: Number(id) });
}, []);
return (
2024-08-28 19:22:11 -05:00
<div className="flex h-screen">
2024-08-18 01:55:59 -05:00
{getLink.data ? (
2024-08-28 19:22:11 -05:00
<LinkDetails
link={getLink.data}
className="sm:max-w-xl sm:m-auto sm:p-5 w-full"
standalone
/>
2024-08-18 01:55:59 -05:00
) : (
2024-08-18 13:45:40 -05:00
<div className="max-w-xl p-5 m-auto w-full flex flex-col items-center gap-5">
2024-08-18 01:55:59 -05:00
<div className="w-20 h-20 skeleton rounded-xl"></div>
<div className="w-full h-10 skeleton rounded-xl"></div>
<div className="w-full h-10 skeleton rounded-xl"></div>
<div className="w-full h-10 skeleton rounded-xl"></div>
<div className="w-full h-10 skeleton rounded-xl"></div>
</div>
)}
</div>
);
};
export default Index;
export { getServerSideProps };