Inaktiv Druckvorlage Preisliste mit Sonderpreis

RainerR

Aktives Mitglied
10. September 2016
44
2
Hallo,
ich versuche eine Druckvorlage "Preisliste" mit der Spalte Sonderpreis zu erstellen.
Leider ohne Erfolg. Ich finde innerhalb der "Daten und Funktionen" keine Variablen für Sonderpreise.
Bei den Artikeletiketten geht das. Bei einer Preisliste nicht.
Was mache ich falsch - wer kenn helfen?
Vielen Dank im Voraus.
MfG
Rainer
 

gutberle

Sehr aktives Mitglied
29. März 2011
1.295
405
Du machst gar nichts falsch, die Variable gibt es schlicht nicht. - Man kann sich die Daten aber mit einer JTL_DirectQuery() direkt aus der Datenbank holen und - letztlich - schwer ist das nicht.
Ich bin die nächsten drei Tage geschäftlich unterwegs und kann für nichts garantieren, aber spätestens Mittwoch kann ich Dir hier helfen, sorry früher geht leider nicht....
 

gutberle

Sehr aktives Mitglied
29. März 2011
1.295
405
Hallo Rainer,

ok, "Hilfe bis Mittwoch" war dann doch zu ehrgeizig, aber jetzt bin ich endlich dazu gekommen und hier ist meine Anleitung zum Einfügen von Sonderpreisen in die Preisliste ...

Wie oben schon gesagt, werden Sonderpreise leider nicht mit an die Preislisten-Vorlage übergeben, man muß sie sich also selbst aus der Datenbank holen. Das macht man mit einem JTL_DirectQuery() Befehl, dem man ein SQL Statement mit auf den Weg gibt und man bekommt dann den gewünschten Wert zurück. Diesen Rückgabewert kann man dann wie einen normalen Text, Zahlen- oder Währungswert weiterverarbeiten, z.B. auch so formatieren, wie es sich für Deutschland gehört. Das habe ich hier gleich noch mit erledigt und der gesamte Befehle sieht dann so aus...
Code:
LocCurrL$(Val(JTL_DirectQuery("SELECT fNettoPreis FROM tSonderpreise JOIN tArtikelSonderpreis ON tArtikelSonderpreis.kArtikelSonderpreis=tSonderpreise.kArtikelSonderpreis JOIN tKundenGruppe ON tKundenGruppe.kKundenGruppe=tSonderpreise.kKundenGruppe WHERE tArtikelSonderpreis.nAktiv=1 AND tKundenGruppe.cName='"+Vorgang.Kundengruppendetails.Name+"' AND tArtikelSonderpreis.kArtikel="+ToString$(Preislistenartikel.InterneArtikelnummer))),"de-DE")

... und wenn Du Dir den Befehl einmal genau anschaust, dann siehst Du, dass an zwei Stellen "Unterbrechungen" im SQL Code sind, nämlich dort, wo die aktuelle Kundengruppe über Vorgang.Kundengruppendetails.Name und später dann die aktuelle (interne) Artikelnummer mit Preislistenartikel.InterneArtikelnummer übergeben werden. Das sind also sozusagen die Variablen, die für jeden Artikel neu bestimmt und mit übergeben werden.

Damit jetzt aber nicht so ein Trum von Befehl in Deiner Tabelle steht, habe ich noch einen Trick angewandt und habe im Bereich Projekt (oben im Fenster) eine Benutzervariable namens @SonderPreis angelegt und habe den obenstehenden Code dort als Inhalt von @SonderPreis abgelegt. Das sieht dann so aus...

JTLWawi_PreislisteSonderpreise_BenutzerVariable.png

Das führt dazu, dass jedesmal, wenn Du in Deiner Tabelle in einer Spalte den Wert @SonderPreis eingibst, die Benutzervariable neu aus der Datenbank geladen und Dir der Sonderpreis des aktuellen Artikels zurückgegeben wird, oder eben 0,00€, falls kein Sonderpreis existiert oder einer existierte, aber schon wieder inaktiv ist. Das sieht dann in der Tabelle mit Deinen Artikelpositionen so aus...

