CRMEB/crmeb/app/api/controller/user/UserBillController.php
2019-11-19 17:07:57 +08:00

329 lines
16 KiB
PHP

<?php
namespace app\api\controller\user;
use app\admin\model\system\SystemAttachment;
use app\models\routine\RoutineCode;
use app\models\routine\RoutineQrcode;
use app\models\store\StoreOrder;
use app\models\user\User;
use app\models\user\UserBill;
use app\models\user\UserExtract;
use app\Request;
use crmeb\services\GroupDataService;
use crmeb\services\SystemConfigService;
use crmeb\services\UploadService;
use crmeb\services\UtilService;
/**
* 账单类
* Class UserBillController
* @package app\api\controller\user
*/
class UserBillController
{
/**
* 推广数据 昨天的佣金 累计提现金额 当前佣金
* @param Request $request
* @return mixed
*/
public function commission(Request $request)
{
$uid = $request->uid();
$lastDayCount = UserBill::yesterdayCommissionSum($uid);//昨天的佣金
$extractCount = UserExtract::extractSum($uid);//累计提现金额
$commissionCount = UserBill::getBrokerage($uid);//获取总佣金
if($commissionCount > 0){
$rechargeCount = UserBill::getRecharge($uid);//累计充值
$orderYuePrice = StoreOrder::getOrderStatusYueSum($uid);//余额累计消费
$systemAdd = UserBill::getSystemAdd($uid);//后台添加余额
$yueCount = bcadd($rechargeCount,$systemAdd,2);// 后台添加余额 + 累计充值 = 非佣金的总金额
$orderYuePrice = $yueCount > $orderYuePrice ? 0 : bcsub($orderYuePrice,$yueCount,2);// 余额累计消费(使用佣金消费的金额)
$commissionCount = bcsub($commissionCount, $extractCount,2);//减去已提现金额
$extractPriceCount = UserExtract::userExtractTotalPrice($uid,0);
$commissionCount = $extractPriceCount < $commissionCount ? bcsub($commissionCount, $extractPriceCount,2) : 0;//减去审核中的提现金额
$commissionCount = $commissionCount > $orderYuePrice ? bcsub($commissionCount, $orderYuePrice,2) : 0;//减掉余额支付
}
$data['lastDayCount'] = $lastDayCount;
$data['extractCount'] = $extractCount;
$data['commissionCount'] = $commissionCount;
return app('json')->successful($data);
}
/**
* 推荐用户
* @param Request $request
* @return mixed
*
* grade == 0 获取一级推荐人
* grade == 1 获取二级推荐人
*
* keyword 会员名称查询
*
* sort childCount ASC/DESC 团队排序 numberCount ASC/DESC 金额排序 orderCount ASC/DESC 订单排序
*/
public function spread_people(Request $request)
{
$spreadInfo = UtilService::postMore([
['page',1],
['limit',20],
['grade',0],
['keyword',''],
['sort',''],
],$request);
$uid = $request->uid();
$data['list'] = User::getUserSpreadGrade($uid, $spreadInfo['grade'], $spreadInfo['sort'], $spreadInfo['keyword'], $spreadInfo['page'], $spreadInfo['limit']);
$data['total'] = User::getSpreadCount($uid);
$data['totalLevel'] = User::getSpreadLevelCount($uid);
return app('json')->successful($data);
}
/**
* 推广订单
* @param Request $request
* @return mixed
*/
public function spread_order(Request $request)
{
$orderInfo = UtilService::postMore([
['page',1],
['limit',20],
['category','now_money'],
['type','brokerage'],
],$request);
$data['list'] = [];
$data['count'] = 0;
$uid = $request->uid();
$data['list'] = UserBill::getRecordList($uid, $orderInfo['page'], $orderInfo['limit'], $orderInfo['category'], $orderInfo['type']);
$count = UserBill::getRecordOrderCount($uid, $orderInfo['category'], $orderInfo['type']);
$data['count'] = $count ? $count : 0;
if(!count($data['list'])) return app('json')->successful($data);
foreach ($data['list'] as $key=>&$value){
$value['child'] = UserBill::getRecordOrderListDraw($uid, $value['time'], $orderInfo['category'], $orderInfo['type']);
$value['count'] = count($value['child']);
}
return app('json')->successful($data);
}
/**
* 推广佣金明细
* @param Request $request
* @param $type 0 全部 1 消费 2 充值 3 返佣 4 提现
* @return mixed
*/
public function spread_commission(Request $request, $type)
{
list($page, $limit) = UtilService::getMore([
['page',0],
['limit',0],
],$request, true);
return app('json')->successful(UserBill::getUserBillList($request->uid(),$page,$limit,$type));
}
/**
* 推广 佣金/提现 总和
* @param Request $request
* @param $type 3 佣金 4 提现
* @return mixed
*/
public function spread_count(Request $request, $type)
{
$count = 0;
if($type == 3) $count = UserBill::getRecordCount($request->uid(), 'now_money', 'brokerage');
else if($type == 4) $count = UserExtract::userExtractTotalPrice($request->uid());//累计提现
$count = $count ? $count : 0;
return app('json')->successful(['count'=>$count]);
}
/**
* 分销二维码海报生成
* @param Request $request
* @return mixed
*/
public function spread_banner(Request $request)
{
list($type) = UtilService::getMore([
['type',2],
],$request, true);
$user = $request->user();
$rootPath = app()->getRootPath();
try{
$resRoutine = true;//小程序
$resWap = true;//公众号
$siteUrl = sysConfig('site_url');
$routineSpreadBanner = GroupDataService::getData('routine_spread_banner');
if(!count($routineSpreadBanner)) return app('json')->fail('暂无海报');
if($type == 1){
//小程序
$name = $user['uid'].'_'.$user['is_promoter'].'_user_routine.jpg';
$imageInfo = SystemAttachment::getInfo($name,'name');
//检测远程文件是否存在
if(isset($imageInfo['att_dir']) && strstr($imageInfo['att_dir'],'http')!==false && UtilService::CurlFileExist($imageInfo['att_dir']) === false){
$imageInfo = null;
SystemAttachment::where(['name'=>$name])->delete();
}
if(!$imageInfo){
$res = RoutineCode::getShareCode($user['uid'], 'spread', '', '');
if(!$res) return app('json')->fail('二维码生成失败');
$imageInfo = UploadService::instance()->setUploadPath('routine/spread/code')->imageStream($name,$res['res']);
if(!is_array($imageInfo)) return app('json')->fail($imageInfo);
SystemAttachment::attachmentAdd($imageInfo['name'],$imageInfo['size'],$imageInfo['type'],$imageInfo['dir'],$imageInfo['thumb_path'],1,$imageInfo['image_type'],$imageInfo['time'],2);
RoutineQrcode::setRoutineQrcodeFind($res['id'],['status'=>1,'time'=>time(),'qrcode_url'=>$imageInfo['dir']]);
$urlCode = $imageInfo['dir'];
}else $urlCode = $imageInfo['att_dir'];
if($imageInfo['image_type'] == 1) $urlCode = $siteUrl.$urlCode;
$siteUrlHttps = UtilService::setHttpType($siteUrl, 0);
$filelink=[
'Bold'=>'static'. DS .'font'. DS .'Alibaba-PuHuiTi-Regular.otf',
'Normal'=>'static'. DS .'font'. DS .'Alibaba-PuHuiTi-Regular.otf',
];
if(!file_exists($filelink['Bold'])) return app('json')->fail('缺少字体文件Bold');
if(!file_exists($filelink['Normal'])) return app('json')->fail('缺少字体文件Normal');
foreach ($routineSpreadBanner as $key=>&$item){
$posterInfo = '海报生成失败:(';
$config = array(
'image'=>array(
array(
'url'=>$urlCode, //二维码资源
'stream'=>0,
'left'=>114,
'top'=>790,
'right'=>0,
'bottom'=>0,
'width'=>120,
'height'=>120,
'opacity'=>100
)
),
'text'=>array(
array(
'text'=>$user['nickname'],
'left'=>250,
'top'=>840,
'fontPath'=>$rootPath.'public'. DS .$filelink['Bold'], //字体文件
'fontSize'=>16, //字号
'fontColor'=>'40,40,40', //字体颜色
'angle'=>0,
),
array(
'text'=>'邀请您加入'.sysConfig('site_name'),
'left'=>250,
'top'=>880,
'fontPath'=>$rootPath.'public'. DS .$filelink['Normal'], //字体文件
'fontSize'=>16, //字号
'fontColor'=>'40,40,40', //字体颜色
'angle'=>0,
)
),
'background'=>$item['pic']
);
$resRoutine = $resRoutine && $posterInfo = UtilService::setSharePoster($config,'routine/spread/poster');
if(!is_array($posterInfo)) return app('json')->fail($posterInfo);
SystemAttachment::attachmentAdd($posterInfo['name'],$posterInfo['size'],$posterInfo['type'],$posterInfo['dir'],$posterInfo['thumb_path'],1,$posterInfo['image_type'],$posterInfo['time'],2);
if($resRoutine){
if($posterInfo['image_type'] == 1)
$item['poster'] = $siteUrlHttps.$posterInfo['dir'];
else
$item['poster'] = UtilService::setHttpType($posterInfo['dir'], 0);
$item['poster'] = str_replace('\\','/',$item['poster']);
}
}
}else if($type == 2){
//公众号
$name = $user['uid'].'_'.$user['is_promoter'].'_user_wap.jpg';
$imageInfo = SystemAttachment::getInfo($name,'name');
//检测远程文件是否存在
if(isset($imageInfo['att_dir']) && strstr($imageInfo['att_dir'],'http')!==false && UtilService::CurlFileExist($imageInfo['att_dir']) === false){
$imageInfo = null;
SystemAttachment::where(['name'=>$name])->delete();
}
if(!$imageInfo){
$codeUrl = UtilService::setHttpType($siteUrl.'?spread='.$user['uid'], 1);//二维码链接
$imageInfo = UtilService::getQRCodePath($codeUrl, $name);
if(!$imageInfo) return app('json')->fail('二维码生成失败');
SystemAttachment::attachmentAdd($imageInfo['name'],$imageInfo['size'],$imageInfo['type'],$imageInfo['dir'],$imageInfo['thumb_path'],1,$imageInfo['image_type'],$imageInfo['time'],2);
$urlCode = $imageInfo['dir'];
}else $urlCode = $imageInfo['att_dir'];
if($imageInfo['image_type'] == 1) $urlCode = $siteUrl.$urlCode;
$siteUrl = UtilService::setHttpType($siteUrl, 1);
$filelink=[
'Bold'=>'static'. DS .'font'. DS .'Alibaba-PuHuiTi-Regular.otf',
'Normal'=>'static'. DS .'font'. DS .'Alibaba-PuHuiTi-Regular.otf',
];
if(!file_exists($filelink['Bold'])) return app('json')->fail('缺少字体文件Bold');
if(!file_exists($filelink['Normal'])) return app('json')->fail('缺少字体文件Normal');
foreach ($routineSpreadBanner as $key=>&$item){
$posterInfo = '海报生成失败:(';
$config = array(
'image'=>array(
array(
'url'=>$urlCode, //二维码资源
'stream'=>0,
'left'=>114,
'top'=>790,
'right'=>0,
'bottom'=>0,
'width'=>120,
'height'=>120,
'opacity'=>100
)
),
'text'=>array(
array(
'text'=>$user['nickname'],
'left'=>250,
'top'=>840,
'fontPath'=>$rootPath.'public'. DS .$filelink['Bold'], //字体文件
'fontSize'=>16, //字号
'fontColor'=>'40,40,40', //字体颜色
'angle'=>0,
),
array(
'text'=>'邀请您加入'.sysConfig('site_name'),
'left'=>250,
'top'=>880,
'fontPath'=>$rootPath.'public'. DS .$filelink['Normal'], //字体文件
'fontSize'=>16, //字号
'fontColor'=>'40,40,40', //字体颜色
'angle'=>0,
)
),
'background'=>$item['pic']
);
$resWap = $resWap && $posterInfo = UtilService::setSharePoster($config,'wap/spread/poster');
if(!is_array($posterInfo)) return app('json')->fail($posterInfo);
SystemAttachment::attachmentAdd($posterInfo['name'],$posterInfo['size'],$posterInfo['type'],$posterInfo['dir'],$posterInfo['thumb_path'],1,$posterInfo['image_type'],$posterInfo['time'],2);
if($resWap){
if($posterInfo['image_type'] == 1)
$item['wap_poster'] = $siteUrl.$posterInfo['dir'];
else
$item['wap_poster'] = UtilService::setHttpType($posterInfo['dir'], 1);
}
}
}
if($resRoutine && $resWap) return app('json')->successful($routineSpreadBanner);
else return app('json')->fail('生成图片失败');
}catch (\Exception $e){
return app('json')->fail('生成图片时,系统错误',['line'=>$e->getLine(),'message'=>$e->getMessage()]);
}
}
/**
* 积分记录
* @param Request $request
* @return mixed
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\ModelNotFoundException
* @throws \think\exception\DbException
*/
public function integral_list(Request $request)
{
list($page, $limit) = UtilService::getMore([
['page',0],['limit',0]
], $request, true);
return app('json')->successful(UserBill::userBillList($request->uid(),$page,$limit));
}
}