westdc-zf1/public/js/voice-submit.js

321 lines
10 KiB
JavaScript

var upload1_count = 0;
var upload2_count = 0;
var upload1, upload2;
window.onload = function() {
upload1 = new SWFUpload({
// Backend Settings
upload_url: "/service/upload",
post_params: param.image,
// File Upload Settings
file_size_limit : "2048", // 2MB
file_types : "*.jpg;*.gif;*.png",
file_types_description : "Image Files",
file_upload_limit : "5",
file_queue_limit : "5",
// Event Handler Settings (all my handlers are in the Handler.js file)
file_dialog_start_handler : fileDialogStart,
file_queued_handler : fileQueued,
file_queue_error_handler : fileQueueError,
file_dialog_complete_handler : fileDialogComplete,
upload_start_handler : uploadStart,
upload_progress_handler : uploadProgress,
upload_error_handler : uploadError,
upload_success_handler : uploadSuccess,
upload_complete_handler : uploadComplete,
// Button Settings
button_image_url : "/static/img/uploadbtn.gif",
button_placeholder_id : "spanButtonPlaceholder1",
button_width: 82,
button_height: 38,
// Flash Settings
flash_url : "/static/lib/swfupload/swfupload.swf",
custom_settings : {
progressTarget : "fsUploadProgress1",
cancelButtonId : "btnCancel1"
},
// Debug Settings
debug: false
});
upload2 = new SWFUpload({
// Backend Settings
upload_url: "/service/upload",
post_params: param.voice,
// File Upload Settings
file_size_limit : "20480", // 20mb
file_types : "*.mp3",
file_types_description : "MP3 Files",
file_upload_limit : "1",
file_queue_limit : "1",
// Event Handler Settings (all my handlers are in the Handler.js file)
file_dialog_start_handler : fileDialogStart,
file_queued_handler : fileQueued,
file_queue_error_handler : fileQueueError,
file_dialog_complete_handler : fileDialogComplete,
upload_start_handler : uploadStart,
upload_progress_handler : uploadProgress,
upload_error_handler : uploadError,
upload_success_handler : uploadSuccess,
upload_complete_handler : uploadComplete,
// Button Settings
button_image_url : "/static/img/uploadbtn.gif",
button_placeholder_id : "spanButtonPlaceholder2",
button_width: 82,
button_height: 38,
// Flash Settings
flash_url : "/static/lib/swfupload/swfupload.swf",
custom_settings : {
progressTarget : "fsUploadProgress2",
cancelButtonId : "btnCancel2"
},
// Debug Settings
debug: false
});
}
var mp3player = {
loaded : function(){
// Local copy of jQuery selectors, for performance.
var my_jPlayer = $("#jquery_jplayer"),
my_trackName = $("#jp_container .track-name"),
my_playState = $("#jp_container .play-state"),
my_extraPlayInfo = $("#jp_container .extra-play-info");
// Some options
var opt_play_first = false, // If true, will attempt to auto-play the default track on page loads. No effect on mobile devices, like iOS.
opt_auto_play = false, // If true, when a track is selected, it will auto-play.
opt_text_playing = "Now playing", // Text when playing
opt_text_selected = "Track selected"; // Text when not playing
// Change the time format
$.jPlayer.timeFormat.padMin = false;
$.jPlayer.timeFormat.padSec = false;
$.jPlayer.timeFormat.sepMin = " min ";
$.jPlayer.timeFormat.sepSec = " sec";
// Initialize the play state text
my_playState.text(opt_text_selected);
// Instance jPlayer
my_jPlayer.jPlayer({
ready: function () {
},
timeupdate: function(event) {
my_extraPlayInfo.text(parseInt(event.jPlayer.status.currentPercentAbsolute, 10) + "%");
},
play: function(event) {
},
pause: function(event) {
},
ended: function(event) {
},
swfPath: "/static/lib/jplayer",
cssSelectorAncestor: "#jp_container",
supplied: "mp3",
solution:"flash,html"
});
// Create click handlers for the different tracks
$(".jp-play").click(function(e) {
my_jPlayer.jPlayer("setMedia", {
mp3: $(this).attr('rel'),
errorAlerts : true,
warningAlerts : false
});
my_jPlayer.jPlayer("play");
$('#player_status').show();
$(this).blur();
return false;
});
$('.jp-stop').click(function(e){
$('#player_status').hide();
});
$('.voice_del').click(function(e) {
$(this).deleteatt({
'id':$(this).attr('rel'),
'url':'/service/delatt',
'content':'是否删除'+$(this).next('h4').html(),
'item_prefix':'thumbItems_',
'callback': function(){
upload2.setStats({successful_uploads:0});
upload2.setFileUploadLimit(1);
my_jPlayer.jPlayer( "stop" );
}
});
});
},
makeHtml : function(data){
html = '<div class="well well-small" id="thumbItems_'+data.attid+'">'
+' <button type="button" class="voice_del close glyphicon glyphicon-trash" rel="'+data.attid+'" title="删除"></button>'
+' <h4>'+data.realname+'</h4>'
+' <div id="jp_container" class="demo-container">'
+' <div class="btn-group">'
+' <button type="button" class="btn btn-default jp-play" rel="/uploads/'+data.file_url+'"><span class="glyphicon glyphicon-play"></span></button>'
+' <button type="button" class="btn btn-default jp-pause"><span class="glyphicon glyphicon-pause"></span></button>'
+' <button type="button" class="btn btn-default jp-stop"><span class="glyphicon glyphicon-stop"></span></button>'
+' <button type="button" class="btn btn-default jp-mute"><span class="glyphicon glyphicon-volume-down"></span></button>'
+' <button type="button" class="btn btn-default jp-volume-max"><span class="glyphicon glyphicon-volume-up"></span></button>'
+' </div>'
+' <span id="player_status" style="display:none;">'
+' 音量:<a class="jp-volume-bar" href="#">|&lt;----------&gt;|</a>'
+' <span class="extra-play-info"></span> of <span class="jp-duration"></span>, which is <span class="jp-current-time"></span>'
+' </span>'
+'<input type="hidden" name="voice" value="'+data.file_url+'" />'
+' </div>'
+'</div>';
return html;
}
}
var thumbfunc = {
binddelbtn : function(id){
this.dom = $('#thumbItems_'+id).children('.media-body').children('.thumb_del');
this.dom.bind('click',function(e) {
$(this).deleteatt({
'id':$(this).attr('rel'),
'url':'/service/delatt',
'content':'是否删除'+$(this).next('h4').html(),
'item_prefix':'thumbItems_',
'callback': thumbfunc.queueset()
});
});
},
loaded : function(){
$('#thumbs').children('div').each(function(index, element) {
this.delbtn = $(this).children('.media-body').children('.thumb_del');
$(this).hover(
function(){
$(this).addClass('hovered');
},
function(){
$(this).removeClass('hovered');
}
)
this.delbtn.bind('click',function(e) {
$(this).deleteatt({
'id':$(this).attr('rel'),
'url':'/service/delatt',
'content':'是否删除'+$(this).next('h4').html(),
'item_prefix':'thumbItems_',
'callback': thumbfunc.queueset()
});
});
});
},
queueset : function(){
this.chilrenslen = $('#thumbs').children('div').length;
upload1.setStats({successful_uploads:this.chilrenslen});
upload1.setFileUploadLimit(5- this.chilrenslen);
upload1.setFileQueueLimit(5- this.chilrenslen);
},
filetype : function(mime){
this.patrn=/image/;
if (this.patrn.test(mime))
{
return "image";
}
this.patrn=/audio/
if(this.patrn.test(mime))
{
return "audio";
}
return null;
},
makeHtml : function(data){
this.imgsrc = typeof(data.file_url) == 'undefined' ? data.fileurl:data.file_url;
this.imgsrc = typeof(data.thumb[400]) == 'undefined' ? this.imgsrc : data.thumb[400].url;
this.imgsrc = typeof(data.thumb[200]) == 'undefined' ? this.imgsrc : data.thumb[200].url;
html = '<div class="media well well-small" id="thumbItems_'+data.attid+'">'
+'<a class="pull-left" href="javascript:void(0);">'
+'<img class="media-object img-thumbnail" src="/uploads/'+ this.imgsrc +'">'
+'</a>'
+'<div class="media-body">'
+'<button type="button" class="thumb_del close glyphicon glyphicon-trash" rel="'+data.attid+'" title="删除"></button>'
+'<h4 class="media-heading">'+data.realname+'</h4>'
+'<textarea name="thumb['+data.attid+'][description]" class="form-control" rows="2"></textarea>'
+'<input type="hidden" name="thumb['+data.attid+'][id]" value="'+data.attid+'" />'
+'</div>'
+'</div>';
return html;
}
};
function voicesubmited(data){
if (typeof(data)=='object')
{
if(typeof(data.error)!='undefined')
{
$("#alert-info").attr('class','alert alert-danger');
$("#alert-info").html(data.error);
return false;
}
if(typeof(data.success)!='undefined')
{
$("#alert-info").attr('class','alert alert-success');
if(typeof(_this.source) != 'undefined' && _this.source == 'edit'){
$("#alert-info").html("编辑成功!(页面将自动跳转,<a href=\"/member\" class=\"alert-link\">如果没有跳转请点击这里</a>)");
}else{
$("#alert-info").html("投稿成功!通过评审后会自动发布(页面将自动跳转,<a href=\"/member\" class=\"alert-link\">如果没有跳转请点击这里</a>)");
}
setTimeout("window.location.href ='/member'",3000);
return false;
}
}
else{
$("#alert-info").attr('class','alert alert-danger');
$("#alert-info").html('服务器掉链子了,<a href="/service/reporterror/?content=voice_submit_error">通知管理员揍它</a>');
return false;
}
}
$(document).ready(function(e) {
$('#tags').tagsInput({width:'auto'});//taginput
$('#submit_btn').click(function(e) {//submit
editor.sync();
$.ajax({
'type':"POST",
'url':"/voice/submit",
'data':$("#voice_submit").serialize(),
'success':voicesubmited,
'timeout': 30000,
'error': function(){
$("#alert-info").attr('class','alert alert-danger');
$("#alert-info").html("出现错误,请稍后重试");
$('#submit-loading').hide();
return false;
},
'beforeSend': function(){
$("#submit_btn").addClass('disabled');
$("#submit_btn").attr('disabled','disabled');
$('#submit-loading').show();
},
complete: function(){
$("#submit_btn").removeClass('disabled');
$("#submit_btn").removeAttr('disabled');
$('#submit-loading').hide();
}
});
});
});