# Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
#
from datetime import datetime, timedelta
+from decimal import Decimal
import os
import tempfile
from django.apps import apps
def __str__(self):
return 'Klub'
+ def get_amounts(self):
+ c = {}
+ single = list(self.singleamount_set.all())
+ monthly = list(self.monthlyamount_set.all())
+ for tag, amounts in ('single', single), ('monthly', monthly):
+ wide_spot = narrow_spot = 0
+ for i, p in enumerate(amounts):
+ if p.wide:
+ # Do we have space for xl?
+ if wide_spot < 2:
+ p.box_variant = 'xl'
+ wide_spot += 2
+ else:
+ p.box_variant = 'card'
+ wide_spot += 1
+ narrow_spot = 0
+ elif p.description:
+ p.box_variant = 'card'
+ if narrow_spot:
+ amounts[i-1].box_variant = 'bar'
+ wide_spot += 1
+ narrow_spot = 0
+ else:
+ p.box_variant = 'half'
+ wide_spot += 1
+ narrow_spot += 1
+ wide_spot %= 3
+ narrow_spot %= 2
+ c[tag] = amounts
+ c[f'{tag}_wide_spot'] = wide_spot
+ return c
+
+ def get_description_for_amount(self, amount, monthly):
+ amounts = self.monthlyamount_set if monthly else self.singleamount_set
+ amount = amounts.all().filter(amount__lte=amount).last()
+ return amount.description if amount is not None else ''
+
class SingleAmount(models.Model):
club = models.ForeignKey(Club, models.CASCADE)
amount = models.IntegerField()
description = models.TextField(blank=True)
+ wide = models.BooleanField(default=False)
class Meta:
ordering = ['amount']
club = models.ForeignKey(Club, models.CASCADE)
amount = models.IntegerField()
description = models.TextField(blank=True)
+ wide = models.BooleanField(default=False)
class Meta:
ordering = ['amount']
super(Schedule, self).save(*args, **kwargs)
self.update_contact()
+ def get_description(self):
+ club = Club.objects.first()
+ return club.get_description_for_amount(self.amount, self.monthly)
+
def initiate_payment(self, request):
return self.get_payment_method().initiate(request, self)
Contact = apps.get_model('messaging', 'Contact')
Funding = apps.get_model('funding', 'Funding')
BillingAgreement = apps.get_model('paypal', 'BillingAgreement')
+ DirectDebit = apps.get_model('pz', 'DirectDebit')
+ Payment = apps.get_model('pz', 'Payment')
+
payments = []
+ optout = None
try:
contact = Contact.objects.get(email=email)
except Contact.DoesNotExist:
notifications=True).order_by('completed_at').first()
if funding is None:
print('no notifications')
- return
- optout = funding.wl_optout_url()
+ if not DirectDebit.objects.filter(email=email, optout=False).exists():
+ return
+ else:
+ optout = funding.wl_optout_url()
else:
if contact.level == Level.OPT_OUT:
print('opt-out')
'amount': funding.amount,
})
+ for pa in Payment.objects.filter(
+ debit__email=email,
+ realised=True,
+ is_dd=True,
+ booking_date__year=year
+ ):
+ payments.append({
+ 'timestamp': datetime(pa.booking_date.year, pa.booking_date.month, pa.booking_date.day, tzinfo=utc),
+ 'amount': Decimal(str(pa.debit.amount) + '.00')
+ })
+
+
if not payments: return
payments.sort(key=lambda x: x['timestamp'])
temp = tempfile.NamedTemporaryFile(prefix='receipt-', suffix='.pdf', delete=False)
temp.close()
render_to_pdf(temp.name, 'club/receipt.texml', ctx, {
- "fnp.eps": os.path.join(settings.STATIC_ROOT, "img/fnp.eps"),
+ "wl.eps": os.path.join(settings.STATIC_ROOT, "img/wl.eps"),
})
message = EmailMessage(
'Odlicz darowiznę na Wolne Lektury od podatku',
template.loader.render_to_string('club/receipt_email.txt', ctx),
- settings.CONTACT_EMAIL, [email]
+ settings.CLUB_CONTACT_EMAIL, [email]
)
with open(temp.name, 'rb') as f:
message.attach('wolnelektury-darowizny.pdf', f.read(), 'application/pdf')