E-books Fixer is a cloud-based web application for making epub files more accessible to visually impaired people. Its main focus is on automatically generating image descriptions using already existing AIs, such as the Google Vision API. Our system also tries to keep the user in control as much as possible so all annotations generated by the AI can be manually edited and improved.
The project is part of the Future Libraries Lab, which is a research and innovation collaboration between the National Library of the Netherlands (Koninklijke Bibliotheek) and the Web Information Systems Group at the Delft University of Technology.
Here is a list with some of the most important features of our system:
- We convert valid ePub2 files into their more modern and accessible version - ePub3.
- Our graphical user interface allows the user to see all pages of the e-book, and we have also included buttons to ease navigation through the pages / images.
- We allow users to download the book they are working on at any point of time with all the changes they have made so far.
- We are using a wide variety of AIs depending on the type of image, some of which consider not only the image itself but also its surrounding context and thus improving the final description.
If you want to learn more about the topics of image annotation and accessibility of e-books here are some helpful links:
-
Client
- Main framework:
React
- Style library:
eslint
- To see the list of all the libraries we used check
package.json
under theclient
directory.
- Main framework:
-
Server
- Main framework:
Django
- Style library:
flake8
- To see the list of all the libraries we used check
requirements.txt
under theserver
directory.
- Main framework:
-
External resources - the systems makes use of the Google Vision API to create image annotations and the GitHub API to store the contents of the epub files (for research purposes).
Documentation for the client and server code can be found on our GitHub page.
To update the documentation run the following commands (you need to have the docker containers running):
- For the client:
docker exec frontend npx run docs
- For the server:
docker exec backend bash -c 'cd docs && make html'
For more information about the system architecture, list of requirements, ethical issues and more check our report.
First, you need to download the scripts or clone the repository.
To clone the repository using SSH run the following command in Git Bash.
git clone [email protected]:Revirator/Ebook-Fixer.git <path_to_local_directory>
To clone the repository using HTTPS run the following command in Git Bash.
git clone https://github.com/Revirator/Ebook-Fixer.git <path_to_local_directory>
After that, the easiest way to build and run the app locally is to install Docker (you can find more information on how to do this here).
Next, open your terminal and navigate to the root of the project directory. You should also make sure that Docker is running using this command.
docker info
Then, enter the following command to build and run the app. It might take a while the first time because of all the docker images and dependencies that are being installed.
docker-compose --env-file .env.development up --build -d
Once it is done, the client will be running on port 3000
, the server on port 8000
, and finally the
MongoDB database on port 27017
. In your browser you can go to http://localhost:3000
to start using the app.
To contribute to the project you should follow these guidelines:
- Open a new issue for the feature you want to implement and assign yourself to it (Don't forget to add a meaningful description to the issue, following our template).
- Make use of isolated branches which will be later merged into
development
via merge requests. - To ensure code quality you need at least 2 approvals on your merge requests for them to be merged.
- Make use of proper, descriptive commit messages and MR descriptions.
- Test your code thoroughly before committing the work. We try to keep the total test coverage at 70% or higher.
- Your MR can only be approved if the GitLab CI/CD pipeline passes. Also, make sure you run the tests and the style checkers before pushing to ensure a passing pipeline.
Use these commands to the run the tests (with coverage) locally.
- For the client:
docker exec frontend npm test
- For the server:
docker exec backend coverage run manage.py test --failfast
docker exec backend coverage report
Use these commands to run the style checkers locally.
- For the client:
docker exec frontend npx eslint .
- For the server:
docker exec backend flake8 --exclude=migrations --max-line-length 99 .
Thanks goes to the following people:
📸 | Name | |
---|---|---|
Aratrika Das | [email protected] | |
Denis Tsvetkov | [email protected] | |
Filip Nguyen Duc | [email protected] | |
Nadine Kuo | [email protected] | |
Vlad Makarov | [email protected] |