Skip to main content

This app makes it easy to display a map for a given address.

Project description

This app makes it easy to display a map for given address in django templates. No API keys, manual geocoding, html/js copy-pasting or django model changes is needed.

The license is MIT.

Installation

pip install geopy
pip install django-easy-maps

Then add ‘easy_maps’ to INSTALLED_APPS and run ./manage.py syncdb (or ./manage.py migrate easy_maps if South is in use)

Usage

This app provides an easy_map template tag:

{% easy_map <address> [<width> <height>] [<zoom>] [using <template_name>] %}

Examples:

{% load easy_maps_tags %}

<!-- Default map with 300x400 dimensions -->
{% easy_map "Russia, Ekaterinburg, Mira 32" 300 400 %}

<!-- Variable address, custom detail level and custom template -->
{% easy_map address 200 200 5 using 'map.html' %}

The coordinates for map will be obtained using google geocoder on first access. Then they’ll be cached in DB. Django’s template caching can be used later in order to prevent DB access on each map render:

{% load easy_maps_tags cache %}

{% cache 600 my_map firm.address %}
    {% easy_map firm.address 300 400 %}
{% endcache %}

Customization

If the default map template is not sufficient then custom map template can be used:

{% easy_map address using 'map.html' %}

<!-- or -->

{% easy_map address 200 300 5 using 'map.html' %}

The template will have ‘map’ (it is the easy_maps.models.Address instance), ‘width’, ‘height’ and ‘zoom’ variables. The outer template context is passed to ‘map.html’ as well.

The default template can be found here: https://bitbucket.org/kmike/django-easy-maps/src/tip/easy_maps/templates/easy_maps/map.html

You can start your own template from scratch or just override some blocks in the default template.

Address model

easy_maps.models.Address model has the following fields:

  • address - the requested address

  • computed_address - address returned by geocoder

  • longtitude

  • latitude

  • geocode_error - True if geocoder wasn’t able to handle the address

Contributing

If you’ve found a bug, implemented a feature or customized the template and think it is useful then please consider contributing. Patches, pull requests or just suggestions are welcome!

Source code: https://bitbucket.org/kmike/django-easy-maps/

Bug tracker: https://bitbucket.org/kmike/django-easy-maps/issues/new

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-easy-maps-0.5.tar.gz (5.0 kB view details)

Uploaded Source

File details

Details for the file django-easy-maps-0.5.tar.gz.

File metadata

File hashes

Hashes for django-easy-maps-0.5.tar.gz
Algorithm Hash digest
SHA256 9f3d41046ffaeba358163ce07ecc87f3c7feb9bf0cd34105ec65512f4ad36b8d
MD5 ed5c4a84f4aacb90147afcba115771e1
BLAKE2b-256 4039ab06ae35b43dbf65bbf92f004035641d167ee05a1f3540173bb3a475f347

See more details on using hashes here.

Provenance

Supported by

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