123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359 |
- <?php
- // +----------------------------------------------------------------------
- // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
- // +----------------------------------------------------------------------
- // | Copyright (c) 2016~2023 https://www.crmeb.com All rights reserved.
- // +----------------------------------------------------------------------
- // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
- // +----------------------------------------------------------------------
- // | Author: CRMEB Team <admin@crmeb.com>
- // +----------------------------------------------------------------------
- namespace app\model\product\product;
- use crmeb\basic\BaseModel;
- use crmeb\traits\ModelTrait;
- use think\Model;
- /**
- * 商品Model
- * Class StoreProduct
- * @package app\model\product\product
- */
- class StoreProduct extends BaseModel
- {
- use ModelTrait;
- /**
- * 数据表主键
- * @var string
- */
- protected $pk = 'id';
- /**
- * 模型名称
- * @var string
- */
- protected $name = 'store_product';
- /**
- * 一对一关联
- * 商品关联商品商品详情
- * @return \think\model\relation\HasOne
- */
- public function description()
- {
- return $this->hasOne(StoreDescription::class, 'product_id', 'id')->where('type', 0)->bind(['description']);
- }
- /**
- * 一对多关联
- * 商品关联优惠卷模板id
- * @return \think\model\relation\HasMany
- */
- public function couponId()
- {
- return $this->hasMany(StoreProductCoupon::class, 'product_id', 'id');
- }
- /**
- * 优惠券名称一对多
- * @return \think\model\relation\HasMany
- */
- public function coupons()
- {
- return $this->hasMany(StoreProductCoupon::class, 'product_id', 'id');
- }
- /**
- * 评论一对多
- * @return \think\model\relation\HasMany
- */
- public function star()
- {
- return $this->hasMany(StoreProductReply::class, 'product_id', 'id')->where('is_del', 0)->field('product_score,product_id');
- }
- /**
- * 分类一对多
- * @return \think\model\relation\HasMany
- */
- public function cateName()
- {
- return $this->hasMany(StoreProductCate::class, 'product_id', 'id')->with('cateName');
- }
- /**
- * 轮播图获取器
- * @param $value
- * @return array|mixed
- */
- public function getSliderImageAttr($value)
- {
- return is_string($value) ? json_decode($value, true) : [];
- }
- /**
- * 是否显示搜索器
- * @param $query
- * @param $value
- */
- public function searchIsShowAttr($query, $value)
- {
- if ($value != -1) $query->where('is_show', $value ?? 1);
- }
- /**
- * @param Model $query
- * @param $value
- */
- public function searchIdAttr($query, $value)
- {
- if (is_array($value)) {
- $query->whereIn('id', $value);
- } else {
- $query->where('id', $value);
- }
- }
- /**
- * 是否删除搜索器
- * @param Model $query
- * @param $value
- */
- public function searchIsDelAttr($query, $value)
- {
- $query->where('is_del', $value ?: 0);
- }
- /**
- * 商户ID搜索器
- * @param Model $query
- * @param $value
- */
- public function searchMerIdAttr($query, $value)
- {
- $query->where('mer_id', $value ?? 0);
- }
- /**
- * keyword搜索器
- * @param Model $query
- * @param $value
- * @param $data
- */
- public function searchStoreNameAttr($query, $value, $data)
- {
- if ($value != '') {
- $field = 'keyword|store_name|store_info|id';
- if (is_string($value)) {
- $query->whereLike($field, htmlspecialchars("%" . trim($value) . "%"));
- } elseif (is_array($value) && count($value) > 0) {
- $query->where(function ($q) use ($value, $field) {
- $data = [];
- foreach ($value as $k) {
- $data[] = [$field, 'like', "%" . trim($k) . "%"];
- }
- $q->whereOr($data);
- });
- }
- }
- }
- /**
- * 新品商品搜索器
- * @param Model $query
- * @param int $value
- */
- public function searchIsNewAttr($query, $value)
- {
- if ($value) $query->where('is_new', $value);
- }
- /**
- * 优惠商品搜索器
- * @param Model $query
- * @param int $value
- */
- public function searchIsBenefitAttr($query, $value)
- {
- $query->where('is_benefit', $value ?? 1);
- }
- /**
- * 热卖商品搜索器
- * @param Model $query
- * @param int $value
- */
- public function searchIsHotAttr($query, $value)
- {
- $query->where('is_hot', $value ?? 1);
- }
- /**
- * 精品商品搜索器
- * @param Model $query
- * @param int $value
- */
- public function searchIsBestAttr($query, $value)
- {
- $query->where('is_best', $value ?? 1);
- }
- /**
- * 精品商品搜索器
- * @param Model $query
- * @param int $value
- */
- public function searchIsGoodAttr($query, $value)
- {
- $query->where('is_good', $value ?? 1);
- }
- /**
- * 标签商品搜索器
- * @param Model $query
- * @param int $value
- */
- public function searchLabelIdAttr($query, $value)
- {
- $query->whereFindInSet('label_id', $value);
- }
- /**
- * SPU搜索器
- * @param Model $query
- * @param int $value
- */
- public function searchSpuAttr($query, $value)
- {
- $query->where('spu', $value);
- }
- /**
- * 库存搜索器
- * @param Model $query
- * @param int $value
- */
- public function searchStockAttr($query, $value)
- {
- $query->where('stock', $value);
- }
- /**
- * 会员专属商品搜索器
- * @param Model $query
- * @param int $value
- */
- public function searchVipUserAttr($query, $value)
- {
- if ($value === 0) {
- $query->where('vip_product', 0);
- }
- }
- /**
- * 是否虚拟商品搜索器
- * @param $query
- * @param $value
- */
- public function searchIsVirtualAttr($query, $value)
- {
- if ($value == 0) {
- $query->where('virtual_type', 0)->where('vip_product', 0)->where('presale', 0);
- }
- }
- /**
- * 是否预售商品
- * @param $query
- * @param $value
- */
- public function searchIsPresaleAttr($query, $value)
- {
- if ($value >= 0) {
- $query->where('presale', $value);
- }
- }
- /**
- * 分类搜索器
- * @param Model $query
- * @param int $value
- */
- public function searchCateIdAttr($query, $value)
- {
- if ($value) {
- if (is_array($value)) {
- $query->whereIn('id', function ($query) use ($value) {
- $query->name('store_product_cate')->where('cate_id', 'IN', $value)->field('product_id')->select();
- });
- } else {
- $query->whereFindInSet('cate_id', $value);
- }
- }
- }
- /**
- * 商品数量条件搜索器
- * @param Model $query
- * @param $value
- * @param $data
- */
- public function searchTypeAttr($query, $value, $data)
- {
- switch ((int)$value) {
- case 1:
- $query->where(['is_show' => 1, 'is_del' => 0]);
- break;
- case 2:
- $query->where(['is_show' => 0, 'is_del' => 0]);
- break;
- case 3:
- $query->where(['is_del' => 0]);
- break;
- case 4:
- $query->where(['is_del' => 0])->where(function ($query) {
- $query->whereIn('id', function ($query) {
- $query->name('store_product_attr_value')->where('stock', 0)->where('type', 0)->field('product_id')->select();
- })->whereOr('stock', 0);
- });
- break;
- case 5:
- if (isset($data['store_stock']) && $data['store_stock']) {
- $store_stock = $data['store_stock'];
- $query->whereIn('id', function ($query) use ($store_stock) {
- $query->name('store_product_attr_value')->where('stock', '<', $store_stock)->where('stock', '>', 0)->where('type', 0)->field('product_id')->select();
- });
- } else {
- $query->where(['is_show' => 1, 'is_del' => 0])->where('stock', '>', 0);
- }
- break;
- case 6:
- $query->where(['is_del' => 1]);
- break;
- }
- }
- /**
- * 在当前id中查询
- * @param $query
- * @param $value
- */
- public function searchIdsAttr($query, $value)
- {
- if (is_string($value)) $value = explode(',', $value);
- if (count($value)) $query->whereIn('id', $value);
- }
- /**
- * 不在当前id中查询
- * @param $query
- * @param $value
- */
- public function searchNotIdsAttr($query, $value)
- {
- if ($value != '') $query->whereNotIn('id', $value);
- }
- }
|