vanthao03596/cartly 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

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

vanthao03596/cartly

最新稳定版本:v1.2.0

Composer 安装命令:

composer require vanthao03596/cartly

包简介

A flexible, customizable shopping cart library for Laravel with dynamic pricing

README 文档

README

A flexible, customizable shopping cart library for Laravel with dynamic pricing.

Latest Version on Packagist Total Downloads License

Features

  • No Stored Prices - All prices resolved at runtime via pluggable resolvers
  • Multiple Storage Drivers - Session, Database, Cache, or custom implementations
  • Multiple Cart Instances - Support cart, wishlist, compare, and custom instances
  • Flexible Conditions - Tax, discounts, shipping, and custom fee modifiers
  • Event-Driven Architecture - Hooks into every cart operation
  • Guest-to-User Cart Merging - Seamlessly merge carts on user login
  • Comprehensive Testing Utilities - Fake mode, assertions, and factories

Requirements

  • PHP 8.1+
  • Laravel 10.0, 11.0 or 12.0

Installation

composer require vanthao03596/cartly

The package uses Laravel's auto-discovery, so the service provider and facade are registered automatically.

Publish Configuration

php artisan vendor:publish --provider="Cart\CartServiceProvider" --tag="config"

Database Driver Setup (Optional)

If you want to use the database driver for persistent storage:

php artisan vendor:publish --provider="Cart\CartServiceProvider" --tag="migrations"
php artisan migrate

Quick Start

Basic Usage

use Cart\Cart;

// Add an item to cart
$item = Cart::add($product, quantity: 2);

// Add with options
$item = Cart::add($product, quantity: 1, options: ['size' => 'L', 'color' => 'blue']);

// Update quantity
Cart::update($item->rowId, 5);

// Remove item
Cart::remove($item->rowId);

// Get totals (in cents)
$subtotal = Cart::subtotal();  // 4999
$total = Cart::total();        // 5499 (with tax)

// Clear cart
Cart::clear();

Using Buyable Models

Implement the Buyable and Priceable interfaces on your model:

use Cart\Contracts\Buyable;
use Cart\Contracts\Priceable;
use Cart\Traits\CanBeBought;

class Product extends Model implements Buyable, Priceable
{
    use CanBeBought;

    // The trait auto-detects price from common attributes:
    // price, sale_price, current_price, original_price, regular_price
}

Or implement the methods manually:

class Product extends Model implements Buyable, Priceable
{
    public function getBuyableIdentifier(): int|string
    {
        return $this->id;
    }

    public function getBuyableDescription(): string
    {
        return $this->name;
    }

    public function getBuyableType(): string
    {
        return static::class;
    }

    public function getBuyablePrice(?CartContext $context = null): int
    {
        return $this->price; // In cents
    }

    public function getBuyableOriginalPrice(): int
    {
        return $this->original_price ?? $this->price;
    }
}

Multiple Instances

// Work with wishlist
Cart::instance('wishlist')->add($product);
// Or use magic method
Cart::wishlist()->add($product);

// Move item between instances
Cart::moveToWishlist($rowId);
Cart::moveToCart($rowId);

Conditions

use Cart\Conditions\TaxCondition;
use Cart\Conditions\DiscountCondition;

// Add 10% tax
Cart::condition(new TaxCondition('VAT', rate: 10));

// Add 15% discount
Cart::condition(new DiscountCondition('Summer Sale', value: 15, mode: 'percentage'));

// Add fixed discount
Cart::condition(new DiscountCondition('Coupon', value: 1000, mode: 'fixed')); // $10.00 off

// Get breakdown
$breakdown = Cart::getCalculationBreakdown();

Documentation

For complete documentation, see the docs folder:

Testing

composer test

License

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

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-15

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固