ManualController.php 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  1. <?php
  2. // +—————————————————————————————————————————————————————————————————————
  3. // | Created by Yunbao
  4. // +—————————————————————————————————————————————————————————————————————
  5. // | Copyright (c) 2013~2022 http://www.yunbaokj.com All rights reserved.
  6. // +—————————————————————————————————————————————————————————————————————
  7. // | Author: https://gitee.com/yunbaokeji
  8. // +—————————————————————————————————————————————————————————————————————
  9. // | Date: 2022-02-17
  10. // +—————————————————————————————————————————————————————————————————————
  11. /**
  12. * 管理员手动充值记录
  13. */
  14. namespace app\admin\controller;
  15. use cmf\controller\AdminBaseController;
  16. use think\Db;
  17. class ManualController extends AdminbaseController {
  18. public function index(){
  19. $data = $this->request->param();
  20. $map=[];
  21. $start_time=isset($data['start_time']) ? $data['start_time']: '';
  22. $end_time=isset($data['end_time']) ? $data['end_time']: '';
  23. if($start_time!=""){
  24. $map[]=['addtime','>=',strtotime($start_time)];
  25. }
  26. if($end_time!=""){
  27. $map[]=['addtime','<=',strtotime($end_time) + 60*60*24];
  28. }
  29. $status=isset($data['status']) ? $data['status']: '';
  30. if($status!=''){
  31. $map[]=['status','=',$status];
  32. }
  33. $uid=isset($data['uid']) ? $data['uid']: '';
  34. if($uid!=''){
  35. $lianguid=getLianguser($uid);
  36. if($lianguid){
  37. $map[]=['touid',['=',$uid],['in',$lianguid],'or'];
  38. }else{
  39. $map[]=['touid','=',$uid];
  40. }
  41. }
  42. $lists = Db::name("charge_admin")
  43. ->where($map)
  44. ->order("id desc")
  45. ->paginate(20);
  46. $lists->each(function($v,$k){
  47. $v['userinfo']=getUserInfo($v['touid']);
  48. $v['ip']=long2ip($v['ip']);
  49. return $v;
  50. });
  51. $lists->appends($data);
  52. $page = $lists->render();
  53. $this->assign('lists', $lists);
  54. $this->assign("page", $page);
  55. $coin = Db::name("charge_admin")
  56. ->where($map)
  57. ->sum('coin');
  58. if(!$coin){
  59. $coin=0;
  60. }
  61. $this->assign('coin', $coin);
  62. return $this->fetch();
  63. }
  64. public function add(){
  65. return $this->fetch();
  66. }
  67. public function addPost(){
  68. if ($this->request->isPost()) {
  69. $data = $this->request->param();
  70. $touid=$data['touid'];
  71. if($touid==""){
  72. $this->error("请填写用户ID");
  73. }
  74. $uid=Db::name("user")->where(["id"=>$touid])->value("id");
  75. if(!$uid){
  76. $this->error("会员不存在,请更正");
  77. }
  78. $coin=$data['coin'];
  79. if($coin==""){
  80. $this->error("请填写充值点数");
  81. }
  82. if(!is_numeric($coin)){
  83. $this->error("充值点数必须为数字");
  84. }
  85. if(floor($coin)!=$coin){
  86. $this->error("充值点数必须为整数");
  87. }
  88. $user_coin=Db::name("user")->where(["id"=>$touid])->value("coin");
  89. $total=$user_coin+$coin;
  90. if($total<0){
  91. $total=0;
  92. }
  93. $adminid=cmf_get_current_admin_id();
  94. $admininfo=Db::name("user")->where(["id"=>$adminid])->value("user_login");
  95. $data['admin']=$admininfo;
  96. $ip=get_client_ip(0,true);
  97. $data['ip']=ip2long($ip);
  98. $data['addtime']=time();
  99. $id = DB::name('charge_admin')->insertGetId($data);
  100. if(!$id){
  101. $this->error("充值失败!");
  102. }
  103. Db::name("user")->where(["id"=>$touid])->update(['coin'=>$total]);
  104. $this->success("充值成功!");
  105. }
  106. }
  107. public function export(){
  108. $data = $this->request->param();
  109. $map=[];
  110. $start_time=isset($data['start_time']) ? $data['start_time']: '';
  111. $end_time=isset($data['end_time']) ? $data['end_time']: '';
  112. if($start_time!=""){
  113. $map[]=['addtime','>=',strtotime($start_time)];
  114. }
  115. if($end_time!=""){
  116. $map[]=['addtime','<=',strtotime($end_time) + 60*60*24];
  117. }
  118. $status=isset($data['status']) ? $data['status']: '';
  119. if($status!=''){
  120. $map[]=['status','=',$status];
  121. }
  122. $uid=isset($data['uid']) ? $data['uid']: '';
  123. if($uid!=''){
  124. $lianguid=getLianguser($uid);
  125. if($lianguid){
  126. $map[]=['touid',['=',$uid],['in',$lianguid],'or'];
  127. }else{
  128. $map[]=['touid','=',$uid];
  129. }
  130. }
  131. $xlsName = "手动充值记录";
  132. $xlsData = Db::name("charge_admin")
  133. ->where($map)
  134. ->order("id desc")
  135. ->select()
  136. ->toArray();
  137. foreach ($xlsData as $k => $v){
  138. $userinfo=getUserInfo($v['touid']);
  139. $xlsData[$k]['ip']=long2ip($v['ip']);
  140. $xlsData[$k]['user_nicename']= $userinfo['user_nicename'].'('.$v['touid'].')';
  141. $xlsData[$k]['addtime']=date("Y-m-d H:i:s",$v['addtime']);
  142. }
  143. $cellName = array('A','B','C','D','E','F');
  144. $xlsCell = array(
  145. array('id','序号'),
  146. array('admin','管理员'),
  147. array('user_nicename','会员 (账号)(ID)'),
  148. array('coin','充值点数'),
  149. array('ip','IP'),
  150. array('addtime','时间'),
  151. );
  152. exportExcel($xlsName,$xlsCell,$xlsData,$cellName);
  153. }
  154. }