Mercurial > public > sg101
changeset 619:00c14431e911
Created a donations side block for BB issue 21.
author | Brian Neal <bgneal@gmail.com> |
---|---|
date | Wed, 26 Sep 2012 19:33:26 -0500 (2012-09-27) |
parents | 8c901a03b2e3 |
children | 40ae28f33b3d |
files | donations/fixtures/donations_test.json donations/models.py donations/templatetags/__init__.py donations/templatetags/donations_tags.py donations/tests.py sg101/templates/base.html sg101/templates/donations/monthly_goal_tag.html |
diffstat | 6 files changed, 166 insertions(+), 1 deletions(-) [+] |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/donations/fixtures/donations_test.json Wed Sep 26 19:33:26 2012 -0500 @@ -0,0 +1,62 @@ +[ + { + "pk": 150, + "model": "donations.donation", + "fields": { + "payment_date": "2012-09-20T02:54:40", + "first_name": "Matthew", + "last_name": "Jones", + "txn_id": "31JFAKETXN_ID0118", + "is_anonymous": false, + "memo": "", + "mc_fee": "1.08", + "payer_id": "HLCCFAKEZIDTS", + "payer_email": "fake@example.com", + "user": null, + "mc_gross": "20.00", + "payer_status": "verified", + "txn_type": "web_accept", + "test_ipn": false + } + }, + { + "pk": 151, + "model": "donations.donation", + "fields": { + "payment_date": "2012-09-19T23:02:20", + "first_name": "Daniel", + "last_name": "Smith", + "txn_id": "17UFAKETXNID16417", + "is_anonymous": false, + "memo": "", + "mc_fee": "0.45", + "payer_id": "S4UFAKEPAYERY", + "payer_email": "fake2@example.com", + "user": null, + "mc_gross": "5.00", + "payer_status": "verified", + "txn_type": "web_accept", + "test_ipn": false + } + }, + { + "pk": 149, + "model": "donations.donation", + "fields": { + "payment_date": "2012-08-19T19:00:21", + "first_name": "Daryl", + "last_name": "A", + "txn_id": "75PFAKETXNID77721", + "is_anonymous": false, + "memo": "", + "mc_fee": "1.03", + "payer_id": "QUFAKEPAYERID", + "payer_email": "fake3@example.com", + "user": null, + "mc_gross": "25.00", + "payer_status": "unverified", + "txn_type": "web_accept", + "test_ipn": false + } + } +]
--- a/donations/models.py Sat Sep 22 11:27:16 2012 -0500 +++ b/donations/models.py Wed Sep 26 19:33:26 2012 -0500 @@ -7,9 +7,12 @@ from django.db import models from django.contrib.auth.models import User from django.conf import settings +from django.db.models import Sum class DonationManager(models.Manager): + """Manager for the Donations model.""" + def monthly_stats(self, year=None, month=None): """ Returns a tuple of items for the given month in the given @@ -43,6 +46,36 @@ return gross, net, donations + def monthly_goal_pct(self, year=None, month=None, limit=True): + """Returns progress towards the given monthly goal as an integer + percent. + + If year is None, the current year is used. + If month is None, the current month is used. + If limit is True, the return value is limited to 100. + + """ + today = datetime.datetime.today() + if year is None: + year = today.year + if month is None: + month = today.month + + r = self.filter(payment_date__year=year, payment_date__month=month).aggregate( + Sum('mc_gross'), Sum('mc_fee')) + + gross, fee = r['mc_gross__sum'], r['mc_fee__sum'] + + if gross is not None and fee is not None: + pct = int((gross - fee) / settings.DONATIONS_GOAL * 100) + else: + pct = 0 + + if limit: + pct = min(pct, 100) + + return pct + class Donation(models.Model): """Model to represent a donation to the website."""
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/donations/templatetags/donations_tags.py Wed Sep 26 19:33:26 2012 -0500 @@ -0,0 +1,17 @@ +""" +Template tags for the donations application. + +""" +from django import template + +from donations.models import Donation + + +register = template.Library() + + +@register.inclusion_tag('donations/monthly_goal_tag.html') +def monthly_goal(): + return { + 'pct': Donation.objects.monthly_goal_pct() + }
--- a/donations/tests.py Sat Sep 22 11:27:16 2012 -0500 +++ b/donations/tests.py Wed Sep 26 19:33:26 2012 -0500 @@ -8,6 +8,7 @@ from django.contrib.auth.models import User from django.test import TestCase from django.core.urlresolvers import reverse +from django.conf import settings from donations.models import Donation import bio.badges @@ -27,7 +28,7 @@ mc_gross=100.00&protection_eligibility=Ineligible&payer_id=FAKEPAYERID02&tax=0.00&payment_date=05:40:33 Jan 16, 2011 PST&payment_status=Completed&charset=windows-1252&first_name=John&option_selection1=No&mc_fee=3.20¬ify_version=3.0&custom=test_user&payer_status=unverified&business=brian@surfguitar101.com&quantity=1&verify_sign=AIkKNFAKE-DATA-NOT-REALpqCSxA-E7Tm4rMGlUpNy6ym0.exBzfiyI&payer_email=test_user@example.com&option_name1=List your name?&txn_id=TESTTXNIDK548343A&payment_type=instant&last_name=Doe&receiver_email=brian@surfguitar101.com&payment_fee=3.20&receiver_id=FAKERECEIVERU&txn_type=web_accept&item_name=Donation for www.surfguitar101.com&mc_currency=USD&item_number=501&residence_country=US&handling_amount=0.00&transaction_subject=test_user&payment_gross=100.00&shipping=0.00""" -class DonationsTest(TestCase): +class DonationsIpnTestCase(TestCase): fixtures = ['badges'] def test_ipn_post_1(self): @@ -108,3 +109,39 @@ # user should not have got a badge for donating p = user.get_profile() self.assertEqual(p.badges.count(), 0) + + +class DonationsManagerTestCase(TestCase): + fixtures = ['donations_test'] + + def test_monthly_goal_pct(self): + + self.assertEqual(settings.DONATIONS_GOAL, Decimal('100.00')) + pct = Donation.objects.monthly_goal_pct(year=2012, month=9) + self.assertEqual(pct, 23) + + def test_monthly_goal_pct2(self): + + # Ensure we get 0 when there are no records + + Donation.objects.all().delete() + pct = Donation.objects.monthly_goal_pct(year=2012, month=9) + self.assertEqual(pct, 0) + + def test_monthly_stats(self): + + gross, net, donations = Donation.objects.monthly_stats(year=2012, month=9) + self.assertEqual(gross, Decimal('25.00')) + self.assertEqual(net, Decimal('23.47')) + self.assertEqual(len(donations), 2) + + def test_monthly_stats2(self): + + # Ensure we get 0 when there are no records + + Donation.objects.all().delete() + + gross, net, donations = Donation.objects.monthly_stats(year=2012, month=9) + self.assertEqual(gross, Decimal('0.00')) + self.assertEqual(net, Decimal('0.00')) + self.assertEqual(len(donations), 0)
--- a/sg101/templates/base.html Sat Sep 22 11:27:16 2012 -0500 +++ b/sg101/templates/base.html Wed Sep 26 19:33:26 2012 -0500 @@ -11,6 +11,7 @@ {% load potd_tags %} {% load script_tags %} {% load poll_tags %} +{% load donations_tags %} {% load core_tags %} {% load cache %} <head><title>SurfGuitar101.com | {% block title %}{% endblock %}</title> @@ -86,6 +87,9 @@ {% cache 3600 poll_block %} {% latest_poll_block %} {% endcache %} + {% cache 600 donations_block %} + {% monthly_goal %} + {% endcache %} {% cache 3600 birthday_block %} {% birthday_block %} {% endcache %}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/sg101/templates/donations/monthly_goal_tag.html Wed Sep 26 19:33:26 2012 -0500 @@ -0,0 +1,12 @@ +{% extends 'side_block.html' %} +{% load url from future %} +{% block block_title %}Donations{% endblock %} +{% block block_content %} +<p class="centered">Help us meet our monthly goal:</p> +<div style="width: 98%; border: 1px solid black; margin: auto;"> +<div style="width: {{ pct }}%; background-color: #17E3CB; color: white;"><span> </span> +</div> +</div> +<p class="centered"><strong>{{ pct }}%</strong></p> +<p class="centered"><a href="{% url 'donations-index' %}">Donate Now</a></p> +{% endblock %}