EpisodeController.php 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323
  1. <?php
  2. namespace App\Http\Controllers\V1;
  3. use App\Models\Banner;
  4. use App\Models\Episode;
  5. use App\Models\EpisodesCategory;
  6. use App\Models\EpisodesList;
  7. use App\Models\NavBar;
  8. use App\Models\Tabbar;
  9. use App\Models\User;
  10. use App\Models\UserEpisodesRecord;
  11. use App\Models\UserWatchRecord;
  12. use Carbon\Carbon;
  13. use Illuminate\Database\Eloquent\Builder;
  14. use Illuminate\Support\Collection;
  15. use function GuzzleHttp\Promise\all;
  16. class EpisodeController extends Controller
  17. {
  18. private $number;
  19. public function __construct()
  20. {
  21. $this->number = env('HOME_RECOMMEND_NUMBER', 6);
  22. }
  23. /**
  24. * 推荐
  25. */
  26. public function recommend()
  27. {
  28. $history = UserWatchRecord::filterUser()
  29. ->withCount(['episode'])
  30. ->whereHas('episode', function (Builder $query){
  31. $query->where('is_opend', 1);
  32. })
  33. ->inRandomOrder()
  34. //->where('created_at','>=', Carbon::now()->subDays(7)->toDateTime())
  35. ->first();
  36. $lists = [];
  37. $ids = [];
  38. if($history){
  39. $ids[] = $history->episode->id;
  40. $history->episode->recent = true;
  41. $history->episode->status_text = $history->episode->status;
  42. $history->episode->total = $history->episode->lists->count();
  43. unset( $history->episode->lists);
  44. $lists[] = $history->episode;
  45. }
  46. $limit = $this->number - count($lists);
  47. // 推荐
  48. $episodes = Episode::filterPlatform()->withCount(['lists'])
  49. ->where('is_opend', 1)
  50. ->when($history,function ($query) use($history){
  51. /* @var Builder $query*/
  52. return $query->where('category_id', $history->episode->category_id)
  53. ->where('id','<>', $history->episode->id);
  54. })
  55. ->limit($limit)
  56. ->get();
  57. /* @var Episode $episode*/
  58. foreach ($episodes as $episode){
  59. $ids[] = $episode->id;
  60. $episode->status_text = $episode->status;
  61. $episode->total = $episode->lists_count;
  62. $episode->guess = true;
  63. $lists[] = $episode;
  64. }
  65. // 推荐的不够两个 需要补充
  66. $limit = $this->number - count($lists);
  67. if($limit){
  68. $supplement = Episode::filterPlatform()->withCount(['lists'])
  69. ->where('is_opend', 1)
  70. ->when($ids, function ($query) use($ids){
  71. /* @var Builder $query*/
  72. return $query->whereNotIn('id',$ids);
  73. })
  74. ->limit($limit)
  75. ->get();
  76. /* @var Episode $episode*/
  77. foreach ($supplement as $episode){
  78. $episode->status_text = $episode->status;
  79. $episode->total = $episode->lists_count;
  80. $episode->guess = true;
  81. $lists[] = $episode;
  82. }
  83. }
  84. return $this->success($lists);
  85. }
  86. /**
  87. * 最新
  88. */
  89. public function news()
  90. {
  91. $limit = request()->input('limit', $this->number);
  92. $page = request()->input('page',1);
  93. $offset = ($page - 1) * $limit;
  94. $episodes = Episode::filterPlatform()->withCount(['lists'])
  95. ->where('is_opend', 1)
  96. //->inRandomOrder()
  97. ->orderByDesc('created_at')
  98. ->limit($limit)
  99. ->offset($offset)
  100. ->get();
  101. $lists = Episode::complete($episodes);
  102. return $this->success($lists);
  103. }
  104. /**
  105. * 今日推荐
  106. */
  107. public function todayRecommend()
  108. {
  109. $limit = request()->input('limit', $this->number);
  110. $page = request()->input('page',1);
  111. $offset = ($page - 1) * $limit;
  112. $episodes = Episode::filterPlatform()->withCount(['lists'])
  113. ->where('is_opend', 1)
  114. //->inRandomOrder()
  115. ->orderBy('sort')
  116. ->limit($limit)
  117. ->offset($offset)
  118. ->get();
  119. $lists = Episode::complete($episodes);
  120. return $this->success($lists);
  121. }
  122. /**
  123. * 排行
  124. */
  125. public function rank()
  126. {
  127. $limit = request()->input('limit', 12);
  128. $page = request()->input('page',1);
  129. $offset = ($page - 1) * $limit;
  130. $episodes = Episode::filterPlatform()->withCount(['userEpisodesRecords','lists'])
  131. ->where('is_opend', 1)
  132. ->orderByDesc('user_episodes_records_count')
  133. ->limit($limit)
  134. ->offset($offset)
  135. ->get();
  136. $lists = [];
  137. $rank = (($page - 1) * $limit) + 1;
  138. /* @var Episode $episode*/
  139. foreach ($episodes as $episode){
  140. $episode->status_text = $episode->status;
  141. $episode->total = $episode->lists_count;
  142. $episode->rank = $rank++;
  143. $lists[] = $episode;
  144. }
  145. return $this->success($lists);
  146. }
  147. public function list()
  148. {
  149. $limit = request()->input('limit', $this->number);
  150. $page = request()->input('page',1);
  151. $cateId = request()->input('cateId',0);
  152. $offset = ($page - 1) * $limit;
  153. $episodes = Episode::filterPlatform()->withCount(['lists'])
  154. ->when($cateId, function ($query, $cateId){
  155. /* @var Builder $query*/
  156. return $query->where('category_id',$cateId);
  157. })
  158. ->where('is_opend', 1)
  159. ->limit($limit)
  160. ->offset($offset)
  161. ->get();
  162. $lists = [];
  163. /* @var Episode $episode*/
  164. foreach ($episodes as $episode){
  165. $episode->status_text = $episode->status;
  166. $episode->total = $episode->lists_count;
  167. $lists[] = $episode;
  168. }
  169. return $this->success($lists);
  170. }
  171. // 追剧
  172. public function trace()
  173. {
  174. $category = EpisodesCategory::with(['child:id,pid'])
  175. ->where('level',1)
  176. ->orderBy('sort')
  177. ->get(['id','name']);
  178. $lists = [];
  179. /* @var EpisodesCategory $item*/
  180. foreach ($category as $item){
  181. $childIds = $item->child->pluck('id');
  182. $childIds[] = $item->id;
  183. $episodes = Episode::filterPlatform()->whereIn('category_id', $childIds)
  184. ->where('is_opend', 1)
  185. ->limit(3)
  186. ->get();
  187. /* @var Episode $episode*/
  188. foreach ($episodes as $episode){
  189. $count = EpisodesList::where('episodes_id',$episode->id)->count();
  190. $episode->total = $count;
  191. $episode->status_text = $episode->status;
  192. }
  193. $item->episodes = $episodes;
  194. unset($item->child);
  195. if($episodes->count()){
  196. $lists[] = $item;
  197. }
  198. }
  199. return $this->success($lists);
  200. }
  201. /**
  202. * 最新
  203. */
  204. public function search()
  205. {
  206. $keywords = request()->input('keywords','');
  207. $limit = request()->input('limit',3);
  208. $page = request()->input('page',1);
  209. $offset = ($page - 1) * $limit;
  210. $episodes = Episode::filterPlatform()->withCount(['lists'])
  211. ->where('is_opend', 1)
  212. ->when($keywords, function ($query, $keywords) {
  213. /* @var Builder $query*/
  214. return $query->where('name','like', "%$keywords%");
  215. })
  216. ->inRandomOrder()
  217. ->orderByDesc('id')
  218. ->limit($limit)
  219. ->offset($offset)
  220. ->get();
  221. $lists = Episode::complete($episodes);
  222. return $this->success($lists);
  223. }
  224. public function vipFree()
  225. {
  226. $limit = request()->input('limit',3);
  227. $page = request()->input('page',1);
  228. $offset = ($page - 1) * $limit;
  229. $episodes = Episode::filterPlatform()->withCount(['lists'])
  230. ->where('is_opend', 1)
  231. ->where('is_vip_watch', 1)
  232. ->inRandomOrder()
  233. ->orderByDesc('id')
  234. ->limit($limit)
  235. ->offset($offset)
  236. ->get();
  237. $lists = Episode::complete($episodes);
  238. return $this->success($lists);
  239. }
  240. // 详情
  241. public function detail($id)
  242. {
  243. $episodes = Episode::filterPlatform()->withCount(['userWatchRecord','userCollect','userFavorite','lists'])
  244. ->with([
  245. 'category:id,name',
  246. 'lists'=> function($query){
  247. $query->select([
  248. 'id','episodes_id','sort','url','is_free','origin_price','sale_price'
  249. ])
  250. ->orderBy('sort');
  251. }
  252. ])
  253. ->where('is_opend', 1)
  254. ->where('id', $id)
  255. ->first();
  256. $episodes->user_watch_record_count += $episodes->play_num;
  257. $episodes->user_favorite_count += $episodes->favorite_num;
  258. $episodes->user_collect_count += $episodes->collect_num;
  259. $episodes->share_count += $episodes->virtual_share;
  260. return $this->success($episodes);
  261. }
  262. public function listBuyNum($listId)
  263. {
  264. $count = UserEpisodesRecord::where('list_id',$listId)->count();
  265. $info = EpisodesList::find($listId);
  266. $res = Episode::find($info->episodes_id);
  267. $count += $res->buy_num;
  268. return $this->success($count);
  269. }
  270. // 分享
  271. public function shared($id)
  272. {
  273. $res = Episode::find($id);
  274. if(!$res){
  275. return $this->success();
  276. }
  277. $res->share_count = $res->share_count + 1;
  278. $res->save();
  279. return $this->success();
  280. }
  281. }