merged with sanj..
This commit is contained in:
commit
9d565b191d
|
@ -66,14 +66,20 @@ def areas(request):
|
|||
|
||||
def stops(request):
|
||||
q = request.GET.get("q", "")
|
||||
ctype = ContentType.objects.get_for_model(Stop)
|
||||
stops = []
|
||||
if q != '':
|
||||
qset = Stop.objects.find_approximate(q, TRIGRAM_THRESHOLD)
|
||||
alt_name_matches = AlternativeName.objects.find_approximate(q, TRIGRAM_THRESHOLD).filter(content_type=ctype)
|
||||
for alt_name in alt_name_matches:
|
||||
stop = alt_name.content_object
|
||||
if stop not in stops:
|
||||
stops.append(stop)
|
||||
else:
|
||||
qset = Stop.objects.all()
|
||||
stops = Stop.objects.all()
|
||||
srid = int(request.GET.get("srid", 4326))
|
||||
return render_to_json_response({
|
||||
'type': 'FeatureCollection',
|
||||
'features': [stop.get_geojson(srid=srid) for stop in qset]
|
||||
'features': [stop.get_geojson(srid=srid) for stop in stops]
|
||||
})
|
||||
|
||||
|
||||
|
|
|
@ -180,7 +180,7 @@ class Stop(models.Model):
|
|||
'name_mr': self.name_mr,
|
||||
'direction': self.dbdirection,
|
||||
'routes': ", ".join([r.alias for r in routes]),
|
||||
'alternative_names': ", ".join([a.name for a in self.alt_names.all().filter(typ='common')]),
|
||||
'alternative_names': ", ".join([a.name for a in self.alt_names.all()]),
|
||||
'url': self.get_absolute_url()
|
||||
}
|
||||
|
||||
|
@ -427,6 +427,7 @@ ALT_TYPE_CHOICES = (
|
|||
)
|
||||
|
||||
class AlternativeName(models.Model):
|
||||
objects = TrigramSearchManager(('name',))
|
||||
name = models.CharField(max_length=512)
|
||||
name_mr = models.CharField(max_length=512, blank=True)
|
||||
typ = models.CharField(max_length=64, choices=ALT_TYPE_CHOICES, default="alt")
|
||||
|
|
Loading…
Reference in New Issue
Block a user