BargainInitiate.php 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | likeshop100%开源免费商用商城系统
  4. // +----------------------------------------------------------------------
  5. // | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
  6. // | 开源版本可自由商用,可去除界面版权logo
  7. // | 商业版本务必购买商业授权,以免引起法律纠纷
  8. // | 禁止对系统程序代码以任何目的,任何形式的再发布
  9. // | gitee下载:https://gitee.com/likeshop_gitee
  10. // | github下载:https://github.com/likeshop-github
  11. // | 访问官网:https://www.likeshop.cn
  12. // | 访问社区:https://home.likeshop.cn
  13. // | 访问手册:http://doc.likeshop.cn
  14. // | 微信公众号:likeshop技术社区
  15. // | likeshop团队 版权所有 拥有最终解释权
  16. // +----------------------------------------------------------------------
  17. // | author: likeshopTeam
  18. // +----------------------------------------------------------------------
  19. namespace app\common\model;
  20. use app\common\enum\BargainEnum;
  21. use think\model\concern\SoftDelete;
  22. class BargainInitiate extends BaseModel
  23. {
  24. use SoftDelete;
  25. protected $deleteTime = 'delete_time';
  26. protected $autoWriteTimestamp = true;
  27. // 设置json类型字段
  28. protected $json = ['goods_snapshot', 'bargain_snapshot'];
  29. // 设置json数据返回数组
  30. protected $jsonAssoc = true;
  31. // 设置JSON字段的类型
  32. protected $jsonType = [
  33. 'goods_snapshot->goods_id' => 'int',
  34. 'goods_snapshot->item_id' => 'int',
  35. ];
  36. /**
  37. * @notes 状态描述获取器
  38. * @param $value
  39. * @return string|string[]
  40. * @author Tab
  41. * @date 2021/9/18 11:33
  42. */
  43. public function getStatusDescAttr($value)
  44. {
  45. return BargainEnum::getStatusDesc($value);
  46. }
  47. /**
  48. * @notes 砍价进度 - 按钮
  49. * @param $bargainInitiate
  50. * @return array
  51. * @author Tab
  52. * @date 2021/9/18 16:43
  53. */
  54. public static function getBtns($bargainInitiate)
  55. {
  56. $user_id = request()->userInfo['user_id'];
  57. $helpBtn = $buyNowBtn = $buyAllowBtn = $viewOrderBtn = false;
  58. // 砍价成功已下单
  59. if ($bargainInitiate['status'] == BargainEnum::STATUS_SUCCESS && empty($bargainInitiate['order_id'])) {
  60. if ($bargainInitiate['user_id'] == $user_id) {
  61. $viewOrderBtn = true;
  62. }
  63. }
  64. // 砍价成功未下单
  65. if ($bargainInitiate['status'] == BargainEnum::STATUS_SUCCESS && empty($bargainInitiate['order_id'])) {
  66. if ($bargainInitiate['user_id'] == $user_id) {
  67. $buyAllowBtn = true;
  68. }
  69. }
  70. // 砍价中 且 任意金额可购买
  71. if ($bargainInitiate['status'] == BargainEnum::STATUS_ING && $bargainInitiate['bargain_snapshot']['buy_condition'] == BargainEnum::BUY_CONDITION_RAND) {
  72. if ($bargainInitiate['user_id'] == $user_id) {
  73. $buyNowBtn = true;
  74. }
  75. }
  76. // 砍价中 且 砍价未结束
  77. if ($bargainInitiate['status'] == BargainEnum::STATUS_ING && $bargainInitiate['end_time'] > time()) {
  78. $helpBtn = true;
  79. }
  80. return [
  81. // 邀请好友帮砍按钮
  82. 'help_btn' => $helpBtn,
  83. // 直接购买按钮
  84. 'buy_now_btn' => $buyNowBtn,
  85. // 立即购买按钮
  86. 'buy_allow_btn' => $buyAllowBtn,
  87. // 查看订单按钮
  88. 'view_order_btn' => $viewOrderBtn
  89. ];
  90. }
  91. /**
  92. * @notes 分享砍价详情 - 按钮
  93. * @param $bargainInitiate
  94. * @param $userId
  95. * @return array
  96. * @author Tab
  97. * @date 2021/9/18 17:42
  98. */
  99. public static function getBtns2($bargainInitiate, $userId)
  100. {
  101. $initiateBtn = $helpBtn = false;
  102. // 砍价活动列表
  103. $where = [
  104. // 进行中状态
  105. ['ba.status', '=', BargainEnum::ACTIVITY_STATUS_ING],
  106. // 已到活动开始时间
  107. ['ba.start_time', '<=', time()],
  108. // 未到活动结束时间
  109. ['ba.end_time', '>', time()],
  110. ];
  111. $field = [
  112. 'g.image' => 'goods_image',
  113. 'g.name' => 'goods_name',
  114. 'g.max_price' => 'goods_max_price',
  115. 'ba.end_time',
  116. 'bg.activity_id' => 'bargain_min_price',
  117. 'bg.activity_id',
  118. 'bg.goods_id',
  119. ];
  120. $count = BargainGoods::alias('bg')
  121. ->leftJoin('goods g', 'g.id = bg.goods_id')
  122. ->leftJoin('bargain_activity ba', 'ba.id = bg.activity_id')
  123. ->distinct(true)
  124. ->field($field)
  125. ->where($where)
  126. ->select()
  127. ->toArray();
  128. if ($count > 0) {
  129. $initiateBtn = true;
  130. }
  131. // 查询是否帮砍过
  132. $count = BargainHelp::where([
  133. 'initiate_id' => $bargainInitiate['id'],
  134. 'user_id' => $userId,
  135. ])->count();
  136. // 砍价活动未结束 且 未帮砍过
  137. if ($bargainInitiate['end_time'] > time() && $count == 0) {
  138. $helpBtn = true;
  139. }
  140. return [
  141. // 我也要发起砍价按钮
  142. 'initiate_btn' => $initiateBtn,
  143. // 帮助砍价按钮
  144. 'help_btn' => $helpBtn,
  145. ];
  146. }
  147. /**
  148. * @notes 商品信息搜索器
  149. * @param $query
  150. * @param $value
  151. * @param $data
  152. * @author Tab
  153. * @date 2021/9/24 16:43
  154. */
  155. public function searchGoodsInfoAttr($query, $value, $data)
  156. {
  157. if (isset($data['goods_info']) && !empty($data['goods_info'])) {
  158. $goodsIds = Goods::where('name|code', 'like', '%'. $data['goods_info'] .'%')->column('id');
  159. $initiateIds = BargainInitiate::where('goods_snapshot->goods_id', 'in', $goodsIds)->column('id');
  160. $query->where('bi.id', 'in', $initiateIds);
  161. }
  162. }
  163. /**
  164. * @notes 用户信息搜索器
  165. * @param $query
  166. * @param $value
  167. * @param $data
  168. * @author Tab
  169. * @date 2021/9/24 16:52
  170. */
  171. public function searchUserInfoAttr($query, $value, $data)
  172. {
  173. if (isset($data['user_info']) && !empty($data['user_info'])) {
  174. $userIds = User::where('sn|nickname', 'like', '%'. $data['user_info'] .'%')->column('id');
  175. $initiateIds = BargainInitiate::where('user_id', 'in', $userIds)->column('id');
  176. $query->where('bi.id', 'in', $initiateIds);
  177. }
  178. }
  179. /**
  180. * @notes 活动信息搜索器
  181. * @param $query
  182. * @param $value
  183. * @param $data
  184. * @author Tab
  185. * @date 2021/9/24 16:52
  186. */
  187. public function searchActivityInfoAttr($query, $value, $data)
  188. {
  189. if (isset($data['activity_info']) && !empty($data['activity_info'])) {
  190. $activityIds = BargainActivity::where('name', 'like', '%'. $data['activity_info'] .'%')->column('id');
  191. $query->where('bi.activity_id', 'in', $activityIds);
  192. }
  193. }
  194. }