-
Notifications
You must be signed in to change notification settings - Fork 56
1 . Introduction
Security Theater edited this page Oct 12, 2018
·
1 revision
Oh Hello, hopefully you like our elegant marketplace 🥇
Create simple products, and complex ones using variation system by attaching the product to a specific type.
Generate , Validate , and purchase them while checkout easily.
- CRUD the wishlist/cart easily
- get the total/subtotal of the whole cart/wishlist and optionally after sale/coupons applied.
- stock handling behind the scenes .
- Attach product, type of products to a category.
- Setup sale for category, specific product, type of products.
Product::generate([
'user_id' => auth()->id(),
'name' => 'laptop',
'description' => 'Fancy laptop',
'price' => 15000,
'category' => 'electronics',
'type' => ['name' => 'MacBook Pro', 'stock' => 20],
'details' => ['color' => 'Silver', 'dummy-feature' => 'dummy-text']
);
Product::fetchByVariations(['locations' => 'U.K', 'variations' => ['size' => 'XL', 'color' => 'red'], 'categories' => 'clothes']);
- Add custom Criterion and use it while searching.
Out of the blue, you may use a couple of methods to retrieve the total/subtotal
Cart::subtotal();
Cart::total(); // returns total after applying tax.
Cart::total($coupons); // Collection of coupons passed, returns total after applying tax and coupons.
Cart::subtotalAfterCoupon($coupons);
Surprisingly every single method you can use for a cart, you can use for a wishlist ( since we can consider it as a virtual cart )
Cart::item(1); // get the item with id of 1
Cart::item(1, ['color' => 'blue', 'size' => 'L']); // get the item with the id of 1 and should have these attributes.
Cart::item(null, ['color' => 'blue','size' => 'L']); // get the current authenticated user's cart which has these attributes assuming that these attributes identical to the database record.
Cart::item(null, ['color' => 'blue','size' => 'L'] , 'or'); // get the current authenticated user's cart which has any of these attributes.
Coupon::generate([
'user_id' => auth()->id(),
'active' => true,
'percentage' => 10.5,
'expires_at' => Carbon::now()->addWeeks(3)->format('Y-m-d H:i:s')
]);
$coupon = Coupon::first(); // valid one
Coupon::validate($coupon); // returns true
$coupon = Coupon::first();
Coupon::deactivate($coupon->id);
$coupon = Coupon::first();
Coupon::purchase($coupon); // Purchase the coupon for the current authenticated user.
Coupon::purchase($coupon, $anotherUser); // Purchase the coupon for the passed user.
- It releases the invalid purchased coupons automatically.
Coupon::purchased(); // returns the only valid purchased coupons.
- Assuming the user has a couple of coupons, he can designate which of them that can be applied on a specific product.
Coupon::appliedCoupons($coupons); // returns a query builder.