UniversityCourse.php 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  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. $list = json_decode(json_encode($list),true);
  36. foreach ($list as $k => $v) {
  37. $list[$k]['apply'] = !empty($v['apply']) ? 1 : 0;
  38. }
  39. return $this->success('success', $list);
  40. }
  41. // 活动详情
  42. public function info()
  43. {
  44. $params = $this->request->param();
  45. if (empty($params['course_id'])) {
  46. return $this->error('参数缺失');
  47. }
  48. $user_id = $this->auth->id;
  49. $info = UniversityCourseModel::with([
  50. 'chapter',
  51. 'apply' => function ($query) use ($user_id) {
  52. $query->field('id,course_id,user_id')->where('user_id', $user_id)->where('status', 1);
  53. }
  54. ])
  55. ->field('id,name,image,images,content')
  56. ->where('id', $params['course_id'])
  57. ->where('status', 1)
  58. ->find();
  59. $info['apply'] = !empty($info['apply']) ? 1 : 0;
  60. return $this->success('success', $info);
  61. }
  62. public function apply()
  63. {
  64. $params = $this->request->param();
  65. if (empty($params['course_id'])) {
  66. return $this->error('参数缺失');
  67. }
  68. if (empty($params['name'])) {
  69. return $this->error('报名信息姓名不能为空');
  70. }
  71. if (empty($params['phone'])) {
  72. return $this->error('报名信息手机号不能为空');
  73. }
  74. if (empty($params['coupon_id'])) {
  75. return $this->error('请选择抵扣券');
  76. }
  77. $user_id = $this->auth->id;
  78. $info = UniversityCourseModel::with([
  79. 'apply' => function ($query) use ($user_id) {
  80. $query->field('id,course_id,user_id')->where('user_id', $user_id)->where('status', 1);
  81. }
  82. ])
  83. ->field('id,name,image,images,content')
  84. ->where('id', $params['course_id'])
  85. ->where('status', 1)
  86. ->find();
  87. if (!$info) {
  88. return $this->error('课程不存在');
  89. }
  90. if (!empty($info['apply'])) {
  91. return $this->error('您已报过名了');
  92. }
  93. $coupon = Db::name('vip_coupon_user')->where('user_id',$user_id)->where('id',$params['coupon_id'])->find();
  94. if (!$coupon || $coupon['status'] != 1){
  95. return $this->error('优惠券不存在或已使用');
  96. }
  97. if ($coupon['end_time'] < time()){
  98. return $this->error('优惠券已过期');
  99. }
  100. if ($coupon['use_frequency_day'] > 0 && $coupon['use_frequency_times'] > 0){
  101. $use_frequency_times = Db::name('vip_coupon_user')->where('user_id',$user_id)
  102. ->where('coupon_id',$coupon['coupon_id'])
  103. ->where('status',2)
  104. ->whereBetween('use_time',[time() - (86400 * $coupon['use_frequency_day']),time()])
  105. ->count();
  106. if ($use_frequency_times >= $coupon['use_frequency_times']){
  107. return $this->error("优惠券{$coupon['use_frequency_day']}天内仅可使用{$coupon['use_frequency_times']}次!");
  108. }
  109. }
  110. $nowTime = time();
  111. // 开始报名
  112. $data = [
  113. 'user_id' => $user_id,
  114. 'course_id' => $params['course_id'],
  115. 'order_no' => createUniqueNo('C', $user_id),
  116. 'name' => $params['name'],
  117. 'phone' => $params['phone'],
  118. 'status' => 1,
  119. 'create_time' => $nowTime
  120. ];
  121. Db::startTrans();
  122. if (!$apply_id = Db::name('university_course_apply')->insertGetId($data)) {
  123. Db::rollback();
  124. return $this->error('订单创建失败');
  125. }
  126. // 抵扣券
  127. if (!Db::name('vip_coupon_user')->where('id',$coupon['id'])->update(['order_id'=>$apply_id,'status' => 2,'use_time' => time()])) {
  128. Db::rollback();
  129. return $this->error('订单创建失败');
  130. }
  131. Db::commit();
  132. return $this->success('报名成功');
  133. }
  134. public function applyList()
  135. {
  136. $user_id = $this->auth->id;
  137. $query = UniversityCourseApplyModel::with([
  138. 'course' => function ($query) {
  139. $query->field(['id','name','image']);
  140. },
  141. 'chapters' => function ($query) {
  142. $query->field(['id','course_id','name']);
  143. }
  144. ])->where('user_id',$user_id)->where('status',1)->order('id','desc')->autopage()->select();
  145. $this->success('success', $query);
  146. }
  147. }