Welcome to my personal website, harindu.dev! This repository contains the source code and configuration for my website built using various technologies and frameworks.
- Next.js: Next.js is a React.js framework used for building static site generator apps. It provides an efficient and optimized way to create dynamic web applications. Learn more about Next.js here.
- Mantine: Mantine is a library of React components that I've used to enhance the UI and functionality of my website. It offers a wide range of customizable components, making development faster and easier. Find out more about Mantine here.
- Cloudinary: Cloudinary is a powerful CDN that I've integrated into my website to optimize the delivery of images and other media files. It helps improve performance and user experience by ensuring fast and reliable content delivery. Explore Cloudinary's features here.
- Vercel: I'm using Vercel as my serverless hosting platform to deploy and serve my website. Vercel, previously known as ZEIT, offers a seamless deployment process and ensures high availability and scalability. Learn more about Vercel here.
- Person Schema: I have implemented Person Schema on my website to provide structured data about myself as a human being. This schema helps search engines understand and present information about me more accurately. Learn more about Person Schema here.
Here are the additional dependencies used in this project:
- @emotion/react and @emotion/server: Libraries for styling and managing CSS-in-JS in React applications.
- @mantine/carousel, @mantine/core, @mantine/dates, @mantine/form, @mantine/hooks, @mantine/notifications, @mantine/nprogress, @mantine/prism: Mantine components and utility libraries.
- @next/bundle-analyzer: Analyzes the bundle size and composition of the Next.js application.
- @next/font: Simplifies adding custom fonts to the Next.js application.
- @tabler/icons: Provides a collection of icons from the Tabler Icons project.
- cookies-next: Handles cookies in Next.js applications.
- dayjs: Manipulates, parses, and formats dates and times.
- embla-carousel-react: React wrapper for the Embla Carousel library for interactive carousels.
- gray-matter: Parses front matter in Markdown files to extract metadata.
- next-mdx-remote: Renders MDX content (Markdown with JSX) on the server in Next.js.
- next-seo: Manages SEO metadata, such as title, description, and Open Graph tags, in Next.js applications.
- next-sitemap: Generates a sitemap for the website to aid search engine crawling and indexing.
- reading-time: Calculates the estimated reading time of a text based on average reading speed.
npm run dev
– start dev servernpm run build
– bundle application for productionnpm run export
– exports static website toout
foldernpm run analyze
– analyzes application bundle with @next/bundle-analyzer
npm run build
npm run sitemap
To run this project locally, follow these steps:
- Clone this repository
- Install the project dependencies:
npm install
- Start the development server:
npm run dev
- Open your browser and visit
http://localhost:3000
to see the website in action.
If you find any issues or have suggestions for improvement, please feel free to open an issue or submit a pull request. I appreciate your contributions!
There is currently a bug causing the website to load very fast but with delayed CSS rendering. This issue is impacting the initial visual display of the website. The bug needs to be fixed to ensure proper loading and rendering of CSS files.