mirror of
https://github.com/nottinghamtec/PyRIGS.git
synced 2026-01-20 15:02:31 +00:00
Restructure based on actual thought put in by @mattysmith22
This commit is contained in:
BIN
RIGS/static/imgs/tappytaptap.gif
Normal file
BIN
RIGS/static/imgs/tappytaptap.gif
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 6.3 MiB |
@@ -23,7 +23,8 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="col-sm-4 mb-3">
|
<div class="col-sm-4 mb-3">
|
||||||
<div class="card">
|
<div class="card">
|
||||||
<img class="card-img-top" src="{% static 'imgs/assets.jpg' %}" alt="" style="height: 150px; object-fit: cover;">
|
{% now "m-d" as todays_date %}
|
||||||
|
<img class="card-img-top" src="{% if todays_date == '04-01' %}{% static 'imgs/tappytaptap.gif' %}{%else%}{% static 'imgs/assets.jpg' %}{%endif%}" alt="" style="height: 150px; object-fit: cover;">
|
||||||
<h4 class="card-header">Asset Database</h4>
|
<h4 class="card-header">Asset Database</h4>
|
||||||
<div class="list-group list-group-flush">
|
<div class="list-group list-group-flush">
|
||||||
<a class="list-group-item list-group-item-action" href="{% url 'asset_index' %}"><span class="fas fa-tag align-middle"></span><span class="align-middle"> Asset List</span></a>
|
<a class="list-group-item list-group-item-action" href="{% url 'asset_index' %}"><span class="fas fa-tag align-middle"></span><span class="align-middle"> Asset List</span></a>
|
||||||
@@ -42,6 +43,8 @@
|
|||||||
<img class="card-img-top" src="{% static 'imgs/training.jpg' %}" alt="" style="height: 150px; object-fit: cover;">
|
<img class="card-img-top" src="{% static 'imgs/training.jpg' %}" alt="" style="height: 150px; object-fit: cover;">
|
||||||
<h4 class="card-header">Training Database</h4>
|
<h4 class="card-header">Training Database</h4>
|
||||||
<div class="list-group list-group-flush">
|
<div class="list-group list-group-flush">
|
||||||
|
<a class="list-group-item list-group-item-action" href=""><span class="fas fa-eye align-middle"></span><span class="align-middle"> View Training Items</span></a>
|
||||||
|
<a class="list-group-item list-group-item-action" href=""><span class="fas fa-plus align-middle"></span><span class="align-middle"> Log Training Session</span></a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -3,7 +3,4 @@ from training import models
|
|||||||
from reversion.admin import VersionAdmin
|
from reversion.admin import VersionAdmin
|
||||||
|
|
||||||
admin.site.register(models.Trainee, VersionAdmin)
|
admin.site.register(models.Trainee, VersionAdmin)
|
||||||
admin.site.register(models.TechnicalAssistant, VersionAdmin)
|
admin.site.register(models.TrainingLevel, VersionAdmin)
|
||||||
admin.site.register(models.Technician, VersionAdmin)
|
|
||||||
admin.site.register(models.Supervisor, VersionAdmin)
|
|
||||||
admin.site.register(models.Department, VersionAdmin)
|
|
||||||
|
|||||||
118
training/migrations/0002_auto_20210630_1514.py
Normal file
118
training/migrations/0002_auto_20210630_1514.py
Normal 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'),
|
||||||
|
),
|
||||||
|
]
|
||||||
@@ -10,52 +10,50 @@ class Trainee(Profile):
|
|||||||
|
|
||||||
# Items
|
# Items
|
||||||
class TrainingCategory(models.Model):
|
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)
|
number = models.CharField(max_length=3)
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
|
|
||||||
|
|
||||||
class TrainingItemInstance(models.Model):
|
class TrainingItem(models.Model):
|
||||||
item = models.ForeignKey('TrainingItem', on_delete=models.CASCADE)
|
category = models.ForeignKey('TrainingCategory', on_delete=models.RESTRICT)
|
||||||
trainee = models.ForeignKey('Trainee', related_name='items', on_delete=models.CASCADE)
|
number = models.CharField(max_length=3)
|
||||||
|
|
||||||
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):
|
|
||||||
name = models.CharField(max_length=50)
|
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
|
# Levels
|
||||||
class TrainingLevel(models.Model, RevisionMixin):
|
class TrainingLevel(models.Model, RevisionMixin):
|
||||||
requirements = models.ManyToManyField(TrainingItem)
|
ASSISTANT = 0
|
||||||
|
TECHNICIAN = 1
|
||||||
class Meta:
|
SUPERVISOR = 2
|
||||||
abstract = True
|
CHOICES = (
|
||||||
|
(ASSISTANT, 'Technical Assistant'),
|
||||||
@reversion.register
|
(TECHNICIAN, 'Technician'),
|
||||||
class TechnicalAssistant(TrainingLevel):
|
(SUPERVISOR, 'Supervisor'),
|
||||||
# department = models.ForeignKey('Department', on_delete=models.CASCADE)
|
)
|
||||||
pass
|
department = models.CharField(max_length=50, null=True) # Technical Assistant does not have a department
|
||||||
|
level = models.IntegerField(choices=CHOICES)
|
||||||
|
|
||||||
|
|
||||||
@reversion.register
|
class TrainingLevelQualification(models.Model):
|
||||||
class Technician(TrainingLevel):
|
trainee = models.ForeignKey('Trainee', related_name='levels', on_delete=models.RESTRICT)
|
||||||
department = models.ForeignKey('Department', on_delete=models.CASCADE)
|
level = models.ForeignKey('TrainingLevel', on_delete=models.RESTRICT)
|
||||||
|
confirmed_on = models.DateTimeField()
|
||||||
|
confirmed_by = models.ForeignKey('Trainee', related_name='confirmer', on_delete=models.RESTRICT)
|
||||||
@reversion.register
|
|
||||||
class Supervisor(TrainingLevel):
|
|
||||||
department = models.ForeignKey('Department', on_delete=models.CASCADE)
|
|
||||||
|
|||||||
5
training/templates/item_list.html
Normal file
5
training/templates/item_list.html
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
{% extends 'base_rigs.html' %}
|
||||||
|
|
||||||
|
{% block content %}
|
||||||
|
|
||||||
|
{% endblock %}
|
||||||
5
training/urls.py
Normal file
5
training/urls.py
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
from django.urls import path
|
||||||
|
|
||||||
|
urlpatterns = [
|
||||||
|
|
||||||
|
]
|
||||||
Reference in New Issue
Block a user