- paid_records (History tab) now prefetches work_logs + adjustments: the template shows a day-count and loops adjustments per row, which fired 2 queries per visible record (~100 on a long history). - batch_pay_preview replaces the per-worker get_worker_active_team() call (worker.teams.filter(...).first() — bypasses prefetch, 1 query per worker) with the same batched membership-dict pattern payroll_dashboard already uses, and reads the unpaid-adjustments check from the existing filtered prefetch instead of .exists(). Also includes (committed earlier in 25910b2 but noting for the record): the /report/ worker-breakdown loop's per-worker-per-type aggregates were replaced by one GROUP BY dict (audit fix #7). Co-Authored-By: Claude Fable 5 <noreply@anthropic.com>
Flatlogic Python Template Workspace
This workspace houses the Django application scaffold used for Python-based templates.
Requirements
- Python 3.11+
- MariaDB (or MySQL-compatible server) with the credentials prepared by
setup_mariadb_project.sh - System packages:
pkg-config,libmariadb-dev(already installed on golden images)
Getting Started
python3 -m pip install --break-system-packages -r requirements.txt
python3 manage.py migrate
python3 manage.py runserver 0.0.0.0:8000
Environment variables are loaded from ../.env (the executor root). See .env.example if you need to populate values manually.
Project Structure
config/– Django project settings, URLs, WSGI entrypoint.core/– Default app with a basic health-check route.manage.py– Django management entrypoint.
Next Steps
- Create additional apps and views according to the generated project requirements.
- Configure serving via Apache + mod_wsgi or gunicorn (instructions to be added).
- Run
python3 manage.py collectstaticbefore serving through Apache.
Description
Languages
JavaScript
42.5%
SCSS
41.7%
CSS
11.9%
Python
3.2%
HTML
0.6%