Add time slot selection

Stop moving elements when error appears under input
make 404, 500, Empty Basket and No Item sections larger
clean up test-api slightly
This commit is contained in:
Michał 2024-05-11 16:26:17 +01:00
parent 58319560eb
commit fd132ebf97
8 changed files with 166 additions and 103 deletions

View file

@ -74,19 +74,10 @@ export async function getItemsByUUID(items: string[]): Promise<Item[]> {
}
export async function getItemByUUID(uuid: string): Promise<Item> {
const data: Item[] = [];
await getItemsByUUID([uuid])
.then((result) => {
if (result.length !== 1) {
throw new Error("Resource could not be found");
}
data.push(...result);
})
.catch((error) => {
throw error;
});
const data = await getItemsByUUID([uuid])
if (data.length !== 1) {
throw new Error("Resource could not be found");
}
return data[0];
}

View file

@ -11,12 +11,12 @@
@import "../styles/vars";
div {
padding: $spacing-large;
height: 100%;
height: 400px;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
}
h1 {
display: flex;

View file

@ -11,12 +11,12 @@
@import "../styles/vars";
div {
padding: $spacing-large;
height: 100%;
height: 400px;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
}
h1 {
display: flex;

View file

@ -1,4 +1,6 @@
<script lang="ts">
import { SealWarning, CaretDown } from "phosphor-svelte";
import { expandOnTyping } from "../lib/utils";
import Calendar from "../components/Calendar.svelte";
@ -9,6 +11,7 @@
let email = "";
let telephone = "";
let date: Date;
let timeSlot = "slot1";
let specialRequests = "";
let nameValid = true;
@ -41,9 +44,11 @@
name="name"
class="form-input"
/>
{#if !nameValid}
<span class="form-notice error">Enter a name</span>
{/if}
<span class="form-notice error">
{#if !nameValid}
Enter a name
{/if}
</span>
</div>
<div class="spacer half" />
@ -59,15 +64,17 @@
name="email"
class="form-input"
/>
{#if !emailValid}
<span class="form-notice error">Email not valid</span>
{/if}
<span class="form-notice error">
{#if !emailValid}
Email not valid
{/if}
</span>
</div>
<div class="spacer half" />
<div class="form-element">
<label class="form-label" for="email">Telephone</label>
<label class="form-label" for="telephone">Telephone</label>
<input
bind:value={telephone}
on:blur={validateTelephone}
@ -77,9 +84,11 @@
name="telephone"
class="form-input"
/>
{#if !telephoneValid}
<span class="form-notice error">Telephone number not valid</span>
{/if}
<span class="form-notice error">
{#if !telephoneValid}
Telephone number not valid
{/if}
</span>
</div>
<div class="spacer" />
@ -91,11 +100,43 @@
on:selected={validateDate}
notBefore={today}
/>
{#if !dateValid}
<span class="form-notice error">Date not valid! Must chose date tomorrow or later</span>
{/if}
<span class="form-notice error">
{#if !dateValid}
Must chose date that's tomorrow or later
{/if}
</span>
</div>
<div class="spacer half" />
<!-- ToDo: Don't give a fake error for the weekend slots, just for testing || !dateValid -->
{#if date && (date.getDay() === 6 || date.getDay() === 0)}
<p class="form-message error"><SealWarning weight="fill" />&nbsp;Time slots not available for this date</p>
{:else}
<div class="form-element">
<label class="form-label" for="time-slot">Time Slot</label>
<div class="select-container">
<select
bind:value={timeSlot}
class="form-input"
id="time-slot"
name="time-slot"
>
<option value="slot0">8am to 10am</option>
<option value="slot1">10am to 12am</option>
<option value="slot2" disabled>12am to 2pm</option>
<option value="slot3">2pm to 4pm</option>
<option value="slot4">4pm to 6pm</option>
<option value="slot5">6pm to 8pm</option>
<option value="slot6">8pm to 10pm</option>
</select>
<div class="select-arrow">
<CaretDown />
</div>
</div>
</div>
{/if}
<div class="spacer" />
<div class="form-element">
@ -136,4 +177,34 @@
resize: none;
overflow: hidden;
}
.select-container{
position: relative;
> select {
width: 200px;
appearance: none;
}
> .select-arrow {
height: 100%;
position: absolute;
top: 0;
right: $spacing-small;
display: flex;
justify-content: center;
align-items: center;
transition: transform 0.1s ease-in-out;
pointer-events: none;
}
&:hover {
> .select-arrow {
transform: translateY(2px);
}
}
}
</style>

View file

@ -105,12 +105,14 @@
#emptyCart {
margin-left: auto;
margin-right: auto;
padding: $spacing-large;
max-width: $sizing-default-width;
height: 400px;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
> h1 {
display: flex;

View file

@ -17,22 +17,13 @@
let emailValid = true;
let messageValid = false;
function validateName() {
nameValid = name.length > 1
}
function validateEmail() {
emailValid = email.length > 1
}
function validateMessage() {
messageValid = message.length > minMessageLength
}
function validateName() { nameValid = name.length > 1 }
function validateEmail() { emailValid = email.length > 1 }
function validateMessage() { messageValid = message.length > minMessageLength }
function onSubmit() {
nameValid = true;
emailValid = true;
messageValid = false;
formMessage = postContactEmail(name, email, message)
.catch((error) => {
@ -66,6 +57,66 @@
<h2>Contact From</h2>
<form on:submit|preventDefault={onSubmit}>
<div class="form-element">
<label class="form-label" for="name">Name</label>
<input
bind:value={name}
on:blur={validateName}
on:input={validateName}
type="text"
id="name"
name="name"
class="form-input"
/>
<span class="form-notice error">
{#if !nameValid}
Enter a name
{/if}
</span>
</div>
<div class="spacer half" />
<div class="form-element">
<label class="form-label" for="email">Email</label>
<input
bind:value={email}
on:blur={validateEmail}
on:input={validateEmail}
type="text"
id="email"
name="email"
class="form-input"
/>
<span class="form-notice error">
{#if !emailValid}
Email not valid
{/if}
</span>
</div>
<div class="spacer half" />
<!-- ToDo: Add dropdown for issue type, such as Technical, Order, Account, or other -->
<div class="form-element">
<label class="form-label" for="message">Message</label>
<textarea
bind:value={message}
on:input={validateMessage}
use:expandOnTyping
rows="1"
cols="50"
id="message"
name="message"
class="form-input"
/>
<span class="form-notice" class:error={!messageValid}>
({message.length}/{minMessageLength})
</span>
</div>
<div class="spacer half" />
{#await formMessage then formMessage}
{#if formMessage}
<p class="form-message success"><SealCheck weight="fill" />&nbsp;{formMessage}</p>
@ -76,62 +127,6 @@
<div class="spacer half" />
{/await}
<div class="form-element">
<label class="form-label" for="name">Name</label>
<input
bind:value={name}
on:blur={validateName}
on:input={validateName}
type="text"
id="name"
name="name"
class="form-input"
/>
{#if !nameValid}
<span class="form-notice error">Enter a name</span>
{/if}
</div>
<div class="spacer half" />
<div class="form-element">
<label class="form-label" for="email">Email</label>
<input
bind:value={email}
on:blur={validateEmail}
on:input={validateEmail}
type="text"
id="email"
name="email"
class="form-input"
/>
{#if !emailValid}
<span class="form-notice error">Email not valid</span>
{/if}
</div>
<div class="spacer half" />
<!-- ToDo: Add dropdown for issue type, such as Technical, Order, Account, or other -->
<div class="form-element">
<label class="form-label" for="message">Message</label>
<textarea
bind:value={message}
on:input={validateMessage}
use:expandOnTyping
rows="1"
cols="50"
id="message"
name="message"
class="form-input"
/>
<span class="form-notice" class:error={!messageValid}>
({message.length}/{minMessageLength})
</span>
</div>
<div class="spacer" />
<button type="submit">Submit&nbsp;&nbsp;<PaperPlaneRight weight="fill" /></button>
</form>

View file

@ -409,12 +409,14 @@
#error {
margin-left: auto;
margin-right: auto;
padding: $spacing-large;
max-width: $sizing-default-width;
height: 400px;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
> h1 {
display: flex;

View file

@ -29,13 +29,15 @@
&:hover {
border: 1px solid rgba($color-dark, 0.4);
}
&:focus {
&:focus-visible {
border: 1px solid rgba($color-primary, 0.9);
outline: 0 solid transparent;
}
}
.form-notice {
height: 16px;
padding: 0 $spacing-xsmall;
display: block;
font-size: $font-size-xsmall;