Welcome to OpenFolio! This collaborative project is aimed at creating a dynamic personal portfolio homepage with fully integrated backend features. Each section of the portfolio is managed by a different developer, ensuring a modular and efficient approach to building a robust portfolio system.
- Project Overview
- Features
- Tech Stack
- Setup and Installation
- Usage
- Contributing
- License
- Acknowledgments
OpenFolio is designed to help developers showcase their skills, projects, and other professional details in an elegant and dynamic manner. The project is divided into sections, each handled by different backend developers, focusing on both frontend and backend aspects.
- Skills Section: Display your technical skills with dynamic progress bars.
- Projects Section: Showcase your projects with details like title, description, and technologies used.
- Contact Form: A fully functional contact form with validation and database integration.
- Hero/About Me Section: Introduce yourself with a dynamic welcome message and bio.
- Frontend: HTML, CSS, JavaScript
- Backend: PHP
- Database: MySQL
- Version Control: Git/GitHub
- PHP: Version 7.4 or higher
- MySQL: Version 5.7 or higher
- Composer: Latest version (for managing PHP dependencies)
- Git: Version control
-
Clone the repository:
git clone https://github.com/skye8-tech/OpenFolio.git
-
Navigate to the project directory:
cd OpenFolio
-
Install PHP dependencies:
composer install
-
Set up the environment file:
Copy the
.env.example
file to.env
and update the database credentials:cp .env.example .env
-
Set up the database:
- Create a new database in MySQL.
- Run any necessary SQL scripts to create tables and set up the schema. Check the
database/
folder or relevant documentation for these scripts.
-
Serve the application:
php -S localhost:8000
-
Open your browser:
Visit http://localhost:8000 to view the portfolio homepage.
-
Project Structure
OpenFolio/ │ ├── assets/ │ ├── css/ │ │ └── style.css │ ├── js/ │ │ └── script.js │ └── images/ │ └── (your image files) │ ├── config/ │ └── config.php # Database and application configuration │ ├── public/ │ ├── index.php # Main entry point of the application │ └── .htaccess # Configuration for URL rewriting and security │ ├── src/ │ ├── Controllers/ │ │ ├── HomeController.php # Controller for handling homepage logic │ │ ├── SkillsController.php # Controller for skills section │ │ └── ProjectsController.php # Controller for projects section │ ├── Models/ │ │ ├── Skill.php # Model for handling skills data │ │ ├── Project.php # Model for handling project data │ │ └── Contact.php # Model for handling contact form data │ └── Views/ │ ├── header.php # Header part of HTML layout │ ├── footer.php # Footer part of HTML layout │ ├── home.php # View for homepage │ ├── skills.php # View for skills section │ ├── projects.php # View for projects section │ └── contact.php # View for contact form │ ├── database/ │ └── migrations/ # SQL scripts or migration files for setting up the database schema │ ├── logs/ │ └── app.log # Log files for debugging and tracking │ ├── tests/ │ └── (unit and integration tests, if applicable) │ ├── .env # Environment variables (not included in version control) ├── composer.json # Composer dependencies and configurations (if using Composer) ├── composer.lock # Composer lock file (if using Composer) └── README.md # Project documentation
Each developer will work on their assigned section, implementing both frontend and backend features. Please ensure you push changes to your respective branches and submit pull requests for merging into the main branch.
- Fork the repository.
- Create your branch:
git checkout -b feature/YourFeature
- Commit your changes:
git commit -m 'Add some feature'
- Push to the branch:
git push origin feature/YourFeature
- Open a pull request.
Please make sure to update tests as appropriate and follow the code style guidelines.
This project is licensed under the MIT License - see the LICENSE file for details.
Special thanks to all contributors who have made this project possible. Each section of this portfolio has been carefully crafted to ensure a cohesive and dynamic user experience.