Package Data | |
---|---|
Maintainer Username: | darthsoup |
Maintainer Contact: | kevin.krummnacker@gmail.com (Kevin Krummmnacker) |
Package Create Date: | 2017-04-04 |
Package Last Update: | 2022-02-18 |
Home Page: | |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2025-01-13 15:06:02 |
Package Statistics | |
---|---|
Total Downloads: | 5,392 |
Monthly Downloads: | 1 |
Daily Downloads: | 0 |
Total Stars: | 2 |
Total Watchers: | 3 |
Total Forks: | 1 |
Total Open Issues: | 0 |
An easy shoppingcart implementation for Laravel > 5.2. Based on the work of Gloudemans\Shoppingcart.
This package for shopping carts provides these features:
Install the package through Composer. Edit your project's composer.json
file by adding:
This package needs at least Laravel 5.2 and PHP 7.1.
First, you'll need to install the package via Composer:
$ composer require darthsoup/shoppingcart
You do not need to do anything else here
Then, update config/app.php
by adding an entry for the service provider.
'providers' => [
// ...
DarthSoup\Cart\CartServiceProvider::class,
];
If you want to access the Cart via Facade than add a new line to the aliases
array
'aliases' => [
// ...
'Cart' => DarthSoup\Cart\Facades\Cart::class,
];
The cart package provides you the following methods to use:
/**
* Add a Item to the cart.
*
* @param string|array $id Unique ID of the item|Item formatted as array|Array of items
* @param string $name Name of the item
* @param int $quantity Item quantity to add to the cart
* @param float $price Price of one item
* @param array $options Array of additional options, such as 'size' or 'color'
*/
// Basic form
Cart::add('1', 'Product One', 1, 9.99, ['option_key' => 'option_value']);
// Array form
Cart::add(['id' => 'mail1000', 'name' => 'Mail Package One', 'quantity' => 5, 'price' => 4.99, 'options' => []]);
// Batch method
Cart::add([
['id' => '15', 'name' => 'Hamburger', 'quantity' => 1, 'price' => 1.99],
['id' => '16', 'name' => 'Cheeseburger', 'quantity' => 1, 'price' => 2.49, 'options' => ['onion' => false]]
]);
you also can make Items by make them manually
$item = new \DarthSoup\Cart\Item('15', 'Hamburger', 1.99, ['onion' => false]);
Cart::add($item);
Cart::update('rowId', [
'options' => [$field => $value]
]);
Cart::get('rowId');
Show the content of the Cart by returning the CartCollection
Cart::content();
Cart::destroy();
Cart::remove('rowId');
Cart::total();
Cart::count();
This package also includes the functionality to add Subitems by adding them to an additional Collection in the Item
The addSubItem
function works basically like add
but it accepts a parent row Id at the end to add an SubItem
to the item.
$hamburger = Cart::add('15', 'Hamburger', 1, 1.99, ['onion' => false]);
Cart::addSubItem('99', 'Extra Bacon', 1, 0.99, [], $hamburger->getRowId())
Just like removing normal ones, just include your subItem rowId
and it will be removed from the parent
A new feature is associating a model with the items in the cart. Let's say you have a Product
model in your application. With the associate()
method, you can tell the cart that an item in the cart, is associated to the Product
model.
That way you can access your model right from the CartCollection
!
Here is an example:
<?php
Cart::associate(\App\Product::class)->add('15', 'Hamburger', 1, 9.99, ['extra_sauce' => true]);
$content = Cart::content();
foreach($content as $row) {
echo 'You have ' . $row->quantity . ' items of ' . $row->model->name . ' with description: "' . $row->model->description . '" in your cart.';
}
Using the key model
to access the model that you associated.
The Cart package will throw exceptions if something goes wrong. This way it's easier to debug your code using the Cart package or to handle the error based on the type of exceptions. The Cart packages can throw the following exceptions:
| Exception | Reason |
| ------------------------------------- | --------------------------------------------------------------------------------- |
| InstanceException | When no instance is passed to the instance() method |
| InvalidRowIdException | When the $rowId
that got passed doesn't exists in the current cart |
| InvalidQuantityException | When the quantity is outside the set limits |
| ClassNotFoundException | When an class cannot found while association |
The cart also has events build in. There are five events available for you to listen for.
| Event | Fired | | ------------------------------ | --------------------------------------- | | cart.added($item) | When a item is added | | cart.subitem.added($item) | When a sub item is added | | | cart.updated($rowId) | When an item in the cart is updated | | cart.removed($rowId) | When an item is removed from the cart | | cart.destroyed() | When the cart is destroyed |
Please use Github for reporting bugs, and making comments or suggestions. See CONTRIBUTING.md for how to contribute changes.