Portfolio template made with Nuxt 3, Nuxt Content v3, NuxtUI v3 and TailwindCSS v4
Canvas Portfolio is a fully customizable i18n portfolio template built with Nuxt and Nuxt UI, designed to help you showcase your work, testimonials, and key information with ease. The template integrates with Nuxt Studio for a smooth editing experience, while leveraging Nuxt Content for content management. Built with performance, flexibility, and responsiveness in mind, Canvas Portfolio provides a robust foundation for developers and creatives alike.
You can see a live demo at canvas.hrcd.fr.
git clone [email protected]:HugoRCD/canvas.git
pnpm install
.env.example
file to .env
and fill in the valuescp .env.example .env
pnpm dev
pnpm generate
pnpm start
Canvas Portfolio is designed to simplify the deployment process on various platforms, whether serverless or not. Below are several detailed methods to deploy your portfolio.
When using serverless platforms, it’s important to note that Nuxt Content v3 relies by default on SQLite for content storage. Since these platforms do not support SQLite natively, we recommend connecting Canvas Portfolio to an external database such as:
For further details on this process and the suitable solutions for serverless deployments, refer to the official Nuxt Content documentation:
Nuxt Content and Serverless Deployment
Nuxthub offers a powerful solution to deploy your portfolio in just a few clicks. With fast global delivery through the Cloudflare network, Nuxthub also provides advanced features such as:
Check out the official Nuxthub documentation for more info.
NuxtHub deployment do not need any extra configuration.
Canvas Portfolio is also available as a Docker image, making it easy to deploy in containerized environments. An official Docker image is automatically created using a GitHub workflow whenever a new release is made, or it can be triggered manually.
This workflow not only builds the official Canvas image but also provides a standard way for anyone who forks the project to create their own Docker image with a proper version tag (e.g., v2.0, v1.0.0, etc.).
To pull the latest Docker image:
docker pull ghcr.io/hugorcd/canvas:latest
You can also use Docker Compose for a quick deployment. A community-provided docker-compose.community.yml file is available and can be used with platforms like Coolify for one-click deployments.
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.
content/2.articles
directory.content/1.works/
directory.To change the featured works on the homepage, simply add the "featured": true
key the JSON file.
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, but it’s not mandatory. The server handle will not be used if you don’t set the NUXT_PRIVATE_RESEND_API_KEY
environment variable.
To set it up, follow these steps:
.env
filefrom
key in the sendEmail
route in the server/api/
folder, you can customize everything you want in this routeTo start contributing, you can follow these steps:
feat/123
or fix/456
.bun run test
.corepack enable
bun install
bun dev
Published under the APACHE license.
Made by @HugoRCD and community 💛
🤖 auto updated with automd (last updated: Mon Feb 10 2025)