NOTE: This repo is archived, read-only access is provided.
This is a chemical inventory suitable for a medium-sized company. A very similar system is actually used in the industry.
Like any inventory, this system is designed to answer two questions:
- WHAT we have
- WHERE it is
Chemicals are structured in categories/subcategories. There are compounds, a compound can have batches and a batch can have many packs. Locationwise you can design laboratories (rooms), inside laboratories different storages (like cabinets, cupboards, fridges, etc.) and inside storages some sub- storages (e.g. shelves of a cupboard). Anyway, you can use any logic, nevertheless there is a pre-defined 3-tier location system.
Compound, batch and pack management is through the web interface. Locations & manufacturers are stored in the database as well as user right levels, so you can manipulate them with a database management software or plain SQL.
Barcodes are assigned to each pack, so you can use labels for identification in the lab. (barcode printing is not implemented yet in this application)
Adding and editing batches and packs is only allowed for admins. Users can add/edit compounds and upload documents, whereas guests only can view and search the database.
- Three user access levels (guest/user/admin)
- Add/edit compounds, batches and packs (Partially implemented in this edition)
- Inactivate packs when getting empty (Not implemented in this edition)
- Changelog for audit trails (Not implemented in this edition)
- Search chemicals with autocomplete (Not implemented in this edition)
- Generate barcodes (Not implemented in this edition)
- Drawing chemical structures (Not implemented in this edition)
- Fully OOP
- Custom-made core framework:
- Routing
- Session Management
- Controllers
- DataBase Handling
- Exception handling
- Rendering
- etc.
- Backend: PHP
- Template engine: Smarty
- jQuery
- Not all inventory feature implemented
- Clone or download repository
- Set
/public
directory to be the web server document root - Setup a MySQL server and import DB_structure.sql
- Edit config.php with your credentials (database)
- (optional) Load the database with sample data (DB_sample_data.sql)
This is a free software ;)
If you need more information feel free to contact me:
Sandor Semsey semseysandor@gmail.com