Add 'Tip of the Day' app to display helpful messages to users

This commit is contained in:
Michael Hall 2018-09-22 01:19:49 -04:00
parent 987d631a45
commit b3a832a420
12 changed files with 139 additions and 2 deletions

View file

@ -56,6 +56,7 @@ INSTALLED_APPS = [
'accounts',
'resume',
'simple_ga',
'totd',
]
LOGIN_URL = 'login'
@ -105,6 +106,7 @@ TEMPLATES = [
'social_django.context_processors.login_redirect',
'django_settings_export.settings_export',
'simple_ga.context_processors.events',
'totd.context_processors.tips',
],
},
},
@ -204,6 +206,7 @@ SETTINGS_EXPORT = [
# Make django messages framework use Bootstrap's alert style classes
from django.contrib.messages import constants as messages
MESSAGE_TAGS = {
messages.DEBUG: 'alert-debug',
messages.INFO: 'alert-info',
messages.SUCCESS: 'alert-success',
messages.WARNING: 'alert-warning',

View file

@ -121,6 +121,12 @@ ul.errorlist li {
text-shadow: 2px 2px #444;
}
.alert-debug {
color: #383d41;
background-color: #e2e3e5;
border-color: #d6d8db;
}
.btn-default {
color: #fff;
background-color: #848484;

View file

@ -1,4 +1,4 @@
{% load static %}
{% load static markup %}
<!doctype html>
<html lang="en">
<head>
@ -90,6 +90,12 @@
<main role="main" class="container">
{% if tip %}
<div class="alerts">
<div class="alert {{ tip.tags }}"><strong>Tip: </strong>{{ tip.text|safe }}</div>
</div>
{% endif %}
{% if messages %}
<div class="alerts">
{% for message in messages %}

0
totd/__init__.py Normal file
View file

32
totd/admin.py Normal file
View file

@ -0,0 +1,32 @@
from django.contrib import admin
from django.urls.resolvers import get_resolver
from django import forms
from .models import Tip
def url_choices():
choices = [('', '-- All Pages --')]
for entry in get_resolver(None).url_patterns:
if entry.pattern.name:
choices.append((entry.pattern.name, entry.pattern.name))
return choices
# Register your models here.
class TipForm(forms.ModelForm):
class Meta:
model = Tip
fields = '__all__'
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
self.fields['view'].widget = forms.Select(choices=url_choices())
class TipAdmin(admin.ModelAdmin):
#raw_id_fields = ('seen_by',)
list_filter =('level', 'view')
list_display = ('name', 'level', 'view', 'run_start', 'run_end')
search_fields = ('name', 'view')
form = TipForm
admin.site.register(Tip, TipAdmin)

5
totd/apps.py Normal file
View file

@ -0,0 +1,5 @@
from django.apps import AppConfig
class TotdConfig(AppConfig):
name = 'totd'

View file

@ -0,0 +1,25 @@
from django.db.models import Q
from .models import Tip
import datetime
def tips(request):
"""
Adds a list of tips for the current request
"""
if not request.user.is_authenticated:
return {}
#import pdb; pdb.set_trace()
tips = Tip.objects.filter(run_start__lte=datetime.datetime.now())
tips = tips.filter(Q(run_end__isnull=True) | Q(run_end__gte=datetime.datetime.now()))
tips = tips.filter(Q(view='') | Q(view=request.resolver_match.url_name)).exclude(seen_by=request.user)
if len(tips) > 0:
tips[0].seen_by.add(request.user)
return {
'tip': tips[0],
}
return {}

View file

@ -0,0 +1,32 @@
# Generated by Django 2.0 on 2018-09-22 05:16
from django.conf import settings
from django.db import migrations, models
import django.utils.timezone
class Migration(migrations.Migration):
initial = True
dependencies = [
('sites', '0002_alter_domain_unique'),
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
]
operations = [
migrations.CreateModel(
name='Tip',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('name', models.CharField(max_length=128)),
('text', models.TextField()),
('level', models.SmallIntegerField(choices=[(10, 'debug'), (20, 'info'), (25, 'success'), (30, 'warning'), (40, 'error')], default=20)),
('run_start', models.DateTimeField(default=django.utils.timezone.now)),
('run_end', models.DateTimeField(blank=True, null=True)),
('view', models.CharField(blank=True, max_length=256, null=True)),
('seen_by', models.ManyToManyField(blank=True, related_name='seen_tips', to=settings.AUTH_USER_MODEL)),
('sites', models.ManyToManyField(to='sites.Site')),
],
),
]

View file

22
totd/models.py Normal file
View file

@ -0,0 +1,22 @@
from django.db import models
from django.contrib.sites.models import Site
from django.contrib.messages.constants import DEFAULT_TAGS, INFO
from django.conf import settings
from django.utils import timezone
# Create your models here.
class Tip(models.Model):
name = models.CharField(max_length=128, null=False, blank=False)
text = models.TextField()
level = models.SmallIntegerField(choices=DEFAULT_TAGS.items(), default=INFO)
run_start = models.DateTimeField(default=timezone.now)
run_end = models.DateTimeField(null=True, blank=True)
view = models.CharField(max_length=256, blank=True, null=True)
sites = models.ManyToManyField(Site)
seen_by = models.ManyToManyField(settings.AUTH_USER_MODEL, related_name='seen_tips', blank=True)
def tags(self):
return settings.MESSAGE_TAGS[self.level]

3
totd/tests.py Normal file
View file

@ -0,0 +1,3 @@
from django.test import TestCase
# Create your tests here.

3
totd/views.py Normal file
View file

@ -0,0 +1,3 @@
from django.shortcuts import render
# Create your views here.