Skip to main content

Configurable and user-friendly map widgets for GeoDjango fields

Project description

https://badge.fury.io/py/django-map-widgets.svg

Django Map Widgets

Django Map Widgets is a package that provides highly configurable, pluggable, and user-friendly map widgets for GeoDjango form fields. It simplifies the integration of interactive maps into GeoDjango applications, enhancing the overall development experience.

The primary goal of Django Map Widgets is to bridge the gap between powerful GeoDjango functionality and user-friendly map interactions, creating a more accessible and enjoyable experience for both developers and end-users of GeoDjango-powered applications.

Mapbox Interactive Widget

Installation

pip install django-map-widgets

Add ‘mapwidgets’ to your INSTALLED_APPS in settings.py

INSTALLED_APPS = [
    ...
    'django.contrib.sessions',
    'django.contrib.staticfiles',

    'mapwidgets',
]

Ensure collectstatic Django admin command is run before using the widgets in production.

python manage.py collectstatic

Usage

Django Admin Usage

from django.contrib.gis.db import models
import mapwidgets


class CityAdmin(admin.ModelAdmin):
    formfield_overrides = {
        models.PointField: {"widget": mapwidgets.GoogleMapPointFieldWidget}
    }

Django Forms Usage

from mapwidgets.widgets import GoogleMapPointFieldWidget, MapboxPointFieldWidget


class CityForm(forms.ModelForm):
    class Meta:
        model = City
        fields = ("coordinates", "city_hall")
        widgets = {
            'coordinates': GoogleMapPointFieldWidget,
            'city_hall': MapboxPointFieldWidget,
        }

When the map widgets are used in Django web views with forms, Remember to include {{ form.media }} template tag in the view templates.

Settings

The JavaScript map rendering behavior of the widgets can be customized by providing MAP_WIDGETS config in the project’s settings file. For detailed guidance on map customization options, check the settings guide.

GOOGLE_MAP_API_KEY = os.getenv("GOOGLE_MAP_API_KEY")
MAPBOX_ACCESS_TOKEN = os.getenv("MAPBOX_ACCESS_TOKEN")

MAP_WIDGETS = {
    "GoogleMap": {
        "apiKey": GOOGLE_MAP_API_KEY,
        "PointField": {
            "interactive": {
                "mapOptions": {
                    "zoom": 15,  # set initial zoom
                    "streetViewControl": False,
                },
                "GooglePlaceAutocompleteOptions": {
                    "componentRestrictions": {"country": "uk"}
                },
            }
        }
    },
    "Mapbox": {
        "accessToken": MAPBOX_ACCESS_TOKEN,
        "PointField": {
            "interactive": {
                "mapOptions": {"zoom": 12, "center": (51.515618, -0.091998)},
                "markerFitZoom": 14,
            }
        },
    },
    "Leaflet": {
        "PointField": {
            "interactive": {
                "mapOptions": {
                    "zoom": 12,
                    "scrollWheelZoom": False
                }
            }
        },
        "markerFitZoom": 14,
    }
}

JQuery Requirement

jQuery is required for Django Map Widgets to function in regular Django views. However, if the widgets is being used within the Django Admin, jQuery does not need to be provided separately. Any map widget class can be configured as described in the documentation, and they will work out of the box.

Preferable jQuery version is 3.7-slim.

Support

Django Map Widgets offers two types of widgets:

  1. Interactive (Dynamic) Widgets: These widgets allow users to interact with the map, such as clicking to set a location or dragging a marker. They are ideal for data input and editing scenarios.

  2. Static (Read-only) Widgets: These widgets display map data in a non-interactive format. They are useful for presenting location information without allowing modifications.

Widget Support Matrix

GeoDjango Field

GoogleMap

Mapbox

Leaflet

Interactive

Static

Interactive

Static

Interactive

Static

PointField

N/A

LineStringField

✖️

✖️

✖️

✖️

✖️

N/A

PolygonField

✖️

✖️

✖️

✖️

✖️

N/A

MultiPointField

✖️

✖️

✖️

✖️

✖️

N/A

MultiLineStringField

✖️

✖️

✖️

✖️

✖️

N/A

MultiPolygonField

✖️

✖️

✖️

✖️

✖️

N/A

Contribution

Currently, the package supports Google, Mapbox, and Leaflet mapping platforms. If you have ideas for additional map providers or new features, or even if you want to help extend support to other GeoDjango form fields, feel free to do so. We would be happy to review and merge your contributions.

For more info how to contribute, please check out the contribution guidelines.

Screenshots

MapBox Interactive Point Field Widget

MapBox Interactive Point Field Widget

MapBox Static Point Field Widget

MapBox Static Point Field Widget

GoogleMap Interactive Point Field Widget

GoogleMap Interactive Point Field Widget

Leaflet Interactive Point Field Widget

Leaflet Interactive Point Field Widget

and more…

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django_map_widgets-0.5.0.tar.gz (160.8 kB view details)

Uploaded Source

Built Distribution

django_map_widgets-0.5.0-py3-none-any.whl (256.0 kB view details)

Uploaded Python 3

File details

Details for the file django_map_widgets-0.5.0.tar.gz.

File metadata

  • Download URL: django_map_widgets-0.5.0.tar.gz
  • Upload date:
  • Size: 160.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.12.0 pkginfo/1.8.3 requests/2.28.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.13

File hashes

Hashes for django_map_widgets-0.5.0.tar.gz
Algorithm Hash digest
SHA256 3642dfcb6af5bc69d71a7964e0dccedb63118ef412ff135fee145a3ff91f6992
MD5 6e96b6500cdb1230fca4f34d7ba47185
BLAKE2b-256 d8a9a9fa5f7f6ceda705094462ce78ed02bdd12777cbcf239c0f49d2b14a1788

See more details on using hashes here.

File details

Details for the file django_map_widgets-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: django_map_widgets-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 256.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.12.0 pkginfo/1.8.3 requests/2.28.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.13

File hashes

Hashes for django_map_widgets-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 af694f593b8837e9909194ec5c6a5895c52361fb956b27eff62454c62315720d
MD5 faf98f709e84222cbad1eb8246eaa7c3
BLAKE2b-256 7d3692e374b13cb3d43c17860de4a3f520ec532451da0981b9f0463d6c293138

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page