| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196 | <?php// +----------------------------------------------------------------------// | Niucloud-admin 企业快速开发的多应用管理平台// +----------------------------------------------------------------------// | 官方网址:https://www.niucloud.com// +----------------------------------------------------------------------// | niucloud团队 版权所有 开源版本可自由商用// +----------------------------------------------------------------------// | Author: Niucloud Team// +----------------------------------------------------------------------namespace addon\mall\app\model\cart;use addon\mall\app\model\goods\Goods;use addon\mall\app\model\goods\GoodsSku;use addon\mall\app\model\goods\GoodsSpec;use app\model\site\Site;use core\base\BaseModel;use think\model\relation\HasMany;use think\model\relation\HasOne;/** * 购物车模型 */class Cart extends BaseModel{    /**     * 数据表主键     * @var string     */    protected $pk = 'id';    /**     * 模型名称     * @var string     */    protected $name = 'mall_cart';    //类型    protected $type = [    ];    /**     * 搜索器:购物车表ID     * @param $value     * @param $data     */    public function searchIdAttr($query, $value, $data)    {        if ($value) {            $query->where('id', $value);        }    }    /**     * 搜索器:购物车会员ID     * @param $value     * @param $data     */    public function searchMemberIdAttr($query, $value, $data)    {        if ($value) {            $query->where('member_id', $value);        }    }    /**     * 搜索器:购物车商品ID     * @param $value     * @param $data     */    public function searchGoodsIdAttr($query, $value, $data)    {        if ($value) {            $query->where('goods_id', $value);        }    }    /**     * 搜索器:购物车sku id     * @param $value     * @param $data     */    public function searchSkuIdAttr($query, $value, $data)    {        if ($value) {            $query->where('sku_id', $value);        }    }    /**     * 搜索器:购物车活动类型     * @param $value     * @param $data     */    public function searchMarketTypeAttr($query, $value, $data)    {        if ($value) {            $query->where('market_type', $value);        }    }    /**     * 搜索器:购物车活动id     * @param $value     * @param $data     */    public function searchMarketTypeIdAttr($query, $value, $data)    {        if ($value) {            $query->where('market_type_id', $value);        }    }    /**     * 搜索器:购物车添加时间     * @param $value     * @param $data     */    public function searchCreateTimeAttr($query, $value, $data)    {        if ($value) {            $query->where('create_time', $value);        }    }    /**     * 搜索器:购物车商品状态     * @param $value     * @param $data     */    public function searchStatusAttr($query, $value, $data)    {        if ($value) {            $query->where('status', $value);        }    }    /**     * 搜索器:购物车失效原因     * @param $value     * @param $data     */    public function searchInvalidRemarkAttr($query, $value, $data)    {        if ($value) {            $query->where('invalid_remark', $value);        }    }    /**     * 关联商品主表     * @return HasOne     */    public function goods()    {        return $this->hasOne(Goods::class, 'goods_id', 'goods_id')            ->joinType('inner')            ->withTrashed()            ->withField('goods_id, site_id, goods_name, goods_type, sub_title, goods_cover, unit, stock, sale_num + virtual_sale_num as sale_num, status,delete_time')            ->append([ 'goods_type_name', 'goods_cover_thumb_small', 'goods_cover_thumb_mid', 'goods_cover_thumb_big' ]);    }    /**     * 关联商品规格     * @return HasOne     */    public function goodsSku()    {        return $this->hasOne(GoodsSku::class, 'sku_id', 'sku_id')            ->joinType('inner')            ->field('sku_id, site_id, sku_name, sku_image, sku_no, goods_id, sku_spec_format, price, market_price, sale_price, stock, weight, volume, is_default')            ->append([ 'sku_image_thumb_small', 'sku_image_thumb_mid', 'sku_image_thumb_big' ]);    }    /**     * 关联商品规格列表     * @return HasMany     */    public function goodsSpec()    {        return $this->hasMany(GoodsSpec::class, 'goods_id', 'goods_id');    }    /**     * 关联店铺信息     * @return HasOne     */    public function site()    {        return $this->hasOne(Site::class, 'site_id', 'site_id');    }}
 |