Skip to content

Commit

Permalink
Fixed GraphQL API calls
Browse files Browse the repository at this point in the history
Signed-off-by: Akash Singh <[email protected]>
  • Loading branch information
SkySingh04 committed May 8, 2024
1 parent 9f3f2a8 commit 60f9733
Show file tree
Hide file tree
Showing 2 changed files with 85 additions and 100 deletions.
177 changes: 84 additions & 93 deletions frontend/app/blogs/[blogid]/page.tsx
Original file line number Diff line number Diff line change
@@ -1,134 +1,124 @@
'use client'
import React, { useEffect, useState } from 'react';
import Header from '../../components/Header';
import { usePathname } from 'next/navigation';
import Comments from '../../components/Comments';
import CommentForm from '../../components/CommentForm';
import Markdown from 'react-markdown';
import { usePathname } from 'next/navigation'
import Comments from '../../components/Comments'
import CommentForm from '../../components/CommentForm'
import Markdown from 'react-markdown'
import Likes from '@/app/components/Likes';
import DeleteDialogueBox from '../../components/DeleteDialogueBox';
import { auth } from '../../firebase';
import { onAuthStateChanged } from 'firebase/auth';
import { useQuery, gql } from '@apollo/client';
import DeleteDialogueBox from "../../components/DeleteDialogueBox";
import { auth } from "../../firebase";
import { onAuthStateChanged } from "firebase/auth";
import SpotifyCard from '@/app/components/SpotifyCard';

//REST API URL
const usersAPI = process.env.NEXT_PUBLIC_USERS_API_URL;
const blogsAPI = process.env.NEXT_PUBLIC_BLOGS_API_URL;

//GraphQL queries
const GET_BLOG_BY_ID = gql`
query GetBlogById($blogId: ID!) {
blogPost(BlogID: $blogId) {
id
title
content
created_at
subtitle
image
uploadedImageLink
spotifyLink
user {
id
username
}
}
}
`;

const GET_USER_BY_ID = gql`
query GetUserById($userId: ID!) {
user(UserID: $userId) {
id
username
}
}
`;

const formatDate = (timestamp: string): string => {
const date = new Date(timestamp);
const day = date.getDate();
const month = date.toLocaleString("default", { month: "short" });
const year = date.getFullYear().toString().slice(-2);
return `${day} ${month} ${year}`;
};
const getUserById = async (id: number) => {
const response = await fetch(`${usersAPI}/users/${id}`);
const data = await response.json();
return data;
}
const Page = () => {
const [isVisibleLikes, setIsVisibleLikes] = useState(true);
const [isVisibleDeleteButton, setIsVisibleDeleteButton] = useState(true);
const [isVisibleCommentsSection, setIsVisibleCommentsSection] = useState(true);
const [loggedInUserId, setLoggedInUserId] = useState<any>(null);
const [isVisible, setIsVisible] = useState(false);
const pathname = usePathname();
const blogid = pathname.split('/').pop();

// Fetch blog post data
const { loading: blogLoading, error: blogError, data: blogData } = useQuery(GET_BLOG_BY_ID, {
variables: { blogId: blogid },
});

// Fetch user data
const { loading: userLoading, error: userError, data: userData } = useQuery(GET_USER_BY_ID, {
variables: { userId: blogData?.blogPost?.user?.id },
});


useEffect(() => {
onAuthStateChanged(auth, async (user) => {
if (!user) {
setIsVisibleLikes(false);
setIsVisibleDeleteButton(false);
setIsVisibleCommentsSection(false);
} else {
console.log('User logged in successfully');
try {
const userEmail = user.email;
const userIdResponse = await fetch(`${usersAPI}/users/email/${userEmail}`);
const userIdData = await userIdResponse.json();
const userid = userIdData.ID;
setLoggedInUserId(userid);
setIsVisibleLikes(true);
setIsVisibleDeleteButton(true);
setIsVisibleCommentsSection(true);
} catch (error) {
console.error(error);
}
}
else{
console.log("User logged in successfully");
try{
const userEmail = user.email;
const userId = await fetch(`${usersAPI}/users/email/${userEmail}`, {
method: "GET",
headers: {
"Content-Type": "application/json",
},
});
const data = await userId.json();
const userid = data.ID;
setLoggedInUserId(userid);

setIsVisibleLikes(true);
setIsVisibleDeleteButton(true);
setIsVisibleCommentsSection(true);
} catch (error) {
console.error(error);
}
}
});
}, [auth]);

if (blogLoading || userLoading) return <div>Loading...</div>;
if (blogError || userError) return <div>Error: {blogError && blogError.message || userError && userError.message}</div>;

const blog = blogData.blogPost;
const user = userData.user;
} , [auth])

