diff --git a/airtime_mvc/application/models/Show.php b/airtime_mvc/application/models/Show.php index 9a0eaa452..d9467cfc1 100644 --- a/airtime_mvc/application/models/Show.php +++ b/airtime_mvc/application/models/Show.php @@ -186,6 +186,7 @@ SQL; /* Check if the show being resized and any of its repeats * overlap with other scheduled shows */ + $utc = new DateTimeZone("UTC"); foreach ($showInstances as $si) { $startsDateTime = new DateTime($si->getDbStarts(), new DateTimeZone("UTC")); @@ -223,15 +224,10 @@ SQL; $sql_gen = << :current_timestamp1) - AND ((ends + interval :deltaDay2 + interval :interval2 - starts) <= interval '24:00') - -UPDATE cc_show_days -SET duration = (CAST(duration AS interval) + interval :deltaDay3 + interval :interval3) -WHERE show_id = :show_id2 - AND ((CAST(duration AS interval) + interval :deltaDay4 + interval :interval4) <= interval '24:00') + AND ((ends + :deltaDay2::INTERVAL + :interval2::INTERVAL - starts) <= interval '24:00') SQL; Application_Common_Database::prepareAndExecute($sql_gen, @@ -241,7 +237,18 @@ SQL; ':show_id1' => $this->_showId, ':current_timestamp1' => $current_timestamp, ':deltaDay2' => "$deltaDay days", - ':interval2' => "$hours:$mins", + ':interval2' => "$hours:$mins" + ), "execute"); + + $sql_gen = << "$deltaDay days", ':interval3' => "$hours:$mins", ':show_id2' => $this->_showId, diff --git a/airtime_mvc/application/views/scripts/audiopreview/audio-preview.phtml b/airtime_mvc/application/views/scripts/audiopreview/audio-preview.phtml index 3404cf6e1..b4ec52bdf 100644 --- a/airtime_mvc/application/views/scripts/audiopreview/audio-preview.phtml +++ b/airtime_mvc/application/views/scripts/audiopreview/audio-preview.phtml @@ -7,8 +7,8 @@ blockId" ?> blockIndex" ?> uri)): ?> - uri" ?> - mime" ?> + + audioFileTitle" ?> audioFileArtist" ?> showID)): ?> diff --git a/airtime_mvc/public/js/airtime/audiopreview/preview_jplayer.js b/airtime_mvc/public/js/airtime/audiopreview/preview_jplayer.js index 56a4afa64..0f5a0b0fe 100644 --- a/airtime_mvc/public/js/airtime/audiopreview/preview_jplayer.js +++ b/airtime_mvc/public/js/airtime/audiopreview/preview_jplayer.js @@ -8,6 +8,17 @@ var _idToPostionLookUp; */ $(document).ready(function(){ + $.jPlayer.timeFormat.showHour = true; + + var audioUri = $('.audioUri').text(); + var audioMime = $('.audioMime').text(); + var playlistID = $('.playlistID').text(); + var playlistIndex = $('.playlistIndex').text(); + var showID = $('.showID').text(); + var showIndex = $('.showIndex').text(); + var blockId = $('.blockId').text(); + var blockIndex = $('.blockIndex').text(); + _playlist_jplayer = new jPlayerPlaylist({ jPlayer: "#jquery_jplayer_1", cssSelectorAncestor: "#jp_container_1" @@ -29,33 +40,20 @@ $(document).ready(function(){ addTime: 0, removeTime: 0, shuffleTime: 0 + }, + ready: function(){ + if (playlistID != "" && playlistID !== ""){ + playAllPlaylist(playlistID, playlistIndex); + }else if (audioUri != "") { + playOne(audioUri, audioMime); + }else if (showID != "") { + playAllShow(showID, showIndex); + }else if(blockId != "" && blockIndex != ""){ + playBlock(blockId, blockIndex); + } } }); - - - $.jPlayer.timeFormat.showHour = true; - - var audioUri = $('.audioUri').text(); - var audioMime = $('.audioMime').text(); - var playlistID = $('.playlistID').text(); - var playlistIndex = $('.playlistIndex').text(); - var showID = $('.showID').text(); - var showIndex = $('.showIndex').text(); - var blockId = $('.blockId').text(); - var blockIndex = $('.blockIndex').text(); - var numOfItems = 0; - - if (playlistID != "" && playlistID !== ""){ - playAllPlaylist(playlistID, playlistIndex); - }else if (audioUri != "") { - playOne(audioUri, audioMime); - }else if (showID != "") { - playAllShow(showID, showIndex); - }else if(blockId != "" && blockIndex != ""){ - playBlock(blockId, blockIndex); - } - $("#jp_container_1").on("mouseenter", "ul.jp-controls li", function(ev) { $(this).addClass("ui-state-hover"); }); @@ -63,6 +61,7 @@ $(document).ready(function(){ $("#jp_container_1").on("mouseleave", "ul.jp-controls li", function(ev) { $(this).removeClass("ui-state-hover"); }); + }); /** @@ -223,7 +222,7 @@ function playOne(uri, mime) { if (media) { _playlist_jplayer.option("autoPlay", true); playlist[0] = media; - _playlist_jplayer._initPlaylist(playlist); + _playlist_jplayer.setPlaylist(playlist); _playlist_jplayer.play(0); } diff --git a/airtime_mvc/public/js/airtime/library/library.js b/airtime_mvc/public/js/airtime/library/library.js index 795bcb010..2f70037cd 100644 --- a/airtime_mvc/public/js/airtime/library/library.js +++ b/airtime_mvc/public/js/airtime/library/library.js @@ -1089,7 +1089,7 @@ function validateAdvancedSearch(divs) { if (!valid) allValid = false; } - addRemoveValidationIcons(valid, $(field)); + addRemoveValidationIcons(valid, $(field), searchTermType); /* Empty fields should not have valid/invalid indicator * Range values are considered valid even if only the @@ -1114,9 +1114,20 @@ function validateAdvancedSearch(divs) { return allValid; } -function addRemoveValidationIcons(valid, field) { - var validIndicator = "", - invalidIndicator = ""; +function addRemoveValidationIcons(valid, field, searchTermType) { + var title = ''; + if (searchTermType === 'i') { + title = 'Input must be a positive number'; + } else if (searchTermType === 'n') { + title = 'Input must be a number'; + } else if (searchTermType === 't') { + title = 'Input must be in the format: yyyy-mm-dd'; + } else if (searchTermType === 'l') { + title = 'Input must be in the format: hh:mm:ss.t'; + } + + var validIndicator = " ", + invalidIndicator = " "; if (valid) { if (!field.closest('div').children(':last-child').hasClass('checked-icon')) { diff --git a/airtime_mvc/public/js/qtip/jquery.qtip.js b/airtime_mvc/public/js/qtip/jquery.qtip.js index 6871a036b..fe9ac3fb5 100644 --- a/airtime_mvc/public/js/qtip/jquery.qtip.js +++ b/airtime_mvc/public/js/qtip/jquery.qtip.js @@ -1247,7 +1247,6 @@ function QTip(target, options, id, attr) position.top -= offset; } else if(overflowBottom > 0 && (my.y !== 'bottom' || overflowTop > 0) ) { - console.log('test'); position.top -= isCenter ? -offset : offset; } if(position.top !== posTop && isCenter) { position.top -= adjust.y; } @@ -3241,4 +3240,4 @@ PLUGINS.bgiframe = function(api) PLUGINS.bgiframe.initialize = 'render'; -}(jQuery, window)); \ No newline at end of file +}(jQuery, window)); diff --git a/dev_tools/fabric/fab_liquidsoap_compile.py b/dev_tools/fabric/fab_liquidsoap_compile.py index a9548756f..55714cbe5 100644 --- a/dev_tools/fabric/fab_liquidsoap_compile.py +++ b/dev_tools/fabric/fab_liquidsoap_compile.py @@ -206,6 +206,7 @@ libcamomile-ocaml-dev libcamlimages-ocaml-dev libtool libpulse-dev libjack-dev c sed('%s/savonet/PACKAGES' % root, '#ocaml-alsa', 'ocaml-alsa') sed('%s/savonet/PACKAGES' % root, '#ocaml-pulseaudio', 'ocaml-pulseaudio') sed('%s/savonet/PACKAGES' % root, '#ocaml-faad', 'ocaml-faad') + do_run('cd %s/savonet && make clean' % root) do_run('cd %s/savonet && ./bootstrap' % root) do_run('cd %s/savonet && ./configure' % root) do_run('cd %s/savonet && make' % root)