Home.php 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. <?php
  2. namespace App\Http\Controllers\admin;
  3. use App\Constants\HttpStatus;
  4. use App\Http\Controllers\Controller;
  5. use App\Models\PaymentOrder;
  6. use App\Services\PaymentOrderService;
  7. use Illuminate\Validation\ValidationException;
  8. use Exception;
  9. use Carbon\Carbon;
  10. use App\Models\Withdraw;
  11. class Home extends Controller
  12. {
  13. public function index()
  14. {
  15. try {
  16. request()->validate([
  17. 'start_date' => ['nullable', 'date_format:Y-m-d'],
  18. 'end_date' => ['nullable', 'date_format:Y-m-d', 'after_or_equal:start_date'],
  19. ]);
  20. $start = request()->input('start_date', date('Y-m-d'));
  21. $end = request()->input('end_date', date('Y-m-d'));
  22. $end = Carbon::createFromFormat('Y-m-d', $end)->addDay();
  23. $query = PaymentOrder::query();
  24. $params['type'] = 2;
  25. $where = PaymentOrderService::getWhere($params);
  26. $totalAmount = (float)$query->where($where)->whereBetween('created_at', [$start, $end])->sum('amount');
  27. $totalSuccess = (float)$query->where($where)->whereBetween('created_at', [$start, $end])->whereIn('status', [1, 2])->sum('amount');
  28. $totalFail = (float)$query->where($where)->whereBetween('created_at', [$start, $end])->where('status', 3)->sum('amount');
  29. $query = Withdraw::query();
  30. $usdTotalAmount = (float)$query->whereBetween('created_at', [$start, $end])->sum('amount');
  31. $usdTotalSuccess = (float)$query->whereBetween('created_at', [$start, $end])->where('status',1)->sum('amount');
  32. $usdTotalFail = $query->whereBetween('created_at', [$start, $end])->where('status',2)
  33. ->sum('amount')->toSql();
  34. $result = [
  35. 'withdraw_usdt' => [
  36. 'total_fail' => $usdTotalFail,
  37. 'total_success' => $usdTotalSuccess,
  38. 'total_amount' => $usdTotalAmount,
  39. ],
  40. 'withdraw_rmb' => [
  41. 'total_fail' => $totalFail,
  42. 'total_success' => $totalSuccess,
  43. 'total_amount' => $totalAmount,
  44. ]
  45. ];
  46. } catch (ValidationException $e) {
  47. return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first());
  48. } catch (Exception $e) {
  49. return $this->error($e->getCode(), $e->getmessage());
  50. }
  51. return $this->success($result);
  52. }
  53. }