UniversityCourse.php 5.3 KB

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