Versionen im Vergleich

Schlüssel

  • Diese Zeile wurde hinzugefügt.
  • Diese Zeile wurde entfernt.
  • Formatierung wurde geändert.

In der Administration kann unter Verwaltung → Shops → bearbeiten → Rechungserstellung die Rechnungserstellung pro Shop aktiviert werden. Hierfür muss die Vorlage befüllt werden. Bitte alten die die Mustervorlage und speichern Sie Ihre Änderungen ab. Die Rechnung ist somit aktiviert und wird an den jeweils eingestellten Stellen angezeigt/ausgegeben.


Inhalt

Variablen

Folgende Variablen stehen in der Rechnungsvorlage zur Verfügung:

...

VariableTypBeschreibung
{$CurrencySymbol} 
string
Währungssymbol
{$cart} 
array
Warenkorb
{$serviceprovider}
array
Dienstleister
{$PaymentId}
int
Zahlungsart-Id
{$PaymentMethod}
string
Bezeichung der Zahlungsart
{$Payment}
array
Zahlungsart (Live)
{$arr_paymentfelder}
array
Zusatzfelder Zahlungsart
{$orderTotalShipping}
float
Summe der Bestellung inkl. Versandkosten
{$orderTotalWithoutShipping}
float
Summe der Bestellung exkl. Versandkosten
{$orderTotal}
float
Summe der Bestellung exkl. Versandkosten
{$Versandkosten}
array
Versandkosten
{$Total}
string
Rechnungsbetrag
{$NetTotal}
string
Rechnungsbetrag
{$VAT}
string
MwSt.
{$Kunde} 
array
Daten des Benutzers (live)
{$Kundendaten} 
array
Daten des Benutzers (live)
{$Bestelldaten} 
array
Bestelldaten
{$Firma1}
string
Lieferadresse: Firma
{$InvoiceCompany}
string
Lieferadresse: Firma
{$LieferadresseFirma}
string
Lieferadresse: Firma
{$Firma2}
string
Lieferadresse: Firma 2
{$InvoiceCompany2}
string
Lieferadresse: Firma 2
{$Ansprechpartnter}
string
Lieferadresse: Ansprechpartner
{$Strasse}
string
Lieferadresse: Straße
{$PLZ}
string
Lieferadresse: PLZ
{$Ort}
string
Lieferadresse: Ort
{$Kostenstelle}
string
Kostenstelle
{$RechnungsadresseFirma}
string
Rechnungsadresse: Firma
{$RechnungsadresseFirma2}
string
Rechnungsadresse: Firma 2
{$RechnungsadresseAnsprechpartnter}
string
Rechnungsadresse: Ansprechpartner
{$RechnungsadresseStrasse}
string
Rechnungsadresse: Straße
{$RechnungsadressePLZ}
string
Rechnungsadresse: PLZ
{$RechnungsadresseOrt}
string
Rechnungsadresse: Ort
{$RechnungsadresseCountry}
string
Rechnungsadresse: Land
{$Bestellcode}
string
Auftragscode (berücksichtigt aus dem individuellen Code)
{$Rechungscode}
string
6-stelliger Auftragscode
{$ustid}
string
Umsatzsteuer-Id
{$ShopURL}
string
Shop URL
{$orderObject}
object
Bestelldaten 
{$cart} (Version 1)arrayBestellpositionen
{$orderItems} (Version 2)arrayBestellpositionen
{$orderItem} (Version 2)arrayBestellposition (pro Posten)



Beispiele


Codeblock
languageactionscript3
titleBestellcode
collapsetrue
Für eine Bestellung kann der Bestellcode in die XML-Vorlage wie folgt eingesetzt werden. Diese Variable unterstützt auch die Funktion dynamischer Bestellcode:

VARIABLE
<OrderCode>{$orderObject->getOrderCode()}</OrderCode>

	

...

Codeblock
languageactionscript3
titleNur freigegebene Positionen berücksichtigen
collapsetrue
Wird die Variable {$cart} verwendet, muss nichts beachtet werden, da diese die abgelehnten Artikel gar nicht berücksichtigt.
{foreach key=key item=item from=$cart}
	{if $item['aid'] > 0}
		Artikelbezeichnung: {$item['s_desc']}
	{/if}
{/foreach}


Bei Verwendung von $orderObject->getOrderCart(), werden grundsätzlich alle Positionen durchlaufen.Dabei müssen die Positionen mit dem nicht gewollten Status übersprungen werden.


{foreach key=key item=item from=$orderObject->getOrderCart()}
	{if $item->get('status') != 'OK' && $item->get('status') != 'PACKED' && $item->get('status') != 'SHIPPED'}
		{continue}
	{/if}

	{if $item->get('aid') > 0}
		Artikelbezeichnung: {$item->get('s_desc')}
	{/if}
{/foreach}

...

Codeblock
languageactionscript3
titleDateien eines BestellpostensAttribute / Zusatzfelder
collapsetrue
Innerhalb der folgenden Abfrage werden die DateienWarenkorbpositionen einer Warenkorbposition durchlaufen:
{foreachsection from=$orderCartObject->getFiles() item="file"name=item loop=$cart}
{/foreachsection}

Beispiel:setzen {foreach key=key item=item from=$orderObject->getOrderCart()} 
	<files>Sie die Abfrage für die Zusatzfelder / Attribute ein.
{if $cart[item].attributes}
  	{foreach from=$item->getFiles()key=name item="file"}
		<file>
			<id>{$file.name}</id>
			<name>{$file.name}</name>
            <filename>{$file.filename}</filename>
			<filenameRenamed>{$file.filenameRenamed}</filenameRenamed>
			<path>{$file.path}</path>
            <size>{$file.size}</size>
 			<type>{$file.path}</type>
		</file>
	{/foreach}
	</files>
{/foreach} 






Codeblock
languageactionscript3
titleID der Preisstaffel (Versandkosten)
collapsetrue
Die Preisstaffel-ID der Versandkosten lässt sich mit der folgenden Variable ausgeben:
{$Versandkosten.preisstaffelId}=value from=$cart[item].attributes}
    	{$name}: {$value}<br>
  	{/foreach}
{/if}
	


Codeblock
languageactionscript3
titleDateien eines Bestellpostens
collapsetrue
Innerhalb der folgenden Abfrage werden die Dateien einer Warenkorbposition durchlaufen:
{foreach from=$orderCartObject->getFiles() item="file"}
{/foreach}

Beispiel:
{foreach key=key item=item from=$orderObject->getOrderCart()} 
	<files>
	{foreach from=$item->getFiles() item="file"}
		<file>
			<id>{$file.name}</id>
			<name>{$file.name}</name>
            <filename>{$file.filename}</filename>
			<filenameRenamed>{$file.filenameRenamed}</filenameRenamed>
			<path>{$file.path}</path>
            <size>{$file.size}</size>
 			<type>{$file.path}</type>
		</file>
	{/foreach}
	</files>
{/foreach} 







Codeblock
languageactionscript3
titleName des FreigebersID der Preisstaffel (Versandkosten)
collapsetrue
Der Die Preisstaffel-ID der Versandkosten lässt sich mit der folgenden Variable ausgeben:
{$Versandkosten.preisstaffelId}


Codeblock
languageactionscript3
titleName des Freigebers
collapsetrue
Der Name des Freigebers kann innerhalb einer Schleife der Positionen im Warenkorb wie folgt ausgegeben werden:
{foreach from=$cart item=orderItem}
	{$orderItem.releaseRecipientName}
{/foreach}

...

