Projekt

Allgemein

Profil

« Zurück | Weiter » 

Revision 51c76e20

Von Johannes Grassler vor etwa 1 Jahr hinzugefügt

  • ID 51c76e20e31eab9eb92dccb76cffc3ce20592558
  • Vorgänger 19299547
  • Nachfolger 1fd17b36

ZUGFeRD-Import: verschiedene behoben

  • Fehlermeldung bei nicht gefundener UStID/Steuernummer verbessert.
  • Interpolation von Lieferantenname in Buchungsvorlagenname repariert.
  • Tippfehler bei SL::DB::ManagerTax->get_all behoben.
  • Fehlermeldung bei unbekanntem XML-Wurzelelement repariert.
  • Suche nach fehlenden Elementen in $self->_data_keys mit grep
  • Fehlermeldung "Parsing the XML data failed" repariert

Unterschiede anzeigen:

SL/Controller/ZUGFeRD.pm
167 167

  
168 168
  $vendor = find_vendor($metadata{'ustid'}, $metadata{'taxnumber'});
169 169

  
170
  die t8("Please add a valid VAT ID or tax number for this vendor: #1", $metadata{'vendor_name'}) unless $vendor;
170
  die t8("Vendor with VAT ID (#1) and/or tax ID (#2) not found. Please check if the vendor " .
171
          "#3 exists and whether it has the correct tax ID/VAT ID." ,
172
           $metadata{'ustid'},
173
           $metadata{'taxnumber'},
174
           $metadata{'vendor_name'},
175
  ) unless $vendor;
171 176

  
172 177

  
173 178
  # Create a record template for this imported invoice
......
216 221
    );
217 222

  
218 223
  $template_ap->assign_attributes(
219
    template_name       => "Faktur-X/ZUGFeRD/XRechnung Import $vendor->name, $invnumber",
224
    template_name       => t8("Faktur-X/ZUGFeRD/XRechnung import #1, #2", $vendor->name, $invnumber),
220 225
    template_type       => 'ap_transaction',
221 226
    direct_debit        => $metadata{'direct_debit'},
222 227
    notes               => "Faktur-X/ZUGFeRD/XRechnung Import. Type: $metadata{'type'}\nIBAN: " . $ibanmessage,
......
248 253
    # be sufficient for that to happen), grab the first tax fitting the default
249 254
    # category, just like the AP form would do it for manual entry.
250 255
    if ( scalar @{$taxes} == 0 ) {
251
      $taxes = SL::D::ManagerTax->get_all(
256
      $taxes = SL::DB::Manager::Tax->get_all(
252 257
        where   => [ chart_categories => { like => '%' . $default_ap_amount_chart->category . '%' } ],
253 258
      );
254 259
    }
SL/XMLInvoice.pm
5 5

  
6 6
use XML::LibXML;
7 7

  
8
use SL::XMLInvoice::UBL;
9
use SL::XMLInvoice::CrossIndustryInvoice;
8
require SL::XMLInvoice::UBL;
9
require SL::XMLInvoice::CrossIndustryInvoice;
10 10

  
11 11
use constant RES_OK => 0;
12 12
use constant RES_XML_PARSING_FAILED => 1;
......
92 92

  
93 93
=cut
94 94

  
95
sub data_keys  {
95
sub data_keys {
96 96
  my @keys = (
97 97
    'currency',      # The bill's currency, such as "EUR"
98 98
    'direct_debit',  # Boolean: whether the bill will get paid by direct debit (1) or not (0)
......
267 267
  $self->{dom} = eval { XML::LibXML->load_xml(string => $xml_data) };
268 268

  
269 269
  if ( ! $self->{dom} ) {
270
    $self->{message} = $::locale->text("Parsing the XML data failed: $xml_data");
270
    $self->{message} = t8("Parsing the XML data failed: #1", $xml_data);
271 271
    $self->{result} = RES_XML_PARSING_FAILED;
272 272
    return $self;
273 273
  }
......
280 280

  
281 281
  unless ( $type ) {
282 282
    $self->{result} = RES_UNKNOWN_ROOT_NODE_TYPE;
283
    my $node_types = keys %{ $self->_document_nodenames };
283
    my $node_types = join(",", keys %{ $self->_document_nodenames });
284 284
    $self->{message} =  t8("Could not parse XML Invoice: unknown root node name (#1) (supported: (#2))",
285
                           $document_nodename,
285 286
                           $node_types,
286
                           $document_nodename);
287
                        );
287 288
    return $self;
288 289
  }
289 290

  
......
291 292

  
292 293
  # Implementation sanity check for child classes: make sure they are aware of
293 294
  # the keys the hash returned by their metadata() method must contain.
294
  my @missing_data_keys = grep { !${$self->_data_keys}{$data_key} } @{ $self->data_keys };
295
  my @missing_data_keys = grep { !${$self->_data_keys}{$_} } @{ $self->data_keys };
295 296
  if ( scalar(@missing_data_keys) > 0 ) {
296 297
    die "Incomplete implementation: the following metadata keys appear to be missing from $type: " . join(", ", @missing_data_keys);
297 298
  }
locale/de/all
1710 1710
  'Factur-X/ZUGFeRD invoice'    => 'Factur-X-/ZUGFeRD-Rechnung',
1711 1711
  'Factur-X/ZUGFeRD notes for each invoice' => 'Factur-X-/ZUGFeRD-Notizen für jede Rechnung',
1712 1712
  'Factur-X/ZUGFeRD settings'   => 'Factur-X-/ZUGFeRD-Einstellungen',
1713
  'Faktur-X/ZUGFeRD/XRechnung import #1, #2' => 'Faktur-X/ZUGFeRD/XRechnung-Import #1, #2',
1713 1714
  'Fax'                         => 'Fax',
1714 1715
  'Features'                    => 'Features',
1715 1716
  'Feb'                         => 'Feb',
......
2727 2728
  'Paid'                        => 'bezahlt',
2728 2729
  'Paid amount'                 => 'Bezahlter Betrag',
2729 2730
  'Parameter module must be given.' => 'Der Parameter "module" miss angegeben werden.',
2731
  'Parsing the XML data failed: #1' => 'Parsen der XML-Daten fehlgeschlagen: #1',
2730 2732
  'Parsing the XMP metadata failed.' => 'Parsen der XMP-Metadaten schlug fehl.',
2731 2733
  'Part'                        => 'Ware',
2732 2734
  'Part "#1" has chargenumber or best before date set. So it cannot be transfered automatically.' => 'Bei Artikel "#1" ist eine Chargenummer oder ein Mindesthaltbarkeitsdatum vergeben. Deshalb kann dieser Artikel nicht automatisch ausgelagert werden.',

Auch abrufbar als: Unified diff