JTLWawi_PreislisteSonderpreise_PreislistenZeile.png

Ich habe hierfür einfach eine Preislistenvorlage im "Standard" Format genommen und den Barcode rausgeschmissen, damit es von der Tabellenbreite her passt. Das musst Du natürlich an Deine Anforderungen anpassen, aber als Referenz habe ich Dir meine Beispielvorlage unten auch einmal angehängt.

Zwei Hinweise noch:

1. Es gibt in den Preislistenvorlagen zwar auch eine Variable Vorgang.Kundengruppe, die wird aber beim Aufruf der Vorlage nicht mit der aktuellen Kundengruppe versorgt, man muß also tatsächlich Vorgang.Kundengruppendetails.Name nehmen.
2. Keine der Kundengruppen-Variablen werden beim Aufruf der Vorlage zum Editieren mit Werten versorgt! - Die Abfrage auf Sonderpreise läuft im Editier-Modus also immer auf die Rückgabe von 0,00€ hinaus. Zum tatsächlichen Testen der Vorlage muß man also über Verkauf > Preisliste in der Wawi gehen, Kundengruppe und ggfls. Sprache auswählen, usw.

Gruß,
Ingmar
 

Anhänge

  • Preisliste_EUR_Sonderpreise_03062017.vlg
    8,4 KB · Aufrufe: 42
Zuletzt bearbeitet:

gutberle

Sehr aktives Mitglied
29. März 2011
1.295
405
... und hier noch ein Nachtrag und eine kleine (Sicherheits-)Korrektur zu oben:

1. Wenn Du Sonderpreise für einen Artikel sowohl für die Wawi wie auch für den Shop definiert hast, dann funktioniert die obige Abfrage und auch die Vorlage weiter genauso gut, obwohl dann zwei Tabellenzeilen zurückgegeben werden. Das ist aber nur deshalb so, weil die JTL_DirectQuery() die zweite Tabellenzeile einfach ignoriert. Das ist aber natürlich schlechter Stil (von mir) und die korrigierte SQL Query holt jetzt explizit nur den Sonderpreis für die Wawi aus der Datenbank...
Code:
LocCurrL$(Val(JTL_DirectQuery("SELECT fNettoPreis FROM tSonderpreise JOIN tArtikelSonderpreis ON tArtikelSonderpreis.kArtikelSonderpreis=tSonderpreise.kArtikelSonderpreis JOIN tKundenGruppe ON tKundenGruppe.kKundenGruppe=tSonderpreise.kKundenGruppe WHERE tArtikelSonderpreis.nAktiv=1 AND tSonderpreise.kShop=0  AND tKundenGruppe.cName='"+Vorgang.Kundengruppendetails.Name+"' AND tArtikelSonderpreis.kArtikel="+ToString$(Preislistenartikel.InterneArtikelnummer))),"de-DE")

2. Falls Du über den aktuellen Sonderpreis hinaus auch noch ausgeben möchtest bis wann oder bis zu welchem Lagerstand der Sonderpreis gilt, dann kriegst Du auch diese Infos auch nur aus der Datenbank. Da dieser Wunsch für eine Preisliste aber eigentlich eher normal sein sollte, habe ich eine etwas komplexere SQL Query geschrieben, die alle relevanten Daten zum Sonderpreis und auch den Sonderpreis selbst in einer handlichen Form zurückgibt.
Code:
JTL_DirectTableQuery("SELECT 'istDatum=', CASE WHEN nIstDatum=0 THEN 'FALSE' ELSE 'TRUE' END, '|StartDatum=', CONVERT(VarChar(10), dStart, 104) AS StartDate, '|EndDatum=', CONVERT(VarChar(10), ISNULL(dEnde,dStart), 104), '|istAnzahl=', CASE WHEN nIstAnzahl=0 THEN 'FALSE' ELSE 'TRUE' END, '|EndAnzahl=', nAnzahl, '|SonderPreis=', tSonderpreise.fNettoPreis FROM tArtikelSonderpreis JOIN tSonderpreise ON tSonderpreise.kArtikelSonderpreis=tArtikelSonderpreis.kArtikelSonderpreis JOIN tKundenGruppe ON tKundenGruppe.kKundenGruppe=tSonderpreise.kKundenGruppe WHERE tArtikelSonderpreis.nAktiv=1 AND tSonderpreise.kShop=0 AND tKundenGruppe.cName='"+Vorgang.Kundengruppendetails.Name+"' AND tArtikelSonderpreis.kArtikel="+ToString$(Preislistenartikel.InterneArtikelnummer),"","|")

