[gelöst]Leeres required Feld wird trotzdem gespeichert
Eingetragen von Ati (210)
am 30.07.2012 - 14:42 Uhr in
am 30.07.2012 - 14:42 Uhr in
Hallo zusammen,
ich hänge immer noch an meiner Terminplanung. Der logische Aufbau der Eingaben ist wie folgt.
Lieferdatum eingeben -> PLZ eingeben -> Durch die PLZ wird Stadtteil und Tour ermittelt und automatisch eingegeben -> Lieferuhrzeit eingeben ->
Jetzt wird ermittelt ob es hier schon einen Eintrag gibt -> ist dies der Fall werden die Felder Kunde (required),Strasse und Bemerkund deaktiviert und im Feld Bemerkung steht "Termin belegt". Wenn man doch auf Speichern klickt, wird trotzdem alles gespeichert!!! Wie kann ich das verhindern?
Ati
- Anmelden oder Registrieren um Kommentare zu schreiben
Ich glaub hier brauchen wir
am 30.07.2012 - 14:53 Uhr
Ich glaub hier brauchen wir mehr Infos. Wo findet die Validierung denn statt? Eventuell mal Code pasten
mfg Cyberschorsch
_________
Ups glatt vergessen! Hier
am 30.07.2012 - 15:43 Uhr
Ups glatt vergessen! Hier mal der Code...ich hoffe ich habe alles "experimentelle" rausgenommen.
function ltermverwaltung_my_form($form, &$form_state) {
$result_tour = db_query('Select plz,ort from tbl_plz');
$touren = array();
foreach ($result_tour as $row) {
$touren[$row->plz] = $row->plz ." ". $row->ort;
}
$result_uhr = db_query('Select uhrzeit from uhrzeit');
$uhrzeit = array();
foreach ($result_uhr as $row) {
$uhrzeit[$row->uhrzeit] = $row->uhrzeit;
}
$form['tart'] = array(
'#type' => 'radios',
'#options' => array(
'Fix-Termin' => 'Fix-Termin',
'Bis-Termin' => 'Bis-Termin',
),
'#title' => 'Welche Terminart?',
'#required' => TRUE,
);
$form['datum'] = array (
'#type' => 'textfield',
'#title' => 'Lieferdatum',
'#size' => 10,
'#maxlength' => 10,
'#attributes' => array('class' => array('pickadate')),
);
$form['plz'] = array (
'#type' => 'select',
'#title' => 'Ort ',
'#options' => $touren,
'#required' => TRUE,
'#ajax' => array(
'callback' => 'ltermverwaltung_my_form_callback',
'wrapper' => 'replace_tour_div',
),
);
$form['tour'] = array (
'#type' => 'textfield',
'#title' => 'Tour',
'#disabled' => TRUE,
'#size' => 5,
'#prefix' => '<div id="replace_tour_div">',
'#suffix' => '</div>',
);
$form['ort'] = array (
'#type' => 'textfield',
'#title' => 'Ort',
'#default_value' => '',
'#disabled' => TRUE,
'#size' => 20,
'#prefix' => '<div id="replace_terminort_div">',
'#suffix' => '</div>',
);
if (!empty($form_state['values']['plz'])) {
$result = db_query('Select tour,ort from tbl_plz where plz='.$form_state['values']['plz']);
$tour = array();
foreach ($result as $row) {
$tour['tour'] = $row->tour;
$tour['ort'] = $row->ort;
}
$form['tour']['#value'] = $tour['tour'];
$form['ort']['#value'] = $tour['ort'];
$form['uebersicht']['#type'] = 'item';
}
$form['zeit'] = array (
'#type' => 'select',
'#title' => 'Uhrzeit',
'#options' => $uhrzeit,
'#ajax' => array(
'callback' => 'ltermverwaltung_my_form_callback2',
'wrapper' => 'replace_termindaten_div',
),
);
$form['kunde'] = array (
'#type' => 'textfield',
'#title' => 'Kunde',
'#default_value' => '',
'#disabled' => TRUE,
'#size' => 20,
'#prefix' => '<div id="replace_termindaten_div">',
'#suffix' => '</div>',
'#required' => TRUE,
);
$form['strasse'] = array (
'#type' => 'textfield',
'#title' => 'Strasse',
'#default_value' => '',
'#disabled' => TRUE,
'#size' => 20,
'#prefix' => '<div id="replace_termindaten2_div">',
'#suffix' => '</div>',
);
$form['bem'] = array (
'#type' => 'textfield',
'#title' => 'Bemerkung',
'#default_value' => '',
'#disabled' => TRUE,
'#size' => 25,
'#prefix' => '<div id="replace_termindaten3_div">',
'#suffix' => '</div>',
);
if (! isset ($form_state['values'])) $form_state['values'] = array();
if (! isset ($form_state['values']['datum'])) $form_state['values']['datum'] = '01.01.2012';
if (! isset ($form_state['values']['tour'])) $form_state['values']['tour'] = '000';
$form['uebersicht'] = array(
'#type' => 'item',
'#title' => 'Termine',
'#markup' => views_embed_view('termine', 'embed_1', $form_state['values']['datum'], $form_state['values']['tour']),
'#prefix' => '<div id="replace_terminanzeige_div">',
'#suffix' => '</div>',
);
if (!empty($form_state['values']['zeit'])) {
$result_kd = db_query("Select kunde from termine where tour ='".$form_state['values']['tour']."' and uhrzeit ='".$form_state['values']['zeit']."' and datum ='".$form_state['values']['datum']."'");
if ($result_kd->rowCount() > 0) {
$form['bem']['#value'] = 'Termin belegt!';
$form['uebersicht']['#type'] = 'item';
}else{
$form['kunde']['#disabled'] = FALSE;
$form['strasse']['#disabled'] = FALSE;
$form['bem']['#disabled'] = FALSE;
$form['uebersicht']['#type'] = 'item';
}
}
function ltermverwaltung_my_form_callback($form, &$form_state) {
$commands = array();
$commands[] = ajax_command_replace("#replace_tour_div", render($form['tour']));
$commands[] = ajax_command_replace("#replace_terminort_div", render($form['ort']));
$commands[] = ajax_command_replace("#replace_terminanzeige_div", render($form['uebersicht']));
return array('#type' => 'ajax', '#commands' => $commands);
}
function ltermverwaltung_my_form_callback2($form, &$form_state) {
$commands = array();
$commands[] = ajax_command_replace("#replace_termindaten_div", render($form['kunde']));
$commands[] = ajax_command_replace("#replace_termindaten2_div", render($form['strasse']));
$commands[] = ajax_command_replace("#replace_termindaten3_div", render($form['bem']));
$commands[] = ajax_command_replace("#replace_terminanzeige_div", render($form['uebersicht']));
return array('#type' => 'ajax', '#commands' => $commands);
}
$form['submit'] = array(
'#type' => 'submit',
'#value' => 'Speichern',
);
return $form;
}
function ltermverwaltung_my_form_validation($form, &$form_state) {
$kundenname = $form_state['values']['kunde'];
if (!$kundenname = '') {
form_set_error('Fehler', 'Fehler beim Kundenname!!');
}
}
function ltermverwaltung_my_form_submit($form, &$form_state) {
$tart = $form_state['values']['tart'];
$datum = $form_state['values']['datum'];
$plz = $form_state['values']['plz'];
$ort = $form_state['values']['ort'];
$tour = $form_state['values']['tour'];
$zeit = $form_state['values']['zeit'];
$kunde = $form_state['values']['kunde'];
$strasse = $form_state['values']['strasse'];
$bem = $form_state['values']['bem'];
$erfdat = date("d.m.Y");
$erfzeit = date("H:i");
db_query("Insert into termine (tour, datum, uhrzeit, kunde, plz, ort, strasse, bem, tart)
values ('$tour', '$datum', '$zeit', '$kunde', '$plz', '$ort', '$strasse', '$bem', '$tart')");
drupal_set_message(t('Liefertermin gespeichert'));
}
Ich bin nicht doof....ich denk nur anders
Mein Gott wie blöd bin ich
am 31.07.2012 - 09:42 Uhr
Mein Gott wie blöd bin ich denn...wenn ich anstatt
function ltermverwaltung_my_form_validation
die Richtige function nehme
function ltermverwaltung_my_form_validate
klappts auch mit dem Nachbarn.
*Kopf->Tisch*
Ich bin nicht doof....ich denk nur anders