Merge branch 'feature/group_type' into dev

master
zhengchanglong 5 years ago
commit 89d9b79930

@ -239,4 +239,38 @@ class AjaxController extends ThinkController{
}
$this->ajaxReturn(['code'=>1, 'msg'=>'获取成功', 'data'=>$lists]);
}
public function getDownstreamData() {
$withdraw_number = $_REQUEST['withdraw_number'];
$data = M("withdraw","tab_")
->field("widthdraw_number,promote_account,tab_promote_company.id as company_id,company_name,settlement_type,mobile_phone,real_name,bank_card,account_openin,address,game_ratio")
->join("left join tab_promote on tab_withdraw.promote_id=tab_promote.id")
->join("left join tab_promote_company on tab_promote.company_id=tab_promote_company.id")
->where(['widthdraw_number'=>$withdraw_number])
->find();
if ($data['settlement_type']==1) {
$data['settlement_type'] = '周结订单';
} else if($data['settlement_type']==2){
$data['settlement_type'] = '月结订单';
} else {
$data['settlement_type'] = '补点订单';
}
$data['game_ratio'] = json_decode($data['game_ratio'],true);
if (is_array($data['game_ratio'])) {
foreach ($data['game_ratio'] as $key=>&$value) {
foreach($value as $k => &$v) {
$v['game_name'] = get_gamename($key);
}
}
}
$this->ajaxReturn(['code'=>1, 'msg'=>'获取成功', 'data'=>$data]);
}
}

@ -8056,66 +8056,12 @@ class ExportController extends Controller
}
public function excelUpStreamTemplate() {
header("Content-type: text/html; charset=gb2312");
error_reporting(E_ALL);
ini_set('display_errors', TRUE);
ini_set('display_startup_errors', TRUE);
define('EOL',(PHP_SAPI == 'cli') ? PHP_EOL : '<br />');
date_default_timezone_set('Europe/London');
Vendor("PHPExcel.PHPExcel");
$objPHPExcel = new \PHPExcel();
$objReader = \PHPExcel_IOFactory::createReader('Excel5');
//设置模板文件
$objPHPExcel = $objReader->load("Runtime/upstream.xls");
$objPHPExcel->getActiveSheet()->setCellValue('D2', 'chengzhi');
$objPHPExcel->getActiveSheet()->insertNewRowBefore(10,1)->mergeCells('J10:K10')->insertNewRowBefore(10,1)->mergeCells('J10:K10');
ob_end_clean();//清除缓冲区,避免乱码
header('pragma:public');
header('Content-type:application/vnd.ms-excel;charset=utf-8;name="15415.xls"');
header("Content-Disposition:attachment;filename=15415.xls");//attachment新窗口打印inline本窗口打印
$objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
$objWriter->save('php://output');
exit;
excelUpStreamTemplate();
}
public function excelDownStreamTemplate() {
header("Content-type: text/html; charset=gb2312");
error_reporting(E_ALL);
ini_set('display_errors', TRUE);
ini_set('display_startup_errors', TRUE);
define('EOL',(PHP_SAPI == 'cli') ? PHP_EOL : '<br />');
date_default_timezone_set('Europe/London');
Vendor("PHPExcel.PHPExcel");
$objPHPExcel = new \PHPExcel();
$objReader = \PHPExcel_IOFactory::createReader('Excel5');
//设置模板文件
$objPHPExcel = $objReader->load("upstream.xls");
$objPHPExcel->getActiveSheet()->setCellValue('D2', 'chengzhi');
$objPHPExcel->getActiveSheet()->insertNewRowBefore(10,1);
ob_end_clean();//清除缓冲区,避免乱码
header('pragma:public');
header('Content-type:application/vnd.ms-excel;charset=utf-8;name="15415.xls"');
header("Content-Disposition:attachment;filename=15415.xls");//attachment新窗口打印inline本窗口打印
$objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
$objWriter->save('php://output');
exit;
excelDownStreamTemplate();
}

