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 Rechnungs 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
RechungsbetragRechnungsbetrag
{$NetTotal}
string
RechungsbetragRechnungsbetrag
{$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
Auftrags-CodeAuftragscode (berücksichtigt aus dendem individuellen Code)
{$Rechungscode}
string
6-Stelligerstelliger Auftrags-CodeAuftragscode
{$ustid}
string
UmsatzstreuerUmsatzsteuer-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 BEstellcodeBestellcode:

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

	

...

Codeblock
languageactionscript3
titleBenutzer der Bestellung / Besteller
collapsetrue
Für eine Bestellung kann der Benutzer über das Bestelldaten-ObjektBestelldatenobjekt abgefragt werden. 
Hinweis: Mit dieser Variablen erfolgt eine Live-AbfrageLiveabfrage auf die Benutzer-TabelleBenutzertabelle, sollte der Benutzer entfernt worden sein, gibt die Variable "false" zurück.

VARIABLE:
{if $orderObject->getCustomerUser()}
<KundennumerBesteller>{$orderObject->getCustomerUser()->get('customer_user_kundennummer')}</KundennumerBesteller>
{/if} 

...

Codeblock
languageactionscript3
titleBenutzergruppe der BestellungNur freigegebene Positionen berücksichtigen
collapsetrue
FürWird einedie BestellungVariable kann die Benutzergruppe über das Bestelldaten-Objekt abgefragt werden. 
Hinweis: Mit dieser Variablen erfolgt eine Live-Abfrage auf die Benutzergruppen-Tabelle, sollte die Benutzergruppe entfernt worden sein gibt die Variable "false" zurück.

VARIABLE:
{if $orderObject->getCustomerUser() && $orderObject->getCustomerUser()->getBudgetgroup()}
<BezeichnungBenutzergruppe>{$orderObject->getCustomerUser()->getBudgetgroup()->get('bezeichnung')}</BezeichnungBenutzergruppe>
<KundennummerBenutzergruppe>{$orderObject->getCustomerUser()->getBudgetgroup()->get('kundennummer')}</KundennummerBenutzergruppe>
{/if} 

	{$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
titlePersonalisierungsfelderBenutzergruppe der Bestellung
collapsetrue
InnerhalbFür dereine folgendenBestellung kann Abfragedie werdenBenutzergruppe dieüber Warenkorbpositionen durchlaufen:
{foreach key=key item=item from=$orderObject->getOrderCart()}
{/foreach}

setzen Sie die Abfrage für die Personalisierungsfelder ein.
{if $item->getPersData()}
  	{foreach key=name item=value from=$item->getPersData()}
    	{$name}: {$value}<br>
  	{/foreach}
{/if}

Beispiel:
{foreach key=key item=item from=$orderObject->getOrderCart()}
	{if $item->getPersData()}
  		{foreach key=name item=value from=$item-das Bestelldaten-Objekt abgefragt werden. 
Hinweis: Mit dieser Variablen erfolgt eine Live-Abfrage auf die Benutzergruppen-Tabelle, sollte die Benutzergruppe entfernt worden sein, gibt die Variable "false" zurück.

VARIABLE:
{if $orderObject->getCustomerUser() && $orderObject->getCustomerUser()->getBudgetgroup()}
<BezeichnungBenutzergruppe>{$orderObject->getCustomerUser()->getBudgetgroup()->get('bezeichnung')}</BezeichnungBenutzergruppe>
<KundennummerBenutzergruppe>{$orderObject->getCustomerUser()->getBudgetgroup()->get('kundennummer')}</KundennummerBenutzergruppe>
{/if} 

	


Codeblock
languageactionscript3
titlePersonalisierungsfelder
collapsetrue
Innerhalb der folgenden Abfrage werden die Warenkorbpositionen durchlaufen:
{foreach key=key item=item from=$orderObject->getOrderCart()}
{/foreach}

setzen Sie die Abfrage für die Personalisierungsfelder ein.
{if $item->getPersData()}
  	{foreach key=name 		item=value from=$item->getPersData()}
    	{$name}: {$value}<br>
  		{/foreach}
	{/if}

Beispiel:
{/foreach} 
	
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>
 key=key item=item from=$orderObject->getOrderCart()}
	{if $item->getPersData()}
  		{foreach key=name item=value from=$item->getPersData()}
    		{$name}: {$value}<br>
  		{/foreach}
	{/if}
{/foreach}

	


Codeblock
languageactionscript3
titleAttribute / Zusatzfelder
collapsetrue
Innerhalb der folgenden Abfrage werden die Warenkorbpositionen durchlaufen:
{section name=item loop=$cart}
{/section}

setzen Sie die Abfrage für die Zusatzfelder / Attribute ein.
{if $cart[item].attributes}
  	{foreach key=name item=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
titleID der Preisstaffel (Versandkosten)
collapsetrue
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}</AdditionalId>
	<AdditionalValueId>{$option->dynamicOptionValueAdditionalId}</AdditionalValueId>
</DynamicOption>
{/foreach}


Beispiele CSV-Export:

Codeblock
titleCSV
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' => <size>{$file.size}</size>
 			<type>{$file.path}</type>
		</file>
	{/foreach}
	</files>
{/foreach}$orderItem.filename,
        'auftrags_datum' => $orderObject->get('cdate'),
        'kunde' 
Codeblock
languageactionscript3
titleID der Preisstaffel (Versandkosten)
collapsetrue
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}

Beispiele XML Export:

Codeblock
titleXML
linenumberstrue
collapsetrue
{if $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[] = [=> $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'ID der Bestellposition' => $orderItem.id=> $orderObject->get('InvoiceAdressStreet'),
        'Lieferanschrift UnternehmenInvoiceAdressZIP' => $orderObject->get('order_DeliverAdressCompanyInvoiceAdressZIP'),
        'Lieferanschrift Unternehmen 2InvoiceAdressTown' => $orderObject->get('order_DeliverAdressCompany2InvoiceAdressTown'),
        'Lieferanschrift Anschriftpreis_netto' => $orderObject->get('order_DeliverAdressName')$orderItem.s_total,
        'Lieferanschrift Ansprechpartner Vornamemwst' => $orderObject->get('order_DeliverAdressFirstname')$orderItem.s_mwst,
        'Lieferanschrift Ansprechpartner Nachnamepersdata' => $orderObject->get('order_DeliverAdressLastname')$orderItem.persdata,
        'Lieferanschrift Ansprechpartner Straßebesteller' => $orderObject->get('order_DeliverAdressStreetcustomer_user_id'),
        'Lieferanschrift Ansprechpartner PLZmd5' => $orderObject->get('order_DeliverAdressZIP')$orderItem.md5,
        'Lieferanschrift Ansprechpartner Stadt'auftragsbezeichnung' => $orderObject->get('order_DeliverAdressTowncode'),
        'Lieferanschrift Ansprechpartner E - Mail'articletyp' => $orderItem.article_type,
        'sap_number' => $orderObject->get('order_DeliverAdressEMail')$orderItem.article_sap_nummer,
        'Artikelnummercostcenter' => $orderItem.article_desc_intern$orderObject->getCustomerUser()->get('customer_user_costcenter'),
        'stueckzahlkundennummer' => $orderItem.s_qty$orderObject->getCustomerUser()->get('customer_user_kundennummer'),
        'aussendienstnummerbudgetgruppenid' => 0$orderObject->get('order_budgetgruppen_user_id'),
        'pdflieferadresse_nameansprechpartner' => $orderItem.filename $orderObject->get('order_DeliverAdressName'),
        'auftragsrechnungsadresse_datumansprechpartner' => $orderObject->get('cdateInvoiceAdressName'),
        'kundezahlungsart' => $orderObject->getCustomer()->get('customer_company') $payment_desc,
        'zahlungsart_preis' => $payment_price,
        'kundenidversandkosten' => $orderObject->getCustomer()->get('idversandkosten'),
        'artikelidremark' => $orderItem.aidremark,
        'InvoiceAdressCompany1auftragsname' => $orderObject->get('InvoiceAdressCompany1')$orderItem.jobname,
        'InvoiceAdressCompany2costcenterCart' => $orderObject->get('InvoiceAdressCompany2')$orderItem.cstctr,
        'InvoiceAdressNameprice_total' => $orderObject->get('InvoiceAdressNamebrutto'),
        'InvoiceAdressStreetcountry_code' => $orderObject->get('InvoiceAdressStreetorder_DeliverAdressCountryCode'),
        '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'),]}{/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}
    {foreach key=key item=item from=$cart}
        {if $item.zipDownloadUrl}
            <url>{$item.zipDownloadUrl}</url>
        {/if}
    {/foreach}
{/if}

