diff options
author | Ilion Beyst <ilion.beyst@gmail.com> | 2022-04-15 19:18:27 +0200 |
---|---|---|
committer | Ilion Beyst <ilion.beyst@gmail.com> | 2022-04-15 19:18:27 +0200 |
commit | a41b4c48cb3fe56037aef62c4289435ede7d3e98 (patch) | |
tree | 00d17eab38339d6e45749a9a27dd7a671ffa6384 /web/pw-server/src | |
parent | 0027fef74e7d4ee8af5f7f3cb919e270816ac33f (diff) | |
download | planetwars.dev-a41b4c48cb3fe56037aef62c4289435ede7d3e98.tar.xz planetwars.dev-a41b4c48cb3fe56037aef62c4289435ede7d3e98.zip |
show bot name validations in frontend
Diffstat (limited to 'web/pw-server/src')
-rw-r--r-- | web/pw-server/src/lib/components/SubmitPane.svelte | 25 |
1 files changed, 16 insertions, 9 deletions
diff --git a/web/pw-server/src/lib/components/SubmitPane.svelte b/web/pw-server/src/lib/components/SubmitPane.svelte index 919f578..4d5172e 100644 --- a/web/pw-server/src/lib/components/SubmitPane.svelte +++ b/web/pw-server/src/lib/components/SubmitPane.svelte @@ -1,8 +1,8 @@ <script lang="ts"> -import { get_session_token } from "$lib/auth"; + import { get_session_token } from "$lib/auth"; import { currentUser } from "$lib/stores/current_user"; -import { createEventDispatcher, onMount } from "svelte"; + import { createEventDispatcher, onMount } from "svelte"; import Select from "svelte-select"; export let editSession; @@ -11,7 +11,7 @@ import { createEventDispatcher, onMount } from "svelte"; let selectedOpponent = undefined; let botName: string | undefined = undefined; - let saveErrorText = undefined; + let saveErrors: string[] = []; onMount(async () => { const res = await fetch("/api/bots", { @@ -57,7 +57,7 @@ import { createEventDispatcher, onMount } from "svelte"; method: "POST", headers: { "Content-Type": "application/json", - "Authorization": `Bearer ${get_session_token()}`, + Authorization: `Bearer ${get_session_token()}`, }, body: JSON.stringify({ bot_name: botName, @@ -69,10 +69,13 @@ import { createEventDispatcher, onMount } from "svelte"; if (response.ok) { dispatch("botSaved", responseData); // clear errors - saveErrorText = undefined; + saveErrors = []; } else { - if (responseData["error"] === "BotNameTaken") { - saveErrorText = "Bot name is already taken"; + const error = responseData["error"]; + if (error["type"] === "validation_failed") { + saveErrors = error["validation_errors"]; + } else if (error["type"] === "bot_name_taken") { + saveErrors = ["Bot name is already taken"]; } else { // unexpected error throw responseData; @@ -101,8 +104,12 @@ import { createEventDispatcher, onMount } from "svelte"; {#if $currentUser} <div>Add your bot to the opponents list</div> <input type="text" class="bot-name-input" placeholder="bot name" bind:value={botName} /> - {#if saveErrorText} - <div class="error-text">{saveErrorText}</div> + {#if saveErrors.length > 0} + <ul> + {#each saveErrors as errorText} + <li class="error-text">{errorText}</li> + {/each} + </ul> {/if} <button class="submit-button save-button" on:click={saveBot}>Save</button> {:else} |