Skip to content

Latest commit

 

History

History
232 lines (168 loc) · 8.46 KB

README.md

File metadata and controls

232 lines (168 loc) · 8.46 KB

Logo

maktabati

Status GitHub Pull Requests License

Electronic library management website

📝 Table of Contents

🧐 About

web site story page

Maktabati is a PHP web project designed for managing an electronic library. This project includes a control panel that allows you to efficiently manage your library's resources. You can easily add, delete, and edit both books, authors, and categories, making it a powerful tool for library administration.

Features

  • Library Management: Add, delete, and edit books, authors, and categories.
  • Advanced Search: Utilize the advanced search feature to find specific resources within the library.
  • Book Information: View detailed information about each book, including ratings.
  • Electronic Copies: Upload electronic copies of books for easy access.

📷 Screenshots

Here are some screenshots of the project:

Login Page:

Login Page

Books List Page:

books list page

Categories List Page:

categories list page

Authors List Page:

authors list page

Advance Search Page:

advance search page

Book Details Page:

book details page

⛏️ Built Using

  • php
  • MySQL
  • Bootstrap
  • JQuery

⚙️ Prerequisites

Before you begin, ensure you have met the following requirements:

  • PHP (>= 8.2.4) installed on your local machine.
  • Apache (>= 2.4.56) installed and configured.
  • MySQL (>= 8.2.4) or MariaDB database server.
  • Git You'll need Git to clone the repository.

🏁 Getting Started

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

📂 Clone the Repository

Open your terminal/command prompt and run the following command to clone the repository:

git clone https://github.com/MohammedShwabi/maktabati

💻 Setting Up the Environment

  1. Configure your web server to serve the project from the cloned directory. For example, with Apache, you can create a virtual host configuration:
<VirtualHost *:80>
    ServerName maktabati.local
    DocumentRoot "/path/to/maktabati"
    <Directory "/path/to/maktabati">
        Options Indexes FollowSymLinks
        AllowOverride All
        Require all granted
    </Directory>
</VirtualHost>

Replace "/path/to/maktabati" with the actual path to your project directory.

  1. Update your system's hosts file to point the domain to your local machine. On most systems, you can find this file at /etc/hosts (Linux/Mac) or C:\Windows\System32\drivers\etc\hosts (Windows). Add an entry like this:
127.0.0.1   maktabati.local

💾 Database Setup

  1. Create a MySQL or MariaDB database for maktabati. You can do this using a tool like phpMyAdmin or via the command line:
CREATE DATABASE maktabati;
  1. Import the maktabati.sql file into your newly created database. You can do this using the command-line MySQL client:
mysql -u your_username -p maktabati < maktabati.sql

Replace 'your_username' with your database username and enter the corresponding password when prompted.

  1. Verify that the tables and test data have been imported successfully:
USE maktabati;
SHOW TABLES;

This should display a list of tables, indicating that the database setup was successful.

🚀 Running the Project

Now that you have set up the project and the database, you can run the maktabati project on your local web server. Open a web browser and navigate to http://maktabati.local (or the domain you configured in your web server).

  1. enter the following credential to login to the web panel:
email: mohamed@gmail.com
password: 123

⚠️ Troubleshooting

If you encounter any issues during the setup process, refer to the PHP documentation or search for solutions on Stack Overflow.

🔧 Future Work Recommendations

While the current version of Maktabati is functional, there are several areas where the project can be further developed and enhanced:

  • 👥 User management system.
  • 👤 User pages and user profiles.
  • 🌍 Support for multiple languages for books, authors and publishers.
  • 🧹 Sorting and filtering options for books.
  • 👥 Ability to associate multiple authors with a book.

If you are interested in contributing to the project, consider working on these future enhancements to make Maktabati even better!

📱 Mobile App

A mobile app version of maktabati is also available. You can find the mobile app implementation of this project on GitHub:

The mobile app complements the web project and extends its functionality to mobile devices, providing a seamless user experience across platforms. Feel free to check it out and contribute to both the web and mobile versions of maktabati!

🙌 Contributing

If you'd like to contribute to the project, feel free to submit pull requests.

📜 License

This project is licensed under the MIT License.

✍️ Authors

See also the list of contributors who participated in this project.