diff --git a/next.config.js b/next.config.js index 08e4f9a..1f9211d 100644 --- a/next.config.js +++ b/next.config.js @@ -1,8 +1,8 @@ -const withMDX = require('@next/mdx')(); - /** @type {import('next').NextConfig} */ const nextConfig = { - output: "export" + images: { + domains: ['tetragram.codered.cloud'], + }, } -module.exports = nextConfig; +module.exports = nextConfig \ No newline at end of file diff --git a/public/man-avatar-clipart-illustration-free-png.webp b/public/man-avatar-clipart-illustration-free-png.webp new file mode 100644 index 0000000..19352e2 Binary files /dev/null and b/public/man-avatar-clipart-illustration-free-png.webp differ diff --git a/src/app/blogs/Blogcard.js b/src/app/blogs/Blogcard.js index b205801..989920d 100644 --- a/src/app/blogs/Blogcard.js +++ b/src/app/blogs/Blogcard.js @@ -1,20 +1,47 @@ +// src/components/BlogCard.js +/*import Link from 'next/link'; +import styles from './Blogcard.module.css'; // Use CSS modules for styles + +const BlogCard = ({ title, blogLink}) => { + //const truncatedDescription = description.length > 100 ? `${description.slice(0, 100)}...` : description; + + return ( +
+
+
+

{title}

+
+
+
+ ); +}; + +export default BlogCard; + +// src/components/BlogCard.js*/ + +// src/components/BlogCard.js import Link from 'next/link'; -//import Image from 'next/image'; +import Image from 'next/image'; import styles from './Blogcard.module.css'; // Use CSS modules for styles -const BlogCard = ({ title, authors, img, description, slug }) => { - // const truncatedDescription = description.length > 100 ? `${description.slice(0, 100)}...` : description; +const BlogCard = ({ title, blogger, description, blogid,img }) => { + const truncatedDescription = description.length > 300 ? `${description.slice(0, 150)}...` : description; return (

{title}

-

by {authors}

-

{description}

+

by {blogger}

+

{truncatedDescription}

+

+ +
Read More
+
- {title} + Blog Image
@@ -22,5 +49,3 @@ const BlogCard = ({ title, authors, img, description, slug }) => { }; export default BlogCard; - -// src/components/BlogCard.js \ No newline at end of file diff --git a/src/app/blogs/Blogcard.module.css b/src/app/blogs/Blogcard.module.css index 7a9cd92..2d9692f 100644 --- a/src/app/blogs/Blogcard.module.css +++ b/src/app/blogs/Blogcard.module.css @@ -4,6 +4,7 @@ flex-direction: column; height: fit-content; align-items: center; + padding: 20px; } .bton { @@ -33,8 +34,6 @@ box-shadow: 0 0 10px rgba(0, 0, 0, 0.1); display: flex; transition: transform 0.3s ease-in-out; - cursor: pointer; - height: 220px; } .blogCcard:hover { @@ -49,21 +48,41 @@ .blogImage { width: 40%; /* Adjusted width for image */ - height: auto; + height: 100%; background-color: #ddd; background-size: cover; } .head { margin-bottom: 10px; + font-weight:bold; font-size: 1.5rem; - color: #333; + color:black; +} + +.blogCard:hover { + transform: translateY(-5px); +} + +.readMoreButton { + display: inline-block; + padding: 10px 20px; + background-color: white; + color: #8e44ad; /* Purple color */ + border: 2px solid #8e44ad; /* Purple color */ + text-decoration: none; + transition: background-color 0.3s, color 0.3s; +} + +.readMoreButton:hover { + background-color: #8e44ad; /* White background on hover */ + color: white; /* Purple text on hover */ } -.para { +.para1 { margin-bottom: 15px; - color: #555; - font-size: small; + font-weight: bold; + color: black; } .p:last-child { diff --git a/src/app/blogs/[blogid]/page.js b/src/app/blogs/[blogid]/page.js new file mode 100644 index 0000000..ff4d631 --- /dev/null +++ b/src/app/blogs/[blogid]/page.js @@ -0,0 +1,63 @@ +// Import necessary modules +"use client" +import { useEffect, useState } from "react"; +import Navbar from "@/components/Navbar/Navbar"; +import Footer from "@/components/footer"; +import ReactMarkdown from "react-markdown"; +import './styleblog.css' +// Import Tailwind CSS classes +import 'tailwindcss/tailwind.css'; + +// Component definition +const BlogId = ({ params }) => { + console.log(params.blogid) + // State to store the fetched data + const [blogData, setBlogData] = useState(null); + + // Effect to fetch data when the component mounts + useEffect(() => { + const fetchData = async () => { + try { + // Fetch data from the API + const response = await fetch('https://tetragram.codered.cloud/api/v2/pages/?type=blog.BlogPage&fields=*'); + const data = await response.json(); + console.log("check",data); + // Find the blog post with the matching id + const matchingBlog = data.items.find(blog => blog.id === parseInt(params.blogid)); + + // Update the state with the matching blog data + setBlogData(matchingBlog); + console.log("blog :",matchingBlog.blog_img_url) + + } catch (error) { + console.error('Error fetching data:', error); + } + }; + + // Call the fetchData function + fetchData(); + }, [params.id]); // Include params.id in the dependency array to refetch data when id changes + + // Render the component + return ( + <> + +
+ +
+ {blogData ? ( +
+

{blogData.title}

+ {blogData.blog_body} +
+ ) : ( +

Loading...

+ )} +
+
+