//INIT
jQT = new $.jQTouch({
icon: 'img/istreamdev.png',
addGlossToIcon: true,
useFastTouch: false,
startupScreen: 'img/startup.png',
statusBar: 'black',
iconIsGlossy: true,
fullscreen: true,
preloadImages: [
'img/chevron.png',
'img/back_button.png',
'img/back_button_clicked.png',
'img/button_clicked.png',
'img/button.png',
'img/button_clicked.png',
'img/loading.gif',
'img/toolbar.png',
'img/on_off.png',
'img/loading.gif',
'img/audio.png',
'img/epg.png',
'img/media.png',
'img/record.png',
'img/timers.png',
'img/timeron.png',
'img/timeroff.png',
'img/timerrec.png',
'img/tv.png',
'img/video.png',
'img/stream.png',
'img/stream_clicked.png',
'img/istreamdev.png',
'img/mask.png',
'img/nologoTV.png',
'img/nologoREC.png',
'img/nologoMEDIA.png',
'img/rec.png',
'img/rec_clicked.png',
'img/sw-alpha.png',
'img/sw-button-cancel.png',
'img/sw-button-done.png',
'img/sw-header.png',
'img/sw-slot-border.png',
'img/nologoTV-mini.jpg'
]
});
// [GENERIC STUFF]
// Global variable
$(document).ready(function(e){
dataString = "action=getGlobals";
showStatus( 0,"Getting configuration data" );
if ( navigator.userAgent.match(/iPad/i)) {
is_ipad = true;
} else {
is_ipad = false;
}
$.getJSON("bin/backend.php",
dataString,
function(data){
streamdev_server = data.streamdev_server;
rec_path = data.rec_path;
video_path = data.video_path;
audio_path = data.audio_path;
epg_maxdays = data.epg_maxdays;
if (streamdev_server != "" && streamdev_server != "null") {
addVdr();
showStatus( 0,"Getting channels list" );
gen_formchanlist();
gen_epgdatelist();
genepg_timelist();
}
if ( video_path != "" && video_path != "null") {
addVideofiles();
}
if ( audio_path != "" && audio_path != "null" ) {
addAudiofiles();
}
getRunningSessions();
});
});
function showStatus( timeout, message ) {
status_box = $('#status_box');
if( timeout == 0 ) {
status_box.html(message);
status_box.show();
setTimeout( function() { showStatus( 1, message ); }, 3000 );
} else if( timeout == 1 ) {
status_box.hide();
}
}
function addVdr() {
vdrmenu = '
\n \n';
vdrmenu += ' ';
vdrmenu += ' ';
vdrmenu += ' ';
vdrmenu += ' \n ';
$('#home #runningsessions').after(vdrmenu);
}
function addVideofiles() {
videomenu = ' ';
if ( $('#home #filemenu').length == 0 ) {
$('#home').append('');
}
$('#home #filemenu').append(videomenu);
}
function addAudiofiles() {
audiomenu = ' ';
if ( $('#home #filemenu').length == 0 ) {
$('#home').append('');
}
$('#home #filemenu').append(audiomenu);
}
//Goto home
$('#home_but').tap(function(event) {
event.preventDefault();
$(this).parents('div').find('a').unbind("tap");
$('#home').bind('pageAnimationEnd', function(event, info){
if (info.direction == 'in') {
$('#jqt div[rel="browser"]').remove();
$('#home').unbind('pageAnimationEnd');
}
});
jQT.goTo('#home','dissolve');
});
//JSON query loading handler
function json_start(button) {
$(button).addClass('active');
$('#loader').addClass("loader");
$('#loader').css("top", window.pageYOffset);
}
function json_complete(destination,effect) {
jQT.goTo(destination,effect);
//$('#loader').removeClass("loader");
$('a').removeClass('active');
}
function hide_loader() {
$('#loader').removeClass("loader");
$('a').removeClass('active');
}
function reinitDivs() {
$('#categories #cat_menu').html('');
$('#channels #chan_menu').html('');
$('#timers ul[rel="timers"]').html('');
}
// Binds
//hide "toggle" elements to lighten animation
$(document).ready(function(e){
$('div').bind('pageAnimationEnd', function(event, info){
if (info.direction == 'in') {
//$('#loader').removeClass("loader");
$(this).find('li[rel="toggle"]').show();
}
})
$('div').bind('pageAnimationStart', function(event, info){
$('#loader').removeClass("loader");
if (info.direction == 'in') {
$(this).find('li[rel="toggle"]').hide();
}
})
});
//disable links of page while animation
$('a[class="back"]').tap(function(event) {
event.preventDefault();
$(this).parents('div').find('a').unbind("tap");
});
//reinit RunningSessions when going to Home:
$(document).ready(function(e){
$('#home').bind('pageAnimationStart', function(event, info){
if (info.direction == 'in') {
getRunningSessions();
}
})
});
//trick to prevent animation bug with object.
$(document).ready(function(e){
$('#streaming').bind('pageAnimationEnd', function(event, info){
if (info.direction == 'in') {
var session = $('#streaming span[rel="session"]').text();
var name = $('#streaming span[rel="name"]').text();
playvideo(session,name);
}
})
$('#streaming').bind('pageAnimationStart', function(event, info){
var session = $('#streaming span[rel="session"]').text();
if (info.direction == 'out') {
var time = new Date();
$('#streaming #player').html(' ');
}
})
});
//preload logos
function preloadLogos() {
showStatus( 0,"Preloading logo pictures" );
$.getJSON("bin/genlogolist.php",
dataString,
function(data){
for (var i = data.length - 1; i >= 0; i--) {
(new Image()).src = data[i];
};
});
}
// [/GENERIC STUFF]
// [HOME SECTION]
//buttons
$('#home #categories_but').tap(function(event) {
event.preventDefault();
json_start(this);
gen_categories();
return false;
});
$('#home #recording_but').tap(function(event) {
event.preventDefault();
json_start(this);
browser = 1;
gen_browser(rec_path,browser,"Recordings","rec");
return false;
});
$('#home #timers_but').tap(function(event) {
event.preventDefault();
json_start(this);
gen_timers();
return false;
});
$('#home #epg_but').tap(function(event) {
event.preventDefault();
json_start(this);
json_complete('#epg','dissolve');
return false;
});
$('#home #video_but').tap(function(event) {
event.preventDefault();
json_start(this);
browser = 1;
gen_browser(video_path,browser,"Videos","vid");
return false;
});
$('#home #audio_but').tap(function(event) {
event.preventDefault();
json_start(this);
browser = 1;
gen_browser(audio_path,browser,"Audio","aud");
return false;
});
$('#home #runningsessions li a').tap(function(event) {
event.preventDefault();
json_start(this);
var session = $(this).attr('rel');
if (session=="killsessions") {
var confirmation = confirm("Delete all active session?");
if ( confirmation == false ) {
hide_loader();
return false;
}
var dataString = 'action=stopBroadcast&session=all';
$.getJSON("bin/backend.php",
dataString,
function(data) {
var status = data.status;
var message = data.message;
hide_loader();
getRunningSessions();
});
} else {
gen_streaming(session);
}
return false;
});
// Get Active broadcast & encoding sessions
function getRunningSessions() {
showStatus( 0,"Getting active sessions" );
var dataString = "action=getRunningSessions";
home_runningsessions = $('#home #runningsessions');
home_runningsessions.html(' \nChecking running session ');
//Json call to get category array
$.getJSON("bin/backend.php",
dataString,
function(data){
home_runningsessions.html(' ');
if ( data.broadcast.length >= 1 ) {
$.each(data.broadcast, function(i,broadcast){
session = broadcast.session;
name = broadcast.name;
type = broadcast.type;
encoding = broadcast.encoding;
if (encoding == 1) { encstatus = '*'; }
else { encstatus = ''; }
if (type == 'tv') { var pic='tv.png'; }
else if (type == 'rec') { var pic='record.png'; }
else if (type == 'vid') { var pic='video.png'; }
home_runningsessions.append(' ');
});
home_runningsessions.append(' ');
}
else {
home_runningsessions.append(' ');
}
});
}
// [/HOME SECTION]
// [TV SECTION]
//buttons
$('#categories ul#cat_menu a').tap(function(event) {
event.preventDefault();
json_start(this);
var category = $(this).text();
gen_channels(category);
return false;
});
$('#channels ul#chan_menu .chan_but').tap(function(event) {
event.preventDefault();
json_start(this);
var channame = $(this).find('span[class="name"]').text();
var channumber = $(this).find('small[class="counter"]').text();
gen_streamchannel(channame,channumber);
return false;
});
//Gen Categories
function gen_categories() {
cat_menu = $("#categories #cat_menu");
cat_menu.html('');
var dataString = "action=getTvCat";
//Json call to get category array
$.getJSON("bin/backend.php",
dataString,
function(data){
$.each(data.categories, function(i,categories){
if ( i > 10 ) {
togglestatus = "toggle";
}
else {
togglestatus = "";
}
cat_menu.append('' + categories.name + ' ' + categories.channels + ' ');
});
cat_menu.find('li[rel="toggle"]').hide();
json_complete('#categories','dissolve');
})
}
//Gen Channels
function gen_channels(category) {
chan_menu = $("#channels #chan_menu");
chan_menu.html('');
var dataString = "action=getTvChan&cat=" + encodeURIComponent(category);
//Json call to get category array
$.getJSON("bin/backend.php",
dataString,
function(data){
$.each(data.channel,function(i,channel){
//trick to lower cpu while animating. When the page have too much elements, it flickers.
if ( i <= 10 ) {
chan_menu.append('' + channel.number + ' ' + channel.name + ' ');
}
else {
chan_menu.append('' + channel.number + ' ' + channel.name + ' ');
}
});
chan_menu.find('li[rel="toggle"]').hide();
json_complete('#channels','dissolve');
})
}
// [/TV SECTION]
// [STREAM SECTION]
//buttons
$('#streamchannel span.streamButton a').tap(function(event) {
stream_channel = $("#streamchannel");
event.preventDefault();
json_start(this);
var type = stream_channel.find('span[rel="type"]').text();
var url = stream_channel.find('span[rel="url"]').text();
var mode = $(this).attr('id');
start_broadcast(type,url,mode);
return false;
});
$('#streamchannel span.recButton a').tap(function(event) {
stream_channel = $("#streamchannel");
event.preventDefault();
json_start(this);
var id = "new";
var active= 1;
var name = stream_channel.find('span[class="name_now"]').text();
name = name.substr(4,name.length);
var channumber = stream_channel.find('span[rel="number"]').text();
var channame = stream_channel.find('span[rel="channame"]').text();
date = new Date();
var rec_year = date.getFullYear();
var rec_month = date.getMonth()+1;
rec_month = str_pad(rec_month,2,'0','STR_PAD_LEFT');
var rec_day = date.getDate();
rec_day = str_pad(rec_day,2,'0','STR_PAD_LEFT');
var rec_date = rec_year + "/" + rec_month + "/" + rec_day;
var epgtime = stream_channel.find('span[class="epgtime_now"]').text();
var starttime = epgtime.substr(0,2) + epgtime.substr(3,2);
var endtime = epgtime.substr(6,2) + epgtime.substr(9,2);
gen_edittimer(id,name,active,channumber,channame,rec_date,starttime,endtime);
return false;
});
$('#streamrec span.streamButton a').tap(function(event) {
stream_rec = $("#streamrec");
event.preventDefault();
json_start(this);
var type = stream_rec.find('span[rel="type"]').text();
var url = stream_rec.find('span[rel="url"]').text();
var mode = $(this).attr('id');
start_broadcast(type,url,mode);
return false;
});
$('#streamvid span.streamButton a').tap(function(event) {
stream_vid = $("#streamvid");
event.preventDefault();
json_start(this);
var type = stream_vid.find('span[rel="type"]').text();
var url = stream_vid.find('span[rel="url"]').text();
var mode = $(this).attr('id');
start_broadcast(type,url,mode);
return false;
});
$('#streaming span.streamButton a[rel="stopbroadcast"]').tap(function(event) {
event.preventDefault();
json_start(this);
var session = $("#streaming").find('span[rel="session"]').text();
stop_broadcast(session);
return false;
});
//Gen tv start stream
function gen_streamchannel(channame,channumber) {
stream_channel = $('#streamchannel');
stream_channel.find('h1').html( ' ' +channame);
stream_channel.find('#thumbnail').attr('src','logos/' + channame + ".png");
var dataString = "action=getChanInfo&chan=" + channumber;
//Json call to get tv program info
$.getJSON("bin/backend.php",
dataString,
function(data){
var program = data.program;
stream_channel.find('span[class="name_now"]').html( 'Now: ' + program.now_title );
stream_channel.find('span[class="epgtime_now"]').html( program.now_time );
stream_channel.find('span[class="desc_now"]').html( program.now_desc );
stream_channel.find('span[class="name_next"]').html( 'Next: ' + program.next_title );
stream_channel.find('span[class="epgtime_next"]').html( program.next_time );
stream_channel.find('span[rel="url"]').html(streamdev_server + channumber);
stream_channel.find('span[rel="type"]').html('tv');
stream_channel.find('span[rel="number"]').html(channumber);
stream_channel.find('span[rel="channame"]').html(channame);
json_complete('#streamchannel','dissolve');
});
}
function gen_streamrec(folder,path) {
var dataString = "action=getRecInfo&rec=" + encodeURIComponent(path);
stream_rec = $('#streamrec');
//Json call to get rec info
$.getJSON("bin/backend.php",
dataString,
function(data){
var program = data.program;
stream_rec.find('h1').html(' ' + program.name);
stream_rec.find('#thumbnail').attr('src','logos/' + program.channel + ".png");
stream_rec.find('span[class="name_now"]').html( program.name );
stream_rec.find('span[class="epgtime_now"]').html( 'Recorded: ' + program.recorded );
stream_rec.find('span[class="desc_now"]').html( program.desc );
stream_rec.find('span[rel="url"]').html(path);
stream_rec.find('span[rel="type"]').html('rec');
json_complete('#streamrec','dissolve');
});
}
function gen_streamvid(filename,path) {
var dataString = "action=getVidInfo&file=" + encodeURIComponent(path);
stream_vid = $('#streamvid');
//Json call to get rec info
$.getJSON("bin/backend.php",
dataString,
function(data){
var program = data.program;
var time = new Date();
stream_vid.find('h1').html(' ' + program.name);
stream_vid.find('#thumbnail').attr('src','ram/temp-logo.png?'+time);
stream_vid.find('span[class="name_now"]').html( program.name );
stream_vid.find('span[class="epgtime_now"]').html( 'Duration: ' + program.duration );
desc='format: ' + program.format + 'video: ' + program.video + 'audio: ' + program.audio + 'resolution: ' + program.resolution;
stream_vid.find('span[class="desc_now"]').html( desc );
stream_vid.find('span[rel="url"]').html( path );
stream_vid.find('span[rel="type"]').html('vid');
json_complete('#streamvid','dissolve');
});
}
//Gen streaming page
function gen_streaming(session) {
streaming = $('#streaming');
streaming.find('span[rel="session"]').html(session);
var dataString = "action=getStreamInfo&session=" + session;
//Json call to start streaming
$.getJSON("bin/backend.php",
dataString,
function(data){
var stream = data.stream;
var time = new Date();
streaming.find('#thumbnail').attr('src','ram/session' + stream.session + '/thumb.png?'+time);
streaming.find('span[rel="thumbwidth"]').html(stream.thumbwidth);
streaming.find('span[rel="thumbheight"]').html(stream.thumbheight);
if (stream.type == "tv")
{
streaming.find('h1').html(' ' + stream.name );
streaming.find('#player').css('width', '90px');
var streaminfo = 'Now: ' + stream.now_title + ' ';
streaminfo += '' + stream.now_time + ' ';
streaminfo += '' + stream.now_desc + ' ';
streaminfo += 'Next: ' + stream.next_title + ' ';
streaminfo += '' + stream.next_time + ' ';
streaming.find('ul[class="streaminfo"]').html(streaminfo);
}
else if (stream.type == "rec")
{
streaming.find('h1').html(' ' + stream.name );
streaming.find('#player').css('width', '90px');
var streaminfo = '' + stream.name + ' ';
streaminfo += 'Recorded: ' + stream.recorded + ' ';
streaminfo += '' + stream.desc + ' ';
streaming.find('ul[class="streaminfo"]').html(streaminfo);
}
else if (stream.type == "vid")
{
streaming.find('h1').html(' ' + stream.name );
streaming.find('#player').css('width', '190px');
var streaminfo = '' + stream.name + ' ';
streaminfo += 'Duration: ' + stream.duration + ' ';
desc='format: ' + stream.format + 'video: ' + stream.video + 'audio: ' + stream.audio + 'resolution: ' + stream.resolution;
streaminfo += '' + desc + ' ';
streaming.find('ul[class="streaminfo"]').html(streaminfo);
}
streaming.find('ul[class="streamstatus"]').find('span[class="mode"]').html('Please wait.');
streaming.find('span[rel="name"]').html(stream.name);
json_complete('#streaming','dissolve');
});
}
//Start broadcast
function start_broadcast(type,url,mode) {
var dataString = 'action=startBroadcast&type='+type+'&url='+encodeURIComponent(url)+'&mode=' + mode;
$.getJSON("bin/backend.php",
dataString,
function(data){
var session = data.session;
gen_streaming(session);
});
}
//Stop broadcast
function stop_broadcast(session) {
var dataString = 'action=stopBroadcast&session='+session;
$.getJSON("bin/backend.php",
dataString,
function(data) {
var status = data.status;
var message = data.message;
hide_loader();
jQT.goBack();
});
}
//Get server status & Play video
function playvideo(session,name) {
var prevmsg="";
var status_OnComplete = function(data) {
streaming = $('#streaming');
var status = data.status;
var message = data.message;
var url = data.url;
var time = new Date();
var thumbwidth = streaming.find('span[rel="thumbwidth"]').text();
var thumbheight = streaming.find('span[rel="thumbheight"]').text();
streaming.find('ul[class="streamstatus"]').find('span[class="mode"]').html(message);
if ( status == "ready" || status == "error" ) {
streaming.find('#player').removeAttr("style");
streaming.find('#player').html(' ');
return false;
}
prevmsg = message;
status_Start(session,prevmsg);
}
var status_Start = function(session,prevmsg) {
dataString = "action=getStreamStatus&session=" + session + "&msg=" + encodeURIComponent(prevmsg);
$.getJSON("bin/backend.php",
dataString,
function(data){
status_OnComplete(data)
});
}
status_Start(session,prevmsg);
}
// [/STREAM SECTION]
// [BROWSER SECTION]
//buttons
$('ul[rel="filelist"] li[class="arrow"] a').tap(function(event) {
event.preventDefault();
json_start(this);
var type = $(this).attr('rel');
if ( type == 'audio' ) {
var name = $(this).find('span[class="tracktitle"]').text();
}
else {
var name = $(this).find('span[class="menuname"]').text();
}
var browser = $(this).parents('div').find('span[rel="currentbrowser"]').html();
var foldertype = $('#browser'+browser+' span[rel="foldertype"]').html();
var path = $('#browser'+browser+' span[rel="path"]').text();
browser = parseInt(browser);
browser++;
if ( type == "folder" )
{
newpath=path+name+'/';
gen_browser(newpath,browser,name,foldertype);
}
else if ( type == "rec" )
{
var path = $(this).find('span[class=filepath]').attr('rel');
gen_streamrec(name,path);
}
else if ( type == "video" )
{
var path = $(this).find('span[class=filepath]').attr('rel');
gen_streamvid(name,path);
}
return false;
});
$('div[rel="browser"] a[class="back"]').tap(function(event) {
event.preventDefault();
$(this).parents('div[rel="browser"]').remove();
});
//Generate browser div according to type
function gen_browser(path,browser,name,foldertype) {
browser_template = '
';
browser_template += '';
browser_template += ''
browser_template += ' ';
browser_template += ' ';
browser_template += '' + foldertype + ' ';
browser_template += '
';
$('#jqt').append('
'),
$('#browser'+browser).html(browser_template);
if ( path == rec_path || path == video_path || path == audio_path ) {
toolbar = 'Home ';
if ( foldertype == 'rec' ){
toolbar += ' ' + name + ' ';
}
else if ( foldertype == 'vid' ){
toolbar += ' ' + name + ' ';
}
else if ( foldertype == 'aud' ){
toolbar += ' ' + name + ' ';
}
$('#browser' + browser + ' div[class="toolbar"]').html(toolbar);
}
else {
toolbar = 'Back ';
toolbar += 'Home ';
if ( foldertype == 'rec' ){
toolbar += ' ' + name + ' ';
}
else if ( foldertype == 'vid' ){
toolbar += ' ' + name + ' ';
}
else if ( foldertype == 'aud' ){
toolbar += ' ' + name + ' ';
}
$('#browser' + browser + ' div[class="toolbar"]').html(toolbar);
}
var dataString = 'action=browseFolder&path='+encodeURIComponent(path);
$.getJSON("bin/backend.php",
dataString,
function(data) {
$("#browser" + browser).find('ul').html('');
$("#browser" + browser).find('span[rel="path"]').html(path);
$("#browser" + browser).find('span[rel="currentbrowser"]').html(browser);
$.each(data.list, function(i,list){
if ( i > 10 ) {
hidetoggle = 'toggle';
}
else
{
hidetoggle = '';
}
if (list.type == "folder") {
$("#browser" + browser).find('ul').append(' ');
}
else if (list.type == "rec") {
$("#browser" + browser).find('ul').append(' ');
}
else if ( list.type == "video" ) {
$("#browser" + browser).find('ul').append(' ');
}
else if ( list.type == "audio" ) {
if ( list.trackname != "" ) {
name = list.trackname;
} else {
name = list.name; }
$("#browser" + browser).find('ul').append('' + list.number + '
' + name + ' ' + list.length +'
');
}
});
$('li[rel="toggle"]').hide();
json_complete('#browser' + browser,'dissolve');
});
}
//Add audio player code when needed
function addplayer(button) {
json_start(button);
var name = $(button).find('span[class="tracktitle"]').attr('rel');
var browser = $(button).parents('div').find('span[rel="currentbrowser"]').html();
var path = $('#browser'+browser+' div[rel="dataholder"] span[rel="path"]').text();
browser = parseInt(browser);
$('#browser'+browser+' #div_player').remove();
$('#browser'+browser).append('
');
//get playlist data
dataString = 'action=streamAudio&path=' + encodeURIComponent(path) + '&file=' + encodeURIComponent(name);
$.ajax({
url: "bin/backend.php",
dataType: 'json',
data: dataString,
async: false,
success: function(json) {
var track = json.track;
playercode = "'";
playercode += "qtnext" + i + "=" + qtattr;
}
playercode += "> ";
$('#div_player').html(playercode);
hide_loader();
return true;
}
});
}
// [/BROWSER SECTION]
// [TIMER SECTION]
// buttons
$('#timers li[class="arrow"] a').tap(function(event) {
event.preventDefault();
$(this).addClass('active');
if ( $(this).attr('rel') == "new" ) {
gen_edittimer();
} else {
timerid = $(this).attr('rel');
timerdata = $('#timers ul[rel="timers"] li a[rel="' + timerid + '"]').data("timerdata");
id = timerdata.id;
name = timerdata.name;
active = timerdata.active;
channumber = timerdata.channumber;
channame = timerdata.channame;
date = timerdata.date;
starttime = timerdata.starttime;
endtime = timerdata.endtime;
gen_edittimer(id,name,active,channumber,channame,date,starttime,endtime);
}
});
$('#edittimer a[rel="deletetimer"]').tap(function(event) {
event.preventDefault();
json_start(this);
var timer_id = $("input#timer_id").val();
dataString = 'action=delTimer&id=' + timer_id;
$.getJSON("bin/backend.php",
dataString,
function(data) {
message = data.status + ": " + data.message;
gen_timers("true");
showStatus( 0,message );
return false;
});
});
// gen Timers
function gen_timers(edit) {
$('#timers ul[rel="timers"]').html('');
var dataString = 'action=getTimers';
$.getJSON("bin/backend.php",
dataString,
function(data) {
$('#timers ul[rel="timers"]').append(' ');
$.each(data.timer, function(i,timer){
if ( i > 10 ) {
togglestatus = "toggle";
}
else {
togglestatus = "";
}
if ( timer.running == "1" ) {
timerli = ' ';
}
else
{
if ( timer.active == "1" ) {
timerli = ' ';
} else {
timerli = ' ';
}
}
$('#timers ul[rel="timers"]').append(timerli);
$('#timers ul[rel="timers"] li a[rel="' + timer.id + '"]').data("timerdata", timer);
});
if ( edit ) {
hide_loader();
jQT.goBack();
}
else {
json_complete('#timers','dissolve');
}
});
}
function gen_edittimer(id,name,active,channumber,channame,date,starttime,endtime) {
$('ul[ref="submitbut"]').remove();
if (id) {
if (id=="new") {
$('#edittimer h1').html(' NEW TIMER');
id="";
submitbutton = '';
$('#timer').append(submitbutton);
}
else
{
$('#edittimer h1').html(' EDIT TIMER');
submitbuttons = '';
submitbuttons += 'Edit ';
submitbuttons += 'Delete ';
$('#timer').append(submitbuttons);
}
if (active == 1)
{
$('#timer_active').attr('checked', true);
}
else {
$('#timer_active').attr('checked', false);
}
$('#timer_id').val(id);
$('#timer_name').val(name);
$('#timer_chan option[value="' + channumber + '"]').attr("selected", "selected");
$('#timer_date').val(date);
var wheeldate = date;
while (wheeldate.indexOf("/") > -1)
wheeldate = wheeldate.replace("/", ",");
$('#a_date').attr('href', "javascript:openSelectDate(" + wheeldate + ");");
$('#layer_date').html(date);
$('#timer_starttime').val(starttime);
$('#timer_endtime').val(endtime);
wheelstart_h = starttime.substring(0,2);
wheelstart_m = starttime.substring(2,4);
$('#layer_starttime').html(wheelstart_h + 'h' + wheelstart_m);
$('#a_starttime').attr('href', "javascript:openSelectTime('layer_starttime','" + wheelstart_h + "','" + wheelstart_m + "')");
wheelend_h = endtime.substring(0,2);
wheelend_m = endtime.substring(2,4);
$('#layer_endtime').html(wheelend_h + 'h' + wheelend_m);
$('#a_endtime').attr('href', "javascript:openSelectTime('layer_endtime','" + wheelend_h + "','" + wheelend_m + "')");
}
else {
$('#edittimer h1').html(' NEW TIMER');
$('#timer_active').attr("checked", "checked");
$('#timer_id').val(null);
$('#timer_name').val(null);
$('#timer_chan option').removeAttr("selected");
$('#timer_chan option[value="1"]').attr("selected", "selected");
$('#a_date').attr('href', "javascript:openSelectDate();");
$('#layer_date').html("Select date");
$('#timer_date').val(null);
$('#timer_starttime').val(null);
$('#timer_endtime').val(null);
$('#a_starttime').attr('href', "javascript:openSelectTime('layer_starttime')");
$('#layer_starttime').html('Select start time');
$('#a_endtime').attr('href', "javascript:openSelectTime('layer_endtime')");
$('#layer_endtime').html('select end time');
submitbutton = '';
$('#timer').append(submitbutton);
}
$('.formerror').hide();
json_complete('#edittimer','dissolve');
}
//get full chanlist for timer page ( doing it one time on document load ).
function gen_formchanlist() {
showStatus( 0,"Getting VDR channels list" );
var dataString = 'action=getFullChanList';
$.getJSON("bin/backend.php",
dataString,
function(data) {
$('#jqt').data('channellist',data);
$.each(data.category, function(i,category){
$('#timer_chan').append('');
var catname = category.name;
$.each(category.channel, function(j, channel){
$('#timer_chan optgroup[label="' + catname +'"]').append('' + channel.name +' ');
});
$('#timer_chan').append(' ');
});
gen_epgchanlist();
});
}
// TIMER FORM VALIDATION & SUBMIT
$('.submit_form').tap(function(event) {
event.preventDefault();
checktimerform();
$(this).removeClass('active');
});
function checktimerform() {
$('.formerror').hide();
var timer_name = $("input#timer_name").val();
if (timer_name == "") {
$.scrollTo('#edittimer .toolbar', 400, {easing:'swing'});
$("li#timer_name_error").show();
return false;
}
var timer_date = $("input#timer_date").val();
if (timer_date == "") {
$("li#timer_date_error").show();
$.scrollTo('#edittimer #timer_date_error');
return false;
}
var timer_starttime = $("input#timer_starttime").val();
if (timer_starttime == "") {
$("li#timer_starttime_error").show();
$.scrollTo('#edittimer #timer_starttime_error');
return false;
}
var timer_endtime = $("input#timer_endtime").val();
if (timer_endtime == "") {
$("li#timer_endtime_error").show();
$.scrollTo('#edittimer #timer_endtime_error');
return false;
}
var timer_id = $("input#timer_id").val();
var timer_chan = $("select#timer_chan").val();
var timer_active = $("input#timer_active").attr('checked')?1:0;
var dataString = 'action=editTimer&id=' + timer_id + '&active=' + timer_active + '&name=' + encodeURIComponent(timer_name) + '&channumber=' + timer_chan + '&date=' + timer_date + '&starttime=' + timer_starttime + '&endtime=' + timer_endtime;
$.getJSON("bin/backend.php",
dataString,
function(data) {
message = data.status + ": " + data.message;
gen_timers("true");
json_start(this);
showStatus( 0,message );
});
return false;
};
// [/TIMER SECTION]
// [EPG SECTION]
//buttons & events
$('.submit_epg').tap(function(event) {
event.preventDefault();
channel = $('#epgform #epg_chan').val();
time = $('#epgform #epg_time').val();
day = $('#epgform #epg_day').val();
if ( channel == "all" && time == "") {
alert("You have to select a time for All channels listing");
$(this).removeClass('active');
return false;
}
if ( time == "" ) {
programs = "day";
}
else if ( channel == "all" ) {
programs = 2;
} else {
programs = "day";
}
json_start(this);
get_epg(channel,time,day,programs);
$(this).removeClass('active');
});
$('#epg ul li a[rel="whatsnow"]').tap(function(event) {
event.preventDefault();
json_start(this);
get_epg("all","now","0","2");
});
$('#epglist #ul_epglist a.epgdetailsbutton').tap(function(event) {
event.preventDefault();
json_start(this);
channum = $(this).attr("rel");
epgtime = $(this).find('span[class="epgtime"]').text();
startingtime = epgtime.substring(0,2) + '' + epgtime.substring(3,5);
day = $('#epglist div[rel="dataholder"] span[rel="day"]').text();
get_epgdetails(channum,startingtime,day);
});
$('#epglist #ul_epglist a[rel="epgchan"]').tap(function(event) {
event.preventDefault();
json_start(this);
channum = $(this).find('span').text();
day = $('#epglist div[rel="dataholder"] span[rel="day"]').text();
get_epg(channum,"",day,"day")
});
$('#epgdetails span.recButton a').tap(function(event) {
event.preventDefault();
json_start(this);
var id = "new";
var active= 1;
var name = $("#epgdetails").find('span[class="name_now"]').text();
var channumber = $("#epgdetails" ).find('span[rel="number"]').text();
var channame = $("#epgdetails").find('span[rel="channame"]').text();
var rec_date = $("#epgdetails").find('span[rel="date"]').text();
var starttime = $("#epgdetails").find('span[rel="stime"]').text();
var endtime = $("#epgdetails").find('span[rel="etime"]').text();
gen_edittimer(id,name,active,channumber,channame,rec_date,starttime,endtime);
return false;
});
$('#epgdetails span.streamButton a').tap(function(event) {
event.preventDefault();
json_start(this);
var url = $("#epgdetails").find('span[rel="url"]').text();
var mode = $(this).attr('id');
start_broadcast('tv',url,mode);
return false;
});
//functions
function gen_epgchanlist() {
epg_chan = $('#epg #epg_chan');
epg_chan.html('All channels ');
datachanlist = $('#jqt').data('channellist');
$.each(datachanlist.category, function(i,category){
epg_chan.append('');
var catname = category.name;
$.each(category.channel, function(j, channel){
epg_chan.find('optgroup[label="' + catname +'"]').append('' + channel.name +' ');
});
epg_chan.append(' ');
});
}
function gen_epgdatelist() {
var date = new Date();
var date_year = date.getFullYear();
var date_month = date.getMonth()+1;
var date_day = date.getDate();
epg_day = $('#epg #epg_day');
epg_day.html('Today ');
var dayname = new Array( "Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat" );
for ( i=1;i' + dayname[date.getDay()] + ' ' + date.getDate() + '/' + (date.getMonth()+1) + '');
}
}
function genepg_timelist() {
starth = 0;
startm = 0;
epg_time = $('#epg #epg_time');
epg_time.append('All ');
for ( i=0;i<24;i++ ) {
curh = str_pad(starth+i,2,'0','STR_PAD_LEFT');
for ( j=0;j<4;j++) {
curm = str_pad(startm+(j*15),2,'0','STR_PAD_LEFT');
epg_time.append('' + curh + 'h' + curm + ' ');
}
}
}
function get_epg(channel,time,day,programs) {
var dataString = 'action=getEpg&channel=' + channel + '&time=' + time + '&day=' + day + '&programs=' + programs;
$.getJSON("bin/backend.php",
dataString,
function(data) {
$('#jqt').data("epg",data);
if ( data.category.length > 1 ) {
type = 'cat';
parse_epg(data,0,type,day);
} else {
type = 'chan';
parse_epg(data,channel,type,day);
}
});
}
function parse_epg(data,selectedvalue,type,day){
epg_list = $('#epglist');
epg_selector = epg_list.find('#epg_selector');
epg_selector.html('');
ul_epglist = epg_list.find('#ul_epglist');
ul_epglist.html('');
epg_list.find('div[rel="dataholder"] span[rel="day"]').html(day);
date = new Date();
var date_milli=date.getTime();
date.setTime(date_milli+(86400000*day));
var date_year = date.getFullYear();
var date_month = str_pad(date.getMonth()+1,2,'0','STR_PAD_LEFT');
var date_day = str_pad(date.getDate(),2,'0','STR_PAD_LEFT');
var epgdate = date_year + "-" + date_month + "-" + date_day;
epg_list.find('h1').html(epgdate);
if ( data.category.length > 1 )
{
epg_selector.append(' ');
epglist_cat = epg_selector.find('#epglist_cat');
$.each(data.category, function(i,category){
epglist_cat.append('' + category.name + ' ');
});
epg_selector.find('select option[value=' + selectedvalue + ']').attr("selected", "selected");
}
else {
epg_selector.append(' ');
datalistchan = $('#jqt').data('channellist');
epglist_chan = epg_selector.find('#epglist_chan');
$.each(datalistchan.category, function(i,category){
epglist_chan.append('');
var catname = category.name;
$.each(category.channel, function(j, channel){
epglist_chan.find('optgroup[label="' + catname +'"]').append('' + channel.name +' ');
});
epglist_chan.append(' ');
});
epg_selector.find('select option[value=' + selectedvalue + ']').attr("selected", "selected");
}
var k=1;
if ( type == "cat" ) {
arrayvalue = selectedvalue;
} else {
arrayvalue = 0;
}
$.each(data.category[arrayvalue].channel, function(i,channel){
if ( k > 10 ) {
togglestatus = 'toggle';
}
else
{
togglestatus = '';
}
k++;
ul_epglist.append('' + channel.number + ' ' + ' - ' + channel.name + ' ');
$.each(channel.epg, function(j,epg){
if ( k > 10 ) {
togglestatus = 'toggle';
}
else
{
togglestatus = '';
}
ul_epglist.append('' + epg.time + ' ' + epg.title + ' ');
k++;
});
});
epg_selector.find('select').change(function () {
epgdata = $('#jqt').data("epg");
selectedvalue = epg_selector.find('select option:selected').val();
if (epg_selector.find('select').attr("id") == 'epglist_cat') {
parse_epg(epgdata,selectedvalue,'cat',day);
} else {
time = $('#epgform #epg_time').val();
day = $('#epgform select##epg_day').val();
if ( time == "" ) {
programs = "day";
}
else if ( channel == "all" ) {
programs = 2;
} else {
programs = "day";
}
json_start('null');
get_epg(selectedvalue,time,day,programs);
}
});
if ( $('div[class="current"]').attr('id') == "epg" || $('div[class="current reverse"]').attr('id') == "epg") {
json_complete('#epglist','dissolve');
}
else {
epg_list.find('li[rel="toggle"]').show();
hide_loader();
}
}
function get_epgdetails(channum,startingtime,day) {
var dataString = 'action=getEpgInfo&channel=' + channum + '&time=' + startingtime + '&day=' + day;
$.getJSON("bin/backend.php",
dataString,
function(data) {
name = data.program.name;
date = data.program.date;
time = data.program.time;
title = data.program.title;
desc = data.program.desc;
stime = startingtime;
running = data.program.running;
etime = time.substring(6,8) + epgtime.substring(9);
epg_details = $('#epgdetails');
epg_details.find('h1').html('' + name);
epg_details.find('ul[class="thumb"] img[class="thumbnail"]').attr('src','logos/'+name+'.png');
epg_details.find('ul[class="streaminfo"] li span[class="name_now"]').html(title);
epg_details.find('ul[class="streaminfo"] li span[class="epgtime_now"]').html(date + ' ' + time);
epg_details.find('ul[class="streaminfo"] li span[class="desc_now"]').html(desc);
epg_details.find('div[rel="dataholder"] span[rel="number"]').html(channum);
epg_details.find('div[rel="dataholder"] span[rel="channame"]').html(name);
epg_details.find('div[rel="dataholder"] span[rel="date"]').html(date);
epg_details.find('div[rel="dataholder"] span[rel="stime"]').html(stime);
epg_details.find('div[rel="dataholder"] span[rel="etime"]').html(etime);
epg_details.find('div[rel="dataholder"] span[rel="url"]').html(streamdev_server + channum);
if ( running == "yes" ) {
epg_details.find('#epgdetails_buttons').html('Edge 3G Wifi Rec. ');
} else {
epg_details.find('#epgdetails_buttons').html('Rec. ');
}
json_complete('#epgdetails','dissolve');
});
}
// [/EPG SECTION]