diff options
Diffstat (limited to 'app/gtd')
-rw-r--r-- | app/gtd/forms.py | 19 | ||||
-rw-r--r-- | app/gtd/models.py | 35 | ||||
-rw-r--r-- | app/gtd/urls.py | 8 | ||||
-rw-r--r-- | app/gtd/views.py | 75 |
4 files changed, 59 insertions, 78 deletions
diff --git a/app/gtd/forms.py b/app/gtd/forms.py index 2e1c576..595611b 100644 --- a/app/gtd/forms.py +++ b/app/gtd/forms.py @@ -1,18 +1,17 @@ from django.forms import ModelForm -from django.forms import ChoiceField from .models import GTDNote, GTDProject, WiredNote, WiredPost class GTDNoteCreateForm(ModelForm): class Meta: - model = GTDNote + model = GTDNote fields = ['title', 'url', 'body_markdown', 'project', 'note_type', 'reminder', 'status'] class GTDNoteEditForm(ModelForm): class Meta: - model = GTDNote + model = GTDNote fields = ['title', 'url', 'body_markdown', 'project', 'note_type', 'reminder', 'status'] @@ -30,10 +29,10 @@ class GTDProjectUpdateForm(ModelForm): class WiredNoteCreateForm(ModelForm): - def __init__(self,*args,**kwargs): + def __init__(self, *args, **kwargs): user = kwargs.pop('user') self.user = user - super(WiredNoteCreateForm,self).__init__(*args,**kwargs) + super(WiredNoteCreateForm, self).__init__(*args, **kwargs) self.fields['post'].required = False def save(self, commit=True): @@ -41,26 +40,26 @@ class WiredNoteCreateForm(ModelForm): return super().save(commit=commit) class Meta: - model = WiredNote + model = WiredNote fields = ['title', 'url', 'body_markdown', 'post'] class WiredNoteEditForm(ModelForm): - def __init__(self,*args,**kwargs): - super(WiredNoteEditForm,self).__init__(*args,**kwargs) + def __init__(self, *args, **kwargs): + super(WiredNoteEditForm, self).__init__(*args, **kwargs) self.fields['post'].queryset = WiredPost.objects.all().order_by("title") def save(self, commit=True): return super().save(commit=commit) class Meta: - model = WiredNote + model = WiredNote fields = ['title', 'url', 'body_markdown', 'post', 'status', 'plan'] class WiredPostUpdateForm(ModelForm): class Meta: - model = WiredPost + model = WiredPost fields = ['title', 'post_status', 'url', 'template_type', 'update_frequency', 'edit_url', 'date_last_pub'] diff --git a/app/gtd/models.py b/app/gtd/models.py index 1ca0d6e..3352394 100644 --- a/app/gtd/models.py +++ b/app/gtd/models.py @@ -1,17 +1,12 @@ import datetime -import os -from django.utils import timezone from django.contrib.gis.db import models -from django.contrib.contenttypes.fields import GenericRelation, GenericForeignKey -from django.contrib.contenttypes.models import ContentType -from django.contrib.sites.models import Site from django.urls import reverse from django.apps import apps -from django.conf import settings -from django.contrib.sitemaps import Sitemap +from django.utils import timezone +from django.utils.html import format_html -from utils.util import render_images, render_products, parse_video, markdown_to_html, extract_main_image +from utils.util import render_images, markdown_to_html def get_upload_path(self, filename): @@ -75,13 +70,13 @@ class GTDProject(models.Model): @property def get_previous_admin_url(self): n = self.get_previous_by_date_goal() - return reverse('admin:%s_%s_change' %(self._meta.app_label, self._meta.model_name), args=[n.id] ) + return reverse('admin:%s_%s_change' % (self._meta.app_label, self._meta.model_name), args=[n.id]) @property def get_next_admin_url(self): model = apps.get_model(app_label=self._meta.app_label, model_name=self._meta.model_name) try: - return reverse('admin:%s_%s_change' %(self._meta.app_label, self._meta.model_name), args=[self.get_next_by_date_goal().pk] ) + return reverse('admin:%s_%s_change' % (self._meta.app_label, self._meta.model_name), args=[self.get_next_by_date_goal().pk]) except model.DoesNotExist: return '' @@ -116,7 +111,7 @@ class GTDNote(models.Model): NONE = 0 OPEN = 1 COMPLETED = 2 - STATUS= [ + STATUS = [ (NONE, 'None'), (OPEN, 'Open'), (COMPLETED, 'Completed'), @@ -129,7 +124,7 @@ class GTDNote(models.Model): def __str__(self): return self.title - + def save(self, *args, **kwargs): self.body_html = markdown_to_html(self.body_markdown) super(GTDNote, self).save(*args, **kwargs) @@ -137,6 +132,7 @@ class GTDNote(models.Model): def get_absolute_url(self, *args, **kwargs): return reverse('gtd:note-edit', kwargs={"pk": self.pk}) + class PostType(models.IntegerChoices): REVIEW = 0, ('review') GUIDE = 1, ('guide') @@ -166,12 +162,11 @@ class WiredPost(models.Model): post_type = models.IntegerField(choices=PostType.choices, default=PostType.GUIDE) template_type = models.IntegerField(choices=TemplateType.choices, default=TemplateType.STORY) update_frequency = models.BigIntegerField(help_text="In days") - #products = models.ManyToManyField(ProductLink, blank=True, null=True) + # products = models.ManyToManyField(ProductLink, blank=True, null=True) needs_update = models.BooleanField(default=False) is_live = models.BooleanField(default=True) post_status = models.IntegerField(choices=PostStatus.choices, default=PostStatus.PUBLISHED) - class Meta: ordering = ('date_last_pub',) @@ -179,17 +174,17 @@ class WiredPost(models.Model): return self.title def time_since_update(self): - td = datetime.date.today() - self.date_last_pub + td = datetime.date.today() - self.date_last_pub return int(td.days) - #def get_needs_update(self): + # def get_needs_update(self): # if self.time_since_update() > self.update_frequency: # return True # else: # return False def days_overdue(self): - if self.needs_update == True: + if self.needs_update: return self.time_since_update() - self.update_frequency else: return 0 @@ -203,11 +198,11 @@ class WiredPost(models.Model): def save(self, *args, **kwargs): if self.date_last_pub: - td = datetime.date.today() - self.date_last_pub + td = datetime.date.today() - self.date_last_pub if td.days > self.update_frequency and self.post_status != 1: self.needs_update = True - else: - self.needs_update = False + else: + self.needs_update = False super(WiredPost, self).save() diff --git a/app/gtd/urls.py b/app/gtd/urls.py index 27a2dd8..a56bbf4 100644 --- a/app/gtd/urls.py +++ b/app/gtd/urls.py @@ -1,4 +1,4 @@ -from django.urls import path, re_path +from django.urls import path from . import views @@ -13,7 +13,7 @@ urlpatterns = [ path( r'notes', views.GTDNoteListView.as_view(), - {'note_type':None}, + {'note_type': None}, name="note-list" ), path( @@ -39,7 +39,7 @@ urlpatterns = [ path( r'projects', views.GTDProjectListView.as_view(), - {'project_type':None}, + {'project_type': None}, name="project-list" ), path( @@ -70,7 +70,7 @@ urlpatterns = [ path( r'wirednotes', views.WiredNoteListView.as_view(), - {'status':None}, + {'status': None}, name="wirednote-list" ), path( diff --git a/app/gtd/views.py b/app/gtd/views.py index c4c8d92..b49f106 100644 --- a/app/gtd/views.py +++ b/app/gtd/views.py @@ -1,21 +1,24 @@ -from django.views.generic import UpdateView, DetailView, ListView -from django.views.generic.edit import CreateView, DeleteView, UpdateView -from django.contrib.auth.mixins import LoginRequiredMixin +from django.views.generic import UpdateView, DetailView, ListView, CreateView, DeleteView from django.urls import reverse, reverse_lazy from django.db.models import Q from .models import GTDNote, GTDProject, GTDOutcome, WiredNote, WiredPost -from .forms import GTDNoteCreateForm, GTDNoteEditForm, GTDProjectCreateForm, GTDProjectUpdateForm, WiredNoteCreateForm, WiredNoteEditForm, WiredPostUpdateForm +from .forms import ( + GTDNoteCreateForm, + GTDNoteEditForm, + GTDProjectCreateForm, + GTDProjectUpdateForm, + WiredNoteCreateForm, + WiredNoteEditForm, + WiredPostUpdateForm +) + class GTDNoteCreateView(CreateView): model = GTDNote form_class = GTDNoteCreateForm template_name = "gtd/note_form.html" - def get_form_kwargs(self): - kwargs = super(GTDNoteCreateView, self).get_form_kwargs() - return kwargs - def get_success_url(self): if 'add_new' in self.request.POST: return reverse('gtd:note-create') @@ -30,7 +33,7 @@ class GTDNoteUpdateView(UpdateView): model = GTDNote form_class = GTDNoteEditForm template_name = "gtd/note_form.html" - + def get_context_data(self, **kwargs): context = super(GTDNoteUpdateView, self).get_context_data(**kwargs) context['is_update'] = True @@ -51,7 +54,7 @@ class GTDNoteListView(ListView): note_type = note_type_reverse[self.kwargs['note_type'].title()] return GTDNote.objects.filter(note_type=note_type) return GTDNote.objects.all() - + def get_context_data(self, **kwargs): context = super(GTDNoteListView, self).get_context_data(**kwargs) context['note_types'] = GTDNote.NOTE_TYPE @@ -64,17 +67,13 @@ class GTDNoteTODOView(ListView): def get_queryset(self): return GTDNote.objects.filter(status=1) - + class GTDProjectCreateView(CreateView): model = GTDProject form_class = GTDProjectCreateForm template_name = "gtd/project_form.html" - def get_form_kwargs(self): - kwargs = super(GTDProjectCreateView, self).get_form_kwargs() - return kwargs - def get_success_url(self): if 'add_new' in self.request.POST: return reverse('gtd:project-create') @@ -94,7 +93,7 @@ class GTDProjectUpdateView(UpdateView): class GTDProjectDetailView(DetailView): - model = GTDProject + model = GTDProject template_name = "gtd/project_detail.html" def get_context_data(self, **kwargs): @@ -103,7 +102,7 @@ class GTDProjectDetailView(DetailView): class GTDProjectListView(ListView): - model = GTDProject + model = GTDProject template_name = "gtd/project_list.html" def get_queryset(self, *args, **kwargs): @@ -118,10 +117,11 @@ class GTDProjectListView(ListView): context['project_types'] = GTDProject.PROJECT_TYPE return context + class GTDProjectDeleteView(DeleteView): # specify the model you want to use model = GTDProject - success_url ="/gtd/projects" + success_url = "/gtd/projects" template_name = "gtd/confirm_delete.html" @@ -130,11 +130,6 @@ class WiredNoteCreateView(CreateView): form_class = WiredNoteCreateForm template_name = "gtd/wirednote_form.html" - def get_form_kwargs(self): - kwargs = super(WiredNoteCreateView, self).get_form_kwargs() - kwargs.update({'user': self.request.user}) - return kwargs - def get_success_url(self): if 'add_new' in self.request.POST: return reverse('gtd:wirednotes-create') @@ -149,10 +144,6 @@ class WiredNoteUpdateView(UpdateView): model = WiredNote form_class = WiredNoteEditForm template_name = "gtd/wirednote_form.html" - - def get_form_kwargs(self): - kwargs = super(WiredNoteUpdateView, self).get_form_kwargs() - return kwargs def get_context_data(self, **kwargs): context = super(WiredNoteUpdateView, self).get_context_data(**kwargs) @@ -173,7 +164,7 @@ class WiredNoteListView(ListView): status = status_reverse[self.kwargs['status'].title()] return WiredNote.objects.filter(status=status) return WiredNote.objects.all() - + def get_context_data(self, **kwargs): context = super(WiredNoteListView, self).get_context_data(**kwargs) context['note_statuses'] = WiredNote.STATUS @@ -181,14 +172,13 @@ class WiredNoteListView(ListView): class WiredNoteDeleteView(DeleteView): - # specify the model you want to use model = WiredNote - success_url ="/gtd/wirednote" + success_url = "/gtd/wirednote" template_name = "gtd/confirm_delete.html" class WiredPostListView(ListView): - model = WiredPost + model = WiredPost template_name = 'gtd/wiredpost_table.html' def get_queryset(self): @@ -197,25 +187,25 @@ class WiredPostListView(ListView): class WiredPostNewView(ListView): template_name = 'gtd/wiredpost_list.html' - + def get_queryset(self): return WiredPost.objects.filter(is_live=0) def get_context_data(self, **kwargs): context = super(WiredPostNewView, self).get_context_data(**kwargs) - context['reviews'] = WiredNote.objects.filter(plan__in=[1,2], status__in=[0,1,2,3]) + context['reviews'] = WiredNote.objects.filter(plan__in=[1, 2], status__in=[0, 1, 2, 3]) return context class WiredPostCreateView(CreateView): - model = WiredPost + model = WiredPost fields = ['title', 'post_status', 'url', 'template_type', 'update_frequency', 'edit_url', 'date_last_pub'] template_name = "gtd/wiredpost_form.html" class WiredPostTodoView(ListView): template_name = 'gtd/wiredpost_table.html' - + def get_queryset(self): qs = WiredPost.objects.filter(Q(needs_update=True) | Q(is_live=0)).exclude(post_status=1) unsorted_results = qs.all() @@ -223,12 +213,12 @@ class WiredPostTodoView(ListView): def get_context_data(self, **kwargs): context = super(WiredPostTodoView, self).get_context_data(**kwargs) - context['reviews'] = WiredNote.objects.filter(plan__in=[1,2,3]).exclude(status__in=[4,5]) + context['reviews'] = WiredNote.objects.filter(plan__in=[1, 2, 3]).exclude(status__in=[4, 5]) return context class WiredPostNotesView(DetailView): - model = WiredPost + model = WiredPost template_name = "gtd/wiredpost_detail.html" def get_context_data(self, **kwargs): @@ -242,10 +232,6 @@ class WiredPostUpdateView(UpdateView): form_class = WiredPostUpdateForm template_name = "gtd/wiredpost_form.html" - def get_form_kwargs(self): - kwargs = super(WiredPostUpdateView, self).get_form_kwargs() - return kwargs - def get_success_url(self): if 'add_new' in self.request.POST: return reverse('gtd:posts-create') @@ -255,8 +241,8 @@ class WiredPostUpdateView(UpdateView): class GTDNoteDeleteView(DeleteView): # specify the model you want to use - model = GTDNote - success_url ="/gtd/notes" + model = GTDNote + success_url = "/gtd/notes" template_name = "gtd/confirm_delete.html" @@ -278,6 +264,7 @@ class GTDOutcomeUpdateView(UpdateView): context['is_update'] = True return context + class GTDOutcomeListView(ListView): model = GTDOutcome template_name = "gtd/outcome_list.html" @@ -286,5 +273,5 @@ class GTDOutcomeListView(ListView): class GTDOutcomeDeleteView(DeleteView): # specify the model you want to use model = GTDOutcome - success_url ="/gtd/outcomes" + success_url = "/gtd/outcomes" template_name = "gtd/confirm_delete.html" |