定制 boddasaad/laravel-discountable 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

boddasaad/laravel-discountable

最新稳定版本:v1.0.1

Composer 安装命令:

composer require boddasaad/laravel-discountable

包简介

Allow your laravel models to redeem vouchers and apply discounts.

README 文档

README

Laravel Discountable

Discountable

Make your models discountable with Laravel, allowing you to apply vouchers with lots of options and conditions. Here's a quick example of how to use the package:

$student = Student::find(1);
// Check if the voucher is valid and can be applied (useful for UI validation before applying)
$student->checkVoucher('SUMMER2023', 100);

// Redeem the voucher, applying the discount
$student->redeemVoucher('SUMMER2023', 100);

Installation

You can install the package via composer:

composer require boddasaad/laravel-discountable

php artisan discountable:install

This is the contents of the published config file:

return [
    /*
     * Database table name that will be used to store vouchers.
     */
    'table' => 'vouchers',

    /*
     * Database table name that will be used to store voucher usages.
     */
    'usage_table' => 'voucher_usages',

    /*
     * List of characters that will be used for voucher code generation.
     */
    'characters' => '23456789ABCDEFGHJKLMNPQRSTUVWXYZ',

    /*
     * Voucher code prefix.
     *
     * Example: foo
     * Generated Code: foo-AGXF-1NH8
     */
    'prefix' => null,

    /*
     * Voucher code suffix.
     *
     * Example: foo
     * Generated Code: AGXF-1NH8-foo
     */
    'suffix' => null,

    /*
     * Code mask.
     * All asterisks will be removed by random characters.
     */
    'mask' => '****-****',

    /*
     * Separator to be used between prefix, code and suffix.
     */
    'separator' => '-',
];

Usage

To use the package, you need to add the CanRedeemVouchers trait to your model:

namespace App\Models;

use BoddaSaad\Voucher\Traits\CanRedeemVouchers;

class User extends Authenticatable
{
    use CanRedeemVouchers;
    # ...
}

Creating Vouchers

You can create vouchers using the Voucher Facade. Here's an example of how to create a voucher with various options:

use BoddaSaad\Voucher\Facades\Voucher;

$voucher = Voucher::maximumRedeems(1000)
        ->discount('percentage', 20)
        ->date('2025-01-01', '2025-12-31')
        ->minimumQualifyingAmount(50)
        ->maximumDiscountAmount(100)
        ->maxUsagesPerModel(1)
        ->data(['description' => 'Holiday Discount'])
        ->create();

Voucher Facade Methods

Method Description
discount(type, value) If type is percentage, value should be between 0 and 100. If type is fixed, value should be a positive number.
maximumRedeems(int $max) This limits how many times the voucher can be redeemed in total.
date(start, end) Both dates should be in Y-m-d format. The voucher will be valid between these dates.
minimumQualifyingAmount(n) This is the minimum amount that must be spent to apply the voucher.
maximumDiscountAmount(n) This limits the discount to a maximum value. For percentage discounts, this is the maximum amount that can be discounted.
maxUsagesPerModel(n) This limits how many times a single model can use the voucher.
data(array $data) This can be any additional information you want to store with the voucher, such as a description or terms and conditions.
prefix(string $prefix) This allows you to specify a prefix for the voucher code dynamically.
suffix(string $suffix) This allows you to specify a suffix for the voucher code dynamically.
separator(string $sep) This allows you to specify a custom separator for the voucher code dynamically.
create() This method will generate the voucher code and save it to the database. (MUST BE CALLED LAST)

Applying Vouchers

To apply a voucher, you can use the checkVoucher and redeemVoucher methods provided by the CanRedeemVouchers trait.

Check Voucher Validity

This is useful for UI validation before applying the voucher so the user can see if the voucher is valid or not.:

auth()->user()->checkVoucher('SUMMER2023', 100);

This will return an object with the following properties if the voucher is valid:

[
    'valid' => true,
    'final_amount' => 80, // The amount after applying the voucher
    'voucher_id' => 1 // The ID of the voucher
]

If the voucher is not valid, it will return an object with the following properties:

[
    'valid' => false,
    'message' => 'Voucher has expired' // The reason why the voucher is not valid
]

Redeem Voucher

To redeem the voucher and apply the discount, you can use the redeemVoucher method:

auth()->user()->redeemVoucher('SUMMER2023', 100);
// Will return true if the voucher was successfully redeemed, or false if it was not.

Testing

composer test

Changelog

Please see CHANGELOG for more information on what has changed recently.

Contributing

Please see CONTRIBUTING for details.

Security Vulnerabilities

Please review our security policy on how to report security vulnerabilities.

Credits

License

The MIT License (MIT). Please see License File for more information.

统计信息

  • 总下载量: 2
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 2
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 2
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-06-19