Die Informationen werden hier in dem Format zurückgeliefert, das der Alias$() Befehl erwartet, mit dem man die einzelnen Bestandteile bequem abfragen kann. Will man z.B. das Startdatum abfragen, dann würde der Alias-Befehl dazu lauten...
Alias$("StartDatum",@SonderPreis) und um zu erkennen, ob der Sonderpreis überhaupt datumsgesteuert ist, könnte man folgendes Konstrukt nehmen: Cond(Alias$("istDatum",@SonderPreis)="TRUE",Alias$("StartDatum",@SonderPreis,"")

Und da der Sonderpreis jetzt nicht mehr in der DB-Abfrage selbst formatiert werden kann, macht man das in der Tabelle mit LocCurrL$(Val(Alias$("SonderPreis",@SonderPreis)),"de-DE") und erst dort, wo man ihn ausgeben will.

Angehängt findest Du eine neue Vorlage, die dies umsetzt und gleich noch ein paar Zeilen Debug-Code enthält, der Dir zeigt, wie die Alias$() Befehle für die unterschiedlichen Sonderpreis-Parameter lauten.
 

Anhänge

  • Preisliste_EUR_SonderpreiseExtendedInfo_DebugVersion_04062017.vlg
    10 KB · Aufrufe: 39

tschwenke

Aktives Mitglied
27. April 2012
49
4
Hallöchen,

auch wenns schon her ist, hab das grad bei uns, etwas abgewandelt, eingebaut.
Was soll ich sagen, einfach Top.

Besten Dank für deine Codesnippets.

Thorsten
 

hii

Gut bekanntes Mitglied
6. Januar 2009
135
9
NRW
Hallo zusammen,

auch mir haben die Codesnippets sehr geholfen, vielen Dank für's teilen!

Jedoch versuche ich verzweifelt den Brutto Sonderpreis auszugeben. Gerne auch in Form einer Berechnung.
Weiß hier jemand wie ich das hinbekommen kann?
 
Zuletzt bearbeitet:

hii

Gut bekanntes Mitglied
6. Januar 2009
135
9
NRW
Habe mir nun nach einigen Experimenten wie folgt geholfen...

Die @SonderPreis habe ich wie folgt angepasst:
Code:
LocCurr$(Val(JTL_DirectQuery("SELECT fNettoPreis FROM tSonderpreise JOIN tArtikelSonderpreis ON tArtikelSonderpreis.kArtikelSonderpreis=tSonderpreise.kArtikelSonderpreis JOIN tKundenGruppe ON tKundenGruppe.kKundenGruppe=tSonderpreise.kKundenGruppe WHERE tArtikelSonderpreis.nAktiv=1 AND tSonderpreise.kShop=0  AND tKundenGruppe.cName='"+Vorgang.Kundengruppendetails.Name+"' AND tArtikelSonderpreis.kArtikel="+ToString$(Preislistenartikel.InterneArtikelnummer))),"de-DE")

Somit bekomme ich eine Zeichenkette die nur aus Zahlen besteht.

Dann platziere ich die Variable in meine Tabelle und Wandel ich per "Val" die Zeichenkette zu einer Zahl und kann somit "weiterrechnen":
Code:
Fstr$((Val (@SonderPreis)*1,19),"-?&.##")

Bei Bedarf kann die Währung angehangen werden:
Code:
Fstr$((Val (@SonderPreis)*1,19),"-?&.##") + " " + Vorgabe.Standardwährung.Name

Sicherlich gibt es elegantere Weg, aber für mich funktioniert dieser.

Viele Grüße
 

Irina

Aktives Mitglied
12. Januar 2016
14
0
Braunschweig
Hallo ich bin ein Anfänger.

ich suche zwei Variablen :

Kundengruppe online shop -> Preis Normal - den ich auf dem Etikett durchstreichen möchte
Kundengruppe online shop -> Sonderpreis - groß als Angebot

Sind diese code für mein Weg richtig? Woran erkenne ich das es die Variable der Kundengruppe?

Danke!
 
Ähnliche Themen
Titel Forum Antworten Datum
Neu JTW Wawi hängt beim Bearbeiten der Druckvorlage für Mahnungen User helfen Usern - Fragen zu JTL-Wawi 0
E-Rechnung ZUGFeRD Umsatzsteuerkategorie bearbeiten/einstellen Druckvorlage JTL-Wawi 1.11 1
DHL 4.0 mit JTL Wawi 1.7.13.0 JTL-Wawi 1.7 0
Neu Google Shopping: g:product_type mit Attribut befüllen ist immer DE, obwohl mehrsprachig angelegt Plugins für JTL-Shop 0
Neu Listung mit Varianten - nicht alle Varianten sind vorhanden Amazon-Lister - Fehler und Bugs 0
Häufiges Aufhängen - vermutlich Probleme mit der Datenbank JTL-Wawi 2.0 2
Neu Kein permanenter Dataflow mit Kern FCB Waage JTL-WMS / JTL-Packtisch+ - Fehler und Bugs 2
Neu DRIGEND HILFE!!! Ebay Abgleich endet mit Arithmetischer Überlauffehler für tinyint-Datentyp, Wert = -1. Die Anweisung wurde beendet. eBay-Anbindung - Fehler und Bugs 4
Wawi 1.10.14.3 lässt sich nicht mehr mit Datev verbinden JTL-Wawi 1.10 3
Problem Wawi 2.0 mit DHL Versand JTL-Wawi 2.0 1
Neu JTL-WaWi + ESL Connector — Entwicklung mit Kostenaufteilung gesucht Business Jungle 0
Neu Ort mit OT per Workflow bereinigen JTL-Workflows - Ideen, Lob und Kritik 3
Statistische Auswertung mit Klar Connector oder Controlling Software? JTL-Wawi 1.10 0
Artikelnamen bei Varioartikel nichtänderbar mit csv JTL-Wawi 1.10 0
Neu Probleme mit Ninepoint und TikTok Shop Schnittstellen Import / Export 6
FFN Abgleich schlägt fehlt mit Worker 2.0 JTL-Wawi 2.0 0
Eingangsrechnungen mit Einstellung "Nur gelieferte Positionen übernehmen" - Versandkosten werden nicht mit übernommen JTL-Wawi 1.11 4
Neu 5.6.1 Bug bei Versandarten mit Kalkulation durch Artikelmenge und Staffelpreisen JTL-Shop - Fehler und Bugs 2
Neu Ältere Young Fashion Kollektion: Mit Kaufland, TikTok & Influencer schnell hochziehen und abverkaufen? Dienstleistung, Jobs und Ähnliches 1
Neu Problem mit "eigenen Seiten" Betrieb / Pflege von JTL-Shop 2
Probleme mit JTL Worker JTL-Wawi 2.0 1
Neu Kein Abgleich mit Amazon nicht mehr möglich JTL-Wawi 2.0 0
Neu Anbindung der POS funktioniert nicht unter WAWI2.0.0 mit EcomData Hosting JTL-Wawi 2.0 7
Neu Bestandsabgleich JTL Wawi mit Amazon JTL-Wawi - Fehler und Bugs 1
Neu Teillieferung nur mit Rechnung über ganzen Auftrag oder ohne Rückstandsmeldung möglich Arbeitsabläufe in JTL-WMS / JTL-Packtisch+ 1
Artikel Wareneingang buchen mit anderer Währung? JTL-Wawi 1.10 0
Worklflow mit einem externen PDF Anhang JTL-Wawi 1.10 0
Neu Aufträge mit JTL-Pos gezahlt im Tagesabschluss (Lexware Office) Allgemeine Fragen zu JTL-POS 0
Neu Bilder importieren mit "vorhandene Bilder vor dem Import entfernen und neu importieren" > eigenartiges Verhalten JTL-Ameise - Fehler und Bugs 2
Problem mit Hintergrundfarbe Einrichtung JTL-Shop5 1
Neu Artikel letzte 10 Versanddaten, sortiert nach Datum mit Plattform Eigene Übersichten in der JTL-Wawi 4
Neu Worker Abgleich mit dem Onlineshop "mit Fehlern beendet" Onlineshop-Anbindung 4
Neu JTL, was ist eigentlich los mit euch? JTL-Wawi - Fehler und Bugs 5
Gelöst Bekannte Störung: Fehler "Der Inhaltstyp text/html stimmt nicht mit text/xml überein" bei der Labelerstellung Gelöste Themen in diesem Bereich 1
Neu BIETE: 2x Fetra 2892 Kommissionier-/Lagerwagen mit Sichtlagerkästen Dienstleistung, Jobs und Ähnliches 0
Neu Export Käuferliste mit Seriennummern User helfen Usern - Fragen zu JTL-Wawi 4
Neu Problem bei Varianten-Upload mit Amazon Lister 2.0 (Attribut-Mapping Farbe/Größe) Onlineshop-Anbindung 1
Neu Probleme mit Inaktive Verkaufskanäle User helfen Usern - Fragen zu JTL-Wawi 0
Neu Vorsicht - eComData "Upgrades" ab 01.04.2026 mit gleichzeitigem Paketwechsel verursacht teilweise 100% mehr Kosten! Smalltalk 6
Verkauf: Positionsname mit Hersteller möglich? JTL-Wawi 1.11 11
Neu Beim Versuch Paypal-Plugin mit Paypal-Konto zu verbinden Shop nicht mehr erreichbar Plugins für JTL-Shop 2
Neu Neues Plugin: Produktbundles mit Rabatten Plugins für JTL-Shop 0
Neu Für die Weiterentwicklung und Betreuung unserer bestehenden Systemlandschaft suchen wir einen erfahrenen Freelancer (m/w/d) mit fundierten Kenntnissen JTL-Wawi App 1
Update von 1.11.6 auf 1.11.7: JTL Worker verbindet nicht mehr mit Datenbank (WaWi schon) JTL-Wawi 1.11 1
Neu Repricer Erfahrungen mit JTL gesucht User helfen Usern - Fragen zu JTL-Wawi 0
Neu Checkout Probleme mit Pflichtfeldangaben Allgemeine Fragen zu JTL-Shop 4
Neu OSS aktiv – Ausnahme für Eventtickets mit deutschem Leistungsort möglich? Allgemeine Fragen zu JTL-Shop 6
Neu Zusatzartikel, Stückliste, Variation den Kunden direkt mit anbieten (Shop/Ebay) User helfen Usern - Fragen zu JTL-Wawi 6
Neu Kundenkonto mit UID und Bestellung als Gast JTL-Shop - Fehler und Bugs 14
Neu Sprachvariablen Textbausteine mit "." im Namen lassen sich nicht ändern JTL-Shop - Fehler und Bugs 2

Ähnliche Themen