add checkout template, view and function
This commit is contained in:
parent
9f8a01dbaf
commit
5b1530c0bd
|
@ -46,6 +46,9 @@
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
|
<a href="{% url 'checkout' %}" class="btn btn-primary" role="button">
|
||||||
|
CHECKOUT
|
||||||
|
</a>
|
||||||
{% else %}
|
{% else %}
|
||||||
<p class="alert alert-danger">
|
<p class="alert alert-danger">
|
||||||
<strong>
|
<strong>
|
||||||
|
|
|
@ -1,8 +1,24 @@
|
||||||
{% extends "webshop/base.html" %}
|
{% extends "webshop/base.html" %}
|
||||||
{% block section_title %}<h1>Cart</h1>{% endblock %}
|
{% block section_title %}<h1>CHECKOUT</h1>{% endblock %}
|
||||||
{% block content %}
|
{% block content %}
|
||||||
<h3>List of Items in your Shopping Cart:</h3>
|
<h3>Preview your Purchase:</h3>
|
||||||
|
<h4>Shipping Address:</h4>
|
||||||
|
{% if user_list %}
|
||||||
|
<p><b>Salutation: </b>{{ person.salutation }}</p>
|
||||||
|
<p><b>Firstname: </b>{{ request.user.first_name }}</p>
|
||||||
|
<p><b>Lastname: </b>{{ request.user.last_name }}</p>
|
||||||
|
<p><b>Street: </b>{{ person.street_name }}</p>
|
||||||
|
<p><b>Streetnumber: </b>{{ person.street_number }}</p>
|
||||||
|
<p><b>City: </b>{{ person.city }}</p>
|
||||||
|
{% else %}
|
||||||
|
<p class="alert alert-danger">
|
||||||
|
<strong>
|
||||||
|
Something whent wrong. Your User is incomplete.
|
||||||
|
<strong>
|
||||||
|
</p>
|
||||||
|
{% endif %}
|
||||||
{% if articles_list %}
|
{% if articles_list %}
|
||||||
|
<h4>Articles:</h4>
|
||||||
<table class="table">
|
<table class="table">
|
||||||
<tr class="table_header">
|
<tr class="table_header">
|
||||||
<th scope="col">POS.</th>
|
<th scope="col">POS.</th>
|
||||||
|
@ -39,11 +55,6 @@
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
<form id="checkout" method="post">
|
|
||||||
{% csrf_token %}
|
|
||||||
{{ checkout_form.as_p }}
|
|
||||||
<input type="submit" value="checkout ->" />
|
|
||||||
</form>
|
|
||||||
{% else %}
|
{% else %}
|
||||||
<p class="alert alert-danger">
|
<p class="alert alert-danger">
|
||||||
<strong>
|
<strong>
|
||||||
|
|
|
@ -20,4 +20,7 @@ urlpatterns = [
|
||||||
url(r'^cart/$',
|
url(r'^cart/$',
|
||||||
views.cart,
|
views.cart,
|
||||||
name='cart'),
|
name='cart'),
|
||||||
|
url(r'^checkout/$',
|
||||||
|
views.checkout,
|
||||||
|
name='checkout'),
|
||||||
]
|
]
|
||||||
|
|
|
@ -260,27 +260,130 @@ def cart(request):
|
||||||
operation
|
operation
|
||||||
)
|
)
|
||||||
|
|
||||||
if 'checkout' in request.POST:
|
|
||||||
print('checkout')
|
|
||||||
checkout_form = CheckoutForm(request.POST)
|
|
||||||
if checkout_form.is_valid():
|
|
||||||
checkout_form = checkout_form.cleaned_data['checkout']
|
|
||||||
print('views checkout checkout_form', checkout_form)
|
|
||||||
if checkout_form is True:
|
|
||||||
# todo add to order
|
|
||||||
order = ''
|
|
||||||
# here we handle the normal cart view:
|
# here we handle the normal cart view:
|
||||||
# if cart_id is not existent create a cart:
|
# if cart_id is not existent create a cart:
|
||||||
cart_id, created_cart = ShoppingCart.objects.get_or_create(user=user_id)
|
cart_id, created_cart = ShoppingCart.objects.get_or_create(user=user_id)
|
||||||
# get all items in the cart of this customer:
|
# get all items in the cart of this customer:
|
||||||
articles = CartPosition.objects.filter(cart=cart_id)
|
cart_positions = CartPosition.objects.filter(cart=cart_id)
|
||||||
if (articles.count()) > 0:
|
if (cart_positions.count()) > 0:
|
||||||
# make a list out of all articles:
|
# make a list out of all articles:
|
||||||
cart_position_list = list(articles)
|
cart_position_list = list(cart_positions)
|
||||||
# enumerate the list of articles and loop over items:
|
# enumerate the list of articles and loop over items:
|
||||||
for idx, cart_position in enumerate(cart_position_list):
|
for idx, cart_position in enumerate(cart_position_list):
|
||||||
# sub funciton of CartPosition:
|
# *************************************************
|
||||||
cart_position.calculate_position_price()
|
# !!! here i don't understand how its intended
|
||||||
|
# to use the utils function.
|
||||||
|
# cart_position = process_article_prices(request, cart_position)
|
||||||
|
# *************************************************
|
||||||
|
# scrap out the details to calculate Total of item and Summ of All:
|
||||||
|
if currency:
|
||||||
|
# get currencyname to display:
|
||||||
|
currency_name = ExchangeRate_name.objects.get(id=currency)
|
||||||
|
# get exchange_rate multiplyed:
|
||||||
|
cart_position.price_in_chf = rate.exchange(
|
||||||
|
currency,
|
||||||
|
cart_position.article.price_in_chf
|
||||||
|
)
|
||||||
|
totalprice_list.append(cart_position.price_in_chf)
|
||||||
|
amount_form = CartForm(
|
||||||
|
initial={'amount_form': cart_position.amount}
|
||||||
|
)
|
||||||
|
amount_form_list.append(amount_form)
|
||||||
|
cart_position_list[idx] = cart_position
|
||||||
|
cart_position_list_zip = zip(cart_position_list, amount_form_list)
|
||||||
|
|
||||||
|
total = sum(totalprice_list)
|
||||||
|
|
||||||
|
return render(request, 'webshop/cart.html',
|
||||||
|
{'cart_position_list_zip': cart_position_list_zip,
|
||||||
|
'totalprice_list': totalprice_list,
|
||||||
|
'total': total,
|
||||||
|
'currencies_form': currencies_form,
|
||||||
|
'amount_form': amount_form,
|
||||||
|
'article_view': article_view,
|
||||||
|
'currency_name': currency_name,
|
||||||
|
'category_list': category_list,
|
||||||
|
'message': message,
|
||||||
|
})
|
||||||
|
|
||||||
|
def checkout(request):
|
||||||
|
category_list = get_categories()
|
||||||
|
currencies_form = CurrenciesForm
|
||||||
|
amount_form = CartForm
|
||||||
|
rate = ExchangeRate
|
||||||
|
article_view = True
|
||||||
|
currency_name = "CHF"
|
||||||
|
message = ""
|
||||||
|
cart_position_list = []
|
||||||
|
amount_form_list = []
|
||||||
|
totalprice_list = []
|
||||||
|
total = 0
|
||||||
|
user_id = request.user.id
|
||||||
|
cart_position_list_zip = []
|
||||||
|
# here we configure the users Currency:
|
||||||
|
if 'currency' not in request.session:
|
||||||
|
request.session['currency'] = None
|
||||||
|
else:
|
||||||
|
currency = request.session['currency']
|
||||||
|
# Here we handle all POST Operations:
|
||||||
|
if request.method == 'POST':
|
||||||
|
# here we react to a currency dropdown change:
|
||||||
|
if 'currencies' in request.POST:
|
||||||
|
print('currencies')
|
||||||
|
currencies_form = CurrenciesForm(request.POST)
|
||||||
|
if currencies_form.is_valid():
|
||||||
|
cf = currencies_form.cleaned_data
|
||||||
|
if cf['currencies']:
|
||||||
|
print('currencies cf:', cf)
|
||||||
|
selection = cf['currencies']
|
||||||
|
request.session['currency'] = selection.id
|
||||||
|
currency_name = ExchangeRate_name.objects.get(
|
||||||
|
id=selection.id)
|
||||||
|
print('currencies currency_name:', currency_name)
|
||||||
|
else:
|
||||||
|
request.session['currency'] = None
|
||||||
|
# here we react to a change of amount per item in the Cart:
|
||||||
|
if 'amount_form' in request.POST:
|
||||||
|
amount_form = CartForm(request.POST)
|
||||||
|
if amount_form.is_valid():
|
||||||
|
amount = amount_form.cleaned_data['amount_form']
|
||||||
|
article_id = request.POST.get('article_id')
|
||||||
|
operation = 'replace'
|
||||||
|
restrict_cart_to_one_article(
|
||||||
|
user_id,
|
||||||
|
article_id,
|
||||||
|
amount,
|
||||||
|
operation
|
||||||
|
)
|
||||||
|
# here we react to a change of amount per item in the Cart:
|
||||||
|
if 'delete' in request.POST:
|
||||||
|
delete = CartForm(request.POST)
|
||||||
|
if delete.is_valid():
|
||||||
|
amount = delete.cleaned_data['amount_form']
|
||||||
|
article_id = request.POST.get('article_id')
|
||||||
|
amount = 1
|
||||||
|
operation = 'delete'
|
||||||
|
restrict_cart_to_one_article(
|
||||||
|
user_id,
|
||||||
|
article_id,
|
||||||
|
amount,
|
||||||
|
operation
|
||||||
|
)
|
||||||
|
# here we handle the normal cart view:
|
||||||
|
# if cart_id is not existent create a cart:
|
||||||
|
cart_id, created_cart = ShoppingCart.objects.get_or_create(user=user_id)
|
||||||
|
# get all items in the cart of this customer:
|
||||||
|
cart_positions = CartPosition.objects.filter(cart=cart_id)
|
||||||
|
if (cart_positions.count()) > 0:
|
||||||
|
# make a list out of all articles:
|
||||||
|
cart_position_list = list(cart_positions)
|
||||||
|
# enumerate the list of articles and loop over items:
|
||||||
|
for idx, cart_position in enumerate(cart_position_list):
|
||||||
|
# *************************************************
|
||||||
|
# !!! here i don't understand how its intended
|
||||||
|
# to use the utils function.
|
||||||
|
# cart_position = process_article_prices(request, cart_position)
|
||||||
|
# *************************************************
|
||||||
# scrap out the details to calculate Total of item and Summ of All:
|
# scrap out the details to calculate Total of item and Summ of All:
|
||||||
if currency:
|
if currency:
|
||||||
# get currencyname to display:
|
# get currencyname to display:
|
||||||
|
@ -301,6 +404,7 @@ def cart(request):
|
||||||
total = sum(totalprice_list)
|
total = sum(totalprice_list)
|
||||||
|
|
||||||
checkout_form = CheckoutForm()
|
checkout_form = CheckoutForm()
|
||||||
|
registration_form = RegistrationForm()
|
||||||
|
|
||||||
return render(request, 'webshop/cart.html',
|
return render(request, 'webshop/cart.html',
|
||||||
{'cart_position_list_zip': cart_position_list_zip,
|
{'cart_position_list_zip': cart_position_list_zip,
|
||||||
|
@ -308,6 +412,8 @@ def cart(request):
|
||||||
'total': total,
|
'total': total,
|
||||||
'currencies_form': currencies_form,
|
'currencies_form': currencies_form,
|
||||||
'amount_form': amount_form,
|
'amount_form': amount_form,
|
||||||
|
'checkout_form': checkout_form,
|
||||||
|
'registration_form': registration_form,
|
||||||
'article_view': article_view,
|
'article_view': article_view,
|
||||||
'currency_name': currency_name,
|
'currency_name': currency_name,
|
||||||
'category_list': category_list,
|
'category_list': category_list,
|
||||||
|
|
Loading…
Reference in New Issue