-
-
Notifications
You must be signed in to change notification settings - Fork 255
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Requirement of Refactoring in the code #1 #9
Comments
This was referenced Mar 19, 2022
kollisathvik0101
added a commit
to kollisathvik0101/Library-management-system
that referenced
this issue
Feb 15, 2025
# 📚 Library Management System -Java <a href="https://github.com/harismuneer"><img alt="views" title="Github views" src="https://komarev.com/ghpvc/?username=harismuneer&style=flat-square" width="125"/></a> [](#) [](https://www.github.com/harismuneer/Library-Management-System-JAVA/fork) [](https://www.github.com/harismuneer/Library-Management-System-JAVA/issues) [](#) A Library Management System made using the concepts of Object Oriented Analysis and Design. Minimal Code is written in the GUI and the entities are decoupled as well. The interface is console based. This project was designed during the course "Object Oriented Analysis and Design CS309". The **Class Diagram** of the project is also provided along with the **Database Schema** file. The class diagram file can be opened using [Star UML](http://staruml.io/). ## Class Diagram  **Note**: After Refactoring, new Class "HoldRequestOperations" is added to the above structure which lies in between the HoldRequest class and Book class. This class removes the bidirectional dependency between HoldRequest and Book. More details mentioned [here](harismuneer/Library-Management-System-JAVA#9) ## Interface <p align="middle"> <img src="../master/images/interface.PNG" width="400"/> <img src="../master/images/interface2.PNG" width="400"/> </p> ## Actors: The actors include the following: * Librarian * Checkout Clerk * Borrower * Administrator ## Use Cases: After determining the actors, the second step in use case analysis is to determine the tasks that each actor will need to do with the system. Each task is called a use case because it represents one particular way the system will be used. **In other words, only those use cases are listed that actors will need to do when they are using the system to solve the customer’s problem.** ### Borrower: * ❏ Search for items by title. * ❏ ... by author. * ❏ ... by subject. * ❏ Place a book on hold if it is on loan to somebody else. * ❏ Check the borrower’s personal information and list of books currently borrowed. ### Checkout Clerk: * ❏ All the Borrower use cases, plus * ❏ Check out an item for a borrower. * ❏ Check in an item that has been returned. * ❏ Renew an item. * ❏ Record that a fine has been paid. * ❏ Add a new borrower. * ❏ Update a borrower’s personal information (address, telephone number etc.). ### Librarian: * ❏ All of the Borrower and Checkout Clerk use cases, plus * ❏ Add a new item to the collection. * ❏ Delete an item from the collection. * ❏ Change the information the system has recorded about an item. ### Administrator: * ❏ Add Clerk. * ❏ Add Librarian. * ❏ View Issued Books History. * ❏ View All Books in Library. ## How to Run 1- Install these: * [Java SE Development Kit 8 (JDK 8)](http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html) * After installing JDK 8, install [NetBeans IDE](https://netbeans.org/downloads/) 2- Open NetBeans IDE. Click on File -> Open Project and browse to the downloaded folder named "Project" and select it. It will load the NetBeans project. 3- Now everything is setup except the Java DB (Derby) Database of NetBeans. So, follow these steps to setup the database: **Step 1:** In the Netbeans Window, there is a tab named "Services" on the left. Select it. Then right click on JavaDB > Properties and change database location to "Database" folder downloaded with this repository (its placed besides the "Project" folder).  **Step 2:** After that a database named LMS will show up under JavaDB tab. Now Right Click Databases > New Connection and select Java DB Network and click Next.  **Step 3:** Provide the following database crendentials in the next popup and click Next. ``` Host: localhost Port: 1527 Database: LMS User Name: haris Password: 123 ```  **Step 4:** Now just click Next for the rest of the windows. After all this the database connection is made. Make sure that you connect with the database before running the project by right clicking on the connection and selecting connect. Now you are ready to run the project!  ## Note The password for Administrative Functions is *lib*. The admin adds new clerks and librarian, then they both do the rest of the functions. <hr> <h1 align="left">Hey there, I'm <a href="https://www.linkedin.com/in/harismuneer/">Haris </a><img src="https://media.giphy.com/media/hvRJCLFzcasrR4ia7z/giphy.gif" width="28"> <a href="https://github.com/harismuneer/Ultimate-Facebook-Scraper"><img align="right" src="https://user-images.githubusercontent.com/30947706/79588950-17515780-80ee-11ea-8f66-e26da49fa052.png" alt="Ultimate Facebook Scraper (UFS)" width="200"/></a> - Maker of Things</h1> ### Creator of <a href="https://github.com/harismuneer/Ultimate-Facebook-Scraper">Ultimate Facebook Scraper</a> (one of the best software to collect Facebook data for research & analysis) <hr> <h2 align="left">🌐 Connect</h2> <p align="left"> <a href="https://www.linkedin.com/in/harismuneer/"><img title="Follow on LinkedIn" src="https://img.shields.io/badge/LinkedIn-0077B5?style=for-the-badge&logo=linkedin&logoColor=white"/></a> <a href="https://www.facebook.com/harism99"><img title="Connect on Facebook" src="https://img.shields.io/badge/Facebook-1877F2?style=for-the-badge&logo=facebook&logoColor=white"/></a> <a href="https://twitter.com/harismuneer99"><img title="Follow on Twitter" src="https://img.shields.io/badge/Twitter-1DA1F2?style=for-the-badge&logo=twitter&logoColor=white"/></a> <a href="mailto:[email protected]"><img title="Email" src="https://img.shields.io/badge/Gmail-D14836?style=for-the-badge&logo=gmail&logoColor=white"/></a> <a href="https://github.com/harismuneer"><img title="Follow on GitHub" src="https://img.shields.io/badge/GitHub-100000?style=for-the-badge&logo=github&logoColor=white"/></a> <a href="https://www.instagram.com/harismuneer99"><img title="Follow on Instagram" src="https://img.shields.io/badge/Instagram-E4405F?style=for-the-badge&logo=instagram&logoColor=white"/></a> <a href="https://www.youtube.com/channel/UCZ-uBd7g0E2Bp-0tXtSlSjw?sub_confirmation=1"><img title="Subscribe on YouTube" src="https://img.shields.io/badge/YouTube-FF0000?style=for-the-badge&logo=youtube&logoColor=white"/></a> </p> ## 🤝 Consulting / Coaching Stuck with some problem? Need help in solution development, guidance, training or capacity building? I am a Full Stack Engineer turned Project Manager with years of technical and leadership experience in a diverse range of technologies and domains. Let me know what problem you are facing at <b>[email protected]</b> and we can schedule a consultation meeting to help you get through it. ## 👨💻 Technical Skills & Expertise - Development of Web Applications, Mobile Applications, and Desktop Applications - Development of Machine Learning/Deep Learning models, and deployment - Web Scraping, Browser Automation, Python Scripting <hr> ## ❤️ Support / Donations If you or your company use any of my projects, like what I’m doing or have benefited from my projects in any way then kindly consider backing my efforts. For donations, you can follow these simple steps: <b>1)</b> Free signup at <b>[TransferWise](https://transferwise.com/invite/u/harism95)</b> using this link: https://transferwise.com/invite/u/harism95</li>. (Signing up through this link will save you from any transcation fee on the donation) <b>2)</b> Select the amount e.g (15$) and choose the receiving/recipient's currency to be PKR. It supports multiple payment options (credit card, debit card, wire transfer etc) <b>3)</b> Then it will show my info as the recipient, select it. If my name isn't shown, then type my email [email protected] in recipients. <b>4)</b> Choose the reason for transfer to the one that suits you the most (in this case it could be 'General expenses') and in the reference section, you can mention 'Support' If you face any issue in sending donation then feel free to get in touch with me at [email protected] Thank you for your contribution! ## Authors 👋 You can get in touch with us on our LinkedIn Profiles: #### Haris Muneer [](https://www.linkedin.com/in/harismuneer) You can also follow my GitHub Profile to stay updated about my latest projects: [](https://github.com/harismuneer) #### Maham Amjad [](https://www.linkedin.com/in/maham-amjad-40796b177/) You can also follow my GitHub Profile to stay updated about my latest projects: [](https://github.com/MahamAmjad) If you liked the repo then kindly support it by giving it a star ⭐ and share in your circles so more people can benefit from the effort. ## Contributions Welcome [](#) If you find any bug in the code or have any improvements in mind then feel free to generate a pull request. ## Issues [](https://www.github.com/harismuneer/Library-Management-System-JAVA/issues) If you face any issue, you can create a new issue in the Issues Tab and I will be glad to help you out. ## License [](../master/LICENSE)
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Refactoring Required
1) Extract Method
Class to be updated: Borrower.java
Initially the method updateBorrowerInfo() had three functionalities of updating the name, address and phone number. These functionalities are separated by creating individual methods for each functionality updateBorrowerName() , updateBorrowerAddress() and updateBorrowerPhoneNumber().
This not only makes the code more readable and understandable but can also be used in extending the functionality of the Library management system by providing only the option of changing the name to admin and giving just the access of changing address and phone numbers to individual borrowers.
2) RENAME METHOD/VARIABLE
Class: Borrower.java
Class: Person.java
3) Move Method
Add Librarian function should be there in Librarian class instead of Library as it is better suited to be the component of that class.
4) Extract Class
Class: Book.java
Hold Requests operations are performed inside the book class. And this violated the principle of single responsibility, so the responsibility is split by creating a new class HoldRequestOperations.
5)Changing Bidirectional Association to Unidirectional
Object or instance variable of HoldRequest is used in various classes. Because of this, there is a bidirectional relationship between Hold Request and Book class. Using HoldRequestOperations class changes the bidirectional relationship to unidirectional. In the future, for any additional features/modifications, users will not need to look up and make changes to several classes.
Thanks for giving me the opportunity to refactor your code! Please let me know your suggestion/feedback for the same
The text was updated successfully, but these errors were encountered: