CustomCoupon.php 9.0 KB

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