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) { $count1 = UserBill::getRecordCount($request->uid(), 'now_money', 'brokerage'); $count2 = UserBill::getRecordCount($request->uid(), 'now_money', 'brokerage', '', true); $count = $count1 - $count2; } 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 = sys_config('site_url'); $routineSpreadBanner = sys_data('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 && curl_file_exist($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('二维码生成失败'); $uploadType = (int)sys_config('upload_type', 1); $upload = new Upload($uploadType, [ 'accessKey' => sys_config('accessKey'), 'secretKey' => sys_config('secretKey'), 'uploadUrl' => sys_config('uploadUrl'), 'storageName' => sys_config('storage_name'), 'storageRegion' => sys_config('storage_region'), ]); $uploadRes = $upload->to('routine/spread/code')->validate()->stream($res['res'], $name); if ($uploadRes === false) { return app('json')->fail($upload->getError()); } $imageInfo = $upload->getUploadInfo(); $imageInfo['image_type'] = $uploadType; 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, 'url_time' => time(), 'qrcode_url' => $imageInfo['dir']]); $urlCode = $imageInfo['dir']; } else $urlCode = $imageInfo['att_dir']; if ($imageInfo['image_type'] == 1) $urlCode = $siteUrl . $urlCode; $siteUrlHttps = set_http_type($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' => 225, 'top' => 913, 'right' => 0, 'bottom' => 0, 'width' => 300, 'height' => 300, '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' => '邀请您加入' . sys_config('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'] = set_http_type($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 && curl_file_exist($imageInfo['att_dir']) === false) { $imageInfo = null; SystemAttachment::where(['name' => $name])->delete(); } if (!$imageInfo) { // $qr_code = QrcodeService::getForeverQrcode('spread', $user['uid']); // if (isset($qr_code['url'])) { // $urlCode = $qr_code['url']; // } else { $codeUrl = set_http_type($siteUrl . '/register?spread=' . $user['uid'], 1);//二维码链接 $imageInfo = UtilService::getQRCodePath($codeUrl, $name); if (is_string($imageInfo)) return app('json')->fail('二维码生成失败', ['error' => $imageInfo]); 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 = set_http_type($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' => 225, 'top' => 913, 'right' => 0, 'bottom' => 0, 'width' => 300, 'height' => 300, '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' => '邀请您加入' . sys_config('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['thumb_path']; else $item['wap_poster'] = UtilService::setHttpType($posterInfo['thumb_path'], 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(), 'file' => $e->getFile()]); } } /** * 积分记录 * @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, $status) = UtilService::getMore([ ['page', 0], ['limit', 0], ['pm', 0] ], $request, true); return app('json')->successful(UserBill::userBillList($request->uid(), $page, $limit, 'integral', ['pm' => $status])); } /** * 白积分记录 * @param Request $request * @return mixed * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\ModelNotFoundException * @throws \think\exception\DbException */ public function white_integral(Request $request) { list($page, $limit, $status) = UtilService::getMore([ ['page', 0], ['limit', 0], ['pm', 0] ], $request, true); return app('json')->successful(UserBill::userBillList($request->uid(), $page, $limit, 'white_integral', ['pm' => $status])); } /** * 紫积分记录 * @param Request $request * @return mixed * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\ModelNotFoundException * @throws \think\exception\DbException */ public function purple_integral(Request $request) { list($page, $limit, $status) = UtilService::getMore([ ['page', 0], ['limit', 0], ['pm', 0] ], $request, true); return app('json')->successful(UserBill::userBillList($request->uid(), $page, $limit, 'purple_integral', ['pm' => $status])); } /** * 绿积分记录 * @param Request $request * @return mixed * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\ModelNotFoundException * @throws \think\exception\DbException */ public function green_integral(Request $request) { list($page, $limit, $status) = UtilService::getMore([ ['page', 0], ['limit', 0], ['pm', 0] ], $request, true); return app('json')->successful(UserBill::userBillList($request->uid(), $page, $limit, 'green_integral', ['pm' => $status])); } /** * 商家积分记录 * @param Request $request * @return mixed * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\ModelNotFoundException * @throws \think\exception\DbException */ public function business_integral(Request $request) { list($page, $limit, $status) = UtilService::getMore([ ['page', 0], ['limit', 0], ['pm', 0] ], $request, true); return app('json')->successful(UserBill::userBillList($request->uid(), $page, $limit, 'business_integral', ['pm' => $status])); } /** * 文票记录 * @param Request $request * @return mixed * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\ModelNotFoundException * @throws \think\exception\DbException */ public function paper_ticket(Request $request) { list($page, $limit, $status) = UtilService::getMore([ ['page', 0], ['limit', 0], ['pm', 0] ], $request, true); return app('json')->successful(UserBill::userBillList($request->uid(), $page, $limit, 'paper_ticket', ['pm' => $status])); } }