master
ELF 4 years ago
parent 8c8d01a446
commit 34586b228e

@ -128,6 +128,7 @@ class PromoteGradeService
$config = json_decode($setting['config'], true); $config = json_decode($setting['config'], true);
$settingLevel = $config['reach_level']; $settingLevel = $config['reach_level'];
$month = $params['month'] ?? date('Y-m'); $month = $params['month'] ?? date('Y-m');
$baseGameId = $params['base_game_id'] ?? 0;
$promoteIds = array_column($promotes, 'id'); $promoteIds = array_column($promotes, 'id');
$beginTime = strtotime($month . '-01 00:00:00'); $beginTime = strtotime($month . '-01 00:00:00');
$endDate = date('Y-m-01 00:00:00', strtotime($month . '-01' . ' +1 month')); $endDate = date('Y-m-01 00:00:00', strtotime($month . '-01' . ' +1 month'));
@ -141,25 +142,43 @@ class PromoteGradeService
->group('promote_id') ->group('promote_id')
->select(false); ->select(false);
$accountItems = M('user_play_info', 'tab_') $baseGame = null;
->field(['promote_id', 'count(DISTINCT user_id) num']) if ($baseGameId > 0) {
->where([ $baseGame = M('base_game', 'tab_')->where(['id' => $baseGameId])->find();
}
$roleMap = [
'role_level' => ['egt', $settingLevel], 'role_level' => ['egt', $settingLevel],
'create_time' => ['between', $betweenTime], 'create_time' => ['between', $betweenTime],
'promote_id' => ['in', $promoteIds], 'promote_id' => ['in', $promoteIds],
'_string' => 'user_id in (' . $userSubSql . ')' '_string' => 'user_id in (' . $userSubSql . ')'
]) ];
$spendMap = [
'pay_time' => ['between', $betweenTime],
'pay_status' => 1,
'promote_id' => ['in', $promoteIds],
'_string' => 'user_id in (' . $userSubSql . ')'
];
if ($baseGame) {
$roleMap['game_id'] = ['in', [$baseGame['android_game_id'], $baseGame['ios_game_id']]];
$spendMap['game_id'] = ['in', [$baseGame['android_game_id'], $baseGame['ios_game_id']]];
} else {
$roleMap['_string'] .= ' and 1=0';
$spendMap['_string'] .= ' and 1=0';
}
$accountItems = M('user_play_info', 'tab_')
->field(['promote_id', 'count(DISTINCT user_id) num'])
->where($roleMap)
->group('promote_id') ->group('promote_id')
->select(); ->select();
$accountItems = index_by_column('promote_id', $accountItems); $accountItems = index_by_column('promote_id', $accountItems);
$amountItems = M('spend', 'tab_') $amountItems = M('spend', 'tab_')
->field(['promote_id', 'sum(pay_amount) amount']) ->field(['promote_id', 'sum(pay_amount) amount'])
->where([ ->where($spendMap)
'pay_time' => ['between', $betweenTime],
'pay_status' => 1, 'promote_id' => ['in', $promoteIds],
'_string' => 'user_id in (' . $userSubSql . ')'
])
->group('promote_id') ->group('promote_id')
->select(); ->select();
$amountItems = index_by_column('promote_id', $amountItems); $amountItems = index_by_column('promote_id', $amountItems);

@ -1894,12 +1894,18 @@ class DownloadController extends BaseController {
public function promote_grade_export() public function promote_grade_export()
{ {
$month = I('month', date('Y-m')); $month = I('month', date('Y-m'));
$month = $month ? $month : date('Y-m');
$baseGameId = I('base_game_id', 0);
$loginPromote = $this->getLoginPromote(); $loginPromote = $this->getLoginPromote();
if ($baseGameId == 0) {
return $this->error('未选择游戏');
}
$promoteGradeService = new PromoteGradeService(); $promoteGradeService = new PromoteGradeService();
$setting = $promoteGradeService->getCurrentSetting($loginPromote); $monthNumber = date('Ym', strtotime($month . '-01'));
$setting = $promoteGradeService->getCurrentSetting($loginPromote, $baseGameId, $monthNumber);
if (is_null($setting)) { if (is_null($setting)) {
return $this->error('未设置评级规则'); return $this->error('该游戏在此月份未设置评级规则');
} }
$parentId = I('parent_id', 0); $parentId = I('parent_id', 0);
@ -1931,7 +1937,7 @@ class DownloadController extends BaseController {
$promotes = M('promote', 'tab_')->field(['id', 'account', 'real_name', 'level', 'chain'])->where($map)->select(); $promotes = M('promote', 'tab_')->field(['id', 'account', 'real_name', 'level', 'chain'])->where($map)->select();
array_unshift($promotes, $parent); array_unshift($promotes, $parent);
$conditions = json_encode(['promotes' => $promotes, 'setting' => $setting, 'month' => $month], true); $conditions = json_encode(['promotes' => $promotes, 'setting' => $setting, 'month' => $month, 'base_game_id' => $baseGameId], true);
$addtime = time(); $addtime = time();
$data1 = [ $data1 = [
'logid' => 'pg_'.time(), 'logid' => 'pg_'.time(),
@ -4217,6 +4223,7 @@ public function iosDetailExcelInfo($id,$map) {
$promoteGradeService = new PromoteGradeService(); $promoteGradeService = new PromoteGradeService();
$records = $promoteGradeService->searchGradeByPromotes($map['promotes'], [ $records = $promoteGradeService->searchGradeByPromotes($map['promotes'], [
'month' => $map['month'], 'month' => $map['month'],
'base_game_id' => $map['base_game_id']
], $map['setting']); ], $map['setting']);
$xlsData = []; $xlsData = [];

@ -85,6 +85,7 @@ class PromoteGradeController extends BaseController
$records = $promoteGradeService->searchGradeByPromotes($promotes, [ $records = $promoteGradeService->searchGradeByPromotes($promotes, [
'month' => $month, 'month' => $month,
'base_game_id' => $baseGameId
], $setting); ], $setting);
if (I('p', 1) == 1) { if (I('p', 1) == 1) {

@ -105,7 +105,7 @@
</div> </div>
<div class="pagenation clearfix"> <div class="pagenation clearfix">
<?php if ($loginer['level'] !== 4) :?> <?php if ($loginer['level'] !== 4) :?>
<a id="sch-btn" href="{:U('download/promote_grade_export',array_merge(['parent_id'=>$parentId,'month'=>$month],I('post.')))}" class="ajax-get">导出</a> <a id="sch-btn" href="{:U('download/promote_grade_export',array_merge(['parent_id'=>$parentId,'month'=>$month, 'base_game_id' => I('base_game_id', 0)],I('post.')))}" class="ajax-get">导出</a>
<?php endif ;?> <?php endif ;?>
{$pagination} {$pagination}
</div> </div>

Loading…
Cancel
Save