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-29 11:24:06 +00:00
components Added nav menu link to dashboard page 2023-01-27 23:41:23 +00:00
lib Updated dashboard 2023-01-29 11:24:06 +00:00
pages Updated dashboard 2023-01-29 11:24:06 +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 Added fork count to projects 2023-01-26 22:21:15 +00:00
.env.example Added github username env variable 2023-01-28 22:12:58 +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 and .env.example 2023-01-22 20:48:20 +00:00
tailwind.config.js Change bg colour 2023-01-23 19:51:54 +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 of the website in tsx format.
  • lib/ - Useful functions and scripts for connecting to external services and so on.
  • pages/api/ - API routes for article 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.