diff options
author | luxagraf <sng@luxagraf.net> | 2018-06-08 20:53:14 -0500 |
---|---|---|
committer | luxagraf <sng@luxagraf.net> | 2018-06-08 20:53:14 -0500 |
commit | 90822f204979663c79444ef8e89bda4701b8defb (patch) | |
tree | b7de5c94ffc42fa71f7c822ff0c92f2b9bcbb55f /app/sightings | |
parent | a32a107db3fe5b5c0742b2ba3f6a767f427fec5e (diff) |
got inline map working
Diffstat (limited to 'app/sightings')
-rw-r--r-- | app/sightings/admin.py | 37 |
1 files changed, 31 insertions, 6 deletions
diff --git a/app/sightings/admin.py b/app/sightings/admin.py index ce1c66a..03aaa83 100644 --- a/app/sightings/admin.py +++ b/app/sightings/admin.py @@ -1,13 +1,13 @@ +import copy from django.contrib import admin from django.contrib.gis.admin import OSMGeoAdmin -from django.contrib.gis.db.models import PointField from .models import APClass, AP, Sighting from photos.forms import GalleryForm from utils.util import get_latlon from utils.widgets import CustomSelectMultiple, LGEntryForm from .forms import SightingsForm -from mapwidgets.widgets import GooglePointFieldInlineWidget +from django.contrib.admin.options import FORMFIELD_FOR_DBFIELD_DEFAULTS class GalleryFormPlus(GalleryForm): def __init__(self, *args, **kwargs): @@ -25,12 +25,37 @@ class APClassAdmin(admin.ModelAdmin): list_filter = ('kind',) -class SightingInline(admin.StackedInline): +class SightingInline(OSMGeoAdmin, admin.StackedInline): + """ + This is very fragile and probably a bad idea since I copied this + code straight from Django and it may change, but it works for now + """ model = Sighting extra = 1 - formfield_overrides = { - PointField: {"widget": GooglePointFieldInlineWidget} - } + lat, lon = get_latlon() + default_lon = lon + default_lat = lat + default_zoom = 13 + units = True + scrollable = False + map_width = 700 + map_height = 425 + map_template = 'gis/admin/osm.html' + openlayers_url = '/static/admin/js/OpenLayers.js' + + def __init__(self, parent_model, admin_site): + self.admin_site = admin_site + self.parent_model = parent_model + self.opts = self.model._meta + self.has_registered_model = admin_site.is_registered(self.model) + overrides = copy.deepcopy(FORMFIELD_FOR_DBFIELD_DEFAULTS) + for k, v in self.formfield_overrides.items(): + overrides.setdefault(k, {}).update(v) + self.formfield_overrides = overrides + if self.verbose_name is None: + self.verbose_name = self.model._meta.verbose_name + if self.verbose_name_plural is None: + self.verbose_name_plural = self.model._meta.verbose_name_plural @admin.register(AP) |