UserExtract.php 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: lianghuan
  5. * Date: 2018-03-03
  6. * Time: 16:47
  7. */
  8. namespace app\admin\model\user;
  9. use app\admin\model\wechat\WechatUser;
  10. use app\models\routine\RoutineTemplate;
  11. use think\facade\Route as Url;
  12. use crmeb\traits\ModelTrait;
  13. use crmeb\basic\BaseModel;
  14. use crmeb\services\WechatTemplateService;
  15. /**
  16. * 用户提现管理 model
  17. * Class User
  18. * @package app\admin\model\user
  19. */
  20. class UserExtract extends BaseModel
  21. {
  22. /**
  23. * 数据表主键
  24. * @var string
  25. */
  26. protected $pk = 'id';
  27. /**
  28. * 模型名称
  29. * @var string
  30. */
  31. protected $name = 'user_extract';
  32. use ModelTrait;
  33. /**
  34. * 获得用户提现总金额
  35. * @param $uid
  36. * @return mixed
  37. */
  38. public static function userExtractTotalPrice($uid,$status=1,$where=[])
  39. {
  40. return self::getModelTime($where,self::where('uid','in',$uid)->where('status',$status))->sum('extract_price')?:0;
  41. }
  42. public static function extractStatistics()
  43. {
  44. //待提现金额
  45. $data['price'] = floatval(self::where('status', 0)->sum('extract_price'));
  46. //佣金总金额
  47. $data['brokerage_count'] = floatval(UserBill::getBrokerageCount());
  48. //已提现金额
  49. $data['priced'] = floatval(self::where('status', 1)->sum('extract_price'));
  50. //未提现金额
  51. $data['brokerage_not'] = bcsub(bcsub($data['brokerage_count'], $data['priced'], 2), $data['price'], 2);
  52. return compact('data');
  53. }
  54. /**
  55. * @param $where
  56. * @return array
  57. */
  58. public static function systemPage($where)
  59. {
  60. $model = new self;
  61. if($where['date'] != '') {
  62. list($startTime, $endTime) = explode(' - ', $where['date']);
  63. $model = $model->where('a.add_time', '>', strtotime($startTime));
  64. $model = $model->where('a.add_time', '<', (int)bcadd(strtotime($endTime), 86400, 0));
  65. }
  66. if($where['status'] != '') $model = $model->where('a.status',$where['status']);
  67. if($where['extract_type'] != '') $model = $model->where('a.extract_type',$where['extract_type']);
  68. if($where['nireid'] != '') $model = $model->where('a.real_name|a.id|b.nickname|a.bank_code|a.alipay_code','like',"%$where[nireid]%");
  69. $model = $model->alias('a');
  70. $model = $model->field('a.*,b.nickname');
  71. $model = $model->join('user b','b.uid=a.uid','LEFT');
  72. $model = $model->order('a.id desc');
  73. return self::page($model, $where);
  74. }
  75. public static function changeFail($id,$fail_msg)
  76. {
  77. $fail_time = time();
  78. $data =self::get($id);
  79. $extract_number=$data['extract_price'];
  80. $mark='提现失败,退回佣金'.$extract_number.'元';
  81. $uid=$data['uid'];
  82. $status = -1;
  83. $User= User::where('uid', $uid)->find()->toArray();
  84. UserBill::income('提现失败',$uid,'now_money','extract',$extract_number,$id,bcadd($User['now_money'],$extract_number,2),$mark);
  85. User::bcInc($uid,'brokerage_price',$extract_number,'uid');
  86. $extract_type='未知方式';
  87. switch ($data['extract_type']){
  88. case 'alipay':
  89. $extract_type='支付宝';
  90. break;
  91. case 'bank':
  92. $extract_type='银行卡';
  93. break;
  94. case 'weixin':
  95. $extract_type='微信';
  96. break;
  97. }
  98. if(strtolower($User['user_type']) == 'wechat'){
  99. WechatTemplateService::sendTemplate(WechatUser::where('uid',$uid)->value('openid'),WechatTemplateService::USER_BALANCE_CHANGE,[
  100. 'first'=> $mark,
  101. 'keyword1'=>'佣金提现',
  102. 'keyword2'=>date('Y-m-d H:i:s',time()),
  103. 'keyword3'=>$extract_number,
  104. 'remark'=>'错误原因:'.$fail_msg
  105. ],Url::buildUrl('/user/cashrecord')->suffix('')->domain(true)->build());
  106. }else if(strtolower($User['user_type'])=='routine'){
  107. RoutineTemplate::sendOut('USER_EXTRACT_FALSE',$uid,[
  108. 'keyword1'=>$fail_msg,
  109. 'keyword2'=>$extract_number,
  110. 'keyword3'=>$extract_type,
  111. 'keyword4'=>date('Y-m-d H:i:s',time()),
  112. ]);
  113. }
  114. return self::edit(compact('fail_time','fail_msg','status'),$id);
  115. }
  116. public static function changeSuccess($id)
  117. {
  118. $data = self::get($id);
  119. $extractNumber = $data['extract_price'];
  120. $mark = '成功提现佣金'.$extractNumber.'元';
  121. $wechatUserInfo = WechatUser::where('uid',$data['uid'])->field('openid,user_type,routine_openid')->find();
  122. $extract_type='未知方式';
  123. switch ($data['extract_type']){
  124. case 'alipay':
  125. $extract_type='支付宝';
  126. break;
  127. case 'bank':
  128. $extract_type='银行卡';
  129. break;
  130. case 'weixin':
  131. $extract_type='微信';
  132. break;
  133. }
  134. if($wechatUserInfo){
  135. if(strtolower($wechatUserInfo->user_type)=='routine'){
  136. RoutineTemplate::sendOut('USER_EXTRACT_TRUE',$data['uid'],[
  137. 'keyword1'=>$extractNumber.'元',
  138. 'keyword2'=>'审核成功',
  139. 'keyword3'=>date('Y-m-d H:i:s', time()),
  140. 'keyword4'=>$extract_type,
  141. ]);
  142. }else if(strtolower($wechatUserInfo->user_type)=='wechat'){
  143. WechatTemplateService::sendTemplate($wechatUserInfo->openid, WechatTemplateService::USER_BALANCE_CHANGE, [
  144. 'first' => $mark,
  145. 'keyword1' => '佣金提现',
  146. 'keyword2' => date('Y-m-d H:i:s', time()),
  147. 'keyword3' => $extractNumber,
  148. 'remark' => '点击查看我的佣金明细'
  149. ], Url::buildUrl('/user/cashrecord')->suffix('')->domain(true)->build());
  150. }
  151. }
  152. return self::edit(['status'=>1],$id);
  153. }
  154. //测试数据
  155. public static function test(){
  156. $uids=User::order('uid desc')->limit(2,20)->field(['uid','nickname'])->select()->toArray();
  157. $type=['bank','alipay','weixin'];
  158. foreach ($uids as $item){
  159. $data=[
  160. 'uid'=>$item['uid'],
  161. 'real_name'=>$item['nickname'],
  162. 'extract_type'=>isset($type[rand(0,2)]) ? $type[rand(0,2)] :'alipay',
  163. 'bank_code'=>rand(1000000,999999999),
  164. 'bank_address'=>'中国',
  165. 'alipay_code'=>rand(1000,9999999),
  166. 'extract_price'=>rand(100,9999),
  167. 'mark'=>'测试数据',
  168. 'add_time'=>time(),
  169. 'status'=>1,
  170. 'wechat'=>rand(999,878788).$item['uid'],
  171. ];
  172. self::create($data);
  173. }
  174. }
  175. //获取头部提现信息
  176. public static function getExtractHead(){
  177. //本月提现人数
  178. $month=self::getModelTime(['data'=>'month'],self::where('status', 1))->group('uid')->count();
  179. //本月提现笔数
  180. $new_month=self::getModelTime(['data'=>'month'],self::where('status', 1))->distinct(true)->count();
  181. //上月提现人数
  182. $last_month=self::whereTime('add_time','last month')->where('status',1)->group('uid')->distinct(true)->count();
  183. //上月提现笔数
  184. $last_count=self::whereTime('add_time','last month')->where('status',1)->count();
  185. //本月提现金额
  186. $extract_price=self::getModelTime(['data'=>'month'],self::where('status', 1))->sum('extract_price');
  187. //上月提现金额
  188. $last_extract_price=self::whereTime('add_time','last month')->where('status',1)->sum('extract_price');
  189. return [
  190. [
  191. 'name'=>'总提现人数',
  192. 'field'=>'个',
  193. 'count'=>self::where('status', 1)->group('uid')->count(),
  194. 'content'=>'',
  195. 'background_color'=>'layui-bg-blue',
  196. 'sum'=>'',
  197. 'class'=>'fa fa-bar-chart',
  198. ],
  199. [
  200. 'name'=>'总提现笔数',
  201. 'field'=>'笔',
  202. 'count'=>self::where('status', 1)->distinct(true)->count(),
  203. 'content'=>'',
  204. 'background_color'=>'layui-bg-cyan',
  205. 'sum'=>'',
  206. 'class'=>'fa fa-line-chart',
  207. ],
  208. [
  209. 'name'=>'本月提现人数',
  210. 'field'=>'人',
  211. 'count'=>$month,
  212. 'content'=>'',
  213. 'background_color'=>'layui-bg-orange',
  214. 'sum'=>'',
  215. 'class'=>'fa fa-line-chart',
  216. ],
  217. [
  218. 'name'=>'本月提现笔数',
  219. 'field'=>'笔',
  220. 'count'=>$new_month,
  221. 'content'=>'',
  222. 'background_color'=>'layui-bg-green',
  223. 'sum'=>'',
  224. 'class'=>'fa fa-line-chart',
  225. ],
  226. [
  227. 'name'=>'本月提现金额',
  228. 'field'=>'元',
  229. 'count'=>$extract_price,
  230. 'content'=>'提现总金额',
  231. 'background_color'=>'layui-bg-cyan',
  232. 'sum'=>self::where('status', 1)->sum('extract_price'),
  233. 'class'=>'fa fa-line-chart',
  234. ],
  235. [
  236. 'name'=>'上月提现人数',
  237. 'field'=>'个',
  238. 'count'=>$last_month,
  239. 'content'=>'环比增幅',
  240. 'background_color'=>'layui-bg-blue',
  241. 'sum'=>$last_month==0 ? '100%' :bcdiv($month,$last_month,2)*100,
  242. 'class'=>$last_month==0 ? 'fa fa-level-up':'fa fa-level-down',
  243. ],
  244. [
  245. 'name'=>'上月提现笔数',
  246. 'field'=>'笔',
  247. 'count'=>$last_count,
  248. 'content'=>'环比增幅',
  249. 'background_color'=>'layui-bg-black',
  250. 'sum'=>$last_count==0 ? '100%':bcdiv($new_month,$last_count,2)*100,
  251. 'class'=>$last_count==0 ? 'fa fa-level-up':'fa fa-level-down',
  252. ],
  253. [
  254. 'name'=>'上月提现金额',
  255. 'field'=>'元',
  256. 'count'=>$last_extract_price,
  257. 'content'=>'环比增幅',
  258. 'background_color'=>'layui-bg-gray',
  259. 'sum'=>$last_extract_price==0 ? '100%':bcdiv($extract_price,$last_extract_price,2)*100,
  260. 'class'=>$last_extract_price==0 ? 'fa fa-level-up':'fa fa-level-down',
  261. ],
  262. ];
  263. }
  264. //获取提现分布图和提现人数金额曲线图
  265. public static function getExtractList($where,$limit=15){
  266. $legdata=['提现人数','提现金额'];
  267. $list=self::getModelTime($where,self::where('status',1))
  268. ->field('FROM_UNIXTIME(add_time,"%Y-%c-%d") as un_time,count(uid) as count,sum(extract_price) as sum_price')->group('un_time')->order('un_time asc')->select();
  269. if(count($list)) $list=$list->toArray();
  270. $xdata = [];
  271. $itemList = [0=>[],1=>[]];
  272. $chatrList = [];
  273. $zoom = '';
  274. foreach ($list as $value){
  275. $xdata[]=$value['un_time'];
  276. $itemList[0][]=$value['count'];
  277. $itemList[1][]=$value['sum_price'];
  278. }
  279. foreach ($legdata as $key=>$name){
  280. $item['name']=$name;
  281. $item['type']='line';
  282. $item['data']=$itemList[$key];
  283. $chatrList[]=$item;
  284. }
  285. unset($item,$name,$key);
  286. if(count($xdata)>$limit) $zoom=$xdata[$limit-5];
  287. //饼状图
  288. $cake=['支付宝','银行卡','微信'];
  289. $fenbulist=self::getModelTime($where,self::where('status',1))
  290. ->field('count(uid) as count,extract_type')->group('extract_type')->order('count asc')->select();
  291. if(count($fenbulist)) $fenbulist = $fenbulist->toArray();
  292. $sum_count = self::getModelTime($where,self::where('status',1))->count();
  293. $color = ['#FB7773','#81BCFE','#91F3FE'];
  294. $fenbudata = [];
  295. foreach ($fenbulist as $key=>$item){
  296. if($item['extract_type']=='bank'){
  297. $item_date['name']='银行卡';
  298. }else if($item['extract_type']=='alipay'){
  299. $item_date['name']='支付宝';
  300. }else if($item['extract_type']=='weixin'){
  301. $item_date['name']='微信';
  302. }
  303. $item_date['value']=bcdiv($item['count'],$sum_count,2)*100;
  304. $item_date['itemStyle']['color']=$color[$key];
  305. $fenbudata[]=$item_date;
  306. }
  307. return compact('xdata','chatrList','legdata','zoom','cake','fenbudata');
  308. }
  309. /**
  310. * 获取用户累计提现金额
  311. * @param int $uid
  312. * @return int|mixed
  313. */
  314. public static function getUserCountPrice($uid = 0){
  315. if(!$uid) return 0;
  316. $price = self::where('uid',$uid)->where('status',1)->sum('extract_price');
  317. return $price ? $price : 0;
  318. }
  319. /**
  320. * 获取用户累计提现次数
  321. * @param int $uid
  322. * @return int|string
  323. */
  324. public static function getUserCountNum($uid = 0){
  325. if(!$uid) return 0;
  326. return self::where('uid',$uid)->count();
  327. }
  328. }