dynamicness!!!

This commit is contained in:
Pachira 2016-09-19 21:21:11 +02:00
parent a6069caaa4
commit c2d60e216c
5 changed files with 71 additions and 29 deletions

View file

@ -30,7 +30,6 @@ class AccountController extends Controller
}
if (session_check()) {
$redirect = route('settings.account.profile');
$save = [];
$allowed = [
'website',
@ -64,9 +63,9 @@ class AccountController extends Controller
if (!checkdate($month, $day, $year ? $year : 1)
|| $year > date("Y")
|| ($year != 0 && $year < (date("Y") - 100))) {
$message = "Your birthdate was invalid, everything else was saved though!";
return view('global/information', compact('message', 'redirect'));
return $this->json(
['error' => "Your birthdate was invalid, everything else was saved though!"]
);
}
// Combine it into a YYYY-MM-DD format
@ -80,8 +79,7 @@ class AccountController extends Controller
]);
}
redirect($redirect);
return;
return $this->json(['error' => null]);
}
return view('settings/account/profile');
@ -110,20 +108,21 @@ class AccountController extends Controller
$username_allow = $edit_usern && (time() - $last_name_change) > 2592000;
if (isset($_POST['session']) && session_check()) {
$redirect = route('settings.account.details');
$email = $_POST['email'] ?? null;
if ($email) {
// Validate e-mail address
if (!filter_var($email, FILTER_VALIDATE_EMAIL)) {
$message = "The e-mail address you supplied is invalid!";
return view('global/information', compact('redirect', 'message'));
return $this->json(
['error' => "The e-mail address you supplied is invalid!"]
);
}
// Check the MX record of the email
if (!check_mx_record($email)) {
$message = 'No valid MX-Record found on the e-mail address you supplied.';
return view('global/information', compact('redirect', 'message'));
return $this->json(
['error' => 'No valid MX-Record found on the e-mail address you supplied.']
);
}
// Check if the e-mail has already been used
@ -131,8 +130,9 @@ class AccountController extends Controller
->where('email', $email)
->count();
if ($emailCheck) {
$message = 'Someone already used this e-mail!';
return view('global/information', compact('redirect', 'message'));
return $this->json(
['error' => 'Someone already used this e-mail!']
);
}
$user->setMail($email);
@ -145,14 +145,16 @@ class AccountController extends Controller
// Check if the username is too short
if (strlen($username_clean) < config('user.name_min')) {
$message = "This username is too short!";
return view('global/information', compact('redirect', 'message'));
return $this->json(
['error' => 'This username is too short!']
);
}
// Check if the username is too long
if (strlen($username_clean) > config('user.name_max')) {
$message = "This username is too long!";
return view('global/information', compact('redirect', 'message'));
return $this->json(
['error' => 'This username is too long!']
);
}
// Check if this username hasn't been used in the last amount of days set in the config
@ -164,8 +166,9 @@ class AccountController extends Controller
// Check if anything was returned
if ($getOld && $getOld->user_id != $user->id) {
$message = "The username you tried to use is reserved, try again later!";
return view('global/information', compact('redirect', 'message'));
return $this->json(
['error' => 'The username you tried to use is reserved, try again later!']
);
}
// Check if the username is already in use
@ -175,8 +178,9 @@ class AccountController extends Controller
// Check if anything was returned
if ($getInUse) {
$message = "Someone is already using this name!";
return view('global/information', compact('redirect', 'message'));
return $this->json(
['error' => 'Someone is already using this name!']
);
}
$user->setUsername($username);
@ -186,8 +190,9 @@ class AccountController extends Controller
if ($title) {
if (strlen($title) > 64) {
$message = "This title is too long!";
return view('global/information', compact('redirect', 'message'));
return $this->json(
['error' => 'This title is too long!']
);
}
if ($title !== $user->title) {
@ -205,15 +210,15 @@ class AccountController extends Controller
if ($password) {
// Check password entropy
if (password_entropy($password) < config('user.pass_min_entropy')) {
$message = "Your password isn't strong enough!";
return view('global/information', compact('redirect', 'message'));
return $this->json(
['error' => "Your password isn't strong enough!"]
);
}
$user->setPassword($password);
}
redirect($redirect);
return;
return $this->json(['error' => null]);
}
return view('settings/account/details', compact(

View file

@ -46,6 +46,8 @@ namespace Sakura
DOM.Append(text, DOM.Text(this.Text));
DOM.Append(container, text);
var firstBtn: HTMLButtonElement = null;
for (var btnId in buttons) {
var btnType: DialogueButton = buttons[btnId],
btnText: string = DialogueButton[btnType],
@ -58,12 +60,17 @@ namespace Sakura
});
DOM.Append(buttonCont, button);
if (firstBtn === null) {
firstBtn = button;
}
}
DOM.Append(container, buttonCont);
DOM.Append(DOM.ID('dialogues'), container);
this.Reference = container;
firstBtn.focus();
}
public Close(): void

View file

@ -7,7 +7,7 @@
{% endblock %}
{% block settingsContent %}
<form enctype="multipart/form-data" method="post" action="{{ route('settings.account.details') }}">
<form enctype="multipart/form-data" method="post" action="javascript:;" onsubmit="updateSettings(this, '{{ route('settings.account.details') }}');">
{% if edit_email %}
<div class="profile-field">
<div><h2>E-mail address</h2></div>

View file

@ -1,3 +1,33 @@
{% extends 'settings/master.twig' %}
{% set category = 'Account' %}
{% block js %}
<script>
function updateSettings(form, action) {
var forms = {},
dialogue = new Sakura.Dialogue,
updater = new Sakura.AJAX;
dialogue.AddCallback(Sakura.DialogueButton.Ok, function () {
this.Close();
});
for (var a = 0; a < form.elements.length; a++) {
forms[form.elements.item(a).name] = form.elements.item(a).value;
}
updater.SetUrl(action);
updater.Form();
updater.SetSend(forms);
updater.AddCallback(0, function () {
var resp = updater.JSON();
dialogue.Text = resp.error || 'Updated!';
dialogue.Display();
});
updater.Start(Sakura.HTTPMethod.POST);
return false;
}
</script>
{% endblock %}

View file

@ -90,7 +90,7 @@
{% set birthday = user.birthday|split('-') %}
{% block settingsContent %}
<form enctype="multipart/form-data" method="post" action="{{ route('settings.account.profile') }}">
<form enctype="multipart/form-data" method="post" action="javascript:;" onsubmit="updateSettings(this, '{{ route('settings.account.profile') }}');">
{% for id, vars in fields %}
<div class="profile-field {{ id }}">
<div>