const pathname = usePathname();
const blogid = pathname.split('/').pop();
const [blog, setBlog] = useState<any>(null);
const [user, setUser] = useState<any>(null);
const [userId, setUserId] = useState<any>(null);
const [isVisible, setIsVisible] = useState(false);

// Function to open delete dialogue
const openDelete = () => {
setIsVisible(true);
};
}

// Format date function
const formatDate = (timestamp : any) => {
const date = new Date(timestamp);
const day = date.getDate();
const month = date.toLocaleString('default', { month: 'short' });
const year = date.getFullYear().toString().slice(-2);
return `${day} ${month} ${year}`;
};
useEffect(() => {
const fetchBlog = async () => {
try {
const response = await fetch(`${blogsAPI}/blogs/${blogid}`);
if (!response.ok) {
throw new Error('Failed to fetch blog');
}
const data = await response.json();
console.log("Blog data", data)
setBlog(data);
setUserId(data.user_id);
const user = await getUserById(data.user_id);
setUser(user);
} catch (error) {
console.error(error);
}
};

if (blogid) {
fetchBlog();
}
}, [blogid]);

if (!blog) {
return <div>
<Header bgImage='' heading='Loading' subheading='' ></Header>
</div>;
}

const formattedDate = formatDate(blog.created_at);

return (
<div>
<Header bgImage={blog.image} heading={blog.title} subheading={blog.subtitle} />
<div className="container mt-12 mx-auto p-4 px-10 border-x-4 flex justify-center flex-col items-center border-bt-navy">
<Markdown className="text-center text-2xl">{blog.content}</Markdown>
<Markdown className="text-center text-2xl ">{blog.content}</Markdown>
{isVisible && <DeleteDialogueBox
blogId={blog.id}
userId={loggedInUserId}
isBlog={true}
onClose={() => setIsVisible(false)}
/>}
<img
src={blog.uploadedImageLink}
alt={blog.title}
width={500}
height={500}
className="m-8 transform scale-100 hover:scale-110 transition duration-300 ease-in-out"
/>
<img src={blog.uploadedImageLink} alt={blog.title} width={500} height={500} className='m-8 transform scale-100 hover:scale-110 transition duration-300 ease-in-out' />
<div className="flex items-center justify-end text-right mt-4 flex-col">
<p className="text-bt-teal">Written By: {user?.username}</p>
<p className="text-bt-teal">Written By: {user?.Username}</p>
<p className="text-bt-teal">Published On: {formattedDate}</p>
<div className="flex items-center">
{isVisibleLikes && <Likes id={blog.id} />}
Expand All @@ -155,6 +145,7 @@ const Page = () => {
</div>
</div>
);

};

export default Page;
export default Page;
8 changes: 1 addition & 7 deletions frontend/app/layout.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,17 +3,13 @@ import { Dosis } from "next/font/google";
import "./globals.css";
import Footer from "./components/Footer";
import { EdgeStoreProvider } from "./lib/edgestore";
import { ApolloClient, InMemoryCache, ApolloProvider } from '@apollo/client';


const dosis = Dosis({
subsets: ["latin"],
weight: "600"
} );

const client = new ApolloClient({
uri: process.env.NEXT_PUBLIC_GRAPHQL_API_URL,
cache: new InMemoryCache()
});

export const metadata: Metadata = {
title: "HaalSamachar",
Expand All @@ -29,11 +25,9 @@ export default function RootLayout({
<html lang="en">

<body className={dosis.className}>
{/* <ApolloProvider client={client}> */}
<EdgeStoreProvider>
{children}
</EdgeStoreProvider>
{/* </ApolloProvider> */}
<Footer />
</body>

Expand Down

0 comments on commit 60f9733

Please sign in to comment.