khaleds / voucher
Coupons and promotional codes generator for Laravel.
This package is auto-updated.
Last update: 2025-01-12 18:29:15 UTC
README
Laravel Voucher Package
Coupons and voucher codes checker. you can create voucher with many conditions that fit your business.
Available Conditions
all of this conditions the package checking it .
what about you have a coupon for a specific users ,vendors or customers beside the other conditions ofcourse , or even i need to apply coupon for category , service or products all of them or specific ones ?
voucher_implementation_id ;) this forigen id related with table takes [class path,value as json]. you can add your voucher audience as a morph table in voucher_audiences that tacks which usable_type as a table name, usable_id as model id ,is_all bool that mean all records in this table and voucher_id . in the voucher_implementations table you can find the implementation record for each voucher the default one is applied . the default implementation just check for model table ,id or is_all check in voucher_audiences table
List of content
- Installation
- How Does It Work?
- How to use
- Advanced use
Installation
composer require khaleds/voucher
Migrate table
php artisan make:migration
Seeder
Add this to your DatabaseSeeder class in run method
use Khaleds\Voucher\Seeder\VoucherImplementaionSeeder; $this->call(VoucherImplementaionSeeder::class);
How Does It Work?
Vouchers table
This table contain the voucher conditions like
Other columns
If you want more condition like specific models or ids like i want this voucher for all accounts table or users table or the users with some ids you can do that in this table
Vouchers Audiences table
This table contain
the relation is one to many so you can add many ids if you want per voucher
User Voucher table
This table contain the users that applied to the voucher added when you use function apply
How to use
you have 2 static classes
// $code : voucher code // model : which model uses this voucher // amount : the amount that you want to apply voucher on it // return : voucher object if passed all conditions ex if not passed VoucherFactory::get(string $code,Model $user,float $amount)->check()->get() // if you pass 0 that mean the voucher applied and not used // applay will add the model to voucher if passes the conditions and increment uses column VoucherFactory::get(string $code,Model $user,float $amount)->check()->apply(1)->get()
If you want to avoid all checks and apply the voucher
VoucherFactory::get(string $code,Model $user,float $amount)->apply(bool $is_used, string $code, Model $model))
Advanced use
what about you have an extra conditions like you want to add voucher with only country ,service , products or categories
Using
VoucherFactory::get(string $code,Model $user)->check() // it tacks table name as a key and array of ids ->append( [ "categories" => [1,2,3], "products" => [1,2,3], ] ) ->apply(1)->get()
you just need to add your audiences in Vouchers Audiences table
if you want to overwrite the implementation class change the class path in voucher_implementations table and extend from DefaultVoucher class