diff options
author | luxagraf <sng@luxagraf> | 2021-03-23 22:21:25 -0400 |
---|---|---|
committer | luxagraf <sng@luxagraf> | 2021-03-23 22:21:25 -0400 |
commit | e807fb3c0e738b512acb68d230e4aae631d3c76d (patch) | |
tree | 11643c1170a1c8c82aeec712403fa8d11b8c131f /app | |
parent | 70f50c11ec68fc1382d39108ed7da0d2be1ae503 (diff) |
posts: added issue to handle mailing letter posts
Diffstat (limited to 'app')
-rw-r--r-- | app/posts/migrations/0019_auto_20210323_2155.py | 23 | ||||
-rw-r--r-- | app/posts/models.py | 12 | ||||
-rw-r--r-- | app/posts/urls/friends_urls.py | 2 |
3 files changed, 35 insertions, 2 deletions
diff --git a/app/posts/migrations/0019_auto_20210323_2155.py b/app/posts/migrations/0019_auto_20210323_2155.py new file mode 100644 index 0000000..0f3af44 --- /dev/null +++ b/app/posts/migrations/0019_auto_20210323_2155.py @@ -0,0 +1,23 @@ +# Generated by Django 3.1 on 2021-03-23 21:55 + +from django.db import migrations, models + + +class Migration(migrations.Migration): + + dependencies = [ + ('posts', '0018_auto_20210128_1708'), + ] + + operations = [ + migrations.AddField( + model_name='post', + name='issue', + field=models.PositiveIntegerField(null=True), + ), + migrations.AlterField( + model_name='post', + name='post_type', + field=models.IntegerField(choices=[(0, 'range'), (1, 'review'), (2, 'essay'), (3, 'src'), (4, 'jrnl'), (5, 'field note'), (6, 'guide'), (7, 'friends')], default=4), + ), + ] diff --git a/app/posts/models.py b/app/posts/models.py index cc6e1d5..6adae3b 100644 --- a/app/posts/models.py +++ b/app/posts/models.py @@ -115,7 +115,9 @@ class Post(models.Model): if self.post_type == PostType.JRNL: return reverse('jrnl:detail', kwargs={"year": self.pub_date.year, "month": self.pub_date.strftime("%m"), "slug": self.slug}) if self.post_type == PostType.RANGE: - return reverse('range:detail', kwargs={"slug": self.slug}) + return reverse('range:detail', kwargs={"issue": self.issue, "slug": self.slug}) + if self.post_type == PostType.FRIENDS: + return reverse('friends:friends-detail', kwargs={"issue": self.get_issue_str(), "slug": self.slug}) def comment_period_open(self): return self.enable_comments and datetime.datetime.today() - datetime.timedelta(30) <= self.pub_date @@ -126,6 +128,14 @@ class Post(models.Model): def get_content_type(self): return ContentType.objects.get(app_label="posts", model="post") + def get_issue_str(self): + issue = self.issue + if self.issue < 100: + issue = "0%s" % self.issue + if self.issue < 10: + issue = "00%s" % self.issue + return issue + @property def get_previous_published(self): return self.get_previous_by_pub_date(status__exact=1,post_type=self.post_type) diff --git a/app/posts/urls/friends_urls.py b/app/posts/urls/friends_urls.py index 2e2d220..5998d08 100644 --- a/app/posts/urls/friends_urls.py +++ b/app/posts/urls/friends_urls.py @@ -7,7 +7,7 @@ app_name = "range" urlpatterns = [ path( - r'<str:slug>', + r'<int:issue>/<str:slug>', views.FriendsDetailView.as_view(), name="friends-detail" ), |