CustomCoupon.php 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213
  1. <?php namespace App\Http\Controllers\Api;
  2. use App\Http\Controllers\Api\Api;
  3. use App\Models\CouponProduct;
  4. use App\Models\CouponRebate;
  5. use App\Models\CustomCoupon as Model;
  6. use App\Http\Requests\Api\Coupon\Custom as Request;
  7. use App\Models\Coupon;
  8. use App\Models\Custom;
  9. /**
  10. * 客户优惠券接口
  11. *
  12. * @author 刘相欣
  13. *
  14. * */
  15. class CustomCoupon extends Api{
  16. /**
  17. * 获取客户优惠券列表 /api/custom_coupon/get_list
  18. *
  19. * @param string $code 授权码
  20. *
  21. * */
  22. public function get_list(Model $Model,CouponRebate $CouponRebate,CouponProduct $CouponProduct){
  23. // 接口验签
  24. // $this->verify_sign();
  25. // 检查登录
  26. $uid = $this->checkLogin();
  27. // 接收参数
  28. $limit = request('limit',10);
  29. // 显示
  30. $map = [['custom_coupon.custom_uid','=',$uid],['custom_coupon.status','<>','4']];
  31. // 查询
  32. $Paginator = $Model->query()->join('coupon','custom_coupon.coupon_id','=','coupon.id')->where($map)->orderBy('custom_coupon.status')->paginate($limit,['custom_coupon.id','coupon.id as coupon_id','coupon.name','coupon.type_id','coupon.rebate_type','coupon.std_pay','coupon.rebate','custom_coupon.status','custom_coupon.exp_time']);
  33. // 通过优惠券ID,查询赠品
  34. $rebates = $CouponRebate->getRebatesByCouponIds(array_column($Paginator->items(),'coupon_id'));
  35. // 商品范围
  36. $products = $CouponProduct->getProductList(array_column($Paginator->items(),'coupon_id'));
  37. // 循环处理数据
  38. foreach ($Paginator as $key => $value) {
  39. $rebateScope = [];
  40. // 获取赠品列表
  41. foreach ($rebates as $vv) {
  42. // 获取优惠券的赠品
  43. if( $vv['coupon_id'] == $value['coupon_id'] ) {
  44. unset($vv['coupon_id']);
  45. // 赠品信息
  46. $rebateScope[] = $vv;
  47. }
  48. }
  49. // 如果过期时间
  50. if( $value['status'] == 0 && $value['exp_time'] < time() ) {
  51. // 设置过期状态
  52. $Model->setStatusByExpire();
  53. // 状态设置
  54. $value['status'] = 3;
  55. }
  56. // 赠品范围
  57. $value['rebate_scope'] = $rebateScope;
  58. // 产品范围
  59. $productScope = [];
  60. // 状态可用 且指定商品
  61. if( $value['status'] == 0 && $value['type_id'] == 1 ) {
  62. // 获取赠品列表
  63. foreach ($products as $vv) {
  64. // 获取优惠券的赠品
  65. if( $vv['coupon_id'] == $value['coupon_id'] ) {
  66. // 赠品信息
  67. $productScope[] = $vv['product_id'];
  68. }
  69. }
  70. }
  71. // 商品范围
  72. $value['product_scope'] = $productScope;
  73. // 时间
  74. $value['exp_time'] = date('Y-m-d H:i:s',$value['exp_time']);
  75. // 优惠券回馈类型
  76. $value['rebate'] = $value['rebate_type'] == 1 ? $value['rebate'] : intval($value['rebate']);
  77. // 重组
  78. $list[$key] = $value;
  79. }
  80. // 获取数据
  81. $data['total'] = $Paginator->total();
  82. $data['current_page'] = $Paginator->currentPage();
  83. $data['per_page'] = $Paginator->perPage();
  84. $data['last_page'] = $Paginator->lastPage();
  85. $data['data'] = $Paginator->items();
  86. // 返回结果
  87. return json_send(['code'=>'success','msg'=>'获取成功','data'=>$data]);
  88. }
  89. /**
  90. * 获取下单可用列表 /api/custom_coupon/get_checked
  91. *
  92. * @param string $code 授权码
  93. *
  94. * */
  95. public function get_checked(Model $Model,CouponRebate $CouponRebate,CouponProduct $CouponProduct){
  96. // 接口验签
  97. // $this->verify_sign();
  98. // 检查登录
  99. $uid = $this->checkLogin();
  100. // 查询条件
  101. $map = [['custom_coupon.custom_uid','=',$uid],['custom_coupon.status','=',0]];
  102. // 查询
  103. $list = $Model->query()->join('coupon','custom_coupon.coupon_id','=','coupon.id')->where($map)->orderBy('custom_coupon.status')->get(['custom_coupon.id','coupon.id as coupon_id','coupon.name','coupon.type_id','coupon.rebate_type','coupon.std_pay','coupon.rebate','custom_coupon.status','custom_coupon.exp_time'])->toArray();
  104. // 通过优惠券ID,查询商品范围
  105. $products = $CouponProduct->getProductList(array_column($list,'coupon_id'));
  106. // 通过优惠券ID,查询赠品
  107. $rebates = $CouponRebate->getRebatesByCouponIds(array_column($list,'coupon_id'));
  108. // 循环处理数据
  109. foreach ($list as $key => $value) {
  110. // 适用范围
  111. $productScope = [];
  112. // 如果是商品表,获取范围
  113. if( $value['type_id'] == 1 ){
  114. // 获取适用的商品范围
  115. foreach ($products as $vv) {
  116. // 获取优惠券指定的商品
  117. if( $vv['coupon_id'] == $value['coupon_id'] ) {
  118. unset($vv['coupon_id']);
  119. $productScope[] = $vv;
  120. }
  121. }
  122. }
  123. // 适用范围
  124. $value['product_scope'] = $productScope;
  125. // 赠品范围
  126. $rebateScope = [];
  127. // 获取赠品列表
  128. foreach ($rebates as $vv) {
  129. // 获取优惠券的赠品
  130. if( $vv['coupon_id'] == $value['coupon_id'] ) {
  131. unset($vv['coupon_id']);
  132. // 赠品信息
  133. $rebateScope[] = $vv;
  134. }
  135. }
  136. // 赠品范围
  137. $value['rebate_scope'] = $rebateScope;
  138. // 如果过期时间
  139. if( $value['exp_time'] < time() ) {
  140. // 设置过期状态
  141. $Model->setStatusByExpire();
  142. // 状态设置
  143. $value['status'] = 3;
  144. }
  145. // 时间
  146. $value['exp_time'] = date('Y-m-d H:i:s',$value['exp_time']);
  147. // 优惠券回馈类型
  148. $value['rebate'] = $value['rebate_type'] == 1 ? $value['rebate'] : intval($value['rebate']);
  149. // 重组
  150. $list[$key] = $value;
  151. }
  152. // 返回结果
  153. return json_send(['code'=>'success','msg'=>'获取成功','data'=>$list]);
  154. }
  155. /**
  156. * 领取优惠券 /api/custom_coupon/get_coupon
  157. *
  158. *
  159. * */
  160. public function get_coupon(Request $request,Model $Model,Coupon $Coupon,Custom $Custom){
  161. // 验证参数
  162. $request->scene('get_coupon')->validate();
  163. // 检查登录
  164. $uid = $this->checkLogin();
  165. // 接收参数
  166. $couponId = request('coupon_id',0);
  167. // 查询优惠券信息
  168. $couponInfo = $Coupon->getOne($couponId);
  169. // 判断优惠券是否可以领取
  170. if( !$couponInfo ) return json_send(['code'=>'error','msg'=>'优惠券不存在或者未上架']);
  171. // 判断优惠券是否可以领取
  172. if( $couponInfo['status'] ) return json_send(['code'=>'error','msg'=>'已结束发放']);
  173. // 时间
  174. if( $couponInfo['start_time'] > time() ) return json_send(['code'=>'error','msg'=>'还没到发放时间哦']);
  175. // 时间
  176. if( $couponInfo['end_time'] <= time() ) return json_send(['code'=>'error','msg'=>'发放时间已经结束了']);
  177. // 如果限制了城市
  178. if( $couponInfo['city_ids'] ) {
  179. // 解析数组
  180. $couponInfo['city_ids'] = explode(',',$couponInfo['city_ids']);
  181. // 获取客户信息
  182. $custom = $Custom->getOne($uid);
  183. // 如果存在的话
  184. if( !$custom ) return json_send(['code'=>'no_login','msg'=>'请登录','data'=>['error'=>'无对应客户']]);
  185. // 如果在城市范围
  186. if( !in_array($custom['city_id'],$couponInfo['city_ids']) ) return json_send(['code'=>'error','msg'=>'客户城市不在领取范围','data'=>['error'=>'客户城市不在领取范围']]);
  187. }
  188. // 如果已经领取过
  189. $isHave = $Model->query()->where([['coupon_id','=',$couponId],['custom_uid','=',$uid]])->count();
  190. // 如果超过数量,不允许发放
  191. if( $isHave ) return json_send(['code'=>'error','msg'=>'已经领取过啦']);
  192. // 查询该优惠券已经发放的数量
  193. $countTotal = $Model->query()->where([['coupon_id','=',$couponId]])->count();
  194. // 如果超过数量,不允许发放
  195. if( $couponInfo['issue_total'] <= $countTotal ) return json_send(['code'=>'error','msg'=>'优惠券已发完']);
  196. // 写入信息
  197. $insertData = ['coupon_id'=>$couponId,'custom_uid'=>$uid,'exp_time'=>$Coupon->getExpTime($couponInfo['exp_time'])];
  198. // 写入表格
  199. $result = $Model->add($insertData);
  200. // 提示
  201. if( !$result ) return json_send(['code'=>'error','msg'=>'领取失败,请重试']);
  202. // 返回成功
  203. return json_send(['code'=>'success','msg'=>'领取成功']);
  204. }
  205. }