mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2025-01-10 22:01:58 +01:00
350 lines
18 KiB
PHP
350 lines
18 KiB
PHP
|
<?php
|
||
|
|
||
|
/*
|
||
|
* Copyright (c) 2022 OpenXE project
|
||
|
*/
|
||
|
|
||
|
use Xentral\Components\Database\Exception\QueryFailureException;
|
||
|
|
||
|
class Konten {
|
||
|
|
||
|
function __construct($app, $intern = false) {
|
||
|
$this->app = $app;
|
||
|
if ($intern)
|
||
|
return;
|
||
|
|
||
|
$this->app->ActionHandlerInit($this);
|
||
|
$this->app->ActionHandler("list", "konten_list");
|
||
|
$this->app->ActionHandler("create", "konten_edit"); // This automatically adds a "New" button
|
||
|
$this->app->ActionHandler("edit", "konten_edit");
|
||
|
$this->app->ActionHandler("delete", "konten_delete");
|
||
|
$this->app->DefaultActionHandler("list");
|
||
|
$this->app->ActionHandlerListen($app);
|
||
|
}
|
||
|
|
||
|
public function Install() {
|
||
|
/* Fill out manually later */
|
||
|
}
|
||
|
|
||
|
static function TableSearch(&$app, $name, $erlaubtevars) {
|
||
|
switch ($name) {
|
||
|
case "konten_list":
|
||
|
$allowed['konten_list'] = array('list');
|
||
|
$heading = array('','','Bezeichnung', 'Kurzbezeichnung', 'Typ', 'Projekt', 'Aktiv','Menü');
|
||
|
$width = array('1%','1%','10%'); // Fill out manually later
|
||
|
|
||
|
// columns that are aligned right (numbers etc)
|
||
|
// $alignright = array(4,5,6,7,8);
|
||
|
|
||
|
$findcols = array('k.id','k.id','k.bezeichnung', 'k.kurzbezeichnung', 'k.type', 'p.abkuerzung', ' k.aktiv','k.id');
|
||
|
$searchsql = array('k.bezeichnung', 'k.kurzbezeichnung', 'k.datevkonto', 'k.blz', 'k.konto', 'k.swift', 'k.iban', 'k.inhaber', 'k.firma','p.abkuerzung');
|
||
|
|
||
|
$defaultorder = 1;
|
||
|
$defaultorderdesc = 0;
|
||
|
|
||
|
$dropnbox = "'<img src=./themes/new/images/details_open.png class=details>' AS `open`, CONCAT('<input type=\"checkbox\" name=\"auswahl[]\" value=\"',k.id,'\" />') AS `auswahl`";
|
||
|
|
||
|
$menu = "<table cellpadding=0 cellspacing=0><tr><td nowrap>" . "<a href=\"index.php?module=konten&action=edit&id=%value%\"><img src=\"./themes/{$app->Conf->WFconf['defaulttheme']}/images/edit.svg\" border=\"0\"></a> <a href=\"#\" onclick=DeleteDialog(\"index.php?module=konten&action=delete&id=%value%\");>" . "<img src=\"themes/{$app->Conf->WFconf['defaulttheme']}/images/delete.svg\" border=\"0\"></a>" . "</td></tr></table>";
|
||
|
|
||
|
$sql = "SELECT SQL_CALC_FOUND_ROWS
|
||
|
k.id,
|
||
|
$dropnbox,
|
||
|
k.bezeichnung,
|
||
|
k.kurzbezeichnung,
|
||
|
k.type,
|
||
|
p.abkuerzung,
|
||
|
k.aktiv,
|
||
|
k.id
|
||
|
FROM
|
||
|
konten k
|
||
|
LEFT JOIN
|
||
|
projekt p
|
||
|
ON
|
||
|
p.id = k.projekt ";
|
||
|
|
||
|
$where = " k.aktiv = 1 ";
|
||
|
|
||
|
// Toggle filters
|
||
|
$app->Tpl->Add('JQUERYREADY', "$('#archiv').click( function() { fnFilterColumn1( 0 ); } );");
|
||
|
|
||
|
for ($r = 1;$r <= 1;$r++) {
|
||
|
$app->Tpl->Add('JAVASCRIPT', '
|
||
|
function fnFilterColumn' . $r . ' ( i )
|
||
|
{
|
||
|
if(oMoreData' . $r . $name . '==1)
|
||
|
oMoreData' . $r . $name . ' = 0;
|
||
|
else
|
||
|
oMoreData' . $r . $name . ' = 1;
|
||
|
|
||
|
$(\'#' . $name . '\').dataTable().fnFilter(
|
||
|
\'\',
|
||
|
i,
|
||
|
0,0
|
||
|
);
|
||
|
}
|
||
|
');
|
||
|
}
|
||
|
|
||
|
|
||
|
$more_data1 = $app->Secure->GetGET("more_data1");
|
||
|
if ($more_data1 == 1) {
|
||
|
$where .= " OR k.aktiv <> 1";
|
||
|
} else {
|
||
|
}
|
||
|
|
||
|
|
||
|
$count = "SELECT count(DISTINCT id) FROM konten k WHERE $where";
|
||
|
// $groupby = "";
|
||
|
|
||
|
break;
|
||
|
}
|
||
|
|
||
|
$erg = false;
|
||
|
|
||
|
foreach ($erlaubtevars as $k => $v) {
|
||
|
if (isset($$v)) {
|
||
|
$erg[$v] = $$v;
|
||
|
}
|
||
|
}
|
||
|
return $erg;
|
||
|
}
|
||
|
|
||
|
function konten_list() {
|
||
|
$this->app->erp->MenuEintrag("index.php?module=konten&action=list", "Übersicht");
|
||
|
$this->app->erp->MenuEintrag("index.php?module=konten&action=create", "Neu anlegen");
|
||
|
|
||
|
$this->app->erp->MenuEintrag("index.php", "Zurück");
|
||
|
|
||
|
$this->app->YUI->TableSearch('TAB1', 'konten_list', "show", "", "", basename(__FILE__), __CLASS__);
|
||
|
$this->app->Tpl->Parse('PAGE', "konten_list.tpl");
|
||
|
}
|
||
|
|
||
|
public function konten_delete() {
|
||
|
$id = (int) $this->app->Secure->GetGET('id');
|
||
|
|
||
|
$this->app->DB->Delete("UPDATE `konten` SET `aktiv` = 0 WHERE `id` = '{$id}'");
|
||
|
$this->app->Tpl->Set('MESSAGE', "<div class=\"info\">Der Eintrag wurde deaktiviert.</div>");
|
||
|
|
||
|
$this->konten_list();
|
||
|
}
|
||
|
|
||
|
/*
|
||
|
* Edit konten item
|
||
|
* If id is empty, create a new one
|
||
|
*/
|
||
|
|
||
|
function konten_edit() {
|
||
|
$id = $this->app->Secure->GetGET('id');
|
||
|
|
||
|
// Check if other users are editing this id
|
||
|
if($this->app->erp->DisableModul('artikel',$id))
|
||
|
{
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
$this->app->Tpl->Set('ID', $id);
|
||
|
|
||
|
$this->app->erp->MenuEintrag("index.php?module=konten&action=edit&id=$id", "Details");
|
||
|
$this->app->erp->MenuEintrag("index.php?module=konten&action=list", "Zurück zur Übersicht");
|
||
|
$id = $this->app->Secure->GetGET('id');
|
||
|
$input = $this->GetInput();
|
||
|
$submit = $this->app->Secure->GetPOST('submit');
|
||
|
|
||
|
if (empty($id)) {
|
||
|
// New item
|
||
|
$id = 'NULL';
|
||
|
}
|
||
|
|
||
|
if ($submit != '')
|
||
|
{
|
||
|
|
||
|
// Write to database
|
||
|
|
||
|
// Add checks here
|
||
|
$input['projekt'] = $this->app->erp->ReplaceProjekt(true,$input['projekt'],true);
|
||
|
|
||
|
$columns = "id, ";
|
||
|
$values = "$id, ";
|
||
|
$update = "";
|
||
|
|
||
|
$fix = "";
|
||
|
|
||
|
foreach ($input as $key => $value) {
|
||
|
$columns = $columns.$fix.$key;
|
||
|
$values = $values.$fix."'".$value."'";
|
||
|
$update = $update.$fix.$key." = '$value'";
|
||
|
|
||
|
$fix = ", ";
|
||
|
}
|
||
|
|
||
|
// echo($columns."<br>");
|
||
|
// echo($values."<br>");
|
||
|
// echo($update."<br>");
|
||
|
|
||
|
$sql = "INSERT INTO konten (".$columns.") VALUES (".$values.") ON DUPLICATE KEY UPDATE ".$update;
|
||
|
|
||
|
// echo($sql);
|
||
|
|
||
|
$this->app->DB->Update($sql);
|
||
|
|
||
|
if ($id == 'NULL') {
|
||
|
$msg = $this->app->erp->base64_url_encode("<div class=\"success\">Das Element wurde erfolgreich angelegt.</div>");
|
||
|
header("Location: index.php?module=konten&action=list&msg=$msg");
|
||
|
} else {
|
||
|
$this->app->Tpl->Set('MESSAGE', "<div class=\"success\">Die Einstellungen wurden erfolgreich übernommen.</div>");
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
// Load values again from database
|
||
|
$dropnbox = "'<img src=./themes/new/images/details_open.png class=details>' AS `open`, CONCAT('<input type=\"checkbox\" name=\"auswahl[]\" value=\"',k.id,'\" />') AS `auswahl`";
|
||
|
$result = $this->app->DB->SelectArr("SELECT SQL_CALC_FOUND_ROWS k.id, $dropnbox, k.bezeichnung, k.kurzbezeichnung, k.type, k.erstezeile, k.datevkonto, k.blz, k.konto, k.swift, k.iban, k.lastschrift, k.hbci, k.hbcikennung, k.inhaber, k.aktiv, k.keineemail, k.firma, k.schreibbar, k.importletztenzeilenignorieren, k.liveimport, k.liveimport_passwort, k.liveimport_online, k.importtrennzeichen, k.codierung, k.importerstezeilenummer, k.importdatenmaskierung, k.importnullbytes, k.glaeubiger, k.geloescht, k.projekt, k.saldo_summieren, k.saldo_betrag, k.saldo_datum, k.importfelddatum, k.importfelddatumformat, k.importfelddatumformatausgabe, k.importfeldbetrag, k.importfeldbetragformat, k.importfeldbuchungstext, k.importfeldbuchungstextformat, k.importfeldwaehrung, k.importfeldwaehrungformat, k.importfeldhabensollkennung, k.importfeldkennunghaben, k.importfeldkennungsoll, k.importextrahabensoll, k.importfeldhaben, k.importfeldsoll, k.cronjobaktiv, k.cronjobverbuchen, k.last_import, k.importperiode_in_hours, k.id FROM konten k"." WHERE id=$id");
|
||
|
|
||
|
foreach ($result[0] as $key => $value) {
|
||
|
$this->app->Tpl->Set(strtoupper($key), $value);
|
||
|
}
|
||
|
|
||
|
/*
|
||
|
* Add displayed items later
|
||
|
*
|
||
|
|
||
|
$this->app->Tpl->Add('KURZUEBERSCHRIFT2', $email);
|
||
|
$this->app->Tpl->Add('EMAIL', $email);
|
||
|
$this->app->Tpl->Add('ANGEZEIGTERNAME', $angezeigtername);
|
||
|
*/
|
||
|
|
||
|
$this->app->YUI->AutoComplete('projekt','projektname',1);
|
||
|
$this->app->Tpl->Set('PROJEKT',$this->app->erp->ReplaceProjekt(false,$result[0]['projekt'],false));
|
||
|
|
||
|
$this->app->Tpl->Set('AKTIV',$result[0]['aktiv']==1?'checked':'');
|
||
|
$this->app->Tpl->Set('KEINEEMAIL',$result[0]['keineemail']==1?'checked':'');
|
||
|
$this->app->Tpl->Set('SCHREIBBAR',$result[0]['schreibbar']==1?'checked':'');
|
||
|
$this->app->Tpl->Set('LASTSCHRIFT',$result[0]['lastschrift']==1?'checked':'');
|
||
|
$this->app->Tpl->Set('SALDO_SUMMIEREN',$result[0]['saldo_summieren']==1?'checked':'');
|
||
|
|
||
|
$this->app->Tpl->Parse('PAGE', "konten_edit.tpl");
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get all paramters from html form and save into $input
|
||
|
*/
|
||
|
public function GetInput(): array {
|
||
|
$input = array();
|
||
|
//$input['EMAIL'] = $this->app->Secure->GetPOST('email');
|
||
|
|
||
|
$input['bezeichnung'] = $this->app->Secure->GetPOST('bezeichnung');
|
||
|
$input['kurzbezeichnung'] = $this->app->Secure->GetPOST('kurzbezeichnung');
|
||
|
$input['type'] = $this->app->Secure->GetPOST('type');
|
||
|
$input['erstezeile'] = $this->app->Secure->GetPOST('erstezeile');
|
||
|
$input['datevkonto'] = $this->app->Secure->GetPOST('datevkonto');
|
||
|
$input['blz'] = $this->app->Secure->GetPOST('blz');
|
||
|
$input['konto'] = $this->app->Secure->GetPOST('konto');
|
||
|
$input['swift'] = $this->app->Secure->GetPOST('swift');
|
||
|
$input['iban'] = $this->app->Secure->GetPOST('iban');
|
||
|
$input['lastschrift'] = $this->app->Secure->GetPOST('lastschrift');
|
||
|
$input['hbci'] = $this->app->Secure->GetPOST('hbci');
|
||
|
$input['hbcikennung'] = $this->app->Secure->GetPOST('hbcikennung');
|
||
|
$input['inhaber'] = $this->app->Secure->GetPOST('inhaber');
|
||
|
$input['aktiv'] = $this->app->Secure->GetPOST('aktiv');
|
||
|
$input['keineemail'] = $this->app->Secure->GetPOST('keineemail');
|
||
|
$input['firma'] = $this->app->Secure->GetPOST('firma');
|
||
|
$input['schreibbar'] = $this->app->Secure->GetPOST('schreibbar');
|
||
|
$input['importletztenzeilenignorieren'] = $this->app->Secure->GetPOST('importletztenzeilenignorieren');
|
||
|
$input['liveimport'] = $this->app->Secure->GetPOST('liveimport');
|
||
|
$input['liveimport_passwort'] = $this->app->Secure->GetPOST('liveimport_passwort');
|
||
|
$input['liveimport_online'] = $this->app->Secure->GetPOST('liveimport_online');
|
||
|
$input['importtrennzeichen'] = $this->app->Secure->GetPOST('importtrennzeichen');
|
||
|
$input['codierung'] = $this->app->Secure->GetPOST('codierung');
|
||
|
$input['importerstezeilenummer'] = $this->app->Secure->GetPOST('importerstezeilenummer');
|
||
|
$input['importdatenmaskierung'] = $this->app->Secure->GetPOST('importdatenmaskierung');
|
||
|
$input['importnullbytes'] = $this->app->Secure->GetPOST('importnullbytes');
|
||
|
$input['glaeubiger'] = $this->app->Secure->GetPOST('glaeubiger');
|
||
|
$input['geloescht'] = $this->app->Secure->GetPOST('geloescht');
|
||
|
$input['projekt'] = $this->app->Secure->GetPOST('projekt');
|
||
|
$input['saldo_summieren'] = $this->app->Secure->GetPOST('saldo_summieren');
|
||
|
$input['saldo_betrag'] = $this->app->Secure->GetPOST('saldo_betrag');
|
||
|
$input['saldo_datum'] = $this->app->Secure->GetPOST('saldo_datum');
|
||
|
$input['importfelddatum'] = $this->app->Secure->GetPOST('importfelddatum');
|
||
|
$input['importfelddatumformat'] = $this->app->Secure->GetPOST('importfelddatumformat');
|
||
|
$input['importfelddatumformatausgabe'] = $this->app->Secure->GetPOST('importfelddatumformatausgabe');
|
||
|
$input['importfeldbetrag'] = $this->app->Secure->GetPOST('importfeldbetrag');
|
||
|
$input['importfeldbetragformat'] = $this->app->Secure->GetPOST('importfeldbetragformat');
|
||
|
$input['importfeldbuchungstext'] = $this->app->Secure->GetPOST('importfeldbuchungstext');
|
||
|
$input['importfeldbuchungstextformat'] = $this->app->Secure->GetPOST('importfeldbuchungstextformat');
|
||
|
$input['importfeldwaehrung'] = $this->app->Secure->GetPOST('importfeldwaehrung');
|
||
|
$input['importfeldwaehrungformat'] = $this->app->Secure->GetPOST('importfeldwaehrungformat');
|
||
|
$input['importfeldhabensollkennung'] = $this->app->Secure->GetPOST('importfeldhabensollkennung');
|
||
|
$input['importfeldkennunghaben'] = $this->app->Secure->GetPOST('importfeldkennunghaben');
|
||
|
$input['importfeldkennungsoll'] = $this->app->Secure->GetPOST('importfeldkennungsoll');
|
||
|
$input['importextrahabensoll'] = $this->app->Secure->GetPOST('importextrahabensoll');
|
||
|
$input['importfeldhaben'] = $this->app->Secure->GetPOST('importfeldhaben');
|
||
|
$input['importfeldsoll'] = $this->app->Secure->GetPOST('importfeldsoll');
|
||
|
$input['cronjobaktiv'] = $this->app->Secure->GetPOST('cronjobaktiv');
|
||
|
$input['cronjobverbuchen'] = $this->app->Secure->GetPOST('cronjobverbuchen');
|
||
|
$input['last_import'] = $this->app->Secure->GetPOST('last_import');
|
||
|
$input['importperiode_in_hours'] = $this->app->Secure->GetPOST('importperiode_in_hours');
|
||
|
return $input;
|
||
|
}
|
||
|
|
||
|
/*
|
||
|
* Set all fields in the page corresponding to $input
|
||
|
*/
|
||
|
function SetInput($input) {
|
||
|
// $this->app->Tpl->Set('EMAIL', $input['email']);
|
||
|
|
||
|
$this->app->Tpl->Set('BEZEICHNUNG', $input['bezeichnung']);
|
||
|
$this->app->Tpl->Set('KURZBEZEICHNUNG', $input['kurzbezeichnung']);
|
||
|
$this->app->Tpl->Set('TYPE', $input['type']);
|
||
|
$this->app->Tpl->Set('ERSTEZEILE', $input['erstezeile']);
|
||
|
$this->app->Tpl->Set('DATEVKONTO', $input['datevkonto']);
|
||
|
$this->app->Tpl->Set('BLZ', $input['blz']);
|
||
|
$this->app->Tpl->Set('KONTO', $input['konto']);
|
||
|
$this->app->Tpl->Set('SWIFT', $input['swift']);
|
||
|
$this->app->Tpl->Set('IBAN', $input['iban']);
|
||
|
$this->app->Tpl->Set('LASTSCHRIFT', $input['lastschrift']);
|
||
|
$this->app->Tpl->Set('HBCI', $input['hbci']);
|
||
|
$this->app->Tpl->Set('HBCIKENNUNG', $input['hbcikennung']);
|
||
|
$this->app->Tpl->Set('INHABER', $input['inhaber']);
|
||
|
$this->app->Tpl->Set('AKTIV', $input['aktiv']);
|
||
|
$this->app->Tpl->Set('KEINEEMAIL', $input['keineemail']);
|
||
|
$this->app->Tpl->Set('FIRMA', $input['firma']);
|
||
|
$this->app->Tpl->Set('SCHREIBBAR', $input['schreibbar']);
|
||
|
$this->app->Tpl->Set('IMPORTLETZTENZEILENIGNORIEREN', $input['importletztenzeilenignorieren']);
|
||
|
$this->app->Tpl->Set('LIVEIMPORT', $input['liveimport']);
|
||
|
$this->app->Tpl->Set('LIVEIMPORT_PASSWORT', $input['liveimport_passwort']);
|
||
|
$this->app->Tpl->Set('LIVEIMPORT_ONLINE', $input['liveimport_online']);
|
||
|
$this->app->Tpl->Set('IMPORTTRENNZEICHEN', $input['importtrennzeichen']);
|
||
|
$this->app->Tpl->Set('CODIERUNG', $input['codierung']);
|
||
|
$this->app->Tpl->Set('IMPORTERSTEZEILENUMMER', $input['importerstezeilenummer']);
|
||
|
$this->app->Tpl->Set('IMPORTDATENMASKIERUNG', $input['importdatenmaskierung']);
|
||
|
$this->app->Tpl->Set('IMPORTNULLBYTES', $input['importnullbytes']);
|
||
|
$this->app->Tpl->Set('GLAEUBIGER', $input['glaeubiger']);
|
||
|
$this->app->Tpl->Set('GELOESCHT', $input['geloescht']);
|
||
|
$this->app->Tpl->Set('PROJEKT', $input['projekt']);
|
||
|
$this->app->Tpl->Set('SALDO_SUMMIEREN', $input['saldo_summieren']);
|
||
|
$this->app->Tpl->Set('SALDO_BETRAG', $input['saldo_betrag']);
|
||
|
$this->app->Tpl->Set('SALDO_DATUM', $input['saldo_datum']);
|
||
|
$this->app->Tpl->Set('IMPORTFELDDATUM', $input['importfelddatum']);
|
||
|
$this->app->Tpl->Set('IMPORTFELDDATUMFORMAT', $input['importfelddatumformat']);
|
||
|
$this->app->Tpl->Set('IMPORTFELDDATUMFORMATAUSGABE', $input['importfelddatumformatausgabe']);
|
||
|
$this->app->Tpl->Set('IMPORTFELDBETRAG', $input['importfeldbetrag']);
|
||
|
$this->app->Tpl->Set('IMPORTFELDBETRAGFORMAT', $input['importfeldbetragformat']);
|
||
|
$this->app->Tpl->Set('IMPORTFELDBUCHUNGSTEXT', $input['importfeldbuchungstext']);
|
||
|
$this->app->Tpl->Set('IMPORTFELDBUCHUNGSTEXTFORMAT', $input['importfeldbuchungstextformat']);
|
||
|
$this->app->Tpl->Set('IMPORTFELDWAEHRUNG', $input['importfeldwaehrung']);
|
||
|
$this->app->Tpl->Set('IMPORTFELDWAEHRUNGFORMAT', $input['importfeldwaehrungformat']);
|
||
|
$this->app->Tpl->Set('IMPORTFELDHABENSOLLKENNUNG', $input['importfeldhabensollkennung']);
|
||
|
$this->app->Tpl->Set('IMPORTFELDKENNUNGHABEN', $input['importfeldkennunghaben']);
|
||
|
$this->app->Tpl->Set('IMPORTFELDKENNUNGSOLL', $input['importfeldkennungsoll']);
|
||
|
$this->app->Tpl->Set('IMPORTEXTRAHABENSOLL', $input['importextrahabensoll']);
|
||
|
$this->app->Tpl->Set('IMPORTFELDHABEN', $input['importfeldhaben']);
|
||
|
$this->app->Tpl->Set('IMPORTFELDSOLL', $input['importfeldsoll']);
|
||
|
$this->app->Tpl->Set('CRONJOBAKTIV', $input['cronjobaktiv']);
|
||
|
$this->app->Tpl->Set('CRONJOBVERBUCHEN', $input['cronjobverbuchen']);
|
||
|
$this->app->Tpl->Set('LAST_IMPORT', $input['last_import']);
|
||
|
$this->app->Tpl->Set('IMPORTPERIODE_IN_HOURS', $input['importperiode_in_hours']);
|
||
|
|
||
|
}
|
||
|
|
||
|
}
|