Profimodus

Bei der Preis- und Gewichtsberechnung muss das Ergebnis einer Formel immer ein numerischer Wert sein. Bei der Validierung muss das Ergebnis immer ein Wahrheitswert / boolescher Wert sein

Aufbau / Syntax

Die Formel im Profimodus ist ein JSON-Objekt, d.h. jegliche Operatoren werden als JSON-Objekt definiert.

Operatoren

Im einfachen Modus stehen die Logikoperatoren und boolesche Operatoren und arithmetische Operatoren zur Verfügung

Arithmetische Operatoren

NameOperator

Multiplizieren

{"*":[1,2]}

Didivdieren

{"/":[1,2]}

Addieren

{"+":[1,2]}

Subtrahieren

{"-":[1,2]}

Quadratwurzel ziehen

{"sqrt":16} 
{"sqrt":{"var":"fields.zahl.value"}

Potenzieren

{"pow":[2,3]} -> 2 hoch 3 
{"pow":[{"var":"fields.zahl.value"},2]}

Alle Operatoren können durch die Angabe weiterer Argumente erweitert werden. Die Anzahl ist also nicht auf 2 beschränkt, z.B. {"*":[1,2,3,4]} = 1 * 2 * 3 * 4 = 24

Vergleichsoperatoren

NameOperator

if / else

{"if" : [
  Bedingung,
  falls Bedingung wahr,
  sonst
]}

if /else if / if

{"if" : [
  {"<": [{"var":"fields.length.value"}, 100] }, 20,  
  {"<": [{"var":"fields.length.value"}, 200] }, 30,  
  {"*":[{"var":"fields.length.value"},10]}
]}

Ergibt: Falls Länge < 100: 20 Sonst falls Länge < 200: 30, sonst 10

Gleich

{"==" : [2, 1]}

Ungleich

{"!=" : [2, 1]}

Größer gleich / Größer

{">" : [2, 1]}
{">=" : [2, 1]}

Kleiner gleich / Kleiner

{"< " : [1, 2]}
{"< =" : [1, 2]}

Nach dem < Zeichen immer ein Leerzeichen lassen!

Rundungen

Vor allem in der Preisberechnung können Rundungen sinnvoll sein.

NameOperator

Runden

{"round" : [{"var":"fields.length.value"}, 2]}
{"round" : [7.999393, 2]}

Rundet den Wert aus dem Feld auf 2 Nachkommastellen

Aufrunden

{"ceil" : 7.90}

Ergebnis: 8

Abrunden

{"floor" : 7.90}

Ergebnis: 7

Bruttopreise / Nettopreise - steuersensitive Angaben je nach Kundengruppe

NameOperator

Preis als Brutto-Preis markieren

{"brutto" : 2.40}
{"brutto" : {"var":"fields.auswahl.price"}}

Sowohl brutto als auch gross werden als Operator-Name unterstützt:

{"gross" : 2.40}
{"gross" : {"var":"fields.auswahl.price"}}

Preis als Netto-Preis markieren

{"netto" : 2.40}
{"netto" : {"var":"fields.auswahl.price"}}

Sowohl net als auch netto werden als Operator-Name unterstützt:

{"net" : 2.40}
{"net" : {"var":"fields.auswahl.price"}}

Sonstiges

NameOperator

Matrix-Operator für Staffelpreise / Preistabellen

{"matrix":[
  550,
  [
    [500, 84.00],
    [600, 89.00],
    [700,94.00]
  ]
]}

{"matrix":[
  {"var":"fields.auflage.value"},
  [
    [100, 84.00],
    [200, 89.00],
    [300,94.00]
  ]
]}

{"matrix":[
  {"var":"fields.length.value"},{"var":"fields.width.value"},
  [
    [100, 20, 84.00],
    [200, 20, 89.00],
    [300, 20, 94.00]
  ]
]}

Kleinster Wert

{"min" : [7.90,{"var":"fields.length.value"}]}

Größter Wert

{"max" : [7.90,{"var":"fields.length.value"}]}

Textlänge

{"length" : "Hallo"}
{"length" : {"var":"fields.text.value"}}

Texte verknüpfen

{"cat" : ["Anzahl Felder: ", {"var:"fields.repeater.count"}]}

--> Anzahl Felder: 3

Beispiele

Formelbeispiel: Preis richtet sich nach der Anzahl der eingegebenen Buchstaben

{
  "if": [
    {">": [{"length": {"var": "fields.textfield.value"}}, 2]},
    {"*":[{"var":"product.price"}, 2.5]},
    {"*":[{"var":"product.price"}, 5.4]}
  ]
}

Formelbeispiel Validierung

Falls im Feld "Dicke" ein Wert kleiner als 6 eingetragen / gewählt wurde, ist der maximal gültige Wert 1400, sonst 2000.

{"or": [
{"and" : [{"< " : [{"var":"fields.dicke.value"}, 6]}, {"< " : [{"var":"value"}, 1400]}]},
{"and" : [{">=" : [{"var":"fields.dicke.value"}, 6]}, {"< " : [{"var":"value"}, 2000]}]}
]}

Formelbeispiel Preis abhängig von Textlänge

2 Euro pro Buchstabe siehe Beispiel im Demoshop: Storefront Admin (demo demo)

{"*":[
    2,
    {"length":{"var":"fields.aufdruck.value"}}
]}

Formelbeispiel: Mindestpreis

Durch den min-Operator wird der jeweils kleinste Wert ausgewählt. Wenn die Berechnung im Ergebnis kleiner als 9,90 ist, wird 9,90 ausgegeben.

{"max" : [
  9.90,
  {"if": [
    {">": [{"length": {"var": "fields.textfield.value"}}, 2]},
    {"*":[{"var":"product.price"}, 2.5]},
    {"*":[{"var":"product.price"}, 5.4]}
  ]}
]}

Auch mehrere Werte sind möglich, der größte Preis wird gewählt, durch die Angabe von 9.90 wird der Mindestpreis auf 9.90 Euro festgelegt.

{"max" : [
  9.90,
  {"*":[{"var":"product.price"}, {"var":"fields.length.value"}]},
  {"if": [
    {">": [{"length": {"var": "fields.textfield.value"}}, 2]},
    {"*":[{"var":"product.price"}, 2.5]},
    {"*":[{"var":"product.price"}, 5.4]}
  ]}
]}

Formelbeispiel Preisstaffel mit dem Matrix-Operator

Mit dem Matrix-Operator lassen sich Preisstaffeln / Staffelpreise einfach umsetzen. Statt mit verschachtelten if-gleich-Blöcken zu arbeiten, kann hier die Eingabe ganz einfach Zeile für Zeile erfolgen. In der ersten Zeile wird der zu prüfende Wert eingetragen, in den Folgezeilen die Abstufungen. Im folgenden Beispiel wird bei Auflage >= 100 und < 200 der Wert 10 gewählt, bei >=200 und < 300 der Wert 8.90 etc. Dieses Ergebnis lässt sich wieder mit anderen Operatoren weiterverarbeiten und kombinieren.

{"matrix":[
  {"var":"fields.auflage.value"},
  [
    [0, 10.00],
    [100, 9.90],
    [200, 8.90],
    [300, 8.70]
  ]
]}

Auch weitere Dimensionen sind möglich:

{"matrix":[
  {"var":"fields.laenge.value"},{"var":"fields.breite.value"},
  [
    [100, 10, 9.90],
    [200, 10, 18.90],
    [300, 10, 27.70],
    [100, 20, 11.90],
    [200, 20, 21.90],
    [300, 20, 31.70],
    [100, 30, 41.90],
    [200, 30, 54.90],
    [300, 30, 45.70],
  ]
]}

Dieses Beispiel würde in tabellarischer Form so aussehen:

Breite Länge ->

100

200

300

10

9,90

18,90

27,70

20

11,90

21,90

31,70

30

41,90

54,90

45,70

Das funktioniert auch mit Auswahlfeldern:

{"matrix":[
  {"var":"fields.auswahl.value"},{"var":"fields.breite.value"},
  [
    ["Variante A", 0, 10],
    ["Variante A", 100, 6],
    ["Variante B", 0, 10.50],
    ["Variante B", 100, 6.50]
  ]
]}

Es sind beliebig viele Dimensionen damit abbildbar

Last updated