created a route for public collections

This commit is contained in:
Daniel
2023-05-29 23:10:23 +03:30
parent 271231120c
commit 7f9b0d8977
7 changed files with 117 additions and 6 deletions
+24
View File
@@ -0,0 +1,24 @@
// Copyright (C) 2022-present Daniel31x13 <daniel31x13@gmail.com>
// This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 3.
// This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
// You should have received a copy of the GNU General Public License along with this program. If not, see <https://www.gnu.org/licenses/>.
import getCollection from "@/lib/api/controllers/public/getCollection";
import type { NextApiRequest, NextApiResponse } from "next";
export default async function (req: NextApiRequest, res: NextApiResponse) {
const collectionId = Number(req.query.collectionId);
if (!collectionId) {
return res
.status(401)
.json({ response: "Please choose a valid collection." });
}
if (req.method === "GET") {
const collection = await getCollection(collectionId);
return res
.status(collection.status)
.json({ response: collection.response });
}
}
+26 -2
View File
@@ -1,5 +1,29 @@
import React from "react";
import getPublicCollectionData from "@/lib/client/getPublicCollectionData";
import { PublicCollectionIncludingLinks } from "@/types/global";
import { useRouter } from "next/router";
import React, { useEffect, useState } from "react";
export default function PublicCollections() {
return <div>Hello</div>;
const router = useRouter();
const [data, setData] = useState<PublicCollectionIncludingLinks>();
useEffect(() => {
const init = async () => {
if (router.query.id) {
const data = await getPublicCollectionData(router.query.id as string);
setData(data);
}
};
init();
}, []);
return (
<div>
<p>Hello</p>
{JSON.stringify(data)}
</div>
);
}