ladunjexa / reactjs18-3d-portfolio

incredible 3D developer portfolio website with awesome graphics - built with React & Three.js πŸͺ„
https://threejs-3-d-portfolio.vercel.app
MIT License
381 stars 153 forks source link
3d-portfolio 3d-web emailjs-browser framer-motion portfolio-website react tailwindcss threejs

3D Portfolio

Latest release Stars Fork GitHub commits Pull requests

demo

ladunjexa License Top Language Contributors Release PRs deployment Known Vulnerabilities

🌐 Live Demo

Explore the live demonstration of the project: reactjs18-3d-portfolio

πŸ“ Description

3D Portfolio is a well-designed and fully functional portfolio website that is built with React.js and Three.js. It is a fully responsive website that works well on all devices.

Folder Structure ```bash reactjs18-3d-portfolio/ β”œβ”€β”€ src/ β”œ β”œβ”€β”€ App.tsx β”œ β”œβ”€β”€ globals.css β”œ β”œβ”€β”€ main.tsx β”œ β”œβ”€β”€ vite.env.d.ts β”œ β”œβ”€β”€ components/ β”œ β”œ β”œβ”€β”€ atoms/ β”œ β”œ β”œ └── Header.tsx β”œ β”œ β”œβ”€β”€ canvas/ β”œ β”œ β”œ β”œβ”€β”€ Ball.tsx β”œ β”œ β”œ β”œβ”€β”€ Computers.tsx β”œ β”œ β”œ β”œβ”€β”€ Earth.tsx β”œ β”œ β”œ β”œβ”€β”€ Stars.tsx β”œ β”œ β”œ └── index.ts β”œ β”œ β”œβ”€β”€ layout/ β”œ β”œ β”œ β”œβ”€β”€ Loader.tsx β”œ β”œ β”œ └── Navbar.tsx β”œ β”œ β”œβ”€β”€ sections/ β”œ β”œ β”œ β”œβ”€β”€ About.tsx β”œ β”œ β”œ β”œβ”€β”€ Contact.tsx β”œ β”œ β”œ β”œβ”€β”€ Experience.tsx β”œ β”œ β”œ β”œβ”€β”€ Feedbacks.tsx β”œ β”œ β”œ β”œβ”€β”€ Hero.tsx β”œ β”œ β”œ β”œβ”€β”€ Tech.tsx β”œ β”œ β”œ β”œβ”€β”€ Works.tsx β”œ β”œ β”œ └── page.tsx β”œ β”œ └── index.ts β”œ β”œβ”€β”€ constants/ β”œ β”œ β”œβ”€β”€ config.ts β”œ β”œ β”œβ”€β”€ styles.ts β”œ β”œ └── index.ts β”œ β”œβ”€β”€ hoc/ β”œ β”œ β”œβ”€β”€ SectionWrapper.tsx β”œ β”œ └── index.ts β”œ β”œβ”€β”€ utils/ β”œ β”œ └── motion.ts β”œ β”œβ”€β”€ types/ β”œ β”œ └── index.d.ts β”œ └── assets/ β”œ β”œβ”€β”€ company/ β”œ β”œ └── [[...]].{svg,png} β”œ β”œβ”€β”€ tech/ β”œ β”œ └── [[...]].{svg,png} β”œ β”œβ”€β”€ [[...]].{svg,png} β”œ └── index.ts β”œβ”€β”€ public/ β”œ β”œβ”€β”€ desktop_pc β”œ β”œ β”œβ”€β”€ textures/[[...]].png β”œ β”œ β”œβ”€β”€ license.txt β”œ β”œ β”œβ”€β”€ scene.bin β”œ β”œ └── scene.gltf β”œ β”œβ”€β”€ planet β”œ β”œ β”œβ”€β”€ textures/[[...]].png β”œ β”œ β”œβ”€β”€ license.txt β”œ β”œ β”œβ”€β”€ scene.bin β”œ β”œ └── scene.gltf β”œ β”œβ”€β”€ logo.png β”œ └── logo.svg β”œβ”€β”€ .env β”œβ”€β”€ .eslintignore β”œβ”€β”€ .eslintrc.cjs β”œβ”€β”€ .gitignore β”œβ”€β”€ .prettierignore β”œβ”€β”€ .prettierrc.cjs β”œβ”€β”€ index.html β”œβ”€β”€ LICENSE β”œβ”€β”€ README.md β”œβ”€β”€ package.json β”œβ”€β”€ postcss.config.cjs β”œβ”€β”€ tailwind.config.cjs β”œβ”€β”€ tsconfig.json β”œβ”€β”€ tsconfig.node.json └── vite.config.js ```