@ -0,0 +1,211 @@
<?php
namespace Admin\Controller;
/**
* cp/公会对账单
* @author yyh
*/
class StatementController extends ThinkController
{
public $mycompany = array(
"id" => 0,
"partner" => "海南万盟天下科技有限公司",
"link_man" => "雷丽华",
"link_phone" => "13067391751",
"address" => "福建省福州市鼓楼区福大怡山创业园区11号103",
"company_tax_no" => "1243245",
"payee_name" => "雷丽华",
"bank_account" => "1654654564364635456",
"opening_bank" => "福州市福大分行"
);
//创建
public function createCpStatement()
{
$this->display();
//获取cp推广公司
}
//获取推广公司基础信息
public function getCpCompanyInfo()
{
$CompanyId = $_REQUEST['company_id'];
if($CompanyId == 0){
$info = $this->mycompany;
}else{
$info = M("partner","tab_")->where("id = '{$CompanyId}'")->find();
}
if(empty($info)){
$this->ajaxReturn(array("error"=>"no find","code"=>2000));
}else{
$this->ajaxReturn(array("success"=>$info,"code"=>0));
}
}
//按时间-公司id-获取订单及分成比例
public function getSpendStatement()
{
$map["pay_status"] = 1;
$CompanyId = $_REQUEST['company_id']; //对账公司id
$statement_type = $_REQUEST['statement_type'];
$is_month = false;//是否是月结判断
if (isset($_REQUEST['time_start']) && isset($_REQUEST['time_end'])) {
//判断是否是月结
$tm = explode('-',$_REQUEST['time_start']);
$en = mktime(0,0,0,$tm[1]-0+1,1,$tm[0])-1; //当月最后一天时间戳
$en2 = strtotime($_REQUEST['time_end']) + 86399; //上传的订单时间
if($tm[2] == 1 && $en == $en2){
$is_month = true;
}
$map['pay_time'] = ['between', [strtotime($_REQUEST['time_start']), strtotime($_REQUEST['time_end']) + 86399]];
}
//获取对应cp公司的游戏
$game_list = M("game","tab_")->field("id")->where("partner_id = '{$CompanyId}'")->select();
if($game_list){
$map['game_id'] = ['in', implode(',', array_column($game_list,'id'))];
}
//获取统计
$list = M("Spend","tab_")->field('sum(pay_amount) pay_amount,game_id,game_name')->where($map)->group('game_id')->select();
$CpGameRatio = M("CpGameRatio","tab_");
$countarr = array(
"pay_amount"=>0,
"sum_money"=>0
);
foreach($list as $k=>&$v){
$map = array(
"game_id"=>$v['game_id'],
"begin_total_amount"=>0,
);
if($is_month){
$map['begin_total_amount'] = array("ELT",$v['pay_amount']);
};
$ratiores = $CpGameRatio->where($map)->order("begin_total_amount desc")->limit(1)->select();
if(empty($ratiores)){
$redio = 0;
}else{
$redio = $ratiores[0]['ratio'];
}
$v['second_ratio'] = $redio;
$v['first_ratio'] = (100-$redio);
if($statement_type == 0){
$v['sum_money'] = round($v['pay_amount']*$v['first_ratio']/100,2);
}else{
$v['sum_money'] = round($v['pay_amount']*$v['second_ratio']/100,2);
}
$countarr['pay_amount'] += $v['pay_amount'];
$countarr['sum_money'] += $v['sum_money'];
$v['fax_ratio'] = 0;
$v['promote_ratio'] = 0;
$v['statement_begin_time']=$_REQUEST['time_start'];
$v['statement_end_time']=$_REQUEST['time_end'];
$v['statement_type']=0;
}
$countarr['pay_amount'] = round($countarr['pay_amount'],2);
$countarr['sum_money'] = round($countarr['sum_money'],2);
$this->ajaxReturn(array("success"=>$list,"count"=>$countarr,"code"=>0));
}
//添加数据
public function doAddCpStatement(){
$second_party_info = $_REQUEST['second_party_info'];
$statement_info = $_REQUEST['statement_info'];
$statement_info[] = array(
"sum_money"=>$_REQUEST['fine'],
"type_name"=>"罚款",
"statement_type"=>1
);
//拼凑数据
$adddata = array(
"statement_type"=>0,
"company_id"=>$second_party_info['id'],
"company_name"=>$second_party_info['partner'],
"link_phone"=>$second_party_info['link_phone'],
"statement_begin_time"=>strtotime($_REQUEST['statement_begin_time']),
"statement_end_time"=>strtotime($_REQUEST['statement_end_time']),
'create_time'=>time(),
"statement_money"=>$_REQUEST['statement_count']['sum_money'],
"pay_amount"=>$_REQUEST['statement_count']['pay_amount'],
"is_confirm"=>0,
"pay_type"=>$_REQUEST['statement_type'] == 0 ? 1 :0,
"first_party_info"=>json_encode($_REQUEST['first_party_info'],JSON_UNESCAPED_UNICODE),
"second_party_info"=>json_encode($_REQUEST['second_party_info'],JSON_UNESCAPED_UNICODE),
"statement_info"=>json_encode($statement_info,JSON_UNESCAPED_UNICODE)
);
$res = M("statement","tab_")->add($adddata);
if($res){
$this->ajaxReturn(array("success"=>"ok","code"=>0));
}else{
$this->ajaxReturn(array("error"=>"database error","code"=>2000));
}
}
//测试数据
public function testData()
{
$mycompany = array(
"id" => 0,
"partner" => "甲方海南万盟天下科技有限公司",
"link_man" => "雷丽华",
"link_phone" => "13067391751",
"address" => "福建省福州市鼓楼区福大怡山创业园区11号103",
"company_tax_no" => "1243245",
"payee_name" => "雷丽华",
"bank_account" => "1423134654531321564561636",
"opening_bank" => "福州市福大分行"
);
$cpcompany = array(
"id" => 1,
"partner" => "乙方海南万盟天下科技有限公司",
"link_man" => "乙方雷丽华",
"link_phone" => "13067391752",
"address" => "福建省福州市鼓楼区福大怡山创业园区11号103",
"company_tax_no" => "1243245445646",
"payee_name" => "乙方王大锤",
"bank_account" => "2343254353462332423",
"opening_bank" => "福州市鼓楼区分行"
);
$statement =array(
array(
"pay_amount"=>10000,
"game_id"=>77,
"game_name"=>"帝王的纷争(安卓版)",
"second_ratio"=>40,
"first_ratio"=>60,
"promote_ratio"=>1,
"fax_ratio"=>1,
"sum_money"=>5880.6,
"statement_begin_time"=>"2019-11-01",
"statement_end_time"=>"2019-11-30",
"statement_type"=>0
),
array(
"sum_money"=>2000,
"type_name"=>"罚款",
"statement_type"=>1
)
);
$arr = array(
"statement_type"=>0,
"company_id"=>3,
"company_name"=>'福州品象网络科技有限公司',
"link_phone"=>'18959188422',
"statement_begin_time"=>'1572537600',
"statement_end_time"=>'1575129599',
'create_time'=>'1578397556',
"statement_money"=>3880.6,
"is_confirm"=>0,
"pay_type"=>0,
"first_party_info"=>json_encode($mycompany,JSON_UNESCAPED_UNICODE),
"second_party_info"=>json_encode($cpcompany,JSON_UNESCAPED_UNICODE),
"statement_info"=>json_encode($statement,JSON_UNESCAPED_UNICODE)
);
$res = M("statement","tab_")->add($arr);
dd($res);
}
}

@ -51,4 +51,41 @@ class StatementMangementController extends ThinkController
}
public function createDownstreamOrder() {
$this->display();
}
public function saveDownstreamOrder() {
$second_party_info = $_REQUEST['second_party_info'];
$first_party_info = $_REQUEST['first_party_info'];
$statement_info = $_REQUEST['statement_info'];
$sumData = $_REQUEST['sum_data'];
$insert['statement_type'] = 1;
$insert['company_id'] = $_REQUEST['company_id'];
$insert['company_name'] = $second_party_info['partner'];
$insert['link_phone'] = $second_party_info['link_phone'];;
$insert['statement_begin_time'] = 0;
$insert['statement_end_time'] = 0;
$insert['create_time'] = time();
$insert['statement_money'] =$sumData['statement_money'];
$insert['pay_amount'] = $sumData['pay_amount'];
$insert['ext_field'] = 0;
$insert['first_party_info'] = 0;
$insert['second_party_info'] = 0;
$insert['statement_info'] = 0;
dump(json_encode($second_party_info));
dump(json_encode($first_party_info));
dump(json_encode($statement_info));
}
}

@ -311,7 +311,9 @@
</if>
</td>
<td >
{$data.lock_remark}
<if condition="get_info_status($data['lock_status'],4) eq 锁定">
{$data.lock_remark}
</if>
</td>
<if condition="get_info_status($data['lock_status'],4) eq 锁定">
<td style="color:red;">已{:get_info_status($data['lock_status'],4)}</td>