Codeblock
languageactionscript3
titleID der dynamischen Optionen
collapsetrue
Die ID der dynamischen Optionen kann innerhalb einer Schleife der Positionen im Warenkorb wie folgt ausgegeben werden:
{assign var="dynamicOptions" value=$item->getInfo('dynamicOptions')|json_decode}
{foreach from=$dynamicOptions item=option}
<DynamicOption>
	<DynamicOptionId>{$option->dynamic_option_id}</DynamicOptionId>
	<DynamicOptionValueId>{$option->dynamic_option_value_id}</DynamicOptionValueId>
	<AdditionalId>{$option->dynamicOptionAdditionalId}</DynamicOption>AdditionalId>
{/foreach	<AdditionalValueId>{$option->dynamicOptionValueAdditionalId}</AdditionalValueId>
</DynamicOption>
{/foreach}


Beispiele XMLCSV-Export:

Codeblock
titleXMLCSV
linenumberstrue
collapsetrue
{if $orderObject && $orderObject->getPayment()}
{assign value=$orderObject->getPayment()->get('payment_desc') var="payment_desc"}
{assign value=$orderObject->getPayment()->get('price') var="payment_price"}
{/if}

{$exportColumns = array()}{foreach from=$cart item=orderItem}{$exportColumns[] = [
        'ID der Bestellposition' => $orderItem.id,
        'Lieferanschrift Unternehmen' => $orderObject->get('order_DeliverAdressCompany'),
        'Lieferanschrift Unternehmen 2' => $orderObject->get('order_DeliverAdressCompany2'),
        'Lieferanschrift Anschrift' => $orderObject->get('order_DeliverAdressName'),
        'Lieferanschrift Ansprechpartner Vorname' => $orderObject->get('order_DeliverAdressFirstname'),
        'Lieferanschrift Ansprechpartner Nachname' => $orderObject->get('order_DeliverAdressLastname'),
        'Lieferanschrift Ansprechpartner Straße' => $orderObject->get('order_DeliverAdressStreet'),
        'Lieferanschrift Ansprechpartner PLZ' => $orderObject->get('order_DeliverAdressZIP'),
        'Lieferanschrift Ansprechpartner Stadt' => $orderObject->get('order_DeliverAdressTown'),
        'Lieferanschrift Ansprechpartner E - Mail' => $orderObject->get('order_DeliverAdressEMail'),
        'Artikelnummer' => $orderItem.article_desc_intern,
        'stueckzahl' => $orderItem.s_qty,
        'aussendienstnummer' => 0,
        'pdf_name' => $orderItem.filename,
        'auftrags_datum' => $orderObject->get('cdate'),
        'kunde' => $orderObject->getCustomer()->get('customer_company'),
        'kundenid' => $orderObject->getCustomer()->get('id'),
        'artikelid' => $orderItem.aid,
        'InvoiceAdressCompany1' => $orderObject->get('InvoiceAdressCompany1'),
        'InvoiceAdressCompany2' => $orderObject->get('InvoiceAdressCompany2'),
        'InvoiceAdressName' => $orderObject->get('InvoiceAdressName'),
        'InvoiceAdressStreet' => $orderObject->get('InvoiceAdressStreet'),
        'InvoiceAdressZIP' => $orderObject->get('InvoiceAdressZIP'),
        'InvoiceAdressTown' => $orderObject->get('InvoiceAdressTown'),
        'preis_netto' => $orderItem.s_total,
        'mwst' => $orderItem.s_mwst,
        'persdata' => $orderItem.persdata,
        'besteller' => $orderObject->get('order_customer_user_id'),
        'md5' => $orderItem.md5,
        'auftragsbezeichnung' => $orderObject->get('order_code'),
        'articletyp' => $orderItem.article_type,
        'sap_number' => $orderItem.article_sap_nummer,
        'costcenter' => $orderObject->getCustomerUser()->get('customer_user_costcenter'),
        'kundennummer' => $orderObject->getCustomerUser()->get('customer_user_kundennummer'),
        'budgetgruppenid' => $orderObject->get('order_budgetgruppen_user_id'),
        'lieferadresse_ansprechpartner' => $orderObject->get('order_DeliverAdressName'),
        'rechnungsadresse_ansprechpartner' => $orderObject->get('InvoiceAdressName'),
        'zahlungsart' => $payment_desc,
        'zahlungsart_preis' => $payment_price,
        'versandkosten' => $orderObject->get('versandkosten'),
        'remark' => $orderItem.remark,
        'auftragsname' => $orderItem.jobname,
        'costcenterCart' => $orderItem.cstctr,
        'price_total' => $orderObject->get('brutto'),
        'country_code' => $orderObject->get('order_DeliverAdressCountryCode')
    ]}{/foreach}{array_keys($exportColumns[0])|implode:';'}
{foreach from=$exportColumns item=row}{$row|implode:';'}
{/foreach}


Codeblock
languageactionscript3
title Adressliste für Liefer- und Rechnungsdaten - AddressListForCart
collapsetrue
{assign value=$orderObject->getOrderInfo('AddressListForCart-delivery_address_list') var="deliveryAddressListValues"}
{if !is_array($deliveryAddressListValues)}
    {assign value=[] var="deliveryAddressListValues"}
{/if}
{assign value=$orderObject->getOrderInfo('AddressListForCart-invoice_address_list') var="invoiceAddressListValues"}
{if !is_array($invoiceAddressListValues)}
    {assign value=[] var="invoiceAddressListValues"}
{/if}

...

Rechnungsadresseliste Adressnummer: {if isset($invoiceAddressListValues['Adressnummer'])}{$invoiceAddressListValues['Adressnummer']}{/if}
Lieferadresseliste Kundennummer: {if isset($deliveryAddressListValues['Kundennummer'])}{$deliveryAddressListValues['Kundennummer']}{/if}


Codeblock
languageactionscript3
titlezipDownloadUrl
collapsetrue
{*Version 1*}
{if $cart}
    'auftragsname'{foreach key=> $orderItem.jobname,
key item=item from=$cart}
       'costcenterCart' => $orderItem.cstctr, {if $item.zipDownloadUrl}
        'price_total' => $orderObject->get('brutto'),
    <url>{$item.zipDownloadUrl}</url>
     'country_code' => $orderObject->get('order_DeliverAdressCountryCode')
    ]}{/foreach}{array_keys($exportColumns[0])|implode:';'}
{foreach from=$exportColumns item=row}{$row|implode:';'if}
    {/foreach}
{/foreach}
Codeblock
languageactionscript3
titlezipDownloadUrl
collapsetrue
if}

