MerchantStatis.php 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. <?php
  2. declare (strict_types = 1);
  3. namespace app\controller;
  4. use app\BaseController;
  5. use app\model\MerchantStatisModel;
  6. use app\common\CommonUtils;
  7. use think\facade\Request;
  8. class MerchantStatis extends BaseController
  9. {
  10. /**
  11. * 获取商户每日数据
  12. */
  13. public function Daily()
  14. {
  15. $userInfo = $this->request->userInfo;
  16. // 获取查询参数
  17. $page = Request::get('page', 1, 'intval');
  18. $limit = Request::get('limit', 10, 'intval');
  19. // 筛选条件
  20. $filters = [
  21. // 时间筛选
  22. 'start_time' => Request::get('start_time', date('Y-m-d', strtotime('-7 days')), 'trim'),
  23. 'end_time' => Request::get('end_time', date('Y-m-d'), 'trim'),
  24. ];
  25. try {
  26. // 获取商户每日数据
  27. $result = MerchantStatisModel::getMerchantDailyList(
  28. $userInfo['merchant_id'],
  29. $page,
  30. $limit,
  31. $filters,
  32. );
  33. // 格式化数据
  34. foreach ($result['list'] as &$item) {
  35. $item['game_profit'] = CommonUtils::convertBalance($item['game_profit'], false);
  36. $item['bet_amount'] = CommonUtils::convertBalance($item['bet_amount'], false);
  37. $item['commission_amount'] = CommonUtils::convertBalance($item['game_profit'] * 0.08, false);
  38. $item['platform_fee'] = CommonUtils::convertBalance($item['bet_amount'] * 0.08, false);
  39. $item['buy_free_bet'] = 0;
  40. }
  41. return json_success($result, '获取成功');
  42. } catch (\Exception $e) {
  43. return json_error([], '获取商户每日数据失败:' . $e->getMessage());
  44. }
  45. }
  46. /*
  47. * 获取商户时间阶段数据统计
  48. */
  49. public function Stage()
  50. {
  51. $userInfo = $this->request->userInfo;
  52. // 筛选条件
  53. $filters = [
  54. // 时间筛选
  55. 'start_time' => Request::get('start_time', date('Y-m-d', strtotime('-7 days')), 'trim'),
  56. 'end_time' => Request::get('end_time', date('Y-m-d'), 'trim'),
  57. ];
  58. try {
  59. // 获取商户每日数据
  60. $result = MerchantStatisModel::getMerchantHistory($userInfo['merchant_id'], $filters);
  61. // 格式化数据
  62. $result['rtp'] = !is_null($result["rtp"]) ? $result["rtp"] : 0;
  63. $result['date_stage'] = implode(' ~ ', $filters);
  64. $result['game_profit'] = CommonUtils::convertBalance($result['game_profit'], false);
  65. $result['bet_amount'] = CommonUtils::convertBalance($result['bet_amount'], false);
  66. $result['commission_amount'] = CommonUtils::convertBalance($result['game_profit'] * 0.08, false);
  67. $result['platform_fee'] = CommonUtils::convertBalance($result['bet_amount'] * 0.08, false);
  68. $result['buy_free_bet'] = 0;
  69. return json_success($result, '获取成功');
  70. } catch (\Exception $e) {
  71. return json_error([], '获取商户每日数据失败:' . $e->getMessage());
  72. }
  73. }
  74. /**
  75. * 获取商户历史数据统计
  76. */
  77. public function History()
  78. {
  79. $userInfo = $this->request->userInfo;
  80. try {
  81. // 获取商户每日数据
  82. $result = MerchantStatisModel::getMerchantHistory($userInfo['merchant_id']);
  83. // 格式化数据
  84. $result['game_profit'] = CommonUtils::convertBalance($result['game_profit'], false);
  85. $result['bet_amount'] = CommonUtils::convertBalance($result['bet_amount'], false);
  86. $result['commission_amount'] = CommonUtils::convertBalance($result['game_profit'] * 0.08, false);
  87. $result['platform_fee'] = CommonUtils::convertBalance($result['bet_amount'] * 0.08, false);
  88. $result['buy_free_bet'] = 0;
  89. return json_success($result, '获取成功');
  90. } catch (\Exception $e) {
  91. return json_error([], '获取商户每日数据失败:' . $e->getMessage());
  92. }
  93. }
  94. }