CustomCoupon.php 8.9 KB

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