You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

2661 lines
130 KiB
HTML

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

<extend name="Public/base" />
<block name="css">
<link rel="stylesheet" type="text/css" href="__CSS__/admin_table.css" media="all">
<link rel="stylesheet" type="text/css" href="__STATIC__/webuploader/webuploader.css" media="all">
<style>
#form .txt_area.download_url {width:400px;}
.tabcon1711 .table_radio2 .table_btn {width:215px;}
.bnt_add,.bnt_remove,.bnt_save{
height: 30px;
width: 20px;
font-size: 20px;
line-height: 10px;
color: #3399ff;
background: none;
border: none;
margin-left: 20px;
cursor: pointer;
}
.bnt_remove{
color: #F70909;
}
.bnt_save{
color: #4DB361;
}
</style>
</block>
<block name="body">
<script src="__STATIC__/layer/layer.js" type="text/javascript"></script>
<script src="__STATIC__/layer/extend/layer.ext.js" type="text/javascript"></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>
<!-- 标签页导航 -->
<div class="tab-wrap">
<div class="cf main-place top_nav_list navtab_list">
<ul class="tabnav1711 fr jstabnav">
<li data-tab="tab1" class="current"><a href="javascript:void(0);">基础信息</a></li>
<notempty name='show_status'>
<li data-tab="tab2" ><a href="javascript:void(0);">下载设置</a></li>
</notempty>
<li data-tab="tab3" ><a href="javascript:void(0);">参数配置</a></li>
<li data-tab="tab4" ><a href="javascript:void(0);">H5分享页面</a></li>
<li data-tab="tab5" ><a href="javascript:void(0);">用户等级设置</a></li>
<li data-tab="tab6" ><a href="javascript:void(0);">推广配置</a></li>
</ul>
<h3 class="page_title">编辑游戏【{$data.relation_game_name}】</h3>
<p class="description_text">说明:查看和编辑游戏的基础信息、下载设置、参数信息等。</p>
</div>
<div class="tab-content tabcon1711">
<!-- 表单 -->
<form id="form" action="{:U('edit')}" method="post" class="form-horizontal">
<!-- 基础 -->
<div id="tab1" class="tab-pane in tab1">
<table border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="l">游戏名称:</td>
<td class="r" >
<input type="text" class="txt " name="game_name" value="{$data['game_name']}" placeholder="请输入游戏名称" readonly="true">
<input type="hidden" name="game_appid" value="{$data['game_appid']}">
</td>
</tr>
<tr>
<td class="l">游戏原包名称:</td>
<td class="r" >
<input type="text" class="txt " name="original_package_name" value="{$data['original_package_name']}" placeholder="请输入游戏原包名称">
</td>
</tr>
<tr>
<td class="l">游戏类型:</td>
<td class="r">
<select id="game_type_id" name="game_type_id">
<volist name=":get_game_type_all()" id="vo">
<if condition="$vo[id] eq $data[game_type_id]">
<option value="{$vo.id}" selected>{$vo.type_name}</option>
<else />
<option value="{$vo.id}">{$vo.type_name}</option>
</if>
</volist>
</select>
<input type="hidden" id="game_type_name" name="game_type_name" value="{$data['game_type_name']}">
</td>
</tr>
<tr>
<td class="l noticeinfo">运营平台</td>
<td class="r table_radio">
<span class="form_radio table_btn">
<volist name=":get_systems_list('cnce')" id="vo">
<eq name="data.sdk_version" value="$key">
<label><input type="radio" class="inp_radio js-device" value="{$key}" name="sdk_version" checked > {$vo}</label>
</eq>
</volist> </span>
<span class="notice-text">显示该游戏所适用的平台,一般为安卓平台和苹果平台</span>
</td>
</tr>
<tr>
<td class="l noticeinfo">混服设置</td>
<td class="r table_radio">
<span class="form_radio table_btn">
<label>
<eq name="data.server_type" value="1">
<input type="radio" class="inp_radio" value="1" name="server_type" checked> 专服
<else/>
<input type="radio" class="inp_radio" value="2" name="server_type" checked> 混服
</eq>
</label>
</span>
<span class="notice-text"></span>
</td>
</tr>
<tr>
<td class="l noticeinfo">开放类型</td>
<td class="r table_radio">
<span class="form_radio table_btn">
<volist name=":get_opentype_all()" id="vo">
<label>
<input type="radio" class="inp_radio" value="{$vo.id}" name="category">
<eq name="data.category" value="$vo['id']"> checked </eq> > {$vo.open_name}
</label>
</volist></span>
<span class="notice-text">显示当前游戏的开放状态一般为公测删档内测不删档内测等。主要APP上显示</span>
</td>
</tr>
<tr>
<td class="l noticeinfo">显示状态</td>
<td class="r table_radio">
<span class="form_radio table_btn">
<label><eq name="data['game_status']" value="0">关闭<else/>开启</eq>
</label>
</span>
<span class="notice-text">设置该游戏是否在各个站点显示</span>
</td>
</tr>
<tr>
<td class="l noticeinfo">显示站点</td>
<td class="r table_radio">
<span class="form_radio table_btn">
<label>
<input type="checkbox" class="inp_radio" value="1" name="display_site[]" > PC官网
</label>
<label>
<input type="checkbox" class="inp_radio" value="2" name="display_site[]" > WAP站
</label>
<label>
<input type="checkbox" class="inp_radio" value="3" name="display_site[]" > 游戏盒子APP
</label></span>
<span class="notice-text">控制游戏在不同平台上是否进行展示,可多选,默认为全部站点显示。取消选择后,对应站点上不显示该游戏的所有数据(含礼包与开服信息)</span>
</td>
</tr>
<tr>
<td class="l noticeinfo">推荐状态</td>
<td class="r table_radio">
<span class="form_radio table_btn">
<label>
<input type="radio" class="inp_radio" value="0" name="recommend_status" <eq name="data['recommend_status']" value="0">checked="checked"</eq>> 不推荐
</label>
<label>
<input type="radio" class="inp_radio" value="1" name="recommend_status" <eq name="data['recommend_status']" value="1">checked="checked"</eq>> 推荐
</label>
<label>
<input type="radio" class="inp_radio" value="2" name="recommend_status" <eq name="data['recommend_status']" value="2">checked="checked"</eq>> 热门
</label>
<label>
<input type="radio" class="inp_radio" value="3" name="recommend_status" <eq name="data['recommend_status']" value="3">checked="checked"</eq>> 最新
</label></span>
<span class="notice-text">设置游戏的推荐类型,更改此游戏在网站所属的推荐板块;</span>
</td>
</tr>
<tr>
<td class="l">游戏排序:</td>
<td class="r">
<input type="text" class="txt" name="sort" value="{$data['sort']}" placeholder="请输入游戏排序如1">
</td>
</tr>
<tr>
<td class="l">游戏下载数:</td>
<td class="r">
<input type="text" class="txt table_btn_input" name="dow_num" value="{$data['dow_num']}" readonly="true" style="background:#e7e7e7">
<a id="dow_num_click" class="table_click" href="javascript:">点击修改</a>
</td>
</tr>
<tr>
<td class="l">游戏评分:</td>
<td class="r">
<input type="text" class="txt" name="game_score" value="{$data['game_score']}" placeholder="请输入0-10数字">
</td>
</tr>
<tr>
<td class="l">游戏首字母:</td>
<td class="r">
<input type="text" class="txt" name="short" value="{$data['short']}" readonly="true" placeholder="例如荒莽纪,输入HMJ">
</td>
</tr>
<empty name='show_status'>
<tr>
<td class="l" >一句话简介:</td>
<td class="r" colspan="3">
<input type="text" class="txt " name="features" value="{$data['features']}" placeholder="输入一句话简介">
</td>
</tr>
<else/>
<tr>
<td class="l" >一句话简介:</td>
<td class="r" >
<input type="text" class="txt " name="features" value="{$data['features']}" placeholder="输入一句话简介">
</td>
</tr>
<tr>
<td class="l" >游戏开发商:</td>
<td class="r" >
<input type="text" class="txt " name="dev_name" value="{$data['dev_name']}" placeholder="输入开发商名称">
</td>
</tr>
</empty>
<tr>
<td class="l" >合作方:</td>
<td class="r" >
<select id="partner_id" name="partner_id">
<option value="">请选择合作方</option>
<volist name=":getPartnerList()" id="vo">
<option value="{$vo.id}"
<eq name="data.partner_id" value="$vo.id"> selected </eq>>{$vo.partner}
</option>
</volist>
</select>
</td>
</tr>
<tr>
<td class="l">游戏简介:</td>
<td class="r">
<textarea name="introduction" class="txt_area">{$data['introduction']}</textarea>
</td>
</tr>
<tr>
<td class="l">游戏资料中心:</td>
<td class="r">
<textarea name="content" class="txt_area">{$data['detail_content']}</textarea>
{:hook('adminArticleEdit', array('name'=>'content','value'=>$field['value']))}
</td>
</tr>
<tr class="picbox">
<td class="l noticeinfo" >游戏ICON</td>
<td class="r">
<!-- <span class="table_btn table_upload">
<input type="file" id="upload_picture_icon">
<input type="hidden" name="icon" id="cover_id_icon" value="{$data.icon}" />
<div class="upload-img-box">
<notempty name="data['icon']">
<div class="upload-pre-item">
<span class="placeholder-graphic placeholder-graphic_icon"><img src="{$data['icon']|get_cover='path'}"/></span>
</div>
</notempty>
</div>
</span>-->
<span class="table_btn table_upload table_icon" style="float: none;">
<input type="hidden" name="icon" value="{$data['icon']}" />
<div id="uploadImg" class="wu-example">
<div class="btns">
<div id="icon">
<div class="webuploader-pick" style="line-height:13px">上传图标</div>
</div>
</div>
<!--用来存放文件信息-->
<div id="icon_thelist" class="uploader-list" style="display: flex;">
</div>
</div>
</span>
<span class="notice-text">尺寸不得小于125*125px大小不得超过50K</span>
</td>
</tr>
<tr class="picbox">
<td class="l noticeinfo">游戏素材包</td>
<td class="r">
<span class="table_btn table_upload">
<div id="uploader" class="wu-example">
<div class="btns">
<div id="picker" style="width: auto;float: left;margin-right: 20px;">上传素材包</div>
</div>
<!--用来存放文件信息-->
<div id="thelist" class="uploader-list" style="float: left;">
<!-- <span id="up_status">
<notempty name="data.material_url">已上传</notempty>
</span> -->
<notempty name="data.material_url">
<?php $name = substr($data['material_url'],strripos($data['material_url'],'/',0)+1); ?>
<div id="beforeupload" class="item">
<h4 class="info">{$name}<a href="javascript:;" class="jsdelzip table_click" style="float:none;display:inline-block;margin-left:10px;">删除</a></h4>
</div>
</notempty>
</div>
</div>
<input type="hidden" id="file_url" name="material_url" value="{$data['material_url']}"/>
</span>
<span class="notice-text">此处可上传该游戏的素材包,必须为压缩包形式,用于渠道后台下载推广</span>
</td>
</tr>
<tr class="picbox">
<td class="l noticeinfo">游戏推荐图</td>
<td class="r">
<span class="table_btn table_upload">
<!-- <input type="file" id="upload_picture_cover">
<input type="hidden" name="cover" id="cover_id_cover" value="{$data.cover}" />
<div class="upload-img-box">
<notempty name="data['cover']">
<div class="upload-pre-item">
<span class="placeholder-graphic placeholder-graphic_ad"><img src="{$data['cover']|get_cover='path'}"/></span>
</div>
</notempty>-->
<span class="table_btn table_upload table_cover" style="float: none;">
<input type="hidden" name="cover" value="{$data['cover']}" />
<div id="uploadImg" class="wu-example">
<div class="btns">
<div id="cover">
<div class="webuploader-pick" style="line-height:13px">上传图片</div>
</div>
</div>
<!--用来存放文件信息-->
<div id="cover_thelist" class="uploader-list" style="display: flex;">
</div>
</div>
</span>
</div>
</span>
<span class="notice-text">470*350px用于官网首屏推荐游戏位展示</span>
</td>
</tr>
<tr class="picbox">
<td class="l noticeinfo" >游戏截图</td>
<td class="r">
<!-- <span class="table_btn table_upload table_screenshot" style="float: none;">
{:hook('UploadImages', array('name'=>'screenshot','value'=>$data['screenshot'],'flag'=>true))}
</span>-->
<span class="table_btn table_upload table_screenshot" style="float: none;">
<input type="hidden" name="screenshot" value="{$data['screenshot']}" />
<div id="uploadImg" class="wu-example">
<div class="btns">
<div id="screenshot">
<div class="webuploader-pick" style="line-height:13px">上传图片</div>
</div>
</div>
<!--用来存放文件信息-->
<div id="screenshot_thelist" class="uploader-list" style="display: flex;">
</div>
</div>
</span>
<span class="notice-text">建议尺寸750*1334图片大小不超过3M</span>
</td>
</tr>
<tr class="picbox">
<td class="l noticeinfo" >落地页图片</td>
<td class="r">
<span class="table_btn table_upload table_flooring_page_imgs" style="float: none;">
<input type="hidden" name="flooring_page_imgs" value="{$data['flooring_page_imgs']}" />
<div id="uploadImg" class="wu-example">
<div class="btns">
<div id="flooring_page_imgs">上传图片</div>
</div>
<!--用来存放文件信息-->
<div id="flooring_page_imgs_thelist" class="uploader-list" style="display: flex;">
</div>
</div>
</span>
<span class="notice-text">横版游戏建议尺寸1691280*720px及以上竖版游戏建议尺寸916720*1280px及以上用于游戏详情页内展示</span>
</td>
</tr>
<tr class="picbox">
<td class="l noticeinfo">落地页视频</td>
<td class="r">
<span class="table_btn table_upload">
<div id="uploaderVideo" class="wu-example">
<div class="btns">
<div id="pickerVideo" style="width: auto;float: left;margin-right: 20px;">上传视频</div>
</div>
<!--用来存放文件信息-->
<div id="video_thelist" class="uploader-list" style="float: left;">
<!-- <span id="up_status">
<notempty name="data.material_url">已上传</notempty>
</span> -->
<notempty name="data.flooring_page_video">
<?php $name = substr($data['flooring_page_video'],strripos($data['flooring_page_video'],'/',0)+1); ?>
<div id="beforeuploadvideo" class="item">
<h4 class="info">{$name}<a href="javascript:;" class="jsdelvideo table_click" style="float:none;display:inline-block;margin-left:10px;">删除</a></h4>
<video src="{$data['flooring_page_video']}" controls width="150px"></video>
</div>
</notempty>
</div>
</div>
<input type="hidden" id="video_url" name="flooring_page_video" value="{$data['flooring_page_video']}"/>
</span>
<span class="notice-text">视频大小不能超过20M支持格式mp4,3gp,wmv,asf,asx,mov,m4v,avi,flv,qlv</span>
</td>
</tr>
<tr class="picbox">
<td class="l noticeinfo" >落地页视频封面</td>
<td class="r">
<span class="table_btn table_upload table_icon" style="float: none;">
<input type="hidden" name="flooring_page_video_cover" value="{$data['flooring_page_video_cover']}" />
<div id="uploadImg" class="wu-example">
<div class="btns">
<div id="flooring_page_video_cover">
<div class="webuploader-pick" style="line-height:13px">上传封面</div>
</div>
</div>
<!--用来存放文件信息-->
<div id="flooring_page_video_cover_thelist" class="uploader-list" style="display: flex;">
</div>
</div>
</span>
<span class="notice-text">安卓视频封面 图片大小不得超过1M 图片比例610 * 343</span>
</td>
</tr>
<tr>
<td class="l">ios视频是否置顶</td>
<if condition="$data['ios_video_top'] eq 1">
<td class="r" >
<span class="form_radio table_btn">
<label>
<input type="radio" class="inp_radio" value="0" name="ios_video_top" > 不置顶
</label>
<label>
<input type="radio" class="inp_radio" value="1" name="ios_video_top" checked="checked"> 置顶
</label></span>
</td>
<else/>
<td class="r" >
<span class="form_radio table_btn">
<label>
<input type="radio" class="inp_radio" value="0" name="ios_video_top" checked="checked"> 不置顶
</label>
<label>
<input type="radio" class="inp_radio" value="1" name="ios_video_top" > 置顶
</label></span>
</td>
</if>
</tr>
<notempty name="data.accredit_img">
<tr class="picbox">
<td class="l noticeinfo">知识产权</td>
<td class="r">
<span class="table_btn table_upload">
<div class="upload-img-box">
<div class="upload-pre-item">
<span class="placeholder-graphic placeholder-graphic_ad"><img src="{$data['accredit_img']|get_cover='path'}"/></span>
</div>
</div>
</span>
</td>
</tr>
</notempty>
</tbody>
</table>
</div>
<!-- 下载 -->
<notempty name='show_status'>
<div id="tab2" class="tab-pane tab2 ">
<table border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="l">游戏名称:</td>
<td class="r" >
<input type="text" class="txt " name="game_name_copy" value="{$data['game_name']}" placeholder="请输入游戏名称" disabled="disabled">
</td>
</tr>
<tr>
<td class="l">运营平台:</td>
<td class="r" >
<span class="form_radio table_btn">
<volist name=":get_systems_list('cecn')" id="vo">
<gt name="key" value="0">
<label>
<input type="radio" class="inp_radio js-device js-devices{$key}" value="{$key}" name="sdk_version_copy" <if condition="$key eq $data['sdk_version']"> checked </if> disabled='true'> {$vo}
</label>
</gt>
</volist></span>
</td>
</tr>
<tr>
<td class="l">下载状态:</td>
<if condition="$data['dow_status'] eq 1">
<td class="r" >
<span class="form_radio table_btn">
<label>
<input type="radio" class="inp_radio" value="0" name="dow_status" > 关闭
</label>
<label>
<input type="radio" class="inp_radio" value="1" name="dow_status" checked="checked"> 开启
</label></span>
</td>
<else/>
<td class="r" >
<span class="form_radio table_btn">
<label>
<input type="radio" class="inp_radio" value="0" name="dow_status" checked="checked"> 关闭
</label>
<label>
<input type="radio" class="inp_radio" value="1" name="dow_status" > 开启
</label></span>
</td>
</if>
</tr>
<tr>
<td class="l">下载端口:</td>
<td class="r" >
<span class="form_radio table_btn" style="width:414px;">
<label>
<input type="radio" class="inp_radio" value="1" name="down_port" <eq name="data['down_port']" value="1">checked="checked"</eq>> 官方原包
</label>
<label>
<input type="radio" class="inp_radio" value="2" name="down_port" <eq name="data['down_port']" value="2">checked="checked"</eq>> 第三方链接
</label>
</span>
<span class="notice-text" style="line-height:1.3;">选择“第三方链接”后推广员后台-游戏列表-申请游戏页面将不显示该游戏,推广员无法进行申请。</span>
</td>
</tr>
<tr style="<eq name='data.down_port' value='2'>display:table-row;<else />display:none;</eq>">
<td class="l noticeinfo" ><i class="mustmark" style="margin-left:-13px">*</i>
第三方下载地址(<span id='span_type'>安卓</span>)
</td>
<td class="r">
<textarea name="add_game_address" id="game_address" class="download_url txt_area">{$data['add_game_address']}</textarea>
<!-- <span class="notice-text">游戏第三方下载链接,设置后官网游戏下载端口启用第三方链接;不可获取数据,不可进行渠道分包。</span> -->
</td>
</tr>
<tr style="<eq name='data.down_port' value='2'>display:table-row;<else />display:none;</eq>">
<td class="l noticeinfo" ><i class="mustmark" style="margin-left:-13px">*</i>
第三方原包大小
</td>
<td class="r"><input type="text" class="txt2" id="game_address_size" value="{$data['game_address_size']}" name="game_address_size" placeholder="请输入第三方原包大小"> </td>
</tr>
<?php if($data['sdk_version'] == 2):?>
<tr>
<td class="l">超级签Token</td>
<td class="r" >
<input type="text" class="txt " name="supersign_token" value="{$data['supersign_token']}" placeholder="请输入超级签Token" >
</td>
</tr>
<tr>
<td class="l">超级签URL</td>
<td class="r" >
<input type="text" class="txt " name="supersign_url" value="{$data['supersign_url']}" placeholder="请输入超级签URL" >
</td>
</tr>
<tr>
<td class="l" >极速版链接:</td>
<td class="r" colspan="3">
<input type="text" class="txt " name="beta_url" value="{$data['beta_url']}" placeholder="请输入极速版下载链接">
</td>
</tr>
<tr>
<td class="l">下载方式</td>
<td class="r" >
<span class="form_radio table_btn">
<label>
<input type="checkbox" class="inp_radio" value="4" name="download_ways[]" <?php if(($data['download_ways'] & 4) == 4):?>checked<?php endif;?>> 至尊下载
</label>
<label>
<input type="checkbox" class="inp_radio" value="2" name="download_ways[]" <?php if(($data['download_ways'] & 2) == 2):?>checked<?php endif;?>> 极速下载
</label>
<label>
<input type="checkbox" class="inp_radio" value="1" name="download_ways[]" <?php if(($data['download_ways'] & 1) == 1):?>checked<?php endif;?>> 普通下载
</label>
</span>
</td>
</tr>
<?php endif;?>
</tbody>
</table>
</div>
</notempty>
<!-- 设置 -->
<div id="tab3" class="tab-pane tab3">
<table border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="l noticeinfo">推广充值CPS比例</td>
<td class="r">
<input type="text" class="txt table_text_input" name="ratio" value="{$data['ratio']}" placeholder="输入0-100之间的数字"><span class="form_unit">%</span>
<span class="notice-text">此处比例为推广结算时CPS模式的分成比例</span>
</td>
</tr>
<tr>
<td class="l noticeinfo">推广注册CPA单价</td>
<td class="r">
<input type="text" class="txt table_text_input" name="money" value="{$data['money']}" placeholder="请输入大于0的数字"><span class="form_unit"></span>
<span class="notice-text">此处数值为推广结算时CPA模式的注册单价</span>
</td>
</tr>
<tr class="bns">
<td class="l noticeinfo">CP分成比例</td>
<td class="r">
<input type="hidden" class="txt table_text_input" name="game_amount" value="0" >
<input type="text" class="txt table_text_input" name="game_ratio" value="{$game_ratio[0]['ratio']}" placeholder="输入0-100之间的数字">
<span class="form_unit">% <button type="button" class="bnt_save" data-id ="{$game_ratio[0]['id']}" data-type="initial" style="display: none"></button> </span>
<span class="notice-text">CP游戏分成比例</span>
</td>
</tr>
<empty name="game_ratio[1]">
<tr class="bns">
<td class="l noticeinfo">CP总流水</td>
<td class="r">
<select name="instanceof" style="width: 50px;margin-right: 5px" >
<option value="1"></option>
<option value="2">></option>
</select>
<input type="text" class="txt table_text_input" name="game_amount" value="" placeholder="" style="width: 55px">
<span class="form_unit" style="margin: 0 10px">分成比例</span>
<input type="text" class="txt table_text_input" name="game_ratio" value="" placeholder="" style="width: 50px">
<span class="form_unit">% </span>
<button type="button" class="bnt_add"></button><button type="button" class="bnt_save" data-id="0" data-type="ladder" style="display: none"></button>
</td>
</tr>
<else />
<foreach name="game_ratio" item="vo" key="k">
<if condition="$k gt 0">
<tr class="bns">
<td class="l noticeinfo">CP总流水</td>
<td class="r">
<select name="instanceof" style="width: 50px;margin-right: 5px" >
<option value="1" <if condition="$vo['instanceof'] eq 1"> selected </if>>≥</option>
<option value="2" <if condition="$vo['instanceof'] eq 2"> selected </if>>></option>
</select>
<input type="text" class="txt table_text_input" name="game_amount" value="{$vo['begin_total_amount']}" placeholder="" style="width: 55px"><span class="form_unit" style="margin: 0 10px">分成比例</span>
<input type="text" class="txt table_text_input" name="game_ratio" value="{$vo['ratio']}" placeholder="" style="width: 50px"><span class="form_unit">%</span>
<if condition="$k eq 1">
<button type="button" class="bnt_add"></button>
<button type="button" class="bnt_remove" data-id="{$vo['id']}"></button>
<else/>
<button type="button" class="bnt_remove" data-id="{$vo['id']}"></button>
</if>
<button type="button" class="bnt_save" data-id="{$vo['id']}" data-type="ladder" style="display: none"></button>
</td>
</tr>
</if>
</foreach>
</empty>
<tr>
<td class="l noticeinfo">开发者分成比例</td>
<td class="r">
<input type="text" class="txt table_text_input" name="dratio" value="{$data['dratio']}" placeholder="请输入0-100之间的数字"><span class="form_unit">%</span>
<span class="notice-text">此处比例为开发者结算时的分成比例</span>
</td>
</tr>
<!-- <tr>
<td class="l noticeinfo">会长代充折扣比例</td>
<td class="r">
<input type="text" class="txt table_text_input" name="discount" value="{$data['discount']}" placeholder="请输入0-10之间的数字"><span class="form_unit">折</span>
<span class="notice-text">设置该游戏的统一折扣,推广员后台会长代充时使用</span>
</td>
</tr>
<tr>
<td class="l noticeinfo">绑币充值折扣</td>
<td class="r">
<input type="text" class="txt table_text_input" name="bind_recharge_discount" value="{$data['bind_recharge_discount']}" placeholder="请输入0-10数字"><span class="form_unit">折</span>
<span class="notice-text">设置APP游戏的绑币统一折扣APP充时绑币时使用</span>
</td>
</tr> -->
<tr>
<td class="l noticeinfo">扶持额度</td>
<td class="r">
<input type="text" class="txt table_text_input" name="support_quota" value="{$data['support_quota']}" placeholder="请输入数字"><span class="form_unit"></span>
<span class="notice-text"> &nbsp&nbsp设置游戏扶持额度</span>
</td>
</tr>
<tr>
<td class="l noticeinfo">扶持比例</td>
<td class="r">
<input type="text" class="txt table_text_input" name="support_ratio" value="{$data['support_ratio']}" placeholder="请输入0-100之间的数字"><span class="form_unit">%</span>
<span class="notice-text">设置游戏扶持比例</span>
</td>
</tr>
<tr>
<td class="l noticeinfo">ios版支付方式</td>
<td class="r table_radio table_radio2">
<span class="table_btn">
<label>
<input type="radio" class="inp_radio" value="1" name="appstatus" <if condition="$data['appstatus'] eq 1"> checked</if>> 第三方支付
</label>
<label>
<input type="radio" class="inp_radio" value="0" name="appstatus" <if condition="$data['appstatus'] eq 0"> checked</if> > 苹果内购
</label></span>
<span class="notice-text" style="line-height:1.4;width:68%;">iOS上架版游戏内支付方式的配置开关二选一默认是第三方支付非上架版在系统-扩展工具-支付设置内进行配置同Android版</span>
<!-- <span class="notice-text" style="line-height:1.4;width:68%;">ios版游戏内的支付方式二选一默认是第三方支付。上架版选择第三方支付则为wap支付选择苹果内购则为苹果内购非上架版选择第三方支付则为wap支付选择苹果内购则为app支付。金猪支付下支付宝始终是app支付订单充值方式记录为支付宝其它皆为wap支付订单充值方式记录为金猪支付</span> -->
</td>
</tr>
<tr>
<td class="l noticeinfo">支付宝</td>
<td class="r table_radio">
<span class="form_select">
<select name="pay_config[zfb]">
<option value="gf" <?php echo $data['pay_config']['zfb'] == 'gf' ? "selected" : ''; ?>>官方</option>
<option value="sq" <?php echo $data['pay_config']['zfb'] == 'sq' ? "selected" : ''; ?>>双乾</option>
</select>
</span>
</td>
</tr>
<tr>
<td class="l noticeinfo">微信</td>
<td class="r table_radio">
<span class="form_select">
<select name="pay_config[wx]">
<option value="gf" selected="selected">官方</option>
</select>
</span>
</td>
</tr>
<tr>
<td class="l noticeinfo">快捷支付</td>
<td class="r table_radio">
<span class="form_select">
<select name="pay_config[quick]">
<option value="sq" selected="selected">双乾</option>
</select>
</span>
</td>
</tr>
<tr>
<td class="l noticeinfo">是否开启强更</td>
<td class="r table_radio table_radio2">
<span class="table_btn">
<label>
<input type="radio" class="inp_radio" value="1" name="is_force_update" <if condition="$data['is_force_update'] eq 1"> checked</if>> 是
</label>
<label>
<input type="radio" class="inp_radio" value="0" name="is_force_update" <if condition="$data['is_force_update'] eq 0"> checked</if> > 否
</label></span>
<span class="notice-text">开启强更后,若后台原包更新,则用户必须重新下载才可以进入游戏</span>
</td>
</tr>
<tr>
<td class="l noticeinfo">游戏标示</td>
<td class="r">
<input type="text" class="txt disabled" name="marking" value="{$data['marking']}" readonly="readonly" placeholder="游戏唯一标示">
<span class="notice-text">苹果游戏分包时需填写的游戏标示,格式无特别要求</span>
</td>
</tr>
<tr>
<td class="l noticeinfo">游戏key</td>
<td class="r">
<input type="text" class="txt disabled" name="game_key" value="{$data['game_key']}" placeholder="游戏支付通知时的加密key">
<span class="notice-text">游戏支付通知时的加密key可自由设置长度不得超过32位字符串设置完必须提供给CP方进行同步</span>
</td>
</tr>
<tr>
<td class="l noticeinfo">游戏支付通知地址</td>
<td class="r" >
<input type="text" class="txt disabled" name="pay_notify_url" value="{$data['pay_notify_url']}" placeholder="支付时通知CP方所用的地址">
<span class="notice-text">此处功能为平台用户游戏充值时通知CP方所用该地址由CP方提供</span>
</td>
</tr>
<tr>
<td class="l noticeinfo">访问秘钥</td>
<td class="r">
<input type="text" class="txt disabled" name="access_key" maxlength="20" value="{$data['access_key']}" placeholder="SDK访问服务器时的加密key">
<span class="notice-text">SDK访问服务器时加密key可自由设置长度不得超过20位字符串</span>
</td>
</tr>
<tr>
<td class="l noticeinfo">威富通商户号</td>
<td class="r">
<input type="text" class="txt disabled" name="partner" value="{$data['partner']}" placeholder="输入威富通商户号">
<span class="notice-text">威富通申请成功以后,威富通方提供的商户号,在此处添加(需要删除,在支付配置里设置即可)</span>
</td>
</tr>
<tr>
<td class="l noticeinfo">威富通秘钥</td>
<td class="r">
<input type="text" class="txt disabled" name="key" value="{$data['key']}" placeholder="输入威富通秘钥">
<span class="notice-text">威富通申请成功以后,威富通方提供的秘钥,在此处添加(需要删除,在支付配置里设置即可)</span>
</td>
</tr>
<tr>
<td class="l noticeinfo">游戏支付appid</td>
<td class="r">
<input type="text" class="txt disabled" name="game_pay_appid" value="{$data['game_pay_appid']}" placeholder="微信支付时用的APPID">
<span class="notice-text">使用微信支付时需要的appid需要到微信开放平台申请创建包括官方微信支付和威富通里的微信支付需要删除在支付配置里设置即可</span>
</td>
</tr>
<tr>
<td class="l noticeinfo">游戏合作id</td>
<td class="r">
<input type="text" class="txt disabled" name="agent_id" value="{$data['agent_id']}" placeholder="安卓生成APK时的包名">
<span class="notice-text">游戏对接时需要的合作id此id由CP方提供此功能根据不同游戏CP确定是否需要使用</span>
</td>
</tr>
<tr>
<td class="l noticeinfo">游戏包名</td>
<td class="r">
<input type="text" class="txt disabled" name="apk_pck_name" value="{$data['apk_pck_name']}" placeholder="安卓生成APK时的包名">
<span class="notice-text">在微信开放平台申请创建的应用包名app.webchat.payment.agree若无此项可不填写待定</span>
</td>
</tr>
<tr>
<td class="l noticeinfo">游戏签名</td>
<td class="r">
<input type="text" class="txt disabled" name="apk_pck_sign" value="{$data['apk_pck_sign']}" placeholder="安卓生成APK时的签名">
<span class="notice-text">在微信开放平台申请创建的应用签名fd0e6a444fd988bf23ce8a1818623b58若无此项可不填写待定</span>
</td>
</tr>
<tr>
<td class="l noticeinfo">客服QQ</td>
<td class="r">
<input type="text" class="txt" name="ccustom_service_qq" value="{$data['ccustom_service_qq']}" placeholder="游戏客服QQ">
<span class="notice-text">在游戏里遇到问题点击联系QQ</span>
</td>
</tr>
</tbody>
</table>
</div>
<!-- H5分享页面 -->
<div id="tab4" class="tab-pane tab4 ">
<div class="infomation information1711">
<p>功能说明H5分享页面每个游戏按需如下要求进行配置推广员申请渠道包时自动生成对应的H5下载页面便于推广员进行快速推广。</p>
<p>例如:{$_SERVER['HTTP_HOST']}{:str_ireplace(_PHP_FILE_,'/Index.php',U('Home/Index/game_view'))}</p>
</div>
<table border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="l">页面标题:</td>
<td class="r">
<input type="text" class="txt2" id="share_game_describe" name="back_describe" value="{$data.back_describe}" style="width: 690px;" >
</td>
</tr>
<tr class="picbox">
<td class="l noticeinfo" >
分享游戏图标
</td>
<td class="r">
<span class="table_btn table_upload">
<input type="file" id="upload_dow_icon">
<input type="hidden" name="dow_icon" id="dow_id_icon" value="{$data.dow_icon}" />
<div class="upload-img-box">
<notempty name="data['dow_icon']">
<div class="upload-pre-item"><img src="{$data['dow_icon']|get_cover='path'}"/></div>
</notempty>
</div>
</span>
<span class="notice-text">512*512px</span>
</td>
</tr>
<tr class="picbox">
<td class="l noticeinfo" >
分享背景图片
</td>
<td class="r">
<span class="table_btn table_upload">
<input type="file" id="upload_dow_detail">
<input type="hidden" name="back_map" id="back_map_detail" value="{$data.back_map}" />
<div class="upload-img-box">
<notempty name="data['back_map']">
<div class="upload-pre-item"><img src="{$data['back_map']|get_cover='path'}"/></div>
</notempty>
</div>
</span>
<span class="notice-text">720*1280px及以上</span>
</td>
</tr>
</tbody>
</table>
</div>
<div id="tab5" class="tab-pane tab5 ">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="l">游戏名称:</td>
<td class="r">
<span class="tab_name">{$data['relation_game_name']}</span>
</td>
</tr>
<tr>
<td class="l">等级档位一:</td>
<td class="r">
<input class="txt" name="first_level_name" value="{$data['first_level_name']}" type="text"><b class="fl tab5_b"></b> <input class="txt" name="first_level" value="{$data['first_level']}" type="text"><span class="fl tab5_notice">第一个框输入等级名称,如:用户一级;第二个框输入玩家达到该等级所需达到的游戏账号级别数10</span>
</td>
</tr>
<tr>
<td class="l">等级档位二:</td>
<td class="r">
<input class="txt" name="second_level_name" value="{$data['second_level_name']}" type="text"><b class="fl tab5_b"></b> <input class="txt" name="second_level" value="{$data['second_level']}" type="text"><span class="fl tab5_notice">第一个框输入等级名称,如:用户二级;第二个框输入玩家达到该等级所需达到的游戏账号级别数20</span>
</td>
</tr>
<tr>
<td class="l">等级档位三:</td>
<td class="r">
<input class="txt" name="third_level_name" value="{$data['third_level_name']}" type="text"><b class="fl tab5_b"></b> <input class="txt" name="third_level" value="{$data['third_level']}" type="text"><span class="fl tab5_notice">第一个框输入等级名称,如:用户三级;第二个框输入玩家达到该等级所需达到的游戏账号级别数30</span>
</td>
</tr>
<tbody>
</table>
</div>
<!--推广配置-->
<div id="tab6" class="tab-pane tab6 ">
<input type="button" id="addpromote" onclick="addPromote()" style="background: #3E96C9;color:white;border:none;outline: none;width:90px;height:30px;border-radius: 3px;" value="添加" />
<div class="data_list data_game_list" id="addpromoteindex" style="margin-top:20px;">
<div class="">
<table>
<thead>
<tr>
<th>会长账号</th>
<th>添加时间</th>
<th>是否已进行推广</th>
<th style="width:10%;min-width:150px;">操作</th>
</tr>
</thead>
<tbody>
<if condition="$apply_auth eq 2">
<empty name ="sociatygames">
<td colspan="14" class="text-center">aOh! 暂时还没有内容!</td>
<else />
<volist name="sociatygames" id="data">
<tr>
<td>{$data['promoteAccount']}</td>
<td>{$data['create_time']}</td>
<td>{$data['isPromote']}</td>
<td class="" style="color:red"><a href="javascript:void()" onclick="del({$data['id']})">移除</a></td>
</tr>
</volist>
</empty>
<else/>
<td colspan="14" class="text-center">该游戏未设置会长权限,现面对所有会长开放!</td>
</if>
</tbody>
</table>
</div>
</div>
<table border="0" cellspacing="0" cellpadding="0" id="promoteset" style="display:none">
<tbody >
<tr style="display:block;width:600px;" >
<td class="l">推广限制</td>
<td class="r" >
<input type="radio" class="inp_radio js-device js-devices{$key}" value="0" id="all" name="apply_auth" checked> 全部会长可申请
<input type="radio" class="inp_radio js-device js-devices{$key}" value="0" id="part" name="apply_auth" style="margin-left:20px"> 部分会长可申请
</td>
</tr>
<tr style="display:none;width:600px;" id="addtype">
<td class="l" >添加方式</td>
<td class="r" >
<input type="radio" class="inp_radio js-device js-devices{$key}" value="" id="excel" name="" checked> EXCEL导入
<input type="radio" class="inp_radio js-device js-devices{$key}" value="" id="partchoose" name="" style="margin-left:20px"> 批量选择
</td>
</tr>
<tr style="display:none" id="moban">
<td class="l">EXCEL模板</td>
<td class="r" >
<a href="{:U('downloadDemo',['game_id'=>$game_id])}">下载模板</a>
</td>
</tr>
<tr style="display:none" id="daoru">
<td class="l">导入模板</td>
<td class="r" >
<input type="file" name="upfile" id="file_excel" style="width:200px"/>
<input type="button" onclick="suba({$game_id})" style="background: #3E96C9;color:white;border:none;outline: none;width:70px;height:30px;border-radius: 3px;" value="导入" />
</td>
</tr>
</tbody>
</table>
<div class="data_list data_game_list" id="data_list"></div>
<link rel="stylesheet" type="text/css" href="__STATIC__/layui-v2.5.5/css/layui.css">
<input type="hidden" name="group_id" id="group_id" value="{$_GET['group_id']}">
<input type="hidden" name="promote_data" id="promote_data" value="[]">
<div id="transfer_promote" class="demo-transfer" style="margin-left: 100px;margin-top: 35px;display:none"></div>
</div>
<div class="form-item cf">
<input type="hidden" name='id' value="{$data['id']}" />
<input type="hidden" name='type' value="{$_GET['type']}" />
<input type="hidden" name="p" value="{$_GET['p']}" />
<button class="submit_btn ajax-post " id="submit1" type="submit" target-form="form-horizontal" style="margin-left:210px;">
保存
</button>
<a class="submit_btn " alt="返回上一页" title="返回上一页" href="{:U('Game/lists',array('type'=>I('type',1)))}" >
返回
</a>
</div>
</form>
</div>
</div>
<div class="common_settings">
<span class="plus_icon"><span><img src="__IMG__/zwmimages/icon_jia.png"></span></span>
<form class="addShortcutIcon">
<input type="hidden" name="title" value="{$m_title}">
<input type="hidden" name="url" value="Game/lists">
</form>
<a class="ajax-post add-butn <notempty name='commonset'>addSIsetted</notempty>" href="javascript:;" target-form="addShortcutIcon" url="{:U('Think/addShortcutIcon')}"><img src="__IMG__/zwmimages/icon_jia.png"><span><notempty name='commonset'>已添加<else />添加至常用设置</notempty></span></a>
</div>
</block>
<block name="script">
<script src="__STATIC__/layui-v2.5.5/layui.all.js"></script>
<script type="text/javascript" src="__STATIC__/datetimepicker/js/bootstrap-datetimepicker.min.js"></script>
<script>
var dataTransfer = '';
$.ajax({
url: "{:U('getRootPromote')}",
type: "post",
data: {group_id: 1},
dataType: 'json',
success: function (data) {
console.log(data,'datadadaa')
// datas = data;
layui.use(['transfer', 'layer', 'util'], function(){
var $ = layui.$
,transfer = layui.transfer
,layer = layui.layer
,util = layui.util;
var data1 =data;
if (JSON.parse(data1).data_president) {
var data2 = JSON.parse(data1).data_president.split(",");
}
// var dataTransfers = transfer.getData('key123');
// $('#promote_data').val(JSON.stringify(dataTransfers));
//显示搜索框
transfer.render({
elem: '#transfer_promote'
,data: JSON.parse(data1).list
,title: ['全部成员', '选中成员']
,showSearch: true,
value: data2,
id: 'key123',
onchange: function(data, index){
dataTransfer = transfer.getData('key123'); //获取右侧数据
// layer.alert(JSON.stringify(dataTransfer));
$('#promote_data').val(JSON.stringify(dataTransfer));
}
})
var dataTransfers = transfer.getData('key123');
$('#promote_data').val(JSON.stringify(dataTransfers));
transfets = transfer;
//批量办法定事件
util.event('lay-demoTransferActive', {
getData: function(othis){
var getData = transfer.getData('key123'); //获取右侧数据
layer.alert(JSON.stringify(getData));
}
});
});
}
});
</script>
<script type="text/javascript">
$("#part").click(function() {
var addtype = document.getElementById("addtype");
addtype.style.display = "block"
$("#part").attr('checked',true)
$("#all").attr('checked',false)
var moban = document.getElementById("moban");
moban.style.display = "block"
var daoru = document.getElementById("daoru");
daoru.style.display = "block"
document.getElementById('all').value = 1
document.getElementById('part').value = 2
})
$("#all").click(function() {
var addtype = document.getElementById("addtype");
addtype.style.display = "none"
$("#part").attr('checked',false)
$("#all").attr('checked',true)
$("#excel").attr('checked',true)
$("#partchoose").attr('checked',false)
var moban = document.getElementById("moban");
moban.style.display = "none"
var daoru = document.getElementById("daoru");
daoru.style.display = "none"
document.getElementById("transfer_promote").style.display = "none"
document.getElementById("data_list").style.display = "none"
document.getElementById('all').value = 1
document.getElementById('part').value = 2
})
$("#excel").click(function() {
var moban = document.getElementById("moban");
// addtype.style.display = "none"
$("#excel").attr('checked',true)
$("#partchoose").attr('checked',false)
moban.style.display = "block"
var daoru = document.getElementById("daoru");
daoru.style.display = "block"
document.getElementById('transfer_promote').style.display = "none"
document.getElementById("data_list").style.display = "block"
})
$("#partchoose").click(function() {
var moban = document.getElementById("moban");
// addtype.style.display = "none"
$("#excel").attr('checked',false)
$("#partchoose").attr('checked',true)
moban.style.display = "none"
var daoru = document.getElementById("daoru");
daoru.style.display = "none"
document.getElementById('transfer_promote').style.display = "block"
document.getElementById("data_list").style.display = "none"
})
function addPromote() {
var addpromoteindex = document.getElementById("addpromoteindex");
var addpromote = document.getElementById("addpromote");
var promoteset = document.getElementById("promoteset");
addpromoteindex.style.display = "none"
addpromote.style.display = "none"
promoteset.style.display = "block"
document.getElementById('all').value = 1
document.getElementById('part').value = 2
}
function del(id) {
var msg = "确认删除该项?"
if(confirm(msg) == true) {
$.ajax({
url:"{:U('Game/delSociatyGames')}",
dataType:'json',
type:'POST',
data:{'id':id},
success:function(res) {
console.log(res.code)
if(res.code == 10001) {
window.location.reload();
}
}
})
}
}
function suba(game_id) {
var file_excel = $('#file_excel')[0].files[0]
var formData = new FormData();
formData.append("file",file_excel);
formData.append("game_id",game_id)
$.ajax({
url:"{:U('Game/uploadExcel1')}",
dataType:'json',
type:'POST',
async:false,
data:formData,
processData : false, // 使数据不做处理
contentType : false, // 不要设置Content-Type请求头
success:function(res) {
document.getElementById('data_list').style.display = "block"
res = JSON.parse(res)
var datalist = res.datalist
var outPromote = res.outPromote
if(datalist.length > 0) {
html = '<div class="" style="width:500px"><table><thead><tr><th>录入成功会长账号</th></tr></thead><tbody>'
datalist.forEach(v=>{
html += '<tr><td>'+v['account']+'</td></tr>';
})
}else {
html = '<div class="" style="width:500px"><table><thead><tr><th>录入成功会长账号</th></tr></thead><tbody>'
+'<tr><td colspan="14" class="text-center">aOh! 暂无账号录入!</td></tr>'
}
html += '</tbody></table></div>'
if(outPromote.length > 0) {
html += '<div class="" style="width:500px"><table><thead><tr><th>录入失败会长账号</th></tr></thead><tbody>'
outPromote.forEach(p=>{
html += '<tr><td>'+p['promote_account']+'</td></tr>';
})
}else {
html += '<div class="" style="width:500px"><table><thead><tr><th>录入失败会长账号</th></tr></thead><tbody>'
+'<tr><td colspan="14" class="text-center">aOh! 暂无录入失败会长账号!</td></tr>>'
}
html += '</tbody></table></div>'
$("#data_list").html(html);
}
})
}
$('[name=shift_mode]').on({
click: function () {
if ($(this).val() == 2) {
$('#shift-transfer').show()
} else {
$('#shift-transfer').hide()
}
}
})
</script>
<script type="text/javascript">
//导航高亮
highlight_subnav('{:U('Game/lists')}');
Think.setValue("game_type_id", {$data.game_type_id|default = 0});
Think.setValue("category", {$data.category|default = 0});
Think.setValue("display_site[]", [{$data.display_site}]);
$('#submit').click(function(){
$('#form').submit();
});
$(function(){
$("#game_type_name").val($("#game_type_id option:selected").text());
$('.time').datetimepicker({
format: 'yyyy-mm-dd hh:ii',
language:"zh-CN",
minView:2,
autoclose:true
});
$('.date').datetimepicker({
format: 'yyyy-mm-dd',
language:"zh-CN",
minView:2,
autoclose:true
});
showTab();
if({$_GET['type']} == 2){
$('.disabled').attr('disabled',true);
$('.disabled').attr('style',"background:#e7e7e7");
}
$('input:radio[name="down_port"]').change();//下载端口默认操作
//运行版本change的操作
$('input:radio[name="sdk_version"]').change();
});
$("#add_another").click(function() {
layer.open({
type: 2,
title: '游戏登录记录',
shadeClose: true,
shade: 0.8,
area: ['70%', '80%'],
content: url+'admin.php?s=/Game/add_another/id/1111'//iframe的url
});
});
/*获取游戏类型名称*/
$("#game_type_id").change(function() {
$("#game_type_name").val($("#game_type_id option:selected").text());
});
//上传游戏图标
/* 初始化上传插件 */
$("#upload_picture_icon").uploadify({
"height" : 30,
"swf" : "__STATIC__/uploadify/uploadify.swf",
"fileObjName" : "download",
"buttonText" : "上传图标",
"uploader" : "{:U('File/uploadPicture',array('session_id'=>session_id()))}",
"width" : 120,
'removeTimeout' : 1,
'fileTypeExts' : '*.jpg; *.jpeg; *.png; *.gif;',
"onUploadSuccess" : upload_picture_icon{$field.name},
'onFallback' : function() {
// alert('未检测到兼容版本的Flash.');
}
});
function upload_picture_icon{$field.name}(file, data){
var data = $.parseJSON(data);
var src = '';
if(data.status){
$("#cover_id_icon").val(data.id);
src = data.url || '__ROOT__' + data.path;
$("#cover_id_icon").parent().find('.upload-img-box').html(
'<div class="upload-pre-item"><span class="placeholder-graphic placeholder-graphic_icon"><img src="' + src + '"/></span></div>'
);
} else {
updateAlert(data.info,'tip_error');
setTimeout(function(){
$('#tip').find('.tipclose').click();
$('#top-alert').find('button').click();
$(that).removeClass('disabled').prop('disabled',false);
},1500);
}
}
//上传游戏封面
/* 初始化上传插件 */
$("#upload_picture_cover").uploadify({
"height" : 30,
"swf" : "__STATIC__/uploadify/uploadify.swf",
"fileObjName" : "download",
"buttonText" : "上传封面",
"uploader" : "{:U('File/uploadPicture',array('session_id'=>session_id(),'flag'=>true))}",
"width" : 120,
'removeTimeout' : 1,
'fileTypeExts' : '*.jpg; *.jpeg; *.png; *.gif;',
"onUploadSuccess" : upload_picture_cover{$field.name},
'onFallback' : function() {
// alert('未检测到兼容版本的Flash.');
}
});
function upload_picture_cover{$field.name}(file, data){
var data = $.parseJSON(data);
var src = '';
if(data.status){
$("#cover_id_cover").val(data.id);
src = data.url || '__ROOT__' + data.path;
$("#cover_id_cover").parent().find('.upload-img-box').html(
'<div class="upload-pre-item"><span class="placeholder-graphic placeholder-graphic_ad"><img src="' + src + '"/></span></div>'
);
} else {
updateAlert(data.info,'tip_error');
setTimeout(function(){
$('#tip').find('.tipclose').click();
$('#top-alert').find('button').click();
$(that).removeClass('disabled').prop('disabled',false);
},1500);
}
}
//上传游戏详情背景
/* 初始化上传插件 */
$("#upload_picture_detail").uploadify({
"height" : 30,
"swf" : "__STATIC__/uploadify/uploadify.swf",
"fileObjName" : "download",
"buttonText" : "上传封面",
"uploader" : "{:U('File/uploadPicture',array('session_id'=>session_id()))}",
"width" : 120,
'removeTimeout' : 1,
'fileTypeExts' : '*.jpg; *.jpeg; *.png; *.gif;',
"onUploadSuccess" : upload_picture_detail{$field.name},
'onFallback' : function() {
// alert('未检测到兼容版本的Flash.');
}
});
function upload_picture_detail{$field.name}(file, data){
var data = $.parseJSON(data);
var src = '';
if(data.status){
$("#detail_id_icon").val(data.id);
src = data.url || '__ROOT__' + data.path;
$("#detail_id_icon").parent().find('.upload-img-box').html(
'<div class="upload-pre-item"><img src="' + src + '"/></div>'
);
} else {
updateAlert(data.info,'tip_error');
setTimeout(function(){
$('#tip').find('.tipclose').click();
$('#top-alert').find('button').click();
$(that).removeClass('disabled').prop('disabled',false);
},1500);
}
}
//上传游戏分享下载图标
/* 初始化上传插件 */
$("#upload_dow_icon").uploadify({
"height" : 30,
"swf" : "__STATIC__/uploadify/uploadify.swf",
"fileObjName" : "download",
"buttonText" : "上传图标",
"uploader" : "{:U('File/uploadPicture',array('session_id'=>session_id()))}",
"width" : 120,
'removeTimeout' : 1,
'fileTypeExts' : '*.jpg; *.jpeg; *.png; *.gif;',
"onUploadSuccess" : upload_dow_icon{$field.name},
'onFallback' : function() {
// alert('未检测到兼容版本的Flash.');
}
});
function upload_dow_icon{$field.name}(file, data){
var data = $.parseJSON(data);
var src = '';
if(data.status){
$("#dow_id_icon").val(data.id);
src = data.url || '__ROOT__' + data.path;
$("#dow_id_icon").parent().find('.upload-img-box').html(
'<div class="upload-pre-item"><img src="' + src + '"/></div>'
);
} else {
updateAlert(data.info,'tip_error');
setTimeout(function(){
$('#tip').find('.tipclose').click();
$('#top-alert').find('button').click();
$(that).removeClass('disabled').prop('disabled',false);
},1500);
}
}
//上传游戏分享背景图片
/* 初始化上传插件 */
$("#upload_dow_detail").uploadify({
"height" : 30,
"swf" : "__STATIC__/uploadify/uploadify.swf",
"fileObjName" : "download",
"buttonText" : "上传背景图",
"uploader" : "{:U('File/uploadPicture',array('session_id'=>session_id(),'flag'=>true))}",
"width" : 120,
'removeTimeout' : 1,
'fileTypeExts' : '*.jpg; *.jpeg; *.png; *.gif;',
"onUploadSuccess" : upload_dow_detail{$field.name},
'onFallback' : function() {
// alert('未检测到兼容版本的Flash.');
}
});
function upload_dow_detail{$field.name}(file, data){
var data = $.parseJSON(data);
var src = '';
if(data.status){
$("#back_map_detail").val(data.id);
src = data.url || '__ROOT__' + data.path;
$("#back_map_detail").parent().find('.upload-img-box').html(
'<div class="upload-pre-item"><img src="' + src + '"/></div>'
);
} else {
updateAlert(data.info,'tip_error');
setTimeout(function(){
$('#tip').find('.tipclose').click();
$('#top-alert').find('button').click();
$(that).removeClass('disabled').prop('disabled',false);
},1500);
}
}
var userInfo = {userId:"kazaff", md5:""}; //用户会话信息
var chunkSize = 5000 * 1024; //分块大小
var uniqueFileName = null; //文件唯一标识符
var md5Mark = null;
var backEndUrl = "{:U('File/shard_upload',array('type'=>1,'session_id'=>session_id()))}";
WebUploader.Uploader.register({
"before-send-file" : "beforeSendFile",
"before-send" : "beforeSend",
"after-send-file" : "afterSendFile"
}, {
beforeSendFile: function(file){
//秒传验证
if (file['source']['ext'] === 'zip' || file['source']['ext'] === 'rar') {
var task = new $.Deferred();
var start = new Date().getTime();
(new WebUploader.Uploader()).md5File(file, 0, 10*1024*1024).progress(function(percentage){
//console.log(percentage);
}).then(function(val){
//console.log("总耗时: "+((new Date().getTime()) - start)/1000);
md5Mark = val;
userInfo.md5 = val;
$.ajax({
type: "POST"
, url: backEndUrl
, data: {status: "md5Check", md5: val}
, cache: false
, timeout: 1000 //todo 超时的话,只能认为该文件不曾上传过
, dataType: "json"
}).then(function(data, textStatus, jqXHR){
alert(data.chunk);
//console.log(data);
if(data.ifExist){ //若存在这返回失败给WebUploader表明该文件不需要上传
task.reject();
uploader.skipFile(file);
file.path = data.path;
}else{
task.resolve();
//拿到上传文件的唯一名称,用于断点续传
uniqueFileName = md5(''+userInfo.userId+file.name+file.type+file.lastModifiedDate+file.size);
}
}, function(jqXHR, textStatus, errorThrown){ //任何形式的验证失败,都触发重新上传
task.resolve();
//拿到上传文件的唯一名称,用于断点续传
uniqueFileName = md5(''+userInfo.userId+file.name+file.type+file.lastModifiedDate+file.size);
});
});
return $.when(task);
}
}
, beforeSend: function(block){
//分片验证是否已传过,用于断点续传
if (block['file']['source']['ext'] === 'zip' || block['file']['source']['ext'] === 'rar') {
var task = new $.Deferred();
$.ajax({
type: "POST"
, url: backEndUrl
, data: {
status: "chunkCheck"
, name: uniqueFileName
, chunkIndex: block.chunk
, size: block.end - block.start
}
, cache: false
, timeout: 1000 //todo 超时的话,只能认为该分片未上传过
, dataType: "json"
}).then(function(data, textStatus, jqXHR){
if(data.ifExist){ //若存在返回失败给WebUploader表明该分块不需要上传
task.reject();
}else{
task.resolve();
}
}, function(jqXHR, textStatus, errorThrown){ //任何形式的验证失败,都触发重新上传
task.resolve();
});
return $.when(task);
}
}
, afterSendFile: function(file){
if (file['source']['ext'] === 'zip' || file['source']['ext'] === 'rar') {
var chunksTotal = 0;
if((chunksTotal = Math.ceil(file.size/chunkSize)) > 1){
//合并请求
var task = new $.Deferred();
$.ajax({
type: "POST"
, url: backEndUrl
, data: {
status: "chunksMerge"
, name: uniqueFileName
, chunks: chunksTotal
, ext: file.ext
, md5: md5Mark
}
, cache: false
, dataType: "json"
}).then(function(data, textStatus, jqXHR){
//todo 检查响应是否正常
task.resolve();
file.path = data.path;
$("#file_name").val(data.name);
$("#file_url").val(data.path+'/'+data.name);
$("#file_size").val(file.size);
}, function(jqXHR, textStatus, errorThrown){
task.reject();
});
return $.when(task);
}else{
//UploadComlate(file);
}
}
}
});
//上传落地页视频
var uploaderVideo = WebUploader.create({
// 选完文件后,是否自动上传。
auto: true,
// swf文件路径
swf: '__STATIC__/webuploader/Uploader.swf',
// 文件接收服务端。
server: backEndUrl,
// 选择文件的按钮。可选。
// 内部根据当前运行是创建可能是input元素也可能是flash.
pick: {id:'#pickerVideo'},
fileSingleSizeLimit:20*1024*1024, //设定单个文件大小
// dnd: true,
paste: document.body,
accept: {
title: '视频',
extensions: 'mp4,3gp,wmv,asf,asx,mov,m4v,avi,flv,qlv',
mimeTypes: '.mp4,.3gp,.wmv,.asf,.asx,.mov,.m4v,.avi,.flv,.qlv',
},
// 不压缩image, 默认如果是jpeg文件上传前会压缩一把再上传
resize: false,
disableGlobalDnd: true,
fileNumLimit:1,
threads:3,
compress: false,
prepareNextFile: true,
formData: function(){return $.extend(true, {}, userInfo);},
duplicate: true
});
// 当有文件被添加进队列的时候
uploaderVideo.on( 'fileQueued', function( file ) {
$("#up_status").remove();
$("#video_thelist").html( '<div id="' + file.id + '" class="item">' +
'<h4 class="info">' + file.name + '</h4>' +
'<p class="state">等待上传...</p>' +
'</div>' );
});
// 文件上传过程中创建进度条实时显示。
uploaderVideo.on( 'uploadProgress', function(file, percentage) {
var $li = $( '#'+file.id ),
$percent = $li.find('.progress .progress-bar');
// 避免重复创建
if ( !$percent.length ) {
$percent = $('<div class="progress progress-striped active">' +
'<div class="progress-bar" role="progressbar" style="width: 0%">' +
'</div>' +
'</div>').appendTo( $li ).find('.progress-bar');
}
$li.find('p.state').text('上传中');
$percent.css( 'width', percentage * 100 + '%' );
$percent.text( (percentage * 100).toFixed(0) + '%' );
});
$('#beforeuploadvideo').children('.info').children('.jsdelvideo').click(function() {
$("#video_url").val('');
$('#beforeuploadvideo').remove();
return false;
});
uploaderVideo.on( 'uploadSuccess', function( file , response) {
$( '#'+file.id ).find('p.state').text('已上传').fadeOut(800);
//alert(JSON.stringify(response));
$('#'+file.id).find('h4.info').append('<a href="javascript:;" class="jsdelvideo table_click" style="float:none;display:inline-block;margin-left:10px;">删除</a>');
var url = response.path + "/" +response.name;
$('#'+file.id).find('h4.info').after("<video src="+url+" controls width=\"150px\"></video>");
$("#video_url").val(url);
$('#'+file.id).find('.jsdelvideo').on('click',function() {
console.log(file);
$("#video_url").val('');
$('#'+file.id).remove();
uploaderVideo.removeFile( file.id );
return false;
});
});
/**
* 验证文件格式以及文件大小
*/
uploaderVideo.on("error",function (type){
if (type=="Q_TYPE_DENIED"){
layer.msg("不支持该视频格式");
}else if(type=="F_EXCEED_SIZE"){
layer.msg("视频大小不能超过20M");
}
});
uploaderVideo.on( 'uploadError', function( file ) {
$( '#'+file.id ).find('p.state').text('上传出错');
});
uploaderVideo.on( 'uploadComplete', function(file) {
$( '#'+file.id ).find('.progress').fadeOut();
});
//上传落地页视频封面
var uploaderFlooringVideoPageCover = WebUploader.create({
// 选完文件后,是否自动上传。
auto: true,
// swf文件路径
swf: '__STATIC__/webuploader/Uploader.swf',
// 文件接收服务端。
server: "{:U('File/uploadPicture',array('session_id'=>session_id(),'flag'=>true))}",
// 选择文件的按钮。可选。
// 内部根据当前运行是创建可能是input元素也可能是flash.
pick: {
id:'#flooring_page_video_cover',
multiple:true
},
// dnd: false,
paste: document.body,
accept: {
title: '图片',
extensions: 'png,gif,jpg,jpeg,bmp',
mimeTypes: '.png,.gif,.jpg,.jpeg,.bmp',
},
// 不压缩image, 默认如果是jpeg文件上传前会压缩一把再上传
resize: false,
disableGlobalDnd: true,
fileNumLimit:1,
threads:1,
thumb:true,
compress:false,
prepareNextFile: true,
formData: function(){return $.extend(true, {}, userInfo);},
chunked:false,
duplicate: true
});
// 当有文件被添加进队列的时候
uploaderFlooringVideoPageCover.on( 'fileQueued', function( file ) {
var html = '';
var imgList = $("#flooring_page_video_cover_thelist");
html += '<div id="' + file.id + '" class="item" style="margin-right: 10px;">';
html += '<a href="javascript:;"><img src="" style="width: 150px;height: 84px;cursor: move;"></a>';
html += '<h4 class="info">' + file.name + '</h4>';
html += '<p class="state">等待上传...</p>';
html += '</div>';
imgList.html(html);
imgList.css('margin-top','10px');
var img2 = imgList.children('#'+file.id).find('img');
uploaderFlooringVideoPageCover.makeThumb(file, function (error, src) {
if (error) {
return;
}
img2.attr('src', src);
}, 300, 300);
});
// 文件上传过程中创建进度条实时显示。
uploaderFlooringVideoPageCover.on( 'uploadProgress', function(file, percentage) {
var $li = $( '#'+file.id ),
$percent = $li.find('.progress .progress-bar');
// 避免重复创建
if ( !$percent.length ) {
$percent = $('<div class="progress progress-striped active">' +
'<div class="progress-bar" role="progressbar" style="width: 0%">' +
'</div>' +
'</div>').appendTo( $li ).find('.progress-bar');
}
$li.find('p.state').text('上传中');
$percent.css( 'width', percentage * 100 + '%' );
$percent.text( (percentage * 100).toFixed(0) + '%' );
});
uploaderFlooringVideoPageCover.on( 'uploadSuccess', function( file , response) {
$( '#'+file.id ).find('p.state').text('已上传').fadeOut(800);
$('#'+file.id).find('h4.info').append('<a href="javascript:;" class="jsdelvideo table_click" style="float:none;display:inline-block;margin-left:10px;">删除</a>');
console.log(response);
var cover = response.id;
$("input[name=flooring_page_video_cover]").val(cover);
$('#'+file.id).find('.jsdelvideo').on('click',function() {
console.log(file);
$("input[name=flooring_page_video_cover]").val('');
$('#'+file.id).remove();
uploaderFlooringVideoPageCover.removeFile( file.id );
return false;
});
});
var flooringVideoPageCover = [];
<?php if (!empty($data['flooring_page_video_cover'])) :?>
var html = '';
<?php $flooringVideoPageCover = $data['flooring_page_video_cover']; ?>
html += '<div id="' + <?=$flooringVideoPageCover?> + '" class="item" style="margin-right: 10px;">';
html += '<a href="javascript:;"><img src="<?=get_cover($flooringVideoPageCover,"path")?>" style="width: 150px;height: 84px;cursor: move;"></a>';
html += '<h4 class="info" style="text-align: center;">';
html += '<a href="javascript:;" class="jsdelzip table_click" style="float:none;display:inline-block;" img-id="' + <?=$flooringVideoPageCover?> + '">删除</a>';
html += '</h4>';
html += '<div class="progress progress-striped active" style="display: none;">';
html += '<div class="progress-bar" role="progressbar" style="width: 100%;">100%</div>';
html += '</div>';
html += '</div>';
$('#flooring_page_video_cover_thelist').css('margin-top','10px');
$('#flooring_page_video_cover_thelist').html(html);
$('#flooring_page_video_cover_thelist').children().children('h4').children('.jsdelzip').on('click', function() {
$(this).parent().parent().remove();
$("input[name=flooring_page_video_cover]").val('');
});
<?php endif ;?>
var uploaderFile = WebUploader.create({
// 选完文件后,是否自动上传。
auto: true,
// swf文件路径
swf: '__STATIC__/webuploader/Uploader.swf',
// 文件接收服务端。
server: backEndUrl,
// 选择文件的按钮。可选。
// 内部根据当前运行是创建可能是input元素也可能是flash.
pick: {id:'#picker'},
// dnd: true,
paste: document.body,
accept: {
title: '压缩包',
extensions: 'rar,zip',
mimeTypes: '.rar,.zip',
},
// 不压缩image, 默认如果是jpeg文件上传前会压缩一把再上传
resize: false,
disableGlobalDnd: true,
fileNumLimit:1,
threads:3,
compress: false,
prepareNextFile: true,
formData: function(){return $.extend(true, {}, userInfo);},
chunked:true,
chunkSize: 5*1000*1024,
duplicate: true
});
// 当有文件被添加进队列的时候
uploaderFile.on( 'fileQueued', function( file ) {
$("#up_status").remove();
$("#thelist").append( '<div id="' + file.id + '" class="item">' +
'<h4 class="info">' + file.name + '</h4>' +
'<p class="state">等待上传...</p>' +
'</div>' );
});
// 文件上传过程中创建进度条实时显示。
uploaderFile.on( 'uploadProgress', function(file, percentage) {
var $li = $( '#'+file.id ),
$percent = $li.find('.progress .progress-bar');
// 避免重复创建
if ( !$percent.length ) {
$percent = $('<div class="progress progress-striped active">' +
'<div class="progress-bar" role="progressbar" style="width: 0%">' +
'</div>' +
'</div>').appendTo( $li ).find('.progress-bar');
}
$li.find('p.state').text('上传中');
$percent.css( 'width', percentage * 100 + '%' );
$percent.text( (percentage * 100).toFixed(0) + '%' );
});
$('#beforeupload').children('.info').children('.jsdelzip').click(function() {
$("#file_url").val('');
$('#beforeupload').remove();
return false;
});
uploaderFile.on( 'uploadSuccess', function( file , response) {
$( '#'+file.id ).find('p.state').text('已上传').fadeOut(800);
//alert(JSON.stringify(response));
$('#'+file.id).find('h4.info').append('<a href="javascript:;" class="jsdelzip table_click" style="float:none;display:inline-block;margin-left:10px;">删除</a>');
$('#'+file.id).find('.jsdelzip').on('click',function() {
$("#file_url").val('');
uploaderFile.removeFile( file.id );
$('#'+file.id).remove();
return false;
});
if(!response.chunk){
var url = response.path + "/" +response.name;
// $("#file_name").val(response.name);
$("#file_url").val(url);
// $("#file_size").val(response.size);
}
//alert($("#file_name").val()+";"+$("#file_url").val()+";"+$("#file_size").val())
});
uploaderFile.on( 'uploadError', function( file ) {
$( '#'+file.id ).find('p.state').text('上传出错');
});
uploaderFile.on( 'uploadComplete', function(file) {
$( '#'+file.id ).find('.progress').fadeOut();
});
//游戏截图
var uploaderImg = WebUploader.create({
// 选完文件后,是否自动上传。
auto: true,
// swf文件路径
swf: '__STATIC__/webuploader/Uploader.swf',
// 文件接收服务端。
server: "{:U('File/uploadPicture',array('session_id'=>session_id(),'flag'=>true))}",
// 选择文件的按钮。可选。
// 内部根据当前运行是创建可能是input元素也可能是flash.
pick: {
id:'#flooring_page_imgs',
multiple:true
},
// dnd: false,
paste: document.body,
accept: {
title: '图片',
extensions: 'png,gif,jpg,jpeg,bmp',
mimeTypes: '.png,.gif,.jpg,.jpeg,.bmp',
},
// 不压缩image, 默认如果是jpeg文件上传前会压缩一把再上传
resize: false,
disableGlobalDnd: true,
fileNumLimit:5,
threads:5,
thumb:true,
compress:false,
prepareNextFile: true,
formData: function(){return $.extend(true, {}, userInfo);},
chunked:false,
duplicate: true
});
var imgListData = [];
<?php if (!empty($data['flooring_page_imgs_data'])) :?>
var html = '';
$('#flooring_page_imgs_thelist').css('margin-top','10px');
<?php foreach ($data['flooring_page_imgs_data'] as $value) {?>
<?php $value = (int)$value;?>
imgListData.push(<?=$value?>);
html += '<div id="' + <?=$value?> + '" class="item flooring_page_img_box" style="margin-right: 10px;">';
html += '<a href="javascript:;"><img src="<?=get_cover($value,"path")?>" style="width: 100px;height: 100px;cursor: move;"></a>';
html += '<h4 class="info" style="text-align: center;">';
html += '<a href="javascript:;" class="jsdelzip table_click" style="float:none;display:inline-block;" img-id="' + <?=$value?> + '">删除</a>';
html += '</h4>';
html += '<div class="progress progress-striped active" style="display: none;">';
html += '<div class="progress-bar" role="progressbar" style="width: 100%;">100%</div>';
html += '</div>';
html += '</div>';
<?php }?>
$('#flooring_page_imgs_thelist').html(html);
$('#flooring_page_imgs_thelist').children().children('h4').children('.jsdelzip').on('click', function() {
var thisId = $(this).attr('img-id');
$(this).parent().parent().remove();
$.each(imgListData,function(index, item) {
if (thisId == item) {
imgListData.splice(index,1);
return false;
}
});
setFlooringPageImgsVal();
});
<?php endif ;?>
// 当有文件被添加进队列的时候
var thisIndex = 0;
var imgList = $("#flooring_page_imgs_thelist");
uploaderImg.on( 'fileQueued', function( file ) {
var html = '';
html += '<div id="' + file.id + '" class="item" style="margin-right: 10px;">';
html += '<a href="javascript:;"><img src="" style="width: 100px;height: 100px;cursor: move;"></a>';
html += '<h4 class="info">' + file.name + '</h4>';
html += '<p class="state">等待上传...</p>';
html += '</div>';
imgList.append(html);
imgList.css('margin-top','10px');
var img = imgList.children('#'+file.id).find('img');
uploaderImg.makeThumb(file, function (error, src) {
if (error) {
return;
}
img.attr('src', src);
}, 300, 300);
});
// 文件上传过程中创建进度条实时显示。
uploaderImg.on( 'uploadProgress', function( file, percentage ) {
var $li = $( '#'+file.id ),
$percent = $li.find('.progress .progress-bar');
// 避免重复创建
if ( !$percent.length ) {
$percent = $('<div class="progress progress-striped active">' +
'<div class="progress-bar" role="progressbar" style="width: 0%">' +
'</div>' +
'</div>').appendTo( $li ).find('.progress-bar');
}
$li.find('p.state').text('上传中');
$percent.css( 'width', percentage * 100 + '%' );
$percent.text( (percentage * 100).toFixed(0) + '%' );
});
uploaderImg.on( 'uploadSuccess', function( file , response) {
imgListData.push(response.id);
setFlooringPageImgsVal();
$( '#'+file.id ).find('p.state').text('已上传').fadeOut(800);
//alert(JSON.stringify(response));
$('#'+file.id).find('h4.info').append('<a href="javascript:;" class="jsdelzip table_click" style="float:none;display:inline-block;margin-left:10px;">删除</a>');
$('#'+file.id).find('.jsdelzip').on('click',function() {
uploaderImg.removeFile( file.id );
$('#'+file.id).remove();
$.each(imgListData,function(index, item) {
if (response.id == item) {
imgListData.splice(index,1);
return false;
}
});
setFlooringPageImgsVal();
console.log(imgListData);
return false;
});
});
uploaderImg.on('uploadError', function(file) {
$( '#'+file.id ).find('p.state').text('上传出错');
});
uploaderImg.on( 'uploadComplete', function(file) {
$( '#'+file.id ).find('.progress').fadeOut();
});
function setFlooringPageImgsVal()
{
var flooring_page_imgs_val = '';
$.each(imgListData,function(index, item) {
flooring_page_imgs_val += item + ',';
});
flooring_page_imgs_val = flooring_page_imgs_val.substring(0, flooring_page_imgs_val.length - 1);
$('input[name=flooring_page_imgs]').val(flooring_page_imgs_val);
}
//运行版本change的操作
$('input:radio[name="sdk_version"]').change( function() {
var radio = document.getElementsByName("sdk_version");
var radioLength = radio.length;
for(var i = 0;i < radioLength;i++)
{
if(radio[i].checked)
{
var radioValue = radio[i].value;
}
}
$("input[name='sdk_version_copy'][value="+radioValue+"]").prop("checked",true);
$("#span_type").text(radioValue ==1?'安卓':"苹果");
$("#game_address").attr("name",radioValue ==1?'add_game_address':"ios_game_address");
});
$('input:radio[name="down_port"]').change( function() {
var radio = document.getElementsByName("down_port");
var radioLength = radio.length;
for(var i = 0;i < radioLength;i++)
{
if(radio[i].checked)
{
var radioValue = radio[i].value;
}
}
if(radioValue == 1){
$('#game_address').attr("disabled",true).closest('tr').hide();
$('#game_address').attr('style',"background:#e7e7e7;");
$('#game_address_size').attr("disabled",true).closest('tr').hide();
$('#game_address_size').attr('style',"background:#e7e7e7;");
}else{
$('#game_address').removeAttr("disabled").closest('tr').show();
$('#game_address').attr('style'," ");
$('#game_address_size').removeAttr("disabled").closest('tr').show();
$('#game_address_size').attr('style'," ");
}
});
$("#dow_num_click").click(function () {
up_dow_num();
});
function up_dow_num(){
layer.prompt(
{formType:0,title:"请输入下载数量",value:''},
function(val,index,elem){
$('input[name="dow_num"]').val(val);
layer.close(index);
}
);
}
</script>
<script type="text/javascript">
var uploaderImgScreen = WebUploader.create({
// 选完文件后,是否自动上传。
auto: true,
// swf文件路径
swf: '__STATIC__/webuploader/Uploader.swf',
// 文件接收服务端。
server: "{:U('File/uploadPicture',array('session_id'=>session_id(),'flag'=>true))}",
// 选择文件的按钮。可选。
// 内部根据当前运行是创建可能是input元素也可能是flash.
pick: {
id:'#screenshot',
multiple:true
},
fileSingleSizeLimit:3*1024*1024, //设定单个文件大小
// dnd: false,
paste: document.body,
accept: {
title: '图片',
extensions: 'png,gif,jpg,jpeg,bmp',
mimeTypes: '.png,.gif,.jpg,.jpeg,.bmp',
},
// 不压缩image, 默认如果是jpeg文件上传前会压缩一把再上传
resize: false,
disableGlobalDnd: true,
fileNumLimit:5,
threads:5,
thumb:true,
compress:false,
prepareNextFile: true,
formData: function(){return $.extend(true, {}, userInfo);},
chunked:false,
duplicate: true
});
var imgListScreenData = [];
<?php if (!empty($data['screenshot_data'])) :?>
var html = '';
$('#screenshot_thelist').css('margin-top','10px');
<?php foreach ($data['screenshot_data'] as $value1) { ?>
<?php $value1 = (int)$value1; ?>
imgListScreenData.push(<?=$value1?>);
html += '<div id="' + <?=$value1?> + '" class="item flooring_page_img_box" style="margin-right: 10px;">';
html += '<a href="javascript:;"><img src="<?=get_cover($value1,"path")?>" style="width: 100px;height: 100px;cursor: move;"></a>';
html += '<h4 class="info" style="text-align: center;">';
html += '<a href="javascript:;" class="jsdelzip table_click" style="float:none;display:inline-block;" img-id="' + <?=$value1?> + '">删除</a>';
html += '</h4>';
html += '<div class="progress progress-striped active" style="display: none;">';
html += '<div class="progress-bar" role="progressbar" style="width: 100%;">100%</div>';
html += '</div>';
html += '</div>';
<?php }?>
$('#screenshot_thelist').html(html);
$('#screenshot_thelist').children().children('h4').children('.jsdelzip').on('click', function() {
var thisId = $(this).attr('img-id');
$(this).parent().parent().remove();
$.each(imgListScreenData,function(index, item) {
if (thisId == item) {
imgListScreenData.splice(index,1);
return false;
}
});
setScreenshotVal();
});
<?php endif ;?>
var thisIndex1 = 0;
var imgScreenList = $("#screenshot_thelist");
uploaderImgScreen.on( 'fileQueued', function( file ) {
var html = '';
html += '<div id="' + file.id + '" class="item" style="margin-right: 10px;">';
html += '<a href="javascript:;"><img src="" style="width: 100px;height: 100px;cursor: move;"></a>';
html += '<h4 class="info">' + file.name + '</h4>';
html += '<p class="state">等待上传...</p>';
html += '</div>';
imgScreenList.append(html);
imgScreenList.css('margin-top','10px');
var img1 = imgScreenList.children('#'+file.id).find('img');
uploaderImgScreen.makeThumb(file, function (error, src) {
if (error) {
return;
}
img1.attr('src', src);
}, 300, 300);
});
// 文件上传过程中创建进度条实时显示。
uploaderImgScreen.on( 'uploadProgress', function( file, percentage ) {
var $li = $( '#'+file.id ),
$percent = $li.find('.progress .progress-bar');
// 避免重复创建
if ( !$percent.length ) {
$percent = $('<div class="progress progress-striped active">' +
'<div class="progress-bar" role="progressbar" style="width: 0%">' +
'</div>' +
'</div>').appendTo( $li ).find('.progress-bar');
}
$li.find('p.state').text('上传中');
$percent.css( 'width', percentage * 100 + '%' );
$percent.text( (percentage * 100).toFixed(0) + '%' );
});
/**
* 验证文件格式以及文件大小
*/
uploaderVideo.on("error",function (type){
if(type=="F_EXCEED_SIZE"){
layer.msg("视频大小不能超过3M");
}
});
uploaderImgScreen.on( 'uploadSuccess', function( file , response) {
imgListScreenData.push(Number(response.id));
console.log(imgListScreenData)
console.log(response)
setScreenshotVal();
$( '#'+file.id ).find('p.state').text('已上传').fadeOut(800);
//alert(JSON.stringify(response));
$('#'+file.id).find('h4.info').append('<a href="javascript:;" class="jsdelzip table_click" style="float:none;display:inline-block;margin-left:10px;">删除</a>');
$('#'+file.id).find('.jsdelzip').on('click',function() {
uploaderImg.removeFile( file.id );
$('#'+file.id).remove();
$.each(imgListScreenData,function(index, item) {
if (response.id == item) {
imgListScreenData.splice(index,1);
return false;
}
});
setScreenshotVal();
console.log(imgListData);
return false;
});
});
function setScreenshotVal()
{
var screen_shot = '';
$.each(imgListScreenData,function(index, item) {
screen_shot += item + ',';
});
screen_shot = screen_shot.substring(0, screen_shot.length - 1);
$('input[name=screenshot]').val(screen_shot);
}
</script>
<script>
var uploaderImgCover = WebUploader.create({
// 选完文件后,是否自动上传。
auto: true,
// swf文件路径
swf: '__STATIC__/webuploader/Uploader.swf',
// 文件接收服务端。
server: "{:U('File/uploadPicture',array('session_id'=>session_id(),'flag'=>true))}",
// 选择文件的按钮。可选。
// 内部根据当前运行是创建可能是input元素也可能是flash.
pick: {
id:'#cover',
multiple:true
},
// dnd: false,
paste: document.body,
accept: {
title: '图片',
extensions: 'png,gif,jpg,jpeg,bmp',
mimeTypes: '.png,.gif,.jpg,.jpeg,.bmp',
},
// 不压缩image, 默认如果是jpeg文件上传前会压缩一把再上传
resize: false,
disableGlobalDnd: true,
fileNumLimit:1,
threads:5,
thumb:true,
compress:false,
prepareNextFile: true,
formData: function(){return $.extend(true, {}, userInfo);},
chunked:false,
duplicate: true
});
var imgListCoverData = [];
<?php if (!empty($data['cover_data'])) :?>
var html = '';
$('#cover_thelist').css('margin-top','10px');
<?php foreach ($data['cover_data'] as $value2) { ?>
<?php $value2 = (int)$value2; ?>
imgListCoverData.push(<?=$value2?>);
html += '<div id="' + <?=$value2?> + '" class="item flooring_page_img_box" style="margin-right: 10px;">';
html += '<a href="javascript:;"><img src="<?=get_cover($value2,"path")?>" style="width: 100px;height: 100px;cursor: move;"></a>';
html += '<h4 class="info" style="text-align: center;">';
html += '<a href="javascript:;" class="jsdelzip table_click" style="float:none;display:inline-block;" img-id="' + <?=$value2?> + '">删除</a>';
html += '</h4>';
html += '<div class="progress progress-striped active" style="display: none;">';
html += '<div class="progress-bar" role="progressbar" style="width: 100%;">100%</div>';
html += '</div>';
html += '</div>';
<?php }?>
$('#cover_thelist').html(html);
$('#cover_thelist').children().children('h4').children('.jsdelzip').on('click', function() {
var thisId = $(this).attr('img-id');
$(this).parent().parent().remove();
$.each(imgListCoverData,function(index, item) {
if (thisId == item) {
imgListCoverData.splice(index,1);
return false;
}
});
setCoverVal();
});
<?php endif ;?>
var thisIndex2 = 0;
var imgCoverList = $("#cover_thelist");
uploaderImgCover.on( 'fileQueued', function( file ) {
var html = '';
html += '<div id="' + file.id + '" class="item" style="margin-right: 10px;">';
html += '<a href="javascript:;"><img src="" style="width: 100px;height: 100px;cursor: move;"></a>';
html += '<h4 class="info">' + file.name + '</h4>';
html += '<p class="state">等待上传...</p>';
html += '</div>';
imgCoverList.append(html);
imgCoverList.css('margin-top','10px');
var img1 = imgCoverList.children('#'+file.id).find('img');
uploaderImgCover.makeThumb(file, function (error, src) {
if (error) {
return;
}
img1.attr('src', src);
}, 300, 300);
});
// 文件上传过程中创建进度条实时显示。
uploaderImgCover.on( 'uploadProgress', function( file, percentage ) {
var $li = $( '#'+file.id ),
$percent = $li.find('.progress .progress-bar');
// 避免重复创建
if ( !$percent.length ) {
$percent = $('<div class="progress progress-striped active">' +
'<div class="progress-bar" role="progressbar" style="width: 0%">' +
'</div>' +
'</div>').appendTo( $li ).find('.progress-bar');
}
$li.find('p.state').text('上传中');
$percent.css( 'width', percentage * 100 + '%' );
$percent.text( (percentage * 100).toFixed(0) + '%' );
});
uploaderImgCover.on( 'uploadSuccess', function( file , response) {
imgListCoverData.push(Number(response.id));
setCoverVal();
$( '#'+file.id ).find('p.state').text('已上传').fadeOut(800);
//alert(JSON.stringify(response));
$('#'+file.id).find('h4.info').append('<a href="javascript:;" class="jsdelzip table_click" style="float:none;display:inline-block;margin-left:10px;">删除</a>');
$('#'+file.id).find('.jsdelzip').on('click',function() {
uploaderImgCover.removeFile( file.id );
$('#'+file.id).remove();
$.each(imgListCoverData,function(index, item) {
if (response.id == item) {
imgListCoverData.splice(index,1);
return false;
}
});
setCoverVal();
return false;
});
});
function setCoverVal()
{
var cover = '';
$.each(imgListCoverData,function(index, item) {
cover += item + ',';
});
cover = cover.substring(0, cover.length - 1);
$('input[name=cover]').val(cover);
}
</script>
<script>
var iconInfo = {userId:"kazaff", md5:"",icon:1}; //用户会话信息
var uploaderImgIcon = WebUploader.create({
// 选完文件后,是否自动上传。
auto: true,
// swf文件路径
swf: '__STATIC__/webuploader/Uploader.swf',
// 文件接收服务端。
server: "{:U('File/uploadPicture',array('session_id'=>session_id(),'flag'=>true))}",
// 选择文件的按钮。可选。
// 内部根据当前运行是创建可能是input元素也可能是flash.
pick: {
id:'#icon',
multiple:true
},
// dnd: false,
paste: document.body,
accept: {
title: '图片',
extensions: 'png,gif,jpg,jpeg,bmp',
mimeTypes: '.png,.gif,.jpg,.jpeg,.bmp',
},
// 不压缩image, 默认如果是jpeg文件上传前会压缩一把再上传
resize: false,
disableGlobalDnd: true,
fileNumLimit:1,
threads:5,
thumb:true,
compress:false,
prepareNextFile: true,
formData: function(){return $.extend(true, {}, iconInfo);},
chunked:false,
duplicate: true
});
var imgListIconData = [];
<?php if (!empty($data['icon_data'])) :?>
var html = '';
$('#icon_thelist').css('margin-top','10px');
<?php foreach ($data['icon_data'] as $value3) { ?>
<?php $value3 = (int)$value3; ?>
imgListIconData.push(<?=$value3?>);
html += '<div id="' + <?=$value3?> + '" class="item flooring_page_img_box" style="margin-right: 10px;">';
html += '<a href="javascript:;"><img src="<?=get_cover($value3,"path")?>" style="width: 100px;height: 100px;cursor: move;"></a>';
html += '<h4 class="info" style="text-align: center;">';
html += '<a href="javascript:;" class="jsdelzip table_click" style="float:none;display:inline-block;" img-id="' + <?=$value3?> + '">删除</a>';
html += '</h4>';
html += '<div class="progress progress-striped active" style="display: none;">';
html += '<div class="progress-bar" role="progressbar" style="width: 100%;">100%</div>';
html += '</div>';
html += '</div>';
<?php }?>
$('#icon_thelist').html(html);
$('#icon_thelist').children().children('h4').children('.jsdelzip').on('click', function() {
var thisId = $(this).attr('img-id');
$(this).parent().parent().remove();
$.each(imgListIconData,function(index, item) {
if (thisId == item) {
imgListIconData.splice(index,1);
return false;
}
});
setIconVal();
});
<?php endif ;?>
var thisIndex2 = 0;
var imgIconList = $("#icon_thelist");
uploaderImgIcon.on( 'fileQueued', function( file ) {
var html = '';
html += '<div id="' + file.id + '" class="item" style="margin-right: 10px;">';
html += '<a href="javascript:;"><img src="" style="width: 100px;height: 100px;cursor: move;"></a>';
html += '<h4 class="info">' + file.name + '</h4>';
html += '<p class="state">等待上传...</p>';
html += '</div>';
imgIconList.append(html);
imgIconList.css('margin-top','10px');
var img2 = imgIconList.children('#'+file.id).find('img');
uploaderImgIcon.makeThumb(file, function (error, src) {
if (error) {
return;
}
img2.attr('src', src);
}, 300, 300);
});
// 文件上传过程中创建进度条实时显示。
uploaderImgIcon.on( 'uploadProgress', function( file, percentage ) {
var $li = $( '#'+file.id ),
$percent = $li.find('.progress .progress-bar');
// 避免重复创建
if ( !$percent.length ) {
$percent = $('<div class="progress progress-striped active">' +
'<div class="progress-bar" role="progressbar" style="width: 0%">' +
'</div>' +
'</div>').appendTo( $li ).find('.progress-bar');
}
$li.find('p.state').text('上传中');
$percent.css( 'width', percentage * 100 + '%' );
$percent.text( (percentage * 100).toFixed(0) + '%' );
});
uploaderImgIcon.on( 'uploadSuccess', function( file , response) {
imgListIconData.push(Number(response.id));
setIconVal();
console.log(response)
$( '#'+file.id ).find('p.state').text('已上传').fadeOut(800);
//alert(JSON.stringify(response));
$('#'+file.id).find('h4.info').append('<a href="javascript:;" class="jsdelzip table_click" style="float:none;display:inline-block;margin-left:10px;">删除</a>');
$('#'+file.id).find('.jsdelzip').on('click',function() {
uploaderImgIcon.removeFile( file.id );
$('#'+file.id).remove();
$.each(imgListIconData,function(index, item) {
if (response.id == item) {
imgListIconData.splice(index,1);
return false;
}
});
setIconVal();
return false;
});
if (response.status==1001) {
alert('图片大小不得超过50k');
$('#icon_thelist').children().last().remove();
location.reload()
}
});
function setIconVal()
{
var icon = '';
$.each(imgListIconData,function(index, item) {
icon += item + ',';
});
icon = icon.substring(0, icon.length - 1);
$('input[name=icon]').val(icon);
}
</script>
<script>
$(".bnt_add").bind("click",function(){
var a= '<tr class="bns" data-id="0">'+
'<td class="l noticeinfo">CP总流水</td>' +
'<td class="r">'+
'<select name="instanceof" style="width: 50px;margin-right: 5px" >'+
'<option value="1">≥</option>'+
'<option value="2">></option>'+
'</select>'+
'<input type="text" class="txt table_text_input" name="game_amount" value="" placeholder="" style="width: 55px">' +
'<span class="form_unit" style="margin: 0 10px">分成比例</span>'+
'<input type="text" class="txt table_text_input" name="game_ratio" value="" placeholder="" style="width: 50px">' +
'<span class="form_unit">% </span>' +
'<button type="button" class="bnt_remove" data-id="0">✖</button>' +
'<button type="button" class="bnt_save" data-id="0" data-type="ladder" style="display: none">✔</button>'+
'</td>'+
'</tr>';
$(".bns:last").after(a);
})
$(document).on('click', '.bnt_remove', function(){
var that = $(this).parents("tr.bns");
var data_id = $(this).attr("data-id");
if(data_id>0){
layer.confirm('你确定要删除本档分成比例吗?', {icon: 3, title:'提示'}, function(index){
layer.close(index);
$.ajax({
//请求方式
type : "POST",
dataType: "json",
url : "{:U('delete_ratio')}",
data : {
data_id :data_id,
game_id:'{$game_id}'
},
//请求成功
success : function(result) {
if(result.result==1){
$(that).remove();
layer.msg(result.desc);
/*setTimeout(function(){
location.reload();
},1500);*/
}else{
layer.msg(result.desc);
}
},
//请求失败,包含具体的错误信息
error : function(e){
console.log(e.status);
console.log(e.responseText);
}
});
});
}else{
$(that).remove();
}
});
$(document).on('input propertychange', 'select[name=instanceof]', function(){
var that = $(this).parents("tr.bns");
$(that).find("button[class=bnt_save]").css("display","")
})
$(document).on('input propertychange', 'input[name=game_ratio]', function(){
var that = $(this).parents("tr.bns");
$(that).find("button[class=bnt_save]").css("display","")
})
$(document).on('input propertychange', 'input[name=game_amount]', function(){
var that = $(this).parents("tr.bns");
$(that).find("button[class=bnt_save]").css("display","")
})
/* $('input[name=game_ratio]').live('input propertychange', function()
{
//获取input 元素,并实时监听用户输入
//逻辑
})*/
$(document).on('click', '.bnt_save', function(){
var data_id = $(this).attr("data-id");
var data_type =$(this).attr("data-type");
var that = $(this).parents("tr.bns");
var total_amount = $(that).find("input[name=game_amount]").val();
var game_ratio = $(that).find("input[name=game_ratio]").val();
var instanceofs = $(that).find("select[name=instanceof]").val();
$.ajax({
//请求方式
type : "POST",
dataType: "json",
url : "{:U('edit_ratio')}",
data : {
data_type:data_type,
data_id :data_id,
total_amount:total_amount,
game_ratio:game_ratio,
game_id:'{$game_id}',
instanceof:instanceofs
},
//请求成功
success : function(result) {
if(result.result==1){
layer.msg(result.desc);
$(that).find("button[class=bnt_save]").css("display","none")
/*setTimeout(function(){
location.reload();
},1500);*/
}else{
layer.msg(result.desc);
}
},
//请求失败,包含具体的错误信息
error : function(e){
console.log(e.status);
console.log(e.responseText);
}
});
});
</script>
<style>
.layui-transfer-box{
overflow: hidden;
height: 410px!important;
}
</style>
</block>