This is book library manager, written in PHP and based on Slim4 and JqueryUI.
The main purpose of it is to manage own book library as excel table with ratings and other stuff like filename synchronizations of your books and more.
It supports all JQuery UI themes.
- excel table is sortable, pagable
- books CRUD
- books categories
- book cover is saved to database
- book cover can be dropped in web interface
- book cover can be imported from PDF (you need to have ghostScript)
- web interface is fully themed (all JqueryUI themes)
- i18n
- MySQL and SQLite support
- synchronization with filesystem (renames, deletes)
- migrations
- configuration is done via web interface
- PHP 8.3 or higher
- SQLite or MySQL database
git clone git@github.com:yurii-github/my-library.git
cd my-library
composer install
./serve
Application will be available at http://localhost:8085
Here's the list of most interesting places:
├── data - - - - - - - - your data is stored here │ ├── config.json - - - - - settings set via web interface │ └── mydb.s3db - - - - - book SQLite database ├── src ├── tests ├── public │ ├── 3rd - - - - - - - - 3rd party assets │ ├── assets - - - - - - - - our assets ├── └── index.php - - - - - - - - entry point of the application └── serve - - - - - - - - run webapp locally ------
If you have enabled synchronization application will sync changes to your filesystem!
- Any cell change that has influence on filename of the book will cause its rename
- If you delete book in MyLibrary it will delete corresponding real file if sync is ON
- You cannot remove records without corresponding real file if sync is ON
- You have to manage file extension manually to rename file properly.
- If you change book filename format it will not rename all books! It will apply new format only to newly renamed books
To import books into the library you have to drop your books to library folder you've set in configuration and then on Import tab press "Import Books". It will import all books from file system that are not in database yet.
To configure tests' run you can create local env file tests/local_test_env.php
with content like below
<?php
putenv('DB_TYPE=sqlite_memory'); // sqlite_memory | sqlite | mysql
putenv('DB_DBNAME=my_library_test2');
putenv('DB_LOGIN=my_library_test');
putenv('DB_PASSWORD=my_library_test_pass');
By default, sqlite_memory
is used as database. See tests/bootstrap.php
for more details.