From b3f82d79148184cdb999f9a64f20fce34c3b8dad Mon Sep 17 00:00:00 2001 From: mtmail Date: Fri, 26 Mar 2021 13:53:17 +0100 Subject: [PATCH] validate countrycodes, lat, lon fields even when hidden (#109) --- src/components/SearchSection.svelte | 9 +++++--- src/components/SearchSectionReverse.svelte | 2 ++ src/components/UrlSubmitForm.svelte | 26 +++++++++++++++++++++- 3 files changed, 33 insertions(+), 4 deletions(-) diff --git a/src/components/SearchSection.svelte b/src/components/SearchSection.svelte index d321eb4..c789804 100644 --- a/src/components/SearchSection.svelte +++ b/src/components/SearchSection.svelte @@ -101,7 +101,8 @@ - + @@ -132,7 +133,8 @@ - + @@ -194,8 +196,9 @@
  • diff --git a/src/components/SearchSectionReverse.svelte b/src/components/SearchSectionReverse.svelte index d996f44..aca422d 100644 --- a/src/components/SearchSectionReverse.svelte +++ b/src/components/SearchSectionReverse.svelte @@ -44,6 +44,7 @@ type="text" class="form-control form-control-sm" placeholder="latitude" + pattern="^-?\d+(\.\d+)?$" bind:value={lat} on:change={maybeSplitLatitude} /> @@ -60,6 +61,7 @@ type="text" class="form-control form-control-sm" placeholder="longitude" + pattern="^-?\d+(\.\d+)?$" bind:value={lon} />
    diff --git a/src/components/UrlSubmitForm.svelte b/src/components/UrlSubmitForm.svelte index 019fa8c..975e79f 100644 --- a/src/components/UrlSubmitForm.svelte +++ b/src/components/UrlSubmitForm.svelte @@ -17,8 +17,32 @@ return params; } + + // https://developer.mozilla.org/en-US/docs/Web/Guide/HTML/HTML5/Constraint_validation + // doesn't support hidden fields, so we check those in an extra step + function validate_field(field) { + if (field.type === 'hidden') { + if (field.pattern && !field.value.match(field.pattern)) return false; + } + return field.checkValidity(); // for hidden field always true + } + + function handle_submit(event) { + let form = event.target; + + let allow_submit = true; + + Array.prototype.slice.call(form.elements).forEach(function (field) { + if (!validate_field(field)) { + alert('Invalid input in ' + field.name); + allow_submit = false; + } + }); + + if (allow_submit) refresh_page(page, serialize_form(form)); + } -
    refresh_page(page, serialize_form(e.target))} class="form-inline" role="search" accept-charset="UTF-8" action=""> +
    -- 2.39.5