πŸ“– Table of Contents

Table of Contents - [Live Demo](#-live-demo) - [Description](#-description) - [Technologies Used](#-technologies-used) - [Get Started](#-get-started) - [Prerequisites](#-prerequisites) - [Installation and Run Locally](#-installation-and-run-locally) - [Scripts](#-scripts) - [Environment Variables](#-environment-variables) - [Deployment](#-deployment) - [Deploy to production (manual)](#-deploy-to-production-manual) - [Deploy on Vercel (recommended)](#-deploy-on-vercel-recommended) - [Deploy on Netlify](#-deploy-on-netlify) - [Contributing](#-contributing) - [Bug / Feature Request](#-bug--feature-request) - [Acknowledgements](#-acknowledgements) - [References](#-references) - [Contact Us](#-contact-us) - [License](#-license)

✨ Technologies Used

3D Portfolio is built using the following technologies: - [TypeScript](https://www.typescriptlang.org/): TypeScript is a typed superset of JavaScript that compiles to plain JavaScript. - [Vite](https://vitejs.dev/): Vite is a build tool that aims to provide a faster and leaner development experience for modern web projects. - [React.js](https://reactjs.org/): React is a free and open-source front-end JavaScript library for building user interfaces or UI components. - [Three.js](https://threejs.org/): Three.js is a cross-browser JavaScript library and application programming interface used to create and display animated 3D computer graphics in a web browser using WebGL. - [Framer Motion](https://www.framer.com/motion/): Framer Motion is a production-ready motion library for React. - [Tailwind CSS](https://tailwindcss.com/): Tailwind CSS is a utility-first CSS framework for rapidly building custom user interfaces. - [ESLint](https://eslint.org/): ESLint is a static code analysis tool for identifying problematic patterns found in JavaScript code. - [Prettier](https://prettier.io/): Prettier is an opinionated code formatter. - [Vercel](https://vercel.com/): Vercel is a cloud platform for frontend developers, providing the frameworks, workflows, and infrastructure to build a faster, more personalized Web.

[![Technologies Used](https://skillicons.dev/icons?i=ts,vite,react,threejs,tailwind,vercel)](https://skillicons.dev) ## 🧰 Get Started To get this project up and running in your development environment, follow these step-by-step instructions. ### πŸ“‹ Prerequisites In order to install and run this project locally, you would need to have the following installed on your local machine. - [Node.js](https://nodejs.org/en/) - [NPM](https://www.npmjs.com/get-npm) - [Git](https://git-scm.com/downloads) ### βš™οΈ Installation and Run Locally **Step 0:** Note :bangbang: the application uses EmailJS in order to send emails using client-side, therefore, you need to create EmailJS account [here](https://emailjs.com/) and sets the `VITE_EMAILJS_SERVICE_ID`, `VITE_EMAILJS_TEMPLATE_ID`, and `VITE_EMAIL_JS_ACCESS_TOKEN` environment variables in `.env` file. **Step 1:** Download or clone this repo by using the link below: ```bash git clone https://github.com/ladunjexa/reactjs18-3d-portfolio.git ``` **Step 2:** Execute the following command in the root directory of the downloaded repo in order to install dependencies: ```bash npm install ``` **Step 3:** Execute the following command in order to run the development server locally: ```bash npm run dev ``` **Step 4:** Open [http://localhost:5173](http://localhost:5173) with your browser to see the result. ### πŸ“œ Scripts All scripts are defined in the `package.json` file. Here is a list of all scripts: | Script | Action | | :----------------- | :------------------------------------------ | | `npm install` | Installs dependencies | | `npm run dev` | Starts local dev server at `localhost:5137` | | `npm run build` | Build your production site to `./dist/` | | `npm run preview` | Boot up a local static web server | | `npm run lint` | Run ESLint | | `npm run ts:check` | Perform type-checking | ## πŸ”’ Environment Variables Environment variables[^3] can be used for configuration. They must be set before running the app. > [Environment variables](https://en.wikipedia.org/wiki/Environment_variable) are variables that are > set in the operating system or shell, typically used to configure programs. **React.js 18 3D Portfolio** uses [EmailJS](https://www.emailjs.com/) as external service. You need to create an account and get the required credentials to run the app. Create a `.env` file in the root directory of the project and add the following environment variables: ```env VITE_EMAILJS_SERVICE_ID= VITE_EMAILJS_TEMPLATE_ID= VITE_EMAIL_JS_ACCESS_TOKEN= ``` ## πŸš€ Deployment #### Deploy to production (manual) You can create an optimized production build with the following command: ```bash npm run build ``` #### Deploy on Vercel (recommended) The easiest way to deploy this Next.js app is to use the [Vercel Platform](https://vercel.com/new?utm_medium=default-template&filter=next.js&utm_source=create-next-app&utm_campaign=create-next-app-readme). [![Deploy with Vercel](https://vercel.com/button)](https://vercel.com/new/clone?repository-url=https%3A%2F%2Fgithub.com%2Fladunjexa%2Freactjs18-3d-portfolio) #### Deploy on Netlify You can also deploy this Next.js app with [Netlify](https://www.netlify.com/). [![Deploy with Netlify](https://www.netlify.com/img/deploy/button.svg)](https://app.netlify.com/start/deploy?repository=https://github.com/ladunjexa/reactjs18-3d-portfolio) Check out [Next.js deployment documentation](https://nextjs.org/docs/deployment) for more details. ## πŸ”§ Contributing [![contributors](https://contrib.rocks/image?repo=ladunjexa/reactjs18-3d-portfolio)](https://github.com/ladunjexa/reactjs18-3d-portfolio/graphs/contributors) Contributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are **greatly appreciated**. To fix a bug or enhance an existing module, follow these steps: 1. Fork the repo 2. Create a new branch (`git checkout -b improve-feature`) 3. Make the appropriate changes in the files 4. Commit your changes (`git commit -am 'Improve feature'`) 5. Push to the branch (`git push origin improve-feature`) 6. Create a Pull Request πŸŽ‰ ### πŸ“© Bug / Feature Request If you find a bug (failure of a module to execute its intended function), kindly open an issue [here](https://github.com/ladunjexa/reactjs18-3d-portfolio/issues/new) by including the issue with a title and clear description. If you'd like to request a new function, feel free to do so by opening an issue [here](https://github.com/ladunjexa/reactjs18-3d-portfolio/issues/new). Please include sample queries and their corresponding results. ## πŸ’Ž Acknowledgements I'd like to express my gratitude to the following people who helped me with this project and made it possible: - [Tailwind CSS](https://tailwindcss.com/) - [Three.js](https://threejs.org/) - [Framer Motion](https://www.framer.com/motion/) - [React Vertical Timeline Component](https://www.npmjs.com/package/react-vertical-timeline-component) - [React Parallax Tilt](https://www.npmjs.com/package/react-parallax-tilt) - [Maath](https://www.npmjs.com/package/maath) - [EmailJS](https://www.emailjs.com/) - [ESLint](https://eslint.org/) - [Prettier](https://prettier.io/) - [Vercel](https://vercel.com/) - [JavaScript Mastery](https://www.jsmastery.pro/) ## πŸ“ž Contact Us [![Telegram](https://img.shields.io/badge/Telegram-@ladunjexa-2CA5E0?style=social&logo=telegram&logoColor=000000)](https://t.me/ladunjexa) [![LinkedIn](https://img.shields.io/badge/LinkedIn-ladunjexa-blue?style=flat&logo=linkedin&logoColor=b0c0c0&labelColor=363D44)](https://www.linkedin.com/in/lironabutbul) [![Instagram](https://img.shields.io/badge/Instagram-ladunjexa-grey?style=flat&logo=instagram&logoColor=b0c0c0&labelColor=8134af)](https://www.instagram.com/ladunjexa) [![Discord](https://img.shields.io/badge/Discord-ladunjexa-7289da?style=flat&logo=discord&logoColor=b0c0c0&labelColor=2c2f33)](https://discord.com/users/827996364331810816) ## πŸ“‹ License **Three.js 3D Portfolio** is open source software [licensed as MIT](https://opensource.org/license/mit/) and is free to use β€” See [LICENSE](https://github.com/ladunjexa/reactjs18-3d-portfolio/blob/main/LICENSE) for more details.