silvershop/shipping
Shipping methods for the SilverShop.
Maintainers
Package info
github.com/silvershop/silvershop-shipping
Type:silverstripe-vendormodule
pkg:composer/silvershop/shipping
Requires
- php: ^8.3
- silvershop/core: ^6
- silvershop/silverstripe-hasonefield: ^5
- silverstripe/framework: ^6
Requires (Dev)
- phpunit/phpunit: ^11.5
- squizlabs/php_codesniffer: ^3.0
Suggests
None
Provides
None
Conflicts
None
Replaces
None
BSD-3-Clause 0654b885c861356892cf5feee97192f7938077f5
README
👁 Latest Stable Version
👁 Latest Unstable Version
👁 CI
👁 Code Coverage
👁 Scrutinizer Quality Score
👁 Total Downloads
Introduce shipping options to SilverShop
Installation
composer require silvershop/shipping
Add the ShippingFrameWorkModifier to your modifiers config, eg:
SilverShop\Model\Order: modifiers: - SilverShop\Shipping\ShippingFrameworkModifier
You need to use the new SteppedCheckout system to allow customers to set their address before they choose their shipping method. To set up steps, including the shippingmethod step, add the following to your mysite/_config/config.yml file:
SilverShop\Page\CheckoutPage: steps: 'membership': 'CheckoutStep_Membership' 'contactdetails': 'CheckoutStep_ContactDetails' 'shippingaddress': 'CheckoutStep_Address' 'billingaddress': 'CheckoutStep_Address' 'shippingmethod': 'CheckoutStep_ShippingMethod' #extra line for shipping method 'paymentmethod': 'CheckoutStep_PaymentMethod' 'summary': 'CheckoutStep_Summary'
If included, remove SteppedCheckout::setupSteps() from your _config.php file (SteppedCheckout::setupSteps() creates default checkout page steps no longer needed with the above YAML entries).
To add the shipping estimation form to your CartPage template, add the following somewhere on your CartPage.ss template:
<% include ShippingEstimator %>
If you need some example tableshipping data to populate your site for testing/development,
you can run the task: yoursite.tld/dev/tasks/PopulateTableShippingTask
Architecture
ShippingPackage is a class used to encapsulate shipping data including: weight, dimensions, value, quantity.
ShippingMethod is the base class for different types of shipping calculation.
These could either be flat rates, table based rates, or a
TableShippingMethod has many TableShippingRate, where TableShippingRate extends RegionRestriction.
Table shipping rates also have optional weight, volume, value, and quantity constraint fields.
DistanceShippingMethod has many DistanceShippingFare, and requires the shop_geocoding module to be present.
Region Restrictions
The RegionRestriction class serves as a base class for providing regionalised restrictions.
Restrictions are specified by Country, State, and PostalCode. A value/rate can be given to each
restriction. To work the appropriate rate, query for all the matching restrictions, and sort
by cheapest.
The wildcard '*' means the restriction will match any region.
