CustomCoupon.php 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  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. /**
  7. * 客户优惠券接口
  8. *
  9. * @author 刘相欣
  10. *
  11. * */
  12. class CustomCoupon extends Api{
  13. /**
  14. * 获取客户优惠券列表 /api/custom_coupon/get_list
  15. *
  16. * @param string $code 授权码
  17. *
  18. * */
  19. public function get_list(Model $Model,CouponRebate $CouponRebate,CouponProduct $CouponProduct){
  20. // 接口验签
  21. // $this->verify_sign();
  22. // 检查登录
  23. $uid = $this->checkLogin();
  24. // 接收参数
  25. $limit = request('limit',10);
  26. // 显示
  27. $map = [['custom_coupon.custom_uid','=',$uid],['custom_coupon.status','<>','4']];
  28. // 查询
  29. $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']);
  30. // 通过优惠券ID,查询赠品
  31. $rebates = $CouponRebate->getRebatesByCouponIds(array_column($Paginator->items(),'coupon_id'));
  32. // 商品范围
  33. $products = $CouponProduct->getProductList(array_column($Paginator->items(),'coupon_id'));
  34. // 循环处理数据
  35. foreach ($Paginator as $key => $value) {
  36. $rebateScope = [];
  37. // 获取赠品列表
  38. foreach ($rebates as $vv) {
  39. // 获取优惠券的赠品
  40. if( $vv['coupon_id'] == $value['coupon_id'] ) {
  41. unset($vv['coupon_id']);
  42. // 赠品信息
  43. $rebateScope[] = $vv;
  44. }
  45. }
  46. // 如果过期时间
  47. if( $value['status'] == 0 && $value['exp_time'] < time() ) {
  48. // 设置过期状态
  49. $Model->setStatusByExpire();
  50. // 状态设置
  51. $value['status'] = 3;
  52. }
  53. // 赠品范围
  54. $value['rebate_scope'] = $rebateScope;
  55. // 产品范围
  56. $productScope = [];
  57. // 状态可用 且指定商品
  58. if( $value['status'] == 0 && $value['type_id'] == 1 ) {
  59. // 获取赠品列表
  60. foreach ($products as $vv) {
  61. // 获取优惠券的赠品
  62. if( $vv['coupon_id'] == $value['coupon_id'] ) {
  63. // 赠品信息
  64. $productScope[] = $vv['product_id'];
  65. }
  66. }
  67. }
  68. // 商品范围
  69. $value['product_scope'] = $productScope;
  70. // 时间
  71. $value['exp_time'] = date('Y-m-d H:i:s',$value['exp_time']);
  72. // 优惠券回馈类型
  73. $value['rebate'] = $value['rebate_type'] == 1 ? $value['rebate'] : intval($value['rebate']);
  74. // 重组
  75. $list[$key] = $value;
  76. }
  77. // 获取数据
  78. $data['total'] = $Paginator->total();
  79. $data['current_page'] = $Paginator->currentPage();
  80. $data['per_page'] = $Paginator->perPage();
  81. $data['last_page'] = $Paginator->lastPage();
  82. $data['data'] = $Paginator->items();
  83. // 返回结果
  84. return json_send(['code'=>'success','msg'=>'获取成功','data'=>$data]);
  85. }
  86. /**
  87. * 获取下单可用列表 /api/custom_coupon/get_checked
  88. *
  89. * @param string $code 授权码
  90. *
  91. * */
  92. public function get_checked(Model $Model,CouponRebate $CouponRebate,CouponProduct $CouponProduct){
  93. // 接口验签
  94. // $this->verify_sign();
  95. // 检查登录
  96. $uid = $this->checkLogin();
  97. // 查询条件
  98. $map = [['custom_coupon.custom_uid','=',$uid],['custom_coupon.status','=',0]];
  99. // 查询
  100. $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();
  101. // 通过优惠券ID,查询商品范围
  102. $products = $CouponProduct->getProductList(array_column($list,'coupon_id'));
  103. // 通过优惠券ID,查询赠品
  104. $rebates = $CouponRebate->getRebatesByCouponIds(array_column($list,'coupon_id'));
  105. // 循环处理数据
  106. foreach ($list as $key => $value) {
  107. // 适用范围
  108. $productScope = [];
  109. // 如果是商品表,获取范围
  110. if( $value['type_id'] == 1 ){
  111. // 获取适用的商品范围
  112. foreach ($products as $vv) {
  113. // 获取优惠券指定的商品
  114. if( $vv['coupon_id'] == $value['coupon_id'] ) {
  115. unset($vv['coupon_id']);
  116. $productScope[] = $vv;
  117. }
  118. }
  119. }
  120. // 适用范围
  121. $value['product_scope'] = $productScope;
  122. // 赠品范围
  123. $rebateScope = [];
  124. // 获取赠品列表
  125. foreach ($rebates as $vv) {
  126. // 获取优惠券的赠品
  127. if( $vv['coupon_id'] == $value['coupon_id'] ) {
  128. unset($vv['coupon_id']);
  129. // 赠品信息
  130. $rebateScope[] = $vv;
  131. }
  132. }
  133. // 赠品范围
  134. $value['rebate_scope'] = $rebateScope;
  135. // 如果过期时间
  136. if( $value['exp_time'] < time() ) {
  137. // 设置过期状态
  138. $Model->setStatusByExpire();
  139. // 状态设置
  140. $value['status'] = 3;
  141. }
  142. // 时间
  143. $value['exp_time'] = date('Y-m-d H:i:s',$value['exp_time']);
  144. // 优惠券回馈类型
  145. $value['rebate'] = $value['rebate_type'] == 1 ? $value['rebate'] : intval($value['rebate']);
  146. // 重组
  147. $list[$key] = $value;
  148. }
  149. // 返回结果
  150. return json_send(['code'=>'success','msg'=>'获取成功','data'=>$list]);
  151. }
  152. }