mirror of
https://github.com/nottinghamtec/PyRIGS.git
synced 2026-01-30 20:02:16 +00:00
Cleanup
This commit is contained in:
@@ -5,6 +5,7 @@ from assets import models
|
|||||||
from RIGS import models as rigsmodels
|
from RIGS import models as rigsmodels
|
||||||
from training import models as tmodels
|
from training import models as tmodels
|
||||||
|
|
||||||
|
|
||||||
class Command(BaseCommand):
|
class Command(BaseCommand):
|
||||||
help = 'Deletes testing sample data'
|
help = 'Deletes testing sample data'
|
||||||
|
|
||||||
|
|||||||
@@ -43,7 +43,104 @@ class Command(BaseCommand):
|
|||||||
self.categories.append(category)
|
self.categories.append(category)
|
||||||
|
|
||||||
def setup_items(self):
|
def setup_items(self):
|
||||||
names = ["Motorised Power Towers", "Catering", "Forgetting Cables", "Gazebo Construction", "Balanced Audio", "Unbalanced Audio", "BBQ/Bin Interactions", "Pushing Boxes", "How Not To Die", "Setting up projectors", "Basketing truss", "First Aid", "Digging Trenches", "Avoiding Bin Lorries", "Getting cherry pickers stuck in mud", "Crashing the Van", "Getting pigs to fly", "Basketing picnics", "Python programming", "Building Cables", "Unbuilding Cables", "Cat Herding", "Pancake making", "Tidying up", "Reading Manuals", "Bikeshedding", "DJing", "Partying", "Teccie Gym", "Putting dust covers on", "Cleaning Lights", "Water Skiing", "Drinking", "Fundamentals of Audio", "Fundamentals of Photons", "Social Interaction", "Discourse Searching", "Discord Searching", "Coiling Cables", "Kit Amnesties", "Van Insurance", "Subhire Insurance", "Paperwork", "More Paperwork", "Second Aid", "Being Old", "Maxihoists", "Sleazyhoists", "Telehoists", "Prolyte", "Prolights", "Making Phonecalls", "Quoting For A Rig", "Basic MIC", "Advanced MIC", "Avoiding MIC", "Washing Cables", "Cable Ramp", "Van Loading", "Trailer Loading", "Storeroom Loading", "Welding", "Fire Extinguishers", "Boring Conference AV", "Flyaway", "Short Leads", "RF Systems", "QLab", "Use of Ladders", "Working at Height", "Organising Training", "Organising Organising Training Training", "Mental Health First Aid", "Writing RAMS", "Makros Runs", "PAT", "Kit Fixing", "Kit Breaking", "Replacing Lamps", "Flying Pig Systems", "Procrastination", "Drinking Beer", "Sending Emails", "Email Signatures", "Digital Sound Desks", "Digital Lighting Desks", "Painting PS10s", "Chain Lubrication", "Big Power", "BIGGER POWER", "Pixel Mapping", "RDM", "Ladder Inspections", "Losing Crimpaz", "Scrapping Trilite", "Bin Diving", "Wiki Editing"]
|
names = [
|
||||||
|
"Motorised Power Towers",
|
||||||
|
"Catering",
|
||||||
|
"Forgetting Cables",
|
||||||
|
"Gazebo Construction",
|
||||||
|
"Balanced Audio",
|
||||||
|
"Unbalanced Audio",
|
||||||
|
"BBQ/Bin Interactions",
|
||||||
|
"Pushing Boxes",
|
||||||
|
"How Not To Die",
|
||||||
|
"Setting up projectors",
|
||||||
|
"Basketing truss",
|
||||||
|
"First Aid",
|
||||||
|
"Digging Trenches",
|
||||||
|
"Avoiding Bin Lorries",
|
||||||
|
"Getting cherry pickers stuck in mud",
|
||||||
|
"Crashing the Van",
|
||||||
|
"Getting pigs to fly",
|
||||||
|
"Basketing picnics",
|
||||||
|
"Python programming",
|
||||||
|
"Building Cables",
|
||||||
|
"Unbuilding Cables",
|
||||||
|
"Cat Herding",
|
||||||
|
"Pancake making",
|
||||||
|
"Tidying up",
|
||||||
|
"Reading Manuals",
|
||||||
|
"Bikeshedding",
|
||||||
|
"DJing",
|
||||||
|
"Partying",
|
||||||
|
"Teccie Gym",
|
||||||
|
"Putting dust covers on",
|
||||||
|
"Cleaning Lights",
|
||||||
|
"Water Skiing",
|
||||||
|
"Drinking",
|
||||||
|
"Fundamentals of Audio",
|
||||||
|
"Fundamentals of Photons",
|
||||||
|
"Social Interaction",
|
||||||
|
"Discourse Searching",
|
||||||
|
"Discord Searching",
|
||||||
|
"Coiling Cables",
|
||||||
|
"Kit Amnesties",
|
||||||
|
"Van Insurance",
|
||||||
|
"Subhire Insurance",
|
||||||
|
"Paperwork",
|
||||||
|
"More Paperwork",
|
||||||
|
"Second Aid",
|
||||||
|
"Being Old",
|
||||||
|
"Maxihoists",
|
||||||
|
"Sleazyhoists",
|
||||||
|
"Telehoists",
|
||||||
|
"Prolyte",
|
||||||
|
"Prolights",
|
||||||
|
"Making Phonecalls",
|
||||||
|
"Quoting For A Rig",
|
||||||
|
"Basic MIC",
|
||||||
|
"Advanced MIC",
|
||||||
|
"Avoiding MIC",
|
||||||
|
"Washing Cables",
|
||||||
|
"Cable Ramp",
|
||||||
|
"Van Loading",
|
||||||
|
"Trailer Loading",
|
||||||
|
"Storeroom Loading",
|
||||||
|
"Welding",
|
||||||
|
"Fire Extinguishers",
|
||||||
|
"Boring Conference AV",
|
||||||
|
"Flyaway",
|
||||||
|
"Short Leads",
|
||||||
|
"RF Systems",
|
||||||
|
"QLab",
|
||||||
|
"Use of Ladders",
|
||||||
|
"Working at Height",
|
||||||
|
"Organising Training",
|
||||||
|
"Organising Organising Training Training",
|
||||||
|
"Mental Health First Aid",
|
||||||
|
"Writing RAMS",
|
||||||
|
"Makros Runs",
|
||||||
|
"PAT",
|
||||||
|
"Kit Fixing",
|
||||||
|
"Kit Breaking",
|
||||||
|
"Replacing Lamps",
|
||||||
|
"Flying Pig Systems",
|
||||||
|
"Procrastination",
|
||||||
|
"Drinking Beer",
|
||||||
|
"Sending Emails",
|
||||||
|
"Email Signatures",
|
||||||
|
"Digital Sound Desks",
|
||||||
|
"Digital Lighting Desks",
|
||||||
|
"Painting PS10s",
|
||||||
|
"Chain Lubrication",
|
||||||
|
"Big Power",
|
||||||
|
"BIGGER POWER",
|
||||||
|
"Pixel Mapping",
|
||||||
|
"RDM",
|
||||||
|
"Ladder Inspections",
|
||||||
|
"Losing Crimpaz",
|
||||||
|
"Scrapping Trilite",
|
||||||
|
"Bin Diving",
|
||||||
|
"Wiki Editing"]
|
||||||
|
|
||||||
for i, name in enumerate(names):
|
for i, name in enumerate(names):
|
||||||
item = models.TrainingItem.objects.create(category=random.choice(self.categories), reference_number=random.randint(0, 100), name=name)
|
item = models.TrainingItem.objects.create(category=random.choice(self.categories), reference_number=random.randint(0, 100), name=name)
|
||||||
@@ -51,9 +148,15 @@ class Command(BaseCommand):
|
|||||||
|
|
||||||
def setup_levels(self):
|
def setup_levels(self):
|
||||||
items = self.items.copy()
|
items = self.items.copy()
|
||||||
ta = models.TrainingLevel.objects.create(level=models.TrainingLevel.TA, description="Passion will hatred faithful evil suicide noble battle. Truth aversion gains grandeur noble. Dead play gains prejudice god ascetic grandeur zarathustra dead good. Faithful ultimate justice overcome love will mountains inexpedient.", icon="address-card")
|
ta = models.TrainingLevel.objects.create(
|
||||||
|
level=models.TrainingLevel.TA,
|
||||||
|
description="Passion will hatred faithful evil suicide noble battle. Truth aversion gains grandeur noble. Dead play gains prejudice god ascetic grandeur zarathustra dead good. Faithful ultimate justice overcome love will mountains inexpedient.",
|
||||||
|
icon="address-card")
|
||||||
self.levels.append(ta)
|
self.levels.append(ta)
|
||||||
tech_ccs = models.TrainingLevel.objects.create(level=models.TrainingLevel.TECHNICIAN, description="Technician Common Competencies. Spirit abstract endless insofar horror sexuality depths war decrepit against strong aversion revaluation free. Christianity reason joy sea law mountains transvaluation. Sea battle aversion dead ultimate morality self. Faithful morality.", icon="book-reader")
|
tech_ccs = models.TrainingLevel.objects.create(
|
||||||
|
level=models.TrainingLevel.TECHNICIAN,
|
||||||
|
description="Technician Common Competencies. Spirit abstract endless insofar horror sexuality depths war decrepit against strong aversion revaluation free. Christianity reason joy sea law mountains transvaluation. Sea battle aversion dead ultimate morality self. Faithful morality.",
|
||||||
|
icon="book-reader")
|
||||||
tech_ccs.prerequisite_levels.add(ta)
|
tech_ccs.prerequisite_levels.add(ta)
|
||||||
super_ccs = models.TrainingLevel.objects.create(level=models.TrainingLevel.SUPERVISOR, description="Depths disgust hope faith of against hatred will victorious. Law...", icon="user-graduate")
|
super_ccs = models.TrainingLevel.objects.create(level=models.TrainingLevel.SUPERVISOR, description="Depths disgust hope faith of against hatred will victorious. Law...", icon="user-graduate")
|
||||||
for i in range(0, 5):
|
for i in range(0, 5):
|
||||||
@@ -98,4 +201,11 @@ class Command(BaseCommand):
|
|||||||
supervisor.set_password('supervisor')
|
supervisor.set_password('supervisor')
|
||||||
supervisor.groups.add(Group.objects.get(name="Keyholders"))
|
supervisor.groups.add(Group.objects.get(name="Keyholders"))
|
||||||
supervisor.save()
|
supervisor.save()
|
||||||
models.TrainingLevelQualification.objects.create(trainee=supervisor, level=models.TrainingLevel.objects.filter(level__gte=models.TrainingLevel.SUPERVISOR).exclude(department=models.TrainingLevel.HAULAGE).exclude(department__isnull=True).first(), confirmed_on=timezone.now(), confirmed_by=models.Trainee.objects.first())
|
models.TrainingLevelQualification.objects.create(
|
||||||
|
trainee=supervisor,
|
||||||
|
level=models.TrainingLevel.objects.filter(
|
||||||
|
level__gte=models.TrainingLevel.SUPERVISOR).exclude(
|
||||||
|
department=models.TrainingLevel.HAULAGE).exclude(
|
||||||
|
department__isnull=True).first(),
|
||||||
|
confirmed_on=timezone.now(),
|
||||||
|
confirmed_by=models.Trainee.objects.first())
|
||||||
|
|||||||
@@ -10,6 +10,7 @@ from django.utils.timezone import make_aware
|
|||||||
from training import models
|
from training import models
|
||||||
from RIGS.models import Profile
|
from RIGS.models import Profile
|
||||||
|
|
||||||
|
|
||||||
class Command(BaseCommand):
|
class Command(BaseCommand):
|
||||||
epoch = datetime.date(1970, 1, 1)
|
epoch = datetime.date(1970, 1, 1)
|
||||||
id_map = {}
|
id_map = {}
|
||||||
@@ -50,7 +51,7 @@ class Command(BaseCommand):
|
|||||||
tally[0] += 1
|
tally[0] += 1
|
||||||
else:
|
else:
|
||||||
# PYTHONIC, BABY
|
# PYTHONIC, BABY
|
||||||
initials = first_name[0] + "".join([name_section[0] for name_section in re.split("\s*-", last_name.replace("(", ""))])
|
initials = first_name[0] + "".join([name_section[0] for name_section in re.split("\\s*-", last_name.replace("(", ""))])
|
||||||
# print(initials)
|
# print(initials)
|
||||||
new_profile = Profile.objects.create(username=name.replace(" ", ""),
|
new_profile = Profile.objects.create(username=name.replace(" ", ""),
|
||||||
first_name=first_name,
|
first_name=first_name,
|
||||||
@@ -210,7 +211,7 @@ class Command(BaseCommand):
|
|||||||
tally[0] += 1
|
tally[0] += 1
|
||||||
|
|
||||||
for level in models.TrainingLevel.objects.all():
|
for level in models.TrainingLevel.objects.all():
|
||||||
if level.department != None:
|
if level.department is not None:
|
||||||
if level.level == models.TrainingLevel.TECHNICIAN:
|
if level.level == models.TrainingLevel.TECHNICIAN:
|
||||||
level.prerequisite_levels.add(models.TrainingLevel.objects.get(level=models.TrainingLevel.TA), models.TrainingLevel.objects.get(level=models.TrainingLevel.TECHNICIAN, department=None))
|
level.prerequisite_levels.add(models.TrainingLevel.objects.get(level=models.TrainingLevel.TA), models.TrainingLevel.objects.get(level=models.TrainingLevel.TECHNICIAN, department=None))
|
||||||
elif level.level == models.TrainingLevel.SUPERVISOR:
|
elif level.level == models.TrainingLevel.SUPERVISOR:
|
||||||
@@ -259,7 +260,13 @@ class Command(BaseCommand):
|
|||||||
for child in root:
|
for child in root:
|
||||||
try:
|
try:
|
||||||
item = child.find('Item').text.split(".")
|
item = child.find('Item').text.split(".")
|
||||||
obj, created = models.TrainingLevelRequirement.objects.update_or_create(level=models.TrainingLevel.objects.get(pk=int(child.find('Level').text)),item=models.TrainingItem.objects.get(active=True, reference_number=item[1], category=models.TrainingCategory.objects.get(reference_number=item[0])), depth=int(child.find('Depth').text))
|
obj, created = models.TrainingLevelRequirement.objects.update_or_create(
|
||||||
|
level=models.TrainingLevel.objects.get(
|
||||||
|
pk=int(
|
||||||
|
child.find('Level').text)), item=models.TrainingItem.objects.get(
|
||||||
|
active=True, reference_number=item[1], category=models.TrainingCategory.objects.get(
|
||||||
|
reference_number=item[0])), depth=int(
|
||||||
|
child.find('Depth').text))
|
||||||
|
|
||||||
if created:
|
if created:
|
||||||
tally[1] += 1
|
tally[1] += 1
|
||||||
|
|||||||
@@ -15,7 +15,7 @@ class Trainee(Profile, RevisionMixin):
|
|||||||
proxy = True
|
proxy = True
|
||||||
|
|
||||||
def started_levels(self):
|
def started_levels(self):
|
||||||
return [level for level in TrainingLevel.objects.all() if level.percentage_complete(self) > 0]
|
return [level for level in TrainingLevel.objects.all() if level.percentage_complete(self) > 0 and level.percentage_complete(self) < 100]
|
||||||
|
|
||||||
def level_qualifications(self, only_confirmed=False):
|
def level_qualifications(self, only_confirmed=False):
|
||||||
return self.levels.all().filter(confirmed_on__isnull=only_confirmed).select_related('level')
|
return self.levels.all().filter(confirmed_on__isnull=only_confirmed).select_related('level')
|
||||||
@@ -70,9 +70,7 @@ class TrainingItem(models.Model):
|
|||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def user_has_qualification(item, user, depth):
|
def user_has_qualification(item, user, depth):
|
||||||
for q in user.qualifications_obtained.all().select_related('item'):
|
return user.qualifications_obtained.values('item', 'depth').filter(item=item, depth_gte=depth).exists()
|
||||||
if q.item == item and q.depth > depth:
|
|
||||||
return True
|
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
unique_together = ["reference_number", "active", "category"]
|
unique_together = ["reference_number", "active", "category"]
|
||||||
@@ -199,7 +197,7 @@ class TrainingLevel(models.Model, RevisionMixin):
|
|||||||
return 0
|
return 0
|
||||||
|
|
||||||
def user_has_requirements(self, user):
|
def user_has_requirements(self, user):
|
||||||
return all(TrainingItem.user_has_qualification(req.item, user, req.depth) for req in self.requirements.select_related().all())
|
return all(TrainingItem.user_has_qualification(req.item, user, req.depth) for req in self.requirements.all())
|
||||||
|
|
||||||
def __str__(self):
|
def __str__(self):
|
||||||
if self.department is None:
|
if self.department is None:
|
||||||
|
|||||||
@@ -8,6 +8,7 @@ from training import models
|
|||||||
|
|
||||||
register = template.Library()
|
register = template.Library()
|
||||||
|
|
||||||
|
|
||||||
@register.simple_tag
|
@register.simple_tag
|
||||||
def user_has_qualification(user, item, depth):
|
def user_has_qualification(user, item, depth):
|
||||||
if models.TrainingItem.user_has_qualification(item, user, depth) is not None:
|
if models.TrainingItem.user_has_qualification(item, user, depth) is not None:
|
||||||
@@ -15,22 +16,27 @@ def user_has_qualification(user, item, depth):
|
|||||||
else:
|
else:
|
||||||
return mark_safe("<span class='fas fa-hourglass-start text-warning'></span>")
|
return mark_safe("<span class='fas fa-hourglass-start text-warning'></span>")
|
||||||
|
|
||||||
|
|
||||||
@register.simple_tag
|
@register.simple_tag
|
||||||
def user_level_if_present(user, level):
|
def user_level_if_present(user, level):
|
||||||
return models.TrainingLevelQualification.objects.filter(trainee=user, level=level).first()
|
return models.TrainingLevelQualification.objects.filter(trainee=user, level=level).first()
|
||||||
|
|
||||||
|
|
||||||
@register.simple_tag
|
@register.simple_tag
|
||||||
def percentage_complete(level, user):
|
def percentage_complete(level, user):
|
||||||
return level.percentage_complete(user)
|
return level.percentage_complete(user)
|
||||||
|
|
||||||
|
|
||||||
@register.simple_tag
|
@register.simple_tag
|
||||||
def colour_from_depth(depth):
|
def colour_from_depth(depth):
|
||||||
return models.TrainingItemQualification.get_colour_from_depth(depth)
|
return models.TrainingItemQualification.get_colour_from_depth(depth)
|
||||||
|
|
||||||
|
|
||||||
@register.filter
|
@register.filter
|
||||||
def get_supervisor(tech):
|
def get_supervisor(tech):
|
||||||
return models.TrainingLevel.objects.get(department=tech.department, level=models.TrainingLevel.SUPERVISOR)
|
return models.TrainingLevel.objects.get(department=tech.department, level=models.TrainingLevel.SUPERVISOR)
|
||||||
|
|
||||||
|
|
||||||
@register.filter
|
@register.filter
|
||||||
def get_levels_of_depth(trainee, level):
|
def get_levels_of_depth(trainee, level):
|
||||||
return trainee.level_qualifications(True).filter(level__level=level)
|
return trainee.level_qualifications(True).filter(level__level=level)
|
||||||
|
|||||||
Reference in New Issue
Block a user