2017 © Pedro Peláez
 

library shipping-calculator

Shipping calculation library based on Symfony 2 components.

image

shiptor/shipping-calculator

Shipping calculation library based on Symfony 2 components.

  • Wednesday, March 16, 2016
  • by moriony
  • Repository
  • 3 Watchers
  • 2 Stars
  • 3,482 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 1 Forks
  • 0 Open issues
  • 19 Versions
  • 0 % Grown

The README.md

Shipping Calculator

Build Status Test Coverage Code Climate Latest Stable Version Total Downloads License, (*1)

Shipping calculation library based on Symfony 2 components., (*2)

Installation

Add in your composer.json the require entry for this library., (*3)

{
    "require": {
        "shiptor/shipping-calculator": "*"
    }
}

and run composer install (or update) to download all files., (*4)

Usage

How to create a calculator?

Example code below will create the calculator for a single shipment method., (*5)

$config = include __DIR__.'/../src/Resources/DHL/ExportExpressWorldWide/tariff_2015_08_25_usa.php';
$calculator = new BaseCalculator([
    'handler' => DhlHandler::create($config)
]);

What is what: - DhlCalculatorHandler contains calculation algorithm for the Dhl Express Shipping Method; - $config contains configuration for the DhlHandler; - BaseCalculator is a wrapper for a calculation handlers, it contains an algorithm "How to use calculation handlers" and returns a calculation result;, (*6)

How to calculate a package shipping?

Example code below will create a package and calculate shipping cost for Dhl Express., (*7)

// previous example code here

$weight = new Weight();
$weight->setValue(10);
$weight->setUnit('lb');

$dimensions = new Dimensions();
$dimensions->setLength(10);
$dimensions->setWidth(10);
$dimensions->setHeight(10);
$dimensions->setUnit('in');

$senderAddress = new Address();
$senderAddress->setCountryCode('USA');

$recipientAddress = new Address();
$recipientAddress->setCountryCode('RUS');

$package = new Package();
$package->setWeight($weight);
$package->setDimensions($dimensions);
$package->setSenderAddress($senderAddress);
$package->setRecipientAddress($recipientAddress);

$result = $calculator->calculate($package);

What is what: - Weight contains information about physical weight; - Dimensions contains information about package box dimensions. It is required to calculate a volumetric weight of your package; - $senderAddress and $recipientAddress contains information about sender and recipient; - Package is a wrapper object to all objects above. You will need to pass this object to calculate method of your calculator; - $result contains your package and resulting calculation data;, (*8)

How to extend a calculator?

Shipping calculator uses symfony event dispatcher and you can use it to extend calculation algorithms as you need. For example, you can increase shipping cost by 10$., (*9)

// place calculator creation code here

$calculator->getDispatcher()->addListener(Events::AFTER_CALCULATE, function (AfterCalculateEvent $event) {
    $event->getResult()->setShippingCost($event->getResult()->getShippingCost() + 10);
});

What is what: - Events::AFTER_CALCULATE is an event calling when calculation ends and calculation result is ready; - AfterCalculateEvent is an event object which contains calculation result and package. Look to other available events here;, (*10)

More ideas how to use and extend shipping calculator

  • create calculation handlers for other couriers and shipping methods;
  • create calculators and realize your own algorithms using handlers;

The Versions

16/03 2016
05/11 2015

0.0.3

0.0.3.0

Shipping calculation library based on Symfony 2 components.

  Sources   Download

MIT

The Requires

 

The Development Requires

05/11 2015

0.0.2

0.0.2.0

Shipping calculation library based on Symfony 2 components.

  Sources   Download

MIT

The Requires

 

The Development Requires

05/11 2015

0.0.1

0.0.1.0

Package delivery calculation library based on Symfony 2 components.

  Sources   Download

MIT

The Requires

 

The Development Requires