StoreSeckill.php 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  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\activity\seckill;
  12. use app\model\product\product\StoreDescription;
  13. use app\model\product\product\StoreProduct;
  14. use app\model\product\sku\StoreProductAttrValue;
  15. use crmeb\basic\BaseModel;
  16. use crmeb\traits\ModelTrait;
  17. use think\Model;
  18. /**
  19. * TODO 秒杀商品Model
  20. * Class StoreSeckill
  21. * @package app\model\activity
  22. */
  23. class StoreSeckill extends BaseModel
  24. {
  25. /**
  26. * 数据表主键
  27. * @var string
  28. */
  29. protected $pk = 'id';
  30. /**
  31. * 模型名称
  32. * @var string
  33. */
  34. protected $name = 'store_seckill';
  35. use ModelTrait;
  36. /**
  37. * 一对一关联
  38. * 商品关联商品商品详情
  39. * @return \think\model\relation\HasOne
  40. */
  41. public function description()
  42. {
  43. return $this->hasOne(StoreDescription::class, 'product_id', 'id')->where('type', 1)->bind(['description']);
  44. }
  45. /**
  46. * 一对一关联
  47. * 商品关联商品商品详情
  48. * @return \think\model\relation\HasOne
  49. */
  50. public function product()
  51. {
  52. return $this->hasOne(StoreProduct::class, 'id', 'product_id')->where('is_show', 1)->where('is_del', 0)->field(['id','cate_id','price'])->bind([
  53. 'cate_id' => 'cate_id',
  54. 'product_price' => 'price'
  55. ]);
  56. }
  57. public function attrs()
  58. {
  59. return $this->hasMany(StoreProductAttrValue::class, 'product_id', 'id')->where('type', 1);
  60. }
  61. /**
  62. * 添加时间获取器
  63. * @param $value
  64. * @return false|string
  65. */
  66. protected function getAddTimeAttr($value)
  67. {
  68. if ($value) return date('Y-m-d H:i:s', (int)$value);
  69. return '';
  70. }
  71. /**
  72. * 图片获取器
  73. * @param $value
  74. * @return array|mixed
  75. */
  76. protected function getImagesAttr($value)
  77. {
  78. return json_decode($value, true) ?: [];
  79. }
  80. /**
  81. * 秒杀商品名称搜索器
  82. * @param Model $query
  83. * @param $value
  84. * @param $data
  85. */
  86. public function searchStoreNameAttr($query, $value, $data)
  87. {
  88. if ($value) $query->where('title|id', 'like', '%' . $value . '%');
  89. }
  90. /**
  91. * 是否推荐搜索器
  92. * @param Model $query
  93. * @param $value
  94. * @param $data
  95. */
  96. public function searchIsHotAttr($query, $value, $data)
  97. {
  98. $query->where('is_hot', $value ?? 1);
  99. }
  100. /**
  101. * 状态搜索器
  102. * @param Model $query
  103. * @param $value
  104. * @param $data
  105. */
  106. public function searchIsShowAttr($query, $value, $data)
  107. {
  108. $query->where('is_show', $value ?? 1);
  109. }
  110. /**
  111. * 是否删除搜索器
  112. * @param Model $query
  113. * @param $value
  114. * @param $data
  115. */
  116. public function searchIsDelAttr($query, $value, $data)
  117. {
  118. $query->where('is_del', $value ?? 0);
  119. }
  120. /**
  121. * 状态搜索器
  122. * @param Model $query
  123. * @param $value
  124. * @param $data
  125. */
  126. public function searchStatusAttr($query, $value, $data)
  127. {
  128. if ($value != '') $query->where('status', $value);
  129. }
  130. /**
  131. * 商品ID搜索器
  132. * @param Model $query
  133. * @param $value
  134. * @param $data
  135. */
  136. public function searchProductIdAttr($query, $value, $data)
  137. {
  138. if ($value) {
  139. if (is_array($value)) {
  140. $query->whereIn('product_id', $value);
  141. } else {
  142. $query->where('product_id', $value);
  143. }
  144. }
  145. }
  146. /**
  147. * 活动有效时间搜索器
  148. * @param $query
  149. * @param $value
  150. */
  151. public function searchSeckillTimeAttr($query, $value)
  152. {
  153. if ($value == 1) {
  154. $time = time();
  155. $query->where('start_time', '<=', $time)->where('stop_time', '>=', $time - 86400);
  156. }
  157. }
  158. public function searchActivityIdAttr($query, $value)
  159. {
  160. if ($value != '') $query->where('activity_id', $value);
  161. }
  162. }