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.

431 lines
17 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="body">
<link rel="stylesheet" type="text/css" href="__STATIC__/bootstrap.min.css" media="all">
<link rel="stylesheet" type="text/css" href="__CSS__/admin_table.css" media="all">
<script type="text/javascript" src="__JS__/select2.min.js"></script>
<link rel="stylesheet" href="__CSS__/select2.min.css" type="text/css" />
<link rel="stylesheet" type="text/css" href="__STATIC__/webuploader/webuploader.css" media="all">
<script src="__STATIC__/md5.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript" src="__STATIC__/webuploader/webuploader.js"></script>
<div class="main-place">
<span class="main-placetitle">位置</span>
<ul class="main-placeul">
<li><a href="{:U('Game/lists')}">游戏</a></li>
<li><a href="{:U('Game/lists')}">游戏管理</a></li>
<li><a href="#">{$meta_title}</a></li>
</ul>
</div>
<!-- 标签页导航 -->
<div class="tab-wrap">
<div class="tab_nav jstabnav">
<ul>
<li data-tab="tab1" class="current"><a href="javascript:void(0);">基础</a></li>
</ul></div>
<div class="tab-content tab_content">
<!-- 表单 -->
<form id="form" action="{:U('addSource')}" method="post" class="form-horizontal">
<!-- 基础文档模型 -->
<div id="tab1" class="tab-pane in tab1 tab_table">
<table border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="l">游戏名称:</td>
<td class="r">
<select id="game_id" name="game_id" class="select_gallery">
<option value="0" selected="">请选择游戏</option>
<volist name=':get_game_list()' id='vo'>
<option value="{$vo.id}" sdk_version="{$vo.sdk_version}">{$vo.game_name}</option>
</volist>
</select>
<input type="hidden" id="game_name" name="game_name" value="" />
</td>
<td class="l">运营平台</td>
<td class="r table_radio">
<volist name=":get_systems_list()" id="vo"><gt name="key" value="0">
<if condition="$Think.get.ratio_type neq '' ">
<eq name="Think.get.ratio_type" value="$key">
<label id="type{$key}"><input type="radio" class="inp_radio js-typeradio" value="{$key}" name="file_type" checked > <span class="type{$key}">{$vo}</span></label>
<else />
<label id="type{$key}" style="display:none"><input type="radio" class="inp_radio js-typeradio" value="{$key}" name="file_type" > <span class="type{$key}" >{$vo}</span></label>
</eq>
<else />
<label id="type{$key}"><input type="radio" class="inp_radio js-typeradio" value="{$key}" name="file_type" > <span class="type{$key}">{$vo}</span></label>
</if></gt>
</volist>
</td>
</tr>
<tr>
<td class="l">上传原包</td>
<td class="r" colspan='1'>
<div id="uploader" class="wu-example">
<div class="btns">
<div id="picker">上传原包</div>
</div>
<!--用来存放文件信息-->
<div id="thelist" class="uploader-list">
</div>
</div>
<input type="hidden" id="data" name="data" value="000"/>
<input type="hidden" id="file_id" name="file_id" value="{$data['file_id']}"/>
<input type="hidden" id="file_name" name="file_name" value="{$data['file_name']}"/>
<input type="hidden" id="file_url" name="file_url" value="{$data['file_url']}"/>
<input type="hidden" id="file_name2" name="file_name2" value="{$data['file_name2']}"/>
<input type="hidden" id="file_url2" name="file_url2" value="{$data['file_url2']}"/>
</td>
<if condition="I('ratio_type') eq 1">
<td class="l">原包名称:</td>
<td class="r" colspan='1'>
<input type="text" class="txt" name="pack_name" value="">
</td>
</if>
<if condition="I('ratio_type') eq 2">
<td class="l">上传描述文件:</td>
<td class="r" colspan='1'>
<div id="uploader" class="wu-example">
<div class="btns">
<div id="picker2">上传描述文件</div>
</div>
<!--用来存放文件信息-->
<div id="thelist2" class="uploader-list">
</div>
</div>
</td>
</if>
</tr>
<tr>
<td class="l">原包版本:</td>
<td class="r">
<input type="text" class="txt" name="version" value="">
</td>
<td class="l">原包大小:</td>
<td class="r">
<input type="text" class="txt" name="gsize" style="background-color:#E8E8E8" value="无需填写,自动生成" disabled="disabled">
</td>
</tr>
<tr>
<td class="l">备注:</td>
<td class="r" colspan='3'>
<textarea name="remark" class="txt_area"></textarea>
</td>
</tr>
</tbody>
</table>
</div>
<div class="form-item cf">
<button class="submit_btn ajax-post " id="submit" type="submit" target-form="form-horizontal">确 定</button>
</div>
</form>
</div>
</div>
</block>
<block name="script">
<script type="text/javascript" src="__STATIC__/datetimepicker/js/bootstrap-datetimepicker.min.js"></script>
<script type="text/javascript">
//导航高亮
highlight_subnav('{:U('developers/source')}');
$('.side-sub-menu').eq(0).show();
$('#submit').click(function(){
$('#form').submit();
});
$(function(){
Think.setValue("game_id", "{$Think.get.game_id|default = 0}");
$("#game_name").val($("#game_id option:selected").text());
$(".select_gallery").select2();
$('.date').datetimepicker({
format: 'yyyy-mm-dd',
language:"zh-CN",
minView:2,
autoclose:true
});
$('.time').datetimepicker({
format: 'yyyy-mm-dd hh:ii',
language:"zh-CN",
minView:2,
autoclose:true
});
showTab();
});
var trid = $('.js-typeradio:checked').siblings('input').css({'display':'none'}).attr('id');
$('.'+trid).hide();
var ratio_type=$("input[type=radio]:checked").val();
if(ratio_type == 1){
var file_type="apk";
}else if(ratio_type == 2){
var file_type="ipa";
}
$("#game_id").change(function(){
$(".inp_radio").click();
});
$(".inp_radio").click(function(){
if($("#game_id option:selected").val()==0){
alert('请选择游戏');
return false;
}
var ratio_type=$("#game_id").children('option:selected').attr('sdk_version');
if(ratio_type == 1){
var file_type="apk";
}else if(ratio_type == 2){
var file_type="ipa";
}
var str = location.href,game_id=$("#game_id option:selected").val();
str = str.replace('.html','');
str = str+'/game_id/'+game_id+'/ratio_type/'+ratio_type;
window.location.href=str;
});
var userInfo = {userId:"kazaff", md5:""}; //用户会话信息
var chunkSize = 5000 * 1024; //分块大小
var uniqueFileName = null; //文件唯一标识符
var md5Mark = null;
var backEndUrl = "{:U('File/shard_upload',array('session_id'=>session_id()))}";
WebUploader.Uploader.register({
"before-send-file" : "beforeSendFile",
"before-send" : "beforeSend",
"after-send-file" : "afterSendFile"
}, {
beforeSendFile: function(file){
//秒传验证
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){
//分片验证是否已传过,用于断点续传
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){
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);
}, function(jqXHR, textStatus, errorThrown){
task.reject();
});
return $.when(task);
}else{
//UploadComlate(file);
}
}
});
var uploader = WebUploader.create({
// 选完文件后,是否自动上传。
auto: true,
// swf文件路径
swf: '__STATIC__/webuploader/Uploader.swf',
// 文件接收服务端。
server: "{:U('File/shard_upload',array('session_id'=>session_id()))}",
// 选择文件的按钮。可选。
// 内部根据当前运行是创建可能是input元素也可能是flash.
pick: {id:'#picker'},
//dnd: "#theList",
paste: document.body,
// 不压缩image, 默认如果是jpeg文件上传前会压缩一把再上传
resize: false,
accept:{extensions: file_type,mimeTypes:'.'+file_type},
disableGlobalDnd: true,
fileNumLimit:1,
threads:3,
compress: false,
prepareNextFile: true,
formData: function(){return $.extend(true, {}, userInfo);},
duplicate:true,
chunked:true,
chunkSize: 5*1000*1024,
duplicate: true
});
// 当有文件被添加进队列的时候
uploader.on( 'fileQueued', function( file ) {
$("#thelist").append( '<div id="' + file.id + '" class="item">' +
'<h4 class="info">' + file.name + '</h4>' +
'<p class="state">等待上传...</p>' +
'</div>' );
});
// 文件上传过程中创建进度条实时显示。
uploader.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) + '%' );
});
uploader.on( 'uploadSuccess', function( file , response) {
$( '#'+file.id ).find('p.state').text('已上传');
// alert(JSON.stringify(response));
if(!response.chunk){
$("#file_name").val(response.name);
$("#file_url").val(response.path);
}
//alert($("#file_name").val()+";"+$("#file_url").val()+";"+$("#file_size").val())
});
uploader.on( 'uploadError', function( file ) {
$( '#'+file.id ).find('p.state').text('上传出错');
});
uploader.on( 'uploadComplete', function(file) {
$( '#'+file.id ).find('.progress').fadeOut();
});
//苹果
var uploader = WebUploader.create({
// 选完文件后,是否自动上传。
auto: true,
// swf文件路径
swf: '__STATIC__/webuploader/Uploader.swf',
// 文件接收服务端。
server: "{:U('File/shard_upload',array('session_id'=>session_id(),'typee'=>1))}",
// 选择文件的按钮。可选。
// 内部根据当前运行是创建可能是input元素也可能是flash.
pick: {id:'#picker2'},
//dnd: "#theList",
paste: document.body,
// 不压缩image, 默认如果是jpeg文件上传前会压缩一把再上传
resize: false,
accept:{extensions:"mobileprovision",mimeTypes:'.mobileprovision'},
disableGlobalDnd: true,
fileNumLimit:1,
threads:3,
compress: false,
prepareNextFile: true,
formData: function(){return $.extend(true, {}, userInfo);},
duplicate:true,
chunked:true,
chunkSize: 5*1000*1024,
duplicate: true
});
// 当有文件被添加进队列的时候
uploader.on( 'fileQueued', function( file2 ) {
$("#thelist2").append( '<div id="' + file2.id + '" class="item">' +
'<h4 class="info">' + file2.name + '</h4>' +
'<p class="state">等待上传...</p>' +
'</div>' );
});
// 文件上传过程中创建进度条实时显示。
uploader.on( 'uploadProgress', function( file2, percentage2 ) {
var $li = $( '#'+file2.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', percentage2 * 100 + '%' );
$percent.text( (percentage2 * 100).toFixed(0) + '%' );
});
uploader.on( 'uploadSuccess', function( file2 , response2) {
$( '#'+file2.id ).find('p.state').text('已上传');
// alert(JSON.stringify(response2));
if(!response2.chunk){
$("#file_name2").val(response2.name);
$("#file_url2").val(response2.path);
}
});
uploader.on( 'uploadError', function( file2 ) {
$( '#'+file2.id ).find('p.state').text('上传出错');
});
uploader.on( 'uploadComplete', function(file2) {
$( '#'+file2.id ).find('.progress').fadeOut();
});
</script>
</block>