Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/erdem/django-map-widgets
Highly customizable, intuitive, and user-friendly map widgets for GeoDjango applications.
https://github.com/erdem/django-map-widgets
django django-admin django-map-widgets geodjango geolocation geospatial map-widgets
Last synced: about 10 hours ago
JSON representation
Highly customizable, intuitive, and user-friendly map widgets for GeoDjango applications.
- Host: GitHub
- URL: https://github.com/erdem/django-map-widgets
- Owner: erdem
- License: mit
- Created: 2016-02-21T14:27:13.000Z (almost 9 years ago)
- Default Branch: main
- Last Pushed: 2024-12-16T15:01:07.000Z (28 days ago)
- Last Synced: 2025-01-09T03:11:50.786Z (4 days ago)
- Topics: django, django-admin, django-map-widgets, geodjango, geolocation, geospatial, map-widgets
- Language: JavaScript
- Homepage:
- Size: 22.9 MB
- Stars: 455
- Watchers: 20
- Forks: 123
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
![CI](https://github.com/erdem/django-map-widgets/workflows/CI/badge.svg)
[![PyPI version](https://badge.fury.io/py/django-map-widgets.svg?c=1)](https://badge.fury.io/py/django-map-widgets)
![License](https://img.shields.io/github/license/erdem/django-map-widgets.svg)
![Documentation Status](https://readthedocs.org/projects/django-map-widgets/badge/?version=latest)## 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. Currently, the package supports Google, Mapbox, and Leaflet mapping platforms.![mapbox_interactive demo](https://github.com/erdem/django-map-widgets/assets/1518272/e6e454f0-6486-4fe7-a0b3-712b9371030a)
---
- [Documentation](http://django-map-widgets.readthedocs.io/)
- [Demo Project](https://github.com/erdem/django-map-widgets/tree/main/demo)
- [Home Page](https://github.com/erdem/django-map-widgets/)### Installation
```shell
pip install django-map-widgets
```Add ‘mapwidgets’ to your `INSTALLED_APPS` in settings.py
```python
INSTALLED_APPS = [
...
'django.contrib.sessions',
'django.contrib.staticfiles','mapwidgets',
]```
Ensure `collectstatic` Django admin command is run before using the widgets in production.
```shell
python manage.py collectstatic
```### Usage
**Django Admin Usage**
```python
from django.contrib.gis.db import models
import mapwidgetsclass CityAdmin(admin.ModelAdmin):
formfield_overrides = {
models.PointField: {"widget": mapwidgets.GoogleMapPointFieldWidget}
}
```**Django Forms Usage**
```python
from mapwidgets.widgets import GoogleMapPointFieldWidget, MapboxPointFieldWidgetclass 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](http://django-map-widgets.readthedocs.io/settings).```python
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](http://django-map-widgets.readthedocs.io/contribution).### Screenshots
##### MapBox Interactive Point Field Widget
##### MapBox Static Point Field Widget
![](https://github.com/erdem/django-map-widgets/assets/1518272/491f2091-5620-4a50-9ed8-d63ddba3a88b)
##### GoogleMap Interactive Point Field Widget
![](https://github.com/erdem/django-map-widgets/assets/1518272/4da33221-20f6-4c44-875c-f1d4b0f98e5a)
##### Leaflet Interactive Point Field Widget
![](https://github.com/erdem/django-map-widgets/assets/1518272/a45158f7-2ec0-4e1a-8dfa-8da0442b832f)
and more...