summaryrefslogtreecommitdiff
path: root/bak/unused_apps/projects/models
diff options
context:
space:
mode:
authorluxagraf <sng@luxagraf.net>2023-07-28 13:39:02 -0500
committerluxagraf <sng@luxagraf.net>2023-07-28 13:39:02 -0500
commit9a620cf42bf1fe6977e378bd834b41ff4a593dde (patch)
treecf41a0582681cecaf88a30bfe409f9c2be57972a /bak/unused_apps/projects/models
parent6e5897117124cd60ae81efb1574c6347f48e60e5 (diff)
main: removed some apps I wasn't using and added bak to git to preserve
a copy of old apps
Diffstat (limited to 'bak/unused_apps/projects/models')
-rw-r--r--bak/unused_apps/projects/models/__init__.py5
-rw-r--r--bak/unused_apps/projects/models/base.py67
-rw-r--r--bak/unused_apps/projects/models/fiveby.py53
-rw-r--r--bak/unused_apps/projects/models/gifs.py26
-rw-r--r--bak/unused_apps/projects/models/natparks.py55
-rw-r--r--bak/unused_apps/projects/models/self_experiments.py56
6 files changed, 262 insertions, 0 deletions
diff --git a/bak/unused_apps/projects/models/__init__.py b/bak/unused_apps/projects/models/__init__.py
new file mode 100644
index 0000000..3230ff4
--- /dev/null
+++ b/bak/unused_apps/projects/models/__init__.py
@@ -0,0 +1,5 @@
+from .base import Project
+from .fiveby import FiveBy
+from .natparks import NationalParks
+from .gifs import AnimatedGif
+from .self_experiments import Experiment
diff --git a/bak/unused_apps/projects/models/base.py b/bak/unused_apps/projects/models/base.py
new file mode 100644
index 0000000..aa795d2
--- /dev/null
+++ b/bak/unused_apps/projects/models/base.py
@@ -0,0 +1,67 @@
+import datetime
+from django.contrib.gis.db import models
+from django.contrib.sitemaps import Sitemap
+from django.conf import settings
+
+
+def get_upload_path(self, filename):
+ return "images/project-thumbs/%s/%s" % (datetime.datetime.today().strftime("%Y"), filename)
+
+
+class Project(models.Model):
+ title = models.CharField(max_length=200)
+ subtitle = models.CharField(max_length=200, null=True, blank=True)
+ slug = models.CharField(max_length=50)
+ lede = models.TextField(blank=True)
+ pub_date = models.DateTimeField('Date published')
+ PUB_STATUS = (
+ (0, 'Draft'),
+ (1, 'Published'),
+ )
+ status = models.IntegerField(choices=PUB_STATUS, default=0)
+ image = models.FileField(upload_to=get_upload_path, null=True, blank=True)
+ model_name = models.CharField(max_length=200, null=True)
+
+ @property
+ def longitude(self):
+ '''Get the site's longitude.'''
+ return self.point.x
+
+ @property
+ def latitude(self):
+ '''Get the site's latitude.'''
+ return self.point.y
+
+ @property
+ def get_project_image(self):
+ return "%s%s" % (settings.IMAGES_URL, self.image.name[7:])
+
+
+ class Meta:
+ ordering = ('-pub_date',)
+ get_latest_by = 'pub_date'
+ app_label = 'projects'
+
+ def __str__(self):
+ return self.title
+
+ def get_absolute_url(self):
+ return "/%s/" % (self.slug)
+
+ def get_previous_published(self):
+ return self.get_previous_by_pub_date(status__exact=1)
+
+ def get_next_published(self):
+ return self.get_next_by_pub_date(status__exact=1)
+
+
+class ProjectSitemap(Sitemap):
+ changefreq = "monthly"
+ priority = 0.5
+ protocol = "https"
+
+ def items(self):
+ return Project.objects.filter(status=1)
+
+ def lastmod(self, obj):
+ return obj.pub_date
diff --git a/bak/unused_apps/projects/models/fiveby.py b/bak/unused_apps/projects/models/fiveby.py
new file mode 100644
index 0000000..473c095
--- /dev/null
+++ b/bak/unused_apps/projects/models/fiveby.py
@@ -0,0 +1,53 @@
+import datetime
+from django.contrib.gis.db import models
+from locations.models import Location, Region
+
+
+def get_upload_path(self, filename):
+ return "images/projects/videos/5x5/%s/%s" % (datetime.datetime.today().strftime("%Y"), filename)
+
+
+def get_image_upload_path(self, filename):
+ return "images/projects/5x5/%s/%s" % (datetime.datetime.today().strftime("%Y"), filename)
+
+
+class FiveBy(models.Model):
+ title = models.CharField(max_length=200)
+ slug = models.SlugField(unique_for_date='pub_date')
+ lede = models.TextField(blank=True)
+ image = models.FileField(upload_to=get_image_upload_path, null=True, blank=True)
+ videoh264 = models.FileField(upload_to=get_upload_path, null=True, blank=True)
+ videoogg = models.FileField(upload_to=get_upload_path, null=True, blank=True)
+ vimeo_link = models.CharField(max_length=200)
+ youtube_link = models.CharField(max_length=200)
+ pub_date = models.DateTimeField('Date published')
+ PUB_STATUS = (
+ (0, 'Draft'),
+ (1, 'Published'),
+ )
+ status = models.IntegerField(choices=PUB_STATUS, default=0)
+ point = models.PointField(null=True)
+ location = models.ForeignKey(Location, on_delete=models.CASCADE, null=True)
+ region = models.ForeignKey(Region, on_delete=models.CASCADE, null=True)
+
+ class Meta:
+ ordering = ('-pub_date',)
+ get_latest_by = 'pub_date'
+ app_label = 'projects'
+ verbose_name_plural = '5x5'
+
+ def __str__(self):
+ return self.title
+
+ def get_absolute_url(self):
+ return "/%s/%s/%s/" % ('projects', '5x5', self.slug)
+
+ @property
+ def longitude(self):
+ '''Get the site's longitude.'''
+ return self.point.x
+
+ @property
+ def latitude(self):
+ '''Get the site's latitude.'''
+ return self.point.y
diff --git a/bak/unused_apps/projects/models/gifs.py b/bak/unused_apps/projects/models/gifs.py
new file mode 100644
index 0000000..25b8734
--- /dev/null
+++ b/bak/unused_apps/projects/models/gifs.py
@@ -0,0 +1,26 @@
+import datetime
+from django.db import models
+
+
+def get_upload_path(self, filename):
+ return "images/projects/gifs/%s/%s" % (datetime.datetime.today().strftime("%Y"), filename)
+
+
+class AnimatedGif(models.Model):
+ title = models.CharField(max_length=254)
+ gif = models.ImageField(upload_to=get_upload_path)
+ slug = models.SlugField()
+ date_created = models.DateField('Date Created')
+ music_ogg = models.FileField(upload_to=get_upload_path, blank=True, null=True)
+ music_mp3 = models.FileField(upload_to=get_upload_path, blank=True, null=True)
+
+ class Meta:
+ verbose_name_plural = "Animated Gifs"
+ app_label = 'projects'
+ ordering = ('-date_created',)
+
+ def __str__(self):
+ return self.slug
+
+ def get_absolute_url(self):
+ return '/projects/gifs/%s/' % (self.slug)
diff --git a/bak/unused_apps/projects/models/natparks.py b/bak/unused_apps/projects/models/natparks.py
new file mode 100644
index 0000000..980d9fa
--- /dev/null
+++ b/bak/unused_apps/projects/models/natparks.py
@@ -0,0 +1,55 @@
+import datetime
+from PIL import Image
+from django.contrib.gis.db import models
+from django.conf import settings
+from jrnl.models import Entry
+from photos.models import PhotoGallery
+from locations.models import State
+
+
+def get_upload_path(self, filename):
+ return "images/projects/np/%s/%s" % (datetime.datetime.today().strftime("%Y"), filename)
+
+
+class NationalParks(models.Model):
+ type = models.CharField(max_length=50)
+ name = models.CharField(max_length=254)
+ state = models.ForeignKey(State, on_delete=models.CASCADE, null=True)
+ size = models.CharField(max_length=10, null=True)
+ fee = models.CharField(max_length=5, null=True)
+ camping_fee = models.CharField(max_length=10, null=True)
+ url = models.CharField(max_length=250, null=True)
+ code = models.CharField(max_length=16)
+ unit_name = models.CharField(max_length=254)
+ date_visited_begin = models.DateField('Date Visited', null=True)
+ date_visited_end = models.DateField('Date Visited', null=True)
+ date_park_created = models.DateField('Date Park Created', null=True)
+ zoom = models.IntegerField(null=True)
+ mpoly = models.MultiPolygonField(null=True)
+ visited = models.BooleanField(default=False)
+ dek = models.TextField(null=True, blank=True)
+ tag_line = models.CharField(max_length=254, null=True)
+ post = models.ForeignKey(Entry, on_delete=models.CASCADE, null=True)
+ gallery = models.ForeignKey(PhotoGallery, on_delete=models.CASCADE, blank=True, null=True, verbose_name='photo set')
+ image = models.FileField(upload_to=get_upload_path, null=True, blank=True,
+ help_text="width: 980px, height: > 450px")
+ image_height = models.CharField(max_length=20, null=True, blank=True)
+ image_width = models.CharField(max_length=20, null=True, blank=True)
+
+ class Meta:
+ verbose_name_plural = "National Parks"
+ app_label = 'projects'
+ ordering = ('-visited', 'unit_name',)
+
+ def __str__(self):
+ return self.unit_name
+
+ @property
+ def get_image_url(self):
+ return "%s%s" % (settings.IMAGES_URL, self.image.name[7:])
+
+ def save(self):
+ #get image dimensions
+ img = Image.open(self.image)
+ self.image_width, self.image_height = img.size
+ super(NationalParks, self).save()
diff --git a/bak/unused_apps/projects/models/self_experiments.py b/bak/unused_apps/projects/models/self_experiments.py
new file mode 100644
index 0000000..be9d0b7
--- /dev/null
+++ b/bak/unused_apps/projects/models/self_experiments.py
@@ -0,0 +1,56 @@
+import datetime
+from django.db import models
+
+import markdown
+
+PUB_STATUS = (
+ (0, 'Draft'),
+ (1, 'Published'),
+)
+
+
+def markdown_processor(md):
+ return markdown.markdown(md, ['footnotes'], safe_mode=False)
+
+
+class Experiment(models.Model):
+ title = models.CharField(max_length=254)
+ slug = models.SlugField()
+ date_created = models.DateField(auto_now_add=True)
+ date_start = models.DateField()
+ date_end_actual = models.DateField(blank=True, null=True)
+ date_end_projected = models.DateField(blank=True)
+ duration = models.PositiveSmallIntegerField(default=30)
+ status = models.IntegerField(choices=PUB_STATUS, default=0)
+ body_html = models.TextField(blank=True)
+ body_markdown = models.TextField()
+
+ class Meta:
+ app_label = 'projects'
+ ordering = ('-date_start',)
+
+ # Returns the string representation of the model.
+ def __str__(self):
+ return self.title
+
+ def get_absolute_url(self):
+ return "/projects/experiments/%s/%s/" % (self.pub_date.strftime("%Y").lower(), self.slug)
+
+ def days_remaining(self):
+ return self.date_end_projected - datetime.date.today()
+
+ @property
+ def get_previous_published(self):
+ return self.get_previous_by_pub_date(status__exact=1)
+
+ @property
+ def get_next_published(self):
+ return self.get_next_by_pub_date(status__exact=1)
+
+ def comment_period_open(self):
+ return self.enable_comments and datetime.datetime.today() - datetime.timedelta(30) <= self.pub_date
+
+ def save(self):
+ self.body_html = markdown_processor(self.body_markdown)
+ self.date_end_projected = self.date_start + datetime.timedelta(self.duration)
+ super(Experiment, self).save()