SportsNoteList.php 35 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: Jonlin
  5. * Date: 2019/4/9
  6. * Time: 9:18
  7. */
  8. namespace App\Models;
  9. use Illuminate\Support\Facades\DB;
  10. class SportsNoteList extends BaseModel {
  11. protected $table = "money_buy_simplex";
  12. public $timestamps = false;
  13. function getinfo($list = 10, $page, $where = '',$type)
  14. {
  15. $data = $this
  16. ->join('money_details','money_details.info_identity','=','money_buy_simplex.info_identity')
  17. ->join('st_'.$type.'_competition','st_'.$type.'_competition.id','=','money_buy_simplex.match_id')
  18. // ->join('st_'.$type.'_league','st_'.$type.'_competition.lg_id','=','st_'.$type.'_league.id')
  19. ->join('st_'.$type.'_league','money_buy_simplex.lg_id','=','st_'.$type.'_league.id')
  20. ->select('money_buy_simplex.id','money_buy_simplex.account_name','money_buy_simplex.is_champion','money_buy_simplex.account_identity','money_buy_simplex.order_id','money_buy_simplex.money','money_buy_simplex.prize_money','money_buy_simplex.status','money_buy_simplex.money_time','money_buy_simplex.settle_status','money_buy_simplex.gain_money','money_buy_simplex.game_code','money_buy_simplex.match_id','money_buy_simplex.game_status','st_'.$type.'_competition.home_team','st_'.$type.'_competition.guest_team','st_'.$type.'_competition.match_date','st_'.$type.'_competition.match_time','st_'.$type.'_competition.lg_id','st_'.$type.'_competition.status as match_status','money_details.money_cash','money_buy_simplex.batch_id','st_'.$type.'_league.name_chinese','st_'.$type.'_league.last_time')
  21. ->where($where)
  22. ->orderby('money_buy_simplex.money_time','desc')
  23. ->paginate ($list);
  24. if (!$data < 0) {
  25. return -2021052003; //
  26. }
  27. //反水
  28. $water_return_money = \App\Models\Money_details::where('trade_type','7')->get();
  29. //注单作废
  30. $invalid_money = \App\Models\Money_details::where('trade_type','3')->get();
  31. //订单投注的玩法
  32. $content = \App\Models\MoneyBuyMatch::where('bet_type','1')->get();
  33. for($d=0;$d<count($content);$d++){
  34. if($content[$d]->result==0){
  35. $content[$d]->result = '未处理';
  36. }
  37. if($content[$d]->result==1){
  38. $content[$d]->result = '赢';
  39. }
  40. if($content[$d]->result==-1){
  41. $content[$d]->result = '输';
  42. }
  43. if($content[$d]->result==2){
  44. $content[$d]->result = '平';
  45. }
  46. if($content[$d]->result==3){
  47. $content[$d]->result = '赢半平半';
  48. }
  49. if($content[$d]->result==4){
  50. $content[$d]->result = '输半平半';
  51. }
  52. }
  53. //玩法
  54. $result = \App\Models\Matchcode::where('game_code',$type)->get();
  55. //$result = \App\Model\Matchcode::get();
  56. for($i=0;$i<count($data);$i++){
  57. // if($data[$i]->status==1 && $data[$i]->game_status==0){
  58. // $data[$i]->order_status = '投注'.'<br>;<a class="layui-btn layui-btn-sm invalid" lay-event="detail" pid="id" uri="/admin/SoccerNoteList/invalid/?id=" href="javascript:invalid(\'/admin/SoccerNoteList/invalid/?id='.$data[$i]->id.'\');"> 作废 </a>';
  59. // }else
  60. if($data[$i]->status==1 && $data[$i]->game_status==0){
  61. $data[$i]->order_status = '投注';
  62. }else if($data[$i]->status==2){
  63. $data[$i]->order_status = '作废';//.'<br><a class="layui-btn layui-btn-sm audit" lay-event="detail" pid="id" uri="" href="javascript:void(0)" style="background-color: grey;"> 已作废 </a>';
  64. }else if($data[$i]->status==3){
  65. $data[$i]->order_status = '撤单';//.'<br><a class="layui-btn layui-btn-sm audit" lay-event="detail" pid="id" uri="" href="javascript:void(0)" style="background-color: grey;"> 已撤单 </a>';
  66. }
  67. if($data[$i]->settle_status==1){
  68. $data[$i]->settle_status = '未结算';
  69. }else if($data[$i]->settle_status==2){
  70. $data[$i]->settle_status = '已结算';
  71. }
  72. if($data[$i]->game_status==0){
  73. $data[$i]->game_status = '未处理';
  74. }else{
  75. $data[$i]->game_status = '已处理';
  76. }
  77. if($data[$i]->game_code == 'zq'){
  78. $data[$i]->match_id_order = '<a href="/admin/sportsfoot/outcome?home_team='.$data[$i]->match_id.'">'.$data[$i]->match_id.'</a> (<span>'.$data[$i]->account_name.'</span>)<br>'.$data[$i]->order_id;
  79. }
  80. if($data[$i]->game_code == 'lq'){
  81. $data[$i]->match_id_order = '<a href="/admin/Sportsbk/outcome?home_team='.$data[$i]->match_id.'">'.$data[$i]->match_id.'</a> (<span>'.$data[$i]->account_name.'</span>)<br>'.$data[$i]->order_id;
  82. }
  83. if($data[$i]->game_code == 'wq'){
  84. $data[$i]->match_id_order = '<a href="/admin/Sportswq/outcome?home_team='.$data[$i]->match_id.'">'.$data[$i]->match_id.'</a> (<span>'.$data[$i]->account_name.'</span>)<br>'.$data[$i]->order_id;
  85. }
  86. if($data[$i]->game_code == 'bq'){
  87. $data[$i]->match_id_order = '<a href="/admin/Sportsbq/outcome?home_team='.$data[$i]->match_id.'">'.$data[$i]->match_id.'</a> (<span>'.$data[$i]->account_name.'</span>)<br>'.$data[$i]->order_id;
  88. }
  89. $data[$i]->league = $data[$i]->name_chinese;
  90. if($data[$i]->is_champion == 0){
  91. $data[$i]->home_guest = $data[$i]->home_team.' VS '.$data[$i]->guest_team;
  92. $data[$i]->time = '开赛:'.$data[$i]->match_date.' '.$data[$i]->match_time;
  93. }else{
  94. $data[$i]->home_guest = '冠军联赛投注';
  95. $data[$i]->time = '结束:'.$data[$i]->last_time;
  96. }
  97. $data[$i]->money_match_time = '下注:'.$data[$i]->money_time.$data[$i]->time;
  98. //反水
  99. $data[$i]->water_return = -1;
  100. for($a=0;$a<count($water_return_money);$a++){
  101. if($data[$i]->order_id == $water_return_money[$a]->trade_id){
  102. if($data[$i]->status == 2 || $data[$i]->status == 3){
  103. $data[$i]->water_return = 0;
  104. }else{
  105. $data[$i]->water_return = $water_return_money[$a]->money;
  106. }
  107. //用户投注后账户金额
  108. $data[$i]->frozen_cash = $water_return_money[$a]->money_cash;
  109. }
  110. }
  111. if($data[$i]->water_return == -1){
  112. $data[$i]->water_return = 0;
  113. //用户投注后账户金额
  114. $data[$i]->frozen_cash = $data[$i]->money_cash;
  115. }
  116. //此时结果金额
  117. $data[$i]->result = $data[$i]->water_return+$data[$i]->gain_money;
  118. //用户投注前账户金额
  119. $data[$i]->available_cash = $data[$i]->money_cash+$data[$i]->money;
  120. //投注前后账户金额
  121. $data[$i]->account_money = $data[$i]->available_cash.'<br><span>'.$data[$i]->money.'</span><br>'.$data[$i]->frozen_cash;
  122. if($data[$i]->status == 2 || $data[$i]->status == 3){
  123. for($b=0;$b<count($invalid_money);$b++){
  124. if($data[$i]->order_id == $invalid_money[$b]->trade_id){
  125. $data[$i]->available_cash = $invalid_money[$b]->money_cash;
  126. $data[$i]->account_money = $data[$i]->available_cash;
  127. }
  128. }
  129. }
  130. $data[$i]->str = 0;
  131. for($b=0;$b<count($content);$b++){
  132. $data[$i]->str1 = 0;
  133. $data[$i]->team = '';
  134. if(!empty($content[$b]->odds_code)){
  135. if(!empty(stristr($content[$b]->odds_code,'home'))){
  136. $data[$i]->team = $data[$i]->home_team;
  137. }
  138. if(!empty(stristr($content[$b]->odds_code,'guest'))){
  139. $data[$i]->team = $data[$i]->guest_team;
  140. }
  141. if($content[$b]->p_code == 'half_full'){
  142. $string = str_replace('home',$data[$i]->home_team,$content[$b]->odds_code);
  143. $string = str_replace('guest',$data[$i]->guest_team,$string);
  144. $string = str_replace('dogfall','和局',$string);
  145. $string = explode('_',$string);
  146. $data[$i]->team = $string['2'].'/'.$string['3'];
  147. }
  148. }
  149. //处理普通赛事玩法详情
  150. if($data[$i]->match_id == $content[$b]->match_id && $data[$i]->batch_id == $content[$b]->batch_id &&$data[$i]->is_champion == 0){
  151. if($content[$b]->p_code == 'first_last_ball' || $content[$b]->p_code == 'half_full' || $content[$b]->p_code == 'capot' || $content[$b]->p_code == 'two_sides' || $content[$b]->p_code == 'total_goal'){
  152. $content[$b]->condition = '';
  153. }
  154. $data[$i]->game_status = $data[$i]->game_status;
  155. //投注详情
  156. if(!empty($data[$i]->match_time)){
  157. $data[$i]->content1 = '['.$data[$i]->match_time.']';
  158. //$data[$i]->match_time = $data[$i]->match_time;
  159. }
  160. else{
  161. if(!empty($data[$i]->last_time)){
  162. $datetime = explode(' ',$data[$i]->last_time);
  163. //$data[$i]->match_time = $datetime[1];
  164. $data[$i]->content1 = '['.$datetime[1].']';
  165. }
  166. }
  167. for($c=0;$c<count($result);$c++){
  168. if($content[$b]->odds_code == $result[$c]->odds_code){
  169. $data[$i]->str1 = 1;
  170. if($content[$b]->result=='未处理'){
  171. $data[$i]->content = $data[$i]->content.$result[$c]->odds_name.'<br>'.$content[$b]->condition.' '.$data[$i]->team.'@'.$content[$b]->odds.' ¥'.$content[$b]->bet_money.'<br>';
  172. }else{
  173. $data[$i]->content = $data[$i]->content.$result[$c]->odds_name.'<br>'.$content[$b]->condition.' '.$data[$i]->team.'@'.$content[$b]->odds.' ¥'.$content[$b]->bet_money.'<br><span>'.$content[$b]->result.'</span>('.$content[$b]->matchresult.')<br>';
  174. }
  175. }
  176. }
  177. if($data[$i]->str1 == 0){
  178. if($content[$b]->result=='未处理'){
  179. $data[$i]->content = $data[$i]->content.$content[$b]->odds_code.'<br>'.$content[$b]->condition.' '.$data[$i]->team.'@'.$content[$b]->odds.' ¥'.$content[$b]->bet_money.'<br>';
  180. }else{
  181. $data[$i]->content = $data[$i]->content.$content[$b]->odds_code.'<br>'.$content[$b]->condition.' '.$data[$i]->team.'@'.$content[$b]->odds.' ¥'.$content[$b]->bet_money.'<br><span>'.$content[$b]->result.'</span>('.$content[$b]->matchresult.')<br>';
  182. }
  183. }
  184. }
  185. //处理冠军联赛玩法详情
  186. if($data[$i]->match_id == $content[$b]->lg_id && $data[$i]->batch_id == $content[$b]->batch_id &&$data[$i]->is_champion == 1){
  187. $content[$b]->condition = '';
  188. if($content[$b]->p_code == 'first_last_ball' || $content[$b]->p_code == 'half_full' || $content[$b]->p_code == 'capot' || $content[$b]->p_code == 'two_sides' || $content[$b]->p_code == 'total_goal'){
  189. $content[$b]->condition = '';
  190. }
  191. $data[$i]->game_status = $data[$i]->game_status;
  192. /*
  193. //投注详情
  194. if(!empty($data[$i]->match_time)){
  195. $data[$i]->content1 = '['.$data[$i]->match_time.']';
  196. //$data[$i]->match_time = $data[$i]->match_time;
  197. }
  198. else{
  199. if(!empty($data[$i]->last_time)){
  200. $datetime = explode(' ',$data[$i]->last_time);
  201. //$data[$i]->match_time = $datetime[1];
  202. $data[$i]->content1 = '['.$datetime[1].']';
  203. }
  204. }
  205. */
  206. /*
  207. for($c=0;$c<count($result);$c++){
  208. if($content[$b]->odds_code == $result[$c]->odds_code){
  209. $data[$i]->str1 = 1;
  210. if($content[$b]->result=='未处理'){
  211. $data[$i]->content = $content[$b]->home_team.'<br>'.$data[$i]->content.$result[$c]->odds_name.'<br>'.$content[$b]->condition.' '.$data[$i]->team.'@'.$content[$b]->odds.' ¥'.$content[$b]->bet_money.'<br>';
  212. }else{
  213. $data[$i]->content = $content[$b]->home_team.'<br>'.$data[$i]->content.$result[$c]->odds_name.'<br>'.$content[$b]->condition.' '.$data[$i]->team.'@'.$content[$b]->odds.' ¥'.$content[$b]->bet_money.'<br><span>'.$content[$b]->result.'</span>('.$content[$b]->matchresult.')<br>';
  214. }
  215. }
  216. }
  217. */
  218. if($data[$i]->str1 == 0){
  219. if($content[$b]->result=='未处理'){
  220. $data[$i]->content = $content[$b]->home_team.'<br>'.$data[$i]->content.$content[$b]->odds_code.'<br>'.$content[$b]->condition.' '.$data[$i]->team.'@'.$content[$b]->odds.' ¥'.$content[$b]->bet_money.'<br>';
  221. }else{
  222. $data[$i]->content = $content[$b]->home_team.'<br>'.$data[$i]->content.$content[$b]->odds_code.'<br>'.$content[$b]->condition.' '.$data[$i]->team.'@'.$content[$b]->odds.' ¥'.$content[$b]->bet_money.'<br><span>'.$content[$b]->result.'</span>('.$content[$b]->matchresult.')<br>';
  223. }
  224. }
  225. }
  226. }
  227. // if($data[$i]->status == 1){
  228. // if($data[$i]->match_status == 0 || $data[$i]->match_status == 1){
  229. // $data[$i]->game_status = $data[$i]->settle_status.'<br><a class="layui-btn layui-btn-sm audit" lay-event="detail" pid="id" uri="" href="javascript:void(0)" style="background-color: grey;"> 结算 </a>';
  230. // }
  231. // if($data[$i]->match_status == 2 || $data[$i]->match_status == 3 || $data[$i]->match_status == 5){
  232. // if($data[$i]->settle_status == '已结算'){
  233. // $data[$i]->game_status = $data[$i]->settle_status.'<br><a class="layui-btn layui-btn-sm resettlement" lay-event="detail" pid="id" uri="/admin/SoccerNoteList/resettlement/?id=" href="javascript:resettlement(\'/admin/SoccerNoteList/resettlement/?id='.$data[$i]->id.'\');"> 重新结算 </a>';
  234. // }else{
  235. // $data[$i]->game_status = $data[$i]->settle_status.'<br><a class="layui-btn layui-btn-sm settlement" lay-event="detail" pid="id" uri="/admin/SoccerNoteList/settlement/?id=" href="javascript:settlement(\'/admin/SoccerNoteList/settlement/?id='.$data[$i]->id.'\');"> 结算 </a>';
  236. // }
  237. // }
  238. // }else{
  239. // $data[$i]->game_status = $data[$i]->settle_status.'<br><a class="layui-btn layui-btn-sm audit" lay-event="detail" pid="id" uri="" href="javascript:void(0)" style="background-color: grey;"> 结2算 </a>';
  240. // }
  241. $data[$i]->content = $data[$i]->content1.$data[$i]->content;
  242. }
  243. return $data->toArray();
  244. }
  245. //投注金额汇总统计
  246. function MoneyCount($where = '',$type) {
  247. $data = array();
  248. // $data['all_money'] = $this->sum('money');
  249. // $data['all_prize_money'] = $this->sum('prize_money');
  250. // $data['alraedy_prize_money'] = $this->where('settle_status','2')->sum('gain_money');
  251. $data['all_money'] = 0;
  252. $data['all_prize_money'] = 0;
  253. $data['alraedy_prize_money'] = 0;
  254. $all_money = $this->join('money_details','money_details.info_identity','=','money_buy_simplex.info_identity')->join('st_'.$type.'_competition','st_'.$type.'_competition.id','=','money_buy_simplex.match_id')->join('st_'.$type.'_league','st_'.$type.'_competition.lg_id','=','st_'.$type.'_league.id')->select('money_buy_simplex.money','money_buy_simplex.prize_money','money_buy_simplex.gain_money')->where('money_buy_simplex.status','1')->get();
  255. for($a=0;$a<count($all_money);$a++){
  256. $data['all_money'] = $data['all_money']+$all_money[$a]->money;
  257. }
  258. $all_prize_money = $this->join('money_details','money_details.info_identity','=','money_buy_simplex.info_identity')->join('st_'.$type.'_competition','st_'.$type.'_competition.id','=','money_buy_simplex.match_id')->join('st_'.$type.'_league','st_'.$type.'_competition.lg_id','=','st_'.$type.'_league.id')->select('money_buy_simplex.money','money_buy_simplex.prize_money','money_buy_simplex.gain_money')->where('money_buy_simplex.status','1')->get();
  259. for($a=0;$a<count($all_prize_money);$a++){
  260. $data['all_prize_money'] = $data['all_money']+$all_prize_money[$a]->prize_money;
  261. }
  262. $alraedy_prize_money = $this->join('money_details','money_details.info_identity','=','money_buy_simplex.info_identity')->join('st_'.$type.'_competition','st_'.$type.'_competition.id','=','money_buy_simplex.match_id')->join('st_'.$type.'_league','st_'.$type.'_competition.lg_id','=','st_'.$type.'_league.id')->select('money_buy_simplex.money','money_buy_simplex.prize_money','money_buy_simplex.gain_money')->where('money_buy_simplex.settle_status','2')->where('money_buy_simplex.status','1')->get();
  263. for($a=0;$a<count($alraedy_prize_money);$a++){
  264. $data['alraedy_prize_money'] = $data['all_money']+$alraedy_prize_money[$a]->gain_money;
  265. }
  266. if (!empty($where) && is_array($where)) {
  267. $data['all_money'] = 0;
  268. $data['all_prize_money'] = 0;
  269. $data['alraedy_prize_money'] = 0;
  270. //$data['all_money'] = $this->where($where)->sum('money');
  271. // $data['all_prize_money'] = $this->where($where)->sum('prize_money');
  272. // $data['alraedy_prize_money'] = $this->where($where)->where('settle_status','2')->sum('gain_money');
  273. $all_money = $this->join('money_details','money_details.info_identity','=','money_buy_simplex.info_identity')->join('st_zq_competition','st_zq_competition.id','=','money_buy_simplex.match_id')->join('st_zq_league','st_zq_competition.lg_id','=','st_zq_league.id')->select('money_buy_simplex.money','money_buy_simplex.prize_money','money_buy_simplex.gain_money')->where($where)->where('money_buy_simplex.status','1')->get();
  274. for($a=0;$a<count($all_money);$a++){
  275. $data['all_money'] = $data['all_money']+$all_money[$a]->money;
  276. }
  277. $all_prize_money = $this->join('money_details','money_details.info_identity','=','money_buy_simplex.info_identity')->join('st_'.$type.'_competition','st_'.$type.'_competition.id','=','money_buy_simplex.match_id')->join('st_'.$type.'_league','st_'.$type.'_competition.lg_id','=','st_'.$type.'_league.id')->select('money_buy_simplex.money','money_buy_simplex.prize_money','money_buy_simplex.gain_money')->where($where)->where('money_buy_simplex.status','1')->get();
  278. for($a=0;$a<count($all_prize_money);$a++){
  279. $data['all_prize_money'] = $data['all_prize_money']+$all_prize_money[$a]->prize_money;
  280. }
  281. $alraedy_prize_money = $this->join('money_details','money_details.info_identity','=','money_buy_simplex.info_identity')->join('st_'.$type.'_competition','st_'.$type.'_competition.id','=','money_buy_simplex.match_id')->join('st_'.$type.'_league','st_'.$type.'_competition.lg_id','=','st_'.$type.'_league.id')->select('money_buy_simplex.money','money_buy_simplex.prize_money','money_buy_simplex.gain_money')->where('money_buy_simplex.settle_status','2')->where($where)->where('money_buy_simplex.status','1')->get();
  282. for($a=0;$a<count($alraedy_prize_money);$a++){
  283. $data['alraedy_prize_money'] = $data['alraedy_prize_money']+$alraedy_prize_money[$a]->gain_money;
  284. }
  285. }
  286. return $data;
  287. }
  288. //修改赛事下的所有单式下注 3199308
  289. function updatesimplex($ssid,$code){
  290. $newapp = new \App\Models\MoneyBuyMatch();
  291. $data = $newapp->allsimplexorder($ssid,$code);
  292. if($data){
  293. for ($i=0; $i < count($data); $i++) {
  294. $the = array(
  295. 'status' => 2,
  296. 'game_status' => 3,
  297. 'game_code' =>$code,
  298. );
  299. $res = $this->where('order_id',$data[$i]['order_id'])->update($the);
  300. }
  301. if($res<0){
  302. return -7012000302; //操作失败
  303. }
  304. return $res;
  305. }else{
  306. return -111;
  307. }
  308. }
  309. function info($list = 10, $page, $where = '',$type)
  310. {
  311. $data = $this
  312. ->join('money_details','money_details.info_identity','=','money_buy_simplex.info_identity')
  313. ->join('st_'.$type.'_competition','st_'.$type.'_competition.id','=','money_buy_simplex.match_id')
  314. // ->join('st_'.$type.'_league','st_'.$type.'_competition.lg_id','=','st_'.$type.'_league.id')
  315. ->join('st_'.$type.'_league','money_buy_simplex.lg_id','=','st_'.$type.'_league.id')
  316. ->select('money_buy_simplex.id','money_buy_simplex.account_name','money_buy_simplex.is_champion','money_buy_simplex.account_identity','money_buy_simplex.order_id','money_buy_simplex.money','money_buy_simplex.prize_money','money_buy_simplex.status','money_buy_simplex.money_time','money_buy_simplex.settle_status','money_buy_simplex.gain_money','money_buy_simplex.game_code','money_buy_simplex.match_id','money_buy_simplex.game_status','st_'.$type.'_competition.home_team','st_'.$type.'_competition.guest_team','st_'.$type.'_competition.match_date','st_'.$type.'_competition.match_time','st_'.$type.'_competition.lg_id','st_'.$type.'_competition.status as match_status','money_details.money_cash','money_buy_simplex.batch_id','st_'.$type.'_league.name_chinese','st_'.$type.'_league.last_time')
  317. ->where($where)
  318. ->orderby('money_buy_simplex.money_time','desc')
  319. ->paginate ($list);
  320. if (!$data < 0) {
  321. return -2021052003; //
  322. }
  323. // dd($data);
  324. //反水
  325. $water_return_money = \App\Models\Money_details::where('trade_type','7')->get();
  326. //注单作废
  327. $invalid_money = \App\Models\Money_details::where('trade_type','3')->get();
  328. //订单投注的玩法
  329. $content = \App\Models\MoneyBuyMatch::where('bet_type','1')->get();
  330. for($d=0;$d<count($content);$d++){
  331. if($content[$d]->result==0){
  332. $content[$d]->result = '未处理';
  333. }
  334. if($content[$d]->result==1){
  335. $content[$d]->result = '赢';
  336. }
  337. if($content[$d]->result==-1){
  338. $content[$d]->result = '输';
  339. }
  340. if($content[$d]->result==2){
  341. $content[$d]->result = '平';
  342. }
  343. if($content[$d]->result==3){
  344. $content[$d]->result = '赢半平半';
  345. }
  346. if($content[$d]->result==4){
  347. $content[$d]->result = '输半平半';
  348. }
  349. }
  350. //玩法
  351. $result = \App\Models\Matchcode::where('game_code',$type)->get();
  352. //$result = \App\Model\Matchcode::get();
  353. for($i=0;$i<count($data);$i++){
  354. if($data[$i]->status==1 && $data[$i]->game_status==0){
  355. $data[$i]->order_status = '投注'.'<br><a class="layui-btn layui-btn-sm invalid" lay-event="detail" pid="id" uri="/admin/SoccerNoteList/invalid/?id=" href="javascript:invalid(\'/admin/SoccerNoteList/invalid/?id='.$data[$i]->id.'\');"> 作废 </a>';
  356. }else if($data[$i]->status==1 && $data[$i]->game_status!=0){
  357. $data[$i]->order_status = '投注';
  358. }else if($data[$i]->status==2){
  359. $data[$i]->order_status = '作废';
  360. }else if($data[$i]->status==3){
  361. $data[$i]->order_status = '撤单';
  362. }
  363. // if($data[$i]->settle_status==1){
  364. // $data[$i]->settle_status = '未结算';
  365. // }else if($data[$i]->settle_status==2){
  366. // $data[$i]->settle_status = '已结算';
  367. // }
  368. if($data[$i]->game_status==0){
  369. $data[$i]->game_status = '未处理';
  370. }else{
  371. $data[$i]->game_status = '已处理';
  372. }
  373. if($data[$i]->game_code == 'zq'){
  374. $data[$i]->match_id_order = '<a href="/admin/sportsfoot/outcome?home_team='.$data[$i]->match_id.'">'.$data[$i]->match_id.'</a> (<span>'.$data[$i]->account_name.'</span>)<br>'.$data[$i]->order_id;
  375. }
  376. if($data[$i]->game_code == 'lq'){
  377. $data[$i]->match_id_order = '<a href="/admin/Sportsbk/outcome?home_team='.$data[$i]->match_id.'">'.$data[$i]->match_id.'</a> (<span>'.$data[$i]->account_name.'</span>)<br>'.$data[$i]->order_id;
  378. }
  379. if($data[$i]->game_code == 'wq'){
  380. $data[$i]->match_id_order = '<a href="/admin/Sportswq/outcome?home_team='.$data[$i]->match_id.'">'.$data[$i]->match_id.'</a> (<span>'.$data[$i]->account_name.'</span>)<br>'.$data[$i]->order_id;
  381. }
  382. if($data[$i]->game_code == 'bq'){
  383. $data[$i]->match_id_order = '<a href="/admin/Sportsbq/outcome?home_team='.$data[$i]->match_id.'">'.$data[$i]->match_id.'</a> (<span>'.$data[$i]->account_name.'</span>)<br>'.$data[$i]->order_id;
  384. }
  385. $data[$i]->league = $data[$i]->name_chinese;
  386. if($data[$i]->is_champion == 0){
  387. $data[$i]->home_guest = $data[$i]->home_team.' VS '.$data[$i]->guest_team;
  388. $data[$i]->time = '开赛:'.$data[$i]->match_date.' '.$data[$i]->match_time;
  389. }else{
  390. $data[$i]->home_guest = '冠军联赛投注';
  391. $data[$i]->time = '结束:'.$data[$i]->last_time;
  392. }
  393. $data[$i]->money_match_time = '下注:'.$data[$i]->money_time.$data[$i]->time;
  394. /*
  395. $data[$i]->home_guest = $data[$i]->home_team.' VS '.$data[$i]->guest_team;
  396. $data[$i]->time = '开赛:'.$data[$i]->match_date.' '.$data[$i]->match_time;
  397. $data[$i]->money_match_time = '下注:'.$data[$i]->money_time.'<br>'.$data[$i]->time;
  398. */
  399. //反水
  400. $data[$i]->water_return = -1;
  401. for($a=0;$a<count($water_return_money);$a++){
  402. if($data[$i]->order_id == $water_return_money[$a]->trade_id){
  403. if($data[$i]->status == 2 || $data[$i]->status == 3){
  404. $data[$i]->water_return = 0;
  405. }else{
  406. $data[$i]->water_return = $water_return_money[$a]->money;
  407. }
  408. //用户投注后账户金额
  409. $data[$i]->frozen_cash = $water_return_money[$a]->money_cash;
  410. }
  411. }
  412. if($data[$i]->water_return == -1){
  413. $data[$i]->water_return = 0;
  414. //用户投注后账户金额
  415. $data[$i]->frozen_cash = $data[$i]->money_cash;
  416. }
  417. //此时结果金额
  418. $data[$i]->result = $data[$i]->water_return+$data[$i]->gain_money;
  419. //用户投注前账户金额
  420. $data[$i]->available_cash = $data[$i]->money_cash+$data[$i]->money;
  421. //投注前后账户金额
  422. $data[$i]->account_money = $data[$i]->available_cash.'<br><span>'.$data[$i]->money.'</span><br>'.$data[$i]->frozen_cash;
  423. if($data[$i]->status == 2 || $data[$i]->status == 3){
  424. for($b=0;$b<count($invalid_money);$b++){
  425. if($data[$i]->order_id == $invalid_money[$b]->trade_id){
  426. $data[$i]->available_cash = $invalid_money[$b]->money_cash;
  427. $data[$i]->account_money = $data[$i]->available_cash;
  428. }
  429. }
  430. }
  431. $data[$i]->str = 0;
  432. for($b=0;$b<count($content);$b++){
  433. $data[$i]->str1 = 0;
  434. $data[$i]->team = '';
  435. if(!empty($content[$b]->odds_code)){
  436. if(!empty(stristr($content[$b]->odds_code,'home'))){
  437. $data[$i]->team = $data[$i]->home_team;
  438. }
  439. if(!empty(stristr($content[$b]->odds_code,'guest'))){
  440. $data[$i]->team = $data[$i]->guest_team;
  441. }
  442. if($content[$b]->p_code == 'half_full'){
  443. $string = str_replace('home',$data[$i]->home_team,$content[$b]->odds_code);
  444. $string = str_replace('guest',$data[$i]->guest_team,$string);
  445. $string = str_replace('dogfall','和局',$string);
  446. $string = explode('_',$string);
  447. $data[$i]->team = $string['2'].'/'.$string['3'];
  448. }
  449. }
  450. //处理普通赛事
  451. if($data[$i]->match_id == $content[$b]->match_id && $data[$i]->batch_id == $content[$b]->batch_id &&$data[$i]->is_champion == 0){
  452. if($content[$b]->p_code == 'first_last_ball' || $content[$b]->p_code == 'half_full' || $content[$b]->p_code == 'capot' || $content[$b]->p_code == 'two_sides' || $content[$b]->p_code == 'total_goal'){
  453. $content[$b]->condition = '';
  454. }
  455. $data[$i]->game_status = $data[$i]->game_status;
  456. //投注详情
  457. if(!empty($data[$i]->match_time)){
  458. $data[$i]->content1 = '['.$data[$i]->match_time.']';
  459. //$data[$i]->match_time = $data[$i]->match_time;
  460. }else{
  461. if(!empty($data[$i]->last_time)){
  462. $datetime = explode(' ',$data[$i]->last_time);
  463. //$data[$i]->match_time = $datetime[1];
  464. $data[$i]->content1 = '['.$datetime[1].']';
  465. }
  466. }
  467. for($c=0;$c<count($result);$c++){
  468. if($content[$b]->odds_code == $result[$c]->odds_code){
  469. $data[$i]->str1 = 1;
  470. if($content[$b]->result=='未处理'){
  471. $data[$i]->content = $data[$i]->content.$result[$c]->odds_name.'<br>'.$content[$b]->condition.' '.$data[$i]->team.'@'.$content[$b]->odds.' ¥'.$content[$b]->bet_money.'<br>';
  472. }else{
  473. $data[$i]->content = $data[$i]->content.$result[$c]->odds_name.'<br>'.$content[$b]->condition.' '.$data[$i]->team.'@'.$content[$b]->odds.' ¥'.$content[$b]->bet_money.'<br><span>'.$content[$b]->result.'</span>('.$content[$b]->matchresult.')<br>';
  474. }
  475. }
  476. }
  477. if($data[$i]->str1 == 0){
  478. if($content[$b]->result=='未处理'){
  479. $data[$i]->content = $data[$i]->content.$content[$b]->odds_code.'<br>'.$content[$b]->condition.' '.$data[$i]->team.'@'.$content[$b]->odds.' ¥'.$content[$b]->bet_money.'<br>';
  480. }else{
  481. $data[$i]->content = $data[$i]->content.$content[$b]->odds_code.'<br>'.$content[$b]->condition.' '.$data[$i]->team.'@'.$content[$b]->odds.' ¥'.$content[$b]->bet_money.'<br><span>'.$content[$b]->result.'</span>('.$content[$b]->matchresult.')<br>';
  482. }
  483. }
  484. }
  485. //处理冠军联赛玩法详情
  486. if($data[$i]->match_id == $content[$b]->lg_id && $data[$i]->batch_id == $content[$b]->batch_id &&$data[$i]->is_champion == 1){
  487. $content[$b]->condition = '';
  488. if($content[$b]->p_code == 'first_last_ball' || $content[$b]->p_code == 'half_full' || $content[$b]->p_code == 'capot' || $content[$b]->p_code == 'two_sides' || $content[$b]->p_code == 'total_goal'){
  489. $content[$b]->condition = '';
  490. }
  491. $data[$i]->game_status = $data[$i]->game_status;
  492. /*
  493. //投注详情
  494. if(!empty($data[$i]->match_time)){
  495. $data[$i]->content1 = '['.$data[$i]->match_time.']';
  496. //$data[$i]->match_time = $data[$i]->match_time;
  497. }
  498. else{
  499. if(!empty($data[$i]->last_time)){
  500. $datetime = explode(' ',$data[$i]->last_time);
  501. //$data[$i]->match_time = $datetime[1];
  502. $data[$i]->content1 = '['.$datetime[1].']';
  503. }
  504. }
  505. */
  506. /*
  507. for($c=0;$c<count($result);$c++){
  508. if($content[$b]->odds_code == $result[$c]->odds_code){
  509. $data[$i]->str1 = 1;
  510. if($content[$b]->result=='未处理'){
  511. $data[$i]->content = $data[$i]->content.$result[$c]->odds_name.'<br>'.$content[$b]->condition.' '.$data[$i]->team.'@'.$content[$b]->odds.' ¥'.$content[$b]->bet_money.'<br>';
  512. }else{
  513. $data[$i]->content = $data[$i]->content.$result[$c]->odds_name.'<br>'.$content[$b]->condition.' '.$data[$i]->team.'@'.$content[$b]->odds.' ¥'.$content[$b]->bet_money.'<br><span>'.$content[$b]->result.'</span>('.$content[$b]->matchresult.')<br>';
  514. }
  515. }
  516. }
  517. */
  518. if($data[$i]->str1 == 0){
  519. if($content[$b]->result=='未处理'){
  520. $data[$i]->content = $content[$b]->home_team.'<br>'.$data[$i]->content.$content[$b]->odds_code.'<br>'.$content[$b]->condition.' '.$data[$i]->team.'@'.$content[$b]->odds.' ¥'.$content[$b]->bet_money.'<br>';
  521. }else{
  522. $data[$i]->content = $content[$b]->home_team.'<br>'.$data[$i]->content.$content[$b]->odds_code.'<br>'.$content[$b]->condition.' '.$data[$i]->team.'@'.$content[$b]->odds.' ¥'.$content[$b]->bet_money.'<br><span>'.$content[$b]->result.'</span>('.$content[$b]->matchresult.')<br>';
  523. }
  524. }
  525. }
  526. }
  527. $data[$i]->game_status = $data[$i]->settle_status;
  528. $data[$i]->content = $data[$i]->content1.$data[$i]->content;
  529. }
  530. return $data->toArray();
  531. }
  532. //查询单订单是否存在
  533. function onlyorder($orderid){
  534. $order = $this->where('order_id', $orderid)->count();
  535. return $order;
  536. }
  537. }