{*Version 12*}
{if $cart$orderItems}
    {foreach key=key item=item from=$cart$orderItems}
        {if $item.orderItem.zipDownloadUrl}
            <url>{$item.zipDownloadUrl}</url>.orderItem.zipDownloadUrl}</url>
        {else}
            <nourl items/>
        {/if}
    {/foreach}
{/ifelse}
 {*VersionPosten bezogener 2*}
{if $orderItems}
    {foreach key=key item=item from=$orderItems}
   Export*}
    {if $item.orderItem$orderItem.zipDownloadUrl}
   
        <url>{$item.orderItem$orderItem.zipDownloadUrl}</url>
   
    {else}
        <nourl    <nourlitem items/>
   
    {/if}
   
{/foreach}
{else} {*Posten bezogener Export*}
    {if $orderItem.zipDownloadUrl}
        <url>{$orderItem.zipDownloadUrl}</url>
    {else}
        <nourl item />
    if}


Codeblock
languageactionscript3
firstline0
titleReseller Artikel Informationen
collapsetrue
{foreach key=key item=value from=$orderItem.info}
	{if $key === 'printwarehouseArticleSettings'}
		{assign var=object value=$value|json_decode:1}
		Preis: {$object.price|number_format:2:',':'.'} €<br>
		{foreach key=name item=setting from=$object.settings}
			{$setting['name']}:{$setting['value']}<br>
		{/foreach}
	{/if}
{/ifforeach}