User.php 50 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130
  1. <?php
  2. /**
  3. *
  4. * @author: xaboy<365615158@qq.com>
  5. * @day: 2017/11/11
  6. */
  7. namespace app\admin\model\user;
  8. use app\admin\model\order\StoreOrder;
  9. use app\admin\model\system\SystemUserLevel;
  10. use traits\ModelTrait;
  11. use app\admin\model\user\UserBill;
  12. use basic\ModelBasic;
  13. use app\admin\model\wechat\WechatUser;
  14. use app\admin\model\store\StoreCouponUser;
  15. use app\admin\model\user\UserExtract;
  16. use app\core\util\SystemConfigService;
  17. use think\Db;
  18. /**
  19. * 用户管理 model
  20. * Class User
  21. * @package app\admin\model\user
  22. */
  23. class User extends ModelBasic
  24. {
  25. use ModelTrait;
  26. /**
  27. * @param $where
  28. * @return array
  29. */
  30. public static function systemPage($where){
  31. $model = new self;
  32. if($where['status'] != '') $model = $model->where('status',$where['status']);
  33. if($where['is_promoter'] != '') $model = $model->where('is_promoter',$where['is_promoter']);
  34. if(isset($where['user_type']) && $where['user_type'] != '') $model = $model->where('user_type',$where['user_type']);
  35. if($where['nickname'] != '') $model = $model->where('nickname|uid','like',"%$where[nickname]%");
  36. $model = $model->order('uid desc');
  37. return self::page($model,function ($item){
  38. if($item['spread_uid']){
  39. $item['spread_uid_nickname'] = self::where('uid',$item['spread_uid'])->value('nickname');
  40. }else{
  41. $item['spread_uid_nickname'] = '无';
  42. }
  43. },$where);
  44. }
  45. /*
  46. * 获取和提现金额
  47. * @param array $uid
  48. * @return float
  49. * */
  50. public static function getextractPrice($uid,$where=[])
  51. {
  52. if(is_array($uid))
  53. if(!count($uid)) return 0;
  54. else
  55. $uid = [$uid];
  56. $brokerage= UserBill::getBrokerage($uid,'now_money','brokerage',$where);//获取总佣金
  57. $recharge = UserBill::getBrokerage($uid,'now_money','recharge',$where);//累计充值
  58. $extractTotalPrice = UserExtract::userExtractTotalPrice($uid,1,$where);//累计提现
  59. if($brokerage > $extractTotalPrice) {
  60. $orderYuePrice = self::getModelTime($where,StoreOrder::where('uid','in',$uid)->where(['is_del'=>0,'paid'=>1]))->sum('pay_price');//余额累计消费
  61. $systemAdd = UserBill::getBrokerage($uid,'now_money','system_add',$where);//后台添加余额
  62. $yueCount = bcadd($recharge,$systemAdd,2);// 后台添加余额 + 累计充值 = 非佣金的总金额
  63. $orderYuePrice = $yueCount > $orderYuePrice ? 0 : bcsub($orderYuePrice,$yueCount,2);// 余额累计消费(使用佣金消费的金额)
  64. $brokerage = bcsub($brokerage,$extractTotalPrice,2);//减去已提现金额
  65. $extract_price = UserExtract::userExtractTotalPrice($uid,0,$where);
  66. $brokerage = $extract_price < $brokerage ? bcsub($brokerage,$extract_price,2) : 0;//减去审核中的提现金额
  67. $brokerage = $brokerage > $orderYuePrice ? bcsub($brokerage,$orderYuePrice,2) : 0;//减掉余额支付
  68. }else{
  69. $brokerage=0;
  70. }
  71. $num = (float)bcsub($brokerage,$extractTotalPrice,2);
  72. return $num > 0 ? $num : 0;//可提现
  73. }
  74. /*
  75. * 设置搜索条件
  76. *
  77. */
  78. public static function setWhere($where)
  79. {
  80. if($where['order']!=''){
  81. $model=self::order(self::setOrder($where['order']));
  82. }else{
  83. $model=self::order('u.uid desc');
  84. }
  85. if($where['user_time_type'] == 'visitno' && $where['user_time'] != ''){
  86. list($startTime, $endTime) = explode(' - ', $where['user_time']);
  87. $model = $model->where('u.last_time', ['>', strtotime($endTime)+24*3600], ['<', strtotime($startTime)],'or');
  88. }
  89. if($where['user_time_type'] == 'visit' && $where['user_time'] != ''){
  90. list($startTime, $endTime) = explode(' - ', $where['user_time']);
  91. $model = $model->where('u.last_time', '>', strtotime($startTime));
  92. $model = $model->where('u.last_time', '<', strtotime($endTime)+24*3600);
  93. }
  94. if($where['user_time_type'] == 'add_time' && $where['user_time'] != ''){
  95. list($startTime, $endTime) = explode(' - ', $where['user_time']);
  96. $model = $model->where('u.add_time', '>', strtotime($startTime));
  97. $model = $model->where('u.add_time', '<', strtotime($endTime)+24*3600);
  98. }
  99. if($where['pay_count'] !== '') {
  100. if($where['pay_count'] == '-1') $model = $model->where('pay_count',0);
  101. else $model = $model->where('pay_count','>',$where['pay_count']);
  102. }
  103. if($where['user_type'] != ''){
  104. if($where['user_type'] == 'routine') $model = $model->where('w.routine_openid','not null');
  105. else if($where['user_type'] == 'wechat') $model = $model->where('w.openid','not null');
  106. }
  107. if($where['country'] != ''){
  108. if($where['country'] == 'domestic') $model = $model->where('w.country','EQ','中国');
  109. else if($where['country'] == 'abroad') $model = $model->where('w.country','NEQ','中国');
  110. }
  111. return $model;
  112. }
  113. /**
  114. * 异步获取当前用户 信息
  115. * @param $where
  116. * @return array
  117. */
  118. public static function getUserList($where){
  119. $model = self::setWherePage(self::setWhere($where),$where,['w.sex','w.province','w.city','u.status','u.is_promoter'],['u.nickname','u.uid']);
  120. $list = $model->alias('u')
  121. ->join('WechatUser w','u.uid=w.uid')
  122. ->field('u.*,w.country,w.province,w.city,w.sex,w.unionid,w.openid,w.routine_openid,w.groupid,w.tagid_list,w.subscribe,w.subscribe_time')
  123. ->page((int)$where['page'],(int)$where['limit'])
  124. ->select()
  125. ->each(function ($item){
  126. $item['add_time']=date('Y-m-d H:i:s',$item['add_time']);
  127. if($item['last_time']) $item['last_time'] = date('Y-m-d H:i:s',$item['last_time']);//最近一次访问日期
  128. else $item['last_time'] = '无访问';//最近一次访问日期
  129. self::edit(['pay_count'=>StoreOrder::getUserCountPay($item['uid'])],$item['uid']);
  130. $item['extract_count_price'] = UserExtract::getUserCountPrice($item['uid']);//累计提现
  131. if($item['spread_uid']){
  132. $item['spread_uid_nickname'] = self::where('uid',$item['spread_uid'])->value('nickname').'/'.$item['spread_uid'];
  133. }else{
  134. $item['spread_uid_nickname'] = '无';
  135. }
  136. if($item['openid'] != '' && $item['routine_openid'] != ''){
  137. $item['user_type']='通用';
  138. }else if($item['openid'] == '' && $item['routine_openid'] != ''){
  139. $item['user_type']='小程序';
  140. }else if($item['openid'] != '' && $item['routine_openid'] == ''){
  141. $item['user_type']='公众号';
  142. }else $item['user_type']='其他';
  143. if($item['sex'] == 1){
  144. $item['sex']='男';
  145. }else if($item['sex'] == 2){
  146. $item['sex']='女';
  147. }else $item['sex']='保密';
  148. $item['vip_name']=false;
  149. $levelinfo=UserLevel::where(['uid'=>$item['uid'],'is_del'=>0])->order('grade desc')->field(['level_id','is_forever','valid_time'])->find();
  150. if($levelinfo){
  151. if($levelinfo['is_forever']) $item['vip_name']=SystemUserLevel::where('id',$levelinfo['level_id'])->value('name');
  152. else if(time() > $levelinfo['valid_time']) $item['vip_name']=SystemUserLevel::where('id',$levelinfo['level_id'])->value('name');
  153. }
  154. });//->toArray();
  155. $count=self::setWherePage(self::setWhere($where),$where,['w.sex','w.province','w.city','u.status','u.is_promoter'],['u.nickname','u.uid'])->alias('u')->join('WechatUser w','u.uid=w.uid')->count();
  156. return ['count'=>$count,'data'=>$list];
  157. }
  158. /**
  159. * 修改用户状态
  160. * @param $uids 用户uid
  161. * @param $status 修改状态
  162. * @return array
  163. */
  164. public static function destrSyatus($uids,$status){
  165. if(empty($uids) && !is_array($uids)) return false;
  166. if($status=='') return false;
  167. self::beginTrans();
  168. try{
  169. $res=self::where('uid','in',$uids)->update(['status'=>$status]);
  170. self::checkTrans($res);
  171. return true;
  172. }catch (\Exception $e){
  173. self::rollbackTrans();
  174. return Json::fail($e->getMessage());
  175. }
  176. }
  177. /*
  178. * 获取某季度,某年某年后的时间戳
  179. *
  180. * self::getMonth('n',1) 获取当前季度的上个季度的时间戳
  181. * self::getMonth('n') 获取当前季度的时间戳
  182. */
  183. public static function getMonth($time='',$ceil=0){
  184. if(empty($time)){
  185. $firstday = date("Y-m-01",time());
  186. $lastday = date("Y-m-d",strtotime("$firstday +1 month -1 day"));
  187. }else if($time=='n'){
  188. if($ceil!=0)
  189. $season = ceil(date('n') /3)-$ceil;
  190. else
  191. $season = ceil(date('n') /3);
  192. $firstday=date('Y-m-01',mktime(0,0,0,($season - 1) *3 +1,1,date('Y')));
  193. $lastday=date('Y-m-t',mktime(0,0,0,$season * 3,1,date('Y')));
  194. }else if($time=='y'){
  195. $firstday=date('Y-01-01');
  196. $lastday=date('Y-12-31');
  197. }else if($time=='h'){
  198. $firstday = date('Y-m-d', strtotime('this week +'.$ceil.' day')) . ' 00:00:00';
  199. $lastday = date('Y-m-d', strtotime('this week +'.($ceil+1).' day')) . ' 23:59:59';
  200. }
  201. return array($firstday,$lastday);
  202. }
  203. public static function getcount(){
  204. return self::count();
  205. }
  206. /*
  207. *获取用户某个时间段的消费信息
  208. *
  209. * reutrn Array || number
  210. */
  211. public static function consume($where,$status='',$keep=''){
  212. $model = new self;
  213. $user_id=[];
  214. if(is_array($where)){
  215. if($where['is_promoter']!='') $model=$model->where('is_promoter',$where['is_promoter']);
  216. if($where['status']!='') $model=$model->where('status',$where['status']);
  217. switch ($where['date']){
  218. case null:case 'today':case 'week':case 'year':
  219. if($where['date']==null){
  220. $where['date']='month';
  221. }
  222. if($keep){
  223. $model=$model->whereTime('add_time',$where['date'])->whereTime('last_time',$where['date']);
  224. }else{
  225. $model=$model->whereTime('add_time',$where['date']);
  226. }
  227. break;
  228. case 'quarter':
  229. $quarter=self::getMonth('n');
  230. $startTime=strtotime($quarter[0]);
  231. $endTime=strtotime($quarter[1]);
  232. if($keep){
  233. $model = $model->where('add_time','>',$startTime)->where('add_time','<',$endTime)->where('last_time','>',$startTime)->where('last_time','<',$endTime);
  234. }else{
  235. $model = $model->where('add_time','>',$startTime)->where('add_time','<',$endTime);
  236. }
  237. break;
  238. default:
  239. //自定义时间
  240. if(strstr($where['date'],'-')!==FALSE){
  241. list($startTime,$endTime)=explode('-',$where['date']);
  242. $model = $model->where('add_time','>',strtotime($startTime))->where('add_time','<',strtotime($endTime));
  243. }else{
  244. $model=$model->whereTime('add_time','month');
  245. }
  246. break;
  247. }
  248. }else{
  249. if(is_array($status)){
  250. $model=$model->where('add_time','>',$status[0])->where('add_time','<',$status[1]);
  251. }
  252. }
  253. if($keep===true){
  254. return $model->count();
  255. }
  256. if($status==='default'){
  257. return $model->group('from_unixtime(add_time,\'%Y-%m-%d\')')->field('count(uid) num,from_unixtime(add_time,\'%Y-%m-%d\') add_time,uid')->select()->toArray();
  258. }
  259. if($status==='grouping'){
  260. return $model->group('user_type')->field('user_type')->select()->toArray();
  261. }
  262. $uid=$model->field('uid')->select()->toArray();
  263. foreach ($uid as $val){
  264. $user_id[]=$val['uid'];
  265. }
  266. if(empty($user_id)){
  267. $user_id=[0];
  268. }
  269. if($status==='xiaofei'){
  270. $list=UserBill::where('uid','in',$user_id)
  271. ->group('type')
  272. ->field('sum(number) as top_number,title')
  273. ->select()
  274. ->toArray();
  275. $series=[
  276. 'name'=>isset($list[0]['title'])?$list[0]['title']:'',
  277. 'type'=>'pie',
  278. 'radius'=> ['40%', '50%'],
  279. 'data'=>[]
  280. ];
  281. foreach($list as $key=>$val){
  282. $series['data'][$key]['value']=$val['top_number'];
  283. $series['data'][$key]['name']=$val['title'];
  284. }
  285. return $series;
  286. }else if($status==='form'){
  287. $list=WechatUser::where('uid','in',$user_id)->group('city')->field('count(city) as top_city,city')->limit(0,10)->select()->toArray();
  288. $count=self::getcount();
  289. $option=[
  290. 'legend_date'=>[],
  291. 'series_date'=>[]
  292. ];
  293. foreach($list as $key=>$val){
  294. $num=$count!=0?(bcdiv($val['top_city'],$count,2))*100:0;
  295. $t=['name'=>$num.'% '.(empty($val['city'])?'未知':$val['city']),'icon'=>'circle'];
  296. $option['legend_date'][$key]=$t;
  297. $option['series_date'][$key]=['value'=>$num,'name'=>$t['name']];
  298. }
  299. return $option;
  300. }else{
  301. $number=UserBill::where('uid','in',$user_id)->where('type','pay_product')->sum('number');
  302. return $number;
  303. }
  304. }
  305. /*
  306. * 获取 用户某个时间段的钱数或者TOP20排行
  307. *
  308. * return Array || number
  309. */
  310. public static function getUserSpend($date,$status=''){
  311. $model=new self();
  312. $model=$model->alias('A');
  313. switch ($date){
  314. case null:case 'today':case 'week':case 'year':
  315. if($date==null) $date='month';
  316. $model=$model->whereTime('A.add_time',$date);
  317. break;
  318. case 'quarter':
  319. list($startTime,$endTime)=User::getMonth('n');
  320. $model = $model->where('A.add_time','>',strtotime($startTime));
  321. $model = $model->where('A.add_time','<',strtotime($endTime));
  322. break;
  323. default:
  324. list($startTime,$endTime)=explode('-',$date);
  325. $model = $model->where('A.add_time','>',strtotime($startTime));
  326. $model = $model->where('A.add_time','<',strtotime($endTime));
  327. break;
  328. }
  329. if($status===true){
  330. return $model->join('user_bill B','B.uid=A.uid')->where('B.type','pay_product')->where('B.pm',0)->sum('B.number');
  331. }
  332. $list=$model->join('user_bill B','B.uid=A.uid')
  333. ->where('B.type','pay_product')
  334. ->where('B.pm',0)
  335. ->field('sum(B.number) as totel_number,A.nickname,A.avatar,A.now_money,A.uid,A.add_time')
  336. ->order('totel_number desc')
  337. ->limit(0,20)
  338. ->select()
  339. ->toArray();
  340. if(!isset($list[0]['totel_number'])){
  341. $list=[];
  342. }
  343. return $list;
  344. }
  345. /*
  346. * 获取 相对于上月或者其他的数据
  347. *
  348. * return Array
  349. */
  350. public static function getPostNumber($date,$status=false,$field='A.add_time',$t='消费'){
  351. $model=new self();
  352. if(!$status) $model=$model->alias('A');
  353. switch ($date){
  354. case null:case 'today':case 'week':case 'year':
  355. if($date==null) {
  356. $date='last month';
  357. $title='相比上月用户'.$t.'增长';
  358. }
  359. if($date=='today') {
  360. $date='yesterday';
  361. $title='相比昨天用户'.$t.'增长';
  362. }
  363. if($date=='week') {
  364. $date='last week';
  365. $title='相比上周用户'.$t.'增长';
  366. }
  367. if($date=='year') {
  368. $date='last year';
  369. $title='相比去年用户'.$t.'增长';
  370. }
  371. $model=$model->whereTime($field,$date);
  372. break;
  373. case 'quarter':
  374. $title='相比上季度用户'.$t.'增长';
  375. list($startTime,$endTime)=User::getMonth('n',1);
  376. $model = $model->where($field,'>',$startTime);
  377. $model = $model->where($field,'<',$endTime);
  378. break;
  379. default:
  380. list($startTime,$endTime)=explode('-',$date);
  381. $title='相比'.$startTime.'-'.$endTime.'时间段用户'.$t.'增长';
  382. $Time=strtotime($endTime)-strtotime($startTime);
  383. $model = $model->where($field,'>',strtotime($startTime)+$Time);
  384. $model = $model->where($field,'<',strtotime($endTime)+$Time);
  385. break;
  386. }
  387. if($status){
  388. return [$model->count(),$title];
  389. }
  390. $number=$model->join('user_bill B','B.uid=A.uid')->where('B.type','pay_product')->where('B.pm',0)->sum('B.number');
  391. return [$number,$title];
  392. }
  393. //获取用户新增,头部信息
  394. public static function getBadgeList($where){
  395. $user_count = self::setWherePage(self::getModelTime($where,new self),$where,['is_promoter','status'])->count();
  396. $user_count_old = self::getOldDate($where)->count();
  397. $store_brokerage_statu = SystemConfigService::get('store_brokerage_statu');
  398. if($store_brokerage_statu == 1)
  399. $fenxiao = self::setWherePage(self::getModelTime($where,new self),$where,['is_promoter','status'])->where('spread_uid','<>',0)->count();
  400. else
  401. $fenxiao = self::count();
  402. $fenxiao_count = self::getOldDate($where)->where('spread_uid','neq',0)->count();
  403. $newFemxiao_count = bcsub($fenxiao,$fenxiao_count,0);
  404. $order_count = bcsub($user_count,$user_count_old,0);
  405. return [
  406. [
  407. 'name'=>'会员人数',
  408. 'field'=>'个',
  409. 'count'=>$user_count,
  410. 'content'=>'会员总人数',
  411. 'background_color'=>'layui-bg-blue',
  412. 'sum'=>self::count(),
  413. 'class'=>'fa fa-bar-chart',
  414. ],
  415. [
  416. 'name'=>'会员增长',
  417. 'field'=>'个',
  418. 'count'=>$order_count,
  419. 'content'=>'会员增长率',
  420. 'background_color'=>'layui-bg-cyan',
  421. 'sum'=>$user_count_old ? bcdiv($order_count,$user_count_old,2)*100:0,
  422. 'class'=>'fa fa-line-chart',
  423. ],
  424. [
  425. 'name'=>'分销人数',
  426. 'field'=>'个',
  427. 'count'=>$fenxiao,
  428. 'content'=>'分销总人数',
  429. 'background_color'=>'layui-bg-green',
  430. 'sum'=>$store_brokerage_statu == 1 ? self::where('spread_uid','neq',0)->count() : $fenxiao,
  431. 'class'=>'fa fa-bar-chart',
  432. ],
  433. [
  434. 'name'=>'分销增长',
  435. 'field'=>'个',
  436. 'count'=>$newFemxiao_count,
  437. 'content'=>'分销总人数',
  438. 'background_color'=>'layui-bg-orange',
  439. 'sum'=>$fenxiao_count ? bcdiv($newFemxiao_count,$fenxiao_count,2)*100:0,
  440. 'class'=>'fa fa-cube',
  441. ],
  442. ];
  443. }
  444. /*
  445. * 获取会员增长曲线图和分布图
  446. * $where 查询条件
  447. * $limit 显示条数,是否有滚动条
  448. */
  449. public static function getUserChartList($where,$limit=20){
  450. $list = self::setWherePage(self::getModelTime($where,new self),$where,['is_promoter','status'])
  451. ->where('add_time','neq',0)
  452. ->field(['FROM_UNIXTIME(add_time,"%Y-%m-%d") as _add_time','count(uid) as num'])
  453. ->order('_add_time asc')
  454. ->group('_add_time')
  455. ->select();
  456. count($list) && $list = $list->toArray();
  457. $seriesdata = [];
  458. $xdata = [];
  459. $Zoom = '';
  460. foreach ($list as $item){
  461. $seriesdata[] = $item['num'];
  462. $xdata[] = $item['_add_time'];
  463. }
  464. (count($xdata) > $limit) && $Zoom = $xdata[$limit-5];
  465. //多次购物会员数量饼状图
  466. $count = self::setWherePage(self::getModelTime($where,new self),$where,['is_promoter'])->count();
  467. $user_count = self::setWherePage(self::getModelTime($where,self::alias('a')->join('__STORE_ORDER__ r','r.uid=a.uid'),'a.add_time'),$where,['is_promoter'])
  468. ->where('r.paid',1)->count('a.uid');
  469. $shop_xdata = ['多次购买数量占比','无购买数量占比'];
  470. $shop_data = [];
  471. $count >0 && $shop_data = [
  472. [
  473. 'value'=>bcdiv($user_count,$count,2)*100,
  474. 'name'=>$shop_xdata[0],
  475. 'itemStyle'=>[
  476. 'color'=>'#D789FF',
  477. ]
  478. ],
  479. [
  480. 'value'=>bcdiv($count-$user_count,$count,2)*100,
  481. 'name'=>$shop_xdata[1],
  482. 'itemStyle'=>[
  483. 'color'=>'#7EF0FB',
  484. ]
  485. ]
  486. ];
  487. return compact('shop_data','shop_xdata','fenbu_data','fenbu_xdata','seriesdata','xdata','Zoom');
  488. }
  489. //获取$date的前一天或者其他的时间段
  490. public static function getOldDate($where,$moedls=null){
  491. $model=$moedls ===null ? self::setWherePage(new self(),$where,['is_promoter','status']) :$moedls;
  492. switch ($where['data']){
  493. case 'today':
  494. $model=$model->whereTime('add_time','yesterday');
  495. break;
  496. case 'week':
  497. $model=$model->whereTime('add_time','last week');
  498. break;
  499. case 'month':
  500. $model=$model->whereTime('add_time','last month');
  501. break;
  502. case 'year':
  503. $model=$model->whereTime('add_time','last year');
  504. break;
  505. case 'quarter':
  506. $time=self::getMonth('n',1);
  507. $model=$model->where('add_time','between',$time);
  508. break;
  509. }
  510. return $model;
  511. }
  512. //获取用户属性和性别分布图
  513. public static function getEchartsData($where){
  514. $model=self::alias('a');
  515. $data=self::getModelTime($where,$model,'a.add_time')
  516. ->join('wechat_user r','r.uid=a.uid')
  517. ->group('r.province')
  518. ->field('count(r.province) as count,province')
  519. ->order('count desc')
  520. ->limit(15)
  521. ->select();
  522. if(count($data)) $data=$data->toArray();
  523. $legdata=[];
  524. $dataList=[];
  525. foreach ($data as $value){
  526. $value['province']=='' && $value['province']='未知省份';
  527. $legdata[]=$value['province'];
  528. $dataList[]=$value['count'];
  529. }
  530. $model=self::alias('a');
  531. $sex=self::getModelTime($where,$model,'a.add_time')
  532. ->join('wechat_user r','r.uid=a.uid')
  533. ->group('r.sex')
  534. ->field('count(r.uid) as count,sex')
  535. ->order('count desc')
  536. ->select();
  537. if(count($sex)) $sex=$sex->toArray();
  538. $sexlegdata=['男','女','未知'];
  539. $sexcount=self::getModelTime($where,new self())->count();
  540. $sexList=[];
  541. $color=['#FB7773','#81BCFE','#91F3FE'];
  542. foreach ($sex as $key=>$item){
  543. if($item['sex']==1){
  544. $item_date['name']='男';
  545. }else if($item['sex']==2){
  546. $item_date['name']='女';
  547. }else{
  548. $item_date['name']='未知性别';
  549. }
  550. $item_date['value']=bcdiv($item['count'],$sexcount,2)*100;
  551. $item_date['itemStyle']['color']=$color[$key];
  552. $sexList[]=$item_date;
  553. }
  554. return compact('sexList','sexlegdata','legdata','dataList');
  555. }
  556. //获取佣金记录列表
  557. public static function getCommissionList($where){
  558. $model = self::setCommissionWhere($where);
  559. if($where['excel'])
  560. $list = $model->select();
  561. else
  562. $list = $model->page((int)$where['page'],(int)$where['limit'])->select();
  563. count($list) && $list=$list->toArray();
  564. $export=[];
  565. foreach ($list as &$value){
  566. $value['ex_price']= Db::name('user_extract')->where(['uid'=>$value['uid']])->sum('extract_price');
  567. $value['extract_price']= Db::name('user_extract')->where(['uid'=>$value['uid'],'status'=>1])->sum('extract_price');
  568. $cashPrice = Db::name('user_extract')->where(['uid'=>$value['uid'],'status'=>0])->sum('extract_price');
  569. $value['money'] = bcsub($value['ex_price'],$value['extract_price'],2);
  570. $value['money'] = bcsub($value['money'],$cashPrice,2);
  571. $export[]=[
  572. $value['nickname'],
  573. $value['sum_number'],
  574. $value['now_money'],
  575. $value['brokerage_price'],
  576. $value['extract_price'],
  577. ];
  578. }
  579. if($where['excel']){
  580. \service\PHPExcelService::setExcelHeader(['昵称/姓名','总佣金金额','账户余额','账户佣金','提现到账佣金'])
  581. ->setExcelTile('拥金记录','拥金记录'.time(),' 生成时间:'.date('Y-m-d H:i:s',time()))
  582. ->setExcelContent($export)
  583. ->ExcelSave();
  584. }
  585. $count=self::setCommissionWhere($where)->count();
  586. return ['data'=>$list,'count'=>$count];
  587. }
  588. //获取佣金记录列表的查询条件
  589. public static function setCommissionWhere($where){
  590. $models=self::setWherePage(self::alias('A'),$where,[],['A.nickname','A.uid'])
  591. ->join('user_bill B','B.uid=A.uid')
  592. ->group('A.uid')
  593. ->where(['B.category'=>'now_money','B.type'=>'brokerage'])
  594. ->field(['sum(B.number) as sum_number','A.nickname','A.uid','A.now_money']);
  595. if($where['order']==''){
  596. $models=$models->order('sum_number desc');
  597. }else{
  598. $models=$models->order($where['order']==1 ? 'sum_number desc':'sum_number asc');
  599. }
  600. if($where['price_max']!='' && $where['price_min']!=''){
  601. $models=$models->where('now_money','between',[$where['price_max'],$where['price_min']]);
  602. }
  603. return $models;
  604. }
  605. /**获取用户详细信息
  606. * @param $uid
  607. * @return array
  608. */
  609. public static function getUserInfos($uid)
  610. {
  611. $userInfo = self::where('uid',$uid)->find();
  612. if(!$userInfo) exception('读取用户信息失败!');
  613. return $userInfo->toArray();
  614. }
  615. //获取某人用户推广信息
  616. public static function getUserinfo($uid){
  617. $userinfo=self::where(['uid'=>$uid])->field(['nickname','spread_uid','now_money','add_time'])->find()->toArray();
  618. $userinfo['number']=UserBill::where(['category'=>'now_money','type'=>'brokerage'])->sum('number');
  619. $userinfo['spread_name']=$userinfo['spread_uid'] ? self::where(['uid'=>$userinfo['spread_uid']])->value('nickname') :'';
  620. return $userinfo;
  621. }
  622. //获取某用户的详细信息
  623. public static function getUserDetailed($uid){
  624. $key_field=['real_name','phone','province','city','district','detail','post_code'];
  625. $Address=($thisAddress= Db::name('user_address')->where(['uid'=>$uid,'is_default'=>1])->field($key_field)->find()) ?
  626. $thisAddress :
  627. Db::name('user_address')->where(['uid'=>$uid])->field($key_field)->find();
  628. $UserInfo=self::get($uid);
  629. return [
  630. ['col'=>12,'name'=>'默认收货地址','value'=>$thisAddress ? '收货人:'.$thisAddress['real_name'].'邮编:'.$thisAddress['post_code'].' 收货人电话:'.$thisAddress['phone'].' 地址:'.$thisAddress['province'].' '.$thisAddress['city'].' '.$thisAddress['district'].' '.$thisAddress['detail'] : ''],
  631. // ['name'=>'微信OpenID','value'=>WechatUser::where(['uid'=>$uid])->value('openid'),'col'=>8],
  632. ['name'=>'手机号码','value'=>$UserInfo['phone']],
  633. // ['name'=>'ID','value'=>$uid],
  634. ['name'=>'姓名','value'=>''],
  635. ['name'=>'微信昵称','value'=>$UserInfo['nickname']],
  636. ['name'=>'邮箱','value'=>''],
  637. ['name'=>'生日','value'=>''],
  638. ['name'=>'积分','value'=>$UserInfo['integral']],
  639. ['name'=>'上级推广人','value'=>$UserInfo['spread_uid'] ? self::where(['uid'=>$UserInfo['spread_uid']])->value('nickname'):''],
  640. ['name'=>'账户余额','value'=>$UserInfo['now_money']],
  641. ['name'=>'佣金总收入','value'=>UserBill::where(['category'=>'now_money','type'=>'brokerage','uid'=>$uid])->sum('number')],
  642. ['name'=>'提现总金额','value'=> Db::name('user_extract')->where(['uid'=>$uid,'status'=>1])->sum('extract_price')],
  643. ];
  644. }
  645. //获取某用户的订单个数,消费明细
  646. public static function getHeaderList($uid){
  647. return [
  648. [
  649. 'title'=>'总计订单',
  650. 'value'=>StoreOrder::where(['uid'=>$uid])->count(),
  651. 'key'=>'笔',
  652. 'class'=>'',
  653. ],
  654. [
  655. 'title'=>'总消费金额',
  656. 'value'=>StoreOrder::where(['uid'=>$uid,'paid'=>1])->sum('total_price'),
  657. 'key'=>'元',
  658. 'class'=>'',
  659. ],
  660. [
  661. 'title'=>'本月订单',
  662. 'value'=>StoreOrder::where(['uid'=>$uid])->whereTime('add_time','month')->count(),
  663. 'key'=>'笔',
  664. 'class'=>'',
  665. ],
  666. [
  667. 'title'=>'本月消费金额',
  668. 'value'=>StoreOrder::where(['uid'=>$uid])->whereTime('add_time','month')->sum('total_price'),
  669. 'key'=>'元',
  670. 'class'=>'',
  671. ]
  672. ];
  673. }
  674. /*
  675. * 获取 会员 订单个数,积分明细,优惠劵明细
  676. *
  677. * $uid 用户id;
  678. *
  679. * return array
  680. */
  681. public static function getCountInfo($uid){
  682. $order_count=StoreOrder::where(['uid'=>$uid])->count();
  683. $integral_count=UserBill::where(['uid'=>$uid,'category'=>'integral'])->where('type','in',['deduction','system_add'])->count();
  684. $sign_count=UserBill::where(['uid'=>$uid,'category'=>'integral','type'=>'sign'])->count();
  685. $balanceChang_count=UserBill::where(['uid'=>$uid,'category'=>'now_money'])
  686. ->where('type','in',['system_add','pay_product','extract','pay_product_refund','system_sub'])
  687. ->count();
  688. $coupon_count=StoreCouponUser::where(['uid'=>$uid])->count();
  689. $spread_count=self::where(['spread_uid'=>$uid])->count();
  690. return compact('order_count','integral_count','sign_count','balanceChang_count','coupon_count','spread_count');
  691. }
  692. /*
  693. * 获取 会员业务的
  694. * 购物会员统计
  695. * 会员访问量
  696. *
  697. * 曲线图
  698. *
  699. * $where 查询条件
  700. *
  701. * return array
  702. */
  703. public static function getUserBusinessChart($where,$limit=20){
  704. //获取购物会员人数趋势图
  705. $list=self::getModelTime($where,self::where('a.status',1)->alias('a')->join('__STORE_ORDER__ r','r.uid=a.uid'),'a.add_time')
  706. ->where(['r.paid'=>1,'a.is_promoter'=>0])
  707. ->where('a.add_time','neq',0)
  708. ->field(['FROM_UNIXTIME(a.add_time,"%Y-%m-%d") as _add_time','count(r.uid) as count_user'])
  709. ->group('_add_time')
  710. ->order('_add_time asc')
  711. ->select();
  712. count($list) && $list=$list->toArray();
  713. $seriesdata=[];
  714. $xdata=[];
  715. $zoom='';
  716. foreach ($list as $item){
  717. $seriesdata[]=$item['count_user'];
  718. $xdata[]=$item['_add_time'];
  719. }
  720. count($xdata) > $limit && $zoom=$xdata[$limit-5];
  721. //会员访问量
  722. $visit=self::getModelTime($where,self::alias('a')->join('__STORE_VISIT__ t','t.uid=a.uid'),'t.add_time')
  723. ->where('a.is_promoter',0)
  724. ->field(['FROM_UNIXTIME(t.add_time,"%Y-%m-%d") as _add_time','count(t.uid) as count_user'])
  725. ->group('_add_time')
  726. ->order('_add_time asc')
  727. ->select();
  728. count($visit) && $visit=$visit->toArray();
  729. $visit_data=[];
  730. $visit_xdata=[];
  731. $visit_zoom='';
  732. foreach ($visit as $item){
  733. $visit_data[]=$item['count_user'];
  734. $visit_xdata[]=$item['_add_time'];
  735. }
  736. count($visit_xdata) > $limit && $visit_zoom=$visit_xdata[$limit-5];
  737. //多次购物会员数量饼状图
  738. $count=self::getModelTime($where,self::where('is_promoter',0))->count();
  739. $user_count=self::getModelTime($where,self::alias('a')->join('__STORE_ORDER__ r','r.uid=a.uid'),'a.add_time')
  740. ->where('a.is_promoter',0)
  741. ->where('r.paid',1)
  742. ->group('a.uid')
  743. ->count();
  744. $shop_xdata=['多次购买数量占比','无购买数量占比'];
  745. $shop_data=[];
  746. $count >0 && $shop_data=[
  747. [
  748. 'value'=>bcdiv($user_count,$count,2)*100,
  749. 'name'=>$shop_xdata[0],
  750. 'itemStyle'=>[
  751. 'color'=>'#D789FF',
  752. ]
  753. ],
  754. [
  755. 'value'=>bcdiv($count-$user_count,$count,2)*100,
  756. 'name'=>$shop_xdata[1],
  757. 'itemStyle'=>[
  758. 'color'=>'#7EF0FB',
  759. ]
  760. ]
  761. ];
  762. return compact('seriesdata','xdata','zoom','visit_data','visit_xdata','visit_zoom','shop_data','shop_xdata');
  763. }
  764. /*
  765. * 获取用户
  766. * 积分排行
  767. * 会员余额排行榜
  768. * 分销商佣金总额排行榜
  769. * 购物笔数排行榜
  770. * 购物金额排行榜
  771. * 分销商佣金提现排行榜
  772. * 上月消费排行榜
  773. * $limit 查询多少条
  774. * return array
  775. */
  776. public static function getUserTop10List($limit=10,$is_promoter=0){
  777. //积分排行
  778. $integral=self::where('status',1)
  779. ->where('is_promoter',$is_promoter)
  780. ->order('integral desc')
  781. ->field(['nickname','phone','integral','FROM_UNIXTIME(add_time,"%Y-%m-%d") as add_time'])
  782. ->limit($limit)
  783. ->select();
  784. count($integral) && $integral=$integral->toArray();
  785. //会员余额排行榜
  786. $now_money=self::where('status',1)
  787. ->where('is_promoter',$is_promoter)
  788. ->order('now_money desc')
  789. ->field(['nickname','phone','now_money','FROM_UNIXTIME(add_time,"%Y-%m-%d") as add_time'])
  790. ->limit($limit)
  791. ->select();
  792. count($now_money) && $now_money=$now_money->toArray();
  793. //购物笔数排行榜
  794. $orderPayCount = StoreOrder::getOrderPayCount($is_promoter);
  795. if($orderPayCount){
  796. $shopcount=self::alias('a')
  797. ->join('__STORE_ORDER__ r','r.uid=a.uid')
  798. ->where(['r.paid'=>1,'a.is_promoter'=>$is_promoter])
  799. ->group('r.uid')
  800. ->field(['a.nickname','a.phone','count(r.uid) as sum_count','FROM_UNIXTIME(a.add_time,"%Y-%m-%d") as add_time'])
  801. ->order('sum_count desc')
  802. ->limit($limit)
  803. ->select();
  804. }else $shopcount = [];
  805. count($shopcount) && $shopcount=$shopcount->toArray();
  806. //购物金额排行榜
  807. if($orderPayCount){
  808. $order=self::alias('a')
  809. ->join('__STORE_ORDER__ r','r.uid=a.uid')
  810. ->where(['r.paid'=>1,'a.is_promoter'=>$is_promoter])
  811. ->group('r.uid')
  812. ->field(['a.nickname','a.phone','sum(r.pay_price) as sum_price','FROM_UNIXTIME(a.add_time,"%Y-%m-%d") as add_time','r.uid'])
  813. ->order('sum_price desc')
  814. ->limit($limit)
  815. ->select();
  816. }else $order = [];
  817. count($order) && $order=$order->toArray();
  818. //上月消费排行
  819. $orderPayCount = StoreOrder::getOrderPayMonthCount($is_promoter);
  820. if($orderPayCount){
  821. $lastorder=self::alias('a')
  822. ->join('__STORE_ORDER__ r','r.uid=a.uid')
  823. ->where(['r.paid'=>1,'a.is_promoter'=>$is_promoter])
  824. // ->whereTime('r.pay_time','last month')
  825. ->where('r.pay_time','between',[strtotime(date('Y-m',strtotime('-1 month'))),strtotime(date('Y-m'))])
  826. ->group('r.uid')
  827. ->field(['a.nickname','a.phone','sum(r.pay_price) as sum_price','FROM_UNIXTIME(a.add_time,"%Y-%m-%d") as add_time','r.uid'])
  828. ->order('sum_price desc')
  829. ->limit($limit)
  830. ->select();
  831. }else $lastorder = [];
  832. count($lastorder) && $lastorder=$lastorder->toArray();
  833. return compact('integral','now_money','shopcount','order','lastorder');
  834. }
  835. /*
  836. * 获取 会员业务
  837. * 会员总余额 会员总积分
  838. * $where 查询条件
  839. *
  840. * return array
  841. */
  842. public static function getUserBusinesHeade($where){
  843. return [
  844. [
  845. 'name'=>'会员总余额',
  846. 'field'=>'元',
  847. 'count'=>self::getModelTime($where,self::where('status',1))->sum('now_money'),
  848. 'background_color'=>'layui-bg-cyan',
  849. 'col'=>6,
  850. ],
  851. [
  852. 'name'=>'会员总积分',
  853. 'field'=>'分',
  854. 'count'=>self::getModelTime($where,self::where('status',1))->sum('integral'),
  855. 'background_color'=>'layui-bg-cyan',
  856. 'col'=>6
  857. ]
  858. ];
  859. }
  860. /*
  861. * 分销会员头部信息查询获取
  862. *
  863. * 分销商总佣金余额
  864. * 分销商总提现佣金
  865. * 本月分销商业务佣金
  866. * 本月分销商佣金提现金额
  867. * 上月分销商业务佣金
  868. * 上月分销商佣金提现金额
  869. * $where array 时间条件
  870. *
  871. * return array
  872. */
  873. public static function getDistributionBadgeList($where){
  874. return [
  875. [
  876. 'name'=>'分销商总佣金',
  877. 'field'=>'元',
  878. 'count'=>self::getModelTime($where,UserBill::where('category','now_money')->where('type','brokerage'))->where('uid','in',function($query){
  879. $query->name('user')->where('status',1)->where('is_promoter',1)->whereOr('spread_uid','neq',0)->field('uid');
  880. })->sum('number'),
  881. 'background_color'=>'layui-bg-cyan',
  882. 'col'=>3,
  883. ],
  884. [
  885. 'name'=>'分销商总佣金余额',
  886. 'field'=>'元',
  887. 'count'=>self::getModelTime($where,self::where('status',1)->where('is_promoter',1))->sum('now_money'),
  888. 'background_color'=>'layui-bg-cyan',
  889. 'col'=>3,
  890. ],
  891. [
  892. 'name'=>'分销商总提现佣金',
  893. 'field'=>'元',
  894. 'count'=>self::getModelTime($where,UserExtract::where('status',1))->sum('extract_price'),
  895. 'background_color'=>'layui-bg-cyan',
  896. 'col'=>3,
  897. ],
  898. [
  899. 'name'=>'本月分销商业务佣金',
  900. 'field'=>'元',
  901. 'count'=>self::getModelTime(['data'=>'month'],UserBill::where('category','now_money')->where('type','brokerage'))
  902. ->where('uid','in',function ($query){
  903. $query->name('user')->where('status',1)->where('is_promoter',1)->whereOr('spread_uid','neq',0)->field('uid');
  904. })->sum('number'),
  905. 'background_color'=>'layui-bg-cyan',
  906. 'col'=>3,
  907. ],
  908. [
  909. 'name'=>'本月分销商佣金提现金额',
  910. 'field'=>'元',
  911. 'count'=>self::getModelTime(['data'=>'month'],UserExtract::where('status',1))
  912. ->where('uid','in',function ($query){
  913. $query->name('user')->where('status',1)->where('is_promoter',1)->field('uid');
  914. })->sum('extract_price'),
  915. 'background_color'=>'layui-bg-cyan',
  916. 'col'=>4,
  917. ],
  918. [
  919. 'name'=>'上月分销商业务佣金',
  920. 'field'=>'元',
  921. 'count'=>self::getOldDate(['data'=>'year'],UserBill::where('category','now_money')->where('uid','in',function ($query){
  922. $query->name('user')->where('status',1)->where('is_promoter',1)->whereOr('spread_uid','neq',0)->field('uid');
  923. })->where('type','brokerage'))->sum('number'),
  924. 'background_color'=>'layui-bg-cyan',
  925. 'col'=>4,
  926. ],
  927. [
  928. 'name'=>'上月分销商佣金提现金额',
  929. 'field'=>'元',
  930. 'count'=>self::getOldDate(['data'=>'year'],UserBill::where('category','now_money')->where('uid','in',function ($query){
  931. $query->name('user')->where('status',1)->where('is_promoter',1)->whereOr('spread_uid','neq',0)->field('uid');
  932. })->where('type','brokerage'))->sum('number'),
  933. 'background_color'=>'layui-bg-cyan',
  934. 'col'=>4,
  935. ],
  936. ];
  937. }
  938. /*
  939. * 分销会员
  940. * 分销数量 饼状图
  941. * 分销商会员访问量 曲线
  942. * 获取购物会员人数趋势图 曲线
  943. * 多次购物分销会员数量 饼状图
  944. * $where array 条件
  945. * $limit int n条数据后出拖动条
  946. * return array
  947. */
  948. public static function getUserDistributionChart($where,$limit=20){
  949. //分销数量
  950. $fenbu_user=self::getModelTime($where,new self)->field(['count(uid) as num'])->group('is_promoter')->select();
  951. count($fenbu_user) && $fenbu_user=$fenbu_user->toArray();
  952. $sum_user=0;
  953. $fenbu_data=[];
  954. $fenbu_xdata=['分销商','非分销商'];
  955. $color=['#81BCFE','#91F3FE'];
  956. foreach($fenbu_user as $item){
  957. $sum_user+=$item['num'];
  958. }
  959. foreach ($fenbu_user as $key=>$item){
  960. $value['value']=bcdiv($item['num'],$sum_user,2)*100;
  961. $value['name']=isset($fenbu_xdata[$key]) ?$fenbu_xdata[$key].' %'.$value['value'] :'';
  962. $value['itemStyle']['color']=$color[$key];
  963. $fenbu_data[]=$value;
  964. }
  965. //分销商会员访问量
  966. $visit=self::getModelTime($where,self::alias('a')->join('store_visit t','t.uid=a.uid'),'t.add_time')
  967. ->where('a.is_promoter',1)
  968. ->field(['FROM_UNIXTIME(t.add_time,"%Y-%m-%d") as _add_time','count(t.uid) as count_user'])
  969. ->group('_add_time')
  970. ->order('_add_time asc')
  971. ->select();
  972. // echo self::getLastSql();die;
  973. count($visit) && $visit=$visit->toArray();
  974. $visit_data=[];
  975. $visit_xdata=[];
  976. $visit_zoom='';
  977. foreach ($visit as $item){
  978. $visit_data[]=$item['count_user'];
  979. $visit_xdata[]=$item['_add_time'];
  980. }
  981. count($visit_xdata) > $limit && $visit_zoom=$visit_xdata[$limit-5];
  982. //获取购物会员人数趋势图
  983. $list=self::getModelTime($where,self::where('a.status',1)->alias('a')->join('__STORE_ORDER__ r','r.uid=a.uid'),'a.add_time')
  984. ->where(['r.paid'=>1,'a.is_promoter'=>1])
  985. ->where('a.add_time','neq',0)
  986. ->field(['FROM_UNIXTIME(a.add_time,"%Y-%m-%d") as _add_time','count(r.uid) as count_user'])
  987. ->group('_add_time')
  988. ->order('_add_time asc')
  989. ->select();
  990. count($list) && $list=$list->toArray();
  991. $seriesdata=[];
  992. $xdata=[];
  993. $zoom='';
  994. foreach ($list as $item){
  995. $seriesdata[]=$item['count_user'];
  996. $xdata[]=$item['_add_time'];
  997. }
  998. count($xdata) > $limit && $zoom=$xdata[$limit-5];
  999. //多次购物分销会员数量饼状图
  1000. $count=self::getModelTime($where,self::where('is_promoter',1))->count();
  1001. $user_count=self::getModelTime($where,self::alias('a')
  1002. ->join('__STORE_ORDER__ r','r.uid=a.uid'),'a.add_time')
  1003. ->where('a.is_promoter',1)
  1004. ->where('r.paid',1)
  1005. ->group('a.uid')
  1006. ->count();
  1007. $shop_xdata=['多次购买数量占比','无购买数量占比'];
  1008. $shop_data=[];
  1009. $count >0 && $shop_data=[
  1010. [
  1011. 'value'=>bcdiv($user_count,$count,2)*100,
  1012. 'name'=>$shop_xdata[0].$user_count.'人',
  1013. 'itemStyle'=>[
  1014. 'color'=>'#D789FF',
  1015. ]
  1016. ],
  1017. [
  1018. 'value'=>bcdiv($count-$user_count,$count,2)*100,
  1019. 'name'=>$shop_xdata[1].($count-$user_count).'人',
  1020. 'itemStyle'=>[
  1021. 'color'=>'#7EF0FB',
  1022. ]
  1023. ]
  1024. ];
  1025. return compact('fenbu_data','fenbu_xdata','visit_data','visit_xdata','visit_zoom','seriesdata','xdata','zoom','shop_xdata','shop_data');
  1026. }
  1027. /*
  1028. * 分销商佣金提现排行榜
  1029. * 分销商佣金总额排行榜
  1030. * $limit 截取条数
  1031. * return array
  1032. */
  1033. public static function getUserDistributionTop10List($limit){
  1034. //分销商佣金提现排行榜
  1035. $extract=self::alias('a')
  1036. ->join('user_extract t','a.uid=t.uid')
  1037. ->where(['t.status'=>1,'a.is_promoter'=>1])
  1038. ->group('t.uid')
  1039. ->field(['a.nickname','a.phone','sum(t.extract_price) as sum_price','FROM_UNIXTIME(a.add_time,"%Y-%m-%d") as add_time','t.uid'])
  1040. ->order('sum_price desc')
  1041. ->limit($limit)
  1042. ->select();
  1043. count($extract) && $extract=$extract->toArray();
  1044. //分销商佣金总额排行榜
  1045. $commission=UserBill::alias('l')
  1046. ->join('user a','l.uid=a.uid')
  1047. ->where(['l.status'=>'1','l.category'=>'now_money','l.type'=>'brokerage','a.is_promoter'=>1])
  1048. ->group('l.uid')
  1049. ->field(['a.nickname','a.phone','sum(number) as sum_number','FROM_UNIXTIME(a.add_time,"%Y-%m-%d") as add_time'])
  1050. ->order('sum_number desc')
  1051. ->limit($limit)
  1052. ->select();
  1053. count($commission) && $commission=$commission->toArray();
  1054. return compact('extract','commission');
  1055. }
  1056. public static function getSpreadList($uid,$page,$limit){
  1057. $list=self::where(['spread_uid'=>$uid])->field(['uid','nickname','now_money','integral','add_time'])
  1058. ->order('uid desc')->page((int)$page,(int)$limit)->select();
  1059. count($list) && $list=$list->toArray();
  1060. foreach ($list as &$item){
  1061. $item['add_time']=date('Y-m-d H',$item['add_time']);
  1062. }
  1063. return $list;
  1064. }
  1065. /**
  1066. * 一级分销
  1067. * @param $orderInfo
  1068. * @return bool
  1069. */
  1070. public static function backOrderBrokerage($orderInfo)
  1071. {
  1072. $userInfo = User::getUserInfo($orderInfo['uid']);
  1073. if(!$userInfo || !$userInfo['spread_uid']) return true;
  1074. $storeBrokerageStatu = SystemConfigService::get('store_brokerage_statu') ? : 1;//获取后台分销类型
  1075. if($storeBrokerageStatu == 1){
  1076. if(!User::be(['uid'=>$userInfo['spread_uid'],'is_promoter'=>1])) return true;
  1077. }
  1078. $brokerageRatio = (SystemConfigService::get('store_brokerage_ratio') ?: 0)/100;
  1079. if($brokerageRatio <= 0) return true;
  1080. $cost = isset($orderInfo['cost']) ? $orderInfo['cost'] : 0;//成本价
  1081. if($cost > $orderInfo['pay_price']) return true;//成本价大于支付价格时直接返回
  1082. $brokeragePrice = bcmul(bcsub($orderInfo['pay_price'],$cost,2),$brokerageRatio,2);
  1083. //返佣之后余额
  1084. $spNow_money = User::where(['uid'=>$userInfo['spread_uid']])->value('now_money');
  1085. $balance = bcadd($spNow_money,$brokeragePrice,2);
  1086. if($brokeragePrice <= 0) return true;
  1087. $mark = $userInfo['nickname'].'成功消费'.floatval($orderInfo['pay_price']).'元,奖励推广佣金'.floatval($brokeragePrice);
  1088. self::beginTrans();
  1089. $res1 = UserBill::income('获得推广佣金',$userInfo['spread_uid'],'now_money','brokerage',$brokeragePrice,$orderInfo['id'],$balance,$mark);
  1090. $res2 = self::bcInc($userInfo['spread_uid'],'now_money',$brokeragePrice,'uid');
  1091. $res = $res1 && $res2;
  1092. self::checkTrans($res);
  1093. if($res) self::backOrderBrokerageTwo($orderInfo);
  1094. return $res;
  1095. }
  1096. /**
  1097. * 二级推广
  1098. * @param $orderInfo
  1099. * @return bool
  1100. */
  1101. public static function backOrderBrokerageTwo($orderInfo){
  1102. $userInfo = User::getUserInfo($orderInfo['uid']);
  1103. $userInfoTwo = User::getUserInfo($userInfo['spread_uid']);
  1104. if(!$userInfoTwo || !$userInfoTwo['spread_uid']) return true;
  1105. $storeBrokerageStatu = SystemConfigService::get('store_brokerage_statu') ? : 1;//获取后台分销类型
  1106. if($storeBrokerageStatu == 1){
  1107. if(!User::be(['uid'=>$userInfoTwo['spread_uid'],'is_promoter'=>1])) return true;
  1108. }
  1109. $brokerageRatio = (SystemConfigService::get('store_brokerage_two') ?: 0)/100;
  1110. if($brokerageRatio <= 0) return true;
  1111. $cost = isset($orderInfo['cost']) ? $orderInfo['cost'] : 0;//成本价
  1112. if($cost > $orderInfo['pay_price']) return true;//成本价大于支付价格时直接返回
  1113. $brokeragePrice = bcmul(bcsub($orderInfo['pay_price'],$cost,2),$brokerageRatio,2);
  1114. //返佣之后余额
  1115. $spNow_money = User::where(['uid'=>$userInfo['spread_uid']])->value('now_money');
  1116. $balance = bcadd($spNow_money,$brokeragePrice,2);
  1117. if($brokeragePrice <= 0) return true;
  1118. $mark = '二级推广人'.$userInfo['nickname'].'成功消费'.floatval($orderInfo['pay_price']).'元,奖励推广佣金'.floatval($brokeragePrice);
  1119. self::beginTrans();
  1120. $res1 = UserBill::income('获得推广佣金',$userInfoTwo['spread_uid'],'now_money','brokerage',$brokeragePrice,$orderInfo['id'],$balance,$mark);
  1121. $res2 = self::bcInc($userInfoTwo['spread_uid'],'now_money',$brokeragePrice,'uid');
  1122. $res = $res1 && $res2;
  1123. self::checkTrans($res);
  1124. return $res;
  1125. }
  1126. }