nopaque/app/profile/views.py

70 lines
3.0 KiB
Python
Raw Normal View History

from flask import flash, redirect, render_template, url_for
from flask_login import current_user, login_required, logout_user
from . import profile
from . import tasks
2020-02-19 14:49:52 +01:00
from .forms import EditEmailForm, EditGeneralSettingsForm, EditPasswordForm
2020-03-27 12:06:11 +01:00
from .. import db
2020-02-19 14:49:52 +01:00
@profile.route('/settings', methods=['GET', 'POST'])
@login_required
2020-02-19 14:49:52 +01:00
def settings():
edit_email_form = EditEmailForm(prefix='edit-email-form')
edit_general_settings_form = EditGeneralSettingsForm(
prefix='edit-general-settings-form')
2020-02-19 14:49:52 +01:00
edit_password_form = EditPasswordForm(prefix='edit-password-form',
user=current_user)
# Check if edit_email_form is submitted and valid
if (edit_email_form.save_email.data
and edit_email_form.validate_on_submit()):
db.session.add(current_user)
2019-10-31 13:19:18 +01:00
db.session.commit()
2020-02-19 14:49:52 +01:00
flash('Your email address has been updated.')
return redirect(url_for('profile.settings'))
# Check if edit_settings_form is submitted and valid
if (edit_general_settings_form.save_settings.data
and edit_general_settings_form.validate_on_submit()):
current_user.setting_dark_mode = \
edit_general_settings_form.dark_mode.data
current_user.setting_job_status_mail_notifications = \
edit_general_settings_form.job_status_mail_notifications.data
current_user.setting_job_status_site_notifications = \
edit_general_settings_form.job_status_site_notifications.data
2020-02-19 14:49:52 +01:00
db.session.add(current_user)
db.session.commit()
flash('Your settings have been updated.')
return redirect(url_for('profile.settings'))
# Check if edit_password_form is submitted and valid
if (edit_password_form.save_password.data
and edit_password_form.validate_on_submit()):
current_user.password = edit_password_form.password.data
db.session.add(current_user)
db.session.commit()
flash('Your password has been updated.')
return redirect(url_for('profile.settings'))
# If no form is submitted or valid, fill out fields with current values
edit_email_form.email.data = current_user.email
2020-04-27 10:19:20 +02:00
edit_general_settings_form.dark_mode.data = current_user.setting_dark_mode
edit_general_settings_form.job_status_site_notifications.data = \
current_user.setting_job_status_site_notifications
edit_general_settings_form.job_status_mail_notifications.data = \
current_user.setting_job_status_mail_notifications
2020-02-19 14:49:52 +01:00
return render_template(
'profile/settings.html.j2',
edit_email_form=edit_email_form,
edit_password_form=edit_password_form,
edit_general_settings_form=edit_general_settings_form,
2020-04-21 10:28:04 +02:00
title='Settings')
2020-02-19 14:49:52 +01:00
@profile.route('/delete', methods=['GET', 'POST'])
@login_required
2020-02-19 14:49:52 +01:00
def delete():
2019-10-09 16:10:30 +02:00
"""
View to delete yourslef and all associated data.
2019-10-09 16:10:30 +02:00
"""
tasks.delete_user(current_user.id)
2020-02-25 10:03:31 +01:00
logout_user()
flash('Your account has been deleted!')
return redirect(url_for('main.index'))