display error, and add style

This commit is contained in:
starnakin 2023-11-27 13:55:05 +01:00
parent ea42d10ddf
commit b98371cf70
2 changed files with 37 additions and 9 deletions

View File

@ -0,0 +1,16 @@
#app .form {
background-color: red;
width: 300px;
height: 300px;
display: grid;
grid-template-columns: repeat(1, 1fr);
grid-gap: 10px;
margin-left: auto;
margin-right: auto;
margin-top: 90px;
border: 1px black solid;
}
#app {
background-color: green;
}

View File

@ -7,10 +7,18 @@ async function login()
let password = document.getElementById("password").value; let password = document.getElementById("password").value;
let response = await client.login(username, password); let response = await client.login(username, password);
let errors = await response.json(); let response_data = await response.json();
errors.user.forEach(error => { ["username", "user", "password"].forEach(error_field => {
console.log(error) let error_display = document.getElementById(`error_${error_field}`);
if (error_display != null)
error_display.innerHTML = "";
});
Object.keys(response_data).forEach(error_field => {
let error_display = document.getElementById(`error_${error_field}`);
if (error_display != null)
error_display.innerHTML = response_data[error_field];
}); });
} }
@ -21,18 +29,22 @@ export default class extends AbstractView {
document.body.addEventListener("click", e => { document.body.addEventListener("click", e => {
e.preventDefault(); e.preventDefault();
if (e.target.type == "button") if (e.target.type == "button")
{
login(); login();
}
}); });
} }
async getHtml() { async getHtml() {
return ` return `
<div class=form>
<link rel="stylesheet" href="static/css/accounts/login.css">
<input type="text" id="username" placeholder="username"> <input type="text" id="username" placeholder="username">
<span id="error_username"></span>
<input type="password" id="password" placeholder="password"> <input type="password" id="password" placeholder="password">
<span id="error_password"></span>
<input type="button" value="login"> <input type="button" value="login">
<span id="login_failed"></span> <span id="error_user"></span>
<a href="/register" class="nav__link" data-link>Register</a>
</div>
`; `;
} }
} }