This is the code for my personal portfolio built with Nuxt and Tailwind CSS.
You can see it live at hrcd.fr.
- Fully integrated with Nuxt Content v3
- Article & Project Content Type using Nuxt Content
- Hidden notes section for private notes
- Working contact form with Resend
- Auto-Generated Open Graph Image with Nuxt OG Image
- Nuxt Robots for auto-generate robots.txt
- ESLint using my personal configuration
- Full typescript support
- Optimized images with Nuxt Image
- Fully responsive on all browsers
- Easy to customize
- Auto generated sitemap
- Clone this repository if you have access or download it from the store
git clone [email protected]:HugoRCD/hr-folio.git
- Install dependencies
pnpm install
- Start development server
pnpm dev
- Generate static project
pnpm generate
- Start production server
pnpm start
This portfolio uses Nuxt Content to manage the content. Here's how you can modify it:
First check the app.config.ts
file to change the global configuration of the portfolio, there is a lot of stuff you can change here.
- Navigate to the
content/2.writing
directory. - Here, you'll find Markdown files for each article. To modify an article, simply open its Markdown file and make your changes.
- To add a new article, create a new Markdown file in this directory. The name of the file will be used as the URL slug for the article.
- Navigate to the
content/1.works/
directory. - Here, you'll find JSON files for each project. To modify an project, simply open its JSON file and make your changes.
- To add a new project, add a new JSON file in this directory.
Simply go to the content/
directory and edit any of the Markdown or JSON files to modify the content.
This portfolio uses Resend to handle the contact form. To set it up, follow these steps:
- Get your api key from Resend here your api key
- Add your api key in the
.env
file - change the
from
key in thesendEmail
route in theserver/api/
folder, you can customize everything you want in this route - That's it, you're good to go!
To change the main open graph image, go to the app.config.ts
file and change the openGrapImage
key.
To start contributing, you can follow these steps:
- First raise an issue to discuss the changes you would like to make.
- Fork the repository.
- Create a branch using conventional commits and the issue number as the branch name. For example,
feat/123
orfix/456
. - Make changes following the local development steps.
- Commit your changes following the Conventional Commits specification.
- If your changes affect the code, run tests using
pnpm run test
. - Create a pull request following the Pull Request Template.
- To be merged, the pull request must pass the tests/workflow and have at least one approval.
- If your changes affect the documentation, make sure to update it.
- If your changes affect the code, make sure to update the tests.
- Wait for the maintainers to review your pull request.
- Once approved, the pull request will be merged in the next release !
Local development
- Clone this repository
- Install latest LTS version of Node.js
- Enable Corepack using
corepack enable
- Install dependencies using
pnpm install
- Start development server using
pnpm dev
- Open http://localhost:3000 in your browser
Published under the APACHE license.
Made by @HugoRCD and community 💛
🤖 auto updated with automd (last updated: Tue Jun 18 2024)