WebPageModuleController.php 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. <?php
  2. namespace App\Http\Controllers\Game;
  3. use App\Game\GameCard;
  4. use App\Game\GlobalUserInfo;
  5. use App\Game\PageModule;
  6. use App\Game\Route;
  7. use App\Http\Controllers\Controller;
  8. use Illuminate\Http\Request;
  9. // use Yansongda\Pay\Log;
  10. class WebPageModuleController extends Controller
  11. {
  12. public function PageModules(Request $request,$page_id){
  13. $modules = PageModule::with(['subs' => function ($query) {
  14. $query->with('subs'); // 递归加载子模块
  15. }])->where('page_id', $page_id)->whereNull('parent_id')->orderBy('pos_index')->get();
  16. if($request->input('abc')){
  17. // 遍历打印每个模块及其子模块
  18. foreach ($modules as $module) {
  19. echo "=== Module ID: {$module->id} ===\n";
  20. echo "Type: {$module->type}\n";
  21. echo "Subs Count: " . $module->subs->count() . "\n";
  22. //echo "Subs Data:\n";
  23. //print_r($module->subs->toArray());
  24. echo "\n\n";
  25. echo "\br\br";
  26. }
  27. }
  28. return response()->json([
  29. 'code' => 0,
  30. 'data' => $modules->map(function (PageModule $module) {
  31. return $module->getSpecificDataAttribute();
  32. }),
  33. 'msg' => '',
  34. ]);
  35. }
  36. public function GameList(Request $request)
  37. {
  38. $type=$request->input('type');
  39. $id=$request->input('id');
  40. PageModule::$enableStateCheck=false;
  41. if($id){
  42. $module = PageModule::where('id', $id)->first();
  43. }else{
  44. $module = PageModule::where('tabtype', $type)->where('type','ModuleGameList')->first();
  45. }
  46. $pageSize = $request->input('pageSize', PageModule::getDefaultPageSize()); // 从请求获取pageSize或使用默认值
  47. $page = $request->input('page', 1); // 从请求获取当前页或使用默认值
  48. // 根据模块获取游戏ID列表
  49. // 获取与模块相关的游戏列表并应用分页
  50. $gamesQuery = $module->games();
  51. $total = $gamesQuery->count();
  52. $games = $gamesQuery->forPage($page, $pageSize)->get();
  53. $games=GameCard::formatGames($games);
  54. $totalPage = ceil($total / $pageSize);
  55. return response()->json([
  56. 'tabtype' =>$type,
  57. 'data' => $games,
  58. 'page' => $page,
  59. 'pageSize' => $pageSize,
  60. 'total' => $total,
  61. 'totalPage' => $totalPage,
  62. ]);
  63. }
  64. public function addFavorite(Request $request)
  65. {
  66. if($request->has('id'))GlobalUserInfo::$me->addFavoGame($request->id);
  67. return apiReturnSuc();
  68. }
  69. public function removeFavorite(Request $request)
  70. {
  71. if($request->has('id'))GlobalUserInfo::$me->removeFavoGame($request->id);
  72. return apiReturnSuc();
  73. }
  74. public function getFavorite(Request $request)
  75. {
  76. $user=$request->user();
  77. $favorites=[];
  78. if($user&&!empty(GlobalUserInfo::$me->FavoriteGames)){
  79. $gameids=trim(GlobalUserInfo::$me->FavoriteGames,',');
  80. $orderClause = 'FIELD(id, ' . $gameids . ')';
  81. $gameids=explode(',', $gameids);
  82. $favorites = GameCard::whereIn('id', $gameids)->orderByRaw($orderClause)->get(); // 只获取状态为 1 的游戏
  83. $favorites = GameCard::formatGames($favorites);
  84. }
  85. return apiReturnSuc($favorites);
  86. }
  87. }