diff --git a/phpwf/htmltags/class.form.php b/phpwf/htmltags/class.form.php
index b4795197..221a477c 100644
--- a/phpwf/htmltags/class.form.php
+++ b/phpwf/htmltags/class.form.php
@@ -1,361 +1,361 @@
-action=$action;
- $this->name=$name;
- $this->method=$method;
- $this->id=$id;
- }
-
- function Set($value)
- {
- }
-
- function Get()
- {
-
- }
-
- function GetClose()
- {
- }
-}
-
-
-
-class HTMLTextarea
-{
- var $name;
- var $rows;
- var $value;
- var $cols;
- var $id="";
- var $readonly="";
- var $disabled="";
- var $class;
-
- function __construct($name,$rows,$cols,$defvalue="",$id="",$readonly="",$disabled="",$class="")
- {
- $this->name = $name;
- $this->rows = $rows;
- $this->cols = $cols;
- $this->class = $class;
- $this->value = $defvalue;
- $this->id = $id;
-
- if($id=="")
- $this->id = $name;
-
- $this->readonly = $readonly;
- $this->disabled = $disabled;
- }
-
- function Get()
- {
- // TEMP ACHTUNG HIER IST MIST!!!
- $value = $this->value;
-/*
- if(!defined('WFHTMLTextareabr') || !WFHTMLTextareabr)$value = preg_replace('/
/i', "\n", $value);
- */
- // $value = str_replace("\\r\\n","\n",$value);
-
- $html = "";
- return $html;
- }
-
- function GetClose()
- {
- }
-}
-
-
-/// fuer Datenfelder die mit in die Datenbank o.ae. kommen sollen, aber nicht durch den
-/// user in irgendeiner art und weise gesehen und manipuliert werden koennen
-
-class BlindField
-{
- var $name;
- var $value;
-
- function __construct($name,$value)
- {
- $this->name = $name;
- $this->value = $value;
- }
- function Get(){}
- function GetClose(){}
-}
-
-
-class HTMLInput
-{
- var $name;
- var $type;
- var $value;
- var $dbvalue;
- var $checkvalue;
- var $onchange;
- var $onclick;
- var $defvalue;
- var $size;
- var $maxlength;
- var $tabindex;
- var $id="";
- var $readonly="";
- var $disabled="";
- var $placeholder="";
- var $class;
- var $checked;
-
- function __construct($name,$type,$value,$size="",$maxlength="",$id="",$defvalue="",$checked="",$readonly="",$disabled="",$class="",$onclick="",$tabindex="",$placeholder="")
- {
- $this->name = $name;
- $this->type = $type;
- $this->value = $value;
- $this->size = $size;
- $this->maxlength = $maxlength;
- $this->id = $id;
- $this->readonly = $readonly;
- $this->disabled = $disabled;
- $this->class=$class;
- $this->checked=$checked;
- $this->tabindex=$tabindex;
- $this->placeholder=$placeholder;
- $this->defvalue=$defvalue; // if value is empty use this
- $this->onclick=$onclick;
-
- }
-
- function Get()
- {
- if($this->id=="") $this->id = $this->name;
-
- switch($this->type)
- {
- case "text":
- $html = "type}\" id=\"{$this->id}\" class=\"{$this->class}\" tabindex=\"{$this->tabindex}\"
- name=\"{$this->name}\" value=\"".preg_replace("/\"/",""",$this->value)."\" size=\"{$this->size}\" placeholder=\"{$this->placeholder}\"
- maxlength=\"{$this->maxlength}\" {$this->readonly} {$this->disabled} [COMMONREADONLYINPUT]>";
- break;
- case "password":
- $html = "type}\" id=\"{$this->id}\" class=\"{$this->class}\" tabindex=\"{$this->tabindex}\"
- name=\"{$this->name}\" value=\"{$this->value}\" size=\"{$this->size}\"
- maxlength=\"{$this->maxlength}\" {$this->readonly} {$this->disabled} [COMMONREADONLYINPUT]>";
- break;
- case "checkbox":
- $html = "type}\" id=\"{$this->id}\" class=\"{$this->class}\" tabindex=\"{$this->tabindex}\"
- name=\"{$this->name}\" value=\"{$this->value}\" {$this->checked} onchange=\"{$this->onchange}\" onclick=\"{$this->onclick}\"
- {$this->readonly} {$this->disabled} [COMMONREADONLYINPUT]>";
- break;
- case "radio":
-
- if($this->value==$this->defvalue) $this->checked="checked";
-
- $tmpname = str_replace('_'.$this->defvalue,'',$this->name);
-
- $html = "type}\" id=\"{$this->id}\" class=\"{$this->class}\" tabindex=\"{$this->tabindex}\"
- name=\"{$tmpname}\" value=\"{$this->defvalue}\" {$this->checked} onchange=\"{$this->onchange}\"
- {$this->readonly} {$this->disabled} [COMMONREADONLYINPUT]>";
- break;
- case "submit":
- $html = "type}\" id=\"{$this->id}\" class=\"{$this->class}\"
- name=\"{$this->name}\" value=\"{$this->value}\"
- {$this->readonly} {$this->disabled}>";
- break;
- case "hidden":
- $html = "type}\" id=\"{$this->id}\" class=\"{$this->class}\"
- name=\"{$this->name}\" value=\"{$this->value}\" size=\"{$this->size}\"
- maxlength=\"{$this->maxlength}\" {$this->readonly} {$this->disabled}>";
- break;
- }
-
- return $html;
- }
-
- function GetClose()
- {
- }
-}
-
-
-
-class HTMLCheckbox extends HTMLInput
-{
- function __construct($name,$value,$defvalue,$checkvalue="",$onclick="",$tabindex="")
- {
-
- if($checkvalue!="")
- $this->checkvalue=$checkvalue;
- else
- $this->checkvalue=$value;
-
- $this->name = $name;
- $this->type = "checkbox";
- $this->checkradiovalue = isset($okvalue)?$okvalue:null;
- $this->defvalue = $defvalue;
- $this->value = $value;
- $this->onclick= $onclick;
- $this->tabindex= $tabindex;
- $this->orgvalue = $value;
- }
-
-
- function Get()
- {
- if(($this->value=="" && $this->defvalue==$this->checkvalue)) {
- }
- if($this->checkvalue==$this->value) {
- $this->checked="checked";
- }
- if($this->value=="" && $this->defvalue!=$this->checkvalue)
- $this->checked="";
-
- $this->value = $this->checkvalue;
- //$this->value=1;
- return parent::Get();
- }
-
- function GetClose()
- {
- }
-
-};
-
-class HTMLSelect
-{
- var $name;
- var $size;
- var $id;
- var $readonly;
- var $disabled;
-
- var $options;
- var $onchange;
- var $selected;
- var $tabindex;
-
- var $class;
-
- function __construct($name,$size,$id="",$readonly=false,$disabled=false,$tabindex="")
- {
- $this->name=$name;
- $this->size=$size;
- $this->id=$id;
- $this->readonly=$readonly;
- $this->disabled=$disabled;
- $this->tabindex=$tabindex;
- $this->class="";
-
- if($id=="")
- $this->id = $name;
- }
-
- function AddOption($option,$value)
- {
- $this->options[] = array($option,$value);
- }
-
- function AddOptionsDimensionalArray($values)
- {
- foreach($values as $key=>$value)
- {
- $this->options[] = array($value[wert],$value[schluessel]);
- }
- }
-
-
- function AddOptionsAsocSimpleArray($values)
- {
- foreach($values as $key=>$value)
- $this->options[] = array($value,$key);
- }
-
- function AddOptionsSimpleArray($values)
- {
- if(is_array($values))
- {
- foreach($values as $key=>$value)
- {
- if(!is_numeric($key))
- $this->options[] = array($value,$key);
- else
- $this->options[] = array($value,$value);
- }
- }
- }
-
- function AddOptions($values)
- {
- $number=0;
- if(count($values)>0)
- {
- foreach($values as $key=>$row)
- foreach($row as $value)
- {
- if($number==0){
- $option=$value;
- $number=1;
- }
- else {
- $this->options[] = array($option,$value);
- $number=0;
- $option="";
- }
- }
- }
-
- }
-
- function Get()
- {
- $html = "";
- return $html;
- }
-
- function GetClose()
- {
- }
-
-}
-
+action=$action;
+ $this->name=$name;
+ $this->method=$method;
+ $this->id=$id;
+ }
+
+ function Set($value)
+ {
+ }
+
+ function Get()
+ {
+
+ }
+
+ function GetClose()
+ {
+ }
+}
+
+
+
+class HTMLTextarea
+{
+ var $name;
+ var $rows;
+ var $value;
+ var $cols;
+ var $id="";
+ var $readonly="";
+ var $disabled="";
+ var $class;
+
+ function __construct($name,$rows,$cols,$defvalue="",$id="",$readonly="",$disabled="",$class="")
+ {
+ $this->name = $name;
+ $this->rows = $rows;
+ $this->cols = $cols;
+ $this->class = $class;
+ $this->value = $defvalue;
+ $this->id = $id;
+
+ if($id=="")
+ $this->id = $name;
+
+ $this->readonly = $readonly;
+ $this->disabled = $disabled;
+ }
+
+ function Get()
+ {
+ // TEMP ACHTUNG HIER IST MIST!!!
+ $value = $this->value;
+/*
+ if(!defined('WFHTMLTextareabr') || !WFHTMLTextareabr)$value = preg_replace('/
/i', "\n", $value);
+ */
+ // $value = str_replace("\\r\\n","\n",$value);
+
+ $html = "";
+ return $html;
+ }
+
+ function GetClose()
+ {
+ }
+}
+
+
+/// fuer Datenfelder die mit in die Datenbank o.ae. kommen sollen, aber nicht durch den
+/// user in irgendeiner art und weise gesehen und manipuliert werden koennen
+
+class BlindField
+{
+ var $name;
+ var $value;
+
+ function __construct($name,$value)
+ {
+ $this->name = $name;
+ $this->value = $value;
+ }
+ function Get(){}
+ function GetClose(){}
+}
+
+
+class HTMLInput
+{
+ var $name;
+ var $type;
+ var $value;
+ var $dbvalue;
+ var $checkvalue;
+ var $onchange;
+ var $onclick;
+ var $defvalue;
+ var $size;
+ var $maxlength;
+ var $tabindex;
+ var $id="";
+ var $readonly="";
+ var $disabled="";
+ var $placeholder="";
+ var $class;
+ var $checked;
+
+ function __construct($name,$type,$value,$size="",$maxlength="",$id="",$defvalue="",$checked="",$readonly="",$disabled="",$class="",$onclick="",$tabindex="",$placeholder="")
+ {
+ $this->name = $name;
+ $this->type = $type;
+ $this->value = $value;
+ $this->size = $size;
+ $this->maxlength = $maxlength;
+ $this->id = $id;
+ $this->readonly = $readonly;
+ $this->disabled = $disabled;
+ $this->class=$class;
+ $this->checked=$checked;
+ $this->tabindex=$tabindex;
+ $this->placeholder=$placeholder;
+ $this->defvalue=$defvalue; // if value is empty use this
+ $this->onclick=$onclick;
+
+ }
+
+ function Get()
+ {
+ if($this->id=="") $this->id = $this->name;
+
+ switch($this->type)
+ {
+ case "text":
+ $html = "type}\" id=\"{$this->id}\" class=\"{$this->class}\" tabindex=\"{$this->tabindex}\"
+ name=\"{$this->name}\" value=\"".preg_replace("/\"/",""",$this->value)."\" size=\"{$this->size}\" placeholder=\"{$this->placeholder}\"
+ maxlength=\"{$this->maxlength}\" {$this->readonly} {$this->disabled} [COMMONREADONLYINPUT]>";
+ break;
+ case "password":
+ $html = "type}\" id=\"{$this->id}\" class=\"{$this->class}\" tabindex=\"{$this->tabindex}\"
+ name=\"{$this->name}\" value=\"{$this->value}\" size=\"{$this->size}\"
+ maxlength=\"{$this->maxlength}\" {$this->readonly} {$this->disabled} [COMMONREADONLYINPUT]>";
+ break;
+ case "checkbox":
+ $html = "type}\" id=\"{$this->id}\" class=\"{$this->class}\" tabindex=\"{$this->tabindex}\"
+ name=\"{$this->name}\" value=\"{$this->value}\" {$this->checked} onchange=\"{$this->onchange}\" onclick=\"{$this->onclick}\"
+ {$this->readonly} {$this->disabled} [COMMONREADONLYINPUT]>";
+ break;
+ case "radio":
+
+ if($this->value==$this->defvalue) $this->checked="checked";
+
+ $tmpname = str_replace('_'.$this->defvalue,'',$this->name);
+
+ $html = "type}\" id=\"{$this->id}\" class=\"{$this->class}\" tabindex=\"{$this->tabindex}\"
+ name=\"{$tmpname}\" value=\"{$this->defvalue}\" {$this->checked} onchange=\"{$this->onchange}\"
+ {$this->readonly} {$this->disabled} [COMMONREADONLYINPUT]>";
+ break;
+ case "submit":
+ $html = "type}\" id=\"{$this->id}\" class=\"{$this->class}\"
+ name=\"{$this->name}\" value=\"{$this->value}\"
+ {$this->readonly} {$this->disabled}>";
+ break;
+ case "hidden":
+ $html = "type}\" id=\"{$this->id}\" class=\"{$this->class}\"
+ name=\"{$this->name}\" value=\"{$this->value}\" size=\"{$this->size}\"
+ maxlength=\"{$this->maxlength}\" {$this->readonly} {$this->disabled}>";
+ break;
+ }
+
+ return $html;
+ }
+
+ function GetClose()
+ {
+ }
+}
+
+
+
+class HTMLCheckbox extends HTMLInput
+{
+ function __construct($name,$value,$defvalue,$checkvalue="",$onclick="",$tabindex="")
+ {
+
+ if($checkvalue!="")
+ $this->checkvalue=$checkvalue;
+ else
+ $this->checkvalue=$value;
+
+ $this->name = $name;
+ $this->type = "checkbox";
+ $this->checkradiovalue = isset($okvalue)?$okvalue:null;
+ $this->defvalue = $defvalue;
+ $this->value = $value;
+ $this->onclick= $onclick;
+ $this->tabindex= $tabindex;
+ $this->orgvalue = $value;
+ }
+
+
+ function Get()
+ {
+ if(($this->value=="" && $this->defvalue==$this->checkvalue)) {
+ }
+ if($this->checkvalue==$this->value) {
+ $this->checked="checked";
+ }
+ if($this->value=="" && $this->defvalue!=$this->checkvalue)
+ $this->checked="";
+
+ $this->value = $this->checkvalue;
+ //$this->value=1;
+ return parent::Get();
+ }
+
+ function GetClose()
+ {
+ }
+
+};
+
+class HTMLSelect
+{
+ var $name;
+ var $size;
+ var $id;
+ var $readonly;
+ var $disabled;
+
+ var $options;
+ var $onchange;
+ var $selected;
+ var $tabindex;
+
+ var $class;
+
+ function __construct($name,$size,$id="",$readonly=false,$disabled=false,$tabindex="")
+ {
+ $this->name=$name;
+ $this->size=$size;
+ $this->id=$id;
+ $this->readonly=$readonly;
+ $this->disabled=$disabled;
+ $this->tabindex=$tabindex;
+ $this->class="";
+
+ if($id=="")
+ $this->id = $name;
+ }
+
+ function AddOption($option,$value)
+ {
+ $this->options[] = array($option,$value);
+ }
+
+ function AddOptionsDimensionalArray($values)
+ {
+ foreach($values as $key=>$value)
+ {
+ $this->options[] = array($value[wert],$value[schluessel]);
+ }
+ }
+
+
+ function AddOptionsAsocSimpleArray($values)
+ {
+ foreach($values as $key=>$value)
+ $this->options[] = array($value,$key);
+ }
+
+ function AddOptionsSimpleArray($values)
+ {
+ if(is_array($values))
+ {
+ foreach($values as $key=>$value)
+ {
+ if(!is_numeric($key))
+ $this->options[] = array($value,$key);
+ else
+ $this->options[] = array($value,$value);
+ }
+ }
+ }
+
+ function AddOptions($values)
+ {
+ $number=0;
+ if(count($values)>0)
+ {
+ foreach($values as $key=>$row)
+ foreach($row as $value)
+ {
+ if($number==0){
+ $option=$value;
+ $number=1;
+ }
+ else {
+ $this->options[] = array($option,$value);
+ $number=0;
+ $option="";
+ }
+ }
+ }
+
+ }
+
+ function Get()
+ {
+ $html = "";
+ return $html;
+ }
+
+ function GetClose()
+ {
+ }
+
+}
+
diff --git a/phpwf/plugins/class.yui.php b/phpwf/plugins/class.yui.php
index ecf58f9c..61630ae7 100644
--- a/phpwf/plugins/class.yui.php
+++ b/phpwf/plugins/class.yui.php
@@ -2563,7 +2563,7 @@ class YUI {
$anzeigebrutto = true;
}
}
-
+
$sortcol = ' b.sort ';
$schreibschutz = !empty($docArr)?$docArr['schreibschutz']:$this->app->DB->Select("SELECT schreibschutz FROM $module WHERE id='$id'");
if(!$schreibschutz)$sortcol = " concat('',b.sort) as sort ";
@@ -2853,7 +2853,64 @@ class YUI {
LEFT JOIN artikel a ON a.id=b.artikel LEFT JOIN projekt p ON b.projekt=p.id
WHERE b.$module='$id'";
- } else {
+ }
+ else if ($module == "verbindlichkeit") // OpenXE
+ {
+ $sql = "
+ SELECT
+ $sortcol,
+ IF(
+ b.beschreibung != '',
+ IF(
+ CHAR_LENGTH(b.bezeichnung) > " . $this->app->erp->MaxArtikelbezeichnung() . ",
+ CONCAT(
+ SUBSTR(
+ CONCAT(b.bezeichnung, ' *'),
+ 1,
+ " . $this->app->erp->MaxArtikelbezeichnung() . "
+ ),
+ '...'
+ ),
+ CONCAT(b.bezeichnung, ' *')
+ ),
+ IF(
+ CHAR_LENGTH(b.bezeichnung) > " . $this->app->erp->MaxArtikelbezeichnung() . ",
+ CONCAT(
+ SUBSTR(
+ b.bezeichnung,
+ 1,
+ " . $this->app->erp->MaxArtikelbezeichnung() . "
+ ),
+ '...'
+ ),
+ b.bezeichnung
+ )
+ ) AS Artikel,
+ p.abkuerzung AS projekt,
+ a.nummer,
+ ".$this->app->erp->FormatDate('lieferdatum')." AS lieferdatum,
+ TRIM(b.menge) +0 AS menge,
+ " . $this->FormatPreis($preiscell) . " AS preis,
+ " . $this->FormatPreis($preiscell."*menge") . " AS Betrag,
+ CONCAT(
+ k.sachkonto,
+ ' - ',
+ k.beschriftung
+ ) AS sachkonto,
+ b.id AS id
+ FROM
+ $table b
+ LEFT JOIN artikel a ON
+ a.id = b.artikel
+ LEFT JOIN projekt p ON
+ b.projekt = p.id
+ LEFT JOIN kontorahmen k ON
+ k.id = b.sachkonto
+ WHERE
+ b.$module = '$id'
+ ";
+ }
+ else {
$sql = null;
$this->app->erp->RunHook('yui_position_sql', 3, $table, $id, $sql);
if($sql === null){
@@ -3549,24 +3606,11 @@ class YUI {
$stop_betragbezahlt = "
app->Conf->WFconf['defaulttheme']}/images/vorkassestop.png\" style=\"margin-right:1px\" title=\"Zahlung fehlt\" border=\"0\">";
$gostop_betragbezahlt = "
app->Conf->WFconf['defaulttheme']}/images/vorkassegostop.png\" style=\"margin-right:1px\" title=\"teilweise bezahlt\" border=\"0\">";
- $go_betragbezahlt = "
app->Conf->WFconf['defaulttheme']}/images/vorkassego.png\" style=\"margin-right:1px\" title=\"komplett bezahlt\" border=\"0\">";
+ $go_betragbezahlt = "
app->Conf->WFconf['defaulttheme']}/images/vorkassego.png\" style=\"margin-right:1px\" title=\"bezahlt\" border=\"0\">";
return "CONCAT('
',
if(v.freigabe,'$go_ware','$stop_ware'),
if(v.rechnungsfreigabe,'$go_summe','$stop_summe'),
- IF( v.betragbezahlt = 0 OR (v.betrag > 0 AND v.betragbezahlt < 0),'$stop_betragbezahlt',
- IF(v.betrag > 0 AND (v.betragbezahlt + v.skonto_erhalten) >= v.betrag, '$go_betragbezahlt',
- IF(v.betrag - v.betragbezahlt <= v.betrag-((v.betrag/100.0)*v.skonto),
- '$gostop_betragbezahlt',
- '$go_betragbezahlt'
- )
- )
- ),
- if((
- (SELECT COUNT(ka.id)
- FROM kontoauszuege_zahlungsausgang ka WHERE ka.parameter=v.id AND ka.objekt='verbindlichkeit') +
- (SELECT COUNT(ke.id) FROM kontoauszuege_zahlungseingang ke WHERE ke.parameter=v.id AND ke.objekt='verbindlichkeit')) > 0,
- '$go_zahlung','$stop_zahlung'
- ),
+ if(v.bezahlt,'$go_betragbezahlt','$stop_betragbezahlt'),
' |
')";
}
@@ -14862,8 +14906,6 @@ source: "index.php?module=ajax&action=filter&filtername=' . $filter . $extendurl
$table->headings[4] = 'Abr. bei Kd';
$table->headings[5] = 'sonst. MwSt'; // kann man auch umbenennen in Keine
-
-
$table->headings[6] = 'MwSt';
$table->headings[7] = 'Kommentar';
$table->headings[8] = 'Bezahlt';
diff --git a/tools/module_creator/module_creator_php_template.txt b/tools/module_creator/module_creator_php_template.txt
index 693723a0..51402e00 100644
--- a/tools/module_creator/module_creator_php_template.txt
+++ b/tools/module_creator/module_creator_php_template.txt
@@ -41,6 +41,10 @@ class PLACEHOLDER_MODULECLASSNAME {
$defaultorder = 1;
$defaultorderdesc = 0;
+ $aligncenter = array();
+ $alignright = array();
+ $numbercols = array();
+ $sumcol = array();
$dropnbox = "PLACEHOLDER_DROPNBOX";
@@ -159,11 +163,17 @@ class PLACEHOLDER_MODULECLASSNAME {
// Load values again from database
$dropnbox = "PLACEHOLDER_DROPNBOX";
- $result = $this->app->DB->SelectArr("PLACEHOLDER_SQL_LIST"." WHERE id=$id");
+ $result = $this->app->DB->SelectArr("PLACEHOLDER_SQL_LIST"." WHERE id=$id");
foreach ($result[0] as $key => $value) {
$this->app->Tpl->Set(strtoupper($key), $value);
}
+
+ if (!empty($result)) {
+ $PLACEHOLDER_MODULENAME_from_db = $result[0];
+ } else {
+ return;
+ }
/*
* Add displayed items later
@@ -177,7 +187,6 @@ class PLACEHOLDER_MODULECLASSNAME {
*/
-// $this->SetInput($input);
$this->app->Tpl->Parse('PAGE', "PLACEHOLDER_MODULENAME_edit.tpl");
}
diff --git a/upgrade/data/db_schema.json b/upgrade/data/db_schema.json
index a5b9520e..c4635b64 100644
--- a/upgrade/data/db_schema.json
+++ b/upgrade/data/db_schema.json
@@ -52382,6 +52382,17 @@
"Privileges": "select,insert,update,references",
"Comment": ""
},
+ {
+ "Field": "nummer",
+ "Type": "int(11)",
+ "Collation": null,
+ "Null": "NO",
+ "Key": "PRI",
+ "Default": null,
+ "Extra": "",
+ "Privileges": "select,insert,update,references",
+ "Comment": ""
+ },
{
"Field": "bezeichnung",
"Type": "varchar(255)",
@@ -52393,6 +52404,17 @@
"Privileges": "select,insert,update,references",
"Comment": ""
},
+ {
+ "Field": "beschreibung",
+ "Type": "varchar(255)",
+ "Collation": "utf8mb3_general_ci",
+ "Null": "NO",
+ "Key": "",
+ "Default": null,
+ "Extra": "",
+ "Privileges": "select,insert,update,references",
+ "Comment": ""
+ },
{
"Field": "projekt",
"Type": "varchar(255)",
@@ -108981,6 +109003,17 @@
"Privileges": "select,insert,update,references",
"Comment": ""
},
+ {
+ "Field": "datum",
+ "Type": "date",
+ "Collation": null,
+ "Null": "YES",
+ "Key": "",
+ "Default": null,
+ "Extra": "",
+ "Privileges": "select,insert,update,references",
+ "Comment": ""
+ },
{
"Field": "status_beleg",
"Type": "varchar(64)",
@@ -110707,6 +110740,39 @@
"Extra": "",
"Privileges": "select,insert,update,references",
"Comment": ""
+ },
+ {
+ "Field": "steuersatz_normal",
+ "Type": "decimal(5,2)",
+ "Collation": null,
+ "Null": "NO",
+ "Key": "",
+ "Default": "0",
+ "Extra": "",
+ "Privileges": "select,insert,update,references",
+ "Comment": ""
+ },
+ {
+ "Field": "steuersatz_ermaessigt",
+ "Type": "decimal(5,2)",
+ "Collation": null,
+ "Null": "NO",
+ "Key": "",
+ "Default": "0",
+ "Extra": "",
+ "Privileges": "select,insert,update,references",
+ "Comment": ""
+ },
+ {
+ "Field": "ust_befreit",
+ "Type": "int(1)",
+ "Collation": null,
+ "Null": "NO",
+ "Key": "",
+ "Default": "0",
+ "Extra": "",
+ "Privileges": "select,insert,update,references",
+ "Comment": ""
}
],
"keys": [
@@ -111302,6 +111368,17 @@
"Extra": "",
"Privileges": "select,insert,update,references",
"Comment": ""
+ },
+ {
+ "Field": "sachkonto",
+ "Type": "int(11)",
+ "Collation": null,
+ "Null": "NO",
+ "Key": "",
+ "Default": "0",
+ "Extra": "",
+ "Privileges": "select,insert,update,references",
+ "Comment": ""
}
],
"keys": [
diff --git a/www/lib/class.erpapi.php b/www/lib/class.erpapi.php
index 87e71fc0..8bb01e1b 100644
--- a/www/lib/class.erpapi.php
+++ b/www/lib/class.erpapi.php
@@ -2676,7 +2676,7 @@ public function NavigationHooks(&$menu)
// @refactor in Dateien Modul
function AnzahlDateien($objekt,$id)
{
- return $this->app->DB->Select("SELECT COUNT(id) FROM datei_stichwoerter WHERE objekt='$objekt' AND parameter='$id'");
+ return $this->app->DB->Select("SELECT COUNT(ds.id) FROM datei_stichwoerter ds INNER JOIN datei d ON d.id = ds.datei WHERE ds.objekt='$objekt' AND ds.parameter='$id' AND d.geloescht <> 1");
}
@@ -35375,6 +35375,7 @@ function Firmendaten($field,$projekt="")
{
case 'bestellung':
case 'anfrage':
+ case 'verbindlichkeit':
$aufwendung = true;
break;
}
@@ -37298,7 +37299,7 @@ function Firmendaten($field,$projekt="")
function GetDateiSubjektObjekt($subjekt,$objekt,$parameter)
{
- $dateien = $this->app->DB->SelectArr("SELECT datei FROM datei_stichwoerter WHERE subjekt LIKE '$subjekt' AND objekt LIKE '$objekt' AND parameter='$parameter' GROUP by datei");
+ $dateien = $this->app->DB->SelectArr("SELECT datei FROM datei_stichwoerter INNER JOIN datei d on d.id = datei WHERE subjekt LIKE '$subjekt' AND objekt LIKE '$objekt' AND parameter='$parameter' AND d.geloescht <> 1 GROUP by datei");
if(empty($dateien)) {
return null;
}
diff --git a/www/objectapi/mysql/_gen/object.gen.verbindlichkeit_position.php b/www/objectapi/mysql/_gen/object.gen.verbindlichkeit_position.php
index 9c82d0a6..c88928ef 100644
--- a/www/objectapi/mysql/_gen/object.gen.verbindlichkeit_position.php
+++ b/www/objectapi/mysql/_gen/object.gen.verbindlichkeit_position.php
@@ -1,238 +1,244 @@
-app = $app;
- }
-
- public function Select($id)
- {
- if(is_numeric($id))
- $result = $this->app->DB->SelectArr("SELECT * FROM `verbindlichkeit_position` WHERE (`id` = '$id')");
- else
- return -1;
-
-$result = $result[0];
-
- $this->id=$result['id'];
- $this->verbindlichkeit=$result['verbindlichkeit'];
- $this->sort=$result['sort'];
- $this->artikel=$result['artikel'];
- $this->projekt=$result['projekt'];
- $this->bestellung=$result['bestellung'];
- $this->nummer=$result['nummer'];
- $this->bestellnummer=$result['bestellnummer'];
- $this->waehrung=$result['waehrung'];
- $this->einheit=$result['einheit'];
- $this->vpe=$result['vpe'];
- $this->bezeichnung=$result['bezeichnung'];
- $this->umsatzsteuer=$result['umsatzsteuer'];
- $this->status=$result['status'];
- $this->beschreibung=$result['beschreibung'];
- $this->lieferdatum=$result['lieferdatum'];
- $this->steuersatz=$result['steuersatz'];
- $this->steuertext=$result['steuertext'];
- $this->preis=$result['preis'];
- $this->menge=$result['menge'];
- $this->kostenstelle=$result['kostenstelle'];
- }
-
- public function Create()
- {
- $sql = "INSERT INTO `verbindlichkeit_position` (`id`,`verbindlichkeit`,`sort`,`artikel`,`projekt`,`bestellung`,`nummer`,`bestellnummer`,`waehrung`,`einheit`,`vpe`,`bezeichnung`,`umsatzsteuer`,`status`,`beschreibung`,`lieferdatum`,`steuersatz`,`steuertext`,`preis`,`menge`,`kostenstelle`)
- VALUES(NULL,'{$this->verbindlichkeit}','{$this->sort}','{$this->artikel}','{$this->projekt}','{$this->bestellung}','{$this->nummer}','{$this->bestellnummer}','{$this->waehrung}','{$this->einheit}','{$this->vpe}','{$this->bezeichnung}','{$this->umsatzsteuer}','{$this->status}','{$this->beschreibung}','{$this->lieferdatum}','{$this->steuersatz}','{$this->steuertext}','{$this->preis}','{$this->menge}','{$this->kostenstelle}')";
-
- $this->app->DB->Insert($sql);
- $this->id = $this->app->DB->GetInsertID();
- }
-
- public function Update()
- {
- if(!is_numeric($this->id)) {
- return -1;
- }
-
- $sql = "UPDATE `verbindlichkeit_position` SET
- `verbindlichkeit`='{$this->verbindlichkeit}',
- `sort`='{$this->sort}',
- `artikel`='{$this->artikel}',
- `projekt`='{$this->projekt}',
- `bestellung`='{$this->bestellung}',
- `nummer`='{$this->nummer}',
- `bestellnummer`='{$this->bestellnummer}',
- `waehrung`='{$this->waehrung}',
- `einheit`='{$this->einheit}',
- `vpe`='{$this->vpe}',
- `bezeichnung`='{$this->bezeichnung}',
- `umsatzsteuer`='{$this->umsatzsteuer}',
- `status`='{$this->status}',
- `beschreibung`='{$this->beschreibung}',
- `lieferdatum`='{$this->lieferdatum}',
- `steuersatz`='{$this->steuersatz}',
- `steuertext`='{$this->steuertext}',
- `preis`='{$this->preis}',
- `menge`='{$this->menge}',
- `kostenstelle`='{$this->kostenstelle}'
- WHERE (`id`='{$this->id}')";
-
- $this->app->DB->Update($sql);
- }
-
- public function Delete($id='')
- {
- if(is_numeric($id))
- {
- $this->id=$id;
- }
- else
- return -1;
-
- $sql = "DELETE FROM `verbindlichkeit_position` WHERE (`id`='{$this->id}')";
- $this->app->DB->Delete($sql);
-
- $this->id='';
- $this->verbindlichkeit='';
- $this->sort='';
- $this->artikel='';
- $this->projekt='';
- $this->bestellung='';
- $this->nummer='';
- $this->bestellnummer='';
- $this->waehrung='';
- $this->einheit='';
- $this->vpe='';
- $this->bezeichnung='';
- $this->umsatzsteuer='';
- $this->status='';
- $this->beschreibung='';
- $this->lieferdatum='';
- $this->steuersatz='';
- $this->steuertext='';
- $this->preis='';
- $this->menge='';
- $this->kostenstelle='';
- }
-
- public function Copy()
- {
- $this->id = '';
- $this->Create();
- }
-
- /**
- Mit dieser Funktion kann man einen Datensatz suchen
- dafuer muss man die Attribute setzen nach denen gesucht werden soll
- dann kriegt man als ergebnis den ersten Datensatz der auf die Suche uebereinstimmt
- zurueck. Mit Next() kann man sich alle weiteren Ergebnisse abholen
- **/
-
- public function Find()
- {
- //TODO Suche mit den werten machen
- }
-
- public function FindNext()
- {
- //TODO Suche mit den alten werten fortsetzen machen
- }
-
- /** Funktionen um durch die Tabelle iterieren zu koennen */
-
- public function Next()
- {
- //TODO: SQL Statement passt nach meiner Meinung nach noch nicht immer
- }
-
- public function First()
- {
- //TODO: SQL Statement passt nach meiner Meinung nach noch nicht immer
- }
-
- /** dank dieser funktionen kann man die tatsaechlichen werte einfach
- ueberladen (in einem Objekt das mit seiner klasse ueber dieser steht)**/
-
- public function SetId($value) { $this->id=$value; }
- public function GetId() { return $this->id; }
- public function SetVerbindlichkeit($value) { $this->verbindlichkeit=$value; }
- public function GetVerbindlichkeit() { return $this->verbindlichkeit; }
- public function SetSort($value) { $this->sort=$value; }
- public function GetSort() { return $this->sort; }
- public function SetArtikel($value) { $this->artikel=$value; }
- public function GetArtikel() { return $this->artikel; }
- public function SetProjekt($value) { $this->projekt=$value; }
- public function GetProjekt() { return $this->projekt; }
- public function SetBestellung($value) { $this->bestellung=$value; }
- public function GetBestellung() { return $this->bestellung; }
- public function SetNummer($value) { $this->nummer=$value; }
- public function GetNummer() { return $this->nummer; }
- public function SetBestellnummer($value) { $this->bestellnummer=$value; }
- public function GetBestellnummer() { return $this->bestellnummer; }
- public function SetWaehrung($value) { $this->waehrung=$value; }
- public function GetWaehrung() { return $this->waehrung; }
- public function SetEinheit($value) { $this->einheit=$value; }
- public function GetEinheit() { return $this->einheit; }
- public function SetVpe($value) { $this->vpe=$value; }
- public function GetVpe() { return $this->vpe; }
- public function SetBezeichnung($value) { $this->bezeichnung=$value; }
- public function GetBezeichnung() { return $this->bezeichnung; }
- public function SetUmsatzsteuer($value) { $this->umsatzsteuer=$value; }
- public function GetUmsatzsteuer() { return $this->umsatzsteuer; }
- public function SetStatus($value) { $this->status=$value; }
- public function GetStatus() { return $this->status; }
- public function SetBeschreibung($value) { $this->beschreibung=$value; }
- public function GetBeschreibung() { return $this->beschreibung; }
- public function SetLieferdatum($value) { $this->lieferdatum=$value; }
- public function GetLieferdatum() { return $this->lieferdatum; }
- public function SetSteuersatz($value) { $this->steuersatz=$value; }
- public function GetSteuersatz() { return $this->steuersatz; }
- public function SetSteuertext($value) { $this->steuertext=$value; }
- public function GetSteuertext() { return $this->steuertext; }
- public function SetPreis($value) { $this->preis=$value; }
- public function GetPreis() { return $this->preis; }
- public function SetMenge($value) { $this->menge=$value; }
- public function GetMenge() { return $this->menge; }
- public function SetKostenstelle($value) { $this->kostenstelle=$value; }
- public function GetKostenstelle() { return $this->kostenstelle; }
-
-}
+app = $app;
+ }
+
+ public function Select($id)
+ {
+ if(is_numeric($id))
+ $result = $this->app->DB->SelectArr("SELECT * FROM `verbindlichkeit_position` WHERE (`id` = '$id')");
+ else
+ return -1;
+
+$result = $result[0];
+
+ $this->id=$result['id'];
+ $this->verbindlichkeit=$result['verbindlichkeit'];
+ $this->sort=$result['sort'];
+ $this->artikel=$result['artikel'];
+ $this->projekt=$result['projekt'];
+ $this->bestellung=$result['bestellung'];
+ $this->nummer=$result['nummer'];
+ $this->bestellnummer=$result['bestellnummer'];
+ $this->waehrung=$result['waehrung'];
+ $this->einheit=$result['einheit'];
+ $this->vpe=$result['vpe'];
+ $this->bezeichnung=$result['bezeichnung'];
+ $this->umsatzsteuer=$result['umsatzsteuer'];
+ $this->status=$result['status'];
+ $this->beschreibung=$result['beschreibung'];
+ $this->lieferdatum=$result['lieferdatum'];
+ $this->steuersatz=$result['steuersatz'];
+ $this->steuertext=$result['steuertext'];
+ $this->preis=$result['preis'];
+ $this->menge=$result['menge'];
+ $this->kostenstelle=$result['kostenstelle'];
+ $this->sachkonto=$result['sachkonto'];
+ }
+
+ public function Create()
+ {
+ $sql = "INSERT INTO `verbindlichkeit_position` (`id`,`verbindlichkeit`,`sort`,`artikel`,`projekt`,`bestellung`,`nummer`,`bestellnummer`,`waehrung`,`einheit`,`vpe`,`bezeichnung`,`umsatzsteuer`,`status`,`beschreibung`,`lieferdatum`,`steuersatz`,`steuertext`,`preis`,`menge`,`kostenstelle`)
+ VALUES(NULL,'{$this->verbindlichkeit}','{$this->sort}','{$this->artikel}','{$this->projekt}','{$this->bestellung}','{$this->nummer}','{$this->bestellnummer}','{$this->waehrung}','{$this->einheit}','{$this->vpe}','{$this->bezeichnung}','{$this->umsatzsteuer}','{$this->status}','{$this->beschreibung}','{$this->lieferdatum}','{$this->steuersatz}','{$this->steuertext}','{$this->preis}','{$this->menge}','{$this->kostenstelle}','{$this->sachkonto}')";
+
+ $this->app->DB->Insert($sql);
+ $this->id = $this->app->DB->GetInsertID();
+ }
+
+ public function Update()
+ {
+ if(!is_numeric($this->id)) {
+ return -1;
+ }
+
+ $sql = "UPDATE `verbindlichkeit_position` SET
+ `verbindlichkeit`='{$this->verbindlichkeit}',
+ `sort`='{$this->sort}',
+ `artikel`='{$this->artikel}',
+ `projekt`='{$this->projekt}',
+ `bestellung`='{$this->bestellung}',
+ `nummer`='{$this->nummer}',
+ `bestellnummer`='{$this->bestellnummer}',
+ `waehrung`='{$this->waehrung}',
+ `einheit`='{$this->einheit}',
+ `vpe`='{$this->vpe}',
+ `bezeichnung`='{$this->bezeichnung}',
+ `umsatzsteuer`='{$this->umsatzsteuer}',
+ `status`='{$this->status}',
+ `beschreibung`='{$this->beschreibung}',
+ `lieferdatum`='{$this->lieferdatum}',
+ `steuersatz`='{$this->steuersatz}',
+ `steuertext`='{$this->steuertext}',
+ `preis`='{$this->preis}',
+ `menge`='{$this->menge}',
+ `kostenstelle`='{$this->kostenstelle}',
+ `sachkonto`='{$this->sachkonto}'
+ WHERE (`id`='{$this->id}')";
+
+ $this->app->DB->Update($sql);
+ }
+
+ public function Delete($id='')
+ {
+ if(is_numeric($id))
+ {
+ $this->id=$id;
+ }
+ else
+ return -1;
+
+ $sql = "DELETE FROM `verbindlichkeit_position` WHERE (`id`='{$this->id}')";
+ $this->app->DB->Delete($sql);
+
+ $this->id='';
+ $this->verbindlichkeit='';
+ $this->sort='';
+ $this->artikel='';
+ $this->projekt='';
+ $this->bestellung='';
+ $this->nummer='';
+ $this->bestellnummer='';
+ $this->waehrung='';
+ $this->einheit='';
+ $this->vpe='';
+ $this->bezeichnung='';
+ $this->umsatzsteuer='';
+ $this->status='';
+ $this->beschreibung='';
+ $this->lieferdatum='';
+ $this->steuersatz='';
+ $this->steuertext='';
+ $this->preis='';
+ $this->menge='';
+ $this->kostenstelle='';
+ $this->sachkonto='';
+ }
+
+ public function Copy()
+ {
+ $this->id = '';
+ $this->Create();
+ }
+
+ /**
+ Mit dieser Funktion kann man einen Datensatz suchen
+ dafuer muss man die Attribute setzen nach denen gesucht werden soll
+ dann kriegt man als ergebnis den ersten Datensatz der auf die Suche uebereinstimmt
+ zurueck. Mit Next() kann man sich alle weiteren Ergebnisse abholen
+ **/
+
+ public function Find()
+ {
+ //TODO Suche mit den werten machen
+ }
+
+ public function FindNext()
+ {
+ //TODO Suche mit den alten werten fortsetzen machen
+ }
+
+ /** Funktionen um durch die Tabelle iterieren zu koennen */
+
+ public function Next()
+ {
+ //TODO: SQL Statement passt nach meiner Meinung nach noch nicht immer
+ }
+
+ public function First()
+ {
+ //TODO: SQL Statement passt nach meiner Meinung nach noch nicht immer
+ }
+
+ /** dank dieser funktionen kann man die tatsaechlichen werte einfach
+ ueberladen (in einem Objekt das mit seiner klasse ueber dieser steht)**/
+
+ public function SetId($value) { $this->id=$value; }
+ public function GetId() { return $this->id; }
+ public function SetVerbindlichkeit($value) { $this->verbindlichkeit=$value; }
+ public function GetVerbindlichkeit() { return $this->verbindlichkeit; }
+ public function SetSort($value) { $this->sort=$value; }
+ public function GetSort() { return $this->sort; }
+ public function SetArtikel($value) { $this->artikel=$value; }
+ public function GetArtikel() { return $this->artikel; }
+ public function SetProjekt($value) { $this->projekt=$value; }
+ public function GetProjekt() { return $this->projekt; }
+ public function SetBestellung($value) { $this->bestellung=$value; }
+ public function GetBestellung() { return $this->bestellung; }
+ public function SetNummer($value) { $this->nummer=$value; }
+ public function GetNummer() { return $this->nummer; }
+ public function SetBestellnummer($value) { $this->bestellnummer=$value; }
+ public function GetBestellnummer() { return $this->bestellnummer; }
+ public function SetWaehrung($value) { $this->waehrung=$value; }
+ public function GetWaehrung() { return $this->waehrung; }
+ public function SetEinheit($value) { $this->einheit=$value; }
+ public function GetEinheit() { return $this->einheit; }
+ public function SetVpe($value) { $this->vpe=$value; }
+ public function GetVpe() { return $this->vpe; }
+ public function SetBezeichnung($value) { $this->bezeichnung=$value; }
+ public function GetBezeichnung() { return $this->bezeichnung; }
+ public function SetUmsatzsteuer($value) { $this->umsatzsteuer=$value; }
+ public function GetUmsatzsteuer() { return $this->umsatzsteuer; }
+ public function SetStatus($value) { $this->status=$value; }
+ public function GetStatus() { return $this->status; }
+ public function SetBeschreibung($value) { $this->beschreibung=$value; }
+ public function GetBeschreibung() { return $this->beschreibung; }
+ public function SetLieferdatum($value) { $this->lieferdatum=$value; }
+ public function GetLieferdatum() { return $this->lieferdatum; }
+ public function SetSteuersatz($value) { $this->steuersatz=$value; }
+ public function GetSteuersatz() { return $this->steuersatz; }
+ public function SetSteuertext($value) { $this->steuertext=$value; }
+ public function GetSteuertext() { return $this->steuertext; }
+ public function SetPreis($value) { $this->preis=$value; }
+ public function GetPreis() { return $this->preis; }
+ public function SetMenge($value) { $this->menge=$value; }
+ public function GetMenge() { return $this->menge; }
+ public function SetKostenstelle($value) { $this->kostenstelle=$value; }
+ public function GetKostenstelle() { return $this->kostenstelle; }
+ public function SetSachkonto($value) { $this->sachkonto=$value; }
+ public function GetSachkonto() { return $this->sachkonto; }
+
+}
diff --git a/www/pages/_gen/adresse.php b/www/pages/_gen/adresse.php
index 1dbb44b8..bf3fe3f9 100644
--- a/www/pages/_gen/adresse.php
+++ b/www/pages/_gen/adresse.php
@@ -1,59 +1,59 @@
-app=&$app;
- $this->app->ActionHandlerInit($this);
-
- $this->app->ActionHandler("create","AdresseCreate");
- $this->app->ActionHandler("edit","AdresseEdit");
- $this->app->ActionHandler("copy","AdresseCopy");
- $this->app->ActionHandler("list","AdresseList");
- $this->app->ActionHandler("delete","AdresseDelete");
-
- $this->app->Tpl->Set("HEADING","Adresse"); //$this->app->ActionHandlerListen($app);
- }
-
- function AdresseCreate(){
- $this->app->Tpl->Set("HEADING","Adresse (Anlegen)");
- $this->app->PageBuilder->CreateGen("adresse_create.tpl");
- }
-
- function AdresseEdit(){
- $this->app->Tpl->Set("HEADING","Adresse (Bearbeiten)");
- $this->app->PageBuilder->CreateGen("adresse_edit.tpl");
- }
-
- function AdresseCopy(){
- $this->app->Tpl->Set("HEADING","Adresse (Kopieren)");
- $this->app->PageBuilder->CreateGen("adresse_copy.tpl");
- }
-
- function AdresseDelete(){
- $this->app->Tpl->Set("HEADING","Adresse (Löschen)");
- $this->app->PageBuilder->CreateGen("adresse_delete.tpl");
- }
-
- function AdresseList(){
- $this->app->Tpl->Set("HEADING","Adresse (Übersicht)");
- $this->app->PageBuilder->CreateGen("adresse_list.tpl");
- }
-
-}
-?>
\ No newline at end of file
+app=&$app;
+ $this->app->ActionHandlerInit($this);
+
+ $this->app->ActionHandler("create","AdresseCreate");
+ $this->app->ActionHandler("edit","AdresseEdit");
+ $this->app->ActionHandler("copy","AdresseCopy");
+ $this->app->ActionHandler("list","AdresseList");
+ $this->app->ActionHandler("delete","AdresseDelete");
+
+ $this->app->Tpl->Set("HEADING","Adresse"); //$this->app->ActionHandlerListen($app);
+ }
+
+ function AdresseCreate(){
+ $this->app->Tpl->Set("HEADING","Adresse (Anlegen)");
+ $this->app->PageBuilder->CreateGen("adresse_create.tpl");
+ }
+
+ function AdresseEdit(){
+ $this->app->Tpl->Set("HEADING","Adresse (Bearbeiten)");
+ $this->app->PageBuilder->CreateGen("adresse_edit.tpl");
+ }
+
+ function AdresseCopy(){
+ $this->app->Tpl->Set("HEADING","Adresse (Kopieren)");
+ $this->app->PageBuilder->CreateGen("adresse_copy.tpl");
+ }
+
+ function AdresseDelete(){
+ $this->app->Tpl->Set("HEADING","Adresse (Löschen)");
+ $this->app->PageBuilder->CreateGen("adresse_delete.tpl");
+ }
+
+ function AdresseList(){
+ $this->app->Tpl->Set("HEADING","Adresse (Übersicht)");
+ $this->app->PageBuilder->CreateGen("adresse_list.tpl");
+ }
+
+}
+?>
diff --git a/www/pages/ajax.php b/www/pages/ajax.php
index 7c9ae905..2a8cb88b 100644
--- a/www/pages/ajax.php
+++ b/www/pages/ajax.php
@@ -674,6 +674,7 @@ class Ajax {
echo $str;
exit;
}
+
if(!empty($datei['parameter'])) {
if($cmd === 'projekt') {
if(!$this->app->erp->UserProjektRecht($datei['parameter'])) {
@@ -707,8 +708,7 @@ class Ajax {
}
}
}
- //Rechte prüfen
-
+ //Rechte prüfen
$userdata = isset($this->app->Conf->WFuserdata)
?$this->app->Conf->WFuserdata
:(str_replace('index.php', '', $_SERVER['SCRIPT_FILENAME']).'../userdata');
@@ -746,34 +746,17 @@ class Ajax {
exit;
break;
case 'application/pdf':
- $str = file_get_contents(dirname(__DIR__) . '/themes/new/images/pdf.svg');
+ $str = file_get_contents(dirname(__DIR__) . '/themes/new/images/pdf.png');
header('Content-type: image/png');
echo $str;
exit;
break;
- default:
- $str = file_get_contents(dirname(__DIR__) . '/themes/new/images/pdf.svg');
- if(substr(strtolower($datei['dateiname']),-4) === '.gif'){
- header('Content-type: image/gif');
- echo $str;
- exit;
- }
- if(substr(strtolower($datei['dateiname']),-4) === '.png'){
- header('Content-type: image/png');
- echo $str;
- exit;
- }
- if(substr(strtolower($datei['dateiname']),-4) === '.jpg'
- || substr(strtolower($datei['dateiname']),-4) === 'jpeg'){
- header('Content-type: image/jpg');
- echo $str;
- exit;
- }
+ default:
break;
}
}
}
-
+
if(file_exists($cachefolder.'/'.$datei['id'].'_100_100')) {
$type = is_file($path.'/'.$datei['id'])? false : mime_content_type($path.'/'.$datei['id']);
if($type === false) {
@@ -2379,7 +2362,14 @@ select a.kundennummer, (SELECT name FROM adresse a2 WHERE a2.kundennummer = a.ku
for($i = 0; $i < $carr; $i++)
$newarr[] = $arr[$i]['name'];
break;
+ case "sachkonto_aufwendungen":
+ $arr = $this->app->DB->SelectArr("SELECT CONCAT(sachkonto,' ',beschriftung) as name FROM kontorahmen
+ WHERE art = 1 AND (beschriftung LIKE '%$term%' OR sachkonto LIKE '%$term%' OR sachkonto LIKE '%$term2%' OR sachkonto LIKE '%$term3%' OR beschriftung LIKE '%$term2%' OR beschriftung LIKE '%$term3%') AND ausblenden!=1 $andprojekt ORDER by sachkonto");
+ $carr = !empty($arr)?count($arr):0;
+ for($i = 0; $i < $carr; $i++)
+ $newarr[] = $arr[$i]['name'];
+ break;
case "lieferbedingungen":
$arr = $this->app->DB->SelectArr("SELECT CONCAT(lieferbedingungen) as name FROM lieferbedingungen
WHERE (lieferbedingungen LIKE '%$term%' OR lieferbedingungen LIKE '%$term2%' OR lieferbedingungen LIKE '%$term3%') ORDER by lieferbedingungen");
@@ -2458,6 +2448,7 @@ select a.kundennummer, (SELECT name FROM adresse a2 WHERE a2.kundennummer = a.ku
$subwhere = $this->AjaxFilterWhere($termorig,$felder);
$arr = $this->app->DB->SelectArr("SELECT CONCAT(nummer,' ',beschreibung) as name FROM kostenstellen WHERE $subwhere ORDER by nummer");
+
$carr = !empty($arr)?count($arr):0;
for($i = 0; $i < $carr; $i++)
$newarr[] = $arr[$i]['name'];
diff --git a/www/pages/content/verbindlichkeit_edit.tpl b/www/pages/content/verbindlichkeit_edit.tpl
new file mode 100644
index 00000000..8e908c75
--- /dev/null
+++ b/www/pages/content/verbindlichkeit_edit.tpl
@@ -0,0 +1,208 @@
+
+
+
+
+
+ [MINIDETAIL]
+
+
+
diff --git a/www/pages/content/verbindlichkeit_list.tpl b/www/pages/content/verbindlichkeit_list.tpl
new file mode 100644
index 00000000..838328d1
--- /dev/null
+++ b/www/pages/content/verbindlichkeit_list.tpl
@@ -0,0 +1,72 @@
+
+
+
diff --git a/www/pages/content/verbindlichkeit_minidetail.tpl b/www/pages/content/verbindlichkeit_minidetail.tpl
index 9d0aa1cb..723fd770 100644
--- a/www/pages/content/verbindlichkeit_minidetail.tpl
+++ b/www/pages/content/verbindlichkeit_minidetail.tpl
@@ -1,176 +1,76 @@
-
[FORMHANDLEREVENT]
[MESSAGE]
-
-
-
-
-
- |
-
-
-
-
-
-
-
-
-
-
-[TABELLEBESTELLUNGEN]
-
-
- |
-
-
-
-
-
-Summe Verbindlichkeit | Summe Kontierung |
-
- [SUMMEVERBINDLICHKEIT] |
- [SUMMEKONTIERUNG] |
-
-
-
-[MESSAGEVORKONTIERUNG]
-[VORKONTIERUNG]
-[ZAHLUNGEN]
-
-
- {|Protokoll|}
-
- [PROTOKOLL]
+
+ Lieferant: |
+ [ADRESSEAUTOSTART][ADRESSE][MSGADRESSE][ADRESSEAUTOEND] |
+
+
+ Rechnungs-Nr.: |
+ [RECHNUNG][MSGRECHNUNG] |
+
+
+ Rechnungsdatum: |
+ [RECHNUNGSDATUM][MSGRECHNUNGSDATUM] |
+
+
+ |
+ Zahlbar bis: |
+ [ZAHLBARBIS][MSGZAHLBARBIS][DATUM_ZAHLBARBIS] |
+
+ Betrag/Total (Brutto): |
+ [BETRAG][MSGBETRAG] [WAEHRUNG][MSGWAEHRUNG] |
+
+ Skonto in %: |
+ [SKONTO][MSGSKONTO] |
+
+
+ Skonto bis: |
+ [SKONTOBIS][MSGSKONTOBIS][DATUM_SKONTOBIS] |
+
+
+ Projekt: |
+ [PROJEKT][MSGKOSTENSTELLE] |
+ |
+
+
+ Kostenstelle: |
+ [KOSTENSTELLE][MSGKOSTENSTELLE] |
+ |
+
+
+ Interne Bemerkung: |
+ [INTERNEBEMERKUNG] |
+
+
+
+
+
Artikel
+
+ [ARTIKEL]
+
+
+
+
Buchungen
+
+ [ZAHLUNGEN]
+
+
+
+
Protokoll
+
+ [PROTOKOLL]
+
+
-
-
-
-
-
-
-
-
-
diff --git a/www/pages/verbindlichkeit.php b/www/pages/verbindlichkeit.php
new file mode 100644
index 00000000..a1483ecf
--- /dev/null
+++ b/www/pages/verbindlichkeit.php
@@ -0,0 +1,857 @@
+app = $app;
+ if ($intern)
+ return;
+
+ $this->app->ActionHandlerInit($this);
+ $this->app->ActionHandler("list", "verbindlichkeit_list");
+ $this->app->ActionHandler("create", "verbindlichkeit_edit"); // This automatically adds a "New" button
+ $this->app->ActionHandler("edit", "verbindlichkeit_edit");
+ $this->app->ActionHandler("positionen", "verbindlichkeit_positionen");
+ $this->app->ActionHandler("delete", "verbindlichkeit_delete");
+ $this->app->ActionHandler("dateien", "verbindlichkeit_dateien");
+ $this->app->ActionHandler("inlinepdf", "verbindlichkeit_inlinepdf");
+ $this->app->ActionHandler("positioneneditpopup", "verbindlichkeit_positioneneditpopup");
+ $this->app->ActionHandler("freigabe", "verbindlichkeit_freigabe");
+ $this->app->ActionHandler("schreibschutz", "verbindlichkeit_schreibschutz");
+ $this->app->ActionHandler("freigabeeinkauf", "verbindlichkeit_freigabeeinkauf");
+ $this->app->ActionHandler("freigabebuchhaltung", "verbindlichkeit_freigabebuchhaltung");
+ $this->app->ActionHandler("freigabebezahlt", "verbindlichkeit_freigabebezahlt");
+ $this->app->ActionHandler("ruecksetzeneinkauf", "verbindlichkeit_ruecksetzeneinkauf");
+ $this->app->ActionHandler("ruecksetzenbuchhaltung", "verbindlichkeit_ruecksetzenbuchhaltung");
+ $this->app->ActionHandler("ruecksetzenbezahlt", "verbindlichkeit_ruecksetzenbezahlt");
+ $this->app->ActionHandler("minidetail", "verbindlichkeit_minidetail");
+
+ $this->app->DefaultActionHandler("list");
+ $this->app->ActionHandlerListen($app);
+ }
+
+ public function Install() {
+ /* Fill out manually later */
+ }
+
+ function TableSearch(&$app, $name, $erlaubtevars) {
+ switch ($name) {
+ case "verbindlichkeit_list":
+ $allowed['verbindlichkeit_list'] = array('list');
+ $heading = array('','','Belegnr','Adresse', 'Lieferant', 'RE-Nr', 'RE-Datum', 'Betrag (brutto)', 'Währung', 'Ziel','Skontoziel','Skonto','Status','Monitor', '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(
+ 'v.id',
+ 'v.id',
+ 'v.id',
+ 'a.name',
+ 'a.lieferantennummer',
+ 'v.rechnung',
+ 'v.rechnungsdatum',
+ 'v.betrag',
+ 'v.waehrung',
+ 'v.zahlbarbis',
+ 'v.skontobis',
+ 'v.skonto',
+ 'v.status',
+ 'v.status_beleg',
+ 'v.id'
+ );
+
+ $searchsql = array(
+ 'a.name',
+ 'a.lieferantennummer',
+ 'v.rechnung',
+ 'v.internebemerkung'
+ );
+
+ $defaultorder = 1;
+ $defaultorderdesc = 0;
+ $alignright = array(8);
+ $sumcol = array(8);
+
+ $dropnbox = "'
' AS `open`, CONCAT('') AS `auswahl`";
+
+// $moreinfo = true; // Allow drop down details
+// $moreinfoaction = "lieferschein"; // specify suffix for minidetail-URL to allow different minidetails
+// $menucol = 11; // Set id col for moredata/menu
+
+ $menu = "";
+
+ $sql = "SELECT SQL_CALC_FOUND_ROWS
+ v.id,
+ $dropnbox,
+ v.belegnr,
+ a.name,
+ a.lieferantennummer,
+ v.rechnung,
+ ".$app->erp->FormatDate("v.rechnungsdatum").",
+ ".$app->erp->FormatMenge('v.betrag',2).",
+ v.waehrung,
+ ".$app->erp->FormatDate("v.zahlbarbis").",
+ IF(v.skonto <> 0,".$app->erp->FormatDate("v.skontobis").",''),
+ IF(v.skonto <> 0,CONCAT(".$app->erp->FormatMenge('v.skonto',0).",'%'),''),
+ v.status,
+ ".$app->YUI->IconsSQLVerbindlichkeit().",
+ v.id FROM verbindlichkeit v
+ LEFT JOIN adresse a ON v.adresse = a.id
+
+";
+
+ $where = "1";
+ $count = "SELECT count(DISTINCT id) FROM verbindlichkeit WHERE $where";
+// $groupby = "";
+
+ // Toggle filters
+ $this->app->Tpl->Add('JQUERYREADY', "$('#wareneingang').click( function() { fnFilterColumn1( 0 ); } );");
+ $this->app->Tpl->Add('JQUERYREADY', "$('#rechnungsfreigabe').click( function() { fnFilterColumn2( 0 ); } );");
+ $this->app->Tpl->Add('JQUERYREADY', "$('#nichtbezahlt').click( function() { fnFilterColumn3( 0 ); } );");
+
+ for ($r = 1;$r <= 3;$r++) {
+ $this->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 = $this->app->Secure->GetGET("more_data1");
+ if ($more_data1 == 1) {
+ $where .= " AND v.freigabe <> '1'";
+ } else {
+ }
+
+ $more_data2 = $this->app->Secure->GetGET("more_data2");
+ if ($more_data2 == 1) {
+ $where .= " AND v.rechnungsfreigabe <> '1'";
+ }
+ else {
+ }
+
+ $more_data3 = $this->app->Secure->GetGET("more_data3");
+ if ($more_data3 == 1) {
+ $where .= " AND v.bezahlt <> '1'";
+ }
+ else {
+ }
+ // END Toggle filters
+
+ $this->app->YUI->DatePicker('zahlbarbis');
+ $filterzahlbarbis = $this->app->YUI->TableSearchFilter($name, 4,'zahlbarbis');
+ if (!empty($filterzahlbarbis)) {
+ $filterzahlbarbis = $this->app->String->Convert($filterzahlbarbis,'%1.%2.%3','%3-%2-%1');
+ $where .= " AND v.zahlbarbis <= '".$filterzahlbarbis."'";
+ }
+
+ $this->app->YUI->DatePicker('skontobis');
+ $filterskontobis = $this->app->YUI->TableSearchFilter($name, 5,'skontobis');
+ if (!empty($filterskontobis)) {
+ $filterskontobis = $this->app->String->Convert($filterskontobis,'%1.%2.%3','%3-%2-%1');
+ $where .= " AND v.skontobis <= '".$filterskontobis."'";
+ }
+
+ $moreinfo = true; // Allow drop down details
+ $menucol = 1; // For moredata
+
+ break;
+ }
+
+ $erg = false;
+
+ foreach ($erlaubtevars as $k => $v) {
+ if (isset($$v)) {
+ $erg[$v] = $$v;
+ }
+ }
+ return $erg;
+ }
+
+ function verbindlichkeit_list() {
+
+ // Process multi action
+ $submit = $this->app->Secure->GetPOST('ausfuehren');
+ if (!empty($submit)) {
+ $auswahl = $this->app->Secure->GetPOST('auswahl');
+ $aktion = $this->app->Secure->GetPOST('sel_aktion');
+
+ $selectedIds = [];
+ if(!empty($auswahl)) {
+ foreach($auswahl as $selectedId) {
+ $selectedId = (int)$selectedId;
+ if($selectedId > 0) {
+ $selectedIds[] = $selectedId;
+ }
+ }
+
+ switch ($aktion) {
+ case 'freigabeeinkauf':
+ foreach ($selectedIds as $id) {
+ $this->verbindlichkeit_freigabeeinkauf($id);
+ }
+ break;
+ case 'freigabebuchhaltung':
+ foreach ($selectedIds as $id) {
+ $this->verbindlichkeit_freigabebuchhaltung($id);
+ }
+ break;
+ case 'bezahlt':
+ foreach ($selectedIds as $id) {
+ $this->verbindlichkeit_freigabebezahlt($id);
+ }
+ break;
+ }
+ }
+ }
+
+ $this->app->erp->MenuEintrag("index.php?module=verbindlichkeit&action=list", "Übersicht");
+ $this->app->erp->MenuEintrag("index.php?module=verbindlichkeit&action=create", "Neu anlegen");
+
+ $this->app->erp->MenuEintrag("index.php", "Zurück");
+
+ $this->app->YUI->TableSearch('TAB1', 'verbindlichkeit_list', "show", "", "", basename(__FILE__), __CLASS__);
+
+/*
+
+ Prepared for later use...
+
+ if($this->app->erp->RechteVorhanden('verbindlichkeit', 'freigabeeinkauf')){
+ $this->app->Tpl->Set('MANUELLFREIGABEEINKAUF', '');
+ }
+
+ if($this->app->erp->RechteVorhanden('verbindlichkeit', 'freigabebuchhaltung')){
+ $this->app->Tpl->Set('MANUELLFREIGABEBUCHHALTUNG', '');
+ }
+
+ if($this->app->erp->RechteVorhanden('verbindlichkeit', 'freigabebezahlt')){
+ $this->app->Tpl->Set('ALSBEZAHLTMARKIEREN', '');
+ }
+*/
+ $this->app->User->SetParameter('table_verbindlichkeit_list_zahlbarbis', '');
+ $this->app->User->SetParameter('table_verbindlichkeit_list_skontobis', '');
+
+ $this->app->Tpl->Parse('PAGE', "verbindlichkeit_list.tpl");
+ }
+
+ public function verbindlichkeit_delete() {
+ $id = (int) $this->app->Secure->GetGET('id');
+
+ $this->app->DB->Delete("UPDATE `verbindlichkeit` SET status='storniert' WHERE `id` = '{$id}'");
+ $this->app->Tpl->Set('MESSAGE', "Der Eintrag wurde storniert.
");
+
+ $this->verbindlichkeit_list();
+ }
+
+ /*
+ * Edit verbindlichkeit item
+ * If id is empty, create a new one
+ */
+
+ function verbindlichkeit_edit() {
+ $id = $this->app->Secure->GetGET('id');
+
+ $this->app->YUI->AARLGPositionen(true); // create iframe with positionen action
+
+ // Check if other users are editing this id
+ if($this->app->erp->DisableModul('artikel',$id))
+ {
+ return;
+ }
+
+ $this->app->Tpl->Set('ID', $id);
+
+ $this->verbindlichkeit_menu($id);
+
+ $input = $this->GetInput();
+ $submit = $this->app->Secure->GetPOST('submit');
+
+ if (empty($id)) {
+ // New item
+ $id = 'NULL';
+ $input['status'] = 'angelegt';
+ }
+
+ if ($submit != '')
+ {
+
+ // Write to database
+ // Add checks here
+ $schreibschutz = $this->app->DB->Select("SELECT schreibschutz FROM verbindlichkeit WHERE id =".$id);
+
+ if ($schreibschutz) {
+ $internebemerkung = $input['internebemerkung'];
+ $projekt = $input['projekt'];
+ $kostenstelle = $input['kostenstelle'];
+ unset($input);
+ $input['internebemerkung'] = $internebemerkung;
+ $input['projekt'] = $this->app->erp->ReplaceProjekt(true,$projekt,true);
+ $input['kostenstelle'] = $this->app->DB->Select("SELECT id FROM kostenstellen WHERE nummer = '".$kostenstelle."'");
+ } else {
+ $input['adresse'] = $this->app->erp->ReplaceLieferantennummer(true,$input['adresse'],true); // Parameters: Target db?, value, from form?
+ $input['rechnungsdatum'] = $this->app->erp->ReplaceDatum(true,$input['rechnungsdatum'],true); // Parameters: Target db?, value, from form?
+ $input['eingangsdatum'] = $this->app->erp->ReplaceDatum(true,$input['eingangsdatum'],true); // Parameters: Target db?, value, from form?
+ $input['skontobis'] = $this->app->erp->ReplaceDatum(true,$input['skontobis'],true); // Parameters: Target db?, value, from form?
+ $input['zahlbarbis'] = $this->app->erp->ReplaceDatum(true,$input['zahlbarbis'],true); // Parameters: Target db?, value, from form?
+ $input['projekt'] = $this->app->erp->ReplaceProjekt(true,$input['projekt'],true);
+ $input['kostenstelle'] = $this->app->DB->Select("SELECT id FROM kostenstellen WHERE nummer = '".$input['kostenstelle']."'");
+ if(empty($input['projekt']) && !empty($input['adresse'])) {
+ $input['projekt'] = $this->app->erp->GetCreateProjekt($input['adresse']);
+ }
+ }
+
+ $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."
");
+// echo($values."
");
+// echo($update."
");
+
+ $sql = "INSERT INTO verbindlichkeit (".$columns.") VALUES (".$values.") ON DUPLICATE KEY UPDATE ".$update;
+
+// echo($sql);
+
+ $this->app->DB->Update($sql);
+
+ if ($id == 'NULL') {
+ $id = $this->app->DB->GetInsertID();
+ $msg = $this->app->erp->base64_url_encode("Das Element wurde erfolgreich angelegt.
");
+ header("Location: index.php?module=verbindlichkeit&action=edit&id=$id&msg=$msg");
+ } else {
+ $this->app->Tpl->Set('MESSAGE', "Die Einstellungen wurden erfolgreich übernommen.
");
+ }
+ }
+
+
+ // Load values again from database
+ $dropnbox = "'
' AS `open`, CONCAT('') AS `auswahl`";
+ $result = $this->app->DB->SelectArr("SELECT SQL_CALC_FOUND_ROWS v.id, $dropnbox, v.belegnr, v.status_beleg, v.schreibschutz, v.rechnung, v.zahlbarbis, v.betrag, v.umsatzsteuer, v.ustid, v.summenormal, v.summeermaessigt, v.summesatz3, v.summesatz4, v.steuersatzname3, v.steuersatzname4, v.skonto, v.skontobis, v.skontofestsetzen, v.freigabe, v.freigabemitarbeiter, v.bestellung, v.adresse, v.projekt, v.teilprojekt, v.auftrag, v.status, v.bezahlt, v.kontoauszuege, v.firma, v.logdatei, v.bestellung1, v.bestellung1betrag, v.bestellung1bemerkung, v.bestellung1projekt, v.bestellung1kostenstelle, v.bestellung1auftrag, v.bestellung2, v.bestellung2betrag, v.bestellung2bemerkung, v.bestellung2kostenstelle, v.bestellung2auftrag, v.bestellung2projekt, v.bestellung3, v.bestellung3betrag, v.bestellung3bemerkung, v.bestellung3kostenstelle, v.bestellung3auftrag, v.bestellung3projekt, v.bestellung4, v.bestellung4betrag, v.bestellung4bemerkung, v.bestellung4kostenstelle, v.bestellung4auftrag, v.bestellung4projekt, v.bestellung5, v.bestellung5betrag, v.bestellung5bemerkung, v.bestellung5kostenstelle, v.bestellung5auftrag, v.bestellung5projekt, v.bestellung6, v.bestellung6betrag, v.bestellung6bemerkung, v.bestellung6kostenstelle, v.bestellung6auftrag, v.bestellung6projekt, v.bestellung7, v.bestellung7betrag, v.bestellung7bemerkung, v.bestellung7kostenstelle, v.bestellung7auftrag, v.bestellung7projekt, v.bestellung8, v.bestellung8betrag, v.bestellung8bemerkung, v.bestellung8kostenstelle, v.bestellung8auftrag, v.bestellung8projekt, v.bestellung9, v.bestellung9betrag, v.bestellung9bemerkung, v.bestellung9kostenstelle, v.bestellung9auftrag, v.bestellung9projekt, v.bestellung10, v.bestellung10betrag, v.bestellung10bemerkung, v.bestellung10kostenstelle, v.bestellung10auftrag, v.bestellung10projekt, v.bestellung11, v.bestellung11betrag, v.bestellung11bemerkung, v.bestellung11kostenstelle, v.bestellung11auftrag, v.bestellung11projekt, v.bestellung12, v.bestellung12betrag, v.bestellung12bemerkung, v.bestellung12projekt, v.bestellung12kostenstelle, v.bestellung12auftrag, v.bestellung13, v.bestellung13betrag, v.bestellung13bemerkung, v.bestellung13kostenstelle, v.bestellung13auftrag, v.bestellung13projekt, v.bestellung14, v.bestellung14betrag, v.bestellung14bemerkung, v.bestellung14kostenstelle, v.bestellung14auftrag, v.bestellung14projekt, v.bestellung15, v.bestellung15betrag, v.bestellung15bemerkung, v.bestellung15kostenstelle, v.bestellung15auftrag, v.bestellung15projekt, v.waehrung, v.zahlungsweise, v.eingangsdatum, v.buha_konto1, v.buha_belegfeld1, v.buha_betrag1, v.buha_konto2, v.buha_belegfeld2, v.buha_betrag2, v.buha_konto3, v.buha_belegfeld3, v.buha_betrag3, v.buha_konto4, v.buha_belegfeld4, v.buha_betrag4, v.buha_konto5, v.buha_belegfeld5, v.buha_betrag5, v.rechnungsdatum, v.rechnungsfreigabe, v.kostenstelle, v.beschreibung, v.sachkonto, v.art, v.verwendungszweck, v.dta_datei, v.frachtkosten, v.internebemerkung, v.ustnormal, v.ustermaessigt, v.uststuer3, v.uststuer4, v.betragbezahlt, v.bezahltam, v.klaerfall, v.klaergrund, v.skonto_erhalten, v.kurs, v.sprache, v.id, a.lieferantennummer, a.name AS adresse_name FROM verbindlichkeit v LEFT JOIN adresse a ON a.id = v.adresse"." WHERE v.id=$id");
+
+ foreach ($result[0] as $key => $value) {
+ $this->app->Tpl->Set(strtoupper($key), $value);
+ }
+
+ if (!empty($result[0])) {
+ $verbindlichkeit_from_db = $result[0];
+ }
+
+ // Summarize positions
+
+ $sql = "SELECT * FROM verbindlichkeit_position WHERE verbindlichkeit = ".$id;
+ $positionen = $this->app->DB->SelectArr($sql);
+
+ if (!empty($positionen)) {
+ $betrag_netto = 0;
+ $betrag_brutto = 0;
+ $steuer_normal = 0;
+ $steuer_ermaessigt = 0;
+
+ /*
+ Normal: umsatzsteuer leer, steuersatz = leer
+ Ermäßigt: umsatzsteuer ermaessigt, steuersatz = -1
+ Befreit: umsatzsteuer befreit, steursatz = -1
+ Individuell: umsatzsteuer leer, steuersatz = wert
+ */
+
+ foreach ($positionen as $position) {
+
+ $tmpsteuersatz = null;
+ $tmpsteuertext = null;
+ $erloes = null;
+
+ // function GetSteuerPosition($typ, $posid,&$tmpsteuersatz = null, &$tmpsteuertext = null, &$erloes = null)
+
+ $this->app->erp->GetSteuerPosition("verbindlichkeit",$position['id'],$tmpsteuersatz,$tmpsteuertext,$erloes);
+
+ $position['steuersatz_berechnet'] = $tmpsteuersatz;
+ $position['steuertext_berechnet'] = $tmpsteuertext;
+ $position['steuererloes_berechnet'] = $erloes;
+
+ $betrag_netto += ($position['menge']*$position['preis']);
+ $betrag_brutto += ($position['menge']*$position['preis'])*(1+($tmpsteuersatz/100));
+
+ }
+
+ $this->app->Tpl->Set('BETRAGNETTO', $betrag_netto);
+ $this->app->Tpl->Set('BETRAGBRUTTOPOS', round($betrag_brutto,2));
+
+ $this->app->Tpl->Set('BETRAGDISABLED', 'disabled');
+
+ }
+
+ /*
+ * 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("artikel", "artikelnummer");
+
+ */
+
+ if ($verbindlichkeit_from_db['schreibschutz']) {
+ $this->app->Tpl->Set('SAVEDISABLED','disabled');
+ $this->app->Tpl->Set('MESSAGE',"Diese Verbindlichkeit ist schreibgeschützt und darf daher nicht mehr bearbeitet werden!
");
+ }
+
+ if (empty($verbindlichkeit_from_db['adresse'] || $verbindlichkeit_from_db['status'] == 'angelegt')) {
+ $this->app->Tpl->Set('FREIGABEEINKAUFHIDDEN','hidden');
+ $this->app->Tpl->Set('FREIGABEBUCHHALTUNGHIDDEN','hidden');
+ $this->app->Tpl->Set('FREIGABEBEZAHLTHIDDEN','hidden');
+ }
+
+ if ($verbindlichkeit_from_db['freigabe']) {
+ $this->app->Tpl->Set('FREIGABEEINKAUFHIDDEN','hidden');
+ } else {
+ $this->app->Tpl->Set('RUECKSETZENEINKAUFHIDDEN','hidden');
+ }
+ if ($verbindlichkeit_from_db['rechnungsfreigabe']) {
+ $this->app->Tpl->Set('FREIGABEBUCHHALTUNGHIDDEN','hidden');
+ } else {
+ $this->app->Tpl->Set('RUECKSETZENBUCHHALTUNGHIDDEN','hidden');
+ }
+ if ($verbindlichkeit_from_db['bezahlt'] == '1') {
+ $this->app->Tpl->Set('FREIGABEBEZAHLTHIDDEN','hidden');
+ } else {
+ $this->app->Tpl->Set('RUECKSETZENBEZAHLTHIDDEN','hidden');
+ }
+
+ $this->app->Tpl->Set('WARENEINGANGCHECKED', $verbindlichkeit_from_db['freigabe']==1?"checked":"");
+ $this->app->Tpl->Set('RECHNUNGSFREIGABECHECKED', $verbindlichkeit_from_db['rechnungsfreigabe']==1?"checked":"");
+ $this->app->Tpl->Set('BEZAHLTCHECKED', $verbindlichkeit_from_db['bezahlt']==1?"checked":"");
+
+ $this->app->Tpl->Set('RECHNUNGSDATUM',$this->app->erp->ReplaceDatum(false,$verbindlichkeit_from_db['rechnungsdatum'],false));
+ $this->app->YUI->DatePicker("rechnungsdatum");
+ $this->app->Tpl->Set('EINGANGSDATUM',$this->app->erp->ReplaceDatum(false,$verbindlichkeit_from_db['eingangsdatum'],false));
+ $this->app->YUI->DatePicker("eingangsdatum");
+ $this->app->Tpl->Set('SKONTOBIS',$this->app->erp->ReplaceDatum(false,$verbindlichkeit_from_db['skontobis'],false));
+ $this->app->YUI->DatePicker("skontobis");
+ $this->app->Tpl->Set('ZAHLBARBIS',$this->app->erp->ReplaceDatum(false,$verbindlichkeit_from_db['zahlbarbis'],false));
+ $this->app->YUI->DatePicker("zahlbarbis");
+
+ $sql = "SELECT " . $this->app->YUI->IconsSQLVerbindlichkeit() . " AS `icons` FROM verbindlichkeit v WHERE id=$id";
+ $icons = $this->app->DB->SelectArr($sql);
+ $this->app->Tpl->Add('STATUSICONS', $icons[0]['icons']);
+
+ $this->app->YUI->AutoComplete("adresse", "lieferant");
+ $this->app->YUI->AutoComplete("projekt", "projektname", 1);
+ $this->app->Tpl->Set('PROJEKT',$this->app->erp->ReplaceProjekt(false,$verbindlichkeit_from_db['projekt'],false));
+ $this->app->YUI->AutoComplete("kostenstelle", "kostenstelle", 1);
+ $this->app->Tpl->Set('KOSTENSTELLE',$this->app->DB->SELECT("SELECT nummer FROM kostenstellen WHERE id = '".$verbindlichkeit_from_db['kostenstelle']."'"));
+
+ $waehrungenselect = $this->app->erp->GetSelect($this->app->erp->GetWaehrung(), $verbindlichkeit_from_db['waehrung']);
+ $this->app->Tpl->Set('WAEHRUNGSELECT', $waehrungenselect);
+
+ $this->app->Tpl->Set('ADRESSE_ID', $verbindlichkeit_from_db['adresse']);
+
+ $this->app->Tpl->Set('ADRESSE', $this->app->erp->ReplaceLieferantennummer(false,$verbindlichkeit_from_db['adresse'],false)); // Convert ID to form display
+
+ $this->app->YUI->CkEditor("internebemerkung");
+
+ $anzahldateien = $this->app->erp->AnzahlDateien("verbindlichkeit",$id);
+ if ($anzahldateien > 0) {
+ $file = urlencode("../../../../index.php?module=verbindlichkeit&action=inlinepdf&id=$id");
+ $iframe = "";
+ $this->app->Tpl->Set('INLINEPDF', $iframe);
+ } else {
+ $this->app->Tpl->Set('INLINEPDF', 'Keine Dateien vorhanden.');
+ }
+
+ $this->verbindlichkeit_minidetail('MINIDETAIL',false);
+ $this->app->Tpl->Parse('PAGE', "verbindlichkeit_edit.tpl");
+
+ }
+
+ /**
+ * Get all paramters from html form and save into $input
+ */
+ public function GetInput(): array {
+ $input = array();
+ $input['adresse'] = $this->app->Secure->GetPOST('adresse');
+ $input['rechnung'] = $this->app->Secure->GetPOST('rechnung');
+ $input['zahlbarbis'] = $this->app->Secure->GetPOST('zahlbarbis');
+ $input['betrag'] = $this->app->Secure->GetPOST('betrag');
+ $input['waehrung'] = $this->app->Secure->GetPOST('waehrung');
+ $input['skonto'] = $this->app->Secure->GetPOST('skonto');
+ $input['skontobis'] = $this->app->Secure->GetPOST('skontobis');
+ $input['projekt'] = $this->app->Secure->GetPOST('projekt');
+ $input['bezahlt'] = $this->app->Secure->GetPOST('bezahlt')?'1':'0';;
+ $input['zahlungsweise'] = $this->app->Secure->GetPOST('zahlungsweise');
+ $input['eingangsdatum'] = $this->app->Secure->GetPOST('eingangsdatum');
+ $input['rechnungsdatum'] = $this->app->Secure->GetPOST('rechnungsdatum');
+ $input['freigabe'] = $this->app->Secure->GetPOST('freigabe')?'1':'0';
+ $input['rechnungsfreigabe'] = $this->app->Secure->GetPOST('rechnungsfreigabe')?'1':'0';
+ $input['kostenstelle'] = $this->app->Secure->GetPOST('kostenstelle');
+ $input['internebemerkung'] = $this->app->Secure->GetPOST('internebemerkung');
+ return $input;
+ }
+
+ function verbindlichkeit_menu($id) {
+
+ $this->app->erp->MenuEintrag("index.php?module=verbindlichkeit&action=edit&id=$id", "Details");
+ $this->app->erp->MenuEintrag("index.php?module=verbindlichkeit&action=list", "Zurück zur Übersicht");
+
+ $anzahldateien = $this->app->erp->AnzahlDateien("verbindlichkeit",$id);
+ if ($anzahldateien > 0) {
+ $anzahldateien = " (".$anzahldateien.")";
+ } else {
+ $anzahldateien="";
+ }
+
+ if ($id != 'NULL') {
+ $this->app->erp->MenuEintrag("index.php?module=verbindlichkeit&action=dateien&id=$id", "Dateien".$anzahldateien);
+ }
+
+ $invoiceArr = $this->app->DB->SelectRow("SELECT v.belegnr, a.name, v.status, schreibschutz FROM verbindlichkeit v LEFT JOIN adresse a ON v.adresse = a.id WHERE v.id='$id' LIMIT 1");
+ $belegnr = $invoiceArr['belegnr'];
+ $name = $invoiceArr['name'];
+ if($belegnr=='0' || $belegnr=='') {
+ $belegnr ='(Entwurf)';
+ }
+ $this->app->Tpl->Set('KURZUEBERSCHRIFT2',"$name Verbindlichkeit $belegnr");
+
+ if ($invoiceArr['status'] === 'angelegt' || $invoiceArr['schreibschutz'] != 1) {
+ $this->app->erp->MenuEintrag("index.php?module=verbindlichkeit&action=freigabe&id=$id",'Freigabe');
+ }
+ }
+
+ function verbindlichkeit_dateien()
+ {
+ $id = $this->app->Secure->GetGET("id");
+ $this->verbindlichkeit_menu($id);
+ $this->app->Tpl->Add('UEBERSCHRIFT'," (Dateien)");
+ $this->app->YUI->DateiUpload('PAGE',"verbindlichkeit",$id);
+ }
+
+ function verbindlichkeit_inlinepdf() {
+ $id = $this->app->Secure->GetGET('id');
+
+ $file_attachments = $this->app->erp->GetDateiSubjektObjekt('%','verbindlichkeit',$id);
+
+ if (!empty($file_attachments)) {
+
+// print_r($file_attachments);
+
+ // Try to merge all PDFs
+ $file_paths = array();
+ foreach ($file_attachments as $file_attachment) {
+ if ($this->app->erp->GetDateiEndung($file_attachment) == 'pdf') {
+ $file_paths[] = $this->app->erp->GetDateiPfad($file_attachment);
+ }
+ }
+ $pdfMerger = $this->app->Container->get('PdfMerger');
+ $mergeOutputPath = realpath($this->app->erp->GetTMP()) . '/' . uniqid('sammelpdf_', true) . '.pdf';
+ try {
+ $pdfMerger->merge($file_paths, $mergeOutputPath);
+ header('Content-type:application/pdf');
+ header('Content-Disposition: attachment;filename='.md5(microtime(true)).'.pdf');
+ readfile($mergeOutputPath);
+ $this->app->ExitXentral();
+ } catch (\Xentral\Components\Pdf\Exception\PdfComponentExceptionInterface $exception) {
+ // Just the first PDF
+ foreach ($file_attachments as $file_attachment) {
+ if ($this->app->erp->GetDateiEndung($file_attachment) == 'pdf') {
+ $file_contents = $this->app->erp->GetDatei($file_attachment);
+ header('Content-type:application/pdf');
+ header('Content-Disposition: attachment;filename=verbindlichkeit_'.$id.'.pdf');
+ echo($file_contents);
+ $this->app->ExitXentral();
+ }
+ }
+ }
+ }
+ $this->app->ExitXentral();
+ }
+
+ function verbindlichkeit_positionen() {
+ $this->app->YUI->AARLGPositionen(false); // Render positionen editable into iframe
+ }
+
+ function verbindlichkeit_positioneneditpopup() {
+ $cmd = $this->app->Secure->GetGET('cmd');
+ if($cmd === 'getopenaccordions')
+ {
+ $accordions = $this->app->Secure->GetPOST('accordions');
+ $accordions = explode('*|*',$accordions);
+ foreach($accordions as $k => $v)
+ {
+ if(empty($v))
+ {
+ unset($accordions[$k]);
+ }else{
+ $accordions[$k] = 'verbindlichkeit_accordion'.$v;
+ }
+ }
+ $ret = [];
+ if(!empty($accordions))
+ {
+ $accordions = $this->app->User->GetParameter($accordions);
+ if(!empty($accordions))
+ {
+ foreach($accordions as $v)
+ {
+ if(!empty($v['value']))
+ {
+ $ret['accordions'][] = str_replace('verbindlichkeit_accordion','',$v['name']);
+ }
+ }
+ }
+ }
+ echo json_encode($ret);
+ $this->app->ExitXentral();
+ }
+ if($cmd === 'setaccordion')
+ {
+ $name = $this->app->Secure->GetPOST('name');
+ $active = $this->app->Secure->GetPOST('active');
+ $this->app->User->SetParameter('verbindlichkeit_accordion'.$name, $active);
+ echo json_encode(array('success'=>1));
+ $this->app->ExitXentral();
+ }
+ $id = $this->app->Secure->GetGET('id');
+ $fmodul = $this->app->Secure->GetGET('fmodul');
+ $artikel= $this->app->DB->Select("SELECT artikel FROM verbindlichkeit_position WHERE id='$id' LIMIT 1");
+
+ // nach page inhalt des dialogs ausgeben
+ $filename = 'widgets/widget.auftag_position_custom.php';
+ if(is_file($filename))
+ {
+ include_once $filename;
+ $widget = new WidgetVerbindlichkeit_positionCustom($this->app,'PAGE');
+ } else {
+ $widget = new WidgetVerbindlichkeit_position($this->app,'PAGE');
+ }
+
+ $sid= $this->app->DB->Select("SELECT verbindlichkeit FROM verbindlichkeit_position WHERE id='$id' LIMIT 1");
+ $widget->form->SpecialActionAfterExecute('close_refresh',
+ "index.php?module=verbindlichkeit&action=positionen&id=$sid&fmodul=$fmodul");
+ $widget->Edit();
+ $this->app->BuildNavigation=false;
+ }
+
+ function verbindlichkeit_freigabe()
+ {
+ $id = $this->app->Secure->GetGET('id');
+ $this->app->erp->BelegFreigabe('verbindlichkeit',$id);
+ $this->app->erp->BelegProtokoll("verbindlichkeit",$id,"Verbindlichkeit freigegeben");
+ $this->app->DB->Update("UPDATE verbindlichkeit SET schreibschutz = 1 WHERE id = ".$id);
+ $this->verbindlichkeit_edit();
+ }
+
+ function verbindlichkeit_freigabeeinkauf($id = null)
+ {
+ if (empty($id)) {
+ $id = $this->app->Secure->GetGET('id');
+ $gotoedit = true;
+ }
+ $sql = "UPDATE verbindlichkeit SET freigabe = 1 WHERE id=".$id;
+ $this->app->DB->Update($sql);
+ $this->app->erp->BelegProtokoll("verbindlichkeit",$id,"Verbindlichkeit freigegeben (Einkauf)");
+ if ($gotoedit) {
+ $this->verbindlichkeit_edit();
+ }
+ }
+
+ function verbindlichkeit_freigabebuchhaltung($id = null)
+ {
+ if (empty($id)) {
+ $id = $this->app->Secure->GetGET('id');
+ $gotoedit = true;
+ }
+ $sql = "UPDATE verbindlichkeit SET rechnungsfreigabe = 1 WHERE id=".$id;
+ $this->app->DB->Update($sql);
+ $this->app->erp->BelegProtokoll("verbindlichkeit",$id,"Verbindlichkeit freigegeben (Buchhaltung)");
+ if ($gotoedit) {
+ $this->verbindlichkeit_edit();
+ }
+ }
+
+ function verbindlichkeit_freigabebezahlt($id = null)
+ {
+ if (empty($id)) {
+ $id = $this->app->Secure->GetGET('id');
+ $gotoedit = true;
+ }
+ $sql = "UPDATE verbindlichkeit SET bezahlt = 1 WHERE id=".$id;
+ $this->app->DB->Update($sql);
+ $this->app->erp->BelegProtokoll("verbindlichkeit",$id,"Verbindlichkeit als bezahlt markiert");
+ if ($gotoedit) {
+ $this->verbindlichkeit_edit();
+ }
+ }
+
+ function verbindlichkeit_ruecksetzeneinkauf($id = null)
+ {
+ if (empty($id)) {
+ $id = $this->app->Secure->GetGET('id');
+ $gotoedit = true;
+ }
+ $sql = "UPDATE verbindlichkeit SET freigabe = 0 WHERE id=".$id;
+ $this->app->DB->Update($sql);
+ $this->app->erp->BelegProtokoll("verbindlichkeit",$id,"Verbindlichkeit rückgesetzt (Einkauf)");
+ if ($gotoedit) {
+ $this->verbindlichkeit_edit();
+ }
+ }
+
+ function verbindlichkeit_ruecksetzenbuchhaltung($id = null)
+ {
+ if (empty($id)) {
+ $id = $this->app->Secure->GetGET('id');
+ $gotoedit = true;
+ }
+ $sql = "UPDATE verbindlichkeit SET rechnungsfreigabe = 0 WHERE id=".$id;
+ $this->app->DB->Update($sql);
+ $this->app->erp->BelegProtokoll("verbindlichkeit",$id,"Verbindlichkeit rückgesetzt (Buchhaltung)");
+ if ($gotoedit) {
+ $this->verbindlichkeit_edit();
+ }
+ }
+
+ function verbindlichkeit_ruecksetzenbezahlt($id = null)
+ {
+ if (empty($id)) {
+ $id = $this->app->Secure->GetGET('id');
+ $gotoedit = true;
+ }
+ $sql = "UPDATE verbindlichkeit SET bezahlt = 0 WHERE id=".$id;
+ $this->app->DB->Update($sql);
+ $this->app->erp->BelegProtokoll("verbindlichkeit",$id,"Verbindlichkeit bezahlt rückgesetzt");
+ if ($gotoedit) {
+ $this->verbindlichkeit_edit();
+ }
+ }
+
+ function verbindlichkeit_schreibschutz($id = null)
+ {
+ if (empty($id)) {
+ $id = $this->app->Secure->GetGET('id');
+ $gotoedit = true;
+ }
+ $sql = "UPDATE verbindlichkeit SET schreibschutz = 0 WHERE id=".$id;
+ $this->app->DB->Update($sql);
+ $this->app->erp->BelegProtokoll("verbindlichkeit",$id,"Verbindlichkeit Schreibschutz entfernt");
+ if ($gotoedit) {
+ $this->verbindlichkeit_edit();
+ }
+ }
+
+ public function verbindlichkeit_minidetail($parsetarget='',$menu=true) {
+
+ $id = $this->app->Secure->GetGET('id');
+
+ $result = $this->app->DB->SelectArr("SELECT SQL_CALC_FOUND_ROWS
+ v.id,
+ v.belegnr,
+ v.status_beleg,
+ v.schreibschutz,
+ v.rechnung,
+ ".$this->app->erp->FormatDate('v.zahlbarbis', 'zahlbarbis').",
+ v.betrag,
+ v.umsatzsteuer,
+ v.ustid,
+ v.summenormal,
+ v.summeermaessigt,
+ v.summesatz3,
+ v.summesatz4,
+ v.steuersatzname3,
+ v.steuersatzname4,
+ v.skonto,
+ ".$this->app->erp->FormatDate('v.skontobis', 'skontobis').",
+ v.skontofestsetzen,
+ v.freigabe,
+ v.freigabemitarbeiter,
+ v.bestellung,
+ p.abkuerzung AS projekt,
+ v.teilprojekt,
+ v.auftrag,
+ v.status,
+ v.bezahlt,
+ v.kontoauszuege,
+ v.firma,
+ v.logdatei,
+ v.waehrung,
+ v.zahlungsweise,
+ ".$this->app->erp->FormatDate('v.eingangsdatum', 'eingangsdatum').",
+ ".$this->app->erp->FormatDate('v.rechnungsdatum', 'rechnungsdatum').",
+ v.rechnungsfreigabe,
+ k.nummer as kostenstelle,
+ v.beschreibung,
+ v.sachkonto,
+ v.art,
+ v.verwendungszweck,
+ v.dta_datei,
+ v.frachtkosten,
+ v.internebemerkung,
+ v.ustnormal,
+ v.ustermaessigt,
+ v.uststuer3,
+ v.uststuer4,
+ v.betragbezahlt,
+ v.bezahltam,
+ v.klaerfall,
+ v.klaergrund,
+ v.skonto_erhalten,
+ v.kurs,
+ v.sprache,
+ v.id,
+ CONCAT(a.lieferantennummer,' ',a.name) AS adresse
+ FROM verbindlichkeit v
+ LEFT JOIN adresse a ON a.id = v.adresse
+ LEFT JOIN projekt p ON a.projekt = p.id
+ LEFT JOIN kostenstellen k ON v.kostenstelle = k.id
+ WHERE v.id='$id'");
+
+ foreach ($result[0] as $key => $value) {
+ $this->app->Tpl->Set(strtoupper($key), $value);
+ }
+
+ if (!empty($result[0])) {
+ $verbindlichkeit_from_db = $result[0];
+ }
+
+ $tmp = new EasyTable($this->app);
+ $tmp->Query("SELECT zeit,bearbeiter,grund FROM verbindlichkeit_protokoll WHERE verbindlichkeit='$id' ORDER by zeit DESC",0,"");
+ $tmp->DisplayNew('PROTOKOLL',"Protokoll","noAction");
+
+ if($parsetarget=='')
+ {
+ $this->app->Tpl->Output('verbindlichkeit_minidetail.tpl');
+ $this->app->ExitXentral();
+ }
+ $this->app->Tpl->Parse($parsetarget,'verbindlichkeit_minidetail.tpl');
+ }
+
+}
diff --git a/www/widgets/_gen/widget.gen.verbindlichkeit_position.php b/www/widgets/_gen/widget.gen.verbindlichkeit_position.php
index efbd4856..71b00ae7 100644
--- a/www/widgets/_gen/widget.gen.verbindlichkeit_position.php
+++ b/www/widgets/_gen/widget.gen.verbindlichkeit_position.php
@@ -1,129 +1,129 @@
-app = $app;
- $this->parsetarget = $parsetarget;
- $this->Form();
- }
-
- public function verbindlichkeit_positionDelete()
- {
-
- $this->form->Execute("verbindlichkeit_position","delete");
-
- $this->verbindlichkeit_positionList();
- }
-
- function Edit()
- {
- $this->form->Edit();
- }
-
- function Copy()
- {
- $this->form->Copy();
- }
-
- public function Create()
- {
- $this->form->Create();
- }
-
- public function Search()
- {
- $this->app->Tpl->Set($this->parsetarget,"SUUUCHEEE");
- }
-
- public function Summary()
- {
- $this->app->Tpl->Set($this->parsetarget,"grosse Tabelle");
- }
-
- function Form()
- {
- $this->form = $this->app->FormHandler->CreateNew("verbindlichkeit_position");
- $this->form->UseTable("verbindlichkeit_position");
- $this->form->UseTemplate("verbindlichkeit_position.tpl",$this->parsetarget);
-
- $field = new HTMLInput("artikel","text","","50","","","","","","","","0","","");
- $this->form->NewField($field);
- $this->form->AddMandatory("artikel","notempty","Pflichtfeld!","MSGARTIKEL");
-
- $field = new HTMLInput("bezeichnung","text","","50","","","","","","","","0","","");
- $this->form->NewField($field);
- $this->form->AddMandatory("bezeichnung","notempty","Pflichtfeld!","MSGBEZEICHNUNG");
-
- $field = new HTMLInput("nummer","text","","50","","","","","","","","0","","");
- $this->form->NewField($field);
-
- $field = new HTMLTextarea("beschreibung",5,30,"","","","","0");
- $this->form->NewField($field);
-
- $field = new HTMLInput("menge","text","","8","","","","","","","","0","","");
- $this->form->NewField($field);
- $this->form->AddMandatory("menge","notempty","Pflichtfeld!","MSGMENGE");
-
- $field = new HTMLInput("preis","text","","50","","","","","","","","0","","");
- $this->form->NewField($field);
-
- $field = new HTMLInput("waehrung","text","","15","","","","","","","","0","","");
- $this->form->NewField($field);
-
- $field = new HTMLSelect("umsatzsteuer",0,"umsatzsteuer","","","0");
- $field->AddOption('Standard','');
- $field->AddOption('Ermäßigt','ermaessigt');
- $field->AddOption('Befreit','befreit');
- $this->form->NewField($field);
-
- $field = new HTMLCheckbox("anderersteuersatz","","","","0","0");
- $this->form->NewField($field);
-
- $field = new HTMLInput("steuersatz","text","","15","","","","","","","","0","","");
- $this->form->NewField($field);
-
- $field = new HTMLTextarea("steuertext",3,50,"","","","","0");
- $this->form->NewField($field);
-
- $field = new HTMLInput("einheit","text","","50","","","","","","","","0","","");
- $this->form->NewField($field);
-
- $field = new HTMLInput("vpe","text","","50","","","","","","","","0","","");
- $this->form->NewField($field);
-
- $field = new HTMLInput("projekt","text","","50","","","","","","","","0","","");
- $this->form->NewField($field);
-
- $field = new HTMLInput("kostenstelle","text","","50","","","","","","","","0","","");
- $this->form->NewField($field);
-
- $field = new HTMLInput("lieferdatum","text","","15","","","","","","","","0","","");
- $this->form->NewField($field);
-
-
- }
-
-}
-
-?>
\ No newline at end of file
+app = $app;
+ $this->parsetarget = $parsetarget;
+ $this->Form();
+ }
+
+ public function verbindlichkeit_positionDelete()
+ {
+
+ $this->form->Execute("verbindlichkeit_position","delete");
+
+ $this->verbindlichkeit_positionList();
+ }
+
+ function Edit()
+ {
+ $this->form->Edit();
+ }
+
+ function Copy()
+ {
+ $this->form->Copy();
+ }
+
+ public function Create()
+ {
+ $this->form->Create();
+ }
+
+ public function Search()
+ {
+ $this->app->Tpl->Set($this->parsetarget,"SUUUCHEEE");
+ }
+
+ public function Summary()
+ {
+ $this->app->Tpl->Set($this->parsetarget,"grosse Tabelle");
+ }
+
+ function Form()
+ {
+ $this->form = $this->app->FormHandler->CreateNew("verbindlichkeit_position");
+ $this->form->UseTable("verbindlichkeit_position");
+ $this->form->UseTemplate("verbindlichkeit_position.tpl",$this->parsetarget);
+
+ $field = new HTMLInput("artikel","text","","50","","","","","","","","0","","");
+ $this->form->NewField($field);
+ $this->form->AddMandatory("artikel","notempty","Pflichtfeld!","MSGARTIKEL");
+
+ $field = new HTMLInput("bezeichnung","text","","50","","","","","","","","0","","");
+ $this->form->NewField($field);
+ $this->form->AddMandatory("bezeichnung","notempty","Pflichtfeld!","MSGBEZEICHNUNG");
+
+ $field = new HTMLInput("nummer","text","","50","","","","","","","","0","","");
+ $this->form->NewField($field);
+
+ $field = new HTMLTextarea("beschreibung",5,30,"","","","","0");
+ $this->form->NewField($field);
+
+ $field = new HTMLInput("menge","text","","8","","","","","","","","0","","");
+ $this->form->NewField($field);
+ $this->form->AddMandatory("menge","notempty","Pflichtfeld!","MSGMENGE");
+
+ $field = new HTMLInput("preis","text","","40","","","","","","","","0","","");
+ $this->form->NewField($field);
+
+ $field = new HTMLSelect("umsatzsteuer",0,"umsatzsteuer","","","0");
+ $field->AddOption('Standard','');
+ $field->AddOption('Ermäßigt','ermaessigt');
+ $field->AddOption('Befreit','befreit');
+ $this->form->NewField($field);
+
+ $field = new HTMLCheckbox("anderersteuersatz","","","","0","0");
+ $this->form->NewField($field);
+
+ $field = new HTMLInput("steuersatz","text","","15","","","","","","","","0","","");
+ $this->form->NewField($field);
+
+ $field = new HTMLTextarea("steuertext",3,50,"","","","","0");
+ $this->form->NewField($field);
+
+ $field = new HTMLInput("einheit","text","","50","","","","","","","","0","","");
+ $this->form->NewField($field);
+
+ $field = new HTMLInput("vpe","text","","50","","","","","","","","0","","");
+ $this->form->NewField($field);
+
+ $field = new HTMLInput("projekt","text","","50","","","","","","","","0","","");
+ $this->form->NewField($field);
+
+ $field = new HTMLInput("sachkonto","text","","50","","","","","","","","0","","");
+ $this->form->NewField($field);
+
+ $field = new HTMLInput("kostenstelle","text","","50","","","","","","","","0","","");
+ $this->form->NewField($field);
+
+ $field = new HTMLInput("lieferdatum","text","","15","","","","","","","","0","","");
+ $this->form->NewField($field);
+
+
+ }
+
+}
+
+?>
diff --git a/www/widgets/templates/_gen/verbindlichkeit_position.tpl b/www/widgets/templates/_gen/verbindlichkeit_position.tpl
index 86803cbb..a8923644 100644
--- a/www/widgets/templates/_gen/verbindlichkeit_position.tpl
+++ b/www/widgets/templates/_gen/verbindlichkeit_position.tpl
@@ -25,31 +25,41 @@ $('#anderersteuersatz').click(function() { if (!$(this).is(':checked')) {
});
[WAEHRUNGSTABELLE]
diff --git a/www/widgets/widget.verbindlichkeit_position.php b/www/widgets/widget.verbindlichkeit_position.php
index e80d4dd7..23710a9b 100644
--- a/www/widgets/widget.verbindlichkeit_position.php
+++ b/www/widgets/widget.verbindlichkeit_position.php
@@ -24,6 +24,7 @@ class WidgetVerbindlichkeit_position extends WidgetGenVerbindlichkeit_position
$this->app->YUI->AutoComplete("projekt","projektname",1);
$this->app->YUI->AutoComplete("kostenstelle","kostenstelle",1);
+ $this->app->YUI->AutoComplete("sachkonto","sachkonto_aufwendungen",1);
$this->app->YUI->AutoComplete("artikel","artikelnummer");
//$this->app->YUI->AutoComplete(AUTO,"artikel",array('nummer','name_de','warengruppe'),"nummer");
@@ -36,6 +37,7 @@ class WidgetVerbindlichkeit_position extends WidgetGenVerbindlichkeit_position
$this->form->ReplaceFunction("menge",$this,"ReplaceMenge");
//$this->form->ReplaceFunction("geliefert",$this,"ReplaceMenge");
$this->form->ReplaceFunction("projekt",$this,"ReplaceProjekt");
+ $this->form->ReplaceFunction("sachkonto",$this,"ReplaceSachkonto");
if($this->app->erp->Firmendaten("briefhtml")=="1")
{
@@ -79,6 +81,11 @@ class WidgetVerbindlichkeit_position extends WidgetGenVerbindlichkeit_position
return $this->app->erp->ReplaceProjekt($db,$value,$fromform);
}
+ function ReplaceSachkonto($db,$value,$fromform)
+ {
+ return $this->app->erp->ReplaceKontorahmen($db,$value,$fromform);
+ }
+
function ReplaceSteuersatz($db,$value,$fromform)
{
if($db)