From a2acec2a226880ae435f6392cff30b56ad038b13 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E2=80=9COMosimege=E2=80=9D?= <“onalerona.mosimege@gmail.com”> Date: Wed, 10 Jul 2024 14:26:12 +0200 Subject: [PATCH] Add user manangement views, templates, and styling --- app/accounts/forms.py | 43 ++++++++-- app/accounts/views.py | 20 ++++- app/static/css/styles.css | 12 ++- app/templates/accounts/login.html | 84 +++++++++++++++---- .../accounts/password_reset_complete.html | 20 +++-- .../accounts/password_reset_confirm.html | 63 +++++++------- .../accounts/password_reset_done.html | 16 ++-- .../accounts/password_reset_form.html | 44 +++++----- app/templates/accounts/register.html | 49 +++++++++-- app/templates/base_error.html | 2 +- 10 files changed, 258 insertions(+), 95 deletions(-) diff --git a/app/accounts/forms.py b/app/accounts/forms.py index e8cb29e7..79b6748f 100644 --- a/app/accounts/forms.py +++ b/app/accounts/forms.py @@ -1,14 +1,31 @@ from django import forms -from django.contrib.auth.forms import UserCreationForm +from django.contrib.auth.forms import AuthenticationForm, UserCreationForm +from django.utils.translation import gettext_lazy as _ from users.models import CustomUser class CustomUserCreationForm(UserCreationForm): - email = forms.EmailField(required=True, help_text="Required. Add a valid email address.") - username = forms.CharField(required=True, help_text="Required. Add a valid username.") - first_name = forms.CharField(required=True, help_text="Required. Add a valid first name.") - last_name = forms.CharField(required=True, help_text="Required. Add a valid last name.") + email = forms.EmailField( + required=True, + help_text=_("Required. Add a valid email address."), + widget=forms.EmailInput(attrs={"class": "form-control"}), + ) + username = forms.CharField( + required=True, + help_text=_("Required. Add a valid username."), + widget=forms.TextInput(attrs={"class": "form-control"}), + ) + first_name = forms.CharField( + required=True, + help_text=_("Required. Add a valid first name."), + widget=forms.TextInput(attrs={"class": "form-control"}), + ) + last_name = forms.CharField( + required=True, + help_text=_("Required. Add a valid last name."), + widget=forms.TextInput(attrs={"class": "form-control"}), + ) class Meta: model = CustomUser @@ -16,7 +33,15 @@ class Meta: def __init__(self, *args, **kwargs): super(CustomUserCreationForm, self).__init__(*args, **kwargs) - self.fields["email"].required = True - self.fields["username"].required = True - self.fields["first_name"].required = True - self.fields["last_name"].required = True + for field_name, field in self.fields.items(): + field.widget.attrs["class"] = "form-control" + + +class CustomAuthenticationForm(AuthenticationForm): + username = forms.CharField(label=_("Username"), help_text=_("Required. Enter your username.")) + password = forms.CharField(label=_("Password"), help_text=_("Required. Enter your password.")) + + def __init__(self, *args, **kwargs): + super(CustomAuthenticationForm, self).__init__(*args, **kwargs) + for field in self.fields.values(): + field.widget.attrs.update({"class": "form-control"}) diff --git a/app/accounts/views.py b/app/accounts/views.py index b2eabcb4..e02657fa 100644 --- a/app/accounts/views.py +++ b/app/accounts/views.py @@ -1,7 +1,8 @@ -from django.contrib.auth import login +from django.contrib.auth import authenticate +from django.contrib.auth import login as auth_login from django.shortcuts import redirect, render -from .forms import CustomUserCreationForm +from .forms import CustomAuthenticationForm, CustomUserCreationForm def register(request): @@ -11,8 +12,21 @@ def register(request): user = form.save(commit=False) user.is_staff = True user.save() - login(request, user) + auth_login(request, user) return redirect("home") else: form = CustomUserCreationForm() return render(request, "accounts/register.html", {"form": form}) + + +def user_login(request): + if request.method == "POST": + form = CustomAuthenticationForm(request, data=request.POST) + if form.is_valid(): + user = form.get_user() + auth_login(request, user) + return redirect("home") + else: + form = CustomAuthenticationForm() + + return render(request, "accounts/login.html", {"form": form}) diff --git a/app/static/css/styles.css b/app/static/css/styles.css index d8ff1f36..438c5e2e 100755 --- a/app/static/css/styles.css +++ b/app/static/css/styles.css @@ -344,12 +344,20 @@ html { font-size: 0.875rem; } +/*Accounts*/ +.user-account-body { + margin: 30px; +} +.login-form-group .form-control { + width: 100%; + max-width: 500px; +} /*Error pages*/ -.error-card { +.body-card { border-color: var(--primary-red); - margin: 0 10px 0 10px; + margin: 10px; width: 100%; } diff --git a/app/templates/accounts/login.html b/app/templates/accounts/login.html index 99b7250d..1bf99d15 100644 --- a/app/templates/accounts/login.html +++ b/app/templates/accounts/login.html @@ -1,22 +1,76 @@ {% extends "base.html" %} +{% load static %} +{% load i18n %} -{% block title %}Log In{% endblock %} +{% block title %}{% trans "Log In" %}{% endblock %} {% block content %} -
{{ error }}
+ {% endfor %} +{{ error }}
+ {% endfor %} +{{ error }}
+ {% endfor %} +{% trans "Don't have an account?" %} {% trans "Create one" %}
+Your password has been set. You may go ahead and log in now.
-{% trans "Your password has been set. You may go ahead and log in now." %}
+Please enter your new password twice so we can verify you typed it in correctly.
- -