Skip to content

My portfolio repository - a showcase of my coding finesse and tidy organization

Notifications You must be signed in to change notification settings

radek-drw/Portfolio

Repository files navigation

Radek Drweski Portfolio Website

Welcome to my personal portfolio website. This website is designed to showcase my skills, projects, and provide a way to contact me. Below you'll find a detailed description of the website's features and how to set it up on your local machine.

Table of Contents

Project Overview

Portfolio Website Screenshot

Features

Navigation

  • Fixed Navigation Bar: The navigation bar remains fixed at the top of the page while scrolling.
  • Animated Navigation Links: Links have a smooth animation effect using jQuery.
  • Responsive Burger Menu:
    • When the page width is 480px or less, the navigation links transform into a burger menu.
    • The burger icon is animated with CSS: when closed, it shows three lines; when opened, it transforms into an arrow indicating how to close the menu.
    • When the burger menu is open, the background is blurred. Clicking anywhere on the blurred background closes the menu.

Header

  • Intro Section: Includes an introductory message with a JavaScript animation effect using classes.

Skills Section

  • Skills Display: Skills are displayed with images (SVG's) and descriptions.
    • Desktop View: Displays 4 images per row.
    • Mobile View: Displays 2 rows with 2 images per row.
  • Image Slider:
    • Images are displayed in a slider format using setInterval in JavaScript along with CSS animations.
    • Progress Bar:
      • Dots and connecting lines are generated automatically with JavaScript based on the number of images.
      • Clicking on a dot highlights the corresponding set of images. Each set of 4 images has a dot that becomes highlighted when active.

Projects Section

  • Project Display: Shows my work with the same progress bar functionality as the Skills section.

Contact Section

Form Validation

  • Each input is validated upon clicking the submit button.
  • If an input is not filled, a message is displayed indicating which input needs attention.
  • Inputs have placeholders that move to the top when clicked (using CSS focus).
  • If an input is not filled and loses focus, the placeholder and bottom border return to their original state.

Form Submission

  • Email Submission: When all fields are filled, the form submission is sent to the website owner's email address using PHP and PHPMailer with Composer.
  • SMTP Integration: All sensitive data in the PHP file is storred in a config.php file.
  • Server-Side Validation: The form undergoes server-side validation to ensure all fields are correctly filled, mirroring client-side validation.
  • Error Handling: Users receive toast messages for server errors or internet connection issues.
  • Submission Animation: An animation is shown while waiting for the server response during form submission. Once a positive response is received, the animation disappears.

General

  • Responsive Design: The website is fully responsive and works on all devices.
  • SEO and Social Media Meta Tags: The website includes SEO enhancements and meta tags for better visibility on search engines and social media platforms.
  • Webpack Configuration: The project uses Webpack for bundling.

Technology Stack

  • Frontend: HTML, CSS, JavaScript, jQuery
  • Backend: PHP, PHPMailer, Composer
  • Build Tool: Webpack

Installation

Prerequisites

  • Ensure you have Node.js, npm, PHP, and Composer installed on your machine.

Steps

  1. Clone the Repository:

    git clone https://github.com/radek-drw/Portfolio.git
    cd radek-drweski-portfolio
  2. Install dependencies:

    npm install
    composer install
  3. Start the Development Server:

    npm start

    This will start the development server and open the website in your default browser.

  4. Build for Production:

    npm run build

This will create an optimized production build in the dist folder.

Usage

  • Navigation: Use the top navigation bar to jump to different sections of the website.
  • Skills and Projects: Click on the dots in the skills and projects sections to navigate through different items.
  • Contact Form: Fill in the contact form to get in touch with me. Ensure all fields are filled correctly before submitting.

Contributing

If you would like to contribute to this project, please fork the repository and use a feature branch. Pull requests are warmly welcome.

License

This project is open source and available under the MIT License.

Contact

If you have any questions or feedback, feel free to contact me at [[email protected]].

Thank you for visiting my portfolio website!