, (*1)
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., (*2)
, (*3)
, (*4)
, (*5)
Functionality
- 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
Requirements
- PHP 8.3 or higher
- SQLite or MySQL database
Setup & Run
git clone git@github.com:yurii-github/my-library.git
cd my-library
composer install
./serve
Application will be available at http://localhost:8085, (*6)
Structure
Here's the list of most interesting places:, (*7)
โโโ 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
------
Sync
If you have enabled synchronization application will sync changes to your filesystem!, (*8)
- 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
Importing new 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., (*9)
Development
To configure tests' run you can create local env file tests/local_test_env.php with content like below, (*10)
<?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., (*11)