Restructure based on actual thought put in by @mattysmith22

This commit is contained in:
2021-06-30 15:17:00 +01:00
parent f6836fdab6
commit f8624d3b7a
7 changed files with 169 additions and 43 deletions

View File

@@ -3,7 +3,4 @@ from training import models
from reversion.admin import VersionAdmin
admin.site.register(models.Trainee, VersionAdmin)
admin.site.register(models.TechnicalAssistant, VersionAdmin)
admin.site.register(models.Technician, VersionAdmin)
admin.site.register(models.Supervisor, VersionAdmin)
admin.site.register(models.Department, VersionAdmin)
admin.site.register(models.TrainingLevel, VersionAdmin)

View File

@@ -0,0 +1,118 @@
# Generated by Django 3.1.5 on 2021-06-30 14:14
import RIGS.models
from django.db import migrations, models
import django.db.models.deletion
class Migration(migrations.Migration):
dependencies = [
('training', '0001_initial'),
]
operations = [
migrations.CreateModel(
name='TrainingItemQualification',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('depth', models.IntegerField(choices=[(0, 'Training Started'), (1, 'Training Complete'), (2, 'Passed Out')])),
('date', models.DateTimeField()),
('notes', models.TextField()),
],
),
migrations.CreateModel(
name='TrainingLevel',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('department', models.CharField(max_length=50, null=True)),
('level', models.IntegerField(choices=[(0, 'Technical Assistant'), (1, 'Technician'), (2, 'Supervisor')])),
],
bases=(models.Model, RIGS.models.RevisionMixin),
),
migrations.CreateModel(
name='TrainingLevelQualification',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('confirmed_on', models.DateTimeField()),
('confirmed_by', models.ForeignKey(on_delete=django.db.models.deletion.RESTRICT, related_name='confirmer', to='training.trainee')),
('level', models.ForeignKey(on_delete=django.db.models.deletion.RESTRICT, to='training.traininglevel')),
('trainee', models.ForeignKey(on_delete=django.db.models.deletion.RESTRICT, related_name='levels', to='training.trainee')),
],
),
migrations.RemoveField(
model_name='supervisor',
name='department',
),
migrations.RemoveField(
model_name='supervisor',
name='requirements',
),
migrations.RemoveField(
model_name='technicalassistant',
name='requirements',
),
migrations.RemoveField(
model_name='technician',
name='department',
),
migrations.RemoveField(
model_name='technician',
name='requirements',
),
migrations.RemoveField(
model_name='trainingiteminstance',
name='item',
),
migrations.RemoveField(
model_name='trainingiteminstance',
name='passed_out_by',
),
migrations.RemoveField(
model_name='trainingiteminstance',
name='trainee',
),
migrations.RemoveField(
model_name='trainingiteminstance',
name='training_complete_by',
),
migrations.RemoveField(
model_name='trainingiteminstance',
name='training_started_by',
),
migrations.AlterField(
model_name='trainingitem',
name='category',
field=models.ForeignKey(on_delete=django.db.models.deletion.RESTRICT, to='training.trainingcategory'),
),
migrations.DeleteModel(
name='Department',
),
migrations.DeleteModel(
name='Supervisor',
),
migrations.DeleteModel(
name='TechnicalAssistant',
),
migrations.DeleteModel(
name='Technician',
),
migrations.DeleteModel(
name='TrainingItemInstance',
),
migrations.AddField(
model_name='trainingitemqualification',
name='item',
field=models.ForeignKey(on_delete=django.db.models.deletion.RESTRICT, to='training.trainingitem'),
),
migrations.AddField(
model_name='trainingitemqualification',
name='supervisor',
field=models.ForeignKey(on_delete=django.db.models.deletion.RESTRICT, related_name='training_started', to='training.trainee'),
),
migrations.AddField(
model_name='trainingitemqualification',
name='trainee',
field=models.ForeignKey(on_delete=django.db.models.deletion.RESTRICT, related_name='items', to='training.trainee'),
),
]

View File

@@ -10,52 +10,50 @@ class Trainee(Profile):
# Items
class TrainingCategory(models.Model):
number = models.CharField(max_length=3) # Does this 1:1 correspond with a department? I think the answer is sometimes...
name = models.CharField(max_length=50)
class TrainingItem(models.Model):
category = models.ForeignKey('TrainingCategory', on_delete=models.CASCADE)
number = models.CharField(max_length=3)
name = models.CharField(max_length=50)
class TrainingItemInstance(models.Model):
item = models.ForeignKey('TrainingItem', on_delete=models.CASCADE)
trainee = models.ForeignKey('Trainee', related_name='items', on_delete=models.CASCADE)
training_started_on = models.DateField()
training_started_by = models.ForeignKey('Trainee', related_name='training_started', on_delete=models.CASCADE)
training_complete_on = models.DateField()
training_complete_by = models.ForeignKey('Trainee', related_name='training_complete', on_delete=models.CASCADE)
passed_out_on = models.DateField()
passed_out_by = models.ForeignKey('Trainee', related_name='passed_out', on_delete=models.CASCADE)
class Department(models.Model):
class TrainingItem(models.Model):
category = models.ForeignKey('TrainingCategory', on_delete=models.RESTRICT)
number = models.CharField(max_length=3)
name = models.CharField(max_length=50)
# TODO Validation that dates cannot be in the future
class TrainingItemQualification(models.Model):
STARTED = 0
COMPLETE = 1
PASSED_OUT = 2
CHOICES = (
(STARTED, 'Training Started'),
(COMPLETE, 'Training Complete'),
(PASSED_OUT, 'Passed Out'),
)
item = models.ForeignKey('TrainingItem', on_delete=models.RESTRICT)
trainee = models.ForeignKey('Trainee', related_name='items', on_delete=models.RESTRICT)
depth = models.IntegerField(choices=CHOICES)
date = models.DateTimeField()
supervisor = models.ForeignKey('Trainee', related_name='training_started', on_delete=models.RESTRICT)
notes = models.TextField()
# Levels
class TrainingLevel(models.Model, RevisionMixin):
requirements = models.ManyToManyField(TrainingItem)
class Meta:
abstract = True
@reversion.register
class TechnicalAssistant(TrainingLevel):
# department = models.ForeignKey('Department', on_delete=models.CASCADE)
pass
ASSISTANT = 0
TECHNICIAN = 1
SUPERVISOR = 2
CHOICES = (
(ASSISTANT, 'Technical Assistant'),
(TECHNICIAN, 'Technician'),
(SUPERVISOR, 'Supervisor'),
)
department = models.CharField(max_length=50, null=True) # Technical Assistant does not have a department
level = models.IntegerField(choices=CHOICES)
@reversion.register
class Technician(TrainingLevel):
department = models.ForeignKey('Department', on_delete=models.CASCADE)
@reversion.register
class Supervisor(TrainingLevel):
department = models.ForeignKey('Department', on_delete=models.CASCADE)
class TrainingLevelQualification(models.Model):
trainee = models.ForeignKey('Trainee', related_name='levels', on_delete=models.RESTRICT)
level = models.ForeignKey('TrainingLevel', on_delete=models.RESTRICT)
confirmed_on = models.DateTimeField()
confirmed_by = models.ForeignKey('Trainee', related_name='confirmer', on_delete=models.RESTRICT)

View File

@@ -0,0 +1,5 @@
{% extends 'base_rigs.html' %}
{% block content %}
{% endblock %}

5
training/urls.py Normal file
View File

@@ -0,0 +1,5 @@
from django.urls import path
urlpatterns = [
]