Skip to content
/ MyBrandFolio Public template

A minimalistic and responsive portfolio website for everyone who wants to express themselves to the world!

Notifications You must be signed in to change notification settings

asadkhalid305/MyBrandFolio

Repository files navigation

MyBrandFolio 🌟

A minimalistic and responsive portfolio website for everyone who wants to express themselves to the world!

Table of Contents

Demo

Demo

Features

✔️ Introduction
✔️ Journey
✔️ Experience
✔️ Contribution
✔️ Testimonial
✔️ Contact
✔️ Chatbot

Demo

To see the current app, click here

To see an example, click here.

Getting Started

These instructions will get you a copy of the project up and running on your local machine for development and testing purposes.

Requirements

You'll need Git, Node.js, and pnpm installed on your computer with the following versions:

How To Use

From your command line, clone and run MyBrandFolio app:

# Clone this repository
git clone https://github.com/asadkhalid305/MyBrandFolio.git

# Go into the repository
cd MyBrandFolio

# Setup default environment variables

# For Linux
cp env.example .env
# For Windows
copy env.example .env

# Install dependencies
pnpm install

# Start a local development server
pnpm run dev

Open http://localhost:3000 with your browser to see the result.

Customization

Content

Personalize page content in src/app/utils/constants.ts.

// For example, replace [Name] with your name in the metadata object
export const metadata: Metadata = {
  title: "Asad Ullah Khalid - Portfolio",
  description: "This is Asad Ullah Khalid's portfolio website",
};

// Similarly, do the same in all other objects

export const header: Header = { ... }

export const intro: Intro = { ... }

export const journey: Journey = { ... }

export const experience: Experience = { ... }

export const contribution: Contribution = { ... }

export const testimonial: Testimonial = { ... }

export const contact: Contact = { ... }

export const footer: Footer = { ... }

export const socials: Socials = { ... }

The following placeholders need to be updated:

[Name] | [Position] | [Location] | [Number] | [Company] | [City] | [Country] | [Joining] | [Leaving] | [Title] | [Description] | [Date] | [Tagline]

Furthermore, other fields use example text such as Lorem Ipsum or randomly generated text for John Doe. You will need to replace all the content as per your needs.

Chatbot

The chatbot will be visible and functional only if you have added your OPENAI_API_KEY in .env file. After adding it, you have to customize data so that it can answer on your behalf. To do that, update chatbot object in src/app/utils/constants.ts.

export const chatbot: Chatbot = {
  config: {
    // If you want to use another model, change the model's name here
    model: "gpt-3.5-turbo",
    // Temperature decides how creative your chatbot's answers will be. Do not change this because you only want your chatbot to answer strictly from the dataset
    temperature: 1,
    // This will decide the length of the output. To estimate how many tokens you would require, refer to https://platform.openai.com/tokenizer
    maxTokens: 150,
  },

  // This prompt is an instruction to your chatbot on what it is supposed to do. Do not change it unless you are sure of what you are doing
  prompt:
    "Welcome! You are now acting as John Doe himself. Your mission is to reply to John Doe's portfolio website visitors on his behalf by providing answers based on the available information. If a question arises that is not covered by the provided info, kindly respond with \"Hmmm! I don't have that information. Please get in touch with John Doe for further assistance.\" Remember, your role is to answer questions strictly related to the portfolio. Maintain your character throughout the interaction. Enjoy your role!",

  // This is the dataset your chatbot will conclude its answers from. Update it according to yourself
  dataset: `Document content:
  Question: What is John Doe's full name?
  Answer: John Doe's full name is John Doe Smith.
  ...`,

  // This defines the limit on the number of inputs a user can provide. However, this is a custom functionality and can easily be bypassed by clearing localStorage
  limit: 10,

  // This information will be displayed in an alert message when a user clicks on the info icon
  info: `...`,

  ...,
};

Deployment

When you are done with the setup, you should host your website online.

Deploying to Vercel

You can host directly with Vercel by linking your own repository.

Deploy with Vercel

For more information, read deploying nextjs app on vercel.

Technologies Used

Contribute

If you'd like to make this app better for other users, create issues to improve this project. Or if you have created something awesome for your fork and want to share it, feel free to open a pull request.