UniversityCourse.php 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. <?php
  2. namespace app\api\controller;
  3. use addons\epay\library\Service;
  4. use app\common\controller\Api;
  5. use app\common\model\PayOrderModel;
  6. use app\common\model\UniversityCourseApplyModel;
  7. use app\common\model\UniversityCourseModel;
  8. use app\common\model\UniversityEventApplyModel;
  9. use app\common\model\UniversityEventModel;
  10. use app\common\model\Wallet;
  11. use app\utils\CurlUtil;
  12. use app\utils\RedisUtil;
  13. use think\Db;
  14. /**
  15. * 老年大学 活动板块
  16. */
  17. class UniversityCourse extends Api
  18. {
  19. protected $noNeedLogin = [''];
  20. protected $noNeedRight = ['*'];
  21. // 活动列表
  22. public function list()
  23. {
  24. $user_id = $this->auth->id;
  25. $list = UniversityCourseModel::with([
  26. 'apply' => function ($query) use ($user_id) {
  27. $query->field('id,course_id,user_id')->where('user_id', $user_id)->where('status', 1);
  28. }
  29. ])
  30. ->field('id,name,image')
  31. ->where('status', 1)
  32. ->order('weigh desc,id desc')
  33. ->autopage()
  34. ->select();
  35. foreach ($list as $k => $v) {
  36. $list[$k]['apply'] = !empty($v['apply']) ? 1 : 0;
  37. }
  38. return $this->success('success', $list);
  39. }
  40. // 活动详情
  41. public function info()
  42. {
  43. $params = $this->request->param();
  44. if (empty($params['course_id'])) {
  45. return $this->error('参数缺失');
  46. }
  47. $user_id = $this->auth->id;
  48. $info = UniversityCourseModel::with([
  49. 'apply' => function ($query) use ($user_id) {
  50. $query->field('id,course_id,user_id')->where('user_id', $user_id)->where('status', 1);
  51. }
  52. ])
  53. ->field('id,name,image,images,content')
  54. ->where('id', $params['course_id'])
  55. ->where('status', 1)
  56. ->find();
  57. $info['apply'] = !empty($info['apply']) ? 1 : 0;
  58. return $this->success('success', $info);
  59. }
  60. public function apply()
  61. {
  62. $params = $this->request->param();
  63. if (empty($params['course_id'])) {
  64. return $this->error('参数缺失');
  65. }
  66. if (empty($params['name'])) {
  67. return $this->error('报名信息姓名不能为空');
  68. }
  69. if (empty($params['phone'])) {
  70. return $this->error('报名信息手机号不能为空');
  71. }
  72. $user_id = $this->auth->id;
  73. $info = UniversityCourseModel::with([
  74. 'apply' => function ($query) use ($user_id) {
  75. $query->field('id,course_id,user_id')->where('user_id', $user_id)->where('status', 1);
  76. }
  77. ])
  78. ->field('id,name,image,images,content')
  79. ->where('id', $params['course_id'])
  80. ->where('status', 1)
  81. ->find();
  82. if (!$info) {
  83. return $this->error('课程不存在');
  84. }
  85. if (!empty($info['apply'])) {
  86. return $this->error('您已报过名了');
  87. }
  88. $coupon = Db::name('vip_coupon_user')->where('user_id',$user_id)->where('id',$params['course_id'])->find();
  89. if (!$coupon || $coupon['status'] != 1){
  90. return $this->error('优惠券不存在或已使用');
  91. }
  92. if ($coupon['end_time'] < time()){
  93. return $this->error('优惠券已过期');
  94. }
  95. if ($coupon['use_frequency_day'] > 0 && $coupon['use_frequency_times'] > 0){
  96. $use_frequency_times = Db::name('vip_coupon_user')->where('user_id',$user_id)
  97. ->where('coupon_id',$coupon['coupon_id'])
  98. ->where('status',2)
  99. ->whereBetween('use_time',[time() - (86400 * $coupon['use_frequency_day']),time()])
  100. ->count();
  101. if ($use_frequency_times >= $coupon['use_frequency_times']){
  102. return $this->error("优惠券{$coupon['use_frequency_day']}天内仅可使用{$coupon['use_frequency_times']}次!");
  103. }
  104. }
  105. $nowTime = time();
  106. // 开始报名
  107. $data = [
  108. 'user_id' => $user_id,
  109. 'course_id' => $params['course_id'],
  110. 'order_no' => createUniqueNo('C', $user_id),
  111. 'name' => $params['name'],
  112. 'phone' => $params['phone'],
  113. 'status' => 1,
  114. 'create_time' => $nowTime
  115. ];
  116. Db::startTrans();
  117. if (!$apply_id = Db::name('university_course_apply')->insertGetId($data)) {
  118. Db::rollback();
  119. return $this->error('订单创建失败');
  120. }
  121. // 抵扣券
  122. if (!Db::name('vip_coupon_user')->where('id',$params['course_id'])->update(['order_id'=>$apply_id,'status' => 2,'use_time' => time()])) {
  123. Db::rollback();
  124. return $this->error('订单创建失败');
  125. }
  126. Db::commit();
  127. return $this->success('报名成功');
  128. }
  129. public function applyList()
  130. {
  131. $user_id = $this->auth->id;
  132. $query = UniversityCourseApplyModel::with([
  133. 'course' => function ($query) {
  134. $query->field(['id','name','image']);
  135. }
  136. ])->where('user_id',$user_id)->where('status',1)->order('id','desc')->autopage()->select();
  137. $this->success('success', $query);
  138. }
  139. }