@ -0,0 +1,792 @@
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<meta charset="UTF-8">
<title></title>
<link rel="stylesheet" type="text/css" href="__CSS__/base.css" media="all">
<link rel="stylesheet" type="text/css" href="__CSS__/common.css" media="all">
<link rel="stylesheet" type="text/css" href="__CSS__/style.css" media="all">
<link rel="stylesheet" type="text/css" href="__CSS__/default_color.css" media="all">
<link href="__STATIC__/datetimepicker/css/datetimepicker.css" rel="stylesheet" type="text/css">
<link href="__STATIC__/datetimepicker/css/dropdown.css" rel="stylesheet" type="text/css">
<link rel="stylesheet" href="__CSS__/select2.min.css" type="text/css" />
<script type="text/javascript" src="__STATIC__/jquery-2.0.3.min.js"></script>
<script type="text/javascript" src="__JS__/select2.min.js"></script>
<script type="text/javascript" src="__STATIC__/layer3/layer.js"></script>
<script type="text/javascript" src="__STATIC__/datetimepicker/js/bootstrap-datetimepicker.min.js"></script>
<script type="text/javascript" src="__STATIC__/datetimepicker/js/locales/bootstrap-datetimepicker.zh-CN.js"charset="UTF-8"></script>
<script src="__STATIC__/juicer-min.js" type="text/javascript"></script>
</head>
<style>
html {
min-width:100%;
}
body {
padding: 0px;
width: 960px;
margin: auto;
}
.tabcon1711 table{
width: 480px;
}
table{
margin: auto;
}
.hidebox{
display: none;
}
.r{
width: 300px;
}
.l{
width: 180px;
}
.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;
}
.input-list, .i_list {
float: left;
margin: 0;
}
</style>
<body>
<!-- <div style="width: 100%;line-height: 100px;font-size: 25px;font-weight: 600;text-align: center;">
海南万盟天下科技有限公司
</div> -->
<div style="display: flex;margin: auto;">
<div class="tab-content tabcon1711" id="firstPartBaseInfo">
<table border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="l">甲方:</td>
<td class="r">
<div class="input-list input-list-game search_label_rehab">
<select id="first_partner_id" name="partner_id" class="select_gallery">
<option value="0" selected>海南万盟天下科技有限公司</option>
</select>
</div>
</td>
</tr>
<tbody id="first_part_bser_info_show">
<tr>
<td class="l">联系人:</td>
<td class="r">
<input type="text" class="txt" name="link_man" value="" placeholder="请输入联系人">
</td>
</tr>
<tr>
<td class="l">联系电话:</td>
<td class="r">
<input type="text" class="txt" name="link_phone" value="" placeholder="请输入联系电话">
</td>
</tr>
<tr>
<td class="l">邮寄地址:</td>
<td class="r">
<input type="text" class="txt" name="address" value="" placeholder="请输入地址">
</td>
</tr>
<tr>
<td class="l">公司税号:</td>
<td class="r">
<input type="text" class="txt" name="company_tax_no" value="" placeholder="请输入公司税号">
</td>
</tr>
</tbody>
</tbody>
</table>
</div>
<div class="tab-content tabcon1711" id="secondPartBaseInfo">
<table border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="l">乙方:</td>
<td class="r">
<div class="input-list input-list-game search_label_rehab">
<select id="second_partner_id" name="partner_id" class="select_gallery">
<option value="">请选择合作公司</option>
<volist name=":getPartner()" id="vo">
<option partner-id="{$vo.id}" value="{$vo.id}" <if condition="$vo.id eq $_GET['partner_id']">selected=selected</if>>{$vo.partner}</option>
</volist>
</select>
</div>
</td>
</tr>
<tbody id="second_part_bser_info_show">
<tr>
<td class="l">联系人:</td>
<td class="r">
<input type="text" class="txt" name="link_man" value="" disabled="disabled" placeholder="请先选择合作公司">
</td>
</tr>
<tr>
<td class="l">联系电话:</td>
<td class="r">
<input type="text" class="txt" name="link_phone" value="" disabled="disabled" placeholder="请先选择合作公司">
</td>
</tr>
<tr>
<td class="l">邮寄地址:</td>
<td class="r">
<input type="text" class="txt" name="address" value="" disabled="disabled" placeholder="请先选择合作公司">
</td>
</tr>
<tr>
<td class="l">公司税号:</td>
<td class="r">
<input type="text" class="txt" name="company_tax_no" value="" disabled="disabled" placeholder="请先选择合作公司">
</td>
</tr>
</tbody>
</tbody>
</table>
</div>
</div>
<div style="padding: 30px 0px 10px;display: block;height:30px;">
<div class="input-list input-list-server search_label_rehab">
<p style="font-size: 20px;font-weight: 600;">支付给:</p>
</div>
<div class="input-list input-list-server search_label_rehab" style="margin-left: 20px;">
<select id="statement_type" name="statement_type" class="select_gallery" style="width: 215px;">
<option value="">请选择合作公司</option>
</select>
</div>
</div>
<div class="search_list" style="display: block;line-height: 30px;height: 10px;">
<div class="input-list input-list-server search_label_rehab">
<p>请选择需要生成结算订单的月份:</p>
</div>
<div class="input-list" style="margin-left: 20px;">
<input type="text" readonly id="time_start" name="time_start" class="" value="{:I('time_start')}"
placeholder="开始时间" />
&nbsp;-&nbsp;
<div class="input-append date" id="datetimepicker" style="display:inline-block">
<input type="text" readonly id="time_end" name="time_end" class="" value="{:I('time_end')}"
placeholder="结束时间" />
<span class="add-on"><i class="icon-th"></i></span>
</div>
</div>
<div class="input-list" style="margin-left: 30px;">
<a class="sch-btn" href="javascript:;" id="getSpendStatement" style="width: 100px;">生成</a>
</div>
</div>
<div class="data_list box_mt" style="margin-top: 40px;">
<div class="">
<table>
<!-- 表头 -->
<thead>
<tr>
<th rowspan="2" style="border-right: solid 1px #b6cad2;">结算时间</th>
<th rowspan="2" style="border-right: solid 1px #b6cad2;">产品</th>
<th rowspan="2" style="border-right: solid 1px #b6cad2;">平台总额</th>
<th colspan=2 style="border-right: solid 1px #b6cad2;">分成比例</th>
<th rowspan="2" style="border-right: solid 1px #b6cad2;">渠道费率</th>
<th rowspan="2" style="border-right: solid 1px #b6cad2;">税费费率</th>
<th >结算金额</th>
</tr>
<tr>
<th style="border-right: solid 1px #b6cad2;min-width: 50px;">甲方</th>
<th style="min-width: 50px;">乙方</th>
<th style="font-size: 10px;font-weight: 400;max-width: 100px;line-height: 1.2;">结算金额=平台总额*1-渠道费)*分成比例*(1-税费费率)</th>
</tr>
</thead>
<!-- 列表 -->
<tbody id="statementInit" class="">
<tr style="height: 100px;">
<td colspan=8>
请先选择生成条件后点击生成对账数据
</td>
</tr>
</tbody>
<tbody id="statementShow">
</tbody>
</table>
</div>
</div>
<div id="partpatinfo" style="display: flex;margin: auto;">
<div class="tab-content tabcon1711" id="skf_payinfo">
<table border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="l">收款方名称:</td>
<td class="r">
<input type="text" class="txt" name="" disabled="disabled" placeholder="请先选择支付给谁" value="">
</td>
</tr>
<tr>
<td class="l">银行账号:</td>
<td class="r">
<input type="text" class="txt" name="" value="" disabled="disabled" placeholder="请先选择支付给谁">
</td>
</tr>
<tr>
<td class="l">开户行:</td>
<td class="r">
<input type="text" class="txt" name="password" value="" disabled="disabled" placeholder="请先选择支付给谁">
</td>
</tr>
</tbody>
</table>
</div>
<div class="tab-content tabcon1711" id="fkf_payinfo">
<table border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="l">付款方名称:</td>
<td class="r">
<input type="text" class="txt" name="" value="" disabled="disabled" placeholder="请先选择支付给谁">
</td>
</tr>
<tr>
<td class="l">银行账号:</td>
<td class="r">
<input type="text" class="txt" name="password" value="" disabled="disabled" placeholder="请先选择支付给谁">
</td>
</tr>
<tr>
<td class="l">开户行:</td>
<td class="r">
<input type="text" class="txt" name="" value="" disabled="disabled" placeholder="请先选择支付给谁">
</td>
</tr>
</tbody>
</table>
</div>
</div>
<div class="search_list" style="position: fixed;justify-content:flex-end;width:960px;">
<div class="input-list" style="margin-left: 30px;float: right;">
<a class="sch-btn" href="javascript:;" id="createStatement" style="width: 150px;">生成对账单</a>
</div>
</div>
<script type="text/html" id="partbasetpl">
<tr>
<td class="l">联系人:</td>
<td class="r">
<input type="text" class="txt normalchange" data-change="${type}.link_man" name="link_man" value="${link_man|nonull}" placeholder="请输入联系人">
</td>
</tr>
<tr>
<td class="l">联系电话:</td>
<td class="r">
<input type="text" class="txt normalchange" name="link_phone" data-change="${type}.link_phone" value="${link_phone|nonull}" placeholder="请输入联系电话">
</td>
</tr>
<tr>
<td class="l">邮寄地址:</td>
<td class="r">
<input type="text" class="txt normalchange" name="address" data-change="${type}.address" value="${address|nonull}" placeholder="请输入地址">
</td>
</tr>
<tr>
<td class="l">公司税号:</td>
<td class="r">
<input type="text" class="txt normalchange" name="company_tax_no" data-change="${type}.company_tax_no" value="${company_tax_no|nonull}" placeholder="请输入公司税号">
</td>
</tr>
</script>
<script type="text/html" id="partpaytpl">
<div class="tab-content tabcon1711" id="skf_payinfo">
<table border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="l">收款方名称:</td>
<td class="r">
<input type="text" class="txt normalchange" placeholder="请输入收款方名称" data-change="${'skf'|setChange}.payee_name" name="payee_name" value="${skfdata.payee_name|nonull}">
</td>
</tr>
<tr>
<td class="l">银行账号:</td>
<td class="r">
<input type="text" class="txt normalchange" placeholder="请输入银行账号" name="bank_account" data-change="${'skf'|setChange}.bank_account" value="${skfdata.bank_account|nonull}">
</td>
</tr>
<tr>
<td class="l">开户行:</td>
<td class="r">
<input type="text" class="txt normalchange" placeholder="请输入开户行" data-change="${'skf'|setChange}.opening_bank" value="${skfdata.opening_bank|nonull}" name="opening_bank">
</td>
</tr>
</tbody>
</table>
</div>
<div class="tab-content tabcon1711" id="fkf_payinfo">
<table border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="l">付款方名称:</td>
<td class="r">
<input type="text" class="txt normalchange" placeholder="请输入付款方名称" data-change="${'fkf'|setChange}.payee_name" name="payee_name" value="${fkfdata.payee_name|nonull}">
</td>
</tr>
<tr>
<td class="l">银行账号:</td>
<td class="r">
<input type="text" class="txt normalchange" placeholder="请输入银行账号" data-change="${'fkf'|setChange}.bank_account" name="bank_account" value="${fkfdata.bank_account|nonull}" >
</td>
</tr>
<tr>
<td class="l">开户行:</td>
<td class="r">
<input type="text" class="txt normalchange" placeholder="请输入开户行" data-change="${'fkf'|setChange}.opening_bank" value="${fkfdata.opening_bank|nonull}" name="opening_bank">
</td>
</tr>
</tbody>
</table>
</div>
</script>
<script type="text/html" id="statementTpl">
{@each list as it,index}
<tr>
<td>${it.statement_begin_time}-${it.statement_end_time}</td>
<td>${it.game_name}</td>
<td>${it.pay_amount}元</td>
<td><input type="text" class="txt statementchange" name="first_ratio" data-index ="${index}" data-change="statement_info[${index}]['first_ratio']" value="${it.first_ratio}" style="width: 30px;">%</td>
<td><input type="text" class="txt statementchange" name="second_ratio" data-index ="${index}" data-change="statement_info[${index}]['second_ratio']" value="${it.second_ratio}" style="width: 30px;">%</td>
<td><input type="text" class="txt statementchange" name="promote_ratio" data-index ="${index}" data-change="statement_info[${index}]['promote_ratio']" value="${it.promote_ratio}" style="width: 30px;">%</td>
<td><input type="text" class="txt statementchange" name="fax_ratio" data-index ="${index}" data-change="statement_info[${index}]['fax_ratio']" value="${it.fax_ratio}" style="width: 30px;">%</td>
<td>${it.sum_money}元</td>
</tr>
{@/each}
<tr>
<td></td>
<td>罚款</td>
<td><input type="text" class="txt statementchange" name="fine" data-change="fine" value="${fine}" style="width: 50px;"></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>${fine}元</td>
</tr>
<tr>
<td>合计</td>
<td></td>
<td>${count.pay_amount}元</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>${count.sum_money}元</td>
</tr>
<tr>
<td colspan=7>本月分成总金额(人民币大写):</td>
<td>${count.sum_money|number_chinese}</td>
</tr>
</script>
<script>
$(function(){
TPLSHOW.juicerInit();
$(".select_gallery").select2();
$('#time_start').datetimepicker({
format: 'yyyy-mm-dd',
language: "zh-CN",
minView: 2,
autoclose: true
});
$('#datetimepicker').datetimepicker({
format: 'yyyy-mm-dd',
language: "zh-CN",
minView: 2,
autoclose: true,
pickerPosition: 'bottom-left'
})
EVENT.changeCompany();
EVENT.createStatement();
$("#first_partner_id").change();//默认甲方只能是我们公司
});
//基础类
var PUBLIC = {
postData(url,data,callback){
$.ajax({
url:url,
data:data,
type:"post",
dataType:"json",
success:function(data){
callback(data)
}
})
}
}
//数据类
var DATAOBJ = {
first_part_company:false,
second_part_company:false,
statement_type:false,
first_party_info:false,
second_party_info:false,
statement_info:false,
statement_count:false,
fine:0,
statement_begin_time:false,
statement_end_time:false
}
//事件类
var EVENT = {
changeCompany(){
$("#first_partner_id").on("change",function(){
//获取数据
var comid = $(this).find("option:selected").val();
//获取基础数据
var url = "{:U('getCpCompanyInfo')}";
PUBLIC.postData(url,{company_id:comid},function(data){
console.log(data);
DATAOBJ.first_part_company = data.success.partner;
DATAOBJ.first_party_info = data.success;
data.success.type = "first_party_info";
TPLSHOW.firstPartInfo(data.success);
})
})
$("#second_partner_id").on("change",function(){
//获取数据
var comid = $(this).find("option:selected").val();
//获取基础数据
var url = "{:U('getCpCompanyInfo')}";
PUBLIC.postData(url,{company_id:comid},function(data){
DATAOBJ.second_part_company = data.success.partner;
DATAOBJ.second_party_info = data.success;
data.success.type = "second_party_info";
TPLSHOW.secondPartInfo(data.success);
})
})
//生成订单
$("#getSpendStatement").on("click",function(){
//获取开始结束时间
var time_start = $("#time_start").val();
var time_end = $("#time_end").val();
if(time_start == '' || time_end == '' || DATAOBJ.statement_type === false){
layer.msg("收款方或账单开始结束时间均不允许为空");
return false;
}
if (Date.parse(time_start) > Date.parse(time_end)){
layer.msg('开始时间必须小于等于结束时间');
return false;
}
//发起查询
var selectData = {
"time_start":time_start,
"time_end":time_end,
"statement_type":DATAOBJ.statement_type,
"company_id": $("#second_partner_id").find("option:selected").val()
}
var url = "{:U('getSpendStatement')}";
PUBLIC.postData(url,selectData,function(data){
DATAOBJ.statement_begin_time = time_start;
DATAOBJ.statement_end_time = time_end;
DATAOBJ.statement_info = data.success;
DATAOBJ.statement_count = data.count;
TPLSHOW.showStatementList(true);
})
})
},
createStatement(){
$("#createStatement").on("click",function(){
//验证信息
for (const key in DATAOBJ) {
if(DATAOBJ[key] === false){
layer.msg('页面中的参数均是必填项目,请先填满');
return false;
}
}
//验证甲方信息
for (const key in DATAOBJ.first_party_info) {
var t = DATAOBJ.first_party_info;
if(t[key] ===''){
layer.msg('甲方信息不全,请先补全 code:'+key);
return false;
}
if(key == "link_phone" && !CHECK.mobile.test(t[key])){
layer.msg('甲方联系人手机号格式错误');
return false;
}
if(key == "bank_account" && !CHECK.BankNo.test(t[key])){
layer.msg('甲方银行卡号格式错误');
return false;
}
}
//乙方
for (const key in DATAOBJ.second_party_info) {
var t = DATAOBJ.second_party_info;
if(!t[key] || t[key] ==''){
layer.msg('乙方信息不全,请先补全 code:'+key);
return false;
}
if(key == "link_phone" && !CHECK.mobile.test(t[key])){
layer.msg('乙方联系人手机号格式错误');
return false;
}
if(key == "bank_account" && !CHECK.BankNo.test(t[key])){
layer.msg('乙方银行卡号格式错误');
return false;
}
}
layer.load(2);
$("#createStatement").off("click");//自我解绑
PUBLIC.postData("{:U('doAddCpStatement')}",DATAOBJ,function(data){
if(data.success){
layer.closeAll('loading');
layer.msg('添加成功');
setTimeout(function(){
window.parent.reload();
},350);
}else{
alert("添加失败,请联系管理员")
}
});
//发送添加请求
})
},
normalchange(){
$(".normalchange").off("blur");
$(".normalchange").on("blur",function(){
var val = $(this).val();
var index = $(this).data("change");
var str = "DATAOBJ."+index+"='"+val+"';";
eval(str);
})
},
statementchange(){
$(".statementchange").off("blur");
$(".statementchange").on("blur",function(){
var sort = $(this).data("change");
var val = $(this).val();
if(!CHECK.number.test(val)){
layer.msg('结算单中的罚款和税率必须是数字');
$(this).val(0);
return false;
}
var str = "DATAOBJ."+sort+"='"+val+"';";
if(sort != 'fine'){
eval(str);
var index = $(this).data("index");
var td = DATAOBJ.statement_info[index];
if( $(this).attr("name") == "first_ratio"){
td['second_ratio'] = 100-val;
}
if( $(this).attr("name") == "second_ratio"){
td['first_ratio'] = 100-val;
}
if(DATAOBJ.statement_type == 0){
var ratio = td['first_ratio']/100;
}else{
var ratio = td['second_ratio']/100;
}
DATAOBJ.statement_count['sum_money'] -= td['sum_money'];
td['sum_money'] = Math.floor((td['pay_amount']*(100-td['promote_ratio'])/100*ratio*(100-td['fax_ratio'])/100)* 100) / 100 ;
DATAOBJ.statement_count['sum_money']+=(td['sum_money']-0);
}else{
DATAOBJ.fine = Math.floor(DATAOBJ.fine * 100) / 100 ;
if(val > DATAOBJ.statement_count['sum_money']){
layer.msg('罚款金额过大,总计不允许为负数');
$(this).val(DATAOBJ.fine);
return false;
}
DATAOBJ.statement_count['sum_money'] = (DATAOBJ.statement_count['sum_money'] -0+DATAOBJ.fine);
DATAOBJ.statement_count['pay_amount'] = (DATAOBJ.statement_count['pay_amount'] -0+DATAOBJ.fine);
eval(str);
DATAOBJ.statement_count['sum_money'] = DATAOBJ.statement_count['sum_money']-DATAOBJ.fine;
DATAOBJ.statement_count['pay_amount'] = DATAOBJ.statement_count['pay_amount']-DATAOBJ.fine;
}
DATAOBJ.statement_count['pay_amount'] = Math.floor(DATAOBJ.statement_count['pay_amount'] * 100) / 100 ;
DATAOBJ.statement_count['sum_money'] = Math.floor(DATAOBJ.statement_count['sum_money'] * 100) / 100;
TPLSHOW.showStatementList(true);
})
},
changeStatementType(){
$("#statement_type").off("change")
$("#statement_type").on("change",function(){
//获取数据
var statement_type = $(this).find("option:selected").val();
if(statement_type == ''){
statement_type = false;
}
DATAOBJ.statement_type = statement_type;
//获取账单信息
TPLSHOW.showStatementList(false);
TPLSHOW.showPartPayInfo();
})
$(".select_gallery").select2();
}
}
var CHECK = {
number: /^\d+(\.{1}\d+)?$/,
mobile:/^1[3456789]\d{9}$/,
BankNo:/^([1-9]{1})(\d{15}|\d{18})$/,
money:/((^[1-9]\d*)|^0)(\.\d{0,2}){0,1}$/
}
//
var TPLSHOW = {
juicerInit(){
var nonull = function(data) {
if(!data){
return '';
}
return data;
};
var setChange = function(typestr) {
if(DATAOBJ.statement_type == 0){
if(typestr == "fkf"){
return 'second_party_info';
}else{
return 'first_party_info';
}
}else{
if(typestr == "fkf"){
return 'first_party_info';
}else{
return 'second_party_info';
}
}
};
var number_chinese = function (str) {
var num = parseFloat(str);
var strOutput = "",
strUnit = '仟佰拾亿仟佰拾万仟佰拾元角分';
num += "00";
var intPos = num.indexOf('.');
if (intPos >= 0){
num = num.substring(0, intPos) + num.substr(intPos + 1, 2);
}
strUnit = strUnit.substr(strUnit.length - num.length);
for (var i=0; i < num.length; i++){
strOutput += '零壹贰叁肆伍陆柒捌玖'.substr(num.substr(i,1),1) + strUnit.substr(i,1);
}
return strOutput.replace(/零角零分$/, '整').replace(/零[仟佰拾]/g, '零').replace(/零{2,}/g, '零').replace(/零([亿|万])/g, '$1').replace(/零+元/, '元').replace(/亿零{0,3}万/, '亿').replace(/^元/, "零元")
}
juicer.register('nonull', nonull);
juicer.register('setChange', setChange);
juicer.register('number_chinese', number_chinese);
},
//
firstPartInfo(data){
var tpl =$("#partbasetpl").html();
var html = juicer(tpl, data);
$("#first_part_bser_info_show").html(html);
TPLSHOW.pushStatementTypeOption();
},
secondPartInfo(data){
var tpl =$("#partbasetpl").html();
var html = juicer(tpl, data);
$("#second_part_bser_info_show").html(html);
TPLSHOW.pushStatementTypeOption();
},
//支付给公司
pushStatementTypeOption(){
EVENT.normalchange();
DATAOBJ.statement_type = false;//重新选择
TPLSHOW.showStatementList(false);
if(DATAOBJ.first_part_company && DATAOBJ.second_part_company){
var str = "<option value=''>请选择合作公司</option><option value='0' >"+DATAOBJ.first_part_company+"</option>";
str += ("<option value='1' selected>"+DATAOBJ.second_part_company+"</option>");//默认支付给乙方
$("#statement_type").html(str);
EVENT.changeStatementType();
$("#statement_type").change();//默认支付给乙方
// TPLSHOW.showPartPayInfo();//查看底下是否有值
}
},
//支付信息显示
showPartPayInfo(){
var data = {};
if(DATAOBJ.statement_type !== false){
if(DATAOBJ.statement_type == 1){
data.fkfdata = DATAOBJ.first_party_info;
data.skfdata = DATAOBJ.second_party_info;
}else{
data.skfdata = DATAOBJ.first_party_info;
data.fkfdata = DATAOBJ.second_party_info;
}
data.type = DATAOBJ.statement_type;
}else{
data.skfdata = {};
data.fkfdata = {};
}
var tpl =$("#partpaytpl").html();
var html = juicer(tpl, data);
$("#partpatinfo").html(html);
EVENT.normalchange();
},
//订单信息显示
showStatementList(flag){
if(flag){
var data = {list:DATAOBJ.statement_info,count:DATAOBJ.statement_count,fine:DATAOBJ.fine};
$("#statementInit").addClass("hidebox");
var tpl =$("#statementTpl").html();
var html = juicer(tpl, data);
$("#statementShow").html(html);
EVENT.statementchange();
}else{
DATAOBJ.statement_info = false;
DATAOBJ.statement_count = false;
DATAOBJ.fine = 0;
$("#statementInit").removeClass("hidebox");
$("#statementShow").html('');
}
}
}
</script>
</body>
</html>

@ -0,0 +1,406 @@
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<meta charset="UTF-8">
<title>充值查询列表|----软件管理平台</title>
<link href="http://admin.vlcms.com/Public/icon.ico" type="image/x-icon" rel="shortcut icon">
<link rel="stylesheet" type="text/css" href="__CSS__/base.css" media="all">
<link rel="stylesheet" type="text/css" href="__CSS__/common.css" media="all">
<link rel="stylesheet" type="text/css" href="__CSS__/module.css">
<link rel="stylesheet" type="text/css" href="__CSS__/style.css" media="all">
<link rel="stylesheet" type="text/css" href="__CSS__/default_color.css" media="all">
<script type="text/javascript" src="__STATIC__/jquery-2.0.3.min.js"></script>
<script type="text/javascript" src="__JS__/jquery.mousewheel.js"></script>
</head>
<style>
body {
padding: 0px;
}
.input-list, .i_list {
/*float: none;*/
margin: 0;
}
.search_list>div {
margin-top: 9px;
line-height: 40px;
}
</style>
<body>
<div id="main" class="main" style="min-height: 342px;width: 92.5%;">
<script src="__STATIC__/layer/layer.js" type="text/javascript"></script>
<link rel="stylesheet" type="text/css" href="__CSS__/admin_table.css" media="all">
<script type="text/javascript" src="__STATIC__/uploadify/jquery.uploadify.min.js"></script>
<div class="cf top_nav_list" style="height: 250px;margin-left: 5px">
<!-- 高级搜索 -->
<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" style="width: 50%;">
提现单号:
<select id="ext_field" name="ext_field" class="select_gallery" style="width: 50%">
<option value="">提现单号</option>
<volist name=":getWithdrawNumber()" id="vo">
<option value="{$vo.widthdraw_number}" <if condition="$vo eq $_GET['count_date']">selected=selected</if>>{$vo.widthdraw_number}</option>
</volist>
</select>
</div>
<div class="input-list input-list-promote search_label_rehab" style="width: 50%">
银行账号:
<input type="text" readonly id="bank_card" name="bank_card" class="" value="" placeholder="银行账号" style="width: 50%"/>
</div>
<div class="input-list input-list-promote search_label_rehab" style="width: 50%">
乙 方:&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
<select disabled="disabled" id="company_name" name="company_name" class="select_gallery" style="width: 50%">
<option value="">乙 方</option>
<volist name=":getCompanyList()" id="vo">
<option company_id="{$vo.id}" value="{$vo.company_name}">{$vo.company_name}</option>
</volist>
</select>
</div>
<div class="input-list input-list-promote search_label_rehab" style="width: 50%">
开 户 行:&nbsp;
<input type="text" id="account_openin" name="account_openin" class="" value="" placeholder="开户行" style="width: 50%"/>
</div>
<div class="input-list input-list-promote search_label_rehab" style="width: 50%">
订单类型:&nbsp;
<input type="text" name="settlement_type_value" id="settlement_type_value" style="display: none" value="默认"/>
<span style="width: 50%" id="settlement_type">默认</span>
</select>
</div>
<div class="input-list input-list-promote search_label_rehab" style="width: 50%">
邮寄地址:
<input type="text" id="address" name="address" class="" value="" placeholder="邮寄地址" style="width: 50%"/>
</div>
<div class="input-list input-list-promote search_label_rehab" style="width: 50%">
联 系 人:&nbsp;&nbsp;&nbsp;
<input type="text" id="real_name" name="real_name" class="" value="" placeholder="联系人" style="width: 50%"/>
</div>
<div class="input-list input-list-promote search_label_rehab" style="width: 50%">
开票项目:
<input type="text" id="invoice_item" name="invoice_item" class="" value="信息技术服务费" placeholder="信息技术服务费" style="width: 50%"/>
</div>
<div class="input-list input-list-promote search_label_rehab" style="width: 50%">
联系电话:&nbsp;&nbsp;
<input type="text" id="mobile_phone" name="mobile_phone" class="" value="{:I('time_start')}" placeholder="请输入联系电话" style="width: 50%"/>
</div>
<div class="input-list input-list-promote search_label_rehab" style="width: 50%">
发票类型:
<input type="text" id="invoice_type" name="invoice_type" class="" value="增值税专用发票" placeholder="增值税专用发票" style="width: 50%"/>
</div>
</div>
</div>
<!-- 数据列表 -->
<div class="data_list box_mt" style="margin-top: 30px">
<div class="">
<table>
<!-- 表头 -->
<thead>
<tr>
<th>结算时间</th>
<th>合作产品</th>
<th >平台总额</th>
<th>分成比例</th>
<th>税费费率</th>
<th >结算金额(元)</th>
</thead>
<!-- 列表 -->
<tbody style="overflow: hidden;height: 300px" class="getData">
<if condition = "empty($list_data)">
<tr>
<td colspan="16" class="text-center">aOh! 暂时还没有内容!</td>
</tr>
</if>
<volist name="list_data" id="data">
<tr>
</tr>
</volist>
</tbody>
</table>
</div>
</div>
<div class="cf top_nav_list" style="height: 250px;margin-left: 5px">
<!-- 高级搜索 -->
<div class="wesearch cf search_list" >
<!-- <div class="input-list search-title-box">-->
<!-- <label>乙方:</label>-->
<!-- </div>-->
<div class="input-list input-list-promote search_label_rehab" style="width: 100%;">
甲方:&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
<input type="text" id="jfCompany" name="jfCompany" class="" value="海南万盟天下科技有限公司" style="width: 30%;display: none"/>
<span>海南万盟天下科技有限公司</span>
</div>
<div class="input-list input-list-promote search_label_rehab" style="width: 100%;">
联系人:&nbsp;&nbsp;&nbsp;
<input type="text" id="jfPerson" name="jfPerson" class="" value="雷丽华" placeholder="雷丽华" style="width: 30%"/>
</div>
<div class="input-list input-list-promote search_label_rehab" style="width: 100%;">
联系电话:
<input type="text" id="jfTel" name="jfTel" class="" value="13067391751" placeholder="13067391751" style="width: 30%"/>
</div>
</div>
</div>
<div class="cf top_nav_list" style="width:50px;position: relative;top: -160px;left: 60%;">
<!-- 高级搜索 -->
<div class="jssearch fl cf search_list">
<div class="input-list">
<a class="sch-btn" href="javascript:;" id="search" url="{:U('Query/marketList','model='.$model['name'] .'&row='.I('row'),false)}" style="width: 120px">生成结算订单</a>
</div>
</div>
</div>
<div class="page">
{$_page|default=''}
</div>
</div>
<script type="text/javascript">
$(function(){
var queryData = [];
var statement = [];
var key = 0;
// $("#tax").change(function () {
// console.log(1)
// console.log($(this).next());
// })
//搜索功能
$("#ext_field").change(function(){
var ext_field = $("#ext_field").val();
console.log(ext_field);
$("tbody").empty();
$("#company_name").val("");
$("#settlement_type").text("");
$("#bank_card").val("");
$("#account_openin").val("");
$("#address").val("");
$("#real_name").val("");
$("#mobile_phone").val("");
$("tbody").append('<tr>\n' +
' <td colspan="16" class="text-center">aOh! 暂时还没有内容!</td>\n' +
' </tr>');
if (ext_field)
$.ajax({
url:"{:U('Ajax/getDownstreamData')}",
type:"get",
data:{withdraw_number:ext_field},
dataType:'json',
success:function(data){
console.log($("#company_name option:selected").attr('company-type'))
$("#company_name").val(data.data.company_name);
$("#settlement_type").text(data.data.settlement_type);
$("#bank_card").val(data.data.bank_card);
$("#account_openin").val(data.data.account_openin);
$("#address").val(data.data.address);
$("#real_name").val(data.data.real_name);
$("#mobile_phone").val(data.data.mobile_phone);
$("#settlement_type_value").val(data.data.settlement_type);
var game_ratio = data.data.game_ratio;
var str = '';
var sumAmount = 0;
var sum = 0;
for(var p in game_ratio){
for(var i in game_ratio[p]) {
queryData['pay_amount'] = game_ratio[p][i].sum_amount;
queryData['game_id'] = p;
queryData['game_name'] = game_ratio[p][i].game_name;
queryData['sum_money'] = (game_ratio[p][i].sum_amount*(game_ratio[p][i].selle_ratio/100)).toFixed(2);
queryData['statement_begin_time'] = game_ratio[p][i].begin_time;
queryData['statement_end_time'] = game_ratio[p][i].end_time;
queryData['second_ratio'] = game_ratio[p][i].selle_ratio;
queryData['fax_ratio'] = 0;
statement.push(queryData);
queryData=[];
// game_name = "<?php echo get_gamename('"+game_id+"')?>";
sumAmount=sumAmount+parseFloat(game_ratio[p][i].sum_amount);
str+="<tr class='statement_data_"+key+"'><td class='time_"+key+"' begin_time='"+game_ratio[p][i].begin_time+"' end_time='"+game_ratio[p][i].end_time+
"'>"+game_ratio[p][i].begin_time+"-"+game_ratio[p][i].end_time+"</td>" +
"<td class='game_name_"+key+"' game_id='"+p+"'>"+game_ratio[p][i].game_name+"</td>" +
"<td class='pay_amount_"+key+"'>"+game_ratio[p][i].sum_amount+"</td>" +
"<td class='second_ratio_"+key+"' second_ratio='"+game_ratio[p][i].selle_ratio+"'>"+game_ratio[p][i].selle_ratio+"%</td>" +
"<td><input value='0' style='width: 30px' class='tax_"+key+"'/>%</td>" +
"<td id='sum_"+key+"' data-value='"+(game_ratio[p][i].sum_amount*(game_ratio[p][i].selle_ratio/100)).toFixed(2)+"'>"+(game_ratio[p][i].sum_amount*(game_ratio[p][i].selle_ratio/100)).toFixed(2)+"</td></tr>";
sum = sum +parseFloat((game_ratio[p][i].sum_amount*(game_ratio[p][i].selle_ratio/100)).toFixed(2));
key++;
}
}
str+="<tr class=''><td>-</td><td>罚款</td>" +
"<td><input value='0' style='width: 30px' class='forfeit'/></td>" +
"<td>-</td>" +
"<td>-</td>" +
"<td>0</td>" +
"</tr>" +
"<tr><td>合计</td>" +
"<td>---</td>" +
"<td class='sumAmount' data-value='"+sumAmount+"'>"+sumAmount+"</td>" +
"<td>-</td>" +
"<td>-</td>" +
"<td class='sumAll' data-value='"+sum+"'>"+sum+"</td>" +
"</tr>"+
"<tr><td colspan='3'>\n" +
"本月分成总金额(人民币大写)</td>" +
"<td>-</td>" +
"<td>-</td>" +
"<td data-value='"+sum+"'>"+number_chinese(sum)+"</td>" +
"</tr>";
$("tbody").empty();
$("tbody").append(str);
eventnew();
}
})
});
function eventnew(){
$(".tax").off("blur");
$(".tax").on("blur", function() {
$(this).parent().next().text(($(this).parent().next().attr('data-value')*(1-$(this).val()/100)).toFixed(2));
$(".sumAll").text((($(".sumAll").attr('data-value')-$(this).parent().next().attr('data-value')+$(this).parent().next().attr('data-value')*(1-$(this).val()/100))-($(".forfeit").val())).toFixed(2));
});
$(".forfeit").off("blur");
$(".forfeit").on("blur", function() {
var lastNumber = $(this).parent().next().next().next().text();
$(this).parent().next().next().next().text($(this).val());
$(".sumAmount").text($(".sumAmount").attr("data-value")-$(this).val());
$(".sumAll").text((parseFloat($(".sumAll").text())+parseFloat(lastNumber)-parseFloat($(this).val())).toFixed(2));
});
}
$("#search").click(function(){
var query = $('.jssearch').find('input').serializeArray();
var weQuery = $('.wesearch').find('input').serializeArray();
query = $.merge(query,$('.jssearch').find('select').serializeArray());
// query = $.merge(query,weQuery);
// console.log(statement)
var ext_field = '';
var second_party_info = {};
var first_party_info = {};
var statement_info = {};
var pushStatement = [];
var sumData = {};
var company_id = $("#company_name option:selected").attr('company_id');
ext_field=$("ext_field").val();
console.log(ext_field)
second_party_info['partner'] = $("#company_name").val();
second_party_info["bank_account"] = $("#bank_card").val();
second_party_info["opening_bank"] = $("#account_openin").val();
// if ($("#settlement_type_value").val()=='周结订单') {
// second_party_info['settlement_type'] = 1;
// } else if ($("#settlement_type_value").val()=='月结订单') {
// second_party_info['settlement_type'] = 2;
// } else {
// second_party_info['settlement_type'] = 3;
// }
second_party_info['settlement_type'] = $("#settlement_type_value").val();
second_party_info['address'] = $("#address").val();
second_party_info['link_man'] = $("#real_name").val();
second_party_info['link_phone'] = $("#mobile_phone").val();
second_party_info['invoice_item'] = $("#invoice_item").val();
second_party_info['invoice_type'] = $("#invoice_type").val();
first_party_info['jfCompany'] = $("#jfCompany").val();
first_party_info['jfPerson'] = $("#jfPerson").val();
first_party_info['jfTel'] = $("#jfTel").val();
var i = 0;
for(i=0;i<key;i++) {
var _this = $(".statement_data_"+i);
statement_info['statement_begin_time'] = _this.children().attr('begin_time');
statement_info['statement_end_time'] = _this.children().attr('end_time');
statement_info['game_id'] = _this.children().next().attr('game_id');
statement_info['game_name'] = $(".statement_data_"+i+' .game_name_'+i).text();
statement_info['pay_amount'] = $(".statement_data_"+i+' .pay_amount_'+i).text();
statement_info['sum_money'] = $(".statement_data_"+i+' #sum_'+i).text();
statement_info['fax_ratio'] = $(".statement_data_"+i+' .tax_'+i).val();
statement_info['second_ratio'] = $(".statement_data_"+i+' .second_ratio_'+i).attr('second_ratio');
statement_info['statement_type'] = 0;
pushStatement.push(statement_info);
statement_info = {};
// console.log(statement_info);
}
var forfeit = {};
forfeit['type_name'] = '罚款';
forfeit['sum_money'] = $('.forfeit').val();
forfeit['statement_type'] = 1;
pushStatement.push(forfeit);
// console.log(pushStatement);
sumData['statement_money'] = $(".sumAll").text();
sumData['pay_amount'] = $(".sumAmount").text();
console.log(sumData)
$.ajax({
url: "{:U('StatementMangement/saveDownstreamOrder')}",
type: "post",
data: {"second_party_info": second_party_info,"first_party_info":first_party_info,
"statement_info":pushStatement,"sum_data":sumData,"ext_field":ext_field,"company_id":company_id},
dataType: 'json',
success: function (data) {
}
});
});
})
function number_chinese(str) {
var num = parseFloat(str);
var strOutput = "",
strUnit = '仟佰拾亿仟佰拾万仟佰拾元角分';
num += "00";
var intPos = num.indexOf('.');
if (intPos >= 0){
num = num.substring(0, intPos) + num.substr(intPos + 1, 2);
}
strUnit = strUnit.substr(strUnit.length - num.length);
for (var i=0; i < num.length; i++){
strOutput += '零壹贰叁肆伍陆柒捌玖'.substr(num.substr(i,1),1) + strUnit.substr(i,1);
}
return strOutput.replace(/零角零分$/, '整').replace(/零[仟佰拾]/g, '零').replace(/零{2,}/g, '零').replace(/零([亿|万])/g, '$1').replace(/零+元/, '元').replace(/亿零{0,3}万/, '亿').replace(/^元/, "零元")
}
</script>
</body>
</html>

