My current portfolio website, built with TypeScript, Next.js, React, Tailwind CSS, self-hosted on Raspberry Pi 5. https://ryanfreeman.dev
Go to file
2023-01-21 23:49:32 +00:00
components Fix issue with preloading of avatar image 2023-01-21 23:49:32 +00:00
lib Changed project structure 2023-01-19 21:53:37 +00:00
pages Added GitHub icons to projects page 2023-01-21 22:59:27 +00:00
prisma Added page views functionality 2023-01-17 21:24:16 +00:00
public Updated CV 2023-01-19 22:00:08 +00:00
styles Migrated to nextjs13 & TypeScript 2023-01-14 21:33:29 +00:00
types Migrated to nextjs13 & TypeScript 2023-01-14 21:33:29 +00:00
.env.example Migrated to nextjs13 & TypeScript 2023-01-14 21:33:29 +00:00
.eslintrc.json Updated portfolio 2023-01-02 18:05:03 +00:00
.gitignore Added page views functionality 2023-01-17 21:24:16 +00:00
jsconfig.json Changed project structure 2023-01-19 21:53:37 +00:00
next.config.mjs Updated views component 2023-01-19 21:18:28 +00:00
package-lock.json Added page views functionality 2023-01-17 21:24:16 +00:00
package.json Added page views functionality 2023-01-17 21:24:16 +00:00
postcss.config.js Migrated to nextjs13 & TypeScript 2023-01-14 21:33:29 +00:00
README.md Updated README 2023-01-21 23:38:13 +00:00
tailwind.config.js Changed project structure 2023-01-19 21:53:37 +00:00
tsconfig.json Changed project structure 2023-01-19 21:53:37 +00:00

Portfolio

This website was built using TypeScript, React, Next.js and Tailwind CSS. It is designed to showcase my professional experience and skills, as well as provide information about me and my interests.

Project structure

  • components/ - All the components on the website in tsx format.
  • lib/ - Useful functions and scripts for connecting to external services and so on.
  • pages/api/ - API routes for articles views and Spotify integrations.
  • pages/writing/ - Blog posts written in MDX format (Markdown in JSX).
  • pages/ - Contains all other static pages like about, projects and uses.
  • prisma/ - Prisma schema which describes the structure of the Supabase postgres database.
  • public/ - Used for static files such as icons and images.
  • styles/ - Contains the stylesheets for Tailwind and Prism.
  • types/ - Types for various components in the project.

Running locally

This application requires node v16.14+.

git clone https://github.com/r-freeman/portfolio.git
cd portfolio/
npm i
npm run dev

Create a .env.local file using .env.example as a template.