Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
11 changes: 4 additions & 7 deletions .env.sample
Original file line number Diff line number Diff line change
Expand Up @@ -24,17 +24,14 @@ AWS_ACCESS_KEY_ID=
AWS_SECRET_ACCESS_KEY=
AWS_STORAGE_BUCKET_NAME=

# PayPal
PAYPAL_RECEIVER_EMAIL=
PAYPAL_BUSINESS_ID=
PAYPAL_TEST=False
# Stripe
STRIPE_PUBLIC_KEY=
STRIPE_SECRET_KEY=
STRIPE_LIVE_MODE=False

# Sentry
SENTRY_DSN=

# Sqreen
SQREEN_TOKEN=

# reCAPTCHA
RECAPTCHA_PUBLIC_KEY=
RECAPTCHA_PRIVATE_KEY=
Expand Down
6 changes: 3 additions & 3 deletions .vscode/settings.json
Original file line number Diff line number Diff line change
Expand Up @@ -23,9 +23,9 @@
"**/migrations/**",
],
"python.linting.pylintEnabled": false,
"python.linting.pep8Enabled": true,
"python.linting.pep8Path": "pycodestyle",
"python.linting.pep8Args": [
"python.linting.pycodestyleEnabled": true,
"python.linting.pycodestylePath": "pycodestyle",
"python.linting.pycodestyleArgs": [
"--max-line-length=120",
],
"[python]": {
Expand Down
2 changes: 1 addition & 1 deletion Pipfile
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ json-logging-py = "*"
django-anymail = "*"
raven = "*"
django-meta = "*"
sqreen = "*"
stripe = "*"

[dev-packages]
pylint = "*"
Expand Down
190 changes: 79 additions & 111 deletions Pipfile.lock

Large diffs are not rendered by default.

7 changes: 7 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -106,6 +106,13 @@ docker kill $(docker ps -q); docker-compose rm -f; docker volume rm $(docker vol
docker-compose build
```

### Adding a new django vendor app
1. Update the pipfile
2. run pipenv lock
3. run docker-compose build



[docker-mac]: https://www.docker.com/docker-mac
[docker-windows]: https://www.docker.com/docker-windows
[docker-toolbox]: https://www.docker.com/products/docker-toolbox
Expand Down
22 changes: 14 additions & 8 deletions accounts/templates/account/_base.html
Original file line number Diff line number Diff line change
@@ -1,20 +1,26 @@
{% extends "coderdojochi/_base.html" %}
{% load coderdojochi_extras %}

{% comment %} Need to do title this way since allauth doesn't support django-meta {% endcomment %}
{% block title %}{{ title_placeholder }} | {{ block.super }}{% endblock %}

{% block subheader %}
{% if user.is_authenticated %}
<div class="sub-menu">
<nav class="grid-container" role="navigation">
<ul class="menu">
<li><a href="{% url 'account_logout' %}">Log Out</a></li>
</ul>
</nav>
</div>
<div class="sub-menu">
<nav class="grid-container" role="navigation">
<ul class="menu">
<li class="{% menu_is_active 'account-payments' 'current' %}">
<a href="{% url 'account-payments' %}">Payments</a>
</li>
<li>
<a href="{% url 'account_logout' %}">Log Out</a>
</li>
</ul>
</nav>
</div>
{% endif %}
{% endblock subheader %}

{% block contained_content %}
{% block content_placeholder %}{% endblock %}
{% block content_placeholder %}{% endblock %}
{% endblock %}
36 changes: 36 additions & 0 deletions accounts/templates/account/account-payments.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
{% extends "account/_base.html" %}
{% load humanize coderdojochi_extras %}

{% block title %}Donations | {{ block.super }}{% endblock %}
{% block meta_facebook_title %}My Account | {{ block.super }}{% endblock %}
{% block meta_twitter_title %}My Account | {{ block.super }}{% endblock %}

{% block body_class %}page-dojo{% endblock %}


{% block contained_content %}

<section class="margin-top-3">
<h2 class="title">Donations</h2>
{% if object_list %}
<table class="table table-striped">
<thead>
<tr>
<th>Date</th>
<th style="text-align:right;">Amount</th>
</tr>
</thead>
<tbody>
{% for payment in object_list %}
<tr>
<td>{{ payment.created_at }}</td>
<td style="text-align:right;">${{ payment.get_formatted_amount | floatformat:2 | intcomma }}</td>
</tr>
{% endfor %}
</tbody>
</table>
{% else %}
<p class="text-muted">You have no donations yet. <a href="{% url 'donate' %}">Donate now!</a></p>
{% endif %}
</section>
{% endblock %}
2 changes: 1 addition & 1 deletion accounts/templates/account/home_guardian.html
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,7 @@ <h2 class="title text-tertiary">Students</h2>
{% endfor %}
</tbody>
</table>
<p><a href="{% url 'welcome' %}?next={% url 'account_home' %}">Add another student</a></p>
<p><a href="{% url 'welcome' %}?next={% url 'account-home' %}">Add another student</a></p>
{% else %}
<p>You have no students registered yet, <a href="{% url 'welcome' %}">register a student now</a>.</p>
{% endif %}
Expand Down
5 changes: 3 additions & 2 deletions accounts/urls.py
Original file line number Diff line number Diff line change
@@ -1,10 +1,11 @@
from django.conf.urls import include
from django.urls import path

from .views import AccountHomeView, LoginView, SignupView
from .views import AccountHomeView, LoginView, PaymentsView, SignupView

urlpatterns = [
path('', AccountHomeView.as_view(), name='account_home'),
path('', AccountHomeView.as_view(), name='account-home'),
path('payments/', PaymentsView.as_view(), name='account-payments',),
path('login/', LoginView.as_view(), name='account_login'),
path('signup/', SignupView.as_view(), name='account_signup'),
path('', include('allauth.urls')),
Expand Down
22 changes: 20 additions & 2 deletions accounts/views.py
Original file line number Diff line number Diff line change
@@ -1,10 +1,15 @@
from django.conf import settings
from django.contrib import messages
from django.contrib.auth import get_user_model
from django.contrib.auth.decorators import login_required
from django.db.models import Q
from django.shortcuts import get_object_or_404, redirect, render
from django.utils import timezone
from django.utils.decorators import method_decorator
from django.views.generic import TemplateView
from django.views.generic.list import ListView

from payments.models import Donation

from allauth.account.views import LoginView as AllAuthLoginView
from allauth.account.views import SignupView as AllAuthSignupView
Expand All @@ -13,6 +18,8 @@
from coderdojochi.forms import CDCModelForm, GuardianForm, MentorForm
from coderdojochi.models import Guardian, MeetingOrder, Mentor, MentorOrder, Order, Student

User = get_user_model()


class SignupView(MetadataMixin, AllAuthSignupView):
template_name = 'account/signup.html'
Expand Down Expand Up @@ -214,7 +221,7 @@ def post_for_mentor(self, **kwargs):
'Profile information saved.'
)

return redirect('account_home')
return redirect('account-home')

else:
messages.error(
Expand Down Expand Up @@ -250,7 +257,7 @@ def post_for_guardian(self, **kwargs):
'Profile information saved.'
)

return redirect('account_home')
return redirect('account-home')

else:
messages.error(
Expand All @@ -262,3 +269,14 @@ def post_for_guardian(self, **kwargs):
context['user_form'] = user_form

return render(self.request, 'account/home_guardian.html', context)


@method_decorator(login_required, name='dispatch')
class PaymentsView(ListView):
model = Donation
template_name = "account/account-payments.html"

def get_queryset(self):
return Donation.objects.filter(
Q(customer=self.request.user) | Q(email=self.request.user.email)
).order_by('-created_at')
7 changes: 5 additions & 2 deletions app.json
Original file line number Diff line number Diff line change
Expand Up @@ -22,10 +22,13 @@
"ENABLE_DEV_FIXTURES": {
"required": true
},
"PAYPAL_BUSINESS_ID": {
"STRIPE_LIVE_PUBLIC_KEY": {
"required": true
},
"PAYPAL_RECEIVER_EMAIL": {
"STRIPE_LIVE_SECRET_KEY": {
"required": true
},
"STRIPE_LIVE_MODE": {
"required": true
},
"SECRET_KEY": {
Expand Down
2 changes: 1 addition & 1 deletion coderdojochi/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ def save(self, *args, **kwargs):
super(CDCUser, self).save(*args, **kwargs)

def get_absolute_url(self):
return reverse('account_home')
return reverse('account-home')


def generate_filename(instance, filename):
Expand Down
Loading