mirror of
https://github.com/pretix/pretix.git
synced 2026-05-04 15:04:03 +00:00
Added a settings change view for users in the frontend
This commit is contained in:
@@ -38,10 +38,10 @@ class VersionedBaseModelForm(BaseI18nModelForm):
|
||||
clone = old.clone()
|
||||
for f in type(self.instance)._meta.get_fields():
|
||||
if f.name not in (
|
||||
'id', 'identity', 'version_start_date', 'version_end_date',
|
||||
'version_birth_date'
|
||||
'id', 'identity', 'version_start_date', 'version_end_date',
|
||||
'version_birth_date'
|
||||
) and not isinstance(f, (
|
||||
models.ManyToOneRel, models.ManyToManyRel, models.ManyToManyField
|
||||
models.ManyToOneRel, models.ManyToManyRel, models.ManyToManyField
|
||||
)):
|
||||
setattr(clone, f.name, getattr(new, f.name))
|
||||
self.instance = clone
|
||||
@@ -29,15 +29,19 @@ class UserSettingsForm(forms.ModelForm):
|
||||
required=False,
|
||||
label=_("Repeat new password"),
|
||||
widget=forms.PasswordInput())
|
||||
timezone = forms.ChoiceField(
|
||||
choices=((a, a) for a in common_timezones),
|
||||
label=_("Default timezone"),
|
||||
)
|
||||
# timezone = forms.ChoiceField(
|
||||
# choices=((a, a) for a in common_timezones),
|
||||
# label=_("Default timezone"),
|
||||
# )
|
||||
|
||||
class Meta:
|
||||
model = User
|
||||
fields = [
|
||||
'givenname', 'familyname', 'locale', 'timezone', 'email'
|
||||
'givenname',
|
||||
'familyname',
|
||||
'locale',
|
||||
# 'timezone',
|
||||
'email'
|
||||
]
|
||||
|
||||
def __init__(self, *args, **kwargs):
|
||||
@@ -12,7 +12,6 @@
|
||||
{% bootstrap_field form.givenname layout='horizontal' %}
|
||||
{% bootstrap_field form.familyname layout='horizontal' %}
|
||||
{% bootstrap_field form.locale layout='horizontal' %}
|
||||
{% bootstrap_field form.timezone layout='horizontal' %}
|
||||
</fieldset>
|
||||
<fieldset>
|
||||
<legend>{% trans "Login settings" %}</legend>
|
||||
|
||||
@@ -3,7 +3,7 @@ from django.contrib.auth import update_session_auth_hash
|
||||
from django.core.urlresolvers import reverse
|
||||
from django.views.generic import UpdateView
|
||||
from django.utils.translation import ugettext_lazy as _
|
||||
from pretix.control.forms.user import UserSettingsForm
|
||||
from pretix.base.forms.user import UserSettingsForm
|
||||
|
||||
from pretix.base.models import User
|
||||
|
||||
|
||||
@@ -34,4 +34,11 @@ footer {
|
||||
img {
|
||||
vertical-align: baseline;
|
||||
}
|
||||
}
|
||||
.huge {
|
||||
font-size: 40px;
|
||||
}
|
||||
a:hover .panel-primary > .panel-heading {
|
||||
background-color: darken(@btn-primary-bg, 10%);
|
||||
border-color: darken(@btn-primary-border, 12%);
|
||||
}
|
||||
@@ -0,0 +1,58 @@
|
||||
{% extends "pretixpresale/event/base.html" %}
|
||||
{% load i18n %}
|
||||
{% block title %}{% trans "Your account" %}{% endblock %}
|
||||
|
||||
{% block content %}
|
||||
<h2>{% trans "Welcome back!" %}</h2>
|
||||
<div class="row">
|
||||
<div class="col-md-6">
|
||||
{% if orders %}
|
||||
<a href="{% url "presale:event.orders" event=request.event.slug organizer=request.event.organizer.slug %}">
|
||||
<div class="panel panel-primary">
|
||||
<div class="panel-heading">
|
||||
<div class="row">
|
||||
<div class="col-xs-3">
|
||||
<i class="fa fa-shopping-cart fa-5x"></i>
|
||||
</div>
|
||||
<div class="col-xs-9 text-right">
|
||||
<div class="huge">{% trans "Your orders" %}</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</a>
|
||||
{% else %}
|
||||
<a href="{% url "presale:event.index" event=request.event.slug organizer=request.event.organizer.slug %}">
|
||||
<div class="panel panel-primary">
|
||||
<div class="panel-heading">
|
||||
<div class="row">
|
||||
<div class="col-xs-3">
|
||||
<i class="fa fa-shopping-cart fa-5x"></i>
|
||||
</div>
|
||||
<div class="col-xs-9 text-right">
|
||||
<div class="huge">{% trans "Place new order" %}</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</a>
|
||||
{% endif %}
|
||||
</div>
|
||||
<div class="col-md-6">
|
||||
<a href="{% url "presale:event.account.settings" event=request.event.slug organizer=request.event.organizer.slug %}">
|
||||
<div class="panel panel-primary">
|
||||
<div class="panel-heading">
|
||||
<div class="row">
|
||||
<div class="col-xs-3">
|
||||
<i class="fa fa-wrench fa-5x"></i>
|
||||
</div>
|
||||
<div class="col-xs-9 text-right">
|
||||
<div class="huge">{% trans "Your settings" %}</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</a>
|
||||
</div>
|
||||
</div>
|
||||
{% endblock %}
|
||||
@@ -0,0 +1,33 @@
|
||||
{% extends "pretixpresale/event/base.html" %}
|
||||
{% load i18n %}
|
||||
{% load bootstrap3 %}
|
||||
{% block title %}{% trans "Account settings" %}{% endblock %}
|
||||
|
||||
{% block content %}
|
||||
<h2>{% trans "Account settings" %}</h2>
|
||||
<form action="" method="post" class="form-horizontal">
|
||||
{% csrf_token %}
|
||||
{% bootstrap_form_errors form %}
|
||||
<fieldset>
|
||||
<legend>{% trans "General settings" %}</legend>
|
||||
{% bootstrap_field form.givenname layout='horizontal' %}
|
||||
{% bootstrap_field form.familyname layout='horizontal' %}
|
||||
{% bootstrap_field form.locale layout='horizontal' %}
|
||||
</fieldset>
|
||||
<fieldset>
|
||||
<legend>{% trans "Login settings" %}</legend>
|
||||
{% bootstrap_field form.old_pw layout='horizontal' %}
|
||||
{% bootstrap_field form.email layout='horizontal' %}
|
||||
{% bootstrap_field form.new_pw layout='horizontal' %}
|
||||
{% bootstrap_field form.new_pw_repeat layout='horizontal' %}
|
||||
</fieldset>
|
||||
<div class="row checkout-button-row">
|
||||
<div class="col-md-4 col-md-offset-8">
|
||||
<button class="btn btn-block btn-primary btn-lg" type="submit">
|
||||
{% trans "Save" %}
|
||||
</button>
|
||||
</div>
|
||||
<div class="clearfix"></div>
|
||||
</div>
|
||||
</form>
|
||||
{% endblock %}
|
||||
@@ -20,7 +20,7 @@
|
||||
<div class="container event">
|
||||
<div class="page-header">
|
||||
<h1 class="pull-left">
|
||||
{{ event.name }}
|
||||
<a href="{% url "presale:event.index" event=event.slug organizer=event.organizer.slug %}">{{ event.name }}</a>
|
||||
<small>{{ event.date_from|date:"DATE_FORMAT" }}{% if event.settings.show_date_to %} – {{ event.date_to|date:"DATE_FORMAT" }}{% endif %}</small>
|
||||
</h1>
|
||||
<div class="pull-right loginbox">
|
||||
@@ -39,8 +39,8 @@
|
||||
{% blocktrans trimmed with name=request.user.get_short_name %}
|
||||
Hello, {{ name }}!
|
||||
{% endblocktrans %} ·
|
||||
<a href="{% url "presale:event.orders" event=request.event.slug organizer=request.event.organizer.slug %}">
|
||||
{% trans "My orders" %}</a> ·
|
||||
<a href="{% url "presale:event.account" event=request.event.slug organizer=request.event.organizer.slug %}">
|
||||
{% trans "Your account" %}</a> ·
|
||||
<a href="{% url "presale:event.logout" event=request.event.slug organizer=request.event.organizer.slug %}">
|
||||
{% trans "Logout" %}</a>
|
||||
{% else %}
|
||||
|
||||
@@ -3,45 +3,38 @@
|
||||
{% block title %}{% trans "Your orders" %}{% endblock %}
|
||||
|
||||
{% block content %}
|
||||
<h2>{% trans "Welcome back!" %}</h2>
|
||||
<div class="panel panel-primary">
|
||||
<div class="panel-heading">
|
||||
<h3 class="panel-title">{% trans "Your orders" %}</h3>
|
||||
</div>
|
||||
<div class="panel-body">
|
||||
<table class="table">
|
||||
<thead>
|
||||
<th>{% trans "Order code" %}</th>
|
||||
<th>{% trans "Date" %}</th>
|
||||
<th>{% trans "Total" %}</th>
|
||||
<th>{% trans "Status" %}</th>
|
||||
<th></th>
|
||||
</thead>
|
||||
<tbody>
|
||||
{% for order in orders %}
|
||||
<tr>
|
||||
<td>{{ order.code }}</td>
|
||||
<td>{{ order.datetime|date:"SHORT_DATE_FORMAT" }}</td>
|
||||
<td>{{ event.currency }} {{ order.total|floatformat:2 }}</td>
|
||||
<td>{% include "pretixpresale/event/fragment_order_status.html" with order=order %}</td>
|
||||
<td><a href="{% url "presale:event.order" event=request.event.slug organizer=request.event.organizer.slug order=order.code %}">
|
||||
{% trans "View details" %}
|
||||
</a></td>
|
||||
</tr>
|
||||
{% empty %}
|
||||
<tr>
|
||||
<td colspan="5">
|
||||
<em>{% trans "You did not yet place any orders." %}</em>
|
||||
</td>
|
||||
</tr>
|
||||
{% endfor %}
|
||||
</tbody>
|
||||
</table>
|
||||
<a href="{% url "presale:event.index" event=request.event.slug organizer=request.event.organizer.slug %}"
|
||||
class="btn btn-primary btn-lg">
|
||||
<span class="fa fa-plus"></span>
|
||||
{% trans "Place new order" %}
|
||||
</a>
|
||||
</div>
|
||||
</div>
|
||||
<h2>{% trans "Your orders" %}</h2>
|
||||
<table class="table">
|
||||
<thead>
|
||||
<th>{% trans "Order code" %}</th>
|
||||
<th>{% trans "Date" %}</th>
|
||||
<th>{% trans "Total" %}</th>
|
||||
<th>{% trans "Status" %}</th>
|
||||
<th></th>
|
||||
</thead>
|
||||
<tbody>
|
||||
{% for order in orders %}
|
||||
<tr>
|
||||
<td>{{ order.code }}</td>
|
||||
<td>{{ order.datetime|date:"SHORT_DATE_FORMAT" }}</td>
|
||||
<td>{{ event.currency }} {{ order.total|floatformat:2 }}</td>
|
||||
<td>{% include "pretixpresale/event/fragment_order_status.html" with order=order %}</td>
|
||||
<td><a href="{% url "presale:event.order" event=request.event.slug organizer=request.event.organizer.slug order=order.code %}">
|
||||
{% trans "View details" %}
|
||||
</a></td>
|
||||
</tr>
|
||||
{% empty %}
|
||||
<tr>
|
||||
<td colspan="5">
|
||||
<em>{% trans "You did not yet place any orders." %}</em>
|
||||
</td>
|
||||
</tr>
|
||||
{% endfor %}
|
||||
</tbody>
|
||||
</table>
|
||||
<a href="{% url "presale:event.index" event=request.event.slug organizer=request.event.organizer.slug %}"
|
||||
class="btn btn-primary btn-lg">
|
||||
<span class="fa fa-plus"></span>
|
||||
{% trans "Place new order" %}
|
||||
</a>
|
||||
{% endblock %}
|
||||
@@ -34,6 +34,8 @@ urlpatterns = [
|
||||
url(r'^forgot/recover$', pretix.presale.views.event.EventRecover.as_view(), name='event.forgot.recover'),
|
||||
url(r'^logout$', pretix.presale.views.event.EventLogout.as_view(), name='event.logout'),
|
||||
url(r'^orders$', pretix.presale.views.event.EventOrders.as_view(), name='event.orders'),
|
||||
url(r'^account$', pretix.presale.views.event.EventAccount.as_view(), name='event.account'),
|
||||
url(r'^account/settings$', pretix.presale.views.event.EventAccountSettings.as_view(), name='event.account.settings'),
|
||||
])),
|
||||
url(r'^locale/set$', pretix.presale.views.locale.LocaleSet.as_view(), name='locale.set'),
|
||||
]
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
import json
|
||||
|
||||
from django.contrib import messages
|
||||
from django.contrib.auth import authenticate, logout
|
||||
from django.contrib.auth import authenticate, logout, update_session_auth_hash
|
||||
from django.core import signing
|
||||
from django.core.signing import SignatureExpired, BadSignature
|
||||
from django.core.urlresolvers import reverse
|
||||
@@ -9,9 +9,10 @@ from django.db.models import Count
|
||||
from django.shortcuts import redirect
|
||||
from django.utils.functional import cached_property
|
||||
from django.contrib.auth import login
|
||||
from django.views.generic import TemplateView, View
|
||||
from django.views.generic import TemplateView, View, UpdateView
|
||||
from django.utils.translation import ugettext_lazy as _
|
||||
from django.conf import settings
|
||||
from pretix.base.forms.user import UserSettingsForm
|
||||
from pretix.base.services.mail import mail
|
||||
from pretix.base.models import User
|
||||
from pretix.helpers.urls import build_absolute_uri
|
||||
@@ -89,7 +90,7 @@ class EventLogin(EventViewMixin, TemplateView):
|
||||
if 'next' in self.request.GET:
|
||||
return redirect(self.request.GET.get('next'))
|
||||
else:
|
||||
return redirect('presale:event.orders',
|
||||
return redirect('presale:event.account',
|
||||
organizer=self.request.event.organizer.slug,
|
||||
event=self.request.event.slug)
|
||||
|
||||
@@ -297,6 +298,15 @@ class EventLogout(EventViewMixin, View):
|
||||
event=self.request.event.slug)
|
||||
|
||||
|
||||
class EventAccount(EventLoginRequiredMixin, EventViewMixin, TemplateView):
|
||||
template_name = 'pretixpresale/event/account.html'
|
||||
|
||||
def get_context_data(self, **kwargs):
|
||||
context = super().get_context_data(**kwargs)
|
||||
context['orders'] = self.request.user.orders.current.count()
|
||||
return context
|
||||
|
||||
|
||||
class EventOrders(EventLoginRequiredMixin, EventViewMixin, TemplateView):
|
||||
template_name = 'pretixpresale/event/orders.html'
|
||||
|
||||
@@ -304,3 +314,30 @@ class EventOrders(EventLoginRequiredMixin, EventViewMixin, TemplateView):
|
||||
context = super().get_context_data(**kwargs)
|
||||
context['orders'] = self.request.user.orders.current.all()
|
||||
return context
|
||||
|
||||
|
||||
class EventAccountSettings(EventLoginRequiredMixin, EventViewMixin, UpdateView):
|
||||
model = User
|
||||
form_class = UserSettingsForm
|
||||
template_name = 'pretixpresale/event/account_settings.html'
|
||||
|
||||
def get_object(self, queryset=None):
|
||||
return self.request.user
|
||||
|
||||
def get_form_kwargs(self):
|
||||
kwargs = super().get_form_kwargs()
|
||||
kwargs['user'] = self.request.user
|
||||
return kwargs
|
||||
|
||||
def form_invalid(self, form):
|
||||
messages.error(self.request, _('Your changes could not be saved. See below for details.'))
|
||||
return super().form_invalid(form)
|
||||
|
||||
def form_valid(self, form):
|
||||
messages.success(self.request, _('Your changes have been saved.'))
|
||||
sup = super().form_valid(form)
|
||||
update_session_auth_hash(self.request, self.request.user)
|
||||
return sup
|
||||
|
||||
def get_success_url(self):
|
||||
return reverse('control:user.settings')
|
||||
|
||||
Reference in New Issue
Block a user