Skip to content

Latest commit

 

History

History
67 lines (50 loc) · 1.42 KB

README.md

File metadata and controls

67 lines (50 loc) · 1.42 KB

Generic badge

Discounter

Installation

Use composer to install the Discounter: composer require bundsgaard/discounter. You can now use the discounter where you want.

Usage

Use the discounter as the following:

use Bundsgaard\Discounter\SimpleDiscounter; // Remember to include the Discounter from its namespace

$basePrice = 1000;
$cartQty = 10;

$rule1 = new \stdClass();
$rule1->operator = '>=';
$rule1->qty = 10;
$rule1->amount = 12;
$rule1->type = 'percentage';

$rule2 = new \stdClass();
$rule2->operator = '=';
$rule2->qty = 5;
$rule2->amount = 8;
$rule2->type = 'percentage';

$rule3 = new \stdClass();
$rule3->operator = '<';
$rule3->qty = 4;
$rule3->amount = 75;
$rule3->type = 'fixed';

$rules = [
    $rule1,
    $rule2,
    $rule3
];

$discounter = new SimpleDiscounter();

$discountedPrice = $discounter->calculate($basePrice, $cartQty, $rules)->get();

Available operators:

  • >= Greater than or equal to
  • <= Less than or equal to
  • > Greater than
  • < Less than
  • = Equal to

Available discount types:

  • Fixed amount (fixed)
  • Percentage (percentage)

Rule explanations:

$rule1 = new \stdClass(); // Create new rule
$rule1->operator = '>='; // Set operator
$rule1->qty = 10; // Set the wanted cart qty
$rule1->amount = 12; // Set the amount of discount
$rule1->type = 'percentage'; // Set the type of discount