diff options
author | lxf <sng@luxagraf.net> | 2022-02-06 13:26:32 -0500 |
---|---|---|
committer | lxf <sng@luxagraf.net> | 2022-02-06 13:26:32 -0500 |
commit | 13c0f7653855b4feb433eeeea513f41693cdb2af (patch) | |
tree | 06194ac19bae42acbc4d771ad64ed82403bca1ea | |
parent | 342a95c15aa3f94b6bb689c2bd7c7151db217691 (diff) |
plan: added a new model to track places we might want to go.
-rw-r--r-- | app/planner/admin.py | 25 | ||||
-rw-r--r-- | app/planner/migrations/0005_auto_20220206_1109.py | 40 | ||||
-rw-r--r-- | app/planner/migrations/0006_campidea_state.py | 19 | ||||
-rw-r--r-- | app/planner/models.py | 40 |
4 files changed, 122 insertions, 2 deletions
diff --git a/app/planner/admin.py b/app/planner/admin.py index 5d533c8..910558a 100644 --- a/app/planner/admin.py +++ b/app/planner/admin.py @@ -4,11 +4,34 @@ from django.contrib.gis.admin import OSMGeoAdmin from django.contrib.contenttypes.admin import GenericStackedInline from utils.widgets import AdminImageWidget, LGEntryForm -from .models import Camp, Trip +from .models import Camp, Trip, CampIdea from media.models import LuxImage from utils.util import get_latlon +@admin.register(CampIdea) +class PlannerAdmin(OSMGeoAdmin): + list_display = ('name', ) + #list_filter = ('has_water', ) + # options for OSM map Using custom ESRI topo map + lat, lon = get_latlon() + default_lon = lon + default_lat = lat + default_zoom = 10 + units = True + scrollable = False + map_width = 700 + map_height = 425 + map_template = 'gis/admin/osm.html' + openlayers_url = '/static/admin/js/OpenLayers.js' + + class Media: + js = ('image-loader.js', 'next-prev-links.js') + #'product-loader.js', + css = { + "all": ("my_styles.css",) + } + @admin.register(Camp) class PlannerAdmin(OSMGeoAdmin): diff --git a/app/planner/migrations/0005_auto_20220206_1109.py b/app/planner/migrations/0005_auto_20220206_1109.py new file mode 100644 index 0000000..dee19bf --- /dev/null +++ b/app/planner/migrations/0005_auto_20220206_1109.py @@ -0,0 +1,40 @@ +# Generated by Django 3.2.7 on 2022-02-06 11:09 + +import django.contrib.gis.db.models.fields +from django.db import migrations, models + + +class Migration(migrations.Migration): + + dependencies = [ + ('planner', '0004_auto_20210815_1856'), + ] + + operations = [ + migrations.CreateModel( + name='CampIdea', + fields=[ + ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), + ('name', models.CharField(max_length=200)), + ('slug', models.SlugField(blank=True, null=True)), + ('point', django.contrib.gis.db.models.fields.PointField(blank=True, null=True, srid=4326)), + ('notes', models.TextField(blank=True, null=True)), + ('notes_html', models.TextField(blank=True, null=True)), + ('date_added', models.DateField(auto_now_add=True)), + ], + options={ + 'ordering': ('date_added',), + 'get_latest_by': 'date_added', + }, + ), + migrations.AlterField( + model_name='camp', + name='slug', + field=models.SlugField(blank=True, null=True), + ), + migrations.AlterField( + model_name='trip', + name='slug', + field=models.SlugField(unique_for_date='date'), + ), + ] diff --git a/app/planner/migrations/0006_campidea_state.py b/app/planner/migrations/0006_campidea_state.py new file mode 100644 index 0000000..f0dbdea --- /dev/null +++ b/app/planner/migrations/0006_campidea_state.py @@ -0,0 +1,19 @@ +# Generated by Django 3.2.7 on 2022-02-06 12:36 + +from django.db import migrations, models + + +class Migration(migrations.Migration): + + dependencies = [ + ('planner', '0005_auto_20220206_1109'), + ] + + operations = [ + migrations.AddField( + model_name='campidea', + name='state', + field=models.CharField(default='none', max_length=40), + preserve_default=False, + ), + ] diff --git a/app/planner/models.py b/app/planner/models.py index df162c7..b9d06cf 100644 --- a/app/planner/models.py +++ b/app/planner/models.py @@ -15,7 +15,7 @@ from django.contrib.sitemaps import Sitemap from django import forms from django.template.defaultfilters import slugify -from locations.models import Location +from locations.models import Location, State from utils.util import render_images, render_products, parse_video, markdown_to_html, extract_main_image @@ -107,3 +107,41 @@ class Camp(models.Model): self.slug = slugify(self.name) self.notes_html = markdown_to_html(self.notes) super(Camp, self).save(*args, **kwargs) + + +class CampIdea(models.Model): + name = models.CharField(max_length=200) + slug = models.SlugField(blank=True, null=True) + point = models.PointField(null=True, blank=True) + notes = models.TextField(null=True, blank=True) + notes_html = models.TextField(null=True, blank=True) + state = models.CharField(max_length=40) + date_added = models.DateField(auto_now_add=True) + + class Meta: + ordering = ('date_added',) + get_latest_by = 'date_added' + + def __str__(self): + return self.name + + def save(self, *args, **kwargs): + created = self.pk is None + if created: + self.state = State.objects.filter(geometry__contains=self.point).get().name + if not self.slug: + self.slug = slugify(self.name) + self.notes_html = markdown_to_html(self.notes) + super(CampIdea, self).save(*args, **kwargs) + + @property + def longitude(self): + '''Get the site's longitude.''' + if self.point: + return self.point.x + + @property + def latitude(self): + '''Get the site's latitude.''' + if self.point: + return self.point.y |