Blog Logo

08 Dec 2024 ~ 2 min read

I made a Terminal Portfolio


This is a repost of an old post that I made on my old blog located at lelbois-blog.vercel.app so the date is inaccurate along with probably some information in this article.

Screenshot 2024-10-13 10 43 37 AM

Introduction

I made a terminal-like portfolio website, which I recently deployed. This project was forked from satnaing, and after forking it, I added my own features.

Tech Stack

This is an entirely frontend project with no server code involved. For the frontend, The original creator chose React over plain JavaScript and Next.js. Here’s his reasons:

  • Declarative Code: Writing declarative code makes managing the HTML DOM less tedious compared to imperative JavaScript.
  • Performance and Reliability: React is known for its speed and reliability.
  • Simplicity: I didn’t require extensive SEO features, routing, or image optimization that Next.js offers.
  • I opted for TypeScript for its type-checking benefits.

The original creator of the repository I forked used styled-components for styling his React components.

Here’s a quick recap of my tech stack:

Features

Here are some features of my terminal portfolio website:

Multiple Themes

Users can switch between multiple themes. At the time of writing, there are five themes available, with plans to add more in the future. The selected theme is saved in storage, ensuring it persists after a page refresh.

Command-line Completion

To provide a nice terminal experience, satnaing implemented a CLI completion feature that auto-completes incomplete typed commands when you press ‘Tab’ or ‘Ctrl + I’.

Previous Commands

Users can navigate through previously typed commands using the Up and Down Arrow keys.

View/Clear Command History

Users can view previously typed commands by typing ‘history’ in the command line. The command history and terminal screen can be cleared by typing ‘clear’ or pressing ‘Ctrl + L’.

Theme Showcase

Here’s a video demonstrating different themes available in the terminal portfolio and me giving my opinion:

Conclusion

This is my first time overly working with React components, and I think the website turned out great.


i am lelbois, a full stack dev based in the us of a. 🇺🇸