X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;ds=inline;f=bin%2Fmozilla%2Fdatev.pl;h=9572e74bd4c2059da5ba9761b196a1ba1b789d0b;hb=42dfa9a7030e7d06288385076e348d34ec809128;hp=f3dbc2eb82bea431afafd5befe337076bd39e65c;hpb=99ecb3cbd8a829f06e1f542a03369c40460ccf99;p=kivitendo-erp.git
diff --git a/bin/mozilla/datev.pl b/bin/mozilla/datev.pl
index f3dbc2eb8..9572e74bd 100644
--- a/bin/mozilla/datev.pl
+++ b/bin/mozilla/datev.pl
@@ -1,5 +1,5 @@
#=====================================================================
-# Lx-Office ERP
+# kivitendo ERP
# Copyright (c) 2004
#
# Author: Philip Reetz
@@ -29,7 +29,7 @@ use POSIX qw(strftime getcwd);
use Archive::Zip qw(:ERROR_CODES :CONSTANTS);
use SL::Common;
-use SL::DATEV;
+use SL::DATEV qw(:CONSTANTS);
use strict;
@@ -45,9 +45,10 @@ sub export {
$::lxdebug->enter_sub;
$::auth->assert('datev_export');
- DATEV->get_datev_stamm(\%::myconfig, $::form);
+ my $stamm = SL::DATEV->new->get_datev_stamm;
+
$::form->header;
- print $::form->parse_html_template('datev/export');
+ print $::form->parse_html_template('datev/export', $stamm);
$::lxdebug->leave_sub;
}
@@ -85,48 +86,41 @@ sub export_stammdaten {
}
sub export3 {
- $main::lxdebug->enter_sub();
-
- my $form = $main::form;
- my %myconfig = %main::myconfig;
- my $locale = $main::locale;
-
- $main::auth->assert('datev_export');
-
- DATEV::clean_temporary_directories();
-
- DATEV->save_datev_stamm(\%myconfig, \%$form);
+ $::lxdebug->enter_sub;
+ $::auth->assert('datev_export');
- my $link = "datev.pl?action=download&download_token=";
+ my %data = (
+ exporttype => $::form->{exporttype} ? DATEV_ET_STAMM : DATEV_ET_BUCHUNGEN,
+ format => $::form->{kne} ? DATEV_FORMAT_KNE : DATEV_FORMAT_OBE,
+ );
+
+ if ($::form->{exporttype} == DATEV_ET_STAMM) {
+ $data{accnofrom} = $::form->{accnofrom},
+ $data{accnoto} = $::form->{accnoto},
+ } elsif ($::form->{exporttype} == DATEV_ET_BUCHUNGEN) {
+ @data{qw(from to)} = _get_dates(
+ $::form->{zeitraum}, $::form->{monat}, $::form->{quartal},
+ $::form->{transdatefrom}, $::form->{transdateto},
+ );
+ } else {
+ die 'invalid exporttype';
+ }
- if ($form->{kne}) {
- my $result = DATEV->kne_export(\%myconfig, \%$form);
- if ($result && @{ $result->{filenames} }) {
- $link .= Q($result->{download_token});
+ my $datev = SL::DATEV->new(%data);
- print(qq|
| . $locale->text('KNE-Export erfolgreich!') . qq|
Download|);
+ $datev->clean_temporary_directories;
+ $datev->save_datev_stamm($::form);
- print $form->parse_html_template('datev/net_gross_difference') if @{ $form->{net_gross_differences} };
+ $datev->export;
- } else {
- $form->error("KNE-Export schlug fehl.");
- }
+ if (!$datev->errors) {
+ $::form->header;
+ print $::form->parse_html_template('datev/export3', { datev => $datev });
} else {
- # OBE-Export nicht implementiert.
-
- # my @filenames = DATEV->obe_export(\%myconfig, \%$form);
- # if (@filenames) {
- # print(qq|
| . $locale->text('OBE-Export erfolgreich!') . qq|
|);
- # $link .= "&filenames=" . $form->escape(join(":", @filenames));
- # print(qq|
Download|);
- # } else {
- # $form->error("OBE-Export schlug fehl.");
- # }
+ $::form->error("Export schlug fehl.\n" . join "\n", $datev->errors);
}
- print("