Your neighborhood has decided to put together a local library where people can lend and borrow books. One of the most important features to organize this is a dashboard that will show which books are available, which are currently out, and other general statistics about the program.
Others are taking care of the logistics and and design, but they need you to build the algorithms!
This project is designed to test your ability to work with large datasets and build algorithms based on those datasets. Before taking on this module, you should be comfortable with the learning objectives listed below. You will not need to make any edits to HTML or CSS for this project.
This project will assess the following learning objectives, in addition to many others:
let
, const
, and var
, and use each appropriately..find()
, .filter()
, .map()
, .some()
, and .every()
to solve different problems..reduce()
to solve different problems..sort()
to sort arrays in various ways.Follow the instructions below to get this project up and running on your own machine:
npm install
.To run the tests, you can run the following command:
npm test
To watch how the code you write affects the application website, you can run the following command. This command will start a server and take over your terminal window. To stop the server from running, you can press Ctrl + C
.
npm start
You are tasked with building a number of different algorithms that will help complete the an administrative site for a local library. All of the functions will work on three common datasets. The datasets are related and at times you will need to work with multiple datasets to solve the problem at hand.
While working on these problems, you have both the tests and the live site to act as a guide. You can solve the tasks in any order and are encouraged to organize your code how you like.
All of the files you need to edit are inside of the public/src/
directory.
While working on this project you should:
.find()
, .filter()
, .map()
, and .reduce()
.for/in
loops.While working on this project you should not:
public/src/
directory.If you feel as though one of your solutions is working but something isn’t showing up right on the site or in the tests, reach out for help.
There are three datasets that are a part of this project: accounts
, authors
, and books
.
You can view all of the accounts data inside of the public/data/
directory. Each account is an object with the following shape:
{
"id": "5f446f2ecfaf0310387c9603",
"name": {
"first": "Esther",
"last": "Tucker"
},
"picture": "https://api.adorable.io/avatars/75/esther.tucker@zillacon.me",
"age": 25,
"company": "ZILLACON",
"email": "esther.tucker@zillacon.me",
"registered": "Thursday, May 28, 2015 2:51 PM"
}
An account represents a person who is registered with the library. Accounts can take out and return books.
You can view all of the authors data inside of the public/data/
directory. Each author is object with the following shape:
{
"id": 0,
"name": {
"first": "Lucia",
"last": "Moreno"
}
}
An author represents someone who wrote one or more books in the library.
You can view all of the books data inside of the public/data/
directory. Each book is object with the following shape:
{
"id": "5f4471327864ee880caf5afc",
"title": "reprehenderit quis laboris adipisicing et",
"genre": "Poetry",
"authorId": 20,
"borrows": [
{
"id": "5f446f2e2a4fcd687493a775",
"returned": false
},
{
"id": "5f446f2ebe8314bcec531cc5",
"returned": true
},
{
"id": "5f446f2ea508b6a99c3e42c6",
"returned": true
}
]
}
Each book represents a physical book but also contains additional information. In particular:
authorId
matches up with an author. It represents who wrote the book.borrows
array is a list of transactions that have ocurred with this book. For example, in the example above the book has been borrowed three times.
id
for each “borrow” record matches with an account ID. In the above example, the account with an ID of "5f446f2e2a4fcd687493a775"
has not yet returned the book, meaning they still are in possession of it.You are tasked with writing the following functions that work with the above datasets. The instructions for the functions can be found at the link below.