User.php 46 KB

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