mirror of
https://github.com/danbulant/Portfolio
synced 2026-07-05 11:00:56 +00:00
Merge pull request #147 from EETagent/frontend_form_formatting
(frontend) Form formatting
This commit is contained in:
commit
a8761c9fdf
2 changed files with 60 additions and 13 deletions
|
|
@ -2,7 +2,7 @@
|
||||||
import { onMount } from 'svelte';
|
import { onMount } from 'svelte';
|
||||||
import TextField from './TextField.svelte';
|
import TextField from './TextField.svelte';
|
||||||
|
|
||||||
let helperText: string = 'Zadejte jméno a příjmení. Například Radko Sáblík';
|
export let helperText: string = 'Zadejte jméno a příjmení. Například Radko Sáblík';
|
||||||
export let placeholder: string = '';
|
export let placeholder: string = '';
|
||||||
|
|
||||||
export let valueName: string = '';
|
export let valueName: string = '';
|
||||||
|
|
|
||||||
|
|
@ -47,6 +47,10 @@
|
||||||
birthdate: '',
|
birthdate: '',
|
||||||
sex: '',
|
sex: '',
|
||||||
address: '',
|
address: '',
|
||||||
|
street: '',
|
||||||
|
houseNumber: '',
|
||||||
|
city: '',
|
||||||
|
zip: '',
|
||||||
citizenship: '',
|
citizenship: '',
|
||||||
personalIdNumber: '',
|
personalIdNumber: '',
|
||||||
study: ''
|
study: ''
|
||||||
|
|
@ -83,7 +87,14 @@
|
||||||
.required()
|
.required()
|
||||||
.matches(/^([0-3]?[0-9])\.(0?[1-9]|1[0-2])\.[0-9]{4}$/),
|
.matches(/^([0-3]?[0-9])\.(0?[1-9]|1[0-2])\.[0-9]{4}$/),
|
||||||
sex: yup.string(),
|
sex: yup.string(),
|
||||||
address: yup.string().required(),
|
address: yup.string(),
|
||||||
|
street: yup.string().required(),
|
||||||
|
houseNumber: yup
|
||||||
|
.string()
|
||||||
|
.required()
|
||||||
|
.matches(/^[0-9]+(\/[0-9]+)?$/),
|
||||||
|
city: yup.string().required(),
|
||||||
|
zip: yup.string().required(),
|
||||||
citizenship: yup.string().required(),
|
citizenship: yup.string().required(),
|
||||||
personalIdNumber: yup.string().required(),
|
personalIdNumber: yup.string().required(),
|
||||||
study: yup.string().required()
|
study: yup.string().required()
|
||||||
|
|
@ -225,6 +236,11 @@
|
||||||
values.parents = values.parents.filter(
|
values.parents = values.parents.filter(
|
||||||
(x) => x.name !== '' && x.surname !== '' && x.email !== '' && x.telephone !== ''
|
(x) => x.name !== '' && x.surname !== '' && x.email !== '' && x.telephone !== ''
|
||||||
);
|
);
|
||||||
|
// @ts-ignore
|
||||||
|
let addressArray: Array<string> = [values.candidate.street + ' ' + values.candidate.houseNumber, values.candidate.city, values.candidate.zip];
|
||||||
|
values.candidate.address = addressArray.map((x) => x.replaceAll(',', '').trim()).join(',');
|
||||||
|
// @ts-ignore
|
||||||
|
delete values.candidate.street;delete values.candidate.houseNumber;delete values.candidate.city;delete values.candidate.zip;
|
||||||
|
|
||||||
await apiFillDetails(values);
|
await apiFillDetails(values);
|
||||||
goto('/dashboard');
|
goto('/dashboard');
|
||||||
|
|
@ -264,7 +280,11 @@
|
||||||
if (
|
if (
|
||||||
$typedErrors['candidate']['birthplace'] ||
|
$typedErrors['candidate']['birthplace'] ||
|
||||||
$typedErrors['candidate']['birthdate'] ||
|
$typedErrors['candidate']['birthdate'] ||
|
||||||
$typedErrors['candidate']['address']
|
$typedErrors['candidate']['street'] ||
|
||||||
|
$typedErrors['candidate']['houseNumber'] ||
|
||||||
|
$typedErrors['candidate']['city'] ||
|
||||||
|
$typedErrors['candidate']['zip']
|
||||||
|
// $typedErrors['candidate']['address']
|
||||||
) {
|
) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
@ -318,7 +338,11 @@
|
||||||
form.set({
|
form.set({
|
||||||
gdpr: true,
|
gdpr: true,
|
||||||
candidate: {
|
candidate: {
|
||||||
...details.candidate
|
...details.candidate,
|
||||||
|
street: details.candidate.address.split(',')[0].split(' ')[0],
|
||||||
|
houseNumber: details.candidate.address.split(',')[0].split(' ')[1],
|
||||||
|
city: details.candidate.address.split(',')[1],
|
||||||
|
zip: details.candidate.address.split(',')[2]
|
||||||
},
|
},
|
||||||
parents: [
|
parents: [
|
||||||
{
|
{
|
||||||
|
|
@ -405,18 +429,41 @@
|
||||||
Pro registraci je potřeba vyplnit několik údajů o Vás. Tyto údaje budou použity pro
|
Pro registraci je potřeba vyplnit několik údajů o Vás. Tyto údaje budou použity pro
|
||||||
přijímací řízení. Všechny údaje jsou důležité.
|
přijímací řízení. Všechny údaje jsou důležité.
|
||||||
</p>
|
</p>
|
||||||
<div class="flex w-full flex-col">
|
<div class="flex field">
|
||||||
<span class="field">
|
<span class="w-[66%]">
|
||||||
<TextField
|
<NameField
|
||||||
error={$typedErrors['candidate']['address']}
|
error={$typedErrors['candidate']['street'] || $typedErrors['candidate']['houseNumber']}
|
||||||
on:change={handleChange}
|
on:change={handleChange}
|
||||||
bind:value={$form.candidate.address}
|
bind:valueName={$form.candidate.street}
|
||||||
type="text"
|
bind:valueSurname={$form.candidate.houseNumber}
|
||||||
placeholder="Adresa trvalého bydliště"
|
placeholder="Ulice a č. p."
|
||||||
helperText="Uveďte ulici, č.p., město, PSČ"
|
helperText="Uveďte ulici a číslo popisné (např. Preslova 72)."
|
||||||
|
|
||||||
/>
|
/>
|
||||||
</span>
|
</span>
|
||||||
<span class="field">
|
<span class="ml-2 w-[33%]">
|
||||||
|
<TextField
|
||||||
|
error={$typedErrors['candidate']['zip']}
|
||||||
|
on:change={handleChange}
|
||||||
|
bind:value={$form.candidate.zip}
|
||||||
|
type="number"
|
||||||
|
placeholder="PSČ"
|
||||||
|
helperText="Uveďte poštovní směrovací číslo. (např. 602 00)"
|
||||||
|
/>
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
<div class="flex field">
|
||||||
|
<span>
|
||||||
|
<TextField
|
||||||
|
error={$typedErrors['candidate']['city']}
|
||||||
|
on:change={handleChange}
|
||||||
|
bind:value={$form.candidate.city}
|
||||||
|
type="text"
|
||||||
|
placeholder="Město"
|
||||||
|
helperText="Uveďte město"
|
||||||
|
/>
|
||||||
|
</span>
|
||||||
|
<span class="ml-2">
|
||||||
<TextField
|
<TextField
|
||||||
error={$typedErrors['candidate']['birthplace']}
|
error={$typedErrors['candidate']['birthplace']}
|
||||||
on:change={handleChange}
|
on:change={handleChange}
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue