新增测试资源统计

master
chenzhi 4 years ago
parent 1c150f290e
commit 2658c50c3a

@ -243,6 +243,95 @@ class TestingResourceController extends ThinkController
$this->assign('records', $records);
$this->display();
}
//每日统计
public function dailyCount()
{
$page = I('p', 1);
$row = I('row', 10);
$params = I('get.');
$where = $this->setDailyCountWhere($params);
$having = '1=1';
isset($params['apply_amount_start']) && !empty($params['apply_amount_start']) && ( $having .= ' and apply_amount >=' . $params['apply_amount_start']);
isset($params['apply_amount_end']) && !empty($params['apply_amount_end']) && ( $having .= ' and apply_amount <=' . $params['apply_amount_end']);
$isExport = $params['export'] ?? 0;
$query = M('testing_resource_batch','tab_')
->where($where)->field("FROM_UNIXTIME(create_time,'%Y-%m-%d') as create_day_time,user_id,role_id,game_id,apply_promote_id,apply_admin_id,verify_admin_id,sum(apply_amount) apply_amount,sum(provide_amount) provide_amount")
->group("role_id,game_id,create_day_time")
->order("create_day_time desc")
->having($having);
$countsql = clone $query;
if(empty($isExport)){
$dbdata= $query->page($page,$row)->select();
$count = M()->table('('.$countsql->select(false).') a')->count();
}else{
$dbdata= $query->select();
}
$repository = new TestingResourceRepository();
$records = $repository->makeDailyCountData($dbdata);
$pagination = set_pagination($count, $row);
$gameRepository = new GameRepository();
$gameId = $params['game_id'] ?? 0;
$this->assign('games', $gameRepository->getChoiceGames());
$this->assign('count', $count);
$this->assign('_page', $pagination);
$this->assign('records', $records);
$this->display();
}
protected function setDailyCountWhere($params)
{
$where['_string'] = '1 = 1';
isset($params['game_id']) && !empty($params['game_id']) && ($where['game_id'] = $params['game_id']);
isset($params['server_id']) && !empty($params['server_id']) && ($where['server_id'] = $params['server_id']);
if (isset($params['account']) && !empty($params['account'])) {
$user = M('user', 'tab_')->field(['id'])->where('account like "' . $params['account'] . '%"')->getField('id',true);
if (!empty($user)) {
$where['user_id'] = ['in',$user];
} else {
$where['_string'] .= ' and 1<>1';
return $where;
}
}
isset($params['create_time_start']) && !empty($params['create_time_start']) && ( $where['_string'] .= ' and create_time >=' . strtotime($params['create_time_start'] . ' 00:00:00'));
isset($params['create_time_end']) && !empty($params['create_time_end']) && ( $where['_string'] .= ' and create_time <=' . strtotime($params['create_time_end'] . ' 23:59:59'));
if (isset($params['role_name']) && !empty($params['role_name']) ) {
$roles = M('user_play_info', 'tab_')->where(['role_name' => ['like', "%{$params['role_name']}%"]])->getField('role_id',true);
if(!empty($roles)){
$where['role_id'] = ["in",$roles];
}else{
$where['_string'] .= ' and 1<>1';
return $where;
}
}
if (isset($params['apply_name']) && !empty($params['apply_name'])) {
$promote = M('promote', 'tab_')->where(['account' => ['like', "%{$params['apply_name']}%"]])->getField('id',true);
$applyAdmins = M('ucenter_member', 'sys_')->where(['username' => ['like', "%{$params['apply_name']}%"]])->getField('id',true);
if(empty($promote) && empty($applyAdmins)){
$where['_string'] .= ' and 1<>1';
return $where;
}
if(!empty($promote)){
$promote = implode(",",$promote);
if(empty($applyAdmins)){
$where['_string'] .= " and apply_promote_id in ({$promote })";
}else{
$where['_string'] .= " and ( apply_promote_id in ({$promote })";
}
}
if(!empty($applyAdmins)){
$applyAdmins = implode(",",$applyAdmins);
if(empty($promote)){
$where['_string'] .= " and apply_admin_id in ({$applyAdmins}) ";
}else{
$where['_string'] .= " or apply_admin_id in ({$applyAdmins}) )";
}
}
}
return $where;
}
public function orders()
{

@ -0,0 +1,302 @@
<extend name="Public/base"/>
<block name="css">
<link rel="stylesheet" href="__CSS__/select2.min.css" type="text/css" />
<link rel="stylesheet" href="__CSS__/promote.css" type="text/css"/>
<script src="__STATIC__/laydate/laydate.js"></script>
<link rel="stylesheet" type="text/css" href="__STATIC__/webuploader/webuploader.css" media="all">
<style>
.select2-container--open {
z-index: 1001;
}
.select2-container--default .select2-selection--single {
color: #000;
resize: none;
border-width: 1px;
border-style: solid;
border-color: #a7b5bc #ced9df #ced9df #a7b5bc;
box-shadow: 0px 3px 3px #F7F8F9 inset;height:35px;
height:28px;border-radius:3px;font-size:12px;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
line-height:35px;
line-height:28px;
}
.select2-container--default .select2-selection--single .select2-selection__arrow {
height:26px;
}
.select2-container--default .select2-search--dropdown .select2-search__field {
height:26px;line-height:26px;font-size:12px;
}
.select2-results__option[aria-selected] {font-size:12px;}
.textarea-style {
width: 200px;
height: 80px;
border-radius: 5px;
padding: 5px;
}
.mustmark {
color: #FF0000;
font-style: normal;
margin: 0 3px;
}
.clearfix:after {
content: "\20";
display: block;
height: 0;
clear: both;
}
.clearfix {
*zoom: 1;
}
.butnbox {
padding: 10px 0 10px;
}
.butnbox .butnlist .butn {
display: inline-block;
width: 120px;
height: 28px;
line-height: 28px;
text-align: center;
color: #FFF;
background: #3C95C8;
border-radius: 3px;
cursor: pointer;
}
.data_list table td .status-0 {
color: #e6a23c;
}
.data_list table td .status-1 {
color: #67c23a;
}
.data_list table td .status-2 {
color: #f56c6c;
}
</style>
</block>
<block name="body">
<script type="text/javascript" src="__JS__/bootstrap.min.js"></script>
<script type="text/javascript" src="__JS__/select2.min.js"></script>
<script type="text/javascript" src="__JS__/jquery.form.js"></script>
<script type="text/javascript" src="__STATIC__/uploadify/jquery.uploadify.min.js"></script>
<script src="__STATIC__/md5.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript" src="__STATIC__/webuploader/webuploader.js"></script>
<script src="__STATIC__/layer/layer.js" type="text/javascript"></script>
<script type="text/javascript" src="__STATIC__/layer/extend/layer.ext.js"></script>
<div class="cf main-place top_nav_list navtab_list">
<h3 class="page_title">测试资源申请统计</h3>
</div>
<div class="cf top_nav_list" style="height: 38px;">
<!-- 高级搜索 -->
<div class="jssearch cf search_list">
<div class="input-list search-title-box">
<label>搜索:</label>
</div>
<div class="input-list input-list-promote search_label_rehab">
<select id="game_id" name="game_id" class="select_gallery" style="width:120px;">
<option value="0">请选游戏</option>
<?php foreach($games as $game):?>
<option game-id="<?=$game['id']?>" value="<?=$game['id']?>"><?=$game['game_name']?></option>
<?php endforeach;?>
</select>
</div>
<div class="input-list input-list-promote search_label_rehab">
<select id="server_id" name="server_id" class="select_gallery" style="width:120px;">
<option value="">请选择区服</option>
</select>
</div>
<div class="input-list">
<input type="text" name="account" placeholder="测试账号" class="" value="" style="width: 150px">
</div>
<div class="input-list input-list-promote search_label_rehab">
<input type="text" readonly name="create_time_start" class="time-select" value="{:I('create_time_start')}"
placeholder="申请开始时间"/>
-
<div class="input-append date" id="datetimepicker" style="display:inline-block">
<input type="text" readonly name="create_time_end" class="time-select" value="{:I('create_time_end')}"
placeholder="申请结束时间"/>
<span class="add-on"><i class="icon-th"></i></span>
</div>
</div>
<div class="input-list">
<input style="width: 200px;" type="text" name="apply_name" class="search-input" value="{:I('apply_name')}" placeholder="请输入申请人">&nbsp;
</div>
<div class="input-list">
<input style="width: 200px;" type="text" name="role_name" class="search-input" value="{:I('role_name')}" placeholder="请输入角色名称">&nbsp;
</div>
<div class="input-list input-list-promote search_label_rehab">
<input type="text" name="apply_amount_start" value="{:I('apply_amount_start')}"
placeholder="请输入申请金额"/>
-
<div class="input-append date" style="display:inline-block">
<input type="text" name="apply_amount_end" value="{:I('apply_amount_end')}"
placeholder="请输入申请金额"/>
<span class="add-on"><i class="icon-th"></i></span>
</div>
</div>
<div class="input-list">
<a class="sch-btn" href="javascript:;" id="search" url="{:U('TestingResource/dailyCount')}">搜索</a>
</div>
</div>
</div>
<div class="butnbox"></div>
<!-- 数据列表 -->
<div class="data_list">
<div class="">
<table>
<!-- 表头 -->
<thead>
<tr>
<th width="125px">申请日期</th>
<th>角色名称</th>
<th>游戏名称</th>
<th>区服名称</th>
<th>测试账号</th>
<th>申请人</th>
<th>所属推广员</th>
<th>总申请金额</th>
<th>实发金额</th>
<th>操作</th>
</tr>
</thead>
<!-- 列表 -->
<tbody>
<empty name ="records">
<td colspan="99" class="text-center">aOh! 暂时还没有内容!</td>
<else />
<volist name="records" id="record" mod="2">
<tr data-id="{$record.id}" class="<eq name='mod' value='1'>odd</eq>">
<td style="word-wrap:break-word;">{$record.create_day_time}</td>
<td>{$record.role_name}</td>
<td>{$record.game_name}</td>
<td>{$record.server_name}</td>
<td>{$record.user_account}</td>
<td>{$record.apply_username}</td>
<td>{$record.promote_account}</td>
<td>{$record.apply_amount}</td>
<td>{$record.provide_amount}</td>
<td>
<a href="{$record.jump_url}">查看</a>
</td>
</tr>
</volist>
</empty>
</tbody>
</table>
</div>
</div>
<div class="page">
<!-- <a class="sch-btn export-btn"
href="{:U(CONTROLLER_NAME.'/'.ACTION_NAME,array_merge(['export'=>1],I('get.')))}" target="_blank">导出</a> -->
{$_page|default=''}
</div>
<div id="add-box" class="layer-box" style="display: none;">
<form method="post" enctype="multipart/form-data">
<div class="form-group">
<label>用户账号</label>
<div class="form-item" style="width:200px">
<select name="base_game_id" class="select_gallery" style="width:220px;">
<option value="0">游戏名称</option>
<?php foreach($baseGames as $baseGame):?>
<option value="<?=$baseGame['id']?>"><?=$baseGame['name']?></option>
<?php endforeach;?>
</select>
</div>
</div>
<div class="form-group">
<label>初始额度</label>
<div class="form-item" style="width:200px">
<input type="text" class="form-input" name="base_quota" style="width:200px" value="" placeholder="请输入初始额度">
</div>
</div>
<div class="form-group">
<label>奖金池比例</label>
<div class="form-item" style="width:200px">
<input type="text" class="form-input" name="rate" style="width:155px" value="" placeholder="请输入奖金池比例">&nbsp;&nbsp;%
</div>
</div>
<div class="form-group">
<label></label>
<a id="add-submit" href="javascript:;" class="add-submit btn">确定</a>
</div>
</form>
</div>
</block>
<block name="script">
<script src="__STATIC__/layer/layer.js" type="text/javascript"></script>
<script type="text/javascript" src="__STATIC__/layer/extend/layer.ext.js" ></script>
<script src="__STATIC__/jquery.cookie.js" charset="utf-8"></script>
<script>
<volist name=":I('get.')" id="vo">
Think.setValue('{$key}',"{$vo}");
</volist>
$(".select_gallery").select2();
</script>
<script type="text/javascript">
//导航高亮
highlight_subnav("{:U('TestingResource/dailyCount')}");
$(function(){
$('.time-select').each(function(){
laydate.render({
elem: this,
type: 'date'
});
});
//搜索功能
$("#search").click(function(){
var url = $(this).attr('url');
var query = $('.jssearch').find('input').serialize();
query += "&"+$('.jssearch').find('select').serialize();
//query = query.replace(/(&|^)(\w*?\d*?\-*?_*?)*?=?((?=&)|(?=$))/g,'');
query = query.replace(/^&/g,'');
if( url.indexOf('?')>0 ){
url += '&' + query;
}else{
url += '?' + query;
}
window.location.href = url;
});
//回车自动提交
$('.jssearch').find('input').keyup(function(event){
if(event.keyCode===13){
$("#search").click();
}
});
var game_server = "{:I('server_id')}";
$("#game_id").change(function () {
var game_id = $("#game_id option:selected").attr('game-id');
var str = "<option value=''>请选择区服</option>";
if(game_id){
$.ajax({
url: "{:U('Ajax/getServer')}",
type: "post",
data: { game_id: $("#game_id option:selected").attr('game-id') },
dataType: 'json',
success: function (data) {
for (var i in data){
str += "<option value='"+data[i].id+"' "+(game_server && data[i].id == game_server?'selected':'')+">"+data[i].server_name+"</option>"
}
$("#server_id").empty();
$("#server_id").append(str);
$("#server_id").select2();
}
})
}else{
$("#server_id").empty();
$("#server_id").append(str);
$("#server_id").select2();
}
})
$("#game_id").change();
});
</script>
</block>

@ -134,7 +134,7 @@ class TestingResourceRepository
return M('testing_resource_batch', 'tab_')->where($conditions)->order('create_time desc');
}
private function getBatchesRelations($batches)
public function getBatchesRelations($batches)
{
$roles = [];
$applyPromotes = [];
@ -226,6 +226,49 @@ class TestingResourceRepository
}
return $records;
}
public function makeDailyCountData($items)
{
$result = $this->getBatchesRelations($items);
$roles = $result['roles'];
$applyPromotes = $result['applyPromotes'];
$users = $result['users'];
$promotes = $result['promotes'];
$verifyAdmins = $result['verifyAdmins'];
$applyAdmins = $result['applyAdmins'];
//获取申请人
$records = [];
foreach ($items as $batch) {
$roleKey = $this->getGameRoleId($batch['game_id'], $batch['role_id']);
$role = isset($roles[$roleKey]) ? $roles[$roleKey] : null;
$user = $users[$batch['user_id']] ?? null;
$applyPromote = $applyPromotes[$batch['apply_promote_id']] ?? null;
$promote = $user && isset($promotes[$user['promote_id']]) ? $promotes[$user['promote_id']] : null;
$verifyAdmin = $verifyAdmins[$batch['verify_admin_id']] ?? null;
$applyAdmin = $applyAdmins[$batch['apply_admin_id']] ?? null;
$jumpParm = [
'game_id'=>$batch['game_id'],
'server_id'=>$batch['server_id'],
'account'=> $role ? $role['user_account'] : '',
'create_time_start'=>$batch['create_day_time'],
'create_time_end'=>$batch['create_day_time']
];
$jumpUrl = U("TestingResource/batches",$jumpParm);
$records[] = [
'create_day_time' => $batch['create_day_time'],
'role_name' => $role ? $role['role_name'] : '--',
'game_name' => $role ? $role['game_name'] : '--',
'server_name' => $role ? $role['server_name'] : '--',
'user_account' => $role ?$role['user_account'] : '--',
'apply_username' => $applyPromote ? $applyPromote['account'] . '[推广员]' : ($applyAdmin ? $applyAdmin['username'] . '[管理员]' : ''),
'promote_account' => $promote['account'],
'apply_amount' => $batch['apply_amount'],
'provide_amount' => $batch['provide_amount'],
'jump_url'=>$jumpUrl
];
}
return $records;
}
private function statByRoles($roles)

Loading…
Cancel
Save