Generischer USTVA Report für alle Kontenrahmen ausser Germany
authorUdo Spallek <info@wissensvermittlung.com>
Wed, 18 Jul 2007 09:12:11 +0000 (09:12 +0000)
committerUdo Spallek <info@wissensvermittlung.com>
Wed, 18 Jul 2007 09:12:11 +0000 (09:12 +0000)
SL/USTVA.pm
bin/mozilla/ustva.pl
locale/de/all
templates/webpages/ustva/config_step1_de.html
templates/webpages/ustva/config_step1_master.html
templates/webpages/ustva/config_step2_de.html
templates/webpages/ustva/config_step2_master.html
templates/webpages/ustva/generic_taxreport_de.html [new file with mode: 0644]
templates/webpages/ustva/generic_taxreport_master.html [new file with mode: 0644]
templates/webpages/ustva/report_de.html
templates/webpages/ustva/report_master.html

index 3655208..658e2c7 100644 (file)
 
 package USTVA;
 
+use SL::DBUtils;
+
+sub get_coa {
+  
+  my ( $self, $form, $myconfig) = @_;
+  
+  my $query = q{ SELECT coa FROM defaults };
+  
+  my $dbh = $form->dbconnect($myconfig);
+  my $sth = $dbh->prepare($query);
+  $sth->execute() || $form->dberror($query);
+
+  my ($coa) = selectrow_query($form, $dbh, $query);  
+  
+  $sth->finish;
+  $dbh->disconnect;
+  
+  $form->{coa} = $coa;
+  $form->{"COA_$coa"} = '1';
+  $form->{COA_Germany} = '1' if ( $coa eq 'Germany-DATEV-SKR03EU' or $coa eq 'Germany-DATEV-SKR04EU');
+
+  return;
+}
+
+
 sub report_variables {
   # Get all positions for taxreport out of the database
   # Needs Databaseupdate Pg-upgrade2/USTVA_abstraction.pl
@@ -53,8 +78,6 @@ sub report_variables {
     $where_dcp  
   |;
   
-  $main::lxdebug->message(LXDebug::QUERY, "\$query= \n $query\n");
-  
   my $dbh = $form->dbconnect($myconfig);
   my $sth = $dbh->prepare($query);
 
index b7b66fb..4229d24 100644 (file)
@@ -197,12 +197,16 @@ sub report {
     }
   ];
  
+  # Which COA is in use? 
   
+  USTVA->get_coa($form, $myconfig);
+
   my $template_ref = {
     openings         => $openings,  
     company_given    => $company_given,
     address_given    => $address_given,     
     taxnumber_given  => $taxnumber_given,
+    taxnumber        => $myconfig->{taxnumber},
     select_year      => $select_year,      
     period_local     => $period_local,
     method_local     => $method_local,
@@ -210,6 +214,7 @@ sub report {
     checkbox_kz_10   => $checkbox_kz_10,
     tax_office_banks => $tax_office_banks_ref,    
     select_options   => &show_options,    
+
   };
   
   print($form->parse_html_template('ustva/report', $template_ref));
@@ -1005,39 +1010,45 @@ sub generate_ustva {
       exit(0);
     }
 
-  # Austria
-  } elsif ($form->{coa} eq 'Austria') {
-
-    #
-    # Outputformat specific customisation's
-    #
+  
+  } else  # Outputformat for generic output
+  {
 
-    my @category_euro = qw(
-      511 861 36   80   971  931  98   96   53   74
-      85  65  66   61   62   67   63   64   59   69 
-      39  83  811  891  Z43  Z45  Z53  Z62  Z65  Z67
-      41 44 49 43 48 51 86 35 77 76 91 89
-      97 93 95 94 42 60 45 52 73 84 81 
-    );
-    
+    my @category_cent = USTVA->report_variables({
+        myconfig    => \%myconfig,
+        form        => $form,
+        type        => '',
+        attribute   => 'position',
+        dec_places  => '2',
+    });
 
-    if ( $form->{format} eq 'html') { # Formatierungen für HTML Ausgabe
+    my @category_euro = USTVA->report_variables({
+        myconfig    => \%myconfig,
+        form        => $form,
+        type        => '',
+        attribute   => 'position',
+        dec_places  => '0',
+    });
 
-      $form->{IN} = $form->{type} . '.html';
-      $form->{padding} = "&nbsp;&nbsp;";
-      $form->{bold}    = "<b>";
-      $form->{endbold} = "</b>";
-      $form->{br}      = "<br>";
-      $form->{address} =~ s/\\n/\n/g;
+    $form->{"Watchdog::USTVA"} = 1;
+    $form->{USTVA} = [];
 
-      foreach $number (@category_euro) {
-        $form->{$number} = $form->format_amount(\%myconfig, $form->{$number}, '2', '0');
+    if ( $form->{format} eq 'generic') { # Formatierungen für HTML Ausgabe
+      
+      my $rec_ref = {};
+      for my $kennziffer (@category_cent, @category_euro) {
+        $rec_ref = {};
+        $rec_ref->{id} = $kennziffer;
+        $rec_ref->{amount} = $form->format_amount(\%myconfig, $form->{$kennziffer}, 2, '0');
+        
+        $lxdebug->message($LXDebug::DEBUG, "Kennziffer $kennziffer: '$form->{$kennziffer}'" );
+        $lxdebug->dump($LXDebug::DEBUG, $rec_ref );
+        push @ { $form->{USTVA} }, $rec_ref;
       }
+      
     }
-    
-  }
 
-  # end nation specific customisations
+  }
   
   if ( $form->{period} eq '13' and $form->{format} ne 'html') {
     $form->header;
@@ -1050,7 +1061,22 @@ sub generate_ustva {
   $form->{templates} = $myconfig{templates};
   $form->{templates} = "doc" if ( $form->{type} eq 'help' );
 
-  $form->parse_template(\%myconfig, $userspath);
+  if ($form->{format} eq 'generic'){
+
+    $form->header();
+
+    $template_ref = {
+        taxnumber => $myconfig{taxnumber},
+    };
+
+    print($form->parse_html_template2('ustva/generic_taxreport', $template_ref));
+
+  } else
+  { 
+
+    $form->parse_template(\%myconfig, $userspath);
+
+  }
 
   $lxdebug->leave_sub();
 }
@@ -1115,6 +1141,10 @@ sub config_step1 {
         { 'variable' => $variable, 'value' => $form->{$variable} };
   }
 
+# Which COA is in use? 
+  
+  USTVA->get_coa($form, \%myconfig);
+
   # hä? kann die weg?
   my $steuernummer_new = '';
 
@@ -1257,8 +1287,6 @@ sub config_step2 {
     saved                   callback
   );
 
-
-
   foreach my $variable (@_hidden_form_variables) {
     push @{ $_hidden_variables_ref}, 
         { 'variable' => $variable, 'value' => $form->{$variable} };
index 6103e46..c970c9e 100644 (file)
@@ -527,6 +527,7 @@ aktualisieren wollen?',
   'From'                        => 'Von',
   'GL Transaction'              => 'Dialogbuchung',
   'General Ledger'              => 'Finanzbuchhaltung',
+  'Generic Tax Report'          => 'USTVA Bericht',
   'Given Name'                  => 'Vorname',
   'Greeting'                    => 'Anrede',
   'Group'                       => 'Warengruppe',
@@ -543,8 +544,6 @@ aktualisieren wollen?',
   'Help'                        => 'Hilfe',
   'Here\'s an example command line:' => 'Hier ist eine Kommandozeile, die als Beispiel dient:',
   'Hide by default'             => 'Standardm&auml;&szlig;ig verstecken',
-  'Hint-Missing-Preferences'    => 'Bitte fehlende USTVA Einstellungen ergänzen (Menüpunkt: System-> UStVA Einstellungen)',
-  'Hints'                       => 'Hinweise',
   'History'                     => 'Historie',
   'History Search'              => 'Historien Suche',
   'History Search Engine'       => 'Historien Suchmaschine',
@@ -710,7 +709,6 @@ aktualisieren wollen?',
   'Missing \'description\' field.' => 'Fehlendes Feld \'description\'.',
   'Missing \'tag\' field.'      => 'Fehlendes Feld \'tag\'.',
   'Missing Method!'             => 'Fehlender Voranmeldungszeitraum',
-  'Missing Preferences: Outputroutine disabled' => 'Die Ausgabefunktionen sind wegen unzureichender Voreinstellungen deaktiviert!',
   'Missing Tax Authoritys Preferences' => 'Fehlende Angaben zum Finanzamt!',
   'Missing amount'              => 'Fehlbetrag',
   'Mitarbeiter'                 => 'Mitarbeiter',
@@ -851,6 +849,8 @@ aktualisieren wollen?',
   'Please enter a license key.' => 'Bitte geben Sie einen Lizenzschlüssel an.',
   'Please enter a number of licenses.' => 'Bitte geben Sie die Anzahl Lizenzschlüssel an.',
   'Please enter the name of the dataset you want to restore the backup in.' => 'Bitte geben Sie den Namen der Datenbank ein, in der Sie die Sicherung wiederherstellen wollen.',
+  'Please enter the taxnumber in the administration menu userpreferences' => 'Bitte bei den Einstellungen des aktuellen Benutzers im Administrationsmodul
+  angeben.',
   'Please enter values'         => 'Bitte Werte eingeben',
   'Please insert object dimensions below.' => 'Bitte geben Sie die Abmessungen unten ein',
   'Please insert your language values below' => 'Bitte die Übersetzungen unten eintragen',
@@ -1079,6 +1079,7 @@ aktualisieren wollen?',
   'Tax Percent is a number between 0 and 100' => 'Prozentsatz muss zwischen
   1% und 100% liegen',
   'Tax Period'                  => 'Voranmeldungszeitraum',
+  'Tax Position'                => 'Position',
   'Tax collected'               => 'vereinnahmte Steuer',
   'Tax deleted!'                => 'Steuer gelöscht!',
   'Tax number'                  => 'Steuernummer',
@@ -1096,6 +1097,7 @@ aktualisieren wollen?',
   'Taxkey_coa'                  => 'Steuerschlüssel',
   'Taxkeys and Taxreport Preferences' => 'Steuerautomatik und UStVA',
   'Taxlink_coa'                 => 'Steuerautomatik',
+  'Taxnumber'                   => 'Steuernummer',
   'Taxrate missing!'            => 'Prozentsatz fehlt!',
   'Tel'                         => 'Tel',
   'Tel.'                        => 'Telefon',
index 3ff7b9b..9b05b7c 100644 (file)
     <tr>
      <td>
        <br />
+<TMPL_IF COA_Germany>
        <fieldset>
        <legend><b>Angaben zum Finanzamt</b></legend>
        <br />
        <TMPL_VAR select_tax_office>
        </fieldset>
        <br />
-       
+</TMPL_IF>
        <fieldset>
        <legend><b>Versteuerungs Verfahren</b>
        </legend>
index ab985b4..4f5421f 100644 (file)
     <tr>
      <td>
        <br />
+<TMPL_IF COA_Germany>
        <fieldset>
        <legend><b><translate>Local Tax Office Preferences</translate></b></legend>
        <br />
        <TMPL_VAR select_tax_office>
        </fieldset>
        <br />
-       
+</TMPL_IF>
        <fieldset>
        <legend><b><translate>Taxation</translate></b>
        </legend>
index 6f1290b..07c0d26 100644 (file)
            <font size="+1">Steuernummer</font>
            </legend>
            <br>
+<TMPL_IF COA_Germany>
            <TMPL_VAR input_steuernummer>
+<TMPL_ELSE>
+Bitte bei den Einstellungen des aktuellen Benutzers im Administrationsmodul
+  angeben.
+</TMPL_IF>
+
+
            </H2><br>
            </fieldset>
            <br>
index 1ec0294..616a292 100644 (file)
            <font size="+1"><translate>Tax Number</translate></font>
            </legend>
            <br>
+<TMPL_IF COA_Germany>
            <TMPL_VAR input_steuernummer>
+<TMPL_ELSE>
+<translate>Please enter the taxnumber in the administration menu user
+preferences</translate>
+</TMPL_IF>
+
+
            </H2><br>
            </fieldset>
            <br>
diff --git a/templates/webpages/ustva/generic_taxreport_de.html b/templates/webpages/ustva/generic_taxreport_de.html
new file mode 100644 (file)
index 0000000..cf5a021
--- /dev/null
@@ -0,0 +1,26 @@
+[% USE HTML %]<body>
+
+<h1>USTVA Bericht</h1>
+<p>Steuernummer: [% taxnumber %]</p>
+<p>Jahr: [% year %]</p>
+<p>Zeitraum: [% period %]</p>
+<br />
+<table width="33%">
+  <tr>
+    <th>Position</th>
+    <th>Betrag</th>
+  </tr>
+[% SET row_odd = '1' %]
+[% FOREACH row = USTVA %]
+  <tr class="listrow[% IF row_odd %]1[% SET row_odd = '0' %][% ELSE %]0[%
+SET row_odd = '1' %][% END %]">
+
+    <td align="left">[% HTML.escape(row.id) %]</td>
+    <td align="right">[% HTML.escape(row.amount) %]</td>
+  </tr>
+[% END %]
+
+</table>
+
+</html>
+</body>
diff --git a/templates/webpages/ustva/generic_taxreport_master.html b/templates/webpages/ustva/generic_taxreport_master.html
new file mode 100644 (file)
index 0000000..c93a955
--- /dev/null
@@ -0,0 +1,26 @@
+[% USE HTML %]<body>
+
+<h1><translate>Generic Tax Report</translate></h1>
+<p><translate>Taxnumber</translate>: [% taxnumber %]</p>
+<p><translate>Year</translate>: [% year %]</p>
+<p><translate>Period</translate>: [% period %]</p>
+<br />
+<table width="33%">
+  <tr>
+    <th><translate>Tax Position</translate></th>
+    <th><translate>Amount</translate></th>
+  </tr>
+[% SET row_odd = '1' %]
+[% FOREACH row = USTVA %]
+  <tr class="listrow[% IF row_odd %]1[% SET row_odd = '0' %][% ELSE %]0[%
+SET row_odd = '1' %][% END %]">
+
+    <td align="left">[% HTML.escape(row.id) %]</td>
+    <td align="right">[% HTML.escape(row.amount) %]</td>
+  </tr>
+[% END %]
+
+</table>
+
+</html>
+</body>
\ No newline at end of file
index 2411b4d..dd4b75d 100644 (file)
             <TMPL_VAR co_email ESCAPE=HTML>
             <br />
             <br />
+
             Steuernummer:&nbsp;
+<TMPL_IF COA_Germany>
             <TMPL_VAR taxnumber_given>
             <br />
             ELSTER-Steuernummer:&nbsp;
             <TMPL_VAR elstersteuernummer ESCAPE=HTML>
             <br />
             <br />
-
+<TMPL_ELSE>
+            <TMPL_VAR taxnumber>
+</TMPL_IF>
             </fieldset>
             <br />
             
               <fieldset>
               <legend>
                 <input checked="checked" 
-                 title = "Beraterdaten in UStVA übernehmen?"
-                 name = "FA_steuerberater" 
-                 id = "steuerberater" 
-                 class = "checkbox" 
-                 type = "checkbox"
-                 value = "1" >
+                 title="Beraterdaten in UStVA übernehmen?"
+                 name="FA_steuerberater" 
+                 id="steuerberater" 
+                 class="checkbox" 
+                 type="checkbox"
+                 value="1" >
                  &nbsp;<b>Steuerberater/-in</b>
                 </legend>
                 
@@ -91,9 +95,6 @@
             </fieldset>
           </td>
           <td width="50%" valign="top">          
-
-<!--            TMPL_IF FA_Name                   -->
-
               <fieldset>
               <legend>
                  <b>Finanzamt</b>
               <legend>
               <b>Ausgabeformat</b>
               </legend>
+<TMPL_IF COA_Germany>
               <TMPL_VAR select_options>
-              </fieldset>
-              
-            <TMPL_ELSE>
+<TMPL_ELSE>
+              <SELECT name="format">
+                <option value="generic">Druckvorschau</option>
+              </SELECT>
+</TMPL_if>
 
-              <td width="50%" valign="bottom">
-              <fieldset>
-              <legend>
-              <b>Hinweise</b>
-              </legend>
-              <h2 class="confirm">
-              Die Ausgabefunktionen sind wegen unzureichender Voreinstellungen deaktiviert!
-              </h2>
-              <h3>Hilfe</h3>
-              <ul>
-              <li>Bitte fehlende USTVA Einstellungen ergänzen (Menüpunkt: System-> UStVA Einstellungen)</li>
-              </ul>
               </fieldset>
-
-            </TMPL_IF>
           </td>
         </tr>
       </table>
index 9f19553..09ae195 100644 (file)
             <TMPL_VAR co_email ESCAPE=HTML>
             <br />
             <br />
+
             <translate>Tax Number</translate>:&nbsp;
+<TMPL_IF COA_Germany>
             <TMPL_VAR taxnumber_given>
             <br />
             <translate>ELSTER Tax Number</translate>:&nbsp;
             <TMPL_VAR elstersteuernummer ESCAPE=HTML>
             <br />
             <br />
-
+<TMPL_ELSE>
+            <TMPL_VAR taxnumber>
+</TMPL_IF>
             </fieldset>
             <br />
             
               <fieldset>
               <legend>
                 <input checked="checked" 
-                 title = "<translate>Assume Tax Consultant Data in Tax Computation?</translate>"
-                 name = "FA_steuerberater" 
-                 id = "steuerberater" 
-                 class = "checkbox" 
-                 type = "checkbox"
-                 value = "1" >
+                 title="<translate>Assume Tax Consultant Data in Tax Computation?</translate>"
+                 name="FA_steuerberater" 
+                 id="steuerberater" 
+                 class="checkbox" 
+                 type="checkbox"
+                 value="1" >
                  &nbsp;<b><translate>Tax Consultant</translate></b>
                 </legend>
                 
@@ -91,9 +95,6 @@
             </fieldset>
           </td>
           <td width="50%" valign="top">          
-
-<!--            TMPL_IF FA_Name                   -->
-
               <fieldset>
               <legend>
                  <b><translate>Tax Office</translate></b>
               <legend>
               <b><translate>Outputformat</translate></b>
               </legend>
+<TMPL_IF COA_Germany>
               <TMPL_VAR select_options>
-              </fieldset>
-              
-            <TMPL_ELSE>
+<TMPL_ELSE>
+              <SELECT name="format">
+                <option value="generic"><translate>Preview</translate></option>
+              </SELECT>
+</TMPL_if>
 
-              <td width="50%" valign="bottom">
-              <fieldset>
-              <legend>
-              <b><translate>Hints</translate></b>
-              </legend>
-              <h2 class="confirm">
-              <translate>Missing Preferences: Outputroutine
-                 disabled</translate>
-              </h2>
-              <h3><translate>Help</translate></h3>
-              <ul>
-              <li><translate>Hint-Missing-Preferences</translate></li>
-              </ul>
               </fieldset>
-
-            </TMPL_IF>
           </td>
         </tr>
       </table>