X-Git-Url: https://git.infodrom.org/?p=misc%2Fhallinta-metro;a=blobdiff_plain;f=artikel.php;h=d7bcc76b8aec0b6f04777bb465e5384368c10b87;hp=12aabbdb4f91b34ec5f8fbaa8b156f8bccab3fb8;hb=44602f0fd181b7789ba4c5289d5dd4bc2526c7b1;hpb=1547f4a3265f3e4a59ca9cbd5a0f891b49e70622 diff --git a/artikel.php b/artikel.php index 12aabbd..d7bcc76 100644 --- a/artikel.php +++ b/artikel.php @@ -1,13 +1,12 @@ add(" div#form_price { padding-left: 10px; padding-right: 10px; font-size: 90%; color: #555; -} -EOC; +}"); $form = '
@@ -28,7 +27,64 @@ $form = '
'; -$javascript = << 0) { + var text = "Diese Artikelnummer ist bereits " + data.count + " mal vorhanden.\\nSoll der Artikel trotzdem gespeichert werden?"; + if (confirm(text)) + form_save(custom_this); + } else { + form_save(custom_this); + } +} + +function custom_save(obj) +{ + custom_this = obj; + var id = document.getElementById('edit_id'); + + if (!id.value.length) + return custom_insert(obj); + + var artnr = document.getElementById('edit_artnr'); + + if (artnr.value == 0) return form_save(custom_this); + + var parms = 'source=' + source.innerHTML + '&callback=artnr'; + parms += '&artnr=' + artnr.value; + parms += '&artikel=' + id.value; + ajax_request('function', parms, custom_save_callback); + + return false; +} + +function custom_insert_callback(data) +{ + if (data.count > 0) { + var text = "Diese Artikelnummer ist bereits " + data.count + " mal vorhanden.\\nSoll der Artikel trotzdem hinzugefügt werden?"; + if (confirm(text)) + form_insert(custom_this); + } else { + form_insert(custom_this); + } +} + +function custom_insert(obj) +{ + custom_this = obj; + var artnr = document.getElementById('edit_artnr'); + + if (artnr.value == 0) return form_insert(custom_this); + + var parms = 'source=' + source.innerHTML + '&callback=artnr'; + parms += '&artnr=' + artnr.value; + ajax_request('function', parms, custom_insert_callback); + + return false; +} + var price_popup = false; function price_popup_open() { @@ -104,12 +160,13 @@ function add_price(obj) return false; } - EOC; -$jscode[] = str_replace('CONTENT_FORM', str_replace(array("\n"), - array("\\\n"), $form), $javascript); - +$jscode = str_replace('CONTENT_FORM', str_replace(array("\n"), + array("\\\n"), $form), $jscode); +$javascript->add($jscode); +$javascript->onLoad("\$('button_save').onclick = function () {return custom_save(this);};"); +$javascript->onLoad("\$('button_insert').onclick = function () {return custom_insert(this);};"); $buttons = << @@ -253,27 +310,32 @@ $mask = array( 'title' => 'Preisverlauf', 'rows' => 5, 'table' => 'metro_artikel_preis', + 'table_edit' => 'metro_artikel_preis', 'where' => 'artikel = {id} ORDER BY datum DESC', 'list' => array( 'id' => array( 'name' => 'ID', + 'edit' => "Writeable:false, EntryType: 'H', Length: 4, isKey: true", 'visible' => false, ), 'datum' => array( 'name' => 'Datum', 'width' => 180, + 'edit' => "EntryType: 'T', isNullable: false, Writeable: true", ), 'steuersatz' => array( 'name' => 'Steuer', 'width' => 60, 'type' => 'number', 'specs' => "decPlaces: 2, ClassName: 'alignrightpad'", + 'edit' => "EntryType: 'T', isNullable: false, Writeable: true", ), 'preis' => array( 'name' => 'netto', 'width' => 60, 'type' => 'number', 'specs' => "decPlaces: 2, ClassName: 'alignrightpad'", + 'edit' => "EntryType: 'T', isNullable: false, Writeable: true", ), 'brutto' => array( 'name' => 'Preis', @@ -291,6 +353,7 @@ $mask = array( ), 'callbacks' => array( 'price' => cb_price, + 'artnr' => cb_artnr, ), ); @@ -317,4 +380,21 @@ function cb_price() return true; } +function cb_artnr() +{ + global $db; + + if (empty($_POST['artnr'])) + return array('error' => 'Nicht ausreichend Daten übermittelt'); + + $sql = sprintf("SELECT count(*) AS count FROM metro_artikel WHERE artnr = %d", $_POST['artnr']); + if (!empty($_POST['artikel'])) + $sql .= sprintf(" AND id <> %d", $_POST['artikel']); + + $sth = $db->query($sql); + $row = $sth->fetch(); + + return array('count' => $row['count']); +} + ?>