StoreProduct.php 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2016~2023 https://www.crmeb.com All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
  8. // +----------------------------------------------------------------------
  9. // | Author: CRMEB Team <admin@crmeb.com>
  10. // +----------------------------------------------------------------------
  11. namespace app\model\product\product;
  12. use crmeb\basic\BaseModel;
  13. use crmeb\traits\ModelTrait;
  14. use think\Model;
  15. /**
  16. * 商品Model
  17. * Class StoreProduct
  18. * @package app\model\product\product
  19. */
  20. class StoreProduct extends BaseModel
  21. {
  22. use ModelTrait;
  23. /**
  24. * 数据表主键
  25. * @var string
  26. */
  27. protected $pk = 'id';
  28. /**
  29. * 模型名称
  30. * @var string
  31. */
  32. protected $name = 'store_product';
  33. /**
  34. * 一对一关联
  35. * 商品关联商品商品详情
  36. * @return \think\model\relation\HasOne
  37. */
  38. public function description()
  39. {
  40. return $this->hasOne(StoreDescription::class, 'product_id', 'id')->where('type', 0)->bind(['description']);
  41. }
  42. /**
  43. * 一对多关联
  44. * 商品关联优惠卷模板id
  45. * @return \think\model\relation\HasMany
  46. */
  47. public function couponId()
  48. {
  49. return $this->hasMany(StoreProductCoupon::class, 'product_id', 'id');
  50. }
  51. /**
  52. * 优惠券名称一对多
  53. * @return \think\model\relation\HasMany
  54. */
  55. public function coupons()
  56. {
  57. return $this->hasMany(StoreProductCoupon::class, 'product_id', 'id');
  58. }
  59. /**
  60. * 评论一对多
  61. * @return \think\model\relation\HasMany
  62. */
  63. public function star()
  64. {
  65. return $this->hasMany(StoreProductReply::class, 'product_id', 'id')->where('is_del', 0)->field('product_score,product_id');
  66. }
  67. /**
  68. * 分类一对多
  69. * @return \think\model\relation\HasMany
  70. */
  71. public function cateName()
  72. {
  73. return $this->hasMany(StoreProductCate::class, 'product_id', 'id')->with('cateName');
  74. }
  75. /**
  76. * 轮播图获取器
  77. * @param $value
  78. * @return array|mixed
  79. */
  80. public function getSliderImageAttr($value)
  81. {
  82. return is_string($value) ? json_decode($value, true) : [];
  83. }
  84. /**
  85. * 是否显示搜索器
  86. * @param $query
  87. * @param $value
  88. */
  89. public function searchIsShowAttr($query, $value)
  90. {
  91. if ($value != -1) $query->where('is_show', $value ?? 1);
  92. }
  93. /**
  94. * @param Model $query
  95. * @param $value
  96. */
  97. public function searchIdAttr($query, $value)
  98. {
  99. if (is_array($value)) {
  100. $query->whereIn('id', $value);
  101. } else {
  102. $query->where('id', $value);
  103. }
  104. }
  105. /**
  106. * 是否删除搜索器
  107. * @param Model $query
  108. * @param $value
  109. */
  110. public function searchIsDelAttr($query, $value)
  111. {
  112. $query->where('is_del', $value ?: 0);
  113. }
  114. /**
  115. * 商户ID搜索器
  116. * @param Model $query
  117. * @param $value
  118. */
  119. public function searchMerIdAttr($query, $value)
  120. {
  121. $query->where('mer_id', $value ?? 0);
  122. }
  123. /**
  124. * keyword搜索器
  125. * @param Model $query
  126. * @param $value
  127. * @param $data
  128. */
  129. public function searchStoreNameAttr($query, $value, $data)
  130. {
  131. if ($value != '') {
  132. $field = 'keyword|store_name|store_info|id';
  133. if (is_string($value)) {
  134. $query->whereLike($field, htmlspecialchars("%" . trim($value) . "%"));
  135. } elseif (is_array($value) && count($value) > 0) {
  136. $query->where(function ($q) use ($value, $field) {
  137. $data = [];
  138. foreach ($value as $k) {
  139. $data[] = [$field, 'like', "%" . trim($k) . "%"];
  140. }
  141. $q->whereOr($data);
  142. });
  143. }
  144. }
  145. }
  146. /**
  147. * 新品商品搜索器
  148. * @param Model $query
  149. * @param int $value
  150. */
  151. public function searchIsNewAttr($query, $value)
  152. {
  153. if ($value) $query->where('is_new', $value);
  154. }
  155. /**
  156. * 优惠商品搜索器
  157. * @param Model $query
  158. * @param int $value
  159. */
  160. public function searchIsBenefitAttr($query, $value)
  161. {
  162. $query->where('is_benefit', $value ?? 1);
  163. }
  164. /**
  165. * 热卖商品搜索器
  166. * @param Model $query
  167. * @param int $value
  168. */
  169. public function searchIsHotAttr($query, $value)
  170. {
  171. $query->where('is_hot', $value ?? 1);
  172. }
  173. /**
  174. * 精品商品搜索器
  175. * @param Model $query
  176. * @param int $value
  177. */
  178. public function searchIsBestAttr($query, $value)
  179. {
  180. $query->where('is_best', $value ?? 1);
  181. }
  182. /**
  183. * 精品商品搜索器
  184. * @param Model $query
  185. * @param int $value
  186. */
  187. public function searchIsGoodAttr($query, $value)
  188. {
  189. $query->where('is_good', $value ?? 1);
  190. }
  191. /**
  192. * 标签商品搜索器
  193. * @param Model $query
  194. * @param int $value
  195. */
  196. public function searchLabelIdAttr($query, $value)
  197. {
  198. $query->whereFindInSet('label_id', $value);
  199. }
  200. /**
  201. * SPU搜索器
  202. * @param Model $query
  203. * @param int $value
  204. */
  205. public function searchSpuAttr($query, $value)
  206. {
  207. $query->where('spu', $value);
  208. }
  209. /**
  210. * 库存搜索器
  211. * @param Model $query
  212. * @param int $value
  213. */
  214. public function searchStockAttr($query, $value)
  215. {
  216. $query->where('stock', $value);
  217. }
  218. /**
  219. * 会员专属商品搜索器
  220. * @param Model $query
  221. * @param int $value
  222. */
  223. public function searchVipUserAttr($query, $value)
  224. {
  225. if ($value === 0) {
  226. $query->where('vip_product', 0);
  227. }
  228. }
  229. /**
  230. * 是否虚拟商品搜索器
  231. * @param $query
  232. * @param $value
  233. */
  234. public function searchIsVirtualAttr($query, $value)
  235. {
  236. if ($value == 0) {
  237. $query->where('virtual_type', 0)->where('vip_product', 0)->where('presale', 0);
  238. }
  239. }
  240. /**
  241. * 是否预售商品
  242. * @param $query
  243. * @param $value
  244. */
  245. public function searchIsPresaleAttr($query, $value)
  246. {
  247. if ($value >= 0) {
  248. $query->where('presale', $value);
  249. }
  250. }
  251. /**
  252. * 分类搜索器
  253. * @param Model $query
  254. * @param int $value
  255. */
  256. public function searchCateIdAttr($query, $value)
  257. {
  258. if ($value) {
  259. if (is_array($value)) {
  260. $query->whereIn('id', function ($query) use ($value) {
  261. $query->name('store_product_cate')->where('cate_id', 'IN', $value)->field('product_id')->select();
  262. });
  263. } else {
  264. $query->whereFindInSet('cate_id', $value);
  265. }
  266. }
  267. }
  268. /**
  269. * 商品数量条件搜索器
  270. * @param Model $query
  271. * @param $value
  272. * @param $data
  273. */
  274. public function searchTypeAttr($query, $value, $data)
  275. {
  276. switch ((int)$value) {
  277. case 1:
  278. $query->where(['is_show' => 1, 'is_del' => 0]);
  279. break;
  280. case 2:
  281. $query->where(['is_show' => 0, 'is_del' => 0]);
  282. break;
  283. case 3:
  284. $query->where(['is_del' => 0]);
  285. break;
  286. case 4:
  287. $query->where(['is_del' => 0])->where(function ($query) {
  288. $query->whereIn('id', function ($query) {
  289. $query->name('store_product_attr_value')->where('stock', 0)->where('type', 0)->field('product_id')->select();
  290. })->whereOr('stock', 0);
  291. });
  292. break;
  293. case 5:
  294. if (isset($data['store_stock']) && $data['store_stock']) {
  295. $store_stock = $data['store_stock'];
  296. $query->whereIn('id', function ($query) use ($store_stock) {
  297. $query->name('store_product_attr_value')->where('stock', '<', $store_stock)->where('stock', '>', 0)->where('type', 0)->field('product_id')->select();
  298. });
  299. } else {
  300. $query->where(['is_show' => 1, 'is_del' => 0])->where('stock', '>', 0);
  301. }
  302. break;
  303. case 6:
  304. $query->where(['is_del' => 1]);
  305. break;
  306. }
  307. }
  308. /**
  309. * 在当前id中查询
  310. * @param $query
  311. * @param $value
  312. */
  313. public function searchIdsAttr($query, $value)
  314. {
  315. if (is_string($value)) $value = explode(',', $value);
  316. if (count($value)) $query->whereIn('id', $value);
  317. }
  318. /**
  319. * 不在当前id中查询
  320. * @param $query
  321. * @param $value
  322. */
  323. public function searchNotIdsAttr($query, $value)
  324. {
  325. if ($value != '') $query->whereNotIn('id', $value);
  326. }
  327. }