# BrickTracker A web application for organizing and tracking LEGO sets, parts, and minifigures. Uses the Rebrickable API to fetch LEGO data and allows users to track missing pieces and collection status. ## Features - Track multiple LEGO sets with their parts and minifigures - Mark sets as checked/collected - Track missing pieces - View parts inventory across sets - View minifigures across sets - Automatic updates for LEGO data (themes, colors, sets) ## Screenshots - [Front page](https://xbackbone.baerentsen.space/LaMU8/koLAhiWe94.png/raw): Search your inventory and sort by theme, year, parts, id, name or sort by missing pieces. If you download instructions as PDF, add them to a specific folder and they show up [under each set](https://xbackbone.baerentsen.space/LaMU8/ZIyIQUdo31.png/raw) - [Inventory page](https://xbackbone.baerentsen.space/LaMU8/MeXaYuVI44.png/raw): Filter by color, quantity, name. Add if a piece is missing. Press images to [show them](https://xbackbone.baerentsen.space/LaMU8/FIFOQicE66.png/raw). Filter by only [missing pieces](https://xbackbone.baerentsen.space/LaMU8/LUQeTETA28.png). Minifigures and their parts are listed [at the end](https://xbackbone.baerentsen.space/LaMU8/nEPujImi75.png/raw). - [Missing pieces](https://xbackbone.baerentsen.space/LaMU8/YEPEKOsE50.png/raw): List of all your missing pieces, with links to bricklink and rebrickable. - [All parts](https://xbackbone.baerentsen.space/LaMU8/TApONAkA94.png/raw): List of all parts in inventory again with links to bricklink and rebrickable. - [Minifigures](https://xbackbone.baerentsen.space/LaMU8/RuWoduFU08.png/raw): List of all minifigures in inventory and quantity. - [Multiple sets](https://xbackbone.baerentsen.space/LaMU8/BUHAYOYe40.png/raw): Each set is given a unique ID, such that you can have multiple copies of a set with different pieces missing in each copy. Sets can also easily be [deleted](https://xbackbone.baerentsen.space/LaMU8/xeroHupE22.png/raw) from the inventory. - [Add set](https://xbackbone.baerentsen.space/LaMU8/lAlUcOhE38.png/raw): Sets are added from rebrickable using your own API key. Set numbers are checked against sets.csv from rebrickable and can be updated from the [config page](https://xbackbone.baerentsen.space/LaMU8/lErImaCE12.png/raw). When a set is added, all images from rebrickable are downloaded and stored locally, so if multiple sets contains the same part/color, only one image is downloaded and stored. This also make no calls to rebrickable when just browsing and using the site. Only time rebrickable to used it when up adding a new set. - [Wishlist](https://xbackbone.baerentsen.space/LaMU8/hACAbArO44.png/raw): Sets are added from rebrickable and again checked against sets.csv. If you can't add a brand new set, consider updating your data from the [`/config` page](https://xbackbone.baerentsen.space/LaMU8/lErImaCE12.png/raw). Press the delete button to remove a set. Known Issue: If multiple sets of the same number is added, they will all be deleted. ## Prerequisites - Docker - Docker Compose - Rebrickable API key (from [Rebrickable](https://rebrickable.com/api/)) ## Setup 1. Clone the repository: ```bash git clone https://gitea.baerentsen.space/FrederikBaerentsen/BrickTracker.git cd BrickTracker mkdir static/{sets,instructions,parts} ``` 2. Create a `.env` file with your configuration: ``` REBRICKABLE_API_KEY=your_api_key_here DOMAIN_NAME=https://your.domain.com ``` If using locally, set `DOMAIN_NAME` to `http://localhost:3333`. 3. Deploy with Docker Compose: ```bash docker compose up -d ``` 4. Access the web interface at `http://localhost:3333` 5. The database is created, csv files are downloaded and you will be redirected to the `/create` page for inputting a set number. ## Usage ### Adding Sets 1. Go to the Create page 2. Enter a LEGO set number (e.g., "42115") 3. Wait for the set to be downloaded and processed ### Managing Sets - Mark sets as checked/collected using the checkboxes - Track missing pieces by entering quantities in the parts table - Note, the checkbox for missing pieces is updated automatically, if the set has missing pieces. It cannot be manually checked off. - View all missing pieces across sets in the Missing page - View complete parts inventory in the Parts page - View all minifigures in the Minifigures page ## Docker Configuration The application uses two main configuration files: ### docker-compose.yml ```yaml services: bricktracker: container_name: BrickTracker restart: unless-stopped build: . ports: - "3333:3333" volumes: - .:/app env_file: - .env ``` ### Dockerfile ```dockerfile FROM python:slim WORKDIR /app COPY requirements.txt . RUN pip install -r requirements.txt COPY . . RUN bash lego.sh CMD ["gunicorn","--bind","0.0.0.0:3333","app:app","--worker-class","eventlet"] ``` ## Development The application is built with: - Flask (Python web framework) - SQLite (Database) - Socket.IO (Real-time updates) - Rebrickable API (LEGO data) Key files: - `app.py`: Main application code - `db.py`: Database operations - `downloadRB.py`: Rebrickable data download utilities ## Notes - The application stores images locally in the `static` directory - Database is stored in `app.db` (SQLite) - LEGO data is cached in CSV files from Rebrickable - Images are downloaded from Rebrickable when entering a set and then stored locally.