<?php
-$style[] = <<<EOC
+JavaScript::instance()->file('lib/rico3/minsrc/ricoLiveGridControls.js');
+JavaScript::instance()->add("Hallinta.closeDialogAfterInsert = false;");
+JavaScript::instance()->add("Hallinta.closeDialogAfterSave = false;");
+JavaScript::instance()->add("Hallinta.fetchItemAfterInsert = true;");
+JavaScript::instance()->add("Hallinta.postFetch = function(data){\$('#edit_artnr').select();};");
+JavaScript::instance()->add("Hallinta.postLoadForm = artikel_init_form;");
+
+Styles::instance()->add("
div#form_price {
padding-left: 10px;
padding-right: 10px;
font-size: 90%;
color: #555;
-}
-EOC;
+}");
$form = '
<div id="form_price">
<label for="form_steuer">Steuersatz</label><br>
<input id="form_steuer" name="steuer" size="10">
<br>
-<label for="form_preis">Preis</label><br>
+<label for="form_preis">Nettopreis</label><br>
<input id="form_preis" name="preis" size="10">
<div class="buttons" style="margin-top: 15px;">
-<button onclick="return add_price(this);">Hinzufügen</button>
+<button class="custom" onclick="return add_price(this);">Hinzufügen</button>
</div>
</form>
</div>
';
-$javascript = <<<EOC
+$jscode = <<<EOC
+var custom_this = false;
+function custom_save_callback(data)
+{
+ if (data.count > 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 || artnr.value == 4711) return form_save(custom_this);
+
+ var parms = '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 || artnr.value == 4711) return form_insert(custom_this);
+
+ var parms = 'callback=artnr';
+ parms += '&artnr=' + artnr.value;
+ ajax_request('function', parms, custom_insert_callback);
+
+ return false;
+}
+
var price_popup = false;
function price_popup_open()
{
var options = { hideOnClick: false, canDragFunc: true };
var content = 'CONTENT_FORM';
- price_popup = new Rico.Popup(options, false, false);
- price_popup.createWindow('<strong>Verbinden</strong>',content,'auto','130px');
+ price_popup = new Rico.Window('Preis hinzufügen', options);
+ price_popup.contentDiv.innerHTML = content;
- price_popup.openPopup(100,300);
+ price_popup.centerPopup();
} else
price_popup.openPopup();
- price_popup.titleDiv.childNodes[0].innerHTML = 'Preis hinzufügen';
-
var form_id = document.getElementById('edit_id');
var artikel = document.getElementById('form_artikel');
artikel.value = form_id.value;
- var datum = document.getElementById('form_datum');
- var preis = document.getElementById('form_preis');
- if (datum.value.length)
- preis.activate();
+ if ($('#form_datum').val().length)
+ $('#form_preis').select();
else
- datum.activate();
+ $('#form_datum').select();
}
function open_popup()
{
- var eid = document.getElementById('edit_id');
- if (!eid || !eid.value.length) return false;
+ if (!$('#edit_id').val().length) return false;
price_popup_open();
return false;
function add_price_callback(data)
{
info('Preis gespeichert');
- grid_update(grid);
+ grid_update(Hallinta.grid);
}
function add_price(obj)
{
- price_popup.closePopup();
-
var datum = document.getElementById('form_datum');
if (!datum.value.length) {
error('Kein Rechnungsdatum angegeben');
return false;
}
- var source = document.getElementById('source');
- if (!source) return false;
-
- var parms = 'source=' + source.innerHTML + '&callback=price&';
- ajax_request('function', parms+Form.serialize(obj.form), add_price_callback);
+ var parms = 'callback=price&' + $(obj.form).serialize();
+ ajax_request('function', parms, add_price_callback);
+ price_popup.closePopup();
preis.value = '';
return false;
}
-EOC;
+function artikel_init_form()
+{
+ $('#button_save').attr('onclick','').prop('onclick',null).off('click');
+ $('#button_save').click(function () {return custom_save(this);});
+ $('#button_insert').attr('onclick','').prop('onclick',null).off('click');
+ $('#button_insert').click(function () {return custom_insert(this);});
+}
-$jscode[] = str_replace('CONTENT_FORM', str_replace(array("\n"),
- array("\\\n"), $form), $javascript);
+EOC;
+$jscode = str_replace('CONTENT_FORM', str_replace(array("\n"),
+ array("\\\n"), $form), $jscode);
+JavaScript::instance()->add($jscode);
$buttons = <<<EOC
<p style="margin-top: 5px; margin-bottom: 4px; text-align: center;">
-<button onclick="return open_popup()">Preis hinzufügen</button>
+<button class="custom" onclick="return open_popup()">Preis hinzufügen</button>
</p>
EOC;
),
'artnr' => array(
'name' => 'ArtNr',
+ 'sqltype' => 'int',
'width' => 60,
+ 'type' => 'number',
+ 'filter' => 't=3',
+ 'specs' => array('decPlaces' => 0, 'thouSep' => ''),
),
'menge' => array(
'name' => 'Menge',
'width' => 60,
- 'specs' => "ClassName: 'alignrightpad', filterUI: 't3'",
+ 'filter' => 't3',
+ 'specs' => array('ClassName' => 'alignrightpad'),
),
'bezeichnung' => array(
'name' => 'Bezeichnung',
'width' => 300,
- 'specs' => "filterUI: 't'",
+ 'filter' => 't15',
),
'netto' => array(
'name' => 'netto',
'width' => 60,
'type' => 'number',
- 'specs' => "decPlaces: 2, ClassName: 'alignrightpad'",
+ 'specs' => array('decPlaces' => 2, 'ClassName' => 'alignrightpad'),
'sql' => '(SELECT preis FROM metro_artikel_preis ' .
'WHERE artikel = metro_artikel.id ORDER BY datum DESC LIMIT 1)',
),
'name' => 'Preis',
'width' => 60,
'type' => 'number',
- 'specs' => "decPlaces: 2, ClassName: 'alignrightpad'",
+ 'specs' => array('decPlaces' => 2, 'ClassName' => 'alignrightpad'),
'sql' => '(SELECT preis * ((100 + steuersatz)/100) FROM metro_artikel_preis ' .
'WHERE artikel = metro_artikel.id ORDER BY datum DESC LIMIT 1)',
),
'hersteller' => array(
'name' => 'Hersteller',
'width' => 100,
- 'specs' => "filterUI: 't'",
+ 'filter' => 't10',
),
'abteilung' => array(
'name' => 'Abteilung',
+ 'sqltype' => 'int',
'width' => 200,
- 'specs' => "filterUI: 's'",
+ 'filter' => 's',
'control' => "new Rico.TableColumn.lookup(".grid_lookup_sql('metro_abteilung','id','name').", 0, '')",
+ 'distinct' => "SELECT DISTINCT abteilung,metro_abteilung.name FROM metro_artikel JOIN metro_abteilung ON abteilung = metro_abteilung.id ORDER BY name",
'visible' => false,
),
'gang' => array(
'name' => 'Gang',
'width' => 50,
- 'specs' => "ClassName: 'aligncenter', filterUI: 's'",
+ 'filter' => 's',
+ 'specs' => array('ClassName' => 'aligncenter'),
'visible' => false,
),
'vpe' => array(
'name' => 'Einheit',
+ 'sqltype' => 'int',
'width' => 70,
- 'specs' => "ClassName: 'aligncenter', filterUI: 's'",
+ 'filter' => 's',
+ 'specs' => array('ClassName' => 'aligncenter'),
'control' => "new Rico.TableColumn.lookup(".grid_lookup_sql('metro_vpe','id','name').", 0, '')",
+ 'distinct' => "SELECT DISTINCT vpe,metro_vpe.name FROM metro_artikel JOIN metro_vpe ON vpe = metro_vpe.id ORDER BY name",
),
),
'edit' => array(
'size' => 21,
'null' => true,
),
+ 'removed' => array(
+ 'name' => 'Artikel nicht mehr im Programm',
+ 'type' => 'boolean',
+ ),
'buttons' => array(
'type' => 'html',
'code' => $buttons,
),
),
'second' => array(
+ 'pricelist' => 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' => array('Writeable' => false, 'EntryType' => 'H', 'Length' => 4, 'isKey' => true),
'visible' => false,
),
'datum' => array(
'name' => 'Datum',
'width' => 180,
+ 'edit' => array('EntryType' => 'T', 'isNullable' => false, 'Writeable' => true),
),
'steuersatz' => array(
'name' => 'Steuer',
'width' => 60,
'type' => 'number',
- 'specs' => "decPlaces: 2, ClassName: 'alignrightpad'",
+ 'specs' => array('decPlaces' => 2, 'ClassName' => 'alignrightpad'),
+ 'edit' => array('EntryType' => 'T', 'isNullable' => false, 'Writeable' => true),
),
'preis' => array(
'name' => 'netto',
'width' => 60,
'type' => 'number',
- 'specs' => "decPlaces: 2, ClassName: 'alignrightpad'",
+ 'specs' => array('decPlaces' => 2, 'ClassName' => 'alignrightpad'),
+ 'edit' => array('EntryType' => 'T', 'isNullable' => false, 'Writeable' => true),
),
'brutto' => array(
'name' => 'Preis',
'width' => 60,
'type' => 'number',
- 'specs' => "decPlaces: 2, ClassName: 'alignrightpad'",
+ 'specs' => array('decPlaces' => 2, 'ClassName' => 'alignrightpad'),
'sql' => 'preis * ((100 + steuersatz)/100)',
),
'empty' => array(
'name' => '',
- 'width' => 10,
+ 'width' => 20,
'sql' => "''",
),
),
),
+ ),
'callbacks' => array(
'price' => cb_price,
+ 'artnr' => cb_artnr,
),
);
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']);
+}
+
?>