Working on error handling
This commit is contained in:
@@ -18,12 +18,14 @@ table.schrauben {
|
||||
table-layout: fixed;
|
||||
}
|
||||
|
||||
td.right {
|
||||
text-align: right;
|
||||
td.error {
|
||||
text-align: end;
|
||||
padding-right: 10px;
|
||||
}
|
||||
td.left {
|
||||
text-align: left;
|
||||
padding: 0px 10px;
|
||||
|
||||
p.error {
|
||||
color: red;
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
textarea {
|
||||
@@ -67,11 +69,6 @@ input.error {
|
||||
border-color: inherit;
|
||||
}
|
||||
|
||||
p.error_message {
|
||||
color: red;
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
.grid-container {
|
||||
display: grid;
|
||||
grid-template-columns: auto auto;
|
||||
|
||||
96
index.php
96
index.php
@@ -89,13 +89,14 @@
|
||||
* mengen
|
||||
*
|
||||
*/
|
||||
|
||||
$mail_from = isset($_POST['email']) ? $_POST['email'] : '';
|
||||
$name = isset($_POST['name']) ? $_POST['name'] : '';
|
||||
$strasse = isset($_POST['strasse']) ? $_POST['strasse'] : '';
|
||||
$stadt = isset($_POST['stadt']) ? $_POST['stadt'] : '';
|
||||
$plz = isset($_POST['plz']) ? $_POST['plz'] : '';
|
||||
$telefon = isset($_POST['telefon']) ? $_POST['telefon'] : '';
|
||||
$schrauben = isset($_POST['schrauben']) ? $_POST['schrauben'] : '';
|
||||
$schrauben = isset($_POST['schrauben']) ? $_POST['schrauben'] : [];
|
||||
$notiz = isset($_POST['notiz']) ? $_POST['notiz'] : '';
|
||||
$sparpaket = isset($_POST['sparpaket']) ? $_POST['sparpaket'] : '';
|
||||
$senden = isset($_POST['senden']) ? $_POST['senden'] : '';
|
||||
@@ -103,45 +104,56 @@
|
||||
$mengen = '';
|
||||
$text = '';
|
||||
|
||||
$ok = true;
|
||||
$ok = false;
|
||||
|
||||
if ($senden == "ok") {
|
||||
$form_errors = [];
|
||||
$screw_errors = [];
|
||||
|
||||
if ($senden == "Abschicken") {
|
||||
foreach ($schrauben as $key => $value) {
|
||||
if ($value >= 10) {
|
||||
$mengen .= "$key: $value\n";
|
||||
}
|
||||
elseif ($value > 0 && $value < 10) {
|
||||
$status .= "Es müssen mindestens 10 Schrauben bestellt werden.<br />";
|
||||
$screw_errors[$key] = "Es müssen mindestens 10 Schrauben bestellt werden.";
|
||||
$ok = false;
|
||||
}
|
||||
}
|
||||
|
||||
if (empty($mail_from)) {
|
||||
$status .= "Bitte Mailadresse angeben.<br />";
|
||||
$form_errors[] = "Bitte E-Mail-Adresse angeben";
|
||||
$ok = false;
|
||||
}
|
||||
if (empty($name)) {
|
||||
$status .= "Bitte Name / Vorname angeben.<br />";
|
||||
$form_errors[] = "Bitte Name / Vorname angeben.";
|
||||
$ok = false;
|
||||
}
|
||||
if (empty($strasse)) {
|
||||
$status .= "Bitte Straße und Hausnummer angeben.<br />";
|
||||
$form_errors[] = "Bitte Straße und Hausnummer angeben.";
|
||||
$ok = false;
|
||||
}
|
||||
if (empty($stadt)) {
|
||||
$status .= "Bitte Stadt angeben.<br />";
|
||||
$form_errors[] = "Bitte Stadt angeben.";
|
||||
$ok = false;
|
||||
}
|
||||
if (empty($plz)) {
|
||||
$status .= "Bitte Postleitzahl eingeben.<br />";
|
||||
$form_errors[] = "Bitte Postleitzahl angeben.";
|
||||
$ok = false;
|
||||
}
|
||||
if (empty($telefon)) {
|
||||
$status .= "Bitte eine Telefonnummer angeben.<br />";
|
||||
$form_errors[] = "Bitte Telefonnummer angeben.";
|
||||
$ok = false;
|
||||
}
|
||||
if (empty($mengen)) {
|
||||
$status .= "Es muss mindestens ein Schraubentyp bestellt werden.";
|
||||
$form_errors[] = "Es muss mindestens ein Schraubentyp bestellt werden.";
|
||||
$ok = false;
|
||||
}
|
||||
|
||||
@@ -167,7 +179,7 @@
|
||||
$headers .= "MIME-Version: 1.0\r\n";
|
||||
$headers .= "\r\n";
|
||||
|
||||
$mail_ok = mail($mail_to, $subject, $text, $headers);
|
||||
//$mail_ok = mail($mail_to, $subject, $text, $headers);
|
||||
|
||||
if ($mail_ok) {
|
||||
$status .= "Mail erfolgreich verschickt.<br />";
|
||||
@@ -192,10 +204,16 @@
|
||||
<script type="text/javascript" src="js/form_helper.js" defer></script>
|
||||
</head>
|
||||
|
||||
<pre><?= var_dump($_POST); ?></pre>
|
||||
|
||||
<pre><?= var_dump($form_errors); ?></pre>
|
||||
|
||||
<pre><?= var_dump($schrauben); ?></pre>
|
||||
|
||||
<body>
|
||||
<div class="container">
|
||||
<div>
|
||||
<a href="http://www.rundkopfschlitzschrauben.de"><h1>DIN 86 Metrisch Rundkopf-Schlitzschrauben</h1></a>
|
||||
<a href="/"><h1>DIN 86 Metrisch Rundkopf-Schlitzschrauben</h1></a>
|
||||
|
||||
<table>
|
||||
<tr><td colspan="2" style="font-weight: bold;">Preise:</td></tr>
|
||||
@@ -262,69 +280,81 @@
|
||||
';
|
||||
|
||||
foreach($values as $value) {
|
||||
echo '
|
||||
<tr>
|
||||
<td>'.$value[0].'</td>
|
||||
$key = $value[0]." - ".$value[1];
|
||||
$has_error = array_key_exists($key, $screw_errors);
|
||||
|
||||
echo '<tr>
|
||||
<td>';
|
||||
echo array_key_exists($key, $schrauben) ? 1 : 0;
|
||||
echo '...'. $value[0].'</td>
|
||||
<td>'.$value[1].'</td>
|
||||
<td><input type="text" pattern="[0-9]+" size="4" maxlength="4" name="schrauben['.$value[0].' - '.$value[1].']" value="0" /></td>
|
||||
<td>
|
||||
<input
|
||||
type="text"
|
||||
size="4"
|
||||
maxlength="4"
|
||||
name="schrauben['.$key.']"
|
||||
value="'.(array_key_exists($key, $schrauben) ? $schrauben[$key] : 0).'"
|
||||
class="'.($has_error ? "error" : "").'"
|
||||
/>
|
||||
</td>
|
||||
</tr>
|
||||
';
|
||||
if($has_error) {
|
||||
echo '
|
||||
<tr>
|
||||
<td colspan="3" class="error">
|
||||
<span style="color:red">'. $screw_errors[$key] .'</span>
|
||||
</td>
|
||||
</tr>
|
||||
';
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
echo '
|
||||
</table>
|
||||
';
|
||||
}
|
||||
|
||||
?>
|
||||
<!--
|
||||
<br />
|
||||
<div class="maintenance">
|
||||
Bedauerlicherweise besteht zurzeit ein Problem mit dem Bestell-Formular.<br />
|
||||
<br />
|
||||
Bis dieses Problem behoben ist, versucht öffnet ein Klick auf den "Abschicken"-Button in Ihrem E-Mail-Programm eine neue E-Mail mit Ihren Angaben zu verfassen.<br />
|
||||
Dies funktioniert nicht auf allen Geräten und nur, wenn Ihr Gerät entsprechend konfiguriert.<br />
|
||||
<br />
|
||||
Sollten Sie Probleme haben, nehmen Sie bitte Kontakt per E-Mail auf.<br />
|
||||
<br />
|
||||
Bitte haben Sie Geduld, bis das Bestell-Formular wieder wie gewohnt funktioniert.
|
||||
|
||||
</div>
|
||||
-->
|
||||
<br />
|
||||
<p class="error_message">
|
||||
<?=$status;?>
|
||||
<p class="error">
|
||||
<?php
|
||||
foreach($form_errors as $error) {
|
||||
echo $error ."<br />";
|
||||
}
|
||||
?>
|
||||
</p>
|
||||
<div class="grid-container">
|
||||
<label for="name">Name / Vorname: *</label>
|
||||
<input type="text" name="name" id="name" value="<?=$name;?>" required />
|
||||
<input type="text" name="name" id="name" value="<?=$name;?>" />
|
||||
<div class="form_feedback">Name / Vorname erforderlich.</div>
|
||||
|
||||
<label for="strasse">Straße, Hausnummer: *</label>
|
||||
<input type="text" name="strasse" id="strasse" value="<?=$strasse;?>" required />
|
||||
<input type="text" name="strasse" id="strasse" value="<?=$strasse;?>" />
|
||||
<div class="form_feedback">Straße und Hausnummer erforderlich.</div>
|
||||
|
||||
<label for="plz">PLZ: *</label>
|
||||
<input type="text" name="plz" id="plz" value="<?=$plz;?>" required />
|
||||
<input type="text" name="plz" id="plz" value="<?=$plz;?>" />
|
||||
<div class="form_feedback">Postleitzahl erforderlich.</div>
|
||||
|
||||
<label for="stadt">Stadt: *</label>
|
||||
<input type="text" name="stadt" id="stadt" value="<?=$stadt?>" required />
|
||||
<input type="text" name="stadt" id="stadt" value="<?=$stadt?>" />
|
||||
<div class="form_feedback">Stadt erforderlich.</div>
|
||||
|
||||
<label for="email">Email: *</label>
|
||||
<input type="email" name="email" id="email" value="<?=$mail_from;?>" required />
|
||||
<input type="email" name="email" id="email" value="<?=$mail_from;?>" />
|
||||
<div class="form_feedback">(Korrekte) E-Mail-Adresse erforderlich.</div>
|
||||
|
||||
<label for="telefon">Telefon: *</label>
|
||||
<input type="tel" name="telefon" id="telefon" value="<?=$telefon;?>" required />
|
||||
<input type="tel" name="telefon" id="telefon" value="<?=$telefon;?>" />
|
||||
<div class="form_feedback">Bitte Telefonnummer eingeben.</div>
|
||||
|
||||
</div>
|
||||
<p>Notiz:</p>
|
||||
<textarea name="notiz"><?=$notiz;?></textarea>
|
||||
<p>Mit Sternchen markierte Felder müssen ausgefüllt sein.</p>
|
||||
<button type="submit" name="senden" value="ok">Abschicken</button>
|
||||
<input type="submit" name="senden" value="Abschicken" />
|
||||
</form>
|
||||
|
||||
<div>
|
||||
|
||||
Reference in New Issue
Block a user