Project

General

Profile

Download (2.13 KB) Statistics
| Branch: | Tag: | Revision:
61861b9b Jérôme Schneider
# -*- coding: utf-8 -*-
4376fbf4 Jérôme Schneider
from ajax_select import LookupChannel
677c2c8d Jérôme Schneider
from calebasse.dossiers.models import PatientRecord, PatientAddress
533ce0c8 Benjamin Dauvergne
from django.core.exceptions import PermissionDenied
4376fbf4 Jérôme Schneider
class PatientRecordLookup(LookupChannel):
model = PatientRecord
cd8a83dc Jérôme Schneider
search_field = 'last_name'
61861b9b Jérôme Schneider
homonym = False
4376fbf4 Jérôme Schneider
def get_query(self,q,request):
cd8a83dc Jérôme Schneider
kwargs = { "%s__istartswith" % self.search_field : q }
qs = self.model.objects.filter(**kwargs).order_by(self.search_field)
4376fbf4 Jérôme Schneider
if request.COOKIES.has_key('home-service'):
8f89c608 Jérôme Schneider
service = request.COOKIES['home-service'].upper().replace('-', ' ')
4376fbf4 Jérôme Schneider
qs = qs.filter(service__name=service)
61861b9b Jérôme Schneider
#nb = qs.count()
#nb_distinct = qs.distinct('display_name').count()
#if nb != nb_distinct:
# self.homonym = True
qs.prefetch_related('last_state__status')
4376fbf4 Jérôme Schneider
return qs

61861b9b Jérôme Schneider
def format_match(self,obj):
4e4c4c50 Jérôme Schneider
return self.format_item_display(texte)

def get_result(self, obj):
return self.format_item_display(obj)

def format_match(self, obj):
return self.format_item_display(obj)

def format_item_display(self,obj):
text = obj.last_name.upper() + ' ' + obj.first_name
a6638759 Jérôme Schneider
if obj.paper_id or obj.last_state:
text += u' ('
cffbd8a2 Jérôme Schneider
if obj.paper_id:
a6638759 Jérôme Schneider
text += obj.paper_id
if obj.last_state:
text += u' - '
61861b9b Jérôme Schneider
if obj.last_state:
a6638759 Jérôme Schneider
text += obj.last_state.status.name
if obj.paper_id or obj.last_state:
text += u')'
4e4c4c50 Jérôme Schneider
return unicode(text)
cffbd8a2 Jérôme Schneider
533ce0c8 Benjamin Dauvergne
def check_auth(self, request):
if not request.user.is_authenticated():
raise PermissionDenied
677c2c8d Jérôme Schneider
class PatientAddressLookup(LookupChannel):
model = PatientAddress
search_field = 'display_name'

def get_query(self, q, request):
qs = super(PatientAddressLookup, self).get_query(q, request)
if request.session.has_key('patientrecord_id'):
qs = qs.filter(patientcontact__id=request.session['patientrecord_id'])
return qs
533ce0c8 Benjamin Dauvergne
def check_auth(self, request):
if not request.user.is_authenticated():
raise PermissionDenied