UniversityCourse.php 5.3 KB

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