diff options
-rw-r--r-- | chimere/models.py | 29 | ||||
-rw-r--r-- | chimere/views.py | 2 |
2 files changed, 22 insertions, 9 deletions
diff --git a/chimere/models.py b/chimere/models.py index d00d0b6..27156bd 100644 --- a/chimere/models.py +++ b/chimere/models.py @@ -906,18 +906,30 @@ class GeographicItem(models.Model): select={'json': 'ST_AsGeoJSON({})'.format(cls.geom_attr)} ).values(*q_values) - vals, added, current_categories, icons = [], [], {}, {} + vals, current_categories, icons = {}, {}, {} start, end = 0, None if slice: start, end = slice has_next = False for item in q.all(): - if item['pk'] in added: + if item['pk'] in vals: + # multi-category for this item + value = vals[item['pk']] + icon, icons = cls._json_get_icons(item, current_categories) + colors, current_categories = \ + cls._json_get_colors(item, default_values, + current_categories) + if not icon and not colors: + # something went wrong when fetching icon / colors + continue + if icon not in value['properties']['extra_icons']: + value['properties']['extra_icons'].append(icon) + if colors not in value['properties']['extra_colors']: + value['properties']['extra_colors'].append(colors) continue if limit_to_categories and \ item["categories__pk"] not in limit_to_categories: continue - added.append(item['pk']) if start: start -= 1 end -= 1 @@ -926,7 +938,8 @@ class GeographicItem(models.Model): has_next = True break properties = {"pk": item['pk'], "name": item['name'], - 'key': "{}-{}".format(cls.geom_attr, item['pk'])} + 'key': "{}-{}".format(cls.geom_attr, item['pk']), + "extra_icons": [], "extra_colors": []} icon, icons = cls._json_get_icons(item, current_categories) colors, current_categories = \ cls._json_get_colors(item, default_values, current_categories) @@ -941,14 +954,14 @@ class GeographicItem(models.Model): except json.decoder.JSONDecodeError: continue - vals.append({ + vals[item['pk']] = { "type": "Feature", "geometry": geom, "properties": properties - }) + } if not check_next: - return vals - return vals, has_next + return vals.values() + return vals.values(), has_next @classmethod def search(cls, query, area=None, get_json=False, slice=None, diff --git a/chimere/views.py b/chimere/views.py index d260a65..00b7f95 100644 --- a/chimere/views.py +++ b/chimere/views.py @@ -714,7 +714,7 @@ def _getGeoObjects(area_name, category_ids, status='A', getjson=True, query = models.Marker.objects.filter(q) if bounding_box: query = query.filter(point__contained=bounding_box) - query = query.distinct('pk').order_by('-pk') + query = query.order_by('-pk') except: return empty, zoom_need_reload |