Bank.php 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310
  1. <?php
  2. /**
  3. * @copyright Copyright (c) 2017 https://www.sapixx.com All rights reserved.
  4. * @license Licensed (http://www.apache.org/licenses/LICENSE-2.0).
  5. * @author pillar<ltmn@qq.com>
  6. * 客户收益管理
  7. */
  8. namespace app\fastshop\controller;
  9. use app\common\controller\Manage;
  10. class Bank extends Manage
  11. {
  12. public function initialize()
  13. {
  14. parent::initialize();
  15. if(!model('auth')->getAuth($this->user->id,3)){
  16. $this->error('无权限,你非【财务管理员】');
  17. }
  18. $this->assign('pathMaps', [['name'=>'客户收益','url'=>'javascript:;']]);
  19. }
  20. /**
  21. * 客户收益管理
  22. * @return void
  23. */
  24. public function index(int $types = 0){
  25. switch ($types) {
  26. case 1:
  27. $order = 'income_money desc';
  28. break;
  29. case 2:
  30. $order = 'money desc';
  31. break;
  32. case 3:
  33. $order = 'lack_money desc';
  34. break;
  35. case 4:
  36. $order = 'shop_money desc';
  37. break;
  38. default:
  39. $order = 'update_time desc';
  40. break;
  41. }
  42. $keyword = trim(input('get.keyword','','htmlspecialchars'));
  43. if(!empty($keyword)){
  44. $condition['system_user.phone_uid'] = $keyword;
  45. }
  46. $condition['fastshop_bank.member_miniapp_id'] = $this->member_miniapp_id;
  47. $view['list'] = model('Bank')->view('fastshop_bank','*')->view('system_user','nickname','fastshop_bank.user_id = system_user.id')->where($condition)->order($order)->paginate(20);
  48. $view['keyword'] = $keyword;
  49. $view['types'] = $types;
  50. return view()->assign($view);
  51. }
  52. /**
  53. * 统计日志
  54. * @return void
  55. */
  56. public function counts(){
  57. $starttime = empty(input('get.starttime')) ? 0 : strtotime(input('get.starttime/s'));
  58. $endtime = empty(input('get.endtime')) ? 0 : strtotime(input('get.endtime/s'));
  59. $whereorder = [];
  60. $entrust = [];
  61. $rebate = [];
  62. if(!empty($starttime) && !empty($endtime)){
  63. if($starttime > $endtime){
  64. $this->error('开始日期不能大于结束日期');
  65. }
  66. $whereorder[] = ['order_starttime','>=',$starttime];
  67. $whereorder[] = ['order_starttime','<=',$endtime];
  68. $entrust[] = ['create_time','>=',$starttime];
  69. $entrust[] = ['create_time','<=',$endtime];
  70. $rebate[] = ['update_time','>=',$starttime];
  71. $rebate[] = ['update_time','<=',$endtime];
  72. }
  73. $config = model('Config')->get(['member_miniapp_id' => $this->member_miniapp_id]);
  74. if(empty($config)){
  75. $proportion = 0;
  76. }else{
  77. if($config->reward_types == 1){
  78. $proportion = ($config->profit+$config->reward_nth+$config->reward_ratio)/100;
  79. }else{
  80. $proportion = ($config->profit+$config->reward_ratio+$config->platform_ratio)/100;
  81. }
  82. }
  83. $view['bank'] = model('order')->where($whereorder)->where(['member_miniapp_id' => $this->member_miniapp_id,'paid_at' => 1,'is_point' => 0])->sum('order_amount');
  84. $view['point'] = model('order')->where($whereorder)->where(['member_miniapp_id' => $this->member_miniapp_id,'paid_at' => 1,'is_point' => 1])->sum('order_amount');
  85. $view['order_wechat'] = model('order')->where($whereorder)->where(['member_miniapp_id' => $this->member_miniapp_id,'paid_at' => 1,'is_point' => 0])->count();
  86. $view['order_point'] = model('order')->where($whereorder)->where(['member_miniapp_id' => $this->member_miniapp_id,'paid_at' => 1,'is_point' => 1])->count();
  87. $view['due_money'] = model('Bank')->where(['member_miniapp_id' => $this->member_miniapp_id])->sum('due_money');
  88. $view['shop_money'] = model('Bank')->where(['member_miniapp_id' => $this->member_miniapp_id])->sum('shop_money');
  89. $view['lack_money'] = model('Bank')->where(['member_miniapp_id' => $this->member_miniapp_id])->sum('lack_money');
  90. $view['alllack_money'] = model('BankCash')->where(['member_miniapp_id' => $this->member_miniapp_id,'state' => 1])->sum('money');
  91. $view['entrust'] = model('EntrustList')->where($entrust)->where(['member_miniapp_id' => $this->member_miniapp_id,'is_rebate' => 0])->count();
  92. $view['entrust_rebate'] = model('EntrustList')->where($rebate)->where(['member_miniapp_id' => $this->member_miniapp_id,'is_rebate' => 1,'is_diy' => 0])->count();
  93. $view['entrust_diy'] = model('EntrustList')->where($rebate)->where(['member_miniapp_id' => $this->member_miniapp_id,'is_rebate' => 1,'is_diy' => 1])->count();
  94. $view['entrust_money'] = model('EntrustList')->where($rebate)->where(['member_miniapp_id' => $this->member_miniapp_id,'is_rebate' => 1,'is_diy' => 0])->sum('rebate');
  95. $view['entrust_diy_money'] = model('EntrustList')->where($rebate)->where(['member_miniapp_id' => $this->member_miniapp_id,'is_rebate' => 1,'is_diy' => 1])->sum('rebate');
  96. $view['bonus_money'] = ($view['entrust_money']+$view['entrust_diy_money'])*$proportion;
  97. $view['starttime'] = $starttime;
  98. $view['endtime'] = $endtime;
  99. return view()->assign($view);
  100. }
  101. /**
  102. * 客户收益记录
  103. * @return void
  104. */
  105. public function top(){
  106. $view['list'] = model('BankAll')->where(['member_miniapp_id' => $this->member_miniapp_id])->order('account desc')->paginate(20);;
  107. return view()->assign($view);
  108. }
  109. /**
  110. * 客户收益记录
  111. * @return void
  112. */
  113. public function logs(int $input = 0){
  114. $starttime = empty(input('get.starttime')) ? 0 : input('get.starttime/s');
  115. $endtime = empty(input('get.endtime')) ? 0 : input('get.endtime/s');
  116. $where = [];
  117. $where[] = ['user_id','=',$input];
  118. $condition = [];
  119. $condition[] = ['user_id','=',$input];
  120. if(!empty($starttime) && !empty($endtime)){
  121. if($starttime > $endtime){
  122. $this->error('开始日期不能大于结束日期');
  123. }
  124. $where[] = ['update_time','>=',strtotime($starttime)];
  125. $where[] = ['update_time','<=',strtotime($endtime)];
  126. $condition[] = ['paid_time','>=',strtotime($starttime)];
  127. $condition[] = ['paid_time','<=',strtotime($endtime)];
  128. }
  129. $view['receipts'] = model('BankLogs')->where(['member_miniapp_id' => $this->member_miniapp_id])->where($where)->where('money','>',0)->sum('money'); //收入
  130. $view['expenses'] = model('BankLogs')->where(['member_miniapp_id' => $this->member_miniapp_id])->where($where)->where('money','<',0)->sum('money'); //支付
  131. $view['balance'] = abs($view['receipts'])-abs($view['expenses']);
  132. $view['wechat_pay'] = model('Order')->where(['member_miniapp_id' => $this->member_miniapp_id,'paid_at' => 1,'is_point' => 0])->where($condition)->sum('real_amount');
  133. $view['balance_pay'] = model('Order')->where(['member_miniapp_id' => $this->member_miniapp_id,'paid_at' => 1,'is_point' => 1])->where($condition)->sum('real_amount');
  134. $view['list'] = model('BankLogs')->where($where)->order('id desc')->paginate(20,false,['query'=>['input' =>$input,'starttime'=>$starttime,'endtime'=>$endtime]]);
  135. $view['input'] = $input;
  136. $view['starttime'] = $starttime;
  137. $view['endtime'] = $endtime;
  138. return view()->assign($view);
  139. }
  140. /**
  141. * 客户收益记录
  142. * @return void
  143. */
  144. public function alllogs(){
  145. $starttime = empty(input('get.starttime')) ? 0 : input('get.starttime/s');
  146. $endtime = empty(input('get.endtime')) ? 0 : input('get.endtime/s');
  147. $where = [];
  148. if(!empty($starttime) && !empty($endtime)){
  149. if($starttime > $endtime){
  150. $this->error('开始日期不能大于结束日期');
  151. }
  152. $where[] = ['update_time','>=',strtotime($starttime)];
  153. $where[] = ['update_time','<=',strtotime($endtime)];
  154. }
  155. $view['receipts'] = model('BankLogs')->where(['member_miniapp_id' => $this->member_miniapp_id])->where($where)->where('money','>',0)->sum('money'); //收入
  156. $view['expenses'] = model('BankLogs')->where(['member_miniapp_id' => $this->member_miniapp_id])->where($where)->where('money','<',0)->sum('money'); //支付
  157. $view['balance'] = $view['expenses']+$view['receipts'];
  158. $view['list'] = model('BankLogs')->where(['member_miniapp_id' => $this->member_miniapp_id])->where($where)->order('id desc')->paginate(20,false,['query'=>['starttime'=>$starttime,'endtime'=>$endtime]]);
  159. $view['starttime'] = $starttime;
  160. $view['endtime'] = $endtime;
  161. return view()->assign($view);
  162. }
  163. /**
  164. * 客户提现
  165. */
  166. public function cash($types = 0){
  167. $keyword = trim(input('get.keyword','','htmlspecialchars'));
  168. if(!empty($keyword)){
  169. $condition['user.phone_uid'] = $keyword;
  170. }
  171. switch ($types) {
  172. case 1:
  173. $state = -1;
  174. break;
  175. case 2:
  176. $state = 1;
  177. break;
  178. default:
  179. $state = 0;
  180. break;
  181. }
  182. $condition['state'] = $state;
  183. $view['list'] = model('BankCash')->lists($this->member_miniapp_id,$condition)->paginate(20,false,['query' => ['types' => $types]]);;
  184. $view['keyword'] = $keyword;
  185. $view['types'] = $types;
  186. return view()->assign($view);
  187. }
  188. /**
  189. * 导出到Excel
  190. */
  191. public function cashExcel($types = 0){
  192. header("Content-type: text/plain");
  193. header("Accept-Ranges: bytes");
  194. header("Content-type:application/vnd.ms-excel");
  195. header("Content-Disposition:attachment;filename=cash_".date('Y-m-d').".xls");
  196. header("Pragma: no-cache");
  197. header("Expires: 0");
  198. switch ($types) {
  199. case 1:
  200. $state = -1;
  201. break;
  202. case 2:
  203. $state = 1;
  204. break;
  205. default:
  206. $state = 0;
  207. break;
  208. }
  209. $condition['state'] = $state;
  210. $view['list'] = model('BankCash')->lists($this->member_miniapp_id,$condition)->select();
  211. $view['config'] = model('Config')->get(['member_miniapp_id' => $this->member_miniapp_id]);
  212. return view()->assign($view);
  213. }
  214. /**
  215. * 充值积分
  216. * @return void
  217. */
  218. public function recharge(int $input){
  219. if(request()->isAjax()){
  220. if($this->user->parent_id){
  221. return json(['code'=>0,'msg'=>'无权限,非【创始人】身份']);
  222. }
  223. $data = [
  224. 'user_id' => input('post.uid/d'),
  225. 'types' => input('post.types/d'),
  226. 'safepassword' => input('post.safepassword/s'),
  227. 'shop_money' => input('post.shop_money/f'),
  228. 'due_money' => input('post.due_money/f'),
  229. 'miniapp_id' => $this->member_miniapp_id,
  230. ];
  231. $validate = $this->validate($data,'Bank.recharge');
  232. if(true !== $validate){
  233. return json(['code'=>0,'msg'=>$validate]);
  234. }
  235. //验证安全密码
  236. if(!password_verify(md5($data['safepassword']),$this->user->safe_password)) {
  237. return json(['code'=>0,'msg'=>"安全密码错误"]);
  238. }
  239. if($data['types'] > 0){ //提取
  240. if($data['due_money'] > 0){
  241. model('Bank')->recharge($this->member_miniapp_id,$data['user_id'],-$data['due_money']);
  242. model('BankLogs')->add($this->member_miniapp_id,$data['user_id'],-(intval($data['due_money']*100)),'提取应付积分'.-money($data['due_money']));
  243. }
  244. if($data['shop_money'] > 0){
  245. model('Bank')->rechargeShop($this->member_miniapp_id,$data['user_id'],-$data['shop_money']);
  246. model('BankLogs')->add($this->member_miniapp_id,$data['user_id'],-(intval($data['shop_money']*100)),'提取购物积分'.-money($data['shop_money']));
  247. }
  248. }else{ //充值
  249. if($data['due_money'] > 0){
  250. model('Bank')->recharge($this->member_miniapp_id,$data['user_id'],$data['due_money']);
  251. model('BankLogs')->add($this->member_miniapp_id,$data['user_id'],intval($data['due_money']*100),'奖励应付积分'.money($data['due_money']));
  252. }
  253. if($data['shop_money'] > 0){
  254. model('Bank')->rechargeShop($this->member_miniapp_id,$data['user_id'],$data['shop_money']);
  255. model('BankLogs')->add($this->member_miniapp_id,$data['user_id'],intval($data['shop_money']*100),'奖励购物积分'.money($data['shop_money']));
  256. }
  257. }
  258. return json(['code'=>200,'msg'=>"充提操作成功"]);
  259. }else{
  260. if($this->user->parent_id){
  261. $this->error('无权限,非【创始人】身份');
  262. }
  263. $view['uid'] = $input;
  264. $view['info'] = model('SystemUser')->get(['member_miniapp_id' => $this->member_miniapp_id,'id' => $input]);
  265. return view()->assign($view);
  266. }
  267. }
  268. /**
  269. * 客户审核
  270. */
  271. public function cashpass(int $id){
  272. if(request()->isAjax()){
  273. $data = [
  274. 'id' => input('post.id/d'),
  275. 'ispass' => input('post.ispass/d'),
  276. 'miniapp_id' => $this->member_miniapp_id,
  277. 'realmoney' => input('post.realmoney/f')
  278. ];
  279. $validate = $this->validate($data,'Bank.cash');
  280. if(true !== $validate){
  281. return json(['code'=>0,'msg'=>$validate]);
  282. }
  283. $result = model('Bank')->ispass($data);
  284. return json($result);
  285. }else{
  286. $config = model('Config')->get(['member_miniapp_id' => $this->member_miniapp_id]);
  287. $cash = model('BankCash')->finds(['fastshop_bank_cash.member_miniapp_id' => $this->member_miniapp_id,'fastshop_bank_cash.id' => $id]);
  288. if(empty($cash)){
  289. $this->error('未找到到所属内容');
  290. }
  291. $bankinfo = model('BankInfo')->finds(['ai_fastshop_bank_info.member_miniapp_id' => $this->member_miniapp_id,'ai_fastshop_bank_info.user_id' => $cash->user_id]);
  292. $yescash = $cash->money-$cash->money*($config->tax/100);
  293. $view['yescash'] = money($yescash/100);
  294. $view['config'] = $config;
  295. $view['cash'] = $cash;
  296. $view['bankinfo'] = $bankinfo;
  297. $view['bank'] = model('Bank')->get(['user_id' => $cash->user_id]);
  298. return view()->assign($view);
  299. }
  300. }
  301. }