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

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

Rundungen

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

Bruttopreise / Nettopreise - steuersensitive Angaben je nach Kundengruppe

Sonstiges

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:

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