Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/alvalens/alvalens-porto-2-nextjs

My second personal portfolio website created using nextJs and animated using fullpage js and motion framer. Can be used as a template for other GitHub users.
https://github.com/alvalens/alvalens-porto-2-nextjs

framer-motion fullpage-js javascript nextjs nextjs-app-router nextjs-portfolio-template portfolio portfolio-nextjs portfolio-template portfolio-website portofolio-website

Last synced: 2 days ago
JSON representation

My second personal portfolio website created using nextJs and animated using fullpage js and motion framer. Can be used as a template for other GitHub users.

Awesome Lists containing this project

README

        

# Alvalens Porto 2

![visitor badge](https://visitor-badge.laobi.icu/badge?page_id=aleph-discord-bot.visitor-badge)

This is my debut project utilizing Next.js, a portfolio website featuring four primary sections: Home, About, Projects, and Contact. The site is brought to life with animations powered by Framer Motion, enhanced page transitions with Fullpage.js, and styled using elements of Tailwind CSS. This project also read list of project data from a JSON file. It serves as a showcase of my web development skills and represents my initial foray into web development with Next.js.

![JavaScript](https://img.shields.io/badge/javascript-%23323330.svg?style=for-the-badge&logo=javascript&logoColor=%23F7DF1E) ![Next JS](https://img.shields.io/badge/Next-black?style=for-the-badge&logo=next.js&logoColor=white) ![TailwindCSS](https://img.shields.io/badge/tailwindcss-%2338B2AC.svg?style=for-the-badge&logo=tailwind-css&logoColor=white)

## Features

* **Smooth Animation:** Smooth page scroll and scroll trigger animation.
* **Smooth Page Transition:** Smooth page transition with prefetching feature of next js.
* **Dynamic Data:** Read the project data from JSON file instead of directly implemented the data.
* **Intelliticks chat widget:** Chat with owner of the web realtime.
* **Spotify realtime widget:** Show what song youre playing in this web.

## Installation

1. Ensure you have [pnpm](https://pnpm.io/) installed. If not, you can install it using:

```shell
npm install -g pnpm
```
2. Clone the repository:

```shell
git clone https://github.com/Alvalens/Alvalens-porto-2-nextJs.git
```
3. Navigate to the project directory:

```shell
cd Alvalens-porto-2-nextJs
```
4. Install dependencies:

```
pnpm install
```
5. Start the development server

```shell
pnpm next dev
```
6. Update the Intelliticks chat widget script in components/Chat.jsx, with your own

```javascript
"use client"
import { useEffect } from "react";

// Component for Intelliticks chat widget
const Chat = () => {
useEffect(() => {
// Replace the Intelliticks script here

}, []);

return null;
};

export default Chat;
```
7. Set env.local by copying env.example and fill the variable

```
NEXT_PUBLIC_SPOTIFY_CLIENT_ID=
NEXT_PUBLIC_SPOTIFY_CLIENT_SECRET=
NEXT_PUBLIC_SPOTIFY_REFRESH_TOKEN=
```

for further reference on how to setup spotify api you can check this [link ](https://leerob.io/blog/spotify-api-nextjs "leerob blog")

## Usage

There are four main sections and two subpages in this portfolio website:

### Home

The home page serves as an introduction to the portfolio. It provides an overview of your web development skills and passion for the field. Users can explore other sections from here.

### About

The about page offers more detailed information about you as a web developer. It might include your background, education, skills, and interests in the field of web development.

### Projects

The projects section showcases your work as a web developer. Users can explore the projects you've worked on, and you can provide details such as project descriptions, technologies used, and images.

### Contact

The contact page allows users to get in touch with you. You can provide contact information or a contact form for inquiries.

### Subpages

- **Project archive:** list all of your project that dont needed to display at main project page.
- Project details: See the main project detail by clicking the project image.

Feel free to customize and expand upon these sections and subpages to suit your needs and showcase your unique skills and projects.

### Intelliticks chat widget

Enjoy chat realtime with ease using Intelliticks (https://app.intelliticks.com/)

## Contributing

Contributions are welcome! If you find any issues or have suggestions, feel free to open an issue or submit a pull request.

## Reference (inspiration)

- https://www.frans.my.id/
- https://kuon-yagi-portfolio.netlify.app/

## License

This project is licensed under the GPL-3.0 License see the [LICENSE](LICENSE) file for details.