{*Version 2*}
{if $orderItems}
    {foreach key=key item=item from=$orderItems}
         'lieferadresse_ansprechpartner' => $orderObject->get('order_DeliverAdressName'),{if $item.orderItem.zipDownloadUrl}
          'rechnungsadresse_ansprechpartner' => $orderObject->get('InvoiceAdressName'), <url>{$item.orderItem.zipDownloadUrl}</url>
        'zahlungsart' => $payment_desc,{else}
            'zahlungsart_preis' => $payment_price,<nourl items/>
        {/if}
 'versandkosten' => $orderObject->get('versandkosten'),
     {/foreach}
{else} {*Posten bezogener Export*}
   'remark' => {if $orderItem.remark,zipDownloadUrl}
        'auftragsname' => $orderItem.jobname,<url>{$orderItem.zipDownloadUrl}</url>
    {else}
   'costcenterCart' => $orderItem.cstctr,   <nourl      'price_total' => $orderObject->get('brutto'),item />
    {/if}
{/if}


Codeblock
languageactionscript3
firstline0
titleReseller Artikel Informationen
collapsetrue
{foreach key=key item=value  'country_code' => $orderObject->get('order_DeliverAdressCountryCode')
    ]}{/foreach}{array_keys($exportColumns[0])|implode:';'}
{foreach from=$exportColumns item=row}{$row|implode:';'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}
{/foreach}