Initial commit: WrestleDesk full project

- Django backend with DRF (clubs, wrestlers, trainers, exercises, templates, trainings, homework, locations, leistungstest)
- Next.js 16 frontend with React, Shadcn UI, Tailwind
- JWT authentication
- Full CRUD for all entities
- Calendar view for trainings
- Homework management system
- Leistungstest tracking
This commit is contained in:
Andrej Spielmann
2026-03-26 13:24:57 +01:00
commit 3fefc550fe
256 changed files with 38295 additions and 0 deletions
@@ -0,0 +1,61 @@
# Generated by Django 4.2.29 on 2026-03-19 09:05
from django.db import migrations, models
import django.db.models.deletion
class Migration(migrations.Migration):
initial = True
dependencies = [
('trainers', '0001_initial'),
('wrestlers', '0001_initial'),
('locations', '0001_initial'),
('templates', '0001_initial'),
]
operations = [
migrations.CreateModel(
name='Training',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('date', models.DateField()),
('start_time', models.TimeField()),
('end_time', models.TimeField()),
('group', models.CharField(choices=[('kids', 'Kids'), ('youth', 'Youth'), ('adults', 'Adults'), ('all', 'All')], default='all', max_length=20)),
('notes', models.TextField(blank=True)),
('is_completed', models.BooleanField(default=False)),
('created_at', models.DateTimeField(auto_now_add=True)),
('updated_at', models.DateTimeField(auto_now=True)),
('location', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='trainings', to='locations.location')),
('template', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='trainings', to='templates.trainingtemplate')),
('trainers', models.ManyToManyField(blank=True, related_name='trainings', to='trainers.trainer')),
],
options={
'ordering': ['-date', '-start_time'],
},
),
migrations.CreateModel(
name='Attendance',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('is_present', models.BooleanField(default=False)),
('created_at', models.DateTimeField(auto_now_add=True)),
('training', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='attendances', to='trainings.training')),
('wrestler', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='attendances', to='wrestlers.wrestler')),
],
),
migrations.AddIndex(
model_name='training',
index=models.Index(fields=['date'], name='trainings_t_date_81aa6e_idx'),
),
migrations.AddIndex(
model_name='training',
index=models.Index(fields=['group'], name='trainings_t_group_290df4_idx'),
),
migrations.AlterUniqueTogether(
name='attendance',
unique_together={('training', 'wrestler')},
),
]
@@ -0,0 +1,30 @@
# Generated by Django 4.2.29 on 2026-03-19 19:20
from django.db import migrations, models
import django.db.models.deletion
class Migration(migrations.Migration):
dependencies = [
('exercises', '0001_initial'),
('trainings', '0001_initial'),
]
operations = [
migrations.CreateModel(
name='TrainingExercise',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('reps', models.IntegerField(blank=True, null=True)),
('time_minutes', models.IntegerField(blank=True, null=True)),
('order', models.IntegerField(default=0)),
('exercise', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='training_exercises', to='exercises.exercise')),
('training', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='training_exercises', to='trainings.training')),
],
options={
'ordering': ['order', 'id'],
'unique_together': {('training', 'exercise')},
},
),
]
@@ -0,0 +1,17 @@
# Generated by Django 4.2.29 on 2026-03-20 07:47
from django.db import migrations
class Migration(migrations.Migration):
dependencies = [
('trainings', '0002_trainingexercise'),
]
operations = [
migrations.RemoveField(
model_name='attendance',
name='is_present',
),
]
@@ -0,0 +1,23 @@
# Generated by Django 4.2.29 on 2026-03-20 14:31
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('trainings', '0003_remove_is_present'),
]
operations = [
migrations.AlterField(
model_name='trainingexercise',
name='reps',
field=models.PositiveIntegerField(blank=True, null=True),
),
migrations.AlterField(
model_name='trainingexercise',
name='time_minutes',
field=models.PositiveIntegerField(blank=True, null=True),
),
]
@@ -0,0 +1,24 @@
# Generated by Django 4.2.29 on 2026-03-20 14:40
from django.db import migrations, models
import django.db.models.deletion
class Migration(migrations.Migration):
dependencies = [
('clubs', '0001_initial'),
('trainings', '0004_alter_trainingexercise_reps_and_more'),
]
operations = [
migrations.AddField(
model_name='training',
name='club',
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='trainings', to='clubs.club'),
),
migrations.AddIndex(
model_name='training',
index=models.Index(fields=['club'], name='trainings_t_club_id_eb404f_idx'),
),
]