@ -38,6 +38,13 @@
.butnbox .butnlist .butn.last {background:#009900;}
.butnbox .butnlist .butn~.butn {margin-left:20px;}
.data_list table tbody tr a.disabled,.data_list table tbody tr a.disabled:hover {color:#999;cursor:default;}
.layui-layer-title {
text-align: center;
height: 80px;
line-height: 80px;
font-weight: 600;
font-size: 18px;
}
</style>
<div class="cf main-place top_nav_list navtab_list">
@ -170,7 +177,10 @@
</script>
<script type="text/javascript">
//导航高亮
highlight_subnav('{:U('Query/marketList')}');
highlight_subnav("{:U('Query/marketList')}");
function reload() {
window.location.reload();
}
$(function(){
//搜索功能
var start = $("#time_start").val();
@ -185,22 +195,22 @@
$("#upstream").click(function () {
layer.open({
type: 2,
title: "【游戏角色】列表",
title: "海南万盟天下科技有限公司",
shadeClose: true,
shade: 0.8,
area: ['70%', '80%'],
content: ['/admin.php?s=/Member/role_list/' , 'no']
content:'/admin.php?s=/Statement/createCpStatement/'
});
});
$("#downstream").click(function () {
layer.open({
type: 2,
title: "【游戏角色】列表",
title: "海南万盟天下科技有限公司",
shadeClose: true,
shade: 0.8,
area: ['70%', '80%'],
content: ['/admin.php?s=/Member/role_list/' , 'no']
content: '/admin.php?s=/statementMangement/createDownstreamOrder/'
});
});

@ -963,6 +963,29 @@ CREATE TABLE `tab_promote_belong` (
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='推广公会归属管理';
-- cp/公会对账单 2020-1-7 陈志
CREATE TABLE `tab_statement` (
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '自增主键',
`statement_type` tinyint(2) DEFAULT '0' COMMENT '对账类型(0-上游对账单;1-下游对账单)',
`company_id` int(11) DEFAULT '0' COMMENT '对账公司id',
`company_name` varchar(60) NOT NULL COMMENT '对账公司名称',
`link_phone` varchar(24) DEFAULT NULL COMMENT '对账公司联系人电话',
`statement_begin_time` int(11) NOT NULL DEFAULT '0' COMMENT '对账开始时间',
`statement_end_time` int(11) NOT NULL DEFAULT '0' COMMENT '对账截止时间',
`create_time` int(11) NOT NULL DEFAULT '0' COMMENT '创建对账单时间',
`statement_money` decimal(10,2) DEFAULT '0.00' COMMENT '对账金额',
`pay_amount` decimal(10,2) DEFAULT '0.00' COMMENT '平台金额合计(已减罚款)',
`is_confirm` tinyint(2) DEFAULT '0' COMMENT '是否确认(0-未确认;1-确认)',
`pay_type` tinyint(2) DEFAULT '0' COMMENT '收款方(0-甲方付给乙方,乙方收款;1-乙方付给甲方,甲方收款)',
`ext_field` varchar(50) DEFAULT '' COMMENT '扩展字段,如果是下游为提现单号',
`first_party_info` longtext NOT NULL COMMENT '甲方相关信息json',
`second_party_info` longtext NOT NULL COMMENT '乙方相关信息json',
`statement_info` longtext NOT NULL COMMENT '订单相关信息json',
PRIMARY KEY (`id`),
KEY `statement_type` (`statement_type`),
KEY `company_id` (`company_id`),
KEY `link_phone` (`link_phone`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='cp/公会对账单';
-- 2020-01-02
-- 提现结算类型 cxj

Loading…
Cancel
Save