search #8

Merged
cayop merged 3 commits from search into main 2024-10-09 16:04:01 +00:00
Showing only changes of commit e0258cbf02 - Show all commits

View file

@ -3,6 +3,7 @@ import json
from django.utils.translation import gettext_lazy as _ from django.utils.translation import gettext_lazy as _
from django.views.generic.edit import FormView from django.views.generic.edit import FormView
from django.shortcuts import Http404 from django.shortcuts import Http404
from django.db.models import Q
from dashboard.mixins import InventaryMixin, DetailsMixin from dashboard.mixins import InventaryMixin, DetailsMixin
from evidence.models import Annotation from evidence.models import Annotation
@ -40,7 +41,7 @@ class LotDashboardView(InventaryMixin, DetailsMixin):
chids = self.object.devicelot_set.all().values_list( chids = self.object.devicelot_set.all().values_list(
"device_id", flat=True "device_id", flat=True
).distinct() ).distinct()
chids_page = chids[offset:offset+limit] chids_page = chids[offset:offset+limit]
return [Device(id=x) for x in chids_page], chids.count() return [Device(id=x) for x in chids_page], chids.count()
@ -50,21 +51,24 @@ class SearchView(InventaryMixin):
section = "Search" section = "Search"
title = _("Search Devices") title = _("Search Devices")
breadcrumb = "Devices / Search Devices" breadcrumb = "Devices / Search Devices"
def get_devices(self, user, offset, limit): def get_devices(self, user, offset, limit):
post = dict(self.request.POST) post = dict(self.request.POST)
query = post.get("search") query = post.get("search")
if not query: if not query:
return [], 0 return [], 0
matches = search( matches = search(
self.request.user.institution, self.request.user.institution,
query[0], query[0],
offset, offset,
limit limit
) )
if not matches.size():
return self.search_hids(query, offset, limit)
annotations = [] annotations = []
for x in matches: for x in matches:
annotations.extend(self.get_annotations(x)) annotations.extend(self.get_annotations(x))
@ -76,10 +80,26 @@ class SearchView(InventaryMixin):
def get_annotations(self, xp): def get_annotations(self, xp):
snap = xp.document.get_data() snap = xp.document.get_data()
uuid = json.loads(snap).get('uuid') uuid = json.loads(snap).get('uuid')
return Annotation.objects.filter( return Annotation.objects.filter(
type=Annotation.Type.SYSTEM, type=Annotation.Type.SYSTEM,
owner=self.request.user.institution, owner=self.request.user.institution,
uuid=uuid uuid=uuid
).values_list("value", flat=True).distinct() ).values_list("value", flat=True).distinct()
def search_hids(self, query, offset, limit):
qry = Q()
for i in query[0].split(" "):
if i:
qry |= Q(value__startswith=i)
chids = Annotation.objects.filter(
type=Annotation.Type.SYSTEM,
owner=self.request.user.institution
).filter(
qry
).values_list("value", flat=True).distinct()
chids_page = chids[offset:offset+limit]
return [Device(id=x) for x in chids_page], chids.count()