Liveroom.php 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269
  1. <?php
  2. namespace addons\shopro\controller\goods;
  3. use addons\shopro\controller\Common;
  4. use addons\shopro\service\goods\GoodsService;
  5. use think\Db;
  6. use app\utils\Service\Tencent\TencentIm;
  7. class Liveroom extends Common
  8. {
  9. protected $noNeedLogin = ['get_room_attr'];
  10. protected $noNeedRight = ['*'];
  11. //检查是不是主播或管理员,主要用来商品操作的鉴权
  12. private function check_auth($room_no,$user_id){
  13. $whereor = [
  14. 'admin_id' => $user_id,
  15. 'status' => 1,
  16. ];
  17. $check = Db::name('live_room_admin')->where('room_no',$room_no)->where('user_id',$user_id)->whereOr(function($query) use ($whereor) {
  18. $query->where($whereor);
  19. })->find();
  20. if(empty($check)){
  21. $this->error('没有操作权限');
  22. }
  23. $rs = empty($check) ? false : true;
  24. return $rs;
  25. }
  26. //商城所有商品列表
  27. public function goods_index()
  28. {
  29. //鉴权
  30. $room_no = input('room_no','','trim');
  31. $user = auth_user();
  32. $this->check_auth($room_no,$user['id']);
  33. //全平台所有商品列表
  34. $service = new GoodsService();
  35. $service->up();
  36. $keyword = input('keyword','','trim');
  37. if ($keyword) {
  38. $service->search($keyword);
  39. }
  40. $goods = $service->order('weigh desc,id desc')->select_autopage();
  41. $goods = collection($goods)->toArray();
  42. $goods = list_domain_image($goods,['image']);//主图
  43. //本直播间已经有的,标记
  44. $goods_ids = Db::name('live_room_goods')->where('room_no',$room_no)->where('status','up')->column('goods_id');
  45. foreach($goods as $key => $good){
  46. $good['goods_added'] = 0;
  47. if(in_array($good['id'],$goods_ids)){
  48. $good['goods_added'] = 1;
  49. }
  50. $goods[$key] = $good;
  51. }
  52. $this->success('获取成功', $goods);
  53. }
  54. //直播间商品列表顶部三个统计
  55. public function liveroom_index_tongji()
  56. {
  57. $rs = [
  58. 'sales_total_price' => 1,
  59. 'paid_ordernum' => 2,
  60. 'uv' => 3,
  61. ];
  62. $this->success('获取成功', $rs);
  63. }
  64. //直播间商品列表
  65. public function liveroom_index()
  66. {
  67. //鉴权
  68. $room_no = input('room_no','','trim');
  69. $user = auth_user();
  70. $this->check_auth($room_no,$user['id']);
  71. //直播间上架商品
  72. $goods_list = Db::name('live_room_goods')->field('goods_id,goods_no,is_top')->where('room_no',$room_no)->where('status','up')->order('is_top desc,goods_no asc,id desc')->select();
  73. if(empty($goods_list))
  74. {
  75. $this->success(1,null);
  76. }
  77. $goods_ids = array_column($goods_list,'goods_id');
  78. //商品列表
  79. $service = new GoodsService();
  80. $service->up();
  81. $keyword = input('keyword','','trim');
  82. if ($keyword) {
  83. $service->search($keyword);
  84. }
  85. $service->whereIds($goods_ids);
  86. $goods = $service->select_autopage();
  87. $goods = collection($goods)->toArray();
  88. $goods = list_domain_image($goods,['image']);//主图
  89. //追加字段
  90. foreach($goods as $key => $good){
  91. foreach($goods_list as $k => $v){
  92. if($good['id'] == $v['goods_id']){
  93. $good['is_top'] = $v['is_top'];
  94. $good['goods_no'] = $v['goods_no'];
  95. }
  96. }
  97. $goods[$key] = $good;
  98. }
  99. $rs = [
  100. 'number' => count($goods_ids),
  101. 'list' => $goods,
  102. ];
  103. $this->success('获取成功', $rs);
  104. }
  105. //添加
  106. public function add(){
  107. //鉴权
  108. $room_no = input('room_no','','trim');
  109. $user = auth_user();
  110. $this->check_auth($room_no,$user['id']);
  111. //检查商品
  112. $goods_id = input('goods_id',0,'intval');
  113. $goods_info = Db::name('shopro_goods')->where('id',$goods_id)->where('status','up')->find();
  114. if(empty($goods_info)){
  115. $this->error('该商品已下架');
  116. }
  117. //商品序号拿最大的+1
  118. $max = Db::name('live_room_goods')->where('room_no',$room_no)->order('goods_no desc')->value('goods_no');
  119. $max = $max ? $max : 0;
  120. $new_goods_no = $max + 1;
  121. //直播间上架商品
  122. $goods_check = Db::name('live_room_goods')->where('room_no',$room_no)->where('goods_id',$goods_id)->find();
  123. if($goods_check){
  124. if($goods_check['status'] == 'up'){$this->error('该商品已存在');}
  125. //重新上架
  126. Db::name('live_room_goods')->where('room_no',$room_no)->where('goods_id',$goods_id)->update(['status'=>'up','goods_no'=>$new_goods_no,'update_time'=>time()]);
  127. }else{
  128. $room_info = Db::name('live_room')->where('room_no',$room_no)->find();
  129. $new = [
  130. 'room_id' => $room_info['id'],
  131. 'room_no' => $room_info['room_no'],
  132. 'user_id' => $room_info['user_id'],
  133. 'goods_id' => $goods_id,
  134. 'goods_no' => $new_goods_no,
  135. 'status' => 'up',
  136. 'create_time' => time(),
  137. 'update_time' => time(),
  138. ];
  139. Db::name('live_room_goods')->insertGetId($new);
  140. }
  141. $this->success('添加成功');
  142. }
  143. //删除
  144. public function down(){
  145. //鉴权
  146. $room_no = input('room_no','','trim');
  147. $user = auth_user();
  148. $this->check_auth($room_no,$user['id']);
  149. $goods_id = input('goods_id','');
  150. $goods_id = explode(',',$goods_id);
  151. Db::name('live_room_goods')->where('room_no',$room_no)->where('goods_id','IN',$goods_id)->update(['status'=>'down','goods_no'=>0]);
  152. $this->success('操作成功');
  153. }
  154. //设置为讲解中,取消讲解
  155. public function top(){
  156. //鉴权
  157. $room_no = input('room_no','','trim');
  158. $user = auth_user();
  159. $this->check_auth($room_no,$user['id']);
  160. $goods_id = input('goods_id',0,'intval');
  161. $is_top = input('is_top',0,'intval');
  162. //取消讲解
  163. if($is_top == 0){
  164. Db::name('live_room_goods')->where('room_no',$room_no)->update(['is_top'=>0]);
  165. //修改房间属性
  166. $top_good[] = [
  167. 'key' => 'top_good',
  168. 'value' => json_encode((object)[]),
  169. ];
  170. $im = new TencentIm();
  171. $im->modify_group_attr($room_no,$top_good);
  172. $this->success('操作成功');
  173. }
  174. //直播间商品
  175. $check = Db::name('live_room_goods')->where('room_no',$room_no)->where('goods_id',$goods_id)->where('status','up')->find();
  176. if(empty($check)){
  177. $this->error('不存在的商品');
  178. }
  179. //商品
  180. $service = new GoodsService();
  181. $service->up();
  182. $service->where('id',$goods_id);
  183. $goods = $service->find();
  184. if(empty($goods)){
  185. $this->error('该商品已下架');
  186. }
  187. //精简商品
  188. $goods = json_decode(json_encode($goods),true);
  189. $goods = [
  190. 'id' => $goods['id'],
  191. 'title' => $goods['title'],
  192. 'image' => localpath_to_netpath($goods['image']),
  193. 'price' => $goods['price'],
  194. 'is_sku'=> $goods['is_sku'],
  195. ];
  196. //其他取消讲解,讲解这个
  197. $goods_id = input('goods_id',0,'intval');
  198. Db::name('live_room_goods')->where('room_no',$room_no)->update(['is_top'=>0]);
  199. Db::name('live_room_goods')->where('room_no',$room_no)->where('goods_id',$goods_id)->update(['is_top'=>1]);
  200. //修改房间属性
  201. $top_good[] = [
  202. 'key' => 'top_good',
  203. 'value' => json_encode($goods),
  204. ];
  205. $im = new TencentIm();
  206. $im->modify_group_attr($room_no,$top_good);
  207. $this->success('操作成功');
  208. }
  209. //获取属性
  210. public function get_room_attr(){
  211. $room_no = input('room_no','','trim');
  212. $im = new TencentIm();
  213. // $im->delete_group_attr($room_no,'jiangjie');
  214. $im->get_group_attr($room_no);
  215. dump($im->getData());
  216. }
  217. }