Lesson.php 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  1. <?php
  2. namespace app\api\controller\coach;
  3. use app\common\controller\Apic;
  4. use think\Db;
  5. /**
  6. * 售课
  7. */
  8. class Lesson extends Apic
  9. {
  10. // 无需登录的接口,*表示全部
  11. protected $noNeedLogin = [];
  12. // 无需鉴权的接口,*表示全部
  13. protected $noNeedRight = ['*'];
  14. //售课分类列表
  15. public function lesson_cate(){
  16. $list = Db::name('lesson_cate')->order('id asc')->select();
  17. $list = $this->list_lang($list,['name']);
  18. $this->success(1,$list);
  19. }
  20. //课时首页
  21. public function slot_list(){
  22. $date = input('date',date('Y-m-d'),'strtotime');
  23. $where = [
  24. 'slot.starttime' => ['BETWEEN',[$date,$date+86399]],
  25. ];
  26. //课时
  27. $list = Db::name('lesson_slot')->alias('slot')
  28. ->field('slot.*,lesson.name,lesson.name_en,lesson.image,lesson.price')
  29. ->join('lesson','slot.lesson_id = lesson.id','LEFT')
  30. ->where($where);
  31. $list->where('find_in_set(:coach_ids,coach_ids)', ['coach_ids' => $this->auth->id]);
  32. $list = $list->order('slot.starttime asc')->select();
  33. if(empty($list)){
  34. $this->success(1,[]);
  35. }
  36. $list = list_domain_image($list,['image']);
  37. $list = $this->list_lang($list,['name']);
  38. foreach($list as $key => &$slot){
  39. //已报名数量,(包含已支付,已点名,没有冲突)
  40. $pay_number = Db::name('lesson_order')->alias('order')
  41. ->field('order.id,user.avatar,order.usernumber')
  42. ->join('user','order.user_id = user.id','LEFT')
  43. ->where('order.slot_id',$slot['id'])
  44. ->where('order.order_status','IN',[10,20])
  45. ->select();
  46. $pay_number = list_domain_image($pay_number,['avatar']);
  47. $slot['usernumber'] = array_sum(array_column($pay_number,'usernumber'));
  48. $slot['useravatar'] = array_column($pay_number,'avatar');
  49. }
  50. $this->success(1,$list);
  51. }
  52. //课时详情
  53. public function slot_info(){
  54. $slot_id = input('slot_id',0);
  55. //课时
  56. $info = Db::name('lesson_slot')->alias('slot')
  57. ->field('slot.*,lesson.name,lesson.name_en,lesson.image,lesson.price')
  58. ->join('lesson','slot.lesson_id = lesson.id','LEFT')
  59. ->where('slot.id',$slot_id)->find();
  60. $info = info_domain_image($info,['image']);
  61. $info = $this->info_lang($info,['name']);
  62. //已报名数量,(包含已支付,已点名,没有冲突)
  63. $pay_number = Db::name('lesson_order')->alias('order')
  64. ->field('order.id,user.avatar,order.usernumber,order.usernumber_sign')
  65. ->join('user','order.user_id = user.id','LEFT')
  66. ->where('order.slot_id',$info['id'])
  67. ->where('order.order_status','IN',[10,20])
  68. ->select();
  69. $pay_number = list_domain_image($pay_number,['avatar']);
  70. $info['usernumber'] = array_sum(array_column($pay_number,'usernumber'));
  71. $info['user_list'] = $pay_number;
  72. $this->success(1,$info);
  73. }
  74. //课时申请报名
  75. public function slot_sign(){
  76. $this->apiLimit();
  77. $slot_id = input('slot_id',0,'intval');
  78. $signdata = input('signdata','','htmlspecialchars_decode');
  79. $signdata = json_decode($signdata,true);
  80. //测试
  81. /*$signdata = [
  82. 6 => 1,
  83. 7 => 2,
  84. ];*/
  85. //检查课时状态
  86. $slot_info = Db::name('lesson_slot')->where('id',$slot_id)->find();
  87. if($slot_info['status'] == 20){
  88. $this->error('此课程已经点过名了');
  89. }
  90. if($slot_info['status'] != 0){
  91. $this->error('此课程不能提交点名');
  92. }
  93. //检查报名单数据
  94. //逐个检查报名单,对比数量和状态。并保存
  95. Db::startTrans();
  96. $order_list = Db::name('lesson_order')->where('slot_id',$slot_id)->where('order_status',10)->order('id asc')->lock(true)->select();
  97. if(count($order_list) != count($signdata)){
  98. Db::rollback();
  99. $this->error('点名数据错误');
  100. }
  101. if(empty($order_list)){
  102. Db::rollback();
  103. $this->error('无人报名,请直接取消课程');
  104. }
  105. foreach($order_list as $order){
  106. if(!isset($signdata[$order['id']])){
  107. Db::rollback();
  108. $this->error('点名数据错误');
  109. }
  110. $usernumber_sign = $signdata[$order['id']];
  111. if($usernumber_sign < 0 || $usernumber_sign > $order['usernumber']){
  112. Db::rollback();
  113. $this->error('点名数据错误');
  114. }
  115. $update = [
  116. 'usernumber_sign' => $usernumber_sign,
  117. 'order_status' => 20,
  118. 'finishtime' => time(),
  119. ];
  120. $rs_sign = Db::name('lesson_order')->where('id',$order['id'])->update($update);
  121. if($rs_sign === false){
  122. Db::rollback();
  123. $this->error('点名失败');
  124. }
  125. }
  126. //修改课时状态
  127. $update = [
  128. 'status' => 20,
  129. 'finishtime' => time(),
  130. ];
  131. $slot_rs = Db::name('lesson_slot')->where('id',$slot_id)->update($update);
  132. if($slot_rs === false){
  133. Db::rollback();
  134. $this->error('点名失败');
  135. }
  136. Db::commit();
  137. $this->success('点名完成');
  138. }
  139. //我的课时记录,点过名的
  140. public function my_slot_history(){
  141. $date = input('date',date('Y-m-d'),'strtotime');
  142. $lesson_id = input('lesson_id',0);
  143. $where = [
  144. 'slot.starttime' => ['BETWEEN',[$date,$date+86399]],
  145. 'slot.status' => 20,
  146. ];
  147. if($lesson_id){
  148. $where['slot.lesson_id'] = $lesson_id;
  149. }
  150. //课时
  151. $list = Db::name('lesson_slot')->alias('slot')
  152. ->field('slot.*,lesson.name,lesson.name_en')
  153. ->join('lesson','slot.lesson_id = lesson.id','LEFT')
  154. ->where('slot.status',20);
  155. $list->where('find_in_set(:coach_ids,coach_ids)', ['coach_ids' => $this->auth->id]);
  156. $list = $list->order('slot.starttime asc')->select();
  157. if(empty($list)){
  158. $this->success(1,[]);
  159. }
  160. $list = $this->list_lang($list,['name']);
  161. foreach($list as $key => &$slot){
  162. //已报名数量
  163. $pay_number = Db::name('lesson_order')->where('slot_id',$slot['id'])->where('order_status',20)->sum('usernumber');
  164. $slot['usernumber'] = $pay_number;
  165. }
  166. $this->success(1,$list);
  167. }
  168. }