Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/legolasvzla/django-google-maps
Basic example of how to use Google Maps with Django and PostGIS
https://github.com/legolasvzla/django-google-maps
django django-rest-framework geocoding geopy google-maps-api postgis python3
Last synced: about 2 months ago
JSON representation
Basic example of how to use Google Maps with Django and PostGIS
- Host: GitHub
- URL: https://github.com/legolasvzla/django-google-maps
- Owner: LegolasVzla
- License: mit
- Created: 2019-07-08T20:46:30.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2022-12-08T05:53:22.000Z (about 2 years ago)
- Last Synced: 2023-03-05T11:55:32.380Z (almost 2 years ago)
- Topics: django, django-rest-framework, geocoding, geopy, google-maps-api, postgis, python3
- Language: JavaScript
- Homepage:
- Size: 966 KB
- Stars: 6
- Watchers: 1
- Forks: 7
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# django-google-maps
Basic example of how to use Google Maps with Django and PostGIS![](https://raw.githubusercontent.com/LegolasVzla/django-google-maps/master/core/static/media/app_image1.jpeg "App Image")
## Technologies
- [Django REST framework](https://www.django-rest-framework.org/) is a powerful and flexible toolkit for building Web APIs.- [PostgreSQL](https://www.postgresql.org/) is the World's Most Advanced Open Source Relational Database.
- [PostGIS](http://postgis.net/) is a spatial database extender for PostgreSQL object-relational database. It adds support for geographic objects allowing location queries to be run in SQL.
- [Geopy](https://geopy.readthedocs.io/en/stable/) is a Python client for several popular geocoding web services.
- [Amazon S3](https://aws.amazon.com/s3/): Amazon Simple Storage Service (Amazon S3) is an object storage service that offers industry-leading scalability, data availability, security, and performance.
## Requirements
- Ubuntu 18## Installation
Clone this project:
git clone https://github.com/LegolasVzla/django-google-maps.git
```Makefile``` will help you with all the installation. First of all, in ```django-google-maps/core/``` path, execute:
make setup
This will install PostgreSQL, PostGIS and pip on your system. After that, you need to create and fill up **settings.ini** file, with the structure as below:
[postgresdbConf]
DB_ENGINE=django.contrib.gis.db.backends.postgis
DB_NAME=dbname
DB_USER=user
DB_PASS=password
DB_HOST=host
DB_PORT=port[GEOSGeometryConf]
max_distance=5[googleMapsConf]
API_KEY=yourGoogleAPIKey
defaultLat=
defaultLng=[amazonS3Conf]
S3_ACCESS_KEY=
S3_SECRET_KEY=
s3_bucket_name=[font-awesomeConf]
KEY=- postgresdbConf section: fill in with your own PostgreSQL credentials. By default, DB_HOST and DB_PORT in PostgreSQL are localhost/5432.
- GEOSGeometryConf section: a ```max_distance``` suggested could be from 1-5 kilometers, to display nearby places.
- googleMapsConf section: google maps API KEY needed to load the map, also a default lat and longitude to focus your map
- font-awesomeConf section: optional, if you have a Font Awesome key for icons
Then, activate your virtualenv already installed (by default, is called ```env``` in the ```Makefile```):
source env/bin/activate
And execute:
make install
This will generate the database with default data and also it will install python requirements and nltk resources. Default credentials for admin superuser are: [email protected] / admin.
Run django server (by default, host and port are set as 127.0.0.1 and 8000 respectively in the ```Makefile```):
make execute
You could see the home page in:
http://127.0.0.1:8000/index/
The map will be setting in the ```defaultLat``` and ```defaultLng``` position.
## Models
- Spots: table to store places of the users. This table contains a position (PostGIS geometry) column that works to store information of latitude and longitude in WGS 84 format.
- Tags: table to store tags related with the spots## Endpoints Structure for Spots API
In a RESTful API, endpoints (URLs) define the structure of the API and how end users access data from our application using the HTTP methods (GET, POST, PUT, DELETE), making all posssible CRUD (create, retrieve, update, delete) operations.
http://127.0.0.1:8000/api/spots/Endpoint |HTTP Method | CRUD Method | Result
-- | -- |-- |--
`api/` | GET | READ | Get all the record
`api//:id` | GET | READ | Get a single record
`api/`| POST | CREATE | Create a new record
`api//:id` | PUT | UPDATE | Update a record
`api//:id` | DELETE | DELETE | Delete a record## Aditional Endpoints related with possible actions
**Add a custom place (CREATE)**
* Endpoint path: `api/spots/create_spot/`
In "GoogleMaps" tab, you can create a new spot doing click in a position of the map and then doing click on the "Add Place" buttom: ![](https://raw.githubusercontent.com/LegolasVzla/django-google-maps/master/core/static/media/app_image3.jpeg "Add Place"), fill up the form and save your spot. Also, you can create a several list of tags for you place.
![](https://raw.githubusercontent.com/LegolasVzla/django-google-maps/master/core/static/media/app_image2.jpeg "App Image")
Note: I used [tagEditor](https://goodies.pixabay.com/jquery/tag-editor/demo.html) plugin to create and edit tags, unfortunately this project is death but was the most recent jQuery tag editor that I could found.
**See spots details (READ)**
* Endpoint path: `api/spots/user_places/`
In "My Spot List" tab, you can see all the details of your spot list.
**Spot details (RETRIEVE)**
* Endpoint path: `api/spots/spot_details/`
In "My Spot List" tab, you can click on any spot and see the information related with it.
**Edit spots (UPDATE)**
* Endpoint path: `api/spots/edit_spot/`
In "My Spot List" tab, you can edit spots by changging name or tags related with it.
**Remove a place (DELETE)**
* Endpoint path: `api/spots/delete_spot/`
In "My Spot List" tab, you can delete a spot in the garbage icon. This action will delete the tags related with the spot if those tags doesn't exists for any other spot.
**Nearby places**
* Endpoint path: `api/spots/nearby_places/`
In "GoogleMaps" tab, you can display nearby places from your current position within 'max_distance' in the nearby buttom: ![](https://raw.githubusercontent.com/LegolasVzla/django-google-maps/master/core/static/media/app_image4.jpeg "Nearby Places"). The map will show your nearby places with the icon below: ![](https://raw.githubusercontent.com/LegolasVzla/django-google-maps/master/core/static/media/place_icon.png "Custom Spot")
## Querying geometry data in PgAdmin4
Spots table contains two geometry columns in WGS 84 format (SRID 4326):
- geom
- positionThat means that you can querying and watch our geometry data in PgAdmin4 as follow:
![](https://raw.githubusercontent.com/LegolasVzla/django-google-maps/master/core/static/media/pgadmin_image1.jpeg "pgAdmin4 geometry Query")
Now you can see an Eye Icon that means you can watch our data in the pgadmin map:
![](https://raw.githubusercontent.com/LegolasVzla/django-google-maps/master/core/static/media/pgadmin_image2.jpeg "pgAdmin4 map")
That's great! also you can watch it in differents layers (street, topography...)
Note: If our layers have an SRID other than 4326, the map will show the layers, but without a background.
## Administrative Divisions
You can access of a administrative divisions data as below:
1. Cities:
administrative_area_level_1
2. County, Municipality:
administrative_area_level_2
3. Parish:
administrative_area_level_3
You can find more information about administrative divisions in:
- [List of administrative divisions by country](https://en.wikipedia.org/wiki/List_of_administrative_divisions_by_country)
- [Country to street level](https://wiki.openstreetmap.org/wiki/Nominatim/Development_overview#Country_to_street_level)
## Contributions
------------------------I started this project from [yt-google-maps-1](https://github.com/Klerith/yt-google-maps-1) repository and I could learn and fun myself at the same time :)
All work to improve performance is good
Enjoy it!