FIX #488: Unable to filter detailed training record by item ID

This commit is contained in:
2022-02-14 11:14:32 +00:00
parent 05d280172d
commit aa19ceaf18
2 changed files with 26 additions and 18 deletions

View File

@@ -1,7 +1,8 @@
from RIGS.models import Profile, filter_by_pk
from reversion import revisions as reversion
from django.db import models
from django.db.models import Q
from django.db.models import Q, F, Value, CharField
from django.db.models.functions import Concat
from django.urls import reverse
from django.utils.safestring import mark_safe
from versioning.versioning import RevisionMixin
@@ -80,8 +81,7 @@ class TrainingItemManager(QueryablePropertiesManager):
def search(self, query=None):
qs = self.get_queryset()
if query is not None:
or_lookup = (Q(description__icontains=query)
)
or_lookup = (Q(description__icontains=query) | Q(display_id=query))
qs = qs.filter(or_lookup).distinct() # distinct() is often necessary with Q lookups
return qs
@@ -107,9 +107,12 @@ class TrainingItem(models.Model):
@classmethod
def display_id(cls, lookup, value):
if '.' in str(value):
category_number, number = value.split('.')
if category_number and number:
return models.Q(category__reference_number=category_number, reference_number=number)
try:
category_number, number = value.split('.', 2)
if category_number and number:
return Q(category__reference_number=int(category_number), reference_number=int(number))
except ValueError:
pass
return models.Q()
def __str__(self):
@@ -130,6 +133,21 @@ class TrainingItem(models.Model):
ordering = ['category__reference_number', 'reference_number']
class TrainingItemQualificationManager(QueryablePropertiesManager):
def search(self, query=None):
qs = self.get_queryset().select_related('item', 'supervisor', 'item__category')
if query is not None:
or_lookup = (Q(item__description__icontains=query) | Q(supervisor__first_name__icontains=query) | Q(supervisor__last_name__icontains=query) | Q(item__category__name__icontains=query) | Q(item__display_id=query))
try:
or_lookup = Q(item__category__reference_number=int(query)) | or_lookup
except: # noqa
pass
qs = qs.filter(or_lookup).distinct()
return qs
@reversion.register
class TrainingItemQualification(models.Model, RevisionMixin):
STARTED = 0
@@ -149,7 +167,7 @@ class TrainingItemQualification(models.Model, RevisionMixin):
notes = models.TextField(blank=True)
# TODO Maximum depth - some things stop at Complete and you can't be passed out in them
objects = QueryablePropertiesManager()
objects = TrainingItemQualificationManager()
def __str__(self):
return f"{self.get_depth_display()} in {self.item} on {self.date.strftime('%b %d %Y')}"

View File

@@ -47,17 +47,7 @@ class TraineeItemDetail(generic.ListView):
template_name = 'trainee_item_list.html'
def get_queryset(self):
q = self.request.GET.get('q', "")
filter = Q(item__description__icontains=q) | Q(supervisor__first_name__icontains=q) | Q(supervisor__last_name__icontains=q)
try:
filter = filter | Q(item__display_id=int(q[0]))
except: # noqa
# not an integer
pass
return models.Trainee.objects.get(pk=self.kwargs['pk']).qualifications_obtained.all().filter(filter).order_by('-item__display_id').select_related('item', 'trainee', 'supervisor', 'item__category')
return models.Trainee.objects.get(pk=self.kwargs['pk']).qualifications_obtained.search(self.request.GET.get('q')).order_by('item__category__reference_number', 'item__reference_number').select_related('item', 'trainee')
def get_context_data(self, **kwargs):
context = super().get_context_data(**kwargs)