* registration UI/UX improvements and better welcome page

This commit is contained in:
Dominika 2021-11-10 22:52:22 +01:00
parent 47955299e2
commit d859dbad0a
2 changed files with 289 additions and 204 deletions

View file

@ -204,24 +204,24 @@ const request = (resource: string, data: any) =>
break; break;
case -2: case -2:
// mail unverified // mail unverified
showElements([".mail-box"]); showElements([".mail-box", ".logout-button"]);
hideElements([ hideElements([
".login-box", ".login-box",
".register-box", ".register-box",
".sms-box", ".sms-box",
".package-list", ".package-list",
".logout-button", ".description",
]); ]);
break; break;
case -3: case -3:
// phone unverified // phone unverified
showElements([".sms-box"]); showElements([".sms-box", ".logout-button"]);
hideElements([ hideElements([
".login-box", ".login-box",
".register-box", ".register-box",
".mail-box", ".mail-box",
".package-list", ".package-list",
".logout-button", ".description",
]); ]);
break; break;
default: default:
@ -347,7 +347,11 @@ const refreshPackages = async (response?: Package[]) => {
const openButton = detailsBox.querySelector( const openButton = detailsBox.querySelector(
".modal-card-foot button.is-primary", ".modal-card-foot button.is-primary",
)! as HTMLButtonElement; )! as HTMLButtonElement;
if (data.status === PackageStatus.READY_TO_PICKUP || data.status === PackageStatus.UNSTACK_FROM_BOX_MACHINE || data.status === PackageStatus.STACK_IN_BOX_MACHINE) { if (
data.status === PackageStatus.READY_TO_PICKUP ||
data.status === PackageStatus.UNSTACK_FROM_BOX_MACHINE ||
data.status === PackageStatus.STACK_IN_BOX_MACHINE
) {
openButton.removeAttribute("disabled"); openButton.removeAttribute("disabled");
openButton.onclick = (e: Event) => { openButton.onclick = (e: Event) => {
e.preventDefault(); e.preventDefault();
@ -505,7 +509,7 @@ window.addEventListener("load", () => {
phone, phone,
}); });
if (res.status == 200) { if (res.status == 200) {
hideElements([".mail-box"]); hideElements([".mail-box", ".description"]);
showElements([".sms-box"]); showElements([".sms-box"]);
if (!phone) { if (!phone) {
showElements([".sms-phone-field"]); showElements([".sms-phone-field"]);
@ -527,7 +531,7 @@ window.addEventListener("load", () => {
phone, phone,
}); });
if (res.status == 200) { if (res.status == 200) {
hideElements([".sms-box"]); hideElements([".sms-box", ".description"]);
phone = null; phone = null;
localStorage.removeItem("phone"); localStorage.removeItem("phone");
await refreshPackages(); await refreshPackages();

View file

@ -1,8 +1,8 @@
<!DOCTYPE html> <!DOCTYPE html>
<html lang="en"> <html lang="en">
<head> <head>
<meta charset="UTF-8"> <meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Otwarty Czapkomat Webowy</title> <title>Otwarty Czapkomat Webowy</title>
<link rel="stylesheet" href="assets/style.css" /> <link rel="stylesheet" href="assets/style.css" />
</head> </head>
@ -11,7 +11,7 @@
<div class="navbar-menu"> <div class="navbar-menu">
<div class="navbar-brand"> <div class="navbar-brand">
<a href="/" class="navbar-item"> <a href="/" class="navbar-item">
<img src="/ocw.png" alt="OCW"> <img src="/ocw.png" alt="OCW" />
</a> </a>
</div> </div>
<div class="navbar-end"> <div class="navbar-end">
@ -28,9 +28,21 @@
<div class="container"> <div class="container">
<div class="description"> <div class="description">
<div class="title is-1">Welcome to OCW!</div> <div class="title is-1">Welcome to OCW!</div>
<p class="paragraph">OCW (Otwarty Czapkomat Mobilny) is an open-source webapp, made for easy opening of Czapkomat compartments. It's free, easy to use, and we collect minimal required data (your username, e-mail and necessary API tokens - not even your phone number*)</p> <p class="paragraph">
<p class="paragraph">Made by <a href="https://selfisekai.rocks">selfisekai</a> and <a href="https://sdomi.pl">sdomi</a>. Please note that this is still Work in Progress.</p> OCW (Otwarty Czapkomat Mobilny) is an open-source webapp, made for
<hr> easy opening of Czapkomat compartments. It's free, easy to use, and we
collect minimal required data (your username, e-mail and necessary API
tokens - not even your phone number*)
<br />
<small>* it's in the JWT, but we don't do anything with that</small>
</p>
<p class="paragraph">
Made by <a href="https://selfisekai.rocks">selfisekai</a> and
<a href="https://sdomi.pl">sdomi</a>. Please note that this is still
Work in Progress.<br />Want to help? Check out
<a href="https://git.sakamoto.pl/laudom/ocw">The Source</a>!
</p>
<hr />
</div> </div>
<div class="columns"> <div class="columns">
<div class="login-box column"> <div class="login-box column">
@ -39,17 +51,29 @@
<div class="field"> <div class="field">
<label for="login" class="label">Username</label> <label for="login" class="label">Username</label>
<div class="control"> <div class="control">
<input type="text" name="login" class="input" placeholder="dominika" required> <input
type="text"
name="login"
class="input"
placeholder="dominika"
required
/>
</div> </div>
</div> </div>
<div class="field"> <div class="field">
<label for="password" class="label">Password</label> <label for="password" class="label">Password</label>
<div class="control"> <div class="control">
<input type="password" name="password" class="input" placeholder="***** ***" required> <input
type="password"
name="password"
class="input"
placeholder="***** ***"
required
/>
</div> </div>
</div> </div>
<div class="control"> <div class="control">
<input type="submit" class="button" value="Login"> <input type="submit" class="button" value="Login" />
</div> </div>
</form> </form>
<div class="password-reset-open-box"> <div class="password-reset-open-box">
@ -61,11 +85,17 @@
<div class="field"> <div class="field">
<label for="login" class="label">Username</label> <label for="login" class="label">Username</label>
<div class="control"> <div class="control">
<input type="login" name="login" class="input" placeholder="filip.grzywok" required> <input
type="login"
name="login"
class="input"
placeholder="filip.grzywok"
required
/>
</div> </div>
</div> </div>
<div class="control"> <div class="control">
<input type="submit" class="button" value="Reset password"> <input type="submit" class="button" value="Reset password" />
</div> </div>
</form> </form>
</div> </div>
@ -75,18 +105,30 @@
<div class="field"> <div class="field">
<label for="hash" class="label">Verification code</label> <label for="hash" class="label">Verification code</label>
<div class="control"> <div class="control">
<input type="text" name="hash" class="input" placeholder="aoeu" required> <input
type="text"
name="hash"
class="input"
placeholder="aoeu"
required
/>
</div> </div>
<p class="help">We've sent you that in an e-mail</p> <p class="help">We've sent you that in an e-mail</p>
</div> </div>
<div class="field"> <div class="field">
<label for="password" class="label">Password</label> <label for="password" class="label">Password</label>
<div class="control"> <div class="control">
<input type="password" name="password" class="input" placeholder="***** ***" required> <input
type="password"
name="password"
class="input"
placeholder="***** ***"
required
/>
</div> </div>
</div> </div>
<div class="control"> <div class="control">
<input type="submit" class="button" value="Set password"> <input type="submit" class="button" value="Set password" />
</div> </div>
</form> </form>
</div> </div>
@ -96,64 +138,98 @@
<div class="field"> <div class="field">
<label for="login" class="label">Username</label> <label for="login" class="label">Username</label>
<div class="control"> <div class="control">
<input type="text" name="login" class="input" placeholder="laura" required> <input
type="text"
name="login"
class="input"
placeholder="laura"
required
/>
</div> </div>
</div> </div>
<div class="field"> <div class="field">
<label for="password" class="label">Password</label> <label for="password" class="label">Password</label>
<div class="control"> <div class="control">
<input type="password" name="password" class="input" placeholder="***** ***" required> <input
type="password"
name="password"
class="input"
placeholder="***** ***"
required
/>
</div> </div>
</div> </div>
<div class="field"> <div class="field">
<label for="email" class="label">E-mail address</label> <label for="email" class="label">E-mail address</label>
<div class="control"> <div class="control">
<input type="email" name="email" class="input" placeholder="@2137.pl" required> <input
type="email"
name="email"
class="input"
placeholder="@2137.pl"
required
/>
</div> </div>
<p class="help">For password recovery. Verified on account registration</p> <p class="help">
For password recovery. Verified on account registration
</p>
</div> </div>
<div class="field"> <div class="field">
<label for="phone" class="label">Phone number</label> <label for="phone" class="label">Phone number</label>
<div class="control"> <div class="control">
<input type="tel" name="phone" class="input" placeholder="222922597" required> <input
type="tel"
name="phone"
class="input"
placeholder="222922597"
required
/>
</div> </div>
<p class="help">The one your packages are assigned to</p> <p class="help">The one your packages are assigned to</p>
</div> </div>
<div class="h-captcha" data-sitekey="06ade6bc-1e3f-42be-85d8-f578c2c9de90"></div> <div
class="h-captcha"
data-sitekey="06ade6bc-1e3f-42be-85d8-f578c2c9de90"
></div>
<div class="control"> <div class="control">
<input type="submit" class="button" value="Register"> <input type="submit" class="button" value="Register" />
</div> </div>
</form> </form>
</div> </div>
<div class="mail-box column"> <div class="mail-box column">
<label class="label is-large">E-mail</label> <label class="label is-large">E-mail verification</label>
<form method="POST" class="mail-form"> <form method="POST" class="mail-form">
<div class="field"> <div class="field">
<label for="code" class="label">E-mail code</label> <label for="code" class="label">E-mail code</label>
<div class="control"> <div class="control">
<input type="number" name="code" class="input"> <input type="number" name="code" class="input" />
</div> </div>
</div> </div>
<input type="submit" class="button" value="Submit"> <input type="submit" class="button" value="Submit" />
</form> </form>
</div> </div>
<div class="sms-box column"> <div class="sms-box column">
<label class="label is-large">SMS</label> <label class="label is-large">SMS verification</label>
<form method="POST" class="sms-form"> <form method="POST" class="sms-form">
<div class="field"> <div class="field">
<label for="code" class="label">SMS code</label> <label for="code" class="label">SMS code</label>
<div class="control"> <div class="control">
<input type="number" name="code" class="input"> <input type="number" name="code" class="input" />
</div> </div>
</div> </div>
<div class="field sms-phone-field"> <div class="field sms-phone-field">
<label for="phone" class="label">Phone number</label> <label for="phone" class="label">Phone number</label>
<div class="control"> <div class="control">
<input type="tel" name="phone" class="input" placeholder="222922597"> <input
type="tel"
name="phone"
class="input"
placeholder="222922597"
/>
</div> </div>
<p class="help">The one your packages are assigned to</p> <p class="help">The one your packages are assigned to</p>
</div> </div>
<input type="submit" class="button" value="Submit"> <input type="submit" class="button" value="Submit" />
</form> </form>
</div> </div>
</div> </div>
@ -165,10 +241,15 @@
<button class="delete" aria-label="close"></button> <button class="delete" aria-label="close"></button>
</header> </header>
<section class="modal-card-body"> <section class="modal-card-body">
<p class="areyousure-text">The parcel locker will open even if you're not close to it, and so, anyone could take your package.</p> <p class="areyousure-text">
The parcel locker will open even if you're not close to it, and
so, anyone could take your package.
</p>
</section> </section>
<footer class="modal-card-foot"> <footer class="modal-card-foot">
<button class="areyousure-button button is-danger">Open locker</button> <button class="areyousure-button button is-danger">
Open locker
</button>
<button class="areyousure-button-deny button">Cancel</button> <button class="areyousure-button-deny button">Cancel</button>
</footer> </footer>
</div> </div>